javascript - 如何在套件中使用 nlapiXMLToPDF

标签 javascript netsuite suitescript

目前正在使用 Suitescript 1.0 创建邮件合并 pdf 生成器。这就是我构建它的方式——有 4 个脚本(1 个用户事件、1 个客户端脚本和 2 个套件)。 用户事件脚本会生成一个下拉菜单,显示其部署到的任何记录上的所有可用模板。

function beforeLoad(type, form){

  var folderId = "folderId";
  var filters = new Array();
  filters[0] = new nlobjSearchFilter('internalid', null, 'is', folderId);
  
  var columns = new Array();
  var filename = new nlobjSearchColumn('name', 'file');
  var file_id = new nlobjSearchColumn('internalid', 'file');
  
  
  var fieldId = "custpage_mail_merge_dropdown";
  var fieldLabel = "Mail Merge Dropdown";
  

  var select = form.addField(fieldId, 'select', fieldLabel);

  columns[0] = filename;
  columns[1] = file_id;
  
  var searchResults = nlapiSearchRecord('folder', null, filters, columns);
  if(searchResults){
    for(var i = 0; i < searchResults.length; i++){
      var f = searchResults[i];
      //add values to the dropdown field created earlier in the UI
      
      select.addSelectOption(f.getValue(file_id), f.getValue(filename))
    }
  }

}

Dropdown generated by code

客户端脚本的目的是充当两个 suitelet 和部署它的记录之间的中介。


function verifyList(types, name, linenum){  
    
  
    if(name == 'custpage_mail_merge_dropdown'){
      
      var field = nlapiGetField(name);
      
      var fileName = nlapiGetFieldText(name);
      var suiteletUrl = nlapiResolveURL("SUITELET", script_id_1, 1);
      var response = nlapiRequestURL(suiteletUrl+"&fileName="+fileName);
      var fileContent = "";
      if(response.getBody()){
        fileContent = response.getBody();      
        nlapiLogExecution('DEBUG', 'STATUS', 'Client script activated '+ JSON.stringify(fileContent));
        var renderedFile = ejs.render(fileContent, {});
        var suiteletPdfUrl = nlapiResolveURL("SUITELET", script_id_2, 1);
        var response2 = nlapiRequestURL(suiteletPdfUrl+"&ejsCompiled="+renderedFile);
        
        nlapiLogExecution('DEBUG', 'STATUS', 'Client script activated '+ JSON.stringify(renderedFile));
        
      }

    }  

}

第一个 suitelet 的目的是加载从下拉列表中选择的模板并将其返回给客户端,在客户端使用 ejs.render() 对其进行转换

套房 1

function mail_merge(req, res){
  
  var fileName = req.getParameter('fileName');
  
  if(fileName){
    var fileId = "Templates__/"+fileName;
    var load_file = nlapiLoadFile(fileId);
    var fileContent = load_file.getValue();
    res.write(fileContent);
    nlapiLogExecution("DEBUG", "STATUS", "Suitelet script activated : "+fileName);
  }  

  
}

第二个 suitelet(应该)基于传递给客户端脚本的第一个 suitelet 的转换内容促进 PDF 文档的创建。 套房 2

function pdf_mail_merge(req, res){
    

    var ejsCompiled = req.getParameter('ejsCompiled');
    //Split by </pdf> due to unexpected string tagging along with file content
    ejsCompiled = ejsCompiled.split("</pdf>")[0];
    ejsCompiled +="</pdf>";
    if(ejsCompiled){
      nlapiLogExecution('DEBUG', 'STATUS', "EJS Compiled "+ejsCompiled);
      try{
      var pdf_file = nlapiXMLToPDF(ejsCompiled);
      }catch(err){
        nlapiLogExecution('DEBUG', 'STATUS', err);
      }
      res.setContentType("PDF", "somename.pdf");
      res.write(pdf_file.getValue());
      nlapiLogExecution('DEBUG', 'STATUS', "Second script activated "+JSON.stringify(pdf_file))
    }  
  
    
  }
  

从下拉列表中选择一个选项后,我收到了这条消息: “在此页面上运行的脚本中发生意外错误...UNEXPECTED_ERROR”

这是用于测试的模板。这正是 nlapiXMLToPDF 将作为参数的字符串。

<pdf>
    <head>

    </head>
    <body>
        <h1>Template One</h1>
    </body>
</pdf>

这让我感到困惑,字符串对我来说似乎非常好,但我一直收到这个奇怪的错误。如果你们中的任何人都可以提供任何有关问题可能的见解,我们将不胜感激。请原谅我冗长的帖子,我认为发布大部分用于解决问题的代码会很有用。

最佳答案

看起来您的模板缺少 BFO 模板引擎所需的 XML 和 DOCTYPE 声明(请参阅 BFO User Guide 的第 8 页)。

尝试在模板字符串的开头添加以下内容:

<?xml version="1.0"?>
<!DOCTYPE pdf PUBLIC "-//big.faceless.org//report" "report-1.1.dtd">

关于javascript - 如何在套件中使用 nlapiXMLToPDF,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59558467/

相关文章:

javascript - 更新 html meteor ?

javascript - NetSuite 中的脚本搜索未按预期工作

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

javascript - 通过 netsuite RESTlet 脚本设置/更改用户密码

NetSuite SuiteScript 如何突破 10MG 的限制?

PHP 和 PDO 防止 Javascript 注入(inject)

javascript - 如何根据环境渲染Paypal Smart Button?

javascript - jQuery Script 有时有效有时无效

javascript - 如何在 Netsuite 中从工作订单创建转移订单?

javascript - 加载更多 Action jquery