fixa-admin 0.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (73) hide show
  1. package/README.md +24 -0
  2. package/esm2022/lib/class/index.api.mjs +2 -0
  3. package/esm2022/lib/class/popover.mjs +28 -0
  4. package/esm2022/lib/components/captcha/captcha.component.mjs +56 -0
  5. package/esm2022/lib/components/grid/filter/date-filter.component.mjs +122 -0
  6. package/esm2022/lib/components/grid/filter/index.api.mjs +2 -0
  7. package/esm2022/lib/components/grid/grid.component.mjs +491 -0
  8. package/esm2022/lib/components/grid/render/action-button.component.mjs +26 -0
  9. package/esm2022/lib/components/index.api.mjs +6 -0
  10. package/esm2022/lib/components/map/map.component.mjs +134 -0
  11. package/esm2022/lib/components/spinner/spinner.component.mjs +14 -0
  12. package/esm2022/lib/directive/char-input.directive.mjs +37 -0
  13. package/esm2022/lib/directive/index.api.mjs +4 -0
  14. package/esm2022/lib/directive/mask.directive.mjs +58 -0
  15. package/esm2022/lib/directive/mask.mjs +78 -0
  16. package/esm2022/lib/directive/numeric-input.directive.mjs +44 -0
  17. package/esm2022/lib/guard/auth.guard.mjs +25 -0
  18. package/esm2022/lib/guard/index.api.mjs +2 -0
  19. package/esm2022/lib/layouts/blank/blank.layout.mjs +14 -0
  20. package/esm2022/lib/layouts/index.api.mjs +3 -0
  21. package/esm2022/lib/layouts/master/master.layout.mjs +53 -0
  22. package/esm2022/lib/models/index.api.mjs +2 -0
  23. package/esm2022/lib/models/shared.model.mjs +28 -0
  24. package/esm2022/lib/pipes/date.pipe.mjs +25 -0
  25. package/esm2022/lib/pipes/index.api.mjs +3 -0
  26. package/esm2022/lib/pipes/timer.pipe.mjs +30 -0
  27. package/esm2022/lib/services/confirm.service.mjs +39 -0
  28. package/esm2022/lib/services/dialog.service.mjs +65 -0
  29. package/esm2022/lib/services/form.service.mjs +22 -0
  30. package/esm2022/lib/services/index.api.mjs +6 -0
  31. package/esm2022/lib/services/shared.service.mjs +15 -0
  32. package/esm2022/lib/services/toast.service.mjs +21 -0
  33. package/esm2022/lib/shared.module.mjs +196 -0
  34. package/esm2022/public-api.mjs +14 -0
  35. package/esm2022/shared.mjs +5 -0
  36. package/fesm2022/shared.mjs +1558 -0
  37. package/fesm2022/shared.mjs.map +1 -0
  38. package/index.d.ts +5 -0
  39. package/lib/class/index.api.d.ts +1 -0
  40. package/lib/class/popover.d.ts +14 -0
  41. package/lib/components/captcha/captcha.component.d.ts +13 -0
  42. package/lib/components/grid/filter/date-filter.component.d.ts +24 -0
  43. package/lib/components/grid/filter/index.api.d.ts +1 -0
  44. package/lib/components/grid/grid.component.d.ts +64 -0
  45. package/lib/components/grid/render/action-button.component.d.ts +13 -0
  46. package/lib/components/index.api.d.ts +5 -0
  47. package/lib/components/map/map.component.d.ts +26 -0
  48. package/lib/components/spinner/spinner.component.d.ts +8 -0
  49. package/lib/directive/char-input.directive.d.ts +12 -0
  50. package/lib/directive/index.api.d.ts +3 -0
  51. package/lib/directive/mask.d.ts +19 -0
  52. package/lib/directive/mask.directive.d.ts +15 -0
  53. package/lib/directive/numeric-input.directive.d.ts +12 -0
  54. package/lib/guard/auth.guard.d.ts +10 -0
  55. package/lib/guard/index.api.d.ts +1 -0
  56. package/lib/layouts/blank/blank.layout.d.ts +8 -0
  57. package/lib/layouts/index.api.d.ts +2 -0
  58. package/lib/layouts/master/master.layout.d.ts +20 -0
  59. package/lib/models/index.api.d.ts +1 -0
  60. package/lib/models/shared.model.d.ts +120 -0
  61. package/lib/pipes/date.pipe.d.ts +7 -0
  62. package/lib/pipes/index.api.d.ts +2 -0
  63. package/lib/pipes/timer.pipe.d.ts +7 -0
  64. package/lib/services/confirm.service.d.ts +9 -0
  65. package/lib/services/dialog.service.d.ts +11 -0
  66. package/lib/services/form.service.d.ts +8 -0
  67. package/lib/services/index.api.d.ts +5 -0
  68. package/lib/services/shared.service.d.ts +8 -0
  69. package/lib/services/toast.service.d.ts +9 -0
  70. package/lib/shared.module.d.ts +41 -0
  71. package/package.json +43 -0
  72. package/public-api.d.ts +10 -0
  73. package/src/style.scss +9 -0
@@ -0,0 +1,491 @@
1
+ import { Component, EventEmitter, Input, Output } from '@angular/core';
2
+ import { FilterOperator } from '../../models/shared.model';
3
+ import { ActionsCellRenderer } from '../index.api';
4
+ import { JDatePipe } from '../../pipes/date.pipe';
5
+ import { DateFilter } from './filter/index.api';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "@ngx-translate/core";
8
+ import * as i2 from "@angular/common";
9
+ import * as i3 from "@ag-grid-community/angular";
10
+ import * as i4 from "ng-zorro-antd/icon";
11
+ import * as i5 from "ng-zorro-antd/button";
12
+ import * as i6 from "ng-zorro-antd/core/transition-patch";
13
+ import * as i7 from "ng-zorro-antd/core/wave";
14
+ export class GridComponent {
15
+ _translate;
16
+ constructor(_translate) {
17
+ this._translate = _translate;
18
+ this.datasource = this.createServerSideDatasource();
19
+ }
20
+ gridApi;
21
+ isServerSideGroup;
22
+ getServerSideGroupKey = null;
23
+ groupDefaultExpanded = -1;
24
+ _treeGroupColumn = null;
25
+ datasource;
26
+ themeClass = "ag-theme-quartz";
27
+ columnDefs = [];
28
+ _column = [];
29
+ autoGroupColumnDef = {
30
+ headerName: "",
31
+ minWidth: 250,
32
+ sortable: false,
33
+ cellRendererParams: {
34
+ suppressCount: true,
35
+ },
36
+ };
37
+ defaultColDef = {
38
+ flex: 1,
39
+ minWidth: 150,
40
+ filter: 'agTextColumnFilter',
41
+ suppressHeaderMenuButton: true,
42
+ suppressHeaderContextMenu: true
43
+ };
44
+ onAction = new EventEmitter();
45
+ onToolbar = new EventEmitter();
46
+ onClicked = new EventEmitter();
47
+ label = null;
48
+ rowModelType = 'serverSide';
49
+ isToolbar = true;
50
+ rtl = true;
51
+ paginationPageSize = 15;
52
+ paginationPageSizeSelector = [10, 15, 25];
53
+ enableAdvancedFilter = false;
54
+ treeModel = false;
55
+ isLeaf = false;
56
+ showAdvancedButton = true;
57
+ actionItems = [
58
+ {
59
+ code: 'edit',
60
+ icon: 'fa-light fa-pen',
61
+ alt: 'ویرایش'
62
+ },
63
+ {
64
+ code: 'delete',
65
+ icon: 'fa-light fa-trash',
66
+ alt: 'حذف'
67
+ }
68
+ ];
69
+ toolbarItems = [
70
+ {
71
+ code: 'insert',
72
+ icon: 'plus',
73
+ text: 'ایجاد جدید',
74
+ type: 'primary'
75
+ },
76
+ // {
77
+ // code: 'refresh',
78
+ // icon: 'sync',
79
+ // text: 'بروزرسانی',
80
+ // type: 'default'
81
+ // }
82
+ ];
83
+ get treeGroupColumn() {
84
+ return this.treeGroupColumn;
85
+ }
86
+ set treeGroupColumn(v) {
87
+ if (v) {
88
+ this._treeGroupColumn = v;
89
+ this.isServerSideGroup = dataItem => {
90
+ if (this.isLeaf) {
91
+ if (!dataItem.lastNode)
92
+ return dataItem[v];
93
+ else
94
+ return false;
95
+ }
96
+ else {
97
+ return dataItem[v];
98
+ }
99
+ };
100
+ this.getServerSideGroupKey = dataItem => {
101
+ return dataItem[v];
102
+ };
103
+ // this.autoGroupColumnDef.headerName = v;
104
+ }
105
+ }
106
+ fetchData;
107
+ get column() {
108
+ return this.column;
109
+ }
110
+ set column(v) {
111
+ if (v != null) {
112
+ this._column = v;
113
+ v.forEach((el) => {
114
+ var filter = 'agTextColumnFilter';
115
+ var sortable = true;
116
+ var filterParams = {
117
+ maxNumConditions: 1
118
+ };
119
+ switch (el.type) {
120
+ case 'boolean':
121
+ filter = 'agNumberColumnFilter';
122
+ filterParams.filterOptions = [
123
+ "empty",
124
+ {
125
+ displayKey: 'true',
126
+ displayName: this._translate.instant('YES'),
127
+ predicate: () => true,
128
+ numberOfInputs: 0
129
+ },
130
+ {
131
+ displayKey: 'false',
132
+ displayName: this._translate.instant('NO'),
133
+ predicate: () => true,
134
+ numberOfInputs: 0
135
+ }
136
+ ];
137
+ break;
138
+ case 'enum':
139
+ filter = 'agNumberColumnFilter';
140
+ const items = [];
141
+ for (const property in el.filterItems) {
142
+ items.push({
143
+ displayKey: el.filterItems[property],
144
+ displayName: this._translate.instant(el.filterItems[property]),
145
+ predicate: true,
146
+ numberOfInputs: 0
147
+ });
148
+ }
149
+ filterParams.filterOptions = [
150
+ "empty",
151
+ ...items
152
+ ];
153
+ break;
154
+ case 'number':
155
+ filter = 'agNumberColumnFilter';
156
+ break;
157
+ case 'select':
158
+ filter = 'agSetColumnFilter';
159
+ break;
160
+ case 'string':
161
+ filter = 'agTextColumnFilter';
162
+ break;
163
+ case 'date':
164
+ filter = 'agDateColumnFilter';
165
+ break;
166
+ default:
167
+ filter = 'agTextColumnFilter';
168
+ break;
169
+ }
170
+ if (el.filter != undefined && !el.filter) {
171
+ filter = false;
172
+ }
173
+ if (el.sortable != undefined && !el.sortable) {
174
+ sortable = false;
175
+ }
176
+ if (el.field != this._treeGroupColumn) {
177
+ if (el.type && el.type == 'boolean') {
178
+ this.columnDefs.push({
179
+ field: el.field,
180
+ headerName: el.label,
181
+ filter: filter,
182
+ sortable,
183
+ editable: el.editable,
184
+ minWidth: el.minWidth ? el.minWidth : null,
185
+ filterParams,
186
+ cellClass: 'ag-boolean-cell',
187
+ cellRenderer: params => {
188
+ if (params.value != null) {
189
+ return params.value ? '<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" stroke="green" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1" stroke-linecap="round" stroke-linejoin="round" class="feather feather-check"><path d="M20 6L9 17L4 12"/></svg>' : '<svg xmlns="http://www.w3.org/2000/svg" stroke="red" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="1" stroke-linecap="round" stroke-linejoin="round" class="feather feather-x"><line x1="18" y1="6" x2="6" y2="18" /><line x1="6" y1="6" x2="18" y2="18" /></svg>';
190
+ }
191
+ else {
192
+ return '';
193
+ }
194
+ }
195
+ });
196
+ }
197
+ else if (el.type && el.type == 'enum') {
198
+ this.columnDefs.push({
199
+ field: el.field,
200
+ headerName: el.label,
201
+ filter: filter,
202
+ sortable,
203
+ editable: el.editable,
204
+ minWidth: el.minWidth ? el.minWidth : null,
205
+ filterParams,
206
+ cellRenderer: params => {
207
+ if (params.value) {
208
+ return this._translate.instant(params.value);
209
+ }
210
+ else {
211
+ return '';
212
+ }
213
+ }
214
+ });
215
+ }
216
+ else if (el.type && el.type == 'date') {
217
+ this.columnDefs.push({
218
+ field: el.field,
219
+ headerName: el.label,
220
+ filter: DateFilter,
221
+ sortable,
222
+ editable: el.editable,
223
+ minWidth: el.minWidth ? el.minWidth : null,
224
+ filterParams,
225
+ cellRenderer: params => {
226
+ if (params.value) {
227
+ return new JDatePipe().transform(params.value);
228
+ }
229
+ else {
230
+ return '';
231
+ }
232
+ }
233
+ });
234
+ }
235
+ else if (el.type && el.type == 'price') {
236
+ this.columnDefs.push({
237
+ field: el.field,
238
+ headerName: el.label,
239
+ filter: filter,
240
+ sortable,
241
+ editable: el.editable,
242
+ minWidth: el.minWidth ? el.minWidth : null,
243
+ filterParams,
244
+ cellRenderer: params => {
245
+ if (params.value) {
246
+ return params.value.toLocaleString();
247
+ }
248
+ else {
249
+ return '';
250
+ }
251
+ }
252
+ });
253
+ }
254
+ else if (el.type && el.type == 'image') {
255
+ this.columnDefs.push({
256
+ field: el.field,
257
+ headerName: el.label,
258
+ minWidth: 80,
259
+ width: 80,
260
+ filter: false,
261
+ sortable: false,
262
+ editable: false,
263
+ filterParams,
264
+ cellRenderer: params => {
265
+ if (params.value) {
266
+ return `<img class="rounded-full mt-1" width="32" height="32" src="${params.value}"/>`;
267
+ }
268
+ else {
269
+ return '';
270
+ }
271
+ }
272
+ });
273
+ }
274
+ else {
275
+ this.columnDefs.push({
276
+ field: el.field,
277
+ headerName: el.label,
278
+ filter,
279
+ sortable,
280
+ editable: el.editable,
281
+ filterParams,
282
+ minWidth: el.minWidth ? el.minWidth : null
283
+ });
284
+ }
285
+ }
286
+ else {
287
+ this.autoGroupColumnDef.field = el.field;
288
+ }
289
+ });
290
+ if (this.actionItems.length > 0) {
291
+ this.columnDefs.push({
292
+ filter: false,
293
+ headerName: '',
294
+ minWidth: 100,
295
+ resizable: true,
296
+ pinned: true,
297
+ sortable: false,
298
+ field: 'actions',
299
+ cellRenderer: ActionsCellRenderer,
300
+ cellRendererParams: {
301
+ onClick: (params) => {
302
+ this.onAction.emit(params);
303
+ }
304
+ }
305
+ });
306
+ }
307
+ }
308
+ }
309
+ cellDoubleClicked(e) {
310
+ this.onClicked.emit(e.data);
311
+ }
312
+ handleClick(item) {
313
+ this.onToolbar.emit(item);
314
+ }
315
+ refresh() {
316
+ this.gridApi.refreshServerSide({ purge: true });
317
+ }
318
+ onGridReady(params) {
319
+ this.gridApi = params.api;
320
+ }
321
+ advancedFilter() {
322
+ this.enableAdvancedFilter = !this.enableAdvancedFilter;
323
+ setTimeout(() => {
324
+ this.gridApi.showAdvancedFilterBuilder();
325
+ setTimeout(() => {
326
+ document.getElementsByClassName('ag-icon-maximize')[0].click();
327
+ });
328
+ }, 10);
329
+ }
330
+ getRouteToNode(rowNode) {
331
+ if (!rowNode.parent) {
332
+ return [];
333
+ }
334
+ return [
335
+ ...this.getRouteToNode(rowNode.parent),
336
+ rowNode.key ? rowNode.key : rowNode.data.employeeName,
337
+ ];
338
+ }
339
+ refreshNode(id) {
340
+ const selectedRows = this.gridApi.getRowNode(id);
341
+ const route = this.getRouteToNode(selectedRows);
342
+ this.gridApi.refreshServerSide({
343
+ purge: true,
344
+ route: route
345
+ });
346
+ }
347
+ refreshParentNode(id) {
348
+ const selectedRows = this.gridApi.getRowNode(id);
349
+ const route = this.getRouteToNode(selectedRows.parent);
350
+ this.gridApi.refreshServerSide({
351
+ purge: true,
352
+ route: route
353
+ });
354
+ }
355
+ createServerSideDatasource() {
356
+ return {
357
+ getRows: (params) => {
358
+ debugger;
359
+ let filter = null;
360
+ if (Object.keys(params.request.filterModel).length > 0) {
361
+ filter = {
362
+ disable: false,
363
+ field: null,
364
+ logic: 'AND',
365
+ filters: [],
366
+ ignoreCase: null,
367
+ operator: null,
368
+ truncateDate: null,
369
+ value: null,
370
+ };
371
+ for (const key in params.request.filterModel) {
372
+ if (params.request.filterModel[key].filterType == 'custom-date') {
373
+ filter.filters.push({
374
+ disable: false,
375
+ field: key == 'ag-Grid-AutoColumn' ? this._treeGroupColumn : key,
376
+ logic: 'AND',
377
+ filters: null,
378
+ ignoreCase: false,
379
+ operator: FilterOperator.truncGreaterThanEqual,
380
+ truncateDate: true,
381
+ value: new Date(params.request.filterModel[key].dateFrom).toISOString()
382
+ });
383
+ if (params.request.filterModel[key].dateTo != "") {
384
+ filter.filters.push({
385
+ disable: false,
386
+ field: key == 'ag-Grid-AutoColumn' ? this._treeGroupColumn : key,
387
+ logic: 'AND',
388
+ filters: null,
389
+ ignoreCase: false,
390
+ operator: FilterOperator.truncLessThanOrEqual,
391
+ truncateDate: true,
392
+ value: new Date(params.request.filterModel[key].dateTo).toISOString()
393
+ });
394
+ }
395
+ }
396
+ else {
397
+ const operation = FilterOperator[params.request.filterModel[key].type];
398
+ let ignoreCase = true;
399
+ const findEl = this._column.find((el) => el.field == key);
400
+ let field = null;
401
+ if (key == 'ag-Grid-AutoColumn') {
402
+ field = this._treeGroupColumn;
403
+ }
404
+ else {
405
+ field = key;
406
+ if (findEl.searchField != null) {
407
+ field = findEl.searchField;
408
+ }
409
+ }
410
+ if (findEl && findEl.type == 'enum') {
411
+ ignoreCase = false;
412
+ }
413
+ filter.filters.push({
414
+ disable: false,
415
+ field,
416
+ logic: 'AND',
417
+ filters: null,
418
+ ignoreCase,
419
+ operator: operation ? operation : FilterOperator.equals,
420
+ truncateDate: true,
421
+ value: params.request.filterModel[key].filter ? params.request.filterModel[key].filter : params.request.filterModel[key].type
422
+ });
423
+ }
424
+ }
425
+ }
426
+ const gridFilter = {
427
+ take: params.api.paginationGetPageSize(),
428
+ data: null,
429
+ filter,
430
+ skip: params.api.paginationGetCurrentPage() * params.api.paginationGetPageSize(),
431
+ sorts: params.request.sortModel.length > 0 ? [{ dir: params.request.sortModel[0].sort, field: params.request.sortModel[0].colId }] : []
432
+ };
433
+ const requestParams = {
434
+ parentNode: params.parentNode.data
435
+ };
436
+ this.fetchData(gridFilter, requestParams).then(data => {
437
+ params.success({
438
+ rowData: data.items,
439
+ rowCount: data.totalCount
440
+ });
441
+ }).catch(() => {
442
+ params.fail();
443
+ });
444
+ }
445
+ };
446
+ }
447
+ ngOnInit() { }
448
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: GridComponent, deps: [{ token: i1.TranslateService }], target: i0.ɵɵFactoryTarget.Component });
449
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: GridComponent, selector: "app-grid", inputs: { label: "label", rowModelType: "rowModelType", isToolbar: "isToolbar", rtl: "rtl", paginationPageSize: "paginationPageSize", paginationPageSizeSelector: "paginationPageSizeSelector", enableAdvancedFilter: "enableAdvancedFilter", treeModel: "treeModel", isLeaf: "isLeaf", showAdvancedButton: "showAdvancedButton", actionItems: "actionItems", toolbarItems: "toolbarItems", treeGroupColumn: "treeGroupColumn", fetchData: "fetchData", column: "column" }, outputs: { onAction: "onAction", onToolbar: "onToolbar", onClicked: "onClicked" }, ngImport: i0, template: "<!-- <button (click)=\"enableAdvancedFilter=!enableAdvancedFilter\">advanced</button> -->\n<div class=\"flex justify-between items-center mb-4 pb-4 border-b border-b-slate-200\" *ngIf=\"isToolbar\">\n <div>\n <h4 class=\"font-semibold text-2xl\">{{label}}</h4>\n </div>\n <div class=\"flex gap-3\">\n <button nz-button *ngFor=\"let item of toolbarItems\" (click)=\"handleClick(item)\" [nzType]=\"item.type\">\n <span nz-icon [nzType]=\"item.icon\"></span>\n {{item.text}}\n </button>\n <button nz-button (click)=\"refresh()\" nzType=\"default\">\n <span nz-icon nzType=\"sync\"></span>\n \u0628\u0631\u0648\u0632\u0631\u0633\u0627\u0646\u06CC\n </button>\n <!-- <button nz-button (click)=\"advancedFilter()\" *ngIf=\"showAdvancedButton\" nzType=\"default\">\n <span nz-icon nzType=\"filter\"></span>\n \u062C\u0633\u062A\u062C\u0648\u06CC \u067E\u06CC\u0634\u0631\u0641\u062A\u0647\n </button> -->\n </div>\n</div>\n<ag-grid-angular style=\"width: 100%;\" [style]=\"(isToolbar) ? 'height: calc(100% - 1rem - 48px);':'height: 100%;'\" [columnDefs]=\"columnDefs\" [pagination]=\"true\"\n [paginationPageSize]=\"paginationPageSize\" [paginationPageSizeSelector]=\"paginationPageSizeSelector\"\n [class]=\"themeClass\" [defaultColDef]=\"defaultColDef\" [enableAdvancedFilter]=\"enableAdvancedFilter\" [enableRtl]=\"rtl\"\n [treeData]=\"treeModel\" [autoGroupColumnDef]=\"autoGroupColumnDef\" [isServerSideGroup]=\"isServerSideGroup\"\n [getServerSideGroupKey]=\"getServerSideGroupKey\" [rowModelType]=\"rowModelType\" [serverSideDatasource]=\"datasource\"\n (gridReady)=\"onGridReady($event)\" [cacheBlockSize]=\"paginationPageSize\" [maxBlocksInCache]=\"2\"\n [context]=\"{actionItems: actionItems}\" (cellDoubleClicked)=\"cellDoubleClicked($event)\" #grid />", dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.AgGridAngular, selector: "ag-grid-angular", inputs: ["gridOptions", "modules", "statusBar", "sideBar", "suppressContextMenu", "preventDefaultOnContextMenu", "allowContextMenuWithControlKey", "columnMenu", "suppressMenuHide", "enableBrowserTooltips", "tooltipTrigger", "tooltipShowDelay", "tooltipHideDelay", "tooltipMouseTrack", "tooltipShowMode", "tooltipInteraction", "popupParent", "copyHeadersToClipboard", "copyGroupHeadersToClipboard", "clipboardDelimiter", "suppressCopyRowsToClipboard", "suppressCopySingleCellRanges", "suppressLastEmptyLineOnPaste", "suppressClipboardPaste", "suppressClipboardApi", "suppressCutToClipboard", "columnDefs", "defaultColDef", "defaultColGroupDef", "columnTypes", "dataTypeDefinitions", "maintainColumnOrder", "enableStrictPivotColumnOrder", "suppressFieldDotNotation", "headerHeight", "groupHeaderHeight", "floatingFiltersHeight", "pivotHeaderHeight", "pivotGroupHeaderHeight", "allowDragFromColumnsToolPanel", "suppressMovableColumns", "suppressColumnMoveAnimation", "suppressMoveWhenColumnDragging", "suppressDragLeaveHidesColumns", "suppressRowGroupHidesColumns", "colResizeDefault", "suppressAutoSize", "autoSizePadding", "skipHeaderOnAutoSize", "autoSizeStrategy", "components", "editType", "singleClickEdit", "suppressClickEdit", "readOnlyEdit", "stopEditingWhenCellsLoseFocus", "enterNavigatesVertically", "enterNavigatesVerticallyAfterEdit", "enableCellEditingOnBackspace", "undoRedoCellEditing", "undoRedoCellEditingLimit", "defaultCsvExportParams", "suppressCsvExport", "defaultExcelExportParams", "suppressExcelExport", "excelStyles", "quickFilterText", "cacheQuickFilter", "includeHiddenColumnsInQuickFilter", "quickFilterParser", "quickFilterMatcher", "applyQuickFilterBeforePivotOrAgg", "excludeChildrenWhenTreeDataFiltering", "enableAdvancedFilter", "advancedFilterModel", "includeHiddenColumnsInAdvancedFilter", "advancedFilterParent", "advancedFilterBuilderParams", "suppressAdvancedFilterEval", "suppressSetFilterByDefault", "enableCharts", "chartThemes", "customChartThemes", "chartThemeOverrides", "chartToolPanelsDef", "chartMenuItems", "loadingCellRenderer", "loadingCellRendererParams", "loadingCellRendererSelector", "localeText", "masterDetail", "keepDetailRows", "keepDetailRowsCount", "detailCellRenderer", "detailCellRendererParams", "detailRowHeight", "detailRowAutoHeight", "context", "dragAndDropImageComponent", "dragAndDropImageComponentParams", "alignedGrids", "tabIndex", "rowBuffer", "valueCache", "valueCacheNeverExpires", "enableCellExpressions", "suppressTouch", "suppressFocusAfterRefresh", "suppressAsyncEvents", "suppressBrowserResizeObserver", "suppressPropertyNamesCheck", "suppressChangeDetection", "debug", "loading", "overlayLoadingTemplate", "loadingOverlayComponent", "loadingOverlayComponentParams", "suppressLoadingOverlay", "overlayNoRowsTemplate", "noRowsOverlayComponent", "noRowsOverlayComponentParams", "suppressNoRowsOverlay", "pagination", "paginationPageSize", "paginationPageSizeSelector", "paginationAutoPageSize", "paginateChildRows", "suppressPaginationPanel", "pivotMode", "pivotPanelShow", "pivotMaxGeneratedColumns", "pivotDefaultExpanded", "pivotColumnGroupTotals", "pivotRowTotals", "pivotSuppressAutoColumn", "suppressExpandablePivotGroups", "functionsReadOnly", "aggFuncs", "suppressAggFuncInHeader", "alwaysAggregateAtRootLevel", "aggregateOnlyChangedColumns", "suppressAggFilteredOnly", "removePivotHeaderRowWhenSingleValueColumn", "animateRows", "enableCellChangeFlash", "cellFlashDuration", "cellFlashDelay", "cellFadeDuration", "cellFadeDelay", "allowShowChangeAfterFilter", "domLayout", "ensureDomOrder", "enableRtl", "suppressColumnVirtualisation", "suppressMaxRenderedRowRestriction", "suppressRowVirtualisation", "rowDragManaged", "suppressRowDrag", "suppressMoveWhenRowDragging", "rowDragEntireRow", "rowDragMultiRow", "rowDragText", "fullWidthCellRenderer", "fullWidthCellRendererParams", "embedFullWidthRows", "suppressGroupMaintainValueType", "groupDisplayType", "groupDefaultExpanded", "autoGroupColumnDef", "groupMaintainOrder", "groupSelectsChildren", "groupLockGroupColumns", "groupAggFiltering", "groupIncludeFooter", "groupIncludeTotalFooter", "groupTotalRow", "grandTotalRow", "suppressStickyTotalRow", "groupSuppressBlankHeader", "groupSelectsFiltered", "showOpenedGroup", "groupRemoveSingleChildren", "groupRemoveLowestSingleChildren", "groupHideOpenParents", "groupAllowUnbalanced", "rowGroupPanelShow", "groupRowRenderer", "groupRowRendererParams", "suppressMakeColumnVisibleAfterUnGroup", "treeData", "rowGroupPanelSuppressSort", "suppressGroupRowsSticky", "pinnedTopRowData", "pinnedBottomRowData", "rowModelType", "rowData", "asyncTransactionWaitMillis", "suppressModelUpdateAfterUpdateTransaction", "datasource", "cacheOverflowSize", "infiniteInitialRowCount", "serverSideInitialRowCount", "suppressServerSideInfiniteScroll", "suppressServerSideFullWidthLoadingRow", "cacheBlockSize", "maxBlocksInCache", "maxConcurrentDatasourceRequests", "blockLoadDebounceMillis", "purgeClosedRowNodes", "serverSideDatasource", "serverSideSortAllLevels", "serverSideEnableClientSideSort", "serverSideOnlyRefreshFilteredGroups", "serverSideSortOnServer", "serverSideFilterOnServer", "serverSidePivotResultFieldSeparator", "viewportDatasource", "viewportRowModelPageSize", "viewportRowModelBufferSize", "alwaysShowHorizontalScroll", "alwaysShowVerticalScroll", "debounceVerticalScrollbar", "suppressHorizontalScroll", "suppressScrollOnNewData", "suppressScrollWhenPopupsAreOpen", "suppressAnimationFrame", "suppressMiddleClickScrolls", "suppressPreventDefaultOnMouseWheel", "scrollbarWidth", "rowSelection", "cellSelection", "rowMultiSelectWithClick", "suppressRowDeselection", "suppressRowClickSelection", "suppressCellFocus", "suppressHeaderFocus", "selectionColumnDef", "suppressMultiRangeSelection", "enableCellTextSelection", "enableRangeSelection", "enableRangeHandle", "enableFillHandle", "fillHandleDirection", "suppressClearOnFillReduction", "sortingOrder", "accentedSort", "unSortIcon", "suppressMultiSort", "alwaysMultiSort", "multiSortKey", "suppressMaintainUnsortedOrder", "icons", "rowHeight", "rowStyle", "rowClass", "rowClassRules", "suppressRowHoverHighlight", "suppressRowTransform", "columnHoverHighlight", "gridId", "deltaSort", "treeDataDisplayType", "enableGroupEdit", "initialState", "theme", "loadThemeGoogleFonts", "getContextMenuItems", "getMainMenuItems", "postProcessPopup", "processUnpinnedColumns", "processCellForClipboard", "processHeaderForClipboard", "processGroupHeaderForClipboard", "processCellFromClipboard", "sendToClipboard", "processDataFromClipboard", "isExternalFilterPresent", "doesExternalFilterPass", "getChartToolbarItems", "createChartContainer", "focusGridInnerElement", "navigateToNextHeader", "tabToNextHeader", "navigateToNextCell", "tabToNextCell", "getLocaleText", "getDocument", "paginationNumberFormatter", "getGroupRowAgg", "isGroupOpenByDefault", "initialGroupOrderComparator", "processPivotResultColDef", "processPivotResultColGroupDef", "getDataPath", "getChildCount", "getServerSideGroupLevelParams", "isServerSideGroupOpenByDefault", "isApplyServerSideTransaction", "isServerSideGroup", "getServerSideGroupKey", "getBusinessKeyForNode", "getRowId", "resetRowDataOnUpdate", "processRowPostCreate", "isRowSelectable", "isRowMaster", "fillOperation", "postSortRows", "getRowStyle", "getRowClass", "getRowHeight", "isFullWidthRow"], outputs: ["toolPanelVisibleChanged", "toolPanelSizeChanged", "columnMenuVisibleChanged", "contextMenuVisibleChanged", "cutStart", "cutEnd", "pasteStart", "pasteEnd", "columnVisible", "columnPinned", "columnResized", "columnMoved", "columnValueChanged", "columnPivotModeChanged", "columnPivotChanged", "columnGroupOpened", "newColumnsLoaded", "gridColumnsChanged", "displayedColumnsChanged", "virtualColumnsChanged", "columnEverythingChanged", "columnHeaderMouseOver", "columnHeaderMouseLeave", "columnHeaderClicked", "columnHeaderContextMenu", "componentStateChanged", "cellValueChanged", "cellEditRequest", "rowValueChanged", "cellEditingStarted", "cellEditingStopped", "rowEditingStarted", "rowEditingStopped", "undoStarted", "undoEnded", "redoStarted", "redoEnded", "cellSelectionDeleteStart", "cellSelectionDeleteEnd", "rangeDeleteStart", "rangeDeleteEnd", "fillStart", "fillEnd", "filterOpened", "filterChanged", "filterModified", "advancedFilterBuilderVisibleChanged", "chartCreated", "chartRangeSelectionChanged", "chartOptionsChanged", "chartDestroyed", "cellKeyDown", "gridReady", "firstDataRendered", "gridSizeChanged", "modelUpdated", "virtualRowRemoved", "viewportChanged", "bodyScroll", "bodyScrollEnd", "dragStarted", "dragStopped", "dragCancelled", "stateUpdated", "paginationChanged", "rowDragEnter", "rowDragMove", "rowDragLeave", "rowDragEnd", "rowDragCancel", "columnRowGroupChanged", "rowGroupOpened", "expandOrCollapseAll", "pivotMaxColumnsExceeded", "pinnedRowDataChanged", "rowDataUpdated", "asyncTransactionsFlushed", "storeRefreshed", "headerFocused", "cellClicked", "cellDoubleClicked", "cellFocused", "cellMouseOver", "cellMouseOut", "cellMouseDown", "rowClicked", "rowDoubleClicked", "rowSelected", "selectionChanged", "cellContextMenu", "rangeSelectionChanged", "cellSelectionChanged", "tooltipShow", "tooltipHide", "sortChanged"] }, { kind: "directive", type: i4.NzIconDirective, selector: "[nz-icon]", inputs: ["nzSpin", "nzRotate", "nzType", "nzTheme", "nzTwotoneColor", "nzIconfont"], exportAs: ["nzIcon"] }, { kind: "component", type: i5.NzButtonComponent, selector: "button[nz-button], a[nz-button]", inputs: ["nzBlock", "nzGhost", "nzSearch", "nzLoading", "nzDanger", "disabled", "tabIndex", "nzType", "nzShape", "nzSize"], exportAs: ["nzButton"] }, { kind: "directive", type: i6.ɵNzTransitionPatchDirective, selector: "[nz-button], nz-button-group, [nz-icon], [nz-menu-item], [nz-submenu], nz-select-top-control, nz-select-placeholder, nz-input-group", inputs: ["hidden"] }, { kind: "directive", type: i7.NzWaveDirective, selector: "[nz-wave],button[nz-button]:not([nzType=\"link\"]):not([nzType=\"text\"])", inputs: ["nzWaveExtraNode"], exportAs: ["nzWave"] }] });
450
+ }
451
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: GridComponent, decorators: [{
452
+ type: Component,
453
+ args: [{ selector: 'app-grid', template: "<!-- <button (click)=\"enableAdvancedFilter=!enableAdvancedFilter\">advanced</button> -->\n<div class=\"flex justify-between items-center mb-4 pb-4 border-b border-b-slate-200\" *ngIf=\"isToolbar\">\n <div>\n <h4 class=\"font-semibold text-2xl\">{{label}}</h4>\n </div>\n <div class=\"flex gap-3\">\n <button nz-button *ngFor=\"let item of toolbarItems\" (click)=\"handleClick(item)\" [nzType]=\"item.type\">\n <span nz-icon [nzType]=\"item.icon\"></span>\n {{item.text}}\n </button>\n <button nz-button (click)=\"refresh()\" nzType=\"default\">\n <span nz-icon nzType=\"sync\"></span>\n \u0628\u0631\u0648\u0632\u0631\u0633\u0627\u0646\u06CC\n </button>\n <!-- <button nz-button (click)=\"advancedFilter()\" *ngIf=\"showAdvancedButton\" nzType=\"default\">\n <span nz-icon nzType=\"filter\"></span>\n \u062C\u0633\u062A\u062C\u0648\u06CC \u067E\u06CC\u0634\u0631\u0641\u062A\u0647\n </button> -->\n </div>\n</div>\n<ag-grid-angular style=\"width: 100%;\" [style]=\"(isToolbar) ? 'height: calc(100% - 1rem - 48px);':'height: 100%;'\" [columnDefs]=\"columnDefs\" [pagination]=\"true\"\n [paginationPageSize]=\"paginationPageSize\" [paginationPageSizeSelector]=\"paginationPageSizeSelector\"\n [class]=\"themeClass\" [defaultColDef]=\"defaultColDef\" [enableAdvancedFilter]=\"enableAdvancedFilter\" [enableRtl]=\"rtl\"\n [treeData]=\"treeModel\" [autoGroupColumnDef]=\"autoGroupColumnDef\" [isServerSideGroup]=\"isServerSideGroup\"\n [getServerSideGroupKey]=\"getServerSideGroupKey\" [rowModelType]=\"rowModelType\" [serverSideDatasource]=\"datasource\"\n (gridReady)=\"onGridReady($event)\" [cacheBlockSize]=\"paginationPageSize\" [maxBlocksInCache]=\"2\"\n [context]=\"{actionItems: actionItems}\" (cellDoubleClicked)=\"cellDoubleClicked($event)\" #grid />" }]
454
+ }], ctorParameters: () => [{ type: i1.TranslateService }], propDecorators: { onAction: [{
455
+ type: Output
456
+ }], onToolbar: [{
457
+ type: Output
458
+ }], onClicked: [{
459
+ type: Output
460
+ }], label: [{
461
+ type: Input
462
+ }], rowModelType: [{
463
+ type: Input
464
+ }], isToolbar: [{
465
+ type: Input
466
+ }], rtl: [{
467
+ type: Input
468
+ }], paginationPageSize: [{
469
+ type: Input
470
+ }], paginationPageSizeSelector: [{
471
+ type: Input
472
+ }], enableAdvancedFilter: [{
473
+ type: Input
474
+ }], treeModel: [{
475
+ type: Input
476
+ }], isLeaf: [{
477
+ type: Input
478
+ }], showAdvancedButton: [{
479
+ type: Input
480
+ }], actionItems: [{
481
+ type: Input
482
+ }], toolbarItems: [{
483
+ type: Input
484
+ }], treeGroupColumn: [{
485
+ type: Input
486
+ }], fetchData: [{
487
+ type: Input
488
+ }], column: [{
489
+ type: Input
490
+ }] } });
491
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid.component.js","sourceRoot":"","sources":["../../../../../../projects/shared/src/lib/components/grid/grid.component.ts","../../../../../../projects/shared/src/lib/components/grid/grid.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CellDoubleClickedEvent, ColDef, GridApi, GridOptions, IDateFilterParams, IRowNode, IServerSideDatasource, IServerSideGetRowsParams, RowModelType, SetFilterValuesFuncParams } from '@ag-grid-community/core';\nimport { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { TranslateService } from '@ngx-translate/core';\nimport { ActionItems, ColumnItems, DatasourceOutputModel, FilterGridItemsModel, FilterOperator, GridActionOutput, GridInputModel, GridRequestParam, ToolbarItems } from '../../models/shared.model';\nimport { ActionsCellRenderer } from '../index.api';\nimport { JDatePipe } from '../../pipes/date.pipe';\nimport { DateFilter } from './filter/index.api';\nexport interface IOlympicData {\n    athlete: string,\n    age: number,\n    country: string,\n    year: number,\n    date: string,\n    sport: string,\n    gold: number,\n    silver: number,\n    bronze: number,\n    total: number\n}\n@Component({\n    selector: 'app-grid',\n    templateUrl: './grid.component.html',\n})\nexport class GridComponent implements OnInit {\n    constructor(\n        private _translate: TranslateService\n    ) {\n        this.datasource = this.createServerSideDatasource();\n    }\n    private gridApi!: GridApi;\n    public isServerSideGroup;\n    public getServerSideGroupKey = null;\n    public groupDefaultExpanded = -1;\n    private _treeGroupColumn: string = null;\n    datasource: IServerSideDatasource;\n    themeClass: string = \"ag-theme-quartz\";\n    columnDefs: ColDef[] = [];\n    _column: ColumnItems[] = [];\n    autoGroupColumnDef: ColDef = {\n        headerName: \"\",\n        minWidth: 250,\n        sortable: false,\n        cellRendererParams: {\n            suppressCount: true,\n        },\n    };\n\n    defaultColDef: ColDef = {\n        flex: 1,\n        minWidth: 150,\n        filter: 'agTextColumnFilter',\n        suppressHeaderMenuButton: true,\n        suppressHeaderContextMenu: true\n    };\n    @Output()\n    onAction: EventEmitter<GridActionOutput> = new EventEmitter();\n\n    @Output()\n    onToolbar: EventEmitter<ToolbarItems> = new EventEmitter();\n\n    @Output()\n    onClicked: EventEmitter<any> = new EventEmitter();\n\n    @Input()\n    label: string = null;\n\n    @Input()\n    rowModelType: RowModelType = 'serverSide';\n\n    @Input()\n    isToolbar: boolean = true;\n\n    @Input()\n    rtl: boolean = true;\n\n    @Input()\n    paginationPageSize = 15;\n\n    @Input()\n    paginationPageSizeSelector: number[] | boolean = [10, 15, 25];\n\n    @Input()\n    enableAdvancedFilter: boolean = false;\n\n    @Input()\n    treeModel: boolean = false;\n\n    @Input()\n    isLeaf: boolean = false;\n\n    @Input()\n    showAdvancedButton: boolean = true;\n\n    @Input()\n    actionItems: ActionItems[] = [\n        {\n            code: 'edit',\n            icon: 'fa-light fa-pen',\n            alt: 'ویرایش'\n        },\n        {\n            code: 'delete',\n            icon: 'fa-light fa-trash',\n            alt: 'حذف'\n        }\n    ];\n\n    @Input()\n    toolbarItems: ToolbarItems[] = [\n        {\n            code: 'insert',\n            icon: 'plus',\n            text: 'ایجاد جدید',\n            type: 'primary'\n        },\n        // {\n        //     code: 'refresh',\n        //     icon: 'sync',\n        //     text: 'بروزرسانی',\n        //     type: 'default'\n        // }\n    ];\n\n    @Input()\n    public get treeGroupColumn() {\n        return this.treeGroupColumn;\n    }\n    public set treeGroupColumn(v: string) {\n        if (v) {\n            this._treeGroupColumn = v;\n            this.isServerSideGroup = dataItem => {\n                if (this.isLeaf) {\n                    if (!dataItem.lastNode)\n                        return dataItem[v];\n                    else\n                        return false\n                } else {\n                    return dataItem[v];\n                }\n            };\n            this.getServerSideGroupKey = dataItem => {\n                return dataItem[v];\n            };\n            // this.autoGroupColumnDef.headerName = v;\n        }\n    }\n\n    @Input()\n    fetchData: (filterGrid: GridInputModel, requestParams: GridRequestParam) => Promise<DatasourceOutputModel>;\n\n    @Input()\n    public get column() {\n        return this.column;\n    }\n    public set column(v: ColumnItems[]) {\n        if (v != null) {\n            this._column = v;\n            v.forEach((el) => {\n                var filter: any = 'agTextColumnFilter';\n                var sortable: boolean = true;\n                var filterParams: IDateFilterParams = {\n                    maxNumConditions: 1\n                };\n                switch (el.type) {\n                    case 'boolean':\n                        filter = 'agNumberColumnFilter';\n                        filterParams.filterOptions = [\n                            \"empty\",\n                            {\n                                displayKey: 'true',\n                                displayName: this._translate.instant('YES'),\n                                predicate: () => true,\n                                numberOfInputs: 0\n                            },\n                            {\n                                displayKey: 'false',\n                                displayName: this._translate.instant('NO'),\n                                predicate: () => true,\n                                numberOfInputs: 0\n                            }\n                        ];\n                        break;\n                    case 'enum':\n                        filter = 'agNumberColumnFilter';\n                        const items = [];\n                        for (const property in el.filterItems) {\n                            items.push({\n                                displayKey: el.filterItems[property],\n                                displayName: this._translate.instant(el.filterItems[property]),\n                                predicate: true,\n                                numberOfInputs: 0\n                            })\n                        }\n                        filterParams.filterOptions = [\n                            \"empty\",\n                            ...items\n                        ];\n                        break;\n                    case 'number':\n                        filter = 'agNumberColumnFilter';\n                        break;\n                    case 'select':\n                        filter = 'agSetColumnFilter';\n                        break;\n                    case 'string':\n                        filter = 'agTextColumnFilter';\n                        break;\n                    case 'date':\n                        filter = 'agDateColumnFilter';\n                        break;\n                    default:\n                        filter = 'agTextColumnFilter';\n                        break;\n                }\n                if (el.filter != undefined && !el.filter) {\n                    filter = false;\n                }\n                if (el.sortable != undefined && !el.sortable) {\n                    sortable = false;\n                }\n                if (el.field != this._treeGroupColumn) {\n                    if (el.type && el.type == 'boolean') {\n                        this.columnDefs.push({\n                            field: el.field,\n                            headerName: el.label,\n                            filter: filter,\n                            sortable,\n                            editable: el.editable,\n                            minWidth: el.minWidth ? el.minWidth : null,\n                            filterParams,\n                            cellClass: 'ag-boolean-cell',\n                            cellRenderer: params => {\n                                if (params.value != null) {\n                                    return params.value ? '<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"24\" height=\"24\" stroke=\"green\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1\" stroke-linecap=\"round\" stroke-linejoin=\"round\" class=\"feather feather-check\"><path d=\"M20 6L9 17L4 12\"/></svg>' : '<svg xmlns=\"http://www.w3.org/2000/svg\" stroke=\"red\" width=\"24\" height=\"24\" viewBox=\"0 0 24 24\" fill=\"none\" stroke=\"currentColor\" stroke-width=\"1\" stroke-linecap=\"round\" stroke-linejoin=\"round\" class=\"feather feather-x\"><line x1=\"18\" y1=\"6\" x2=\"6\" y2=\"18\" /><line x1=\"6\" y1=\"6\" x2=\"18\" y2=\"18\" /></svg>';\n                                } else {\n                                    return '';\n                                }\n                            }\n                        })\n                    } else if (el.type && el.type == 'enum') {\n                        this.columnDefs.push({\n                            field: el.field,\n                            headerName: el.label,\n                            filter: filter,\n                            sortable,\n                            editable: el.editable,\n                            minWidth: el.minWidth ? el.minWidth : null,\n                            filterParams,\n                            cellRenderer: params => {\n                                if (params.value) {\n                                    return this._translate.instant(params.value);\n                                } else {\n                                    return '';\n                                }\n                            }\n                        })\n                    } else if (el.type && el.type == 'date') {\n                        this.columnDefs.push({\n                            field: el.field,\n                            headerName: el.label,\n                            filter: DateFilter,\n                            sortable,\n                            editable: el.editable,\n                            minWidth: el.minWidth ? el.minWidth : null,\n                            filterParams,\n                            cellRenderer: params => {\n                                if (params.value) {\n                                    return new JDatePipe().transform(params.value);\n                                } else {\n                                    return '';\n                                }\n                            }\n                        })\n                    } else if (el.type && el.type == 'price') {\n                        this.columnDefs.push({\n                            field: el.field,\n                            headerName: el.label,\n                            filter: filter,\n                            sortable,\n                            editable: el.editable,\n                            minWidth: el.minWidth ? el.minWidth : null,\n                            filterParams,\n                            cellRenderer: params => {\n                                if (params.value) {\n                                    return params.value.toLocaleString();\n                                } else {\n                                    return '';\n                                }\n                            }\n                        })\n                    } else if (el.type && el.type == 'image') {\n                        this.columnDefs.push({\n                            field: el.field,\n                            headerName: el.label,\n                            minWidth: 80,\n                            width: 80,\n                            filter: false,\n                            sortable: false,\n                            editable: false,\n                            filterParams,\n                            cellRenderer: params => {\n                                if (params.value) {\n                                    return `<img class=\"rounded-full mt-1\" width=\"32\" height=\"32\" src=\"${params.value}\"/>`;\n                                } else {\n                                    return '';\n                                }\n                            }\n                        })\n                    }\n                    else {\n                        this.columnDefs.push({\n                            field: el.field,\n                            headerName: el.label,\n                            filter,\n                            sortable,\n                            editable: el.editable,\n                            filterParams,\n                            minWidth: el.minWidth ? el.minWidth : null\n                        })\n                    }\n                } else {\n                    this.autoGroupColumnDef.field = el.field;\n                }\n            });\n            if (this.actionItems.length > 0) {\n                this.columnDefs.push({\n                    filter: false,\n                    headerName: '',\n                    minWidth: 100,\n                    resizable: true,\n                    pinned: true,\n                    sortable: false,\n                    field: 'actions',\n                    cellRenderer: ActionsCellRenderer,\n                    cellRendererParams: {\n                        onClick: (params: GridActionOutput) => {\n                            this.onAction.emit(params);\n                        }\n                    }\n                })\n            }\n        }\n    }\n\n    cellDoubleClicked(e: CellDoubleClickedEvent) {\n        this.onClicked.emit(e.data);\n    }\n\n    handleClick(item: ToolbarItems) {\n        this.onToolbar.emit(item);\n    }\n\n    public refresh() {\n        this.gridApi.refreshServerSide({ purge: true })\n    }\n\n    onGridReady(params: any) {\n        this.gridApi = params.api;\n    }\n\n    advancedFilter() {\n        this.enableAdvancedFilter = !this.enableAdvancedFilter;\n        setTimeout(() => {\n            this.gridApi.showAdvancedFilterBuilder();\n            setTimeout(() => {\n                (document.getElementsByClassName('ag-icon-maximize')[0] as HTMLElement).click();\n            })\n        }, 10);\n    }\n\n    private getRouteToNode(rowNode: IRowNode): string[] {\n        if (!rowNode.parent) {\n            return [];\n        }\n        return [\n            ...this.getRouteToNode(rowNode.parent),\n            rowNode.key ? rowNode.key : rowNode.data.employeeName,\n        ];\n    }\n\n    refreshNode(id: string): void {\n        const selectedRows = this.gridApi.getRowNode(id);\n        const route = this.getRouteToNode(selectedRows);\n        this.gridApi.refreshServerSide({\n            purge: true,\n            route: route\n        });\n    }\n\n    refreshParentNode(id: string): void {\n        const selectedRows = this.gridApi.getRowNode(id);\n        const route = this.getRouteToNode(selectedRows.parent);\n        this.gridApi.refreshServerSide({\n            purge: true,\n            route: route\n        });\n    }\n\n    createServerSideDatasource(): IServerSideDatasource {\n        return {\n            getRows: (params: IServerSideGetRowsParams) => {\n                debugger\n                let filter: FilterGridItemsModel = null;\n                if (Object.keys(params.request.filterModel).length > 0) {\n                    filter = {\n                        disable: false,\n                        field: null,\n                        logic: 'AND',\n                        filters: [],\n                        ignoreCase: null,\n                        operator: null,\n                        truncateDate: null,\n                        value: null,\n                    };\n                    for (const key in params.request.filterModel) {\n                        if (params.request.filterModel[key].filterType == 'custom-date') {\n                            filter.filters.push({\n                                disable: false,\n                                field: key == 'ag-Grid-AutoColumn' ? this._treeGroupColumn : key,\n                                logic: 'AND',\n                                filters: null,\n                                ignoreCase: false,\n                                operator: FilterOperator.truncGreaterThanEqual,\n                                truncateDate: true,\n                                value: new Date(params.request.filterModel[key].dateFrom).toISOString()\n                            });\n                            if (params.request.filterModel[key].dateTo != \"\") {\n                                filter.filters.push({\n                                    disable: false,\n                                    field: key == 'ag-Grid-AutoColumn' ? this._treeGroupColumn : key,\n                                    logic: 'AND',\n                                    filters: null,\n                                    ignoreCase: false,\n                                    operator: FilterOperator.truncLessThanOrEqual,\n                                    truncateDate: true,\n                                    value: new Date(params.request.filterModel[key].dateTo).toISOString()\n                                });\n                            }\n                        } else {\n                            const operation = FilterOperator[params.request.filterModel[key].type];\n                            let ignoreCase = true;\n                            const findEl = this._column.find((el) => el.field == key);\n                            let field = null;\n                            if (key == 'ag-Grid-AutoColumn') {\n                                field = this._treeGroupColumn;\n                            } else {\n                                field = key;\n                                if (findEl.searchField != null) {\n                                    field = findEl.searchField;\n                                }\n                            }\n                            if (findEl && findEl.type == 'enum') {\n                                ignoreCase = false;\n                            }\n                            filter.filters.push({\n                                disable: false,\n                                field,\n                                logic: 'AND',\n                                filters: null,\n                                ignoreCase,\n                                operator: operation ? operation : FilterOperator.equals,\n                                truncateDate: true,\n                                value: params.request.filterModel[key].filter ? params.request.filterModel[key].filter : params.request.filterModel[key].type\n                            })\n                        }\n                    }\n                }\n                const gridFilter: GridInputModel = {\n                    take: params.api.paginationGetPageSize(),\n                    data: null,\n                    filter,\n                    skip: params.api.paginationGetCurrentPage() * params.api.paginationGetPageSize(),\n                    sorts: params.request.sortModel.length > 0 ? [{ dir: params.request.sortModel[0].sort, field: params.request.sortModel[0].colId }] : []\n                };\n                const requestParams: GridRequestParam = {\n                    parentNode: params.parentNode.data\n                };\n                this.fetchData(gridFilter, requestParams).then(data => {\n                    params.success({\n                        rowData: data.items,\n                        rowCount: data.totalCount\n                    });\n                }).catch(() => {\n                    params.fail();\n                });\n            }\n        };\n    }\n\n    ngOnInit(): void { }\n}","<!-- <button (click)=\"enableAdvancedFilter=!enableAdvancedFilter\">advanced</button> -->\n<div class=\"flex justify-between items-center mb-4 pb-4 border-b border-b-slate-200\" *ngIf=\"isToolbar\">\n    <div>\n        <h4 class=\"font-semibold text-2xl\">{{label}}</h4>\n    </div>\n    <div class=\"flex gap-3\">\n        <button nz-button *ngFor=\"let item of toolbarItems\" (click)=\"handleClick(item)\" [nzType]=\"item.type\">\n            <span nz-icon [nzType]=\"item.icon\"></span>\n            {{item.text}}\n        </button>\n        <button nz-button (click)=\"refresh()\" nzType=\"default\">\n            <span nz-icon nzType=\"sync\"></span>\n            بروزرسانی\n        </button>\n        <!-- <button nz-button (click)=\"advancedFilter()\" *ngIf=\"showAdvancedButton\" nzType=\"default\">\n            <span nz-icon nzType=\"filter\"></span>\n            جستجوی پیشرفته\n        </button> -->\n    </div>\n</div>\n<ag-grid-angular style=\"width: 100%;\" [style]=\"(isToolbar) ? 'height: calc(100% - 1rem - 48px);':'height: 100%;'\" [columnDefs]=\"columnDefs\" [pagination]=\"true\"\n    [paginationPageSize]=\"paginationPageSize\" [paginationPageSizeSelector]=\"paginationPageSizeSelector\"\n    [class]=\"themeClass\" [defaultColDef]=\"defaultColDef\" [enableAdvancedFilter]=\"enableAdvancedFilter\" [enableRtl]=\"rtl\"\n    [treeData]=\"treeModel\" [autoGroupColumnDef]=\"autoGroupColumnDef\" [isServerSideGroup]=\"isServerSideGroup\"\n    [getServerSideGroupKey]=\"getServerSideGroupKey\" [rowModelType]=\"rowModelType\" [serverSideDatasource]=\"datasource\"\n    (gridReady)=\"onGridReady($event)\" [cacheBlockSize]=\"paginationPageSize\" [maxBlocksInCache]=\"2\"\n    [context]=\"{actionItems: actionItems}\" (cellDoubleClicked)=\"cellDoubleClicked($event)\" #grid />"]}