2023-01-27 03:22:44 -08:00
|
|
|
import type { INodeProperties } from 'n8n-workflow';
|
2020-03-04 09:05:54 -08:00
|
|
|
|
2021-12-03 00:44:16 -08:00
|
|
|
export const expenseOperations: INodeProperties[] = [
|
2020-03-04 09:05:54 -08:00
|
|
|
{
|
|
|
|
displayName: 'Operation',
|
|
|
|
name: 'operation',
|
|
|
|
type: 'options',
|
2022-05-20 14:47:24 -07:00
|
|
|
noDataExpression: true,
|
2020-03-04 09:05:54 -08:00
|
|
|
displayOptions: {
|
|
|
|
show: {
|
2022-08-17 08:50:24 -07:00
|
|
|
resource: ['expense'],
|
2020-03-04 09:05:54 -08:00
|
|
|
},
|
|
|
|
},
|
|
|
|
options: [
|
|
|
|
{
|
|
|
|
name: 'Create',
|
|
|
|
value: 'create',
|
|
|
|
description: 'Create a new expense',
|
2022-07-10 13:50:51 -07:00
|
|
|
action: 'Create an expense',
|
2020-03-04 09:05:54 -08:00
|
|
|
},
|
2020-03-16 15:26:27 -07:00
|
|
|
{
|
|
|
|
name: 'Delete',
|
|
|
|
value: 'delete',
|
|
|
|
description: 'Delete an expense',
|
2022-07-10 13:50:51 -07:00
|
|
|
action: 'Delete an expense',
|
2020-03-16 15:26:27 -07:00
|
|
|
},
|
2020-03-04 09:05:54 -08:00
|
|
|
{
|
|
|
|
name: 'Get',
|
|
|
|
value: 'get',
|
2020-03-16 15:26:27 -07:00
|
|
|
description: 'Get data of an expense',
|
2022-07-10 13:50:51 -07:00
|
|
|
action: 'Get an expense',
|
2020-03-04 09:05:54 -08:00
|
|
|
},
|
|
|
|
{
|
2022-09-07 07:51:14 -07:00
|
|
|
name: 'Get Many',
|
2020-03-04 09:05:54 -08:00
|
|
|
value: 'getAll',
|
2022-09-13 03:36:36 -07:00
|
|
|
description: 'Get data of many expenses',
|
2022-09-08 08:10:13 -07:00
|
|
|
action: 'Get many expenses',
|
2020-03-04 09:05:54 -08:00
|
|
|
},
|
|
|
|
],
|
|
|
|
default: 'create',
|
|
|
|
},
|
2021-12-03 00:44:16 -08:00
|
|
|
];
|
2020-03-04 09:05:54 -08:00
|
|
|
|
2021-12-03 00:44:16 -08:00
|
|
|
export const expenseFields: INodeProperties[] = [
|
2022-08-17 08:50:24 -07:00
|
|
|
/* -------------------------------------------------------------------------- */
|
|
|
|
/* expense:create */
|
|
|
|
/* -------------------------------------------------------------------------- */
|
2020-03-04 09:05:54 -08:00
|
|
|
{
|
|
|
|
displayName: 'Additional Fields',
|
|
|
|
name: 'additionalFields',
|
|
|
|
type: 'collection',
|
|
|
|
placeholder: 'Add Field',
|
|
|
|
default: {},
|
|
|
|
displayOptions: {
|
|
|
|
show: {
|
2022-08-17 08:50:24 -07:00
|
|
|
operation: ['create'],
|
|
|
|
resource: ['expense'],
|
2020-03-04 09:05:54 -08:00
|
|
|
},
|
|
|
|
},
|
|
|
|
options: [
|
2020-03-16 15:26:27 -07:00
|
|
|
{
|
|
|
|
displayName: 'Amount',
|
|
|
|
name: 'amount',
|
|
|
|
type: 'number',
|
|
|
|
default: 0,
|
|
|
|
},
|
2020-03-04 09:05:54 -08:00
|
|
|
{
|
|
|
|
displayName: 'Billable',
|
|
|
|
name: 'billable',
|
|
|
|
type: 'boolean',
|
|
|
|
default: false,
|
|
|
|
},
|
|
|
|
{
|
2022-06-03 10:23:49 -07:00
|
|
|
displayName: 'Client Name or ID',
|
2020-03-04 09:05:54 -08:00
|
|
|
name: 'client',
|
|
|
|
type: 'options',
|
2022-08-17 08:50:24 -07:00
|
|
|
description:
|
|
|
|
'Choose from the list, or specify an ID using an <a href="https://docs.n8n.io/code-examples/expressions/">expression</a>',
|
2020-03-04 09:05:54 -08:00
|
|
|
typeOptions: {
|
|
|
|
loadOptionsMethod: 'getClients',
|
|
|
|
},
|
|
|
|
default: '',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
displayName: 'Custom Value 1',
|
|
|
|
name: 'customValue1',
|
|
|
|
type: 'string',
|
|
|
|
default: '',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
displayName: 'Custom Value 2',
|
|
|
|
name: 'customValue2',
|
|
|
|
type: 'string',
|
|
|
|
default: '',
|
|
|
|
},
|
|
|
|
{
|
2022-06-03 10:23:49 -07:00
|
|
|
displayName: 'Category Name or ID',
|
2020-03-04 09:05:54 -08:00
|
|
|
name: 'category',
|
|
|
|
type: 'options',
|
2022-08-17 08:50:24 -07:00
|
|
|
description:
|
|
|
|
'Choose from the list, or specify an ID using an <a href="https://docs.n8n.io/code-examples/expressions/">expression</a>',
|
2020-03-04 09:05:54 -08:00
|
|
|
typeOptions: {
|
|
|
|
loadOptionsMethod: 'getExpenseCategories',
|
|
|
|
},
|
|
|
|
default: '',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
displayName: 'Expense Date',
|
|
|
|
name: 'expenseDate',
|
|
|
|
type: 'dateTime',
|
|
|
|
default: '',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
displayName: 'Payment Date',
|
|
|
|
name: 'paymentDate',
|
|
|
|
type: 'dateTime',
|
|
|
|
default: '',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
displayName: 'Payment Type',
|
|
|
|
name: 'paymentType',
|
|
|
|
type: 'options',
|
|
|
|
options: [
|
2022-06-03 10:23:49 -07:00
|
|
|
{
|
|
|
|
name: 'ACH',
|
|
|
|
value: 5,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: 'Alipay',
|
|
|
|
value: 28,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: 'American Express',
|
|
|
|
value: 8,
|
|
|
|
},
|
2020-03-04 09:05:54 -08:00
|
|
|
{
|
|
|
|
name: 'Apply Credit',
|
|
|
|
value: 1,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: 'Bank Transfer',
|
|
|
|
value: 2,
|
|
|
|
},
|
|
|
|
{
|
2022-06-03 10:23:49 -07:00
|
|
|
name: 'Bitcoin',
|
|
|
|
value: 32,
|
2020-03-04 09:05:54 -08:00
|
|
|
},
|
|
|
|
{
|
2022-06-03 10:23:49 -07:00
|
|
|
name: 'Carte Blanche',
|
|
|
|
value: 17,
|
2020-03-04 09:05:54 -08:00
|
|
|
},
|
|
|
|
{
|
2022-06-03 10:23:49 -07:00
|
|
|
name: 'Cash',
|
|
|
|
value: 3,
|
2020-03-04 09:05:54 -08:00
|
|
|
},
|
|
|
|
{
|
2022-06-03 10:23:49 -07:00
|
|
|
name: 'Check',
|
|
|
|
value: 16,
|
2020-03-04 09:05:54 -08:00
|
|
|
},
|
|
|
|
{
|
2022-06-03 10:23:49 -07:00
|
|
|
name: 'Credit Card Other',
|
|
|
|
value: 13,
|
2020-03-04 09:05:54 -08:00
|
|
|
},
|
|
|
|
{
|
2022-06-03 10:23:49 -07:00
|
|
|
name: 'Debit',
|
|
|
|
value: 4,
|
2020-03-04 09:05:54 -08:00
|
|
|
},
|
|
|
|
{
|
|
|
|
name: 'Diners Card',
|
|
|
|
value: 10,
|
|
|
|
},
|
|
|
|
{
|
2022-06-03 10:23:49 -07:00
|
|
|
name: 'Discover Card',
|
|
|
|
value: 9,
|
2020-03-04 09:05:54 -08:00
|
|
|
},
|
|
|
|
{
|
2022-06-03 10:23:49 -07:00
|
|
|
name: 'EuroCard',
|
|
|
|
value: 11,
|
2020-03-04 09:05:54 -08:00
|
|
|
},
|
|
|
|
{
|
2022-06-03 10:23:49 -07:00
|
|
|
name: 'GoCardless',
|
|
|
|
value: 31,
|
2020-03-04 09:05:54 -08:00
|
|
|
},
|
|
|
|
{
|
|
|
|
name: 'Google Wallet',
|
|
|
|
value: 15,
|
|
|
|
},
|
|
|
|
{
|
2022-06-03 10:23:49 -07:00
|
|
|
name: 'iZettle',
|
|
|
|
value: 24,
|
2020-03-04 09:05:54 -08:00
|
|
|
},
|
|
|
|
{
|
|
|
|
name: 'JCB',
|
|
|
|
value: 19,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: 'Laser',
|
|
|
|
value: 20,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: 'Maestro',
|
|
|
|
value: 21,
|
|
|
|
},
|
|
|
|
{
|
2022-06-03 10:23:49 -07:00
|
|
|
name: 'MasterCard',
|
|
|
|
value: 7,
|
2020-03-04 09:05:54 -08:00
|
|
|
},
|
|
|
|
{
|
2022-06-03 10:23:49 -07:00
|
|
|
name: 'Money Order',
|
|
|
|
value: 27,
|
2020-03-04 09:05:54 -08:00
|
|
|
},
|
|
|
|
{
|
2022-06-03 10:23:49 -07:00
|
|
|
name: 'Nova',
|
|
|
|
value: 12,
|
2020-03-04 09:05:54 -08:00
|
|
|
},
|
|
|
|
{
|
2022-06-03 10:23:49 -07:00
|
|
|
name: 'Paypal',
|
|
|
|
value: 14,
|
2020-03-04 09:05:54 -08:00
|
|
|
},
|
|
|
|
{
|
2022-06-03 10:23:49 -07:00
|
|
|
name: 'SEPA',
|
|
|
|
value: 30,
|
2020-03-04 09:05:54 -08:00
|
|
|
},
|
|
|
|
{
|
2022-06-03 10:23:49 -07:00
|
|
|
name: 'Sofort',
|
|
|
|
value: 29,
|
2020-03-04 09:05:54 -08:00
|
|
|
},
|
|
|
|
{
|
2022-06-03 10:23:49 -07:00
|
|
|
name: 'Solo',
|
|
|
|
value: 22,
|
2020-03-04 09:05:54 -08:00
|
|
|
},
|
|
|
|
{
|
2022-06-03 10:23:49 -07:00
|
|
|
name: 'Swich',
|
|
|
|
value: 23,
|
2020-03-04 09:05:54 -08:00
|
|
|
},
|
|
|
|
{
|
2022-06-03 10:23:49 -07:00
|
|
|
name: 'Swish',
|
|
|
|
value: 25,
|
2020-03-04 09:05:54 -08:00
|
|
|
},
|
|
|
|
{
|
2022-06-03 10:23:49 -07:00
|
|
|
name: 'UnionPay',
|
|
|
|
value: 18,
|
2020-03-04 09:05:54 -08:00
|
|
|
},
|
|
|
|
{
|
2022-06-03 10:23:49 -07:00
|
|
|
name: 'Venmo',
|
|
|
|
value: 26,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
name: 'Visa Card',
|
|
|
|
value: 6,
|
2020-03-04 09:05:54 -08:00
|
|
|
},
|
|
|
|
],
|
|
|
|
default: 1,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
displayName: 'Private Notes',
|
|
|
|
name: 'privateNotes',
|
|
|
|
type: 'string',
|
|
|
|
default: '',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
displayName: 'Public Notes',
|
|
|
|
name: 'publicNotes',
|
|
|
|
type: 'string',
|
|
|
|
default: '',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
displayName: 'Tax Name 1',
|
|
|
|
name: 'taxName1',
|
|
|
|
type: 'string',
|
|
|
|
default: '',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
displayName: 'Tax Name 2',
|
|
|
|
name: 'taxName2',
|
|
|
|
type: 'string',
|
|
|
|
default: '',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
displayName: 'Tax Rate 1',
|
|
|
|
name: 'taxRate1',
|
|
|
|
type: 'number',
|
|
|
|
default: 0,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
displayName: 'Tax Rate 2',
|
|
|
|
name: 'taxRate2',
|
|
|
|
type: 'number',
|
|
|
|
default: 0,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
displayName: 'Transaction Reference',
|
|
|
|
name: 'transactionReference',
|
|
|
|
type: 'string',
|
|
|
|
default: '',
|
|
|
|
},
|
|
|
|
{
|
2022-06-03 10:23:49 -07:00
|
|
|
displayName: 'Vendor Name or ID',
|
2020-03-04 09:05:54 -08:00
|
|
|
name: 'vendor',
|
|
|
|
type: 'options',
|
2022-08-17 08:50:24 -07:00
|
|
|
description:
|
|
|
|
'Choose from the list, or specify an ID using an <a href="https://docs.n8n.io/code-examples/expressions/">expression</a>',
|
2020-03-04 09:05:54 -08:00
|
|
|
typeOptions: {
|
|
|
|
loadOptionsMethod: 'getVendors',
|
|
|
|
},
|
|
|
|
default: '',
|
|
|
|
},
|
2020-10-22 06:46:03 -07:00
|
|
|
],
|
2020-03-04 09:05:54 -08:00
|
|
|
},
|
2022-08-17 08:50:24 -07:00
|
|
|
/* -------------------------------------------------------------------------- */
|
|
|
|
/* expense:delete */
|
|
|
|
/* -------------------------------------------------------------------------- */
|
2020-03-04 09:05:54 -08:00
|
|
|
{
|
|
|
|
displayName: 'Expense ID',
|
|
|
|
name: 'expenseId',
|
|
|
|
type: 'string',
|
2021-12-03 00:44:16 -08:00
|
|
|
default: '',
|
2020-03-04 09:05:54 -08:00
|
|
|
required: true,
|
|
|
|
displayOptions: {
|
|
|
|
show: {
|
2022-08-17 08:50:24 -07:00
|
|
|
resource: ['expense'],
|
|
|
|
operation: ['delete'],
|
2020-03-04 09:05:54 -08:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2022-08-17 08:50:24 -07:00
|
|
|
/* -------------------------------------------------------------------------- */
|
|
|
|
/* expense:get */
|
|
|
|
/* -------------------------------------------------------------------------- */
|
2020-03-04 09:05:54 -08:00
|
|
|
{
|
|
|
|
displayName: 'Expense ID',
|
|
|
|
name: 'expenseId',
|
|
|
|
type: 'string',
|
2021-12-03 00:44:16 -08:00
|
|
|
default: '',
|
2020-03-04 09:05:54 -08:00
|
|
|
required: true,
|
|
|
|
displayOptions: {
|
|
|
|
show: {
|
2022-08-17 08:50:24 -07:00
|
|
|
resource: ['expense'],
|
|
|
|
operation: ['get'],
|
2020-03-04 09:05:54 -08:00
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
2022-08-17 08:50:24 -07:00
|
|
|
/* -------------------------------------------------------------------------- */
|
|
|
|
/* expense:getAll */
|
|
|
|
/* -------------------------------------------------------------------------- */
|
2020-03-04 09:05:54 -08:00
|
|
|
{
|
|
|
|
displayName: 'Return All',
|
|
|
|
name: 'returnAll',
|
|
|
|
type: 'boolean',
|
|
|
|
displayOptions: {
|
|
|
|
show: {
|
2022-08-17 08:50:24 -07:00
|
|
|
resource: ['expense'],
|
|
|
|
operation: ['getAll'],
|
2020-03-04 09:05:54 -08:00
|
|
|
},
|
|
|
|
},
|
|
|
|
default: false,
|
2022-05-06 14:01:25 -07:00
|
|
|
description: 'Whether to return all results or only up to a given limit',
|
2020-03-04 09:05:54 -08:00
|
|
|
},
|
|
|
|
{
|
|
|
|
displayName: 'Limit',
|
|
|
|
name: 'limit',
|
|
|
|
type: 'number',
|
|
|
|
displayOptions: {
|
|
|
|
show: {
|
2022-08-17 08:50:24 -07:00
|
|
|
resource: ['expense'],
|
|
|
|
operation: ['getAll'],
|
|
|
|
returnAll: [false],
|
2020-03-04 09:05:54 -08:00
|
|
|
},
|
|
|
|
},
|
|
|
|
typeOptions: {
|
|
|
|
minValue: 1,
|
|
|
|
maxValue: 60,
|
|
|
|
},
|
|
|
|
default: 50,
|
2022-05-06 14:01:25 -07:00
|
|
|
description: 'Max number of results to return',
|
2020-03-04 09:05:54 -08:00
|
|
|
},
|
2021-12-03 00:44:16 -08:00
|
|
|
];
|