@esfaenza/forms-and-validations 15.2.57 → 16.0.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.
Files changed (80) hide show
  1. package/{esm2020 → esm2022}/lib/forms/base-form-control.mjs +6 -4
  2. package/{esm2020 → esm2022}/lib/forms/form-adaptive/form-adaptive.component.loc.mjs +4 -4
  3. package/{esm2020 → esm2022}/lib/forms/form-adaptive/form-adaptive.component.mjs +4 -4
  4. package/{esm2020 → esm2022}/lib/forms/form-autocomplete/form-autocomplete.component.loc.mjs +4 -4
  5. package/{esm2020 → esm2022}/lib/forms/form-autocomplete/form-autocomplete.component.mjs +4 -4
  6. package/{esm2020 → esm2022}/lib/forms/form-checkbox/form-checkbox.component.mjs +4 -4
  7. package/{esm2020 → esm2022}/lib/forms/form-date/form-date.component.mjs +4 -4
  8. package/{esm2020 → esm2022}/lib/forms/form-datetime/form-datetime.component.mjs +4 -4
  9. package/{esm2020 → esm2022}/lib/forms/form-empty/form-empty.component.mjs +4 -4
  10. package/{esm2020 → esm2022}/lib/forms/form-error/form-error.component.mjs +4 -4
  11. package/{esm2020 → esm2022}/lib/forms/form-file/form-file.component.loc.mjs +4 -4
  12. package/{esm2020 → esm2022}/lib/forms/form-file/form-file.component.mjs +4 -4
  13. package/{esm2020 → esm2022}/lib/forms/form-info/form-info.component.mjs +4 -4
  14. package/{esm2020 → esm2022}/lib/forms/form-input/form-input.component.mjs +5 -5
  15. package/{esm2020 → esm2022}/lib/forms/form-multiselect/form-multiselect.component.loc.mjs +4 -4
  16. package/{esm2020 → esm2022}/lib/forms/form-multiselect/form-multiselect.component.mjs +4 -4
  17. package/{esm2020 → esm2022}/lib/forms/form-select/form-select.component.loc.mjs +4 -4
  18. package/{esm2020 → esm2022}/lib/forms/form-select/form-select.component.mjs +4 -4
  19. package/{esm2020 → esm2022}/lib/forms/form-template/form-template.component.mjs +4 -4
  20. package/{esm2020 → esm2022}/lib/forms/form-textarea/form-textarea.component.mjs +4 -4
  21. package/{esm2020 → esm2022}/lib/forms/form-time/form-time.component.mjs +4 -4
  22. package/{esm2020 → esm2022}/lib/forms-and-validations.module.mjs +64 -64
  23. package/{esm2020 → esm2022}/lib/models/dayjs-adapter/dayjs-date-adapter.mjs +4 -4
  24. package/{esm2020 → esm2022}/lib/validations/base-validation.loc.mjs +4 -4
  25. package/{esm2020 → esm2022}/lib/validations/base-validation.mjs +4 -4
  26. package/{esm2020 → esm2022}/lib/validations/customValidators/CustomRequiredDirective.mjs +4 -4
  27. package/esm2022/lib/validations/validation-autocomplete/validation-autocomplete.component.mjs +147 -0
  28. package/esm2022/lib/validations/validation-autocomplete-multi/validation-autocomplete-multi.component.mjs +240 -0
  29. package/esm2022/lib/validations/validation-currency/validation-currency.component.mjs +75 -0
  30. package/esm2022/lib/validations/validation-date/validation-date.component.mjs +183 -0
  31. package/esm2022/lib/validations/validation-datetime/validation-datetime.component.mjs +212 -0
  32. package/esm2022/lib/validations/validation-input/validation-input.component.mjs +218 -0
  33. package/esm2022/lib/validations/validation-select/validation-select.component.mjs +183 -0
  34. package/esm2022/lib/validations/validation-text-area/validation-text-area.component.mjs +78 -0
  35. package/{fesm2020 → fesm2022}/esfaenza-forms-and-validations.mjs +227 -223
  36. package/fesm2022/esfaenza-forms-and-validations.mjs.map +1 -0
  37. package/lib/forms/base-form-control.d.ts +3 -1
  38. package/lib/forms/form-adaptive/form-adaptive.component.d.ts +1 -1
  39. package/lib/forms/form-autocomplete/form-autocomplete.component.d.ts +1 -1
  40. package/lib/forms/form-checkbox/form-checkbox.component.d.ts +1 -1
  41. package/lib/forms/form-date/form-date.component.d.ts +1 -1
  42. package/lib/forms/form-datetime/form-datetime.component.d.ts +1 -1
  43. package/lib/forms/form-empty/form-empty.component.d.ts +1 -1
  44. package/lib/forms/form-error/form-error.component.d.ts +1 -1
  45. package/lib/forms/form-file/form-file.component.d.ts +1 -1
  46. package/lib/forms/form-info/form-info.component.d.ts +1 -1
  47. package/lib/forms/form-input/form-input.component.d.ts +1 -1
  48. package/lib/forms/form-multiselect/form-multiselect.component.d.ts +1 -1
  49. package/lib/forms/form-select/form-select.component.d.ts +1 -1
  50. package/lib/forms/form-template/form-template.component.d.ts +1 -1
  51. package/lib/forms/form-textarea/form-textarea.component.d.ts +1 -1
  52. package/lib/forms/form-time/form-time.component.d.ts +1 -1
  53. package/lib/validations/base-validation.d.ts +1 -1
  54. package/lib/validations/customValidators/CustomRequiredDirective.d.ts +1 -1
  55. package/lib/validations/validation-autocomplete/validation-autocomplete.component.d.ts +1 -1
  56. package/lib/validations/validation-autocomplete-multi/validation-autocomplete-multi.component.d.ts +1 -1
  57. package/lib/validations/validation-currency/validation-currency.component.d.ts +1 -1
  58. package/lib/validations/validation-date/validation-date.component.d.ts +1 -1
  59. package/lib/validations/validation-datetime/validation-datetime.component.d.ts +1 -1
  60. package/lib/validations/validation-input/validation-input.component.d.ts +2 -2
  61. package/lib/validations/validation-select/validation-select.component.d.ts +1 -1
  62. package/lib/validations/validation-text-area/validation-text-area.component.d.ts +1 -1
  63. package/package.json +20 -26
  64. package/esm2020/lib/validations/validation-autocomplete/validation-autocomplete.component.mjs +0 -147
  65. package/esm2020/lib/validations/validation-autocomplete-multi/validation-autocomplete-multi.component.mjs +0 -240
  66. package/esm2020/lib/validations/validation-currency/validation-currency.component.mjs +0 -75
  67. package/esm2020/lib/validations/validation-date/validation-date.component.mjs +0 -183
  68. package/esm2020/lib/validations/validation-datetime/validation-datetime.component.mjs +0 -212
  69. package/esm2020/lib/validations/validation-input/validation-input.component.mjs +0 -216
  70. package/esm2020/lib/validations/validation-select/validation-select.component.mjs +0 -183
  71. package/esm2020/lib/validations/validation-text-area/validation-text-area.component.mjs +0 -78
  72. package/fesm2015/esfaenza-forms-and-validations.mjs +0 -4310
  73. package/fesm2015/esfaenza-forms-and-validations.mjs.map +0 -1
  74. package/fesm2020/esfaenza-forms-and-validations.mjs.map +0 -1
  75. /package/{esm2020 → esm2022}/esfaenza-forms-and-validations.mjs +0 -0
  76. /package/{esm2020 → esm2022}/lib/models/AppFile.mjs +0 -0
  77. /package/{esm2020 → esm2022}/lib/models/ChangeEvent.mjs +0 -0
  78. /package/{esm2020 → esm2022}/lib/models/FormsAndValidationsModuleConfig.mjs +0 -0
  79. /package/{esm2020 → esm2022}/lib/tokens.mjs +0 -0
  80. /package/{esm2020 → esm2022}/public-api.mjs +0 -0
@@ -0,0 +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/legacy-form-field";
14
+ import * as i5 from "@angular/material/legacy-input";
15
+ import * as i6 from "ngx-bootstrap/tooltip";
16
+ import * as i7 from "@angular/material/legacy-autocomplete";
17
+ import * as i8 from "@angular/material/legacy-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: "16.2.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: "16.2.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: "component", type: i4.MatLegacyFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatLegacyLabel, selector: "mat-label" }, { kind: "directive", type: i5.MatLegacyInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", exportAs: ["matInput"] }, { 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.MatLegacyAutocomplete, selector: "mat-autocomplete", inputs: ["disableRipple"], exportAs: ["matAutocomplete"] }, { kind: "directive", type: i7.MatLegacyAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", exportAs: ["matAutocompleteTrigger"] }, { kind: "component", type: i8.MatLegacyOption, selector: "mat-option", exportAs: ["matOption"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
117
+ }
118
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.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: function () { return [{ 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>"]}
@@ -0,0 +1,240 @@
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, ViewChild, ViewEncapsulation } from "@angular/core";
4
+ import { MatLegacyAutocompleteTrigger as MatAutocompleteTrigger } from "@angular/material/legacy-autocomplete";
5
+ import { COMMA, ENTER } from "@angular/cdk/keycodes";
6
+ // Configurazioni
7
+ import { LocalizationService } from "@esfaenza/localizations";
8
+ // Direttive, Componenti, Librerie
9
+ import { BaseValidation } from "../base-validation";
10
+ import { BaseValidationLoc } from '../base-validation.loc';
11
+ import * as i0 from "@angular/core";
12
+ import * as i1 from "@esfaenza/localizations";
13
+ import * as i2 from "@angular/common";
14
+ import * as i3 from "@angular/forms";
15
+ import * as i4 from "@angular/material/legacy-form-field";
16
+ import * as i5 from "@angular/material/legacy-input";
17
+ import * as i6 from "@angular/material/legacy-chips";
18
+ import * as i7 from "@angular/material/icon";
19
+ import * as i8 from "@angular/material/legacy-checkbox";
20
+ import * as i9 from "ngx-bootstrap/tooltip";
21
+ import * as i10 from "@angular/material/legacy-autocomplete";
22
+ import * as i11 from "@angular/material/legacy-core";
23
+ /** Componente di validaizone per gli input di Autocompletamento */
24
+ export class ValidationAutocompleteMultiComponent extends BaseValidation {
25
+ /** @ignore */
26
+ constructor(cdr, _validators, _asyncValidators, injector, lc) {
27
+ super(cdr);
28
+ this._validators = _validators;
29
+ this._asyncValidators = _asyncValidators;
30
+ this.injector = injector;
31
+ this.lc = lc;
32
+ this.displayFn = () => '';
33
+ /** Numero massimo di chip visualizzate */
34
+ this.ChipThreshold = 10;
35
+ /** Sorgente da cui scegliere valori filtrata in base a quello che ha scritto l'utente */
36
+ this.FilteredSource = [];
37
+ /** Contenuto della label Floattante Material-Style */
38
+ this.label = "";
39
+ /** Definisce che ad ogni selezione deve chiudere la tendina */
40
+ this.HideChoicesOnSelection = false;
41
+ /** Evento che indica l'opzione selezionata dal componente. Il valore finale della selezione dovrà essere questo */
42
+ this.optionChange = new EventEmitter();
43
+ /** Elementi selezionati */
44
+ this.selectData = [];
45
+ /** @ignore */
46
+ this.onTouched = () => { }; //placeholder on touched function
47
+ }
48
+ /** @ignore */
49
+ ngOnInit() {
50
+ super.ngOnInit();
51
+ this.registerFocusRequest();
52
+ this.checkRequiredness(this._validators);
53
+ if (this.UnboundMode) {
54
+ this.separatorKeysCodes = [ENTER, COMMA];
55
+ this.addOnBlur = true;
56
+ }
57
+ else {
58
+ this.separatorKeysCodes = [ENTER];
59
+ this.addOnBlur = false;
60
+ }
61
+ }
62
+ /** @ignore */
63
+ ngOnDestroy() {
64
+ super.ngOnDestroy();
65
+ this.deregisterFocusRequest();
66
+ if (this.tooltipSubscription)
67
+ this.tooltipSubscription.unsubscribe();
68
+ }
69
+ /** @ignore */
70
+ ngAfterViewInit() {
71
+ this.postBinding();
72
+ }
73
+ /** In caso arrivi una nuova sorgente devo reimpostare lo stato di selezione con quello attuale */
74
+ ngOnChanges(changes) {
75
+ let newSource = changes["FilteredSource"];
76
+ if (!newSource || newSource.firstChange)
77
+ return;
78
+ for (let i = 0; i < this.FilteredSource.length; i++) {
79
+ let item = this.FilteredSource[i];
80
+ item.selected = this.selectData.find(t => t.id == item.id);
81
+ }
82
+ }
83
+ /**
84
+ * Metodo che si occupa di collegare i validatori e la funzione di reset dal **ControlValueAccessor** rappresentato
85
+ * da questo componente al **ControlValueAccessor** rappresentato dall'effettivo elemento di Input presente lato HTML
86
+ */
87
+ postBinding() {
88
+ this.CheckValidity();
89
+ const ngControl = this.injector.get(NgControl, null);
90
+ if (ngControl) {
91
+ this.parentControl = ngControl.control;
92
+ //se la variabile novalidate è true, elimino tutti i validatori eventualmente inseriti
93
+ if (this.noValidate) {
94
+ this.parentControl.clearValidators();
95
+ this.parentControl.clearAsyncValidators();
96
+ }
97
+ else {
98
+ this.baseInput.control.setAsyncValidators(this._asyncValidators);
99
+ this.baseInput.control.setValidators(this._validators);
100
+ }
101
+ //faccio in modo che se chiamo il reset del controllo (o della form) dall'esterno si resetti anche il controllo nativo
102
+ const origFunc = this.parentControl.reset;
103
+ this.parentControl.reset = () => {
104
+ origFunc.apply(this.parentControl);
105
+ this.baseInput.control.reset();
106
+ this.tooltip.hide();
107
+ };
108
+ }
109
+ }
110
+ /** @ignore */
111
+ writeValue(value, finalValue = false) {
112
+ var val = value && this.FilteredSource ? this.FilteredSource.find(t => t.id == value) : null;
113
+ if (finalValue)
114
+ this.optionChange.emit(value);
115
+ this.propagateChange(val ? val.id : value);
116
+ this.value = val ? val.description : value;
117
+ }
118
+ /**
119
+ * L'emit della modifica al valore viene gestito su un evento custom (**inputChange**) come workaround al malfunzionamento dell'**ngModelChange** nativo
120
+ *
121
+ * @param {any} toEmit valore da propagare all'esterno
122
+ */
123
+ onModelChange(toEmit, finalValue = false) {
124
+ this.writeValue(toEmit, finalValue);
125
+ if (!finalValue)
126
+ this.inputChange.emit(toEmit);
127
+ this.onTouched();
128
+ }
129
+ /** @ignore */
130
+ registerOnChange(fn) {
131
+ this.propagateChange = fn;
132
+ }
133
+ /** @ignore */
134
+ registerOnTouched(fn) {
135
+ this.onTouched = fn;
136
+ }
137
+ addWhenUnbound(event) {
138
+ let input = event.input;
139
+ let toAdd = event.value;
140
+ if (!this.value)
141
+ this.value = [];
142
+ if ((toAdd || '').trim()) {
143
+ let array = toAdd.split(/[\s,;]+/).filter(f => f != null && f != "" && f != undefined);
144
+ array = array.map(item => item.replace(',', '').replace(';', '').trim());
145
+ array.forEach(a => {
146
+ this.toggleSelection({ id: a, description: a });
147
+ });
148
+ this.value = [...this.value, ...array];
149
+ this.propagateChange(this.value);
150
+ }
151
+ if (input) {
152
+ input.value = '';
153
+ }
154
+ }
155
+ /** Rimuove un elemento selezionato */
156
+ removeChip(data) {
157
+ if (!data) {
158
+ this.selectData = [];
159
+ if (this.FilteredSource)
160
+ this.FilteredSource.forEach(data => data.selected = false);
161
+ this.onModelChange("", true);
162
+ this.onFinalize();
163
+ }
164
+ else
165
+ this.toggleSelection(data);
166
+ }
167
+ ;
168
+ /** Seleziona o deseleziona un oggetto */
169
+ toggleSelection(data) {
170
+ data.selected = !data.selected;
171
+ if (data.selected === true) {
172
+ this.selectData.push(data);
173
+ }
174
+ else {
175
+ const i = this.selectData.findIndex(value => value.id === data.id);
176
+ this.selectData.splice(i, 1);
177
+ }
178
+ this.onModelChange(this.selectData.map(t => t.id).join(','), true);
179
+ if (this.HideChoicesOnSelection)
180
+ this.htmlInput.nativeElement.value = "";
181
+ else {
182
+ if (!this.UnboundMode) {
183
+ this.autoTrigger.closePanel();
184
+ requestAnimationFrame(() => {
185
+ this.autoTrigger.openPanel();
186
+ });
187
+ }
188
+ }
189
+ this.onFinalize();
190
+ }
191
+ ;
192
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ValidationAutocompleteMultiComponent, 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 }); }
193
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ValidationAutocompleteMultiComponent, selector: "val-autocomplete-multi", inputs: { ChipThreshold: "ChipThreshold", FilteredSource: "FilteredSource", UnboundMode: "UnboundMode", value: "value", label: "label", HideChoicesOnSelection: "HideChoicesOnSelection" }, outputs: { optionChange: "optionChange" }, providers: [
194
+ { provide: LocalizationService, useClass: BaseValidationLoc },
195
+ {
196
+ provide: NG_VALUE_ACCESSOR,
197
+ useExisting: forwardRef(() => ValidationAutocompleteMultiComponent),
198
+ multi: true
199
+ }
200
+ ], viewQueries: [{ propertyName: "autoTrigger", first: true, predicate: MatAutocompleteTrigger, descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, 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 [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\"\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 (matChipInputTokenEnd)=\"addWhenUnbound($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); !HideChoicesOnSelection && $event.stopPropagation()\">\r\n <mat-checkbox [checked]=\"data.selected\" (change)=\"toggleSelection(data);\" (click)=\"!HideChoicesOnSelection && $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>{{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", "val-autocomplete-multi .mat-form-field-appearance-outline .mat-form-field-infix{height:auto!important;min-height:36px!important}val-autocomplete-multi .mat-form-field-appearance-outline .mat-form-field-wrapper{height:auto!important}\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: "component", type: i4.MatLegacyFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatLegacyLabel, selector: "mat-label" }, { kind: "directive", type: i5.MatLegacyInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", exportAs: ["matInput"] }, { kind: "component", type: i6.MatLegacyChipList, selector: "mat-chip-list", inputs: ["role", "aria-describedby", "errorStateMatcher", "multiple", "compareWith", "value", "required", "placeholder", "disabled", "aria-orientation", "selectable", "tabIndex"], outputs: ["change", "valueChange"], exportAs: ["matChipList"] }, { kind: "directive", type: i6.MatLegacyChip, selector: "mat-basic-chip, [mat-basic-chip], mat-chip, [mat-chip]", inputs: ["color", "disableRipple", "tabIndex", "role", "selected", "value", "selectable", "disabled", "removable"], outputs: ["selectionChange", "destroyed", "removed"], exportAs: ["matChip"] }, { kind: "directive", type: i6.MatLegacyChipInput, selector: "input[matChipInputFor]", inputs: ["matChipInputFor", "matChipInputAddOnBlur", "matChipInputSeparatorKeyCodes", "placeholder", "id", "disabled"], outputs: ["matChipInputTokenEnd"], exportAs: ["matChipInput", "matChipInputFor"] }, { kind: "component", type: i7.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i8.MatLegacyCheckbox, selector: "mat-checkbox", inputs: ["disableRipple", "color", "tabIndex"], exportAs: ["matCheckbox"] }, { kind: "directive", type: i9.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: i10.MatLegacyAutocomplete, selector: "mat-autocomplete", inputs: ["disableRipple"], exportAs: ["matAutocomplete"] }, { kind: "directive", type: i10.MatLegacyAutocompleteTrigger, selector: "input[matAutocomplete], textarea[matAutocomplete]", exportAs: ["matAutocompleteTrigger"] }, { kind: "component", type: i11.MatLegacyOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "pipe", type: i1.LocalizePipe, name: "localize" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
201
+ }
202
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ValidationAutocompleteMultiComponent, decorators: [{
203
+ type: Component,
204
+ args: [{ selector: "val-autocomplete-multi", changeDetection: ChangeDetectionStrategy.OnPush, providers: [
205
+ { provide: LocalizationService, useClass: BaseValidationLoc },
206
+ {
207
+ provide: NG_VALUE_ACCESSOR,
208
+ useExisting: forwardRef(() => ValidationAutocompleteMultiComponent),
209
+ multi: true
210
+ }
211
+ ], encapsulation: ViewEncapsulation.None, 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 [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\"\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 (matChipInputTokenEnd)=\"addWhenUnbound($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); !HideChoicesOnSelection && $event.stopPropagation()\">\r\n <mat-checkbox [checked]=\"data.selected\" (change)=\"toggleSelection(data);\" (click)=\"!HideChoicesOnSelection && $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>{{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", "val-autocomplete-multi .mat-form-field-appearance-outline .mat-form-field-infix{height:auto!important;min-height:36px!important}val-autocomplete-multi .mat-form-field-appearance-outline .mat-form-field-wrapper{height:auto!important}\n"] }]
212
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: Array, decorators: [{
213
+ type: Optional
214
+ }, {
215
+ type: Inject,
216
+ args: [NG_VALIDATORS]
217
+ }] }, { type: Array, decorators: [{
218
+ type: Optional
219
+ }, {
220
+ type: Inject,
221
+ args: [NG_ASYNC_VALIDATORS]
222
+ }] }, { type: i0.Injector }, { type: i1.LocalizationService }]; }, propDecorators: { ChipThreshold: [{
223
+ type: Input
224
+ }], FilteredSource: [{
225
+ type: Input
226
+ }], UnboundMode: [{
227
+ type: Input
228
+ }], value: [{
229
+ type: Input
230
+ }], label: [{
231
+ type: Input
232
+ }], HideChoicesOnSelection: [{
233
+ type: Input
234
+ }], optionChange: [{
235
+ type: Output
236
+ }], autoTrigger: [{
237
+ type: ViewChild,
238
+ args: [MatAutocompleteTrigger]
239
+ }] } });
240
+ //# 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","../../../../../../projects/forms-and-validations/src/lib/validations/validation-autocomplete-multi/validation-autocomplete-multi.component.html"],"names":[],"mappings":"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","sourcesContent":["// Angular\r\nimport { ControlValueAccessor, UntypedFormControl, NG_ASYNC_VALIDATORS, NG_VALIDATORS, NG_VALUE_ACCESSOR, NgControl } from \"@angular/forms\";\r\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, forwardRef, Inject, Injector, Input, Optional, Output, SimpleChanges, ViewChild, ViewEncapsulation } from \"@angular/core\";\r\nimport { MatLegacyAutocompleteTrigger as MatAutocompleteTrigger } from \"@angular/material/legacy-autocomplete\";\r\nimport { COMMA, ENTER } from \"@angular/cdk/keycodes\";\r\n\r\n// Configurazioni\r\nimport { LocalizationService } from \"@esfaenza/localizations\";\r\n\r\n// Direttive, Componenti, Librerie\r\nimport { BaseValidation } from \"../base-validation\";\r\nimport { BaseValidationLoc } from '../base-validation.loc';\r\nimport { Subscription } from \"rxjs\";\r\n\r\n/** Componente di validaizone per gli input di Autocompletamento */\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\", \"./validation-autocomplete-multi.component.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    /** Indica il fatto che non c'è una Source da cui scegliere */\r\n    @Input() public UnboundMode: boolean;\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    /** Definisce che ad ogni selezione deve chiudere la tendina */\r\n    @Input() public HideChoicesOnSelection: boolean = false;\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: UntypedFormControl;\r\n\r\n    /** Chiavi su cui dividere gli input del mat chip */\r\n    public separatorKeysCodes: number[];\r\n\r\n    /** Aggiunge una chip o meno su blur */\r\n    public addOnBlur: boolean;\r\n\r\n    /** Elementi selezionati */\r\n    public selectData: { id: string, description: string }[] = [];\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, public 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        if (this.UnboundMode) {\r\n            this.separatorKeysCodes = [ENTER, COMMA];\r\n            this.addOnBlur = true;\r\n        }\r\n        else {\r\n            this.separatorKeysCodes = [ENTER];\r\n            this.addOnBlur = false;\r\n        }\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    /** 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 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, 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    addWhenUnbound(event: any) {\r\n        let input = event.input;\r\n        let toAdd = event.value;\r\n\r\n        if (!this.value) this.value = [];\r\n\r\n        if ((toAdd || '').trim()) {\r\n            let array = toAdd.split(/[\\s,;]+/).filter(f => f != null && f != \"\" && f != undefined);\r\n            array = array.map(item => item.replace(',', '').replace(';', '').trim());\r\n\r\n            array.forEach(a => {\r\n                this.toggleSelection({id: a, description: a});\r\n            })\r\n\r\n            this.value = [...this.value, ...array];\r\n            this.propagateChange(this.value);\r\n        }\r\n        if (input) { input.value = ''; }\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            if(this.FilteredSource)\r\n                this.FilteredSource.forEach(data => (<any>data).selected = false);\r\n            this.onModelChange(\"\", 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        this.onModelChange(this.selectData.map(t => t.id).join(','), true);\r\n        if (this.HideChoicesOnSelection)\r\n            this.htmlInput.nativeElement.value = \"\";\r\n        else {\r\n            if (!this.UnboundMode) {\r\n                this.autoTrigger.closePanel();\r\n                requestAnimationFrame(() => {\r\n                    this.autoTrigger.openPanel();\r\n                });\r\n            }\r\n        }\r\n        this.onFinalize();\r\n    };\r\n}","<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            [matChipInputSeparatorKeyCodes]=\"separatorKeysCodes\"\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            (matChipInputTokenEnd)=\"addWhenUnbound($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); !HideChoicesOnSelection && $event.stopPropagation()\">\r\n                <mat-checkbox [checked]=\"data.selected\" (change)=\"toggleSelection(data);\" (click)=\"!HideChoicesOnSelection && $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>{{validationFailedBind}}</span>\r\n    </div>\r\n</ng-template>"]}
@@ -0,0 +1,75 @@
1
+ // Angular
2
+ import { ChangeDetectionStrategy, Component, forwardRef, Inject, Input, Optional, ViewEncapsulation } from "@angular/core";
3
+ import { NG_ASYNC_VALIDATORS, NG_VALIDATORS, NG_VALUE_ACCESSOR } from "@angular/forms";
4
+ // Configurazioni
5
+ import { LocalizationService } from "@esfaenza/localizations";
6
+ // Direttive, Componenti, Librerie
7
+ import { BaseValidationLoc } from '../base-validation.loc';
8
+ import { ValidationInputComponent } from '../validation-input/validation-input.component';
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/legacy-form-field";
14
+ import * as i5 from "@angular/material/legacy-input";
15
+ import * as i6 from "ngx-bootstrap/tooltip";
16
+ import * as i7 from "@esfaenza/ngx-currency-mask";
17
+ /**
18
+ * Componente di validaizone per gli input con maschera di inserimento numerica
19
+ */
20
+ export class ValidationCurrencyComponent extends ValidationInputComponent {
21
+ /**
22
+ * @ignore
23
+ */
24
+ constructor(cdr, validators, asyncValidators, injector, lc) {
25
+ super(cdr, validators, asyncValidators, injector, lc);
26
+ this.lc = lc;
27
+ }
28
+ /**
29
+ * @ignore
30
+ */
31
+ ngOnInit() {
32
+ super.ngOnInit();
33
+ this.registerFocusRequest();
34
+ }
35
+ /**
36
+ * @ignore
37
+ */
38
+ ngOnDestroy() {
39
+ super.ngOnDestroy();
40
+ this.deregisterFocusRequest();
41
+ }
42
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ValidationCurrencyComponent, 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 }); }
43
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ValidationCurrencyComponent, selector: "val-currency", inputs: { CurrencyOptions: "CurrencyOptions" }, providers: [
44
+ { provide: LocalizationService, useClass: BaseValidationLoc },
45
+ {
46
+ provide: NG_VALUE_ACCESSOR,
47
+ useExisting: forwardRef(() => ValidationCurrencyComponent),
48
+ multi: true
49
+ }
50
+ ], usesInheritance: true, ngImport: i0, template: "<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=\"placeholder && FloatingLabel\">{{placeholder}}</mat-label>\r\n <input #baseInput='ngModel'\r\n #htmlInput\r\n currencyMask\r\n matInput\r\n [readonly]=\"Readonly\"\r\n [options]='CurrencyOptions'\r\n [(ngModel)]=\"value\"\r\n name=\"val-input\"\r\n id=\"{{id}}\"\r\n [placeholder]=\"FloatingLabel ? undefined : placeholder\"\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 class=\"form-control {{class}}\"\r\n [class.no-content-shift]=\"!noValidate && CurrencyOptions?.align == 'left'\"\r\n [class.checking-field]=\"!noValidate\"\r\n (ngModelChange)=\"onModelChange($event)\"\r\n type=\"{{Type}}\"\r\n [tooltip]=\"tolTemplate\"\r\n triggers=\"\"\r\n placement=\"top\"\r\n autocomplete=\"{{autocomplete}}\" />\r\n</mat-form-field>\r\n\r\n<ng-template #tolTemplate>\r\n <div>\r\n <span class=\"close-button pull-right\" (click)=\"closeTooltip()\" aria-label=\"Close\">\r\n <span aria-hidden=\"true\">&times;</span>\r\n </span>\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", "val-currency .mat-form-field-wrapper .form-control.checking-field.ng-touched{padding-right:25px;margin-left:-25px}val-currency .mat-form-field-wrapper .form-control.checking-field.ng-touched.no-content-shift{padding-right:0!important;margin-left:0!important}\n"], dependencies: [{ 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: "component", type: i4.MatLegacyFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "directive", type: i4.MatLegacyLabel, selector: "mat-label" }, { kind: "directive", type: i5.MatLegacyInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", exportAs: ["matInput"] }, { 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: "directive", type: i7.CurrencyMaskDirective, selector: "[currencyMask]", inputs: ["max", "min", "options"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
51
+ }
52
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ValidationCurrencyComponent, decorators: [{
53
+ type: Component,
54
+ args: [{ selector: "val-currency", changeDetection: ChangeDetectionStrategy.OnPush, providers: [
55
+ { provide: LocalizationService, useClass: BaseValidationLoc },
56
+ {
57
+ provide: NG_VALUE_ACCESSOR,
58
+ useExisting: forwardRef(() => ValidationCurrencyComponent),
59
+ multi: true
60
+ }
61
+ ], encapsulation: ViewEncapsulation.None, template: "<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=\"placeholder && FloatingLabel\">{{placeholder}}</mat-label>\r\n <input #baseInput='ngModel'\r\n #htmlInput\r\n currencyMask\r\n matInput\r\n [readonly]=\"Readonly\"\r\n [options]='CurrencyOptions'\r\n [(ngModel)]=\"value\"\r\n name=\"val-input\"\r\n id=\"{{id}}\"\r\n [placeholder]=\"FloatingLabel ? undefined : placeholder\"\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 class=\"form-control {{class}}\"\r\n [class.no-content-shift]=\"!noValidate && CurrencyOptions?.align == 'left'\"\r\n [class.checking-field]=\"!noValidate\"\r\n (ngModelChange)=\"onModelChange($event)\"\r\n type=\"{{Type}}\"\r\n [tooltip]=\"tolTemplate\"\r\n triggers=\"\"\r\n placement=\"top\"\r\n autocomplete=\"{{autocomplete}}\" />\r\n</mat-form-field>\r\n\r\n<ng-template #tolTemplate>\r\n <div>\r\n <span class=\"close-button pull-right\" (click)=\"closeTooltip()\" aria-label=\"Close\">\r\n <span aria-hidden=\"true\">&times;</span>\r\n </span>\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", "val-currency .mat-form-field-wrapper .form-control.checking-field.ng-touched{padding-right:25px;margin-left:-25px}val-currency .mat-form-field-wrapper .form-control.checking-field.ng-touched.no-content-shift{padding-right:0!important;margin-left:0!important}\n"] }]
62
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: Array, decorators: [{
63
+ type: Optional
64
+ }, {
65
+ type: Inject,
66
+ args: [NG_VALIDATORS]
67
+ }] }, { type: Array, decorators: [{
68
+ type: Optional
69
+ }, {
70
+ type: Inject,
71
+ args: [NG_ASYNC_VALIDATORS]
72
+ }] }, { type: i0.Injector }, { type: i1.LocalizationService }]; }, propDecorators: { CurrencyOptions: [{
73
+ type: Input
74
+ }] } });
75
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWRhdGlvbi1jdXJyZW5jeS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9mb3Jtcy1hbmQtdmFsaWRhdGlvbnMvc3JjL2xpYi92YWxpZGF0aW9ucy92YWxpZGF0aW9uLWN1cnJlbmN5L3ZhbGlkYXRpb24tY3VycmVuY3kuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZm9ybXMtYW5kLXZhbGlkYXRpb25zL3NyYy9saWIvdmFsaWRhdGlvbnMvdmFsaWRhdGlvbi1jdXJyZW5jeS92YWxpZGF0aW9uLWN1cnJlbmN5LmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLFVBQVU7QUFDVixPQUFPLEVBQUUsdUJBQXVCLEVBQXFCLFNBQVMsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFZLEtBQUssRUFBRSxRQUFRLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDeEosT0FBTyxFQUFFLG1CQUFtQixFQUFFLGFBQWEsRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRXZGLGlCQUFpQjtBQUNqQixPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUU5RCxrQ0FBa0M7QUFDbEMsT0FBTyxFQUFDLGlCQUFpQixFQUFDLE1BQU0sd0JBQXdCLENBQUM7QUFDekQsT0FBTyxFQUFDLHdCQUF3QixFQUFDLE1BQU0sZ0RBQWdELENBQUM7Ozs7Ozs7OztBQUV4Rjs7R0FFRztBQWdCSCxNQUFNLE9BQU8sMkJBQTRCLFNBQVEsd0JBQXdCO0lBT3JFOztPQUVHO0lBQ0gsWUFBWSxHQUFzQixFQUFxQyxVQUFzQixFQUEyQyxlQUEyQixFQUFFLFFBQWtCLEVBQVksRUFBdUI7UUFDdE4sS0FBSyxDQUFDLEdBQUcsRUFBRSxVQUFVLEVBQUUsZUFBZSxFQUFFLFFBQVEsRUFBRSxFQUFFLENBQUMsQ0FBQztRQUR5SSxPQUFFLEdBQUYsRUFBRSxDQUFxQjtJQUUxTixDQUFDO0lBRUQ7O09BRUc7SUFDSCxRQUFRO1FBQ0osS0FBSyxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBQ2pCLElBQUksQ0FBQyxvQkFBb0IsRUFBRSxDQUFDO0lBQ2hDLENBQUM7SUFFRDs7T0FFRztJQUNILFdBQVc7UUFDUCxLQUFLLENBQUMsV0FBVyxFQUFFLENBQUM7UUFDcEIsSUFBSSxDQUFDLHNCQUFzQixFQUFFLENBQUM7SUFDbEMsQ0FBQzsrR0E1QlEsMkJBQTJCLG1EQVVvQixhQUFhLDZCQUE4QyxtQkFBbUI7bUdBVjdILDJCQUEyQix1RkFYekI7WUFDUCxFQUFFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxRQUFRLEVBQUUsaUJBQWlCLEVBQUU7WUFDN0Q7Z0JBQ0ksT0FBTyxFQUFFLGlCQUFpQjtnQkFDMUIsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQywyQkFBMkIsQ0FBQztnQkFDMUQsS0FBSyxFQUFFLElBQUk7YUFDZDtTQUNKLGlEQ3pCTCxraURBa0NjOzs0RkRMRCwyQkFBMkI7a0JBZnZDLFNBQVM7K0JBQ0ksY0FBYyxtQkFFUCx1QkFBdUIsQ0FBQyxNQUFNLGFBQ3BDO3dCQUNQLEVBQUUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLFFBQVEsRUFBRSxpQkFBaUIsRUFBRTt3QkFDN0Q7NEJBQ0ksT0FBTyxFQUFFLGlCQUFpQjs0QkFDMUIsV0FBVyxFQUFFLFVBQVUsQ0FBQyxHQUFHLEVBQUUsNEJBQTRCLENBQUM7NEJBQzFELEtBQUssRUFBRSxJQUFJO3lCQUNkO3FCQUNKLGlCQUNjLGlCQUFpQixDQUFDLElBQUk7OzBCQWFBLFFBQVE7OzBCQUFJLE1BQU07MkJBQUMsYUFBYTs7MEJBQTJCLFFBQVE7OzBCQUFJLE1BQU07MkJBQUMsbUJBQW1CO3FHQUw3SCxlQUFlO3NCQUF2QixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiLy8gQW5ndWxhclxyXG5pbXBvcnQgeyBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSwgQ2hhbmdlRGV0ZWN0b3JSZWYsIENvbXBvbmVudCwgZm9yd2FyZFJlZiwgSW5qZWN0LCBJbmplY3RvciwgSW5wdXQsIE9wdGlvbmFsLCBWaWV3RW5jYXBzdWxhdGlvbiB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7IE5HX0FTWU5DX1ZBTElEQVRPUlMsIE5HX1ZBTElEQVRPUlMsIE5HX1ZBTFVFX0FDQ0VTU09SIH0gZnJvbSBcIkBhbmd1bGFyL2Zvcm1zXCI7XHJcblxyXG4vLyBDb25maWd1cmF6aW9uaVxyXG5pbXBvcnQgeyBMb2NhbGl6YXRpb25TZXJ2aWNlIH0gZnJvbSBcIkBlc2ZhZW56YS9sb2NhbGl6YXRpb25zXCI7XHJcblxyXG4vLyBEaXJldHRpdmUsIENvbXBvbmVudGksIExpYnJlcmllXHJcbmltcG9ydCB7QmFzZVZhbGlkYXRpb25Mb2N9IGZyb20gJy4uL2Jhc2UtdmFsaWRhdGlvbi5sb2MnO1xyXG5pbXBvcnQge1ZhbGlkYXRpb25JbnB1dENvbXBvbmVudH0gZnJvbSAnLi4vdmFsaWRhdGlvbi1pbnB1dC92YWxpZGF0aW9uLWlucHV0LmNvbXBvbmVudCc7XHJcblxyXG4vKipcclxuICogQ29tcG9uZW50ZSBkaSB2YWxpZGFpem9uZSBwZXIgZ2xpIGlucHV0IGNvbiBtYXNjaGVyYSBkaSBpbnNlcmltZW50byBudW1lcmljYVxyXG4gKi9cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogXCJ2YWwtY3VycmVuY3lcIixcclxuICAgIHRlbXBsYXRlVXJsOiBcInZhbGlkYXRpb24tY3VycmVuY3kuY29tcG9uZW50Lmh0bWxcIixcclxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxyXG4gICAgcHJvdmlkZXJzOiBbXHJcbiAgICAgICAgeyBwcm92aWRlOiBMb2NhbGl6YXRpb25TZXJ2aWNlLCB1c2VDbGFzczogQmFzZVZhbGlkYXRpb25Mb2MgfSxcclxuICAgICAgICB7XHJcbiAgICAgICAgICAgIHByb3ZpZGU6IE5HX1ZBTFVFX0FDQ0VTU09SLFxyXG4gICAgICAgICAgICB1c2VFeGlzdGluZzogZm9yd2FyZFJlZigoKSA9PiBWYWxpZGF0aW9uQ3VycmVuY3lDb21wb25lbnQpLFxyXG4gICAgICAgICAgICBtdWx0aTogdHJ1ZVxyXG4gICAgICAgIH1cclxuICAgIF0sXHJcbiAgICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxyXG4gICAgc3R5bGVVcmxzOiBbXCIuLi92YWxpZGF0aW9uLXN0eWxlLnNjc3NcIiwgXCJ2YWxpZGF0aW9uLWN1cnJlbmN5LmNvbXBvbmVudC5zY3NzXCJdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBWYWxpZGF0aW9uQ3VycmVuY3lDb21wb25lbnQgZXh0ZW5kcyBWYWxpZGF0aW9uSW5wdXRDb21wb25lbnQge1xyXG5cclxuICAgIC8qKlxyXG4gICAgICogT3B6aW9uaSBkaXJldHRhbWVudGUgYmluZGF0ZSBhbGxhIGRpcmV0dGl2YSAqKmN1cnJlbmN5TWFzayoqXHJcbiAgICAgKi9cclxuICAgIEBJbnB1dCgpIEN1cnJlbmN5T3B0aW9uczogYW55O1xyXG5cclxuICAgIC8qKlxyXG4gICAgICogQGlnbm9yZSBcclxuICAgICAqL1xyXG4gICAgY29uc3RydWN0b3IoY2RyOiBDaGFuZ2VEZXRlY3RvclJlZiwgQE9wdGlvbmFsKCkgQEluamVjdChOR19WQUxJREFUT1JTKSB2YWxpZGF0b3JzOiBBcnJheTxhbnk+LCBAT3B0aW9uYWwoKSBASW5qZWN0KE5HX0FTWU5DX1ZBTElEQVRPUlMpIGFzeW5jVmFsaWRhdG9yczogQXJyYXk8YW55PiwgaW5qZWN0b3I6IEluamVjdG9yLCBwcm90ZWN0ZWQgbGM6IExvY2FsaXphdGlvblNlcnZpY2UpIHtcclxuICAgICAgICBzdXBlcihjZHIsIHZhbGlkYXRvcnMsIGFzeW5jVmFsaWRhdG9ycywgaW5qZWN0b3IsIGxjKTtcclxuICAgIH1cclxuXHJcbiAgICAvKipcclxuICAgICAqIEBpZ25vcmVcclxuICAgICAqL1xyXG4gICAgbmdPbkluaXQoKTogdm9pZCB7XHJcbiAgICAgICAgc3VwZXIubmdPbkluaXQoKTtcclxuICAgICAgICB0aGlzLnJlZ2lzdGVyRm9jdXNSZXF1ZXN0KCk7XHJcbiAgICB9XHJcblxyXG4gICAgLyoqXHJcbiAgICAgKiBAaWdub3JlXHJcbiAgICAgKi9cclxuICAgIG5nT25EZXN0cm95KCk6IHZvaWQge1xyXG4gICAgICAgIHN1cGVyLm5nT25EZXN0cm95KCk7XHJcbiAgICAgICAgdGhpcy5kZXJlZ2lzdGVyRm9jdXNSZXF1ZXN0KCk7XHJcbiAgICB9XHJcbn0iLCI8bWF0LWZvcm0tZmllbGQgYXBwZWFyYW5jZT1cInt7RmllbGRBcHBlYXJlbmNlfX1cIiBjbGFzcz1cIm1hdC1mdWxsLXdpZHRoIG1hdC1uby1ib3JkZXItdG9wIG1hdC1oZWlnaHQtZml4ZWRcIiBbc3R5bGUud2lkdGgucHhdPVwid2lkdGhQeFwiPlxyXG4gICAgPG1hdC1sYWJlbCAqbmdJZj1cInBsYWNlaG9sZGVyICYmIEZsb2F0aW5nTGFiZWxcIj57e3BsYWNlaG9sZGVyfX08L21hdC1sYWJlbD5cclxuICAgIDxpbnB1dCAjYmFzZUlucHV0PSduZ01vZGVsJ1xyXG4gICAgICAgICAgICNodG1sSW5wdXRcclxuICAgICAgICAgICBjdXJyZW5jeU1hc2tcclxuICAgICAgICAgICBtYXRJbnB1dFxyXG4gICAgICAgICAgIFtyZWFkb25seV09XCJSZWFkb25seVwiXHJcbiAgICAgICAgICAgW29wdGlvbnNdPSdDdXJyZW5jeU9wdGlvbnMnXHJcbiAgICAgICAgICAgWyhuZ01vZGVsKV09XCJ2YWx1ZVwiXHJcbiAgICAgICAgICAgbmFtZT1cInZhbC1pbnB1dFwiXHJcbiAgICAgICAgICAgaWQ9XCJ7e2lkfX1cIlxyXG4gICAgICAgICAgIFtwbGFjZWhvbGRlcl09XCJGbG9hdGluZ0xhYmVsID8gdW5kZWZpbmVkIDogcGxhY2Vob2xkZXJcIlxyXG4gICAgICAgICAgIChjbGljayk9XCJvbkZvY3VzKCRldmVudClcIlxyXG4gICAgICAgICAgIChmb2N1cyk9XCJjaGVja1Rvb2x0aXAoKTtcIlxyXG4gICAgICAgICAgIChrZXl1cCk9XCIoJGV2ZW50LmtleUNvZGUgPT0gMTMgfHwgJGV2ZW50LmtleUNvZGUgPT0gMjcpICYmIG9uRmluYWxpemUoKTtcIlxyXG4gICAgICAgICAgIChibHVyKT1cImNsb3NlVG9vbHRpcCgpOyBvbkZpbmFsaXplKCk7XCJcclxuICAgICAgICAgICBjbGFzcz1cImZvcm0tY29udHJvbCB7e2NsYXNzfX1cIlxyXG4gICAgICAgICAgIFtjbGFzcy5uby1jb250ZW50LXNoaWZ0XT1cIiFub1ZhbGlkYXRlICYmIEN1cnJlbmN5T3B0aW9ucz8uYWxpZ24gPT0gJ2xlZnQnXCJcclxuICAgICAgICAgICBbY2xhc3MuY2hlY2tpbmctZmllbGRdPVwiIW5vVmFsaWRhdGVcIlxyXG4gICAgICAgICAgIChuZ01vZGVsQ2hhbmdlKT1cIm9uTW9kZWxDaGFuZ2UoJGV2ZW50KVwiXHJcbiAgICAgICAgICAgdHlwZT1cInt7VHlwZX19XCJcclxuICAgICAgICAgICBbdG9vbHRpcF09XCJ0b2xUZW1wbGF0ZVwiXHJcbiAgICAgICAgICAgdHJpZ2dlcnM9XCJcIlxyXG4gICAgICAgICAgIHBsYWNlbWVudD1cInRvcFwiXHJcbiAgICAgICAgICAgYXV0b2NvbXBsZXRlPVwie3thdXRvY29tcGxldGV9fVwiIC8+XHJcbjwvbWF0LWZvcm0tZmllbGQ+XHJcblxyXG48bmctdGVtcGxhdGUgI3RvbFRlbXBsYXRlPlxyXG4gICAgPGRpdj5cclxuICAgICAgICA8c3BhbiBjbGFzcz1cImNsb3NlLWJ1dHRvbiBwdWxsLXJpZ2h0XCIgKGNsaWNrKT1cImNsb3NlVG9vbHRpcCgpXCIgYXJpYS1sYWJlbD1cIkNsb3NlXCI+XHJcbiAgICAgICAgICAgIDxzcGFuIGFyaWEtaGlkZGVuPVwidHJ1ZVwiPiZ0aW1lczs8L3NwYW4+XHJcbiAgICAgICAgPC9zcGFuPlxyXG4gICAgICAgIDxzcGFuPnt7dmFsaWRhdGlvbkZhaWxlZEJpbmR9fTwvc3Bhbj5cclxuICAgIDwvZGl2PlxyXG48L25nLXRlbXBsYXRlPiJdfQ==