У меня был некоторый успех в создании пользовательских штампов в Bluebeam (отличный редактор PDF), начиная с их существующих образцов штампов. У меня есть штамп с одним настраиваемым текстовым полем, в котором есть выпадающее меню с предопределенными параметрами для выбора. Марка также имеет несколько других текстовых полей, некоторые из которых позволяют пользователю вводить данные, а некоторые - извлекать данные - текущую дату и имя пользователя.
Все это работает хорошо, но я бы хотел добавьте второе текстовое поле с предопределенными параметрами, и, кажется, нет никакого способа сделать это.
Как работает это программное обеспечение, есть «расчет» javascript, который запускается всякий раз, когда штамп впервые помещается в PDF. Код расчета создает пользовательский интерфейс для ввода даты. Код расчета ссылается на «stampcode» javascript. «Stampcode» ссылается на указанные c элементы в самой штампе (также PDF-файл).
Я думаю, что у меня правильно установлен штамп-код Я думаю, что код расчета - это то, что нужно отредактировать. У меня такое ощущение, что это довольно простой процесс, я просто начинающий программист и действительно не знаю, с чего начать. Я потратил около 4 часов. пытаясь настроить код расчета и не повезло с ним. Любая помощь будет принята с благодарностью. (Я использую визуальный код студии для редактирования).
Штамп код:
var builder =
{
// These map to Text Fields in the Stamp
textBoxes :
[
{ field:"Client", description:"Client:", default:function() { return ""; } },
{ field:"Project_Number", description:"Project No.:", default:function() { return ""; } },
{ field:"Expense_Date", description:"Date of Exp.:", default:function() { return ""; } },
{ field:"Markup", description:"Markup %:", default:function() { ""; } },
{ field:"CheckedBy", description:"Checked by:", default:function() { return Collab.user; } },
{ field:"Date", description:"Date:", default:function()
{
var curDate = new Date();
return (curDate.getMonth() + 1) + "/" + curDate.getDate() + "/" + curDate.getFullYear();
}
},
],
// This maps to a Radio Group in the PDF named 'Status'
radioGroup : "Status",
radioButtons :
[
// value maps to the 'Choice' of each radio button in the group, description will show on the dialog
{ value:"Approved", description:"Approved" },
{ value:"Revise", description:"Revise" },
{ value:"Rejected", description:"Rejected" }
],
// This maps to a Popup Group in the PDF named 'Reimburse'
popupGroup: "Reimburse",
listItems :
[
{popupItems :
{
//list of items of Popup menu, positive number indicates default selection
"XXX": -1,
"XXX": -1,
"DC": -1,
"CC": -1
}
}
],
// This maps to a Popup Group in the PDF named 'Service'
popupGroup: "Service",
listItems :
[
{popupItems :
{
//list of items of Popup menu, positive number indicates default selection
"00": -1,
"10": -1,
"20": -1,
"30": -1,
"40": -1,
"50": -1,
"51": -1,
"55": -1,
"60": -1,
"65": -1,
"70": -1,
"80": -1,
"81": -1,
"90": -1,
"91": -1,
"99": -1
}
}
],
// This maps to a Radio Group in the PDF named 'Status'
radioGroup : "Status",
radioButtons :
[
// value maps to the 'Choice' of each radio button in the group, description will show on the dialog
{ value:"Billable", description:"Billable" },
{ value:"Not Billable", description:"Not Billable" }
],
radioErrorMsg : "Please select a status",
}
Расчетный код:
// WARNING: DO NOT EDIT
// SEE GLOBAL JAVASCRIPT SECTION FOR CUSTOMIZATION
if (event.source.forReal)
{
var stampDialog = CreateDialog(builder);
app.execDialog(stampDialog);
this.getField(builder.radioGroup).value = stampDialog.radioSelection;
this.getField(builder.popupGroup).value = stampDialog.popupSelection;
for (var i = 0; i < builder.textBoxes.length; ++i)
{
var t = builder.textBoxes[i];
this.getField(t.field).value = stampDialog.textBoxResults[i];
}
}
function CreateDialog(dialogBuilder)
{
var sd = new Object();
sd.builder = dialogBuilder;
sd.radioSelection = "";
sd.popupSelection = "";
sd.textBoxResults = new Array();
var popupElements = new Array();
popupElements[0] =
{
type: "popup",
item_id: "popupItems",
field: sd.builder.popupGroup,
width: 250
};
var popupCluster =
{
type: "cluster",
name: builder.popupGroup,
elements: popupElements
};
var stateElements = new Array();
for (var i = 0; i < dialogBuilder.radioButtons.length; ++i)
{
var c = dialogBuilder.radioButtons[i];
stateElements[i] =
{
type: "radio",
name: c.description,
item_id: "rad" + i,
group_id: "grp1"
};
}
var stateCluster =
{
type: "cluster",
name: "Status",
alignment: "align_center",
align_children: "align_distribute",
elements: stateElements
};
var optionsElements = new Array();
for (var i = 0; i < dialogBuilder.textBoxes.length; ++i)
{
var view = new Object();
view.type = "view";
view.align_children = "align_row";
view.elements = new Array();
var t = dialogBuilder.textBoxes[i];
var s = new Object();
s.type = "static_text";
s.item_id = "sta" + i;
s.name = t.description;
s.width = 90;
var e = new Object();
e.type = "edit_text";
e.item_id = "edt" + i;
e.width = 150;
view.elements[0] = s;
view.elements[1] = e;
optionsElements[i] = view;
}
var optionsCluster =
{
type: "cluster",
name: "Options",
elements: optionsElements
};
sd.initialize = function(dialog)
{
var init = new Object();
for (var i = 0; i < this.builder.textBoxes.length; ++i)
{
var t = this.builder.textBoxes[i];
var id = "edt" + i;
init[id] = t.default();
}
dialog.load(init);
dialog.load(this.builder.listItems[0]);
};
sd.commit = function(dialog)
{
var res = dialog.store();
for (var i = 0; i < this.builder.radioButtons.length; ++i)
{
var c = this.builder.radioButtons[i];
var id = "rad" + i;
if (res[id] == true)
{
this.radioSelection = c.value;
break;
}
}
for (var i = 0; i < this.builder.textBoxes.length; ++i)
{
var t = this.builder.textBoxes[i];
var id = "edt" + i;
this.textBoxResults[i] = res[id];
}
for (var i in res["popupItems"])
if (res["popupItems"][i] >0)
{
this.popupSelection = i;
}
};
sd.validate = function(dialog)
{
var res = dialog.store();
for (var i = 0; i < this.builder.radioButtons.length; ++i)
{
var c = this.builder.radioButtons[i];
var id = "rad" + i;
if (res[id] == true)
return true;
}
app.alert(this.builder.radioErrorMsg);
return false;
};
sd.description =
{
name: "Stamp Dialog",
elements:
[
{
type: "view",
align_children: "align_fill",
elements:
[
popupCluster,
stateCluster,
optionsCluster
]
},
{
type: "ok"
}
]
};
return sd;
}