@klippa/ngx-enhancy-forms 2.2.0 → 3.0.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/bundles/klippa-ngx-enhancy-forms.umd.js +482 -412
- package/bundles/klippa-ngx-enhancy-forms.umd.js.map +1 -1
- package/bundles/klippa-ngx-enhancy-forms.umd.min.js +2 -3
- package/bundles/klippa-ngx-enhancy-forms.umd.min.js.map +1 -1
- package/esm2015/lib/form/form-element/form-element.component.js +3 -1
- package/esm2015/lib/form/form.component.js +70 -13
- package/esm2015/lib/ngx-enhancy-forms.module.js +25 -23
- package/fesm2015/klippa-ngx-enhancy-forms.js +110 -50
- package/fesm2015/klippa-ngx-enhancy-forms.js.map +1 -1
- package/klippa-ngx-enhancy-forms.metadata.json +1 -1
- package/lib/form/form.component.d.ts +18 -5
- package/package.json +1 -1
|
@@ -28,6 +28,8 @@ export class FormElementComponent {
|
|
|
28
28
|
}, message);
|
|
29
29
|
}
|
|
30
30
|
registerControl(formControl) {
|
|
31
|
+
// console.log('register');
|
|
32
|
+
// console.log(this.caption);
|
|
31
33
|
this.attachedControl = formControl;
|
|
32
34
|
this.parent.registerControl(formControl, this);
|
|
33
35
|
}
|
|
@@ -97,4 +99,4 @@ FormElementComponent.propDecorators = {
|
|
|
97
99
|
swapInputAndCaption: [{ type: Input }],
|
|
98
100
|
internalComponentRef: [{ type: ViewChild, args: ['internalComponentRef',] }]
|
|
99
101
|
};
|
|
100
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
102
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-element.component.js","sourceRoot":"/home/runner/work/ngx-enhancy-forms/ngx-enhancy-forms/projects/klippa/ngx-enhancy-forms/src/","sources":["lib/form/form-element/form-element.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, ElementRef, Host, Inject, InjectionToken, Input, OnInit, Optional, ViewChild} from '@angular/core';\nimport { AbstractControl, FormControl } from '@angular/forms';\nimport {FormComponent} from \"../form.component\";\nimport {CustomErrorMessages, FormErrorMessages} from \"../../types\";\n\nexport const FORM_ERROR_MESSAGES = new InjectionToken<CustomErrorMessages>('form.error.messages');\n\nexport const DEFAULT_ERROR_MESSAGES: FormErrorMessages = {\n\tmin: \"Use a number larger than %min%\",\n\tmax: \"Use a number smaller than %max%\",\n\trequired: \"This field is required\",\n\temail: \"Use a valid email address\",\n\tminLength: \"Has to be longer than %minLength% character(s)\",\n\tmaxLength: \"Has to be shorter than %maxLength% character(s)\",\n\tpattern: \"This input is not valid\",\n\tmatchPassword: \"Passwords must match\",\n\tdate: \"Enter a valid date\",\n}\n\n@Component({\n\tselector: 'klp-form-element',\n\ttemplateUrl: './form-element.component.html',\n\tstyleUrls: ['./form-element.component.scss'],\n})\nexport class FormElementComponent {\n\tpublic attachedControl: AbstractControl;\n\t@Input() public caption: String;\n\t@Input() public direction: 'horizontal' | 'vertical' = 'horizontal';\n\t@Input() public captionSpacing: 'percentages' | 'none' = 'percentages';\n\t@Input() public swapInputAndCaption: boolean = false;\n\t@ViewChild('internalComponentRef') public internalComponentRef: ElementRef;\n\n\tpublic captionRef: ElementRef;\n\tpublic errorMessages: FormErrorMessages = DEFAULT_ERROR_MESSAGES;\n\tpublic customErrorHandlers: Array<{ error: string; templateRef: ElementRef }> = [];\n\n\tconstructor(\n\t\t@Host() @Optional() private parent: FormComponent,\n\t\t@Inject(FORM_ERROR_MESSAGES) @Optional() private customMessages: CustomErrorMessages\n\t) {\n\t}\n\n\tpublic substituteParameters(message: string, parameters: Record<string, any>): string {\n\t\treturn Object.keys(parameters).reduce((msg, key) => {\n\t\t\treturn msg.replace(`%${key}%`, parameters[key]);\n\t\t}, message);\n\t}\n\n\tpublic registerControl(formControl: FormControl) {\n\t\t// console.log('register');\n\t\t// console.log(this.caption);\n\t\tthis.attachedControl = formControl;\n\t\tthis.parent.registerControl(formControl, this);\n\t}\n\n\tpublic unregisterControl(formControl: FormControl) {\n\t\tthis.attachedControl = null;\n\t\tthis.parent.unregisterControl(formControl);\n\t}\n\n\tpublic getAttachedControl() {\n\t\treturn this.attachedControl;\n\t}\n\n\tpublic registerErrorHandler(error: string, templateRef: ElementRef) {\n\t\tthis.customErrorHandlers.push({ error, templateRef });\n\t}\n\n\tpublic registerCaption(templateRef: ElementRef) {\n\t\tthis.captionRef = templateRef;\n\t}\n\n\tgetErrorToShow() {\n\t\tif (this.attachedControl?.touched === true && this.attachedControl?.errors) {\n\t\t\treturn Object.keys(this.attachedControl?.errors)[0];\n\t\t}\n\t\treturn null;\n\t}\n\n\tgetCustomErrorHandler(error: string) {\n\t\treturn this.customErrorHandlers.find((e) => e.error === error);\n\t}\n\n\tshowDefaultError(error: string) {\n\t\treturn this.getErrorToShow() === error && !this.customErrorHandlers.some((e) => e.error === error);\n\t}\n\n\tgetScrollableParent(node) {\n\t\tif (node == null) {\n\t\t\treturn null;\n\t\t}\n\t\tif (node.scrollHeight > node.clientHeight) {\n\t\t\treturn node;\n\t\t} else {\n\t\t\treturn this.getScrollableParent(node.parentNode);\n\t\t}\n\t}\n\n\tscrollTo() {\n\t\tthis.internalComponentRef.nativeElement.scrollIntoView(true);\n\t\t// to give some breathing room, we scroll 100px more to the top\n\t\tthis.getScrollableParent(this.internalComponentRef.nativeElement)?.scrollBy(0, -100);\n\t}\n\n\tgetErrorMessages(key: keyof FormErrorMessages) {\n\t\treturn this.customMessages?.[key]?.() ?? this.errorMessages[key];\n\t}\n}\n"]}
|
|
@@ -1,43 +1,95 @@
|
|
|
1
|
-
import { Component, Input } from '@angular/core';
|
|
1
|
+
import { Component, Directive, Input, Optional, SkipSelf } from '@angular/core';
|
|
2
2
|
import { FormArray, FormControl, FormGroup } from '@angular/forms';
|
|
3
|
+
import { isValueSet } from '../util/values';
|
|
3
4
|
export const invalidFieldsSymbol = Symbol('Not all fields are valid');
|
|
4
|
-
export class
|
|
5
|
+
export class SubFormDirective {
|
|
6
|
+
}
|
|
7
|
+
SubFormDirective.decorators = [
|
|
8
|
+
{ type: Directive, args: [{
|
|
9
|
+
// tslint:disable-next-line:directive-selector
|
|
10
|
+
selector: 'klp-sub-form',
|
|
11
|
+
},] }
|
|
12
|
+
];
|
|
13
|
+
SubFormDirective.propDecorators = {
|
|
14
|
+
injectInto: [{ type: Input }]
|
|
15
|
+
};
|
|
16
|
+
// Only used as a 'marker' to define a property will be filled in by a sub form
|
|
17
|
+
export class SubForm extends FormGroup {
|
|
5
18
|
constructor() {
|
|
19
|
+
super({}, null);
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
export class FormComponent {
|
|
23
|
+
constructor(parent, subFormPlaceholder) {
|
|
24
|
+
this.parent = parent;
|
|
25
|
+
this.subFormPlaceholder = subFormPlaceholder;
|
|
6
26
|
// we keep track of what form controls are actually rendered. Only those count when looking at form validation
|
|
7
27
|
this.activeControls = [];
|
|
8
28
|
}
|
|
29
|
+
ngOnInit() {
|
|
30
|
+
if (isValueSet(this.parent) && isValueSet(this.subFormPlaceholder)) {
|
|
31
|
+
const parentOfInjectInto = this.subFormPlaceholder.injectInto.parent;
|
|
32
|
+
if (parentOfInjectInto instanceof FormArray) {
|
|
33
|
+
const i = parentOfInjectInto.controls.findIndex((e) => e === this.subFormPlaceholder.injectInto);
|
|
34
|
+
parentOfInjectInto.setControl(i, this.formGroup);
|
|
35
|
+
}
|
|
36
|
+
else if (parentOfInjectInto instanceof FormGroup) {
|
|
37
|
+
const toReplace = Object.entries(parentOfInjectInto.controls).find(([key, val]) => {
|
|
38
|
+
return val === this.subFormPlaceholder.injectInto;
|
|
39
|
+
});
|
|
40
|
+
if (!((toReplace === null || toReplace === void 0 ? void 0 : toReplace[1]) instanceof SubForm)) {
|
|
41
|
+
throw new Error(`You are trying to inject a subForm ('${toReplace === null || toReplace === void 0 ? void 0 : toReplace[0]}') within something that is not annotated as such.`);
|
|
42
|
+
}
|
|
43
|
+
parentOfInjectInto.setControl(toReplace[0], this.formGroup);
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
}
|
|
9
47
|
registerControl(formControl, formElement) {
|
|
10
48
|
this.activeControls.push({ formControl, formElement });
|
|
49
|
+
if (this.parent) {
|
|
50
|
+
this.parent.registerControl(formControl, formElement);
|
|
51
|
+
}
|
|
11
52
|
}
|
|
12
53
|
unregisterControl(formControl) {
|
|
13
54
|
this.activeControls = this.activeControls.filter((e) => e.formControl !== formControl);
|
|
55
|
+
if (this.parent) {
|
|
56
|
+
this.parent.unregisterControl(formControl);
|
|
57
|
+
}
|
|
14
58
|
}
|
|
15
|
-
|
|
59
|
+
addFormGroupControls(formGroup, result) {
|
|
16
60
|
Object.values(formGroup.controls).forEach((value) => {
|
|
17
61
|
if (value instanceof FormGroup) {
|
|
18
|
-
this.
|
|
62
|
+
this.addFormGroupControls(value, result);
|
|
19
63
|
}
|
|
20
64
|
else if (value instanceof FormArray) {
|
|
21
|
-
this.
|
|
65
|
+
this.addFormArrayControls(value, result);
|
|
22
66
|
}
|
|
23
67
|
else if (value instanceof FormControl) {
|
|
24
|
-
this.
|
|
68
|
+
this.addFormControl(value, result);
|
|
25
69
|
}
|
|
26
70
|
});
|
|
27
71
|
}
|
|
28
|
-
|
|
72
|
+
addFormArrayControls(formArray, result) {
|
|
29
73
|
formArray.controls.forEach((value) => {
|
|
30
74
|
if (value instanceof FormGroup) {
|
|
31
|
-
this.
|
|
75
|
+
this.addFormGroupControls(value, result);
|
|
32
76
|
}
|
|
33
77
|
else if (value instanceof FormArray) {
|
|
34
|
-
this.
|
|
78
|
+
this.addFormArrayControls(value, result);
|
|
35
79
|
}
|
|
36
80
|
else if (value instanceof FormControl) {
|
|
37
|
-
this.
|
|
81
|
+
this.addFormControl(value, result);
|
|
38
82
|
}
|
|
39
83
|
});
|
|
40
84
|
}
|
|
85
|
+
getAllFormControls() {
|
|
86
|
+
const result = [];
|
|
87
|
+
this.addFormGroupControls(this.formGroup, result);
|
|
88
|
+
return result;
|
|
89
|
+
}
|
|
90
|
+
addFormControl(control, result) {
|
|
91
|
+
result.push(control);
|
|
92
|
+
}
|
|
41
93
|
disableInactiveFormControl(control) {
|
|
42
94
|
if (!this.activeControls.some((e) => e.formControl === control)) {
|
|
43
95
|
control.disable();
|
|
@@ -46,10 +98,11 @@ export class FormComponent {
|
|
|
46
98
|
trySubmit() {
|
|
47
99
|
var _a, _b;
|
|
48
100
|
this.formGroup.markAllAsTouched();
|
|
49
|
-
const
|
|
101
|
+
const allControls = this.getAllFormControls();
|
|
102
|
+
const originalDisabledStates = allControls.map(e => {
|
|
50
103
|
return { control: e, disabled: e.disabled };
|
|
51
104
|
});
|
|
52
|
-
|
|
105
|
+
allControls.forEach(e => this.disableInactiveFormControl(e));
|
|
53
106
|
const values = this.formGroup.value;
|
|
54
107
|
if (this.formGroup.valid) {
|
|
55
108
|
this.setDisabledStatesForAllControls(originalDisabledStates);
|
|
@@ -79,7 +132,11 @@ FormComponent.decorators = [
|
|
|
79
132
|
styles: [":host{display:block}:host.row{display:flex}"]
|
|
80
133
|
},] }
|
|
81
134
|
];
|
|
135
|
+
FormComponent.ctorParameters = () => [
|
|
136
|
+
{ type: FormComponent, decorators: [{ type: SkipSelf }, { type: Optional }] },
|
|
137
|
+
{ type: SubFormDirective, decorators: [{ type: Optional }] }
|
|
138
|
+
];
|
|
82
139
|
FormComponent.propDecorators = {
|
|
83
140
|
formGroup: [{ type: Input }]
|
|
84
141
|
};
|
|
85
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiL2hvbWUvcnVubmVyL3dvcmsvbmd4LWVuaGFuY3ktZm9ybXMvbmd4LWVuaGFuY3ktZm9ybXMvcHJvamVjdHMva2xpcHBhL25neC1lbmhhbmN5LWZvcm1zL3NyYy8iLCJzb3VyY2VzIjpbImxpYi9mb3JtL2Zvcm0uY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2pELE9BQU8sRUFBa0IsU0FBUyxFQUFFLFdBQVcsRUFBRSxTQUFTLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQztBQUdsRixNQUFNLENBQUMsTUFBTSxtQkFBbUIsR0FBRyxNQUFNLENBQUMsMEJBQTBCLENBQUMsQ0FBQztBQU90RSxNQUFNLE9BQU8sYUFBYTtJQUwxQjtRQVFDLDhHQUE4RztRQUN0RyxtQkFBYyxHQUdqQixFQUFFLENBQUM7SUFnRVQsQ0FBQztJQTlETyxlQUFlLENBQUMsV0FBd0IsRUFBRSxXQUFpQztRQUNqRixJQUFJLENBQUMsY0FBYyxDQUFDLElBQUksQ0FBQyxFQUFFLFdBQVcsRUFBRSxXQUFXLEVBQUUsQ0FBQyxDQUFDO0lBQ3hELENBQUM7SUFFTSxpQkFBaUIsQ0FBQyxXQUF3QjtRQUNoRCxJQUFJLENBQUMsY0FBYyxHQUFHLElBQUksQ0FBQyxjQUFjLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsV0FBVyxLQUFLLFdBQVcsQ0FBQyxDQUFDO0lBQ3hGLENBQUM7SUFFTyxnQ0FBZ0MsQ0FBQyxTQUFvQjtRQUM1RCxNQUFNLENBQUMsTUFBTSxDQUFDLFNBQVMsQ0FBQyxRQUFRLENBQUMsQ0FBQyxPQUFPLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRTtZQUNuRCxJQUFJLEtBQUssWUFBWSxTQUFTLEVBQUU7Z0JBQy9CLElBQUksQ0FBQyxnQ0FBZ0MsQ0FBQyxLQUFLLENB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b21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQge0Fic3RyYWN0Q29udHJvbCwgRm9ybUFycmF5LCBGb3JtQ29udHJvbCwgRm9ybUdyb3VwfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQge0Zvcm1FbGVtZW50Q29tcG9uZW50fSBmcm9tIFwiLi9mb3JtLWVsZW1lbnQvZm9ybS1lbGVtZW50LmNvbXBvbmVudFwiO1xuXG5leHBvcnQgY29uc3QgaW52YWxpZEZpZWxkc1N5bWJvbCA9IFN5bWJvbCgnTm90IGFsbCBmaWVsZHMgYXJlIHZhbGlkJyk7XG5cbkBDb21wb25lbnQoe1xuXHRzZWxlY3RvcjogJ2tscC1mb3JtJyxcblx0dGVtcGxhdGVVcmw6ICcuL2Zvcm0uY29tcG9uZW50Lmh0bWwnLFxuXHRzdHlsZVVybHM6IFsnLi9mb3JtLmNvbXBvbmVudC5zY3NzJ10sXG59KVxuZXhwb3J0IGNsYXNzIEZvcm1Db21wb25lbnQge1xuXHRASW5wdXQoKSBwdWJsaWMgZm9ybUdyb3VwOiBGb3JtR3JvdXA7XG5cblx0Ly8gd2Uga2VlcCB0cmFjayBvZiB3aGF0IGZvcm0gY29udHJvbHMgYXJlIGFjdHVhbGx5IHJlbmRlcmVkLiBPbmx5IHRob3NlIGNvdW50IHdoZW4gbG9va2luZyBhdCBmb3JtIHZhbGlkYXRpb25cblx0cHJpdmF0ZSBhY3RpdmVDb250cm9sczogQXJyYXk8e1xuXHRcdGZvcm1Db250cm9sOiBGb3JtQ29udHJvbDtcblx0XHRmb3JtRWxlbWVudDogRm9ybUVsZW1lbnRDb21wb25lbnQ7XG5cdH0+ID0gW107XG5cblx0cHVibGljIHJlZ2lzdGVyQ29udHJvbChmb3JtQ29udHJvbDogRm9ybUNvbnRyb2wsIGZvcm1FbGVtZW50OiBGb3JtRWxlbWVudENvbXBvbmVudCk6IHZvaWQge1xuXHRcdHRoaXMuYWN0aXZlQ29udHJvbHMucHVzaCh7IGZvcm1Db250cm9sLCBmb3JtRWxlbWVudCB9KTtcblx0fVxuXG5cdHB1YmxpYyB1bnJlZ2lzdGVyQ29udHJvbChmb3JtQ29udHJvbDogRm9ybUNvbnRyb2wpOiB2b2lkIHtcblx0XHR0aGlzLmFjdGl2ZUNvbnRyb2xzID0gdGhpcy5hY3RpdmVDb250cm9scy5maWx0ZXIoKGUpID0+IGUuZm9ybUNvbnRyb2wgIT09IGZvcm1Db250cm9sKTtcblx0fVxuXG5cdHByaXZhdGUgZGlzYWJsZUluYWN0aXZlRm9ybUdyb3VwQ29udHJvbHMoZm9ybUdyb3VwOiBGb3JtR3JvdXApOiB2b2lkIHtcblx0XHRPYmplY3QudmFsdWVzKGZvcm1Hcm91cC5jb250cm9scykuZm9yRWFjaCgodmFsdWUpID0+IHtcblx0XHRcdGlmICh2YWx1ZSBpbnN0YW5jZW9mIEZvcm1Hcm91cCkge1xuXHRcdFx0XHR0aGlzLmRpc2FibGVJbmFjdGl2ZUZvcm1Hcm91cENvbnRyb2xzKHZhbHVlKTtcblx0XHRcdH0gZWxzZSBpZiAodmFsdWUgaW5zdGFuY2VvZiBGb3JtQXJyYXkpIHtcblx0XHRcdFx0dGhpcy5kaXNhYmxlSW5hY3RpdmVGb3JtQXJyYXlDb250cm9scyh2YWx1ZSk7XG5cdFx0XHR9IGVsc2UgaWYgKHZhbHVlIGluc3RhbmNlb2YgRm9ybUNvbnRyb2wpIHtcblx0XHRcdFx0dGhpcy5kaXNhYmxlSW5hY3RpdmVGb3JtQ29udHJvbCh2YWx1ZSk7XG5cdFx0XHR9XG5cdFx0fSk7XG5cdH1cblx0cHJpdmF0ZSBkaXNhYmxlSW5hY3RpdmVGb3JtQXJyYXlDb250cm9scyhmb3JtQXJyYXk6IEZvcm1BcnJheSk6IHZvaWQge1xuXHRcdGZvcm1BcnJheS5jb250cm9scy5mb3JFYWNoKCh2YWx1ZSkgPT4ge1xuXHRcdFx0aWYgKHZhbHVlIGluc3RhbmNlb2YgRm9ybUdyb3VwKSB7XG5cdFx0XHRcdHRoaXMuZGlzYWJsZUluYWN0aXZlRm9ybUdyb3VwQ29udHJvbHModmFsdWUpO1xuXHRcdFx0fSBlbHNlIGlmICh2YWx1ZSBpbnN0YW5jZW9mIEZvcm1BcnJheSkge1xuXHRcdFx0XHR0aGlzLmRpc2FibGVJbmFjdGl2ZUZvcm1BcnJheUNvbnRyb2xzKHZhbHVlKTtcblx0XHRcdH0gZWxzZSBpZiAodmFsdWUgaW5zdGFuY2VvZiBGb3JtQ29udHJvbCkge1xuXHRcdFx0XHR0aGlzLmRpc2FibGVJbmFjdGl2ZUZvcm1Db250cm9sKHZhbHVlKTtcblx0XHRcdH1cblx0XHR9KTtcblx0fVxuXHRwcml2YXRlIGRpc2FibGVJbmFjdGl2ZUZvcm1Db250cm9sKGNvbnRyb2w6IEZvcm1Db250cm9sKTogdm9pZCB7XG5cdFx0aWYgKCF0aGlzLmFjdGl2ZUNvbnRyb2xzLnNvbWUoKGUpID0+IGUuZm9ybUNvbnRyb2wgPT09IGNvbnRyb2wpKSB7XG5cdFx0XHRjb250cm9sLmRpc2FibGUoKTtcblx0XHR9XG5cdH1cblxuXHR0cnlTdWJtaXQoKTogUHJvbWlzZTxhbnk+IHtcblx0XHR0aGlzLmZvcm1Hcm91cC5tYXJrQWxsQXNUb3VjaGVkKCk7XG5cdFx0Y29uc3Qgb3JpZ2luYWxEaXNhYmxlZFN0YXRlcyA9IE9iamVjdC52YWx1ZXModGhpcy5mb3JtR3JvdXAuY29udHJvbHMpLm1hcChlID0+IHtcblx0XHRcdHJldHVybiB7IGNvbnRyb2w6IGUsIGRpc2FibGVkOiBlLmRpc2FibGVkfTtcblx0XHR9KTtcblx0XHR0aGlzLmRpc2FibGVJbmFjdGl2ZUZvcm1Hcm91cENvbnRyb2xzKHRoaXMuZm9ybUdyb3VwKTtcblx0XHRjb25zdCB2YWx1ZXMgPSB0aGlzLmZvcm1Hcm91cC52YWx1ZTtcblx0XHRpZiAodGhpcy5mb3JtR3JvdXAudmFsaWQpIHtcblx0XHRcdHRoaXMuc2V0RGlzYWJsZWRTdGF0ZXNGb3JBbGxDb250cm9scyhvcmlnaW5hbERpc2FibGVkU3RhdGVzKTtcblx0XHRcdHJldHVybiBQcm9taXNlLnJlc29sdmUodmFsdWVzKTtcblx0XHR9IGVsc2Uge1xuXHRcdFx0dGhpcy5hY3RpdmVDb250cm9scy5maW5kKChlKSA9PiAhZS5mb3JtQ29udHJvbC52YWxpZCk/LmZvcm1FbGVtZW50Py5zY3JvbGxUbygpO1xuXHRcdFx0dGhpcy5zZXREaXNhYmxlZFN0YXRlc0ZvckFsbENvbnRyb2xzKG9yaWdpbmFsRGlzYWJsZWRTdGF0ZXMpO1xuXHRcdFx0cmV0dXJuIFByb21pc2UucmVqZWN0KGludmFsaWRGaWVsZHNTeW1ib2wpO1xuXHRcdH1cblx0fVxuXG5cdHByaXZhdGUgc2V0RGlzYWJsZWRTdGF0ZXNGb3JBbGxDb250cm9scyhvcmlnaW5hbERpc2FibGVkU3RhdGVzOiBBcnJheTx7IGNvbnRyb2w6IEFic3RyYWN0Q29udHJvbDsgZGlzYWJsZWQ6IGJvb2xlYW4gfT4pOiB2b2lkIHtcblx0XHRvcmlnaW5hbERpc2FibGVkU3RhdGVzLmZvckVhY2goKGUpID0+IHtcblx0XHRcdGlmIChlLmRpc2FibGVkKSB7XG5cdFx0XHRcdGUuY29udHJvbC5kaXNhYmxlKCk7XG5cdFx0XHR9IGVsc2Uge1xuXHRcdFx0XHRlLmNvbnRyb2wuZW5hYmxlKCk7XG5cdFx0XHR9XG5cdFx0fSk7XG5cdH1cbn1cbiJdfQ==
|
|
142
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.component.js","sourceRoot":"/home/runner/work/ngx-enhancy-forms/ngx-enhancy-forms/projects/klippa/ngx-enhancy-forms/src/","sources":["lib/form/form.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,SAAS,EAAE,SAAS,EAAE,KAAK,EAAU,QAAQ,EAAE,QAAQ,EAAC,MAAM,eAAe,CAAC;AACtF,OAAO,EAAkB,SAAS,EAAE,WAAW,EAAE,SAAS,EAAgB,MAAM,gBAAgB,CAAC;AAEjG,OAAO,EAAC,UAAU,EAAC,MAAM,gBAAgB,CAAC;AAE1C,MAAM,CAAC,MAAM,mBAAmB,GAAG,MAAM,CAAC,0BAA0B,CAAC,CAAC;AAMtE,MAAM,OAAO,gBAAgB;;;YAJ5B,SAAS,SAAC;gBACV,8CAA8C;gBAC9C,QAAQ,EAAE,cAAc;aACxB;;;yBAEC,KAAK;;AAGP,+EAA+E;AAC/E,MAAM,OAAO,OAAQ,SAAQ,SAAS;IACrC;QACC,KAAK,CAAC,EAAE,EAAE,IAAI,CAAC,CAAC;IACjB,CAAC;CACD;AAOD,MAAM,OAAO,aAAa;IASzB,YAA4C,MAAqB,EAAsB,kBAAoC;QAA/E,WAAM,GAAN,MAAM,CAAe;QAAsB,uBAAkB,GAAlB,kBAAkB,CAAkB;QAN3H,8GAA8G;QACtG,mBAAc,GAGjB,EAAE,CAAC;IAEsH,CAAC;IAE/H,QAAQ;QACP,IAAI,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,UAAU,CAAC,IAAI,CAAC,kBAAkB,CAAC,EAAE;YACnE,MAAM,kBAAkB,GAAG,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAAC,MAAM,CAAC;YACrE,IAAI,kBAAkB,YAAY,SAAS,EAAE;gBAC5C,MAAM,CAAC,GAAG,kBAAkB,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,KAAK,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAAC,CAAC;gBACjG,kBAAkB,CAAC,UAAU,CAAC,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;aACjD;iBAAM,IAAI,kBAAkB,YAAY,SAAS,EAAE;gBACnD,MAAM,SAAS,GAAG,MAAM,CAAC,OAAO,CAAC,kBAAkB,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,EAAE,GAAG,CAAC,EAAE,EAAE;oBACjF,OAAO,GAAG,KAAK,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAAC;gBACnD,CAAC,CAAC,CAAC;gBACH,IAAI,CAAC,CAAC,CAAA,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAG,CAAC,cAAa,OAAO,CAAC,EAAE;oBACzC,MAAM,IAAI,KAAK,CAAC,wCAAwC,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAG,CAAC,CAAC,oDAAoD,CAAC,CAAC;iBAC5H;gBACD,kBAAkB,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;aAC5D;SACD;IACF,CAAC;IAEM,eAAe,CAAC,WAAwB,EAAE,WAAiC;QACjF,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,EAAC,WAAW,EAAE,WAAW,EAAC,CAAC,CAAC;QACrD,IAAI,IAAI,CAAC,MAAM,EAAE;YAChB,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC;SACtD;IACF,CAAC;IAEM,iBAAiB,CAAC,WAAwB;QAChD,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,KAAK,WAAW,CAAC,CAAC;QACvF,IAAI,IAAI,CAAC,MAAM,EAAE;YAChB,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC;SAC3C;IACF,CAAC;IAEO,oBAAoB,CAAC,SAAoB,EAAE,MAA0B;QAC5E,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;YACnD,IAAI,KAAK,YAAY,SAAS,EAAE;gBAC/B,IAAI,CAAC,oBAAoB,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;aACzC;iBAAM,IAAI,KAAK,YAAY,SAAS,EAAE;gBACtC,IAAI,CAAC,oBAAoB,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;aACzC;iBAAM,IAAI,KAAK,YAAY,WAAW,EAAE;gBACxC,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;aACnC;QACF,CAAC,CAAC,CAAC;IACJ,CAAC;IAEO,oBAAoB,CAAC,SAAoB,EAAE,MAA0B;QAC5E,SAAS,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;YACpC,IAAI,KAAK,YAAY,SAAS,EAAE;gBAC/B,IAAI,CAAC,oBAAoB,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;aACzC;iBAAM,IAAI,KAAK,YAAY,SAAS,EAAE;gBACtC,IAAI,CAAC,oBAAoB,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;aACzC;iBAAM,IAAI,KAAK,YAAY,WAAW,EAAE;gBACxC,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;aACnC;QACF,CAAC,CAAC,CAAC;IACJ,CAAC;IAEO,kBAAkB;QACzB,MAAM,MAAM,GAAG,EAAE,CAAC;QAClB,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;QAClD,OAAO,MAAM,CAAC;IACf,CAAC;IAEO,cAAc,CAAC,OAAoB,EAAE,MAA0B;QACtE,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACtB,CAAC;IAEO,0BAA0B,CAAC,OAAoB;QACtD,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,KAAK,OAAO,CAAC,EAAE;YAChE,OAAO,CAAC,OAAO,EAAE,CAAC;SAClB;IACF,CAAC;IAED,SAAS;;QACR,IAAI,CAAC,SAAS,CAAC,gBAAgB,EAAE,CAAC;QAClC,MAAM,WAAW,GAAuB,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAClE,MAAM,sBAAsB,GAAG,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;YAClD,OAAO,EAAC,OAAO,EAAE,CAAC,EAAE,QAAQ,EAAE,CAAC,CAAC,QAAQ,EAAC,CAAC;QAC3C,CAAC,CAAC,CAAC;QACH,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,0BAA0B,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7D,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC;QACpC,IAAI,IAAI,CAAC,SAAS,CAAC,KAAK,EAAE;YACzB,IAAI,CAAC,+BAA+B,CAAC,sBAAsB,CAAC,CAAC;YAC7D,OAAO,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;SAC/B;aAAM;YACN,YAAA,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,KAAK,CAAC,0CAAE,WAAW,0CAAE,QAAQ,GAAG;YAC/E,IAAI,CAAC,+BAA+B,CAAC,sBAAsB,CAAC,CAAC;YAC7D,OAAO,OAAO,CAAC,MAAM,CAAC,mBAAmB,CAAC,CAAC;SAC3C;IACF,CAAC;IAEO,+BAA+B,CAAC,sBAA8E;QACrH,sBAAsB,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;YACpC,IAAI,CAAC,CAAC,QAAQ,EAAE;gBACf,CAAC,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;aACpB;iBAAM;gBACN,CAAC,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC;aACnB;QACF,CAAC,CAAC,CAAC;IACJ,CAAC;;;YAlHD,SAAS,SAAC;gBACV,QAAQ,EAAE,UAAU;gBACpB,8DAAoC;;aAEpC;;;YAUoD,aAAa,uBAApD,QAAQ,YAAI,QAAQ;YAA0E,gBAAgB,uBAAvD,QAAQ;;;wBAR3E,KAAK","sourcesContent":["import {Component, Directive, Input, OnInit, Optional, SkipSelf} from '@angular/core';\nimport {AbstractControl, FormArray, FormControl, FormGroup, FormGroupName} from '@angular/forms';\nimport {FormElementComponent} from './form-element/form-element.component';\nimport {isValueSet} from '../util/values';\n\nexport const invalidFieldsSymbol = Symbol('Not all fields are valid');\n\n@Directive({\n\t// tslint:disable-next-line:directive-selector\n\tselector: 'klp-sub-form',\n})\nexport class SubFormDirective {\n\t@Input() injectInto: AbstractControl;\n}\n\n// Only used as a 'marker' to define a property will be filled in by a sub form\nexport class SubForm extends FormGroup {\n\tconstructor() {\n\t\tsuper({}, null);\n\t}\n}\n\n@Component({\n\tselector: 'klp-form',\n\ttemplateUrl: './form.component.html',\n\tstyleUrls: ['./form.component.scss'],\n})\nexport class FormComponent implements OnInit {\n\t@Input() public formGroup: FormGroup;\n\n\t// we keep track of what form controls are actually rendered. Only those count when looking at form validation\n\tprivate activeControls: Array<{\n\t\tformControl: FormControl;\n\t\tformElement: FormElementComponent;\n\t}> = [];\n\n\tconstructor(@SkipSelf() @Optional() private parent: FormComponent, @Optional() private subFormPlaceholder: SubFormDirective) {}\n\n\tngOnInit(): void {\n\t\tif (isValueSet(this.parent) && isValueSet(this.subFormPlaceholder)) {\n\t\t\tconst parentOfInjectInto = this.subFormPlaceholder.injectInto.parent;\n\t\t\tif (parentOfInjectInto instanceof FormArray) {\n\t\t\t\tconst i = parentOfInjectInto.controls.findIndex((e) => e === this.subFormPlaceholder.injectInto);\n\t\t\t\tparentOfInjectInto.setControl(i, this.formGroup);\n\t\t\t} else if (parentOfInjectInto instanceof FormGroup) {\n\t\t\t\tconst toReplace = Object.entries(parentOfInjectInto.controls).find(([key, val]) => {\n\t\t\t\t\treturn val === this.subFormPlaceholder.injectInto;\n\t\t\t\t});\n\t\t\t\tif (!(toReplace?.[1] instanceof SubForm)) {\n\t\t\t\t\tthrow new Error(`You are trying to inject a subForm ('${toReplace?.[0]}') within something that is not annotated as such.`);\n\t\t\t\t}\n\t\t\t\tparentOfInjectInto.setControl(toReplace[0], this.formGroup);\n\t\t\t}\n\t\t}\n\t}\n\n\tpublic registerControl(formControl: FormControl, formElement: FormElementComponent): void {\n\t\tthis.activeControls.push({formControl, formElement});\n\t\tif (this.parent) {\n\t\t\tthis.parent.registerControl(formControl, formElement);\n\t\t}\n\t}\n\n\tpublic unregisterControl(formControl: FormControl): void {\n\t\tthis.activeControls = this.activeControls.filter((e) => e.formControl !== formControl);\n\t\tif (this.parent) {\n\t\t\tthis.parent.unregisterControl(formControl);\n\t\t}\n\t}\n\n\tprivate addFormGroupControls(formGroup: FormGroup, result: Array<FormControl>): void {\n\t\tObject.values(formGroup.controls).forEach((value) => {\n\t\t\tif (value instanceof FormGroup) {\n\t\t\t\tthis.addFormGroupControls(value, result);\n\t\t\t} else if (value instanceof FormArray) {\n\t\t\t\tthis.addFormArrayControls(value, result);\n\t\t\t} else if (value instanceof FormControl) {\n\t\t\t\tthis.addFormControl(value, result);\n\t\t\t}\n\t\t});\n\t}\n\n\tprivate addFormArrayControls(formArray: FormArray, result: Array<FormControl>): void {\n\t\tformArray.controls.forEach((value) => {\n\t\t\tif (value instanceof FormGroup) {\n\t\t\t\tthis.addFormGroupControls(value, result);\n\t\t\t} else if (value instanceof FormArray) {\n\t\t\t\tthis.addFormArrayControls(value, result);\n\t\t\t} else if (value instanceof FormControl) {\n\t\t\t\tthis.addFormControl(value, result);\n\t\t\t}\n\t\t});\n\t}\n\n\tprivate getAllFormControls(): Array<FormControl> {\n\t\tconst result = [];\n\t\tthis.addFormGroupControls(this.formGroup, result);\n\t\treturn result;\n\t}\n\n\tprivate addFormControl(control: FormControl, result: Array<FormControl>): void {\n\t\tresult.push(control);\n\t}\n\n\tprivate disableInactiveFormControl(control: FormControl): void {\n\t\tif (!this.activeControls.some((e) => e.formControl === control)) {\n\t\t\tcontrol.disable();\n\t\t}\n\t}\n\n\ttrySubmit(): Promise<any> {\n\t\tthis.formGroup.markAllAsTouched();\n\t\tconst allControls: Array<FormControl> = this.getAllFormControls();\n\t\tconst originalDisabledStates = allControls.map(e => {\n\t\t\treturn {control: e, disabled: e.disabled};\n\t\t});\n\t\tallControls.forEach(e => this.disableInactiveFormControl(e));\n\t\tconst values = this.formGroup.value;\n\t\tif (this.formGroup.valid) {\n\t\t\tthis.setDisabledStatesForAllControls(originalDisabledStates);\n\t\t\treturn Promise.resolve(values);\n\t\t} else {\n\t\t\tthis.activeControls.find((e) => !e.formControl.valid)?.formElement?.scrollTo();\n\t\t\tthis.setDisabledStatesForAllControls(originalDisabledStates);\n\t\t\treturn Promise.reject(invalidFieldsSymbol);\n\t\t}\n\t}\n\n\tprivate setDisabledStatesForAllControls(originalDisabledStates: Array<{ control: AbstractControl; disabled: boolean }>): void {\n\t\toriginalDisabledStates.forEach((e) => {\n\t\t\tif (e.disabled) {\n\t\t\t\te.control.disable();\n\t\t\t} else {\n\t\t\t\te.control.enable();\n\t\t\t}\n\t\t});\n\t}\n}\n"]}
|
|
@@ -1,26 +1,26 @@
|
|
|
1
1
|
import { NgModule } from '@angular/core';
|
|
2
|
-
import { CommonModule } from
|
|
3
|
-
import { FormsModule } from
|
|
4
|
-
import { ValueAccessorBase } from
|
|
5
|
-
import { ButtonComponent } from
|
|
6
|
-
import { CheckboxComponent } from
|
|
7
|
-
import { EmailInputComponent } from
|
|
8
|
-
import { LoadingIndicatorComponent } from
|
|
9
|
-
import { NumberInputComponent } from
|
|
10
|
-
import { PasswordFieldComponent } from
|
|
11
|
-
import { SelectComponent } from
|
|
12
|
-
import { SortableItemsComponent } from
|
|
13
|
-
import { TextInputComponent } from
|
|
14
|
-
import { ToggleComponent } from
|
|
15
|
-
import { FormCaptionComponent } from
|
|
16
|
-
import { FormElementComponent } from
|
|
17
|
-
import { FormErrorComponent } from
|
|
18
|
-
import { FormSubmitButtonComponent } from
|
|
19
|
-
import { FormComponent } from
|
|
20
|
-
import { SortablejsModule } from
|
|
21
|
-
import { NgSelectModule } from
|
|
22
|
-
import { DatepickerComponent } from
|
|
23
|
-
import { MaterialModule } from
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { FormsModule } from '@angular/forms';
|
|
4
|
+
import { ValueAccessorBase } from './elements/value-accessor-base/value-accessor-base.component';
|
|
5
|
+
import { ButtonComponent } from './elements/button/button.component';
|
|
6
|
+
import { CheckboxComponent } from './elements/checkbox/checkbox.component';
|
|
7
|
+
import { EmailInputComponent } from './elements/email/email-input.component';
|
|
8
|
+
import { LoadingIndicatorComponent } from './elements/loading-indicator/loading-indicator.component';
|
|
9
|
+
import { NumberInputComponent } from './elements/number-input/number-input.component';
|
|
10
|
+
import { PasswordFieldComponent } from './elements/password-field/password-field.component';
|
|
11
|
+
import { SelectComponent } from './elements/select/select.component';
|
|
12
|
+
import { SortableItemsComponent } from './elements/sortable-items/sortable-items.component';
|
|
13
|
+
import { TextInputComponent } from './elements/text-input/text-input.component';
|
|
14
|
+
import { ToggleComponent } from './elements/toggle/toggle.component';
|
|
15
|
+
import { FormCaptionComponent } from './form/form-caption/form-caption.component';
|
|
16
|
+
import { FormElementComponent } from './form/form-element/form-element.component';
|
|
17
|
+
import { FormErrorComponent } from './form/form-error/form-error.component';
|
|
18
|
+
import { FormSubmitButtonComponent } from './form/form-submit-button/form-submit-button.component';
|
|
19
|
+
import { FormComponent, SubFormDirective } from './form/form.component';
|
|
20
|
+
import { SortablejsModule } from 'ngx-sortablejs';
|
|
21
|
+
import { NgSelectModule } from '@ng-select/ng-select';
|
|
22
|
+
import { DatepickerComponent } from './elements/datepicker/datepicker.component';
|
|
23
|
+
import { MaterialModule } from './material.module';
|
|
24
24
|
export class NgxEnhancyFormsModule {
|
|
25
25
|
}
|
|
26
26
|
NgxEnhancyFormsModule.decorators = [
|
|
@@ -50,6 +50,7 @@ NgxEnhancyFormsModule.decorators = [
|
|
|
50
50
|
FormErrorComponent,
|
|
51
51
|
FormSubmitButtonComponent,
|
|
52
52
|
FormComponent,
|
|
53
|
+
SubFormDirective,
|
|
53
54
|
],
|
|
54
55
|
exports: [
|
|
55
56
|
ValueAccessorBase,
|
|
@@ -69,7 +70,8 @@ NgxEnhancyFormsModule.decorators = [
|
|
|
69
70
|
FormErrorComponent,
|
|
70
71
|
FormSubmitButtonComponent,
|
|
71
72
|
FormComponent,
|
|
73
|
+
SubFormDirective,
|
|
72
74
|
]
|
|
73
75
|
},] }
|
|
74
76
|
];
|
|
75
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
77
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibmd4LWVuaGFuY3ktZm9ybXMubW9kdWxlLmpzIiwic291cmNlUm9vdCI6Ii9ob21lL3J1bm5lci93b3JrL25neC1lbmhhbmN5LWZvcm1zL25neC1lbmhhbmN5LWZvcm1zL3Byb2plY3RzL2tsaXBwYS9uZ3gtZW5oYW5jeS1mb3Jtcy9zcmMvIiwic291cmNlcyI6WyJsaWIvbmd4LWVuaGFuY3ktZm9ybXMubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBQyxRQUFRLEVBQUMsTUFBTSxlQUFlLENBQUM7QUFDdkMsT0FBTyxFQUFDLFlBQVksRUFBQyxNQUFNLGlCQUFpQixDQUFDO0FBQzdDLE9BQU8sRUFBQyxXQUFXLEVBQUMsTUFBTSxnQkFBZ0IsQ0FBQztBQUMzQyxPQUFPLEVBQUMsaUJBQWlCLEVBQUMsTUFBTSw4REFBOEQsQ0FBQztBQUMvRixPQUFPLEVBQUMsZUFBZSxFQUFDLE1BQU0sb0NBQW9DLENBQUM7QUFDbkUsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0sd0NBQXdDLENBQUM7QUFDekUsT0FBTyxFQUFDLG1CQUFtQixFQUFDLE1BQU0sd0NBQXdDLENBQUM7QUFDM0UsT0FBTyxFQUFDLHlCQUF5QixFQUFDLE1BQU0sMERBQTBELENBQUM7QUFDbkcsT0FBTyxFQUFDLG9CQUFvQixFQUFDLE1BQU0sZ0RBQWdELENBQUM7QUFDcEYsT0FBTyxFQUFDLHNCQUFzQixFQUFDLE1BQU0sb0RBQW9ELENBQUM7QUFDMUYsT0FBTyxFQUFDLGVBQWUsRUFBQyxNQUFNLG9DQUFvQyxDQUFDO0FBQ25FLE9BQU8sRUFBQyxzQkFBc0IsRUFBQyxNQUFNLG9EQUFvRCxDQUFDO0FBQzFGLE9BQU8sRUFBQyxrQkFBa0IsRUFBQyxNQUFNLDRDQUE0QyxDQUFDO0FBQzlFLE9BQU8sRUFBQyxlQUFlLEVBQUMsTUFBTSxvQ0FBb0MsQ0FBQztBQUNuRSxPQUFPLEVBQUMsb0JBQW9CLEVBQUMsTUFBTSw0Q0FBNEMsQ0FBQztBQUNoRixPQUFPLEVBQUMsb0JBQW9CLEVBQUMsTUFBTSw0Q0FBNEMsQ0FBQztBQUNoRixPQUFPLEVBQUMsa0JBQWtCLEVBQUMsTUFBTSx3Q0FBd0MsQ0FBQztBQUMxRSxPQUFPLEVBQUMseUJBQXlCLEVBQUMsTUFBTSx3REFBd0QsQ0FBQztBQUNqRyxPQUFPLEVBQUMsYUFBYSxFQUFFLGdCQUFnQixFQUFDLE1BQU0sdUJBQXVCLENBQUM7QUFDdEUsT0FBTyxFQUFDLGdCQUFnQixFQUFDLE1BQU0sZ0JBQWdCLENBQUM7QUFDaEQsT0FBTyxFQUFDLGNBQWMsRUFBQyxNQUFNLHNCQUFzQixDQUFDO0FBQ3BELE9BQU8sRUFBQyxtQkFBbUIsRUFBQyxNQUFNLDRDQUE0QyxDQUFDO0FBQy9FLE9BQU8sRUFBQyxjQUFjLEVBQUMsTUFBTSxtQkFBbUIsQ0FBQztBQW9EakQsTUFBTSxPQUFPLHFCQUFxQjs7O1lBakRqQyxRQUFRLFNBQUM7Z0JBQ1QsT0FBTyxFQUFFO29CQUNSLFlBQVk7b0JBQ1osV0FBVztvQkFDWCxjQUFjO29CQUNkLGdCQUFnQjtvQkFDaEIsY0FBYztpQkFDZDtnQkFDRCxZQUFZLEVBQUU7b0JBQ2IsaUJBQWlCO29CQUNqQixlQUFlO29CQUNmLGlCQUFpQjtvQkFDakIsbUJBQW1CO29CQUNuQixtQkFBbUI7b0JBQ25CLHlCQUF5QjtvQkFDekIsb0JBQW9CO29CQUNwQixzQkFBc0I7b0JBQ3RCLGVBQWU7b0JBQ2Ysc0JBQXNCO29CQUN0QixrQkFBa0I7b0JBQ2xCLGVBQWU7b0JBQ2Ysb0JBQW9CO29CQUNwQixvQkFBb0I7b0JBQ3BCLGtCQUFrQjtvQkFDbEIseUJBQXlCO29CQUN6QixhQUFhO29CQUNiLGdCQUFnQjtpQkFDaEI7Z0JBQ0QsT0FBTyxFQUFFO29CQUNSLGlCQUFpQjtvQkFDakIsZUFBZTtvQkFDZixtQkFBbUI7b0JBQ25CLGlCQUFpQjtvQkFDakIsbUJBQW1CO29CQUNuQix5QkFBeUI7b0JBQ3pCLG9CQUFvQjtvQkFDcEIsc0JBQXNCO29CQUN0QixlQUFlO29CQUNmLHNCQUFzQjtvQkFDdEIsa0JBQWtCO29CQUNsQixlQUFlO29CQUNmLG9CQUFvQjtvQkFDcEIsb0JBQW9CO29CQUNwQixrQkFBa0I7b0JBQ2xCLHlCQUF5QjtvQkFDekIsYUFBYTtvQkFDYixnQkFBZ0I7aUJBQ2hCO2FBQ0QiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge05nTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7Q29tbW9uTW9kdWxlfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHtGb3Jtc01vZHVsZX0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHtWYWx1ZUFjY2Vzc29yQmFzZX0gZnJvbSAnLi9lbGVtZW50cy92YWx1ZS1hY2Nlc3Nvci1iYXNlL3ZhbHVlLWFjY2Vzc29yLWJhc2UuY29tcG9uZW50JztcbmltcG9ydCB7QnV0dG9uQ29tcG9uZW50fSBmcm9tICcuL2VsZW1lbnRzL2J1dHRvbi9idXR0b24uY29tcG9uZW50JztcbmltcG9ydCB7Q2hlY2tib3hDb21wb25lbnR9IGZyb20gJy4vZWxlbWVudHMvY2hlY2tib3gvY2hlY2tib3guY29tcG9uZW50JztcbmltcG9ydCB7RW1haWxJbnB1dENvbXBvbmVudH0gZnJvbSAnLi9lbGVtZW50cy9lbWFpbC9lbWFpbC1pbnB1dC5jb21wb25lbnQnO1xuaW1wb3J0IHtMb2FkaW5nSW5kaWNhdG9yQ29tcG9uZW50fSBmcm9tICcuL2VsZW1lbnRzL2xvYWRpbmctaW5kaWNhdG9yL2xvYWRpbmctaW5kaWNhdG9yLmNvbXBvbmVudCc7XG5pbXBvcnQge051bWJlcklucHV0Q29tcG9uZW50fSBmcm9tICcuL2VsZW1lbnRzL251bWJlci1pbnB1dC9udW1iZXItaW5wdXQuY29tcG9uZW50JztcbmltcG9ydCB7UGFzc3dvcmRGaWVsZENvbXBvbmVudH0gZnJvbSAnLi9lbGVtZW50cy9wYXNzd29yZC1maWVsZC9wYXNzd29yZC1maWVsZC5jb21wb25lbnQnO1xuaW1wb3J0IHtTZWxlY3RDb21wb25lbnR9IGZyb20gJy4vZWxlbWVudHMvc2VsZWN0L3NlbGVjdC5jb21wb25lbnQnO1xuaW1wb3J0IHtTb3J0YWJsZUl0ZW1zQ29tcG9uZW50fSBmcm9tICcuL2VsZW1lbnRzL3NvcnRhYmxlLWl0ZW1zL3NvcnRhYmxlLWl0ZW1zLmNvbXBvbmVudCc7XG5pbXBvcnQge1RleHRJbnB1dENvbXBvbmVudH0gZnJvbSAnLi9lbGVtZW50cy90ZXh0LWlucHV0L3RleHQtaW5wdXQuY29tcG9uZW50JztcbmltcG9ydCB7VG9nZ2xlQ29tcG9uZW50fSBmcm9tICcuL2VsZW1lbnRzL3RvZ2dsZS90b2dnbGUuY29tcG9uZW50JztcbmltcG9ydCB7Rm9ybUNhcHRpb25Db21wb25lbnR9IGZyb20gJy4vZm9ybS9mb3JtLWNhcHRpb24vZm9ybS1jYXB0aW9uLmNvbXBvbmVudCc7XG5pbXBvcnQge0Zvcm1FbGVtZW50Q29tcG9uZW50fSBmcm9tICcuL2Zvcm0vZm9ybS1lbGVtZW50L2Zvcm0tZWxlbWVudC5jb21wb25lbnQnO1xuaW1wb3J0IHtGb3JtRXJyb3JDb21wb25lbnR9IGZyb20gJy4vZm9ybS9mb3JtLWVycm9yL2Zvcm0tZXJyb3IuY29tcG9uZW50JztcbmltcG9ydCB7Rm9ybVN1Ym1pdEJ1dHRvbkNvbXBvbmVudH0gZnJvbSAnLi9mb3JtL2Zvcm0tc3VibWl0LWJ1dHRvbi9mb3JtLXN1Ym1pdC1idXR0b24uY29tcG9uZW50JztcbmltcG9ydCB7Rm9ybUNvbXBvbmVudCwgU3ViRm9ybURpcmVjdGl2ZX0gZnJvbSAnLi9mb3JtL2Zvcm0uY29tcG9uZW50JztcbmltcG9ydCB7U29ydGFibGVqc01vZHVsZX0gZnJvbSAnbmd4LXNvcnRhYmxlanMnO1xuaW1wb3J0IHtOZ1NlbGVjdE1vZHVsZX0gZnJvbSAnQG5nLXNlbGVjdC9uZy1zZWxlY3QnO1xuaW1wb3J0IHtEYXRlcGlja2VyQ29tcG9uZW50fSBmcm9tICcuL2VsZW1lbnRzL2RhdGVwaWNrZXIvZGF0ZXBpY2tlci5jb21wb25lbnQnO1xuaW1wb3J0IHtNYXRlcmlhbE1vZHVsZX0gZnJvbSAnLi9tYXRlcmlhbC5tb2R1bGUnO1xuXG5cbkBOZ01vZHVsZSh7XG5cdGltcG9ydHM6IFtcblx0XHRDb21tb25Nb2R1bGUsXG5cdFx0Rm9ybXNNb2R1bGUsXG5cdFx0TmdTZWxlY3RNb2R1bGUsXG5cdFx0U29ydGFibGVqc01vZHVsZSxcblx0XHRNYXRlcmlhbE1vZHVsZSxcblx0XSxcblx0ZGVjbGFyYXRpb25zOiBbXG5cdFx0VmFsdWVBY2Nlc3NvckJhc2UsXG5cdFx0QnV0dG9uQ29tcG9uZW50LFxuXHRcdENoZWNrYm94Q29tcG9uZW50LFxuXHRcdERhdGVwaWNrZXJDb21wb25lbnQsXG5cdFx0RW1haWxJbnB1dENvbXBvbmVudCxcblx0XHRMb2FkaW5nSW5kaWNhdG9yQ29tcG9uZW50LFxuXHRcdE51bWJlcklucHV0Q29tcG9uZW50LFxuXHRcdFBhc3N3b3JkRmllbGRDb21wb25lbnQsXG5cdFx0U2VsZWN0Q29tcG9uZW50LFxuXHRcdFNvcnRhYmxlSXRlbXNDb21wb25lbnQsXG5cdFx0VGV4dElucHV0Q29tcG9uZW50LFxuXHRcdFRvZ2dsZUNvbXBvbmVudCxcblx0XHRGb3JtQ2FwdGlvbkNvbXBvbmVudCxcblx0XHRGb3JtRWxlbWVudENvbXBvbmVudCxcblx0XHRGb3JtRXJyb3JDb21wb25lbnQsXG5cdFx0Rm9ybVN1Ym1pdEJ1dHRvbkNvbXBvbmVudCxcblx0XHRGb3JtQ29tcG9uZW50LFxuXHRcdFN1YkZvcm1EaXJlY3RpdmUsXG5cdF0sXG5cdGV4cG9ydHM6IFtcblx0XHRWYWx1ZUFjY2Vzc29yQmFzZSxcblx0XHRCdXR0b25Db21wb25lbnQsXG5cdFx0RGF0ZXBpY2tlckNvbXBvbmVudCxcblx0XHRDaGVja2JveENvbXBvbmVudCxcblx0XHRFbWFpbElucHV0Q29tcG9uZW50LFxuXHRcdExvYWRpbmdJbmRpY2F0b3JDb21wb25lbnQsXG5cdFx0TnVtYmVySW5wdXRDb21wb25lbnQsXG5cdFx0UGFzc3dvcmRGaWVsZENvbXBvbmVudCxcblx0XHRTZWxlY3RDb21wb25lbnQsXG5cdFx0U29ydGFibGVJdGVtc0NvbXBvbmVudCxcblx0XHRUZXh0SW5wdXRDb21wb25lbnQsXG5cdFx0VG9nZ2xlQ29tcG9uZW50LFxuXHRcdEZvcm1DYXB0aW9uQ29tcG9uZW50LFxuXHRcdEZvcm1FbGVtZW50Q29tcG9uZW50LFxuXHRcdEZvcm1FcnJvckNvbXBvbmVudCxcblx0XHRGb3JtU3VibWl0QnV0dG9uQ29tcG9uZW50LFxuXHRcdEZvcm1Db21wb25lbnQsXG5cdFx0U3ViRm9ybURpcmVjdGl2ZSxcblx0XVxufSlcbmV4cG9ydCBjbGFzcyBOZ3hFbmhhbmN5Rm9ybXNNb2R1bGUge1xufVxuIl19
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import {
|
|
1
|
+
import { Directive, Input, Component, SkipSelf, Optional, InjectionToken, Host, Inject, ViewChild, HostBinding, EventEmitter, Output, ContentChild, TemplateRef, NgModule } from '@angular/core';
|
|
2
2
|
import { CommonModule } from '@angular/common';
|
|
3
3
|
import { FormGroup, FormArray, FormControl, ControlContainer, NG_VALUE_ACCESSOR, FormsModule } from '@angular/forms';
|
|
4
4
|
import { isString } from 'lodash';
|
|
@@ -10,44 +10,132 @@ import { MatFormFieldModule } from '@angular/material/form-field';
|
|
|
10
10
|
import { MatInputModule } from '@angular/material/input';
|
|
11
11
|
import { MatButtonModule } from '@angular/material/button';
|
|
12
12
|
|
|
13
|
+
function stringIsSetAndNotEmpty(s) {
|
|
14
|
+
return isString(s) && s.length > 0;
|
|
15
|
+
}
|
|
16
|
+
function isNullOrUndefined(value) {
|
|
17
|
+
return value === null || value === undefined;
|
|
18
|
+
}
|
|
19
|
+
function numberIsSet(value) {
|
|
20
|
+
return isValueSet(value) && typeof value === 'number';
|
|
21
|
+
}
|
|
22
|
+
function isValueSet(value) {
|
|
23
|
+
return value !== null && value !== undefined;
|
|
24
|
+
}
|
|
25
|
+
function stringOrArrayIsSetAndEmpty(value) {
|
|
26
|
+
return value !== null && value !== undefined && value.length === 0;
|
|
27
|
+
}
|
|
28
|
+
function useIfStringIsSet(s) {
|
|
29
|
+
if (stringIsSetAndNotEmpty(s)) {
|
|
30
|
+
return s;
|
|
31
|
+
}
|
|
32
|
+
return undefined;
|
|
33
|
+
}
|
|
34
|
+
function useIfArrayIsSetWithOneItem(a) {
|
|
35
|
+
if (!isNullOrUndefined(a) && a.length === 1) {
|
|
36
|
+
return a[0];
|
|
37
|
+
}
|
|
38
|
+
return undefined;
|
|
39
|
+
}
|
|
40
|
+
function convertParentToChild(originalClass, newClass) {
|
|
41
|
+
return Object.assign(newClass, originalClass);
|
|
42
|
+
}
|
|
43
|
+
function truncateString(s, length) {
|
|
44
|
+
if (s.length < length) {
|
|
45
|
+
return s;
|
|
46
|
+
}
|
|
47
|
+
return s.substring(0, length) + '...';
|
|
48
|
+
}
|
|
49
|
+
|
|
13
50
|
const invalidFieldsSymbol = Symbol('Not all fields are valid');
|
|
14
|
-
class
|
|
51
|
+
class SubFormDirective {
|
|
52
|
+
}
|
|
53
|
+
SubFormDirective.decorators = [
|
|
54
|
+
{ type: Directive, args: [{
|
|
55
|
+
// tslint:disable-next-line:directive-selector
|
|
56
|
+
selector: 'klp-sub-form',
|
|
57
|
+
},] }
|
|
58
|
+
];
|
|
59
|
+
SubFormDirective.propDecorators = {
|
|
60
|
+
injectInto: [{ type: Input }]
|
|
61
|
+
};
|
|
62
|
+
// Only used as a 'marker' to define a property will be filled in by a sub form
|
|
63
|
+
class SubForm extends FormGroup {
|
|
15
64
|
constructor() {
|
|
65
|
+
super({}, null);
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
class FormComponent {
|
|
69
|
+
constructor(parent, subFormPlaceholder) {
|
|
70
|
+
this.parent = parent;
|
|
71
|
+
this.subFormPlaceholder = subFormPlaceholder;
|
|
16
72
|
// we keep track of what form controls are actually rendered. Only those count when looking at form validation
|
|
17
73
|
this.activeControls = [];
|
|
18
74
|
}
|
|
75
|
+
ngOnInit() {
|
|
76
|
+
if (isValueSet(this.parent) && isValueSet(this.subFormPlaceholder)) {
|
|
77
|
+
const parentOfInjectInto = this.subFormPlaceholder.injectInto.parent;
|
|
78
|
+
if (parentOfInjectInto instanceof FormArray) {
|
|
79
|
+
const i = parentOfInjectInto.controls.findIndex((e) => e === this.subFormPlaceholder.injectInto);
|
|
80
|
+
parentOfInjectInto.setControl(i, this.formGroup);
|
|
81
|
+
}
|
|
82
|
+
else if (parentOfInjectInto instanceof FormGroup) {
|
|
83
|
+
const toReplace = Object.entries(parentOfInjectInto.controls).find(([key, val]) => {
|
|
84
|
+
return val === this.subFormPlaceholder.injectInto;
|
|
85
|
+
});
|
|
86
|
+
if (!((toReplace === null || toReplace === void 0 ? void 0 : toReplace[1]) instanceof SubForm)) {
|
|
87
|
+
throw new Error(`You are trying to inject a subForm ('${toReplace === null || toReplace === void 0 ? void 0 : toReplace[0]}') within something that is not annotated as such.`);
|
|
88
|
+
}
|
|
89
|
+
parentOfInjectInto.setControl(toReplace[0], this.formGroup);
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
}
|
|
19
93
|
registerControl(formControl, formElement) {
|
|
20
94
|
this.activeControls.push({ formControl, formElement });
|
|
95
|
+
if (this.parent) {
|
|
96
|
+
this.parent.registerControl(formControl, formElement);
|
|
97
|
+
}
|
|
21
98
|
}
|
|
22
99
|
unregisterControl(formControl) {
|
|
23
100
|
this.activeControls = this.activeControls.filter((e) => e.formControl !== formControl);
|
|
101
|
+
if (this.parent) {
|
|
102
|
+
this.parent.unregisterControl(formControl);
|
|
103
|
+
}
|
|
24
104
|
}
|
|
25
|
-
|
|
105
|
+
addFormGroupControls(formGroup, result) {
|
|
26
106
|
Object.values(formGroup.controls).forEach((value) => {
|
|
27
107
|
if (value instanceof FormGroup) {
|
|
28
|
-
this.
|
|
108
|
+
this.addFormGroupControls(value, result);
|
|
29
109
|
}
|
|
30
110
|
else if (value instanceof FormArray) {
|
|
31
|
-
this.
|
|
111
|
+
this.addFormArrayControls(value, result);
|
|
32
112
|
}
|
|
33
113
|
else if (value instanceof FormControl) {
|
|
34
|
-
this.
|
|
114
|
+
this.addFormControl(value, result);
|
|
35
115
|
}
|
|
36
116
|
});
|
|
37
117
|
}
|
|
38
|
-
|
|
118
|
+
addFormArrayControls(formArray, result) {
|
|
39
119
|
formArray.controls.forEach((value) => {
|
|
40
120
|
if (value instanceof FormGroup) {
|
|
41
|
-
this.
|
|
121
|
+
this.addFormGroupControls(value, result);
|
|
42
122
|
}
|
|
43
123
|
else if (value instanceof FormArray) {
|
|
44
|
-
this.
|
|
124
|
+
this.addFormArrayControls(value, result);
|
|
45
125
|
}
|
|
46
126
|
else if (value instanceof FormControl) {
|
|
47
|
-
this.
|
|
127
|
+
this.addFormControl(value, result);
|
|
48
128
|
}
|
|
49
129
|
});
|
|
50
130
|
}
|
|
131
|
+
getAllFormControls() {
|
|
132
|
+
const result = [];
|
|
133
|
+
this.addFormGroupControls(this.formGroup, result);
|
|
134
|
+
return result;
|
|
135
|
+
}
|
|
136
|
+
addFormControl(control, result) {
|
|
137
|
+
result.push(control);
|
|
138
|
+
}
|
|
51
139
|
disableInactiveFormControl(control) {
|
|
52
140
|
if (!this.activeControls.some((e) => e.formControl === control)) {
|
|
53
141
|
control.disable();
|
|
@@ -56,10 +144,11 @@ class FormComponent {
|
|
|
56
144
|
trySubmit() {
|
|
57
145
|
var _a, _b;
|
|
58
146
|
this.formGroup.markAllAsTouched();
|
|
59
|
-
const
|
|
147
|
+
const allControls = this.getAllFormControls();
|
|
148
|
+
const originalDisabledStates = allControls.map(e => {
|
|
60
149
|
return { control: e, disabled: e.disabled };
|
|
61
150
|
});
|
|
62
|
-
|
|
151
|
+
allControls.forEach(e => this.disableInactiveFormControl(e));
|
|
63
152
|
const values = this.formGroup.value;
|
|
64
153
|
if (this.formGroup.valid) {
|
|
65
154
|
this.setDisabledStatesForAllControls(originalDisabledStates);
|
|
@@ -89,6 +178,10 @@ FormComponent.decorators = [
|
|
|
89
178
|
styles: [":host{display:block}:host.row{display:flex}"]
|
|
90
179
|
},] }
|
|
91
180
|
];
|
|
181
|
+
FormComponent.ctorParameters = () => [
|
|
182
|
+
{ type: FormComponent, decorators: [{ type: SkipSelf }, { type: Optional }] },
|
|
183
|
+
{ type: SubFormDirective, decorators: [{ type: Optional }] }
|
|
184
|
+
];
|
|
92
185
|
FormComponent.propDecorators = {
|
|
93
186
|
formGroup: [{ type: Input }]
|
|
94
187
|
};
|
|
@@ -121,6 +214,8 @@ class FormElementComponent {
|
|
|
121
214
|
}, message);
|
|
122
215
|
}
|
|
123
216
|
registerControl(formControl) {
|
|
217
|
+
// console.log('register');
|
|
218
|
+
// console.log(this.caption);
|
|
124
219
|
this.attachedControl = formControl;
|
|
125
220
|
this.parent.registerControl(formControl, this);
|
|
126
221
|
}
|
|
@@ -191,43 +286,6 @@ FormElementComponent.propDecorators = {
|
|
|
191
286
|
internalComponentRef: [{ type: ViewChild, args: ['internalComponentRef',] }]
|
|
192
287
|
};
|
|
193
288
|
|
|
194
|
-
function stringIsSetAndNotEmpty(s) {
|
|
195
|
-
return isString(s) && s.length > 0;
|
|
196
|
-
}
|
|
197
|
-
function isNullOrUndefined(value) {
|
|
198
|
-
return value === null || value === undefined;
|
|
199
|
-
}
|
|
200
|
-
function numberIsSet(value) {
|
|
201
|
-
return isValueSet(value) && typeof value === 'number';
|
|
202
|
-
}
|
|
203
|
-
function isValueSet(value) {
|
|
204
|
-
return value !== null && value !== undefined;
|
|
205
|
-
}
|
|
206
|
-
function stringOrArrayIsSetAndEmpty(value) {
|
|
207
|
-
return value !== null && value !== undefined && value.length === 0;
|
|
208
|
-
}
|
|
209
|
-
function useIfStringIsSet(s) {
|
|
210
|
-
if (stringIsSetAndNotEmpty(s)) {
|
|
211
|
-
return s;
|
|
212
|
-
}
|
|
213
|
-
return undefined;
|
|
214
|
-
}
|
|
215
|
-
function useIfArrayIsSetWithOneItem(a) {
|
|
216
|
-
if (!isNullOrUndefined(a) && a.length === 1) {
|
|
217
|
-
return a[0];
|
|
218
|
-
}
|
|
219
|
-
return undefined;
|
|
220
|
-
}
|
|
221
|
-
function convertParentToChild(originalClass, newClass) {
|
|
222
|
-
return Object.assign(newClass, originalClass);
|
|
223
|
-
}
|
|
224
|
-
function truncateString(s, length) {
|
|
225
|
-
if (s.length < length) {
|
|
226
|
-
return s;
|
|
227
|
-
}
|
|
228
|
-
return s.substring(0, length) + '...';
|
|
229
|
-
}
|
|
230
|
-
|
|
231
289
|
/**
|
|
232
290
|
* This component is a base in order to create a component that supports ngModel.
|
|
233
291
|
* Some important things to know about it:
|
|
@@ -784,6 +842,7 @@ NgxEnhancyFormsModule.decorators = [
|
|
|
784
842
|
FormErrorComponent,
|
|
785
843
|
FormSubmitButtonComponent,
|
|
786
844
|
FormComponent,
|
|
845
|
+
SubFormDirective,
|
|
787
846
|
],
|
|
788
847
|
exports: [
|
|
789
848
|
ValueAccessorBase,
|
|
@@ -803,6 +862,7 @@ NgxEnhancyFormsModule.decorators = [
|
|
|
803
862
|
FormErrorComponent,
|
|
804
863
|
FormSubmitButtonComponent,
|
|
805
864
|
FormComponent,
|
|
865
|
+
SubFormDirective,
|
|
806
866
|
]
|
|
807
867
|
},] }
|
|
808
868
|
];
|
|
@@ -815,5 +875,5 @@ NgxEnhancyFormsModule.decorators = [
|
|
|
815
875
|
* Generated bundle index. Do not edit.
|
|
816
876
|
*/
|
|
817
877
|
|
|
818
|
-
export { ButtonComponent, CheckboxComponent, DEFAULT_ERROR_MESSAGES, DatepickerComponent, EmailInputComponent, FORM_ERROR_MESSAGES, FormCaptionComponent, FormComponent, FormElementComponent, FormErrorComponent, FormSubmitButtonComponent, KLP_DATE_FORMATS, LoadingIndicatorComponent, NgxEnhancyFormsModule, NumberInputComponent, PasswordFieldComponent, SelectComponent, SortableItemsComponent, TextInputComponent, ToggleComponent, ValueAccessorBase, dateValidator, invalidDateKey, invalidFieldsSymbol, matDateFormatsFactory, MaterialModule as ɵa };
|
|
878
|
+
export { ButtonComponent, CheckboxComponent, DEFAULT_ERROR_MESSAGES, DatepickerComponent, EmailInputComponent, FORM_ERROR_MESSAGES, FormCaptionComponent, FormComponent, FormElementComponent, FormErrorComponent, FormSubmitButtonComponent, KLP_DATE_FORMATS, LoadingIndicatorComponent, NgxEnhancyFormsModule, NumberInputComponent, PasswordFieldComponent, SelectComponent, SortableItemsComponent, SubForm, SubFormDirective, TextInputComponent, ToggleComponent, ValueAccessorBase, dateValidator, invalidDateKey, invalidFieldsSymbol, matDateFormatsFactory, MaterialModule as ɵa };
|
|
819
879
|
//# sourceMappingURL=klippa-ngx-enhancy-forms.js.map
|