The buildForms
script can be used to bundle all form configurations and generate a folder structure for each supported project.
npm install # Make sure you run this before running the script
npm run buildForms
This will create a folder for each supported project in the ./dist
folder. You can then copy this folder to each respective project.
By default a new timestamp will be generated when running the script, which will be used to prefix all file and folder names. If you want to use a different date for this you can pass it in as an argument to the script:
npm run buildForms -- --date 2022-02-03T11:00:00
The date should be a valid ISO 8601 date and parsable by date-fns'
parseISO
function.
To run in a docker container clone this repo then run:
docker run -it --rm -v "$PWD":/app -w /app node:16 sh build-forms.sh
Make sure to test extensively your updates.
Loket
- Create a new submission
- Save the empty submission to check validations
- Fill the submission
- Ensure fields and subfields behave property, especially with
- Save the submission, close it, reopen it
- Send the submission, close it, reopen it
- Open a submission in
Concept
state created with the previous forms version - Open a submission in
Sent
state created with the previous forms version
Meldingsplichtige
- Create a new submission
- Save the empty submission to check validations
- Fill the submission
- Ensure fields and subfields behave property, especially with
- Save the submission, close it, reopen it
- Send the submission, close it, reopen it
- Open a submission in
Concept
state created with the previous forms version - Open a submission in
Sent
state created with the previous forms version
Toezicht
- Note
⚠️ forms should reside in http://mu.semte.ch/graphs/organizations/141d9d6b-54af-4d17-b313-8d1c30bc3f5b - Open a submission with the new form version
- Open a submission with the old form version
Full flow
- Create a submission with the new forms version in Loket, send it, make sure it appears in Toezicht and can be opened
- Same with a submission created with the old forms version but sent with the new forms version in application (env variable)
app-public-decisions-database
- Note
⚠️ forms should reside in http://mu.semte.ch/graphs/access-for-role/PubliekeBesluitendatabank-BesluitendatabankLezer - connect the app to a source loket (with delta's), assuming the new forms have been deployed at the source
- create e.g. a besluitenlijst in the source and see wether it comes through and you can open it
app-worship-decisions-database
- connect the app to a source loket (with delta's), assuming the new forms have been deployed at the source
- create e.g. notulen from an eredienstberstuur, and check it correctly syncs through, i.e. login as the same eredienstbestuur on worship-decisions-database
This list is meant to evolve and get filled by developpers encountering issues.
- Forms not opening in Toezicht ABB --> double check there is a migration defining the form file as a resource
- For app-public-decisions-database, there is another default graph where the forms-files are stored, so you will need to update the migration accordingly.
- For app-public-decisions-database, if a new form, very likely the business rules to decided whether it should be published or not, should be updated too.
- So most likely enrich-submission needs an upate too
This is a little guide of files and services that need to be updated when creating new form fields.
- Create your new field in
formSkeleton/inputFields/input-fields.ttl
with the appropriated constraints and adisplayType
. - If the
displayType
is a new one (it's the case if you need a custom behaviour or if it doesn't exist yet), you will need to create the matching component in ember-submission-form-fields and add the correct mappings in the following files :
- addon/helpers/component-for-display-type-edit.js
- addon/helpers/component-for-display-type-show.js
- addon/helpers/component-for-display-type.js
- Use the new field where it's needed in the forms
If your field is using new concept schemes they must be added in lib/enricher.js
of enrich-submission-service
If your field is using new relationships that are not added in the enrichment yet, they must be added in lib/enricher.js
of enrich-submission-service as well as in lib/submission-enricher.js
of import-submission-service
Furthermore, most likely, you want this field in the database if new relation: this toezicht-flattened-form-data-generator should be updated with a new extractor
Generate the project specific files using the npm run buildForms
script and paste the output in the app's root folder.
If you create a new configuration file, a few things need to be done :
- The
ACTIVE_FORM_FILE
environment variable of the enrich-submission-service needs to be updated to the new file name - Add migrations to the app defining the configuration file as a resource in the database (migration)
- Best to add the migration on all instances of the apps using it.
- Bear in mind: app-digitaal-loket, app-toezicht-abb, app-meldingsplichtige-api and app-public-decisions-database, app-worship-decisions-database are currently using it.
If you introduce new Dossier Types (i.e., Concepts), they have to be published in several places. Additionally, there are business rules that should be published so vendors know how to handle these new dossier types.
This should only happen on app-centrale-vindplaats. It's a simple TTL file that needs to be updated and ingested. Here is a reference. Take the latest migration you find and update the file.
This involves:
Data model for the rules can be found here.
Since these skos:Concept
s fall under data.vlaanderen.be
, they should be published here as well so they resolve correctly.
Example PR: Publishing to data.vlaanderen