@esfaenza/forms-and-validations 11.2.77 → 11.2.80
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/bundles/esfaenza-forms-and-validations.umd.js +234 -49
- package/bundles/esfaenza-forms-and-validations.umd.js.map +1 -1
- package/esfaenza-forms-and-validations.d.ts +2 -1
- package/esfaenza-forms-and-validations.metadata.json +1 -1
- package/esm2015/esfaenza-forms-and-validations.js +3 -2
- package/esm2015/lib/forms/form-autocomplete/form-autocomplete.component.js +21 -7
- package/esm2015/lib/forms/form-multiselect/form-multiselect.component.js +11 -4
- package/esm2015/lib/forms/form-select/form-select.component.js +6 -3
- package/esm2015/lib/forms-and-validations.module.js +9 -1
- package/esm2015/lib/validations/base-validation.loc.js +2 -1
- package/esm2015/lib/validations/validation-autocomplete/validation-autocomplete.component.js +12 -34
- package/esm2015/lib/validations/validation-autocomplete-multi/validation-autocomplete-multi.component.js +175 -0
- package/fesm2015/esfaenza-forms-and-validations.js +223 -46
- package/fesm2015/esfaenza-forms-and-validations.js.map +1 -1
- package/lib/forms/form-autocomplete/form-autocomplete.component.d.ts +4 -0
- package/lib/forms/form-multiselect/form-multiselect.component.d.ts +3 -1
- package/lib/validations/validation-autocomplete/validation-autocomplete.component.d.ts +14 -42
- package/lib/validations/validation-autocomplete-multi/validation-autocomplete-multi.component.d.ts +78 -0
- package/package.json +1 -1
package/esm2015/lib/validations/validation-autocomplete/validation-autocomplete.component.js
CHANGED
|
@@ -10,52 +10,36 @@ import { BaseValidationLoc } from '../base-validation.loc';
|
|
|
10
10
|
* Componente di validaizone per gli input di Autocompletamento
|
|
11
11
|
*/
|
|
12
12
|
export class ValidationAutocompleteComponent extends BaseValidation {
|
|
13
|
-
/**
|
|
14
|
-
* @ignore
|
|
15
|
-
*/
|
|
13
|
+
/** @ignore */
|
|
16
14
|
constructor(_validators, _asyncValidators, injector, lc) {
|
|
17
15
|
super();
|
|
18
16
|
this._validators = _validators;
|
|
19
17
|
this._asyncValidators = _asyncValidators;
|
|
20
18
|
this.injector = injector;
|
|
21
19
|
this.lc = lc;
|
|
22
|
-
/**
|
|
23
|
-
* Sorgente da cui scegliere valori filtrata in base a quello che ha scritto l'utente
|
|
24
|
-
*/
|
|
20
|
+
/** Sorgente da cui scegliere valori filtrata in base a quello che ha scritto l'utente */
|
|
25
21
|
this.FilteredSource = [];
|
|
26
|
-
/**
|
|
27
|
-
* Contenuto della label Floattante Material-Style
|
|
28
|
-
*/
|
|
22
|
+
/** Contenuto della label Floattante Material-Style */
|
|
29
23
|
this.label = "";
|
|
30
|
-
/**
|
|
31
|
-
* Evento che indica l'opzione selezionata dal componente. Il valore finale della selezione dovrà essere questo
|
|
32
|
-
*/
|
|
24
|
+
/** Evento che indica l'opzione selezionata dal componente. Il valore finale della selezione dovrà essere questo */
|
|
33
25
|
this.optionChange = new EventEmitter();
|
|
34
|
-
/**
|
|
35
|
-
* @ignore
|
|
36
|
-
*/
|
|
26
|
+
/** @ignore */
|
|
37
27
|
this.onTouched = () => { }; //placeholder on touched function
|
|
38
28
|
}
|
|
39
|
-
/**
|
|
40
|
-
* @ignore
|
|
41
|
-
*/
|
|
29
|
+
/** @ignore */
|
|
42
30
|
ngOnInit() {
|
|
43
31
|
this.registerFocusRequest();
|
|
44
32
|
//controllo se è settato un required per decidere in maniera condizionale se utilizzare il validatore required nel componente interno
|
|
45
33
|
if (this._validators && !this.noValidate && this._validators.some(elem => elem instanceof RequiredValidator))
|
|
46
34
|
this.required = true;
|
|
47
35
|
}
|
|
48
|
-
/**
|
|
49
|
-
* @ignore
|
|
50
|
-
*/
|
|
36
|
+
/** @ignore */
|
|
51
37
|
ngOnDestroy() {
|
|
52
38
|
this.deregisterFocusRequest();
|
|
53
39
|
if (this.tooltipSubscription)
|
|
54
40
|
this.tooltipSubscription.unsubscribe();
|
|
55
41
|
}
|
|
56
|
-
/**
|
|
57
|
-
* @ignore
|
|
58
|
-
*/
|
|
42
|
+
/** @ignore */
|
|
59
43
|
ngAfterViewInit() {
|
|
60
44
|
this.postBinding();
|
|
61
45
|
}
|
|
@@ -86,9 +70,7 @@ export class ValidationAutocompleteComponent extends BaseValidation {
|
|
|
86
70
|
};
|
|
87
71
|
}
|
|
88
72
|
}
|
|
89
|
-
/**
|
|
90
|
-
* @ignore
|
|
91
|
-
*/
|
|
73
|
+
/** @ignore */
|
|
92
74
|
writeValue(value) {
|
|
93
75
|
var val = value && this.FilteredSource ? this.FilteredSource.find(t => t.id == value) : null;
|
|
94
76
|
if (val)
|
|
@@ -106,15 +88,11 @@ export class ValidationAutocompleteComponent extends BaseValidation {
|
|
|
106
88
|
this.inputChange.emit(toEmit);
|
|
107
89
|
this.onTouched();
|
|
108
90
|
}
|
|
109
|
-
/**
|
|
110
|
-
* @ignore
|
|
111
|
-
*/
|
|
91
|
+
/** @ignore */
|
|
112
92
|
registerOnChange(fn) {
|
|
113
93
|
this.propagateChange = fn;
|
|
114
94
|
}
|
|
115
|
-
/**
|
|
116
|
-
* @ignore
|
|
117
|
-
*/
|
|
95
|
+
/** @ignore */
|
|
118
96
|
registerOnTouched(fn) {
|
|
119
97
|
this.onTouched = fn;
|
|
120
98
|
}
|
|
@@ -148,4 +126,4 @@ ValidationAutocompleteComponent.propDecorators = {
|
|
|
148
126
|
label: [{ type: Input }],
|
|
149
127
|
optionChange: [{ type: Output }]
|
|
150
128
|
};
|
|
151
|
-
//# 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"],"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, EventEmitter, forwardRef, Inject, Injector, Input, Optional, Output, ViewEncapsulation } from \"@angular/core\";\r\n\r\n// Configurazioni\r\nimport { LocalizationService } from \"@esfaenza/localizations\";\r\n\r\n// Direttive, Componenti, Librerie\r\nimport { BaseValidation } from \"../base-validation\";\r\nimport { BaseValidationLoc } from '../base-validation.loc';\r\nimport { Subject, 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     */\r\n    @Input() FilteredSource: { id: string, description: string }[] = [];\r\n\r\n    /**\r\n     * Valore del modello\r\n     */\r\n    @Input() public value: any;\r\n\r\n    /**\r\n     * Contenuto della label Floattante Material-Style\r\n     */\r\n     @Input() public label: string = \"\";\r\n\r\n    /**\r\n     * Evento che indica l'opzione selezionata dal componente. Il valore finale della selezione dovrà essere questo\r\n     */\r\n    @Output() optionChange: EventEmitter<string> = new EventEmitter<string>();\r\n\r\n    /**\r\n     * Subscription del tootltip da ripulire alla distruzione del componente\r\n     */\r\n    private tooltipSubscription: Subscription;\r\n\r\n    /**\r\n     * Controllo esposto ottenuto tramite injector\r\n     */\r\n    private parentControl: FormControl;\r\n\r\n    /**\r\n     * @ignore\r\n     */\r\n    constructor(@Optional() @Inject(NG_VALIDATORS) private _validators: Array<any>, @Optional() @Inject(NG_ASYNC_VALIDATORS) private _asyncValidators: Array<any>, private injector: Injector, protected lc: LocalizationService) {\r\n        super();\r\n    }\r\n\r\n    /**\r\n     * @ignore\r\n     */\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    /**\r\n     * @ignore\r\n     */\r\n    ngOnDestroy() {\r\n        this.deregisterFocusRequest();\r\n        if (this.tooltipSubscription) this.tooltipSubscription.unsubscribe();\r\n    }\r\n\r\n    /**\r\n     * @ignore\r\n     */\r\n    ngAfterViewInit() {\r\n        this.postBinding();\r\n    }\r\n\r\n    /**\r\n     * Metodo che si occupa di collegare i validatori e la funzione di reset dal **ControlValueAccessor** rappresentato \r\n     * da questo componente al **ControlValueAccessor** rappresentato dall'effettivo elemento di Input presente lato HTML\r\n     */\r\n    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    /**\r\n     * @ignore\r\n     */\r\n    private onTouched = () => { }; //placeholder on touched function\r\n\r\n    /**\r\n     * @ignore\r\n     */\r\n    writeValue(value: any): void {\r\n        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    /**\r\n     * @ignore\r\n     */\r\n    registerOnChange(fn: any): void {\r\n        this.propagateChange = fn;\r\n    }\r\n\r\n    /**\r\n     * @ignore\r\n     */\r\n    registerOnTouched(fn: any): void {\r\n        this.onTouched = fn;\r\n    }\r\n}"]}
|
|
129
|
+
//# 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"],"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, 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}"]}
|
|
@@ -0,0 +1,175 @@
|
|
|
1
|
+
// Angular
|
|
2
|
+
import { NG_ASYNC_VALIDATORS, NG_VALIDATORS, NG_VALUE_ACCESSOR, NgControl, RequiredValidator } from "@angular/forms";
|
|
3
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, forwardRef, Inject, Injector, Input, Optional, Output, ViewChild, ViewEncapsulation } from "@angular/core";
|
|
4
|
+
// Configurazioni
|
|
5
|
+
import { LocalizationService } from "@esfaenza/localizations";
|
|
6
|
+
// Direttive, Componenti, Librerie
|
|
7
|
+
import { BaseValidation } from "../base-validation";
|
|
8
|
+
import { BaseValidationLoc } from '../base-validation.loc';
|
|
9
|
+
import { MatAutocompleteTrigger } from "@angular/material/autocomplete";
|
|
10
|
+
/**
|
|
11
|
+
* Componente di validaizone per gli input di Autocompletamento
|
|
12
|
+
*/
|
|
13
|
+
export class ValidationAutocompleteMultiComponent extends BaseValidation {
|
|
14
|
+
/** @ignore */
|
|
15
|
+
constructor(_validators, _asyncValidators, injector, lc) {
|
|
16
|
+
super();
|
|
17
|
+
this._validators = _validators;
|
|
18
|
+
this._asyncValidators = _asyncValidators;
|
|
19
|
+
this.injector = injector;
|
|
20
|
+
this.lc = lc;
|
|
21
|
+
this.displayFn = () => '';
|
|
22
|
+
/** Numero massimo di chip visualizzate */
|
|
23
|
+
this.ChipThreshold = 10;
|
|
24
|
+
/** Sorgente da cui scegliere valori filtrata in base a quello che ha scritto l'utente */
|
|
25
|
+
this.FilteredSource = [];
|
|
26
|
+
/** Contenuto della label Floattante Material-Style */
|
|
27
|
+
this.label = "";
|
|
28
|
+
/** Evento che indica l'opzione selezionata dal componente. Il valore finale della selezione dovrà essere questo */
|
|
29
|
+
this.optionChange = new EventEmitter();
|
|
30
|
+
/** Elementi selezionati */
|
|
31
|
+
this.selectData = [];
|
|
32
|
+
/** @ignore */
|
|
33
|
+
this.onTouched = () => { }; //placeholder on touched function
|
|
34
|
+
}
|
|
35
|
+
/** @ignore */
|
|
36
|
+
ngOnInit() {
|
|
37
|
+
this.registerFocusRequest();
|
|
38
|
+
//controllo se è settato un required per decidere in maniera condizionale se utilizzare il validatore required nel componente interno
|
|
39
|
+
if (this._validators && !this.noValidate && this._validators.some(elem => elem instanceof RequiredValidator))
|
|
40
|
+
this.required = true;
|
|
41
|
+
}
|
|
42
|
+
/** @ignore */
|
|
43
|
+
ngOnDestroy() {
|
|
44
|
+
this.deregisterFocusRequest();
|
|
45
|
+
if (this.tooltipSubscription)
|
|
46
|
+
this.tooltipSubscription.unsubscribe();
|
|
47
|
+
}
|
|
48
|
+
/** @ignore */
|
|
49
|
+
ngAfterViewInit() {
|
|
50
|
+
this.postBinding();
|
|
51
|
+
}
|
|
52
|
+
/** In caso arrivi una nuova sorgente devo reimpostare lo stato di selezione con quello attuale */
|
|
53
|
+
ngOnChanges(changes) {
|
|
54
|
+
let newSource = changes["FilteredSource"];
|
|
55
|
+
if (!newSource || newSource.firstChange)
|
|
56
|
+
return;
|
|
57
|
+
for (let i = 0; i < this.FilteredSource.length; i++) {
|
|
58
|
+
let item = this.FilteredSource[i];
|
|
59
|
+
item.selected = this.selectData.find(t => t.id == item.id);
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
/**
|
|
63
|
+
* Metodo che si occupa di collegare i validatori e la funzione di reset dal **ControlValueAccessor** rappresentato
|
|
64
|
+
* da questo componente al **ControlValueAccessor** rappresentato dall'effettivo elemento di Input presente lato HTML
|
|
65
|
+
*/
|
|
66
|
+
postBinding() {
|
|
67
|
+
this.CheckValidity();
|
|
68
|
+
const ngControl = this.injector.get(NgControl, null);
|
|
69
|
+
if (ngControl) {
|
|
70
|
+
this.parentControl = ngControl.control;
|
|
71
|
+
//se la variabile novalidate è true, elimino tutti i validatori eventualmente inseriti
|
|
72
|
+
if (this.noValidate) {
|
|
73
|
+
this.parentControl.clearValidators();
|
|
74
|
+
this.parentControl.clearAsyncValidators();
|
|
75
|
+
}
|
|
76
|
+
else {
|
|
77
|
+
this.baseInput.control.setAsyncValidators(this._asyncValidators);
|
|
78
|
+
this.baseInput.control.setValidators(this._validators);
|
|
79
|
+
}
|
|
80
|
+
//faccio in modo che se chiamo il reset del controllo (o della form) dall'esterno si resetti anche il controllo nativo
|
|
81
|
+
const origFunc = this.parentControl.reset;
|
|
82
|
+
this.parentControl.reset = () => {
|
|
83
|
+
origFunc.apply(this.parentControl);
|
|
84
|
+
this.baseInput.control.reset();
|
|
85
|
+
this.tooltip.hide();
|
|
86
|
+
};
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
/** @ignore */
|
|
90
|
+
writeValue(value, finalValue = false) {
|
|
91
|
+
var val = value && this.FilteredSource ? this.FilteredSource.find(t => t.id == value) : null;
|
|
92
|
+
if (finalValue)
|
|
93
|
+
this.optionChange.emit(value);
|
|
94
|
+
this.propagateChange(val ? val.id : value);
|
|
95
|
+
this.value = val ? val.description : value;
|
|
96
|
+
}
|
|
97
|
+
/**
|
|
98
|
+
* L'emit della modifica al valore viene gestito su un evento custom (**inputChange**) come workaround al malfunzionamento dell'**ngModelChange** nativo
|
|
99
|
+
*
|
|
100
|
+
* @param {any} toEmit valore da propagare all'esterno
|
|
101
|
+
*/
|
|
102
|
+
onModelChange(toEmit, finalValue = false) {
|
|
103
|
+
this.writeValue(toEmit, finalValue);
|
|
104
|
+
if (!finalValue)
|
|
105
|
+
this.inputChange.emit(toEmit);
|
|
106
|
+
this.onTouched();
|
|
107
|
+
}
|
|
108
|
+
/** @ignore */
|
|
109
|
+
registerOnChange(fn) {
|
|
110
|
+
this.propagateChange = fn;
|
|
111
|
+
}
|
|
112
|
+
/** @ignore */
|
|
113
|
+
registerOnTouched(fn) {
|
|
114
|
+
this.onTouched = fn;
|
|
115
|
+
}
|
|
116
|
+
/** Rimuove un elemento selezionato */
|
|
117
|
+
removeChip(data) {
|
|
118
|
+
if (!data) {
|
|
119
|
+
this.selectData = [];
|
|
120
|
+
this.FilteredSource.forEach(data => data.selected = false);
|
|
121
|
+
this.onModelChange(this.selectData.map(t => t.id).join(','), true);
|
|
122
|
+
this.onFinalize();
|
|
123
|
+
}
|
|
124
|
+
else
|
|
125
|
+
this.toggleSelection(data);
|
|
126
|
+
}
|
|
127
|
+
;
|
|
128
|
+
/** Seleziona o deseleziona un oggetto */
|
|
129
|
+
toggleSelection(data) {
|
|
130
|
+
data.selected = !data.selected;
|
|
131
|
+
if (data.selected === true) {
|
|
132
|
+
this.selectData.push(data);
|
|
133
|
+
}
|
|
134
|
+
else {
|
|
135
|
+
const i = this.selectData.findIndex(value => value.id === data.id);
|
|
136
|
+
this.selectData.splice(i, 1);
|
|
137
|
+
}
|
|
138
|
+
this.value = null;
|
|
139
|
+
this.onModelChange(this.selectData.map(t => t.id).join(','), true);
|
|
140
|
+
this.onFinalize();
|
|
141
|
+
}
|
|
142
|
+
;
|
|
143
|
+
}
|
|
144
|
+
ValidationAutocompleteMultiComponent.decorators = [
|
|
145
|
+
{ type: Component, args: [{
|
|
146
|
+
selector: "val-autocomplete-multi",
|
|
147
|
+
template: "<mat-form-field appearance=\"{{FieldAppearence}}\" class=\"mat-full-width mat-no-border-top\" [style.width.px]=\"widthPx\">\r\n <mat-label *ngIf=\"label\">{{label}}</mat-label>\r\n <mat-chip-list #chipList>\r\n <ng-container *ngIf=\"selectData.length < ChipThreshold\" >\r\n <mat-chip *ngFor=\"let select of selectData\" class=\"cardinal-colors\" (click)=\"!(readonly || disabled) && removeChip(select)\">\r\n {{ select.description }}\r\n <mat-icon class=\"mat-chip-remove\">cancel</mat-icon>\r\n </mat-chip>\r\n </ng-container>\r\n\r\n <mat-chip *ngIf=\"selectData.length >= ChipThreshold\" class=\"cardinal-colors\" (click)=\"!(readonly || disabled) && removeChip(null)\">\r\n {{ selectData.length }} {{ 'Elements selected' | localize: lc }}\r\n <mat-icon class=\"mat-chip-remove\">cancel</mat-icon>\r\n </mat-chip>\r\n \r\n <input matInput\r\n [matChipInputFor]=\"chipList\"\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 [(ngModel)]=\"value\"\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 (blur)=\"closeTooltip();\">\r\n </mat-chip-list>\r\n\r\n <mat-autocomplete #auto=\"matAutocomplete\" [displayWith]=\"displayFn\">\r\n <mat-option *ngFor=\"let data of FilteredSource\">\r\n <div (click)=\"toggleSelection(data); $event.stopPropagation()\">\r\n <mat-checkbox [checked]=\"data.selected\" (change)=\"toggleSelection(data);\" (click)=\"$event.stopPropagation()\">\r\n {{ data.description }}\r\n </mat-checkbox>\r\n </div>\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>",
|
|
148
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
149
|
+
providers: [
|
|
150
|
+
{ provide: LocalizationService, useClass: BaseValidationLoc },
|
|
151
|
+
{
|
|
152
|
+
provide: NG_VALUE_ACCESSOR,
|
|
153
|
+
useExisting: forwardRef(() => ValidationAutocompleteMultiComponent),
|
|
154
|
+
multi: true
|
|
155
|
+
}
|
|
156
|
+
],
|
|
157
|
+
encapsulation: ViewEncapsulation.None,
|
|
158
|
+
styles: [".tooltip-inner{background-color:#842a30;font-size:12px;width:-webkit-max-content;width:-moz-max-content;width:max-content}.tooltip{margin:auto auto auto 20%!important}.tooltip-inner{background-color:#842a30!important;color:#fff}.tooltip.top .tooltip-arrow,.tooltip.top .tooltip-arrow:before{border-top-color:#842a30}.close-button{position:absolute;right:0;top:-.2em;float:right;font-size:16px;font-weight:700;color:inherit;text-shadow:0 1px 0 #fff;opacity:.5}.close-button:focus,.close-button:hover{text-decoration:none;cursor:pointer;opacity:.75}"]
|
|
159
|
+
},] }
|
|
160
|
+
];
|
|
161
|
+
ValidationAutocompleteMultiComponent.ctorParameters = () => [
|
|
162
|
+
{ type: Array, decorators: [{ type: Optional }, { type: Inject, args: [NG_VALIDATORS,] }] },
|
|
163
|
+
{ type: Array, decorators: [{ type: Optional }, { type: Inject, args: [NG_ASYNC_VALIDATORS,] }] },
|
|
164
|
+
{ type: Injector },
|
|
165
|
+
{ type: LocalizationService }
|
|
166
|
+
];
|
|
167
|
+
ValidationAutocompleteMultiComponent.propDecorators = {
|
|
168
|
+
ChipThreshold: [{ type: Input }],
|
|
169
|
+
FilteredSource: [{ type: Input }],
|
|
170
|
+
value: [{ type: Input }],
|
|
171
|
+
label: [{ type: Input }],
|
|
172
|
+
optionChange: [{ type: Output }],
|
|
173
|
+
autoTrigger: [{ type: ViewChild, args: [MatAutocompleteTrigger,] }]
|
|
174
|
+
};
|
|
175
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validation-autocomplete-multi.component.js","sourceRoot":"","sources":["../../../../../../projects/forms-and-validations/src/lib/validations/validation-autocomplete-multi/validation-autocomplete-multi.component.ts"],"names":[],"mappings":"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","sourcesContent":["// Angular\r\nimport { ControlValueAccessor, FormControl, NG_ASYNC_VALIDATORS, NG_VALIDATORS, NG_VALUE_ACCESSOR, NgControl, RequiredValidator } from \"@angular/forms\";\r\nimport { ChangeDetectionStrategy, Component, EventEmitter, forwardRef, Inject, Injector, Input, Optional, Output, SimpleChanges, ViewChild, ViewEncapsulation } from \"@angular/core\";\r\n\r\n// Configurazioni\r\nimport { LocalizationService } from \"@esfaenza/localizations\";\r\n\r\n// Direttive, Componenti, Librerie\r\nimport { BaseValidation } from \"../base-validation\";\r\nimport { BaseValidationLoc } from '../base-validation.loc';\r\nimport { Subscription } from \"rxjs\";\r\nimport { MatAutocompleteTrigger } from \"@angular/material/autocomplete\";\r\n\r\n/**\r\n * Componente di validaizone per gli input di Autocompletamento\r\n */\r\n@Component({\r\n    selector: \"val-autocomplete-multi\",\r\n    templateUrl: \"validation-autocomplete-multi.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(() => ValidationAutocompleteMultiComponent),\r\n            multi: true\r\n        }\r\n    ],\r\n    encapsulation: ViewEncapsulation.None,\r\n    styleUrls: [\"../validation-style.scss\"]\r\n})\r\nexport class ValidationAutocompleteMultiComponent extends BaseValidation implements ControlValueAccessor {\r\n\r\n    public displayFn = (): string => '';\r\n\r\n    /** Numero massimo di chip visualizzate */\r\n    @Input() ChipThreshold: number = 10;\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    /** Trigger dell'autocomplete per tenerlo aperto */\r\n    @ViewChild(MatAutocompleteTrigger) autoTrigger: MatAutocompleteTrigger;\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    /** Elementi selezionati */\r\n    public selectData: { id: string, description: string }[] = [];\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, public 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    /** In caso arrivi una nuova sorgente devo reimpostare lo stato di selezione con quello attuale */\r\n    public ngOnChanges(changes: SimpleChanges) {\r\n        let newSource = changes[\"FilteredSource\"];\r\n        if (!newSource || newSource.firstChange)\r\n            return;\r\n\r\n        for (let i = 0; i < this.FilteredSource.length; i++) {\r\n            let item = this.FilteredSource[i];\r\n            (<any>item).selected = this.selectData.find(t => t.id == item.id)\r\n        }\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, finalValue: boolean = false): void {\r\n        var val = value && this.FilteredSource ? this.FilteredSource.find(t => t.id == value) : null;\r\n        if(finalValue) this.optionChange.emit(value);\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, finalValue: boolean = false) {\r\n        this.writeValue(toEmit, finalValue);\r\n        if(!finalValue)\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\r\n    /** Rimuove un elemento selezionato */\r\n    public removeChip(data: { id: string, description: string }): void {\r\n        if (!data) {\r\n            this.selectData = [];\r\n            this.FilteredSource.forEach(data => (<any>data).selected = false);\r\n            this.onModelChange(this.selectData.map(t => t.id).join(','), true);\r\n            this.onFinalize();\r\n        }\r\n        else\r\n            this.toggleSelection(data);\r\n    };\r\n\r\n    /** Seleziona o deseleziona un oggetto */\r\n    public toggleSelection(data: { id: string, description: string }): void {\r\n        (<any>data).selected = !(<any>data).selected;\r\n\r\n        if ((<any>data).selected === true) {\r\n            this.selectData.push(data);\r\n        } else {\r\n            const i = this.selectData.findIndex(value => value.id === data.id);\r\n            this.selectData.splice(i, 1);\r\n        }\r\n\r\n        this.value = null;\r\n        this.onModelChange(this.selectData.map(t => t.id).join(','), true);\r\n        this.onFinalize();\r\n    };\r\n}"]}
|