Webforms
Table of contents
ClICK HERE to view documentation for individual webforms for the macpro-mako project.
Purpose of this view
The goal of the webforms view is to be able to view all possible form fields as they relate to the data collected. We try to associate the “name” of the field, which is the key of the data as it is collected and stored, to the prompt and label of the question the user is presented with.
What are onemac webforms
These webforms are a replacement for the pdf form uploads previously used in mmdl, etc. These are dynamicly generated forms from a single document that represent the shape of a form and version. There three pieces to this puzzle.
- The form schema itself. this is the shape of a form that is delivered by the /forms endpoint to the frontend ui.
- The form genereator. This is a collection of ui react components and
react-hook-form
methods that generate the ui from the form schema and render and validate the form presented to the user. - The data. The data collected is added along with its metadata to its parent record. This data can be used to view/approve/edit the form later by admins or other users with appropriate permissions.
Things to note
Some of the fields listed in these webforms are FieldArrays. This means that they are arrays of values that contain groups of like values (think an array of identicaly typed objects). The items within those arrays will have Parent
values to indicate which parent they belong to.
Key structuring of Webforms:
For our webforms, we are in communication with data connect on our we should pass our json data to their team. We have gone with this approach to help streamline our data, but also make it as easy as possible to hunt down questions if items are added or changed. Our “name” keys are made up of for different parts.
Our agreed upon key structures for the “name” property of form field sections are as follows:
The Four Parts to the name field are:
- form name ‘-‘ instead of dots
- section title separated by “-” shortened if possible
- input id/label as close and short as possible with only ‘-‘ as separators
- input type is usually the (rhf) value text/textarea/array/checkgroup/upload/radiogroup/select
[form-name]_[section-title]_[question-id]_[input]
Example: “abp1_pop-id_abp-pop-name_input”
It is imperative that this pattern be followed in all forms.