@esfaenza/forms-and-validations 16.2.31 → 17.3.16
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/esfaenza-forms-and-validations.mjs +4 -4
- package/esm2022/lib/forms/base-form-control.mjs +558 -558
- package/esm2022/lib/forms/form-adaptive/form-adaptive.component.loc.mjs +21 -21
- package/esm2022/lib/forms/form-adaptive/form-adaptive.component.mjs +420 -420
- package/esm2022/lib/forms/form-autocomplete/form-autocomplete.component.loc.mjs +20 -20
- package/esm2022/lib/forms/form-autocomplete/form-autocomplete.component.mjs +289 -289
- package/esm2022/lib/forms/form-checkbox/form-checkbox.component.mjs +74 -74
- package/esm2022/lib/forms/form-date/form-date.component.mjs +69 -69
- package/esm2022/lib/forms/form-datetime/form-datetime.component.mjs +67 -67
- package/esm2022/lib/forms/form-empty/form-empty.component.mjs +29 -29
- package/esm2022/lib/forms/form-error/form-error.component.mjs +41 -41
- package/esm2022/lib/forms/form-file/form-file.component.loc.mjs +21 -21
- package/esm2022/lib/forms/form-file/form-file.component.mjs +175 -175
- package/esm2022/lib/forms/form-info/form-info.component.mjs +41 -41
- package/esm2022/lib/forms/form-input/form-input.component.mjs +83 -83
- package/esm2022/lib/forms/form-multiselect/form-multiselect.component.loc.mjs +22 -22
- package/esm2022/lib/forms/form-multiselect/form-multiselect.component.mjs +163 -163
- package/esm2022/lib/forms/form-select/form-select.component.loc.mjs +20 -20
- package/esm2022/lib/forms/form-select/form-select.component.mjs +165 -165
- package/esm2022/lib/forms/form-template/form-template.component.mjs +76 -76
- package/esm2022/lib/forms/form-textarea/form-textarea.component.mjs +57 -57
- package/esm2022/lib/forms/form-time/form-time.component.mjs +115 -115
- package/esm2022/lib/forms-and-validations.module.mjs +200 -200
- package/esm2022/lib/models/AppFile.mjs +13 -13
- package/esm2022/lib/models/ChangeEvent.mjs +6 -6
- package/esm2022/lib/models/FormsAndValidationsModuleConfig.mjs +5 -5
- package/esm2022/lib/models/dayjs-adapter/dayjs-date-adapter.mjs +89 -89
- package/esm2022/lib/tokens.mjs +7 -7
- package/esm2022/lib/validations/base-validation.loc.mjs +22 -22
- package/esm2022/lib/validations/base-validation.mjs +328 -328
- package/esm2022/lib/validations/customValidators/CustomRequiredDirective.mjs +40 -40
- package/esm2022/lib/validations/validation-autocomplete/validation-autocomplete.component.mjs +147 -147
- package/esm2022/lib/validations/validation-autocomplete-multi/validation-autocomplete-multi.component.mjs +240 -240
- package/esm2022/lib/validations/validation-currency/validation-currency.component.mjs +75 -75
- package/esm2022/lib/validations/validation-date/validation-date.component.mjs +183 -183
- package/esm2022/lib/validations/validation-datetime/validation-datetime.component.mjs +212 -212
- package/esm2022/lib/validations/validation-input/validation-input.component.mjs +222 -222
- package/esm2022/lib/validations/validation-select/validation-select.component.mjs +183 -183
- package/esm2022/lib/validations/validation-text-area/validation-text-area.component.mjs +78 -78
- package/esm2022/public-api.mjs +39 -39
- package/fesm2022/esfaenza-forms-and-validations.mjs +4162 -4162
- package/fesm2022/esfaenza-forms-and-validations.mjs.map +1 -1
- package/index.d.ts +5 -5
- package/lib/forms/base-form-control.d.ts +276 -276
- package/lib/forms/form-adaptive/form-adaptive.component.d.ts +126 -126
- package/lib/forms/form-adaptive/form-adaptive.component.loc.d.ts +14 -14
- package/lib/forms/form-autocomplete/form-autocomplete.component.d.ts +84 -84
- package/lib/forms/form-autocomplete/form-autocomplete.component.loc.d.ts +14 -14
- package/lib/forms/form-checkbox/form-checkbox.component.d.ts +23 -23
- package/lib/forms/form-date/form-date.component.d.ts +21 -21
- package/lib/forms/form-datetime/form-datetime.component.d.ts +23 -23
- package/lib/forms/form-empty/form-empty.component.d.ts +15 -15
- package/lib/forms/form-error/form-error.component.d.ts +19 -19
- package/lib/forms/form-file/form-file.component.d.ts +46 -46
- package/lib/forms/form-file/form-file.component.loc.d.ts +14 -14
- package/lib/forms/form-info/form-info.component.d.ts +19 -19
- package/lib/forms/form-input/form-input.component.d.ts +33 -33
- package/lib/forms/form-multiselect/form-multiselect.component.d.ts +67 -67
- package/lib/forms/form-multiselect/form-multiselect.component.loc.d.ts +14 -14
- package/lib/forms/form-select/form-select.component.d.ts +43 -43
- package/lib/forms/form-select/form-select.component.loc.d.ts +14 -14
- package/lib/forms/form-template/form-template.component.d.ts +38 -38
- package/lib/forms/form-textarea/form-textarea.component.d.ts +18 -18
- package/lib/forms/form-time/form-time.component.d.ts +40 -40
- package/lib/forms-and-validations.module.d.ts +47 -47
- package/lib/models/AppFile.d.ts +21 -21
- package/lib/models/ChangeEvent.d.ts +5 -5
- package/lib/models/FormsAndValidationsModuleConfig.d.ts +11 -11
- package/lib/models/dayjs-adapter/dayjs-date-adapter.d.ts +49 -49
- package/lib/tokens.d.ts +7 -7
- package/lib/validations/base-validation.d.ts +219 -219
- package/lib/validations/base-validation.loc.d.ts +14 -14
- package/lib/validations/customValidators/CustomRequiredDirective.d.ts +24 -24
- package/lib/validations/validation-autocomplete/validation-autocomplete.component.d.ts +58 -58
- package/lib/validations/validation-autocomplete-multi/validation-autocomplete-multi.component.d.ts +88 -88
- package/lib/validations/validation-currency/validation-currency.component.d.ts +28 -28
- package/lib/validations/validation-date/validation-date.component.d.ts +79 -79
- package/lib/validations/validation-datetime/validation-datetime.component.d.ts +109 -109
- package/lib/validations/validation-input/validation-input.component.d.ts +134 -134
- package/lib/validations/validation-select/validation-select.component.d.ts +95 -95
- package/lib/validations/validation-text-area/validation-text-area.component.d.ts +28 -28
- package/package.json +13 -13
- package/public-api.d.ts +31 -31
|
@@ -1,41 +1,41 @@
|
|
|
1
|
-
// Angular
|
|
2
|
-
import { NG_VALIDATORS } from "@angular/forms";
|
|
3
|
-
import { Directive, Input } from "@angular/core";
|
|
4
|
-
import * as i0 from "@angular/core";
|
|
5
|
-
/**
|
|
6
|
-
* Direttiva utilizzata per validazioni "required" custom, in modo da poter dire che anche se c'è un valore selezionato, ma quel valore lo considero null
|
|
7
|
-
* allora la validazione fallisce. Attualmente usato nell'unico punto sensato: validation-select
|
|
8
|
-
*/
|
|
9
|
-
export class CustomRequiredDirective {
|
|
10
|
-
constructor() {
|
|
11
|
-
/**
|
|
12
|
-
* Lista di valori che vengono considerati "vuoti" seppur presenti
|
|
13
|
-
*/
|
|
14
|
-
this.NullValues = [];
|
|
15
|
-
}
|
|
16
|
-
/**
|
|
17
|
-
* @ignore
|
|
18
|
-
*/
|
|
19
|
-
validate(c) {
|
|
20
|
-
// Controllo solo per custom required a true, altrimenti qualsiasi valore mi va bene
|
|
21
|
-
if (!this.customRequired)
|
|
22
|
-
return null;
|
|
23
|
-
return !c.value || this.NullValues.includes(c.value) ? { required: true } : null;
|
|
24
|
-
}
|
|
25
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
26
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "
|
|
27
|
-
}
|
|
28
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
29
|
-
type: Directive,
|
|
30
|
-
args: [{
|
|
31
|
-
selector: '[customRequired]',
|
|
32
|
-
providers: [{ provide: NG_VALIDATORS, useExisting: CustomRequiredDirective, multi: true }]
|
|
33
|
-
}]
|
|
34
|
-
}], propDecorators: { NullValues: [{
|
|
35
|
-
type: Input,
|
|
36
|
-
args: ["CustomNullValues"]
|
|
37
|
-
}], customRequired: [{
|
|
38
|
-
type: Input,
|
|
39
|
-
args: ['customRequired']
|
|
40
|
-
}] } });
|
|
1
|
+
// Angular
|
|
2
|
+
import { NG_VALIDATORS } from "@angular/forms";
|
|
3
|
+
import { Directive, Input } from "@angular/core";
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
/**
|
|
6
|
+
* Direttiva utilizzata per validazioni "required" custom, in modo da poter dire che anche se c'è un valore selezionato, ma quel valore lo considero null
|
|
7
|
+
* allora la validazione fallisce. Attualmente usato nell'unico punto sensato: validation-select
|
|
8
|
+
*/
|
|
9
|
+
export class CustomRequiredDirective {
|
|
10
|
+
constructor() {
|
|
11
|
+
/**
|
|
12
|
+
* Lista di valori che vengono considerati "vuoti" seppur presenti
|
|
13
|
+
*/
|
|
14
|
+
this.NullValues = [];
|
|
15
|
+
}
|
|
16
|
+
/**
|
|
17
|
+
* @ignore
|
|
18
|
+
*/
|
|
19
|
+
validate(c) {
|
|
20
|
+
// Controllo solo per custom required a true, altrimenti qualsiasi valore mi va bene
|
|
21
|
+
if (!this.customRequired)
|
|
22
|
+
return null;
|
|
23
|
+
return !c.value || this.NullValues.includes(c.value) ? { required: true } : null;
|
|
24
|
+
}
|
|
25
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CustomRequiredDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
26
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: CustomRequiredDirective, selector: "[customRequired]", inputs: { NullValues: ["CustomNullValues", "NullValues"], customRequired: "customRequired" }, providers: [{ provide: NG_VALIDATORS, useExisting: CustomRequiredDirective, multi: true }], ngImport: i0 }); }
|
|
27
|
+
}
|
|
28
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CustomRequiredDirective, decorators: [{
|
|
29
|
+
type: Directive,
|
|
30
|
+
args: [{
|
|
31
|
+
selector: '[customRequired]',
|
|
32
|
+
providers: [{ provide: NG_VALIDATORS, useExisting: CustomRequiredDirective, multi: true }]
|
|
33
|
+
}]
|
|
34
|
+
}], propDecorators: { NullValues: [{
|
|
35
|
+
type: Input,
|
|
36
|
+
args: ["CustomNullValues"]
|
|
37
|
+
}], customRequired: [{
|
|
38
|
+
type: Input,
|
|
39
|
+
args: ['customRequired']
|
|
40
|
+
}] } });
|
|
41
41
|
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQ3VzdG9tUmVxdWlyZWREaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9mb3Jtcy1hbmQtdmFsaWRhdGlvbnMvc3JjL2xpYi92YWxpZGF0aW9ucy9jdXN0b21WYWxpZGF0b3JzL0N1c3RvbVJlcXVpcmVkRGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLFVBQVU7QUFDVixPQUFPLEVBQW1CLGFBQWEsRUFBYSxNQUFNLGdCQUFnQixDQUFDO0FBQzNFLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUVqRDs7O0dBR0c7QUFLSCxNQUFNLE9BQU8sdUJBQXVCO0lBSnBDO1FBTUk7O1dBRUc7UUFDd0IsZUFBVSxHQUFhLEVBQUUsQ0FBQztLQWlCeEQ7SUFWRzs7T0FFRztJQUNILFFBQVEsQ0FBQyxDQUFrQjtRQUN2QixvRkFBb0Y7UUFDcEYsSUFBSSxDQUFDLElBQUksQ0FBQyxjQUFjO1lBQ3BCLE9BQU8sSUFBSSxDQUFDO1FBRWhCLE9BQU8sQ0FBQyxDQUFDLENBQUMsS0FBSyxJQUFJLElBQUksQ0FBQyxVQUFVLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQztJQUNyRixDQUFDOytHQXJCUSx1QkFBdUI7bUdBQXZCLHVCQUF1Qix5SUFGckIsQ0FBQyxFQUFFLE9BQU8sRUFBRSxhQUFhLEVBQUUsV0FBVyxFQUFFLHVCQUF1QixFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUUsQ0FBQzs7NEZBRWpGLHVCQUF1QjtrQkFKbkMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsa0JBQWtCO29CQUM1QixTQUFTLEVBQUUsQ0FBQyxFQUFFLE9BQU8sRUFBRSxhQUFhLEVBQUUsV0FBVyx5QkFBeUIsRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFFLENBQUM7aUJBQzdGOzhCQU04QixVQUFVO3NCQUFwQyxLQUFLO3VCQUFDLGtCQUFrQjtnQkFLTyxjQUFjO3NCQUE3QyxLQUFLO3VCQUFDLGdCQUFnQiIsInNvdXJjZXNDb250ZW50IjpbIi8vIEFuZ3VsYXJcclxuaW1wb3J0IHsgQWJzdHJhY3RDb250cm9sLCBOR19WQUxJREFUT1JTLCBWYWxpZGF0b3IgfSBmcm9tIFwiQGFuZ3VsYXIvZm9ybXNcIjtcclxuaW1wb3J0IHsgRGlyZWN0aXZlLCBJbnB1dCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcblxyXG4vKipcclxuICogRGlyZXR0aXZhIHV0aWxpenphdGEgcGVyIHZhbGlkYXppb25pIFwicmVxdWlyZWRcIiBjdXN0b20sIGluIG1vZG8gZGEgcG90ZXIgZGlyZSBjaGUgYW5jaGUgc2UgYyfDqCB1biB2YWxvcmUgc2VsZXppb25hdG8sIG1hIHF1ZWwgdmFsb3JlIGxvIGNvbnNpZGVybyBudWxsIFxyXG4gKiBhbGxvcmEgbGEgdmFsaWRhemlvbmUgZmFsbGlzY2UuIEF0dHVhbG1lbnRlIHVzYXRvIG5lbGwndW5pY28gcHVudG8gc2Vuc2F0bzogdmFsaWRhdGlvbi1zZWxlY3RcclxuICovXHJcbkBEaXJlY3RpdmUoe1xyXG4gICAgc2VsZWN0b3I6ICdbY3VzdG9tUmVxdWlyZWRdJyxcclxuICAgIHByb3ZpZGVyczogW3sgcHJvdmlkZTogTkdfVkFMSURBVE9SUywgdXNlRXhpc3Rpbmc6IEN1c3RvbVJlcXVpcmVkRGlyZWN0aXZlLCBtdWx0aTogdHJ1ZSB9XVxyXG59KVxyXG5leHBvcnQgY2xhc3MgQ3VzdG9tUmVxdWlyZWREaXJlY3RpdmUgaW1wbGVtZW50cyBWYWxpZGF0b3Ige1xyXG5cclxuICAgIC8qKlxyXG4gICAgICogTGlzdGEgZGkgdmFsb3JpIGNoZSB2ZW5nb25vIGNvbnNpZGVyYXRpIFwidnVvdGlcIiBzZXBwdXIgcHJlc2VudGlcclxuICAgICAqL1xyXG4gICAgQElucHV0KFwiQ3VzdG9tTnVsbFZhbHVlc1wiKSBOdWxsVmFsdWVzOiBzdHJpbmdbXSA9IFtdO1xyXG5cclxuICAgIC8qKlxyXG4gICAgICogYm9vbGVhbm8gaW4gbW9kYWxpdMOgIHN0cmluZ2EgKFwidHJ1ZVwiIG8gXCJmYWxzZVwiKSBjaGUgaW5kaWNhIHNlIGFwcGxpY2FyZSBsYSB2YWxpZGF6aW9uZSBkaSBvYmJsaWdhdG9yaWV0w6AgbyBtZW5vXHJcbiAgICAgKi9cclxuICAgIEBJbnB1dCgnY3VzdG9tUmVxdWlyZWQnKSBwdWJsaWMgY3VzdG9tUmVxdWlyZWQ6IGJvb2xlYW47XHJcblxyXG4gICAgLyoqXHJcbiAgICAgKiBAaWdub3JlXHJcbiAgICAgKi9cclxuICAgIHZhbGlkYXRlKGM6IEFic3RyYWN0Q29udHJvbCk6IHsgW2tleTogc3RyaW5nXTogYW55OyB9IHtcclxuICAgICAgICAvLyBDb250cm9sbG8gc29sbyBwZXIgY3VzdG9tIHJlcXVpcmVkIGEgdHJ1ZSwgYWx0cmltZW50aSBxdWFsc2lhc2kgdmFsb3JlIG1pIHZhIGJlbmVcclxuICAgICAgICBpZiAoIXRoaXMuY3VzdG9tUmVxdWlyZWQpXHJcbiAgICAgICAgICAgIHJldHVybiBudWxsO1xyXG5cclxuICAgICAgICByZXR1cm4gIWMudmFsdWUgfHwgdGhpcy5OdWxsVmFsdWVzLmluY2x1ZGVzKGMudmFsdWUpID8geyByZXF1aXJlZDogdHJ1ZSB9IDogbnVsbDtcclxuICAgIH1cclxufSJdfQ==
|
package/esm2022/lib/validations/validation-autocomplete/validation-autocomplete.component.mjs
CHANGED
|
@@ -1,147 +1,147 @@
|
|
|
1
|
-
// Angular
|
|
2
|
-
import { NG_ASYNC_VALIDATORS, NG_VALIDATORS, NG_VALUE_ACCESSOR, NgControl } from "@angular/forms";
|
|
3
|
-
import { ChangeDetectionStrategy, Component, EventEmitter, forwardRef, Inject, Input, Optional, Output, ViewEncapsulation } from "@angular/core";
|
|
4
|
-
// Configurazioni
|
|
5
|
-
import { LocalizationService } from "@esfaenza/localizations";
|
|
6
|
-
// Direttive, Componenti, Librerie
|
|
7
|
-
import { BaseValidation } from "../base-validation";
|
|
8
|
-
import { BaseValidationLoc } from '../base-validation.loc';
|
|
9
|
-
import * as i0 from "@angular/core";
|
|
10
|
-
import * as i1 from "@esfaenza/localizations";
|
|
11
|
-
import * as i2 from "@angular/common";
|
|
12
|
-
import * as i3 from "@angular/forms";
|
|
13
|
-
import * as i4 from "@angular/material/
|
|
14
|
-
import * as i5 from "@angular/material/
|
|
15
|
-
import * as i6 from "ngx-bootstrap/tooltip";
|
|
16
|
-
import * as i7 from "@angular/material/
|
|
17
|
-
import * as i8 from "@angular/material/
|
|
18
|
-
/**
|
|
19
|
-
* Componente di validaizone per gli input di Autocompletamento
|
|
20
|
-
*/
|
|
21
|
-
export class ValidationAutocompleteComponent extends BaseValidation {
|
|
22
|
-
/** @ignore */
|
|
23
|
-
constructor(cdr, _validators, _asyncValidators, injector, lc) {
|
|
24
|
-
super(cdr);
|
|
25
|
-
this._validators = _validators;
|
|
26
|
-
this._asyncValidators = _asyncValidators;
|
|
27
|
-
this.injector = injector;
|
|
28
|
-
this.lc = lc;
|
|
29
|
-
/** Sorgente da cui scegliere valori filtrata in base a quello che ha scritto l'utente */
|
|
30
|
-
this.FilteredSource = [];
|
|
31
|
-
/** Contenuto della label Floattante Material-Style */
|
|
32
|
-
this.label = "";
|
|
33
|
-
/** Evento che indica l'opzione selezionata dal componente. Il valore finale della selezione dovrà essere questo */
|
|
34
|
-
this.optionChange = new EventEmitter();
|
|
35
|
-
/** @ignore */
|
|
36
|
-
this.onTouched = () => { }; //placeholder on touched function
|
|
37
|
-
}
|
|
38
|
-
/** @ignore */
|
|
39
|
-
ngOnInit() {
|
|
40
|
-
super.ngOnInit();
|
|
41
|
-
this.registerFocusRequest();
|
|
42
|
-
this.checkRequiredness(this._validators);
|
|
43
|
-
}
|
|
44
|
-
/** @ignore */
|
|
45
|
-
ngOnDestroy() {
|
|
46
|
-
super.ngOnDestroy();
|
|
47
|
-
this.deregisterFocusRequest();
|
|
48
|
-
if (this.tooltipSubscription)
|
|
49
|
-
this.tooltipSubscription.unsubscribe();
|
|
50
|
-
}
|
|
51
|
-
/** @ignore */
|
|
52
|
-
ngAfterViewInit() {
|
|
53
|
-
this.postBinding();
|
|
54
|
-
}
|
|
55
|
-
/**
|
|
56
|
-
* Metodo che si occupa di collegare i validatori e la funzione di reset dal **ControlValueAccessor** rappresentato
|
|
57
|
-
* da questo componente al **ControlValueAccessor** rappresentato dall'effettivo elemento di Input presente lato HTML
|
|
58
|
-
*/
|
|
59
|
-
postBinding() {
|
|
60
|
-
this.CheckValidity();
|
|
61
|
-
const ngControl = this.injector.get(NgControl, null);
|
|
62
|
-
if (ngControl) {
|
|
63
|
-
this.parentControl = ngControl.control;
|
|
64
|
-
//se la variabile novalidate è true, elimino tutti i validatori eventualmente inseriti
|
|
65
|
-
if (this.noValidate) {
|
|
66
|
-
this.parentControl.clearValidators();
|
|
67
|
-
this.parentControl.clearAsyncValidators();
|
|
68
|
-
}
|
|
69
|
-
else {
|
|
70
|
-
this.baseInput.control.setAsyncValidators(this._asyncValidators);
|
|
71
|
-
this.baseInput.control.setValidators(this._validators);
|
|
72
|
-
}
|
|
73
|
-
//faccio in modo che se chiamo il reset del controllo (o della form) dall'esterno si resetti anche il controllo nativo
|
|
74
|
-
const origFunc = this.parentControl.reset;
|
|
75
|
-
this.parentControl.reset = () => {
|
|
76
|
-
origFunc.apply(this.parentControl);
|
|
77
|
-
this.baseInput.control.reset();
|
|
78
|
-
this.tooltip.hide();
|
|
79
|
-
};
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
/** @ignore */
|
|
83
|
-
writeValue(value) {
|
|
84
|
-
var val = value && this.FilteredSource ? this.FilteredSource.find(t => t.id == value) : null;
|
|
85
|
-
if (val)
|
|
86
|
-
this.optionChange.emit(val.id);
|
|
87
|
-
this.propagateChange(val ? val.id : value);
|
|
88
|
-
this.value = val ? val.description : value;
|
|
89
|
-
}
|
|
90
|
-
/**
|
|
91
|
-
* L'emit della modifica al valore viene gestito su un evento custom (**inputChange**) come workaround al malfunzionamento dell'**ngModelChange** nativo
|
|
92
|
-
*
|
|
93
|
-
* @param {any} toEmit valore da propagare all'esterno
|
|
94
|
-
*/
|
|
95
|
-
onModelChange(toEmit) {
|
|
96
|
-
this.writeValue(toEmit);
|
|
97
|
-
this.inputChange.emit(toEmit);
|
|
98
|
-
this.onTouched();
|
|
99
|
-
}
|
|
100
|
-
/** @ignore */
|
|
101
|
-
registerOnChange(fn) {
|
|
102
|
-
this.propagateChange = fn;
|
|
103
|
-
}
|
|
104
|
-
/** @ignore */
|
|
105
|
-
registerOnTouched(fn) {
|
|
106
|
-
this.onTouched = fn;
|
|
107
|
-
}
|
|
108
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
109
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "
|
|
110
|
-
{ provide: LocalizationService, useClass: BaseValidationLoc },
|
|
111
|
-
{
|
|
112
|
-
provide: NG_VALUE_ACCESSOR,
|
|
113
|
-
useExisting: forwardRef(() => ValidationAutocompleteComponent),
|
|
114
|
-
multi: true
|
|
115
|
-
}
|
|
116
|
-
], 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:0;top:-.2em;float:right;font-size:16px;font-weight:700;color:inherit;text-shadow:0 1px 0 #fff;opacity:.5}.close-button:hover,.close-button:focus{text-decoration:none;cursor:pointer;opacity:.75}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "
|
|
117
|
-
}
|
|
118
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
119
|
-
type: Component,
|
|
120
|
-
args: [{ selector: "val-autocomplete", changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
121
|
-
{ provide: LocalizationService, useClass: BaseValidationLoc },
|
|
122
|
-
{
|
|
123
|
-
provide: NG_VALUE_ACCESSOR,
|
|
124
|
-
useExisting: forwardRef(() => ValidationAutocompleteComponent),
|
|
125
|
-
multi: true
|
|
126
|
-
}
|
|
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>{{validationFailedBind}}</span>\r\n </div>\r\n</ng-template>", styles: [".tooltip-inner{background-color:#842a30;color:#fff;font-size:12px;width:max-content}.tooltip{margin:auto auto auto 20%!important}.tooltip-inner{background-color:#842a30!important;color:#fff}.tooltip.top .tooltip-arrow:before,.tooltip.top .tooltip-arrow{border-top-color:#842a30}.close-button{position:absolute;right:0;top:-.2em;float:right;font-size:16px;font-weight:700;color:inherit;text-shadow:0 1px 0 #fff;opacity:.5}.close-button:hover,.close-button:focus{text-decoration:none;cursor:pointer;opacity:.75}\n"] }]
|
|
128
|
-
}], ctorParameters:
|
|
129
|
-
type: Optional
|
|
130
|
-
}, {
|
|
131
|
-
type: Inject,
|
|
132
|
-
args: [NG_VALIDATORS]
|
|
133
|
-
}] }, { type: Array, decorators: [{
|
|
134
|
-
type: Optional
|
|
135
|
-
}, {
|
|
136
|
-
type: Inject,
|
|
137
|
-
args: [NG_ASYNC_VALIDATORS]
|
|
138
|
-
}] }, { type: i0.Injector }, { type: i1.LocalizationService }]
|
|
139
|
-
type: Input
|
|
140
|
-
}], value: [{
|
|
141
|
-
type: Input
|
|
142
|
-
}], label: [{
|
|
143
|
-
type: Input
|
|
144
|
-
}], optionChange: [{
|
|
145
|
-
type: Output
|
|
146
|
-
}] } });
|
|
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":"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","sourcesContent":["// Angular\r\nimport { ControlValueAccessor, UntypedFormControl, NG_ASYNC_VALIDATORS, NG_VALIDATORS, NG_VALUE_ACCESSOR, NgControl, RequiredValidator } from \"@angular/forms\";\r\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, 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: UntypedFormControl;\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        this.checkRequiredness(this._validators);\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 UntypedFormControl;\r\n\r\n            //se la variabile novalidate è true, elimino tutti i validatori eventualmente inseriti\r\n            if (this.noValidate) {\r\n                this.parentControl.clearValidators();\r\n                this.parentControl.clearAsyncValidators();\r\n            }\r\n            else {\r\n                this.baseInput.control.setAsyncValidators(this._asyncValidators);\r\n                this.baseInput.control.setValidators(this._validators);\r\n            }\r\n\r\n            //faccio in modo che se chiamo il reset del controllo (o della form) dall'esterno si resetti anche il controllo nativo\r\n            const origFunc = this.parentControl.reset;\r\n            this.parentControl.reset = () => { //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>"]}
|
|
1
|
+
// Angular
|
|
2
|
+
import { NG_ASYNC_VALIDATORS, NG_VALIDATORS, NG_VALUE_ACCESSOR, NgControl } from "@angular/forms";
|
|
3
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, forwardRef, Inject, Input, Optional, Output, ViewEncapsulation } from "@angular/core";
|
|
4
|
+
// Configurazioni
|
|
5
|
+
import { LocalizationService } from "@esfaenza/localizations";
|
|
6
|
+
// Direttive, Componenti, Librerie
|
|
7
|
+
import { BaseValidation } from "../base-validation";
|
|
8
|
+
import { BaseValidationLoc } from '../base-validation.loc';
|
|
9
|
+
import * as i0 from "@angular/core";
|
|
10
|
+
import * as i1 from "@esfaenza/localizations";
|
|
11
|
+
import * as i2 from "@angular/common";
|
|
12
|
+
import * as i3 from "@angular/forms";
|
|
13
|
+
import * as i4 from "@angular/material/input";
|
|
14
|
+
import * as i5 from "@angular/material/form-field";
|
|
15
|
+
import * as i6 from "ngx-bootstrap/tooltip";
|
|
16
|
+
import * as i7 from "@angular/material/autocomplete";
|
|
17
|
+
import * as i8 from "@angular/material/core";
|
|
18
|
+
/**
|
|
19
|
+
* Componente di validaizone per gli input di Autocompletamento
|
|
20
|
+
*/
|
|
21
|
+
export class ValidationAutocompleteComponent extends BaseValidation {
|
|
22
|
+
/** @ignore */
|
|
23
|
+
constructor(cdr, _validators, _asyncValidators, injector, lc) {
|
|
24
|
+
super(cdr);
|
|
25
|
+
this._validators = _validators;
|
|
26
|
+
this._asyncValidators = _asyncValidators;
|
|
27
|
+
this.injector = injector;
|
|
28
|
+
this.lc = lc;
|
|
29
|
+
/** Sorgente da cui scegliere valori filtrata in base a quello che ha scritto l'utente */
|
|
30
|
+
this.FilteredSource = [];
|
|
31
|
+
/** Contenuto della label Floattante Material-Style */
|
|
32
|
+
this.label = "";
|
|
33
|
+
/** Evento che indica l'opzione selezionata dal componente. Il valore finale della selezione dovrà essere questo */
|
|
34
|
+
this.optionChange = new EventEmitter();
|
|
35
|
+
/** @ignore */
|
|
36
|
+
this.onTouched = () => { }; //placeholder on touched function
|
|
37
|
+
}
|
|
38
|
+
/** @ignore */
|
|
39
|
+
ngOnInit() {
|
|
40
|
+
super.ngOnInit();
|
|
41
|
+
this.registerFocusRequest();
|
|
42
|
+
this.checkRequiredness(this._validators);
|
|
43
|
+
}
|
|
44
|
+
/** @ignore */
|
|
45
|
+
ngOnDestroy() {
|
|
46
|
+
super.ngOnDestroy();
|
|
47
|
+
this.deregisterFocusRequest();
|
|
48
|
+
if (this.tooltipSubscription)
|
|
49
|
+
this.tooltipSubscription.unsubscribe();
|
|
50
|
+
}
|
|
51
|
+
/** @ignore */
|
|
52
|
+
ngAfterViewInit() {
|
|
53
|
+
this.postBinding();
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* Metodo che si occupa di collegare i validatori e la funzione di reset dal **ControlValueAccessor** rappresentato
|
|
57
|
+
* da questo componente al **ControlValueAccessor** rappresentato dall'effettivo elemento di Input presente lato HTML
|
|
58
|
+
*/
|
|
59
|
+
postBinding() {
|
|
60
|
+
this.CheckValidity();
|
|
61
|
+
const ngControl = this.injector.get(NgControl, null);
|
|
62
|
+
if (ngControl) {
|
|
63
|
+
this.parentControl = ngControl.control;
|
|
64
|
+
//se la variabile novalidate è true, elimino tutti i validatori eventualmente inseriti
|
|
65
|
+
if (this.noValidate) {
|
|
66
|
+
this.parentControl.clearValidators();
|
|
67
|
+
this.parentControl.clearAsyncValidators();
|
|
68
|
+
}
|
|
69
|
+
else {
|
|
70
|
+
this.baseInput.control.setAsyncValidators(this._asyncValidators);
|
|
71
|
+
this.baseInput.control.setValidators(this._validators);
|
|
72
|
+
}
|
|
73
|
+
//faccio in modo che se chiamo il reset del controllo (o della form) dall'esterno si resetti anche il controllo nativo
|
|
74
|
+
const origFunc = this.parentControl.reset;
|
|
75
|
+
this.parentControl.reset = () => {
|
|
76
|
+
origFunc.apply(this.parentControl);
|
|
77
|
+
this.baseInput.control.reset();
|
|
78
|
+
this.tooltip.hide();
|
|
79
|
+
};
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
/** @ignore */
|
|
83
|
+
writeValue(value) {
|
|
84
|
+
var val = value && this.FilteredSource ? this.FilteredSource.find(t => t.id == value) : null;
|
|
85
|
+
if (val)
|
|
86
|
+
this.optionChange.emit(val.id);
|
|
87
|
+
this.propagateChange(val ? val.id : value);
|
|
88
|
+
this.value = val ? val.description : value;
|
|
89
|
+
}
|
|
90
|
+
/**
|
|
91
|
+
* L'emit della modifica al valore viene gestito su un evento custom (**inputChange**) come workaround al malfunzionamento dell'**ngModelChange** nativo
|
|
92
|
+
*
|
|
93
|
+
* @param {any} toEmit valore da propagare all'esterno
|
|
94
|
+
*/
|
|
95
|
+
onModelChange(toEmit) {
|
|
96
|
+
this.writeValue(toEmit);
|
|
97
|
+
this.inputChange.emit(toEmit);
|
|
98
|
+
this.onTouched();
|
|
99
|
+
}
|
|
100
|
+
/** @ignore */
|
|
101
|
+
registerOnChange(fn) {
|
|
102
|
+
this.propagateChange = fn;
|
|
103
|
+
}
|
|
104
|
+
/** @ignore */
|
|
105
|
+
registerOnTouched(fn) {
|
|
106
|
+
this.onTouched = fn;
|
|
107
|
+
}
|
|
108
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", 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 }); }
|
|
109
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: ValidationAutocompleteComponent, selector: "val-autocomplete", inputs: { FilteredSource: "FilteredSource", value: "value", label: "label" }, outputs: { optionChange: "optionChange" }, providers: [
|
|
110
|
+
{ provide: LocalizationService, useClass: BaseValidationLoc },
|
|
111
|
+
{
|
|
112
|
+
provide: NG_VALUE_ACCESSOR,
|
|
113
|
+
useExisting: forwardRef(() => ValidationAutocompleteComponent),
|
|
114
|
+
multi: true
|
|
115
|
+
}
|
|
116
|
+
], 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:0;top:-.2em;float:right;font-size:16px;font-weight:700;color:inherit;text-shadow:0 1px 0 #fff;opacity:.5}.close-button:hover,.close-button:focus{text-decoration:none;cursor:pointer;opacity:.75}\n"], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i3.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i3.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i4.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"] }, { kind: "component", type: i5.MatFormField, selector: "mat-form-field", inputs: ["hideRequiredMarker", "color", "floatLabel", "appearance", "subscriptSizing", "hintLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i5.MatLabel, selector: "mat-label" }, { kind: "directive", type: i6.TooltipDirective, selector: "[tooltip], [tooltipHtml]", inputs: ["adaptivePosition", "tooltip", "placement", "triggers", "container", "containerClass", "boundariesElement", "isOpen", "isDisabled", "delay", "tooltipHtml", "tooltipPlacement", "tooltipIsOpen", "tooltipEnable", "tooltipAppendToBody", "tooltipAnimation", "tooltipClass", "tooltipContext", "tooltipPopupDelay", "tooltipFadeDuration", "tooltipTrigger"], outputs: ["tooltipChange", "onShown", "onHidden", "tooltipStateChanged"], exportAs: ["bs-tooltip"] }, { kind: "component", type: i7.MatAutocomplete, selector: "mat-autocomplete", inputs: ["aria-label", "aria-labelledby", "displayWith", "autoActiveFirstOption", "autoSelectActiveOption", "requireSelection", "panelWidth", "disableRipple", "class", "hideSingleSelectionIndicator"], outputs: ["optionSelected", "opened", "closed", "optionActivated"], exportAs: ["matAutocomplete"] }, { kind: "component", type: i8.MatOption, selector: "mat-option", inputs: ["value", "id", "disabled"], outputs: ["onSelectionChange"], exportAs: ["matOption"] }, { kind: "directive", type: i7.MatAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", inputs: ["matAutocomplete", "matAutocompletePosition", "matAutocompleteConnectedTo", "autocomplete", "matAutocompleteDisabled"], exportAs: ["matAutocompleteTrigger"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
117
|
+
}
|
|
118
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: ValidationAutocompleteComponent, decorators: [{
|
|
119
|
+
type: Component,
|
|
120
|
+
args: [{ selector: "val-autocomplete", changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
121
|
+
{ provide: LocalizationService, useClass: BaseValidationLoc },
|
|
122
|
+
{
|
|
123
|
+
provide: NG_VALUE_ACCESSOR,
|
|
124
|
+
useExisting: forwardRef(() => ValidationAutocompleteComponent),
|
|
125
|
+
multi: true
|
|
126
|
+
}
|
|
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>{{validationFailedBind}}</span>\r\n </div>\r\n</ng-template>", styles: [".tooltip-inner{background-color:#842a30;color:#fff;font-size:12px;width:max-content}.tooltip{margin:auto auto auto 20%!important}.tooltip-inner{background-color:#842a30!important;color:#fff}.tooltip.top .tooltip-arrow:before,.tooltip.top .tooltip-arrow{border-top-color:#842a30}.close-button{position:absolute;right:0;top:-.2em;float:right;font-size:16px;font-weight:700;color:inherit;text-shadow:0 1px 0 #fff;opacity:.5}.close-button:hover,.close-button:focus{text-decoration:none;cursor:pointer;opacity:.75}\n"] }]
|
|
128
|
+
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: Array, decorators: [{
|
|
129
|
+
type: Optional
|
|
130
|
+
}, {
|
|
131
|
+
type: Inject,
|
|
132
|
+
args: [NG_VALIDATORS]
|
|
133
|
+
}] }, { type: Array, decorators: [{
|
|
134
|
+
type: Optional
|
|
135
|
+
}, {
|
|
136
|
+
type: Inject,
|
|
137
|
+
args: [NG_ASYNC_VALIDATORS]
|
|
138
|
+
}] }, { type: i0.Injector }, { type: i1.LocalizationService }], propDecorators: { FilteredSource: [{
|
|
139
|
+
type: Input
|
|
140
|
+
}], value: [{
|
|
141
|
+
type: Input
|
|
142
|
+
}], label: [{
|
|
143
|
+
type: Input
|
|
144
|
+
}], optionChange: [{
|
|
145
|
+
type: Output
|
|
146
|
+
}] } });
|
|
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":"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","sourcesContent":["// Angular\r\nimport { ControlValueAccessor, UntypedFormControl, NG_ASYNC_VALIDATORS, NG_VALIDATORS, NG_VALUE_ACCESSOR, NgControl, RequiredValidator } from \"@angular/forms\";\r\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, 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: UntypedFormControl;\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        this.checkRequiredness(this._validators);\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 UntypedFormControl;\r\n\r\n            //se la variabile novalidate è true, elimino tutti i validatori eventualmente inseriti\r\n            if (this.noValidate) {\r\n                this.parentControl.clearValidators();\r\n                this.parentControl.clearAsyncValidators();\r\n            }\r\n            else {\r\n                this.baseInput.control.setAsyncValidators(this._asyncValidators);\r\n                this.baseInput.control.setValidators(this._validators);\r\n            }\r\n\r\n            //faccio in modo che se chiamo il reset del controllo (o della form) dall'esterno si resetti anche il controllo nativo\r\n            const origFunc = this.parentControl.reset;\r\n            this.parentControl.reset = () => { //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>"]}
|