spModal似乎有一个称为“共享”的选项,如下所示:https://github.com/service-portal/x-archive/blob/master/documentation/spModal.md(向下滚动到共享)。
我在努力让它运转起来。
在我们的服务门户中,我有一个页面,其中包含一个加载小部件的客户端脚本,我在此处添加了“共享”选项,如上面的链接所示:
function onLoad() {
if (g_scratchpad.canWrite && !g_form.isReadOnly('u_custom_company') && spModal) {
var wait = setInterval(function() {
var vendorEle = this.document.querySelector('#u_custom_company > .form-group');
if (!vendorEle) {
return;
}
var ccompany = {};
var btn = this.document.createElement('button');
btn.innerHTML = 'Add New Custom Company';
btn.className = 'btn btn-sm btn-primary m-t-sm';
btn.onclick = function() {
spModal.open({
title: 'Add New Custom Company',
widget: 'new_custom_company',
footerStyle: { display: "none" },
shared: ccompany
}).then(function() {
// Shared object was updated
console.log(ccompany);
});
};
vendorEle.appendChild(btn);
clearInterval(wait);
}, 500);
}
}
在上面的脚本中,我在console.log()
的结果中一直得到“undefined”。
然后,在我的自定义小部件的客户端脚本中,我不确定如何为这个共享变量赋值,以便上面的客户端脚本可以访问它。这是我目前所尝试的:
function($scope) {
/* widget controller */
var c = this;
c.submit = function() {
if ( $('#name').val() && ( $('#idone').val() || $('#idtwo').val() )) {
c.data.action = 'createCustomCompany';
c.server.update().then(function() {
c.widget.options.shared = $scope.data.custom_companay.sys_id;
});
// close modal popup when submit is clicked
$scope.$parent.$parent.buttonClicked({ label: "Submit", submit: true });
} else {
$('.errormessage').show();
}
};
}
custom_company.sys_id
由我的服务器脚本填充,并且包含sys_id,例如新创建的自定义公司记录。
我不确定如何将数据从$scope.data.custom_companay.sys_id
传递到第一个客户端脚本中的变量?
1条答案
按热度按时间e0bqpujr1#
这可能有点晚了,但在这里添加它,以防万一有人在未来有同样的问题。
您不能通过spModal设置小部件的options属性,而应使用小部件的input属性。要从spModal访问数据,您需要在小部件的服务器脚本组件中编写代码。