UNPKG

ngx-config-form

Version:
363 lines 28.7 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; import { Component, EventEmitter, forwardRef, Input, Output } from '@angular/core'; import { FormBuilder, FormGroup, NG_VALUE_ACCESSOR } from '@angular/forms'; import { BehaviorSubject } from 'rxjs'; /** @type {?} */ var USER_PROFILE_VALUE_ACCESSOR = { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef((/** * @return {?} */ function () { return FormComponent; })), multi: true }; var FormComponent = /** @class */ (function () { function FormComponent(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 {?} */ FormComponent.prototype.ngOnInit = /** * @return {?} */ function () { this.initFormGroupSetting(); }; /** * @param {?} originObj * @return {?} */ FormComponent.prototype.writeValue = /** * @param {?} originObj * @return {?} */ function (originObj) { if (!originObj) { return; } this.data = originObj; this.setFormGroupValue(); this.setReady(); }; /** * @private * @return {?} */ FormComponent.prototype.setReady = /** * @private * @return {?} */ function () { this.isReady = true; this.cfFormReady.emit(); }; /** * @param {?} fn * @return {?} */ FormComponent.prototype.registerOnChange = /** * @param {?} fn * @return {?} */ function (fn) { this.onChange = fn; }; /** * @param {?} fn * @return {?} */ FormComponent.prototype.registerOnTouched = /** * @param {?} fn * @return {?} */ function (fn) { this.onTouched = fn; }; /** * @param {?} isDisabled * @return {?} */ FormComponent.prototype.setDisabledState = /** * @param {?} isDisabled * @return {?} */ function (isDisabled) { }; /** * @param {?} key * @param {?} value * @return {?} */ FormComponent.prototype.notifyValueChange = /** * @param {?} key * @param {?} value * @return {?} */ function (key, value) { if (!this.onChange) { return; } /** @type {?} */ var v = value; /** @type {?} */ var 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 {?} */ FormComponent.prototype.notifyValidatedInfo = /** * @param {?} key * @param {?} isValid * @param {?=} info * @return {?} */ function (key, isValid, info) { if (!this.onChange) { return; } if (isValid) { /** @type {?} */ var obj = this.data[this.errorPropName] || {}; delete obj[key]; this.data[this.errorPropName] = obj; } else { /** @type {?} */ var obj = this.data[this.errorPropName] || {}; /** @type {?} */ var oErrorObj = obj[key] || {}; obj[key] = info; this.data[this.errorPropName] = obj; } this.onChange(this.data); }; /** * @return {?} */ FormComponent.prototype.onReady = /** * @return {?} */ function () { return this.cfFormReady; }; /** * @private * @return {?} */ FormComponent.prototype.initFormGroupSetting = /** * @private * @return {?} */ function () { var e_1, _a, e_2, _b; try { for (var _c = tslib_1.__values(Object.keys(this.cfFormSetting)), _d = _c.next(); !_d.done; _d = _c.next()) { var propName = _d.value; /** @type {?} */ var setting = this.cfFormSetting[propName]; /** @type {?} */ var g = {}; try { for (var _e = tslib_1.__values(setting.items), _f = _e.next(); !_f.done; _f = _e.next()) { var item = _f.value; /** @type {?} */ var itemValidatorInfo = this.getValidators(item.validators); g[item.name] = ['', itemValidatorInfo.validatorFns, itemValidatorInfo.asyncValidatorFns]; } } catch (e_2_1) { e_2 = { error: e_2_1 }; } finally { try { if (_f && !_f.done && (_b = _e.return)) _b.call(_e); } finally { if (e_2) throw e_2.error; } } /** @type {?} */ var fbG = this.fb.group(g); /** @type {?} */ var groupValidatorInfo = this.getValidators(setting.validators); fbG.setValidators(groupValidatorInfo.validatorFns); fbG.setAsyncValidators(groupValidatorInfo.asyncValidatorFns); this.cfFormGroup.setControl(propName, fbG); } } catch (e_1_1) { e_1 = { error: e_1_1 }; } finally { try { if (_d && !_d.done && (_a = _c.return)) _a.call(_c); } finally { if (e_1) throw e_1.error; } } }; /** * @private * @return {?} */ FormComponent.prototype.setFormGroupValue = /** * @private * @return {?} */ function () { var e_3, _a, e_4, _b; try { for (var _c = tslib_1.__values(Object.keys(this.cfFormSetting)), _d = _c.next(); !_d.done; _d = _c.next()) { var propName = _d.value; /** @type {?} */ var setting = this.cfFormSetting[propName]; try { for (var _e = tslib_1.__values(setting.items), _f = _e.next(); !_f.done; _f = _e.next()) { var item = _f.value; /** @type {?} */ var value = this.data[item.name] || item.value || ''; if (setting.converter) { value = setting.converter.to(value); } /** @type {?} */ var c = this.cfFormGroup.get([propName, item.name]); c.setValue(value); } } catch (e_4_1) { e_4 = { error: e_4_1 }; } finally { try { if (_f && !_f.done && (_b = _e.return)) _b.call(_e); } finally { if (e_4) throw e_4.error; } } } } catch (e_3_1) { e_3 = { error: e_3_1 }; } finally { try { if (_d && !_d.done && (_a = _c.return)) _a.call(_c); } finally { if (e_3) throw e_3.error; } } }; /** * @private * @param {?} validators * @return {?} */ FormComponent.prototype.getValidators = /** * @private * @param {?} validators * @return {?} */ function (validators) { var e_5, _a; /** @type {?} */ var validatorFns = []; /** @type {?} */ var asyncValidatorFns = []; try { for (var _b = tslib_1.__values(Object.keys(validators)), _c = _b.next(); !_c.done; _c = _b.next()) { var key = _c.value; /** @type {?} */ var v = validators[key]; if (v.isPromiseOrObservable) { asyncValidatorFns.push((/** @type {?} */ (v.validator))); } else { validatorFns.push((/** @type {?} */ (v.validator))); } } } catch (e_5_1) { e_5 = { error: e_5_1 }; } finally { try { if (_c && !_c.done && (_a = _b.return)) _a.call(_b); } finally { if (e_5) throw e_5.error; } } return { validatorFns: validatorFns, asyncValidatorFns: 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 = function () { return [ { type: FormBuilder } ]; }; FormComponent.propDecorators = { autocomplete: [{ type: Input }], cfFormSetting: [{ type: Input }], cfFormGroup: [{ type: Input }], formClass: [{ type: Input }], isDebug: [{ type: Input }], cfFormReady: [{ type: Output }] }; return FormComponent; }()); export { FormComponent }; 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":";;;;;AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,UAAU,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,eAAe,CAAC;AAC3F,OAAO,EAA0C,WAAW,EAAE,SAAS,EAAE,iBAAiB,EAAe,MAAM,gBAAgB,CAAC;AAChI,OAAO,EAAE,eAAe,EAAE,MAAM,MAAM,CAAC;;IAMjC,2BAA2B,GAAQ;IACvC,OAAO,EAAE,iBAAiB;IAC1B,WAAW,EAAE,UAAU;;;IAAC,cAAM,OAAA,aAAa,EAAb,CAAa,EAAC;IAC5C,KAAK,EAAE,IAAI;CACZ;AAED;IAyBE,uBAAoB,EAAe;QAAf,OAAE,GAAF,EAAE,CAAa;QAjBnC,YAAO,GAAG,KAAK,CAAC;QACR,kBAAa,GAAG,UAAU,CAAC;QAE1B,iBAAY,GAAiB,KAAK,CAAC;QACnC,kBAAa,GAAiB,EAAE,CAAC;QAEjC,cAAS,GAAG,EAAE,CAAC;QACf,YAAO,GAAG,KAAK,CAAC;QAEf,gBAAW,GAAG,IAAI,YAAY,EAAQ,CAAC;QAMjD,UAAK,GAAG,IAAI,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAGvC,CAAC;;;;IAED,gCAAQ;;;IAAR;QACE,IAAI,CAAC,oBAAoB,EAAE,CAAC;IAC9B,CAAC;;;;;IAED,kCAAU;;;;IAAV,UAAW,SAAiB;QAC1B,IAAI,CAAC,SAAS,EAAE;YACd,OAAO;SACR;QACD,IAAI,CAAC,IAAI,GAAG,SAAS,CAAC;QACtB,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACzB,IAAI,CAAC,QAAQ,EAAE,CAAC;IAClB,CAAC;;;;;IACO,gCAAQ;;;;IAAhB;QACE,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;QACpB,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE,CAAC;IAC1B,CAAC;;;;;IAED,wCAAgB;;;;IAAhB,UAAiB,EAAO;QACtB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;;;;;IACD,yCAAiB;;;;IAAjB,UAAkB,EAAO;QACvB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACtB,CAAC;;;;;IACD,wCAAgB;;;;IAAhB,UAAkB,UAAmB;IACrC,CAAC;;;;;;IAED,yCAAiB;;;;;IAAjB,UAAkB,GAAW,EAAE,KAAU;QACvC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,OAAO;SACR;;YAEG,CAAC,GAAG,KAAK;;YACP,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC;QACvC,IAAI,OAAO,CAAC,SAAS,EAAE;YACrB,CAAC,GAAG,OAAO,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SACnC;QACD,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;QAEnB,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QAC3B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC3B,CAAC;;;;;;;IAED,2CAAmB;;;;;;IAAnB,UAAoB,GAAW,EAAE,OAAgB,EAAE,IAAiB;QAClE,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;YAClB,OAAO;SACR;QAED,IAAI,OAAO,EAAE;;gBACL,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE;YAC/C,OAAO,GAAG,CAAC,GAAG,CAAC,CAAC;YAChB,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,GAAG,GAAG,CAAC;SACrC;aAAM;;gBACC,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE;;gBACzC,SAAS,GAAG,GAAG,CAAC,GAAG,CAAC,IAAI,EAAE;YAChC,GAAG,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC;YAChB,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,GAAG,GAAG,CAAC;SACrC;QAED,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC3B,CAAC;;;;IAED,+BAAO;;;IAAP;QACE,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;;;;;IAEO,4CAAoB;;;;IAA5B;;;YACE,KAAuB,IAAA,KAAA,iBAAA,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAA,gBAAA,4BAAE;gBAAnD,IAAM,QAAQ,WAAA;;oBACX,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC;;oBACtC,CAAC,GAAG,EAAE;;oBACZ,KAAmB,IAAA,KAAA,iBAAA,OAAO,CAAC,KAAK,CAAA,gBAAA,4BAAE;wBAA7B,IAAM,IAAI,WAAA;;4BACP,iBAAiB,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,UAAU,CAAC;wBAC7D,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,iBAAiB,CAAC,YAAY,EAAE,iBAAiB,CAAC,iBAAiB,CAAC,CAAC;qBAC1F;;;;;;;;;;oBACK,GAAG,GAAG,IAAI,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC;;oBACtB,kBAAkB,GAAG,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,UAAU,CAAC;gBACjE,GAAG,CAAC,aAAa,CAAC,kBAAkB,CAAC,YAAY,CAAC,CAAC;gBACnD,GAAG,CAAC,kBAAkB,CAAC,kBAAkB,CAAC,iBAAiB,CAAC,CAAC;gBAC7D,IAAI,CAAC,WAAW,CAAC,UAAU,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;aAC5C;;;;;;;;;IACH,CAAC;;;;;IAEO,yCAAiB;;;;IAAzB;;;YACE,KAAuB,IAAA,KAAA,iBAAA,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAA,gBAAA,4BAAE;gBAAnD,IAAM,QAAQ,WAAA;;oBACX,OAAO,GAAG,IAAI,CAAC,aAAa,CAAC,QAAQ,CAAC;;oBAC5C,KAAmB,IAAA,KAAA,iBAAA,OAAO,CAAC,KAAK,CAAA,gBAAA,4BAAE;wBAA7B,IAAM,IAAI,WAAA;;4BACT,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,KAAK,IAAI,EAAE;wBACpD,IAAI,OAAO,CAAC,SAAS,EAAE;4BACrB,KAAK,GAAG,OAAO,CAAC,SAAS,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC;yBACrC;;4BACK,CAAC,GAAG,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;wBACrD,CAAC,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;qBACnB;;;;;;;;;aACF;;;;;;;;;IACH,CAAC;;;;;;IAEO,qCAAa;;;;;IAArB,UAAsB,UAAkC;;;YAChD,YAAY,GAAkB,EAAE;;YAChC,iBAAiB,GAAuB,EAAE;;YAChD,KAAkB,IAAA,KAAA,iBAAA,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAA,gBAAA,4BAAE;gBAAtC,IAAM,GAAG,WAAA;;oBACN,CAAC,GAAG,UAAU,CAAC,GAAG,CAAC;gBACzB,IAAI,CAAC,CAAC,qBAAqB,EAAE;oBAC3B,iBAAiB,CAAC,IAAI,CAAC,mBAAA,CAAC,CAAC,SAAS,EAAoB,CAAC,CAAC;iBACzD;qBAAM;oBACL,YAAY,CAAC,IAAI,CAAC,mBAAA,CAAC,CAAC,SAAS,EAAe,CAAC,CAAC;iBAC/C;aACF;;;;;;;;;QACD,OAAO,EAAE,YAAY,cAAA,EAAE,iBAAiB,mBAAA,EAAE,CAAC;IAC7C,CAAC;;gBAvIF,SAAS,SAAC;oBACT,QAAQ,EAAE,SAAS;oBACnB,0wLAAoC;oBAEpC,SAAS,EAAE,CAAC,2BAA2B,CAAC;;iBACzC;;;;gBAlBgD,WAAW;;;+BAwBzD,KAAK;gCACL,KAAK;8BACL,KAAK;4BACL,KAAK;0BACL,KAAK;8BAEL,MAAM;;IAwHT,oBAAC;CAAA,AAzID,IAyIC;SAnIY,aAAa;;;IAExB,gCAAgB;;;;;IAChB,sCAAmC;;IAEnC,qCAA4C;;IAC5C,sCAA0C;;IAC1C,oCAAgC;;IAChC,kCAAwB;;IACxB,gCAAyB;;IAEzB,oCAAiD;;;;;IAEjD,iCAAgC;;;;;IAChC,kCAAiC;;;;;IAEjC,6BAAqB;;IACrB,8BAAuC;;;;;IAE3B,2BAAuB","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"]}