@recursyve/nice-ui-kit.v2 16.0.0-beta.140 → 16.0.0-beta.142
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/esm2022/lib/components/form-error/control-status.directive.mjs +59 -59
- package/esm2022/lib/components/translation-form/components/translation-form.component.mjs +2 -2
- package/esm2022/lib/utils/file.utils.mjs +14 -1
- package/fesm2022/recursyve-nice-ui-kit.v2.mjs +72 -59
- package/fesm2022/recursyve-nice-ui-kit.v2.mjs.map +1 -1
- package/lib/components/form-error/control-status.directive.d.ts +1 -1
- package/lib/utils/file.utils.d.ts +3 -0
- package/package.json +1 -1
|
@@ -14,6 +14,64 @@ export class NiceControlStatusDirective {
|
|
|
14
14
|
this.formField = formField;
|
|
15
15
|
this.translateService = translateService;
|
|
16
16
|
this.unsubscribeAll$ = new Subject();
|
|
17
|
+
this.onChange = () => {
|
|
18
|
+
if (this.control.pending) {
|
|
19
|
+
return;
|
|
20
|
+
}
|
|
21
|
+
if (this.control.invalid && this.control.touched) {
|
|
22
|
+
for (const error in this.control.errors) {
|
|
23
|
+
if (this.control.errors.hasOwnProperty(error)) {
|
|
24
|
+
if (this.control.errors[error]) {
|
|
25
|
+
let lastErrorKey = error;
|
|
26
|
+
let param;
|
|
27
|
+
if (error === "pattern") {
|
|
28
|
+
lastErrorKey = this.control.errors[error].requiredPattern;
|
|
29
|
+
}
|
|
30
|
+
if (error === "mask") {
|
|
31
|
+
lastErrorKey = this.control.errors[error].requiredMask;
|
|
32
|
+
}
|
|
33
|
+
if (error === "minlength" || error === "maxlength") {
|
|
34
|
+
param = {
|
|
35
|
+
value: this.control.errors[error].requiredLength
|
|
36
|
+
};
|
|
37
|
+
}
|
|
38
|
+
if (error === "min") {
|
|
39
|
+
param = {
|
|
40
|
+
min: this.control.errors[error].min,
|
|
41
|
+
actual: this.control.errors[error].actual
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
if (error === "max") {
|
|
45
|
+
param = {
|
|
46
|
+
max: this.control.errors[error].max,
|
|
47
|
+
actual: this.control.errors[error].actual
|
|
48
|
+
};
|
|
49
|
+
}
|
|
50
|
+
if (error === "arrayMinLength") {
|
|
51
|
+
param = {
|
|
52
|
+
min: this.control.errors[error].min,
|
|
53
|
+
actual: this.control.errors[error].actual
|
|
54
|
+
};
|
|
55
|
+
}
|
|
56
|
+
if (error === "arrayMaxLength") {
|
|
57
|
+
param = {
|
|
58
|
+
max: this.control.errors[error].max,
|
|
59
|
+
actual: this.control.errors[error].actual
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
if (typeof this.control.errors[error] === "object" && !param) {
|
|
63
|
+
param = this.control.errors[error];
|
|
64
|
+
}
|
|
65
|
+
this.setError(this.translateService.instant(`errors.${lastErrorKey}`, param));
|
|
66
|
+
break;
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
else {
|
|
72
|
+
this.setError("");
|
|
73
|
+
}
|
|
74
|
+
};
|
|
17
75
|
}
|
|
18
76
|
ngAfterViewInit() {
|
|
19
77
|
this.control = this.formField._control.ngControl;
|
|
@@ -25,64 +83,6 @@ export class NiceControlStatusDirective {
|
|
|
25
83
|
this.unsubscribeAll$.next();
|
|
26
84
|
this.unsubscribeAll$.complete();
|
|
27
85
|
}
|
|
28
|
-
onChange() {
|
|
29
|
-
if (this.control.pending) {
|
|
30
|
-
return;
|
|
31
|
-
}
|
|
32
|
-
if (this.control.invalid && this.control.touched) {
|
|
33
|
-
for (const error in this.control.errors) {
|
|
34
|
-
if (this.control.errors.hasOwnProperty(error)) {
|
|
35
|
-
if (this.control.errors[error]) {
|
|
36
|
-
let lastErrorKey = error;
|
|
37
|
-
let param;
|
|
38
|
-
if (error === "pattern") {
|
|
39
|
-
lastErrorKey = this.control.errors[error].requiredPattern;
|
|
40
|
-
}
|
|
41
|
-
if (error === "mask") {
|
|
42
|
-
lastErrorKey = this.control.errors[error].requiredMask;
|
|
43
|
-
}
|
|
44
|
-
if (error === "minlength" || error === "maxlength") {
|
|
45
|
-
param = {
|
|
46
|
-
value: this.control.errors[error].requiredLength
|
|
47
|
-
};
|
|
48
|
-
}
|
|
49
|
-
if (error === "min") {
|
|
50
|
-
param = {
|
|
51
|
-
min: this.control.errors[error].min,
|
|
52
|
-
actual: this.control.errors[error].actual
|
|
53
|
-
};
|
|
54
|
-
}
|
|
55
|
-
if (error === "max") {
|
|
56
|
-
param = {
|
|
57
|
-
max: this.control.errors[error].max,
|
|
58
|
-
actual: this.control.errors[error].actual
|
|
59
|
-
};
|
|
60
|
-
}
|
|
61
|
-
if (error === "arrayMinLength") {
|
|
62
|
-
param = {
|
|
63
|
-
min: this.control.errors[error].min,
|
|
64
|
-
actual: this.control.errors[error].actual
|
|
65
|
-
};
|
|
66
|
-
}
|
|
67
|
-
if (error === "arrayMaxLength") {
|
|
68
|
-
param = {
|
|
69
|
-
max: this.control.errors[error].max,
|
|
70
|
-
actual: this.control.errors[error].actual
|
|
71
|
-
};
|
|
72
|
-
}
|
|
73
|
-
if (typeof this.control.errors[error] === "object" && !param) {
|
|
74
|
-
param = this.control.errors[error];
|
|
75
|
-
}
|
|
76
|
-
this.setError(this.translateService.instant(`errors.${lastErrorKey}`, param));
|
|
77
|
-
break;
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
else {
|
|
83
|
-
this.setError("");
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
86
|
setError(text) {
|
|
87
87
|
if (!this.ref) {
|
|
88
88
|
this.ref = this.vcr.createComponent(NiceFormErrorComponent);
|
|
@@ -122,4 +122,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.5", ngImpor
|
|
|
122
122
|
type: Directive,
|
|
123
123
|
args: [{ selector: "[niceControlStatus]" }]
|
|
124
124
|
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ViewContainerRef }, { type: i1.MatFormField }, { type: i2.TranslateService }]; } });
|
|
125
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"control-status.directive.js","sourceRoot":"","sources":["../../../../../../projects/nice-ui-kit-v2/src/lib/components/form-error/control-status.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ComponentRef, Directive, ElementRef, OnDestroy, ViewContainerRef } from \"@angular/core\";\nimport { NgControl } from \"@angular/forms\";\nimport { MatFormField } from \"@angular/material/form-field\";\nimport { TranslateService } from \"@ngx-translate/core\";\nimport { th } from \"date-fns/locale\";\nimport { NiceFormErrorComponent } from \"./form-error.component\";\nimport { Subject, combineLatest } from \"rxjs\";\nimport { takeUntil } from \"rxjs/operators\";\n\n@Directive({ selector: \"[niceControlStatus]\" })\nexport class NiceControlStatusDirective implements AfterViewInit, OnDestroy {\n    private ref: ComponentRef<NiceFormErrorComponent>;\n    private control: NgControl;\n\n    private unsubscribeAll$ = new Subject<void>();\n\n    constructor(\n        private el: ElementRef<HTMLElement>,\n        private vcr: ViewContainerRef,\n        private formField: MatFormField,\n        private translateService: TranslateService\n    ) {}\n\n    public ngAfterViewInit(): void {\n        this.control = this.formField._control.ngControl as NgControl;\n        combineLatest([this.formField._control.stateChanges, this.control.statusChanges])\n            .pipe(takeUntil(this.unsubscribeAll$))\n            .subscribe(() => this.onChange());\n    }\n\n    public ngOnDestroy(): void {\n        this.unsubscribeAll$.next();\n        this.unsubscribeAll$.complete();\n    }\n\n    public onChange(): void {\n        if (this.control.pending) {\n            return;\n        }\n\n        if (this.control.invalid && this.control.touched) {\n            for (const error in this.control.errors) {\n                if (this.control.errors.hasOwnProperty(error)) {\n                    if (this.control.errors[error]) {\n                        let lastErrorKey = error;\n                        let param: any;\n                        if (error === \"pattern\") {\n                            lastErrorKey = this.control.errors[error].requiredPattern;\n                        }\n                        if (error === \"mask\") {\n                            lastErrorKey = this.control.errors[error].requiredMask;\n                        }\n                        if (error === \"minlength\" || error === \"maxlength\") {\n                            param = {\n                                value: this.control.errors[error].requiredLength\n                            };\n                        }\n                        if (error === \"min\") {\n                            param = {\n                                min: this.control.errors[error].min,\n                                actual: this.control.errors[error].actual\n                            };\n                        }\n                        if (error === \"max\") {\n                            param = {\n                                max: this.control.errors[error].max,\n                                actual: this.control.errors[error].actual\n                            };\n                        }\n                        if (error === \"arrayMinLength\") {\n                            param = {\n                                min: this.control.errors[error].min,\n                                actual: this.control.errors[error].actual\n                            };\n                        }\n                        if (error === \"arrayMaxLength\") {\n                            param = {\n                                max: this.control.errors[error].max,\n                                actual: this.control.errors[error].actual\n                            };\n                        }\n\n                        if (typeof this.control.errors[error] === \"object\" && !param) {\n                            param = this.control.errors[error];\n                        }\n\n                        this.setError(this.translateService.instant(`errors.${lastErrorKey}`, param));\n                        break;\n                    }\n                }\n            }\n        } else {\n            this.setError(\"\");\n        }\n    }\n\n    public setError(text: string): void {\n        if (!this.ref) {\n            this.ref = this.vcr.createComponent(NiceFormErrorComponent);\n            if (this.el.nativeElement.getElementsByClassName(\"mat-form-field-wrapper\").item(0)) {\n                this.el.nativeElement\n                    .getElementsByClassName(\"mat-form-field-wrapper\")\n                    .item(0)\n                    .getElementsByClassName(\"mat-form-field-subscript-wrapper\")\n                    .item(0)\n                    .appendChild(this.ref.location.nativeElement);\n            }\n\n            if (this.el.nativeElement.getElementsByClassName(\"mat-mdc-form-field-subscript-wrapper\").item(0)) {\n                const hint = this.el.nativeElement.getElementsByClassName(\"mat-mdc-form-field-hint\").item(0);\n                (this.ref.location.nativeElement as HTMLDivElement).style.position = \"absolute\";\n                (this.ref.location.nativeElement as HTMLDivElement).style.top = hint ? \"16px\" : \"0\";\n\n                const wrapper = this.el.nativeElement\n                    .getElementsByClassName(\"mat-mdc-form-field-subscript-wrapper\")\n                    .item(0);\n                if (hint) {\n                    wrapper.classList.add(\"override-height\");\n                }\n\n                wrapper.prepend(this.ref.location.nativeElement);\n            }\n        }\n        if (text) {\n            this.el.nativeElement.classList.add(\"form-error-show\");\n        } else {\n            this.el.nativeElement.classList.remove(\"form-error-show\");\n        }\n        this.ref.instance.error = text;\n    }\n}\n"]}
|
|
125
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"control-status.directive.js","sourceRoot":"","sources":["../../../../../../projects/nice-ui-kit-v2/src/lib/components/form-error/control-status.directive.ts"],"names":[],"mappings":"AAAA,OAAO,EAA+B,SAAS,EAAE,UAAU,EAAa,gBAAgB,EAAE,MAAM,eAAe,CAAC;AAEhH,OAAO,EAAE,YAAY,EAAE,MAAM,8BAA8B,CAAC;AAC5D,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AAEvD,OAAO,EAAE,sBAAsB,EAAE,MAAM,wBAAwB,CAAC;AAChE,OAAO,EAAE,OAAO,EAAE,aAAa,EAAE,MAAM,MAAM,CAAC;AAC9C,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;;;;AAG3C,MAAM,OAAO,0BAA0B;IAmEnC,YACY,EAA2B,EAC3B,GAAqB,EACrB,SAAuB,EACvB,gBAAkC;QAHlC,OAAE,GAAF,EAAE,CAAyB;QAC3B,QAAG,GAAH,GAAG,CAAkB;QACrB,cAAS,GAAT,SAAS,CAAc;QACvB,qBAAgB,GAAhB,gBAAgB,CAAkB;QAnEtC,oBAAe,GAAG,IAAI,OAAO,EAAQ,CAAC;QAEvC,aAAQ,GAAG,GAAG,EAAE;YACnB,IAAI,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE;gBACtB,OAAO;aACV;YAED,IAAI,IAAI,CAAC,OAAO,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE;gBAC9C,KAAK,MAAM,KAAK,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE;oBACrC,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,cAAc,CAAC,KAAK,CAAC,EAAE;wBAC3C,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE;4BAC5B,IAAI,YAAY,GAAG,KAAK,CAAC;4BACzB,IAAI,KAAU,CAAC;4BACf,IAAI,KAAK,KAAK,SAAS,EAAE;gCACrB,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,eAAe,CAAC;6BAC7D;4BACD,IAAI,KAAK,KAAK,MAAM,EAAE;gCAClB,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,YAAY,CAAC;6BAC1D;4BACD,IAAI,KAAK,KAAK,WAAW,IAAI,KAAK,KAAK,WAAW,EAAE;gCAChD,KAAK,GAAG;oCACJ,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,cAAc;iCACnD,CAAC;6BACL;4BACD,IAAI,KAAK,KAAK,KAAK,EAAE;gCACjB,KAAK,GAAG;oCACJ,GAAG,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,GAAG;oCACnC,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,MAAM;iCAC5C,CAAC;6BACL;4BACD,IAAI,KAAK,KAAK,KAAK,EAAE;gCACjB,KAAK,GAAG;oCACJ,GAAG,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,GAAG;oCACnC,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,MAAM;iCAC5C,CAAC;6BACL;4BACD,IAAI,KAAK,KAAK,gBAAgB,EAAE;gCAC5B,KAAK,GAAG;oCACJ,GAAG,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,GAAG;oCACnC,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,MAAM;iCAC5C,CAAC;6BACL;4BACD,IAAI,KAAK,KAAK,gBAAgB,EAAE;gCAC5B,KAAK,GAAG;oCACJ,GAAG,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,GAAG;oCACnC,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,MAAM;iCAC5C,CAAC;6BACL;4BAED,IAAI,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,QAAQ,IAAI,CAAC,KAAK,EAAE;gCAC1D,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;6BACtC;4BAED,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,UAAU,YAAY,EAAE,EAAE,KAAK,CAAC,CAAC,CAAC;4BAC9E,MAAM;yBACT;qBACJ;iBACJ;aACJ;iBAAM;gBACH,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;aACrB;QACL,CAAC,CAAA;IAOE,CAAC;IAEG,eAAe;QAClB,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,SAAsB,CAAC;QAC9D,aAAa,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,YAAY,EAAE,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;aAC5E,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;aACrC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;IAC1C,CAAC;IAEM,WAAW;QACd,IAAI,CAAC,eAAe,CAAC,IAAI,EAAE,CAAC;QAC5B,IAAI,CAAC,eAAe,CAAC,QAAQ,EAAE,CAAC;IACpC,CAAC;IAEM,QAAQ,CAAC,IAAY;QACxB,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE;YACX,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,eAAe,CAAC,sBAAsB,CAAC,CAAC;YAC5D,IAAI,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,sBAAsB,CAAC,wBAAwB,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE;gBAChF,IAAI,CAAC,EAAE,CAAC,aAAa;qBAChB,sBAAsB,CAAC,wBAAwB,CAAC;qBAChD,IAAI,CAAC,CAAC,CAAC;qBACP,sBAAsB,CAAC,kCAAkC,CAAC;qBAC1D,IAAI,CAAC,CAAC,CAAC;qBACP,WAAW,CAAC,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC;aACrD;YAED,IAAI,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,sBAAsB,CAAC,sCAAsC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE;gBAC9F,MAAM,IAAI,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,sBAAsB,CAAC,yBAAyB,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;gBAC5F,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,aAAgC,CAAC,KAAK,CAAC,QAAQ,GAAG,UAAU,CAAC;gBAC/E,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,aAAgC,CAAC,KAAK,CAAC,GAAG,GAAG,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC;gBAEpF,MAAM,OAAO,GAAG,IAAI,CAAC,EAAE,CAAC,aAAa;qBAChC,sBAAsB,CAAC,sCAAsC,CAAC;qBAC9D,IAAI,CAAC,CAAC,CAAC,CAAC;gBACb,IAAI,IAAI,EAAE;oBACN,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC;iBAC5C;gBAED,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC;aACpD;SACJ;QACD,IAAI,IAAI,EAAE;YACN,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,SAAS,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC;SAC1D;aAAM;YACH,IAAI,CAAC,EAAE,CAAC,aAAa,CAAC,SAAS,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAC;SAC7D;QACD,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,KAAK,GAAG,IAAI,CAAC;IACnC,CAAC;8GAvHQ,0BAA0B;kGAA1B,0BAA0B;;2FAA1B,0BAA0B;kBADtC,SAAS;mBAAC,EAAE,QAAQ,EAAE,qBAAqB,EAAE","sourcesContent":["import { AfterViewInit, ComponentRef, Directive, ElementRef, OnDestroy, ViewContainerRef } from \"@angular/core\";\nimport { NgControl } from \"@angular/forms\";\nimport { MatFormField } from \"@angular/material/form-field\";\nimport { TranslateService } from \"@ngx-translate/core\";\nimport { th } from \"date-fns/locale\";\nimport { NiceFormErrorComponent } from \"./form-error.component\";\nimport { Subject, combineLatest } from \"rxjs\";\nimport { takeUntil } from \"rxjs/operators\";\n\n@Directive({ selector: \"[niceControlStatus]\" })\nexport class NiceControlStatusDirective implements AfterViewInit, OnDestroy {\n    private ref: ComponentRef<NiceFormErrorComponent>;\n    private control: NgControl;\n\n    private unsubscribeAll$ = new Subject<void>();\n\n    public onChange = () => {\n        if (this.control.pending) {\n            return;\n        }\n\n        if (this.control.invalid && this.control.touched) {\n            for (const error in this.control.errors) {\n                if (this.control.errors.hasOwnProperty(error)) {\n                    if (this.control.errors[error]) {\n                        let lastErrorKey = error;\n                        let param: any;\n                        if (error === \"pattern\") {\n                            lastErrorKey = this.control.errors[error].requiredPattern;\n                        }\n                        if (error === \"mask\") {\n                            lastErrorKey = this.control.errors[error].requiredMask;\n                        }\n                        if (error === \"minlength\" || error === \"maxlength\") {\n                            param = {\n                                value: this.control.errors[error].requiredLength\n                            };\n                        }\n                        if (error === \"min\") {\n                            param = {\n                                min: this.control.errors[error].min,\n                                actual: this.control.errors[error].actual\n                            };\n                        }\n                        if (error === \"max\") {\n                            param = {\n                                max: this.control.errors[error].max,\n                                actual: this.control.errors[error].actual\n                            };\n                        }\n                        if (error === \"arrayMinLength\") {\n                            param = {\n                                min: this.control.errors[error].min,\n                                actual: this.control.errors[error].actual\n                            };\n                        }\n                        if (error === \"arrayMaxLength\") {\n                            param = {\n                                max: this.control.errors[error].max,\n                                actual: this.control.errors[error].actual\n                            };\n                        }\n\n                        if (typeof this.control.errors[error] === \"object\" && !param) {\n                            param = this.control.errors[error];\n                        }\n\n                        this.setError(this.translateService.instant(`errors.${lastErrorKey}`, param));\n                        break;\n                    }\n                }\n            }\n        } else {\n            this.setError(\"\");\n        }\n    }\n\n    constructor(\n        private el: ElementRef<HTMLElement>,\n        private vcr: ViewContainerRef,\n        private formField: MatFormField,\n        private translateService: TranslateService\n    ) {}\n\n    public ngAfterViewInit(): void {\n        this.control = this.formField._control.ngControl as NgControl;\n        combineLatest([this.formField._control.stateChanges, this.control.statusChanges])\n            .pipe(takeUntil(this.unsubscribeAll$))\n            .subscribe(() => this.onChange());\n    }\n\n    public ngOnDestroy(): void {\n        this.unsubscribeAll$.next();\n        this.unsubscribeAll$.complete();\n    }\n\n    public setError(text: string): void {\n        if (!this.ref) {\n            this.ref = this.vcr.createComponent(NiceFormErrorComponent);\n            if (this.el.nativeElement.getElementsByClassName(\"mat-form-field-wrapper\").item(0)) {\n                this.el.nativeElement\n                    .getElementsByClassName(\"mat-form-field-wrapper\")\n                    .item(0)\n                    .getElementsByClassName(\"mat-form-field-subscript-wrapper\")\n                    .item(0)\n                    .appendChild(this.ref.location.nativeElement);\n            }\n\n            if (this.el.nativeElement.getElementsByClassName(\"mat-mdc-form-field-subscript-wrapper\").item(0)) {\n                const hint = this.el.nativeElement.getElementsByClassName(\"mat-mdc-form-field-hint\").item(0);\n                (this.ref.location.nativeElement as HTMLDivElement).style.position = \"absolute\";\n                (this.ref.location.nativeElement as HTMLDivElement).style.top = hint ? \"16px\" : \"0\";\n\n                const wrapper = this.el.nativeElement\n                    .getElementsByClassName(\"mat-mdc-form-field-subscript-wrapper\")\n                    .item(0);\n                if (hint) {\n                    wrapper.classList.add(\"override-height\");\n                }\n\n                wrapper.prepend(this.ref.location.nativeElement);\n            }\n        }\n        if (text) {\n            this.el.nativeElement.classList.add(\"form-error-show\");\n        } else {\n            this.el.nativeElement.classList.remove(\"form-error-show\");\n        }\n        this.ref.instance.error = text;\n    }\n}\n"]}
|
|
@@ -17,7 +17,7 @@ export class TranslationFormComponent {
|
|
|
17
17
|
};
|
|
18
18
|
}
|
|
19
19
|
get shouldLabelFloat() {
|
|
20
|
-
return this.floating || !this.empty;
|
|
20
|
+
return this.floating || !this.empty || this.focused;
|
|
21
21
|
}
|
|
22
22
|
set required(req) {
|
|
23
23
|
this._required = coerceBooleanProperty(req);
|
|
@@ -169,4 +169,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.5", ngImpor
|
|
|
169
169
|
type: HostBinding,
|
|
170
170
|
args: ["attr.aria-describedby"]
|
|
171
171
|
}] } });
|
|
172
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"translation-form.component.js","sourceRoot":"","sources":["../../../../../../../projects/nice-ui-kit-v2/src/lib/components/translation-form/components/translation-form.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { coerceBooleanProperty } from \"@angular/cdk/coercion\";\nimport {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    HostBinding,\n    Input,\n    OnDestroy,\n    OnInit,\n} from \"@angular/core\";\nimport {\n    AbstractControlDirective,\n    ControlContainer,\n    ControlValueAccessor,\n    FormControl,\n    FormGroup,\n    NgControl,\n    Validators,\n} from \"@angular/forms\";\nimport { MatFormFieldControl } from \"@angular/material/form-field\";\nimport { Subject } from \"rxjs\";\nimport { takeUntil } from \"rxjs/operators\";\nimport * as uuid from \"uuid\";\nimport { TranslationContextDirective } from \"../directives/translation-context.directive\";\nimport { NiceTranslationFormService } from \"../providers/nice-translation-form.service\";\n\n@Component({\n    template: ``,\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport abstract class TranslationFormComponent\n    implements\n        OnInit,\n        OnDestroy,\n        MatFormFieldControl<string>,\n        ControlValueAccessor\n{\n    @HostBinding(\"class\")\n    public get classList(): any {\n        return {\n            \"w-full\": true\n        };\n    }\n\n    @HostBinding(\"class.floating\")\n    public get shouldLabelFloat(): boolean {\n        return this.floating || !this.empty;\n    }\n\n    @Input()\n    public set required(req) {\n        this._required = coerceBooleanProperty(req);\n        this.stateChanges.next();\n    }\n\n    public get required(): boolean {\n        return (\n            this._required ??\n            this.ngControl?.control?.hasValidator(Validators.required) ??\n            false\n        );\n    }\n\n    @Input()\n    public get disabled(): boolean {\n        return this._disabled;\n    }\n\n    public set disabled(value: boolean) {\n        this._disabled = coerceBooleanProperty(value);\n\n        this.handleDisabledState();\n        this.stateChanges.next();\n    }\n\n    @Input()\n    public set placeholder(placeholder: string) {\n        this._placeholder = placeholder;\n        this.stateChanges.next();\n    }\n\n    public get placeholder(): string {\n        return this._placeholder;\n    }\n\n    public set value(value: any) {\n        if (value === this._value) {\n            return;\n        }\n\n        this._value = value;\n        this.propagate(this._value);\n    }\n\n    public get value(): any {\n        return this._value;\n    }\n\n    public get empty(): boolean {\n        const emptyControlValue =\n            !this.currentControl?.value || !this.currentControl.value.length;\n\n        const emptyValue =\n            !this._value ||\n            (typeof this._value === \"string\" && !this._value.length);\n\n        return emptyControlValue && emptyValue;\n    }\n\n    public get errorState(): boolean {\n        return this.ngControl\n            ? this.ngControl.touched && this.ngControl.invalid\n            : false;\n    }\n\n    constructor(\n        private container: ControlContainer,\n        private context: TranslationContextDirective,\n        private service: NiceTranslationFormService,\n        private changeDetectorRef: ChangeDetectorRef\n    ) {}\n\n    @Input()\n    public floating = true;\n\n    @Input()\n    public maxLength = 524288; // The maximum number of characters allowed in the <input> element. Default value is 524288\n\n    @HostBinding()\n    public id: string = uuid.v4();\n\n    @HostBinding(\"attr.aria-describedby\")\n    public describedBy = \"\";\n\n    public formGroup: FormGroup;\n    public currentControl?: FormControl;\n    public stateChanges = new Subject<void>();\n    public ngControl: AbstractControlDirective | NgControl;\n    public focused: boolean;\n    public controlType = \"translationForm\";\n\n    private _unsubscribeAll$ = new Subject<void>();\n    private _required: boolean;\n    private _disabled = false;\n    private _placeholder: string;\n    private _value: any;\n\n    public readonly autofilled: boolean;\n    public readonly userAriaDescribedBy: string;\n\n    public propagate: (value: string) => void = () => {};\n\n    public onContainerClick(event: MouseEvent): void {}\n\n    public setDescribedByIds(ids: string[]): void {\n        this.describedBy = ids.join(\" \");\n    }\n\n    public registerOnChange(fn: any): void {\n        this.propagate = fn;\n    }\n\n    public registerOnTouched(fn: any): void {}\n\n    public writeValue(value: any): void {\n        this._value = value;\n    }\n\n    public ngOnInit(): void {\n        this.formGroup = this.container.control as FormGroup;\n\n        this.service.languages$\n            .pipe(takeUntil(this._unsubscribeAll$))\n            .subscribe((languages) => {\n                if (!languages?.length) {\n                    return;\n                }\n\n                this.setupFormControls(languages);\n            });\n\n        this.context.activeLanguage$\n            .pipe(takeUntil(this._unsubscribeAll$))\n            .subscribe((activeLanguage) => {\n                this.setLanguage(activeLanguage);\n            });\n    }\n\n    public ngOnDestroy(): void {\n        this._unsubscribeAll$.next();\n        this._unsubscribeAll$.complete();\n    }\n\n    public setLanguage(language: string): void {\n        this.currentControl = this.formGroup.get(language) as FormControl;\n        this.handleDisabledState();\n        this.changeDetectorRef.markForCheck();\n    }\n\n    private setupFormControls(languages: string[]): void {\n        for (const language of languages) {\n            if (!this.formGroup.controls[language]) {\n                this.formGroup.addControl(language, new FormControl(), {\n                    emitEvent: false,\n                });\n            }\n        }\n\n        const controlToRemove = Object.keys(this.formGroup.controls).filter(\n            (key) => !languages.includes(key)\n        );\n\n        for (const key of controlToRemove) {\n            this.formGroup.removeControl(key, { emitEvent: false });\n        }\n\n        this.currentControl = this.formGroup.get(languages[0]) as FormControl;\n        this.handleDisabledState();\n    }\n\n    private handleDisabledState(): void {\n        if (this._disabled) {\n            this.currentControl?.disable({ emitEvent: false });\n        } else {\n            this.currentControl?.enable({ emitEvent: false });\n        }\n    }\n}\n"]}
|
|
172
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"translation-form.component.js","sourceRoot":"","sources":["../../../../../../../projects/nice-ui-kit-v2/src/lib/components/translation-form/components/translation-form.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,uBAAuB,CAAC;AAC9D,OAAO,EACH,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,WAAW,EACX,KAAK,GAGR,MAAM,eAAe,CAAC;AACvB,OAAO,EAEH,gBAAgB,EAEhB,WAAW,EAGX,UAAU,GACb,MAAM,gBAAgB,CAAC;AAExB,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC/B,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,KAAK,IAAI,MAAM,MAAM,CAAC;AAC7B,OAAO,EAAE,2BAA2B,EAAE,MAAM,6CAA6C,CAAC;AAC1F,OAAO,EAAE,0BAA0B,EAAE,MAAM,4CAA4C,CAAC;;;;;AAMxF,MAAM,OAAgB,wBAAwB;IAO1C,IACW,SAAS;QAChB,OAAO;YACH,QAAQ,EAAE,IAAI;SACjB,CAAC;IACN,CAAC;IAED,IACW,gBAAgB;QACvB,OAAO,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,KAAK,IAAI,IAAI,CAAC,OAAO,CAAC;IACxD,CAAC;IAED,IACW,QAAQ,CAAC,GAAG;QACnB,IAAI,CAAC,SAAS,GAAG,qBAAqB,CAAC,GAAG,CAAC,CAAC;QAC5C,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;IAC7B,CAAC;IAED,IAAW,QAAQ;QACf,OAAO,CACH,IAAI,CAAC,SAAS;YACd,IAAI,CAAC,SAAS,EAAE,OAAO,EAAE,YAAY,CAAC,UAAU,CAAC,QAAQ,CAAC;YAC1D,KAAK,CACR,CAAC;IACN,CAAC;IAED,IACW,QAAQ;QACf,OAAO,IAAI,CAAC,SAAS,CAAC;IAC1B,CAAC;IAED,IAAW,QAAQ,CAAC,KAAc;QAC9B,IAAI,CAAC,SAAS,GAAG,qBAAqB,CAAC,KAAK,CAAC,CAAC;QAE9C,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAC3B,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;IAC7B,CAAC;IAED,IACW,WAAW,CAAC,WAAmB;QACtC,IAAI,CAAC,YAAY,GAAG,WAAW,CAAC;QAChC,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;IAC7B,CAAC;IAED,IAAW,WAAW;QAClB,OAAO,IAAI,CAAC,YAAY,CAAC;IAC7B,CAAC;IAED,IAAW,KAAK,CAAC,KAAU;QACvB,IAAI,KAAK,KAAK,IAAI,CAAC,MAAM,EAAE;YACvB,OAAO;SACV;QAED,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IAChC,CAAC;IAED,IAAW,KAAK;QACZ,OAAO,IAAI,CAAC,MAAM,CAAC;IACvB,CAAC;IAED,IAAW,KAAK;QACZ,MAAM,iBAAiB,GACnB,CAAC,IAAI,CAAC,cAAc,EAAE,KAAK,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,MAAM,CAAC;QAErE,MAAM,UAAU,GACZ,CAAC,IAAI,CAAC,MAAM;YACZ,CAAC,OAAO,IAAI,CAAC,MAAM,KAAK,QAAQ,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;QAE7D,OAAO,iBAAiB,IAAI,UAAU,CAAC;IAC3C,CAAC;IAED,IAAW,UAAU;QACjB,OAAO,IAAI,CAAC,SAAS;YACjB,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,OAAO,IAAI,IAAI,CAAC,SAAS,CAAC,OAAO;YAClD,CAAC,CAAC,KAAK,CAAC;IAChB,CAAC;IAED,YACY,SAA2B,EAC3B,OAAoC,EACpC,OAAmC,EACnC,iBAAoC;QAHpC,cAAS,GAAT,SAAS,CAAkB;QAC3B,YAAO,GAAP,OAAO,CAA6B;QACpC,YAAO,GAAP,OAAO,CAA4B;QACnC,sBAAiB,GAAjB,iBAAiB,CAAmB;QAIzC,aAAQ,GAAG,IAAI,CAAC;QAGhB,cAAS,GAAG,MAAM,CAAC,CAAC,2FAA2F;QAG/G,OAAE,GAAW,IAAI,CAAC,EAAE,EAAE,CAAC;QAGvB,gBAAW,GAAG,EAAE,CAAC;QAIjB,iBAAY,GAAG,IAAI,OAAO,EAAQ,CAAC;QAGnC,gBAAW,GAAG,iBAAiB,CAAC;QAE/B,qBAAgB,GAAG,IAAI,OAAO,EAAQ,CAAC;QAEvC,cAAS,GAAG,KAAK,CAAC;QAOnB,cAAS,GAA4B,GAAG,EAAE,GAAE,CAAC,CAAC;IA9BlD,CAAC;IAgCG,gBAAgB,CAAC,KAAiB,IAAS,CAAC;IAE5C,iBAAiB,CAAC,GAAa;QAClC,IAAI,CAAC,WAAW,GAAG,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACrC,CAAC;IAEM,gBAAgB,CAAC,EAAO;QAC3B,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACxB,CAAC;IAEM,iBAAiB,CAAC,EAAO,IAAS,CAAC;IAEnC,UAAU,CAAC,KAAU;QACxB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;IACxB,CAAC;IAEM,QAAQ;QACX,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,OAAoB,CAAC;QAErD,IAAI,CAAC,OAAO,CAAC,UAAU;aAClB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;aACtC,SAAS,CAAC,CAAC,SAAS,EAAE,EAAE;YACrB,IAAI,CAAC,SAAS,EAAE,MAAM,EAAE;gBACpB,OAAO;aACV;YAED,IAAI,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAC;QACtC,CAAC,CAAC,CAAC;QAEP,IAAI,CAAC,OAAO,CAAC,eAAe;aACvB,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;aACtC,SAAS,CAAC,CAAC,cAAc,EAAE,EAAE;YAC1B,IAAI,CAAC,WAAW,CAAC,cAAc,CAAC,CAAC;QACrC,CAAC,CAAC,CAAC;IACX,CAAC;IAEM,WAAW;QACd,IAAI,CAAC,gBAAgB,CAAC,IAAI,EAAE,CAAC;QAC7B,IAAI,CAAC,gBAAgB,CAAC,QAAQ,EAAE,CAAC;IACrC,CAAC;IAEM,WAAW,CAAC,QAAgB;QAC/B,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAgB,CAAC;QAClE,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAC3B,IAAI,CAAC,iBAAiB,CAAC,YAAY,EAAE,CAAC;IAC1C,CAAC;IAEO,iBAAiB,CAAC,SAAmB;QACzC,KAAK,MAAM,QAAQ,IAAI,SAAS,EAAE;YAC9B,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC,EAAE;gBACpC,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,QAAQ,EAAE,IAAI,WAAW,EAAE,EAAE;oBACnD,SAAS,EAAE,KAAK;iBACnB,CAAC,CAAC;aACN;SACJ;QAED,MAAM,eAAe,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,MAAM,CAC/D,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,SAAS,CAAC,QAAQ,CAAC,GAAG,CAAC,CACpC,CAAC;QAEF,KAAK,MAAM,GAAG,IAAI,eAAe,EAAE;YAC/B,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,GAAG,EAAE,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;SAC3D;QAED,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,CAAC,CAAgB,CAAC;QACtE,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC/B,CAAC;IAEO,mBAAmB;QACvB,IAAI,IAAI,CAAC,SAAS,EAAE;YAChB,IAAI,CAAC,cAAc,EAAE,OAAO,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;SACtD;aAAM;YACH,IAAI,CAAC,cAAc,EAAE,MAAM,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,CAAC,CAAC;SACrD;IACL,CAAC;8GApMiB,wBAAwB;kGAAxB,wBAAwB,oVAHhC,EAAE;;2FAGM,wBAAwB;kBAJ7C,SAAS;mBAAC;oBACP,QAAQ,EAAE,EAAE;oBACZ,eAAe,EAAE,uBAAuB,CAAC,MAAM;iBAClD;0NASc,SAAS;sBADnB,WAAW;uBAAC,OAAO;gBAQT,gBAAgB;sBAD1B,WAAW;uBAAC,gBAAgB;gBAMlB,QAAQ;sBADlB,KAAK;gBAeK,QAAQ;sBADlB,KAAK;gBAaK,WAAW;sBADrB,KAAK;gBAgDC,QAAQ;sBADd,KAAK;gBAIC,SAAS;sBADf,KAAK;gBAIC,EAAE;sBADR,WAAW;gBAIL,WAAW;sBADjB,WAAW;uBAAC,uBAAuB","sourcesContent":["import { coerceBooleanProperty } from \"@angular/cdk/coercion\";\nimport {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    HostBinding,\n    Input,\n    OnDestroy,\n    OnInit,\n} from \"@angular/core\";\nimport {\n    AbstractControlDirective,\n    ControlContainer,\n    ControlValueAccessor,\n    FormControl,\n    FormGroup,\n    NgControl,\n    Validators,\n} from \"@angular/forms\";\nimport { MatFormFieldControl } from \"@angular/material/form-field\";\nimport { Subject } from \"rxjs\";\nimport { takeUntil } from \"rxjs/operators\";\nimport * as uuid from \"uuid\";\nimport { TranslationContextDirective } from \"../directives/translation-context.directive\";\nimport { NiceTranslationFormService } from \"../providers/nice-translation-form.service\";\n\n@Component({\n    template: ``,\n    changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport abstract class TranslationFormComponent\n    implements\n        OnInit,\n        OnDestroy,\n        MatFormFieldControl<string>,\n        ControlValueAccessor\n{\n    @HostBinding(\"class\")\n    public get classList(): any {\n        return {\n            \"w-full\": true\n        };\n    }\n\n    @HostBinding(\"class.floating\")\n    public get shouldLabelFloat(): boolean {\n        return this.floating || !this.empty || this.focused;\n    }\n\n    @Input()\n    public set required(req) {\n        this._required = coerceBooleanProperty(req);\n        this.stateChanges.next();\n    }\n\n    public get required(): boolean {\n        return (\n            this._required ??\n            this.ngControl?.control?.hasValidator(Validators.required) ??\n            false\n        );\n    }\n\n    @Input()\n    public get disabled(): boolean {\n        return this._disabled;\n    }\n\n    public set disabled(value: boolean) {\n        this._disabled = coerceBooleanProperty(value);\n\n        this.handleDisabledState();\n        this.stateChanges.next();\n    }\n\n    @Input()\n    public set placeholder(placeholder: string) {\n        this._placeholder = placeholder;\n        this.stateChanges.next();\n    }\n\n    public get placeholder(): string {\n        return this._placeholder;\n    }\n\n    public set value(value: any) {\n        if (value === this._value) {\n            return;\n        }\n\n        this._value = value;\n        this.propagate(this._value);\n    }\n\n    public get value(): any {\n        return this._value;\n    }\n\n    public get empty(): boolean {\n        const emptyControlValue =\n            !this.currentControl?.value || !this.currentControl.value.length;\n\n        const emptyValue =\n            !this._value ||\n            (typeof this._value === \"string\" && !this._value.length);\n\n        return emptyControlValue && emptyValue;\n    }\n\n    public get errorState(): boolean {\n        return this.ngControl\n            ? this.ngControl.touched && this.ngControl.invalid\n            : false;\n    }\n\n    constructor(\n        private container: ControlContainer,\n        private context: TranslationContextDirective,\n        private service: NiceTranslationFormService,\n        private changeDetectorRef: ChangeDetectorRef\n    ) {}\n\n    @Input()\n    public floating = true;\n\n    @Input()\n    public maxLength = 524288; // The maximum number of characters allowed in the <input> element. Default value is 524288\n\n    @HostBinding()\n    public id: string = uuid.v4();\n\n    @HostBinding(\"attr.aria-describedby\")\n    public describedBy = \"\";\n\n    public formGroup: FormGroup;\n    public currentControl?: FormControl;\n    public stateChanges = new Subject<void>();\n    public ngControl: AbstractControlDirective | NgControl;\n    public focused: boolean;\n    public controlType = \"translationForm\";\n\n    private _unsubscribeAll$ = new Subject<void>();\n    private _required: boolean;\n    private _disabled = false;\n    private _placeholder: string;\n    private _value: any;\n\n    public readonly autofilled: boolean;\n    public readonly userAriaDescribedBy: string;\n\n    public propagate: (value: string) => void = () => {};\n\n    public onContainerClick(event: MouseEvent): void {}\n\n    public setDescribedByIds(ids: string[]): void {\n        this.describedBy = ids.join(\" \");\n    }\n\n    public registerOnChange(fn: any): void {\n        this.propagate = fn;\n    }\n\n    public registerOnTouched(fn: any): void {}\n\n    public writeValue(value: any): void {\n        this._value = value;\n    }\n\n    public ngOnInit(): void {\n        this.formGroup = this.container.control as FormGroup;\n\n        this.service.languages$\n            .pipe(takeUntil(this._unsubscribeAll$))\n            .subscribe((languages) => {\n                if (!languages?.length) {\n                    return;\n                }\n\n                this.setupFormControls(languages);\n            });\n\n        this.context.activeLanguage$\n            .pipe(takeUntil(this._unsubscribeAll$))\n            .subscribe((activeLanguage) => {\n                this.setLanguage(activeLanguage);\n            });\n    }\n\n    public ngOnDestroy(): void {\n        this._unsubscribeAll$.next();\n        this._unsubscribeAll$.complete();\n    }\n\n    public setLanguage(language: string): void {\n        this.currentControl = this.formGroup.get(language) as FormControl;\n        this.handleDisabledState();\n        this.changeDetectorRef.markForCheck();\n    }\n\n    private setupFormControls(languages: string[]): void {\n        for (const language of languages) {\n            if (!this.formGroup.controls[language]) {\n                this.formGroup.addControl(language, new FormControl(), {\n                    emitEvent: false,\n                });\n            }\n        }\n\n        const controlToRemove = Object.keys(this.formGroup.controls).filter(\n            (key) => !languages.includes(key)\n        );\n\n        for (const key of controlToRemove) {\n            this.formGroup.removeControl(key, { emitEvent: false });\n        }\n\n        this.currentControl = this.formGroup.get(languages[0]) as FormControl;\n        this.handleDisabledState();\n    }\n\n    private handleDisabledState(): void {\n        if (this._disabled) {\n            this.currentControl?.disable({ emitEvent: false });\n        } else {\n            this.currentControl?.enable({ emitEvent: false });\n        }\n    }\n}\n"]}
|
|
@@ -35,6 +35,19 @@ export class FileUtils {
|
|
|
35
35
|
window.URL.revokeObjectURL(dataUrl);
|
|
36
36
|
document.body.removeChild(downloadLink);
|
|
37
37
|
}
|
|
38
|
+
static openFile(file, options = { openInNewTab: true }) {
|
|
39
|
+
const anchor = document.createElement("a");
|
|
40
|
+
document.body.appendChild(anchor);
|
|
41
|
+
anchor.style.display = "none";
|
|
42
|
+
const dataUrl = window.URL.createObjectURL(file);
|
|
43
|
+
anchor.href = dataUrl;
|
|
44
|
+
if (options.openInNewTab) {
|
|
45
|
+
anchor.target = "_blank";
|
|
46
|
+
}
|
|
47
|
+
anchor.click();
|
|
48
|
+
window.URL.revokeObjectURL(dataUrl);
|
|
49
|
+
document.body.removeChild(anchor);
|
|
50
|
+
}
|
|
38
51
|
static downloadUrl(url) {
|
|
39
52
|
const downloadLink = document.createElement("a");
|
|
40
53
|
document.body.appendChild(downloadLink);
|
|
@@ -74,4 +87,4 @@ export class FileUtils {
|
|
|
74
87
|
});
|
|
75
88
|
}
|
|
76
89
|
}
|
|
77
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
90
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file.utils.js","sourceRoot":"","sources":["../../../../../projects/nice-ui-kit-v2/src/lib/utils/file.utils.ts"],"names":[],"mappings":"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","sourcesContent":["export class FileUtils {\n    public static async getFileFromUrl(url?: string, name = \"\"): Promise<File | undefined> {\n        if (!url) {\n            return undefined;\n        }\n        const res = await fetch(url);\n        return new File([await res.blob()], name);\n    }\n\n    public static async selectFile(accept: string, multiple = false): Promise<File | File[]> {\n        return new Promise(resolve => {\n            const input = document.createElement(\"input\");\n            input.type = \"file\";\n            input.multiple = multiple;\n            input.accept = accept;\n\n            input.onchange = () => {\n                if (input.files) {\n                    const files = Array.from(input.files);\n                    return resolve(multiple ? files : files[0]);\n                }\n\n                resolve(null);\n            };\n\n            input.click();\n        });\n    }\n\n    public static downloadFile(fileName: string, content: Blob, downloadLink?: HTMLAnchorElement): void {\n        if (!downloadLink) {\n            downloadLink = document.createElement(\"a\");\n            document.body.appendChild(downloadLink);\n            downloadLink.style.display = \"none\";\n        }\n\n        const dataUrl = window.URL.createObjectURL(content);\n        downloadLink.href = dataUrl;\n        downloadLink.download = fileName;\n        downloadLink.click();\n        window.URL.revokeObjectURL(dataUrl);\n        document.body.removeChild(downloadLink);\n    }\n\n    public static openFile(file: Blob, options: { openInNewTab: boolean } = { openInNewTab: true }): void {\n        const anchor = document.createElement(\"a\");\n        document.body.appendChild(anchor);\n        anchor.style.display = \"none\";\n\n        const dataUrl = window.URL.createObjectURL(file);\n        anchor.href = dataUrl;\n        if (options.openInNewTab) {\n            anchor.target = \"_blank\";\n        }\n        anchor.click();\n        window.URL.revokeObjectURL(dataUrl);\n        document.body.removeChild(anchor);\n    }\n\n    public static downloadUrl(url: string): void {\n        const downloadLink = document.createElement(\"a\");\n        document.body.appendChild(downloadLink);\n        downloadLink.style.display = \"none\";\n        downloadLink.href = url;\n        downloadLink.click();\n        document.body.removeChild(downloadLink);\n    }\n\n    public static openPrintableWindow(content: string): void {\n        const win = window.open(\"\");\n        if (!win) {\n            return;\n        }\n\n        win.document.open();\n        win.document.write(content);\n        win.document.close();\n    }\n\n    public static filenameToExtension(filename: string): string {\n        const re = /(?:\\.([^.]+))?$/;\n        return re.exec(filename)[1];\n    }\n\n    public static getDataUrl(file: File): Promise<string> {\n        return new Promise((resolve, reject) => {\n            const reader = new FileReader();\n            reader.readAsDataURL(file);\n            reader.onload = () => resolve(reader.result as string);\n            reader.onerror = error => reject(error);\n        });\n    }\n\n    public static async getFileFromDataUrl(data: string, name: string): Promise<File> {\n        const base64Response = await fetch(data);\n        const blob = await base64Response.blob();\n        const [, type] = blob.type.split(\"/\");\n        return new File([blob], `${name}.${type}`, {\n            lastModified: Date.now(),\n            type: blob.type\n        });\n    }\n}\n"]}
|
|
@@ -1298,6 +1298,19 @@ class FileUtils {
|
|
|
1298
1298
|
window.URL.revokeObjectURL(dataUrl);
|
|
1299
1299
|
document.body.removeChild(downloadLink);
|
|
1300
1300
|
}
|
|
1301
|
+
static openFile(file, options = { openInNewTab: true }) {
|
|
1302
|
+
const anchor = document.createElement("a");
|
|
1303
|
+
document.body.appendChild(anchor);
|
|
1304
|
+
anchor.style.display = "none";
|
|
1305
|
+
const dataUrl = window.URL.createObjectURL(file);
|
|
1306
|
+
anchor.href = dataUrl;
|
|
1307
|
+
if (options.openInNewTab) {
|
|
1308
|
+
anchor.target = "_blank";
|
|
1309
|
+
}
|
|
1310
|
+
anchor.click();
|
|
1311
|
+
window.URL.revokeObjectURL(dataUrl);
|
|
1312
|
+
document.body.removeChild(anchor);
|
|
1313
|
+
}
|
|
1301
1314
|
static downloadUrl(url) {
|
|
1302
1315
|
const downloadLink = document.createElement("a");
|
|
1303
1316
|
document.body.appendChild(downloadLink);
|
|
@@ -5421,6 +5434,64 @@ class NiceControlStatusDirective {
|
|
|
5421
5434
|
this.formField = formField;
|
|
5422
5435
|
this.translateService = translateService;
|
|
5423
5436
|
this.unsubscribeAll$ = new Subject();
|
|
5437
|
+
this.onChange = () => {
|
|
5438
|
+
if (this.control.pending) {
|
|
5439
|
+
return;
|
|
5440
|
+
}
|
|
5441
|
+
if (this.control.invalid && this.control.touched) {
|
|
5442
|
+
for (const error in this.control.errors) {
|
|
5443
|
+
if (this.control.errors.hasOwnProperty(error)) {
|
|
5444
|
+
if (this.control.errors[error]) {
|
|
5445
|
+
let lastErrorKey = error;
|
|
5446
|
+
let param;
|
|
5447
|
+
if (error === "pattern") {
|
|
5448
|
+
lastErrorKey = this.control.errors[error].requiredPattern;
|
|
5449
|
+
}
|
|
5450
|
+
if (error === "mask") {
|
|
5451
|
+
lastErrorKey = this.control.errors[error].requiredMask;
|
|
5452
|
+
}
|
|
5453
|
+
if (error === "minlength" || error === "maxlength") {
|
|
5454
|
+
param = {
|
|
5455
|
+
value: this.control.errors[error].requiredLength
|
|
5456
|
+
};
|
|
5457
|
+
}
|
|
5458
|
+
if (error === "min") {
|
|
5459
|
+
param = {
|
|
5460
|
+
min: this.control.errors[error].min,
|
|
5461
|
+
actual: this.control.errors[error].actual
|
|
5462
|
+
};
|
|
5463
|
+
}
|
|
5464
|
+
if (error === "max") {
|
|
5465
|
+
param = {
|
|
5466
|
+
max: this.control.errors[error].max,
|
|
5467
|
+
actual: this.control.errors[error].actual
|
|
5468
|
+
};
|
|
5469
|
+
}
|
|
5470
|
+
if (error === "arrayMinLength") {
|
|
5471
|
+
param = {
|
|
5472
|
+
min: this.control.errors[error].min,
|
|
5473
|
+
actual: this.control.errors[error].actual
|
|
5474
|
+
};
|
|
5475
|
+
}
|
|
5476
|
+
if (error === "arrayMaxLength") {
|
|
5477
|
+
param = {
|
|
5478
|
+
max: this.control.errors[error].max,
|
|
5479
|
+
actual: this.control.errors[error].actual
|
|
5480
|
+
};
|
|
5481
|
+
}
|
|
5482
|
+
if (typeof this.control.errors[error] === "object" && !param) {
|
|
5483
|
+
param = this.control.errors[error];
|
|
5484
|
+
}
|
|
5485
|
+
this.setError(this.translateService.instant(`errors.${lastErrorKey}`, param));
|
|
5486
|
+
break;
|
|
5487
|
+
}
|
|
5488
|
+
}
|
|
5489
|
+
}
|
|
5490
|
+
}
|
|
5491
|
+
else {
|
|
5492
|
+
this.setError("");
|
|
5493
|
+
}
|
|
5494
|
+
};
|
|
5424
5495
|
}
|
|
5425
5496
|
ngAfterViewInit() {
|
|
5426
5497
|
this.control = this.formField._control.ngControl;
|
|
@@ -5432,64 +5503,6 @@ class NiceControlStatusDirective {
|
|
|
5432
5503
|
this.unsubscribeAll$.next();
|
|
5433
5504
|
this.unsubscribeAll$.complete();
|
|
5434
5505
|
}
|
|
5435
|
-
onChange() {
|
|
5436
|
-
if (this.control.pending) {
|
|
5437
|
-
return;
|
|
5438
|
-
}
|
|
5439
|
-
if (this.control.invalid && this.control.touched) {
|
|
5440
|
-
for (const error in this.control.errors) {
|
|
5441
|
-
if (this.control.errors.hasOwnProperty(error)) {
|
|
5442
|
-
if (this.control.errors[error]) {
|
|
5443
|
-
let lastErrorKey = error;
|
|
5444
|
-
let param;
|
|
5445
|
-
if (error === "pattern") {
|
|
5446
|
-
lastErrorKey = this.control.errors[error].requiredPattern;
|
|
5447
|
-
}
|
|
5448
|
-
if (error === "mask") {
|
|
5449
|
-
lastErrorKey = this.control.errors[error].requiredMask;
|
|
5450
|
-
}
|
|
5451
|
-
if (error === "minlength" || error === "maxlength") {
|
|
5452
|
-
param = {
|
|
5453
|
-
value: this.control.errors[error].requiredLength
|
|
5454
|
-
};
|
|
5455
|
-
}
|
|
5456
|
-
if (error === "min") {
|
|
5457
|
-
param = {
|
|
5458
|
-
min: this.control.errors[error].min,
|
|
5459
|
-
actual: this.control.errors[error].actual
|
|
5460
|
-
};
|
|
5461
|
-
}
|
|
5462
|
-
if (error === "max") {
|
|
5463
|
-
param = {
|
|
5464
|
-
max: this.control.errors[error].max,
|
|
5465
|
-
actual: this.control.errors[error].actual
|
|
5466
|
-
};
|
|
5467
|
-
}
|
|
5468
|
-
if (error === "arrayMinLength") {
|
|
5469
|
-
param = {
|
|
5470
|
-
min: this.control.errors[error].min,
|
|
5471
|
-
actual: this.control.errors[error].actual
|
|
5472
|
-
};
|
|
5473
|
-
}
|
|
5474
|
-
if (error === "arrayMaxLength") {
|
|
5475
|
-
param = {
|
|
5476
|
-
max: this.control.errors[error].max,
|
|
5477
|
-
actual: this.control.errors[error].actual
|
|
5478
|
-
};
|
|
5479
|
-
}
|
|
5480
|
-
if (typeof this.control.errors[error] === "object" && !param) {
|
|
5481
|
-
param = this.control.errors[error];
|
|
5482
|
-
}
|
|
5483
|
-
this.setError(this.translateService.instant(`errors.${lastErrorKey}`, param));
|
|
5484
|
-
break;
|
|
5485
|
-
}
|
|
5486
|
-
}
|
|
5487
|
-
}
|
|
5488
|
-
}
|
|
5489
|
-
else {
|
|
5490
|
-
this.setError("");
|
|
5491
|
-
}
|
|
5492
|
-
}
|
|
5493
5506
|
setError(text) {
|
|
5494
5507
|
if (!this.ref) {
|
|
5495
5508
|
this.ref = this.vcr.createComponent(NiceFormErrorComponent);
|
|
@@ -10680,7 +10693,7 @@ class TranslationFormComponent {
|
|
|
10680
10693
|
};
|
|
10681
10694
|
}
|
|
10682
10695
|
get shouldLabelFloat() {
|
|
10683
|
-
return this.floating || !this.empty;
|
|
10696
|
+
return this.floating || !this.empty || this.focused;
|
|
10684
10697
|
}
|
|
10685
10698
|
set required(req) {
|
|
10686
10699
|
this._required = coerceBooleanProperty(req);
|