@esfaenza/forms-and-validations 15.2.57 → 16.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (80) hide show
  1. package/{esm2020 → esm2022}/lib/forms/base-form-control.mjs +6 -4
  2. package/{esm2020 → esm2022}/lib/forms/form-adaptive/form-adaptive.component.loc.mjs +4 -4
  3. package/{esm2020 → esm2022}/lib/forms/form-adaptive/form-adaptive.component.mjs +4 -4
  4. package/{esm2020 → esm2022}/lib/forms/form-autocomplete/form-autocomplete.component.loc.mjs +4 -4
  5. package/{esm2020 → esm2022}/lib/forms/form-autocomplete/form-autocomplete.component.mjs +4 -4
  6. package/{esm2020 → esm2022}/lib/forms/form-checkbox/form-checkbox.component.mjs +4 -4
  7. package/{esm2020 → esm2022}/lib/forms/form-date/form-date.component.mjs +4 -4
  8. package/{esm2020 → esm2022}/lib/forms/form-datetime/form-datetime.component.mjs +4 -4
  9. package/{esm2020 → esm2022}/lib/forms/form-empty/form-empty.component.mjs +4 -4
  10. package/{esm2020 → esm2022}/lib/forms/form-error/form-error.component.mjs +4 -4
  11. package/{esm2020 → esm2022}/lib/forms/form-file/form-file.component.loc.mjs +4 -4
  12. package/{esm2020 → esm2022}/lib/forms/form-file/form-file.component.mjs +4 -4
  13. package/{esm2020 → esm2022}/lib/forms/form-info/form-info.component.mjs +4 -4
  14. package/{esm2020 → esm2022}/lib/forms/form-input/form-input.component.mjs +5 -5
  15. package/{esm2020 → esm2022}/lib/forms/form-multiselect/form-multiselect.component.loc.mjs +4 -4
  16. package/{esm2020 → esm2022}/lib/forms/form-multiselect/form-multiselect.component.mjs +4 -4
  17. package/{esm2020 → esm2022}/lib/forms/form-select/form-select.component.loc.mjs +4 -4
  18. package/{esm2020 → esm2022}/lib/forms/form-select/form-select.component.mjs +4 -4
  19. package/{esm2020 → esm2022}/lib/forms/form-template/form-template.component.mjs +4 -4
  20. package/{esm2020 → esm2022}/lib/forms/form-textarea/form-textarea.component.mjs +4 -4
  21. package/{esm2020 → esm2022}/lib/forms/form-time/form-time.component.mjs +4 -4
  22. package/{esm2020 → esm2022}/lib/forms-and-validations.module.mjs +64 -64
  23. package/{esm2020 → esm2022}/lib/models/dayjs-adapter/dayjs-date-adapter.mjs +4 -4
  24. package/{esm2020 → esm2022}/lib/validations/base-validation.loc.mjs +4 -4
  25. package/{esm2020 → esm2022}/lib/validations/base-validation.mjs +4 -4
  26. package/{esm2020 → esm2022}/lib/validations/customValidators/CustomRequiredDirective.mjs +4 -4
  27. package/esm2022/lib/validations/validation-autocomplete/validation-autocomplete.component.mjs +147 -0
  28. package/esm2022/lib/validations/validation-autocomplete-multi/validation-autocomplete-multi.component.mjs +240 -0
  29. package/esm2022/lib/validations/validation-currency/validation-currency.component.mjs +75 -0
  30. package/esm2022/lib/validations/validation-date/validation-date.component.mjs +183 -0
  31. package/esm2022/lib/validations/validation-datetime/validation-datetime.component.mjs +212 -0
  32. package/esm2022/lib/validations/validation-input/validation-input.component.mjs +218 -0
  33. package/esm2022/lib/validations/validation-select/validation-select.component.mjs +183 -0
  34. package/esm2022/lib/validations/validation-text-area/validation-text-area.component.mjs +78 -0
  35. package/{fesm2020 → fesm2022}/esfaenza-forms-and-validations.mjs +227 -223
  36. package/fesm2022/esfaenza-forms-and-validations.mjs.map +1 -0
  37. package/lib/forms/base-form-control.d.ts +3 -1
  38. package/lib/forms/form-adaptive/form-adaptive.component.d.ts +1 -1
  39. package/lib/forms/form-autocomplete/form-autocomplete.component.d.ts +1 -1
  40. package/lib/forms/form-checkbox/form-checkbox.component.d.ts +1 -1
  41. package/lib/forms/form-date/form-date.component.d.ts +1 -1
  42. package/lib/forms/form-datetime/form-datetime.component.d.ts +1 -1
  43. package/lib/forms/form-empty/form-empty.component.d.ts +1 -1
  44. package/lib/forms/form-error/form-error.component.d.ts +1 -1
  45. package/lib/forms/form-file/form-file.component.d.ts +1 -1
  46. package/lib/forms/form-info/form-info.component.d.ts +1 -1
  47. package/lib/forms/form-input/form-input.component.d.ts +1 -1
  48. package/lib/forms/form-multiselect/form-multiselect.component.d.ts +1 -1
  49. package/lib/forms/form-select/form-select.component.d.ts +1 -1
  50. package/lib/forms/form-template/form-template.component.d.ts +1 -1
  51. package/lib/forms/form-textarea/form-textarea.component.d.ts +1 -1
  52. package/lib/forms/form-time/form-time.component.d.ts +1 -1
  53. package/lib/validations/base-validation.d.ts +1 -1
  54. package/lib/validations/customValidators/CustomRequiredDirective.d.ts +1 -1
  55. package/lib/validations/validation-autocomplete/validation-autocomplete.component.d.ts +1 -1
  56. package/lib/validations/validation-autocomplete-multi/validation-autocomplete-multi.component.d.ts +1 -1
  57. package/lib/validations/validation-currency/validation-currency.component.d.ts +1 -1
  58. package/lib/validations/validation-date/validation-date.component.d.ts +1 -1
  59. package/lib/validations/validation-datetime/validation-datetime.component.d.ts +1 -1
  60. package/lib/validations/validation-input/validation-input.component.d.ts +2 -2
  61. package/lib/validations/validation-select/validation-select.component.d.ts +1 -1
  62. package/lib/validations/validation-text-area/validation-text-area.component.d.ts +1 -1
  63. package/package.json +20 -26
  64. package/esm2020/lib/validations/validation-autocomplete/validation-autocomplete.component.mjs +0 -147
  65. package/esm2020/lib/validations/validation-autocomplete-multi/validation-autocomplete-multi.component.mjs +0 -240
  66. package/esm2020/lib/validations/validation-currency/validation-currency.component.mjs +0 -75
  67. package/esm2020/lib/validations/validation-date/validation-date.component.mjs +0 -183
  68. package/esm2020/lib/validations/validation-datetime/validation-datetime.component.mjs +0 -212
  69. package/esm2020/lib/validations/validation-input/validation-input.component.mjs +0 -216
  70. package/esm2020/lib/validations/validation-select/validation-select.component.mjs +0 -183
  71. package/esm2020/lib/validations/validation-text-area/validation-text-area.component.mjs +0 -78
  72. package/fesm2015/esfaenza-forms-and-validations.mjs +0 -4310
  73. package/fesm2015/esfaenza-forms-and-validations.mjs.map +0 -1
  74. package/fesm2020/esfaenza-forms-and-validations.mjs.map +0 -1
  75. /package/{esm2020 → esm2022}/esfaenza-forms-and-validations.mjs +0 -0
  76. /package/{esm2020 → esm2022}/lib/models/AppFile.mjs +0 -0
  77. /package/{esm2020 → esm2022}/lib/models/ChangeEvent.mjs +0 -0
  78. /package/{esm2020 → esm2022}/lib/models/FormsAndValidationsModuleConfig.mjs +0 -0
  79. /package/{esm2020 → esm2022}/lib/tokens.mjs +0 -0
  80. /package/{esm2020 → esm2022}/public-api.mjs +0 -0
@@ -0,0 +1,183 @@
1
+ // Angular
2
+ import { NG_ASYNC_VALIDATORS, NG_VALIDATORS, NG_VALUE_ACCESSOR, NgControl } from "@angular/forms";
3
+ import { ChangeDetectionStrategy, Component, forwardRef, Inject, Input, Optional, ViewEncapsulation } from "@angular/core";
4
+ // Configurazioni
5
+ import { LocalizationService } from "@esfaenza/localizations";
6
+ // Direttive, Componenti, Librerie
7
+ import { BaseValidation } from "../base-validation";
8
+ import { BaseValidationLoc } from "../base-validation.loc";
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "@esfaenza/localizations";
11
+ import * as i2 from "@esfaenza/extensions";
12
+ import * as i3 from "@angular/common";
13
+ import * as i4 from "@angular/forms";
14
+ import * as i5 from "@angular/material/legacy-form-field";
15
+ import * as i6 from "@angular/material/legacy-input";
16
+ import * as i7 from "@angular/material/datepicker";
17
+ import * as i8 from "ngx-bootstrap/tooltip";
18
+ /**
19
+ * Componente di validaizone per gli input di tipo data
20
+ */
21
+ export class ValidationDateComponent extends BaseValidation {
22
+ /**
23
+ * @ignore
24
+ */
25
+ constructor(cdr, _validators, _asyncValidators, injector, lc, dateExts) {
26
+ super(cdr);
27
+ this._validators = _validators;
28
+ this._asyncValidators = _asyncValidators;
29
+ this.injector = injector;
30
+ this.lc = lc;
31
+ this.dateExts = dateExts;
32
+ /**
33
+ * Utilizza il Date di Javascript come modello in uscita. Il modello in entrata verrà comunque ricondotto a un DayJs
34
+ */
35
+ this.useJsDates = false;
36
+ /**
37
+ * @ignore
38
+ */
39
+ this.onTouched = () => { };
40
+ }
41
+ /**
42
+ * @ignore
43
+ */
44
+ ngOnInit() {
45
+ super.ngOnInit();
46
+ this.registerFocusRequest();
47
+ this.checkRequiredness(this._validators);
48
+ this._format = this.lc.token("getSmallDateDisplayFormat");
49
+ }
50
+ /**
51
+ * @ignore
52
+ */
53
+ ngOnDestroy() {
54
+ super.ngOnDestroy();
55
+ this.deregisterFocusRequest();
56
+ }
57
+ /**
58
+ * @ignore
59
+ */
60
+ ngAfterViewInit() {
61
+ this.postBinding();
62
+ }
63
+ /**
64
+ * Metodo che si occupa di collegare i validatori e la funzione di reset dal **ControlValueAccessor** rappresentato
65
+ * da questo componente al **ControlValueAccessor** rappresentato dall'effettivo elemento di Input presente lato HTML
66
+ */
67
+ postBinding() {
68
+ this.CheckValidity();
69
+ const ngControl = this.injector.get(NgControl, null);
70
+ if (ngControl) {
71
+ this.parentControl = ngControl.control;
72
+ if (this.noValidate) {
73
+ this.parentControl.clearValidators();
74
+ this.parentControl.clearAsyncValidators();
75
+ }
76
+ else {
77
+ this.baseInput.control.setAsyncValidators(this._asyncValidators);
78
+ this.baseInput.control.setValidators(this._validators);
79
+ }
80
+ // //faccio in modo che se chiamo il reset del controllo (o della form) dall'esterno si resetti anche il controllo nativo
81
+ //faccio in modo che se chiamo il reset del controllo (o della form) dall'esterno si resetti anche il controllo nativo
82
+ const origFunc = this.parentControl.reset;
83
+ this.parentControl.reset = () => {
84
+ origFunc.apply(this.parentControl);
85
+ this.baseInput.control.reset();
86
+ this.tooltip.hide();
87
+ };
88
+ }
89
+ }
90
+ /**
91
+ * @ignore
92
+ */
93
+ writeValue(value) {
94
+ if (!value) {
95
+ this.value = null;
96
+ if (this.baseInput)
97
+ this.baseInput.reset();
98
+ }
99
+ else {
100
+ var date = null;
101
+ if (this.useJsDates) {
102
+ date = this.dateExts.getDateConvertion(value);
103
+ if (date) {
104
+ this.propagateChange(date.toDate());
105
+ this.inputChange.emit(date.toDate());
106
+ }
107
+ }
108
+ else
109
+ date = dayjs(value, this.lc.token("getSmallDateFormat"));
110
+ this.value = date;
111
+ }
112
+ this.cdr.markForCheck();
113
+ }
114
+ /**
115
+ * Metodo che si occupa di, eventualmente, aggiustare il valore da propagare ed emetterlo
116
+ *
117
+ * L'emit della modifica al valore viene gestito su un evento custom (**inputChange**) come workaround al malfunzionamento dell'**ngModelChange** nativo
118
+ *
119
+ * @param {any} toEmit valore da propagare all'esterno
120
+ */
121
+ outputValue(toEmit) {
122
+ let value = toEmit.value;
123
+ let propagateValue;
124
+ if (!value)
125
+ propagateValue = null;
126
+ else if (!this.useJsDates)
127
+ propagateValue = value.format(this.lc.token("getSmallDateFormat"));
128
+ else {
129
+ if (value && value.isValid())
130
+ propagateValue = value.hour(0).minute(0).second(0).toDate();
131
+ else
132
+ propagateValue = null;
133
+ }
134
+ this.propagateChange(propagateValue);
135
+ this.inputChange.emit(propagateValue);
136
+ this.onTouched();
137
+ }
138
+ /**
139
+ * @ignore
140
+ */
141
+ registerOnChange(fn) {
142
+ this.propagateChange = fn;
143
+ }
144
+ /**
145
+ * @ignore
146
+ */
147
+ registerOnTouched(fn) {
148
+ this.onTouched = fn;
149
+ }
150
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ValidationDateComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: NG_VALIDATORS, optional: true }, { token: NG_ASYNC_VALIDATORS, optional: true }, { token: i0.Injector }, { token: i1.LocalizationService }, { token: i2.DateService }], target: i0.ɵɵFactoryTarget.Component }); }
151
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ValidationDateComponent, selector: "val-date", inputs: { useJsDates: "useJsDates" }, providers: [
152
+ { provide: LocalizationService, useClass: BaseValidationLoc },
153
+ {
154
+ provide: NG_VALUE_ACCESSOR,
155
+ useExisting: forwardRef(() => ValidationDateComponent),
156
+ multi: true
157
+ }
158
+ ], usesInheritance: true, ngImport: i0, template: "<mat-form-field appearance=\"{{FieldAppearence}}\" class=\"mat-full-width mat-no-border-top mat-height-fixed\" [style.width.px]=\"widthPx\">\r\n <mat-label *ngIf=\"placeholder && FloatingLabel\">{{placeholder}}</mat-label>\r\n <input matInput\r\n [matDatepicker]=\"datepicker\"\r\n #baseInput=\"ngModel\"\r\n #htmlInput\r\n type=\"text\"\r\n triggers=\"\"\r\n placement=\"top\"\r\n name=\"val-date\"\r\n class=\"form-control {{class}}\"\r\n autocomplete=\"{{autocomplete}}\"\r\n id=\"{{id}}\"\r\n (click)=\"onFocus($event)\"\r\n [(ngModel)]=\"value\"\r\n [class.checking-field]=\"!noValidate\"\r\n [tooltip]=\"tolTemplate\"\r\n [placeholder]=\"placeholder ? (FloatingLabel ? undefined : placeholder) : _format\"\r\n [disabled]=\"Readonly || disabled\"\r\n [isDisabled]=\"Readonly || disabled\"\r\n (dateChange)=\"outputValue($event); onFinalize();\"\r\n (keyup)=\"($event.keyCode == 13 || $event.keyCode == 27) && onFinalize();\"\r\n (blur)=\"closeTooltip();\"\r\n />\r\n <mat-datepicker-toggle matSuffix [for]=\"datepicker\"></mat-datepicker-toggle>\r\n <mat-datepicker #datepicker></mat-datepicker>\r\n</mat-form-field>\r\n\r\n<ng-template #tolTemplate>\r\n <div (click)=\"closeTooltip()\">\r\n <span>{{validationFailedBind}}</span>\r\n </div>\r\n</ng-template>", styles: [".tooltip-inner{background-color:#842a30;color:#fff;font-size:12px;width:max-content}.tooltip{margin:auto auto auto 20%!important}.tooltip-inner{background-color:#842a30!important;color:#fff}.tooltip.top .tooltip-arrow:before,.tooltip.top .tooltip-arrow{border-top-color:#842a30}.close-button{position:absolute;right:0;top:-.2em;float:right;font-size:16px;font-weight:700;color:inherit;text-shadow:0 1px 0 #fff;opacity:.5}.close-button:hover,.close-button:focus{text-decoration:none;cursor:pointer;opacity:.75}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i5.MatLegacyFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i5.MatLegacyLabel, selector: "mat-label" }, { kind: "directive", type: i5.MatLegacySuffix, selector: "[matSuffix]" }, { kind: "directive", type: i6.MatLegacyInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", exportAs: ["matInput"] }, { kind: "component", type: i7.MatDatepicker, selector: "mat-datepicker", exportAs: ["matDatepicker"] }, { kind: "directive", type: i7.MatDatepickerInput, selector: "input[matDatepicker]", inputs: ["matDatepicker", "min", "max", "matDatepickerFilter"], exportAs: ["matDatepickerInput"] }, { kind: "component", type: i7.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { kind: "directive", type: i8.TooltipDirective, selector: "[tooltip], [tooltipHtml]", inputs: ["adaptivePosition", "tooltip", "placement", "triggers", "container", "containerClass", "boundariesElement", "isOpen", "isDisabled", "delay", "tooltipHtml", "tooltipPlacement", "tooltipIsOpen", "tooltipEnable", "tooltipAppendToBody", "tooltipAnimation", "tooltipClass", "tooltipContext", "tooltipPopupDelay", "tooltipFadeDuration", "tooltipTrigger"], outputs: ["tooltipChange", "onShown", "onHidden", "tooltipStateChanged"], exportAs: ["bs-tooltip"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
159
+ }
160
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ValidationDateComponent, decorators: [{
161
+ type: Component,
162
+ args: [{ selector: "val-date", encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [
163
+ { provide: LocalizationService, useClass: BaseValidationLoc },
164
+ {
165
+ provide: NG_VALUE_ACCESSOR,
166
+ useExisting: forwardRef(() => ValidationDateComponent),
167
+ multi: true
168
+ }
169
+ ], template: "<mat-form-field appearance=\"{{FieldAppearence}}\" class=\"mat-full-width mat-no-border-top mat-height-fixed\" [style.width.px]=\"widthPx\">\r\n <mat-label *ngIf=\"placeholder && FloatingLabel\">{{placeholder}}</mat-label>\r\n <input matInput\r\n [matDatepicker]=\"datepicker\"\r\n #baseInput=\"ngModel\"\r\n #htmlInput\r\n type=\"text\"\r\n triggers=\"\"\r\n placement=\"top\"\r\n name=\"val-date\"\r\n class=\"form-control {{class}}\"\r\n autocomplete=\"{{autocomplete}}\"\r\n id=\"{{id}}\"\r\n (click)=\"onFocus($event)\"\r\n [(ngModel)]=\"value\"\r\n [class.checking-field]=\"!noValidate\"\r\n [tooltip]=\"tolTemplate\"\r\n [placeholder]=\"placeholder ? (FloatingLabel ? undefined : placeholder) : _format\"\r\n [disabled]=\"Readonly || disabled\"\r\n [isDisabled]=\"Readonly || disabled\"\r\n (dateChange)=\"outputValue($event); onFinalize();\"\r\n (keyup)=\"($event.keyCode == 13 || $event.keyCode == 27) && onFinalize();\"\r\n (blur)=\"closeTooltip();\"\r\n />\r\n <mat-datepicker-toggle matSuffix [for]=\"datepicker\"></mat-datepicker-toggle>\r\n <mat-datepicker #datepicker></mat-datepicker>\r\n</mat-form-field>\r\n\r\n<ng-template #tolTemplate>\r\n <div (click)=\"closeTooltip()\">\r\n <span>{{validationFailedBind}}</span>\r\n </div>\r\n</ng-template>", styles: [".tooltip-inner{background-color:#842a30;color:#fff;font-size:12px;width:max-content}.tooltip{margin:auto auto auto 20%!important}.tooltip-inner{background-color:#842a30!important;color:#fff}.tooltip.top .tooltip-arrow:before,.tooltip.top .tooltip-arrow{border-top-color:#842a30}.close-button{position:absolute;right:0;top:-.2em;float:right;font-size:16px;font-weight:700;color:inherit;text-shadow:0 1px 0 #fff;opacity:.5}.close-button:hover,.close-button:focus{text-decoration:none;cursor:pointer;opacity:.75}\n"] }]
170
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: Array, decorators: [{
171
+ type: Optional
172
+ }, {
173
+ type: Inject,
174
+ args: [NG_VALIDATORS]
175
+ }] }, { type: Array, decorators: [{
176
+ type: Optional
177
+ }, {
178
+ type: Inject,
179
+ args: [NG_ASYNC_VALIDATORS]
180
+ }] }, { type: i0.Injector }, { type: i1.LocalizationService }, { type: i2.DateService }]; }, propDecorators: { useJsDates: [{
181
+ type: Input
182
+ }] } });
183
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validation-date.component.js","sourceRoot":"","sources":["../../../../../../projects/forms-and-validations/src/lib/validations/validation-date/validation-date.component.ts","../../../../../../projects/forms-and-validations/src/lib/validations/validation-date/validation-date.component.html"],"names":[],"mappings":"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","sourcesContent":["// Angular\r\nimport { ControlValueAccessor, UntypedFormControl, NG_ASYNC_VALIDATORS, NG_VALIDATORS, NG_VALUE_ACCESSOR, NgControl, RequiredValidator } from \"@angular/forms\";\r\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, forwardRef, Inject, Injector, Input, Optional, ViewEncapsulation} from \"@angular/core\";\r\n\r\n// Configurazioni\r\nimport { LocalizationService } from \"@esfaenza/localizations\";\r\n\r\n// Direttive, Componenti, Librerie\r\nimport { BaseValidation } from \"../base-validation\";\r\nimport { BaseValidationLoc } from \"../base-validation.loc\"\r\nimport { DateService } from '@esfaenza/extensions';\r\n\r\n/**\r\n * Dichiarazione della variabile globale dayjs. L'onere di \"crearla\" è affidato all'applicazione che utilizza questa libreria, \r\n * che dovrà importare lo script globale di dayjs nella CLI\r\n */\r\ndeclare var dayjs: any;\r\n\r\n/**\r\n * Componente di validaizone per gli input di tipo data\r\n */\r\n@Component({\r\n    selector: \"val-date\",\r\n    templateUrl: \"validation-date.component.html\",\r\n    encapsulation: ViewEncapsulation.None,\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    styleUrls: [\"../validation-style.scss\"],\r\n    providers: [\r\n        { provide: LocalizationService, useClass: BaseValidationLoc },\r\n        {\r\n            provide: NG_VALUE_ACCESSOR,\r\n            useExisting: forwardRef(() => ValidationDateComponent),\r\n            multi: true\r\n        }\r\n    ]\r\n})\r\nexport class ValidationDateComponent extends BaseValidation implements ControlValueAccessor {\r\n    \r\n    /**\r\n     * Usato solo per stampare il placeholder qualora l'Input **placeholder** non fosse valorizzato\r\n     */\r\n    public _format: string;\r\n\r\n    /**\r\n    * Modello collegato all'input\r\n    */\r\n    public value: Date;\r\n\r\n    /**\r\n     * Controllo esposto ottenuto tramite injector\r\n     */\r\n    private parentControl: UntypedFormControl;\r\n\r\n    /**\r\n     * Utilizza il Date di Javascript come modello in uscita. Il modello in entrata verrà comunque ricondotto a un DayJs\r\n     */\r\n    @Input() public useJsDates: boolean = false;\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    constructor(cdr : ChangeDetectorRef, @Optional() @Inject(NG_VALIDATORS) private _validators: Array<any>, @Optional() @Inject(NG_ASYNC_VALIDATORS) private _asyncValidators: Array<any>, private injector: Injector, protected lc: LocalizationService, private dateExts: DateService) {\r\n        super(cdr);\r\n    }\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    ngOnInit() {\r\n        super.ngOnInit();\r\n        this.registerFocusRequest();\r\n\r\n        this.checkRequiredness(this._validators);\r\n\r\n        this._format = this.lc.token(\"getSmallDateDisplayFormat\");\r\n    }\r\n\r\n    /**\r\n     * @ignore\r\n     */\r\n    ngOnDestroy() {\r\n        super.ngOnDestroy();\r\n        this.deregisterFocusRequest();\r\n    }\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    ngAfterViewInit() {\r\n        this.postBinding();\r\n    }\r\n\r\n    /**\r\n     * Metodo che si occupa di collegare i validatori e la funzione di reset dal **ControlValueAccessor** rappresentato \r\n     * da questo componente al **ControlValueAccessor** rappresentato dall'effettivo elemento di Input presente lato HTML\r\n     */\r\n    postBinding() {\r\n        this.CheckValidity();\r\n        const ngControl: NgControl = this.injector.get(NgControl, null);\r\n        if (ngControl) {\r\n            this.parentControl = ngControl.control as UntypedFormControl;\r\n\r\n            if (this.noValidate) {\r\n                this.parentControl.clearValidators();\r\n                this.parentControl.clearAsyncValidators();\r\n            }\r\n            else {\r\n                this.baseInput.control.setAsyncValidators(this._asyncValidators);\r\n                this.baseInput.control.setValidators(this._validators);\r\n            }\r\n\r\n            // //faccio in modo che se chiamo il reset del controllo (o della form) dall'esterno si resetti anche il controllo nativo\r\n            //faccio in modo che se chiamo il reset del controllo (o della form) dall'esterno si resetti anche il controllo nativo\r\n            const origFunc = this.parentControl.reset;\r\n            this.parentControl.reset = () => { //faccio in modo che se chiamo il reset del controllo (o della form) dall'esterno si resetti anche il controllo nativo\r\n                origFunc.apply(this.parentControl);\r\n                this.baseInput.control.reset();\r\n                this.tooltip.hide();\r\n            };\r\n        }\r\n    }\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    private onTouched = () => { };\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    writeValue(value: any): void {\r\n        if (!value) {\r\n            this.value = null;\r\n            if (this.baseInput)\r\n                this.baseInput.reset();\r\n        } else {\r\n            var date = null;\r\n            if (this.useJsDates) {\r\n                date = this.dateExts.getDateConvertion(value);\r\n                if (date) {\r\n                    this.propagateChange(date.toDate());\r\n                    this.inputChange.emit(date.toDate());\r\n                }\r\n            }\r\n            else\r\n                date = dayjs(value, this.lc.token(\"getSmallDateFormat\"));\r\n\r\n            this.value = date;\r\n        }\r\n\r\n        this.cdr.markForCheck();\r\n    }\r\n\r\n    /**\r\n     * Metodo che si occupa di, eventualmente, aggiustare il valore da propagare ed emetterlo\r\n     * \r\n     * L'emit della modifica al valore viene gestito su un evento custom (**inputChange**) come workaround al malfunzionamento dell'**ngModelChange** nativo\r\n     * \r\n     * @param {any} toEmit valore da propagare all'esterno\r\n     */\r\n    outputValue(toEmit: any): void {\r\n        let value = toEmit.value;\r\n        let propagateValue: any;\r\n\r\n        if (!value)\r\n            propagateValue = null;\r\n        else if (!this.useJsDates)\r\n            propagateValue = value.format(this.lc.token(\"getSmallDateFormat\"));\r\n        else {\r\n            if (value && value.isValid())\r\n                propagateValue = value.hour(0).minute(0).second(0).toDate();\r\n            else\r\n                propagateValue = null;\r\n        }\r\n        this.propagateChange(propagateValue);\r\n        this.inputChange.emit(propagateValue);\r\n        this.onTouched();\r\n    }\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    registerOnChange(fn: any): void {\r\n        this.propagateChange = fn;\r\n    }\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    registerOnTouched(fn: any): void {\r\n        this.onTouched = fn;\r\n    }\r\n}","<mat-form-field appearance=\"{{FieldAppearence}}\" class=\"mat-full-width mat-no-border-top mat-height-fixed\" [style.width.px]=\"widthPx\">\r\n    <mat-label *ngIf=\"placeholder && FloatingLabel\">{{placeholder}}</mat-label>\r\n    <input matInput\r\n           [matDatepicker]=\"datepicker\"\r\n           #baseInput=\"ngModel\"\r\n           #htmlInput\r\n           type=\"text\"\r\n           triggers=\"\"\r\n           placement=\"top\"\r\n           name=\"val-date\"\r\n           class=\"form-control {{class}}\"\r\n           autocomplete=\"{{autocomplete}}\"\r\n           id=\"{{id}}\"\r\n           (click)=\"onFocus($event)\"\r\n           [(ngModel)]=\"value\"\r\n           [class.checking-field]=\"!noValidate\"\r\n           [tooltip]=\"tolTemplate\"\r\n           [placeholder]=\"placeholder ? (FloatingLabel ? undefined : placeholder) : _format\"\r\n           [disabled]=\"Readonly || disabled\"\r\n           [isDisabled]=\"Readonly || disabled\"\r\n           (dateChange)=\"outputValue($event); onFinalize();\"\r\n           (keyup)=\"($event.keyCode == 13 || $event.keyCode == 27) && onFinalize();\"\r\n           (blur)=\"closeTooltip();\"\r\n           />\r\n    <mat-datepicker-toggle matSuffix [for]=\"datepicker\"></mat-datepicker-toggle>\r\n    <mat-datepicker #datepicker></mat-datepicker>\r\n</mat-form-field>\r\n\r\n<ng-template #tolTemplate>\r\n    <div (click)=\"closeTooltip()\">\r\n        <span>{{validationFailedBind}}</span>\r\n    </div>\r\n</ng-template>"]}
@@ -0,0 +1,212 @@
1
+ // Angular
2
+ import { NG_ASYNC_VALIDATORS, NG_VALIDATORS, NG_VALUE_ACCESSOR, NgControl } from "@angular/forms";
3
+ import { ChangeDetectionStrategy, Component, forwardRef, Inject, Input, Optional, ViewEncapsulation } from "@angular/core";
4
+ // Configurazioni
5
+ import { LocalizationService } from "@esfaenza/localizations";
6
+ // Direttive, Componenti, Librerie
7
+ import { BaseValidation } from "../base-validation";
8
+ import { BaseValidationLoc } from "../base-validation.loc";
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "@esfaenza/localizations";
11
+ import * as i2 from "@esfaenza/extensions";
12
+ import * as i3 from "@angular/common";
13
+ import * as i4 from "@angular/forms";
14
+ import * as i5 from "@angular/material/legacy-form-field";
15
+ import * as i6 from "@angular/material/legacy-input";
16
+ import * as i7 from "@angular/material/datepicker";
17
+ import * as i8 from "ngx-bootstrap/tooltip";
18
+ import * as i9 from "@angular-material-components/datetime-picker";
19
+ /**
20
+ * Componente di validaizone per gli input di tipo data-ora
21
+ */
22
+ export class ValidationDateTimeComponent extends BaseValidation {
23
+ /**
24
+ * @ignore
25
+ */
26
+ constructor(cdr, _validators, _asyncValidators, injector, lc, dateExts) {
27
+ super(cdr);
28
+ this._validators = _validators;
29
+ this._asyncValidators = _asyncValidators;
30
+ this.injector = injector;
31
+ this.lc = lc;
32
+ this.dateExts = dateExts;
33
+ /**
34
+ * Proprietà dell'elemento di selezione dell'orario. Mostra o nasconde gli spinner
35
+ *
36
+ * Attualemnte non bindata ed utilizzata solo a livello di default ma non si sa mai
37
+ */
38
+ this.showSpinners = true;
39
+ /**
40
+ * Proprietà dell'elemento di selezione dell'orario. Mostra o nasconde i secondi
41
+ *
42
+ * Attualemnte non bindata ed utilizzata solo a livello di default ma non si sa mai
43
+ */
44
+ this.showSeconds = true;
45
+ /**
46
+ * Proprietà dell'elemento di selezione dell'orario. Imposta l'incremento/decremento minimo per le ore
47
+ *
48
+ * Attualemnte non bindata ed utilizzata solo a livello di default ma non si sa mai
49
+ */
50
+ this.stepHour = 1;
51
+ /**
52
+ * Proprietà dell'elemento di selezione dell'orario. Imposta l'incremento/decremento minimo per i minuti
53
+ *
54
+ * Attualemnte non bindata ed utilizzata solo a livello di default ma non si sa mai
55
+ */
56
+ this.stepMinute = 1;
57
+ /**
58
+ * Proprietà dell'elemento di selezione dell'orario. Imposta l'incremento/decremento minimo per i secondi
59
+ *
60
+ * Attualemnte non bindata ed utilizzata solo a livello di default ma non si sa mai
61
+ */
62
+ this.stepSecond = 1;
63
+ /**
64
+ * Utilizza il Date di Javascript come modello in uscita. Il modello in entrata verrà comunque ricondotto a un DayJs
65
+ */
66
+ this.useJsDates = false;
67
+ /**
68
+ * @ignore
69
+ */
70
+ this.onTouched = () => { };
71
+ }
72
+ /**
73
+ * @ignore
74
+ */
75
+ ngOnInit() {
76
+ super.ngOnInit();
77
+ this.registerFocusRequest();
78
+ this.checkRequiredness(this._validators);
79
+ this._format = this.lc.token("getSmallDateDisplayFormat");
80
+ }
81
+ /**
82
+ * @ignore
83
+ */
84
+ ngOnDestroy() {
85
+ super.ngOnDestroy();
86
+ this.deregisterFocusRequest();
87
+ }
88
+ /**
89
+ * @ignore
90
+ */
91
+ ngAfterViewInit() {
92
+ this.postBinding();
93
+ }
94
+ /**
95
+ * Metodo che si occupa di collegare i validatori e la funzione di reset dal **ControlValueAccessor** rappresentato
96
+ * da questo componente al **ControlValueAccessor** rappresentato dall'effettivo elemento di Input presente lato HTML
97
+ */
98
+ postBinding() {
99
+ this.CheckValidity();
100
+ const ngControl = this.injector.get(NgControl, null);
101
+ if (ngControl) {
102
+ this.parentControl = ngControl.control;
103
+ // Se la variabile novalidate è true, elimino tutti i validatori eventualmente inseriti
104
+ if (this.noValidate) {
105
+ this.parentControl.clearValidators();
106
+ this.parentControl.clearAsyncValidators();
107
+ }
108
+ else {
109
+ this.baseInput.control.setAsyncValidators(this._asyncValidators);
110
+ this.baseInput.control.setValidators(this._validators);
111
+ }
112
+ // Faccio in modo che se chiamo il reset del controllo (o della form) dall'esterno si resetti anche il controllo nativo
113
+ const origFunc = this.parentControl.reset;
114
+ this.parentControl.reset = () => {
115
+ origFunc.apply(this.parentControl);
116
+ this.baseInput.control.reset();
117
+ this.tooltip.hide();
118
+ };
119
+ }
120
+ }
121
+ /**
122
+ * @ignore
123
+ */
124
+ writeValue(value) {
125
+ if (!value) {
126
+ this.value = null;
127
+ if (this.baseInput)
128
+ this.baseInput.reset();
129
+ }
130
+ else {
131
+ var date = null;
132
+ if (this.useJsDates) {
133
+ date = this.dateExts.getDateConvertion(value);
134
+ this.propagateChange(date);
135
+ this.inputChange.emit(date);
136
+ }
137
+ else
138
+ date = dayjs(value, this.lc.token("getSmallDateFormat") + " HH:mm:ss");
139
+ this.value = date;
140
+ }
141
+ this.cdr.markForCheck();
142
+ }
143
+ /**
144
+ * Metodo che si occupa di, eventualmente, aggiustare il valore da propagare ed emetterlo
145
+ *
146
+ * L'emit della modifica al valore viene gestito su un evento custom (**inputChange**) come workaround al malfunzionamento dell'**ngModelChange** nativo
147
+ *
148
+ * @param {any} toEmit valore da propagare all'esterno
149
+ */
150
+ outputValue(toEmit) {
151
+ let value = toEmit.value;
152
+ let propagateValue;
153
+ if (!value)
154
+ propagateValue = null;
155
+ else if (!this.useJsDates)
156
+ propagateValue = value.format(this.lc.token("getSmallDateFormat") + " HH:mm:ss");
157
+ else {
158
+ if (value && value.isValid())
159
+ propagateValue = value.toDate();
160
+ else
161
+ propagateValue = null;
162
+ }
163
+ this.propagateChange(propagateValue);
164
+ this.inputChange.emit(propagateValue);
165
+ this.onTouched();
166
+ }
167
+ /**
168
+ * @ignore
169
+ */
170
+ registerOnChange(fn) {
171
+ this.propagateChange = fn;
172
+ }
173
+ /**
174
+ * @ignore
175
+ */
176
+ registerOnTouched(fn) {
177
+ this.onTouched = fn;
178
+ }
179
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ValidationDateTimeComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: NG_VALIDATORS, optional: true }, { token: NG_ASYNC_VALIDATORS, optional: true }, { token: i0.Injector }, { token: i1.LocalizationService }, { token: i2.DateService }], target: i0.ɵɵFactoryTarget.Component }); }
180
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ValidationDateTimeComponent, selector: "val-datetime", inputs: { useJsDates: "useJsDates" }, providers: [
181
+ { provide: LocalizationService, useClass: BaseValidationLoc },
182
+ {
183
+ provide: NG_VALUE_ACCESSOR,
184
+ useExisting: forwardRef(() => ValidationDateTimeComponent),
185
+ multi: true
186
+ }
187
+ ], usesInheritance: true, ngImport: i0, template: "<mat-form-field appearance=\"{{FieldAppearence}}\" class=\"mat-full-width mat-no-border-top mat-height-fixed\" [style.width.px]=\"widthPx\">\r\n <mat-label *ngIf=\"placeholder && FloatingLabel\">{{placeholder}}</mat-label>\r\n\r\n <input matInput \r\n [ngxMatDatetimePicker]=\"datepicker\" \r\n #baseInput=\"ngModel\"\r\n #htmlInput\r\n type=\"text\"\r\n triggers=\"\"\r\n placement=\"top\"\r\n name=\"val-date\"\r\n id=\"{{id}}\"\r\n (click)=\"onFocus($event)\"\r\n class=\"form-control {{class}}\"\r\n autocomplete=\"{{autocomplete}}\"\r\n [placeholder]=\"FloatingLabel ? undefined : placeholder\"\r\n [(ngModel)]=\"value\"\r\n [class.checking-field]=\"!noValidate\"\r\n [tooltip]=\"tolTemplate\"\r\n [placeholder]=\"placeholder ? '' : _format\"\r\n [disabled]=\"Readonly || disabled\"\r\n [isDisabled]=\"Readonly || disabled\"\r\n (dateChange)=\"outputValue($event); onFinalize();\"\r\n (keyup)=\"($event.keyCode == 13 || $event.keyCode == 27) && onFinalize();\"\r\n (blur)=\"closeTooltip();\"\r\n />\r\n\r\n <mat-datepicker-toggle matSuffix [for]=\"datepicker\"></mat-datepicker-toggle>\r\n\r\n <ngx-mat-datetime-picker #datepicker \r\n [showSpinners]=\"showSpinners\" \r\n [showSeconds]=\"showSeconds\" \r\n [stepHour]=\"stepHour\" \r\n [stepMinute]=\"stepMinute\" \r\n [stepSecond]=\"stepSecond\" \r\n [touchUi]=\"false\" \r\n [color]=\"'primary'\">\r\n </ngx-mat-datetime-picker>\r\n</mat-form-field>\r\n\r\n<ng-template #tolTemplate>\r\n <div (click)=\"closeTooltip()\">\r\n <span>{{validationFailedBind}}</span>\r\n </div>\r\n</ng-template>", styles: [".tooltip-inner{background-color:#842a30;color:#fff;font-size:12px;width:max-content}.tooltip{margin:auto auto auto 20%!important}.tooltip-inner{background-color:#842a30!important;color:#fff}.tooltip.top .tooltip-arrow:before,.tooltip.top .tooltip-arrow{border-top-color:#842a30}.close-button{position:absolute;right:0;top:-.2em;float:right;font-size:16px;font-weight:700;color:inherit;text-shadow:0 1px 0 #fff;opacity:.5}.close-button:hover,.close-button:focus{text-decoration:none;cursor:pointer;opacity:.75}\n"], dependencies: [{ kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i5.MatLegacyFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i5.MatLegacyLabel, selector: "mat-label" }, { kind: "directive", type: i5.MatLegacySuffix, selector: "[matSuffix]" }, { kind: "directive", type: i6.MatLegacyInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", exportAs: ["matInput"] }, { kind: "component", type: i7.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { kind: "directive", type: i8.TooltipDirective, selector: "[tooltip], [tooltipHtml]", inputs: ["adaptivePosition", "tooltip", "placement", "triggers", "container", "containerClass", "boundariesElement", "isOpen", "isDisabled", "delay", "tooltipHtml", "tooltipPlacement", "tooltipIsOpen", "tooltipEnable", "tooltipAppendToBody", "tooltipAnimation", "tooltipClass", "tooltipContext", "tooltipPopupDelay", "tooltipFadeDuration", "tooltipTrigger"], outputs: ["tooltipChange", "onShown", "onHidden", "tooltipStateChanged"], exportAs: ["bs-tooltip"] }, { kind: "component", type: i9.NgxMatDatetimePicker, selector: "ngx-mat-datetime-picker", inputs: ["calendarHeaderComponent", "startAt", "startView", "defaultColor", "color", "touchUi", "hideTime", "disabled", "panelClass", "dateClass", "opened", "showSpinners", "showSeconds", "stepHour", "stepMinute", "stepSecond", "enableMeridian", "disableMinute", "defaultTime"], outputs: ["yearSelected", "monthSelected", "opened", "closed"], exportAs: ["ngxMatDatetimePicker"] }, { kind: "directive", type: i9.NgxMatDatetimeInput, selector: "input[ngxMatDatetimePicker]", inputs: ["ngxMatDatetimePicker", "ngxMatDatetimePickerFilter", "value", "min", "max", "disabled"], outputs: ["dateChange", "dateInput"], exportAs: ["ngxMatDatetimePickerInput"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
188
+ }
189
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ValidationDateTimeComponent, decorators: [{
190
+ type: Component,
191
+ args: [{ selector: "val-datetime", encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [
192
+ { provide: LocalizationService, useClass: BaseValidationLoc },
193
+ {
194
+ provide: NG_VALUE_ACCESSOR,
195
+ useExisting: forwardRef(() => ValidationDateTimeComponent),
196
+ multi: true
197
+ }
198
+ ], template: "<mat-form-field appearance=\"{{FieldAppearence}}\" class=\"mat-full-width mat-no-border-top mat-height-fixed\" [style.width.px]=\"widthPx\">\r\n <mat-label *ngIf=\"placeholder && FloatingLabel\">{{placeholder}}</mat-label>\r\n\r\n <input matInput \r\n [ngxMatDatetimePicker]=\"datepicker\" \r\n #baseInput=\"ngModel\"\r\n #htmlInput\r\n type=\"text\"\r\n triggers=\"\"\r\n placement=\"top\"\r\n name=\"val-date\"\r\n id=\"{{id}}\"\r\n (click)=\"onFocus($event)\"\r\n class=\"form-control {{class}}\"\r\n autocomplete=\"{{autocomplete}}\"\r\n [placeholder]=\"FloatingLabel ? undefined : placeholder\"\r\n [(ngModel)]=\"value\"\r\n [class.checking-field]=\"!noValidate\"\r\n [tooltip]=\"tolTemplate\"\r\n [placeholder]=\"placeholder ? '' : _format\"\r\n [disabled]=\"Readonly || disabled\"\r\n [isDisabled]=\"Readonly || disabled\"\r\n (dateChange)=\"outputValue($event); onFinalize();\"\r\n (keyup)=\"($event.keyCode == 13 || $event.keyCode == 27) && onFinalize();\"\r\n (blur)=\"closeTooltip();\"\r\n />\r\n\r\n <mat-datepicker-toggle matSuffix [for]=\"datepicker\"></mat-datepicker-toggle>\r\n\r\n <ngx-mat-datetime-picker #datepicker \r\n [showSpinners]=\"showSpinners\" \r\n [showSeconds]=\"showSeconds\" \r\n [stepHour]=\"stepHour\" \r\n [stepMinute]=\"stepMinute\" \r\n [stepSecond]=\"stepSecond\" \r\n [touchUi]=\"false\" \r\n [color]=\"'primary'\">\r\n </ngx-mat-datetime-picker>\r\n</mat-form-field>\r\n\r\n<ng-template #tolTemplate>\r\n <div (click)=\"closeTooltip()\">\r\n <span>{{validationFailedBind}}</span>\r\n </div>\r\n</ng-template>", styles: [".tooltip-inner{background-color:#842a30;color:#fff;font-size:12px;width:max-content}.tooltip{margin:auto auto auto 20%!important}.tooltip-inner{background-color:#842a30!important;color:#fff}.tooltip.top .tooltip-arrow:before,.tooltip.top .tooltip-arrow{border-top-color:#842a30}.close-button{position:absolute;right:0;top:-.2em;float:right;font-size:16px;font-weight:700;color:inherit;text-shadow:0 1px 0 #fff;opacity:.5}.close-button:hover,.close-button:focus{text-decoration:none;cursor:pointer;opacity:.75}\n"] }]
199
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: Array, decorators: [{
200
+ type: Optional
201
+ }, {
202
+ type: Inject,
203
+ args: [NG_VALIDATORS]
204
+ }] }, { type: Array, decorators: [{
205
+ type: Optional
206
+ }, {
207
+ type: Inject,
208
+ args: [NG_ASYNC_VALIDATORS]
209
+ }] }, { type: i0.Injector }, { type: i1.LocalizationService }, { type: i2.DateService }]; }, propDecorators: { useJsDates: [{
210
+ type: Input
211
+ }] } });
212
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validation-datetime.component.js","sourceRoot":"","sources":["../../../../../../projects/forms-and-validations/src/lib/validations/validation-datetime/validation-datetime.component.ts","../../../../../../projects/forms-and-validations/src/lib/validations/validation-datetime/validation-datetime.component.html"],"names":[],"mappings":"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","sourcesContent":["// Angular\r\nimport { ControlValueAccessor, UntypedFormControl, NG_ASYNC_VALIDATORS, NG_VALIDATORS, NG_VALUE_ACCESSOR, NgControl, RequiredValidator } from \"@angular/forms\";\r\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, forwardRef, Inject, Injector, Input, Optional, ViewEncapsulation } from \"@angular/core\";\r\n\r\n// Configurazioni\r\nimport { LocalizationService } from \"@esfaenza/localizations\";\r\n\r\n// Direttive, Componenti, Librerie\r\nimport { BaseValidation } from \"../base-validation\";\r\nimport { BaseValidationLoc } from \"../base-validation.loc\"\r\nimport { DateService } from '@esfaenza/extensions';\r\n\r\n/**\r\n * Dichiarazione della variabile globale dayjs. L'onere di \"crearla\" è affidato all'applicazione che utilizza questa libreria, \r\n * che dovrà importare lo script globale di dayjs nella CLI\r\n */\r\ndeclare var dayjs: any;\r\n\r\n/**\r\n * Componente di validaizone per gli input di tipo data-ora\r\n */\r\n@Component({\r\n    selector: \"val-datetime\",\r\n    templateUrl: \"validation-datetime.component.html\",\r\n    encapsulation: ViewEncapsulation.None,\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    styleUrls: [\"../validation-style.scss\"],\r\n    providers: [\r\n        { provide: LocalizationService, useClass: BaseValidationLoc },\r\n        {\r\n            provide: NG_VALUE_ACCESSOR,\r\n            useExisting: forwardRef(() => ValidationDateTimeComponent),\r\n            multi: true\r\n        }\r\n    ]\r\n})\r\nexport class ValidationDateTimeComponent extends BaseValidation implements ControlValueAccessor {\r\n\r\n    /**\r\n     * Usato solo per stampare il placeholder qualora l'Input **placeholder** non fosse valorizzato\r\n     */\r\n    public _format: string;\r\n\r\n    /**\r\n     * Modello collegato all'input\r\n     */\r\n    public value: Date;\r\n\r\n    /**\r\n     * Controllo esposto ottenuto tramite injector\r\n     */\r\n    private parentControl: UntypedFormControl;\r\n\r\n    /**\r\n     * Proprietà dell'elemento di selezione dell'orario. Mostra o nasconde gli spinner\r\n     * \r\n     * Attualemnte non bindata ed utilizzata solo a livello di default ma non si sa mai\r\n     */\r\n    public showSpinners = true;\r\n\r\n    /**\r\n     * Proprietà dell'elemento di selezione dell'orario. Mostra o nasconde i secondi\r\n     * \r\n     * Attualemnte non bindata ed utilizzata solo a livello di default ma non si sa mai\r\n     */\r\n    public showSeconds = true;\r\n\r\n    /**\r\n     * Proprietà dell'elemento di selezione dell'orario. Imposta l'incremento/decremento minimo per le ore\r\n     * \r\n     * Attualemnte non bindata ed utilizzata solo a livello di default ma non si sa mai\r\n     */\r\n    public stepHour = 1;\r\n\r\n    /**\r\n     * Proprietà dell'elemento di selezione dell'orario. Imposta l'incremento/decremento minimo per i minuti\r\n     * \r\n     * Attualemnte non bindata ed utilizzata solo a livello di default ma non si sa mai\r\n     */\r\n    public stepMinute = 1;\r\n\r\n    /**\r\n     * Proprietà dell'elemento di selezione dell'orario. Imposta l'incremento/decremento minimo per i secondi\r\n     * \r\n     * Attualemnte non bindata ed utilizzata solo a livello di default ma non si sa mai\r\n     */\r\n    public stepSecond = 1;\r\n\r\n    /**\r\n     * Utilizza il Date di Javascript come modello in uscita. Il modello in entrata verrà comunque ricondotto a un DayJs\r\n     */\r\n    @Input() public useJsDates: boolean = false;\r\n\r\n    /**\r\n     * @ignore\r\n     */\r\n    constructor(cdr: ChangeDetectorRef, @Optional() @Inject(NG_VALIDATORS) private _validators: Array<any>, @Optional() @Inject(NG_ASYNC_VALIDATORS) private _asyncValidators: Array<any>, private injector: Injector, protected lc: LocalizationService, private dateExts: DateService) {\r\n        super(cdr);\r\n    }\r\n\r\n    /**\r\n     * @ignore\r\n     */\r\n    ngOnInit() {\r\n        super.ngOnInit();\r\n        this.registerFocusRequest();\r\n\r\n        this.checkRequiredness(this._validators);\r\n\r\n        this._format = this.lc.token(\"getSmallDateDisplayFormat\");\r\n    }\r\n\r\n    /**\r\n     * @ignore\r\n     */\r\n    ngOnDestroy(){\r\n        super.ngOnDestroy();\r\n        this.deregisterFocusRequest();\r\n    }\r\n\r\n    /**\r\n     * @ignore\r\n     */\r\n    ngAfterViewInit() {\r\n        this.postBinding();\r\n    }\r\n\r\n    /**\r\n     * Metodo che si occupa di collegare i validatori e la funzione di reset dal **ControlValueAccessor** rappresentato \r\n     * da questo componente al **ControlValueAccessor** rappresentato dall'effettivo elemento di Input presente lato HTML\r\n     */\r\n    postBinding() {\r\n        this.CheckValidity();\r\n        const ngControl: NgControl = this.injector.get(NgControl, null);\r\n        if (ngControl) {\r\n            this.parentControl = ngControl.control as UntypedFormControl;\r\n\r\n            // Se la variabile novalidate è true, elimino tutti i validatori eventualmente inseriti\r\n            if (this.noValidate) {\r\n                this.parentControl.clearValidators();\r\n                this.parentControl.clearAsyncValidators();\r\n            }\r\n            else {\r\n                this.baseInput.control.setAsyncValidators(this._asyncValidators);\r\n                this.baseInput.control.setValidators(this._validators);\r\n            }\r\n\r\n            // Faccio in modo che se chiamo il reset del controllo (o della form) dall'esterno si resetti anche il controllo nativo\r\n            const origFunc = this.parentControl.reset;\r\n            this.parentControl.reset = () => { \r\n                origFunc.apply(this.parentControl);\r\n                this.baseInput.control.reset();\r\n                this.tooltip.hide();\r\n            };\r\n        }\r\n    }\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    private onTouched = () => { };\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    writeValue(value: any): void {\r\n        if (!value) {\r\n            this.value = null;\r\n            if (this.baseInput)\r\n                this.baseInput.reset();\r\n        } else {\r\n            var date = null;\r\n            if (this.useJsDates) {\r\n                date = this.dateExts.getDateConvertion(value)\r\n                this.propagateChange(date);\r\n                this.inputChange.emit(date);\r\n            }\r\n            else\r\n                date = dayjs(value, this.lc.token(\"getSmallDateFormat\") + \" HH:mm:ss\");\r\n\r\n            this.value = date;\r\n        }\r\n        this.cdr.markForCheck();\r\n    }\r\n\r\n    /**\r\n     * Metodo che si occupa di, eventualmente, aggiustare il valore da propagare ed emetterlo\r\n     * \r\n     * L'emit della modifica al valore viene gestito su un evento custom (**inputChange**) come workaround al malfunzionamento dell'**ngModelChange** nativo\r\n     * \r\n     * @param {any} toEmit valore da propagare all'esterno\r\n     */\r\n    outputValue(toEmit: any): void {\r\n        let value = toEmit.value;\r\n        let propagateValue: any;\r\n\r\n        if (!value)\r\n            propagateValue = null;\r\n        else if (!this.useJsDates)\r\n            propagateValue = value.format(this.lc.token(\"getSmallDateFormat\") + \" HH:mm:ss\");\r\n        else {\r\n            if (value && value.isValid())\r\n                propagateValue = value.toDate();\r\n            else\r\n                propagateValue = null;\r\n        }\r\n        this.propagateChange(propagateValue);\r\n        this.inputChange.emit(propagateValue);\r\n        this.onTouched();\r\n    }\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    registerOnChange(fn: any): void {\r\n        this.propagateChange = fn;\r\n    }\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    registerOnTouched(fn: any): void {\r\n        this.onTouched = fn;\r\n    }\r\n}","<mat-form-field appearance=\"{{FieldAppearence}}\" class=\"mat-full-width mat-no-border-top mat-height-fixed\" [style.width.px]=\"widthPx\">\r\n    <mat-label *ngIf=\"placeholder && FloatingLabel\">{{placeholder}}</mat-label>\r\n\r\n    <input matInput \r\n           [ngxMatDatetimePicker]=\"datepicker\" \r\n           #baseInput=\"ngModel\"\r\n           #htmlInput\r\n           type=\"text\"\r\n           triggers=\"\"\r\n           placement=\"top\"\r\n           name=\"val-date\"\r\n           id=\"{{id}}\"\r\n           (click)=\"onFocus($event)\"\r\n           class=\"form-control {{class}}\"\r\n           autocomplete=\"{{autocomplete}}\"\r\n           [placeholder]=\"FloatingLabel ? undefined : placeholder\"\r\n           [(ngModel)]=\"value\"\r\n           [class.checking-field]=\"!noValidate\"\r\n           [tooltip]=\"tolTemplate\"\r\n           [placeholder]=\"placeholder ? '' : _format\"\r\n           [disabled]=\"Readonly || disabled\"\r\n           [isDisabled]=\"Readonly || disabled\"\r\n           (dateChange)=\"outputValue($event); onFinalize();\"\r\n           (keyup)=\"($event.keyCode == 13 || $event.keyCode == 27) && onFinalize();\"\r\n           (blur)=\"closeTooltip();\"\r\n           />\r\n\r\n  <mat-datepicker-toggle matSuffix [for]=\"datepicker\"></mat-datepicker-toggle>\r\n\r\n  <ngx-mat-datetime-picker #datepicker \r\n            [showSpinners]=\"showSpinners\" \r\n            [showSeconds]=\"showSeconds\" \r\n            [stepHour]=\"stepHour\" \r\n            [stepMinute]=\"stepMinute\" \r\n            [stepSecond]=\"stepSecond\" \r\n            [touchUi]=\"false\" \r\n            [color]=\"'primary'\">\r\n  </ngx-mat-datetime-picker>\r\n</mat-form-field>\r\n\r\n<ng-template #tolTemplate>\r\n    <div (click)=\"closeTooltip()\">\r\n        <span>{{validationFailedBind}}</span>\r\n    </div>\r\n</ng-template>"]}