@progress-chef/platform-shared-components 0.0.142 → 0.0.144
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/atoms/alert/alert.component.mjs +6 -6
- package/esm2022/lib/atoms/alert/alert.module.mjs +13 -8
- package/esm2022/lib/atoms/angular-popup/angular-popup.component.mjs +10 -5
- package/esm2022/lib/atoms/angular-popup/angular-popup.module.mjs +12 -10
- package/esm2022/lib/atoms/atoms.module.mjs +4 -4
- package/esm2022/lib/atoms/avatar/avatar.component.mjs +14 -8
- package/esm2022/lib/atoms/avatar/avatar.module.mjs +19 -11
- package/esm2022/lib/atoms/breadcrumb/breadcrumb.component.mjs +6 -5
- package/esm2022/lib/atoms/breadcrumb/breadcrumb.module.mjs +8 -8
- package/esm2022/lib/atoms/button/button.component.mjs +42 -14
- package/esm2022/lib/atoms/button/button.module.mjs +12 -8
- package/esm2022/lib/atoms/button-group/button-group.component.mjs +17 -9
- package/esm2022/lib/atoms/button-group/button-group.module.mjs +12 -10
- package/esm2022/lib/atoms/checkbox/checkbox.component.mjs +18 -9
- package/esm2022/lib/atoms/checkbox/checkbox.module.mjs +12 -10
- package/esm2022/lib/atoms/chip/chip.component.mjs +8 -6
- package/esm2022/lib/atoms/chip/chip.module.mjs +8 -8
- package/esm2022/lib/atoms/chip-list/chip-list.component.mjs +31 -10
- package/esm2022/lib/atoms/chip-list/chip-list.module.mjs +12 -10
- package/esm2022/lib/atoms/clipboard/clipboard.component.mjs +27 -11
- package/esm2022/lib/atoms/clipboard/clipboard.module.mjs +12 -10
- package/esm2022/lib/atoms/container/container.component.mjs +5 -5
- package/esm2022/lib/atoms/container/container.module.mjs +7 -8
- package/esm2022/lib/atoms/date-range/date-range.component.mjs +13 -6
- package/esm2022/lib/atoms/date-range/date-range.module.mjs +17 -11
- package/esm2022/lib/atoms/datepicker/datepicker.component.mjs +20 -12
- package/esm2022/lib/atoms/datepicker/datepicker.module.mjs +16 -10
- package/esm2022/lib/atoms/drag-and-drop/drag-and-drop.component.mjs +20 -12
- package/esm2022/lib/atoms/drag-and-drop/drag-and-drop.module.mjs +8 -8
- package/esm2022/lib/atoms/dropdown/dropdown.component.mjs +45 -17
- package/esm2022/lib/atoms/dropdown/dropdown.module.mjs +12 -10
- package/esm2022/lib/atoms/dropdown-button/dropdown-button.component.mjs +15 -8
- package/esm2022/lib/atoms/dropdown-button/dropdown-button.module.mjs +12 -10
- package/esm2022/lib/atoms/dropdown-tree/dropdowntree.component.mjs +36 -12
- package/esm2022/lib/atoms/dropdown-tree/dropdowntree.module.mjs +12 -10
- package/esm2022/lib/atoms/expansion-panel/expansion-panel.component.mjs +18 -10
- package/esm2022/lib/atoms/expansion-panel/expansion-panel.module.mjs +12 -10
- package/esm2022/lib/atoms/icon/icon.component.mjs +16 -6
- package/esm2022/lib/atoms/icon/icon.module.mjs +11 -7
- package/esm2022/lib/atoms/labels/label.component.mjs +16 -7
- package/esm2022/lib/atoms/labels/label.module.mjs +8 -8
- package/esm2022/lib/atoms/list-views/list-view.component.mjs +32 -13
- package/esm2022/lib/atoms/list-views/list-view.module.mjs +12 -10
- package/esm2022/lib/atoms/loader/loader.component.mjs +9 -8
- package/esm2022/lib/atoms/loader/loader.module.mjs +8 -8
- package/esm2022/lib/atoms/loading-spinner/loading-spinner.component.mjs +28 -8
- package/esm2022/lib/atoms/loading-spinner/loading-spinner.module.mjs +15 -9
- package/esm2022/lib/atoms/multi-select-dropdown/multi-select-dropdown.component.mjs +40 -20
- package/esm2022/lib/atoms/multi-select-dropdown/multi-select-dropdown.module.mjs +12 -10
- package/esm2022/lib/atoms/notification/notification.component.mjs +5 -5
- package/esm2022/lib/atoms/notification/notification.module.mjs +7 -8
- package/esm2022/lib/atoms/numeric-textbox/numeric-textbox.component.mjs +73 -16
- package/esm2022/lib/atoms/numeric-textbox/numeric-textbox.module.mjs +8 -8
- package/esm2022/lib/atoms/progress-bar/progress-bar.component.mjs +18 -6
- package/esm2022/lib/atoms/progress-bar/progress-bar.module.mjs +14 -8
- package/esm2022/lib/atoms/radio-button/radio-button.component.mjs +18 -9
- package/esm2022/lib/atoms/radio-button/radio-button.module.mjs +12 -10
- package/esm2022/lib/atoms/search-box/search-box.component.mjs +47 -15
- package/esm2022/lib/atoms/search-box/search-box.module.mjs +12 -10
- package/esm2022/lib/atoms/slider/slider.component.mjs +24 -9
- package/esm2022/lib/atoms/slider/slider.module.mjs +12 -10
- package/esm2022/lib/atoms/stepper/stepper.component.mjs +30 -8
- package/esm2022/lib/atoms/stepper/stepper.module.mjs +8 -8
- package/esm2022/lib/atoms/switch/switch.component.mjs +17 -9
- package/esm2022/lib/atoms/switch/switch.module.mjs +8 -8
- package/esm2022/lib/atoms/text-area/text-area.component.mjs +44 -14
- package/esm2022/lib/atoms/text-area/text-area.module.mjs +12 -10
- package/esm2022/lib/atoms/textbox/textbox.component.mjs +46 -16
- package/esm2022/lib/atoms/textbox/textbox.module.mjs +12 -10
- package/esm2022/lib/atoms/time-picker/time-picker.component.mjs +17 -8
- package/esm2022/lib/atoms/time-picker/time-picker.module.mjs +17 -11
- package/esm2022/lib/atoms/timescheduler/timescheduler.component.mjs +15 -8
- package/esm2022/lib/atoms/timescheduler/timescheduler.module.mjs +16 -10
- package/esm2022/lib/atoms/tooltip/tooltip.component.mjs +38 -12
- package/esm2022/lib/atoms/tooltip/tooltip.module.mjs +14 -8
- package/esm2022/lib/atoms/typography/TypographyType.mjs +1 -1
- package/esm2022/lib/atoms/typography/typography.component.mjs +10 -7
- package/esm2022/lib/atoms/typography/typography.module.mjs +11 -9
- package/esm2022/lib/atoms/uploader/uploader.component.mjs +34 -17
- package/esm2022/lib/atoms/uploader/uploader.module.mjs +13 -10
- package/esm2022/lib/molecules/card/card-actions/card-actions.component.mjs +8 -5
- package/esm2022/lib/molecules/card/card-body/card-body.component.mjs +8 -5
- package/esm2022/lib/molecules/card/card-footer/card-footer.component.mjs +8 -5
- package/esm2022/lib/molecules/card/card-header/card-header.component.mjs +14 -8
- package/esm2022/lib/molecules/card/card.component.mjs +11 -37
- package/esm2022/lib/molecules/card/card.module.mjs +19 -17
- package/esm2022/lib/molecules/dialog/confirmation-dialog/confirmation-dialog.component.mjs +28 -11
- package/esm2022/lib/molecules/dialog/dialog-actions/dialog-actions.component.mjs +8 -5
- package/esm2022/lib/molecules/dialog/dialog-titlebar/dialog-titlebar.component.mjs +16 -7
- package/esm2022/lib/molecules/dialog/dialog.component.mjs +35 -9
- package/esm2022/lib/molecules/dialog/dialog.module.mjs +32 -14
- package/esm2022/lib/molecules/grid-form/grid-form.component.mjs +26 -14
- package/esm2022/lib/molecules/grid-form/grid-form.module.mjs +12 -14
- package/esm2022/lib/molecules/grid-layout/grid-layout-item/grid-layout-item.component.mjs +30 -7
- package/esm2022/lib/molecules/grid-layout/grid-layout.component.mjs +27 -7
- package/esm2022/lib/molecules/grid-layout/grid-layout.module.mjs +15 -12
- package/esm2022/lib/molecules/grid-pagination/grid-pagination-spacer/grid-pagination-spacer.component.mjs +8 -5
- package/esm2022/lib/molecules/grid-pagination/grid-pagination.component.mjs +137 -70
- package/esm2022/lib/molecules/grid-pagination/grid-pagination.module.mjs +16 -24
- package/esm2022/lib/molecules/grid-pagination/kebab-menu-filter.pipe.mjs +5 -4
- package/esm2022/lib/molecules/molecules.module.mjs +6 -6
- package/esm2022/lib/molecules/tabstrip/tabstrip-tab/tabstrip-tab.component.mjs +7 -6
- package/esm2022/lib/molecules/tabstrip/tabstrip.component.mjs +19 -8
- package/esm2022/lib/molecules/tabstrip/tabstrip.module.mjs +14 -12
- package/esm2022/lib/shared.component.mjs +5 -5
- package/esm2022/lib/shared.module.mjs +7 -6
- package/esm2022/public-api.mjs +4 -2
- package/fesm2022/progress-chef-platform-shared-components.mjs +1747 -1039
- package/fesm2022/progress-chef-platform-shared-components.mjs.map +1 -1
- package/lib/atoms/alert/alert.component.d.ts +1 -1
- package/lib/atoms/alert/alert.module.d.ts +4 -3
- package/lib/atoms/angular-popup/angular-popup.component.d.ts +1 -1
- package/lib/atoms/angular-popup/angular-popup.module.d.ts +1 -1
- package/lib/atoms/avatar/avatar.component.d.ts +1 -1
- package/lib/atoms/avatar/avatar.module.d.ts +3 -3
- package/lib/atoms/breadcrumb/breadcrumb.component.d.ts +1 -1
- package/lib/atoms/breadcrumb/breadcrumb.module.d.ts +1 -1
- package/lib/atoms/button/button.component.d.ts +16 -3
- package/lib/atoms/button/button.module.d.ts +5 -4
- package/lib/atoms/button-group/button-group.component.d.ts +3 -1
- package/lib/atoms/button-group/button-group.module.d.ts +1 -1
- package/lib/atoms/checkbox/checkbox.component.d.ts +3 -3
- package/lib/atoms/checkbox/checkbox.module.d.ts +1 -1
- package/lib/atoms/chip/chip.component.d.ts +3 -2
- package/lib/atoms/chip/chip.module.d.ts +1 -1
- package/lib/atoms/chip-list/chip-list.component.d.ts +3 -2
- package/lib/atoms/chip-list/chip-list.module.d.ts +1 -1
- package/lib/atoms/clipboard/clipboard.component.d.ts +3 -1
- package/lib/atoms/clipboard/clipboard.module.d.ts +1 -1
- package/lib/atoms/container/container.component.d.ts +1 -1
- package/lib/atoms/container/container.module.d.ts +1 -1
- package/lib/atoms/date-range/date-range.component.d.ts +2 -1
- package/lib/atoms/date-range/date-range.module.d.ts +7 -6
- package/lib/atoms/datepicker/datepicker.component.d.ts +8 -4
- package/lib/atoms/datepicker/datepicker.module.d.ts +6 -5
- package/lib/atoms/drag-and-drop/drag-and-drop.component.d.ts +4 -4
- package/lib/atoms/drag-and-drop/drag-and-drop.module.d.ts +1 -1
- package/lib/atoms/dropdown/dropdown.component.d.ts +17 -3
- package/lib/atoms/dropdown/dropdown.module.d.ts +1 -1
- package/lib/atoms/dropdown-button/dropdown-button.component.d.ts +1 -1
- package/lib/atoms/dropdown-button/dropdown-button.module.d.ts +1 -1
- package/lib/atoms/dropdown-tree/dropdowntree.component.d.ts +19 -3
- package/lib/atoms/dropdown-tree/dropdowntree.module.d.ts +1 -1
- package/lib/atoms/expansion-panel/expansion-panel.component.d.ts +3 -1
- package/lib/atoms/expansion-panel/expansion-panel.module.d.ts +1 -1
- package/lib/atoms/icon/icon.component.d.ts +3 -2
- package/lib/atoms/icon/icon.module.d.ts +3 -2
- package/lib/atoms/labels/label.component.d.ts +3 -2
- package/lib/atoms/labels/label.module.d.ts +1 -1
- package/lib/atoms/list-views/list-view.component.d.ts +7 -1
- package/lib/atoms/list-views/list-view.module.d.ts +1 -1
- package/lib/atoms/loader/loader.component.d.ts +4 -4
- package/lib/atoms/loader/loader.module.d.ts +1 -1
- package/lib/atoms/loading-spinner/loading-spinner.component.d.ts +4 -1
- package/lib/atoms/loading-spinner/loading-spinner.module.d.ts +2 -1
- package/lib/atoms/multi-select-dropdown/multi-select-dropdown.component.d.ts +13 -3
- package/lib/atoms/multi-select-dropdown/multi-select-dropdown.module.d.ts +1 -1
- package/lib/atoms/notification/notification.component.d.ts +1 -1
- package/lib/atoms/notification/notification.module.d.ts +1 -1
- package/lib/atoms/numeric-textbox/numeric-textbox.component.d.ts +20 -10
- package/lib/atoms/numeric-textbox/numeric-textbox.module.d.ts +1 -1
- package/lib/atoms/progress-bar/progress-bar.component.d.ts +2 -1
- package/lib/atoms/progress-bar/progress-bar.module.d.ts +4 -3
- package/lib/atoms/radio-button/radio-button.component.d.ts +3 -3
- package/lib/atoms/radio-button/radio-button.module.d.ts +1 -1
- package/lib/atoms/search-box/search-box.component.d.ts +7 -1
- package/lib/atoms/search-box/search-box.module.d.ts +1 -1
- package/lib/atoms/slider/slider.component.d.ts +4 -1
- package/lib/atoms/slider/slider.module.d.ts +1 -1
- package/lib/atoms/stepper/stepper.component.d.ts +4 -1
- package/lib/atoms/stepper/stepper.module.d.ts +1 -1
- package/lib/atoms/switch/switch.component.d.ts +3 -1
- package/lib/atoms/switch/switch.module.d.ts +1 -1
- package/lib/atoms/text-area/text-area.component.d.ts +8 -3
- package/lib/atoms/text-area/text-area.module.d.ts +1 -1
- package/lib/atoms/textbox/textbox.component.d.ts +12 -4
- package/lib/atoms/textbox/textbox.module.d.ts +1 -1
- package/lib/atoms/time-picker/time-picker.component.d.ts +6 -3
- package/lib/atoms/time-picker/time-picker.module.d.ts +6 -5
- package/lib/atoms/timescheduler/timescheduler.component.d.ts +4 -2
- package/lib/atoms/timescheduler/timescheduler.module.d.ts +6 -5
- package/lib/atoms/tooltip/tooltip.component.d.ts +11 -2
- package/lib/atoms/tooltip/tooltip.module.d.ts +4 -3
- package/lib/atoms/typography/TypographyType.d.ts +1 -1
- package/lib/atoms/typography/typography.component.d.ts +2 -1
- package/lib/atoms/typography/typography.module.d.ts +3 -3
- package/lib/atoms/uploader/uploader.component.d.ts +10 -1
- package/lib/atoms/uploader/uploader.module.d.ts +1 -1
- package/lib/molecules/card/card-actions/card-actions.component.d.ts +1 -1
- package/lib/molecules/card/card-body/card-body.component.d.ts +1 -1
- package/lib/molecules/card/card-footer/card-footer.component.d.ts +1 -1
- package/lib/molecules/card/card-header/card-header.component.d.ts +1 -1
- package/lib/molecules/card/card.component.d.ts +1 -10
- package/lib/molecules/card/card.module.d.ts +1 -2
- package/lib/molecules/dialog/confirmation-dialog/confirmation-dialog.component.d.ts +2 -1
- package/lib/molecules/dialog/dialog-actions/dialog-actions.component.d.ts +1 -1
- package/lib/molecules/dialog/dialog-titlebar/dialog-titlebar.component.d.ts +2 -1
- package/lib/molecules/dialog/dialog.component.d.ts +2 -1
- package/lib/molecules/dialog/dialog.module.d.ts +5 -4
- package/lib/molecules/grid-form/grid-form.component.d.ts +2 -1
- package/lib/molecules/grid-form/grid-form.module.d.ts +2 -3
- package/lib/molecules/grid-layout/grid-layout-item/grid-layout-item.component.d.ts +3 -1
- package/lib/molecules/grid-layout/grid-layout.component.d.ts +3 -1
- package/lib/molecules/grid-layout/grid-layout.module.d.ts +1 -1
- package/lib/molecules/grid-pagination/grid-pagination-spacer/grid-pagination-spacer.component.d.ts +1 -1
- package/lib/molecules/grid-pagination/grid-pagination.component.d.ts +32 -12
- package/lib/molecules/grid-pagination/grid-pagination.module.d.ts +14 -16
- package/lib/molecules/grid-pagination/kebab-menu-filter.pipe.d.ts +1 -1
- package/lib/molecules/tabstrip/tabstrip-tab/tabstrip-tab.component.d.ts +2 -1
- package/lib/molecules/tabstrip/tabstrip.component.d.ts +3 -2
- package/lib/molecules/tabstrip/tabstrip.module.d.ts +1 -1
- package/lib/shared.component.d.ts +1 -1
- package/lib/shared.module.d.ts +1 -1
- package/package.json +29 -27
- package/public-api.d.ts +3 -1
- package/esm2022/lib/molecules/grid-pagination/grid-pagination-ai/grid-pagination-ai.component.mjs +0 -44
- package/lib/molecules/grid-pagination/grid-pagination-ai/grid-pagination-ai.component.d.ts +0 -14
|
@@ -5,31 +5,34 @@ import { orderBy } from '@progress/kendo-data-query';
|
|
|
5
5
|
import { LoaderSize, LoaderThemeColor, LoaderType } from '../../atoms/loader/loader.component';
|
|
6
6
|
import { GridComponent } from '@progress/kendo-angular-grid';
|
|
7
7
|
import { chevronDownIcon, chevronUpIcon, moreVerticalIcon } from '@progress/kendo-svg-icons';
|
|
8
|
+
import { GridModule } from '@progress/kendo-angular-grid';
|
|
9
|
+
import { CommonModule } from '@angular/common';
|
|
10
|
+
import { booleanAttribute } from '@angular/core';
|
|
11
|
+
import { ButtonsModule } from '@progress/kendo-angular-buttons';
|
|
12
|
+
import { DropDownsModule } from '@progress/kendo-angular-dropdowns';
|
|
13
|
+
import { TypographyComponent } from '../../atoms/typography/typography.component';
|
|
14
|
+
import { IconComponent } from '../../atoms/icon/icon.component';
|
|
15
|
+
import { ButtonComponent } from '../../atoms/button/button.component';
|
|
16
|
+
import { LoaderComponent } from '../../atoms/loader/loader.component';
|
|
17
|
+
import { TooltipComponent } from '../../atoms/tooltip/tooltip.component';
|
|
18
|
+
import { KebabMenuFilterPipe } from './kebab-menu-filter.pipe';
|
|
8
19
|
import * as i0 from "@angular/core";
|
|
9
|
-
import * as i1 from "@
|
|
10
|
-
import * as i2 from "@angular
|
|
11
|
-
import * as i3 from "@
|
|
12
|
-
import * as i4 from "
|
|
13
|
-
import * as i5 from "@progress/kendo-angular-inputs";
|
|
14
|
-
import * as i6 from "@progress/kendo-angular-grid";
|
|
15
|
-
import * as i7 from "../../atoms/tooltip/tooltip.component";
|
|
16
|
-
import * as i8 from "../../atoms/typography/typography.component";
|
|
17
|
-
import * as i9 from "../../atoms/loader/loader.component";
|
|
18
|
-
import * as i10 from "../../atoms/button/button.component";
|
|
19
|
-
import * as i11 from "@progress/kendo-angular-tooltip";
|
|
20
|
-
import * as i12 from "./grid-pagination-spacer/grid-pagination-spacer.component";
|
|
21
|
-
import * as i13 from "./kebab-menu-filter.pipe";
|
|
20
|
+
import * as i1 from "@progress/kendo-angular-grid";
|
|
21
|
+
import * as i2 from "@progress/kendo-angular-pager";
|
|
22
|
+
import * as i3 from "@angular/common";
|
|
23
|
+
import * as i4 from "@progress/kendo-angular-buttons";
|
|
22
24
|
export class CustomColumnTemplate {
|
|
23
25
|
constructor(template) {
|
|
24
26
|
this.template = template;
|
|
25
27
|
this.type = "";
|
|
26
28
|
}
|
|
27
|
-
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "
|
|
28
|
-
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "
|
|
29
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: CustomColumnTemplate, deps: [{ token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive }); }
|
|
30
|
+
static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "19.2.17", type: CustomColumnTemplate, isStandalone: true, selector: "ng-template[type]", inputs: { type: "type" }, ngImport: i0 }); }
|
|
29
31
|
}
|
|
30
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
32
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: CustomColumnTemplate, decorators: [{
|
|
31
33
|
type: Directive,
|
|
32
34
|
args: [{
|
|
35
|
+
standalone: true,
|
|
33
36
|
selector: 'ng-template[type]'
|
|
34
37
|
}]
|
|
35
38
|
}], ctorParameters: () => [{ type: i0.TemplateRef }], propDecorators: { type: [{
|
|
@@ -53,9 +56,8 @@ export class GridPaginationComponent {
|
|
|
53
56
|
set pageCount(value) {
|
|
54
57
|
this._pageCount = value > 10 ? 10 : value;
|
|
55
58
|
}
|
|
56
|
-
constructor(cdRef,
|
|
59
|
+
constructor(cdRef, renderer) {
|
|
57
60
|
this.cdRef = cdRef;
|
|
58
|
-
this.sanitizer = sanitizer;
|
|
59
61
|
this.renderer = renderer;
|
|
60
62
|
this.skip = 0;
|
|
61
63
|
this.itemName = 'Items';
|
|
@@ -63,7 +65,6 @@ export class GridPaginationComponent {
|
|
|
63
65
|
this.allPagesSelected = false;
|
|
64
66
|
this.previousSelectAllState = 'unchecked';
|
|
65
67
|
this.onSelectAllAcrossPages = new EventEmitter();
|
|
66
|
-
this.aiQuestions = [];
|
|
67
68
|
this.columnData = [];
|
|
68
69
|
this.pageSize = 0;
|
|
69
70
|
this.pageable = false;
|
|
@@ -139,13 +140,11 @@ export class GridPaginationComponent {
|
|
|
139
140
|
this.gridLoading = false;
|
|
140
141
|
this.minResizableWidth = 50;
|
|
141
142
|
this.showRefresh = false;
|
|
142
|
-
this.isKebabColumnSticky =
|
|
143
|
+
this.isKebabColumnSticky = false;
|
|
143
144
|
this.isCheckBoxColumnSticky = false;
|
|
144
145
|
this.isDeleteColumnSticky = false;
|
|
145
146
|
this.emitRefreshEvt = new EventEmitter();
|
|
146
147
|
this.isSelectAllCheckboxRequired = true;
|
|
147
|
-
this.kebabAIIcon = "data:image/png;base64,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";
|
|
148
|
-
this.kebabIconSafeUrl = this.sanitizer.bypassSecurityTrustResourceUrl(this.kebabAIIcon);
|
|
149
148
|
this.columnTemplateDict = {};
|
|
150
149
|
/*
|
|
151
150
|
* This logic of dynamically calculating the height of grid need further brainstorming hence commented for now.
|
|
@@ -187,7 +186,6 @@ export class GridPaginationComponent {
|
|
|
187
186
|
if (!this.ignoreColumnCellClick.includes(index)) {
|
|
188
187
|
column.class = 'column-cursor-pointer';
|
|
189
188
|
}
|
|
190
|
-
column.columnWidth = column.columnWidth ? column.columnWidth : "50";
|
|
191
189
|
});
|
|
192
190
|
if (!this.hasApiSorting) {
|
|
193
191
|
this.loadGridData();
|
|
@@ -456,28 +454,48 @@ export class GridPaginationComponent {
|
|
|
456
454
|
refreshGridData() {
|
|
457
455
|
this.emitRefreshEvt.emit();
|
|
458
456
|
}
|
|
459
|
-
|
|
460
|
-
|
|
461
|
-
|
|
462
|
-
|
|
463
|
-
|
|
464
|
-
|
|
465
|
-
|
|
466
|
-
|
|
467
|
-
|
|
468
|
-
|
|
469
|
-
|
|
470
|
-
|
|
471
|
-
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
|
|
475
|
-
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", aiQuestions: "aiQuestions", 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-container *ngTemplateOutlet=\"showAIIcon\"></ng-container> -->\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 <!-- <ng-template #showAIIcon>\n <div *ngIf=\"mainAIQuestions && mainAIQuestions?.length > 0\">\n <div kendoPopoverAnchor [popover]=\"actionPopover\" showOn=\"hover\">\n <img [src]=\"kebabIconSafeUrl\" alt=\"Ask Chef AI\"\n [ngStyle]=\"{ width: '1.75rem', cursor: 'pointer', position: 'relative', top: '-2px' }\"\n (click)=\"onChefyClick($event, null)\" />\n </div>\n <div>\n <kendo-popover #actionPopover appendTo=\"body\" [width]=\"200\" [offset]=\"-16\" position=\"bottom\"\n popupClass=\"chef-ai-menu\" [callout]=\"true\">\n <ng-template kendoPopoverBodyTemplate>\n <div class=\"recommendations\" *ngFor=\"let mainAIQuestion of mainAIQuestions\"\n (click)=\"onChefyClick($event, null, mainAIQuestion)\">\n <lib-typography type=\"BODY_MEDIUM\" [defaultText]=\"mainAIQuestion\"></lib-typography>\n </div>\n <div class=\"recommendations action-item\" (click)=\"onChefyClick($event, null)\">\n <img [src]=\"kebabIconSafeUrl\" alt=\"Ask Chef AI\"\n [ngStyle]=\"{ width: '1.5rem', cursor: 'pointer', position: 'relative', top: '-2px' }\" />\n <lib-typography type=\"BODY_MEDIUM\" defaultText=\"Start New Conversation\"></lib-typography>\n </div>\n </ng-template>\n </kendo-popover>\n </div>\n </div>\n <div *ngIf=\"!mainAIQuestions || mainAIQuestions?.length === 0\">\n <img [src]=\"kebabIconSafeUrl\" alt=\"Ask Chef AI\"\n [ngStyle]=\"{ width: '1.75rem', cursor: 'pointer', position: 'relative', top: '-2px' }\"\n (click)=\"onChefyClick($event, null)\" />\n </div>\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; let i = index\" [field]=\"item.field\"\n [title]=\"item.title\" [width]=\"item.columnWidth\" [minResizableWidth]=\"minResizableWidth\"\n [sortable]=\"item.sortable\" [editor]=\"item.editor\" [class]=\"item.class\"\n [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=\"i === 0\" kendoGridCellTemplate let-dataItem>\n <div class=\"first-custom-column\">\n <lib-typography type=\"BODY_MEDIUM\">{{dataItem?.[item.field]}}</lib-typography>\n <lib-button class=\"chefy\" size=\"small\" rounded=\"full\" (buttonClick)=\"onChefyClick($event, dataItem)\" fillMode=\"solid\"\n themeColor=\"primary\" label=\"Chefy\" />\n </div>\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\" title=\"Actions\"\n [sticky]=\"isKebabColumnSticky && !customExpandRowColumn\">\n <ng-template kendoGridCellTemplate let-dataItem let-rowIndex=\"rowIndex\">\n <div *ngIf=\"aiQuestions && aiQuestions?.length > 0\">\n <div kendoPopoverAnchor [popover]=\"actionPopover\" showOn=\"hover\">\n <img [src]=\"kebabIconSafeUrl\" alt=\"Ask Chef AI\"\n [ngStyle]=\"{ width: '1.75rem', cursor: 'pointer', position: 'relative', top: '-2px' }\"\n (click)=\"onChefyClick($event, dataItem)\" />\n </div>\n <div>\n <kendo-popover #actionPopover appendTo=\"body\" [width]=\"200\" [offset]=\"-16\" position=\"bottom\"\n popupClass=\"chef-ai-menu\" [callout]=\"true\">\n <ng-template kendoPopoverBodyTemplate>\n <div class=\"recommendations\" *ngFor=\"let question of aiQuestions\"\n (click)=\"onChefyClick($event, dataItem, question)\">\n <lib-typography type=\"BODY_MEDIUM\" [defaultText]=\"question\"></lib-typography>\n </div>\n <div class=\"recommendations action-item\" (click)=\"onChefyClick($event, dataItem)\">\n <img [src]=\"kebabIconSafeUrl\" alt=\"Ask Chef AI\"\n [ngStyle]=\"{ width: '1.5rem', cursor: 'pointer', position: 'relative', top: '-2px' }\" />\n <lib-typography type=\"BODY_MEDIUM\" defaultText=\"Start New Conversation\"></lib-typography>\n </div>\n </ng-template>\n </kendo-popover>\n </div>\n </div>\n <div *ngIf=\"!aiQuestions || aiQuestions?.length === 0\">\n <img [src]=\"kebabIconSafeUrl\" alt=\"Ask Chef AI\"\n [ngStyle]=\"{ width: '1.75rem', cursor: 'pointer', position: 'relative', top: '-2px' }\"\n (click)=\"onChefyClick($event, dataItem)\" />\n </div>\n <div *ngIf=\"showKebab\">\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 </div>\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}::ng-deep .first-custom-column{position:relative}::ng-deep .first-custom-column .chefy{display:none;position:absolute;right:0;opacity:0;transition:opacity .2s ease}::ng-deep .first-custom-column .chefy .btn-padding{padding:.125rem .25rem}::ng-deep .k-grid tbody>tr:not(.k-detail-row):hover .first-custom-column .chefy{display:inline-block;opacity:1}::ng-deep kendo-popover .k-popover-body{padding:0!important}::ng-deep kendo-popover .k-popover-callout.k-callout-n{top:.5rem!important}::ng-deep kendo-popover .recommendations{border-bottom:1px solid #dee2e6;padding:.25rem .5rem;cursor:pointer}::ng-deep kendo-popover .recommendations:hover{background-color:#f3f3f3}::ng-deep kendo-popover .recommendations.action-item{padding:.25rem;color:#0069ff}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "component", type: i3.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: i3.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: i4.IconComponent, selector: "lib-icon", inputs: ["name", "projectedIcon", "fontSize", "type"] }, { kind: "directive", type: i5.CheckBoxDirective, selector: "input[kendoCheckBox]", inputs: ["size", "rounded"] }, { kind: "component", type: i6.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: i6.ToolbarTemplateDirective, selector: "[kendoGridToolbarTemplate]", inputs: ["position"] }, { kind: "directive", type: i6.SelectionDirective, selector: "[kendoGridSelectBy]" }, { kind: "component", type: i6.ColumnComponent, selector: "kendo-grid-column", inputs: ["field", "format", "sortable", "groupable", "editor", "filter", "filterable", "editable"] }, { kind: "directive", type: i6.DetailTemplateDirective, selector: "[kendoGridDetailTemplate]", inputs: ["kendoGridDetailTemplateShowIf"] }, { kind: "component", type: i6.CheckboxColumnComponent, selector: "kendo-grid-checkbox-column", inputs: ["showSelectAll"] }, { kind: "directive", type: i6.CellTemplateDirective, selector: "[kendoGridCellTemplate]" }, { kind: "directive", type: i6.NoRecordsTemplateDirective, selector: "[kendoGridNoRecordsTemplate]" }, { kind: "directive", type: i6.LoadingTemplateDirective, selector: "[kendoGridLoadingTemplate]" }, { kind: "directive", type: i6.HeaderTemplateDirective, selector: "[kendoGridHeaderTemplate]" }, { kind: "directive", type: i6.SelectAllCheckboxDirective, selector: "[kendoGridSelectAllCheckbox]", inputs: ["state"], outputs: ["selectAllChange"] }, { kind: "component", type: i6.PagerPrevButtonsComponent, selector: "kendo-pager-prev-buttons" }, { kind: "component", type: i6.PagerNextButtonsComponent, selector: "kendo-pager-next-buttons" }, { kind: "component", type: i6.PagerNumericButtonsComponent, selector: "kendo-pager-numeric-buttons", inputs: ["buttonCount"] }, { kind: "component", type: i6.PagerInfoComponent, selector: "kendo-pager-info" }, { kind: "component", type: i6.PagerPageSizesComponent, selector: "kendo-pager-page-sizes", inputs: ["pageSizes"] }, { kind: "directive", type: i6.PagerTemplateDirective, selector: "[kendoPagerTemplate]" }, { kind: "component", type: i7.TooltipComponent, selector: "lib-tooltip", inputs: ["position", "tooltipWidth", "tooltipHeight", "showOn", "closable", "title", "callout"] }, { kind: "component", type: i8.TypographyComponent, selector: "lib-typography", inputs: ["type", "defaultText", "isLabel", "hiddenLabel"] }, { kind: "component", type: i9.LoaderComponent, selector: "lib-loader", inputs: ["size", "type", "themeColor"] }, { kind: "component", type: i10.ButtonComponent, selector: "lib-button", inputs: ["size", "rounded", "fillMode", "themeColor", "label", "iconName", "disabled", "toggleable", "iconPosition", "fontType", "width", "iconButton", "projectedIcon", "formatFn", "iconFontSize"], outputs: ["buttonClick"] }, { kind: "directive", type: i11.PopoverBodyTemplateDirective, selector: "[kendoPopoverBodyTemplate]" }, { kind: "directive", type: i11.PopoverAnchorDirective, selector: "[kendoPopoverAnchor]", exportAs: ["kendoPopoverAnchor"] }, { kind: "component", type: i11.PopoverComponent, selector: "kendo-popover", inputs: ["position", "offset", "width", "height", "title", "subtitle", "body", "callout", "animation", "templateData"], outputs: ["show", "shown", "hide", "hidden", "closeOnKeyDown"] }, { kind: "component", type: i12.GridPaginationSpacerComponent, selector: "lib-grid-pagination-spacer" }, { kind: "pipe", type: i13.KebabMenuFilterPipe, name: "kebabMenuFilter" }] }); }
|
|
457
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: GridPaginationComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
458
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "16.1.0", version: "19.2.17", type: GridPaginationComponent, isStandalone: true, selector: "lib-grid-pagination", inputs: { skip: ["skip", "skip", (value) => {
|
|
459
|
+
if (value === undefined || value === null)
|
|
460
|
+
return 0;
|
|
461
|
+
return typeof value === 'string' ? parseInt(value, 10) || 0 : value;
|
|
462
|
+
}], itemName: "itemName", showSelectAllMessage: ["showSelectAllMessage", "showSelectAllMessage", (value) => value === true || value === 'true'], columnData: "columnData", pageSize: ["pageSize", "pageSize", (value) => {
|
|
463
|
+
if (value === undefined || value === null)
|
|
464
|
+
return 0;
|
|
465
|
+
return typeof value === 'string' ? parseInt(value, 10) || 0 : value;
|
|
466
|
+
}], pageable: ["pageable", "pageable", booleanAttribute], sortable: ["sortable", "sortable", (value) => value === true || value === 'true'], groupable: ["groupable", "groupable", (value) => value === true || value === 'true'], reorderable: ["reorderable", "reorderable", (value) => value === true || value === 'true'], resizable: ["resizable", "resizable", (value) => value === true || value === 'true'], checkBoxWidth: ["checkBoxWidth", "checkBoxWidth", (value) => {
|
|
467
|
+
if (value === undefined || value === null)
|
|
468
|
+
return 45;
|
|
469
|
+
return typeof value === 'string' ? parseInt(value, 10) || 45 : value;
|
|
470
|
+
}], checkBoxColumnResizable: ["checkBoxColumnResizable", "checkBoxColumnResizable", (value) => value === true || value === 'true'], checkBoxColumnMenu: ["checkBoxColumnMenu", "checkBoxColumnMenu", (value) => value === true || value === 'true'], checkBoxColumnShowSelectedAll: ["checkBoxColumnShowSelectedAll", "checkBoxColumnShowSelectedAll", (value) => value === true || value === 'true'], checkBoxRequired: ["checkBoxRequired", "checkBoxRequired", (value) => value === true || value === 'true'], columnMenu: ["columnMenu", "columnMenu", (value) => value === true || value === 'true'], mode: "mode", checkboxOnly: "checkboxOnly", dragColumns: "dragColumns", navigable: ["navigable", "navigable", (value) => value === true || value === 'true'], gridHeight: "gridHeight", gridRowSelectByValue: "gridRowSelectByValue", noRecordsContent: "noRecordsContent", showToolbar: ["showToolbar", "showToolbar", (value) => value === true || value === 'true'], kebabList: "kebabList", showKebab: ["showKebab", "showKebab", (value) => value === true || value === 'true'], icon: "icon", kebabColumnWidth: ["kebabColumnWidth", "kebabColumnWidth", (value) => {
|
|
471
|
+
if (value === undefined || value === null)
|
|
472
|
+
return 90;
|
|
473
|
+
return typeof value === 'string' ? parseInt(value, 10) || 90 : value;
|
|
474
|
+
}], selectColumn: "selectColumn", preSelected: "preSelected", gridView: "gridView", ignoreColumnCellClick: "ignoreColumnCellClick", allowColumnClick: ["allowColumnClick", "allowColumnClick", (value) => value === true || value === 'true'], sort: "sort", hasApiSorting: "hasApiSorting", expandRowIndex: "expandRowIndex", customExpandRowColumn: ["customExpandRowColumn", "customExpandRowColumn", (value) => value === true || value === 'true'], deleteColumnWidth: ["deleteColumnWidth", "deleteColumnWidth", (value) => {
|
|
475
|
+
if (value === undefined || value === null)
|
|
476
|
+
return 42;
|
|
477
|
+
return typeof value === 'string' ? parseInt(value, 10) || 42 : value;
|
|
478
|
+
}], expandRowColumnWidth: ["expandRowColumnWidth", "expandRowColumnWidth", (value) => {
|
|
479
|
+
if (value === undefined || value === null)
|
|
480
|
+
return 56;
|
|
481
|
+
return typeof value === 'string' ? parseInt(value, 10) || 56 : value;
|
|
482
|
+
}], sizes: "sizes", pageCount: "pageCount", showDeleteColumn: "showDeleteColumn", hideKebabRowIndex: "hideKebabRowIndex", loading: ["loading", "loading", (value) => value === true || value === 'true'], loaderType: "loaderType", loaderSize: "loaderSize", loaderTheme: "loaderTheme", disablePreSelectedRows: "disablePreSelectedRows", allowEditingCell: "allowEditingCell", columnContentNoWrap: "columnContentNoWrap", infiniteScrollLoader: "infiniteScrollLoader", isInfiniteScrollGrid: ["isInfiniteScrollGrid", "isInfiniteScrollGrid", (value) => value === true || value === 'true'], gridLoading: ["gridLoading", "gridLoading", (value) => value === true || value === 'true'], 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\" [closable]=\"false\">\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: "ngmodule", type: GridModule }, { kind: "component", type: i1.GridComponent, selector: "kendo-grid", inputs: ["data", "pageSize", "height", "rowHeight", "adaptiveMode", "detailRowHeight", "skip", "scrollable", "selectable", "sort", "size", "trackBy", "filter", "group", "virtualColumns", "filterable", "sortable", "pageable", "groupable", "gridResizable", "rowReorderable", "navigable", "autoSize", "rowClass", "rowSticky", "rowSelected", "isRowSelectable", "cellSelected", "resizable", "reorderable", "loading", "columnMenu", "hideHeader", "showInactiveTools", "isDetailExpanded", "isGroupExpanded", "dataLayoutMode"], outputs: ["filterChange", "pageChange", "groupChange", "sortChange", "selectionChange", "rowReorder", "dataStateChange", "gridStateChange", "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: i1.ToolbarTemplateDirective, selector: "[kendoGridToolbarTemplate]", inputs: ["position"] }, { kind: "directive", type: i1.SelectionDirective, selector: "[kendoGridSelectBy]" }, { kind: "component", type: i1.ColumnComponent, selector: "kendo-grid-column", inputs: ["field", "format", "sortable", "groupable", "editor", "filter", "filterVariant", "filterable", "editable"] }, { kind: "directive", type: i1.DetailTemplateDirective, selector: "[kendoGridDetailTemplate]", inputs: ["kendoGridDetailTemplateShowIf"] }, { kind: "component", type: i1.CheckboxColumnComponent, selector: "kendo-grid-checkbox-column", inputs: ["showSelectAll", "showDisabledCheckbox"] }, { kind: "directive", type: i1.CellTemplateDirective, selector: "[kendoGridCellTemplate]" }, { kind: "directive", type: i1.NoRecordsTemplateDirective, selector: "[kendoGridNoRecordsTemplate]" }, { kind: "directive", type: i1.LoadingTemplateDirective, selector: "[kendoGridLoadingTemplate]" }, { kind: "directive", type: i1.HeaderTemplateDirective, selector: "[kendoGridHeaderTemplate]" }, { kind: "directive", type: i1.SelectAllCheckboxDirective, selector: "[kendoGridSelectAllCheckbox]", inputs: ["state"], outputs: ["selectAllChange"] }, { kind: "component", type: i2.PagerInfoComponent, selector: "kendo-datapager-info, kendo-pager-info" }, { kind: "component", type: i2.PagerNextButtonsComponent, selector: "kendo-datapager-next-buttons, kendo-pager-next-buttons", inputs: ["size"] }, { kind: "component", type: i2.PagerNumericButtonsComponent, selector: "kendo-datapager-numeric-buttons, kendo-pager-numeric-buttons", inputs: ["buttonCount", "size"] }, { kind: "component", type: i2.PagerPageSizesComponent, selector: "kendo-datapager-page-sizes, kendo-pager-page-sizes", inputs: ["showItemsText", "pageSizes", "size", "adaptiveMode"] }, { kind: "component", type: i2.PagerPrevButtonsComponent, selector: "kendo-datapager-prev-buttons, kendo-pager-prev-buttons", inputs: ["size"] }, { kind: "directive", type: i2.PagerTemplateDirective, selector: "[kendoDataPagerTemplate], [kendoPagerTemplate]" }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "ngmodule", type: ButtonsModule }, { kind: "component", type: i4.DropDownButtonComponent, selector: "kendo-dropdownbutton", inputs: ["arrowIcon", "icon", "svgIcon", "iconClass", "imageUrl", "textField", "data", "size", "rounded", "fillMode", "themeColor", "buttonAttributes"], outputs: ["itemClick", "focus", "blur"], exportAs: ["kendoDropDownButton"] }, { kind: "ngmodule", type: DropDownsModule }, { kind: "component", type: TypographyComponent, selector: "lib-typography", inputs: ["type", "defaultText", "isLabel", "hiddenLabel"] }, { kind: "component", type: IconComponent, selector: "lib-icon", inputs: ["name", "projectedIcon", "fontSize", "type"] }, { kind: "component", type: 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: LoaderComponent, selector: "lib-loader", inputs: ["size", "type", "themeColor"] }, { kind: "component", type: TooltipComponent, selector: "lib-tooltip", inputs: ["position", "tooltipWidth", "tooltipHeight", "showOn", "closable", "title", "callout"] }, { kind: "pipe", type: KebabMenuFilterPipe, name: "kebabMenuFilter" }] }); }
|
|
476
483
|
}
|
|
477
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "
|
|
484
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "19.2.17", ngImport: i0, type: GridPaginationComponent, decorators: [{
|
|
478
485
|
type: Component,
|
|
479
|
-
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-container *ngTemplateOutlet=\"showAIIcon\"></ng-container> -->\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 <!-- <ng-template #showAIIcon>\n <div *ngIf=\"mainAIQuestions && mainAIQuestions?.length > 0\">\n <div kendoPopoverAnchor [popover]=\"actionPopover\" showOn=\"hover\">\n <img [src]=\"kebabIconSafeUrl\" alt=\"Ask Chef AI\"\n [ngStyle]=\"{ width: '1.75rem', cursor: 'pointer', position: 'relative', top: '-2px' }\"\n (click)=\"onChefyClick($event, null)\" />\n </div>\n <div>\n <kendo-popover #actionPopover appendTo=\"body\" [width]=\"200\" [offset]=\"-16\" position=\"bottom\"\n popupClass=\"chef-ai-menu\" [callout]=\"true\">\n <ng-template kendoPopoverBodyTemplate>\n <div class=\"recommendations\" *ngFor=\"let mainAIQuestion of mainAIQuestions\"\n (click)=\"onChefyClick($event, null, mainAIQuestion)\">\n <lib-typography type=\"BODY_MEDIUM\" [defaultText]=\"mainAIQuestion\"></lib-typography>\n </div>\n <div class=\"recommendations action-item\" (click)=\"onChefyClick($event, null)\">\n <img [src]=\"kebabIconSafeUrl\" alt=\"Ask Chef AI\"\n [ngStyle]=\"{ width: '1.5rem', cursor: 'pointer', position: 'relative', top: '-2px' }\" />\n <lib-typography type=\"BODY_MEDIUM\" defaultText=\"Start New Conversation\"></lib-typography>\n </div>\n </ng-template>\n </kendo-popover>\n </div>\n </div>\n <div *ngIf=\"!mainAIQuestions || mainAIQuestions?.length === 0\">\n <img [src]=\"kebabIconSafeUrl\" alt=\"Ask Chef AI\"\n [ngStyle]=\"{ width: '1.75rem', cursor: 'pointer', position: 'relative', top: '-2px' }\"\n (click)=\"onChefyClick($event, null)\" />\n </div>\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; let i = index\" [field]=\"item.field\"\n [title]=\"item.title\" [width]=\"item.columnWidth\" [minResizableWidth]=\"minResizableWidth\"\n [sortable]=\"item.sortable\" [editor]=\"item.editor\" [class]=\"item.class\"\n [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=\"i === 0\" kendoGridCellTemplate let-dataItem>\n <div class=\"first-custom-column\">\n <lib-typography type=\"BODY_MEDIUM\">{{dataItem?.[item.field]}}</lib-typography>\n <lib-button class=\"chefy\" size=\"small\" rounded=\"full\" (buttonClick)=\"onChefyClick($event, dataItem)\" fillMode=\"solid\"\n themeColor=\"primary\" label=\"Chefy\" />\n </div>\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\" title=\"Actions\"\n [sticky]=\"isKebabColumnSticky && !customExpandRowColumn\">\n <ng-template kendoGridCellTemplate let-dataItem let-rowIndex=\"rowIndex\">\n <div *ngIf=\"aiQuestions && aiQuestions?.length > 0\">\n <div kendoPopoverAnchor [popover]=\"actionPopover\" showOn=\"hover\">\n <img [src]=\"kebabIconSafeUrl\" alt=\"Ask Chef AI\"\n [ngStyle]=\"{ width: '1.75rem', cursor: 'pointer', position: 'relative', top: '-2px' }\"\n (click)=\"onChefyClick($event, dataItem)\" />\n </div>\n <div>\n <kendo-popover #actionPopover appendTo=\"body\" [width]=\"200\" [offset]=\"-16\" position=\"bottom\"\n popupClass=\"chef-ai-menu\" [callout]=\"true\">\n <ng-template kendoPopoverBodyTemplate>\n <div class=\"recommendations\" *ngFor=\"let question of aiQuestions\"\n (click)=\"onChefyClick($event, dataItem, question)\">\n <lib-typography type=\"BODY_MEDIUM\" [defaultText]=\"question\"></lib-typography>\n </div>\n <div class=\"recommendations action-item\" (click)=\"onChefyClick($event, dataItem)\">\n <img [src]=\"kebabIconSafeUrl\" alt=\"Ask Chef AI\"\n [ngStyle]=\"{ width: '1.5rem', cursor: 'pointer', position: 'relative', top: '-2px' }\" />\n <lib-typography type=\"BODY_MEDIUM\" defaultText=\"Start New Conversation\"></lib-typography>\n </div>\n </ng-template>\n </kendo-popover>\n </div>\n </div>\n <div *ngIf=\"!aiQuestions || aiQuestions?.length === 0\">\n <img [src]=\"kebabIconSafeUrl\" alt=\"Ask Chef AI\"\n [ngStyle]=\"{ width: '1.75rem', cursor: 'pointer', position: 'relative', top: '-2px' }\"\n (click)=\"onChefyClick($event, dataItem)\" />\n </div>\n <div *ngIf=\"showKebab\">\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 </div>\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}::ng-deep .first-custom-column{position:relative}::ng-deep .first-custom-column .chefy{display:none;position:absolute;right:0;opacity:0;transition:opacity .2s ease}::ng-deep .first-custom-column .chefy .btn-padding{padding:.125rem .25rem}::ng-deep .k-grid tbody>tr:not(.k-detail-row):hover .first-custom-column .chefy{display:inline-block;opacity:1}::ng-deep kendo-popover .k-popover-body{padding:0!important}::ng-deep kendo-popover .k-popover-callout.k-callout-n{top:.5rem!important}::ng-deep kendo-popover .recommendations{border-bottom:1px solid #dee2e6;padding:.25rem .5rem;cursor:pointer}::ng-deep kendo-popover .recommendations:hover{background-color:#f3f3f3}::ng-deep kendo-popover .recommendations.action-item{padding:.25rem;color:#0069ff}\n"] }]
|
|
480
|
-
|
|
486
|
+
args: [{ standalone: true, selector: 'lib-grid-pagination', imports: [
|
|
487
|
+
GridModule,
|
|
488
|
+
CommonModule,
|
|
489
|
+
ButtonsModule,
|
|
490
|
+
DropDownsModule,
|
|
491
|
+
TypographyComponent,
|
|
492
|
+
IconComponent,
|
|
493
|
+
ButtonComponent,
|
|
494
|
+
LoaderComponent,
|
|
495
|
+
TooltipComponent,
|
|
496
|
+
KebabMenuFilterPipe
|
|
497
|
+
], 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\" [closable]=\"false\">\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"] }]
|
|
498
|
+
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i0.Renderer2 }], propDecorators: { columnTemplates: [{
|
|
481
499
|
type: ContentChildren,
|
|
482
500
|
args: [CustomColumnTemplate]
|
|
483
501
|
}], templateRef: [{
|
|
@@ -502,41 +520,65 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
502
520
|
type: ViewChild,
|
|
503
521
|
args: ['selectAllMessageElement']
|
|
504
522
|
}], skip: [{
|
|
505
|
-
type: Input
|
|
523
|
+
type: Input,
|
|
524
|
+
args: [{ transform: (value) => {
|
|
525
|
+
if (value === undefined || value === null)
|
|
526
|
+
return 0;
|
|
527
|
+
return typeof value === 'string' ? parseInt(value, 10) || 0 : value;
|
|
528
|
+
} }]
|
|
506
529
|
}], itemName: [{
|
|
507
530
|
type: Input
|
|
508
531
|
}], showSelectAllMessage: [{
|
|
509
|
-
type: Input
|
|
532
|
+
type: Input,
|
|
533
|
+
args: [{ transform: (value) => value === true || value === 'true' }]
|
|
510
534
|
}], onSelectAllAcrossPages: [{
|
|
511
535
|
type: Output
|
|
512
|
-
}], aiQuestions: [{
|
|
513
|
-
type: Input
|
|
514
536
|
}], columnData: [{
|
|
515
537
|
type: Input
|
|
516
538
|
}], pageSize: [{
|
|
517
|
-
type: Input
|
|
539
|
+
type: Input,
|
|
540
|
+
args: [{ transform: (value) => {
|
|
541
|
+
if (value === undefined || value === null)
|
|
542
|
+
return 0;
|
|
543
|
+
return typeof value === 'string' ? parseInt(value, 10) || 0 : value;
|
|
544
|
+
} }]
|
|
518
545
|
}], pageable: [{
|
|
519
|
-
type: Input
|
|
546
|
+
type: Input,
|
|
547
|
+
args: [{ transform: booleanAttribute }]
|
|
520
548
|
}], sortable: [{
|
|
521
|
-
type: Input
|
|
549
|
+
type: Input,
|
|
550
|
+
args: [{ transform: (value) => value === true || value === 'true' }]
|
|
522
551
|
}], groupable: [{
|
|
523
|
-
type: Input
|
|
552
|
+
type: Input,
|
|
553
|
+
args: [{ transform: (value) => value === true || value === 'true' }]
|
|
524
554
|
}], reorderable: [{
|
|
525
|
-
type: Input
|
|
555
|
+
type: Input,
|
|
556
|
+
args: [{ transform: (value) => value === true || value === 'true' }]
|
|
526
557
|
}], resizable: [{
|
|
527
|
-
type: Input
|
|
558
|
+
type: Input,
|
|
559
|
+
args: [{ transform: (value) => value === true || value === 'true' }]
|
|
528
560
|
}], checkBoxWidth: [{
|
|
529
|
-
type: Input
|
|
561
|
+
type: Input,
|
|
562
|
+
args: [{ transform: (value) => {
|
|
563
|
+
if (value === undefined || value === null)
|
|
564
|
+
return 45;
|
|
565
|
+
return typeof value === 'string' ? parseInt(value, 10) || 45 : value;
|
|
566
|
+
} }]
|
|
530
567
|
}], checkBoxColumnResizable: [{
|
|
531
|
-
type: Input
|
|
568
|
+
type: Input,
|
|
569
|
+
args: [{ transform: (value) => value === true || value === 'true' }]
|
|
532
570
|
}], checkBoxColumnMenu: [{
|
|
533
|
-
type: Input
|
|
571
|
+
type: Input,
|
|
572
|
+
args: [{ transform: (value) => value === true || value === 'true' }]
|
|
534
573
|
}], checkBoxColumnShowSelectedAll: [{
|
|
535
|
-
type: Input
|
|
574
|
+
type: Input,
|
|
575
|
+
args: [{ transform: (value) => value === true || value === 'true' }]
|
|
536
576
|
}], checkBoxRequired: [{
|
|
537
|
-
type: Input
|
|
577
|
+
type: Input,
|
|
578
|
+
args: [{ transform: (value) => value === true || value === 'true' }]
|
|
538
579
|
}], columnMenu: [{
|
|
539
|
-
type: Input
|
|
580
|
+
type: Input,
|
|
581
|
+
args: [{ transform: (value) => value === true || value === 'true' }]
|
|
540
582
|
}], mode: [{
|
|
541
583
|
type: Input
|
|
542
584
|
}], checkboxOnly: [{
|
|
@@ -544,7 +586,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
544
586
|
}], dragColumns: [{
|
|
545
587
|
type: Input
|
|
546
588
|
}], navigable: [{
|
|
547
|
-
type: Input
|
|
589
|
+
type: Input,
|
|
590
|
+
args: [{ transform: (value) => value === true || value === 'true' }]
|
|
548
591
|
}], gridHeight: [{
|
|
549
592
|
type: Input
|
|
550
593
|
}], gridRowSelectByValue: [{
|
|
@@ -554,11 +597,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
554
597
|
}], selectedRowData: [{
|
|
555
598
|
type: Output
|
|
556
599
|
}], showToolbar: [{
|
|
557
|
-
type: Input
|
|
600
|
+
type: Input,
|
|
601
|
+
args: [{ transform: (value) => value === true || value === 'true' }]
|
|
558
602
|
}], kebabList: [{
|
|
559
603
|
type: Input
|
|
560
604
|
}], showKebab: [{
|
|
561
|
-
type: Input
|
|
605
|
+
type: Input,
|
|
606
|
+
args: [{ transform: (value) => value === true || value === 'true' }]
|
|
562
607
|
}], rowDetails: [{
|
|
563
608
|
type: Output
|
|
564
609
|
}], kebabItemClick: [{
|
|
@@ -566,7 +611,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
566
611
|
}], icon: [{
|
|
567
612
|
type: Input
|
|
568
613
|
}], kebabColumnWidth: [{
|
|
569
|
-
type: Input
|
|
614
|
+
type: Input,
|
|
615
|
+
args: [{ transform: (value) => {
|
|
616
|
+
if (value === undefined || value === null)
|
|
617
|
+
return 90;
|
|
618
|
+
return typeof value === 'string' ? parseInt(value, 10) || 90 : value;
|
|
619
|
+
} }]
|
|
570
620
|
}], selectColumn: [{
|
|
571
621
|
type: Input
|
|
572
622
|
}], rowDataOfClickedCell: [{
|
|
@@ -580,7 +630,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
580
630
|
}], ignoreColumnCellClick: [{
|
|
581
631
|
type: Input
|
|
582
632
|
}], allowColumnClick: [{
|
|
583
|
-
type: Input
|
|
633
|
+
type: Input,
|
|
634
|
+
args: [{ transform: (value) => value === true || value === 'true' }]
|
|
584
635
|
}], sort: [{
|
|
585
636
|
type: Input
|
|
586
637
|
}], hasApiSorting: [{
|
|
@@ -590,9 +641,22 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
590
641
|
}], expandRowIndex: [{
|
|
591
642
|
type: Input
|
|
592
643
|
}], customExpandRowColumn: [{
|
|
593
|
-
type: Input
|
|
644
|
+
type: Input,
|
|
645
|
+
args: [{ transform: (value) => value === true || value === 'true' }]
|
|
594
646
|
}], deleteColumnWidth: [{
|
|
595
|
-
type: Input
|
|
647
|
+
type: Input,
|
|
648
|
+
args: [{ transform: (value) => {
|
|
649
|
+
if (value === undefined || value === null)
|
|
650
|
+
return 42;
|
|
651
|
+
return typeof value === 'string' ? parseInt(value, 10) || 42 : value;
|
|
652
|
+
} }]
|
|
653
|
+
}], expandRowColumnWidth: [{
|
|
654
|
+
type: Input,
|
|
655
|
+
args: [{ transform: (value) => {
|
|
656
|
+
if (value === undefined || value === null)
|
|
657
|
+
return 56;
|
|
658
|
+
return typeof value === 'string' ? parseInt(value, 10) || 56 : value;
|
|
659
|
+
} }]
|
|
596
660
|
}], deletedRowData: [{
|
|
597
661
|
type: Output
|
|
598
662
|
}], sizes: [{
|
|
@@ -604,7 +668,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
604
668
|
}], hideKebabRowIndex: [{
|
|
605
669
|
type: Input
|
|
606
670
|
}], loading: [{
|
|
607
|
-
type: Input
|
|
671
|
+
type: Input,
|
|
672
|
+
args: [{ transform: (value) => value === true || value === 'true' }]
|
|
608
673
|
}], loaderType: [{
|
|
609
674
|
type: Input
|
|
610
675
|
}], loaderSize: [{
|
|
@@ -624,9 +689,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
624
689
|
}], onscrollBottom: [{
|
|
625
690
|
type: Output
|
|
626
691
|
}], isInfiniteScrollGrid: [{
|
|
627
|
-
type: Input
|
|
692
|
+
type: Input,
|
|
693
|
+
args: [{ transform: (value) => value === true || value === 'true' }]
|
|
628
694
|
}], gridLoading: [{
|
|
629
|
-
type: Input
|
|
695
|
+
type: Input,
|
|
696
|
+
args: [{ transform: (value) => value === true || value === 'true' }]
|
|
630
697
|
}], minResizableWidth: [{
|
|
631
698
|
type: Input
|
|
632
699
|
}], showRefresh: [{
|
|
@@ -642,4 +709,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
642
709
|
}], isSelectAllCheckboxRequired: [{
|
|
643
710
|
type: Input
|
|
644
711
|
}] } });
|
|
645
|
-
//# 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';\nimport { DomSanitizer } from '@angular/platform-browser';\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() aiQuestions: any = [];\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 = true;\n  @Input() isCheckBoxColumnSticky = false;\n  @Input() isDeleteColumnSticky = false;\n  @Output() emitRefreshEvt = new EventEmitter();\n  @Input() isSelectAllCheckboxRequired = true;\n\n  kebabAIIcon = \"data:image/png;base64,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\";\n  kebabIconSafeUrl = this.sanitizer.bypassSecurityTrustResourceUrl(this.kebabAIIcon);\n  constructor(private cdRef: ChangeDetectorRef,\n    private sanitizer: DomSanitizer,\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      column.columnWidth = column.columnWidth ? column.columnWidth : \"50\";\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  onChefyClick(e: any, dataItem: any, query = null) {\n    e.stopPropagation();\n    const customEvent = new CustomEvent('gridChefyClick', {\n      detail: {\n        itemName: this.itemName,\n        dataItem: dataItem,\n        query: query,\n        columnData: this.columnData\n      },\n      bubbles: true,\n      cancelable: true\n    });\n\n    // Dispatch on document to make it globally available\n    document.dispatchEvent(customEvent);\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-container *ngTemplateOutlet=\"showAIIcon\"></ng-container> -->\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    <!-- <ng-template #showAIIcon>\n      <div *ngIf=\"mainAIQuestions && mainAIQuestions?.length > 0\">\n        <div kendoPopoverAnchor [popover]=\"actionPopover\" showOn=\"hover\">\n          <img [src]=\"kebabIconSafeUrl\" alt=\"Ask Chef AI\"\n            [ngStyle]=\"{ width: '1.75rem', cursor: 'pointer', position: 'relative', top: '-2px' }\"\n            (click)=\"onChefyClick($event, null)\" />\n        </div>\n        <div>\n          <kendo-popover #actionPopover appendTo=\"body\" [width]=\"200\" [offset]=\"-16\" position=\"bottom\"\n            popupClass=\"chef-ai-menu\" [callout]=\"true\">\n            <ng-template kendoPopoverBodyTemplate>\n              <div class=\"recommendations\" *ngFor=\"let mainAIQuestion of mainAIQuestions\"\n                (click)=\"onChefyClick($event, null, mainAIQuestion)\">\n                <lib-typography type=\"BODY_MEDIUM\" [defaultText]=\"mainAIQuestion\"></lib-typography>\n              </div>\n              <div class=\"recommendations action-item\" (click)=\"onChefyClick($event, null)\">\n                <img [src]=\"kebabIconSafeUrl\" alt=\"Ask Chef AI\"\n                  [ngStyle]=\"{ width: '1.5rem', cursor: 'pointer', position: 'relative', top: '-2px' }\" />\n                <lib-typography type=\"BODY_MEDIUM\" defaultText=\"Start New Conversation\"></lib-typography>\n              </div>\n            </ng-template>\n          </kendo-popover>\n        </div>\n      </div>\n      <div *ngIf=\"!mainAIQuestions || mainAIQuestions?.length === 0\">\n        <img [src]=\"kebabIconSafeUrl\" alt=\"Ask Chef AI\"\n          [ngStyle]=\"{ width: '1.75rem', cursor: 'pointer', position: 'relative', top: '-2px' }\"\n          (click)=\"onChefyClick($event, null)\" />\n      </div>\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; let i = index\" [field]=\"item.field\"\n        [title]=\"item.title\" [width]=\"item.columnWidth\" [minResizableWidth]=\"minResizableWidth\"\n        [sortable]=\"item.sortable\" [editor]=\"item.editor\" [class]=\"item.class\"\n        [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=\"i === 0\" kendoGridCellTemplate let-dataItem>\n          <div class=\"first-custom-column\">\n            <lib-typography type=\"BODY_MEDIUM\">{{dataItem?.[item.field]}}</lib-typography>\n            <lib-button class=\"chefy\" size=\"small\" rounded=\"full\" (buttonClick)=\"onChefyClick($event, dataItem)\" fillMode=\"solid\"\n              themeColor=\"primary\" label=\"Chefy\" />\n          </div>\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\" title=\"Actions\"\n        [sticky]=\"isKebabColumnSticky && !customExpandRowColumn\">\n        <ng-template kendoGridCellTemplate let-dataItem let-rowIndex=\"rowIndex\">\n          <div *ngIf=\"aiQuestions && aiQuestions?.length > 0\">\n            <div kendoPopoverAnchor [popover]=\"actionPopover\" showOn=\"hover\">\n              <img [src]=\"kebabIconSafeUrl\" alt=\"Ask Chef AI\"\n                [ngStyle]=\"{ width: '1.75rem', cursor: 'pointer', position: 'relative', top: '-2px' }\"\n                (click)=\"onChefyClick($event, dataItem)\" />\n            </div>\n            <div>\n              <kendo-popover #actionPopover appendTo=\"body\" [width]=\"200\" [offset]=\"-16\" position=\"bottom\"\n                popupClass=\"chef-ai-menu\" [callout]=\"true\">\n                <ng-template kendoPopoverBodyTemplate>\n                  <div class=\"recommendations\" *ngFor=\"let question of aiQuestions\"\n                    (click)=\"onChefyClick($event, dataItem, question)\">\n                    <lib-typography type=\"BODY_MEDIUM\" [defaultText]=\"question\"></lib-typography>\n                  </div>\n                  <div class=\"recommendations action-item\" (click)=\"onChefyClick($event, dataItem)\">\n                    <img [src]=\"kebabIconSafeUrl\" alt=\"Ask Chef AI\"\n                      [ngStyle]=\"{ width: '1.5rem', cursor: 'pointer', position: 'relative', top: '-2px' }\" />\n                    <lib-typography type=\"BODY_MEDIUM\" defaultText=\"Start New Conversation\"></lib-typography>\n                  </div>\n                </ng-template>\n              </kendo-popover>\n            </div>\n          </div>\n          <div *ngIf=\"!aiQuestions || aiQuestions?.length === 0\">\n            <img [src]=\"kebabIconSafeUrl\" alt=\"Ask Chef AI\"\n              [ngStyle]=\"{ width: '1.75rem', cursor: 'pointer', position: 'relative', top: '-2px' }\"\n              (click)=\"onChefyClick($event, dataItem)\" />\n          </div>\n          <div *ngIf=\"showKebab\">\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          </div>\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"]}
|
|
712
|
+
//# 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, PagerSettings, RowClassArgs, SelectAllCheckboxState, SelectableMode, SelectableSettings } from '@progress/kendo-angular-grid';\nimport { chevronDownIcon, chevronUpIcon, moreVerticalIcon, SVGIcon } from '@progress/kendo-svg-icons';\nimport { GridModule } from '@progress/kendo-angular-grid';\nimport { CommonModule } from '@angular/common';\nimport { booleanAttribute } from '@angular/core';\nimport { numberAttribute } from '@angular/core';\nimport { ButtonsModule } from '@progress/kendo-angular-buttons';\nimport { DropDownsModule } from '@progress/kendo-angular-dropdowns';\nimport { TypographyComponent } from '../../atoms/typography/typography.component';\nimport { IconComponent } from '../../atoms/icon/icon.component';\nimport { ButtonComponent } from '../../atoms/button/button.component';\nimport { LoaderComponent } from '../../atoms/loader/loader.component';\nimport { TooltipComponent } from '../../atoms/tooltip/tooltip.component';\nimport { KebabMenuFilterPipe } from './kebab-menu-filter.pipe';\n\n\n@Directive({\n  standalone: true,\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  standalone: true,\n  selector: 'lib-grid-pagination',\n  templateUrl: './grid-pagination.component.html',\n  styleUrls: ['./grid-pagination.component.scss']\n,\n  imports: [\n    GridModule,\n    CommonModule,\n    ButtonsModule,\n    DropDownsModule,\n    TypographyComponent,\n    IconComponent,\n    ButtonComponent,\n    LoaderComponent,\n    TooltipComponent,\n    KebabMenuFilterPipe\n  ]\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({ transform: (value: number | string | undefined) => {\n    if (value === undefined || value === null) return 0;\n    return typeof value === 'string' ? parseInt(value, 10) || 0 : value;\n  } }) skip: number = 0;\n  @Input() itemName: string = 'Items';\n  @Input({ transform: (value: boolean | string) => value === true || value === 'true' }) showSelectAllMessage: boolean = false;\n  allPagesSelected: boolean = false;\n  previousSelectAllState: SelectAllCheckboxState = 'unchecked';\n  @Output() onSelectAllAcrossPages = new EventEmitter<boolean>();\n  @Input() columnData: any = [];\n  @Input({ transform: (value: number | string | undefined) => {\n    if (value === undefined || value === null) return 0;\n    return typeof value === 'string' ? parseInt(value, 10) || 0 : value;\n  } }) pageSize: number = 0;\n  @Input({ transform: booleanAttribute }) pageable: boolean | PagerSettings = false;\n  @Input({ transform: (value: boolean | string) => value === true || value === 'true' }) sortable: boolean = false;\n  @Input({ transform: (value: boolean | string) => value === true || value === 'true' }) groupable: boolean = false;\n  @Input({ transform: (value: boolean | string) => value === true || value === 'true' }) reorderable: boolean = false;\n  @Input({ transform: (value: boolean | string) => value === true || value === 'true' }) resizable: boolean = false;\n  @Input({ transform: (value: number | string | undefined) => {\n    if (value === undefined || value === null) return 45;\n    return typeof value === 'string' ? parseInt(value, 10) || 45 : value;\n  } }) checkBoxWidth: number = 45;\n  @Input({ transform: (value: boolean | string) => value === true || value === 'true' }) checkBoxColumnResizable: boolean = false;\n  @Input({ transform: (value: boolean | string) => value === true || value === 'true' }) checkBoxColumnMenu: boolean = false;\n  @Input({ transform: (value: boolean | string) => value === true || value === 'true' }) checkBoxColumnShowSelectedAll: boolean = true;\n  @Input({ transform: (value: boolean | string) => value === true || value === 'true' }) checkBoxRequired: boolean = false;\n  @Input({ transform: (value: boolean | string) => value === true || value === 'true' }) columnMenu: boolean = false;\n  @Input() mode: SelectableMode | undefined = 'multiple';\n  @Input() checkboxOnly = true;\n  @Input() dragColumns = false;\n  @Input({ transform: (value: boolean | string) => value === true || value === 'true' }) 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({ transform: (value: boolean | string) => value === true || value === 'true' }) showToolbar: boolean = false;\n  extractDataItems: any;\n  selectableSettings: SelectableSettings = {};\n  @Input() kebabList: any = [];\n  @Input({ transform: (value: boolean | string) => value === true || value === 'true' }) showKebab: boolean = false;\n  @Output() rowDetails = new EventEmitter<any[]>();\n  @Output() kebabItemClick = new EventEmitter<any>();\n  @Input() icon: SVGIcon = moreVerticalIcon;\n  @Input({ transform: (value: number | string | undefined) => {\n    if (value === undefined || value === null) return 90;\n    return typeof value === 'string' ? parseInt(value, 10) || 90 : value;\n  } }) 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({ transform: (value: boolean | string) => value === true || value === 'true' }) 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({ transform: (value: boolean | string) => value === true || value === 'true' }) customExpandRowColumn: boolean = false;\n  @Input({ transform: (value: number | string | undefined) => {\n    if (value === undefined || value === null) return 42;\n    return typeof value === 'string' ? parseInt(value, 10) || 42 : value;\n  } }) deleteColumnWidth: number = 42;\n  @Input({ transform: (value: number | string | undefined) => {\n    if (value === undefined || value === null) return 56;\n    return typeof value === 'string' ? parseInt(value, 10) || 56 : value;\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({ transform: (value: boolean | string) => value === true || value === 'true' }) 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({ transform: (value: boolean | string) => value === true || value === 'true' }) isInfiniteScrollGrid: boolean = false;\n  @Input({ transform: (value: boolean | string) => value === true || value === 'true' }) 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\" [closable]=\"false\">\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"]}
|