@esfaenza/forms-and-validations 16.2.31 → 17.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/esfaenza-forms-and-validations.mjs +4 -4
- package/esm2022/lib/forms/base-form-control.mjs +558 -558
- package/esm2022/lib/forms/form-adaptive/form-adaptive.component.loc.mjs +21 -21
- package/esm2022/lib/forms/form-adaptive/form-adaptive.component.mjs +420 -420
- package/esm2022/lib/forms/form-autocomplete/form-autocomplete.component.loc.mjs +20 -20
- package/esm2022/lib/forms/form-autocomplete/form-autocomplete.component.mjs +289 -289
- package/esm2022/lib/forms/form-checkbox/form-checkbox.component.mjs +74 -74
- package/esm2022/lib/forms/form-date/form-date.component.mjs +69 -69
- package/esm2022/lib/forms/form-datetime/form-datetime.component.mjs +67 -67
- package/esm2022/lib/forms/form-empty/form-empty.component.mjs +29 -29
- package/esm2022/lib/forms/form-error/form-error.component.mjs +41 -41
- package/esm2022/lib/forms/form-file/form-file.component.loc.mjs +21 -21
- package/esm2022/lib/forms/form-file/form-file.component.mjs +175 -175
- package/esm2022/lib/forms/form-info/form-info.component.mjs +41 -41
- package/esm2022/lib/forms/form-input/form-input.component.mjs +83 -83
- package/esm2022/lib/forms/form-multiselect/form-multiselect.component.loc.mjs +22 -22
- package/esm2022/lib/forms/form-multiselect/form-multiselect.component.mjs +163 -163
- package/esm2022/lib/forms/form-select/form-select.component.loc.mjs +20 -20
- package/esm2022/lib/forms/form-select/form-select.component.mjs +165 -165
- package/esm2022/lib/forms/form-template/form-template.component.mjs +76 -76
- package/esm2022/lib/forms/form-textarea/form-textarea.component.mjs +57 -57
- package/esm2022/lib/forms/form-time/form-time.component.mjs +115 -115
- package/esm2022/lib/forms-and-validations.module.mjs +199 -199
- package/esm2022/lib/models/AppFile.mjs +13 -13
- package/esm2022/lib/models/ChangeEvent.mjs +6 -6
- package/esm2022/lib/models/FormsAndValidationsModuleConfig.mjs +5 -5
- package/esm2022/lib/models/dayjs-adapter/dayjs-date-adapter.mjs +89 -89
- package/esm2022/lib/tokens.mjs +7 -7
- package/esm2022/lib/validations/base-validation.loc.mjs +22 -22
- package/esm2022/lib/validations/base-validation.mjs +328 -328
- package/esm2022/lib/validations/customValidators/CustomRequiredDirective.mjs +40 -40
- package/esm2022/lib/validations/validation-autocomplete/validation-autocomplete.component.mjs +147 -147
- package/esm2022/lib/validations/validation-autocomplete-multi/validation-autocomplete-multi.component.mjs +240 -240
- package/esm2022/lib/validations/validation-currency/validation-currency.component.mjs +75 -75
- package/esm2022/lib/validations/validation-date/validation-date.component.mjs +183 -183
- package/esm2022/lib/validations/validation-datetime/validation-datetime.component.mjs +212 -212
- package/esm2022/lib/validations/validation-input/validation-input.component.mjs +222 -222
- package/esm2022/lib/validations/validation-select/validation-select.component.mjs +183 -183
- package/esm2022/lib/validations/validation-text-area/validation-text-area.component.mjs +78 -78
- package/esm2022/public-api.mjs +39 -39
- package/fesm2022/esfaenza-forms-and-validations.mjs +4152 -4152
- package/fesm2022/esfaenza-forms-and-validations.mjs.map +1 -1
- package/index.d.ts +5 -5
- package/lib/forms/base-form-control.d.ts +276 -276
- package/lib/forms/form-adaptive/form-adaptive.component.d.ts +126 -126
- package/lib/forms/form-adaptive/form-adaptive.component.loc.d.ts +14 -14
- package/lib/forms/form-autocomplete/form-autocomplete.component.d.ts +84 -84
- package/lib/forms/form-autocomplete/form-autocomplete.component.loc.d.ts +14 -14
- package/lib/forms/form-checkbox/form-checkbox.component.d.ts +23 -23
- package/lib/forms/form-date/form-date.component.d.ts +21 -21
- package/lib/forms/form-datetime/form-datetime.component.d.ts +23 -23
- package/lib/forms/form-empty/form-empty.component.d.ts +15 -15
- package/lib/forms/form-error/form-error.component.d.ts +19 -19
- package/lib/forms/form-file/form-file.component.d.ts +46 -46
- package/lib/forms/form-file/form-file.component.loc.d.ts +14 -14
- package/lib/forms/form-info/form-info.component.d.ts +19 -19
- package/lib/forms/form-input/form-input.component.d.ts +33 -33
- package/lib/forms/form-multiselect/form-multiselect.component.d.ts +67 -67
- package/lib/forms/form-multiselect/form-multiselect.component.loc.d.ts +14 -14
- package/lib/forms/form-select/form-select.component.d.ts +43 -43
- package/lib/forms/form-select/form-select.component.loc.d.ts +14 -14
- package/lib/forms/form-template/form-template.component.d.ts +38 -38
- package/lib/forms/form-textarea/form-textarea.component.d.ts +18 -18
- package/lib/forms/form-time/form-time.component.d.ts +40 -40
- package/lib/forms-and-validations.module.d.ts +47 -47
- package/lib/models/AppFile.d.ts +21 -21
- package/lib/models/ChangeEvent.d.ts +5 -5
- package/lib/models/FormsAndValidationsModuleConfig.d.ts +11 -11
- package/lib/models/dayjs-adapter/dayjs-date-adapter.d.ts +49 -49
- package/lib/tokens.d.ts +7 -7
- package/lib/validations/base-validation.d.ts +219 -219
- package/lib/validations/base-validation.loc.d.ts +14 -14
- package/lib/validations/customValidators/CustomRequiredDirective.d.ts +24 -24
- package/lib/validations/validation-autocomplete/validation-autocomplete.component.d.ts +58 -58
- package/lib/validations/validation-autocomplete-multi/validation-autocomplete-multi.component.d.ts +88 -88
- package/lib/validations/validation-currency/validation-currency.component.d.ts +28 -28
- package/lib/validations/validation-date/validation-date.component.d.ts +79 -79
- package/lib/validations/validation-datetime/validation-datetime.component.d.ts +109 -109
- package/lib/validations/validation-input/validation-input.component.d.ts +134 -134
- package/lib/validations/validation-select/validation-select.component.d.ts +95 -95
- package/lib/validations/validation-text-area/validation-text-area.component.d.ts +28 -28
- package/package.json +13 -13
- package/public-api.d.ts +31 -31
|
@@ -1,328 +1,328 @@
|
|
|
1
|
-
// Angular
|
|
2
|
-
import { EventEmitter, Input, Output, ViewChild, Directive } from "@angular/core";
|
|
3
|
-
import { RequiredValidator } from "@angular/forms";
|
|
4
|
-
// Direttive, Componenti, Librerie
|
|
5
|
-
import { TooltipDirective } from "ngx-bootstrap/tooltip";
|
|
6
|
-
import { Subject } from "rxjs";
|
|
7
|
-
import { takeUntil } from "rxjs/operators";
|
|
8
|
-
import * as i0 from "@angular/core";
|
|
9
|
-
/**
|
|
10
|
-
* Classe astratta base che contiene le logiche / proprietà in comune a tutti i validatori
|
|
11
|
-
*
|
|
12
|
-
* Nota bene: I tooltip rallentano tantissimo la pagina perché il tizio che ha fatto ngx bootstrap non è capace
|
|
13
|
-
*/
|
|
14
|
-
export class BaseValidation {
|
|
15
|
-
/** @ignore Constructor */
|
|
16
|
-
constructor(cdr) {
|
|
17
|
-
this.cdr = cdr;
|
|
18
|
-
/**
|
|
19
|
-
* Variabile per tenere in memoria il fatto che il componente è forzato a invalido o no
|
|
20
|
-
*/
|
|
21
|
-
this._forceInvalid = false;
|
|
22
|
-
/**
|
|
23
|
-
* Indica se il valore è obbligatorio o opzionale
|
|
24
|
-
*/
|
|
25
|
-
this.required = false;
|
|
26
|
-
/**
|
|
27
|
-
* Indica se di default deve valutare il messaggio di errore in base al validatore che fallisce.
|
|
28
|
-
*
|
|
29
|
-
* Se fallisce il required validator scriverà che l'input è obbligatorio, se invece fallisce
|
|
30
|
-
* un eventuale pattern validator scriverà che il formato dell'input è invalido
|
|
31
|
-
*/
|
|
32
|
-
this.InferErrorMessages = true;
|
|
33
|
-
/**
|
|
34
|
-
* Modalità in cui viene mostrato il campo, 1-1 rispetto alle definizioni di Angular Material
|
|
35
|
-
*/
|
|
36
|
-
this.FieldAppearence = "outline";
|
|
37
|
-
/**
|
|
38
|
-
* Indica se il **Placeholder** dev'essere usato come una floating label di material o solo come un placeholder standard
|
|
39
|
-
*
|
|
40
|
-
* Ignorata lato autocomplete, autocomplete-multi e select in quanto hanno gestioni particolari di placeholder ecc...
|
|
41
|
-
*/
|
|
42
|
-
this.FloatingLabel = true;
|
|
43
|
-
/**
|
|
44
|
-
* Messaggio da mostrare se la validazione fallisce.
|
|
45
|
-
*
|
|
46
|
-
* Se questo è valorizzato, il messaggio non viene valutato in automatico nonstante **InferErrorMessages** sia **true**
|
|
47
|
-
*/
|
|
48
|
-
this.validationFailed = "";
|
|
49
|
-
/**
|
|
50
|
-
* Indica se il componente è in sola lettura
|
|
51
|
-
*/
|
|
52
|
-
this.Readonly = false;
|
|
53
|
-
/**
|
|
54
|
-
* Indica le dimensioni del componente
|
|
55
|
-
*/
|
|
56
|
-
this.widthPx = null;
|
|
57
|
-
/**
|
|
58
|
-
* Indica se il componente è disabilitato o no (più o meno stesso concetto del readonly)
|
|
59
|
-
*/
|
|
60
|
-
this.disabled = false;
|
|
61
|
-
/**
|
|
62
|
-
* Eventuale placeholder da mostrare al posto del valore quando il valore è nullo / vuoto
|
|
63
|
-
*/
|
|
64
|
-
this.placeholder = "";
|
|
65
|
-
/**
|
|
66
|
-
* Classi da applicare al componente
|
|
67
|
-
*/
|
|
68
|
-
this.class = "";
|
|
69
|
-
/**
|
|
70
|
-
* Stili da applicare al componente
|
|
71
|
-
*/
|
|
72
|
-
this.style = "";
|
|
73
|
-
/**
|
|
74
|
-
* Pattern di validazione dell'input
|
|
75
|
-
*/
|
|
76
|
-
this.pattern = "";
|
|
77
|
-
/**
|
|
78
|
-
* Indica di non validare il componente
|
|
79
|
-
*/
|
|
80
|
-
this.noValidate = false;
|
|
81
|
-
/**
|
|
82
|
-
* Indica se abilitare o meno l'autocompletamento di default del browser
|
|
83
|
-
*/
|
|
84
|
-
this.autocomplete = "off";
|
|
85
|
-
/**
|
|
86
|
-
* Id dell'input. È importante impostarlo soprattutto se l'interfaccia generata dev'essere testata
|
|
87
|
-
*/
|
|
88
|
-
this.id = "";
|
|
89
|
-
/**
|
|
90
|
-
* Evento che sostituisce l'ngModelChange facendolo funzionare in maniera un po' più consistente
|
|
91
|
-
*/
|
|
92
|
-
this.inputChange = new EventEmitter();
|
|
93
|
-
/**
|
|
94
|
-
* Evento che indica il focus avvenuto su un controllo
|
|
95
|
-
*/
|
|
96
|
-
this.inputFocus = new EventEmitter();
|
|
97
|
-
/**
|
|
98
|
-
* Evento che indica la finalizzazione del valore avvenuta su un controllo
|
|
99
|
-
*/
|
|
100
|
-
this.inputFinalized = new EventEmitter();
|
|
101
|
-
this.destroyed$ = new Subject();
|
|
102
|
-
/**
|
|
103
|
-
* @ignore
|
|
104
|
-
*/
|
|
105
|
-
this.propagateChange = (_) => { };
|
|
106
|
-
}
|
|
107
|
-
/**
|
|
108
|
-
* Query che raccoglie il tooltip in maniera dinamica (ad ogni change detection)
|
|
109
|
-
*
|
|
110
|
-
* @param {TooltipDirective} comp Elemento HTML a cui è applicata la direttiva del tooltip
|
|
111
|
-
*/
|
|
112
|
-
set tooltip_static(comp) {
|
|
113
|
-
if (comp) {
|
|
114
|
-
this.tooltip = comp;
|
|
115
|
-
}
|
|
116
|
-
}
|
|
117
|
-
;
|
|
118
|
-
/**
|
|
119
|
-
* Query che raccoglie l'input o direttiva che contiene il valore in maniera dinamica (ad ogni change detection)
|
|
120
|
-
*
|
|
121
|
-
* @param {NgModel} comp Elemento HTML associato al ngModel del componente
|
|
122
|
-
*/
|
|
123
|
-
set baseInput_static(comp) {
|
|
124
|
-
if (comp) {
|
|
125
|
-
this.baseInput = comp;
|
|
126
|
-
}
|
|
127
|
-
}
|
|
128
|
-
;
|
|
129
|
-
/**
|
|
130
|
-
* Imposta il componente come "submitted" scatenandone le validazioni ed eventualmente la visualizzazione del tooltip di errore
|
|
131
|
-
*
|
|
132
|
-
* @param {boolean} val **true** se si vuole impostare questo controllo come submitted, **false** altrimenti
|
|
133
|
-
*/
|
|
134
|
-
set submitted(val) {
|
|
135
|
-
this._submitted = val;
|
|
136
|
-
if (!this.baseInput)
|
|
137
|
-
return;
|
|
138
|
-
if (val)
|
|
139
|
-
this.baseInput.control.markAsTouched();
|
|
140
|
-
if (this.baseInput.control.status === "INVALID" && val)
|
|
141
|
-
this.showTooltipWithMessage();
|
|
142
|
-
else
|
|
143
|
-
this.tooltip.hide();
|
|
144
|
-
}
|
|
145
|
-
/**
|
|
146
|
-
* Imposta il componente come "invalid" a prescindere dai validatori
|
|
147
|
-
*/
|
|
148
|
-
set forceInvalid(val) {
|
|
149
|
-
this._forceInvalid = val;
|
|
150
|
-
if (val)
|
|
151
|
-
setTimeout(() => {
|
|
152
|
-
this.baseInput.control.setErrors({ forcedtoinvalid: true });
|
|
153
|
-
this.baseInput.control.markAsTouched();
|
|
154
|
-
this.baseInput.control.markAsDirty();
|
|
155
|
-
this.cdr.detectChanges();
|
|
156
|
-
});
|
|
157
|
-
else
|
|
158
|
-
setTimeout(() => {
|
|
159
|
-
this.baseInput.control.setErrors({ forcedtoinvalid: null });
|
|
160
|
-
this.baseInput.control.updateValueAndValidity();
|
|
161
|
-
});
|
|
162
|
-
}
|
|
163
|
-
ngOnInit() {
|
|
164
|
-
if (this.SetValidationSubject) {
|
|
165
|
-
this.SetValidationSubject.pipe(takeUntil(this.destroyed$)).subscribe(v => {
|
|
166
|
-
if (v.fieldName + "_internal" == this.id) {
|
|
167
|
-
this.forceInvalid = true;
|
|
168
|
-
this.showTooltipWithMessage(v.error);
|
|
169
|
-
}
|
|
170
|
-
});
|
|
171
|
-
}
|
|
172
|
-
}
|
|
173
|
-
checkRequiredness(_validators) {
|
|
174
|
-
if (_validators && _validators.some(elem => elem instanceof RequiredValidator && (elem.required === true || (!elem.required && elem.required !== false))))
|
|
175
|
-
this.required = true;
|
|
176
|
-
}
|
|
177
|
-
ngOnDestroy() {
|
|
178
|
-
this.destroyed$.next();
|
|
179
|
-
this.destroyed$.complete();
|
|
180
|
-
}
|
|
181
|
-
/**
|
|
182
|
-
* Helper che controlla se il tooltip deve essere mostrato o meno,
|
|
183
|
-
* richiamato direttamente dall'HTML dei componenti
|
|
184
|
-
*/
|
|
185
|
-
checkTooltip() {
|
|
186
|
-
if ((this.baseInput.invalid && this.baseInput.touched))
|
|
187
|
-
this.showTooltipWithMessage();
|
|
188
|
-
}
|
|
189
|
-
/**
|
|
190
|
-
* Helper che calcola il messaggio da mostrare nel tooltip che andrà ad aprire
|
|
191
|
-
*/
|
|
192
|
-
showTooltipWithMessage(messageOverride = null) {
|
|
193
|
-
// Aggiorno il messaggio di validazione solo se il valore è diverso dall'ultimo valore ricevuto
|
|
194
|
-
if (this.valueOnLastValidation != this.baseInput.value) {
|
|
195
|
-
this.validationFailedBind = messageOverride || this.validationFailed || (this.InferErrorMessages ? this.inferMessage() : "");
|
|
196
|
-
this.valueOnLastValidation = this.baseInput.value;
|
|
197
|
-
}
|
|
198
|
-
if (this.validationFailedBind)
|
|
199
|
-
this.tooltip.show();
|
|
200
|
-
}
|
|
201
|
-
/**
|
|
202
|
-
* Calcola il messaggio da mostrare in base al valore.
|
|
203
|
-
*
|
|
204
|
-
* Entrare in questa funzione significa che lo stato di validazione è fallito, per questo si comporta semplicemente in maniera esclusiva, e cioè:
|
|
205
|
-
*
|
|
206
|
-
* 1) Se ero required e sono senza valore --> Input richiesto
|
|
207
|
-
*
|
|
208
|
-
* 2) Altrimenti se ho un valore --> Di sicuro il formato è errato
|
|
209
|
-
*/
|
|
210
|
-
inferMessage() {
|
|
211
|
-
if (this.required && !this.baseInput.value)
|
|
212
|
-
return this.lc.loc("Required Input");
|
|
213
|
-
if (this.baseInput.value)
|
|
214
|
-
return this.lc.loc("Invalid Input Format");
|
|
215
|
-
}
|
|
216
|
-
/**
|
|
217
|
-
* Forza la chiusura del tooltip
|
|
218
|
-
*/
|
|
219
|
-
closeTooltip() {
|
|
220
|
-
this.tooltip.hide();
|
|
221
|
-
}
|
|
222
|
-
/**
|
|
223
|
-
* Controlla se il controllo è valido e in caso lo sia chiude il tooltip
|
|
224
|
-
*/
|
|
225
|
-
CheckValidity() {
|
|
226
|
-
if (!this.baseInput.statusChanges)
|
|
227
|
-
return;
|
|
228
|
-
this.baseInput.statusChanges.subscribe(event => {
|
|
229
|
-
if (event === "VALID")
|
|
230
|
-
this.tooltip.hide();
|
|
231
|
-
});
|
|
232
|
-
}
|
|
233
|
-
/**
|
|
234
|
-
* L'emit del focus dell'elemento
|
|
235
|
-
*
|
|
236
|
-
* @param {any} toEmit valore da propagare all'esterno
|
|
237
|
-
*/
|
|
238
|
-
onFocus(toEmit) {
|
|
239
|
-
this.inputFocus.emit(toEmit);
|
|
240
|
-
}
|
|
241
|
-
/**
|
|
242
|
-
* Finalizzazione Input
|
|
243
|
-
*/
|
|
244
|
-
onFinalize() {
|
|
245
|
-
this.inputFinalized.emit();
|
|
246
|
-
}
|
|
247
|
-
/**
|
|
248
|
-
* Registra il Subject per ricevere le richieste di Focus dall'esterno
|
|
249
|
-
*/
|
|
250
|
-
registerFocusRequest() {
|
|
251
|
-
if (!this.FocusSubject)
|
|
252
|
-
return;
|
|
253
|
-
this.observable = this.FocusSubject.subscribe(t => {
|
|
254
|
-
this.htmlInput.nativeElement.focus();
|
|
255
|
-
});
|
|
256
|
-
}
|
|
257
|
-
/**
|
|
258
|
-
* Deregistra il Subject delle richieste di focus
|
|
259
|
-
*/
|
|
260
|
-
deregisterFocusRequest() {
|
|
261
|
-
if (this.observable)
|
|
262
|
-
this.observable.unsubscribe();
|
|
263
|
-
}
|
|
264
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
265
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "
|
|
266
|
-
}
|
|
267
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
268
|
-
type: Directive
|
|
269
|
-
}], ctorParameters:
|
|
270
|
-
type: ViewChild,
|
|
271
|
-
args: [TooltipDirective, { static: false }]
|
|
272
|
-
}], tooltip_static: [{
|
|
273
|
-
type: ViewChild,
|
|
274
|
-
args: [TooltipDirective, { static: true }]
|
|
275
|
-
}], htmlInput: [{
|
|
276
|
-
type: ViewChild,
|
|
277
|
-
args: ['htmlInput', { static: false }]
|
|
278
|
-
}], baseInput: [{
|
|
279
|
-
type: ViewChild,
|
|
280
|
-
args: ["baseInput", { static: false }]
|
|
281
|
-
}], baseInput_static: [{
|
|
282
|
-
type: ViewChild,
|
|
283
|
-
args: ["baseInput", { static: true }]
|
|
284
|
-
}], FocusSubject: [{
|
|
285
|
-
type: Input
|
|
286
|
-
}], SetValidationSubject: [{
|
|
287
|
-
type: Input
|
|
288
|
-
}], InferErrorMessages: [{
|
|
289
|
-
type: Input
|
|
290
|
-
}], FieldAppearence: [{
|
|
291
|
-
type: Input
|
|
292
|
-
}], FloatingLabel: [{
|
|
293
|
-
type: Input
|
|
294
|
-
}], validationFailed: [{
|
|
295
|
-
type: Input
|
|
296
|
-
}], Readonly: [{
|
|
297
|
-
type: Input
|
|
298
|
-
}], widthPx: [{
|
|
299
|
-
type: Input
|
|
300
|
-
}], disabled: [{
|
|
301
|
-
type: Input
|
|
302
|
-
}], placeholder: [{
|
|
303
|
-
type: Input
|
|
304
|
-
}], class: [{
|
|
305
|
-
type: Input
|
|
306
|
-
}], style: [{
|
|
307
|
-
type: Input
|
|
308
|
-
}], pattern: [{
|
|
309
|
-
type: Input
|
|
310
|
-
}], noValidate: [{
|
|
311
|
-
type: Input
|
|
312
|
-
}], autocomplete: [{
|
|
313
|
-
type: Input
|
|
314
|
-
}], id: [{
|
|
315
|
-
type: Input
|
|
316
|
-
}], inputChange: [{
|
|
317
|
-
type: Output
|
|
318
|
-
}], inputFocus: [{
|
|
319
|
-
type: Output
|
|
320
|
-
}], inputFinalized: [{
|
|
321
|
-
type: Output
|
|
322
|
-
}], submitted: [{
|
|
323
|
-
type: Input,
|
|
324
|
-
args: ["submitted"]
|
|
325
|
-
}], forceInvalid: [{
|
|
326
|
-
type: Input
|
|
327
|
-
}] } });
|
|
328
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-validation.js","sourceRoot":"","sources":["../../../../../projects/forms-and-validations/src/lib/validations/base-validation.ts"],"names":[],"mappings":"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","sourcesContent":["// Angular\r\nimport { EventEmitter, Input, Output, ViewChild, Directive, ElementRef, ChangeDetectorRef } from \"@angular/core\";\r\nimport { NgModel, RequiredValidator, Validator } from \"@angular/forms\";\r\n\r\n// Configurazioni\r\nimport { LocalizationService } from \"@esfaenza/localizations\";\r\n\r\n// Direttive, Componenti, Librerie\r\nimport { TooltipDirective } from \"ngx-bootstrap/tooltip\";\r\nimport { Subject } from \"rxjs\";\r\nimport { ChangeEvent } from \"../models/ChangeEvent\";\r\nimport { takeUntil } from \"rxjs/operators\";\r\n\r\n/**\r\n * Classe astratta base che contiene le logiche / proprietà in comune a tutti i validatori\r\n * \r\n * Nota bene: I tooltip rallentano tantissimo la pagina perché il tizio che ha fatto ngx bootstrap non è capace\r\n */\r\n@Directive()\r\nexport abstract class BaseValidation {\r\n\r\n    /** @ignore Constructor */\r\n    constructor(protected cdr: ChangeDetectorRef) { }\r\n\r\n    /**\r\n     * Per non sovrascrivere l'originale con errori che spuntano da BE\r\n     */\r\n    public validationFailedBind: string;\r\n\r\n    /**\r\n     * Per gestire il cambio di messaggi di errore\r\n     */\r\n    private valueOnLastValidation: string;\r\n\r\n    /**\r\n     * Servizio di localizzazione del Componente\r\n     */\r\n    protected lc: LocalizationService;\r\n\r\n    /**\r\n     * Variabile per tenere in memoria lo stato di submit di questo componente\r\n     */\r\n    protected _submitted: boolean;\r\n\r\n    /**\r\n     * Variabile per tenere in memoria il fatto che il componente è forzato a invalido o no\r\n     */\r\n    protected _forceInvalid: boolean = false;\r\n\r\n    /**\r\n     * Indica se il valore è obbligatorio o opzionale\r\n     */\r\n    public required: boolean = false;\r\n\r\n    /**\r\n     * Query che raccoglie il tooltip in maniera statica (solo all'inizio)\r\n     */\r\n    @ViewChild(TooltipDirective, { static: false }) protected tooltip: TooltipDirective;\r\n\r\n    /**\r\n     * Query che raccoglie il tooltip in maniera dinamica (ad ogni change detection)\r\n     * \r\n     * @param {TooltipDirective} comp Elemento HTML a cui è applicata la direttiva del tooltip\r\n     */\r\n    @ViewChild(TooltipDirective, { static: true }) set tooltip_static(comp: TooltipDirective) {\r\n        if (comp) { this.tooltip = comp; }\r\n    };\r\n\r\n    /**\r\n     * Elemento HTML rappresentante l'Input\r\n     */\r\n    @ViewChild('htmlInput', { static: false }) htmlInput: ElementRef;\r\n\r\n    /**\r\n     * Query che raccoglie l'input o direttiva che contiene il valore in maniera statica (solo all'inizio)\r\n     */\r\n    @ViewChild(\"baseInput\", { static: false }) baseInput: NgModel;\r\n\r\n    /**\r\n     * Query che raccoglie l'input o direttiva che contiene il valore in maniera dinamica (ad ogni change detection)\r\n     * \r\n     * @param {NgModel} comp Elemento HTML associato al ngModel del componente\r\n     */\r\n    @ViewChild(\"baseInput\", { static: true }) set baseInput_static(comp: NgModel) {\r\n        if (comp) { this.baseInput = comp; }\r\n    };\r\n\r\n    /**\r\n     * Subject a cui l'oggetto interno si collega per effettuare il focus dell'elemento input sottostante\r\n     */\r\n    @Input() FocusSubject: Subject<void>;\r\n\r\n    /**\r\n     * @EXPERIMENTAL\r\n     */\r\n    @Input() SetValidationSubject: Subject<{ fieldName: string, error: string }>;\r\n\r\n    /**\r\n     * Indica se di default deve valutare il messaggio di errore in base al validatore che fallisce.\r\n     * \r\n     * Se fallisce il required validator scriverà che l'input è obbligatorio, se invece fallisce \r\n     * un eventuale pattern validator scriverà che il formato dell'input è invalido\r\n     */\r\n    @Input() InferErrorMessages: boolean = true;\r\n\r\n    /**\r\n     * Modalità in cui viene mostrato il campo, 1-1 rispetto alle definizioni di Angular Material \r\n     */\r\n    @Input() FieldAppearence: \"legacy\" | \"standard\" | \"fill\" | \"outline\" = \"outline\";\r\n\r\n    /**\r\n     * Indica se il **Placeholder** dev'essere usato come una floating label di material o solo come un placeholder standard \r\n     * \r\n     * Ignorata lato autocomplete, autocomplete-multi e select in quanto hanno gestioni particolari di placeholder ecc...\r\n     */\r\n    @Input() FloatingLabel: boolean = true;\r\n\r\n    /**\r\n     * Messaggio da mostrare se la validazione fallisce. \r\n     * \r\n     * Se questo è valorizzato, il messaggio non viene valutato in automatico nonstante **InferErrorMessages** sia **true**\r\n     */\r\n    @Input() validationFailed: string = \"\";\r\n\r\n    /**\r\n     * Indica se il componente è in sola lettura\r\n     */\r\n    @Input() Readonly: boolean = false;\r\n\r\n    /**\r\n     * Indica le dimensioni del componente\r\n     */\r\n    @Input() widthPx: number = null;\r\n\r\n    /**\r\n     * Indica se il componente è disabilitato o no (più o meno stesso concetto del readonly)\r\n     */\r\n    @Input() disabled: boolean = false;\r\n\r\n    /**\r\n     * Eventuale placeholder da mostrare al posto del valore quando il valore è nullo / vuoto\r\n     */\r\n    @Input() placeholder: string = \"\";\r\n\r\n    /**\r\n     * Classi da applicare al componente\r\n     */\r\n    @Input() class: string = \"\";\r\n\r\n    /**\r\n     * Stili da applicare al componente\r\n     */\r\n    @Input() style: string = \"\";\r\n\r\n    /**\r\n     * Pattern di validazione dell'input\r\n     */\r\n    @Input() pattern: string = \"\";\r\n\r\n    /**\r\n     * Indica di non validare il componente\r\n     */\r\n    @Input() noValidate: boolean = false;\r\n\r\n    /**\r\n     * Indica se abilitare o meno l'autocompletamento di default del browser\r\n     */\r\n    @Input() autocomplete: string = \"off\";\r\n\r\n    /**\r\n     * Id dell'input. È importante impostarlo soprattutto se l'interfaccia generata dev'essere testata\r\n     */\r\n    @Input() id: string = \"\";\r\n\r\n    /**\r\n     * Evento che sostituisce l'ngModelChange facendolo funzionare in maniera un po' più consistente\r\n     */\r\n    @Output() inputChange: EventEmitter<string> = new EventEmitter<string>();\r\n\r\n    /**\r\n     * Evento che indica il focus avvenuto su un controllo\r\n     */\r\n    @Output() inputFocus: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n    /**\r\n     * Evento che indica la finalizzazione del valore avvenuta su un controllo\r\n     */\r\n    @Output() inputFinalized: EventEmitter<any> = new EventEmitter<any>();\r\n    \r\n    /**\r\n     * Imposta il componente come \"submitted\" scatenandone le validazioni ed eventualmente la visualizzazione del tooltip di errore\r\n     * \r\n     * @param {boolean} val **true** se si vuole impostare questo controllo come submitted, **false** altrimenti\r\n     */\r\n    @Input(\"submitted\") set submitted(val: boolean) {\r\n        this._submitted = val;\r\n        if (!this.baseInput)\r\n            return;\r\n\r\n        if (val)\r\n            this.baseInput.control.markAsTouched();\r\n\r\n        if (this.baseInput.control.status === \"INVALID\" && val)\r\n            this.showTooltipWithMessage();\r\n        else\r\n            this.tooltip.hide();\r\n    }\r\n\r\n    /**\r\n     * Imposta il componente come \"invalid\" a prescindere dai validatori\r\n     */\r\n    @Input() set forceInvalid(val: boolean) {\r\n        this._forceInvalid = val;\r\n\r\n        if (val)\r\n            setTimeout(() => {\r\n                this.baseInput.control.setErrors({ forcedtoinvalid: true });\r\n                this.baseInput.control.markAsTouched();\r\n                this.baseInput.control.markAsDirty();\r\n                this.cdr.detectChanges();\r\n            });\r\n        else\r\n            setTimeout(() => {\r\n                this.baseInput.control.setErrors({ forcedtoinvalid: null });\r\n                this.baseInput.control.updateValueAndValidity();\r\n            });\r\n    }\r\n\r\n    ngOnInit() {\r\n        if (this.SetValidationSubject) {\r\n            this.SetValidationSubject.pipe(takeUntil(this.destroyed$)).subscribe(v => {\r\n                if (v.fieldName + \"_internal\" == this.id) {\r\n                    this.forceInvalid = true;\r\n                    this.showTooltipWithMessage(v.error);\r\n                }\r\n            })\r\n        } \r\n    }\r\n\r\n    protected checkRequiredness(_validators: Validator[]) {\r\n        if (_validators && _validators.some(elem => elem instanceof RequiredValidator && (elem.required === true || (!elem.required && elem.required !== false))))\r\n            this.required = true;\r\n    }\r\n\r\n    destroyed$: Subject<void> = new Subject<void>();\r\n    ngOnDestroy(){\r\n        this.destroyed$.next();\r\n        this.destroyed$.complete();\r\n    }\r\n    /**\r\n     * Helper che controlla se il tooltip deve essere mostrato o meno, \r\n     * richiamato direttamente dall'HTML dei componenti\r\n     */\r\n    public checkTooltip() {\r\n        if ((this.baseInput.invalid && this.baseInput.touched))\r\n            this.showTooltipWithMessage();\r\n    }\r\n\r\n    /**\r\n     * Helper che calcola il messaggio da mostrare nel tooltip che andrà ad aprire\r\n     */\r\n    private showTooltipWithMessage(messageOverride: string = null) {\r\n\r\n        // Aggiorno il messaggio di validazione solo se il valore è diverso dall'ultimo valore ricevuto\r\n        if (this.valueOnLastValidation != this.baseInput.value) {\r\n            this.validationFailedBind = messageOverride || this.validationFailed || (this.InferErrorMessages ? this.inferMessage() : \"\");\r\n            this.valueOnLastValidation = this.baseInput.value;\r\n        }\r\n\r\n        if (this.validationFailedBind)\r\n            this.tooltip.show();\r\n    }\r\n\r\n    /**\r\n     * Calcola il messaggio da mostrare in base al valore.\r\n     * \r\n     * Entrare in questa funzione significa che lo stato di validazione è fallito, per questo si comporta semplicemente in maniera esclusiva, e cioè:\r\n     * \r\n     * 1) Se ero required e sono senza valore --> Input richiesto\r\n     * \r\n     * 2) Altrimenti se ho un valore --> Di sicuro il formato è errato\r\n     */\r\n    private inferMessage(): string {\r\n        if (this.required && !this.baseInput.value)\r\n            return this.lc.loc(\"Required Input\")\r\n\r\n        if (this.baseInput.value)\r\n            return this.lc.loc(\"Invalid Input Format\")\r\n    }\r\n\r\n    /**\r\n     * Forza la chiusura del tooltip\r\n     */\r\n    closeTooltip() {\r\n        this.tooltip.hide();\r\n    }\r\n\r\n    /**\r\n     * Controlla se il controllo è valido e in caso lo sia chiude il tooltip\r\n     */\r\n    protected CheckValidity() {\r\n        if (!this.baseInput.statusChanges)\r\n            return;\r\n\r\n        this.baseInput.statusChanges.subscribe(event => {\r\n            if (event === \"VALID\")\r\n                this.tooltip.hide();\r\n        });\r\n    }\r\n\r\n    /**\r\n     * @ignore\r\n     */\r\n    protected propagateChange = (_: any) => { };\r\n\r\n    /**\r\n     * L'emit del focus dell'elemento\r\n     * \r\n     * @param {any} toEmit valore da propagare all'esterno\r\n     */\r\n    onFocus(toEmit) {\r\n        this.inputFocus.emit(toEmit);\r\n    }\r\n\r\n    /**\r\n     * Finalizzazione Input\r\n     */\r\n    onFinalize() {\r\n        this.inputFinalized.emit();\r\n    }\r\n\r\n    /**\r\n     * Subscription alle richieste di focus\r\n     */\r\n    observable: any;\r\n\r\n    /**\r\n     * Registra il Subject per ricevere le richieste di Focus dall'esterno\r\n     */\r\n    registerFocusRequest(): any {\r\n        if(!this.FocusSubject)\r\n            return;\r\n        this.observable = this.FocusSubject.subscribe(t => {\r\n            this.htmlInput.nativeElement.focus();\r\n        });\r\n    }\r\n\r\n    /**\r\n     * Deregistra il Subject delle richieste di focus\r\n     */\r\n    deregisterFocusRequest() {\r\n        if (this.observable)\r\n            this.observable.unsubscribe();\r\n    }\r\n}"]}
|
|
1
|
+
// Angular
|
|
2
|
+
import { EventEmitter, Input, Output, ViewChild, Directive } from "@angular/core";
|
|
3
|
+
import { RequiredValidator } from "@angular/forms";
|
|
4
|
+
// Direttive, Componenti, Librerie
|
|
5
|
+
import { TooltipDirective } from "ngx-bootstrap/tooltip";
|
|
6
|
+
import { Subject } from "rxjs";
|
|
7
|
+
import { takeUntil } from "rxjs/operators";
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
/**
|
|
10
|
+
* Classe astratta base che contiene le logiche / proprietà in comune a tutti i validatori
|
|
11
|
+
*
|
|
12
|
+
* Nota bene: I tooltip rallentano tantissimo la pagina perché il tizio che ha fatto ngx bootstrap non è capace
|
|
13
|
+
*/
|
|
14
|
+
export class BaseValidation {
|
|
15
|
+
/** @ignore Constructor */
|
|
16
|
+
constructor(cdr) {
|
|
17
|
+
this.cdr = cdr;
|
|
18
|
+
/**
|
|
19
|
+
* Variabile per tenere in memoria il fatto che il componente è forzato a invalido o no
|
|
20
|
+
*/
|
|
21
|
+
this._forceInvalid = false;
|
|
22
|
+
/**
|
|
23
|
+
* Indica se il valore è obbligatorio o opzionale
|
|
24
|
+
*/
|
|
25
|
+
this.required = false;
|
|
26
|
+
/**
|
|
27
|
+
* Indica se di default deve valutare il messaggio di errore in base al validatore che fallisce.
|
|
28
|
+
*
|
|
29
|
+
* Se fallisce il required validator scriverà che l'input è obbligatorio, se invece fallisce
|
|
30
|
+
* un eventuale pattern validator scriverà che il formato dell'input è invalido
|
|
31
|
+
*/
|
|
32
|
+
this.InferErrorMessages = true;
|
|
33
|
+
/**
|
|
34
|
+
* Modalità in cui viene mostrato il campo, 1-1 rispetto alle definizioni di Angular Material
|
|
35
|
+
*/
|
|
36
|
+
this.FieldAppearence = "outline";
|
|
37
|
+
/**
|
|
38
|
+
* Indica se il **Placeholder** dev'essere usato come una floating label di material o solo come un placeholder standard
|
|
39
|
+
*
|
|
40
|
+
* Ignorata lato autocomplete, autocomplete-multi e select in quanto hanno gestioni particolari di placeholder ecc...
|
|
41
|
+
*/
|
|
42
|
+
this.FloatingLabel = true;
|
|
43
|
+
/**
|
|
44
|
+
* Messaggio da mostrare se la validazione fallisce.
|
|
45
|
+
*
|
|
46
|
+
* Se questo è valorizzato, il messaggio non viene valutato in automatico nonstante **InferErrorMessages** sia **true**
|
|
47
|
+
*/
|
|
48
|
+
this.validationFailed = "";
|
|
49
|
+
/**
|
|
50
|
+
* Indica se il componente è in sola lettura
|
|
51
|
+
*/
|
|
52
|
+
this.Readonly = false;
|
|
53
|
+
/**
|
|
54
|
+
* Indica le dimensioni del componente
|
|
55
|
+
*/
|
|
56
|
+
this.widthPx = null;
|
|
57
|
+
/**
|
|
58
|
+
* Indica se il componente è disabilitato o no (più o meno stesso concetto del readonly)
|
|
59
|
+
*/
|
|
60
|
+
this.disabled = false;
|
|
61
|
+
/**
|
|
62
|
+
* Eventuale placeholder da mostrare al posto del valore quando il valore è nullo / vuoto
|
|
63
|
+
*/
|
|
64
|
+
this.placeholder = "";
|
|
65
|
+
/**
|
|
66
|
+
* Classi da applicare al componente
|
|
67
|
+
*/
|
|
68
|
+
this.class = "";
|
|
69
|
+
/**
|
|
70
|
+
* Stili da applicare al componente
|
|
71
|
+
*/
|
|
72
|
+
this.style = "";
|
|
73
|
+
/**
|
|
74
|
+
* Pattern di validazione dell'input
|
|
75
|
+
*/
|
|
76
|
+
this.pattern = "";
|
|
77
|
+
/**
|
|
78
|
+
* Indica di non validare il componente
|
|
79
|
+
*/
|
|
80
|
+
this.noValidate = false;
|
|
81
|
+
/**
|
|
82
|
+
* Indica se abilitare o meno l'autocompletamento di default del browser
|
|
83
|
+
*/
|
|
84
|
+
this.autocomplete = "off";
|
|
85
|
+
/**
|
|
86
|
+
* Id dell'input. È importante impostarlo soprattutto se l'interfaccia generata dev'essere testata
|
|
87
|
+
*/
|
|
88
|
+
this.id = "";
|
|
89
|
+
/**
|
|
90
|
+
* Evento che sostituisce l'ngModelChange facendolo funzionare in maniera un po' più consistente
|
|
91
|
+
*/
|
|
92
|
+
this.inputChange = new EventEmitter();
|
|
93
|
+
/**
|
|
94
|
+
* Evento che indica il focus avvenuto su un controllo
|
|
95
|
+
*/
|
|
96
|
+
this.inputFocus = new EventEmitter();
|
|
97
|
+
/**
|
|
98
|
+
* Evento che indica la finalizzazione del valore avvenuta su un controllo
|
|
99
|
+
*/
|
|
100
|
+
this.inputFinalized = new EventEmitter();
|
|
101
|
+
this.destroyed$ = new Subject();
|
|
102
|
+
/**
|
|
103
|
+
* @ignore
|
|
104
|
+
*/
|
|
105
|
+
this.propagateChange = (_) => { };
|
|
106
|
+
}
|
|
107
|
+
/**
|
|
108
|
+
* Query che raccoglie il tooltip in maniera dinamica (ad ogni change detection)
|
|
109
|
+
*
|
|
110
|
+
* @param {TooltipDirective} comp Elemento HTML a cui è applicata la direttiva del tooltip
|
|
111
|
+
*/
|
|
112
|
+
set tooltip_static(comp) {
|
|
113
|
+
if (comp) {
|
|
114
|
+
this.tooltip = comp;
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
;
|
|
118
|
+
/**
|
|
119
|
+
* Query che raccoglie l'input o direttiva che contiene il valore in maniera dinamica (ad ogni change detection)
|
|
120
|
+
*
|
|
121
|
+
* @param {NgModel} comp Elemento HTML associato al ngModel del componente
|
|
122
|
+
*/
|
|
123
|
+
set baseInput_static(comp) {
|
|
124
|
+
if (comp) {
|
|
125
|
+
this.baseInput = comp;
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
;
|
|
129
|
+
/**
|
|
130
|
+
* Imposta il componente come "submitted" scatenandone le validazioni ed eventualmente la visualizzazione del tooltip di errore
|
|
131
|
+
*
|
|
132
|
+
* @param {boolean} val **true** se si vuole impostare questo controllo come submitted, **false** altrimenti
|
|
133
|
+
*/
|
|
134
|
+
set submitted(val) {
|
|
135
|
+
this._submitted = val;
|
|
136
|
+
if (!this.baseInput)
|
|
137
|
+
return;
|
|
138
|
+
if (val)
|
|
139
|
+
this.baseInput.control.markAsTouched();
|
|
140
|
+
if (this.baseInput.control.status === "INVALID" && val)
|
|
141
|
+
this.showTooltipWithMessage();
|
|
142
|
+
else
|
|
143
|
+
this.tooltip.hide();
|
|
144
|
+
}
|
|
145
|
+
/**
|
|
146
|
+
* Imposta il componente come "invalid" a prescindere dai validatori
|
|
147
|
+
*/
|
|
148
|
+
set forceInvalid(val) {
|
|
149
|
+
this._forceInvalid = val;
|
|
150
|
+
if (val)
|
|
151
|
+
setTimeout(() => {
|
|
152
|
+
this.baseInput.control.setErrors({ forcedtoinvalid: true });
|
|
153
|
+
this.baseInput.control.markAsTouched();
|
|
154
|
+
this.baseInput.control.markAsDirty();
|
|
155
|
+
this.cdr.detectChanges();
|
|
156
|
+
});
|
|
157
|
+
else
|
|
158
|
+
setTimeout(() => {
|
|
159
|
+
this.baseInput.control.setErrors({ forcedtoinvalid: null });
|
|
160
|
+
this.baseInput.control.updateValueAndValidity();
|
|
161
|
+
});
|
|
162
|
+
}
|
|
163
|
+
ngOnInit() {
|
|
164
|
+
if (this.SetValidationSubject) {
|
|
165
|
+
this.SetValidationSubject.pipe(takeUntil(this.destroyed$)).subscribe(v => {
|
|
166
|
+
if (v.fieldName + "_internal" == this.id) {
|
|
167
|
+
this.forceInvalid = true;
|
|
168
|
+
this.showTooltipWithMessage(v.error);
|
|
169
|
+
}
|
|
170
|
+
});
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
checkRequiredness(_validators) {
|
|
174
|
+
if (_validators && _validators.some(elem => elem instanceof RequiredValidator && (elem.required === true || (!elem.required && elem.required !== false))))
|
|
175
|
+
this.required = true;
|
|
176
|
+
}
|
|
177
|
+
ngOnDestroy() {
|
|
178
|
+
this.destroyed$.next();
|
|
179
|
+
this.destroyed$.complete();
|
|
180
|
+
}
|
|
181
|
+
/**
|
|
182
|
+
* Helper che controlla se il tooltip deve essere mostrato o meno,
|
|
183
|
+
* richiamato direttamente dall'HTML dei componenti
|
|
184
|
+
*/
|
|
185
|
+
checkTooltip() {
|
|
186
|
+
if ((this.baseInput.invalid && this.baseInput.touched))
|
|
187
|
+
this.showTooltipWithMessage();
|
|
188
|
+
}
|
|
189
|
+
/**
|
|
190
|
+
* Helper che calcola il messaggio da mostrare nel tooltip che andrà ad aprire
|
|
191
|
+
*/
|
|
192
|
+
showTooltipWithMessage(messageOverride = null) {
|
|
193
|
+
// Aggiorno il messaggio di validazione solo se il valore è diverso dall'ultimo valore ricevuto
|
|
194
|
+
if (this.valueOnLastValidation != this.baseInput.value) {
|
|
195
|
+
this.validationFailedBind = messageOverride || this.validationFailed || (this.InferErrorMessages ? this.inferMessage() : "");
|
|
196
|
+
this.valueOnLastValidation = this.baseInput.value;
|
|
197
|
+
}
|
|
198
|
+
if (this.validationFailedBind)
|
|
199
|
+
this.tooltip.show();
|
|
200
|
+
}
|
|
201
|
+
/**
|
|
202
|
+
* Calcola il messaggio da mostrare in base al valore.
|
|
203
|
+
*
|
|
204
|
+
* Entrare in questa funzione significa che lo stato di validazione è fallito, per questo si comporta semplicemente in maniera esclusiva, e cioè:
|
|
205
|
+
*
|
|
206
|
+
* 1) Se ero required e sono senza valore --> Input richiesto
|
|
207
|
+
*
|
|
208
|
+
* 2) Altrimenti se ho un valore --> Di sicuro il formato è errato
|
|
209
|
+
*/
|
|
210
|
+
inferMessage() {
|
|
211
|
+
if (this.required && !this.baseInput.value)
|
|
212
|
+
return this.lc.loc("Required Input");
|
|
213
|
+
if (this.baseInput.value)
|
|
214
|
+
return this.lc.loc("Invalid Input Format");
|
|
215
|
+
}
|
|
216
|
+
/**
|
|
217
|
+
* Forza la chiusura del tooltip
|
|
218
|
+
*/
|
|
219
|
+
closeTooltip() {
|
|
220
|
+
this.tooltip.hide();
|
|
221
|
+
}
|
|
222
|
+
/**
|
|
223
|
+
* Controlla se il controllo è valido e in caso lo sia chiude il tooltip
|
|
224
|
+
*/
|
|
225
|
+
CheckValidity() {
|
|
226
|
+
if (!this.baseInput.statusChanges)
|
|
227
|
+
return;
|
|
228
|
+
this.baseInput.statusChanges.subscribe(event => {
|
|
229
|
+
if (event === "VALID")
|
|
230
|
+
this.tooltip.hide();
|
|
231
|
+
});
|
|
232
|
+
}
|
|
233
|
+
/**
|
|
234
|
+
* L'emit del focus dell'elemento
|
|
235
|
+
*
|
|
236
|
+
* @param {any} toEmit valore da propagare all'esterno
|
|
237
|
+
*/
|
|
238
|
+
onFocus(toEmit) {
|
|
239
|
+
this.inputFocus.emit(toEmit);
|
|
240
|
+
}
|
|
241
|
+
/**
|
|
242
|
+
* Finalizzazione Input
|
|
243
|
+
*/
|
|
244
|
+
onFinalize() {
|
|
245
|
+
this.inputFinalized.emit();
|
|
246
|
+
}
|
|
247
|
+
/**
|
|
248
|
+
* Registra il Subject per ricevere le richieste di Focus dall'esterno
|
|
249
|
+
*/
|
|
250
|
+
registerFocusRequest() {
|
|
251
|
+
if (!this.FocusSubject)
|
|
252
|
+
return;
|
|
253
|
+
this.observable = this.FocusSubject.subscribe(t => {
|
|
254
|
+
this.htmlInput.nativeElement.focus();
|
|
255
|
+
});
|
|
256
|
+
}
|
|
257
|
+
/**
|
|
258
|
+
* Deregistra il Subject delle richieste di focus
|
|
259
|
+
*/
|
|
260
|
+
deregisterFocusRequest() {
|
|
261
|
+
if (this.observable)
|
|
262
|
+
this.observable.unsubscribe();
|
|
263
|
+
}
|
|
264
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: BaseValidation, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
265
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: BaseValidation, inputs: { FocusSubject: "FocusSubject", SetValidationSubject: "SetValidationSubject", InferErrorMessages: "InferErrorMessages", FieldAppearence: "FieldAppearence", FloatingLabel: "FloatingLabel", validationFailed: "validationFailed", Readonly: "Readonly", widthPx: "widthPx", disabled: "disabled", placeholder: "placeholder", class: "class", style: "style", pattern: "pattern", noValidate: "noValidate", autocomplete: "autocomplete", id: "id", submitted: "submitted", forceInvalid: "forceInvalid" }, outputs: { inputChange: "inputChange", inputFocus: "inputFocus", inputFinalized: "inputFinalized" }, viewQueries: [{ propertyName: "tooltip", first: true, predicate: TooltipDirective, descendants: true }, { propertyName: "tooltip_static", first: true, predicate: TooltipDirective, descendants: true, static: true }, { propertyName: "htmlInput", first: true, predicate: ["htmlInput"], descendants: true }, { propertyName: "baseInput", first: true, predicate: ["baseInput"], descendants: true }, { propertyName: "baseInput_static", first: true, predicate: ["baseInput"], descendants: true, static: true }], ngImport: i0 }); }
|
|
266
|
+
}
|
|
267
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: BaseValidation, decorators: [{
|
|
268
|
+
type: Directive
|
|
269
|
+
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }], propDecorators: { tooltip: [{
|
|
270
|
+
type: ViewChild,
|
|
271
|
+
args: [TooltipDirective, { static: false }]
|
|
272
|
+
}], tooltip_static: [{
|
|
273
|
+
type: ViewChild,
|
|
274
|
+
args: [TooltipDirective, { static: true }]
|
|
275
|
+
}], htmlInput: [{
|
|
276
|
+
type: ViewChild,
|
|
277
|
+
args: ['htmlInput', { static: false }]
|
|
278
|
+
}], baseInput: [{
|
|
279
|
+
type: ViewChild,
|
|
280
|
+
args: ["baseInput", { static: false }]
|
|
281
|
+
}], baseInput_static: [{
|
|
282
|
+
type: ViewChild,
|
|
283
|
+
args: ["baseInput", { static: true }]
|
|
284
|
+
}], FocusSubject: [{
|
|
285
|
+
type: Input
|
|
286
|
+
}], SetValidationSubject: [{
|
|
287
|
+
type: Input
|
|
288
|
+
}], InferErrorMessages: [{
|
|
289
|
+
type: Input
|
|
290
|
+
}], FieldAppearence: [{
|
|
291
|
+
type: Input
|
|
292
|
+
}], FloatingLabel: [{
|
|
293
|
+
type: Input
|
|
294
|
+
}], validationFailed: [{
|
|
295
|
+
type: Input
|
|
296
|
+
}], Readonly: [{
|
|
297
|
+
type: Input
|
|
298
|
+
}], widthPx: [{
|
|
299
|
+
type: Input
|
|
300
|
+
}], disabled: [{
|
|
301
|
+
type: Input
|
|
302
|
+
}], placeholder: [{
|
|
303
|
+
type: Input
|
|
304
|
+
}], class: [{
|
|
305
|
+
type: Input
|
|
306
|
+
}], style: [{
|
|
307
|
+
type: Input
|
|
308
|
+
}], pattern: [{
|
|
309
|
+
type: Input
|
|
310
|
+
}], noValidate: [{
|
|
311
|
+
type: Input
|
|
312
|
+
}], autocomplete: [{
|
|
313
|
+
type: Input
|
|
314
|
+
}], id: [{
|
|
315
|
+
type: Input
|
|
316
|
+
}], inputChange: [{
|
|
317
|
+
type: Output
|
|
318
|
+
}], inputFocus: [{
|
|
319
|
+
type: Output
|
|
320
|
+
}], inputFinalized: [{
|
|
321
|
+
type: Output
|
|
322
|
+
}], submitted: [{
|
|
323
|
+
type: Input,
|
|
324
|
+
args: ["submitted"]
|
|
325
|
+
}], forceInvalid: [{
|
|
326
|
+
type: Input
|
|
327
|
+
}] } });
|
|
328
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-validation.js","sourceRoot":"","sources":["../../../../../projects/forms-and-validations/src/lib/validations/base-validation.ts"],"names":[],"mappings":"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","sourcesContent":["// Angular\r\nimport { EventEmitter, Input, Output, ViewChild, Directive, ElementRef, ChangeDetectorRef } from \"@angular/core\";\r\nimport { NgModel, RequiredValidator, Validator } from \"@angular/forms\";\r\n\r\n// Configurazioni\r\nimport { LocalizationService } from \"@esfaenza/localizations\";\r\n\r\n// Direttive, Componenti, Librerie\r\nimport { TooltipDirective } from \"ngx-bootstrap/tooltip\";\r\nimport { Subject } from \"rxjs\";\r\nimport { ChangeEvent } from \"../models/ChangeEvent\";\r\nimport { takeUntil } from \"rxjs/operators\";\r\n\r\n/**\r\n * Classe astratta base che contiene le logiche / proprietà in comune a tutti i validatori\r\n * \r\n * Nota bene: I tooltip rallentano tantissimo la pagina perché il tizio che ha fatto ngx bootstrap non è capace\r\n */\r\n@Directive()\r\nexport abstract class BaseValidation {\r\n\r\n    /** @ignore Constructor */\r\n    constructor(protected cdr: ChangeDetectorRef) { }\r\n\r\n    /**\r\n     * Per non sovrascrivere l'originale con errori che spuntano da BE\r\n     */\r\n    public validationFailedBind: string;\r\n\r\n    /**\r\n     * Per gestire il cambio di messaggi di errore\r\n     */\r\n    private valueOnLastValidation: string;\r\n\r\n    /**\r\n     * Servizio di localizzazione del Componente\r\n     */\r\n    protected lc: LocalizationService;\r\n\r\n    /**\r\n     * Variabile per tenere in memoria lo stato di submit di questo componente\r\n     */\r\n    protected _submitted: boolean;\r\n\r\n    /**\r\n     * Variabile per tenere in memoria il fatto che il componente è forzato a invalido o no\r\n     */\r\n    protected _forceInvalid: boolean = false;\r\n\r\n    /**\r\n     * Indica se il valore è obbligatorio o opzionale\r\n     */\r\n    public required: boolean = false;\r\n\r\n    /**\r\n     * Query che raccoglie il tooltip in maniera statica (solo all'inizio)\r\n     */\r\n    @ViewChild(TooltipDirective, { static: false }) protected tooltip: TooltipDirective;\r\n\r\n    /**\r\n     * Query che raccoglie il tooltip in maniera dinamica (ad ogni change detection)\r\n     * \r\n     * @param {TooltipDirective} comp Elemento HTML a cui è applicata la direttiva del tooltip\r\n     */\r\n    @ViewChild(TooltipDirective, { static: true }) set tooltip_static(comp: TooltipDirective) {\r\n        if (comp) { this.tooltip = comp; }\r\n    };\r\n\r\n    /**\r\n     * Elemento HTML rappresentante l'Input\r\n     */\r\n    @ViewChild('htmlInput', { static: false }) htmlInput: ElementRef;\r\n\r\n    /**\r\n     * Query che raccoglie l'input o direttiva che contiene il valore in maniera statica (solo all'inizio)\r\n     */\r\n    @ViewChild(\"baseInput\", { static: false }) baseInput: NgModel;\r\n\r\n    /**\r\n     * Query che raccoglie l'input o direttiva che contiene il valore in maniera dinamica (ad ogni change detection)\r\n     * \r\n     * @param {NgModel} comp Elemento HTML associato al ngModel del componente\r\n     */\r\n    @ViewChild(\"baseInput\", { static: true }) set baseInput_static(comp: NgModel) {\r\n        if (comp) { this.baseInput = comp; }\r\n    };\r\n\r\n    /**\r\n     * Subject a cui l'oggetto interno si collega per effettuare il focus dell'elemento input sottostante\r\n     */\r\n    @Input() FocusSubject: Subject<void>;\r\n\r\n    /**\r\n     * @EXPERIMENTAL\r\n     */\r\n    @Input() SetValidationSubject: Subject<{ fieldName: string, error: string }>;\r\n\r\n    /**\r\n     * Indica se di default deve valutare il messaggio di errore in base al validatore che fallisce.\r\n     * \r\n     * Se fallisce il required validator scriverà che l'input è obbligatorio, se invece fallisce \r\n     * un eventuale pattern validator scriverà che il formato dell'input è invalido\r\n     */\r\n    @Input() InferErrorMessages: boolean = true;\r\n\r\n    /**\r\n     * Modalità in cui viene mostrato il campo, 1-1 rispetto alle definizioni di Angular Material \r\n     */\r\n    @Input() FieldAppearence: \"legacy\" | \"standard\" | \"fill\" | \"outline\" = \"outline\";\r\n\r\n    /**\r\n     * Indica se il **Placeholder** dev'essere usato come una floating label di material o solo come un placeholder standard \r\n     * \r\n     * Ignorata lato autocomplete, autocomplete-multi e select in quanto hanno gestioni particolari di placeholder ecc...\r\n     */\r\n    @Input() FloatingLabel: boolean = true;\r\n\r\n    /**\r\n     * Messaggio da mostrare se la validazione fallisce. \r\n     * \r\n     * Se questo è valorizzato, il messaggio non viene valutato in automatico nonstante **InferErrorMessages** sia **true**\r\n     */\r\n    @Input() validationFailed: string = \"\";\r\n\r\n    /**\r\n     * Indica se il componente è in sola lettura\r\n     */\r\n    @Input() Readonly: boolean = false;\r\n\r\n    /**\r\n     * Indica le dimensioni del componente\r\n     */\r\n    @Input() widthPx: number = null;\r\n\r\n    /**\r\n     * Indica se il componente è disabilitato o no (più o meno stesso concetto del readonly)\r\n     */\r\n    @Input() disabled: boolean = false;\r\n\r\n    /**\r\n     * Eventuale placeholder da mostrare al posto del valore quando il valore è nullo / vuoto\r\n     */\r\n    @Input() placeholder: string = \"\";\r\n\r\n    /**\r\n     * Classi da applicare al componente\r\n     */\r\n    @Input() class: string = \"\";\r\n\r\n    /**\r\n     * Stili da applicare al componente\r\n     */\r\n    @Input() style: string = \"\";\r\n\r\n    /**\r\n     * Pattern di validazione dell'input\r\n     */\r\n    @Input() pattern: string = \"\";\r\n\r\n    /**\r\n     * Indica di non validare il componente\r\n     */\r\n    @Input() noValidate: boolean = false;\r\n\r\n    /**\r\n     * Indica se abilitare o meno l'autocompletamento di default del browser\r\n     */\r\n    @Input() autocomplete: string = \"off\";\r\n\r\n    /**\r\n     * Id dell'input. È importante impostarlo soprattutto se l'interfaccia generata dev'essere testata\r\n     */\r\n    @Input() id: string = \"\";\r\n\r\n    /**\r\n     * Evento che sostituisce l'ngModelChange facendolo funzionare in maniera un po' più consistente\r\n     */\r\n    @Output() inputChange: EventEmitter<string> = new EventEmitter<string>();\r\n\r\n    /**\r\n     * Evento che indica il focus avvenuto su un controllo\r\n     */\r\n    @Output() inputFocus: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n    /**\r\n     * Evento che indica la finalizzazione del valore avvenuta su un controllo\r\n     */\r\n    @Output() inputFinalized: EventEmitter<any> = new EventEmitter<any>();\r\n    \r\n    /**\r\n     * Imposta il componente come \"submitted\" scatenandone le validazioni ed eventualmente la visualizzazione del tooltip di errore\r\n     * \r\n     * @param {boolean} val **true** se si vuole impostare questo controllo come submitted, **false** altrimenti\r\n     */\r\n    @Input(\"submitted\") set submitted(val: boolean) {\r\n        this._submitted = val;\r\n        if (!this.baseInput)\r\n            return;\r\n\r\n        if (val)\r\n            this.baseInput.control.markAsTouched();\r\n\r\n        if (this.baseInput.control.status === \"INVALID\" && val)\r\n            this.showTooltipWithMessage();\r\n        else\r\n            this.tooltip.hide();\r\n    }\r\n\r\n    /**\r\n     * Imposta il componente come \"invalid\" a prescindere dai validatori\r\n     */\r\n    @Input() set forceInvalid(val: boolean) {\r\n        this._forceInvalid = val;\r\n\r\n        if (val)\r\n            setTimeout(() => {\r\n                this.baseInput.control.setErrors({ forcedtoinvalid: true });\r\n                this.baseInput.control.markAsTouched();\r\n                this.baseInput.control.markAsDirty();\r\n                this.cdr.detectChanges();\r\n            });\r\n        else\r\n            setTimeout(() => {\r\n                this.baseInput.control.setErrors({ forcedtoinvalid: null });\r\n                this.baseInput.control.updateValueAndValidity();\r\n            });\r\n    }\r\n\r\n    ngOnInit() {\r\n        if (this.SetValidationSubject) {\r\n            this.SetValidationSubject.pipe(takeUntil(this.destroyed$)).subscribe(v => {\r\n                if (v.fieldName + \"_internal\" == this.id) {\r\n                    this.forceInvalid = true;\r\n                    this.showTooltipWithMessage(v.error);\r\n                }\r\n            })\r\n        } \r\n    }\r\n\r\n    protected checkRequiredness(_validators: Validator[]) {\r\n        if (_validators && _validators.some(elem => elem instanceof RequiredValidator && (elem.required === true || (!elem.required && elem.required !== false))))\r\n            this.required = true;\r\n    }\r\n\r\n    destroyed$: Subject<void> = new Subject<void>();\r\n    ngOnDestroy(){\r\n        this.destroyed$.next();\r\n        this.destroyed$.complete();\r\n    }\r\n    /**\r\n     * Helper che controlla se il tooltip deve essere mostrato o meno, \r\n     * richiamato direttamente dall'HTML dei componenti\r\n     */\r\n    public checkTooltip() {\r\n        if ((this.baseInput.invalid && this.baseInput.touched))\r\n            this.showTooltipWithMessage();\r\n    }\r\n\r\n    /**\r\n     * Helper che calcola il messaggio da mostrare nel tooltip che andrà ad aprire\r\n     */\r\n    private showTooltipWithMessage(messageOverride: string = null) {\r\n\r\n        // Aggiorno il messaggio di validazione solo se il valore è diverso dall'ultimo valore ricevuto\r\n        if (this.valueOnLastValidation != this.baseInput.value) {\r\n            this.validationFailedBind = messageOverride || this.validationFailed || (this.InferErrorMessages ? this.inferMessage() : \"\");\r\n            this.valueOnLastValidation = this.baseInput.value;\r\n        }\r\n\r\n        if (this.validationFailedBind)\r\n            this.tooltip.show();\r\n    }\r\n\r\n    /**\r\n     * Calcola il messaggio da mostrare in base al valore.\r\n     * \r\n     * Entrare in questa funzione significa che lo stato di validazione è fallito, per questo si comporta semplicemente in maniera esclusiva, e cioè:\r\n     * \r\n     * 1) Se ero required e sono senza valore --> Input richiesto\r\n     * \r\n     * 2) Altrimenti se ho un valore --> Di sicuro il formato è errato\r\n     */\r\n    private inferMessage(): string {\r\n        if (this.required && !this.baseInput.value)\r\n            return this.lc.loc(\"Required Input\")\r\n\r\n        if (this.baseInput.value)\r\n            return this.lc.loc(\"Invalid Input Format\")\r\n    }\r\n\r\n    /**\r\n     * Forza la chiusura del tooltip\r\n     */\r\n    closeTooltip() {\r\n        this.tooltip.hide();\r\n    }\r\n\r\n    /**\r\n     * Controlla se il controllo è valido e in caso lo sia chiude il tooltip\r\n     */\r\n    protected CheckValidity() {\r\n        if (!this.baseInput.statusChanges)\r\n            return;\r\n\r\n        this.baseInput.statusChanges.subscribe(event => {\r\n            if (event === \"VALID\")\r\n                this.tooltip.hide();\r\n        });\r\n    }\r\n\r\n    /**\r\n     * @ignore\r\n     */\r\n    protected propagateChange = (_: any) => { };\r\n\r\n    /**\r\n     * L'emit del focus dell'elemento\r\n     * \r\n     * @param {any} toEmit valore da propagare all'esterno\r\n     */\r\n    onFocus(toEmit) {\r\n        this.inputFocus.emit(toEmit);\r\n    }\r\n\r\n    /**\r\n     * Finalizzazione Input\r\n     */\r\n    onFinalize() {\r\n        this.inputFinalized.emit();\r\n    }\r\n\r\n    /**\r\n     * Subscription alle richieste di focus\r\n     */\r\n    observable: any;\r\n\r\n    /**\r\n     * Registra il Subject per ricevere le richieste di Focus dall'esterno\r\n     */\r\n    registerFocusRequest(): any {\r\n        if(!this.FocusSubject)\r\n            return;\r\n        this.observable = this.FocusSubject.subscribe(t => {\r\n            this.htmlInput.nativeElement.focus();\r\n        });\r\n    }\r\n\r\n    /**\r\n     * Deregistra il Subject delle richieste di focus\r\n     */\r\n    deregisterFocusRequest() {\r\n        if (this.observable)\r\n            this.observable.unsubscribe();\r\n    }\r\n}"]}
|