通过Suitescript在Netsuite中创建销售订单时,我们可以通过向其发送包含完整地址的字符串来成功设置“收货地址”(字段ID:shipaddress)。
这会导致问题,因为“SHIP TO SELECT”下拉字段会保留客户设置的默认地址。
理想情况下,我们宁愿从Customer记录中发送有效ID,并使用该ID设置下拉列表“SHIP TO SELECT”(字段ID:shipaddresslist)字段。
我们可以获取有效的ID,但无法找到在该字段上设置该ID的方法,以便填充该下拉列表。
答案 0 :(得分:3)
通常,如果您在提交脚本前的用户事件的上下文之外执行此操作,则还需要确保通过采购进行保存。
var soRec = nlapiLoadRecord('salesorder' soId);
soRec.setFieldValue('shipaddresslist', addressId);
nlapiSubmitRecord(soRec, true);
// alternatively nlapiSubmitRecord(soRec, {enablesourcing:true [, disabletriggers:true|false, ignoremandatoryfields:true|false]});
如果您仍然看到旧地址文字,可以添加:
soRec.setFieldValue('shipaddress', null);
在提交之前。
如果你想要做的是设置一个自定义地址然后类似但你需要设置覆盖:
var soRec = nlapiLoadRecord('salesorder' soId);
soRec.setFieldValue('shipaddresslist', null);
soRec.setFieldValue('shipoverride', 'T');
soRec.setFieldValue('shipaddress', formattedAddressString);
nlapiSubmitRecord(soRec);
请注意,尽管这样做会使依赖地址字段的任何搜索或自动化错过或在此记录周围产生不正确的结果。
如果您想要自定义地址,通常情况下会更好:
var soRec = nlapiLoadRecord('salesorder' soId);
soRec.setFieldValue('shipaddresslist', null);
soRec.setFieldValue('shipaddr1', '123 Elm St.');
soRec.setFieldValue('shipcity', 'Portland');
...
nlapiSubmitRecord(soRec);