在创建记录期间由供应商自动过滤项目

时间:2017-01-06 08:02:16

标签: javascript netsuite suitescript

我有一组我正在使用的脚本互相交互。我使用客户端,用户事件和suitelet脚本来创建一个按钮,当按下该按钮时,会打开一个弹出窗口,其中包含供应商过滤的项目列表。

当我在编辑时它工作正常但是当我使用它时创建记录问题出现了。由于要创建的记录没有供应商或ID,因此我无法按供应商检索项目。我要做的是让Suitelet从保存之前输入的供应商字段中检索信息。因此,我可以按供应商过滤所有项目,并一次性添加必要的项目。这可能吗?我能否在提交之前访问该信息。

以下是客户端和Suitelet。用户事件只是对套件的调用,所以为了简洁起见,我把它留了出来。

客户端脚本

function addItemButtonCallback(data){
    nlapiSelectNewLineItem('item');
    nlapiSetCurrentLineItemValue('item', 'item', data);
    nlapiCommitLineItem('inventoryitem');
}

function addItemButton() {
    var id = nlapiGetFieldValue('id');
    if (id != "") {
        var url = nlapiResolveURL('SUITELET', 'customscript_val', 'customdeploy1') + '&poId='+id;
        window.open(url, '_blank', 'width=500,height=500'); 
    } 
}

Suitelet

function suitelet(request, response){
    if(request.getMethod() == 'GET') {
        var form = nlapiCreateForm('Add Item');
        form.addSubmitButton('Submit');

        var itemfield = form.addField('custpage_val', 'select', 'Item');
        var id = request.getParameter('id');

        var rec = nlapiLoadRecord('purchaseorder', id);
        var vend = rec.getFieldValue('entity');
        var search = nlapiSearchRecord(...search parameters...);

        for (result in search){
          if (search[result].getValue('vendor') == vend){
            itemfield.addSelectOption(search[result].id, nlapiLookupField('inventoryitem', search[result].id, 'itemid'));
          }
        }
        response.writePage(form);
    } else {
        var data = request.getParameter('custpage_item');
        response.write('<html><body><script>window.opener.addItemButtonCallback("'+data+'"); window.close();</script></body></html>');
    }
}

1 个答案:

答案 0 :(得分:3)

在clientscript上使用nlapiGetFieldValue('entity')并使用查询参数将其传递给Suitelet,就像使用poId一样(如果你这样做,你可能甚至不需要poId,毕竟+不需要加载记录在套件上。)

此外,您可能希望通过运行一个通过itemid数组的搜索来优化代码,而不是为每个项目调用nlapiLookupField。

您可能需要修改beforeLoad,以便在按下按钮时动态插入实体(我不记得customercript按钮是否这样做)。像这样:

var suiteletURL = nlapiResolveURL('SUITELET', 'customscript_val', 'customdeploy1');
var script = "var entity = nlapiGetFieldValue('entity'); var url = '" + suiteletURL + "'&entityId=' + entity;window.open(url, '_blank', 'width=500,height=500')";
var button = form.addButton('custpage_addItemButton', 'Add Item', script);