@progress-chef/platform-shared-components 0.0.111 → 0.0.113
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/atoms/alert/alert.component.mjs +40 -0
- package/esm2022/lib/atoms/alert/alert.module.mjs +24 -0
- package/esm2022/lib/atoms/angular-popup/angular-popup.component.mjs +34 -0
- package/esm2022/lib/atoms/angular-popup/angular-popup.module.mjs +32 -0
- package/esm2022/lib/atoms/atoms.module.mjs +304 -0
- package/esm2022/lib/atoms/avatar/avatar.component.mjs +62 -0
- package/esm2022/lib/atoms/avatar/avatar.module.mjs +32 -0
- package/esm2022/lib/atoms/breadcrumb/breadcrumb.component.mjs +58 -0
- package/esm2022/lib/atoms/breadcrumb/breadcrumb.module.mjs +40 -0
- package/esm2022/lib/atoms/button/button.component.mjs +85 -0
- package/esm2022/lib/atoms/button/button.module.mjs +36 -0
- package/esm2022/lib/atoms/button-group/button-group.component.mjs +51 -0
- package/esm2022/lib/atoms/button-group/button-group.module.mjs +36 -0
- package/esm2022/lib/atoms/checkbox/checkbox.component.mjs +47 -0
- package/esm2022/lib/atoms/checkbox/checkbox.module.mjs +36 -0
- package/esm2022/lib/atoms/chip/chip.component.mjs +32 -0
- package/esm2022/lib/atoms/chip/chip.module.mjs +44 -0
- package/esm2022/lib/atoms/chip-list/chip-list.component.mjs +87 -0
- package/esm2022/lib/atoms/chip-list/chip-list.module.mjs +52 -0
- package/esm2022/lib/atoms/clipboard/clipboard.component.mjs +111 -0
- package/esm2022/lib/atoms/clipboard/clipboard.module.mjs +40 -0
- package/esm2022/lib/atoms/container/container.component.mjs +28 -0
- package/esm2022/lib/atoms/container/container.module.mjs +24 -0
- package/esm2022/lib/atoms/date-range/date-range.component.mjs +49 -0
- package/esm2022/lib/atoms/date-range/date-range.module.mjs +39 -0
- package/esm2022/lib/atoms/datepicker/datepicker.component.mjs +91 -0
- package/esm2022/lib/atoms/datepicker/datepicker.module.mjs +35 -0
- package/esm2022/lib/atoms/drag-and-drop/drag-and-drop.component.mjs +88 -0
- package/esm2022/lib/atoms/drag-and-drop/drag-and-drop.module.mjs +44 -0
- package/esm2022/lib/atoms/dropdown/dropdown.component.mjs +200 -0
- package/esm2022/lib/atoms/dropdown/dropdown.module.mjs +43 -0
- package/esm2022/lib/atoms/dropdown-button/dropdown-button.component.mjs +46 -0
- package/esm2022/lib/atoms/dropdown-button/dropdown-button.module.mjs +36 -0
- package/esm2022/lib/atoms/dropdown-tree/dropdowntree.component.mjs +102 -0
- package/esm2022/lib/atoms/dropdown-tree/dropdowntree.module.mjs +43 -0
- package/esm2022/lib/atoms/expansion-panel/expansion-panel.component.mjs +51 -0
- package/esm2022/lib/atoms/expansion-panel/expansion-panel.module.mjs +56 -0
- package/esm2022/lib/atoms/icon/icon.component.mjs +37 -0
- package/esm2022/lib/atoms/icon/icon.module.mjs +21 -0
- package/esm2022/lib/atoms/labels/label.component.mjs +25 -0
- package/esm2022/lib/atoms/labels/label.module.mjs +32 -0
- package/esm2022/lib/atoms/list-views/list-view.component.mjs +91 -0
- package/esm2022/lib/atoms/list-views/list-view.module.mjs +60 -0
- package/esm2022/lib/atoms/loader/loader.component.mjs +48 -0
- package/esm2022/lib/atoms/loader/loader.module.mjs +28 -0
- package/esm2022/lib/atoms/loading-spinner/loading-spinner.component.mjs +25 -0
- package/esm2022/lib/atoms/loading-spinner/loading-spinner.module.mjs +24 -0
- package/esm2022/lib/atoms/multi-select-dropdown/multi-select-dropdown.component.mjs +150 -0
- package/esm2022/lib/atoms/multi-select-dropdown/multi-select-dropdown.module.mjs +43 -0
- package/esm2022/lib/atoms/notification/notification.component.mjs +69 -0
- package/esm2022/lib/atoms/notification/notification.module.mjs +24 -0
- package/esm2022/lib/atoms/numeric-textbox/numeric-textbox.component.mjs +75 -0
- package/esm2022/lib/atoms/numeric-textbox/numeric-textbox.module.mjs +35 -0
- package/esm2022/lib/atoms/progress-bar/progress-bar.component.mjs +19 -0
- package/esm2022/lib/atoms/progress-bar/progress-bar.module.mjs +24 -0
- package/esm2022/lib/atoms/radio-button/radio-button.component.mjs +53 -0
- package/esm2022/lib/atoms/radio-button/radio-button.module.mjs +39 -0
- package/esm2022/lib/atoms/search-box/search-box.component.mjs +108 -0
- package/esm2022/lib/atoms/search-box/search-box.module.mjs +40 -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/stepper/stepper.component.mjs +38 -0
- package/esm2022/lib/atoms/stepper/stepper.module.mjs +52 -0
- package/esm2022/lib/atoms/switch/switch.component.mjs +53 -0
- package/esm2022/lib/atoms/switch/switch.module.mjs +59 -0
- package/esm2022/lib/atoms/text-area/text-area.component.mjs +93 -0
- package/esm2022/lib/atoms/text-area/text-area.module.mjs +36 -0
- package/esm2022/lib/atoms/textbox/textbox.component.mjs +115 -0
- package/esm2022/lib/atoms/textbox/textbox.module.mjs +40 -0
- package/esm2022/lib/atoms/time-picker/time-picker.component.mjs +83 -0
- package/esm2022/lib/atoms/time-picker/time-picker.module.mjs +35 -0
- package/esm2022/lib/atoms/timescheduler/timescheduler.component.mjs +79 -0
- package/esm2022/lib/atoms/timescheduler/timescheduler.module.mjs +35 -0
- package/esm2022/lib/atoms/toast-notification/toast-notification.module.mjs +31 -0
- package/esm2022/lib/atoms/toast-notification/toast-notification.service.mjs +160 -0
- package/esm2022/lib/atoms/tooltip/tooltip.component.mjs +48 -0
- package/esm2022/lib/atoms/tooltip/tooltip.module.mjs +24 -0
- package/esm2022/lib/atoms/typography/TypographyType.mjs +2 -0
- package/esm2022/lib/atoms/typography/typography.component.mjs +78 -0
- package/esm2022/lib/atoms/typography/typography.module.mjs +24 -0
- package/esm2022/lib/atoms/uploader/uploader.component.mjs +213 -0
- package/esm2022/lib/atoms/uploader/uploader.module.mjs +53 -0
- package/esm2022/lib/molecules/card/card-actions/card-actions.component.mjs +20 -0
- package/esm2022/lib/molecules/card/card-body/card-body.component.mjs +12 -0
- package/esm2022/lib/molecules/card/card-footer/card-footer.component.mjs +12 -0
- package/esm2022/lib/molecules/card/card-header/card-header.component.mjs +31 -0
- package/esm2022/lib/molecules/card/card.component.mjs +20 -0
- package/esm2022/lib/molecules/card/card.module.mjs +52 -0
- package/esm2022/lib/molecules/dialog/confirmation-dialog/confirmation-dialog.component.mjs +81 -0
- package/esm2022/lib/molecules/dialog/dialog-actions/dialog-actions.component.mjs +17 -0
- package/esm2022/lib/molecules/dialog/dialog-titlebar/dialog-titlebar.component.mjs +40 -0
- package/esm2022/lib/molecules/dialog/dialog.component.mjs +53 -0
- package/esm2022/lib/molecules/dialog/dialog.module.mjs +55 -0
- package/esm2022/lib/molecules/grid-form/grid-form.component.mjs +110 -0
- package/esm2022/lib/molecules/grid-form/grid-form.module.mjs +59 -0
- package/esm2022/lib/molecules/grid-layout/grid-layout-item/grid-layout-item.component.mjs +37 -0
- package/esm2022/lib/molecules/grid-layout/grid-layout.component.mjs +32 -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 +12 -0
- package/esm2022/lib/molecules/grid-pagination/grid-pagination.component.mjs +621 -0
- package/esm2022/lib/molecules/grid-pagination/grid-pagination.module.mjs +84 -0
- package/esm2022/lib/molecules/grid-pagination/kebab-menu-filter.pipe.mjs +22 -0
- package/esm2022/lib/molecules/molecules.module.mjs +66 -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 +4 -4
- package/esm2022/lib/shared.module.mjs +25 -10
- package/esm2022/public-api.mjs +114 -2
- package/fesm2022/progress-chef-platform-shared-components.mjs +5698 -14
- package/fesm2022/progress-chef-platform-shared-components.mjs.map +1 -1
- package/lib/atoms/alert/alert.component.d.ts +20 -0
- package/lib/atoms/alert/alert.module.d.ts +8 -0
- package/lib/atoms/angular-popup/angular-popup.component.d.ts +15 -0
- package/lib/atoms/angular-popup/angular-popup.module.d.ts +10 -0
- package/lib/atoms/atoms.module.d.ts +48 -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 +17 -0
- package/lib/atoms/breadcrumb/breadcrumb.module.d.ts +12 -0
- package/lib/atoms/button/button.component.d.ts +29 -0
- package/lib/atoms/button/button.module.d.ts +11 -0
- package/lib/atoms/button-group/button-group.component.d.ts +20 -0
- package/lib/atoms/button-group/button-group.module.d.ts +11 -0
- package/lib/atoms/checkbox/checkbox.component.d.ts +21 -0
- package/lib/atoms/checkbox/checkbox.module.d.ts +11 -0
- package/lib/atoms/chip/chip.component.d.ts +12 -0
- package/lib/atoms/chip/chip.module.d.ts +13 -0
- package/lib/atoms/chip-list/chip-list.component.d.ts +32 -0
- package/lib/atoms/chip-list/chip-list.module.d.ts +15 -0
- package/lib/atoms/clipboard/clipboard.component.d.ts +35 -0
- package/lib/atoms/clipboard/clipboard.module.d.ts +12 -0
- package/lib/atoms/container/container.component.d.ts +9 -0
- package/lib/atoms/container/container.module.d.ts +8 -0
- package/lib/atoms/date-range/date-range.component.d.ts +24 -0
- package/lib/atoms/date-range/date-range.module.d.ts +11 -0
- package/lib/atoms/datepicker/datepicker.component.d.ts +32 -0
- package/lib/atoms/datepicker/datepicker.module.d.ts +10 -0
- package/lib/atoms/drag-and-drop/drag-and-drop.component.d.ts +26 -0
- package/lib/atoms/drag-and-drop/drag-and-drop.module.d.ts +13 -0
- package/lib/atoms/dropdown/dropdown.component.d.ts +67 -0
- package/lib/atoms/dropdown/dropdown.module.d.ts +12 -0
- package/lib/atoms/dropdown-button/dropdown-button.component.d.ts +17 -0
- package/lib/atoms/dropdown-button/dropdown-button.module.d.ts +11 -0
- package/lib/atoms/dropdown-tree/dropdowntree.component.d.ts +35 -0
- package/lib/atoms/dropdown-tree/dropdowntree.module.d.ts +12 -0
- package/lib/atoms/expansion-panel/expansion-panel.component.d.ts +21 -0
- package/lib/atoms/expansion-panel/expansion-panel.module.d.ts +16 -0
- package/lib/atoms/icon/icon.component.d.ts +14 -0
- package/lib/atoms/icon/icon.module.d.ts +7 -0
- package/lib/atoms/labels/label.component.d.ts +12 -0
- package/lib/atoms/labels/label.module.d.ts +10 -0
- package/lib/atoms/list-views/list-view.component.d.ts +32 -0
- package/lib/atoms/list-views/list-view.module.d.ts +17 -0
- package/lib/atoms/loader/loader.component.d.ts +30 -0
- package/lib/atoms/loader/loader.module.d.ts +9 -0
- package/lib/atoms/loading-spinner/loading-spinner.component.d.ts +11 -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 +50 -0
- package/lib/atoms/multi-select-dropdown/multi-select-dropdown.module.d.ts +12 -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 +28 -0
- package/lib/atoms/numeric-textbox/numeric-textbox.module.d.ts +10 -0
- package/lib/atoms/progress-bar/progress-bar.component.d.ts +9 -0
- package/lib/atoms/progress-bar/progress-bar.module.d.ts +8 -0
- package/lib/atoms/radio-button/radio-button.component.d.ts +22 -0
- package/lib/atoms/radio-button/radio-button.module.d.ts +11 -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/stepper/stepper.component.d.ts +25 -0
- package/lib/atoms/stepper/stepper.module.d.ts +15 -0
- package/lib/atoms/switch/switch.component.d.ts +20 -0
- package/lib/atoms/switch/switch.module.d.ts +16 -0
- package/lib/atoms/text-area/text-area.component.d.ts +35 -0
- package/lib/atoms/text-area/text-area.module.d.ts +11 -0
- package/lib/atoms/textbox/textbox.component.d.ts +37 -0
- package/lib/atoms/textbox/textbox.module.d.ts +12 -0
- package/lib/atoms/time-picker/time-picker.component.d.ts +31 -0
- package/lib/atoms/time-picker/time-picker.module.d.ts +10 -0
- package/lib/atoms/timescheduler/timescheduler.component.d.ts +28 -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 +51 -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 +25 -0
- package/lib/atoms/typography/typography.module.d.ts +8 -0
- package/lib/atoms/uploader/uploader.component.d.ts +64 -0
- package/lib/atoms/uploader/uploader.module.d.ts +14 -0
- package/lib/molecules/card/card-actions/card-actions.component.d.ts +8 -0
- package/lib/molecules/card/card-body/card-body.component.d.ts +5 -0
- package/lib/molecules/card/card-footer/card-footer.component.d.ts +5 -0
- package/lib/molecules/card/card-header/card-header.component.d.ts +11 -0
- package/lib/molecules/card/card.component.d.ts +7 -0
- package/lib/molecules/card/card.module.d.ts +14 -0
- package/lib/molecules/dialog/confirmation-dialog/confirmation-dialog.component.d.ts +20 -0
- package/lib/molecules/dialog/dialog-actions/dialog-actions.component.d.ts +7 -0
- package/lib/molecules/dialog/dialog-titlebar/dialog-titlebar.component.d.ts +16 -0
- package/lib/molecules/dialog/dialog.component.d.ts +20 -0
- package/lib/molecules/dialog/dialog.module.d.ts +15 -0
- package/lib/molecules/grid-form/grid-form.component.d.ts +33 -0
- package/lib/molecules/grid-form/grid-form.module.d.ts +16 -0
- package/lib/molecules/grid-layout/grid-layout-item/grid-layout-item.component.d.ts +14 -0
- package/lib/molecules/grid-layout/grid-layout.component.d.ts +11 -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 +5 -0
- package/lib/molecules/grid-pagination/grid-pagination.component.d.ts +150 -0
- package/lib/molecules/grid-pagination/grid-pagination.module.d.ts +21 -0
- package/lib/molecules/grid-pagination/kebab-menu-filter.pipe.d.ts +7 -0
- package/lib/molecules/molecules.module.d.ts +14 -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.module.d.ts +5 -2
- package/package.json +32 -5
- package/public-api.d.ts +108 -1
|
@@ -0,0 +1,621 @@
|
|
|
1
|
+
import { Component, ContentChild, ContentChildren, Directive, EventEmitter, Input, Output, ViewChild } from '@angular/core';
|
|
2
|
+
import { FormControl, FormGroup, Validators } from '@angular/forms';
|
|
3
|
+
import { Keys } from '@progress/kendo-angular-common';
|
|
4
|
+
import { orderBy } from '@progress/kendo-data-query';
|
|
5
|
+
import { LoaderSize, LoaderThemeColor, LoaderType } from '../../atoms/loader/loader.component';
|
|
6
|
+
import { GridComponent } from '@progress/kendo-angular-grid';
|
|
7
|
+
import { chevronDownIcon, chevronUpIcon, moreVerticalIcon } from '@progress/kendo-svg-icons';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
import * as i1 from "@angular/common";
|
|
10
|
+
import * as i2 from "@progress/kendo-angular-buttons";
|
|
11
|
+
import * as i3 from "../../atoms/icon/icon.component";
|
|
12
|
+
import * as i4 from "@progress/kendo-angular-inputs";
|
|
13
|
+
import * as i5 from "@progress/kendo-angular-grid";
|
|
14
|
+
import * as i6 from "../../atoms/tooltip/tooltip.component";
|
|
15
|
+
import * as i7 from "../../atoms/typography/typography.component";
|
|
16
|
+
import * as i8 from "../../atoms/loader/loader.component";
|
|
17
|
+
import * as i9 from "../../atoms/button/button.component";
|
|
18
|
+
import * as i10 from "./grid-pagination-spacer/grid-pagination-spacer.component";
|
|
19
|
+
import * as i11 from "./kebab-menu-filter.pipe";
|
|
20
|
+
export class CustomColumnTemplate {
|
|
21
|
+
constructor(template) {
|
|
22
|
+
this.template = template;
|
|
23
|
+
this.type = "";
|
|
24
|
+
}
|
|
25
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CustomColumnTemplate, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
26
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.3.12", type: CustomColumnTemplate, selector: "ng-template[type]", inputs: { type: "type" }, ngImport: i0 }); }
|
|
27
|
+
}
|
|
28
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: CustomColumnTemplate, decorators: [{
|
|
29
|
+
type: Directive,
|
|
30
|
+
args: [{
|
|
31
|
+
selector: 'ng-template[type]'
|
|
32
|
+
}]
|
|
33
|
+
}], ctorParameters: () => [{ type: i0.TemplateRef }], propDecorators: { type: [{
|
|
34
|
+
type: Input
|
|
35
|
+
}] } });
|
|
36
|
+
const createFormGroup = (dataItem) => {
|
|
37
|
+
const form = new FormGroup({});
|
|
38
|
+
for (let data of Object.keys(dataItem)) {
|
|
39
|
+
form.addControl(data, new FormControl(dataItem[data], Validators.required));
|
|
40
|
+
}
|
|
41
|
+
return form;
|
|
42
|
+
};
|
|
43
|
+
export class GridPaginationComponent {
|
|
44
|
+
set preSelected(value) {
|
|
45
|
+
this._preSelected = value;
|
|
46
|
+
this.initGrid();
|
|
47
|
+
}
|
|
48
|
+
set gridView(value) {
|
|
49
|
+
this._gridView = value;
|
|
50
|
+
}
|
|
51
|
+
set pageCount(value) {
|
|
52
|
+
this._pageCount = value > 10 ? 10 : value;
|
|
53
|
+
}
|
|
54
|
+
constructor(cdRef, renderer) {
|
|
55
|
+
this.cdRef = cdRef;
|
|
56
|
+
this.renderer = renderer;
|
|
57
|
+
this.skip = 0;
|
|
58
|
+
this.itemName = 'Items';
|
|
59
|
+
this.showSelectAllMessage = false;
|
|
60
|
+
this.allPagesSelected = false;
|
|
61
|
+
this.previousSelectAllState = 'unchecked';
|
|
62
|
+
this.onSelectAllAcrossPages = new EventEmitter();
|
|
63
|
+
this.columnData = [];
|
|
64
|
+
this.pageSize = 0;
|
|
65
|
+
this.pageable = false;
|
|
66
|
+
this.sortable = false;
|
|
67
|
+
this.groupable = false;
|
|
68
|
+
this.reorderable = false;
|
|
69
|
+
this.resizable = false;
|
|
70
|
+
this.checkBoxWidth = 45;
|
|
71
|
+
this.checkBoxColumnResizable = false;
|
|
72
|
+
this.checkBoxColumnMenu = false;
|
|
73
|
+
this.checkBoxColumnShowSelectedAll = true;
|
|
74
|
+
this.checkBoxRequired = false;
|
|
75
|
+
this.columnMenu = false;
|
|
76
|
+
this.mode = 'multiple';
|
|
77
|
+
this.checkboxOnly = true;
|
|
78
|
+
this.dragColumns = false;
|
|
79
|
+
this.navigable = true;
|
|
80
|
+
this.gridRowSelectByValue = '';
|
|
81
|
+
this.noRecordsContent = 'No records are available yet.';
|
|
82
|
+
this.selectedRowData = new EventEmitter();
|
|
83
|
+
this.showToolbar = false;
|
|
84
|
+
this.selectableSettings = {};
|
|
85
|
+
this.kebabList = [];
|
|
86
|
+
this.showKebab = false;
|
|
87
|
+
this.rowDetails = new EventEmitter();
|
|
88
|
+
this.kebabItemClick = new EventEmitter();
|
|
89
|
+
this.icon = moreVerticalIcon;
|
|
90
|
+
this.kebabColumnWidth = 90;
|
|
91
|
+
this.data = [];
|
|
92
|
+
this.selectColumn = '';
|
|
93
|
+
this.rowDataOfClickedCell = new EventEmitter();
|
|
94
|
+
this._preSelected = [];
|
|
95
|
+
this._gridView = { data: [], total: 0 };
|
|
96
|
+
this.preSelectedRecords = [];
|
|
97
|
+
this.onPageChange = new EventEmitter();
|
|
98
|
+
this.ignoreColumnCellClick = [];
|
|
99
|
+
this.allowColumnClick = false;
|
|
100
|
+
this.sort = [
|
|
101
|
+
{
|
|
102
|
+
field: '',
|
|
103
|
+
dir: undefined,
|
|
104
|
+
},
|
|
105
|
+
];
|
|
106
|
+
this.hasApiSorting = false;
|
|
107
|
+
this.sortDirection = new EventEmitter();
|
|
108
|
+
this.arrowDownIcon = chevronDownIcon;
|
|
109
|
+
this.arrowUpIcon = chevronUpIcon;
|
|
110
|
+
this.expandRowIndex = [];
|
|
111
|
+
this.customExpandRowColumn = false;
|
|
112
|
+
this.deleteColumnWidth = 42;
|
|
113
|
+
this.expandRowColumnWidth = 56;
|
|
114
|
+
this.deletedRowData = new EventEmitter();
|
|
115
|
+
this.sizes = [];
|
|
116
|
+
this._pageCount = 0;
|
|
117
|
+
this.showDeleteColumn = false;
|
|
118
|
+
this.hideKebabRowIndex = [];
|
|
119
|
+
this.loading = false;
|
|
120
|
+
this.loaderType = LoaderType.pulsing;
|
|
121
|
+
this.loaderSize = LoaderSize.medium;
|
|
122
|
+
this.loaderTheme = LoaderThemeColor.primary;
|
|
123
|
+
this.gridBottomSpace = 24;
|
|
124
|
+
this.resizeHeight = 0;
|
|
125
|
+
this.selectAllState = 'unchecked';
|
|
126
|
+
this.selectedItemCount = 0;
|
|
127
|
+
this.selectedRows = [];
|
|
128
|
+
this.disablePreSelectedRows = false;
|
|
129
|
+
this.updatedData = new EventEmitter();
|
|
130
|
+
this.allowEditingCell = false;
|
|
131
|
+
this.columnContentNoWrap = false;
|
|
132
|
+
this.infiniteScrollLoader = false;
|
|
133
|
+
this.onscrollBottom = new EventEmitter();
|
|
134
|
+
this.isInfiniteScrollGrid = false;
|
|
135
|
+
this.gridLoading = false;
|
|
136
|
+
this.minResizableWidth = 50;
|
|
137
|
+
this.showRefresh = false;
|
|
138
|
+
this.isKebabColumnSticky = false;
|
|
139
|
+
this.isCheckBoxColumnSticky = false;
|
|
140
|
+
this.isDeleteColumnSticky = false;
|
|
141
|
+
this.emitRefreshEvt = new EventEmitter();
|
|
142
|
+
this.isSelectAllCheckboxRequired = true;
|
|
143
|
+
this.columnTemplateDict = {};
|
|
144
|
+
/*
|
|
145
|
+
* This logic of dynamically calculating the height of grid need further brainstorming hence commented for now.
|
|
146
|
+
*/
|
|
147
|
+
// getGridHeight() {
|
|
148
|
+
// const windowHeight = window.innerHeight;
|
|
149
|
+
// const viewport: any = document.getElementById('lib-grid');
|
|
150
|
+
// const gridOffset = viewport.getBoundingClientRect().top + window.scrollY;
|
|
151
|
+
// const gridHeight =
|
|
152
|
+
// this.gridElement.nativeElement.offsetHeight + this.gridBottomSpace; //grid should have 24px space at bottom
|
|
153
|
+
// if (gridOffset + gridHeight >= windowHeight) {
|
|
154
|
+
// this.height = windowHeight - (gridOffset + this.gridBottomSpace);
|
|
155
|
+
// }
|
|
156
|
+
// }
|
|
157
|
+
// @HostListener('window:resize', ['$event'])
|
|
158
|
+
// resize(ev: any) {
|
|
159
|
+
// if (ev.target.innerHeight > this.resizeHeight) {
|
|
160
|
+
// this.resizeHeight = ev.target.innerHeight;
|
|
161
|
+
// this.height = '100%';
|
|
162
|
+
// }
|
|
163
|
+
// if (this.resizeHeight > window.innerHeight) {
|
|
164
|
+
// this.resizeHeight = 0;
|
|
165
|
+
// }
|
|
166
|
+
// this.getGridHeight();
|
|
167
|
+
// }
|
|
168
|
+
this.rowClass = (args) => {
|
|
169
|
+
if (this.selectedRows && this.disablePreSelectedRows) {
|
|
170
|
+
return {
|
|
171
|
+
'k-disabled': this.selectedRows.includes(args.dataItem[this.gridRowSelectByValue]) || this.allPagesSelected,
|
|
172
|
+
};
|
|
173
|
+
}
|
|
174
|
+
return '';
|
|
175
|
+
};
|
|
176
|
+
this.setSelectableSettings();
|
|
177
|
+
}
|
|
178
|
+
ngOnInit() {
|
|
179
|
+
this.columnData.forEach((column, index) => {
|
|
180
|
+
column.sortable = column.sortable == undefined ? true : column.sortable;
|
|
181
|
+
if (!this.ignoreColumnCellClick.includes(index)) {
|
|
182
|
+
column.class = 'column-cursor-pointer';
|
|
183
|
+
}
|
|
184
|
+
});
|
|
185
|
+
if (!this.hasApiSorting) {
|
|
186
|
+
this.loadGridData();
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
scrollBottom() {
|
|
190
|
+
this.onscrollBottom.emit();
|
|
191
|
+
}
|
|
192
|
+
getPosition() {
|
|
193
|
+
if (this.showToolbar && this.infiniteScrollLoader) {
|
|
194
|
+
return 'both';
|
|
195
|
+
}
|
|
196
|
+
else if (this.showToolbar) {
|
|
197
|
+
return 'top';
|
|
198
|
+
}
|
|
199
|
+
else if (this.infiniteScrollLoader) {
|
|
200
|
+
return 'bottom';
|
|
201
|
+
}
|
|
202
|
+
else {
|
|
203
|
+
return;
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
ngAfterContentInit() {
|
|
207
|
+
if (!this.pageable) {
|
|
208
|
+
this.pageSize = this._gridView.data?.length;
|
|
209
|
+
}
|
|
210
|
+
this.columnTemplates.forEach(x => this.columnTemplateDict[x.type] = x.template);
|
|
211
|
+
}
|
|
212
|
+
ngAfterViewInit() {
|
|
213
|
+
this.initGrid();
|
|
214
|
+
}
|
|
215
|
+
initGrid() {
|
|
216
|
+
if (this.customExpandRowColumn) {
|
|
217
|
+
this.expandRowIndex.forEach((id) => {
|
|
218
|
+
this.grid.expandRow(id);
|
|
219
|
+
});
|
|
220
|
+
}
|
|
221
|
+
this.selectedRows = this._preSelected;
|
|
222
|
+
if (this.selectedRows?.length > 0) {
|
|
223
|
+
if (this.selectedRows?.length == this._gridView.total) {
|
|
224
|
+
this.selectAllState = 'checked';
|
|
225
|
+
}
|
|
226
|
+
else {
|
|
227
|
+
this.selectAllState = 'indeterminate';
|
|
228
|
+
}
|
|
229
|
+
}
|
|
230
|
+
else {
|
|
231
|
+
this.selectAllState = 'unchecked';
|
|
232
|
+
}
|
|
233
|
+
if (this.gridElement) {
|
|
234
|
+
this.initialGridHeight =
|
|
235
|
+
this.gridElement?.nativeElement?.offsetHeight + this.gridBottomSpace;
|
|
236
|
+
// this.getGridHeight();
|
|
237
|
+
const gridContainer = this.gridElement?.nativeElement?.getElementsByClassName('k-grid-container')[0];
|
|
238
|
+
if (gridContainer && this.selectAllMessageElement?.nativeElement) {
|
|
239
|
+
this.renderer.insertBefore(gridContainer.parentElement, this.selectAllMessageElement?.nativeElement, gridContainer, true);
|
|
240
|
+
}
|
|
241
|
+
const selectAllCheckbox = this.gridElement?.nativeElement?.querySelector('.select-all-header input');
|
|
242
|
+
if (selectAllCheckbox) {
|
|
243
|
+
this.renderer.setProperty(selectAllCheckbox, 'disabled', this.canEnableSelectAll());
|
|
244
|
+
}
|
|
245
|
+
this.cdRef.detectChanges();
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
selectAcrossPages(isSelected) {
|
|
249
|
+
this.triggerSelectAllPagesEvent(isSelected);
|
|
250
|
+
if (!isSelected) {
|
|
251
|
+
this.onSelectAllChange(this.previousSelectAllState);
|
|
252
|
+
}
|
|
253
|
+
}
|
|
254
|
+
triggerSelectAllPagesEvent(isSelected) {
|
|
255
|
+
this.allPagesSelected = isSelected;
|
|
256
|
+
this.onSelectAllAcrossPages.emit(isSelected);
|
|
257
|
+
this.selectedItemCount = isSelected ? this._gridView.total : 0;
|
|
258
|
+
console.log('triggerSelectAllPagesEvent : isSelected', isSelected);
|
|
259
|
+
}
|
|
260
|
+
addSelectAllMessage(selectAll) {
|
|
261
|
+
this.selectAllMsgParentElement = this.selectAllMessageElement?.nativeElement?.parentElement;
|
|
262
|
+
if (this.showSelectAllMessage && this.selectAllMsgParentElement && (this._pageCount > 1 || this.isInfiniteScrollGrid)) {
|
|
263
|
+
const selectAllMsgElement = this.selectAllMessageElement?.nativeElement?.querySelector('.lib-grid-select-all-message-container');
|
|
264
|
+
if (selectAll) {
|
|
265
|
+
const beforeHeight = this.selectAllMsgParentElement.offsetHeight;
|
|
266
|
+
selectAllMsgElement?.classList.add('lib-grid-select-all-message-show');
|
|
267
|
+
const afterHeight = this.selectAllMsgParentElement.offsetHeight;
|
|
268
|
+
this.selectAllMsgParentElement.style.height = (this.selectAllMsgParentElement.offsetHeight - (afterHeight - beforeHeight)) + 'px';
|
|
269
|
+
}
|
|
270
|
+
else {
|
|
271
|
+
selectAllMsgElement?.classList.remove('lib-grid-select-all-message-show');
|
|
272
|
+
if (this.allPagesSelected) {
|
|
273
|
+
this.triggerSelectAllPagesEvent(false);
|
|
274
|
+
}
|
|
275
|
+
}
|
|
276
|
+
}
|
|
277
|
+
}
|
|
278
|
+
pageChange(event) {
|
|
279
|
+
if (this.selectAllMsgParentElement) {
|
|
280
|
+
this.selectAllMsgParentElement.style.height = '';
|
|
281
|
+
}
|
|
282
|
+
this.onPageChange.emit(event);
|
|
283
|
+
}
|
|
284
|
+
setSelectableSettings() {
|
|
285
|
+
if (this.checkboxOnly || this.mode === 'single') {
|
|
286
|
+
this.dragColumns = false;
|
|
287
|
+
}
|
|
288
|
+
this.selectableSettings = {
|
|
289
|
+
checkboxOnly: this.checkboxOnly,
|
|
290
|
+
mode: this.mode,
|
|
291
|
+
drag: this.dragColumns,
|
|
292
|
+
};
|
|
293
|
+
}
|
|
294
|
+
// We can extract data out of row number using below function
|
|
295
|
+
/* extract() {
|
|
296
|
+
this.extractDataItems = this.mySelection.map(idx => {
|
|
297
|
+
return this.gridData.find((data: { ProductID: number; }) => data.ProductID === idx);
|
|
298
|
+
});
|
|
299
|
+
console.log(this.extractDataItems)
|
|
300
|
+
this.selectedRowData.emit(this.extractDataItems);
|
|
301
|
+
} */
|
|
302
|
+
selectedKeysChange(rows) {
|
|
303
|
+
let selectedRowData = [];
|
|
304
|
+
let selectedRowsCount = 0;
|
|
305
|
+
if (rows?.length > 0) {
|
|
306
|
+
selectedRowsCount = rows?.length;
|
|
307
|
+
}
|
|
308
|
+
else if (this.selectedRows?.length > 0 && this.disablePreSelectedRows) {
|
|
309
|
+
selectedRowsCount = this.selectedRows?.length;
|
|
310
|
+
rows = this.selectedRows;
|
|
311
|
+
}
|
|
312
|
+
this.previousSelectAllState = this.selectAllState;
|
|
313
|
+
this.selectAllState = this.getSelectAllState(selectedRowsCount);
|
|
314
|
+
if (this.selectAllState === 'unchecked' || this.selectAllState === 'indeterminate') {
|
|
315
|
+
this.addSelectAllMessage(false);
|
|
316
|
+
}
|
|
317
|
+
selectedRowData = rows.map(rowData => {
|
|
318
|
+
return this._gridView.data.find((data) => data[this.gridRowSelectByValue] === rowData);
|
|
319
|
+
});
|
|
320
|
+
this.selectedRowData.emit(selectedRowData);
|
|
321
|
+
}
|
|
322
|
+
getSelectAllState(selectedRowsCount) {
|
|
323
|
+
if (selectedRowsCount == this._gridView.total) {
|
|
324
|
+
this.selectAllState = 'checked';
|
|
325
|
+
}
|
|
326
|
+
else if (selectedRowsCount == 0) {
|
|
327
|
+
this.selectAllState = 'unchecked';
|
|
328
|
+
this.addSelectAllMessage(false);
|
|
329
|
+
}
|
|
330
|
+
else {
|
|
331
|
+
this.selectAllState = 'indeterminate';
|
|
332
|
+
this.addSelectAllMessage(false);
|
|
333
|
+
}
|
|
334
|
+
}
|
|
335
|
+
onKebabClick(item, rowDetails) {
|
|
336
|
+
this.kebabItemClick.emit({ action: item, rowDetails });
|
|
337
|
+
}
|
|
338
|
+
onDetailExpand(rowData) {
|
|
339
|
+
this.rowDetails.emit(rowData.dataItem);
|
|
340
|
+
}
|
|
341
|
+
cellClickHandler(args) {
|
|
342
|
+
if (this.allowColumnClick) {
|
|
343
|
+
if (this.ignoreColumnCellClick.includes(args.columnIndex)) {
|
|
344
|
+
return;
|
|
345
|
+
}
|
|
346
|
+
this.rowDataOfClickedCell.emit({ dataItem: args.dataItem, columnIndex: args.columnIndex });
|
|
347
|
+
}
|
|
348
|
+
if (this.allowEditingCell) {
|
|
349
|
+
this.formGroup = createFormGroup(args.dataItem);
|
|
350
|
+
args.sender.editCell(args.rowIndex, args.columnIndex, this.formGroup);
|
|
351
|
+
}
|
|
352
|
+
}
|
|
353
|
+
sortChange(sort) {
|
|
354
|
+
this.sort = sort;
|
|
355
|
+
if (!this.hasApiSorting) {
|
|
356
|
+
this.loadGridData();
|
|
357
|
+
}
|
|
358
|
+
this.sortDirection.emit(this.sort);
|
|
359
|
+
}
|
|
360
|
+
loadGridData() {
|
|
361
|
+
this._gridView = {
|
|
362
|
+
data: orderBy(this._gridView?.data, this.sort),
|
|
363
|
+
total: this._gridView?.total,
|
|
364
|
+
};
|
|
365
|
+
}
|
|
366
|
+
expandRow(id) {
|
|
367
|
+
this.grid.expandRow(id);
|
|
368
|
+
this.expandRowIndex.push(id);
|
|
369
|
+
// setTimeout(() => {
|
|
370
|
+
// this.getGridHeight();
|
|
371
|
+
// }, 0);
|
|
372
|
+
}
|
|
373
|
+
collapseRow(id) {
|
|
374
|
+
this.grid.collapseRow(id);
|
|
375
|
+
this.expandRowIndex.splice(this.expandRowIndex.indexOf(id), 1);
|
|
376
|
+
// if (this.expandRowIndex?.length == 0) {
|
|
377
|
+
// const windowHeight = window.innerHeight;
|
|
378
|
+
// const viewport: any = document.getElementById('lib-grid');
|
|
379
|
+
// const gridOffset = viewport.getBoundingClientRect().top + window.scrollY;
|
|
380
|
+
// if (windowHeight > gridOffset + this.initialGridHeight) {
|
|
381
|
+
// this.height = '100%';
|
|
382
|
+
// return;
|
|
383
|
+
// }
|
|
384
|
+
// // this.getGridHeight();
|
|
385
|
+
// }
|
|
386
|
+
}
|
|
387
|
+
onDelete(rowDetails) {
|
|
388
|
+
setTimeout(() => {
|
|
389
|
+
this.getHeaderHeight();
|
|
390
|
+
}, 1000);
|
|
391
|
+
this.deletedRowData.emit(rowDetails);
|
|
392
|
+
}
|
|
393
|
+
getHeaderHeight() {
|
|
394
|
+
if (this._gridView?.data?.length === 0) {
|
|
395
|
+
return 'hide-header';
|
|
396
|
+
}
|
|
397
|
+
return 'view-header';
|
|
398
|
+
}
|
|
399
|
+
expandColumnClass() {
|
|
400
|
+
if (this.selectedRows?.length > 0 && this.disablePreSelectedRows) {
|
|
401
|
+
this.expandRowColumnWidth = 194;
|
|
402
|
+
return 'expand-row';
|
|
403
|
+
}
|
|
404
|
+
this.expandRowColumnWidth = 56;
|
|
405
|
+
return '';
|
|
406
|
+
}
|
|
407
|
+
onSelectAllChange(checkedState) {
|
|
408
|
+
if (checkedState === 'checked') {
|
|
409
|
+
this._preSelected = this._gridView.data
|
|
410
|
+
.map((item) => item[this.gridRowSelectByValue])
|
|
411
|
+
.filter((id) => id);
|
|
412
|
+
this.selectAllState = 'checked';
|
|
413
|
+
this.selectedItemCount = this._gridView.data.length;
|
|
414
|
+
}
|
|
415
|
+
else if (this.selectedRows?.length > 0 && this.disablePreSelectedRows) {
|
|
416
|
+
this._preSelected = this.selectedRows;
|
|
417
|
+
this.selectAllState = 'indeterminate';
|
|
418
|
+
this.selectedItemCount = 0;
|
|
419
|
+
}
|
|
420
|
+
else {
|
|
421
|
+
this._preSelected = [];
|
|
422
|
+
this.selectAllState = 'unchecked';
|
|
423
|
+
this.selectedItemCount = 0;
|
|
424
|
+
}
|
|
425
|
+
this.addSelectAllMessage(this.selectAllState === 'checked');
|
|
426
|
+
}
|
|
427
|
+
canEnableSelectAll() {
|
|
428
|
+
return (this.selectedRows?.length == this._gridView.total &&
|
|
429
|
+
this.disablePreSelectedRows);
|
|
430
|
+
}
|
|
431
|
+
cellCloseHandler(args) {
|
|
432
|
+
let { formGroup, dataItem } = args;
|
|
433
|
+
if (!formGroup.valid) {
|
|
434
|
+
args.preventDefault();
|
|
435
|
+
}
|
|
436
|
+
else if (formGroup.dirty) {
|
|
437
|
+
if (args.originalEvent && args.originalEvent.keyCode === Keys.Escape) {
|
|
438
|
+
return;
|
|
439
|
+
}
|
|
440
|
+
Object.assign(dataItem, formGroup.value);
|
|
441
|
+
this.saveChanges();
|
|
442
|
+
this.updatedData.emit(this.grid.data);
|
|
443
|
+
}
|
|
444
|
+
}
|
|
445
|
+
saveChanges() {
|
|
446
|
+
this.grid.closeCell();
|
|
447
|
+
this.grid.cancelCell();
|
|
448
|
+
}
|
|
449
|
+
refreshGridData() {
|
|
450
|
+
this.emitRefreshEvt.emit();
|
|
451
|
+
}
|
|
452
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: GridPaginationComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
453
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: GridPaginationComponent, selector: "lib-grid-pagination", inputs: { skip: "skip", itemName: "itemName", showSelectAllMessage: "showSelectAllMessage", 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", gridHeight: "gridHeight", gridRowSelectByValue: "gridRowSelectByValue", noRecordsContent: "noRecordsContent", showToolbar: "showToolbar", kebabList: "kebabList", showKebab: "showKebab", icon: "icon", kebabColumnWidth: "kebabColumnWidth", selectColumn: "selectColumn", preSelected: "preSelected", gridView: "gridView", ignoreColumnCellClick: "ignoreColumnCellClick", allowColumnClick: "allowColumnClick", sort: "sort", hasApiSorting: "hasApiSorting", expandRowIndex: "expandRowIndex", customExpandRowColumn: "customExpandRowColumn", deleteColumnWidth: "deleteColumnWidth", sizes: "sizes", pageCount: "pageCount", showDeleteColumn: "showDeleteColumn", hideKebabRowIndex: "hideKebabRowIndex", loading: "loading", loaderType: "loaderType", loaderSize: "loaderSize", loaderTheme: "loaderTheme", disablePreSelectedRows: "disablePreSelectedRows", allowEditingCell: "allowEditingCell", columnContentNoWrap: "columnContentNoWrap", infiniteScrollLoader: "infiniteScrollLoader", isInfiniteScrollGrid: "isInfiniteScrollGrid", gridLoading: "gridLoading", minResizableWidth: "minResizableWidth", showRefresh: "showRefresh", isKebabColumnSticky: "isKebabColumnSticky", isCheckBoxColumnSticky: "isCheckBoxColumnSticky", isDeleteColumnSticky: "isDeleteColumnSticky", isSelectAllCheckboxRequired: "isSelectAllCheckboxRequired" }, outputs: { onSelectAllAcrossPages: "onSelectAllAcrossPages", selectedRowData: "selectedRowData", rowDetails: "rowDetails", kebabItemClick: "kebabItemClick", rowDataOfClickedCell: "rowDataOfClickedCell", onPageChange: "onPageChange", sortDirection: "sortDirection", deletedRowData: "deletedRowData", updatedData: "updatedData", onscrollBottom: "onscrollBottom", emitRefreshEvt: "emitRefreshEvt" }, 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 }, { propertyName: "columnTemplates", predicate: CustomColumnTemplate }], viewQueries: [{ propertyName: "grid", first: true, predicate: GridComponent, descendants: true }, { propertyName: "gridElement", first: true, predicate: ["gridElement"], descendants: true }, { propertyName: "selectAllCheckbox", first: true, predicate: ["selectAllCheckbox"], descendants: true }, { propertyName: "selectAllMessageElement", first: true, predicate: ["selectAllMessageElement"], descendants: true }], ngImport: i0, template: "<div #gridElement [ngClass]=\"columnContentNoWrap ? 'column-content-nowrap' : ''\">\n <kendo-grid [data]=\"_gridView\" [pageSize]=\"pageSize\" [skip]=\"skip\" [selectable]=\"selectableSettings\"\n [pageable]=\"pageable\" [sortable]=\"sortable\" [loading]=\"gridLoading\" [groupable]=\"groupable\"\n [reorderable]=\"reorderable\" [resizable]=\"resizable\" [columnMenu]=\"columnMenu\" [navigable]=\"navigable\"\n [height]=\"gridHeight\" (change)=\"setSelectableSettings()\" (selectedKeysChange)=\"selectedKeysChange($event)\"\n [kendoGridSelectBy]=\"gridRowSelectByValue\" (detailExpand)=\"onDetailExpand($event)\" [selectedKeys]=\"_preSelected\"\n (pageChange)=\"pageChange($event)\" (cellClick)=\"cellClickHandler($event)\" (cellClose)=\"cellCloseHandler($event)\"\n [sort]=\"sort\" (sortChange)=\"sortChange($event)\" (scrollBottom)=\"scrollBottom()\" [ngClass]=\"getHeaderHeight()\"\n id=\"lib-grid\" [rowClass]=\"rowClass\">\n <div #selectAllMessageElement>\n <div class=\"lib-grid-select-all-message-container\"\n *ngIf=\"((selectedItemCount < _gridView.total) || allPagesSelected)\">\n <div *ngIf=\"(selectedItemCount < _gridView.total)\" class=\"lib-grid-select-all-message\">\n <lib-typography [defaultText]=\"'All '+selectedItemCount+' '+itemName+' on this page are selected.'\"\n type=\"BODY_SMALL\"></lib-typography>\n <u><lib-typography (click)=\"selectAcrossPages(true)\" class=\"select-all-handler\"\n [defaultText]=\"'Select all '+_gridView.total+' '+itemName+' from all pages'\"\n type=\"BODY_SMALL\"></lib-typography></u>\n </div>\n <div *ngIf=\"allPagesSelected\" class=\"lib-grid-select-all-message\">\n <lib-icon name=\"circle-checked\" class=\"all-selected-icon\"></lib-icon>\n <lib-typography [defaultText]=\"'All '+_gridView.total+' '+itemName+' across all pages are selected.'\"\n type=\"BODY_SMALL\"></lib-typography>\n <u><lib-typography (click)=\"selectAcrossPages(false)\" class=\"select-all-handler\"\n [defaultText]=\"'Clear selection'\" type=\"BODY_SMALL\"></lib-typography></u>\n </div>\n </div>\n </div>\n <ng-template kendoGridToolbarTemplate [position]=\"getPosition()\" let-position=\"position\">\n <ng-container *ngIf=\"showToolbar && position === 'top'\">\n <ng-content></ng-content>\n <ng-container *ngIf=\"showRefresh\">\n <ng-container *ngTemplateOutlet=\"showRefreshTemplate\"></ng-container>\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"infiniteScrollLoader && position === 'bottom'\">\n <lib-grid-pagination-spacer></lib-grid-pagination-spacer>\n <lib-loader [type]=\"loaderType\" [size]=\"loaderSize\" [themeColor]=\"loaderTheme\"></lib-loader>\n <lib-grid-pagination-spacer></lib-grid-pagination-spacer>\n </ng-container>\n </ng-template>\n\n <ng-template #showRefreshTemplate>\n <lib-tooltip position=\"top\" showOn=\"hover\" [tooltipWidth]=\"68\" [callout]=\"true\">\n <div class=\"tooltip-content\">\n <lib-typography defaultText=\"Refresh\"></lib-typography>\n </div>\n <lib-button size=\"small\" width=\"2.4rem\" rounded=\"small\" fillMode=\"solid\" themeColor=\"primary\" iconName=\"reset\"\n [toggleable]=\"false\" (buttonClick)=\"refreshGridData()\" [iconButton]=\"true\" [iconFontSize]=\"13\"></lib-button>\n </lib-tooltip>\n </ng-template>\n\n <ng-template kendoGridLoadingTemplate>\n <div class=\"k-loading-color\"></div>\n <div class=\"loading-container\">\n <lib-loader [type]=\"loaderType\" [size]=\"loaderSize\" [themeColor]=\"loaderTheme\"></lib-loader>\n </div>\n </ng-template>\n\n <ng-template *ngIf=\"this._gridView.total === 0\" kendoGridNoRecordsTemplate>\n <lib-typography *ngIf=\"!loading\" [defaultText]=\"noRecordsContent\" type=\"BODY_MEDIUM\"></lib-typography>\n <lib-loader *ngIf=\"loading\" [type]=\"loaderType\" [size]=\"loaderSize\" [themeColor]=\"loaderTheme\"></lib-loader>\n </ng-template>\n <ng-container *ngIf=\"this._gridView.total > 0\">\n <kendo-grid-checkbox-column #selectAllCheckbox headerClass=\"select-all-header\" *ngIf=\"checkBoxRequired\"\n [width]=\"checkBoxWidth\" [resizable]=\"checkBoxColumnResizable\" [columnMenu]=\"checkBoxColumnMenu\"\n class=\"checkbox-column\" [sticky]=\"isCheckBoxColumnSticky && !customExpandRowColumn\">\n <ng-template kendoGridHeaderTemplate *ngIf=\"isSelectAllCheckboxRequired\">\n <input id=\"selectAllCheckboxId\" type=\"checkbox\" kendoCheckBox kendoGridSelectAllCheckbox\n [state]=\"selectAllState\" (selectAllChange)=\"onSelectAllChange($event)\" />\n </ng-template>\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\" [minResizableWidth]=\"minResizableWidth\" [sortable]=\"item.sortable\"\n [editor]=\"item.editor\" [class]=\"item.class\" [sticky]=\"item.columnSticky && !customExpandRowColumn\">\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.customColumn\" kendoGridCellTemplate let-dataItem>\n <ng-container [ngTemplateOutlet]=\"columnTemplateDict[item.type]\"\n [ngTemplateOutletContext]=\"{$implicit: dataItem}\"></ng-container>\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 [sticky]=\"isDeleteColumnSticky && !customExpandRowColumn\">\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 [sticky]=\"isKebabColumnSticky && !customExpandRowColumn\">\n <ng-template kendoGridCellTemplate let-dataItem let-rowIndex=\"rowIndex\">\n <kendo-dropdownbutton *ngIf=\"!hideKebabRowIndex.includes(rowIndex)\" [svgIcon]=\"icon\" fillMode=\"none\"\n [data]=\"kebabList | kebabMenuFilter : dataItem\" class=\"kebab\" (itemClick)=\"onKebabClick($event, dataItem)\"\n [popupSettings]=\"{ align: 'right', animate: true, popupClass: 'kebab-list' }\">\n </kendo-dropdownbutton>\n </ng-template>\n </kendo-grid-column>\n </ng-container>\n\n <!-- Limitation: detail template and sticky columns do not co-exist-->\n <ng-template *ngIf=\"customExpandRowColumn\" 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 <div [ngClass]=\"expandColumnClass()\">\n <span *ngIf=\"selectedRows.includes(dataItem[gridRowSelectByValue]) && disablePreSelectedRows\"\n class=\"expand-column-text\">\n Already added\n </span>\n <kendo-button *ngIf=\"!expandRowIndex.includes(rowIndex)\" [svgIcon]=\"arrowDownIcon\"\n (click)=\"expandRow(rowIndex)\" fillMode=\"none\" class=\"arrow-btn\">\n </kendo-button>\n <kendo-button *ngIf=\"expandRowIndex.includes(rowIndex)\" [svgIcon]=\"arrowUpIcon\"\n (click)=\"collapseRow(rowIndex)\" fillMode=\"none\" class=\"arrow-btn\">\n </kendo-button>\n </div>\n </ng-template>\n </kendo-grid-column>\n\n <ng-template kendoPagerTemplate let-totalPages=\"totalPages\" let-currentPage=\"currentPage\">\n <div class=\"pagination-wrapper\" [ngClass]=\"allPagesSelected ? 'pagination-disabled' : ''\">\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 </div>\n </ng-template>\n\n </kendo-grid>\n</div>\n", styles: [".loading-container{height:100%;display:flex;justify-content:center;align-items:center}::ng-deep .k-grid tr{height:50px}::ng-deep .pagination-wrapper{display:flex;width:100%}::ng-deep .pagination-disabled{color:#6c6f72!important;pointer-events:none}::ng-deep .lib-grid-select-all-message-container{height:2rem;display:none;gap:.25rem;justify-content:center;align-items:center;background-color:#eceff5!important;font-family:Inter,sans-serif!important;font-weight:400!important;font-style:normal;font-size:12px!important;line-height:16px!important;letter-spacing:.25px!important}::ng-deep .lib-grid-select-all-message-container .select-all-handler{cursor:pointer}::ng-deep .lib-grid-select-all-message-container .lib-grid-select-all-message{display:flex;gap:.25rem}::ng-deep .lib-grid-select-all-message-container .lib-grid-select-all-message .all-selected-icon{color:#198038}::ng-deep .disabled{cursor:none!important;pointer-events:none;opacity:.5}::ng-deep .lib-grid-select-all-message-show{display:flex!important}::ng-deep .k-grid .k-table-th,::ng-deep .k-grid .k-table-th.k-sorted{font-family:Inter,sans-serif!important;font-weight:600!important;font-style:normal!important;font-size:12px!important;line-height:16px!important;letter-spacing:.25px!important;background-color:#dee6f7!important;border-bottom-color:#ebecec!important;border-bottom-style:solid!important;border-bottom-width:2px!important;border-right:0px!important;border-left:0px!important;cursor:default!important}::ng-deep .k-grid .k-table-th .k-cell-inner,::ng-deep .k-grid .k-table-th.k-sorted .k-cell-inner{padding-right:.5rem;border-right:2px solid #C2D2F3!important}::ng-deep .k-grid .k-table-th .k-cell-inner .k-link,::ng-deep .k-grid .k-table-th.k-sorted .k-cell-inner .k-link{cursor:default!important}::ng-deep .k-grid .k-table-th:focus,::ng-deep .k-grid .k-table-th.k-sorted:focus{box-shadow:none!important}::ng-deep .k-grid .k-table-th.k-sorted{font-family:Inter,sans-serif!important;font-weight:600!important;font-style:normal!important;font-size:12px!important;line-height:16px!important;letter-spacing:.25px!important;background-color:#dee6f7!important}::ng-deep .k-grid tbody>tr:not(.k-detail-row):hover{background-color:#d0dcf5!important}::ng-deep .k-grid .k-table-row.k-selected>.k-table-td{background-color:#c9d7f4!important}::ng-deep .k-grid .k-table-row.k-disabled>.k-table-td{background-color:#fff!important}::ng-deep .k-grid .k-table-td{border-bottom-color:#ebecec!important;border-bottom-style:solid!important;border-bottom-width:1px!important;border-right:0px!important;border-left:0px!important}::ng-deep .k-grid td,::ng-deep .k-grid .k-table-td{white-space:nowrap!important}::ng-deep .k-table-alt-row{background-color:inherit!important}::ng-deep .k-grid .k-table-td{font-family:Inter,sans-serif!important;font-weight:400!important;font-style:normal;font-size:12px!important;line-height:16px!important;letter-spacing:.25px!important}::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:Inter,sans-serif!important;font-weight:400!important;font-style:normal!important;font-size:14px!important;line-height:20px!important;letter-spacing:.25px!important}::ng-deep .k-pager{border-style:none!important}::ng-deep .k-input-value-text{overflow:unset!important}::ng-deep .k-grid th.k-header{vertical-align:middle!important;padding-left:16px;padding-right:.5rem}::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{background-color:#f4f8fa!important;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-grouping-header{background-color:#eceff5!important}::ng-deep .k-grid-toolbar{padding:4px 16px!important;height:54px;background-color:#eceff5!important}::ng-deep .k-grid td:not(.kebab-column):not(.expand-column){padding-left:16px!important;padding-right:16px!important}::ng-deep .view-header .k-table-thead tr{height:50px}::ng-deep .hide-header .k-table-thead tr{height:0px;padding:0;display:block}::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}::ng-deep .expand-column{pointer-events:all!important}::ng-deep .expand-column-text{margin-right:32px}::ng-deep .expand-row{display:flex;align-items:center;justify-content:flex-end}::ng-deep .column-cursor-pointer{cursor:pointer}::ng-deep .column-content-nowrap .k-grid .k-table-th,::ng-deep .column-content-nowrap .k-grid td,::ng-deep .column-content-nowrap .k-grid .k-table-td{white-space:nowrap;text-overflow:clip}::ng-deep kendo-grid.k-grid .k-table-alt-row .k-grid-content-sticky,::ng-deep kendo-grid.k-grid .k-grid-row-sticky.k-table-alt-row td,::ng-deep kendo-grid.k-grid .k-grid-row-sticky.k-table-alt-row .k-table-td,::ng-deep .k-master-row.k-table-alt-row .k-grid-content-sticky,::ng-deep .k-master-row.k-table-alt-row .k-grid-row-sticky{background-color:#fff}::ng-deep kendo-grid.k-grid .k-grid-content-sticky:hover,::ng-deep kendo-grid.k-grid .k-grid-content-sticky.k-hover,::ng-deep kendo-grid.k-grid .k-table-row:hover .k-grid-content-sticky{background-color:#d0dcf5!important}\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", "projectedIcon", "fontSize", "type"] }, { kind: "directive", type: i4.CheckBoxDirective, selector: "input[kendoCheckBox]", inputs: ["size", "rounded"] }, { kind: "component", type: i5.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: i5.ToolbarTemplateDirective, selector: "[kendoGridToolbarTemplate]", inputs: ["position"] }, { kind: "directive", type: i5.SelectionDirective, selector: "[kendoGridSelectBy]" }, { kind: "component", type: i5.ColumnComponent, selector: "kendo-grid-column", inputs: ["field", "format", "sortable", "groupable", "editor", "filter", "filterable", "editable"] }, { kind: "directive", type: i5.DetailTemplateDirective, selector: "[kendoGridDetailTemplate]", inputs: ["kendoGridDetailTemplateShowIf"] }, { kind: "component", type: i5.CheckboxColumnComponent, selector: "kendo-grid-checkbox-column", inputs: ["showSelectAll"] }, { kind: "directive", type: i5.CellTemplateDirective, selector: "[kendoGridCellTemplate]" }, { kind: "directive", type: i5.NoRecordsTemplateDirective, selector: "[kendoGridNoRecordsTemplate]" }, { kind: "directive", type: i5.LoadingTemplateDirective, selector: "[kendoGridLoadingTemplate]" }, { kind: "directive", type: i5.HeaderTemplateDirective, selector: "[kendoGridHeaderTemplate]" }, { kind: "directive", type: i5.SelectAllCheckboxDirective, selector: "[kendoGridSelectAllCheckbox]", inputs: ["state"], outputs: ["selectAllChange"] }, { kind: "component", type: i5.PagerPrevButtonsComponent, selector: "kendo-pager-prev-buttons" }, { kind: "component", type: i5.PagerNextButtonsComponent, selector: "kendo-pager-next-buttons" }, { kind: "component", type: i5.PagerNumericButtonsComponent, selector: "kendo-pager-numeric-buttons", inputs: ["buttonCount"] }, { kind: "component", type: i5.PagerInfoComponent, selector: "kendo-pager-info" }, { kind: "component", type: i5.PagerPageSizesComponent, selector: "kendo-pager-page-sizes", inputs: ["pageSizes"] }, { kind: "directive", type: i5.PagerTemplateDirective, selector: "[kendoPagerTemplate]" }, { kind: "component", type: i6.TooltipComponent, selector: "lib-tooltip", inputs: ["position", "tooltipWidth", "tooltipHeight", "showOn", "closable", "title", "callout"] }, { kind: "component", type: i7.TypographyComponent, selector: "lib-typography", inputs: ["type", "defaultText", "isLabel", "hiddenLabel"] }, { kind: "component", type: i8.LoaderComponent, selector: "lib-loader", inputs: ["size", "type", "themeColor"] }, { kind: "component", type: i9.ButtonComponent, selector: "lib-button", inputs: ["size", "rounded", "fillMode", "themeColor", "label", "iconName", "disabled", "toggleable", "iconPosition", "fontType", "width", "iconButton", "projectedIcon", "formatFn", "iconFontSize"], outputs: ["buttonClick"] }, { kind: "component", type: i10.GridPaginationSpacerComponent, selector: "lib-grid-pagination-spacer" }, { kind: "pipe", type: i11.KebabMenuFilterPipe, name: "kebabMenuFilter" }] }); }
|
|
454
|
+
}
|
|
455
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: GridPaginationComponent, decorators: [{
|
|
456
|
+
type: Component,
|
|
457
|
+
args: [{ selector: 'lib-grid-pagination', template: "<div #gridElement [ngClass]=\"columnContentNoWrap ? 'column-content-nowrap' : ''\">\n <kendo-grid [data]=\"_gridView\" [pageSize]=\"pageSize\" [skip]=\"skip\" [selectable]=\"selectableSettings\"\n [pageable]=\"pageable\" [sortable]=\"sortable\" [loading]=\"gridLoading\" [groupable]=\"groupable\"\n [reorderable]=\"reorderable\" [resizable]=\"resizable\" [columnMenu]=\"columnMenu\" [navigable]=\"navigable\"\n [height]=\"gridHeight\" (change)=\"setSelectableSettings()\" (selectedKeysChange)=\"selectedKeysChange($event)\"\n [kendoGridSelectBy]=\"gridRowSelectByValue\" (detailExpand)=\"onDetailExpand($event)\" [selectedKeys]=\"_preSelected\"\n (pageChange)=\"pageChange($event)\" (cellClick)=\"cellClickHandler($event)\" (cellClose)=\"cellCloseHandler($event)\"\n [sort]=\"sort\" (sortChange)=\"sortChange($event)\" (scrollBottom)=\"scrollBottom()\" [ngClass]=\"getHeaderHeight()\"\n id=\"lib-grid\" [rowClass]=\"rowClass\">\n <div #selectAllMessageElement>\n <div class=\"lib-grid-select-all-message-container\"\n *ngIf=\"((selectedItemCount < _gridView.total) || allPagesSelected)\">\n <div *ngIf=\"(selectedItemCount < _gridView.total)\" class=\"lib-grid-select-all-message\">\n <lib-typography [defaultText]=\"'All '+selectedItemCount+' '+itemName+' on this page are selected.'\"\n type=\"BODY_SMALL\"></lib-typography>\n <u><lib-typography (click)=\"selectAcrossPages(true)\" class=\"select-all-handler\"\n [defaultText]=\"'Select all '+_gridView.total+' '+itemName+' from all pages'\"\n type=\"BODY_SMALL\"></lib-typography></u>\n </div>\n <div *ngIf=\"allPagesSelected\" class=\"lib-grid-select-all-message\">\n <lib-icon name=\"circle-checked\" class=\"all-selected-icon\"></lib-icon>\n <lib-typography [defaultText]=\"'All '+_gridView.total+' '+itemName+' across all pages are selected.'\"\n type=\"BODY_SMALL\"></lib-typography>\n <u><lib-typography (click)=\"selectAcrossPages(false)\" class=\"select-all-handler\"\n [defaultText]=\"'Clear selection'\" type=\"BODY_SMALL\"></lib-typography></u>\n </div>\n </div>\n </div>\n <ng-template kendoGridToolbarTemplate [position]=\"getPosition()\" let-position=\"position\">\n <ng-container *ngIf=\"showToolbar && position === 'top'\">\n <ng-content></ng-content>\n <ng-container *ngIf=\"showRefresh\">\n <ng-container *ngTemplateOutlet=\"showRefreshTemplate\"></ng-container>\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"infiniteScrollLoader && position === 'bottom'\">\n <lib-grid-pagination-spacer></lib-grid-pagination-spacer>\n <lib-loader [type]=\"loaderType\" [size]=\"loaderSize\" [themeColor]=\"loaderTheme\"></lib-loader>\n <lib-grid-pagination-spacer></lib-grid-pagination-spacer>\n </ng-container>\n </ng-template>\n\n <ng-template #showRefreshTemplate>\n <lib-tooltip position=\"top\" showOn=\"hover\" [tooltipWidth]=\"68\" [callout]=\"true\">\n <div class=\"tooltip-content\">\n <lib-typography defaultText=\"Refresh\"></lib-typography>\n </div>\n <lib-button size=\"small\" width=\"2.4rem\" rounded=\"small\" fillMode=\"solid\" themeColor=\"primary\" iconName=\"reset\"\n [toggleable]=\"false\" (buttonClick)=\"refreshGridData()\" [iconButton]=\"true\" [iconFontSize]=\"13\"></lib-button>\n </lib-tooltip>\n </ng-template>\n\n <ng-template kendoGridLoadingTemplate>\n <div class=\"k-loading-color\"></div>\n <div class=\"loading-container\">\n <lib-loader [type]=\"loaderType\" [size]=\"loaderSize\" [themeColor]=\"loaderTheme\"></lib-loader>\n </div>\n </ng-template>\n\n <ng-template *ngIf=\"this._gridView.total === 0\" kendoGridNoRecordsTemplate>\n <lib-typography *ngIf=\"!loading\" [defaultText]=\"noRecordsContent\" type=\"BODY_MEDIUM\"></lib-typography>\n <lib-loader *ngIf=\"loading\" [type]=\"loaderType\" [size]=\"loaderSize\" [themeColor]=\"loaderTheme\"></lib-loader>\n </ng-template>\n <ng-container *ngIf=\"this._gridView.total > 0\">\n <kendo-grid-checkbox-column #selectAllCheckbox headerClass=\"select-all-header\" *ngIf=\"checkBoxRequired\"\n [width]=\"checkBoxWidth\" [resizable]=\"checkBoxColumnResizable\" [columnMenu]=\"checkBoxColumnMenu\"\n class=\"checkbox-column\" [sticky]=\"isCheckBoxColumnSticky && !customExpandRowColumn\">\n <ng-template kendoGridHeaderTemplate *ngIf=\"isSelectAllCheckboxRequired\">\n <input id=\"selectAllCheckboxId\" type=\"checkbox\" kendoCheckBox kendoGridSelectAllCheckbox\n [state]=\"selectAllState\" (selectAllChange)=\"onSelectAllChange($event)\" />\n </ng-template>\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\" [minResizableWidth]=\"minResizableWidth\" [sortable]=\"item.sortable\"\n [editor]=\"item.editor\" [class]=\"item.class\" [sticky]=\"item.columnSticky && !customExpandRowColumn\">\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.customColumn\" kendoGridCellTemplate let-dataItem>\n <ng-container [ngTemplateOutlet]=\"columnTemplateDict[item.type]\"\n [ngTemplateOutletContext]=\"{$implicit: dataItem}\"></ng-container>\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 [sticky]=\"isDeleteColumnSticky && !customExpandRowColumn\">\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 [sticky]=\"isKebabColumnSticky && !customExpandRowColumn\">\n <ng-template kendoGridCellTemplate let-dataItem let-rowIndex=\"rowIndex\">\n <kendo-dropdownbutton *ngIf=\"!hideKebabRowIndex.includes(rowIndex)\" [svgIcon]=\"icon\" fillMode=\"none\"\n [data]=\"kebabList | kebabMenuFilter : dataItem\" class=\"kebab\" (itemClick)=\"onKebabClick($event, dataItem)\"\n [popupSettings]=\"{ align: 'right', animate: true, popupClass: 'kebab-list' }\">\n </kendo-dropdownbutton>\n </ng-template>\n </kendo-grid-column>\n </ng-container>\n\n <!-- Limitation: detail template and sticky columns do not co-exist-->\n <ng-template *ngIf=\"customExpandRowColumn\" 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 <div [ngClass]=\"expandColumnClass()\">\n <span *ngIf=\"selectedRows.includes(dataItem[gridRowSelectByValue]) && disablePreSelectedRows\"\n class=\"expand-column-text\">\n Already added\n </span>\n <kendo-button *ngIf=\"!expandRowIndex.includes(rowIndex)\" [svgIcon]=\"arrowDownIcon\"\n (click)=\"expandRow(rowIndex)\" fillMode=\"none\" class=\"arrow-btn\">\n </kendo-button>\n <kendo-button *ngIf=\"expandRowIndex.includes(rowIndex)\" [svgIcon]=\"arrowUpIcon\"\n (click)=\"collapseRow(rowIndex)\" fillMode=\"none\" class=\"arrow-btn\">\n </kendo-button>\n </div>\n </ng-template>\n </kendo-grid-column>\n\n <ng-template kendoPagerTemplate let-totalPages=\"totalPages\" let-currentPage=\"currentPage\">\n <div class=\"pagination-wrapper\" [ngClass]=\"allPagesSelected ? 'pagination-disabled' : ''\">\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 </div>\n </ng-template>\n\n </kendo-grid>\n</div>\n", styles: [".loading-container{height:100%;display:flex;justify-content:center;align-items:center}::ng-deep .k-grid tr{height:50px}::ng-deep .pagination-wrapper{display:flex;width:100%}::ng-deep .pagination-disabled{color:#6c6f72!important;pointer-events:none}::ng-deep .lib-grid-select-all-message-container{height:2rem;display:none;gap:.25rem;justify-content:center;align-items:center;background-color:#eceff5!important;font-family:Inter,sans-serif!important;font-weight:400!important;font-style:normal;font-size:12px!important;line-height:16px!important;letter-spacing:.25px!important}::ng-deep .lib-grid-select-all-message-container .select-all-handler{cursor:pointer}::ng-deep .lib-grid-select-all-message-container .lib-grid-select-all-message{display:flex;gap:.25rem}::ng-deep .lib-grid-select-all-message-container .lib-grid-select-all-message .all-selected-icon{color:#198038}::ng-deep .disabled{cursor:none!important;pointer-events:none;opacity:.5}::ng-deep .lib-grid-select-all-message-show{display:flex!important}::ng-deep .k-grid .k-table-th,::ng-deep .k-grid .k-table-th.k-sorted{font-family:Inter,sans-serif!important;font-weight:600!important;font-style:normal!important;font-size:12px!important;line-height:16px!important;letter-spacing:.25px!important;background-color:#dee6f7!important;border-bottom-color:#ebecec!important;border-bottom-style:solid!important;border-bottom-width:2px!important;border-right:0px!important;border-left:0px!important;cursor:default!important}::ng-deep .k-grid .k-table-th .k-cell-inner,::ng-deep .k-grid .k-table-th.k-sorted .k-cell-inner{padding-right:.5rem;border-right:2px solid #C2D2F3!important}::ng-deep .k-grid .k-table-th .k-cell-inner .k-link,::ng-deep .k-grid .k-table-th.k-sorted .k-cell-inner .k-link{cursor:default!important}::ng-deep .k-grid .k-table-th:focus,::ng-deep .k-grid .k-table-th.k-sorted:focus{box-shadow:none!important}::ng-deep .k-grid .k-table-th.k-sorted{font-family:Inter,sans-serif!important;font-weight:600!important;font-style:normal!important;font-size:12px!important;line-height:16px!important;letter-spacing:.25px!important;background-color:#dee6f7!important}::ng-deep .k-grid tbody>tr:not(.k-detail-row):hover{background-color:#d0dcf5!important}::ng-deep .k-grid .k-table-row.k-selected>.k-table-td{background-color:#c9d7f4!important}::ng-deep .k-grid .k-table-row.k-disabled>.k-table-td{background-color:#fff!important}::ng-deep .k-grid .k-table-td{border-bottom-color:#ebecec!important;border-bottom-style:solid!important;border-bottom-width:1px!important;border-right:0px!important;border-left:0px!important}::ng-deep .k-grid td,::ng-deep .k-grid .k-table-td{white-space:nowrap!important}::ng-deep .k-table-alt-row{background-color:inherit!important}::ng-deep .k-grid .k-table-td{font-family:Inter,sans-serif!important;font-weight:400!important;font-style:normal;font-size:12px!important;line-height:16px!important;letter-spacing:.25px!important}::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:Inter,sans-serif!important;font-weight:400!important;font-style:normal!important;font-size:14px!important;line-height:20px!important;letter-spacing:.25px!important}::ng-deep .k-pager{border-style:none!important}::ng-deep .k-input-value-text{overflow:unset!important}::ng-deep .k-grid th.k-header{vertical-align:middle!important;padding-left:16px;padding-right:.5rem}::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{background-color:#f4f8fa!important;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-grouping-header{background-color:#eceff5!important}::ng-deep .k-grid-toolbar{padding:4px 16px!important;height:54px;background-color:#eceff5!important}::ng-deep .k-grid td:not(.kebab-column):not(.expand-column){padding-left:16px!important;padding-right:16px!important}::ng-deep .view-header .k-table-thead tr{height:50px}::ng-deep .hide-header .k-table-thead tr{height:0px;padding:0;display:block}::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}::ng-deep .expand-column{pointer-events:all!important}::ng-deep .expand-column-text{margin-right:32px}::ng-deep .expand-row{display:flex;align-items:center;justify-content:flex-end}::ng-deep .column-cursor-pointer{cursor:pointer}::ng-deep .column-content-nowrap .k-grid .k-table-th,::ng-deep .column-content-nowrap .k-grid td,::ng-deep .column-content-nowrap .k-grid .k-table-td{white-space:nowrap;text-overflow:clip}::ng-deep kendo-grid.k-grid .k-table-alt-row .k-grid-content-sticky,::ng-deep kendo-grid.k-grid .k-grid-row-sticky.k-table-alt-row td,::ng-deep kendo-grid.k-grid .k-grid-row-sticky.k-table-alt-row .k-table-td,::ng-deep .k-master-row.k-table-alt-row .k-grid-content-sticky,::ng-deep .k-master-row.k-table-alt-row .k-grid-row-sticky{background-color:#fff}::ng-deep kendo-grid.k-grid .k-grid-content-sticky:hover,::ng-deep kendo-grid.k-grid .k-grid-content-sticky.k-hover,::ng-deep kendo-grid.k-grid .k-table-row:hover .k-grid-content-sticky{background-color:#d0dcf5!important}\n"] }]
|
|
458
|
+
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i0.Renderer2 }], propDecorators: { columnTemplates: [{
|
|
459
|
+
type: ContentChildren,
|
|
460
|
+
args: [CustomColumnTemplate]
|
|
461
|
+
}], templateRef: [{
|
|
462
|
+
type: ContentChild,
|
|
463
|
+
args: ['multiColumnData']
|
|
464
|
+
}], detailTemplate: [{
|
|
465
|
+
type: ContentChild,
|
|
466
|
+
args: ['detailTemplate']
|
|
467
|
+
}], impactColumn: [{
|
|
468
|
+
type: ContentChild,
|
|
469
|
+
args: ['impactColumn']
|
|
470
|
+
}], grid: [{
|
|
471
|
+
type: ViewChild,
|
|
472
|
+
args: [GridComponent]
|
|
473
|
+
}], gridElement: [{
|
|
474
|
+
type: ViewChild,
|
|
475
|
+
args: ['gridElement']
|
|
476
|
+
}], selectAllCheckbox: [{
|
|
477
|
+
type: ViewChild,
|
|
478
|
+
args: ['selectAllCheckbox']
|
|
479
|
+
}], selectAllMessageElement: [{
|
|
480
|
+
type: ViewChild,
|
|
481
|
+
args: ['selectAllMessageElement']
|
|
482
|
+
}], skip: [{
|
|
483
|
+
type: Input
|
|
484
|
+
}], itemName: [{
|
|
485
|
+
type: Input
|
|
486
|
+
}], showSelectAllMessage: [{
|
|
487
|
+
type: Input
|
|
488
|
+
}], onSelectAllAcrossPages: [{
|
|
489
|
+
type: Output
|
|
490
|
+
}], columnData: [{
|
|
491
|
+
type: Input
|
|
492
|
+
}], pageSize: [{
|
|
493
|
+
type: Input
|
|
494
|
+
}], pageable: [{
|
|
495
|
+
type: Input
|
|
496
|
+
}], sortable: [{
|
|
497
|
+
type: Input
|
|
498
|
+
}], groupable: [{
|
|
499
|
+
type: Input
|
|
500
|
+
}], reorderable: [{
|
|
501
|
+
type: Input
|
|
502
|
+
}], resizable: [{
|
|
503
|
+
type: Input
|
|
504
|
+
}], checkBoxWidth: [{
|
|
505
|
+
type: Input
|
|
506
|
+
}], checkBoxColumnResizable: [{
|
|
507
|
+
type: Input
|
|
508
|
+
}], checkBoxColumnMenu: [{
|
|
509
|
+
type: Input
|
|
510
|
+
}], checkBoxColumnShowSelectedAll: [{
|
|
511
|
+
type: Input
|
|
512
|
+
}], checkBoxRequired: [{
|
|
513
|
+
type: Input
|
|
514
|
+
}], columnMenu: [{
|
|
515
|
+
type: Input
|
|
516
|
+
}], mode: [{
|
|
517
|
+
type: Input
|
|
518
|
+
}], checkboxOnly: [{
|
|
519
|
+
type: Input
|
|
520
|
+
}], dragColumns: [{
|
|
521
|
+
type: Input
|
|
522
|
+
}], navigable: [{
|
|
523
|
+
type: Input
|
|
524
|
+
}], gridHeight: [{
|
|
525
|
+
type: Input
|
|
526
|
+
}], gridRowSelectByValue: [{
|
|
527
|
+
type: Input
|
|
528
|
+
}], noRecordsContent: [{
|
|
529
|
+
type: Input
|
|
530
|
+
}], selectedRowData: [{
|
|
531
|
+
type: Output
|
|
532
|
+
}], showToolbar: [{
|
|
533
|
+
type: Input
|
|
534
|
+
}], kebabList: [{
|
|
535
|
+
type: Input
|
|
536
|
+
}], showKebab: [{
|
|
537
|
+
type: Input
|
|
538
|
+
}], rowDetails: [{
|
|
539
|
+
type: Output
|
|
540
|
+
}], kebabItemClick: [{
|
|
541
|
+
type: Output
|
|
542
|
+
}], icon: [{
|
|
543
|
+
type: Input
|
|
544
|
+
}], kebabColumnWidth: [{
|
|
545
|
+
type: Input
|
|
546
|
+
}], selectColumn: [{
|
|
547
|
+
type: Input
|
|
548
|
+
}], rowDataOfClickedCell: [{
|
|
549
|
+
type: Output
|
|
550
|
+
}], preSelected: [{
|
|
551
|
+
type: Input
|
|
552
|
+
}], gridView: [{
|
|
553
|
+
type: Input
|
|
554
|
+
}], onPageChange: [{
|
|
555
|
+
type: Output
|
|
556
|
+
}], ignoreColumnCellClick: [{
|
|
557
|
+
type: Input
|
|
558
|
+
}], allowColumnClick: [{
|
|
559
|
+
type: Input
|
|
560
|
+
}], sort: [{
|
|
561
|
+
type: Input
|
|
562
|
+
}], hasApiSorting: [{
|
|
563
|
+
type: Input
|
|
564
|
+
}], sortDirection: [{
|
|
565
|
+
type: Output
|
|
566
|
+
}], expandRowIndex: [{
|
|
567
|
+
type: Input
|
|
568
|
+
}], customExpandRowColumn: [{
|
|
569
|
+
type: Input
|
|
570
|
+
}], deleteColumnWidth: [{
|
|
571
|
+
type: Input
|
|
572
|
+
}], deletedRowData: [{
|
|
573
|
+
type: Output
|
|
574
|
+
}], sizes: [{
|
|
575
|
+
type: Input
|
|
576
|
+
}], pageCount: [{
|
|
577
|
+
type: Input
|
|
578
|
+
}], showDeleteColumn: [{
|
|
579
|
+
type: Input
|
|
580
|
+
}], hideKebabRowIndex: [{
|
|
581
|
+
type: Input
|
|
582
|
+
}], loading: [{
|
|
583
|
+
type: Input
|
|
584
|
+
}], loaderType: [{
|
|
585
|
+
type: Input
|
|
586
|
+
}], loaderSize: [{
|
|
587
|
+
type: Input
|
|
588
|
+
}], loaderTheme: [{
|
|
589
|
+
type: Input
|
|
590
|
+
}], disablePreSelectedRows: [{
|
|
591
|
+
type: Input
|
|
592
|
+
}], updatedData: [{
|
|
593
|
+
type: Output
|
|
594
|
+
}], allowEditingCell: [{
|
|
595
|
+
type: Input
|
|
596
|
+
}], columnContentNoWrap: [{
|
|
597
|
+
type: Input
|
|
598
|
+
}], infiniteScrollLoader: [{
|
|
599
|
+
type: Input
|
|
600
|
+
}], onscrollBottom: [{
|
|
601
|
+
type: Output
|
|
602
|
+
}], isInfiniteScrollGrid: [{
|
|
603
|
+
type: Input
|
|
604
|
+
}], gridLoading: [{
|
|
605
|
+
type: Input
|
|
606
|
+
}], minResizableWidth: [{
|
|
607
|
+
type: Input
|
|
608
|
+
}], showRefresh: [{
|
|
609
|
+
type: Input
|
|
610
|
+
}], isKebabColumnSticky: [{
|
|
611
|
+
type: Input
|
|
612
|
+
}], isCheckBoxColumnSticky: [{
|
|
613
|
+
type: Input
|
|
614
|
+
}], isDeleteColumnSticky: [{
|
|
615
|
+
type: Input
|
|
616
|
+
}], emitRefreshEvt: [{
|
|
617
|
+
type: Output
|
|
618
|
+
}], isSelectAllCheckboxRequired: [{
|
|
619
|
+
type: Input
|
|
620
|
+
}] } });
|
|
621
|
+
//# 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 { AfterContentInit, AfterViewInit, ChangeDetectorRef, Component, ContentChild, ContentChildren, Directive, ElementRef, EventEmitter, Input, OnInit, Output, QueryList, Renderer2, TemplateRef, ViewChild } from '@angular/core';\nimport { FormControl, FormGroup, Validators } from '@angular/forms';\nimport { Keys } from '@progress/kendo-angular-common';\nimport { SortDescriptor, orderBy } from '@progress/kendo-data-query';\nimport { LoaderSize, LoaderThemeColor, LoaderType } from '../../atoms/loader/loader.component';\nimport { CellClickEvent, CellCloseEvent, GridComponent, GridDataResult, PageChangeEvent, RowClassArgs, SelectAllCheckboxState, SelectableMode, SelectableSettings } from '@progress/kendo-angular-grid';\nimport { chevronDownIcon, chevronUpIcon, moreVerticalIcon, SVGIcon } from '@progress/kendo-svg-icons';\n\n\n@Directive({\n  selector: 'ng-template[type]'\n})\nexport class CustomColumnTemplate {\n  @Input() type: string = \"\";\n  constructor(public template: TemplateRef<Component>) { }\n}\n\nconst createFormGroup = (dataItem: any): FormGroup => {\n  const form = new FormGroup({});\n  for (let data of Object.keys(dataItem)) {\n    form.addControl(data, new FormControl(dataItem[data], Validators.required))\n  }\n  return form\n};\n\n\n\n@Component({\n  selector: 'lib-grid-pagination',\n  templateUrl: './grid-pagination.component.html',\n  styleUrls: ['./grid-pagination.component.scss']\n})\nexport class GridPaginationComponent implements OnInit, AfterContentInit, AfterViewInit {\n\n  @ContentChildren(CustomColumnTemplate) columnTemplates!: QueryList<CustomColumnTemplate> | [];\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  @ViewChild('selectAllCheckbox') selectAllCheckbox!: ElementRef;\n  @ViewChild('selectAllMessageElement') selectAllMessageElement!: ElementRef;\n  @Input() skip: number = 0;\n  @Input() itemName: string = 'Items';\n  @Input() showSelectAllMessage: boolean = false;\n  allPagesSelected: boolean = false;\n  previousSelectAllState: SelectAllCheckboxState = 'unchecked';\n  @Output() onSelectAllAcrossPages = new EventEmitter<boolean>();\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  @Input() gridHeight!: any;\n  @Input() gridRowSelectByValue: string = '';\n  @Input() noRecordsContent: string = 'No records are available yet.';\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 = 90;\n  data: any = [];\n  @Input() selectColumn = '';\n  @Output() rowDataOfClickedCell = new EventEmitter<any>();\n  _preSelected: any[] = [];\n  @Input() set preSelected(value: any[]) {\n    this._preSelected = value;\n    this.initGrid();\n  }\n  _gridView: GridDataResult = { data: [], total: 0 };\n  @Input() set gridView(value: GridDataResult) {\n    this._gridView = value;\n  }\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  expandRowColumnWidth: number = 56;\n  @Output() deletedRowData = new EventEmitter<any>();\n  @Input() sizes: any[] = [];\n  _pageCount: number = 0;\n  @Input() set pageCount(value: number) {\n    this._pageCount = value > 10 ? 10 : value;\n  }\n  @Input() showDeleteColumn = false;\n  @Input() hideKebabRowIndex: number[] = [];\n  @Input() loading: boolean = false;\n  @Input() loaderType: LoaderType = LoaderType.pulsing;\n  @Input() loaderSize: LoaderSize = LoaderSize.medium;\n  @Input() loaderTheme: LoaderThemeColor = LoaderThemeColor.primary;\n  initialGridHeight: any;\n  gridBottomSpace = 24;\n  resizeHeight: any = 0;\n  selectAllState: SelectAllCheckboxState = 'unchecked';\n  selectedItemCount: number = 0;\n  selectedRows: any[] = [];\n  @Input() disablePreSelectedRows = false;\n  public formGroup!: FormGroup | any;\n  @Output() updatedData = new EventEmitter<any>();\n  @Input() allowEditingCell = false;\n  @Input() columnContentNoWrap = false;\n  @Input() infiniteScrollLoader = false;\n  @Output() onscrollBottom = new EventEmitter<any>();\n  @Input() isInfiniteScrollGrid: boolean = false;\n  @Input() gridLoading: boolean = false;\n  selectAllMsgParentElement: any;\n  @Input() minResizableWidth = 50;\n  @Input() showRefresh = false;\n  @Input() isKebabColumnSticky = false;\n  @Input() isCheckBoxColumnSticky = false;\n  @Input() isDeleteColumnSticky = false;\n  @Output() emitRefreshEvt = new EventEmitter();\n  @Input() isSelectAllCheckboxRequired = true;\n\n  constructor(private cdRef: ChangeDetectorRef,\n    private renderer: Renderer2\n  ) {\n    this.setSelectableSettings();\n  }\n\n  columnTemplateDict: any = {};\n\n  ngOnInit() {\n    this.columnData.forEach((column: any, index: number) => {\n      column.sortable = column.sortable == undefined ? true : column.sortable;\n      if (!this.ignoreColumnCellClick.includes(index)) {\n        column.class = 'column-cursor-pointer';\n      }\n    })\n    if (!this.hasApiSorting) {\n      this.loadGridData();\n    }\n  }\n\n  scrollBottom() {\n    this.onscrollBottom.emit();\n  }\n\n  getPosition(): any {\n    if (this.showToolbar && this.infiniteScrollLoader) {\n      return 'both';\n    } else if (this.showToolbar) {\n      return 'top';\n    } else if (this.infiniteScrollLoader) {\n      return 'bottom';\n    } else {\n      return;\n    }\n  }\n\n  ngAfterContentInit(): void {\n    if (!this.pageable) {\n      this.pageSize = this._gridView.data?.length;\n    }\n    this.columnTemplates.forEach(x => this.columnTemplateDict[x.type] = x.template);\n  }\n\n  ngAfterViewInit() {\n    this.initGrid();\n  }\n\n  initGrid() {\n    if (this.customExpandRowColumn) {\n      this.expandRowIndex.forEach((id) => {\n        this.grid.expandRow(id);\n      });\n    }\n    this.selectedRows = this._preSelected;\n\n    if (this.selectedRows?.length > 0) {\n      if (this.selectedRows?.length == this._gridView.total) {\n        this.selectAllState = 'checked';\n      } else {\n        this.selectAllState = 'indeterminate';\n      }\n    } else {\n      this.selectAllState = 'unchecked';\n    }\n    if (this.gridElement) {\n      this.initialGridHeight =\n        this.gridElement?.nativeElement?.offsetHeight + this.gridBottomSpace;\n      // this.getGridHeight();\n\n      const gridContainer = this.gridElement?.nativeElement?.getElementsByClassName('k-grid-container')[0];\n      if (gridContainer && this.selectAllMessageElement?.nativeElement) {\n        this.renderer.insertBefore(\n          gridContainer.parentElement,\n          this.selectAllMessageElement?.nativeElement,\n          gridContainer,\n          true\n        );\n      }\n      const selectAllCheckbox = this.gridElement?.nativeElement?.querySelector('.select-all-header input');\n      if (selectAllCheckbox) {\n        this.renderer.setProperty(selectAllCheckbox, 'disabled', this.canEnableSelectAll());\n      }\n      this.cdRef.detectChanges();\n    }\n  }\n\n  selectAcrossPages(isSelected: boolean) {\n    this.triggerSelectAllPagesEvent(isSelected);\n    if (!isSelected) {\n      this.onSelectAllChange(this.previousSelectAllState)\n    }\n  }\n\n  triggerSelectAllPagesEvent(isSelected: boolean) {\n    this.allPagesSelected = isSelected;\n    this.onSelectAllAcrossPages.emit(isSelected);\n    this.selectedItemCount = isSelected ? this._gridView.total : 0;\n    console.log('triggerSelectAllPagesEvent : isSelected', isSelected);\n  }\n\n  addSelectAllMessage(selectAll: boolean) {\n    this.selectAllMsgParentElement = this.selectAllMessageElement?.nativeElement?.parentElement;\n    if (this.showSelectAllMessage && this.selectAllMsgParentElement && (this._pageCount > 1 || this.isInfiniteScrollGrid)) {\n      const selectAllMsgElement = this.selectAllMessageElement?.nativeElement?.querySelector('.lib-grid-select-all-message-container');\n      if (selectAll) {\n        const beforeHeight = this.selectAllMsgParentElement.offsetHeight;\n\n        selectAllMsgElement?.classList.add('lib-grid-select-all-message-show');\n\n        const afterHeight = this.selectAllMsgParentElement.offsetHeight;\n        this.selectAllMsgParentElement.style.height = (this.selectAllMsgParentElement.offsetHeight - (afterHeight - beforeHeight)) + 'px';\n      } else {\n        selectAllMsgElement?.classList.remove('lib-grid-select-all-message-show');\n        if (this.allPagesSelected) {\n          this.triggerSelectAllPagesEvent(false);\n        }\n      }\n    }\n  }\n\n  pageChange(event: PageChangeEvent) {\n    if (this.selectAllMsgParentElement) {\n      this.selectAllMsgParentElement.style.height = ''\n    }\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  selectedKeysChange(rows: number[]) {\n    let selectedRowData: any = [];\n    let selectedRowsCount = 0;\n\n    if (rows?.length > 0) {\n      selectedRowsCount = rows?.length;\n    } else if (this.selectedRows?.length > 0 && this.disablePreSelectedRows) {\n      selectedRowsCount = this.selectedRows?.length;\n      rows = this.selectedRows;\n    }\n    this.previousSelectAllState = this.selectAllState;\n    this.selectAllState = this.getSelectAllState(selectedRowsCount);\n    if (this.selectAllState === 'unchecked' || this.selectAllState === 'indeterminate') {\n      this.addSelectAllMessage(false);\n    }\n\n    selectedRowData = rows.map(rowData => {\n      return this._gridView.data.find((data) => data[this.gridRowSelectByValue] === rowData);\n    });\n\n    this.selectedRowData.emit(selectedRowData);\n  }\n\n  getSelectAllState(selectedRowsCount: number): any {\n    if (selectedRowsCount == this._gridView.total) {\n      this.selectAllState = 'checked';\n    } else if (selectedRowsCount == 0) {\n      this.selectAllState = 'unchecked';\n      this.addSelectAllMessage(false);\n    } else {\n      this.selectAllState = 'indeterminate';\n      this.addSelectAllMessage(false);\n    }\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({ dataItem: args.dataItem, columnIndex: args.columnIndex });\n    }\n    if (this.allowEditingCell) {\n      this.formGroup = createFormGroup(args.dataItem);\n      args.sender.editCell(args.rowIndex, args.columnIndex, this.formGroup);\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    setTimeout(() => {\n      this.getHeaderHeight();\n    }, 1000);\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  /*\n   * This logic of dynamically calculating the height of grid need further brainstorming hence commented for now.\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 =\n  //     this.gridElement.nativeElement.offsetHeight + 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  rowClass = (args: RowClassArgs) => {\n    if (this.selectedRows && this.disablePreSelectedRows) {\n      return {\n        'k-disabled': this.selectedRows.includes(\n          args.dataItem[this.gridRowSelectByValue]\n        ) || this.allPagesSelected,\n      };\n    }\n    return '';\n  };\n\n  expandColumnClass() {\n    if (this.selectedRows?.length > 0 && this.disablePreSelectedRows) {\n      this.expandRowColumnWidth = 194;\n      return 'expand-row';\n    }\n    this.expandRowColumnWidth = 56;\n    return '';\n  }\n\n  onSelectAllChange(checkedState: SelectAllCheckboxState): void {\n    if (\n      checkedState === 'checked'\n    ) {\n      this._preSelected = this._gridView.data\n        .map((item: any) => item[this.gridRowSelectByValue])\n        .filter((id: any) => id);\n      this.selectAllState = 'checked';\n      this.selectedItemCount = this._gridView.data.length;\n    } else if (this.selectedRows?.length > 0 && this.disablePreSelectedRows) {\n      this._preSelected = this.selectedRows;\n      this.selectAllState = 'indeterminate';\n      this.selectedItemCount = 0;\n    } else {\n      this._preSelected = [];\n      this.selectAllState = 'unchecked';\n      this.selectedItemCount = 0;\n    }\n    this.addSelectAllMessage(this.selectAllState === 'checked');\n  }\n\n  canEnableSelectAll() {\n    return (this.selectedRows?.length == this._gridView.total &&\n      this.disablePreSelectedRows)\n  }\n\n  public cellCloseHandler(args: CellCloseEvent): void {\n    let { formGroup, dataItem } = args;\n    if (!formGroup.valid) {\n      args.preventDefault();\n    } else if (formGroup.dirty) {\n      if (args.originalEvent && args.originalEvent.keyCode === Keys.Escape) {\n        return;\n      }\n      Object.assign(dataItem, formGroup.value);\n      this.saveChanges();\n      this.updatedData.emit(this.grid.data)\n    }\n  }\n\n  public saveChanges(): void {\n    this.grid.closeCell();\n    this.grid.cancelCell();\n  }\n\n  refreshGridData() {\n    this.emitRefreshEvt.emit();\n  }\n\n}\n","<div #gridElement [ngClass]=\"columnContentNoWrap ? 'column-content-nowrap' : ''\">\n  <kendo-grid [data]=\"_gridView\" [pageSize]=\"pageSize\" [skip]=\"skip\" [selectable]=\"selectableSettings\"\n    [pageable]=\"pageable\" [sortable]=\"sortable\" [loading]=\"gridLoading\" [groupable]=\"groupable\"\n    [reorderable]=\"reorderable\" [resizable]=\"resizable\" [columnMenu]=\"columnMenu\" [navigable]=\"navigable\"\n    [height]=\"gridHeight\" (change)=\"setSelectableSettings()\" (selectedKeysChange)=\"selectedKeysChange($event)\"\n    [kendoGridSelectBy]=\"gridRowSelectByValue\" (detailExpand)=\"onDetailExpand($event)\" [selectedKeys]=\"_preSelected\"\n    (pageChange)=\"pageChange($event)\" (cellClick)=\"cellClickHandler($event)\" (cellClose)=\"cellCloseHandler($event)\"\n    [sort]=\"sort\" (sortChange)=\"sortChange($event)\" (scrollBottom)=\"scrollBottom()\" [ngClass]=\"getHeaderHeight()\"\n    id=\"lib-grid\" [rowClass]=\"rowClass\">\n    <div #selectAllMessageElement>\n      <div class=\"lib-grid-select-all-message-container\"\n        *ngIf=\"((selectedItemCount < _gridView.total) || allPagesSelected)\">\n        <div *ngIf=\"(selectedItemCount < _gridView.total)\" class=\"lib-grid-select-all-message\">\n          <lib-typography [defaultText]=\"'All '+selectedItemCount+' '+itemName+' on this page are selected.'\"\n            type=\"BODY_SMALL\"></lib-typography>\n          <u><lib-typography (click)=\"selectAcrossPages(true)\" class=\"select-all-handler\"\n              [defaultText]=\"'Select all '+_gridView.total+' '+itemName+' from all pages'\"\n              type=\"BODY_SMALL\"></lib-typography></u>\n        </div>\n        <div *ngIf=\"allPagesSelected\" class=\"lib-grid-select-all-message\">\n          <lib-icon name=\"circle-checked\" class=\"all-selected-icon\"></lib-icon>\n          <lib-typography [defaultText]=\"'All '+_gridView.total+' '+itemName+' across all pages are selected.'\"\n            type=\"BODY_SMALL\"></lib-typography>\n          <u><lib-typography (click)=\"selectAcrossPages(false)\" class=\"select-all-handler\"\n              [defaultText]=\"'Clear selection'\" type=\"BODY_SMALL\"></lib-typography></u>\n        </div>\n      </div>\n    </div>\n    <ng-template kendoGridToolbarTemplate [position]=\"getPosition()\" let-position=\"position\">\n      <ng-container *ngIf=\"showToolbar && position === 'top'\">\n        <ng-content></ng-content>\n        <ng-container *ngIf=\"showRefresh\">\n          <ng-container *ngTemplateOutlet=\"showRefreshTemplate\"></ng-container>\n        </ng-container>\n      </ng-container>\n      <ng-container *ngIf=\"infiniteScrollLoader && position === 'bottom'\">\n        <lib-grid-pagination-spacer></lib-grid-pagination-spacer>\n        <lib-loader [type]=\"loaderType\" [size]=\"loaderSize\" [themeColor]=\"loaderTheme\"></lib-loader>\n        <lib-grid-pagination-spacer></lib-grid-pagination-spacer>\n      </ng-container>\n    </ng-template>\n\n    <ng-template #showRefreshTemplate>\n      <lib-tooltip position=\"top\" showOn=\"hover\" [tooltipWidth]=\"68\" [callout]=\"true\">\n        <div class=\"tooltip-content\">\n          <lib-typography defaultText=\"Refresh\"></lib-typography>\n        </div>\n        <lib-button size=\"small\" width=\"2.4rem\" rounded=\"small\" fillMode=\"solid\" themeColor=\"primary\" iconName=\"reset\"\n          [toggleable]=\"false\" (buttonClick)=\"refreshGridData()\" [iconButton]=\"true\" [iconFontSize]=\"13\"></lib-button>\n      </lib-tooltip>\n    </ng-template>\n\n    <ng-template kendoGridLoadingTemplate>\n      <div class=\"k-loading-color\"></div>\n      <div class=\"loading-container\">\n        <lib-loader [type]=\"loaderType\" [size]=\"loaderSize\" [themeColor]=\"loaderTheme\"></lib-loader>\n      </div>\n    </ng-template>\n\n    <ng-template *ngIf=\"this._gridView.total === 0\" kendoGridNoRecordsTemplate>\n      <lib-typography *ngIf=\"!loading\" [defaultText]=\"noRecordsContent\" type=\"BODY_MEDIUM\"></lib-typography>\n      <lib-loader *ngIf=\"loading\" [type]=\"loaderType\" [size]=\"loaderSize\" [themeColor]=\"loaderTheme\"></lib-loader>\n    </ng-template>\n    <ng-container *ngIf=\"this._gridView.total > 0\">\n      <kendo-grid-checkbox-column #selectAllCheckbox headerClass=\"select-all-header\" *ngIf=\"checkBoxRequired\"\n        [width]=\"checkBoxWidth\" [resizable]=\"checkBoxColumnResizable\" [columnMenu]=\"checkBoxColumnMenu\"\n        class=\"checkbox-column\" [sticky]=\"isCheckBoxColumnSticky && !customExpandRowColumn\">\n        <ng-template kendoGridHeaderTemplate *ngIf=\"isSelectAllCheckboxRequired\">\n          <input id=\"selectAllCheckboxId\" type=\"checkbox\" kendoCheckBox kendoGridSelectAllCheckbox\n            [state]=\"selectAllState\" (selectAllChange)=\"onSelectAllChange($event)\" />\n        </ng-template>\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\" [minResizableWidth]=\"minResizableWidth\" [sortable]=\"item.sortable\"\n        [editor]=\"item.editor\" [class]=\"item.class\" [sticky]=\"item.columnSticky && !customExpandRowColumn\">\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.customColumn\" kendoGridCellTemplate let-dataItem>\n          <ng-container [ngTemplateOutlet]=\"columnTemplateDict[item.type]\"\n            [ngTemplateOutletContext]=\"{$implicit: dataItem}\"></ng-container>\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        [sticky]=\"isDeleteColumnSticky && !customExpandRowColumn\">\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        [sticky]=\"isKebabColumnSticky && !customExpandRowColumn\">\n        <ng-template kendoGridCellTemplate let-dataItem let-rowIndex=\"rowIndex\">\n          <kendo-dropdownbutton *ngIf=\"!hideKebabRowIndex.includes(rowIndex)\" [svgIcon]=\"icon\" fillMode=\"none\"\n            [data]=\"kebabList | kebabMenuFilter : dataItem\" class=\"kebab\" (itemClick)=\"onKebabClick($event, dataItem)\"\n            [popupSettings]=\"{ align: 'right', animate: true, popupClass: 'kebab-list' }\">\n          </kendo-dropdownbutton>\n        </ng-template>\n      </kendo-grid-column>\n    </ng-container>\n\n    <!-- Limitation: detail template and sticky columns do not co-exist-->\n    <ng-template *ngIf=\"customExpandRowColumn\" 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        <div [ngClass]=\"expandColumnClass()\">\n          <span *ngIf=\"selectedRows.includes(dataItem[gridRowSelectByValue]) && disablePreSelectedRows\"\n            class=\"expand-column-text\">\n            Already added\n          </span>\n          <kendo-button *ngIf=\"!expandRowIndex.includes(rowIndex)\" [svgIcon]=\"arrowDownIcon\"\n            (click)=\"expandRow(rowIndex)\" fillMode=\"none\" class=\"arrow-btn\">\n          </kendo-button>\n          <kendo-button *ngIf=\"expandRowIndex.includes(rowIndex)\" [svgIcon]=\"arrowUpIcon\"\n            (click)=\"collapseRow(rowIndex)\" fillMode=\"none\" class=\"arrow-btn\">\n          </kendo-button>\n        </div>\n      </ng-template>\n    </kendo-grid-column>\n\n    <ng-template kendoPagerTemplate let-totalPages=\"totalPages\" let-currentPage=\"currentPage\">\n      <div class=\"pagination-wrapper\" [ngClass]=\"allPagesSelected ? 'pagination-disabled' : ''\">\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      </div>\n    </ng-template>\n\n  </kendo-grid>\n</div>\n"]}
|