@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.
Files changed (220) hide show
  1. package/esm2022/lib/atoms/alert/alert.component.mjs +40 -0
  2. package/esm2022/lib/atoms/alert/alert.module.mjs +24 -0
  3. package/esm2022/lib/atoms/angular-popup/angular-popup.component.mjs +34 -0
  4. package/esm2022/lib/atoms/angular-popup/angular-popup.module.mjs +32 -0
  5. package/esm2022/lib/atoms/atoms.module.mjs +304 -0
  6. package/esm2022/lib/atoms/avatar/avatar.component.mjs +62 -0
  7. package/esm2022/lib/atoms/avatar/avatar.module.mjs +32 -0
  8. package/esm2022/lib/atoms/breadcrumb/breadcrumb.component.mjs +58 -0
  9. package/esm2022/lib/atoms/breadcrumb/breadcrumb.module.mjs +40 -0
  10. package/esm2022/lib/atoms/button/button.component.mjs +85 -0
  11. package/esm2022/lib/atoms/button/button.module.mjs +36 -0
  12. package/esm2022/lib/atoms/button-group/button-group.component.mjs +51 -0
  13. package/esm2022/lib/atoms/button-group/button-group.module.mjs +36 -0
  14. package/esm2022/lib/atoms/checkbox/checkbox.component.mjs +47 -0
  15. package/esm2022/lib/atoms/checkbox/checkbox.module.mjs +36 -0
  16. package/esm2022/lib/atoms/chip/chip.component.mjs +32 -0
  17. package/esm2022/lib/atoms/chip/chip.module.mjs +44 -0
  18. package/esm2022/lib/atoms/chip-list/chip-list.component.mjs +87 -0
  19. package/esm2022/lib/atoms/chip-list/chip-list.module.mjs +52 -0
  20. package/esm2022/lib/atoms/clipboard/clipboard.component.mjs +111 -0
  21. package/esm2022/lib/atoms/clipboard/clipboard.module.mjs +40 -0
  22. package/esm2022/lib/atoms/container/container.component.mjs +28 -0
  23. package/esm2022/lib/atoms/container/container.module.mjs +24 -0
  24. package/esm2022/lib/atoms/date-range/date-range.component.mjs +49 -0
  25. package/esm2022/lib/atoms/date-range/date-range.module.mjs +39 -0
  26. package/esm2022/lib/atoms/datepicker/datepicker.component.mjs +91 -0
  27. package/esm2022/lib/atoms/datepicker/datepicker.module.mjs +35 -0
  28. package/esm2022/lib/atoms/drag-and-drop/drag-and-drop.component.mjs +88 -0
  29. package/esm2022/lib/atoms/drag-and-drop/drag-and-drop.module.mjs +44 -0
  30. package/esm2022/lib/atoms/dropdown/dropdown.component.mjs +200 -0
  31. package/esm2022/lib/atoms/dropdown/dropdown.module.mjs +43 -0
  32. package/esm2022/lib/atoms/dropdown-button/dropdown-button.component.mjs +46 -0
  33. package/esm2022/lib/atoms/dropdown-button/dropdown-button.module.mjs +36 -0
  34. package/esm2022/lib/atoms/dropdown-tree/dropdowntree.component.mjs +102 -0
  35. package/esm2022/lib/atoms/dropdown-tree/dropdowntree.module.mjs +43 -0
  36. package/esm2022/lib/atoms/expansion-panel/expansion-panel.component.mjs +51 -0
  37. package/esm2022/lib/atoms/expansion-panel/expansion-panel.module.mjs +56 -0
  38. package/esm2022/lib/atoms/icon/icon.component.mjs +37 -0
  39. package/esm2022/lib/atoms/icon/icon.module.mjs +21 -0
  40. package/esm2022/lib/atoms/labels/label.component.mjs +25 -0
  41. package/esm2022/lib/atoms/labels/label.module.mjs +32 -0
  42. package/esm2022/lib/atoms/list-views/list-view.component.mjs +91 -0
  43. package/esm2022/lib/atoms/list-views/list-view.module.mjs +60 -0
  44. package/esm2022/lib/atoms/loader/loader.component.mjs +48 -0
  45. package/esm2022/lib/atoms/loader/loader.module.mjs +28 -0
  46. package/esm2022/lib/atoms/loading-spinner/loading-spinner.component.mjs +25 -0
  47. package/esm2022/lib/atoms/loading-spinner/loading-spinner.module.mjs +24 -0
  48. package/esm2022/lib/atoms/multi-select-dropdown/multi-select-dropdown.component.mjs +150 -0
  49. package/esm2022/lib/atoms/multi-select-dropdown/multi-select-dropdown.module.mjs +43 -0
  50. package/esm2022/lib/atoms/notification/notification.component.mjs +69 -0
  51. package/esm2022/lib/atoms/notification/notification.module.mjs +24 -0
  52. package/esm2022/lib/atoms/numeric-textbox/numeric-textbox.component.mjs +75 -0
  53. package/esm2022/lib/atoms/numeric-textbox/numeric-textbox.module.mjs +35 -0
  54. package/esm2022/lib/atoms/progress-bar/progress-bar.component.mjs +19 -0
  55. package/esm2022/lib/atoms/progress-bar/progress-bar.module.mjs +24 -0
  56. package/esm2022/lib/atoms/radio-button/radio-button.component.mjs +53 -0
  57. package/esm2022/lib/atoms/radio-button/radio-button.module.mjs +39 -0
  58. package/esm2022/lib/atoms/search-box/search-box.component.mjs +108 -0
  59. package/esm2022/lib/atoms/search-box/search-box.module.mjs +40 -0
  60. package/esm2022/lib/atoms/slider/slider.component.mjs +58 -0
  61. package/esm2022/lib/atoms/slider/slider.module.mjs +28 -0
  62. package/esm2022/lib/atoms/stepper/stepper.component.mjs +38 -0
  63. package/esm2022/lib/atoms/stepper/stepper.module.mjs +52 -0
  64. package/esm2022/lib/atoms/switch/switch.component.mjs +53 -0
  65. package/esm2022/lib/atoms/switch/switch.module.mjs +59 -0
  66. package/esm2022/lib/atoms/text-area/text-area.component.mjs +93 -0
  67. package/esm2022/lib/atoms/text-area/text-area.module.mjs +36 -0
  68. package/esm2022/lib/atoms/textbox/textbox.component.mjs +115 -0
  69. package/esm2022/lib/atoms/textbox/textbox.module.mjs +40 -0
  70. package/esm2022/lib/atoms/time-picker/time-picker.component.mjs +83 -0
  71. package/esm2022/lib/atoms/time-picker/time-picker.module.mjs +35 -0
  72. package/esm2022/lib/atoms/timescheduler/timescheduler.component.mjs +79 -0
  73. package/esm2022/lib/atoms/timescheduler/timescheduler.module.mjs +35 -0
  74. package/esm2022/lib/atoms/toast-notification/toast-notification.module.mjs +31 -0
  75. package/esm2022/lib/atoms/toast-notification/toast-notification.service.mjs +160 -0
  76. package/esm2022/lib/atoms/tooltip/tooltip.component.mjs +48 -0
  77. package/esm2022/lib/atoms/tooltip/tooltip.module.mjs +24 -0
  78. package/esm2022/lib/atoms/typography/TypographyType.mjs +2 -0
  79. package/esm2022/lib/atoms/typography/typography.component.mjs +78 -0
  80. package/esm2022/lib/atoms/typography/typography.module.mjs +24 -0
  81. package/esm2022/lib/atoms/uploader/uploader.component.mjs +213 -0
  82. package/esm2022/lib/atoms/uploader/uploader.module.mjs +53 -0
  83. package/esm2022/lib/molecules/card/card-actions/card-actions.component.mjs +20 -0
  84. package/esm2022/lib/molecules/card/card-body/card-body.component.mjs +12 -0
  85. package/esm2022/lib/molecules/card/card-footer/card-footer.component.mjs +12 -0
  86. package/esm2022/lib/molecules/card/card-header/card-header.component.mjs +31 -0
  87. package/esm2022/lib/molecules/card/card.component.mjs +20 -0
  88. package/esm2022/lib/molecules/card/card.module.mjs +52 -0
  89. package/esm2022/lib/molecules/dialog/confirmation-dialog/confirmation-dialog.component.mjs +81 -0
  90. package/esm2022/lib/molecules/dialog/dialog-actions/dialog-actions.component.mjs +17 -0
  91. package/esm2022/lib/molecules/dialog/dialog-titlebar/dialog-titlebar.component.mjs +40 -0
  92. package/esm2022/lib/molecules/dialog/dialog.component.mjs +53 -0
  93. package/esm2022/lib/molecules/dialog/dialog.module.mjs +55 -0
  94. package/esm2022/lib/molecules/grid-form/grid-form.component.mjs +110 -0
  95. package/esm2022/lib/molecules/grid-form/grid-form.module.mjs +59 -0
  96. package/esm2022/lib/molecules/grid-layout/grid-layout-item/grid-layout-item.component.mjs +37 -0
  97. package/esm2022/lib/molecules/grid-layout/grid-layout.component.mjs +32 -0
  98. package/esm2022/lib/molecules/grid-layout/grid-layout.module.mjs +33 -0
  99. package/esm2022/lib/molecules/grid-pagination/grid-pagination-spacer/grid-pagination-spacer.component.mjs +12 -0
  100. package/esm2022/lib/molecules/grid-pagination/grid-pagination.component.mjs +621 -0
  101. package/esm2022/lib/molecules/grid-pagination/grid-pagination.module.mjs +84 -0
  102. package/esm2022/lib/molecules/grid-pagination/kebab-menu-filter.pipe.mjs +22 -0
  103. package/esm2022/lib/molecules/molecules.module.mjs +66 -0
  104. package/esm2022/lib/molecules/tabstrip/tabstrip-tab/tabstrip-tab.component.mjs +25 -0
  105. package/esm2022/lib/molecules/tabstrip/tabstrip.component.mjs +37 -0
  106. package/esm2022/lib/molecules/tabstrip/tabstrip.module.mjs +33 -0
  107. package/esm2022/lib/shared.component.mjs +4 -4
  108. package/esm2022/lib/shared.module.mjs +25 -10
  109. package/esm2022/public-api.mjs +114 -2
  110. package/fesm2022/progress-chef-platform-shared-components.mjs +5698 -14
  111. package/fesm2022/progress-chef-platform-shared-components.mjs.map +1 -1
  112. package/lib/atoms/alert/alert.component.d.ts +20 -0
  113. package/lib/atoms/alert/alert.module.d.ts +8 -0
  114. package/lib/atoms/angular-popup/angular-popup.component.d.ts +15 -0
  115. package/lib/atoms/angular-popup/angular-popup.module.d.ts +10 -0
  116. package/lib/atoms/atoms.module.d.ts +48 -0
  117. package/lib/atoms/avatar/avatar.component.d.ts +21 -0
  118. package/lib/atoms/avatar/avatar.module.d.ts +10 -0
  119. package/lib/atoms/breadcrumb/breadcrumb.component.d.ts +17 -0
  120. package/lib/atoms/breadcrumb/breadcrumb.module.d.ts +12 -0
  121. package/lib/atoms/button/button.component.d.ts +29 -0
  122. package/lib/atoms/button/button.module.d.ts +11 -0
  123. package/lib/atoms/button-group/button-group.component.d.ts +20 -0
  124. package/lib/atoms/button-group/button-group.module.d.ts +11 -0
  125. package/lib/atoms/checkbox/checkbox.component.d.ts +21 -0
  126. package/lib/atoms/checkbox/checkbox.module.d.ts +11 -0
  127. package/lib/atoms/chip/chip.component.d.ts +12 -0
  128. package/lib/atoms/chip/chip.module.d.ts +13 -0
  129. package/lib/atoms/chip-list/chip-list.component.d.ts +32 -0
  130. package/lib/atoms/chip-list/chip-list.module.d.ts +15 -0
  131. package/lib/atoms/clipboard/clipboard.component.d.ts +35 -0
  132. package/lib/atoms/clipboard/clipboard.module.d.ts +12 -0
  133. package/lib/atoms/container/container.component.d.ts +9 -0
  134. package/lib/atoms/container/container.module.d.ts +8 -0
  135. package/lib/atoms/date-range/date-range.component.d.ts +24 -0
  136. package/lib/atoms/date-range/date-range.module.d.ts +11 -0
  137. package/lib/atoms/datepicker/datepicker.component.d.ts +32 -0
  138. package/lib/atoms/datepicker/datepicker.module.d.ts +10 -0
  139. package/lib/atoms/drag-and-drop/drag-and-drop.component.d.ts +26 -0
  140. package/lib/atoms/drag-and-drop/drag-and-drop.module.d.ts +13 -0
  141. package/lib/atoms/dropdown/dropdown.component.d.ts +67 -0
  142. package/lib/atoms/dropdown/dropdown.module.d.ts +12 -0
  143. package/lib/atoms/dropdown-button/dropdown-button.component.d.ts +17 -0
  144. package/lib/atoms/dropdown-button/dropdown-button.module.d.ts +11 -0
  145. package/lib/atoms/dropdown-tree/dropdowntree.component.d.ts +35 -0
  146. package/lib/atoms/dropdown-tree/dropdowntree.module.d.ts +12 -0
  147. package/lib/atoms/expansion-panel/expansion-panel.component.d.ts +21 -0
  148. package/lib/atoms/expansion-panel/expansion-panel.module.d.ts +16 -0
  149. package/lib/atoms/icon/icon.component.d.ts +14 -0
  150. package/lib/atoms/icon/icon.module.d.ts +7 -0
  151. package/lib/atoms/labels/label.component.d.ts +12 -0
  152. package/lib/atoms/labels/label.module.d.ts +10 -0
  153. package/lib/atoms/list-views/list-view.component.d.ts +32 -0
  154. package/lib/atoms/list-views/list-view.module.d.ts +17 -0
  155. package/lib/atoms/loader/loader.component.d.ts +30 -0
  156. package/lib/atoms/loader/loader.module.d.ts +9 -0
  157. package/lib/atoms/loading-spinner/loading-spinner.component.d.ts +11 -0
  158. package/lib/atoms/loading-spinner/loading-spinner.module.d.ts +8 -0
  159. package/lib/atoms/multi-select-dropdown/multi-select-dropdown.component.d.ts +50 -0
  160. package/lib/atoms/multi-select-dropdown/multi-select-dropdown.module.d.ts +12 -0
  161. package/lib/atoms/notification/notification.component.d.ts +24 -0
  162. package/lib/atoms/notification/notification.module.d.ts +8 -0
  163. package/lib/atoms/numeric-textbox/numeric-textbox.component.d.ts +28 -0
  164. package/lib/atoms/numeric-textbox/numeric-textbox.module.d.ts +10 -0
  165. package/lib/atoms/progress-bar/progress-bar.component.d.ts +9 -0
  166. package/lib/atoms/progress-bar/progress-bar.module.d.ts +8 -0
  167. package/lib/atoms/radio-button/radio-button.component.d.ts +22 -0
  168. package/lib/atoms/radio-button/radio-button.module.d.ts +11 -0
  169. package/lib/atoms/search-box/search-box.component.d.ts +37 -0
  170. package/lib/atoms/search-box/search-box.module.d.ts +12 -0
  171. package/lib/atoms/slider/slider.component.d.ts +18 -0
  172. package/lib/atoms/slider/slider.module.d.ts +9 -0
  173. package/lib/atoms/stepper/stepper.component.d.ts +25 -0
  174. package/lib/atoms/stepper/stepper.module.d.ts +15 -0
  175. package/lib/atoms/switch/switch.component.d.ts +20 -0
  176. package/lib/atoms/switch/switch.module.d.ts +16 -0
  177. package/lib/atoms/text-area/text-area.component.d.ts +35 -0
  178. package/lib/atoms/text-area/text-area.module.d.ts +11 -0
  179. package/lib/atoms/textbox/textbox.component.d.ts +37 -0
  180. package/lib/atoms/textbox/textbox.module.d.ts +12 -0
  181. package/lib/atoms/time-picker/time-picker.component.d.ts +31 -0
  182. package/lib/atoms/time-picker/time-picker.module.d.ts +10 -0
  183. package/lib/atoms/timescheduler/timescheduler.component.d.ts +28 -0
  184. package/lib/atoms/timescheduler/timescheduler.module.d.ts +10 -0
  185. package/lib/atoms/toast-notification/toast-notification.module.d.ts +8 -0
  186. package/lib/atoms/toast-notification/toast-notification.service.d.ts +51 -0
  187. package/lib/atoms/tooltip/tooltip.component.d.ts +17 -0
  188. package/lib/atoms/tooltip/tooltip.module.d.ts +8 -0
  189. package/lib/atoms/typography/TypographyType.d.ts +1 -0
  190. package/lib/atoms/typography/typography.component.d.ts +25 -0
  191. package/lib/atoms/typography/typography.module.d.ts +8 -0
  192. package/lib/atoms/uploader/uploader.component.d.ts +64 -0
  193. package/lib/atoms/uploader/uploader.module.d.ts +14 -0
  194. package/lib/molecules/card/card-actions/card-actions.component.d.ts +8 -0
  195. package/lib/molecules/card/card-body/card-body.component.d.ts +5 -0
  196. package/lib/molecules/card/card-footer/card-footer.component.d.ts +5 -0
  197. package/lib/molecules/card/card-header/card-header.component.d.ts +11 -0
  198. package/lib/molecules/card/card.component.d.ts +7 -0
  199. package/lib/molecules/card/card.module.d.ts +14 -0
  200. package/lib/molecules/dialog/confirmation-dialog/confirmation-dialog.component.d.ts +20 -0
  201. package/lib/molecules/dialog/dialog-actions/dialog-actions.component.d.ts +7 -0
  202. package/lib/molecules/dialog/dialog-titlebar/dialog-titlebar.component.d.ts +16 -0
  203. package/lib/molecules/dialog/dialog.component.d.ts +20 -0
  204. package/lib/molecules/dialog/dialog.module.d.ts +15 -0
  205. package/lib/molecules/grid-form/grid-form.component.d.ts +33 -0
  206. package/lib/molecules/grid-form/grid-form.module.d.ts +16 -0
  207. package/lib/molecules/grid-layout/grid-layout-item/grid-layout-item.component.d.ts +14 -0
  208. package/lib/molecules/grid-layout/grid-layout.component.d.ts +11 -0
  209. package/lib/molecules/grid-layout/grid-layout.module.d.ts +10 -0
  210. package/lib/molecules/grid-pagination/grid-pagination-spacer/grid-pagination-spacer.component.d.ts +5 -0
  211. package/lib/molecules/grid-pagination/grid-pagination.component.d.ts +150 -0
  212. package/lib/molecules/grid-pagination/grid-pagination.module.d.ts +21 -0
  213. package/lib/molecules/grid-pagination/kebab-menu-filter.pipe.d.ts +7 -0
  214. package/lib/molecules/molecules.module.d.ts +14 -0
  215. package/lib/molecules/tabstrip/tabstrip-tab/tabstrip-tab.component.d.ts +10 -0
  216. package/lib/molecules/tabstrip/tabstrip.component.d.ts +15 -0
  217. package/lib/molecules/tabstrip/tabstrip.module.d.ts +10 -0
  218. package/lib/shared.module.d.ts +5 -2
  219. package/package.json +32 -5
  220. 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"]}