Skip to content

This is an Angular project consisting of two primary components: Form Builder and Form Renderer. These components enable users to create dynamic forms through a drag-and-drop interface, render the forms, submit them, and view the submissions. And all the forms and submission are stored in a JSON format.

Notifications You must be signed in to change notification settings

AniruddhaSadhukhan/dynamic-forms

Repository files navigation

Dynamic Forms

This is an Angular project consisting of two primary components: Form Builder and Form Renderer. These components enable users to create dynamic forms through a drag-and-drop interface, render the forms, submit them, and view the submissions. And all the forms and submission are stored in a JSON format. This project is built using the FORMIO library, focusing on the client-side aspects, and excludes server-side functionality.

Form Builder

The Angular Dynamic Form Builder is a powerful tool that allows users to create forms in the UI using a drag-and-drop interface. This project provides a user-friendly way to design forms with various components and layout options and then export the form's configuration or structure in JSON format.

Inputs & Outputs

Input/Output Name Description
initialForm Input This is an optional input. If a JSON of a form is provided, that form will be loaded and then the user can edit that.
save Output On clicking the Save Form button, this will emit the JSON of the form structure.

Screenshot

Form Renderer

The Angular Dynamic Form Renderer can then render the form in json format created previously by the form builder for the user to fill up. After submitting the form, a JSON will be created with the values of the submission by the Form Renderer. Then submission JSON can also be used to prefill the Form Renderer or show the submission in read only mode in the Form Renderer.

Inputs & Outputs

Input/Output Name Description
form Input This is the JSON of a form structure that will be rendered. The JSON will be created by the Form Builder previously.
submission Input This is an optional input. If submission JSON is provided, that form will be prefilled by that and then the user can edit that if read-only mode is not set.
readOnly Input This is an optional input. If this readOnly mode is true, that form will not allow the user to edit it.
submit Output On clicking the Submit button, this will emit the JSON of the form submission.

Screenshot

Example

  1. Creating Form using Form Builder
  2. The form will be saved in JSON format
{
  "components": [
    {
      "label": "HTML",
      "tag": "h2",
      "attrs": [
        {
          "attr": "",
          "value": ""
        }
      ],
      "content": "A Random Form",
      "refreshOnChange": false,
      "key": "html",
      "type": "htmlelement",
      "input": false,
      "tableView": false
    },
    {
      "label": "Name",
      "columns": [
        {
          "components": [
            {
              "label": "First Name",
              "applyMaskOn": "change",
              "validate": {
                "required": true
              },
              "key": "firstName",
              "type": "textfield",
              "input": true,
              "tableView": true
            }
          ],
          "width": 4,
          "offset": 0,
          "push": 0,
          "pull": 0,
          "size": "md",
          "currentWidth": 4
        },
        {
          "components": [
            {
              "label": "Middle Name",
              "applyMaskOn": "change",
              "key": "middleName",
              "type": "textfield",
              "input": true,
              "tableView": true
            }
          ],
          "width": 4,
          "offset": 0,
          "push": 0,
          "pull": 0,
          "size": "md",
          "currentWidth": 4
        },
        {
          "components": [
            {
              "label": "Last Name",
              "applyMaskOn": "change",
              "validate": {
                "required": true
              },
              "key": "firstName1",
              "type": "textfield",
              "input": true,
              "tableView": true
            }
          ],
          "size": "md",
          "width": 4,
          "offset": 0,
          "push": 0,
          "pull": 0,
          "currentWidth": 4
        }
      ],
      "key": "name",
      "type": "columns",
      "input": false,
      "tableView": false
    },
    {
      "label": "Tabs",
      "components": [
        {
          "label": "Tab 1",
          "key": "tab1",
          "components": [
            {
              "label": "Columns",
              "columns": [
                {
                  "components": [
                    {
                      "label": "Date of Birth",
                      "datePicker": {
                        "disableWeekends": false,
                        "disableWeekdays": false
                      },
                      "enableMinDateInput": false,
                      "enableMaxDateInput": false,
                      "key": "dateOfBirth",
                      "type": "datetime",
                      "input": true,
                      "tableView": false,
                      "widget": {
                        "type": "calendar",
                        "displayInTimezone": "viewer",
                        "locale": "en",
                        "useLocaleSettings": false,
                        "allowInput": true,
                        "mode": "single",
                        "enableTime": true,
                        "noCalendar": false,
                        "format": "yyyy-MM-dd hh:mm a",
                        "hourIncrement": 1,
                        "minuteIncrement": 1,
                        "time_24hr": false,
                        "minDate": null,
                        "disableWeekends": false,
                        "disableWeekdays": false,
                        "maxDate": null
                      }
                    }
                  ],
                  "width": 6,
                  "offset": 0,
                  "push": 0,
                  "pull": 0,
                  "size": "md",
                  "currentWidth": 6
                },
                {
                  "components": [
                    {
                      "label": "Phone Number",
                      "applyMaskOn": "change",
                      "key": "phoneNumber",
                      "type": "phoneNumber",
                      "input": true,
                      "tableView": true
                    }
                  ],
                  "width": 6,
                  "offset": 0,
                  "push": 0,
                  "pull": 0,
                  "size": "md",
                  "currentWidth": 6
                }
              ],
              "key": "columns",
              "type": "columns",
              "input": false,
              "tableView": false
            }
          ]
        },
        {
          "label": "Tab 2",
          "key": "tab2",
          "components": []
        }
      ],
      "key": "tabs",
      "type": "tabs",
      "input": false,
      "tableView": false
    },
    {
      "label": "Survey",
      "tableView": false,
      "questions": [
        {
          "label": "How was the product?",
          "value": "howWasTheProduct",
          "tooltip": ""
        },
        {
          "label": "How was the delivery?",
          "value": "howWasTheDelivery",
          "tooltip": ""
        }
      ],
      "values": [
        {
          "label": "Very Good",
          "value": "veryGood",
          "tooltip": ""
        },
        {
          "label": "Good",
          "value": "good",
          "tooltip": ""
        },
        {
          "label": "Medium",
          "value": "medium",
          "tooltip": ""
        },
        {
          "label": "Bad",
          "value": "bad",
          "tooltip": ""
        },
        {
          "label": "Very Bad",
          "value": "veryBad",
          "tooltip": ""
        }
      ],
      "key": "survey",
      "type": "survey",
      "input": true
    },
    {
      "label": "Signature",
      "key": "signature",
      "type": "signature",
      "input": true,
      "tableView": false
    },
    {
      "label": "Columns",
      "columns": [
        {
          "components": [
            {
              "label": "Reset",
              "action": "reset",
              "showValidations": false,
              "theme": "danger",
              "block": true,
              "leftIcon": "fa fa-eraser",
              "key": "reset",
              "type": "button",
              "input": true,
              "tableView": false
            }
          ],
          "width": 6,
          "offset": 0,
          "push": 0,
          "pull": 0,
          "size": "md",
          "currentWidth": 6
        },
        {
          "components": [
            {
              "label": "Submit",
              "showValidations": false,
              "block": true,
              "leftIcon": "fa fa-floppy-o",
              "disableOnInvalid": true,
              "key": "submit",
              "type": "button",
              "input": true,
              "tableView": false,
              "saveOnEnter": false
            }
          ],
          "width": 6,
          "offset": 0,
          "push": 0,
          "pull": 0,
          "size": "md",
          "currentWidth": 6
        }
      ],
      "autoAdjust": true,
      "key": "columns1",
      "type": "columns",
      "input": false,
      "tableView": false
    }
  ]
}
  1. Viewing the form and filling it up
  2. After submit, it will give a submission JSON
{
  "data": {
    "firstName": "Abc",
    "middleName": "",
    "firstName1": "Xyz",
    "dateOfBirth": "2023-09-05T12:00:00+05:30",
    "phoneNumber": "",
    "survey": {
      "howWasTheProduct": "good",
      "howWasTheDelivery": "medium"
    },
    "signature": "",
    "reset": false,
    "submit": true
  },
  "metadata": {
    "timezone": "Asia/Kolkata",
    "offset": 330,
    "origin": "https://ani-dynamic-forms-demo.surge.sh",
    "referrer": "",
    "browserName": "Netscape",
    "userAgent": "Mozilla/5.0 (X11; Linux x86_64; rv:109.0) Gecko/20100101 Firefox/116.0",
    "pathName": "/",
    "onLine": true
  },
  "state": "submitted",
  "_vnote": ""
}
  1. You can use the submission JSON to pre-fill the form or see it in read only mode.

Development server

Run npm run serve for a dev server. Navigate to http://localhost:4200/. The application will automatically reload if you change any of the source files.

Build

Run npm run build to build the project. The build artifacts will be stored in the dist/ directory.

About

This is an Angular project consisting of two primary components: Form Builder and Form Renderer. These components enable users to create dynamic forms through a drag-and-drop interface, render the forms, submit them, and view the submissions. And all the forms and submission are stored in a JSON format.

Topics

Resources

Stars

Watchers

Forks