@stemy/ngx-dynamic-form 10.2.18 → 10.2.22

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.
Files changed (32) hide show
  1. package/README.md +27 -27
  2. package/bundles/stemy-ngx-dynamic-form.umd.js +1400 -1390
  3. package/bundles/stemy-ngx-dynamic-form.umd.js.map +1 -1
  4. package/bundles/stemy-ngx-dynamic-form.umd.min.js +1 -1
  5. package/bundles/stemy-ngx-dynamic-form.umd.min.js.map +1 -1
  6. package/esm2015/ngx-dynamic-form/common-types.js +134 -134
  7. package/esm2015/ngx-dynamic-form/components/base/dynamic-base-form-control-container.component.js +91 -91
  8. package/esm2015/ngx-dynamic-form/components/base/dynamic-base-form.component.js +129 -129
  9. package/esm2015/ngx-dynamic-form/directives/async-submit.directive.js +100 -100
  10. package/esm2015/ngx-dynamic-form/ngx-dynamic-form.module.js +82 -82
  11. package/esm2015/ngx-dynamic-form/services/dynamic-form-validation.service.js +11 -11
  12. package/esm2015/ngx-dynamic-form/services/dynamic-form.service.js +393 -383
  13. package/esm2015/ngx-dynamic-form/utils/dynamic-form-array.model.js +8 -8
  14. package/esm2015/ngx-dynamic-form/utils/form-subject.js +18 -18
  15. package/esm2015/ngx-dynamic-form/utils/validators.js +28 -28
  16. package/esm2015/public_api.js +9 -9
  17. package/esm2015/stemy-ngx-dynamic-form.js +6 -6
  18. package/fesm2015/stemy-ngx-dynamic-form.js +936 -926
  19. package/fesm2015/stemy-ngx-dynamic-form.js.map +1 -1
  20. package/ngx-dynamic-form/common-types.d.ts +148 -148
  21. package/ngx-dynamic-form/components/base/dynamic-base-form-control-container.component.d.ts +37 -37
  22. package/ngx-dynamic-form/components/base/dynamic-base-form.component.d.ts +37 -37
  23. package/ngx-dynamic-form/directives/async-submit.directive.d.ts +27 -27
  24. package/ngx-dynamic-form/ngx-dynamic-form.module.d.ts +10 -10
  25. package/ngx-dynamic-form/services/dynamic-form-validation.service.d.ts +5 -5
  26. package/ngx-dynamic-form/services/dynamic-form.service.d.ts +40 -40
  27. package/ngx-dynamic-form/utils/dynamic-form-array.model.d.ts +12 -12
  28. package/ngx-dynamic-form/utils/form-subject.d.ts +8 -8
  29. package/ngx-dynamic-form/utils/validators.d.ts +4 -4
  30. package/package.json +12 -12
  31. package/public_api.d.ts +8 -8
  32. package/stemy-ngx-dynamic-form.d.ts +6 -6
@@ -1,134 +1,134 @@
1
- import { ObjectUtils, ReflectUtils, UniqueUtils } from "@stemy/ngx-utils";
2
- // --- Decorator functions ---
3
- const emptyArray = [];
4
- const emptyTester = () => {
5
- return Promise.resolve(false);
6
- };
7
- const ɵ0 = emptyTester;
8
- export function defaultSerializer(id, parent) {
9
- const control = parent.get(id);
10
- return !control ? null : control.value;
11
- }
12
- export function FormSerializable(serializer) {
13
- return (target, propertyKey) => {
14
- ReflectUtils.defineMetadata("dynamicFormSerializer", serializer || defaultSerializer, target, propertyKey);
15
- };
16
- }
17
- export function FormInput(data) {
18
- return (target, propertyKey) => {
19
- const meta = ReflectUtils.getOwnMetadata("design:type", target, propertyKey);
20
- const type = meta ? meta.name : "";
21
- let inputType = propertyKey.indexOf("password") < 0 ? "text" : "password";
22
- switch (type) {
23
- case "Number":
24
- inputType = "number";
25
- break;
26
- case "Boolean":
27
- inputType = "checkbox";
28
- break;
29
- }
30
- defineFormControl(target, propertyKey, createFormInput(propertyKey, data, inputType));
31
- };
32
- }
33
- export function FormSelect(data) {
34
- return (target, propertyKey) => {
35
- defineFormControl(target, propertyKey, createFormSelect(propertyKey, data));
36
- };
37
- }
38
- export function FormStatic(data) {
39
- return (target, propertyKey) => {
40
- defineFormControl(target, propertyKey, createFormStatic(propertyKey, data));
41
- };
42
- }
43
- export function FormModel(data) {
44
- return (target, propertyKey) => {
45
- defineFormControl(target, propertyKey, createFormModel(propertyKey, data));
46
- };
47
- }
48
- export function FormFile(data) {
49
- return (target, propertyKey) => {
50
- defineFormControl(target, propertyKey, createFormFile(propertyKey, data));
51
- };
52
- }
53
- export function FormFieldSet(data) {
54
- return (target) => {
55
- const sets = getFormFieldSets(target);
56
- data.classes = data.classes || "";
57
- sets[data.id] = data;
58
- ReflectUtils.defineMetadata("dynamicFormFieldSets", sets, target);
59
- };
60
- }
61
- export function defineFormControl(target, propertyKey, control) {
62
- ReflectUtils.defineMetadata("dynamicFormControl", control, target, propertyKey);
63
- }
64
- export function getFormFieldSets(target) {
65
- return ReflectUtils.getMetadata("dynamicFormFieldSets", target) || {};
66
- }
67
- export function getFormControl(target, propertyKey) {
68
- return ReflectUtils.getMetadata("dynamicFormControl", target, propertyKey);
69
- }
70
- export function getFormSerializer(target, propertyKey) {
71
- return ReflectUtils.getMetadata("dynamicFormSerializer", target, propertyKey);
72
- }
73
- export function createFormControl(id, type, data) {
74
- data = data || {};
75
- data.label = ObjectUtils.isNullOrUndefined(data.label) ? id : data.label;
76
- data.labelAlign = data.labelAlign || "left";
77
- data.fieldSet = data.fieldSet || UniqueUtils.uuid();
78
- data.classes = data.classes || "";
79
- data.readonly = data.readonly || emptyTester;
80
- data.hidden = data.hidden || emptyTester;
81
- data.validators = data.validators || emptyArray;
82
- return {
83
- id: id,
84
- type: type,
85
- data: data
86
- };
87
- }
88
- export function createFormInput(id, data, type = "text") {
89
- const control = createFormControl(id, "input", data);
90
- data = control.data;
91
- data.type = data.type || type;
92
- data.classes = !data.classes ? `form-group-${data.type}` : `${data.classes} form-group-${data.type}`;
93
- data.placeholder = data.placeholder || (data.type == "mask" ? "_" : "");
94
- data.step = data.step || 1;
95
- data.mask = data.mask || [/\w*/gi];
96
- return control;
97
- }
98
- export function createFormSelect(id, data) {
99
- const control = createFormControl(id, "select", data);
100
- data = control.data;
101
- data.options = data.options || [];
102
- data.type = data.type || "select";
103
- const classType = data.type == "select" ? "select" : `select-${data.type}`;
104
- data.classes = !data.classes ? `form-group-${classType}` : `${data.classes} form-group-${classType}`;
105
- return control;
106
- }
107
- export function createFormStatic(id, data) {
108
- const control = createFormControl(id, "static", data);
109
- data = control.data;
110
- data.style = data.style || "table";
111
- return control;
112
- }
113
- export function createFormModel(id, data) {
114
- const control = createFormControl(id, "model", data);
115
- data = control.data;
116
- data.name = data.name || "";
117
- return control;
118
- }
119
- export function createFormFile(id, data) {
120
- const control = createFormControl(id, "file", data);
121
- data = control.data;
122
- data.accept = data.accept || ".jpg,.jpeg,.png";
123
- data.multi = data.multi || false;
124
- data.baseUrl = ObjectUtils.isString(data.baseUrl) ? data.baseUrl : "assets/";
125
- data.uploadUrl = ObjectUtils.isString(data.uploadUrl) ? data.uploadUrl : "assets";
126
- data.createUploadData = data.createUploadData || ((file) => {
127
- const form = new FormData();
128
- form.append("file", file);
129
- return form;
130
- });
131
- return control;
132
- }
133
- export { ɵ0 };
134
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"common-types.js","sourceRoot":"","sources":["../../../src/ngx-dynamic-form/common-types.ts"],"names":[],"mappings":"AAUA,OAAO,EAIH,WAAW,EACX,YAAY,EACZ,WAAW,EACd,MAAM,kBAAkB,CAAC;AAkK1B,8BAA8B;AAC9B,MAAM,UAAU,GAAQ,EAAE,CAAC;AAC3B,MAAM,WAAW,GAAsB,GAAG,EAAE;IACxC,OAAO,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;AAClC,CAAC,CAAC;;AAEF,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,UAAqD;IAClF,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,IAAqB;IAC3C,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,IAAsB;IAC7C,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,IAAsB;IAC7C,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,IAAqB;IAC3C,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,IAAoB;IACzC,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,YAAY,CAAC,IAAmB;IAC5C,OAAO,CAAC,MAAW,EAAQ,EAAE;QACzB,MAAM,IAAI,GAAG,gBAAgB,CAAC,MAAM,CAAC,CAAC;QACtC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,IAAI,EAAE,CAAC;QAClC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC;QACrB,YAAY,CAAC,cAAc,CAAC,sBAAsB,EAAE,IAAI,EAAE,MAAM,CAAC,CAAC;IACtE,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,gBAAgB,CAAC,MAAW;IACxC,OAAO,YAAY,CAAC,WAAW,CAAC,sBAAsB,EAAE,MAAM,CAAC,IAAI,EAAE,CAAC;AAC1E,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,IAAuB;IAC/E,IAAI,GAAG,IAAI,IAAI,EAAE,CAAC;IAClB,IAAI,CAAC,KAAK,GAAG,WAAW,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC;IACzE,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,IAAI,MAAM,CAAC;IAC5C,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,IAAI,WAAW,CAAC,IAAI,EAAE,CAAC;IACpD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,IAAI,EAAE,CAAC;IAClC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,IAAI,WAAW,CAAC;IAC7C,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,IAAI,WAAW,CAAC;IACzC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,IAAI,UAAU,CAAC;IAChD,OAAO;QACH,EAAE,EAAE,EAAE;QACN,IAAI,EAAE,IAAI;QACV,IAAI,EAAE,IAAI;KACb,CAAC;AACN,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,EAAU,EAAE,IAAoB,EAAE,OAAe,MAAM;IACnF,MAAM,OAAO,GAAG,iBAAiB,CAAC,EAAE,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;IACrD,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;IACpB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC;IAC9B,IAAI,CAAC,OAAO,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,cAAc,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,OAAO,eAAe,IAAI,CAAC,IAAI,EAAE,CAAC;IACrG,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;IACxE,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,IAAI,CAAC,CAAC;IAC3B,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,CAAC;IACnC,OAAO,OAAO,CAAC;AACnB,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,EAAU,EAAE,IAAqB;IAC9D,MAAM,OAAO,GAAG,iBAAiB,CAAC,EAAE,EAAE,QAAQ,EAAE,IAAI,CAAC,CAAC;IACtD,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;IACpB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,IAAI,EAAE,CAAC;IAClC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,IAAI,QAAQ,CAAC;IAClC,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,IAAI,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,UAAU,IAAI,CAAC,IAAI,EAAE,CAAC;IAC3E,IAAI,CAAC,OAAO,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,cAAc,SAAS,EAAE,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,OAAO,eAAe,SAAS,EAAE,CAAC;IACrG,OAAO,OAAO,CAAC;AACnB,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,EAAU,EAAE,IAAqB;IAC9D,MAAM,OAAO,GAAG,iBAAiB,CAAC,EAAE,EAAE,QAAQ,EAAE,IAAI,CAAC,CAAC;IACtD,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;IACpB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,IAAI,OAAO,CAAC;IACnC,OAAO,OAAO,CAAC;AACnB,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,EAAU,EAAE,IAAoB;IAC5D,MAAM,OAAO,GAAG,iBAAiB,CAAC,EAAE,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;IACrD,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;IACpB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,IAAI,EAAE,CAAC;IAC5B,OAAO,OAAO,CAAC;AACnB,CAAC;AAED,MAAM,UAAU,cAAc,CAAC,EAAU,EAAE,IAAmB;IAC1D,MAAM,OAAO,GAAG,iBAAiB,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,CAAC,CAAC;IACpD,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;IACpB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,IAAI,iBAAiB,CAAC;IAC/C,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,IAAI,KAAK,CAAC;IACjC,IAAI,CAAC,OAAO,GAAG,WAAW,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC;IAC7E,IAAI,CAAC,SAAS,GAAG,WAAW,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC;IAClF,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,IAAI,CAAC,CAAC,IAAU,EAAE,EAAE;QAC7D,MAAM,IAAI,GAAG,IAAI,QAAQ,EAAE,CAAC;QAC5B,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;QAC1B,OAAO,IAAI,CAAC;IAChB,CAAC,CAAC,CAAC;IACH,OAAO,OAAO,CAAC;AACnB,CAAC","sourcesContent":["import {EventEmitter, TemplateRef} from \"@angular/core\";\nimport {AbstractControl, FormArray} from \"@angular/forms\";\nimport {Observable} from \"rxjs\";\nimport {\n    DynamicFormControl,\n    DynamicFormOptionConfig,\n    DynamicFormValueControlModel,\n    DynamicValidatorDescriptor,\n    DynamicValidatorsConfig\n} from \"@ng-dynamic-forms/core\";\nimport {\n    IAsyncMessage,\n    IRequestOptions,\n    IResolveFactory,\n    ObjectUtils,\n    ReflectUtils,\n    UniqueUtils\n} from \"@stemy/ngx-utils\";\n\n// --- Basic form control interfaces ---\n\nexport interface IDynamicFormBase {\n\n    status: DynamicFormState;\n\n    onStatusChange: EventEmitter<IDynamicFormBase>;\n    onValueChange: EventEmitter<IDynamicFormBase>;\n    onSubmit: EventEmitter<IDynamicFormBase>;\n\n    validate(): Promise<any>;\n    serialize(validate?: boolean): Promise<any>;\n}\n\nexport interface IDynamicForm extends IDynamicFormBase{\n\n}\n\nexport interface OnCreatedFormControl extends DynamicFormControl {\n    onCreated(): any;\n}\n\nexport type IFormControlSerializer = (model: DynamicFormValueControlModel<any>, control: AbstractControl) => Promise<any>;\nexport type IFormInputMask = string | RegExp;\nexport type IFormInputMaskFunction = (raw: string) => IFormInputMask[];\nexport type IFormInputUnMaskFunction = (value: string) => any;\n\nexport interface IFormSerializer {\n    id: string;\n    func: IFormControlSerializer;\n}\n\nexport interface IFormSerializers {\n    [id: string]: IFormControlSerializer | IResolveFactory | null\n}\n\nexport type DynamicFormState = \"VALID\" | \"INVALID\" | \"PENDING\" | \"DISABLED\" | \"LOADING\";\nexport type DynamicFormUpdateOn = \"change\" | \"blur\" | \"submit\";\n\nexport interface IFormControl {\n    id: string;\n    type: string;\n    visible?: boolean;\n    data?: IFormControlData;\n}\n\nexport interface IFormControlData {\n    label?: string;\n    labelAlign?: string;\n    fieldSet?: string;\n    classes?: string;\n    readonly?: FormControlTesterFactory;\n    hidden?: FormControlTesterFactory;\n    shouldSerialize?: FormControlTesterFactory;\n    shouldValidate?: FormControlTesterFactory;\n    validator?: DynamicValidatorDescriptor;\n    validators?: DynamicValidatorsConfig;\n    updateOn?: DynamicFormUpdateOn;\n    reload?: string | string[];\n}\n\nexport interface IFormInputData extends IFormControlData {\n    type?: string;\n    autocomplete?: string;\n    placeholder?: string;\n    useLanguage?: boolean;\n    mask?: IFormInputMaskFunction | IFormInputMask[];\n    unmask?: IFormInputUnMaskFunction;\n    step?: number;\n    min?: number;\n    max?: number;\n}\n\nexport interface IFormSelectData extends IFormControlData {\n    options?: DynamicFormOptionConfig<any>[] | Observable<DynamicFormOptionConfig<any>[]>;\n    emptyOption?: boolean;\n    type?: string;\n    multi?: boolean;\n}\n\nexport interface IFormStaticData extends IFormControlData {\n    properties?: string[];\n    style?: string;\n}\n\nexport interface IFormFileData extends IFormControlData {\n    accept?: string;\n    multi?: boolean;\n    baseUrl?: string;\n    asFile?: boolean;\n    asDataUrl?: boolean;\n    uploadUrl?: string;\n    uploadOptions?: IRequestOptions;\n    createUploadData?: (file: File) => any;\n}\n\nexport interface IFormModelData extends IFormControlData, IDynamicFormInfo {\n\n}\n\nexport interface IFormFieldSet {\n    id: string;\n    classes?: string;\n    title?: string;\n    titleClasses?: string;\n    setClasses?: string;\n    controlClasses?: string;\n}\n\nexport interface IFormControlOption {\n    id: any;\n    label: string;\n    selectable?: boolean;\n}\n\n// --- Basic form interfaces ---\n\nexport interface IDynamicFormTemplates {\n    [id: string]: TemplateRef<any>;\n}\n\nexport interface IDynamicFormConfig {\n    path?: string | number | Array<string | number>;\n    name?: string;\n    classes?: string;\n    formClasses?: string;\n    innerFormClasses?: string;\n    id: string;\n}\n\nexport interface IDynamicSingleFormConfig extends IDynamicFormConfig, IDynamicFormInfo {\n    data: any;\n    controlData?: IFormControlData;\n    multi?: false;\n}\n\nexport interface IDynamicMultiFormConfig extends IDynamicFormConfig {\n    data: IDynamicFormsConfigs;\n    multi: true;\n}\n\nexport type IDynamicFormsConfigs = Array<IDynamicSingleFormConfig | IDynamicMultiFormConfig>;\n\nexport declare type AsyncSubmitMethod = (form: IDynamicFormBase, context?: any) => Promise<IAsyncMessage>;\n\nexport interface IDynamicFormInfo {\n    name?: string;\n    controls?: IFormControl[];\n    serializers?: IFormSerializers;\n    fieldSets?: IFormFieldSet[];\n}\n\nexport interface IDynamicFormFieldSets {\n    [id: string]: IFormFieldSet\n}\n\n// --- Basic form types ---\nexport type FormControlTester = (control: AbstractControl) => Promise<boolean>;\nexport type FormControlTesterFactory = FormControlTester | IResolveFactory;\n\n// --- Decorator functions ---\nconst emptyArray: any = [];\nconst emptyTester: FormControlTester = () => {\n    return Promise.resolve(false);\n};\n\nexport function defaultSerializer(id: string, parent: FormArray): Promise<any> {\n    const control = parent.get(id);\n    return !control ? null: control.value;\n}\n\nexport function FormSerializable(serializer?: IFormControlSerializer | IResolveFactory): PropertyDecorator {\n    return (target: any, propertyKey: string): void => {\n        ReflectUtils.defineMetadata(\"dynamicFormSerializer\", serializer || defaultSerializer, target, propertyKey);\n    };\n}\n\nexport function FormInput(data?: IFormInputData): PropertyDecorator {\n    return (target: any, propertyKey: string): void => {\n        const meta = ReflectUtils.getOwnMetadata(\"design:type\", target, propertyKey);\n        const type = meta ? meta.name : \"\";\n        let inputType = propertyKey.indexOf(\"password\") < 0 ? \"text\" : \"password\";\n        switch (type) {\n            case \"Number\":\n                inputType = \"number\";\n                break;\n            case \"Boolean\":\n                inputType = \"checkbox\";\n                break;\n        }\n        defineFormControl(target, propertyKey, createFormInput(propertyKey, data, inputType));\n    };\n}\n\nexport function FormSelect(data?: IFormSelectData): PropertyDecorator {\n    return (target: any, propertyKey: string): void => {\n        defineFormControl(target, propertyKey, createFormSelect(propertyKey, data));\n    };\n}\n\nexport function FormStatic(data?: IFormStaticData): PropertyDecorator {\n    return (target: any, propertyKey: string): void => {\n        defineFormControl(target, propertyKey, createFormStatic(propertyKey, data));\n    };\n}\n\nexport function FormModel(data?: IFormModelData): PropertyDecorator {\n    return (target: any, propertyKey: string): void => {\n        defineFormControl(target, propertyKey, createFormModel(propertyKey, data));\n    };\n}\n\nexport function FormFile(data?: IFormFileData): PropertyDecorator {\n    return (target: any, propertyKey: string): void => {\n        defineFormControl(target, propertyKey, createFormFile(propertyKey, data));\n    };\n}\n\nexport function FormFieldSet(data: IFormFieldSet): ClassDecorator {\n    return (target: any): void => {\n        const sets = getFormFieldSets(target);\n        data.classes = data.classes || \"\";\n        sets[data.id] = data;\n        ReflectUtils.defineMetadata(\"dynamicFormFieldSets\", sets, target);\n    };\n}\n\nexport function defineFormControl(target: any, propertyKey: string, control: IFormControl): void {\n    ReflectUtils.defineMetadata(\"dynamicFormControl\", control, target, propertyKey);\n}\n\nexport function getFormFieldSets(target: any): IDynamicFormFieldSets {\n    return ReflectUtils.getMetadata(\"dynamicFormFieldSets\", target) || {};\n}\n\nexport function getFormControl(target: any, propertyKey: string): IFormControl {\n    return ReflectUtils.getMetadata(\"dynamicFormControl\", target, propertyKey);\n}\n\nexport function getFormSerializer(target: any, propertyKey: string): IFormControlSerializer | IResolveFactory {\n    return ReflectUtils.getMetadata(\"dynamicFormSerializer\", target, propertyKey);\n}\n\nexport function createFormControl(id: string, type: string, data?: IFormControlData): IFormControl {\n    data = data || {};\n    data.label = ObjectUtils.isNullOrUndefined(data.label) ? id : data.label;\n    data.labelAlign = data.labelAlign || \"left\";\n    data.fieldSet = data.fieldSet || UniqueUtils.uuid();\n    data.classes = data.classes || \"\";\n    data.readonly = data.readonly || emptyTester;\n    data.hidden = data.hidden || emptyTester;\n    data.validators = data.validators || emptyArray;\n    return {\n        id: id,\n        type: type,\n        data: data\n    };\n}\n\nexport function createFormInput(id: string, data: IFormInputData, type: string = \"text\"): IFormControl {\n    const control = createFormControl(id, \"input\", data);\n    data = control.data;\n    data.type = data.type || type;\n    data.classes = !data.classes ? `form-group-${data.type}` : `${data.classes} form-group-${data.type}`;\n    data.placeholder = data.placeholder || (data.type == \"mask\" ? \"_\" : \"\");\n    data.step = data.step || 1;\n    data.mask = data.mask || [/\\w*/gi];\n    return control;\n}\n\nexport function createFormSelect(id: string, data: IFormSelectData): IFormControl {\n    const control = createFormControl(id, \"select\", data);\n    data = control.data;\n    data.options = data.options || [];\n    data.type = data.type || \"select\";\n    const classType = data.type == \"select\" ? \"select\" : `select-${data.type}`;\n    data.classes = !data.classes ? `form-group-${classType}` : `${data.classes} form-group-${classType}`;\n    return control;\n}\n\nexport function createFormStatic(id: string, data: IFormStaticData): IFormControl {\n    const control = createFormControl(id, \"static\", data);\n    data = control.data;\n    data.style = data.style || \"table\";\n    return control;\n}\n\nexport function createFormModel(id: string, data: IFormModelData): IFormControl {\n    const control = createFormControl(id, \"model\", data);\n    data = control.data;\n    data.name = data.name || \"\";\n    return control;\n}\n\nexport function createFormFile(id: string, data: IFormFileData): IFormControl {\n    const control = createFormControl(id, \"file\", data);\n    data = control.data;\n    data.accept = data.accept || \".jpg,.jpeg,.png\";\n    data.multi = data.multi || false;\n    data.baseUrl = ObjectUtils.isString(data.baseUrl) ? data.baseUrl : \"assets/\";\n    data.uploadUrl = ObjectUtils.isString(data.uploadUrl) ? data.uploadUrl : \"assets\";\n    data.createUploadData = data.createUploadData || ((file: File) => {\n        const form = new FormData();\n        form.append(\"file\", file);\n        return form;\n    });\n    return control;\n}\n"]}
1
+ import { ObjectUtils, ReflectUtils, UniqueUtils } from "@stemy/ngx-utils";
2
+ // --- Decorator functions ---
3
+ const emptyArray = [];
4
+ const emptyTester = () => {
5
+ return Promise.resolve(false);
6
+ };
7
+ const ɵ0 = emptyTester;
8
+ export function defaultSerializer(id, parent) {
9
+ const control = parent.get(id);
10
+ return !control ? null : control.value;
11
+ }
12
+ export function FormSerializable(serializer) {
13
+ return (target, propertyKey) => {
14
+ ReflectUtils.defineMetadata("dynamicFormSerializer", serializer || defaultSerializer, target, propertyKey);
15
+ };
16
+ }
17
+ export function FormInput(data) {
18
+ return (target, propertyKey) => {
19
+ const meta = ReflectUtils.getOwnMetadata("design:type", target, propertyKey);
20
+ const type = meta ? meta.name : "";
21
+ let inputType = propertyKey.indexOf("password") < 0 ? "text" : "password";
22
+ switch (type) {
23
+ case "Number":
24
+ inputType = "number";
25
+ break;
26
+ case "Boolean":
27
+ inputType = "checkbox";
28
+ break;
29
+ }
30
+ defineFormControl(target, propertyKey, createFormInput(propertyKey, data, inputType));
31
+ };
32
+ }
33
+ export function FormSelect(data) {
34
+ return (target, propertyKey) => {
35
+ defineFormControl(target, propertyKey, createFormSelect(propertyKey, data));
36
+ };
37
+ }
38
+ export function FormStatic(data) {
39
+ return (target, propertyKey) => {
40
+ defineFormControl(target, propertyKey, createFormStatic(propertyKey, data));
41
+ };
42
+ }
43
+ export function FormModel(data) {
44
+ return (target, propertyKey) => {
45
+ defineFormControl(target, propertyKey, createFormModel(propertyKey, data));
46
+ };
47
+ }
48
+ export function FormFile(data) {
49
+ return (target, propertyKey) => {
50
+ defineFormControl(target, propertyKey, createFormFile(propertyKey, data));
51
+ };
52
+ }
53
+ export function FormFieldSet(data) {
54
+ return (target) => {
55
+ const sets = getFormFieldSets(target);
56
+ data.classes = data.classes || "";
57
+ sets[data.id] = data;
58
+ ReflectUtils.defineMetadata("dynamicFormFieldSets", sets, target);
59
+ };
60
+ }
61
+ export function defineFormControl(target, propertyKey, control) {
62
+ ReflectUtils.defineMetadata("dynamicFormControl", control, target, propertyKey);
63
+ }
64
+ export function getFormFieldSets(target) {
65
+ return ReflectUtils.getMetadata("dynamicFormFieldSets", target) || {};
66
+ }
67
+ export function getFormControl(target, propertyKey) {
68
+ return ReflectUtils.getMetadata("dynamicFormControl", target, propertyKey);
69
+ }
70
+ export function getFormSerializer(target, propertyKey) {
71
+ return ReflectUtils.getMetadata("dynamicFormSerializer", target, propertyKey);
72
+ }
73
+ export function createFormControl(id, type, data) {
74
+ data = data || {};
75
+ data.label = ObjectUtils.isNullOrUndefined(data.label) ? id : data.label;
76
+ data.labelAlign = data.labelAlign || "left";
77
+ data.fieldSet = data.fieldSet || UniqueUtils.uuid();
78
+ data.classes = data.classes || "";
79
+ data.readonly = data.readonly || emptyTester;
80
+ data.hidden = data.hidden || emptyTester;
81
+ data.validators = data.validators || emptyArray;
82
+ return {
83
+ id: id,
84
+ type: type,
85
+ data: data
86
+ };
87
+ }
88
+ export function createFormInput(id, data, type = "text") {
89
+ const control = createFormControl(id, "input", data);
90
+ data = control.data;
91
+ data.type = data.type || type;
92
+ data.classes = !data.classes ? `form-group-${data.type}` : `${data.classes} form-group-${data.type}`;
93
+ data.placeholder = data.placeholder || (data.type == "mask" ? "_" : "");
94
+ data.step = data.step || 1;
95
+ data.mask = data.mask || [/\w*/gi];
96
+ return control;
97
+ }
98
+ export function createFormSelect(id, data) {
99
+ const control = createFormControl(id, "select", data);
100
+ data = control.data;
101
+ data.options = data.options || [];
102
+ data.type = data.type || "select";
103
+ const classType = data.type == "select" ? "select" : `select-${data.type}`;
104
+ data.classes = !data.classes ? `form-group-${classType}` : `${data.classes} form-group-${classType}`;
105
+ return control;
106
+ }
107
+ export function createFormStatic(id, data) {
108
+ const control = createFormControl(id, "static", data);
109
+ data = control.data;
110
+ data.style = data.style || "table";
111
+ return control;
112
+ }
113
+ export function createFormModel(id, data) {
114
+ const control = createFormControl(id, "model", data);
115
+ data = control.data;
116
+ data.name = data.name || "";
117
+ return control;
118
+ }
119
+ export function createFormFile(id, data) {
120
+ const control = createFormControl(id, "file", data);
121
+ data = control.data;
122
+ data.accept = data.accept || ".jpg,.jpeg,.png";
123
+ data.multi = data.multi || false;
124
+ data.baseUrl = ObjectUtils.isString(data.baseUrl) ? data.baseUrl : "assets/";
125
+ data.uploadUrl = ObjectUtils.isString(data.uploadUrl) ? data.uploadUrl : "assets";
126
+ data.createUploadData = data.createUploadData || ((file) => {
127
+ const form = new FormData();
128
+ form.append("file", file);
129
+ return form;
130
+ });
131
+ return control;
132
+ }
133
+ export { ɵ0 };
134
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"common-types.js","sourceRoot":"","sources":["../../../src/ngx-dynamic-form/common-types.ts"],"names":[],"mappings":"AAUA,OAAO,EAIH,WAAW,EACX,YAAY,EACZ,WAAW,EACd,MAAM,kBAAkB,CAAC;AAkK1B,8BAA8B;AAC9B,MAAM,UAAU,GAAQ,EAAE,CAAC;AAC3B,MAAM,WAAW,GAAsB,GAAG,EAAE;IACxC,OAAO,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;AAClC,CAAC,CAAC;;AAEF,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,UAAqD;IAClF,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,IAAqB;IAC3C,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,IAAsB;IAC7C,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,IAAsB;IAC7C,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,IAAqB;IAC3C,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,IAAoB;IACzC,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,YAAY,CAAC,IAAmB;IAC5C,OAAO,CAAC,MAAW,EAAQ,EAAE;QACzB,MAAM,IAAI,GAAG,gBAAgB,CAAC,MAAM,CAAC,CAAC;QACtC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,IAAI,EAAE,CAAC;QAClC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC;QACrB,YAAY,CAAC,cAAc,CAAC,sBAAsB,EAAE,IAAI,EAAE,MAAM,CAAC,CAAC;IACtE,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,gBAAgB,CAAC,MAAW;IACxC,OAAO,YAAY,CAAC,WAAW,CAAC,sBAAsB,EAAE,MAAM,CAAC,IAAI,EAAE,CAAC;AAC1E,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,IAAuB;IAC/E,IAAI,GAAG,IAAI,IAAI,EAAE,CAAC;IAClB,IAAI,CAAC,KAAK,GAAG,WAAW,CAAC,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC;IACzE,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,IAAI,MAAM,CAAC;IAC5C,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,IAAI,WAAW,CAAC,IAAI,EAAE,CAAC;IACpD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,IAAI,EAAE,CAAC;IAClC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,IAAI,WAAW,CAAC;IAC7C,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,IAAI,WAAW,CAAC;IACzC,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,IAAI,UAAU,CAAC;IAChD,OAAO;QACH,EAAE,EAAE,EAAE;QACN,IAAI,EAAE,IAAI;QACV,IAAI,EAAE,IAAI;KACb,CAAC;AACN,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,EAAU,EAAE,IAAoB,EAAE,OAAe,MAAM;IACnF,MAAM,OAAO,GAAG,iBAAiB,CAAC,EAAE,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;IACrD,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;IACpB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC;IAC9B,IAAI,CAAC,OAAO,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,cAAc,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,OAAO,eAAe,IAAI,CAAC,IAAI,EAAE,CAAC;IACrG,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;IACxE,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,IAAI,CAAC,CAAC;IAC3B,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,CAAC;IACnC,OAAO,OAAO,CAAC;AACnB,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,EAAU,EAAE,IAAqB;IAC9D,MAAM,OAAO,GAAG,iBAAiB,CAAC,EAAE,EAAE,QAAQ,EAAE,IAAI,CAAC,CAAC;IACtD,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;IACpB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,IAAI,EAAE,CAAC;IAClC,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,IAAI,QAAQ,CAAC;IAClC,MAAM,SAAS,GAAG,IAAI,CAAC,IAAI,IAAI,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,UAAU,IAAI,CAAC,IAAI,EAAE,CAAC;IAC3E,IAAI,CAAC,OAAO,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,cAAc,SAAS,EAAE,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,OAAO,eAAe,SAAS,EAAE,CAAC;IACrG,OAAO,OAAO,CAAC;AACnB,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,EAAU,EAAE,IAAqB;IAC9D,MAAM,OAAO,GAAG,iBAAiB,CAAC,EAAE,EAAE,QAAQ,EAAE,IAAI,CAAC,CAAC;IACtD,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;IACpB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,IAAI,OAAO,CAAC;IACnC,OAAO,OAAO,CAAC;AACnB,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,EAAU,EAAE,IAAoB;IAC5D,MAAM,OAAO,GAAG,iBAAiB,CAAC,EAAE,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;IACrD,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;IACpB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,IAAI,EAAE,CAAC;IAC5B,OAAO,OAAO,CAAC;AACnB,CAAC;AAED,MAAM,UAAU,cAAc,CAAC,EAAU,EAAE,IAAmB;IAC1D,MAAM,OAAO,GAAG,iBAAiB,CAAC,EAAE,EAAE,MAAM,EAAE,IAAI,CAAC,CAAC;IACpD,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;IACpB,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,MAAM,IAAI,iBAAiB,CAAC;IAC/C,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,IAAI,KAAK,CAAC;IACjC,IAAI,CAAC,OAAO,GAAG,WAAW,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC;IAC7E,IAAI,CAAC,SAAS,GAAG,WAAW,CAAC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,QAAQ,CAAC;IAClF,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,IAAI,CAAC,CAAC,IAAU,EAAE,EAAE;QAC7D,MAAM,IAAI,GAAG,IAAI,QAAQ,EAAE,CAAC;QAC5B,IAAI,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,CAAC;QAC1B,OAAO,IAAI,CAAC;IAChB,CAAC,CAAC,CAAC;IACH,OAAO,OAAO,CAAC;AACnB,CAAC","sourcesContent":["import {EventEmitter, TemplateRef} from \"@angular/core\";\r\nimport {AbstractControl, FormArray} from \"@angular/forms\";\r\nimport {Observable} from \"rxjs\";\r\nimport {\r\n    DynamicFormControl,\r\n    DynamicFormOptionConfig,\r\n    DynamicFormValueControlModel,\r\n    DynamicValidatorDescriptor,\r\n    DynamicValidatorsConfig\r\n} from \"@ng-dynamic-forms/core\";\r\nimport {\r\n    IAsyncMessage,\r\n    IRequestOptions,\r\n    IResolveFactory,\r\n    ObjectUtils,\r\n    ReflectUtils,\r\n    UniqueUtils\r\n} from \"@stemy/ngx-utils\";\r\n\r\n// --- Basic form control interfaces ---\r\n\r\nexport interface IDynamicFormBase {\r\n\r\n    status: DynamicFormState;\r\n\r\n    onStatusChange: EventEmitter<IDynamicFormBase>;\r\n    onValueChange: EventEmitter<IDynamicFormBase>;\r\n    onSubmit: EventEmitter<IDynamicFormBase>;\r\n\r\n    validate(): Promise<any>;\r\n    serialize(validate?: boolean): Promise<any>;\r\n}\r\n\r\nexport interface IDynamicForm extends IDynamicFormBase{\r\n\r\n}\r\n\r\nexport interface OnCreatedFormControl extends DynamicFormControl {\r\n    onCreated(): any;\r\n}\r\n\r\nexport type IFormControlSerializer = (model: DynamicFormValueControlModel<any>, control: AbstractControl) => Promise<any>;\r\nexport type IFormInputMask = string | RegExp;\r\nexport type IFormInputMaskFunction = (raw: string) => IFormInputMask[];\r\nexport type IFormInputUnMaskFunction = (value: string) => any;\r\n\r\nexport interface IFormSerializer {\r\n    id: string;\r\n    func: IFormControlSerializer;\r\n}\r\n\r\nexport interface IFormSerializers {\r\n    [id: string]: IFormControlSerializer | IResolveFactory | null\r\n}\r\n\r\nexport type DynamicFormState = \"VALID\" | \"INVALID\" | \"PENDING\" | \"DISABLED\" | \"LOADING\";\r\nexport type DynamicFormUpdateOn = \"change\" | \"blur\" | \"submit\";\r\n\r\nexport interface IFormControl {\r\n    id: string;\r\n    type: string;\r\n    visible?: boolean;\r\n    data?: IFormControlData;\r\n}\r\n\r\nexport interface IFormControlData {\r\n    label?: string;\r\n    labelAlign?: string;\r\n    fieldSet?: string;\r\n    classes?: string;\r\n    readonly?: FormControlTesterFactory;\r\n    hidden?: FormControlTesterFactory;\r\n    shouldSerialize?: FormControlTesterFactory;\r\n    shouldValidate?: FormControlTesterFactory;\r\n    validator?: DynamicValidatorDescriptor;\r\n    validators?: DynamicValidatorsConfig;\r\n    updateOn?: DynamicFormUpdateOn;\r\n    reload?: string | string[];\r\n}\r\n\r\nexport interface IFormInputData extends IFormControlData {\r\n    type?: string;\r\n    autocomplete?: string;\r\n    placeholder?: string;\r\n    useLanguage?: boolean;\r\n    mask?: IFormInputMaskFunction | IFormInputMask[];\r\n    unmask?: IFormInputUnMaskFunction;\r\n    step?: number;\r\n    min?: number;\r\n    max?: number;\r\n}\r\n\r\nexport interface IFormSelectData extends IFormControlData {\r\n    options?: DynamicFormOptionConfig<any>[] | Observable<DynamicFormOptionConfig<any>[]>;\r\n    emptyOption?: boolean;\r\n    type?: string;\r\n    multi?: boolean;\r\n}\r\n\r\nexport interface IFormStaticData extends IFormControlData {\r\n    properties?: string[];\r\n    style?: string;\r\n}\r\n\r\nexport interface IFormFileData extends IFormControlData {\r\n    accept?: string;\r\n    multi?: boolean;\r\n    baseUrl?: string;\r\n    asFile?: boolean;\r\n    asDataUrl?: boolean;\r\n    uploadUrl?: string;\r\n    uploadOptions?: IRequestOptions;\r\n    createUploadData?: (file: File) => any;\r\n}\r\n\r\nexport interface IFormModelData extends IFormControlData, IDynamicFormInfo {\r\n\r\n}\r\n\r\nexport interface IFormFieldSet {\r\n    id: string;\r\n    classes?: string;\r\n    title?: string;\r\n    titleClasses?: string;\r\n    setClasses?: string;\r\n    controlClasses?: string;\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?: IFormControlData;\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: IDynamicFormBase, context?: any) => Promise<IAsyncMessage>;\r\n\r\nexport interface IDynamicFormInfo {\r\n    name?: string;\r\n    controls?: IFormControl[];\r\n    serializers?: IFormSerializers;\r\n    fieldSets?: IFormFieldSet[];\r\n}\r\n\r\nexport interface IDynamicFormFieldSets {\r\n    [id: string]: IFormFieldSet\r\n}\r\n\r\n// --- Basic form types ---\r\nexport type FormControlTester = (control: AbstractControl) => Promise<boolean>;\r\nexport type FormControlTesterFactory = FormControlTester | IResolveFactory;\r\n\r\n// --- Decorator functions ---\r\nconst emptyArray: any = [];\r\nconst emptyTester: FormControlTester = () => {\r\n    return Promise.resolve(false);\r\n};\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?: IFormControlSerializer | 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?: IFormInputData): 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?: IFormSelectData): 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?: IFormStaticData): 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?: IFormModelData): 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?: IFormFileData): 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 FormFieldSet(data: IFormFieldSet): ClassDecorator {\r\n    return (target: any): void => {\r\n        const sets = getFormFieldSets(target);\r\n        data.classes = data.classes || \"\";\r\n        sets[data.id] = data;\r\n        ReflectUtils.defineMetadata(\"dynamicFormFieldSets\", sets, target);\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 getFormFieldSets(target: any): IDynamicFormFieldSets {\r\n    return ReflectUtils.getMetadata(\"dynamicFormFieldSets\", target) || {};\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): IFormControlSerializer | IResolveFactory {\r\n    return ReflectUtils.getMetadata(\"dynamicFormSerializer\", target, propertyKey);\r\n}\r\n\r\nexport function createFormControl(id: string, type: string, data?: IFormControlData): IFormControl {\r\n    data = data || {};\r\n    data.label = ObjectUtils.isNullOrUndefined(data.label) ? id : data.label;\r\n    data.labelAlign = data.labelAlign || \"left\";\r\n    data.fieldSet = data.fieldSet || UniqueUtils.uuid();\r\n    data.classes = data.classes || \"\";\r\n    data.readonly = data.readonly || emptyTester;\r\n    data.hidden = data.hidden || emptyTester;\r\n    data.validators = data.validators || emptyArray;\r\n    return {\r\n        id: id,\r\n        type: type,\r\n        data: data\r\n    };\r\n}\r\n\r\nexport function createFormInput(id: string, data: IFormInputData, type: string = \"text\"): IFormControl {\r\n    const control = createFormControl(id, \"input\", data);\r\n    data = control.data;\r\n    data.type = data.type || type;\r\n    data.classes = !data.classes ? `form-group-${data.type}` : `${data.classes} form-group-${data.type}`;\r\n    data.placeholder = data.placeholder || (data.type == \"mask\" ? \"_\" : \"\");\r\n    data.step = data.step || 1;\r\n    data.mask = data.mask || [/\\w*/gi];\r\n    return control;\r\n}\r\n\r\nexport function createFormSelect(id: string, data: IFormSelectData): IFormControl {\r\n    const control = createFormControl(id, \"select\", data);\r\n    data = control.data;\r\n    data.options = data.options || [];\r\n    data.type = data.type || \"select\";\r\n    const classType = data.type == \"select\" ? \"select\" : `select-${data.type}`;\r\n    data.classes = !data.classes ? `form-group-${classType}` : `${data.classes} form-group-${classType}`;\r\n    return control;\r\n}\r\n\r\nexport function createFormStatic(id: string, data: IFormStaticData): IFormControl {\r\n    const control = createFormControl(id, \"static\", data);\r\n    data = control.data;\r\n    data.style = data.style || \"table\";\r\n    return control;\r\n}\r\n\r\nexport function createFormModel(id: string, data: IFormModelData): IFormControl {\r\n    const control = createFormControl(id, \"model\", data);\r\n    data = control.data;\r\n    data.name = data.name || \"\";\r\n    return control;\r\n}\r\n\r\nexport function createFormFile(id: string, data: IFormFileData): IFormControl {\r\n    const control = createFormControl(id, \"file\", data);\r\n    data = control.data;\r\n    data.accept = data.accept || \".jpg,.jpeg,.png\";\r\n    data.multi = data.multi || false;\r\n    data.baseUrl = ObjectUtils.isString(data.baseUrl) ? data.baseUrl : \"assets/\";\r\n    data.uploadUrl = ObjectUtils.isString(data.uploadUrl) ? data.uploadUrl : \"assets\";\r\n    data.createUploadData = data.createUploadData || ((file: File) => {\r\n        const form = new FormData();\r\n        form.append(\"file\", file);\r\n        return form;\r\n    });\r\n    return control;\r\n}\r\n"]}
@@ -1,91 +1,91 @@
1
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ComponentFactoryResolver, ContentChildren, EventEmitter, HostBinding, Input, Output, ViewChild, ViewContainerRef } from "@angular/core";
2
- import { DYNAMIC_FORM_CONTROL_TYPE_ARRAY, DynamicFormComponentService, DynamicFormControlContainerComponent, DynamicFormLayoutService, DynamicFormRelationService, DynamicFormValidationService, DynamicTemplateDirective } from "@ng-dynamic-forms/core";
3
- import { DynamicBaseFormComponent } from "./dynamic-base-form.component";
4
- import { ObjectUtils } from "@stemy/ngx-utils";
5
- export class DynamicBaseFormControlContainerComponent extends DynamicFormControlContainerComponent {
6
- constructor(form, changeDetectorRef, componentFactoryResolver, layoutService, validationService, componentService, relationService) {
7
- super(changeDetectorRef, componentFactoryResolver, layoutService, validationService, componentService, relationService);
8
- this.form = form;
9
- this.changeDetectorRef = changeDetectorRef;
10
- this.componentFactoryResolver = componentFactoryResolver;
11
- this.layoutService = layoutService;
12
- this.validationService = validationService;
13
- this.componentService = componentService;
14
- this.relationService = relationService;
15
- this.context = null;
16
- this.blur = new EventEmitter();
17
- this.change = new EventEmitter();
18
- this.focus = new EventEmitter();
19
- }
20
- get componentType() {
21
- var _a;
22
- return (_a = this.componentService.getCustomComponentType(this.model)) !== null && _a !== void 0 ? _a : this.getComponentType(this.model);
23
- }
24
- get startTemplate() {
25
- return (this.model.type == DYNAMIC_FORM_CONTROL_TYPE_ARRAY)
26
- ? this.layoutService.getAlignedTemplate(this.model, this.templates, "ARRAY_START")
27
- : this.layoutService.getStartTemplate(this.model, this.templates);
28
- }
29
- get endTemplate() {
30
- return (this.model.type == DYNAMIC_FORM_CONTROL_TYPE_ARRAY)
31
- ? this.layoutService.getAlignedTemplate(this.model, this.templates, "ARRAY_END")
32
- : this.layoutService.getEndTemplate(this.model, this.templates);
33
- }
34
- get formService() {
35
- return this.form.formService;
36
- }
37
- ngOnInit() {
38
- this.onDetectChanges = this.formService.onDetectChanges.subscribe(form => {
39
- if (form !== this.form)
40
- return;
41
- this.changeDetectorRef.detectChanges();
42
- this.formService.updateSelectOptions(this.model, this.control);
43
- });
44
- }
45
- ngOnDestroy() {
46
- super.ngOnDestroy();
47
- this.onDetectChanges.unsubscribe();
48
- }
49
- createFormControlComponent() {
50
- var _a;
51
- super.createFormControlComponent();
52
- const component = (_a = this.componentRef) === null || _a === void 0 ? void 0 : _a.instance;
53
- if (!component || !ObjectUtils.isFunction(component.onCreated))
54
- return;
55
- component.onCreated();
56
- }
57
- getComponentType(model) {
58
- return null;
59
- }
60
- }
61
- DynamicBaseFormControlContainerComponent.decorators = [
62
- { type: Component, args: [{
63
- selector: "dynamic-base-form-control",
64
- template: "",
65
- changeDetection: ChangeDetectionStrategy.OnPush
66
- },] }
67
- ];
68
- DynamicBaseFormControlContainerComponent.ctorParameters = () => [
69
- { type: DynamicBaseFormComponent },
70
- { type: ChangeDetectorRef },
71
- { type: ComponentFactoryResolver },
72
- { type: DynamicFormLayoutService },
73
- { type: DynamicFormValidationService },
74
- { type: DynamicFormComponentService },
75
- { type: DynamicFormRelationService }
76
- ];
77
- DynamicBaseFormControlContainerComponent.propDecorators = {
78
- contentTemplateList: [{ type: ContentChildren, args: [DynamicTemplateDirective,] }],
79
- klass: [{ type: HostBinding, args: ["class",] }],
80
- context: [{ type: Input }],
81
- group: [{ type: Input }],
82
- hostClass: [{ type: Input }],
83
- inputTemplateList: [{ type: Input, args: ["templates",] }],
84
- layout: [{ type: Input }],
85
- model: [{ type: Input }],
86
- blur: [{ type: Output }],
87
- change: [{ type: Output }],
88
- focus: [{ type: Output }],
89
- componentViewContainerRef: [{ type: ViewChild, args: ["componentViewContainer", { read: ViewContainerRef, static: true },] }]
90
- };
91
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-base-form-control-container.component.js","sourceRoot":"","sources":["../../../../../src/ngx-dynamic-form/components/base/dynamic-base-form-control-container.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ComponentFactoryResolver,\n    ContentChildren,\n    EventEmitter,\n    HostBinding,\n    Input,\n    OnInit,\n    Output,\n    QueryList,\n    Type,\n    ViewChild,\n    ViewContainerRef\n} from \"@angular/core\";\nimport {FormGroup} from \"@angular/forms\";\nimport {Subscription} from \"rxjs\";\nimport {\n    DYNAMIC_FORM_CONTROL_TYPE_ARRAY,\n    DynamicFormArrayGroupModel,\n    DynamicFormComponentService,\n    DynamicFormControl,\n    DynamicFormControlContainerComponent,\n    DynamicFormControlEvent,\n    DynamicFormControlModel,\n    DynamicFormLayout,\n    DynamicFormLayoutService,\n    DynamicFormRelationService,\n    DynamicFormValidationService,\n    DynamicTemplateDirective\n} from \"@ng-dynamic-forms/core\";\nimport {DynamicBaseFormComponent} from \"./dynamic-base-form.component\";\nimport {DynamicFormService} from \"../../services/dynamic-form.service\";\nimport {ObjectUtils} from \"@stemy/ngx-utils\";\nimport {OnCreatedFormControl} from \"../../common-types\";\n\n@Component({\n    selector: \"dynamic-base-form-control\",\n    template: \"\",\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class DynamicBaseFormControlContainerComponent extends DynamicFormControlContainerComponent implements OnInit {\n\n    @ContentChildren(DynamicTemplateDirective) contentTemplateList: QueryList<DynamicTemplateDirective>;\n\n    @HostBinding(\"class\") klass;\n\n    @Input() context: DynamicFormArrayGroupModel | null = null;\n    @Input() group: FormGroup;\n    @Input() hostClass: string[];\n    @Input(\"templates\") inputTemplateList: QueryList<DynamicTemplateDirective>;\n    @Input() layout: DynamicFormLayout;\n    @Input() model: DynamicFormControlModel;\n\n    @Output() blur: EventEmitter<DynamicFormControlEvent> = new EventEmitter<DynamicFormControlEvent>();\n    @Output() change: EventEmitter<DynamicFormControlEvent> = new EventEmitter<DynamicFormControlEvent>();\n    @Output() focus: EventEmitter<DynamicFormControlEvent> = new EventEmitter<DynamicFormControlEvent>();\n\n    @ViewChild(\"componentViewContainer\", {read: ViewContainerRef, static: true}) componentViewContainerRef: ViewContainerRef;\n\n    protected onDetectChanges: Subscription;\n\n    get componentType(): Type<DynamicFormControl> | null {\n        return this.componentService.getCustomComponentType(this.model) ?? this.getComponentType(this.model);\n    }\n\n    get startTemplate(): DynamicTemplateDirective {\n        return (this.model.type == DYNAMIC_FORM_CONTROL_TYPE_ARRAY)\n            ? this.layoutService.getAlignedTemplate(this.model, this.templates, \"ARRAY_START\" as any)\n            : this.layoutService.getStartTemplate(this.model, this.templates);\n    }\n\n    get endTemplate(): DynamicTemplateDirective {\n        return (this.model.type == DYNAMIC_FORM_CONTROL_TYPE_ARRAY)\n            ? this.layoutService.getAlignedTemplate(this.model, this.templates, \"ARRAY_END\" as any)\n            : this.layoutService.getEndTemplate(this.model, this.templates);\n    }\n\n    get formService(): DynamicFormService {\n        return this.form.formService;\n    }\n\n    constructor(readonly form: DynamicBaseFormComponent,\n                readonly changeDetectorRef: ChangeDetectorRef,\n                readonly componentFactoryResolver: ComponentFactoryResolver,\n                readonly layoutService: DynamicFormLayoutService,\n                readonly validationService: DynamicFormValidationService,\n                readonly componentService: DynamicFormComponentService,\n                readonly relationService: DynamicFormRelationService) {\n        super(changeDetectorRef, componentFactoryResolver, layoutService, validationService, componentService, relationService);\n    }\n\n    ngOnInit(): void {\n        this.onDetectChanges = this.formService.onDetectChanges.subscribe(form => {\n            if (form !== this.form) return;\n            this.changeDetectorRef.detectChanges();\n            this.formService.updateSelectOptions(this.model, this.control);\n        });\n    }\n\n    ngOnDestroy() {\n        super.ngOnDestroy();\n        this.onDetectChanges.unsubscribe();\n    }\n\n    protected createFormControlComponent() {\n        super.createFormControlComponent();\n        const component = this.componentRef?.instance as OnCreatedFormControl;\n        if (!component || !ObjectUtils.isFunction(component.onCreated)) return;\n        component.onCreated();\n    }\n\n    protected getComponentType(model: DynamicFormControlModel): Type<DynamicFormControl> | null {\n        return null;\n    }\n}\n"]}
1
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ComponentFactoryResolver, ContentChildren, EventEmitter, HostBinding, Input, Output, ViewChild, ViewContainerRef } from "@angular/core";
2
+ import { DYNAMIC_FORM_CONTROL_TYPE_ARRAY, DynamicFormComponentService, DynamicFormControlContainerComponent, DynamicFormLayoutService, DynamicFormRelationService, DynamicFormValidationService, DynamicTemplateDirective } from "@ng-dynamic-forms/core";
3
+ import { DynamicBaseFormComponent } from "./dynamic-base-form.component";
4
+ import { ObjectUtils } from "@stemy/ngx-utils";
5
+ export class DynamicBaseFormControlContainerComponent extends DynamicFormControlContainerComponent {
6
+ constructor(form, changeDetectorRef, componentFactoryResolver, layoutService, validationService, componentService, relationService) {
7
+ super(changeDetectorRef, componentFactoryResolver, layoutService, validationService, componentService, relationService);
8
+ this.form = form;
9
+ this.changeDetectorRef = changeDetectorRef;
10
+ this.componentFactoryResolver = componentFactoryResolver;
11
+ this.layoutService = layoutService;
12
+ this.validationService = validationService;
13
+ this.componentService = componentService;
14
+ this.relationService = relationService;
15
+ this.context = null;
16
+ this.blur = new EventEmitter();
17
+ this.change = new EventEmitter();
18
+ this.focus = new EventEmitter();
19
+ }
20
+ get componentType() {
21
+ var _a;
22
+ return (_a = this.componentService.getCustomComponentType(this.model)) !== null && _a !== void 0 ? _a : this.getComponentType(this.model);
23
+ }
24
+ get startTemplate() {
25
+ return (this.model.type == DYNAMIC_FORM_CONTROL_TYPE_ARRAY)
26
+ ? this.layoutService.getAlignedTemplate(this.model, this.templates, "ARRAY_START")
27
+ : this.layoutService.getStartTemplate(this.model, this.templates);
28
+ }
29
+ get endTemplate() {
30
+ return (this.model.type == DYNAMIC_FORM_CONTROL_TYPE_ARRAY)
31
+ ? this.layoutService.getAlignedTemplate(this.model, this.templates, "ARRAY_END")
32
+ : this.layoutService.getEndTemplate(this.model, this.templates);
33
+ }
34
+ get formService() {
35
+ return this.form.formService;
36
+ }
37
+ ngOnInit() {
38
+ this.onDetectChanges = this.formService.onDetectChanges.subscribe(form => {
39
+ if (form !== this.form)
40
+ return;
41
+ this.changeDetectorRef.detectChanges();
42
+ this.formService.updateSelectOptions(this.model, this.control);
43
+ });
44
+ }
45
+ ngOnDestroy() {
46
+ super.ngOnDestroy();
47
+ this.onDetectChanges.unsubscribe();
48
+ }
49
+ createFormControlComponent() {
50
+ var _a;
51
+ super.createFormControlComponent();
52
+ const component = (_a = this.componentRef) === null || _a === void 0 ? void 0 : _a.instance;
53
+ if (!component || !ObjectUtils.isFunction(component.onCreated))
54
+ return;
55
+ component.onCreated();
56
+ }
57
+ getComponentType(model) {
58
+ return null;
59
+ }
60
+ }
61
+ DynamicBaseFormControlContainerComponent.decorators = [
62
+ { type: Component, args: [{
63
+ selector: "dynamic-base-form-control",
64
+ template: "",
65
+ changeDetection: ChangeDetectionStrategy.OnPush
66
+ },] }
67
+ ];
68
+ DynamicBaseFormControlContainerComponent.ctorParameters = () => [
69
+ { type: DynamicBaseFormComponent },
70
+ { type: ChangeDetectorRef },
71
+ { type: ComponentFactoryResolver },
72
+ { type: DynamicFormLayoutService },
73
+ { type: DynamicFormValidationService },
74
+ { type: DynamicFormComponentService },
75
+ { type: DynamicFormRelationService }
76
+ ];
77
+ DynamicBaseFormControlContainerComponent.propDecorators = {
78
+ contentTemplateList: [{ type: ContentChildren, args: [DynamicTemplateDirective,] }],
79
+ klass: [{ type: HostBinding, args: ["class",] }],
80
+ context: [{ type: Input }],
81
+ group: [{ type: Input }],
82
+ hostClass: [{ type: Input }],
83
+ inputTemplateList: [{ type: Input, args: ["templates",] }],
84
+ layout: [{ type: Input }],
85
+ model: [{ type: Input }],
86
+ blur: [{ type: Output }],
87
+ change: [{ type: Output }],
88
+ focus: [{ type: Output }],
89
+ componentViewContainerRef: [{ type: ViewChild, args: ["componentViewContainer", { read: ViewContainerRef, static: true },] }]
90
+ };
91
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dynamic-base-form-control-container.component.js","sourceRoot":"","sources":["../../../../../src/ngx-dynamic-form/components/base/dynamic-base-form-control-container.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    ChangeDetectionStrategy,\r\n    ChangeDetectorRef,\r\n    Component,\r\n    ComponentFactoryResolver,\r\n    ContentChildren,\r\n    EventEmitter,\r\n    HostBinding,\r\n    Input,\r\n    OnInit,\r\n    Output,\r\n    QueryList,\r\n    Type,\r\n    ViewChild,\r\n    ViewContainerRef\r\n} from \"@angular/core\";\r\nimport {FormGroup} from \"@angular/forms\";\r\nimport {Subscription} from \"rxjs\";\r\nimport {\r\n    DYNAMIC_FORM_CONTROL_TYPE_ARRAY,\r\n    DynamicFormArrayGroupModel,\r\n    DynamicFormComponentService,\r\n    DynamicFormControl,\r\n    DynamicFormControlContainerComponent,\r\n    DynamicFormControlEvent,\r\n    DynamicFormControlModel,\r\n    DynamicFormLayout,\r\n    DynamicFormLayoutService,\r\n    DynamicFormRelationService,\r\n    DynamicFormValidationService,\r\n    DynamicTemplateDirective\r\n} from \"@ng-dynamic-forms/core\";\r\nimport {DynamicBaseFormComponent} from \"./dynamic-base-form.component\";\r\nimport {DynamicFormService} from \"../../services/dynamic-form.service\";\r\nimport {ObjectUtils} from \"@stemy/ngx-utils\";\r\nimport {OnCreatedFormControl} from \"../../common-types\";\r\n\r\n@Component({\r\n    selector: \"dynamic-base-form-control\",\r\n    template: \"\",\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class DynamicBaseFormControlContainerComponent extends DynamicFormControlContainerComponent implements OnInit {\r\n\r\n    @ContentChildren(DynamicTemplateDirective) contentTemplateList: QueryList<DynamicTemplateDirective>;\r\n\r\n    @HostBinding(\"class\") klass;\r\n\r\n    @Input() context: DynamicFormArrayGroupModel | null = null;\r\n    @Input() group: FormGroup;\r\n    @Input() hostClass: string[];\r\n    @Input(\"templates\") inputTemplateList: QueryList<DynamicTemplateDirective>;\r\n    @Input() layout: DynamicFormLayout;\r\n    @Input() model: DynamicFormControlModel;\r\n\r\n    @Output() blur: EventEmitter<DynamicFormControlEvent> = new EventEmitter<DynamicFormControlEvent>();\r\n    @Output() change: EventEmitter<DynamicFormControlEvent> = new EventEmitter<DynamicFormControlEvent>();\r\n    @Output() focus: EventEmitter<DynamicFormControlEvent> = new EventEmitter<DynamicFormControlEvent>();\r\n\r\n    @ViewChild(\"componentViewContainer\", {read: ViewContainerRef, static: true}) componentViewContainerRef: ViewContainerRef;\r\n\r\n    protected onDetectChanges: Subscription;\r\n\r\n    get componentType(): Type<DynamicFormControl> | null {\r\n        return this.componentService.getCustomComponentType(this.model) ?? this.getComponentType(this.model);\r\n    }\r\n\r\n    get startTemplate(): DynamicTemplateDirective {\r\n        return (this.model.type == DYNAMIC_FORM_CONTROL_TYPE_ARRAY)\r\n            ? this.layoutService.getAlignedTemplate(this.model, this.templates, \"ARRAY_START\" as any)\r\n            : this.layoutService.getStartTemplate(this.model, this.templates);\r\n    }\r\n\r\n    get endTemplate(): DynamicTemplateDirective {\r\n        return (this.model.type == DYNAMIC_FORM_CONTROL_TYPE_ARRAY)\r\n            ? this.layoutService.getAlignedTemplate(this.model, this.templates, \"ARRAY_END\" as any)\r\n            : this.layoutService.getEndTemplate(this.model, this.templates);\r\n    }\r\n\r\n    get formService(): DynamicFormService {\r\n        return this.form.formService;\r\n    }\r\n\r\n    constructor(readonly form: DynamicBaseFormComponent,\r\n                readonly changeDetectorRef: ChangeDetectorRef,\r\n                readonly componentFactoryResolver: ComponentFactoryResolver,\r\n                readonly layoutService: DynamicFormLayoutService,\r\n                readonly validationService: DynamicFormValidationService,\r\n                readonly componentService: DynamicFormComponentService,\r\n                readonly relationService: DynamicFormRelationService) {\r\n        super(changeDetectorRef, componentFactoryResolver, layoutService, validationService, componentService, relationService);\r\n    }\r\n\r\n    ngOnInit(): void {\r\n        this.onDetectChanges = this.formService.onDetectChanges.subscribe(form => {\r\n            if (form !== this.form) return;\r\n            this.changeDetectorRef.detectChanges();\r\n            this.formService.updateSelectOptions(this.model, this.control);\r\n        });\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        super.ngOnDestroy();\r\n        this.onDetectChanges.unsubscribe();\r\n    }\r\n\r\n    protected createFormControlComponent() {\r\n        super.createFormControlComponent();\r\n        const component = this.componentRef?.instance as OnCreatedFormControl;\r\n        if (!component || !ObjectUtils.isFunction(component.onCreated)) return;\r\n        component.onCreated();\r\n    }\r\n\r\n    protected getComponentType(model: DynamicFormControlModel): Type<DynamicFormControl> | null {\r\n        return null;\r\n    }\r\n}\r\n"]}