This is a proof of concept (POC) about creating a wizard form for data entry single submission in Angular 14, most of the concepts and ideas used here are valid in other frameworks too.
This POC specifically created for the following scenario:
- You have a submission form for data entry.
- It needs to be divided into some steps as a wizard for better user experience and more simplicity.
- It's a single submission form, which means that no submit on each step, only one submission in the last step.
- There is some interactions and changes may be needed between the steps.
- Each step has it's own design and components to represent it's part of the form submission.
If you decide to design the above wizard in Angular the normal way you'll face the following challenges:
- Syncing data from the parent (wizard container) to the children (steps) and vise versa.
- Interaction between steps when needed.
- Validation before going to the next step or submit.
- Handling step nivigation logic in a clean way instead of implementing it in each step.
- Guarantee direct reflection of the data changes on the UI regardless of which step you see.
- Guarantee that all the data gathered correctly on submit.
- Timing issues on edit scenario, when will all the step components be ready? when I can bind my data for edit?
- Handle a lot of user interactions and reflect effects on the same step or other next one or more if needed.
If we used the standard Angular approach without a good analysis of the above scenario we'll end up with a dirty solution with tons of events and subscriptions. Angular standard way is great for loosely coupled components, to design a fine grained peice of UI to reuse it many times in a generic way and this is awsome, but the fact about the wizard in the above scenario is that it's a container and children with tightly coupled nature, and the steps itself are just parts of the form and it's not planned to be used anywhere else.
I respected the tightly coupled nature of the wizard and used Angular standards considering this, I came with a very good solution (in my opinion) which ended up with clean, organized and extesible code and approach.
Please feel free to check out the POC code to see the solution.
Note: Sorry I know that the UI is ugly, that's because my POC has nothing with styling, it's a front-end architecture POC :)
This project was generated with Angular CLI version 14.0.6.
Run npm i
Run npm run start
to run on localhost:4200
Made with love by Ayyoub Jadoo