-
Notifications
You must be signed in to change notification settings - Fork 221
Form Runner ~ XBL Components ~ XForms Inspector
Home ▸ Form Runner ▸ XBL Components
The XForms Inspector allows you to:
- See the "live" content of your instances as you interact with the form.
- Type in XPath expression, and see what the result is when they are evaluated.
- See what is logged by your form to the XForms inspector console (experimental).
The console is an experimental new feature, and is likely to be improved and changed in the future. When you select View Console , the output area of the inspector shows what your XForms code logs to the console. You log something to the console by dispatching an event fr-log
to the id of the XForms inspector. If you included the inspector by setting the oxf.epilogue.xforms.inspector
property to true
, that id is orbeon-xforms-inspector
. Otherwise, it is the id you put on the <fr:xforms-inspector>
. The event take one parameter:
fr-messages
. Its value is a sequence of values, either elements or atomic values (strings, numbers…).
<xf:dispatch name="fr-log" target="orbeon-xforms-inspector">
<xxf:context
name="fr-messages"
select="instance('fr-xforms-inspector-input')"/>
</xf:dispatch>
In some cases, you'd like to evaluate an XPath expression you type in the console, but you want that XPath expression to be evaluated in a very particular context, for instance in a middle of a sequence of actions. For this, add the following instance to your form:
<xf:instance id="fr-xforms-inspector-input">
<input/>
</xf:instance>
When the XForms inspector finds this instance, it shows an additional input field, and binds it to your fr-xforms-inspector-input
instance. You can then use fr-log evaluating the expression you typed in the newly added input field with:
<xf:dispatch
event="xforms-value-changed"
name="fr-log"
targetid="orbeon-xforms-inspector">
<xxf:context
name="fr-messages"
select="saxon:evaluate(instance('fr-xforms-inspector-input'))"/>
</xf:dispatch>