UNPKG

ngx-config-form

Version:
260 lines 24.6 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, EventEmitter, forwardRef, Input, Output } from '@angular/core'; import { FormBuilder, FormGroup, NG_VALUE_ACCESSOR } from '@angular/forms'; import { BehaviorSubject } from 'rxjs'; /** @type {?} */ const USER_PROFILE_VALUE_ACCESSOR = { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef((/** * @return {?} */ () => FormComponent)), multi: true }; export class FormComponent { /** * @param {?} fb */ constructor(fb) { this.fb = fb; this.isReady = false; this.errorPropName = '_errMsg_'; this.autocomplete = 'off'; this.cfFormSetting = {}; this.formClass = ''; this.isDebug = false; this.cfFormReady = new EventEmitter(); this.data$ = new BehaviorSubject(this.data); } /** * @return {?} */ ngOnInit() { this.initFormGroupSetting(); } /** * @param {?} originObj * @return {?} */ writeValue(originObj) { if (!originObj) { return; } this.data = originObj; this.setFormGroupValue(); this.setReady(); } /** * @private * @return {?} */ setReady() { this.isReady = true; this.cfFormReady.emit(); } /** * @param {?} fn * @return {?} */ registerOnChange(fn) { this.onChange = fn; } /** * @param {?} fn * @return {?} */ registerOnTouched(fn) { this.onTouched = fn; } /** * @param {?} isDisabled * @return {?} */ setDisabledState(isDisabled) { } /** * @param {?} key * @param {?} value * @return {?} */ notifyValueChange(key, value) { if (!this.onChange) { return; } /** @type {?} */ let v = value; /** @type {?} */ const setting = this.cfFormSetting[key]; if (setting.converter) { v = setting.converter.from(value); } this.data[key] = v; this.data$.next(this.data); this.onChange(this.data); } /** * @param {?} key * @param {?} isValid * @param {?=} info * @return {?} */ notifyValidatedInfo(key, isValid, info) { if (!this.onChange) { return; } if (isValid) { /** @type {?} */ const obj = this.data[this.errorPropName] || {}; delete obj[key]; this.data[this.errorPropName] = obj; } else { /** @type {?} */ const obj = this.data[this.errorPropName] || {}; /** @type {?} */ const oErrorObj = obj[key] || {}; obj[key] = info; this.data[this.errorPropName] = obj; } this.onChange(this.data); } /** * @return {?} */ onReady() { return this.cfFormReady; } /** * @private * @return {?} */ initFormGroupSetting() { for (const propName of Object.keys(this.cfFormSetting)) { /** @type {?} */ const setting = this.cfFormSetting[propName]; /** @type {?} */ const g = {}; for (const item of setting.items) { /** @type {?} */ const itemValidatorInfo = this.getValidators(item.validators); g[item.name] = ['', itemValidatorInfo.validatorFns, itemValidatorInfo.asyncValidatorFns]; } /** @type {?} */ const fbG = this.fb.group(g); /** @type {?} */ const groupValidatorInfo = this.getValidators(setting.validators); fbG.setValidators(groupValidatorInfo.validatorFns); fbG.setAsyncValidators(groupValidatorInfo.asyncValidatorFns); this.cfFormGroup.setControl(propName, fbG); } } /** * @private * @return {?} */ setFormGroupValue() { for (const propName of Object.keys(this.cfFormSetting)) { /** @type {?} */ const setting = this.cfFormSetting[propName]; for (const item of setting.items) { /** @type {?} */ let value = this.data[item.name] || item.value || ''; if (setting.converter) { value = setting.converter.to(value); } /** @type {?} */ const c = this.cfFormGroup.get([propName, item.name]); c.setValue(value); } } } /** * @private * @param {?} validators * @return {?} */ getValidators(validators) { /** @type {?} */ const validatorFns = []; /** @type {?} */ const asyncValidatorFns = []; for (const key of Object.keys(validators)) { /** @type {?} */ const v = validators[key]; if (v.isPromiseOrObservable) { asyncValidatorFns.push((/** @type {?} */ (v.validator))); } else { validatorFns.push((/** @type {?} */ (v.validator))); } } return { validatorFns, asyncValidatorFns }; } } FormComponent.decorators = [ { type: Component, args: [{ selector: 'cf-form', template: " <form *ngIf=\"isReady\"\n [class]=\"formClass\" \n [formGroup]=\"cfFormGroup\"\n [autocomplete]=\"autocomplete\"\n novalidate>\n\n <ng-content></ng-content>\n\n <!-- <div class=\"form-row\">\n <div class=\"form-group col-sm-10\">\n <a href=\"#\" class=\"btn btn-primary\" (click)=\"submit($event)\" [ngClass]=\"{'disabled': !(cfFormGroup.dirty && cfFormGroup.valid)}\">Submit</a>\n <a href=\"#\" class=\"btn btn-danger\" (click)=\"delete($event)\" [ngClass]=\"{'d-none': id===0}\">Delete</a>\n <a href=\"#\" class=\"btn btn-secondary\" (click)=\"goBack($event)\">Back</a>\n </div>\n </div> -->\n\n <div *ngIf=\"isDebug\">\n \n <hr /> \n cfFormGroup.value => {{cfFormGroup.value | json}} <br />\n cfFormGroup.valid => {{cfFormGroup.valid | json}} <br />\n cfFormGroup.touched => {{cfFormGroup.touched | json}} <br />\n cfFormGroup.dirty => {{cfFormGroup.dirty | json}}\n <hr />\n\n </div>\n\n </form>\n\n\n\n\n\n <!-- <form>\n <div class=\"form-group row\">\n <label for=\"inputEmail3\" class=\"col-sm-2 col-form-label\">Email</label>\n <div class=\"col-sm-10\">\n <input type=\"email\" class=\"form-control is-invalid\" id=\"inputEmail3\" placeholder=\"Email\">\n <small id=\"emailHelp\" class=\"form-text text-muted\">We'll never share your email with anyone else.</small>\n <small id=\"emailHelp\" class=\"form-text text-danger\">We'll never share your email with anyone else.</small>\n </div>\n </div>\n <div class=\"form-group row\">\n <label for=\"inputPassword3\" class=\"col-sm-2 col-form-label\">Password</label>\n <div class=\"col-sm-10\">\n <input type=\"password\" class=\"form-control\" id=\"inputPassword3\" placeholder=\"Password\">\n </div>\n </div>\n \n <fieldset class=\"form-group\">\n <div class=\"row\">\n <legend class=\"col-form-legend col-sm-2\">Radios</legend>\n <div class=\"col-sm-10\">\n <div class=\"form-check\">\n <label class=\"form-check-label\">\n <input class=\"form-check-input\" type=\"radio\" name=\"gridRadios\" id=\"gridRadios1\" value=\"option1\" checked> Option one is this and that&mdash;be sure to include why it's great\n </label>\n </div>\n <div class=\"form-check\">\n <label class=\"form-check-label\">\n <input class=\"form-check-input\" type=\"radio\" name=\"gridRadios\" id=\"gridRadios2\" value=\"option2\"> Option two can be something else and selecting it will deselect option one\n </label>\n </div>\n <div class=\"form-check disabled\">\n <label class=\"form-check-label\">\n <input class=\"form-check-input\" type=\"radio\" name=\"gridRadios\" id=\"gridRadios3\" value=\"option3\" disabled> Option three is disabled\n </label>\n </div>\n <small id=\"emailHelp\" class=\"form-text text-muted\">We'll never share your email with anyone else.</small>\n <small id=\"emailHelp\" class=\"form-text text-danger\">We'll never share your email with anyone else.</small>\n </div>\n\n </div>\n </fieldset>\n\n <div class=\"form-group row\">\n <div class=\"col-sm-2\">Checkbox</div>\n <div class=\"col-sm-10\">\n <div class=\"form-check\">\n <label class=\"form-check-label\">\n <input class=\"form-check-input\" type=\"checkbox\"> Check me out\n </label>\n </div>\n <div class=\"form-check\">\n <label class=\"form-check-label\">\n <input class=\"form-check-input\" type=\"checkbox\"> Check me out\n </label>\n </div>\n </div>\n </div>\n\n <div class=\"form-group row\">\n <div class=\"col-sm-2\">Example select</div>\n <div class=\"col-sm-10\">\n <select class=\"form-control is-invalid\" id=\"exampleFormControlSelect1\">\n <option>1</option>\n <option>2</option>\n <option>3</option>\n <option>4</option>\n <option>5</option>\n </select>\n <small id=\"emailHelp\" class=\"form-text text-muted\">We'll never share your email with anyone else.</small>\n <small id=\"emailHelp\" class=\"form-text text-danger\">We'll never share your email with anyone else.</small>\n </div>\n </div>\n <div class=\"form-group row\">\n <div class=\"col-sm-2\">Example multiple select</div>\n <div class=\"col-sm-10\">\n <select multiple class=\"form-control\" id=\"exampleFormControlSelect2\">\n <option>1</option>\n <option>2</option>\n <option>3</option>\n <option>4</option>\n <option>5</option>\n </select>\n <small id=\"emailHelp\" class=\"form-text text-muted\">We'll never share your email with anyone else.</small>\n <small id=\"emailHelp\" class=\"form-text text-danger\">We'll never share your email with anyone else.</small>\n </div>\n </div>\n <div class=\"form-group row\">\n <div class=\"col-sm-2\">Example textarea</div>\n <div class=\"col-sm-10\">\n <textarea class=\"form-control\" id=\"exampleFormControlTextarea1\" rows=\"5\"></textarea>\n <small id=\"emailHelp\" class=\"form-text text-muted\">We'll never share your email with anyone else.</small>\n <small id=\"emailHelp\" class=\"form-text text-danger\">We'll never share your email with anyone else.</small>\n </div>\n </div>\n\n <div class=\"form-group row\">\n <div class=\"col-sm-10\">\n <a href=\"#\" class=\"btn btn-primary\">Submit</a>\n <a href=\"#\" class=\"btn btn-secondary\">Reset</a>\n <a href=\"#\" class=\"btn btn-secondary\" (click)=\"goBack($event)\">Back</a>\n </div>\n </div>\n\n\n </form> -->\n", providers: [USER_PROFILE_VALUE_ACCESSOR], styles: [""] }] } ]; /** @nocollapse */ FormComponent.ctorParameters = () => [ { type: FormBuilder } ]; FormComponent.propDecorators = { autocomplete: [{ type: Input }], cfFormSetting: [{ type: Input }], cfFormGroup: [{ type: Input }], formClass: [{ type: Input }], isDebug: [{ type: Input }], cfFormReady: [{ type: Output }] }; if (false) { /** @type {?} */ FormComponent.prototype.isReady; /** * @type {?} * @private */ FormComponent.prototype.errorPropName; /** @type {?} */ FormComponent.prototype.autocomplete; /** @type {?} */ FormComponent.prototype.cfFormSetting; /** @type {?} */ FormComponent.prototype.cfFormGroup; /** @type {?} */ FormComponent.prototype.formClass; /** @type {?} */ FormComponent.prototype.isDebug; /** @type {?} */ FormComponent.prototype.cfFormReady; /** * @type {?} * @private */ FormComponent.prototype.onChange; /** * @type {?} * @private */ FormComponent.prototype.onTouched; /** * @type {?} * @private */ FormComponent.prototype.data; /** @type {?} */ FormComponent.prototype.data$; /** * @type {?} * @private */ FormComponent.prototype.fb; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.component.js","sourceRoot":"ng://ngx-config-form/","sources":["lib/components/form/form.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, forwardRef, Input, OnInit, Output } from '@angular/core';\nimport { AsyncValidatorFn, ControlValueAccessor, FormBuilder, FormGroup, NG_VALUE_ACCESSOR, ValidatorFn } from '@angular/forms';\nimport { BehaviorSubject } from 'rxjs';\nimport { IErrorInfo } from '../../common/IErrorInfo';\nimport { IForm } from '../../common/IForm';\nimport { IFormSetting } from '../../common/IFormSetting';\nimport { IInputValidatorSetting } from '../../common/IInputValidatorSetting';\n\nconst USER_PROFILE_VALUE_ACCESSOR: any = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => FormComponent),\n  multi: true\n};\n\n@Component({\n  selector: 'cf-form',\n  templateUrl: './form.component.html',\n  styleUrls: ['./form.component.scss'],\n  providers: [USER_PROFILE_VALUE_ACCESSOR]\n})\nexport class FormComponent implements ControlValueAccessor, OnInit, IForm {\n\n  isReady = false;\n  private errorPropName = '_errMsg_';\n\n  @Input() autocomplete: 'on' | 'off' = 'off';\n  @Input() cfFormSetting: IFormSetting = {};\n  @Input() cfFormGroup: FormGroup;\n  @Input() formClass = '';\n  @Input() isDebug = false;\n\n  @Output() cfFormReady = new EventEmitter<void>();\n\n  private onChange: (value) => {};\n  private onTouched: (value) => {};\n\n  private data: object;\n  data$ = new BehaviorSubject(this.data);\n\n  constructor(private fb: FormBuilder) {\n  }\n\n  ngOnInit() {\n    this.initFormGroupSetting();\n  }\n\n  writeValue(originObj: object): void {\n    if (!originObj) {\n      return;\n    }\n    this.data = originObj;\n    this.setFormGroupValue();\n    this.setReady();\n  }\n  private setReady(): any {\n    this.isReady = true;\n    this.cfFormReady.emit();\n  }\n\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n  registerOnTouched(fn: any): void {\n    this.onTouched = fn;\n  }\n  setDisabledState?(isDisabled: boolean): void {\n  }\n\n  notifyValueChange(key: string, value: any) {\n    if (!this.onChange) {\n      return;\n    }\n\n    let v = value;\n    const setting = this.cfFormSetting[key];\n    if (setting.converter) {\n      v = setting.converter.from(value);\n    }\n    this.data[key] = v;\n\n    this.data$.next(this.data);\n    this.onChange(this.data);\n  }\n\n  notifyValidatedInfo(key: string, isValid: boolean, info?: IErrorInfo) {\n    if (!this.onChange) {\n      return;\n    }\n\n    if (isValid) {\n      const obj = this.data[this.errorPropName] || {};\n      delete obj[key];\n      this.data[this.errorPropName] = obj;\n    } else {\n      const obj = this.data[this.errorPropName] || {};\n      const oErrorObj = obj[key] || {};\n      obj[key] = info;\n      this.data[this.errorPropName] = obj;\n    }\n\n    this.onChange(this.data);\n  }\n\n  onReady(): EventEmitter<void> {\n    return this.cfFormReady;\n  }\n\n  private initFormGroupSetting() {\n    for (const propName of Object.keys(this.cfFormSetting)) {\n      const setting = this.cfFormSetting[propName];\n      const g = {};\n      for (const item of setting.items) {\n        const itemValidatorInfo = this.getValidators(item.validators);\n        g[item.name] = ['', itemValidatorInfo.validatorFns, itemValidatorInfo.asyncValidatorFns];\n      }\n      const fbG = this.fb.group(g);\n      const groupValidatorInfo = this.getValidators(setting.validators);\n      fbG.setValidators(groupValidatorInfo.validatorFns);\n      fbG.setAsyncValidators(groupValidatorInfo.asyncValidatorFns);\n      this.cfFormGroup.setControl(propName, fbG);\n    }\n  }\n\n  private setFormGroupValue() {\n    for (const propName of Object.keys(this.cfFormSetting)) {\n      const setting = this.cfFormSetting[propName];\n      for (const item of setting.items) {\n        let value = this.data[item.name] || item.value || '';\n        if (setting.converter) {\n          value = setting.converter.to(value);\n        }\n        const c = this.cfFormGroup.get([propName, item.name]);\n        c.setValue(value);\n      }\n    }\n  }\n\n  private getValidators(validators: IInputValidatorSetting) {\n    const validatorFns: ValidatorFn[] = [];\n    const asyncValidatorFns: AsyncValidatorFn[] = [];\n    for (const key of Object.keys(validators)) {\n      const v = validators[key];\n      if (v.isPromiseOrObservable) {\n        asyncValidatorFns.push(v.validator as AsyncValidatorFn);\n      } else {\n        validatorFns.push(v.validator as ValidatorFn);\n      }\n    }\n    return { validatorFns, asyncValidatorFns };\n  }\n\n}\n"]}