2

我希望在有人单击销售订单上的批准按钮时生成采购订单。我将脚本部署到销售订单记录和单击批准按钮时触发的事件类型。但是,此代码不会创建采购订单,因为子列表项值的字段值无效。

我将项目的内部 ID 和字符串名称都用作值,并且我得到相同的“无效字段值”错误。有谁知道怎么了?

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();

    }
}
4

1 回答 1

3

entity字段在采购订单记录中是必需的。项目记录上的vendorname字段不存储供应商记录,即使存储了,vendorname采购订单上也没有相应的字段。项目记录中的此值用于标识项目本身的供应商名称/代码,以防它们具有不同的名称。

entity如所写,如果在 PO 上设置了字段,则此代码至少在情境下起作用。如果您设置了一个或者如果使用多个供应商功能已经在那里配置了一个首选供应商,您仍然可以直接从项目记录中Preferred Vendor查找相应的字段。entity

无需为待售商品的库存和非库存编写脚本即可实现此脚本似乎正在执行的操作的一种简单方法是使用这些商品记录上的Drop Ship Item复选框或复选框。Special Order Item为每个符合条件的项目选择其中一个将允许为您的销售订单的行项目自动创建采购订单。在 Netsuite 帮助中搜索Special Order Items有关差异以及如何设置的更多信息。

于 2016-11-11T14:49:08.153 回答