@esfaenza/forms-and-validations 11.2.63 → 11.2.66

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (45) hide show
  1. package/bundles/esfaenza-forms-and-validations.umd.js +310 -523
  2. package/bundles/esfaenza-forms-and-validations.umd.js.map +1 -1
  3. package/esfaenza-forms-and-validations.d.ts +9 -9
  4. package/esfaenza-forms-and-validations.metadata.json +1 -1
  5. package/esm2015/esfaenza-forms-and-validations.js +10 -10
  6. package/esm2015/lib/forms/base-form-control.js +61 -118
  7. package/esm2015/lib/forms/form-adaptive/form-adaptive.component.js +49 -65
  8. package/esm2015/lib/forms/form-autocomplete/form-autocomplete.component.js +20 -46
  9. package/esm2015/lib/forms/form-checkbox/form-checkbox.component.js +15 -14
  10. package/esm2015/lib/forms/form-date/form-date.component.js +19 -20
  11. package/esm2015/lib/forms/form-datetime/form-datetime.component.js +18 -17
  12. package/esm2015/lib/forms/form-empty/form-empty.component.js +4 -10
  13. package/esm2015/lib/forms/form-error/form-error.component.js +6 -16
  14. package/esm2015/lib/forms/form-file/form-file.component.js +15 -29
  15. package/esm2015/lib/forms/form-info/form-info.component.js +6 -16
  16. package/esm2015/lib/forms/form-input/form-input.component.js +21 -35
  17. package/esm2015/lib/forms/form-multiselect/form-multiselect.component.js +17 -35
  18. package/esm2015/lib/forms/form-select/form-select.component.js +29 -33
  19. package/esm2015/lib/forms/form-template/form-template.component.js +10 -28
  20. package/esm2015/lib/forms/form-textarea/form-textarea.component.js +15 -17
  21. package/esm2015/lib/forms/form-time/form-time.component.js +17 -34
  22. package/esm2015/lib/forms-and-validations.module.js +3 -2
  23. package/esm2015/lib/models/FormsAndValidationsModuleConfig.js +1 -1
  24. package/esm2015/lib/tokens.js +5 -7
  25. package/fesm2015/esfaenza-forms-and-validations.js +300 -515
  26. package/fesm2015/esfaenza-forms-and-validations.js.map +1 -1
  27. package/lib/forms/base-form-control.d.ts +56 -130
  28. package/lib/forms/form-adaptive/form-adaptive.component.d.ts +25 -72
  29. package/lib/forms/form-autocomplete/form-autocomplete.component.d.ts +13 -41
  30. package/lib/forms/form-checkbox/form-checkbox.component.d.ts +8 -12
  31. package/lib/forms/form-date/form-date.component.d.ts +9 -15
  32. package/lib/forms/form-datetime/form-datetime.component.d.ts +8 -12
  33. package/lib/forms/form-empty/form-empty.component.d.ts +3 -9
  34. package/lib/forms/form-error/form-error.component.d.ts +5 -15
  35. package/lib/forms/form-file/form-file.component.d.ts +9 -27
  36. package/lib/forms/form-info/form-info.component.d.ts +5 -15
  37. package/lib/forms/form-input/form-input.component.d.ts +14 -36
  38. package/lib/forms/form-multiselect/form-multiselect.component.d.ts +10 -30
  39. package/lib/forms/form-select/form-select.component.d.ts +11 -24
  40. package/lib/forms/form-template/form-template.component.d.ts +9 -27
  41. package/lib/forms/form-textarea/form-textarea.component.d.ts +7 -15
  42. package/lib/forms/form-time/form-time.component.d.ts +10 -30
  43. package/lib/models/FormsAndValidationsModuleConfig.d.ts +6 -8
  44. package/lib/tokens.d.ts +4 -6
  45. package/package.json +1 -1
@@ -11,59 +11,37 @@ import { NgxMatDateAdapter } from "@angular-material-components/datetime-picker"
11
11
  import { BaseFormControl } from "../base-form-control";
12
12
  import { FormAdaptiveComponentLoc } from "./form-adaptive.component.loc";
13
13
  // Modelli
14
- import { ACO_CUSTOMKEY } from '../../tokens';
14
+ import { ACO_CUSTOMKEY, FAV_DEBUG_MODE } from '../../tokens';
15
15
  import { AppFile } from "../../models/AppFile";
16
- /**
17
- * 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
18
- */
16
+ /** 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 */
19
17
  export class FormAdaptiveComponent extends BaseFormControl {
20
- /**
21
- * Costruttore
22
- *
23
- * @ignore
24
- */
25
- constructor(cdr, utiExts, datesExts, dateAdapter, lc, ngControl, _validators, ac, AppContext, ACO_CUSTOMKEY) {
26
- super(cdr, ngControl, _validators, ac, AppContext, ACO_CUSTOMKEY);
18
+ /** @ignore Costruttore */
19
+ constructor(cdr, utiExts, datesExts, dateAdapter, lc, ngControl, _validators, ac, AppContext, ACO_CUSTOMKEY, FAV_DEBUG_MODE) {
20
+ super(cdr, ngControl, _validators, ac, AppContext, ACO_CUSTOMKEY, FAV_DEBUG_MODE);
27
21
  this.utiExts = utiExts;
28
22
  this.datesExts = datesExts;
29
23
  this.dateAdapter = dateAdapter;
30
24
  this.lc = lc;
31
- /**
32
- * Permette di scaricare l'eventuale file presente qualora il **Type** di questo componente fosse **file**
33
- */
25
+ /** Permette di scaricare l'eventuale file presente qualora il **Type** di questo componente fosse **file** */
34
26
  this.AllowDownload = true;
35
- /**
36
- * Utilizzata nel form-adapter per specificare la precisione degli input currencymap (Type: currency)
37
- */
27
+ /** Utilizzata nel form-adapter per specificare la precisione degli input currencymap (Type: currency) */
38
28
  this.Precision = 2;
39
- /**
40
- * Allineamento della currency mask
41
- */
29
+ /** Allineamento della currency mask */
42
30
  this.Alignment = 'right';
43
- /**
44
- * Funzione di ricerca che verrà chiamata dal componente
45
- */
31
+ /** Funzione di ricerca che verrà chiamata dal componente */
46
32
  this.SearchFunction = null;
47
- /**
48
- * Numero minimo di caratteri con cui cercare
49
- */
33
+ /** Numero minimo di caratteri con cui cercare */
50
34
  this.MinChars = 3;
51
- /**
52
- * Indica se i controlli devono essere effettuati tenendo conto del Case o meno. Vale solo qualora la **Source** fosse fornita
53
- */
35
+ /** Indica se i controlli devono essere effettuati tenendo conto del Case o meno. Vale solo qualora la **Source** fosse fornita */
54
36
  this.CaseSensitive = false;
55
- /**
56
- * Variabile interna che gestisce se effettuare il riallineamento dei dati o meno
57
- */
37
+ /** Variabile interna che gestisce se effettuare il riallineamento dei dati o meno */
58
38
  this.alignValues = false;
59
39
  /**
60
40
  * Indica se ignorare il prossimo evento writeValue che normalmente dovrebbe richiedere la nuova source. Serve per quando l'utente seleziona un elemento:
61
41
  * Subito dopo partirebbe un altro evento modelChange che ricaricherebbe nuovamente la source
62
42
  */
63
43
  this.ignoreNextWriteValue = false;
64
- /**
65
- * 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
66
- */
44
+ /** 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 */
67
45
  this.FilteredBoundSource = [];
68
46
  //******************** Funzione di throttling per non spammare richieste in caso di animazioni attivate
69
47
  //TODO: spostarla in un metodo di utilità (esfaenza/extensions)
@@ -71,9 +49,7 @@ export class FormAdaptiveComponent extends BaseFormControl {
71
49
  this.executionTimers = {};
72
50
  this.ModelFile = new AppFile();
73
51
  }
74
- /**
75
- * @ignore
76
- */
52
+ /** @ignore */
77
53
  ngOnChanges(changes) {
78
54
  var _a;
79
55
  return __awaiter(this, void 0, void 0, function* () {
@@ -92,28 +68,41 @@ export class FormAdaptiveComponent extends BaseFormControl {
92
68
  this.writeValue(this.Model);
93
69
  });
94
70
  }
95
- /**
96
- * @ignore
97
- */
71
+ /** @ignore */
98
72
  writeValue(obj) {
73
+ var _a;
99
74
  this.alignValues = false;
100
- if (!this.Type)
75
+ this.EvaluatedModel = (obj === null || obj === void 0 ? void 0 : obj.toString()) || "";
76
+ if (!this.Type) {
101
77
  this.Type = "string";
102
- if (this.Type == "date" || this.Type == "datetime")
78
+ this.EvaluatedModel = obj;
79
+ }
80
+ if (this.Type == "date" || this.Type == "datetime") {
103
81
  this.useJsDates = Object.prototype.toString.call(obj) === "[object Date]";
104
- else if ((this.Type == "float" || this.Type == "number") && obj)
82
+ if (this.Type == "date")
83
+ this.EvaluatedModel = this.datesExts.getFormatted(obj, true, false);
84
+ if (this.Type == "datetime")
85
+ this.EvaluatedModel = this.datesExts.getFormatted(obj, false, true);
86
+ }
87
+ else if ((this.Type == "float" || this.Type == "number") && obj) {
105
88
  obj = obj.toString().replace(".", ",");
89
+ this.EvaluatedModel = obj;
90
+ }
106
91
  // Per sicurezza riallineo i valori
107
92
  else if (this.Type == "boolean") {
108
93
  obj = obj ? (obj === true || obj.toLowerCase() == "true") : false;
109
94
  this.alignValues = true;
95
+ this.EvaluatedModel = this.lc.loc(obj ? 'Yes' : 'No');
110
96
  }
111
97
  else if (this.Type == "time") {
112
- const [hours, minutes, seconds] = (obj || "0:0:0").split(":");
113
- obj = dayjs().hour(hours !== null && hours !== void 0 ? hours : 0).minute(minutes !== null && minutes !== void 0 ? minutes : 0).second(seconds !== null && seconds !== void 0 ? seconds : 0);
98
+ const [hours, minutes, seconds] = (obj || "00:00:00").split(":");
99
+ obj = dayjs().hour(parseInt(hours !== null && hours !== void 0 ? hours : 0)).minute(parseInt(minutes !== null && minutes !== void 0 ? minutes : 0)).second(parseInt(seconds !== null && seconds !== void 0 ? seconds : 0));
100
+ this.EvaluatedModel = `${hours || '00'}:${minutes || '00'}:${seconds || '00'}`;
114
101
  }
115
- else if (this.Type == "file")
102
+ else if (this.Type == "file") {
116
103
  obj = this.ModelFile;
104
+ this.EvaluatedModel = this.ModelFile.filename;
105
+ }
117
106
  else if (this.Type == "autocomplete") {
118
107
  if (this.SearchFunction) {
119
108
  this.SearchFunction(obj, true).subscribe(t => {
@@ -126,6 +115,8 @@ export class FormAdaptiveComponent extends BaseFormControl {
126
115
  else
127
116
  this.finalizeValue(obj);
128
117
  }
118
+ if (this.BoundSource && this.BoundSource.length > 0)
119
+ this.EvaluatedModel = (_a = this.BoundSource.find(t => t.id == obj)) === null || _a === void 0 ? void 0 : _a.description;
129
120
  super.writeValue(obj);
130
121
  if (this.alignValues) {
131
122
  this.changed();
@@ -141,6 +132,7 @@ export class FormAdaptiveComponent extends BaseFormControl {
141
132
  var val = this.Source.find(t => t.id == value);
142
133
  this.propagateChange(val ? val.id : value);
143
134
  this.Model = val ? val.description : value;
135
+ this.EvaluatedModel = this.Model;
144
136
  }
145
137
  /**
146
138
  * Evento di filtro della sorgente dati in base all'input utente
@@ -183,9 +175,7 @@ export class FormAdaptiveComponent extends BaseFormControl {
183
175
  }, 100);
184
176
  }
185
177
  }
186
- /**
187
- * Metodo richiamato quando viene modificato il modello del campo di input
188
- */
178
+ /** Metodo richiamato quando viene modificato il modello del campo di input */
189
179
  changed() {
190
180
  var toEmit = this.getModelToEmit();
191
181
  if (this.Type == "autocomplete")
@@ -193,18 +183,15 @@ export class FormAdaptiveComponent extends BaseFormControl {
193
183
  if (this.EmitPendingChanges)
194
184
  super.changed(toEmit);
195
185
  }
186
+ /** @ignore */
196
187
  finalized() {
197
188
  super.finalized();
198
189
  }
199
- /**
200
- * Metodo richiamato quando viene selezionato il campo col mouse
201
- */
190
+ /** Metodo richiamato quando viene selezionato il campo col mouse */
202
191
  focused(event) {
203
192
  super.focused(event);
204
193
  }
205
- /**
206
- * Effettua gli aggiustamenti dati del caso ed emette il modello corretto
207
- */
194
+ /** Effettua gli aggiustamenti dati del caso ed emette il modello corretto */
208
195
  getModelToEmit() {
209
196
  var toEmit = this.Model ?
210
197
  (this.Type == "time" || this.useJsDates ?
@@ -246,16 +233,12 @@ export class FormAdaptiveComponent extends BaseFormControl {
246
233
  }
247
234
  this.changed();
248
235
  }
249
- /**
250
- * Permette di scaricare il file collegato all'evetnuale file input rappresentato da questo componente
251
- */
236
+ /** Permette di scaricare il file collegato all'evetnuale file input rappresentato da questo componente */
252
237
  downloadAttachment() {
253
238
  let model = this.Model;
254
239
  this.utiExts.saveFile(model.fileb64, model.filename);
255
240
  }
256
- /**
257
- * @ignore
258
- */
241
+ /** @ignore */
259
242
  onNotNullValueSet() { }
260
243
  /** @ignore */
261
244
  throttla(id, func, throttleTime) {
@@ -270,7 +253,7 @@ FormAdaptiveComponent.decorators = [
270
253
  { type: Component, args: [{
271
254
  selector: "form-adaptive",
272
255
  providers: [{ provide: LocalizationService, useClass: FormAdaptiveComponentLoc }],
273
- template: "<ng-container *ngIf=\"!FormLayout\">\r\n <ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container>\r\n</ng-container>\r\n\r\n<div *ngIf=\"FormLayout\" class=\"form-group row {{FormGroupClass}}\" [class.app-margin-bottom-0]=\"Last\">\r\n <label class=\"col-md-{{LabelColWidth}} m-t-5\">{{Label}}{{Required ? '*' : ''}}:</label>\r\n <div class=\"col-md-{{InputColWidth}}\">\r\n <ng-container *ngTemplateOutlet=\"controlTemplate\"></ng-container>\r\n </div>\r\n <div class=\"clearfix\"></div>\r\n</div>\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\" [FieldAppearence]=\"FieldAppearence\" [forceInvalid]=\"ForcedError\"\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\" [FieldAppearence]=\"FieldAppearence\" [forceInvalid]=\"ForcedError\" [noValidate]=\"!Validation\" [readonly]=\"Readonly\" [submitted]=\"Form?.submitted\" [required]=\"Required\" [(ngModel)]=\"Model\" [id]=\"GeneratedName\" [useJsDates]=\"useJsDates\" name=\"{{GeneratedName}}\" autocomplete=\"off\" (inputChange)=\"changed();\" (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\" [FieldAppearence]=\"FieldAppearence\" [forceInvalid]=\"ForcedError\" [noValidate]=\"!Validation\" [readonly]=\"Readonly\" [submitted]=\"Form?.submitted\" type=\"text\" pattern=\"{{Pattern || ''}}\" [required]=\"Required\" [(ngModel)]=\"Model\" [id]=\"GeneratedName\" name=\"{{GeneratedName}}\" autocomplete=\"off\" (inputChange)=\"changed();\" (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\" [FieldAppearence]=\"FieldAppearence\" [forceInvalid]=\"ForcedError\" [noValidate]=\"!Validation\" [readonly]=\"Readonly\" [submitted]=\"Form?.submitted\" type=\"text\" pattern=\"{{Pattern || '^([0-9]*[,])?[0-9]+$'}}\" [required]=\"Required\" [(ngModel)]=\"Model\" [id]=\"GeneratedName\" name=\"{{GeneratedName}}\" autocomplete=\"off\" (inputChange)=\"changed();\" (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\" [FieldAppearence]=\"FieldAppearence\" [forceInvalid]=\"ForcedError\" [noValidate]=\"!Validation\" [readonly]=\"Readonly\" [submitted]=\"Form?.submitted\" type=\"text\" pattern=\"{{Pattern || '^[0-9]\\\\d*$'}}\" [required]=\"Required\" [(ngModel)]=\"Model\" [id]=\"GeneratedName\" name=\"{{GeneratedName}}\" autocomplete=\"off\" (inputChange)=\"changed();\" (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\" [FieldAppearence]=\"FieldAppearence\" [forceInvalid]=\"ForcedError\" [noValidate]=\"!Validation\" [readonly]=\"Readonly\" [submitted]=\"Form?.submitted\" [placeHolderValue]=\"''\" [placeholder]=\"Required ? ('Select' | localize : lc) + '...' : Placeholder\" [required]=\"Required\" [(ngModel)]=\"Model\" (inputChange)=\"changed();\" (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\" [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();\" (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\" [FieldAppearence]=\"FieldAppearence\" [forceInvalid]=\"ForcedError\" [noValidate]=\"!Validation\" [readonly]=\"Readonly\" [submitted]=\"Form?.submitted\" [required]=\"Required\" [useJsDates]=\"useJsDates\" [(ngModel)]=\"Model\" [id]=\"GeneratedName\" name=\"{{GeneratedName}}\" autocomplete=\"off\" (inputChange)=\"changed();\" (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>",
256
+ template: "<ng-container *ngIf=\"!FormLayout\">\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</ng-container>\r\n\r\n<div *ngIf=\"FormLayout\" class=\"form-group row {{FormGroupClass}}\" [class.app-margin-bottom-0]=\"Last\">\r\n <label class=\"col-md-{{LabelColWidth}} m-t-5\" [class.app-strong]=\"DisplayMode\">{{Label}}{{Required && !DisplayMode ? '*' : ''}}:</label>\r\n <div class=\"col-md-{{InputColWidth}}\">\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<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\" [FieldAppearence]=\"FieldAppearence\" [forceInvalid]=\"ForcedError\"\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\" [FieldAppearence]=\"FieldAppearence\" [forceInvalid]=\"ForcedError\" [noValidate]=\"!Validation\" [readonly]=\"Readonly\" [submitted]=\"Form?.submitted\" [required]=\"Required\" [(ngModel)]=\"Model\" [id]=\"GeneratedName\" [useJsDates]=\"useJsDates\" name=\"{{GeneratedName}}\" autocomplete=\"off\" (inputChange)=\"changed();\" (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\" [FieldAppearence]=\"FieldAppearence\" [forceInvalid]=\"ForcedError\" [noValidate]=\"!Validation\" [readonly]=\"Readonly\" [submitted]=\"Form?.submitted\" type=\"text\" pattern=\"{{Pattern || ''}}\" [required]=\"Required\" [(ngModel)]=\"Model\" [id]=\"GeneratedName\" name=\"{{GeneratedName}}\" autocomplete=\"off\" (inputChange)=\"changed();\" (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\" [FieldAppearence]=\"FieldAppearence\" [forceInvalid]=\"ForcedError\" [noValidate]=\"!Validation\" [readonly]=\"Readonly\" [submitted]=\"Form?.submitted\" type=\"text\" pattern=\"{{Pattern || '^([0-9]*[,])?[0-9]+$'}}\" [required]=\"Required\" [(ngModel)]=\"Model\" [id]=\"GeneratedName\" name=\"{{GeneratedName}}\" autocomplete=\"off\" (inputChange)=\"changed();\" (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\" [FieldAppearence]=\"FieldAppearence\" [forceInvalid]=\"ForcedError\" [noValidate]=\"!Validation\" [readonly]=\"Readonly\" [submitted]=\"Form?.submitted\" type=\"text\" pattern=\"{{Pattern || '^[0-9]\\\\d*$'}}\" [required]=\"Required\" [(ngModel)]=\"Model\" [id]=\"GeneratedName\" name=\"{{GeneratedName}}\" autocomplete=\"off\" (inputChange)=\"changed();\" (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\" [FieldAppearence]=\"FieldAppearence\" [forceInvalid]=\"ForcedError\" [noValidate]=\"!Validation\" [readonly]=\"Readonly\" [submitted]=\"Form?.submitted\" [placeHolderValue]=\"''\" [placeholder]=\"Required ? ('Select' | localize : lc) + '...' : Placeholder\" [required]=\"Required\" [(ngModel)]=\"Model\" (inputChange)=\"changed();\" (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\" [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();\" (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\" [FieldAppearence]=\"FieldAppearence\" [forceInvalid]=\"ForcedError\" [noValidate]=\"!Validation\" [readonly]=\"Readonly\" [submitted]=\"Form?.submitted\" [required]=\"Required\" [useJsDates]=\"useJsDates\" [(ngModel)]=\"Model\" [id]=\"GeneratedName\" name=\"{{GeneratedName}}\" autocomplete=\"off\" (inputChange)=\"changed();\" (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>",
274
257
  changeDetection: ChangeDetectionStrategy.OnPush,
275
258
  styles: [".frm-padding-left-22{padding-left:22px}"]
276
259
  },] }
@@ -285,7 +268,8 @@ FormAdaptiveComponent.ctorParameters = () => [
285
268
  { type: Array, decorators: [{ type: Optional }, { type: Inject, args: [NG_VALIDATORS,] }] },
286
269
  { type: AccessControlService },
287
270
  { type: ComponentContext, decorators: [{ type: Optional }] },
288
- { type: String, decorators: [{ type: Optional }, { type: Inject, args: [ACO_CUSTOMKEY,] }] }
271
+ { type: String, decorators: [{ type: Optional }, { type: Inject, args: [ACO_CUSTOMKEY,] }] },
272
+ { type: Boolean, decorators: [{ type: Optional }, { type: Inject, args: [FAV_DEBUG_MODE,] }] }
289
273
  ];
290
274
  FormAdaptiveComponent.propDecorators = {
291
275
  Type: [{ type: Input }],
@@ -299,4 +283,4 @@ FormAdaptiveComponent.propDecorators = {
299
283
  MinChars: [{ type: Input }],
300
284
  CaseSensitive: [{ type: Input }]
301
285
  };
302
- //# 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"],"names":[],"mappings":"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","sourcesContent":["// Angular\r\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, Inject, Input, Optional, Self, SimpleChanges, ViewChild } from \"@angular/core\";\r\nimport { ControlValueAccessor, NG_VALIDATORS, NgControl } 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 \"@angular-material-components/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 } from '../../tokens';\r\nimport { AppFile } from \"../../models/AppFile\";\r\n\r\nimport { Observable } from \"rxjs\";\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 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 */\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    /**\r\n     * Tipologia che decide che componente mostrare\r\n     */\r\n    @Input() Type: 'string' | 'float' | 'date' | 'number' | 'int' | 'boolean' | 'enum' | 'autocomplete' | 'datetime' | 'time' | 'file' | 'currency';\r\n\r\n    /**\r\n     * Messaggio per quando si binda un form-adaptive senza tipo\r\n     */\r\n    @Input() TypeMissingMessage: string;\r\n\r\n    /**\r\n     * Pattern di validazione\r\n     */\r\n    @Input() Pattern: string;\r\n\r\n    /**\r\n     * Riferimento all'elemento input di tipo file qualora il **Type** di questo componente fosse **file**\r\n     */\r\n    @ViewChild(\"fileInput\", { static: false }) inputEl: ElementRef;\r\n\r\n    /**\r\n     * Permette di scaricare l'eventuale file presente qualora il **Type** di questo componente fosse **file**\r\n     */\r\n    @Input() AllowDownload: boolean = true;\r\n\r\n    /**\r\n     * Modello typescript di bind dei file\r\n     */\r\n    ModelFile: AppFile;\r\n\r\n    /**\r\n     * Utilizzata nel form-adapter per specificare la precisione degli input currencymap (Type: currency)\r\n     */\r\n    @Input() Precision: number = 2;\r\n\r\n    /**\r\n     * Allineamento della currency mask\r\n     */\r\n    @Input() Alignment: 'left' | 'right' = 'right';\r\n\r\n    /**\r\n     * Funzione di ricerca che verrà chiamata dal componente\r\n     */\r\n    @Input() SearchFunction: (search: string, byid: boolean) => Observable<{ id: string, description: string }[]> = null;\r\n\r\n    /**\r\n     * Numero minimo di caratteri con cui cercare\r\n     */\r\n    @Input() MinChars: number = 3;\r\n\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     */\r\n    @Input() CaseSensitive: boolean = false;\r\n\r\n    /**\r\n     * Variabile interna che gestisce se effettuare il riallineamento dei dati o meno\r\n     */\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    /**\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     */\r\n    public FilteredBoundSource: { id: string, description: string }[] = [];\r\n\r\n    /**\r\n     * Solo per gli input di tipo \"date\". Capisce che modalità usare per il validation-date sottostante\r\n     */\r\n    public useJsDates: boolean;\r\n\r\n    /**\r\n     * Costruttore \r\n     * \r\n     * @ignore\r\n     */\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) {\r\n        super(cdr, ngControl, _validators, ac, AppContext,ACO_CUSTOMKEY);\r\n\r\n        this.ModelFile = new AppFile();\r\n    }\r\n\r\n    /**\r\n     * @ignore\r\n     */\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    /**\r\n     * @ignore\r\n     */\r\n    writeValue(obj: any): void {\r\n        this.alignValues = false;\r\n\r\n        if (!this.Type)\r\n            this.Type = \"string\";\r\n\r\n        if(this.Type == \"date\" || this.Type == \"datetime\")\r\n            this.useJsDates = Object.prototype.toString.call(obj) === \"[object Date]\";\r\n\r\n        else if ((this.Type == \"float\" || this.Type == \"number\") && obj)\r\n            obj = obj.toString().replace(\".\", \",\");\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        }\r\n\r\n        else if (this.Type == \"time\") {\r\n            const [hours, minutes, seconds] = (obj || \"0:0:0\").split(\":\");\r\n            obj = dayjs().hour(hours ?? 0).minute(minutes ?? 0).second(seconds ?? 0);\r\n        }\r\n\r\n        else if (this.Type == \"file\")\r\n            obj = this.ModelFile;\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        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    }\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: string) {\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(\"\");\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.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, 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.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)) || (!this.CaseSensitive && t.description.toLowerCase().includes(event.toLowerCase())));\r\n                this.cdr.markForCheck();\r\n            }, 100);\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Metodo richiamato quando viene modificato il modello del campo di input\r\n     */\r\n    changed() {\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);\r\n    }\r\n\r\n    finalized() {\r\n        super.finalized();\r\n    }\r\n\r\n    /**\r\n     * Metodo richiamato quando viene selezionato il campo col mouse\r\n     */\r\n    focused(event: any) {\r\n        super.focused(event);\r\n    }\r\n\r\n    /**\r\n     * Effettua gli aggiustamenti dati del caso ed emette il modello corretto\r\n     */\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            toEmit = toEmit.replace(\".\", \"\").replace(\",\", \".\");\r\n\r\n        else if (this.Type == \"boolean\")\r\n            toEmit = toEmit ? true : false;\r\n\r\n        else if (this.Type == \"time\")\r\n            toEmit = toEmit.format(\"HH:mm:ss\");\r\n\r\n        else if((this.Type == \"date\" || this.Type == \"datetime\") && this.useJsDates)\r\n            toEmit = toEmit.toDate();\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    /**\r\n     * Permette di scaricare il file collegato all'evetnuale file input rappresentato da questo componente\r\n     */\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    /**\r\n     * @ignore\r\n     */\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}"]}
286
+ //# 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"],"names":[],"mappings":"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","sourcesContent":["// Angular\r\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, Inject, Input, Optional, Self, SimpleChanges, ViewChild } from \"@angular/core\";\r\nimport { ControlValueAccessor, NG_VALIDATORS, NgControl } 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 \"@angular-material-components/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\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/** 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    /** 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    /** 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;\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    }\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        {\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 = Object.prototype.toString.call(obj) === \"[object Date]\";\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        {\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 ? 'Yes' : '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        {\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: string) {\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(\"\");\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.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, 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.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)) || (!this.CaseSensitive && t.description.toLowerCase().includes(event.toLowerCase())));\r\n                this.cdr.markForCheck();\r\n            }, 100);\r\n        }\r\n    }\r\n\r\n    /** Metodo richiamato quando viene modificato il modello del campo di input */\r\n    changed() {\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);\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            toEmit = toEmit.replace(\".\", \"\").replace(\",\", \".\");\r\n\r\n        else if (this.Type == \"boolean\")\r\n            toEmit = toEmit ? true : false;\r\n\r\n        else if (this.Type == \"time\")\r\n            toEmit = toEmit.format(\"HH:mm:ss\");\r\n\r\n        else if((this.Type == \"date\" || this.Type == \"datetime\") && this.useJsDates)\r\n            toEmit = toEmit.toDate();\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}"]}