@stemy/ngx-dynamic-form 13.1.20 → 13.2.0
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 +2 -97
- package/esm2020/ngx-dynamic-form/components/base/dynamic-base-form-array.component.mjs +1 -1
- package/esm2020/ngx-dynamic-form/components/base/dynamic-base-form-control.component.mjs +2 -2
- package/esm2020/ngx-dynamic-form/components/base/dynamic-base-form.component.mjs +3 -2
- package/esm2020/ngx-dynamic-form/ngx-dynamic-form.module.mjs +1 -2
- package/esm2020/ngx-dynamic-form/utils/creators.mjs +66 -0
- package/esm2020/ngx-dynamic-form/utils/dynamic-select.model.mjs +3 -2
- package/esm2020/public_api.mjs +2 -2
- package/fesm2015/stemy-ngx-dynamic-form.mjs +172 -208
- package/fesm2015/stemy-ngx-dynamic-form.mjs.map +1 -1
- package/fesm2020/stemy-ngx-dynamic-form.mjs +171 -207
- package/fesm2020/stemy-ngx-dynamic-form.mjs.map +1 -1
- package/ngx-dynamic-form/common-types.d.ts +3 -19
- package/ngx-dynamic-form/utils/creators.d.ts +14 -0
- package/package.json +1 -1
- package/public_api.d.ts +2 -1
|
@@ -1,97 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
export function defaultSerializer(id, parent) {
|
|
4
|
-
const control = parent.get(id);
|
|
5
|
-
return !control ? null : control.value;
|
|
6
|
-
}
|
|
7
|
-
export function FormSerializable(serializer) {
|
|
8
|
-
return (target, propertyKey) => {
|
|
9
|
-
ReflectUtils.defineMetadata("dynamicFormSerializer", serializer || defaultSerializer, target, propertyKey);
|
|
10
|
-
};
|
|
11
|
-
}
|
|
12
|
-
export function FormInput(data) {
|
|
13
|
-
return (target, propertyKey) => {
|
|
14
|
-
const meta = ReflectUtils.getOwnMetadata("design:type", target, propertyKey);
|
|
15
|
-
const type = meta ? meta.name : "";
|
|
16
|
-
let inputType = propertyKey.indexOf("password") < 0 ? "text" : "password";
|
|
17
|
-
switch (type) {
|
|
18
|
-
case "Number":
|
|
19
|
-
inputType = "number";
|
|
20
|
-
break;
|
|
21
|
-
case "Boolean":
|
|
22
|
-
inputType = "checkbox";
|
|
23
|
-
break;
|
|
24
|
-
}
|
|
25
|
-
defineFormControl(target, propertyKey, createFormInput(propertyKey, data, inputType));
|
|
26
|
-
};
|
|
27
|
-
}
|
|
28
|
-
export function FormSelect(data) {
|
|
29
|
-
return (target, propertyKey) => {
|
|
30
|
-
defineFormControl(target, propertyKey, createFormSelect(propertyKey, data));
|
|
31
|
-
};
|
|
32
|
-
}
|
|
33
|
-
export function FormStatic(data) {
|
|
34
|
-
return (target, propertyKey) => {
|
|
35
|
-
defineFormControl(target, propertyKey, createFormStatic(propertyKey, data));
|
|
36
|
-
};
|
|
37
|
-
}
|
|
38
|
-
export function FormModel(data) {
|
|
39
|
-
return (target, propertyKey) => {
|
|
40
|
-
defineFormControl(target, propertyKey, createFormModel(propertyKey, data));
|
|
41
|
-
};
|
|
42
|
-
}
|
|
43
|
-
export function FormFile(data) {
|
|
44
|
-
return (target, propertyKey) => {
|
|
45
|
-
defineFormControl(target, propertyKey, createFormFile(propertyKey, data));
|
|
46
|
-
};
|
|
47
|
-
}
|
|
48
|
-
export function defineFormControl(target, propertyKey, control) {
|
|
49
|
-
ReflectUtils.defineMetadata("dynamicFormControl", control, target, propertyKey);
|
|
50
|
-
}
|
|
51
|
-
export function getFormControl(target, propertyKey) {
|
|
52
|
-
return ReflectUtils.getMetadata("dynamicFormControl", target, propertyKey);
|
|
53
|
-
}
|
|
54
|
-
export function getFormSerializer(target, propertyKey) {
|
|
55
|
-
return ReflectUtils.getMetadata("dynamicFormSerializer", target, propertyKey);
|
|
56
|
-
}
|
|
57
|
-
export function createFormControl(id, type, config) {
|
|
58
|
-
config = config || { id };
|
|
59
|
-
config.id = id;
|
|
60
|
-
config.label = ObjectUtils.isNullOrUndefined(config.label) ? id : config.label;
|
|
61
|
-
config.disabled = config.disabled || false;
|
|
62
|
-
config.hidden = config.hidden || false;
|
|
63
|
-
return { id, type, config };
|
|
64
|
-
}
|
|
65
|
-
export function createFormInput(id, config, type = "text") {
|
|
66
|
-
const control = createFormControl(id, "input", config);
|
|
67
|
-
config = control.config;
|
|
68
|
-
config.inputType = config.inputType || type;
|
|
69
|
-
config.placeholder = config.placeholder || (config.inputType == "mask" ? "_" : "");
|
|
70
|
-
config.step = config.step || 1;
|
|
71
|
-
config.mask = config.mask || null;
|
|
72
|
-
return control;
|
|
73
|
-
}
|
|
74
|
-
export function createFormSelect(id, data) {
|
|
75
|
-
const control = createFormControl(id, "select", data);
|
|
76
|
-
data = control.config;
|
|
77
|
-
data.options = data.options || [];
|
|
78
|
-
return control;
|
|
79
|
-
}
|
|
80
|
-
export function createFormStatic(id, config) {
|
|
81
|
-
return createFormControl(id, "static", config);
|
|
82
|
-
}
|
|
83
|
-
export function createFormModel(id, data) {
|
|
84
|
-
const control = createFormControl(id, "group", data);
|
|
85
|
-
data = control.config;
|
|
86
|
-
data.name = data.name || "";
|
|
87
|
-
return control;
|
|
88
|
-
}
|
|
89
|
-
export function createFormFile(id, data) {
|
|
90
|
-
const control = createFormControl(id, "file", data);
|
|
91
|
-
data = control.config;
|
|
92
|
-
data.accept = data.accept || ["jpg", "jpeg", "png"];
|
|
93
|
-
data.multiple = data.multiple || false;
|
|
94
|
-
data.url = ObjectUtils.isString(data.url) ? data.url : "assets";
|
|
95
|
-
return control;
|
|
96
|
-
}
|
|
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 {ChangeDetectorRef, EventEmitter, Injector, Type} from \"@angular/core\";\r\nimport {AbstractControl, FormArray, FormGroup} from \"@angular/forms\";\r\nimport {\r\n    DynamicFileUploadModelConfig,\r\n    DynamicFormControl, DynamicFormControlComponent,\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\r\n    readonly group: FormGroup;\r\n\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 declare interface ModelType extends Function {\r\n    new (config: DynamicFormControlModelConfig): DynamicFormControlModel;\r\n}\r\n\r\nexport type PromiseOrNot<T> = Promise<T> | T;\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) => PromiseOrNot<DynamicFormControlModel | DynamicFormControlModel[]>;\r\nexport type FormModelCustomizerWrap = (\r\n    property: IOpenApiSchemaProperty, schema: IOpenApiSchema,\r\n    modelType: ModelType, config: DynamicFormControlModelConfig\r\n) => Promise<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 DynamicFormInitControl extends DynamicFormControl {\r\n    initialize(cdr?: ChangeDetectorRef): void;\r\n}\r\n\r\nexport declare type AsyncSubmitMethod = (form: IDynamicForm, context?: any) => Promise<IAsyncMessage>;\r\n\r\n// --- Decorator functions ---\r\n\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 type GetFormControlComponentType = (model: DynamicFormControlModel) => Type<DynamicFormControlComponent>;\r\n\r\nexport interface IDynamicFormModuleConfig {\r\n    controlProvider?: (injector: Injector) => DynamicFormControlMapFn;\r\n}\r\n"]}
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29tbW9uLXR5cGVzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL25neC1keW5hbWljLWZvcm0vY29tbW9uLXR5cGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge0NoYW5nZURldGVjdG9yUmVmLCBFdmVudEVtaXR0ZXIsIEluamVjdG9yLCBUeXBlfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQge0Fic3RyYWN0Q29udHJvbCwgRm9ybUdyb3VwfSBmcm9tIFwiQGFuZ3VsYXIvZm9ybXNcIjtcclxuaW1wb3J0IHtcclxuICAgIER5bmFtaWNGaWxlVXBsb2FkTW9kZWwsXHJcbiAgICBEeW5hbWljRmlsZVVwbG9hZE1vZGVsQ29uZmlnLFxyXG4gICAgRHluYW1pY0Zvcm1Db250cm9sLFxyXG4gICAgRHluYW1pY0Zvcm1Db250cm9sQ29tcG9uZW50LFxyXG4gICAgRHluYW1pY0Zvcm1Db250cm9sRXZlbnQsXHJcbiAgICBEeW5hbWljRm9ybUNvbnRyb2xNYXBGbixcclxuICAgIER5bmFtaWNGb3JtQ29udHJvbE1vZGVsLFxyXG4gICAgRHluYW1pY0Zvcm1Db250cm9sTW9kZWxDb25maWcsXHJcbiAgICBEeW5hbWljRm9ybUdyb3VwTW9kZWwsXHJcbiAgICBEeW5hbWljRm9ybUdyb3VwTW9kZWxDb25maWcsXHJcbiAgICBEeW5hbWljRm9ybVZhbHVlQ29udHJvbE1vZGVsLFxyXG4gICAgRHluYW1pY0lucHV0TW9kZWwsXHJcbiAgICBEeW5hbWljSW5wdXRNb2RlbENvbmZpZyxcclxuICAgIER5bmFtaWNTZWxlY3RNb2RlbENvbmZpZyxcclxuICAgIER5bmFtaWNGb3JtQ29udHJvbExheW91dCxcclxuICAgIER5bmFtaWNDaGVja2JveE1vZGVsLFxyXG4gICAgRHluYW1pY0NoZWNrYm94TW9kZWxDb25maWcsXHJcbiAgICBEeW5hbWljRGF0ZVBpY2tlck1vZGVsLFxyXG4gICAgRHluYW1pY0RhdGVDb250cm9sTW9kZWxcclxufSBmcm9tIFwiQG5nLWR5bmFtaWMtZm9ybXMvY29yZVwiO1xyXG5pbXBvcnQge0lBc3luY01lc3NhZ2UsIElPcGVuQXBpU2NoZW1hLCBJT3BlbkFwaVNjaGVtYVByb3BlcnR5LCBPYmplY3RVdGlsc30gZnJvbSBcIkBzdGVteS9uZ3gtdXRpbHNcIjtcclxuaW1wb3J0IHtEeW5hbWljU2VsZWN0TW9kZWx9IGZyb20gXCIuL3V0aWxzL2R5bmFtaWMtc2VsZWN0Lm1vZGVsXCI7XHJcbmltcG9ydCB7RHluYW1pY0VkaXRvck1vZGVsLCBEeW5hbWljRWRpdG9yTW9kZWxDb25maWd9IGZyb20gXCIuL3V0aWxzL2R5bmFtaWMtZWRpdG9yLm1vZGVsXCI7XHJcbmltcG9ydCB7RHluYW1pY0Zvcm1BcnJheU1vZGVsQ29uZmlnfSBmcm9tIFwiLi91dGlscy9keW5hbWljLWZvcm0tYXJyYXkubW9kZWxcIjtcclxuXHJcbi8vIC0tLSBCYXNpYyBmb3JtIGNvbnRyb2wgaW50ZXJmYWNlcyAtLS1cclxuXHJcbmV4cG9ydCB0eXBlIER5bmFtaWNGb3JtU3RhdGUgPSBcIlZBTElEXCIgfCBcIklOVkFMSURcIiB8IFwiUEVORElOR1wiIHwgXCJESVNBQkxFRFwiIHwgXCJMT0FESU5HXCI7XHJcbmV4cG9ydCB0eXBlIER5bmFtaWNGb3JtVXBkYXRlT24gPSBcImNoYW5nZVwiIHwgXCJibHVyXCIgfCBcInN1Ym1pdFwiO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBJRHluYW1pY0Zvcm1FdmVudCBleHRlbmRzIER5bmFtaWNGb3JtQ29udHJvbEV2ZW50IHtcclxuICAgIGZvcm06IElEeW5hbWljRm9ybTtcclxufVxyXG5cclxuZXhwb3J0IGludGVyZmFjZSBJRHluYW1pY0Zvcm0ge1xyXG5cclxuICAgIHJlYWRvbmx5IGdyb3VwOiBGb3JtR3JvdXA7XHJcblxyXG4gICAgc3RhdHVzOiBEeW5hbWljRm9ybVN0YXRlO1xyXG5cclxuICAgIG9uVmFsdWVDaGFuZ2U6IEV2ZW50RW1pdHRlcjxJRHluYW1pY0Zvcm1FdmVudD47XHJcbiAgICBvblN0YXR1c0NoYW5nZTogRXZlbnRFbWl0dGVyPElEeW5hbWljRm9ybT47XHJcbiAgICBvblN1Ym1pdDogRXZlbnRFbWl0dGVyPElEeW5hbWljRm9ybT47XHJcblxyXG4gICAgdmFsaWRhdGUoKTogUHJvbWlzZTxhbnk+O1xyXG4gICAgc2VyaWFsaXplKHZhbGlkYXRlPzogYm9vbGVhbik6IFByb21pc2U8YW55PjtcclxufVxyXG5cclxuZXhwb3J0IGRlY2xhcmUgaW50ZXJmYWNlIE1vZGVsVHlwZSBleHRlbmRzIEZ1bmN0aW9uIHtcclxuICAgIG5ldyAoY29uZmlnOiBEeW5hbWljRm9ybUNvbnRyb2xNb2RlbENvbmZpZyk6IER5bmFtaWNGb3JtQ29udHJvbE1vZGVsO1xyXG59XHJcblxyXG5leHBvcnQgdHlwZSBQcm9taXNlT3JOb3Q8VD4gPSBQcm9taXNlPFQ+IHwgVDtcclxuZXhwb3J0IHR5cGUgRm9ybUNvbnRyb2xTZXJpYWxpemVyID0gKG1vZGVsOiBEeW5hbWljRm9ybVZhbHVlQ29udHJvbE1vZGVsPGFueT4sIGNvbnRyb2w6IEFic3RyYWN0Q29udHJvbCkgPT4gUHJvbWlzZTxhbnk+O1xyXG5leHBvcnQgdHlwZSBGb3JtTW9kZWxDdXN0b21pemVyID0gKFxyXG4gICAgcHJvcGVydHk6IElPcGVuQXBpU2NoZW1hUHJvcGVydHksIHNjaGVtYTogSU9wZW5BcGlTY2hlbWEsXHJcbiAgICBtb2RlbDogRHluYW1pY0Zvcm1Db250cm9sTW9kZWwsIGNvbmZpZzogRHluYW1pY0Zvcm1Db250cm9sTW9kZWxDb25maWcsIGluamVjdG9yOiBJbmplY3RvclxyXG4pID0+IFByb21pc2VPck5vdDxEeW5hbWljRm9ybUNvbnRyb2xNb2RlbCB8IER5bmFtaWNGb3JtQ29udHJvbE1vZGVsW10+O1xyXG5leHBvcnQgdHlwZSBGb3JtTW9kZWxDdXN0b21pemVyV3JhcCA9IChcclxuICAgIHByb3BlcnR5OiBJT3BlbkFwaVNjaGVtYVByb3BlcnR5LCBzY2hlbWE6IElPcGVuQXBpU2NoZW1hLFxyXG4gICAgbW9kZWxUeXBlOiBNb2RlbFR5cGUsIGNvbmZpZzogRHluYW1pY0Zvcm1Db250cm9sTW9kZWxDb25maWdcclxuKSA9PiBQcm9taXNlPER5bmFtaWNGb3JtQ29udHJvbE1vZGVsW10+O1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBJRm9ybUNvbnRyb2wge1xyXG4gICAgaWQ6IHN0cmluZztcclxuICAgIHR5cGU6IHN0cmluZztcclxuICAgIGNvbmZpZz86IER5bmFtaWNGb3JtQ29udHJvbE1vZGVsQ29uZmlnO1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIER5bmFtaWNGb3JtSW5pdENvbnRyb2wgZXh0ZW5kcyBEeW5hbWljRm9ybUNvbnRyb2wge1xyXG4gICAgaW5pdGlhbGl6ZShjZHI/OiBDaGFuZ2VEZXRlY3RvclJlZik6IHZvaWQ7XHJcbn1cclxuXHJcbmV4cG9ydCBkZWNsYXJlIHR5cGUgQXN5bmNTdWJtaXRNZXRob2QgPSAoZm9ybTogSUR5bmFtaWNGb3JtLCBjb250ZXh0PzogYW55KSA9PiBQcm9taXNlPElBc3luY01lc3NhZ2U+O1xyXG5cclxuZXhwb3J0IHR5cGUgR2V0Rm9ybUNvbnRyb2xDb21wb25lbnRUeXBlID0gKG1vZGVsOiBEeW5hbWljRm9ybUNvbnRyb2xNb2RlbCkgPT4gVHlwZTxEeW5hbWljRm9ybUNvbnRyb2xDb21wb25lbnQ+O1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBJRHluYW1pY0Zvcm1Nb2R1bGVDb25maWcge1xyXG4gICAgY29udHJvbFByb3ZpZGVyPzogKGluamVjdG9yOiBJbmplY3RvcikgPT4gRHluYW1pY0Zvcm1Db250cm9sTWFwRm47XHJcbn1cclxuIl19
|
|
@@ -101,4 +101,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
|
|
|
101
101
|
type: ViewChildren,
|
|
102
102
|
args: [forwardRef(() => DynamicBaseFormControlContainerComponent)]
|
|
103
103
|
}] } });
|
|
104
|
-
//# 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    ChangeDetectorRef,\r\n    Component,\r\n    EventEmitter,\r\n    forwardRef,\r\n    Injector,\r\n    Input,\r\n    OnDestroy,\r\n    Output,\r\n    QueryList,\r\n    ViewChildren\r\n} from \"@angular/core\";\r\nimport {FormGroup} from \"@angular/forms\";\r\nimport {lastValueFrom, Subscription} from \"rxjs\";\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 {DynamicFormArrayGroupModel, DynamicFormArrayModel} from \"../../utils/dynamic-form-array.model\";\r\nimport {collectPathAble} from \"../../utils/misc\";\r\nimport {DynamicFormInitControl} from \"../../common-types\";\r\nimport {DynamicBaseFormComponent} from \"./dynamic-base-form.component\";\r\nimport {DynamicBaseFormControlContainerComponent} from \"./dynamic-base-form-control-container.component\";\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 implements DynamicFormInitControl, OnDestroy {\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(() => DynamicBaseFormControlContainerComponent))\r\n    components: QueryList<DynamicBaseFormControlContainerComponent>;\r\n\r\n    get useTabs(): boolean {\r\n        return this.model?.useTabs;\r\n    }\r\n\r\n    protected subscription: Subscription;\r\n\r\n    constructor(layoutService: DynamicFormLayoutService, validationService: DynamicFormValidationService,\r\n                readonly form: DynamicBaseFormComponent, readonly injector: Injector, readonly cdr: ChangeDetectorRef) {\r\n        super(layoutService, validationService);\r\n    }\r\n\r\n    initialize(cdr: ChangeDetectorRef): void {\r\n        this.subscription = this.model.filteredGroups.subscribe(filteredGroups => {\r\n            this.updateGroups(filteredGroups);\r\n        });\r\n        this.model.initialize(this.array);\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        if (this.subscription)\r\n            this.subscription.unsubscribe();\r\n    }\r\n\r\n    saveTab(index: number): void {\r\n        this.model.saveTab(index, this.model.getFiltered(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, model: DynamicFormArrayGroupModel): string {\r\n        return this.model.getTabLabel(index, model, 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    protected updateGroups(filteredGroups: ReadonlyArray<DynamicFormArrayGroupModel>): void {\r\n        this.cdr.detectChanges();\r\n        this.components.forEach(t => t.cdr.detectChanges());\r\n    }\r\n}\r\n"]}
|
|
104
|
+
//# 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    ChangeDetectorRef,\r\n    Component,\r\n    EventEmitter,\r\n    forwardRef,\r\n    Injector,\r\n    Input,\r\n    OnDestroy,\r\n    Output,\r\n    QueryList,\r\n    ViewChildren\r\n} from \"@angular/core\";\r\nimport {FormGroup} from \"@angular/forms\";\r\nimport {Subscription} from \"rxjs\";\r\nimport {\r\n    DynamicFormArrayComponent,\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 {DynamicFormArrayGroupModel, DynamicFormArrayModel} from \"../../utils/dynamic-form-array.model\";\r\nimport {collectPathAble} from \"../../utils/misc\";\r\nimport {DynamicFormInitControl} from \"../../common-types\";\r\nimport {DynamicBaseFormComponent} from \"./dynamic-base-form.component\";\r\nimport {DynamicBaseFormControlContainerComponent} from \"./dynamic-base-form-control-container.component\";\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 implements DynamicFormInitControl, OnDestroy {\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(() => DynamicBaseFormControlContainerComponent))\r\n    components: QueryList<DynamicBaseFormControlContainerComponent>;\r\n\r\n    get useTabs(): boolean {\r\n        return this.model?.useTabs;\r\n    }\r\n\r\n    protected subscription: Subscription;\r\n\r\n    constructor(layoutService: DynamicFormLayoutService, validationService: DynamicFormValidationService,\r\n                readonly form: DynamicBaseFormComponent, readonly injector: Injector, readonly cdr: ChangeDetectorRef) {\r\n        super(layoutService, validationService);\r\n    }\r\n\r\n    initialize(cdr: ChangeDetectorRef): void {\r\n        this.subscription = this.model.filteredGroups.subscribe(filteredGroups => {\r\n            this.updateGroups(filteredGroups);\r\n        });\r\n        this.model.initialize(this.array);\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        if (this.subscription)\r\n            this.subscription.unsubscribe();\r\n    }\r\n\r\n    saveTab(index: number): void {\r\n        this.model.saveTab(index, this.model.getFiltered(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, model: DynamicFormArrayGroupModel): string {\r\n        return this.model.getTabLabel(index, model, 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    protected updateGroups(filteredGroups: ReadonlyArray<DynamicFormArrayGroupModel>): void {\r\n        this.cdr.detectChanges();\r\n        this.components.forEach(t => t.cdr.detectChanges());\r\n    }\r\n}\r\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from "@angular/core";
|
|
2
|
-
import { debounceTime } from "rxjs";
|
|
2
|
+
import { debounceTime } from "rxjs/operators";
|
|
3
3
|
import { DynamicFormControlComponent } from "@ng-dynamic-forms/core";
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
import * as i1 from "@ng-dynamic-forms/core";
|
|
@@ -54,4 +54,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
|
|
|
54
54
|
}], focus: [{
|
|
55
55
|
type: Output
|
|
56
56
|
}] } });
|
|
57
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
57
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHluYW1pYy1iYXNlLWZvcm0tY29udHJvbC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvbmd4LWR5bmFtaWMtZm9ybS9jb21wb25lbnRzL2Jhc2UvZHluYW1pYy1iYXNlLWZvcm0tY29udHJvbC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUVILHVCQUF1QixFQUV2QixTQUFTLEVBQ1QsWUFBWSxFQUVaLEtBQUssRUFFTCxNQUFNLEVBQ1QsTUFBTSxlQUFlLENBQUM7QUFHdkIsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGdCQUFnQixDQUFDO0FBQzVDLE9BQU8sRUFDSCwyQkFBMkIsRUFNOUIsTUFBTSx3QkFBd0IsQ0FBQzs7OztBQVFoQyxNQUFNLE9BQU8sK0JBQW1FLFNBQVEsMkJBQTJCO0lBYS9HLFlBQVksYUFBdUMsRUFBRSxpQkFBK0MsRUFDL0UsSUFBOEIsRUFBVyxRQUFrQixFQUFXLEdBQXNCO1FBQzdHLEtBQUssQ0FBQyxhQUFhLEVBQUUsaUJBQWlCLENBQUMsQ0FBQztRQUR2QixTQUFJLEdBQUosSUFBSSxDQUEwQjtRQUFXLGFBQVEsR0FBUixRQUFRLENBQVU7UUFBVyxRQUFHLEdBQUgsR0FBRyxDQUFtQjtRQUU3RyxJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksWUFBWSxFQUFPLENBQUM7UUFDcEMsSUFBSSxDQUFDLE1BQU0sR0FBRyxJQUFJLFlBQVksRUFBTyxDQUFDO1FBQ3RDLElBQUksQ0FBQyxLQUFLLEdBQUcsSUFBSSxZQUFZLEVBQU8sQ0FBQztJQUN6QyxDQUFDO0lBRUQsZUFBZTtRQUNYLElBQUksQ0FBQyxZQUFZLEdBQUcsSUFBSSxDQUFDLE9BQU8sQ0FBQyxZQUFZLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsRUFBRTtZQUNwRixJQUFJLENBQUMsY0FBYyxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQy9CLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVELFdBQVc7UUFDUCxJQUFJLENBQUMsSUFBSSxDQUFDLFlBQVk7WUFBRSxPQUFPO1FBQy9CLElBQUksQ0FBQyxZQUFZLENBQUMsV0FBVyxFQUFFLENBQUM7SUFDcEMsQ0FBQztJQUVELE1BQU07UUFDRixJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDO0lBQ3ZCLENBQUM7SUFFUyxjQUFjLENBQUMsS0FBVTtJQUVuQyxDQUFDOzs0SEF0Q1EsK0JBQStCO2dIQUEvQiwrQkFBK0IsNk9BSDlCLEVBQUU7MkZBR0gsK0JBQStCO2tCQUwzQyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSwyQkFBMkI7b0JBQ3JDLFFBQVEsRUFBRSxFQUFFO29CQUNaLGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO2lCQUNsRDt3UEFHWSxVQUFVO3NCQUFsQixLQUFLO2dCQUNHLEtBQUs7c0JBQWIsS0FBSztnQkFDRyxNQUFNO3NCQUFkLEtBQUs7Z0JBQ0csS0FBSztzQkFBYixLQUFLO2dCQUVJLElBQUk7c0JBQWIsTUFBTTtnQkFDRyxNQUFNO3NCQUFmLE1BQU07Z0JBQ0csS0FBSztzQkFBZCxNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcclxuICAgIEFmdGVyVmlld0luaXQsXHJcbiAgICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcclxuICAgIENoYW5nZURldGVjdG9yUmVmLFxyXG4gICAgQ29tcG9uZW50LFxyXG4gICAgRXZlbnRFbWl0dGVyLFxyXG4gICAgSW5qZWN0b3IsXHJcbiAgICBJbnB1dCxcclxuICAgIE9uRGVzdHJveSxcclxuICAgIE91dHB1dFxyXG59IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7Rm9ybUdyb3VwfSBmcm9tIFwiQGFuZ3VsYXIvZm9ybXNcIjtcclxuaW1wb3J0IHtTdWJzY3JpcHRpb259IGZyb20gXCJyeGpzXCI7XHJcbmltcG9ydCB7ZGVib3VuY2VUaW1lfSBmcm9tIFwicnhqcy9vcGVyYXRvcnNcIjtcclxuaW1wb3J0IHtcclxuICAgIER5bmFtaWNGb3JtQ29udHJvbENvbXBvbmVudCxcclxuICAgIER5bmFtaWNGb3JtQ29udHJvbExheW91dCxcclxuICAgIER5bmFtaWNGb3JtQ29udHJvbE1vZGVsLFxyXG4gICAgRHluYW1pY0Zvcm1MYXlvdXQsXHJcbiAgICBEeW5hbWljRm9ybUxheW91dFNlcnZpY2UsXHJcbiAgICBEeW5hbWljRm9ybVZhbGlkYXRpb25TZXJ2aWNlXHJcbn0gZnJvbSBcIkBuZy1keW5hbWljLWZvcm1zL2NvcmVcIjtcclxuaW1wb3J0IHtEeW5hbWljQmFzZUZvcm1Db21wb25lbnR9IGZyb20gXCIuL2R5bmFtaWMtYmFzZS1mb3JtLmNvbXBvbmVudFwiO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogXCJkeW5hbWljLWJhc2UtZm9ybS1jb250cm9sXCIsXHJcbiAgICB0ZW1wbGF0ZTogXCJcIixcclxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBEeW5hbWljQmFzZUZvcm1Db250cm9sQ29tcG9uZW50PFQgZXh0ZW5kcyBEeW5hbWljRm9ybUNvbnRyb2xNb2RlbD4gZXh0ZW5kcyBEeW5hbWljRm9ybUNvbnRyb2xDb21wb25lbnQgaW1wbGVtZW50cyBBZnRlclZpZXdJbml0LCBPbkRlc3Ryb3kge1xyXG5cclxuICAgIEBJbnB1dCgpIGZvcm1MYXlvdXQ6IER5bmFtaWNGb3JtTGF5b3V0O1xyXG4gICAgQElucHV0KCkgZ3JvdXA6IEZvcm1Hcm91cDtcclxuICAgIEBJbnB1dCgpIGxheW91dDogRHluYW1pY0Zvcm1Db250cm9sTGF5b3V0O1xyXG4gICAgQElucHV0KCkgbW9kZWw6IFQ7XHJcblxyXG4gICAgQE91dHB1dCgpIGJsdXI6IEV2ZW50RW1pdHRlcjxhbnk+O1xyXG4gICAgQE91dHB1dCgpIGNoYW5nZTogRXZlbnRFbWl0dGVyPGFueT47XHJcbiAgICBAT3V0cHV0KCkgZm9jdXM6IEV2ZW50RW1pdHRlcjxhbnk+O1xyXG5cclxuICAgIHByb3RlY3RlZCBzdWJzY3JpcHRpb246IFN1YnNjcmlwdGlvbjtcclxuXHJcbiAgICBjb25zdHJ1Y3RvcihsYXlvdXRTZXJ2aWNlOiBEeW5hbWljRm9ybUxheW91dFNlcnZpY2UsIHZhbGlkYXRpb25TZXJ2aWNlOiBEeW5hbWljRm9ybVZhbGlkYXRpb25TZXJ2aWNlLFxyXG4gICAgICAgICAgICAgICAgcmVhZG9ubHkgZm9ybTogRHluYW1pY0Jhc2VGb3JtQ29tcG9uZW50LCByZWFkb25seSBpbmplY3RvcjogSW5qZWN0b3IsIHJlYWRvbmx5IGNkcjogQ2hhbmdlRGV0ZWN0b3JSZWYpIHtcclxuICAgICAgICBzdXBlcihsYXlvdXRTZXJ2aWNlLCB2YWxpZGF0aW9uU2VydmljZSk7XHJcbiAgICAgICAgdGhpcy5ibHVyID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XHJcbiAgICAgICAgdGhpcy5jaGFuZ2UgPSBuZXcgRXZlbnRFbWl0dGVyPGFueT4oKTtcclxuICAgICAgICB0aGlzLmZvY3VzID0gbmV3IEV2ZW50RW1pdHRlcjxhbnk+KCk7XHJcbiAgICB9XHJcblxyXG4gICAgbmdBZnRlclZpZXdJbml0KCk6IHZvaWQge1xyXG4gICAgICAgIHRoaXMuc3Vic2NyaXB0aW9uID0gdGhpcy5jb250cm9sLnZhbHVlQ2hhbmdlcy5waXBlKGRlYm91bmNlVGltZSg1MDApKS5zdWJzY3JpYmUodmFsdWUgPT4ge1xyXG4gICAgICAgICAgICB0aGlzLm9uVmFsdWVDaGFuZ2VkKHZhbHVlKTtcclxuICAgICAgICB9KTtcclxuICAgIH1cclxuXHJcbiAgICBuZ09uRGVzdHJveSgpOiB2b2lkIHtcclxuICAgICAgICBpZiAoIXRoaXMuc3Vic2NyaXB0aW9uKSByZXR1cm47XHJcbiAgICAgICAgdGhpcy5zdWJzY3JpcHRpb24udW5zdWJzY3JpYmUoKTtcclxuICAgIH1cclxuXHJcbiAgICBzdWJtaXQoKTogdm9pZCB7XHJcbiAgICAgICAgdGhpcy5mb3JtLnN1Ym1pdCgpO1xyXG4gICAgfVxyXG5cclxuICAgIHByb3RlY3RlZCBvblZhbHVlQ2hhbmdlZCh2YWx1ZTogYW55KTogdm9pZCB7XHJcblxyXG4gICAgfVxyXG59XHJcbiJdfQ==
|
|
@@ -1,5 +1,6 @@
|
|
|
1
1
|
import { ChangeDetectionStrategy, Component, ContentChildren, EventEmitter, Inject, Input, Output, QueryList, ViewChildren } from "@angular/core";
|
|
2
|
-
import {
|
|
2
|
+
import { Subscription } from "rxjs";
|
|
3
|
+
import { debounceTime, groupBy, mergeMap } from "rxjs/operators";
|
|
3
4
|
import { first } from "rxjs/operators";
|
|
4
5
|
import { DynamicFormComponent, DynamicFormGroupModel, DynamicTemplateDirective } from "@ng-dynamic-forms/core";
|
|
5
6
|
import { EventsService, ObservableUtils } from "@stemy/ngx-utils";
|
|
@@ -169,4 +170,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
|
|
|
169
170
|
}], onDetectChanges: [{
|
|
170
171
|
type: Output
|
|
171
172
|
}] } });
|
|
172
|
-
//# 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    ViewChildren\r\n} from \"@angular/core\";\r\nimport {FormArray, FormGroup} from \"@angular/forms\";\r\nimport {debounceTime, groupBy, mergeMap, 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, GetFormControlComponentType, 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    @Input() getComponentType: GetFormControlComponentType;\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    @Output() readonly onDetectChanges: EventEmitter<IDynamicForm>;\r\n\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.onDetectChanges = 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        this.getComponentType = () => null;\r\n    }\r\n\r\n    submit(): void {\r\n        this.onSubmit.emit(this);\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.pipe(debounceTime(500)).subscribe(() => {\r\n                    this.formService.notifyChanges(this.model, this.group);\r\n                }),\r\n                this.change.pipe(groupBy(ev => ev.model))\r\n                    .pipe(mergeMap(t => t.pipe(debounceTime(500))))\r\n                    .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.notifyChanges(this.model, this.group);\r\n                this.formService.detectChanges(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    detectChanges(): void {\r\n        super.detectChanges();\r\n        this.onDetectChanges.emit(this);\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.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.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.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.detectChanges();\r\n    }\r\n\r\n    clearFormArray(formArray: FormArray, formArrayModel: DynamicFormArrayModel): void {\r\n        this.formService.clearFormArray(formArray, formArrayModel);\r\n        this.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"]}
|
|
173
|
+
//# 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    ViewChildren\r\n} from \"@angular/core\";\r\nimport {FormArray, FormGroup} from \"@angular/forms\";\r\nimport {Subscription} from \"rxjs\";\r\nimport {debounceTime, groupBy, mergeMap} from \"rxjs/operators\";\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, GetFormControlComponentType, 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    @Input() getComponentType: GetFormControlComponentType;\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    @Output() readonly onDetectChanges: EventEmitter<IDynamicForm>;\r\n\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.onDetectChanges = 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        this.getComponentType = () => null;\r\n    }\r\n\r\n    submit(): void {\r\n        this.onSubmit.emit(this);\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.pipe(debounceTime(500)).subscribe(() => {\r\n                    this.formService.notifyChanges(this.model, this.group);\r\n                }),\r\n                this.change.pipe(groupBy(ev => ev.model))\r\n                    .pipe(mergeMap(t => t.pipe(debounceTime(500))))\r\n                    .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.notifyChanges(this.model, this.group);\r\n                this.formService.detectChanges(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    detectChanges(): void {\r\n        super.detectChanges();\r\n        this.onDetectChanges.emit(this);\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.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.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.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.detectChanges();\r\n    }\r\n\r\n    clearFormArray(formArray: FormArray, formArrayModel: DynamicFormArrayModel): void {\r\n        this.formService.clearFormArray(formArray, formArrayModel);\r\n        this.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"]}
|
|
@@ -90,7 +90,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
|
|
|
90
90
|
ReactiveFormsModule,
|
|
91
91
|
NgxUtilsModule
|
|
92
92
|
],
|
|
93
|
-
entryComponents: components,
|
|
94
93
|
providers: [
|
|
95
94
|
...pipes,
|
|
96
95
|
{ provide: NG_VALIDATORS, useValue: validateJSON, multi: true },
|
|
@@ -114,4 +113,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.8", ngImpor
|
|
|
114
113
|
]
|
|
115
114
|
}]
|
|
116
115
|
}] });
|
|
117
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
116
|
+
//# 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":"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","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    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"]}
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
import { DynamicCheckboxModel, DynamicDatePickerModel, DynamicFileUploadModel, DynamicFormGroupModel, DynamicInputModel, DynamicTextAreaModel } from "@ng-dynamic-forms/core";
|
|
2
|
+
import { ObjectUtils } from "@stemy/ngx-utils";
|
|
3
|
+
import { DynamicEditorModel } from "./dynamic-editor.model";
|
|
4
|
+
import { DynamicFormArrayModel } from "./dynamic-form-array.model";
|
|
5
|
+
import { DynamicSelectModel } from "./dynamic-select.model";
|
|
6
|
+
export function createFormConfig(id, config) {
|
|
7
|
+
config = config || { id };
|
|
8
|
+
config.id = id;
|
|
9
|
+
config.label = ObjectUtils.isNullOrUndefined(config.label) ? id : config.label;
|
|
10
|
+
config.disabled = config.disabled || false;
|
|
11
|
+
config.hidden = config.hidden || false;
|
|
12
|
+
return config;
|
|
13
|
+
}
|
|
14
|
+
export function createFormCheckbox(id, config, layout) {
|
|
15
|
+
config = createFormConfig(id, config);
|
|
16
|
+
config.indeterminate = config.indeterminate || false;
|
|
17
|
+
return new DynamicCheckboxModel(config, layout);
|
|
18
|
+
}
|
|
19
|
+
export function createFormDate(id, config, layout) {
|
|
20
|
+
config = createFormConfig(id, config);
|
|
21
|
+
config.autoFocus = config.autoFocus || false;
|
|
22
|
+
config.focusedDate = config.focusedDate || new Date();
|
|
23
|
+
config.inline = config.inline || false;
|
|
24
|
+
return new DynamicDatePickerModel(config, layout);
|
|
25
|
+
}
|
|
26
|
+
export function createFormEditor(id, config, layout) {
|
|
27
|
+
config = createFormConfig(id, config);
|
|
28
|
+
return new DynamicEditorModel(config, layout);
|
|
29
|
+
}
|
|
30
|
+
export function createFormArray(id, config, layout) {
|
|
31
|
+
config = createFormConfig(id, config);
|
|
32
|
+
return new DynamicFormArrayModel(config, layout);
|
|
33
|
+
}
|
|
34
|
+
export function createFormGroup(id, config, layout) {
|
|
35
|
+
config = createFormConfig(id, config);
|
|
36
|
+
config.name = config.name || "";
|
|
37
|
+
return new DynamicFormGroupModel(config, layout);
|
|
38
|
+
}
|
|
39
|
+
export function createFormInput(id, config, type = "text", layout) {
|
|
40
|
+
config = createFormConfig(id, config);
|
|
41
|
+
config.inputType = config.inputType || type;
|
|
42
|
+
config.placeholder = config.placeholder || (config.inputType == "mask" ? "_" : "");
|
|
43
|
+
config.step = config.step || 1;
|
|
44
|
+
config.mask = config.mask || null;
|
|
45
|
+
return new DynamicInputModel(config, layout);
|
|
46
|
+
}
|
|
47
|
+
export function createFormSelect(id, config, layout) {
|
|
48
|
+
config = createFormConfig(id, config);
|
|
49
|
+
config.options = config.options || [];
|
|
50
|
+
return new DynamicSelectModel(config, layout);
|
|
51
|
+
}
|
|
52
|
+
export function createFormTextarea(id, config, layout) {
|
|
53
|
+
config = createFormConfig(id, config);
|
|
54
|
+
config.cols = config.cols || 10;
|
|
55
|
+
config.rows = config.rows || 3;
|
|
56
|
+
config.wrap = config.wrap || "soft";
|
|
57
|
+
return new DynamicTextAreaModel(config, layout);
|
|
58
|
+
}
|
|
59
|
+
export function createFormFile(id, config, layout) {
|
|
60
|
+
config = createFormConfig(id, config);
|
|
61
|
+
config.accept = config.accept || ["jpg", "jpeg", "png"];
|
|
62
|
+
config.multiple = config.multiple || false;
|
|
63
|
+
config.url = ObjectUtils.isString(config.url) ? config.url : "assets";
|
|
64
|
+
return new DynamicFileUploadModel(config, layout);
|
|
65
|
+
}
|
|
66
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"creators.js","sourceRoot":"","sources":["../../../../src/ngx-dynamic-form/utils/creators.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    DynamicCheckboxModel,\r\n    DynamicCheckboxModelConfig,\r\n    DynamicDatePickerModel,\r\n    DynamicFileUploadModel,\r\n    DynamicFileUploadModelConfig,\r\n    DynamicFormControlLayout,\r\n    DynamicFormControlModelConfig,\r\n    DynamicFormGroupModel,\r\n    DynamicFormGroupModelConfig,\r\n    DynamicInputModel,\r\n    DynamicInputModelConfig,\r\n    DynamicTextAreaModel,\r\n    DynamicTextAreaModelConfig\r\n} from \"@ng-dynamic-forms/core\";\r\nimport {ObjectUtils} from \"@stemy/ngx-utils\";\r\nimport {DynamicEditorModel, DynamicEditorModelConfig} from \"./dynamic-editor.model\";\r\nimport {DynamicFormArrayModel, DynamicFormArrayModelConfig} from \"./dynamic-form-array.model\";\r\nimport {DynamicSelectModelConfig, DynamicSelectModel} from \"./dynamic-select.model\";\r\n\r\nexport function createFormConfig<T extends DynamicFormControlModelConfig>(id: string, config?: T): T {\r\n    config = config || {id} as T;\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 config;\r\n}\r\n\r\nexport function createFormCheckbox(id: string, config: DynamicCheckboxModelConfig, layout?: DynamicFormControlLayout): DynamicCheckboxModel {\r\n    config = createFormConfig(id, config);\r\n    config.indeterminate = config.indeterminate || false;\r\n    return new DynamicCheckboxModel(config, layout);\r\n}\r\n\r\nexport function createFormDate(id: string, config: DynamicDatePickerModel, layout?: DynamicFormControlLayout): DynamicDatePickerModel {\r\n    config = createFormConfig(id, config);\r\n    config.autoFocus = config.autoFocus || false;\r\n    config.focusedDate = config.focusedDate || new Date();\r\n    config.inline = config.inline || false;\r\n    return new DynamicDatePickerModel(config, layout);\r\n}\r\n\r\nexport function createFormEditor(id: string, config: DynamicEditorModelConfig, layout?: DynamicFormControlLayout): DynamicEditorModel {\r\n    config = createFormConfig(id, config);\r\n    return new DynamicEditorModel(config, layout);\r\n}\r\n\r\nexport function createFormArray(id: string, config: DynamicFormArrayModelConfig, layout?: DynamicFormControlLayout): DynamicFormArrayModel {\r\n    config = createFormConfig(id, config);\r\n    return new DynamicFormArrayModel(config, layout);\r\n}\r\n\r\nexport function createFormGroup(id: string, config: DynamicFormGroupModelConfig, layout?: DynamicFormControlLayout): DynamicFormGroupModel {\r\n    config = createFormConfig(id, config);\r\n    config.name = config.name || \"\";\r\n    return new DynamicFormGroupModel(config, layout);\r\n}\r\n\r\nexport function createFormInput(id: string, config: DynamicInputModelConfig, type: string = \"text\", layout?: DynamicFormControlLayout): DynamicInputModel {\r\n    config = createFormConfig(id, 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 new DynamicInputModel(config, layout);\r\n}\r\n\r\nexport function createFormSelect<T = any>(id: string, config: DynamicSelectModelConfig<T>, layout?: DynamicFormControlLayout): DynamicSelectModel<T> {\r\n    config = createFormConfig(id, config);\r\n    config.options = config.options || [];\r\n    return new DynamicSelectModel(config, layout);\r\n}\r\n\r\nexport function createFormTextarea(id: string, config: DynamicTextAreaModelConfig, layout?: DynamicFormControlLayout): DynamicTextAreaModel {\r\n    config = createFormConfig(id, config);\r\n    config.cols = config.cols || 10;\r\n    config.rows = config.rows || 3;\r\n    config.wrap = config.wrap || \"soft\";\r\n    return new DynamicTextAreaModel(config, layout);\r\n}\r\n\r\nexport function createFormFile(id: string, config: DynamicFileUploadModelConfig, layout?: DynamicFormControlLayout): DynamicFileUploadModel {\r\n    config = createFormConfig(id, config);\r\n    config.accept = config.accept || [\"jpg\", \"jpeg\", \"png\"];\r\n    config.multiple = config.multiple || false;\r\n    config.url = ObjectUtils.isString(config.url) ? config.url : \"assets\";\r\n    return new DynamicFileUploadModel(config, layout);\r\n}\r\n"]}
|
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
import { isObservable,
|
|
1
|
+
import { isObservable, of } from "rxjs";
|
|
2
|
+
import { map } from "rxjs/operators";
|
|
2
3
|
import { ObjectUtils } from "@stemy/ngx-utils";
|
|
3
4
|
import { DynamicFormOption as BaseOption, DynamicSelectModel as Base, } from "@ng-dynamic-forms/core";
|
|
4
5
|
const ignoredKeys = ["disabled", "label", "value", "classes"];
|
|
@@ -54,4 +55,4 @@ export class DynamicSelectModel extends Base {
|
|
|
54
55
|
this.updateOptions();
|
|
55
56
|
}
|
|
56
57
|
}
|
|
57
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
58
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-select.model.js","sourceRoot":"","sources":["../../../../src/ngx-dynamic-form/utils/dynamic-select.model.ts"],"names":[],"mappings":"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","sourcesContent":["import {Injector} from \"@angular/core\";\r\nimport {FormControl} from \"@angular/forms\";\r\nimport {isObservable, Observable, of} from \"rxjs\";\r\nimport {map} from \"rxjs/operators\";\r\nimport {ObjectUtils} from \"@stemy/ngx-utils\";\r\nimport {\r\n    DynamicFormControlLayout,\r\n    DynamicFormOption as BaseOption,\r\n    DynamicFormOptionConfig as BaseOptionConfig,\r\n    DynamicSelectModel as Base,\r\n    DynamicSelectModelConfig as BaseConfig,\r\n} from \"@ng-dynamic-forms/core\";\r\n\r\nconst ignoredKeys = [\"disabled\", \"label\", \"value\", \"classes\"];\r\n\r\nexport interface DynamicFormOptionConfig<T> extends BaseOptionConfig<T> {\r\n    classes?: string;\r\n\r\n    [key: string]: any;\r\n}\r\n\r\nexport class DynamicFormOption<T> extends BaseOption<T> {\r\n\r\n    readonly classes: string;\r\n    readonly props: any;\r\n\r\n    constructor(config: DynamicFormOptionConfig<T>) {\r\n        super(config);\r\n        this.classes = config.classes || \"\";\r\n        this.props = Object.keys(config).reduce((res, k) => {\r\n            if (ignoredKeys.indexOf(k) >= 0) return res;\r\n            res[k] = config[k];\r\n            return res;\r\n        }, {});\r\n    }\r\n}\r\n\r\nexport interface DynamicFormOptionGroup<T> {\r\n    group: string;\r\n    options: ReadonlyArray<DynamicFormOption<T>>;\r\n}\r\n\r\nexport type OptionClassesFunc<T> = (option: DynamicFormOptionConfig<T>, model: DynamicSelectModel<T>, control: FormControl, injector: Injector) => string;\r\n\r\nexport interface DynamicSelectModelConfig<T> extends BaseConfig<T> {\r\n    groupBy?: string;\r\n    inline?: boolean;\r\n    options?: DynamicFormOptionConfig<T>[] | Observable<DynamicFormOptionConfig<T>[]>;\r\n    getClasses?: OptionClassesFunc<T>;\r\n}\r\n\r\nexport class DynamicSelectModel<T> extends Base<T> {\r\n\r\n    readonly groupBy: string;\r\n    readonly inline: boolean;\r\n    readonly getClasses: OptionClassesFunc<T>;\r\n\r\n    options$: Observable<DynamicFormOption<T>[]>;\r\n\r\n    protected mOptions: DynamicFormOption<T>[];\r\n\r\n    constructor(config: DynamicSelectModelConfig<T>, layout?: DynamicFormControlLayout) {\r\n        super(config, layout);\r\n        this.groupBy = config.groupBy || null;\r\n        this.inline = config.inline || false;\r\n        this.getClasses = ObjectUtils.isFunction(config.getClasses) ? config.getClasses : (() => \"\");\r\n        this.mOptions = this.mOptions || [];\r\n    }\r\n\r\n    protected updateOptions(): void {\r\n        this.options$ = of(this.mOptions);\r\n    }\r\n\r\n    set options(options: any) {\r\n        if (Array.isArray(options)) {\r\n            this.mOptions = (options as DynamicFormOptionConfig<T>[]).map(optionConfig => new DynamicFormOption<T>(optionConfig));\r\n            this.updateOptions();\r\n        } else if (isObservable(options)) {\r\n            this.options$ = (options as Observable<DynamicFormOptionConfig<T>[]>).pipe(\r\n                map(optionsConfig => {\r\n                    this.mOptions = optionsConfig.map(optionConfig => new DynamicFormOption<T>(optionConfig));\r\n                    return this.mOptions;\r\n                }));\r\n        } else {\r\n            this.updateOptions();\r\n        }\r\n    }\r\n\r\n    get options(): ReadonlyArray<DynamicFormOption<T>> {\r\n        return this.mOptions;\r\n    }\r\n\r\n    insert(index: number, optionConfig: DynamicFormOptionConfig<T>): DynamicFormOption<T> {\r\n        const option = new DynamicFormOption(optionConfig);\r\n        this.mOptions.splice(index, 0, option);\r\n        this.updateOptions();\r\n        return option;\r\n    }\r\n\r\n    remove(...indices: number[]): void {\r\n        indices.forEach(index => this.mOptions.splice(index, 1));\r\n        this.updateOptions();\r\n    }\r\n}\r\n"]}
|
package/esm2020/public_api.mjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
export {
|
|
1
|
+
export { createFormCheckbox, createFormDate, createFormEditor, createFormArray, createFormGroup, createFormInput, createFormSelect, createFormTextarea, createFormFile, } from "./ngx-dynamic-form/utils/creators";
|
|
2
2
|
export { replaceSpecialChars, mergeFormModels, MIN_INPUT_NUM, MAX_INPUT_NUM, EDITOR_FORMATS } from "./ngx-dynamic-form/utils/misc";
|
|
3
3
|
export { validateJSON, validateRequiredTranslation, validatePhone, validateItemsMinLength, validateItemsMaxLength, validateItemsMinValue, validateItemsMaxValue } from "./ngx-dynamic-form/utils/validators";
|
|
4
4
|
export { DynamicEditorModel } from "./ngx-dynamic-form/utils/dynamic-editor.model";
|
|
@@ -16,4 +16,4 @@ export { DynamicBaseFormGroupComponent } from "./ngx-dynamic-form/components/bas
|
|
|
16
16
|
export { DynamicBaseSelectComponent } from "./ngx-dynamic-form/components/base/dynamic-base-select.component";
|
|
17
17
|
export { NgxDynamicFormModule } from "./ngx-dynamic-form/ngx-dynamic-form.module";
|
|
18
18
|
export { DYNAMIC_FORM_CONTROL_TYPE_ARRAY, DYNAMIC_FORM_CONTROL_TYPE_CHECKBOX, DYNAMIC_FORM_CONTROL_TYPE_CHECKBOX_GROUP, DYNAMIC_FORM_CONTROL_TYPE_FILE_UPLOAD, DYNAMIC_FORM_CONTROL_TYPE_GROUP, DYNAMIC_FORM_CONTROL_TYPE_INPUT, DYNAMIC_FORM_CONTROL_TYPE_DATEPICKER, DYNAMIC_FORM_CONTROL_TYPE_RADIO_GROUP, DYNAMIC_FORM_CONTROL_TYPE_SELECT, DYNAMIC_FORM_CONTROL_TYPE_TEXTAREA, DYNAMIC_FORM_CONTROL_TYPE_EDITOR, DynamicTemplateDirective, DynamicListDirective, DynamicFormsCoreModule, DynamicCheckboxModel, DynamicCheckboxGroupModel, DynamicFileUploadModel, DynamicFormGroupModel, DynamicInputModel, DynamicDatePickerModel, DynamicRadioGroupModel, DynamicTextAreaModel, DynamicFormControlComponent } from "@ng-dynamic-forms/core";
|
|
19
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
19
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljX2FwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9wdWJsaWNfYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWFBLE9BQU8sRUFDSCxrQkFBa0IsRUFDbEIsY0FBYyxFQUNkLGdCQUFnQixFQUNoQixlQUFlLEVBQ2YsZUFBZSxFQUNmLGVBQWUsRUFDZixnQkFBZ0IsRUFDaEIsa0JBQWtCLEVBQ2xCLGNBQWMsR0FDakIsTUFBTSxtQ0FBbUMsQ0FBQztBQUUzQyxPQUFPLEVBQ0gsbUJBQW1CLEVBQ25CLGVBQWUsRUFDZixhQUFhLEVBQ2IsYUFBYSxFQUNiLGNBQWMsRUFDakIsTUFBTSwrQkFBK0IsQ0FBQztBQUV2QyxPQUFPLEVBQ0gsWUFBWSxFQUNaLDJCQUEyQixFQUMzQixhQUFhLEVBQ2Isc0JBQXNCLEVBQ3RCLHNCQUFzQixFQUN0QixxQkFBcUIsRUFDckIscUJBQXFCLEVBQ3hCLE1BQU0scUNBQXFDLENBQUM7QUFFN0MsT0FBTyxFQUVILGtCQUFrQixFQUNyQixNQUFNLCtDQUErQyxDQUFDO0FBRXZELE9BQU8sRUFJSCwwQkFBMEIsRUFFMUIscUJBQXFCLEVBQ3hCLE1BQU0sbURBQW1ELENBQUM7QUFFM0QsT0FBTyxFQUVILGlCQUFpQixFQUlqQixrQkFBa0IsRUFDckIsTUFBTSwrQ0FBK0MsQ0FBQztBQUV2RCxPQUFPLEVBQUMsaUJBQWlCLEVBQUMsTUFBTSw4Q0FBOEMsQ0FBQztBQUMvRSxPQUFPLEVBQUMsV0FBVyxFQUFDLE1BQU0sdUNBQXVDLENBQUM7QUFFbEUsT0FBTyxFQUFDLGtCQUFrQixFQUFDLE1BQU0sa0RBQWtELENBQUM7QUFFcEYsT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0sc0RBQXNELENBQUM7QUFFMUYsT0FBTyxFQUFDLHdCQUF3QixFQUFDLE1BQU0sZ0VBQWdFLENBQUM7QUFDeEcsT0FBTyxFQUFDLDZCQUE2QixFQUFDLE1BQU0sc0VBQXNFLENBQUM7QUFDbkgsT0FBTyxFQUNILCtCQUErQixFQUNsQyxNQUFNLHdFQUF3RSxDQUFDO0FBQ2hGLE9BQU8sRUFDSCx3Q0FBd0MsRUFDM0MsTUFBTSxrRkFBa0YsQ0FBQztBQUMxRixPQUFPLEVBQUMsNkJBQTZCLEVBQUMsTUFBTSxzRUFBc0UsQ0FBQztBQUNuSCxPQUFPLEVBQUMsMEJBQTBCLEVBQUMsTUFBTSxrRUFBa0UsQ0FBQztBQUU1RyxPQUFPLEVBQUMsb0JBQW9CLEVBQUMsTUFBTSw0Q0FBNEMsQ0FBQztBQUVoRixPQUFPLEVBQ0gsK0JBQStCLEVBQy9CLGtDQUFrQyxFQUNsQyx3Q0FBd0MsRUFDeEMscUNBQXFDLEVBQ3JDLCtCQUErQixFQUMvQiwrQkFBK0IsRUFDL0Isb0NBQW9DLEVBQ3BDLHFDQUFxQyxFQUNyQyxnQ0FBZ0MsRUFDaEMsa0NBQWtDLEVBQ2xDLGdDQUFnQyxFQUNoQyx3QkFBd0IsRUFDeEIsb0JBQW9CLEVBR3BCLHNCQUFzQixFQUV0QixvQkFBb0IsRUFDcEIseUJBQXlCLEVBRXpCLHNCQUFzQixFQUV0QixxQkFBcUIsRUFFckIsaUJBQWlCLEVBRWpCLHNCQUFzQixFQUV0QixzQkFBc0IsRUFFdEIsb0JBQW9CLEVBQ3BCLDJCQUEyQixFQUM5QixNQUFNLHdCQUF3QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHtcclxuICAgIElEeW5hbWljRm9ybUV2ZW50LFxyXG4gICAgSUR5bmFtaWNGb3JtLFxyXG4gICAgRm9ybUNvbnRyb2xTZXJpYWxpemVyLFxyXG4gICAgRm9ybU1vZGVsQ3VzdG9taXplcixcclxuICAgIER5bmFtaWNGb3JtU3RhdGUsXHJcbiAgICBEeW5hbWljRm9ybVVwZGF0ZU9uLFxyXG4gICAgRHluYW1pY0Zvcm1Jbml0Q29udHJvbCxcclxuICAgIEFzeW5jU3VibWl0TWV0aG9kLFxyXG4gICAgR2V0Rm9ybUNvbnRyb2xDb21wb25lbnRUeXBlLFxyXG4gICAgSUR5bmFtaWNGb3JtTW9kdWxlQ29uZmlnLFxyXG59IGZyb20gXCIuL25neC1keW5hbWljLWZvcm0vY29tbW9uLXR5cGVzXCI7XHJcblxyXG5leHBvcnQge1xyXG4gICAgY3JlYXRlRm9ybUNoZWNrYm94LFxyXG4gICAgY3JlYXRlRm9ybURhdGUsXHJcbiAgICBjcmVhdGVGb3JtRWRpdG9yLFxyXG4gICAgY3JlYXRlRm9ybUFycmF5LFxyXG4gICAgY3JlYXRlRm9ybUdyb3VwLFxyXG4gICAgY3JlYXRlRm9ybUlucHV0LFxyXG4gICAgY3JlYXRlRm9ybVNlbGVjdCxcclxuICAgIGNyZWF0ZUZvcm1UZXh0YXJlYSxcclxuICAgIGNyZWF0ZUZvcm1GaWxlLFxyXG59IGZyb20gXCIuL25neC1keW5hbWljLWZvcm0vdXRpbHMvY3JlYXRvcnNcIjtcclxuXHJcbmV4cG9ydCB7XHJcbiAgICByZXBsYWNlU3BlY2lhbENoYXJzLFxyXG4gICAgbWVyZ2VGb3JtTW9kZWxzLFxyXG4gICAgTUlOX0lOUFVUX05VTSxcclxuICAgIE1BWF9JTlBVVF9OVU0sXHJcbiAgICBFRElUT1JfRk9STUFUU1xyXG59IGZyb20gXCIuL25neC1keW5hbWljLWZvcm0vdXRpbHMvbWlzY1wiO1xyXG5cclxuZXhwb3J0IHtcclxuICAgIHZhbGlkYXRlSlNPTixcclxuICAgIHZhbGlkYXRlUmVxdWlyZWRUcmFuc2xhdGlvbixcclxuICAgIHZhbGlkYXRlUGhvbmUsXHJcbiAgICB2YWxpZGF0ZUl0ZW1zTWluTGVuZ3RoLFxyXG4gICAgdmFsaWRhdGVJdGVtc01heExlbmd0aCxcclxuICAgIHZhbGlkYXRlSXRlbXNNaW5WYWx1ZSxcclxuICAgIHZhbGlkYXRlSXRlbXNNYXhWYWx1ZVxyXG59IGZyb20gXCIuL25neC1keW5hbWljLWZvcm0vdXRpbHMvdmFsaWRhdG9yc1wiO1xyXG5cclxuZXhwb3J0IHtcclxuICAgIER5bmFtaWNFZGl0b3JNb2RlbENvbmZpZyxcclxuICAgIER5bmFtaWNFZGl0b3JNb2RlbFxyXG59IGZyb20gXCIuL25neC1keW5hbWljLWZvcm0vdXRpbHMvZHluYW1pYy1lZGl0b3IubW9kZWxcIjtcclxuXHJcbmV4cG9ydCB7XHJcbiAgICBTYXZlVGFiRnVuYyxcclxuICAgIFJlc3RvcmVUYWJGdW5jLFxyXG4gICAgVGFiTGFiZWxGdW5jLFxyXG4gICAgRHluYW1pY0Zvcm1BcnJheUdyb3VwTW9kZWwsXHJcbiAgICBEeW5hbWljRm9ybUFycmF5TW9kZWxDb25maWcsXHJcbiAgICBEeW5hbWljRm9ybUFycmF5TW9kZWxcclxufSBmcm9tIFwiLi9uZ3gtZHluYW1pYy1mb3JtL3V0aWxzL2R5bmFtaWMtZm9ybS1hcnJheS5tb2RlbFwiO1xyXG5cclxuZXhwb3J0IHtcclxuICAgIER5bmFtaWNGb3JtT3B0aW9uQ29uZmlnLFxyXG4gICAgRHluYW1pY0Zvcm1PcHRpb24sXHJcbiAgICBEeW5hbWljRm9ybU9wdGlvbkdyb3VwLFxyXG4gICAgT3B0aW9uQ2xhc3Nlc0Z1bmMsXHJcbiAgICBEeW5hbWljU2VsZWN0TW9kZWxDb25maWcsXHJcbiAgICBEeW5hbWljU2VsZWN0TW9kZWxcclxufSBmcm9tIFwiLi9uZ3gtZHluYW1pYy1mb3JtL3V0aWxzL2R5bmFtaWMtc2VsZWN0Lm1vZGVsXCI7XHJcblxyXG5leHBvcnQge0Zvcm1TZWxlY3RTdWJqZWN0fSBmcm9tIFwiLi9uZ3gtZHluYW1pYy1mb3JtL3V0aWxzL2Zvcm0tc2VsZWN0LXN1YmplY3RcIjtcclxuZXhwb3J0IHtGb3JtU3ViamVjdH0gZnJvbSBcIi4vbmd4LWR5bmFtaWMtZm9ybS91dGlscy9mb3JtLXN1YmplY3RcIjtcclxuXHJcbmV4cG9ydCB7RHluYW1pY0Zvcm1TZXJ2aWNlfSBmcm9tIFwiLi9uZ3gtZHluYW1pYy1mb3JtL3NlcnZpY2VzL2R5bmFtaWMtZm9ybS5zZXJ2aWNlXCI7XHJcblxyXG5leHBvcnQge0FzeW5jU3VibWl0RGlyZWN0aXZlfSBmcm9tIFwiLi9uZ3gtZHluYW1pYy1mb3JtL2RpcmVjdGl2ZXMvYXN5bmMtc3VibWl0LmRpcmVjdGl2ZVwiO1xyXG5cclxuZXhwb3J0IHtEeW5hbWljQmFzZUZvcm1Db21wb25lbnR9IGZyb20gXCIuL25neC1keW5hbWljLWZvcm0vY29tcG9uZW50cy9iYXNlL2R5bmFtaWMtYmFzZS1mb3JtLmNvbXBvbmVudFwiO1xyXG5leHBvcnQge0R5bmFtaWNCYXNlRm9ybUFycmF5Q29tcG9uZW50fSBmcm9tIFwiLi9uZ3gtZHluYW1pYy1mb3JtL2NvbXBvbmVudHMvYmFzZS9keW5hbWljLWJhc2UtZm9ybS1hcnJheS5jb21wb25lbnRcIjtcclxuZXhwb3J0IHtcclxuICAgIER5bmFtaWNCYXNlRm9ybUNvbnRyb2xDb21wb25lbnRcclxufSBmcm9tIFwiLi9uZ3gtZHluYW1pYy1mb3JtL2NvbXBvbmVudHMvYmFzZS9keW5hbWljLWJhc2UtZm9ybS1jb250cm9sLmNvbXBvbmVudFwiO1xyXG5leHBvcnQge1xyXG4gICAgRHluYW1pY0Jhc2VGb3JtQ29udHJvbENvbnRhaW5lckNvbXBvbmVudFxyXG59IGZyb20gXCIuL25neC1keW5hbWljLWZvcm0vY29tcG9uZW50cy9iYXNlL2R5bmFtaWMtYmFzZS1mb3JtLWNvbnRyb2wtY29udGFpbmVyLmNvbXBvbmVudFwiO1xyXG5leHBvcnQge0R5bmFtaWNCYXNlRm9ybUdyb3VwQ29tcG9uZW50fSBmcm9tIFwiLi9uZ3gtZHluYW1pYy1mb3JtL2NvbXBvbmVudHMvYmFzZS9keW5hbWljLWJhc2UtZm9ybS1ncm91cC5jb21wb25lbnRcIjtcclxuZXhwb3J0IHtEeW5hbWljQmFzZVNlbGVjdENvbXBvbmVudH0gZnJvbSBcIi4vbmd4LWR5bmFtaWMtZm9ybS9jb21wb25lbnRzL2Jhc2UvZHluYW1pYy1iYXNlLXNlbGVjdC5jb21wb25lbnRcIjtcclxuXHJcbmV4cG9ydCB7Tmd4RHluYW1pY0Zvcm1Nb2R1bGV9IGZyb20gXCIuL25neC1keW5hbWljLWZvcm0vbmd4LWR5bmFtaWMtZm9ybS5tb2R1bGVcIjtcclxuXHJcbmV4cG9ydCB7XHJcbiAgICBEWU5BTUlDX0ZPUk1fQ09OVFJPTF9UWVBFX0FSUkFZLFxyXG4gICAgRFlOQU1JQ19GT1JNX0NPTlRST0xfVFlQRV9DSEVDS0JPWCxcclxuICAgIERZTkFNSUNfRk9STV9DT05UUk9MX1RZUEVfQ0hFQ0tCT1hfR1JPVVAsXHJcbiAgICBEWU5BTUlDX0ZPUk1fQ09OVFJPTF9UWVBFX0ZJTEVfVVBMT0FELFxyXG4gICAgRFlOQU1JQ19GT1JNX0NPTlRST0xfVFlQRV9HUk9VUCxcclxuICAgIERZTkFNSUNfRk9STV9DT05UUk9MX1RZUEVfSU5QVVQsXHJcbiAgICBEWU5BTUlDX0ZPUk1fQ09OVFJPTF9UWVBFX0RBVEVQSUNLRVIsXHJcbiAgICBEWU5BTUlDX0ZPUk1fQ09OVFJPTF9UWVBFX1JBRElPX0dST1VQLFxyXG4gICAgRFlOQU1JQ19GT1JNX0NPTlRST0xfVFlQRV9TRUxFQ1QsXHJcbiAgICBEWU5BTUlDX0ZPUk1fQ09OVFJPTF9UWVBFX1RFWFRBUkVBLFxyXG4gICAgRFlOQU1JQ19GT1JNX0NPTlRST0xfVFlQRV9FRElUT1IsXHJcbiAgICBEeW5hbWljVGVtcGxhdGVEaXJlY3RpdmUsXHJcbiAgICBEeW5hbWljTGlzdERpcmVjdGl2ZSxcclxuICAgIER5bmFtaWNGb3JtTW9kZWwsXHJcbiAgICBEeW5hbWljRm9ybUNvbnRyb2xNYXBGbixcclxuICAgIER5bmFtaWNGb3Jtc0NvcmVNb2R1bGUsXHJcbiAgICBEeW5hbWljQ2hlY2tib3hNb2RlbENvbmZpZyxcclxuICAgIER5bmFtaWNDaGVja2JveE1vZGVsLFxyXG4gICAgRHluYW1pY0NoZWNrYm94R3JvdXBNb2RlbCxcclxuICAgIER5bmFtaWNGaWxlVXBsb2FkTW9kZWxDb25maWcsXHJcbiAgICBEeW5hbWljRmlsZVVwbG9hZE1vZGVsLFxyXG4gICAgRHluYW1pY0Zvcm1Hcm91cE1vZGVsQ29uZmlnLFxyXG4gICAgRHluYW1pY0Zvcm1Hcm91cE1vZGVsLFxyXG4gICAgRHluYW1pY0lucHV0TW9kZWxDb25maWcsXHJcbiAgICBEeW5hbWljSW5wdXRNb2RlbCxcclxuICAgIER5bmFtaWNEYXRlUGlja2VyTW9kZWxDb25maWcsXHJcbiAgICBEeW5hbWljRGF0ZVBpY2tlck1vZGVsLFxyXG4gICAgRHluYW1pY1JhZGlvR3JvdXBNb2RlbENvbmZpZyxcclxuICAgIER5bmFtaWNSYWRpb0dyb3VwTW9kZWwsXHJcbiAgICBEeW5hbWljVGV4dEFyZWFNb2RlbENvbmZpZyxcclxuICAgIER5bmFtaWNUZXh0QXJlYU1vZGVsLFxyXG4gICAgRHluYW1pY0Zvcm1Db250cm9sQ29tcG9uZW50XHJcbn0gZnJvbSBcIkBuZy1keW5hbWljLWZvcm1zL2NvcmVcIjtcclxuIl19
|