@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.
@@ -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":"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;IAMnC,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;QANtC,oBAAe,GAAG,IAAI,OAAO,EAAQ,CAAC;IAO3C,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;QACX,IAAI,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE;YACtB,OAAO;SACV;QAED,IAAI,IAAI,CAAC,OAAO,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE;YAC9C,KAAK,MAAM,KAAK,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE;gBACrC,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,cAAc,CAAC,KAAK,CAAC,EAAE;oBAC3C,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE;wBAC5B,IAAI,YAAY,GAAG,KAAK,CAAC;wBACzB,IAAI,KAAU,CAAC;wBACf,IAAI,KAAK,KAAK,SAAS,EAAE;4BACrB,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,eAAe,CAAC;yBAC7D;wBACD,IAAI,KAAK,KAAK,MAAM,EAAE;4BAClB,YAAY,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,YAAY,CAAC;yBAC1D;wBACD,IAAI,KAAK,KAAK,WAAW,IAAI,KAAK,KAAK,WAAW,EAAE;4BAChD,KAAK,GAAG;gCACJ,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,cAAc;6BACnD,CAAC;yBACL;wBACD,IAAI,KAAK,KAAK,KAAK,EAAE;4BACjB,KAAK,GAAG;gCACJ,GAAG,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,GAAG;gCACnC,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,MAAM;6BAC5C,CAAC;yBACL;wBACD,IAAI,KAAK,KAAK,KAAK,EAAE;4BACjB,KAAK,GAAG;gCACJ,GAAG,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,GAAG;gCACnC,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,MAAM;6BAC5C,CAAC;yBACL;wBACD,IAAI,KAAK,KAAK,gBAAgB,EAAE;4BAC5B,KAAK,GAAG;gCACJ,GAAG,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,GAAG;gCACnC,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,MAAM;6BAC5C,CAAC;yBACL;wBACD,IAAI,KAAK,KAAK,gBAAgB,EAAE;4BAC5B,KAAK,GAAG;gCACJ,GAAG,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,GAAG;gCACnC,MAAM,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,MAAM;6BAC5C,CAAC;yBACL;wBAED,IAAI,OAAO,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,KAAK,QAAQ,IAAI,CAAC,KAAK,EAAE;4BAC1D,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;yBACtC;wBAED,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,UAAU,YAAY,EAAE,EAAE,KAAK,CAAC,CAAC,CAAC;wBAC9E,MAAM;qBACT;iBACJ;aACJ;SACJ;aAAM;YACH,IAAI,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;SACrB;IACL,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    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":"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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    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":"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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 || 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,{"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 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"]}
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);