UNPKG

@ng-dynamic-forms/core

Version:

A rapid form development library for Angular

100 lines 13.9 kB
import { __decorate } from "tslib"; import { DynamicInputControlModel } from "../dynamic-input-control.model"; import { serializable } from "../../decorator/serializable.decorator"; import { isBoolean, isNumber } from "../../utils/core.utils"; import { isObservable, of } from "rxjs"; import { tap } from "rxjs/operators"; import { initialConfig } from "ngx-mask"; export const DYNAMIC_FORM_CONTROL_TYPE_INPUT = "INPUT"; export const DYNAMIC_FORM_CONTROL_INPUT_TYPE_COLOR = "color"; export const DYNAMIC_FORM_CONTROL_INPUT_TYPE_DATE = "date"; // export const DYNAMIC_FORM_CONTROL_INPUT_TYPE_DATETIME = "datetime"; export const DYNAMIC_FORM_CONTROL_INPUT_TYPE_DATETIME_LOCAL = "datetime-local"; export const DYNAMIC_FORM_CONTROL_INPUT_TYPE_EMAIL = "email"; export const DYNAMIC_FORM_CONTROL_INPUT_TYPE_FILE = "file"; export const DYNAMIC_FORM_CONTROL_INPUT_TYPE_MONTH = "month"; export const DYNAMIC_FORM_CONTROL_INPUT_TYPE_NUMBER = "number"; export const DYNAMIC_FORM_CONTROL_INPUT_TYPE_PASSWORD = "password"; export const DYNAMIC_FORM_CONTROL_INPUT_TYPE_RANGE = "range"; export const DYNAMIC_FORM_CONTROL_INPUT_TYPE_SEARCH = "search"; export const DYNAMIC_FORM_CONTROL_INPUT_TYPE_TEL = "tel"; export const DYNAMIC_FORM_CONTROL_INPUT_TYPE_TEXT = "text"; export const DYNAMIC_FORM_CONTROL_INPUT_TYPE_TIME = "time"; export const DYNAMIC_FORM_CONTROL_INPUT_TYPE_URL = "url"; export const DYNAMIC_FORM_CONTROL_INPUT_TYPE_WEEK = "week"; export class DynamicInputModel extends DynamicInputControlModel { constructor(config, layout) { super(config, layout); this.files = null; this.list$ = null; this._list = null; this._listId = null; this.type = DYNAMIC_FORM_CONTROL_TYPE_INPUT; this.accept = config.accept ?? null; this.inputType = config.inputType ?? DYNAMIC_FORM_CONTROL_INPUT_TYPE_TEXT; this.mask = config.mask ?? ""; this.maskConfig = config.maskConfig ? { ...initialConfig, ...config.maskConfig } : initialConfig; this.max = config.max !== undefined ? config.max : null; this.min = config.min !== undefined ? config.min : null; this.multiple = isBoolean(config.multiple) ? config.multiple : null; this.pattern = config.pattern ?? null; this.step = isNumber(config.step) ? config.step : null; if (config.list !== undefined) { this.list = config.list; this._listId = `${this.id}List`; } } get listId() { return this._listId; } get hasList() { return isObservable(this.list$); } set list(list) { if (Array.isArray(list)) { this._list = list; this.list$ = of(this._list); } else if (isObservable(list)) { this.list$ = list.pipe(tap(_list => this._list = _list)); } else { this._list = null; this.list$ = null; } } } __decorate([ serializable() ], DynamicInputModel.prototype, "accept", void 0); __decorate([ serializable() ], DynamicInputModel.prototype, "inputType", void 0); __decorate([ serializable() ], DynamicInputModel.prototype, "mask", void 0); __decorate([ serializable() ], DynamicInputModel.prototype, "maskConfig", void 0); __decorate([ serializable() ], DynamicInputModel.prototype, "max", void 0); __decorate([ serializable() ], DynamicInputModel.prototype, "min", void 0); __decorate([ serializable() ], DynamicInputModel.prototype, "multiple", void 0); __decorate([ serializable() ], DynamicInputModel.prototype, "pattern", void 0); __decorate([ serializable() ], DynamicInputModel.prototype, "step", void 0); __decorate([ serializable("list") ], DynamicInputModel.prototype, "_list", void 0); __decorate([ serializable() ], DynamicInputModel.prototype, "type", void 0); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-input.model.js","sourceRoot":"","sources":["../../../../../../../projects/ng-dynamic-forms/core/src/lib/model/input/dynamic-input.model.ts"],"names":[],"mappings":";AAAA,OAAO,EAAE,wBAAwB,EAAkC,MAAM,gCAAgC,CAAC;AAE1G,OAAO,EAAE,YAAY,EAAE,MAAM,wCAAwC,CAAC;AACtE,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,wBAAwB,CAAC;AAC7D,OAAO,EAAc,YAAY,EAAE,EAAE,EAAE,MAAM,MAAM,CAAC;AACpD,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,EAAW,aAAa,EAAE,MAAM,UAAU,CAAC;AAElD,MAAM,CAAC,MAAM,+BAA+B,GAAG,OAAO,CAAC;AAEvD,MAAM,CAAC,MAAM,qCAAqC,GAAG,OAAO,CAAC;AAC7D,MAAM,CAAC,MAAM,oCAAoC,GAAG,MAAM,CAAC;AAC3D,sEAAsE;AACtE,MAAM,CAAC,MAAM,8CAA8C,GAAG,gBAAgB,CAAC;AAC/E,MAAM,CAAC,MAAM,qCAAqC,GAAG,OAAO,CAAC;AAC7D,MAAM,CAAC,MAAM,oCAAoC,GAAG,MAAM,CAAC;AAC3D,MAAM,CAAC,MAAM,qCAAqC,GAAG,OAAO,CAAC;AAC7D,MAAM,CAAC,MAAM,sCAAsC,GAAG,QAAQ,CAAC;AAC/D,MAAM,CAAC,MAAM,wCAAwC,GAAG,UAAU,CAAC;AACnE,MAAM,CAAC,MAAM,qCAAqC,GAAG,OAAO,CAAC;AAC7D,MAAM,CAAC,MAAM,sCAAsC,GAAG,QAAQ,CAAC;AAC/D,MAAM,CAAC,MAAM,mCAAmC,GAAG,KAAK,CAAC;AACzD,MAAM,CAAC,MAAM,oCAAoC,GAAG,MAAM,CAAC;AAC3D,MAAM,CAAC,MAAM,oCAAoC,GAAG,MAAM,CAAC;AAC3D,MAAM,CAAC,MAAM,mCAAmC,GAAG,KAAK,CAAC;AACzD,MAAM,CAAC,MAAM,oCAAoC,GAAG,MAAM,CAAC;AAe3D,MAAM,OAAO,iBAAkB,SAAQ,wBAA2D;IAkB9F,YAAY,MAA+B,EAAE,MAAiC;QAC1E,KAAK,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;QAhB1B,UAAK,GAAoB,IAAI,CAAC;QAC9B,UAAK,GAA6B,IAAI,CAAC;QAST,UAAK,GAAiB,IAAI,CAAC;QACxC,YAAO,GAAkB,IAAI,CAAC;QAEtB,SAAI,GAAW,+BAA+B,CAAC;QAKpE,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,MAAM,IAAI,IAAI,CAAC;QACpC,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC,SAAS,IAAI,oCAAoC,CAAC;QAC1E,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC,IAAI,IAAI,EAAE,CAAC;QAC9B,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,EAAC,GAAG,aAAa,EAAE,GAAG,MAAM,CAAC,UAAU,EAAC,CAAC,CAAC,CAAC,aAAa,CAAC;QAC/F,IAAI,CAAC,GAAG,GAAG,MAAM,CAAC,GAAG,KAAK,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC;QACxD,IAAI,CAAC,GAAG,GAAG,MAAM,CAAC,GAAG,KAAK,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC;QACxD,IAAI,CAAC,QAAQ,GAAG,SAAS,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC;QACpE,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC,OAAO,IAAI,IAAI,CAAC;QACtC,IAAI,CAAC,IAAI,GAAG,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;QAEvD,IAAI,MAAM,CAAC,IAAI,KAAK,SAAS,EAAE;YAC3B,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC;YACxB,IAAI,CAAC,OAAO,GAAG,GAAG,IAAI,CAAC,EAAE,MAAM,CAAC;SACnC;IACL,CAAC;IAED,IAAI,MAAM;QACN,OAAO,IAAI,CAAC,OAAO,CAAC;IACxB,CAAC;IAED,IAAI,OAAO;QACP,OAAO,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACpC,CAAC;IAED,IAAI,IAAI,CAAC,IAAsC;QAC3C,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACrB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;YAClB,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;SAE/B;aAAM,IAAI,YAAY,CAAC,IAAI,CAAC,EAAE;YAC3B,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,IAAI,CAClB,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC,CACnC,CAAC;SAEL;aAAM;YACH,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;YAClB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;SACrB;IACL,CAAC;CACJ;AA3DmB;IAAf,YAAY,EAAE;iDAAuB;AACtB;IAAf,YAAY,EAAE;oDAAmB;AAGlB;IAAf,YAAY,EAAE;+CAAc;AACb;IAAf,YAAY,EAAE;qDAAqB;AACpB;IAAf,YAAY,EAAE;8CAAoC;AACnC;IAAf,YAAY,EAAE;8CAAoC;AACnC;IAAf,YAAY,EAAE;mDAA0B;AACzB;IAAf,YAAY,EAAE;kDAAwB;AACvB;IAAf,YAAY,EAAE;+CAAqB;AAEN;IAA7B,YAAY,CAAC,MAAM,CAAC;gDAAoC;AAGhC;IAAxB,YAAY,EAAE;+CAAyD","sourcesContent":["import { DynamicInputControlModel, DynamicInputControlModelConfig } from \"../dynamic-input-control.model\";\nimport { DynamicFormControlLayout } from \"../misc/dynamic-form-control-layout.model\";\nimport { serializable } from \"../../decorator/serializable.decorator\";\nimport { isBoolean, isNumber } from \"../../utils/core.utils\";\nimport { Observable, isObservable, of } from \"rxjs\";\nimport { tap } from \"rxjs/operators\";\nimport { IConfig, initialConfig } from \"ngx-mask\";\n\nexport const DYNAMIC_FORM_CONTROL_TYPE_INPUT = \"INPUT\";\n\nexport const DYNAMIC_FORM_CONTROL_INPUT_TYPE_COLOR = \"color\";\nexport const DYNAMIC_FORM_CONTROL_INPUT_TYPE_DATE = \"date\";\n// export const DYNAMIC_FORM_CONTROL_INPUT_TYPE_DATETIME = \"datetime\";\nexport const DYNAMIC_FORM_CONTROL_INPUT_TYPE_DATETIME_LOCAL = \"datetime-local\";\nexport const DYNAMIC_FORM_CONTROL_INPUT_TYPE_EMAIL = \"email\";\nexport const DYNAMIC_FORM_CONTROL_INPUT_TYPE_FILE = \"file\";\nexport const DYNAMIC_FORM_CONTROL_INPUT_TYPE_MONTH = \"month\";\nexport const DYNAMIC_FORM_CONTROL_INPUT_TYPE_NUMBER = \"number\";\nexport const DYNAMIC_FORM_CONTROL_INPUT_TYPE_PASSWORD = \"password\";\nexport const DYNAMIC_FORM_CONTROL_INPUT_TYPE_RANGE = \"range\";\nexport const DYNAMIC_FORM_CONTROL_INPUT_TYPE_SEARCH = \"search\";\nexport const DYNAMIC_FORM_CONTROL_INPUT_TYPE_TEL = \"tel\";\nexport const DYNAMIC_FORM_CONTROL_INPUT_TYPE_TEXT = \"text\";\nexport const DYNAMIC_FORM_CONTROL_INPUT_TYPE_TIME = \"time\";\nexport const DYNAMIC_FORM_CONTROL_INPUT_TYPE_URL = \"url\";\nexport const DYNAMIC_FORM_CONTROL_INPUT_TYPE_WEEK = \"week\";\n\nexport interface DynamicInputModelConfig extends DynamicInputControlModelConfig<string | number | Date | string[]> {\n    accept?: string;\n    inputType?: string;\n    list?: any[] | Observable<any[]>;\n    mask?: string;\n    maskConfig?: Partial<IConfig>;\n    max?: number | string | Date;\n    min?: number | string | Date;\n    multiple?: boolean;\n    pattern?: string;\n    step?: number;\n}\n\nexport class DynamicInputModel extends DynamicInputControlModel<string | number | Date | string[]> {\n    @serializable() accept: string | null;\n    @serializable() inputType: string;\n    files: FileList | null = null;\n    list$: Observable<any[]> | null = null;\n    @serializable() mask: string;\n    @serializable() maskConfig: IConfig;\n    @serializable() max: number | string | Date | null;\n    @serializable() min: number | string | Date | null;\n    @serializable() multiple: boolean | null;\n    @serializable() pattern: string | null;\n    @serializable() step: number | null;\n\n    @serializable(\"list\") private _list: any[] | null = null;\n    private readonly _listId: string | null = null;\n\n    @serializable() readonly type: string = DYNAMIC_FORM_CONTROL_TYPE_INPUT;\n\n    constructor(config: DynamicInputModelConfig, layout?: DynamicFormControlLayout) {\n        super(config, layout);\n\n        this.accept = config.accept ?? null;\n        this.inputType = config.inputType ?? DYNAMIC_FORM_CONTROL_INPUT_TYPE_TEXT;\n        this.mask = config.mask ?? \"\";\n        this.maskConfig = config.maskConfig ? {...initialConfig, ...config.maskConfig} : initialConfig;\n        this.max = config.max !== undefined ? config.max : null;\n        this.min = config.min !== undefined ? config.min : null;\n        this.multiple = isBoolean(config.multiple) ? config.multiple : null;\n        this.pattern = config.pattern ?? null;\n        this.step = isNumber(config.step) ? config.step : null;\n\n        if (config.list !== undefined) {\n            this.list = config.list;\n            this._listId = `${this.id}List`;\n        }\n    }\n\n    get listId(): string | null {\n        return this._listId;\n    }\n\n    get hasList(): boolean {\n        return isObservable(this.list$);\n    }\n\n    set list(list: any[] | Observable<any[]> | null) {\n        if (Array.isArray(list)) {\n            this._list = list;\n            this.list$ = of(this._list);\n\n        } else if (isObservable(list)) {\n            this.list$ = list.pipe(\n                tap(_list => this._list = _list)\n            );\n\n        } else {\n            this._list = null;\n            this.list$ = null;\n        }\n    }\n}\n"]}