javascript - 用于动态 PDF 图章对话框的 Javascript 不起作用
问题描述
我一直在尝试在图章上创建一个动态 PDF-XChange 图章,其中包含 4 个动态文本字段(Text1、Text2、Text3 和 Text4),用户可以在放置图章之前在对话框中进行编辑。我想要的是用户选择图章和弹出对话框以打开 4 个用户输入字段:
- RMA 状态 - 用户添加状态(命名为 RMAS)
- 供用户输入任何内容的自由文本字段(名为 FREE)
- 用户的姓名和业务团队,从用户的身份信息(名为 TEAM)中提取
- 今天的日期,可编辑以防他们在事后盖章(命名为 DATE)
我让它在弹出一个对话框的地方工作,它连续 4 次询问用户每个问题,但是一个带有 4 个文本字段的对话框是所请求的。我似乎无法弄清楚下面的代码需要如何更改才能工作,但我对此很陌生。
目前它只打开最后一个问题(日期),在对话框激活之前没有被我的 JavaScript 日期代码填充,没有其他问题。如果我删除日期元素,它会询问它之前的问题(名称和业务单位),但它不会显示使用代码末尾处理的数据预先填充的所有 4 个问题的对话框,该数据已经过测试分开并且正在工作。
我的代码在下面注释。如果有人可以帮助我打开带有预先填充的 4 个文本字段的对话框,我很想看看我哪里出错了。如果你能帮我把数据添加到邮票的 Text1 到 Text4 框中,我会欣喜若狂!
// Dialog Definition
var oDlg = {
RMAStatus: "",
FreeText: "",
NameAndUnit: "",
TodaysDate: "",
description:
{
name: "Stamp details",
elements:
[
{
type: "view",
elements:
[
{
type: "view",
elements:
[
{
item_id: "lbl1",
type: "static_text",
name: "&RMA Stage",
},
{
width: 200,
height: 22,
type: "edit_text",
item_id: "rmas",
}
],
type: "view",
elements:
[
{
item_id: "lbl1",
type: "static_text",
name: "&Free text field",
},
{
width: 200,
height: 88,
type: "edit_text",
item_id: "free",
}
],
type: "view",
elements:
[
{
item_id: "lbl1",
type: "static_text",
name: "&Your name and team",
},
{
width: 200,
height: 22,
type: "edit_text",
item_id: "team",
}
],
type: "view",
elements:
[
{
item_id: "lbl1",
type: "static_text",
name: "&Stamp date",
},
{
width: 200,
height: 22,
type: "edit_text",
item_id: "date",
}
]
},
{
type: "ok_cancel",
}
]
}
]
},
initialize: function(dialog) { // where the data in dialog elements is set when the dialog is first activated
dialog.load({
"rmas":this.RMAStage,
"free":this.FreeText,
"team":this.CorrectName,
"date":this.todaysDate,
});
},
commit: function(dialog) { // where element data is acquired when the user presses the OK button
var data = dialog.store();
this.RMAStage = data["rmas"];
this.FreeText = data["free"];
this.CorrectName = data["team"];
this.todaysDate = data["date"];
}
};
/*
* Pre-fill the dialog text fields with the data below
*/
/* RMA STAGE (for RMAS to be populated) */
oDlg.RMAStage = "RMA Stage";
/* FREE TEXT FIELD (for FREE to be populated) */
oDlg.FreeText = "";
/* NAME AND UNIT (for TEAM to be populated) */
var IdentityName, IdentityNameSplit, Unit;
/* Set Organisation Unit */
Unit = "Parks & Landscapes Team"; // Unlikely to change
/* Find correctly formatted username from Identity info */
if((identity.name != null) && !/^\s*$/.test(identity.name))
IdentityName = identity.name;
else
IdentityName = identity.loginName.replace(/\./g," ").replace(/\./g," ").replace(/\b(\w)/g,function(Word,cFst){return cFst.toUpperCase()});
if (IdentityName.indexOf(', ') > -1) { // If the result is "Surname, Firstname" swap the names to make "Firstname Surname"
IdentityNameSplit = IdentityName.split(', ');
oDlg.NameAndUnit = IdentityNameSplit[1] + " " + IdentityNameSplit[0] + ", " + Unit;
}
else
oDlg.NameAndUnit = IdentityName + ", " + Unit;
/* FORMATTED DATE FIELD (for DATE to be populated) */
var stampDate;
stampDate = new Date();
oDlg.TodaysDate = util.printd("dd mmmm, yyyy", stampDate);
// Start dialog function
app.execDialog (oDlg);
解决方案
搞定了!如果其他人想自己复制/粘贴此解决方案:
var pagDlg =
{
result: "cancel",
DoDialog: function () { return app.execDialog(this); },
//definitions
strDefFmt: "dd-mm-yyyy",
strFmt: "dddd d mmmm, yyyy",
vDate: new Date,
strDate: "",
iOChecked: false,
abwChecked: false,
//
SetListSel: function (list, path) {
if (path.length == 0) return;
eval("list[\"" + ((path.join != "function") ? path : path.join("\"][\"")) + "\"] = 1");
},
GetListSel: function (oLstResult) {
for (var item in oLstResult) {
if ((typeof oLstResult[item] == "number") && (oLstResult[item] > 0))
return item;
}
return "";
},
formatDate: function (d, f) {
return util.printd(f, d);
},
//Initialize values that will be used in the pop-up dialogue
initialize: function (dialog) {
var unit = "Technical Services & Design";
this.strDate = this.formatDate(this.vDate, this.strDefFmt);
//this.strDate = this.formatDate(this.vDate, "dd mmmm, yyyy");
//
var dlgInit =
{
"date": this.strDate,
"free": "Enter your description text here.", //enable this checkbox option as default
"abw_2": IdentityName + ", " + unit,
"rma": "RMA Stage",
};
dialog.load(dlgInit);
iOChecked = dlgInit["free"]; // initialise and keep it the same as the value in dlgInit
abwChecked = dlgInit["abw_2"];
rmaChecked = dlgInit["rma"];
},
commit: function (dialog) { // Called when OK button is pressed
var oRslt = dialog.store();
var path = new Array();
var d = oRslt["date"]; //OK Go date
//
if (typeof d == "string")
d = util.scand(this.strDefFmt, d);
if (d != null)
{
var cur = new Date;
d = new Date(d.getFullYear(), d.getMonth(), d.getDate(), cur.getHours(), cur.getMinutes(), cur.getSeconds());
}
this.vDate = d;
//
this.rmaChecked = oRslt["rma"];
this.iOChecked = oRslt["free"];
this.abwChecked = oRslt["abw_2"];
this.strDate = oRslt["date"];
},
//Description of the layout of the Dialoge Window
description:
{
name: "Stamp details",
width: 450,
elements:
[
{
type: "view",
width: 450,
elements:
[
{
type: "view",
align_children: "align_row",
elements:
[
{
item_id: "lbl1",
name: "RMA Stage",
type: "static_text",
width: 100,
},
{
item_id: "rma",
type: "edit_text",
width: 300,
},
]
},
{
type: "view",
align_children: "align_row",
elements:
[
{
item_id: "lbl1",
name: "Free text",
type: "static_text",
width: 100,
alignment: "align_top",
align_children: "align_top",
},
{
item_id: "free",
type: "edit_text",
multiline: true,
width: 300,
height: 88,
},
]
},
{
type: "view",
align_children: "align_row",
elements:
[
{
item_id: "lbl1",
name: "Name and team",
type: "static_text",
width: 100,
},
{
item_id: "abw_2",
type: "edit_text",
width: 300,
},
]
},
{
type: "view",
align_children: "align_row",
elements:
[
{
item_id: "lbl1",
name: "Date",
type: "static_text",
width: 100,
},
{
item_id: "date",
type: "edit_text",
DateEdit: true,
width: 100,
}
]
},
{
type: "ok_cancel",
},
]
}
]
}
};
/* NAME */
var IdentityName, IdentityNameSplit;
/* Find correctly formatted username from Identity info */
if((identity.name != null) && !/^\s*$/.test(identity.name))
IdentityName = identity.name;
else
IdentityName = identity.loginName.replace(/\./g," ").replace(/\./g," ").replace(/\b(\w)/g,function(Word,cFst){return cFst.toUpperCase()});
if (IdentityName.indexOf(', ') > -1) { // If the result is "Surname, Firstname" swap the names to make "Firstname Surname"
IdentityNameSplit = IdentityName.split(', ');
IdentityName = IdentityNameSplit[1] + " " + IdentityNameSplit[0];
}
if (event.source.forReal && (event.source.stampName == "#T2CKw07Lo6sr42d6F3ao#0"))
{
if (pagDlg.DoDialog() == "ok")
{
var d = pagDlg.vDate;
this.getField("Text1").value = pagDlg.rmaChecked; // RMA Stage
this.getField("Text2").value = pagDlg.iOChecked; // Free text
this.getField("Text3").value = pagDlg.abwChecked; // Name and team
this.getField("Text4").value = util.printd(pagDlg.strFmt, d); // Date
}
else
{
app.alert("Stamp cancelled", 3);
}
}
else
{
var d = pagDlg.vDate;
event.value = util.printd(pagDlg.strFmt, d);
}
希望有人会发现这很有用。
推荐阅读
- javascript - 按枚举顺序而不是值对数组进行排序
- laravel - Laravel Lumen,Swagger 返回 json 而不是视图
- ios - 使用 tableview 自定义下拉菜单
- webpack - webpack 防止重复的 sass 导入导致重复的 css
- ios - 可以通过免费帐户使用 TestFlight
- python - VsCode Python“运行代码”与“在终端中运行 Python 文件”
- azure - Azure 函数的 IP 地址超出了 VNet 的范围
- python - Discord.py:在 cog 中调用时,主文件中的函数“未定义”
- python - 如何根据行号将不同的行连接到一个最终字符串中
- javascript - 高级图表 - 组织结构图