@esfaenza/forms-and-validations 13.3.15 → 13.4.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/forms/base-form-control.mjs +32 -8
- package/esm2020/lib/forms/form-adaptive/form-adaptive.component.loc.mjs +4 -4
- package/esm2020/lib/forms/form-adaptive/form-adaptive.component.mjs +70 -12
- package/esm2020/lib/forms/form-autocomplete/form-autocomplete.component.loc.mjs +4 -4
- package/esm2020/lib/forms/form-autocomplete/form-autocomplete.component.mjs +11 -9
- package/esm2020/lib/forms/form-checkbox/form-checkbox.component.mjs +5 -4
- package/esm2020/lib/forms/form-date/form-date.component.mjs +5 -5
- package/esm2020/lib/forms/form-datetime/form-datetime.component.mjs +5 -5
- package/esm2020/lib/forms/form-empty/form-empty.component.mjs +4 -4
- package/esm2020/lib/forms/form-error/form-error.component.mjs +4 -4
- package/esm2020/lib/forms/form-file/form-file.component.loc.mjs +4 -4
- package/esm2020/lib/forms/form-file/form-file.component.mjs +23 -9
- package/esm2020/lib/forms/form-info/form-info.component.mjs +4 -4
- package/esm2020/lib/forms/form-input/form-input.component.mjs +5 -5
- package/esm2020/lib/forms/form-multiselect/form-multiselect.component.loc.mjs +4 -4
- package/esm2020/lib/forms/form-multiselect/form-multiselect.component.mjs +4 -4
- package/esm2020/lib/forms/form-select/form-select.component.loc.mjs +4 -4
- package/esm2020/lib/forms/form-select/form-select.component.mjs +10 -6
- package/esm2020/lib/forms/form-template/form-template.component.mjs +5 -5
- package/esm2020/lib/forms/form-textarea/form-textarea.component.mjs +5 -5
- package/esm2020/lib/forms/form-time/form-time.component.mjs +4 -4
- package/esm2020/lib/forms-and-validations.module.mjs +5 -5
- package/esm2020/lib/models/ChangeEvent.mjs +7 -0
- package/esm2020/lib/models/dayjs-adapter/dayjs-date-adapter.mjs +4 -4
- package/esm2020/lib/validations/base-validation.loc.mjs +4 -4
- package/esm2020/lib/validations/base-validation.mjs +40 -10
- package/esm2020/lib/validations/customValidators/CustomRequiredDirective.mjs +4 -4
- package/esm2020/lib/validations/validation-autocomplete/validation-autocomplete.component.mjs +11 -9
- package/esm2020/lib/validations/validation-autocomplete-multi/validation-autocomplete-multi.component.mjs +11 -9
- package/esm2020/lib/validations/validation-currency/validation-currency.component.mjs +8 -6
- package/esm2020/lib/validations/validation-date/validation-date.component.mjs +9 -8
- package/esm2020/lib/validations/validation-datetime/validation-datetime.component.mjs +9 -8
- package/esm2020/lib/validations/validation-input/validation-input.component.mjs +9 -8
- package/esm2020/lib/validations/validation-select/validation-select.component.mjs +11 -10
- package/esm2020/lib/validations/validation-text-area/validation-text-area.component.mjs +8 -6
- package/fesm2015/esfaenza-forms-and-validations.mjs +321 -170
- package/fesm2015/esfaenza-forms-and-validations.mjs.map +1 -1
- package/fesm2020/esfaenza-forms-and-validations.mjs +319 -170
- package/fesm2020/esfaenza-forms-and-validations.mjs.map +1 -1
- package/lib/forms/base-form-control.d.ts +18 -4
- package/lib/forms/form-adaptive/form-adaptive.component.d.ts +20 -3
- package/lib/forms/form-autocomplete/form-autocomplete.component.d.ts +4 -2
- package/lib/forms/form-file/form-file.component.d.ts +7 -4
- package/lib/forms/form-select/form-select.component.d.ts +4 -2
- package/lib/models/ChangeEvent.d.ts +5 -0
- package/lib/validations/base-validation.d.ts +23 -2
- package/lib/validations/validation-autocomplete/validation-autocomplete.component.d.ts +3 -3
- package/lib/validations/validation-autocomplete-multi/validation-autocomplete-multi.component.d.ts +3 -3
- package/lib/validations/validation-date/validation-date.component.d.ts +0 -1
- package/lib/validations/validation-datetime/validation-datetime.component.d.ts +0 -1
- package/lib/validations/validation-input/validation-input.component.d.ts +0 -1
- package/lib/validations/validation-select/validation-select.component.d.ts +0 -1
- package/package.json +12 -12
|
@@ -2,6 +2,8 @@
|
|
|
2
2
|
import { EventEmitter, Input, Output, ViewChild, Directive } from "@angular/core";
|
|
3
3
|
// Direttive, Componenti, Librerie
|
|
4
4
|
import { TooltipDirective } from "ngx-bootstrap/tooltip";
|
|
5
|
+
import { Subject } from "rxjs";
|
|
6
|
+
import { takeUntil } from "rxjs/operators";
|
|
5
7
|
import * as i0 from "@angular/core";
|
|
6
8
|
/**
|
|
7
9
|
* Classe astratta base che contiene le logiche / proprietà in comune a tutti i validatori
|
|
@@ -9,7 +11,9 @@ import * as i0 from "@angular/core";
|
|
|
9
11
|
* Nota bene: I tooltip rallentano tantissimo la pagina perché il tizio che ha fatto ngx bootstrap non è capace
|
|
10
12
|
*/
|
|
11
13
|
export class BaseValidation {
|
|
12
|
-
|
|
14
|
+
/** @ignore Constructor */
|
|
15
|
+
constructor(cdr) {
|
|
16
|
+
this.cdr = cdr;
|
|
13
17
|
/**
|
|
14
18
|
* Variabile per tenere in memoria il fatto che il componente è forzato a invalido o no
|
|
15
19
|
*/
|
|
@@ -93,6 +97,7 @@ export class BaseValidation {
|
|
|
93
97
|
* Evento che indica la finalizzazione del valore avvenuta su un controllo
|
|
94
98
|
*/
|
|
95
99
|
this.inputFinalized = new EventEmitter();
|
|
100
|
+
this.destroyed$ = new Subject();
|
|
96
101
|
/**
|
|
97
102
|
* @ignore
|
|
98
103
|
*/
|
|
@@ -142,13 +147,32 @@ export class BaseValidation {
|
|
|
142
147
|
set forceInvalid(val) {
|
|
143
148
|
this._forceInvalid = val;
|
|
144
149
|
if (val)
|
|
145
|
-
setTimeout(() =>
|
|
150
|
+
setTimeout(() => {
|
|
151
|
+
this.baseInput.control.setErrors({ forcedtoinvalid: true });
|
|
152
|
+
this.baseInput.control.markAsTouched();
|
|
153
|
+
this.baseInput.control.markAsDirty();
|
|
154
|
+
this.cdr.detectChanges();
|
|
155
|
+
});
|
|
146
156
|
else
|
|
147
157
|
setTimeout(() => {
|
|
148
158
|
this.baseInput.control.setErrors({ forcedtoinvalid: null });
|
|
149
159
|
this.baseInput.control.updateValueAndValidity();
|
|
150
160
|
});
|
|
151
161
|
}
|
|
162
|
+
ngOnInit() {
|
|
163
|
+
if (this.SetValidationSubject) {
|
|
164
|
+
this.SetValidationSubject.pipe(takeUntil(this.destroyed$)).subscribe(v => {
|
|
165
|
+
if (v.fieldName + "_internal" == this.id) {
|
|
166
|
+
this.forceInvalid = true;
|
|
167
|
+
this.showTooltipWithMessage(v.error);
|
|
168
|
+
}
|
|
169
|
+
});
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
ngOnDestroy() {
|
|
173
|
+
this.destroyed$.next();
|
|
174
|
+
this.destroyed$.complete();
|
|
175
|
+
}
|
|
152
176
|
/**
|
|
153
177
|
* Helper che controlla se il tooltip deve essere mostrato o meno,
|
|
154
178
|
* richiamato direttamente dall'HTML dei componenti
|
|
@@ -160,9 +184,13 @@ export class BaseValidation {
|
|
|
160
184
|
/**
|
|
161
185
|
* Helper che calcola il messaggio da mostrare nel tooltip che andrà ad aprire
|
|
162
186
|
*/
|
|
163
|
-
showTooltipWithMessage() {
|
|
164
|
-
|
|
165
|
-
if (this.
|
|
187
|
+
showTooltipWithMessage(messageOverride = null) {
|
|
188
|
+
// Aggiorno il messaggio di validazione solo se il valore è diverso dall'ultimo valore ricevuto
|
|
189
|
+
if (this.valueOnLastValidation != this.baseInput.value) {
|
|
190
|
+
this.validationFailedBind = messageOverride || this.validationFailed || (this.InferErrorMessages ? this.inferMessage() : "");
|
|
191
|
+
this.valueOnLastValidation = this.baseInput.value;
|
|
192
|
+
}
|
|
193
|
+
if (this.validationFailedBind)
|
|
166
194
|
this.tooltip.show();
|
|
167
195
|
}
|
|
168
196
|
/**
|
|
@@ -236,11 +264,11 @@ export class BaseValidation {
|
|
|
236
264
|
this.observable.unsubscribe();
|
|
237
265
|
}
|
|
238
266
|
}
|
|
239
|
-
BaseValidation.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.
|
|
240
|
-
BaseValidation.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.
|
|
241
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.
|
|
267
|
+
BaseValidation.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: BaseValidation, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
268
|
+
BaseValidation.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.4.0", 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 });
|
|
269
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: BaseValidation, decorators: [{
|
|
242
270
|
type: Directive
|
|
243
|
-
}], propDecorators: { tooltip: [{
|
|
271
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { tooltip: [{
|
|
244
272
|
type: ViewChild,
|
|
245
273
|
args: [TooltipDirective, { static: false }]
|
|
246
274
|
}], tooltip_static: [{
|
|
@@ -257,6 +285,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
|
|
|
257
285
|
args: ["baseInput", { static: true }]
|
|
258
286
|
}], FocusSubject: [{
|
|
259
287
|
type: Input
|
|
288
|
+
}], SetValidationSubject: [{
|
|
289
|
+
type: Input
|
|
260
290
|
}], InferErrorMessages: [{
|
|
261
291
|
type: Input
|
|
262
292
|
}], FieldAppearence: [{
|
|
@@ -297,4 +327,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
|
|
|
297
327
|
}], forceInvalid: [{
|
|
298
328
|
type: Input
|
|
299
329
|
}] } });
|
|
300
|
-
//# 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 } from \"@angular/core\";\r\nimport { NgModel } 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\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    /**\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     * 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(() => this.baseInput.control.setErrors({ forcedtoinvalid: true }));\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\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() {\r\n        this.validationFailed = this.validationFailed ? this.validationFailed : this.InferErrorMessages ? this.inferMessage() : \"\";\r\n        if (this.validationFailed)\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    setDisabledState?(isDisabled: boolean): void {\r\n        isDisabled ? this.baseInput.control.disable() : this.baseInput.control.enable();\r\n        this.readonly = isDisabled;\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}"]}
|
|
330
|
+
//# 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 } 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    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    setDisabledState?(isDisabled: boolean): void {\r\n        isDisabled ? this.baseInput.control.disable() : this.baseInput.control.enable();\r\n        this.readonly = isDisabled;\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}"]}
|
|
@@ -23,9 +23,9 @@ export class CustomRequiredDirective {
|
|
|
23
23
|
return !c.value || this.NullValues.includes(c.value) ? { required: true } : null;
|
|
24
24
|
}
|
|
25
25
|
}
|
|
26
|
-
CustomRequiredDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.
|
|
27
|
-
CustomRequiredDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.
|
|
28
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.
|
|
26
|
+
CustomRequiredDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: CustomRequiredDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
|
|
27
|
+
CustomRequiredDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.4.0", type: CustomRequiredDirective, selector: "[customRequired]", inputs: { NullValues: ["CustomNullValues", "NullValues"], customRequired: "customRequired" }, providers: [{ provide: NG_VALIDATORS, useExisting: CustomRequiredDirective, multi: true }], ngImport: i0 });
|
|
28
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: CustomRequiredDirective, decorators: [{
|
|
29
29
|
type: Directive,
|
|
30
30
|
args: [{
|
|
31
31
|
selector: '[customRequired]',
|
|
@@ -38,4 +38,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
|
|
|
38
38
|
type: Input,
|
|
39
39
|
args: ['customRequired']
|
|
40
40
|
}] } });
|
|
41
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
41
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ3VzdG9tUmVxdWlyZWREaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9mb3Jtcy1hbmQtdmFsaWRhdGlvbnMvc3JjL2xpYi92YWxpZGF0aW9ucy9jdXN0b21WYWxpZGF0b3JzL0N1c3RvbVJlcXVpcmVkRGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLFVBQVU7QUFDVixPQUFPLEVBQW1CLGFBQWEsRUFBYSxNQUFNLGdCQUFnQixDQUFDO0FBQzNFLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUVqRDs7O0dBR0c7QUFLSCxNQUFNLE9BQU8sdUJBQXVCO0lBSnBDO1FBTUk7O1dBRUc7UUFDd0IsZUFBVSxHQUFhLEVBQUUsQ0FBQztLQWlCeEQ7SUFWRzs7T0FFRztJQUNILFFBQVEsQ0FBQyxDQUFrQjtRQUN2QixvRkFBb0Y7UUFDcEYsSUFBSSxJQUFJLENBQUMsY0FBYyxJQUFJLE1BQU07WUFDN0IsT0FBTyxJQUFJLENBQUM7UUFFaEIsT0FBTyxDQUFDLENBQUMsQ0FBQyxLQUFLLElBQUksSUFBSSxDQUFDLFVBQVUsQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLFFBQVEsRUFBRSxJQUFJLEVBQUUsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDO0lBQ3JGLENBQUM7O29IQXJCUSx1QkFBdUI7d0dBQXZCLHVCQUF1Qix5SUFGckIsQ0FBQyxFQUFFLE9BQU8sRUFBRSxhQUFhLEVBQUUsV0FBVyxFQUFFLHVCQUF1QixFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUUsQ0FBQzsyRkFFakYsdUJBQXVCO2tCQUpuQyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxrQkFBa0I7b0JBQzVCLFNBQVMsRUFBRSxDQUFDLEVBQUUsT0FBTyxFQUFFLGFBQWEsRUFBRSxXQUFXLHlCQUF5QixFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUUsQ0FBQztpQkFDN0Y7OEJBTThCLFVBQVU7c0JBQXBDLEtBQUs7dUJBQUMsa0JBQWtCO2dCQUtPLGNBQWM7c0JBQTdDLEtBQUs7dUJBQUMsZ0JBQWdCIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQW5ndWxhclxyXG5pbXBvcnQgeyBBYnN0cmFjdENvbnRyb2wsIE5HX1ZBTElEQVRPUlMsIFZhbGlkYXRvciB9IGZyb20gXCJAYW5ndWxhci9mb3Jtc1wiO1xyXG5pbXBvcnQgeyBEaXJlY3RpdmUsIElucHV0IH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcclxuXHJcbi8qKlxyXG4gKiBEaXJldHRpdmEgdXRpbGl6emF0YSBwZXIgdmFsaWRhemlvbmkgXCJyZXF1aXJlZFwiIGN1c3RvbSwgaW4gbW9kbyBkYSBwb3RlciBkaXJlIGNoZSBhbmNoZSBzZSBjJ8OoIHVuIHZhbG9yZSBzZWxlemlvbmF0bywgbWEgcXVlbCB2YWxvcmUgbG8gY29uc2lkZXJvIG51bGwgXHJcbiAqIGFsbG9yYSBsYSB2YWxpZGF6aW9uZSBmYWxsaXNjZS4gQXR0dWFsbWVudGUgdXNhdG8gbmVsbCd1bmljbyBwdW50byBzZW5zYXRvOiB2YWxpZGF0aW9uLXNlbGVjdFxyXG4gKi9cclxuQERpcmVjdGl2ZSh7XHJcbiAgICBzZWxlY3RvcjogJ1tjdXN0b21SZXF1aXJlZF0nLFxyXG4gICAgcHJvdmlkZXJzOiBbeyBwcm92aWRlOiBOR19WQUxJREFUT1JTLCB1c2VFeGlzdGluZzogQ3VzdG9tUmVxdWlyZWREaXJlY3RpdmUsIG11bHRpOiB0cnVlIH1dXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDdXN0b21SZXF1aXJlZERpcmVjdGl2ZSBpbXBsZW1lbnRzIFZhbGlkYXRvciB7XHJcblxyXG4gICAgLyoqXHJcbiAgICAgKiBMaXN0YSBkaSB2YWxvcmkgY2hlIHZlbmdvbm8gY29uc2lkZXJhdGkgXCJ2dW90aVwiIHNlcHB1ciBwcmVzZW50aVxyXG4gICAgICovXHJcbiAgICBASW5wdXQoXCJDdXN0b21OdWxsVmFsdWVzXCIpIE51bGxWYWx1ZXM6IHN0cmluZ1tdID0gW107XHJcblxyXG4gICAgLyoqXHJcbiAgICAgKiBib29sZWFubyBpbiBtb2RhbGl0w6Agc3RyaW5nYSAoXCJ0cnVlXCIgbyBcImZhbHNlXCIpIGNoZSBpbmRpY2Egc2UgYXBwbGljYXJlIGxhIHZhbGlkYXppb25lIGRpIG9iYmxpZ2F0b3JpZXTDoCBvIG1lbm9cclxuICAgICAqL1xyXG4gICAgQElucHV0KCdjdXN0b21SZXF1aXJlZCcpIHB1YmxpYyBjdXN0b21SZXF1aXJlZDogc3RyaW5nO1xyXG5cclxuICAgIC8qKlxyXG4gICAgICogQGlnbm9yZVxyXG4gICAgICovXHJcbiAgICB2YWxpZGF0ZShjOiBBYnN0cmFjdENvbnRyb2wpOiB7IFtrZXk6IHN0cmluZ106IGFueTsgfSB7XHJcbiAgICAgICAgLy8gQ29udHJvbGxvIHNvbG8gcGVyIGN1c3RvbSByZXF1aXJlZCBhIHRydWUsIGFsdHJpbWVudGkgcXVhbHNpYXNpIHZhbG9yZSBtaSB2YSBiZW5lXHJcbiAgICAgICAgaWYgKHRoaXMuY3VzdG9tUmVxdWlyZWQgIT0gXCJ0cnVlXCIpXHJcbiAgICAgICAgICAgIHJldHVybiBudWxsO1xyXG5cclxuICAgICAgICByZXR1cm4gIWMudmFsdWUgfHwgdGhpcy5OdWxsVmFsdWVzLmluY2x1ZGVzKGMudmFsdWUpID8geyByZXF1aXJlZDogdHJ1ZSB9IDogbnVsbDtcclxuICAgIH1cclxufSJdfQ==
|
package/esm2020/lib/validations/validation-autocomplete/validation-autocomplete.component.mjs
CHANGED
|
@@ -20,8 +20,8 @@ import * as i8 from "ngx-bootstrap/tooltip";
|
|
|
20
20
|
*/
|
|
21
21
|
export class ValidationAutocompleteComponent extends BaseValidation {
|
|
22
22
|
/** @ignore */
|
|
23
|
-
constructor(_validators, _asyncValidators, injector, lc) {
|
|
24
|
-
super();
|
|
23
|
+
constructor(cdr, _validators, _asyncValidators, injector, lc) {
|
|
24
|
+
super(cdr);
|
|
25
25
|
this._validators = _validators;
|
|
26
26
|
this._asyncValidators = _asyncValidators;
|
|
27
27
|
this.injector = injector;
|
|
@@ -37,6 +37,7 @@ export class ValidationAutocompleteComponent extends BaseValidation {
|
|
|
37
37
|
}
|
|
38
38
|
/** @ignore */
|
|
39
39
|
ngOnInit() {
|
|
40
|
+
super.ngOnInit();
|
|
40
41
|
this.registerFocusRequest();
|
|
41
42
|
//controllo se è settato un required per decidere in maniera condizionale se utilizzare il validatore required nel componente interno
|
|
42
43
|
if (this._validators && !this.noValidate && this._validators.some(elem => elem instanceof RequiredValidator))
|
|
@@ -44,6 +45,7 @@ export class ValidationAutocompleteComponent extends BaseValidation {
|
|
|
44
45
|
}
|
|
45
46
|
/** @ignore */
|
|
46
47
|
ngOnDestroy() {
|
|
48
|
+
super.ngOnDestroy();
|
|
47
49
|
this.deregisterFocusRequest();
|
|
48
50
|
if (this.tooltipSubscription)
|
|
49
51
|
this.tooltipSubscription.unsubscribe();
|
|
@@ -106,16 +108,16 @@ export class ValidationAutocompleteComponent extends BaseValidation {
|
|
|
106
108
|
this.onTouched = fn;
|
|
107
109
|
}
|
|
108
110
|
}
|
|
109
|
-
ValidationAutocompleteComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.
|
|
110
|
-
ValidationAutocompleteComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.
|
|
111
|
+
ValidationAutocompleteComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: ValidationAutocompleteComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: NG_VALIDATORS, optional: true }, { token: NG_ASYNC_VALIDATORS, optional: true }, { token: i0.Injector }, { token: i1.LocalizationService }], target: i0.ɵɵFactoryTarget.Component });
|
|
112
|
+
ValidationAutocompleteComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.4.0", type: ValidationAutocompleteComponent, selector: "val-autocomplete", inputs: { FilteredSource: "FilteredSource", value: "value", label: "label" }, outputs: { optionChange: "optionChange" }, providers: [
|
|
111
113
|
{ provide: LocalizationService, useClass: BaseValidationLoc },
|
|
112
114
|
{
|
|
113
115
|
provide: NG_VALUE_ACCESSOR,
|
|
114
116
|
useExisting: forwardRef(() => ValidationAutocompleteComponent),
|
|
115
117
|
multi: true
|
|
116
118
|
}
|
|
117
|
-
], usesInheritance: true, ngImport: i0, template: "<!-- Val-Model: {{value}} -->\r\n<mat-form-field appearance=\"{{FieldAppearence}}\" class=\"mat-full-width mat-no-border-top mat-height-fixed\" [style.width.px]=\"widthPx\">\r\n <mat-label *ngIf=\"label\">{{label}}</mat-label>\r\n <input matInput\r\n #htmlInput\r\n #baseInput='ngModel'\r\n type=\"text\"\r\n triggers=\"\"\r\n placement=\"top\"\r\n placeholder=\"{{placeholder}}\"\r\n [matAutocomplete]=\"auto\"\r\n name=\"val-input\"\r\n id=\"{{id}}\"\r\n class=\"form-control {{class}}\"\r\n [(ngModel)]=\"value\"\r\n [class.checking-field]=\"!noValidate\"\r\n [tooltip]=\"tolTemplate\"\r\n [disabled]=\"readonly || disabled\"\r\n (ngModelChange)=\"onModelChange($event)\"\r\n (click)=\"onFocus($event)\"\r\n (focus)=\"checkTooltip();\"\r\n (keyup)=\"($event.keyCode == 13 || $event.keyCode == 27) && onFinalize();\"\r\n (blur)=\"closeTooltip(); onFinalize();\">\r\n\r\n <mat-autocomplete autoActiveFirstOption #auto=\"matAutocomplete\">\r\n <mat-option *ngFor=\"let option of FilteredSource\" [value]=\"option.id\">\r\n {{option.description}}\r\n </mat-option>\r\n </mat-autocomplete>\r\n</mat-form-field>\r\n\r\n<ng-template #tolTemplate>\r\n <div (click)=\"closeTooltip()\">\r\n <span>{{
|
|
118
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.
|
|
119
|
+
], usesInheritance: true, ngImport: i0, template: "<!-- Val-Model: {{value}} -->\r\n<mat-form-field appearance=\"{{FieldAppearence}}\" class=\"mat-full-width mat-no-border-top mat-height-fixed\" [style.width.px]=\"widthPx\">\r\n <mat-label *ngIf=\"label\">{{label}}</mat-label>\r\n <input matInput\r\n #htmlInput\r\n #baseInput='ngModel'\r\n type=\"text\"\r\n triggers=\"\"\r\n placement=\"top\"\r\n placeholder=\"{{placeholder}}\"\r\n [matAutocomplete]=\"auto\"\r\n name=\"val-input\"\r\n id=\"{{id}}\"\r\n class=\"form-control {{class}}\"\r\n [(ngModel)]=\"value\"\r\n [class.checking-field]=\"!noValidate\"\r\n [tooltip]=\"tolTemplate\"\r\n [disabled]=\"readonly || disabled\"\r\n (ngModelChange)=\"onModelChange($event)\"\r\n (click)=\"onFocus($event)\"\r\n (focus)=\"checkTooltip();\"\r\n (keyup)=\"($event.keyCode == 13 || $event.keyCode == 27) && onFinalize();\"\r\n (blur)=\"closeTooltip(); onFinalize();\">\r\n\r\n <mat-autocomplete autoActiveFirstOption #auto=\"matAutocomplete\">\r\n <mat-option *ngFor=\"let option of FilteredSource\" [value]=\"option.id\">\r\n {{option.description}}\r\n </mat-option>\r\n </mat-autocomplete>\r\n</mat-form-field>\r\n\r\n<ng-template #tolTemplate>\r\n <div (click)=\"closeTooltip()\">\r\n <span>{{validationFailedBind}}</span>\r\n </div>\r\n</ng-template>", styles: [".tooltip-inner{background-color:#842a30;color:#fff;font-size:12px;width:max-content}.tooltip{margin:auto auto auto 20%!important}.tooltip-inner{background-color:#842a30!important;color:#fff}.tooltip.top .tooltip-arrow:before,.tooltip.top .tooltip-arrow{border-top-color:#842a30}.close-button{position:absolute;right:0em;top:-.2em;float:right;font-size:16px;font-weight:700;color:inherit;text-shadow:0 1px 0 #fff;opacity:.5}.close-button:hover,.close-button:focus{text-decoration:none;cursor:pointer;opacity:.75}\n"], components: [{ type: i2.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { type: i3.MatAutocomplete, selector: "mat-autocomplete", inputs: ["disableRipple"], exportAs: ["matAutocomplete"] }, { type: i4.MatOption, selector: "mat-option", exportAs: ["matOption"] }], directives: [{ type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.MatLabel, selector: "mat-label" }, { type: i6.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "name", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { type: i3.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", exportAs: ["matAutocompleteTrigger"] }, { type: i7.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i7.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i7.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i8.TooltipDirective, selector: "[tooltip], [tooltipHtml]", inputs: ["adaptivePosition", "tooltip", "placement", "triggers", "container", "containerClass", "boundariesElement", "isOpen", "isDisabled", "delay", "tooltipHtml", "tooltipPlacement", "tooltipIsOpen", "tooltipEnable", "tooltipAppendToBody", "tooltipAnimation", "tooltipClass", "tooltipContext", "tooltipPopupDelay", "tooltipFadeDuration", "tooltipTrigger"], outputs: ["tooltipChange", "onShown", "onHidden", "tooltipStateChanged"], exportAs: ["bs-tooltip"] }, { type: i5.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
120
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.4.0", ngImport: i0, type: ValidationAutocompleteComponent, decorators: [{
|
|
119
121
|
type: Component,
|
|
120
122
|
args: [{ selector: "val-autocomplete", changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
121
123
|
{ provide: LocalizationService, useClass: BaseValidationLoc },
|
|
@@ -124,8 +126,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
|
|
|
124
126
|
useExisting: forwardRef(() => ValidationAutocompleteComponent),
|
|
125
127
|
multi: true
|
|
126
128
|
}
|
|
127
|
-
], encapsulation: ViewEncapsulation.None, template: "<!-- Val-Model: {{value}} -->\r\n<mat-form-field appearance=\"{{FieldAppearence}}\" class=\"mat-full-width mat-no-border-top mat-height-fixed\" [style.width.px]=\"widthPx\">\r\n <mat-label *ngIf=\"label\">{{label}}</mat-label>\r\n <input matInput\r\n #htmlInput\r\n #baseInput='ngModel'\r\n type=\"text\"\r\n triggers=\"\"\r\n placement=\"top\"\r\n placeholder=\"{{placeholder}}\"\r\n [matAutocomplete]=\"auto\"\r\n name=\"val-input\"\r\n id=\"{{id}}\"\r\n class=\"form-control {{class}}\"\r\n [(ngModel)]=\"value\"\r\n [class.checking-field]=\"!noValidate\"\r\n [tooltip]=\"tolTemplate\"\r\n [disabled]=\"readonly || disabled\"\r\n (ngModelChange)=\"onModelChange($event)\"\r\n (click)=\"onFocus($event)\"\r\n (focus)=\"checkTooltip();\"\r\n (keyup)=\"($event.keyCode == 13 || $event.keyCode == 27) && onFinalize();\"\r\n (blur)=\"closeTooltip(); onFinalize();\">\r\n\r\n <mat-autocomplete autoActiveFirstOption #auto=\"matAutocomplete\">\r\n <mat-option *ngFor=\"let option of FilteredSource\" [value]=\"option.id\">\r\n {{option.description}}\r\n </mat-option>\r\n </mat-autocomplete>\r\n</mat-form-field>\r\n\r\n<ng-template #tolTemplate>\r\n <div (click)=\"closeTooltip()\">\r\n <span>{{
|
|
128
|
-
}], ctorParameters: function () { return [{ type: Array, decorators: [{
|
|
129
|
+
], encapsulation: ViewEncapsulation.None, template: "<!-- Val-Model: {{value}} -->\r\n<mat-form-field appearance=\"{{FieldAppearence}}\" class=\"mat-full-width mat-no-border-top mat-height-fixed\" [style.width.px]=\"widthPx\">\r\n <mat-label *ngIf=\"label\">{{label}}</mat-label>\r\n <input matInput\r\n #htmlInput\r\n #baseInput='ngModel'\r\n type=\"text\"\r\n triggers=\"\"\r\n placement=\"top\"\r\n placeholder=\"{{placeholder}}\"\r\n [matAutocomplete]=\"auto\"\r\n name=\"val-input\"\r\n id=\"{{id}}\"\r\n class=\"form-control {{class}}\"\r\n [(ngModel)]=\"value\"\r\n [class.checking-field]=\"!noValidate\"\r\n [tooltip]=\"tolTemplate\"\r\n [disabled]=\"readonly || disabled\"\r\n (ngModelChange)=\"onModelChange($event)\"\r\n (click)=\"onFocus($event)\"\r\n (focus)=\"checkTooltip();\"\r\n (keyup)=\"($event.keyCode == 13 || $event.keyCode == 27) && onFinalize();\"\r\n (blur)=\"closeTooltip(); onFinalize();\">\r\n\r\n <mat-autocomplete autoActiveFirstOption #auto=\"matAutocomplete\">\r\n <mat-option *ngFor=\"let option of FilteredSource\" [value]=\"option.id\">\r\n {{option.description}}\r\n </mat-option>\r\n </mat-autocomplete>\r\n</mat-form-field>\r\n\r\n<ng-template #tolTemplate>\r\n <div (click)=\"closeTooltip()\">\r\n <span>{{validationFailedBind}}</span>\r\n </div>\r\n</ng-template>", styles: [".tooltip-inner{background-color:#842a30;color:#fff;font-size:12px;width:max-content}.tooltip{margin:auto auto auto 20%!important}.tooltip-inner{background-color:#842a30!important;color:#fff}.tooltip.top .tooltip-arrow:before,.tooltip.top .tooltip-arrow{border-top-color:#842a30}.close-button{position:absolute;right:0em;top:-.2em;float:right;font-size:16px;font-weight:700;color:inherit;text-shadow:0 1px 0 #fff;opacity:.5}.close-button:hover,.close-button:focus{text-decoration:none;cursor:pointer;opacity:.75}\n"] }]
|
|
130
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: Array, decorators: [{
|
|
129
131
|
type: Optional
|
|
130
132
|
}, {
|
|
131
133
|
type: Inject,
|
|
@@ -144,4 +146,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.11", ngImpo
|
|
|
144
146
|
}], optionChange: [{
|
|
145
147
|
type: Output
|
|
146
148
|
}] } });
|
|
147
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validation-autocomplete.component.js","sourceRoot":"","sources":["../../../../../../projects/forms-and-validations/src/lib/validations/validation-autocomplete/validation-autocomplete.component.ts","../../../../../../projects/forms-and-validations/src/lib/validations/validation-autocomplete/validation-autocomplete.component.html"],"names":[],"mappings":"AAAA,UAAU;AACV,OAAO,EAAqC,mBAAmB,EAAE,aAAa,EAAE,iBAAiB,EAAE,SAAS,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACxJ,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAc,YAAY,EAAE,UAAU,EAAE,MAAM,EAAY,KAAK,EAAE,QAAQ,EAAE,MAAM,EAAE,iBAAiB,EAAE,MAAM,eAAe,CAAC;AACvK,iBAAiB;AACjB,OAAO,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAE9D,kCAAkC;AAClC,OAAO,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACpD,OAAO,EAAE,iBAAiB,EAAE,MAAM,wBAAwB,CAAC;;;;;;;;;;AAG3D;;GAEG;AAgBH,MAAM,OAAO,+BAAgC,SAAQ,cAAc;IAqB/D,cAAc;IACd,YAAuD,WAAuB,EAAmD,gBAA4B,EAAU,QAAkB,EAAY,EAAuB;QACxN,KAAK,EAAE,CAAC;QAD2C,gBAAW,GAAX,WAAW,CAAY;QAAmD,qBAAgB,GAAhB,gBAAgB,CAAY;QAAU,aAAQ,GAAR,QAAQ,CAAU;QAAY,OAAE,GAAF,EAAE,CAAqB;QAnB5N,yFAAyF;QAChF,mBAAc,GAA0C,EAAE,CAAC;QAKpE,sDAAsD;QACtC,UAAK,GAAW,EAAE,CAAC;QAEnC,mHAAmH;QACzG,iBAAY,GAAyB,IAAI,YAAY,EAAU,CAAC;QA+D1E,cAAc;QACN,cAAS,GAAG,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC,iCAAiC;IArDhE,CAAC;IAED,cAAc;IACd,QAAQ;QACJ,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAE5B,qIAAqI;QACrI,IAAI,IAAI,CAAC,WAAW,IAAI,CAAC,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,YAAY,iBAAiB,CAAC;YACxG,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;IAC7B,CAAC;IAED,cAAc;IACd,WAAW;QACP,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAC9B,IAAI,IAAI,CAAC,mBAAmB;YAAE,IAAI,CAAC,mBAAmB,CAAC,WAAW,EAAE,CAAC;IACzE,CAAC;IAED,cAAc;IACd,eAAe;QACX,IAAI,CAAC,WAAW,EAAE,CAAC;IACvB,CAAC;IAED;;;OAGG;IACK,WAAW;QACf,IAAI,CAAC,aAAa,EAAE,CAAC;QACrB,MAAM,SAAS,GAAc,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;QAChE,IAAI,SAAS,EAAE;YACX,IAAI,CAAC,aAAa,GAAG,SAAS,CAAC,OAAsB,CAAC;YAEtD,sFAAsF;YACtF,IAAI,IAAI,CAAC,UAAU,EAAE;gBACjB,IAAI,CAAC,aAAa,CAAC,eAAe,EAAE,CAAC;gBACrC,IAAI,CAAC,aAAa,CAAC,oBAAoB,EAAE,CAAC;aAC7C;iBACI;gBACD,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,kBAAkB,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;gBACjE,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,aAAa,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;aAC1D;YAED,sHAAsH;YACtH,MAAM,QAAQ,GAAG,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC;YAC1C,IAAI,CAAC,aAAa,CAAC,KAAK,GAAG,GAAG,EAAE;gBAC5B,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;gBACnC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;gBAC/B,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;YACxB,CAAC,CAAC;SACL;IACL,CAAC;IAKD,cAAc;IACd,UAAU,CAAC,KAAU;QACjB,IAAI,GAAG,GAAG,KAAK,IAAI,IAAI,CAAC,cAAc,CAAC,CAAC,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,IAAI,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;QAC7F,IAAG,GAAG;YAAE,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QACvC,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;QAC3C,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,WAAW,CAAC,CAAC,CAAC,KAAK,CAAC;IAC/C,CAAC;IAED;;;;OAIG;IACH,aAAa,CAAC,MAAM;QAChB,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;QACxB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC9B,IAAI,CAAC,SAAS,EAAE,CAAC;IACrB,CAAC;IAED,cAAc;IACd,gBAAgB,CAAC,EAAO;QACpB,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;IAC9B,CAAC;IAED,cAAc;IACd,iBAAiB,CAAC,EAAO;QACrB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;IACxB,CAAC;;6HA1GQ,+BAA+B,kBAsBR,aAAa,6BAAuD,mBAAmB;iHAtB9G,+BAA+B,oKAX7B;QACP,EAAE,OAAO,EAAE,mBAAmB,EAAE,QAAQ,EAAE,iBAAiB,EAAE;QAC7D;YACI,OAAO,EAAE,iBAAiB;YAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,+BAA+B,CAAC;YAC9D,KAAK,EAAE,IAAI;SACd;KACJ,iDCzBL,g9CAmCc;4FDND,+BAA+B;kBAf3C,SAAS;+BACI,kBAAkB,mBAEX,uBAAuB,CAAC,MAAM,aACpC;wBACP,EAAE,OAAO,EAAE,mBAAmB,EAAE,QAAQ,EAAE,iBAAiB,EAAE;wBAC7D;4BACI,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,gCAAgC,CAAC;4BAC9D,KAAK,EAAE,IAAI;yBACd;qBACJ,iBACc,iBAAiB,CAAC,IAAI;0DAyB+B,KAAK;0BAA5D,QAAQ;;0BAAI,MAAM;2BAAC,aAAa;8BAAsG,KAAK;0BAAvE,QAAQ;;0BAAI,MAAM;2BAAC,mBAAmB;qGAlB9G,cAAc;sBAAtB,KAAK;gBAGU,KAAK;sBAApB,KAAK;gBAGU,KAAK;sBAApB,KAAK;gBAGI,YAAY;sBAArB,MAAM","sourcesContent":["// Angular\r\nimport { ControlValueAccessor, FormControl, NG_ASYNC_VALIDATORS, NG_VALIDATORS, NG_VALUE_ACCESSOR, NgControl, RequiredValidator } from \"@angular/forms\";\r\nimport { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, forwardRef, Inject, Injector, Input, Optional, Output, ViewEncapsulation } from \"@angular/core\";\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 di Autocompletamento\r\n */\r\n@Component({\r\n    selector: \"val-autocomplete\",\r\n    templateUrl: \"validation-autocomplete.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(() => ValidationAutocompleteComponent),\r\n            multi: true\r\n        }\r\n    ],\r\n    encapsulation: ViewEncapsulation.None,\r\n    styleUrls: [\"../validation-style.scss\"]\r\n})\r\nexport class ValidationAutocompleteComponent extends BaseValidation implements ControlValueAccessor {\r\n\r\n\r\n    /** Sorgente da cui scegliere valori filtrata in base a quello che ha scritto l'utente */\r\n    @Input() FilteredSource: { id: string, description: string }[] = [];\r\n\r\n    /** Valore del modello */\r\n    @Input() public value: any;\r\n\r\n    /** Contenuto della label Floattante Material-Style */\r\n    @Input() public label: string = \"\";\r\n\r\n    /** Evento che indica l'opzione selezionata dal componente. Il valore finale della selezione dovrà essere questo */\r\n    @Output() optionChange: EventEmitter<string> = new EventEmitter<string>();\r\n\r\n    /** Subscription del tootltip da ripulire alla distruzione del componente */\r\n    private tooltipSubscription: Subscription;\r\n\r\n    /** Controllo esposto ottenuto tramite injector */\r\n    private parentControl: FormControl;\r\n\r\n    /** @ignore */\r\n    constructor(@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    /** @ignore */\r\n    ngOnInit() {\r\n        this.registerFocusRequest();\r\n\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\r\n    /** @ignore */\r\n    ngOnDestroy() {\r\n        this.deregisterFocusRequest();\r\n        if (this.tooltipSubscription) this.tooltipSubscription.unsubscribe();\r\n    }\r\n\r\n    /** @ignore */\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    private 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 = () => { //faccio in modo che se chiamo il reset del controllo (o della form) dall'esterno si resetti anche il controllo nativo\r\n                origFunc.apply(this.parentControl);\r\n                this.baseInput.control.reset();\r\n                this.tooltip.hide();\r\n            };\r\n        }\r\n    }\r\n\r\n    /** @ignore */\r\n    private onTouched = () => { }; //placeholder on touched function\r\n\r\n    /** @ignore */\r\n    writeValue(value: any): void {\r\n        var val = value && this.FilteredSource ? this.FilteredSource.find(t => t.id == value) : null;\r\n        if(val) this.optionChange.emit(val.id);\r\n        this.propagateChange(val ? val.id : value);\r\n        this.value = val ? val.description : value;\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    /** @ignore */\r\n    registerOnChange(fn: any): void {\r\n        this.propagateChange = fn;\r\n    }\r\n\r\n    /** @ignore */\r\n    registerOnTouched(fn: any): void {\r\n        this.onTouched = fn;\r\n    }\r\n}","<!-- Val-Model: {{value}} -->\r\n<mat-form-field appearance=\"{{FieldAppearence}}\" class=\"mat-full-width mat-no-border-top mat-height-fixed\" [style.width.px]=\"widthPx\">\r\n    <mat-label *ngIf=\"label\">{{label}}</mat-label>\r\n    <input matInput\r\n           #htmlInput\r\n           #baseInput='ngModel'\r\n           type=\"text\"\r\n           triggers=\"\"\r\n           placement=\"top\"\r\n           placeholder=\"{{placeholder}}\"\r\n           [matAutocomplete]=\"auto\"\r\n           name=\"val-input\"\r\n           id=\"{{id}}\"\r\n           class=\"form-control {{class}}\"\r\n           [(ngModel)]=\"value\"\r\n           [class.checking-field]=\"!noValidate\"\r\n           [tooltip]=\"tolTemplate\"\r\n           [disabled]=\"readonly || disabled\"\r\n           (ngModelChange)=\"onModelChange($event)\"\r\n           (click)=\"onFocus($event)\"\r\n           (focus)=\"checkTooltip();\"\r\n           (keyup)=\"($event.keyCode == 13 || $event.keyCode == 27) && onFinalize();\"\r\n           (blur)=\"closeTooltip(); onFinalize();\">\r\n\r\n    <mat-autocomplete autoActiveFirstOption #auto=\"matAutocomplete\">\r\n        <mat-option *ngFor=\"let option of FilteredSource\" [value]=\"option.id\">\r\n            {{option.description}}\r\n        </mat-option>\r\n    </mat-autocomplete>\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>"]}
|
|
149
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validation-autocomplete.component.js","sourceRoot":"","sources":["../../../../../../projects/forms-and-validations/src/lib/validations/validation-autocomplete/validation-autocomplete.component.ts","../../../../../../projects/forms-and-validations/src/lib/validations/validation-autocomplete/validation-autocomplete.component.html"],"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, ElementRef, EventEmitter, forwardRef, Inject, Injector, Input, Optional, Output, ViewEncapsulation } from \"@angular/core\";\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 di Autocompletamento\r\n */\r\n@Component({\r\n    selector: \"val-autocomplete\",\r\n    templateUrl: \"validation-autocomplete.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(() => ValidationAutocompleteComponent),\r\n            multi: true\r\n        }\r\n    ],\r\n    encapsulation: ViewEncapsulation.None,\r\n    styleUrls: [\"../validation-style.scss\"]\r\n})\r\nexport class ValidationAutocompleteComponent extends BaseValidation implements ControlValueAccessor {\r\n\r\n\r\n    /** Sorgente da cui scegliere valori filtrata in base a quello che ha scritto l'utente */\r\n    @Input() FilteredSource: { id: string, description: string }[] = [];\r\n\r\n    /** Valore del modello */\r\n    @Input() public value: any;\r\n\r\n    /** Contenuto della label Floattante Material-Style */\r\n    @Input() public label: string = \"\";\r\n\r\n    /** Evento che indica l'opzione selezionata dal componente. Il valore finale della selezione dovrà essere questo */\r\n    @Output() optionChange: EventEmitter<string> = new EventEmitter<string>();\r\n\r\n    /** Subscription del tootltip da ripulire alla distruzione del componente */\r\n    private tooltipSubscription: Subscription;\r\n\r\n    /** Controllo esposto ottenuto tramite injector */\r\n    private parentControl: FormControl;\r\n\r\n    /** @ignore */\r\n    constructor(cdr: ChangeDetectorRef, @Optional() @Inject(NG_VALIDATORS) private _validators: Array<any>, @Optional() @Inject(NG_ASYNC_VALIDATORS) private _asyncValidators: Array<any>, private injector: Injector, protected lc: LocalizationService) {\r\n        super(cdr);\r\n    }\r\n\r\n    /** @ignore */\r\n    ngOnInit() {\r\n        super.ngOnInit();\r\n        this.registerFocusRequest();\r\n\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\r\n    /** @ignore */\r\n    ngOnDestroy() {\r\n        super.ngOnDestroy();\r\n        this.deregisterFocusRequest();\r\n        if (this.tooltipSubscription) this.tooltipSubscription.unsubscribe();\r\n    }\r\n\r\n    /** @ignore */\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    private 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 = () => { //faccio in modo che se chiamo il reset del controllo (o della form) dall'esterno si resetti anche il controllo nativo\r\n                origFunc.apply(this.parentControl);\r\n                this.baseInput.control.reset();\r\n                this.tooltip.hide();\r\n            };\r\n        }\r\n    }\r\n\r\n    /** @ignore */\r\n    private onTouched = () => { }; //placeholder on touched function\r\n\r\n    /** @ignore */\r\n    writeValue(value: any): void {\r\n        var val = value && this.FilteredSource ? this.FilteredSource.find(t => t.id == value) : null;\r\n        if(val) this.optionChange.emit(val.id);\r\n        this.propagateChange(val ? val.id : value);\r\n        this.value = val ? val.description : value;\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    /** @ignore */\r\n    registerOnChange(fn: any): void {\r\n        this.propagateChange = fn;\r\n    }\r\n\r\n    /** @ignore */\r\n    registerOnTouched(fn: any): void {\r\n        this.onTouched = fn;\r\n    }\r\n}","<!-- Val-Model: {{value}} -->\r\n<mat-form-field appearance=\"{{FieldAppearence}}\" class=\"mat-full-width mat-no-border-top mat-height-fixed\" [style.width.px]=\"widthPx\">\r\n    <mat-label *ngIf=\"label\">{{label}}</mat-label>\r\n    <input matInput\r\n           #htmlInput\r\n           #baseInput='ngModel'\r\n           type=\"text\"\r\n           triggers=\"\"\r\n           placement=\"top\"\r\n           placeholder=\"{{placeholder}}\"\r\n           [matAutocomplete]=\"auto\"\r\n           name=\"val-input\"\r\n           id=\"{{id}}\"\r\n           class=\"form-control {{class}}\"\r\n           [(ngModel)]=\"value\"\r\n           [class.checking-field]=\"!noValidate\"\r\n           [tooltip]=\"tolTemplate\"\r\n           [disabled]=\"readonly || disabled\"\r\n           (ngModelChange)=\"onModelChange($event)\"\r\n           (click)=\"onFocus($event)\"\r\n           (focus)=\"checkTooltip();\"\r\n           (keyup)=\"($event.keyCode == 13 || $event.keyCode == 27) && onFinalize();\"\r\n           (blur)=\"closeTooltip(); onFinalize();\">\r\n\r\n    <mat-autocomplete autoActiveFirstOption #auto=\"matAutocomplete\">\r\n        <mat-option *ngFor=\"let option of FilteredSource\" [value]=\"option.id\">\r\n            {{option.description}}\r\n        </mat-option>\r\n    </mat-autocomplete>\r\n</mat-form-field>\r\n\r\n<ng-template #tolTemplate>\r\n    <div (click)=\"closeTooltip()\">\r\n        <span>{{validationFailedBind}}</span>\r\n    </div>\r\n</ng-template>"]}
|