Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/formswizard/forms-designer
Drag&Drop based UI for generating JSONSchema based forms
https://github.com/formswizard/forms-designer
Last synced: about 2 months ago
JSON representation
Drag&Drop based UI for generating JSONSchema based forms
- Host: GitHub
- URL: https://github.com/formswizard/forms-designer
- Owner: FormsWizard
- License: mit
- Created: 2023-07-27T14:30:31.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2023-09-26T11:37:15.000Z (over 1 year ago)
- Last Synced: 2024-11-07T09:29:01.961Z (2 months ago)
- Language: TypeScript
- Homepage:
- Size: 1.93 MB
- Stars: 6
- Watchers: 1
- Forks: 1
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Forms Designer
[![Test build pipeline](https://github.com/FormsWizard/forms-designer/actions/workflows/staging.yml/badge.svg)](https://github.com/FormsWizard/forms-designer/actions/workflows/staging.yml)
[![Deploy Next.js site to Pages](https://github.com/FormsWizard/forms-designer/actions/workflows/pages.yml/badge.svg)](https://github.com/FormsWizard/forms-designer/actions/workflows/pages.yml)## Overview
FormsDesigner is a WYSIWYG editor developed in TypeScript for creating diverse forms using the JSONForms framework. It enables the creation of a JSON-Schema and an UI-schema for streamlined form creation and management.
## Open a Demo
The following Live Demos can be opened from the following links:
- [Create React App](https://formswizard.github.io/forms-designer/cra/)
- [Next.js](https://formswizard.github.io/forms-designer/next/)
- [Storybook](https://formswizard.github.io/forms-designer/storybook/)To view a demo on your local machine, execute the following command:
```sh
pnpm export
(cd apps/cra/out/; python -m http.server) &
xdg-open http://localhost:8000
```alternatively you can launch a dev build see [Develop](#develop) for more details.
## Details
FormsDesigner allows for the easy and efficient creation of forms, producing JSON-Schema and UI-schema which can be used independently with JSONForms, enhancing its compatibility across various frameworks like VueJS, Angular, and Vanilla JS. It employs a modular approach for extending by providing new renderers for both the final form and the editing process.
The FormsDesigner is a part of the broader FormsWizard project, which delivers a complete No-Code solution to form creation and management, with synchronization and serverless operations brought by the FormsWizard project as a whole.
## Apps and Packages
This Turborepo includes various packages and apps:
### Apps
- `./apps/cra`: An example using Create-React-App.
- `./apps/docs`: Holds the documentation.
- `./apps/storybook`: A Storybook for visualizing components.
- `./apps/vite`: An example using ViteJS.
- `./apps/web`: A web application built with Next.js.### Packages
- `./packages/basic-renderer`: Contains basic renderers for the project.
- `./packages/core`: Essential core functionalities for FormsDesigner.
- `./packages/eslint-config-custom`: Provides custom ESLint configurations.
- `./packages/experimental-renderers` & `./packages/experimental-renderers_next`: Experimental renderers for different environments, like location picker (leaflet).
- `./packages/fieldSettings`: Field Settings logic and settings typically seen within the right drawer
- `./packages/forms-designer`: The main FormsDesigner package.
- `./packages/jest-presets`: Contains Jest presets for turbo repos.
- `./packages/react-hooks`: Includes React hooks used in the project.
- `./packages/renderer`: Houses special drag-and-drop renderers needed for the editor view.
- `./packages/state`: Manages state within the project.
- `./packages/theme`: Contains theming details and configurations.
- `./packages/toolbox`: A toolbox seen within the left drawer, where one can pick tools and blocks
- `./packages/tsconfig`: Holds TypeScript configuration details.
- `./packages/types`: Type definitions used across the project.
- `./packages/utils`: General utilities for various tasks.Each package/app is fully developed in TypeScript and provides type definitions.
## Build
To build all apps and packages, execute:
```sh
pnpm build
```## Develop
To develop all apps and packages, execute:
```sh
pnpm dev
```If you only want to run a task for part of the projects use turbo's filtering:
```sh
pnpm dev --filter @formswizard/forms-designer-renderer
```
or exclude certain apps:
```sh
pnpm dev --filter '!@formswizard/web' --filter '!@formswizard/storybook'
```
## TestTo run all tests, execute:
```sh
pnpm test
```## Update dependencies
To update all dependencies, execute:
```sh
pnpm update -r --latest
```### Utilities
This Turborepo has some additional tools already setup for you:
- [TypeScript](https://www.typescriptlang.org/) for static type checking
- [ESLint](https://eslint.org/) for code linting
- [Prettier](https://prettier.io) for code formatting### Useful Links
Learn more about the power of Turborepo:
- [Tasks](https://turbo.build/repo/docs/core-concepts/monorepos/running-tasks)
- [Caching](https://turbo.build/repo/docs/core-concepts/caching)
- [Remote Caching](https://turbo.build/repo/docs/core-concepts/remote-caching)
- [Filtering](https://turbo.build/repo/docs/core-concepts/monorepos/filtering)
- [Configuration Options](https://turbo.build/repo/docs/reference/configuration)
- [CLI Usage](https://turbo.build/repo/docs/reference/command-line-reference)