2020-01-28 07:50:15 -08:00
import { INodeProperties } from "n8n-workflow" ;
2020-01-31 05:43:40 -08:00
const resource = [ 'invoices' ] ;
2020-01-28 07:50:15 -08:00
export const invoiceOperations = [
{
displayName : 'Operation' ,
name : 'operation' ,
type : 'options' ,
displayOptions : {
show : {
2020-01-31 05:43:40 -08:00
resource ,
2020-01-28 07:50:15 -08:00
} ,
} ,
options : [
{
name : 'Get' ,
value : 'get' ,
description : 'Get data of a invoice' ,
} ,
{
name : 'Get All' ,
value : 'getAll' ,
description : 'Get data of all invoices' ,
} ,
2020-02-03 03:57:39 -08:00
{
name : 'Create' ,
value : 'create' ,
description : ` Create a invoice ` ,
} ,
{
name : 'Update' ,
value : 'update' ,
description : ` Update a invoice ` ,
} ,
2020-01-31 04:47:20 -08:00
{
name : 'Delete' ,
value : 'delete' ,
description : ` Delete a invoice ` ,
} ,
2020-01-28 07:50:15 -08:00
] ,
2020-01-28 23:04:52 -08:00
default : 'getAll' ,
2020-01-28 07:50:15 -08:00
description : 'The operation to perform.' ,
} ,
] as INodeProperties [ ] ;
export const invoiceFields = [
/* -------------------------------------------------------------------------- */
/* invoice:getAll */
/* -------------------------------------------------------------------------- */
{
displayName : 'Return All' ,
name : 'returnAll' ,
type : 'boolean' ,
displayOptions : {
show : {
2020-01-31 05:43:40 -08:00
resource ,
2020-01-28 07:50:15 -08:00
operation : [
'getAll' ,
] ,
} ,
} ,
default : false ,
description : 'Returns a list of your invoices.' ,
} ,
{
displayName : 'Limit' ,
name : 'limit' ,
type : 'number' ,
displayOptions : {
show : {
2020-01-31 05:43:40 -08:00
resource ,
2020-01-28 07:50:15 -08:00
operation : [
'getAll' ,
] ,
returnAll : [
false ,
] ,
} ,
} ,
typeOptions : {
minValue : 1 ,
maxValue : 100 ,
} ,
default : 100 ,
description : 'How many results to return.' ,
} ,
{
displayName : 'Filters' ,
name : 'filters' ,
type : 'collection' ,
placeholder : 'Add Filter' ,
default : { } ,
displayOptions : {
show : {
2020-01-31 05:43:40 -08:00
resource ,
2020-01-28 07:50:15 -08:00
operation : [
'getAll' ,
] ,
} ,
} ,
options : [
{
displayName : 'Client ID' ,
name : 'client_id' ,
type : 'string' ,
default : '' ,
description : 'Only return time entries belonging to the client with the given ID.' ,
} ,
{
displayName : 'Project ID' ,
name : 'project_id' ,
type : 'string' ,
default : '' ,
description : 'Only return time entries belonging to the client with the given ID.' ,
} ,
{
displayName : 'Updated Since' ,
name : 'updated_since' ,
2020-01-29 15:51:14 -08:00
type : 'dateTime' ,
2020-01-28 07:50:15 -08:00
default : '' ,
description : 'Only return time entries that have been updated since the given date and time.' ,
} ,
{
displayName : 'From' ,
name : 'from' ,
type : 'dateTime' ,
default : '' ,
description : 'Only return time entries with a spent_date on or after the given date.' ,
} ,
{
displayName : 'To' ,
name : 'to' ,
type : 'dateTime' ,
default : '' ,
description : 'Only return time entries with a spent_date on or before the given date.' ,
} ,
{
displayName : 'State' ,
name : 'state' ,
type : 'multiOptions' ,
options : [
{
name : 'draft' ,
value : 'draft' ,
} ,
{
name : 'open' ,
value : 'open' ,
} ,
{
name : 'paid' ,
value : 'paid' ,
} ,
{
name : 'closed' ,
value : 'closed' ,
} ,
] ,
default : [ ] ,
description : 'Only return invoices with a state matching the value provided. Options: draft, open, paid, or closed.' ,
} ,
{
displayName : 'Page' ,
name : 'page' ,
2020-01-29 15:51:14 -08:00
type : 'number' ,
typeOptions : {
minValue : 1 ,
} ,
default : 1 ,
2020-01-28 07:50:15 -08:00
description : 'The page number to use in pagination. For instance, if you make a list request and receive 100 records, your subsequent call can include page=2 to retrieve the next page of the list. (Default: 1)' ,
}
]
} ,
/* -------------------------------------------------------------------------- */
/* invoice:get */
/* -------------------------------------------------------------------------- */
{
2020-01-28 23:04:52 -08:00
displayName : 'Invoice Id' ,
2020-01-28 07:50:15 -08:00
name : 'id' ,
type : 'string' ,
default : '' ,
required : true ,
displayOptions : {
show : {
operation : [
'get' ,
] ,
2020-01-31 05:43:40 -08:00
resource ,
2020-01-28 07:50:15 -08:00
} ,
} ,
description : 'The ID of the invoice you are retrieving.' ,
2020-01-31 04:47:20 -08:00
} ,
/* -------------------------------------------------------------------------- */
/* invoice:delete */
/* -------------------------------------------------------------------------- */
{
displayName : 'Invoice Id' ,
name : 'id' ,
type : 'string' ,
default : '' ,
required : true ,
displayOptions : {
show : {
operation : [
'delete' ,
] ,
2020-01-31 05:43:40 -08:00
resource ,
2020-01-31 04:47:20 -08:00
} ,
} ,
description : 'The ID of the invoice want to delete.' ,
2020-02-03 01:23:58 -08:00
} ,
/* -------------------------------------------------------------------------- */
/* invoice:create */
/* -------------------------------------------------------------------------- */
{
2020-02-03 04:55:21 -08:00
displayName : 'Client Id' ,
2020-02-03 01:23:58 -08:00
name : 'client_id' ,
type : 'string' ,
displayOptions : {
show : {
operation : [
'create' ,
] ,
resource ,
} ,
} ,
default : '' ,
required : true ,
description : 'The ID of the retainer associated with this invoice..' ,
} ,
{
displayName : 'Additional Fields' ,
name : 'additionalFields' ,
type : 'collection' ,
placeholder : 'Add Field' ,
displayOptions : {
show : {
operation : [
'create' ,
] ,
resource ,
} ,
} ,
default : { } ,
options : [
{
displayName : 'Retainer Id' ,
name : 'retainer_id' ,
type : 'boolean' ,
default : true ,
description : 'The ID of the retainer associated with this invoice.'
} ,
{
displayName : 'Estimate Id' ,
name : 'estimate_id' ,
type : 'string' ,
default : '' ,
description : 'The ID of the estimate associated with this invoice.'
} ,
{
displayName : 'Number' ,
name : 'number' ,
type : 'string' ,
default : '' ,
description : 'If no value is set, the number will be automatically generated.'
} ,
{
displayName : 'Purchase Order' ,
name : 'purchase_order' ,
type : 'string' ,
default : '' ,
description : 'The purchase order number.'
} ,
{
displayName : 'Tax' ,
name : 'tax' ,
type : 'string' ,
default : '' ,
description : 'This percentage is applied to the subtotal, including line items and discounts. Example: use 10.0 for 10.0%.'
} ,
{
displayName : 'Tax2' ,
name : 'tax2' ,
type : 'string' ,
default : '' ,
description : 'This percentage is applied to the subtotal, including line items and discounts. Example: use 10.0 for 10.0%.'
} ,
{
displayName : 'Discount' ,
name : 'over_budget_notification_percentage' ,
type : 'string' ,
default : '' ,
description : 'This percentage is subtracted from the subtotal. Example: use 10.0 for 10.0%.'
} ,
{
displayName : 'Subject' ,
name : 'subject' ,
type : 'string' ,
default : '' ,
description : 'The invoice subject.'
} ,
{
displayName : 'Currency' ,
name : 'currency' ,
type : 'string' ,
default : '' ,
description : 'The currency used by the invoice. If not provided, the client’ s currency will be used. See a list of supported currencies'
} ,
{
displayName : 'Payment Term' ,
name : 'payment_term' ,
type : 'string' ,
default : '' ,
description : 'The timeframe in which the invoice should be paid. Defaults to custom. Options: upon receipt, net 15, net 30, net 45, or net 60.'
} ,
{
displayName : 'Notes' ,
name : 'notes' ,
type : 'string' ,
default : '' ,
description : 'Notes about the project.'
} ,
{
displayName : 'Issue Date' ,
name : 'issue_date' ,
type : 'dateTime' ,
default : '' ,
description : 'Date the invoice was issued. Defaults to today’ s date.'
} ,
{
displayName : 'Due Date' ,
name : 'ends_on' ,
type : 'dateTime' ,
default : '' ,
description : 'Date the invoice is due. Defaults to the issue_date if no payment_term is specified.'
} ,
2020-01-28 07:50:15 -08:00
2020-02-03 01:23:58 -08:00
] ,
} ,
/* -------------------------------------------------------------------------- */
/* invoice:update */
/* -------------------------------------------------------------------------- */
2020-02-03 01:54:21 -08:00
{
displayName : 'Invoice Id' ,
name : 'id' ,
type : 'string' ,
default : '' ,
required : true ,
displayOptions : {
show : {
operation : [
'update' ,
] ,
resource ,
} ,
} ,
description : 'The ID of the invoice want to update.' ,
} ,
2020-02-03 01:23:58 -08:00
{
displayName : 'Update Fields' ,
name : 'updateFields' ,
type : 'collection' ,
placeholder : 'Add Field' ,
displayOptions : {
show : {
operation : [
2020-02-03 01:54:21 -08:00
'update' ,
2020-02-03 01:23:58 -08:00
] ,
resource ,
} ,
} ,
default : { } ,
options : [
{
2020-02-03 04:55:21 -08:00
displayName : 'Client Id' ,
2020-02-03 01:23:58 -08:00
name : 'client_id' ,
type : 'string' ,
default : '' ,
description : 'The ID of the retainer associated with this invoice..' ,
} ,
{
displayName : 'Retainer Id' ,
name : 'retainer_id' ,
type : 'boolean' ,
default : true ,
description : 'The ID of the retainer associated with this invoice.'
} ,
{
displayName : 'Estimate Id' ,
name : 'estimate_id' ,
type : 'string' ,
default : '' ,
description : 'The ID of the estimate associated with this invoice.'
} ,
{
displayName : 'Number' ,
name : 'number' ,
type : 'string' ,
default : '' ,
description : 'If no value is set, the number will be automatically generated.'
} ,
{
displayName : 'Purchase Order' ,
name : 'purchase_order' ,
type : 'string' ,
default : '' ,
description : 'The purchase order number.'
} ,
{
displayName : 'Tax' ,
name : 'tax' ,
type : 'string' ,
default : '' ,
description : 'This percentage is applied to the subtotal, including line items and discounts. Example: use 10.0 for 10.0%.'
} ,
{
displayName : 'Tax2' ,
name : 'tax2' ,
type : 'string' ,
default : '' ,
description : 'This percentage is applied to the subtotal, including line items and discounts. Example: use 10.0 for 10.0%.'
} ,
{
displayName : 'Discount' ,
name : 'over_budget_notification_percentage' ,
type : 'string' ,
default : '' ,
description : 'This percentage is subtracted from the subtotal. Example: use 10.0 for 10.0%.'
} ,
{
displayName : 'Subject' ,
name : 'subject' ,
type : 'string' ,
default : '' ,
description : 'The invoice subject.'
} ,
{
displayName : 'Currency' ,
name : 'currency' ,
type : 'string' ,
default : '' ,
description : 'The currency used by the invoice. If not provided, the client’ s currency will be used. See a list of supported currencies'
} ,
{
displayName : 'Payment Term' ,
name : 'payment_term' ,
type : 'string' ,
default : '' ,
description : 'The timeframe in which the invoice should be paid. Defaults to custom. Options: upon receipt, net 15, net 30, net 45, or net 60.'
} ,
{
displayName : 'Notes' ,
name : 'notes' ,
type : 'string' ,
default : '' ,
description : 'Notes about the project.'
} ,
{
displayName : 'Issue Date' ,
name : 'issue_date' ,
type : 'dateTime' ,
default : '' ,
description : 'Date the invoice was issued. Defaults to today’ s date.'
} ,
{
displayName : 'Due Date' ,
name : 'ends_on' ,
type : 'dateTime' ,
default : '' ,
description : 'Date the invoice is due. Defaults to the issue_date if no payment_term is specified.'
} ,
] ,
} ,
2020-01-28 07:50:15 -08:00
] as INodeProperties [ ] ;