@wemake4u/form-player-se 1.0.9 → 1.0.10
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/esm2022/lib/common/record.mjs +26 -0
- package/esm2022/lib/common/symbols.mjs +2 -0
- package/esm2022/lib/dataSources/odata.mjs +7 -1
- package/esm2022/lib/dynamic-fields/dynamic-fields.component.mjs +17 -161
- package/esm2022/lib/locale/locale-it.mjs +8 -2
- package/esm2022/lib/services/formatter.service.mjs +27 -9
- package/esm2022/lib/services/grid.service.mjs +483 -0
- package/esm2022/lib/services/programmability.service.mjs +7 -2
- package/esm2022/lib/services/weak.service.mjs +15 -11
- package/esm2022/lib/utils/setFilter.mjs +111 -0
- package/esm2022/public-api.mjs +1 -4
- package/fesm2022/wemake4u-form-player-se.mjs +931 -511
- package/fesm2022/wemake4u-form-player-se.mjs.map +1 -1
- package/lib/common/record.d.ts +11 -0
- package/lib/common/symbols.d.ts +1 -0
- package/lib/dynamic-fields/dynamic-fields.component.d.ts +9 -12
- package/lib/dynamic-form/dynamic-form.component.d.ts +6 -0
- package/lib/locale/locale-it.d.ts +6 -0
- package/lib/services/formatter.service.d.ts +1 -0
- package/lib/services/grid.service.d.ts +42 -0
- package/lib/utils/gridCells.d.ts +12 -0
- package/lib/utils/setFilter.d.ts +72 -0
- package/package.json +2 -1
- package/esm2022/lib/utils/gridUtils.mjs +0 -75
- package/lib/utils/gridUtils.d.ts +0 -4
|
@@ -0,0 +1,483 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { PaginationModule, ClientSideRowModelModule, InfiniteRowModelModule, LocaleModule, CellStyleModule, TextFilterModule, NumberFilterModule, DateFilterModule, themeQuartz, iconSetAlpine, ClientSideRowModelApiModule, ColumnAutoSizeModule, ColumnApiModule } from 'ag-grid-community';
|
|
3
|
+
import { AG_GRID_LOCALE_IT } from '@ag-grid-community/locale';
|
|
4
|
+
import { ObjectURLRendererComponent, DeleteRowCellRenderer, ActionsCellRenderer } from '../utils/gridCells';
|
|
5
|
+
import { SetFilterComponent } from '../utils/setFilter';
|
|
6
|
+
import { isRecord, isLabeledRecord, isNumericKey } from '../common/record';
|
|
7
|
+
import { getLabelSymbol } from '../common/symbols';
|
|
8
|
+
import { Texts } from '../locale/locale-it';
|
|
9
|
+
import * as i0 from "@angular/core";
|
|
10
|
+
import * as i1 from "../services/formatter.service";
|
|
11
|
+
import * as i2 from "../services/programmability.service";
|
|
12
|
+
export class GridService {
|
|
13
|
+
formatter;
|
|
14
|
+
programmability;
|
|
15
|
+
constructor(formatter, programmability) {
|
|
16
|
+
this.formatter = formatter;
|
|
17
|
+
this.programmability = programmability;
|
|
18
|
+
}
|
|
19
|
+
getGridModules() {
|
|
20
|
+
return [
|
|
21
|
+
ClientSideRowModelModule,
|
|
22
|
+
InfiniteRowModelModule,
|
|
23
|
+
PaginationModule,
|
|
24
|
+
LocaleModule,
|
|
25
|
+
CellStyleModule,
|
|
26
|
+
ClientSideRowModelApiModule,
|
|
27
|
+
TextFilterModule,
|
|
28
|
+
NumberFilterModule,
|
|
29
|
+
DateFilterModule,
|
|
30
|
+
ColumnAutoSizeModule,
|
|
31
|
+
ColumnApiModule
|
|
32
|
+
];
|
|
33
|
+
}
|
|
34
|
+
;
|
|
35
|
+
getGridOptions(component, formGroup) {
|
|
36
|
+
const columnDefs = this.getGridColumns(component, formGroup);
|
|
37
|
+
const pagination = this.getGridPaginable(component);
|
|
38
|
+
const pageSize = this.getGridPageSize(component);
|
|
39
|
+
const texts = this.getGridTexts();
|
|
40
|
+
const theme = this.getGridTheme();
|
|
41
|
+
return {
|
|
42
|
+
defaultColDef: {
|
|
43
|
+
floatingFilter: (component.floatingFilter === true),
|
|
44
|
+
headerClass: (component.floatingFilter === true)
|
|
45
|
+
? 'show-filter' : 'hide-filter'
|
|
46
|
+
},
|
|
47
|
+
dataTypeDefinitions: this.getDataTypeDefinitions(),
|
|
48
|
+
columnDefs: columnDefs,
|
|
49
|
+
pagination: pagination,
|
|
50
|
+
paginationPageSize: pageSize,
|
|
51
|
+
cacheBlockSize: pageSize,
|
|
52
|
+
paginationPageSizeSelector: [5, 10, 20, 50],
|
|
53
|
+
localeText: texts,
|
|
54
|
+
enableCellTextSelection: true,
|
|
55
|
+
theme: theme,
|
|
56
|
+
onGridReady: (params) => {
|
|
57
|
+
params.api.autoSizeColumns(["actions"]);
|
|
58
|
+
}
|
|
59
|
+
};
|
|
60
|
+
}
|
|
61
|
+
getGridColumns(component, formGroup) {
|
|
62
|
+
if (Array.isArray(component.columns)) {
|
|
63
|
+
const columns = component.columns.map((column) => {
|
|
64
|
+
const colDef = {
|
|
65
|
+
field: column.key,
|
|
66
|
+
headerName: column.label,
|
|
67
|
+
};
|
|
68
|
+
this.setCellDataType(column, colDef);
|
|
69
|
+
const map = this.getMap(column, colDef, formGroup);
|
|
70
|
+
this.setCellRenderer(column, colDef, map);
|
|
71
|
+
this.setResizable(column, colDef);
|
|
72
|
+
this.setSortable(column, colDef);
|
|
73
|
+
this.setFilter(column, colDef, map);
|
|
74
|
+
this.setFilterParams(column, colDef, map);
|
|
75
|
+
this.setSuppressMovable(column, colDef);
|
|
76
|
+
this.setFlex(column, colDef);
|
|
77
|
+
this.setAlign(column, colDef);
|
|
78
|
+
this.setPinned(column, colDef);
|
|
79
|
+
this.setWidth(column, colDef);
|
|
80
|
+
this.setValueFormatter(column, colDef, map);
|
|
81
|
+
return colDef;
|
|
82
|
+
});
|
|
83
|
+
if (Array.isArray(component.actions) && component.actions.length > 0) {
|
|
84
|
+
columns.push({
|
|
85
|
+
colId: 'actions',
|
|
86
|
+
headerName: Texts.Actions,
|
|
87
|
+
resizable: false,
|
|
88
|
+
cellDataType: false,
|
|
89
|
+
pinned: "right",
|
|
90
|
+
cellRendererParams: {
|
|
91
|
+
component: component,
|
|
92
|
+
formGroup: formGroup
|
|
93
|
+
},
|
|
94
|
+
cellRenderer: ActionsCellRenderer,
|
|
95
|
+
suppressKeyboardEvent: this.navigateInsideCell
|
|
96
|
+
});
|
|
97
|
+
}
|
|
98
|
+
return columns;
|
|
99
|
+
}
|
|
100
|
+
else {
|
|
101
|
+
return [];
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
setCellDataType(column, colDef) {
|
|
105
|
+
if (typeof column.dataType === "string"
|
|
106
|
+
&& column.dataType.trim() !== ""
|
|
107
|
+
&& column.dataType !== "auto") {
|
|
108
|
+
colDef.cellDataType = column.dataType;
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
setCellRenderer(column, colDef, map) {
|
|
112
|
+
if (column.format === "objectURL") {
|
|
113
|
+
colDef.cellRenderer = ObjectURLRendererComponent;
|
|
114
|
+
}
|
|
115
|
+
if (column.format === "deleteRow") {
|
|
116
|
+
colDef.cellRenderer = DeleteRowCellRenderer;
|
|
117
|
+
}
|
|
118
|
+
if (colDef.cellDataType === "boolean" && map) {
|
|
119
|
+
colDef.cellRenderer = (params) => {
|
|
120
|
+
return this.formatMap(params.value, map);
|
|
121
|
+
};
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
setResizable(column, colDef) {
|
|
125
|
+
colDef.resizable = (column.resize === true);
|
|
126
|
+
}
|
|
127
|
+
setSortable(column, colDef) {
|
|
128
|
+
colDef.sortable = (column.sort === true);
|
|
129
|
+
}
|
|
130
|
+
setFilter(column, colDef, map) {
|
|
131
|
+
if (column.filter === true) {
|
|
132
|
+
colDef.filter = true;
|
|
133
|
+
if (map) {
|
|
134
|
+
colDef.filter = SetFilterComponent;
|
|
135
|
+
}
|
|
136
|
+
}
|
|
137
|
+
}
|
|
138
|
+
setFilterParams(column, colDef, map) {
|
|
139
|
+
const filterParams = {};
|
|
140
|
+
if (column.dataType === 'uuid') {
|
|
141
|
+
this.setUuidFilterParams(filterParams);
|
|
142
|
+
}
|
|
143
|
+
else if (column.dataType === 'integer') {
|
|
144
|
+
this.setIntegerFilterParams(filterParams);
|
|
145
|
+
}
|
|
146
|
+
else if (column.dataType === 'date') {
|
|
147
|
+
this.setDateFilterParams(filterParams);
|
|
148
|
+
}
|
|
149
|
+
else if (column.dataType === 'boolean') {
|
|
150
|
+
this.setBooleanFilterParams(filterParams);
|
|
151
|
+
}
|
|
152
|
+
if (map) {
|
|
153
|
+
filterParams.map = map;
|
|
154
|
+
}
|
|
155
|
+
colDef.filterParams = filterParams;
|
|
156
|
+
}
|
|
157
|
+
setUuidFilterParams(filterParams) {
|
|
158
|
+
filterParams.filterOptions = ['equals', 'notEqual'];
|
|
159
|
+
}
|
|
160
|
+
setIntegerFilterParams(filterParams) {
|
|
161
|
+
filterParams.allowedCharPattern = '\\d';
|
|
162
|
+
}
|
|
163
|
+
setDateFilterParams(filterParams) {
|
|
164
|
+
filterParams.comparator = (filterLocalDateAtMidnight, cellValue) => {
|
|
165
|
+
if (!cellValue)
|
|
166
|
+
return -1;
|
|
167
|
+
const cellDate = new Date(cellValue);
|
|
168
|
+
if (isNaN(cellDate.getTime()))
|
|
169
|
+
return -1;
|
|
170
|
+
const cellDateNoTime = new Date(cellDate.getFullYear(), cellDate.getMonth(), cellDate.getDate());
|
|
171
|
+
if (cellDateNoTime < filterLocalDateAtMidnight)
|
|
172
|
+
return -1;
|
|
173
|
+
if (cellDateNoTime > filterLocalDateAtMidnight)
|
|
174
|
+
return 1;
|
|
175
|
+
return 0;
|
|
176
|
+
};
|
|
177
|
+
}
|
|
178
|
+
setBooleanFilterParams(filterParams) {
|
|
179
|
+
filterParams.filterOptions = [
|
|
180
|
+
{
|
|
181
|
+
displayKey: 'includeAll',
|
|
182
|
+
displayName: Texts.ChooseOne,
|
|
183
|
+
numberOfInputs: 0,
|
|
184
|
+
predicate: ([filter], value) => true
|
|
185
|
+
},
|
|
186
|
+
{
|
|
187
|
+
displayKey: 'true',
|
|
188
|
+
displayName: Texts.True,
|
|
189
|
+
numberOfInputs: 0,
|
|
190
|
+
predicate: ([filter], value) => value === true
|
|
191
|
+
},
|
|
192
|
+
{
|
|
193
|
+
displayKey: 'false',
|
|
194
|
+
displayName: Texts.False,
|
|
195
|
+
numberOfInputs: 0,
|
|
196
|
+
predicate: ([filter], value) => value === false
|
|
197
|
+
},
|
|
198
|
+
{
|
|
199
|
+
displayKey: 'blank',
|
|
200
|
+
displayName: Texts.Blank,
|
|
201
|
+
numberOfInputs: 0,
|
|
202
|
+
predicate: ([filter], value) => value === null
|
|
203
|
+
},
|
|
204
|
+
{
|
|
205
|
+
displayKey: 'notBlank',
|
|
206
|
+
displayName: Texts.NotBlank,
|
|
207
|
+
numberOfInputs: 0,
|
|
208
|
+
predicate: ([filter], value) => value !== null
|
|
209
|
+
},
|
|
210
|
+
];
|
|
211
|
+
filterParams.suppressAndOrCondition = true;
|
|
212
|
+
}
|
|
213
|
+
setSuppressMovable(column, colDef) {
|
|
214
|
+
if (!(column.move === true)) {
|
|
215
|
+
colDef.suppressMovable = true;
|
|
216
|
+
}
|
|
217
|
+
}
|
|
218
|
+
setFlex(column, colDef) {
|
|
219
|
+
if (column.flex === true) {
|
|
220
|
+
colDef.flex = 1;
|
|
221
|
+
}
|
|
222
|
+
}
|
|
223
|
+
setAlign(column, colDef) {
|
|
224
|
+
if (column.align === "left") {
|
|
225
|
+
colDef.cellStyle = { textAlign: 'left' };
|
|
226
|
+
}
|
|
227
|
+
else if (column.align === "center") {
|
|
228
|
+
colDef.cellStyle = { textAlign: 'center' };
|
|
229
|
+
}
|
|
230
|
+
else if (column.align === "right") {
|
|
231
|
+
colDef.cellStyle = { textAlign: 'right' };
|
|
232
|
+
}
|
|
233
|
+
}
|
|
234
|
+
setPinned(column, colDef) {
|
|
235
|
+
if (typeof column.pinned === "string") {
|
|
236
|
+
colDef.pinned = column.pinned;
|
|
237
|
+
}
|
|
238
|
+
}
|
|
239
|
+
setWidth(column, colDef) {
|
|
240
|
+
if (typeof column.width === "number") {
|
|
241
|
+
colDef.width = column.width;
|
|
242
|
+
}
|
|
243
|
+
if (typeof column.minWidth === "number") {
|
|
244
|
+
colDef.minWidth = column.minWidth;
|
|
245
|
+
}
|
|
246
|
+
if (typeof column.maxWidth === "number") {
|
|
247
|
+
colDef.maxWidth = column.maxWidth;
|
|
248
|
+
}
|
|
249
|
+
}
|
|
250
|
+
setValueFormatter(column, colDef, map) {
|
|
251
|
+
if (map) {
|
|
252
|
+
colDef.valueFormatter = (params) => this.formatMap(params.value, map);
|
|
253
|
+
}
|
|
254
|
+
}
|
|
255
|
+
getGridPaginable(component) {
|
|
256
|
+
return (typeof component.rowCount === 'number' && component.rowCount > 0);
|
|
257
|
+
}
|
|
258
|
+
getGridPageSize(component) {
|
|
259
|
+
if (typeof component.rowCount === 'number') {
|
|
260
|
+
return component.rowCount;
|
|
261
|
+
}
|
|
262
|
+
}
|
|
263
|
+
getGridTexts() {
|
|
264
|
+
return {
|
|
265
|
+
...AG_GRID_LOCALE_IT,
|
|
266
|
+
"pageSizeSelectorLabel": "Elementi per pagina:",
|
|
267
|
+
"to": "-",
|
|
268
|
+
};
|
|
269
|
+
}
|
|
270
|
+
getGridTheme() {
|
|
271
|
+
return themeQuartz
|
|
272
|
+
.withPart(iconSetAlpine)
|
|
273
|
+
.withParams({
|
|
274
|
+
backgroundColor: "#FAFAFA",
|
|
275
|
+
borderColor: "#D9E4F7",
|
|
276
|
+
browserColorScheme: "light",
|
|
277
|
+
cellTextColor: "#00121A",
|
|
278
|
+
columnBorder: true,
|
|
279
|
+
fontFamily: "inherit",
|
|
280
|
+
fontSize: 16,
|
|
281
|
+
headerBackgroundColor: "#002460",
|
|
282
|
+
headerColumnBorder: true,
|
|
283
|
+
headerColumnResizeHandleColor: "#F2F6FC",
|
|
284
|
+
headerColumnResizeHandleWidth: 2,
|
|
285
|
+
headerFontSize: 16,
|
|
286
|
+
headerFontWeight: 600,
|
|
287
|
+
headerRowBorder: false,
|
|
288
|
+
headerTextColor: "#F2F6FC",
|
|
289
|
+
rowBorder: true
|
|
290
|
+
});
|
|
291
|
+
}
|
|
292
|
+
getDataTypeDefinitions() {
|
|
293
|
+
return {
|
|
294
|
+
uuid: {
|
|
295
|
+
baseDataType: 'text',
|
|
296
|
+
extendsDataType: 'text'
|
|
297
|
+
},
|
|
298
|
+
date: {
|
|
299
|
+
baseDataType: 'dateString',
|
|
300
|
+
extendsDataType: 'dateString',
|
|
301
|
+
dateParser: (value) => {
|
|
302
|
+
return value ? new Date(value) : undefined;
|
|
303
|
+
},
|
|
304
|
+
valueFormatter: params => {
|
|
305
|
+
return this.formatter.formatDate(params.value);
|
|
306
|
+
}
|
|
307
|
+
},
|
|
308
|
+
dateTime: {
|
|
309
|
+
baseDataType: 'dateString',
|
|
310
|
+
extendsDataType: 'dateString',
|
|
311
|
+
dateParser: (value) => {
|
|
312
|
+
return value ? new Date(value) : undefined;
|
|
313
|
+
},
|
|
314
|
+
valueFormatter: params => {
|
|
315
|
+
return this.formatter.formatDateTime(params.value);
|
|
316
|
+
}
|
|
317
|
+
},
|
|
318
|
+
currency: {
|
|
319
|
+
extendsDataType: 'number',
|
|
320
|
+
baseDataType: 'number',
|
|
321
|
+
valueFormatter: params => params.value == null
|
|
322
|
+
? ''
|
|
323
|
+
: this.formatter.formatCurrency(params.value)
|
|
324
|
+
},
|
|
325
|
+
integer: {
|
|
326
|
+
extendsDataType: 'number',
|
|
327
|
+
baseDataType: 'number',
|
|
328
|
+
valueFormatter: params => params.value == null
|
|
329
|
+
? ''
|
|
330
|
+
: this.formatter.formatInteger(params.value)
|
|
331
|
+
},
|
|
332
|
+
percentage: {
|
|
333
|
+
extendsDataType: 'number',
|
|
334
|
+
baseDataType: 'number',
|
|
335
|
+
valueFormatter: params => params.value == null
|
|
336
|
+
? ''
|
|
337
|
+
: `${Math.round(params.value * 100)}%`,
|
|
338
|
+
},
|
|
339
|
+
flags: {
|
|
340
|
+
extendsDataType: 'number',
|
|
341
|
+
baseDataType: 'number'
|
|
342
|
+
}
|
|
343
|
+
};
|
|
344
|
+
}
|
|
345
|
+
getMap(column, colDef, formGroup) {
|
|
346
|
+
const allowed = (colDef.cellDataType === "boolean"
|
|
347
|
+
|| colDef.cellDataType === "text"
|
|
348
|
+
|| colDef.cellDataType === "number"
|
|
349
|
+
|| colDef.cellDataType === "flags");
|
|
350
|
+
if (allowed && column.map) {
|
|
351
|
+
const map = this.programmability.evaluate(formGroup, column.mapValues);
|
|
352
|
+
const valid = isRecord(map, key => typeof key === 'string' || typeof key === 'number', val => typeof val === 'string');
|
|
353
|
+
if (!valid)
|
|
354
|
+
return null;
|
|
355
|
+
if (colDef.cellDataType === "flags") {
|
|
356
|
+
map[getLabelSymbol] = (key) => this.formatFlags(key, map);
|
|
357
|
+
}
|
|
358
|
+
return map;
|
|
359
|
+
}
|
|
360
|
+
else {
|
|
361
|
+
return null;
|
|
362
|
+
}
|
|
363
|
+
}
|
|
364
|
+
formatMap(value, map) {
|
|
365
|
+
if (value == null) {
|
|
366
|
+
return '';
|
|
367
|
+
}
|
|
368
|
+
if (map) {
|
|
369
|
+
var result = map[value];
|
|
370
|
+
if (result === undefined) {
|
|
371
|
+
const labeled = isLabeledRecord(map, key => typeof key === 'string' || typeof key === 'number', val => typeof val === 'string', getLabelSymbol);
|
|
372
|
+
if (labeled) {
|
|
373
|
+
result = map[getLabelSymbol](value);
|
|
374
|
+
}
|
|
375
|
+
}
|
|
376
|
+
return result ?? value.toString();
|
|
377
|
+
}
|
|
378
|
+
else {
|
|
379
|
+
return value.toString();
|
|
380
|
+
}
|
|
381
|
+
}
|
|
382
|
+
formatFlags(value, map) {
|
|
383
|
+
if (typeof value === 'number' &&
|
|
384
|
+
isRecord(map, isNumericKey, val => typeof val === 'string')) {
|
|
385
|
+
if (value == 0) {
|
|
386
|
+
return map[0] ?? "0";
|
|
387
|
+
}
|
|
388
|
+
const availableFlags = Object.keys(map)
|
|
389
|
+
.map(Number)
|
|
390
|
+
.filter(flag => flag !== 0);
|
|
391
|
+
const flags = availableFlags.filter(flag => (value & flag) === flag);
|
|
392
|
+
const sumFlags = flags.reduce((sum, f) => sum | f, 0);
|
|
393
|
+
if ((value & sumFlags) !== value) {
|
|
394
|
+
return null;
|
|
395
|
+
}
|
|
396
|
+
return flags
|
|
397
|
+
.map(flag => map[flag])
|
|
398
|
+
.filter((label) => !!label)
|
|
399
|
+
.join(', ');
|
|
400
|
+
}
|
|
401
|
+
else {
|
|
402
|
+
return null;
|
|
403
|
+
}
|
|
404
|
+
}
|
|
405
|
+
navigateInsideCell({ event }) {
|
|
406
|
+
const GRID_CELL_CLASSNAME = "ag-cell";
|
|
407
|
+
const { key, shiftKey } = event;
|
|
408
|
+
const path = this.getEventPath(event);
|
|
409
|
+
const isTabForward = key === "Tab" && shiftKey === false;
|
|
410
|
+
const isTabBackward = key === "Tab" && shiftKey === true;
|
|
411
|
+
let suppressEvent = false;
|
|
412
|
+
// Handle cell children tabbing
|
|
413
|
+
if (isTabForward || isTabBackward) {
|
|
414
|
+
const eGridCell = path.find((el) => {
|
|
415
|
+
if (el.classList === undefined)
|
|
416
|
+
return false;
|
|
417
|
+
return el.classList.contains(GRID_CELL_CLASSNAME);
|
|
418
|
+
});
|
|
419
|
+
if (!eGridCell) {
|
|
420
|
+
return suppressEvent;
|
|
421
|
+
}
|
|
422
|
+
const focusableChildrenElements = this.getAllFocusableElementsOf(eGridCell);
|
|
423
|
+
const lastCellChildEl = focusableChildrenElements[focusableChildrenElements.length - 1];
|
|
424
|
+
const firstCellChildEl = focusableChildrenElements[0];
|
|
425
|
+
// Suppress keyboard event if tabbing forward within the cell and the current focused element is not the last child
|
|
426
|
+
if (focusableChildrenElements.length === 0) {
|
|
427
|
+
return false;
|
|
428
|
+
}
|
|
429
|
+
const currentIndex = focusableChildrenElements.indexOf(document.activeElement);
|
|
430
|
+
if (isTabForward) {
|
|
431
|
+
const isLastChildFocused = lastCellChildEl && document.activeElement === lastCellChildEl;
|
|
432
|
+
if (!isLastChildFocused) {
|
|
433
|
+
suppressEvent = true;
|
|
434
|
+
if (currentIndex !== -1 || document.activeElement === eGridCell) {
|
|
435
|
+
event.preventDefault();
|
|
436
|
+
focusableChildrenElements[currentIndex + 1].focus();
|
|
437
|
+
}
|
|
438
|
+
}
|
|
439
|
+
}
|
|
440
|
+
// Suppress keyboard event if tabbing backwards within the cell, and the current focused element is not the first child
|
|
441
|
+
else {
|
|
442
|
+
const cellHasFocusedChildren = eGridCell.contains(document.activeElement) &&
|
|
443
|
+
eGridCell !== document.activeElement;
|
|
444
|
+
// Manually set focus to the last child element if cell doesn't have focused children
|
|
445
|
+
if (!cellHasFocusedChildren) {
|
|
446
|
+
lastCellChildEl.focus();
|
|
447
|
+
// Cancel keyboard press, so that it doesn't focus on the last child and then pass through the keyboard press to
|
|
448
|
+
// move to the 2nd last child element
|
|
449
|
+
event.preventDefault();
|
|
450
|
+
}
|
|
451
|
+
const isFirstChildFocused = firstCellChildEl && document.activeElement === firstCellChildEl;
|
|
452
|
+
if (!isFirstChildFocused) {
|
|
453
|
+
suppressEvent = true;
|
|
454
|
+
if (currentIndex !== -1 || document.activeElement === eGridCell) {
|
|
455
|
+
event.preventDefault();
|
|
456
|
+
focusableChildrenElements[currentIndex - 1].focus();
|
|
457
|
+
}
|
|
458
|
+
}
|
|
459
|
+
}
|
|
460
|
+
}
|
|
461
|
+
return suppressEvent;
|
|
462
|
+
}
|
|
463
|
+
getEventPath(event) {
|
|
464
|
+
const path = [];
|
|
465
|
+
let currentTarget = event.target;
|
|
466
|
+
while (currentTarget) {
|
|
467
|
+
path.push(currentTarget);
|
|
468
|
+
currentTarget = currentTarget.parentElement;
|
|
469
|
+
}
|
|
470
|
+
return path;
|
|
471
|
+
}
|
|
472
|
+
getAllFocusableElementsOf(el) {
|
|
473
|
+
return Array.from(el.querySelectorAll('button, [href], input, select, textarea, [tabindex]:not([tabindex="-1"])')).filter((focusableEl) => {
|
|
474
|
+
return focusableEl.tabIndex !== -1 && !focusableEl.hasAttribute('disabled');
|
|
475
|
+
});
|
|
476
|
+
}
|
|
477
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: GridService, deps: [{ token: i1.FormatterService }, { token: i2.ProgrammabilityService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
478
|
+
static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: GridService });
|
|
479
|
+
}
|
|
480
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: GridService, decorators: [{
|
|
481
|
+
type: Injectable
|
|
482
|
+
}], ctorParameters: () => [{ type: i1.FormatterService }, { type: i2.ProgrammabilityService }] });
|
|
483
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid.service.js","sourceRoot":"","sources":["../../../../../projects/ngx-sirio/src/lib/services/grid.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport {\r\n  Module, PaginationModule, ClientSideRowModelModule, InfiniteRowModelModule\r\n  , LocaleModule, CellStyleModule, ValidationModule\r\n  , TextFilterModule, NumberFilterModule, DateFilterModule\r\n  , ColDef, themeQuartz, iconSetAlpine, GridOptions, DataTypeDefinition\r\n  , ClientSideRowModelApiModule\r\n  , GridReadyEvent, ColumnAutoSizeModule, ColumnApiModule\r\n  , SuppressKeyboardEventParams\r\n} from 'ag-grid-community';\r\nimport { AG_GRID_LOCALE_IT } from '@ag-grid-community/locale';\r\nimport { FormGroup } from '@angular/forms';\r\nimport { ObjectURLRendererComponent, DeleteRowCellRenderer, ActionsCellRenderer } from '../utils/gridCells';\r\nimport { FormatterService } from '../services/formatter.service';\r\nimport { ProgrammabilityService } from '../services/programmability.service';\r\nimport { SetFilterComponent } from '../utils/setFilter';\r\nimport { isRecord, isLabeledRecord, isNumericKey } from '../common/record';\r\nimport { getLabelSymbol } from '../common/symbols';\r\nimport { Texts } from '../locale/locale-it';\r\n\r\ntype MapType = Record<string | number, string> | null;\r\n\r\n@Injectable()\r\nexport class GridService {\r\n\r\n  constructor(private formatter: FormatterService,\r\n    private programmability: ProgrammabilityService) {\r\n  }\r\n\r\n  getGridModules(): Module[] {\r\n    return [\r\n      ClientSideRowModelModule\r\n      , InfiniteRowModelModule\r\n      , PaginationModule\r\n      , LocaleModule\r\n      , CellStyleModule\r\n      , ClientSideRowModelApiModule\r\n      , TextFilterModule\r\n      , NumberFilterModule\r\n      , DateFilterModule\r\n      , ColumnAutoSizeModule\r\n      , ColumnApiModule      \r\n    ];\r\n  };\r\n\r\n  getGridOptions(component: any, formGroup: FormGroup): GridOptions {\r\n    const columnDefs = this.getGridColumns(component, formGroup);\r\n    const pagination = this.getGridPaginable(component);\r\n    const pageSize = this.getGridPageSize(component);\r\n    const texts = this.getGridTexts();\r\n    const theme = this.getGridTheme();\r\n    return {\r\n      defaultColDef: {\r\n        floatingFilter: (component.floatingFilter === true),\r\n        headerClass: (component.floatingFilter === true)\r\n          ? 'show-filter' : 'hide-filter'\r\n      },\r\n      dataTypeDefinitions: this.getDataTypeDefinitions(),\r\n      columnDefs: columnDefs,\r\n      pagination: pagination,\r\n      paginationPageSize: pageSize,\r\n      cacheBlockSize: pageSize,\r\n      paginationPageSizeSelector: [5, 10, 20, 50],\r\n      localeText: texts,\r\n      enableCellTextSelection: true,\r\n      theme: theme,\r\n      onGridReady: (params: GridReadyEvent) => {\r\n        params.api.autoSizeColumns([\"actions\"]);\r\n      }\r\n    };\r\n  }\r\n\r\n  private getGridColumns(component: any, formGroup: FormGroup): ColDef[] {\r\n    if (Array.isArray(component.columns)) {\r\n      const columns = component.columns.map((column: any) => {\r\n        const colDef: ColDef = {\r\n          field: column.key,\r\n          headerName: column.label,\r\n        }\r\n\r\n        this.setCellDataType(column, colDef);\r\n\r\n        const map = this.getMap(column, colDef, formGroup);\r\n\r\n        this.setCellRenderer(column, colDef, map);\r\n        this.setResizable(column, colDef);\r\n        this.setSortable(column, colDef);\r\n        this.setFilter(column, colDef, map);\r\n        this.setFilterParams(column, colDef, map);\r\n        this.setSuppressMovable(column, colDef);\r\n        this.setFlex(column, colDef);\r\n        this.setAlign(column, colDef);\r\n        this.setPinned(column, colDef);\r\n        this.setWidth(column, colDef);\r\n        this.setValueFormatter(column, colDef, map);        \r\n        return colDef;\r\n      });\r\n\r\n\r\n      if (Array.isArray(component.actions) && component.actions.length > 0) {\r\n        columns.push({\r\n          colId: 'actions',\r\n          headerName: Texts.Actions,\r\n          resizable: false,\r\n          cellDataType: false,\r\n          pinned: \"right\",\r\n          cellRendererParams: {\r\n            component: component,\r\n            formGroup: formGroup\r\n          },\r\n          cellRenderer: ActionsCellRenderer,\r\n          suppressKeyboardEvent: this.navigateInsideCell\r\n        });\r\n      }\r\n\r\n      return columns;\r\n    }\r\n    else {\r\n      return [];\r\n    }\r\n  }\r\n\r\n  private setCellDataType(column: any, colDef: ColDef) {\r\n    if (typeof column.dataType === \"string\"\r\n      && column.dataType.trim() !== \"\"\r\n      && column.dataType !== \"auto\") {\r\n      colDef.cellDataType = column.dataType;\r\n    }\r\n  }\r\n\r\n  private setCellRenderer(column: any, colDef: ColDef, map: MapType) {\r\n    if (column.format === \"objectURL\") {\r\n      colDef.cellRenderer = ObjectURLRendererComponent;\r\n    }\r\n\r\n    if (column.format === \"deleteRow\") {\r\n      colDef.cellRenderer = DeleteRowCellRenderer;\r\n    }\r\n\r\n    if (colDef.cellDataType === \"boolean\" && map) {\r\n      colDef.cellRenderer = (params: any) => {\r\n        return this.formatMap(params.value, map); \r\n      }\r\n    }\r\n  }\r\n\r\n  private setResizable(column: any, colDef: ColDef ) {\r\n    colDef.resizable = (column.resize === true);\r\n  }\r\n\r\n  private setSortable(column: any, colDef: ColDef) {\r\n    colDef.sortable = (column.sort === true);\r\n  }\r\n\r\n  private setFilter(column: any, colDef: ColDef, map: MapType) {\r\n    if (column.filter === true) {\r\n      colDef.filter = true;\r\n      if (map) {\r\n        colDef.filter = SetFilterComponent;\r\n      }\r\n    }\r\n  }\r\n\r\n  private setFilterParams(column: any, colDef: ColDef, map: MapType) {\r\n\r\n    const filterParams: any = {};\r\n\r\n    if (column.dataType === 'uuid') {\r\n      this.setUuidFilterParams(filterParams);\r\n    }\r\n    else if (column.dataType === 'integer') {\r\n      this.setIntegerFilterParams(filterParams);\r\n    }\r\n    else if (column.dataType === 'date') {\r\n      this.setDateFilterParams(filterParams);\r\n    }\r\n    else if (column.dataType === 'boolean') {\r\n      this.setBooleanFilterParams(filterParams);\r\n    }\r\n    \r\n    if (map) {\r\n      filterParams.map = map;\r\n    }\r\n\r\n    colDef.filterParams = filterParams;\r\n  }\r\n\r\n  private setUuidFilterParams(filterParams: any) {\r\n    filterParams.filterOptions = ['equals', 'notEqual'];\r\n  }\r\n\r\n  private setIntegerFilterParams(filterParams: any) {\r\n    filterParams.allowedCharPattern = '\\\\d';\r\n  }\r\n\r\n  private setDateFilterParams(filterParams: any) {\r\n    filterParams.comparator = (filterLocalDateAtMidnight: Date, cellValue: string) => {\r\n      if (!cellValue) return -1;\r\n      const cellDate = new Date(cellValue);\r\n      if (isNaN(cellDate.getTime())) return -1;\r\n\r\n      const cellDateNoTime = new Date(cellDate.getFullYear(), cellDate.getMonth(), cellDate.getDate());\r\n\r\n      if (cellDateNoTime < filterLocalDateAtMidnight) return -1;\r\n      if (cellDateNoTime > filterLocalDateAtMidnight) return 1;\r\n      return 0;\r\n    }\r\n  }\r\n\r\n  private setBooleanFilterParams(filterParams: any) {\r\n    filterParams.filterOptions = [\r\n      {\r\n        displayKey: 'includeAll',\r\n        displayName: Texts.ChooseOne,\r\n        numberOfInputs: 0,\r\n        predicate: ([filter]: [any], value: any) => true\r\n      },\r\n      {\r\n        displayKey: 'true',\r\n        displayName: Texts.True,\r\n        numberOfInputs: 0,\r\n        predicate: ([filter]: [any], value: any) => value === true\r\n      },\r\n      {\r\n        displayKey: 'false',\r\n        displayName: Texts.False,\r\n        numberOfInputs: 0,\r\n        predicate: ([filter]: [any], value: any) => value === false\r\n      },\r\n      {\r\n        displayKey: 'blank',\r\n        displayName: Texts.Blank,\r\n        numberOfInputs: 0,\r\n        predicate: ([filter]: [any], value: any) => value === null\r\n      },\r\n      {\r\n        displayKey: 'notBlank',\r\n        displayName: Texts.NotBlank,\r\n        numberOfInputs: 0,\r\n        predicate: ([filter]: [any], value: any) => value !== null\r\n      },\r\n    ];\r\n    filterParams.suppressAndOrCondition = true;\r\n  }\r\n\r\n  private setSuppressMovable(column: any, colDef: ColDef) {\r\n    if (!(column.move === true)) { \r\n      colDef.suppressMovable = true;\r\n    }\r\n  }\r\n\r\n  private setFlex(column: any, colDef: ColDef) {\r\n    if (column.flex === true) { \r\n      colDef.flex = 1;\r\n    }\r\n  }\r\n\r\n  private setAlign(column: any, colDef: ColDef) {\r\n    if (column.align === \"left\") {\r\n      colDef.cellStyle = { textAlign: 'left' };\r\n    }\r\n    else if (column.align === \"center\") {\r\n      colDef.cellStyle = { textAlign: 'center' };\r\n    }\r\n    else if (column.align === \"right\") { \r\n      colDef.cellStyle = { textAlign: 'right' };\r\n    }\r\n  }\r\n\r\n  private setPinned(column: any, colDef: ColDef) {\r\n    if (typeof column.pinned === \"string\") { \r\n      colDef.pinned = column.pinned;\r\n    }\r\n  }\r\n\r\n  private setWidth(column: any, colDef: ColDef) {\r\n    if (typeof column.width === \"number\") { \r\n      colDef.width = column.width;\r\n    }\r\n\r\n    if (typeof column.minWidth === \"number\") { \r\n      colDef.minWidth = column.minWidth;\r\n    }\r\n\r\n    if (typeof column.maxWidth === \"number\") { \r\n      colDef.maxWidth = column.maxWidth;\r\n    }\r\n  }\r\n\r\n  private setValueFormatter(column: any, colDef: ColDef, map: MapType) {\r\n    if (map) {\r\n      colDef.valueFormatter = (params) => this.formatMap(params.value, map);      \r\n    }\r\n  }\r\n\r\n  private getGridPaginable(component: any): boolean {\r\n    return (typeof component.rowCount === 'number' && component.rowCount > 0);\r\n  }\r\n\r\n  private getGridPageSize(component: any) {\r\n    if (typeof component.rowCount === 'number') {\r\n      return component.rowCount;\r\n    }\r\n  }\r\n\r\n  private getGridTexts() {\r\n    return {\r\n      ...AG_GRID_LOCALE_IT,\r\n      \"pageSizeSelectorLabel\": \"Elementi per pagina:\",\r\n      \"to\": \"-\",\r\n    };\r\n  }\r\n\r\n  private getGridTheme() {\r\n    return themeQuartz\r\n      .withPart(iconSetAlpine)\r\n      .withParams({\r\n        backgroundColor: \"#FAFAFA\",\r\n        borderColor: \"#D9E4F7\",\r\n        browserColorScheme: \"light\",\r\n        cellTextColor: \"#00121A\",\r\n        columnBorder: true,\r\n        fontFamily: \"inherit\",\r\n        fontSize: 16,\r\n        headerBackgroundColor: \"#002460\",\r\n        headerColumnBorder: true,\r\n        headerColumnResizeHandleColor: \"#F2F6FC\",\r\n        headerColumnResizeHandleWidth: 2,\r\n        headerFontSize: 16,\r\n        headerFontWeight: 600,\r\n        headerRowBorder: false,\r\n        headerTextColor: \"#F2F6FC\",\r\n        rowBorder: true\r\n      });\r\n  }\r\n\r\n  private getDataTypeDefinitions(): { [cellDataType: string]: DataTypeDefinition<any>; } {\r\n    return {\r\n      uuid: {\r\n        baseDataType: 'text',\r\n        extendsDataType: 'text'\r\n      },\r\n      date: {\r\n        baseDataType: 'dateString',\r\n        extendsDataType: 'dateString',\r\n        dateParser: (value: string | undefined) => {\r\n          return value ? new Date(value) : undefined;\r\n        },\r\n        valueFormatter: params => {\r\n          return this.formatter.formatDate(params.value);\r\n        }\r\n      },\r\n      dateTime: {\r\n        baseDataType: 'dateString',\r\n        extendsDataType: 'dateString',\r\n        dateParser: (value: string | undefined) => {\r\n          return value ? new Date(value) : undefined;\r\n        },\r\n        valueFormatter: params => {\r\n          return this.formatter.formatDateTime(params.value);\r\n        }\r\n      },\r\n      currency: {\r\n        extendsDataType: 'number',\r\n        baseDataType: 'number',\r\n        valueFormatter: params => params.value == null\r\n          ? ''\r\n          : this.formatter.formatCurrency(params.value)\r\n      },\r\n      integer: {\r\n        extendsDataType: 'number',\r\n        baseDataType: 'number',\r\n        valueFormatter: params => params.value == null\r\n          ? ''\r\n          : this.formatter.formatInteger(params.value)\r\n      },\r\n      percentage: {\r\n        extendsDataType: 'number',\r\n        baseDataType: 'number',\r\n        valueFormatter: params => params.value == null\r\n          ? ''\r\n          : `${Math.round(params.value * 100)}%`,\r\n      },\r\n      flags: {\r\n        extendsDataType: 'number',\r\n        baseDataType: 'number'\r\n      }      \r\n    };\r\n  }\r\n\r\n  private getMap(column: any, colDef: ColDef, formGroup: FormGroup): MapType {\r\n\r\n    const allowed = (colDef.cellDataType === \"boolean\"\r\n      || colDef.cellDataType === \"text\"\r\n      || colDef.cellDataType === \"number\"\r\n      || colDef.cellDataType === \"flags\");\r\n\r\n    if (allowed && column.map) {\r\n      const map = this.programmability.evaluate(formGroup, column.mapValues);\r\n\r\n      const valid = isRecord(\r\n        map,\r\n        key => typeof key === 'string' || typeof key === 'number',\r\n        val => typeof val === 'string'\r\n      );\r\n\r\n      if (!valid)\r\n        return null;\r\n\r\n      if (colDef.cellDataType === \"flags\") {\r\n        (map as any)[getLabelSymbol] = (key: any) => this.formatFlags(key, map);\r\n      }\r\n\r\n      return map;\r\n    }\r\n    else {\r\n      return null;\r\n    }\r\n  }\r\n\r\n  private formatMap(value: any, map: MapType)\r\n  {\r\n    if (value == null) {\r\n      return '';\r\n    }\r\n\r\n    if (map) {\r\n      var result = map[value];\r\n\r\n      if (result === undefined) {\r\n        const labeled = isLabeledRecord(\r\n          map,\r\n          key => typeof key === 'string' || typeof key === 'number',\r\n          val => typeof val === 'string',\r\n          getLabelSymbol\r\n        );\r\n\r\n        if (labeled) {\r\n          result = map[getLabelSymbol](value);\r\n        }\r\n      }\r\n      \r\n      return result ?? value.toString();\r\n    }\r\n    else {\r\n      return value.toString();\r\n    }\r\n  }\r\n\r\n  private formatFlags(value: any, map: MapType) {\r\n    if (typeof value === 'number' &&\r\n      isRecord(map, isNumericKey, val => typeof val === 'string')\r\n    ) {\r\n      if (value == 0) {\r\n        return map[0] ?? \"0\";\r\n      }\r\n\r\n      const availableFlags = Object.keys(map)\r\n        .map(Number)\r\n        .filter(flag => flag !== 0);\r\n\r\n      const flags = availableFlags.filter(flag => (value & flag) === flag);\r\n\r\n      const sumFlags = flags.reduce((sum, f) => sum | f, 0);\r\n\r\n      if ((value & sumFlags) !== value) {\r\n        return null;\r\n      }\r\n\r\n      return flags\r\n        .map(flag => map[flag])\r\n        .filter((label): label is string => !!label)\r\n        .join(', ');\r\n    } else {\r\n      return null;\r\n    }\r\n  }\r\n\r\n  private navigateInsideCell({ event }: SuppressKeyboardEventParams<any>) {\r\n    const GRID_CELL_CLASSNAME = \"ag-cell\";\r\n    const { key, shiftKey } = event;\r\n    const path = this.getEventPath(event);\r\n    const isTabForward = key === \"Tab\" && shiftKey === false;\r\n    const isTabBackward = key === \"Tab\" && shiftKey === true;\r\n    let suppressEvent = false;\r\n    // Handle cell children tabbing\r\n    if (isTabForward || isTabBackward) {\r\n      const eGridCell = path.find((el) => {\r\n        if (el.classList === undefined) return false;\r\n        return el.classList.contains(GRID_CELL_CLASSNAME);\r\n      });\r\n      if (!eGridCell) {\r\n        return suppressEvent;\r\n      }\r\n      const focusableChildrenElements = this.getAllFocusableElementsOf(eGridCell);\r\n      const lastCellChildEl =\r\n        focusableChildrenElements[focusableChildrenElements.length - 1];\r\n      const firstCellChildEl = focusableChildrenElements[0];\r\n      // Suppress keyboard event if tabbing forward within the cell and the current focused element is not the last child\r\n      if (focusableChildrenElements.length === 0) {\r\n        return false;\r\n      }\r\n      const currentIndex = focusableChildrenElements.indexOf(\r\n        document.activeElement as HTMLElement,\r\n      );\r\n      if (isTabForward) {\r\n        const isLastChildFocused =\r\n          lastCellChildEl && document.activeElement === lastCellChildEl;\r\n        if (!isLastChildFocused) {\r\n          suppressEvent = true;\r\n          if (currentIndex !== -1 || document.activeElement === eGridCell) {\r\n            event.preventDefault();\r\n            focusableChildrenElements[currentIndex + 1].focus();\r\n          }\r\n        }\r\n      }\r\n      // Suppress keyboard event if tabbing backwards within the cell, and the current focused element is not the first child\r\n      else {\r\n        const cellHasFocusedChildren =\r\n          eGridCell.contains(document.activeElement) &&\r\n          eGridCell !== document.activeElement;\r\n        // Manually set focus to the last child element if cell doesn't have focused children\r\n        if (!cellHasFocusedChildren) {\r\n          lastCellChildEl.focus();\r\n          // Cancel keyboard press, so that it doesn't focus on the last child and then pass through the keyboard press to\r\n          // move to the 2nd last child element\r\n          event.preventDefault();\r\n        }\r\n        const isFirstChildFocused =\r\n          firstCellChildEl && document.activeElement === firstCellChildEl;\r\n        if (!isFirstChildFocused) {\r\n          suppressEvent = true;\r\n          if (currentIndex !== -1 || document.activeElement === eGridCell) {\r\n            event.preventDefault();\r\n            focusableChildrenElements[currentIndex - 1].focus();\r\n          }\r\n        }\r\n      }\r\n    }\r\n    return suppressEvent;\r\n  }\r\n\r\n  private getEventPath(event: Event): HTMLElement[] {\r\n    const path: HTMLElement[] = [];\r\n    let currentTarget: any = event.target;\r\n    while (currentTarget) {\r\n      path.push(currentTarget);\r\n      currentTarget = currentTarget.parentElement;\r\n    }\r\n    return path;\r\n  }\r\n\r\n  private getAllFocusableElementsOf(el: HTMLElement) {\r\n    return Array.from<HTMLElement>(\r\n      el.querySelectorAll(\r\n        'button, [href], input, select, textarea, [tabindex]:not([tabindex=\"-1\"])',\r\n      )\r\n    ).filter((focusableEl) => {\r\n      return focusableEl.tabIndex !== -1 && !focusableEl.hasAttribute('disabled');\r\n    });\r\n  }\r\n}\r\n"]}
|