hof-confirm-controller
HOF Controller for showing summary pages
The controller will create a set of "locals" data which is compatible with the confirm
view from hof-template-partials
.
Usage
If no sections config is passed, then the controller will create a section for each step that has fields, and a row within each section for each field on that step.
'/confirm': {
controller: require('hof-confirm-controller'),
...
}
Alternatively, sections can be defined manually as follows:
'/confirm': {
controller: require('hof-confirm-controller'),
sections: {
'museum-details': [
'name',
{
field: 'exhibit-addresses',
parse: (value) => value.map(a => a.address),
step: '/exhibit-add-another-address'
}
],
'contact': [
'contact-name',
'contact-email',
'contact-phone',
{
field: 'contact-address',
step: '/contact-address'
}
]
},
...
}
Configuration
The sections
configuration should be a map of arrays, where the entries in the array are the fields that should be shown within that section.
Field configuration
Fields can be defined as simple strings of the field key, in which case all default configuration will be used.
Alternatively, a field can be passed as an object with a field
property defining the field key, and any additional properties as follows:
step
- String
defines the step which the user is returned to to edit the field value. By default this is the first step in the form's steps configuration which contains the field.parse
- Function
can parse the value for the field from the session into a value for display.
Translations
The content for section headings and field labels will be loaded from translation files based on the keys.
Section headings
Translations for section headings are looked for in the following order:
pages.confirm.sections.${key}.header
pages.${key}.header
Field labels
Translations for field labels are looked for in the following order:
pages.confirm.fields.${key}.label
fields.${key}.label
fields.${key}.legend