fixa-admin 0.0.53 → 0.0.55
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/grid/filter/date-filter.component.mjs +7 -1
- package/esm2022/lib/components/grid/filter/index.api.mjs +2 -1
- package/esm2022/lib/components/grid/filter/time-filter.component.mjs +104 -0
- package/esm2022/lib/components/grid/grid.component.mjs +615 -287
- package/esm2022/lib/components/map/map.component.mjs +5 -2
- package/esm2022/lib/components/uploader/uploader.component.mjs +1 -2
- package/esm2022/lib/db.mjs +12 -0
- package/esm2022/lib/directive/image.directive.mjs +1 -2
- package/esm2022/lib/layouts/master/master.layout.mjs +15 -3
- package/esm2022/lib/models/shared.model.mjs +1 -1
- package/esm2022/lib/shared.module.mjs +21 -6
- package/fesm2022/fixa-admin.mjs +774 -313
- package/fesm2022/fixa-admin.mjs.map +1 -1
- package/lib/components/grid/filter/index.api.d.ts +1 -0
- package/lib/components/grid/filter/time-filter.component.d.ts +22 -0
- package/lib/components/grid/grid.component.d.ts +28 -4
- package/lib/db.d.ts +7 -0
- package/lib/layouts/master/master.layout.d.ts +24 -0
- package/lib/models/shared.model.d.ts +36 -2
- package/lib/shared.module.d.ts +36 -31
- package/package.json +1 -1
- package/src/style.scss +35 -1
|
@@ -1,19 +1,32 @@
|
|
|
1
1
|
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
2
|
import { FilterOperator } from '../../models/shared.model';
|
|
3
|
-
import { ActionsCellRenderer } from '../index.api';
|
|
4
3
|
import { JDatePipe } from '../../pipes/date.pipe';
|
|
5
|
-
import {
|
|
4
|
+
import { ActionsCellRenderer } from '../index.api';
|
|
5
|
+
import { DateFilter, TimeFilter } from './filter/index.api';
|
|
6
|
+
import { db } from '../../db';
|
|
6
7
|
import * as i0 from "@angular/core";
|
|
7
8
|
import * as i1 from "@ngx-translate/core";
|
|
8
|
-
import * as i2 from "
|
|
9
|
-
import * as i3 from "@
|
|
10
|
-
import * as i4 from "
|
|
11
|
-
import * as i5 from "ng-zorro-antd/
|
|
12
|
-
import * as i6 from "ng-zorro-antd/
|
|
13
|
-
import * as i7 from "ng-zorro-antd/core/
|
|
9
|
+
import * as i2 from "../../services/index.api";
|
|
10
|
+
import * as i3 from "@angular/common";
|
|
11
|
+
import * as i4 from "@ag-grid-community/angular";
|
|
12
|
+
import * as i5 from "ng-zorro-antd/icon";
|
|
13
|
+
import * as i6 from "ng-zorro-antd/button";
|
|
14
|
+
import * as i7 from "ng-zorro-antd/core/transition-patch";
|
|
15
|
+
import * as i8 from "ng-zorro-antd/core/wave";
|
|
16
|
+
import * as i9 from "ng-zorro-antd/modal";
|
|
17
|
+
import * as i10 from "@angular/forms";
|
|
18
|
+
import * as i11 from "ng-zorro-antd/input";
|
|
19
|
+
import * as i12 from "ng-zorro-antd/grid";
|
|
20
|
+
import * as i13 from "ng-zorro-antd/form";
|
|
21
|
+
import * as i14 from "ng-zorro-antd/select";
|
|
22
|
+
import * as i15 from "ng-zorro-antd/tree-select";
|
|
23
|
+
import * as i16 from "ng-zorro-antd/popover";
|
|
24
|
+
import * as i17 from "@qeydar/datepicker";
|
|
14
25
|
export class GridComponent {
|
|
15
|
-
constructor(_translate) {
|
|
26
|
+
constructor(_translate, _cdr, _toast) {
|
|
16
27
|
this._translate = _translate;
|
|
28
|
+
this._cdr = _cdr;
|
|
29
|
+
this._toast = _toast;
|
|
17
30
|
this.getServerSideGroupKey = null;
|
|
18
31
|
this.groupDefaultExpanded = -1;
|
|
19
32
|
this._treeGroupColumn = null;
|
|
@@ -23,7 +36,16 @@ export class GridComponent {
|
|
|
23
36
|
};
|
|
24
37
|
this.themeClass = "ag-theme-quartz";
|
|
25
38
|
this.columnDefs = [];
|
|
39
|
+
this.visibleFilterBox = false;
|
|
26
40
|
this._column = [];
|
|
41
|
+
this._filterBoxItems = [];
|
|
42
|
+
this.filterItemsValues = [];
|
|
43
|
+
this.filterTemplateItems = [];
|
|
44
|
+
this.visibleFilterTemplateBox = false;
|
|
45
|
+
this.isVisibleModal = false;
|
|
46
|
+
this.gridModel = null;
|
|
47
|
+
this.templateName = null;
|
|
48
|
+
this.gridId = null;
|
|
27
49
|
this._autoColumnSize = { type: 'fitGridWidth' };
|
|
28
50
|
this.autoGroupColumnDef = {
|
|
29
51
|
headerName: "",
|
|
@@ -50,6 +72,7 @@ export class GridComponent {
|
|
|
50
72
|
this.rowSelectionChange = new EventEmitter();
|
|
51
73
|
this.actionWidth = 100;
|
|
52
74
|
this.label = null;
|
|
75
|
+
this.id = null;
|
|
53
76
|
this.rowModelType = 'serverSide';
|
|
54
77
|
this.serverSideSort = true;
|
|
55
78
|
this.serverSideFilter = true;
|
|
@@ -90,6 +113,12 @@ export class GridComponent {
|
|
|
90
113
|
];
|
|
91
114
|
this.datasource = this.createServerSideDatasource();
|
|
92
115
|
}
|
|
116
|
+
getRowClass(params) {
|
|
117
|
+
if (params.node.rowIndex % 2 !== 0) {
|
|
118
|
+
return 'row-odd';
|
|
119
|
+
}
|
|
120
|
+
return '';
|
|
121
|
+
}
|
|
93
122
|
set isRowSelection(v) {
|
|
94
123
|
if (v) {
|
|
95
124
|
this._rowSelection = {
|
|
@@ -147,249 +176,424 @@ export class GridComponent {
|
|
|
147
176
|
// this.autoGroupColumnDef.headerName = v;
|
|
148
177
|
}
|
|
149
178
|
}
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
}
|
|
153
|
-
set column(v) {
|
|
154
|
-
this.columnDefs = [];
|
|
155
|
-
if (v != null) {
|
|
156
|
-
this._column = v;
|
|
179
|
+
set filterItems(v) {
|
|
180
|
+
if (v != null && v.length > 0) {
|
|
157
181
|
v.forEach((el) => {
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
},
|
|
174
|
-
{
|
|
175
|
-
displayKey: 'false',
|
|
176
|
-
displayName: this._translate.instant('NO'),
|
|
177
|
-
predicate: () => true,
|
|
178
|
-
numberOfInputs: 0
|
|
182
|
+
if (!this._filterBoxItems.find((item) => item.field == el.field)) {
|
|
183
|
+
let items = [];
|
|
184
|
+
if ((el.type == 'enum' || el.type == 'select' || el.type == 'tree-select') && el.items != null) {
|
|
185
|
+
el.items?.().then((res) => {
|
|
186
|
+
let nodes = [];
|
|
187
|
+
if (el.type == 'tree-select') {
|
|
188
|
+
const convertToNzTreeNodes = (items) => {
|
|
189
|
+
return items.map(item => ({
|
|
190
|
+
title: item.label,
|
|
191
|
+
key: String(item.value),
|
|
192
|
+
isLeaf: item.children && item.children.length > 0 ? false : true,
|
|
193
|
+
children: item.children ? convertToNzTreeNodes(item.children) : [],
|
|
194
|
+
}));
|
|
195
|
+
};
|
|
196
|
+
nodes = convertToNzTreeNodes(res);
|
|
179
197
|
}
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
displayName: this._translate.instant(el.filterItems[property]),
|
|
189
|
-
predicate: true,
|
|
190
|
-
numberOfInputs: 0
|
|
198
|
+
this._filterBoxItems.push({
|
|
199
|
+
field: el.field,
|
|
200
|
+
label: el.label,
|
|
201
|
+
value: null,
|
|
202
|
+
items: res,
|
|
203
|
+
type: el.type,
|
|
204
|
+
position: el.position ? el.position : 'filter',
|
|
205
|
+
nodes
|
|
191
206
|
});
|
|
192
|
-
}
|
|
193
|
-
filterParams.filterOptions = [
|
|
194
|
-
"empty",
|
|
195
|
-
...items
|
|
196
|
-
];
|
|
197
|
-
break;
|
|
198
|
-
case 'number':
|
|
199
|
-
filter = 'agNumberColumnFilter';
|
|
200
|
-
break;
|
|
201
|
-
case 'select':
|
|
202
|
-
filter = 'agSetColumnFilter';
|
|
203
|
-
break;
|
|
204
|
-
case 'string':
|
|
205
|
-
filter = 'agTextColumnFilter';
|
|
206
|
-
break;
|
|
207
|
-
case 'date':
|
|
208
|
-
filter = 'agDateColumnFilter';
|
|
209
|
-
break;
|
|
210
|
-
default:
|
|
211
|
-
filter = 'agTextColumnFilter';
|
|
212
|
-
break;
|
|
213
|
-
}
|
|
214
|
-
if (el.filter != undefined && !el.filter) {
|
|
215
|
-
filter = false;
|
|
216
|
-
}
|
|
217
|
-
if (el.sortable != undefined && !el.sortable) {
|
|
218
|
-
sortable = false;
|
|
219
|
-
}
|
|
220
|
-
if (el.field != this._treeGroupColumn) {
|
|
221
|
-
if (el.type && el.type == 'boolean') {
|
|
222
|
-
this.columnDefs.push({
|
|
223
|
-
colId: el.id ? el.id : el.field,
|
|
224
|
-
field: el.field,
|
|
225
|
-
headerName: el.label,
|
|
226
|
-
filter: filter,
|
|
227
|
-
sortable,
|
|
228
|
-
editable: el.editable,
|
|
229
|
-
minWidth: el.minWidth ? el.minWidth : null,
|
|
230
|
-
filterParams,
|
|
231
|
-
pinned: el.pinned,
|
|
232
|
-
cellClass: 'ag-boolean-cell',
|
|
233
|
-
cellRenderer: params => {
|
|
234
|
-
if (params.value != null) {
|
|
235
|
-
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>';
|
|
236
|
-
}
|
|
237
|
-
else {
|
|
238
|
-
return '';
|
|
239
|
-
}
|
|
240
|
-
}
|
|
241
207
|
});
|
|
242
208
|
}
|
|
243
|
-
else if (el.type
|
|
244
|
-
|
|
245
|
-
|
|
209
|
+
else if (el.type == 'boolean') {
|
|
210
|
+
items.push({
|
|
211
|
+
label: this._translate.instant("true"),
|
|
212
|
+
value: true
|
|
213
|
+
}, {
|
|
214
|
+
label: this._translate.instant("false"),
|
|
215
|
+
value: false
|
|
216
|
+
});
|
|
217
|
+
this._filterBoxItems.push({
|
|
246
218
|
field: el.field,
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
filterParams,
|
|
254
|
-
cellRenderer: params => {
|
|
255
|
-
if (params.value) {
|
|
256
|
-
return this._translate.instant(params.value);
|
|
257
|
-
}
|
|
258
|
-
else {
|
|
259
|
-
return '';
|
|
260
|
-
}
|
|
261
|
-
}
|
|
219
|
+
label: el.label,
|
|
220
|
+
value: null,
|
|
221
|
+
items,
|
|
222
|
+
type: el.type,
|
|
223
|
+
position: el.position ? el.position : 'filter',
|
|
224
|
+
nodes: []
|
|
262
225
|
});
|
|
263
226
|
}
|
|
264
|
-
else
|
|
265
|
-
this.
|
|
266
|
-
colId: el.id ? el.id : el.field,
|
|
227
|
+
else {
|
|
228
|
+
this._filterBoxItems.push({
|
|
267
229
|
field: el.field,
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
pinned: el.pinned,
|
|
275
|
-
cellRenderer: params => {
|
|
276
|
-
if (params.value) {
|
|
277
|
-
return new JDatePipe().transform(params.value);
|
|
278
|
-
}
|
|
279
|
-
else {
|
|
280
|
-
return '';
|
|
281
|
-
}
|
|
282
|
-
}
|
|
230
|
+
label: el.label,
|
|
231
|
+
value: null,
|
|
232
|
+
items,
|
|
233
|
+
type: el.type,
|
|
234
|
+
position: el.position ? el.position : 'filter',
|
|
235
|
+
nodes: []
|
|
283
236
|
});
|
|
284
237
|
}
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
238
|
+
}
|
|
239
|
+
});
|
|
240
|
+
}
|
|
241
|
+
}
|
|
242
|
+
get column() {
|
|
243
|
+
return this.column;
|
|
244
|
+
}
|
|
245
|
+
set column(v) {
|
|
246
|
+
setTimeout(() => {
|
|
247
|
+
this.columnDefs = [];
|
|
248
|
+
if (v != null) {
|
|
249
|
+
this._column = v;
|
|
250
|
+
v.forEach((el) => {
|
|
251
|
+
var filter = 'agTextColumnFilter';
|
|
252
|
+
var sortable = true;
|
|
253
|
+
var filterParams = {
|
|
254
|
+
maxNumConditions: 1
|
|
255
|
+
};
|
|
256
|
+
switch (el.type) {
|
|
257
|
+
case 'boolean':
|
|
258
|
+
filter = 'agNumberColumnFilter';
|
|
259
|
+
filterParams.filterOptions = [
|
|
260
|
+
"empty",
|
|
261
|
+
{
|
|
262
|
+
displayKey: 'true',
|
|
263
|
+
displayName: this._translate.instant('YES'),
|
|
264
|
+
predicate: () => true,
|
|
265
|
+
numberOfInputs: 0
|
|
266
|
+
},
|
|
267
|
+
{
|
|
268
|
+
displayKey: 'false',
|
|
269
|
+
displayName: this._translate.instant('NO'),
|
|
270
|
+
predicate: () => true,
|
|
271
|
+
numberOfInputs: 0
|
|
302
272
|
}
|
|
273
|
+
];
|
|
274
|
+
break;
|
|
275
|
+
case 'enum':
|
|
276
|
+
filter = 'agNumberColumnFilter';
|
|
277
|
+
const items = [];
|
|
278
|
+
for (const property in el.filterItems) {
|
|
279
|
+
items.push({
|
|
280
|
+
displayKey: el.filterItems[property],
|
|
281
|
+
displayName: this._translate.instant(el.filterItems[property]),
|
|
282
|
+
predicate: true,
|
|
283
|
+
numberOfInputs: 0
|
|
284
|
+
});
|
|
303
285
|
}
|
|
304
|
-
|
|
286
|
+
filterParams.filterOptions = [
|
|
287
|
+
"empty",
|
|
288
|
+
...items
|
|
289
|
+
];
|
|
290
|
+
break;
|
|
291
|
+
case 'number':
|
|
292
|
+
filter = 'agNumberColumnFilter';
|
|
293
|
+
break;
|
|
294
|
+
case 'select':
|
|
295
|
+
filter = 'agSetColumnFilter';
|
|
296
|
+
break;
|
|
297
|
+
case 'string':
|
|
298
|
+
filter = 'agTextColumnFilter';
|
|
299
|
+
break;
|
|
300
|
+
case 'date':
|
|
301
|
+
filter = 'agDateColumnFilter';
|
|
302
|
+
break;
|
|
303
|
+
default:
|
|
304
|
+
filter = 'agTextColumnFilter';
|
|
305
|
+
break;
|
|
305
306
|
}
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
307
|
+
if (this._filterBoxItems.find((item) => item.field == el.field || item.field == el.searchField)) {
|
|
308
|
+
filter = false;
|
|
309
|
+
}
|
|
310
|
+
if (el.filter != undefined && (el.filter == 'filter-box' || el.filter == 'none')) {
|
|
311
|
+
filter = false;
|
|
312
|
+
}
|
|
313
|
+
if (el.sortable != undefined && !el.sortable) {
|
|
314
|
+
sortable = false;
|
|
315
|
+
}
|
|
316
|
+
if (el.field != this._treeGroupColumn) {
|
|
317
|
+
if (el.type && el.type == 'boolean') {
|
|
318
|
+
this.columnDefs.push({
|
|
319
|
+
colId: el.id ? el.id : el.field,
|
|
320
|
+
field: el.field,
|
|
321
|
+
headerName: el.label,
|
|
322
|
+
filter: filter,
|
|
323
|
+
sortable,
|
|
324
|
+
editable: el.editable,
|
|
325
|
+
minWidth: el.minWidth ? el.minWidth : null,
|
|
326
|
+
filterParams,
|
|
327
|
+
pinned: el.pinned,
|
|
328
|
+
cellClass: 'ag-boolean-cell',
|
|
329
|
+
cellRenderer: params => {
|
|
330
|
+
if (params.value != null) {
|
|
331
|
+
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>';
|
|
332
|
+
}
|
|
333
|
+
else {
|
|
334
|
+
return '';
|
|
335
|
+
}
|
|
320
336
|
}
|
|
321
|
-
|
|
322
|
-
|
|
337
|
+
});
|
|
338
|
+
}
|
|
339
|
+
else if (el.type && el.type == 'enum') {
|
|
340
|
+
this.columnDefs.push({
|
|
341
|
+
colId: el.id ? el.id : el.field,
|
|
342
|
+
field: el.field,
|
|
343
|
+
headerName: el.label,
|
|
344
|
+
filter: filter,
|
|
345
|
+
sortable,
|
|
346
|
+
editable: el.editable,
|
|
347
|
+
pinned: el.pinned,
|
|
348
|
+
minWidth: el.minWidth ? el.minWidth : null,
|
|
349
|
+
filterParams,
|
|
350
|
+
cellRenderer: params => {
|
|
351
|
+
if (params.value) {
|
|
352
|
+
return this._translate.instant(params.value);
|
|
353
|
+
}
|
|
354
|
+
else {
|
|
355
|
+
return '';
|
|
356
|
+
}
|
|
323
357
|
}
|
|
324
|
-
}
|
|
325
|
-
}
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
358
|
+
});
|
|
359
|
+
}
|
|
360
|
+
else if (el.type && el.type == 'date') {
|
|
361
|
+
this.columnDefs.push({
|
|
362
|
+
colId: el.id ? el.id : el.field,
|
|
363
|
+
field: el.field,
|
|
364
|
+
headerName: el.label,
|
|
365
|
+
filter: DateFilter,
|
|
366
|
+
sortable,
|
|
367
|
+
editable: el.editable,
|
|
368
|
+
minWidth: el.minWidth ? el.minWidth : null,
|
|
369
|
+
filterParams,
|
|
370
|
+
pinned: el.pinned,
|
|
371
|
+
cellRenderer: params => {
|
|
372
|
+
if (params.value) {
|
|
373
|
+
return new JDatePipe().transform(params.value);
|
|
374
|
+
}
|
|
375
|
+
else {
|
|
376
|
+
return '';
|
|
377
|
+
}
|
|
342
378
|
}
|
|
343
|
-
|
|
344
|
-
|
|
379
|
+
});
|
|
380
|
+
}
|
|
381
|
+
else if (el.type && el.type == 'time') {
|
|
382
|
+
this.columnDefs.push({
|
|
383
|
+
colId: el.id ? el.id : el.field,
|
|
384
|
+
field: el.field,
|
|
385
|
+
headerName: el.label,
|
|
386
|
+
filter: TimeFilter,
|
|
387
|
+
sortable,
|
|
388
|
+
editable: el.editable,
|
|
389
|
+
minWidth: el.minWidth ? el.minWidth : null,
|
|
390
|
+
filterParams,
|
|
391
|
+
pinned: el.pinned,
|
|
392
|
+
cellRenderer: params => {
|
|
393
|
+
if (params.value) {
|
|
394
|
+
return params.value;
|
|
395
|
+
}
|
|
396
|
+
else {
|
|
397
|
+
return '';
|
|
398
|
+
}
|
|
345
399
|
}
|
|
346
|
-
}
|
|
347
|
-
}
|
|
400
|
+
});
|
|
401
|
+
}
|
|
402
|
+
else if (el.type && el.type == 'date-time') {
|
|
403
|
+
this.columnDefs.push({
|
|
404
|
+
colId: el.id ? el.id : el.field,
|
|
405
|
+
field: el.field,
|
|
406
|
+
headerName: el.label,
|
|
407
|
+
filter: DateFilter,
|
|
408
|
+
sortable,
|
|
409
|
+
editable: el.editable,
|
|
410
|
+
minWidth: el.minWidth ? el.minWidth : null,
|
|
411
|
+
filterParams,
|
|
412
|
+
pinned: el.pinned,
|
|
413
|
+
cellRenderer: params => {
|
|
414
|
+
if (params.value) {
|
|
415
|
+
return new JDatePipe().transform(params.value, true);
|
|
416
|
+
}
|
|
417
|
+
else {
|
|
418
|
+
return '';
|
|
419
|
+
}
|
|
420
|
+
}
|
|
421
|
+
});
|
|
422
|
+
}
|
|
423
|
+
else if (el.type && el.type == 'price') {
|
|
424
|
+
this.columnDefs.push({
|
|
425
|
+
colId: el.id ? el.id : el.field,
|
|
426
|
+
field: el.field,
|
|
427
|
+
headerName: el.label,
|
|
428
|
+
filter: filter,
|
|
429
|
+
sortable,
|
|
430
|
+
editable: el.editable,
|
|
431
|
+
minWidth: el.minWidth ? el.minWidth : null,
|
|
432
|
+
filterParams,
|
|
433
|
+
pinned: el.pinned,
|
|
434
|
+
cellRenderer: params => {
|
|
435
|
+
if (params.value) {
|
|
436
|
+
return params.value.toLocaleString();
|
|
437
|
+
}
|
|
438
|
+
else {
|
|
439
|
+
return '';
|
|
440
|
+
}
|
|
441
|
+
}
|
|
442
|
+
});
|
|
443
|
+
}
|
|
444
|
+
else if (el.type && el.type == 'image') {
|
|
445
|
+
this.columnDefs.push({
|
|
446
|
+
colId: el.id ? el.id : el.field,
|
|
447
|
+
field: el.field,
|
|
448
|
+
headerName: el.label,
|
|
449
|
+
minWidth: 80,
|
|
450
|
+
width: 80,
|
|
451
|
+
filter: 'none',
|
|
452
|
+
sortable: false,
|
|
453
|
+
editable: false,
|
|
454
|
+
filterParams,
|
|
455
|
+
pinned: el.pinned,
|
|
456
|
+
cellRenderer: params => {
|
|
457
|
+
if (params.value) {
|
|
458
|
+
return `<img class="rounded-full mt-1" width="32" height="32" src="${params.value}"/>`;
|
|
459
|
+
}
|
|
460
|
+
else {
|
|
461
|
+
return '';
|
|
462
|
+
}
|
|
463
|
+
}
|
|
464
|
+
});
|
|
465
|
+
}
|
|
466
|
+
else {
|
|
467
|
+
this.columnDefs.push({
|
|
468
|
+
colId: el.id ? el.id : el.field,
|
|
469
|
+
field: el.field,
|
|
470
|
+
headerName: el.label,
|
|
471
|
+
filter,
|
|
472
|
+
sortable,
|
|
473
|
+
editable: el.editable,
|
|
474
|
+
filterParams,
|
|
475
|
+
pinned: el.pinned,
|
|
476
|
+
minWidth: el.minWidth ? el.minWidth : null
|
|
477
|
+
});
|
|
478
|
+
}
|
|
348
479
|
}
|
|
349
480
|
else {
|
|
350
|
-
this.
|
|
351
|
-
colId: el.id ? el.id : el.field,
|
|
352
|
-
field: el.field,
|
|
353
|
-
headerName: el.label,
|
|
354
|
-
filter,
|
|
355
|
-
sortable,
|
|
356
|
-
editable: el.editable,
|
|
357
|
-
filterParams,
|
|
358
|
-
pinned: el.pinned,
|
|
359
|
-
minWidth: el.minWidth ? el.minWidth : null
|
|
360
|
-
});
|
|
481
|
+
this.autoGroupColumnDef.field = el.field;
|
|
361
482
|
}
|
|
362
|
-
}
|
|
363
|
-
|
|
364
|
-
|
|
365
|
-
|
|
366
|
-
|
|
367
|
-
|
|
368
|
-
|
|
369
|
-
|
|
370
|
-
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
|
|
379
|
-
|
|
483
|
+
});
|
|
484
|
+
this._column.filter((el) => el.filter == 'filter-box').forEach((el) => {
|
|
485
|
+
let items = [];
|
|
486
|
+
if (el.filterItems != null) {
|
|
487
|
+
switch (el.type) {
|
|
488
|
+
case 'enum':
|
|
489
|
+
Object.keys(el.filterItems).forEach((item) => {
|
|
490
|
+
items.push({
|
|
491
|
+
label: this._translate.instant(el.filterItems[item]),
|
|
492
|
+
value: el.filterItems[item]
|
|
493
|
+
});
|
|
494
|
+
});
|
|
495
|
+
break;
|
|
496
|
+
case 'boolean':
|
|
497
|
+
Object.keys(el.filterItems).forEach((item) => {
|
|
498
|
+
items.push({
|
|
499
|
+
label: this._translate.instant("true"),
|
|
500
|
+
value: true
|
|
501
|
+
}, {
|
|
502
|
+
label: this._translate.instant("false"),
|
|
503
|
+
value: false
|
|
504
|
+
});
|
|
505
|
+
});
|
|
506
|
+
break;
|
|
380
507
|
}
|
|
381
508
|
}
|
|
509
|
+
this._filterBoxItems.push({
|
|
510
|
+
label: el.label,
|
|
511
|
+
value: null,
|
|
512
|
+
items,
|
|
513
|
+
type: el.type,
|
|
514
|
+
field: el.field,
|
|
515
|
+
position: 'filter',
|
|
516
|
+
nodes: []
|
|
517
|
+
});
|
|
382
518
|
});
|
|
519
|
+
if (this.actionItems.length > 0) {
|
|
520
|
+
this.columnDefs.push({
|
|
521
|
+
filter: false,
|
|
522
|
+
headerName: '',
|
|
523
|
+
minWidth: this.actionWidth,
|
|
524
|
+
resizable: true,
|
|
525
|
+
pinned: true,
|
|
526
|
+
sortable: false,
|
|
527
|
+
field: 'actions',
|
|
528
|
+
cellRenderer: ActionsCellRenderer,
|
|
529
|
+
cellRendererParams: {
|
|
530
|
+
onClick: (params) => {
|
|
531
|
+
this.onAction.emit(params);
|
|
532
|
+
}
|
|
533
|
+
}
|
|
534
|
+
});
|
|
535
|
+
}
|
|
383
536
|
}
|
|
537
|
+
}, 100);
|
|
538
|
+
}
|
|
539
|
+
changeDatePickerValue(e, item, index) {
|
|
540
|
+
if (item.value != null) {
|
|
541
|
+
item.value[index] = e;
|
|
542
|
+
}
|
|
543
|
+
else {
|
|
544
|
+
item.value = [null, null];
|
|
545
|
+
item.value[index] = e;
|
|
384
546
|
}
|
|
385
547
|
}
|
|
386
548
|
cellDoubleClicked(e) {
|
|
387
|
-
console.log(e);
|
|
388
549
|
this.onClicked.emit({ ...e.data, colId: e.column.getColId() });
|
|
389
550
|
}
|
|
390
551
|
handleClick(item) {
|
|
391
552
|
this.onToolbar.emit(item);
|
|
392
553
|
}
|
|
554
|
+
saveFilterGrid() {
|
|
555
|
+
if (this.id == null) {
|
|
556
|
+
this._toast.show('شناسه ی جدول وارد نشده است', 'error');
|
|
557
|
+
return;
|
|
558
|
+
}
|
|
559
|
+
if (this.gridId == null) {
|
|
560
|
+
this.isVisibleModal = true;
|
|
561
|
+
this._cdr.detectChanges();
|
|
562
|
+
}
|
|
563
|
+
else {
|
|
564
|
+
db.gridFilterItems.get(this.gridId).then((res) => {
|
|
565
|
+
db.gridFilterItems.put({
|
|
566
|
+
...res,
|
|
567
|
+
grid: this.gridModel,
|
|
568
|
+
});
|
|
569
|
+
this.fetchTemplate();
|
|
570
|
+
this._toast.show('قالب با موفقیت بروزرسانی شد', 'success');
|
|
571
|
+
});
|
|
572
|
+
}
|
|
573
|
+
}
|
|
574
|
+
handleCancelModal() {
|
|
575
|
+
this.isVisibleModal = false;
|
|
576
|
+
this._cdr.detectChanges();
|
|
577
|
+
}
|
|
578
|
+
handleOkModal() {
|
|
579
|
+
if (this.templateName == null) {
|
|
580
|
+
this._toast.show('عنوان قالب وارد نشده است', 'error');
|
|
581
|
+
return;
|
|
582
|
+
}
|
|
583
|
+
this.gridId = new Date().getTime().toString();
|
|
584
|
+
db.gridFilterItems.add({
|
|
585
|
+
id: this.gridId,
|
|
586
|
+
grid: this.gridModel,
|
|
587
|
+
tableId: this.id,
|
|
588
|
+
title: this.templateName,
|
|
589
|
+
userName: null
|
|
590
|
+
});
|
|
591
|
+
this._toast.show('قالب با موفقیت ذخیره شد', 'success');
|
|
592
|
+
this.templateName = null;
|
|
593
|
+
this.isVisibleModal = false;
|
|
594
|
+
this._cdr.detectChanges();
|
|
595
|
+
this.fetchTemplate();
|
|
596
|
+
}
|
|
393
597
|
refresh(purge = false) {
|
|
394
598
|
if (this.rowModelType == 'serverSide') {
|
|
395
599
|
this.gridApi.refreshServerSide({ purge });
|
|
@@ -442,7 +646,13 @@ export class GridComponent {
|
|
|
442
646
|
});
|
|
443
647
|
}
|
|
444
648
|
clearFilter() {
|
|
649
|
+
this.visibleFilterBox = false;
|
|
650
|
+
this._filterBoxItems.forEach((el) => {
|
|
651
|
+
el.value = null;
|
|
652
|
+
});
|
|
445
653
|
this.gridApi.setFilterModel(null);
|
|
654
|
+
this.gridApi.onFilterChanged();
|
|
655
|
+
this.filterItemsValues = [];
|
|
446
656
|
this.refresh();
|
|
447
657
|
}
|
|
448
658
|
refreshParentNode(id) {
|
|
@@ -453,89 +663,155 @@ export class GridComponent {
|
|
|
453
663
|
route: route
|
|
454
664
|
});
|
|
455
665
|
}
|
|
666
|
+
filter() {
|
|
667
|
+
this.handleFilterLabelValue();
|
|
668
|
+
this.refresh();
|
|
669
|
+
this.visibleFilterBox = false;
|
|
670
|
+
}
|
|
671
|
+
setTemplateFilter(item) {
|
|
672
|
+
this.clearFilter();
|
|
673
|
+
setTimeout(() => {
|
|
674
|
+
item.grid.filter.filters.forEach((el) => {
|
|
675
|
+
const findEl = this._column.find((item) => item.field == el.field || item.searchField == el.field);
|
|
676
|
+
if (findEl && this.columnDefs.find((item) => item.field == findEl.field && item.filter)) {
|
|
677
|
+
this.gridApi.setColumnFilterModel(findEl.field, {
|
|
678
|
+
type: el.logic,
|
|
679
|
+
filter: el.value
|
|
680
|
+
});
|
|
681
|
+
}
|
|
682
|
+
else {
|
|
683
|
+
const index = this._filterBoxItems.findIndex((item) => item.field == el.field);
|
|
684
|
+
this._filterBoxItems[index].value = el.value;
|
|
685
|
+
this._cdr.detectChanges();
|
|
686
|
+
}
|
|
687
|
+
});
|
|
688
|
+
this.gridId = item.id;
|
|
689
|
+
this.visibleFilterTemplateBox = false;
|
|
690
|
+
this._cdr.detectChanges();
|
|
691
|
+
this.handleFilterLabelValue();
|
|
692
|
+
this.gridApi.onFilterChanged();
|
|
693
|
+
this.refresh();
|
|
694
|
+
}, 100);
|
|
695
|
+
}
|
|
696
|
+
handleFilterLabelValue() {
|
|
697
|
+
this._filterBoxItems.forEach((el) => {
|
|
698
|
+
const findEl = this.filterItemsValues.find((fi) => fi.field == el.field);
|
|
699
|
+
if (!findEl) {
|
|
700
|
+
if (el.value != null) {
|
|
701
|
+
this.filterItemsValues.push({
|
|
702
|
+
field: el.field,
|
|
703
|
+
label: el.label,
|
|
704
|
+
value: el.value
|
|
705
|
+
});
|
|
706
|
+
this._cdr.detectChanges();
|
|
707
|
+
}
|
|
708
|
+
}
|
|
709
|
+
else {
|
|
710
|
+
if (el.value == null || el.value == "") {
|
|
711
|
+
this.filterItemsValues = this.filterItemsValues.filter((fi) => fi.field != el.field);
|
|
712
|
+
}
|
|
713
|
+
else {
|
|
714
|
+
findEl.value = el.value;
|
|
715
|
+
}
|
|
716
|
+
this._cdr.detectChanges();
|
|
717
|
+
}
|
|
718
|
+
});
|
|
719
|
+
}
|
|
720
|
+
removeFilter(item) {
|
|
721
|
+
const index = this._filterBoxItems.findIndex((el) => el.field == item.field);
|
|
722
|
+
if (index >= 0) {
|
|
723
|
+
this._filterBoxItems[index].value = null;
|
|
724
|
+
}
|
|
725
|
+
else {
|
|
726
|
+
this.gridApi.setColumnFilterModel(item.field, null);
|
|
727
|
+
this.gridApi.onFilterChanged();
|
|
728
|
+
}
|
|
729
|
+
this.filterItemsValues = this.filterItemsValues.filter((el) => el.field != item.field);
|
|
730
|
+
this._cdr.detectChanges();
|
|
731
|
+
this.refresh();
|
|
732
|
+
}
|
|
456
733
|
createServerSideDatasource() {
|
|
457
734
|
return {
|
|
458
735
|
getRows: (params) => {
|
|
459
736
|
let filter = null;
|
|
737
|
+
filter = {
|
|
738
|
+
disable: false,
|
|
739
|
+
field: null,
|
|
740
|
+
logic: 'AND',
|
|
741
|
+
filters: [],
|
|
742
|
+
ignoreCase: null,
|
|
743
|
+
operator: null,
|
|
744
|
+
truncateDate: null,
|
|
745
|
+
value: null,
|
|
746
|
+
};
|
|
460
747
|
if (Object.keys(params.request.filterModel).length > 0) {
|
|
461
|
-
filter = {
|
|
462
|
-
disable: false,
|
|
463
|
-
field: null,
|
|
464
|
-
logic: 'AND',
|
|
465
|
-
filters: [],
|
|
466
|
-
ignoreCase: null,
|
|
467
|
-
operator: null,
|
|
468
|
-
truncateDate: null,
|
|
469
|
-
value: null,
|
|
470
|
-
};
|
|
471
748
|
for (const key in params.request.filterModel) {
|
|
749
|
+
let field = key == 'ag-Grid-AutoColumn' ? this._treeGroupColumn : key;
|
|
750
|
+
let value = null;
|
|
751
|
+
let operator = FilterOperator.equals;
|
|
752
|
+
let ignoreCase = false;
|
|
753
|
+
const findEl = this._column.find((el) => el.field == key);
|
|
754
|
+
if (key == 'ag-Grid-AutoColumn') {
|
|
755
|
+
field = this._treeGroupColumn;
|
|
756
|
+
}
|
|
757
|
+
else {
|
|
758
|
+
field = key;
|
|
759
|
+
if (findEl.searchField != null) {
|
|
760
|
+
field = findEl.searchField;
|
|
761
|
+
}
|
|
762
|
+
}
|
|
472
763
|
if (params.request.filterModel[key].filterType == 'custom-date') {
|
|
473
764
|
if (params.request.filterModel[key].dateFrom && params.request.filterModel[key].dateTo) {
|
|
474
|
-
|
|
475
|
-
|
|
476
|
-
field: key == 'ag-Grid-AutoColumn' ? this._treeGroupColumn : key,
|
|
477
|
-
logic: 'AND',
|
|
478
|
-
filters: null,
|
|
479
|
-
ignoreCase: false,
|
|
480
|
-
operator: FilterOperator.between,
|
|
481
|
-
truncateDate: true,
|
|
482
|
-
value: [params.request.filterModel[key].dateFrom, params.request.filterModel[key].dateTo]
|
|
483
|
-
});
|
|
765
|
+
operator = FilterOperator.between;
|
|
766
|
+
value = [params.request.filterModel[key].dateFrom, params.request.filterModel[key].dateTo];
|
|
484
767
|
}
|
|
485
768
|
else if (params.request.filterModel[key].dateFrom) {
|
|
486
|
-
|
|
487
|
-
|
|
488
|
-
field: key == 'ag-Grid-AutoColumn' ? this._treeGroupColumn : key,
|
|
489
|
-
logic: 'AND',
|
|
490
|
-
filters: null,
|
|
491
|
-
ignoreCase: false,
|
|
492
|
-
operator: FilterOperator.truncGreaterThanEqual,
|
|
493
|
-
truncateDate: true,
|
|
494
|
-
value: params.request.filterModel[key].dateFrom,
|
|
495
|
-
});
|
|
769
|
+
operator = FilterOperator.truncGreaterThanEqual;
|
|
770
|
+
value = params.request.filterModel[key].dateFrom;
|
|
496
771
|
}
|
|
497
772
|
else if (params.request.filterModel[key].dateTo && params.request.filterModel[key].dateTo != "") {
|
|
498
|
-
|
|
499
|
-
|
|
500
|
-
field: key == 'ag-Grid-AutoColumn' ? this._treeGroupColumn : key,
|
|
501
|
-
logic: 'AND',
|
|
502
|
-
filters: null,
|
|
503
|
-
ignoreCase: false,
|
|
504
|
-
operator: FilterOperator.truncLessThanOrEqual,
|
|
505
|
-
truncateDate: true,
|
|
506
|
-
value: params.request.filterModel[key].dateTo,
|
|
507
|
-
});
|
|
773
|
+
operator = FilterOperator.truncLessThanOrEqual;
|
|
774
|
+
value = params.request.filterModel[key].dateTo;
|
|
508
775
|
}
|
|
509
776
|
}
|
|
777
|
+
else if (params.request.filterModel[key].filterType == 'custom-time' && params.request.filterModel[key].time != null) {
|
|
778
|
+
operator = FilterOperator.equals;
|
|
779
|
+
value = `${params.request.filterModel[key].time.substr(0, 2)}:${params.request.filterModel[key].time.substr(2, 2)}:${params.request.filterModel[key].time.substr(4, 2)}`;
|
|
780
|
+
}
|
|
510
781
|
else {
|
|
511
|
-
|
|
512
|
-
|
|
513
|
-
const findEl = this._column.find((el) => el.field == key);
|
|
514
|
-
let field = null;
|
|
515
|
-
if (key == 'ag-Grid-AutoColumn') {
|
|
516
|
-
field = this._treeGroupColumn;
|
|
517
|
-
}
|
|
518
|
-
else {
|
|
519
|
-
field = key;
|
|
520
|
-
if (findEl.searchField != null) {
|
|
521
|
-
field = findEl.searchField;
|
|
522
|
-
}
|
|
782
|
+
if (FilterOperator[params.request.filterModel[key].type]) {
|
|
783
|
+
operator = FilterOperator[params.request.filterModel[key].type];
|
|
523
784
|
}
|
|
785
|
+
ignoreCase = true;
|
|
786
|
+
value = params.request.filterModel[key].filter ? params.request.filterModel[key].filter : params.request.filterModel[key].type;
|
|
524
787
|
if (findEl && findEl.type == 'enum') {
|
|
525
788
|
ignoreCase = false;
|
|
526
789
|
}
|
|
527
|
-
|
|
528
|
-
|
|
529
|
-
|
|
530
|
-
|
|
531
|
-
|
|
532
|
-
|
|
533
|
-
|
|
534
|
-
truncateDate: true,
|
|
535
|
-
value: params.request.filterModel[key].filter ? params.request.filterModel[key].filter : params.request.filterModel[key].type
|
|
790
|
+
}
|
|
791
|
+
const findFilterItemsEl = this.filterItemsValues.find((fi) => fi.field == findEl.field);
|
|
792
|
+
if (!findFilterItemsEl) {
|
|
793
|
+
this.filterItemsValues.push({
|
|
794
|
+
field: findEl.field,
|
|
795
|
+
label: findEl.label,
|
|
796
|
+
value: value
|
|
536
797
|
});
|
|
537
798
|
}
|
|
799
|
+
else {
|
|
800
|
+
findFilterItemsEl.value = value;
|
|
801
|
+
}
|
|
802
|
+
filter.filters.push({
|
|
803
|
+
disable: false,
|
|
804
|
+
field,
|
|
805
|
+
logic: 'AND',
|
|
806
|
+
filters: null,
|
|
807
|
+
ignoreCase,
|
|
808
|
+
operator,
|
|
809
|
+
truncateDate: true,
|
|
810
|
+
value
|
|
811
|
+
});
|
|
538
812
|
}
|
|
813
|
+
this._cdr.detectChanges();
|
|
814
|
+
// this.filterItemsValues = structuredClone(this.filterItemsValues);
|
|
539
815
|
}
|
|
540
816
|
let sorts = [];
|
|
541
817
|
if (params.request.sortModel.length) {
|
|
@@ -555,7 +831,7 @@ export class GridComponent {
|
|
|
555
831
|
}
|
|
556
832
|
const gridFilter = {
|
|
557
833
|
take: params.api.paginationGetPageSize(),
|
|
558
|
-
data:
|
|
834
|
+
data: {},
|
|
559
835
|
filter,
|
|
560
836
|
skip: params.api.paginationGetCurrentPage() * params.api.paginationGetPageSize(),
|
|
561
837
|
sorts
|
|
@@ -563,6 +839,45 @@ export class GridComponent {
|
|
|
563
839
|
const requestParams = {
|
|
564
840
|
parentNode: params.parentNode.data
|
|
565
841
|
};
|
|
842
|
+
this._filterBoxItems.forEach((el) => {
|
|
843
|
+
if (el.value != null) {
|
|
844
|
+
if (el.position == 'filter') {
|
|
845
|
+
let operator = null;
|
|
846
|
+
switch (el.type) {
|
|
847
|
+
case 'string':
|
|
848
|
+
operator = FilterOperator.contains;
|
|
849
|
+
break;
|
|
850
|
+
case 'date':
|
|
851
|
+
case 'date-time':
|
|
852
|
+
operator = FilterOperator.between;
|
|
853
|
+
if (el.value[0] == null) {
|
|
854
|
+
el.value[0] = new Date('1997-01-01').toISOString();
|
|
855
|
+
}
|
|
856
|
+
else if (el.value[1] == null) {
|
|
857
|
+
el.value[1] = new Date().toISOString();
|
|
858
|
+
}
|
|
859
|
+
break;
|
|
860
|
+
default:
|
|
861
|
+
operator = FilterOperator.equals;
|
|
862
|
+
break;
|
|
863
|
+
}
|
|
864
|
+
gridFilter.filter.filters.push({
|
|
865
|
+
disable: false,
|
|
866
|
+
field: el.field,
|
|
867
|
+
filters: null,
|
|
868
|
+
ignoreCase: false,
|
|
869
|
+
logic: 'AND',
|
|
870
|
+
operator,
|
|
871
|
+
truncateDate: false,
|
|
872
|
+
value: el.value
|
|
873
|
+
});
|
|
874
|
+
}
|
|
875
|
+
else {
|
|
876
|
+
gridFilter.data[el.field] = el.value;
|
|
877
|
+
}
|
|
878
|
+
}
|
|
879
|
+
});
|
|
880
|
+
this.gridModel = gridFilter;
|
|
566
881
|
this.fetchData(gridFilter, requestParams).then(data => {
|
|
567
882
|
params.success({
|
|
568
883
|
rowData: data.items,
|
|
@@ -577,14 +892,23 @@ export class GridComponent {
|
|
|
577
892
|
}
|
|
578
893
|
};
|
|
579
894
|
}
|
|
580
|
-
|
|
581
|
-
|
|
582
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: GridComponent, selector: "app-grid", inputs: { actionWidth: "actionWidth", label: "label", isRowSelection: "isRowSelection", rowModelType: "rowModelType", serverSideSort: "serverSideSort", serverSideFilter: "serverSideFilter", isToolbar: "isToolbar", rtl: "rtl", paginationPageSize: "paginationPageSize", paginationPageSizeSelector: "paginationPageSizeSelector", enableAdvancedFilter: "enableAdvancedFilter", treeModel: "treeModel", isLeaf: "isLeaf", rowData: "rowData", autoColumnSize: "autoColumnSize", showAdvancedButton: "showAdvancedButton", actionItems: "actionItems", toolbarItems: "toolbarItems", treeGroupColumn: "treeGroupColumn", fetchData: "fetchData", column: "column" }, outputs: { onAction: "onAction", onToolbar: "onToolbar", onClicked: "onClicked", rowSelectionChange: "rowSelectionChange" }, ngImport: i0, template: "<!-- <button (click)=\"enableAdvancedFilter=!enableAdvancedFilter\">advanced</button> -->\n<div\n class=\"flex justify-between items-center mb-4 pb-4 border-b border-b-slate-200\"\n *ngIf=\"isToolbar\"\n>\n <div>\n <h4 class=\"font-semibold text-2xl\">{{ label }}</h4>\n </div>\n <div class=\"flex gap-3\">\n @for (item of toolbarItems; track $index) {\n <button\n nz-button\n [nzLoading]=\"item.loading ? item.loading : false\"\n (click)=\"handleClick(item)\"\n [nzType]=\"item.type\"\n >\n <span nz-icon [nzType]=\"item.icon\"></span>\n {{ item.text }}\n </button>\n }\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)=\"clearFilter()\" nzType=\"default\">\n <span nz-icon nzType=\"clear\"></span>\n \u067E\u0627\u06A9\u0633\u0627\u0632\u06CC\n </button>\n\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<div>\n <ng-content></ng-content>\n</div>\n<ag-grid-angular\n style=\"width: 100%\"\n [style]=\"isToolbar ? 'height: calc(100% - 1rem - 48px);' : 'height: 100%;'\"\n [columnDefs]=\"columnDefs\"\n [pagination]=\"true\"\n [paginationPageSize]=\"paginationPageSize\"\n [paginationPageSizeSelector]=\"paginationPageSizeSelector\"\n [class]=\"themeClass\"\n [defaultColDef]=\"defaultColDef\"\n [enableAdvancedFilter]=\"enableAdvancedFilter\"\n [enableRtl]=\"rtl\"\n [treeData]=\"treeModel\"\n [autoGroupColumnDef]=\"autoGroupColumnDef\"\n [isServerSideGroup]=\"isServerSideGroup\"\n [getServerSideGroupKey]=\"getServerSideGroupKey\"\n [rowModelType]=\"rowModelType\"\n [rowData]=\"rowData\"\n [serverSideDatasource]=\"datasource\"\n (gridReady)=\"onGridReady($event)\"\n [cacheBlockSize]=\"paginationPageSize\"\n [maxBlocksInCache]=\"2\"\n [context]=\"{ actionItems: actionItems }\"\n (cellDoubleClicked)=\"cellDoubleClicked($event)\"\n [autoSizeStrategy]=\"_autoColumnSize\"\n [rowSelection]=\"_rowSelection\"\n (selectionChanged)=\"selectionChanged($event)\"\n #grid\n/>\n", dependencies: [{ 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"] }] }); }
|
|
895
|
+
fetchTemplate() {
|
|
896
|
+
if (this.id != null) {
|
|
897
|
+
db.gridFilterItems.filter((el) => el.tableId == this.id).toArray().then((res) => {
|
|
898
|
+
this.filterTemplateItems = res;
|
|
899
|
+
});
|
|
900
|
+
}
|
|
901
|
+
}
|
|
902
|
+
ngOnInit() {
|
|
903
|
+
this.fetchTemplate();
|
|
904
|
+
}
|
|
905
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: GridComponent, deps: [{ token: i1.TranslateService }, { token: i0.ChangeDetectorRef }, { token: i2.ToastService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
906
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.3.12", type: GridComponent, selector: "app-grid", inputs: { actionWidth: "actionWidth", label: "label", id: "id", isRowSelection: "isRowSelection", rowModelType: "rowModelType", serverSideSort: "serverSideSort", serverSideFilter: "serverSideFilter", isToolbar: "isToolbar", rtl: "rtl", paginationPageSize: "paginationPageSize", paginationPageSizeSelector: "paginationPageSizeSelector", enableAdvancedFilter: "enableAdvancedFilter", treeModel: "treeModel", isLeaf: "isLeaf", rowData: "rowData", autoColumnSize: "autoColumnSize", showAdvancedButton: "showAdvancedButton", actionItems: "actionItems", toolbarItems: "toolbarItems", treeGroupColumn: "treeGroupColumn", filterItems: "filterItems", fetchData: "fetchData", column: "column" }, outputs: { onAction: "onAction", onToolbar: "onToolbar", onClicked: "onClicked", rowSelectionChange: "rowSelectionChange" }, ngImport: i0, template: "<!-- <button (click)=\"enableAdvancedFilter=!enableAdvancedFilter\">advanced</button> -->\n<div class=\"flex justify-between items-center py-4 border-b border-b-slate-200 mx-4\" *ngIf=\"isToolbar\">\n <div>\n <h4 class=\"font-semibold text-2xl\">{{ label }}</h4>\n </div>\n <div class=\"flex gap-3\">\n @for (item of toolbarItems; track $index) {\n <button nz-button [nzLoading]=\"item.loading ? item.loading : false\" (click)=\"handleClick(item)\" [nzType]=\"item.type\">\n <span nz-icon [nzType]=\"item.icon\"></span>\n {{ item.text }}\n </button>\n }\n <button\n nz-button\n nzType=\"default\"\n nz-popover\n nzPopoverTitle=\"\"\n [(nzPopoverVisible)]=\"visibleFilterBox\"\n nzPopoverTrigger=\"click\"\n [nzPopoverContent]=\"contentTemplate\"\n nzPopoverOverlayClassName=\"filter-popover\"\n nzPopoverPlacement=\"bottom\"\n *ngIf=\"_filterBoxItems.length > 0\">\n <span nz-icon nzType=\"filter\"></span>\n \u0641\u06CC\u0644\u062A\u0631\n </button>\n <button\n nz-button\n nzType=\"default\"\n class=\"flex items-center\"\n nz-popover\n nzPopoverTitle=\"\"\n [(nzPopoverVisible)]=\"visibleFilterTemplateBox\"\n nzPopoverTrigger=\"click\"\n [nzPopoverContent]=\"contentFilterTemplate\"\n nzPopoverOverlayClassName=\"filter-popover-sm\"\n nzPopoverPlacement=\"bottom\"\n *ngIf=\"id != null\">\n <span nz-icon nzType=\"layout\"></span>\n \u0641\u06CC\u0644\u062A\u0631 \u0647\u0627\u06CC \u0630\u062E\u06CC\u0631\u0647 \u0634\u062F\u0647\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<ng-template #contentTemplate class=\"w-full\">\n <div class=\"grid gap-x-4 pt-4\" [ngClass]=\"{ 'grid-cols-1': _filterBoxItems.length == 1, 'grid-cols-2': _filterBoxItems.length > 1 }\">\n <div *ngFor=\"let item of _filterBoxItems\" [ngClass]=\"{ 'col-span-2': item.type == 'date' || item.type == 'date-time' }\">\n <div *ngIf=\"item.type == 'date' || item.type == 'date-time'\" class=\"grid grid-cols-2 gap-x-4\">\n <nz-form-item>\n <nz-form-label>\u0627\u0632 \u062A\u0627\u0631\u06CC\u062E</nz-form-label>\n <nz-form-control>\n <qeydar-date-picker\n [ngModel]=\"item.value != null ? item.value[0] : null\"\n (onChangeValue)=\"changeDatePickerValue($event, item, 0)\"\n [showToday]=\"true\"\n [allowEmpty]=\"true\"\n [calendarType]=\"'jalali'\"\n format=\"yyyy-MM-dd\"\n [rtl]=\"true\"></qeydar-date-picker>\n </nz-form-control>\n </nz-form-item>\n <nz-form-item>\n <nz-form-label>\u062A\u0627 \u062A\u0627\u0631\u06CC\u062E</nz-form-label>\n <nz-form-control>\n <qeydar-date-picker\n [ngModel]=\"item.value != null ? item.value[1] : null\"\n (onChangeValue)=\"changeDatePickerValue($event, item, 1)\"\n [showToday]=\"true\"\n [allowEmpty]=\"true\"\n [calendarType]=\"'jalali'\"\n format=\"yyyy-MM-dd\"\n [rtl]=\"true\"></qeydar-date-picker>\n </nz-form-control>\n </nz-form-item>\n </div>\n <div *ngIf=\"item.type == 'enum' || item.type == 'select' || item.type == 'boolean'\">\n <nz-form-item class=\"w-full\">\n <nz-form-label>{{ item.label }}</nz-form-label>\n <nz-select class=\"w-full\" [(ngModel)]=\"item.value\" nzShowSearch>\n <nz-option *ngFor=\"let item2 of item.items\" [nzValue]=\"item2.value\" [nzLabel]=\"item2.label\"></nz-option>\n </nz-select>\n </nz-form-item>\n </div>\n <div *ngIf=\"item.type == 'tree-select'\">\n <nz-form-item class=\"w-full\">\n <nz-form-label>{{ item.label }}</nz-form-label>\n <nz-tree-select class=\"w-full\" [nzNodes]=\"item.nodes\" nzShowSearch [(ngModel)]=\"item.value\"></nz-tree-select>\n </nz-form-item>\n </div>\n <div *ngIf=\"item.type == 'string' || item.type == null\">\n <nz-form-item class=\"w-full\">\n <nz-form-label>{{ item.label }}</nz-form-label>\n <input type=\"text\" nz-input [(ngModel)]=\"item.value\" />\n </nz-form-item>\n </div>\n </div>\n </div>\n <div class=\"flex gap-2 pt-4 mt-4 border-t border-t-slate-200\">\n <button nz-button nzType=\"primary\" (click)=\"filter()\">\u0627\u0639\u0645\u0627\u0644</button>\n <button nz-button nzType=\"default\" (click)=\"clearFilter()\">\u067E\u0627\u06A9\u0633\u0627\u0632\u06CC \u0648 \u0628\u0633\u062A\u0646</button>\n </div>\n</ng-template>\n<!-- template items box -->\n<ng-template #contentFilterTemplate class=\"w-full\">\n <ul class=\"flex flex-col gap-2 max-h-[300px]\">\n <li class=\"p-2 rounded-lg cursor-pointer border border-slate-200\" *ngFor=\"let item of filterTemplateItems\" (click)=\"setTemplateFilter(item)\">{{ item.title }}</li>\n </ul>\n</ng-template>\n<div class=\"flex items-center justify-between gap-2 px-4 py-2 h-14\" *ngIf=\"isToolbar\">\n <div class=\"flex items-center gap-2\">\n <span class=\"font-medium text-sm text-blue-500\">\u0641\u06CC\u0644\u062A\u0631\u0647\u0627\u06CC \u0627\u0639\u0645\u0627\u0644 \u0634\u062F\u0647:</span>\n <ul class=\"flex items-center gap-2\">\n <li class=\"bg-white border border-slate-200 rounded-md px-2 py-1 flex items-center gap-1 h-8\" *ngIf=\"filterItemsValues.length == 0\">\n <span class=\"text-slate-800 font-medium text-sm\">\u0628\u062F\u0648\u0646 \u0641\u06CC\u0644\u062A\u0631</span>\n </li>\n <li class=\"bg-white border border-slate-200 rounded-md px-2 py-1 flex items-center gap-1 h-8\" *ngFor=\"let item of filterItemsValues\">\n <label class=\"text-slate-500 text-sm\">{{ item.label }}:</label>\n <span class=\"text-slate-800 font-medium text-sm\">{{ item.value | translate }}</span>\n <i class=\"fa-regular fa-times cursor-pointer ps-2\" (click)=\"removeFilter(item)\"></i>\n </li>\n </ul>\n </div>\n <div class=\"flex items-center gap-2\" *ngIf=\"id != null\">\n <button nz-button nzType=\"default\" *ngIf=\"filterItemsValues.length > 0 || gridId != null\" (click)=\"saveFilterGrid()\">\n {{ gridId == null ? '\u0630\u062E\u06CC\u0631\u0647 \u0641\u06CC\u0644\u062A\u0631' : '\u0627\u0639\u0645\u0627\u0644 \u062A\u063A\u06CC\u06CC\u0631\u0627\u062A \u0641\u06CC\u0644\u062A\u0631' }}\n </button>\n <button nz-button nzType=\"default\" *ngIf=\"gridId != null\" (click)=\"clearFilter(); gridId = null\">\u0644\u063A\u0648</button>\n </div>\n</div>\n\n<nz-modal [(nzVisible)]=\"isVisibleModal\" nzTitle=\"\u0627\u0641\u0632\u0648\u062F\u0646 \u0642\u0627\u0644\u0628 \u062C\u062F\u06CC\u062F\" (nzOnCancel)=\"handleCancelModal()\" (nzOnOk)=\"handleOkModal()\">\n <ng-container *nzModalContent>\n <nz-form-item class=\"w-full\">\n <nz-form-label>\u0639\u0646\u0648\u0627\u0646 \u0642\u0627\u0644\u0628</nz-form-label>\n <input type=\"text\" nz-input [(ngModel)]=\"templateName\" />\n </nz-form-item>\n </ng-container>\n</nz-modal>\n\n<ag-grid-angular\n style=\"width: 100%\"\n [style]=\"isToolbar ? 'height: calc(100% - 1rem - 124px);' : 'height: 100%;'\"\n [columnDefs]=\"columnDefs\"\n [pagination]=\"true\"\n [paginationPageSize]=\"paginationPageSize\"\n [paginationPageSizeSelector]=\"paginationPageSizeSelector\"\n [class]=\"themeClass\"\n [rowHeight]=\"48\"\n [defaultColDef]=\"defaultColDef\"\n [enableAdvancedFilter]=\"enableAdvancedFilter\"\n [enableRtl]=\"rtl\"\n [treeData]=\"treeModel\"\n [autoGroupColumnDef]=\"autoGroupColumnDef\"\n [isServerSideGroup]=\"isServerSideGroup\"\n [getServerSideGroupKey]=\"getServerSideGroupKey\"\n [rowModelType]=\"rowModelType\"\n [rowData]=\"rowData\"\n [serverSideDatasource]=\"datasource\"\n (gridReady)=\"onGridReady($event)\"\n [cacheBlockSize]=\"paginationPageSize\"\n [maxBlocksInCache]=\"2\"\n [context]=\"{ actionItems: actionItems }\"\n (cellDoubleClicked)=\"cellDoubleClicked($event)\"\n [autoSizeStrategy]=\"_autoColumnSize\"\n [rowSelection]=\"_rowSelection\"\n (selectionChanged)=\"selectionChanged($event)\"\n [theme]=\"\"\n [getRowClass]=\"getRowClass\"\n #grid />\n", dependencies: [{ kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.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: i5.NzIconDirective, selector: "[nz-icon]", inputs: ["nzSpin", "nzRotate", "nzType", "nzTheme", "nzTwotoneColor", "nzIconfont"], exportAs: ["nzIcon"] }, { kind: "component", type: i6.NzButtonComponent, selector: "button[nz-button], a[nz-button]", inputs: ["nzBlock", "nzGhost", "nzSearch", "nzLoading", "nzDanger", "disabled", "tabIndex", "nzType", "nzShape", "nzSize"], exportAs: ["nzButton"] }, { kind: "directive", type: i7.ɵ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: i8.NzWaveDirective, selector: "[nz-wave],button[nz-button]:not([nzType=\"link\"]):not([nzType=\"text\"])", inputs: ["nzWaveExtraNode"], exportAs: ["nzWave"] }, { kind: "component", type: i9.NzModalComponent, selector: "nz-modal", inputs: ["nzMask", "nzMaskClosable", "nzCloseOnNavigation", "nzVisible", "nzClosable", "nzOkLoading", "nzOkDisabled", "nzCancelDisabled", "nzCancelLoading", "nzKeyboard", "nzNoAnimation", "nzCentered", "nzDraggable", "nzContent", "nzFooter", "nzZIndex", "nzWidth", "nzWrapClassName", "nzClassName", "nzStyle", "nzTitle", "nzCloseIcon", "nzMaskStyle", "nzBodyStyle", "nzOkText", "nzCancelText", "nzOkType", "nzOkDanger", "nzIconType", "nzModalType", "nzAutofocus", "nzOnOk", "nzOnCancel"], outputs: ["nzOnOk", "nzOnCancel", "nzAfterOpen", "nzAfterClose", "nzVisibleChange"], exportAs: ["nzModal"] }, { kind: "directive", type: i9.NzModalContentDirective, selector: "[nzModalContent]", exportAs: ["nzModalContent"] }, { kind: "directive", type: i10.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i10.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i10.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: i11.NzInputDirective, selector: "input[nz-input],textarea[nz-input]", inputs: ["nzBorderless", "nzSize", "nzStepperless", "nzStatus", "disabled"], exportAs: ["nzInput"] }, { kind: "directive", type: i12.NzColDirective, selector: "[nz-col],nz-col,nz-form-control,nz-form-label", inputs: ["nzFlex", "nzSpan", "nzOrder", "nzOffset", "nzPush", "nzPull", "nzXs", "nzSm", "nzMd", "nzLg", "nzXl", "nzXXl"], exportAs: ["nzCol"] }, { kind: "directive", type: i12.NzRowDirective, selector: "[nz-row],nz-row,nz-form-item", inputs: ["nzAlign", "nzJustify", "nzGutter"], exportAs: ["nzRow"] }, { kind: "component", type: i13.NzFormItemComponent, selector: "nz-form-item", exportAs: ["nzFormItem"] }, { kind: "component", type: i13.NzFormLabelComponent, selector: "nz-form-label", inputs: ["nzFor", "nzRequired", "nzNoColon", "nzTooltipTitle", "nzTooltipIcon", "nzLabelAlign", "nzLabelWrap"], exportAs: ["nzFormLabel"] }, { kind: "component", type: i13.NzFormControlComponent, selector: "nz-form-control", inputs: ["nzSuccessTip", "nzWarningTip", "nzErrorTip", "nzValidatingTip", "nzExtra", "nzAutoTips", "nzDisableAutoTips", "nzHasFeedback", "nzValidateStatus"], exportAs: ["nzFormControl"] }, { kind: "component", type: i14.NzOptionComponent, selector: "nz-option", inputs: ["nzTitle", "nzLabel", "nzValue", "nzKey", "nzDisabled", "nzHide", "nzCustomContent"], exportAs: ["nzOption"] }, { kind: "component", type: i14.NzSelectComponent, selector: "nz-select", inputs: ["nzId", "nzSize", "nzStatus", "nzOptionHeightPx", "nzOptionOverflowSize", "nzDropdownClassName", "nzDropdownMatchSelectWidth", "nzDropdownStyle", "nzNotFoundContent", "nzPlaceHolder", "nzPlacement", "nzMaxTagCount", "nzDropdownRender", "nzCustomTemplate", "nzSuffixIcon", "nzClearIcon", "nzRemoveIcon", "nzMenuItemSelectedIcon", "nzTokenSeparators", "nzMaxTagPlaceholder", "nzMaxMultipleCount", "nzMode", "nzFilterOption", "compareWith", "nzAllowClear", "nzBorderless", "nzShowSearch", "nzLoading", "nzAutoFocus", "nzAutoClearSearchValue", "nzServerSearch", "nzDisabled", "nzOpen", "nzSelectOnTab", "nzBackdrop", "nzOptions", "nzShowArrow"], outputs: ["nzOnSearch", "nzScrollToBottom", "nzOpenChange", "nzBlur", "nzFocus"], exportAs: ["nzSelect"] }, { kind: "component", type: i15.NzTreeSelectComponent, selector: "nz-tree-select", inputs: ["nzId", "nzAllowClear", "nzShowExpand", "nzShowLine", "nzDropdownMatchSelectWidth", "nzCheckable", "nzHideUnMatched", "nzShowIcon", "nzShowSearch", "nzDisabled", "nzAsyncData", "nzMultiple", "nzDefaultExpandAll", "nzCheckStrictly", "nzVirtualItemSize", "nzVirtualMaxBufferPx", "nzVirtualMinBufferPx", "nzVirtualHeight", "nzExpandedIcon", "nzNotFoundContent", "nzNodes", "nzOpen", "nzSize", "nzPlaceHolder", "nzDropdownStyle", "nzDropdownClassName", "nzBackdrop", "nzStatus", "nzPlacement", "nzExpandedKeys", "nzDisplayWith", "nzMaxTagCount", "nzMaxTagPlaceholder", "nzTreeTemplate"], outputs: ["nzOpenChange", "nzCleared", "nzRemoved", "nzExpandChange", "nzTreeClick", "nzTreeCheckBoxChange"], exportAs: ["nzTreeSelect"] }, { kind: "directive", type: i16.NzPopoverDirective, selector: "[nz-popover]", inputs: ["nzPopoverArrowPointAtCenter", "nzPopoverTitle", "nzPopoverContent", "nz-popover", "nzPopoverTrigger", "nzPopoverPlacement", "nzPopoverOrigin", "nzPopoverVisible", "nzPopoverMouseEnterDelay", "nzPopoverMouseLeaveDelay", "nzPopoverOverlayClassName", "nzPopoverOverlayStyle", "nzPopoverBackdrop"], outputs: ["nzPopoverVisibleChange"], exportAs: ["nzPopover"] }, { kind: "component", type: i17.DatePickerComponent, selector: "qeydar-date-picker", inputs: ["rtl", "mode", "isRange", "customLabels", "calendarType", "lang", "cssClass", "footerDescription", "rangeInputLabels", "inputLabel", "placement", "disabled", "isInline", "showSidebar", "showToday", "valueFormat", "disableInputMask", "disabledDates", "disabledDatesFilter", "disabledTimesFilter", "allowEmpty", "readOnly", "readOnlyInput", "minDate", "maxDate", "format"], outputs: ["onFocus", "onBlur", "onChangeValue", "onOpenChange"] }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }] }); }
|
|
583
907
|
}
|
|
584
908
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: GridComponent, decorators: [{
|
|
585
909
|
type: Component,
|
|
586
|
-
args: [{ selector: 'app-grid', template: "<!-- <button (click)=\"enableAdvancedFilter=!enableAdvancedFilter\">advanced</button> -->\n<div
|
|
587
|
-
}], ctorParameters: () => [{ type: i1.TranslateService }], propDecorators: { onAction: [{
|
|
910
|
+
args: [{ selector: 'app-grid', template: "<!-- <button (click)=\"enableAdvancedFilter=!enableAdvancedFilter\">advanced</button> -->\n<div class=\"flex justify-between items-center py-4 border-b border-b-slate-200 mx-4\" *ngIf=\"isToolbar\">\n <div>\n <h4 class=\"font-semibold text-2xl\">{{ label }}</h4>\n </div>\n <div class=\"flex gap-3\">\n @for (item of toolbarItems; track $index) {\n <button nz-button [nzLoading]=\"item.loading ? item.loading : false\" (click)=\"handleClick(item)\" [nzType]=\"item.type\">\n <span nz-icon [nzType]=\"item.icon\"></span>\n {{ item.text }}\n </button>\n }\n <button\n nz-button\n nzType=\"default\"\n nz-popover\n nzPopoverTitle=\"\"\n [(nzPopoverVisible)]=\"visibleFilterBox\"\n nzPopoverTrigger=\"click\"\n [nzPopoverContent]=\"contentTemplate\"\n nzPopoverOverlayClassName=\"filter-popover\"\n nzPopoverPlacement=\"bottom\"\n *ngIf=\"_filterBoxItems.length > 0\">\n <span nz-icon nzType=\"filter\"></span>\n \u0641\u06CC\u0644\u062A\u0631\n </button>\n <button\n nz-button\n nzType=\"default\"\n class=\"flex items-center\"\n nz-popover\n nzPopoverTitle=\"\"\n [(nzPopoverVisible)]=\"visibleFilterTemplateBox\"\n nzPopoverTrigger=\"click\"\n [nzPopoverContent]=\"contentFilterTemplate\"\n nzPopoverOverlayClassName=\"filter-popover-sm\"\n nzPopoverPlacement=\"bottom\"\n *ngIf=\"id != null\">\n <span nz-icon nzType=\"layout\"></span>\n \u0641\u06CC\u0644\u062A\u0631 \u0647\u0627\u06CC \u0630\u062E\u06CC\u0631\u0647 \u0634\u062F\u0647\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<ng-template #contentTemplate class=\"w-full\">\n <div class=\"grid gap-x-4 pt-4\" [ngClass]=\"{ 'grid-cols-1': _filterBoxItems.length == 1, 'grid-cols-2': _filterBoxItems.length > 1 }\">\n <div *ngFor=\"let item of _filterBoxItems\" [ngClass]=\"{ 'col-span-2': item.type == 'date' || item.type == 'date-time' }\">\n <div *ngIf=\"item.type == 'date' || item.type == 'date-time'\" class=\"grid grid-cols-2 gap-x-4\">\n <nz-form-item>\n <nz-form-label>\u0627\u0632 \u062A\u0627\u0631\u06CC\u062E</nz-form-label>\n <nz-form-control>\n <qeydar-date-picker\n [ngModel]=\"item.value != null ? item.value[0] : null\"\n (onChangeValue)=\"changeDatePickerValue($event, item, 0)\"\n [showToday]=\"true\"\n [allowEmpty]=\"true\"\n [calendarType]=\"'jalali'\"\n format=\"yyyy-MM-dd\"\n [rtl]=\"true\"></qeydar-date-picker>\n </nz-form-control>\n </nz-form-item>\n <nz-form-item>\n <nz-form-label>\u062A\u0627 \u062A\u0627\u0631\u06CC\u062E</nz-form-label>\n <nz-form-control>\n <qeydar-date-picker\n [ngModel]=\"item.value != null ? item.value[1] : null\"\n (onChangeValue)=\"changeDatePickerValue($event, item, 1)\"\n [showToday]=\"true\"\n [allowEmpty]=\"true\"\n [calendarType]=\"'jalali'\"\n format=\"yyyy-MM-dd\"\n [rtl]=\"true\"></qeydar-date-picker>\n </nz-form-control>\n </nz-form-item>\n </div>\n <div *ngIf=\"item.type == 'enum' || item.type == 'select' || item.type == 'boolean'\">\n <nz-form-item class=\"w-full\">\n <nz-form-label>{{ item.label }}</nz-form-label>\n <nz-select class=\"w-full\" [(ngModel)]=\"item.value\" nzShowSearch>\n <nz-option *ngFor=\"let item2 of item.items\" [nzValue]=\"item2.value\" [nzLabel]=\"item2.label\"></nz-option>\n </nz-select>\n </nz-form-item>\n </div>\n <div *ngIf=\"item.type == 'tree-select'\">\n <nz-form-item class=\"w-full\">\n <nz-form-label>{{ item.label }}</nz-form-label>\n <nz-tree-select class=\"w-full\" [nzNodes]=\"item.nodes\" nzShowSearch [(ngModel)]=\"item.value\"></nz-tree-select>\n </nz-form-item>\n </div>\n <div *ngIf=\"item.type == 'string' || item.type == null\">\n <nz-form-item class=\"w-full\">\n <nz-form-label>{{ item.label }}</nz-form-label>\n <input type=\"text\" nz-input [(ngModel)]=\"item.value\" />\n </nz-form-item>\n </div>\n </div>\n </div>\n <div class=\"flex gap-2 pt-4 mt-4 border-t border-t-slate-200\">\n <button nz-button nzType=\"primary\" (click)=\"filter()\">\u0627\u0639\u0645\u0627\u0644</button>\n <button nz-button nzType=\"default\" (click)=\"clearFilter()\">\u067E\u0627\u06A9\u0633\u0627\u0632\u06CC \u0648 \u0628\u0633\u062A\u0646</button>\n </div>\n</ng-template>\n<!-- template items box -->\n<ng-template #contentFilterTemplate class=\"w-full\">\n <ul class=\"flex flex-col gap-2 max-h-[300px]\">\n <li class=\"p-2 rounded-lg cursor-pointer border border-slate-200\" *ngFor=\"let item of filterTemplateItems\" (click)=\"setTemplateFilter(item)\">{{ item.title }}</li>\n </ul>\n</ng-template>\n<div class=\"flex items-center justify-between gap-2 px-4 py-2 h-14\" *ngIf=\"isToolbar\">\n <div class=\"flex items-center gap-2\">\n <span class=\"font-medium text-sm text-blue-500\">\u0641\u06CC\u0644\u062A\u0631\u0647\u0627\u06CC \u0627\u0639\u0645\u0627\u0644 \u0634\u062F\u0647:</span>\n <ul class=\"flex items-center gap-2\">\n <li class=\"bg-white border border-slate-200 rounded-md px-2 py-1 flex items-center gap-1 h-8\" *ngIf=\"filterItemsValues.length == 0\">\n <span class=\"text-slate-800 font-medium text-sm\">\u0628\u062F\u0648\u0646 \u0641\u06CC\u0644\u062A\u0631</span>\n </li>\n <li class=\"bg-white border border-slate-200 rounded-md px-2 py-1 flex items-center gap-1 h-8\" *ngFor=\"let item of filterItemsValues\">\n <label class=\"text-slate-500 text-sm\">{{ item.label }}:</label>\n <span class=\"text-slate-800 font-medium text-sm\">{{ item.value | translate }}</span>\n <i class=\"fa-regular fa-times cursor-pointer ps-2\" (click)=\"removeFilter(item)\"></i>\n </li>\n </ul>\n </div>\n <div class=\"flex items-center gap-2\" *ngIf=\"id != null\">\n <button nz-button nzType=\"default\" *ngIf=\"filterItemsValues.length > 0 || gridId != null\" (click)=\"saveFilterGrid()\">\n {{ gridId == null ? '\u0630\u062E\u06CC\u0631\u0647 \u0641\u06CC\u0644\u062A\u0631' : '\u0627\u0639\u0645\u0627\u0644 \u062A\u063A\u06CC\u06CC\u0631\u0627\u062A \u0641\u06CC\u0644\u062A\u0631' }}\n </button>\n <button nz-button nzType=\"default\" *ngIf=\"gridId != null\" (click)=\"clearFilter(); gridId = null\">\u0644\u063A\u0648</button>\n </div>\n</div>\n\n<nz-modal [(nzVisible)]=\"isVisibleModal\" nzTitle=\"\u0627\u0641\u0632\u0648\u062F\u0646 \u0642\u0627\u0644\u0628 \u062C\u062F\u06CC\u062F\" (nzOnCancel)=\"handleCancelModal()\" (nzOnOk)=\"handleOkModal()\">\n <ng-container *nzModalContent>\n <nz-form-item class=\"w-full\">\n <nz-form-label>\u0639\u0646\u0648\u0627\u0646 \u0642\u0627\u0644\u0628</nz-form-label>\n <input type=\"text\" nz-input [(ngModel)]=\"templateName\" />\n </nz-form-item>\n </ng-container>\n</nz-modal>\n\n<ag-grid-angular\n style=\"width: 100%\"\n [style]=\"isToolbar ? 'height: calc(100% - 1rem - 124px);' : 'height: 100%;'\"\n [columnDefs]=\"columnDefs\"\n [pagination]=\"true\"\n [paginationPageSize]=\"paginationPageSize\"\n [paginationPageSizeSelector]=\"paginationPageSizeSelector\"\n [class]=\"themeClass\"\n [rowHeight]=\"48\"\n [defaultColDef]=\"defaultColDef\"\n [enableAdvancedFilter]=\"enableAdvancedFilter\"\n [enableRtl]=\"rtl\"\n [treeData]=\"treeModel\"\n [autoGroupColumnDef]=\"autoGroupColumnDef\"\n [isServerSideGroup]=\"isServerSideGroup\"\n [getServerSideGroupKey]=\"getServerSideGroupKey\"\n [rowModelType]=\"rowModelType\"\n [rowData]=\"rowData\"\n [serverSideDatasource]=\"datasource\"\n (gridReady)=\"onGridReady($event)\"\n [cacheBlockSize]=\"paginationPageSize\"\n [maxBlocksInCache]=\"2\"\n [context]=\"{ actionItems: actionItems }\"\n (cellDoubleClicked)=\"cellDoubleClicked($event)\"\n [autoSizeStrategy]=\"_autoColumnSize\"\n [rowSelection]=\"_rowSelection\"\n (selectionChanged)=\"selectionChanged($event)\"\n [theme]=\"\"\n [getRowClass]=\"getRowClass\"\n #grid />\n" }]
|
|
911
|
+
}], ctorParameters: () => [{ type: i1.TranslateService }, { type: i0.ChangeDetectorRef }, { type: i2.ToastService }], propDecorators: { onAction: [{
|
|
588
912
|
type: Output
|
|
589
913
|
}], onToolbar: [{
|
|
590
914
|
type: Output
|
|
@@ -596,6 +920,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
596
920
|
type: Input
|
|
597
921
|
}], label: [{
|
|
598
922
|
type: Input
|
|
923
|
+
}], id: [{
|
|
924
|
+
type: Input
|
|
599
925
|
}], isRowSelection: [{
|
|
600
926
|
type: Input
|
|
601
927
|
}], rowModelType: [{
|
|
@@ -630,9 +956,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
630
956
|
type: Input
|
|
631
957
|
}], treeGroupColumn: [{
|
|
632
958
|
type: Input
|
|
959
|
+
}], filterItems: [{
|
|
960
|
+
type: Input
|
|
633
961
|
}], fetchData: [{
|
|
634
962
|
type: Input
|
|
635
963
|
}], column: [{
|
|
636
964
|
type: Input
|
|
637
965
|
}] } });
|
|
638
|
-
//# 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, IServerSideGroupSelectionState, RowModelType, RowSelectionOptions, SelectionChangedEvent, SetFilterValuesFuncParams, SizeColumnsToContentStrategy, SizeColumnsToFitGridStrategy, SizeColumnsToFitProvidedWidthStrategy } 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, SortModel, 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    _rowSelection: RowSelectionOptions = {\n        mode: 'singleRow',\n        checkboxes: false\n    };\n    datasource: IServerSideDatasource;\n    themeClass: string = \"ag-theme-quartz\";\n    columnDefs: ColDef[] = [];\n    _column: ColumnItems[] = [];\n    _autoColumnSize: SizeColumnsToFitGridStrategy | SizeColumnsToFitProvidedWidthStrategy | SizeColumnsToContentStrategy = { type: 'fitGridWidth' };\n    autoGroupColumnDef: ColDef = {\n        headerName: \"\",\n        minWidth: 250,\n        sortable: false,\n        cellRendererParams: {\n            suppressCount: true,\n        },\n        filterParams: {\n            maxNumConditions: 1\n        }\n    };\n\n    defaultColDef: ColDef = {\n        flex: 1,\n        minWidth: 150,\n        filter: 'agTextColumnFilter',\n        suppressHeaderMenuButton: true,\n        suppressHeaderContextMenu: true,\n        suppressSizeToFit: true\n    };\n\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    @Output()\n    rowSelectionChange: EventEmitter<any> = new EventEmitter();\n\n    @Input()\n    actionWidth: number = 100;\n\n    @Input()\n    label: string = null;\n\n    @Input()\n    public set isRowSelection(v: boolean) {\n        if (v) {\n            this._rowSelection = {\n                mode: 'multiRow',\n                checkboxes: true\n            }\n        }\n    }\n\n    selectionChanged(e: SelectionChangedEvent) {\n        const items = [];\n        e.api.forEachNode((el) => {\n            if (el.isSelected()) {\n                items.push(el.data);\n            }\n        });\n        this.rowSelectionChange.emit(items);\n    }\n\n    public selectAll() {\n        this.gridApi.selectAll();\n    }\n\n    public deselectAll() {\n        this.gridApi.deselectAll();\n    }\n\n    @Input()\n    rowModelType: RowModelType = 'serverSide';\n\n    @Input()\n    serverSideSort: boolean = true;\n\n    @Input()\n    serverSideFilter: boolean = true;\n\n    @Input()\n    isToolbar: boolean = true;\n\n    @Input()\n    rtl: boolean = true;\n\n    @Input()\n    paginationPageSize = 25;\n\n    @Input()\n    paginationPageSizeSelector: number[] | boolean = [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    rowData: any = null;\n\n    @Input()\n    public get autoColumnSize(): SizeColumnsToFitGridStrategy | SizeColumnsToFitProvidedWidthStrategy | SizeColumnsToContentStrategy {\n        return this._autoColumnSize;\n    }\n    public set autoColumnSize(v: boolean) {\n        if (v) {\n            this._autoColumnSize = { type: 'fitCellContents' };\n        } else {\n            this._autoColumnSize = { type: 'fitGridWidth' };\n        }\n    }\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        this.columnDefs = [];\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                            colId: el.id ? el.id : el.field,\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                            pinned: el.pinned,\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                            colId: el.id ? el.id : el.field,\n                            field: el.field,\n                            headerName: el.label,\n                            filter: filter,\n                            sortable,\n                            editable: el.editable,\n                            pinned: el.pinned,\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                            colId: el.id ? el.id : el.field,\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                            pinned: el.pinned,\n                            cellRenderer: params => {\n                                if (params.value) {\n                                    return new JDatePipe().transform(params.value);\n                                } else {\n                                    return '';\n                                }\n                            }\n                        })\n                    }\n                    else if (el.type && el.type == 'date-time') {\n                        this.columnDefs.push({\n                            colId: el.id ? el.id : el.field,\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                            pinned: el.pinned,\n                            cellRenderer: params => {\n                                if (params.value) {\n                                    return new JDatePipe().transform(params.value, true);\n                                } else {\n                                    return '';\n                                }\n                            }\n                        })\n                    } else if (el.type && el.type == 'price') {\n                        this.columnDefs.push({\n                            colId: el.id ? el.id : el.field,\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                            pinned: el.pinned,\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                            colId: el.id ? el.id : el.field,\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                            pinned: el.pinned,\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                            colId: el.id ? el.id : el.field,\n                            field: el.field,\n                            headerName: el.label,\n                            filter,\n                            sortable,\n                            editable: el.editable,\n                            filterParams,\n                            pinned: el.pinned,\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: this.actionWidth,\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        console.log(e);\n        this.onClicked.emit({ ...e.data, colId: e.column.getColId() });\n    }\n\n    handleClick(item: ToolbarItems) {\n        this.onToolbar.emit(item);\n    }\n\n    public refresh(purge = false) {\n        if (this.rowModelType == 'serverSide') {\n            this.gridApi.refreshServerSide({ purge })\n        } else {\n            this.rowData = [];\n            this.gridApi.refreshCells();\n            this.gridApi.setGridOption('columnDefs', this.columnDefs);\n            this.gridApi.setGridOption('loading', true);\n            this.fetchData(null, null).then(data => {\n                this.rowData = data.items;\n                this.gridApi.setGridOption('loading', false);\n            });\n        }\n    }\n\n    onGridReady(params: any) {\n        this.gridApi = params.api;\n        if (this.rowModelType == 'clientSide') {\n            this.fetchData(null, null).then(data => {\n                this.rowData = data.items;\n            }).catch(() => {\n                params.fail();\n            });\n        }\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    clearFilter() {\n        this.gridApi.setFilterModel(null);\n        this.refresh();\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                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                            if (params.request.filterModel[key].dateFrom && 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.between,\n                                    truncateDate: true,\n                                    value: [params.request.filterModel[key].dateFrom, params.request.filterModel[key].dateTo]\n                                });\n                            } else if (params.request.filterModel[key].dateFrom) {\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: params.request.filterModel[key].dateFrom,\n                                });\n                            } else if (params.request.filterModel[key].dateTo && 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: params.request.filterModel[key].dateTo,\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                let sorts: SortModel[] = [];\n                if (params.request.sortModel.length) {\n                    const findEl = this._column.find((el) => el.field == params.request.sortModel[0].colId);\n                    if (findEl.searchField != null) {\n                        sorts = [{\n                            dir: params.request.sortModel[0].sort,\n                            field: findEl.searchField\n                        }];\n                    } else {\n                        sorts = [{\n                            dir: params.request.sortModel[0].sort,\n                            field: params.request.sortModel[0].colId\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\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                    if (this.rowModelType == 'serverSide' && this.gridApi.getServerSideSelectionState()['selectAll']) {\n                        this.selectAll();\n                    }\n                }).catch(() => {\n                    params.fail();\n                });\n            }\n        };\n    }\n\n    ngOnInit(): void { }\n}","<!-- <button (click)=\"enableAdvancedFilter=!enableAdvancedFilter\">advanced</button> -->\n<div\n  class=\"flex justify-between items-center mb-4 pb-4 border-b border-b-slate-200\"\n  *ngIf=\"isToolbar\"\n>\n  <div>\n    <h4 class=\"font-semibold text-2xl\">{{ label }}</h4>\n  </div>\n  <div class=\"flex gap-3\">\n    @for (item of toolbarItems; track $index) {\n    <button\n      nz-button\n      [nzLoading]=\"item.loading ? item.loading : false\"\n      (click)=\"handleClick(item)\"\n      [nzType]=\"item.type\"\n    >\n      <span nz-icon [nzType]=\"item.icon\"></span>\n      {{ item.text }}\n    </button>\n    }\n    <button nz-button (click)=\"refresh()\" nzType=\"default\">\n      <span nz-icon nzType=\"sync\"></span>\n      بروزرسانی\n    </button>\n    <button nz-button (click)=\"clearFilter()\" nzType=\"default\">\n      <span nz-icon nzType=\"clear\"></span>\n      پاکسازی\n    </button>\n\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<div>\n  <ng-content></ng-content>\n</div>\n<ag-grid-angular\n  style=\"width: 100%\"\n  [style]=\"isToolbar ? 'height: calc(100% - 1rem - 48px);' : 'height: 100%;'\"\n  [columnDefs]=\"columnDefs\"\n  [pagination]=\"true\"\n  [paginationPageSize]=\"paginationPageSize\"\n  [paginationPageSizeSelector]=\"paginationPageSizeSelector\"\n  [class]=\"themeClass\"\n  [defaultColDef]=\"defaultColDef\"\n  [enableAdvancedFilter]=\"enableAdvancedFilter\"\n  [enableRtl]=\"rtl\"\n  [treeData]=\"treeModel\"\n  [autoGroupColumnDef]=\"autoGroupColumnDef\"\n  [isServerSideGroup]=\"isServerSideGroup\"\n  [getServerSideGroupKey]=\"getServerSideGroupKey\"\n  [rowModelType]=\"rowModelType\"\n  [rowData]=\"rowData\"\n  [serverSideDatasource]=\"datasource\"\n  (gridReady)=\"onGridReady($event)\"\n  [cacheBlockSize]=\"paginationPageSize\"\n  [maxBlocksInCache]=\"2\"\n  [context]=\"{ actionItems: actionItems }\"\n  (cellDoubleClicked)=\"cellDoubleClicked($event)\"\n  [autoSizeStrategy]=\"_autoColumnSize\"\n  [rowSelection]=\"_rowSelection\"\n  (selectionChanged)=\"selectionChanged($event)\"\n  #grid\n/>\n"]}
|
|
966
|
+
//# 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, IDateFilterParams, IRowNode, IServerSideDatasource, IServerSideGetRowsParams, RowModelType, RowSelectionOptions, SelectionChangedEvent, SizeColumnsToContentStrategy, SizeColumnsToFitGridStrategy, SizeColumnsToFitProvidedWidthStrategy } from '@ag-grid-community/core';\nimport { ChangeDetectorRef, Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { TranslateService } from '@ngx-translate/core';\nimport { ActionItems, ColumnItems, DatasourceOutputModel, FilterBoxItemsModel, FilterBoxModel, FilterGridItemsModel, FilterItemsModel, FilterItemsValuesModel, FilterOperator, FilterTemplateModel, GridActionOutput, GridInputModel, GridRequestParam, SortModel, ToolbarItems } from '../../models/shared.model';\nimport { JDatePipe } from '../../pipes/date.pipe';\nimport { ActionsCellRenderer } from '../index.api';\nimport { DateFilter, TimeFilter } from './filter/index.api';\nimport { NzTreeNodeOptions } from 'ng-zorro-antd/tree';\nimport { ToastService } from '../../services/index.api';\nimport { db } from '../../db';\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        private _cdr: ChangeDetectorRef,\n        private _toast: ToastService\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    _rowSelection: RowSelectionOptions = {\n        mode: 'singleRow',\n        checkboxes: false\n    };\n    datasource: IServerSideDatasource;\n    themeClass: string = \"ag-theme-quartz\";\n    columnDefs: ColDef[] = [];\n    visibleFilterBox: boolean = false;\n    _column: ColumnItems[] = [];\n    _filterBoxItems: FilterBoxModel[] = [];\n    filterItemsValues: FilterItemsValuesModel[] = [];\n    filterTemplateItems: FilterTemplateModel[] = [];\n    visibleFilterTemplateBox: boolean = false;\n    isVisibleModal: boolean = false;\n    gridModel: GridInputModel = null;\n    templateName: string = null;\n    gridId: string = null;\n\n    _autoColumnSize: SizeColumnsToFitGridStrategy | SizeColumnsToFitProvidedWidthStrategy | SizeColumnsToContentStrategy = { type: 'fitGridWidth' };\n    autoGroupColumnDef: ColDef = {\n        headerName: \"\",\n        minWidth: 250,\n        sortable: false,\n        cellRendererParams: {\n            suppressCount: true,\n        },\n        filterParams: {\n            maxNumConditions: 1\n        }\n    };\n\n    defaultColDef: ColDef = {\n        flex: 1,\n        minWidth: 150,\n        filter: 'agTextColumnFilter',\n        suppressHeaderMenuButton: true,\n        suppressHeaderContextMenu: true,\n        suppressSizeToFit: true\n    };\n\n    getRowClass(params) {\n        if (params.node.rowIndex % 2 !== 0) {\n            return 'row-odd'\n        }\n        return '';\n    }\n\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    @Output()\n    rowSelectionChange: EventEmitter<any> = new EventEmitter();\n\n    @Input()\n    actionWidth: number = 100;\n\n    @Input()\n    label: string = null;\n\n    @Input()\n    id: string = null;\n\n    @Input()\n    public set isRowSelection(v: boolean) {\n        if (v) {\n            this._rowSelection = {\n                mode: 'multiRow',\n                checkboxes: true\n            }\n        }\n    }\n\n    selectionChanged(e: SelectionChangedEvent) {\n        const items = [];\n        e.api.forEachNode((el) => {\n            if (el.isSelected()) {\n                items.push(el.data);\n            }\n        });\n        this.rowSelectionChange.emit(items);\n    }\n\n    public selectAll() {\n        this.gridApi.selectAll();\n    }\n\n    public deselectAll() {\n        this.gridApi.deselectAll();\n    }\n\n    @Input()\n    rowModelType: RowModelType = 'serverSide';\n\n    @Input()\n    serverSideSort: boolean = true;\n\n    @Input()\n    serverSideFilter: boolean = true;\n\n    @Input()\n    isToolbar: boolean = true;\n\n    @Input()\n    rtl: boolean = true;\n\n    @Input()\n    paginationPageSize = 25;\n\n    @Input()\n    paginationPageSizeSelector: number[] | boolean = [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    rowData: any = null;\n\n    @Input()\n    public get autoColumnSize(): SizeColumnsToFitGridStrategy | SizeColumnsToFitProvidedWidthStrategy | SizeColumnsToContentStrategy {\n        return this._autoColumnSize;\n    }\n    public set autoColumnSize(v: boolean) {\n        if (v) {\n            this._autoColumnSize = { type: 'fitCellContents' };\n        } else {\n            this._autoColumnSize = { type: 'fitGridWidth' };\n        }\n    }\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    public set filterItems(v: FilterItemsModel[]) {\n        if (v != null && v.length > 0) {\n            v.forEach((el) => {\n                if (!this._filterBoxItems.find((item) => item.field == el.field)) {\n                    let items = [];\n                    if ((el.type == 'enum' || el.type == 'select' || el.type == 'tree-select') && el.items != null) {\n                        el.items?.().then((res) => {\n                            let nodes: NzTreeNodeOptions[] = [];\n                            if (el.type == 'tree-select') {\n                                const convertToNzTreeNodes = (items: FilterBoxItemsModel[]): NzTreeNodeOptions[] => {\n                                    return items.map(item => ({\n                                        title: item.label,\n                                        key: String(item.value),\n                                        isLeaf: item.children && item.children.length > 0 ? false : true,\n                                        children: item.children ? convertToNzTreeNodes(item.children) : [],\n                                    }));\n                                }\n                                nodes = convertToNzTreeNodes(res);\n                            }\n                            this._filterBoxItems.push({\n                                field: el.field,\n                                label: el.label,\n                                value: null,\n                                items: res,\n                                type: el.type,\n                                position: el.position ? el.position : 'filter',\n                                nodes\n                            });\n                        });\n                    } else if (el.type == 'boolean') {\n                        items.push({\n                            label: this._translate.instant(\"true\"),\n                            value: true\n                        }, {\n                            label: this._translate.instant(\"false\"),\n                            value: false\n                        });\n                        this._filterBoxItems.push({\n                            field: el.field,\n                            label: el.label,\n                            value: null,\n                            items,\n                            type: el.type,\n                            position: el.position ? el.position : 'filter',\n                            nodes: []\n                        });\n                    } else {\n                        this._filterBoxItems.push({\n                            field: el.field,\n                            label: el.label,\n                            value: null,\n                            items,\n                            type: el.type,\n                            position: el.position ? el.position : 'filter',\n                            nodes: []\n                        });\n                    }\n\n                }\n            })\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        setTimeout(() => {\n            this.columnDefs = [];\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 (this._filterBoxItems.find((item) => item.field == el.field || item.field == el.searchField)) {\n                        filter = false;\n                    }\n                    if (el.filter != undefined && (el.filter == 'filter-box' || el.filter == 'none')) {\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                                colId: el.id ? el.id : el.field,\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                                pinned: el.pinned,\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                                colId: el.id ? el.id : el.field,\n                                field: el.field,\n                                headerName: el.label,\n                                filter: filter,\n                                sortable,\n                                editable: el.editable,\n                                pinned: el.pinned,\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                                colId: el.id ? el.id : el.field,\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                                pinned: el.pinned,\n                                cellRenderer: params => {\n                                    if (params.value) {\n                                        return new JDatePipe().transform(params.value);\n                                    } else {\n                                        return '';\n                                    }\n                                }\n                            })\n                        }\n                        else if (el.type && el.type == 'time') {\n                            this.columnDefs.push({\n                                colId: el.id ? el.id : el.field,\n                                field: el.field,\n                                headerName: el.label,\n                                filter: TimeFilter,\n                                sortable,\n                                editable: el.editable,\n                                minWidth: el.minWidth ? el.minWidth : null,\n                                filterParams,\n                                pinned: el.pinned,\n                                cellRenderer: params => {\n                                    if (params.value) {\n                                        return params.value;\n                                    } else {\n                                        return '';\n                                    }\n                                }\n                            })\n                        }\n                        else if (el.type && el.type == 'date-time') {\n                            this.columnDefs.push({\n                                colId: el.id ? el.id : el.field,\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                                pinned: el.pinned,\n                                cellRenderer: params => {\n                                    if (params.value) {\n                                        return new JDatePipe().transform(params.value, true);\n                                    } else {\n                                        return '';\n                                    }\n                                }\n                            })\n                        } else if (el.type && el.type == 'price') {\n                            this.columnDefs.push({\n                                colId: el.id ? el.id : el.field,\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                                pinned: el.pinned,\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                                colId: el.id ? el.id : el.field,\n                                field: el.field,\n                                headerName: el.label,\n                                minWidth: 80,\n                                width: 80,\n                                filter: 'none',\n                                sortable: false,\n                                editable: false,\n                                filterParams,\n                                pinned: el.pinned,\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                                colId: el.id ? el.id : el.field,\n                                field: el.field,\n                                headerName: el.label,\n                                filter,\n                                sortable,\n                                editable: el.editable,\n                                filterParams,\n                                pinned: el.pinned,\n                                minWidth: el.minWidth ? el.minWidth : null\n                            })\n                        }\n                    } else {\n                        this.autoGroupColumnDef.field = el.field;\n                    }\n                });\n                this._column.filter((el) => el.filter == 'filter-box').forEach((el) => {\n                    let items = [];\n                    if (el.filterItems != null) {\n                        switch (el.type) {\n                            case 'enum':\n                                Object.keys(el.filterItems).forEach((item) => {\n                                    items.push({\n                                        label: this._translate.instant(el.filterItems[item]),\n                                        value: el.filterItems[item]\n                                    })\n                                });\n                                break;\n                            case 'boolean':\n                                Object.keys(el.filterItems).forEach((item) => {\n                                    items.push({\n                                        label: this._translate.instant(\"true\"),\n                                        value: true\n                                    }, {\n                                        label: this._translate.instant(\"false\"),\n                                        value: false\n                                    })\n                                });\n                                break;\n                        }\n                    }\n                    this._filterBoxItems.push({\n                        label: el.label,\n                        value: null,\n                        items,\n                        type: el.type,\n                        field: el.field,\n                        position: 'filter',\n                        nodes: []\n                    })\n                });\n                if (this.actionItems.length > 0) {\n                    this.columnDefs.push({\n                        filter: false,\n                        headerName: '',\n                        minWidth: this.actionWidth,\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        }, 100);\n    }\n\n    changeDatePickerValue(e, item: FilterBoxModel, index) {\n        if (item.value != null) {\n            item.value[index] = e;\n        } else {\n            item.value = [null, null];\n            item.value[index] = e;\n        }\n    }\n\n    cellDoubleClicked(e: CellDoubleClickedEvent) {\n        this.onClicked.emit({ ...e.data, colId: e.column.getColId() });\n    }\n\n    handleClick(item: ToolbarItems) {\n        this.onToolbar.emit(item);\n    }\n\n    saveFilterGrid() {\n        if (this.id == null) {\n            this._toast.show('شناسه ی جدول وارد نشده است', 'error');\n            return\n        }\n        if (this.gridId == null) {\n            this.isVisibleModal = true;\n            this._cdr.detectChanges();\n        } else {\n            db.gridFilterItems.get(this.gridId).then((res) => {\n                db.gridFilterItems.put({\n                    ...res,\n                    grid: this.gridModel,\n                });\n                this.fetchTemplate();\n                this._toast.show('قالب با موفقیت بروزرسانی شد', 'success');\n            })\n        }\n\n    }\n\n    handleCancelModal() {\n        this.isVisibleModal = false;\n        this._cdr.detectChanges();\n    }\n\n    handleOkModal() {\n        if (this.templateName == null) {\n            this._toast.show('عنوان قالب وارد نشده است', 'error');\n            return\n        }\n        this.gridId = new Date().getTime().toString();\n        db.gridFilterItems.add({\n            id: this.gridId,\n            grid: this.gridModel,\n            tableId: this.id,\n            title: this.templateName,\n            userName: null\n        });\n        this._toast.show('قالب با موفقیت ذخیره شد', 'success');\n        this.templateName = null;\n        this.isVisibleModal = false;\n        this._cdr.detectChanges();\n        this.fetchTemplate();\n    }\n\n    public refresh(purge = false) {\n        if (this.rowModelType == 'serverSide') {\n            this.gridApi.refreshServerSide({ purge })\n        } else {\n            this.rowData = [];\n            this.gridApi.refreshCells();\n            this.gridApi.setGridOption('columnDefs', this.columnDefs);\n            this.gridApi.setGridOption('loading', true);\n            this.fetchData(null, null).then(data => {\n                this.rowData = data.items;\n                this.gridApi.setGridOption('loading', false);\n            });\n        }\n    }\n\n    onGridReady(params: any) {\n        this.gridApi = params.api;\n        if (this.rowModelType == 'clientSide') {\n            this.fetchData(null, null).then(data => {\n                this.rowData = data.items;\n            }).catch(() => {\n                params.fail();\n            });\n        }\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    clearFilter() {\n        this.visibleFilterBox = false;\n        this._filterBoxItems.forEach((el) => {\n            el.value = null;\n        });\n        this.gridApi.setFilterModel(null);\n        this.gridApi.onFilterChanged();\n        this.filterItemsValues = [];\n        this.refresh();\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    filter() {\n        this.handleFilterLabelValue();\n        this.refresh();\n        this.visibleFilterBox = false;\n    }\n\n    setTemplateFilter(item: FilterTemplateModel) {\n        this.clearFilter();\n        setTimeout(() => {\n            item.grid.filter.filters.forEach((el) => {\n                const findEl = this._column.find((item) => item.field == el.field || item.searchField == el.field);\n                if (findEl && this.columnDefs.find((item) => item.field == findEl.field && item.filter)) {\n                    this.gridApi.setColumnFilterModel(findEl.field, {\n                        type: el.logic,\n                        filter: el.value\n                    });\n                } else {\n                    const index = this._filterBoxItems.findIndex((item) => item.field == el.field);\n                    this._filterBoxItems[index].value = el.value;\n                    this._cdr.detectChanges();\n                }\n            });\n            this.gridId = item.id;\n            this.visibleFilterTemplateBox = false;\n            this._cdr.detectChanges();\n            this.handleFilterLabelValue();\n            this.gridApi.onFilterChanged();\n            this.refresh();\n        }, 100);\n    }\n\n    handleFilterLabelValue() {\n        this._filterBoxItems.forEach((el) => {\n            const findEl = this.filterItemsValues.find((fi) => fi.field == el.field);\n            if (!findEl) {\n                if (el.value != null) {\n                    this.filterItemsValues.push({\n                        field: el.field,\n                        label: el.label,\n                        value: el.value\n                    });\n                    this._cdr.detectChanges();\n                }\n            } else {\n                if (el.value == null || el.value == \"\") {\n                    this.filterItemsValues = this.filterItemsValues.filter((fi) => fi.field != el.field);\n                } else {\n                    findEl.value = el.value;\n                }\n                this._cdr.detectChanges();\n            }\n        });\n    }\n\n    removeFilter(item: FilterItemsValuesModel) {\n        const index = this._filterBoxItems.findIndex((el) => el.field == item.field);\n        if (index >= 0) {\n            this._filterBoxItems[index].value = null;\n        } else {\n            this.gridApi.setColumnFilterModel(item.field, null);\n            this.gridApi.onFilterChanged();\n        }\n        this.filterItemsValues = this.filterItemsValues.filter((el) => el.field != item.field);\n        this._cdr.detectChanges();\n        this.refresh();\n    }\n\n    createServerSideDatasource(): IServerSideDatasource {\n        return {\n            getRows: (params: IServerSideGetRowsParams) => {\n                let filter: FilterGridItemsModel = null;\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                if (Object.keys(params.request.filterModel).length > 0) {\n                    for (const key in params.request.filterModel) {\n                        let field = key == 'ag-Grid-AutoColumn' ? this._treeGroupColumn : key;\n                        let value = null;\n                        let operator = FilterOperator.equals;\n                        let ignoreCase = false;\n                        const findEl = this._column.find((el) => el.field == key);\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 (params.request.filterModel[key].filterType == 'custom-date') {\n                            if (params.request.filterModel[key].dateFrom && params.request.filterModel[key].dateTo) {\n                                operator = FilterOperator.between;\n                                value = [params.request.filterModel[key].dateFrom, params.request.filterModel[key].dateTo];\n                            } else if (params.request.filterModel[key].dateFrom) {\n                                operator = FilterOperator.truncGreaterThanEqual;\n                                value = params.request.filterModel[key].dateFrom;\n                            } else if (params.request.filterModel[key].dateTo && params.request.filterModel[key].dateTo != \"\") {\n                                operator = FilterOperator.truncLessThanOrEqual;\n                                value = params.request.filterModel[key].dateTo;\n                            }\n                        } else if (params.request.filterModel[key].filterType == 'custom-time' && params.request.filterModel[key].time != null) {\n                            operator = FilterOperator.equals;\n                            value = `${params.request.filterModel[key].time.substr(0, 2)}:${params.request.filterModel[key].time.substr(2, 2)}:${params.request.filterModel[key].time.substr(4, 2)}`;\n                        } else {\n                            if (FilterOperator[params.request.filterModel[key].type]) {\n                                operator = FilterOperator[params.request.filterModel[key].type];\n                            }\n                            ignoreCase = true;\n                            value = params.request.filterModel[key].filter ? params.request.filterModel[key].filter : params.request.filterModel[key].type;\n                            if (findEl && findEl.type == 'enum') {\n                                ignoreCase = false;\n                            }\n                        }\n                        const findFilterItemsEl = this.filterItemsValues.find((fi) => fi.field == findEl.field);\n                        if (!findFilterItemsEl) {\n                            this.filterItemsValues.push({\n                                field: findEl.field,\n                                label: findEl.label,\n                                value: value\n                            });\n                        } else {\n                            findFilterItemsEl.value = value;\n                        }\n                        filter.filters.push({\n                            disable: false,\n                            field,\n                            logic: 'AND',\n                            filters: null,\n                            ignoreCase,\n                            operator,\n                            truncateDate: true,\n                            value\n                        });\n                    }\n                    this._cdr.detectChanges();\n                    // this.filterItemsValues = structuredClone(this.filterItemsValues);\n                }\n                let sorts: SortModel[] = [];\n                if (params.request.sortModel.length) {\n                    const findEl = this._column.find((el) => el.field == params.request.sortModel[0].colId);\n                    if (findEl.searchField != null) {\n                        sorts = [{\n                            dir: params.request.sortModel[0].sort,\n                            field: findEl.searchField\n                        }];\n                    } else {\n                        sorts = [{\n                            dir: params.request.sortModel[0].sort,\n                            field: params.request.sortModel[0].colId\n                        }];\n                    }\n                }\n                const gridFilter: GridInputModel = {\n                    take: params.api.paginationGetPageSize(),\n                    data: {},\n                    filter,\n                    skip: params.api.paginationGetCurrentPage() * params.api.paginationGetPageSize(),\n                    sorts\n                };\n                const requestParams: GridRequestParam = {\n                    parentNode: params.parentNode.data\n                };\n                this._filterBoxItems.forEach((el) => {\n                    if (el.value != null) {\n                        if (el.position == 'filter') {\n                            let operator: FilterOperator = null;\n                            switch (el.type) {\n                                case 'string':\n                                    operator = FilterOperator.contains;\n                                    break;\n                                case 'date': case 'date-time':\n                                    operator = FilterOperator.between;\n                                    if (el.value[0] == null) {\n                                        el.value[0] = new Date('1997-01-01').toISOString();\n                                    } else if (el.value[1] == null) {\n                                        el.value[1] = new Date().toISOString();\n                                    }\n                                    break;\n                                default:\n                                    operator = FilterOperator.equals;\n                                    break;\n                            }\n                            gridFilter.filter.filters.push({\n                                disable: false,\n                                field: el.field,\n                                filters: null,\n                                ignoreCase: false,\n                                logic: 'AND',\n                                operator,\n                                truncateDate: false,\n                                value: el.value\n                            });\n                        } else {\n                            gridFilter.data[el.field] = el.value;\n                        }\n                    }\n                });\n                this.gridModel = gridFilter;\n                this.fetchData(gridFilter, requestParams).then(data => {\n                    params.success({\n                        rowData: data.items,\n                        rowCount: data.totalCount,\n                    });\n                    if (this.rowModelType == 'serverSide' && this.gridApi.getServerSideSelectionState()['selectAll']) {\n                        this.selectAll();\n                    }\n                }).catch(() => {\n                    params.fail();\n                });\n            }\n        };\n    }\n\n    fetchTemplate() {\n        if (this.id != null) {\n            db.gridFilterItems.filter((el) => el.tableId == this.id).toArray().then((res) => {\n                this.filterTemplateItems = res;\n            });\n        }\n    }\n\n    ngOnInit(): void {\n        this.fetchTemplate();\n    }\n}","<!-- <button (click)=\"enableAdvancedFilter=!enableAdvancedFilter\">advanced</button> -->\n<div class=\"flex justify-between items-center py-4 border-b border-b-slate-200 mx-4\" *ngIf=\"isToolbar\">\n    <div>\n        <h4 class=\"font-semibold text-2xl\">{{ label }}</h4>\n    </div>\n    <div class=\"flex gap-3\">\n        @for (item of toolbarItems; track $index) {\n        <button nz-button [nzLoading]=\"item.loading ? item.loading : false\" (click)=\"handleClick(item)\" [nzType]=\"item.type\">\n            <span nz-icon [nzType]=\"item.icon\"></span>\n            {{ item.text }}\n        </button>\n        }\n        <button\n            nz-button\n            nzType=\"default\"\n            nz-popover\n            nzPopoverTitle=\"\"\n            [(nzPopoverVisible)]=\"visibleFilterBox\"\n            nzPopoverTrigger=\"click\"\n            [nzPopoverContent]=\"contentTemplate\"\n            nzPopoverOverlayClassName=\"filter-popover\"\n            nzPopoverPlacement=\"bottom\"\n            *ngIf=\"_filterBoxItems.length > 0\">\n            <span nz-icon nzType=\"filter\"></span>\n            فیلتر\n        </button>\n        <button\n            nz-button\n            nzType=\"default\"\n            class=\"flex items-center\"\n            nz-popover\n            nzPopoverTitle=\"\"\n            [(nzPopoverVisible)]=\"visibleFilterTemplateBox\"\n            nzPopoverTrigger=\"click\"\n            [nzPopoverContent]=\"contentFilterTemplate\"\n            nzPopoverOverlayClassName=\"filter-popover-sm\"\n            nzPopoverPlacement=\"bottom\"\n            *ngIf=\"id != null\">\n            <span nz-icon nzType=\"layout\"></span>\n            فیلتر های ذخیره شده\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<ng-template #contentTemplate class=\"w-full\">\n    <div class=\"grid gap-x-4 pt-4\" [ngClass]=\"{ 'grid-cols-1': _filterBoxItems.length == 1, 'grid-cols-2': _filterBoxItems.length > 1 }\">\n        <div *ngFor=\"let item of _filterBoxItems\" [ngClass]=\"{ 'col-span-2': item.type == 'date' || item.type == 'date-time' }\">\n            <div *ngIf=\"item.type == 'date' || item.type == 'date-time'\" class=\"grid grid-cols-2 gap-x-4\">\n                <nz-form-item>\n                    <nz-form-label>از تاریخ</nz-form-label>\n                    <nz-form-control>\n                        <qeydar-date-picker\n                            [ngModel]=\"item.value != null ? item.value[0] : null\"\n                            (onChangeValue)=\"changeDatePickerValue($event, item, 0)\"\n                            [showToday]=\"true\"\n                            [allowEmpty]=\"true\"\n                            [calendarType]=\"'jalali'\"\n                            format=\"yyyy-MM-dd\"\n                            [rtl]=\"true\"></qeydar-date-picker>\n                    </nz-form-control>\n                </nz-form-item>\n                <nz-form-item>\n                    <nz-form-label>تا تاریخ</nz-form-label>\n                    <nz-form-control>\n                        <qeydar-date-picker\n                            [ngModel]=\"item.value != null ? item.value[1] : null\"\n                            (onChangeValue)=\"changeDatePickerValue($event, item, 1)\"\n                            [showToday]=\"true\"\n                            [allowEmpty]=\"true\"\n                            [calendarType]=\"'jalali'\"\n                            format=\"yyyy-MM-dd\"\n                            [rtl]=\"true\"></qeydar-date-picker>\n                    </nz-form-control>\n                </nz-form-item>\n            </div>\n            <div *ngIf=\"item.type == 'enum' || item.type == 'select' || item.type == 'boolean'\">\n                <nz-form-item class=\"w-full\">\n                    <nz-form-label>{{ item.label }}</nz-form-label>\n                    <nz-select class=\"w-full\" [(ngModel)]=\"item.value\" nzShowSearch>\n                        <nz-option *ngFor=\"let item2 of item.items\" [nzValue]=\"item2.value\" [nzLabel]=\"item2.label\"></nz-option>\n                    </nz-select>\n                </nz-form-item>\n            </div>\n            <div *ngIf=\"item.type == 'tree-select'\">\n                <nz-form-item class=\"w-full\">\n                    <nz-form-label>{{ item.label }}</nz-form-label>\n                    <nz-tree-select class=\"w-full\" [nzNodes]=\"item.nodes\" nzShowSearch [(ngModel)]=\"item.value\"></nz-tree-select>\n                </nz-form-item>\n            </div>\n            <div *ngIf=\"item.type == 'string' || item.type == null\">\n                <nz-form-item class=\"w-full\">\n                    <nz-form-label>{{ item.label }}</nz-form-label>\n                    <input type=\"text\" nz-input [(ngModel)]=\"item.value\" />\n                </nz-form-item>\n            </div>\n        </div>\n    </div>\n    <div class=\"flex gap-2 pt-4 mt-4 border-t border-t-slate-200\">\n        <button nz-button nzType=\"primary\" (click)=\"filter()\">اعمال</button>\n        <button nz-button nzType=\"default\" (click)=\"clearFilter()\">پاکسازی و بستن</button>\n    </div>\n</ng-template>\n<!-- template items box  -->\n<ng-template #contentFilterTemplate class=\"w-full\">\n    <ul class=\"flex flex-col gap-2 max-h-[300px]\">\n        <li class=\"p-2 rounded-lg cursor-pointer border border-slate-200\" *ngFor=\"let item of filterTemplateItems\" (click)=\"setTemplateFilter(item)\">{{ item.title }}</li>\n    </ul>\n</ng-template>\n<div class=\"flex items-center justify-between gap-2 px-4 py-2 h-14\" *ngIf=\"isToolbar\">\n    <div class=\"flex items-center gap-2\">\n        <span class=\"font-medium text-sm text-blue-500\">فیلترهای اعمال شده:</span>\n        <ul class=\"flex items-center gap-2\">\n            <li class=\"bg-white border border-slate-200 rounded-md px-2 py-1 flex items-center gap-1 h-8\" *ngIf=\"filterItemsValues.length == 0\">\n                <span class=\"text-slate-800 font-medium text-sm\">بدون فیلتر</span>\n            </li>\n            <li class=\"bg-white border border-slate-200 rounded-md px-2 py-1 flex items-center gap-1 h-8\" *ngFor=\"let item of filterItemsValues\">\n                <label class=\"text-slate-500 text-sm\">{{ item.label }}:</label>\n                <span class=\"text-slate-800 font-medium text-sm\">{{ item.value | translate }}</span>\n                <i class=\"fa-regular fa-times cursor-pointer ps-2\" (click)=\"removeFilter(item)\"></i>\n            </li>\n        </ul>\n    </div>\n    <div class=\"flex items-center gap-2\" *ngIf=\"id != null\">\n        <button nz-button nzType=\"default\" *ngIf=\"filterItemsValues.length > 0 || gridId != null\" (click)=\"saveFilterGrid()\">\n            {{ gridId == null ? 'ذخیره فیلتر' : 'اعمال تغییرات فیلتر' }}\n        </button>\n        <button nz-button nzType=\"default\" *ngIf=\"gridId != null\" (click)=\"clearFilter(); gridId = null\">لغو</button>\n    </div>\n</div>\n\n<nz-modal [(nzVisible)]=\"isVisibleModal\" nzTitle=\"افزودن قالب جدید\" (nzOnCancel)=\"handleCancelModal()\" (nzOnOk)=\"handleOkModal()\">\n    <ng-container *nzModalContent>\n        <nz-form-item class=\"w-full\">\n            <nz-form-label>عنوان قالب</nz-form-label>\n            <input type=\"text\" nz-input [(ngModel)]=\"templateName\" />\n        </nz-form-item>\n    </ng-container>\n</nz-modal>\n\n<ag-grid-angular\n    style=\"width: 100%\"\n    [style]=\"isToolbar ? 'height: calc(100% - 1rem - 124px);' : 'height: 100%;'\"\n    [columnDefs]=\"columnDefs\"\n    [pagination]=\"true\"\n    [paginationPageSize]=\"paginationPageSize\"\n    [paginationPageSizeSelector]=\"paginationPageSizeSelector\"\n    [class]=\"themeClass\"\n    [rowHeight]=\"48\"\n    [defaultColDef]=\"defaultColDef\"\n    [enableAdvancedFilter]=\"enableAdvancedFilter\"\n    [enableRtl]=\"rtl\"\n    [treeData]=\"treeModel\"\n    [autoGroupColumnDef]=\"autoGroupColumnDef\"\n    [isServerSideGroup]=\"isServerSideGroup\"\n    [getServerSideGroupKey]=\"getServerSideGroupKey\"\n    [rowModelType]=\"rowModelType\"\n    [rowData]=\"rowData\"\n    [serverSideDatasource]=\"datasource\"\n    (gridReady)=\"onGridReady($event)\"\n    [cacheBlockSize]=\"paginationPageSize\"\n    [maxBlocksInCache]=\"2\"\n    [context]=\"{ actionItems: actionItems }\"\n    (cellDoubleClicked)=\"cellDoubleClicked($event)\"\n    [autoSizeStrategy]=\"_autoColumnSize\"\n    [rowSelection]=\"_rowSelection\"\n    (selectionChanged)=\"selectionChanged($event)\"\n    [theme]=\"\"\n    [getRowClass]=\"getRowClass\"\n    #grid />\n"]}
|