Toolbox

Introduction

The Form Builder toolbox provides the following:

  • Global buttons. Global cut/copy/paste and "reload toolbox" icon buttons
  • Form structure
    • New Section
    • New Grid
    • New Repeated Grid
  • Form controls. Form control (AKA form fields) you can add to your form to capture and/or show data.
  • Metadata. Allows you to modify the application name and form name.
  • Advanced. Includes advanced features like XML Schema, PDF and source code view.
  • Services and Actions. Editors for simple services and actions.

Depending on your monitor or browser size, you can use the scrollbar to the right of the toolbox to see more toolbox content.

Configuration of the toolbox

The toolbox can be configured via properties and component metadata.

Cut, copy and paste

The Cut, Copy and Paste icons are located at the top of the toolbox:

They allow performing the usual cut/copy/paste operations on form controls.

  • Copy: copies the control in the currently selected table cell to the Form Builder clipboard. If the cell is empty, nothing happens.
  • Cut: same as Copy, but removes the control from the current grid cell. If the cell is empty, nothing happens.
  • Paste: pastes the control in the Form Builder clipboard to the next available grid cell. If there is no control in the clipboard, nothing happens.

NOTE: These operations are restricted to the currently running instance of Form Builder. They do not apply between different Form Builder windows or tabs, or between edition sessions.

The following control information is copied and pasted:

  • Control type
  • Name
  • Label, hint, and help
  • Itemset
  • Validations, including datatype, constraints, and alerts
  • Formulas
  • All associated localized resources

When the control is pasted, if the control name of the clipboard control is currently not in use in the form, it is used. Otherwise, a new name is chosen by Form Builder.

Form structure

New section button

Pressing this button inserts a new section into the form. The section is inserted after the currently selected section, that is the section containing the currently selected control.

After insertion, the new section has an empty title. You can change the section title by clicking on it.

![][27]

New grid button

Pressing this button inserts a new grid into the form. The grid is inserted after the currently selected grid within the currently selected section, that is the section and grid containing the currently selected control.

New repeated grid button

Pressing this button inserts a new repeated grid into the form. The grid is inserted after the currently selected grid within the currently selected section, that is the section and grid containing the currently selected control.

After insertion, the new grid has one column and one cell. You can change the dimensions of the grid using the grid icons. You can change the grid settings with the Grid Settings icon.

Form controls

The toolbox contains the user interface controls you can insert into your form, grouped by category:

  • Text controls. Controls that just capture or show text.
  • Typed controls. Controls that have type information associated, like email, phone number, attachments, etc.
  • Date and time controls. Controls for capturing a date or a time or both.
  • Selection controls. Controls that allow selecting one or more values, like dropdown menus, radio buttons, etc.
  • Attachment controls. Controls to attach images or files.
  • Button controls. Action buttons.

To add a control to your form, simply click on the control. The following insertion logic is implemented:

  • If the currently selected grid cell is empty, the control is inserted there.
  • Otherwise, if the cell to the right of the currently selected grid cell is empty, the control is inserted there.
  • Otherwise, if the control is the last control of the grid, a new grid row is inserted and the control is inserted in the first cell of the new row.
  • Otherwise, the controls in the toolbox are disabled and you cannot insert a new control.

Controls appear in the grid in two ways:

  • Most of the controls appear in a WYSIWYG manner.
  • Some controls are represented just with an icon. This is the case of some controls such as phone number, currency fields, etc. Orbeon is expecting feedback from users on the controls marked experimental below.

Text controls

Name Description
Input field Simple input field
Text Area Simple multi-line area
Text Output Like most other controls, the text output has a label, hint, but unlike most other control, the it can't be used by users to edit its value. Instead, it just shows a value, either fixed or calculated with a formula.
Password Field An input field that hides the characters you type
Formatted Text A rich text editor, aka HTML editor
Explanation Explanatory text which does not capture a value (blog post)

The controls appear like this at design time:

Typed controls

Name Description
Email Address Input field which validates that the content is an email address
US Phone Number US phone number with automatic formatting
Number A simple number
Currency US dollar currency
US State US state selector

The controls appear like this at design time:

Date and time controls

Name Description
Date Date field with date picker
Time Time field
Date and Time Combined date and time field
Dropdown Date Date chooser which uses dropdown menus
Fields Date date chooser which uses separate text fields

The controls appear like this at design time:

Selection controls

Name Selection Description
Dropdown Menu single dropdown menu
Radio Buttons single radio buttons
Checkboxes multiple checkboxes
Boolean Input - checkbox storing a boolean value
Scrollable Checkboxes single scrollable radio buttons
Dynamic Data Dropdown single dynamic dropdown bound to a REST service
Autocomplete single autocompletion

You edit the choices of most selection controls with the Itemset Editor.

The controls appear like this at design time:

NOTE: The "Scrollable List" control is deprecated as of Orbeon Forms 4.11 and removed from the toolbox.

Attachment controls

Name Description
Image Image displayed on the form at design time. It is not possible to change the image at runtime.
Image Attachment Image which can be attached to the form at design time or at runtime. The image can also be changed at runtime once attached.
File Attachment File which can be attached to the form at design time or at runtime. The file can also be replaced or downloaded once attached.
Image Annotation Select and annotate an image (see blog post).

The controls appear like this at design time:

Button controls

Name Description
Button Simple button
Link Button Button appearing as a link

Buttons do not allow entering data, and by default do nothing significant, but they can be used to trigger actions with the Action Editor.

NOTE: Buttons do not appear at all in preview mode.

The controls appear like this at design time:

Choices

You can edit the possible choices by clicking on the ![][41] icon that shows to the right of a control. When doing so, a dialog, like the one shown in the following screenshot, will appear.

![][42]

For each choice, you can enter:

  • A label – This is what users see when they fill out the form.
  • A value – This is what is stored as part of the data when users select this choice.
  • A hint – The third column only shows for radio buttons and checkboxes. If you provide a hint for a choice, that choice will be highlighted and the hint you provided will show when users move the mouse pointer over the label, as shown in the following screenshot.

![][43]

If you check the HTML checkbox, all the hints and labels you type in dialog are interpreted as HTML, allowing you to use HTML tags in label and hints, say to make text bold or italic.

![][44]

Data dropdown

From the perspective of people who will be filling out your form, the data dropdown works just like a regular dropdown. However, the data in the dropdown comes from a service. For instance, imagine you have a list to select a state and that you don't want to hard code the list of states in the form, either for convenience, or because the subset of selectable states is dynamic:

  1. Insert a data dropdown field.
  2. Click on cogwheel to bring up a Control Settings dialog, similar to the one shown to the right.
  3. In the Resource URI, enter the address of an HTTP service that returns the data you want to use to populate the dropdown. In most cases, the URL will look like http://your-host/your-service. If the address you specify start with a /, it is relative to the Orbeon Forms web app, which allows you to access a service you might have implemented in Orbeon Forms with XPL. For this example, let's assuming your service returns a list of states that looks like:
<states>
    <state abbreviation="AK" name="Alaska"/>
    <state abbreviation="AL" name="Alabama"/>
    <state abbreviation="AR" name="Arkansas"/>
    ...
</states>
  1. In the Items field, enter an XPath expression that returns one node per state. In this case, it will be: /states/state.
  2. For each state (item), specify an expression relative to the node returning the label (shown to users in the dropdown) and the value (stored in the data). In this case, those expressions will be, respectively: @name and @abbreviation.

If the data in the dropdown depends on a value entered by users in another form field, you can pass that value to the service as a request parameter. For instance, let's say that in addition to the State dropdown, you have a City dropdown where you want to list all the cities in the currently selected state. If the service is at /xforms-sandbox/service/zip-cities and takes a request parameter state-abbreviation, assuming you named your State field state, in the Resource URI enter:

/xforms-sandbox/service/zip-cities?state-abbreviation={$state}

Limitation: you can't yet use a variable as shown in the above example, to refer to another fields value. Instead, if the control is in the same section use {state}; if in a different section with name other-section, use {../other-section/state}. See #431.

![][45]

Autocomplete

The autocomplete control is a single item selection control that loads a list of suggestions from a service. It takes the same Resource URI, Items, Label, and Value configuration parameters as the [Data dropdown control][46]. You may want to pass the value of other controls to the service, but you'll always want to pass the currently typed value, as the suggestions should depend on what users typed so far. You access to the currently typed by value with $fr-search-value, as in the following example:

/xforms-controls/services/countries?country-name={`encode-for-uri($fr-search-value)}

![][47]