@stemy/ngx-dynamic-form 13.0.2 → 13.1.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/ngx-dynamic-form/common-types.mjs +1 -1
- package/esm2020/ngx-dynamic-form/components/base/dynamic-base-form-array.component.mjs +4 -1
- package/esm2020/ngx-dynamic-form/components/base/dynamic-base-form-control.component.mjs +37 -0
- package/esm2020/ngx-dynamic-form/components/base/dynamic-base-form.component.mjs +6 -2
- package/esm2020/ngx-dynamic-form/components/base/dynamic-base-select.component.mjs +63 -0
- package/esm2020/ngx-dynamic-form/ngx-dynamic-form.imports.mjs +6 -2
- package/esm2020/ngx-dynamic-form/ngx-dynamic-form.module.mjs +8 -6
- package/esm2020/ngx-dynamic-form/services/dynamic-form.service.mjs +31 -20
- package/esm2020/ngx-dynamic-form/utils/dynamic-form-array.model.mjs +4 -1
- package/esm2020/ngx-dynamic-form/utils/dynamic-select.model.mjs +57 -0
- package/esm2020/ngx-dynamic-form/utils/form-select-subject.mjs +1 -1
- package/esm2020/ngx-dynamic-form/utils/form-subject.mjs +1 -1
- package/esm2020/ngx-dynamic-form/utils/misc.mjs +24 -1
- package/esm2020/public_api.mjs +6 -2
- package/fesm2015/stemy-ngx-dynamic-form.mjs +214 -25
- package/fesm2015/stemy-ngx-dynamic-form.mjs.map +1 -1
- package/fesm2020/stemy-ngx-dynamic-form.mjs +214 -23
- package/fesm2020/stemy-ngx-dynamic-form.mjs.map +1 -1
- package/ngx-dynamic-form/common-types.d.ts +1 -2
- package/ngx-dynamic-form/components/base/dynamic-base-form-array.component.d.ts +1 -0
- package/ngx-dynamic-form/components/base/dynamic-base-form-control.component.d.ts +16 -0
- package/ngx-dynamic-form/components/base/dynamic-base-form.component.d.ts +3 -1
- package/ngx-dynamic-form/components/base/dynamic-base-select.component.d.ts +15 -0
- package/ngx-dynamic-form/ngx-dynamic-form.imports.d.ts +4 -2
- package/ngx-dynamic-form/ngx-dynamic-form.module.d.ts +9 -7
- package/ngx-dynamic-form/services/dynamic-form.service.d.ts +7 -6
- package/ngx-dynamic-form/utils/dynamic-form-array.model.d.ts +4 -0
- package/ngx-dynamic-form/utils/dynamic-select.model.d.ts +37 -0
- package/ngx-dynamic-form/utils/form-select-subject.d.ts +2 -2
- package/ngx-dynamic-form/utils/form-subject.d.ts +6 -6
- package/ngx-dynamic-form/utils/misc.d.ts +5 -1
- package/package.json +2 -2
- package/public_api.d.ts +6 -2
|
@@ -94,4 +94,4 @@ export function createFormFile(id, data) {
|
|
|
94
94
|
data.url = ObjectUtils.isString(data.url) ? data.url : "assets";
|
|
95
95
|
return control;
|
|
96
96
|
}
|
|
97
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"common-types.js","sourceRoot":"","sources":["../../../src/ngx-dynamic-form/common-types.ts"],"names":[],"mappings":"AAYA,OAAO,EAKH,WAAW,EACX,YAAY,EACf,MAAM,kBAAkB,CAAC;AAwF1B,8BAA8B;AAC9B,MAAM,UAAU,iBAAiB,CAAC,EAAU,EAAE,MAAiB;IAC3D,MAAM,OAAO,GAAG,MAAM,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAC/B,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAA,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC;AAC1C,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,UAAoD;IACjF,OAAO,CAAC,MAAW,EAAE,WAAmB,EAAQ,EAAE;QAC9C,YAAY,CAAC,cAAc,CAAC,uBAAuB,EAAE,UAAU,IAAI,iBAAiB,EAAE,MAAM,EAAE,WAAW,CAAC,CAAC;IAC/G,CAAC,CAAC;AACN,CAAC;AAED,MAAM,UAAU,SAAS,CAAC,IAA8B;IACpD,OAAO,CAAC,MAAW,EAAE,WAAmB,EAAQ,EAAE;QAC9C,MAAM,IAAI,GAAG,YAAY,CAAC,cAAc,CAAC,aAAa,EAAE,MAAM,EAAE,WAAW,CAAC,CAAC;QAC7E,MAAM,IAAI,GAAG,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC;QACnC,IAAI,SAAS,GAAG,WAAW,CAAC,OAAO,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,UAAU,CAAC;QAC1E,QAAQ,IAAI,EAAE;YACV,KAAK,QAAQ;gBACT,SAAS,GAAG,QAAQ,CAAC;gBACrB,MAAM;YACV,KAAK,SAAS;gBACV,SAAS,GAAG,UAAU,CAAC;gBACvB,MAAM;SACb;QACD,iBAAiB,CAAC,MAAM,EAAE,WAAW,EAAE,eAAe,CAAC,WAAW,EAAE,IAAI,EAAE,SAAS,CAAC,CAAC,CAAC;IAC1F,CAAC,CAAC;AACN,CAAC;AAED,MAAM,UAAU,UAAU,CAAC,IAAoC;IAC3D,OAAO,CAAC,MAAW,EAAE,WAAmB,EAAQ,EAAE;QAC9C,iBAAiB,CAAC,MAAM,EAAE,WAAW,EAAE,gBAAgB,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC,CAAC;IAChF,CAAC,CAAC;AACN,CAAC;AAED,MAAM,UAAU,UAAU,CAAC,IAAoC;IAC3D,OAAO,CAAC,MAAW,EAAE,WAAmB,EAAQ,EAAE;QAC9C,iBAAiB,CAAC,MAAM,EAAE,WAAW,EAAE,gBAAgB,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC,CAAC;IAChF,CAAC,CAAC;AACN,CAAC;AAED,MAAM,UAAU,SAAS,CAAC,IAAkC;IACxD,OAAO,CAAC,MAAW,EAAE,WAAmB,EAAQ,EAAE;QAC9C,iBAAiB,CAAC,MAAM,EAAE,WAAW,EAAE,eAAe,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC,CAAC;IAC/E,CAAC,CAAC;AACN,CAAC;AAED,MAAM,UAAU,QAAQ,CAAC,IAAmC;IACxD,OAAO,CAAC,MAAW,EAAE,WAAmB,EAAQ,EAAE;QAC9C,iBAAiB,CAAC,MAAM,EAAE,WAAW,EAAE,cAAc,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC,CAAC;IAC9E,CAAC,CAAC;AACN,CAAC;AAED,MAAM,UAAU,iBAAiB,CAAC,MAAW,EAAE,WAAmB,EAAE,OAAqB;IACrF,YAAY,CAAC,cAAc,CAAC,oBAAoB,EAAE,OAAO,EAAE,MAAM,EAAE,WAAW,CAAC,CAAC;AACpF,CAAC;AAED,MAAM,UAAU,cAAc,CAAC,MAAW,EAAE,WAAmB;IAC3D,OAAO,YAAY,CAAC,WAAW,CAAC,oBAAoB,EAAE,MAAM,EAAE,WAAW,CAAC,CAAC;AAC/E,CAAC;AAED,MAAM,UAAU,iBAAiB,CAAC,MAAW,EAAE,WAAmB;IAC9D,OAAO,YAAY,CAAC,WAAW,CAAC,uBAAuB,EAAE,MAAM,EAAE,WAAW,CAAC,CAAC;AAClF,CAAC;AAED,MAAM,UAAU,iBAAiB,CAAC,EAAU,EAAE,IAAY,EAAE,MAAsC;IAC9F,MAAM,GAAG,MAAM,IAAI,EAAC,EAAE,EAAC,CAAC;IACxB,MAAM,CAAC,EAAE,GAAG,EAAE,CAAC;IACf,MAAM,CAAC,KAAK,GAAG,WAAW,CAAC,iBAAiB,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC;IAC/E,MAAM,CAAC,QAAQ,GAAG,MAAM,CAAC,QAAQ,IAAI,KAAK,CAAC;IAC3C,MAAM,CAAC,MAAM,GAAG,MAAM,CAAC,MAAM,IAAI,KAAK,CAAC;IACvC,OAAO,EAAC,EAAE,EAAE,IAAI,EAAE,MAAM,EAAC,CAAC;AAC9B,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,EAAU,EAAE,MAA+B,EAAE,OAAe,MAAM;IAC9F,MAAM,OAAO,GAAG,iBAAiB,CAAC,EAAE,EAAE,OAAO,EAAE,MAAM,CAAC,CAAC;IACvD,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IACxB,MAAM,CAAC,SAAS,GAAG,MAAM,CAAC,SAAS,IAAI,IAAI,CAAC;IAC5C,MAAM,CAAC,WAAW,GAAG,MAAM,CAAC,WAAW,IAAI,CAAC,MAAM,CAAC,SAAS,IAAI,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;IACnF,MAAM,CAAC,IAAI,GAAG,MAAM,CAAC,IAAI,IAAI,CAAC,CAAC;IAC/B,MAAM,CAAC,IAAI,GAAG,MAAM,CAAC,IAAI,IAAI,IAAI,CAAC;IAClC,OAAO,OAAO,CAAC;AACnB,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,EAAU,EAAE,IAAmC;IAC5E,MAAM,OAAO,GAAG,iBAAiB,CAAC,EAAE,EAAE,QAAQ,EAAE,IAAI,CAAC,CAAC;IACtD,IAAI,GAAG,OAAO,CAAC,MAAM,CAAC;IACtB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,IAAI,EAAE,CAAC;IAClC,OAAO,OAAO,CAAC;AACnB,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,EAAU,EAAE,MAAqC;IAC9E,OAAO,iBAAiB,CAAC,EAAE,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAC;AACnD,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,EAAU,EAAE,IAAiC;IACzE,MAAM,OAAO,GAAG,iBAAiB,CAAC,EAAE,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;IACrD,IAAI,GAAG,OAAO,CAAC,MAAM,CAAC;IACtB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,IAAI,EAAE,CAAC;IAC5B,OAAO,OAAO,CAAC;AACnB,CAAC;AAED,MAAM,UAAU,cAAc,CAAC,EAAU,EAAE,IAAkC;IACzE,MAAM,OAAO,GAAG,iBAAiB,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,CAAC,CAAC;IACpD,IAAI,GAAG,OAAO,CAAC,MAAM,CAAC;IACtB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,IAAI,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,CAAC,CAAC;IACpD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,IAAI,KAAK,CAAC;IACvC,IAAI,CAAC,GAAG,GAAG,WAAW,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC;IAChE,OAAO,OAAO,CAAC;AACnB,CAAC","sourcesContent":["import {EventEmitter, Injector, TemplateRef} from \"@angular/core\";\r\nimport {AbstractControl, FormArray} from \"@angular/forms\";\r\nimport {\r\n    DynamicFileUploadModelConfig,\r\n    DynamicFormControl, DynamicFormControlEvent,\r\n    DynamicFormControlModel,\r\n    DynamicFormControlModelConfig,\r\n    DynamicFormGroupModelConfig,\r\n    DynamicFormValueControlModel,\r\n    DynamicInputModelConfig,\r\n    DynamicSelectModelConfig\r\n} from \"@ng-dynamic-forms/core\";\r\nimport {\r\n    IAsyncMessage,\r\n    IOpenApiSchema,\r\n    IOpenApiSchemaProperty,\r\n    IResolveFactory,\r\n    ObjectUtils,\r\n    ReflectUtils\r\n} from \"@stemy/ngx-utils\";\r\nimport {DynamicFormControlMapFn} from \"@ng-dynamic-forms/core/lib/service/dynamic-form-component.service\";\r\n\r\n// --- Basic form control interfaces ---\r\n\r\nexport type DynamicFormState = \"VALID\" | \"INVALID\" | \"PENDING\" | \"DISABLED\" | \"LOADING\";\r\nexport type DynamicFormUpdateOn = \"change\" | \"blur\" | \"submit\";\r\n\r\nexport interface IDynamicFormEvent extends DynamicFormControlEvent {\r\n    form: IDynamicForm;\r\n}\r\n\r\nexport interface IDynamicForm {\r\n    status: DynamicFormState;\r\n\r\n    onValueChange: EventEmitter<IDynamicFormEvent>;\r\n    onStatusChange: EventEmitter<IDynamicForm>;\r\n    onSubmit: EventEmitter<IDynamicForm>;\r\n\r\n    validate(): Promise<any>;\r\n    serialize(validate?: boolean): Promise<any>;\r\n}\r\n\r\nexport interface OnCreatedFormControl extends DynamicFormControl {\r\n    onCreated(): any;\r\n}\r\n\r\nexport declare interface ModelType extends Function {\r\n    new (config: DynamicFormControlModelConfig): DynamicFormControlModel;\r\n}\r\n\r\nexport type FormControlSerializer = (model: DynamicFormValueControlModel<any>, control: AbstractControl) => Promise<any>;\r\nexport type FormModelCustomizer = (\r\n    property: IOpenApiSchemaProperty, schema: IOpenApiSchema,\r\n    model: DynamicFormControlModel, config: DynamicFormControlModelConfig, injector: Injector\r\n) => DynamicFormControlModel | DynamicFormControlModel[];\r\nexport type FormModelCustomizerWrap = (\r\n    property: IOpenApiSchemaProperty, schema: IOpenApiSchema,\r\n    modelType: ModelType, config: DynamicFormControlModelConfig\r\n) => DynamicFormControlModel[];\r\n\r\nexport interface IFormControl {\r\n    id: string;\r\n    type: string;\r\n    config?: DynamicFormControlModelConfig;\r\n}\r\n\r\nexport interface IFormControlOption {\r\n    id: any;\r\n    label: string;\r\n    selectable?: boolean;\r\n}\r\n\r\n// --- Basic form interfaces ---\r\n\r\nexport interface IDynamicFormTemplates {\r\n    [id: string]: TemplateRef<any>;\r\n}\r\n\r\nexport interface IDynamicFormConfig {\r\n    path?: string | number | Array<string | number>;\r\n    name?: string;\r\n    classes?: string;\r\n    formClasses?: string;\r\n    innerFormClasses?: string;\r\n    id: string;\r\n}\r\n\r\nexport interface IDynamicSingleFormConfig extends IDynamicFormConfig, IDynamicFormInfo {\r\n    data: any;\r\n    controlData?: DynamicFormGroupModelConfig;\r\n    multi?: false;\r\n}\r\n\r\nexport interface IDynamicMultiFormConfig extends IDynamicFormConfig {\r\n    data: IDynamicFormsConfigs;\r\n    multi: true;\r\n}\r\n\r\nexport type IDynamicFormsConfigs = Array<IDynamicSingleFormConfig | IDynamicMultiFormConfig>;\r\n\r\nexport declare type AsyncSubmitMethod = (form: IDynamicForm, context?: any) => Promise<IAsyncMessage>;\r\n\r\nexport interface IDynamicFormInfo {\r\n    name?: string;\r\n    controls?: IFormControl[];\r\n}\r\n\r\n// --- Decorator functions ---\r\nexport function defaultSerializer(id: string, parent: FormArray): Promise<any> {\r\n    const control = parent.get(id);\r\n    return !control ? null: control.value;\r\n}\r\n\r\nexport function FormSerializable(serializer?: FormControlSerializer | IResolveFactory): PropertyDecorator {\r\n    return (target: any, propertyKey: string): void => {\r\n        ReflectUtils.defineMetadata(\"dynamicFormSerializer\", serializer || defaultSerializer, target, propertyKey);\r\n    };\r\n}\r\n\r\nexport function FormInput(data?: DynamicInputModelConfig): PropertyDecorator {\r\n    return (target: any, propertyKey: string): void => {\r\n        const meta = ReflectUtils.getOwnMetadata(\"design:type\", target, propertyKey);\r\n        const type = meta ? meta.name : \"\";\r\n        let inputType = propertyKey.indexOf(\"password\") < 0 ? \"text\" : \"password\";\r\n        switch (type) {\r\n            case \"Number\":\r\n                inputType = \"number\";\r\n                break;\r\n            case \"Boolean\":\r\n                inputType = \"checkbox\";\r\n                break;\r\n        }\r\n        defineFormControl(target, propertyKey, createFormInput(propertyKey, data, inputType));\r\n    };\r\n}\r\n\r\nexport function FormSelect(data?: DynamicSelectModelConfig<any>): PropertyDecorator {\r\n    return (target: any, propertyKey: string): void => {\r\n        defineFormControl(target, propertyKey, createFormSelect(propertyKey, data));\r\n    };\r\n}\r\n\r\nexport function FormStatic(data?: DynamicFormControlModelConfig): PropertyDecorator {\r\n    return (target: any, propertyKey: string): void => {\r\n        defineFormControl(target, propertyKey, createFormStatic(propertyKey, data));\r\n    };\r\n}\r\n\r\nexport function FormModel(data?: DynamicFormGroupModelConfig): PropertyDecorator {\r\n    return (target: any, propertyKey: string): void => {\r\n        defineFormControl(target, propertyKey, createFormModel(propertyKey, data));\r\n    };\r\n}\r\n\r\nexport function FormFile(data?: DynamicFileUploadModelConfig): PropertyDecorator {\r\n    return (target: any, propertyKey: string): void => {\r\n        defineFormControl(target, propertyKey, createFormFile(propertyKey, data));\r\n    };\r\n}\r\n\r\nexport function defineFormControl(target: any, propertyKey: string, control: IFormControl): void {\r\n    ReflectUtils.defineMetadata(\"dynamicFormControl\", control, target, propertyKey);\r\n}\r\n\r\nexport function getFormControl(target: any, propertyKey: string): IFormControl {\r\n    return ReflectUtils.getMetadata(\"dynamicFormControl\", target, propertyKey);\r\n}\r\n\r\nexport function getFormSerializer(target: any, propertyKey: string): FormControlSerializer | IResolveFactory {\r\n    return ReflectUtils.getMetadata(\"dynamicFormSerializer\", target, propertyKey);\r\n}\r\n\r\nexport function createFormControl(id: string, type: string, config?: DynamicFormControlModelConfig): IFormControl {\r\n    config = config || {id};\r\n    config.id = id;\r\n    config.label = ObjectUtils.isNullOrUndefined(config.label) ? id : config.label;\r\n    config.disabled = config.disabled || false;\r\n    config.hidden = config.hidden || false;\r\n    return {id, type, config};\r\n}\r\n\r\nexport function createFormInput(id: string, config: DynamicInputModelConfig, type: string = \"text\"): IFormControl {\r\n    const control = createFormControl(id, \"input\", config);\r\n    config = control.config;\r\n    config.inputType = config.inputType || type;\r\n    config.placeholder = config.placeholder || (config.inputType == \"mask\" ? \"_\" : \"\");\r\n    config.step = config.step || 1;\r\n    config.mask = config.mask || null;\r\n    return control;\r\n}\r\n\r\nexport function createFormSelect(id: string, data: DynamicSelectModelConfig<any>): IFormControl {\r\n    const control = createFormControl(id, \"select\", data);\r\n    data = control.config;\r\n    data.options = data.options || [];\r\n    return control;\r\n}\r\n\r\nexport function createFormStatic(id: string, config: DynamicFormControlModelConfig): IFormControl {\r\n    return createFormControl(id, \"static\", config);\r\n}\r\n\r\nexport function createFormModel(id: string, data: DynamicFormGroupModelConfig): IFormControl {\r\n    const control = createFormControl(id, \"group\", data);\r\n    data = control.config;\r\n    data.name = data.name || \"\";\r\n    return control;\r\n}\r\n\r\nexport function createFormFile(id: string, data: DynamicFileUploadModelConfig): IFormControl {\r\n    const control = createFormControl(id, \"file\", data);\r\n    data = control.config;\r\n    data.accept = data.accept || [\"jpg\", \"jpeg\", \"png\"];\r\n    data.multiple = data.multiple || false;\r\n    data.url = ObjectUtils.isString(data.url) ? data.url : \"assets\";\r\n    return control;\r\n}\r\n\r\nexport interface IDynamicFormModuleConfig {\r\n    controlProvider?: (injector: Injector) => DynamicFormControlMapFn;\r\n}\r\n"]}
|
|
97
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"common-types.js","sourceRoot":"","sources":["../../../src/ngx-dynamic-form/common-types.ts"],"names":[],"mappings":"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","sourcesContent":["import {EventEmitter, Injector, TemplateRef} from \"@angular/core\";\r\nimport {AbstractControl, FormArray} from \"@angular/forms\";\r\nimport {\r\n    DynamicFileUploadModelConfig,\r\n    DynamicFormControl,\r\n    DynamicFormControlEvent,\r\n    DynamicFormControlMapFn,\r\n    DynamicFormControlModel,\r\n    DynamicFormControlModelConfig,\r\n    DynamicFormGroupModelConfig,\r\n    DynamicFormValueControlModel,\r\n    DynamicInputModelConfig,\r\n    DynamicSelectModelConfig\r\n} from \"@ng-dynamic-forms/core\";\r\nimport {\r\n    IAsyncMessage,\r\n    IOpenApiSchema,\r\n    IOpenApiSchemaProperty,\r\n    IResolveFactory,\r\n    ObjectUtils,\r\n    ReflectUtils\r\n} from \"@stemy/ngx-utils\";\r\n\r\n// --- Basic form control interfaces ---\r\n\r\nexport type DynamicFormState = \"VALID\" | \"INVALID\" | \"PENDING\" | \"DISABLED\" | \"LOADING\";\r\nexport type DynamicFormUpdateOn = \"change\" | \"blur\" | \"submit\";\r\n\r\nexport interface IDynamicFormEvent extends DynamicFormControlEvent {\r\n    form: IDynamicForm;\r\n}\r\n\r\nexport interface IDynamicForm {\r\n    status: DynamicFormState;\r\n\r\n    onValueChange: EventEmitter<IDynamicFormEvent>;\r\n    onStatusChange: EventEmitter<IDynamicForm>;\r\n    onSubmit: EventEmitter<IDynamicForm>;\r\n\r\n    validate(): Promise<any>;\r\n    serialize(validate?: boolean): Promise<any>;\r\n}\r\n\r\nexport interface OnCreatedFormControl extends DynamicFormControl {\r\n    onCreated(): any;\r\n}\r\n\r\nexport declare interface ModelType extends Function {\r\n    new (config: DynamicFormControlModelConfig): DynamicFormControlModel;\r\n}\r\n\r\nexport type FormControlSerializer = (model: DynamicFormValueControlModel<any>, control: AbstractControl) => Promise<any>;\r\nexport type FormModelCustomizer = (\r\n    property: IOpenApiSchemaProperty, schema: IOpenApiSchema,\r\n    model: DynamicFormControlModel, config: DynamicFormControlModelConfig, injector: Injector\r\n) => DynamicFormControlModel | DynamicFormControlModel[];\r\nexport type FormModelCustomizerWrap = (\r\n    property: IOpenApiSchemaProperty, schema: IOpenApiSchema,\r\n    modelType: ModelType, config: DynamicFormControlModelConfig\r\n) => DynamicFormControlModel[];\r\n\r\nexport interface IFormControl {\r\n    id: string;\r\n    type: string;\r\n    config?: DynamicFormControlModelConfig;\r\n}\r\n\r\nexport interface IFormControlOption {\r\n    id: any;\r\n    label: string;\r\n    selectable?: boolean;\r\n}\r\n\r\n// --- Basic form interfaces ---\r\n\r\nexport interface IDynamicFormTemplates {\r\n    [id: string]: TemplateRef<any>;\r\n}\r\n\r\nexport interface IDynamicFormConfig {\r\n    path?: string | number | Array<string | number>;\r\n    name?: string;\r\n    classes?: string;\r\n    formClasses?: string;\r\n    innerFormClasses?: string;\r\n    id: string;\r\n}\r\n\r\nexport interface IDynamicSingleFormConfig extends IDynamicFormConfig, IDynamicFormInfo {\r\n    data: any;\r\n    controlData?: DynamicFormGroupModelConfig;\r\n    multi?: false;\r\n}\r\n\r\nexport interface IDynamicMultiFormConfig extends IDynamicFormConfig {\r\n    data: IDynamicFormsConfigs;\r\n    multi: true;\r\n}\r\n\r\nexport type IDynamicFormsConfigs = Array<IDynamicSingleFormConfig | IDynamicMultiFormConfig>;\r\n\r\nexport declare type AsyncSubmitMethod = (form: IDynamicForm, context?: any) => Promise<IAsyncMessage>;\r\n\r\nexport interface IDynamicFormInfo {\r\n    name?: string;\r\n    controls?: IFormControl[];\r\n}\r\n\r\n// --- Decorator functions ---\r\nexport function defaultSerializer(id: string, parent: FormArray): Promise<any> {\r\n    const control = parent.get(id);\r\n    return !control ? null: control.value;\r\n}\r\n\r\nexport function FormSerializable(serializer?: FormControlSerializer | IResolveFactory): PropertyDecorator {\r\n    return (target: any, propertyKey: string): void => {\r\n        ReflectUtils.defineMetadata(\"dynamicFormSerializer\", serializer || defaultSerializer, target, propertyKey);\r\n    };\r\n}\r\n\r\nexport function FormInput(data?: DynamicInputModelConfig): PropertyDecorator {\r\n    return (target: any, propertyKey: string): void => {\r\n        const meta = ReflectUtils.getOwnMetadata(\"design:type\", target, propertyKey);\r\n        const type = meta ? meta.name : \"\";\r\n        let inputType = propertyKey.indexOf(\"password\") < 0 ? \"text\" : \"password\";\r\n        switch (type) {\r\n            case \"Number\":\r\n                inputType = \"number\";\r\n                break;\r\n            case \"Boolean\":\r\n                inputType = \"checkbox\";\r\n                break;\r\n        }\r\n        defineFormControl(target, propertyKey, createFormInput(propertyKey, data, inputType));\r\n    };\r\n}\r\n\r\nexport function FormSelect(data?: DynamicSelectModelConfig<any>): PropertyDecorator {\r\n    return (target: any, propertyKey: string): void => {\r\n        defineFormControl(target, propertyKey, createFormSelect(propertyKey, data));\r\n    };\r\n}\r\n\r\nexport function FormStatic(data?: DynamicFormControlModelConfig): PropertyDecorator {\r\n    return (target: any, propertyKey: string): void => {\r\n        defineFormControl(target, propertyKey, createFormStatic(propertyKey, data));\r\n    };\r\n}\r\n\r\nexport function FormModel(data?: DynamicFormGroupModelConfig): PropertyDecorator {\r\n    return (target: any, propertyKey: string): void => {\r\n        defineFormControl(target, propertyKey, createFormModel(propertyKey, data));\r\n    };\r\n}\r\n\r\nexport function FormFile(data?: DynamicFileUploadModelConfig): PropertyDecorator {\r\n    return (target: any, propertyKey: string): void => {\r\n        defineFormControl(target, propertyKey, createFormFile(propertyKey, data));\r\n    };\r\n}\r\n\r\nexport function defineFormControl(target: any, propertyKey: string, control: IFormControl): void {\r\n    ReflectUtils.defineMetadata(\"dynamicFormControl\", control, target, propertyKey);\r\n}\r\n\r\nexport function getFormControl(target: any, propertyKey: string): IFormControl {\r\n    return ReflectUtils.getMetadata(\"dynamicFormControl\", target, propertyKey);\r\n}\r\n\r\nexport function getFormSerializer(target: any, propertyKey: string): FormControlSerializer | IResolveFactory {\r\n    return ReflectUtils.getMetadata(\"dynamicFormSerializer\", target, propertyKey);\r\n}\r\n\r\nexport function createFormControl(id: string, type: string, config?: DynamicFormControlModelConfig): IFormControl {\r\n    config = config || {id};\r\n    config.id = id;\r\n    config.label = ObjectUtils.isNullOrUndefined(config.label) ? id : config.label;\r\n    config.disabled = config.disabled || false;\r\n    config.hidden = config.hidden || false;\r\n    return {id, type, config};\r\n}\r\n\r\nexport function createFormInput(id: string, config: DynamicInputModelConfig, type: string = \"text\"): IFormControl {\r\n    const control = createFormControl(id, \"input\", config);\r\n    config = control.config;\r\n    config.inputType = config.inputType || type;\r\n    config.placeholder = config.placeholder || (config.inputType == \"mask\" ? \"_\" : \"\");\r\n    config.step = config.step || 1;\r\n    config.mask = config.mask || null;\r\n    return control;\r\n}\r\n\r\nexport function createFormSelect(id: string, data: DynamicSelectModelConfig<any>): IFormControl {\r\n    const control = createFormControl(id, \"select\", data);\r\n    data = control.config;\r\n    data.options = data.options || [];\r\n    return control;\r\n}\r\n\r\nexport function createFormStatic(id: string, config: DynamicFormControlModelConfig): IFormControl {\r\n    return createFormControl(id, \"static\", config);\r\n}\r\n\r\nexport function createFormModel(id: string, data: DynamicFormGroupModelConfig): IFormControl {\r\n    const control = createFormControl(id, \"group\", data);\r\n    data = control.config;\r\n    data.name = data.name || \"\";\r\n    return control;\r\n}\r\n\r\nexport function createFormFile(id: string, data: DynamicFileUploadModelConfig): IFormControl {\r\n    const control = createFormControl(id, \"file\", data);\r\n    data = control.config;\r\n    data.accept = data.accept || [\"jpg\", \"jpeg\", \"png\"];\r\n    data.multiple = data.multiple || false;\r\n    data.url = ObjectUtils.isString(data.url) ? data.url : \"assets\";\r\n    return control;\r\n}\r\n\r\nexport interface IDynamicFormModuleConfig {\r\n    controlProvider?: (injector: Injector) => DynamicFormControlMapFn;\r\n}\r\n"]}
|
|
@@ -24,6 +24,9 @@ export class DynamicBaseFormArrayComponent extends DynamicFormArrayComponent {
|
|
|
24
24
|
restoreTab() {
|
|
25
25
|
return this.model.restoreTab(this.model, this.injector);
|
|
26
26
|
}
|
|
27
|
+
getTabLabel(index) {
|
|
28
|
+
return this.model.getTabLabel(index, this.model, this.array, this.injector);
|
|
29
|
+
}
|
|
27
30
|
getClass(context, place, model) {
|
|
28
31
|
return [
|
|
29
32
|
context == "element" ? this.getModelClass(model) : null,
|
|
@@ -82,4 +85,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
|
|
|
82
85
|
type: ViewChildren,
|
|
83
86
|
args: [forwardRef(() => DynamicFormControlContainerComponent)]
|
|
84
87
|
}] } });
|
|
85
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
88
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-base-form-array.component.js","sourceRoot":"","sources":["../../../../../src/ngx-dynamic-form/components/base/dynamic-base-form-array.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    ChangeDetectionStrategy,\r\n    Component,\r\n    EventEmitter,\r\n    forwardRef,\r\n    Injector,\r\n    Input,\r\n    Output,\r\n    QueryList,\r\n    ViewChildren\r\n} from \"@angular/core\";\r\nimport {FormGroup} from \"@angular/forms\";\r\nimport {\r\n    DynamicFormArrayComponent,\r\n    DynamicFormControlContainerComponent,\r\n    DynamicFormControlCustomEvent,\r\n    DynamicFormControlLayout,\r\n    DynamicFormControlLayoutContext,\r\n    DynamicFormControlLayoutPlace,\r\n    DynamicFormControlModel,\r\n    DynamicFormGroupModel,\r\n    DynamicFormLayout,\r\n    DynamicFormLayoutService,\r\n    DynamicFormValidationService,\r\n    DynamicFormValueControlModel,\r\n    DynamicTemplateDirective\r\n} from \"@ng-dynamic-forms/core\";\r\nimport {DynamicFormArrayModel} from \"../../utils/dynamic-form-array.model\";\r\nimport {collectPathAble} from \"../../utils/misc\";\r\n\r\n@Component({\r\n    selector: \"dynamic-base-form-array\",\r\n    template: \"\",\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class DynamicBaseFormArrayComponent extends DynamicFormArrayComponent {\r\n\r\n    @Input() formLayout: DynamicFormLayout;\r\n    @Input() group: FormGroup;\r\n    @Input() layout: DynamicFormControlLayout;\r\n    @Input() model: DynamicFormArrayModel;\r\n    @Input() templates: QueryList<DynamicTemplateDirective> | undefined;\r\n\r\n    @Output() blur: EventEmitter<any> = new EventEmitter();\r\n    @Output() change: EventEmitter<any> = new EventEmitter();\r\n    @Output() customEvent: EventEmitter<DynamicFormControlCustomEvent> = new EventEmitter();\r\n    @Output() focus: EventEmitter<any> = new EventEmitter();\r\n\r\n    @ViewChildren(forwardRef(() => DynamicFormControlContainerComponent))\r\n    components: QueryList<DynamicFormControlContainerComponent>;\r\n\r\n    get useTabs(): boolean {\r\n        return this.model?.useTabs;\r\n    }\r\n\r\n    constructor(protected layoutService: DynamicFormLayoutService,\r\n                protected validationService: DynamicFormValidationService,\r\n                protected injector: Injector) {\r\n\r\n        super(layoutService, validationService);\r\n    }\r\n\r\n    saveTab(index: number): void {\r\n        this.model.saveTab(index, this.model, this.injector);\r\n    }\r\n\r\n    restoreTab(): number {\r\n        return this.model.restoreTab(this.model, this.injector);\r\n    }\r\n\r\n    getTabLabel(index: number): string {\r\n        return this.model.getTabLabel(index, this.model, this.array, this.injector);\r\n    }\r\n\r\n    getClass(context: DynamicFormControlLayoutContext, place: DynamicFormControlLayoutPlace, model?: DynamicFormControlModel): string {\r\n        return [\r\n            context == \"element\" ? this.getModelClass(model) : null,\r\n            context == \"element\" ? this.getAdditionalClass(model) : null,\r\n            super.getClass(context, place, model),\r\n            model instanceof DynamicFormValueControlModel ? model.additional?.classes : null\r\n        ].filter(cls => !!cls).join(\" \");\r\n    }\r\n\r\n    protected getModelClass(model?: DynamicFormControlModel): string {\r\n        const parts = collectPathAble(model, p => p.id);\r\n        if (parts.length == 0) return \"\";\r\n        if (model instanceof DynamicFormGroupModel) {\r\n            return `form-group-${parts.join(\"-\")}`;\r\n        }\r\n        return `form-control-${parts.join(\"-\")}`;\r\n    }\r\n\r\n    protected getAdditionalClass(model?: DynamicFormControlModel): string {\r\n        if (model instanceof DynamicFormArrayModel) {\r\n            return model.additional?.classes;\r\n        }\r\n        if (model instanceof DynamicFormValueControlModel) {\r\n            return model.additional?.classes;\r\n        }\r\n        return null;\r\n    }\r\n}\r\n"]}
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from "@angular/core";
|
|
2
|
+
import { DynamicFormControlComponent } from "@ng-dynamic-forms/core";
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@ng-dynamic-forms/core";
|
|
5
|
+
export class DynamicBaseFormControlComponent extends DynamicFormControlComponent {
|
|
6
|
+
constructor(layoutService, validationService) {
|
|
7
|
+
super(layoutService, validationService);
|
|
8
|
+
this.blur = new EventEmitter();
|
|
9
|
+
this.change = new EventEmitter();
|
|
10
|
+
this.focus = new EventEmitter();
|
|
11
|
+
}
|
|
12
|
+
}
|
|
13
|
+
DynamicBaseFormControlComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: DynamicBaseFormControlComponent, deps: [{ token: i1.DynamicFormLayoutService }, { token: i1.DynamicFormValidationService }], target: i0.ɵɵFactoryTarget.Component });
|
|
14
|
+
DynamicBaseFormControlComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.8", type: DynamicBaseFormControlComponent, selector: "dynamic-base-form-control", inputs: { formLayout: "formLayout", group: "group", layout: "layout", model: "model" }, outputs: { blur: "blur", change: "change", focus: "focus" }, usesInheritance: true, ngImport: i0, template: "", isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
15
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: DynamicBaseFormControlComponent, decorators: [{
|
|
16
|
+
type: Component,
|
|
17
|
+
args: [{
|
|
18
|
+
selector: "dynamic-base-form-control",
|
|
19
|
+
template: "",
|
|
20
|
+
changeDetection: ChangeDetectionStrategy.OnPush
|
|
21
|
+
}]
|
|
22
|
+
}], ctorParameters: function () { return [{ type: i1.DynamicFormLayoutService }, { type: i1.DynamicFormValidationService }]; }, propDecorators: { formLayout: [{
|
|
23
|
+
type: Input
|
|
24
|
+
}], group: [{
|
|
25
|
+
type: Input
|
|
26
|
+
}], layout: [{
|
|
27
|
+
type: Input
|
|
28
|
+
}], model: [{
|
|
29
|
+
type: Input
|
|
30
|
+
}], blur: [{
|
|
31
|
+
type: Output
|
|
32
|
+
}], change: [{
|
|
33
|
+
type: Output
|
|
34
|
+
}], focus: [{
|
|
35
|
+
type: Output
|
|
36
|
+
}] } });
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHluYW1pYy1iYXNlLWZvcm0tY29udHJvbC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbmd4LWR5bmFtaWMtZm9ybS9jb21wb25lbnRzL2Jhc2UvZHluYW1pYy1iYXNlLWZvcm0tY29udHJvbC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUU5RixPQUFPLEVBQ0gsMkJBQTJCLEVBTTlCLE1BQU0sd0JBQXdCLENBQUM7OztBQU9oQyxNQUFNLE9BQU8sK0JBQW1FLFNBQVEsMkJBQTJCO0lBVy9HLFlBQVksYUFBdUMsRUFBRSxpQkFBK0M7UUFDaEcsS0FBSyxDQUFDLGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxDQUFDO1FBQ3hDLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxZQUFZLEVBQU8sQ0FBQztRQUNwQyxJQUFJLENBQUMsTUFBTSxHQUFHLElBQUksWUFBWSxFQUFPLENBQUM7UUFDdEMsSUFBSSxDQUFDLEtBQUssR0FBRyxJQUFJLFlBQVksRUFBTyxDQUFDO0lBQ3pDLENBQUM7OzRIQWhCUSwrQkFBK0I7Z0hBQS9CLCtCQUErQiw2T0FIOUIsRUFBRTsyRkFHSCwrQkFBK0I7a0JBTDNDLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLDJCQUEyQjtvQkFDckMsUUFBUSxFQUFFLEVBQUU7b0JBQ1osZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07aUJBQ2xEOzBKQUdZLFVBQVU7c0JBQWxCLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLO2dCQUNHLE1BQU07c0JBQWQsS0FBSztnQkFDRyxLQUFLO3NCQUFiLEtBQUs7Z0JBRUksSUFBSTtzQkFBYixNQUFNO2dCQUNHLE1BQU07c0JBQWYsTUFBTTtnQkFDRyxLQUFLO3NCQUFkLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHtGb3JtR3JvdXB9IGZyb20gXCJAYW5ndWxhci9mb3Jtc1wiO1xyXG5pbXBvcnQge1xyXG4gICAgRHluYW1pY0Zvcm1Db250cm9sQ29tcG9uZW50LFxyXG4gICAgRHluYW1pY0Zvcm1Db250cm9sTGF5b3V0LFxyXG4gICAgRHluYW1pY0Zvcm1Db250cm9sTW9kZWwsXHJcbiAgICBEeW5hbWljRm9ybUxheW91dCxcclxuICAgIER5bmFtaWNGb3JtTGF5b3V0U2VydmljZSxcclxuICAgIER5bmFtaWNGb3JtVmFsaWRhdGlvblNlcnZpY2VcclxufSBmcm9tIFwiQG5nLWR5bmFtaWMtZm9ybXMvY29yZVwiO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogXCJkeW5hbWljLWJhc2UtZm9ybS1jb250cm9sXCIsXHJcbiAgICB0ZW1wbGF0ZTogXCJcIixcclxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBEeW5hbWljQmFzZUZvcm1Db250cm9sQ29tcG9uZW50PFQgZXh0ZW5kcyBEeW5hbWljRm9ybUNvbnRyb2xNb2RlbD4gZXh0ZW5kcyBEeW5hbWljRm9ybUNvbnRyb2xDb21wb25lbnQge1xyXG5cclxuICAgIEBJbnB1dCgpIGZvcm1MYXlvdXQ6IER5bmFtaWNGb3JtTGF5b3V0O1xyXG4gICAgQElucHV0KCkgZ3JvdXA6IEZvcm1Hcm91cDtcclxuICAgIEBJbnB1dCgpIGxheW91dDogRHluYW1pY0Zvcm1Db250cm9sTGF5b3V0O1xyXG4gICAgQElucHV0KCkgbW9kZWw6IFQ7XHJcblxyXG4gICAgQE91dHB1dCgpIGJsdXI6IEV2ZW50RW1pdHRlcjxhbnk+O1xyXG4gICAgQE91dHB1dCgpIGNoYW5nZTogRXZlbnRFbWl0dGVyPGFueT47XHJcbiAgICBAT3V0cHV0KCkgZm9jdXM6IEV2ZW50RW1pdHRlcjxhbnk+O1xyXG5cclxuICAgIGNvbnN0cnVjdG9yKGxheW91dFNlcnZpY2U6IER5bmFtaWNGb3JtTGF5b3V0U2VydmljZSwgdmFsaWRhdGlvblNlcnZpY2U6IER5bmFtaWNGb3JtVmFsaWRhdGlvblNlcnZpY2UpIHtcclxuICAgICAgICBzdXBlcihsYXlvdXRTZXJ2aWNlLCB2YWxpZGF0aW9uU2VydmljZSk7XHJcbiAgICAgICAgdGhpcy5ibHVyID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XHJcbiAgICAgICAgdGhpcy5jaGFuZ2UgPSBuZXcgRXZlbnRFbWl0dGVyPGFueT4oKTtcclxuICAgICAgICB0aGlzLmZvY3VzID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XHJcbiAgICB9XHJcbn1cclxuIl19
|
|
@@ -4,8 +4,8 @@ import { Subscription } from "rxjs";
|
|
|
4
4
|
import { first } from "rxjs/operators";
|
|
5
5
|
import { DynamicFormComponent, DynamicFormGroupModel, DynamicTemplateDirective } from "@ng-dynamic-forms/core";
|
|
6
6
|
import { EventsService, ObservableUtils } from "@stemy/ngx-utils";
|
|
7
|
-
import { DynamicFormService } from "../../services/dynamic-form.service";
|
|
8
7
|
import { collectPathAble } from "../../utils/misc";
|
|
8
|
+
import { DynamicFormService } from "../../services/dynamic-form.service";
|
|
9
9
|
import * as i0 from "@angular/core";
|
|
10
10
|
import * as i1 from "@ng-dynamic-forms/core";
|
|
11
11
|
import * as i2 from "../../services/dynamic-form.service";
|
|
@@ -63,6 +63,10 @@ export class DynamicBaseFormComponent extends DynamicFormComponent {
|
|
|
63
63
|
this.formService.insertFormArrayGroup(index, formArray, formArrayModel);
|
|
64
64
|
this.changeDetectorRef.detectChanges();
|
|
65
65
|
}
|
|
66
|
+
cloneFormArrayGroup(index, formArray, formArrayModel) {
|
|
67
|
+
this.formService.cloneFormArrayGroup(index, formArray, formArrayModel);
|
|
68
|
+
this.changeDetectorRef.detectChanges();
|
|
69
|
+
}
|
|
66
70
|
removeFormArrayGroup(index, formArray, formArrayModel) {
|
|
67
71
|
this.formService.removeFormArrayGroup(index, formArray, formArrayModel);
|
|
68
72
|
this.changeDetectorRef.detectChanges();
|
|
@@ -155,4 +159,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
|
|
|
155
159
|
type: ViewChild,
|
|
156
160
|
args: [NgForm]
|
|
157
161
|
}] } });
|
|
158
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-base-form.component.js","sourceRoot":"","sources":["../../../../../src/ngx-dynamic-form/components/base/dynamic-base-form.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    AfterViewInit,\r\n    ChangeDetectionStrategy,\r\n    ChangeDetectorRef,\r\n    Component,\r\n    ContentChildren,\r\n    EventEmitter,\r\n    Inject,\r\n    Input,\r\n    OnChanges,\r\n    Output,\r\n    QueryList,\r\n    SimpleChanges,\r\n    ViewChild,\r\n    ViewChildren\r\n} from \"@angular/core\";\r\nimport {FormArray, FormGroup, NgForm} from \"@angular/forms\";\r\nimport {Subscription} from \"rxjs\";\r\nimport {first} from \"rxjs/operators\";\r\nimport {\r\n    DynamicFormArrayModel,\r\n    DynamicFormComponent,\r\n    DynamicFormComponentService,\r\n    DynamicFormControlEvent,\r\n    DynamicFormControlModel,\r\n    DynamicFormGroupModel,\r\n    DynamicFormLayout,\r\n    DynamicFormModel,\r\n    DynamicTemplateDirective\r\n} from \"@ng-dynamic-forms/core\";\r\nimport {EventsService, ObservableUtils} from \"@stemy/ngx-utils\";\r\nimport {DynamicFormState, IDynamicForm, IDynamicFormEvent} from \"../../common-types\";\r\nimport {DynamicFormService} from \"../../services/dynamic-form.service\";\r\nimport {collectPathAble} from \"../../utils/misc\";\r\n\r\n@Component({\r\n    selector: \"dynamic-base-form\",\r\n    template: \"\",\r\n    changeDetection: ChangeDetectionStrategy.Default\r\n})\r\nexport class DynamicBaseFormComponent extends DynamicFormComponent implements OnChanges, AfterViewInit, IDynamicForm {\r\n\r\n    @Input() group: FormGroup;\r\n    @Input() model: DynamicFormModel;\r\n    @Input() layout: DynamicFormLayout;\r\n    @Input() labelPrefix: string;\r\n\r\n    @Output() blur: EventEmitter<DynamicFormControlEvent>;\r\n    @Output() change: EventEmitter<DynamicFormControlEvent>;\r\n    @Output() focus: EventEmitter<DynamicFormControlEvent>;\r\n\r\n    @ContentChildren(DynamicTemplateDirective) contentTemplates: QueryList<DynamicTemplateDirective>;\r\n    @ViewChildren(DynamicTemplateDirective) viewTemplates: QueryList<DynamicTemplateDirective>;\r\n\r\n    get status(): DynamicFormState {\r\n        return !this.group ? null : this.group.status as DynamicFormState;\r\n    }\r\n\r\n    @Output() readonly onValueChange: EventEmitter<IDynamicFormEvent>;\r\n    @Output() readonly onStatusChange: EventEmitter<IDynamicForm>;\r\n    @Output() readonly onSubmit: EventEmitter<IDynamicForm>;\r\n\r\n    @ViewChild(NgForm)\r\n    protected ngForm: NgForm;\r\n    protected subscription: Subscription;\r\n    protected groupSubscription: Subscription;\r\n\r\n    constructor(@Inject(DynamicFormService) readonly formService: DynamicFormService,\r\n                @Inject(EventsService) readonly events: EventsService,\r\n                changeDetectorRef: ChangeDetectorRef,\r\n                componentService: DynamicFormComponentService,) {\r\n        super(changeDetectorRef, componentService);\r\n        this.blur = new EventEmitter<DynamicFormControlEvent>();\r\n        this.change = new EventEmitter<DynamicFormControlEvent>();\r\n        this.focus = new EventEmitter<DynamicFormControlEvent>();\r\n        this.onValueChange = new EventEmitter<IDynamicFormEvent>();\r\n        this.onStatusChange = new EventEmitter<IDynamicForm>();\r\n        this.onSubmit = new EventEmitter<IDynamicForm>();\r\n        this.templates = new QueryList<DynamicTemplateDirective>();\r\n        this.subscription = new Subscription();\r\n        this.groupSubscription = new Subscription();\r\n        this.labelPrefix = \"label\";\r\n    }\r\n\r\n    ngOnChanges(changes: SimpleChanges): void {\r\n        this.groupSubscription.unsubscribe();\r\n        if (this.group) {\r\n            this.groupSubscription = ObservableUtils.multiSubscription(\r\n                this.group.statusChanges.subscribe(() => {\r\n                    this.onStatusChange.emit(this);\r\n                }),\r\n                this.group.valueChanges.subscribe(() => {\r\n                    this.formService.notifyChanges(this.model, this.group, this.model);\r\n                }),\r\n                this.change.subscribe(ev => {\r\n                    this.onValueChange.emit({...ev, form: this});\r\n                })\r\n            );\r\n        }\r\n    }\r\n\r\n    ngAfterViewInit(): void {\r\n        this.subscription = ObservableUtils.multiSubscription(\r\n            ObservableUtils.subscribe(\r\n                {\r\n                    subjects: [this.contentTemplates.changes, this.viewTemplates.changes],\r\n                    cb: () => {\r\n                        const templates = this.contentTemplates.toArray().concat(this.viewTemplates.toArray());\r\n                        this.templates.reset(templates);\r\n                    }\r\n                }\r\n            ),\r\n            this.events.languageChanged.subscribe(() => {\r\n                this.formService.detectChanges(this)\r\n            }),\r\n            this.ngForm.ngSubmit.subscribe(() => {\r\n                this.onSubmit.emit(this);\r\n            })\r\n        );\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        super.ngOnDestroy();\r\n        this.subscription.unsubscribe();\r\n        this.groupSubscription.unsubscribe();\r\n    }\r\n\r\n    insertFormArrayGroup(index: number, formArray: FormArray, formArrayModel: DynamicFormArrayModel): void {\r\n        this.formService.insertFormArrayGroup(index, formArray, formArrayModel);\r\n        this.changeDetectorRef.detectChanges();\r\n    }\r\n\r\n    removeFormArrayGroup(index: number, formArray: FormArray, formArrayModel: DynamicFormArrayModel): void {\r\n        this.formService.removeFormArrayGroup(index, formArray, formArrayModel);\r\n        this.changeDetectorRef.detectChanges();\r\n    }\r\n\r\n    moveFormArrayGroup(index: number, step: number, formArray: FormArray, formArrayModel: DynamicFormArrayModel): void {\r\n        this.formService.moveFormArrayGroup(index, step, formArray, formArrayModel);\r\n        this.changeDetectorRef.detectChanges();\r\n    }\r\n\r\n    clearFormArray(formArray: FormArray, formArrayModel: DynamicFormArrayModel): void {\r\n        this.formService.clearFormArray(formArray, formArrayModel);\r\n        this.changeDetectorRef.detectChanges();\r\n    }\r\n\r\n    getClass(model?: DynamicFormControlModel): string {\r\n        const parts = collectPathAble(model, p => p.id);\r\n        if (parts.length == 0) return \"\";\r\n        if (model instanceof DynamicFormGroupModel) {\r\n            return `form-group-${parts.join(\"-\")}`;\r\n        }\r\n        return `form-control-${parts.join(\"-\")}`;\r\n    }\r\n\r\n    validate(showErrors: boolean = true): Promise<any> {\r\n        if (!this.group) return Promise.resolve();\r\n        return new Promise<any>((resolve, reject) => {\r\n            this.group.statusChanges.pipe(first(status => status == \"VALID\" || status == \"INVALID\")).subscribe(status => {\r\n                if (showErrors) {\r\n                    this.formService.showErrors(this);\r\n                }\r\n                if (status == \"VALID\") {\r\n                    resolve(null);\r\n                    return;\r\n                }\r\n                reject(null);\r\n            });\r\n            this.group.updateValueAndValidity();\r\n        });\r\n    }\r\n\r\n    async serialize(validate?: boolean): Promise<any> {\r\n        if (!this.group) return null;\r\n        if (validate) {\r\n            await this.validate();\r\n        }\r\n        return await this.formService.serialize(this.model, this.group);\r\n    }\r\n}\r\n"]}
|
|
162
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-base-form.component.js","sourceRoot":"","sources":["../../../../../src/ngx-dynamic-form/components/base/dynamic-base-form.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    AfterViewInit,\r\n    ChangeDetectionStrategy,\r\n    ChangeDetectorRef,\r\n    Component,\r\n    ContentChildren,\r\n    EventEmitter,\r\n    Inject,\r\n    Input,\r\n    OnChanges,\r\n    Output,\r\n    QueryList,\r\n    SimpleChanges,\r\n    ViewChild,\r\n    ViewChildren\r\n} from \"@angular/core\";\r\nimport {FormArray, FormGroup, NgForm} from \"@angular/forms\";\r\nimport {Subscription} from \"rxjs\";\r\nimport {first} from \"rxjs/operators\";\r\nimport {\r\n    DynamicFormComponent,\r\n    DynamicFormComponentService,\r\n    DynamicFormControlEvent,\r\n    DynamicFormControlModel,\r\n    DynamicFormGroupModel,\r\n    DynamicFormLayout,\r\n    DynamicFormModel,\r\n    DynamicTemplateDirective\r\n} from \"@ng-dynamic-forms/core\";\r\nimport {EventsService, ObservableUtils} from \"@stemy/ngx-utils\";\r\nimport {DynamicFormState, IDynamicForm, IDynamicFormEvent} from \"../../common-types\";\r\nimport {collectPathAble} from \"../../utils/misc\";\r\nimport {DynamicFormArrayModel} from \"../../utils/dynamic-form-array.model\";\r\nimport {DynamicFormService} from \"../../services/dynamic-form.service\";\r\n\r\n@Component({\r\n    selector: \"dynamic-base-form\",\r\n    template: \"\",\r\n    changeDetection: ChangeDetectionStrategy.Default\r\n})\r\nexport class DynamicBaseFormComponent extends DynamicFormComponent implements OnChanges, AfterViewInit, IDynamicForm {\r\n\r\n    @Input() group: FormGroup;\r\n    @Input() model: DynamicFormModel;\r\n    @Input() layout: DynamicFormLayout;\r\n    @Input() labelPrefix: string;\r\n\r\n    @Output() blur: EventEmitter<DynamicFormControlEvent>;\r\n    @Output() change: EventEmitter<DynamicFormControlEvent>;\r\n    @Output() focus: EventEmitter<DynamicFormControlEvent>;\r\n\r\n    @ContentChildren(DynamicTemplateDirective) contentTemplates: QueryList<DynamicTemplateDirective>;\r\n    @ViewChildren(DynamicTemplateDirective) viewTemplates: QueryList<DynamicTemplateDirective>;\r\n\r\n    get status(): DynamicFormState {\r\n        return !this.group ? null : this.group.status as DynamicFormState;\r\n    }\r\n\r\n    @Output() readonly onValueChange: EventEmitter<IDynamicFormEvent>;\r\n    @Output() readonly onStatusChange: EventEmitter<IDynamicForm>;\r\n    @Output() readonly onSubmit: EventEmitter<IDynamicForm>;\r\n\r\n    @ViewChild(NgForm)\r\n    protected ngForm: NgForm;\r\n    protected subscription: Subscription;\r\n    protected groupSubscription: Subscription;\r\n\r\n    constructor(@Inject(DynamicFormService) readonly formService: DynamicFormService,\r\n                @Inject(EventsService) readonly events: EventsService,\r\n                changeDetectorRef: ChangeDetectorRef,\r\n                componentService: DynamicFormComponentService,) {\r\n        super(changeDetectorRef, componentService);\r\n        this.blur = new EventEmitter<DynamicFormControlEvent>();\r\n        this.change = new EventEmitter<DynamicFormControlEvent>();\r\n        this.focus = new EventEmitter<DynamicFormControlEvent>();\r\n        this.onValueChange = new EventEmitter<IDynamicFormEvent>();\r\n        this.onStatusChange = new EventEmitter<IDynamicForm>();\r\n        this.onSubmit = new EventEmitter<IDynamicForm>();\r\n        this.templates = new QueryList<DynamicTemplateDirective>();\r\n        this.subscription = new Subscription();\r\n        this.groupSubscription = new Subscription();\r\n        this.labelPrefix = \"label\";\r\n    }\r\n\r\n    ngOnChanges(changes: SimpleChanges): void {\r\n        this.groupSubscription.unsubscribe();\r\n        if (this.group) {\r\n            this.groupSubscription = ObservableUtils.multiSubscription(\r\n                this.group.statusChanges.subscribe(() => {\r\n                    this.onStatusChange.emit(this);\r\n                }),\r\n                this.group.valueChanges.subscribe(() => {\r\n                    this.formService.notifyChanges(this.model, this.group, this.model);\r\n                }),\r\n                this.change.subscribe(ev => {\r\n                    this.onValueChange.emit({...ev, form: this});\r\n                })\r\n            );\r\n        }\r\n    }\r\n\r\n    ngAfterViewInit(): void {\r\n        this.subscription = ObservableUtils.multiSubscription(\r\n            ObservableUtils.subscribe(\r\n                {\r\n                    subjects: [this.contentTemplates.changes, this.viewTemplates.changes],\r\n                    cb: () => {\r\n                        const templates = this.contentTemplates.toArray().concat(this.viewTemplates.toArray());\r\n                        this.templates.reset(templates);\r\n                    }\r\n                }\r\n            ),\r\n            this.events.languageChanged.subscribe(() => {\r\n                this.formService.detectChanges(this)\r\n            }),\r\n            this.ngForm.ngSubmit.subscribe(() => {\r\n                this.onSubmit.emit(this);\r\n            })\r\n        );\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        super.ngOnDestroy();\r\n        this.subscription.unsubscribe();\r\n        this.groupSubscription.unsubscribe();\r\n    }\r\n\r\n    insertFormArrayGroup(index: number, formArray: FormArray, formArrayModel: DynamicFormArrayModel): void {\r\n        this.formService.insertFormArrayGroup(index, formArray, formArrayModel);\r\n        this.changeDetectorRef.detectChanges();\r\n    }\r\n\r\n    cloneFormArrayGroup(index: number, formArray: FormArray, formArrayModel: DynamicFormArrayModel): void {\r\n        this.formService.cloneFormArrayGroup(index, formArray, formArrayModel);\r\n        this.changeDetectorRef.detectChanges();\r\n    }\r\n\r\n    removeFormArrayGroup(index: number, formArray: FormArray, formArrayModel: DynamicFormArrayModel): void {\r\n        this.formService.removeFormArrayGroup(index, formArray, formArrayModel);\r\n        this.changeDetectorRef.detectChanges();\r\n    }\r\n\r\n    moveFormArrayGroup(index: number, step: number, formArray: FormArray, formArrayModel: DynamicFormArrayModel): void {\r\n        this.formService.moveFormArrayGroup(index, step, formArray, formArrayModel);\r\n        this.changeDetectorRef.detectChanges();\r\n    }\r\n\r\n    clearFormArray(formArray: FormArray, formArrayModel: DynamicFormArrayModel): void {\r\n        this.formService.clearFormArray(formArray, formArrayModel);\r\n        this.changeDetectorRef.detectChanges();\r\n    }\r\n\r\n    getClass(model?: DynamicFormControlModel): string {\r\n        const parts = collectPathAble(model, p => p.id);\r\n        if (parts.length == 0) return \"\";\r\n        if (model instanceof DynamicFormGroupModel) {\r\n            return `form-group-${parts.join(\"-\")}`;\r\n        }\r\n        return `form-control-${parts.join(\"-\")}`;\r\n    }\r\n\r\n    validate(showErrors: boolean = true): Promise<any> {\r\n        if (!this.group) return Promise.resolve();\r\n        return new Promise<any>((resolve, reject) => {\r\n            this.group.statusChanges.pipe(first(status => status == \"VALID\" || status == \"INVALID\")).subscribe(status => {\r\n                if (showErrors) {\r\n                    this.formService.showErrors(this);\r\n                }\r\n                if (status == \"VALID\") {\r\n                    resolve(null);\r\n                    return;\r\n                }\r\n                reject(null);\r\n            });\r\n            this.group.updateValueAndValidity();\r\n        });\r\n    }\r\n\r\n    async serialize(validate?: boolean): Promise<any> {\r\n        if (!this.group) return null;\r\n        if (validate) {\r\n            await this.validate();\r\n        }\r\n        return await this.formService.serialize(this.model, this.group);\r\n    }\r\n}\r\n"]}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component } from "@angular/core";
|
|
2
|
+
import { BehaviorSubject } from "rxjs";
|
|
3
|
+
import { DynamicBaseFormControlComponent } from "./dynamic-base-form-control.component";
|
|
4
|
+
import { replaceSpecialChars } from "../../utils/misc";
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
export class DynamicBaseSelectComponent extends DynamicBaseFormControlComponent {
|
|
7
|
+
ngOnInit() {
|
|
8
|
+
this.groups$ = new BehaviorSubject([]);
|
|
9
|
+
this.subscription = this.model.options$.subscribe(options => {
|
|
10
|
+
const groupBy = this.model.inline || !this.model.multiple ? this.model.groupBy : null;
|
|
11
|
+
const groups = options.reduce((res, option) => {
|
|
12
|
+
const key = replaceSpecialChars(groupBy ? option.props[this.model.groupBy] || "default" : "default", "-");
|
|
13
|
+
res[key] = res[key] || [];
|
|
14
|
+
res[key].push(option);
|
|
15
|
+
return res;
|
|
16
|
+
}, {});
|
|
17
|
+
this.groups$.next(Object.keys(groups).map(group => {
|
|
18
|
+
return {
|
|
19
|
+
group,
|
|
20
|
+
options: groups[group]
|
|
21
|
+
};
|
|
22
|
+
}));
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
ngOnDestroy() {
|
|
26
|
+
if (this.subscription)
|
|
27
|
+
this.subscription.unsubscribe();
|
|
28
|
+
}
|
|
29
|
+
isSelected(option) {
|
|
30
|
+
if (this.model.multiple) {
|
|
31
|
+
return this.control.value?.indexOf(option.value) >= 0;
|
|
32
|
+
}
|
|
33
|
+
return this.control.value == option.value;
|
|
34
|
+
}
|
|
35
|
+
selectToggle(option, state) {
|
|
36
|
+
if (this.model.multiple) {
|
|
37
|
+
const value = Array.from(this.control.value || []);
|
|
38
|
+
const index = value.indexOf(option.value);
|
|
39
|
+
if (index >= 0) {
|
|
40
|
+
value.splice(index, 1);
|
|
41
|
+
}
|
|
42
|
+
if (state) {
|
|
43
|
+
value.push(option.value);
|
|
44
|
+
}
|
|
45
|
+
this.control.setValue(value);
|
|
46
|
+
this.onChange(value);
|
|
47
|
+
return;
|
|
48
|
+
}
|
|
49
|
+
this.control.setValue(option.value);
|
|
50
|
+
this.onChange(option.value);
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
DynamicBaseSelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: DynamicBaseSelectComponent, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
54
|
+
DynamicBaseSelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.8", type: DynamicBaseSelectComponent, selector: "dynamic-base-select", usesInheritance: true, ngImport: i0, template: "", isInline: true, changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
55
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: DynamicBaseSelectComponent, decorators: [{
|
|
56
|
+
type: Component,
|
|
57
|
+
args: [{
|
|
58
|
+
selector: "dynamic-base-select",
|
|
59
|
+
template: "",
|
|
60
|
+
changeDetection: ChangeDetectionStrategy.OnPush
|
|
61
|
+
}]
|
|
62
|
+
}] });
|
|
63
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHluYW1pYy1iYXNlLXNlbGVjdC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbmd4LWR5bmFtaWMtZm9ybS9jb21wb25lbnRzL2Jhc2UvZHluYW1pYy1iYXNlLXNlbGVjdC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFDLHVCQUF1QixFQUFFLFNBQVMsRUFBb0IsTUFBTSxlQUFlLENBQUM7QUFDcEYsT0FBTyxFQUFDLGVBQWUsRUFBZSxNQUFNLE1BQU0sQ0FBQztBQUNuRCxPQUFPLEVBQUMsK0JBQStCLEVBQUMsTUFBTSx1Q0FBdUMsQ0FBQztBQUV0RixPQUFPLEVBQUMsbUJBQW1CLEVBQUMsTUFBTSxrQkFBa0IsQ0FBQzs7QUFPckQsTUFBTSxPQUFPLDBCQUEyQixTQUFRLCtCQUF3RDtJQU1wRyxRQUFRO1FBQ0osSUFBSSxDQUFDLE9BQU8sR0FBRyxJQUFJLGVBQWUsQ0FBZ0MsRUFBRSxDQUFDLENBQUM7UUFDdEUsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLEVBQUU7WUFDeEQsTUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLElBQUksQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQztZQUN0RixNQUFNLE1BQU0sR0FBRyxPQUFPLENBQUMsTUFBTSxDQUFDLENBQUMsR0FBRyxFQUFFLE1BQU0sRUFBRSxFQUFFO2dCQUMxQyxNQUFNLEdBQUcsR0FBRyxtQkFBbUIsQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsSUFBSSxTQUFTLENBQUMsQ0FBQyxDQUFDLFNBQVMsRUFBRSxHQUFHLENBQUMsQ0FBQztnQkFDMUcsR0FBRyxDQUFDLEdBQUcsQ0FBQyxHQUFHLEdBQUcsQ0FBQyxHQUFHLENBQUMsSUFBSSxFQUFFLENBQUM7Z0JBQzFCLEdBQUcsQ0FBQyxHQUFHLENBQUMsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7Z0JBQ3RCLE9BQU8sR0FBRyxDQUFDO1lBQ2YsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDO1lBQ1AsSUFBSSxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDLEVBQUU7Z0JBQzlDLE9BQU87b0JBQ0gsS0FBSztvQkFDTCxPQUFPLEVBQUUsTUFBTSxDQUFDLEtBQUssQ0FBQztpQkFDekIsQ0FBQztZQUNOLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDUixDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7SUFFRCxXQUFXO1FBQ1AsSUFBSSxJQUFJLENBQUMsWUFBWTtZQUNqQixJQUFJLENBQUMsWUFBWSxDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQ3hDLENBQUM7SUFFRCxVQUFVLENBQUMsTUFBOEI7UUFDckMsSUFBSSxJQUFJLENBQUMsS0FBSyxDQUFDLFFBQVEsRUFBRTtZQUNyQixPQUFPLElBQUksQ0FBQyxPQUFPLENBQUMsS0FBSyxFQUFFLE9BQU8sQ0FBQyxNQUFNLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxDQUFDO1NBQ3pEO1FBQ0QsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLEtBQUssSUFBSSxNQUFNLENBQUMsS0FBSyxDQUFDO0lBQzlDLENBQUM7SUFFRCxZQUFZLENBQUMsTUFBOEIsRUFBRSxLQUFjO1FBQ3ZELElBQUksSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLEVBQUU7WUFDckIsTUFBTSxLQUFLLEdBQUcsS0FBSyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsT0FBTyxDQUFDLEtBQUssSUFBSSxFQUFFLENBQUMsQ0FBQztZQUNuRCxNQUFNLEtBQUssR0FBRyxLQUFLLENBQUMsT0FBTyxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQztZQUMxQyxJQUFJLEtBQUssSUFBSSxDQUFDLEVBQUU7Z0JBQ1osS0FBSyxDQUFDLE1BQU0sQ0FBQyxLQUFLLEVBQUUsQ0FBQyxDQUFDLENBQUM7YUFDMUI7WUFDRCxJQUFJLEtBQUssRUFBRTtnQkFDUCxLQUFLLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQzthQUM1QjtZQUNELElBQUksQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQzdCLElBQUksQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDckIsT0FBTztTQUNWO1FBQ0QsSUFBSSxDQUFDLE9BQU8sQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ3BDLElBQUksQ0FBQyxRQUFRLENBQUMsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ2hDLENBQUM7O3VIQXJEUSwwQkFBMEI7MkdBQTFCLDBCQUEwQixrRkFIekIsRUFBRTsyRkFHSCwwQkFBMEI7a0JBTHRDLFNBQVM7bUJBQUM7b0JBQ1AsUUFBUSxFQUFFLHFCQUFxQjtvQkFDL0IsUUFBUSxFQUFFLEVBQUU7b0JBQ1osZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07aUJBQ2xEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ29tcG9uZW50LCBPbkRlc3Ryb3ksIE9uSW5pdH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuaW1wb3J0IHtCZWhhdmlvclN1YmplY3QsIFN1YnNjcmlwdGlvbn0gZnJvbSBcInJ4anNcIjtcclxuaW1wb3J0IHtEeW5hbWljQmFzZUZvcm1Db250cm9sQ29tcG9uZW50fSBmcm9tIFwiLi9keW5hbWljLWJhc2UtZm9ybS1jb250cm9sLmNvbXBvbmVudFwiO1xyXG5pbXBvcnQge0R5bmFtaWNGb3JtT3B0aW9uLCBEeW5hbWljRm9ybU9wdGlvbkdyb3VwLCBEeW5hbWljU2VsZWN0TW9kZWx9IGZyb20gXCIuLi8uLi91dGlscy9keW5hbWljLXNlbGVjdC5tb2RlbFwiO1xyXG5pbXBvcnQge3JlcGxhY2VTcGVjaWFsQ2hhcnN9IGZyb20gXCIuLi8uLi91dGlscy9taXNjXCI7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICAgIHNlbGVjdG9yOiBcImR5bmFtaWMtYmFzZS1zZWxlY3RcIixcclxuICAgIHRlbXBsYXRlOiBcIlwiLFxyXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcclxufSlcclxuZXhwb3J0IGNsYXNzIER5bmFtaWNCYXNlU2VsZWN0Q29tcG9uZW50IGV4dGVuZHMgRHluYW1pY0Jhc2VGb3JtQ29udHJvbENvbXBvbmVudDxEeW5hbWljU2VsZWN0TW9kZWw8YW55Pj4gaW1wbGVtZW50cyBPbkluaXQsIE9uRGVzdHJveSB7XHJcblxyXG4gICAgZ3JvdXBzJDogQmVoYXZpb3JTdWJqZWN0PER5bmFtaWNGb3JtT3B0aW9uR3JvdXA8YW55PltdPjtcclxuXHJcbiAgICBwcm90ZWN0ZWQgc3Vic2NyaXB0aW9uOiBTdWJzY3JpcHRpb247XHJcblxyXG4gICAgbmdPbkluaXQoKTogdm9pZCB7XHJcbiAgICAgICAgdGhpcy5ncm91cHMkID0gbmV3IEJlaGF2aW9yU3ViamVjdDxEeW5hbWljRm9ybU9wdGlvbkdyb3VwPGFueT5bXT4oW10pO1xyXG4gICAgICAgIHRoaXMuc3Vic2NyaXB0aW9uID0gdGhpcy5tb2RlbC5vcHRpb25zJC5zdWJzY3JpYmUob3B0aW9ucyA9PiB7XHJcbiAgICAgICAgICAgIGNvbnN0IGdyb3VwQnkgPSB0aGlzLm1vZGVsLmlubGluZSB8fCAhdGhpcy5tb2RlbC5tdWx0aXBsZSA/IHRoaXMubW9kZWwuZ3JvdXBCeSA6IG51bGw7XHJcbiAgICAgICAgICAgIGNvbnN0IGdyb3VwcyA9IG9wdGlvbnMucmVkdWNlKChyZXMsIG9wdGlvbikgPT4ge1xyXG4gICAgICAgICAgICAgICAgY29uc3Qga2V5ID0gcmVwbGFjZVNwZWNpYWxDaGFycyhncm91cEJ5ID8gb3B0aW9uLnByb3BzW3RoaXMubW9kZWwuZ3JvdXBCeV0gfHwgXCJkZWZhdWx0XCIgOiBcImRlZmF1bHRcIiwgXCItXCIpO1xyXG4gICAgICAgICAgICAgICAgcmVzW2tleV0gPSByZXNba2V5XSB8fCBbXTtcclxuICAgICAgICAgICAgICAgIHJlc1trZXldLnB1c2gob3B0aW9uKTtcclxuICAgICAgICAgICAgICAgIHJldHVybiByZXM7XHJcbiAgICAgICAgICAgIH0sIHt9KTtcclxuICAgICAgICAgICAgdGhpcy5ncm91cHMkLm5leHQoT2JqZWN0LmtleXMoZ3JvdXBzKS5tYXAoZ3JvdXAgPT4ge1xyXG4gICAgICAgICAgICAgICAgcmV0dXJuIHtcclxuICAgICAgICAgICAgICAgICAgICBncm91cCxcclxuICAgICAgICAgICAgICAgICAgICBvcHRpb25zOiBncm91cHNbZ3JvdXBdXHJcbiAgICAgICAgICAgICAgICB9O1xyXG4gICAgICAgICAgICB9KSk7XHJcbiAgICAgICAgfSk7XHJcbiAgICB9XHJcblxyXG4gICAgbmdPbkRlc3Ryb3koKTogdm9pZCB7XHJcbiAgICAgICAgaWYgKHRoaXMuc3Vic2NyaXB0aW9uKVxyXG4gICAgICAgICAgICB0aGlzLnN1YnNjcmlwdGlvbi51bnN1YnNjcmliZSgpO1xyXG4gICAgfVxyXG5cclxuICAgIGlzU2VsZWN0ZWQob3B0aW9uOiBEeW5hbWljRm9ybU9wdGlvbjxhbnk+KTogYm9vbGVhbiB7XHJcbiAgICAgICAgaWYgKHRoaXMubW9kZWwubXVsdGlwbGUpIHtcclxuICAgICAgICAgICAgcmV0dXJuIHRoaXMuY29udHJvbC52YWx1ZT8uaW5kZXhPZihvcHRpb24udmFsdWUpID49IDA7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIHJldHVybiB0aGlzLmNvbnRyb2wudmFsdWUgPT0gb3B0aW9uLnZhbHVlO1xyXG4gICAgfVxyXG5cclxuICAgIHNlbGVjdFRvZ2dsZShvcHRpb246IER5bmFtaWNGb3JtT3B0aW9uPGFueT4sIHN0YXRlOiBib29sZWFuKTogdm9pZCB7XHJcbiAgICAgICAgaWYgKHRoaXMubW9kZWwubXVsdGlwbGUpIHtcclxuICAgICAgICAgICAgY29uc3QgdmFsdWUgPSBBcnJheS5mcm9tKHRoaXMuY29udHJvbC52YWx1ZSB8fCBbXSk7XHJcbiAgICAgICAgICAgIGNvbnN0IGluZGV4ID0gdmFsdWUuaW5kZXhPZihvcHRpb24udmFsdWUpO1xyXG4gICAgICAgICAgICBpZiAoaW5kZXggPj0gMCkge1xyXG4gICAgICAgICAgICAgICAgdmFsdWUuc3BsaWNlKGluZGV4LCAxKTtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICBpZiAoc3RhdGUpIHtcclxuICAgICAgICAgICAgICAgIHZhbHVlLnB1c2gob3B0aW9uLnZhbHVlKTtcclxuICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICB0aGlzLmNvbnRyb2wuc2V0VmFsdWUodmFsdWUpO1xyXG4gICAgICAgICAgICB0aGlzLm9uQ2hhbmdlKHZhbHVlKTtcclxuICAgICAgICAgICAgcmV0dXJuO1xyXG4gICAgICAgIH1cclxuICAgICAgICB0aGlzLmNvbnRyb2wuc2V0VmFsdWUob3B0aW9uLnZhbHVlKTtcclxuICAgICAgICB0aGlzLm9uQ2hhbmdlKG9wdGlvbi52YWx1ZSk7XHJcbiAgICB9XHJcbn1cclxuIl19
|
|
@@ -1,14 +1,18 @@
|
|
|
1
1
|
import { AsyncSubmitDirective } from "./directives/async-submit.directive";
|
|
2
2
|
import { DynamicBaseFormComponent } from "./components/base/dynamic-base-form.component";
|
|
3
3
|
import { DynamicBaseFormArrayComponent } from "./components/base/dynamic-base-form-array.component";
|
|
4
|
+
import { DynamicBaseFormControlComponent } from "./components/base/dynamic-base-form-control.component";
|
|
4
5
|
import { DynamicBaseFormControlContainerComponent } from "./components/base/dynamic-base-form-control-container.component";
|
|
5
6
|
import { DynamicBaseFormGroupComponent } from "./components/base/dynamic-base-form-group.component";
|
|
7
|
+
import { DynamicBaseSelectComponent } from "./components/base/dynamic-base-select.component";
|
|
6
8
|
// --- Components ---
|
|
7
9
|
export const components = [
|
|
8
10
|
DynamicBaseFormComponent,
|
|
9
11
|
DynamicBaseFormArrayComponent,
|
|
12
|
+
DynamicBaseFormControlComponent,
|
|
10
13
|
DynamicBaseFormControlContainerComponent,
|
|
11
|
-
DynamicBaseFormGroupComponent
|
|
14
|
+
DynamicBaseFormGroupComponent,
|
|
15
|
+
DynamicBaseSelectComponent
|
|
12
16
|
];
|
|
13
17
|
// --- Directives ---
|
|
14
18
|
export const directives = [
|
|
@@ -19,4 +23,4 @@ export const pipes = [];
|
|
|
19
23
|
export function defaultFormControlProvider() {
|
|
20
24
|
return () => null;
|
|
21
25
|
}
|
|
22
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWR5bmFtaWMtZm9ybS5pbXBvcnRzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL25neC1keW5hbWljLWZvcm0vbmd4LWR5bmFtaWMtZm9ybS5pbXBvcnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE9BQU8sRUFBQyxvQkFBb0IsRUFBQyxNQUFNLHFDQUFxQyxDQUFDO0FBRXpFLE9BQU8sRUFBQyx3QkFBd0IsRUFBQyxNQUFNLCtDQUErQyxDQUFDO0FBQ3ZGLE9BQU8sRUFBQyw2QkFBNkIsRUFBQyxNQUFNLHFEQUFxRCxDQUFDO0FBQ2xHLE9BQU8sRUFBQywrQkFBK0IsRUFBQyxNQUFNLHVEQUF1RCxDQUFDO0FBQ3RHLE9BQU8sRUFDSCx3Q0FBd0MsRUFDM0MsTUFBTSxpRUFBaUUsQ0FBQztBQUN6RSxPQUFPLEVBQUMsNkJBQTZCLEVBQUMsTUFBTSxxREFBcUQsQ0FBQztBQUNsRyxPQUFPLEVBQUMsMEJBQTBCLEVBQUMsTUFBTSxpREFBaUQsQ0FBQztBQUUzRixxQkFBcUI7QUFDckIsTUFBTSxDQUFDLE1BQU0sVUFBVSxHQUFHO0lBQ3RCLHdCQUF3QjtJQUN4Qiw2QkFBNkI7SUFDN0IsK0JBQStCO0lBQy9CLHdDQUF3QztJQUN4Qyw2QkFBNkI7SUFDN0IsMEJBQTBCO0NBQzdCLENBQUM7QUFFRixxQkFBcUI7QUFDckIsTUFBTSxDQUFDLE1BQU0sVUFBVSxHQUFHO0lBQ3RCLG9CQUFvQjtDQUN2QixDQUFDO0FBRUYsZ0JBQWdCO0FBQ2hCLE1BQU0sQ0FBQyxNQUFNLEtBQUssR0FBRyxFQUFFLENBQUM7QUFFeEIsTUFBTSxVQUFVLDBCQUEwQjtJQUN0QyxPQUFPLEdBQUcsRUFBRSxDQUFDLElBQUksQ0FBQztBQUN0QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtEeW5hbWljRm9ybUNvbnRyb2xNYXBGbn0gZnJvbSBcIkBuZy1keW5hbWljLWZvcm1zL2NvcmVcIjtcclxuXHJcbmltcG9ydCB7QXN5bmNTdWJtaXREaXJlY3RpdmV9IGZyb20gXCIuL2RpcmVjdGl2ZXMvYXN5bmMtc3VibWl0LmRpcmVjdGl2ZVwiO1xyXG5cclxuaW1wb3J0IHtEeW5hbWljQmFzZUZvcm1Db21wb25lbnR9IGZyb20gXCIuL2NvbXBvbmVudHMvYmFzZS9keW5hbWljLWJhc2UtZm9ybS5jb21wb25lbnRcIjtcclxuaW1wb3J0IHtEeW5hbWljQmFzZUZvcm1BcnJheUNvbXBvbmVudH0gZnJvbSBcIi4vY29tcG9uZW50cy9iYXNlL2R5bmFtaWMtYmFzZS1mb3JtLWFycmF5LmNvbXBvbmVudFwiO1xyXG5pbXBvcnQge0R5bmFtaWNCYXNlRm9ybUNvbnRyb2xDb21wb25lbnR9IGZyb20gXCIuL2NvbXBvbmVudHMvYmFzZS9keW5hbWljLWJhc2UtZm9ybS1jb250cm9sLmNvbXBvbmVudFwiO1xyXG5pbXBvcnQge1xyXG4gICAgRHluYW1pY0Jhc2VGb3JtQ29udHJvbENvbnRhaW5lckNvbXBvbmVudFxyXG59IGZyb20gXCIuL2NvbXBvbmVudHMvYmFzZS9keW5hbWljLWJhc2UtZm9ybS1jb250cm9sLWNvbnRhaW5lci5jb21wb25lbnRcIjtcclxuaW1wb3J0IHtEeW5hbWljQmFzZUZvcm1Hcm91cENvbXBvbmVudH0gZnJvbSBcIi4vY29tcG9uZW50cy9iYXNlL2R5bmFtaWMtYmFzZS1mb3JtLWdyb3VwLmNvbXBvbmVudFwiO1xyXG5pbXBvcnQge0R5bmFtaWNCYXNlU2VsZWN0Q29tcG9uZW50fSBmcm9tIFwiLi9jb21wb25lbnRzL2Jhc2UvZHluYW1pYy1iYXNlLXNlbGVjdC5jb21wb25lbnRcIjtcclxuXHJcbi8vIC0tLSBDb21wb25lbnRzIC0tLVxyXG5leHBvcnQgY29uc3QgY29tcG9uZW50cyA9IFtcclxuICAgIER5bmFtaWNCYXNlRm9ybUNvbXBvbmVudCxcclxuICAgIER5bmFtaWNCYXNlRm9ybUFycmF5Q29tcG9uZW50LFxyXG4gICAgRHluYW1pY0Jhc2VGb3JtQ29udHJvbENvbXBvbmVudCxcclxuICAgIER5bmFtaWNCYXNlRm9ybUNvbnRyb2xDb250YWluZXJDb21wb25lbnQsXHJcbiAgICBEeW5hbWljQmFzZUZvcm1Hcm91cENvbXBvbmVudCxcclxuICAgIER5bmFtaWNCYXNlU2VsZWN0Q29tcG9uZW50XHJcbl07XHJcblxyXG4vLyAtLS0gRGlyZWN0aXZlcyAtLS1cclxuZXhwb3J0IGNvbnN0IGRpcmVjdGl2ZXMgPSBbXHJcbiAgICBBc3luY1N1Ym1pdERpcmVjdGl2ZSxcclxuXTtcclxuXHJcbi8vIC0tLSBQaXBlcyAtLS1cclxuZXhwb3J0IGNvbnN0IHBpcGVzID0gW107XHJcblxyXG5leHBvcnQgZnVuY3Rpb24gZGVmYXVsdEZvcm1Db250cm9sUHJvdmlkZXIoKTogRHluYW1pY0Zvcm1Db250cm9sTWFwRm4ge1xyXG4gICAgcmV0dXJuICgpID0+IG51bGw7XHJcbn1cclxuIl19
|
|
@@ -9,9 +9,11 @@ import { components, defaultFormControlProvider, directives, pipes } from "./ngx
|
|
|
9
9
|
import * as i0 from "@angular/core";
|
|
10
10
|
import * as i1 from "./components/base/dynamic-base-form.component";
|
|
11
11
|
import * as i2 from "./components/base/dynamic-base-form-array.component";
|
|
12
|
-
import * as i3 from "./components/base/dynamic-base-form-control
|
|
13
|
-
import * as i4 from "./components/base/dynamic-base-form-
|
|
14
|
-
import * as i5 from "./
|
|
12
|
+
import * as i3 from "./components/base/dynamic-base-form-control.component";
|
|
13
|
+
import * as i4 from "./components/base/dynamic-base-form-control-container.component";
|
|
14
|
+
import * as i5 from "./components/base/dynamic-base-form-group.component";
|
|
15
|
+
import * as i6 from "./components/base/dynamic-base-select.component";
|
|
16
|
+
import * as i7 from "./directives/async-submit.directive";
|
|
15
17
|
export class NgxDynamicFormModule {
|
|
16
18
|
static forRoot(config) {
|
|
17
19
|
return {
|
|
@@ -32,10 +34,10 @@ export class NgxDynamicFormModule {
|
|
|
32
34
|
}
|
|
33
35
|
}
|
|
34
36
|
NgxDynamicFormModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: NgxDynamicFormModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
35
|
-
NgxDynamicFormModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: NgxDynamicFormModule, declarations: [i1.DynamicBaseFormComponent, i2.DynamicBaseFormArrayComponent, i3.
|
|
37
|
+
NgxDynamicFormModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: NgxDynamicFormModule, declarations: [i1.DynamicBaseFormComponent, i2.DynamicBaseFormArrayComponent, i3.DynamicBaseFormControlComponent, i4.DynamicBaseFormControlContainerComponent, i5.DynamicBaseFormGroupComponent, i6.DynamicBaseSelectComponent, i7.AsyncSubmitDirective], imports: [CommonModule,
|
|
36
38
|
FormsModule,
|
|
37
39
|
ReactiveFormsModule,
|
|
38
|
-
NgxUtilsModule], exports: [i1.DynamicBaseFormComponent, i2.DynamicBaseFormArrayComponent, i3.
|
|
40
|
+
NgxUtilsModule], exports: [i1.DynamicBaseFormComponent, i2.DynamicBaseFormArrayComponent, i3.DynamicBaseFormControlComponent, i4.DynamicBaseFormControlContainerComponent, i5.DynamicBaseFormGroupComponent, i6.DynamicBaseSelectComponent, i7.AsyncSubmitDirective, FormsModule,
|
|
39
41
|
ReactiveFormsModule,
|
|
40
42
|
NgxUtilsModule] });
|
|
41
43
|
NgxDynamicFormModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.8", ngImport: i0, type: NgxDynamicFormModule, providers: [
|
|
@@ -112,4 +114,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
|
|
|
112
114
|
]
|
|
113
115
|
}]
|
|
114
116
|
}] });
|
|
115
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
117
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-dynamic-form.module.js","sourceRoot":"","sources":["../../../src/ngx-dynamic-form/ngx-dynamic-form.module.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,QAAQ,EAAuB,QAAQ,EAAC,MAAM,eAAe,CAAC;AACtE,OAAO,EAAC,YAAY,EAAC,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EAAC,WAAW,EAAE,aAAa,EAAE,mBAAmB,EAAC,MAAM,gBAAgB,CAAC;AAC/E,OAAO,EACH,2BAA2B,EAC3B,kBAAkB,EAClB,kBAAkB,IAAI,sBAAsB,EAG/C,MAAM,wBAAwB,CAAC;AAChC,OAAO,EAAC,cAAc,EAAC,MAAM,kBAAkB,CAAC;AAEhD,OAAO,EACH,sBAAsB,EACtB,qBAAqB,EACrB,sBAAsB,EACtB,qBAAqB,EACrB,YAAY,EACZ,aAAa,EACb,2BAA2B,EAC9B,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAC,kBAAkB,EAAC,MAAM,iCAAiC,CAAC;AACnE,OAAO,EAAC,UAAU,EAAE,0BAA0B,EAAE,UAAU,EAAE,KAAK,EAAC,MAAM,4BAA4B,CAAC;;;;;;;;;AA8CrG,MAAM,OAAO,oBAAoB;IAE7B,MAAM,CAAC,OAAO,CAAC,MAAiC;QAC5C,OAAO;YACH,QAAQ,EAAE,oBAAoB;YAC9B,SAAS,EAAE;gBACP,kBAAkB;gBAClB;oBACI,OAAO,EAAE,sBAAsB;oBAC/B,WAAW,EAAE,kBAAkB;iBAClC;gBACD;oBACI,OAAO,EAAE,2BAA2B;oBACpC,UAAU,EAAE,CAAC,MAAM,EAAE,eAAe,IAAI,0BAA0B,CAAC;oBACnE,IAAI,EAAE,CAAC,QAAQ,CAAC;iBACnB;aACJ;SACJ,CAAA;IACL,CAAC;;iHAlBQ,oBAAoB;kHAApB,oBAAoB,sQApCzB,YAAY;QACZ,WAAW;QACX,mBAAmB;QACnB,cAAc,uPAMd,WAAW;QACX,mBAAmB;QACnB,cAAc;kHAyBT,oBAAoB,aAtBlB;QACP,GAAG,KAAK;QACR,EAAC,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,YAAY,EAAE,KAAK,EAAE,IAAI,EAAC;QAC7D,EAAC,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,2BAA2B,EAAE,KAAK,EAAE,IAAI,EAAC;QAC5E,EAAC,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,sBAAsB,EAAE,KAAK,EAAE,IAAI,EAAC;QACvE,EAAC,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,sBAAsB,EAAE,KAAK,EAAE,IAAI,EAAC;QACvE,EAAC,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,qBAAqB,EAAE,KAAK,EAAE,IAAI,EAAC;QACtE,EAAC,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,qBAAqB,EAAE,KAAK,EAAE,IAAI,EAAC;QACtE;YACI,OAAO,EAAE,kBAAkB;YAC3B,QAAQ,EAAE,IAAI,GAAG,CAAuC;gBACpD,CAAC,MAAM,EAAE,YAAY,CAAC;gBACtB,CAAC,qBAAqB,EAAE,2BAA2B,CAAC;gBACpD,CAAC,OAAO,EAAE,aAAa,CAAC;gBACxB,CAAC,gBAAgB,EAAE,sBAAsB,CAAC;gBAC1C,CAAC,gBAAgB,EAAE,sBAAsB,CAAC;gBAC1C,CAAC,eAAe,EAAE,qBAAqB,CAAC;gBACxC,CAAC,eAAe,EAAE,qBAAqB,CAAC;aAC3C,CAAC;SACL;KACJ,YAnCQ;YACL,YAAY;YACZ,WAAW;YACX,mBAAmB;YACnB,cAAc;SACjB,EAKG,WAAW;QACX,mBAAmB;QACnB,cAAc;2FAyBT,oBAAoB;kBA3ChC,QAAQ;mBAAC;oBACN,YAAY,EAAE;wBACV,GAAG,UAAU;wBACb,GAAG,UAAU;wBACb,GAAG,KAAK;qBACX;oBACD,OAAO,EAAE;wBACL,YAAY;wBACZ,WAAW;wBACX,mBAAmB;wBACnB,cAAc;qBACjB;oBACD,OAAO,EAAE;wBACL,GAAG,UAAU;wBACb,GAAG,UAAU;wBACb,GAAG,KAAK;wBACR,WAAW;wBACX,mBAAmB;wBACnB,cAAc;qBACjB;oBACD,eAAe,EAAE,UAAU;oBAC3B,SAAS,EAAE;wBACP,GAAG,KAAK;wBACR,EAAC,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,YAAY,EAAE,KAAK,EAAE,IAAI,EAAC;wBAC7D,EAAC,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,2BAA2B,EAAE,KAAK,EAAE,IAAI,EAAC;wBAC5E,EAAC,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,sBAAsB,EAAE,KAAK,EAAE,IAAI,EAAC;wBACvE,EAAC,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,sBAAsB,EAAE,KAAK,EAAE,IAAI,EAAC;wBACvE,EAAC,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,qBAAqB,EAAE,KAAK,EAAE,IAAI,EAAC;wBACtE,EAAC,OAAO,EAAE,aAAa,EAAE,QAAQ,EAAE,qBAAqB,EAAE,KAAK,EAAE,IAAI,EAAC;wBACtE;4BACI,OAAO,EAAE,kBAAkB;4BAC3B,QAAQ,EAAE,IAAI,GAAG,CAAuC;gCACpD,CAAC,MAAM,EAAE,YAAY,CAAC;gCACtB,CAAC,qBAAqB,EAAE,2BAA2B,CAAC;gCACpD,CAAC,OAAO,EAAE,aAAa,CAAC;gCACxB,CAAC,gBAAgB,EAAE,sBAAsB,CAAC;gCAC1C,CAAC,gBAAgB,EAAE,sBAAsB,CAAC;gCAC1C,CAAC,eAAe,EAAE,qBAAqB,CAAC;gCACxC,CAAC,eAAe,EAAE,qBAAqB,CAAC;6BAC3C,CAAC;yBACL;qBACJ;iBACJ","sourcesContent":["import {Injector, ModuleWithProviders, NgModule} from \"@angular/core\";\r\nimport {CommonModule} from \"@angular/common\";\r\nimport {FormsModule, NG_VALIDATORS, ReactiveFormsModule} from \"@angular/forms\";\r\nimport {\r\n    DYNAMIC_FORM_CONTROL_MAP_FN,\r\n    DYNAMIC_VALIDATORS,\r\n    DynamicFormService as BaseDynamicFormService,\r\n    Validator,\r\n    ValidatorFactory\r\n} from \"@ng-dynamic-forms/core\";\r\nimport {NgxUtilsModule} from \"@stemy/ngx-utils\";\r\n\r\nimport {\r\n    validateItemsMaxLength,\r\n    validateItemsMaxValue,\r\n    validateItemsMinLength,\r\n    validateItemsMinValue,\r\n    validateJSON,\r\n    validatePhone,\r\n    validateRequiredTranslation\r\n} from \"./utils/validators\";\r\nimport {DynamicFormService} from \"./services/dynamic-form.service\";\r\nimport {components, defaultFormControlProvider, directives, pipes} from \"./ngx-dynamic-form.imports\";\r\nimport {IDynamicFormModuleConfig} from \"./common-types\";\r\n\r\n@NgModule({\r\n    declarations: [\r\n        ...components,\r\n        ...directives,\r\n        ...pipes\r\n    ],\r\n    imports: [\r\n        CommonModule,\r\n        FormsModule,\r\n        ReactiveFormsModule,\r\n        NgxUtilsModule\r\n    ],\r\n    exports: [\r\n        ...components,\r\n        ...directives,\r\n        ...pipes,\r\n        FormsModule,\r\n        ReactiveFormsModule,\r\n        NgxUtilsModule\r\n    ],\r\n    entryComponents: components,\r\n    providers: [\r\n        ...pipes,\r\n        {provide: NG_VALIDATORS, useValue: validateJSON, multi: true},\r\n        {provide: NG_VALIDATORS, useValue: validateRequiredTranslation, multi: true},\r\n        {provide: NG_VALIDATORS, useValue: validateItemsMinLength, multi: true},\r\n        {provide: NG_VALIDATORS, useValue: validateItemsMaxLength, multi: true},\r\n        {provide: NG_VALIDATORS, useValue: validateItemsMinValue, multi: true},\r\n        {provide: NG_VALIDATORS, useValue: validateItemsMaxValue, multi: true},\r\n        {\r\n            provide: DYNAMIC_VALIDATORS,\r\n            useValue: new Map<string, Validator | ValidatorFactory>([\r\n                [\"json\", validateJSON],\r\n                [\"requiredTranslation\", validateRequiredTranslation],\r\n                [\"phone\", validatePhone],\r\n                [\"itemsMinLength\", validateItemsMinLength],\r\n                [\"itemsMaxLength\", validateItemsMaxLength],\r\n                [\"itemsMinValue\", validateItemsMinValue],\r\n                [\"itemsMaxValue\", validateItemsMaxValue],\r\n            ])\r\n        }\r\n    ]\r\n})\r\nexport class NgxDynamicFormModule {\r\n\r\n    static forRoot(config?: IDynamicFormModuleConfig): ModuleWithProviders<NgxDynamicFormModule> {\r\n        return {\r\n            ngModule: NgxDynamicFormModule,\r\n            providers: [\r\n                DynamicFormService,\r\n                {\r\n                    provide: BaseDynamicFormService,\r\n                    useExisting: DynamicFormService\r\n                },\r\n                {\r\n                    provide: DYNAMIC_FORM_CONTROL_MAP_FN,\r\n                    useFactory: (config?.controlProvider || defaultFormControlProvider),\r\n                    deps: [Injector]\r\n                }\r\n            ]\r\n        }\r\n    }\r\n}\r\n"]}
|