mss-engine-forms
Version:
A simple typehead library developed by MSS development team to be used for dynamic forms
122 lines • 20.6 kB
JavaScript
import { Component, EventEmitter, Input, Output } from "@angular/core";
import { FormControl, FormGroup, Validators } from "@angular/forms";
import * as i0 from "@angular/core";
import * as i1 from "@angular/forms";
import * as i2 from "@angular/common";
import * as i3 from "./components/dynamic-field/dynamic-field.component";
import * as i4 from "./components/dynamic-error/dynamic-error.component";
import * as i5 from "./_helpers/breakpoints.pipe";
export class MssFormsComponent {
constructor(_fb) {
this._fb = _fb;
this.isLoading = false;
this.cancelBtnOptions = null;
this.onSubmit = new EventEmitter();
this.fields = [];
}
ngOnInit() {
// this.buildForm();
}
ngOnChanges(changes) {
if (changes['model']) {
this.fields = [];
this.buildForm();
}
}
buildForm() {
const formGroupFields = this.getFormControlsFields();
// if (!this.dynamicFormGroup) {
this.dynamicFormGroup = new FormGroup(formGroupFields);
for (const field of Object.keys(this.model)) {
const fieldProps = this.model[field];
if (fieldProps?.disabled)
this.dynamicFormGroup.get(field).disable();
this.dynamicFormGroup.get(field)?.updateValueAndValidity();
}
// } else {
// this.getNewFormControlsFields()
// }
}
getFormControlsFields() {
const formGroupFields = {};
for (const field of Object.keys(this.model)) {
const fieldProps = this.model[field];
const validators = this.addValidator(fieldProps.rules);
formGroupFields[field] = new FormControl(fieldProps.value, validators);
let index = this.fields.findIndex((f) => {
if (f.fieldName == field)
return true;
return false;
});
if (index === -1)
this.fields.push({ ...fieldProps, fieldName: field });
}
return formGroupFields;
}
getNewFormControlsFields() {
Object.keys(this.model).map((model) => {
const fieldProps = this.model[model];
const validators = this.addValidator(fieldProps.rules);
if (!this.dynamicFormGroup['controls'][model]) {
this.dynamicFormGroup.addControl(model, this._fb.control({ value: fieldProps.value, disabled: fieldProps?.disabled ? true : false }, validators));
// this.dynamicFormGroup.get()
}
});
}
addValidator(rules) {
if (!rules) {
return [];
}
const validators = Object.keys(rules).map((rule, index) => {
switch (rule) {
case "required":
return Validators.required;
case "email":
return Validators.email;
case "minLength":
return Validators.minLength(Object.values(rules)[index]);
case "maxLength":
return Validators.maxLength(Object.values(rules)[index]);
case "pattern":
return Validators.pattern(Object.values(rules)[index]);
case "min":
return Validators.min(Object.values(rules)[index]);
case "max":
return Validators.max(Object.values(rules)[index]);
default:
return;
//add more case for future.
}
});
return validators;
}
submit() {
this.onSubmit.emit(this.dynamicFormGroup);
}
resetForm() {
this.dynamicFormGroup.reset();
}
setRule(formControlName, validators) {
if (this.dynamicFormGroup['controls'][formControlName])
this.dynamicFormGroup['controls'][formControlName].setValidators(validators);
}
}
MssFormsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: MssFormsComponent, deps: [{ token: i1.FormBuilder }], target: i0.ɵɵFactoryTarget.Component });
MssFormsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: MssFormsComponent, selector: "lib-mss-forms", inputs: { model: "model", isLoading: "isLoading", submitBtnOptions: "submitBtnOptions", cancelBtnOptions: "cancelBtnOptions", error: "error" }, outputs: { onSubmit: "onSubmit" }, usesOnChanges: true, ngImport: i0, template: "<form [formGroup]=\"dynamicFormGroup\" (ngSubmit)=\"submit()\" (keyup.enter)=\"submit()\">\n <div class=\"row\">\n <div *ngFor=\"let field of fields\" class=\"col-12 custom-engine-field-container\" [ngClass]=\"field | breakpoint\">\n <app-field-input [field]=\"field\"></app-field-input>\n <app-dynamic-error [field]=\"field\"></app-dynamic-error>\n </div>\n <div *ngIf=\"cancelBtnOptions\" class=\"col-12\" [ngClass]=\"cancelBtnOptions | breakpoint\">\n <button type=\"button\" (click)=\"cancelBtnOptions?.submit()\"\n class=\"w-100 d-flex align-items-center justify-content-center btn-default\">\n {{cancelBtnOptions?.content}}\n </button>\n </div>\n <div class=\"col-12\" [ngClass]=\"submitBtnOptions | breakpoint\">\n <button type=\"submit\" [disabled]=\"isLoading || dynamicFormGroup.invalid\"\n class=\"w-100 d-flex align-items-center justify-content-center btn-primary\">\n <div *ngIf=\"isLoading\" class=\"spinner-border text-primary\"></div>\n <ng-container *ngIf=\"!isLoading\">{{submitBtnOptions?.content}}</ng-container>\n </button>\n </div>\n </div>\n\n</form>", dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "component", type: i3.DynamicFieldComponent, selector: "app-field-input", inputs: ["field"] }, { kind: "component", type: i4.DynamicErrorComponent, selector: "app-dynamic-error", inputs: ["field"] }, { kind: "pipe", type: i5.BreakpointPipe, name: "breakpoint" }] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: MssFormsComponent, decorators: [{
type: Component,
args: [{ selector: 'lib-mss-forms', template: "<form [formGroup]=\"dynamicFormGroup\" (ngSubmit)=\"submit()\" (keyup.enter)=\"submit()\">\n <div class=\"row\">\n <div *ngFor=\"let field of fields\" class=\"col-12 custom-engine-field-container\" [ngClass]=\"field | breakpoint\">\n <app-field-input [field]=\"field\"></app-field-input>\n <app-dynamic-error [field]=\"field\"></app-dynamic-error>\n </div>\n <div *ngIf=\"cancelBtnOptions\" class=\"col-12\" [ngClass]=\"cancelBtnOptions | breakpoint\">\n <button type=\"button\" (click)=\"cancelBtnOptions?.submit()\"\n class=\"w-100 d-flex align-items-center justify-content-center btn-default\">\n {{cancelBtnOptions?.content}}\n </button>\n </div>\n <div class=\"col-12\" [ngClass]=\"submitBtnOptions | breakpoint\">\n <button type=\"submit\" [disabled]=\"isLoading || dynamicFormGroup.invalid\"\n class=\"w-100 d-flex align-items-center justify-content-center btn-primary\">\n <div *ngIf=\"isLoading\" class=\"spinner-border text-primary\"></div>\n <ng-container *ngIf=\"!isLoading\">{{submitBtnOptions?.content}}</ng-container>\n </button>\n </div>\n </div>\n\n</form>" }]
}], ctorParameters: function () { return [{ type: i1.FormBuilder }]; }, propDecorators: { model: [{
type: Input
}], isLoading: [{
type: Input
}], submitBtnOptions: [{
type: Input
}], cancelBtnOptions: [{
type: Input
}], error: [{
type: Input
}], onSubmit: [{
type: Output
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"mss-forms.component.js","sourceRoot":"","sources":["../../../../projects/mss-forms/src/lib/mss-forms.component.ts","../../../../projects/mss-forms/src/lib/mss-forms.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges } from \"@angular/core\";\nimport { FormBuilder, FormControl, FormGroup, Validators } from \"@angular/forms\";\n\n@Component({\n  selector: 'lib-mss-forms',\n  templateUrl: './mss-forms.component.html',\n  styles: [\n  ]\n})\nexport class MssFormsComponent implements OnInit, OnChanges {\n\n  @Input() model: any;\n  @Input() isLoading: boolean = false;\n  // @Input() submitBtnTxt: string = \"\";\n  @Input() submitBtnOptions: any\n  @Input() cancelBtnOptions: any = null\n  @Input() error: any;\n  @Output() onSubmit = new EventEmitter();\n  public dynamicFormGroup: any;\n  public fields: any = [];\n\n  constructor(private _fb: FormBuilder) { }\n\n  ngOnInit() {\n    // this.buildForm();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes['model']) {\n      this.fields = []\n      this.buildForm()\n    }\n  }\n\n\n\n  private buildForm() {\n    const formGroupFields = this.getFormControlsFields();\n    // if (!this.dynamicFormGroup) {\n    this.dynamicFormGroup = new FormGroup(formGroupFields)\n    for (const field of Object.keys(this.model)) {\n      const fieldProps = this.model[field];\n      if (fieldProps?.disabled) this.dynamicFormGroup.get(field).disable()\n      this.dynamicFormGroup.get(field)?.updateValueAndValidity()\n    }\n    // } else {\n    //   this.getNewFormControlsFields()\n    // }\n  }\n\n  private getFormControlsFields() {\n    const formGroupFields: any = {};\n    for (const field of Object.keys(this.model)) {\n\n      const fieldProps = this.model[field];\n      const validators: any = this.addValidator(fieldProps.rules);\n\n      formGroupFields[field] = new FormControl(fieldProps.value, validators);\n\n      let index = this.fields.findIndex((f: any) => {\n        if (f.fieldName == field) return true\n        return false\n      })\n      if (index === -1) this.fields.push({ ...fieldProps, fieldName: field });\n    }\n    return formGroupFields;\n  }\n\n  private getNewFormControlsFields() {\n    Object.keys(this.model).map((model) => {\n      const fieldProps = this.model[model];\n      const validators: any = this.addValidator(fieldProps.rules);\n      if (!this.dynamicFormGroup['controls'][model]) {\n        this.dynamicFormGroup.addControl(model, this._fb.control({ value: fieldProps.value, disabled: fieldProps?.disabled ? true : false }, validators))\n        // this.dynamicFormGroup.get()\n      }\n    })\n  }\n\n  private addValidator(rules: any) {\n    if (!rules) {\n      return [];\n    }\n\n    const validators = Object.keys(rules).map((rule, index) => {\n      switch (rule) {\n        case \"required\":\n          return Validators.required;\n        case \"email\":\n          return Validators.email;\n        case \"minLength\":\n          return Validators.minLength(Object.values(rules)[index] as number);\n        case \"maxLength\":\n          return Validators.maxLength(Object.values(rules)[index] as number);\n        case \"pattern\":\n          return Validators.pattern(Object.values(rules)[index] as string);\n        case \"min\":\n          return Validators.min(Object.values(rules)[index] as number)\n        case \"max\":\n          return Validators.max(Object.values(rules)[index] as number)\n        default:\n          return\n        //add more case for future.\n      }\n    });\n    return validators;\n  }\n\n\n  submit() {\n    this.onSubmit.emit(this.dynamicFormGroup)\n  }\n\n  resetForm() {\n    this.dynamicFormGroup.reset()\n  }\n\n  setRule(formControlName: string, validators: any) {\n    if (this.dynamicFormGroup['controls'][formControlName]) this.dynamicFormGroup['controls'][formControlName].setValidators(validators)\n  }\n}\n","<form [formGroup]=\"dynamicFormGroup\" (ngSubmit)=\"submit()\" (keyup.enter)=\"submit()\">\n    <div class=\"row\">\n        <div *ngFor=\"let field of fields\" class=\"col-12 custom-engine-field-container\" [ngClass]=\"field | breakpoint\">\n            <app-field-input [field]=\"field\"></app-field-input>\n            <app-dynamic-error [field]=\"field\"></app-dynamic-error>\n        </div>\n        <div *ngIf=\"cancelBtnOptions\" class=\"col-12\" [ngClass]=\"cancelBtnOptions | breakpoint\">\n            <button type=\"button\" (click)=\"cancelBtnOptions?.submit()\"\n                class=\"w-100 d-flex align-items-center justify-content-center btn-default\">\n                {{cancelBtnOptions?.content}}\n            </button>\n        </div>\n        <div class=\"col-12\" [ngClass]=\"submitBtnOptions | breakpoint\">\n            <button type=\"submit\" [disabled]=\"isLoading || dynamicFormGroup.invalid\"\n                class=\"w-100 d-flex align-items-center justify-content-center btn-primary\">\n                <div *ngIf=\"isLoading\" class=\"spinner-border text-primary\"></div>\n                <ng-container *ngIf=\"!isLoading\">{{submitBtnOptions?.content}}</ng-container>\n            </button>\n        </div>\n    </div>\n\n</form>"]}