@eqproject/eqp-attachments 3.0.0 → 3.0.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (51) hide show
  1. package/{esm2020 → esm2022}/eqproject-eqp-attachments.mjs +4 -4
  2. package/esm2022/lib/directives/eqp-common/dynamic-loader/dynamic-loader.directive.mjs +53 -0
  3. package/esm2022/lib/directives/eqp-common/eqp-common.service.mjs +78 -0
  4. package/esm2022/lib/directives/eqp-common/index.mjs +10 -0
  5. package/esm2022/lib/directives/eqp-common/models/base-field.model.mjs +57 -0
  6. package/esm2022/lib/directives/eqp-common/models/common-enum.model.mjs +8 -0
  7. package/esm2022/lib/directives/eqp-common/models/config-column.model.mjs +116 -0
  8. package/esm2022/lib/directives/eqp-common/models/filterConfig.model.mjs +318 -0
  9. package/esm2022/lib/directives/eqp-common/models/filterField.model.mjs +254 -0
  10. package/esm2022/lib/directives/eqp-common/models/form.model.mjs +168 -0
  11. package/esm2022/lib/directives/eqp-common/models/linqFilterResult.model.mjs +73 -0
  12. package/esm2022/lib/directives/eqp-common/models/tableColumn-field.model.mjs +107 -0
  13. package/esm2022/lib/eqp-attachments.component.mjs +1096 -0
  14. package/{esm2020 → esm2022}/lib/eqp-attachments.module.mjs +43 -43
  15. package/esm2022/lib/helpers/attachment.helper.mjs +66 -0
  16. package/{esm2020 → esm2022}/lib/interfaces/IAttachment.mjs +11 -11
  17. package/{esm2020 → esm2022}/lib/interfaces/IOptions.mjs +1 -1
  18. package/{esm2020 → esm2022}/lib/modules/material.module.mjs +231 -231
  19. package/{esm2020 → esm2022}/lib/services/eqp-attachment-dialog.service.mjs +103 -103
  20. package/{esm2020 → esm2022}/lib/services/eqp-attachment.service.mjs +23 -23
  21. package/{esm2020 → esm2022}/public-api.mjs +9 -9
  22. package/fesm2022/eqproject-eqp-attachments.mjs +2730 -0
  23. package/fesm2022/eqproject-eqp-attachments.mjs.map +1 -0
  24. package/index.d.ts +5 -5
  25. package/lib/directives/eqp-common/dynamic-loader/dynamic-loader.directive.d.ts +17 -0
  26. package/lib/directives/eqp-common/eqp-common.service.d.ts +21 -0
  27. package/lib/directives/eqp-common/index.d.ts +9 -0
  28. package/lib/directives/eqp-common/models/base-field.model.d.ts +52 -0
  29. package/lib/directives/eqp-common/models/common-enum.model.d.ts +6 -0
  30. package/lib/directives/eqp-common/models/config-column.model.d.ts +113 -0
  31. package/lib/directives/eqp-common/models/filterConfig.model.d.ts +264 -0
  32. package/lib/directives/eqp-common/models/filterField.model.d.ts +144 -0
  33. package/lib/directives/eqp-common/models/form.model.d.ts +129 -0
  34. package/lib/directives/eqp-common/models/linqFilterResult.model.d.ts +58 -0
  35. package/lib/directives/eqp-common/models/tableColumn-field.model.d.ts +31 -0
  36. package/lib/eqp-attachments.component.d.ts +319 -318
  37. package/lib/eqp-attachments.module.d.ts +13 -13
  38. package/lib/helpers/attachment.helper.d.ts +20 -20
  39. package/lib/interfaces/IAttachment.d.ts +21 -21
  40. package/lib/interfaces/IOptions.d.ts +11 -11
  41. package/lib/modules/material.module.d.ts +37 -37
  42. package/lib/services/eqp-attachment-dialog.service.d.ts +31 -31
  43. package/lib/services/eqp-attachment.service.d.ts +7 -7
  44. package/package.json +5 -11
  45. package/public-api.d.ts +6 -6
  46. package/esm2020/lib/eqp-attachments.component.mjs +0 -1064
  47. package/esm2020/lib/helpers/attachment.helper.mjs +0 -66
  48. package/fesm2015/eqproject-eqp-attachments.mjs +0 -1535
  49. package/fesm2015/eqproject-eqp-attachments.mjs.map +0 -1
  50. package/fesm2020/eqproject-eqp-attachments.mjs +0 -1532
  51. package/fesm2020/eqproject-eqp-attachments.mjs.map +0 -1
@@ -0,0 +1,318 @@
1
+ /**
2
+ * Classe utilizzata per la configurazione di filtri custom
3
+ */
4
+ export class FilterConfig {
5
+ constructor(filterID, filterClass, label, propertyName, propertyValue, inputType, wherePartType, cvlConfig, preventRemoval) {
6
+ this.FilterID = filterID;
7
+ if (filterClass)
8
+ this.FilterClass = filterClass;
9
+ this.Label = label;
10
+ this.PropertyName = propertyName;
11
+ this.PropertyObject = propertyValue;
12
+ this.InputType = inputType;
13
+ this.WherePartType = wherePartType;
14
+ this.PreventRemoval = preventRemoval;
15
+ this.EnumData = cvlConfig?.EnumData;
16
+ this.ArrayData = cvlConfig?.ArrayData;
17
+ this.ArrayKeyProperty = cvlConfig?.ArrayKeyProperty;
18
+ this.ArrayValueProperty = cvlConfig?.ArrayValueProperty;
19
+ this.IsEnumSearchable = cvlConfig?.IsSearchable;
20
+ this.ShowEnumCancelButton = cvlConfig?.ShowCancelButton;
21
+ this.EnumSearchText = cvlConfig?.SearchText;
22
+ this.IsEnumMultiSelect = cvlConfig?.IsMultiSelect;
23
+ this.BindLookupFullObject = cvlConfig?.BindFullObject;
24
+ }
25
+ /**
26
+ * Identificativo univoco del filtro
27
+ */
28
+ FilterID;
29
+ /**
30
+ * Permette di definire la classe css da applicare
31
+ * al filtro
32
+ */
33
+ FilterClass = FilterSizeClass.SMALL;
34
+ /**
35
+ *
36
+ */
37
+ CustomFilterClasses;
38
+ /**
39
+ * Etichetta da mostrare per il filtro
40
+ */
41
+ Label;
42
+ /**
43
+ * Valore della proprietà dell'oggetto su cui andrà applicato il filtro
44
+ */
45
+ PropertyName;
46
+ /**
47
+ * Valore da usare per il filtro.
48
+ */
49
+ PropertyObject;
50
+ /**
51
+ * Definisce il tipo di filtro da applicare (valori ammessi in base all'enumeratore InputType)
52
+ */
53
+ InputType;
54
+ /**
55
+ * Definisce il tipo di operatore logico da utilizzare per la where part
56
+ */
57
+ WherePartType;
58
+ /**
59
+ * Se il filtro è di tipo CVL o CVLEnum allora in questa proprietà ci va definita la configurazione della cvl.
60
+ * La cvl verrà renderizzata con una eqp-select
61
+ */
62
+ CvlConfig;
63
+ /**
64
+ * Permette di definire il template esterno da renderizzare come filtro.
65
+ */
66
+ Externaltemplate;
67
+ /**
68
+ * Permette di disabilitare la cancellazione del filtro all'utente.
69
+ * Di default assume il valore FALSE (se true allora nel riepilogo dei filtri applicati non sarà mostrato il pulsante X)
70
+ */
71
+ PreventRemoval = false;
72
+ /**
73
+ * Permette di definire una funzione custom esterna da richiamare per il filtro corrente quando vengono premuti i pulsanti APPLICA FILTRI
74
+ * o RESET
75
+ */
76
+ CustomWherePartFunction;
77
+ /**
78
+ * Permette di definire la funzione custom per restituire il valore del filtro applicato, da mostrare nell'header della card
79
+ *
80
+ */
81
+ CustomAppliedFilterInfoFunction;
82
+ /**
83
+ * Per i filtri di tipo ContainsElement e NotContainsElement che si basano sull'applicazione di una where part con l'operatore
84
+ * Linq ANY allora questa proprietà permette di definire il nome della proprietà degli oggetti figli su cui applicare la where part.
85
+ * In questo caso dentro PropertyName ci andrà il nome della proprietà contenente la lista di child.
86
+ *
87
+ * (Es: PropertyName = 'Users' e ChildElementPropertyName = 'Role' per filtrare i record che contengono una lista di utenti con uno specifico)
88
+ */
89
+ ChildElementPropertyName;
90
+ static CreateStandardFilterConfig(filterID, label, propertyName, type, wherePartType, filterClass, filterCvlConfig, externaltemplate, customWherePartFunction, childElementPropertyName, filterValue, preventRemoval) {
91
+ let filter = new FilterConfig(filterID, filterClass, label, propertyName, null, type, wherePartType, filterCvlConfig, preventRemoval);
92
+ if (externaltemplate)
93
+ filter.Externaltemplate = externaltemplate;
94
+ if (customWherePartFunction)
95
+ filter.CustomWherePartFunction = customWherePartFunction;
96
+ if (childElementPropertyName)
97
+ filter.ChildElementPropertyName = childElementPropertyName;
98
+ if (filterValue)
99
+ filter.PropertyObject = filterValue;
100
+ return filter;
101
+ }
102
+ /**
103
+ * Se la CVL si basa su un enumeratore allora in questa proprietà va definito il type dell'enumeratore da usare.
104
+ * In questo modo la sorgente dati della CVL sarà l'insieme dei valori definiti per l'enumeratore
105
+ */
106
+ EnumData;
107
+ /**
108
+ * Se la CVL si basa su un array allora in questa proprietà va definito l'array da mostrare come sorgente dati della CVL
109
+ */
110
+ ArrayData;
111
+ /**
112
+ * Nel caso di ArrayData definito permette di indicare la proprietà degli oggetti dell'array da bindare al filtro
113
+ */
114
+ ArrayKeyProperty;
115
+ /**
116
+ * Nel caso di ArrayData definito permette di indicare la proprietà degli oggetti da visualizzare nel filtro
117
+ */
118
+ ArrayValueProperty;
119
+ /**
120
+ * Se TRUE allora mostra il campo di ricerca all'interno della CVL (default: TRUE)
121
+ */
122
+ IsEnumSearchable = false;
123
+ /**
124
+ * Se TRUE allora mostra il pulsante per pulire la selezione della CVL (default: TRUE)
125
+ */
126
+ ShowEnumCancelButton = true;
127
+ /**
128
+ * Permette di definire l'etichetta per il campo di ricerca della CVL (default: 'Cerca')
129
+ */
130
+ EnumSearchText = "Cerca";
131
+ /**
132
+ * Permette di definire la multi selezione dei valori della CVL (default: false)
133
+ */
134
+ IsEnumMultiSelect = false;
135
+ /**
136
+ * Se TRUE allora mostra il campo di ricerca all'interno della lookup (default: TRUE)
137
+ */
138
+ IsLookupSearchable = false;
139
+ /**
140
+ * Se TRUE allora mostra il pulsante per pulire la selezione della lookup (default: TRUE)
141
+ */
142
+ ShowLookupCancelButton = true;
143
+ /**
144
+ * Permette di definire l'etichetta per il campo di ricerca della Lookup (default: 'Cerca')
145
+ */
146
+ LookupSearchText = "Cerca";
147
+ /**
148
+ * Permette di definire la multi selezione dei valori della lookup (default: false)
149
+ */
150
+ IsLookupMultiple = false;
151
+ /**
152
+ * Permette di definire se nella lookup il binding deve considerare tutto l'oggetto
153
+ * (default: true)
154
+ */
155
+ BindLookupFullObject = true;
156
+ /**
157
+ * Permette di definire l'entità della lookup
158
+ */
159
+ LookupEntityType = null;
160
+ /**
161
+ * Permette di definire l'url per effettuare la chiamata che popola la lookup
162
+ */
163
+ LookupFullUrlHttpCall = null;
164
+ /**
165
+ * Permette di definire (in maniera opzionale) gli eventuali predicati standard da applicare nel recuperare gli item per la lookup
166
+ */
167
+ DataFilter = null;
168
+ /**
169
+ * Permette di definire un oggetto contenente la funzione di validazione e la label del suggerimento per validare il campo del filtro
170
+ */
171
+ ValidationProperties;
172
+ }
173
+ /**
174
+ * Classe che permette di configurare una eqp-select (CVL) per uno specifico filtro
175
+ */
176
+ export class FilterCvlConfig {
177
+ /**
178
+ * Se la CVL si basa su un enumeratore allora in questa proprietà va definito il type dell'enumeratore da usare.
179
+ * In questo modo la sorgente dati della CVL sarà l'insieme dei valori definiti per l'enumeratore
180
+ */
181
+ EnumData;
182
+ /**
183
+ * Se la CVL si basa su un array allora in questa proprietà va definito l'array da mostrare come sorgente dati della CVL
184
+ */
185
+ ArrayData;
186
+ /**
187
+ * Nel caso di ArrayData definito permette di indicare la proprietà degli oggetti dell'array da bindare al filtro
188
+ */
189
+ ArrayKeyProperty;
190
+ /**
191
+ * Nel caso di ArrayData definito permette di indicare la proprietà degli oggetti da visualizzare nel filtro
192
+ */
193
+ ArrayValueProperty;
194
+ /**
195
+ * Se TRUE allora mostra il campo di ricerca all'interno della CVL (default: TRUE)
196
+ */
197
+ IsSearchable = false;
198
+ /**
199
+ * Se TRUE allora mostra il pulsante per pulire la selezione della CVL (default: TRUE)
200
+ */
201
+ ShowCancelButton = true;
202
+ /**
203
+ * Permette di definire l'etichetta per il campo di ricerca (default: 'Cerca')
204
+ */
205
+ SearchText = "Cerca";
206
+ /**
207
+ * Permette di definire la multi selezione dei valori della CVL (default: false)
208
+ */
209
+ IsMultiSelect = false;
210
+ /**
211
+ * Permette di definire se nella CVL il binding deve considera tutto l'oggetto o solo la proprietà
212
+ * definita dentro ArrayKeyProperty
213
+ * (default: true)
214
+ */
215
+ BindFullObject = true;
216
+ /**
217
+ * Dati gli opportuni parametri restituisce un oggetto FilterCvlConfig pronto all'uso.
218
+ * @param enumData Type dell'enumeratore da usare nella cvl (opzionale)
219
+ * @param arrayData Array da usare nella cvl (opzionale)
220
+ * @param arrayKeyProperty Nome della proprietà da usare come binding (opzionale)
221
+ * @param arrayValueProperty Nome della proprietà da mostrare nella CVL (opzionale)
222
+ * @param isMultiSelect Attiva o disattiva la multiselezione (opzionale)
223
+ * @param isSearchable Attiva o disattiva la ricerca nella CVL (opzionale)
224
+ * @param showCancelButton Attiva o disattiva il pulsante per pulire la selezione nella CVL (opzionale)
225
+ * @param searchText Definisce l'etichetta del campo di ricerca (opzionale)
226
+ * @returns Valida i parametri e restituisce un oggetto di tipo FilterCvlConfig
227
+ */
228
+ static CreateFilterCVLConfig(enumData, arrayData, arrayKeyProperty, arrayValueProperty, isMultiSelect, isSearchable, showCancelButton, searchText, bindFullObject) {
229
+ let cvlConfig = new FilterCvlConfig();
230
+ if ((enumData == null || enumData == undefined) && (arrayData == null || arrayData == undefined)) {
231
+ throw new Error("It's mandatory to define one of the enumData or enumArray properties");
232
+ }
233
+ cvlConfig.ArrayData = arrayData;
234
+ cvlConfig.EnumData = enumData;
235
+ cvlConfig.ArrayKeyProperty = arrayKeyProperty;
236
+ cvlConfig.ArrayValueProperty = arrayValueProperty;
237
+ if (isMultiSelect != null)
238
+ cvlConfig.IsMultiSelect = isMultiSelect;
239
+ if (isSearchable != null)
240
+ cvlConfig.IsSearchable = isSearchable;
241
+ if (showCancelButton != null)
242
+ cvlConfig.ShowCancelButton = showCancelButton;
243
+ if (searchText)
244
+ cvlConfig.SearchText = searchText;
245
+ if (bindFullObject != null)
246
+ cvlConfig.BindFullObject = bindFullObject;
247
+ return cvlConfig;
248
+ }
249
+ }
250
+ /**
251
+ * Classe utilizzata per memorizzare le informazioni sui filtri salvati nel local storage.
252
+ * Utilizzata solo se per la direttiva eqp-filters è stato richiesto il salvataggio dei filtri
253
+ */
254
+ export class SavedFilterItem {
255
+ FilterName;
256
+ PreventRemoval;
257
+ }
258
+ export var InputType;
259
+ (function (InputType) {
260
+ InputType[InputType["Text"] = 1] = "Text";
261
+ InputType[InputType["Number"] = 2] = "Number";
262
+ InputType[InputType["Date"] = 3] = "Date";
263
+ InputType[InputType["Datetime"] = 4] = "Datetime";
264
+ InputType[InputType["CvlEnum"] = 5] = "CvlEnum";
265
+ InputType[InputType["Cvl"] = 6] = "Cvl";
266
+ InputType[InputType["Boolean"] = 7] = "Boolean";
267
+ InputType[InputType["BooleanCvl"] = 8] = "BooleanCvl";
268
+ InputType[InputType["CustomTemplate"] = 9] = "CustomTemplate";
269
+ InputType[InputType["DateRange"] = 10] = "DateRange";
270
+ InputType[InputType["Lookup"] = 11] = "Lookup";
271
+ })(InputType || (InputType = {}));
272
+ export var WherePartType;
273
+ (function (WherePartType) {
274
+ WherePartType[WherePartType["Equal"] = 1] = "Equal";
275
+ WherePartType[WherePartType["NotEqual"] = 2] = "NotEqual";
276
+ WherePartType[WherePartType["StringContains"] = 3] = "StringContains";
277
+ WherePartType[WherePartType["StringNotContains"] = 4] = "StringNotContains";
278
+ WherePartType[WherePartType["GreaterThan"] = 5] = "GreaterThan";
279
+ WherePartType[WherePartType["GreaterThanOrEqual"] = 6] = "GreaterThanOrEqual";
280
+ WherePartType[WherePartType["LessThan"] = 7] = "LessThan";
281
+ WherePartType[WherePartType["LessThanOrEqual"] = 8] = "LessThanOrEqual";
282
+ WherePartType[WherePartType["ContainsElement"] = 9] = "ContainsElement";
283
+ WherePartType[WherePartType["NotContainsElement"] = 10] = "NotContainsElement";
284
+ })(WherePartType || (WherePartType = {}));
285
+ export var FilterSizeClass;
286
+ (function (FilterSizeClass) {
287
+ FilterSizeClass[FilterSizeClass["SMALL"] = 1] = "SMALL";
288
+ FilterSizeClass[FilterSizeClass["MEDIUM"] = 2] = "MEDIUM";
289
+ FilterSizeClass[FilterSizeClass["LARGE"] = 3] = "LARGE";
290
+ FilterSizeClass[FilterSizeClass["CUSTOM"] = 4] = "CUSTOM";
291
+ })(FilterSizeClass || (FilterSizeClass = {}));
292
+ /**
293
+ * Enumeratore usato come input del componente eqp-filter.
294
+ * Permette di indicare la complessità dell'oggetto da restituire quando viene premuto
295
+ * il pulsante Applica FIltri.
296
+ * La documentazione delle due tipologie è stata riportata nel metodo createFilterValue del componente
297
+ * eqp-filters.component.ts
298
+ */
299
+ export var FilterResultType;
300
+ (function (FilterResultType) {
301
+ FilterResultType[FilterResultType["BASIC"] = 1] = "BASIC";
302
+ FilterResultType[FilterResultType["ADVANCED"] = 2] = "ADVANCED";
303
+ })(FilterResultType || (FilterResultType = {}));
304
+ /**
305
+ * Utilizzato per battezzare il comportamento e l'aspetto grafico della direttiva eqp-filters.
306
+ * WITH_CARD: viene renderizzata una card espandibile e i filtri sono visualizzati nel mat-card-content. Quando si applicano i filtri nel card-header vengono riepilogati i filtri applicati
307
+ * WITH_BUTTON: viene renderizzato un pulsante (con lo stesso stile del card-header precedente). Alla pressione del pulsante si apre una modale contenente tutti i filtri. Quando si applicano o resettano i filtri la modale si chiude e nel pulsante vengono riepilogati i filtri applicati
308
+ */
309
+ export var FilterMode;
310
+ (function (FilterMode) {
311
+ FilterMode[FilterMode["WITH_CARD"] = 1] = "WITH_CARD";
312
+ FilterMode[FilterMode["WITH_BUTTON"] = 2] = "WITH_BUTTON";
313
+ })(FilterMode || (FilterMode = {}));
314
+ export class ValidationObject {
315
+ Valid;
316
+ HintLabel;
317
+ }
318
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filterConfig.model.js","sourceRoot":"","sources":["../../../../../../../projects/eqp-attachments/src/lib/directives/eqp-common/models/filterConfig.model.ts"],"names":[],"mappings":"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","sourcesContent":["import { TemplateRef } from \"@angular/core\";\r\nimport { LinqPredicateDTO } from './linqFilterResult.model';\r\n\r\n/**\r\n * Classe utilizzata per la configurazione di filtri custom\r\n */\r\nexport class FilterConfig {\r\n  constructor(filterID?: string,\r\n    filterClass?: FilterSizeClass,\r\n    label?: string,\r\n    propertyName?: string,\r\n    propertyValue?: any,\r\n    inputType?: InputType,\r\n    wherePartType?: WherePartType,\r\n    cvlConfig?: FilterCvlConfig,\r\n    preventRemoval?: boolean) {\r\n\r\n    this.FilterID = filterID;\r\n    if (filterClass) this.FilterClass = filterClass;\r\n\r\n    this.Label = label;\r\n    this.PropertyName = propertyName;\r\n    this.PropertyObject = propertyValue;\r\n    this.InputType = inputType;\r\n    this.WherePartType = wherePartType;\r\n    this.PreventRemoval = preventRemoval;\r\n    this.EnumData = cvlConfig?.EnumData;\r\n    this.ArrayData = cvlConfig?.ArrayData;\r\n    this.ArrayKeyProperty = cvlConfig?.ArrayKeyProperty;\r\n    this.ArrayValueProperty = cvlConfig?.ArrayValueProperty;\r\n    this.IsEnumSearchable = cvlConfig?.IsSearchable;\r\n    this.ShowEnumCancelButton = cvlConfig?.ShowCancelButton;\r\n    this.EnumSearchText = cvlConfig?.SearchText;\r\n    this.IsEnumMultiSelect = cvlConfig?.IsMultiSelect;\r\n    this.BindLookupFullObject = cvlConfig?.BindFullObject;\r\n  }\r\n\r\n  /**\r\n   * Identificativo univoco del filtro\r\n   */\r\n  public FilterID: string;\r\n\r\n  /**\r\n   * Permette di definire la classe css da applicare\r\n   * al filtro\r\n   */\r\n  public FilterClass?: FilterSizeClass = FilterSizeClass.SMALL;\r\n\r\n  /**\r\n   *\r\n   */\r\n  public CustomFilterClasses?: string;\r\n\r\n  /**\r\n   * Etichetta da mostrare per il filtro\r\n   */\r\n  public Label: string;\r\n\r\n  /**\r\n   * Valore della proprietà dell'oggetto su cui andrà applicato il filtro\r\n   */\r\n  public PropertyName?: string;\r\n\r\n  /**\r\n   * Valore da usare per il filtro.\r\n   */\r\n  public PropertyObject?: any;\r\n\r\n  /**\r\n   * Definisce il tipo di filtro da applicare (valori ammessi in base all'enumeratore InputType)\r\n   */\r\n  public InputType: InputType;\r\n\r\n  /**\r\n   * Definisce il tipo di operatore logico da utilizzare per la where part\r\n   */\r\n  public WherePartType?: WherePartType;\r\n\r\n  /**\r\n   * Se il filtro è di tipo CVL o CVLEnum allora in questa proprietà ci va definita la configurazione della cvl.\r\n   * La cvl verrà renderizzata con una eqp-select\r\n   */\r\n  public CvlConfig?: FilterCvlConfig;\r\n\r\n  /**\r\n   * Permette di definire il template esterno da renderizzare come filtro.\r\n   */\r\n  public Externaltemplate?: TemplateRef<any>;\r\n\r\n  /**\r\n   * Permette di disabilitare la cancellazione del filtro all'utente.\r\n   * Di default assume il valore FALSE (se true allora nel riepilogo dei filtri applicati non sarà mostrato il pulsante X)\r\n   */\r\n  public PreventRemoval?: boolean = false;\r\n\r\n  /**\r\n   * Permette di definire una funzione custom esterna da richiamare per il filtro corrente quando vengono premuti i pulsanti APPLICA FILTRI\r\n   * o RESET\r\n   */\r\n  public CustomWherePartFunction?: (filterConfig: FilterConfig, isResetAll?: boolean, isRemoveFilter?: boolean) => any;\r\n\r\n  /**\r\n   * Permette di definire la funzione custom per restituire il valore del filtro applicato, da mostrare nell'header della card\r\n   *\r\n   */\r\n  public CustomAppliedFilterInfoFunction?: (\r\n    filterConfig: FilterConfig,\r\n    isResetAll?: boolean,\r\n    isRemoveFilter?: boolean\r\n  ) => any;\r\n\r\n  /**\r\n   * Per i filtri di tipo ContainsElement e NotContainsElement che si basano sull'applicazione di una where part con l'operatore\r\n   * Linq ANY allora questa proprietà permette di definire il nome della proprietà degli oggetti figli su cui applicare la where part.\r\n   * In questo caso dentro PropertyName ci andrà il nome della proprietà contenente la lista di child.\r\n   *\r\n   * (Es: PropertyName = 'Users' e ChildElementPropertyName = 'Role' per filtrare i record che contengono una lista di utenti con uno specifico)\r\n   */\r\n  public ChildElementPropertyName?: string;\r\n\r\n  public static CreateStandardFilterConfig(\r\n    filterID: string,\r\n    label: string,\r\n    propertyName: string,\r\n    type: InputType,\r\n    wherePartType: WherePartType,\r\n    filterClass?: FilterSizeClass,\r\n    filterCvlConfig?: FilterCvlConfig,\r\n    externaltemplate?: TemplateRef<any>,\r\n    customWherePartFunction?: (filterConfig: FilterConfig, isResetAll?: boolean, isRemoveFilter?: boolean) => any,\r\n    childElementPropertyName?: string,\r\n    filterValue?: any,\r\n    preventRemoval?: boolean\r\n  ): FilterConfig {\r\n    let filter: FilterConfig = new FilterConfig(\r\n      filterID,\r\n      filterClass,\r\n      label,\r\n      propertyName,\r\n      null,\r\n      type,\r\n      wherePartType,\r\n      filterCvlConfig,\r\n      preventRemoval\r\n    );\r\n\r\n    if (externaltemplate) filter.Externaltemplate = externaltemplate;\r\n\r\n    if (customWherePartFunction) filter.CustomWherePartFunction = customWherePartFunction;\r\n\r\n    if (childElementPropertyName) filter.ChildElementPropertyName = childElementPropertyName;\r\n\r\n    if (filterValue) filter.PropertyObject = filterValue;\r\n\r\n    return filter;\r\n  }\r\n\r\n  /**\r\n   * Se la CVL si basa su un enumeratore allora in questa proprietà va definito il type dell'enumeratore da usare.\r\n   * In questo modo la sorgente dati della CVL sarà l'insieme dei valori definiti per l'enumeratore\r\n   */\r\n  public EnumData?: any;\r\n\r\n  /**\r\n   * Se la CVL si basa su un array allora in questa proprietà va definito l'array da mostrare come sorgente dati della CVL\r\n   */\r\n  public ArrayData?: any;\r\n\r\n  /**\r\n   * Nel caso di ArrayData definito permette di indicare la proprietà degli oggetti dell'array da bindare al filtro\r\n   */\r\n  public ArrayKeyProperty?: any;\r\n\r\n  /**\r\n   * Nel caso di ArrayData definito permette di indicare la proprietà degli oggetti da visualizzare nel filtro\r\n   */\r\n  public ArrayValueProperty?: any;\r\n\r\n  /**\r\n   * Se TRUE allora mostra il campo di ricerca all'interno della CVL (default: TRUE)\r\n   */\r\n  public IsEnumSearchable?: boolean = false;\r\n\r\n  /**\r\n   * Se TRUE allora mostra il pulsante per pulire la selezione della CVL (default: TRUE)\r\n   */\r\n  public ShowEnumCancelButton?: boolean = true;\r\n\r\n  /**\r\n   * Permette di definire l'etichetta per il campo di ricerca della CVL (default: 'Cerca')\r\n   */\r\n  public EnumSearchText?: string = \"Cerca\";\r\n\r\n  /**\r\n   * Permette di definire la multi selezione dei valori della CVL (default: false)\r\n   */\r\n  public IsEnumMultiSelect?: boolean = false;\r\n\r\n  /**\r\n   * Se TRUE allora mostra il campo di ricerca all'interno della lookup (default: TRUE)\r\n   */\r\n  public IsLookupSearchable?: boolean = false;\r\n\r\n  /**\r\n   * Se TRUE allora mostra il pulsante per pulire la selezione della lookup (default: TRUE)\r\n   */\r\n  public ShowLookupCancelButton?: boolean = true;\r\n\r\n  /**\r\n   * Permette di definire l'etichetta per il campo di ricerca della Lookup (default: 'Cerca')\r\n   */\r\n  public LookupSearchText?: string = \"Cerca\";\r\n\r\n  /**\r\n   * Permette di definire la multi selezione dei valori della lookup (default: false)\r\n   */\r\n  public IsLookupMultiple?: boolean = false;\r\n\r\n  /**\r\n   * Permette di definire se nella lookup il binding deve considerare tutto l'oggetto\r\n   * (default: true)\r\n   */\r\n  public BindLookupFullObject?: boolean = true;\r\n\r\n  /**\r\n   * Permette di definire l'entità della lookup\r\n   */\r\n  public LookupEntityType?: string = null;\r\n\r\n  /**\r\n   * Permette di definire l'url per effettuare la chiamata che popola la lookup\r\n   */\r\n  public LookupFullUrlHttpCall?: string = null;\r\n\r\n  /**\r\n   * Permette di definire (in maniera opzionale) gli eventuali predicati standard da applicare nel recuperare gli item per la lookup\r\n   */\r\n  public DataFilter?: Array<LinqPredicateDTO> | null = null;\r\n\r\n  /**\r\n   * Permette di definire un oggetto contenente la funzione di validazione e la label del suggerimento per validare il campo del filtro\r\n   */\r\n  public ValidationProperties?: ValidationObject;\r\n}\r\n\r\n/**\r\n * Classe che permette di configurare una eqp-select (CVL) per uno specifico filtro\r\n */\r\nexport class FilterCvlConfig {\r\n  /**\r\n   * Se la CVL si basa su un enumeratore allora in questa proprietà va definito il type dell'enumeratore da usare.\r\n   * In questo modo la sorgente dati della CVL sarà l'insieme dei valori definiti per l'enumeratore\r\n   */\r\n  public EnumData?: any;\r\n\r\n  /**\r\n   * Se la CVL si basa su un array allora in questa proprietà va definito l'array da mostrare come sorgente dati della CVL\r\n   */\r\n  public ArrayData?: any;\r\n\r\n  /**\r\n   * Nel caso di ArrayData definito permette di indicare la proprietà degli oggetti dell'array da bindare al filtro\r\n   */\r\n  public ArrayKeyProperty?: any;\r\n\r\n  /**\r\n   * Nel caso di ArrayData definito permette di indicare la proprietà degli oggetti da visualizzare nel filtro\r\n   */\r\n  public ArrayValueProperty?: any;\r\n\r\n  /**\r\n   * Se TRUE allora mostra il campo di ricerca all'interno della CVL (default: TRUE)\r\n   */\r\n  public IsSearchable?: boolean = false;\r\n\r\n  /**\r\n   * Se TRUE allora mostra il pulsante per pulire la selezione della CVL (default: TRUE)\r\n   */\r\n  public ShowCancelButton?: boolean = true;\r\n\r\n  /**\r\n   * Permette di definire l'etichetta per il campo di ricerca (default: 'Cerca')\r\n   */\r\n  public SearchText?: string = \"Cerca\";\r\n\r\n  /**\r\n   * Permette di definire la multi selezione dei valori della CVL (default: false)\r\n   */\r\n  public IsMultiSelect?: boolean = false;\r\n\r\n  /**\r\n   * Permette di definire se nella CVL il binding deve considera tutto l'oggetto o solo la proprietà\r\n   * definita dentro ArrayKeyProperty\r\n   * (default: true)\r\n   */\r\n  public BindFullObject?: boolean = true;\r\n\r\n  /**\r\n   * Dati gli opportuni parametri restituisce un oggetto FilterCvlConfig pronto all'uso.\r\n   * @param enumData Type dell'enumeratore da usare nella cvl (opzionale)\r\n   * @param arrayData Array da usare nella cvl (opzionale)\r\n   * @param arrayKeyProperty Nome della proprietà da usare come binding (opzionale)\r\n   * @param arrayValueProperty Nome della proprietà da mostrare nella CVL (opzionale)\r\n   * @param isMultiSelect Attiva o disattiva la multiselezione (opzionale)\r\n   * @param isSearchable Attiva o disattiva la ricerca nella CVL (opzionale)\r\n   * @param showCancelButton Attiva o disattiva il pulsante per pulire la selezione nella CVL (opzionale)\r\n   * @param searchText Definisce l'etichetta del campo di ricerca (opzionale)\r\n   * @returns Valida i parametri e restituisce un oggetto di tipo FilterCvlConfig\r\n   */\r\n  static CreateFilterCVLConfig(\r\n    enumData?: any,\r\n    arrayData?: any,\r\n    arrayKeyProperty?: any,\r\n    arrayValueProperty?: any,\r\n    isMultiSelect?: boolean,\r\n    isSearchable?: boolean,\r\n    showCancelButton?: boolean,\r\n    searchText?: string,\r\n    bindFullObject?: boolean\r\n  ): FilterCvlConfig {\r\n    let cvlConfig: FilterCvlConfig = new FilterCvlConfig();\r\n\r\n    if ((enumData == null || enumData == undefined) && (arrayData == null || arrayData == undefined)) {\r\n      throw new Error(\"It's mandatory to define one of the enumData or enumArray properties\");\r\n    }\r\n\r\n    cvlConfig.ArrayData = arrayData;\r\n    cvlConfig.EnumData = enumData;\r\n    cvlConfig.ArrayKeyProperty = arrayKeyProperty;\r\n    cvlConfig.ArrayValueProperty = arrayValueProperty;\r\n\r\n    if (isMultiSelect != null) cvlConfig.IsMultiSelect = isMultiSelect;\r\n\r\n    if (isSearchable != null) cvlConfig.IsSearchable = isSearchable;\r\n\r\n    if (showCancelButton != null) cvlConfig.ShowCancelButton = showCancelButton;\r\n\r\n    if (searchText) cvlConfig.SearchText = searchText;\r\n\r\n    if (bindFullObject != null) cvlConfig.BindFullObject = bindFullObject;\r\n\r\n    return cvlConfig;\r\n  }\r\n}\r\n\r\n/**\r\n * Classe utilizzata per memorizzare le informazioni sui filtri salvati nel local storage.\r\n * Utilizzata solo se per la direttiva eqp-filters è stato richiesto il salvataggio dei filtri\r\n */\r\nexport class SavedFilterItem {\r\n  public FilterName: string;\r\n  public PreventRemoval: boolean;\r\n}\r\n\r\nexport enum InputType {\r\n  Text = 1,\r\n  Number = 2,\r\n  Date = 3,\r\n  Datetime = 4,\r\n  CvlEnum = 5,\r\n  Cvl = 6,\r\n  Boolean = 7,\r\n  BooleanCvl = 8,\r\n  CustomTemplate = 9,\r\n  DateRange = 10,\r\n  Lookup = 11\r\n}\r\n\r\nexport enum WherePartType {\r\n  Equal = 1,\r\n  NotEqual = 2,\r\n  StringContains = 3,\r\n  StringNotContains = 4,\r\n  GreaterThan = 5,\r\n  GreaterThanOrEqual = 6,\r\n  LessThan = 7,\r\n  LessThanOrEqual = 8,\r\n  ContainsElement = 9,\r\n  NotContainsElement = 10\r\n}\r\n\r\nexport enum FilterSizeClass {\r\n  SMALL = 1,\r\n  MEDIUM = 2,\r\n  LARGE = 3,\r\n  CUSTOM = 4\r\n}\r\n\r\n/**\r\n * Enumeratore usato come input del componente eqp-filter.\r\n * Permette di indicare la complessità dell'oggetto da restituire quando viene premuto\r\n * il pulsante Applica FIltri.\r\n * La documentazione delle due tipologie è stata riportata nel metodo createFilterValue del componente\r\n * eqp-filters.component.ts\r\n */\r\nexport enum FilterResultType {\r\n  BASIC = 1,\r\n  ADVANCED = 2\r\n}\r\n\r\n/**\r\n * Utilizzato per battezzare il comportamento e l'aspetto grafico della direttiva eqp-filters.\r\n * WITH_CARD: viene renderizzata una card espandibile e i filtri sono visualizzati nel mat-card-content. Quando si applicano i filtri nel card-header vengono riepilogati i filtri applicati\r\n * WITH_BUTTON: viene renderizzato un pulsante (con lo stesso stile del card-header precedente). Alla pressione del pulsante si apre una modale contenente tutti i filtri. Quando si applicano o resettano i filtri la modale si chiude e nel pulsante vengono riepilogati i filtri applicati\r\n */\r\nexport enum FilterMode {\r\n  WITH_CARD = 1,\r\n  WITH_BUTTON = 2\r\n}\r\n\r\nexport class ValidationObject {\r\n  public Valid?: Function;\r\n  public HintLabel?: string;\r\n}\r\n\r\n"]}