basesite-shared-grid-lib 0.0.0-watch
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +30 -0
- package/basesite-shared-grid-lib-0.0.0-watch+1699364357423.tgz +0 -0
- package/esm2020/basesite-shared-grid-lib.mjs +5 -0
- package/esm2020/lib/formatters/column-value-formatter.mjs +27 -0
- package/esm2020/lib/grid-library.component.mjs +546 -0
- package/esm2020/lib/grid-library.module.mjs +47 -0
- package/esm2020/lib/grid-library.service.mjs +44 -0
- package/esm2020/lib/helpers/index.mjs +3 -0
- package/esm2020/lib/helpers/oDataProvider.mjs +787 -0
- package/esm2020/lib/helpers/types.mjs +2 -0
- package/esm2020/lib/helpers/utils.mjs +7 -0
- package/esm2020/lib/renderer/button-renderer/button-renderer.component.mjs +49 -0
- package/esm2020/lib/renderer/dropdown-renderer/drop-down-renderer.mjs +52 -0
- package/esm2020/lib/renderer/tooltip-renderer/custom-tooltip-renderer.mjs +30 -0
- package/esm2020/public-api.mjs +7 -0
- package/fesm2015/basesite-shared-grid-lib.mjs +1580 -0
- package/fesm2015/basesite-shared-grid-lib.mjs.map +1 -0
- package/fesm2020/basesite-shared-grid-lib.mjs +1575 -0
- package/fesm2020/basesite-shared-grid-lib.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/formatters/column-value-formatter.d.ts +10 -0
- package/lib/grid-library.component.d.ts +62 -0
- package/lib/grid-library.module.d.ts +14 -0
- package/lib/grid-library.service.d.ts +15 -0
- package/lib/helpers/index.d.ts +2 -0
- package/lib/helpers/oDataProvider.d.ts +338 -0
- package/lib/helpers/types.d.ts +20 -0
- package/lib/helpers/utils.d.ts +2 -0
- package/lib/renderer/button-renderer/button-renderer.component.d.ts +12 -0
- package/lib/renderer/dropdown-renderer/drop-down-renderer.d.ts +11 -0
- package/lib/renderer/tooltip-renderer/custom-tooltip-renderer.d.ts +16 -0
- package/package.json +49 -0
- package/public-api.d.ts +3 -0
- package/src/lib/styles/styles.scss +184 -0
|
@@ -0,0 +1,546 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output, ViewChild, } from '@angular/core';
|
|
2
|
+
import { OdataServerSideProvider } from './helpers';
|
|
3
|
+
import { ButtonRendererComponent } from './renderer/button-renderer/button-renderer.component';
|
|
4
|
+
import { CustomTooltip } from './renderer/tooltip-renderer/custom-tooltip-renderer';
|
|
5
|
+
import { DropdownRenderer } from './renderer/dropdown-renderer/drop-down-renderer';
|
|
6
|
+
import { takeUntil } from 'rxjs/operators';
|
|
7
|
+
import { Subject } from 'rxjs';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
import * as i1 from "./grid-library.service";
|
|
10
|
+
import * as i2 from "./formatters/column-value-formatter";
|
|
11
|
+
import * as i3 from "ag-grid-angular";
|
|
12
|
+
export class GridLibraryComponent {
|
|
13
|
+
constructor(gridService, formatterService) {
|
|
14
|
+
this.gridService = gridService;
|
|
15
|
+
this.formatterService = formatterService;
|
|
16
|
+
this.pageSize = 20;
|
|
17
|
+
this.rowSelection = 'multiple';
|
|
18
|
+
this.enableServerSidePaging = false;
|
|
19
|
+
this.cacheBlockSize = 0;
|
|
20
|
+
this.rowMultiSelectWithClick = false;
|
|
21
|
+
this.floatingFilter = false;
|
|
22
|
+
this.paginationAutoPageSize = false;
|
|
23
|
+
//event emitters
|
|
24
|
+
this.btnClickHandler = new EventEmitter();
|
|
25
|
+
this.firstDataRendered = new EventEmitter();
|
|
26
|
+
this.filterChanged = new EventEmitter();
|
|
27
|
+
this.selectionChanged = new EventEmitter();
|
|
28
|
+
//paramters
|
|
29
|
+
this.rowDataHidden = [];
|
|
30
|
+
this.exportColumnsList = [];
|
|
31
|
+
this.tooltipShowDelay = 0;
|
|
32
|
+
this.tooltipHideDelay = 2000;
|
|
33
|
+
this.rowModelType = 'clientSide';
|
|
34
|
+
this.gridPageSize = 0;
|
|
35
|
+
//unsubscribe subject
|
|
36
|
+
this.unsubscribe$ = new Subject();
|
|
37
|
+
this.defaultColDef = {
|
|
38
|
+
sortable: true,
|
|
39
|
+
filter: true,
|
|
40
|
+
tooltipComponent: CustomTooltip,
|
|
41
|
+
};
|
|
42
|
+
this.paginationNumberFormatter = (params) => {
|
|
43
|
+
return '[' + params.value.toLocaleString() + ']';
|
|
44
|
+
};
|
|
45
|
+
this.getRowById = (params) => {
|
|
46
|
+
var data = params.data;
|
|
47
|
+
return data.id ?? 0;
|
|
48
|
+
};
|
|
49
|
+
// Custom right click Context Menu to support custom excel exports
|
|
50
|
+
this.getContextMenuItems = (params) => {
|
|
51
|
+
let res = [
|
|
52
|
+
'cut',
|
|
53
|
+
'copy',
|
|
54
|
+
'copyWithHeaders',
|
|
55
|
+
'copyWithGroupHeaders',
|
|
56
|
+
'paste',
|
|
57
|
+
{
|
|
58
|
+
name: 'Export',
|
|
59
|
+
subMenu: [
|
|
60
|
+
{
|
|
61
|
+
name: 'CSV Export',
|
|
62
|
+
action: () => {
|
|
63
|
+
this.exportFile('csv');
|
|
64
|
+
},
|
|
65
|
+
},
|
|
66
|
+
{
|
|
67
|
+
name: 'Excel Export',
|
|
68
|
+
action: () => {
|
|
69
|
+
this.exportFile('xlsx');
|
|
70
|
+
},
|
|
71
|
+
},
|
|
72
|
+
],
|
|
73
|
+
},
|
|
74
|
+
];
|
|
75
|
+
return res;
|
|
76
|
+
};
|
|
77
|
+
}
|
|
78
|
+
onSortChangedEvent() {
|
|
79
|
+
this.gridColumnState = this.agGrid.columnApi.getColumnState();
|
|
80
|
+
}
|
|
81
|
+
ngOnInit() {
|
|
82
|
+
this.gridPageSize = this.pageSize;
|
|
83
|
+
this.cacheBlockSize = this.cacheBlockSize = 0
|
|
84
|
+
? this.pageSize
|
|
85
|
+
: this.cacheBlockSize;
|
|
86
|
+
this.gridService.setBaseUrl(this.environment);
|
|
87
|
+
this.getGridState();
|
|
88
|
+
this.getColDef();
|
|
89
|
+
if (this.enableServerSidePaging == true) {
|
|
90
|
+
this.rowModelType = 'serverSide';
|
|
91
|
+
this.rowData = '';
|
|
92
|
+
}
|
|
93
|
+
else {
|
|
94
|
+
this.rowModelType = 'clientSide';
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
onModelUpdated() {
|
|
98
|
+
this.setGridState();
|
|
99
|
+
}
|
|
100
|
+
getColDef() {
|
|
101
|
+
if (this.gridId && this.loggedInUser) {
|
|
102
|
+
this.gridService.getColDef(this.gridId).pipe(takeUntil(this.unsubscribe$)).subscribe((response) => {
|
|
103
|
+
if (response.status == 1) {
|
|
104
|
+
let coldef = response.list.map((res) => {
|
|
105
|
+
if (res.isButton === false) {
|
|
106
|
+
if (res.columnType === 'checkbox') {
|
|
107
|
+
return {
|
|
108
|
+
field: res.field,
|
|
109
|
+
headerName: res.title,
|
|
110
|
+
sortable: false,
|
|
111
|
+
tooltipField: res.field,
|
|
112
|
+
resizable: true,
|
|
113
|
+
headerCheckboxSelection: false,
|
|
114
|
+
filterable: false,
|
|
115
|
+
checkboxSelection: true,
|
|
116
|
+
showDisabledCheckboxes: true,
|
|
117
|
+
suppressFilter: true,
|
|
118
|
+
suppressSorting: true,
|
|
119
|
+
suppressMenu: true,
|
|
120
|
+
width: 55,
|
|
121
|
+
};
|
|
122
|
+
}
|
|
123
|
+
else if (res.columnType === 'dropdown') {
|
|
124
|
+
return {
|
|
125
|
+
field: res.field,
|
|
126
|
+
headerName: res.title,
|
|
127
|
+
resizable: true,
|
|
128
|
+
sortable: false,
|
|
129
|
+
suppressFilter: true,
|
|
130
|
+
suppressSorting: true,
|
|
131
|
+
suppressMenu: true,
|
|
132
|
+
tooltipField: res.field,
|
|
133
|
+
cellRenderer: DropdownRenderer,
|
|
134
|
+
cellRendererParams: {
|
|
135
|
+
onClick: this.onBtnClick.bind(this),
|
|
136
|
+
tooltip: res.tooltip,
|
|
137
|
+
dropDownData: res.dropDownData,
|
|
138
|
+
},
|
|
139
|
+
onCellClicked: (e) => {
|
|
140
|
+
e.node.setSelected(false);
|
|
141
|
+
},
|
|
142
|
+
width: 40,
|
|
143
|
+
pinned: res.pinPosition,
|
|
144
|
+
lockPinned: true,
|
|
145
|
+
};
|
|
146
|
+
}
|
|
147
|
+
else {
|
|
148
|
+
return {
|
|
149
|
+
field: res.field,
|
|
150
|
+
headerName: res.title,
|
|
151
|
+
resizable: true,
|
|
152
|
+
hide: !res.visible,
|
|
153
|
+
sortable: true,
|
|
154
|
+
tooltipField: res.field,
|
|
155
|
+
floatingFilter: this.floatingFilter,
|
|
156
|
+
valueFormatter: (params) => this.formatterService.colValueFormatter(params, res.columnType),
|
|
157
|
+
filterable: res.filterable,
|
|
158
|
+
filter: res.columnType == 'string'
|
|
159
|
+
? 'agTextColumnFilter'
|
|
160
|
+
: res.columnType == 'number'
|
|
161
|
+
? 'agNumberColumnFilter'
|
|
162
|
+
: 'agDateColumnFilter',
|
|
163
|
+
filterParams: {
|
|
164
|
+
comparator: (filterLocalDateAtMidnight, cellValue) => {
|
|
165
|
+
const dateAsString = cellValue;
|
|
166
|
+
if (dateAsString == null) {
|
|
167
|
+
return 0;
|
|
168
|
+
}
|
|
169
|
+
if (res.columnType == 'date') {
|
|
170
|
+
const cellDate = new Date(dateAsString);
|
|
171
|
+
if (cellDate < filterLocalDateAtMidnight) {
|
|
172
|
+
return -1;
|
|
173
|
+
}
|
|
174
|
+
else if (cellDate > filterLocalDateAtMidnight) {
|
|
175
|
+
return 1;
|
|
176
|
+
}
|
|
177
|
+
}
|
|
178
|
+
return 0;
|
|
179
|
+
},
|
|
180
|
+
buttons: ['reset']
|
|
181
|
+
},
|
|
182
|
+
};
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
else {
|
|
186
|
+
return {
|
|
187
|
+
field: res.field,
|
|
188
|
+
headerName: res.title,
|
|
189
|
+
resizable: true,
|
|
190
|
+
sortable: false,
|
|
191
|
+
hide: !res.visible,
|
|
192
|
+
suppressFilter: true,
|
|
193
|
+
suppressSorting: true,
|
|
194
|
+
suppressMenu: true,
|
|
195
|
+
tooltipField: res.field,
|
|
196
|
+
cellRenderer: ButtonRendererComponent,
|
|
197
|
+
cellRendererParams: {
|
|
198
|
+
onClick: this.onBtnClick.bind(this),
|
|
199
|
+
label: res.label,
|
|
200
|
+
icon: res.icon,
|
|
201
|
+
buttonName: res.buttonName,
|
|
202
|
+
tooltip: res.tooltip,
|
|
203
|
+
},
|
|
204
|
+
valueGetter: (params) => {
|
|
205
|
+
return res.tooltip || res.title;
|
|
206
|
+
},
|
|
207
|
+
minWidth: 20,
|
|
208
|
+
cellClass: 'action-button',
|
|
209
|
+
pinned: res.pinPosition,
|
|
210
|
+
lockPinned: true,
|
|
211
|
+
width: res.label ? 100 : 40,
|
|
212
|
+
};
|
|
213
|
+
}
|
|
214
|
+
});
|
|
215
|
+
this.exportColumnsList = response.list;
|
|
216
|
+
this.columnDefs = coldef;
|
|
217
|
+
this.agGrid.gridOptions?.api?.setColumnDefs(coldef);
|
|
218
|
+
this.getGridState();
|
|
219
|
+
}
|
|
220
|
+
else {
|
|
221
|
+
console.log('ColDef Read Error=>', response.message);
|
|
222
|
+
}
|
|
223
|
+
});
|
|
224
|
+
}
|
|
225
|
+
else {
|
|
226
|
+
console.log('Please pass valid GridId and loggedIn user Id');
|
|
227
|
+
}
|
|
228
|
+
}
|
|
229
|
+
setExternalFilters(options) {
|
|
230
|
+
var serverUrl = '';
|
|
231
|
+
if (this.serverDataUrl.indexOf('filter') >= 0 &&
|
|
232
|
+
options.indexOf('filter') >= 0) {
|
|
233
|
+
let slug = this.serverDataUrl.split('?$filter=');
|
|
234
|
+
if (slug && slug.length > 0) {
|
|
235
|
+
options = options + ' and ' + slug[1];
|
|
236
|
+
serverUrl = slug[0];
|
|
237
|
+
}
|
|
238
|
+
}
|
|
239
|
+
else if (this.serverDataUrl.indexOf('?') >= 0) {
|
|
240
|
+
serverUrl = this.serverDataUrl;
|
|
241
|
+
options = options.replace('?', '&');
|
|
242
|
+
}
|
|
243
|
+
return `${serverUrl}${options}`;
|
|
244
|
+
}
|
|
245
|
+
onGridReady(params) {
|
|
246
|
+
this.gridPageSize = this.pageSize;
|
|
247
|
+
if (this.enableServerSidePaging == true) {
|
|
248
|
+
params.api.setServerSideDatasource(new OdataServerSideProvider({
|
|
249
|
+
isCaseSensitiveStringFilter: false,
|
|
250
|
+
callApi: (options) => fetch(`${this.setExternalFilters(options)}`, {
|
|
251
|
+
headers: {
|
|
252
|
+
'Content-type': 'application/json',
|
|
253
|
+
Accept: 'application/json',
|
|
254
|
+
},
|
|
255
|
+
}).then((response) => response.json()),
|
|
256
|
+
afterLoadData: (options, rowData, totalCount) => {
|
|
257
|
+
if (!rowData || rowData.length <= 0) {
|
|
258
|
+
this.agGrid.api.showNoRowsOverlay();
|
|
259
|
+
}
|
|
260
|
+
else {
|
|
261
|
+
this.agGrid.api.hideOverlay();
|
|
262
|
+
}
|
|
263
|
+
},
|
|
264
|
+
}));
|
|
265
|
+
}
|
|
266
|
+
}
|
|
267
|
+
setGridState() {
|
|
268
|
+
if (this.gridColumnState) {
|
|
269
|
+
this.agGrid.columnApi.applyColumnState({
|
|
270
|
+
state: this.gridColumnState,
|
|
271
|
+
applyOrder: true,
|
|
272
|
+
});
|
|
273
|
+
}
|
|
274
|
+
else {
|
|
275
|
+
var columns = this.agGrid.columnApi.getColumns();
|
|
276
|
+
if (columns && columns.length > 0) {
|
|
277
|
+
if (columns.length > 15) {
|
|
278
|
+
const allColumnIds = [];
|
|
279
|
+
this.agGrid.columnApi.getColumns().forEach((column) => {
|
|
280
|
+
allColumnIds.push(column.getId());
|
|
281
|
+
});
|
|
282
|
+
this.agGrid.columnApi.autoSizeColumns(allColumnIds, false);
|
|
283
|
+
}
|
|
284
|
+
else {
|
|
285
|
+
this.agGrid.api.sizeColumnsToFit();
|
|
286
|
+
}
|
|
287
|
+
}
|
|
288
|
+
}
|
|
289
|
+
}
|
|
290
|
+
getGridState() {
|
|
291
|
+
if (this.gridId && this.loggedInUser) {
|
|
292
|
+
this.gridService
|
|
293
|
+
.getGridState(this.gridId, this.loggedInUser)
|
|
294
|
+
.pipe(takeUntil(this.unsubscribe$))
|
|
295
|
+
.subscribe((response) => {
|
|
296
|
+
if (response.status == 1 &&
|
|
297
|
+
response.object &&
|
|
298
|
+
response.object.gridConfig) {
|
|
299
|
+
this.gridColumnState = JSON.parse(response.object.gridConfig);
|
|
300
|
+
this.setGridState();
|
|
301
|
+
}
|
|
302
|
+
else {
|
|
303
|
+
console.log('Error while loading grid state');
|
|
304
|
+
}
|
|
305
|
+
});
|
|
306
|
+
}
|
|
307
|
+
}
|
|
308
|
+
onBtnClick(e) {
|
|
309
|
+
console.log('btn click=>', e);
|
|
310
|
+
this.btnClickHandler.emit(e.rowData);
|
|
311
|
+
}
|
|
312
|
+
onSaveGridColumnState(event) {
|
|
313
|
+
let columnState = this.agGrid.columnApi?.getColumnState();
|
|
314
|
+
let columnData = {
|
|
315
|
+
gridConfig: JSON.stringify(columnState),
|
|
316
|
+
uiGridId: this.gridId,
|
|
317
|
+
userId: this.loggedInUser,
|
|
318
|
+
};
|
|
319
|
+
if (event.finished == true || event.type === 'columnPinned') {
|
|
320
|
+
this.gridColumnState = columnState;
|
|
321
|
+
this.gridService.saveColumnConfig(columnData)
|
|
322
|
+
.pipe(takeUntil(this.unsubscribe$))
|
|
323
|
+
.subscribe((res) => {
|
|
324
|
+
this.setGridState();
|
|
325
|
+
if (res.status == 0) {
|
|
326
|
+
console.log('Error while saving column configuration:', res.message);
|
|
327
|
+
}
|
|
328
|
+
});
|
|
329
|
+
}
|
|
330
|
+
}
|
|
331
|
+
//custom export method
|
|
332
|
+
exportFile(type) {
|
|
333
|
+
this.getDataForExcelExport(type);
|
|
334
|
+
}
|
|
335
|
+
//Generate only those columns for export which are visible and are not of other types that are not required for export
|
|
336
|
+
generateColumnsForExcel() {
|
|
337
|
+
let columnsToBeDisplayedForExcel = [];
|
|
338
|
+
this.exportColumnsList.forEach((column) => {
|
|
339
|
+
if (column.visible == true &&
|
|
340
|
+
column.columnType != 'checkbox' &&
|
|
341
|
+
column.columnType != 'dropdown' &&
|
|
342
|
+
column.columnType != '') {
|
|
343
|
+
columnsToBeDisplayedForExcel.push(column.field);
|
|
344
|
+
}
|
|
345
|
+
});
|
|
346
|
+
return columnsToBeDisplayedForExcel;
|
|
347
|
+
}
|
|
348
|
+
//Get data from server without paging so that whole data can be exported to excel
|
|
349
|
+
// and also check for server side and client side rendering of data for export.
|
|
350
|
+
getDataForExcelExport(type) {
|
|
351
|
+
this.agGrid.api.showLoadingOverlay();
|
|
352
|
+
if (this.enableServerSidePaging) {
|
|
353
|
+
this.gridService
|
|
354
|
+
.getDataForExport(this.serverDataUrl)
|
|
355
|
+
.pipe(takeUntil(this.unsubscribe$))
|
|
356
|
+
.subscribe((response) => {
|
|
357
|
+
this.agGrid.api.hideOverlay();
|
|
358
|
+
if (response && response.value.length > 0) {
|
|
359
|
+
this.excelAPI.setRowData(response.value);
|
|
360
|
+
this.excelAPI.sizeColumnsToFit();
|
|
361
|
+
if (type == 'csv') {
|
|
362
|
+
this.excelAPI.exportDataAsCsv({
|
|
363
|
+
columnKeys: this.generateColumnsForExcel(),
|
|
364
|
+
});
|
|
365
|
+
}
|
|
366
|
+
else {
|
|
367
|
+
this.excelAPI.exportDataAsExcel({
|
|
368
|
+
columnKeys: this.generateColumnsForExcel(),
|
|
369
|
+
});
|
|
370
|
+
}
|
|
371
|
+
}
|
|
372
|
+
else {
|
|
373
|
+
console.log('Error while fetching data for excel/csv export');
|
|
374
|
+
}
|
|
375
|
+
});
|
|
376
|
+
}
|
|
377
|
+
else {
|
|
378
|
+
this.agGrid.api.hideOverlay();
|
|
379
|
+
if (type == 'csv') {
|
|
380
|
+
this.agGrid.api.exportDataAsCsv({
|
|
381
|
+
columnKeys: this.generateColumnsForExcel(),
|
|
382
|
+
});
|
|
383
|
+
}
|
|
384
|
+
else {
|
|
385
|
+
this.agGrid.api.exportDataAsExcel({
|
|
386
|
+
columnKeys: this.generateColumnsForExcel(),
|
|
387
|
+
});
|
|
388
|
+
}
|
|
389
|
+
}
|
|
390
|
+
}
|
|
391
|
+
onSelectionChanged(e) {
|
|
392
|
+
this.selectionChanged.emit(e);
|
|
393
|
+
}
|
|
394
|
+
onFilterChanged(e) {
|
|
395
|
+
this.filterChanged.emit(e);
|
|
396
|
+
}
|
|
397
|
+
onFirstDataRendered(e) {
|
|
398
|
+
this.firstDataRendered.emit(e);
|
|
399
|
+
}
|
|
400
|
+
onGridReadyExcel(params) {
|
|
401
|
+
this.excelAPI = params.api;
|
|
402
|
+
}
|
|
403
|
+
//destroy all associated subscriptions on component destroy
|
|
404
|
+
ngOnDestroy() {
|
|
405
|
+
this.unsubscribe$.next();
|
|
406
|
+
this.unsubscribe$.complete();
|
|
407
|
+
}
|
|
408
|
+
}
|
|
409
|
+
GridLibraryComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.6", ngImport: i0, type: GridLibraryComponent, deps: [{ token: i1.GridLibraryService }, { token: i2.ColumnValueFormatter }], target: i0.ɵɵFactoryTarget.Component });
|
|
410
|
+
GridLibraryComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.6", type: GridLibraryComponent, selector: "lib-basesite-shared-grid-lib", inputs: { columnDefs: "columnDefs", rowData: "rowData", pageSize: "pageSize", rowSelection: "rowSelection", gridId: "gridId", loggedInUser: "loggedInUser", enableServerSidePaging: "enableServerSidePaging", serverDataUrl: "serverDataUrl", environment: "environment", cacheBlockSize: "cacheBlockSize", rowMultiSelectWithClick: "rowMultiSelectWithClick", floatingFilter: "floatingFilter", paginationAutoPageSize: "paginationAutoPageSize" }, outputs: { btnClickHandler: "btnClickHandler", firstDataRendered: "firstDataRendered", filterChanged: "filterChanged", selectionChanged: "selectionChanged" }, viewQueries: [{ propertyName: "agGrid", first: true, predicate: ["agGrid"], descendants: true }], ngImport: i0, template: `
|
|
411
|
+
<ag-grid-angular #agGrid
|
|
412
|
+
style="width: 100%;height:98.2vh"
|
|
413
|
+
class="ag-theme-balham shared-grid-lib"
|
|
414
|
+
[columnDefs]="columnDefs"
|
|
415
|
+
[defaultColDef]="defaultColDef"
|
|
416
|
+
[rowData]="rowData"
|
|
417
|
+
[rowSelection]="rowSelection"
|
|
418
|
+
[animateRows]="true"
|
|
419
|
+
(gridReady)="onGridReady($event)"
|
|
420
|
+
[pagination]="true"
|
|
421
|
+
[paginationPageSize]="gridPageSize"
|
|
422
|
+
[paginationNumberFormatter]="paginationNumberFormatter"
|
|
423
|
+
(modelUpdated)="onModelUpdated()"
|
|
424
|
+
[tooltipShowDelay]="tooltipShowDelay"
|
|
425
|
+
[tooltipHideDelay]="tooltipHideDelay"
|
|
426
|
+
[rowModelType]="rowModelType"
|
|
427
|
+
[cacheBlockSize]="cacheBlockSize"
|
|
428
|
+
[maxConcurrentDatasourceRequests]="1"
|
|
429
|
+
[blockLoadDebounceMillis]="100"
|
|
430
|
+
[paginationAutoPageSize]="paginationAutoPageSize"
|
|
431
|
+
(columnVisible)="onSaveGridColumnState($event)"
|
|
432
|
+
(columnPinned)="onSaveGridColumnState($event)"
|
|
433
|
+
(columnResized)="onSaveGridColumnState($event)"
|
|
434
|
+
(columnMoved)="onSaveGridColumnState($event)"
|
|
435
|
+
(sortChanged)="onSortChangedEvent()"
|
|
436
|
+
[rowMultiSelectWithClick]="rowMultiSelectWithClick"
|
|
437
|
+
[getContextMenuItems]="getContextMenuItems"
|
|
438
|
+
(selectionChanged)="onSelectionChanged($event)"
|
|
439
|
+
(filterChanged)="onFilterChanged($event)"
|
|
440
|
+
(firstDataRendered)="onFirstDataRendered($event)"
|
|
441
|
+
>
|
|
442
|
+
</ag-grid-angular>
|
|
443
|
+
<ag-grid-angular
|
|
444
|
+
#agGridHidden
|
|
445
|
+
style="height:100vh; width:100%;display:none"
|
|
446
|
+
class="ag-theme-balham"
|
|
447
|
+
[rowData]="rowDataHidden"
|
|
448
|
+
[columnDefs]="columnDefs"
|
|
449
|
+
[defaultColDef]="defaultColDef"
|
|
450
|
+
[animateRows]="false"
|
|
451
|
+
[rowSelection]="'multiple'"
|
|
452
|
+
(gridReady)="onGridReadyExcel($event)"
|
|
453
|
+
[suppressScrollOnNewData]="true"
|
|
454
|
+
[cacheQuickFilter]="false"
|
|
455
|
+
>
|
|
456
|
+
</ag-grid-angular>
|
|
457
|
+
`, isInline: true, dependencies: [{ kind: "component", type: i3.AgGridAngular, selector: "ag-grid-angular", inputs: ["gridOptions", "modules", "statusBar", "sideBar", "suppressContextMenu", "preventDefaultOnContextMenu", "allowContextMenuWithControlKey", "suppressMenuHide", "enableBrowserTooltips", "tooltipShowDelay", "tooltipHideDelay", "tooltipMouseTrack", "popupParent", "copyHeadersToClipboard", "copyGroupHeadersToClipboard", "clipboardDelimiter", "suppressCopyRowsToClipboard", "suppressCopySingleCellRanges", "suppressLastEmptyLineOnPaste", "suppressClipboardPaste", "suppressClipboardApi", "suppressCutToClipboard", "columnDefs", "defaultColDef", "defaultColGroupDef", "columnTypes", "maintainColumnOrder", "suppressFieldDotNotation", "headerHeight", "groupHeaderHeight", "floatingFiltersHeight", "pivotHeaderHeight", "pivotGroupHeaderHeight", "allowDragFromColumnsToolPanel", "suppressMovableColumns", "suppressColumnMoveAnimation", "suppressDragLeaveHidesColumns", "suppressRowGroupHidesColumns", "colResizeDefault", "suppressAutoSize", "autoSizePadding", "skipHeaderOnAutoSize", "components", "frameworkComponents", "editType", "singleClickEdit", "suppressClickEdit", "readOnlyEdit", "stopEditingWhenCellsLoseFocus", "enterMovesDown", "enterMovesDownAfterEdit", "enableCellEditingOnBackspace", "undoRedoCellEditing", "undoRedoCellEditingLimit", "defaultCsvExportParams", "suppressCsvExport", "defaultExcelExportParams", "suppressExcelExport", "excelStyles", "quickFilterText", "cacheQuickFilter", "excludeHiddenColumnsFromQuickFilter", "excludeChildrenWhenTreeDataFiltering", "enableCharts", "chartThemes", "customChartThemes", "chartThemeOverrides", "enableChartToolPanelsButton", "suppressChartToolPanelsButton", "chartToolPanelsDef", "loadingCellRenderer", "loadingCellRendererFramework", "loadingCellRendererParams", "loadingCellRendererSelector", "localeText", "masterDetail", "keepDetailRows", "keepDetailRowsCount", "detailCellRenderer", "detailCellRendererFramework", "detailCellRendererParams", "detailRowHeight", "detailRowAutoHeight", "context", "alignedGrids", "tabIndex", "rowBuffer", "valueCache", "valueCacheNeverExpires", "enableCellExpressions", "suppressParentsInRowNodes", "suppressTouch", "suppressFocusAfterRefresh", "suppressAsyncEvents", "suppressBrowserResizeObserver", "suppressPropertyNamesCheck", "suppressChangeDetection", "debug", "overlayLoadingTemplate", "loadingOverlayComponent", "loadingOverlayComponentFramework", "loadingOverlayComponentParams", "suppressLoadingOverlay", "overlayNoRowsTemplate", "noRowsOverlayComponent", "noRowsOverlayComponentFramework", "noRowsOverlayComponentParams", "suppressNoRowsOverlay", "pagination", "paginationPageSize", "paginationAutoPageSize", "paginateChildRows", "suppressPaginationPanel", "pivotMode", "pivotPanelShow", "pivotColumnGroupTotals", "pivotRowTotals", "pivotSuppressAutoColumn", "suppressExpandablePivotGroups", "functionsReadOnly", "aggFuncs", "suppressAggFuncInHeader", "suppressAggAtRootLevel", "aggregateOnlyChangedColumns", "suppressAggFilteredOnly", "removePivotHeaderRowWhenSingleValueColumn", "animateRows", "enableCellChangeFlash", "cellFlashDelay", "cellFadeDelay", "allowShowChangeAfterFilter", "domLayout", "ensureDomOrder", "enableRtl", "suppressColumnVirtualisation", "suppressMaxRenderedRowRestriction", "suppressRowVirtualisation", "rowDragManaged", "suppressRowDrag", "suppressMoveWhenRowDragging", "rowDragEntireRow", "rowDragMultiRow", "rowDragText", "fullWidthCellRenderer", "fullWidthCellRendererFramework", "fullWidthCellRendererParams", "embedFullWidthRows", "groupDisplayType", "groupDefaultExpanded", "autoGroupColumnDef", "groupMaintainOrder", "groupSelectsChildren", "groupAggFiltering", "groupIncludeFooter", "groupIncludeTotalFooter", "groupSuppressBlankHeader", "groupSelectsFiltered", "showOpenedGroup", "groupRemoveSingleChildren", "groupRemoveLowestSingleChildren", "groupHideOpenParents", "groupAllowUnbalanced", "rowGroupPanelShow", "groupRowRenderer", "groupRowRendererFramework", "groupRowRendererParams", "suppressMakeColumnVisibleAfterUnGroup", "treeData", "rowGroupPanelSuppressSort", "groupRowsSticky", "rememberGroupStateWhenNewData", "pinnedTopRowData", "pinnedBottomRowData", "rowModelType", "rowData", "immutableData", "asyncTransactionWaitMillis", "suppressModelUpdateAfterUpdateTransaction", "datasource", "cacheOverflowSize", "infiniteInitialRowCount", "serverSideInitialRowCount", "serverSideStoreType", "suppressServerSideInfiniteScroll", "cacheBlockSize", "maxBlocksInCache", "maxConcurrentDatasourceRequests", "blockLoadDebounceMillis", "purgeClosedRowNodes", "serverSideDatasource", "serverSideSortAllLevels", "serverSideFilterAllLevels", "serverSideSortOnServer", "serverSideFilterOnServer", "serverSideSortingAlwaysResets", "serverSideFilteringAlwaysResets", "viewportDatasource", "viewportRowModelPageSize", "viewportRowModelBufferSize", "alwaysShowHorizontalScroll", "alwaysShowVerticalScroll", "debounceVerticalScrollbar", "suppressHorizontalScroll", "suppressScrollOnNewData", "suppressScrollWhenPopupsAreOpen", "suppressAnimationFrame", "suppressMiddleClickScrolls", "suppressPreventDefaultOnMouseWheel", "scrollbarWidth", "rowSelection", "rowMultiSelectWithClick", "suppressRowDeselection", "suppressRowClickSelection", "suppressCellSelection", "suppressCellFocus", "suppressMultiRangeSelection", "enableCellTextSelection", "enableRangeSelection", "enableRangeHandle", "enableFillHandle", "fillHandleDirection", "suppressClearOnFillReduction", "sortingOrder", "accentedSort", "unSortIcon", "suppressMultiSort", "alwaysMultiSort", "multiSortKey", "suppressMaintainUnsortedOrder", "icons", "rowHeight", "rowStyle", "rowClass", "rowClassRules", "suppressRowHoverHighlight", "suppressRowTransform", "columnHoverHighlight", "deltaSort", "treeDataDisplayType", "functionsPassive", "enableGroupEdit", "getContextMenuItems", "getMainMenuItems", "postProcessPopup", "processCellForClipboard", "processHeaderForClipboard", "processGroupHeaderForClipboard", "processCellFromClipboard", "sendToClipboard", "processDataFromClipboard", "isExternalFilterPresent", "doesExternalFilterPass", "getChartToolbarItems", "createChartContainer", "navigateToNextHeader", "tabToNextHeader", "navigateToNextCell", "tabToNextCell", "localeTextFunc", "getLocaleText", "getDocument", "paginationNumberFormatter", "groupRowAggNodes", "getGroupRowAgg", "isGroupOpenByDefault", "initialGroupOrderComparator", "defaultGroupOrderComparator", "processSecondaryColDef", "processSecondaryColGroupDef", "processPivotResultColDef", "processPivotResultColGroupDef", "getDataPath", "getChildCount", "getServerSideGroupLevelParams", "getServerSideStoreParams", "isServerSideGroupOpenByDefault", "isApplyServerSideTransaction", "isServerSideGroup", "getServerSideGroupKey", "getBusinessKeyForNode", "getRowNodeId", "getRowId", "resetRowDataOnUpdate", "processRowPostCreate", "isRowSelectable", "isRowMaster", "fillOperation", "postSort", "postSortRows", "getRowStyle", "getRowClass", "getRowHeight", "isFullWidthCell", "isFullWidthRow"], outputs: ["toolPanelVisibleChanged", "toolPanelSizeChanged", "pasteStart", "pasteEnd", "columnVisible", "columnPinned", "columnResized", "columnMoved", "columnValueChanged", "columnPivotModeChanged", "columnPivotChanged", "columnGroupOpened", "newColumnsLoaded", "gridColumnsChanged", "displayedColumnsChanged", "virtualColumnsChanged", "columnEverythingChanged", "componentStateChanged", "cellValueChanged", "cellEditRequest", "rowValueChanged", "cellEditingStarted", "cellEditingStopped", "rowEditingStarted", "rowEditingStopped", "undoStarted", "undoEnded", "redoStarted", "redoEnded", "filterOpened", "filterChanged", "filterModified", "chartCreated", "chartRangeSelectionChanged", "chartOptionsChanged", "chartDestroyed", "cellKeyDown", "cellKeyPress", "gridReady", "firstDataRendered", "gridSizeChanged", "modelUpdated", "virtualRowRemoved", "viewportChanged", "bodyScroll", "bodyScrollEnd", "dragStarted", "dragStopped", "paginationChanged", "rowDragEnter", "rowDragMove", "rowDragLeave", "rowDragEnd", "columnRowGroupChanged", "rowGroupOpened", "expandOrCollapseAll", "pinnedRowDataChanged", "rowDataChanged", "rowDataUpdated", "asyncTransactionsFlushed", "cellClicked", "cellDoubleClicked", "cellFocused", "cellMouseOver", "cellMouseOut", "cellMouseDown", "rowClicked", "rowDoubleClicked", "rowSelected", "selectionChanged", "cellContextMenu", "rangeSelectionChanged", "sortChanged", "columnRowGroupChangeRequest", "columnPivotChangeRequest", "columnValueChangeRequest", "columnAggFuncChangeRequest"] }] });
|
|
458
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.6", ngImport: i0, type: GridLibraryComponent, decorators: [{
|
|
459
|
+
type: Component,
|
|
460
|
+
args: [{ selector: 'lib-basesite-shared-grid-lib', template: `
|
|
461
|
+
<ag-grid-angular #agGrid
|
|
462
|
+
style="width: 100%;height:98.2vh"
|
|
463
|
+
class="ag-theme-balham shared-grid-lib"
|
|
464
|
+
[columnDefs]="columnDefs"
|
|
465
|
+
[defaultColDef]="defaultColDef"
|
|
466
|
+
[rowData]="rowData"
|
|
467
|
+
[rowSelection]="rowSelection"
|
|
468
|
+
[animateRows]="true"
|
|
469
|
+
(gridReady)="onGridReady($event)"
|
|
470
|
+
[pagination]="true"
|
|
471
|
+
[paginationPageSize]="gridPageSize"
|
|
472
|
+
[paginationNumberFormatter]="paginationNumberFormatter"
|
|
473
|
+
(modelUpdated)="onModelUpdated()"
|
|
474
|
+
[tooltipShowDelay]="tooltipShowDelay"
|
|
475
|
+
[tooltipHideDelay]="tooltipHideDelay"
|
|
476
|
+
[rowModelType]="rowModelType"
|
|
477
|
+
[cacheBlockSize]="cacheBlockSize"
|
|
478
|
+
[maxConcurrentDatasourceRequests]="1"
|
|
479
|
+
[blockLoadDebounceMillis]="100"
|
|
480
|
+
[paginationAutoPageSize]="paginationAutoPageSize"
|
|
481
|
+
(columnVisible)="onSaveGridColumnState($event)"
|
|
482
|
+
(columnPinned)="onSaveGridColumnState($event)"
|
|
483
|
+
(columnResized)="onSaveGridColumnState($event)"
|
|
484
|
+
(columnMoved)="onSaveGridColumnState($event)"
|
|
485
|
+
(sortChanged)="onSortChangedEvent()"
|
|
486
|
+
[rowMultiSelectWithClick]="rowMultiSelectWithClick"
|
|
487
|
+
[getContextMenuItems]="getContextMenuItems"
|
|
488
|
+
(selectionChanged)="onSelectionChanged($event)"
|
|
489
|
+
(filterChanged)="onFilterChanged($event)"
|
|
490
|
+
(firstDataRendered)="onFirstDataRendered($event)"
|
|
491
|
+
>
|
|
492
|
+
</ag-grid-angular>
|
|
493
|
+
<ag-grid-angular
|
|
494
|
+
#agGridHidden
|
|
495
|
+
style="height:100vh; width:100%;display:none"
|
|
496
|
+
class="ag-theme-balham"
|
|
497
|
+
[rowData]="rowDataHidden"
|
|
498
|
+
[columnDefs]="columnDefs"
|
|
499
|
+
[defaultColDef]="defaultColDef"
|
|
500
|
+
[animateRows]="false"
|
|
501
|
+
[rowSelection]="'multiple'"
|
|
502
|
+
(gridReady)="onGridReadyExcel($event)"
|
|
503
|
+
[suppressScrollOnNewData]="true"
|
|
504
|
+
[cacheQuickFilter]="false"
|
|
505
|
+
>
|
|
506
|
+
</ag-grid-angular>
|
|
507
|
+
` }]
|
|
508
|
+
}], ctorParameters: function () { return [{ type: i1.GridLibraryService }, { type: i2.ColumnValueFormatter }]; }, propDecorators: { columnDefs: [{
|
|
509
|
+
type: Input
|
|
510
|
+
}], rowData: [{
|
|
511
|
+
type: Input
|
|
512
|
+
}], pageSize: [{
|
|
513
|
+
type: Input
|
|
514
|
+
}], rowSelection: [{
|
|
515
|
+
type: Input
|
|
516
|
+
}], gridId: [{
|
|
517
|
+
type: Input
|
|
518
|
+
}], loggedInUser: [{
|
|
519
|
+
type: Input
|
|
520
|
+
}], enableServerSidePaging: [{
|
|
521
|
+
type: Input
|
|
522
|
+
}], serverDataUrl: [{
|
|
523
|
+
type: Input
|
|
524
|
+
}], environment: [{
|
|
525
|
+
type: Input
|
|
526
|
+
}], cacheBlockSize: [{
|
|
527
|
+
type: Input
|
|
528
|
+
}], rowMultiSelectWithClick: [{
|
|
529
|
+
type: Input
|
|
530
|
+
}], floatingFilter: [{
|
|
531
|
+
type: Input
|
|
532
|
+
}], paginationAutoPageSize: [{
|
|
533
|
+
type: Input
|
|
534
|
+
}], btnClickHandler: [{
|
|
535
|
+
type: Output
|
|
536
|
+
}], firstDataRendered: [{
|
|
537
|
+
type: Output
|
|
538
|
+
}], filterChanged: [{
|
|
539
|
+
type: Output
|
|
540
|
+
}], selectionChanged: [{
|
|
541
|
+
type: Output
|
|
542
|
+
}], agGrid: [{
|
|
543
|
+
type: ViewChild,
|
|
544
|
+
args: ['agGrid']
|
|
545
|
+
}] } });
|
|
546
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid-library.component.js","sourceRoot":"","sources":["../../../../projects/basesite-shared-grid-lib/src/lib/grid-library.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { DatePipe } from '@angular/common';\r\nimport {\r\n  Component,\r\n  EventEmitter,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport { AgGridAngular } from 'ag-grid-angular';\r\nimport {\r\n  ColDef,\r\n  GetContextMenuItemsParams,\r\n  GetRowIdFunc,\r\n  GetRowIdParams,\r\n  GridApi,\r\n  GridReadyEvent,\r\n  MenuItemDef,\r\n  PaginationNumberFormatterParams,\r\n  RowModelType,\r\n  RowNode,\r\n  ValueFormatterParams,\r\n} from 'ag-grid-community';\r\nimport { GridLibraryService } from './grid-library.service';\r\nimport { OdataServerSideProvider } from './helpers';\r\nimport { ButtonRendererComponent } from './renderer/button-renderer/button-renderer.component';\r\nimport { CustomTooltip } from './renderer/tooltip-renderer/custom-tooltip-renderer';\r\nimport { DropdownRenderer } from './renderer/dropdown-renderer/drop-down-renderer';\r\nimport { ColumnValueFormatter } from './formatters/column-value-formatter';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport { Subject } from 'rxjs';\r\n\r\n@Component({\r\n  selector: 'lib-basesite-shared-grid-lib',\r\n  template: `\r\n    <ag-grid-angular #agGrid\r\n      style=\"width: 100%;height:98.2vh\"\r\n      class=\"ag-theme-balham shared-grid-lib\"\r\n      [columnDefs]=\"columnDefs\"\r\n      [defaultColDef]=\"defaultColDef\"\r\n      [rowData]=\"rowData\"\r\n      [rowSelection]=\"rowSelection\"\r\n      [animateRows]=\"true\"\r\n      (gridReady)=\"onGridReady($event)\"\r\n      [pagination]=\"true\"\r\n      [paginationPageSize]=\"gridPageSize\"\r\n      [paginationNumberFormatter]=\"paginationNumberFormatter\"\r\n      (modelUpdated)=\"onModelUpdated()\"\r\n      [tooltipShowDelay]=\"tooltipShowDelay\"\r\n      [tooltipHideDelay]=\"tooltipHideDelay\"\r\n      [rowModelType]=\"rowModelType\"\r\n      [cacheBlockSize]=\"cacheBlockSize\"\r\n      [maxConcurrentDatasourceRequests]=\"1\"\r\n      [blockLoadDebounceMillis]=\"100\"\r\n      [paginationAutoPageSize]=\"paginationAutoPageSize\"\r\n      (columnVisible)=\"onSaveGridColumnState($event)\"\r\n      (columnPinned)=\"onSaveGridColumnState($event)\"\r\n      (columnResized)=\"onSaveGridColumnState($event)\"\r\n      (columnMoved)=\"onSaveGridColumnState($event)\"\r\n      (sortChanged)=\"onSortChangedEvent()\"\r\n      [rowMultiSelectWithClick]=\"rowMultiSelectWithClick\"\r\n      [getContextMenuItems]=\"getContextMenuItems\"\r\n      (selectionChanged)=\"onSelectionChanged($event)\"\r\n      (filterChanged)=\"onFilterChanged($event)\"\r\n      (firstDataRendered)=\"onFirstDataRendered($event)\"\r\n    >\r\n    </ag-grid-angular>\r\n    <ag-grid-angular\r\n      #agGridHidden\r\n      style=\"height:100vh; width:100%;display:none\"\r\n      class=\"ag-theme-balham\"\r\n      [rowData]=\"rowDataHidden\"\r\n      [columnDefs]=\"columnDefs\"\r\n      [defaultColDef]=\"defaultColDef\"\r\n      [animateRows]=\"false\"\r\n      [rowSelection]=\"'multiple'\"\r\n      (gridReady)=\"onGridReadyExcel($event)\"\r\n      [suppressScrollOnNewData]=\"true\"\r\n      [cacheQuickFilter]=\"false\"\r\n    >\r\n    </ag-grid-angular>\r\n  `,\r\n  styles: [],\r\n})\r\nexport class GridLibraryComponent implements OnInit,OnDestroy {\r\n  //input params\r\n  @Input() columnDefs: any;\r\n  @Input() rowData: any;\r\n  @Input() pageSize: number = 20;\r\n  @Input() rowSelection: any = 'multiple';\r\n  @Input() gridId: any;\r\n  @Input() loggedInUser: any;\r\n  @Input() enableServerSidePaging: boolean = false;\r\n  @Input() serverDataUrl!: string;\r\n  @Input() environment!: string;\r\n  @Input() cacheBlockSize: number = 0;\r\n  @Input() rowMultiSelectWithClick: boolean = false;\r\n  @Input() floatingFilter: boolean = false;\r\n  @Input() paginationAutoPageSize: boolean = false;\r\n  //event emitters\r\n  @Output() btnClickHandler = new EventEmitter<any>();\r\n  @Output() firstDataRendered = new EventEmitter<any>();\r\n  @Output() filterChanged = new EventEmitter<any>();\r\n  @Output() selectionChanged = new EventEmitter<any>();\r\n\r\n  //viewChilds\r\n  @ViewChild('agGrid') agGrid!: AgGridAngular;\r\n\r\n  //paramters\r\n  rowDataHidden: any = [];\r\n  gridColumnState: any;\r\n  exportColumnsList: any = [];\r\n  public tooltipShowDelay = 0;\r\n  public tooltipHideDelay = 2000;\r\n  public rowModelType: RowModelType = 'clientSide';\r\n  public gridPageSize: number = 0;\r\n  private excelAPI!: GridApi;\r\n\r\n  //unsubscribe subject\r\n  private unsubscribe$ = new Subject<void>();\r\n  \r\n  constructor(\r\n    private gridService: GridLibraryService,\r\n    private formatterService: ColumnValueFormatter\r\n  ) {\r\n  }\r\n\r\n  onSortChangedEvent() {\r\n    this.gridColumnState = this.agGrid.columnApi.getColumnState();\r\n  }\r\n\r\n  public defaultColDef: ColDef = {\r\n    sortable: true,\r\n    filter: true,\r\n    tooltipComponent: CustomTooltip,\r\n  };\r\n\r\n  ngOnInit() {\r\n    this.gridPageSize = this.pageSize;\r\n    this.cacheBlockSize = this.cacheBlockSize = 0\r\n      ? this.pageSize\r\n      : this.cacheBlockSize;\r\n    this.gridService.setBaseUrl(this.environment);\r\n    this.getGridState();\r\n    this.getColDef();\r\n    if (this.enableServerSidePaging == true) {\r\n      this.rowModelType = 'serverSide';\r\n      this.rowData = '';\r\n    } else {\r\n      this.rowModelType = 'clientSide';\r\n    }\r\n  }\r\n\r\n  public paginationNumberFormatter: (\r\n    params: PaginationNumberFormatterParams\r\n  ) => string = (params: PaginationNumberFormatterParams) => {\r\n    return '[' + params.value.toLocaleString() + ']';\r\n  };\r\n\r\n  onModelUpdated() {\r\n    this.setGridState();\r\n  }\r\n\r\n  getColDef() {\r\n    if (this.gridId && this.loggedInUser) {\r\n      this.gridService.getColDef(this.gridId).pipe(takeUntil(this.unsubscribe$)).subscribe((response: any) => {\r\n        if (response.status == 1) {\r\n          let coldef: ColDef[] = response.list.map((res: any) => {\r\n            if (res.isButton === false) {\r\n              if (res.columnType === 'checkbox') {\r\n                return {\r\n                  field: res.field,\r\n                  headerName: res.title,\r\n                  sortable: false,\r\n                  tooltipField: res.field,\r\n                  resizable: true,\r\n                  headerCheckboxSelection: false,\r\n                  filterable: false,\r\n                  checkboxSelection: true,\r\n                  showDisabledCheckboxes: true,\r\n                  suppressFilter: true,\r\n                  suppressSorting: true,\r\n                  suppressMenu: true,\r\n                  width: 55,\r\n                };\r\n              } else if (res.columnType === 'dropdown') {\r\n                return {\r\n                  field: res.field,\r\n                  headerName: res.title,\r\n                  resizable: true,\r\n                  sortable: false,\r\n                  suppressFilter: true,\r\n                  suppressSorting: true,\r\n                  suppressMenu: true,\r\n                  tooltipField: res.field,\r\n                  cellRenderer: DropdownRenderer,\r\n                  cellRendererParams: {\r\n                    onClick: this.onBtnClick.bind(this),\r\n                    tooltip: res.tooltip,\r\n                    dropDownData: res.dropDownData,\r\n                  },\r\n                  onCellClicked: (e: any) => {\r\n                    e.node.setSelected(false);\r\n                  },\r\n                  width: 40,\r\n                  pinned: res.pinPosition,\r\n                  lockPinned: true,\r\n                };\r\n              } else {\r\n                return {\r\n                  field: res.field,\r\n                  headerName: res.title,\r\n                  resizable: true,\r\n                  hide: !res.visible,\r\n                  sortable: true,\r\n                  tooltipField: res.field,\r\n                  floatingFilter: this.floatingFilter,\r\n                  valueFormatter: (params: ValueFormatterParams) =>\r\n                    this.formatterService.colValueFormatter(\r\n                      params,\r\n                      res.columnType\r\n                    ),\r\n                  filterable: res.filterable,\r\n                  filter:\r\n                    res.columnType == 'string'\r\n                      ? 'agTextColumnFilter'\r\n                      : res.columnType == 'number'\r\n                      ? 'agNumberColumnFilter'\r\n                      : 'agDateColumnFilter',\r\n                  filterParams: {\r\n                    comparator: (\r\n                      filterLocalDateAtMidnight: any,\r\n                      cellValue: any\r\n                    ) => {\r\n                      const dateAsString = cellValue;\r\n\r\n                      if (dateAsString == null) {\r\n                        return 0;\r\n                      }\r\n                      if (res.columnType == 'date') {\r\n                        const cellDate = new Date(dateAsString);\r\n                        if (cellDate < filterLocalDateAtMidnight) {\r\n                          return -1;\r\n                        } else if (cellDate > filterLocalDateAtMidnight) {\r\n                          return 1;\r\n                        }\r\n                      }\r\n                      return 0;\r\n                    },\r\n                    buttons: ['reset']\r\n                  },\r\n                };\r\n              }\r\n            } else {\r\n              return {\r\n                field: res.field,\r\n                headerName: res.title,\r\n                resizable: true,\r\n                sortable: false,\r\n                hide: !res.visible,\r\n                suppressFilter: true,\r\n                suppressSorting: true,\r\n                suppressMenu: true,\r\n                tooltipField: res.field,\r\n                cellRenderer: ButtonRendererComponent,\r\n                cellRendererParams: {\r\n                  onClick: this.onBtnClick.bind(this),\r\n                  label: res.label,\r\n                  icon: res.icon,\r\n                  buttonName: res.buttonName,\r\n                  tooltip: res.tooltip,\r\n                },\r\n                valueGetter: (params: any) => {\r\n                  return res.tooltip || res.title;\r\n                },\r\n                minWidth: 20,\r\n                cellClass: 'action-button',\r\n                pinned: res.pinPosition,\r\n                lockPinned: true,\r\n                width: res.label ? 100 : 40,\r\n              };\r\n            }\r\n          });\r\n          this.exportColumnsList = response.list;\r\n          this.columnDefs = coldef;\r\n          this.agGrid.gridOptions?.api?.setColumnDefs(coldef);\r\n          this.getGridState();\r\n        } else {\r\n          console.log('ColDef Read Error=>', response.message);\r\n        }\r\n      });\r\n    } else {\r\n      console.log('Please pass valid GridId and loggedIn user Id');\r\n    }\r\n  }\r\n\r\n  setExternalFilters(options: any) {\r\n    var serverUrl = '';\r\n    if (\r\n      this.serverDataUrl.indexOf('filter') >= 0 &&\r\n      options.indexOf('filter') >= 0\r\n    ) {\r\n      let slug = this.serverDataUrl.split('?$filter=');\r\n      if (slug && slug.length > 0) {\r\n        options = options + ' and ' + slug[1];\r\n        serverUrl = slug[0];\r\n      }\r\n    } else if (this.serverDataUrl.indexOf('?') >= 0) {\r\n      serverUrl = this.serverDataUrl;\r\n      options = options.replace('?', '&');\r\n    }\r\n    return `${serverUrl}${options}`;\r\n  }\r\n\r\n  onGridReady(params: GridReadyEvent) {\r\n    this.gridPageSize = this.pageSize;\r\n    if (this.enableServerSidePaging == true) {\r\n      params.api.setServerSideDatasource(\r\n        new OdataServerSideProvider({\r\n          isCaseSensitiveStringFilter: false,\r\n          callApi: (options) =>\r\n            fetch(`${this.setExternalFilters(options)}`, {\r\n              headers: {\r\n                'Content-type': 'application/json',\r\n                Accept: 'application/json',\r\n              },\r\n            }).then((response) => response.json()),\r\n          afterLoadData: (options, rowData, totalCount) => {\r\n            if (!rowData || rowData.length <= 0) {\r\n              this.agGrid.api.showNoRowsOverlay();\r\n            } else {\r\n              this.agGrid.api.hideOverlay();\r\n            }\r\n          },\r\n        })\r\n      );\r\n    }\r\n  }\r\n\r\n  setGridState() {\r\n    if (this.gridColumnState) {\r\n      this.agGrid.columnApi.applyColumnState({\r\n        state: this.gridColumnState,\r\n        applyOrder: true,\r\n      });\r\n    } else {\r\n      var columns = this.agGrid.columnApi.getColumns();\r\n      if (columns && columns.length > 0) {\r\n        if (columns.length > 15) {\r\n          const allColumnIds: string[] = [];\r\n          this.agGrid.columnApi!.getColumns()!.forEach((column) => {\r\n            allColumnIds.push(column.getId());\r\n          });\r\n          this.agGrid.columnApi!.autoSizeColumns(allColumnIds, false);\r\n        } else {\r\n          this.agGrid.api.sizeColumnsToFit();\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  getGridState() {\r\n    if (this.gridId && this.loggedInUser) {\r\n      this.gridService\r\n        .getGridState(this.gridId, this.loggedInUser)\r\n        .pipe(takeUntil(this.unsubscribe$))\r\n        .subscribe((response: any) => {\r\n          if (\r\n            response.status == 1 &&\r\n            response.object &&\r\n            response.object.gridConfig\r\n          ) {\r\n            this.gridColumnState = JSON.parse(response.object.gridConfig);\r\n            this.setGridState();\r\n          } else {\r\n            console.log('Error while loading grid state');\r\n          }\r\n        });\r\n    }\r\n  }\r\n\r\n  onBtnClick(e: any) {\r\n    console.log('btn click=>', e);\r\n    this.btnClickHandler.emit(e.rowData);\r\n  }\r\n\r\n  onSaveGridColumnState(event: any) {\r\n    let columnState = this.agGrid.columnApi?.getColumnState();\r\n    let columnData = {\r\n      gridConfig: JSON.stringify(columnState),\r\n      uiGridId: this.gridId,\r\n      userId: this.loggedInUser,\r\n    };\r\n    if (event.finished == true || event.type === 'columnPinned') {\r\n      this.gridColumnState = columnState;\r\n      this.gridService.saveColumnConfig(columnData)\r\n      .pipe(takeUntil(this.unsubscribe$))\r\n      .subscribe((res: any) => {\r\n        this.setGridState();\r\n        if (res.status == 0) {\r\n          console.log('Error while saving column configuration:', res.message);\r\n        }\r\n      });\r\n    }\r\n  }\r\n\r\n  getRowById: GetRowIdFunc = (params: GetRowIdParams) => {\r\n    var data = params.data;\r\n    return data.id ?? 0;\r\n  };\r\n\r\n  // Custom right click Context Menu to support custom excel exports\r\n  public getContextMenuItems = (\r\n    params: GetContextMenuItemsParams\r\n  ): (string | MenuItemDef)[] => {\r\n    let res: (string | MenuItemDef)[] = [\r\n      'cut',\r\n      'copy',\r\n      'copyWithHeaders',\r\n      'copyWithGroupHeaders',\r\n      'paste',\r\n      {\r\n        name: 'Export',\r\n        subMenu: [\r\n          {\r\n            name: 'CSV Export',\r\n            action: () => {\r\n              this.exportFile('csv');\r\n            },\r\n          },\r\n          {\r\n            name: 'Excel Export',\r\n            action: () => {\r\n              this.exportFile('xlsx');\r\n            },\r\n          },\r\n        ],\r\n      },\r\n    ];\r\n    return res;\r\n  };\r\n\r\n  //custom export method\r\n  public exportFile(type: string) {\r\n    this.getDataForExcelExport(type);\r\n  }\r\n  //Generate only those columns for export which are visible and are not of other types that are not required for export\r\n  generateColumnsForExcel(): string[] {\r\n    let columnsToBeDisplayedForExcel: any = [];\r\n    this.exportColumnsList.forEach((column: any) => {\r\n      if (\r\n        column.visible == true &&\r\n        column.columnType != 'checkbox' &&\r\n        column.columnType != 'dropdown' &&\r\n        column.columnType != ''\r\n      ) {\r\n        columnsToBeDisplayedForExcel.push(column.field);\r\n      }\r\n    });\r\n    return columnsToBeDisplayedForExcel;\r\n  }\r\n\r\n  //Get data from server without paging so that whole data can be exported to excel\r\n  // and also check for server side and client side rendering of data for export.\r\n  getDataForExcelExport(type: string) {\r\n    this.agGrid.api.showLoadingOverlay();\r\n    if (this.enableServerSidePaging) {\r\n      this.gridService\r\n        .getDataForExport(this.serverDataUrl)\r\n        .pipe(takeUntil(this.unsubscribe$))\r\n        .subscribe((response: any) => {\r\n          this.agGrid.api.hideOverlay();\r\n          if (response && response.value.length > 0) {\r\n            this.excelAPI.setRowData(response.value);\r\n            this.excelAPI.sizeColumnsToFit();\r\n            if (type == 'csv') {\r\n              this.excelAPI.exportDataAsCsv({\r\n                columnKeys: this.generateColumnsForExcel(),\r\n              });\r\n            } else {\r\n              this.excelAPI.exportDataAsExcel({\r\n                columnKeys: this.generateColumnsForExcel(),\r\n              });\r\n            }\r\n          } else {\r\n            console.log('Error while fetching data for excel/csv export');\r\n          }\r\n        });\r\n    } else {\r\n      this.agGrid.api.hideOverlay();\r\n      if (type == 'csv') {\r\n        this.agGrid.api.exportDataAsCsv({\r\n          columnKeys: this.generateColumnsForExcel(),\r\n        });\r\n      } else {\r\n        this.agGrid.api.exportDataAsExcel({\r\n          columnKeys: this.generateColumnsForExcel(),\r\n        });\r\n      }\r\n    }\r\n  }\r\n\r\n  onSelectionChanged(e: any) {\r\n    this.selectionChanged.emit(e);\r\n  }\r\n\r\n  onFilterChanged(e: any) {\r\n    this.filterChanged.emit(e);\r\n  }\r\n\r\n  onFirstDataRendered(e: any) {\r\n    this.firstDataRendered.emit(e);\r\n  }\r\n\r\n  onGridReadyExcel(params: any) {\r\n    this.excelAPI = params.api;\r\n  }\r\n\r\n  //destroy all associated subscriptions on component destroy\r\n  ngOnDestroy() {\r\n    this.unsubscribe$.next();\r\n    this.unsubscribe$.complete();\r\n  }\r\n}\r\n"]}
|