npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

sh-dynamic-form-builder

v2.7.9

Published

Dynamic form builder, generate form controls, form group and form array

Downloads

339

Readme

todo

Demo

✔️ Version 2.7.0

  • Customizing form array title by setting titleClass property
  • Ability to define as many form group with as many fields you want for each
  • Setting full with buttons for mobile and another device size by setting fullWidthButtons property

✔️ Version 2.6.0

  • Sizing for control and label by values: small,medium and large.Default is medium
  • Red color added to color of buttons
  • Simple validation error style has added that shows red text without background color.You can reached it by setting simpleValidationError:true

Some Features

  • Ability to define form fields by type
  • Ability to define as many form arrays with as many fields you want for each
  • Ability to define as many form group with as many fields you want for each
  • Has a config for Add button of form array
  • Ability to define the as many validation rules and error message of the field and the form array fields as desired
  • Has a config for form array divider
  • Ability to define Send, Reset and Cancel buttons with the desired title, color, and order
  • Binding form by object in edit mode
  • Bootstrap style

Field types

  • Text
  • Range
  • Number
  • Password
  • Color
  • Dropdown
  • Radio
  • Checkbox
  • File
  • Date
  • Datetime local
  • Time
  • Week
  • Month
  • Form array
  • Form group

Table of contents

Install

npm i sh-dynamic-form-builder

Install dependencies

npm install bootstrap --save
npm install bootstrap-icons --save
npm install sh-ordinal-numbers --save

Quick start

import { DynamicFormBuilderModule } from "sh-dynamic-form-builder";

@NgModule({
  imports: [DynamicFormBuilderModule],
})
export class AppModule {}

Import style and icon

In angular.json

"styles": [
    "src/styles.scss",
    "./node_modules/bootstrap/dist/css/bootstrap.min.css"
    "./node_modules/bootstrap-icons/font/bootstrap-icons.scss"
]

If Bootstrap icons don't work, you should import them in global style.

@import "~bootstrap-icons/font/bootstrap-icons";

How to use?

In component

formGroup = new FormGroup({});
isSubmit: boolean = false;
config: IFormConfig = {
    title: 'Profile',
    fields: [
      {
        type: 'text', name: 'fullName', label: 'Full name', id: 'fullName',
        validators: [
          { rule: 'required', msg: 'Full name is required' },
          { rule: 'minlength', value: 6, msg: 'Full name must be at least 6 characters long' },

        ],
      },
      {
        type: 'form-array',
        label: 'Tasks',
        name: 'tasks',
        formArray: {
          simpleAddButton: true,
          addButtonBGColor: 'green',
          fields: [
            {
              type: 'text', name: 'title', label: 'title', validators: [
                { rule: 'required', msg: 'title is required!' },
                { rule: 'maxlength', value: 50, msg: 'Maximum length should be 50 characters' }
              ]
            },
            {
              type: 'date', name: 'dueDate', label: 'due date', validators: [
                { rule: 'required', msg: 'date is required!' }
              ]
            }
          ]
        }
      },
      {
        type: 'text', name: 'email1', label: 'E-mail',
        validators: [
          { rule: 'email', msg: 'E-mail is wrong' }
        ],
      },
      {
        type: 'file', name: 'avatar', label: 'Avatar',
        onUpload: this.onUpload.bind(this), multipleFile: true
      }
      ...
        buttonSetting: {
      fullWidthButtons: 'only-mobile',
      buttons:
        [
          { type: 'submit', caption: 'Submit', bgColor: 'blue' },
          { type: 'reset', caption: 'Reset', bgColor: 'orange' },
          { type: 'cancel', caption: 'Cancel', bgColor: 'light' }
        ]
    }
}
private onUpload(event: any): void {
    const files = event.files;
    ...
}
 public submit(event: FormGroup): void {
    this.isSubmit = true;
    this.formGroup = event;
    /**Sending data ... */
    this.isSubmit = false;
 }
 public cancel(): void {
    /** */
 }

In template

<div class="container">
  <sh-dynamic-form-builder
    [config]="config"
    [isSubmit]="isSubmit"
    (submit)="submit($event)"
  >
  </sh-dynamic-form-builder>
</div>

Input

| Name | Type | Default | Required? | Description | | ----------------- | ------------- | ------- | --------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | | config | IFormConfig | - | yes | Form config | | formValue | object | {} | - | Adjust form values | | isSubmit | boolean | false | no | Set in to your Submit Function. If it sets "true", Submit button will be disabled.When submit is clicked it must be set "true" value, when sending data will be ended it must be set "false" value |

  • Config

| Name | Type | Default | Required? | Description | | ----------------------------------------- | -------------------- | ------- | --------- | --------------------------------------------------------------------------------------------------------------- | | fields | IMainFieldItem | - | yes | Form fields | | title | string | - | no | Form title | | titleClass | string | - | no | Set style for form title, you can add one or more class name split by space. for example:'class1 class2 class3' | | buttonSetting | IButtonSetting | {} | yes | Button setting | | formControlConfig | IFormControlConfig | {} | yes | Form controls configuration |

  • Form control config

| Name | Type | Default | Required? | Description | | --------------------- | --------- | -------- | --------- | ----------------------------------------------------------------- | | elementSize | string | medium | no | Control size and label size | | simpleValidationError | boolean | false | no | Red text without background color as the validation error message |

Output

| Name | Type | Description | | -------- | ----------- | -------------------------------------------- | | (submit) | FormGroup | Output formGroup, when Submit button clicked | | (cancel) | boolean | When the Cancel button has been clicked |

Field properties and methods

| Name | Type | Default | Required? | Description | | --------------------------- | ------------------ | ------- | --------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | | type | string | - | yes | Allowed values: text, range, number, password, color, dropdown, radio, checkbox, file, date, datetime-local, time, week, month, form-group and form-array | | name | string | - | yes | Form control name | | defaultValue | any | - | no | Form control default value | | placeholder | string | - | no | Usable for text, number, password, dropdown and email | | [validators] | IValidationRules | - | no | Set validator rules and error messages | | id | string | - | no | Element id | | width | number | 100% | no | Width of Control | | disable | boolean | false | no | Disable control |

  • File

    | Name | Type | Default | Required? | Description | | ------------------------ | --------- | ------- | --------- | -------------------------- | | onUpload | void | - | yes | File selection event. | | multipleFile | boolean | false | no | Allow choice multiple file |

  • Text

    | Name | Type | Default | Required? | Description | | --------- | --------- | ------- | --------- | ----------------------------------------------------- | | multiline | boolean | false | no | Multiline handling | | rowCount | number | 5 | no | Specifies the visible height of a text area, in lines |

  • Radio

    | Name | Type | Default | Required? | Description | | --------- | --------- | ------- | --------- | -------------------------------------------- | | [options] | IOption | - | yes | Define options: {key: string;label: string;} | | inline | boolean | false | no | Show on the same horizontal row |

  • dropdown

    | Name | Type | Default | Required? | Description | | --------- | --------- | ------- | --------- | -------------------------------------------- | | [options] | IOption | - | yes | Define options: {key: string;label: string;} |

  • Range

    | Name | Type | Default | Required? | Description | | --------- | -------- | ------- | --------- | ----------------- | | rangeMin | number | 0 | no | value of the min | | rangeMax | number | 100 | no | value of the max | | rangeStep | number | 1 | no | value of the step |

    • Form-group

    | Name | Type | Default | Required? | Description | | ----------------------- | ------------ | ------- | --------- | ------------------------------------- | | formGroup | IFormGroup | - | no | Set form group fields and validations |

    • FormGroup

    | Name | Type | Default | Required? | Description | | ---------- | --------------------- | ------- | --------- | --------------------------------------------------------------------------------------------------------------------- | | [fields] | IFormGroupFieldItem | - | yes | Form group fields | | titleClass | string | - | no | Set style for form group title, you can add one or more class name split by space. for example:'class1 class2 class3' | | showInCard | boolean | false | no | Show in bootstrap card |

  • Form-array

    | Name | Type | Default | Required? | Description | | ----------------------- | ------------ | ------- | --------- | ------------------------------------- | | formArray | IFormArray | - | no | Set form array fields and validations |

    • FormArray

      | Name | Type | Default | Required? | Description | | ------------------- | --------------------- | ------- | --------- | ---------------------------------------------------------------------------- | | [fields] | IFormArrayFieldItem | - | yes | Form array fields | | simpleAddButton | boolean | false | no | Only icon on button, without text | | addButtonBGColor | string | gray | no | Allowed values: gray, green, blue, red, orange, light and dark | | divider | IDivider | - | no | doesn't show an ordinal number in the center of the divider line |

      • Divider

        | Name | Type | Default | Required? | Description | | --------------------- | --------- | ------- | --------- | ---------------------------------------------------------------------------------------------------------------------------------------- | | suppress | boolean | false | no | Doesn't show divider | | lineClass | string | - | no | Set style for divider line, you can add one or more class name split by space. for example:'class1 class2 class3' | | ordinalNumberClass | string | - | no | Set style for ordinal number between divider line, you can add one or more class name split by space. for example:'class1 class2 class3' | | suppressOrdinalNumber | boolean | false | no | Doesn't show an ordinal number in the center of the divider line | | height | number | 3 | no | The height of divider |

Button setting

| Name | Type | Default | Required? | Description | | ------------------------------- | --------- | ------- | --------- | -------------------------------------------- | | [buttons] | IButton | [] | yes | The array of buttons, order by definition | | buttonsAlign | string | left | no | Usable when fullWidthButtons is false | | fullWidthButtons | string | none | no | Allowed values: none, all, only-mobile |

  • Button properties

| Name | Type | Required? | Description | | ------- | -------- | --------- | ---------------------------------------------------------------------------- | | type | string | yes | Allowed values: submit, cancel and reset | | caption | string | yes | Button caption | | bgColor | string | yes | Allowed values: gray, green, blue, red, orange, light and dark |

Validators

| name | type | Required | Description | | ------------------------ | -------- | -------- | --------------------------------------------------------- | | rule | string | yes | Define rules | | msg | string | yes | Error message | | value | any | no | Usable for min, max,pattern,minlength and maxlength rules |

  • Validator rules

| Name | Type | Description | | ------------ | --------- | -------------------------------------------------------------------------------------------------------------------- | | min | number | Validator that requires the control's value to be greater than or equal to the provided number. | | max | number | Validator that requires the control's value to be less than or equal to the provided number. | | email | boolean | Validator that requires the control's value pass an email validation test. | | pattern | string | Validator that requires the control's value to match a regex pattern. | | required | boolean | Validator that requires the control have a non-empty value. | | requiredTrue | boolean | Validator that requires the control's value be true. This validator is commonly used for required checkboxes. | | minLength | number | Validator that requires the length of the control's value to be greater than or equal to the provided minimum length | | maxLength | number | Validator that requires the length of the control's value to be less than or equal to the provided maximum length. |

Creator

Hakime sheikhalishahi

License

MIT