@progress-chef/platform-shared-components 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 +30 -0
- package/assets/IconFont.css +68 -0
- package/assets/IconFont.scss +68 -0
- package/assets/IconFont.ttf +0 -0
- package/assets/IconFont.woff +0 -0
- package/assets/IconFont.woff2 +0 -0
- package/esm2022/lib/atoms/alert/alert.component.mjs +37 -0
- package/esm2022/lib/atoms/alert/alert.module.mjs +20 -0
- package/esm2022/lib/atoms/angular-popup/angular-popup.component.mjs +35 -0
- package/esm2022/lib/atoms/angular-popup/angular-popup.module.mjs +36 -0
- package/esm2022/lib/atoms/atoms.module.mjs +234 -0
- package/esm2022/lib/atoms/avatar/avatar.component.mjs +62 -0
- package/esm2022/lib/atoms/avatar/avatar.module.mjs +20 -0
- package/esm2022/lib/atoms/breadcrumb/breadcrumb.component.mjs +59 -0
- package/esm2022/lib/atoms/breadcrumb/breadcrumb.module.mjs +36 -0
- package/esm2022/lib/atoms/button/button.component.mjs +72 -0
- package/esm2022/lib/atoms/button/button.module.mjs +21 -0
- package/esm2022/lib/atoms/button-group/button-group.component.mjs +52 -0
- package/esm2022/lib/atoms/button-group/button-group.module.mjs +21 -0
- package/esm2022/lib/atoms/checkbox/checkbox.component.mjs +45 -0
- package/esm2022/lib/atoms/checkbox/checkbox.module.mjs +32 -0
- package/esm2022/lib/atoms/clipboard/clipboard.component.mjs +104 -0
- package/esm2022/lib/atoms/clipboard/clipboard.module.mjs +32 -0
- package/esm2022/lib/atoms/container/container.component.mjs +29 -0
- package/esm2022/lib/atoms/container/container.module.mjs +22 -0
- package/esm2022/lib/atoms/dropdown/dropdown.component.mjs +102 -0
- package/esm2022/lib/atoms/dropdown/dropdown.module.mjs +39 -0
- package/esm2022/lib/atoms/dropdowntree/dropdowntree.component.mjs +103 -0
- package/esm2022/lib/atoms/dropdowntree/dropdowntree.module.mjs +43 -0
- package/esm2022/lib/atoms/expansion-panel/expansion-panel.component.mjs +38 -0
- package/esm2022/lib/atoms/expansion-panel/expansion-panel.module.mjs +56 -0
- package/esm2022/lib/atoms/icon/icon.component.mjs +24 -0
- package/esm2022/lib/atoms/icon/icon.module.mjs +17 -0
- package/esm2022/lib/atoms/label/label.component.mjs +26 -0
- package/esm2022/lib/atoms/label/label.module.mjs +20 -0
- package/esm2022/lib/atoms/loading-spinner/loading-spinner.component.mjs +26 -0
- package/esm2022/lib/atoms/loading-spinner/loading-spinner.module.mjs +18 -0
- package/esm2022/lib/atoms/multi-select-dropdown/multi-select-dropdown.component.mjs +101 -0
- package/esm2022/lib/atoms/multi-select-dropdown/multi-select-dropdown.module.mjs +39 -0
- package/esm2022/lib/atoms/notification/notification.component.mjs +69 -0
- package/esm2022/lib/atoms/notification/notification.module.mjs +20 -0
- package/esm2022/lib/atoms/numeric-textbox/numeric-textbox.component.mjs +80 -0
- package/esm2022/lib/atoms/numeric-textbox/numeric-textbox.module.mjs +35 -0
- package/esm2022/lib/atoms/progress-bar/progress-bar.component.mjs +20 -0
- package/esm2022/lib/atoms/progress-bar/progress-bar.module.mjs +24 -0
- package/esm2022/lib/atoms/radio-button/radio-button.component.mjs +51 -0
- package/esm2022/lib/atoms/radio-button/radio-button.module.mjs +39 -0
- package/esm2022/lib/atoms/report-summary/report-summary.component.mjs +47 -0
- package/esm2022/lib/atoms/report-summary/report-summary.module.mjs +24 -0
- package/esm2022/lib/atoms/search-box/search-box.component.mjs +108 -0
- package/esm2022/lib/atoms/search-box/search-box.module.mjs +36 -0
- package/esm2022/lib/atoms/slider/slider.component.mjs +58 -0
- package/esm2022/lib/atoms/slider/slider.module.mjs +28 -0
- package/esm2022/lib/atoms/text-area/text-area.component.mjs +43 -0
- package/esm2022/lib/atoms/text-area/text-area.module.mjs +28 -0
- package/esm2022/lib/atoms/textbox/textbox.component.mjs +102 -0
- package/esm2022/lib/atoms/textbox/textbox.module.mjs +21 -0
- package/esm2022/lib/atoms/timescheduler/timescheduler.component.mjs +62 -0
- package/esm2022/lib/atoms/timescheduler/timescheduler.module.mjs +31 -0
- package/esm2022/lib/atoms/toast-notification/toast-notification.module.mjs +19 -0
- package/esm2022/lib/atoms/toast-notification/toast-notification.service.mjs +45 -0
- package/esm2022/lib/atoms/tooltip/tooltip.component.mjs +35 -0
- package/esm2022/lib/atoms/tooltip/tooltip.module.mjs +20 -0
- package/esm2022/lib/atoms/typography/TypographyType.mjs +2 -0
- package/esm2022/lib/atoms/typography/typography.component.mjs +97 -0
- package/esm2022/lib/atoms/typography/typography.module.mjs +24 -0
- package/esm2022/lib/molecules/card/card-actions/card-actions.component.mjs +21 -0
- package/esm2022/lib/molecules/card/card-body/card-body.component.mjs +14 -0
- package/esm2022/lib/molecules/card/card-footer/card-footer.component.mjs +14 -0
- package/esm2022/lib/molecules/card/card-header/card-header.component.mjs +32 -0
- package/esm2022/lib/molecules/card/card.component.mjs +21 -0
- package/esm2022/lib/molecules/card/card.module.mjs +44 -0
- package/esm2022/lib/molecules/dialog/dialog-actions/dialog-actions.component.mjs +18 -0
- package/esm2022/lib/molecules/dialog/dialog-titlebar/dialog-titlebar.component.mjs +41 -0
- package/esm2022/lib/molecules/dialog/dialog.component.mjs +52 -0
- package/esm2022/lib/molecules/dialog/dialog.module.mjs +40 -0
- package/esm2022/lib/molecules/grid/grid-form/grid-form.component.mjs +112 -0
- package/esm2022/lib/molecules/grid/grid-spacer/grid-spacer.component.mjs +15 -0
- package/esm2022/lib/molecules/grid/grid.component.mjs +278 -0
- package/esm2022/lib/molecules/grid/grid.module.mjs +61 -0
- package/esm2022/lib/molecules/grid-layout/grid-layout-item/grid-layout-item.component.mjs +39 -0
- package/esm2022/lib/molecules/grid-layout/grid-layout.component.mjs +34 -0
- package/esm2022/lib/molecules/grid-layout/grid-layout.module.mjs +33 -0
- package/esm2022/lib/molecules/grid-pagination/grid-pagination-spacer/grid-pagination-spacer.component.mjs +15 -0
- package/esm2022/lib/molecules/grid-pagination/grid-pagination.component.mjs +380 -0
- package/esm2022/lib/molecules/grid-pagination/grid-pagination.module.mjs +69 -0
- package/esm2022/lib/molecules/grid-pagination/kebab-menu-filter.pipe.mjs +22 -0
- package/esm2022/lib/molecules/molecules.module.mjs +74 -0
- package/esm2022/lib/molecules/sidebar/layout/layout.model.mjs +2 -0
- package/esm2022/lib/molecules/sidebar/sidebar.component.mjs +43 -0
- package/esm2022/lib/molecules/sidebar/sidebar.module.mjs +32 -0
- package/esm2022/lib/molecules/tabstrip/tabstrip-tab/tabstrip-tab.component.mjs +25 -0
- package/esm2022/lib/molecules/tabstrip/tabstrip.component.mjs +37 -0
- package/esm2022/lib/molecules/tabstrip/tabstrip.module.mjs +33 -0
- package/esm2022/lib/shared.component.mjs +16 -0
- package/esm2022/lib/shared.module.mjs +40 -0
- package/esm2022/lib/shared.service.mjs +14 -0
- package/esm2022/lib/style-tokens/style-tokens.module.mjs +18 -0
- package/esm2022/progress-chef-platform-shared-components.mjs +5 -0
- package/esm2022/public-api.mjs +98 -0
- package/fesm2022/progress-chef-platform-shared-components.mjs +3970 -0
- package/fesm2022/progress-chef-platform-shared-components.mjs.map +1 -0
- package/index.d.ts +5 -0
- package/lib/atoms/alert/alert.component.d.ts +19 -0
- package/lib/atoms/alert/alert.module.d.ts +8 -0
- package/lib/atoms/angular-popup/angular-popup.component.d.ts +16 -0
- package/lib/atoms/angular-popup/angular-popup.module.d.ts +11 -0
- package/lib/atoms/atoms.module.d.ts +38 -0
- package/lib/atoms/avatar/avatar.component.d.ts +21 -0
- package/lib/atoms/avatar/avatar.module.d.ts +10 -0
- package/lib/atoms/breadcrumb/breadcrumb.component.d.ts +18 -0
- package/lib/atoms/breadcrumb/breadcrumb.module.d.ts +12 -0
- package/lib/atoms/button/button.component.d.ts +26 -0
- package/lib/atoms/button/button.module.d.ts +11 -0
- package/lib/atoms/button-group/button-group.component.d.ts +21 -0
- package/lib/atoms/button-group/button-group.module.d.ts +11 -0
- package/lib/atoms/checkbox/checkbox.component.d.ts +20 -0
- package/lib/atoms/checkbox/checkbox.module.d.ts +11 -0
- package/lib/atoms/clipboard/clipboard.component.d.ts +33 -0
- package/lib/atoms/clipboard/clipboard.module.d.ts +11 -0
- package/lib/atoms/container/container.component.d.ts +12 -0
- package/lib/atoms/container/container.module.d.ts +8 -0
- package/lib/atoms/dropdown/dropdown.component.d.ts +38 -0
- package/lib/atoms/dropdown/dropdown.module.d.ts +11 -0
- package/lib/atoms/dropdowntree/dropdowntree.component.d.ts +36 -0
- package/lib/atoms/dropdowntree/dropdowntree.module.d.ts +12 -0
- package/lib/atoms/expansion-panel/expansion-panel.component.d.ts +16 -0
- package/lib/atoms/expansion-panel/expansion-panel.module.d.ts +17 -0
- package/lib/atoms/icon/icon.component.d.ts +13 -0
- package/lib/atoms/icon/icon.module.d.ts +7 -0
- package/lib/atoms/label/label.component.d.ts +14 -0
- package/lib/atoms/label/label.module.d.ts +10 -0
- package/lib/atoms/loading-spinner/loading-spinner.component.d.ts +13 -0
- package/lib/atoms/loading-spinner/loading-spinner.module.d.ts +8 -0
- package/lib/atoms/multi-select-dropdown/multi-select-dropdown.component.d.ts +37 -0
- package/lib/atoms/multi-select-dropdown/multi-select-dropdown.module.d.ts +11 -0
- package/lib/atoms/notification/notification.component.d.ts +24 -0
- package/lib/atoms/notification/notification.module.d.ts +8 -0
- package/lib/atoms/numeric-textbox/numeric-textbox.component.d.ts +30 -0
- package/lib/atoms/numeric-textbox/numeric-textbox.module.d.ts +10 -0
- package/lib/atoms/progress-bar/progress-bar.component.d.ts +11 -0
- package/lib/atoms/progress-bar/progress-bar.module.d.ts +8 -0
- package/lib/atoms/radio-button/radio-button.component.d.ts +21 -0
- package/lib/atoms/radio-button/radio-button.module.d.ts +11 -0
- package/lib/atoms/report-summary/report-summary.component.d.ts +23 -0
- package/lib/atoms/report-summary/report-summary.module.d.ts +8 -0
- package/lib/atoms/search-box/search-box.component.d.ts +37 -0
- package/lib/atoms/search-box/search-box.module.d.ts +12 -0
- package/lib/atoms/slider/slider.component.d.ts +18 -0
- package/lib/atoms/slider/slider.module.d.ts +9 -0
- package/lib/atoms/text-area/text-area.component.d.ts +20 -0
- package/lib/atoms/text-area/text-area.module.d.ts +10 -0
- package/lib/atoms/textbox/textbox.component.d.ts +34 -0
- package/lib/atoms/textbox/textbox.module.d.ts +11 -0
- package/lib/atoms/timescheduler/timescheduler.component.d.ts +23 -0
- package/lib/atoms/timescheduler/timescheduler.module.d.ts +10 -0
- package/lib/atoms/toast-notification/toast-notification.module.d.ts +8 -0
- package/lib/atoms/toast-notification/toast-notification.service.d.ts +28 -0
- package/lib/atoms/tooltip/tooltip.component.d.ts +17 -0
- package/lib/atoms/tooltip/tooltip.module.d.ts +8 -0
- package/lib/atoms/typography/TypographyType.d.ts +1 -0
- package/lib/atoms/typography/typography.component.d.ts +24 -0
- package/lib/atoms/typography/typography.module.d.ts +8 -0
- package/lib/molecules/card/card-actions/card-actions.component.d.ts +11 -0
- package/lib/molecules/card/card-body/card-body.component.d.ts +8 -0
- package/lib/molecules/card/card-footer/card-footer.component.d.ts +8 -0
- package/lib/molecules/card/card-header/card-header.component.d.ts +14 -0
- package/lib/molecules/card/card.component.d.ts +9 -0
- package/lib/molecules/card/card.module.d.ts +14 -0
- package/lib/molecules/dialog/dialog-actions/dialog-actions.component.d.ts +10 -0
- package/lib/molecules/dialog/dialog-titlebar/dialog-titlebar.component.d.ts +17 -0
- package/lib/molecules/dialog/dialog.component.d.ts +21 -0
- package/lib/molecules/dialog/dialog.module.d.ts +13 -0
- package/lib/molecules/grid/grid-form/grid-form.component.d.ts +34 -0
- package/lib/molecules/grid/grid-spacer/grid-spacer.component.d.ts +8 -0
- package/lib/molecules/grid/grid.component.d.ts +71 -0
- package/lib/molecules/grid/grid.module.d.ts +19 -0
- package/lib/molecules/grid-layout/grid-layout-item/grid-layout-item.component.d.ts +15 -0
- package/lib/molecules/grid-layout/grid-layout.component.d.ts +14 -0
- package/lib/molecules/grid-layout/grid-layout.module.d.ts +10 -0
- package/lib/molecules/grid-pagination/grid-pagination-spacer/grid-pagination-spacer.component.d.ts +8 -0
- package/lib/molecules/grid-pagination/grid-pagination.component.d.ts +90 -0
- package/lib/molecules/grid-pagination/grid-pagination.module.d.ts +19 -0
- package/lib/molecules/grid-pagination/kebab-menu-filter.pipe.d.ts +7 -0
- package/lib/molecules/molecules.module.d.ts +15 -0
- package/lib/molecules/sidebar/layout/layout.model.d.ts +20 -0
- package/lib/molecules/sidebar/sidebar.component.d.ts +14 -0
- package/lib/molecules/sidebar/sidebar.module.d.ts +10 -0
- package/lib/molecules/tabstrip/tabstrip-tab/tabstrip-tab.component.d.ts +10 -0
- package/lib/molecules/tabstrip/tabstrip.component.d.ts +15 -0
- package/lib/molecules/tabstrip/tabstrip.module.d.ts +10 -0
- package/lib/shared.component.d.ts +10 -0
- package/lib/shared.module.d.ts +11 -0
- package/lib/shared.service.d.ts +6 -0
- package/lib/style-tokens/style-tokens.module.d.ts +7 -0
- package/package.json +55 -0
- package/public-api.d.ts +91 -0
|
@@ -0,0 +1,380 @@
|
|
|
1
|
+
import { Component, ContentChild, EventEmitter, HostListener, Input, Output, ViewChild, } from '@angular/core';
|
|
2
|
+
import { GridComponent, } from '@progress/kendo-angular-grid';
|
|
3
|
+
import { orderBy } from '@progress/kendo-data-query';
|
|
4
|
+
import { chevronDownIcon, chevronUpIcon, moreVerticalIcon } from '@progress/kendo-svg-icons';
|
|
5
|
+
import * as i0 from "@angular/core";
|
|
6
|
+
import * as i1 from "@angular/common";
|
|
7
|
+
import * as i2 from "@progress/kendo-angular-buttons";
|
|
8
|
+
import * as i3 from "../../atoms/icon/icon.component";
|
|
9
|
+
import * as i4 from "@progress/kendo-angular-grid";
|
|
10
|
+
import * as i5 from "../../atoms/tooltip/tooltip.component";
|
|
11
|
+
import * as i6 from "../../atoms/typography/typography.component";
|
|
12
|
+
import * as i7 from "./kebab-menu-filter.pipe";
|
|
13
|
+
export class GridPaginationComponent {
|
|
14
|
+
constructor() {
|
|
15
|
+
this.gridView = { data: [], total: 0 };
|
|
16
|
+
this.skip = 0;
|
|
17
|
+
this.columnData = [];
|
|
18
|
+
this.pageSize = 0;
|
|
19
|
+
this.pageable = false;
|
|
20
|
+
this.sortable = false;
|
|
21
|
+
this.groupable = false;
|
|
22
|
+
this.reorderable = false;
|
|
23
|
+
this.resizable = false;
|
|
24
|
+
this.checkBoxWidth = 45;
|
|
25
|
+
this.checkBoxColumnResizable = false;
|
|
26
|
+
this.checkBoxColumnMenu = false;
|
|
27
|
+
this.checkBoxColumnShowSelectedAll = true;
|
|
28
|
+
this.checkBoxRequired = false;
|
|
29
|
+
this.columnMenu = false;
|
|
30
|
+
this.mode = 'multiple';
|
|
31
|
+
this.checkboxOnly = true;
|
|
32
|
+
this.dragColumns = false;
|
|
33
|
+
this.navigable = true;
|
|
34
|
+
this.gridRowSelectByValue = '';
|
|
35
|
+
this.noRecordsContent = 'No Records Available';
|
|
36
|
+
this.selectedRowData = new EventEmitter();
|
|
37
|
+
this.showToolbar = false;
|
|
38
|
+
this.selectableSettings = {};
|
|
39
|
+
this.kebabList = [];
|
|
40
|
+
this.showKebab = false;
|
|
41
|
+
this.rowDetails = new EventEmitter();
|
|
42
|
+
this.kebabItemClick = new EventEmitter();
|
|
43
|
+
this.icon = moreVerticalIcon;
|
|
44
|
+
this.kebabColumnWidth = 60;
|
|
45
|
+
this.data = [];
|
|
46
|
+
this.selectColumn = '';
|
|
47
|
+
this.rowDataOfClickedCell = new EventEmitter();
|
|
48
|
+
this.preSelected = [];
|
|
49
|
+
this.preSelectedRecords = [];
|
|
50
|
+
this.onPageChange = new EventEmitter();
|
|
51
|
+
this.ignoreColumnCellClick = [];
|
|
52
|
+
this.allowColumnClick = false;
|
|
53
|
+
this.sort = [
|
|
54
|
+
{
|
|
55
|
+
field: '',
|
|
56
|
+
dir: undefined,
|
|
57
|
+
},
|
|
58
|
+
];
|
|
59
|
+
this.hasApiSorting = false;
|
|
60
|
+
this.sortDirection = new EventEmitter();
|
|
61
|
+
this.arrowDownIcon = chevronDownIcon;
|
|
62
|
+
this.arrowUpIcon = chevronUpIcon;
|
|
63
|
+
this.expandRowIndex = [];
|
|
64
|
+
this.customExpandRowColumn = false;
|
|
65
|
+
this.deleteColumnWidth = 42;
|
|
66
|
+
this.expandRowColumnWidth = 42;
|
|
67
|
+
this.deletedRowData = new EventEmitter();
|
|
68
|
+
this.sizes = [];
|
|
69
|
+
this.pageCount = 0;
|
|
70
|
+
this.showDeleteColumn = false;
|
|
71
|
+
this.hideKebabRowIndex = [];
|
|
72
|
+
this.gridBottomSpace = 24;
|
|
73
|
+
this.resizeHeight = 0;
|
|
74
|
+
this.setSelectableSettings();
|
|
75
|
+
}
|
|
76
|
+
ngOnInit() {
|
|
77
|
+
for (let column of this.columnData) {
|
|
78
|
+
column.sortable = column.sortable == undefined ? true : column.sortable;
|
|
79
|
+
}
|
|
80
|
+
if (!this.hasApiSorting) {
|
|
81
|
+
this.loadGridData();
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
ngOnChanges(changes) {
|
|
85
|
+
let prevPreSelected = JSON.stringify(changes['preSelected']?.previousValue);
|
|
86
|
+
let currPreSelected = JSON.stringify(changes['preSelected']?.currentValue);
|
|
87
|
+
// Check if there is a change in this.preSelected input
|
|
88
|
+
if (prevPreSelected !== currPreSelected) {
|
|
89
|
+
// Clear the this.preSelectedRecords array
|
|
90
|
+
this.preSelectedRecords = [];
|
|
91
|
+
for (let row = 0; row < changes['preSelected'].currentValue.length; row++) {
|
|
92
|
+
for (let col = 0; col < this.gridView.data.length; col++) {
|
|
93
|
+
// Find the relevant record for a particular id
|
|
94
|
+
if (this.gridView.data[col][this.gridRowSelectByValue] ===
|
|
95
|
+
changes['preSelected'].currentValue[row]) {
|
|
96
|
+
let found = false;
|
|
97
|
+
// Check if this record is present in this.data, if yes don't push it in this.preSelectedRecords else push it
|
|
98
|
+
for (let index = 0; index < this.data.length; index++) {
|
|
99
|
+
if (this.data[index][this.gridRowSelectByValue] ===
|
|
100
|
+
this.gridView.data[col][this.gridRowSelectByValue]) {
|
|
101
|
+
found = true;
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
if (!found) {
|
|
105
|
+
this.preSelectedRecords.push(this.gridView.data[col]);
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
this.selectedRowData.emit(this.preSelectedRecords.concat(this.data));
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
ngAfterContentInit() {
|
|
114
|
+
if (!this.pageable) {
|
|
115
|
+
this.pageSize = this.gridView.data.length;
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
ngAfterViewInit() {
|
|
119
|
+
if (this.customExpandRowColumn) {
|
|
120
|
+
this.expandRowIndex.forEach((id) => {
|
|
121
|
+
this.grid.expandRow(id);
|
|
122
|
+
});
|
|
123
|
+
}
|
|
124
|
+
this.initialGridHeight = this.gridElement.nativeElement.offsetHeight + this.gridBottomSpace;
|
|
125
|
+
this.getGridHeight();
|
|
126
|
+
}
|
|
127
|
+
pageChange(event) {
|
|
128
|
+
this.onPageChange.emit(event);
|
|
129
|
+
}
|
|
130
|
+
setSelectableSettings() {
|
|
131
|
+
if (this.checkboxOnly || this.mode === 'single') {
|
|
132
|
+
this.dragColumns = false;
|
|
133
|
+
}
|
|
134
|
+
this.selectableSettings = {
|
|
135
|
+
checkboxOnly: this.checkboxOnly,
|
|
136
|
+
mode: this.mode,
|
|
137
|
+
drag: this.dragColumns,
|
|
138
|
+
};
|
|
139
|
+
}
|
|
140
|
+
// We can extract data out of row number using below function
|
|
141
|
+
/* extract() {
|
|
142
|
+
this.extractDataItems = this.mySelection.map(idx => {
|
|
143
|
+
return this.gridData.find((data: { ProductID: number; }) => data.ProductID === idx);
|
|
144
|
+
});
|
|
145
|
+
console.log(this.extractDataItems)
|
|
146
|
+
this.selectedRowData.emit(this.extractDataItems);
|
|
147
|
+
} */
|
|
148
|
+
onSelectionChange(args) {
|
|
149
|
+
for (let row = 0; row < args.selectedRows.length; row++) {
|
|
150
|
+
var found = false;
|
|
151
|
+
for (let col = 0; col < this.data.length; col++) {
|
|
152
|
+
if (this.data[col][this.gridRowSelectByValue] ===
|
|
153
|
+
args.selectedRows[row].dataItem[this.gridRowSelectByValue]) {
|
|
154
|
+
found = true;
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
if (!found) {
|
|
158
|
+
this.data.push(args.selectedRows[row].dataItem);
|
|
159
|
+
}
|
|
160
|
+
}
|
|
161
|
+
if (args.deselectedRows.length !== 0) {
|
|
162
|
+
for (let row = 0; row < args.deselectedRows.length; row++) {
|
|
163
|
+
for (let col = 0; col < this.data.length; col++) {
|
|
164
|
+
if (this.data[col][this.gridRowSelectByValue] ===
|
|
165
|
+
args.deselectedRows[row].dataItem[this.gridRowSelectByValue]) {
|
|
166
|
+
this.data.splice(col, 1);
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
for (let col = 0; col < this.preSelectedRecords.length; col++) {
|
|
170
|
+
if (this.preSelectedRecords[col][this.gridRowSelectByValue] ===
|
|
171
|
+
args.deselectedRows[row].dataItem[this.gridRowSelectByValue]) {
|
|
172
|
+
this.preSelectedRecords.splice(col, 1);
|
|
173
|
+
// Remove this element from preselected
|
|
174
|
+
let index = this.preSelected.indexOf(args.deselectedRows[row].dataItem[this.gridRowSelectByValue]);
|
|
175
|
+
if (index !== -1) {
|
|
176
|
+
this.preSelected.splice(index, 1);
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
this.selectedRowData.emit(this.preSelectedRecords.concat(this.data));
|
|
183
|
+
}
|
|
184
|
+
onKebabClick(item, rowDetails) {
|
|
185
|
+
this.kebabItemClick.emit({ action: item, rowDetails });
|
|
186
|
+
}
|
|
187
|
+
onDetailExpand(rowData) {
|
|
188
|
+
this.rowDetails.emit(rowData.dataItem);
|
|
189
|
+
}
|
|
190
|
+
cellClickHandler(args) {
|
|
191
|
+
if (this.allowColumnClick) {
|
|
192
|
+
if (this.ignoreColumnCellClick.includes(args.columnIndex)) {
|
|
193
|
+
return;
|
|
194
|
+
}
|
|
195
|
+
this.rowDataOfClickedCell.emit(args.dataItem);
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
sortChange(sort) {
|
|
199
|
+
this.sort = sort;
|
|
200
|
+
if (!this.hasApiSorting) {
|
|
201
|
+
this.loadGridData();
|
|
202
|
+
}
|
|
203
|
+
this.sortDirection.emit(this.sort);
|
|
204
|
+
}
|
|
205
|
+
loadGridData() {
|
|
206
|
+
this.gridView = {
|
|
207
|
+
data: orderBy(this.gridView?.data, this.sort),
|
|
208
|
+
total: this.gridView?.total,
|
|
209
|
+
};
|
|
210
|
+
}
|
|
211
|
+
expandRow(id) {
|
|
212
|
+
this.grid.expandRow(id);
|
|
213
|
+
this.expandRowIndex.push(id);
|
|
214
|
+
setTimeout(() => {
|
|
215
|
+
this.getGridHeight();
|
|
216
|
+
}, 0);
|
|
217
|
+
}
|
|
218
|
+
collapseRow(id) {
|
|
219
|
+
this.grid.collapseRow(id);
|
|
220
|
+
this.expandRowIndex.splice(this.expandRowIndex.indexOf(id), 1);
|
|
221
|
+
if (this.expandRowIndex.length == 0) {
|
|
222
|
+
const windowHeight = window.innerHeight;
|
|
223
|
+
const viewport = document.getElementById('lib-grid');
|
|
224
|
+
const gridOffset = viewport.getBoundingClientRect().top + window.scrollY;
|
|
225
|
+
if (windowHeight > (gridOffset + this.initialGridHeight)) {
|
|
226
|
+
this.height = '100%';
|
|
227
|
+
return;
|
|
228
|
+
}
|
|
229
|
+
this.getGridHeight();
|
|
230
|
+
}
|
|
231
|
+
}
|
|
232
|
+
onDelete(rowDetails) {
|
|
233
|
+
this.deletedRowData.emit(rowDetails);
|
|
234
|
+
}
|
|
235
|
+
getHeaderHeight() {
|
|
236
|
+
if (this.gridView?.data?.length === 0) {
|
|
237
|
+
return 'hide-header';
|
|
238
|
+
}
|
|
239
|
+
return 'view-header';
|
|
240
|
+
}
|
|
241
|
+
getGridHeight() {
|
|
242
|
+
const windowHeight = window.innerHeight;
|
|
243
|
+
const viewport = document.getElementById('lib-grid');
|
|
244
|
+
const gridOffset = viewport.getBoundingClientRect().top + window.scrollY;
|
|
245
|
+
const gridHeight = this.gridElement.nativeElement.offsetHeight
|
|
246
|
+
+ this.gridBottomSpace; //grid should have 24px space at bottom
|
|
247
|
+
if (gridOffset + gridHeight >= windowHeight) {
|
|
248
|
+
this.height = windowHeight - (gridOffset + this.gridBottomSpace);
|
|
249
|
+
}
|
|
250
|
+
}
|
|
251
|
+
resize(ev) {
|
|
252
|
+
if (ev.target.innerHeight > this.resizeHeight) {
|
|
253
|
+
this.resizeHeight = ev.target.innerHeight;
|
|
254
|
+
this.height = '100%';
|
|
255
|
+
}
|
|
256
|
+
if (this.resizeHeight > window.innerHeight) {
|
|
257
|
+
this.resizeHeight = 0;
|
|
258
|
+
}
|
|
259
|
+
this.getGridHeight();
|
|
260
|
+
}
|
|
261
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: GridPaginationComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
262
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: GridPaginationComponent, selector: "lib-grid-pagination", inputs: { gridView: "gridView", skip: "skip", columnData: "columnData", pageSize: "pageSize", pageable: "pageable", sortable: "sortable", groupable: "groupable", reorderable: "reorderable", resizable: "resizable", checkBoxWidth: "checkBoxWidth", checkBoxColumnResizable: "checkBoxColumnResizable", checkBoxColumnMenu: "checkBoxColumnMenu", checkBoxColumnShowSelectedAll: "checkBoxColumnShowSelectedAll", checkBoxRequired: "checkBoxRequired", columnMenu: "columnMenu", mode: "mode", checkboxOnly: "checkboxOnly", dragColumns: "dragColumns", navigable: "navigable", gridRowSelectByValue: "gridRowSelectByValue", noRecordsContent: "noRecordsContent", showToolbar: "showToolbar", kebabList: "kebabList", showKebab: "showKebab", icon: "icon", kebabColumnWidth: "kebabColumnWidth", selectColumn: "selectColumn", preSelected: "preSelected", ignoreColumnCellClick: "ignoreColumnCellClick", allowColumnClick: "allowColumnClick", sort: "sort", hasApiSorting: "hasApiSorting", expandRowIndex: "expandRowIndex", customExpandRowColumn: "customExpandRowColumn", deleteColumnWidth: "deleteColumnWidth", expandRowColumnWidth: "expandRowColumnWidth", sizes: "sizes", pageCount: "pageCount", showDeleteColumn: "showDeleteColumn", hideKebabRowIndex: "hideKebabRowIndex" }, outputs: { selectedRowData: "selectedRowData", rowDetails: "rowDetails", kebabItemClick: "kebabItemClick", rowDataOfClickedCell: "rowDataOfClickedCell", onPageChange: "onPageChange", sortDirection: "sortDirection", deletedRowData: "deletedRowData" }, host: { listeners: { "window:resize": "resize($event)" } }, queries: [{ propertyName: "templateRef", first: true, predicate: ["multiColumnData"], descendants: true }, { propertyName: "detailTemplate", first: true, predicate: ["detailTemplate"], descendants: true }, { propertyName: "impactColumn", first: true, predicate: ["impactColumn"], descendants: true }], viewQueries: [{ propertyName: "grid", first: true, predicate: GridComponent, descendants: true }, { propertyName: "gridElement", first: true, predicate: ["gridElement"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div #gridElement (window:resize)=\"resize($event)\" >\n<kendo-grid [data]=\"gridView\" [pageSize]=\"pageSize\" [skip]=\"skip\" [selectable]=\"selectableSettings\"\n [pageable]=\"pageable\" [sortable]=\"sortable\" [groupable]=\"groupable\" [reorderable]=\"reorderable\"\n [resizable]=\"resizable\" [columnMenu]=\"columnMenu\" [navigable]=\"navigable\" [height]=\"height\" [style.height]=\"height\"\n (change)=\"setSelectableSettings()\" (selectionChange)=\"onSelectionChange($event)\"\n [kendoGridSelectBy]=\"gridRowSelectByValue\" (detailExpand)=\"onDetailExpand($event)\" [selectedKeys]=\"preSelected\"\n (pageChange)=\"pageChange($event)\" (cellClick)=\"cellClickHandler($event)\" [sort]=\"sort\"\n (sortChange)=\"sortChange($event)\" [ngClass]=\"getHeaderHeight()\" id=\"lib-grid\">\n\n <ng-template *ngIf=\"showToolbar\" kendoGridToolbarTemplate>\n <ng-content></ng-content>\n </ng-template>\n\n <ng-template *ngIf=\"this.gridView.data.length === 0\" kendoGridNoRecordsTemplate>\n <lib-typography [defaultText]=\"noRecordsContent\" type=\"P_MULISH_16_REGULAR\"></lib-typography>\n </ng-template>\n\n <ng-container *ngIf=\"this.gridView.data.length > 0\">\n <kendo-grid-checkbox-column *ngIf=\"checkBoxRequired === true\" [width]=\"checkBoxWidth\"\n [resizable]=\"checkBoxColumnResizable\" [columnMenu]=\"checkBoxColumnMenu\"\n [showSelectAll]=\"checkBoxColumnShowSelectedAll\" class=\"checkbox-column\">\n </kendo-grid-checkbox-column>\n\n <kendo-grid-column class=\"grid-column\" *ngFor=\"let item of columnData\" [field]=\"item.field\" [title]=\"item.title\"\n [width]=\"item.columnWidth\" [sortable]=\"item.sortable\">\n\n <ng-template *ngIf=\"sortable\" kendoGridHeaderTemplate>\n {{item.title}}\n <span *ngIf=\"sort[0].field === item.field\">\n <span *ngIf=\"sort[0].dir === 'asc'\"></span>\n <span *ngIf=\"sort[0].dir === 'desc'\"></span>\n </span>\n </ng-template>\n\n <ng-template *ngIf=\"item.custom\" kendoGridCellTemplate let-dataItem>\n <ng-container *ngTemplateOutlet=\"templateRef; context: {$implicit: dataItem}\"></ng-container>\n </ng-template>\n <ng-template *ngIf=\"item.impact\" kendoGridCellTemplate let-dataItem>\n <ng-container *ngTemplateOutlet=\"impactColumn; context: {$implicit: dataItem}\"></ng-container>\n </ng-template>\n </kendo-grid-column>\n\n <kendo-grid-column *ngIf=\"showDeleteColumn\" [width]=\"deleteColumnWidth\" class=\"delete-column\" title=\"Action\">\n <ng-template kendoGridCellTemplate let-dataItem let-rowIndex=\"rowIndex\">\n <lib-tooltip showOn=\"hover\" position=\"bottom\" class=\"remove-tooltip\">\n <lib-icon name=\"delete\" class=\"delete-icon\" (click)=\"onDelete(dataItem)\"></lib-icon>\n <div class=\"tooltip-content\">\n <lib-typography defaultText=\"Remove\"></lib-typography>\n </div>\n </lib-tooltip>\n </ng-template>\n </kendo-grid-column>\n\n <kendo-grid-column [width]=\"kebabColumnWidth\" class=\"kebab-column\" *ngIf=\"showKebab\" title=\"Actions\">\n <ng-template kendoGridCellTemplate let-dataItem let-rowIndex=\"rowIndex\">\n <kendo-dropdownbutton *ngIf=\"!hideKebabRowIndex.includes(rowIndex)\" [svgIcon]=\"icon\" fillMode=\"none\" [data]=\"kebabList | kebabMenuFilter : dataItem\" class=\"kebab\"\n (itemClick)=\"onKebabClick($event, dataItem)\" [popupSettings]=\"{ align: 'right', animate: true, popupClass: 'kebab-list' }\">\n </kendo-dropdownbutton>\n </ng-template>\n </kendo-grid-column>\n </ng-container>\n\n <ng-template kendoGridDetailTemplate let-dataItem>\n <ng-container *ngTemplateOutlet=\"detailTemplate; context: {$implicit: dataItem}\"></ng-container>\n </ng-template>\n\n <kendo-grid-column *ngIf=\"customExpandRowColumn\" [width]=\"expandRowColumnWidth\" class=\"grid-column expand-column\">\n <ng-template kendoGridCellTemplate let-dataItem let-rowIndex=\"rowIndex\">\n <kendo-button *ngIf=\"!expandRowIndex.includes(rowIndex)\" [svgIcon]=\"arrowDownIcon\" (click)=\"expandRow(rowIndex)\"\n fillMode=\"none\" class=\"arrow-btn\">\n </kendo-button>\n <kendo-button *ngIf=\"expandRowIndex.includes(rowIndex)\" [svgIcon]=\"arrowUpIcon\" (click)=\"collapseRow(rowIndex)\"\n fillMode=\"none\" class=\"arrow-btn\">\n </kendo-button>\n </ng-template>\n </kendo-grid-column>\n\n <ng-template kendoPagerTemplate let-totalPages=\"totalPages\" let-currentPage=\"currentPage\">\n <kendo-pager-prev-buttons></kendo-pager-prev-buttons>\n <kendo-pager-numeric-buttons [buttonCount]=\"pageCount\"></kendo-pager-numeric-buttons>\n <kendo-pager-next-buttons></kendo-pager-next-buttons>\n <kendo-pager-info></kendo-pager-info>\n <kendo-pager-page-sizes [pageSizes]=\"sizes\"></kendo-pager-page-sizes>\n </ng-template>\n\n</kendo-grid>\n</div>\n", styles: ["@font-face{font-family:Mulish;src:url(/assets/fonts/Mulish-Light.ttf);font-weight:300;font-style:normal}@font-face{font-family:Mulish;src:url(../assets/fonts/Mulish-LightItalic.ttf);font-weight:300;font-style:italic}@font-face{font-family:Mulish;src:url(../assets/fonts/Mulish-Regular.ttf);font-weight:400;font-style:normal}@font-face{font-family:Mulish;src:url(../assets/fonts/Mulish-Italic.ttf);font-weight:400;font-style:italic}@font-face{font-family:Mulish;src:url(../assets/fonts/Mulish-Bold.ttf);font-weight:700;font-style:normal}::ng-deep .k-grid th{font-family:Mulish,sans-serif;font-weight:700;font-style:normal;font-size:16px;line-height:24px;letter-spacing:.2px}::ng-deep .k-grid tr{font-family:Mulish,sans-serif;font-weight:400;font-style:normal;font-size:14px;line-height:21px;letter-spacing:.8px;height:50px}::ng-deep .k-grid tr:hover{font-family:Mulish,sans-serif;font-weight:700;font-style:normal;font-size:14px;line-height:21px;letter-spacing:.8px}::ng-deep .k-grid-norecords{text-align:center!important;opacity:.4}::ng-deep .k-grid-norecords td{padding:14px 0 14px 24px!important}::ng-deep kendo-pager.k-pager-wrap.k-grid-pager{font-family:Mulish,sans-serif;font-weight:400;font-style:normal;font-size:14px;line-height:21px;letter-spacing:.2px}::ng-deep .k-grid th.k-header{vertical-align:middle!important;padding-left:16px;padding-right:0}::ng-deep .grid-column,::ng-deep .kebab-column,::ng-deep .delete-column{padding:0!important}::ng-deep .grid-column kendo-button,::ng-deep .kebab-column kendo-button,::ng-deep .delete-column kendo-button{align-items:center!important;justify-content:center!important;display:flex!important}::ng-deep .k-checkbox{width:20px!important;height:20px!important;border-radius:0!important}::ng-deep .k-grid .k-hierarchy-cell,::ng-deep .k-grid .k-hierarchy-col{width:0;display:none}::ng-deep .k-grid .k-detail-row .k-detail-cell{padding:16px!important}::ng-deep .delete-icon{color:#dc267f!important;padding-left:12px;cursor:pointer}::ng-deep .remove-tooltip kendo-tooltip.k-tooltip{background-color:#fff;color:#000}::ng-deep .hide-header .k-grid-header{border:0px!important}::ng-deep .k-grid-toolbar{padding:4px 16px!important;height:50px}::ng-deep .k-grid td:not(.kebab-column):not(.expand-column){padding-left:16px!important}::ng-deep .view-header .k-table-thead tr{height:50px}::ng-deep .hide-header .k-table-thead tr{height:0px}::ng-deep td.kebab-column{display:flex;justify-content:center;align-items:center;height:inherit}::ng-deep .k-grid .k-table-td>.k-checkbox{vertical-align:middle!important}::ng-deep .kebab .k-button,::ng-deep .expand-column .k-button{border:0px}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: i2.ButtonComponent, selector: "button[kendoButton], span[kendoButton], kendo-button", inputs: ["arrowIcon", "toggleable", "togglable", "selected", "tabIndex", "imageUrl", "iconClass", "icon", "disabled", "size", "rounded", "fillMode", "themeColor", "svgIcon", "role", "primary", "look"], outputs: ["selectedChange", "click"], exportAs: ["kendoButton"] }, { kind: "component", type: i2.DropDownButtonComponent, selector: "kendo-dropdownbutton", inputs: ["arrowIcon", "icon", "svgIcon", "iconClass", "imageUrl", "textField", "data", "size", "rounded", "fillMode", "themeColor", "buttonAttributes"], outputs: ["itemClick", "focus", "blur"], exportAs: ["kendoDropDownButton"] }, { kind: "component", type: i3.IconComponent, selector: "lib-icon", inputs: ["name", "fontSize", "type"] }, { kind: "component", type: i4.GridComponent, selector: "kendo-grid", inputs: ["data", "pageSize", "height", "rowHeight", "detailRowHeight", "skip", "scrollable", "selectable", "sort", "size", "trackBy", "filter", "group", "virtualColumns", "filterable", "sortable", "pageable", "groupable", "rowReorderable", "navigable", "navigatable", "autoSize", "rowClass", "rowSticky", "rowSelected", "cellSelected", "resizable", "reorderable", "loading", "columnMenu", "hideHeader", "isDetailExpanded", "isGroupExpanded"], outputs: ["filterChange", "pageChange", "groupChange", "sortChange", "selectionChange", "rowReorder", "dataStateChange", "groupExpand", "groupCollapse", "detailExpand", "detailCollapse", "edit", "cancel", "save", "remove", "add", "cellClose", "cellClick", "pdfExport", "excelExport", "columnResize", "columnReorder", "columnVisibilityChange", "columnLockedChange", "columnStickyChange", "scrollBottom", "contentScroll"], exportAs: ["kendoGrid"] }, { kind: "directive", type: i4.ToolbarTemplateDirective, selector: "[kendoGridToolbarTemplate]", inputs: ["position"] }, { kind: "directive", type: i4.SelectionDirective, selector: "[kendoGridSelectBy]" }, { kind: "component", type: i4.ColumnComponent, selector: "kendo-grid-column", inputs: ["field", "format", "sortable", "groupable", "editor", "filter", "filterable", "editable"] }, { kind: "directive", type: i4.DetailTemplateDirective, selector: "[kendoGridDetailTemplate]", inputs: ["kendoGridDetailTemplateShowIf"] }, { kind: "component", type: i4.CheckboxColumnComponent, selector: "kendo-grid-checkbox-column", inputs: ["showSelectAll"] }, { kind: "directive", type: i4.CellTemplateDirective, selector: "[kendoGridCellTemplate]" }, { kind: "directive", type: i4.NoRecordsTemplateDirective, selector: "[kendoGridNoRecordsTemplate]" }, { kind: "directive", type: i4.HeaderTemplateDirective, selector: "[kendoGridHeaderTemplate]" }, { kind: "component", type: i4.PagerPrevButtonsComponent, selector: "kendo-pager-prev-buttons" }, { kind: "component", type: i4.PagerNextButtonsComponent, selector: "kendo-pager-next-buttons" }, { kind: "component", type: i4.PagerNumericButtonsComponent, selector: "kendo-pager-numeric-buttons", inputs: ["buttonCount"] }, { kind: "component", type: i4.PagerInfoComponent, selector: "kendo-pager-info" }, { kind: "component", type: i4.PagerPageSizesComponent, selector: "kendo-pager-page-sizes", inputs: ["pageSizes"] }, { kind: "directive", type: i4.PagerTemplateDirective, selector: "[kendoPagerTemplate]" }, { kind: "component", type: i5.TooltipComponent, selector: "lib-tooltip", inputs: ["position", "tooltipWidth", "tooltipHeight", "showOn", "closable", "title", "callout"] }, { kind: "component", type: i6.TypographyComponent, selector: "lib-typography", inputs: ["type", "defaultText", "isLabel", "hiddenLabel"] }, { kind: "pipe", type: i7.KebabMenuFilterPipe, name: "kebabMenuFilter" }] }); }
|
|
263
|
+
}
|
|
264
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: GridPaginationComponent, decorators: [{
|
|
265
|
+
type: Component,
|
|
266
|
+
args: [{ selector: 'lib-grid-pagination', template: "<div #gridElement (window:resize)=\"resize($event)\" >\n<kendo-grid [data]=\"gridView\" [pageSize]=\"pageSize\" [skip]=\"skip\" [selectable]=\"selectableSettings\"\n [pageable]=\"pageable\" [sortable]=\"sortable\" [groupable]=\"groupable\" [reorderable]=\"reorderable\"\n [resizable]=\"resizable\" [columnMenu]=\"columnMenu\" [navigable]=\"navigable\" [height]=\"height\" [style.height]=\"height\"\n (change)=\"setSelectableSettings()\" (selectionChange)=\"onSelectionChange($event)\"\n [kendoGridSelectBy]=\"gridRowSelectByValue\" (detailExpand)=\"onDetailExpand($event)\" [selectedKeys]=\"preSelected\"\n (pageChange)=\"pageChange($event)\" (cellClick)=\"cellClickHandler($event)\" [sort]=\"sort\"\n (sortChange)=\"sortChange($event)\" [ngClass]=\"getHeaderHeight()\" id=\"lib-grid\">\n\n <ng-template *ngIf=\"showToolbar\" kendoGridToolbarTemplate>\n <ng-content></ng-content>\n </ng-template>\n\n <ng-template *ngIf=\"this.gridView.data.length === 0\" kendoGridNoRecordsTemplate>\n <lib-typography [defaultText]=\"noRecordsContent\" type=\"P_MULISH_16_REGULAR\"></lib-typography>\n </ng-template>\n\n <ng-container *ngIf=\"this.gridView.data.length > 0\">\n <kendo-grid-checkbox-column *ngIf=\"checkBoxRequired === true\" [width]=\"checkBoxWidth\"\n [resizable]=\"checkBoxColumnResizable\" [columnMenu]=\"checkBoxColumnMenu\"\n [showSelectAll]=\"checkBoxColumnShowSelectedAll\" class=\"checkbox-column\">\n </kendo-grid-checkbox-column>\n\n <kendo-grid-column class=\"grid-column\" *ngFor=\"let item of columnData\" [field]=\"item.field\" [title]=\"item.title\"\n [width]=\"item.columnWidth\" [sortable]=\"item.sortable\">\n\n <ng-template *ngIf=\"sortable\" kendoGridHeaderTemplate>\n {{item.title}}\n <span *ngIf=\"sort[0].field === item.field\">\n <span *ngIf=\"sort[0].dir === 'asc'\"></span>\n <span *ngIf=\"sort[0].dir === 'desc'\"></span>\n </span>\n </ng-template>\n\n <ng-template *ngIf=\"item.custom\" kendoGridCellTemplate let-dataItem>\n <ng-container *ngTemplateOutlet=\"templateRef; context: {$implicit: dataItem}\"></ng-container>\n </ng-template>\n <ng-template *ngIf=\"item.impact\" kendoGridCellTemplate let-dataItem>\n <ng-container *ngTemplateOutlet=\"impactColumn; context: {$implicit: dataItem}\"></ng-container>\n </ng-template>\n </kendo-grid-column>\n\n <kendo-grid-column *ngIf=\"showDeleteColumn\" [width]=\"deleteColumnWidth\" class=\"delete-column\" title=\"Action\">\n <ng-template kendoGridCellTemplate let-dataItem let-rowIndex=\"rowIndex\">\n <lib-tooltip showOn=\"hover\" position=\"bottom\" class=\"remove-tooltip\">\n <lib-icon name=\"delete\" class=\"delete-icon\" (click)=\"onDelete(dataItem)\"></lib-icon>\n <div class=\"tooltip-content\">\n <lib-typography defaultText=\"Remove\"></lib-typography>\n </div>\n </lib-tooltip>\n </ng-template>\n </kendo-grid-column>\n\n <kendo-grid-column [width]=\"kebabColumnWidth\" class=\"kebab-column\" *ngIf=\"showKebab\" title=\"Actions\">\n <ng-template kendoGridCellTemplate let-dataItem let-rowIndex=\"rowIndex\">\n <kendo-dropdownbutton *ngIf=\"!hideKebabRowIndex.includes(rowIndex)\" [svgIcon]=\"icon\" fillMode=\"none\" [data]=\"kebabList | kebabMenuFilter : dataItem\" class=\"kebab\"\n (itemClick)=\"onKebabClick($event, dataItem)\" [popupSettings]=\"{ align: 'right', animate: true, popupClass: 'kebab-list' }\">\n </kendo-dropdownbutton>\n </ng-template>\n </kendo-grid-column>\n </ng-container>\n\n <ng-template kendoGridDetailTemplate let-dataItem>\n <ng-container *ngTemplateOutlet=\"detailTemplate; context: {$implicit: dataItem}\"></ng-container>\n </ng-template>\n\n <kendo-grid-column *ngIf=\"customExpandRowColumn\" [width]=\"expandRowColumnWidth\" class=\"grid-column expand-column\">\n <ng-template kendoGridCellTemplate let-dataItem let-rowIndex=\"rowIndex\">\n <kendo-button *ngIf=\"!expandRowIndex.includes(rowIndex)\" [svgIcon]=\"arrowDownIcon\" (click)=\"expandRow(rowIndex)\"\n fillMode=\"none\" class=\"arrow-btn\">\n </kendo-button>\n <kendo-button *ngIf=\"expandRowIndex.includes(rowIndex)\" [svgIcon]=\"arrowUpIcon\" (click)=\"collapseRow(rowIndex)\"\n fillMode=\"none\" class=\"arrow-btn\">\n </kendo-button>\n </ng-template>\n </kendo-grid-column>\n\n <ng-template kendoPagerTemplate let-totalPages=\"totalPages\" let-currentPage=\"currentPage\">\n <kendo-pager-prev-buttons></kendo-pager-prev-buttons>\n <kendo-pager-numeric-buttons [buttonCount]=\"pageCount\"></kendo-pager-numeric-buttons>\n <kendo-pager-next-buttons></kendo-pager-next-buttons>\n <kendo-pager-info></kendo-pager-info>\n <kendo-pager-page-sizes [pageSizes]=\"sizes\"></kendo-pager-page-sizes>\n </ng-template>\n\n</kendo-grid>\n</div>\n", styles: ["@font-face{font-family:Mulish;src:url(/assets/fonts/Mulish-Light.ttf);font-weight:300;font-style:normal}@font-face{font-family:Mulish;src:url(../assets/fonts/Mulish-LightItalic.ttf);font-weight:300;font-style:italic}@font-face{font-family:Mulish;src:url(../assets/fonts/Mulish-Regular.ttf);font-weight:400;font-style:normal}@font-face{font-family:Mulish;src:url(../assets/fonts/Mulish-Italic.ttf);font-weight:400;font-style:italic}@font-face{font-family:Mulish;src:url(../assets/fonts/Mulish-Bold.ttf);font-weight:700;font-style:normal}::ng-deep .k-grid th{font-family:Mulish,sans-serif;font-weight:700;font-style:normal;font-size:16px;line-height:24px;letter-spacing:.2px}::ng-deep .k-grid tr{font-family:Mulish,sans-serif;font-weight:400;font-style:normal;font-size:14px;line-height:21px;letter-spacing:.8px;height:50px}::ng-deep .k-grid tr:hover{font-family:Mulish,sans-serif;font-weight:700;font-style:normal;font-size:14px;line-height:21px;letter-spacing:.8px}::ng-deep .k-grid-norecords{text-align:center!important;opacity:.4}::ng-deep .k-grid-norecords td{padding:14px 0 14px 24px!important}::ng-deep kendo-pager.k-pager-wrap.k-grid-pager{font-family:Mulish,sans-serif;font-weight:400;font-style:normal;font-size:14px;line-height:21px;letter-spacing:.2px}::ng-deep .k-grid th.k-header{vertical-align:middle!important;padding-left:16px;padding-right:0}::ng-deep .grid-column,::ng-deep .kebab-column,::ng-deep .delete-column{padding:0!important}::ng-deep .grid-column kendo-button,::ng-deep .kebab-column kendo-button,::ng-deep .delete-column kendo-button{align-items:center!important;justify-content:center!important;display:flex!important}::ng-deep .k-checkbox{width:20px!important;height:20px!important;border-radius:0!important}::ng-deep .k-grid .k-hierarchy-cell,::ng-deep .k-grid .k-hierarchy-col{width:0;display:none}::ng-deep .k-grid .k-detail-row .k-detail-cell{padding:16px!important}::ng-deep .delete-icon{color:#dc267f!important;padding-left:12px;cursor:pointer}::ng-deep .remove-tooltip kendo-tooltip.k-tooltip{background-color:#fff;color:#000}::ng-deep .hide-header .k-grid-header{border:0px!important}::ng-deep .k-grid-toolbar{padding:4px 16px!important;height:50px}::ng-deep .k-grid td:not(.kebab-column):not(.expand-column){padding-left:16px!important}::ng-deep .view-header .k-table-thead tr{height:50px}::ng-deep .hide-header .k-table-thead tr{height:0px}::ng-deep td.kebab-column{display:flex;justify-content:center;align-items:center;height:inherit}::ng-deep .k-grid .k-table-td>.k-checkbox{vertical-align:middle!important}::ng-deep .kebab .k-button,::ng-deep .expand-column .k-button{border:0px}\n"] }]
|
|
267
|
+
}], ctorParameters: function () { return []; }, propDecorators: { templateRef: [{
|
|
268
|
+
type: ContentChild,
|
|
269
|
+
args: ['multiColumnData']
|
|
270
|
+
}], detailTemplate: [{
|
|
271
|
+
type: ContentChild,
|
|
272
|
+
args: ['detailTemplate']
|
|
273
|
+
}], impactColumn: [{
|
|
274
|
+
type: ContentChild,
|
|
275
|
+
args: ['impactColumn']
|
|
276
|
+
}], grid: [{
|
|
277
|
+
type: ViewChild,
|
|
278
|
+
args: [GridComponent]
|
|
279
|
+
}], gridElement: [{
|
|
280
|
+
type: ViewChild,
|
|
281
|
+
args: ['gridElement']
|
|
282
|
+
}], gridView: [{
|
|
283
|
+
type: Input
|
|
284
|
+
}], skip: [{
|
|
285
|
+
type: Input
|
|
286
|
+
}], columnData: [{
|
|
287
|
+
type: Input
|
|
288
|
+
}], pageSize: [{
|
|
289
|
+
type: Input
|
|
290
|
+
}], pageable: [{
|
|
291
|
+
type: Input
|
|
292
|
+
}], sortable: [{
|
|
293
|
+
type: Input
|
|
294
|
+
}], groupable: [{
|
|
295
|
+
type: Input
|
|
296
|
+
}], reorderable: [{
|
|
297
|
+
type: Input
|
|
298
|
+
}], resizable: [{
|
|
299
|
+
type: Input
|
|
300
|
+
}], checkBoxWidth: [{
|
|
301
|
+
type: Input
|
|
302
|
+
}], checkBoxColumnResizable: [{
|
|
303
|
+
type: Input
|
|
304
|
+
}], checkBoxColumnMenu: [{
|
|
305
|
+
type: Input
|
|
306
|
+
}], checkBoxColumnShowSelectedAll: [{
|
|
307
|
+
type: Input
|
|
308
|
+
}], checkBoxRequired: [{
|
|
309
|
+
type: Input
|
|
310
|
+
}], columnMenu: [{
|
|
311
|
+
type: Input
|
|
312
|
+
}], mode: [{
|
|
313
|
+
type: Input
|
|
314
|
+
}], checkboxOnly: [{
|
|
315
|
+
type: Input
|
|
316
|
+
}], dragColumns: [{
|
|
317
|
+
type: Input
|
|
318
|
+
}], navigable: [{
|
|
319
|
+
type: Input
|
|
320
|
+
}], gridRowSelectByValue: [{
|
|
321
|
+
type: Input
|
|
322
|
+
}], noRecordsContent: [{
|
|
323
|
+
type: Input
|
|
324
|
+
}], selectedRowData: [{
|
|
325
|
+
type: Output
|
|
326
|
+
}], showToolbar: [{
|
|
327
|
+
type: Input
|
|
328
|
+
}], kebabList: [{
|
|
329
|
+
type: Input
|
|
330
|
+
}], showKebab: [{
|
|
331
|
+
type: Input
|
|
332
|
+
}], rowDetails: [{
|
|
333
|
+
type: Output
|
|
334
|
+
}], kebabItemClick: [{
|
|
335
|
+
type: Output
|
|
336
|
+
}], icon: [{
|
|
337
|
+
type: Input
|
|
338
|
+
}], kebabColumnWidth: [{
|
|
339
|
+
type: Input
|
|
340
|
+
}], selectColumn: [{
|
|
341
|
+
type: Input
|
|
342
|
+
}], rowDataOfClickedCell: [{
|
|
343
|
+
type: Output
|
|
344
|
+
}], preSelected: [{
|
|
345
|
+
type: Input
|
|
346
|
+
}], onPageChange: [{
|
|
347
|
+
type: Output
|
|
348
|
+
}], ignoreColumnCellClick: [{
|
|
349
|
+
type: Input
|
|
350
|
+
}], allowColumnClick: [{
|
|
351
|
+
type: Input
|
|
352
|
+
}], sort: [{
|
|
353
|
+
type: Input
|
|
354
|
+
}], hasApiSorting: [{
|
|
355
|
+
type: Input
|
|
356
|
+
}], sortDirection: [{
|
|
357
|
+
type: Output
|
|
358
|
+
}], expandRowIndex: [{
|
|
359
|
+
type: Input
|
|
360
|
+
}], customExpandRowColumn: [{
|
|
361
|
+
type: Input
|
|
362
|
+
}], deleteColumnWidth: [{
|
|
363
|
+
type: Input
|
|
364
|
+
}], expandRowColumnWidth: [{
|
|
365
|
+
type: Input
|
|
366
|
+
}], deletedRowData: [{
|
|
367
|
+
type: Output
|
|
368
|
+
}], sizes: [{
|
|
369
|
+
type: Input
|
|
370
|
+
}], pageCount: [{
|
|
371
|
+
type: Input
|
|
372
|
+
}], showDeleteColumn: [{
|
|
373
|
+
type: Input
|
|
374
|
+
}], hideKebabRowIndex: [{
|
|
375
|
+
type: Input
|
|
376
|
+
}], resize: [{
|
|
377
|
+
type: HostListener,
|
|
378
|
+
args: ['window:resize', ['$event']]
|
|
379
|
+
}] } });
|
|
380
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid-pagination.component.js","sourceRoot":"","sources":["../../../../../../projects/shared/src/lib/molecules/grid-pagination/grid-pagination.component.ts","../../../../../../projects/shared/src/lib/molecules/grid-pagination/grid-pagination.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit,\n  AfterViewInit,\n  Component,\n  ContentChild,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  OnChanges,\n  OnInit,\n  Output,\n  SimpleChanges,\n  TemplateRef,\n  ViewChild,\n} from '@angular/core';\nimport {\n  SelectableSettings,\n  SelectableMode,\n  CellClickEvent,\n  GridComponent,\n  GridDataResult,\n  PageChangeEvent,\n} from '@progress/kendo-angular-grid';\nimport { SortDescriptor, orderBy } from '@progress/kendo-data-query';\nimport {\n  SVGIcon,\n  chevronDownIcon,\n  chevronUpIcon,\n  moreVerticalIcon\n} from '@progress/kendo-svg-icons';\n\n@Component({\n  selector: 'lib-grid-pagination',\n  templateUrl: './grid-pagination.component.html',\n  styleUrls: ['./grid-pagination.component.scss'],\n})\nexport class GridPaginationComponent\n  implements OnInit, AfterContentInit, OnChanges, AfterViewInit\n{\n  @ContentChild('multiColumnData') templateRef!: TemplateRef<any> | null;\n  @ContentChild('detailTemplate') detailTemplate!: TemplateRef<any> | null;\n  @ContentChild('impactColumn') impactColumn!: TemplateRef<any> | null;\n  @ViewChild(GridComponent) grid!: GridComponent;\n  @ViewChild('gridElement') gridElement!: ElementRef;\n\n  @Input() gridView: GridDataResult = { data: [], total: 0 };\n  @Input() skip: number = 0;\n  @Input() columnData: any = [];\n  @Input() pageSize: number = 0;\n  @Input() pageable: boolean = false;\n  @Input() sortable: boolean = false;\n  @Input() groupable: boolean = false;\n  @Input() reorderable: boolean = false;\n  @Input() resizable: boolean = false;\n  @Input() checkBoxWidth: number = 45;\n  @Input() checkBoxColumnResizable: boolean = false;\n  @Input() checkBoxColumnMenu: boolean = false;\n  @Input() checkBoxColumnShowSelectedAll: boolean = true;\n  @Input() checkBoxRequired: boolean = false;\n  @Input() columnMenu: boolean = false;\n  @Input() mode: SelectableMode | undefined = 'multiple';\n  @Input() checkboxOnly = true;\n  @Input() dragColumns = false;\n  @Input() navigable: boolean = true;\n  height: any;\n  @Input() gridRowSelectByValue: string = '';\n  @Input() noRecordsContent: string = 'No Records Available';\n  @Output() selectedRowData = new EventEmitter<any[]>();\n  @Input() showToolbar: boolean = false;\n  extractDataItems: any;\n  selectableSettings: SelectableSettings = {};\n  @Input() kebabList: any = [];\n  @Input() showKebab: boolean = false;\n  @Output() rowDetails = new EventEmitter<any[]>();\n  @Output() kebabItemClick = new EventEmitter<any>();\n  @Input() icon: SVGIcon = moreVerticalIcon;\n  @Input() kebabColumnWidth: number = 60;\n  data: any = [];\n  @Input() selectColumn = '';\n  @Output() rowDataOfClickedCell = new EventEmitter<any>();\n  @Input() preSelected: any[] = [];\n  preSelectedRecords: any[] = [];\n  @Output() onPageChange = new EventEmitter<any>();\n  @Input() ignoreColumnCellClick: number[] = [];\n  @Input() allowColumnClick: boolean = false;\n  @Input() sort: SortDescriptor[] = [\n    {\n      field: '',\n      dir: undefined,\n    },\n  ];\n  @Input() hasApiSorting = false;\n  @Output() sortDirection = new EventEmitter<any>();\n  public arrowDownIcon: SVGIcon = chevronDownIcon;\n  public arrowUpIcon: SVGIcon = chevronUpIcon;\n  @Input() expandRowIndex: number[] = [];\n  @Input() customExpandRowColumn: boolean = false;\n  @Input() deleteColumnWidth: number = 42;\n  @Input() expandRowColumnWidth: number = 42;\n  @Output() deletedRowData = new EventEmitter<any>();\n  @Input() sizes: any[] = [];\n  @Input() pageCount = 0;\n  @Input() showDeleteColumn = false;\n  @Input() hideKebabRowIndex: number[] = [];\n  initialGridHeight: any;\n  gridBottomSpace = 24;\n  resizeHeight: any = 0;\n\n  constructor() {\n    this.setSelectableSettings();\n  }\n\n  ngOnInit() {\n    for (let column of this.columnData) {\n      column.sortable = column.sortable == undefined ? true : column.sortable;\n    }\n    if (!this.hasApiSorting) {\n      this.loadGridData();\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    let prevPreSelected = JSON.stringify(changes['preSelected']?.previousValue);\n    let currPreSelected = JSON.stringify(changes['preSelected']?.currentValue);\n    // Check if there is a change in this.preSelected input\n    if (prevPreSelected !== currPreSelected) {\n      // Clear the this.preSelectedRecords array\n      this.preSelectedRecords = [];\n      for (\n        let row = 0;\n        row < changes['preSelected'].currentValue.length;\n        row++\n      ) {\n        for (let col = 0; col < this.gridView.data.length; col++) {\n          // Find the relevant record for a particular id\n          if (\n            this.gridView.data[col][this.gridRowSelectByValue] ===\n            changes['preSelected'].currentValue[row]\n          ) {\n            let found = false;\n            // Check if this record is present in this.data, if yes don't push it in this.preSelectedRecords else push it\n            for (let index = 0; index < this.data.length; index++) {\n              if (\n                this.data[index][this.gridRowSelectByValue] ===\n                this.gridView.data[col][this.gridRowSelectByValue]\n              ) {\n                found = true;\n              }\n            }\n            if (!found) {\n              this.preSelectedRecords.push(this.gridView.data[col]);\n            }\n          }\n        }\n      }\n      this.selectedRowData.emit(this.preSelectedRecords.concat(this.data));\n    }\n  }\n\n  ngAfterContentInit(): void {\n    if (!this.pageable) {\n      this.pageSize = this.gridView.data.length;\n    }\n  }\n\n  ngAfterViewInit() {\n    if (this.customExpandRowColumn) {\n      this.expandRowIndex.forEach((id) => {\n        this.grid.expandRow(id);\n      });\n    }\n    this.initialGridHeight = this.gridElement.nativeElement.offsetHeight + this.gridBottomSpace;\n    this.getGridHeight();\n  }\n\n  pageChange(event: PageChangeEvent) {\n    this.onPageChange.emit(event);\n  }\n\n  setSelectableSettings(): void {\n    if (this.checkboxOnly || this.mode === 'single') {\n      this.dragColumns = false;\n    }\n\n    this.selectableSettings = {\n      checkboxOnly: this.checkboxOnly,\n      mode: this.mode,\n      drag: this.dragColumns,\n    };\n  }\n\n  // We can extract data out of row number using below function\n  /* extract() {\n    this.extractDataItems = this.mySelection.map(idx => {\n      return this.gridData.find((data: { ProductID: number; }) => data.ProductID === idx);\n    });\n    console.log(this.extractDataItems)\n    this.selectedRowData.emit(this.extractDataItems);\n  } */\n\n  onSelectionChange(args: any): any {\n    for (let row = 0; row < args.selectedRows.length; row++) {\n      var found = false;\n      for (let col = 0; col < this.data.length; col++) {\n        if (\n          this.data[col][this.gridRowSelectByValue] ===\n          args.selectedRows[row].dataItem[this.gridRowSelectByValue]\n        ) {\n          found = true;\n        }\n      }\n      if (!found) {\n        this.data.push(args.selectedRows[row].dataItem);\n      }\n    }\n    if (args.deselectedRows.length !== 0) {\n      for (let row = 0; row < args.deselectedRows.length; row++) {\n        for (let col = 0; col < this.data.length; col++) {\n          if (\n            this.data[col][this.gridRowSelectByValue] ===\n            args.deselectedRows[row].dataItem[this.gridRowSelectByValue]\n          ) {\n            this.data.splice(col, 1);\n          }\n        }\n        for (let col = 0; col < this.preSelectedRecords.length; col++) {\n          if (\n            this.preSelectedRecords[col][this.gridRowSelectByValue] ===\n            args.deselectedRows[row].dataItem[this.gridRowSelectByValue]\n          ) {\n            this.preSelectedRecords.splice(col, 1);\n            // Remove this element from preselected\n            let index = this.preSelected.indexOf(\n              args.deselectedRows[row].dataItem[this.gridRowSelectByValue]\n            );\n            if (index !== -1) {\n              this.preSelected.splice(index, 1);\n            }\n          }\n        }\n      }\n    }\n    this.selectedRowData.emit(this.preSelectedRecords.concat(this.data));\n  }\n\n  onKebabClick(item: any, rowDetails: any) {\n    this.kebabItemClick.emit({ action: item, rowDetails });\n  }\n\n  onDetailExpand(rowData: any) {\n    this.rowDetails.emit(rowData.dataItem);\n  }\n\n  cellClickHandler(args: CellClickEvent) {\n    if (this.allowColumnClick) {\n      if (this.ignoreColumnCellClick.includes(args.columnIndex)) {\n        return;\n      }\n      this.rowDataOfClickedCell.emit(args.dataItem);\n    }\n  }\n\n  sortChange(sort: SortDescriptor[]): void {\n    this.sort = sort;\n    if (!this.hasApiSorting) {\n      this.loadGridData();\n    }\n    this.sortDirection.emit(this.sort);\n  }\n\n  loadGridData(): void {\n    this.gridView = {\n      data: orderBy(this.gridView?.data, this.sort),\n      total: this.gridView?.total,\n    };\n  }\n\n  expandRow(id: number) {\n    this.grid.expandRow(id);\n    this.expandRowIndex.push(id);\n    setTimeout(()=>{\n      this.getGridHeight();\n    },0)\n  }\n\n  collapseRow(id: number) {\n    this.grid.collapseRow(id);\n    this.expandRowIndex.splice(this.expandRowIndex.indexOf(id), 1);\n    if (this.expandRowIndex.length == 0) {\n      const windowHeight = window.innerHeight;\n      const viewport: any = document.getElementById('lib-grid');\n      const gridOffset = viewport.getBoundingClientRect().top + window.scrollY;\n      if (windowHeight > (gridOffset + this.initialGridHeight)) {\n        this.height = '100%';\n        return;\n      }\n      this.getGridHeight();\n    }\n  }\n\n  onDelete(rowDetails: any) {\n    this.deletedRowData.emit(rowDetails);\n  }\n\n  getHeaderHeight() {\n    if (this.gridView?.data?.length === 0) {\n      return 'hide-header';\n    }\n    return 'view-header';\n  }\n\n  getGridHeight() {\n    const windowHeight = window.innerHeight;\n    const viewport: any = document.getElementById('lib-grid');\n    const gridOffset = viewport.getBoundingClientRect().top + window.scrollY;\n    const gridHeight = this.gridElement.nativeElement.offsetHeight \n                        + this.gridBottomSpace; //grid should have 24px space at bottom\n    if (gridOffset + gridHeight >= windowHeight) {\n      this.height = windowHeight - (gridOffset + this.gridBottomSpace);\n    }\n  }\n\n  @HostListener('window:resize', ['$event'])\n  resize(ev: any) {\n    if (ev.target.innerHeight > this.resizeHeight) {\n      this.resizeHeight = ev.target.innerHeight;\n      this.height = '100%';\n    }\n    if (this.resizeHeight > window.innerHeight) {\n      this.resizeHeight = 0;\n    }\n    this.getGridHeight();\n  }\n}\n","<div #gridElement (window:resize)=\"resize($event)\" >\n<kendo-grid [data]=\"gridView\" [pageSize]=\"pageSize\" [skip]=\"skip\" [selectable]=\"selectableSettings\"\n  [pageable]=\"pageable\" [sortable]=\"sortable\" [groupable]=\"groupable\" [reorderable]=\"reorderable\"\n  [resizable]=\"resizable\" [columnMenu]=\"columnMenu\" [navigable]=\"navigable\" [height]=\"height\" [style.height]=\"height\"\n  (change)=\"setSelectableSettings()\" (selectionChange)=\"onSelectionChange($event)\"\n  [kendoGridSelectBy]=\"gridRowSelectByValue\" (detailExpand)=\"onDetailExpand($event)\" [selectedKeys]=\"preSelected\"\n  (pageChange)=\"pageChange($event)\" (cellClick)=\"cellClickHandler($event)\" [sort]=\"sort\"\n  (sortChange)=\"sortChange($event)\" [ngClass]=\"getHeaderHeight()\" id=\"lib-grid\">\n\n  <ng-template *ngIf=\"showToolbar\" kendoGridToolbarTemplate>\n    <ng-content></ng-content>\n  </ng-template>\n\n  <ng-template *ngIf=\"this.gridView.data.length === 0\" kendoGridNoRecordsTemplate>\n    <lib-typography [defaultText]=\"noRecordsContent\" type=\"P_MULISH_16_REGULAR\"></lib-typography>\n  </ng-template>\n\n  <ng-container *ngIf=\"this.gridView.data.length > 0\">\n    <kendo-grid-checkbox-column *ngIf=\"checkBoxRequired === true\" [width]=\"checkBoxWidth\"\n      [resizable]=\"checkBoxColumnResizable\" [columnMenu]=\"checkBoxColumnMenu\"\n      [showSelectAll]=\"checkBoxColumnShowSelectedAll\" class=\"checkbox-column\">\n    </kendo-grid-checkbox-column>\n\n    <kendo-grid-column class=\"grid-column\" *ngFor=\"let item of columnData\" [field]=\"item.field\" [title]=\"item.title\"\n      [width]=\"item.columnWidth\" [sortable]=\"item.sortable\">\n\n      <ng-template *ngIf=\"sortable\" kendoGridHeaderTemplate>\n        {{item.title}}\n        <span *ngIf=\"sort[0].field === item.field\">\n          <span *ngIf=\"sort[0].dir === 'asc'\"></span>\n          <span *ngIf=\"sort[0].dir === 'desc'\"></span>\n        </span>\n      </ng-template>\n\n      <ng-template *ngIf=\"item.custom\" kendoGridCellTemplate let-dataItem>\n        <ng-container *ngTemplateOutlet=\"templateRef; context: {$implicit: dataItem}\"></ng-container>\n      </ng-template>\n      <ng-template *ngIf=\"item.impact\" kendoGridCellTemplate let-dataItem>\n        <ng-container *ngTemplateOutlet=\"impactColumn; context: {$implicit: dataItem}\"></ng-container>\n      </ng-template>\n    </kendo-grid-column>\n\n    <kendo-grid-column *ngIf=\"showDeleteColumn\" [width]=\"deleteColumnWidth\" class=\"delete-column\" title=\"Action\">\n      <ng-template kendoGridCellTemplate let-dataItem let-rowIndex=\"rowIndex\">\n        <lib-tooltip showOn=\"hover\" position=\"bottom\" class=\"remove-tooltip\">\n            <lib-icon name=\"delete\" class=\"delete-icon\" (click)=\"onDelete(dataItem)\"></lib-icon>\n          <div class=\"tooltip-content\">\n            <lib-typography defaultText=\"Remove\"></lib-typography>\n          </div>\n        </lib-tooltip>\n      </ng-template>\n    </kendo-grid-column>\n\n    <kendo-grid-column [width]=\"kebabColumnWidth\" class=\"kebab-column\" *ngIf=\"showKebab\" title=\"Actions\">\n      <ng-template kendoGridCellTemplate let-dataItem let-rowIndex=\"rowIndex\">\n        <kendo-dropdownbutton *ngIf=\"!hideKebabRowIndex.includes(rowIndex)\" [svgIcon]=\"icon\" fillMode=\"none\" [data]=\"kebabList | kebabMenuFilter : dataItem\"  class=\"kebab\"\n          (itemClick)=\"onKebabClick($event, dataItem)\" [popupSettings]=\"{ align: 'right', animate: true, popupClass: 'kebab-list' }\">\n        </kendo-dropdownbutton>\n      </ng-template>\n    </kendo-grid-column>\n  </ng-container>\n\n  <ng-template kendoGridDetailTemplate let-dataItem>\n    <ng-container *ngTemplateOutlet=\"detailTemplate; context: {$implicit: dataItem}\"></ng-container>\n  </ng-template>\n\n  <kendo-grid-column *ngIf=\"customExpandRowColumn\" [width]=\"expandRowColumnWidth\" class=\"grid-column expand-column\">\n    <ng-template kendoGridCellTemplate let-dataItem let-rowIndex=\"rowIndex\">\n      <kendo-button *ngIf=\"!expandRowIndex.includes(rowIndex)\" [svgIcon]=\"arrowDownIcon\" (click)=\"expandRow(rowIndex)\"\n        fillMode=\"none\" class=\"arrow-btn\">\n      </kendo-button>\n      <kendo-button *ngIf=\"expandRowIndex.includes(rowIndex)\" [svgIcon]=\"arrowUpIcon\" (click)=\"collapseRow(rowIndex)\"\n        fillMode=\"none\" class=\"arrow-btn\">\n      </kendo-button>\n    </ng-template>\n  </kendo-grid-column>\n\n  <ng-template kendoPagerTemplate let-totalPages=\"totalPages\" let-currentPage=\"currentPage\">\n    <kendo-pager-prev-buttons></kendo-pager-prev-buttons>\n    <kendo-pager-numeric-buttons [buttonCount]=\"pageCount\"></kendo-pager-numeric-buttons>\n    <kendo-pager-next-buttons></kendo-pager-next-buttons>\n    <kendo-pager-info></kendo-pager-info>\n    <kendo-pager-page-sizes [pageSizes]=\"sizes\"></kendo-pager-page-sizes>\n  </ng-template>\n\n</kendo-grid>\n</div>\n"]}
|
|
@@ -0,0 +1,69 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { GridPaginationComponent } from './grid-pagination.component';
|
|
4
|
+
import { GridModule } from '@progress/kendo-angular-grid';
|
|
5
|
+
import { ButtonsModule } from '@progress/kendo-angular-buttons';
|
|
6
|
+
import { InputsModule } from '@progress/kendo-angular-inputs';
|
|
7
|
+
import { DialogModule } from '@progress/kendo-angular-dialog';
|
|
8
|
+
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
9
|
+
import { TypographyModule } from './../../atoms/typography/typography.module';
|
|
10
|
+
import { IconModule } from '../../atoms/icon/icon.module';
|
|
11
|
+
import { IconsModule } from "@progress/kendo-angular-icons";
|
|
12
|
+
import { TooltipModule } from '../../atoms/tooltip/tooltip.module';
|
|
13
|
+
import { GridPaginationSpacerComponent } from './grid-pagination-spacer/grid-pagination-spacer.component';
|
|
14
|
+
import { KebabMenuFilterPipe } from './kebab-menu-filter.pipe';
|
|
15
|
+
import * as i0 from "@angular/core";
|
|
16
|
+
export class GridPaginationModule {
|
|
17
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: GridPaginationModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
|
|
18
|
+
static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: GridPaginationModule, declarations: [GridPaginationComponent,
|
|
19
|
+
GridPaginationSpacerComponent,
|
|
20
|
+
GridPaginationSpacerComponent,
|
|
21
|
+
KebabMenuFilterPipe], imports: [CommonModule,
|
|
22
|
+
ButtonsModule,
|
|
23
|
+
IconModule,
|
|
24
|
+
IconsModule,
|
|
25
|
+
InputsModule,
|
|
26
|
+
GridModule,
|
|
27
|
+
DialogModule,
|
|
28
|
+
FormsModule,
|
|
29
|
+
TooltipModule,
|
|
30
|
+
ReactiveFormsModule,
|
|
31
|
+
TypographyModule], exports: [GridPaginationComponent, GridPaginationSpacerComponent] }); }
|
|
32
|
+
static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: GridPaginationModule, imports: [CommonModule,
|
|
33
|
+
ButtonsModule,
|
|
34
|
+
IconModule,
|
|
35
|
+
IconsModule,
|
|
36
|
+
InputsModule,
|
|
37
|
+
GridModule,
|
|
38
|
+
DialogModule,
|
|
39
|
+
FormsModule,
|
|
40
|
+
TooltipModule,
|
|
41
|
+
ReactiveFormsModule,
|
|
42
|
+
TypographyModule] }); }
|
|
43
|
+
}
|
|
44
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: GridPaginationModule, decorators: [{
|
|
45
|
+
type: NgModule,
|
|
46
|
+
args: [{
|
|
47
|
+
declarations: [
|
|
48
|
+
GridPaginationComponent,
|
|
49
|
+
GridPaginationSpacerComponent,
|
|
50
|
+
GridPaginationSpacerComponent,
|
|
51
|
+
KebabMenuFilterPipe
|
|
52
|
+
],
|
|
53
|
+
imports: [
|
|
54
|
+
CommonModule,
|
|
55
|
+
ButtonsModule,
|
|
56
|
+
IconModule,
|
|
57
|
+
IconsModule,
|
|
58
|
+
InputsModule,
|
|
59
|
+
GridModule,
|
|
60
|
+
DialogModule,
|
|
61
|
+
FormsModule,
|
|
62
|
+
TooltipModule,
|
|
63
|
+
ReactiveFormsModule,
|
|
64
|
+
TypographyModule
|
|
65
|
+
],
|
|
66
|
+
exports: [GridPaginationComponent, GridPaginationSpacerComponent],
|
|
67
|
+
}]
|
|
68
|
+
}] });
|
|
69
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JpZC1wYWdpbmF0aW9uLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3NoYXJlZC9zcmMvbGliL21vbGVjdWxlcy9ncmlkLXBhZ2luYXRpb24vZ3JpZC1wYWdpbmF0aW9uLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUN0RSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDMUQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQ2hFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUM5RCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDOUQsT0FBTyxFQUFFLFdBQVcsRUFBRSxtQkFBbUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLDRDQUE0QyxDQUFDO0FBQzlFLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQztBQUMxRCxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sK0JBQStCLENBQUM7QUFDNUQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLG9DQUFvQyxDQUFDO0FBQ25FLE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxNQUFNLDJEQUEyRCxDQUFDO0FBQzFHLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLDBCQUEwQixDQUFDOztBQXdCL0QsTUFBTSxPQUFPLG9CQUFvQjsrR0FBcEIsb0JBQW9CO2dIQUFwQixvQkFBb0IsaUJBcEI3Qix1QkFBdUI7WUFDdkIsNkJBQTZCO1lBQzdCLDZCQUE2QjtZQUM3QixtQkFBbUIsYUFHbkIsWUFBWTtZQUNaLGFBQWE7WUFDYixVQUFVO1lBQ1YsV0FBVztZQUNYLFlBQVk7WUFDWixVQUFVO1lBQ1YsWUFBWTtZQUNaLFdBQVc7WUFDWCxhQUFhO1lBQ2IsbUJBQW1CO1lBQ25CLGdCQUFnQixhQUVSLHVCQUF1QixFQUFFLDZCQUE2QjtnSEFFckQsb0JBQW9CLFlBZDdCLFlBQVk7WUFDWixhQUFhO1lBQ2IsVUFBVTtZQUNWLFdBQVc7WUFDWCxZQUFZO1lBQ1osVUFBVTtZQUNWLFlBQVk7WUFDWixXQUFXO1lBQ1gsYUFBYTtZQUNiLG1CQUFtQjtZQUNuQixnQkFBZ0I7OzRGQUlQLG9CQUFvQjtrQkF0QmhDLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLHVCQUF1Qjt3QkFDdkIsNkJBQTZCO3dCQUM3Qiw2QkFBNkI7d0JBQzdCLG1CQUFtQjtxQkFDcEI7b0JBQ0QsT0FBTyxFQUFFO3dCQUNQLFlBQVk7d0JBQ1osYUFBYTt3QkFDYixVQUFVO3dCQUNWLFdBQVc7d0JBQ1gsWUFBWTt3QkFDWixVQUFVO3dCQUNWLFlBQVk7d0JBQ1osV0FBVzt3QkFDWCxhQUFhO3dCQUNiLG1CQUFtQjt3QkFDbkIsZ0JBQWdCO3FCQUNqQjtvQkFDRCxPQUFPLEVBQUUsQ0FBQyx1QkFBdUIsRUFBRSw2QkFBNkIsQ0FBQztpQkFDbEUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IEdyaWRQYWdpbmF0aW9uQ29tcG9uZW50IH0gZnJvbSAnLi9ncmlkLXBhZ2luYXRpb24uY29tcG9uZW50JztcbmltcG9ydCB7IEdyaWRNb2R1bGUgfSBmcm9tICdAcHJvZ3Jlc3Mva2VuZG8tYW5ndWxhci1ncmlkJztcbmltcG9ydCB7IEJ1dHRvbnNNb2R1bGUgfSBmcm9tICdAcHJvZ3Jlc3Mva2VuZG8tYW5ndWxhci1idXR0b25zJztcbmltcG9ydCB7IElucHV0c01vZHVsZSB9IGZyb20gJ0Bwcm9ncmVzcy9rZW5kby1hbmd1bGFyLWlucHV0cyc7XG5pbXBvcnQgeyBEaWFsb2dNb2R1bGUgfSBmcm9tICdAcHJvZ3Jlc3Mva2VuZG8tYW5ndWxhci1kaWFsb2cnO1xuaW1wb3J0IHsgRm9ybXNNb2R1bGUsIFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBUeXBvZ3JhcGh5TW9kdWxlIH0gZnJvbSAnLi8uLi8uLi9hdG9tcy90eXBvZ3JhcGh5L3R5cG9ncmFwaHkubW9kdWxlJztcbmltcG9ydCB7IEljb25Nb2R1bGUgfSBmcm9tICcuLi8uLi9hdG9tcy9pY29uL2ljb24ubW9kdWxlJztcbmltcG9ydCB7IEljb25zTW9kdWxlIH0gZnJvbSBcIkBwcm9ncmVzcy9rZW5kby1hbmd1bGFyLWljb25zXCI7XG5pbXBvcnQgeyBUb29sdGlwTW9kdWxlIH0gZnJvbSAnLi4vLi4vYXRvbXMvdG9vbHRpcC90b29sdGlwLm1vZHVsZSc7XG5pbXBvcnQgeyBHcmlkUGFnaW5hdGlvblNwYWNlckNvbXBvbmVudCB9IGZyb20gJy4vZ3JpZC1wYWdpbmF0aW9uLXNwYWNlci9ncmlkLXBhZ2luYXRpb24tc3BhY2VyLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBLZWJhYk1lbnVGaWx0ZXJQaXBlIH0gZnJvbSAnLi9rZWJhYi1tZW51LWZpbHRlci5waXBlJztcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgR3JpZFBhZ2luYXRpb25Db21wb25lbnQsIFxuICAgIEdyaWRQYWdpbmF0aW9uU3BhY2VyQ29tcG9uZW50LCBcbiAgICBHcmlkUGFnaW5hdGlvblNwYWNlckNvbXBvbmVudCxcbiAgICBLZWJhYk1lbnVGaWx0ZXJQaXBlXG4gIF0sXG4gIGltcG9ydHM6IFtcbiAgICBDb21tb25Nb2R1bGUsXG4gICAgQnV0dG9uc01vZHVsZSxcbiAgICBJY29uTW9kdWxlLFxuICAgIEljb25zTW9kdWxlLFxuICAgIElucHV0c01vZHVsZSxcbiAgICBHcmlkTW9kdWxlLFxuICAgIERpYWxvZ01vZHVsZSxcbiAgICBGb3Jtc01vZHVsZSxcbiAgICBUb29sdGlwTW9kdWxlLFxuICAgIFJlYWN0aXZlRm9ybXNNb2R1bGUsXG4gICAgVHlwb2dyYXBoeU1vZHVsZVxuICBdLFxuICBleHBvcnRzOiBbR3JpZFBhZ2luYXRpb25Db21wb25lbnQsIEdyaWRQYWdpbmF0aW9uU3BhY2VyQ29tcG9uZW50XSxcbn0pXG5leHBvcnQgY2xhc3MgR3JpZFBhZ2luYXRpb25Nb2R1bGUgeyB9XG4iXX0=
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import { Pipe } from "@angular/core";
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
export class KebabMenuFilterPipe {
|
|
4
|
+
transform(menu, ...args) {
|
|
5
|
+
const dataItem = args[0];
|
|
6
|
+
if (Array.isArray(menu)) {
|
|
7
|
+
return menu.filter((kebabItem) => {
|
|
8
|
+
return kebabItem?.isVisible ? kebabItem.isVisible(dataItem) : true;
|
|
9
|
+
});
|
|
10
|
+
}
|
|
11
|
+
return [];
|
|
12
|
+
}
|
|
13
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: KebabMenuFilterPipe, deps: [], target: i0.ɵɵFactoryTarget.Pipe }); }
|
|
14
|
+
static { this.ɵpipe = i0.ɵɵngDeclarePipe({ minVersion: "14.0.0", version: "16.2.12", ngImport: i0, type: KebabMenuFilterPipe, name: "kebabMenuFilter" }); }
|
|
15
|
+
}
|
|
16
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: KebabMenuFilterPipe, decorators: [{
|
|
17
|
+
type: Pipe,
|
|
18
|
+
args: [{
|
|
19
|
+
name: "kebabMenuFilter"
|
|
20
|
+
}]
|
|
21
|
+
}] });
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2ViYWItbWVudS1maWx0ZXIucGlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3NoYXJlZC9zcmMvbGliL21vbGVjdWxlcy9ncmlkLXBhZ2luYXRpb24va2ViYWItbWVudS1maWx0ZXIucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQzs7QUFLcEQsTUFBTSxPQUFPLG1CQUFtQjtJQUM5QixTQUFTLENBQUMsSUFBUyxFQUFFLEdBQUcsSUFBVztRQUNqQyxNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDekIsSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxFQUFFO1lBQ3ZCLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDLFNBQVMsRUFBRSxFQUFFO2dCQUMvQixPQUFPLFNBQVMsRUFBRSxTQUFTLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxTQUFTLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQztZQUNyRSxDQUFDLENBQUMsQ0FBQTtTQUNIO1FBQ0QsT0FBTyxFQUFFLENBQUM7SUFDWixDQUFDOytHQVRVLG1CQUFtQjs2R0FBbkIsbUJBQW1COzs0RkFBbkIsbUJBQW1CO2tCQUgvQixJQUFJO21CQUFDO29CQUNKLElBQUksRUFBRSxpQkFBaUI7aUJBQ3hCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUGlwZSwgUGlwZVRyYW5zZm9ybSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5cbkBQaXBlKHtcbiAgbmFtZTogXCJrZWJhYk1lbnVGaWx0ZXJcIlxufSlcbmV4cG9ydCBjbGFzcyBLZWJhYk1lbnVGaWx0ZXJQaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XG4gIHRyYW5zZm9ybShtZW51OiBhbnksIC4uLmFyZ3M6IGFueVtdKSB7XG4gICAgY29uc3QgZGF0YUl0ZW0gPSBhcmdzWzBdO1xuICAgIGlmIChBcnJheS5pc0FycmF5KG1lbnUpKSB7XG4gICAgICByZXR1cm4gbWVudS5maWx0ZXIoKGtlYmFiSXRlbSkgPT4ge1xuICAgICAgICByZXR1cm4ga2ViYWJJdGVtPy5pc1Zpc2libGUgPyBrZWJhYkl0ZW0uaXNWaXNpYmxlKGRhdGFJdGVtKSA6IHRydWU7XG4gICAgICB9KVxuICAgIH1cbiAgICByZXR1cm4gW107XG4gIH1cbn1cbiJdfQ==
|