@esfaenza/forms-and-validations 12.2.27 → 13.1.2
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/esfaenza-forms-and-validations.d.ts +1 -12
- package/esm2020/esfaenza-forms-and-validations.mjs +5 -0
- package/esm2020/lib/forms/base-form-control.mjs +482 -0
- package/esm2020/lib/forms/form-adaptive/form-adaptive.component.loc.mjs +28 -0
- package/esm2020/lib/forms/form-adaptive/form-adaptive.component.mjs +294 -0
- package/esm2020/lib/forms/form-autocomplete/form-autocomplete.component.loc.mjs +26 -0
- package/esm2020/lib/forms/form-autocomplete/form-autocomplete.component.mjs +200 -0
- package/esm2020/lib/forms/form-checkbox/form-checkbox.component.mjs +52 -0
- package/esm2020/lib/forms/form-date/form-date.component.mjs +59 -0
- package/esm2020/lib/forms/form-datetime/form-datetime.component.mjs +59 -0
- package/esm2020/lib/forms/form-empty/form-empty.component.mjs +36 -0
- package/esm2020/lib/forms/form-error/form-error.component.mjs +52 -0
- package/esm2020/lib/forms/form-file/form-file.component.loc.mjs +28 -0
- package/esm2020/lib/forms/form-file/form-file.component.mjs +119 -0
- package/esm2020/lib/forms/form-info/form-info.component.mjs +52 -0
- package/esm2020/lib/forms/form-input/form-input.component.mjs +93 -0
- package/esm2020/lib/forms/form-multiselect/form-multiselect.component.loc.mjs +29 -0
- package/esm2020/lib/forms/form-multiselect/form-multiselect.component.mjs +159 -0
- package/esm2020/lib/forms/form-select/form-select.component.loc.mjs +26 -0
- package/esm2020/lib/forms/form-select/form-select.component.mjs +129 -0
- package/esm2020/lib/forms/form-template/form-template.component.mjs +71 -0
- package/esm2020/lib/forms/form-textarea/form-textarea.component.mjs +54 -0
- package/esm2020/lib/forms/form-time/form-time.component.mjs +131 -0
- package/esm2020/lib/forms-and-validations.module.mjs +203 -0
- package/{esm2015/lib/models/AppFile.js → esm2020/lib/models/AppFile.mjs} +0 -0
- package/{esm2015/lib/models/FormsAndValidationsModuleConfig.js → esm2020/lib/models/FormsAndValidationsModuleConfig.mjs} +0 -0
- package/esm2020/lib/models/dayjs-adapter/dayjs-date-adapter.mjs +89 -0
- package/{esm2015/lib/tokens.js → esm2020/lib/tokens.mjs} +0 -0
- package/esm2020/lib/validations/base-validation.loc.mjs +28 -0
- package/esm2020/lib/validations/base-validation.mjs +232 -0
- package/esm2020/lib/validations/customValidators/CustomRequiredDirective.mjs +41 -0
- package/esm2020/lib/validations/validation-autocomplete/validation-autocomplete.component.mjs +168 -0
- package/esm2020/lib/validations/validation-currency/validation-currency.component.mjs +61 -0
- package/esm2020/lib/validations/validation-date/validation-date.component.mjs +177 -0
- package/esm2020/lib/validations/validation-datetime/validation-datetime.component.mjs +206 -0
- package/esm2020/lib/validations/validation-input/validation-input.component.mjs +207 -0
- package/esm2020/lib/validations/validation-select/validation-select.component.mjs +184 -0
- package/esm2020/lib/validations/validation-text-area/validation-text-area.component.mjs +64 -0
- package/esm2020/public-api.mjs +35 -0
- package/fesm2015/esfaenza-forms-and-validations.mjs +3620 -0
- package/fesm2015/esfaenza-forms-and-validations.mjs.map +1 -0
- package/fesm2020/esfaenza-forms-and-validations.mjs +3562 -0
- package/fesm2020/esfaenza-forms-and-validations.mjs.map +1 -0
- package/lib/forms/base-form-control.d.ts +27 -0
- package/lib/forms/form-adaptive/form-adaptive.component.d.ts +25 -0
- package/lib/forms/form-adaptive/form-adaptive.component.loc.d.ts +3 -0
- package/lib/forms/form-autocomplete/form-autocomplete.component.d.ts +19 -1
- package/lib/forms/form-autocomplete/form-autocomplete.component.loc.d.ts +3 -0
- package/lib/forms/form-checkbox/form-checkbox.component.d.ts +3 -0
- package/lib/forms/form-date/form-date.component.d.ts +3 -0
- package/lib/forms/form-datetime/form-datetime.component.d.ts +3 -0
- package/lib/forms/form-empty/form-empty.component.d.ts +3 -0
- package/lib/forms/form-error/form-error.component.d.ts +3 -0
- package/lib/forms/form-file/form-file.component.d.ts +3 -0
- package/lib/forms/form-file/form-file.component.loc.d.ts +3 -0
- package/lib/forms/form-info/form-info.component.d.ts +3 -0
- package/lib/forms/form-input/form-input.component.d.ts +3 -0
- package/lib/forms/form-multiselect/form-multiselect.component.d.ts +4 -0
- package/lib/forms/form-multiselect/form-multiselect.component.loc.d.ts +3 -0
- package/lib/forms/form-select/form-select.component.d.ts +3 -0
- package/lib/forms/form-select/form-select.component.loc.d.ts +3 -0
- package/lib/forms/form-template/form-template.component.d.ts +3 -0
- package/lib/forms/form-textarea/form-textarea.component.d.ts +3 -0
- package/lib/forms/form-time/form-time.component.d.ts +3 -0
- package/lib/forms-and-validations.module.d.ts +38 -0
- package/lib/models/dayjs-adapter/dayjs-date-adapter.d.ts +3 -0
- package/lib/validations/base-validation.d.ts +3 -0
- package/lib/validations/base-validation.loc.d.ts +3 -0
- package/lib/validations/customValidators/CustomRequiredDirective.d.ts +3 -0
- package/lib/validations/validation-autocomplete/validation-autocomplete.component.d.ts +3 -4
- package/lib/validations/validation-currency/validation-currency.component.d.ts +3 -0
- package/lib/validations/validation-date/validation-date.component.d.ts +3 -0
- package/lib/validations/validation-datetime/validation-datetime.component.d.ts +3 -0
- package/lib/validations/validation-input/validation-input.component.d.ts +3 -0
- package/lib/validations/validation-select/validation-select.component.d.ts +3 -0
- package/lib/validations/validation-text-area/validation-text-area.component.d.ts +3 -0
- package/package.json +31 -19
- package/public-api.d.ts +2 -0
- package/bundles/esfaenza-forms-and-validations.umd.js +0 -3628
- package/bundles/esfaenza-forms-and-validations.umd.js.map +0 -1
- package/esfaenza-forms-and-validations.metadata.json +0 -1
- package/esm2015/esfaenza-forms-and-validations.js +0 -17
- package/esm2015/lib/forms/base-form-control.js +0 -424
- package/esm2015/lib/forms/form-adaptive/form-adaptive.component.js +0 -219
- package/esm2015/lib/forms/form-adaptive/form-adaptive.component.loc.js +0 -23
- package/esm2015/lib/forms/form-autocomplete/form-autocomplete.component.js +0 -145
- package/esm2015/lib/forms/form-autocomplete/form-autocomplete.component.loc.js +0 -21
- package/esm2015/lib/forms/form-checkbox/form-checkbox.component.js +0 -41
- package/esm2015/lib/forms/form-date/form-date.component.js +0 -49
- package/esm2015/lib/forms/form-datetime/form-datetime.component.js +0 -49
- package/esm2015/lib/forms/form-empty/form-empty.component.js +0 -34
- package/esm2015/lib/forms/form-error/form-error.component.js +0 -49
- package/esm2015/lib/forms/form-file/form-file.component.js +0 -109
- package/esm2015/lib/forms/form-file/form-file.component.loc.js +0 -23
- package/esm2015/lib/forms/form-info/form-info.component.js +0 -49
- package/esm2015/lib/forms/form-input/form-input.component.js +0 -76
- package/esm2015/lib/forms/form-multiselect/form-multiselect.component.js +0 -153
- package/esm2015/lib/forms/form-multiselect/form-multiselect.component.loc.js +0 -24
- package/esm2015/lib/forms/form-select/form-select.component.js +0 -114
- package/esm2015/lib/forms/form-select/form-select.component.loc.js +0 -21
- package/esm2015/lib/forms/form-template/form-template.component.js +0 -64
- package/esm2015/lib/forms/form-textarea/form-textarea.component.js +0 -44
- package/esm2015/lib/forms/form-time/form-time.component.js +0 -117
- package/esm2015/lib/forms-and-validations.module.js +0 -144
- package/esm2015/lib/models/dayjs-adapter/dayjs-date-adapter.js +0 -86
- package/esm2015/lib/validations/base-validation.js +0 -208
- package/esm2015/lib/validations/base-validation.loc.js +0 -23
- package/esm2015/lib/validations/customValidators/CustomRequiredDirective.js +0 -35
- package/esm2015/lib/validations/validation-autocomplete/validation-autocomplete.component.js +0 -163
- package/esm2015/lib/validations/validation-currency/validation-currency.component.js +0 -48
- package/esm2015/lib/validations/validation-date/validation-date.component.js +0 -165
- package/esm2015/lib/validations/validation-datetime/validation-datetime.component.js +0 -193
- package/esm2015/lib/validations/validation-input/validation-input.component.js +0 -186
- package/esm2015/lib/validations/validation-select/validation-select.component.js +0 -166
- package/esm2015/lib/validations/validation-text-area/validation-text-area.component.js +0 -52
- package/esm2015/public-api.js +0 -32
- package/fesm2015/esfaenza-forms-and-validations.js +0 -3137
- package/fesm2015/esfaenza-forms-and-validations.js.map +0 -1
|
@@ -0,0 +1,206 @@
|
|
|
1
|
+
// Angular
|
|
2
|
+
import { NG_ASYNC_VALIDATORS, NG_VALIDATORS, NG_VALUE_ACCESSOR, NgControl, RequiredValidator } from "@angular/forms";
|
|
3
|
+
import { ChangeDetectionStrategy, Component, 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 "@esfaenza/extensions";
|
|
12
|
+
import * as i3 from "@angular/material/form-field";
|
|
13
|
+
import * as i4 from "@angular/material/datepicker";
|
|
14
|
+
import * as i5 from "@angular-material-components/datetime-picker";
|
|
15
|
+
import * as i6 from "@angular/common";
|
|
16
|
+
import * as i7 from "@angular/material/input";
|
|
17
|
+
import * as i8 from "@angular/forms";
|
|
18
|
+
import * as i9 from "ngx-bootstrap/tooltip";
|
|
19
|
+
/**
|
|
20
|
+
* Componente di validaizone per gli input di tipo data-ora
|
|
21
|
+
*/
|
|
22
|
+
export class ValidationDateTimeComponent extends BaseValidation {
|
|
23
|
+
/**
|
|
24
|
+
* @ignore
|
|
25
|
+
*/
|
|
26
|
+
constructor(cdr, _validators, _asyncValidators, injector, lc, dateExts) {
|
|
27
|
+
super();
|
|
28
|
+
this.cdr = cdr;
|
|
29
|
+
this._validators = _validators;
|
|
30
|
+
this._asyncValidators = _asyncValidators;
|
|
31
|
+
this.injector = injector;
|
|
32
|
+
this.lc = lc;
|
|
33
|
+
this.dateExts = dateExts;
|
|
34
|
+
/**
|
|
35
|
+
* Proprietà dell'elemento di selezione dell'orario. Mostra o nasconde gli spinner
|
|
36
|
+
*
|
|
37
|
+
* Attualemnte non bindata ed utilizzata solo a livello di default ma non si sa mai
|
|
38
|
+
*/
|
|
39
|
+
this.showSpinners = true;
|
|
40
|
+
/**
|
|
41
|
+
* Proprietà dell'elemento di selezione dell'orario. Mostra o nasconde i secondi
|
|
42
|
+
*
|
|
43
|
+
* Attualemnte non bindata ed utilizzata solo a livello di default ma non si sa mai
|
|
44
|
+
*/
|
|
45
|
+
this.showSeconds = true;
|
|
46
|
+
/**
|
|
47
|
+
* Proprietà dell'elemento di selezione dell'orario. Imposta l'incremento/decremento minimo per le ore
|
|
48
|
+
*
|
|
49
|
+
* Attualemnte non bindata ed utilizzata solo a livello di default ma non si sa mai
|
|
50
|
+
*/
|
|
51
|
+
this.stepHour = 1;
|
|
52
|
+
/**
|
|
53
|
+
* Proprietà dell'elemento di selezione dell'orario. Imposta l'incremento/decremento minimo per i minuti
|
|
54
|
+
*
|
|
55
|
+
* Attualemnte non bindata ed utilizzata solo a livello di default ma non si sa mai
|
|
56
|
+
*/
|
|
57
|
+
this.stepMinute = 1;
|
|
58
|
+
/**
|
|
59
|
+
* Proprietà dell'elemento di selezione dell'orario. Imposta l'incremento/decremento minimo per i secondi
|
|
60
|
+
*
|
|
61
|
+
* Attualemnte non bindata ed utilizzata solo a livello di default ma non si sa mai
|
|
62
|
+
*/
|
|
63
|
+
this.stepSecond = 1;
|
|
64
|
+
/**
|
|
65
|
+
* Utilizza il Date di Javascript come modello in uscita. Il modello in entrata verrà comunque ricondotto a un DayJs
|
|
66
|
+
*/
|
|
67
|
+
this.useJsDates = false;
|
|
68
|
+
/**
|
|
69
|
+
* @ignore
|
|
70
|
+
*/
|
|
71
|
+
this.onTouched = () => { };
|
|
72
|
+
}
|
|
73
|
+
/**
|
|
74
|
+
* @ignore
|
|
75
|
+
*/
|
|
76
|
+
ngOnInit() {
|
|
77
|
+
// Controllo se è settato un required per decidere in maniera condizionale se utilizzare il validatore required nel componente interno
|
|
78
|
+
if (this._validators && !this.noValidate && this._validators.some(elem => elem instanceof RequiredValidator))
|
|
79
|
+
this.required = true;
|
|
80
|
+
this._format = this.lc.token("getSmallDateDisplayFormat");
|
|
81
|
+
}
|
|
82
|
+
/**
|
|
83
|
+
* @ignore
|
|
84
|
+
*/
|
|
85
|
+
ngAfterViewInit() {
|
|
86
|
+
this.postBinding();
|
|
87
|
+
}
|
|
88
|
+
/**
|
|
89
|
+
* Metodo che si occupa di collegare i validatori e la funzione di reset dal **ControlValueAccessor** rappresentato
|
|
90
|
+
* da questo componente al **ControlValueAccessor** rappresentato dall'effettivo elemento di Input presente lato HTML
|
|
91
|
+
*/
|
|
92
|
+
postBinding() {
|
|
93
|
+
this.CheckValidity();
|
|
94
|
+
const ngControl = this.injector.get(NgControl, null);
|
|
95
|
+
if (ngControl) {
|
|
96
|
+
this.parentControl = ngControl.control;
|
|
97
|
+
// Se la variabile novalidate è true, elimino tutti i validatori eventualmente inseriti
|
|
98
|
+
if (this.noValidate) {
|
|
99
|
+
this.parentControl.clearValidators();
|
|
100
|
+
this.parentControl.clearAsyncValidators();
|
|
101
|
+
}
|
|
102
|
+
else {
|
|
103
|
+
this.baseInput.control.setAsyncValidators(this._asyncValidators);
|
|
104
|
+
this.baseInput.control.setValidators(this._validators);
|
|
105
|
+
}
|
|
106
|
+
// Faccio in modo che se chiamo il reset del controllo (o della form) dall'esterno si resetti anche il controllo nativo
|
|
107
|
+
const origFunc = this.parentControl.reset;
|
|
108
|
+
this.parentControl.reset = () => {
|
|
109
|
+
origFunc.apply(this.parentControl);
|
|
110
|
+
this.baseInput.control.reset();
|
|
111
|
+
this.tooltip.hide();
|
|
112
|
+
};
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
/**
|
|
116
|
+
* @ignore
|
|
117
|
+
*/
|
|
118
|
+
writeValue(value) {
|
|
119
|
+
if (!value) {
|
|
120
|
+
this.value = null;
|
|
121
|
+
if (this.baseInput)
|
|
122
|
+
this.baseInput.reset();
|
|
123
|
+
}
|
|
124
|
+
else {
|
|
125
|
+
var date = null;
|
|
126
|
+
if (this.useJsDates) {
|
|
127
|
+
date = this.dateExts.getDateConvertion(value);
|
|
128
|
+
this.propagateChange(date);
|
|
129
|
+
this.inputChange.emit(date);
|
|
130
|
+
}
|
|
131
|
+
else
|
|
132
|
+
date = dayjs(value, this.lc.token("getSmallDateFormat") + " HH:mm:ss");
|
|
133
|
+
this.value = date;
|
|
134
|
+
}
|
|
135
|
+
this.cdr.markForCheck();
|
|
136
|
+
}
|
|
137
|
+
/**
|
|
138
|
+
* Metodo che si occupa di, eventualmente, aggiustare il valore da propagare ed emetterlo
|
|
139
|
+
*
|
|
140
|
+
* L'emit della modifica al valore viene gestito su un evento custom (**inputChange**) come workaround al malfunzionamento dell'**ngModelChange** nativo
|
|
141
|
+
*
|
|
142
|
+
* @param {any} toEmit valore da propagare all'esterno
|
|
143
|
+
*/
|
|
144
|
+
outputValue(toEmit) {
|
|
145
|
+
let value = toEmit.value;
|
|
146
|
+
let propagateValue;
|
|
147
|
+
if (!value)
|
|
148
|
+
propagateValue = null;
|
|
149
|
+
else if (!this.useJsDates)
|
|
150
|
+
propagateValue = value.format(this.lc.token("getSmallDateFormat") + " HH:mm:ss");
|
|
151
|
+
else {
|
|
152
|
+
if (value && value.isValid())
|
|
153
|
+
propagateValue = value.toDate();
|
|
154
|
+
else
|
|
155
|
+
propagateValue = null;
|
|
156
|
+
}
|
|
157
|
+
this.propagateChange(propagateValue);
|
|
158
|
+
this.inputChange.emit(propagateValue);
|
|
159
|
+
this.onTouched();
|
|
160
|
+
}
|
|
161
|
+
/**
|
|
162
|
+
* @ignore
|
|
163
|
+
*/
|
|
164
|
+
registerOnChange(fn) {
|
|
165
|
+
this.propagateChange = fn;
|
|
166
|
+
}
|
|
167
|
+
/**
|
|
168
|
+
* @ignore
|
|
169
|
+
*/
|
|
170
|
+
registerOnTouched(fn) {
|
|
171
|
+
this.onTouched = fn;
|
|
172
|
+
}
|
|
173
|
+
}
|
|
174
|
+
ValidationDateTimeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: ValidationDateTimeComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: NG_VALIDATORS, optional: true }, { token: NG_ASYNC_VALIDATORS, optional: true }, { token: i0.Injector }, { token: i1.LocalizationService }, { token: i2.DateService }], target: i0.ɵɵFactoryTarget.Component });
|
|
175
|
+
ValidationDateTimeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: ValidationDateTimeComponent, selector: "val-datetime", inputs: { useJsDates: "useJsDates" }, providers: [
|
|
176
|
+
{ provide: LocalizationService, useClass: BaseValidationLoc },
|
|
177
|
+
{
|
|
178
|
+
provide: NG_VALUE_ACCESSOR,
|
|
179
|
+
useExisting: forwardRef(() => ValidationDateTimeComponent),
|
|
180
|
+
multi: true
|
|
181
|
+
}
|
|
182
|
+
], usesInheritance: true, ngImport: i0, template: "<mat-form-field appearance=\"outline\" class=\"mat-full-width mat-no-border-top mat-height-fixed\" [style.width.px]=\"widthPx\">\r\n <mat-label *ngIf=\"placeholder\">{{placeholder}}</mat-label>\r\n\r\n <input matInput \r\n [ngxMatDatetimePicker]=\"datepicker\" \r\n #baseInput=\"ngModel\"\r\n type=\"text\"\r\n triggers=\"\"\r\n placement=\"top\"\r\n name=\"val-date\"\r\n class=\"form-control {{class}}\"\r\n autocomplete=\"{{autocomplete}}\"\r\n [(ngModel)]=\"value\"\r\n [class.checking-field]=\"!noValidate\"\r\n [tooltip]=\"tolTemplate\"\r\n [placeholder]=\"placeholder ? '' : _format\"\r\n [disabled]=\"readonly || disabled\"\r\n [isDisabled]=\"readonly || disabled\"\r\n (dateChange)=\"outputValue($event)\"/>\r\n\r\n <mat-datepicker-toggle matSuffix [for]=\"datepicker\"></mat-datepicker-toggle>\r\n\r\n <ngx-mat-datetime-picker #datepicker \r\n [showSpinners]=\"showSpinners\" \r\n [showSeconds]=\"showSeconds\" \r\n [stepHour]=\"stepHour\" \r\n [stepMinute]=\"stepMinute\" \r\n [stepSecond]=\"stepSecond\" \r\n [touchUi]=\"false\" \r\n [color]=\"'primary'\">\r\n </ngx-mat-datetime-picker>\r\n</mat-form-field>\r\n\r\n<ng-template #tolTemplate>\r\n <div (click)=\"closeTooltip()\">\r\n <span>{{validationFailed}}</span>\r\n </div>\r\n</ng-template>", styles: [".tooltip-inner{background-color:#842a30;color:#fff;font-size:12px;width:max-content}.tooltip{margin:auto auto auto 20%!important}.tooltip-inner{background-color:#842a30!important;color:#fff}.tooltip.top .tooltip-arrow:before,.tooltip.top .tooltip-arrow{border-top-color:#842a30}.close-button{position:absolute;right:0em;top:-.2em;float:right;font-size:16px;font-weight:700;color:inherit;text-shadow:0 1px 0 #fff;opacity:.5}.close-button:hover,.close-button:focus{text-decoration:none;cursor:pointer;opacity:.75}\n"], components: [{ type: i3.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { type: i4.MatDatepickerToggle, selector: "mat-datepicker-toggle", inputs: ["for", "tabIndex", "aria-label", "disabled", "disableRipple"], exportAs: ["matDatepickerToggle"] }, { type: i5.NgxMatDatetimePicker, selector: "ngx-mat-datetime-picker", inputs: ["calendarHeaderComponent", "startAt", "startView", "defaultColor", "color", "touchUi", "hideTime", "disabled", "panelClass", "dateClass", "opened", "showSpinners", "showSeconds", "stepHour", "stepMinute", "stepSecond", "enableMeridian", "disableMinute", "defaultTime"], outputs: ["yearSelected", "monthSelected", "opened", "closed"], exportAs: ["ngxMatDatetimePicker"] }], directives: [{ type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.MatLabel, selector: "mat-label" }, { type: i7.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { type: i5.NgxMatDatetimeInput, selector: "input[ngxMatDatetimePicker]", inputs: ["ngxMatDatetimePicker", "ngxMatDatetimePickerFilter", "value", "min", "max", "disabled"], outputs: ["dateChange", "dateInput"], exportAs: ["ngxMatDatetimePickerInput"] }, { type: i8.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i8.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i8.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i9.TooltipDirective, selector: "[tooltip], [tooltipHtml]", inputs: ["adaptivePosition", "placement", "triggers", "containerClass", "isDisabled", "delay", "tooltipAnimation", "tooltipFadeDuration", "isOpen", "tooltipHtml", "tooltip", "tooltipPlacement", "tooltipIsOpen", "tooltipEnable", "tooltipAppendToBody", "container", "tooltipClass", "tooltipContext", "tooltipPopupDelay", "tooltipTrigger", "boundariesElement"], outputs: ["tooltipChange", "tooltipStateChanged", "onShown", "onHidden"], exportAs: ["bs-tooltip"] }, { type: i3.MatSuffix, selector: "[matSuffix]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
183
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: ValidationDateTimeComponent, decorators: [{
|
|
184
|
+
type: Component,
|
|
185
|
+
args: [{ selector: "val-datetime", encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
186
|
+
{ provide: LocalizationService, useClass: BaseValidationLoc },
|
|
187
|
+
{
|
|
188
|
+
provide: NG_VALUE_ACCESSOR,
|
|
189
|
+
useExisting: forwardRef(() => ValidationDateTimeComponent),
|
|
190
|
+
multi: true
|
|
191
|
+
}
|
|
192
|
+
], template: "<mat-form-field appearance=\"outline\" class=\"mat-full-width mat-no-border-top mat-height-fixed\" [style.width.px]=\"widthPx\">\r\n <mat-label *ngIf=\"placeholder\">{{placeholder}}</mat-label>\r\n\r\n <input matInput \r\n [ngxMatDatetimePicker]=\"datepicker\" \r\n #baseInput=\"ngModel\"\r\n type=\"text\"\r\n triggers=\"\"\r\n placement=\"top\"\r\n name=\"val-date\"\r\n class=\"form-control {{class}}\"\r\n autocomplete=\"{{autocomplete}}\"\r\n [(ngModel)]=\"value\"\r\n [class.checking-field]=\"!noValidate\"\r\n [tooltip]=\"tolTemplate\"\r\n [placeholder]=\"placeholder ? '' : _format\"\r\n [disabled]=\"readonly || disabled\"\r\n [isDisabled]=\"readonly || disabled\"\r\n (dateChange)=\"outputValue($event)\"/>\r\n\r\n <mat-datepicker-toggle matSuffix [for]=\"datepicker\"></mat-datepicker-toggle>\r\n\r\n <ngx-mat-datetime-picker #datepicker \r\n [showSpinners]=\"showSpinners\" \r\n [showSeconds]=\"showSeconds\" \r\n [stepHour]=\"stepHour\" \r\n [stepMinute]=\"stepMinute\" \r\n [stepSecond]=\"stepSecond\" \r\n [touchUi]=\"false\" \r\n [color]=\"'primary'\">\r\n </ngx-mat-datetime-picker>\r\n</mat-form-field>\r\n\r\n<ng-template #tolTemplate>\r\n <div (click)=\"closeTooltip()\">\r\n <span>{{validationFailed}}</span>\r\n </div>\r\n</ng-template>", styles: [".tooltip-inner{background-color:#842a30;color:#fff;font-size:12px;width:max-content}.tooltip{margin:auto auto auto 20%!important}.tooltip-inner{background-color:#842a30!important;color:#fff}.tooltip.top .tooltip-arrow:before,.tooltip.top .tooltip-arrow{border-top-color:#842a30}.close-button{position:absolute;right:0em;top:-.2em;float:right;font-size:16px;font-weight:700;color:inherit;text-shadow:0 1px 0 #fff;opacity:.5}.close-button:hover,.close-button:focus{text-decoration:none;cursor:pointer;opacity:.75}\n"] }]
|
|
193
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: Array, decorators: [{
|
|
194
|
+
type: Optional
|
|
195
|
+
}, {
|
|
196
|
+
type: Inject,
|
|
197
|
+
args: [NG_VALIDATORS]
|
|
198
|
+
}] }, { type: Array, decorators: [{
|
|
199
|
+
type: Optional
|
|
200
|
+
}, {
|
|
201
|
+
type: Inject,
|
|
202
|
+
args: [NG_ASYNC_VALIDATORS]
|
|
203
|
+
}] }, { type: i0.Injector }, { type: i1.LocalizationService }, { type: i2.DateService }]; }, propDecorators: { useJsDates: [{
|
|
204
|
+
type: Input
|
|
205
|
+
}] } });
|
|
206
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"validation-datetime.component.js","sourceRoot":"","sources":["../../../../../../projects/forms-and-validations/src/lib/validations/validation-datetime/validation-datetime.component.ts","../../../../../../projects/forms-and-validations/src/lib/validations/validation-datetime/validation-datetime.component.html"],"names":[],"mappings":"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","sourcesContent":["// Angular\r\nimport { ControlValueAccessor, FormControl, NG_ASYNC_VALIDATORS, NG_VALIDATORS, NG_VALUE_ACCESSOR, NgControl, RequiredValidator } from \"@angular/forms\";\r\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, forwardRef, Inject, Injector, Input, Optional, 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 { DateService } from '@esfaenza/extensions';\r\n\r\n/**\r\n * Dichiarazione della variabile globale dayjs. L'onere di \"crearla\" è affidato all'applicazione che utilizza questa libreria, \r\n * che dovrà importare lo script globale di dayjs nella CLI\r\n */\r\ndeclare var dayjs: any;\r\n\r\n/**\r\n * Componente di validaizone per gli input di tipo data-ora\r\n */\r\n@Component({\r\n    selector: \"val-datetime\",\r\n    templateUrl: \"validation-datetime.component.html\",\r\n    encapsulation: ViewEncapsulation.None,\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    styleUrls: [\"../validation-style.scss\"],\r\n    providers: [\r\n        { provide: LocalizationService, useClass: BaseValidationLoc },\r\n        {\r\n            provide: NG_VALUE_ACCESSOR,\r\n            useExisting: forwardRef(() => ValidationDateTimeComponent),\r\n            multi: true\r\n        }\r\n    ]\r\n})\r\nexport class ValidationDateTimeComponent extends BaseValidation implements ControlValueAccessor {\r\n\r\n    /**\r\n     * Usato solo per stampare il placeholder qualora l'Input **placeholder** non fosse valorizzato\r\n     */\r\n    public _format: string;\r\n\r\n    /**\r\n     * Modello collegato all'input\r\n     */\r\n    public value: Date;\r\n\r\n    /**\r\n     * Controllo esposto ottenuto tramite injector\r\n     */\r\n    private parentControl: FormControl;\r\n\r\n    /**\r\n     * Proprietà dell'elemento di selezione dell'orario. Mostra o nasconde gli spinner\r\n     * \r\n     * Attualemnte non bindata ed utilizzata solo a livello di default ma non si sa mai\r\n     */\r\n    public showSpinners = true;\r\n\r\n    /**\r\n     * Proprietà dell'elemento di selezione dell'orario. Mostra o nasconde i secondi\r\n     * \r\n     * Attualemnte non bindata ed utilizzata solo a livello di default ma non si sa mai\r\n     */\r\n    public showSeconds = true;\r\n\r\n    /**\r\n     * Proprietà dell'elemento di selezione dell'orario. Imposta l'incremento/decremento minimo per le ore\r\n     * \r\n     * Attualemnte non bindata ed utilizzata solo a livello di default ma non si sa mai\r\n     */\r\n    public stepHour = 1;\r\n\r\n    /**\r\n     * Proprietà dell'elemento di selezione dell'orario. Imposta l'incremento/decremento minimo per i minuti\r\n     * \r\n     * Attualemnte non bindata ed utilizzata solo a livello di default ma non si sa mai\r\n     */\r\n    public stepMinute = 1;\r\n\r\n    /**\r\n     * Proprietà dell'elemento di selezione dell'orario. Imposta l'incremento/decremento minimo per i secondi\r\n     * \r\n     * Attualemnte non bindata ed utilizzata solo a livello di default ma non si sa mai\r\n     */\r\n    public stepSecond = 1;\r\n\r\n    /**\r\n     * Utilizza il Date di Javascript come modello in uscita. Il modello in entrata verrà comunque ricondotto a un DayJs\r\n     */\r\n    @Input() public useJsDates: boolean = false;\r\n\r\n    /**\r\n     * @ignore\r\n     */\r\n    constructor(private 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, private dateExts: DateService) {\r\n        super();\r\n    }\r\n\r\n    /**\r\n     * @ignore\r\n     */\r\n    ngOnInit() {\r\n        // Controllo se è settato un required per decidere in maniera condizionale se utilizzare il validatore required nel componente interno\r\n        if (this._validators && !this.noValidate && this._validators.some(elem => elem instanceof RequiredValidator))\r\n            this.required = true;\r\n\r\n        this._format = this.lc.token(\"getSmallDateDisplayFormat\");\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        this.CheckValidity();\r\n        const ngControl: NgControl = this.injector.get(NgControl, null);\r\n        if (ngControl) {\r\n            this.parentControl = ngControl.control as FormControl;\r\n\r\n            // Se la variabile novalidate è true, elimino tutti i validatori eventualmente inseriti\r\n            if (this.noValidate) {\r\n                this.parentControl.clearValidators();\r\n                this.parentControl.clearAsyncValidators();\r\n            }\r\n            else {\r\n                this.baseInput.control.setAsyncValidators(this._asyncValidators);\r\n                this.baseInput.control.setValidators(this._validators);\r\n            }\r\n\r\n            // Faccio in modo che se chiamo il reset del controllo (o della form) dall'esterno si resetti anche il controllo nativo\r\n            const origFunc = this.parentControl.reset;\r\n            this.parentControl.reset = () => { \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        if (!value) {\r\n            this.value = null;\r\n            if (this.baseInput)\r\n                this.baseInput.reset();\r\n        } else {\r\n            var date = null;\r\n            if (this.useJsDates) {\r\n                date = this.dateExts.getDateConvertion(value)\r\n                this.propagateChange(date);\r\n                this.inputChange.emit(date);\r\n            }\r\n            else\r\n                date = dayjs(value, this.lc.token(\"getSmallDateFormat\") + \" HH:mm:ss\");\r\n\r\n            this.value = date;\r\n        }\r\n        this.cdr.markForCheck();\r\n    }\r\n\r\n    /**\r\n     * Metodo che si occupa di, eventualmente, aggiustare il valore da propagare ed emetterlo\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    outputValue(toEmit: any): void {\r\n        let value = toEmit.value;\r\n        let propagateValue: any;\r\n\r\n        if (!value)\r\n            propagateValue = null;\r\n        else if (!this.useJsDates)\r\n            propagateValue = value.format(this.lc.token(\"getSmallDateFormat\") + \" HH:mm:ss\");\r\n        else {\r\n            if (value && value.isValid())\r\n                propagateValue = value.toDate();\r\n            else\r\n                propagateValue = null;\r\n        }\r\n        this.propagateChange(propagateValue);\r\n        this.inputChange.emit(propagateValue);\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=\"outline\" class=\"mat-full-width mat-no-border-top mat-height-fixed\" [style.width.px]=\"widthPx\">\r\n    <mat-label *ngIf=\"placeholder\">{{placeholder}}</mat-label>\r\n\r\n    <input matInput \r\n           [ngxMatDatetimePicker]=\"datepicker\" \r\n           #baseInput=\"ngModel\"\r\n           type=\"text\"\r\n           triggers=\"\"\r\n           placement=\"top\"\r\n           name=\"val-date\"\r\n           class=\"form-control {{class}}\"\r\n           autocomplete=\"{{autocomplete}}\"\r\n           [(ngModel)]=\"value\"\r\n           [class.checking-field]=\"!noValidate\"\r\n           [tooltip]=\"tolTemplate\"\r\n           [placeholder]=\"placeholder ? '' : _format\"\r\n           [disabled]=\"readonly || disabled\"\r\n           [isDisabled]=\"readonly || disabled\"\r\n           (dateChange)=\"outputValue($event)\"/>\r\n\r\n  <mat-datepicker-toggle matSuffix [for]=\"datepicker\"></mat-datepicker-toggle>\r\n\r\n  <ngx-mat-datetime-picker #datepicker \r\n            [showSpinners]=\"showSpinners\" \r\n            [showSeconds]=\"showSeconds\" \r\n            [stepHour]=\"stepHour\" \r\n            [stepMinute]=\"stepMinute\" \r\n            [stepSecond]=\"stepSecond\" \r\n            [touchUi]=\"false\" \r\n            [color]=\"'primary'\">\r\n  </ngx-mat-datetime-picker>\r\n</mat-form-field>\r\n\r\n<ng-template #tolTemplate>\r\n    <div (click)=\"closeTooltip()\">\r\n        <span>{{validationFailed}}</span>\r\n    </div>\r\n</ng-template>"]}
|
|
@@ -0,0 +1,207 @@
|
|
|
1
|
+
// Angular
|
|
2
|
+
import { NG_ASYNC_VALIDATORS, NG_VALIDATORS, NG_VALUE_ACCESSOR, NgControl, RequiredValidator } 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/material/form-field";
|
|
12
|
+
import * as i3 from "@angular/common";
|
|
13
|
+
import * as i4 from "@angular/material/input";
|
|
14
|
+
import * as i5 from "@angular/forms";
|
|
15
|
+
import * as i6 from "ngx-bootstrap/tooltip";
|
|
16
|
+
/**
|
|
17
|
+
* Componente di validaizone per gli input a semplice casella di testo
|
|
18
|
+
*/
|
|
19
|
+
export class ValidationInputComponent extends BaseValidation {
|
|
20
|
+
/**
|
|
21
|
+
* @ignore
|
|
22
|
+
*/
|
|
23
|
+
constructor(cdr, _validators, _asyncValidators, injector, lc) {
|
|
24
|
+
super();
|
|
25
|
+
this.cdr = cdr;
|
|
26
|
+
this._validators = _validators;
|
|
27
|
+
this._asyncValidators = _asyncValidators;
|
|
28
|
+
this.injector = injector;
|
|
29
|
+
this.lc = lc;
|
|
30
|
+
/**
|
|
31
|
+
* Indica se questo Comopnente deve rappresentare un oggetto di Input di tipo "Password"
|
|
32
|
+
*/
|
|
33
|
+
this.Password = false;
|
|
34
|
+
/**
|
|
35
|
+
* Indica se deve mostrare un indicazione di warning nel suffisso
|
|
36
|
+
*/
|
|
37
|
+
this.showWarning = false;
|
|
38
|
+
/**
|
|
39
|
+
* Classe del warning eventualmente modificabile.
|
|
40
|
+
*
|
|
41
|
+
* Default: "fa fa-warning"
|
|
42
|
+
*/
|
|
43
|
+
this.warningClass = "fa fa-warning";
|
|
44
|
+
/**
|
|
45
|
+
* Identifica se il testo di un componente di tipo "password" dev'essere visualizzato o meno
|
|
46
|
+
*/
|
|
47
|
+
this.passShown = false;
|
|
48
|
+
/**
|
|
49
|
+
* Tipo del componente, può essere "text" o "password" e viene impostato automaticamente dall'Input **Password**
|
|
50
|
+
*/
|
|
51
|
+
this.type = "text";
|
|
52
|
+
/**
|
|
53
|
+
* Indicazione se il componente ha o meno un suffisso.
|
|
54
|
+
*
|
|
55
|
+
* Valorizzato a **true** solo se viene trovata una proiezione su **suffix_internal** o se l'Input **showWarning** viene impostato a **true**
|
|
56
|
+
*/
|
|
57
|
+
this.HasSuffix = false;
|
|
58
|
+
/**
|
|
59
|
+
* Indicazione se il componente ha o meno un prefisso.
|
|
60
|
+
*
|
|
61
|
+
* Valorizzato a **true** solo se viene trovata una proiezione su **prefix_internal**
|
|
62
|
+
*/
|
|
63
|
+
this.HasPrefix = false;
|
|
64
|
+
/**
|
|
65
|
+
* @ignore
|
|
66
|
+
*/
|
|
67
|
+
this.onTouched = () => { };
|
|
68
|
+
}
|
|
69
|
+
/**
|
|
70
|
+
* @ignore
|
|
71
|
+
*/
|
|
72
|
+
ngOnInit() {
|
|
73
|
+
//controllo se è settato un required per decidere in maniera condizionale se utilizzare il validatore required nel componente interno
|
|
74
|
+
if (this._validators && !this.noValidate && this._validators.some(elem => elem instanceof RequiredValidator))
|
|
75
|
+
this.required = true;
|
|
76
|
+
if (this.Password)
|
|
77
|
+
this.type = "password";
|
|
78
|
+
}
|
|
79
|
+
/**
|
|
80
|
+
* @ignore
|
|
81
|
+
*/
|
|
82
|
+
ngOnDestroy() {
|
|
83
|
+
if (this.tooltipSubscription)
|
|
84
|
+
this.tooltipSubscription.unsubscribe();
|
|
85
|
+
}
|
|
86
|
+
/**
|
|
87
|
+
* @ignore
|
|
88
|
+
*/
|
|
89
|
+
ngAfterViewInit() {
|
|
90
|
+
this.HasSuffix = !!this.suffix_internal || this.showWarning;
|
|
91
|
+
this.HasPrefix = !!this.prefix_internal;
|
|
92
|
+
this.postBinding();
|
|
93
|
+
}
|
|
94
|
+
/**
|
|
95
|
+
* @ignore
|
|
96
|
+
*/
|
|
97
|
+
ngOnChanges(changes) {
|
|
98
|
+
const newShowWarnings = changes["showWarning"];
|
|
99
|
+
if (newShowWarnings)
|
|
100
|
+
this.HasSuffix = !!this.suffix_internal || this.showWarning;
|
|
101
|
+
}
|
|
102
|
+
/**
|
|
103
|
+
* Metodo che si occupa di collegare i validatori e la funzione di reset dal **ControlValueAccessor** rappresentato
|
|
104
|
+
* da questo componente al **ControlValueAccessor** rappresentato dall'effettivo elemento di Input presente lato HTML
|
|
105
|
+
*/
|
|
106
|
+
postBinding() {
|
|
107
|
+
this.CheckValidity();
|
|
108
|
+
const ngControl = this.injector.get(NgControl, null);
|
|
109
|
+
if (ngControl) {
|
|
110
|
+
this.parentControl = ngControl.control;
|
|
111
|
+
// Se la variabile novalidate è true, elimino tutti i validatori eventualmente inseriti
|
|
112
|
+
if (this.noValidate) {
|
|
113
|
+
this.parentControl.clearValidators();
|
|
114
|
+
this.parentControl.clearAsyncValidators();
|
|
115
|
+
}
|
|
116
|
+
else {
|
|
117
|
+
this.baseInput.control.setAsyncValidators(this._asyncValidators);
|
|
118
|
+
this.baseInput.control.setValidators(this._validators);
|
|
119
|
+
}
|
|
120
|
+
// Faccio in modo che se chiamo il reset del controllo (o della form) dall'esterno si resetti anche il controllo nativo
|
|
121
|
+
const origFunc = this.parentControl.reset;
|
|
122
|
+
this.parentControl.reset = () => {
|
|
123
|
+
origFunc.apply(this.parentControl);
|
|
124
|
+
this.baseInput.control.reset();
|
|
125
|
+
this.tooltip.hide();
|
|
126
|
+
};
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
/**
|
|
130
|
+
* @ignore
|
|
131
|
+
*/
|
|
132
|
+
writeValue(value) {
|
|
133
|
+
this.value = value;
|
|
134
|
+
this.propagateChange(value);
|
|
135
|
+
this.cdr.markForCheck();
|
|
136
|
+
}
|
|
137
|
+
/**
|
|
138
|
+
* L'emit della modifica al valore viene gestito su un evento custom (**inputChange**) come workaround al malfunzionamento dell'**ngModelChange** nativo
|
|
139
|
+
*
|
|
140
|
+
* @param {any} toEmit valore da propagare all'esterno
|
|
141
|
+
*/
|
|
142
|
+
onModelChange(toEmit) {
|
|
143
|
+
this.writeValue(toEmit);
|
|
144
|
+
this.inputChange.emit(toEmit);
|
|
145
|
+
this.onTouched();
|
|
146
|
+
}
|
|
147
|
+
/**
|
|
148
|
+
* @ignore
|
|
149
|
+
*/
|
|
150
|
+
registerOnChange(fn) {
|
|
151
|
+
this.propagateChange = fn;
|
|
152
|
+
}
|
|
153
|
+
/**
|
|
154
|
+
* @ignore
|
|
155
|
+
*/
|
|
156
|
+
registerOnTouched(fn) {
|
|
157
|
+
this.onTouched = fn;
|
|
158
|
+
}
|
|
159
|
+
}
|
|
160
|
+
ValidationInputComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", 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 });
|
|
161
|
+
ValidationInputComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.1.1", type: ValidationInputComponent, selector: "val-input", inputs: { Password: "Password", showWarning: "showWarning", warningTitle: "warningTitle", warningClass: "warningClass", value: "value" }, providers: [
|
|
162
|
+
{ provide: LocalizationService, useClass: BaseValidationLoc },
|
|
163
|
+
{
|
|
164
|
+
provide: NG_VALUE_ACCESSOR,
|
|
165
|
+
useExisting: forwardRef(() => ValidationInputComponent),
|
|
166
|
+
multi: true
|
|
167
|
+
}
|
|
168
|
+
], 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 appearance=\"outline\" 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\">{{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 <input matInput\r\n #baseInput='ngModel'\r\n type=\"{{type}}\"\r\n triggers=\"\"\r\n placement=\"top\"\r\n autocomplete=\"{{autocomplete}}\"\r\n name=\"val-input\"\r\n class=\"form-control {{class}}\"\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 [disabled]=\"readonly || disabled\"\r\n (ngModelChange)=\"onModelChange($event)\"\r\n (focus)=\"checkTooltip();\"\r\n (blur)=\"closeTooltip();\">\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<ng-template #tolTemplate>\r\n <div (click)=\"closeTooltip()\">\r\n <span>{{validationFailed}}</span>\r\n </div>\r\n</ng-template>", styles: [".tooltip-inner{background-color:#842a30;color:#fff;font-size:12px;width:max-content}.tooltip{margin:auto auto auto 20%!important}.tooltip-inner{background-color:#842a30!important;color:#fff}.tooltip.top .tooltip-arrow:before,.tooltip.top .tooltip-arrow{border-top-color:#842a30}.close-button{position:absolute;right:0em;top:-.2em;float:right;font-size:16px;font-weight:700;color:inherit;text-shadow:0 1px 0 #fff;opacity:.5}.close-button:hover,.close-button:focus{text-decoration:none;cursor:pointer;opacity:.75}\n"], components: [{ type: i2.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.MatLabel, selector: "mat-label" }, { type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }, { type: i4.MatInput, selector: "input[matInput], textarea[matInput], select[matNativeControl], input[matNativeControl], textarea[matNativeControl]", inputs: ["disabled", "id", "placeholder", "required", "type", "errorStateMatcher", "aria-describedby", "value", "readonly"], exportAs: ["matInput"] }, { type: i5.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i6.TooltipDirective, selector: "[tooltip], [tooltipHtml]", inputs: ["adaptivePosition", "placement", "triggers", "containerClass", "isDisabled", "delay", "tooltipAnimation", "tooltipFadeDuration", "isOpen", "tooltipHtml", "tooltip", "tooltipPlacement", "tooltipIsOpen", "tooltipEnable", "tooltipAppendToBody", "container", "tooltipClass", "tooltipContext", "tooltipPopupDelay", "tooltipTrigger", "boundariesElement"], outputs: ["tooltipChange", "tooltipStateChanged", "onShown", "onHidden"], exportAs: ["bs-tooltip"] }, { type: i2.MatSuffix, selector: "[matSuffix]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
169
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: ValidationInputComponent, decorators: [{
|
|
170
|
+
type: Component,
|
|
171
|
+
args: [{ selector: "val-input", changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
172
|
+
{ provide: LocalizationService, useClass: BaseValidationLoc },
|
|
173
|
+
{
|
|
174
|
+
provide: NG_VALUE_ACCESSOR,
|
|
175
|
+
useExisting: forwardRef(() => ValidationInputComponent),
|
|
176
|
+
multi: true
|
|
177
|
+
}
|
|
178
|
+
], encapsulation: ViewEncapsulation.None, template: "<mat-form-field appearance=\"outline\" 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\">{{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 <input matInput\r\n #baseInput='ngModel'\r\n type=\"{{type}}\"\r\n triggers=\"\"\r\n placement=\"top\"\r\n autocomplete=\"{{autocomplete}}\"\r\n name=\"val-input\"\r\n class=\"form-control {{class}}\"\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 [disabled]=\"readonly || disabled\"\r\n (ngModelChange)=\"onModelChange($event)\"\r\n (focus)=\"checkTooltip();\"\r\n (blur)=\"closeTooltip();\">\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<ng-template #tolTemplate>\r\n <div (click)=\"closeTooltip()\">\r\n <span>{{validationFailed}}</span>\r\n </div>\r\n</ng-template>", styles: [".tooltip-inner{background-color:#842a30;color:#fff;font-size:12px;width:max-content}.tooltip{margin:auto auto auto 20%!important}.tooltip-inner{background-color:#842a30!important;color:#fff}.tooltip.top .tooltip-arrow:before,.tooltip.top .tooltip-arrow{border-top-color:#842a30}.close-button{position:absolute;right:0em;top:-.2em;float:right;font-size:16px;font-weight:700;color:inherit;text-shadow:0 1px 0 #fff;opacity:.5}.close-button:hover,.close-button:focus{text-decoration:none;cursor:pointer;opacity:.75}\n"] }]
|
|
179
|
+
}], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: Array, decorators: [{
|
|
180
|
+
type: Optional
|
|
181
|
+
}, {
|
|
182
|
+
type: Inject,
|
|
183
|
+
args: [NG_VALIDATORS]
|
|
184
|
+
}] }, { type: Array, decorators: [{
|
|
185
|
+
type: Optional
|
|
186
|
+
}, {
|
|
187
|
+
type: Inject,
|
|
188
|
+
args: [NG_ASYNC_VALIDATORS]
|
|
189
|
+
}] }, { type: i0.Injector }, { type: i1.LocalizationService }]; }, propDecorators: { Password: [{
|
|
190
|
+
type: Input
|
|
191
|
+
}], showWarning: [{
|
|
192
|
+
type: Input
|
|
193
|
+
}], warningTitle: [{
|
|
194
|
+
type: Input
|
|
195
|
+
}], warningClass: [{
|
|
196
|
+
type: Input
|
|
197
|
+
}], value: [{
|
|
198
|
+
type: Input,
|
|
199
|
+
args: ["value"]
|
|
200
|
+
}], suffix_internal: [{
|
|
201
|
+
type: ContentChild,
|
|
202
|
+
args: ["suffix_internal", { static: false }]
|
|
203
|
+
}], prefix_internal: [{
|
|
204
|
+
type: ContentChild,
|
|
205
|
+
args: ["prefix_internal", { static: false }]
|
|
206
|
+
}] } });
|
|
207
|
+
//# 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, FormControl, 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     * 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: FormControl;\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    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(private 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();\r\n    }\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    ngOnInit() {\r\n        //controllo se è settato un required per decidere in maniera condizionale se utilizzare il validatore required nel componente interno\r\n        if (this._validators && !this.noValidate && this._validators.some(elem => elem instanceof RequiredValidator))\r\n            this.required = true;\r\n\r\n        if (this.Password)\r\n            this.type = \"password\";\r\n    }\r\n\r\n    /**\r\n     * @ignore \r\n     */\r\n    ngOnDestroy() {\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 FormControl;\r\n\r\n            // Se la variabile novalidate è true, elimino tutti i validatori eventualmente inseriti\r\n            if (this.noValidate) {\r\n                this.parentControl.clearValidators();\r\n                this.parentControl.clearAsyncValidators();\r\n            }\r\n            else {\r\n                this.baseInput.control.setAsyncValidators(this._asyncValidators);\r\n                this.baseInput.control.setValidators(this._validators);\r\n            }\r\n\r\n            // Faccio in modo che se chiamo il reset del controllo (o della form) dall'esterno si resetti anche il controllo nativo\r\n            const origFunc = this.parentControl.reset;\r\n            this.parentControl.reset = () => {\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 appearance=\"outline\" 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\">{{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    <input matInput\r\n           #baseInput='ngModel'\r\n           type=\"{{type}}\"\r\n           triggers=\"\"\r\n           placement=\"top\"\r\n           autocomplete=\"{{autocomplete}}\"\r\n           name=\"val-input\"\r\n           class=\"form-control {{class}}\"\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           [disabled]=\"readonly || disabled\"\r\n           (ngModelChange)=\"onModelChange($event)\"\r\n           (focus)=\"checkTooltip();\"\r\n           (blur)=\"closeTooltip();\">\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<ng-template #tolTemplate>\r\n    <div (click)=\"closeTooltip()\">\r\n        <span>{{validationFailed}}</span>\r\n    </div>\r\n</ng-template>"]}
|