Home‎ > ‎Site Admins‎ > ‎

Branch Logic Blocks

The Branch Logic tools in LegalServer allow you to display subforms based on existing data or a user's selection. For example, if Homeless = "Yes", then display 4 additional fields.

Basic Setup

Place the block on a form, pick a toggle field, then select branch form(s) to display based on how the user responds to the toggle field.

Branch Logic Block

You place the Branch Logic block on a form as you would any other block. You select the field to display on the form (the Toggle Field), optionally mark the field as Required, optionally set a Default value for the field, then select the branch logic form to present (if any) for each possible selection the user can make. Here is an example with the options shown for a Yes/No question:

In the example above, the toggle field, "Has Applicant been to DEMO before", is a Yes/No field. With this configuration, if the user selects No when filling out the primary form, then nothing else would happen. If the user selects Yes, then the display will expand to show the branch logic form named "Applicant has been here before". That form can contain fields, instructions, and other elements.

The Default option in the block will not override an existing value for the toggle field. In the example, if the toggle field has not been set when the primary form is displayed, it will default to No. However, if that field had previously been set to Yes (in another form or if the user is returning to the same form where it was set to Yes earlier), then the Default of No will not override the Yes value.

The Read Only Subforms option allows branch logic forms to be displayed, but not saved.

The Required option determines if the toggle field is required on the primary form.

The Hidden? option hides the toggle field, and will display nothing on the primary form unless the block has been configured with a default value for the toggle field, or the toggle field has been set previously.

If the toggle field you select is a Lookup field instead of a Yes/No field, you could select a branch logic form for each possible value of that particular lookup field:

The toggle field can also be a multi-select Lookup field. In that case, the selections the user makes on the primary form will display as many branch logic forms as you have defined for those selections.

Branch Logic Forms

Branch Logic forms contain elements like other forms (fields, instructions, blocks, etc.). You can display as much additional information as you want inside the parent form. You create and edit branch logic forms in the same way you work with intake, auxiliary, and other forms, on the process management page (Admin > Processes, Forms, and Profiles).

Branch Logic Block on Branch Logic Forms

You can place a Branch Logic block on a branch logic form (for a form within a form within a form), but will need to guard against a circular setup - a form that branches to another form, but that form branches back to the first branch form, etc.

Branch Logic Example

You might want to ask applicants if their primary language is English. If the response is Yes, you want the form to display the standard Language dropdown with English pre-selected. But if the response is No, you want the form to display the standard Language dropdown (with no language pre-selected), and also ask additional questions like what the applicant's primary language is, their level of proficiency in English, and so on. To accomplish this, you would:
  • Create a field for the initial Yes/No question "Primary Language is English" (if one doesn't already exist).

  • Create a branch logic form for the Yes response in Admin / Processes, Forms, and Profiles. Add the Language field to this form and set the default value as English.

  • Create a branch logic form for the No response. Add the Language field to this form, as well as any additional fields, instructions, and blocks necessary to collect any additional information.

  • Add the Branch Logic block as an element on your primary form (in this example, probably an Intake form). Expand the Branch Logic block and set the options: select your Yes/No field for Toggle Field, and the appropriate branch logic forms for the Yes and No responses.
Note how you need to build in reverse: create/decide on a toggle field, build the branch logic forms, then place the Branch Logic block on the parent form (after you have the pieces the block needs).

Branch Logic based on Existing Information

Although branch logic is often used during intake to make different forms appear based on a user's selection, it can also be used for fields that already have a selection made, whether earlier in an intake or after a case is accepted.

For example, a site could have an auxiliary process called "Additional Questions" that appears on open cases. The form called by that process would contain a branch logic block with a toggle field for a value that has already been entered (legal problem code, funding code, county of residence, a site-specific field, etc.) As soon as a user clicks the "Additional Questions" link, the branch logic block would display the appropriate questions (the branch logic form configured for that legal problem code, funding code, etc.). If a site has several sets of questions based on a single field, one link could replace several separate links.

The Hidden option could also be used so that the user could not, on that form, accidentally change the toggle field value.

Alternate Versions

Two other blocks provide the ability to do branch logic on a form.

Branch Logic Form Toggle Button

This block is useful in "Show/Hide" situations to display, or not, a branch logic form. It allows you to avoid creating an unnecessary Yes/No toggle field for the 'full' Branch Logic block.

In the example, an agency wants to display a branch logic form if an applicant has previous applications, but has no need to create a "Previous Applications" field and store a Yes or No value for it.

The above configuration will initially display on a form like this:

And like this after the "Show" button is clicked:

Conditional Branch Logic Form Include

Allows a branch logic form to be displayed based on one or more conditions. For example, the form could be displayed based on a matter's percentage of poverty, legal problem code, and county of residence. The conditions can be joined by the AND option (all conditions must be met) or the OR option (the form is displayed if any of the conditions are met).

See Conditional Branch Logic Form Include for more information.