# 自定义验签结果弹窗
本章节将介绍如何自定义验签结果弹窗。
# 验签结果弹窗
执行下面的示例代码,默认的验签结果弹窗将被替换,并将右键菜单栏的显示签名属性按钮移除。
var pdfui = new PDFUI({
viewerOptions: {
viewerUI: new class extends UIExtension.XViewerUI {
getSignatureUI() {
return Promise.resolve({
// Get the customization dialog.
getSignVerifiedResultDialog(){
return pdfui.getRootComponent().then(rootComponent => rootComponent.querySelector('@custom-dialog'));
}
});
}
}()
},
fragments:[
// Remove the menu item used to display the signature result dialog.
// {
// target: 'fv--contextmenu-item-form-sign',
// action: UIExtension.UIConsts.FRAGMENT_ACTION.REMOVE
// },
// {
// target: 'fv--xfa-signature-contextmenu-sign',
// action: UIExtension.UIConsts.FRAGMENT_ACTION.REMOVE
// },
// Remove the menu item used to display the signature properties dialog.
{
target: 'fv--contextmenu-item-form-verify',
action: UIExtension.UIConsts.FRAGMENT_ACTION.REMOVE
},
{
target: 'fv--xfa-signature-contextmenu-verify',
action: UIExtension.UIConsts.FRAGMENT_ACTION.REMOVE
}
]
});
// Defined the customization dialog.
class CustomSignedPropertiesDialog extends UIExtension.SeniorComponentFactory.createSuperClass({
template: `
<layer name="custom-dialog"
class="fv__ui-signedProperty-dialog center"
modal="true">
<layer-header class="fv__ui-signProperty-header" title="dialog.signProperty.title" name="dialog.signProperty.title"></layer-header>
<div id="result"></div>
</layer>
`,
}) {
static getName() {
return 'custom-dialog';
}
constructor(...arg) {
super(...arg);
}
openWith(annot,res){
console.log(annot,res);
this.show();
this.element.querySelector('#result').innerHTML = res;
}
hide(){
super.hide();
console.log(`hide`);
}
destroy(){
super.destroy();
console.log(`destroy`);
}
isOpened(){
return this.isVisible
}
}
UIExtension.modular.root().registerComponent(CustomSignedPropertiesDialog);
pdfui.getRootComponent().then(rootComponent=>rootComponent.append('<custom-dialog>'));