@esfaenza/forms-and-validations 18.2.2 → 19.2.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/fesm2022/esfaenza-forms-and-validations.mjs +153 -153
- package/fesm2022/esfaenza-forms-and-validations.mjs.map +1 -1
- package/lib/forms/base-form-control.d.ts +1 -1
- package/lib/forms/form-adaptive/form-adaptive.component.d.ts +2 -2
- package/lib/forms/form-time/form-time.component.d.ts +2 -2
- package/lib/validations/base-validation.d.ts +1 -1
- package/package.json +13 -15
- 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
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
import { Injectable } from "@angular/core";
|
|
2
|
-
import { LocalizationService } from "@esfaenza/localizations";
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
/**
|
|
5
|
-
* Classe di localizzazione per il componente **FormAutocompleteComponent**
|
|
6
|
-
*/
|
|
7
|
-
export class FormAutocompleteComponentLoc extends LocalizationService {
|
|
8
|
-
/**
|
|
9
|
-
* @ignore
|
|
10
|
-
*/
|
|
11
|
-
constructor(injector) {
|
|
12
|
-
super(injector);
|
|
13
|
-
super.set("it->en", "Seleziona", ["Select"]);
|
|
14
|
-
}
|
|
15
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormAutocompleteComponentLoc, deps: [{ token: i0.Injector }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
16
|
-
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormAutocompleteComponentLoc }); }
|
|
17
|
-
}
|
|
18
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormAutocompleteComponentLoc, decorators: [{
|
|
19
|
-
type: Injectable
|
|
20
|
-
}], ctorParameters: () => [{ type: i0.Injector }] });
|
|
21
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZm9ybS1hdXRvY29tcGxldGUuY29tcG9uZW50LmxvYy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Zvcm1zLWFuZC12YWxpZGF0aW9ucy9zcmMvbGliL2Zvcm1zL2Zvcm0tYXV0b2NvbXBsZXRlL2Zvcm0tYXV0b2NvbXBsZXRlLmNvbXBvbmVudC5sb2MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBWSxNQUFNLGVBQWUsQ0FBQztBQUNyRCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQzs7QUFFOUQ7O0dBRUc7QUFFSCxNQUFNLE9BQU8sNEJBQTZCLFNBQVEsbUJBQW1CO0lBRWpFOztPQUVHO0lBQ0gsWUFBWSxRQUFrQjtRQUMxQixLQUFLLENBQUMsUUFBUSxDQUFDLENBQUM7UUFFaEIsS0FBSyxDQUFDLEdBQUcsQ0FBQyxRQUFRLEVBQUUsV0FBVyxFQUFFLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQTtJQUNoRCxDQUFDOytHQVRRLDRCQUE0QjttSEFBNUIsNEJBQTRCOzs0RkFBNUIsNEJBQTRCO2tCQUR4QyxVQUFVIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSwgSW5qZWN0b3IgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgeyBMb2NhbGl6YXRpb25TZXJ2aWNlIH0gZnJvbSBcIkBlc2ZhZW56YS9sb2NhbGl6YXRpb25zXCI7XHJcblxyXG4vKipcclxuICogQ2xhc3NlIGRpIGxvY2FsaXp6YXppb25lIHBlciBpbCBjb21wb25lbnRlICoqRm9ybUF1dG9jb21wbGV0ZUNvbXBvbmVudCoqXHJcbiAqL1xyXG5ASW5qZWN0YWJsZSgpXHJcbmV4cG9ydCBjbGFzcyBGb3JtQXV0b2NvbXBsZXRlQ29tcG9uZW50TG9jIGV4dGVuZHMgTG9jYWxpemF0aW9uU2VydmljZSB7XHJcblxyXG4gICAgLyoqXHJcbiAgICAgKiBAaWdub3JlXHJcbiAgICAgKi9cclxuICAgIGNvbnN0cnVjdG9yKGluamVjdG9yOiBJbmplY3Rvcikge1xyXG4gICAgICAgIHN1cGVyKGluamVjdG9yKTtcclxuXHJcbiAgICAgICAgc3VwZXIuc2V0KFwiaXQtPmVuXCIsIFwiU2VsZXppb25hXCIsIFtcIlNlbGVjdFwiXSlcclxuICAgIH1cclxufSJdfQ==
|
|
@@ -1,289 +0,0 @@
|
|
|
1
|
-
// Angular
|
|
2
|
-
import { ChangeDetectionStrategy, Component, Inject, Input, Optional, Self } from "@angular/core";
|
|
3
|
-
import { NG_VALIDATORS } from "@angular/forms";
|
|
4
|
-
// Applicazione
|
|
5
|
-
import { BaseFormControl } from "../base-form-control";
|
|
6
|
-
import { LocalizationService } from "@esfaenza/localizations";
|
|
7
|
-
import { ACO_CUSTOMKEY, FAV_DEBUG_MODE } from '../../tokens';
|
|
8
|
-
//Localizzazione
|
|
9
|
-
import { FormAutocompleteComponentLoc } from "./form-autocomplete.component.loc";
|
|
10
|
-
import * as i0 from "@angular/core";
|
|
11
|
-
import * as i1 from "@esfaenza/localizations";
|
|
12
|
-
import * as i2 from "@angular/forms";
|
|
13
|
-
import * as i3 from "@esfaenza/access-control";
|
|
14
|
-
import * as i4 from "@angular/common";
|
|
15
|
-
import * as i5 from "../../validations/validation-autocomplete/validation-autocomplete.component";
|
|
16
|
-
import * as i6 from "../../validations/validation-autocomplete-multi/validation-autocomplete-multi.component";
|
|
17
|
-
/** Componente di input che si auto-completa in base al valore attuale */
|
|
18
|
-
export class FormAutocompleteComponent extends BaseFormControl {
|
|
19
|
-
/** @ignore Costruttore */
|
|
20
|
-
constructor(cdr, lc, ngControl, _validators, ac, AppContext, ACO_CUSTOMKEY, FAV_DEBUG_MODE) {
|
|
21
|
-
super(cdr, ngControl, _validators, ac, AppContext, ACO_CUSTOMKEY, FAV_DEBUG_MODE);
|
|
22
|
-
this.lc = lc;
|
|
23
|
-
/** Permette di specificare il testo della Label flottante material-style */
|
|
24
|
-
this.SelectLabel = "";
|
|
25
|
-
/** Funzione di ricerca che verrà chiamata dal componente */
|
|
26
|
-
this.SearchFunction = null;
|
|
27
|
-
/** Numero minimo di caratteri con cui cercare */
|
|
28
|
-
this.MinChars = 3;
|
|
29
|
-
/** Definisce che ad ogni selezione deve chiudere la tendina */
|
|
30
|
-
this.HideChoicesOnSelection = false;
|
|
31
|
-
/** Override del placeholder per select requried */
|
|
32
|
-
this.RequiredPlaceholder = null;
|
|
33
|
-
/** Indica se i controlli devono essere effettuati tenendo conto del Case o meno. Vale solo qualora la **Source** fosse fornita */
|
|
34
|
-
this.CaseSensitive = false;
|
|
35
|
-
/** Indica se usare la modalità multiselezione o no */
|
|
36
|
-
this.Multi = false;
|
|
37
|
-
/** Indica se usare la modalità multiselezione o no */
|
|
38
|
-
this.MultiElementsThreshold = 10;
|
|
39
|
-
/** Indica il fatto che non c'è una Source da cui scegliere */
|
|
40
|
-
this.UnboundMode = false;
|
|
41
|
-
/**
|
|
42
|
-
* Indica se ignorare il prossimo evento writeValue che normalmente dovrebbe richiedere la nuova source. Serve per quando l'utente seleziona un elemento:
|
|
43
|
-
* Subito dopo partirebbe un altro evento modelChange che ricaricherebbe nuovamente la source
|
|
44
|
-
*/
|
|
45
|
-
this.ignoreNextWriteValue = false;
|
|
46
|
-
/** Sorgente Bindata Filtrata in base al contenuto della casella di testo */
|
|
47
|
-
this.FilteredBoundSource = [];
|
|
48
|
-
this.timer = null;
|
|
49
|
-
this.maxCallsPerSecond = 4;
|
|
50
|
-
this.callsDoneThisThreeSeconds = 0;
|
|
51
|
-
//******************** Funzione di throttling per non spammare richieste in caso di animazioni attivate
|
|
52
|
-
//TODO: spostarla in un metodo di utilità (esfaenza/extensions)
|
|
53
|
-
/** @ignore */
|
|
54
|
-
this.executionTimers = {};
|
|
55
|
-
}
|
|
56
|
-
/** @ignore */
|
|
57
|
-
writeValue(value) {
|
|
58
|
-
if (!value)
|
|
59
|
-
return;
|
|
60
|
-
if (this.SearchFunction && !this.UnboundMode) {
|
|
61
|
-
this.doSearchProtected(value, true, this.SearchFunctionContext, (t) => {
|
|
62
|
-
this.Source = t;
|
|
63
|
-
this.tryBindSourceDisplay();
|
|
64
|
-
setTimeout(() => { this.finalizeValue(value); });
|
|
65
|
-
});
|
|
66
|
-
return;
|
|
67
|
-
}
|
|
68
|
-
if (!this.Multi)
|
|
69
|
-
this.finalizeValue(value);
|
|
70
|
-
}
|
|
71
|
-
/**
|
|
72
|
-
* 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
|
|
73
|
-
*
|
|
74
|
-
* @param {any} value Valore scritto nell'input di testo
|
|
75
|
-
*/
|
|
76
|
-
finalizeValue(value) {
|
|
77
|
-
var val = this.UnboundMode ? null : this.BoundSource.find(t => t.id == value);
|
|
78
|
-
this.propagateChange(val ? val.id : value);
|
|
79
|
-
// Alor... praticamente qui potrebbero arrivare degli switcheroni in cui il Model è uguale all'inizio e alla fine dello stack, per qualche motivo
|
|
80
|
-
// quindi per assicurarmi che il valore venga preso correttamente faccio il classico metti a null poi metti su
|
|
81
|
-
// Notare che mettere il modello a null scatena i writevalue ma tutti i writevalue che si collegao a questo giro dovrebbero essere NOOP su null
|
|
82
|
-
this.Model = null;
|
|
83
|
-
setTimeout(() => {
|
|
84
|
-
this.Model = val ? val.description : value;
|
|
85
|
-
this.EvaluatedModel = this.Model;
|
|
86
|
-
this.cdr.markForCheck();
|
|
87
|
-
});
|
|
88
|
-
}
|
|
89
|
-
/**
|
|
90
|
-
* Quando viene scritto un nuovo valore bisogna controllare se per botta di culo fosse un id, in tal caso dev'essere rieffettuato il bind
|
|
91
|
-
* per mostrare solo la descrizione nell'autocomplete
|
|
92
|
-
*/
|
|
93
|
-
evaluateIdResearch(onFailure) {
|
|
94
|
-
let tmpModel = this.Model;
|
|
95
|
-
if (this.UnboundMode)
|
|
96
|
-
return;
|
|
97
|
-
if (!tmpModel || !this.SearchFunction) {
|
|
98
|
-
onFailure?.();
|
|
99
|
-
return;
|
|
100
|
-
}
|
|
101
|
-
this.log("filtersource enqueue");
|
|
102
|
-
this.throttla("filtersource", () => {
|
|
103
|
-
this.log("filtersource fire");
|
|
104
|
-
this.doSearchProtected(tmpModel, true, this.SearchFunctionContext, (t) => {
|
|
105
|
-
if (t && t.length > 0) {
|
|
106
|
-
this.Source = t;
|
|
107
|
-
this.tryBindSourceDisplay();
|
|
108
|
-
if (!this.Multi)
|
|
109
|
-
setTimeout(() => { this.finalizeValue(tmpModel); });
|
|
110
|
-
else
|
|
111
|
-
this.cdr.markForCheck();
|
|
112
|
-
}
|
|
113
|
-
else
|
|
114
|
-
onFailure?.();
|
|
115
|
-
});
|
|
116
|
-
}, 400);
|
|
117
|
-
}
|
|
118
|
-
/**
|
|
119
|
-
* Evento di filtro della sorgente dati in base all'input utente
|
|
120
|
-
*
|
|
121
|
-
* @param {string} event Input utente
|
|
122
|
-
*/
|
|
123
|
-
filterSource(event) {
|
|
124
|
-
// Contorllo prima di tutto se è un ID. in caso contrario effettuo la ricerca
|
|
125
|
-
this.evaluateIdResearch(() => {
|
|
126
|
-
this.doFilterSource(event);
|
|
127
|
-
});
|
|
128
|
-
}
|
|
129
|
-
doFilterSource(event) {
|
|
130
|
-
if (this.UnboundMode)
|
|
131
|
-
return;
|
|
132
|
-
if (this.ignoreNextWriteValue) {
|
|
133
|
-
this.ignoreNextWriteValue = false;
|
|
134
|
-
return;
|
|
135
|
-
}
|
|
136
|
-
// Quando filtro la source, se non devo ignorare l'evento devo comunque assicurarmi di impostare il valore selezionato a null
|
|
137
|
-
if (!this.Multi)
|
|
138
|
-
super.changed(null);
|
|
139
|
-
if (!event && this.MinChars == 0 && !this.SearchFunction) {
|
|
140
|
-
this.FilteredBoundSource = this.BoundSource;
|
|
141
|
-
this.cdr.markForCheck();
|
|
142
|
-
return;
|
|
143
|
-
}
|
|
144
|
-
if (!event || event.length < this.MinChars) {
|
|
145
|
-
this.log("search event ignored: " + event);
|
|
146
|
-
this.FilteredBoundSource = [];
|
|
147
|
-
this.cdr.markForCheck();
|
|
148
|
-
return;
|
|
149
|
-
}
|
|
150
|
-
if (!this.SearchFunction && (!this.Source || this.Source.length == 0))
|
|
151
|
-
throw "Impossibile filtrare gli elementi senza una funzione di ricerca che restituisca una lista di { id: string, description: string }";
|
|
152
|
-
if (this.SearchFunction) {
|
|
153
|
-
this.log("filtersource enqueue");
|
|
154
|
-
this.throttla("filtersource", () => {
|
|
155
|
-
this.log("filtersource fire");
|
|
156
|
-
this.doSearchProtected(event, false, this.SearchFunctionContext, (t) => {
|
|
157
|
-
this.log("filtersource received API response");
|
|
158
|
-
this.Source = t;
|
|
159
|
-
this.tryBindSourceDisplay();
|
|
160
|
-
// In questo caso è già filtrata dalla SearchFunction
|
|
161
|
-
this.FilteredBoundSource = this.BoundSource;
|
|
162
|
-
this.removeFilteredSourceOnDescriptionSelection();
|
|
163
|
-
this.cdr.markForCheck();
|
|
164
|
-
});
|
|
165
|
-
}, 400);
|
|
166
|
-
}
|
|
167
|
-
else {
|
|
168
|
-
this.throttla("filtersource", () => {
|
|
169
|
-
this.log("filtersource fire");
|
|
170
|
-
// In questo caso devo filtrare io in memoria
|
|
171
|
-
this.FilteredBoundSource = this.BoundSource.filter(t => (this.CaseSensitive && t.description.includes(event)) || (!this.CaseSensitive && t.description.toLowerCase().includes(event.toLowerCase())));
|
|
172
|
-
this.removeFilteredSourceOnDescriptionSelection();
|
|
173
|
-
this.cdr.markForCheck();
|
|
174
|
-
}, 100);
|
|
175
|
-
}
|
|
176
|
-
}
|
|
177
|
-
// Permetto al massimo 4 chiamate ogni 3 secondi, se nell'arco di 3 secondi ci sono più di 4 chiamate, ignoro le eccedenti
|
|
178
|
-
doSearchProtected(search, byid, context, onRes) {
|
|
179
|
-
if (!this.timer) {
|
|
180
|
-
this.timer = setTimeout(() => {
|
|
181
|
-
this.callsDoneThisThreeSeconds = 0;
|
|
182
|
-
clearTimeout(this.timer);
|
|
183
|
-
this.timer = null;
|
|
184
|
-
}, 3000);
|
|
185
|
-
}
|
|
186
|
-
if (this.callsDoneThisThreeSeconds >= this.maxCallsPerSecond) {
|
|
187
|
-
this.log("Ignoring excessive calls");
|
|
188
|
-
return;
|
|
189
|
-
}
|
|
190
|
-
this.callsDoneThisThreeSeconds++;
|
|
191
|
-
this.log("Search function being called...");
|
|
192
|
-
this.SearchFunction(search, byid, context).subscribe(t => {
|
|
193
|
-
onRes(t);
|
|
194
|
-
});
|
|
195
|
-
}
|
|
196
|
-
/** @ignore */
|
|
197
|
-
removeFilteredSourceOnDescriptionSelection() {
|
|
198
|
-
if (this.FilteredBoundSource.length == 1 && (this.FilteredBoundSource[0].description === this.Model) && !this.Multi) {
|
|
199
|
-
let model = this.BoundSource[0].id;
|
|
200
|
-
this.Model = model;
|
|
201
|
-
this.EvaluatedModel = this.BoundSource[0].description;
|
|
202
|
-
this.FilteredBoundSource = [];
|
|
203
|
-
setTimeout(() => { this.finalizeValue(model); });
|
|
204
|
-
}
|
|
205
|
-
}
|
|
206
|
-
/** @ignore */
|
|
207
|
-
ngOnChanges(changes) {
|
|
208
|
-
let newSource = changes["Source"];
|
|
209
|
-
if (newSource) {
|
|
210
|
-
this.tryBindSourceDisplay();
|
|
211
|
-
// Prima assegnazione se cambia la source sotto (quindi se viene bindata direttamente da HTML)
|
|
212
|
-
if ((this.Model?.length || 0) >= this.MinChars && !this.SearchFunction)
|
|
213
|
-
this.FilteredBoundSource = this.BoundSource;
|
|
214
|
-
else
|
|
215
|
-
this.FilteredBoundSource = [];
|
|
216
|
-
this.cdr.markForCheck();
|
|
217
|
-
}
|
|
218
|
-
}
|
|
219
|
-
/** @ignore Override che marca anche il prossimo evento di filterSource da ignorare */
|
|
220
|
-
changed(forcedValue = null, markForCheck = false) {
|
|
221
|
-
if (!this.Multi)
|
|
222
|
-
this.ignoreNextWriteValue = true;
|
|
223
|
-
if (forcedValue == "" && this.Multi)
|
|
224
|
-
this.Model = "";
|
|
225
|
-
var selecteds = forcedValue ? [forcedValue] : this.Model ? (this.Model.Multi ? this.Model.split(',') : [this.Model]) : [];
|
|
226
|
-
this.EvaluatedModel = selecteds.map(s => this.BoundSource && this.BoundSource.length > 0 ? this.BoundSource.find(t => t.id == s)?.description : this.UnboundMode ? s : "").join(', ');
|
|
227
|
-
super.changed(forcedValue, markForCheck);
|
|
228
|
-
}
|
|
229
|
-
/** @ignore */
|
|
230
|
-
onNotNullValueSet() { }
|
|
231
|
-
/** @ignore */
|
|
232
|
-
throttla(id, func, throttleTime) {
|
|
233
|
-
//Se ho la funzione che vuole eseguire ripulisco quel timeout
|
|
234
|
-
if (this.executionTimers[id])
|
|
235
|
-
clearTimeout(this.executionTimers[id]);
|
|
236
|
-
//Ricreo il timeout per eseguire quella funzione dopo throttleTime millisecondi
|
|
237
|
-
this.executionTimers[id] = setTimeout(() => { func(); this.executionTimers[id] = null; }, throttleTime);
|
|
238
|
-
}
|
|
239
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormAutocompleteComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.LocalizationService }, { token: i2.NgControl, optional: true, self: true }, { token: NG_VALIDATORS, optional: true }, { token: i3.AccessControlService, optional: true }, { token: i3.ComponentContext, optional: true }, { token: ACO_CUSTOMKEY, optional: true }, { token: FAV_DEBUG_MODE, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
240
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FormAutocompleteComponent, selector: "form-autocomplete", inputs: { SelectLabel: "SelectLabel", SearchFunctionContext: "SearchFunctionContext", SearchFunction: "SearchFunction", MinChars: "MinChars", HideChoicesOnSelection: "HideChoicesOnSelection", RequiredPlaceholder: "RequiredPlaceholder", CaseSensitive: "CaseSensitive", Multi: "Multi", MultiElementsThreshold: "MultiElementsThreshold", UnboundMode: "UnboundMode" }, providers: [{ provide: LocalizationService, useClass: FormAutocompleteComponentLoc }], 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<!-- Form-Model: {{Model}} -->\r\n<ng-template #controlTemplate>\r\n <val-autocomplete *ngIf=\"!Multi\" [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\" [noValidate]=\"!Validation\"\r\n [submitted]=\"Form?.submitted\"\r\n [Readonly]=\"Readonly\"\r\n [label]=\"SelectLabel\"\r\n type=\"text\"\r\n [(ngModel)]=\"Model\"\r\n [id]=\"GeneratedName\"\r\n name=\"{{GeneratedName}}\"\r\n #validationControl=\"ngModel\"\r\n (inputChange)=\"filterSource($event);\"\r\n (inputFocus)=\"focused($event);\"\r\n (inputFinalized)=\"finalized()\"\r\n (optionChange)=\"changed($event);\"\r\n [placeholder]=\"Required ? ((RequiredPlaceholder != null ? RequiredPlaceholder : (('Seleziona' | localize : lc) + '...'))) : Placeholder\"\r\n [validationFailed]=\"FailedValidationMessage\"\r\n [FilteredSource]=\"FilteredBoundSource\">\r\n </val-autocomplete>\r\n\r\n <val-autocomplete-multi *ngIf=\"Multi\" [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\" [noValidate]=\"!Validation\"\r\n [submitted]=\"Form?.submitted\"\r\n [Readonly]=\"Readonly\"\r\n [label]=\"SelectLabel\"\r\n [ChipThreshold]=\"MultiElementsThreshold\"\r\n [HideChoicesOnSelection]=\"HideChoicesOnSelection\"\r\n type=\"text\"\r\n [(ngModel)]=\"Model\"\r\n [id]=\"GeneratedName\"\r\n name=\"{{GeneratedName}}\"\r\n #validationControl=\"ngModel\"\r\n (inputChange)=\"filterSource($event);\"\r\n (inputFocus)=\"focused($event);\"\r\n (inputFinalized)=\"finalized()\"\r\n (optionChange)=\"changed($event);\"\r\n [placeholder]=\"Required ? ((RequiredPlaceholder != null ? RequiredPlaceholder : (('Seleziona' | localize : lc) + '...'))) : Placeholder\"\r\n [validationFailed]=\"FailedValidationMessage\"\r\n [FilteredSource]=\"FilteredBoundSource\"\r\n [UnboundMode]=\"UnboundMode\">\r\n\r\n </val-autocomplete-multi>\r\n</ng-template>", dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i5.ValidationAutocompleteComponent, selector: "val-autocomplete", inputs: ["FilteredSource", "value", "label"], outputs: ["optionChange"] }, { kind: "component", type: i6.ValidationAutocompleteMultiComponent, selector: "val-autocomplete-multi", inputs: ["ChipThreshold", "FilteredSource", "UnboundMode", "value", "label", "HideChoicesOnSelection"], outputs: ["optionChange"] }, { kind: "pipe", type: i1.LocalizePipe, name: "localize" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
241
|
-
}
|
|
242
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormAutocompleteComponent, decorators: [{
|
|
243
|
-
type: Component,
|
|
244
|
-
args: [{ selector: "form-autocomplete", providers: [{ provide: LocalizationService, useClass: FormAutocompleteComponentLoc }], 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<!-- Form-Model: {{Model}} -->\r\n<ng-template #controlTemplate>\r\n <val-autocomplete *ngIf=\"!Multi\" [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\" [noValidate]=\"!Validation\"\r\n [submitted]=\"Form?.submitted\"\r\n [Readonly]=\"Readonly\"\r\n [label]=\"SelectLabel\"\r\n type=\"text\"\r\n [(ngModel)]=\"Model\"\r\n [id]=\"GeneratedName\"\r\n name=\"{{GeneratedName}}\"\r\n #validationControl=\"ngModel\"\r\n (inputChange)=\"filterSource($event);\"\r\n (inputFocus)=\"focused($event);\"\r\n (inputFinalized)=\"finalized()\"\r\n (optionChange)=\"changed($event);\"\r\n [placeholder]=\"Required ? ((RequiredPlaceholder != null ? RequiredPlaceholder : (('Seleziona' | localize : lc) + '...'))) : Placeholder\"\r\n [validationFailed]=\"FailedValidationMessage\"\r\n [FilteredSource]=\"FilteredBoundSource\">\r\n </val-autocomplete>\r\n\r\n <val-autocomplete-multi *ngIf=\"Multi\" [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\" [noValidate]=\"!Validation\"\r\n [submitted]=\"Form?.submitted\"\r\n [Readonly]=\"Readonly\"\r\n [label]=\"SelectLabel\"\r\n [ChipThreshold]=\"MultiElementsThreshold\"\r\n [HideChoicesOnSelection]=\"HideChoicesOnSelection\"\r\n type=\"text\"\r\n [(ngModel)]=\"Model\"\r\n [id]=\"GeneratedName\"\r\n name=\"{{GeneratedName}}\"\r\n #validationControl=\"ngModel\"\r\n (inputChange)=\"filterSource($event);\"\r\n (inputFocus)=\"focused($event);\"\r\n (inputFinalized)=\"finalized()\"\r\n (optionChange)=\"changed($event);\"\r\n [placeholder]=\"Required ? ((RequiredPlaceholder != null ? RequiredPlaceholder : (('Seleziona' | localize : lc) + '...'))) : Placeholder\"\r\n [validationFailed]=\"FailedValidationMessage\"\r\n [FilteredSource]=\"FilteredBoundSource\"\r\n [UnboundMode]=\"UnboundMode\">\r\n\r\n </val-autocomplete-multi>\r\n</ng-template>" }]
|
|
245
|
-
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.LocalizationService }, { type: i2.NgControl, decorators: [{
|
|
246
|
-
type: Optional
|
|
247
|
-
}, {
|
|
248
|
-
type: Self
|
|
249
|
-
}] }, { type: Array, decorators: [{
|
|
250
|
-
type: Optional
|
|
251
|
-
}, {
|
|
252
|
-
type: Inject,
|
|
253
|
-
args: [NG_VALIDATORS]
|
|
254
|
-
}] }, { type: i3.AccessControlService, decorators: [{
|
|
255
|
-
type: Optional
|
|
256
|
-
}] }, { type: i3.ComponentContext, decorators: [{
|
|
257
|
-
type: Optional
|
|
258
|
-
}] }, { type: undefined, decorators: [{
|
|
259
|
-
type: Optional
|
|
260
|
-
}, {
|
|
261
|
-
type: Inject,
|
|
262
|
-
args: [ACO_CUSTOMKEY]
|
|
263
|
-
}] }, { type: undefined, decorators: [{
|
|
264
|
-
type: Optional
|
|
265
|
-
}, {
|
|
266
|
-
type: Inject,
|
|
267
|
-
args: [FAV_DEBUG_MODE]
|
|
268
|
-
}] }], propDecorators: { SelectLabel: [{
|
|
269
|
-
type: Input
|
|
270
|
-
}], SearchFunctionContext: [{
|
|
271
|
-
type: Input
|
|
272
|
-
}], SearchFunction: [{
|
|
273
|
-
type: Input
|
|
274
|
-
}], MinChars: [{
|
|
275
|
-
type: Input
|
|
276
|
-
}], HideChoicesOnSelection: [{
|
|
277
|
-
type: Input
|
|
278
|
-
}], RequiredPlaceholder: [{
|
|
279
|
-
type: Input
|
|
280
|
-
}], CaseSensitive: [{
|
|
281
|
-
type: Input
|
|
282
|
-
}], Multi: [{
|
|
283
|
-
type: Input
|
|
284
|
-
}], MultiElementsThreshold: [{
|
|
285
|
-
type: Input
|
|
286
|
-
}], UnboundMode: [{
|
|
287
|
-
type: Input
|
|
288
|
-
}] } });
|
|
289
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-autocomplete.component.js","sourceRoot":"","sources":["../../../../../../projects/forms-and-validations/src/lib/forms/form-autocomplete/form-autocomplete.component.ts","../../../../../../projects/forms-and-validations/src/lib/forms/form-autocomplete/form-autocomplete.component.html"],"names":[],"mappings":"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","sourcesContent":["// Angular\r\nimport { ChangeDetectionStrategy, Component, Inject, Input, Optional, ChangeDetectorRef, Self, SimpleChanges, Host } from \"@angular/core\";\r\nimport { ControlValueAccessor, NG_VALIDATORS, NgControl } from \"@angular/forms\";\r\n\r\n// Applicazione\r\nimport { BaseFormControl } from \"../base-form-control\";\r\n\r\n// Configurazioni\r\nimport { AccessControlService, ComponentContext } from '@esfaenza/access-control';\r\nimport { LocalizationService } from \"@esfaenza/localizations\";\r\nimport { ACO_CUSTOMKEY, FAV_DEBUG_MODE } from '../../tokens';\r\n\r\nimport { Observable } from \"rxjs\";\r\n\r\n//Localizzazione\r\nimport { FormAutocompleteComponentLoc } from \"./form-autocomplete.component.loc\";\r\n\r\n/** Componente di input che si auto-completa in base al valore attuale */\r\n@Component({\r\n    selector: \"form-autocomplete\",\r\n    templateUrl: \"form-autocomplete.component.html\",\r\n    providers: [{ provide: LocalizationService, useClass: FormAutocompleteComponentLoc }],\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class FormAutocompleteComponent extends BaseFormControl implements ControlValueAccessor {\r\n\r\n    /** Permette di specificare il testo della Label flottante material-style */\r\n    @Input() SelectLabel: string = \"\";\r\n\r\n    /** Contesto per la funzione di ricerca */\r\n    @Input() SearchFunctionContext: any;\r\n\r\n    /** Funzione di ricerca che verrà chiamata dal componente */\r\n    @Input() SearchFunction: (search: string, byid: boolean, context?: any) => 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    /** Definisce che ad ogni selezione deve chiudere la tendina */\r\n    @Input() HideChoicesOnSelection: boolean = false;\r\n\r\n    /** Override del placeholder per select requried */\r\n    @Input() RequiredPlaceholder: string = null;\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    /** Indica se usare la modalità multiselezione o no */\r\n    @Input() Multi: boolean = false;\r\n\r\n    /** Indica se usare la modalità multiselezione o no */\r\n    @Input() MultiElementsThreshold: number = 10;\r\n\r\n    /** Indica il fatto che non c'è una Source da cui scegliere */\r\n    @Input() UnboundMode: 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    /** Sorgente Bindata Filtrata in base al contenuto della casella di testo */\r\n    public FilteredBoundSource: { id: string, description: string }[] = [];\r\n\r\n    /** @ignore Costruttore  */\r\n    constructor(cdr: ChangeDetectorRef, public lc: LocalizationService, @Optional() @Self() ngControl: NgControl, @Optional() @Inject(NG_VALIDATORS) _validators: Array<any>, @Optional() 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\r\n    /** @ignore */\r\n    writeValue(value: any): void {\r\n        if (!value) return;\r\n\r\n        if (this.SearchFunction && !this.UnboundMode) {\r\n\r\n            this.doSearchProtected(value, true, this.SearchFunctionContext, (t) => {\r\n                this.Source = t;\r\n                this.tryBindSourceDisplay();\r\n                setTimeout(() => { this.finalizeValue(value); });\r\n            });\r\n            return;\r\n        }\r\n\r\n        if (!this.Multi)\r\n            this.finalizeValue(value);\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.UnboundMode ? null : this.BoundSource.find(t => t.id == value);\r\n        this.propagateChange(val ? val.id : value);\r\n\r\n        // Alor... praticamente qui potrebbero arrivare degli switcheroni in cui il Model è uguale all'inizio e alla fine dello stack, per qualche motivo\r\n        // quindi per assicurarmi che il valore venga preso correttamente faccio il classico metti a null poi metti su\r\n        // Notare che mettere il modello a null scatena i writevalue ma tutti i writevalue che si collegao a questo giro dovrebbero essere NOOP su null\r\n        this.Model = null;\r\n        setTimeout(() => {\r\n            this.Model = val ? val.description : value;\r\n            this.EvaluatedModel = this.Model;\r\n            this.cdr.markForCheck();\r\n        });\r\n    }\r\n\r\n    /**\r\n     * Quando viene scritto un nuovo valore bisogna controllare se per botta di culo fosse un id, in tal caso dev'essere rieffettuato il bind\r\n     * per mostrare solo la descrizione nell'autocomplete\r\n     */\r\n    public evaluateIdResearch(onFailure: Function) {\r\n        let tmpModel = this.Model;\r\n        \r\n        if(this.UnboundMode)\r\n            return;\r\n\r\n        if (!tmpModel || !this.SearchFunction) {\r\n            onFailure?.();\r\n            return;\r\n        }\r\n\r\n        this.log(\"filtersource enqueue\");\r\n        this.throttla(\"filtersource\", () => {\r\n            this.log(\"filtersource fire\");\r\n            this.doSearchProtected(tmpModel, true, this.SearchFunctionContext, (t) => {\r\n                if (t && t.length > 0) {\r\n                    this.Source = t;\r\n                    this.tryBindSourceDisplay();\r\n                    if (!this.Multi)\r\n                        setTimeout(() => { this.finalizeValue(tmpModel); });\r\n                    else\r\n                        this.cdr.markForCheck();\r\n                }\r\n                else\r\n                    onFailure?.();\r\n            });\r\n        }, 400);\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\r\n        // Contorllo prima di tutto se è un ID. in caso contrario effettuo la ricerca\r\n        this.evaluateIdResearch(() => {\r\n            this.doFilterSource(event);\r\n        })\r\n    }\r\n\r\n    doFilterSource(event: string){\r\n        if (this.UnboundMode)\r\n            return;\r\n\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        if (!this.Multi)\r\n            super.changed(null);\r\n\r\n        if (!event && this.MinChars == 0 && !this.SearchFunction) {\r\n            this.FilteredBoundSource = this.BoundSource;\r\n            this.cdr.markForCheck();\r\n            return;\r\n        }\r\n\r\n        if (!event || event.length < this.MinChars) {\r\n            this.log(\"search event ignored: \" + event);\r\n            this.FilteredBoundSource = [];\r\n            this.cdr.markForCheck();\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.log(\"filtersource enqueue\");\r\n            this.throttla(\"filtersource\", () => {\r\n                this.log(\"filtersource fire\");\r\n                this.doSearchProtected(event, false, this.SearchFunctionContext, (t) => {\r\n                    this.log(\"filtersource received API response\");\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                this.log(\"filtersource fire\");\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.removeFilteredSourceOnDescriptionSelection();\r\n                this.cdr.markForCheck();\r\n            }, 100);\r\n        }\r\n    }\r\n\r\n    timer = null;\r\n    maxCallsPerSecond = 4;\r\n    callsDoneThisThreeSeconds = 0;\r\n\r\n    // Permetto al massimo 4 chiamate ogni 3 secondi, se nell'arco di 3 secondi ci sono più di 4 chiamate, ignoro le eccedenti\r\n    private doSearchProtected(search: string, byid: boolean, context?: any, onRes?: Function) {\r\n        if (!this.timer) {\r\n            this.timer = setTimeout(() => {\r\n                this.callsDoneThisThreeSeconds = 0;\r\n                clearTimeout(this.timer);\r\n                this.timer = null;\r\n            }, 3000);\r\n        }\r\n\r\n        if (this.callsDoneThisThreeSeconds >= this.maxCallsPerSecond) {\r\n            this.log(\"Ignoring excessive calls\");\r\n            return;\r\n        }\r\n\r\n        this.callsDoneThisThreeSeconds++;\r\n        this.log(\"Search function being called...\");\r\n        this.SearchFunction(search, byid, context).subscribe(t => {\r\n            onRes(t);\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) && !this.Multi) {\r\n            let model = this.BoundSource[0].id\r\n            this.Model = model;\r\n            this.EvaluatedModel = this.BoundSource[0].description;\r\n            this.FilteredBoundSource = [];\r\n            setTimeout(() => { this.finalizeValue(model); });\r\n        }\r\n    }\r\n\r\n    /** @ignore */\r\n    public ngOnChanges(changes: SimpleChanges) {\r\n        let newSource = changes[\"Source\"];\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.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\r\n    /** @ignore Override che marca anche il prossimo evento di filterSource da ignorare */\r\n    changed(forcedValue: any = null, markForCheck: boolean = false) {\r\n        if (!this.Multi)\r\n            this.ignoreNextWriteValue = true;\r\n\r\n        if (forcedValue == \"\" && this.Multi)\r\n            this.Model = \"\";\r\n\r\n        var selecteds: string[] = forcedValue ? [forcedValue] : this.Model ? (this.Model.Multi ? this.Model.split(',') : [this.Model]) : [];\r\n        this.EvaluatedModel = selecteds.map(s => this.BoundSource && this.BoundSource.length > 0 ? this.BoundSource.find(t => t.id == s)?.description : this.UnboundMode ? s : \"\").join(', ');\r\n\r\n        super.changed(forcedValue, markForCheck);\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<!-- Form-Model: {{Model}} -->\r\n<ng-template #controlTemplate>\r\n    <val-autocomplete *ngIf=\"!Multi\" [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\" [noValidate]=\"!Validation\"\r\n               [submitted]=\"Form?.submitted\"\r\n               [Readonly]=\"Readonly\"\r\n               [label]=\"SelectLabel\"\r\n               type=\"text\"\r\n               [(ngModel)]=\"Model\"\r\n               [id]=\"GeneratedName\"\r\n               name=\"{{GeneratedName}}\"\r\n               #validationControl=\"ngModel\"\r\n               (inputChange)=\"filterSource($event);\"\r\n               (inputFocus)=\"focused($event);\"\r\n               (inputFinalized)=\"finalized()\"\r\n               (optionChange)=\"changed($event);\"\r\n               [placeholder]=\"Required ? ((RequiredPlaceholder != null ? RequiredPlaceholder : (('Seleziona' | localize : lc) + '...'))) : Placeholder\"\r\n               [validationFailed]=\"FailedValidationMessage\"\r\n               [FilteredSource]=\"FilteredBoundSource\">\r\n    </val-autocomplete>\r\n\r\n    <val-autocomplete-multi *ngIf=\"Multi\" [FocusSubject]=\"FocusSubject\" [SetValidationSubject]=\"SetValidationSubject\" [FieldAppearence]=\"FieldAppearence\" [noValidate]=\"!Validation\"\r\n               [submitted]=\"Form?.submitted\"\r\n               [Readonly]=\"Readonly\"\r\n               [label]=\"SelectLabel\"\r\n               [ChipThreshold]=\"MultiElementsThreshold\"\r\n               [HideChoicesOnSelection]=\"HideChoicesOnSelection\"\r\n               type=\"text\"\r\n               [(ngModel)]=\"Model\"\r\n               [id]=\"GeneratedName\"\r\n               name=\"{{GeneratedName}}\"\r\n               #validationControl=\"ngModel\"\r\n               (inputChange)=\"filterSource($event);\"\r\n               (inputFocus)=\"focused($event);\"\r\n               (inputFinalized)=\"finalized()\"\r\n               (optionChange)=\"changed($event);\"\r\n               [placeholder]=\"Required ? ((RequiredPlaceholder != null ? RequiredPlaceholder : (('Seleziona' | localize : lc) + '...'))) : Placeholder\"\r\n               [validationFailed]=\"FailedValidationMessage\"\r\n               [FilteredSource]=\"FilteredBoundSource\"\r\n               [UnboundMode]=\"UnboundMode\">\r\n\r\n    </val-autocomplete-multi>\r\n</ng-template>"]}
|
|
@@ -1,74 +0,0 @@
|
|
|
1
|
-
// Angular
|
|
2
|
-
import { NG_VALIDATORS } from "@angular/forms";
|
|
3
|
-
import { Component, Inject, Optional, Self, ChangeDetectionStrategy, Input } from "@angular/core";
|
|
4
|
-
// Applicazione
|
|
5
|
-
import { BaseFormControl } from "../base-form-control";
|
|
6
|
-
import { ACO_CUSTOMKEY, FAV_DEBUG_MODE, FAV_SLIDER_MODE } from '../../tokens';
|
|
7
|
-
import * as i0 from "@angular/core";
|
|
8
|
-
import * as i1 from "@esfaenza/localizations";
|
|
9
|
-
import * as i2 from "@angular/forms";
|
|
10
|
-
import * as i3 from "@esfaenza/access-control";
|
|
11
|
-
import * as i4 from "@angular/common";
|
|
12
|
-
/** Componente rappresentante una checkbox */
|
|
13
|
-
export class FormCheckboxComponent extends BaseFormControl {
|
|
14
|
-
/** @ignore Costruttore */
|
|
15
|
-
constructor(lc, cdr, ngControl, _validators, ac, AppContext, ACO_CUSTOMKEY, FAV_SLIDER_MODE, FAV_DEBUG_MODE) {
|
|
16
|
-
super(cdr, ngControl, _validators, ac, AppContext, ACO_CUSTOMKEY, FAV_DEBUG_MODE);
|
|
17
|
-
this.lc = lc;
|
|
18
|
-
this.FAV_SLIDER_MODE = FAV_SLIDER_MODE;
|
|
19
|
-
/** Mostra l'input checkbox con lo stile di uno slider */
|
|
20
|
-
this.SliderMode = null;
|
|
21
|
-
}
|
|
22
|
-
ngOnInit() {
|
|
23
|
-
super.ngOnInit();
|
|
24
|
-
if (this.SliderMode == null)
|
|
25
|
-
this.SliderMode = this.FAV_SLIDER_MODE;
|
|
26
|
-
}
|
|
27
|
-
/** @ignore */
|
|
28
|
-
writeValue(obj) {
|
|
29
|
-
obj = obj ? (obj === true || obj.toLowerCase() == "true") : false;
|
|
30
|
-
this.EvaluatedModel = this.lc.loc(obj ? 'Sì' : 'No');
|
|
31
|
-
super.writeValue(obj);
|
|
32
|
-
}
|
|
33
|
-
changed() {
|
|
34
|
-
this.EvaluatedModel = this.lc.loc(this.Model ? 'Sì' : 'No');
|
|
35
|
-
super.changed(null, false, true);
|
|
36
|
-
}
|
|
37
|
-
/** @ignore */
|
|
38
|
-
onNotNullValueSet() { }
|
|
39
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormCheckboxComponent, deps: [{ token: i1.LocalizationService }, { token: i0.ChangeDetectorRef }, { token: i2.NgControl, optional: true, self: true }, { token: NG_VALIDATORS, optional: true }, { token: i3.AccessControlService }, { token: i3.ComponentContext, optional: true }, { token: ACO_CUSTOMKEY, optional: true }, { token: FAV_SLIDER_MODE, optional: true }, { token: FAV_DEBUG_MODE, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
40
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: FormCheckboxComponent, selector: "form-checkbox", inputs: { SliderMode: "SliderMode" }, usesInheritance: 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\" class=\"app-inline-block\"><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>\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 <ng-container *ngIf=\"SliderMode\">\r\n <label class=\"toggler-wrapper slider-checkbox\">\r\n <input [disabled]=\"Readonly ? true : null\" type=\"checkbox\" [(ngModel)]=\"Model\" id=\"{{GeneratedName}}\" name=\"{{GeneratedName}}\" #validationControl=\"ngModel\" (ngModelChange)=\"changed(); finalized()\" (click)=\"focused($event)\" >\r\n <div class=\"toggler-slider\">\r\n <div class=\"toggler-knob\"></div>\r\n </div>\r\n </label>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"!SliderMode\">\r\n <input class=\"app-pointer\" [disabled]=\"Readonly ? true : null\" type=\"checkbox\" [(ngModel)]=\"Model\" id=\"{{GeneratedName}}\" name=\"{{GeneratedName}}\" #validationControl=\"ngModel\" (ngModelChange)=\"changed(); finalized()\" (click)=\"focused($event)\"/>\r\n </ng-container>\r\n</ng-template>", styles: [".toggler-wrapper{display:block;width:45px;height:25px;cursor:pointer;position:relative}.toggler-wrapper input[type=checkbox]{display:none}.toggler-wrapper input[type=checkbox]:checked+.toggler-slider{background-color:#007bff}.toggler-wrapper .toggler-slider{background-color:#ccc;position:absolute;border-radius:100px;top:0;left:0;width:100%;height:100%;-webkit-transition:all .3s ease;transition:all .3s ease}.toggler-wrapper .toggler-knob{position:absolute;-webkit-transition:all .3s ease;transition:all .3s ease}.slider-checkbox{margin-top:3px}.toggler-wrapper.slider-checkbox input[type=checkbox]:checked+.toggler-slider .toggler-knob{left:calc(100% - 22px)}.toggler-wrapper.slider-checkbox .toggler-slider:after{position:absolute;top:50%;right:-25px;-webkit-transform:translateY(-50%);transform:translateY(-50%);font-size:75%;text-transform:uppercase;font-weight:500;opacity:.7}.toggler-wrapper.slider-checkbox .toggler-knob{width:19px;height:19px;border-radius:50%;left:3px;top:3px;background-color:#fff}\n"], dependencies: [{ kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.CheckboxControlValueAccessor, selector: "input[type=checkbox][formControlName],input[type=checkbox][formControl],input[type=checkbox][ngModel]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
41
|
-
}
|
|
42
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: FormCheckboxComponent, decorators: [{
|
|
43
|
-
type: Component,
|
|
44
|
-
args: [{ selector: "form-checkbox", 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\" class=\"app-inline-block\"><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>\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 <ng-container *ngIf=\"SliderMode\">\r\n <label class=\"toggler-wrapper slider-checkbox\">\r\n <input [disabled]=\"Readonly ? true : null\" type=\"checkbox\" [(ngModel)]=\"Model\" id=\"{{GeneratedName}}\" name=\"{{GeneratedName}}\" #validationControl=\"ngModel\" (ngModelChange)=\"changed(); finalized()\" (click)=\"focused($event)\" >\r\n <div class=\"toggler-slider\">\r\n <div class=\"toggler-knob\"></div>\r\n </div>\r\n </label>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"!SliderMode\">\r\n <input class=\"app-pointer\" [disabled]=\"Readonly ? true : null\" type=\"checkbox\" [(ngModel)]=\"Model\" id=\"{{GeneratedName}}\" name=\"{{GeneratedName}}\" #validationControl=\"ngModel\" (ngModelChange)=\"changed(); finalized()\" (click)=\"focused($event)\"/>\r\n </ng-container>\r\n</ng-template>", styles: [".toggler-wrapper{display:block;width:45px;height:25px;cursor:pointer;position:relative}.toggler-wrapper input[type=checkbox]{display:none}.toggler-wrapper input[type=checkbox]:checked+.toggler-slider{background-color:#007bff}.toggler-wrapper .toggler-slider{background-color:#ccc;position:absolute;border-radius:100px;top:0;left:0;width:100%;height:100%;-webkit-transition:all .3s ease;transition:all .3s ease}.toggler-wrapper .toggler-knob{position:absolute;-webkit-transition:all .3s ease;transition:all .3s ease}.slider-checkbox{margin-top:3px}.toggler-wrapper.slider-checkbox input[type=checkbox]:checked+.toggler-slider .toggler-knob{left:calc(100% - 22px)}.toggler-wrapper.slider-checkbox .toggler-slider:after{position:absolute;top:50%;right:-25px;-webkit-transform:translateY(-50%);transform:translateY(-50%);font-size:75%;text-transform:uppercase;font-weight:500;opacity:.7}.toggler-wrapper.slider-checkbox .toggler-knob{width:19px;height:19px;border-radius:50%;left:3px;top:3px;background-color:#fff}\n"] }]
|
|
45
|
-
}], ctorParameters: () => [{ type: i1.LocalizationService }, { type: i0.ChangeDetectorRef }, { type: i2.NgControl, decorators: [{
|
|
46
|
-
type: Optional
|
|
47
|
-
}, {
|
|
48
|
-
type: Self
|
|
49
|
-
}] }, { type: Array, decorators: [{
|
|
50
|
-
type: Optional
|
|
51
|
-
}, {
|
|
52
|
-
type: Inject,
|
|
53
|
-
args: [NG_VALIDATORS]
|
|
54
|
-
}] }, { type: i3.AccessControlService }, { type: i3.ComponentContext, decorators: [{
|
|
55
|
-
type: Optional
|
|
56
|
-
}] }, { type: undefined, decorators: [{
|
|
57
|
-
type: Optional
|
|
58
|
-
}, {
|
|
59
|
-
type: Inject,
|
|
60
|
-
args: [ACO_CUSTOMKEY]
|
|
61
|
-
}] }, { type: undefined, decorators: [{
|
|
62
|
-
type: Optional
|
|
63
|
-
}, {
|
|
64
|
-
type: Inject,
|
|
65
|
-
args: [FAV_SLIDER_MODE]
|
|
66
|
-
}] }, { type: undefined, decorators: [{
|
|
67
|
-
type: Optional
|
|
68
|
-
}, {
|
|
69
|
-
type: Inject,
|
|
70
|
-
args: [FAV_DEBUG_MODE]
|
|
71
|
-
}] }], propDecorators: { SliderMode: [{
|
|
72
|
-
type: Input
|
|
73
|
-
}] } });
|
|
74
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-checkbox.component.js","sourceRoot":"","sources":["../../../../../../projects/forms-and-validations/src/lib/forms/form-checkbox/form-checkbox.component.ts","../../../../../../projects/forms-and-validations/src/lib/forms/form-checkbox/form-checkbox.component.html"],"names":[],"mappings":"AAAA,UAAU;AACV,OAAO,EAAwB,aAAa,EAAa,MAAM,gBAAgB,CAAC;AAChF,OAAO,EAAE,SAAS,EAAE,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAQ,uBAAuB,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAIxG,eAAe;AACf,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,EAAE,aAAa,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;;;;;;AAI9E,6CAA6C;AAO7C,MAAM,OAAO,qBAAsB,SAAQ,eAAe;IAKtD,2BAA2B;IAC3B,YAAoB,EAAuB,EAAE,GAAsB,EAAsB,SAAoB,EAAqC,WAAuB,EAAE,EAAwB,EAAc,UAA4B,EAAqC,aAAqB,EAA+C,eAAwB,EAAsC,cAAuB;QACva,KAAK,CAAC,GAAG,EAAE,SAAS,EAAE,WAAW,EAAE,EAAE,EAAE,UAAU,EAAE,aAAa,EAAE,cAAc,CAAC,CAAC;QADlE,OAAE,GAAF,EAAE,CAAqB;QAA2S,oBAAe,GAAf,eAAe,CAAS;QAJ9W,yDAAyD;QAChD,eAAU,GAAY,IAAI,CAAC;IAKpC,CAAC;IAED,QAAQ;QACJ,KAAK,CAAC,QAAQ,EAAE,CAAC;QACjB,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI;YACvB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,eAAe,CAAC;IAC/C,CAAC;IAED,cAAc;IACd,UAAU,CAAC,GAAQ;QACf,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,KAAK,IAAI,IAAI,GAAG,CAAC,WAAW,EAAE,IAAI,MAAM,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;QAClE,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;QAErD,KAAK,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC;IAC1B,CAAC;IAED,OAAO;QACH,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;QAC5D,KAAK,CAAC,OAAO,CAAC,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC;IACrC,CAAC;IAED,cAAc;IACd,iBAAiB,KAAW,CAAC;+GA9BpB,qBAAqB,2IAMqG,aAAa,iHAAmH,aAAa,6BAA6C,eAAe,6BAAwD,cAAc;mGANzY,qBAAqB,kHCnBlC,imGAqCc;;4FDlBD,qBAAqB;kBANjC,SAAS;+BACI,eAAe,mBAGR,uBAAuB,CAAC,MAAM;;0BAQuB,QAAQ;;0BAAI,IAAI;;0BAA0B,QAAQ;;0BAAI,MAAM;2BAAC,aAAa;;0BAAsD,QAAQ;;0BAAkC,QAAQ;;0BAAI,MAAM;2BAAC,aAAa;;0BAA0B,QAAQ;;0BAAI,MAAM;2BAAC,eAAe;;0BAAqC,QAAQ;;0BAAI,MAAM;2BAAC,cAAc;yCAHzY,UAAU;sBAAlB,KAAK","sourcesContent":["// Angular\r\nimport { ControlValueAccessor, NG_VALIDATORS, NgControl } from \"@angular/forms\";\r\nimport { Component, Inject, Optional, Self, Host, ChangeDetectionStrategy, Input } from \"@angular/core\";\r\n\r\nimport { AccessControlService, ComponentContext } from '@esfaenza/access-control';\r\n\r\n// Applicazione\r\nimport { BaseFormControl } from \"../base-form-control\";\r\nimport { ACO_CUSTOMKEY, FAV_DEBUG_MODE, FAV_SLIDER_MODE } from '../../tokens';\r\nimport { ChangeDetectorRef } from \"@angular/core\";\r\nimport { LocalizationService } from \"@esfaenza/localizations\";\r\n\r\n/** Componente rappresentante una checkbox */\r\n@Component({\r\n    selector: \"form-checkbox\",\r\n    templateUrl: \"form-checkbox.component.html\",\r\n    styleUrls: [\"form-checkbox.component.scss\"],\r\n    changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class FormCheckboxComponent extends BaseFormControl implements ControlValueAccessor {\r\n\r\n    /** Mostra l'input checkbox con lo stile di uno slider */\r\n    @Input() SliderMode: boolean = null;\r\n\r\n    /** @ignore Costruttore  */\r\n    constructor(private lc: LocalizationService, cdr: ChangeDetectorRef, @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_SLIDER_MODE) private FAV_SLIDER_MODE: boolean, @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\r\n    ngOnInit() {\r\n        super.ngOnInit();\r\n        if (this.SliderMode == null)\r\n            this.SliderMode = this.FAV_SLIDER_MODE;\r\n    }\r\n\r\n    /** @ignore */\r\n    writeValue(obj: any): void {\r\n        obj = obj ? (obj === true || obj.toLowerCase() == \"true\") : false;\r\n        this.EvaluatedModel = this.lc.loc(obj ? 'Sì' : 'No');\r\n\r\n        super.writeValue(obj);\r\n    }\r\n\r\n    changed(): void {\r\n        this.EvaluatedModel = this.lc.loc(this.Model ? 'Sì' : 'No');\r\n        super.changed(null, false, true);\r\n    }\r\n\r\n    /** @ignore */\r\n    onNotNullValueSet(): void { }\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\" class=\"app-inline-block\"><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>\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    <ng-container *ngIf=\"SliderMode\">\r\n        <label class=\"toggler-wrapper slider-checkbox\">\r\n            <input [disabled]=\"Readonly ? true : null\" type=\"checkbox\" [(ngModel)]=\"Model\" id=\"{{GeneratedName}}\" name=\"{{GeneratedName}}\" #validationControl=\"ngModel\" (ngModelChange)=\"changed(); finalized()\" (click)=\"focused($event)\" >\r\n            <div class=\"toggler-slider\">\r\n              <div class=\"toggler-knob\"></div>\r\n            </div>\r\n        </label>\r\n    </ng-container>\r\n\r\n    <ng-container *ngIf=\"!SliderMode\">\r\n        <input class=\"app-pointer\" [disabled]=\"Readonly ? true : null\" type=\"checkbox\" [(ngModel)]=\"Model\" id=\"{{GeneratedName}}\" name=\"{{GeneratedName}}\" #validationControl=\"ngModel\" (ngModelChange)=\"changed(); finalized()\" (click)=\"focused($event)\"/>\r\n    </ng-container>\r\n</ng-template>"]}
|