@ng-dynamic-forms/core
Version:
A rapid form development library for Angular
100 lines • 13.9 kB
JavaScript
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":"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","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"]}