@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.
- package/{esm2020 → esm2022}/lib/forms/base-form-control.mjs +6 -4
- package/{esm2020 → esm2022}/lib/forms/form-adaptive/form-adaptive.component.loc.mjs +4 -4
- package/{esm2020 → esm2022}/lib/forms/form-adaptive/form-adaptive.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/forms/form-autocomplete/form-autocomplete.component.loc.mjs +4 -4
- package/{esm2020 → esm2022}/lib/forms/form-autocomplete/form-autocomplete.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/forms/form-checkbox/form-checkbox.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/forms/form-date/form-date.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/forms/form-datetime/form-datetime.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/forms/form-empty/form-empty.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/forms/form-error/form-error.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/forms/form-file/form-file.component.loc.mjs +4 -4
- package/{esm2020 → esm2022}/lib/forms/form-file/form-file.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/forms/form-info/form-info.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/forms/form-input/form-input.component.mjs +5 -5
- package/{esm2020 → esm2022}/lib/forms/form-multiselect/form-multiselect.component.loc.mjs +4 -4
- package/{esm2020 → esm2022}/lib/forms/form-multiselect/form-multiselect.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/forms/form-select/form-select.component.loc.mjs +4 -4
- package/{esm2020 → esm2022}/lib/forms/form-select/form-select.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/forms/form-template/form-template.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/forms/form-textarea/form-textarea.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/forms/form-time/form-time.component.mjs +4 -4
- package/{esm2020 → esm2022}/lib/forms-and-validations.module.mjs +64 -64
- package/{esm2020 → esm2022}/lib/models/dayjs-adapter/dayjs-date-adapter.mjs +4 -4
- package/{esm2020 → esm2022}/lib/validations/base-validation.loc.mjs +4 -4
- package/{esm2020 → esm2022}/lib/validations/base-validation.mjs +4 -4
- package/{esm2020 → esm2022}/lib/validations/customValidators/CustomRequiredDirective.mjs +4 -4
- package/esm2022/lib/validations/validation-autocomplete/validation-autocomplete.component.mjs +147 -0
- package/esm2022/lib/validations/validation-autocomplete-multi/validation-autocomplete-multi.component.mjs +240 -0
- package/esm2022/lib/validations/validation-currency/validation-currency.component.mjs +75 -0
- package/esm2022/lib/validations/validation-date/validation-date.component.mjs +183 -0
- package/esm2022/lib/validations/validation-datetime/validation-datetime.component.mjs +212 -0
- package/esm2022/lib/validations/validation-input/validation-input.component.mjs +218 -0
- package/esm2022/lib/validations/validation-select/validation-select.component.mjs +183 -0
- package/esm2022/lib/validations/validation-text-area/validation-text-area.component.mjs +78 -0
- package/{fesm2020 → fesm2022}/esfaenza-forms-and-validations.mjs +227 -223
- package/fesm2022/esfaenza-forms-and-validations.mjs.map +1 -0
- package/lib/forms/base-form-control.d.ts +3 -1
- package/lib/forms/form-adaptive/form-adaptive.component.d.ts +1 -1
- package/lib/forms/form-autocomplete/form-autocomplete.component.d.ts +1 -1
- package/lib/forms/form-checkbox/form-checkbox.component.d.ts +1 -1
- package/lib/forms/form-date/form-date.component.d.ts +1 -1
- package/lib/forms/form-datetime/form-datetime.component.d.ts +1 -1
- package/lib/forms/form-empty/form-empty.component.d.ts +1 -1
- package/lib/forms/form-error/form-error.component.d.ts +1 -1
- package/lib/forms/form-file/form-file.component.d.ts +1 -1
- package/lib/forms/form-info/form-info.component.d.ts +1 -1
- package/lib/forms/form-input/form-input.component.d.ts +1 -1
- package/lib/forms/form-multiselect/form-multiselect.component.d.ts +1 -1
- package/lib/forms/form-select/form-select.component.d.ts +1 -1
- package/lib/forms/form-template/form-template.component.d.ts +1 -1
- package/lib/forms/form-textarea/form-textarea.component.d.ts +1 -1
- package/lib/forms/form-time/form-time.component.d.ts +1 -1
- package/lib/validations/base-validation.d.ts +1 -1
- package/lib/validations/customValidators/CustomRequiredDirective.d.ts +1 -1
- package/lib/validations/validation-autocomplete/validation-autocomplete.component.d.ts +1 -1
- package/lib/validations/validation-autocomplete-multi/validation-autocomplete-multi.component.d.ts +1 -1
- package/lib/validations/validation-currency/validation-currency.component.d.ts +1 -1
- package/lib/validations/validation-date/validation-date.component.d.ts +1 -1
- package/lib/validations/validation-datetime/validation-datetime.component.d.ts +1 -1
- package/lib/validations/validation-input/validation-input.component.d.ts +2 -2
- package/lib/validations/validation-select/validation-select.component.d.ts +1 -1
- package/lib/validations/validation-text-area/validation-text-area.component.d.ts +1 -1
- package/package.json +20 -26
- package/esm2020/lib/validations/validation-autocomplete/validation-autocomplete.component.mjs +0 -147
- package/esm2020/lib/validations/validation-autocomplete-multi/validation-autocomplete-multi.component.mjs +0 -240
- package/esm2020/lib/validations/validation-currency/validation-currency.component.mjs +0 -75
- package/esm2020/lib/validations/validation-date/validation-date.component.mjs +0 -183
- package/esm2020/lib/validations/validation-datetime/validation-datetime.component.mjs +0 -212
- package/esm2020/lib/validations/validation-input/validation-input.component.mjs +0 -216
- package/esm2020/lib/validations/validation-select/validation-select.component.mjs +0 -183
- package/esm2020/lib/validations/validation-text-area/validation-text-area.component.mjs +0 -78
- package/fesm2015/esfaenza-forms-and-validations.mjs +0 -4310
- package/fesm2015/esfaenza-forms-and-validations.mjs.map +0 -1
- package/fesm2020/esfaenza-forms-and-validations.mjs.map +0 -1
- /package/{esm2020 → esm2022}/esfaenza-forms-and-validations.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/models/AppFile.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/models/ChangeEvent.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/models/FormsAndValidationsModuleConfig.mjs +0 -0
- /package/{esm2020 → esm2022}/lib/tokens.mjs +0 -0
- /package/{esm2020 → esm2022}/public-api.mjs +0 -0
|
@@ -0,0 +1,218 @@
|
|
|
1
|
+
// Angular
|
|
2
|
+
import { NG_ASYNC_VALIDATORS, NG_VALIDATORS, NG_VALUE_ACCESSOR, NgControl } from "@angular/forms";
|
|
3
|
+
import { ChangeDetectionStrategy, Component, ContentChild, forwardRef, Inject, Input, Optional, 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 "@angular/material/datepicker";
|
|
16
|
+
import * as i7 from "ngx-bootstrap/tooltip";
|
|
17
|
+
/**
|
|
18
|
+
* Componente di validaizone per gli input a semplice casella di testo
|
|
19
|
+
*/
|
|
20
|
+
export class ValidationInputComponent extends BaseValidation {
|
|
21
|
+
/**
|
|
22
|
+
* @ignore
|
|
23
|
+
*/
|
|
24
|
+
constructor(cdr, _validators, _asyncValidators, injector, lc) {
|
|
25
|
+
super(cdr);
|
|
26
|
+
this._validators = _validators;
|
|
27
|
+
this._asyncValidators = _asyncValidators;
|
|
28
|
+
this.injector = injector;
|
|
29
|
+
this.lc = lc;
|
|
30
|
+
/**
|
|
31
|
+
* Permette di scrivere o meno nel campo di Input. Si differenzia dal Readonly in quanto fisicamente l'Input è scrivibile e vengono mantenuti i temi della validazione
|
|
32
|
+
* ma interagire direttamente con la casella di Input per l'utente non è possibile
|
|
33
|
+
*/
|
|
34
|
+
this.Frozen = false;
|
|
35
|
+
/**
|
|
36
|
+
* Indica se questo Comopnente deve rappresentare un oggetto di Input di tipo "Password"
|
|
37
|
+
*/
|
|
38
|
+
this.Password = false;
|
|
39
|
+
/**
|
|
40
|
+
* Indica se deve mostrare un indicazione di warning nel suffisso
|
|
41
|
+
*/
|
|
42
|
+
this.showWarning = false;
|
|
43
|
+
/**
|
|
44
|
+
* Classe del warning eventualmente modificabile.
|
|
45
|
+
*
|
|
46
|
+
* Default: "fa fa-warning"
|
|
47
|
+
*/
|
|
48
|
+
this.warningClass = "fa fa-warning";
|
|
49
|
+
/**
|
|
50
|
+
* Identifica se il testo di un componente di tipo "password" dev'essere visualizzato o meno
|
|
51
|
+
*/
|
|
52
|
+
this.passShown = false;
|
|
53
|
+
/**
|
|
54
|
+
* Tipo del componente, può essere "text" o "password" e viene impostato automaticamente dall'Input **Password**
|
|
55
|
+
*/
|
|
56
|
+
this.Type = "text";
|
|
57
|
+
/**
|
|
58
|
+
* Indicazione se il componente ha o meno un suffisso.
|
|
59
|
+
*
|
|
60
|
+
* Valorizzato a **true** solo se viene trovata una proiezione su **suffix_internal** o se l'Input **showWarning** viene impostato a **true**
|
|
61
|
+
*/
|
|
62
|
+
this.HasSuffix = false;
|
|
63
|
+
/**
|
|
64
|
+
* Indicazione se il componente ha o meno un prefisso.
|
|
65
|
+
*
|
|
66
|
+
* Valorizzato a **true** solo se viene trovata una proiezione su **prefix_internal**
|
|
67
|
+
*/
|
|
68
|
+
this.HasPrefix = false;
|
|
69
|
+
/**
|
|
70
|
+
* @ignore
|
|
71
|
+
*/
|
|
72
|
+
this.onTouched = () => { };
|
|
73
|
+
}
|
|
74
|
+
/**
|
|
75
|
+
* @ignore
|
|
76
|
+
*/
|
|
77
|
+
ngOnInit() {
|
|
78
|
+
super.ngOnInit();
|
|
79
|
+
this.registerFocusRequest();
|
|
80
|
+
this.checkRequiredness(this._validators);
|
|
81
|
+
if (this.Password)
|
|
82
|
+
this.Type = "password";
|
|
83
|
+
}
|
|
84
|
+
/**
|
|
85
|
+
* @ignore
|
|
86
|
+
*/
|
|
87
|
+
ngOnDestroy() {
|
|
88
|
+
super.ngOnDestroy();
|
|
89
|
+
this.deregisterFocusRequest();
|
|
90
|
+
if (this.tooltipSubscription)
|
|
91
|
+
this.tooltipSubscription.unsubscribe();
|
|
92
|
+
}
|
|
93
|
+
/**
|
|
94
|
+
* @ignore
|
|
95
|
+
*/
|
|
96
|
+
ngAfterViewInit() {
|
|
97
|
+
this.HasSuffix = !!this.suffix_internal || this.showWarning;
|
|
98
|
+
this.HasPrefix = !!this.prefix_internal;
|
|
99
|
+
this.postBinding();
|
|
100
|
+
}
|
|
101
|
+
/**
|
|
102
|
+
* @ignore
|
|
103
|
+
*/
|
|
104
|
+
ngOnChanges(changes) {
|
|
105
|
+
const newShowWarnings = changes["showWarning"];
|
|
106
|
+
if (newShowWarnings)
|
|
107
|
+
this.HasSuffix = !!this.suffix_internal || this.showWarning;
|
|
108
|
+
}
|
|
109
|
+
/**
|
|
110
|
+
* Metodo che si occupa di collegare i validatori e la funzione di reset dal **ControlValueAccessor** rappresentato
|
|
111
|
+
* da questo componente al **ControlValueAccessor** rappresentato dall'effettivo elemento di Input presente lato HTML
|
|
112
|
+
*/
|
|
113
|
+
postBinding() {
|
|
114
|
+
this.CheckValidity();
|
|
115
|
+
const ngControl = this.injector.get(NgControl, null);
|
|
116
|
+
if (ngControl) {
|
|
117
|
+
this.parentControl = ngControl.control;
|
|
118
|
+
// Se la variabile novalidate è true, elimino tutti i validatori eventualmente inseriti
|
|
119
|
+
if (this.noValidate) {
|
|
120
|
+
this.parentControl.clearValidators();
|
|
121
|
+
this.parentControl.clearAsyncValidators();
|
|
122
|
+
}
|
|
123
|
+
else {
|
|
124
|
+
this.baseInput.control.setAsyncValidators(this._asyncValidators);
|
|
125
|
+
this.baseInput.control.setValidators(this._validators);
|
|
126
|
+
}
|
|
127
|
+
// Faccio in modo che se chiamo il reset del controllo (o della form) dall'esterno si resetti anche il controllo nativo
|
|
128
|
+
const origFunc = this.parentControl.reset;
|
|
129
|
+
this.parentControl.reset = () => {
|
|
130
|
+
origFunc.apply(this.parentControl);
|
|
131
|
+
this.baseInput.control.reset();
|
|
132
|
+
this.tooltip.hide();
|
|
133
|
+
};
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
/**
|
|
137
|
+
* @ignore
|
|
138
|
+
*/
|
|
139
|
+
writeValue(value) {
|
|
140
|
+
this.value = value;
|
|
141
|
+
this.propagateChange(value);
|
|
142
|
+
this.cdr.markForCheck();
|
|
143
|
+
}
|
|
144
|
+
/**
|
|
145
|
+
* L'emit della modifica al valore viene gestito su un evento custom (**inputChange**) come workaround al malfunzionamento dell'**ngModelChange** nativo
|
|
146
|
+
*
|
|
147
|
+
* @param {any} toEmit valore da propagare all'esterno
|
|
148
|
+
*/
|
|
149
|
+
onModelChange(toEmit) {
|
|
150
|
+
this.writeValue(toEmit);
|
|
151
|
+
this.inputChange.emit(toEmit);
|
|
152
|
+
this.onTouched();
|
|
153
|
+
}
|
|
154
|
+
/**
|
|
155
|
+
* @ignore
|
|
156
|
+
*/
|
|
157
|
+
registerOnChange(fn) {
|
|
158
|
+
this.propagateChange = fn;
|
|
159
|
+
}
|
|
160
|
+
/**
|
|
161
|
+
* @ignore
|
|
162
|
+
*/
|
|
163
|
+
registerOnTouched(fn) {
|
|
164
|
+
this.onTouched = fn;
|
|
165
|
+
}
|
|
166
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ValidationInputComponent, 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 }); }
|
|
167
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ValidationInputComponent, selector: "val-input", inputs: { Frozen: "Frozen", Password: "Password", showWarning: "showWarning", warningTitle: "warningTitle", warningClass: "warningClass", value: "value", Type: "Type" }, providers: [
|
|
168
|
+
{ provide: LocalizationService, useClass: BaseValidationLoc },
|
|
169
|
+
{
|
|
170
|
+
provide: NG_VALUE_ACCESSOR,
|
|
171
|
+
useExisting: forwardRef(() => ValidationInputComponent),
|
|
172
|
+
multi: true
|
|
173
|
+
}
|
|
174
|
+
], queries: [{ propertyName: "suffix_internal", first: true, predicate: ["suffix_internal"], descendants: true }, { propertyName: "prefix_internal", first: true, predicate: ["prefix_internal"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<mat-form-field floatLabel=\"never\" appearance=\"{{FieldAppearence}}\" class=\"mat-full-width mat-no-border-top mat-height-fixed\" [style.width.px]=\"widthPx\">\r\n <mat-label [class.app-margin-left-25]=\"HasPrefix\" *ngIf=\"placeholder && FloatingLabel\">{{placeholder}}</mat-label>\r\n <ng-container *ngIf=\"HasPrefix\">\r\n <ng-container *ngTemplateOutlet=\"prefix_internal\"></ng-container>\r\n </ng-container>\r\n\r\n <!-- Bisogna fixare un po' l'uso di readonly, disabled, frozen cazzi e mazzi -->\r\n <input matInput\r\n #baseInput='ngModel'\r\n #htmlInput\r\n type=\"{{Type}}\"\r\n triggers=\"\"\r\n placement=\"top\"\r\n autocomplete=\"{{autocomplete}}\"\r\n name=\"{{id}}\"\r\n class=\"form-control {{class}}\"\r\n id=\"{{id}}\"\r\n [class.app-margin-left-25]=\"HasPrefix\"\r\n [class.mat-input-with-suffix]=\"HasSuffix || Password || showWarning\"\r\n [(ngModel)]=\"value\"\r\n [class.checking-field]=\"!noValidate && !showWarning\"\r\n [tooltip]=\"tolTemplate\"\r\n [readonly]=\"Frozen\"\r\n [disabled]=\"Readonly || disabled || Frozen\"\r\n [placeholder]=\"FloatingLabel ? undefined : placeholder\"\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 <ng-container *ngIf=\"HasSuffix || Password || showWarning\">\r\n <ng-container *ngIf=\"!Password && !showWarning\">\r\n <ng-container *ngTemplateOutlet=\"suffix_internal\"></ng-container>\r\n </ng-container>\r\n\r\n <span class=\"form-input-suffix\" *ngIf=\"Password || showWarning\">\r\n <ng-container *ngIf=\"Password\" matSuffix>\r\n <a *ngIf=\"passShown\" class=\"fa fa-eye-slash app-fs-16 app-pointer\" (click)=\"Type = 'password'; passShown = !passShown; $event.preventDefault()\"></a>\r\n <a *ngIf=\"!passShown\" class=\"fa fa-eye app-fs-16 app-pointer\" (click)=\"Type = 'text'; passShown = !passShown; $event.preventDefault()\"></a>\r\n </ng-container>\r\n <ng-container *ngIf=\"showWarning\" matSuffix>\r\n <span title=\"{{warningTitle}}\" class=\"{{warningClass}} text-warning app-fs-16\"></span>\r\n </ng-container>\r\n </span>\r\n </ng-container>\r\n</mat-form-field>\r\n\r\n<!-- Questo compoennte nascosto serve solamente per assicurarsi che angular carichi gli stili dei mat-button che altrimenti non caricherebbe... dunno why -->\r\n<div hidden><mat-datepicker-toggle></mat-datepicker-toggle></div>\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.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { 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: i4.MatLegacySuffix, selector: "[matSuffix]" }, { kind: "directive", type: i5.MatLegacyInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", exportAs: ["matInput"] }, { kind: "component", type: i6.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { kind: "directive", type: i7.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"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
175
|
+
}
|
|
176
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ValidationInputComponent, decorators: [{
|
|
177
|
+
type: Component,
|
|
178
|
+
args: [{ selector: "val-input", changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
179
|
+
{ provide: LocalizationService, useClass: BaseValidationLoc },
|
|
180
|
+
{
|
|
181
|
+
provide: NG_VALUE_ACCESSOR,
|
|
182
|
+
useExisting: forwardRef(() => ValidationInputComponent),
|
|
183
|
+
multi: true
|
|
184
|
+
}
|
|
185
|
+
], encapsulation: ViewEncapsulation.None, template: "<mat-form-field floatLabel=\"never\" appearance=\"{{FieldAppearence}}\" class=\"mat-full-width mat-no-border-top mat-height-fixed\" [style.width.px]=\"widthPx\">\r\n <mat-label [class.app-margin-left-25]=\"HasPrefix\" *ngIf=\"placeholder && FloatingLabel\">{{placeholder}}</mat-label>\r\n <ng-container *ngIf=\"HasPrefix\">\r\n <ng-container *ngTemplateOutlet=\"prefix_internal\"></ng-container>\r\n </ng-container>\r\n\r\n <!-- Bisogna fixare un po' l'uso di readonly, disabled, frozen cazzi e mazzi -->\r\n <input matInput\r\n #baseInput='ngModel'\r\n #htmlInput\r\n type=\"{{Type}}\"\r\n triggers=\"\"\r\n placement=\"top\"\r\n autocomplete=\"{{autocomplete}}\"\r\n name=\"{{id}}\"\r\n class=\"form-control {{class}}\"\r\n id=\"{{id}}\"\r\n [class.app-margin-left-25]=\"HasPrefix\"\r\n [class.mat-input-with-suffix]=\"HasSuffix || Password || showWarning\"\r\n [(ngModel)]=\"value\"\r\n [class.checking-field]=\"!noValidate && !showWarning\"\r\n [tooltip]=\"tolTemplate\"\r\n [readonly]=\"Frozen\"\r\n [disabled]=\"Readonly || disabled || Frozen\"\r\n [placeholder]=\"FloatingLabel ? undefined : placeholder\"\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 <ng-container *ngIf=\"HasSuffix || Password || showWarning\">\r\n <ng-container *ngIf=\"!Password && !showWarning\">\r\n <ng-container *ngTemplateOutlet=\"suffix_internal\"></ng-container>\r\n </ng-container>\r\n\r\n <span class=\"form-input-suffix\" *ngIf=\"Password || showWarning\">\r\n <ng-container *ngIf=\"Password\" matSuffix>\r\n <a *ngIf=\"passShown\" class=\"fa fa-eye-slash app-fs-16 app-pointer\" (click)=\"Type = 'password'; passShown = !passShown; $event.preventDefault()\"></a>\r\n <a *ngIf=\"!passShown\" class=\"fa fa-eye app-fs-16 app-pointer\" (click)=\"Type = 'text'; passShown = !passShown; $event.preventDefault()\"></a>\r\n </ng-container>\r\n <ng-container *ngIf=\"showWarning\" matSuffix>\r\n <span title=\"{{warningTitle}}\" class=\"{{warningClass}} text-warning app-fs-16\"></span>\r\n </ng-container>\r\n </span>\r\n </ng-container>\r\n</mat-form-field>\r\n\r\n<!-- Questo compoennte nascosto serve solamente per assicurarsi che angular carichi gli stili dei mat-button che altrimenti non caricherebbe... dunno why -->\r\n<div hidden><mat-datepicker-toggle></mat-datepicker-toggle></div>\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"] }]
|
|
186
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: Array, decorators: [{
|
|
187
|
+
type: Optional
|
|
188
|
+
}, {
|
|
189
|
+
type: Inject,
|
|
190
|
+
args: [NG_VALIDATORS]
|
|
191
|
+
}] }, { type: Array, decorators: [{
|
|
192
|
+
type: Optional
|
|
193
|
+
}, {
|
|
194
|
+
type: Inject,
|
|
195
|
+
args: [NG_ASYNC_VALIDATORS]
|
|
196
|
+
}] }, { type: i0.Injector }, { type: i1.LocalizationService }]; }, propDecorators: { Frozen: [{
|
|
197
|
+
type: Input
|
|
198
|
+
}], Password: [{
|
|
199
|
+
type: Input
|
|
200
|
+
}], showWarning: [{
|
|
201
|
+
type: Input
|
|
202
|
+
}], warningTitle: [{
|
|
203
|
+
type: Input
|
|
204
|
+
}], warningClass: [{
|
|
205
|
+
type: Input
|
|
206
|
+
}], value: [{
|
|
207
|
+
type: Input,
|
|
208
|
+
args: ["value"]
|
|
209
|
+
}], suffix_internal: [{
|
|
210
|
+
type: ContentChild,
|
|
211
|
+
args: ["suffix_internal", { static: false }]
|
|
212
|
+
}], prefix_internal: [{
|
|
213
|
+
type: ContentChild,
|
|
214
|
+
args: ["prefix_internal", { static: false }]
|
|
215
|
+
}], Type: [{
|
|
216
|
+
type: Input
|
|
217
|
+
}] } });
|
|
218
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validation-input.component.js","sourceRoot":"","sources":["../../../../../../projects/forms-and-validations/src/lib/validations/validation-input/validation-input.component.ts","../../../../../../projects/forms-and-validations/src/lib/validations/validation-input/validation-input.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, ContentChild, forwardRef, Inject, Injector, Input, Optional, SimpleChanges, ViewEncapsulation } from \"@angular/core\";\r\n\r\n// Configurazioni\r\nimport { LocalizationService } from \"@esfaenza/localizations\";\r\n\r\n// Direttive, Componenti, Librerie\r\nimport { BaseValidation } from \"../base-validation\";\r\nimport { BaseValidationLoc } from '../base-validation.loc';\r\nimport { Subscription } from \"rxjs\";\r\n\r\n/**\r\n * Componente di validaizone per gli input a semplice casella di testo\r\n */\r\n@Component({\r\n    selector: \"val-input\",\r\n    templateUrl: \"validation-input.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(() => ValidationInputComponent),\r\n            multi: true\r\n        }\r\n    ],\r\n    encapsulation: ViewEncapsulation.None,\r\n    styleUrls: [\"../validation-style.scss\"]\r\n})\r\nexport class ValidationInputComponent extends BaseValidation implements ControlValueAccessor {\r\n\r\n    /** \r\n    * Permette di scrivere o meno nel campo di Input. Si differenzia dal Readonly in quanto fisicamente l'Input è scrivibile e vengono mantenuti i temi della validazione\r\n    * ma interagire direttamente con la casella di Input per l'utente non è possibile\r\n    */\r\n    @Input() Frozen: boolean = false;\r\n\r\n    /**\r\n     * Indica se questo Comopnente deve rappresentare un oggetto di Input di tipo \"Password\"\r\n     */\r\n    @Input() public Password: boolean = false;\r\n\r\n    /**\r\n     * Indica se deve mostrare un indicazione di warning nel suffisso\r\n     */\r\n    @Input() public showWarning: boolean = false;\r\n\r\n    /**\r\n     * Titolo del Warning da impostare se **showWarning** è impostato a **true**\r\n     */\r\n    @Input() public warningTitle: string;\r\n\r\n    /**\r\n     * Classe del warning eventualmente modificabile. \r\n     * \r\n     * Default: \"fa fa-warning\"\r\n     */\r\n    @Input() public warningClass: string = \"fa fa-warning\";\r\n\r\n    /**\r\n     * Valore del modello rappresentato da questo input\r\n     */\r\n    @Input(\"value\") public value: any;\r\n\r\n    /**\r\n     * Contiene la proiezione del suffisso qualora fosse fornita\r\n     */\r\n    @ContentChild(\"suffix_internal\", { static: false }) suffix_internal;\r\n\r\n    /**\r\n     * Contiene la proiezione del prefisso qualora fosse fornita\r\n     */\r\n    @ContentChild(\"prefix_internal\", { static: false }) prefix_internal;\r\n\r\n    /**\r\n     * Subscription del tooltip da ripulire al destroy del componente\r\n     */\r\n    private tooltipSubscription: Subscription;\r\n\r\n    /**\r\n     * Controllo esposto ottenuto tramite injector\r\n     */\r\n    private parentControl: UntypedFormControl;\r\n\r\n    /**\r\n     * Identifica se il testo di un componente di tipo \"password\" dev'essere visualizzato o meno\r\n     */\r\n    public passShown: boolean = false;\r\n\r\n    /**\r\n     * Tipo del componente, può essere \"text\" o \"password\" e viene impostato automaticamente dall'Input **Password**\r\n     */\r\n    @Input() public Type: string = \"text\";\r\n\r\n    /**\r\n     * Indicazione se il componente ha o meno un suffisso. \r\n     * \r\n     * Valorizzato a **true** solo se viene trovata una proiezione su **suffix_internal** o se l'Input **showWarning** viene impostato a **true**\r\n     */\r\n    public HasSuffix: boolean = false;\r\n\r\n    /**\r\n     * Indicazione se il componente ha o meno un prefisso. \r\n     * \r\n     * Valorizzato a **true** solo se viene trovata una proiezione su **prefix_internal**\r\n     */\r\n    public HasPrefix: boolean = false;\r\n\r\n    /**\r\n     * @ignore \r\n     */\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    /**\r\n     * @ignore \r\n     */\r\n    ngOnInit() {\r\n        super.ngOnInit();\r\n\r\n        this.registerFocusRequest();\r\n\r\n        this.checkRequiredness(this._validators);\r\n\r\n        if (this.Password)\r\n            this.Type = \"password\";\r\n    }\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    ngOnDestroy() {\r\n        super.ngOnDestroy();\r\n\r\n        this.deregisterFocusRequest();\r\n        if (this.tooltipSubscription) this.tooltipSubscription.unsubscribe();\r\n    }\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    ngAfterViewInit() {\r\n        this.HasSuffix = !!this.suffix_internal || this.showWarning;\r\n        this.HasPrefix = !!this.prefix_internal;\r\n\r\n        this.postBinding();\r\n    }\r\n\r\n    /**\r\n     * @ignore\r\n     */\r\n    ngOnChanges(changes: SimpleChanges) {\r\n        const newShowWarnings = changes[\"showWarning\"];\r\n        if (newShowWarnings)\r\n            this.HasSuffix = !!this.suffix_internal || this.showWarning;\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    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 = () => {\r\n                origFunc.apply(this.parentControl);\r\n                this.baseInput.control.reset();\r\n                this.tooltip.hide();\r\n            };\r\n        }\r\n    }\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    private onTouched = () => { };\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    writeValue(value: any): void {\r\n        this.value = value;\r\n        this.propagateChange(value);\r\n        this.cdr.markForCheck();\r\n    }\r\n\r\n    /**\r\n     * L'emit della modifica al valore viene gestito su un evento custom (**inputChange**) come workaround al malfunzionamento dell'**ngModelChange** nativo\r\n     * \r\n     * @param {any} toEmit valore da propagare all'esterno\r\n     */\r\n    onModelChange(toEmit) {\r\n        this.writeValue(toEmit);\r\n        this.inputChange.emit(toEmit);\r\n        this.onTouched();\r\n    }\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    registerOnChange(fn: any): void {\r\n        this.propagateChange = fn;\r\n    }\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    registerOnTouched(fn: any): void {\r\n        this.onTouched = fn;\r\n    }\r\n}","<mat-form-field floatLabel=\"never\" appearance=\"{{FieldAppearence}}\" class=\"mat-full-width mat-no-border-top mat-height-fixed\" [style.width.px]=\"widthPx\">\r\n    <mat-label [class.app-margin-left-25]=\"HasPrefix\" *ngIf=\"placeholder && FloatingLabel\">{{placeholder}}</mat-label>\r\n    <ng-container *ngIf=\"HasPrefix\">\r\n        <ng-container *ngTemplateOutlet=\"prefix_internal\"></ng-container>\r\n    </ng-container>\r\n\r\n    <!-- Bisogna fixare un po' l'uso di readonly, disabled, frozen cazzi e mazzi -->\r\n    <input matInput\r\n           #baseInput='ngModel'\r\n           #htmlInput\r\n           type=\"{{Type}}\"\r\n           triggers=\"\"\r\n           placement=\"top\"\r\n           autocomplete=\"{{autocomplete}}\"\r\n           name=\"{{id}}\"\r\n           class=\"form-control {{class}}\"\r\n           id=\"{{id}}\"\r\n           [class.app-margin-left-25]=\"HasPrefix\"\r\n           [class.mat-input-with-suffix]=\"HasSuffix || Password || showWarning\"\r\n           [(ngModel)]=\"value\"\r\n           [class.checking-field]=\"!noValidate && !showWarning\"\r\n           [tooltip]=\"tolTemplate\"\r\n           [readonly]=\"Frozen\"\r\n           [disabled]=\"Readonly || disabled || Frozen\"\r\n           [placeholder]=\"FloatingLabel ? undefined : placeholder\"\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    <ng-container *ngIf=\"HasSuffix || Password || showWarning\">\r\n        <ng-container *ngIf=\"!Password && !showWarning\">\r\n            <ng-container *ngTemplateOutlet=\"suffix_internal\"></ng-container>\r\n        </ng-container>\r\n\r\n        <span class=\"form-input-suffix\" *ngIf=\"Password || showWarning\">\r\n            <ng-container *ngIf=\"Password\" matSuffix>\r\n                <a *ngIf=\"passShown\" class=\"fa fa-eye-slash app-fs-16 app-pointer\" (click)=\"Type = 'password'; passShown = !passShown; $event.preventDefault()\"></a>\r\n                <a *ngIf=\"!passShown\" class=\"fa fa-eye app-fs-16 app-pointer\" (click)=\"Type = 'text'; passShown = !passShown; $event.preventDefault()\"></a>\r\n            </ng-container>\r\n            <ng-container *ngIf=\"showWarning\" matSuffix>\r\n                <span title=\"{{warningTitle}}\" class=\"{{warningClass}} text-warning app-fs-16\"></span>\r\n            </ng-container>\r\n        </span>\r\n    </ng-container>\r\n</mat-form-field>\r\n\r\n<!-- Questo compoennte nascosto serve solamente per assicurarsi che angular carichi gli stili dei mat-button che altrimenti non caricherebbe... dunno why -->\r\n<div hidden><mat-datepicker-toggle></mat-datepicker-toggle></div>\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,183 @@
|
|
|
1
|
+
// Angular
|
|
2
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, forwardRef, Inject, Input, Optional, Output, ViewEncapsulation } from "@angular/core";
|
|
3
|
+
import { NG_ASYNC_VALIDATORS, NG_VALIDATORS, NG_VALUE_ACCESSOR, NgControl } from "@angular/forms";
|
|
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 "../customValidators/CustomRequiredDirective";
|
|
17
|
+
/**
|
|
18
|
+
* Componente di validaizone per gli input a selezione singola
|
|
19
|
+
*/
|
|
20
|
+
export class ValidationSelectComponent extends BaseValidation {
|
|
21
|
+
/**
|
|
22
|
+
* @ignore
|
|
23
|
+
*/
|
|
24
|
+
constructor(_validators, _asyncValidators, injector, cdr, lc) {
|
|
25
|
+
super(cdr);
|
|
26
|
+
this._validators = _validators;
|
|
27
|
+
this._asyncValidators = _asyncValidators;
|
|
28
|
+
this.injector = injector;
|
|
29
|
+
this.lc = lc;
|
|
30
|
+
/**
|
|
31
|
+
* valore del campo vuoto della select
|
|
32
|
+
*/
|
|
33
|
+
this.emptyFieldValue = "-2000";
|
|
34
|
+
/**
|
|
35
|
+
* Valore del placeholder
|
|
36
|
+
*/
|
|
37
|
+
this.placeHolderValue = "-1000";
|
|
38
|
+
/**
|
|
39
|
+
* Per i componenti non obbligatori indica se fornire un "valore vuoto"
|
|
40
|
+
*/
|
|
41
|
+
this.emptyValue = true;
|
|
42
|
+
/**
|
|
43
|
+
* Indica se mostrare o nascondere il simboletto di validazione (Tic verde o Croce rossa)
|
|
44
|
+
*/
|
|
45
|
+
this.showValidationSymbol = true;
|
|
46
|
+
/**
|
|
47
|
+
* Contenuto della label Floattante Material-Style
|
|
48
|
+
*/
|
|
49
|
+
this.label = "";
|
|
50
|
+
/**
|
|
51
|
+
* Evento richiamato quando si perde il focus sull'input di inserimento
|
|
52
|
+
*/
|
|
53
|
+
this.onBlur = new EventEmitter();
|
|
54
|
+
/**
|
|
55
|
+
* @ignore
|
|
56
|
+
*/
|
|
57
|
+
this.onTouched = () => { }; //placeholder on touched function
|
|
58
|
+
}
|
|
59
|
+
/**
|
|
60
|
+
* @ignore
|
|
61
|
+
*/
|
|
62
|
+
ngOnInit() {
|
|
63
|
+
super.ngOnInit();
|
|
64
|
+
this.registerFocusRequest();
|
|
65
|
+
this.checkRequiredness(this._validators);
|
|
66
|
+
}
|
|
67
|
+
/**
|
|
68
|
+
* @ignore
|
|
69
|
+
*/
|
|
70
|
+
ngOnDestroy() {
|
|
71
|
+
super.ngOnDestroy();
|
|
72
|
+
this.deregisterFocusRequest();
|
|
73
|
+
if (this.tooltipSubscription)
|
|
74
|
+
this.tooltipSubscription.unsubscribe();
|
|
75
|
+
}
|
|
76
|
+
/**
|
|
77
|
+
* @ignore
|
|
78
|
+
*/
|
|
79
|
+
ngAfterViewInit() {
|
|
80
|
+
this.postBinding();
|
|
81
|
+
}
|
|
82
|
+
/**
|
|
83
|
+
* Metodo che si occupa di collegare i validatori e la funzione di reset dal **ControlValueAccessor** rappresentato
|
|
84
|
+
* da questo componente al **ControlValueAccessor** rappresentato dall'effettivo elemento di Input presente lato HTML
|
|
85
|
+
*/
|
|
86
|
+
postBinding() {
|
|
87
|
+
// Eredito i validatori
|
|
88
|
+
if (!this.noValidate) {
|
|
89
|
+
this.baseInput.control.setAsyncValidators(this._asyncValidators);
|
|
90
|
+
this.baseInput.control.setValidators(this._validators);
|
|
91
|
+
}
|
|
92
|
+
this.CheckValidity();
|
|
93
|
+
const ngControl = this.injector.get(NgControl, null);
|
|
94
|
+
if (ngControl) {
|
|
95
|
+
this.parentControl = ngControl.control;
|
|
96
|
+
// se la variabile novalidate è true, elimino tutti i validatori eventualmente inseriti
|
|
97
|
+
if (this.noValidate) {
|
|
98
|
+
this.parentControl.clearValidators();
|
|
99
|
+
this.parentControl.clearAsyncValidators();
|
|
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
|
+
/**
|
|
111
|
+
* @ignore
|
|
112
|
+
*/
|
|
113
|
+
writeValue(value) {
|
|
114
|
+
this.value = value;
|
|
115
|
+
this.propagateChange(value);
|
|
116
|
+
this.cdr.markForCheck();
|
|
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) {
|
|
124
|
+
this.writeValue(toEmit);
|
|
125
|
+
this.inputChange.emit(toEmit);
|
|
126
|
+
this.onTouched();
|
|
127
|
+
}
|
|
128
|
+
/**
|
|
129
|
+
* @ignore
|
|
130
|
+
*/
|
|
131
|
+
registerOnChange(fn) {
|
|
132
|
+
this.propagateChange = fn;
|
|
133
|
+
}
|
|
134
|
+
/**
|
|
135
|
+
* @ignore
|
|
136
|
+
*/
|
|
137
|
+
registerOnTouched(fn) {
|
|
138
|
+
this.onTouched = fn;
|
|
139
|
+
}
|
|
140
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ValidationSelectComponent, deps: [{ token: NG_VALIDATORS, optional: true }, { token: NG_ASYNC_VALIDATORS, optional: true }, { token: i0.Injector }, { token: i0.ChangeDetectorRef }, { token: i1.LocalizationService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
141
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ValidationSelectComponent, selector: "val-select", inputs: { emptyFieldValue: "emptyFieldValue", placeHolderValue: "placeHolderValue", emptyValue: "emptyValue", showValidationSymbol: "showValidationSymbol", label: "label" }, outputs: { onBlur: "onBlur" }, providers: [
|
|
142
|
+
{ provide: LocalizationService, useClass: BaseValidationLoc },
|
|
143
|
+
{
|
|
144
|
+
provide: NG_VALUE_ACCESSOR,
|
|
145
|
+
useExisting: forwardRef(() => ValidationSelectComponent),
|
|
146
|
+
multi: true
|
|
147
|
+
}
|
|
148
|
+
], 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=\"label\">{{label}}</mat-label>\r\n <select matNativeControl\r\n #baseInput=\"ngModel\"\r\n #htmlInput\r\n name=\"val-select\"\r\n class=\"form-control\"\r\n triggers=\"\"\r\n placement=\"top\"\r\n id=\"{{id}}\"\r\n [customRequired]=\"required\"\r\n [CustomNullValues]=\"[placeHolderValue, emptyFieldValue]\"\r\n [(ngModel)]=\"value\"\r\n [tooltip]=\"tolTemplate\"\r\n [class.checking-combo]=\"!noValidate\"\r\n [class.app-option-placeholder]=\"baseInput.value === placeHolderValue\"\r\n [class.no-bg-img]=\"!showValidationSymbol\"\r\n [disabled]=\"Readonly\"\r\n (click)=\"onFocus($event)\"\r\n (focus)=\"checkTooltip();\"\r\n (blur)=\"closeTooltip(); onBlur.emit(true);\"\r\n (ngModelChange)=\"onModelChange($event); onFinalize()\">\r\n\r\n <option *ngIf=\"placeholder\" [value]=\"placeHolderValue\" disabled selected hidden>{{placeholder}}</option>\r\n <option *ngIf=\"required == false && emptyValue\" [value]=\"emptyFieldValue\"></option>\r\n <ng-content></ng-content>\r\n </select>\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.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i3.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i3.SelectControlValueAccessor, selector: "select:not([multiple])[formControlName],select:not([multiple])[formControl],select:not([multiple])[ngModel]", inputs: ["compareWith"] }, { 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.CustomRequiredDirective, selector: "[customRequired]", inputs: ["CustomNullValues", "customRequired"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
149
|
+
}
|
|
150
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ValidationSelectComponent, decorators: [{
|
|
151
|
+
type: Component,
|
|
152
|
+
args: [{ selector: "val-select", encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
153
|
+
{ provide: LocalizationService, useClass: BaseValidationLoc },
|
|
154
|
+
{
|
|
155
|
+
provide: NG_VALUE_ACCESSOR,
|
|
156
|
+
useExisting: forwardRef(() => ValidationSelectComponent),
|
|
157
|
+
multi: true
|
|
158
|
+
}
|
|
159
|
+
], 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=\"label\">{{label}}</mat-label>\r\n <select matNativeControl\r\n #baseInput=\"ngModel\"\r\n #htmlInput\r\n name=\"val-select\"\r\n class=\"form-control\"\r\n triggers=\"\"\r\n placement=\"top\"\r\n id=\"{{id}}\"\r\n [customRequired]=\"required\"\r\n [CustomNullValues]=\"[placeHolderValue, emptyFieldValue]\"\r\n [(ngModel)]=\"value\"\r\n [tooltip]=\"tolTemplate\"\r\n [class.checking-combo]=\"!noValidate\"\r\n [class.app-option-placeholder]=\"baseInput.value === placeHolderValue\"\r\n [class.no-bg-img]=\"!showValidationSymbol\"\r\n [disabled]=\"Readonly\"\r\n (click)=\"onFocus($event)\"\r\n (focus)=\"checkTooltip();\"\r\n (blur)=\"closeTooltip(); onBlur.emit(true);\"\r\n (ngModelChange)=\"onModelChange($event); onFinalize()\">\r\n\r\n <option *ngIf=\"placeholder\" [value]=\"placeHolderValue\" disabled selected hidden>{{placeholder}}</option>\r\n <option *ngIf=\"required == false && emptyValue\" [value]=\"emptyFieldValue\"></option>\r\n <ng-content></ng-content>\r\n </select>\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"] }]
|
|
160
|
+
}], ctorParameters: function () { return [{ type: Array, decorators: [{
|
|
161
|
+
type: Optional
|
|
162
|
+
}, {
|
|
163
|
+
type: Inject,
|
|
164
|
+
args: [NG_VALIDATORS]
|
|
165
|
+
}] }, { type: Array, decorators: [{
|
|
166
|
+
type: Optional
|
|
167
|
+
}, {
|
|
168
|
+
type: Inject,
|
|
169
|
+
args: [NG_ASYNC_VALIDATORS]
|
|
170
|
+
}] }, { type: i0.Injector }, { type: i0.ChangeDetectorRef }, { type: i1.LocalizationService }]; }, propDecorators: { emptyFieldValue: [{
|
|
171
|
+
type: Input
|
|
172
|
+
}], placeHolderValue: [{
|
|
173
|
+
type: Input
|
|
174
|
+
}], emptyValue: [{
|
|
175
|
+
type: Input
|
|
176
|
+
}], showValidationSymbol: [{
|
|
177
|
+
type: Input
|
|
178
|
+
}], label: [{
|
|
179
|
+
type: Input
|
|
180
|
+
}], onBlur: [{
|
|
181
|
+
type: Output
|
|
182
|
+
}] } });
|
|
183
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validation-select.component.js","sourceRoot":"","sources":["../../../../../../projects/forms-and-validations/src/lib/validations/validation-select/validation-select.component.ts","../../../../../../projects/forms-and-validations/src/lib/validations/validation-select/validation-select.component.html"],"names":[],"mappings":"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","sourcesContent":["// Angular\r\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, forwardRef, Inject, Injector, Input, Optional, Output, ViewChild, ViewEncapsulation } from \"@angular/core\";\r\nimport { ControlValueAccessor, UntypedFormControl, NG_ASYNC_VALIDATORS, NG_VALIDATORS, NG_VALUE_ACCESSOR, NgControl, RequiredValidator } from \"@angular/forms\";\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\n\r\nimport { Subscription } from \"rxjs\";\r\n\r\n/**\r\n * Componente di validaizone per gli input a selezione singola\r\n */\r\n@Component({\r\n    selector: \"val-select\",\r\n    templateUrl: \"validation-select.component.html\",\r\n    encapsulation: ViewEncapsulation.None,\r\n    styleUrls: [\"../validation-style.scss\"],\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(() => ValidationSelectComponent),\r\n            multi: true\r\n        }\r\n    ]\r\n})\r\nexport class ValidationSelectComponent extends BaseValidation implements ControlValueAccessor {\r\n    \r\n    /**\r\n     * valore del campo vuoto della select\r\n     */\r\n    @Input() public emptyFieldValue = \"-2000\";\r\n    \r\n    /**\r\n     * Valore del placeholder\r\n     */\r\n    @Input() public placeHolderValue = \"-1000\";\r\n    \r\n    /**\r\n     * Per i componenti non obbligatori indica se fornire un \"valore vuoto\"\r\n     */\r\n    @Input() public emptyValue = true;\r\n\r\n    /**\r\n     * Indica se mostrare o nascondere il simboletto di validazione (Tic verde o Croce rossa)\r\n     */\r\n    @Input() public showValidationSymbol: boolean = true;\r\n\r\n    /**\r\n     * Contenuto della label Floattante Material-Style\r\n     */\r\n    @Input() public label: string = \"\";\r\n\r\n    /**\r\n     * Evento richiamato quando si perde il focus sull'input di inserimento\r\n     */\r\n    @Output() public onBlur: EventEmitter<boolean> = new EventEmitter<boolean>();\r\n\r\n    /**\r\n     * Controllo esposto ottenuto tramite injector\r\n     */\r\n    public parentControl: UntypedFormControl;\r\n\r\n    /**\r\n     * Valore del modello rappresentato dal componente\r\n     */\r\n    public value: string;\r\n\r\n    /**\r\n     * Subscription del tootltip da ripulire alla distruzione del componente\r\n     */\r\n    private tooltipSubscription: Subscription;\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    constructor(@Optional() @Inject(NG_VALIDATORS) private _validators: Array<any>, @Optional() @Inject(NG_ASYNC_VALIDATORS) private _asyncValidators: Array<any>, private injector: Injector, cdr: ChangeDetectorRef, protected lc: LocalizationService) {\r\n        super(cdr);\r\n    }\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    ngOnInit() {\r\n        super.ngOnInit();\r\n\r\n        this.registerFocusRequest();\r\n\r\n        this.checkRequiredness(this._validators);\r\n    }\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    ngOnDestroy() {\r\n        super.ngOnDestroy();\r\n\r\n        this.deregisterFocusRequest();\r\n        if (this.tooltipSubscription) this.tooltipSubscription.unsubscribe();\r\n    }\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    ngAfterViewInit() {\r\n        this.postBinding();\r\n    }\r\n\r\n    /**\r\n     * Metodo che si occupa di collegare i validatori e la funzione di reset dal **ControlValueAccessor** rappresentato \r\n     * da questo componente al **ControlValueAccessor** rappresentato dall'effettivo elemento di Input presente lato HTML\r\n     */\r\n    postBinding() {\r\n        // Eredito i validatori\r\n        if (!this.noValidate) {\r\n            this.baseInput.control.setAsyncValidators(this._asyncValidators);\r\n            this.baseInput.control.setValidators(this._validators);\r\n        }\r\n\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\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 = () => {\r\n                origFunc.apply(this.parentControl);\r\n                this.baseInput.control.reset();\r\n                this.tooltip.hide();\r\n            };\r\n        }\r\n    }\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    private onTouched = () => { }; //placeholder on touched function\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    writeValue(value: any): void {\r\n        this.value = value;\r\n        this.propagateChange(value);\r\n        this.cdr.markForCheck();\r\n    }\r\n\r\n    /**\r\n     * L'emit della modifica al valore viene gestito su un evento custom (**inputChange**) come workaround al malfunzionamento dell'**ngModelChange** nativo\r\n     * \r\n     * @param {any} toEmit valore da propagare all'esterno\r\n     */\r\n    onModelChange(toEmit) {\r\n        this.writeValue(toEmit);\r\n        this.inputChange.emit(toEmit);\r\n        this.onTouched();\r\n    }\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    registerOnChange(fn: any): void {\r\n        this.propagateChange = fn;\r\n    }\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    registerOnTouched(fn: any): void {\r\n        this.onTouched = fn;\r\n    }\r\n}","<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    <select matNativeControl\r\n            #baseInput=\"ngModel\"\r\n            #htmlInput\r\n            name=\"val-select\"\r\n            class=\"form-control\"\r\n            triggers=\"\"\r\n            placement=\"top\"\r\n            id=\"{{id}}\"\r\n            [customRequired]=\"required\"\r\n            [CustomNullValues]=\"[placeHolderValue, emptyFieldValue]\"\r\n            [(ngModel)]=\"value\"\r\n            [tooltip]=\"tolTemplate\"\r\n            [class.checking-combo]=\"!noValidate\"\r\n            [class.app-option-placeholder]=\"baseInput.value === placeHolderValue\"\r\n            [class.no-bg-img]=\"!showValidationSymbol\"\r\n            [disabled]=\"Readonly\"\r\n            (click)=\"onFocus($event)\"\r\n            (focus)=\"checkTooltip();\"\r\n            (blur)=\"closeTooltip(); onBlur.emit(true);\"\r\n            (ngModelChange)=\"onModelChange($event); onFinalize()\">\r\n\r\n        <option *ngIf=\"placeholder\" [value]=\"placeHolderValue\" disabled selected hidden>{{placeholder}}</option>\r\n        <option *ngIf=\"required == false && emptyValue\" [value]=\"emptyFieldValue\"></option>\r\n        <ng-content></ng-content>\r\n    </select>\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,78 @@
|
|
|
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
|
+
/**
|
|
17
|
+
* Componente di validaizone per gli input ad area di testo
|
|
18
|
+
*/
|
|
19
|
+
export class ValidationTextAreaComponent extends ValidationInputComponent {
|
|
20
|
+
/**
|
|
21
|
+
* @ignore
|
|
22
|
+
*/
|
|
23
|
+
constructor(cdr, validators, asyncValidators, injector, lc) {
|
|
24
|
+
super(cdr, validators, asyncValidators, injector, lc);
|
|
25
|
+
this.lc = lc;
|
|
26
|
+
/**
|
|
27
|
+
* Righe da mostrare di default per l'area di inserimento
|
|
28
|
+
*/
|
|
29
|
+
this.rows = 2;
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* @ignore
|
|
33
|
+
*/
|
|
34
|
+
ngOnInit() {
|
|
35
|
+
super.ngOnInit();
|
|
36
|
+
this.registerFocusRequest();
|
|
37
|
+
}
|
|
38
|
+
/**
|
|
39
|
+
* @ignore
|
|
40
|
+
*/
|
|
41
|
+
ngOnDestroy() {
|
|
42
|
+
super.ngOnDestroy();
|
|
43
|
+
this.deregisterFocusRequest();
|
|
44
|
+
}
|
|
45
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ValidationTextAreaComponent, 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 }); }
|
|
46
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: ValidationTextAreaComponent, selector: "val-textarea", inputs: { rows: "rows" }, providers: [
|
|
47
|
+
{ provide: LocalizationService, useClass: BaseValidationLoc },
|
|
48
|
+
{
|
|
49
|
+
provide: NG_VALUE_ACCESSOR,
|
|
50
|
+
useExisting: forwardRef(() => ValidationTextAreaComponent),
|
|
51
|
+
multi: true
|
|
52
|
+
}
|
|
53
|
+
], usesInheritance: true, ngImport: i0, template: "<mat-form-field appearance=\"{{FieldAppearence}}\" class=\"mat-full-width mat-full-height mat-no-border-top mat-height-auto\">\r\n <mat-label *ngIf=\"placeholder && FloatingLabel\">{{placeholder}}</mat-label>\r\n <textarea matInput\r\n #baseInput=\"ngModel\"\r\n #htmlInput\r\n [(ngModel)]=\"value\"\r\n name=\"val-textarea\"\r\n triggers=\"\"\r\n class=\"app-no-resize form-control {{class}}\"\r\n id=\"{{id}}\"\r\n [class.checking-field]=\"!noValidate\"\r\n rows=\"{{rows}}\"\r\n [tooltip]=\"tolTemplate\"\r\n [placeholder]=\"FloatingLabel ? undefined : placeholder\"\r\n placement=\"top\"\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 (ngModelChange)=\"onModelChange($event)\">\r\n </textarea>\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.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"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
|
54
|
+
}
|
|
55
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: ValidationTextAreaComponent, decorators: [{
|
|
56
|
+
type: Component,
|
|
57
|
+
args: [{ selector: "val-textarea", providers: [
|
|
58
|
+
{ provide: LocalizationService, useClass: BaseValidationLoc },
|
|
59
|
+
{
|
|
60
|
+
provide: NG_VALUE_ACCESSOR,
|
|
61
|
+
useExisting: forwardRef(() => ValidationTextAreaComponent),
|
|
62
|
+
multi: true
|
|
63
|
+
}
|
|
64
|
+
], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<mat-form-field appearance=\"{{FieldAppearence}}\" class=\"mat-full-width mat-full-height mat-no-border-top mat-height-auto\">\r\n <mat-label *ngIf=\"placeholder && FloatingLabel\">{{placeholder}}</mat-label>\r\n <textarea matInput\r\n #baseInput=\"ngModel\"\r\n #htmlInput\r\n [(ngModel)]=\"value\"\r\n name=\"val-textarea\"\r\n triggers=\"\"\r\n class=\"app-no-resize form-control {{class}}\"\r\n id=\"{{id}}\"\r\n [class.checking-field]=\"!noValidate\"\r\n rows=\"{{rows}}\"\r\n [tooltip]=\"tolTemplate\"\r\n [placeholder]=\"FloatingLabel ? undefined : placeholder\"\r\n placement=\"top\"\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 (ngModelChange)=\"onModelChange($event)\">\r\n </textarea>\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"] }]
|
|
65
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: Array, decorators: [{
|
|
66
|
+
type: Optional
|
|
67
|
+
}, {
|
|
68
|
+
type: Inject,
|
|
69
|
+
args: [NG_VALIDATORS]
|
|
70
|
+
}] }, { type: Array, decorators: [{
|
|
71
|
+
type: Optional
|
|
72
|
+
}, {
|
|
73
|
+
type: Inject,
|
|
74
|
+
args: [NG_ASYNC_VALIDATORS]
|
|
75
|
+
}] }, { type: i0.Injector }, { type: i1.LocalizationService }]; }, propDecorators: { rows: [{
|
|
76
|
+
type: Input
|
|
77
|
+
}] } });
|
|
78
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWRhdGlvbi10ZXh0LWFyZWEuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZm9ybXMtYW5kLXZhbGlkYXRpb25zL3NyYy9saWIvdmFsaWRhdGlvbnMvdmFsaWRhdGlvbi10ZXh0LWFyZWEvdmFsaWRhdGlvbi10ZXh0LWFyZWEuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvZm9ybXMtYW5kLXZhbGlkYXRpb25zL3NyYy9saWIvdmFsaWRhdGlvbnMvdmFsaWRhdGlvbi10ZXh0LWFyZWEvdmFsaWRhdGlvbi10ZXh0LWFyZWEuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsVUFBVTtBQUNWLE9BQU8sRUFBRSx1QkFBdUIsRUFBcUIsU0FBUyxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQVksS0FBSyxFQUFFLFFBQVEsRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN4SixPQUFPLEVBQUUsbUJBQW1CLEVBQUUsYUFBYSxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFFdkYsaUJBQWlCO0FBQ2pCLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBRTlELGtDQUFrQztBQUNsQyxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUMzRCxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSxnREFBZ0QsQ0FBQzs7Ozs7Ozs7QUFFMUY7O0dBRUc7QUFnQkgsTUFBTSxPQUFPLDJCQUE0QixTQUFRLHdCQUF3QjtJQU9yRTs7T0FFRztJQUNILFlBQVksR0FBc0IsRUFBcUMsVUFBc0IsRUFBMkMsZUFBMkIsRUFBRSxRQUFrQixFQUFZLEVBQXVCO1FBQ3ROLEtBQUssQ0FBQyxHQUFHLEVBQUUsVUFBVSxFQUFFLGVBQWUsRUFBRSxRQUFRLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFEeUksT0FBRSxHQUFGLEVBQUUsQ0FBcUI7UUFSMU47O1dBRUc7UUFDTSxTQUFJLEdBQVcsQ0FBQyxDQUFDO0lBTzFCLENBQUM7SUFFRDs7T0FFRztJQUNILFFBQVE7UUFDSixLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7UUFFakIsSUFBSSxDQUFDLG9CQUFvQixFQUFFLENBQUM7SUFDaEMsQ0FBQztJQUVEOztPQUVHO0lBQ0gsV0FBVztRQUNQLEtBQUssQ0FBQyxXQUFXLEVBQUUsQ0FBQztRQUVwQixJQUFJLENBQUMsc0JBQXNCLEVBQUUsQ0FBQztJQUNsQyxDQUFDOytHQTlCUSwyQkFBMkIsbURBVW9CLGFBQWEsNkJBQThDLG1CQUFtQjttR0FWN0gsMkJBQTJCLGlFQVp6QjtZQUNQLEVBQUUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLFFBQVEsRUFBRSxpQkFBaUIsRUFBRTtZQUM3RDtnQkFDSSxPQUFPLEVBQUUsaUJBQWlCO2dCQUMxQixXQUFXLEVBQUUsVUFBVSxDQUFDLEdBQUcsRUFBRSxDQUFDLDJCQUEyQixDQUFDO2dCQUMxRCxLQUFLLEVBQUUsSUFBSTthQUNkO1NBQ0osaURDeEJMLG11Q0EyQmM7OzRGREVELDJCQUEyQjtrQkFmdkMsU0FBUzsrQkFDSSxjQUFjLGFBRWI7d0JBQ1AsRUFBRSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsUUFBUSxFQUFFLGlCQUFpQixFQUFFO3dCQUM3RDs0QkFDSSxPQUFPLEVBQUUsaUJBQWlCOzRCQUMxQixXQUFXLEVBQUUsVUFBVSxDQUFDLEdBQUcsRUFBRSw0QkFBNEIsQ0FBQzs0QkFDMUQsS0FBSyxFQUFFLElBQUk7eUJBQ2Q7cUJBQ0osaUJBQ2MsaUJBQWlCLENBQUMsSUFBSSxtQkFFcEIsdUJBQXVCLENBQUMsTUFBTTs7MEJBWVYsUUFBUTs7MEJBQUksTUFBTTsyQkFBQyxhQUFhOzswQkFBMkIsUUFBUTs7MEJBQUksTUFBTTsyQkFBQyxtQkFBbUI7cUdBTDdILElBQUk7c0JBQVosS0FBSyIsInNvdXJjZXNDb250ZW50IjpbIi8vIEFuZ3VsYXJcclxuaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENoYW5nZURldGVjdG9yUmVmLCBDb21wb25lbnQsIGZvcndhcmRSZWYsIEluamVjdCwgSW5qZWN0b3IsIElucHV0LCBPcHRpb25hbCwgVmlld0VuY2Fwc3VsYXRpb24gfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgeyBOR19BU1lOQ19WQUxJREFUT1JTLCBOR19WQUxJREFUT1JTLCBOR19WQUxVRV9BQ0NFU1NPUiB9IGZyb20gXCJAYW5ndWxhci9mb3Jtc1wiO1xyXG5cclxuLy8gQ29uZmlndXJhemlvbmlcclxuaW1wb3J0IHsgTG9jYWxpemF0aW9uU2VydmljZSB9IGZyb20gXCJAZXNmYWVuemEvbG9jYWxpemF0aW9uc1wiO1xyXG5cclxuLy8gRGlyZXR0aXZlLCBDb21wb25lbnRpLCBMaWJyZXJpZVxyXG5pbXBvcnQgeyBCYXNlVmFsaWRhdGlvbkxvYyB9IGZyb20gXCIuLi9iYXNlLXZhbGlkYXRpb24ubG9jXCI7XHJcbmltcG9ydCB7IFZhbGlkYXRpb25JbnB1dENvbXBvbmVudCB9IGZyb20gXCIuLi92YWxpZGF0aW9uLWlucHV0L3ZhbGlkYXRpb24taW5wdXQuY29tcG9uZW50XCI7XHJcblxyXG4vKipcclxuICogQ29tcG9uZW50ZSBkaSB2YWxpZGFpem9uZSBwZXIgZ2xpIGlucHV0IGFkIGFyZWEgZGkgdGVzdG9cclxuICovXHJcbkBDb21wb25lbnQoe1xyXG4gICAgc2VsZWN0b3I6IFwidmFsLXRleHRhcmVhXCIsXHJcbiAgICB0ZW1wbGF0ZVVybDogXCJ2YWxpZGF0aW9uLXRleHQtYXJlYS5jb21wb25lbnQuaHRtbFwiLFxyXG4gICAgcHJvdmlkZXJzOiBbXHJcbiAgICAgICAgeyBwcm92aWRlOiBMb2NhbGl6YXRpb25TZXJ2aWNlLCB1c2VDbGFzczogQmFzZVZhbGlkYXRpb25Mb2MgfSxcclxuICAgICAgICB7XHJcbiAgICAgICAgICAgIHByb3ZpZGU6IE5HX1ZBTFVFX0FDQ0VTU09SLFxyXG4gICAgICAgICAgICB1c2VFeGlzdGluZzogZm9yd2FyZFJlZigoKSA9PiBWYWxpZGF0aW9uVGV4dEFyZWFDb21wb25lbnQpLFxyXG4gICAgICAgICAgICBtdWx0aTogdHJ1ZVxyXG4gICAgICAgIH1cclxuICAgIF0sXHJcbiAgICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxyXG4gICAgc3R5bGVVcmxzOiBbXCIuLi92YWxpZGF0aW9uLXN0eWxlLnNjc3NcIl0sXHJcbiAgICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxyXG59KVxyXG5leHBvcnQgY2xhc3MgVmFsaWRhdGlvblRleHRBcmVhQ29tcG9uZW50IGV4dGVuZHMgVmFsaWRhdGlvbklucHV0Q29tcG9uZW50IHtcclxuXHJcbiAgICAvKipcclxuICAgICAqIFJpZ2hlIGRhIG1vc3RyYXJlIGRpIGRlZmF1bHQgcGVyIGwnYXJlYSBkaSBpbnNlcmltZW50b1xyXG4gICAgICovXHJcbiAgICBASW5wdXQoKSByb3dzOiBudW1iZXIgPSAyO1xyXG5cclxuICAgIC8qKlxyXG4gICAgICogQGlnbm9yZVxyXG4gICAgICovXHJcbiAgICBjb25zdHJ1Y3RvcihjZHI6IENoYW5nZURldGVjdG9yUmVmLCBAT3B0aW9uYWwoKSBASW5qZWN0KE5HX1ZBTElEQVRPUlMpIHZhbGlkYXRvcnM6IEFycmF5PGFueT4sIEBPcHRpb25hbCgpIEBJbmplY3QoTkdfQVNZTkNfVkFMSURBVE9SUykgYXN5bmNWYWxpZGF0b3JzOiBBcnJheTxhbnk+LCBpbmplY3RvcjogSW5qZWN0b3IsIHByb3RlY3RlZCBsYzogTG9jYWxpemF0aW9uU2VydmljZSkge1xyXG4gICAgICAgIHN1cGVyKGNkciwgdmFsaWRhdG9ycywgYXN5bmNWYWxpZGF0b3JzLCBpbmplY3RvciwgbGMpO1xyXG4gICAgfVxyXG5cclxuICAgIC8qKlxyXG4gICAgICogQGlnbm9yZVxyXG4gICAgICovXHJcbiAgICBuZ09uSW5pdCgpOiB2b2lkIHtcclxuICAgICAgICBzdXBlci5uZ09uSW5pdCgpO1xyXG5cclxuICAgICAgICB0aGlzLnJlZ2lzdGVyRm9jdXNSZXF1ZXN0KCk7XHJcbiAgICB9XHJcblxyXG4gICAgLyoqXHJcbiAgICAgKiBAaWdub3JlXHJcbiAgICAgKi9cclxuICAgIG5nT25EZXN0cm95KCk6IHZvaWQge1xyXG4gICAgICAgIHN1cGVyLm5nT25EZXN0cm95KCk7XHJcbiAgICAgICAgXHJcbiAgICAgICAgdGhpcy5kZXJlZ2lzdGVyRm9jdXNSZXF1ZXN0KCk7XHJcbiAgICB9XHJcbn0iLCI8bWF0LWZvcm0tZmllbGQgYXBwZWFyYW5jZT1cInt7RmllbGRBcHBlYXJlbmNlfX1cIiBjbGFzcz1cIm1hdC1mdWxsLXdpZHRoIG1hdC1mdWxsLWhlaWdodCBtYXQtbm8tYm9yZGVyLXRvcCBtYXQtaGVpZ2h0LWF1dG9cIj5cclxuICAgIDxtYXQtbGFiZWwgKm5nSWY9XCJwbGFjZWhvbGRlciAmJiBGbG9hdGluZ0xhYmVsXCI+e3twbGFjZWhvbGRlcn19PC9tYXQtbGFiZWw+XHJcbiAgICA8dGV4dGFyZWEgbWF0SW5wdXRcclxuICAgICAgICAgICAgICAjYmFzZUlucHV0PVwibmdNb2RlbFwiXHJcbiAgICAgICAgICAgICAgI2h0bWxJbnB1dFxyXG4gICAgICAgICAgICAgIFsobmdNb2RlbCldPVwidmFsdWVcIlxyXG4gICAgICAgICAgICAgIG5hbWU9XCJ2YWwtdGV4dGFyZWFcIlxyXG4gICAgICAgICAgICAgIHRyaWdnZXJzPVwiXCJcclxuICAgICAgICAgICAgICBjbGFzcz1cImFwcC1uby1yZXNpemUgZm9ybS1jb250cm9sIHt7Y2xhc3N9fVwiXHJcbiAgICAgICAgICAgICAgaWQ9XCJ7e2lkfX1cIlxyXG4gICAgICAgICAgICAgIFtjbGFzcy5jaGVja2luZy1maWVsZF09XCIhbm9WYWxpZGF0ZVwiXHJcbiAgICAgICAgICAgICAgcm93cz1cInt7cm93c319XCJcclxuICAgICAgICAgICAgICBbdG9vbHRpcF09XCJ0b2xUZW1wbGF0ZVwiXHJcbiAgICAgICAgICAgICAgW3BsYWNlaG9sZGVyXT1cIkZsb2F0aW5nTGFiZWwgPyB1bmRlZmluZWQgOiBwbGFjZWhvbGRlclwiXHJcbiAgICAgICAgICAgICAgcGxhY2VtZW50PVwidG9wXCJcclxuICAgICAgICAgICAgICAoY2xpY2spPVwib25Gb2N1cygkZXZlbnQpXCJcclxuICAgICAgICAgICAgICAoZm9jdXMpPVwiY2hlY2tUb29sdGlwKCk7XCJcclxuICAgICAgICAgICAgICAoa2V5dXApPVwiKCRldmVudC5rZXlDb2RlID09IDEzIHx8ICRldmVudC5rZXlDb2RlID09IDI3KSAmJiBvbkZpbmFsaXplKCk7XCJcclxuICAgICAgICAgICAgICAoYmx1cik9XCJjbG9zZVRvb2x0aXAoKTsgb25GaW5hbGl6ZSgpO1wiXHJcbiAgICAgICAgICAgICAgKG5nTW9kZWxDaGFuZ2UpPVwib25Nb2RlbENoYW5nZSgkZXZlbnQpXCI+XHJcbiAgICA8L3RleHRhcmVhPlxyXG48L21hdC1mb3JtLWZpZWxkPlxyXG5cclxuPG5nLXRlbXBsYXRlICN0b2xUZW1wbGF0ZT5cclxuICAgIDxkaXYgKGNsaWNrKT1cImNsb3NlVG9vbHRpcCgpXCI+XHJcbiAgICAgICAgPHNwYW4+e3t2YWxpZGF0aW9uRmFpbGVkQmluZH19PC9zcGFuPlxyXG4gICAgPC9kaXY+XHJcbjwvbmctdGVtcGxhdGU+Il19
|