Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/keyurparalkar/json-to-form
A project to demonstrate Dependency Injection Pattern with JSON based HTML forms
https://github.com/keyurparalkar/json-to-form
codemirror javascript jsonforms react schema shadcn-ui tailwindcss typescript zod
Last synced: 2 months ago
JSON representation
A project to demonstrate Dependency Injection Pattern with JSON based HTML forms
- Host: GitHub
- URL: https://github.com/keyurparalkar/json-to-form
- Owner: keyurparalkar
- Created: 2024-04-17T10:18:44.000Z (9 months ago)
- Default Branch: main
- Last Pushed: 2024-04-22T15:00:48.000Z (9 months ago)
- Last Synced: 2024-10-12T02:31:31.941Z (3 months ago)
- Topics: codemirror, javascript, jsonforms, react, schema, shadcn-ui, tailwindcss, typescript, zod
- Language: TypeScript
- Homepage: https://json-to-form-eta.vercel.app
- Size: 79.1 KB
- Stars: 9
- Watchers: 1
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
## JSON-TO-FORM
This project focuses on demonstrating the Dependency Injection(DI) pattern by transforming a JSON schema into an HTML form.
Here the JSON schema acts a depenedency to the `SchemaRenderer` component. This component requires JSON schema so that it can map over to this object and rendered the required input fields for the form.
This project was also demonstrated at the JSlovers meet-up. You can find the details about the talk below:
- Slides - [Building forms with Dependency Injection pattern in React.pdf](https://github.com/keyurparalkar/json-to-form/files/15064877/Building.forms.with.Dependency.Injection.pattern.in.React.pdf)
- [Talk](https://www.meetup.com/jslovers-pune/events/299433526/)### Inspiration
I got inspired to make this project when I was debugging a friends react based form. It had a lot of explicit conditional cases based on the specific input field which made that form more resistant to new changes.
I found JSON schema driven form based soltions, which I found to be extensible and easily configurable and testable.
### Approach
- Here is the approach that I took to implement the project:
- Every JSON schema should have the following format/fields so that we can call it a valid schema:
```ts
type TField = {
type: "field";
dataType: "number" | "text" | "email";
fieldName: string;
accessorKey: string;
validation?:
| {
required?:
| {
value: boolean;
message: string;
}
| undefined;
maxLength?:
| {
value: number;
message: string;
}
| undefined;
minLength?:
| {
value: number;
message: string;
}
| undefined;
max?:
| {
value: number;
message: string;
}
| undefined;
min?:
| {
value: number;
message: string;
}
| undefined;
pattern?:
| {
value: string;
message: string;
}
| undefined;
}
| undefined;
};type GroupFieldType = {
type: "group";
orientation: "horizontal" | "vertical";
fields: (TField | GroupFieldType)[];
};
```- Check the JSON schema input as per the above type by parsing it with [zod's schema parser](https://zod.dev/?id=basic-usage).
- Next, we pass this schema to `SchemaRenderer` component that renders each `field` type object with the `input` element.
- We make use of the react-hook-form to manage the form state and updates.
- Lastly, we unregister fields from the form state when any field is removed from the schema.### Advantages
With the help of the DI pattern we are able to easily configure forms. Making changes into the form is a breeze since we only need to change the JSON schema.
Here is a simple example of adding and removing fields
https://github.com/keyurparalkar/json-to-form/assets/14138515/b68e6a97-937b-42e6-9119-d91a21d4765a
You can also add validation to the form from the JSON schema itself:
https://github.com/keyurparalkar/json-to-form/assets/14138515/ab90fedd-02a8-4907-85d1-777be48de710
You can read more about dependency injection pattern in react [here](https://blog.logrocket.com/dependency-injection-react/).
### Libraries
- [react-hook-form](https://react-hook-form.com/)
- [shadcn-ui](https://ui.shadcn.com/)
- [codemirror-react](https://uiwjs.github.io/react-codemirror/)
- [zod](https://zod.dev/)