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