@esfaenza/forms-and-validations 12.2.31 → 13.1.2

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 (118) hide show
  1. package/esfaenza-forms-and-validations.d.ts +1 -12
  2. package/esm2020/esfaenza-forms-and-validations.mjs +5 -0
  3. package/esm2020/lib/forms/base-form-control.mjs +482 -0
  4. package/esm2020/lib/forms/form-adaptive/form-adaptive.component.loc.mjs +28 -0
  5. package/esm2020/lib/forms/form-adaptive/form-adaptive.component.mjs +294 -0
  6. package/esm2020/lib/forms/form-autocomplete/form-autocomplete.component.loc.mjs +26 -0
  7. package/esm2020/lib/forms/form-autocomplete/form-autocomplete.component.mjs +200 -0
  8. package/esm2020/lib/forms/form-checkbox/form-checkbox.component.mjs +52 -0
  9. package/esm2020/lib/forms/form-date/form-date.component.mjs +59 -0
  10. package/esm2020/lib/forms/form-datetime/form-datetime.component.mjs +59 -0
  11. package/esm2020/lib/forms/form-empty/form-empty.component.mjs +36 -0
  12. package/esm2020/lib/forms/form-error/form-error.component.mjs +52 -0
  13. package/esm2020/lib/forms/form-file/form-file.component.loc.mjs +28 -0
  14. package/esm2020/lib/forms/form-file/form-file.component.mjs +119 -0
  15. package/esm2020/lib/forms/form-info/form-info.component.mjs +52 -0
  16. package/esm2020/lib/forms/form-input/form-input.component.mjs +93 -0
  17. package/esm2020/lib/forms/form-multiselect/form-multiselect.component.loc.mjs +29 -0
  18. package/esm2020/lib/forms/form-multiselect/form-multiselect.component.mjs +159 -0
  19. package/esm2020/lib/forms/form-select/form-select.component.loc.mjs +26 -0
  20. package/esm2020/lib/forms/form-select/form-select.component.mjs +129 -0
  21. package/esm2020/lib/forms/form-template/form-template.component.mjs +71 -0
  22. package/esm2020/lib/forms/form-textarea/form-textarea.component.mjs +54 -0
  23. package/esm2020/lib/forms/form-time/form-time.component.mjs +131 -0
  24. package/esm2020/lib/forms-and-validations.module.mjs +203 -0
  25. package/{esm2015/lib/models/AppFile.js → esm2020/lib/models/AppFile.mjs} +0 -0
  26. package/{esm2015/lib/models/FormsAndValidationsModuleConfig.js → esm2020/lib/models/FormsAndValidationsModuleConfig.mjs} +0 -0
  27. package/esm2020/lib/models/dayjs-adapter/dayjs-date-adapter.mjs +89 -0
  28. package/{esm2015/lib/tokens.js → esm2020/lib/tokens.mjs} +0 -0
  29. package/esm2020/lib/validations/base-validation.loc.mjs +28 -0
  30. package/esm2020/lib/validations/base-validation.mjs +232 -0
  31. package/esm2020/lib/validations/customValidators/CustomRequiredDirective.mjs +41 -0
  32. package/esm2020/lib/validations/validation-autocomplete/validation-autocomplete.component.mjs +168 -0
  33. package/esm2020/lib/validations/validation-currency/validation-currency.component.mjs +61 -0
  34. package/esm2020/lib/validations/validation-date/validation-date.component.mjs +177 -0
  35. package/esm2020/lib/validations/validation-datetime/validation-datetime.component.mjs +206 -0
  36. package/esm2020/lib/validations/validation-input/validation-input.component.mjs +207 -0
  37. package/esm2020/lib/validations/validation-select/validation-select.component.mjs +184 -0
  38. package/esm2020/lib/validations/validation-text-area/validation-text-area.component.mjs +64 -0
  39. package/esm2020/public-api.mjs +35 -0
  40. package/fesm2015/esfaenza-forms-and-validations.mjs +3620 -0
  41. package/fesm2015/esfaenza-forms-and-validations.mjs.map +1 -0
  42. package/fesm2020/esfaenza-forms-and-validations.mjs +3562 -0
  43. package/fesm2020/esfaenza-forms-and-validations.mjs.map +1 -0
  44. package/lib/forms/base-form-control.d.ts +3 -0
  45. package/lib/forms/form-adaptive/form-adaptive.component.d.ts +3 -0
  46. package/lib/forms/form-adaptive/form-adaptive.component.loc.d.ts +3 -0
  47. package/lib/forms/form-autocomplete/form-autocomplete.component.d.ts +3 -0
  48. package/lib/forms/form-autocomplete/form-autocomplete.component.loc.d.ts +3 -0
  49. package/lib/forms/form-checkbox/form-checkbox.component.d.ts +3 -0
  50. package/lib/forms/form-date/form-date.component.d.ts +3 -0
  51. package/lib/forms/form-datetime/form-datetime.component.d.ts +3 -0
  52. package/lib/forms/form-empty/form-empty.component.d.ts +3 -0
  53. package/lib/forms/form-error/form-error.component.d.ts +3 -0
  54. package/lib/forms/form-file/form-file.component.d.ts +3 -0
  55. package/lib/forms/form-file/form-file.component.loc.d.ts +3 -0
  56. package/lib/forms/form-info/form-info.component.d.ts +3 -0
  57. package/lib/forms/form-input/form-input.component.d.ts +3 -0
  58. package/lib/forms/form-multiselect/form-multiselect.component.d.ts +3 -0
  59. package/lib/forms/form-multiselect/form-multiselect.component.loc.d.ts +3 -0
  60. package/lib/forms/form-select/form-select.component.d.ts +3 -0
  61. package/lib/forms/form-select/form-select.component.loc.d.ts +3 -0
  62. package/lib/forms/form-template/form-template.component.d.ts +3 -0
  63. package/lib/forms/form-textarea/form-textarea.component.d.ts +3 -0
  64. package/lib/forms/form-time/form-time.component.d.ts +3 -0
  65. package/lib/forms-and-validations.module.d.ts +38 -0
  66. package/lib/models/dayjs-adapter/dayjs-date-adapter.d.ts +3 -0
  67. package/lib/validations/base-validation.d.ts +3 -0
  68. package/lib/validations/base-validation.loc.d.ts +3 -0
  69. package/lib/validations/customValidators/CustomRequiredDirective.d.ts +3 -0
  70. package/lib/validations/validation-autocomplete/validation-autocomplete.component.d.ts +3 -0
  71. package/lib/validations/validation-currency/validation-currency.component.d.ts +3 -0
  72. package/lib/validations/validation-date/validation-date.component.d.ts +3 -0
  73. package/lib/validations/validation-datetime/validation-datetime.component.d.ts +3 -0
  74. package/lib/validations/validation-input/validation-input.component.d.ts +3 -0
  75. package/lib/validations/validation-select/validation-select.component.d.ts +3 -0
  76. package/lib/validations/validation-text-area/validation-text-area.component.d.ts +3 -0
  77. package/package.json +30 -18
  78. package/public-api.d.ts +2 -0
  79. package/bundles/esfaenza-forms-and-validations.umd.js +0 -3754
  80. package/bundles/esfaenza-forms-and-validations.umd.js.map +0 -1
  81. package/esfaenza-forms-and-validations.metadata.json +0 -1
  82. package/esm2015/esfaenza-forms-and-validations.js +0 -17
  83. package/esm2015/lib/forms/base-form-control.js +0 -460
  84. package/esm2015/lib/forms/form-adaptive/form-adaptive.component.js +0 -277
  85. package/esm2015/lib/forms/form-adaptive/form-adaptive.component.loc.js +0 -23
  86. package/esm2015/lib/forms/form-autocomplete/form-autocomplete.component.js +0 -187
  87. package/esm2015/lib/forms/form-autocomplete/form-autocomplete.component.loc.js +0 -21
  88. package/esm2015/lib/forms/form-checkbox/form-checkbox.component.js +0 -41
  89. package/esm2015/lib/forms/form-date/form-date.component.js +0 -49
  90. package/esm2015/lib/forms/form-datetime/form-datetime.component.js +0 -49
  91. package/esm2015/lib/forms/form-empty/form-empty.component.js +0 -34
  92. package/esm2015/lib/forms/form-error/form-error.component.js +0 -49
  93. package/esm2015/lib/forms/form-file/form-file.component.js +0 -109
  94. package/esm2015/lib/forms/form-file/form-file.component.loc.js +0 -23
  95. package/esm2015/lib/forms/form-info/form-info.component.js +0 -49
  96. package/esm2015/lib/forms/form-input/form-input.component.js +0 -76
  97. package/esm2015/lib/forms/form-multiselect/form-multiselect.component.js +0 -154
  98. package/esm2015/lib/forms/form-multiselect/form-multiselect.component.loc.js +0 -24
  99. package/esm2015/lib/forms/form-select/form-select.component.js +0 -114
  100. package/esm2015/lib/forms/form-select/form-select.component.loc.js +0 -21
  101. package/esm2015/lib/forms/form-template/form-template.component.js +0 -64
  102. package/esm2015/lib/forms/form-textarea/form-textarea.component.js +0 -44
  103. package/esm2015/lib/forms/form-time/form-time.component.js +0 -117
  104. package/esm2015/lib/forms-and-validations.module.js +0 -144
  105. package/esm2015/lib/models/dayjs-adapter/dayjs-date-adapter.js +0 -86
  106. package/esm2015/lib/validations/base-validation.js +0 -208
  107. package/esm2015/lib/validations/base-validation.loc.js +0 -23
  108. package/esm2015/lib/validations/customValidators/CustomRequiredDirective.js +0 -35
  109. package/esm2015/lib/validations/validation-autocomplete/validation-autocomplete.component.js +0 -151
  110. package/esm2015/lib/validations/validation-currency/validation-currency.component.js +0 -48
  111. package/esm2015/lib/validations/validation-date/validation-date.component.js +0 -165
  112. package/esm2015/lib/validations/validation-datetime/validation-datetime.component.js +0 -193
  113. package/esm2015/lib/validations/validation-input/validation-input.component.js +0 -186
  114. package/esm2015/lib/validations/validation-select/validation-select.component.js +0 -166
  115. package/esm2015/lib/validations/validation-text-area/validation-text-area.component.js +0 -52
  116. package/esm2015/public-api.js +0 -32
  117. package/fesm2015/esfaenza-forms-and-validations.js +0 -3262
  118. package/fesm2015/esfaenza-forms-and-validations.js.map +0 -1
@@ -1,193 +0,0 @@
1
- // Angular
2
- import { NG_ASYNC_VALIDATORS, NG_VALIDATORS, NG_VALUE_ACCESSOR, NgControl, RequiredValidator } from "@angular/forms";
3
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, forwardRef, Inject, Injector, 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 { DateService } from '@esfaenza/extensions';
10
- /**
11
- * Componente di validaizone per gli input di tipo data-ora
12
- */
13
- export class ValidationDateTimeComponent extends BaseValidation {
14
- /**
15
- * @ignore
16
- */
17
- constructor(cdr, _validators, _asyncValidators, injector, lc, dateExts) {
18
- super();
19
- this.cdr = cdr;
20
- this._validators = _validators;
21
- this._asyncValidators = _asyncValidators;
22
- this.injector = injector;
23
- this.lc = lc;
24
- this.dateExts = dateExts;
25
- /**
26
- * Proprietà dell'elemento di selezione dell'orario. Mostra o nasconde gli spinner
27
- *
28
- * Attualemnte non bindata ed utilizzata solo a livello di default ma non si sa mai
29
- */
30
- this.showSpinners = true;
31
- /**
32
- * Proprietà dell'elemento di selezione dell'orario. Mostra o nasconde i secondi
33
- *
34
- * Attualemnte non bindata ed utilizzata solo a livello di default ma non si sa mai
35
- */
36
- this.showSeconds = true;
37
- /**
38
- * Proprietà dell'elemento di selezione dell'orario. Imposta l'incremento/decremento minimo per le ore
39
- *
40
- * Attualemnte non bindata ed utilizzata solo a livello di default ma non si sa mai
41
- */
42
- this.stepHour = 1;
43
- /**
44
- * Proprietà dell'elemento di selezione dell'orario. Imposta l'incremento/decremento minimo per i minuti
45
- *
46
- * Attualemnte non bindata ed utilizzata solo a livello di default ma non si sa mai
47
- */
48
- this.stepMinute = 1;
49
- /**
50
- * Proprietà dell'elemento di selezione dell'orario. Imposta l'incremento/decremento minimo per i secondi
51
- *
52
- * Attualemnte non bindata ed utilizzata solo a livello di default ma non si sa mai
53
- */
54
- this.stepSecond = 1;
55
- /**
56
- * Utilizza il Date di Javascript come modello in uscita. Il modello in entrata verrà comunque ricondotto a un DayJs
57
- */
58
- this.useJsDates = false;
59
- /**
60
- * @ignore
61
- */
62
- this.onTouched = () => { };
63
- }
64
- /**
65
- * @ignore
66
- */
67
- ngOnInit() {
68
- // Controllo se è settato un required per decidere in maniera condizionale se utilizzare il validatore required nel componente interno
69
- if (this._validators && !this.noValidate && this._validators.some(elem => elem instanceof RequiredValidator))
70
- this.required = true;
71
- this._format = this.lc.token("getSmallDateDisplayFormat");
72
- }
73
- /**
74
- * @ignore
75
- */
76
- ngAfterViewInit() {
77
- this.postBinding();
78
- }
79
- /**
80
- * Metodo che si occupa di collegare i validatori e la funzione di reset dal **ControlValueAccessor** rappresentato
81
- * da questo componente al **ControlValueAccessor** rappresentato dall'effettivo elemento di Input presente lato HTML
82
- */
83
- postBinding() {
84
- this.CheckValidity();
85
- const ngControl = this.injector.get(NgControl, null);
86
- if (ngControl) {
87
- this.parentControl = ngControl.control;
88
- // Se la variabile novalidate è true, elimino tutti i validatori eventualmente inseriti
89
- if (this.noValidate) {
90
- this.parentControl.clearValidators();
91
- this.parentControl.clearAsyncValidators();
92
- }
93
- else {
94
- this.baseInput.control.setAsyncValidators(this._asyncValidators);
95
- this.baseInput.control.setValidators(this._validators);
96
- }
97
- // Faccio in modo che se chiamo il reset del controllo (o della form) dall'esterno si resetti anche il controllo nativo
98
- const origFunc = this.parentControl.reset;
99
- this.parentControl.reset = () => {
100
- origFunc.apply(this.parentControl);
101
- this.baseInput.control.reset();
102
- this.tooltip.hide();
103
- };
104
- }
105
- }
106
- /**
107
- * @ignore
108
- */
109
- writeValue(value) {
110
- if (!value) {
111
- this.value = null;
112
- if (this.baseInput)
113
- this.baseInput.reset();
114
- }
115
- else {
116
- var date = null;
117
- if (this.useJsDates) {
118
- date = this.dateExts.getDateConvertion(value);
119
- this.propagateChange(date);
120
- this.inputChange.emit(date);
121
- }
122
- else
123
- date = dayjs(value, this.lc.token("getSmallDateFormat") + " HH:mm:ss");
124
- this.value = date;
125
- }
126
- this.cdr.markForCheck();
127
- }
128
- /**
129
- * Metodo che si occupa di, eventualmente, aggiustare il valore da propagare ed emetterlo
130
- *
131
- * L'emit della modifica al valore viene gestito su un evento custom (**inputChange**) come workaround al malfunzionamento dell'**ngModelChange** nativo
132
- *
133
- * @param {any} toEmit valore da propagare all'esterno
134
- */
135
- outputValue(toEmit) {
136
- let value = toEmit.value;
137
- let propagateValue;
138
- if (!value)
139
- propagateValue = null;
140
- else if (!this.useJsDates)
141
- propagateValue = value.format(this.lc.token("getSmallDateFormat") + " HH:mm:ss");
142
- else {
143
- if (value && value.isValid())
144
- propagateValue = value.toDate();
145
- else
146
- propagateValue = null;
147
- }
148
- this.propagateChange(propagateValue);
149
- this.inputChange.emit(propagateValue);
150
- this.onTouched();
151
- }
152
- /**
153
- * @ignore
154
- */
155
- registerOnChange(fn) {
156
- this.propagateChange = fn;
157
- }
158
- /**
159
- * @ignore
160
- */
161
- registerOnTouched(fn) {
162
- this.onTouched = fn;
163
- }
164
- }
165
- ValidationDateTimeComponent.decorators = [
166
- { type: Component, args: [{
167
- selector: "val-datetime",
168
- template: "<mat-form-field appearance=\"outline\" class=\"mat-full-width mat-no-border-top mat-height-fixed\" [style.width.px]=\"widthPx\">\r\n <mat-label *ngIf=\"placeholder\">{{placeholder}}</mat-label>\r\n\r\n <input matInput \r\n [ngxMatDatetimePicker]=\"datepicker\" \r\n #baseInput=\"ngModel\"\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 [(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)\"/>\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>{{validationFailed}}</span>\r\n </div>\r\n</ng-template>",
169
- encapsulation: ViewEncapsulation.None,
170
- changeDetection: ChangeDetectionStrategy.OnPush,
171
- providers: [
172
- { provide: LocalizationService, useClass: BaseValidationLoc },
173
- {
174
- provide: NG_VALUE_ACCESSOR,
175
- useExisting: forwardRef(() => ValidationDateTimeComponent),
176
- multi: true
177
- }
178
- ],
179
- 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:0em;top:-.2em;float:right;font-size:16px;font-weight:bold;color:inherit;text-shadow:0 1px 0 #fff;opacity:.5}.close-button:hover,.close-button:focus{text-decoration:none;cursor:pointer;opacity:.75}\n"]
180
- },] }
181
- ];
182
- ValidationDateTimeComponent.ctorParameters = () => [
183
- { type: ChangeDetectorRef },
184
- { type: Array, decorators: [{ type: Optional }, { type: Inject, args: [NG_VALIDATORS,] }] },
185
- { type: Array, decorators: [{ type: Optional }, { type: Inject, args: [NG_ASYNC_VALIDATORS,] }] },
186
- { type: Injector },
187
- { type: LocalizationService },
188
- { type: DateService }
189
- ];
190
- ValidationDateTimeComponent.propDecorators = {
191
- useJsDates: [{ type: Input }]
192
- };
193
- //# 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"],"names":[],"mappings":"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","sourcesContent":["// Angular\r\nimport { ControlValueAccessor, FormControl, 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: FormControl;\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(private 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();\r\n    }\r\n\r\n    /**\r\n     * @ignore\r\n     */\r\n    ngOnInit() {\r\n        // Controllo se è settato un required per decidere in maniera condizionale se utilizzare il validatore required nel componente interno\r\n        if (this._validators && !this.noValidate && this._validators.some(elem => elem instanceof RequiredValidator))\r\n            this.required = true;\r\n\r\n        this._format = this.lc.token(\"getSmallDateDisplayFormat\");\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 FormControl;\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}"]}
@@ -1,186 +0,0 @@
1
- // Angular
2
- import { NG_ASYNC_VALIDATORS, NG_VALIDATORS, NG_VALUE_ACCESSOR, NgControl, RequiredValidator } from "@angular/forms";
3
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, forwardRef, Inject, Injector, 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
- /**
10
- * Componente di validaizone per gli input a semplice casella di testo
11
- */
12
- export class ValidationInputComponent extends BaseValidation {
13
- /**
14
- * @ignore
15
- */
16
- constructor(cdr, _validators, _asyncValidators, injector, lc) {
17
- super();
18
- this.cdr = cdr;
19
- this._validators = _validators;
20
- this._asyncValidators = _asyncValidators;
21
- this.injector = injector;
22
- this.lc = lc;
23
- /**
24
- * Indica se questo Comopnente deve rappresentare un oggetto di Input di tipo "Password"
25
- */
26
- this.Password = false;
27
- /**
28
- * Indica se deve mostrare un indicazione di warning nel suffisso
29
- */
30
- this.showWarning = false;
31
- /**
32
- * Classe del warning eventualmente modificabile.
33
- *
34
- * Default: "fa fa-warning"
35
- */
36
- this.warningClass = "fa fa-warning";
37
- /**
38
- * Identifica se il testo di un componente di tipo "password" dev'essere visualizzato o meno
39
- */
40
- this.passShown = false;
41
- /**
42
- * Tipo del componente, può essere "text" o "password" e viene impostato automaticamente dall'Input **Password**
43
- */
44
- this.type = "text";
45
- /**
46
- * Indicazione se il componente ha o meno un suffisso.
47
- *
48
- * Valorizzato a **true** solo se viene trovata una proiezione su **suffix_internal** o se l'Input **showWarning** viene impostato a **true**
49
- */
50
- this.HasSuffix = false;
51
- /**
52
- * Indicazione se il componente ha o meno un prefisso.
53
- *
54
- * Valorizzato a **true** solo se viene trovata una proiezione su **prefix_internal**
55
- */
56
- this.HasPrefix = false;
57
- /**
58
- * @ignore
59
- */
60
- this.onTouched = () => { };
61
- }
62
- /**
63
- * @ignore
64
- */
65
- ngOnInit() {
66
- //controllo se è settato un required per decidere in maniera condizionale se utilizzare il validatore required nel componente interno
67
- if (this._validators && !this.noValidate && this._validators.some(elem => elem instanceof RequiredValidator))
68
- this.required = true;
69
- if (this.Password)
70
- this.type = "password";
71
- }
72
- /**
73
- * @ignore
74
- */
75
- ngOnDestroy() {
76
- if (this.tooltipSubscription)
77
- this.tooltipSubscription.unsubscribe();
78
- }
79
- /**
80
- * @ignore
81
- */
82
- ngAfterViewInit() {
83
- this.HasSuffix = !!this.suffix_internal || this.showWarning;
84
- this.HasPrefix = !!this.prefix_internal;
85
- this.postBinding();
86
- }
87
- /**
88
- * @ignore
89
- */
90
- ngOnChanges(changes) {
91
- const newShowWarnings = changes["showWarning"];
92
- if (newShowWarnings)
93
- this.HasSuffix = !!this.suffix_internal || this.showWarning;
94
- }
95
- /**
96
- * Metodo che si occupa di collegare i validatori e la funzione di reset dal **ControlValueAccessor** rappresentato
97
- * da questo componente al **ControlValueAccessor** rappresentato dall'effettivo elemento di Input presente lato HTML
98
- */
99
- postBinding() {
100
- this.CheckValidity();
101
- const ngControl = this.injector.get(NgControl, null);
102
- if (ngControl) {
103
- this.parentControl = ngControl.control;
104
- // Se la variabile novalidate è true, elimino tutti i validatori eventualmente inseriti
105
- if (this.noValidate) {
106
- this.parentControl.clearValidators();
107
- this.parentControl.clearAsyncValidators();
108
- }
109
- else {
110
- this.baseInput.control.setAsyncValidators(this._asyncValidators);
111
- this.baseInput.control.setValidators(this._validators);
112
- }
113
- // Faccio in modo che se chiamo il reset del controllo (o della form) dall'esterno si resetti anche il controllo nativo
114
- const origFunc = this.parentControl.reset;
115
- this.parentControl.reset = () => {
116
- origFunc.apply(this.parentControl);
117
- this.baseInput.control.reset();
118
- this.tooltip.hide();
119
- };
120
- }
121
- }
122
- /**
123
- * @ignore
124
- */
125
- writeValue(value) {
126
- this.value = value;
127
- this.propagateChange(value);
128
- this.cdr.markForCheck();
129
- }
130
- /**
131
- * L'emit della modifica al valore viene gestito su un evento custom (**inputChange**) come workaround al malfunzionamento dell'**ngModelChange** nativo
132
- *
133
- * @param {any} toEmit valore da propagare all'esterno
134
- */
135
- onModelChange(toEmit) {
136
- this.writeValue(toEmit);
137
- this.inputChange.emit(toEmit);
138
- this.onTouched();
139
- }
140
- /**
141
- * @ignore
142
- */
143
- registerOnChange(fn) {
144
- this.propagateChange = fn;
145
- }
146
- /**
147
- * @ignore
148
- */
149
- registerOnTouched(fn) {
150
- this.onTouched = fn;
151
- }
152
- }
153
- ValidationInputComponent.decorators = [
154
- { type: Component, args: [{
155
- selector: "val-input",
156
- template: "<mat-form-field appearance=\"outline\" class=\"mat-full-width mat-no-border-top mat-height-fixed\" [style.width.px]=\"widthPx\">\r\n <mat-label [class.app-margin-left-25]=\"HasPrefix\" *ngIf=\"placeholder\">{{placeholder}}</mat-label>\r\n <ng-container *ngIf=\"HasPrefix\">\r\n <ng-container *ngTemplateOutlet=\"prefix_internal\"></ng-container>\r\n </ng-container>\r\n\r\n <input matInput\r\n #baseInput='ngModel'\r\n type=\"{{type}}\"\r\n triggers=\"\"\r\n placement=\"top\"\r\n autocomplete=\"{{autocomplete}}\"\r\n name=\"val-input\"\r\n class=\"form-control {{class}}\"\r\n [class.app-margin-left-25]=\"HasPrefix\"\r\n [class.mat-input-with-suffix]=\"HasSuffix || Password || showWarning\"\r\n [(ngModel)]=\"value\"\r\n [class.checking-field]=\"!noValidate && !showWarning\"\r\n [tooltip]=\"tolTemplate\"\r\n [disabled]=\"readonly || disabled\"\r\n (ngModelChange)=\"onModelChange($event)\"\r\n (focus)=\"checkTooltip();\"\r\n (blur)=\"closeTooltip();\">\r\n <ng-container *ngIf=\"HasSuffix || Password || showWarning\">\r\n <ng-container *ngIf=\"!Password && !showWarning\">\r\n <ng-container *ngTemplateOutlet=\"suffix_internal\"></ng-container>\r\n </ng-container>\r\n\r\n <span class=\"form-input-suffix\" *ngIf=\"Password || showWarning\">\r\n <ng-container *ngIf=\"Password\" matSuffix>\r\n <a *ngIf=\"passShown\" class=\"fa fa-eye-slash app-fs-16 app-pointer\" (click)=\"type = 'password'; passShown = !passShown; $event.preventDefault()\"></a>\r\n <a *ngIf=\"!passShown\" class=\"fa fa-eye app-fs-16 app-pointer\" (click)=\"type = 'text'; passShown = !passShown; $event.preventDefault()\"></a>\r\n </ng-container>\r\n <ng-container *ngIf=\"showWarning\" matSuffix>\r\n <span title=\"{{warningTitle}}\" class=\"{{warningClass}} text-warning app-fs-16\"></span>\r\n </ng-container>\r\n </span>\r\n </ng-container>\r\n</mat-form-field>\r\n\r\n<ng-template #tolTemplate>\r\n <div (click)=\"closeTooltip()\">\r\n <span>{{validationFailed}}</span>\r\n </div>\r\n</ng-template>",
157
- changeDetection: ChangeDetectionStrategy.OnPush,
158
- providers: [
159
- { provide: LocalizationService, useClass: BaseValidationLoc },
160
- {
161
- provide: NG_VALUE_ACCESSOR,
162
- useExisting: forwardRef(() => ValidationInputComponent),
163
- multi: true
164
- }
165
- ],
166
- encapsulation: ViewEncapsulation.None,
167
- 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:0em;top:-.2em;float:right;font-size:16px;font-weight:bold;color:inherit;text-shadow:0 1px 0 #fff;opacity:.5}.close-button:hover,.close-button:focus{text-decoration:none;cursor:pointer;opacity:.75}\n"]
168
- },] }
169
- ];
170
- ValidationInputComponent.ctorParameters = () => [
171
- { type: ChangeDetectorRef },
172
- { type: Array, decorators: [{ type: Optional }, { type: Inject, args: [NG_VALIDATORS,] }] },
173
- { type: Array, decorators: [{ type: Optional }, { type: Inject, args: [NG_ASYNC_VALIDATORS,] }] },
174
- { type: Injector },
175
- { type: LocalizationService }
176
- ];
177
- ValidationInputComponent.propDecorators = {
178
- Password: [{ type: Input }],
179
- showWarning: [{ type: Input }],
180
- warningTitle: [{ type: Input }],
181
- warningClass: [{ type: Input }],
182
- value: [{ type: Input, args: ["value",] }],
183
- suffix_internal: [{ type: ContentChild, args: ["suffix_internal", { static: false },] }],
184
- prefix_internal: [{ type: ContentChild, args: ["prefix_internal", { static: false },] }]
185
- };
186
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validation-input.component.js","sourceRoot":"","sources":["../../../../../../projects/forms-and-validations/src/lib/validations/validation-input/validation-input.component.ts"],"names":[],"mappings":"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","sourcesContent":["// Angular\r\nimport { ControlValueAccessor, FormControl, NG_ASYNC_VALIDATORS, NG_VALIDATORS, NG_VALUE_ACCESSOR, NgControl, RequiredValidator } from \"@angular/forms\";\r\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, forwardRef, Inject, Injector, Input, Optional, SimpleChanges, 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 { Subscription } from \"rxjs\";\r\n\r\n/**\r\n * Componente di validaizone per gli input a semplice casella di testo\r\n */\r\n@Component({\r\n    selector: \"val-input\",\r\n    templateUrl: \"validation-input.component.html\",\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    providers: [\r\n        { provide: LocalizationService, useClass: BaseValidationLoc },\r\n        {\r\n            provide: NG_VALUE_ACCESSOR,\r\n            useExisting: forwardRef(() => ValidationInputComponent),\r\n            multi: true\r\n        }\r\n    ],\r\n    encapsulation: ViewEncapsulation.None,\r\n    styleUrls: [\"../validation-style.scss\"]\r\n})\r\nexport class ValidationInputComponent extends BaseValidation implements ControlValueAccessor {\r\n\r\n    /**\r\n     * Indica se questo Comopnente deve rappresentare un oggetto di Input di tipo \"Password\"\r\n     */\r\n    @Input() public Password: boolean = false;\r\n\r\n    /**\r\n     * Indica se deve mostrare un indicazione di warning nel suffisso\r\n     */\r\n    @Input() public showWarning: boolean = false;\r\n\r\n    /**\r\n     * Titolo del Warning da impostare se **showWarning** è impostato a **true**\r\n     */\r\n    @Input() public warningTitle: string;\r\n\r\n    /**\r\n     * Classe del warning eventualmente modificabile. \r\n     * \r\n     * Default: \"fa fa-warning\"\r\n     */\r\n    @Input() public warningClass: string = \"fa fa-warning\";\r\n\r\n    /**\r\n     * Valore del modello rappresentato da questo input\r\n     */\r\n    @Input(\"value\") public value: any;\r\n\r\n    /**\r\n     * Contiene la proiezione del suffisso qualora fosse fornita\r\n     */\r\n    @ContentChild(\"suffix_internal\", { static: false }) suffix_internal;\r\n\r\n    /**\r\n     * Contiene la proiezione del prefisso qualora fosse fornita\r\n     */\r\n    @ContentChild(\"prefix_internal\", { static: false }) prefix_internal;\r\n\r\n    /**\r\n     * Subscription del tooltip da ripulire al destroy del componente\r\n     */\r\n    private tooltipSubscription: Subscription;\r\n\r\n    /**\r\n     * Controllo esposto ottenuto tramite injector\r\n     */\r\n    private parentControl: FormControl;\r\n\r\n    /**\r\n     * Identifica se il testo di un componente di tipo \"password\" dev'essere visualizzato o meno\r\n     */\r\n    public passShown: boolean = false;\r\n\r\n    /**\r\n     * Tipo del componente, può essere \"text\" o \"password\" e viene impostato automaticamente dall'Input **Password**\r\n     */\r\n    public type: string = \"text\";\r\n\r\n    /**\r\n     * Indicazione se il componente ha o meno un suffisso. \r\n     * \r\n     * Valorizzato a **true** solo se viene trovata una proiezione su **suffix_internal** o se l'Input **showWarning** viene impostato a **true**\r\n     */\r\n    public HasSuffix: boolean = false;\r\n\r\n    /**\r\n     * Indicazione se il componente ha o meno un prefisso. \r\n     * \r\n     * Valorizzato a **true** solo se viene trovata una proiezione su **prefix_internal**\r\n     */\r\n    public HasPrefix: boolean = false;\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    constructor(private 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) {\r\n        super();\r\n    }\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    ngOnInit() {\r\n        //controllo se è settato un required per decidere in maniera condizionale se utilizzare il validatore required nel componente interno\r\n        if (this._validators && !this.noValidate && this._validators.some(elem => elem instanceof RequiredValidator))\r\n            this.required = true;\r\n\r\n        if (this.Password)\r\n            this.type = \"password\";\r\n    }\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    ngOnDestroy() {\r\n        if (this.tooltipSubscription) this.tooltipSubscription.unsubscribe();\r\n    }\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    ngAfterViewInit() {\r\n        this.HasSuffix = !!this.suffix_internal || this.showWarning;\r\n        this.HasPrefix = !!this.prefix_internal;\r\n\r\n        this.postBinding();\r\n    }\r\n\r\n    /**\r\n     * @ignore\r\n     */\r\n    ngOnChanges(changes: SimpleChanges) {\r\n        const newShowWarnings = changes[\"showWarning\"];\r\n        if (newShowWarnings)\r\n            this.HasSuffix = !!this.suffix_internal || this.showWarning;\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 FormControl;\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        this.value = value;\r\n        this.propagateChange(value);\r\n        this.cdr.markForCheck();\r\n    }\r\n\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    onModelChange(toEmit) {\r\n        this.writeValue(toEmit);\r\n        this.inputChange.emit(toEmit);\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}"]}
@@ -1,166 +0,0 @@
1
- // Angular
2
- import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, forwardRef, Inject, Injector, Input, Optional, Output, ViewEncapsulation } from "@angular/core";
3
- import { NG_ASYNC_VALIDATORS, NG_VALIDATORS, NG_VALUE_ACCESSOR, NgControl, RequiredValidator } from "@angular/forms";
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
- /**
10
- * Componente di validaizone per gli input a selezione singola
11
- */
12
- export class ValidationSelectComponent extends BaseValidation {
13
- /**
14
- * @ignore
15
- */
16
- constructor(_validators, _asyncValidators, injector, cdr, lc) {
17
- super();
18
- this._validators = _validators;
19
- this._asyncValidators = _asyncValidators;
20
- this.injector = injector;
21
- this.cdr = cdr;
22
- this.lc = lc;
23
- /**
24
- * valore del campo vuoto della select
25
- */
26
- this.emptyFieldValue = "-2";
27
- /**
28
- * Valore del placeholder
29
- */
30
- this.placeHolderValue = "-1";
31
- /**
32
- * Per i componenti non obbligatori indica se fornire un "valore vuoto"
33
- */
34
- this.emptyValue = true;
35
- /**
36
- * Indica se mostrare o nascondere il simboletto di validazione (Tic verde o Croce rossa)
37
- */
38
- this.showValidationSymbol = true;
39
- /**
40
- * Contenuto della label Floattante Material-Style
41
- */
42
- this.label = "";
43
- /**
44
- * Evento richiamato quando si perde il focus sull'input di inserimento
45
- */
46
- this.onBlur = new EventEmitter();
47
- /**
48
- * @ignore
49
- */
50
- this.onTouched = () => { }; //placeholder on touched function
51
- }
52
- /**
53
- * @ignore
54
- */
55
- ngOnInit() {
56
- //controllo se è settato un required per decidere in maniera condizionale se utilizzare il validatore required nel componente interno
57
- //Lo imposto ANCHE se sono in situazione di noValidate perché comporta eventuali modifiche grafiche che potrebbero servirmi, ma comunque non va a d aggiungere
58
- //validatori o cose strane, quindi GG
59
- if (this._validators && this._validators.some(elem => elem instanceof RequiredValidator && elem.required))
60
- this.required = true;
61
- }
62
- /**
63
- * @ignore
64
- */
65
- ngOnDestroy() {
66
- if (this.tooltipSubscription)
67
- this.tooltipSubscription.unsubscribe();
68
- }
69
- /**
70
- * @ignore
71
- */
72
- ngAfterViewInit() {
73
- this.postBinding();
74
- }
75
- /**
76
- * Metodo che si occupa di collegare i validatori e la funzione di reset dal **ControlValueAccessor** rappresentato
77
- * da questo componente al **ControlValueAccessor** rappresentato dall'effettivo elemento di Input presente lato HTML
78
- */
79
- postBinding() {
80
- // Eredito i validatori
81
- if (!this.noValidate) {
82
- this.baseInput.control.setAsyncValidators(this._asyncValidators);
83
- this.baseInput.control.setValidators(this._validators);
84
- }
85
- this.CheckValidity();
86
- const ngControl = this.injector.get(NgControl, null);
87
- if (ngControl) {
88
- this.parentControl = ngControl.control;
89
- // se la variabile novalidate è true, elimino tutti i validatori eventualmente inseriti
90
- if (this.noValidate) {
91
- this.parentControl.clearValidators();
92
- this.parentControl.clearAsyncValidators();
93
- }
94
- // faccio in modo che se chiamo il reset del controllo (o della form) dall'esterno si resetti anche il controllo nativo
95
- const origFunc = this.parentControl.reset;
96
- this.parentControl.reset = () => {
97
- origFunc.apply(this.parentControl);
98
- this.baseInput.control.reset();
99
- this.tooltip.hide();
100
- };
101
- }
102
- }
103
- /**
104
- * @ignore
105
- */
106
- writeValue(value) {
107
- this.value = value;
108
- this.propagateChange(value);
109
- this.cdr.markForCheck();
110
- }
111
- /**
112
- * L'emit della modifica al valore viene gestito su un evento custom (**inputChange**) come workaround al malfunzionamento dell'**ngModelChange** nativo
113
- *
114
- * @param {any} toEmit valore da propagare all'esterno
115
- */
116
- onModelChange(toEmit) {
117
- this.writeValue(toEmit);
118
- this.inputChange.emit(toEmit);
119
- this.onTouched();
120
- }
121
- /**
122
- * @ignore
123
- */
124
- registerOnChange(fn) {
125
- this.propagateChange = fn;
126
- }
127
- /**
128
- * @ignore
129
- */
130
- registerOnTouched(fn) {
131
- this.onTouched = fn;
132
- }
133
- }
134
- ValidationSelectComponent.decorators = [
135
- { type: Component, args: [{
136
- selector: "val-select",
137
- template: "<mat-form-field appearance=\"outline\" class=\"mat-full-width mat-no-border-top mat-height-fixed\" [style.width.px]=\"widthPx\">\r\n <mat-label *ngIf=\"label\">{{label}}</mat-label>\r\n <select matNativeControl\r\n #baseInput=\"ngModel\"\r\n name=\"val-select\"\r\n class=\"form-control\"\r\n triggers=\"\"\r\n placement=\"top\"\r\n [customRequired]=\"required ? 'true' : 'false'\"\r\n [CustomNullValues]=\"[placeHolderValue,emptyFieldValue]\"\r\n [(ngModel)]=\"value\"\r\n [tooltip]=\"tolTemplate\"\r\n [class.checking-combo]=\"!noValidate\"\r\n [class.app-option-placeholder]=\"baseInput.value === placeHolderValue\"\r\n [class.no-bg-img]=\"!showValidationSymbol\"\r\n [disabled]=\"readonly\"\r\n (focus)=\"checkTooltip()\"\r\n (blur)=\"closeTooltip(); onBlur.emit(true);\"\r\n (ngModelChange)=\"onModelChange($event)\">\r\n\r\n <option *ngIf=\"placeholder\" [value]=\"placeHolderValue\" disabled selected hidden>{{placeholder}}</option>\r\n <option *ngIf=\"required == false && emptyValue\" [value]=\"emptyFieldValue\"></option>\r\n <ng-content></ng-content>\r\n </select>\r\n</mat-form-field>\r\n\r\n<ng-template #tolTemplate>\r\n <div (click)=\"closeTooltip()\">\r\n <span>{{validationFailed}}</span>\r\n </div>\r\n</ng-template>",
138
- encapsulation: ViewEncapsulation.None,
139
- changeDetection: ChangeDetectionStrategy.OnPush,
140
- providers: [
141
- { provide: LocalizationService, useClass: BaseValidationLoc },
142
- {
143
- provide: NG_VALUE_ACCESSOR,
144
- useExisting: forwardRef(() => ValidationSelectComponent),
145
- multi: true
146
- }
147
- ],
148
- 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:0em;top:-.2em;float:right;font-size:16px;font-weight:bold;color:inherit;text-shadow:0 1px 0 #fff;opacity:.5}.close-button:hover,.close-button:focus{text-decoration:none;cursor:pointer;opacity:.75}\n"]
149
- },] }
150
- ];
151
- ValidationSelectComponent.ctorParameters = () => [
152
- { type: Array, decorators: [{ type: Optional }, { type: Inject, args: [NG_VALIDATORS,] }] },
153
- { type: Array, decorators: [{ type: Optional }, { type: Inject, args: [NG_ASYNC_VALIDATORS,] }] },
154
- { type: Injector },
155
- { type: ChangeDetectorRef },
156
- { type: LocalizationService }
157
- ];
158
- ValidationSelectComponent.propDecorators = {
159
- emptyFieldValue: [{ type: Input }],
160
- placeHolderValue: [{ type: Input }],
161
- emptyValue: [{ type: Input }],
162
- showValidationSymbol: [{ type: Input }],
163
- label: [{ type: Input }],
164
- onBlur: [{ type: Output }]
165
- };
166
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validation-select.component.js","sourceRoot":"","sources":["../../../../../../projects/forms-and-validations/src/lib/validations/validation-select/validation-select.component.ts"],"names":[],"mappings":"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","sourcesContent":["// Angular\r\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, forwardRef, Inject, Injector, Input, Optional, Output, ViewChild, ViewEncapsulation } from \"@angular/core\";\r\nimport { ControlValueAccessor, FormControl, NG_ASYNC_VALIDATORS, NG_VALIDATORS, NG_VALUE_ACCESSOR, NgControl, RequiredValidator } from \"@angular/forms\";\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\n\r\nimport { Subscription } from \"rxjs\";\r\n\r\n/**\r\n * Componente di validaizone per gli input a selezione singola\r\n */\r\n@Component({\r\n    selector: \"val-select\",\r\n    templateUrl: \"validation-select.component.html\",\r\n    encapsulation: ViewEncapsulation.None,\r\n    styleUrls: [\"../validation-style.scss\"],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    providers: [\r\n        { provide: LocalizationService, useClass: BaseValidationLoc },\r\n        {\r\n            provide: NG_VALUE_ACCESSOR,\r\n            useExisting: forwardRef(() => ValidationSelectComponent),\r\n            multi: true\r\n        }\r\n    ]\r\n})\r\nexport class ValidationSelectComponent extends BaseValidation implements ControlValueAccessor {\r\n    \r\n    /**\r\n     * valore del campo vuoto della select\r\n     */\r\n    @Input() public emptyFieldValue = \"-2\";\r\n    \r\n    /**\r\n     * Valore del placeholder\r\n     */\r\n    @Input() public placeHolderValue = \"-1\";\r\n    \r\n    /**\r\n     * Per i componenti non obbligatori indica se fornire un \"valore vuoto\"\r\n     */\r\n    @Input() public emptyValue = true;\r\n\r\n    /**\r\n     * Indica se mostrare o nascondere il simboletto di validazione (Tic verde o Croce rossa)\r\n     */\r\n    @Input() public showValidationSymbol: boolean = true;\r\n\r\n    /**\r\n     * Contenuto della label Floattante Material-Style\r\n     */\r\n    @Input() public label: string = \"\";\r\n\r\n    /**\r\n     * Evento richiamato quando si perde il focus sull'input di inserimento\r\n     */\r\n    @Output() public onBlur: EventEmitter<boolean> = new EventEmitter<boolean>();\r\n\r\n    /**\r\n     * Controllo esposto ottenuto tramite injector\r\n     */\r\n    public parentControl: FormControl;\r\n\r\n    /**\r\n     * Valore del modello rappresentato dal componente\r\n     */\r\n    public value: string;\r\n\r\n    /**\r\n     * Subscription del tootltip da ripulire alla distruzione del componente\r\n     */\r\n    private tooltipSubscription: Subscription;\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    constructor(@Optional() @Inject(NG_VALIDATORS) private _validators: Array<any>, @Optional() @Inject(NG_ASYNC_VALIDATORS) private _asyncValidators: Array<any>, private injector: Injector, private cdr: ChangeDetectorRef, protected lc: LocalizationService) {\r\n        super();\r\n    }\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    ngOnInit() {\r\n        //controllo se è settato un required per decidere in maniera condizionale se utilizzare il validatore required nel componente interno\r\n        //Lo imposto ANCHE se sono in situazione di noValidate perché comporta eventuali modifiche grafiche che potrebbero servirmi, ma comunque non va a d aggiungere\r\n        //validatori o cose strane, quindi GG\r\n        if (this._validators && this._validators.some(elem => elem instanceof RequiredValidator && elem.required))\r\n            this.required = true;\r\n    }\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    ngOnDestroy() {\r\n        if (this.tooltipSubscription) this.tooltipSubscription.unsubscribe();\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        // Eredito i validatori\r\n        if (!this.noValidate) {\r\n            this.baseInput.control.setAsyncValidators(this._asyncValidators);\r\n            this.baseInput.control.setValidators(this._validators);\r\n        }\r\n\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 FormControl;\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\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 = () => { }; //placeholder on touched function\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    writeValue(value: any): void {\r\n        this.value = value;\r\n        this.propagateChange(value);\r\n        this.cdr.markForCheck();\r\n    }\r\n\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    onModelChange(toEmit) {\r\n        this.writeValue(toEmit);\r\n        this.inputChange.emit(toEmit);\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}"]}