The purpose of this kata is to get you acquainted with actions and loaders in Qwik. The kata assumes you have already completed kata 2.
The idea here is to serialize our data model to the file system to demonstrate full stack capabilities of Qwik:
- Lifting local state so it can be managed from outside
- Writing and loading the inventory data from the file system or another external source
Complete the following:
- Lift the inventory state from
Inventory
to its parent so that the inventory data can be managed centrally. Hint: To keep this simple, focus on only a single inventory at first as supporting multiple will add complexity. - Derive the amount of inventory items dynamically at useTask and show it in the user interface. In this case you could avoid the calculation but it is good to understand how to derive data as this will come up with more complex use cases where you want to retain a single source of truth.
- Read and write the state of each inventory to the file system. The basic requirement here is that the system should persist its state even if you restart the application. The implementation should use Qwik actions and loaders. If you go with route actions and route loaders, you have to keep both at the route level as otherwise it won't work! Consider using a task for tracking the side effect that occurs when inventory items change. Hint: Most likely you will need to use the QRL type at the implementation to allow Qwik Optimizer to split up your code.
- Optional - Try using Form for sending data related to modifications.
- Optional - Try using zod for data validation. Can you see the benefit?
- Optional - Make the data model of the application more robust by introducing unique ids for items. You will have to refactor from simple strings to something more complex.
- Optional - Connect the persisted state to a database (SQLite or something more complex)
- Optional - Generalize the system to work with multiple inventories. Hint: Likely for this to work, you have to come up with a way to tell the inventories apart.