@esfaenza/forms-and-validations 18.2.2 → 19.2.3
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/README.md +63 -1
- package/fesm2022/esfaenza-forms-and-validations.mjs +1099 -3972
- package/fesm2022/esfaenza-forms-and-validations.mjs.map +1 -1
- package/lib/forms/adaptive/form-adaptive.component.d.ts +23 -0
- package/lib/forms/autocomplete/form-autocomplete.component.d.ts +40 -0
- package/lib/forms/base/base-form-control.d.ts +132 -0
- package/lib/forms/base/skeleton/input-skeleton.component.d.ts +12 -0
- package/lib/forms/checkbox/form-checkbox.component.d.ts +11 -0
- package/lib/forms/currency/form-currency.component.d.ts +10 -0
- package/lib/forms/date/form-date.component.d.ts +36 -0
- package/lib/forms/datetime/form-datetime.component.d.ts +7 -0
- package/lib/forms/{form-info/form-info.component.d.ts → error/form-error.component.d.ts} +4 -4
- package/lib/forms/file/form-file.component.d.ts +38 -0
- package/lib/forms/{form-error/form-error.component.d.ts → info/form-info.component.d.ts} +4 -4
- package/lib/forms/input/form-input.component.d.ts +25 -0
- package/lib/forms/multiselect/form-multiselect.component.d.ts +20 -0
- package/lib/forms/select/form-select.component.d.ts +9 -0
- package/lib/forms/{form-template → template}/form-template.component.d.ts +3 -3
- package/lib/forms/textarea/form-textarea.component.d.ts +13 -0
- package/lib/forms/time/form-time.component.d.ts +7 -0
- package/lib/forms.module.d.ts +32 -0
- package/lib/models/AppFile.d.ts +5 -15
- package/lib/models/BaseFormConfiguration.d.ts +27 -0
- package/lib/models/EsFormsModuleConfig.d.ts +7 -0
- package/lib/services/helper.d.ts +15 -0
- package/lib/tokens.d.ts +1 -5
- package/package.json +10 -16
- package/public-api.d.ts +18 -28
- package/esm2022/esfaenza-forms-and-validations.mjs +0 -5
- package/esm2022/lib/forms/base-form-control.mjs +0 -558
- package/esm2022/lib/forms/form-adaptive/form-adaptive.component.loc.mjs +0 -22
- package/esm2022/lib/forms/form-adaptive/form-adaptive.component.mjs +0 -420
- package/esm2022/lib/forms/form-autocomplete/form-autocomplete.component.loc.mjs +0 -21
- package/esm2022/lib/forms/form-autocomplete/form-autocomplete.component.mjs +0 -289
- package/esm2022/lib/forms/form-checkbox/form-checkbox.component.mjs +0 -74
- package/esm2022/lib/forms/form-date/form-date.component.mjs +0 -69
- package/esm2022/lib/forms/form-datetime/form-datetime.component.mjs +0 -67
- package/esm2022/lib/forms/form-empty/form-empty.component.mjs +0 -30
- package/esm2022/lib/forms/form-error/form-error.component.mjs +0 -42
- package/esm2022/lib/forms/form-file/form-file.component.loc.mjs +0 -22
- package/esm2022/lib/forms/form-file/form-file.component.mjs +0 -175
- package/esm2022/lib/forms/form-info/form-info.component.mjs +0 -42
- package/esm2022/lib/forms/form-input/form-input.component.mjs +0 -83
- package/esm2022/lib/forms/form-multiselect/form-multiselect.component.loc.mjs +0 -23
- package/esm2022/lib/forms/form-multiselect/form-multiselect.component.mjs +0 -163
- package/esm2022/lib/forms/form-select/form-select.component.loc.mjs +0 -21
- package/esm2022/lib/forms/form-select/form-select.component.mjs +0 -165
- package/esm2022/lib/forms/form-template/form-template.component.mjs +0 -77
- package/esm2022/lib/forms/form-textarea/form-textarea.component.mjs +0 -57
- package/esm2022/lib/forms/form-time/form-time.component.mjs +0 -115
- package/esm2022/lib/forms-and-validations.module.mjs +0 -213
- package/esm2022/lib/models/AppFile.mjs +0 -14
- package/esm2022/lib/models/ChangeEvent.mjs +0 -7
- package/esm2022/lib/models/FormsAndValidationsModuleConfig.mjs +0 -6
- package/esm2022/lib/models/dayjs-adapter/dayjs-date-adapter.mjs +0 -89
- package/esm2022/lib/tokens.mjs +0 -8
- package/esm2022/lib/validations/base-validation.loc.mjs +0 -23
- package/esm2022/lib/validations/base-validation.mjs +0 -328
- package/esm2022/lib/validations/customValidators/CustomRequiredDirective.mjs +0 -41
- package/esm2022/lib/validations/validation-autocomplete/validation-autocomplete.component.mjs +0 -147
- package/esm2022/lib/validations/validation-autocomplete-multi/validation-autocomplete-multi.component.mjs +0 -240
- package/esm2022/lib/validations/validation-currency/validation-currency.component.mjs +0 -75
- package/esm2022/lib/validations/validation-date/validation-date.component.mjs +0 -183
- package/esm2022/lib/validations/validation-datetime/validation-datetime.component.mjs +0 -212
- package/esm2022/lib/validations/validation-input/validation-input.component.mjs +0 -222
- package/esm2022/lib/validations/validation-select/validation-select.component.mjs +0 -183
- package/esm2022/lib/validations/validation-text-area/validation-text-area.component.mjs +0 -78
- package/esm2022/public-api.mjs +0 -40
- package/lib/forms/base-form-control.d.ts +0 -276
- package/lib/forms/form-adaptive/form-adaptive.component.d.ts +0 -126
- package/lib/forms/form-adaptive/form-adaptive.component.loc.d.ts +0 -14
- package/lib/forms/form-autocomplete/form-autocomplete.component.d.ts +0 -84
- package/lib/forms/form-autocomplete/form-autocomplete.component.loc.d.ts +0 -14
- package/lib/forms/form-checkbox/form-checkbox.component.d.ts +0 -23
- package/lib/forms/form-date/form-date.component.d.ts +0 -21
- package/lib/forms/form-datetime/form-datetime.component.d.ts +0 -23
- package/lib/forms/form-empty/form-empty.component.d.ts +0 -15
- package/lib/forms/form-file/form-file.component.d.ts +0 -46
- package/lib/forms/form-file/form-file.component.loc.d.ts +0 -14
- package/lib/forms/form-input/form-input.component.d.ts +0 -33
- package/lib/forms/form-multiselect/form-multiselect.component.d.ts +0 -67
- package/lib/forms/form-multiselect/form-multiselect.component.loc.d.ts +0 -14
- package/lib/forms/form-select/form-select.component.d.ts +0 -43
- package/lib/forms/form-select/form-select.component.loc.d.ts +0 -14
- package/lib/forms/form-textarea/form-textarea.component.d.ts +0 -18
- package/lib/forms/form-time/form-time.component.d.ts +0 -40
- package/lib/forms-and-validations.module.d.ts +0 -47
- package/lib/models/FormsAndValidationsModuleConfig.d.ts +0 -11
- package/lib/models/dayjs-adapter/dayjs-date-adapter.d.ts +0 -49
- package/lib/validations/base-validation.d.ts +0 -219
- package/lib/validations/base-validation.loc.d.ts +0 -14
- package/lib/validations/customValidators/CustomRequiredDirective.d.ts +0 -24
- package/lib/validations/validation-autocomplete/validation-autocomplete.component.d.ts +0 -58
- package/lib/validations/validation-autocomplete-multi/validation-autocomplete-multi.component.d.ts +0 -88
- package/lib/validations/validation-currency/validation-currency.component.d.ts +0 -28
- package/lib/validations/validation-date/validation-date.component.d.ts +0 -79
- package/lib/validations/validation-datetime/validation-datetime.component.d.ts +0 -109
- package/lib/validations/validation-input/validation-input.component.d.ts +0 -134
- package/lib/validations/validation-select/validation-select.component.d.ts +0 -95
- package/lib/validations/validation-text-area/validation-text-area.component.d.ts +0 -28
|
@@ -1,420 +0,0 @@
|
|
|
1
|
-
// Angular
|
|
2
|
-
import { ChangeDetectionStrategy, Component, Inject, Input, Optional, Self, ViewChild } from "@angular/core";
|
|
3
|
-
import { NG_VALIDATORS, PatternValidator } from "@angular/forms";
|
|
4
|
-
// ES / Configurazioni
|
|
5
|
-
import { LocalizationService } from "@esfaenza/localizations";
|
|
6
|
-
// Applicazione
|
|
7
|
-
import { BaseFormControl } from "../base-form-control";
|
|
8
|
-
import { FormAdaptiveComponentLoc } from "./form-adaptive.component.loc";
|
|
9
|
-
// Modelli
|
|
10
|
-
import { ACO_CUSTOMKEY, FAV_DEBUG_MODE } from '../../tokens';
|
|
11
|
-
import { AppFile } from "../../models/AppFile";
|
|
12
|
-
import * as i0 from "@angular/core";
|
|
13
|
-
import * as i1 from "@esfaenza/extensions";
|
|
14
|
-
import * as i2 from "@ngxmc/datetime-picker";
|
|
15
|
-
import * as i3 from "@esfaenza/localizations";
|
|
16
|
-
import * as i4 from "@angular/forms";
|
|
17
|
-
import * as i5 from "@esfaenza/access-control";
|
|
18
|
-
import * as i6 from "@angular/common";
|
|
19
|
-
import * as i7 from "../../validations/validation-input/validation-input.component";
|
|
20
|
-
import * as i8 from "../../validations/validation-select/validation-select.component";
|
|
21
|
-
import * as i9 from "../../validations/validation-date/validation-date.component";
|
|
22
|
-
import * as i10 from "../../validations/validation-currency/validation-currency.component";
|
|
23
|
-
import * as i11 from "../../validations/validation-autocomplete/validation-autocomplete.component";
|
|
24
|
-
import * as i12 from "../../validations/validation-datetime/validation-datetime.component";
|
|
25
|
-
/** Componente in grado di assumere la forma di un qualsiasi altro componente form in base al tipo specificato. Utile per la creazione di form dinamici */
|
|
26
|
-
export class FormAdaptiveComponent extends BaseFormControl {
|
|
27
|
-
/** @ignore Costruttore */
|
|
28
|
-
constructor(cdr, utiExts, datesExts, dateAdapter, lc, ngControl, _validators, ac, AppContext, ACO_CUSTOMKEY, FAV_DEBUG_MODE) {
|
|
29
|
-
super(cdr, ngControl, _validators, ac, AppContext, ACO_CUSTOMKEY, FAV_DEBUG_MODE);
|
|
30
|
-
this.utiExts = utiExts;
|
|
31
|
-
this.datesExts = datesExts;
|
|
32
|
-
this.dateAdapter = dateAdapter;
|
|
33
|
-
this.lc = lc;
|
|
34
|
-
/** Indica di aggiustare in uscita i number in modo che siano parsabili dal javascript */
|
|
35
|
-
this.AdjustNumber = true;
|
|
36
|
-
/** Permette di scaricare l'eventuale file presente qualora il **Type** di questo componente fosse **file** */
|
|
37
|
-
this.AllowDownload = true;
|
|
38
|
-
/** Utilizzata nel form-adapter per specificare la precisione degli input currencymap (Type: currency) */
|
|
39
|
-
this.Precision = 2;
|
|
40
|
-
/** Allineamento della currency mask */
|
|
41
|
-
this.Alignment = 'right';
|
|
42
|
-
/** Funzione di ricerca che verrà chiamata dal componente */
|
|
43
|
-
this.SearchFunction = null;
|
|
44
|
-
/** Numero minimo di caratteri con cui cercare */
|
|
45
|
-
this.MinChars = 3;
|
|
46
|
-
/** Indica se i controlli devono essere effettuati tenendo conto del Case o meno. Vale solo qualora la **Source** fosse fornita */
|
|
47
|
-
this.CaseSensitive = false;
|
|
48
|
-
/** Opzioni specifiche per il componente che si va a visualizzare. Es. per i tipi date: { JsDates: true } */
|
|
49
|
-
this.Options = {};
|
|
50
|
-
/** Variabile interna che gestisce se effettuare il riallineamento dei dati o meno */
|
|
51
|
-
this.alignValues = false;
|
|
52
|
-
/**
|
|
53
|
-
* Indica se ignorare il prossimo evento writeValue che normalmente dovrebbe richiedere la nuova source. Serve per quando l'utente seleziona un elemento:
|
|
54
|
-
* Subito dopo partirebbe un altro evento modelChange che ricaricherebbe nuovamente la source
|
|
55
|
-
*/
|
|
56
|
-
this.ignoreNextWriteValue = false;
|
|
57
|
-
/** Cache della sorgente originale POST binding, in modo da poter fare filtri in locale qualora la **SearchFunction** non fosse definita e la **Source** fosse assegnata */
|
|
58
|
-
this.FilteredBoundSource = [];
|
|
59
|
-
/** Solo per gli input di tipo "date". Capisce che modalità usare per il validation-date sottostante */
|
|
60
|
-
this.useJsDates = null;
|
|
61
|
-
this.IntPattern = '^[0-9]\\d*$';
|
|
62
|
-
this.FloatPattern = '^([0-9]*[,])?[0-9]+$';
|
|
63
|
-
//******************** Funzione di throttling per non spammare richieste in caso di animazioni attivate
|
|
64
|
-
//TODO: spostarla in un metodo di utilità (esfaenza/extensions)
|
|
65
|
-
/** @ignore */
|
|
66
|
-
this.executionTimers = {};
|
|
67
|
-
this.ModelFile = new AppFile();
|
|
68
|
-
this.UseUserValidators = false;
|
|
69
|
-
}
|
|
70
|
-
/**
|
|
71
|
-
* Nvl con un minimo di senso
|
|
72
|
-
* @param value Valore base
|
|
73
|
-
* @param ifnod Valore da usare se **value** è nullo o undefined
|
|
74
|
-
* @returns Il valore preso fra i due disponibili
|
|
75
|
-
*/
|
|
76
|
-
nvl(value, ifnod) {
|
|
77
|
-
return value == null || value == undefined ? ifnod : value;
|
|
78
|
-
}
|
|
79
|
-
ngOnInit() {
|
|
80
|
-
// Assegnazione Opzioni da oggetto
|
|
81
|
-
if (this.Options) {
|
|
82
|
-
this.useJsDates = this.nvl(this.Options?.JsDates, this.useJsDates);
|
|
83
|
-
;
|
|
84
|
-
this.CaseSensitive = this.nvl(this.Options?.CaseSensitive, this.CaseSensitive);
|
|
85
|
-
this.MinChars = this.nvl(this.Options?.MinChars, this.MinChars);
|
|
86
|
-
this.SearchFunction = this.nvl(this.Options?.SearchFunction, this.SearchFunction);
|
|
87
|
-
this.Alignment = this.nvl(this.Options?.Alignment, this.Alignment);
|
|
88
|
-
this.Precision = this.nvl(this.Options?.Precision, this.Precision);
|
|
89
|
-
this.AllowDownload = this.nvl(this.Options?.AllowDownload, this.AllowDownload);
|
|
90
|
-
this.AdjustNumber = this.nvl(this.Options?.AdjustNumber, this.AdjustNumber);
|
|
91
|
-
this.Pattern = this.nvl(this.Options?.Pattern, this.Pattern);
|
|
92
|
-
}
|
|
93
|
-
if (this.ngControl) {
|
|
94
|
-
// Esclusi i validatori a componenti
|
|
95
|
-
let validators = [...(this._validators || [])].filter(v => !v.ngOnInit);
|
|
96
|
-
var pv = new PatternValidator();
|
|
97
|
-
switch (this.Type) {
|
|
98
|
-
case 'int':
|
|
99
|
-
pv.pattern = this.Pattern || this.IntPattern;
|
|
100
|
-
validators.push(pv);
|
|
101
|
-
break;
|
|
102
|
-
case 'float':
|
|
103
|
-
case 'number':
|
|
104
|
-
pv.pattern = this.Pattern || this.FloatPattern;
|
|
105
|
-
validators.push(pv);
|
|
106
|
-
break;
|
|
107
|
-
case 'string':
|
|
108
|
-
if (this.Pattern) {
|
|
109
|
-
pv.pattern = this.Pattern;
|
|
110
|
-
validators.push(pv);
|
|
111
|
-
}
|
|
112
|
-
break;
|
|
113
|
-
}
|
|
114
|
-
// A quanto pare la creazione del validatore rompe il caso d'uso classico...
|
|
115
|
-
pv._validator = this.customPatternValidator(pv.pattern);
|
|
116
|
-
this.ngControl._setValidators(validators);
|
|
117
|
-
this.ngControl.control.setValidators(validators);
|
|
118
|
-
this.ngControl.control.updateValueAndValidity();
|
|
119
|
-
}
|
|
120
|
-
super.ngOnInit();
|
|
121
|
-
}
|
|
122
|
-
/**
|
|
123
|
-
* Validator that requires the control's value to match a regex pattern.
|
|
124
|
-
* See `Validators.pattern` for additional information.
|
|
125
|
-
*/
|
|
126
|
-
customPatternValidator(pattern) {
|
|
127
|
-
if (!pattern)
|
|
128
|
-
return (_) => null;
|
|
129
|
-
let regex;
|
|
130
|
-
let regexStr;
|
|
131
|
-
if (typeof pattern === 'string') {
|
|
132
|
-
regexStr = '';
|
|
133
|
-
if (pattern.charAt(0) !== '^')
|
|
134
|
-
regexStr += '^';
|
|
135
|
-
regexStr += pattern;
|
|
136
|
-
if (pattern.charAt(pattern.length - 1) !== '$')
|
|
137
|
-
regexStr += '$';
|
|
138
|
-
regex = new RegExp(regexStr);
|
|
139
|
-
}
|
|
140
|
-
return (control) => {
|
|
141
|
-
if (!control.value) {
|
|
142
|
-
return null;
|
|
143
|
-
}
|
|
144
|
-
// Caricamento avvenuto adesso da modello
|
|
145
|
-
if (control.value && !this.floatValuePreAdjustmente)
|
|
146
|
-
this.floatValuePreAdjustmente = control.value.toString().replace(".", ",");
|
|
147
|
-
return regex.test(this.floatValuePreAdjustmente) ? null : { 'pattern': { 'requiredPattern': regexStr, 'actualValue': this.floatValuePreAdjustmente } };
|
|
148
|
-
};
|
|
149
|
-
}
|
|
150
|
-
/** @ignore */
|
|
151
|
-
async ngOnChanges(changes) {
|
|
152
|
-
const newSource = changes["Source"];
|
|
153
|
-
const newType = changes["Type"];
|
|
154
|
-
if (newSource) {
|
|
155
|
-
this.tryBindSourceDisplay();
|
|
156
|
-
// Prima assegnazione se cambia la source sotto (quindi se viene bindata direttamente da HTML)
|
|
157
|
-
if (this.Type == "autocomplete" && (this.Model?.length || 0) >= this.MinChars && !this.SearchFunction)
|
|
158
|
-
this.FilteredBoundSource = this.BoundSource;
|
|
159
|
-
else
|
|
160
|
-
this.FilteredBoundSource = [];
|
|
161
|
-
this.cdr.markForCheck();
|
|
162
|
-
}
|
|
163
|
-
if (newType && this.Model)
|
|
164
|
-
this.writeValue(this.Model);
|
|
165
|
-
}
|
|
166
|
-
/** @ignore */
|
|
167
|
-
writeValue(obj) {
|
|
168
|
-
this.alignValues = false;
|
|
169
|
-
this.EvaluatedModel = obj?.toString() || "";
|
|
170
|
-
if (!this.Type) {
|
|
171
|
-
this.Type = "string";
|
|
172
|
-
this.EvaluatedModel = obj;
|
|
173
|
-
}
|
|
174
|
-
if (this.Type == "date" || this.Type == "datetime") {
|
|
175
|
-
this.useJsDates = this.useJsDates == null ? Object.prototype.toString.call(obj) === "[object Date]" : this.useJsDates;
|
|
176
|
-
if (this.Type == "date")
|
|
177
|
-
this.EvaluatedModel = this.datesExts.getFormatted(obj, true, false);
|
|
178
|
-
if (this.Type == "datetime")
|
|
179
|
-
this.EvaluatedModel = this.datesExts.getFormatted(obj, false, true);
|
|
180
|
-
}
|
|
181
|
-
else if ((this.Type == "float" || this.Type == "number") && obj) {
|
|
182
|
-
obj = obj.toString().replace(".", ",");
|
|
183
|
-
this.EvaluatedModel = obj;
|
|
184
|
-
}
|
|
185
|
-
// Per sicurezza riallineo i valori
|
|
186
|
-
else if (this.Type == "boolean") {
|
|
187
|
-
obj = obj ? (obj === true || obj.toLowerCase() == "true") : false;
|
|
188
|
-
this.alignValues = true;
|
|
189
|
-
this.EvaluatedModel = this.lc.loc(obj ? 'Sì' : 'No');
|
|
190
|
-
}
|
|
191
|
-
else if (this.Type == "time") {
|
|
192
|
-
const [hours, minutes, seconds] = (obj || "00:00:00").split(":");
|
|
193
|
-
obj = dayjs().hour(parseInt(hours ?? 0)).minute(parseInt(minutes ?? 0)).second(parseInt(seconds ?? 0));
|
|
194
|
-
this.EvaluatedModel = `${hours || '00'}:${minutes || '00'}:${seconds || '00'}`;
|
|
195
|
-
}
|
|
196
|
-
else if (this.Type == "file") {
|
|
197
|
-
obj = this.ModelFile;
|
|
198
|
-
this.EvaluatedModel = this.ModelFile.filename;
|
|
199
|
-
}
|
|
200
|
-
else if (this.Type == "autocomplete") {
|
|
201
|
-
if (this.SearchFunction) {
|
|
202
|
-
this.SearchFunction(obj, true).subscribe(t => {
|
|
203
|
-
this.Source = t;
|
|
204
|
-
this.tryBindSourceDisplay();
|
|
205
|
-
setTimeout(() => { this.finalizeValue(obj); });
|
|
206
|
-
});
|
|
207
|
-
return;
|
|
208
|
-
}
|
|
209
|
-
else
|
|
210
|
-
this.finalizeValue(obj);
|
|
211
|
-
}
|
|
212
|
-
if (this.BoundSource && this.BoundSource.length > 0)
|
|
213
|
-
this.EvaluatedModel = this.BoundSource.find(t => t.id == obj)?.description;
|
|
214
|
-
super.writeValue(obj);
|
|
215
|
-
if (this.alignValues) {
|
|
216
|
-
this.changed();
|
|
217
|
-
this.cdr.markForCheck();
|
|
218
|
-
}
|
|
219
|
-
}
|
|
220
|
-
/**
|
|
221
|
-
* Dato un valore verifica se può restituire le informazioni trovate in **Source** con id uguale a **value** o se deve restituire il valore in se
|
|
222
|
-
*
|
|
223
|
-
* @param {any} value Valore scritto nell'input di testo
|
|
224
|
-
*/
|
|
225
|
-
finalizeValue(value) {
|
|
226
|
-
var val = this.Source.find(t => t.id == value);
|
|
227
|
-
this.propagateChange(val ? val.id : value);
|
|
228
|
-
this.Model = val ? val.description : value;
|
|
229
|
-
this.EvaluatedModel = this.Model;
|
|
230
|
-
}
|
|
231
|
-
/**
|
|
232
|
-
* Evento di filtro della sorgente dati in base all'input utente
|
|
233
|
-
*
|
|
234
|
-
* @param {string} event Input utente
|
|
235
|
-
*/
|
|
236
|
-
filterSource(event) {
|
|
237
|
-
if (this.ignoreNextWriteValue) {
|
|
238
|
-
this.ignoreNextWriteValue = false;
|
|
239
|
-
return;
|
|
240
|
-
}
|
|
241
|
-
// Quando filtro la source, se non devo ignorare l'evento devo comunque assicurarmi di impostare il valore selezionato a null
|
|
242
|
-
super.changed(null);
|
|
243
|
-
if (!event && this.MinChars == 0 && !this.SearchFunction) {
|
|
244
|
-
this.FilteredBoundSource = this.BoundSource;
|
|
245
|
-
return;
|
|
246
|
-
}
|
|
247
|
-
if (!event || event.value.length < this.MinChars) {
|
|
248
|
-
this.FilteredBoundSource = [];
|
|
249
|
-
return;
|
|
250
|
-
}
|
|
251
|
-
if (!this.SearchFunction && (!this.Source || this.Source.length == 0))
|
|
252
|
-
throw "Impossibile filtrare gli elementi senza una funzione di ricerca che restituisca una lista di { id: string, description: string }";
|
|
253
|
-
if (this.SearchFunction) {
|
|
254
|
-
this.throttla("filtersource", () => {
|
|
255
|
-
this.SearchFunction(event.value, false).subscribe(t => {
|
|
256
|
-
this.Source = t;
|
|
257
|
-
this.tryBindSourceDisplay();
|
|
258
|
-
// In questo caso è già filtrata dalla SearchFunction
|
|
259
|
-
this.FilteredBoundSource = this.BoundSource;
|
|
260
|
-
this.removeFilteredSourceOnDescriptionSelection();
|
|
261
|
-
this.cdr.markForCheck();
|
|
262
|
-
});
|
|
263
|
-
}, 400);
|
|
264
|
-
}
|
|
265
|
-
else {
|
|
266
|
-
this.throttla("filtersource", () => {
|
|
267
|
-
// In questo caso devo filtrare io in memoria
|
|
268
|
-
this.FilteredBoundSource = this.BoundSource.filter(t => (this.CaseSensitive && t.description.includes(event.value)) || (!this.CaseSensitive && t.description.toLowerCase().includes(event.value.toLowerCase())));
|
|
269
|
-
this.removeFilteredSourceOnDescriptionSelection();
|
|
270
|
-
this.cdr.markForCheck();
|
|
271
|
-
}, 100);
|
|
272
|
-
}
|
|
273
|
-
}
|
|
274
|
-
/** @ignore */
|
|
275
|
-
removeFilteredSourceOnDescriptionSelection() {
|
|
276
|
-
if (this.FilteredBoundSource.length == 1 && (this.FilteredBoundSource[0].description === this.Model)) {
|
|
277
|
-
this.Model = this.BoundSource[0].id;
|
|
278
|
-
this.EvaluatedModel = this.BoundSource[0].description;
|
|
279
|
-
this.FilteredBoundSource = [];
|
|
280
|
-
}
|
|
281
|
-
}
|
|
282
|
-
/** Metodo richiamato quando viene modificato il modello del campo di input */
|
|
283
|
-
changed(event) {
|
|
284
|
-
var toEmit = this.getModelToEmit();
|
|
285
|
-
if (this.Type == "autocomplete")
|
|
286
|
-
this.ignoreNextWriteValue = true;
|
|
287
|
-
if (this.EmitPendingChanges)
|
|
288
|
-
super.changed(toEmit, false, false, event?.internal);
|
|
289
|
-
}
|
|
290
|
-
/** @ignore */
|
|
291
|
-
finalized() {
|
|
292
|
-
super.finalized();
|
|
293
|
-
}
|
|
294
|
-
/** Metodo richiamato quando viene selezionato il campo col mouse */
|
|
295
|
-
focused(event) {
|
|
296
|
-
super.focused(event);
|
|
297
|
-
}
|
|
298
|
-
/** Effettua gli aggiustamenti dati del caso ed emette il modello corretto */
|
|
299
|
-
getModelToEmit() {
|
|
300
|
-
var toEmit = this.Model ?
|
|
301
|
-
(this.Type == "time" || this.useJsDates ?
|
|
302
|
-
this.dateAdapter.clone(this.datesExts.getDateConvertion(this.Model))
|
|
303
|
-
: JSON.parse(JSON.stringify(this.Model)))
|
|
304
|
-
: null;
|
|
305
|
-
if ((this.Type == "float" || this.Type == "number") && toEmit) {
|
|
306
|
-
if (this.AdjustNumber) {
|
|
307
|
-
this.floatValuePreAdjustmente = toEmit;
|
|
308
|
-
toEmit = toEmit.replace(".", "").replace(",", ".");
|
|
309
|
-
}
|
|
310
|
-
this.EvaluatedModel = toEmit;
|
|
311
|
-
}
|
|
312
|
-
else if (this.Type == "boolean") {
|
|
313
|
-
toEmit = toEmit ? true : false;
|
|
314
|
-
this.EvaluatedModel = this.lc.loc(toEmit ? 'Yes' : 'No');
|
|
315
|
-
;
|
|
316
|
-
}
|
|
317
|
-
else if (this.Type == "time") {
|
|
318
|
-
toEmit = toEmit.format("HH:mm:ss");
|
|
319
|
-
this.EvaluatedModel = toEmit;
|
|
320
|
-
}
|
|
321
|
-
else if ((this.Type == "date" || this.Type == "datetime") && this.useJsDates) {
|
|
322
|
-
toEmit = toEmit.toDate();
|
|
323
|
-
this.EvaluatedModel = this.datesExts.getFormatted(this.Model, this.Type == "date", this.Type == "datetime");
|
|
324
|
-
}
|
|
325
|
-
return toEmit;
|
|
326
|
-
}
|
|
327
|
-
/**
|
|
328
|
-
* Helper per gestire la modifica del file attualmente bindato. Ovviamente funziona solo qualora il **Type** fosse **file**
|
|
329
|
-
*
|
|
330
|
-
* @param {boolean} clear Indica se bisogna svuotare l'input o meno
|
|
331
|
-
*/
|
|
332
|
-
fileChange(clear = false) {
|
|
333
|
-
let files = [];
|
|
334
|
-
let model = this.Model;
|
|
335
|
-
let ne = this.inputEl.nativeElement;
|
|
336
|
-
if (clear) {
|
|
337
|
-
model.filename = "";
|
|
338
|
-
ne.value = "";
|
|
339
|
-
}
|
|
340
|
-
else {
|
|
341
|
-
for (let i = 0; i < ne.files.length; i++)
|
|
342
|
-
files.push(ne.files.item(i));
|
|
343
|
-
if (ne.files.length == 1)
|
|
344
|
-
model.filename = ne.files[0].name;
|
|
345
|
-
if (ne.files.length > 1)
|
|
346
|
-
model.filename = ne.files.length + " " + this.lc.loc("Files Selected");
|
|
347
|
-
model.nativefiles = files;
|
|
348
|
-
model.fileb64 = null;
|
|
349
|
-
}
|
|
350
|
-
this.changed();
|
|
351
|
-
}
|
|
352
|
-
/** Permette di scaricare il file collegato all'evetnuale file input rappresentato da questo componente */
|
|
353
|
-
downloadAttachment() {
|
|
354
|
-
let model = this.Model;
|
|
355
|
-
this.utiExts.saveFile(model.fileb64, model.filename);
|
|
356
|
-
}
|
|
357
|
-
/** @ignore */
|
|
358
|
-
onNotNullValueSet() { }
|
|
359
|
-
/** @ignore */
|
|
360
|
-
throttla(id, func, throttleTime) {
|
|
361
|
-
//Se ho la funzione che vuole eseguire ripulisco quel timeout
|
|
362
|
-
if (this.executionTimers[id])
|
|
363
|
-
clearTimeout(this.executionTimers[id]);
|
|
364
|
-
//Ricreo il timeout per eseguire quella funzione dopo throttleTime millisecondi
|
|
365
|
-
this.executionTimers[id] = setTimeout(() => { func(); this.executionTimers[id] = null; }, throttleTime);
|
|
366
|
-
}
|
|
367
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormAdaptiveComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.UtilityService }, { token: i1.DateService }, { token: i2.NgxMatDateAdapter }, { token: i3.LocalizationService }, { token: i4.NgControl, optional: true, self: true }, { token: NG_VALIDATORS, optional: true }, { token: i5.AccessControlService }, { token: i5.ComponentContext, optional: true }, { token: ACO_CUSTOMKEY, optional: true }, { token: FAV_DEBUG_MODE, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
368
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FormAdaptiveComponent, selector: "form-adaptive", inputs: { Type: "Type", TypeMissingMessage: "TypeMissingMessage", Pattern: "Pattern", AdjustNumber: "AdjustNumber", AllowDownload: "AllowDownload", Precision: "Precision", Alignment: "Alignment", SearchFunction: "SearchFunction", MinChars: "MinChars", CaseSensitive: "CaseSensitive", Options: "Options" }, providers: [{ provide: LocalizationService, useClass: FormAdaptiveComponentLoc }], viewQueries: [{ propertyName: "inputEl", first: true, predicate: ["fileInput"], descendants: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<!-- Uguale in tutti i componenti --------------------------------------------------------------------------->\r\n<ng-container *ngIf=\"!FormLayout && (!DisplayMode || (DisplayLayout != 'hidden' && DisplayCondition))\">\r\n <ng-container *ngIf=\"DisplayMode && !DisplayModeTemplate\">\r\n <ng-container *ngIf=\"DisplayLayout == 'form'\">{{ EvaluatedModel }}</ng-container>\r\n <div *ngIf=\"DisplayLayout == 'inline'\" class=\"app-inline\">{{ EvaluatedModel }}</div>\r\n </ng-container>\r\n <ng-container *ngIf=\"DisplayMode && DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"DisplayModeTemplate, context: { $implicit: EvaluatedModel }\"></ng-container></ng-container>\r\n <div [hidden]=\"DisplayMode\"><ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container></div>\r\n</ng-container>\r\n\r\n<div *ngIf=\"FormLayout && (!DisplayMode || (DisplayLayout != 'hidden' && DisplayCondition))\" class=\"{{FormGroupClass + (Last ? ' app-margin-bottom-0 app-margin-right-0 ' : '') + (DisplayLayout == 'inline' && DisplayMode ? (' app-inline-block ' + (!Last ? 'app-margin-right-10' : '')) : ' form-group row')}}\">\r\n\r\n <label class=\"col-md-{{(DisplayMode && DisplayLayout == 'inline' ? 'none app-bold app-margin-bottom-0' : LabelColWidth) + (DisplayMode ? ' app-bold' : ' m-t-5') }}\">{{Label}}{{Required && !DisplayMode ? '*' : ''}}{{Label ? \":\" : \"\"}}</label>\r\n <span *ngIf=\"DisplayMode && DisplayLayout == 'inline' && InlineSeparator != ''\">{{InlineSeparator}}</span>\r\n <div class=\"col-md-{{DisplayMode && DisplayLayout == 'inline' ? 'none app-inline-block' : InputColWidth}}\">\r\n\r\n <ng-container *ngIf=\"DisplayMode && !DisplayModeTemplate\">{{ EvaluatedModel }}</ng-container>\r\n <ng-container *ngIf=\"DisplayMode && DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"DisplayModeTemplate, context: { $implicit: EvaluatedModel }\"></ng-container></ng-container>\r\n <div [hidden]=\"DisplayMode\"><ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container></div>\r\n </div>\r\n <div class=\"clearfix\"></div>\r\n</div>\r\n<!----------------------------------------------------------------------------------------------------------->\r\n\r\n<ng-template #controlTemplate>\r\n <div *ngIf=\"!Type\" class=\"app-margin-top-5\">\r\n <em>{{TypeMissingMessage}}</em>\r\n </div>\r\n \r\n <!--Se currency-->\r\n <div *ngIf=\"Type == 'currency'\">\r\n <val-currency #validationControl=\"ngModel\" [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\" [forceInvalid]=\"ForcedError\" [FloatingLabel]=\"FloatingLabel\"\r\n [CurrencyOptions]=\"{ prefix: '', thousands: '.', decimal: ',', precision: Precision, align: Alignment }\" [noValidate]=\"!Validation\"\r\n type=\"text\" [Readonly]=\"Readonly\" [submitted]=\"Form?.submitted\" [required]=\"Required\" [(ngModel)]=\"Model\" [id]=\"GeneratedName\" name=\"{{GeneratedName}}\" autocomplete=\"off\" (inputChange)=\"changed();\" (inputFocus)=\"focused($event);\" (inputFinalized)=\"finalized()\"></val-currency>\r\n </div>\r\n <!--Se data-->\r\n <div *ngIf=\"Type == 'date'\">\r\n <val-date #validationControl=\"ngModel\" [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\" [forceInvalid]=\"ForcedError\" [FloatingLabel]=\"FloatingLabel\" [noValidate]=\"!Validation\" [Readonly]=\"Readonly\" [submitted]=\"Form?.submitted\" [required]=\"Required\" [(ngModel)]=\"Model\" [id]=\"GeneratedName\" [useJsDates]=\"useJsDates\" name=\"{{GeneratedName}}\" autocomplete=\"off\" (inputChange)=\"changed($event);\" (inputFocus)=\"focused($event);\" (inputFinalized)=\"finalized()\"></val-date>\r\n </div>\r\n <!--Se stringa-->\r\n <div *ngIf=\"Type == 'string'\">\r\n <val-input #validationControl=\"ngModel\" [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\" [forceInvalid]=\"ForcedError\" [FloatingLabel]=\"FloatingLabel\" [noValidate]=\"!Validation\" [Readonly]=\"Readonly\" [submitted]=\"Form?.submitted\" type=\"text\" pattern=\"{{Pattern || ''}}\" [required]=\"Required\" [placeholder]=\"Placeholder\" [(ngModel)]=\"Model\" [id]=\"GeneratedName\" name=\"{{GeneratedName}}\" autocomplete=\"off\" (inputChange)=\"changed($event);\" (inputFocus)=\"focused($event);\" (inputFinalized)=\"finalized()\"></val-input>\r\n </div>\r\n <!--Se numero-->\r\n <div *ngIf=\"Type == 'float' || Type == 'number'\">\r\n <val-input #validationControl=\"ngModel\" [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\" [forceInvalid]=\"ForcedError\" [FloatingLabel]=\"FloatingLabel\" [noValidate]=\"!Validation\" [Readonly]=\"Readonly\" [submitted]=\"Form?.submitted\" type=\"text\" pattern=\"{{Pattern || FloatPattern}}\" [required]=\"Required\" [placeholder]=\"Placeholder\" [(ngModel)]=\"Model\" [id]=\"GeneratedName\" name=\"{{GeneratedName}}\" autocomplete=\"off\" (inputChange)=\"changed($event);\" (inputFocus)=\"focused($event);\" (inputFinalized)=\"finalized()\"></val-input>\r\n </div>\r\n <!--Se numero intero-->\r\n <div *ngIf=\"Type == 'int'\">\r\n <val-input #validationControl=\"ngModel\" [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\" [forceInvalid]=\"ForcedError\" [FloatingLabel]=\"FloatingLabel\" [noValidate]=\"!Validation\" [Readonly]=\"Readonly\" [submitted]=\"Form?.submitted\" type=\"text\" pattern=\"{{Pattern || IntPattern}}\" [required]=\"Required\" [placeholder]=\"Placeholder\" [(ngModel)]=\"Model\" [id]=\"GeneratedName\" name=\"{{GeneratedName}}\" autocomplete=\"off\" (inputChange)=\"changed($event);\" (inputFocus)=\"focused($event);\" (inputFinalized)=\"finalized()\"></val-input>\r\n </div>\r\n <!--Se boolean-->\r\n <div class=\"m-t-5\" *ngIf=\"Type == 'boolean'\">\r\n <input #validationControl=\"ngModel\" [readonly]=\"Readonly\" type=\"checkbox\" class=\"app-pointer\" [(ngModel)]=\"Model\" id=\"{{GeneratedName}}\" name=\"{{GeneratedName}}\" (ngModelChange)=\"changed(); finalized();\" (click)=\"focused($event);\" />\r\n </div>\r\n <!--Se enum-->\r\n <div *ngIf=\"Type == 'enum'\">\r\n <val-select #validationControl=\"ngModel\" [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\" [forceInvalid]=\"ForcedError\" [noValidate]=\"!Validation\" [Readonly]=\"Readonly\" [submitted]=\"Form?.submitted\" [placeHolderValue]=\"''\" [placeholder]=\"Required ? ('Select' | localize : lc) + '...' : Placeholder\" [required]=\"Required\" [(ngModel)]=\"Model\" (inputChange)=\"changed($event);\" (inputFocus)=\"focused($event);\" (inputFinalized)=\"finalized()\" [id]=\"GeneratedName\" name=\"{{GeneratedName}}\">\r\n <option *ngFor=\"let val of BoundSource\" [value]=\"val.id\">{{val.description}}</option>\r\n </val-select>\r\n </div>\r\n <!--Se autocomplete-->\r\n <div *ngIf=\"Type == 'autocomplete'\">\r\n <val-autocomplete #validationControl=\"ngModel\" [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\" [forceInvalid]=\"ForcedError\" [noValidate]=\"!Validation\" [Readonly]=\"Readonly\" [submitted]=\"Form?.submitted\" [required]=\"Required\" [placeholder]=\"Required ? ('Select' | localize : lc) + '...' : Placeholder\" [(ngModel)]=\"Model\" [id]=\"GeneratedName\" name=\"{{GeneratedName}}\" [FilteredSource]=\"FilteredBoundSource\" (inputChange)=\"filterSource($event); changed($event);\" (inputFocus)=\"focused($event);\" (inputFinalized)=\"finalized()\"></val-autocomplete>\r\n </div>\r\n <!--Se date time-->\r\n <div *ngIf=\"Type == 'datetime'\">\r\n <val-datetime #validationControl=\"ngModel\" [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\" [forceInvalid]=\"ForcedError\" [FloatingLabel]=\"FloatingLabel\" [noValidate]=\"!Validation\" [Readonly]=\"Readonly\" [submitted]=\"Form?.submitted\" [required]=\"Required\" [useJsDates]=\"useJsDates\" [(ngModel)]=\"Model\" [id]=\"GeneratedName\" name=\"{{GeneratedName}}\" autocomplete=\"off\" (inputChange)=\"changed($event);\" (inputFocus)=\"focused($event);\" (inputFinalized)=\"finalized()\"></val-datetime>\r\n </div>\r\n <!--Se time-->\r\n <div *ngIf=\"Type == 'time'\">\r\n <ngx-mat-timepicker name=\"val-time\" #elementRef #baseInput=\"ngModel\" [(ngModel)]=\"Model\" [disabled]=\"Readonly\"\r\n [showSpinners]=\"false\" [stepHour]=\"2\" [stepMinute]=\"5\" [stepSecond]=\"30\"\r\n [showSeconds]=\"true\" (ngModelChange)=\"changed()\" #validationControl=\"ngModel\">\r\n </ngx-mat-timepicker>\r\n </div>\r\n <!--Se file-->\r\n <div *ngIf=\"Type == 'file'\">\r\n <div class=\"input-group file-upload\">\r\n <input type=\"file\" (change)=\"fileChange()\" #fileInput id=\"{{GeneratedName}}\" class=\"file-upload-btn app-pointer\" [multiple]=\"null\"/>\r\n <input type=\"text\" [class.frm-padding-left-22]=\"AllowDownload && ModelFile.filename && ModelFile.fileb64\" class=\"form-control checking-field\" placeholder=\"{{'Select a file' | localize : lc}}...\" [(ngModel)]=\"ModelFile.filename\" name=\"dsfile\" #validationControl=\"ngModel\" [required]=\"Required\"/>\r\n \r\n <a class=\"fa fa-download app-pointer app-input-icon\" *ngIf=\"AllowDownload && ModelFile.filename && ModelFile.fileb64\" (click)=\"downloadAttachment()\"></a>\r\n <i class=\"fa fa-times delete-file\" (click)=\"fileChange(true)\" *ngIf=\"ModelFile.filename\"></i>\r\n <span class=\"input-group-btn\">\r\n <button class=\"btn btn-primary btn-file-upload\" type=\"button\"><i class=\"fa fa-upload\"></i></button>\r\n </span>\r\n </div>\r\n </div>\r\n</ng-template>", styles: [".frm-padding-left-22{padding-left:22px}.drop-container{position:relative;display:flex;gap:10px;flex-direction:column;justify-content:center;align-items:center;height:200px;padding:20px;border-radius:10px;border:2px dashed #0d45a5;color:#444;cursor:pointer;transition:background .2s ease-in-out,border .2s ease-in-out}.drop-container:hover{background:#eee;border-color:#111}.drop-container:hover .drop-title{color:#222}.drop-title{color:#444;font-size:20px;font-weight:700;text-align:center;transition:color .2s ease-in-out}input[type=file]{width:350px;max-width:100%;color:#444;padding:5px;background:#fff;border-radius:10px;border:1px solid #555}input[type=file]::file-selector-button{margin-right:20px;border:none;background:#084cdf;padding:10px 20px;border-radius:10px;color:#fff;cursor:pointer;transition:background .2s ease-in-out}input[type=file]::file-selector-button:hover{background:#0d45a5}.file-download-btn{border-radius:5px;padding:5px 10px;background-color:#0d45a5}.file-download-btn:hover{background-color:#084cdf}.file-download-btn-text{color:#fff}.file-delete-btn{color:red;position:absolute;right:10px;top:10px}.file-name-container{width:100%;white-space:nowrap;text-overflow:ellipsis;overflow-y:clip;text-align:center}\n"], dependencies: [{ kind: "directive", type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i4.NgSelectOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i4.ɵNgSelectMultipleOption, selector: "option", inputs: ["ngValue", "value"] }, { kind: "directive", type: i4.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: i4.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i4.PatternValidator, selector: "[pattern][formControlName],[pattern][formControl],[pattern][ngModel]", inputs: ["pattern"] }, { kind: "directive", type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i2.NgxMatTimepickerComponent, selector: "ngx-mat-timepicker", inputs: ["disabled", "showSpinners", "stepHour", "stepMinute", "stepSecond", "showSeconds", "disableMinute", "enableMeridian", "defaultTime", "color"], exportAs: ["ngxMatTimepicker"] }, { kind: "component", type: i7.ValidationInputComponent, selector: "val-input", inputs: ["Frozen", "Password", "showWarning", "warningTitle", "warningClass", "value", "Type", "maxlength", "minlength"] }, { kind: "component", type: i8.ValidationSelectComponent, selector: "val-select", inputs: ["emptyFieldValue", "placeHolderValue", "emptyValue", "showValidationSymbol", "label"], outputs: ["onBlur"] }, { kind: "component", type: i9.ValidationDateComponent, selector: "val-date", inputs: ["useJsDates"] }, { kind: "component", type: i10.ValidationCurrencyComponent, selector: "val-currency", inputs: ["CurrencyOptions"] }, { kind: "component", type: i11.ValidationAutocompleteComponent, selector: "val-autocomplete", inputs: ["FilteredSource", "value", "label"], outputs: ["optionChange"] }, { kind: "component", type: i12.ValidationDateTimeComponent, selector: "val-datetime", inputs: ["useJsDates"] }, { kind: "pipe", type: i3.LocalizePipe, name: "localize" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
369
|
-
}
|
|
370
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormAdaptiveComponent, decorators: [{
|
|
371
|
-
type: Component,
|
|
372
|
-
args: [{ selector: "form-adaptive", providers: [{ provide: LocalizationService, useClass: FormAdaptiveComponentLoc }], changeDetection: ChangeDetectionStrategy.OnPush, template: "<!-- Uguale in tutti i componenti --------------------------------------------------------------------------->\r\n<ng-container *ngIf=\"!FormLayout && (!DisplayMode || (DisplayLayout != 'hidden' && DisplayCondition))\">\r\n <ng-container *ngIf=\"DisplayMode && !DisplayModeTemplate\">\r\n <ng-container *ngIf=\"DisplayLayout == 'form'\">{{ EvaluatedModel }}</ng-container>\r\n <div *ngIf=\"DisplayLayout == 'inline'\" class=\"app-inline\">{{ EvaluatedModel }}</div>\r\n </ng-container>\r\n <ng-container *ngIf=\"DisplayMode && DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"DisplayModeTemplate, context: { $implicit: EvaluatedModel }\"></ng-container></ng-container>\r\n <div [hidden]=\"DisplayMode\"><ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container></div>\r\n</ng-container>\r\n\r\n<div *ngIf=\"FormLayout && (!DisplayMode || (DisplayLayout != 'hidden' && DisplayCondition))\" class=\"{{FormGroupClass + (Last ? ' app-margin-bottom-0 app-margin-right-0 ' : '') + (DisplayLayout == 'inline' && DisplayMode ? (' app-inline-block ' + (!Last ? 'app-margin-right-10' : '')) : ' form-group row')}}\">\r\n\r\n <label class=\"col-md-{{(DisplayMode && DisplayLayout == 'inline' ? 'none app-bold app-margin-bottom-0' : LabelColWidth) + (DisplayMode ? ' app-bold' : ' m-t-5') }}\">{{Label}}{{Required && !DisplayMode ? '*' : ''}}{{Label ? \":\" : \"\"}}</label>\r\n <span *ngIf=\"DisplayMode && DisplayLayout == 'inline' && InlineSeparator != ''\">{{InlineSeparator}}</span>\r\n <div class=\"col-md-{{DisplayMode && DisplayLayout == 'inline' ? 'none app-inline-block' : InputColWidth}}\">\r\n\r\n <ng-container *ngIf=\"DisplayMode && !DisplayModeTemplate\">{{ EvaluatedModel }}</ng-container>\r\n <ng-container *ngIf=\"DisplayMode && DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"DisplayModeTemplate, context: { $implicit: EvaluatedModel }\"></ng-container></ng-container>\r\n <div [hidden]=\"DisplayMode\"><ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container></div>\r\n </div>\r\n <div class=\"clearfix\"></div>\r\n</div>\r\n<!----------------------------------------------------------------------------------------------------------->\r\n\r\n<ng-template #controlTemplate>\r\n <div *ngIf=\"!Type\" class=\"app-margin-top-5\">\r\n <em>{{TypeMissingMessage}}</em>\r\n </div>\r\n \r\n <!--Se currency-->\r\n <div *ngIf=\"Type == 'currency'\">\r\n <val-currency #validationControl=\"ngModel\" [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\" [forceInvalid]=\"ForcedError\" [FloatingLabel]=\"FloatingLabel\"\r\n [CurrencyOptions]=\"{ prefix: '', thousands: '.', decimal: ',', precision: Precision, align: Alignment }\" [noValidate]=\"!Validation\"\r\n type=\"text\" [Readonly]=\"Readonly\" [submitted]=\"Form?.submitted\" [required]=\"Required\" [(ngModel)]=\"Model\" [id]=\"GeneratedName\" name=\"{{GeneratedName}}\" autocomplete=\"off\" (inputChange)=\"changed();\" (inputFocus)=\"focused($event);\" (inputFinalized)=\"finalized()\"></val-currency>\r\n </div>\r\n <!--Se data-->\r\n <div *ngIf=\"Type == 'date'\">\r\n <val-date #validationControl=\"ngModel\" [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\" [forceInvalid]=\"ForcedError\" [FloatingLabel]=\"FloatingLabel\" [noValidate]=\"!Validation\" [Readonly]=\"Readonly\" [submitted]=\"Form?.submitted\" [required]=\"Required\" [(ngModel)]=\"Model\" [id]=\"GeneratedName\" [useJsDates]=\"useJsDates\" name=\"{{GeneratedName}}\" autocomplete=\"off\" (inputChange)=\"changed($event);\" (inputFocus)=\"focused($event);\" (inputFinalized)=\"finalized()\"></val-date>\r\n </div>\r\n <!--Se stringa-->\r\n <div *ngIf=\"Type == 'string'\">\r\n <val-input #validationControl=\"ngModel\" [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\" [forceInvalid]=\"ForcedError\" [FloatingLabel]=\"FloatingLabel\" [noValidate]=\"!Validation\" [Readonly]=\"Readonly\" [submitted]=\"Form?.submitted\" type=\"text\" pattern=\"{{Pattern || ''}}\" [required]=\"Required\" [placeholder]=\"Placeholder\" [(ngModel)]=\"Model\" [id]=\"GeneratedName\" name=\"{{GeneratedName}}\" autocomplete=\"off\" (inputChange)=\"changed($event);\" (inputFocus)=\"focused($event);\" (inputFinalized)=\"finalized()\"></val-input>\r\n </div>\r\n <!--Se numero-->\r\n <div *ngIf=\"Type == 'float' || Type == 'number'\">\r\n <val-input #validationControl=\"ngModel\" [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\" [forceInvalid]=\"ForcedError\" [FloatingLabel]=\"FloatingLabel\" [noValidate]=\"!Validation\" [Readonly]=\"Readonly\" [submitted]=\"Form?.submitted\" type=\"text\" pattern=\"{{Pattern || FloatPattern}}\" [required]=\"Required\" [placeholder]=\"Placeholder\" [(ngModel)]=\"Model\" [id]=\"GeneratedName\" name=\"{{GeneratedName}}\" autocomplete=\"off\" (inputChange)=\"changed($event);\" (inputFocus)=\"focused($event);\" (inputFinalized)=\"finalized()\"></val-input>\r\n </div>\r\n <!--Se numero intero-->\r\n <div *ngIf=\"Type == 'int'\">\r\n <val-input #validationControl=\"ngModel\" [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\" [forceInvalid]=\"ForcedError\" [FloatingLabel]=\"FloatingLabel\" [noValidate]=\"!Validation\" [Readonly]=\"Readonly\" [submitted]=\"Form?.submitted\" type=\"text\" pattern=\"{{Pattern || IntPattern}}\" [required]=\"Required\" [placeholder]=\"Placeholder\" [(ngModel)]=\"Model\" [id]=\"GeneratedName\" name=\"{{GeneratedName}}\" autocomplete=\"off\" (inputChange)=\"changed($event);\" (inputFocus)=\"focused($event);\" (inputFinalized)=\"finalized()\"></val-input>\r\n </div>\r\n <!--Se boolean-->\r\n <div class=\"m-t-5\" *ngIf=\"Type == 'boolean'\">\r\n <input #validationControl=\"ngModel\" [readonly]=\"Readonly\" type=\"checkbox\" class=\"app-pointer\" [(ngModel)]=\"Model\" id=\"{{GeneratedName}}\" name=\"{{GeneratedName}}\" (ngModelChange)=\"changed(); finalized();\" (click)=\"focused($event);\" />\r\n </div>\r\n <!--Se enum-->\r\n <div *ngIf=\"Type == 'enum'\">\r\n <val-select #validationControl=\"ngModel\" [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\" [forceInvalid]=\"ForcedError\" [noValidate]=\"!Validation\" [Readonly]=\"Readonly\" [submitted]=\"Form?.submitted\" [placeHolderValue]=\"''\" [placeholder]=\"Required ? ('Select' | localize : lc) + '...' : Placeholder\" [required]=\"Required\" [(ngModel)]=\"Model\" (inputChange)=\"changed($event);\" (inputFocus)=\"focused($event);\" (inputFinalized)=\"finalized()\" [id]=\"GeneratedName\" name=\"{{GeneratedName}}\">\r\n <option *ngFor=\"let val of BoundSource\" [value]=\"val.id\">{{val.description}}</option>\r\n </val-select>\r\n </div>\r\n <!--Se autocomplete-->\r\n <div *ngIf=\"Type == 'autocomplete'\">\r\n <val-autocomplete #validationControl=\"ngModel\" [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\" [forceInvalid]=\"ForcedError\" [noValidate]=\"!Validation\" [Readonly]=\"Readonly\" [submitted]=\"Form?.submitted\" [required]=\"Required\" [placeholder]=\"Required ? ('Select' | localize : lc) + '...' : Placeholder\" [(ngModel)]=\"Model\" [id]=\"GeneratedName\" name=\"{{GeneratedName}}\" [FilteredSource]=\"FilteredBoundSource\" (inputChange)=\"filterSource($event); changed($event);\" (inputFocus)=\"focused($event);\" (inputFinalized)=\"finalized()\"></val-autocomplete>\r\n </div>\r\n <!--Se date time-->\r\n <div *ngIf=\"Type == 'datetime'\">\r\n <val-datetime #validationControl=\"ngModel\" [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\" [forceInvalid]=\"ForcedError\" [FloatingLabel]=\"FloatingLabel\" [noValidate]=\"!Validation\" [Readonly]=\"Readonly\" [submitted]=\"Form?.submitted\" [required]=\"Required\" [useJsDates]=\"useJsDates\" [(ngModel)]=\"Model\" [id]=\"GeneratedName\" name=\"{{GeneratedName}}\" autocomplete=\"off\" (inputChange)=\"changed($event);\" (inputFocus)=\"focused($event);\" (inputFinalized)=\"finalized()\"></val-datetime>\r\n </div>\r\n <!--Se time-->\r\n <div *ngIf=\"Type == 'time'\">\r\n <ngx-mat-timepicker name=\"val-time\" #elementRef #baseInput=\"ngModel\" [(ngModel)]=\"Model\" [disabled]=\"Readonly\"\r\n [showSpinners]=\"false\" [stepHour]=\"2\" [stepMinute]=\"5\" [stepSecond]=\"30\"\r\n [showSeconds]=\"true\" (ngModelChange)=\"changed()\" #validationControl=\"ngModel\">\r\n </ngx-mat-timepicker>\r\n </div>\r\n <!--Se file-->\r\n <div *ngIf=\"Type == 'file'\">\r\n <div class=\"input-group file-upload\">\r\n <input type=\"file\" (change)=\"fileChange()\" #fileInput id=\"{{GeneratedName}}\" class=\"file-upload-btn app-pointer\" [multiple]=\"null\"/>\r\n <input type=\"text\" [class.frm-padding-left-22]=\"AllowDownload && ModelFile.filename && ModelFile.fileb64\" class=\"form-control checking-field\" placeholder=\"{{'Select a file' | localize : lc}}...\" [(ngModel)]=\"ModelFile.filename\" name=\"dsfile\" #validationControl=\"ngModel\" [required]=\"Required\"/>\r\n \r\n <a class=\"fa fa-download app-pointer app-input-icon\" *ngIf=\"AllowDownload && ModelFile.filename && ModelFile.fileb64\" (click)=\"downloadAttachment()\"></a>\r\n <i class=\"fa fa-times delete-file\" (click)=\"fileChange(true)\" *ngIf=\"ModelFile.filename\"></i>\r\n <span class=\"input-group-btn\">\r\n <button class=\"btn btn-primary btn-file-upload\" type=\"button\"><i class=\"fa fa-upload\"></i></button>\r\n </span>\r\n </div>\r\n </div>\r\n</ng-template>", styles: [".frm-padding-left-22{padding-left:22px}.drop-container{position:relative;display:flex;gap:10px;flex-direction:column;justify-content:center;align-items:center;height:200px;padding:20px;border-radius:10px;border:2px dashed #0d45a5;color:#444;cursor:pointer;transition:background .2s ease-in-out,border .2s ease-in-out}.drop-container:hover{background:#eee;border-color:#111}.drop-container:hover .drop-title{color:#222}.drop-title{color:#444;font-size:20px;font-weight:700;text-align:center;transition:color .2s ease-in-out}input[type=file]{width:350px;max-width:100%;color:#444;padding:5px;background:#fff;border-radius:10px;border:1px solid #555}input[type=file]::file-selector-button{margin-right:20px;border:none;background:#084cdf;padding:10px 20px;border-radius:10px;color:#fff;cursor:pointer;transition:background .2s ease-in-out}input[type=file]::file-selector-button:hover{background:#0d45a5}.file-download-btn{border-radius:5px;padding:5px 10px;background-color:#0d45a5}.file-download-btn:hover{background-color:#084cdf}.file-download-btn-text{color:#fff}.file-delete-btn{color:red;position:absolute;right:10px;top:10px}.file-name-container{width:100%;white-space:nowrap;text-overflow:ellipsis;overflow-y:clip;text-align:center}\n"] }]
|
|
373
|
-
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.UtilityService }, { type: i1.DateService }, { type: i2.NgxMatDateAdapter }, { type: i3.LocalizationService }, { type: i4.NgControl, decorators: [{
|
|
374
|
-
type: Optional
|
|
375
|
-
}, {
|
|
376
|
-
type: Self
|
|
377
|
-
}] }, { type: Array, decorators: [{
|
|
378
|
-
type: Optional
|
|
379
|
-
}, {
|
|
380
|
-
type: Inject,
|
|
381
|
-
args: [NG_VALIDATORS]
|
|
382
|
-
}] }, { type: i5.AccessControlService }, { type: i5.ComponentContext, decorators: [{
|
|
383
|
-
type: Optional
|
|
384
|
-
}] }, { type: undefined, decorators: [{
|
|
385
|
-
type: Optional
|
|
386
|
-
}, {
|
|
387
|
-
type: Inject,
|
|
388
|
-
args: [ACO_CUSTOMKEY]
|
|
389
|
-
}] }, { type: undefined, decorators: [{
|
|
390
|
-
type: Optional
|
|
391
|
-
}, {
|
|
392
|
-
type: Inject,
|
|
393
|
-
args: [FAV_DEBUG_MODE]
|
|
394
|
-
}] }], propDecorators: { Type: [{
|
|
395
|
-
type: Input
|
|
396
|
-
}], TypeMissingMessage: [{
|
|
397
|
-
type: Input
|
|
398
|
-
}], Pattern: [{
|
|
399
|
-
type: Input
|
|
400
|
-
}], AdjustNumber: [{
|
|
401
|
-
type: Input
|
|
402
|
-
}], inputEl: [{
|
|
403
|
-
type: ViewChild,
|
|
404
|
-
args: ["fileInput", { static: false }]
|
|
405
|
-
}], AllowDownload: [{
|
|
406
|
-
type: Input
|
|
407
|
-
}], Precision: [{
|
|
408
|
-
type: Input
|
|
409
|
-
}], Alignment: [{
|
|
410
|
-
type: Input
|
|
411
|
-
}], SearchFunction: [{
|
|
412
|
-
type: Input
|
|
413
|
-
}], MinChars: [{
|
|
414
|
-
type: Input
|
|
415
|
-
}], CaseSensitive: [{
|
|
416
|
-
type: Input
|
|
417
|
-
}], Options: [{
|
|
418
|
-
type: Input
|
|
419
|
-
}] } });
|
|
420
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-adaptive.component.js","sourceRoot":"","sources":["../../../../../../projects/forms-and-validations/src/lib/forms/form-adaptive/form-adaptive.component.ts","../../../../../../projects/forms-and-validations/src/lib/forms/form-adaptive/form-adaptive.component.html"],"names":[],"mappings":"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","sourcesContent":["// Angular\r\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, Host, Inject, Input, Optional, Self, SimpleChanges, ViewChild } from \"@angular/core\";\r\nimport { AbstractControl, ControlValueAccessor, NG_VALIDATORS, NgControl, PatternValidator, ValidationErrors, ValidatorFn } from \"@angular/forms\";\r\n\r\n// ES / Configurazioni\r\nimport { LocalizationService } from \"@esfaenza/localizations\";\r\nimport { DateService, UtilityService } from \"@esfaenza/extensions\";\r\nimport { AccessControlService, ComponentContext } from '@esfaenza/access-control';\r\nimport { NgxMatDateAdapter } from \"@ngxmc/datetime-picker\";\r\n\r\n// Applicazione\r\nimport { BaseFormControl } from \"../base-form-control\";\r\nimport { FormAdaptiveComponentLoc } from \"./form-adaptive.component.loc\";\r\n\r\n// Modelli\r\nimport { ACO_CUSTOMKEY, FAV_DEBUG_MODE } from '../../tokens';\r\nimport { AppFile } from \"../../models/AppFile\";\r\n\r\nimport { Observable } from \"rxjs\";\r\nimport { ChangeEvent } from \"../../models/ChangeEvent\";\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/** Opzioni generiche disponibili */\r\nexport type AvailableOptions = 'JsDates' | 'CaseSensitive' | 'MinChars' | 'SearchFunction' | 'Alignment' | 'Precision' | 'AllowDownload' | 'AdjustNumber' | 'Pattern';\r\n\r\n/** Componente in grado di assumere la forma di un qualsiasi altro componente form in base al tipo specificato. Utile  per la creazione di form dinamici */\r\n@Component({\r\n    selector: \"form-adaptive\",\r\n    providers: [{ provide: LocalizationService, useClass: FormAdaptiveComponentLoc }],\r\n    templateUrl: \"form-adaptive.component.html\",\r\n    styleUrls: [\"../form-file/form-file.component.css\"],\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class FormAdaptiveComponent extends BaseFormControl implements ControlValueAccessor {\r\n\r\n    /** Tipologia che decide che componente mostrare */\r\n    @Input() Type: 'string' | 'float' | 'date' | 'number' | 'int' | 'boolean' | 'enum' | 'autocomplete' | 'datetime' | 'time' | 'file' | 'currency';\r\n\r\n    /** Messaggio per quando si binda un form-adaptive senza tipo */\r\n    @Input() TypeMissingMessage: string;\r\n\r\n    /** Pattern di validazione */\r\n    @Input() Pattern: string;\r\n\r\n    /** Indica di aggiustare in uscita i number in modo che siano parsabili dal javascript */\r\n    @Input() AdjustNumber: boolean = true;\r\n\r\n    /** Riferimento all'elemento input di tipo file qualora il **Type** di questo componente fosse **file** */\r\n    @ViewChild(\"fileInput\", { static: false }) inputEl: ElementRef;\r\n\r\n    /** Permette di scaricare l'eventuale file presente qualora il **Type** di questo componente fosse **file** */\r\n    @Input() AllowDownload: boolean = true;\r\n\r\n    /** Modello typescript di bind dei file */\r\n    ModelFile: AppFile;\r\n\r\n    /** Utilizzata nel form-adapter per specificare la precisione degli input currencymap (Type: currency) */\r\n    @Input() Precision: number = 2;\r\n\r\n    /** Allineamento della currency mask */\r\n    @Input() Alignment: 'left' | 'right' = 'right';\r\n\r\n    /** Funzione di ricerca che verrà chiamata dal componente */\r\n    @Input() SearchFunction: (search: string, byid: boolean) => Observable<{ id: string, description: string }[]> = null;\r\n\r\n    /** Numero minimo di caratteri con cui cercare */\r\n    @Input() MinChars: number = 3;\r\n\r\n    /** Indica se i controlli devono essere effettuati tenendo conto del Case o meno. Vale solo qualora la **Source** fosse fornita */\r\n    @Input() CaseSensitive: boolean = false;\r\n\r\n    /** Opzioni specifiche per il componente che si va a visualizzare. Es. per i tipi date: { JsDates: true } */\r\n    @Input() Options: { [id in AvailableOptions]?: any } = {};\r\n\r\n    /** Variabile interna che gestisce se effettuare il riallineamento dei dati o meno */\r\n    private alignValues: boolean = false;\r\n\r\n    /**\r\n     * Indica se ignorare il prossimo evento writeValue che normalmente dovrebbe richiedere la nuova source. Serve per quando l'utente seleziona un elemento:\r\n     * Subito dopo partirebbe un altro evento modelChange che ricaricherebbe nuovamente la source\r\n     */\r\n    private ignoreNextWriteValue: boolean = false;\r\n\r\n    /** Cache della sorgente originale POST binding, in modo da poter fare filtri in locale qualora la **SearchFunction** non fosse definita e la **Source** fosse assegnata */\r\n    public FilteredBoundSource: { id: string, description: string }[] = [];\r\n\r\n    /** Solo per gli input di tipo \"date\". Capisce che modalità usare per il validation-date sottostante */\r\n    public useJsDates: boolean = null;\r\n\r\n    /** Variabile interna che salva il valore degli input float prima dell'aggiustamento */\r\n    private floatValuePreAdjustmente: string;\r\n\r\n    /** @ignore Costruttore  */\r\n    constructor(cdr: ChangeDetectorRef, private utiExts: UtilityService, private datesExts: DateService, private dateAdapter: NgxMatDateAdapter<any>, public lc: LocalizationService, @Optional() @Self() ngControl: NgControl, @Optional() @Inject(NG_VALIDATORS) _validators: Array<any>, ac: AccessControlService, @Optional() AppContext: ComponentContext, @Optional() @Inject(ACO_CUSTOMKEY) ACO_CUSTOMKEY: string, @Optional() @Inject(FAV_DEBUG_MODE) FAV_DEBUG_MODE: boolean) {\r\n        super(cdr, ngControl, _validators, ac, AppContext, ACO_CUSTOMKEY, FAV_DEBUG_MODE);\r\n\r\n        this.ModelFile = new AppFile();\r\n        this.UseUserValidators = false;\r\n    }\r\n\r\n    public IntPattern = '^[0-9]\\\\d*$';\r\n    public FloatPattern = '^([0-9]*[,])?[0-9]+$';\r\n\r\n    /**\r\n     * Nvl con un minimo di senso\r\n     * @param value Valore base\r\n     * @param ifnod Valore da usare se **value** è nullo o undefined\r\n     * @returns Il valore preso fra i due disponibili\r\n     */\r\n    private nvl<T>(value: T, ifnod: T): T {\r\n        return value == null || value == undefined ? ifnod : value;\r\n    }\r\n\r\n    ngOnInit(): void {\r\n\r\n        // Assegnazione Opzioni da oggetto\r\n        if(this.Options){\r\n            this.useJsDates = this.nvl(this.Options?.JsDates, this.useJsDates);;\r\n            this.CaseSensitive = this.nvl(this.Options?.CaseSensitive, this.CaseSensitive);\r\n            this.MinChars = this.nvl(this.Options?.MinChars, this.MinChars);\r\n            this.SearchFunction = this.nvl(this.Options?.SearchFunction, this.SearchFunction);\r\n            this.Alignment = this.nvl(this.Options?.Alignment, this.Alignment);\r\n            this.Precision = this.nvl(this.Options?.Precision, this.Precision);\r\n            this.AllowDownload = this.nvl(this.Options?.AllowDownload, this.AllowDownload);\r\n            this.AdjustNumber = this.nvl(this.Options?.AdjustNumber, this.AdjustNumber);\r\n            this.Pattern = this.nvl(this.Options?.Pattern, this.Pattern);\r\n        }\r\n\r\n        if (this.ngControl) {\r\n            // Esclusi i validatori a componenti\r\n           let validators = [...(this._validators || [])].filter(v => !v.ngOnInit);\r\n\r\n           var pv = new PatternValidator();\r\n           switch (this.Type) {\r\n               case 'int':\r\n                   pv.pattern = this.Pattern || this.IntPattern;\r\n                   validators.push(pv);\r\n                   break;\r\n               case 'float':\r\n               case 'number':\r\n                   pv.pattern = this.Pattern || this.FloatPattern;\r\n                   validators.push(pv);\r\n                   break;\r\n               case 'string':\r\n                   if (this.Pattern) {\r\n                       pv.pattern = this.Pattern;\r\n                       validators.push(pv);\r\n                   }\r\n                   break;\r\n           }\r\n           // A quanto pare la creazione del validatore rompe il caso d'uso classico...\r\n           (<any>pv)._validator = this.customPatternValidator(pv.pattern);\r\n           (<any>this.ngControl)._setValidators(validators);\r\n           this.ngControl.control.setValidators(validators);\r\n           this.ngControl.control.updateValueAndValidity();\r\n        }\r\n\r\n        super.ngOnInit();\r\n    }\r\n\r\n    /**\r\n     * Validator that requires the control's value to match a regex pattern.\r\n     * See `Validators.pattern` for additional information.\r\n     */\r\n    customPatternValidator(pattern: string | RegExp): ValidatorFn {\r\n        if (!pattern) return (_: AbstractControl) => null;\r\n        let regex: RegExp;\r\n        let regexStr: string;\r\n\r\n        if (typeof pattern === 'string') {\r\n            regexStr = '';\r\n            if (pattern.charAt(0) !== '^') regexStr += '^';\r\n            regexStr += pattern;\r\n            if (pattern.charAt(pattern.length - 1) !== '$') regexStr += '$';\r\n            regex = new RegExp(regexStr);\r\n        }\r\n\r\n        return (control: AbstractControl): ValidationErrors | null => {\r\n            if (!control.value) { return null; }\r\n\r\n            // Caricamento avvenuto adesso da modello\r\n            if(control.value && !this.floatValuePreAdjustmente)\r\n                this.floatValuePreAdjustmente = control.value.toString().replace(\".\", \",\");\r\n\r\n            return regex.test(this.floatValuePreAdjustmente) ? null : { 'pattern': { 'requiredPattern': regexStr, 'actualValue': this.floatValuePreAdjustmente } };\r\n        };\r\n    }\r\n\r\n    /** @ignore */\r\n    public async ngOnChanges(changes: SimpleChanges) {\r\n        const newSource = changes[\"Source\"];\r\n        const newType = changes[\"Type\"];\r\n\r\n        if (newSource) {\r\n            this.tryBindSourceDisplay();\r\n\r\n            // Prima assegnazione se cambia la source sotto (quindi se viene bindata direttamente da HTML)\r\n            if (this.Type == \"autocomplete\" && (this.Model?.length || 0) >= this.MinChars && !this.SearchFunction)\r\n                this.FilteredBoundSource = this.BoundSource;\r\n            else\r\n                this.FilteredBoundSource = [];\r\n\r\n            this.cdr.markForCheck();\r\n        }\r\n\r\n        if (newType && this.Model)\r\n            this.writeValue(this.Model);\r\n    }\r\n\r\n    /** @ignore */\r\n    writeValue(obj: any): void {\r\n        this.alignValues = false;\r\n\r\n        this.EvaluatedModel = obj?.toString() || \"\";\r\n\r\n        if (!this.Type) {\r\n            this.Type = \"string\";\r\n            this.EvaluatedModel = obj;\r\n        }\r\n\r\n        if (this.Type == \"date\" || this.Type == \"datetime\") {\r\n            this.useJsDates = this.useJsDates == null ? Object.prototype.toString.call(obj) === \"[object Date]\" : this.useJsDates;\r\n            if (this.Type == \"date\")\r\n                this.EvaluatedModel = this.datesExts.getFormatted(obj, true, false);\r\n            if (this.Type == \"datetime\")\r\n                this.EvaluatedModel = this.datesExts.getFormatted(obj, false, true);\r\n        }\r\n        else if ((this.Type == \"float\" || this.Type == \"number\") && obj) {\r\n            obj = obj.toString().replace(\".\", \",\");\r\n            this.EvaluatedModel = obj;\r\n        }\r\n        // Per sicurezza riallineo i valori\r\n        else if (this.Type == \"boolean\") {\r\n            obj = obj ? (obj === true || obj.toLowerCase() == \"true\") : false;\r\n            this.alignValues = true;\r\n            this.EvaluatedModel = this.lc.loc(obj ? 'Sì' : 'No');\r\n        }\r\n        else if (this.Type == \"time\") {\r\n            const [hours, minutes, seconds] = (obj || \"00:00:00\").split(\":\");\r\n            obj = dayjs().hour(parseInt(hours ?? 0)).minute(parseInt(minutes ?? 0)).second(parseInt(seconds ?? 0));\r\n            this.EvaluatedModel = `${hours || '00'}:${minutes || '00'}:${seconds || '00'}`;\r\n        }\r\n        else if (this.Type == \"file\") {\r\n            obj = this.ModelFile;\r\n            this.EvaluatedModel = this.ModelFile.filename;\r\n        }\r\n        else if (this.Type == \"autocomplete\") {\r\n            if (this.SearchFunction) {\r\n                this.SearchFunction(obj, true).subscribe(t => {\r\n                    this.Source = t;\r\n                    this.tryBindSourceDisplay();\r\n                    setTimeout(() => { this.finalizeValue(obj); });\r\n                });\r\n                return;\r\n            }\r\n            else\r\n                this.finalizeValue(obj);\r\n        }\r\n\r\n        if (this.BoundSource && this.BoundSource.length > 0)\r\n            this.EvaluatedModel = this.BoundSource.find(t => t.id == obj)?.description;\r\n\r\n        super.writeValue(obj);\r\n\r\n        if (this.alignValues) {\r\n            this.changed();\r\n            this.cdr.markForCheck();\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Dato un valore verifica se può restituire le informazioni trovate in **Source** con id uguale a **value** o se deve restituire il valore in se\r\n     * \r\n     * @param {any} value Valore scritto nell'input di testo\r\n     */\r\n    private finalizeValue(value: any) {\r\n        var val = this.Source.find(t => t.id == value);\r\n        this.propagateChange(val ? val.id : value);\r\n        this.Model = val ? val.description : value;\r\n        this.EvaluatedModel = this.Model;\r\n    }\r\n\r\n    /**\r\n     * Evento di filtro della sorgente dati in base all'input utente\r\n     * \r\n     * @param {string} event Input utente\r\n     */\r\n    public filterSource(event?: ChangeEvent) {\r\n        if (this.ignoreNextWriteValue) {\r\n            this.ignoreNextWriteValue = false;\r\n            return;\r\n        }\r\n\r\n        // Quando filtro la source, se non devo ignorare l'evento devo comunque assicurarmi di impostare il valore selezionato a null\r\n        super.changed(null);\r\n\r\n        if (!event && this.MinChars == 0 && !this.SearchFunction) {\r\n            this.FilteredBoundSource = this.BoundSource;\r\n            return;\r\n        }\r\n\r\n        if (!event || event.value.length < this.MinChars) {\r\n            this.FilteredBoundSource = [];\r\n            return;\r\n        }\r\n\r\n        if (!this.SearchFunction && (!this.Source || this.Source.length == 0))\r\n            throw \"Impossibile filtrare gli elementi senza una funzione di ricerca che restituisca una lista di { id: string, description: string }\";\r\n\r\n        if (this.SearchFunction) {\r\n            this.throttla(\"filtersource\", () => {\r\n                this.SearchFunction(event.value, false).subscribe(t => {\r\n                    this.Source = t;\r\n                    this.tryBindSourceDisplay();\r\n                    // In questo caso è già filtrata dalla SearchFunction\r\n                    this.FilteredBoundSource = this.BoundSource;\r\n                    this.removeFilteredSourceOnDescriptionSelection();\r\n                    this.cdr.markForCheck();\r\n                });\r\n            }, 400);\r\n        }\r\n        else {\r\n            this.throttla(\"filtersource\", () => {\r\n                // In questo caso devo filtrare io in memoria\r\n                this.FilteredBoundSource = this.BoundSource.filter(t => (this.CaseSensitive && t.description.includes(event.value)) || (!this.CaseSensitive && t.description.toLowerCase().includes(event.value.toLowerCase())));\r\n                this.removeFilteredSourceOnDescriptionSelection();\r\n                this.cdr.markForCheck();\r\n            }, 100);\r\n        }\r\n    }\r\n\r\n    /** @ignore */\r\n    private removeFilteredSourceOnDescriptionSelection() {\r\n        if (this.FilteredBoundSource.length == 1 && (this.FilteredBoundSource[0].description === this.Model)) {\r\n            this.Model = this.BoundSource[0].id;\r\n            this.EvaluatedModel = this.BoundSource[0].description;\r\n            this.FilteredBoundSource = [];\r\n        }\r\n    }\r\n\r\n    /** Metodo richiamato quando viene modificato il modello del campo di input */\r\n    changed(event?: ChangeEvent) {\r\n        var toEmit = this.getModelToEmit();\r\n\r\n        if (this.Type == \"autocomplete\")\r\n            this.ignoreNextWriteValue = true;\r\n\r\n        if (this.EmitPendingChanges)\r\n            super.changed(toEmit, false, false, event?.internal);\r\n    }\r\n\r\n    /** @ignore */\r\n    finalized() {\r\n        super.finalized();\r\n    }\r\n\r\n    /** Metodo richiamato quando viene selezionato il campo col mouse */\r\n    focused(event: any) {\r\n        super.focused(event);\r\n    }\r\n\r\n    /** Effettua gli aggiustamenti dati del caso ed emette il modello corretto */\r\n    private getModelToEmit() {\r\n        var toEmit = this.Model ?\r\n            (this.Type == \"time\" || this.useJsDates ?\r\n                this.dateAdapter.clone(this.datesExts.getDateConvertion(this.Model))\r\n                : JSON.parse(JSON.stringify(this.Model)))\r\n            : null;\r\n\r\n        if ((this.Type == \"float\" || this.Type == \"number\") && toEmit) {\r\n            if (this.AdjustNumber) {\r\n                this.floatValuePreAdjustmente = toEmit;\r\n                toEmit = toEmit.replace(\".\", \"\").replace(\",\", \".\");\r\n            }\r\n            this.EvaluatedModel = toEmit;\r\n        }\r\n        else if (this.Type == \"boolean\") {\r\n            toEmit = toEmit ? true : false;\r\n            this.EvaluatedModel = this.lc.loc(toEmit ? 'Yes' : 'No');;\r\n        }\r\n        else if (this.Type == \"time\") {\r\n            toEmit = toEmit.format(\"HH:mm:ss\");\r\n            this.EvaluatedModel = toEmit;\r\n        }\r\n        else if ((this.Type == \"date\" || this.Type == \"datetime\") && this.useJsDates) {\r\n            toEmit = toEmit.toDate();\r\n            this.EvaluatedModel = this.datesExts.getFormatted(this.Model, this.Type == \"date\", this.Type == \"datetime\");\r\n        }\r\n\r\n        return toEmit;\r\n    }\r\n\r\n    /**\r\n     * Helper per gestire la modifica del file attualmente bindato. Ovviamente funziona solo qualora il **Type** fosse **file**\r\n     * \r\n     * @param {boolean} clear Indica se bisogna svuotare l'input o meno \r\n     */\r\n    fileChange(clear: boolean = false) {\r\n        let files: File[] = [];\r\n        let model = (<AppFile>this.Model);\r\n        let ne: HTMLInputElement = this.inputEl.nativeElement;\r\n\r\n        if (clear) {\r\n            model.filename = \"\";\r\n            ne.value = \"\";\r\n        }\r\n        else {\r\n            for (let i = 0; i < ne.files.length; i++)\r\n                files.push(ne.files.item(i));\r\n\r\n            if (ne.files.length == 1)\r\n                model.filename = ne.files[0].name;\r\n            if (ne.files.length > 1)\r\n                model.filename = ne.files.length + \" \" + this.lc.loc(\"Files Selected\");\r\n            model.nativefiles = files;\r\n            model.fileb64 = null;\r\n        }\r\n        this.changed();\r\n    }\r\n\r\n    /** Permette di scaricare il file collegato all'evetnuale file input rappresentato da questo componente */\r\n    downloadAttachment() {\r\n        let model = (<AppFile>this.Model);\r\n        this.utiExts.saveFile(model.fileb64, model.filename);\r\n    }\r\n\r\n    /** @ignore */\r\n    onNotNullValueSet(): void { }\r\n\r\n    //******************** Funzione di throttling per non spammare richieste in caso di animazioni attivate\r\n    //TODO: spostarla in un metodo di utilità (esfaenza/extensions)\r\n    /** @ignore */\r\n    private executionTimers: { [index: string]: any } = {};\r\n    /** @ignore */\r\n    private throttla(id: string, func: Function, throttleTime: number): void {\r\n        //Se ho la funzione che vuole eseguire ripulisco quel timeout\r\n        if (this.executionTimers[id])\r\n            clearTimeout(this.executionTimers[id]);\r\n\r\n        //Ricreo il timeout per eseguire quella funzione dopo throttleTime millisecondi\r\n        this.executionTimers[id] = setTimeout(() => { func(); this.executionTimers[id] = null; }, throttleTime);\r\n    }\r\n    //*************************\r\n}","<!-- Uguale in tutti i componenti --------------------------------------------------------------------------->\r\n<ng-container *ngIf=\"!FormLayout && (!DisplayMode || (DisplayLayout != 'hidden' && DisplayCondition))\">\r\n    <ng-container *ngIf=\"DisplayMode && !DisplayModeTemplate\">\r\n        <ng-container *ngIf=\"DisplayLayout == 'form'\">{{ EvaluatedModel }}</ng-container>\r\n        <div *ngIf=\"DisplayLayout == 'inline'\" class=\"app-inline\">{{ EvaluatedModel }}</div>\r\n    </ng-container>\r\n    <ng-container *ngIf=\"DisplayMode && DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"DisplayModeTemplate, context: { $implicit: EvaluatedModel }\"></ng-container></ng-container>\r\n    <div [hidden]=\"DisplayMode\"><ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container></div>\r\n</ng-container>\r\n\r\n<div *ngIf=\"FormLayout && (!DisplayMode || (DisplayLayout != 'hidden' && DisplayCondition))\" class=\"{{FormGroupClass + (Last ? ' app-margin-bottom-0 app-margin-right-0 ' : '') + (DisplayLayout == 'inline' && DisplayMode ? (' app-inline-block ' + (!Last ? 'app-margin-right-10' : '')) : ' form-group row')}}\">\r\n\r\n    <label class=\"col-md-{{(DisplayMode && DisplayLayout == 'inline' ? 'none app-bold app-margin-bottom-0' : LabelColWidth) + (DisplayMode ? ' app-bold' : ' m-t-5') }}\">{{Label}}{{Required && !DisplayMode ? '*' : ''}}{{Label ? \":\" : \"\"}}</label>\r\n    <span *ngIf=\"DisplayMode && DisplayLayout == 'inline' && InlineSeparator != ''\">{{InlineSeparator}}</span>\r\n    <div class=\"col-md-{{DisplayMode && DisplayLayout == 'inline' ? 'none app-inline-block' : InputColWidth}}\">\r\n\r\n        <ng-container *ngIf=\"DisplayMode && !DisplayModeTemplate\">{{ EvaluatedModel }}</ng-container>\r\n        <ng-container *ngIf=\"DisplayMode && DisplayModeTemplate\"><ng-container *ngTemplateOutlet=\"DisplayModeTemplate, context: { $implicit: EvaluatedModel }\"></ng-container></ng-container>\r\n        <div [hidden]=\"DisplayMode\"><ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container></div>\r\n    </div>\r\n    <div class=\"clearfix\"></div>\r\n</div>\r\n<!----------------------------------------------------------------------------------------------------------->\r\n\r\n<ng-template #controlTemplate>\r\n    <div *ngIf=\"!Type\" class=\"app-margin-top-5\">\r\n        <em>{{TypeMissingMessage}}</em>\r\n    </div>\r\n   \r\n     <!--Se currency-->\r\n     <div *ngIf=\"Type == 'currency'\">\r\n        <val-currency #validationControl=\"ngModel\" [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\" [forceInvalid]=\"ForcedError\" [FloatingLabel]=\"FloatingLabel\"\r\n        [CurrencyOptions]=\"{ prefix: '', thousands: '.', decimal: ',', precision: Precision, align: Alignment }\" [noValidate]=\"!Validation\"\r\n        type=\"text\" [Readonly]=\"Readonly\" [submitted]=\"Form?.submitted\" [required]=\"Required\" [(ngModel)]=\"Model\" [id]=\"GeneratedName\" name=\"{{GeneratedName}}\" autocomplete=\"off\" (inputChange)=\"changed();\" (inputFocus)=\"focused($event);\" (inputFinalized)=\"finalized()\"></val-currency>\r\n    </div>\r\n    <!--Se data-->\r\n    <div *ngIf=\"Type == 'date'\">\r\n        <val-date #validationControl=\"ngModel\" [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\" [forceInvalid]=\"ForcedError\" [FloatingLabel]=\"FloatingLabel\" [noValidate]=\"!Validation\" [Readonly]=\"Readonly\" [submitted]=\"Form?.submitted\" [required]=\"Required\" [(ngModel)]=\"Model\" [id]=\"GeneratedName\" [useJsDates]=\"useJsDates\" name=\"{{GeneratedName}}\" autocomplete=\"off\" (inputChange)=\"changed($event);\" (inputFocus)=\"focused($event);\" (inputFinalized)=\"finalized()\"></val-date>\r\n    </div>\r\n    <!--Se stringa-->\r\n    <div *ngIf=\"Type == 'string'\">\r\n        <val-input #validationControl=\"ngModel\" [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\" [forceInvalid]=\"ForcedError\" [FloatingLabel]=\"FloatingLabel\" [noValidate]=\"!Validation\" [Readonly]=\"Readonly\" [submitted]=\"Form?.submitted\" type=\"text\" pattern=\"{{Pattern || ''}}\" [required]=\"Required\" [placeholder]=\"Placeholder\" [(ngModel)]=\"Model\" [id]=\"GeneratedName\" name=\"{{GeneratedName}}\" autocomplete=\"off\" (inputChange)=\"changed($event);\" (inputFocus)=\"focused($event);\" (inputFinalized)=\"finalized()\"></val-input>\r\n    </div>\r\n    <!--Se numero-->\r\n    <div *ngIf=\"Type == 'float' || Type == 'number'\">\r\n        <val-input #validationControl=\"ngModel\" [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\" [forceInvalid]=\"ForcedError\" [FloatingLabel]=\"FloatingLabel\" [noValidate]=\"!Validation\" [Readonly]=\"Readonly\" [submitted]=\"Form?.submitted\" type=\"text\" pattern=\"{{Pattern || FloatPattern}}\" [required]=\"Required\" [placeholder]=\"Placeholder\" [(ngModel)]=\"Model\" [id]=\"GeneratedName\" name=\"{{GeneratedName}}\" autocomplete=\"off\" (inputChange)=\"changed($event);\" (inputFocus)=\"focused($event);\" (inputFinalized)=\"finalized()\"></val-input>\r\n    </div>\r\n    <!--Se numero intero-->\r\n    <div *ngIf=\"Type == 'int'\">\r\n        <val-input #validationControl=\"ngModel\" [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\" [forceInvalid]=\"ForcedError\" [FloatingLabel]=\"FloatingLabel\" [noValidate]=\"!Validation\" [Readonly]=\"Readonly\" [submitted]=\"Form?.submitted\" type=\"text\" pattern=\"{{Pattern || IntPattern}}\" [required]=\"Required\" [placeholder]=\"Placeholder\" [(ngModel)]=\"Model\" [id]=\"GeneratedName\" name=\"{{GeneratedName}}\" autocomplete=\"off\" (inputChange)=\"changed($event);\" (inputFocus)=\"focused($event);\" (inputFinalized)=\"finalized()\"></val-input>\r\n    </div>\r\n    <!--Se boolean-->\r\n    <div class=\"m-t-5\" *ngIf=\"Type == 'boolean'\">\r\n        <input #validationControl=\"ngModel\" [readonly]=\"Readonly\" type=\"checkbox\" class=\"app-pointer\" [(ngModel)]=\"Model\" id=\"{{GeneratedName}}\" name=\"{{GeneratedName}}\" (ngModelChange)=\"changed(); finalized();\" (click)=\"focused($event);\" />\r\n    </div>\r\n    <!--Se enum-->\r\n    <div *ngIf=\"Type == 'enum'\">\r\n        <val-select #validationControl=\"ngModel\" [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\" [forceInvalid]=\"ForcedError\" [noValidate]=\"!Validation\" [Readonly]=\"Readonly\" [submitted]=\"Form?.submitted\" [placeHolderValue]=\"''\" [placeholder]=\"Required ? ('Select' | localize : lc) + '...' : Placeholder\" [required]=\"Required\" [(ngModel)]=\"Model\" (inputChange)=\"changed($event);\" (inputFocus)=\"focused($event);\" (inputFinalized)=\"finalized()\" [id]=\"GeneratedName\" name=\"{{GeneratedName}}\">\r\n            <option *ngFor=\"let val of BoundSource\" [value]=\"val.id\">{{val.description}}</option>\r\n        </val-select>\r\n    </div>\r\n    <!--Se autocomplete-->\r\n    <div *ngIf=\"Type == 'autocomplete'\">\r\n        <val-autocomplete #validationControl=\"ngModel\" [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\" [forceInvalid]=\"ForcedError\" [noValidate]=\"!Validation\" [Readonly]=\"Readonly\" [submitted]=\"Form?.submitted\" [required]=\"Required\" [placeholder]=\"Required ? ('Select' | localize : lc) + '...' : Placeholder\" [(ngModel)]=\"Model\" [id]=\"GeneratedName\" name=\"{{GeneratedName}}\" [FilteredSource]=\"FilteredBoundSource\" (inputChange)=\"filterSource($event); changed($event);\" (inputFocus)=\"focused($event);\" (inputFinalized)=\"finalized()\"></val-autocomplete>\r\n    </div>\r\n    <!--Se date time-->\r\n    <div *ngIf=\"Type == 'datetime'\">\r\n        <val-datetime #validationControl=\"ngModel\" [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\" [forceInvalid]=\"ForcedError\" [FloatingLabel]=\"FloatingLabel\" [noValidate]=\"!Validation\" [Readonly]=\"Readonly\" [submitted]=\"Form?.submitted\" [required]=\"Required\" [useJsDates]=\"useJsDates\" [(ngModel)]=\"Model\" [id]=\"GeneratedName\" name=\"{{GeneratedName}}\" autocomplete=\"off\" (inputChange)=\"changed($event);\" (inputFocus)=\"focused($event);\" (inputFinalized)=\"finalized()\"></val-datetime>\r\n    </div>\r\n    <!--Se time-->\r\n    <div *ngIf=\"Type == 'time'\">\r\n        <ngx-mat-timepicker name=\"val-time\" #elementRef #baseInput=\"ngModel\" [(ngModel)]=\"Model\" [disabled]=\"Readonly\"\r\n        [showSpinners]=\"false\" [stepHour]=\"2\" [stepMinute]=\"5\" [stepSecond]=\"30\"\r\n        [showSeconds]=\"true\" (ngModelChange)=\"changed()\" #validationControl=\"ngModel\">\r\n        </ngx-mat-timepicker>\r\n    </div>\r\n    <!--Se file-->\r\n    <div *ngIf=\"Type == 'file'\">\r\n        <div class=\"input-group file-upload\">\r\n            <input type=\"file\" (change)=\"fileChange()\" #fileInput id=\"{{GeneratedName}}\" class=\"file-upload-btn app-pointer\" [multiple]=\"null\"/>\r\n            <input type=\"text\" [class.frm-padding-left-22]=\"AllowDownload && ModelFile.filename && ModelFile.fileb64\" class=\"form-control checking-field\" placeholder=\"{{'Select a file' | localize : lc}}...\" [(ngModel)]=\"ModelFile.filename\" name=\"dsfile\" #validationControl=\"ngModel\" [required]=\"Required\"/>\r\n    \r\n            <a class=\"fa fa-download app-pointer app-input-icon\" *ngIf=\"AllowDownload && ModelFile.filename && ModelFile.fileb64\" (click)=\"downloadAttachment()\"></a>\r\n            <i class=\"fa fa-times delete-file\" (click)=\"fileChange(true)\" *ngIf=\"ModelFile.filename\"></i>\r\n            <span class=\"input-group-btn\">\r\n                <button class=\"btn btn-primary btn-file-upload\" type=\"button\"><i class=\"fa fa-upload\"></i></button>\r\n            </span>\r\n        </div>\r\n    </div>\r\n</ng-template>"]}
|