orbeon - 如何在 orbeon 中的所有表单上填充对话框
问题描述
如果我将其直接放入表单中,我可以填充和使用以下对话框。但是,我想将它放在所有表单上,而不必将代码放入每个表单中。我已将对话框保存到它自己单独的 email-dialog.xml 文件中,我可以使用在 properties-local.xml 中设置的第二个片段来调用它。该对话框显示为一个非常小的框,除了在您拖动框的顶部的标签“EMAIL ADDRESS”之外,里面什么都没有。我不知道如何让里面的东西填充。我最近更新到了 Orbeon 2020.1.2.2021 的最新版本。任何帮助或方向将不胜感激。
<xxf:dialog
xmlns:ev="http://www.w3.org/2001/xml-events"
xmlns:xh="http://www.w3.org/1999/xhtml"
xmlns:xxf="http://orbeon.org/oxf/xml/xforms"
xmlns:xf="http://www.w3.org/2002/xforms"
xmlns:fr="http://orbeon.org/oxf/xml/form-runner"
id="my-dialog-id"
appearance="full"
level="modal"
close="true"
draggable="true"
visible="false">
<xf:label>EMAIL ADDRESS</xf:label>
<xf:input id="textBoxDialog-control" bind="textBoxDialog-bind">
<xf:label ref="$form-resources/textBoxDialog/label"/>
<xf:hint ref="$form-resources/textBoxDialog/hint"/>
<xf:alert ref="$fr-resources/detail/labels/alert"/>
</xf:input>
<xf:trigger id="btnDialogBox-control" bind="btnDialogBox-bind">
<xf:label ref="$form-resources/btnDialogBox/label"/>
<xf:hint ref="$form-resources/btnDialogBox/hint"/>
<xf:alert ref="$fr-resources/detail/labels/alert"/>
<!-- send email function-->
<xf:action event="DOMActivate" type="xpath">
fr:run-process('oxf.fr.detail.process', 'email')
</xf:action>
</xf:trigger>
</xxf:dialog>
<property
as="xs:string"
name="oxf.fr.detail.dialogs.custom.*.*"
value="oxf:/forms/resources/email-dialog.xml"/>
<property as="xs:string" name="oxf.fr.detail.process.send.*.*">
xf:show(dialog="my-dialog-id")
</property>
解决方案
我假设您在每个表单中都有一个名为 的字段,当用户单击“发送”按钮textBoxDialog
时,您希望使用用户在显示的对话框内显示的文本字段中输入的值填充该字段。我建议您对对话框的代码进行两项更改:
- 在您的
xf:input
, 中删除, 或者您可能会收到重复的 id 错误,因为您在每个表单中id
都有一个带有 id 的控件。textBoxDialog-control
- 对于对话框内的按钮,不要引用窗
btnDialogBox
体内控件的标签,而是将标签放在对话框的代码中。
通过这些更改,对话框如下所示:
这是您的代码的修改版本:
<xxf:dialog
xmlns:ev="http://www.w3.org/2001/xml-events"
xmlns:xh="http://www.w3.org/1999/xhtml"
xmlns:xxf="http://orbeon.org/oxf/xml/xforms"
xmlns:xf="http://www.w3.org/2002/xforms"
xmlns:fr="http://orbeon.org/oxf/xml/form-runner"
id="my-dialog-id"
appearance="full"
level="modal"
close="true"
draggable="true"
visible="false">
<xf:label>EMAIL ADDRESS</xf:label>
<xf:input bind="textBoxDialog-bind">
<xf:label ref="$form-resources/textBoxDialog/label"/>
<xf:hint ref="$form-resources/textBoxDialog/hint"/>
<xf:alert ref="$fr-resources/detail/labels/alert"/>
</xf:input>
<xf:trigger>
<xf:label>Send</xf:label>
<!-- send email function-->
<xf:action event="DOMActivate" type="xpath">
fr:run-process('oxf.fr.detail.process', 'email')
</xf:action>
</xf:trigger>
</xxf:dialog>
推荐阅读
- javascript - React.js 路由到“/”会导致 [不能在没有“新”的情况下调用]
- ios - Alamofire 不会自动设置“If-None-Match”标头
- arrays - 如何优化这段代码,让整个过程加速?
- python - 在 Python(tkinter)中从类的外部更改类的私有属性(标签)
- c++ - 我应该如何在 io_service 中解决这个问题?
- android - Jetpack Compose 减少 TextField 的高度
- javascript - 如何在 nodejs 中导入 puppeteer npm
- go - 优雅地停止收听频道的更好方法
- python - 使用 xarray/other 库在 netcdf 文件中组合时间维度
- reactjs - 避免在多个 setState 上重新渲染