2023-01-27 03:22:44 -08:00
import type { INodeProperties } from 'n8n-workflow' ;
2021-07-02 14:34:12 -07:00
import {
billingAddress ,
currencies ,
makeCustomFieldsFixedCollection ,
makeGetAllFields ,
productDetailsOptions ,
shippingAddress ,
} from './SharedFields' ;
2021-12-03 00:44:16 -08:00
export const salesOrderOperations : INodeProperties [ ] = [
2021-07-02 14:34:12 -07:00
{
displayName : 'Operation' ,
name : 'operation' ,
type : 'options' ,
2022-05-20 14:47:24 -07:00
noDataExpression : true ,
2021-07-02 14:34:12 -07:00
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
resource : [ 'salesOrder' ] ,
2021-07-02 14:34:12 -07:00
} ,
} ,
options : [
{
name : 'Create' ,
value : 'create' ,
description : 'Create a sales order' ,
2022-07-10 13:50:51 -07:00
action : 'Create a sales order' ,
2021-07-02 14:34:12 -07:00
} ,
{
name : 'Create or Update' ,
value : 'upsert' ,
description : 'Create a new record, or update the current one if it already exists (upsert)' ,
2022-07-10 13:50:51 -07:00
action : 'Create or update a sales order' ,
2021-07-02 14:34:12 -07:00
} ,
{
name : 'Delete' ,
value : 'delete' ,
description : 'Delete a sales order' ,
2022-07-10 13:50:51 -07:00
action : 'Delete a sales order' ,
2021-07-02 14:34:12 -07:00
} ,
{
name : 'Get' ,
value : 'get' ,
description : 'Get a sales order' ,
2022-07-10 13:50:51 -07:00
action : 'Get a sales order' ,
2021-07-02 14:34:12 -07:00
} ,
{
2022-09-07 07:51:14 -07:00
name : 'Get Many' ,
2021-07-02 14:34:12 -07:00
value : 'getAll' ,
2022-09-13 03:36:36 -07:00
description : 'Get many sales orders' ,
2022-09-08 08:10:13 -07:00
action : 'Get many sales orders' ,
2021-07-02 14:34:12 -07:00
} ,
{
name : 'Update' ,
value : 'update' ,
description : 'Update a sales order' ,
2022-07-10 13:50:51 -07:00
action : 'Update a sales order' ,
2021-07-02 14:34:12 -07:00
} ,
] ,
default : 'create' ,
} ,
2021-12-03 00:44:16 -08:00
] ;
2021-07-02 14:34:12 -07:00
2021-12-03 00:44:16 -08:00
export const salesOrderFields : INodeProperties [ ] = [
2021-07-02 14:34:12 -07:00
// ----------------------------------------
// salesOrder: create + upsert
// ----------------------------------------
{
2022-06-03 10:23:49 -07:00
displayName : 'Account Name or ID' ,
2021-07-02 14:34:12 -07:00
name : 'accountId' ,
required : true ,
type : 'options' ,
2022-08-17 08:50:24 -07:00
description :
2024-09-12 07:53:36 -07:00
'Choose from the list, or specify an ID using an <a href="https://docs.n8n.io/code/expressions/">expression</a>' ,
2021-07-02 14:34:12 -07:00
default : [ ] ,
typeOptions : {
loadOptionsMethod : 'getAccounts' ,
} ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
resource : [ 'salesOrder' ] ,
operation : [ 'create' , 'upsert' ] ,
2021-07-02 14:34:12 -07:00
} ,
} ,
} ,
// ----------------------------------------
// salesOrder: create
// ----------------------------------------
{
displayName : 'Subject' ,
name : 'subject' ,
2022-05-06 14:01:25 -07:00
description : 'Subject or title of the sales order' ,
2021-07-02 14:34:12 -07:00
type : 'string' ,
required : true ,
default : '' ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
resource : [ 'salesOrder' ] ,
operation : [ 'create' ] ,
2021-07-02 14:34:12 -07:00
} ,
} ,
} ,
// ----------------------------------------
// salesOrder: upsert
// ----------------------------------------
{
displayName : 'Subject' ,
name : 'subject' ,
2022-08-17 08:50:24 -07:00
description :
'Subject or title of the sales order. If a record with this subject exists it will be updated, otherwise a new one will be created.' ,
2021-07-02 14:34:12 -07:00
type : 'string' ,
required : true ,
default : '' ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
resource : [ 'salesOrder' ] ,
operation : [ 'upsert' ] ,
2021-07-02 14:34:12 -07:00
} ,
} ,
} ,
// ----------------------------------------
// salesOrder: create + upsert
// ----------------------------------------
{
displayName : 'Products' ,
name : 'Product_Details' ,
type : 'collection' ,
typeOptions : {
multipleValues : true ,
multipleValueButtonText : 'Add Product' ,
} ,
default : { } ,
placeholder : 'Add Field' ,
options : productDetailsOptions ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
resource : [ 'salesOrder' ] ,
operation : [ 'create' , 'upsert' ] ,
2021-07-02 14:34:12 -07:00
} ,
} ,
} ,
{
displayName : 'Additional Fields' ,
name : 'additionalFields' ,
type : 'collection' ,
placeholder : 'Add Field' ,
default : { } ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
resource : [ 'salesOrder' ] ,
operation : [ 'create' , 'upsert' ] ,
2021-07-02 14:34:12 -07:00
} ,
} ,
options : [
{
displayName : 'Adjustment' ,
name : 'Adjustment' ,
type : 'number' ,
default : 0 ,
typeOptions : {
minValue : 0 ,
} ,
2022-05-06 14:01:25 -07:00
description : 'Adjustment in the grand total, if any' ,
2021-07-02 14:34:12 -07:00
} ,
billingAddress ,
{
displayName : 'Carrier' ,
name : 'Carrier' ,
type : 'string' ,
default : '' ,
2022-05-06 14:01:25 -07:00
description : 'Name of the carrier' ,
2021-07-02 14:34:12 -07:00
} ,
{
2022-06-03 10:23:49 -07:00
displayName : 'Contact Name or ID' ,
2021-07-02 14:34:12 -07:00
name : 'contactId' ,
type : 'options' ,
2022-08-17 08:50:24 -07:00
description :
2024-09-12 07:53:36 -07:00
'Choose from the list, or specify an ID using an <a href="https://docs.n8n.io/code/expressions/">expression</a>' ,
2021-07-02 14:34:12 -07:00
default : [ ] ,
typeOptions : {
loadOptionsMethod : 'getContacts' ,
} ,
} ,
{
displayName : 'Currency' ,
name : 'Currency' ,
type : 'options' ,
default : 'USD' ,
2022-05-06 14:01:25 -07:00
description : 'Symbol of the currency in which revenue is generated' ,
2021-07-02 14:34:12 -07:00
options : currencies ,
} ,
makeCustomFieldsFixedCollection ( 'salesOrder' ) ,
{
2022-06-03 10:23:49 -07:00
displayName : 'Deal Name or ID' ,
2021-07-02 14:34:12 -07:00
name : 'dealId' ,
type : 'options' ,
2022-08-17 08:50:24 -07:00
description :
2024-09-12 07:53:36 -07:00
'Choose from the list, or specify an ID using an <a href="https://docs.n8n.io/code/expressions/">expression</a>' ,
2021-07-02 14:34:12 -07:00
default : [ ] ,
typeOptions : {
loadOptionsMethod : 'getDeals' ,
} ,
} ,
{
displayName : 'Description' ,
name : 'Description' ,
type : 'string' ,
default : '' ,
} ,
{
displayName : 'Discount' ,
name : 'Discount' ,
type : 'number' ,
description : 'Discount applied to the sales order. For example, enter 12 for 12%.' ,
default : 0 ,
typeOptions : {
minValue : 0 ,
} ,
} ,
{
displayName : 'Due Date' ,
name : 'Due_Date' ,
type : 'dateTime' ,
default : '' ,
} ,
{
displayName : 'Exchange Rate' ,
name : 'Exchange_Rate' ,
type : 'number' ,
default : 0 ,
typeOptions : {
minValue : 0 ,
} ,
2022-05-06 14:01:25 -07:00
description : 'Exchange rate of the default currency to the home currency' ,
2021-07-02 14:34:12 -07:00
} ,
{
displayName : 'Grand Total' ,
name : 'Grand_Total' ,
type : 'number' ,
default : 0 ,
typeOptions : {
minValue : 0 ,
} ,
2022-05-06 14:01:25 -07:00
description : 'Total amount for the product after deducting tax and discounts' ,
2021-07-02 14:34:12 -07:00
} ,
{
displayName : 'Sales Order Number' ,
name : 'SO_Number' ,
type : 'string' ,
default : '' ,
2022-05-06 14:01:25 -07:00
description : 'ID of the sales order after creating a case' ,
2021-07-02 14:34:12 -07:00
} ,
{
displayName : 'Sales Commission' ,
name : 'Sales_Commission' ,
type : 'number' ,
default : 0 ,
typeOptions : {
minValue : 0 ,
} ,
2022-08-17 08:50:24 -07:00
description :
'Commission of sales person on deal closure as a percentage. For example, enter 12 for 12%.' ,
2021-07-02 14:34:12 -07:00
} ,
shippingAddress ,
{
2022-06-03 10:23:49 -07:00
displayName : 'Status Name or ID' ,
2021-07-02 14:34:12 -07:00
name : 'Status' ,
type : 'options' ,
default : [ ] ,
typeOptions : {
loadOptionsMethod : 'getSalesOrderStatus' ,
} ,
2022-08-17 08:50:24 -07:00
description :
2024-09-12 07:53:36 -07:00
'Status of the sales order. Choose from the list, or specify an ID using an <a href="https://docs.n8n.io/code/expressions/">expression</a>.' ,
2021-07-02 14:34:12 -07:00
} ,
{
displayName : 'Sub Total' ,
name : 'Sub_Total' ,
type : 'number' ,
default : 0 ,
typeOptions : {
minValue : 0 ,
} ,
2022-05-06 14:01:25 -07:00
description : 'Total amount for the product excluding tax' ,
2021-07-02 14:34:12 -07:00
} ,
{
displayName : 'Tax' ,
name : 'Tax' ,
type : 'number' ,
default : 0 ,
typeOptions : {
minValue : 0 ,
} ,
2022-05-06 14:01:25 -07:00
description : 'Tax amount as the sum of sales tax and value-added tax' ,
2021-07-02 14:34:12 -07:00
} ,
{
displayName : 'Terms and Conditions' ,
name : 'Terms_and_Conditions' ,
type : 'string' ,
default : '' ,
2022-05-06 14:01:25 -07:00
description : 'Terms and conditions associated with the purchase order' ,
2021-07-02 14:34:12 -07:00
} ,
] ,
} ,
// ----------------------------------------
// salesOrder: delete
// ----------------------------------------
{
displayName : 'Sales Order ID' ,
name : 'salesOrderId' ,
2022-05-06 14:01:25 -07:00
description : 'ID of the sales order to delete' ,
2021-07-02 14:34:12 -07:00
type : 'string' ,
required : true ,
default : '' ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
resource : [ 'salesOrder' ] ,
operation : [ 'delete' ] ,
2021-07-02 14:34:12 -07:00
} ,
} ,
} ,
// ----------------------------------------
// salesOrder: get
// ----------------------------------------
{
displayName : 'Sales Order ID' ,
name : 'salesOrderId' ,
2022-05-06 14:01:25 -07:00
description : 'ID of the sales order to retrieve' ,
2021-07-02 14:34:12 -07:00
type : 'string' ,
required : true ,
default : '' ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
resource : [ 'salesOrder' ] ,
operation : [ 'get' ] ,
2021-07-02 14:34:12 -07:00
} ,
} ,
} ,
// ----------------------------------------
// salesOrder: getAll
// ----------------------------------------
. . . makeGetAllFields ( 'salesOrder' ) ,
// ----------------------------------------
// salesOrder: update
// ----------------------------------------
{
displayName : 'Sales Order ID' ,
name : 'salesOrderId' ,
2022-05-06 14:01:25 -07:00
description : 'ID of the sales order to update' ,
2021-07-02 14:34:12 -07:00
type : 'string' ,
required : true ,
default : '' ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
resource : [ 'salesOrder' ] ,
operation : [ 'update' ] ,
2021-07-02 14:34:12 -07:00
} ,
} ,
} ,
{
displayName : 'Update Fields' ,
name : 'updateFields' ,
type : 'collection' ,
placeholder : 'Add Field' ,
default : { } ,
displayOptions : {
show : {
2022-08-17 08:50:24 -07:00
resource : [ 'salesOrder' ] ,
operation : [ 'update' ] ,
2021-07-02 14:34:12 -07:00
} ,
} ,
options : [
{
2022-06-03 10:23:49 -07:00
displayName : 'Account Name or ID' ,
2021-07-02 14:34:12 -07:00
name : 'accountId' ,
type : 'options' ,
default : [ ] ,
typeOptions : {
loadOptionsMethod : 'getAccounts' ,
} ,
2022-08-17 08:50:24 -07:00
description :
2024-09-12 07:53:36 -07:00
'ID of the account associated with this invoice. Choose from the list, or specify an ID using an <a href="https://docs.n8n.io/code/expressions/">expression</a>.' ,
2021-07-02 14:34:12 -07:00
} ,
{
displayName : 'Adjustment' ,
name : 'Adjustment' ,
type : 'number' ,
default : 0 ,
typeOptions : {
minValue : 0 ,
} ,
2022-05-06 14:01:25 -07:00
description : 'Adjustment in the grand total, if any' ,
2021-07-02 14:34:12 -07:00
} ,
billingAddress ,
{
displayName : 'Carrier' ,
name : 'Carrier' ,
type : 'string' ,
default : '' ,
2022-05-06 14:01:25 -07:00
description : 'Name of the carrier' ,
2021-07-02 14:34:12 -07:00
} ,
{
2022-06-03 10:23:49 -07:00
displayName : 'Contact Name or ID' ,
2021-07-02 14:34:12 -07:00
name : 'contactId' ,
type : 'options' ,
2022-08-17 08:50:24 -07:00
description :
2024-09-12 07:53:36 -07:00
'Choose from the list, or specify an ID using an <a href="https://docs.n8n.io/code/expressions/">expression</a>' ,
2021-07-02 14:34:12 -07:00
default : [ ] ,
typeOptions : {
loadOptionsMethod : 'getContacts' ,
} ,
} ,
{
displayName : 'Currency' ,
name : 'Currency' ,
type : 'options' ,
default : 'USD' ,
2022-05-06 14:01:25 -07:00
description : 'Symbol of the currency in which revenue is generated' ,
2021-07-02 14:34:12 -07:00
options : currencies ,
} ,
makeCustomFieldsFixedCollection ( 'salesOrder' ) ,
{
2022-06-03 10:23:49 -07:00
displayName : 'Deal Name or ID' ,
2021-07-02 14:34:12 -07:00
name : 'dealId' ,
type : 'options' ,
2022-08-17 08:50:24 -07:00
description :
2024-09-12 07:53:36 -07:00
'Choose from the list, or specify an ID using an <a href="https://docs.n8n.io/code/expressions/">expression</a>' ,
2021-07-02 14:34:12 -07:00
default : [ ] ,
typeOptions : {
loadOptionsMethod : 'getDeals' ,
} ,
} ,
{
displayName : 'Description' ,
name : 'Description' ,
type : 'string' ,
default : '' ,
} ,
{
displayName : 'Discount' ,
name : 'Discount' ,
type : 'number' ,
default : 0 ,
typeOptions : {
minValue : 0 ,
} ,
} ,
{
displayName : 'Due Date' ,
name : 'Due_Date' ,
type : 'dateTime' ,
default : '' ,
} ,
{
displayName : 'Exchange Rate' ,
name : 'Exchange_Rate' ,
type : 'number' ,
default : 0 ,
typeOptions : {
minValue : 0 ,
} ,
2022-05-06 14:01:25 -07:00
description : 'Exchange rate of the default currency to the home currency' ,
2021-07-02 14:34:12 -07:00
} ,
{
displayName : 'Grand Total' ,
name : 'Grand_Total' ,
type : 'number' ,
default : 0 ,
typeOptions : {
minValue : 0 ,
} ,
2022-05-06 14:01:25 -07:00
description : 'Total amount for the product after deducting tax and discounts' ,
2021-07-02 14:34:12 -07:00
} ,
{
displayName : 'Sales Order Number' ,
name : 'SO_Number' ,
type : 'string' ,
default : '' ,
2022-05-06 14:01:25 -07:00
description : 'ID of the sales order after creating a case' ,
2021-07-02 14:34:12 -07:00
} ,
{
displayName : 'Sales Commission' ,
name : 'Sales_Commission' ,
type : 'number' ,
default : 0 ,
typeOptions : {
minValue : 0 ,
} ,
2022-08-17 08:50:24 -07:00
description :
'Commission of sales person on deal closure as a percentage. For example, enter 12 for 12%.' ,
2021-07-02 14:34:12 -07:00
} ,
shippingAddress ,
{
2022-06-03 10:23:49 -07:00
displayName : 'Status Name or ID' ,
2021-07-02 14:34:12 -07:00
name : 'Status' ,
type : 'options' ,
default : [ ] ,
typeOptions : {
loadOptionsMethod : 'getSalesOrderStatus' ,
} ,
2022-08-17 08:50:24 -07:00
description :
2024-09-12 07:53:36 -07:00
'Status of the sales order. Choose from the list, or specify an ID using an <a href="https://docs.n8n.io/code/expressions/">expression</a>.' ,
2021-07-02 14:34:12 -07:00
} ,
{
displayName : 'Sub Total' ,
name : 'Sub_Total' ,
type : 'number' ,
default : 0 ,
typeOptions : {
minValue : 0 ,
} ,
2022-05-06 14:01:25 -07:00
description : 'Total amount for the product excluding tax' ,
2021-07-02 14:34:12 -07:00
} ,
{
displayName : 'Subject' ,
name : 'Subject' ,
type : 'string' ,
default : '' ,
2022-05-06 14:01:25 -07:00
description : 'Subject or title of the sales order' ,
2021-07-02 14:34:12 -07:00
} ,
{
displayName : 'Tax' ,
name : 'Tax' ,
type : 'number' ,
default : 0 ,
typeOptions : {
minValue : 0 ,
} ,
2022-05-06 14:01:25 -07:00
description : 'Tax amount as the sum of sales tax and value-added tax' ,
2021-07-02 14:34:12 -07:00
} ,
{
displayName : 'Terms and Conditions' ,
name : 'Terms_and_Conditions' ,
type : 'string' ,
default : '' ,
2022-05-06 14:01:25 -07:00
description : 'Terms and conditions associated with the purchase order' ,
2021-07-02 14:34:12 -07:00
} ,
] ,
} ,
2021-12-03 00:44:16 -08:00
] ;