NetSuite SS 2.0 : Salesorder Custom address

标签 netsuite suitescript2.0

我们目前正在从第 3 方导入销售订单, 销售订单创建完成得很好。 我们正在努力解决送货地址问题,我们需要为每个新销售订单创建一个自定义送货地址。

当我们使用以下代码时,销售订单中只显示了shipzip,您看出什么原因了吗?

              var shippingDetails = order[k].shipping_address;
          log.debug('shipping',shippingDetails);
          salesOrder.setValue('shipaddresslist', null);

          salesOrder.setValue('shipcountry', shippingDetails.country_iso_code.substring(0,2));
          log.debug('shipcountry',
                    salesOrder.getValue({
            fieldId: 'shipcountry'
          })
                   );
          salesOrder.setValue('shipisresidential', 'T');
          salesOrder.setValue('shipattention', 'Adresse de livraison');
          log.debug('shipattention',
                    salesOrder.getValue({
            fieldId: 'shipattention'
          })
                   );
          salesOrder.setValue('shipaddressee', shippingDetails.civility +' '+shippingDetails.firstname+' '+shippingDetails.lastname);
          log.debug('shipaddressee',
                    salesOrder.getValue({
            fieldId: 'shipaddressee'
          })
                   );
          salesOrder.setValue('shipaddrphone', shippingDetails.phone);
          salesOrder.setValue('shipaddr1', shippingDetails.street_1);
          salesOrder.setValue('shipaddr2', shippingDetails.street_2);
          salesOrder.setValue('shipcity', shippingDetails.city);
          //salesOrder.setValue('shipstate', 'CA');
          salesOrder.setValue('shipzip', shippingDetails.zip_code);           

作为解决方法,我们尝试使用下面的代码,我们怎样才能有回车符?:

              salesOrder.setValue('shipaddress', shippingDetails.civility +' '+shippingDetails.firstname+' '+shippingDetails.lastname +'\n'+shippingDetails.street_1+'\n'+shippingDetails.zip_code+' '+shippingDetails.city);

最佳答案

要使用 SuiteScript 2.0 在销售订单上正确设置帐单或送货地址,您必须使用 subrecord 方法。

以下是使用指定的客户内部 ID 和单个有效的项目内部 ID 创建销售订单的完整工作示例

您可以对其进行调整以满足您的需求。

/**
*@NApiVersion 2.x
*/
require(['N/record'], function (record) {

    var VALID_CUSTOMER_ID = 14907; // A valid Customer Internal ID for testing
    var VALID_ITEM_ID = 7006; // A valid Item Internal ID for testing

    // Example address details
    var shippingDetails = { "country_iso_code": "USA", "civility": "civilty", "firstname": "firstname", "lastname": "lastname", "phone": "0123456789", "street_1": "Street 1", "street_2": "Street 2", "city": "Bell", "shipstate": "California", "zip_code": "90201" };
    var billingDetails = { "country_iso_code": "USA", "civility": "civilty", "firstname": "firstname", "lastname": "lastname", "phone": "0123456789", "street_1": "Street 1", "street_2": "Street 2", "city": "Bell", "shipstate": "California", "zip_code": "90201" };

    function CreateSalesOrder() {

        // Create our new sales order
        var salesOrder = record.create({
            type: record.Type.SALES_ORDER,
            isDynamic: true,
            defaultValues: { entity: VALID_CUSTOMER_ID }
        });

        // Add a line item (just for testing / example)
        salesOrder.selectNewLine({sublistId: 'item'});
        salesOrder.setCurrentSublistValue({
            sublistId: 'item',
            fieldId: 'item',
            value: VALID_ITEM_ID
        });
        salesOrder.setCurrentSublistValue({
            sublistId: 'item',
            fieldId: 'quantity',
            value: 1
        });
        salesOrder.setCurrentSublistValue({
            sublistId: 'item',
            fieldId: 'amount',
            value: 1
        });
        salesOrder.commitLine({sublistId: 'item'});

        // Set our billing address
        salesOrder.setValue({
            fieldId: 'billaddresslist',
            value: null // Needed to override default address
        });
        var billaddrSubrecord = salesOrder.getSubrecord({fieldId: 'billingaddress'});
        billaddrSubrecord.setValue({
            fieldId: 'country',
            value: billingDetails.country_iso_code.substring(0,2)
        });
        billaddrSubrecord.setValue({
            fieldId: 'isresidential',
            value: 'T'
        });
        billaddrSubrecord.setValue({
            fieldId: 'attention',
            value: 'Adresse de livraison'
        });
        billaddrSubrecord.setValue({
            fieldId: 'addressee',
            value: billingDetails.civility +' '+billingDetails.firstname+' '+billingDetails.lastname
        });
        billaddrSubrecord.setValue({
            fieldId: 'addrphone',
            value: billingDetails.phone
        });
        billaddrSubrecord.setValue({
            fieldId: 'addr1',
            value: billingDetails.street_1
        });
        billaddrSubrecord.setValue({
            fieldId: 'addr2',
            value: billingDetails.street_2
        });
        billaddrSubrecord.setValue({
            fieldId: 'city',
            value: billingDetails.city
        });
        billaddrSubrecord.setValue({
            fieldId: 'state',
            value: billingDetails.state
        });
        billaddrSubrecord.setValue({
            fieldId: 'zip',
            value: billingDetails.zip_code
        });

        // Set our shipping address
        salesOrder.setValue({
            fieldId: 'shipaddresslist',
            value: null // Needed to override default address
        });
        var shipaddrSubrecord = salesOrder.getSubrecord({fieldId: 'shippingaddress'});
        shipaddrSubrecord.setValue({
            fieldId: 'country',
            value: shippingDetails.country_iso_code.substring(0,2)
        });
        shipaddrSubrecord.setValue({
            fieldId: 'isresidential',
            value: 'T'
        });
        shipaddrSubrecord.setValue({
            fieldId: 'attention',
            value: 'Adresse de livraison'
        });
        shipaddrSubrecord.setValue({
            fieldId: 'addressee',
            value: shippingDetails.civility +' '+shippingDetails.firstname+' '+shippingDetails.lastname
        });
        shipaddrSubrecord.setValue({
            fieldId: 'addrphone',
            value: shippingDetails.phone
        });
        shipaddrSubrecord.setValue({
            fieldId: 'addr1',
            value: shippingDetails.street_1
        });
        shipaddrSubrecord.setValue({
            fieldId: 'addr2',
            value: shippingDetails.street_2
        });
        shipaddrSubrecord.setValue({
            fieldId: 'city',
            value: shippingDetails.city
        });
        shipaddrSubrecord.setValue({
            fieldId: 'state',
            value: shippingDetails.state
        });
        shipaddrSubrecord.setValue({
            fieldId: 'zip',
            value: shippingDetails.zip_code
        });

        // Save our new sales order
        salesOrder.save({ignoreMandatoryFields: true});
    }

    CreateSalesOrder();
});

工作示例视频

Animated GIF Video showing code running in Debugger and created Sales Order

关于NetSuite SS 2.0 : Salesorder Custom address,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62256547/

相关文章:

javascript - SuiteScript 2.0 TypeError 无法调用未定义的方法 "getValue"

netsuite - SuiteScript 2.0 将电子邮件附加到多个交易

javascript - Netsuite 客户端脚本仅在测试模式下执行

javascript - Netsuite 用户事件脚本 : Not all user event types firing

java - NetSuite 集成 - CustomFieldList 的问题

javascript - 我应该添加什么过滤器以在 Netsuite - suitescript 的最后 14 或 15 天内获得相同的 transaction_date 字段?

javascript - Suitescript 未知错误 : TypeError this. handleChange 不是函数

javascript - 如何让 for 循环包含 NetSuite 中用户事件脚本的最后一行?