我想在点击销售订单上的 "approve" 按钮后创建采购订单
I want to create a purchase order after the "approve" button is clicked on a sales order
我希望在用户单击销售订单上的批准按钮时生成采购订单。我将脚本部署到销售订单记录和单击批准按钮时触发的事件类型。但是,此代码不会创建采购订单,因为我的子列表项值的字段值无效。
我使用了项目的内部 ID 和字符串名称作为值,但我得到了相同的 "invalid field value" 错误。有人知道怎么了吗?
function beforeSubmit(context) {
var sRecord = context.newRecord;
var user = runtime.getCurrentUser();
//get line count
var itemCount = sRecord.getLineCount({
sublistId: 'item'
});
for (var i = 0; i<itemCount; i++){
var pOrder = record.create({
type: record.Type.PURCHASE_ORDER,
isDynamic: true
});
//get item internal id
var itemId = sRecord.getSublistValue({
sublistId : 'item',
fieldId : 'item',
line : i
});
//get qty
var qty = sRecord.getSublistValue({
sublistId : 'item',
fieldId : 'quantity',
line : i
});
//get vendor of item
var vendor = search.lookupFields({
type : 'item',
id : itemId,
columns : ['vendorname']
});
//add vendor to record
pOrder.setValue('vendorname', vendor);
//selects new line
pOrder.selectNewLine({sublistId: 'item'});
//add item to sublist
pOrder.setCurrentSublistValue({
sublistId : 'item',
fieldId : 'item',
value : itemId
});
//add quantity to sublist
pOrder.setCurrentSublistValue({
sublistId : 'item',
fieldId : 'quantity',
value : qty
});
pOrder.commitLine({sublistId: 'item'});
pOrder.save();
}
}
entity
字段在采购订单记录中是必需的。项目记录上的 vendorname
字段不存储供应商记录,即使存储了供应商记录,采购订单上也没有相应的 vendorname
字段。项目记录中的此值用于识别供应商对项目本身的 name/code,如果他们有不同的名称。
如所写,如果在 PO 上设置了 entity
字段,则此代码至少在某些情况下起作用。如果您设置了 Preferred Vendor
或者如果使用多个供应商功能在那里配置了首选供应商,您仍然可以直接从项目记录中查找适当的 entity
字段。
无需为待售商品的库存和非库存编写脚本即可实现此脚本似乎正在执行的操作的一种简单方法是使用这些商品记录上的 Drop Ship Item
复选框或 Special Order Item
复选框.为每个符合条件的项目选择任一将允许为您的销售订单的行项目自动创建采购订单。在 Netsuite 帮助中搜索 Special Order Items
以获取有关差异和设置方法的更多信息。
我希望在用户单击销售订单上的批准按钮时生成采购订单。我将脚本部署到销售订单记录和单击批准按钮时触发的事件类型。但是,此代码不会创建采购订单,因为我的子列表项值的字段值无效。
我使用了项目的内部 ID 和字符串名称作为值,但我得到了相同的 "invalid field value" 错误。有人知道怎么了吗?
function beforeSubmit(context) {
var sRecord = context.newRecord;
var user = runtime.getCurrentUser();
//get line count
var itemCount = sRecord.getLineCount({
sublistId: 'item'
});
for (var i = 0; i<itemCount; i++){
var pOrder = record.create({
type: record.Type.PURCHASE_ORDER,
isDynamic: true
});
//get item internal id
var itemId = sRecord.getSublistValue({
sublistId : 'item',
fieldId : 'item',
line : i
});
//get qty
var qty = sRecord.getSublistValue({
sublistId : 'item',
fieldId : 'quantity',
line : i
});
//get vendor of item
var vendor = search.lookupFields({
type : 'item',
id : itemId,
columns : ['vendorname']
});
//add vendor to record
pOrder.setValue('vendorname', vendor);
//selects new line
pOrder.selectNewLine({sublistId: 'item'});
//add item to sublist
pOrder.setCurrentSublistValue({
sublistId : 'item',
fieldId : 'item',
value : itemId
});
//add quantity to sublist
pOrder.setCurrentSublistValue({
sublistId : 'item',
fieldId : 'quantity',
value : qty
});
pOrder.commitLine({sublistId: 'item'});
pOrder.save();
}
}
entity
字段在采购订单记录中是必需的。项目记录上的 vendorname
字段不存储供应商记录,即使存储了供应商记录,采购订单上也没有相应的 vendorname
字段。项目记录中的此值用于识别供应商对项目本身的 name/code,如果他们有不同的名称。
如所写,如果在 PO 上设置了 entity
字段,则此代码至少在某些情况下起作用。如果您设置了 Preferred Vendor
或者如果使用多个供应商功能在那里配置了首选供应商,您仍然可以直接从项目记录中查找适当的 entity
字段。
无需为待售商品的库存和非库存编写脚本即可实现此脚本似乎正在执行的操作的一种简单方法是使用这些商品记录上的 Drop Ship Item
复选框或 Special Order Item
复选框.为每个符合条件的项目选择任一将允许为您的销售订单的行项目自动创建采购订单。在 Netsuite 帮助中搜索 Special Order Items
以获取有关差异和设置方法的更多信息。