@annalib/anna-core 20.2.30 → 20.2.31

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (106) hide show
  1. package/{esm2020 → esm2022}/annalib-anna-core.mjs +4 -4
  2. package/{esm2020 → esm2022}/lib/anna-core-shared-lib/components/anna-buyer-approval-icon-template/anna-buyer-approval-icon-template.component.mjs +14 -14
  3. package/{esm2020 → esm2022}/lib/anna-core-shared-lib/components/anna-deleted-order-icon-template/anna-deleted-order-icon-template.component.mjs +13 -13
  4. package/{esm2020 → esm2022}/lib/anna-core-shared-lib/components/anna-est-icon-template/anna-est-icon-template.component.mjs +11 -11
  5. package/{esm2020 → esm2022}/lib/anna-core-shared-lib/components/anna-icon-column/anna-icon-column.component.mjs +43 -43
  6. package/{esm2020 → esm2022}/lib/anna-core-shared-lib/components/anna-live-icon-template/anna-live-icon-template.component.mjs +14 -14
  7. package/{esm2020 → esm2022}/lib/anna-core-shared-lib/components/anna-no-data/anna-no-data.component.mjs +22 -22
  8. package/{esm2020 → esm2022}/lib/anna-core-shared-lib/components/anna-notify-icon-template/anna-notify-icon-template.component.mjs +13 -13
  9. package/{esm2020 → esm2022}/lib/anna-core-shared-lib/components/anna-pay-for-performance-icon-template/anna-pay-for-performance-icon-template.component.mjs +22 -22
  10. package/{esm2020 → esm2022}/lib/anna-core-shared-lib/components/anna-rejected-icon-template/anna-rejected-icon-template.component.mjs +14 -14
  11. package/esm2022/lib/anna-core-shared-lib/constants/shared.constant.mjs +47 -0
  12. package/{esm2020 → esm2022}/lib/anna-core-shared-lib/directives/digits-only/digits-only.directive.mjs +273 -273
  13. package/{esm2020 → esm2022}/lib/anna-core-shared-lib/directives/fixed-rows-popup-table/fixed-rows-popup-table.directive.mjs +46 -46
  14. package/{esm2020 → esm2022}/lib/anna-core-shared-lib/directives/show-ellipsis-text/show-ellipsis-text.directive.mjs +39 -39
  15. package/{esm2020 → esm2022}/lib/anna-core-shared-lib/models/anna-generic-data-type.model.mjs +1 -1
  16. package/{esm2020 → esm2022}/lib/anna-core-shared-lib/models/anna-global-dropdown-config.model.mjs +1 -1
  17. package/{esm2020 → esm2022}/lib/anna-core-shared-lib/models/anna-non-editable-gt-models.mjs +21 -21
  18. package/{esm2020 → esm2022}/lib/anna-core-shared-lib/models/anna-sort.model.mjs +6 -6
  19. package/{esm2020 → esm2022}/lib/anna-core-shared-lib/models/anna-tooltip.model.mjs +29 -29
  20. package/{esm2020 → esm2022}/lib/anna-core-shared-lib/pipes/annaConvertArrayToCommaSeperatedValue.pipe.mjs +39 -39
  21. package/{esm2020 → esm2022}/lib/anna-core-shared-lib/pipes/annaConvertZeroOrNullOrUndefined.pipe.mjs +27 -27
  22. package/{esm2020 → esm2022}/lib/anna-core-shared-lib/pipes/annaDateFormatter.pipe.mjs +22 -22
  23. package/{esm2020 → esm2022}/lib/anna-core-shared-lib/pipes/annaFilterSearchedText.pipe.mjs +55 -55
  24. package/{esm2020 → esm2022}/lib/anna-core-shared-lib/pipes/annaReplaceChar.pipe.mjs +26 -26
  25. package/{esm2020 → esm2022}/lib/anna-core-shared-lib/pipes/annaTypeOfData.pipe.mjs +17 -17
  26. package/{esm2020 → esm2022}/lib/anna-core-shared-lib/services/anna-date-time-format.service.mjs +208 -208
  27. package/esm2022/lib/anna-core-shared-lib/services/anna-filter.service.mjs +1272 -0
  28. package/{esm2020 → esm2022}/lib/anna-core-shared-lib/services/anna-generic-table.service.mjs +151 -151
  29. package/{esm2020 → esm2022}/lib/anna-core-shared-lib/services/anna-global-config.service.mjs +135 -135
  30. package/{esm2020 → esm2022}/lib/anna-core-shared-lib/services/anna-number-format.service.mjs +53 -53
  31. package/{esm2020 → esm2022}/lib/anna-core-shared-lib/services/anna-persisting-filter.service.mjs +65 -65
  32. package/{esm2020 → esm2022}/lib/anna-core-shared-lib/services/anna-sort.service.mjs +178 -178
  33. package/esm2022/lib/anna-core.module.mjs +226 -0
  34. package/{esm2020 → esm2022}/lib/anna-dropdown-lib/components/anna-calendar-filter/anna-calendar-filter.component.mjs +160 -160
  35. package/esm2022/lib/anna-dropdown-lib/components/anna-week-calendar-filter/anna-week-calendar-filter.component.mjs +371 -0
  36. package/{esm2020 → esm2022}/lib/anna-generic-table-lib/components/anna-column-filters/anna-column-checkbox-filter/anna-column-checkbox-filter.component.mjs +252 -252
  37. package/{esm2020 → esm2022}/lib/anna-generic-table-lib/components/anna-column-filters/anna-column-date-range-filter/anna-column-date-range-filter.component.mjs +185 -185
  38. package/{esm2020 → esm2022}/lib/anna-generic-table-lib/components/anna-column-filters/anna-column-slider-filter/anna-column-slider-filter.component.mjs +314 -314
  39. package/{esm2020 → esm2022}/lib/anna-generic-table-lib/components/anna-column-filters/anna-column-time-filter/anna-column-time-filter.component.mjs +298 -298
  40. package/{esm2020 → esm2022}/lib/anna-generic-table-lib/components/anna-non-editable-generic-table/anna-non-editable-generic-table.component.mjs +865 -865
  41. package/{esm2020 → esm2022}/lib/anna-generic-table-lib/components/anna-sort/anna-sort.component.mjs +64 -64
  42. package/esm2022/lib/anna-generic-table-lib/components/anna-table-virtual-scroll-viewport/anna-table-virtual-scroll-viewport.component.mjs +352 -0
  43. package/esm2022/lib/anna-generic-table-lib/directives/anna-fixed-row-size-table-virtual-scroll-strategy/anna-fixed-row-size-table-virtual-scroll-strategy.directive.mjs +204 -0
  44. package/{esm2020 → esm2022}/lib/anna-generic-table-lib/directives/anna-fixed-row-size-table-virtual-scroll-strategy/index.mjs +1 -1
  45. package/esm2022/lib/anna-generic-table-lib/directives/anna-virtual-table/anna-virtual-table.directive.mjs +180 -0
  46. package/{esm2020 → esm2022}/lib/anna-generic-table-lib/directives/anna-virtual-table/index.mjs +1 -1
  47. package/{esm2020 → esm2022}/public-api.mjs +57 -57
  48. package/{fesm2020 → fesm2022}/annalib-anna-core.mjs +5988 -5999
  49. package/{fesm2020 → fesm2022}/annalib-anna-core.mjs.map +1 -1
  50. package/index.d.ts +5 -5
  51. package/lib/anna-core-shared-lib/components/anna-buyer-approval-icon-template/anna-buyer-approval-icon-template.component.d.ts +8 -8
  52. package/lib/anna-core-shared-lib/components/anna-deleted-order-icon-template/anna-deleted-order-icon-template.component.d.ts +8 -8
  53. package/lib/anna-core-shared-lib/components/anna-est-icon-template/anna-est-icon-template.component.d.ts +5 -5
  54. package/lib/anna-core-shared-lib/components/anna-icon-column/anna-icon-column.component.d.ts +17 -17
  55. package/lib/anna-core-shared-lib/components/anna-live-icon-template/anna-live-icon-template.component.d.ts +8 -8
  56. package/lib/anna-core-shared-lib/components/anna-no-data/anna-no-data.component.d.ts +11 -11
  57. package/lib/anna-core-shared-lib/components/anna-notify-icon-template/anna-notify-icon-template.component.d.ts +8 -8
  58. package/lib/anna-core-shared-lib/components/anna-pay-for-performance-icon-template/anna-pay-for-performance-icon-template.component.d.ts +12 -12
  59. package/lib/anna-core-shared-lib/components/anna-rejected-icon-template/anna-rejected-icon-template.component.d.ts +8 -8
  60. package/lib/anna-core-shared-lib/constants/shared.constant.d.ts +45 -45
  61. package/lib/anna-core-shared-lib/directives/digits-only/digits-only.directive.d.ts +34 -34
  62. package/lib/anna-core-shared-lib/directives/fixed-rows-popup-table/fixed-rows-popup-table.directive.d.ts +16 -16
  63. package/lib/anna-core-shared-lib/directives/show-ellipsis-text/show-ellipsis-text.directive.d.ts +10 -10
  64. package/lib/anna-core-shared-lib/models/anna-generic-data-type.model.d.ts +16 -16
  65. package/lib/anna-core-shared-lib/models/anna-global-dropdown-config.model.d.ts +97 -97
  66. package/lib/anna-core-shared-lib/models/anna-non-editable-gt-models.d.ts +128 -128
  67. package/lib/anna-core-shared-lib/models/anna-sort.model.d.ts +11 -11
  68. package/lib/anna-core-shared-lib/models/anna-tooltip.model.d.ts +25 -25
  69. package/lib/anna-core-shared-lib/pipes/annaConvertArrayToCommaSeperatedValue.pipe.d.ts +9 -9
  70. package/lib/anna-core-shared-lib/pipes/annaConvertZeroOrNullOrUndefined.pipe.d.ts +9 -9
  71. package/lib/anna-core-shared-lib/pipes/annaDateFormatter.pipe.d.ts +8 -8
  72. package/lib/anna-core-shared-lib/pipes/annaFilterSearchedText.pipe.d.ts +9 -9
  73. package/lib/anna-core-shared-lib/pipes/annaReplaceChar.pipe.d.ts +9 -9
  74. package/lib/anna-core-shared-lib/pipes/annaTypeOfData.pipe.d.ts +7 -7
  75. package/lib/anna-core-shared-lib/services/anna-date-time-format.service.d.ts +28 -28
  76. package/lib/anna-core-shared-lib/services/anna-filter.service.d.ts +154 -154
  77. package/lib/anna-core-shared-lib/services/anna-generic-table.service.d.ts +27 -27
  78. package/lib/anna-core-shared-lib/services/anna-global-config.service.d.ts +21 -21
  79. package/lib/anna-core-shared-lib/services/anna-number-format.service.d.ts +8 -8
  80. package/lib/anna-core-shared-lib/services/anna-persisting-filter.service.d.ts +9 -9
  81. package/lib/anna-core-shared-lib/services/anna-sort.service.d.ts +18 -18
  82. package/lib/anna-core.module.d.ts +45 -45
  83. package/lib/anna-dropdown-lib/components/anna-calendar-filter/anna-calendar-filter.component.d.ts +45 -45
  84. package/lib/anna-dropdown-lib/components/anna-week-calendar-filter/anna-week-calendar-filter.component.d.ts +70 -70
  85. package/lib/anna-generic-table-lib/components/anna-column-filters/anna-column-checkbox-filter/anna-column-checkbox-filter.component.d.ts +60 -60
  86. package/lib/anna-generic-table-lib/components/anna-column-filters/anna-column-date-range-filter/anna-column-date-range-filter.component.d.ts +53 -53
  87. package/lib/anna-generic-table-lib/components/anna-column-filters/anna-column-slider-filter/anna-column-slider-filter.component.d.ts +65 -65
  88. package/lib/anna-generic-table-lib/components/anna-column-filters/anna-column-time-filter/anna-column-time-filter.component.d.ts +83 -83
  89. package/lib/anna-generic-table-lib/components/anna-non-editable-generic-table/anna-non-editable-generic-table.component.d.ts +175 -175
  90. package/lib/anna-generic-table-lib/components/anna-sort/anna-sort.component.d.ts +17 -17
  91. package/lib/anna-generic-table-lib/components/anna-table-virtual-scroll-viewport/anna-table-virtual-scroll-viewport.component.d.ts +141 -141
  92. package/lib/anna-generic-table-lib/directives/anna-fixed-row-size-table-virtual-scroll-strategy/anna-fixed-row-size-table-virtual-scroll-strategy.directive.d.ts +89 -89
  93. package/lib/anna-generic-table-lib/directives/anna-fixed-row-size-table-virtual-scroll-strategy/index.d.ts +1 -1
  94. package/lib/anna-generic-table-lib/directives/anna-virtual-table/anna-virtual-table.directive.d.ts +45 -45
  95. package/lib/anna-generic-table-lib/directives/anna-virtual-table/index.d.ts +1 -1
  96. package/package.json +5 -11
  97. package/public-api.d.ts +42 -42
  98. package/esm2020/lib/anna-core-shared-lib/constants/shared.constant.mjs +0 -47
  99. package/esm2020/lib/anna-core-shared-lib/services/anna-filter.service.mjs +0 -1272
  100. package/esm2020/lib/anna-core.module.mjs +0 -237
  101. package/esm2020/lib/anna-dropdown-lib/components/anna-week-calendar-filter/anna-week-calendar-filter.component.mjs +0 -371
  102. package/esm2020/lib/anna-generic-table-lib/components/anna-table-virtual-scroll-viewport/anna-table-virtual-scroll-viewport.component.mjs +0 -352
  103. package/esm2020/lib/anna-generic-table-lib/directives/anna-fixed-row-size-table-virtual-scroll-strategy/anna-fixed-row-size-table-virtual-scroll-strategy.directive.mjs +0 -204
  104. package/esm2020/lib/anna-generic-table-lib/directives/anna-virtual-table/anna-virtual-table.directive.mjs +0 -180
  105. package/fesm2015/annalib-anna-core.mjs +0 -6131
  106. package/fesm2015/annalib-anna-core.mjs.map +0 -1
@@ -1,865 +1,865 @@
1
- // Angular import statements
2
- import { Component, Input, ViewChildren, QueryList, Output, EventEmitter, ChangeDetectorRef, ChangeDetectionStrategy, } from '@angular/core';
3
- // Third party import statements
4
- import { cloneDeep, isEqual, uniq } from 'lodash-es';
5
- import { AnnaDateTimeFormatService } from '../../../anna-core-shared-lib/services/anna-date-time-format.service';
6
- import { radioButtonModel } from '../../../anna-core-shared-lib/models/anna-tooltip.model';
7
- import { AnnaSortService } from '../../../anna-core-shared-lib/services/anna-sort.service';
8
- import { AnnaFilterService } from '../../../anna-core-shared-lib/services/anna-filter.service';
9
- import { BehaviorSubject } from 'rxjs';
10
- import { NgCircleProgressModule } from 'ng-circle-progress';
11
- import { AnnaColumnTimeFilterComponent } from '../anna-column-filters/anna-column-time-filter/anna-column-time-filter.component';
12
- import { AnnaColumnDateRangeFilterComponent } from '../anna-column-filters/anna-column-date-range-filter/anna-column-date-range-filter.component';
13
- import { AnnaColumnSliderFilterComponent } from '../anna-column-filters/anna-column-slider-filter/anna-column-slider-filter.component';
14
- import { AnnaColumnCheckboxFilterComponent } from '../anna-column-filters/anna-column-checkbox-filter/anna-column-checkbox-filter.component';
15
- import { AnnaNoDataComponent } from '../../../anna-core-shared-lib/components/anna-no-data/anna-no-data.component';
16
- import { MatRadioModule } from '@angular/material/radio';
17
- import { FormsModule } from '@angular/forms';
18
- import { AnnaIconColumnComponent } from '../../../anna-core-shared-lib/components/anna-icon-column/anna-icon-column.component';
19
- import { showEllipsisTextOnHoverDirective } from '../../../anna-core-shared-lib/directives/show-ellipsis-text/show-ellipsis-text.directive';
20
- import { NgxSkeletonLoaderModule } from 'ngx-skeleton-loader';
21
- import { NgbTooltip } from '@ng-bootstrap/ng-bootstrap';
22
- import { MatTableModule } from '@angular/material/table';
23
- import { NgClass, NgStyle, NgFor, NgIf, NgTemplateOutlet, NgSwitch, NgSwitchCase, NgSwitchDefault, AsyncPipe, } from '@angular/common';
24
- import * as i0 from "@angular/core";
25
- import * as i1 from "../../../anna-core-shared-lib/services/anna-sort.service";
26
- import * as i2 from "../../../anna-core-shared-lib/services/anna-date-time-format.service";
27
- import * as i3 from "../../../anna-core-shared-lib/services/anna-filter.service";
28
- import * as i4 from "@angular/material/table";
29
- import * as i5 from "ngx-skeleton-loader";
30
- import * as i6 from "@angular/forms";
31
- import * as i7 from "@angular/material/radio";
32
- import * as i8 from "ng-circle-progress";
33
- export class AnnaNonEditableGenericTableComponent {
34
- constructor(cdRef, annaSortService, annaDateTimeFormatService, annaFilterService) {
35
- this.cdRef = cdRef;
36
- this.annaSortService = annaSortService;
37
- this.annaDateTimeFormatService = annaDateTimeFormatService;
38
- this.annaFilterService = annaFilterService;
39
- this.maximumRowsWhichCanBeRenderedWithoutScroll = 5;
40
- this.fixNumberOfRowsForPopup = false;
41
- this.limit = 30;
42
- this.includeBorderInTableHeight = true;
43
- this.clickableRow = false;
44
- this.setTableHeightWhenRowSizeIsFixed = true;
45
- this.tableBorderBottomClassRequired = true;
46
- this.hideSomeTds = false;
47
- this.tdsHaveRowSpan = false;
48
- this.multipleTablesPresent = false;
49
- this.toggleCheckbox = new EventEmitter();
50
- this.toggleRowCheckbox = new EventEmitter();
51
- this.toggleHeaderCheckbox = new EventEmitter();
52
- this.undoIconClicked = new EventEmitter();
53
- this.filterAppliedToTable = new EventEmitter();
54
- this.sortingAppliedToTable = new EventEmitter();
55
- this.rowClicked = new EventEmitter();
56
- this.radioButtonSelected = new EventEmitter();
57
- this.columnFilterOpened = new EventEmitter();
58
- this.columnFilterClosed = new EventEmitter();
59
- this.gtIconClicked = new EventEmitter();
60
- this.gtSVGIconClicked = new EventEmitter();
61
- this.gtTextActionClicked = new EventEmitter();
62
- this.gtViewDetailClicked = new EventEmitter();
63
- this.gtInnerHTMLClicked = new EventEmitter();
64
- this.downloadSpotDetails = new EventEmitter();
65
- this.clickableDataClicked = new EventEmitter();
66
- this.totalRowIconClicked = new EventEmitter();
67
- this.notificationIconHover = new EventEmitter();
68
- this.notificationIconHoverLeave = new EventEmitter();
69
- this.editableInputEdited = new EventEmitter();
70
- this.radioButtonMessageIconClicked = new EventEmitter();
71
- this.numberOfSkeletonRows = Array(20).fill(0);
72
- this.noDataWidth = '50%';
73
- this.filterAlignment = 'bottom auto';
74
- this.disableColumnClearAllBtn = true;
75
- this.margin = 5;
76
- this.tableColumns = [];
77
- this.totalRowColumns = null;
78
- this.isScrolledLeft = false;
79
- this.rowBorderWidth = 2;
80
- this.isScrollEnded = true;
81
- this.marginTop = '';
82
- this.start = 0;
83
- this.end = this.limit + this.start;
84
- this.isNoDataToDisplaySubject$ = new BehaviorSubject(false);
85
- this.textActionTooltip = [];
86
- this.tooltipContainingTable = null;
87
- this.tableBottomBorderClass = null;
88
- this.showCheckboxesForTimeFilter = false;
89
- this.setTooltipRadioNames();
90
- }
91
- ngAfterViewChecked() {
92
- this.setMarginLeftForFilterIcon();
93
- }
94
- ngOnInit() {
95
- this.setFilterAlignmentBasedOnScreenResolution();
96
- }
97
- detectChanges() {
98
- this.cdRef.detectChanges();
99
- }
100
- ngOnChanges(changes) {
101
- if (changes &&
102
- changes['gtDimension'] &&
103
- changes['gtDimension'].currentValue &&
104
- this.setTableHeightWhenRowSizeIsFixed) {
105
- this.setTableHeight();
106
- this.setTableBottomBorder();
107
- }
108
- if (this.showSkeletonLoading) {
109
- this.tableData = this.numberOfSkeletonRows;
110
- this.renderedData = this.numberOfSkeletonRows;
111
- this.isNoDataToDisplaySubject$.next(false);
112
- this.setTableBottomBorder();
113
- }
114
- else if (changes['percentDone'] ||
115
- changes['downloadInProgress'] ||
116
- (changes['starredInProgress'] && changes['starredInProgress'].currentValue != undefined)) {
117
- //no task will be performed
118
- }
119
- else {
120
- this.setInitialRowsForTable();
121
- this.disableEnableEachColumnTooltipIcon();
122
- this.tableColumns = this.tableHeaders.filter((x) => x.visible).map((x) => x.headerInfo[0].objectKey);
123
- if ((this.tableData && this.tableData.length == 0) ||
124
- (this.tableData.length == 2 && this.checkIfAllTheElementsAreZero())) {
125
- this.tableData = Array(2).fill(0);
126
- this.renderedData = cloneDeep(this.tableData);
127
- this.marginTop = -this.gtDimension.rowHeight - this.gtDimension.rowHeight / 2 + 'px';
128
- this.isNoDataToDisplaySubject$.next(true);
129
- }
130
- else {
131
- this.isNoDataToDisplaySubject$.next(false);
132
- }
133
- this.showSkeletonLoading = false;
134
- this.setTableBottomBorder();
135
- }
136
- //setting table column here as well because while showing skeleton loader, we should show table headers.
137
- if (changes['tableHeaders'] &&
138
- !isEqual(changes['tableHeaders'].currentValue, changes['tableHeaders'].previousValue)) {
139
- this.tableColumns = this.tableHeaders.filter((x) => x.visible).map((x) => x.headerInfo[0].objectKey);
140
- this.annaSortService.columnSortState = new Map();
141
- this.annaFilterService.initialValueMap = new Map();
142
- // this.setColumnSortStateMap();
143
- this.setActiveStateObject();
144
- }
145
- if (changes['totalRowInfo'] && changes['totalRowInfo'].currentValue) {
146
- this.totalRowColumns = this.totalRowInfo.map((x) => x.colName);
147
- }
148
- this.cdRef.detectChanges();
149
- }
150
- setFilterAlignmentBasedOnScreenResolution() {
151
- let viewportHeight = window.innerHeight;
152
- if (viewportHeight < 740) {
153
- this.filterAlignment = 'left right';
154
- }
155
- else {
156
- this.filterAlignment = 'bottom left right';
157
- }
158
- }
159
- setTableBottomBorder() {
160
- if (this.tableBorderBottomClassRequired &&
161
- this.tableData &&
162
- this.tableData.length &&
163
- this.maximumRowsWhichCanBeRenderedWithoutScroll < this.tableData.length) {
164
- this.tableBottomBorderClass = 'bottom-border';
165
- }
166
- else {
167
- this.tableBottomBorderClass = null;
168
- }
169
- }
170
- checkIfAllTheElementsAreZero() {
171
- return !this.tableData.some((item) => item != 0);
172
- }
173
- setTableHeight() {
174
- let viewportHeight = window.innerHeight;
175
- let rowHeight = this.gtDimension.rowHeight;
176
- let headerHeight = this.gtDimension.headerHeight;
177
- let dataOnTopHeight = this.gtDimension.dataOnTopHeight;
178
- let marginFromBottom = this.gtDimension.marginFromBottom;
179
- let actualTableHeight;
180
- if (this.fixNumberOfRowsForPopup) {
181
- let maxNoOfRowsToDisplay = viewportHeight < 740 ? 5 : 10;
182
- this.maximumRowsWhichCanBeRenderedWithoutScroll = maxNoOfRowsToDisplay;
183
- actualTableHeight = this.maximumRowsWhichCanBeRenderedWithoutScroll * rowHeight + headerHeight;
184
- }
185
- else {
186
- let minHeightForTable = headerHeight + 3 * rowHeight;
187
- viewportHeight = viewportHeight <= dataOnTopHeight ? dataOnTopHeight + minHeightForTable : viewportHeight;
188
- let heightLeftForTable = viewportHeight - dataOnTopHeight - marginFromBottom;
189
- this.maximumRowsWhichCanBeRenderedWithoutScroll =
190
- Math.ceil((heightLeftForTable - headerHeight - rowHeight) / rowHeight) + 1;
191
- actualTableHeight = viewportHeight - dataOnTopHeight - marginFromBottom;
192
- }
193
- // let actualTableHeight = heightLeftForTable - ((heightLeftForTable - headerHeight - rowHeight) % rowHeight);
194
- this.gtDimension.tableHeight = `${actualTableHeight}px`;
195
- this.numberOfSkeletonRows = this.maximumRowsWhichCanBeRenderedWithoutScroll
196
- ? Array(this.maximumRowsWhichCanBeRenderedWithoutScroll).fill(0)
197
- : Array(5).fill(0);
198
- }
199
- trackByFn(index) {
200
- return index;
201
- }
202
- setTooltipRadioNames() {
203
- this.tooltipRadioTextMap = new Map();
204
- this.tooltipRadioTextMap.set('StartTimeForFilter', 'Start Time');
205
- this.tooltipRadioTextMap.set('EndTimeForFilter', 'End Time');
206
- this.tooltipRadioTextMap.set('startTimeForFilter', 'Start Time');
207
- this.tooltipRadioTextMap.set('endTimeForFilter', 'End Time');
208
- this.tooltipRadioTextMap.set('start_time_for_filter', 'Start Time');
209
- this.tooltipRadioTextMap.set('end_time_for_filter', 'End Time');
210
- this.tooltipRadioTextMap.set('primaryAEName', 'Primary AE');
211
- this.tooltipRadioTextMap.set('region', 'Region');
212
- this.tooltipRadioTextMap.set('agencyName', 'Agency');
213
- this.tooltipRadioTextMap.set('location', 'Location');
214
- this.tooltipRadioTextMap.set('advertiserName', 'Advertiser');
215
- this.tooltipRadioTextMap.set('productCode', 'Product Code');
216
- this.tooltipRadioTextMap.set('flightStartDate', 'Start Date');
217
- this.tooltipRadioTextMap.set('flightEndDate', 'End Date');
218
- this.tooltipRadioTextMap.set('orderIdAndRevNumber', 'STN Order#-Rev#');
219
- this.tooltipRadioTextMap.set('stationOrderNumber', 'STN Order#');
220
- this.tooltipRadioTextMap.set('alternateOrderId', 'Alt/Rep Order #');
221
- this.tooltipRadioTextMap.set('grp', 'GRP');
222
- this.tooltipRadioTextMap.set('cpp', 'CPP');
223
- this.tooltipRadioTextMap.set('imps', 'IMPS');
224
- this.tooltipRadioTextMap.set('cpm', 'CPM');
225
- this.tooltipRadioTextMap.set('offeredMGs', 'Offered MG');
226
- this.tooltipRadioTextMap.set('outstandingPE', 'O/S PE');
227
- this.tooltipRadioTextMap.set('offeredADUs', 'Offered ADUs');
228
- this.tooltipRadioTextMap.set('udDeficitValue', 'O/S Aud Delta');
229
- this.tooltipRadioTextMap.set('startEndTimeMulti', 'Time');
230
- this.tooltipRadioTextMap.set('bookedValue', 'Booked');
231
- this.tooltipRadioTextMap.set('bookedSpots', 'Spots');
232
- this.tooltipRadioTextMap.set('UserCreditedValue', 'User Credited');
233
- this.tooltipRadioTextMap.set('UserUnresolvedValue', 'User Unresolved');
234
- this.tooltipRadioTextMap.set('BuyerAddedValue', 'Buyer Added');
235
- this.tooltipRadioTextMap.set('BuyerDeletedValue', 'Buyer Deleted');
236
- this.tooltipRadioTextMap.set('userChanges', 'User Changes');
237
- this.tooltipRadioTextMap.set('buyerChanges', 'Buyer Changes');
238
- this.tooltipRadioTextMap.set('userMG', 'User MG');
239
- this.tooltipRadioTextMap.set('userADUs', 'User ADUs');
240
- this.tooltipRadioTextMap.set('inventoryCode', 'Inventory Code');
241
- this.tooltipRadioTextMap.set('program', 'Program');
242
- this.tooltipRadioTextMap.set('agency', 'Agency');
243
- this.tooltipRadioTextMap.set('advertiser', 'Advertiser');
244
- this.tooltipRadioTextMap.set('startDate', 'Start Date');
245
- this.tooltipRadioTextMap.set('endDate', 'End Date');
246
- this.tooltipRadioTextMap.set('date', 'Date');
247
- this.tooltipRadioTextMap.set('rcvPreempt', '$ Madegood PEs');
248
- this.tooltipRadioTextMap.set('osPreempt', '$ O/S PEs');
249
- this.tooltipRadioTextMap.set('rcvUnderDly', 'Recovered UD');
250
- this.tooltipRadioTextMap.set('osUnderDly', 'O/s Under Dly');
251
- this.tooltipRadioTextMap.set('primaryAe', 'Primary AE');
252
- this.tooltipRadioTextMap.set('region', 'Region');
253
- this.tooltipRadioTextMap.set('revCode1', 'Rev code 1');
254
- this.tooltipRadioTextMap.set('orderNoRevNo', 'STN Order#-Rev#');
255
- this.tooltipRadioTextMap.set('revCode2', 'Rev code 2');
256
- this.tooltipRadioTextMap.set('revCode3', 'Rev code 3');
257
- this.tooltipRadioTextMap.set('booked', '$ Booked');
258
- this.tooltipRadioTextMap.set('spots', 'Spots');
259
- this.tooltipRadioTextMap.set('postedAudPercent', 'Posted %');
260
- this.tooltipRadioTextMap.set('revision', 'Revision');
261
- this.tooltipRadioTextMap.set('buyerOrderId', 'ALT/REP Order#');
262
- this.tooltipRadioTextMap.set('demo', 'Demo');
263
- this.tooltipRadioTextMap.set('postedAdu', '$ Posted ADUs');
264
- this.tooltipRadioTextMap.set('scheduledAdu', '$ Scheduled ADUs');
265
- this.tooltipRadioTextMap.set('audienceDeficit', '$ O/S Audience');
266
- this.tooltipRadioTextMap.set('postedAudPercent', 'Posted Audience %');
267
- this.tooltipRadioTextMap.set('potentialUnitsValue', 'POT Units');
268
- this.tooltipRadioTextMap.set('bookedUnitsValue', 'Booked Eq Units');
269
- this.tooltipRadioTextMap.set('bookedAmountWithZeroRatingValue', 'Total $ Booked');
270
- this.tooltipRadioTextMap.set('bookedAmountPercentageWithZeroRatingValue', '% Against All Demos');
271
- this.tooltipRadioTextMap.set('bookedAmountWithoutZeroRatingValue', '$Booked With Imps(’000)');
272
- this.tooltipRadioTextMap.set('bookedAmountPercentageWithoutZeroRatingValue', '% Against All Demos');
273
- this.tooltipRadioTextMap.set('totalBookedAmountValue', 'Total $Booked');
274
- this.tooltipRadioTextMap.set('averageUnitRateValue', ' AUR');
275
- this.tooltipRadioTextMap.set('totalBookedAmountWithRatingValue', '$Booked With Rating');
276
- this.tooltipRadioTextMap.set('averageUnitRateWithRatingValue', 'AUR With Rating');
277
- this.tooltipRadioTextMap.set('totalBookedAmountWithImpressionValue', '$Booked With IMPS');
278
- this.tooltipRadioTextMap.set('averageUnitRateWithImpressionValue', 'AUR With IMPS');
279
- this.tooltipRadioTextMap.set('bookedUnitsWithRatingValue', 'Booked Units With Rating');
280
- this.tooltipRadioTextMap.set('postedUnitsWithRatingValue', 'Posted Units With Rating');
281
- this.tooltipRadioTextMap.set('bookedUnitsWithImpressionValue', 'Booked Units With IMPS');
282
- this.tooltipRadioTextMap.set('postedUnitsWithImpressionValue', 'Posted Units With IMPS');
283
- this.tooltipRadioTextMap.set('bookedRatings', 'Booked Rating');
284
- this.tooltipRadioTextMap.set('postedRatings', 'POSTED Rating');
285
- this.tooltipRadioTextMap.set('PostedRating', 'Posted RTG');
286
- this.tooltipRadioTextMap.set('bookedImpressions', "Booked IMP('000)");
287
- this.tooltipRadioTextMap.set('postedImpressions', "Posted IMP('000)");
288
- this.tooltipRadioTextMap.set('PostedImpressions', "Posted IMP('000)");
289
- this.tooltipRadioTextMap.set('bookedAverageRating', 'Booked AU Rating');
290
- this.tooltipRadioTextMap.set('postedAverageRating', 'Posted AU Rating');
291
- this.tooltipRadioTextMap.set('bookedAverageImpression', 'Booked AU IMPS');
292
- this.tooltipRadioTextMap.set('postedAverageImpression', 'Posted AU IMPS');
293
- this.tooltipRadioTextMap.set('bookedCppValue', 'Booked CPP');
294
- this.tooltipRadioTextMap.set('bookedEffectiveCppValue', 'Effective CPP');
295
- this.tooltipRadioTextMap.set('bookedCpmValue', 'Booked CPM');
296
- this.tooltipRadioTextMap.set('bookedEffectiveCpmValue', 'Effective CPM');
297
- this.tooltipRadioTextMap.set('orderSource', 'Order Route');
298
- this.tooltipRadioTextMap.set('orderCategory', 'Rev Category');
299
- this.tooltipRadioTextMap.set('cashOrTrade', 'C/T');
300
- this.tooltipRadioTextMap.set('revisionStartDate', 'Revision Start Date');
301
- this.tooltipRadioTextMap.set('name', 'name');
302
- this.tooltipRadioTextMap.set('role', 'role');
303
- this.tooltipRadioTextMap.set('stationCount', 'stationCount');
304
- this.tooltipRadioTextMap.set('stationList', 'stationList');
305
- this.tooltipRadioTextMap.set('approvedOn', 'Approved On');
306
- this.tooltipRadioTextMap.set('approvedBy', 'Approved By');
307
- this.tooltipRadioTextMap.set('ODImps', 'Proj. OD IMPS');
308
- this.tooltipRadioTextMap.set('UDImps', 'Proj. UD IMPS');
309
- this.tooltipRadioTextMap.set('ODGrp', 'Proj. OD GRP');
310
- this.tooltipRadioTextMap.set('UDGrp', 'Proj. UD GRP');
311
- this.tooltipRadioTextMap.set('udImpsPercent', 'Proj. UD %');
312
- this.tooltipRadioTextMap.set('udGrpPercent', 'Proj. UD GRP %');
313
- this.tooltipRadioTextMap.set('odImpsPercent', 'Proj. OD %');
314
- this.tooltipRadioTextMap.set('odGrpPercent', 'Proj. OD GRP %');
315
- this.tooltipRadioTextMap.set('RevisionNumber', 'Revision #');
316
- this.tooltipRadioTextMap.set('RevisionType', 'Revision Type');
317
- this.tooltipRadioTextMap.set('GeneratedOn', 'Generated On');
318
- this.tooltipRadioTextMap.set('BookedValueForDisplay', '$ BOOKED');
319
- this.tooltipRadioTextMap.set('BookedValue', '$ Booked');
320
- this.tooltipRadioTextMap.set('BookedSpots', 'Spots');
321
- this.tooltipRadioTextMap.set('BookedGRP', 'GRP');
322
- this.tooltipRadioTextMap.set('BookedIMPSRevTab', "IMPS'(000)");
323
- this.tooltipRadioTextMap.set('BookedCPP', 'CPP');
324
- this.tooltipRadioTextMap.set('BookedCPM', 'CPM');
325
- this.tooltipRadioTextMap.set('MGsValueForDisplay', '$ MGS');
326
- this.tooltipRadioTextMap.set('MGsValue', '$ MGS');
327
- this.tooltipRadioTextMap.set('ADUsValueForDisplay', '$ ADUS');
328
- this.tooltipRadioTextMap.set('ADUsValue', '$ ADUS');
329
- this.tooltipRadioTextMap.set('BuyerChangesValueForDisplay', '$ Buyer Change');
330
- this.tooltipRadioTextMap.set('BuyerChangesValue', '$ Buyer Change');
331
- this.tooltipRadioTextMap.set('UserChangesValueForDisplay', '$ Seller User Change');
332
- this.tooltipRadioTextMap.set('UserChangesValue', '$ Seller User Change');
333
- this.tooltipRadioTextMap.set('SellerLine', 'Seller Line #');
334
- this.tooltipRadioTextMap.set('BuyerLine', 'Buy Line #');
335
- this.tooltipRadioTextMap.set('SpotStatus', 'Spot Status');
336
- this.tooltipRadioTextMap.set('InventoryCode', 'Inventory Code');
337
- this.tooltipRadioTextMap.set('BuyerProgramName', 'Buyer Program Name');
338
- this.tooltipRadioTextMap.set('RevenueClass', 'Revenue Class');
339
- this.tooltipRadioTextMap.set('WeeklyAUR', 'Booked Avg. Rate');
340
- this.tooltipRadioTextMap.set('BookedRate', 'Booked Rate');
341
- this.tooltipRadioTextMap.set('averageRate', 'Average Rate');
342
- this.tooltipRadioTextMap.set('bookedAverageRate', 'Booked AVG. Rate');
343
- this.tooltipRadioTextMap.set('dollarIMPSImpact', '$ IMPS Impact');
344
- this.tooltipRadioTextMap.set('dollarRTGImpact', '$ RTG IMPACT');
345
- this.tooltipRadioTextMap.set('IMPSImpact', "IMPS ('000) IMPACT");
346
- this.tooltipRadioTextMap.set('RTGImpact', 'RTG Impact');
347
- this.tooltipRadioTextMap.set('inventoryFillPercentageSameWeek', 'Inv Fill Same Week');
348
- this.tooltipRadioTextMap.set('inventoryFillPercentageFinal', 'Inv Fill Final');
349
- this.tooltipRadioTextMap.set('projectedRTG', 'Projected RTG');
350
- this.tooltipRadioTextMap.set('projectedIMPS', "Projected IMPS('000)");
351
- this.tooltipRadioTextMap.set('desiredCPM', 'Desired CPM');
352
- this.tooltipRadioTextMap.set('desiredCPP', 'Desired CPP');
353
- this.tooltipRadioTextMap.set('origin', 'Origin');
354
- this.tooltipRadioTextMap.set('BookedRTG', 'Booked RTG');
355
- this.tooltipRadioTextMap.set('BookedIMPS', "Booked IMPS('000)");
356
- this.tooltipRadioTextMap.set('IMPS', "IMP('000)");
357
- this.tooltipRadioTextMap.set('AURTG', 'Avg RTG');
358
- this.tooltipRadioTextMap.set('AUIMPS', "Avg IMP('000)");
359
- this.tooltipRadioTextMap.set('PostedRatingsOrImpressions', 'Posted RTG');
360
- this.tooltipRadioTextMap.set('ScheduleFlightWeek', 'Schedule Week');
361
- this.tooltipRadioTextMap.set('ScheduledDay', 'Scheduled Day');
362
- this.tooltipRadioTextMap.set('AirStatus', 'Air Status');
363
- this.tooltipRadioTextMap.set('AirDateAndTime', 'Air Date & Time');
364
- this.tooltipRadioTextMap.set('AirDate', 'Air Date');
365
- this.tooltipRadioTextMap.set('NormalizedOrderedRating', 'Normalized Booked RTG');
366
- this.tooltipRadioTextMap.set('NormalizedOrderedImpressions', "Normalized Booked IMP('000)");
367
- this.tooltipRadioTextMap.set('NormalizedPostedRating', 'Normalized Posted RTG');
368
- this.tooltipRadioTextMap.set('NormalizedPostedImpressions', "Normalized Posted IMP('000)");
369
- this.tooltipRadioTextMap.set('AdId', 'Ad-Id');
370
- this.tooltipRadioTextMap.set('displayimps', 'IMPS');
371
- this.tooltipRadioTextMap.set('displayGrp', 'GRP');
372
- this.tooltipRadioTextMap.set('bookedSpotsForDisplay', 'Spots');
373
- this.tooltipRadioTextMap.set('displaySpots', 'Spots');
374
- this.tooltipRadioTextMap.set('estimateNo', 'Estimate#');
375
- this.tooltipRadioTextMap.set('primaryBuyer', 'Primary Buyer');
376
- this.tooltipRadioTextMap.set('primaryBuyerName', 'Primary Buyer');
377
- this.tooltipRadioTextMap.set('secondaryBuyerName', 'Secondary Buyer');
378
- this.tooltipRadioTextMap.set('secondaryBuyer', 'Secondary Buyer');
379
- this.tooltipRadioTextMap.set('timeoutDate', 'Timeout Date');
380
- this.tooltipRadioTextMap.set('DisplaytSpotStatusBI', 'Spot Status');
381
- this.tooltipRadioTextMap.set('LineSpot', 'Line.Spot');
382
- this.tooltipRadioTextMap.set('LurWindowName', 'Political Window');
383
- this.tooltipRadioTextMap.set('length', 'Length');
384
- this.tooltipRadioTextMap.set('revClass', 'Rev Class');
385
- // this.tooltipRadioTextMap.set("udValue", "$ UD");
386
- // this.tooltipRadioTextMap.set("odValue", "$ OD");
387
- this.tooltipRadioTextMap.set('udValue', 'Proj. $ UD');
388
- this.tooltipRadioTextMap.set('odValue', 'Proj. $ OD');
389
- this.tooltipRadioTextMap.set('OtherAvailableSpotsTableInventoryCode', 'Inventory Code');
390
- this.tooltipRadioTextMap.set('OtherAvailableSpotsTableBuyerProgramName', 'Buyer Program Name');
391
- this.tooltipRadioTextMap.set('OtherAvailableSpotsTableStartTime', 'Start Time');
392
- this.tooltipRadioTextMap.set('OtherAvailableSpotsTableEndTime', 'End Time');
393
- this.tooltipRadioTextMap.set('OtherAvailableSpotsTableWeeklyAUR', 'Booked Avg. Rate');
394
- this.tooltipRadioTextMap.set('OtherAvailableSpotsTableDisplayRevenueClass', 'Rev Class');
395
- this.tooltipRadioTextMap.set('OtherAvailableSpotsTableActualWeekStartDate', 'Week');
396
- this.tooltipRadioTextMap.set('OtherAvailableSpotsTableWeekDay', 'Day');
397
- this.tooltipRadioTextMap.set('OtherAvailableSpotsTableDisplayLength', 'Length');
398
- this.tooltipRadioTextMap.set('ProjectedImpressions', "Projected IMP('000)");
399
- this.tooltipRadioTextMap.set('ProjectedRtg', 'Projected RTG');
400
- }
401
- selectOrUnselectCheckbox(rowData, columnKeys, isCheckboxSelected) {
402
- rowData[columnKeys] = !rowData[columnKeys];
403
- this.toggleCheckbox.emit({ rowData, columnKeys, isCheckboxSelected });
404
- }
405
- selectOrUnselectRadiobox(rowData, columnKeys, isCheckboxSelected) {
406
- if (rowData[columnKeys] == isCheckboxSelected)
407
- return;
408
- rowData[columnKeys] = isCheckboxSelected;
409
- this.toggleCheckbox.emit({ rowData, columnKeys, isCheckboxSelected });
410
- }
411
- selectUnselectAllRows() {
412
- this.toggleHeaderCheckbox.emit();
413
- }
414
- selectUnselectRow(rowData) {
415
- this.toggleRowCheckbox.emit(rowData);
416
- }
417
- undoCreditedSpot(data) {
418
- this.undoIconClicked.emit({ data, mgOrCredit: 'Credit' });
419
- }
420
- undoMgSpot(data) {
421
- this.undoIconClicked.emit({ data, mgOrCredit: 'MakeGood' });
422
- }
423
- //Sort and Filter Logic begins!
424
- closeTooltip() {
425
- if (this.tooltip && this.tooltip.isOpen()) {
426
- this.tooltip.close();
427
- }
428
- this.tooltip = null;
429
- if (!this.bindValueFuncCalled) {
430
- this.columnFilterClosed.emit();
431
- }
432
- }
433
- isTooltipActive(header) {
434
- return this.annaFilterService.isTooltipActive(header, this.annaSortService.columnSortState);
435
- }
436
- bindTheValueToToolTip(tooltip, header) {
437
- this.bindValueFuncCalled = true;
438
- // if same tooltip opened close it
439
- if (tooltip == this.tooltip) {
440
- this.bindValueFuncCalled = false;
441
- this.closeTooltip();
442
- }
443
- else {
444
- let enabledHeaders = [];
445
- this.checkIfUniqueValuePresentForTheHeader(header, enabledHeaders);
446
- this.openTooltip(tooltip, enabledHeaders, header);
447
- if (window.innerWidth < 1500 &&
448
- window.innerHeight < 768 &&
449
- !this.annaFilterService.sliderSet.has(header.filterSortObjectKeys[0])) {
450
- this.columnFilterOpened.emit();
451
- }
452
- this.showCheckboxesForTimeFilter =
453
- this.gtGeneralConfig.component == 'SPOTDETAILS' ||
454
- this.gtGeneralConfig.component == 'EXCLUDEINVENTORYPOPUP' ||
455
- this.gtGeneralConfig.component == 'RATING';
456
- this.showFilterTooltipTabs = header.filterSortObjectKeys.length > 1;
457
- this.bindValueFuncCalled = false;
458
- }
459
- }
460
- checkIfUniqueValuePresentForTheHeader(header, enabledHeaders) {
461
- header.filterSortObjectKeys.forEach((item) => {
462
- let dataToCheck = this.annaFilterService.getFilterOptionsData(this.tableData, this.clonedTableData, item);
463
- if (item == 'period') {
464
- let uniqStartDate = uniq(dataToCheck.map((u) => u['startDate']));
465
- let uniqEndDate = uniq(dataToCheck.map((u) => u['endDate']));
466
- if (uniqStartDate.length > 1 || uniqEndDate.length > 1 || this.isTooltipActive([item])) {
467
- enabledHeaders.push(item);
468
- }
469
- }
470
- else {
471
- let values = dataToCheck.map((u) => u[item]);
472
- // if last applied filter is this header, push it alos as enabledHeader
473
- let activeAndLastlyAppliedHeader = false;
474
- if (this.annaFilterService.appliedFiltersArray.length > 0 &&
475
- this.annaFilterService.appliedFiltersArray[this.annaFilterService.appliedFiltersArray.length - 1] ==
476
- item) {
477
- activeAndLastlyAppliedHeader = true;
478
- }
479
- if (header.filter == 'CHECKBOX' &&
480
- (uniq(values).filter((n) => n != null).length > 1 || activeAndLastlyAppliedHeader)) {
481
- enabledHeaders.push(item);
482
- }
483
- else if (header.filter != 'CHECKBOX' &&
484
- (uniq(values).filter((n) => n != null && n != '-').length > 1 || activeAndLastlyAppliedHeader)) {
485
- enabledHeaders.push(item);
486
- }
487
- }
488
- });
489
- }
490
- openTooltip(tooltip, header, columnHeader) {
491
- this.closeTooltip();
492
- this.tooltip = tooltip;
493
- this.tooltip.open();
494
- //convert key into the header
495
- this.filterTabObjects = header.map((key, index) => {
496
- let value = this.tooltipRadioTextMap.has(key) ? this.tooltipRadioTextMap.get(key) : key; //change to display name
497
- return new radioButtonModel(key, value, columnHeader.isSortRequired[index], columnHeader.isFilterRequired[index]);
498
- });
499
- }
500
- disableEnableEachColumnTooltipIcon() {
501
- this.tableHeaders.forEach((header) => {
502
- header.headerInfo.forEach((item) => {
503
- if (item.showTooltipIcon) {
504
- let values = [];
505
- item.disableTooltipIcon = true;
506
- item.filterSortObjectKeys.forEach((key) => {
507
- let latestFilters = this.annaFilterService.appliedFiltersArray;
508
- if (latestFilters.length > 0 &&
509
- item.disableTooltipIcon &&
510
- latestFilters[latestFilters.length - 1] == key) {
511
- item.disableTooltipIcon = false;
512
- }
513
- if (item.disableTooltipIcon) {
514
- if (key == 'period') {
515
- let uniqStartDate = uniq(this.tableData.map((u) => u['startDate']));
516
- let uniqEndDate = uniq(this.tableData.map((u) => u['endDate']));
517
- item.disableTooltipIcon =
518
- uniqStartDate.length > 1 || uniqEndDate.length > 1 ? false : true;
519
- }
520
- else {
521
- values = this.tableData.map((u) => u[key]);
522
- if ((item.filter == 'CHECKBOX' && uniq(values).filter((n) => n != null).length > 1) ||
523
- (item.filter != 'CHECKBOX' &&
524
- uniq(values).filter((n) => n != null && n != '-').length > 1)) {
525
- item.disableTooltipIcon = false;
526
- }
527
- }
528
- }
529
- });
530
- }
531
- });
532
- });
533
- }
534
- setMarginLeftForFilterIcon() {
535
- let elementArr = this.viewChildTableHeaders.toArray();
536
- elementArr.forEach((item) => {
537
- let childDivElements = item.nativeElement.children;
538
- if (childDivElements.length == 2) {
539
- let firstParagraphOffsetWidth = childDivElements[0]?.children[0]?.offsetWidth
540
- ? childDivElements[0]?.children[0]?.offsetWidth
541
- : 0;
542
- let secondParagraphOffsetWidth = childDivElements[1].children[0]?.offsetWidth
543
- ? childDivElements[1].children[0]?.offsetWidth
544
- : 0;
545
- if (firstParagraphOffsetWidth > secondParagraphOffsetWidth) {
546
- let diff = firstParagraphOffsetWidth - secondParagraphOffsetWidth;
547
- if (childDivElements[0].children.length == 2) {
548
- childDivElements[0].children[1].style.marginLeft = 4 + 'px';
549
- }
550
- if (childDivElements[1].children.length == 2) {
551
- childDivElements[1].children[1].style.marginLeft = diff + 4 + 'px';
552
- }
553
- }
554
- else {
555
- let diff = secondParagraphOffsetWidth - firstParagraphOffsetWidth;
556
- if (childDivElements[0].children.length == 2) {
557
- childDivElements[0].children[1].style.marginLeft = diff + 4 + 'px';
558
- }
559
- if (childDivElements[1].children.length == 2) {
560
- childDivElements[1].children[1].style.marginLeft = 4 + 'px';
561
- }
562
- }
563
- }
564
- });
565
- }
566
- dataRowClicked(rowData) {
567
- this.rowClicked.emit(rowData);
568
- }
569
- radioButtonClicked(data, action, isDisabled) {
570
- if (!isDisabled) {
571
- this.radioButtonSelected.emit({ data, action });
572
- }
573
- }
574
- bindTheValueToSellerGroupTooltip(sellerGroupHierarchy, tooltip) {
575
- if (this.hierarchyTooltip && this.hierarchyTooltip.open) {
576
- this.hierarchyTooltip.close();
577
- }
578
- this.sellerGroupHierarchy = sellerGroupHierarchy;
579
- this.hierarchyTooltip = tooltip;
580
- this.hierarchyTooltip.open();
581
- }
582
- iconClicked(rowData, iconClass) {
583
- if ('orderId' in rowData && iconClass.includes('mdi-star')) {
584
- this.selectedStarredOrderId = rowData.orderId;
585
- }
586
- this.gtIconClicked.emit({ data: rowData, iconClass: iconClass });
587
- }
588
- svgIconClicked(data) {
589
- this.gtSVGIconClicked.emit(data);
590
- }
591
- textActionClicked(rowData, id, columnHeader) {
592
- this.gtTextActionClicked.emit({ data: rowData, id: id, columnHeader: columnHeader, isIconClicked: false });
593
- }
594
- iconClickedOnStringIconActionType(rowData, id, columnHeader) {
595
- this.gtTextActionClicked.emit({ data: rowData, id: id, columnHeader: columnHeader, isIconClicked: true });
596
- }
597
- innerHTMLCellClicked(event, rowData) {
598
- this.gtInnerHTMLClicked.emit({ event, rowData });
599
- }
600
- viewDetailsClicked(rowData) {
601
- this.gtViewDetailClicked.emit({ data: rowData });
602
- }
603
- setActiveStateObject() {
604
- this.annaFilterService.isFilterSortActive =
605
- !this.annaFilterService.resetFilterSortActiveStatus || this.multipleTablesPresent
606
- ? this.annaFilterService.isFilterSortActive
607
- : {};
608
- this.tableHeaders.forEach((item) => {
609
- item.headerInfo.forEach((header) => {
610
- if (header.showTooltipIcon) {
611
- let key = header.filterSortObjectKeys.join(',');
612
- header.joinedFilterSortObjectKeys = key;
613
- // ANNA-4113 fix
614
- if (this.annaFilterService.resetFilterSortActiveStatus) {
615
- this.annaFilterService.isFilterSortActive[key] = false;
616
- }
617
- }
618
- });
619
- });
620
- this.annaFilterService.resetFilterSortActiveStatus = true;
621
- }
622
- setIsDifference(value) {
623
- this.isDifferenceLessThan25Percent = value;
624
- }
625
- resetIndex() {
626
- this.start = 0;
627
- this.end = this.limit + this.start;
628
- }
629
- onTableContainerScroll(e) {
630
- const tableViewHeight = e.target.offsetHeight; // viewport
631
- const tableScrollHeight = e.target.scrollHeight; // length of all table
632
- const scrollLocation = e.target.scrollTop; // how far user scrolled
633
- this.removeTooltipOnScroll();
634
- // If the user has scrolled within 150px of the bottom, add more data
635
- const buffer = 150;
636
- const limit = tableScrollHeight - tableViewHeight - buffer;
637
- if (scrollLocation > limit) {
638
- let data = this.getTableData(this.start, this.end);
639
- this.renderedData = this.renderedData.concat(data);
640
- this.updateIndex();
641
- }
642
- this.tableContainerScrolled(e);
643
- }
644
- getTableData(start, end) {
645
- return this.tableData.filter((value, index) => index >= start && index < end);
646
- }
647
- updateIndex() {
648
- this.start = this.end;
649
- this.end = this.limit + this.start;
650
- }
651
- setInitialRowsForTable() {
652
- this.resetIndex();
653
- this.renderedData = this.getTableData(this.start, this.end);
654
- this.updateIndex();
655
- }
656
- spotDetailsDownloadClicked(parentChildOrTotalRow, rowdata) {
657
- if (rowdata) {
658
- this.selectedInventoryIdForDownload = rowdata.inventoryCodeId;
659
- this.selectedDemographicForDownload = rowdata.demographic;
660
- }
661
- else {
662
- this.selectedInventoryIdForDownload = null;
663
- this.selectedDemographicForDownload = null;
664
- }
665
- this.selectedRowTypeForDownload = parentChildOrTotalRow;
666
- this.downloadSpotDetails.emit({
667
- parentChildOrTotalRow: parentChildOrTotalRow,
668
- inventoryCodeId: this.selectedInventoryIdForDownload,
669
- demographic: this.selectedDemographicForDownload,
670
- });
671
- }
672
- tableContainerScrolled(event) {
673
- this.isScrolledLeft = event.target.scrollLeft > 0;
674
- this.isScrollEnded = Math.round(event.target.scrollLeft) == event.target.scrollWidth - event.target.clientWidth;
675
- this.removeTooltipOnScroll();
676
- }
677
- mouseEnterOnStringTextActionType(rowData, tooltipKey) {
678
- this.textActionTooltip = rowData[tooltipKey];
679
- this.notificationIconHover.emit({ rowData: rowData, type: 'on-enter' });
680
- }
681
- mouseEnterOnStringTextActionTypeContainingTable(rowData, tooltipKey) {
682
- this.tooltipContainingTable = rowData[tooltipKey];
683
- }
684
- mouseLeaveTextActionType(rowData) {
685
- this.notificationIconHoverLeave.emit({ rowData: rowData, type: 'on-leave' });
686
- }
687
- mouseEnterOnTextActionType(rowData, tooltipKey) {
688
- this.textActionTooltip = rowData[tooltipKey];
689
- }
690
- onClickableDataClicked(Rowdata, id) {
691
- this.clickableDataClicked.emit({ data: Rowdata, id: id });
692
- }
693
- removeTooltipOnScroll() {
694
- const elements = document.getElementsByClassName('remarks-info-tooltip');
695
- // const tooltipElements = document.getElementsByClassName("tooltip");
696
- const gtTooltip = document.getElementsByClassName('remove-on-scroll-class');
697
- const tooltipElements = document.getElementsByClassName('tooltip');
698
- while (elements && elements.length > 0) {
699
- elements[0].remove();
700
- }
701
- while (tooltipElements && tooltipElements.length > 0) {
702
- tooltipElements[0].remove();
703
- this.tooltip = null;
704
- }
705
- while (gtTooltip && gtTooltip.length > 0) {
706
- gtTooltip[0].remove();
707
- }
708
- }
709
- iconClickedInTotalRow(colName) {
710
- this.totalRowIconClicked.emit(colName);
711
- }
712
- changesMadeInEditableInputBox(event, editedObject, pasteEvent) {
713
- let enteredValue = pasteEvent ? event.clipboardData.getData('text') : event.key;
714
- let dotIndex = editedObject.value.indexOf('.');
715
- if (event.keyCode != 8 &&
716
- event.keyCode != 46 &&
717
- !(event.keyCode >= 37 && event.keyCode <= 40) &&
718
- ((!editedObject?.allowSpecialCharacters && !/[`0-9.]/.test(enteredValue)) ||
719
- (editedObject.isDecimalPointCheckRequired &&
720
- dotIndex >= 0 &&
721
- event?.target?.selectionStart > dotIndex &&
722
- editedObject.value.length - (dotIndex + 1) >= editedObject.maxDecimalPointsAllowed))) {
723
- event.preventDefault();
724
- }
725
- }
726
- editableInputValueChanged(value, row, keyEdited) {
727
- this.editableInputEdited.emit({ row: row, value: value, keyEdited: keyEdited });
728
- }
729
- radioButtonIconClicked(data) {
730
- this.radioButtonMessageIconClicked.emit(data);
731
- }
732
- filterApplied(tableData) {
733
- this.tableData = tableData;
734
- this.setInitialRowsForTable();
735
- this.disableEnableEachColumnTooltipIcon();
736
- this.filterAppliedToTable.emit(tableData);
737
- this.closeTooltip();
738
- }
739
- sortingApplied(tableData) {
740
- this.tableData = tableData;
741
- this.setInitialRowsForTable();
742
- this.disableEnableEachColumnTooltipIcon();
743
- this.sortingAppliedToTable.emit(tableData);
744
- this.closeTooltip();
745
- }
746
- }
747
- AnnaNonEditableGenericTableComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: AnnaNonEditableGenericTableComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.AnnaSortService }, { token: i2.AnnaDateTimeFormatService }, { token: i3.AnnaFilterService }], target: i0.ɵɵFactoryTarget.Component });
748
- AnnaNonEditableGenericTableComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: AnnaNonEditableGenericTableComponent, isStandalone: true, selector: "anna-core-non-editable-generic-table-lib", inputs: { showSkeletonLoading: "showSkeletonLoading", tableHeaders: "tableHeaders", tableData: "tableData", clonedTableData: "clonedTableData", gtGeneralConfig: "gtGeneralConfig", totalRowInfo: "totalRowInfo", gtDimension: "gtDimension", tableClass: "tableClass", maximumRowsWhichCanBeRenderedWithoutScroll: "maximumRowsWhichCanBeRenderedWithoutScroll", fixNumberOfRowsForPopup: "fixNumberOfRowsForPopup", limit: "limit", includeBorderInTableHeight: "includeBorderInTableHeight", downloadInProgress: "downloadInProgress", percentDone: "percentDone", starredInProgress: "starredInProgress", clickableRow: "clickableRow", setTableHeightWhenRowSizeIsFixed: "setTableHeightWhenRowSizeIsFixed", tableBorderBottomClassRequired: "tableBorderBottomClassRequired", hideSomeTds: "hideSomeTds", tdsHaveRowSpan: "tdsHaveRowSpan", multipleTablesPresent: "multipleTablesPresent" }, outputs: { toggleCheckbox: "toggleCheckbox", toggleRowCheckbox: "toggleRowCheckbox", toggleHeaderCheckbox: "toggleHeaderCheckbox", undoIconClicked: "undoIconClicked", filterAppliedToTable: "filterAppliedToTable", sortingAppliedToTable: "sortingAppliedToTable", rowClicked: "rowClicked", radioButtonSelected: "radioButtonSelected", columnFilterOpened: "columnFilterOpened", columnFilterClosed: "columnFilterClosed", gtIconClicked: "gtIconClicked", gtSVGIconClicked: "gtSVGIconClicked", gtTextActionClicked: "gtTextActionClicked", gtViewDetailClicked: "gtViewDetailClicked", gtInnerHTMLClicked: "gtInnerHTMLClicked", downloadSpotDetails: "downloadSpotDetails", clickableDataClicked: "clickableDataClicked", totalRowIconClicked: "totalRowIconClicked", notificationIconHover: "notificationIconHover", notificationIconHoverLeave: "notificationIconHoverLeave", editableInputEdited: "editableInputEdited", radioButtonMessageIconClicked: "radioButtonMessageIconClicked" }, viewQueries: [{ propertyName: "viewChildTableHeaders", predicate: ["tableHeader"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div\r\n id=\"generic-table-conatiner\"\r\n class=\"table-container {{ gtGeneralConfig?.tableOuterContainerName }} {{ tableBottomBorderClass }}\"\r\n [ngClass]=\"{\r\n 'scroll-left-shadow-effect': isScrolledLeft,\r\n 'scroll-right-shadow-effect': !isScrollEnded,\r\n 'clickable-row': clickableRow,\r\n 'no-data-table': (isNoDataToDisplaySubject$ | async)\r\n }\"\r\n (scroll)=\"onTableContainerScroll($event)\"\r\n>\r\n <div\r\n [class]=\"gtGeneralConfig.tableContainerName\"\r\n class=\"horizontal-scroll-for-table-container\"\r\n [ngStyle]=\"{\r\n height:\r\n tableData.length < maximumRowsWhichCanBeRenderedWithoutScroll\r\n ? 'calc(' +\r\n (gtDimension.rowHeight * tableData.length +\r\n (!tableData.length || !gtGeneralConfig.totalRow\r\n ? gtDimension.headerHeight\r\n : gtDimension.headerHeight + gtDimension.rowHeight)) +\r\n 'px)'\r\n : gtDimension.tableHeight\r\n }\"\r\n >\r\n <table\r\n class=\"gt\"\r\n [ngClass]=\"tableClass\"\r\n mat-table\r\n [dataSource]=\"renderedData\"\r\n >\r\n <tr\r\n class=\"header-row\"\r\n mat-header-row\r\n *matHeaderRowDef=\"tableColumns; sticky: true\"\r\n [style.height.px]=\"gtDimension.headerHeight\"\r\n ></tr>\r\n <tr\r\n class=\"total-row\"\r\n mat-header-row\r\n [style.height.px]=\"gtDimension.rowHeight\"\r\n *matHeaderRowDef=\"totalRowColumns; sticky: true\"\r\n [class.hidden]=\"\r\n showSkeletonLoading ||\r\n (!showSkeletonLoading && !tableData.length) ||\r\n (isNoDataToDisplaySubject$ | async) ||\r\n (!showSkeletonLoading && !gtGeneralConfig.totalRow)\r\n \"\r\n ></tr>\r\n <tr\r\n [class]=\"rowData.gtClass\"\r\n [ngClass]=\"{ 'no-border-tr': (isNoDataToDisplaySubject$ | async) }\"\r\n mat-row\r\n *matRowDef=\"let rowData; columns: tableColumns\"\r\n [style.height.px]=\"gtDimension.rowHeight\"\r\n (click)=\"dataRowClicked(rowData)\"\r\n ></tr>\r\n\r\n <!-- TOTAL ROW -->\r\n <ng-container\r\n [matColumnDef]=\"column.colName\"\r\n *ngFor=\"let column of totalRowInfo; trackBy: trackByFn\"\r\n >\r\n <td\r\n mat-header-cell\r\n *matHeaderCellDef\r\n [attr.colspan]=\"column.colspan\"\r\n class=\"{{ column.class }}\"\r\n >\r\n <ng-container *ngIf=\"column['isActionColumn']\">\r\n <a\r\n *ngFor=\"let data of column.actionData\"\r\n [class]=\"data.class\"\r\n (click)=\"onClickableDataClicked({}, data.id)\"\r\n >\r\n {{ data.name }}\r\n </a>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"column['isIconColumn']\">\r\n <i\r\n class=\"{{ column?.iconData?.class }}\"\r\n (click)=\"iconClickedInTotalRow(column?.colName)\"\r\n >\r\n </i>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"!column['isActionColumn']\">\r\n <strong class=\"upper-label\">{{ column.data }}</strong>\r\n <ng-container *ngIf=\"column.lowerData\">\r\n <br />\r\n <span\r\n *ngIf=\"\r\n column.colName == 'total-potential-booked-unit' &&\r\n gtGeneralConfig.component == 'RATING';\r\n else columnLowerData\r\n \"\r\n class=\"clickable-data\"\r\n (click)=\"spotDetailsDownloadClicked('TOTALROW')\"\r\n [ngClass]=\"{ 'disabled-clickable-data': downloadInProgress }\"\r\n >{{ column.lowerData }}\r\n <span class=\"material-icons spot-details-download-icons\">get_app</span>\r\n <ng-container *ngIf=\"downloadInProgress && selectedRowTypeForDownload == 'TOTALROW'\">\r\n <ng-container [ngTemplateOutlet]=\"circularProgressBar\"></ng-container>\r\n </ng-container>\r\n </span>\r\n <ng-template #columnLowerData>\r\n <span class=\"lower-label\">{{ column.lowerData }}</span>\r\n </ng-template>\r\n </ng-container>\r\n <ng-container *ngIf=\"column.tooltipMessage && gtGeneralConfig.component != 'LUR_VIOLATIONS'\">\r\n <i\r\n class=\"{{ column.tooltipIconClass }}\"\r\n container=\"body\"\r\n [ngbTooltip]=\"column.tooltipMessage\"\r\n tooltipClass=\"gt-total-row-tooltip\"\r\n placement=\"bottom\"\r\n ></i>\r\n </ng-container>\r\n <ng-container *ngIf=\"gtGeneralConfig.component == 'LUR_VIOLATIONS' && column.tooltipMessage\">\r\n <i\r\n class=\"mi mdi-info-outline info-label\"\r\n container=\"body\"\r\n [ngbTooltip]=\"lurViolationTotalRowToolTip\"\r\n tooltipClass=\"gt-total-row-tooltip\"\r\n placement=\"bottom\"\r\n ></i>\r\n </ng-container>\r\n </ng-container>\r\n </td>\r\n </ng-container>\r\n\r\n <!-- MAIN ROW -->\r\n <ng-container\r\n [matColumnDef]=\"columnDef.headerInfo[0].objectKey\"\r\n *ngFor=\"let columnDef of tableHeaders; trackBy: trackByFn\"\r\n >\r\n <th\r\n #tableHeader\r\n nowrap\r\n mat-header-cell\r\n *matHeaderCellDef\r\n [style.width]=\"columnDef.width\"\r\n >\r\n <div\r\n class=\"row mx-0\"\r\n *ngFor=\"let header of columnDef.headerInfo; let j = index\"\r\n >\r\n <p\r\n *ngIf=\"header.typeOfHeaderData === 'STRING'\"\r\n [ngClass]=\"{ 'upper-label': j === 0, 'lower-label': j === 1 }\"\r\n >\r\n <ngx-skeleton-loader\r\n *ngIf=\"header.name == null\"\r\n count=\"1\"\r\n [theme]=\"{\r\n height: '10px',\r\n display: 'block',\r\n width: columnDef.width,\r\n 'max-width': 'calc(100% - 20px)'\r\n }\"\r\n >\r\n </ngx-skeleton-loader>\r\n <ng-container *ngIf=\"header.name\">\r\n {{ header.name }}\r\n </ng-container>\r\n <ng-container *ngIf=\"header.tooltip && header.tooltip.tooltipMessage\">\r\n <i\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"header.tooltip.tooltipMessage\"\r\n container=\"body\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n </ng-container>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'impsInfoTooltip'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"impsInfoTooltip\"\r\n container=\"body\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"\r\n header.tooltip && header.tooltip.name == 'spotsColumnEquivalizationMessageTooltip'\r\n \"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n container=\"body\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"spotsColumnEquivalizationMessageTooltip\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'underDeliveryTooltip'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n container=\"body\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"underDeliveryTooltip\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'overDeliveryTooltip'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n container=\"body\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"overDeliveryTooltip\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'ratingInfoTooltip'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"ratingInfoTooltip\"\r\n container=\"body\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'rateInfoTooltip'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"rateInfoTooltip\"\r\n container=\"body\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'ongoingRevBookedColumnTooltip'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"ongoingRevBookedColumnTooltip\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'completedRevBookedColumnTooltip'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"completedRevBookedColumnTooltip\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'avgBookedRate'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"avgBookedRate\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'avgBookedRtg'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"avgBookedRtg\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'avgBookedImps'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"avgBookedImps\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'automationTooltip'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"automationTooltip\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'rebateImpact'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"rebateImpact\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'projectedImpsRtg'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"projectedImpsRtg\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n </p>\r\n\r\n <ng-container *ngIf=\"header.typeOfHeaderData === 'CHECKBOX'\">\r\n <span\r\n *ngIf=\"gtGeneralConfig.isHeaderChecked\"\r\n class=\"material-icons custom-column-checkbox-checked\"\r\n (click)=\"selectUnselectAllRows()\"\r\n >\r\n check_box\r\n </span>\r\n <span\r\n *ngIf=\"!gtGeneralConfig.isHeaderChecked\"\r\n class=\"material-icons custom-column-checkbox-unchecked\"\r\n [ngClass]=\"{ 'disable-checkbox': gtGeneralConfig.disableHeaderCheckbox }\"\r\n (click)=\"selectUnselectAllRows()\"\r\n >\r\n check_box_outline_blank\r\n </span>\r\n </ng-container>\r\n\r\n <div\r\n *ngIf=\"gtGeneralConfig.showAllColumnFilter\"\r\n class=\"sort-filter-container\"\r\n >\r\n <ng-container *ngIf=\"header.showTooltipIcon\">\r\n <!-- Active tooltip Functionality -->\r\n <ng-container *ngIf=\"header.filter === 'CHECKBOX'\">\r\n <span\r\n class=\"mdi mdi-filter-variant\"\r\n [ngClass]=\"{\r\n active:\r\n annaFilterService.isFilterSortActive &&\r\n annaFilterService.isFilterSortActive[header.joinedFilterSortObjectKeys],\r\n disabled: header.disableTooltipIcon || showSkeletonLoading\r\n }\"\r\n [ngbTooltip]=\"filterTooltip\"\r\n placement=\"{{ filterAlignment }}\"\r\n container=\"body\"\r\n tooltipClass=\"non-edit-checkbox-tooltip\"\r\n [autoClose]=\"'outside'\"\r\n triggers=\"manual\"\r\n #t=\"ngbTooltip\"\r\n (click)=\"bindTheValueToToolTip(t, header)\"\r\n (hidden)=\"closeTooltip()\"\r\n >\r\n </span\r\n ><br />\r\n </ng-container>\r\n <ng-container *ngIf=\"header.filter === 'SLIDER'\">\r\n <span\r\n class=\"mdi mdi-filter-variant\"\r\n [ngClass]=\"{\r\n active:\r\n annaFilterService.isFilterSortActive &&\r\n annaFilterService.isFilterSortActive[header.joinedFilterSortObjectKeys],\r\n disabled: header.disableTooltipIcon || showSkeletonLoading\r\n }\"\r\n [ngbTooltip]=\"sliderToolTip\"\r\n placement=\"bottom left-top\"\r\n container=\"body\"\r\n tooltipClass=\"non-edit-slider-tooltip\"\r\n [autoClose]=\"'outside'\"\r\n triggers=\"manual\"\r\n #t1=\"ngbTooltip\"\r\n (click)=\"bindTheValueToToolTip(t1, header)\"\r\n (hidden)=\"closeTooltip()\"\r\n >\r\n </span\r\n ><br />\r\n </ng-container>\r\n <ng-container *ngIf=\"header.filter === 'DATE'\">\r\n <span\r\n class=\"mdi mdi-filter-variant\"\r\n [ngClass]=\"{\r\n active:\r\n annaFilterService.isFilterSortActive &&\r\n annaFilterService.isFilterSortActive[header.joinedFilterSortObjectKeys],\r\n disabled: header.disableTooltipIcon || showSkeletonLoading\r\n }\"\r\n [ngbTooltip]=\"datePickerTooltip\"\r\n placement=\"bottom auto\"\r\n container=\"body\"\r\n tooltipClass=\"non-edit-datepicker-tooltip\"\r\n [autoClose]=\"'outside'\"\r\n triggers=\"manual\"\r\n #t2=\"ngbTooltip\"\r\n (click)=\"bindTheValueToToolTip(t2, header)\"\r\n (hidden)=\"closeTooltip()\"\r\n >\r\n </span\r\n ><br />\r\n </ng-container>\r\n <ng-container *ngIf=\"header.filter === 'WEEK'\">\r\n <span\r\n class=\"mdi mdi-filter-variant\"\r\n [ngClass]=\"{\r\n active:\r\n annaFilterService.isFilterSortActive &&\r\n annaFilterService.isFilterSortActive[header.joinedFilterSortObjectKeys],\r\n disabled: header.disableTooltipIcon || showSkeletonLoading\r\n }\"\r\n [ngbTooltip]=\"weekPickerToolTip\"\r\n placement=\"bottom left-top\"\r\n container=\"body\"\r\n [autoClose]=\"'outside'\"\r\n triggers=\"manual\"\r\n #t3=\"ngbTooltip\"\r\n (click)=\"bindTheValueToToolTip(t3, header)\"\r\n (hidden)=\"closeTooltip()\"\r\n >\r\n </span\r\n ><br />\r\n </ng-container>\r\n <ng-container *ngIf=\"header.filter === 'TIME'\">\r\n <span\r\n class=\"mdi mdi-filter-variant\"\r\n [ngClass]=\"{\r\n active:\r\n annaFilterService.isFilterSortActive &&\r\n annaFilterService.isFilterSortActive[header.joinedFilterSortObjectKeys],\r\n disabled: header.disableTooltipIcon || showSkeletonLoading\r\n }\"\r\n [ngbTooltip]=\"timeFilterToolTip\"\r\n placement=\"bottom left-top auto\"\r\n container=\"body\"\r\n tooltipClass=\"non-edit-time-tooltip\"\r\n [autoClose]=\"'outside'\"\r\n triggers=\"manual\"\r\n #t4=\"ngbTooltip\"\r\n (click)=\"bindTheValueToToolTip(t4, header)\"\r\n (hidden)=\"closeTooltip()\"\r\n >\r\n </span\r\n ><br />\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"!header.showTooltipIcon\">\r\n <span id=\"no-filter-space\"></span><br />\r\n </ng-container>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'lurViolationInfoTooltip'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"lurViolationInfoTooltip\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n </div>\r\n </div>\r\n </th>\r\n\r\n <ng-container *matCellDef=\"let ROW_DATA\">\r\n <td\r\n mat-cell\r\n [style.background]=\"ROW_DATA.backgroundColor\"\r\n [style.border]=\"ROW_DATA.border\"\r\n class=\"{{ ROW_DATA.rowClass }}\"\r\n [ngClass]=\"ROW_DATA[columnDef.headerInfo[0].objectKey + 'TdClass']\"\r\n [attr.rowspan]=\"ROW_DATA[columnDef.headerInfo[0].objectKey + 'Rowspan']\"\r\n *ngIf=\"\r\n !hideSomeTds ||\r\n (hideSomeTds && !ROW_DATA['hide' + columnDef.headerInfo[0].objectKey + 'Td'])\r\n \"\r\n >\r\n <ngx-skeleton-loader\r\n *ngIf=\"showSkeletonLoading\"\r\n count=\"1\"\r\n [theme]=\"{ height: '10px', display: 'block' }\"\r\n >\r\n </ngx-skeleton-loader>\r\n\r\n <ng-container *ngIf=\"!showSkeletonLoading\">\r\n <ng-container *ngIf=\"tableData.length > 0 && !(isNoDataToDisplaySubject$ | async)\">\r\n <ng-container\r\n *ngFor=\"\r\n let subline of columnDef.headerInfo;\r\n let subLineIndex = index;\r\n trackBy: trackByFn\r\n \"\r\n >\r\n <div showEllipsisTextOnHover>\r\n <ng-container [ngSwitch]=\"columnDef.headerInfo[subLineIndex].typeOfBodyData\">\r\n <ng-container *ngSwitchCase=\"'ICON'\">\r\n <i\r\n *ngIf=\"\r\n !(\r\n starredInProgress &&\r\n ROW_DATA.orderId == selectedStarredOrderId\r\n )\r\n \"\r\n [class]=\"ROW_DATA.iconClass\"\r\n (click)=\"iconClicked(ROW_DATA, ROW_DATA.iconClass)\"\r\n ngbTooltip=\"{{ ROW_DATA.iconTitleText }}\"\r\n placement=\"bottom\"\r\n container=\"body\"\r\n tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\r\n ></i>\r\n <ng-container\r\n *ngIf=\"\r\n starredInProgress && ROW_DATA.orderId == selectedStarredOrderId\r\n \"\r\n >\r\n <div class=\"spinner-for-button-directive\"></div>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'ICON_CELL'\">\r\n <ng-container\r\n *ngFor=\"\r\n let action of ROW_DATA[\r\n columnDef.headerInfo[subLineIndex].actionKey\r\n ]\r\n \"\r\n >\r\n <ng-container *ngIf=\"action.showObjectKey\">\r\n {{ ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey] }}\r\n </ng-container>\r\n\r\n <i\r\n *ngIf=\"action.showIcon\"\r\n [class]=\"action.iconClass\"\r\n (mouseenter)=\"\r\n mouseEnterOnStringTextActionType(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].tooltipKey\r\n )\r\n \"\r\n placement=\"bottom auto\"\r\n container=\"body\"\r\n [autoClose]=\"true\"\r\n tooltipClass=\"team-user-tooltip remove-on-scroll-class\"\r\n [ngbTooltip]=\"action.showTooltip ? action.tooltipData : null\"\r\n (click)=\"\r\n textActionClicked(\r\n ROW_DATA,\r\n action.id,\r\n columnDef.headerInfo[subLineIndex]\r\n )\r\n \"\r\n [disableTooltip]=\"!action.showTooltip\"\r\n >\r\n </i>\r\n\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'HTML_STRING'\">\r\n <p\r\n [innerHTML]=\"ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\r\n (click)=\"innerHTMLCellClicked($event, ROW_DATA)\"\r\n ></p>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'SVG_ICON'\">\r\n <anna-core-anna-icon-column\r\n [componentName]=\"gtGeneralConfig.component\"\r\n [dataObject]=\"ROW_DATA\"\r\n [iconToShow]=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n \"\r\n (onColumnIconClicked)=\"svgIconClicked($event)\"\r\n ></anna-core-anna-icon-column>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'TEXT_ACTIONS'\">\r\n <ng-container\r\n *ngFor=\"\r\n let text of ROW_DATA[\r\n columnDef.headerInfo[subLineIndex].actionKey\r\n ]\r\n \"\r\n >\r\n <button\r\n *ngIf=\"text.showTooltip\"\r\n (click)=\"\r\n textActionClicked(\r\n ROW_DATA,\r\n text.id,\r\n columnDef.headerInfo[subLineIndex]\r\n )\r\n \"\r\n [disabled]=\"text.isDisabled\"\r\n class=\"{{ text.class }}\"\r\n (mouseenter)=\"\r\n mouseEnterOnTextActionType(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].tooltipKey\r\n )\r\n \"\r\n [ngbTooltip]=\"textActionTooltipTemplate\"\r\n placement=\"auto\"\r\n container=\"body\"\r\n tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\r\n >\r\n {{ text.name }}\r\n </button>\r\n\r\n <button\r\n *ngIf=\"!text.showTooltip\"\r\n (click)=\"\r\n textActionClicked(\r\n ROW_DATA,\r\n text.id,\r\n columnDef.headerInfo[subLineIndex]\r\n )\r\n \"\r\n [disabled]=\"text.isDisabled\"\r\n class=\"{{ text.class }}\"\r\n >\r\n {{ text.name }}\r\n </button>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'CHECKBOX'\">\r\n <span\r\n *ngIf=\"ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\r\n [ngClass]=\"{\r\n 'disable-checkbox':\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].isDisabledKey]\r\n }\"\r\n class=\"material-icons custom-column-checkbox-checked\"\r\n (click)=\"\r\n selectOrUnselectCheckbox(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].objectKey,\r\n false\r\n )\r\n \"\r\n >\r\n check_box\r\n </span>\r\n <span\r\n *ngIf=\"!ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\r\n class=\"material-icons custom-column-checkbox-unchecked\"\r\n [ngClass]=\"{\r\n 'disable-checkbox':\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].isDisabledKey]\r\n }\"\r\n (click)=\"\r\n selectOrUnselectCheckbox(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].objectKey,\r\n true\r\n )\r\n \"\r\n >\r\n check_box_outline_blank\r\n </span>\r\n\r\n <ng-container\r\n *ngFor=\"\r\n let action of ROW_DATA[\r\n columnDef.headerInfo[subLineIndex].actionKey\r\n ]\r\n \"\r\n >\r\n <i\r\n *ngIf=\"action.showIcon\"\r\n [class]=\"action.iconClass\"\r\n [ngClass]=\"{ disabled: action.disabledIcon }\"\r\n (mouseenter)=\"\r\n mouseEnterOnStringTextActionTypeContainingTable(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].tooltipKey\r\n )\r\n \"\r\n placement=\"bottom auto\"\r\n container=\"body\"\r\n [autoClose]=\"true\"\r\n tooltipClass=\"tooltip-containing-table remove-on-scroll-class\"\r\n [ngbTooltip]=\"tooltipContainingTableTemplate\"\r\n >\r\n </i>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'CLICKABLE_DATA'\">\r\n <a\r\n *ngFor=\"\r\n let text of ROW_DATA[\r\n columnDef.headerInfo[subLineIndex].actionKey\r\n ]\r\n \"\r\n [class]=\"text.class\"\r\n (click)=\"onClickableDataClicked(ROW_DATA, text.id)\"\r\n >\r\n {{ text.name }}\r\n </a>\r\n <span\r\n *ngIf=\"\r\n subline.objectKey == 'displayBookedUnits' &&\r\n gtGeneralConfig.component == 'RATING'\r\n \"\r\n class=\"clickable-data\"\r\n (click)=\"spotDetailsDownloadClicked('DATAROW', ROW_DATA)\"\r\n [ngClass]=\"{ 'disabled-clickable-data': downloadInProgress }\"\r\n >{{ ROW_DATA.displayBookedUnits }}\r\n <span class=\"material-icons spot-details-download-icons\"\r\n >get_app</span\r\n >\r\n <ng-container\r\n *ngIf=\"\r\n downloadInProgress &&\r\n ROW_DATA.inventoryCodeId ==\r\n selectedInventoryIdForDownload &&\r\n ROW_DATA.demographic == selectedDemographicForDownload\r\n \"\r\n >\r\n <ng-container\r\n [ngTemplateOutlet]=\"circularProgressBar\"\r\n ></ng-container>\r\n </ng-container>\r\n </span>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'STRING___ICON_OR_TEXT_ACTION'\">\r\n <ng-container\r\n *ngFor=\"\r\n let action of ROW_DATA[\r\n columnDef.headerInfo[subLineIndex].actionKey\r\n ]\r\n \"\r\n >\r\n <span\r\n [class]=\"action.additionalTextBeforeLinkClass\"\r\n [innerHtml]=\"action.additionalTextBeforeLink\"\r\n ngbTooltip=\"{{ action.additionalTextBeforeLink }}\"\r\n placement=\"bottom\"\r\n container=\"body\"\r\n tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\r\n [disableTooltip]=\"!action.enableTooltipForAdditionalText\"\r\n ></span>\r\n\r\n <ng-container *ngIf=\"action && action.typeOfData == 'STRING'\">\r\n {{ action.data }}\r\n </ng-container>\r\n\r\n <a\r\n [id]=\"action.id\"\r\n *ngIf=\"action.showLink\"\r\n (click)=\"\r\n textActionClicked(\r\n ROW_DATA,\r\n action.id,\r\n columnDef.headerInfo[subLineIndex]\r\n )\r\n \"\r\n [class]=\"action.linkClass\"\r\n [ngClass]=\"{ disabled: action.disabledLink }\"\r\n >{{ action.data }}</a\r\n >\r\n <span\r\n ngbTooltip=\"{{ action.additionalTextAfterLink }}\"\r\n placement=\"bottom\"\r\n container=\"body\"\r\n [class]=\"action.additionalTextAfterLinkClass\"\r\n tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\r\n [disableTooltip]=\"!action.enableTooltipForAdditionalAfterText\"\r\n >\r\n {{ action.additionalTextAfterLink }}\r\n </span>\r\n\r\n <ng-container *ngIf=\"action.showTooltip\">\r\n <ng-container *ngIf=\"action.tooltipData.innerHtml\">\r\n <i\r\n *ngIf=\"action.showIcon\"\r\n [class]=\"action.iconClass\"\r\n [ngClass]=\"{ disabled: action.disabledIcon }\"\r\n (mouseenter)=\"\r\n mouseEnterOnStringTextActionTypeContainingTable(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].tooltipKey\r\n )\r\n \"\r\n placement=\"bottom auto\"\r\n container=\"body\"\r\n [autoClose]=\"true\"\r\n tooltipClass=\"tooltip-containing-table remove-on-scroll-class\"\r\n [ngbTooltip]=\"tooltipContainingTableTemplate\"\r\n >\r\n </i>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"!action.tooltipData.tooltipTableBody\">\r\n <i\r\n *ngIf=\"action.showIcon\"\r\n [class]=\"action.iconClass\"\r\n [ngClass]=\"{ disabled: action.disabledIcon }\"\r\n (click)=\"\r\n iconClickedOnStringIconActionType(\r\n ROW_DATA,\r\n action.id,\r\n columnDef.headerInfo[subLineIndex]\r\n )\r\n \"\r\n (mouseleave)=\"mouseLeaveTextActionType(ROW_DATA)\"\r\n (mouseenter)=\"\r\n mouseEnterOnStringTextActionType(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].tooltipKey\r\n )\r\n \"\r\n [placement]=\"\r\n action.tooltipPlacement\r\n ? action.tooltipPlacement\r\n : 'bottom auto'\r\n \"\r\n container=\"body\"\r\n [autoClose]=\"true\"\r\n tooltipClass=\"team-user-tooltip remove-on-scroll-class {{\r\n action.tooltipClass\r\n }}\"\r\n [ngbTooltip]=\"userLoggedInDetails\"\r\n >\r\n </i>\r\n <ng-container *ngIf=\"action['showSvgIcon']\">\r\n <anna-core-anna-est-icon-template\r\n class=\"float-right\"\r\n *ngIf=\"action['svgIconName'] == 'anna-icon'\"\r\n (mouseleave)=\"mouseLeaveTextActionType(ROW_DATA)\"\r\n (mouseenter)=\"\r\n mouseEnterOnStringTextActionType(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex]\r\n .tooltipKey\r\n )\r\n \"\r\n [placement]=\"\r\n action.tooltipPlacement\r\n ? action.tooltipPlacement\r\n : 'bottom auto'\r\n \"\r\n tooltipClass=\"team-user-tooltip remove-on-scroll-class {{\r\n action['tooltipClass']\r\n }}\"\r\n [ngbTooltip]=\"userLoggedInDetails\"\r\n container=\"body\"\r\n [autoClose]=\"true\"\r\n >\r\n </anna-core-anna-est-icon-template>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"!action.showTooltip\">\r\n <i\r\n *ngIf=\"action.showIcon\"\r\n [class]=\"action.iconClass\"\r\n [ngClass]=\"{ disabled: action.disabledIcon }\"\r\n (click)=\"\r\n iconClickedOnStringIconActionType(\r\n ROW_DATA,\r\n action.id,\r\n columnDef.headerInfo[subLineIndex]\r\n )\r\n \"\r\n >\r\n </i>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'STRING_OR_INPUT'\">\r\n <ng-container\r\n *ngIf=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]?.type ==\r\n 'STRING';\r\n else inputBox\r\n \"\r\n >\r\n <span\r\n [innerHtml]=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n ?.value\r\n \"\r\n ></span>\r\n </ng-container>\r\n <ng-template #inputBox>\r\n <input\r\n placeholder=\"{{\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n ?.placeholder\r\n }}\"\r\n showEllipsisTextOnHover\r\n class=\"{{\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n .className\r\n }}\"\r\n (keydown)=\"\r\n changesMadeInEditableInputBox(\r\n $event,\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey],\r\n false\r\n )\r\n \"\r\n (paste)=\"\r\n changesMadeInEditableInputBox(\r\n $event,\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey],\r\n true\r\n )\r\n \"\r\n (ngModelChange)=\"\r\n editableInputValueChanged(\r\n $event,\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].objectKey\r\n )\r\n \"\r\n [ngModel]=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey].value\r\n \"\r\n [disabled]=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n .disabled\r\n \"\r\n [ngClass]=\"{\r\n 'red-border':\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n .hasError\r\n }\"\r\n />\r\n\r\n <i\r\n *ngIf=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n .showIcon\r\n \"\r\n container=\"body\"\r\n [ngbTooltip]=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n .iconTooltip\r\n \"\r\n tooltipClass=\"gt-total-row-tooltip\"\r\n placement=\"bottom\"\r\n class=\"{{\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n .iconClass\r\n }}\"\r\n >\r\n </i>\r\n <ng-container\r\n *ngIf=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey][\r\n 'showSvgIcon'\r\n ]\r\n \"\r\n >\r\n <anna-core-anna-est-icon-template\r\n class=\"float-right\"\r\n *ngIf=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey][\r\n 'svgIconName'\r\n ] == 'anna-icon'\r\n \"\r\n [placement]=\"'bottom auto'\"\r\n tooltipClass=\"gt-total-row-tooltip\"\r\n [ngbTooltip]=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n .iconTooltip\r\n \"\r\n container=\"body\"\r\n >\r\n </anna-core-anna-est-icon-template>\r\n </ng-container>\r\n </ng-template>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'HTML'\">\r\n <span\r\n [innerHtml]=\"ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\r\n ></span>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'SINGLE_RADIO'\">\r\n <span\r\n *ngIf=\"ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\r\n [ngClass]=\"{\r\n 'disable-checkbox':\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].isDisabledKey]\r\n }\"\r\n class=\"mdi mdi-radiobox-marked\"\r\n (click)=\"(null)\"\r\n >\r\n </span>\r\n <span\r\n *ngIf=\"!ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\r\n class=\"mdi mdi-radiobox-blank\"\r\n [ngClass]=\"{\r\n 'disable-checkbox':\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].isDisabledKey]\r\n }\"\r\n (click)=\"\r\n selectOrUnselectCheckbox(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].objectKey,\r\n true\r\n )\r\n \"\r\n >\r\n </span>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'RADIO'\">\r\n <mat-radio-group\r\n *ngIf=\"ROW_DATA['RadioButtonConfig']\"\r\n [ngModel]=\"ROW_DATA[subline.objectKey]\"\r\n [disabled]=\"ROW_DATA['RadioButtonConfig'][0].isDisabled\"\r\n >\r\n <ng-container\r\n *ngFor=\"\r\n let radioButton of ROW_DATA['RadioButtonConfig'];\r\n let last = last\r\n \"\r\n >\r\n <mat-radio-button\r\n value=\"{{ radioButton.value }}\"\r\n class=\"{{ radioButton.class }}\"\r\n (click)=\"\r\n radioButtonClicked(\r\n ROW_DATA,\r\n radioButton.value,\r\n ROW_DATA['RadioButtonConfig'][0].isDisabled\r\n )\r\n \"\r\n >{{ radioButton.label }}\r\n </mat-radio-button>\r\n <i\r\n class=\" {{ radioButton.iconClass }}\"\r\n (click)=\"radioButtonIconClicked(ROW_DATA)\"\r\n ></i>\r\n <br *ngIf=\"!last\" />\r\n </ng-container>\r\n </mat-radio-group>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'STRING_WITH_TOOLTIP'\">\r\n <ng-container\r\n *ngFor=\"\r\n let action of ROW_DATA[\r\n columnDef.headerInfo[subLineIndex].actionKey\r\n ]\r\n \"\r\n >\r\n <span> {{ action?.dataToDisplay }}</span>\r\n <span\r\n *ngIf=\"action?.showTooltip\"\r\n [ngbTooltip]=\"textActionTooltipTemplate\"\r\n (mouseenter)=\"\r\n mouseEnterOnStringTextActionType(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].tooltipKey\r\n )\r\n \"\r\n [placement]=\"action?.tooltipPosition\"\r\n container=\"body\"\r\n [class]=\"action?.tooltipIconClass\"\r\n tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\r\n [disableTooltip]=\"action?.disableTooltip\"\r\n >\r\n </span>\r\n <span> {{ action?.dataToDisplayAfterTooltip }}</span>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchDefault>\r\n <ng-container *ngIf=\"subline.objectKey != 'description'\">\r\n <span>{{\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n }}</span>\r\n <i\r\n *ngIf=\"\r\n subline.objectKey == 'inventoryCode' &&\r\n ROW_DATA['isSellerGroup'] &&\r\n gtGeneralConfig.component == 'RATING'\r\n \"\r\n class=\"mi mdi-info-outline seller-tooltip\"\r\n [ngbTooltip]=\"sellerHierarchyTooltip\"\r\n placement=\"bottom auto\"\r\n container=\"body\"\r\n [autoClose]=\"true\"\r\n triggers=\"manual\"\r\n (hidden)=\"closeTooltip()\"\r\n #info=\"ngbTooltip\"\r\n tooltipClass=\"hierarchy-tooltip remove-on-scroll-class\"\r\n (mouseenter)=\"\r\n bindTheValueToSellerGroupTooltip(\r\n ROW_DATA.sellerGroupHierarchy,\r\n info\r\n )\r\n \"\r\n >\r\n </i>\r\n\r\n <i\r\n *ngIf=\"\r\n subline.objectKey == 'displayBookedAverageRating' &&\r\n gtGeneralConfig.component == 'RATING' &&\r\n ROW_DATA['showRatingAverageIcon']\r\n \"\r\n class=\"mi mdi-info-outline seller-tooltip\"\r\n placement=\"bottom auto\"\r\n container=\"body\"\r\n [autoClose]=\"true\"\r\n (mouseenter)=\"\r\n setIsDifference(ROW_DATA.isDifferenceLessThan25Percent)\r\n \"\r\n tooltipClass=\"posted-avg-tooltip remove-on-scroll-class\"\r\n [ngbTooltip]=\"postedRatingDifference\"\r\n >\r\n </i>\r\n\r\n <i\r\n *ngIf=\"\r\n subline.objectKey == 'displayBookedAverageImpression' &&\r\n gtGeneralConfig.component == 'RATING' &&\r\n ROW_DATA['showImpressionAverageIcon']\r\n \"\r\n class=\"mi mdi-info-outline seller-tooltip\"\r\n placement=\"bottom auto\"\r\n container=\"body\"\r\n [autoClose]=\"true\"\r\n (mouseenter)=\"\r\n setIsDifference(ROW_DATA.isDifferenceLessThan25Percent)\r\n \"\r\n tooltipClass=\"posted-avg-tooltip remove-on-scroll-class\"\r\n [ngbTooltip]=\"postedImpDifference\"\r\n >\r\n </i>\r\n </ng-container>\r\n <ng-container *ngIf=\"subline.objectKey == 'description'\">\r\n <p\r\n *ngIf=\"\r\n ROW_DATA.descriptionMessage ||\r\n ROW_DATA.descriptionEmailReferenceNum\r\n \"\r\n >\r\n <ng-container *ngIf=\"ROW_DATA.descriptionMessage\">\r\n {{ ROW_DATA.descriptionMessage }}\r\n <br />\r\n </ng-container>\r\n <ng-container\r\n *ngIf=\"\r\n ROW_DATA.descriptionEmailReferenceNum != '-' &&\r\n ROW_DATA.descriptionEmailReferenceNum != ''\r\n \"\r\n >\r\n Email Ref: {{ ROW_DATA.descriptionEmailReferenceNum }}\r\n <br />\r\n </ng-container>\r\n </p>\r\n <a\r\n href=\"{{ ROW_DATA.descriptionDetailsUrl }}\"\r\n target=\"_blank\"\r\n *ngIf=\"\r\n ROW_DATA.descriptionDetailsUrlType === 'PDF' ||\r\n ROW_DATA.descriptionDetailsUrlType === 'EXCEL'\r\n \"\r\n >\r\n <button class=\"btn viewDetailsAndEmailBtn\">Download</button>\r\n </a>\r\n <ng-container\r\n *ngIf=\"ROW_DATA.activityname.toLowerCase() == 'order onboarded'\"\r\n >\r\n <a\r\n *ngIf=\"ROW_DATA.descriptionDetailsUrlType === 'LINK'\"\r\n (click)=\"viewDetailsClicked(ROW_DATA)\"\r\n >\r\n <button class=\"btn viewDetailsAndEmailBtn order-onboarded\">\r\n View details\r\n </button>\r\n </a>\r\n </ng-container>\r\n\r\n <a\r\n href=\"{{ ROW_DATA.descriptionEmailUrl }}\"\r\n target=\"_blank\"\r\n *ngIf=\"\r\n ROW_DATA.descriptionEmailUrl != '-' &&\r\n ROW_DATA.descriptionEmailUrl != ''\r\n \"\r\n >\r\n <button class=\"btn viewDetailsAndEmailBtn\">View email</button>\r\n </a>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"isNoDataToDisplaySubject$ | async\">\r\n <div>\r\n {{ null }}\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n </td>\r\n </ng-container>\r\n </ng-container>\r\n </table>\r\n </div>\r\n <anna-core-no-data-lib\r\n [width]=\"noDataWidth\"\r\n [marginTop]=\"marginTop\"\r\n *ngIf=\"isNoDataToDisplaySubject$ | async\"\r\n >\r\n </anna-core-no-data-lib>\r\n</div>\r\n\r\n<!-- Checkbox template -->\r\n<ng-template #filterTooltip>\r\n <anna-core-anna-column-checkbox-filter\r\n [tableData]=\"tableData\"\r\n [showFilterHeaderTabs]=\"showFilterTooltipTabs\"\r\n [isLurAndCsrComponent]=\"false\"\r\n [clonedTableData]=\"clonedTableData\"\r\n [filterTabObjects]=\"filterTabObjects\"\r\n (filterAppliedToTable)=\"filterApplied($event)\"\r\n (sortingAppliedToTable)=\"sortingApplied($event)\"\r\n (closeTooltip)=\"closeTooltip()\"\r\n >\r\n </anna-core-anna-column-checkbox-filter>\r\n</ng-template>\r\n\r\n<!-- Slider template -->\r\n<ng-template #sliderToolTip>\r\n <anna-core-anna-column-slider-filter\r\n [tableData]=\"tableData\"\r\n [showFilterHeaderTabs]=\"showFilterTooltipTabs\"\r\n [isLurAndCsrComponent]=\"false\"\r\n [clonedTableData]=\"clonedTableData\"\r\n [filterTabObjects]=\"filterTabObjects\"\r\n (filterAppliedToTable)=\"filterApplied($event)\"\r\n (sortingAppliedToTable)=\"sortingApplied($event)\"\r\n (closeTooltip)=\"closeTooltip()\"\r\n >\r\n </anna-core-anna-column-slider-filter>\r\n</ng-template>\r\n\r\n<!-- Date Picker Template -->\r\n<ng-template #datePickerTooltip>\r\n <anna-core-anna-column-date-range-filter\r\n [tableData]=\"tableData\"\r\n [showFilterHeaderTabs]=\"showFilterTooltipTabs\"\r\n [isLurAndCsrComponent]=\"false\"\r\n [clonedTableData]=\"clonedTableData\"\r\n [filterTabObjects]=\"filterTabObjects\"\r\n (filterAppliedToTable)=\"filterApplied($event)\"\r\n (sortingAppliedToTable)=\"sortingApplied($event)\"\r\n (closeTooltip)=\"closeTooltip()\"\r\n >\r\n </anna-core-anna-column-date-range-filter>\r\n</ng-template>\r\n\r\n<!-- Week Picker Template -->\r\n<ng-template #weekPickerToolTip>\r\n <!-- <div class=\"weekpicker-container\">\r\n <anna-core-week-calendar-filter-lib\r\n [week-calendar-config]=\"gtGeneralConfig.multiWeekPickerConfig\"\r\n (apply)=\"applyWeekFilter($event)\"\r\n [from-date]=\"calendarMinEnabledDate\"\r\n [to-date]=\"calendarMaxEnabledDate\"\r\n >\r\n </anna-core-week-calendar-filter-lib>\r\n </div> -->\r\n</ng-template>\r\n\r\n<!-- Time Filter Template -->\r\n<ng-template #timeFilterToolTip>\r\n <anna-core-anna-column-time-filter\r\n [tableData]=\"tableData\"\r\n [showFilterHeaderTabs]=\"showFilterTooltipTabs\"\r\n [isLurAndCsrComponent]=\"false\"\r\n [showAllTimeRangeCheckboxes]=\"showCheckboxesForTimeFilter\"\r\n [clonedTableData]=\"clonedTableData\"\r\n [filterTabObjects]=\"filterTabObjects\"\r\n (filterAppliedToTable)=\"filterApplied($event)\"\r\n (sortingAppliedToTable)=\"sortingApplied($event)\"\r\n (closeTooltip)=\"closeTooltip()\"\r\n >\r\n </anna-core-anna-column-time-filter>\r\n</ng-template>\r\n\r\n<ng-template #columnInfoTooltip>\r\n <p style=\"color: black; white-space: nowrap\">This preemption is rejected and not marked for credit.</p>\r\n</ng-template>\r\n\r\n<ng-template #ratingInfoTooltip>\r\n <p class=\"first-row\">Shows 'Booked Rating' for Preemptions & MakeGood Offered spot(s).</p>\r\n <p class=\"second-row\">Shows 'Projected Rating' for ADU Offered spot(s).</p>\r\n</ng-template>\r\n\r\n<ng-template #impsInfoTooltip>\r\n <p class=\"first-row\">Shows 'Booked IMPS' for Preemptions & MakeGood Offered spot(s).</p>\r\n <p class=\"second-row\">Shows 'Projected IMPS' for ADU Offered spot(s).</p>\r\n</ng-template>\r\n\r\n<ng-template #spotsColumnEquivalizationMessageTooltip>\r\n <p class=\"spot-column-tooltip-message\">\r\n This consists of equivalized spots and un-equivalized Paid Programs & un-equivalized Non-spots.\r\n </p>\r\n</ng-template>\r\n\r\n<ng-template #underDeliveryTooltip>\r\n <p class=\"spot-column-tooltip-message\">\r\n Indicates the Under-delivery percentage based on booked and posted RTG/IMPS.\r\n </p>\r\n</ng-template>\r\n\r\n<ng-template #overDeliveryTooltip>\r\n <p class=\"spot-column-tooltip-message\">\r\n Indicates the Over-delivery percentage based on booked and posted RTG/IMPS.\r\n </p>\r\n</ng-template>\r\n\r\n<ng-template #rateInfoTooltip>\r\n <p class=\"first-row\">Shows 'Booked Rate' for Preemptions & MakeGood Offered spot(s).</p>\r\n <p class=\"second-row\">Shows 'Projected $ Value' for ADU Offered spot(s).</p>\r\n</ng-template>\r\n\r\n<ng-template #sellerHierarchyTooltip>\r\n <ng-container *ngIf=\"sellerGroupHierarchy.length > 0\">\r\n <section class=\"hierarchy-table-container\">\r\n <table class=\"seller-hierarchy-table\">\r\n <thead>\r\n <tr>\r\n <th>#</th>\r\n <th>Inventory Codes</th>\r\n <th>Program/Description</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let data of sellerGroupHierarchy; let tooltipIndex = index\">\r\n <td>{{ tooltipIndex + 1 }}</td>\r\n <td>\r\n <span showEllipsisTextOnHover>{{ data.InventoryCode }}</span>\r\n </td>\r\n <td>\r\n <span showEllipsisTextOnHover>{{ data.Program }}</span>\r\n </td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n </section>\r\n </ng-container>\r\n <ng-container *ngIf=\"sellerGroupHierarchy.length == 0\">\r\n <span style=\"color: #000\">Seller group not available for this inventory code</span>\r\n </ng-container>\r\n</ng-template>\r\n\r\n<ng-template #lurViolationInfoTooltip>\r\n <p class=\"first-row\">The values are for the entire week.</p>\r\n</ng-template>\r\n\r\n<ng-template #postedRatingDifference>\r\n <p class=\"difference-text\">\r\n The difference between posted and booked average rating is\r\n {{ isDifferenceLessThan25Percent ? \"less\" : \"more\" }} than 25%.\r\n </p>\r\n</ng-template>\r\n\r\n<ng-template #postedImpDifference>\r\n <p class=\"difference-text\">\r\n The difference between posted and booked average impression is\r\n {{ isDifferenceLessThan25Percent ? \"less\" : \"more\" }} than 25%.\r\n </p>\r\n</ng-template>\r\n\r\n<ng-template #ongoingRevBookedColumnTooltip>\r\n <p>The Booked $ value, Spots, GRP, CPP, IMPS, CPM corresponds on the last permanent revision generated</p>\r\n</ng-template>\r\n\r\n<ng-template #completedRevBookedColumnTooltip>\r\n <p>The Booked $ value corresponds on the last permanent revision generated</p>\r\n</ng-template>\r\n\r\n<ng-template #avgBookedRate>\r\n <p>This is the booked average Rate</p>\r\n</ng-template>\r\n\r\n<ng-template #avgBookedRtg>\r\n <p>This is the booked average RTG</p>\r\n</ng-template>\r\n\r\n<ng-template #avgBookedImps>\r\n <p>This is the booked average IMP(\u2019000)</p>\r\n</ng-template>\r\n\r\n<ng-template #projectedImpsRtg>\r\n <p>\r\n All projections are derived from the sum of actual posted information until the last posted date and estimates\r\n for the remaining selected period.\r\n </p>\r\n</ng-template>\r\n\r\n<ng-template #automationTooltip>\r\n <p>\r\n Please get the order business rules approved to activate the order for automation. Only for the\r\n automation-activated orders, any approved MGs, ADUs, or credited spots on ANNA will be fed into the traffic\r\n system i.e. ANNA revisions.\r\n <!-- removed below line as part of enhancmennt in 14.0 releas -->\r\n <!-- Additionally, ANNA will only enter buyer revisions into traffic for the selected\r\n Medialine/WOC orders. -->\r\n </p>\r\n</ng-template>\r\n\r\n<ng-template #rebateImpact>\r\n <p>Rebate impact value is for the originally ordered spot length and is not equivalized.</p>\r\n</ng-template>\r\n\r\n<ng-template #lurViolationTotalRowToolTip>\r\n <ul>\r\n <li>\r\n <strong>POLITICAL RATE VIOLATIONS:</strong>\r\n Violations flagged when non-political spots are booked at a rate lower than the minimum booked rate for\r\n political candidates for the same week, Inventory Code and Revenue Class.\r\n </li>\r\n <li>\r\n <strong>CANDIDATE TO CANDIDATE VIOLATION:</strong>\r\n Violations flagged when political spots are booked at different rates to other political spots for the same\r\n week, Inventory Code and Revenue Class.\r\n </li>\r\n </ul>\r\n</ng-template>\r\n\r\n<ng-template #circularProgressBar>\r\n <circle-progress\r\n [percent]=\"percentDone\"\r\n [radius]=\"5\"\r\n [showTitle]=\"false\"\r\n [showUnits]=\"false\"\r\n [showSubtitle]=\"false\"\r\n [outerStrokeWidth]=\"3\"\r\n [innerStrokeWidth]=\"3\"\r\n [space]=\"-3\"\r\n [outerStrokeColor]=\"'#268bff'\"\r\n [innerStrokeColor]=\"'#d5d5d5'\"\r\n [animationDuration]=\"10\"\r\n ></circle-progress>\r\n</ng-template>\r\n\r\n<ng-template #userLoggedInDetails>\r\n <div class=\"tooltip-div-container\">\r\n <ng-container *ngFor=\"let data of textActionTooltip\">\r\n <span *ngIf=\"data.key != 'read'\">\r\n {{ data.key }} <b> {{ data.value }}</b>\r\n </span>\r\n <span *ngIf=\"data.key == 'read'\">\r\n {{ data.value }}\r\n </span>\r\n </ng-container>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #markAsReadTip>\r\n <div class=\"notification-tooltip-div-container\">\r\n <ng-container *ngFor=\"let data of textActionTooltip\">\r\n {{ data.value }}\r\n </ng-container>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #textActionTooltipTemplate>\r\n <ng-container *ngFor=\"let data of textActionTooltip\">\r\n {{ data.key }} <b> {{ data.value }}</b>\r\n </ng-container>\r\n</ng-template>\r\n\r\n<ng-template #tooltipContainingTableTemplate>\r\n <div\r\n *ngIf=\"tooltipContainingTable\"\r\n [innerHTML]=\"tooltipContainingTable.innerHtml\"\r\n class=\"notification-tooltip-div-container\"\r\n >\r\n <!-- <ul>\r\n <li *ngFor=\"let headerMsg of tooltipContainingTable.tableHeaderMsg\">\r\n <b> {{headerMsg}} </b>\r\n </li>\r\n </ul>\r\n\r\n <table class=\"tooltip-table\">\r\n <thead>\r\n <tr>\r\n <th *ngFor=\"let header of tooltipContainingTable.tooltipTableHeader\">\r\n {{ header}}\r\n </th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let rows of tooltipContainingTable.tooltipTableBody\">\r\n <td *ngFor=\"let data of rows\">\r\n {{ data }}\r\n </td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n\r\n <ul>\r\n <li style=\"margin-top:10px; padding:0\" *ngFor=\"let footerMsg of tooltipContainingTable.tableFooterMsg\">\r\n {{ footerMsg }} \r\n </li>\r\n </ul> -->\r\n </div>\r\n</ng-template>\r\n<!-- <ng-template #textActionTooltipTemplate>\r\n <ng-container *ngFor=\"let data of textActionTooltip\">\r\n {{ data.key }} <b> {{data.value}}</b>\r\n </ng-container>\r\n</ng-template> -->\r\n", styles: [".sort-btn{background:white;border:none;border-right:1px solid #1b88ff;text-decoration:underline;font-family:Roboto;font-size:14px;font-weight:400;font-stretch:normal;font-style:normal;line-height:1.07;letter-spacing:normal;color:#1b88ff;cursor:pointer;flex:1;text-align:center}.sort-btn:last-of-type{border-right:none}.sort-btn.active{color:#202b47;text-decoration:none}p.sort-container{margin-top:8px;padding-bottom:8px;border-bottom:1px solid #e6e6e6;margin-bottom:0;display:flex}::ng-deep .tooltip-inner{max-height:22rem;background-color:#fff;border:1px solid white;border-radius:5px;box-shadow:0 2px 2px #0000003d,0 0 2px #0000001f;max-width:251px;width:100%;padding:0!important}::ng-deep .tooltip-inner div.radio-container{flex-wrap:wrap}::ng-deep .md-drppicker{box-shadow:unset!important}::ng-deep .available{color:#999}::ng-deep .bs-tooltip-bottom .arrow:before{border-bottom-color:#fff!important}::ng-deep .bs-tooltip-left .arrow:before{border-left-color:#fff!important}::ng-deep .tooltip.show{opacity:1}.input{text-align:left;margin:5px 10px 5px 5px;display:flex;align-items:center;width:230px;white-space:nowrap}.data{color:#000;font-weight:700;margin-left:5px;margin-right:5px}span.data{display:inline-block;text-overflow:ellipsis;white-space:pre;width:100%;overflow:hidden}.check-box{font-size:14px;cursor:pointer;position:relative;top:-1px}span.mdi-filter.active{color:#000;opacity:1!important;pointer-events:all!important}p{margin-bottom:0;line-height:initial}span.mdi-filter{color:#cbcbcb}::ng-deep .ngx-slider-pointer{top:-5px!important;width:12px!important;height:12px!important;background:#bdbdbd!important;border:1px solid #ffffff!important;box-shadow:0 1px 3px #0000004d!important;border-radius:16px!important}input:focus{outline:none}input::placeholder{color:#c8c8c8}.cancel-btn{background:#c7e1ff;color:#268bff}.apply-btn{background:#268bff;color:#fff;margin-left:.3125rem}div.radio-container{display:flex;white-space:nowrap;justify-content:space-between;background-color:#f4f4f4;border-radius:.125rem;margin:.4375rem .4375rem .25rem}div.radio-container div{flex:1;width:50%}div.radio-container div.full-width{width:100%}div.radio-container input{position:relative;top:.125rem;margin-right:.25rem}div.radio-container label{font-family:Roboto;font-size:.875rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:1.29;letter-spacing:0;color:#4a4a4a;margin:0;padding-left:.125rem}div.radio-container label:first-of-type{margin-right:.188rem}div.radio-container input[type=radio]{appearance:none;display:inline-block;width:.9375rem;height:.9375rem;padding:.125rem;background-clip:content-box;border:.125rem solid #268bff;background-color:transparent;border-radius:50%}div.radio-container input[type=radio]:checked{background-color:#268bff}.checkbox-filter-buttons-container{padding:0 8px!important}.buttons-container{display:flex;margin:0px auto .4375rem;justify-content:center;padding:0 12px}.buttons-container .button{padding:0 10px;width:100%;margin:8px 0 0;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.buttons-container button:last-of-type{background-color:#268bff;color:#fff;margin-left:.5rem}.buttons-container button.disabled{background:#bdbdbd;opacity:.5;color:#4a4a4a}.button{display:inline-block;margin:8px 4px 0 8px;padding:0 16px;border-radius:4px;text-align:center;outline:none;font-family:Roboto;font-size:.75rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:1.67;letter-spacing:normal;border:none;color:#268bff;background-color:#e5f1ff}.search-box{display:flex;align-items:center;color:#c8c8c8;border:1px solid #e6e6e6;border-radius:.125rem;margin:.25rem .4375rem .188rem;height:1.5rem;padding:.188rem 8px .188rem .5rem}.search-box .search-bar-close{margin-left:auto;float:right}.search-icon{margin:0 4px 0 0;font-size:1.125rem;color:#9b9b9b}.filter-icon{justify-content:right;margin-left:auto;color:#d4d4d4;color:#a1a1a1;font-size:16px;cursor:pointer}.data{margin:0 13px 0 8px;font-family:Roboto;font-size:.875rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:1.86;letter-spacing:\"\";color:#4a4a4a}.search-input{margin:1px 0 1px 4px;font-family:Roboto;font-size:.875rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal;color:#c8c8c8;width:calc(100% - 38px)}.check-box{color:#268bff}.tooltip-data-container{overflow-y:scroll;max-height:8rem}.searchbar{width:100%;display:flex;justify-content:flex-end;align-items:flex-end}.clear-button{opacity:.5;font-family:Roboto;font-size:.9375rem;font-weight:500;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal;text-decoration:underline;border:none;background-color:#fff;color:#4a4a4a;margin-left:.625rem;padding:0}.clear-button:focus{outline:none;box-shadow:none}.unchecked{color:#268bff}cdk-virtual-scroll-viewport.dropdown-data-container{max-height:12.3rem;width:100%;overflow-y:auto;overflow-x:hidden}cdk-virtual-scroll-viewport.dropdown-data-container p.input{margin-left:0}cdk-virtual-scroll-viewport.dropdown-data-container p.input span.mi{padding-left:.4375rem}cdk-virtual-scroll-viewport.dropdown-data-container p.input:hover{background-color:#ebebeb;cursor:pointer}cdk-virtual-scroll-viewport.dropdown-data-container::-webkit-scrollbar{width:.188rem}cdk-virtual-scroll-viewport.dropdown-data-container::-webkit-scrollbar-thumb{color:#d3d3d3;background:lightgray}section.min-maxContainer{display:flex;justify-content:center;margin-bottom:-.125rem;margin-top:.5rem;width:100%}section.min-maxContainer input{width:30%;height:1.875rem;border:1px solid lightgray;color:gray}section.min-maxContainer span{display:inline-block;padding-left:.5rem;padding-right:.5rem;position:relative;top:.3125rem;color:#666}.time-container{width:100%;display:flex;padding:0 .75rem}.time-container input.form-control:disabled{background-color:#fff;width:2.813rem}.time-container input.numberInput:focus{box-shadow:none;border-color:#c2cfd6}.time-container .dot{color:#cbcbcb;position:relative;left:-7px;font-size:17px}.time-container div.arrow-container{flex-direction:column;display:flex;margin-top:.375rem;width:9px;height:18px;margin-right:1.1875rem}.time-container div.arrow-container i{color:#000;cursor:pointer;max-height:9px;font-size:25px;width:10px}.time-container div.arrow-container i:before{width:0;height:0;pointer-events:none;position:relative;left:-9px;top:-11px}.mdi-filter{cursor:pointer}.time-label-container{display:flex;justify-content:flex-start}.time-label-container label{margin-bottom:0;color:#4a4a4a;margin-top:.125rem;margin-left:.625rem;font-weight:700}.time-heading{color:#000;font-size:.8125rem;text-align:left;padding-left:.625rem;margin-top:.625rem;font-weight:700}.column-clear-all{width:94%;text-align:center;border:none;font-size:14px;background:none;text-decoration:underline;color:#268bff}.checkbox-container{display:flex;padding-inline:.625rem}.checkbox-container .data{text-align:left}.checkbox-container:first-of-type{margin-top:.625rem;font-weight:500}.column-clear-all{width:94%;text-align:center;border:none;background:none;text-decoration:underline;color:#268bff}.column-clear-all:disabled{opacity:.5;color:#4a4a4a;font-weight:400}.column-clear-all.align-center{text-align:center}span.mdi-filter-variant.disabled{pointer-events:none;opacity:.5}.datepicker-container{width:100%}span.mdi-filter-variant{color:#cbcbcb;cursor:pointer;font-size:.875rem}span.mdi-filter-variant.active{color:#000}p.filter-tab{font-family:Roboto;font-size:14px;font-weight:400;font-stretch:normal;font-style:normal;line-height:1.29;letter-spacing:normal;color:#1b88ff;border-radius:5px;background-color:#f4f4f4;padding-inline:8px;cursor:pointer;overflow:hidden;text-align:center;text-overflow:ellipsis}p.filter-tab.active{color:#fff;background-color:#1b88ff}button.filter-text-btn{background:white;text-decoration:underline;font-family:Roboto;font-size:14px;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal;border:none;color:#268bff;margin-inline:4px;margin-top:2px}button.filter-text-btn:disabled{color:#b1b1b1;cursor:not-allowed}::ng-deep .non-edit-datepicker-tooltip .tooltip-inner{max-width:310px!important;width:283px!important;overflow-y:initial!important;padding:0!important}input.slider-text::-webkit-outer-spin-button,input.slider-text::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input.slider-text{-moz-appearance:textfield}input.slider-text.red-border{border:1px solid #f44336!important}::ng-deep .checkbox-sort p.sort-container{margin-top:8px!important;padding-bottom:8px!important}i.mdi-close{cursor:pointer}i.mdi-close.disable-close-icon{pointer-events:none;cursor:not-allowed}input.error-border{border:1px solid #f44336!important}::ng-deep .non-edit-checkbox-tooltip .tooltip-inner{width:238px!important;padding:0!important}::ng-deep .non-edit-slider-tooltip .tooltip-inner{width:238px!important;padding:0!important}::ng-deep .non-edit-time-tooltip .tooltip-inner{width:250px!important;padding:0!important}::ng-deep .non-edit-time-tooltip.bs-tooltip-start{padding:.4rem}::ng-deep .non-edit-time-tooltip.bs-tooltip-start .tooltip-arrow{right:0;top:5px!important;width:var(--bs-tooltip-arrow-height);height:var(--bs-tooltip-arrow-width)}::ng-deep .non-edit-time-tooltip.bs-tooltip-start .tooltip-arrow:before{border-left-color:#fff;left:-1px;border-width:calc(var(--bs-tooltip-arrow-width) * .5) 0 calc(var(--bs-tooltip-arrow-width) * .5) var(--bs-tooltip-arrow-height)}::ng-deep .no-bottom-border p.sort-container{border-bottom:none!important}::ng-deep .ngx-slider-pointer-min:after{display:none}::ng-deep .ngx-slider-pointer-max:after{display:none}::ng-deep .ngx-slider span.ngx-slider-pointer{width:12px;height:12px;top:-5px;background-color:#bdbdbd}::ng-deep .ngx-slider span.ngx-slider-bar{height:3px;background:#ededed}::ng-deep .ngx-slider span.ngx-slider-selection{background:#bdbdbd}::ng-deep .ngx-slider span.ngx-slider-bubble{bottom:-22px;font-size:12px;color:#333}::ng-deep .show-min.ngx-slider span.ngx-slider-model-value{background:white;box-shadow:0 6px 10px #0000004d,0 2px 2px #0003}::ng-deep .show-max.ngx-slider span.ngx-slider-model-high{background:white;box-shadow:none}::ng-deep .ngx-slider span.ngx-slider-combined{background:white;box-shadow:0 6px 10px #0000004d,0 2px 2px #0003}::ng-deep .ngx-slider{top:10px!important;margin:5px 0 2px!important}::ng-deep .ngx-slider-animate{top:0!important}.sidebar-slider{margin-bottom:35px!important;margin-left:5px;margin-right:5px}.slider-placeholder{height:14px}::ng-deep .filter-calendar select.form-select:focus{border-color:#c2cfd6;box-shadow:none}::ng-deep .filter-calendar select.form-select{background-color:#fff}.no-data-case{padding-left:.4375rem!important;font-size:.875rem!important;margin-top:10px!important;cursor:pointer}.check-mark,.unread-mark{cursor:pointer}.on-hover:hover .unread-mark,.notificationHover .check-mark{opacity:0;cursor:pointer}.on-hover:hover .check-mark{opacity:1;cursor:pointer}:host ::ng-deep .gt{table-layout:fixed;margin-bottom:0;width:100%}:host ::ng-deep .gt th,:host ::ng-deep .gt td{padding:2px 8px;line-height:normal}:host ::ng-deep .gt thead tr th .upper-label{font-family:Roboto;font-size:.6875rem;font-weight:500;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:.3px;color:#4a4a4a;margin-bottom:0}:host ::ng-deep .gt thead tr th .lower-label{font-family:Roboto;font-size:.6875rem;font-weight:500;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:.3px;color:#a7a7a7;margin-bottom:0}:host ::ng-deep .gt thead tr th{background-color:#ededed;position:sticky;position:-webkit-sticky;top:0;border-top:none!important;border-bottom:none!important;outline:none!important;box-shadow:inset 0 1px #d4d4d4,inset 0 -1px #d4d4d4,inset -1px 0 #d4d4d4}:host ::ng-deep .gt thead tr th br{display:block;content:\"\";margin-top:-8px}:host ::ng-deep .gt thead tr th div.row{display:flex;flex-wrap:nowrap;justify-content:space-between;align-items:center;width:max-content}:host ::ng-deep .gt thead tr th div.sort-filter-container{display:flex;flex-wrap:nowrap;align-items:center;margin-left:.25rem;margin-right:auto}:host ::ng-deep .gt thead tr th span.mdi-filter-variant{font-size:13px!important;top:-1px!important;position:relative}:host ::ng-deep .gt thead tr th:first-of-type{box-shadow:inset 0 1px #d4d4d4,inset 0 -1px #d4d4d4,inset -1px 0 #d4d4d4,inset 1px 0 #d4d4d4}:host ::ng-deep .gt tbody tr td:first-of-type{box-shadow:inset 1px 0 #d4d4d4,inset -1px 0 #d4d4d4,inset 0 -1px #d4d4d4;border:none}:host ::ng-deep .gt tbody tr td:nth-of-type(n + 2){box-shadow:inset -1px 0 #d4d4d4,inset 0 -1px #d4d4d4;border:none}:host ::ng-deep .gt tbody tr td .upper-label{font-family:Roboto;font-size:.75rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:0px;color:#000;display:inline-block;width:90%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}:host ::ng-deep .gt tbody tr td .lower-label{font-family:Roboto;font-size:.75rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:0px;color:#a7a7a7;display:inline-block;width:90%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}:host ::ng-deep .gt tbody tr br{display:block;content:\"\";margin-top:-8px}:host ::ng-deep .gt tbody tr:nth-of-type(1) td{border-top:none!important}:host ::ng-deep .gt .custom-column-checkbox-checked,:host ::ng-deep .gt .custom-column-checkbox-unchecked{font-size:.875rem;cursor:pointer}:host ::ng-deep .gt .custom-column-checkbox-checked{color:#268bff}:host ::ng-deep .gt .custom-column-checkbox-unchecked{color:#4a4a4a}:host ::ng-deep .bottom-border .gt tbody tr:last-of-type td:first-of-type{box-shadow:inset 1px 0 #d4d4d4,inset -1px 0 #d4d4d4}:host ::ng-deep .bottom-border .gt tbody tr:last-of-type td:nth-of-type(n + 2){box-shadow:inset -1px 0 #d4d4d4}.table-container{overflow-x:auto;overflow-y:auto}.rowSelectCheckbox,#selectAllRowsCheckbox{cursor:pointer}.disable-checkbox{color:#dedede!important;pointer-events:none!important}.mdi-warning{color:#f3c639;font-size:16px;line-height:28px}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{opacity:1}.redcolor-status{color:#c62a2a}#no-filter-space{width:.875rem}::ng-deep .mat-button-toggle-appearance-standard .mat-button-toggle-label-content{line-height:1.875rem!important;width:2.625rem;padding:0 .625rem}input.numberInput{margin-right:-.8125rem;padding:0 0 0 .625rem;height:1.875rem}::ng-deep .mat-button-toggle-checked{background-color:#268bff!important;color:#fff!important}::ng-deep .mat-button-toggle-group-appearance-standard{border-radius:0}.hidden{display:none}.no-data-div{margin-top:2.5px}.no-data-div label{margin:0;width:auto;font-weight:500;background-color:#d3d3d3;padding:.3125rem 1.125rem;border-radius:.25rem}.column-values:nth-of-type(2){color:#a7a7a7!important}.custom-column-checkbox-checked,.custom-column-checkbox-unchecked{font-size:.875rem;cursor:pointer}.custom-column-checkbox-checked{color:#268bff}.custom-column-checkbox-unchecked{color:#4a4a4a}.time-filter-checkboxes>div>p{color:#151b1e}::ng-deep .margin-bottom-zero .mat-radio-label{margin-bottom:0}:host ::ng-deep mat-radio-group br{margin-top:0!important}:host ::ng-deep mat-radio-group mat-radio-button .mdc-radio__background{width:var(--mat-radio-size);height:var(--mat-radio-size)}:host ::ng-deep mat-radio-group mat-radio-button .mdc-radio__inner-circle{border-width:calc(var(--mat-radio-size) / 2)}:host ::ng-deep mat-radio-group mat-radio-button .mdc-form-field>label{margin:0 0 0 4px;padding:0;top:-2px;position:relative}:host ::ng-deep mat-radio-group mat-radio-button .mdc-radio--disabled+label{color:var(--primary-text-color-dark)!important}:host ::ng-deep mat-radio-group mat-radio-button.mat-mdc-radio-button .mdc-form-field .mdc-radio{padding:0}:host ::ng-deep mat-radio-group mat-radio-button .mdc-form-field>label{left:-94px;font-size:12px;color:#4a4a4a;position:relative}::ng-deep .reject.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-outer-circle{border-color:#ff0}::ng-deep .reject.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-inner-circle{background-color:#ff0}::ng-deep .resubmit.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-outer-circle{border-color:#ff0}::ng-deep .resubmit.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-inner-circle{background-color:#ff0}::ng-deep .noAction.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-outer-circle{border-color:green}::ng-deep .noAction.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-inner-circle{background-color:green}::ng-deep .approve.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-outer-circle{border-color:green}::ng-deep .approve.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-inner-circle{background-color:green}::ng-deep .credit.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-outer-circle{border-color:red}::ng-deep .credit.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-inner-circle{background-color:red}::ng-deep .mat-radio-button.mat-radio-disabled .mat-radio-outer-circle{border-color:#00000061!important}::ng-deep .mat-radio-button.mat-radio-disabled.mat-radio-checked .mat-radio-inner-circle{background-color:#00000061!important}::ng-deep tr.white-background-row{background:white}::ng-deep tr.gray-background-row{background:rgba(233,233,233,.5)!important}.remarks-tooltip,.mdi-information,.mdi-information-outline,.seller-tooltip{font-size:.875rem;color:#268bff;position:relative;top:.1875rem;cursor:pointer}.seller-tooltip{top:-1px;float:right}::ng-deep .remarks-info-tooltip .tooltip-inner{max-width:19.25rem!important}.rating-icon,.lur-violation-icon{color:#268bff;cursor:pointer;position:relative;left:-2px}::ng-deep .rating-info-tooltip .tooltip-inner{max-width:800px!important}.spots-info-icon{color:#268bff;cursor:pointer;margin:1px 2px 0 -14px}.spots-info-icon-ol{color:#268bff;cursor:pointer;margin:1px 4px 0 -2px}::ng-deep .spot-info-tooltip .tooltip-inner{position:relative;max-width:220px!important;background:#fff;word-break:break-word;display:flex}::ng-deep .spot-info-tooltip-for-orderlisting-table .tooltip-inner{max-width:220px!important;background:#fff;word-break:break-word;display:flex}p.first-row{padding:.5rem .5rem 0;color:#000;white-space:nowrap;text-align:left}p.second-row{padding:2px .5rem .5rem;color:#000;white-space:nowrap;text-align:left}::ng-deep .gt-total-row-tooltip{opacity:1!important}::ng-deep .gt-total-row-tooltip .tooltip-inner{color:#000;box-shadow:0 6px 10px #0000004d,0 2px 2px #0003;background-color:#fff;padding:4px!important;width:100%;border-radius:2px!important}::ng-deep .gt-total-row-tooltip .arrow:before{border-top-color:#fff!important}.info-label{margin-left:4px;color:#268bff;vertical-align:text-top}::ng-deep .hierarchy-tooltip{max-width:-moz-fit-content;max-width:fit-content;width:310px!important}::ng-deep .hierarchy-tooltip .tooltip-inner{padding:4px!important;max-width:22.75rem;max-height:11.25rem}table.seller-hierarchy-table{table-layout:fixed}table.seller-hierarchy-table tr th{font-family:Roboto;font-size:.75rem;font-weight:500;font-stretch:normal;font-style:normal;line-height:1.67;letter-spacing:normal;color:#5e5e5e;white-space:nowrap;background:#ededed;position:sticky;box-shadow:inset 0 1px #d4d4d4;top:0;z-index:1}table.seller-hierarchy-table tr th:nth-child(1){width:20px}table.seller-hierarchy-table tr th:first-of-type,table.seller-hierarchy-table tr td:first-of-type{width:20px;border-left:1px solid #d4d4d4}table.seller-hierarchy-table tr th:last-of-type,table.seller-hierarchy-table tr td:last-of-type{border-right:1px solid #d4d4d4;width:7.875rem!important}table.seller-hierarchy-table tr th:nth-of-type(2){width:7.75rem!important}table.seller-hierarchy-table tr td{font-family:Roboto;font-size:.75rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal;color:#4a4a4a;box-shadow:none!important;border-top:1px solid #d4d4d4;border-bottom:1px solid #d4d4d4}table.seller-hierarchy-table tr td:nth-of-type(2),table.seller-hierarchy-table tr td:nth-of-type(3){padding-top:.25rem}table.seller-hierarchy-table tr td span{display:inline-block;width:90%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;position:relative}section.hierarchy-table-container{max-height:8.75rem;overflow:auto}section.hierarchy-table-container::-webkit-scrollbar-track{margin-top:1.5rem}.difference-text{padding:.5rem;color:#000;text-align:left}::ng-deep .posted-avg-tooltip .tooltip-inner{width:13.8125rem!important}::ng-deep .drrBooked-info-tooltip{transform:translate(26px,6px)}::ng-deep .drrBooked-info-tooltip .tooltip-inner{max-width:307px!important;width:242px!important;background:#fff;word-break:break-word;display:flex;padding:4px!important;text-align:left}::ng-deep .drrBooked-info-tooltip .tooltip-inner p{color:#000}::ng-deep .drrBooked-info-tooltip .arrow:before{border-right-color:#fff!important}.clickable-data{cursor:pointer;color:#268bff!important;display:flex!important;align-items:center}.clickable-data .spot-details-download-icons{font-size:12px}.disabled-clickable-data{pointer-events:none;color:#d4d4d4!important}.spot-column-tooltip-message{color:#000;width:max-content;text-align:left}div.spinner-for-button-directive{position:relative;left:-1px}.clickable-row table tr.mat-row td{cursor:pointer!important}.tooltip-div-container{text-align:left!important;padding:12px 4px;color:#4a4a4a!important;font-size:12px!important;font-family:Roboto;font-size:12px;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}.notification-tooltip-div-container{text-align:left!important;padding:6px 8px;color:#4a4a4a!important;font-size:12px!important;font-family:Roboto;font-size:12px;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}.mdi-information,.mdi-information-outline{left:3px;top:1px}.mdi-information-outline{position:static}::ng-deep .team-user-tooltip.bs-tooltip-top .arrow:before{border-top:6px solid white}::ng-deep .team-user-tooltip.bs-tooltip-left .arrow:before{border-left:6px solid white}::ng-deep .team-user-tooltip.bs-tooltip-bottom .arrow:before{border-bottom:6px solid white}::ng-deep .team-user-tooltip.bs-tooltip-right .arrow:before{border-right:5px solid white}::ng-deep .team-user-tooltip .tooltip-inner{opacity:1!important;width:-moz-fit-content!important;width:fit-content!important;max-width:520px;border-radius:2px;padding:0 4px!important}::ng-deep .team-user-tooltip .tooltip-inner .tooltip-inner{color:#4a4a4a;text-align:left;padding:8px!important;border-radius:2px;background:white!important;box-shadow:0 6px 10px #0000004d,0 2px 2px #0003;font-family:Roboto;font-size:12px;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}::ng-deep .team-user-tooltip .tooltip-inner.bs-tooltip-top .arrow:before{border-top:6px solid white}::ng-deep .team-user-tooltip .tooltip-inner.bs-tooltip-left .arrow:before{border-left:6px solid white}::ng-deep .team-user-tooltip .tooltip-inner.bs-tooltip-bottom .arrow:before{border-bottom:6px solid white}::ng-deep .team-user-tooltip .tooltip-inner.bs-tooltip-right .arrow:before{border-right:5px solid white}::ng-deep .gt-icon-column-tooltip{opacity:1!important}::ng-deep .gt-icon-column-tooltip .tooltip-inner{color:#4a4a4a;text-align:left;padding:8px!important;border-radius:2px;background:white!important;box-shadow:0 6px 10px #0000004d,0 2px 2px #0003;font-family:Roboto;font-size:12px;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}::ng-deep .gt-icon-column-tooltip.bs-tooltip-top .arrow:before{border-top:6px solid white}::ng-deep .gt-icon-column-tooltip.bs-tooltip-left .arrow:before{border-left:6px solid white}::ng-deep .gt-icon-column-tooltip.bs-tooltip-bottom .arrow:before{border-bottom:6px solid white}::ng-deep .gt-icon-column-tooltip.bs-tooltip-right .arrow:before{border-right:5px solid white}::ng-deep .gt-icon-column-tooltip .tooltip-inner{width:100%}::ng-deep .tooltip-containing-table{opacity:1!important}::ng-deep .tooltip-containing-table .tooltip-inner{color:#4a4a4a;text-align:left;padding:8px!important;border-radius:2px;background:white!important;box-shadow:0 6px 10px #0000004d,0 2px 2px #0003;font-family:Roboto;font-size:12px;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}::ng-deep .tooltip-containing-table.bs-tooltip-top .arrow:before{border-top:6px solid white}::ng-deep .tooltip-containing-table.bs-tooltip-left .arrow:before{border-left:6px solid white}::ng-deep .tooltip-containing-table.bs-tooltip-bottom .arrow:before{border-bottom:6px solid white}::ng-deep .tooltip-containing-table.bs-tooltip-right .arrow:before{border-right:5px solid white}::ng-deep .tooltip-containing-table li{margin:0!important;padding:0!important}::ng-deep .tooltip-containing-table ul{margin:0!important;padding-left:8px!important}::ng-deep .tooltip-containing-table .tooltip-inner{width:100%;max-width:230px}table.tooltip-table{table-layout:fixed;margin:4px 0 0;width:100%}table.tooltip-table th,table.tooltip-table td{padding:2px 8px;line-height:normal}table.tooltip-table thead tr th:first-of-type{box-shadow:inset 0 1px #d4d4d4,inset 0 -1px #d4d4d4,inset -1px 0 #d4d4d4,inset 1px 0 #d4d4d4!important;border:none}table.tooltip-table thead tr th{color:#5e5e5e!important;font-size:12px;font-weight:500;font-family:Roboto;line-height:1.67;background-color:#ededed;border-top:none!important;border-bottom:none!important;outline:none!important;box-shadow:inset 0 1px #d4d4d4,inset 0 -1px #d4d4d4,inset -1px 0 #d4d4d4}table.tooltip-table thead tr th div.row{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center}table.tooltip-table tbody tr td{color:#5e5e5e!important;font-size:12px;font-weight:500;font-family:Roboto;line-height:1.67}table.tooltip-table tbody tr td:first-of-type{box-shadow:inset 1px 0 #d4d4d4,inset -1px 0 #d4d4d4,inset 0 -1px #d4d4d4;border:none}table.tooltip-table tbody tr td:nth-of-type(n + 2){box-shadow:inset -1px 0 #d4d4d4,inset 0 -1px #d4d4d4;border:none}.bottom-border{border-bottom:1px solid #d4d4d4!important}i.disabled{pointer-events:none!important}\n"], dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: MatTableModule }, { kind: "component", type: i4.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i4.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i4.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i4.MatColumnDef, selector: "[matColumnDef]", inputs: ["sticky", "matColumnDef"] }, { kind: "directive", type: i4.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i4.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i4.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i4.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "component", type: i4.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i4.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: NgbTooltip, selector: "[ngbTooltip]", inputs: ["animation", "autoClose", "placement", "popperOptions", "triggers", "positionTarget", "container", "disableTooltip", "tooltipClass", "openDelay", "closeDelay", "ngbTooltip"], outputs: ["shown", "hidden"], exportAs: ["ngbTooltip"] }, { kind: "ngmodule", type: NgxSkeletonLoaderModule }, { kind: "component", type: i5.NgxSkeletonLoaderComponent, selector: "ngx-skeleton-loader", inputs: ["appearance", "animation", "theme", "loadingText", "count", "ariaLabel"] }, { kind: "directive", type: showEllipsisTextOnHoverDirective, selector: "[showEllipsisTextOnHover]" }, { kind: "directive", type: NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "component", type: AnnaIconColumnComponent, selector: "anna-core-anna-icon-column", inputs: ["componentName", "iconToShow", "dataObject"], outputs: ["onColumnIconClicked"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i6.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: MatRadioModule }, { kind: "directive", type: i7.MatRadioGroup, selector: "mat-radio-group", exportAs: ["matRadioGroup"] }, { kind: "component", type: i7.MatRadioButton, selector: "mat-radio-button", inputs: ["disableRipple", "tabIndex"], exportAs: ["matRadioButton"] }, { kind: "directive", type: NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "component", type: AnnaNoDataComponent, selector: "anna-core-no-data-lib", inputs: ["width", "marginTop"] }, { kind: "component", type: AnnaColumnCheckboxFilterComponent, selector: "anna-core-anna-column-checkbox-filter", inputs: ["showFilterHeaderTabs", "isLurAndCsrComponent", "tableData", "clonedTableData", "filterTabObjects"], outputs: ["filterAppliedToTable", "sortingAppliedToTable", "getSortType", "closeTooltip"] }, { kind: "component", type: AnnaColumnSliderFilterComponent, selector: "anna-core-anna-column-slider-filter", inputs: ["filterTabObjects", "isLurAndCsrComponent", "tableData", "showFilterHeaderTabs", "clonedTableData"], outputs: ["closeTooltip", "filterAppliedToTable", "getSortType", "sortingAppliedToTable"] }, { kind: "component", type: AnnaColumnDateRangeFilterComponent, selector: "anna-core-anna-column-date-range-filter", inputs: ["tableData", "clonedTableData", "filterTabObjects", "isLurAndCsrComponent", "showFilterHeaderTabs"], outputs: ["filterAppliedToTable", "sortingAppliedToTable", "getSortType", "closeTooltip"] }, { kind: "component", type: AnnaColumnTimeFilterComponent, selector: "anna-core-anna-column-time-filter", inputs: ["tableData", "clonedTableData", "filterTabObjects", "showFilterHeaderTabs", "showAllTimeRangeCheckboxes", "isLurAndCsrComponent", "gtGeneralConfig", "showClearAllFilter", "startFromText", "endToText", "isSortAndFilterAbsent"], outputs: ["timeChanges", "filterAppliedToTable", "sortingAppliedToTable", "getSortType", "closeTooltip"] }, { kind: "ngmodule", type: NgCircleProgressModule }, { kind: "component", type: i8.CircleProgressComponent, selector: "circle-progress", inputs: ["name", "class", "backgroundGradient", "backgroundColor", "backgroundGradientStopColor", "backgroundOpacity", "backgroundStroke", "backgroundStrokeWidth", "backgroundPadding", "radius", "space", "percent", "toFixed", "maxPercent", "renderOnClick", "units", "unitsFontSize", "unitsFontWeight", "unitsColor", "outerStrokeGradient", "outerStrokeWidth", "outerStrokeColor", "outerStrokeGradientStopColor", "outerStrokeLinecap", "innerStrokeColor", "innerStrokeWidth", "titleFormat", "title", "titleColor", "titleFontSize", "titleFontWeight", "subtitleFormat", "subtitle", "subtitleColor", "subtitleFontSize", "subtitleFontWeight", "imageSrc", "imageHeight", "imageWidth", "animation", "animateTitle", "animateSubtitle", "animationDuration", "showTitle", "showSubtitle", "showUnits", "showImage", "showBackground", "showInnerStroke", "clockwise", "responsive", "startFromZero", "showZeroOuterStroke", "lazy", "options"], outputs: ["onClick"] }, { kind: "pipe", type: AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
749
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: AnnaNonEditableGenericTableComponent, decorators: [{
750
- type: Component,
751
- args: [{ selector: 'anna-core-non-editable-generic-table-lib', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
752
- NgClass,
753
- NgStyle,
754
- MatTableModule,
755
- NgFor,
756
- NgIf,
757
- NgTemplateOutlet,
758
- NgbTooltip,
759
- NgxSkeletonLoaderModule,
760
- showEllipsisTextOnHoverDirective,
761
- NgSwitch,
762
- NgSwitchCase,
763
- AnnaIconColumnComponent,
764
- FormsModule,
765
- MatRadioModule,
766
- NgSwitchDefault,
767
- AnnaNoDataComponent,
768
- AnnaColumnCheckboxFilterComponent,
769
- AnnaColumnSliderFilterComponent,
770
- AnnaColumnDateRangeFilterComponent,
771
- AnnaColumnTimeFilterComponent,
772
- NgCircleProgressModule,
773
- AsyncPipe,
774
- ], template: "<div\r\n id=\"generic-table-conatiner\"\r\n class=\"table-container {{ gtGeneralConfig?.tableOuterContainerName }} {{ tableBottomBorderClass }}\"\r\n [ngClass]=\"{\r\n 'scroll-left-shadow-effect': isScrolledLeft,\r\n 'scroll-right-shadow-effect': !isScrollEnded,\r\n 'clickable-row': clickableRow,\r\n 'no-data-table': (isNoDataToDisplaySubject$ | async)\r\n }\"\r\n (scroll)=\"onTableContainerScroll($event)\"\r\n>\r\n <div\r\n [class]=\"gtGeneralConfig.tableContainerName\"\r\n class=\"horizontal-scroll-for-table-container\"\r\n [ngStyle]=\"{\r\n height:\r\n tableData.length < maximumRowsWhichCanBeRenderedWithoutScroll\r\n ? 'calc(' +\r\n (gtDimension.rowHeight * tableData.length +\r\n (!tableData.length || !gtGeneralConfig.totalRow\r\n ? gtDimension.headerHeight\r\n : gtDimension.headerHeight + gtDimension.rowHeight)) +\r\n 'px)'\r\n : gtDimension.tableHeight\r\n }\"\r\n >\r\n <table\r\n class=\"gt\"\r\n [ngClass]=\"tableClass\"\r\n mat-table\r\n [dataSource]=\"renderedData\"\r\n >\r\n <tr\r\n class=\"header-row\"\r\n mat-header-row\r\n *matHeaderRowDef=\"tableColumns; sticky: true\"\r\n [style.height.px]=\"gtDimension.headerHeight\"\r\n ></tr>\r\n <tr\r\n class=\"total-row\"\r\n mat-header-row\r\n [style.height.px]=\"gtDimension.rowHeight\"\r\n *matHeaderRowDef=\"totalRowColumns; sticky: true\"\r\n [class.hidden]=\"\r\n showSkeletonLoading ||\r\n (!showSkeletonLoading && !tableData.length) ||\r\n (isNoDataToDisplaySubject$ | async) ||\r\n (!showSkeletonLoading && !gtGeneralConfig.totalRow)\r\n \"\r\n ></tr>\r\n <tr\r\n [class]=\"rowData.gtClass\"\r\n [ngClass]=\"{ 'no-border-tr': (isNoDataToDisplaySubject$ | async) }\"\r\n mat-row\r\n *matRowDef=\"let rowData; columns: tableColumns\"\r\n [style.height.px]=\"gtDimension.rowHeight\"\r\n (click)=\"dataRowClicked(rowData)\"\r\n ></tr>\r\n\r\n <!-- TOTAL ROW -->\r\n <ng-container\r\n [matColumnDef]=\"column.colName\"\r\n *ngFor=\"let column of totalRowInfo; trackBy: trackByFn\"\r\n >\r\n <td\r\n mat-header-cell\r\n *matHeaderCellDef\r\n [attr.colspan]=\"column.colspan\"\r\n class=\"{{ column.class }}\"\r\n >\r\n <ng-container *ngIf=\"column['isActionColumn']\">\r\n <a\r\n *ngFor=\"let data of column.actionData\"\r\n [class]=\"data.class\"\r\n (click)=\"onClickableDataClicked({}, data.id)\"\r\n >\r\n {{ data.name }}\r\n </a>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"column['isIconColumn']\">\r\n <i\r\n class=\"{{ column?.iconData?.class }}\"\r\n (click)=\"iconClickedInTotalRow(column?.colName)\"\r\n >\r\n </i>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"!column['isActionColumn']\">\r\n <strong class=\"upper-label\">{{ column.data }}</strong>\r\n <ng-container *ngIf=\"column.lowerData\">\r\n <br />\r\n <span\r\n *ngIf=\"\r\n column.colName == 'total-potential-booked-unit' &&\r\n gtGeneralConfig.component == 'RATING';\r\n else columnLowerData\r\n \"\r\n class=\"clickable-data\"\r\n (click)=\"spotDetailsDownloadClicked('TOTALROW')\"\r\n [ngClass]=\"{ 'disabled-clickable-data': downloadInProgress }\"\r\n >{{ column.lowerData }}\r\n <span class=\"material-icons spot-details-download-icons\">get_app</span>\r\n <ng-container *ngIf=\"downloadInProgress && selectedRowTypeForDownload == 'TOTALROW'\">\r\n <ng-container [ngTemplateOutlet]=\"circularProgressBar\"></ng-container>\r\n </ng-container>\r\n </span>\r\n <ng-template #columnLowerData>\r\n <span class=\"lower-label\">{{ column.lowerData }}</span>\r\n </ng-template>\r\n </ng-container>\r\n <ng-container *ngIf=\"column.tooltipMessage && gtGeneralConfig.component != 'LUR_VIOLATIONS'\">\r\n <i\r\n class=\"{{ column.tooltipIconClass }}\"\r\n container=\"body\"\r\n [ngbTooltip]=\"column.tooltipMessage\"\r\n tooltipClass=\"gt-total-row-tooltip\"\r\n placement=\"bottom\"\r\n ></i>\r\n </ng-container>\r\n <ng-container *ngIf=\"gtGeneralConfig.component == 'LUR_VIOLATIONS' && column.tooltipMessage\">\r\n <i\r\n class=\"mi mdi-info-outline info-label\"\r\n container=\"body\"\r\n [ngbTooltip]=\"lurViolationTotalRowToolTip\"\r\n tooltipClass=\"gt-total-row-tooltip\"\r\n placement=\"bottom\"\r\n ></i>\r\n </ng-container>\r\n </ng-container>\r\n </td>\r\n </ng-container>\r\n\r\n <!-- MAIN ROW -->\r\n <ng-container\r\n [matColumnDef]=\"columnDef.headerInfo[0].objectKey\"\r\n *ngFor=\"let columnDef of tableHeaders; trackBy: trackByFn\"\r\n >\r\n <th\r\n #tableHeader\r\n nowrap\r\n mat-header-cell\r\n *matHeaderCellDef\r\n [style.width]=\"columnDef.width\"\r\n >\r\n <div\r\n class=\"row mx-0\"\r\n *ngFor=\"let header of columnDef.headerInfo; let j = index\"\r\n >\r\n <p\r\n *ngIf=\"header.typeOfHeaderData === 'STRING'\"\r\n [ngClass]=\"{ 'upper-label': j === 0, 'lower-label': j === 1 }\"\r\n >\r\n <ngx-skeleton-loader\r\n *ngIf=\"header.name == null\"\r\n count=\"1\"\r\n [theme]=\"{\r\n height: '10px',\r\n display: 'block',\r\n width: columnDef.width,\r\n 'max-width': 'calc(100% - 20px)'\r\n }\"\r\n >\r\n </ngx-skeleton-loader>\r\n <ng-container *ngIf=\"header.name\">\r\n {{ header.name }}\r\n </ng-container>\r\n <ng-container *ngIf=\"header.tooltip && header.tooltip.tooltipMessage\">\r\n <i\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"header.tooltip.tooltipMessage\"\r\n container=\"body\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n </ng-container>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'impsInfoTooltip'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"impsInfoTooltip\"\r\n container=\"body\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"\r\n header.tooltip && header.tooltip.name == 'spotsColumnEquivalizationMessageTooltip'\r\n \"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n container=\"body\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"spotsColumnEquivalizationMessageTooltip\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'underDeliveryTooltip'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n container=\"body\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"underDeliveryTooltip\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'overDeliveryTooltip'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n container=\"body\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"overDeliveryTooltip\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'ratingInfoTooltip'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"ratingInfoTooltip\"\r\n container=\"body\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'rateInfoTooltip'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"rateInfoTooltip\"\r\n container=\"body\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'ongoingRevBookedColumnTooltip'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"ongoingRevBookedColumnTooltip\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'completedRevBookedColumnTooltip'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"completedRevBookedColumnTooltip\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'avgBookedRate'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"avgBookedRate\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'avgBookedRtg'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"avgBookedRtg\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'avgBookedImps'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"avgBookedImps\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'automationTooltip'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"automationTooltip\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'rebateImpact'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"rebateImpact\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'projectedImpsRtg'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"projectedImpsRtg\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n </p>\r\n\r\n <ng-container *ngIf=\"header.typeOfHeaderData === 'CHECKBOX'\">\r\n <span\r\n *ngIf=\"gtGeneralConfig.isHeaderChecked\"\r\n class=\"material-icons custom-column-checkbox-checked\"\r\n (click)=\"selectUnselectAllRows()\"\r\n >\r\n check_box\r\n </span>\r\n <span\r\n *ngIf=\"!gtGeneralConfig.isHeaderChecked\"\r\n class=\"material-icons custom-column-checkbox-unchecked\"\r\n [ngClass]=\"{ 'disable-checkbox': gtGeneralConfig.disableHeaderCheckbox }\"\r\n (click)=\"selectUnselectAllRows()\"\r\n >\r\n check_box_outline_blank\r\n </span>\r\n </ng-container>\r\n\r\n <div\r\n *ngIf=\"gtGeneralConfig.showAllColumnFilter\"\r\n class=\"sort-filter-container\"\r\n >\r\n <ng-container *ngIf=\"header.showTooltipIcon\">\r\n <!-- Active tooltip Functionality -->\r\n <ng-container *ngIf=\"header.filter === 'CHECKBOX'\">\r\n <span\r\n class=\"mdi mdi-filter-variant\"\r\n [ngClass]=\"{\r\n active:\r\n annaFilterService.isFilterSortActive &&\r\n annaFilterService.isFilterSortActive[header.joinedFilterSortObjectKeys],\r\n disabled: header.disableTooltipIcon || showSkeletonLoading\r\n }\"\r\n [ngbTooltip]=\"filterTooltip\"\r\n placement=\"{{ filterAlignment }}\"\r\n container=\"body\"\r\n tooltipClass=\"non-edit-checkbox-tooltip\"\r\n [autoClose]=\"'outside'\"\r\n triggers=\"manual\"\r\n #t=\"ngbTooltip\"\r\n (click)=\"bindTheValueToToolTip(t, header)\"\r\n (hidden)=\"closeTooltip()\"\r\n >\r\n </span\r\n ><br />\r\n </ng-container>\r\n <ng-container *ngIf=\"header.filter === 'SLIDER'\">\r\n <span\r\n class=\"mdi mdi-filter-variant\"\r\n [ngClass]=\"{\r\n active:\r\n annaFilterService.isFilterSortActive &&\r\n annaFilterService.isFilterSortActive[header.joinedFilterSortObjectKeys],\r\n disabled: header.disableTooltipIcon || showSkeletonLoading\r\n }\"\r\n [ngbTooltip]=\"sliderToolTip\"\r\n placement=\"bottom left-top\"\r\n container=\"body\"\r\n tooltipClass=\"non-edit-slider-tooltip\"\r\n [autoClose]=\"'outside'\"\r\n triggers=\"manual\"\r\n #t1=\"ngbTooltip\"\r\n (click)=\"bindTheValueToToolTip(t1, header)\"\r\n (hidden)=\"closeTooltip()\"\r\n >\r\n </span\r\n ><br />\r\n </ng-container>\r\n <ng-container *ngIf=\"header.filter === 'DATE'\">\r\n <span\r\n class=\"mdi mdi-filter-variant\"\r\n [ngClass]=\"{\r\n active:\r\n annaFilterService.isFilterSortActive &&\r\n annaFilterService.isFilterSortActive[header.joinedFilterSortObjectKeys],\r\n disabled: header.disableTooltipIcon || showSkeletonLoading\r\n }\"\r\n [ngbTooltip]=\"datePickerTooltip\"\r\n placement=\"bottom auto\"\r\n container=\"body\"\r\n tooltipClass=\"non-edit-datepicker-tooltip\"\r\n [autoClose]=\"'outside'\"\r\n triggers=\"manual\"\r\n #t2=\"ngbTooltip\"\r\n (click)=\"bindTheValueToToolTip(t2, header)\"\r\n (hidden)=\"closeTooltip()\"\r\n >\r\n </span\r\n ><br />\r\n </ng-container>\r\n <ng-container *ngIf=\"header.filter === 'WEEK'\">\r\n <span\r\n class=\"mdi mdi-filter-variant\"\r\n [ngClass]=\"{\r\n active:\r\n annaFilterService.isFilterSortActive &&\r\n annaFilterService.isFilterSortActive[header.joinedFilterSortObjectKeys],\r\n disabled: header.disableTooltipIcon || showSkeletonLoading\r\n }\"\r\n [ngbTooltip]=\"weekPickerToolTip\"\r\n placement=\"bottom left-top\"\r\n container=\"body\"\r\n [autoClose]=\"'outside'\"\r\n triggers=\"manual\"\r\n #t3=\"ngbTooltip\"\r\n (click)=\"bindTheValueToToolTip(t3, header)\"\r\n (hidden)=\"closeTooltip()\"\r\n >\r\n </span\r\n ><br />\r\n </ng-container>\r\n <ng-container *ngIf=\"header.filter === 'TIME'\">\r\n <span\r\n class=\"mdi mdi-filter-variant\"\r\n [ngClass]=\"{\r\n active:\r\n annaFilterService.isFilterSortActive &&\r\n annaFilterService.isFilterSortActive[header.joinedFilterSortObjectKeys],\r\n disabled: header.disableTooltipIcon || showSkeletonLoading\r\n }\"\r\n [ngbTooltip]=\"timeFilterToolTip\"\r\n placement=\"bottom left-top auto\"\r\n container=\"body\"\r\n tooltipClass=\"non-edit-time-tooltip\"\r\n [autoClose]=\"'outside'\"\r\n triggers=\"manual\"\r\n #t4=\"ngbTooltip\"\r\n (click)=\"bindTheValueToToolTip(t4, header)\"\r\n (hidden)=\"closeTooltip()\"\r\n >\r\n </span\r\n ><br />\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"!header.showTooltipIcon\">\r\n <span id=\"no-filter-space\"></span><br />\r\n </ng-container>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'lurViolationInfoTooltip'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"lurViolationInfoTooltip\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n </div>\r\n </div>\r\n </th>\r\n\r\n <ng-container *matCellDef=\"let ROW_DATA\">\r\n <td\r\n mat-cell\r\n [style.background]=\"ROW_DATA.backgroundColor\"\r\n [style.border]=\"ROW_DATA.border\"\r\n class=\"{{ ROW_DATA.rowClass }}\"\r\n [ngClass]=\"ROW_DATA[columnDef.headerInfo[0].objectKey + 'TdClass']\"\r\n [attr.rowspan]=\"ROW_DATA[columnDef.headerInfo[0].objectKey + 'Rowspan']\"\r\n *ngIf=\"\r\n !hideSomeTds ||\r\n (hideSomeTds && !ROW_DATA['hide' + columnDef.headerInfo[0].objectKey + 'Td'])\r\n \"\r\n >\r\n <ngx-skeleton-loader\r\n *ngIf=\"showSkeletonLoading\"\r\n count=\"1\"\r\n [theme]=\"{ height: '10px', display: 'block' }\"\r\n >\r\n </ngx-skeleton-loader>\r\n\r\n <ng-container *ngIf=\"!showSkeletonLoading\">\r\n <ng-container *ngIf=\"tableData.length > 0 && !(isNoDataToDisplaySubject$ | async)\">\r\n <ng-container\r\n *ngFor=\"\r\n let subline of columnDef.headerInfo;\r\n let subLineIndex = index;\r\n trackBy: trackByFn\r\n \"\r\n >\r\n <div showEllipsisTextOnHover>\r\n <ng-container [ngSwitch]=\"columnDef.headerInfo[subLineIndex].typeOfBodyData\">\r\n <ng-container *ngSwitchCase=\"'ICON'\">\r\n <i\r\n *ngIf=\"\r\n !(\r\n starredInProgress &&\r\n ROW_DATA.orderId == selectedStarredOrderId\r\n )\r\n \"\r\n [class]=\"ROW_DATA.iconClass\"\r\n (click)=\"iconClicked(ROW_DATA, ROW_DATA.iconClass)\"\r\n ngbTooltip=\"{{ ROW_DATA.iconTitleText }}\"\r\n placement=\"bottom\"\r\n container=\"body\"\r\n tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\r\n ></i>\r\n <ng-container\r\n *ngIf=\"\r\n starredInProgress && ROW_DATA.orderId == selectedStarredOrderId\r\n \"\r\n >\r\n <div class=\"spinner-for-button-directive\"></div>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'ICON_CELL'\">\r\n <ng-container\r\n *ngFor=\"\r\n let action of ROW_DATA[\r\n columnDef.headerInfo[subLineIndex].actionKey\r\n ]\r\n \"\r\n >\r\n <ng-container *ngIf=\"action.showObjectKey\">\r\n {{ ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey] }}\r\n </ng-container>\r\n\r\n <i\r\n *ngIf=\"action.showIcon\"\r\n [class]=\"action.iconClass\"\r\n (mouseenter)=\"\r\n mouseEnterOnStringTextActionType(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].tooltipKey\r\n )\r\n \"\r\n placement=\"bottom auto\"\r\n container=\"body\"\r\n [autoClose]=\"true\"\r\n tooltipClass=\"team-user-tooltip remove-on-scroll-class\"\r\n [ngbTooltip]=\"action.showTooltip ? action.tooltipData : null\"\r\n (click)=\"\r\n textActionClicked(\r\n ROW_DATA,\r\n action.id,\r\n columnDef.headerInfo[subLineIndex]\r\n )\r\n \"\r\n [disableTooltip]=\"!action.showTooltip\"\r\n >\r\n </i>\r\n\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'HTML_STRING'\">\r\n <p\r\n [innerHTML]=\"ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\r\n (click)=\"innerHTMLCellClicked($event, ROW_DATA)\"\r\n ></p>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'SVG_ICON'\">\r\n <anna-core-anna-icon-column\r\n [componentName]=\"gtGeneralConfig.component\"\r\n [dataObject]=\"ROW_DATA\"\r\n [iconToShow]=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n \"\r\n (onColumnIconClicked)=\"svgIconClicked($event)\"\r\n ></anna-core-anna-icon-column>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'TEXT_ACTIONS'\">\r\n <ng-container\r\n *ngFor=\"\r\n let text of ROW_DATA[\r\n columnDef.headerInfo[subLineIndex].actionKey\r\n ]\r\n \"\r\n >\r\n <button\r\n *ngIf=\"text.showTooltip\"\r\n (click)=\"\r\n textActionClicked(\r\n ROW_DATA,\r\n text.id,\r\n columnDef.headerInfo[subLineIndex]\r\n )\r\n \"\r\n [disabled]=\"text.isDisabled\"\r\n class=\"{{ text.class }}\"\r\n (mouseenter)=\"\r\n mouseEnterOnTextActionType(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].tooltipKey\r\n )\r\n \"\r\n [ngbTooltip]=\"textActionTooltipTemplate\"\r\n placement=\"auto\"\r\n container=\"body\"\r\n tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\r\n >\r\n {{ text.name }}\r\n </button>\r\n\r\n <button\r\n *ngIf=\"!text.showTooltip\"\r\n (click)=\"\r\n textActionClicked(\r\n ROW_DATA,\r\n text.id,\r\n columnDef.headerInfo[subLineIndex]\r\n )\r\n \"\r\n [disabled]=\"text.isDisabled\"\r\n class=\"{{ text.class }}\"\r\n >\r\n {{ text.name }}\r\n </button>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'CHECKBOX'\">\r\n <span\r\n *ngIf=\"ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\r\n [ngClass]=\"{\r\n 'disable-checkbox':\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].isDisabledKey]\r\n }\"\r\n class=\"material-icons custom-column-checkbox-checked\"\r\n (click)=\"\r\n selectOrUnselectCheckbox(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].objectKey,\r\n false\r\n )\r\n \"\r\n >\r\n check_box\r\n </span>\r\n <span\r\n *ngIf=\"!ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\r\n class=\"material-icons custom-column-checkbox-unchecked\"\r\n [ngClass]=\"{\r\n 'disable-checkbox':\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].isDisabledKey]\r\n }\"\r\n (click)=\"\r\n selectOrUnselectCheckbox(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].objectKey,\r\n true\r\n )\r\n \"\r\n >\r\n check_box_outline_blank\r\n </span>\r\n\r\n <ng-container\r\n *ngFor=\"\r\n let action of ROW_DATA[\r\n columnDef.headerInfo[subLineIndex].actionKey\r\n ]\r\n \"\r\n >\r\n <i\r\n *ngIf=\"action.showIcon\"\r\n [class]=\"action.iconClass\"\r\n [ngClass]=\"{ disabled: action.disabledIcon }\"\r\n (mouseenter)=\"\r\n mouseEnterOnStringTextActionTypeContainingTable(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].tooltipKey\r\n )\r\n \"\r\n placement=\"bottom auto\"\r\n container=\"body\"\r\n [autoClose]=\"true\"\r\n tooltipClass=\"tooltip-containing-table remove-on-scroll-class\"\r\n [ngbTooltip]=\"tooltipContainingTableTemplate\"\r\n >\r\n </i>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'CLICKABLE_DATA'\">\r\n <a\r\n *ngFor=\"\r\n let text of ROW_DATA[\r\n columnDef.headerInfo[subLineIndex].actionKey\r\n ]\r\n \"\r\n [class]=\"text.class\"\r\n (click)=\"onClickableDataClicked(ROW_DATA, text.id)\"\r\n >\r\n {{ text.name }}\r\n </a>\r\n <span\r\n *ngIf=\"\r\n subline.objectKey == 'displayBookedUnits' &&\r\n gtGeneralConfig.component == 'RATING'\r\n \"\r\n class=\"clickable-data\"\r\n (click)=\"spotDetailsDownloadClicked('DATAROW', ROW_DATA)\"\r\n [ngClass]=\"{ 'disabled-clickable-data': downloadInProgress }\"\r\n >{{ ROW_DATA.displayBookedUnits }}\r\n <span class=\"material-icons spot-details-download-icons\"\r\n >get_app</span\r\n >\r\n <ng-container\r\n *ngIf=\"\r\n downloadInProgress &&\r\n ROW_DATA.inventoryCodeId ==\r\n selectedInventoryIdForDownload &&\r\n ROW_DATA.demographic == selectedDemographicForDownload\r\n \"\r\n >\r\n <ng-container\r\n [ngTemplateOutlet]=\"circularProgressBar\"\r\n ></ng-container>\r\n </ng-container>\r\n </span>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'STRING___ICON_OR_TEXT_ACTION'\">\r\n <ng-container\r\n *ngFor=\"\r\n let action of ROW_DATA[\r\n columnDef.headerInfo[subLineIndex].actionKey\r\n ]\r\n \"\r\n >\r\n <span\r\n [class]=\"action.additionalTextBeforeLinkClass\"\r\n [innerHtml]=\"action.additionalTextBeforeLink\"\r\n ngbTooltip=\"{{ action.additionalTextBeforeLink }}\"\r\n placement=\"bottom\"\r\n container=\"body\"\r\n tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\r\n [disableTooltip]=\"!action.enableTooltipForAdditionalText\"\r\n ></span>\r\n\r\n <ng-container *ngIf=\"action && action.typeOfData == 'STRING'\">\r\n {{ action.data }}\r\n </ng-container>\r\n\r\n <a\r\n [id]=\"action.id\"\r\n *ngIf=\"action.showLink\"\r\n (click)=\"\r\n textActionClicked(\r\n ROW_DATA,\r\n action.id,\r\n columnDef.headerInfo[subLineIndex]\r\n )\r\n \"\r\n [class]=\"action.linkClass\"\r\n [ngClass]=\"{ disabled: action.disabledLink }\"\r\n >{{ action.data }}</a\r\n >\r\n <span\r\n ngbTooltip=\"{{ action.additionalTextAfterLink }}\"\r\n placement=\"bottom\"\r\n container=\"body\"\r\n [class]=\"action.additionalTextAfterLinkClass\"\r\n tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\r\n [disableTooltip]=\"!action.enableTooltipForAdditionalAfterText\"\r\n >\r\n {{ action.additionalTextAfterLink }}\r\n </span>\r\n\r\n <ng-container *ngIf=\"action.showTooltip\">\r\n <ng-container *ngIf=\"action.tooltipData.innerHtml\">\r\n <i\r\n *ngIf=\"action.showIcon\"\r\n [class]=\"action.iconClass\"\r\n [ngClass]=\"{ disabled: action.disabledIcon }\"\r\n (mouseenter)=\"\r\n mouseEnterOnStringTextActionTypeContainingTable(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].tooltipKey\r\n )\r\n \"\r\n placement=\"bottom auto\"\r\n container=\"body\"\r\n [autoClose]=\"true\"\r\n tooltipClass=\"tooltip-containing-table remove-on-scroll-class\"\r\n [ngbTooltip]=\"tooltipContainingTableTemplate\"\r\n >\r\n </i>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"!action.tooltipData.tooltipTableBody\">\r\n <i\r\n *ngIf=\"action.showIcon\"\r\n [class]=\"action.iconClass\"\r\n [ngClass]=\"{ disabled: action.disabledIcon }\"\r\n (click)=\"\r\n iconClickedOnStringIconActionType(\r\n ROW_DATA,\r\n action.id,\r\n columnDef.headerInfo[subLineIndex]\r\n )\r\n \"\r\n (mouseleave)=\"mouseLeaveTextActionType(ROW_DATA)\"\r\n (mouseenter)=\"\r\n mouseEnterOnStringTextActionType(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].tooltipKey\r\n )\r\n \"\r\n [placement]=\"\r\n action.tooltipPlacement\r\n ? action.tooltipPlacement\r\n : 'bottom auto'\r\n \"\r\n container=\"body\"\r\n [autoClose]=\"true\"\r\n tooltipClass=\"team-user-tooltip remove-on-scroll-class {{\r\n action.tooltipClass\r\n }}\"\r\n [ngbTooltip]=\"userLoggedInDetails\"\r\n >\r\n </i>\r\n <ng-container *ngIf=\"action['showSvgIcon']\">\r\n <anna-core-anna-est-icon-template\r\n class=\"float-right\"\r\n *ngIf=\"action['svgIconName'] == 'anna-icon'\"\r\n (mouseleave)=\"mouseLeaveTextActionType(ROW_DATA)\"\r\n (mouseenter)=\"\r\n mouseEnterOnStringTextActionType(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex]\r\n .tooltipKey\r\n )\r\n \"\r\n [placement]=\"\r\n action.tooltipPlacement\r\n ? action.tooltipPlacement\r\n : 'bottom auto'\r\n \"\r\n tooltipClass=\"team-user-tooltip remove-on-scroll-class {{\r\n action['tooltipClass']\r\n }}\"\r\n [ngbTooltip]=\"userLoggedInDetails\"\r\n container=\"body\"\r\n [autoClose]=\"true\"\r\n >\r\n </anna-core-anna-est-icon-template>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"!action.showTooltip\">\r\n <i\r\n *ngIf=\"action.showIcon\"\r\n [class]=\"action.iconClass\"\r\n [ngClass]=\"{ disabled: action.disabledIcon }\"\r\n (click)=\"\r\n iconClickedOnStringIconActionType(\r\n ROW_DATA,\r\n action.id,\r\n columnDef.headerInfo[subLineIndex]\r\n )\r\n \"\r\n >\r\n </i>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'STRING_OR_INPUT'\">\r\n <ng-container\r\n *ngIf=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]?.type ==\r\n 'STRING';\r\n else inputBox\r\n \"\r\n >\r\n <span\r\n [innerHtml]=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n ?.value\r\n \"\r\n ></span>\r\n </ng-container>\r\n <ng-template #inputBox>\r\n <input\r\n placeholder=\"{{\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n ?.placeholder\r\n }}\"\r\n showEllipsisTextOnHover\r\n class=\"{{\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n .className\r\n }}\"\r\n (keydown)=\"\r\n changesMadeInEditableInputBox(\r\n $event,\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey],\r\n false\r\n )\r\n \"\r\n (paste)=\"\r\n changesMadeInEditableInputBox(\r\n $event,\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey],\r\n true\r\n )\r\n \"\r\n (ngModelChange)=\"\r\n editableInputValueChanged(\r\n $event,\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].objectKey\r\n )\r\n \"\r\n [ngModel]=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey].value\r\n \"\r\n [disabled]=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n .disabled\r\n \"\r\n [ngClass]=\"{\r\n 'red-border':\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n .hasError\r\n }\"\r\n />\r\n\r\n <i\r\n *ngIf=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n .showIcon\r\n \"\r\n container=\"body\"\r\n [ngbTooltip]=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n .iconTooltip\r\n \"\r\n tooltipClass=\"gt-total-row-tooltip\"\r\n placement=\"bottom\"\r\n class=\"{{\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n .iconClass\r\n }}\"\r\n >\r\n </i>\r\n <ng-container\r\n *ngIf=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey][\r\n 'showSvgIcon'\r\n ]\r\n \"\r\n >\r\n <anna-core-anna-est-icon-template\r\n class=\"float-right\"\r\n *ngIf=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey][\r\n 'svgIconName'\r\n ] == 'anna-icon'\r\n \"\r\n [placement]=\"'bottom auto'\"\r\n tooltipClass=\"gt-total-row-tooltip\"\r\n [ngbTooltip]=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n .iconTooltip\r\n \"\r\n container=\"body\"\r\n >\r\n </anna-core-anna-est-icon-template>\r\n </ng-container>\r\n </ng-template>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'HTML'\">\r\n <span\r\n [innerHtml]=\"ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\r\n ></span>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'SINGLE_RADIO'\">\r\n <span\r\n *ngIf=\"ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\r\n [ngClass]=\"{\r\n 'disable-checkbox':\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].isDisabledKey]\r\n }\"\r\n class=\"mdi mdi-radiobox-marked\"\r\n (click)=\"(null)\"\r\n >\r\n </span>\r\n <span\r\n *ngIf=\"!ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\r\n class=\"mdi mdi-radiobox-blank\"\r\n [ngClass]=\"{\r\n 'disable-checkbox':\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].isDisabledKey]\r\n }\"\r\n (click)=\"\r\n selectOrUnselectCheckbox(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].objectKey,\r\n true\r\n )\r\n \"\r\n >\r\n </span>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'RADIO'\">\r\n <mat-radio-group\r\n *ngIf=\"ROW_DATA['RadioButtonConfig']\"\r\n [ngModel]=\"ROW_DATA[subline.objectKey]\"\r\n [disabled]=\"ROW_DATA['RadioButtonConfig'][0].isDisabled\"\r\n >\r\n <ng-container\r\n *ngFor=\"\r\n let radioButton of ROW_DATA['RadioButtonConfig'];\r\n let last = last\r\n \"\r\n >\r\n <mat-radio-button\r\n value=\"{{ radioButton.value }}\"\r\n class=\"{{ radioButton.class }}\"\r\n (click)=\"\r\n radioButtonClicked(\r\n ROW_DATA,\r\n radioButton.value,\r\n ROW_DATA['RadioButtonConfig'][0].isDisabled\r\n )\r\n \"\r\n >{{ radioButton.label }}\r\n </mat-radio-button>\r\n <i\r\n class=\" {{ radioButton.iconClass }}\"\r\n (click)=\"radioButtonIconClicked(ROW_DATA)\"\r\n ></i>\r\n <br *ngIf=\"!last\" />\r\n </ng-container>\r\n </mat-radio-group>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'STRING_WITH_TOOLTIP'\">\r\n <ng-container\r\n *ngFor=\"\r\n let action of ROW_DATA[\r\n columnDef.headerInfo[subLineIndex].actionKey\r\n ]\r\n \"\r\n >\r\n <span> {{ action?.dataToDisplay }}</span>\r\n <span\r\n *ngIf=\"action?.showTooltip\"\r\n [ngbTooltip]=\"textActionTooltipTemplate\"\r\n (mouseenter)=\"\r\n mouseEnterOnStringTextActionType(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].tooltipKey\r\n )\r\n \"\r\n [placement]=\"action?.tooltipPosition\"\r\n container=\"body\"\r\n [class]=\"action?.tooltipIconClass\"\r\n tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\r\n [disableTooltip]=\"action?.disableTooltip\"\r\n >\r\n </span>\r\n <span> {{ action?.dataToDisplayAfterTooltip }}</span>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchDefault>\r\n <ng-container *ngIf=\"subline.objectKey != 'description'\">\r\n <span>{{\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n }}</span>\r\n <i\r\n *ngIf=\"\r\n subline.objectKey == 'inventoryCode' &&\r\n ROW_DATA['isSellerGroup'] &&\r\n gtGeneralConfig.component == 'RATING'\r\n \"\r\n class=\"mi mdi-info-outline seller-tooltip\"\r\n [ngbTooltip]=\"sellerHierarchyTooltip\"\r\n placement=\"bottom auto\"\r\n container=\"body\"\r\n [autoClose]=\"true\"\r\n triggers=\"manual\"\r\n (hidden)=\"closeTooltip()\"\r\n #info=\"ngbTooltip\"\r\n tooltipClass=\"hierarchy-tooltip remove-on-scroll-class\"\r\n (mouseenter)=\"\r\n bindTheValueToSellerGroupTooltip(\r\n ROW_DATA.sellerGroupHierarchy,\r\n info\r\n )\r\n \"\r\n >\r\n </i>\r\n\r\n <i\r\n *ngIf=\"\r\n subline.objectKey == 'displayBookedAverageRating' &&\r\n gtGeneralConfig.component == 'RATING' &&\r\n ROW_DATA['showRatingAverageIcon']\r\n \"\r\n class=\"mi mdi-info-outline seller-tooltip\"\r\n placement=\"bottom auto\"\r\n container=\"body\"\r\n [autoClose]=\"true\"\r\n (mouseenter)=\"\r\n setIsDifference(ROW_DATA.isDifferenceLessThan25Percent)\r\n \"\r\n tooltipClass=\"posted-avg-tooltip remove-on-scroll-class\"\r\n [ngbTooltip]=\"postedRatingDifference\"\r\n >\r\n </i>\r\n\r\n <i\r\n *ngIf=\"\r\n subline.objectKey == 'displayBookedAverageImpression' &&\r\n gtGeneralConfig.component == 'RATING' &&\r\n ROW_DATA['showImpressionAverageIcon']\r\n \"\r\n class=\"mi mdi-info-outline seller-tooltip\"\r\n placement=\"bottom auto\"\r\n container=\"body\"\r\n [autoClose]=\"true\"\r\n (mouseenter)=\"\r\n setIsDifference(ROW_DATA.isDifferenceLessThan25Percent)\r\n \"\r\n tooltipClass=\"posted-avg-tooltip remove-on-scroll-class\"\r\n [ngbTooltip]=\"postedImpDifference\"\r\n >\r\n </i>\r\n </ng-container>\r\n <ng-container *ngIf=\"subline.objectKey == 'description'\">\r\n <p\r\n *ngIf=\"\r\n ROW_DATA.descriptionMessage ||\r\n ROW_DATA.descriptionEmailReferenceNum\r\n \"\r\n >\r\n <ng-container *ngIf=\"ROW_DATA.descriptionMessage\">\r\n {{ ROW_DATA.descriptionMessage }}\r\n <br />\r\n </ng-container>\r\n <ng-container\r\n *ngIf=\"\r\n ROW_DATA.descriptionEmailReferenceNum != '-' &&\r\n ROW_DATA.descriptionEmailReferenceNum != ''\r\n \"\r\n >\r\n Email Ref: {{ ROW_DATA.descriptionEmailReferenceNum }}\r\n <br />\r\n </ng-container>\r\n </p>\r\n <a\r\n href=\"{{ ROW_DATA.descriptionDetailsUrl }}\"\r\n target=\"_blank\"\r\n *ngIf=\"\r\n ROW_DATA.descriptionDetailsUrlType === 'PDF' ||\r\n ROW_DATA.descriptionDetailsUrlType === 'EXCEL'\r\n \"\r\n >\r\n <button class=\"btn viewDetailsAndEmailBtn\">Download</button>\r\n </a>\r\n <ng-container\r\n *ngIf=\"ROW_DATA.activityname.toLowerCase() == 'order onboarded'\"\r\n >\r\n <a\r\n *ngIf=\"ROW_DATA.descriptionDetailsUrlType === 'LINK'\"\r\n (click)=\"viewDetailsClicked(ROW_DATA)\"\r\n >\r\n <button class=\"btn viewDetailsAndEmailBtn order-onboarded\">\r\n View details\r\n </button>\r\n </a>\r\n </ng-container>\r\n\r\n <a\r\n href=\"{{ ROW_DATA.descriptionEmailUrl }}\"\r\n target=\"_blank\"\r\n *ngIf=\"\r\n ROW_DATA.descriptionEmailUrl != '-' &&\r\n ROW_DATA.descriptionEmailUrl != ''\r\n \"\r\n >\r\n <button class=\"btn viewDetailsAndEmailBtn\">View email</button>\r\n </a>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"isNoDataToDisplaySubject$ | async\">\r\n <div>\r\n {{ null }}\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n </td>\r\n </ng-container>\r\n </ng-container>\r\n </table>\r\n </div>\r\n <anna-core-no-data-lib\r\n [width]=\"noDataWidth\"\r\n [marginTop]=\"marginTop\"\r\n *ngIf=\"isNoDataToDisplaySubject$ | async\"\r\n >\r\n </anna-core-no-data-lib>\r\n</div>\r\n\r\n<!-- Checkbox template -->\r\n<ng-template #filterTooltip>\r\n <anna-core-anna-column-checkbox-filter\r\n [tableData]=\"tableData\"\r\n [showFilterHeaderTabs]=\"showFilterTooltipTabs\"\r\n [isLurAndCsrComponent]=\"false\"\r\n [clonedTableData]=\"clonedTableData\"\r\n [filterTabObjects]=\"filterTabObjects\"\r\n (filterAppliedToTable)=\"filterApplied($event)\"\r\n (sortingAppliedToTable)=\"sortingApplied($event)\"\r\n (closeTooltip)=\"closeTooltip()\"\r\n >\r\n </anna-core-anna-column-checkbox-filter>\r\n</ng-template>\r\n\r\n<!-- Slider template -->\r\n<ng-template #sliderToolTip>\r\n <anna-core-anna-column-slider-filter\r\n [tableData]=\"tableData\"\r\n [showFilterHeaderTabs]=\"showFilterTooltipTabs\"\r\n [isLurAndCsrComponent]=\"false\"\r\n [clonedTableData]=\"clonedTableData\"\r\n [filterTabObjects]=\"filterTabObjects\"\r\n (filterAppliedToTable)=\"filterApplied($event)\"\r\n (sortingAppliedToTable)=\"sortingApplied($event)\"\r\n (closeTooltip)=\"closeTooltip()\"\r\n >\r\n </anna-core-anna-column-slider-filter>\r\n</ng-template>\r\n\r\n<!-- Date Picker Template -->\r\n<ng-template #datePickerTooltip>\r\n <anna-core-anna-column-date-range-filter\r\n [tableData]=\"tableData\"\r\n [showFilterHeaderTabs]=\"showFilterTooltipTabs\"\r\n [isLurAndCsrComponent]=\"false\"\r\n [clonedTableData]=\"clonedTableData\"\r\n [filterTabObjects]=\"filterTabObjects\"\r\n (filterAppliedToTable)=\"filterApplied($event)\"\r\n (sortingAppliedToTable)=\"sortingApplied($event)\"\r\n (closeTooltip)=\"closeTooltip()\"\r\n >\r\n </anna-core-anna-column-date-range-filter>\r\n</ng-template>\r\n\r\n<!-- Week Picker Template -->\r\n<ng-template #weekPickerToolTip>\r\n <!-- <div class=\"weekpicker-container\">\r\n <anna-core-week-calendar-filter-lib\r\n [week-calendar-config]=\"gtGeneralConfig.multiWeekPickerConfig\"\r\n (apply)=\"applyWeekFilter($event)\"\r\n [from-date]=\"calendarMinEnabledDate\"\r\n [to-date]=\"calendarMaxEnabledDate\"\r\n >\r\n </anna-core-week-calendar-filter-lib>\r\n </div> -->\r\n</ng-template>\r\n\r\n<!-- Time Filter Template -->\r\n<ng-template #timeFilterToolTip>\r\n <anna-core-anna-column-time-filter\r\n [tableData]=\"tableData\"\r\n [showFilterHeaderTabs]=\"showFilterTooltipTabs\"\r\n [isLurAndCsrComponent]=\"false\"\r\n [showAllTimeRangeCheckboxes]=\"showCheckboxesForTimeFilter\"\r\n [clonedTableData]=\"clonedTableData\"\r\n [filterTabObjects]=\"filterTabObjects\"\r\n (filterAppliedToTable)=\"filterApplied($event)\"\r\n (sortingAppliedToTable)=\"sortingApplied($event)\"\r\n (closeTooltip)=\"closeTooltip()\"\r\n >\r\n </anna-core-anna-column-time-filter>\r\n</ng-template>\r\n\r\n<ng-template #columnInfoTooltip>\r\n <p style=\"color: black; white-space: nowrap\">This preemption is rejected and not marked for credit.</p>\r\n</ng-template>\r\n\r\n<ng-template #ratingInfoTooltip>\r\n <p class=\"first-row\">Shows 'Booked Rating' for Preemptions & MakeGood Offered spot(s).</p>\r\n <p class=\"second-row\">Shows 'Projected Rating' for ADU Offered spot(s).</p>\r\n</ng-template>\r\n\r\n<ng-template #impsInfoTooltip>\r\n <p class=\"first-row\">Shows 'Booked IMPS' for Preemptions & MakeGood Offered spot(s).</p>\r\n <p class=\"second-row\">Shows 'Projected IMPS' for ADU Offered spot(s).</p>\r\n</ng-template>\r\n\r\n<ng-template #spotsColumnEquivalizationMessageTooltip>\r\n <p class=\"spot-column-tooltip-message\">\r\n This consists of equivalized spots and un-equivalized Paid Programs & un-equivalized Non-spots.\r\n </p>\r\n</ng-template>\r\n\r\n<ng-template #underDeliveryTooltip>\r\n <p class=\"spot-column-tooltip-message\">\r\n Indicates the Under-delivery percentage based on booked and posted RTG/IMPS.\r\n </p>\r\n</ng-template>\r\n\r\n<ng-template #overDeliveryTooltip>\r\n <p class=\"spot-column-tooltip-message\">\r\n Indicates the Over-delivery percentage based on booked and posted RTG/IMPS.\r\n </p>\r\n</ng-template>\r\n\r\n<ng-template #rateInfoTooltip>\r\n <p class=\"first-row\">Shows 'Booked Rate' for Preemptions & MakeGood Offered spot(s).</p>\r\n <p class=\"second-row\">Shows 'Projected $ Value' for ADU Offered spot(s).</p>\r\n</ng-template>\r\n\r\n<ng-template #sellerHierarchyTooltip>\r\n <ng-container *ngIf=\"sellerGroupHierarchy.length > 0\">\r\n <section class=\"hierarchy-table-container\">\r\n <table class=\"seller-hierarchy-table\">\r\n <thead>\r\n <tr>\r\n <th>#</th>\r\n <th>Inventory Codes</th>\r\n <th>Program/Description</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let data of sellerGroupHierarchy; let tooltipIndex = index\">\r\n <td>{{ tooltipIndex + 1 }}</td>\r\n <td>\r\n <span showEllipsisTextOnHover>{{ data.InventoryCode }}</span>\r\n </td>\r\n <td>\r\n <span showEllipsisTextOnHover>{{ data.Program }}</span>\r\n </td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n </section>\r\n </ng-container>\r\n <ng-container *ngIf=\"sellerGroupHierarchy.length == 0\">\r\n <span style=\"color: #000\">Seller group not available for this inventory code</span>\r\n </ng-container>\r\n</ng-template>\r\n\r\n<ng-template #lurViolationInfoTooltip>\r\n <p class=\"first-row\">The values are for the entire week.</p>\r\n</ng-template>\r\n\r\n<ng-template #postedRatingDifference>\r\n <p class=\"difference-text\">\r\n The difference between posted and booked average rating is\r\n {{ isDifferenceLessThan25Percent ? \"less\" : \"more\" }} than 25%.\r\n </p>\r\n</ng-template>\r\n\r\n<ng-template #postedImpDifference>\r\n <p class=\"difference-text\">\r\n The difference between posted and booked average impression is\r\n {{ isDifferenceLessThan25Percent ? \"less\" : \"more\" }} than 25%.\r\n </p>\r\n</ng-template>\r\n\r\n<ng-template #ongoingRevBookedColumnTooltip>\r\n <p>The Booked $ value, Spots, GRP, CPP, IMPS, CPM corresponds on the last permanent revision generated</p>\r\n</ng-template>\r\n\r\n<ng-template #completedRevBookedColumnTooltip>\r\n <p>The Booked $ value corresponds on the last permanent revision generated</p>\r\n</ng-template>\r\n\r\n<ng-template #avgBookedRate>\r\n <p>This is the booked average Rate</p>\r\n</ng-template>\r\n\r\n<ng-template #avgBookedRtg>\r\n <p>This is the booked average RTG</p>\r\n</ng-template>\r\n\r\n<ng-template #avgBookedImps>\r\n <p>This is the booked average IMP(\u2019000)</p>\r\n</ng-template>\r\n\r\n<ng-template #projectedImpsRtg>\r\n <p>\r\n All projections are derived from the sum of actual posted information until the last posted date and estimates\r\n for the remaining selected period.\r\n </p>\r\n</ng-template>\r\n\r\n<ng-template #automationTooltip>\r\n <p>\r\n Please get the order business rules approved to activate the order for automation. Only for the\r\n automation-activated orders, any approved MGs, ADUs, or credited spots on ANNA will be fed into the traffic\r\n system i.e. ANNA revisions.\r\n <!-- removed below line as part of enhancmennt in 14.0 releas -->\r\n <!-- Additionally, ANNA will only enter buyer revisions into traffic for the selected\r\n Medialine/WOC orders. -->\r\n </p>\r\n</ng-template>\r\n\r\n<ng-template #rebateImpact>\r\n <p>Rebate impact value is for the originally ordered spot length and is not equivalized.</p>\r\n</ng-template>\r\n\r\n<ng-template #lurViolationTotalRowToolTip>\r\n <ul>\r\n <li>\r\n <strong>POLITICAL RATE VIOLATIONS:</strong>\r\n Violations flagged when non-political spots are booked at a rate lower than the minimum booked rate for\r\n political candidates for the same week, Inventory Code and Revenue Class.\r\n </li>\r\n <li>\r\n <strong>CANDIDATE TO CANDIDATE VIOLATION:</strong>\r\n Violations flagged when political spots are booked at different rates to other political spots for the same\r\n week, Inventory Code and Revenue Class.\r\n </li>\r\n </ul>\r\n</ng-template>\r\n\r\n<ng-template #circularProgressBar>\r\n <circle-progress\r\n [percent]=\"percentDone\"\r\n [radius]=\"5\"\r\n [showTitle]=\"false\"\r\n [showUnits]=\"false\"\r\n [showSubtitle]=\"false\"\r\n [outerStrokeWidth]=\"3\"\r\n [innerStrokeWidth]=\"3\"\r\n [space]=\"-3\"\r\n [outerStrokeColor]=\"'#268bff'\"\r\n [innerStrokeColor]=\"'#d5d5d5'\"\r\n [animationDuration]=\"10\"\r\n ></circle-progress>\r\n</ng-template>\r\n\r\n<ng-template #userLoggedInDetails>\r\n <div class=\"tooltip-div-container\">\r\n <ng-container *ngFor=\"let data of textActionTooltip\">\r\n <span *ngIf=\"data.key != 'read'\">\r\n {{ data.key }} <b> {{ data.value }}</b>\r\n </span>\r\n <span *ngIf=\"data.key == 'read'\">\r\n {{ data.value }}\r\n </span>\r\n </ng-container>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #markAsReadTip>\r\n <div class=\"notification-tooltip-div-container\">\r\n <ng-container *ngFor=\"let data of textActionTooltip\">\r\n {{ data.value }}\r\n </ng-container>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #textActionTooltipTemplate>\r\n <ng-container *ngFor=\"let data of textActionTooltip\">\r\n {{ data.key }} <b> {{ data.value }}</b>\r\n </ng-container>\r\n</ng-template>\r\n\r\n<ng-template #tooltipContainingTableTemplate>\r\n <div\r\n *ngIf=\"tooltipContainingTable\"\r\n [innerHTML]=\"tooltipContainingTable.innerHtml\"\r\n class=\"notification-tooltip-div-container\"\r\n >\r\n <!-- <ul>\r\n <li *ngFor=\"let headerMsg of tooltipContainingTable.tableHeaderMsg\">\r\n <b> {{headerMsg}} </b>\r\n </li>\r\n </ul>\r\n\r\n <table class=\"tooltip-table\">\r\n <thead>\r\n <tr>\r\n <th *ngFor=\"let header of tooltipContainingTable.tooltipTableHeader\">\r\n {{ header}}\r\n </th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let rows of tooltipContainingTable.tooltipTableBody\">\r\n <td *ngFor=\"let data of rows\">\r\n {{ data }}\r\n </td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n\r\n <ul>\r\n <li style=\"margin-top:10px; padding:0\" *ngFor=\"let footerMsg of tooltipContainingTable.tableFooterMsg\">\r\n {{ footerMsg }} \r\n </li>\r\n </ul> -->\r\n </div>\r\n</ng-template>\r\n<!-- <ng-template #textActionTooltipTemplate>\r\n <ng-container *ngFor=\"let data of textActionTooltip\">\r\n {{ data.key }} <b> {{data.value}}</b>\r\n </ng-container>\r\n</ng-template> -->\r\n", styles: [".sort-btn{background:white;border:none;border-right:1px solid #1b88ff;text-decoration:underline;font-family:Roboto;font-size:14px;font-weight:400;font-stretch:normal;font-style:normal;line-height:1.07;letter-spacing:normal;color:#1b88ff;cursor:pointer;flex:1;text-align:center}.sort-btn:last-of-type{border-right:none}.sort-btn.active{color:#202b47;text-decoration:none}p.sort-container{margin-top:8px;padding-bottom:8px;border-bottom:1px solid #e6e6e6;margin-bottom:0;display:flex}::ng-deep .tooltip-inner{max-height:22rem;background-color:#fff;border:1px solid white;border-radius:5px;box-shadow:0 2px 2px #0000003d,0 0 2px #0000001f;max-width:251px;width:100%;padding:0!important}::ng-deep .tooltip-inner div.radio-container{flex-wrap:wrap}::ng-deep .md-drppicker{box-shadow:unset!important}::ng-deep .available{color:#999}::ng-deep .bs-tooltip-bottom .arrow:before{border-bottom-color:#fff!important}::ng-deep .bs-tooltip-left .arrow:before{border-left-color:#fff!important}::ng-deep .tooltip.show{opacity:1}.input{text-align:left;margin:5px 10px 5px 5px;display:flex;align-items:center;width:230px;white-space:nowrap}.data{color:#000;font-weight:700;margin-left:5px;margin-right:5px}span.data{display:inline-block;text-overflow:ellipsis;white-space:pre;width:100%;overflow:hidden}.check-box{font-size:14px;cursor:pointer;position:relative;top:-1px}span.mdi-filter.active{color:#000;opacity:1!important;pointer-events:all!important}p{margin-bottom:0;line-height:initial}span.mdi-filter{color:#cbcbcb}::ng-deep .ngx-slider-pointer{top:-5px!important;width:12px!important;height:12px!important;background:#bdbdbd!important;border:1px solid #ffffff!important;box-shadow:0 1px 3px #0000004d!important;border-radius:16px!important}input:focus{outline:none}input::placeholder{color:#c8c8c8}.cancel-btn{background:#c7e1ff;color:#268bff}.apply-btn{background:#268bff;color:#fff;margin-left:.3125rem}div.radio-container{display:flex;white-space:nowrap;justify-content:space-between;background-color:#f4f4f4;border-radius:.125rem;margin:.4375rem .4375rem .25rem}div.radio-container div{flex:1;width:50%}div.radio-container div.full-width{width:100%}div.radio-container input{position:relative;top:.125rem;margin-right:.25rem}div.radio-container label{font-family:Roboto;font-size:.875rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:1.29;letter-spacing:0;color:#4a4a4a;margin:0;padding-left:.125rem}div.radio-container label:first-of-type{margin-right:.188rem}div.radio-container input[type=radio]{appearance:none;display:inline-block;width:.9375rem;height:.9375rem;padding:.125rem;background-clip:content-box;border:.125rem solid #268bff;background-color:transparent;border-radius:50%}div.radio-container input[type=radio]:checked{background-color:#268bff}.checkbox-filter-buttons-container{padding:0 8px!important}.buttons-container{display:flex;margin:0px auto .4375rem;justify-content:center;padding:0 12px}.buttons-container .button{padding:0 10px;width:100%;margin:8px 0 0;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.buttons-container button:last-of-type{background-color:#268bff;color:#fff;margin-left:.5rem}.buttons-container button.disabled{background:#bdbdbd;opacity:.5;color:#4a4a4a}.button{display:inline-block;margin:8px 4px 0 8px;padding:0 16px;border-radius:4px;text-align:center;outline:none;font-family:Roboto;font-size:.75rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:1.67;letter-spacing:normal;border:none;color:#268bff;background-color:#e5f1ff}.search-box{display:flex;align-items:center;color:#c8c8c8;border:1px solid #e6e6e6;border-radius:.125rem;margin:.25rem .4375rem .188rem;height:1.5rem;padding:.188rem 8px .188rem .5rem}.search-box .search-bar-close{margin-left:auto;float:right}.search-icon{margin:0 4px 0 0;font-size:1.125rem;color:#9b9b9b}.filter-icon{justify-content:right;margin-left:auto;color:#d4d4d4;color:#a1a1a1;font-size:16px;cursor:pointer}.data{margin:0 13px 0 8px;font-family:Roboto;font-size:.875rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:1.86;letter-spacing:\"\";color:#4a4a4a}.search-input{margin:1px 0 1px 4px;font-family:Roboto;font-size:.875rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal;color:#c8c8c8;width:calc(100% - 38px)}.check-box{color:#268bff}.tooltip-data-container{overflow-y:scroll;max-height:8rem}.searchbar{width:100%;display:flex;justify-content:flex-end;align-items:flex-end}.clear-button{opacity:.5;font-family:Roboto;font-size:.9375rem;font-weight:500;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal;text-decoration:underline;border:none;background-color:#fff;color:#4a4a4a;margin-left:.625rem;padding:0}.clear-button:focus{outline:none;box-shadow:none}.unchecked{color:#268bff}cdk-virtual-scroll-viewport.dropdown-data-container{max-height:12.3rem;width:100%;overflow-y:auto;overflow-x:hidden}cdk-virtual-scroll-viewport.dropdown-data-container p.input{margin-left:0}cdk-virtual-scroll-viewport.dropdown-data-container p.input span.mi{padding-left:.4375rem}cdk-virtual-scroll-viewport.dropdown-data-container p.input:hover{background-color:#ebebeb;cursor:pointer}cdk-virtual-scroll-viewport.dropdown-data-container::-webkit-scrollbar{width:.188rem}cdk-virtual-scroll-viewport.dropdown-data-container::-webkit-scrollbar-thumb{color:#d3d3d3;background:lightgray}section.min-maxContainer{display:flex;justify-content:center;margin-bottom:-.125rem;margin-top:.5rem;width:100%}section.min-maxContainer input{width:30%;height:1.875rem;border:1px solid lightgray;color:gray}section.min-maxContainer span{display:inline-block;padding-left:.5rem;padding-right:.5rem;position:relative;top:.3125rem;color:#666}.time-container{width:100%;display:flex;padding:0 .75rem}.time-container input.form-control:disabled{background-color:#fff;width:2.813rem}.time-container input.numberInput:focus{box-shadow:none;border-color:#c2cfd6}.time-container .dot{color:#cbcbcb;position:relative;left:-7px;font-size:17px}.time-container div.arrow-container{flex-direction:column;display:flex;margin-top:.375rem;width:9px;height:18px;margin-right:1.1875rem}.time-container div.arrow-container i{color:#000;cursor:pointer;max-height:9px;font-size:25px;width:10px}.time-container div.arrow-container i:before{width:0;height:0;pointer-events:none;position:relative;left:-9px;top:-11px}.mdi-filter{cursor:pointer}.time-label-container{display:flex;justify-content:flex-start}.time-label-container label{margin-bottom:0;color:#4a4a4a;margin-top:.125rem;margin-left:.625rem;font-weight:700}.time-heading{color:#000;font-size:.8125rem;text-align:left;padding-left:.625rem;margin-top:.625rem;font-weight:700}.column-clear-all{width:94%;text-align:center;border:none;font-size:14px;background:none;text-decoration:underline;color:#268bff}.checkbox-container{display:flex;padding-inline:.625rem}.checkbox-container .data{text-align:left}.checkbox-container:first-of-type{margin-top:.625rem;font-weight:500}.column-clear-all{width:94%;text-align:center;border:none;background:none;text-decoration:underline;color:#268bff}.column-clear-all:disabled{opacity:.5;color:#4a4a4a;font-weight:400}.column-clear-all.align-center{text-align:center}span.mdi-filter-variant.disabled{pointer-events:none;opacity:.5}.datepicker-container{width:100%}span.mdi-filter-variant{color:#cbcbcb;cursor:pointer;font-size:.875rem}span.mdi-filter-variant.active{color:#000}p.filter-tab{font-family:Roboto;font-size:14px;font-weight:400;font-stretch:normal;font-style:normal;line-height:1.29;letter-spacing:normal;color:#1b88ff;border-radius:5px;background-color:#f4f4f4;padding-inline:8px;cursor:pointer;overflow:hidden;text-align:center;text-overflow:ellipsis}p.filter-tab.active{color:#fff;background-color:#1b88ff}button.filter-text-btn{background:white;text-decoration:underline;font-family:Roboto;font-size:14px;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal;border:none;color:#268bff;margin-inline:4px;margin-top:2px}button.filter-text-btn:disabled{color:#b1b1b1;cursor:not-allowed}::ng-deep .non-edit-datepicker-tooltip .tooltip-inner{max-width:310px!important;width:283px!important;overflow-y:initial!important;padding:0!important}input.slider-text::-webkit-outer-spin-button,input.slider-text::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input.slider-text{-moz-appearance:textfield}input.slider-text.red-border{border:1px solid #f44336!important}::ng-deep .checkbox-sort p.sort-container{margin-top:8px!important;padding-bottom:8px!important}i.mdi-close{cursor:pointer}i.mdi-close.disable-close-icon{pointer-events:none;cursor:not-allowed}input.error-border{border:1px solid #f44336!important}::ng-deep .non-edit-checkbox-tooltip .tooltip-inner{width:238px!important;padding:0!important}::ng-deep .non-edit-slider-tooltip .tooltip-inner{width:238px!important;padding:0!important}::ng-deep .non-edit-time-tooltip .tooltip-inner{width:250px!important;padding:0!important}::ng-deep .non-edit-time-tooltip.bs-tooltip-start{padding:.4rem}::ng-deep .non-edit-time-tooltip.bs-tooltip-start .tooltip-arrow{right:0;top:5px!important;width:var(--bs-tooltip-arrow-height);height:var(--bs-tooltip-arrow-width)}::ng-deep .non-edit-time-tooltip.bs-tooltip-start .tooltip-arrow:before{border-left-color:#fff;left:-1px;border-width:calc(var(--bs-tooltip-arrow-width) * .5) 0 calc(var(--bs-tooltip-arrow-width) * .5) var(--bs-tooltip-arrow-height)}::ng-deep .no-bottom-border p.sort-container{border-bottom:none!important}::ng-deep .ngx-slider-pointer-min:after{display:none}::ng-deep .ngx-slider-pointer-max:after{display:none}::ng-deep .ngx-slider span.ngx-slider-pointer{width:12px;height:12px;top:-5px;background-color:#bdbdbd}::ng-deep .ngx-slider span.ngx-slider-bar{height:3px;background:#ededed}::ng-deep .ngx-slider span.ngx-slider-selection{background:#bdbdbd}::ng-deep .ngx-slider span.ngx-slider-bubble{bottom:-22px;font-size:12px;color:#333}::ng-deep .show-min.ngx-slider span.ngx-slider-model-value{background:white;box-shadow:0 6px 10px #0000004d,0 2px 2px #0003}::ng-deep .show-max.ngx-slider span.ngx-slider-model-high{background:white;box-shadow:none}::ng-deep .ngx-slider span.ngx-slider-combined{background:white;box-shadow:0 6px 10px #0000004d,0 2px 2px #0003}::ng-deep .ngx-slider{top:10px!important;margin:5px 0 2px!important}::ng-deep .ngx-slider-animate{top:0!important}.sidebar-slider{margin-bottom:35px!important;margin-left:5px;margin-right:5px}.slider-placeholder{height:14px}::ng-deep .filter-calendar select.form-select:focus{border-color:#c2cfd6;box-shadow:none}::ng-deep .filter-calendar select.form-select{background-color:#fff}.no-data-case{padding-left:.4375rem!important;font-size:.875rem!important;margin-top:10px!important;cursor:pointer}.check-mark,.unread-mark{cursor:pointer}.on-hover:hover .unread-mark,.notificationHover .check-mark{opacity:0;cursor:pointer}.on-hover:hover .check-mark{opacity:1;cursor:pointer}:host ::ng-deep .gt{table-layout:fixed;margin-bottom:0;width:100%}:host ::ng-deep .gt th,:host ::ng-deep .gt td{padding:2px 8px;line-height:normal}:host ::ng-deep .gt thead tr th .upper-label{font-family:Roboto;font-size:.6875rem;font-weight:500;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:.3px;color:#4a4a4a;margin-bottom:0}:host ::ng-deep .gt thead tr th .lower-label{font-family:Roboto;font-size:.6875rem;font-weight:500;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:.3px;color:#a7a7a7;margin-bottom:0}:host ::ng-deep .gt thead tr th{background-color:#ededed;position:sticky;position:-webkit-sticky;top:0;border-top:none!important;border-bottom:none!important;outline:none!important;box-shadow:inset 0 1px #d4d4d4,inset 0 -1px #d4d4d4,inset -1px 0 #d4d4d4}:host ::ng-deep .gt thead tr th br{display:block;content:\"\";margin-top:-8px}:host ::ng-deep .gt thead tr th div.row{display:flex;flex-wrap:nowrap;justify-content:space-between;align-items:center;width:max-content}:host ::ng-deep .gt thead tr th div.sort-filter-container{display:flex;flex-wrap:nowrap;align-items:center;margin-left:.25rem;margin-right:auto}:host ::ng-deep .gt thead tr th span.mdi-filter-variant{font-size:13px!important;top:-1px!important;position:relative}:host ::ng-deep .gt thead tr th:first-of-type{box-shadow:inset 0 1px #d4d4d4,inset 0 -1px #d4d4d4,inset -1px 0 #d4d4d4,inset 1px 0 #d4d4d4}:host ::ng-deep .gt tbody tr td:first-of-type{box-shadow:inset 1px 0 #d4d4d4,inset -1px 0 #d4d4d4,inset 0 -1px #d4d4d4;border:none}:host ::ng-deep .gt tbody tr td:nth-of-type(n + 2){box-shadow:inset -1px 0 #d4d4d4,inset 0 -1px #d4d4d4;border:none}:host ::ng-deep .gt tbody tr td .upper-label{font-family:Roboto;font-size:.75rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:0px;color:#000;display:inline-block;width:90%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}:host ::ng-deep .gt tbody tr td .lower-label{font-family:Roboto;font-size:.75rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:0px;color:#a7a7a7;display:inline-block;width:90%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}:host ::ng-deep .gt tbody tr br{display:block;content:\"\";margin-top:-8px}:host ::ng-deep .gt tbody tr:nth-of-type(1) td{border-top:none!important}:host ::ng-deep .gt .custom-column-checkbox-checked,:host ::ng-deep .gt .custom-column-checkbox-unchecked{font-size:.875rem;cursor:pointer}:host ::ng-deep .gt .custom-column-checkbox-checked{color:#268bff}:host ::ng-deep .gt .custom-column-checkbox-unchecked{color:#4a4a4a}:host ::ng-deep .bottom-border .gt tbody tr:last-of-type td:first-of-type{box-shadow:inset 1px 0 #d4d4d4,inset -1px 0 #d4d4d4}:host ::ng-deep .bottom-border .gt tbody tr:last-of-type td:nth-of-type(n + 2){box-shadow:inset -1px 0 #d4d4d4}.table-container{overflow-x:auto;overflow-y:auto}.rowSelectCheckbox,#selectAllRowsCheckbox{cursor:pointer}.disable-checkbox{color:#dedede!important;pointer-events:none!important}.mdi-warning{color:#f3c639;font-size:16px;line-height:28px}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{opacity:1}.redcolor-status{color:#c62a2a}#no-filter-space{width:.875rem}::ng-deep .mat-button-toggle-appearance-standard .mat-button-toggle-label-content{line-height:1.875rem!important;width:2.625rem;padding:0 .625rem}input.numberInput{margin-right:-.8125rem;padding:0 0 0 .625rem;height:1.875rem}::ng-deep .mat-button-toggle-checked{background-color:#268bff!important;color:#fff!important}::ng-deep .mat-button-toggle-group-appearance-standard{border-radius:0}.hidden{display:none}.no-data-div{margin-top:2.5px}.no-data-div label{margin:0;width:auto;font-weight:500;background-color:#d3d3d3;padding:.3125rem 1.125rem;border-radius:.25rem}.column-values:nth-of-type(2){color:#a7a7a7!important}.custom-column-checkbox-checked,.custom-column-checkbox-unchecked{font-size:.875rem;cursor:pointer}.custom-column-checkbox-checked{color:#268bff}.custom-column-checkbox-unchecked{color:#4a4a4a}.time-filter-checkboxes>div>p{color:#151b1e}::ng-deep .margin-bottom-zero .mat-radio-label{margin-bottom:0}:host ::ng-deep mat-radio-group br{margin-top:0!important}:host ::ng-deep mat-radio-group mat-radio-button .mdc-radio__background{width:var(--mat-radio-size);height:var(--mat-radio-size)}:host ::ng-deep mat-radio-group mat-radio-button .mdc-radio__inner-circle{border-width:calc(var(--mat-radio-size) / 2)}:host ::ng-deep mat-radio-group mat-radio-button .mdc-form-field>label{margin:0 0 0 4px;padding:0;top:-2px;position:relative}:host ::ng-deep mat-radio-group mat-radio-button .mdc-radio--disabled+label{color:var(--primary-text-color-dark)!important}:host ::ng-deep mat-radio-group mat-radio-button.mat-mdc-radio-button .mdc-form-field .mdc-radio{padding:0}:host ::ng-deep mat-radio-group mat-radio-button .mdc-form-field>label{left:-94px;font-size:12px;color:#4a4a4a;position:relative}::ng-deep .reject.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-outer-circle{border-color:#ff0}::ng-deep .reject.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-inner-circle{background-color:#ff0}::ng-deep .resubmit.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-outer-circle{border-color:#ff0}::ng-deep .resubmit.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-inner-circle{background-color:#ff0}::ng-deep .noAction.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-outer-circle{border-color:green}::ng-deep .noAction.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-inner-circle{background-color:green}::ng-deep .approve.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-outer-circle{border-color:green}::ng-deep .approve.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-inner-circle{background-color:green}::ng-deep .credit.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-outer-circle{border-color:red}::ng-deep .credit.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-inner-circle{background-color:red}::ng-deep .mat-radio-button.mat-radio-disabled .mat-radio-outer-circle{border-color:#00000061!important}::ng-deep .mat-radio-button.mat-radio-disabled.mat-radio-checked .mat-radio-inner-circle{background-color:#00000061!important}::ng-deep tr.white-background-row{background:white}::ng-deep tr.gray-background-row{background:rgba(233,233,233,.5)!important}.remarks-tooltip,.mdi-information,.mdi-information-outline,.seller-tooltip{font-size:.875rem;color:#268bff;position:relative;top:.1875rem;cursor:pointer}.seller-tooltip{top:-1px;float:right}::ng-deep .remarks-info-tooltip .tooltip-inner{max-width:19.25rem!important}.rating-icon,.lur-violation-icon{color:#268bff;cursor:pointer;position:relative;left:-2px}::ng-deep .rating-info-tooltip .tooltip-inner{max-width:800px!important}.spots-info-icon{color:#268bff;cursor:pointer;margin:1px 2px 0 -14px}.spots-info-icon-ol{color:#268bff;cursor:pointer;margin:1px 4px 0 -2px}::ng-deep .spot-info-tooltip .tooltip-inner{position:relative;max-width:220px!important;background:#fff;word-break:break-word;display:flex}::ng-deep .spot-info-tooltip-for-orderlisting-table .tooltip-inner{max-width:220px!important;background:#fff;word-break:break-word;display:flex}p.first-row{padding:.5rem .5rem 0;color:#000;white-space:nowrap;text-align:left}p.second-row{padding:2px .5rem .5rem;color:#000;white-space:nowrap;text-align:left}::ng-deep .gt-total-row-tooltip{opacity:1!important}::ng-deep .gt-total-row-tooltip .tooltip-inner{color:#000;box-shadow:0 6px 10px #0000004d,0 2px 2px #0003;background-color:#fff;padding:4px!important;width:100%;border-radius:2px!important}::ng-deep .gt-total-row-tooltip .arrow:before{border-top-color:#fff!important}.info-label{margin-left:4px;color:#268bff;vertical-align:text-top}::ng-deep .hierarchy-tooltip{max-width:-moz-fit-content;max-width:fit-content;width:310px!important}::ng-deep .hierarchy-tooltip .tooltip-inner{padding:4px!important;max-width:22.75rem;max-height:11.25rem}table.seller-hierarchy-table{table-layout:fixed}table.seller-hierarchy-table tr th{font-family:Roboto;font-size:.75rem;font-weight:500;font-stretch:normal;font-style:normal;line-height:1.67;letter-spacing:normal;color:#5e5e5e;white-space:nowrap;background:#ededed;position:sticky;box-shadow:inset 0 1px #d4d4d4;top:0;z-index:1}table.seller-hierarchy-table tr th:nth-child(1){width:20px}table.seller-hierarchy-table tr th:first-of-type,table.seller-hierarchy-table tr td:first-of-type{width:20px;border-left:1px solid #d4d4d4}table.seller-hierarchy-table tr th:last-of-type,table.seller-hierarchy-table tr td:last-of-type{border-right:1px solid #d4d4d4;width:7.875rem!important}table.seller-hierarchy-table tr th:nth-of-type(2){width:7.75rem!important}table.seller-hierarchy-table tr td{font-family:Roboto;font-size:.75rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal;color:#4a4a4a;box-shadow:none!important;border-top:1px solid #d4d4d4;border-bottom:1px solid #d4d4d4}table.seller-hierarchy-table tr td:nth-of-type(2),table.seller-hierarchy-table tr td:nth-of-type(3){padding-top:.25rem}table.seller-hierarchy-table tr td span{display:inline-block;width:90%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;position:relative}section.hierarchy-table-container{max-height:8.75rem;overflow:auto}section.hierarchy-table-container::-webkit-scrollbar-track{margin-top:1.5rem}.difference-text{padding:.5rem;color:#000;text-align:left}::ng-deep .posted-avg-tooltip .tooltip-inner{width:13.8125rem!important}::ng-deep .drrBooked-info-tooltip{transform:translate(26px,6px)}::ng-deep .drrBooked-info-tooltip .tooltip-inner{max-width:307px!important;width:242px!important;background:#fff;word-break:break-word;display:flex;padding:4px!important;text-align:left}::ng-deep .drrBooked-info-tooltip .tooltip-inner p{color:#000}::ng-deep .drrBooked-info-tooltip .arrow:before{border-right-color:#fff!important}.clickable-data{cursor:pointer;color:#268bff!important;display:flex!important;align-items:center}.clickable-data .spot-details-download-icons{font-size:12px}.disabled-clickable-data{pointer-events:none;color:#d4d4d4!important}.spot-column-tooltip-message{color:#000;width:max-content;text-align:left}div.spinner-for-button-directive{position:relative;left:-1px}.clickable-row table tr.mat-row td{cursor:pointer!important}.tooltip-div-container{text-align:left!important;padding:12px 4px;color:#4a4a4a!important;font-size:12px!important;font-family:Roboto;font-size:12px;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}.notification-tooltip-div-container{text-align:left!important;padding:6px 8px;color:#4a4a4a!important;font-size:12px!important;font-family:Roboto;font-size:12px;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}.mdi-information,.mdi-information-outline{left:3px;top:1px}.mdi-information-outline{position:static}::ng-deep .team-user-tooltip.bs-tooltip-top .arrow:before{border-top:6px solid white}::ng-deep .team-user-tooltip.bs-tooltip-left .arrow:before{border-left:6px solid white}::ng-deep .team-user-tooltip.bs-tooltip-bottom .arrow:before{border-bottom:6px solid white}::ng-deep .team-user-tooltip.bs-tooltip-right .arrow:before{border-right:5px solid white}::ng-deep .team-user-tooltip .tooltip-inner{opacity:1!important;width:-moz-fit-content!important;width:fit-content!important;max-width:520px;border-radius:2px;padding:0 4px!important}::ng-deep .team-user-tooltip .tooltip-inner .tooltip-inner{color:#4a4a4a;text-align:left;padding:8px!important;border-radius:2px;background:white!important;box-shadow:0 6px 10px #0000004d,0 2px 2px #0003;font-family:Roboto;font-size:12px;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}::ng-deep .team-user-tooltip .tooltip-inner.bs-tooltip-top .arrow:before{border-top:6px solid white}::ng-deep .team-user-tooltip .tooltip-inner.bs-tooltip-left .arrow:before{border-left:6px solid white}::ng-deep .team-user-tooltip .tooltip-inner.bs-tooltip-bottom .arrow:before{border-bottom:6px solid white}::ng-deep .team-user-tooltip .tooltip-inner.bs-tooltip-right .arrow:before{border-right:5px solid white}::ng-deep .gt-icon-column-tooltip{opacity:1!important}::ng-deep .gt-icon-column-tooltip .tooltip-inner{color:#4a4a4a;text-align:left;padding:8px!important;border-radius:2px;background:white!important;box-shadow:0 6px 10px #0000004d,0 2px 2px #0003;font-family:Roboto;font-size:12px;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}::ng-deep .gt-icon-column-tooltip.bs-tooltip-top .arrow:before{border-top:6px solid white}::ng-deep .gt-icon-column-tooltip.bs-tooltip-left .arrow:before{border-left:6px solid white}::ng-deep .gt-icon-column-tooltip.bs-tooltip-bottom .arrow:before{border-bottom:6px solid white}::ng-deep .gt-icon-column-tooltip.bs-tooltip-right .arrow:before{border-right:5px solid white}::ng-deep .gt-icon-column-tooltip .tooltip-inner{width:100%}::ng-deep .tooltip-containing-table{opacity:1!important}::ng-deep .tooltip-containing-table .tooltip-inner{color:#4a4a4a;text-align:left;padding:8px!important;border-radius:2px;background:white!important;box-shadow:0 6px 10px #0000004d,0 2px 2px #0003;font-family:Roboto;font-size:12px;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}::ng-deep .tooltip-containing-table.bs-tooltip-top .arrow:before{border-top:6px solid white}::ng-deep .tooltip-containing-table.bs-tooltip-left .arrow:before{border-left:6px solid white}::ng-deep .tooltip-containing-table.bs-tooltip-bottom .arrow:before{border-bottom:6px solid white}::ng-deep .tooltip-containing-table.bs-tooltip-right .arrow:before{border-right:5px solid white}::ng-deep .tooltip-containing-table li{margin:0!important;padding:0!important}::ng-deep .tooltip-containing-table ul{margin:0!important;padding-left:8px!important}::ng-deep .tooltip-containing-table .tooltip-inner{width:100%;max-width:230px}table.tooltip-table{table-layout:fixed;margin:4px 0 0;width:100%}table.tooltip-table th,table.tooltip-table td{padding:2px 8px;line-height:normal}table.tooltip-table thead tr th:first-of-type{box-shadow:inset 0 1px #d4d4d4,inset 0 -1px #d4d4d4,inset -1px 0 #d4d4d4,inset 1px 0 #d4d4d4!important;border:none}table.tooltip-table thead tr th{color:#5e5e5e!important;font-size:12px;font-weight:500;font-family:Roboto;line-height:1.67;background-color:#ededed;border-top:none!important;border-bottom:none!important;outline:none!important;box-shadow:inset 0 1px #d4d4d4,inset 0 -1px #d4d4d4,inset -1px 0 #d4d4d4}table.tooltip-table thead tr th div.row{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center}table.tooltip-table tbody tr td{color:#5e5e5e!important;font-size:12px;font-weight:500;font-family:Roboto;line-height:1.67}table.tooltip-table tbody tr td:first-of-type{box-shadow:inset 1px 0 #d4d4d4,inset -1px 0 #d4d4d4,inset 0 -1px #d4d4d4;border:none}table.tooltip-table tbody tr td:nth-of-type(n + 2){box-shadow:inset -1px 0 #d4d4d4,inset 0 -1px #d4d4d4;border:none}.bottom-border{border-bottom:1px solid #d4d4d4!important}i.disabled{pointer-events:none!important}\n"] }]
775
- }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.AnnaSortService }, { type: i2.AnnaDateTimeFormatService }, { type: i3.AnnaFilterService }]; }, propDecorators: { showSkeletonLoading: [{
776
- type: Input
777
- }], tableHeaders: [{
778
- type: Input
779
- }], tableData: [{
780
- type: Input
781
- }], clonedTableData: [{
782
- type: Input
783
- }], gtGeneralConfig: [{
784
- type: Input
785
- }], totalRowInfo: [{
786
- type: Input
787
- }], gtDimension: [{
788
- type: Input
789
- }], tableClass: [{
790
- type: Input
791
- }], maximumRowsWhichCanBeRenderedWithoutScroll: [{
792
- type: Input
793
- }], fixNumberOfRowsForPopup: [{
794
- type: Input
795
- }], limit: [{
796
- type: Input
797
- }], includeBorderInTableHeight: [{
798
- type: Input
799
- }], downloadInProgress: [{
800
- type: Input
801
- }], percentDone: [{
802
- type: Input
803
- }], starredInProgress: [{
804
- type: Input
805
- }], clickableRow: [{
806
- type: Input
807
- }], setTableHeightWhenRowSizeIsFixed: [{
808
- type: Input
809
- }], tableBorderBottomClassRequired: [{
810
- type: Input
811
- }], hideSomeTds: [{
812
- type: Input
813
- }], tdsHaveRowSpan: [{
814
- type: Input
815
- }], multipleTablesPresent: [{
816
- type: Input
817
- }], toggleCheckbox: [{
818
- type: Output
819
- }], toggleRowCheckbox: [{
820
- type: Output
821
- }], toggleHeaderCheckbox: [{
822
- type: Output
823
- }], undoIconClicked: [{
824
- type: Output
825
- }], filterAppliedToTable: [{
826
- type: Output
827
- }], sortingAppliedToTable: [{
828
- type: Output
829
- }], rowClicked: [{
830
- type: Output
831
- }], radioButtonSelected: [{
832
- type: Output
833
- }], columnFilterOpened: [{
834
- type: Output
835
- }], columnFilterClosed: [{
836
- type: Output
837
- }], gtIconClicked: [{
838
- type: Output
839
- }], gtSVGIconClicked: [{
840
- type: Output
841
- }], gtTextActionClicked: [{
842
- type: Output
843
- }], gtViewDetailClicked: [{
844
- type: Output
845
- }], gtInnerHTMLClicked: [{
846
- type: Output
847
- }], downloadSpotDetails: [{
848
- type: Output
849
- }], clickableDataClicked: [{
850
- type: Output
851
- }], totalRowIconClicked: [{
852
- type: Output
853
- }], notificationIconHover: [{
854
- type: Output
855
- }], notificationIconHoverLeave: [{
856
- type: Output
857
- }], editableInputEdited: [{
858
- type: Output
859
- }], radioButtonMessageIconClicked: [{
860
- type: Output
861
- }], viewChildTableHeaders: [{
862
- type: ViewChildren,
863
- args: ['tableHeader']
864
- }] } });
865
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"anna-non-editable-generic-table.component.js","sourceRoot":"","sources":["../../../../../../../projects/anna-core/src/lib/anna-generic-table-lib/components/anna-non-editable-generic-table/anna-non-editable-generic-table.component.ts","../../../../../../../projects/anna-core/src/lib/anna-generic-table-lib/components/anna-non-editable-generic-table/anna-non-editable-generic-table.component.html"],"names":[],"mappings":"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","sourcesContent":["// Angular import statements\r\nimport {\r\n    Component,\r\n    OnInit,\r\n    Input,\r\n    ViewChildren,\r\n    QueryList,\r\n    Output,\r\n    EventEmitter,\r\n    SimpleChanges,\r\n    OnChanges,\r\n    ChangeDetectorRef,\r\n    ElementRef,\r\n    AfterViewChecked,\r\n    ChangeDetectionStrategy,\r\n} from '@angular/core';\r\n\r\n// Third party import statements\r\nimport { cloneDeep, isEqual, uniq } from 'lodash-es';\r\n\r\n//sub-entries of anna lib import statement\r\nimport {\r\n    IGtGeneralConfig,\r\n    IGtTableHeader,\r\n    IHeaderInfo,\r\n    ITotalRowInfo,\r\n} from '../../../anna-core-shared-lib/models/anna-non-editable-gt-models';\r\nimport { AnnaDateTimeFormatService } from '../../../anna-core-shared-lib/services/anna-date-time-format.service';\r\nimport { IWeekCalendar } from '../../../anna-core-shared-lib/models/anna-global-dropdown-config.model';\r\nimport {\r\n    GtColumnIconEmittedData,\r\n    RatingSellerGroupHierarchy,\r\n} from '../../../anna-core-shared-lib/models/anna-generic-data-type.model';\r\nimport { radioButtonModel } from '../../../anna-core-shared-lib/models/anna-tooltip.model';\r\nimport { AnnaSortService } from '../../../anna-core-shared-lib/services/anna-sort.service';\r\nimport { AnnaFilterService } from '../../../anna-core-shared-lib/services/anna-filter.service';\r\nimport { BehaviorSubject } from 'rxjs';\r\nimport { NgCircleProgressModule } from 'ng-circle-progress';\r\nimport { AnnaColumnTimeFilterComponent } from '../anna-column-filters/anna-column-time-filter/anna-column-time-filter.component';\r\nimport { AnnaColumnDateRangeFilterComponent } from '../anna-column-filters/anna-column-date-range-filter/anna-column-date-range-filter.component';\r\nimport { AnnaColumnSliderFilterComponent } from '../anna-column-filters/anna-column-slider-filter/anna-column-slider-filter.component';\r\nimport { AnnaColumnCheckboxFilterComponent } from '../anna-column-filters/anna-column-checkbox-filter/anna-column-checkbox-filter.component';\r\nimport { AnnaNoDataComponent } from '../../../anna-core-shared-lib/components/anna-no-data/anna-no-data.component';\r\nimport { MatRadioModule } from '@angular/material/radio';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { AnnaIconColumnComponent } from '../../../anna-core-shared-lib/components/anna-icon-column/anna-icon-column.component';\r\nimport { showEllipsisTextOnHoverDirective } from '../../../anna-core-shared-lib/directives/show-ellipsis-text/show-ellipsis-text.directive';\r\nimport { NgxSkeletonLoaderModule } from 'ngx-skeleton-loader';\r\nimport { NgbTooltip } from '@ng-bootstrap/ng-bootstrap';\r\nimport { MatTableModule } from '@angular/material/table';\r\nimport {\r\n    NgClass,\r\n    NgStyle,\r\n    NgFor,\r\n    NgIf,\r\n    NgTemplateOutlet,\r\n    NgSwitch,\r\n    NgSwitchCase,\r\n    NgSwitchDefault,\r\n    AsyncPipe,\r\n} from '@angular/common';\r\n\r\ninterface keyValueTooltipType {\r\n    key: string;\r\n    value: string;\r\n}\r\ninterface tableTooltipType {\r\n    tooltipTableHeader: string[];\r\n    tooltipTableBody: string[][];\r\n    tableHeaderMsg: string[];\r\n    tableFooterMsg: string[];\r\n    innerHtml: string;\r\n}\r\n\r\n@Component({\r\n    selector: 'anna-core-non-editable-generic-table-lib',\r\n    templateUrl: './anna-non-editable-generic-table.component.html',\r\n    styleUrls: ['./anna-non-editable-generic-table.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    standalone: true,\r\n    imports: [\r\n        NgClass,\r\n        NgStyle,\r\n        MatTableModule,\r\n        NgFor,\r\n        NgIf,\r\n        NgTemplateOutlet,\r\n        NgbTooltip,\r\n        NgxSkeletonLoaderModule,\r\n        showEllipsisTextOnHoverDirective,\r\n        NgSwitch,\r\n        NgSwitchCase,\r\n        AnnaIconColumnComponent,\r\n        FormsModule,\r\n        MatRadioModule,\r\n        NgSwitchDefault,\r\n        AnnaNoDataComponent,\r\n        AnnaColumnCheckboxFilterComponent,\r\n        AnnaColumnSliderFilterComponent,\r\n        AnnaColumnDateRangeFilterComponent,\r\n        AnnaColumnTimeFilterComponent,\r\n        NgCircleProgressModule,\r\n        AsyncPipe,\r\n    ],\r\n})\r\nexport class AnnaNonEditableGenericTableComponent implements OnInit, OnChanges, AfterViewChecked {\r\n    @Input() showSkeletonLoading: boolean;\r\n    @Input() tableHeaders: IGtTableHeader[];\r\n    @Input() tableData: any[];\r\n    @Input() clonedTableData: any[];\r\n    @Input() gtGeneralConfig: IGtGeneralConfig;\r\n    @Input() totalRowInfo?: ITotalRowInfo[];\r\n    @Input() gtDimension: {\r\n        rowHeight: number;\r\n        headerHeight: number;\r\n        dataOnTopHeight: number;\r\n        marginFromBottom: number;\r\n        tableHeight?: string;\r\n    };\r\n    @Input() tableClass: string;\r\n    @Input() maximumRowsWhichCanBeRenderedWithoutScroll: number = 5;\r\n    @Input() fixNumberOfRowsForPopup: boolean = false;\r\n    @Input() limit: number = 30;\r\n    @Input() includeBorderInTableHeight: boolean = true;\r\n    @Input() downloadInProgress: boolean;\r\n    @Input() percentDone: number;\r\n    @Input() starredInProgress: boolean;\r\n    @Input() clickableRow: boolean = false;\r\n    @Input() setTableHeightWhenRowSizeIsFixed: boolean = true;\r\n    @Input() tableBorderBottomClassRequired: boolean = true;\r\n    @Input() hideSomeTds: boolean = false;\r\n    @Input() tdsHaveRowSpan: boolean = false;\r\n    @Input() multipleTablesPresent: boolean = false;\r\n\r\n    @Output() toggleCheckbox = new EventEmitter();\r\n    @Output() toggleRowCheckbox = new EventEmitter();\r\n    @Output() toggleHeaderCheckbox = new EventEmitter();\r\n    @Output() undoIconClicked = new EventEmitter();\r\n    @Output() filterAppliedToTable = new EventEmitter();\r\n    @Output() sortingAppliedToTable = new EventEmitter();\r\n    @Output() rowClicked = new EventEmitter();\r\n    @Output() radioButtonSelected = new EventEmitter();\r\n    @Output() columnFilterOpened = new EventEmitter();\r\n    @Output() columnFilterClosed = new EventEmitter();\r\n    @Output() gtIconClicked = new EventEmitter();\r\n    @Output() gtSVGIconClicked = new EventEmitter();\r\n    @Output() gtTextActionClicked = new EventEmitter();\r\n    @Output() gtViewDetailClicked = new EventEmitter();\r\n    @Output() gtInnerHTMLClicked = new EventEmitter();\r\n    @Output() downloadSpotDetails = new EventEmitter();\r\n    @Output() clickableDataClicked = new EventEmitter();\r\n    @Output() totalRowIconClicked = new EventEmitter();\r\n    @Output() notificationIconHover = new EventEmitter();\r\n    @Output() notificationIconHoverLeave = new EventEmitter();\r\n    @Output() editableInputEdited = new EventEmitter();\r\n    @Output() radioButtonMessageIconClicked = new EventEmitter();\r\n\r\n    numberOfSkeletonRows: number[][] = Array(20).fill(0);\r\n    tableDataWrapper: any[];\r\n    rowChecked: boolean;\r\n    isAllRowsChecked: boolean;\r\n    noDataWidth: string = '50%';\r\n    markedForCreditStatus: string;\r\n    markedForMGStatus: string;\r\n    filterAlignment: string = 'bottom auto';\r\n\r\n    //Sort and Filter\r\n    tooltipRadioTextMap: Map<any, any>;\r\n    filterTabObjects: any[];\r\n    tooltip: any;\r\n    disableColumnClearAllBtn: boolean = true;\r\n    margin = 5;\r\n\r\n    //Week Filter\r\n    multiWeekPickerConfig: IWeekCalendar;\r\n\r\n    tableColumns: string[] = [];\r\n    totalRowColumns: string[] = null;\r\n    bindValueFuncCalled: boolean;\r\n\r\n    hierarchyTooltip: { open: () => void; close: () => void };\r\n    sellerGroupHierarchy: RatingSellerGroupHierarchy[];\r\n    showFilterTooltipTabs: boolean; //Change the Name\r\n\r\n    isScrolledLeft: boolean = false;\r\n    rowBorderWidth: number = 2;\r\n\r\n    sameTooltipClicked: boolean;\r\n    isScrollEnded: boolean = true;\r\n    marginTop: string = '';\r\n    @ViewChildren('tableHeader') viewChildTableHeaders: QueryList<ElementRef>;\r\n\r\n    isDifferenceLessThan25Percent: boolean;\r\n    start: number = 0;\r\n    end: number = this.limit + this.start;\r\n    renderedData: any[];\r\n    selectedInventoryIdForDownload: number;\r\n    selectedDemographicForDownload: any;\r\n    selectedRowTypeForDownload: string;\r\n    heightOfCheckboxTooltipFilter: number;\r\n    isNoDataToDisplaySubject$ = new BehaviorSubject<boolean>(false);\r\n    selectedStarredOrderId: string;\r\n\r\n    textActionTooltip: keyValueTooltipType[] = [];\r\n    tooltipContainingTable: tableTooltipType = null;\r\n    tableBottomBorderClass: string = null;\r\n    showCheckboxesForTimeFilter: boolean = false;\r\n\r\n    constructor(\r\n        private cdRef: ChangeDetectorRef,\r\n        private annaSortService: AnnaSortService,\r\n        public annaDateTimeFormatService: AnnaDateTimeFormatService,\r\n        public annaFilterService: AnnaFilterService,\r\n    ) {\r\n        this.setTooltipRadioNames();\r\n    }\r\n\r\n    ngAfterViewChecked(): void {\r\n        this.setMarginLeftForFilterIcon();\r\n    }\r\n\r\n    ngOnInit() {\r\n        this.setFilterAlignmentBasedOnScreenResolution();\r\n    }\r\n\r\n    detectChanges() {\r\n        this.cdRef.detectChanges();\r\n    }\r\n\r\n    ngOnChanges(changes: SimpleChanges) {\r\n        if (\r\n            changes &&\r\n            changes['gtDimension'] &&\r\n            changes['gtDimension'].currentValue &&\r\n            this.setTableHeightWhenRowSizeIsFixed\r\n        ) {\r\n            this.setTableHeight();\r\n            this.setTableBottomBorder();\r\n        }\r\n        if (this.showSkeletonLoading) {\r\n            this.tableData = this.numberOfSkeletonRows;\r\n            this.renderedData = this.numberOfSkeletonRows;\r\n            this.isNoDataToDisplaySubject$.next(false);\r\n            this.setTableBottomBorder();\r\n        } else if (\r\n            changes['percentDone'] ||\r\n            changes['downloadInProgress'] ||\r\n            (changes['starredInProgress'] && changes['starredInProgress'].currentValue != undefined)\r\n        ) {\r\n            //no task will be performed\r\n        } else {\r\n            this.setInitialRowsForTable();\r\n            this.disableEnableEachColumnTooltipIcon();\r\n            this.tableColumns = this.tableHeaders.filter((x) => x.visible).map((x) => x.headerInfo[0].objectKey);\r\n            if (\r\n                (this.tableData && this.tableData.length == 0) ||\r\n                (this.tableData.length == 2 && this.checkIfAllTheElementsAreZero())\r\n            ) {\r\n                this.tableData = Array(2).fill(0);\r\n                this.renderedData = cloneDeep(this.tableData);\r\n                this.marginTop = -this.gtDimension.rowHeight - this.gtDimension.rowHeight / 2 + 'px';\r\n                this.isNoDataToDisplaySubject$.next(true);\r\n            } else {\r\n                this.isNoDataToDisplaySubject$.next(false);\r\n            }\r\n\r\n            this.showSkeletonLoading = false;\r\n            this.setTableBottomBorder();\r\n        }\r\n\r\n        //setting table column here as well because while showing skeleton loader, we should show table headers.\r\n        if (\r\n            changes['tableHeaders'] &&\r\n            !isEqual(changes['tableHeaders'].currentValue, changes['tableHeaders'].previousValue)\r\n        ) {\r\n            this.tableColumns = this.tableHeaders.filter((x) => x.visible).map((x) => x.headerInfo[0].objectKey);\r\n            this.annaSortService.columnSortState = new Map();\r\n            this.annaFilterService.initialValueMap = new Map();\r\n            // this.setColumnSortStateMap();\r\n            this.setActiveStateObject();\r\n        }\r\n\r\n        if (changes['totalRowInfo'] && changes['totalRowInfo'].currentValue) {\r\n            this.totalRowColumns = this.totalRowInfo.map((x) => x.colName);\r\n        }\r\n        this.cdRef.detectChanges();\r\n    }\r\n\r\n    setFilterAlignmentBasedOnScreenResolution() {\r\n        let viewportHeight = window.innerHeight;\r\n        if (viewportHeight < 740) {\r\n            this.filterAlignment = 'left right';\r\n        } else {\r\n            this.filterAlignment = 'bottom left right';\r\n        }\r\n    }\r\n\r\n    setTableBottomBorder() {\r\n        if (\r\n            this.tableBorderBottomClassRequired &&\r\n            this.tableData &&\r\n            this.tableData.length &&\r\n            this.maximumRowsWhichCanBeRenderedWithoutScroll < this.tableData.length\r\n        ) {\r\n            this.tableBottomBorderClass = 'bottom-border';\r\n        } else {\r\n            this.tableBottomBorderClass = null;\r\n        }\r\n    }\r\n\r\n    checkIfAllTheElementsAreZero() {\r\n        return !this.tableData.some((item) => item != 0);\r\n    }\r\n\r\n    setTableHeight() {\r\n        let viewportHeight = window.innerHeight;\r\n        let rowHeight = this.gtDimension.rowHeight;\r\n        let headerHeight = this.gtDimension.headerHeight;\r\n        let dataOnTopHeight = this.gtDimension.dataOnTopHeight;\r\n        let marginFromBottom = this.gtDimension.marginFromBottom;\r\n        let actualTableHeight;\r\n\r\n        if (this.fixNumberOfRowsForPopup) {\r\n            let maxNoOfRowsToDisplay = viewportHeight < 740 ? 5 : 10;\r\n            this.maximumRowsWhichCanBeRenderedWithoutScroll = maxNoOfRowsToDisplay;\r\n            actualTableHeight = this.maximumRowsWhichCanBeRenderedWithoutScroll * rowHeight + headerHeight;\r\n        } else {\r\n            let minHeightForTable = headerHeight + 3 * rowHeight;\r\n            viewportHeight = viewportHeight <= dataOnTopHeight ? dataOnTopHeight + minHeightForTable : viewportHeight;\r\n            let heightLeftForTable = viewportHeight - dataOnTopHeight - marginFromBottom;\r\n            this.maximumRowsWhichCanBeRenderedWithoutScroll =\r\n                Math.ceil((heightLeftForTable - headerHeight - rowHeight) / rowHeight) + 1;\r\n            actualTableHeight = viewportHeight - dataOnTopHeight - marginFromBottom;\r\n        }\r\n\r\n        // let actualTableHeight = heightLeftForTable - ((heightLeftForTable - headerHeight - rowHeight) % rowHeight);\r\n\r\n        this.gtDimension.tableHeight = `${actualTableHeight}px`;\r\n\r\n        this.numberOfSkeletonRows = this.maximumRowsWhichCanBeRenderedWithoutScroll\r\n            ? Array(this.maximumRowsWhichCanBeRenderedWithoutScroll).fill(0)\r\n            : Array(5).fill(0);\r\n    }\r\n\r\n    trackByFn(index: number) {\r\n        return index;\r\n    }\r\n\r\n    setTooltipRadioNames() {\r\n        this.tooltipRadioTextMap = new Map();\r\n        this.tooltipRadioTextMap.set('StartTimeForFilter', 'Start Time');\r\n        this.tooltipRadioTextMap.set('EndTimeForFilter', 'End Time');\r\n        this.tooltipRadioTextMap.set('startTimeForFilter', 'Start Time');\r\n        this.tooltipRadioTextMap.set('endTimeForFilter', 'End Time');\r\n        this.tooltipRadioTextMap.set('start_time_for_filter', 'Start Time');\r\n        this.tooltipRadioTextMap.set('end_time_for_filter', 'End Time');\r\n        this.tooltipRadioTextMap.set('primaryAEName', 'Primary AE');\r\n        this.tooltipRadioTextMap.set('region', 'Region');\r\n        this.tooltipRadioTextMap.set('agencyName', 'Agency');\r\n        this.tooltipRadioTextMap.set('location', 'Location');\r\n        this.tooltipRadioTextMap.set('advertiserName', 'Advertiser');\r\n        this.tooltipRadioTextMap.set('productCode', 'Product Code');\r\n        this.tooltipRadioTextMap.set('flightStartDate', 'Start Date');\r\n        this.tooltipRadioTextMap.set('flightEndDate', 'End Date');\r\n        this.tooltipRadioTextMap.set('orderIdAndRevNumber', 'STN Order#-Rev#');\r\n        this.tooltipRadioTextMap.set('stationOrderNumber', 'STN Order#');\r\n        this.tooltipRadioTextMap.set('alternateOrderId', 'Alt/Rep Order #');\r\n        this.tooltipRadioTextMap.set('grp', 'GRP');\r\n        this.tooltipRadioTextMap.set('cpp', 'CPP');\r\n        this.tooltipRadioTextMap.set('imps', 'IMPS');\r\n        this.tooltipRadioTextMap.set('cpm', 'CPM');\r\n        this.tooltipRadioTextMap.set('offeredMGs', 'Offered MG');\r\n        this.tooltipRadioTextMap.set('outstandingPE', 'O/S PE');\r\n        this.tooltipRadioTextMap.set('offeredADUs', 'Offered ADUs');\r\n        this.tooltipRadioTextMap.set('udDeficitValue', 'O/S Aud Delta');\r\n        this.tooltipRadioTextMap.set('startEndTimeMulti', 'Time');\r\n        this.tooltipRadioTextMap.set('bookedValue', 'Booked');\r\n        this.tooltipRadioTextMap.set('bookedSpots', 'Spots');\r\n        this.tooltipRadioTextMap.set('UserCreditedValue', 'User Credited');\r\n        this.tooltipRadioTextMap.set('UserUnresolvedValue', 'User Unresolved');\r\n        this.tooltipRadioTextMap.set('BuyerAddedValue', 'Buyer Added');\r\n        this.tooltipRadioTextMap.set('BuyerDeletedValue', 'Buyer Deleted');\r\n        this.tooltipRadioTextMap.set('userChanges', 'User Changes');\r\n        this.tooltipRadioTextMap.set('buyerChanges', 'Buyer Changes');\r\n        this.tooltipRadioTextMap.set('userMG', 'User MG');\r\n        this.tooltipRadioTextMap.set('userADUs', 'User ADUs');\r\n        this.tooltipRadioTextMap.set('inventoryCode', 'Inventory Code');\r\n        this.tooltipRadioTextMap.set('program', 'Program');\r\n        this.tooltipRadioTextMap.set('agency', 'Agency');\r\n        this.tooltipRadioTextMap.set('advertiser', 'Advertiser');\r\n        this.tooltipRadioTextMap.set('startDate', 'Start Date');\r\n        this.tooltipRadioTextMap.set('endDate', 'End Date');\r\n        this.tooltipRadioTextMap.set('date', 'Date');\r\n        this.tooltipRadioTextMap.set('rcvPreempt', '$ Madegood PEs');\r\n        this.tooltipRadioTextMap.set('osPreempt', '$ O/S PEs');\r\n        this.tooltipRadioTextMap.set('rcvUnderDly', 'Recovered UD');\r\n        this.tooltipRadioTextMap.set('osUnderDly', 'O/s Under Dly');\r\n        this.tooltipRadioTextMap.set('primaryAe', 'Primary AE');\r\n        this.tooltipRadioTextMap.set('region', 'Region');\r\n        this.tooltipRadioTextMap.set('revCode1', 'Rev code 1');\r\n        this.tooltipRadioTextMap.set('orderNoRevNo', 'STN Order#-Rev#');\r\n        this.tooltipRadioTextMap.set('revCode2', 'Rev code 2');\r\n        this.tooltipRadioTextMap.set('revCode3', 'Rev code 3');\r\n        this.tooltipRadioTextMap.set('booked', '$ Booked');\r\n        this.tooltipRadioTextMap.set('spots', 'Spots');\r\n        this.tooltipRadioTextMap.set('postedAudPercent', 'Posted %');\r\n        this.tooltipRadioTextMap.set('revision', 'Revision');\r\n        this.tooltipRadioTextMap.set('buyerOrderId', 'ALT/REP Order#');\r\n        this.tooltipRadioTextMap.set('demo', 'Demo');\r\n        this.tooltipRadioTextMap.set('postedAdu', '$ Posted ADUs');\r\n        this.tooltipRadioTextMap.set('scheduledAdu', '$ Scheduled ADUs');\r\n        this.tooltipRadioTextMap.set('audienceDeficit', '$ O/S Audience');\r\n        this.tooltipRadioTextMap.set('postedAudPercent', 'Posted Audience %');\r\n        this.tooltipRadioTextMap.set('potentialUnitsValue', 'POT Units');\r\n        this.tooltipRadioTextMap.set('bookedUnitsValue', 'Booked Eq Units');\r\n        this.tooltipRadioTextMap.set('bookedAmountWithZeroRatingValue', 'Total $ Booked');\r\n        this.tooltipRadioTextMap.set('bookedAmountPercentageWithZeroRatingValue', '% Against All Demos');\r\n        this.tooltipRadioTextMap.set('bookedAmountWithoutZeroRatingValue', '$Booked With Imps(’000)');\r\n        this.tooltipRadioTextMap.set('bookedAmountPercentageWithoutZeroRatingValue', '% Against All Demos');\r\n\r\n        this.tooltipRadioTextMap.set('totalBookedAmountValue', 'Total $Booked');\r\n        this.tooltipRadioTextMap.set('averageUnitRateValue', ' AUR');\r\n        this.tooltipRadioTextMap.set('totalBookedAmountWithRatingValue', '$Booked With Rating');\r\n        this.tooltipRadioTextMap.set('averageUnitRateWithRatingValue', 'AUR With Rating');\r\n\r\n        this.tooltipRadioTextMap.set('totalBookedAmountWithImpressionValue', '$Booked With IMPS');\r\n        this.tooltipRadioTextMap.set('averageUnitRateWithImpressionValue', 'AUR With IMPS');\r\n\r\n        this.tooltipRadioTextMap.set('bookedUnitsWithRatingValue', 'Booked Units With Rating');\r\n        this.tooltipRadioTextMap.set('postedUnitsWithRatingValue', 'Posted Units With Rating');\r\n\r\n        this.tooltipRadioTextMap.set('bookedUnitsWithImpressionValue', 'Booked Units With IMPS');\r\n        this.tooltipRadioTextMap.set('postedUnitsWithImpressionValue', 'Posted Units With IMPS');\r\n\r\n        this.tooltipRadioTextMap.set('bookedRatings', 'Booked Rating');\r\n        this.tooltipRadioTextMap.set('postedRatings', 'POSTED Rating');\r\n        this.tooltipRadioTextMap.set('PostedRating', 'Posted RTG');\r\n\r\n        this.tooltipRadioTextMap.set('bookedImpressions', \"Booked IMP('000)\");\r\n        this.tooltipRadioTextMap.set('postedImpressions', \"Posted IMP('000)\");\r\n        this.tooltipRadioTextMap.set('PostedImpressions', \"Posted IMP('000)\");\r\n\r\n        this.tooltipRadioTextMap.set('bookedAverageRating', 'Booked AU Rating');\r\n        this.tooltipRadioTextMap.set('postedAverageRating', 'Posted AU Rating');\r\n\r\n        this.tooltipRadioTextMap.set('bookedAverageImpression', 'Booked AU IMPS');\r\n        this.tooltipRadioTextMap.set('postedAverageImpression', 'Posted AU IMPS');\r\n\r\n        this.tooltipRadioTextMap.set('bookedCppValue', 'Booked CPP');\r\n        this.tooltipRadioTextMap.set('bookedEffectiveCppValue', 'Effective CPP');\r\n\r\n        this.tooltipRadioTextMap.set('bookedCpmValue', 'Booked CPM');\r\n        this.tooltipRadioTextMap.set('bookedEffectiveCpmValue', 'Effective CPM');\r\n\r\n        this.tooltipRadioTextMap.set('orderSource', 'Order Route');\r\n        this.tooltipRadioTextMap.set('orderCategory', 'Rev Category');\r\n        this.tooltipRadioTextMap.set('cashOrTrade', 'C/T');\r\n        this.tooltipRadioTextMap.set('revisionStartDate', 'Revision Start Date');\r\n        this.tooltipRadioTextMap.set('name', 'name');\r\n        this.tooltipRadioTextMap.set('role', 'role');\r\n        this.tooltipRadioTextMap.set('stationCount', 'stationCount');\r\n        this.tooltipRadioTextMap.set('stationList', 'stationList');\r\n        this.tooltipRadioTextMap.set('approvedOn', 'Approved On');\r\n        this.tooltipRadioTextMap.set('approvedBy', 'Approved By');\r\n        this.tooltipRadioTextMap.set('ODImps', 'Proj. OD IMPS');\r\n        this.tooltipRadioTextMap.set('UDImps', 'Proj. UD IMPS');\r\n        this.tooltipRadioTextMap.set('ODGrp', 'Proj. OD GRP');\r\n        this.tooltipRadioTextMap.set('UDGrp', 'Proj. UD GRP');\r\n        this.tooltipRadioTextMap.set('udImpsPercent', 'Proj. UD %');\r\n        this.tooltipRadioTextMap.set('udGrpPercent', 'Proj. UD GRP %');\r\n        this.tooltipRadioTextMap.set('odImpsPercent', 'Proj. OD %');\r\n        this.tooltipRadioTextMap.set('odGrpPercent', 'Proj. OD GRP %');\r\n\r\n        this.tooltipRadioTextMap.set('RevisionNumber', 'Revision #');\r\n        this.tooltipRadioTextMap.set('RevisionType', 'Revision Type');\r\n        this.tooltipRadioTextMap.set('GeneratedOn', 'Generated On');\r\n        this.tooltipRadioTextMap.set('BookedValueForDisplay', '$ BOOKED');\r\n        this.tooltipRadioTextMap.set('BookedValue', '$ Booked');\r\n        this.tooltipRadioTextMap.set('BookedSpots', 'Spots');\r\n        this.tooltipRadioTextMap.set('BookedGRP', 'GRP');\r\n        this.tooltipRadioTextMap.set('BookedIMPSRevTab', \"IMPS'(000)\");\r\n        this.tooltipRadioTextMap.set('BookedCPP', 'CPP');\r\n        this.tooltipRadioTextMap.set('BookedCPM', 'CPM');\r\n        this.tooltipRadioTextMap.set('MGsValueForDisplay', '$ MGS');\r\n        this.tooltipRadioTextMap.set('MGsValue', '$ MGS');\r\n        this.tooltipRadioTextMap.set('ADUsValueForDisplay', '$ ADUS');\r\n        this.tooltipRadioTextMap.set('ADUsValue', '$ ADUS');\r\n        this.tooltipRadioTextMap.set('BuyerChangesValueForDisplay', '$ Buyer Change');\r\n        this.tooltipRadioTextMap.set('BuyerChangesValue', '$ Buyer Change');\r\n        this.tooltipRadioTextMap.set('UserChangesValueForDisplay', '$ Seller User Change');\r\n        this.tooltipRadioTextMap.set('UserChangesValue', '$ Seller User Change');\r\n        this.tooltipRadioTextMap.set('SellerLine', 'Seller Line #');\r\n        this.tooltipRadioTextMap.set('BuyerLine', 'Buy Line #');\r\n        this.tooltipRadioTextMap.set('SpotStatus', 'Spot Status');\r\n        this.tooltipRadioTextMap.set('InventoryCode', 'Inventory Code');\r\n        this.tooltipRadioTextMap.set('BuyerProgramName', 'Buyer Program Name');\r\n        this.tooltipRadioTextMap.set('RevenueClass', 'Revenue Class');\r\n        this.tooltipRadioTextMap.set('WeeklyAUR', 'Booked Avg. Rate');\r\n        this.tooltipRadioTextMap.set('BookedRate', 'Booked Rate');\r\n        this.tooltipRadioTextMap.set('averageRate', 'Average Rate');\r\n        this.tooltipRadioTextMap.set('bookedAverageRate','Booked AVG. Rate')\r\n        this.tooltipRadioTextMap.set('dollarIMPSImpact', '$ IMPS Impact');\r\n        this.tooltipRadioTextMap.set('dollarRTGImpact', '$ RTG IMPACT');\r\n        this.tooltipRadioTextMap.set('IMPSImpact', \"IMPS ('000) IMPACT\");\r\n        this.tooltipRadioTextMap.set('RTGImpact', 'RTG Impact');\r\n\r\n        this.tooltipRadioTextMap.set('inventoryFillPercentageSameWeek', 'Inv Fill Same Week');\r\n        this.tooltipRadioTextMap.set('inventoryFillPercentageFinal', 'Inv Fill Final');\r\n\r\n        this.tooltipRadioTextMap.set('projectedRTG', 'Projected RTG');\r\n        this.tooltipRadioTextMap.set('projectedIMPS', \"Projected IMPS('000)\");\r\n        this.tooltipRadioTextMap.set('desiredCPM', 'Desired CPM');\r\n        this.tooltipRadioTextMap.set('desiredCPP', 'Desired CPP');\r\n        this.tooltipRadioTextMap.set('origin', 'Origin');\r\n\r\n        this.tooltipRadioTextMap.set('BookedRTG', 'Booked RTG');\r\n        this.tooltipRadioTextMap.set('BookedIMPS', \"Booked IMPS('000)\");\r\n        this.tooltipRadioTextMap.set('IMPS', \"IMP('000)\");\r\n        this.tooltipRadioTextMap.set('AURTG', 'Avg RTG');\r\n        this.tooltipRadioTextMap.set('AUIMPS', \"Avg IMP('000)\");\r\n        this.tooltipRadioTextMap.set('PostedRatingsOrImpressions', 'Posted RTG');\r\n        this.tooltipRadioTextMap.set('ScheduleFlightWeek', 'Schedule Week');\r\n        this.tooltipRadioTextMap.set('ScheduledDay', 'Scheduled Day');\r\n        this.tooltipRadioTextMap.set('AirStatus', 'Air Status');\r\n        this.tooltipRadioTextMap.set('AirDateAndTime', 'Air Date & Time');\r\n        this.tooltipRadioTextMap.set('AirDate', 'Air Date');\r\n        this.tooltipRadioTextMap.set('NormalizedOrderedRating', 'Normalized Booked RTG');\r\n        this.tooltipRadioTextMap.set('NormalizedOrderedImpressions', \"Normalized Booked IMP('000)\");\r\n        this.tooltipRadioTextMap.set('NormalizedPostedRating', 'Normalized Posted RTG');\r\n        this.tooltipRadioTextMap.set('NormalizedPostedImpressions', \"Normalized Posted IMP('000)\");\r\n        this.tooltipRadioTextMap.set('AdId', 'Ad-Id');\r\n\r\n        this.tooltipRadioTextMap.set('displayimps', 'IMPS');\r\n        this.tooltipRadioTextMap.set('displayGrp', 'GRP');\r\n        this.tooltipRadioTextMap.set('bookedSpotsForDisplay', 'Spots');\r\n        this.tooltipRadioTextMap.set('displaySpots', 'Spots');\r\n\r\n        this.tooltipRadioTextMap.set('estimateNo', 'Estimate#');\r\n        this.tooltipRadioTextMap.set('primaryBuyer', 'Primary Buyer');\r\n        this.tooltipRadioTextMap.set('primaryBuyerName', 'Primary Buyer');\r\n        this.tooltipRadioTextMap.set('secondaryBuyerName', 'Secondary Buyer');\r\n        this.tooltipRadioTextMap.set('secondaryBuyer', 'Secondary Buyer');\r\n        this.tooltipRadioTextMap.set('timeoutDate', 'Timeout Date');\r\n        this.tooltipRadioTextMap.set('DisplaytSpotStatusBI', 'Spot Status');\r\n        this.tooltipRadioTextMap.set('LineSpot', 'Line.Spot');\r\n        this.tooltipRadioTextMap.set('LurWindowName', 'Political Window');\r\n\r\n        this.tooltipRadioTextMap.set('length', 'Length');\r\n        this.tooltipRadioTextMap.set('revClass', 'Rev Class');\r\n\r\n        // this.tooltipRadioTextMap.set(\"udValue\", \"$ UD\");\r\n        // this.tooltipRadioTextMap.set(\"odValue\", \"$ OD\");\r\n        this.tooltipRadioTextMap.set('udValue', 'Proj. $ UD');\r\n        this.tooltipRadioTextMap.set('odValue', 'Proj. $ OD');\r\n\r\n        this.tooltipRadioTextMap.set('OtherAvailableSpotsTableInventoryCode', 'Inventory Code');\r\n        this.tooltipRadioTextMap.set('OtherAvailableSpotsTableBuyerProgramName', 'Buyer Program Name');\r\n        this.tooltipRadioTextMap.set('OtherAvailableSpotsTableStartTime', 'Start Time');\r\n        this.tooltipRadioTextMap.set('OtherAvailableSpotsTableEndTime', 'End Time');\r\n        this.tooltipRadioTextMap.set('OtherAvailableSpotsTableWeeklyAUR', 'Booked Avg. Rate');\r\n        this.tooltipRadioTextMap.set('OtherAvailableSpotsTableDisplayRevenueClass', 'Rev Class');\r\n        this.tooltipRadioTextMap.set('OtherAvailableSpotsTableActualWeekStartDate', 'Week');\r\n        this.tooltipRadioTextMap.set('OtherAvailableSpotsTableWeekDay', 'Day');\r\n        this.tooltipRadioTextMap.set('OtherAvailableSpotsTableDisplayLength', 'Length');\r\n\r\n        this.tooltipRadioTextMap.set('ProjectedImpressions', \"Projected IMP('000)\");\r\n        this.tooltipRadioTextMap.set('ProjectedRtg', 'Projected RTG');\r\n    }\r\n\r\n    selectOrUnselectCheckbox(rowData: any, columnKeys: any, isCheckboxSelected: any) {\r\n        rowData[columnKeys] = !rowData[columnKeys];\r\n        this.toggleCheckbox.emit({ rowData, columnKeys, isCheckboxSelected });\r\n    }\r\n\r\n    selectOrUnselectRadiobox(rowData: any, columnKeys: any, isCheckboxSelected: boolean) {\r\n        if (rowData[columnKeys] == isCheckboxSelected) return;\r\n        rowData[columnKeys] = isCheckboxSelected;\r\n        this.toggleCheckbox.emit({ rowData, columnKeys, isCheckboxSelected });\r\n    }\r\n\r\n    selectUnselectAllRows() {\r\n        this.toggleHeaderCheckbox.emit();\r\n    }\r\n\r\n    selectUnselectRow(rowData: any) {\r\n        this.toggleRowCheckbox.emit(rowData);\r\n    }\r\n\r\n    undoCreditedSpot(data: any) {\r\n        this.undoIconClicked.emit({ data, mgOrCredit: 'Credit' });\r\n    }\r\n\r\n    undoMgSpot(data: any) {\r\n        this.undoIconClicked.emit({ data, mgOrCredit: 'MakeGood' });\r\n    }\r\n\r\n    //Sort and Filter Logic begins!\r\n    closeTooltip() {\r\n        if (this.tooltip && this.tooltip.isOpen()) {\r\n            this.tooltip.close();\r\n        }\r\n        this.tooltip = null;\r\n        if (!this.bindValueFuncCalled) {\r\n            this.columnFilterClosed.emit();\r\n        }\r\n    }\r\n\r\n    isTooltipActive(header: any[]) {\r\n        return this.annaFilterService.isTooltipActive(header, this.annaSortService.columnSortState);\r\n    }\r\n\r\n    bindTheValueToToolTip(tooltip: any, header: IHeaderInfo) {\r\n        this.bindValueFuncCalled = true;\r\n        // if same tooltip opened close it\r\n        if (tooltip == this.tooltip) {\r\n            this.bindValueFuncCalled = false;\r\n            this.closeTooltip();\r\n        } else {\r\n            let enabledHeaders: any[] = [];\r\n            this.checkIfUniqueValuePresentForTheHeader(header, enabledHeaders);\r\n            this.openTooltip(tooltip, enabledHeaders, header);\r\n\r\n            if (\r\n                window.innerWidth < 1500 &&\r\n                window.innerHeight < 768 &&\r\n                !this.annaFilterService.sliderSet.has(header.filterSortObjectKeys[0])\r\n            ) {\r\n                this.columnFilterOpened.emit();\r\n            }\r\n\r\n            this.showCheckboxesForTimeFilter =\r\n                this.gtGeneralConfig.component == 'SPOTDETAILS' ||\r\n                this.gtGeneralConfig.component == 'EXCLUDEINVENTORYPOPUP' ||\r\n                this.gtGeneralConfig.component == 'RATING';\r\n            this.showFilterTooltipTabs = header.filterSortObjectKeys.length > 1;\r\n            this.bindValueFuncCalled = false;\r\n        }\r\n    }\r\n\r\n    checkIfUniqueValuePresentForTheHeader(header: IHeaderInfo, enabledHeaders: any[]) {\r\n        header.filterSortObjectKeys.forEach((item: string) => {\r\n            let dataToCheck = this.annaFilterService.getFilterOptionsData(this.tableData, this.clonedTableData, item);\r\n            if (item == 'period') {\r\n                let uniqStartDate = uniq(dataToCheck.map((u: { [x: string]: any }) => u['startDate']));\r\n                let uniqEndDate = uniq(dataToCheck.map((u: { [x: string]: any }) => u['endDate']));\r\n                if (uniqStartDate.length > 1 || uniqEndDate.length > 1 || this.isTooltipActive([item])) {\r\n                    enabledHeaders.push(item);\r\n                }\r\n            } else {\r\n                let values = dataToCheck.map((u: { [x: string]: any }) => u[item]);\r\n                // if last applied filter is this header, push it alos as enabledHeader\r\n                let activeAndLastlyAppliedHeader = false;\r\n                if (\r\n                    this.annaFilterService.appliedFiltersArray.length > 0 &&\r\n                    this.annaFilterService.appliedFiltersArray[this.annaFilterService.appliedFiltersArray.length - 1] ==\r\n                        item\r\n                ) {\r\n                    activeAndLastlyAppliedHeader = true;\r\n                }\r\n                if (\r\n                    header.filter == 'CHECKBOX' &&\r\n                    (uniq(values).filter((n) => n != null).length > 1 || activeAndLastlyAppliedHeader)\r\n                ) {\r\n                    enabledHeaders.push(item);\r\n                } else if (\r\n                    header.filter != 'CHECKBOX' &&\r\n                    (uniq(values).filter((n) => n != null && n != '-').length > 1 || activeAndLastlyAppliedHeader)\r\n                ) {\r\n                    enabledHeaders.push(item);\r\n                }\r\n            }\r\n        });\r\n    }\r\n\r\n    openTooltip(tooltip: any, header: any, columnHeader: IHeaderInfo) {\r\n        this.closeTooltip();\r\n        this.tooltip = tooltip;\r\n        this.tooltip.open();\r\n        //convert key into the header\r\n        this.filterTabObjects = header.map((key: string, index: number) => {\r\n            let value = this.tooltipRadioTextMap.has(key) ? this.tooltipRadioTextMap.get(key) : key; //change to display name\r\n            return new radioButtonModel(\r\n                key,\r\n                value,\r\n                columnHeader.isSortRequired[index],\r\n                columnHeader.isFilterRequired[index],\r\n            );\r\n        });\r\n    }\r\n\r\n    disableEnableEachColumnTooltipIcon() {\r\n        this.tableHeaders.forEach((header) => {\r\n            header.headerInfo.forEach((item) => {\r\n                if (item.showTooltipIcon) {\r\n                    let values = [];\r\n                    item.disableTooltipIcon = true;\r\n\r\n                    item.filterSortObjectKeys.forEach((key) => {\r\n                        let latestFilters = this.annaFilterService.appliedFiltersArray;\r\n\r\n                        if (\r\n                            latestFilters.length > 0 &&\r\n                            item.disableTooltipIcon &&\r\n                            latestFilters[latestFilters.length - 1] == key\r\n                        ) {\r\n                            item.disableTooltipIcon = false;\r\n                        }\r\n\r\n                        if (item.disableTooltipIcon) {\r\n                            if (key == 'period') {\r\n                                let uniqStartDate = uniq(\r\n                                    this.tableData.map((u: { [x: string]: any }) => u['startDate']),\r\n                                );\r\n                                let uniqEndDate = uniq(this.tableData.map((u: { [x: string]: any }) => u['endDate']));\r\n\r\n                                item.disableTooltipIcon =\r\n                                    uniqStartDate.length > 1 || uniqEndDate.length > 1 ? false : true;\r\n                            } else {\r\n                                values = this.tableData.map((u: { [x: string]: any }) => u[key]);\r\n                                if (\r\n                                    (item.filter == 'CHECKBOX' && uniq(values).filter((n) => n != null).length > 1) ||\r\n                                    (item.filter != 'CHECKBOX' &&\r\n                                        uniq(values).filter((n) => n != null && n != '-').length > 1)\r\n                                ) {\r\n                                    item.disableTooltipIcon = false;\r\n                                }\r\n                            }\r\n                        }\r\n                    });\r\n                }\r\n            });\r\n        });\r\n    }\r\n\r\n    setMarginLeftForFilterIcon() {\r\n        let elementArr = this.viewChildTableHeaders.toArray();\r\n        elementArr.forEach((item) => {\r\n            let childDivElements = item.nativeElement.children;\r\n\r\n            if (childDivElements.length == 2) {\r\n                let firstParagraphOffsetWidth: number = childDivElements[0]?.children[0]?.offsetWidth\r\n                    ? childDivElements[0]?.children[0]?.offsetWidth\r\n                    : 0;\r\n                let secondParagraphOffsetWidth: number = childDivElements[1].children[0]?.offsetWidth\r\n                    ? childDivElements[1].children[0]?.offsetWidth\r\n                    : 0;\r\n\r\n                if (firstParagraphOffsetWidth > secondParagraphOffsetWidth) {\r\n                    let diff = firstParagraphOffsetWidth - secondParagraphOffsetWidth;\r\n                    if (childDivElements[0].children.length == 2) {\r\n                        childDivElements[0].children[1].style.marginLeft = 4 + 'px';\r\n                    }\r\n\r\n                    if (childDivElements[1].children.length == 2) {\r\n                        childDivElements[1].children[1].style.marginLeft = diff + 4 + 'px';\r\n                    }\r\n                } else {\r\n                    let diff = secondParagraphOffsetWidth - firstParagraphOffsetWidth;\r\n                    if (childDivElements[0].children.length == 2) {\r\n                        childDivElements[0].children[1].style.marginLeft = diff + 4 + 'px';\r\n                    }\r\n\r\n                    if (childDivElements[1].children.length == 2) {\r\n                        childDivElements[1].children[1].style.marginLeft = 4 + 'px';\r\n                    }\r\n                }\r\n            }\r\n        });\r\n    }\r\n\r\n    dataRowClicked(rowData: any) {\r\n        this.rowClicked.emit(rowData);\r\n    }\r\n\r\n    radioButtonClicked(data: any, action: string, isDisabled: boolean) {\r\n        if (!isDisabled) {\r\n            this.radioButtonSelected.emit({ data, action });\r\n        }\r\n    }\r\n\r\n    bindTheValueToSellerGroupTooltip(sellerGroupHierarchy: RatingSellerGroupHierarchy[], tooltip: any): void {\r\n        if (this.hierarchyTooltip && this.hierarchyTooltip.open) {\r\n            this.hierarchyTooltip.close();\r\n        }\r\n        this.sellerGroupHierarchy = sellerGroupHierarchy;\r\n        this.hierarchyTooltip = tooltip;\r\n        this.hierarchyTooltip.open();\r\n    }\r\n\r\n    iconClicked(rowData: any, iconClass: string) {\r\n        if ('orderId' in rowData && iconClass.includes('mdi-star')) {\r\n            this.selectedStarredOrderId = rowData.orderId;\r\n        }\r\n\r\n        this.gtIconClicked.emit({ data: rowData, iconClass: iconClass });\r\n    }\r\n\r\n    svgIconClicked(data: GtColumnIconEmittedData) {\r\n        this.gtSVGIconClicked.emit(data);\r\n    }\r\n\r\n    textActionClicked(rowData: any, id: any, columnHeader: IHeaderInfo) {\r\n        this.gtTextActionClicked.emit({ data: rowData, id: id, columnHeader: columnHeader, isIconClicked: false });\r\n    }\r\n\r\n    iconClickedOnStringIconActionType(rowData: any, id: any, columnHeader: IHeaderInfo) {\r\n        this.gtTextActionClicked.emit({ data: rowData, id: id, columnHeader: columnHeader, isIconClicked: true });\r\n    }\r\n\r\n    innerHTMLCellClicked(event: any, rowData: any) {\r\n        this.gtInnerHTMLClicked.emit({ event, rowData });\r\n    }\r\n\r\n    viewDetailsClicked(rowData: any) {\r\n        this.gtViewDetailClicked.emit({ data: rowData });\r\n    }\r\n\r\n    setActiveStateObject() {\r\n        this.annaFilterService.isFilterSortActive =\r\n            !this.annaFilterService.resetFilterSortActiveStatus || this.multipleTablesPresent\r\n                ? this.annaFilterService.isFilterSortActive\r\n                : {};\r\n        this.tableHeaders.forEach((item) => {\r\n            item.headerInfo.forEach((header) => {\r\n                if (header.showTooltipIcon) {\r\n                    let key = header.filterSortObjectKeys.join(',');\r\n                    header.joinedFilterSortObjectKeys = key;\r\n                    // ANNA-4113 fix\r\n                    if (this.annaFilterService.resetFilterSortActiveStatus) {\r\n                        this.annaFilterService.isFilterSortActive[key] = false;\r\n                    }\r\n                }\r\n            });\r\n        });\r\n        this.annaFilterService.resetFilterSortActiveStatus = true;\r\n    }\r\n\r\n    setIsDifference(value: boolean) {\r\n        this.isDifferenceLessThan25Percent = value;\r\n    }\r\n\r\n    resetIndex() {\r\n        this.start = 0;\r\n        this.end = this.limit + this.start;\r\n    }\r\n\r\n    onTableContainerScroll(e: any) {\r\n        const tableViewHeight = e.target.offsetHeight; // viewport\r\n        const tableScrollHeight = e.target.scrollHeight; // length of all table\r\n        const scrollLocation = e.target.scrollTop; // how far user scrolled\r\n\r\n        this.removeTooltipOnScroll();\r\n\r\n        // If the user has scrolled within 150px of the bottom, add more data\r\n        const buffer = 150;\r\n        const limit = tableScrollHeight - tableViewHeight - buffer;\r\n        if (scrollLocation > limit) {\r\n            let data = this.getTableData(this.start, this.end);\r\n            this.renderedData = this.renderedData.concat(data);\r\n            this.updateIndex();\r\n        }\r\n        this.tableContainerScrolled(e);\r\n    }\r\n\r\n    getTableData(start: number, end: number) {\r\n        return this.tableData.filter((value, index) => index >= start && index < end);\r\n    }\r\n\r\n    updateIndex() {\r\n        this.start = this.end;\r\n        this.end = this.limit + this.start;\r\n    }\r\n\r\n    setInitialRowsForTable() {\r\n        this.resetIndex();\r\n        this.renderedData = this.getTableData(this.start, this.end);\r\n        this.updateIndex();\r\n    }\r\n\r\n    spotDetailsDownloadClicked(parentChildOrTotalRow: 'DATAROW' | 'TOTALROW', rowdata?: any) {\r\n        if (rowdata) {\r\n            this.selectedInventoryIdForDownload = rowdata.inventoryCodeId;\r\n            this.selectedDemographicForDownload = rowdata.demographic;\r\n        } else {\r\n            this.selectedInventoryIdForDownload = null;\r\n            this.selectedDemographicForDownload = null;\r\n        }\r\n        this.selectedRowTypeForDownload = parentChildOrTotalRow;\r\n        this.downloadSpotDetails.emit({\r\n            parentChildOrTotalRow: parentChildOrTotalRow,\r\n            inventoryCodeId: this.selectedInventoryIdForDownload,\r\n            demographic: this.selectedDemographicForDownload,\r\n        });\r\n    }\r\n\r\n    tableContainerScrolled(event: any) {\r\n        this.isScrolledLeft = event.target.scrollLeft > 0;\r\n        this.isScrollEnded = Math.round(event.target.scrollLeft) == event.target.scrollWidth - event.target.clientWidth;\r\n        this.removeTooltipOnScroll();\r\n    }\r\n\r\n    mouseEnterOnStringTextActionType(rowData: any, tooltipKey: string) {\r\n        this.textActionTooltip = rowData[tooltipKey];\r\n        this.notificationIconHover.emit({ rowData: rowData, type: 'on-enter' });\r\n    }\r\n\r\n    mouseEnterOnStringTextActionTypeContainingTable(rowData: any, tooltipKey: string) {\r\n        this.tooltipContainingTable = rowData[tooltipKey];\r\n    }\r\n\r\n    mouseLeaveTextActionType(rowData: any) {\r\n        this.notificationIconHoverLeave.emit({ rowData: rowData, type: 'on-leave' });\r\n    }\r\n\r\n    mouseEnterOnTextActionType(rowData: any, tooltipKey: string) {\r\n        this.textActionTooltip = rowData[tooltipKey];\r\n    }\r\n\r\n    onClickableDataClicked(Rowdata: any, id: number) {\r\n        this.clickableDataClicked.emit({ data: Rowdata, id: id });\r\n    }\r\n\r\n    removeTooltipOnScroll() {\r\n        const elements = document.getElementsByClassName('remarks-info-tooltip');\r\n        // const tooltipElements = document.getElementsByClassName(\"tooltip\");\r\n        const gtTooltip = document.getElementsByClassName('remove-on-scroll-class');\r\n        const tooltipElements = document.getElementsByClassName('tooltip');\r\n\r\n        while (elements && elements.length > 0) {\r\n            elements[0].remove();\r\n        }\r\n        while (tooltipElements && tooltipElements.length > 0) {\r\n            tooltipElements[0].remove();\r\n            this.tooltip = null;\r\n        }\r\n        while (gtTooltip && gtTooltip.length > 0) {\r\n            gtTooltip[0].remove();\r\n        }\r\n    }\r\n\r\n    iconClickedInTotalRow(colName: string) {\r\n        this.totalRowIconClicked.emit(colName);\r\n    }\r\n\r\n    changesMadeInEditableInputBox(event: any, editedObject: any, pasteEvent: boolean) {\r\n        let enteredValue = pasteEvent ? event.clipboardData.getData('text') : event.key;\r\n        let dotIndex = editedObject.value.indexOf('.');\r\n\r\n        if (\r\n            event.keyCode != 8 &&\r\n            event.keyCode != 46 &&\r\n            !(event.keyCode >= 37 && event.keyCode <= 40) &&\r\n            ((!editedObject?.allowSpecialCharacters && !/[`0-9.]/.test(enteredValue)) ||\r\n                (editedObject.isDecimalPointCheckRequired &&\r\n                    dotIndex >= 0 &&\r\n                    event?.target?.selectionStart > dotIndex &&\r\n                    editedObject.value.length - (dotIndex + 1) >= editedObject.maxDecimalPointsAllowed))\r\n        ) {\r\n            event.preventDefault();\r\n        }\r\n    }\r\n\r\n    editableInputValueChanged(value: any, row: any, keyEdited: string) {\r\n        this.editableInputEdited.emit({ row: row, value: value, keyEdited: keyEdited });\r\n    }\r\n\r\n    radioButtonIconClicked(data: any) {\r\n        this.radioButtonMessageIconClicked.emit(data);\r\n    }\r\n\r\n    filterApplied(tableData: any[]) {\r\n        this.tableData = tableData;\r\n        this.setInitialRowsForTable();\r\n        this.disableEnableEachColumnTooltipIcon();\r\n        this.filterAppliedToTable.emit(tableData);\r\n        this.closeTooltip();\r\n    }\r\n\r\n    sortingApplied(tableData: any[]) {\r\n        this.tableData = tableData;\r\n        this.setInitialRowsForTable();\r\n        this.disableEnableEachColumnTooltipIcon();\r\n        this.sortingAppliedToTable.emit(tableData);\r\n        this.closeTooltip();\r\n    }\r\n}\r\n","<div\r\n    id=\"generic-table-conatiner\"\r\n    class=\"table-container {{ gtGeneralConfig?.tableOuterContainerName }} {{ tableBottomBorderClass }}\"\r\n    [ngClass]=\"{\r\n        'scroll-left-shadow-effect': isScrolledLeft,\r\n        'scroll-right-shadow-effect': !isScrollEnded,\r\n        'clickable-row': clickableRow,\r\n        'no-data-table': (isNoDataToDisplaySubject$ | async)\r\n    }\"\r\n    (scroll)=\"onTableContainerScroll($event)\"\r\n>\r\n    <div\r\n        [class]=\"gtGeneralConfig.tableContainerName\"\r\n        class=\"horizontal-scroll-for-table-container\"\r\n        [ngStyle]=\"{\r\n            height:\r\n                tableData.length < maximumRowsWhichCanBeRenderedWithoutScroll\r\n                    ? 'calc(' +\r\n                      (gtDimension.rowHeight * tableData.length +\r\n                          (!tableData.length || !gtGeneralConfig.totalRow\r\n                              ? gtDimension.headerHeight\r\n                              : gtDimension.headerHeight + gtDimension.rowHeight)) +\r\n                      'px)'\r\n                    : gtDimension.tableHeight\r\n        }\"\r\n    >\r\n        <table\r\n            class=\"gt\"\r\n            [ngClass]=\"tableClass\"\r\n            mat-table\r\n            [dataSource]=\"renderedData\"\r\n        >\r\n            <tr\r\n                class=\"header-row\"\r\n                mat-header-row\r\n                *matHeaderRowDef=\"tableColumns; sticky: true\"\r\n                [style.height.px]=\"gtDimension.headerHeight\"\r\n            ></tr>\r\n            <tr\r\n                class=\"total-row\"\r\n                mat-header-row\r\n                [style.height.px]=\"gtDimension.rowHeight\"\r\n                *matHeaderRowDef=\"totalRowColumns; sticky: true\"\r\n                [class.hidden]=\"\r\n                    showSkeletonLoading ||\r\n                    (!showSkeletonLoading && !tableData.length) ||\r\n                    (isNoDataToDisplaySubject$ | async) ||\r\n                    (!showSkeletonLoading && !gtGeneralConfig.totalRow)\r\n                \"\r\n            ></tr>\r\n            <tr\r\n                [class]=\"rowData.gtClass\"\r\n                [ngClass]=\"{ 'no-border-tr': (isNoDataToDisplaySubject$ | async) }\"\r\n                mat-row\r\n                *matRowDef=\"let rowData; columns: tableColumns\"\r\n                [style.height.px]=\"gtDimension.rowHeight\"\r\n                (click)=\"dataRowClicked(rowData)\"\r\n            ></tr>\r\n\r\n            <!-- TOTAL ROW -->\r\n            <ng-container\r\n                [matColumnDef]=\"column.colName\"\r\n                *ngFor=\"let column of totalRowInfo; trackBy: trackByFn\"\r\n            >\r\n                <td\r\n                    mat-header-cell\r\n                    *matHeaderCellDef\r\n                    [attr.colspan]=\"column.colspan\"\r\n                    class=\"{{ column.class }}\"\r\n                >\r\n                    <ng-container *ngIf=\"column['isActionColumn']\">\r\n                        <a\r\n                            *ngFor=\"let data of column.actionData\"\r\n                            [class]=\"data.class\"\r\n                            (click)=\"onClickableDataClicked({}, data.id)\"\r\n                        >\r\n                            {{ data.name }}\r\n                        </a>\r\n                    </ng-container>\r\n\r\n                    <ng-container *ngIf=\"column['isIconColumn']\">\r\n                        <i\r\n                            class=\"{{ column?.iconData?.class }}\"\r\n                            (click)=\"iconClickedInTotalRow(column?.colName)\"\r\n                        >\r\n                        </i>\r\n                    </ng-container>\r\n\r\n                    <ng-container *ngIf=\"!column['isActionColumn']\">\r\n                        <strong class=\"upper-label\">{{ column.data }}</strong>\r\n                        <ng-container *ngIf=\"column.lowerData\">\r\n                            <br />\r\n                            <span\r\n                                *ngIf=\"\r\n                                    column.colName == 'total-potential-booked-unit' &&\r\n                                        gtGeneralConfig.component == 'RATING';\r\n                                    else columnLowerData\r\n                                \"\r\n                                class=\"clickable-data\"\r\n                                (click)=\"spotDetailsDownloadClicked('TOTALROW')\"\r\n                                [ngClass]=\"{ 'disabled-clickable-data': downloadInProgress }\"\r\n                                >{{ column.lowerData }}\r\n                                <span class=\"material-icons spot-details-download-icons\">get_app</span>\r\n                                <ng-container *ngIf=\"downloadInProgress && selectedRowTypeForDownload == 'TOTALROW'\">\r\n                                    <ng-container [ngTemplateOutlet]=\"circularProgressBar\"></ng-container>\r\n                                </ng-container>\r\n                            </span>\r\n                            <ng-template #columnLowerData>\r\n                                <span class=\"lower-label\">{{ column.lowerData }}</span>\r\n                            </ng-template>\r\n                        </ng-container>\r\n                        <ng-container *ngIf=\"column.tooltipMessage && gtGeneralConfig.component != 'LUR_VIOLATIONS'\">\r\n                            <i\r\n                                class=\"{{ column.tooltipIconClass }}\"\r\n                                container=\"body\"\r\n                                [ngbTooltip]=\"column.tooltipMessage\"\r\n                                tooltipClass=\"gt-total-row-tooltip\"\r\n                                placement=\"bottom\"\r\n                            ></i>\r\n                        </ng-container>\r\n                        <ng-container *ngIf=\"gtGeneralConfig.component == 'LUR_VIOLATIONS' && column.tooltipMessage\">\r\n                            <i\r\n                                class=\"mi mdi-info-outline info-label\"\r\n                                container=\"body\"\r\n                                [ngbTooltip]=\"lurViolationTotalRowToolTip\"\r\n                                tooltipClass=\"gt-total-row-tooltip\"\r\n                                placement=\"bottom\"\r\n                            ></i>\r\n                        </ng-container>\r\n                    </ng-container>\r\n                </td>\r\n            </ng-container>\r\n\r\n            <!-- MAIN ROW -->\r\n            <ng-container\r\n                [matColumnDef]=\"columnDef.headerInfo[0].objectKey\"\r\n                *ngFor=\"let columnDef of tableHeaders; trackBy: trackByFn\"\r\n            >\r\n                <th\r\n                    #tableHeader\r\n                    nowrap\r\n                    mat-header-cell\r\n                    *matHeaderCellDef\r\n                    [style.width]=\"columnDef.width\"\r\n                >\r\n                    <div\r\n                        class=\"row mx-0\"\r\n                        *ngFor=\"let header of columnDef.headerInfo; let j = index\"\r\n                    >\r\n                        <p\r\n                            *ngIf=\"header.typeOfHeaderData === 'STRING'\"\r\n                            [ngClass]=\"{ 'upper-label': j === 0, 'lower-label': j === 1 }\"\r\n                        >\r\n                            <ngx-skeleton-loader\r\n                                *ngIf=\"header.name == null\"\r\n                                count=\"1\"\r\n                                [theme]=\"{\r\n                                    height: '10px',\r\n                                    display: 'block',\r\n                                    width: columnDef.width,\r\n                                    'max-width': 'calc(100% - 20px)'\r\n                                }\"\r\n                            >\r\n                            </ngx-skeleton-loader>\r\n                            <ng-container *ngIf=\"header.name\">\r\n                                {{ header.name }}\r\n                            </ng-container>\r\n                            <ng-container *ngIf=\"header.tooltip && header.tooltip.tooltipMessage\">\r\n                                <i\r\n                                    class=\"{{ header['tooltip'].iconClass }}\"\r\n                                    [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n                                    #t=\"ngbTooltip\"\r\n                                    container=\"body\"\r\n                                    [ngbTooltip]=\"header.tooltip.tooltipMessage\"\r\n                                    container=\"body\"\r\n                                    placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n                                    tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n                                >\r\n                                </i>\r\n                            </ng-container>\r\n                            <i\r\n                                *ngIf=\"header.tooltip && header.tooltip.name == 'impsInfoTooltip'\"\r\n                                class=\"{{ header['tooltip'].iconClass }}\"\r\n                                [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n                                #t=\"ngbTooltip\"\r\n                                container=\"body\"\r\n                                [ngbTooltip]=\"impsInfoTooltip\"\r\n                                container=\"body\"\r\n                                placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n                                tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n                            >\r\n                            </i>\r\n                            <i\r\n                                *ngIf=\"\r\n                                    header.tooltip && header.tooltip.name == 'spotsColumnEquivalizationMessageTooltip'\r\n                                \"\r\n                                class=\"{{ header['tooltip'].iconClass }}\"\r\n                                [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n                                container=\"body\"\r\n                                #t=\"ngbTooltip\"\r\n                                container=\"body\"\r\n                                [ngbTooltip]=\"spotsColumnEquivalizationMessageTooltip\"\r\n                                placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n                                tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n                            >\r\n                            </i>\r\n                            <i\r\n                                *ngIf=\"header.tooltip && header.tooltip.name == 'underDeliveryTooltip'\"\r\n                                class=\"{{ header['tooltip'].iconClass }}\"\r\n                                [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n                                container=\"body\"\r\n                                #t=\"ngbTooltip\"\r\n                                container=\"body\"\r\n                                [ngbTooltip]=\"underDeliveryTooltip\"\r\n                                placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n                                tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n                            >\r\n                            </i>\r\n                            <i\r\n                                *ngIf=\"header.tooltip && header.tooltip.name == 'overDeliveryTooltip'\"\r\n                                class=\"{{ header['tooltip'].iconClass }}\"\r\n                                [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n                                container=\"body\"\r\n                                #t=\"ngbTooltip\"\r\n                                container=\"body\"\r\n                                [ngbTooltip]=\"overDeliveryTooltip\"\r\n                                placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n                                tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n                            >\r\n                            </i>\r\n                            <i\r\n                                *ngIf=\"header.tooltip && header.tooltip.name == 'ratingInfoTooltip'\"\r\n                                class=\"{{ header['tooltip'].iconClass }}\"\r\n                                [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n                                #t=\"ngbTooltip\"\r\n                                container=\"body\"\r\n                                [ngbTooltip]=\"ratingInfoTooltip\"\r\n                                container=\"body\"\r\n                                placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n                                tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n                            >\r\n                            </i>\r\n                            <i\r\n                                *ngIf=\"header.tooltip && header.tooltip.name == 'rateInfoTooltip'\"\r\n                                class=\"{{ header['tooltip'].iconClass }}\"\r\n                                [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n                                #t=\"ngbTooltip\"\r\n                                container=\"body\"\r\n                                [ngbTooltip]=\"rateInfoTooltip\"\r\n                                container=\"body\"\r\n                                placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n                                tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n                            >\r\n                            </i>\r\n                            <i\r\n                                *ngIf=\"header.tooltip && header.tooltip.name == 'ongoingRevBookedColumnTooltip'\"\r\n                                class=\"{{ header['tooltip'].iconClass }}\"\r\n                                [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n                                #t=\"ngbTooltip\"\r\n                                container=\"body\"\r\n                                [ngbTooltip]=\"ongoingRevBookedColumnTooltip\"\r\n                                placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n                                tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n                            >\r\n                            </i>\r\n                            <i\r\n                                *ngIf=\"header.tooltip && header.tooltip.name == 'completedRevBookedColumnTooltip'\"\r\n                                class=\"{{ header['tooltip'].iconClass }}\"\r\n                                [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n                                #t=\"ngbTooltip\"\r\n                                container=\"body\"\r\n                                [ngbTooltip]=\"completedRevBookedColumnTooltip\"\r\n                                placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n                                tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n                            >\r\n                            </i>\r\n                            <i\r\n                                *ngIf=\"header.tooltip && header.tooltip.name == 'avgBookedRate'\"\r\n                                class=\"{{ header['tooltip'].iconClass }}\"\r\n                                [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n                                #t=\"ngbTooltip\"\r\n                                container=\"body\"\r\n                                [ngbTooltip]=\"avgBookedRate\"\r\n                                placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n                                tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n                            >\r\n                            </i>\r\n                            <i\r\n                                *ngIf=\"header.tooltip && header.tooltip.name == 'avgBookedRtg'\"\r\n                                class=\"{{ header['tooltip'].iconClass }}\"\r\n                                [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n                                #t=\"ngbTooltip\"\r\n                                container=\"body\"\r\n                                [ngbTooltip]=\"avgBookedRtg\"\r\n                                placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n                                tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n                            >\r\n                            </i>\r\n                            <i\r\n                                *ngIf=\"header.tooltip && header.tooltip.name == 'avgBookedImps'\"\r\n                                class=\"{{ header['tooltip'].iconClass }}\"\r\n                                [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n                                #t=\"ngbTooltip\"\r\n                                container=\"body\"\r\n                                [ngbTooltip]=\"avgBookedImps\"\r\n                                placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n                                tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n                            >\r\n                            </i>\r\n\r\n                            <i\r\n                                *ngIf=\"header.tooltip && header.tooltip.name == 'automationTooltip'\"\r\n                                class=\"{{ header['tooltip'].iconClass }}\"\r\n                                [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n                                #t=\"ngbTooltip\"\r\n                                container=\"body\"\r\n                                [ngbTooltip]=\"automationTooltip\"\r\n                                placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n                                tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n                            >\r\n                            </i>\r\n\r\n                            <i\r\n                                *ngIf=\"header.tooltip && header.tooltip.name == 'rebateImpact'\"\r\n                                class=\"{{ header['tooltip'].iconClass }}\"\r\n                                [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n                                #t=\"ngbTooltip\"\r\n                                container=\"body\"\r\n                                [ngbTooltip]=\"rebateImpact\"\r\n                                placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n                                tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n                            >\r\n                            </i>\r\n\r\n                            <i\r\n                                *ngIf=\"header.tooltip && header.tooltip.name == 'projectedImpsRtg'\"\r\n                                class=\"{{ header['tooltip'].iconClass }}\"\r\n                                [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n                                #t=\"ngbTooltip\"\r\n                                container=\"body\"\r\n                                [ngbTooltip]=\"projectedImpsRtg\"\r\n                                placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n                                tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n                            >\r\n                            </i>\r\n                        </p>\r\n\r\n                        <ng-container *ngIf=\"header.typeOfHeaderData === 'CHECKBOX'\">\r\n                            <span\r\n                                *ngIf=\"gtGeneralConfig.isHeaderChecked\"\r\n                                class=\"material-icons custom-column-checkbox-checked\"\r\n                                (click)=\"selectUnselectAllRows()\"\r\n                            >\r\n                                check_box\r\n                            </span>\r\n                            <span\r\n                                *ngIf=\"!gtGeneralConfig.isHeaderChecked\"\r\n                                class=\"material-icons custom-column-checkbox-unchecked\"\r\n                                [ngClass]=\"{ 'disable-checkbox': gtGeneralConfig.disableHeaderCheckbox }\"\r\n                                (click)=\"selectUnselectAllRows()\"\r\n                            >\r\n                                check_box_outline_blank\r\n                            </span>\r\n                        </ng-container>\r\n\r\n                        <div\r\n                            *ngIf=\"gtGeneralConfig.showAllColumnFilter\"\r\n                            class=\"sort-filter-container\"\r\n                        >\r\n                            <ng-container *ngIf=\"header.showTooltipIcon\">\r\n                                <!-- Active tooltip Functionality -->\r\n                                <ng-container *ngIf=\"header.filter === 'CHECKBOX'\">\r\n                                    <span\r\n                                        class=\"mdi mdi-filter-variant\"\r\n                                        [ngClass]=\"{\r\n                                            active:\r\n                                                annaFilterService.isFilterSortActive &&\r\n                                                annaFilterService.isFilterSortActive[header.joinedFilterSortObjectKeys],\r\n                                            disabled: header.disableTooltipIcon || showSkeletonLoading\r\n                                        }\"\r\n                                        [ngbTooltip]=\"filterTooltip\"\r\n                                        placement=\"{{ filterAlignment }}\"\r\n                                        container=\"body\"\r\n                                        tooltipClass=\"non-edit-checkbox-tooltip\"\r\n                                        [autoClose]=\"'outside'\"\r\n                                        triggers=\"manual\"\r\n                                        #t=\"ngbTooltip\"\r\n                                        (click)=\"bindTheValueToToolTip(t, header)\"\r\n                                        (hidden)=\"closeTooltip()\"\r\n                                    >\r\n                                    </span\r\n                                    ><br />\r\n                                </ng-container>\r\n                                <ng-container *ngIf=\"header.filter === 'SLIDER'\">\r\n                                    <span\r\n                                        class=\"mdi mdi-filter-variant\"\r\n                                        [ngClass]=\"{\r\n                                            active:\r\n                                                annaFilterService.isFilterSortActive &&\r\n                                                annaFilterService.isFilterSortActive[header.joinedFilterSortObjectKeys],\r\n                                            disabled: header.disableTooltipIcon || showSkeletonLoading\r\n                                        }\"\r\n                                        [ngbTooltip]=\"sliderToolTip\"\r\n                                        placement=\"bottom left-top\"\r\n                                        container=\"body\"\r\n                                        tooltipClass=\"non-edit-slider-tooltip\"\r\n                                        [autoClose]=\"'outside'\"\r\n                                        triggers=\"manual\"\r\n                                        #t1=\"ngbTooltip\"\r\n                                        (click)=\"bindTheValueToToolTip(t1, header)\"\r\n                                        (hidden)=\"closeTooltip()\"\r\n                                    >\r\n                                    </span\r\n                                    ><br />\r\n                                </ng-container>\r\n                                <ng-container *ngIf=\"header.filter === 'DATE'\">\r\n                                    <span\r\n                                        class=\"mdi mdi-filter-variant\"\r\n                                        [ngClass]=\"{\r\n                                            active:\r\n                                                annaFilterService.isFilterSortActive &&\r\n                                                annaFilterService.isFilterSortActive[header.joinedFilterSortObjectKeys],\r\n                                            disabled: header.disableTooltipIcon || showSkeletonLoading\r\n                                        }\"\r\n                                        [ngbTooltip]=\"datePickerTooltip\"\r\n                                        placement=\"bottom auto\"\r\n                                        container=\"body\"\r\n                                        tooltipClass=\"non-edit-datepicker-tooltip\"\r\n                                        [autoClose]=\"'outside'\"\r\n                                        triggers=\"manual\"\r\n                                        #t2=\"ngbTooltip\"\r\n                                        (click)=\"bindTheValueToToolTip(t2, header)\"\r\n                                        (hidden)=\"closeTooltip()\"\r\n                                    >\r\n                                    </span\r\n                                    ><br />\r\n                                </ng-container>\r\n                                <ng-container *ngIf=\"header.filter === 'WEEK'\">\r\n                                    <span\r\n                                        class=\"mdi mdi-filter-variant\"\r\n                                        [ngClass]=\"{\r\n                                            active:\r\n                                                annaFilterService.isFilterSortActive &&\r\n                                                annaFilterService.isFilterSortActive[header.joinedFilterSortObjectKeys],\r\n                                            disabled: header.disableTooltipIcon || showSkeletonLoading\r\n                                        }\"\r\n                                        [ngbTooltip]=\"weekPickerToolTip\"\r\n                                        placement=\"bottom left-top\"\r\n                                        container=\"body\"\r\n                                        [autoClose]=\"'outside'\"\r\n                                        triggers=\"manual\"\r\n                                        #t3=\"ngbTooltip\"\r\n                                        (click)=\"bindTheValueToToolTip(t3, header)\"\r\n                                        (hidden)=\"closeTooltip()\"\r\n                                    >\r\n                                    </span\r\n                                    ><br />\r\n                                </ng-container>\r\n                                <ng-container *ngIf=\"header.filter === 'TIME'\">\r\n                                    <span\r\n                                        class=\"mdi mdi-filter-variant\"\r\n                                        [ngClass]=\"{\r\n                                            active:\r\n                                                annaFilterService.isFilterSortActive &&\r\n                                                annaFilterService.isFilterSortActive[header.joinedFilterSortObjectKeys],\r\n                                            disabled: header.disableTooltipIcon || showSkeletonLoading\r\n                                        }\"\r\n                                        [ngbTooltip]=\"timeFilterToolTip\"\r\n                                        placement=\"bottom left-top auto\"\r\n                                        container=\"body\"\r\n                                        tooltipClass=\"non-edit-time-tooltip\"\r\n                                        [autoClose]=\"'outside'\"\r\n                                        triggers=\"manual\"\r\n                                        #t4=\"ngbTooltip\"\r\n                                        (click)=\"bindTheValueToToolTip(t4, header)\"\r\n                                        (hidden)=\"closeTooltip()\"\r\n                                    >\r\n                                    </span\r\n                                    ><br />\r\n                                </ng-container>\r\n                            </ng-container>\r\n                            <ng-container *ngIf=\"!header.showTooltipIcon\">\r\n                                <span id=\"no-filter-space\"></span><br />\r\n                            </ng-container>\r\n                            <i\r\n                                *ngIf=\"header.tooltip && header.tooltip.name == 'lurViolationInfoTooltip'\"\r\n                                class=\"{{ header['tooltip'].iconClass }}\"\r\n                                [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n                                #t=\"ngbTooltip\"\r\n                                container=\"body\"\r\n                                [ngbTooltip]=\"lurViolationInfoTooltip\"\r\n                                placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n                                tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n                            >\r\n                            </i>\r\n                        </div>\r\n                    </div>\r\n                </th>\r\n\r\n                <ng-container *matCellDef=\"let ROW_DATA\">\r\n                    <td\r\n                        mat-cell\r\n                        [style.background]=\"ROW_DATA.backgroundColor\"\r\n                        [style.border]=\"ROW_DATA.border\"\r\n                        class=\"{{ ROW_DATA.rowClass }}\"\r\n                        [ngClass]=\"ROW_DATA[columnDef.headerInfo[0].objectKey + 'TdClass']\"\r\n                        [attr.rowspan]=\"ROW_DATA[columnDef.headerInfo[0].objectKey + 'Rowspan']\"\r\n                        *ngIf=\"\r\n                            !hideSomeTds ||\r\n                            (hideSomeTds && !ROW_DATA['hide' + columnDef.headerInfo[0].objectKey + 'Td'])\r\n                        \"\r\n                    >\r\n                        <ngx-skeleton-loader\r\n                            *ngIf=\"showSkeletonLoading\"\r\n                            count=\"1\"\r\n                            [theme]=\"{ height: '10px', display: 'block' }\"\r\n                        >\r\n                        </ngx-skeleton-loader>\r\n\r\n                        <ng-container *ngIf=\"!showSkeletonLoading\">\r\n                            <ng-container *ngIf=\"tableData.length > 0 && !(isNoDataToDisplaySubject$ | async)\">\r\n                                <ng-container\r\n                                    *ngFor=\"\r\n                                        let subline of columnDef.headerInfo;\r\n                                        let subLineIndex = index;\r\n                                        trackBy: trackByFn\r\n                                    \"\r\n                                >\r\n                                    <div showEllipsisTextOnHover>\r\n                                        <ng-container [ngSwitch]=\"columnDef.headerInfo[subLineIndex].typeOfBodyData\">\r\n                                            <ng-container *ngSwitchCase=\"'ICON'\">\r\n                                                <i\r\n                                                    *ngIf=\"\r\n                                                        !(\r\n                                                            starredInProgress &&\r\n                                                            ROW_DATA.orderId == selectedStarredOrderId\r\n                                                        )\r\n                                                    \"\r\n                                                    [class]=\"ROW_DATA.iconClass\"\r\n                                                    (click)=\"iconClicked(ROW_DATA, ROW_DATA.iconClass)\"\r\n                                                    ngbTooltip=\"{{ ROW_DATA.iconTitleText }}\"\r\n                                                    placement=\"bottom\"\r\n                                                    container=\"body\"\r\n                                                    tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\r\n                                                ></i>\r\n                                                <ng-container\r\n                                                    *ngIf=\"\r\n                                                        starredInProgress && ROW_DATA.orderId == selectedStarredOrderId\r\n                                                    \"\r\n                                                >\r\n                                                    <div class=\"spinner-for-button-directive\"></div>\r\n                                                </ng-container>\r\n                                            </ng-container>\r\n\r\n                                            <ng-container *ngSwitchCase=\"'ICON_CELL'\">\r\n                                                <ng-container\r\n                                                    *ngFor=\"\r\n                                                        let action of ROW_DATA[\r\n                                                            columnDef.headerInfo[subLineIndex].actionKey\r\n                                                        ]\r\n                                                    \"\r\n                                                >\r\n                                                    <ng-container *ngIf=\"action.showObjectKey\">\r\n                                                        {{ ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey] }}\r\n                                                    </ng-container>\r\n\r\n                                                    <i\r\n                                                        *ngIf=\"action.showIcon\"\r\n                                                        [class]=\"action.iconClass\"\r\n                                                        (mouseenter)=\"\r\n                                                            mouseEnterOnStringTextActionType(\r\n                                                                ROW_DATA,\r\n                                                                columnDef.headerInfo[subLineIndex].tooltipKey\r\n                                                            )\r\n                                                        \"\r\n                                                        placement=\"bottom auto\"\r\n                                                        container=\"body\"\r\n                                                        [autoClose]=\"true\"\r\n                                                        tooltipClass=\"team-user-tooltip remove-on-scroll-class\"\r\n                                                        [ngbTooltip]=\"action.showTooltip ? action.tooltipData : null\"\r\n                                                        (click)=\"\r\n                                                            textActionClicked(\r\n                                                                ROW_DATA,\r\n                                                                action.id,\r\n                                                                columnDef.headerInfo[subLineIndex]\r\n                                                            )\r\n                                                        \"\r\n                                                        [disableTooltip]=\"!action.showTooltip\"\r\n                                                    >\r\n                                                    </i>\r\n\r\n                                                </ng-container>\r\n                                            </ng-container>\r\n\r\n                                            <ng-container *ngSwitchCase=\"'HTML_STRING'\">\r\n                                                <p\r\n                                                    [innerHTML]=\"ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\r\n                                                    (click)=\"innerHTMLCellClicked($event, ROW_DATA)\"\r\n                                                ></p>\r\n                                            </ng-container>\r\n\r\n                                            <ng-container *ngSwitchCase=\"'SVG_ICON'\">\r\n                                                <anna-core-anna-icon-column\r\n                                                    [componentName]=\"gtGeneralConfig.component\"\r\n                                                    [dataObject]=\"ROW_DATA\"\r\n                                                    [iconToShow]=\"\r\n                                                        ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n                                                    \"\r\n                                                    (onColumnIconClicked)=\"svgIconClicked($event)\"\r\n                                                ></anna-core-anna-icon-column>\r\n                                            </ng-container>\r\n\r\n                                            <ng-container *ngSwitchCase=\"'TEXT_ACTIONS'\">\r\n                                                <ng-container\r\n                                                    *ngFor=\"\r\n                                                        let text of ROW_DATA[\r\n                                                            columnDef.headerInfo[subLineIndex].actionKey\r\n                                                        ]\r\n                                                    \"\r\n                                                >\r\n                                                    <button\r\n                                                        *ngIf=\"text.showTooltip\"\r\n                                                        (click)=\"\r\n                                                            textActionClicked(\r\n                                                                ROW_DATA,\r\n                                                                text.id,\r\n                                                                columnDef.headerInfo[subLineIndex]\r\n                                                            )\r\n                                                        \"\r\n                                                        [disabled]=\"text.isDisabled\"\r\n                                                        class=\"{{ text.class }}\"\r\n                                                        (mouseenter)=\"\r\n                                                            mouseEnterOnTextActionType(\r\n                                                                ROW_DATA,\r\n                                                                columnDef.headerInfo[subLineIndex].tooltipKey\r\n                                                            )\r\n                                                        \"\r\n                                                        [ngbTooltip]=\"textActionTooltipTemplate\"\r\n                                                        placement=\"auto\"\r\n                                                        container=\"body\"\r\n                                                        tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\r\n                                                    >\r\n                                                        {{ text.name }}\r\n                                                    </button>\r\n\r\n                                                    <button\r\n                                                        *ngIf=\"!text.showTooltip\"\r\n                                                        (click)=\"\r\n                                                            textActionClicked(\r\n                                                                ROW_DATA,\r\n                                                                text.id,\r\n                                                                columnDef.headerInfo[subLineIndex]\r\n                                                            )\r\n                                                        \"\r\n                                                        [disabled]=\"text.isDisabled\"\r\n                                                        class=\"{{ text.class }}\"\r\n                                                    >\r\n                                                        {{ text.name }}\r\n                                                    </button>\r\n                                                </ng-container>\r\n                                            </ng-container>\r\n\r\n                                            <ng-container *ngSwitchCase=\"'CHECKBOX'\">\r\n                                                <span\r\n                                                    *ngIf=\"ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\r\n                                                    [ngClass]=\"{\r\n                                                        'disable-checkbox':\r\n                                                            ROW_DATA[columnDef.headerInfo[subLineIndex].isDisabledKey]\r\n                                                    }\"\r\n                                                    class=\"material-icons custom-column-checkbox-checked\"\r\n                                                    (click)=\"\r\n                                                        selectOrUnselectCheckbox(\r\n                                                            ROW_DATA,\r\n                                                            columnDef.headerInfo[subLineIndex].objectKey,\r\n                                                            false\r\n                                                        )\r\n                                                    \"\r\n                                                >\r\n                                                    check_box\r\n                                                </span>\r\n                                                <span\r\n                                                    *ngIf=\"!ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\r\n                                                    class=\"material-icons custom-column-checkbox-unchecked\"\r\n                                                    [ngClass]=\"{\r\n                                                        'disable-checkbox':\r\n                                                            ROW_DATA[columnDef.headerInfo[subLineIndex].isDisabledKey]\r\n                                                    }\"\r\n                                                    (click)=\"\r\n                                                        selectOrUnselectCheckbox(\r\n                                                            ROW_DATA,\r\n                                                            columnDef.headerInfo[subLineIndex].objectKey,\r\n                                                            true\r\n                                                        )\r\n                                                    \"\r\n                                                >\r\n                                                    check_box_outline_blank\r\n                                                </span>\r\n\r\n                                                <ng-container\r\n                                                    *ngFor=\"\r\n                                                        let action of ROW_DATA[\r\n                                                            columnDef.headerInfo[subLineIndex].actionKey\r\n                                                        ]\r\n                                                    \"\r\n                                                >\r\n                                                    <i\r\n                                                        *ngIf=\"action.showIcon\"\r\n                                                        [class]=\"action.iconClass\"\r\n                                                        [ngClass]=\"{ disabled: action.disabledIcon }\"\r\n                                                        (mouseenter)=\"\r\n                                                            mouseEnterOnStringTextActionTypeContainingTable(\r\n                                                                ROW_DATA,\r\n                                                                columnDef.headerInfo[subLineIndex].tooltipKey\r\n                                                            )\r\n                                                        \"\r\n                                                        placement=\"bottom auto\"\r\n                                                        container=\"body\"\r\n                                                        [autoClose]=\"true\"\r\n                                                        tooltipClass=\"tooltip-containing-table remove-on-scroll-class\"\r\n                                                        [ngbTooltip]=\"tooltipContainingTableTemplate\"\r\n                                                    >\r\n                                                    </i>\r\n                                                </ng-container>\r\n                                            </ng-container>\r\n\r\n                                            <ng-container *ngSwitchCase=\"'CLICKABLE_DATA'\">\r\n                                                <a\r\n                                                    *ngFor=\"\r\n                                                        let text of ROW_DATA[\r\n                                                            columnDef.headerInfo[subLineIndex].actionKey\r\n                                                        ]\r\n                                                    \"\r\n                                                    [class]=\"text.class\"\r\n                                                    (click)=\"onClickableDataClicked(ROW_DATA, text.id)\"\r\n                                                >\r\n                                                    {{ text.name }}\r\n                                                </a>\r\n                                                <span\r\n                                                    *ngIf=\"\r\n                                                        subline.objectKey == 'displayBookedUnits' &&\r\n                                                        gtGeneralConfig.component == 'RATING'\r\n                                                    \"\r\n                                                    class=\"clickable-data\"\r\n                                                    (click)=\"spotDetailsDownloadClicked('DATAROW', ROW_DATA)\"\r\n                                                    [ngClass]=\"{ 'disabled-clickable-data': downloadInProgress }\"\r\n                                                    >{{ ROW_DATA.displayBookedUnits }}\r\n                                                    <span class=\"material-icons spot-details-download-icons\"\r\n                                                        >get_app</span\r\n                                                    >\r\n                                                    <ng-container\r\n                                                        *ngIf=\"\r\n                                                            downloadInProgress &&\r\n                                                            ROW_DATA.inventoryCodeId ==\r\n                                                                selectedInventoryIdForDownload &&\r\n                                                            ROW_DATA.demographic == selectedDemographicForDownload\r\n                                                        \"\r\n                                                    >\r\n                                                        <ng-container\r\n                                                            [ngTemplateOutlet]=\"circularProgressBar\"\r\n                                                        ></ng-container>\r\n                                                    </ng-container>\r\n                                                </span>\r\n                                            </ng-container>\r\n\r\n                                            <ng-container *ngSwitchCase=\"'STRING___ICON_OR_TEXT_ACTION'\">\r\n                                                <ng-container\r\n                                                    *ngFor=\"\r\n                                                        let action of ROW_DATA[\r\n                                                            columnDef.headerInfo[subLineIndex].actionKey\r\n                                                        ]\r\n                                                    \"\r\n                                                >\r\n                                                    <span\r\n                                                        [class]=\"action.additionalTextBeforeLinkClass\"\r\n                                                        [innerHtml]=\"action.additionalTextBeforeLink\"\r\n                                                        ngbTooltip=\"{{ action.additionalTextBeforeLink }}\"\r\n                                                        placement=\"bottom\"\r\n                                                        container=\"body\"\r\n                                                        tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\r\n                                                        [disableTooltip]=\"!action.enableTooltipForAdditionalText\"\r\n                                                    ></span>\r\n\r\n                                                    <ng-container *ngIf=\"action && action.typeOfData == 'STRING'\">\r\n                                                        {{ action.data }}\r\n                                                    </ng-container>\r\n\r\n                                                    <a\r\n                                                        [id]=\"action.id\"\r\n                                                        *ngIf=\"action.showLink\"\r\n                                                        (click)=\"\r\n                                                            textActionClicked(\r\n                                                                ROW_DATA,\r\n                                                                action.id,\r\n                                                                columnDef.headerInfo[subLineIndex]\r\n                                                            )\r\n                                                        \"\r\n                                                        [class]=\"action.linkClass\"\r\n                                                        [ngClass]=\"{ disabled: action.disabledLink }\"\r\n                                                        >{{ action.data }}</a\r\n                                                    >\r\n                                                    <span\r\n                                                        ngbTooltip=\"{{ action.additionalTextAfterLink }}\"\r\n                                                        placement=\"bottom\"\r\n                                                        container=\"body\"\r\n                                                        [class]=\"action.additionalTextAfterLinkClass\"\r\n                                                        tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\r\n                                                        [disableTooltip]=\"!action.enableTooltipForAdditionalAfterText\"\r\n                                                    >\r\n                                                        {{ action.additionalTextAfterLink }}\r\n                                                    </span>\r\n\r\n                                                    <ng-container *ngIf=\"action.showTooltip\">\r\n                                                        <ng-container *ngIf=\"action.tooltipData.innerHtml\">\r\n                                                            <i\r\n                                                                *ngIf=\"action.showIcon\"\r\n                                                                [class]=\"action.iconClass\"\r\n                                                                [ngClass]=\"{ disabled: action.disabledIcon }\"\r\n                                                                (mouseenter)=\"\r\n                                                                    mouseEnterOnStringTextActionTypeContainingTable(\r\n                                                                        ROW_DATA,\r\n                                                                        columnDef.headerInfo[subLineIndex].tooltipKey\r\n                                                                    )\r\n                                                                \"\r\n                                                                placement=\"bottom auto\"\r\n                                                                container=\"body\"\r\n                                                                [autoClose]=\"true\"\r\n                                                                tooltipClass=\"tooltip-containing-table remove-on-scroll-class\"\r\n                                                                [ngbTooltip]=\"tooltipContainingTableTemplate\"\r\n                                                            >\r\n                                                            </i>\r\n                                                        </ng-container>\r\n\r\n                                                        <ng-container *ngIf=\"!action.tooltipData.tooltipTableBody\">\r\n                                                            <i\r\n                                                                *ngIf=\"action.showIcon\"\r\n                                                                [class]=\"action.iconClass\"\r\n                                                                [ngClass]=\"{ disabled: action.disabledIcon }\"\r\n                                                                (click)=\"\r\n                                                                    iconClickedOnStringIconActionType(\r\n                                                                        ROW_DATA,\r\n                                                                        action.id,\r\n                                                                        columnDef.headerInfo[subLineIndex]\r\n                                                                    )\r\n                                                                \"\r\n                                                                (mouseleave)=\"mouseLeaveTextActionType(ROW_DATA)\"\r\n                                                                (mouseenter)=\"\r\n                                                                    mouseEnterOnStringTextActionType(\r\n                                                                        ROW_DATA,\r\n                                                                        columnDef.headerInfo[subLineIndex].tooltipKey\r\n                                                                    )\r\n                                                                \"\r\n                                                                [placement]=\"\r\n                                                                    action.tooltipPlacement\r\n                                                                        ? action.tooltipPlacement\r\n                                                                        : 'bottom auto'\r\n                                                                \"\r\n                                                                container=\"body\"\r\n                                                                [autoClose]=\"true\"\r\n                                                                tooltipClass=\"team-user-tooltip remove-on-scroll-class {{\r\n                                                                    action.tooltipClass\r\n                                                                }}\"\r\n                                                                [ngbTooltip]=\"userLoggedInDetails\"\r\n                                                            >\r\n                                                            </i>\r\n                                                            <ng-container *ngIf=\"action['showSvgIcon']\">\r\n                                                                <anna-core-anna-est-icon-template\r\n                                                                    class=\"float-right\"\r\n                                                                    *ngIf=\"action['svgIconName'] == 'anna-icon'\"\r\n                                                                    (mouseleave)=\"mouseLeaveTextActionType(ROW_DATA)\"\r\n                                                                    (mouseenter)=\"\r\n                                                                        mouseEnterOnStringTextActionType(\r\n                                                                            ROW_DATA,\r\n                                                                            columnDef.headerInfo[subLineIndex]\r\n                                                                                .tooltipKey\r\n                                                                        )\r\n                                                                    \"\r\n                                                                    [placement]=\"\r\n                                                                        action.tooltipPlacement\r\n                                                                            ? action.tooltipPlacement\r\n                                                                            : 'bottom auto'\r\n                                                                    \"\r\n                                                                    tooltipClass=\"team-user-tooltip remove-on-scroll-class {{\r\n                                                                        action['tooltipClass']\r\n                                                                    }}\"\r\n                                                                    [ngbTooltip]=\"userLoggedInDetails\"\r\n                                                                    container=\"body\"\r\n                                                                    [autoClose]=\"true\"\r\n                                                                >\r\n                                                                </anna-core-anna-est-icon-template>\r\n                                                            </ng-container>\r\n                                                        </ng-container>\r\n                                                    </ng-container>\r\n\r\n                                                    <ng-container *ngIf=\"!action.showTooltip\">\r\n                                                        <i\r\n                                                            *ngIf=\"action.showIcon\"\r\n                                                            [class]=\"action.iconClass\"\r\n                                                            [ngClass]=\"{ disabled: action.disabledIcon }\"\r\n                                                            (click)=\"\r\n                                                                iconClickedOnStringIconActionType(\r\n                                                                    ROW_DATA,\r\n                                                                    action.id,\r\n                                                                    columnDef.headerInfo[subLineIndex]\r\n                                                                )\r\n                                                            \"\r\n                                                        >\r\n                                                        </i>\r\n                                                    </ng-container>\r\n                                                </ng-container>\r\n                                            </ng-container>\r\n\r\n                                            <ng-container *ngSwitchCase=\"'STRING_OR_INPUT'\">\r\n                                                <ng-container\r\n                                                    *ngIf=\"\r\n                                                        ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]?.type ==\r\n                                                            'STRING';\r\n                                                        else inputBox\r\n                                                    \"\r\n                                                >\r\n                                                    <span\r\n                                                        [innerHtml]=\"\r\n                                                            ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n                                                                ?.value\r\n                                                        \"\r\n                                                    ></span>\r\n                                                </ng-container>\r\n                                                <ng-template #inputBox>\r\n                                                    <input\r\n                                                        placeholder=\"{{\r\n                                                            ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n                                                                ?.placeholder\r\n                                                        }}\"\r\n                                                        showEllipsisTextOnHover\r\n                                                        class=\"{{\r\n                                                            ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n                                                                .className\r\n                                                        }}\"\r\n                                                        (keydown)=\"\r\n                                                            changesMadeInEditableInputBox(\r\n                                                                $event,\r\n                                                                ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey],\r\n                                                                false\r\n                                                            )\r\n                                                        \"\r\n                                                        (paste)=\"\r\n                                                            changesMadeInEditableInputBox(\r\n                                                                $event,\r\n                                                                ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey],\r\n                                                                true\r\n                                                            )\r\n                                                        \"\r\n                                                        (ngModelChange)=\"\r\n                                                            editableInputValueChanged(\r\n                                                                $event,\r\n                                                                ROW_DATA,\r\n                                                                columnDef.headerInfo[subLineIndex].objectKey\r\n                                                            )\r\n                                                        \"\r\n                                                        [ngModel]=\"\r\n                                                            ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey].value\r\n                                                        \"\r\n                                                        [disabled]=\"\r\n                                                            ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n                                                                .disabled\r\n                                                        \"\r\n                                                        [ngClass]=\"{\r\n                                                            'red-border':\r\n                                                                ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n                                                                    .hasError\r\n                                                        }\"\r\n                                                    />\r\n\r\n                                                    <i\r\n                                                        *ngIf=\"\r\n                                                            ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n                                                                .showIcon\r\n                                                        \"\r\n                                                        container=\"body\"\r\n                                                        [ngbTooltip]=\"\r\n                                                            ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n                                                                .iconTooltip\r\n                                                        \"\r\n                                                        tooltipClass=\"gt-total-row-tooltip\"\r\n                                                        placement=\"bottom\"\r\n                                                        class=\"{{\r\n                                                            ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n                                                                .iconClass\r\n                                                        }}\"\r\n                                                    >\r\n                                                    </i>\r\n                                                    <ng-container\r\n                                                        *ngIf=\"\r\n                                                            ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey][\r\n                                                                'showSvgIcon'\r\n                                                            ]\r\n                                                        \"\r\n                                                    >\r\n                                                        <anna-core-anna-est-icon-template\r\n                                                            class=\"float-right\"\r\n                                                            *ngIf=\"\r\n                                                                ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey][\r\n                                                                    'svgIconName'\r\n                                                                ] == 'anna-icon'\r\n                                                            \"\r\n                                                            [placement]=\"'bottom auto'\"\r\n                                                            tooltipClass=\"gt-total-row-tooltip\"\r\n                                                            [ngbTooltip]=\"\r\n                                                                ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n                                                                    .iconTooltip\r\n                                                            \"\r\n                                                            container=\"body\"\r\n                                                        >\r\n                                                        </anna-core-anna-est-icon-template>\r\n                                                    </ng-container>\r\n                                                </ng-template>\r\n                                            </ng-container>\r\n\r\n                                            <ng-container *ngSwitchCase=\"'HTML'\">\r\n                                                <span\r\n                                                    [innerHtml]=\"ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\r\n                                                ></span>\r\n                                            </ng-container>\r\n\r\n                                            <ng-container *ngSwitchCase=\"'SINGLE_RADIO'\">\r\n                                                <span\r\n                                                    *ngIf=\"ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\r\n                                                    [ngClass]=\"{\r\n                                                        'disable-checkbox':\r\n                                                            ROW_DATA[columnDef.headerInfo[subLineIndex].isDisabledKey]\r\n                                                    }\"\r\n                                                    class=\"mdi mdi-radiobox-marked\"\r\n                                                    (click)=\"(null)\"\r\n                                                >\r\n                                                </span>\r\n                                                <span\r\n                                                    *ngIf=\"!ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\r\n                                                    class=\"mdi mdi-radiobox-blank\"\r\n                                                    [ngClass]=\"{\r\n                                                        'disable-checkbox':\r\n                                                            ROW_DATA[columnDef.headerInfo[subLineIndex].isDisabledKey]\r\n                                                    }\"\r\n                                                    (click)=\"\r\n                                                        selectOrUnselectCheckbox(\r\n                                                            ROW_DATA,\r\n                                                            columnDef.headerInfo[subLineIndex].objectKey,\r\n                                                            true\r\n                                                        )\r\n                                                    \"\r\n                                                >\r\n                                                </span>\r\n                                            </ng-container>\r\n\r\n                                            <ng-container *ngSwitchCase=\"'RADIO'\">\r\n                                                <mat-radio-group\r\n                                                    *ngIf=\"ROW_DATA['RadioButtonConfig']\"\r\n                                                    [ngModel]=\"ROW_DATA[subline.objectKey]\"\r\n                                                    [disabled]=\"ROW_DATA['RadioButtonConfig'][0].isDisabled\"\r\n                                                >\r\n                                                    <ng-container\r\n                                                        *ngFor=\"\r\n                                                            let radioButton of ROW_DATA['RadioButtonConfig'];\r\n                                                            let last = last\r\n                                                        \"\r\n                                                    >\r\n                                                        <mat-radio-button\r\n                                                            value=\"{{ radioButton.value }}\"\r\n                                                            class=\"{{ radioButton.class }}\"\r\n                                                            (click)=\"\r\n                                                                radioButtonClicked(\r\n                                                                    ROW_DATA,\r\n                                                                    radioButton.value,\r\n                                                                    ROW_DATA['RadioButtonConfig'][0].isDisabled\r\n                                                                )\r\n                                                            \"\r\n                                                            >{{ radioButton.label }}\r\n                                                        </mat-radio-button>\r\n                                                        <i\r\n                                                            class=\" {{ radioButton.iconClass }}\"\r\n                                                            (click)=\"radioButtonIconClicked(ROW_DATA)\"\r\n                                                        ></i>\r\n                                                        <br *ngIf=\"!last\" />\r\n                                                    </ng-container>\r\n                                                </mat-radio-group>\r\n                                            </ng-container>\r\n\r\n                                            <ng-container *ngSwitchCase=\"'STRING_WITH_TOOLTIP'\">\r\n                                                <ng-container\r\n                                                    *ngFor=\"\r\n                                                        let action of ROW_DATA[\r\n                                                            columnDef.headerInfo[subLineIndex].actionKey\r\n                                                        ]\r\n                                                    \"\r\n                                                >\r\n                                                    <span> {{ action?.dataToDisplay }}</span>\r\n                                                    <span\r\n                                                        *ngIf=\"action?.showTooltip\"\r\n                                                        [ngbTooltip]=\"textActionTooltipTemplate\"\r\n                                                        (mouseenter)=\"\r\n                                                            mouseEnterOnStringTextActionType(\r\n                                                                ROW_DATA,\r\n                                                                columnDef.headerInfo[subLineIndex].tooltipKey\r\n                                                            )\r\n                                                        \"\r\n                                                        [placement]=\"action?.tooltipPosition\"\r\n                                                        container=\"body\"\r\n                                                        [class]=\"action?.tooltipIconClass\"\r\n                                                        tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\r\n                                                        [disableTooltip]=\"action?.disableTooltip\"\r\n                                                    >\r\n                                                    </span>\r\n                                                    <span> {{ action?.dataToDisplayAfterTooltip }}</span>\r\n                                                </ng-container>\r\n                                            </ng-container>\r\n\r\n                                            <ng-container *ngSwitchDefault>\r\n                                                <ng-container *ngIf=\"subline.objectKey != 'description'\">\r\n                                                    <span>{{\r\n                                                        ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n                                                    }}</span>\r\n                                                    <i\r\n                                                        *ngIf=\"\r\n                                                            subline.objectKey == 'inventoryCode' &&\r\n                                                            ROW_DATA['isSellerGroup'] &&\r\n                                                            gtGeneralConfig.component == 'RATING'\r\n                                                        \"\r\n                                                        class=\"mi mdi-info-outline seller-tooltip\"\r\n                                                        [ngbTooltip]=\"sellerHierarchyTooltip\"\r\n                                                        placement=\"bottom auto\"\r\n                                                        container=\"body\"\r\n                                                        [autoClose]=\"true\"\r\n                                                        triggers=\"manual\"\r\n                                                        (hidden)=\"closeTooltip()\"\r\n                                                        #info=\"ngbTooltip\"\r\n                                                        tooltipClass=\"hierarchy-tooltip remove-on-scroll-class\"\r\n                                                        (mouseenter)=\"\r\n                                                            bindTheValueToSellerGroupTooltip(\r\n                                                                ROW_DATA.sellerGroupHierarchy,\r\n                                                                info\r\n                                                            )\r\n                                                        \"\r\n                                                    >\r\n                                                    </i>\r\n\r\n                                                    <i\r\n                                                        *ngIf=\"\r\n                                                            subline.objectKey == 'displayBookedAverageRating' &&\r\n                                                            gtGeneralConfig.component == 'RATING' &&\r\n                                                            ROW_DATA['showRatingAverageIcon']\r\n                                                        \"\r\n                                                        class=\"mi mdi-info-outline seller-tooltip\"\r\n                                                        placement=\"bottom auto\"\r\n                                                        container=\"body\"\r\n                                                        [autoClose]=\"true\"\r\n                                                        (mouseenter)=\"\r\n                                                            setIsDifference(ROW_DATA.isDifferenceLessThan25Percent)\r\n                                                        \"\r\n                                                        tooltipClass=\"posted-avg-tooltip remove-on-scroll-class\"\r\n                                                        [ngbTooltip]=\"postedRatingDifference\"\r\n                                                    >\r\n                                                    </i>\r\n\r\n                                                    <i\r\n                                                        *ngIf=\"\r\n                                                            subline.objectKey == 'displayBookedAverageImpression' &&\r\n                                                            gtGeneralConfig.component == 'RATING' &&\r\n                                                            ROW_DATA['showImpressionAverageIcon']\r\n                                                        \"\r\n                                                        class=\"mi mdi-info-outline seller-tooltip\"\r\n                                                        placement=\"bottom auto\"\r\n                                                        container=\"body\"\r\n                                                        [autoClose]=\"true\"\r\n                                                        (mouseenter)=\"\r\n                                                            setIsDifference(ROW_DATA.isDifferenceLessThan25Percent)\r\n                                                        \"\r\n                                                        tooltipClass=\"posted-avg-tooltip remove-on-scroll-class\"\r\n                                                        [ngbTooltip]=\"postedImpDifference\"\r\n                                                    >\r\n                                                    </i>\r\n                                                </ng-container>\r\n                                                <ng-container *ngIf=\"subline.objectKey == 'description'\">\r\n                                                    <p\r\n                                                        *ngIf=\"\r\n                                                            ROW_DATA.descriptionMessage ||\r\n                                                            ROW_DATA.descriptionEmailReferenceNum\r\n                                                        \"\r\n                                                    >\r\n                                                        <ng-container *ngIf=\"ROW_DATA.descriptionMessage\">\r\n                                                            {{ ROW_DATA.descriptionMessage }}\r\n                                                            <br />\r\n                                                        </ng-container>\r\n                                                        <ng-container\r\n                                                            *ngIf=\"\r\n                                                                ROW_DATA.descriptionEmailReferenceNum != '-' &&\r\n                                                                ROW_DATA.descriptionEmailReferenceNum != ''\r\n                                                            \"\r\n                                                        >\r\n                                                            Email Ref: {{ ROW_DATA.descriptionEmailReferenceNum }}\r\n                                                            <br />\r\n                                                        </ng-container>\r\n                                                    </p>\r\n                                                    <a\r\n                                                        href=\"{{ ROW_DATA.descriptionDetailsUrl }}\"\r\n                                                        target=\"_blank\"\r\n                                                        *ngIf=\"\r\n                                                            ROW_DATA.descriptionDetailsUrlType === 'PDF' ||\r\n                                                            ROW_DATA.descriptionDetailsUrlType === 'EXCEL'\r\n                                                        \"\r\n                                                    >\r\n                                                        <button class=\"btn viewDetailsAndEmailBtn\">Download</button>\r\n                                                    </a>\r\n                                                    <ng-container\r\n                                                        *ngIf=\"ROW_DATA.activityname.toLowerCase() == 'order onboarded'\"\r\n                                                    >\r\n                                                        <a\r\n                                                            *ngIf=\"ROW_DATA.descriptionDetailsUrlType === 'LINK'\"\r\n                                                            (click)=\"viewDetailsClicked(ROW_DATA)\"\r\n                                                        >\r\n                                                            <button class=\"btn viewDetailsAndEmailBtn order-onboarded\">\r\n                                                                View details\r\n                                                            </button>\r\n                                                        </a>\r\n                                                    </ng-container>\r\n\r\n                                                    <a\r\n                                                        href=\"{{ ROW_DATA.descriptionEmailUrl }}\"\r\n                                                        target=\"_blank\"\r\n                                                        *ngIf=\"\r\n                                                            ROW_DATA.descriptionEmailUrl != '-' &&\r\n                                                            ROW_DATA.descriptionEmailUrl != ''\r\n                                                        \"\r\n                                                    >\r\n                                                        <button class=\"btn viewDetailsAndEmailBtn\">View email</button>\r\n                                                    </a>\r\n                                                </ng-container>\r\n                                            </ng-container>\r\n                                        </ng-container>\r\n                                    </div>\r\n                                </ng-container>\r\n                            </ng-container>\r\n                            <ng-container *ngIf=\"isNoDataToDisplaySubject$ | async\">\r\n                                <div>\r\n                                    {{ null }}\r\n                                </div>\r\n                            </ng-container>\r\n                        </ng-container>\r\n                    </td>\r\n                </ng-container>\r\n            </ng-container>\r\n        </table>\r\n    </div>\r\n    <anna-core-no-data-lib\r\n        [width]=\"noDataWidth\"\r\n        [marginTop]=\"marginTop\"\r\n        *ngIf=\"isNoDataToDisplaySubject$ | async\"\r\n    >\r\n    </anna-core-no-data-lib>\r\n</div>\r\n\r\n<!-- Checkbox template -->\r\n<ng-template #filterTooltip>\r\n    <anna-core-anna-column-checkbox-filter\r\n        [tableData]=\"tableData\"\r\n        [showFilterHeaderTabs]=\"showFilterTooltipTabs\"\r\n        [isLurAndCsrComponent]=\"false\"\r\n        [clonedTableData]=\"clonedTableData\"\r\n        [filterTabObjects]=\"filterTabObjects\"\r\n        (filterAppliedToTable)=\"filterApplied($event)\"\r\n        (sortingAppliedToTable)=\"sortingApplied($event)\"\r\n        (closeTooltip)=\"closeTooltip()\"\r\n    >\r\n    </anna-core-anna-column-checkbox-filter>\r\n</ng-template>\r\n\r\n<!-- Slider template -->\r\n<ng-template #sliderToolTip>\r\n    <anna-core-anna-column-slider-filter\r\n        [tableData]=\"tableData\"\r\n        [showFilterHeaderTabs]=\"showFilterTooltipTabs\"\r\n        [isLurAndCsrComponent]=\"false\"\r\n        [clonedTableData]=\"clonedTableData\"\r\n        [filterTabObjects]=\"filterTabObjects\"\r\n        (filterAppliedToTable)=\"filterApplied($event)\"\r\n        (sortingAppliedToTable)=\"sortingApplied($event)\"\r\n        (closeTooltip)=\"closeTooltip()\"\r\n    >\r\n    </anna-core-anna-column-slider-filter>\r\n</ng-template>\r\n\r\n<!-- Date Picker Template -->\r\n<ng-template #datePickerTooltip>\r\n    <anna-core-anna-column-date-range-filter\r\n        [tableData]=\"tableData\"\r\n        [showFilterHeaderTabs]=\"showFilterTooltipTabs\"\r\n        [isLurAndCsrComponent]=\"false\"\r\n        [clonedTableData]=\"clonedTableData\"\r\n        [filterTabObjects]=\"filterTabObjects\"\r\n        (filterAppliedToTable)=\"filterApplied($event)\"\r\n        (sortingAppliedToTable)=\"sortingApplied($event)\"\r\n        (closeTooltip)=\"closeTooltip()\"\r\n    >\r\n    </anna-core-anna-column-date-range-filter>\r\n</ng-template>\r\n\r\n<!-- Week Picker Template -->\r\n<ng-template #weekPickerToolTip>\r\n    <!-- <div class=\"weekpicker-container\">\r\n        <anna-core-week-calendar-filter-lib\r\n            [week-calendar-config]=\"gtGeneralConfig.multiWeekPickerConfig\"\r\n            (apply)=\"applyWeekFilter($event)\"\r\n            [from-date]=\"calendarMinEnabledDate\"\r\n            [to-date]=\"calendarMaxEnabledDate\"\r\n        >\r\n        </anna-core-week-calendar-filter-lib>\r\n    </div> -->\r\n</ng-template>\r\n\r\n<!-- Time Filter Template -->\r\n<ng-template #timeFilterToolTip>\r\n    <anna-core-anna-column-time-filter\r\n        [tableData]=\"tableData\"\r\n        [showFilterHeaderTabs]=\"showFilterTooltipTabs\"\r\n        [isLurAndCsrComponent]=\"false\"\r\n        [showAllTimeRangeCheckboxes]=\"showCheckboxesForTimeFilter\"\r\n        [clonedTableData]=\"clonedTableData\"\r\n        [filterTabObjects]=\"filterTabObjects\"\r\n        (filterAppliedToTable)=\"filterApplied($event)\"\r\n        (sortingAppliedToTable)=\"sortingApplied($event)\"\r\n        (closeTooltip)=\"closeTooltip()\"\r\n    >\r\n    </anna-core-anna-column-time-filter>\r\n</ng-template>\r\n\r\n<ng-template #columnInfoTooltip>\r\n    <p style=\"color: black; white-space: nowrap\">This preemption is rejected and not marked for credit.</p>\r\n</ng-template>\r\n\r\n<ng-template #ratingInfoTooltip>\r\n    <p class=\"first-row\">Shows 'Booked Rating' for Preemptions & MakeGood Offered spot(s).</p>\r\n    <p class=\"second-row\">Shows 'Projected Rating' for ADU Offered spot(s).</p>\r\n</ng-template>\r\n\r\n<ng-template #impsInfoTooltip>\r\n    <p class=\"first-row\">Shows 'Booked IMPS' for Preemptions & MakeGood Offered spot(s).</p>\r\n    <p class=\"second-row\">Shows 'Projected IMPS' for ADU Offered spot(s).</p>\r\n</ng-template>\r\n\r\n<ng-template #spotsColumnEquivalizationMessageTooltip>\r\n    <p class=\"spot-column-tooltip-message\">\r\n        This consists of equivalized spots and un-equivalized Paid Programs & un-equivalized Non-spots.\r\n    </p>\r\n</ng-template>\r\n\r\n<ng-template #underDeliveryTooltip>\r\n    <p class=\"spot-column-tooltip-message\">\r\n        Indicates the Under-delivery percentage based on booked and posted RTG/IMPS.\r\n    </p>\r\n</ng-template>\r\n\r\n<ng-template #overDeliveryTooltip>\r\n    <p class=\"spot-column-tooltip-message\">\r\n        Indicates the Over-delivery percentage based on booked and posted RTG/IMPS.\r\n    </p>\r\n</ng-template>\r\n\r\n<ng-template #rateInfoTooltip>\r\n    <p class=\"first-row\">Shows 'Booked Rate' for Preemptions & MakeGood Offered spot(s).</p>\r\n    <p class=\"second-row\">Shows 'Projected $ Value' for ADU Offered spot(s).</p>\r\n</ng-template>\r\n\r\n<ng-template #sellerHierarchyTooltip>\r\n    <ng-container *ngIf=\"sellerGroupHierarchy.length > 0\">\r\n        <section class=\"hierarchy-table-container\">\r\n            <table class=\"seller-hierarchy-table\">\r\n                <thead>\r\n                    <tr>\r\n                        <th>#</th>\r\n                        <th>Inventory Codes</th>\r\n                        <th>Program/Description</th>\r\n                    </tr>\r\n                </thead>\r\n                <tbody>\r\n                    <tr *ngFor=\"let data of sellerGroupHierarchy; let tooltipIndex = index\">\r\n                        <td>{{ tooltipIndex + 1 }}</td>\r\n                        <td>\r\n                            <span showEllipsisTextOnHover>{{ data.InventoryCode }}</span>\r\n                        </td>\r\n                        <td>\r\n                            <span showEllipsisTextOnHover>{{ data.Program }}</span>\r\n                        </td>\r\n                    </tr>\r\n                </tbody>\r\n            </table>\r\n        </section>\r\n    </ng-container>\r\n    <ng-container *ngIf=\"sellerGroupHierarchy.length == 0\">\r\n        <span style=\"color: #000\">Seller group not available for this inventory code</span>\r\n    </ng-container>\r\n</ng-template>\r\n\r\n<ng-template #lurViolationInfoTooltip>\r\n    <p class=\"first-row\">The values are for the entire week.</p>\r\n</ng-template>\r\n\r\n<ng-template #postedRatingDifference>\r\n    <p class=\"difference-text\">\r\n        The difference between posted and booked average rating is\r\n        {{ isDifferenceLessThan25Percent ? \"less\" : \"more\" }} than 25%.\r\n    </p>\r\n</ng-template>\r\n\r\n<ng-template #postedImpDifference>\r\n    <p class=\"difference-text\">\r\n        The difference between posted and booked average impression is\r\n        {{ isDifferenceLessThan25Percent ? \"less\" : \"more\" }} than 25%.\r\n    </p>\r\n</ng-template>\r\n\r\n<ng-template #ongoingRevBookedColumnTooltip>\r\n    <p>The Booked $ value, Spots, GRP, CPP, IMPS, CPM corresponds on the last permanent revision generated</p>\r\n</ng-template>\r\n\r\n<ng-template #completedRevBookedColumnTooltip>\r\n    <p>The Booked $ value corresponds on the last permanent revision generated</p>\r\n</ng-template>\r\n\r\n<ng-template #avgBookedRate>\r\n    <p>This is the booked average Rate</p>\r\n</ng-template>\r\n\r\n<ng-template #avgBookedRtg>\r\n    <p>This is the booked average RTG</p>\r\n</ng-template>\r\n\r\n<ng-template #avgBookedImps>\r\n    <p>This is the booked average IMP(’000)</p>\r\n</ng-template>\r\n\r\n<ng-template #projectedImpsRtg>\r\n    <p>\r\n        All projections are derived from the sum of actual posted information until the last posted date and estimates\r\n        for the remaining selected period.\r\n    </p>\r\n</ng-template>\r\n\r\n<ng-template #automationTooltip>\r\n    <p>\r\n        Please get the order business rules approved to activate the order for automation. Only for the\r\n        automation-activated orders, any approved MGs, ADUs, or credited spots on ANNA will be fed into the traffic\r\n        system i.e. ANNA revisions.\r\n        <!-- removed below line as part of enhancmennt in 14.0 releas -->\r\n        <!-- Additionally, ANNA will only enter buyer revisions into traffic for the selected\r\n        Medialine/WOC orders. -->\r\n    </p>\r\n</ng-template>\r\n\r\n<ng-template #rebateImpact>\r\n    <p>Rebate impact value is for the originally ordered spot length and is not equivalized.</p>\r\n</ng-template>\r\n\r\n<ng-template #lurViolationTotalRowToolTip>\r\n    <ul>\r\n        <li>\r\n            <strong>POLITICAL RATE VIOLATIONS:</strong>\r\n            Violations flagged when non-political spots are booked at a rate lower than the minimum booked rate for\r\n            political candidates for the same week, Inventory Code and Revenue Class.\r\n        </li>\r\n        <li>\r\n            <strong>CANDIDATE TO CANDIDATE VIOLATION:</strong>\r\n            Violations flagged when political spots are booked at different rates to other political spots for the same\r\n            week, Inventory Code and Revenue Class.\r\n        </li>\r\n    </ul>\r\n</ng-template>\r\n\r\n<ng-template #circularProgressBar>\r\n    <circle-progress\r\n        [percent]=\"percentDone\"\r\n        [radius]=\"5\"\r\n        [showTitle]=\"false\"\r\n        [showUnits]=\"false\"\r\n        [showSubtitle]=\"false\"\r\n        [outerStrokeWidth]=\"3\"\r\n        [innerStrokeWidth]=\"3\"\r\n        [space]=\"-3\"\r\n        [outerStrokeColor]=\"'#268bff'\"\r\n        [innerStrokeColor]=\"'#d5d5d5'\"\r\n        [animationDuration]=\"10\"\r\n    ></circle-progress>\r\n</ng-template>\r\n\r\n<ng-template #userLoggedInDetails>\r\n    <div class=\"tooltip-div-container\">\r\n        <ng-container *ngFor=\"let data of textActionTooltip\">\r\n            <span *ngIf=\"data.key != 'read'\">\r\n                {{ data.key }} <b> {{ data.value }}</b>\r\n            </span>\r\n            <span *ngIf=\"data.key == 'read'\">\r\n                {{ data.value }}\r\n            </span>\r\n        </ng-container>\r\n    </div>\r\n</ng-template>\r\n\r\n<ng-template #markAsReadTip>\r\n    <div class=\"notification-tooltip-div-container\">\r\n        <ng-container *ngFor=\"let data of textActionTooltip\">\r\n            {{ data.value }}\r\n        </ng-container>\r\n    </div>\r\n</ng-template>\r\n\r\n<ng-template #textActionTooltipTemplate>\r\n    <ng-container *ngFor=\"let data of textActionTooltip\">\r\n        {{ data.key }} <b> {{ data.value }}</b>\r\n    </ng-container>\r\n</ng-template>\r\n\r\n<ng-template #tooltipContainingTableTemplate>\r\n    <div\r\n        *ngIf=\"tooltipContainingTable\"\r\n        [innerHTML]=\"tooltipContainingTable.innerHtml\"\r\n        class=\"notification-tooltip-div-container\"\r\n    >\r\n        <!-- <ul>\r\n      <li *ngFor=\"let headerMsg of tooltipContainingTable.tableHeaderMsg\">\r\n        <b> {{headerMsg}}  </b>\r\n      </li>\r\n    </ul>\r\n\r\n    <table class=\"tooltip-table\">\r\n      <thead>\r\n        <tr>\r\n          <th *ngFor=\"let header of tooltipContainingTable.tooltipTableHeader\">\r\n            {{ header}}\r\n          </th>\r\n        </tr>\r\n      </thead>\r\n      <tbody>\r\n        <tr *ngFor=\"let rows of tooltipContainingTable.tooltipTableBody\">\r\n          <td *ngFor=\"let data of rows\">\r\n            {{ data }}\r\n          </td>\r\n        </tr>\r\n      </tbody>\r\n    </table>\r\n\r\n    <ul>\r\n      <li style=\"margin-top:10px; padding:0\" *ngFor=\"let footerMsg of tooltipContainingTable.tableFooterMsg\">\r\n        {{ footerMsg }} \r\n      </li>\r\n    </ul> -->\r\n    </div>\r\n</ng-template>\r\n<!-- <ng-template #textActionTooltipTemplate>\r\n   <ng-container *ngFor=\"let data of textActionTooltip\">\r\n      {{ data.key }} <b> {{data.value}}</b>\r\n   </ng-container>\r\n</ng-template> -->\r\n"]}
1
+ // Angular import statements
2
+ import { Component, Input, ViewChildren, QueryList, Output, EventEmitter, ChangeDetectorRef, ChangeDetectionStrategy, } from '@angular/core';
3
+ // Third party import statements
4
+ import { cloneDeep, isEqual, uniq } from 'lodash-es';
5
+ import { AnnaDateTimeFormatService } from '../../../anna-core-shared-lib/services/anna-date-time-format.service';
6
+ import { radioButtonModel } from '../../../anna-core-shared-lib/models/anna-tooltip.model';
7
+ import { AnnaSortService } from '../../../anna-core-shared-lib/services/anna-sort.service';
8
+ import { AnnaFilterService } from '../../../anna-core-shared-lib/services/anna-filter.service';
9
+ import { BehaviorSubject } from 'rxjs';
10
+ import { NgCircleProgressModule } from 'ng-circle-progress';
11
+ import { AnnaColumnTimeFilterComponent } from '../anna-column-filters/anna-column-time-filter/anna-column-time-filter.component';
12
+ import { AnnaColumnDateRangeFilterComponent } from '../anna-column-filters/anna-column-date-range-filter/anna-column-date-range-filter.component';
13
+ import { AnnaColumnSliderFilterComponent } from '../anna-column-filters/anna-column-slider-filter/anna-column-slider-filter.component';
14
+ import { AnnaColumnCheckboxFilterComponent } from '../anna-column-filters/anna-column-checkbox-filter/anna-column-checkbox-filter.component';
15
+ import { AnnaNoDataComponent } from '../../../anna-core-shared-lib/components/anna-no-data/anna-no-data.component';
16
+ import { MatRadioModule } from '@angular/material/radio';
17
+ import { FormsModule } from '@angular/forms';
18
+ import { AnnaIconColumnComponent } from '../../../anna-core-shared-lib/components/anna-icon-column/anna-icon-column.component';
19
+ import { showEllipsisTextOnHoverDirective } from '../../../anna-core-shared-lib/directives/show-ellipsis-text/show-ellipsis-text.directive';
20
+ import { NgxSkeletonLoaderModule } from 'ngx-skeleton-loader';
21
+ import { NgbTooltip } from '@ng-bootstrap/ng-bootstrap';
22
+ import { MatTableModule } from '@angular/material/table';
23
+ import { NgClass, NgStyle, NgFor, NgIf, NgTemplateOutlet, NgSwitch, NgSwitchCase, NgSwitchDefault, AsyncPipe, } from '@angular/common';
24
+ import * as i0 from "@angular/core";
25
+ import * as i1 from "../../../anna-core-shared-lib/services/anna-sort.service";
26
+ import * as i2 from "../../../anna-core-shared-lib/services/anna-date-time-format.service";
27
+ import * as i3 from "../../../anna-core-shared-lib/services/anna-filter.service";
28
+ import * as i4 from "@angular/material/table";
29
+ import * as i5 from "ngx-skeleton-loader";
30
+ import * as i6 from "@angular/forms";
31
+ import * as i7 from "@angular/material/radio";
32
+ import * as i8 from "ng-circle-progress";
33
+ export class AnnaNonEditableGenericTableComponent {
34
+ constructor(cdRef, annaSortService, annaDateTimeFormatService, annaFilterService) {
35
+ this.cdRef = cdRef;
36
+ this.annaSortService = annaSortService;
37
+ this.annaDateTimeFormatService = annaDateTimeFormatService;
38
+ this.annaFilterService = annaFilterService;
39
+ this.maximumRowsWhichCanBeRenderedWithoutScroll = 5;
40
+ this.fixNumberOfRowsForPopup = false;
41
+ this.limit = 30;
42
+ this.includeBorderInTableHeight = true;
43
+ this.clickableRow = false;
44
+ this.setTableHeightWhenRowSizeIsFixed = true;
45
+ this.tableBorderBottomClassRequired = true;
46
+ this.hideSomeTds = false;
47
+ this.tdsHaveRowSpan = false;
48
+ this.multipleTablesPresent = false;
49
+ this.toggleCheckbox = new EventEmitter();
50
+ this.toggleRowCheckbox = new EventEmitter();
51
+ this.toggleHeaderCheckbox = new EventEmitter();
52
+ this.undoIconClicked = new EventEmitter();
53
+ this.filterAppliedToTable = new EventEmitter();
54
+ this.sortingAppliedToTable = new EventEmitter();
55
+ this.rowClicked = new EventEmitter();
56
+ this.radioButtonSelected = new EventEmitter();
57
+ this.columnFilterOpened = new EventEmitter();
58
+ this.columnFilterClosed = new EventEmitter();
59
+ this.gtIconClicked = new EventEmitter();
60
+ this.gtSVGIconClicked = new EventEmitter();
61
+ this.gtTextActionClicked = new EventEmitter();
62
+ this.gtViewDetailClicked = new EventEmitter();
63
+ this.gtInnerHTMLClicked = new EventEmitter();
64
+ this.downloadSpotDetails = new EventEmitter();
65
+ this.clickableDataClicked = new EventEmitter();
66
+ this.totalRowIconClicked = new EventEmitter();
67
+ this.notificationIconHover = new EventEmitter();
68
+ this.notificationIconHoverLeave = new EventEmitter();
69
+ this.editableInputEdited = new EventEmitter();
70
+ this.radioButtonMessageIconClicked = new EventEmitter();
71
+ this.numberOfSkeletonRows = Array(20).fill(0);
72
+ this.noDataWidth = '50%';
73
+ this.filterAlignment = 'bottom auto';
74
+ this.disableColumnClearAllBtn = true;
75
+ this.margin = 5;
76
+ this.tableColumns = [];
77
+ this.totalRowColumns = null;
78
+ this.isScrolledLeft = false;
79
+ this.rowBorderWidth = 2;
80
+ this.isScrollEnded = true;
81
+ this.marginTop = '';
82
+ this.start = 0;
83
+ this.end = this.limit + this.start;
84
+ this.isNoDataToDisplaySubject$ = new BehaviorSubject(false);
85
+ this.textActionTooltip = [];
86
+ this.tooltipContainingTable = null;
87
+ this.tableBottomBorderClass = null;
88
+ this.showCheckboxesForTimeFilter = false;
89
+ this.setTooltipRadioNames();
90
+ }
91
+ ngAfterViewChecked() {
92
+ this.setMarginLeftForFilterIcon();
93
+ }
94
+ ngOnInit() {
95
+ this.setFilterAlignmentBasedOnScreenResolution();
96
+ }
97
+ detectChanges() {
98
+ this.cdRef.detectChanges();
99
+ }
100
+ ngOnChanges(changes) {
101
+ if (changes &&
102
+ changes['gtDimension'] &&
103
+ changes['gtDimension'].currentValue &&
104
+ this.setTableHeightWhenRowSizeIsFixed) {
105
+ this.setTableHeight();
106
+ this.setTableBottomBorder();
107
+ }
108
+ if (this.showSkeletonLoading) {
109
+ this.tableData = this.numberOfSkeletonRows;
110
+ this.renderedData = this.numberOfSkeletonRows;
111
+ this.isNoDataToDisplaySubject$.next(false);
112
+ this.setTableBottomBorder();
113
+ }
114
+ else if (changes['percentDone'] ||
115
+ changes['downloadInProgress'] ||
116
+ (changes['starredInProgress'] && changes['starredInProgress'].currentValue != undefined)) {
117
+ //no task will be performed
118
+ }
119
+ else {
120
+ this.setInitialRowsForTable();
121
+ this.disableEnableEachColumnTooltipIcon();
122
+ this.tableColumns = this.tableHeaders.filter((x) => x.visible).map((x) => x.headerInfo[0].objectKey);
123
+ if ((this.tableData && this.tableData.length == 0) ||
124
+ (this.tableData.length == 2 && this.checkIfAllTheElementsAreZero())) {
125
+ this.tableData = Array(2).fill(0);
126
+ this.renderedData = cloneDeep(this.tableData);
127
+ this.marginTop = -this.gtDimension.rowHeight - this.gtDimension.rowHeight / 2 + 'px';
128
+ this.isNoDataToDisplaySubject$.next(true);
129
+ }
130
+ else {
131
+ this.isNoDataToDisplaySubject$.next(false);
132
+ }
133
+ this.showSkeletonLoading = false;
134
+ this.setTableBottomBorder();
135
+ }
136
+ //setting table column here as well because while showing skeleton loader, we should show table headers.
137
+ if (changes['tableHeaders'] &&
138
+ !isEqual(changes['tableHeaders'].currentValue, changes['tableHeaders'].previousValue)) {
139
+ this.tableColumns = this.tableHeaders.filter((x) => x.visible).map((x) => x.headerInfo[0].objectKey);
140
+ this.annaSortService.columnSortState = new Map();
141
+ this.annaFilterService.initialValueMap = new Map();
142
+ // this.setColumnSortStateMap();
143
+ this.setActiveStateObject();
144
+ }
145
+ if (changes['totalRowInfo'] && changes['totalRowInfo'].currentValue) {
146
+ this.totalRowColumns = this.totalRowInfo.map((x) => x.colName);
147
+ }
148
+ this.cdRef.detectChanges();
149
+ }
150
+ setFilterAlignmentBasedOnScreenResolution() {
151
+ let viewportHeight = window.innerHeight;
152
+ if (viewportHeight < 740) {
153
+ this.filterAlignment = 'left right';
154
+ }
155
+ else {
156
+ this.filterAlignment = 'bottom left right';
157
+ }
158
+ }
159
+ setTableBottomBorder() {
160
+ if (this.tableBorderBottomClassRequired &&
161
+ this.tableData &&
162
+ this.tableData.length &&
163
+ this.maximumRowsWhichCanBeRenderedWithoutScroll < this.tableData.length) {
164
+ this.tableBottomBorderClass = 'bottom-border';
165
+ }
166
+ else {
167
+ this.tableBottomBorderClass = null;
168
+ }
169
+ }
170
+ checkIfAllTheElementsAreZero() {
171
+ return !this.tableData.some((item) => item != 0);
172
+ }
173
+ setTableHeight() {
174
+ let viewportHeight = window.innerHeight;
175
+ let rowHeight = this.gtDimension.rowHeight;
176
+ let headerHeight = this.gtDimension.headerHeight;
177
+ let dataOnTopHeight = this.gtDimension.dataOnTopHeight;
178
+ let marginFromBottom = this.gtDimension.marginFromBottom;
179
+ let actualTableHeight;
180
+ if (this.fixNumberOfRowsForPopup) {
181
+ let maxNoOfRowsToDisplay = viewportHeight < 740 ? 5 : 10;
182
+ this.maximumRowsWhichCanBeRenderedWithoutScroll = maxNoOfRowsToDisplay;
183
+ actualTableHeight = this.maximumRowsWhichCanBeRenderedWithoutScroll * rowHeight + headerHeight;
184
+ }
185
+ else {
186
+ let minHeightForTable = headerHeight + 3 * rowHeight;
187
+ viewportHeight = viewportHeight <= dataOnTopHeight ? dataOnTopHeight + minHeightForTable : viewportHeight;
188
+ let heightLeftForTable = viewportHeight - dataOnTopHeight - marginFromBottom;
189
+ this.maximumRowsWhichCanBeRenderedWithoutScroll =
190
+ Math.ceil((heightLeftForTable - headerHeight - rowHeight) / rowHeight) + 1;
191
+ actualTableHeight = viewportHeight - dataOnTopHeight - marginFromBottom;
192
+ }
193
+ // let actualTableHeight = heightLeftForTable - ((heightLeftForTable - headerHeight - rowHeight) % rowHeight);
194
+ this.gtDimension.tableHeight = `${actualTableHeight}px`;
195
+ this.numberOfSkeletonRows = this.maximumRowsWhichCanBeRenderedWithoutScroll
196
+ ? Array(this.maximumRowsWhichCanBeRenderedWithoutScroll).fill(0)
197
+ : Array(5).fill(0);
198
+ }
199
+ trackByFn(index) {
200
+ return index;
201
+ }
202
+ setTooltipRadioNames() {
203
+ this.tooltipRadioTextMap = new Map();
204
+ this.tooltipRadioTextMap.set('StartTimeForFilter', 'Start Time');
205
+ this.tooltipRadioTextMap.set('EndTimeForFilter', 'End Time');
206
+ this.tooltipRadioTextMap.set('startTimeForFilter', 'Start Time');
207
+ this.tooltipRadioTextMap.set('endTimeForFilter', 'End Time');
208
+ this.tooltipRadioTextMap.set('start_time_for_filter', 'Start Time');
209
+ this.tooltipRadioTextMap.set('end_time_for_filter', 'End Time');
210
+ this.tooltipRadioTextMap.set('primaryAEName', 'Primary AE');
211
+ this.tooltipRadioTextMap.set('region', 'Region');
212
+ this.tooltipRadioTextMap.set('agencyName', 'Agency');
213
+ this.tooltipRadioTextMap.set('location', 'Location');
214
+ this.tooltipRadioTextMap.set('advertiserName', 'Advertiser');
215
+ this.tooltipRadioTextMap.set('productCode', 'Product Code');
216
+ this.tooltipRadioTextMap.set('flightStartDate', 'Start Date');
217
+ this.tooltipRadioTextMap.set('flightEndDate', 'End Date');
218
+ this.tooltipRadioTextMap.set('orderIdAndRevNumber', 'STN Order#-Rev#');
219
+ this.tooltipRadioTextMap.set('stationOrderNumber', 'STN Order#');
220
+ this.tooltipRadioTextMap.set('alternateOrderId', 'Alt/Rep Order #');
221
+ this.tooltipRadioTextMap.set('grp', 'GRP');
222
+ this.tooltipRadioTextMap.set('cpp', 'CPP');
223
+ this.tooltipRadioTextMap.set('imps', 'IMPS');
224
+ this.tooltipRadioTextMap.set('cpm', 'CPM');
225
+ this.tooltipRadioTextMap.set('offeredMGs', 'Offered MG');
226
+ this.tooltipRadioTextMap.set('outstandingPE', 'O/S PE');
227
+ this.tooltipRadioTextMap.set('offeredADUs', 'Offered ADUs');
228
+ this.tooltipRadioTextMap.set('udDeficitValue', 'O/S Aud Delta');
229
+ this.tooltipRadioTextMap.set('startEndTimeMulti', 'Time');
230
+ this.tooltipRadioTextMap.set('bookedValue', 'Booked');
231
+ this.tooltipRadioTextMap.set('bookedSpots', 'Spots');
232
+ this.tooltipRadioTextMap.set('UserCreditedValue', 'User Credited');
233
+ this.tooltipRadioTextMap.set('UserUnresolvedValue', 'User Unresolved');
234
+ this.tooltipRadioTextMap.set('BuyerAddedValue', 'Buyer Added');
235
+ this.tooltipRadioTextMap.set('BuyerDeletedValue', 'Buyer Deleted');
236
+ this.tooltipRadioTextMap.set('userChanges', 'User Changes');
237
+ this.tooltipRadioTextMap.set('buyerChanges', 'Buyer Changes');
238
+ this.tooltipRadioTextMap.set('userMG', 'User MG');
239
+ this.tooltipRadioTextMap.set('userADUs', 'User ADUs');
240
+ this.tooltipRadioTextMap.set('inventoryCode', 'Inventory Code');
241
+ this.tooltipRadioTextMap.set('program', 'Program');
242
+ this.tooltipRadioTextMap.set('agency', 'Agency');
243
+ this.tooltipRadioTextMap.set('advertiser', 'Advertiser');
244
+ this.tooltipRadioTextMap.set('startDate', 'Start Date');
245
+ this.tooltipRadioTextMap.set('endDate', 'End Date');
246
+ this.tooltipRadioTextMap.set('date', 'Date');
247
+ this.tooltipRadioTextMap.set('rcvPreempt', '$ Madegood PEs');
248
+ this.tooltipRadioTextMap.set('osPreempt', '$ O/S PEs');
249
+ this.tooltipRadioTextMap.set('rcvUnderDly', 'Recovered UD');
250
+ this.tooltipRadioTextMap.set('osUnderDly', 'O/s Under Dly');
251
+ this.tooltipRadioTextMap.set('primaryAe', 'Primary AE');
252
+ this.tooltipRadioTextMap.set('region', 'Region');
253
+ this.tooltipRadioTextMap.set('revCode1', 'Rev code 1');
254
+ this.tooltipRadioTextMap.set('orderNoRevNo', 'STN Order#-Rev#');
255
+ this.tooltipRadioTextMap.set('revCode2', 'Rev code 2');
256
+ this.tooltipRadioTextMap.set('revCode3', 'Rev code 3');
257
+ this.tooltipRadioTextMap.set('booked', '$ Booked');
258
+ this.tooltipRadioTextMap.set('spots', 'Spots');
259
+ this.tooltipRadioTextMap.set('postedAudPercent', 'Posted %');
260
+ this.tooltipRadioTextMap.set('revision', 'Revision');
261
+ this.tooltipRadioTextMap.set('buyerOrderId', 'ALT/REP Order#');
262
+ this.tooltipRadioTextMap.set('demo', 'Demo');
263
+ this.tooltipRadioTextMap.set('postedAdu', '$ Posted ADUs');
264
+ this.tooltipRadioTextMap.set('scheduledAdu', '$ Scheduled ADUs');
265
+ this.tooltipRadioTextMap.set('audienceDeficit', '$ O/S Audience');
266
+ this.tooltipRadioTextMap.set('postedAudPercent', 'Posted Audience %');
267
+ this.tooltipRadioTextMap.set('potentialUnitsValue', 'POT Units');
268
+ this.tooltipRadioTextMap.set('bookedUnitsValue', 'Booked Eq Units');
269
+ this.tooltipRadioTextMap.set('bookedAmountWithZeroRatingValue', 'Total $ Booked');
270
+ this.tooltipRadioTextMap.set('bookedAmountPercentageWithZeroRatingValue', '% Against All Demos');
271
+ this.tooltipRadioTextMap.set('bookedAmountWithoutZeroRatingValue', '$Booked With Imps(’000)');
272
+ this.tooltipRadioTextMap.set('bookedAmountPercentageWithoutZeroRatingValue', '% Against All Demos');
273
+ this.tooltipRadioTextMap.set('totalBookedAmountValue', 'Total $Booked');
274
+ this.tooltipRadioTextMap.set('averageUnitRateValue', ' AUR');
275
+ this.tooltipRadioTextMap.set('totalBookedAmountWithRatingValue', '$Booked With Rating');
276
+ this.tooltipRadioTextMap.set('averageUnitRateWithRatingValue', 'AUR With Rating');
277
+ this.tooltipRadioTextMap.set('totalBookedAmountWithImpressionValue', '$Booked With IMPS');
278
+ this.tooltipRadioTextMap.set('averageUnitRateWithImpressionValue', 'AUR With IMPS');
279
+ this.tooltipRadioTextMap.set('bookedUnitsWithRatingValue', 'Booked Units With Rating');
280
+ this.tooltipRadioTextMap.set('postedUnitsWithRatingValue', 'Posted Units With Rating');
281
+ this.tooltipRadioTextMap.set('bookedUnitsWithImpressionValue', 'Booked Units With IMPS');
282
+ this.tooltipRadioTextMap.set('postedUnitsWithImpressionValue', 'Posted Units With IMPS');
283
+ this.tooltipRadioTextMap.set('bookedRatings', 'Booked Rating');
284
+ this.tooltipRadioTextMap.set('postedRatings', 'POSTED Rating');
285
+ this.tooltipRadioTextMap.set('PostedRating', 'Posted RTG');
286
+ this.tooltipRadioTextMap.set('bookedImpressions', "Booked IMP('000)");
287
+ this.tooltipRadioTextMap.set('postedImpressions', "Posted IMP('000)");
288
+ this.tooltipRadioTextMap.set('PostedImpressions', "Posted IMP('000)");
289
+ this.tooltipRadioTextMap.set('bookedAverageRating', 'Booked AU Rating');
290
+ this.tooltipRadioTextMap.set('postedAverageRating', 'Posted AU Rating');
291
+ this.tooltipRadioTextMap.set('bookedAverageImpression', 'Booked AU IMPS');
292
+ this.tooltipRadioTextMap.set('postedAverageImpression', 'Posted AU IMPS');
293
+ this.tooltipRadioTextMap.set('bookedCppValue', 'Booked CPP');
294
+ this.tooltipRadioTextMap.set('bookedEffectiveCppValue', 'Effective CPP');
295
+ this.tooltipRadioTextMap.set('bookedCpmValue', 'Booked CPM');
296
+ this.tooltipRadioTextMap.set('bookedEffectiveCpmValue', 'Effective CPM');
297
+ this.tooltipRadioTextMap.set('orderSource', 'Order Route');
298
+ this.tooltipRadioTextMap.set('orderCategory', 'Rev Category');
299
+ this.tooltipRadioTextMap.set('cashOrTrade', 'C/T');
300
+ this.tooltipRadioTextMap.set('revisionStartDate', 'Revision Start Date');
301
+ this.tooltipRadioTextMap.set('name', 'name');
302
+ this.tooltipRadioTextMap.set('role', 'role');
303
+ this.tooltipRadioTextMap.set('stationCount', 'stationCount');
304
+ this.tooltipRadioTextMap.set('stationList', 'stationList');
305
+ this.tooltipRadioTextMap.set('approvedOn', 'Approved On');
306
+ this.tooltipRadioTextMap.set('approvedBy', 'Approved By');
307
+ this.tooltipRadioTextMap.set('ODImps', 'Proj. OD IMPS');
308
+ this.tooltipRadioTextMap.set('UDImps', 'Proj. UD IMPS');
309
+ this.tooltipRadioTextMap.set('ODGrp', 'Proj. OD GRP');
310
+ this.tooltipRadioTextMap.set('UDGrp', 'Proj. UD GRP');
311
+ this.tooltipRadioTextMap.set('udImpsPercent', 'Proj. UD %');
312
+ this.tooltipRadioTextMap.set('udGrpPercent', 'Proj. UD GRP %');
313
+ this.tooltipRadioTextMap.set('odImpsPercent', 'Proj. OD %');
314
+ this.tooltipRadioTextMap.set('odGrpPercent', 'Proj. OD GRP %');
315
+ this.tooltipRadioTextMap.set('RevisionNumber', 'Revision #');
316
+ this.tooltipRadioTextMap.set('RevisionType', 'Revision Type');
317
+ this.tooltipRadioTextMap.set('GeneratedOn', 'Generated On');
318
+ this.tooltipRadioTextMap.set('BookedValueForDisplay', '$ BOOKED');
319
+ this.tooltipRadioTextMap.set('BookedValue', '$ Booked');
320
+ this.tooltipRadioTextMap.set('BookedSpots', 'Spots');
321
+ this.tooltipRadioTextMap.set('BookedGRP', 'GRP');
322
+ this.tooltipRadioTextMap.set('BookedIMPSRevTab', "IMPS'(000)");
323
+ this.tooltipRadioTextMap.set('BookedCPP', 'CPP');
324
+ this.tooltipRadioTextMap.set('BookedCPM', 'CPM');
325
+ this.tooltipRadioTextMap.set('MGsValueForDisplay', '$ MGS');
326
+ this.tooltipRadioTextMap.set('MGsValue', '$ MGS');
327
+ this.tooltipRadioTextMap.set('ADUsValueForDisplay', '$ ADUS');
328
+ this.tooltipRadioTextMap.set('ADUsValue', '$ ADUS');
329
+ this.tooltipRadioTextMap.set('BuyerChangesValueForDisplay', '$ Buyer Change');
330
+ this.tooltipRadioTextMap.set('BuyerChangesValue', '$ Buyer Change');
331
+ this.tooltipRadioTextMap.set('UserChangesValueForDisplay', '$ Seller User Change');
332
+ this.tooltipRadioTextMap.set('UserChangesValue', '$ Seller User Change');
333
+ this.tooltipRadioTextMap.set('SellerLine', 'Seller Line #');
334
+ this.tooltipRadioTextMap.set('BuyerLine', 'Buy Line #');
335
+ this.tooltipRadioTextMap.set('SpotStatus', 'Spot Status');
336
+ this.tooltipRadioTextMap.set('InventoryCode', 'Inventory Code');
337
+ this.tooltipRadioTextMap.set('BuyerProgramName', 'Buyer Program Name');
338
+ this.tooltipRadioTextMap.set('RevenueClass', 'Revenue Class');
339
+ this.tooltipRadioTextMap.set('WeeklyAUR', 'Booked Avg. Rate');
340
+ this.tooltipRadioTextMap.set('BookedRate', 'Booked Rate');
341
+ this.tooltipRadioTextMap.set('averageRate', 'Average Rate');
342
+ this.tooltipRadioTextMap.set('bookedAverageRate', 'Booked AVG. Rate');
343
+ this.tooltipRadioTextMap.set('dollarIMPSImpact', '$ IMPS Impact');
344
+ this.tooltipRadioTextMap.set('dollarRTGImpact', '$ RTG IMPACT');
345
+ this.tooltipRadioTextMap.set('IMPSImpact', "IMPS ('000) IMPACT");
346
+ this.tooltipRadioTextMap.set('RTGImpact', 'RTG Impact');
347
+ this.tooltipRadioTextMap.set('inventoryFillPercentageSameWeek', 'Inv Fill Same Week');
348
+ this.tooltipRadioTextMap.set('inventoryFillPercentageFinal', 'Inv Fill Final');
349
+ this.tooltipRadioTextMap.set('projectedRTG', 'Projected RTG');
350
+ this.tooltipRadioTextMap.set('projectedIMPS', "Projected IMPS('000)");
351
+ this.tooltipRadioTextMap.set('desiredCPM', 'Desired CPM');
352
+ this.tooltipRadioTextMap.set('desiredCPP', 'Desired CPP');
353
+ this.tooltipRadioTextMap.set('origin', 'Origin');
354
+ this.tooltipRadioTextMap.set('BookedRTG', 'Booked RTG');
355
+ this.tooltipRadioTextMap.set('BookedIMPS', "Booked IMPS('000)");
356
+ this.tooltipRadioTextMap.set('IMPS', "IMP('000)");
357
+ this.tooltipRadioTextMap.set('AURTG', 'Avg RTG');
358
+ this.tooltipRadioTextMap.set('AUIMPS', "Avg IMP('000)");
359
+ this.tooltipRadioTextMap.set('PostedRatingsOrImpressions', 'Posted RTG');
360
+ this.tooltipRadioTextMap.set('ScheduleFlightWeek', 'Schedule Week');
361
+ this.tooltipRadioTextMap.set('ScheduledDay', 'Scheduled Day');
362
+ this.tooltipRadioTextMap.set('AirStatus', 'Air Status');
363
+ this.tooltipRadioTextMap.set('AirDateAndTime', 'Air Date & Time');
364
+ this.tooltipRadioTextMap.set('AirDate', 'Air Date');
365
+ this.tooltipRadioTextMap.set('NormalizedOrderedRating', 'Normalized Booked RTG');
366
+ this.tooltipRadioTextMap.set('NormalizedOrderedImpressions', "Normalized Booked IMP('000)");
367
+ this.tooltipRadioTextMap.set('NormalizedPostedRating', 'Normalized Posted RTG');
368
+ this.tooltipRadioTextMap.set('NormalizedPostedImpressions', "Normalized Posted IMP('000)");
369
+ this.tooltipRadioTextMap.set('AdId', 'Ad-Id');
370
+ this.tooltipRadioTextMap.set('displayimps', 'IMPS');
371
+ this.tooltipRadioTextMap.set('displayGrp', 'GRP');
372
+ this.tooltipRadioTextMap.set('bookedSpotsForDisplay', 'Spots');
373
+ this.tooltipRadioTextMap.set('displaySpots', 'Spots');
374
+ this.tooltipRadioTextMap.set('estimateNo', 'Estimate#');
375
+ this.tooltipRadioTextMap.set('primaryBuyer', 'Primary Buyer');
376
+ this.tooltipRadioTextMap.set('primaryBuyerName', 'Primary Buyer');
377
+ this.tooltipRadioTextMap.set('secondaryBuyerName', 'Secondary Buyer');
378
+ this.tooltipRadioTextMap.set('secondaryBuyer', 'Secondary Buyer');
379
+ this.tooltipRadioTextMap.set('timeoutDate', 'Timeout Date');
380
+ this.tooltipRadioTextMap.set('DisplaytSpotStatusBI', 'Spot Status');
381
+ this.tooltipRadioTextMap.set('LineSpot', 'Line.Spot');
382
+ this.tooltipRadioTextMap.set('LurWindowName', 'Political Window');
383
+ this.tooltipRadioTextMap.set('length', 'Length');
384
+ this.tooltipRadioTextMap.set('revClass', 'Rev Class');
385
+ // this.tooltipRadioTextMap.set("udValue", "$ UD");
386
+ // this.tooltipRadioTextMap.set("odValue", "$ OD");
387
+ this.tooltipRadioTextMap.set('udValue', 'Proj. $ UD');
388
+ this.tooltipRadioTextMap.set('odValue', 'Proj. $ OD');
389
+ this.tooltipRadioTextMap.set('OtherAvailableSpotsTableInventoryCode', 'Inventory Code');
390
+ this.tooltipRadioTextMap.set('OtherAvailableSpotsTableBuyerProgramName', 'Buyer Program Name');
391
+ this.tooltipRadioTextMap.set('OtherAvailableSpotsTableStartTime', 'Start Time');
392
+ this.tooltipRadioTextMap.set('OtherAvailableSpotsTableEndTime', 'End Time');
393
+ this.tooltipRadioTextMap.set('OtherAvailableSpotsTableWeeklyAUR', 'Booked Avg. Rate');
394
+ this.tooltipRadioTextMap.set('OtherAvailableSpotsTableDisplayRevenueClass', 'Rev Class');
395
+ this.tooltipRadioTextMap.set('OtherAvailableSpotsTableActualWeekStartDate', 'Week');
396
+ this.tooltipRadioTextMap.set('OtherAvailableSpotsTableWeekDay', 'Day');
397
+ this.tooltipRadioTextMap.set('OtherAvailableSpotsTableDisplayLength', 'Length');
398
+ this.tooltipRadioTextMap.set('ProjectedImpressions', "Projected IMP('000)");
399
+ this.tooltipRadioTextMap.set('ProjectedRtg', 'Projected RTG');
400
+ }
401
+ selectOrUnselectCheckbox(rowData, columnKeys, isCheckboxSelected) {
402
+ rowData[columnKeys] = !rowData[columnKeys];
403
+ this.toggleCheckbox.emit({ rowData, columnKeys, isCheckboxSelected });
404
+ }
405
+ selectOrUnselectRadiobox(rowData, columnKeys, isCheckboxSelected) {
406
+ if (rowData[columnKeys] == isCheckboxSelected)
407
+ return;
408
+ rowData[columnKeys] = isCheckboxSelected;
409
+ this.toggleCheckbox.emit({ rowData, columnKeys, isCheckboxSelected });
410
+ }
411
+ selectUnselectAllRows() {
412
+ this.toggleHeaderCheckbox.emit();
413
+ }
414
+ selectUnselectRow(rowData) {
415
+ this.toggleRowCheckbox.emit(rowData);
416
+ }
417
+ undoCreditedSpot(data) {
418
+ this.undoIconClicked.emit({ data, mgOrCredit: 'Credit' });
419
+ }
420
+ undoMgSpot(data) {
421
+ this.undoIconClicked.emit({ data, mgOrCredit: 'MakeGood' });
422
+ }
423
+ //Sort and Filter Logic begins!
424
+ closeTooltip() {
425
+ if (this.tooltip && this.tooltip.isOpen()) {
426
+ this.tooltip.close();
427
+ }
428
+ this.tooltip = null;
429
+ if (!this.bindValueFuncCalled) {
430
+ this.columnFilterClosed.emit();
431
+ }
432
+ }
433
+ isTooltipActive(header) {
434
+ return this.annaFilterService.isTooltipActive(header, this.annaSortService.columnSortState);
435
+ }
436
+ bindTheValueToToolTip(tooltip, header) {
437
+ this.bindValueFuncCalled = true;
438
+ // if same tooltip opened close it
439
+ if (tooltip == this.tooltip) {
440
+ this.bindValueFuncCalled = false;
441
+ this.closeTooltip();
442
+ }
443
+ else {
444
+ let enabledHeaders = [];
445
+ this.checkIfUniqueValuePresentForTheHeader(header, enabledHeaders);
446
+ this.openTooltip(tooltip, enabledHeaders, header);
447
+ if (window.innerWidth < 1500 &&
448
+ window.innerHeight < 768 &&
449
+ !this.annaFilterService.sliderSet.has(header.filterSortObjectKeys[0])) {
450
+ this.columnFilterOpened.emit();
451
+ }
452
+ this.showCheckboxesForTimeFilter =
453
+ this.gtGeneralConfig.component == 'SPOTDETAILS' ||
454
+ this.gtGeneralConfig.component == 'EXCLUDEINVENTORYPOPUP' ||
455
+ this.gtGeneralConfig.component == 'RATING';
456
+ this.showFilterTooltipTabs = header.filterSortObjectKeys.length > 1;
457
+ this.bindValueFuncCalled = false;
458
+ }
459
+ }
460
+ checkIfUniqueValuePresentForTheHeader(header, enabledHeaders) {
461
+ header.filterSortObjectKeys.forEach((item) => {
462
+ let dataToCheck = this.annaFilterService.getFilterOptionsData(this.tableData, this.clonedTableData, item);
463
+ if (item == 'period') {
464
+ let uniqStartDate = uniq(dataToCheck.map((u) => u['startDate']));
465
+ let uniqEndDate = uniq(dataToCheck.map((u) => u['endDate']));
466
+ if (uniqStartDate.length > 1 || uniqEndDate.length > 1 || this.isTooltipActive([item])) {
467
+ enabledHeaders.push(item);
468
+ }
469
+ }
470
+ else {
471
+ let values = dataToCheck.map((u) => u[item]);
472
+ // if last applied filter is this header, push it alos as enabledHeader
473
+ let activeAndLastlyAppliedHeader = false;
474
+ if (this.annaFilterService.appliedFiltersArray.length > 0 &&
475
+ this.annaFilterService.appliedFiltersArray[this.annaFilterService.appliedFiltersArray.length - 1] ==
476
+ item) {
477
+ activeAndLastlyAppliedHeader = true;
478
+ }
479
+ if (header.filter == 'CHECKBOX' &&
480
+ (uniq(values).filter((n) => n != null).length > 1 || activeAndLastlyAppliedHeader)) {
481
+ enabledHeaders.push(item);
482
+ }
483
+ else if (header.filter != 'CHECKBOX' &&
484
+ (uniq(values).filter((n) => n != null && n != '-').length > 1 || activeAndLastlyAppliedHeader)) {
485
+ enabledHeaders.push(item);
486
+ }
487
+ }
488
+ });
489
+ }
490
+ openTooltip(tooltip, header, columnHeader) {
491
+ this.closeTooltip();
492
+ this.tooltip = tooltip;
493
+ this.tooltip.open();
494
+ //convert key into the header
495
+ this.filterTabObjects = header.map((key, index) => {
496
+ let value = this.tooltipRadioTextMap.has(key) ? this.tooltipRadioTextMap.get(key) : key; //change to display name
497
+ return new radioButtonModel(key, value, columnHeader.isSortRequired[index], columnHeader.isFilterRequired[index]);
498
+ });
499
+ }
500
+ disableEnableEachColumnTooltipIcon() {
501
+ this.tableHeaders.forEach((header) => {
502
+ header.headerInfo.forEach((item) => {
503
+ if (item.showTooltipIcon) {
504
+ let values = [];
505
+ item.disableTooltipIcon = true;
506
+ item.filterSortObjectKeys.forEach((key) => {
507
+ let latestFilters = this.annaFilterService.appliedFiltersArray;
508
+ if (latestFilters.length > 0 &&
509
+ item.disableTooltipIcon &&
510
+ latestFilters[latestFilters.length - 1] == key) {
511
+ item.disableTooltipIcon = false;
512
+ }
513
+ if (item.disableTooltipIcon) {
514
+ if (key == 'period') {
515
+ let uniqStartDate = uniq(this.tableData.map((u) => u['startDate']));
516
+ let uniqEndDate = uniq(this.tableData.map((u) => u['endDate']));
517
+ item.disableTooltipIcon =
518
+ uniqStartDate.length > 1 || uniqEndDate.length > 1 ? false : true;
519
+ }
520
+ else {
521
+ values = this.tableData.map((u) => u[key]);
522
+ if ((item.filter == 'CHECKBOX' && uniq(values).filter((n) => n != null).length > 1) ||
523
+ (item.filter != 'CHECKBOX' &&
524
+ uniq(values).filter((n) => n != null && n != '-').length > 1)) {
525
+ item.disableTooltipIcon = false;
526
+ }
527
+ }
528
+ }
529
+ });
530
+ }
531
+ });
532
+ });
533
+ }
534
+ setMarginLeftForFilterIcon() {
535
+ let elementArr = this.viewChildTableHeaders.toArray();
536
+ elementArr.forEach((item) => {
537
+ let childDivElements = item.nativeElement.children;
538
+ if (childDivElements.length == 2) {
539
+ let firstParagraphOffsetWidth = childDivElements[0]?.children[0]?.offsetWidth
540
+ ? childDivElements[0]?.children[0]?.offsetWidth
541
+ : 0;
542
+ let secondParagraphOffsetWidth = childDivElements[1].children[0]?.offsetWidth
543
+ ? childDivElements[1].children[0]?.offsetWidth
544
+ : 0;
545
+ if (firstParagraphOffsetWidth > secondParagraphOffsetWidth) {
546
+ let diff = firstParagraphOffsetWidth - secondParagraphOffsetWidth;
547
+ if (childDivElements[0].children.length == 2) {
548
+ childDivElements[0].children[1].style.marginLeft = 4 + 'px';
549
+ }
550
+ if (childDivElements[1].children.length == 2) {
551
+ childDivElements[1].children[1].style.marginLeft = diff + 4 + 'px';
552
+ }
553
+ }
554
+ else {
555
+ let diff = secondParagraphOffsetWidth - firstParagraphOffsetWidth;
556
+ if (childDivElements[0].children.length == 2) {
557
+ childDivElements[0].children[1].style.marginLeft = diff + 4 + 'px';
558
+ }
559
+ if (childDivElements[1].children.length == 2) {
560
+ childDivElements[1].children[1].style.marginLeft = 4 + 'px';
561
+ }
562
+ }
563
+ }
564
+ });
565
+ }
566
+ dataRowClicked(rowData) {
567
+ this.rowClicked.emit(rowData);
568
+ }
569
+ radioButtonClicked(data, action, isDisabled) {
570
+ if (!isDisabled) {
571
+ this.radioButtonSelected.emit({ data, action });
572
+ }
573
+ }
574
+ bindTheValueToSellerGroupTooltip(sellerGroupHierarchy, tooltip) {
575
+ if (this.hierarchyTooltip && this.hierarchyTooltip.open) {
576
+ this.hierarchyTooltip.close();
577
+ }
578
+ this.sellerGroupHierarchy = sellerGroupHierarchy;
579
+ this.hierarchyTooltip = tooltip;
580
+ this.hierarchyTooltip.open();
581
+ }
582
+ iconClicked(rowData, iconClass) {
583
+ if ('orderId' in rowData && iconClass.includes('mdi-star')) {
584
+ this.selectedStarredOrderId = rowData.orderId;
585
+ }
586
+ this.gtIconClicked.emit({ data: rowData, iconClass: iconClass });
587
+ }
588
+ svgIconClicked(data) {
589
+ this.gtSVGIconClicked.emit(data);
590
+ }
591
+ textActionClicked(rowData, id, columnHeader) {
592
+ this.gtTextActionClicked.emit({ data: rowData, id: id, columnHeader: columnHeader, isIconClicked: false });
593
+ }
594
+ iconClickedOnStringIconActionType(rowData, id, columnHeader) {
595
+ this.gtTextActionClicked.emit({ data: rowData, id: id, columnHeader: columnHeader, isIconClicked: true });
596
+ }
597
+ innerHTMLCellClicked(event, rowData) {
598
+ this.gtInnerHTMLClicked.emit({ event, rowData });
599
+ }
600
+ viewDetailsClicked(rowData) {
601
+ this.gtViewDetailClicked.emit({ data: rowData });
602
+ }
603
+ setActiveStateObject() {
604
+ this.annaFilterService.isFilterSortActive =
605
+ !this.annaFilterService.resetFilterSortActiveStatus || this.multipleTablesPresent
606
+ ? this.annaFilterService.isFilterSortActive
607
+ : {};
608
+ this.tableHeaders.forEach((item) => {
609
+ item.headerInfo.forEach((header) => {
610
+ if (header.showTooltipIcon) {
611
+ let key = header.filterSortObjectKeys.join(',');
612
+ header.joinedFilterSortObjectKeys = key;
613
+ // ANNA-4113 fix
614
+ if (this.annaFilterService.resetFilterSortActiveStatus) {
615
+ this.annaFilterService.isFilterSortActive[key] = false;
616
+ }
617
+ }
618
+ });
619
+ });
620
+ this.annaFilterService.resetFilterSortActiveStatus = true;
621
+ }
622
+ setIsDifference(value) {
623
+ this.isDifferenceLessThan25Percent = value;
624
+ }
625
+ resetIndex() {
626
+ this.start = 0;
627
+ this.end = this.limit + this.start;
628
+ }
629
+ onTableContainerScroll(e) {
630
+ const tableViewHeight = e.target.offsetHeight; // viewport
631
+ const tableScrollHeight = e.target.scrollHeight; // length of all table
632
+ const scrollLocation = e.target.scrollTop; // how far user scrolled
633
+ this.removeTooltipOnScroll();
634
+ // If the user has scrolled within 150px of the bottom, add more data
635
+ const buffer = 150;
636
+ const limit = tableScrollHeight - tableViewHeight - buffer;
637
+ if (scrollLocation > limit) {
638
+ let data = this.getTableData(this.start, this.end);
639
+ this.renderedData = this.renderedData.concat(data);
640
+ this.updateIndex();
641
+ }
642
+ this.tableContainerScrolled(e);
643
+ }
644
+ getTableData(start, end) {
645
+ return this.tableData.filter((value, index) => index >= start && index < end);
646
+ }
647
+ updateIndex() {
648
+ this.start = this.end;
649
+ this.end = this.limit + this.start;
650
+ }
651
+ setInitialRowsForTable() {
652
+ this.resetIndex();
653
+ this.renderedData = this.getTableData(this.start, this.end);
654
+ this.updateIndex();
655
+ }
656
+ spotDetailsDownloadClicked(parentChildOrTotalRow, rowdata) {
657
+ if (rowdata) {
658
+ this.selectedInventoryIdForDownload = rowdata.inventoryCodeId;
659
+ this.selectedDemographicForDownload = rowdata.demographic;
660
+ }
661
+ else {
662
+ this.selectedInventoryIdForDownload = null;
663
+ this.selectedDemographicForDownload = null;
664
+ }
665
+ this.selectedRowTypeForDownload = parentChildOrTotalRow;
666
+ this.downloadSpotDetails.emit({
667
+ parentChildOrTotalRow: parentChildOrTotalRow,
668
+ inventoryCodeId: this.selectedInventoryIdForDownload,
669
+ demographic: this.selectedDemographicForDownload,
670
+ });
671
+ }
672
+ tableContainerScrolled(event) {
673
+ this.isScrolledLeft = event.target.scrollLeft > 0;
674
+ this.isScrollEnded = Math.round(event.target.scrollLeft) == event.target.scrollWidth - event.target.clientWidth;
675
+ this.removeTooltipOnScroll();
676
+ }
677
+ mouseEnterOnStringTextActionType(rowData, tooltipKey) {
678
+ this.textActionTooltip = rowData[tooltipKey];
679
+ this.notificationIconHover.emit({ rowData: rowData, type: 'on-enter' });
680
+ }
681
+ mouseEnterOnStringTextActionTypeContainingTable(rowData, tooltipKey) {
682
+ this.tooltipContainingTable = rowData[tooltipKey];
683
+ }
684
+ mouseLeaveTextActionType(rowData) {
685
+ this.notificationIconHoverLeave.emit({ rowData: rowData, type: 'on-leave' });
686
+ }
687
+ mouseEnterOnTextActionType(rowData, tooltipKey) {
688
+ this.textActionTooltip = rowData[tooltipKey];
689
+ }
690
+ onClickableDataClicked(Rowdata, id) {
691
+ this.clickableDataClicked.emit({ data: Rowdata, id: id });
692
+ }
693
+ removeTooltipOnScroll() {
694
+ const elements = document.getElementsByClassName('remarks-info-tooltip');
695
+ // const tooltipElements = document.getElementsByClassName("tooltip");
696
+ const gtTooltip = document.getElementsByClassName('remove-on-scroll-class');
697
+ const tooltipElements = document.getElementsByClassName('tooltip');
698
+ while (elements && elements.length > 0) {
699
+ elements[0].remove();
700
+ }
701
+ while (tooltipElements && tooltipElements.length > 0) {
702
+ tooltipElements[0].remove();
703
+ this.tooltip = null;
704
+ }
705
+ while (gtTooltip && gtTooltip.length > 0) {
706
+ gtTooltip[0].remove();
707
+ }
708
+ }
709
+ iconClickedInTotalRow(colName) {
710
+ this.totalRowIconClicked.emit(colName);
711
+ }
712
+ changesMadeInEditableInputBox(event, editedObject, pasteEvent) {
713
+ let enteredValue = pasteEvent ? event.clipboardData.getData('text') : event.key;
714
+ let dotIndex = editedObject.value.indexOf('.');
715
+ if (event.keyCode != 8 &&
716
+ event.keyCode != 46 &&
717
+ !(event.keyCode >= 37 && event.keyCode <= 40) &&
718
+ ((!editedObject?.allowSpecialCharacters && !/[`0-9.]/.test(enteredValue)) ||
719
+ (editedObject.isDecimalPointCheckRequired &&
720
+ dotIndex >= 0 &&
721
+ event?.target?.selectionStart > dotIndex &&
722
+ editedObject.value.length - (dotIndex + 1) >= editedObject.maxDecimalPointsAllowed))) {
723
+ event.preventDefault();
724
+ }
725
+ }
726
+ editableInputValueChanged(value, row, keyEdited) {
727
+ this.editableInputEdited.emit({ row: row, value: value, keyEdited: keyEdited });
728
+ }
729
+ radioButtonIconClicked(data) {
730
+ this.radioButtonMessageIconClicked.emit(data);
731
+ }
732
+ filterApplied(tableData) {
733
+ this.tableData = tableData;
734
+ this.setInitialRowsForTable();
735
+ this.disableEnableEachColumnTooltipIcon();
736
+ this.filterAppliedToTable.emit(tableData);
737
+ this.closeTooltip();
738
+ }
739
+ sortingApplied(tableData) {
740
+ this.tableData = tableData;
741
+ this.setInitialRowsForTable();
742
+ this.disableEnableEachColumnTooltipIcon();
743
+ this.sortingAppliedToTable.emit(tableData);
744
+ this.closeTooltip();
745
+ }
746
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AnnaNonEditableGenericTableComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.AnnaSortService }, { token: i2.AnnaDateTimeFormatService }, { token: i3.AnnaFilterService }], target: i0.ɵɵFactoryTarget.Component }); }
747
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: AnnaNonEditableGenericTableComponent, isStandalone: true, selector: "anna-core-non-editable-generic-table-lib", inputs: { showSkeletonLoading: "showSkeletonLoading", tableHeaders: "tableHeaders", tableData: "tableData", clonedTableData: "clonedTableData", gtGeneralConfig: "gtGeneralConfig", totalRowInfo: "totalRowInfo", gtDimension: "gtDimension", tableClass: "tableClass", maximumRowsWhichCanBeRenderedWithoutScroll: "maximumRowsWhichCanBeRenderedWithoutScroll", fixNumberOfRowsForPopup: "fixNumberOfRowsForPopup", limit: "limit", includeBorderInTableHeight: "includeBorderInTableHeight", downloadInProgress: "downloadInProgress", percentDone: "percentDone", starredInProgress: "starredInProgress", clickableRow: "clickableRow", setTableHeightWhenRowSizeIsFixed: "setTableHeightWhenRowSizeIsFixed", tableBorderBottomClassRequired: "tableBorderBottomClassRequired", hideSomeTds: "hideSomeTds", tdsHaveRowSpan: "tdsHaveRowSpan", multipleTablesPresent: "multipleTablesPresent" }, outputs: { toggleCheckbox: "toggleCheckbox", toggleRowCheckbox: "toggleRowCheckbox", toggleHeaderCheckbox: "toggleHeaderCheckbox", undoIconClicked: "undoIconClicked", filterAppliedToTable: "filterAppliedToTable", sortingAppliedToTable: "sortingAppliedToTable", rowClicked: "rowClicked", radioButtonSelected: "radioButtonSelected", columnFilterOpened: "columnFilterOpened", columnFilterClosed: "columnFilterClosed", gtIconClicked: "gtIconClicked", gtSVGIconClicked: "gtSVGIconClicked", gtTextActionClicked: "gtTextActionClicked", gtViewDetailClicked: "gtViewDetailClicked", gtInnerHTMLClicked: "gtInnerHTMLClicked", downloadSpotDetails: "downloadSpotDetails", clickableDataClicked: "clickableDataClicked", totalRowIconClicked: "totalRowIconClicked", notificationIconHover: "notificationIconHover", notificationIconHoverLeave: "notificationIconHoverLeave", editableInputEdited: "editableInputEdited", radioButtonMessageIconClicked: "radioButtonMessageIconClicked" }, viewQueries: [{ propertyName: "viewChildTableHeaders", predicate: ["tableHeader"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div\r\n id=\"generic-table-conatiner\"\r\n class=\"table-container {{ gtGeneralConfig?.tableOuterContainerName }} {{ tableBottomBorderClass }}\"\r\n [ngClass]=\"{\r\n 'scroll-left-shadow-effect': isScrolledLeft,\r\n 'scroll-right-shadow-effect': !isScrollEnded,\r\n 'clickable-row': clickableRow,\r\n 'no-data-table': (isNoDataToDisplaySubject$ | async)\r\n }\"\r\n (scroll)=\"onTableContainerScroll($event)\"\r\n>\r\n <div\r\n [class]=\"gtGeneralConfig.tableContainerName\"\r\n class=\"horizontal-scroll-for-table-container\"\r\n [ngStyle]=\"{\r\n height:\r\n tableData.length < maximumRowsWhichCanBeRenderedWithoutScroll\r\n ? 'calc(' +\r\n (gtDimension.rowHeight * tableData.length +\r\n (!tableData.length || !gtGeneralConfig.totalRow\r\n ? gtDimension.headerHeight\r\n : gtDimension.headerHeight + gtDimension.rowHeight)) +\r\n 'px)'\r\n : gtDimension.tableHeight\r\n }\"\r\n >\r\n <table\r\n class=\"gt\"\r\n [ngClass]=\"tableClass\"\r\n mat-table\r\n [dataSource]=\"renderedData\"\r\n >\r\n <tr\r\n class=\"header-row\"\r\n mat-header-row\r\n *matHeaderRowDef=\"tableColumns; sticky: true\"\r\n [style.height.px]=\"gtDimension.headerHeight\"\r\n ></tr>\r\n <tr\r\n class=\"total-row\"\r\n mat-header-row\r\n [style.height.px]=\"gtDimension.rowHeight\"\r\n *matHeaderRowDef=\"totalRowColumns; sticky: true\"\r\n [class.hidden]=\"\r\n showSkeletonLoading ||\r\n (!showSkeletonLoading && !tableData.length) ||\r\n (isNoDataToDisplaySubject$ | async) ||\r\n (!showSkeletonLoading && !gtGeneralConfig.totalRow)\r\n \"\r\n ></tr>\r\n <tr\r\n [class]=\"rowData.gtClass\"\r\n [ngClass]=\"{ 'no-border-tr': (isNoDataToDisplaySubject$ | async) }\"\r\n mat-row\r\n *matRowDef=\"let rowData; columns: tableColumns\"\r\n [style.height.px]=\"gtDimension.rowHeight\"\r\n (click)=\"dataRowClicked(rowData)\"\r\n ></tr>\r\n\r\n <!-- TOTAL ROW -->\r\n <ng-container\r\n [matColumnDef]=\"column.colName\"\r\n *ngFor=\"let column of totalRowInfo; trackBy: trackByFn\"\r\n >\r\n <td\r\n mat-header-cell\r\n *matHeaderCellDef\r\n [attr.colspan]=\"column.colspan\"\r\n class=\"{{ column.class }}\"\r\n >\r\n <ng-container *ngIf=\"column['isActionColumn']\">\r\n <a\r\n *ngFor=\"let data of column.actionData\"\r\n [class]=\"data.class\"\r\n (click)=\"onClickableDataClicked({}, data.id)\"\r\n >\r\n {{ data.name }}\r\n </a>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"column['isIconColumn']\">\r\n <i\r\n class=\"{{ column?.iconData?.class }}\"\r\n (click)=\"iconClickedInTotalRow(column?.colName)\"\r\n >\r\n </i>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"!column['isActionColumn']\">\r\n <strong class=\"upper-label\">{{ column.data }}</strong>\r\n <ng-container *ngIf=\"column.lowerData\">\r\n <br />\r\n <span\r\n *ngIf=\"\r\n column.colName == 'total-potential-booked-unit' &&\r\n gtGeneralConfig.component == 'RATING';\r\n else columnLowerData\r\n \"\r\n class=\"clickable-data\"\r\n (click)=\"spotDetailsDownloadClicked('TOTALROW')\"\r\n [ngClass]=\"{ 'disabled-clickable-data': downloadInProgress }\"\r\n >{{ column.lowerData }}\r\n <span class=\"material-icons spot-details-download-icons\">get_app</span>\r\n <ng-container *ngIf=\"downloadInProgress && selectedRowTypeForDownload == 'TOTALROW'\">\r\n <ng-container [ngTemplateOutlet]=\"circularProgressBar\"></ng-container>\r\n </ng-container>\r\n </span>\r\n <ng-template #columnLowerData>\r\n <span class=\"lower-label\">{{ column.lowerData }}</span>\r\n </ng-template>\r\n </ng-container>\r\n <ng-container *ngIf=\"column.tooltipMessage && gtGeneralConfig.component != 'LUR_VIOLATIONS'\">\r\n <i\r\n class=\"{{ column.tooltipIconClass }}\"\r\n container=\"body\"\r\n [ngbTooltip]=\"column.tooltipMessage\"\r\n tooltipClass=\"gt-total-row-tooltip\"\r\n placement=\"bottom\"\r\n ></i>\r\n </ng-container>\r\n <ng-container *ngIf=\"gtGeneralConfig.component == 'LUR_VIOLATIONS' && column.tooltipMessage\">\r\n <i\r\n class=\"mi mdi-info-outline info-label\"\r\n container=\"body\"\r\n [ngbTooltip]=\"lurViolationTotalRowToolTip\"\r\n tooltipClass=\"gt-total-row-tooltip\"\r\n placement=\"bottom\"\r\n ></i>\r\n </ng-container>\r\n </ng-container>\r\n </td>\r\n </ng-container>\r\n\r\n <!-- MAIN ROW -->\r\n <ng-container\r\n [matColumnDef]=\"columnDef.headerInfo[0].objectKey\"\r\n *ngFor=\"let columnDef of tableHeaders; trackBy: trackByFn\"\r\n >\r\n <th\r\n #tableHeader\r\n nowrap\r\n mat-header-cell\r\n *matHeaderCellDef\r\n [style.width]=\"columnDef.width\"\r\n >\r\n <div\r\n class=\"row mx-0\"\r\n *ngFor=\"let header of columnDef.headerInfo; let j = index\"\r\n >\r\n <p\r\n *ngIf=\"header.typeOfHeaderData === 'STRING'\"\r\n [ngClass]=\"{ 'upper-label': j === 0, 'lower-label': j === 1 }\"\r\n >\r\n <ngx-skeleton-loader\r\n *ngIf=\"header.name == null\"\r\n count=\"1\"\r\n [theme]=\"{\r\n height: '10px',\r\n display: 'block',\r\n width: columnDef.width,\r\n 'max-width': 'calc(100% - 20px)'\r\n }\"\r\n >\r\n </ngx-skeleton-loader>\r\n <ng-container *ngIf=\"header.name\">\r\n {{ header.name }}\r\n </ng-container>\r\n <ng-container *ngIf=\"header.tooltip && header.tooltip.tooltipMessage\">\r\n <i\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"header.tooltip.tooltipMessage\"\r\n container=\"body\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n </ng-container>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'impsInfoTooltip'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"impsInfoTooltip\"\r\n container=\"body\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"\r\n header.tooltip && header.tooltip.name == 'spotsColumnEquivalizationMessageTooltip'\r\n \"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n container=\"body\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"spotsColumnEquivalizationMessageTooltip\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'underDeliveryTooltip'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n container=\"body\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"underDeliveryTooltip\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'overDeliveryTooltip'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n container=\"body\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"overDeliveryTooltip\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'ratingInfoTooltip'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"ratingInfoTooltip\"\r\n container=\"body\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'rateInfoTooltip'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"rateInfoTooltip\"\r\n container=\"body\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'ongoingRevBookedColumnTooltip'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"ongoingRevBookedColumnTooltip\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'completedRevBookedColumnTooltip'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"completedRevBookedColumnTooltip\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'avgBookedRate'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"avgBookedRate\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'avgBookedRtg'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"avgBookedRtg\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'avgBookedImps'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"avgBookedImps\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'automationTooltip'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"automationTooltip\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'rebateImpact'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"rebateImpact\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'projectedImpsRtg'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"projectedImpsRtg\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n </p>\r\n\r\n <ng-container *ngIf=\"header.typeOfHeaderData === 'CHECKBOX'\">\r\n <span\r\n *ngIf=\"gtGeneralConfig.isHeaderChecked\"\r\n class=\"material-icons custom-column-checkbox-checked\"\r\n (click)=\"selectUnselectAllRows()\"\r\n >\r\n check_box\r\n </span>\r\n <span\r\n *ngIf=\"!gtGeneralConfig.isHeaderChecked\"\r\n class=\"material-icons custom-column-checkbox-unchecked\"\r\n [ngClass]=\"{ 'disable-checkbox': gtGeneralConfig.disableHeaderCheckbox }\"\r\n (click)=\"selectUnselectAllRows()\"\r\n >\r\n check_box_outline_blank\r\n </span>\r\n </ng-container>\r\n\r\n <div\r\n *ngIf=\"gtGeneralConfig.showAllColumnFilter\"\r\n class=\"sort-filter-container\"\r\n >\r\n <ng-container *ngIf=\"header.showTooltipIcon\">\r\n <!-- Active tooltip Functionality -->\r\n <ng-container *ngIf=\"header.filter === 'CHECKBOX'\">\r\n <span\r\n class=\"mdi mdi-filter-variant\"\r\n [ngClass]=\"{\r\n active:\r\n annaFilterService.isFilterSortActive &&\r\n annaFilterService.isFilterSortActive[header.joinedFilterSortObjectKeys],\r\n disabled: header.disableTooltipIcon || showSkeletonLoading\r\n }\"\r\n [ngbTooltip]=\"filterTooltip\"\r\n placement=\"{{ filterAlignment }}\"\r\n container=\"body\"\r\n tooltipClass=\"non-edit-checkbox-tooltip\"\r\n [autoClose]=\"'outside'\"\r\n triggers=\"manual\"\r\n #t=\"ngbTooltip\"\r\n (click)=\"bindTheValueToToolTip(t, header)\"\r\n (hidden)=\"closeTooltip()\"\r\n >\r\n </span\r\n ><br />\r\n </ng-container>\r\n <ng-container *ngIf=\"header.filter === 'SLIDER'\">\r\n <span\r\n class=\"mdi mdi-filter-variant\"\r\n [ngClass]=\"{\r\n active:\r\n annaFilterService.isFilterSortActive &&\r\n annaFilterService.isFilterSortActive[header.joinedFilterSortObjectKeys],\r\n disabled: header.disableTooltipIcon || showSkeletonLoading\r\n }\"\r\n [ngbTooltip]=\"sliderToolTip\"\r\n placement=\"bottom left-top\"\r\n container=\"body\"\r\n tooltipClass=\"non-edit-slider-tooltip\"\r\n [autoClose]=\"'outside'\"\r\n triggers=\"manual\"\r\n #t1=\"ngbTooltip\"\r\n (click)=\"bindTheValueToToolTip(t1, header)\"\r\n (hidden)=\"closeTooltip()\"\r\n >\r\n </span\r\n ><br />\r\n </ng-container>\r\n <ng-container *ngIf=\"header.filter === 'DATE'\">\r\n <span\r\n class=\"mdi mdi-filter-variant\"\r\n [ngClass]=\"{\r\n active:\r\n annaFilterService.isFilterSortActive &&\r\n annaFilterService.isFilterSortActive[header.joinedFilterSortObjectKeys],\r\n disabled: header.disableTooltipIcon || showSkeletonLoading\r\n }\"\r\n [ngbTooltip]=\"datePickerTooltip\"\r\n placement=\"bottom auto\"\r\n container=\"body\"\r\n tooltipClass=\"non-edit-datepicker-tooltip\"\r\n [autoClose]=\"'outside'\"\r\n triggers=\"manual\"\r\n #t2=\"ngbTooltip\"\r\n (click)=\"bindTheValueToToolTip(t2, header)\"\r\n (hidden)=\"closeTooltip()\"\r\n >\r\n </span\r\n ><br />\r\n </ng-container>\r\n <ng-container *ngIf=\"header.filter === 'WEEK'\">\r\n <span\r\n class=\"mdi mdi-filter-variant\"\r\n [ngClass]=\"{\r\n active:\r\n annaFilterService.isFilterSortActive &&\r\n annaFilterService.isFilterSortActive[header.joinedFilterSortObjectKeys],\r\n disabled: header.disableTooltipIcon || showSkeletonLoading\r\n }\"\r\n [ngbTooltip]=\"weekPickerToolTip\"\r\n placement=\"bottom left-top\"\r\n container=\"body\"\r\n [autoClose]=\"'outside'\"\r\n triggers=\"manual\"\r\n #t3=\"ngbTooltip\"\r\n (click)=\"bindTheValueToToolTip(t3, header)\"\r\n (hidden)=\"closeTooltip()\"\r\n >\r\n </span\r\n ><br />\r\n </ng-container>\r\n <ng-container *ngIf=\"header.filter === 'TIME'\">\r\n <span\r\n class=\"mdi mdi-filter-variant\"\r\n [ngClass]=\"{\r\n active:\r\n annaFilterService.isFilterSortActive &&\r\n annaFilterService.isFilterSortActive[header.joinedFilterSortObjectKeys],\r\n disabled: header.disableTooltipIcon || showSkeletonLoading\r\n }\"\r\n [ngbTooltip]=\"timeFilterToolTip\"\r\n placement=\"bottom left-top auto\"\r\n container=\"body\"\r\n tooltipClass=\"non-edit-time-tooltip\"\r\n [autoClose]=\"'outside'\"\r\n triggers=\"manual\"\r\n #t4=\"ngbTooltip\"\r\n (click)=\"bindTheValueToToolTip(t4, header)\"\r\n (hidden)=\"closeTooltip()\"\r\n >\r\n </span\r\n ><br />\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"!header.showTooltipIcon\">\r\n <span id=\"no-filter-space\"></span><br />\r\n </ng-container>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'lurViolationInfoTooltip'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"lurViolationInfoTooltip\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n </div>\r\n </div>\r\n </th>\r\n\r\n <ng-container *matCellDef=\"let ROW_DATA\">\r\n <td\r\n mat-cell\r\n [style.background]=\"ROW_DATA.backgroundColor\"\r\n [style.border]=\"ROW_DATA.border\"\r\n class=\"{{ ROW_DATA.rowClass }}\"\r\n [ngClass]=\"ROW_DATA[columnDef.headerInfo[0].objectKey + 'TdClass']\"\r\n [attr.rowspan]=\"ROW_DATA[columnDef.headerInfo[0].objectKey + 'Rowspan']\"\r\n *ngIf=\"\r\n !hideSomeTds ||\r\n (hideSomeTds && !ROW_DATA['hide' + columnDef.headerInfo[0].objectKey + 'Td'])\r\n \"\r\n >\r\n <ngx-skeleton-loader\r\n *ngIf=\"showSkeletonLoading\"\r\n count=\"1\"\r\n [theme]=\"{ height: '10px', display: 'block' }\"\r\n >\r\n </ngx-skeleton-loader>\r\n\r\n <ng-container *ngIf=\"!showSkeletonLoading\">\r\n <ng-container *ngIf=\"tableData.length > 0 && !(isNoDataToDisplaySubject$ | async)\">\r\n <ng-container\r\n *ngFor=\"\r\n let subline of columnDef.headerInfo;\r\n let subLineIndex = index;\r\n trackBy: trackByFn\r\n \"\r\n >\r\n <div showEllipsisTextOnHover>\r\n <ng-container [ngSwitch]=\"columnDef.headerInfo[subLineIndex].typeOfBodyData\">\r\n <ng-container *ngSwitchCase=\"'ICON'\">\r\n <i\r\n *ngIf=\"\r\n !(\r\n starredInProgress &&\r\n ROW_DATA.orderId == selectedStarredOrderId\r\n )\r\n \"\r\n [class]=\"ROW_DATA.iconClass\"\r\n (click)=\"iconClicked(ROW_DATA, ROW_DATA.iconClass)\"\r\n ngbTooltip=\"{{ ROW_DATA.iconTitleText }}\"\r\n placement=\"bottom\"\r\n container=\"body\"\r\n tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\r\n ></i>\r\n <ng-container\r\n *ngIf=\"\r\n starredInProgress && ROW_DATA.orderId == selectedStarredOrderId\r\n \"\r\n >\r\n <div class=\"spinner-for-button-directive\"></div>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'ICON_CELL'\">\r\n <ng-container\r\n *ngFor=\"\r\n let action of ROW_DATA[\r\n columnDef.headerInfo[subLineIndex].actionKey\r\n ]\r\n \"\r\n >\r\n <ng-container *ngIf=\"action.showObjectKey\">\r\n {{ ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey] }}\r\n </ng-container>\r\n\r\n <i\r\n *ngIf=\"action.showIcon\"\r\n [class]=\"action.iconClass\"\r\n (mouseenter)=\"\r\n mouseEnterOnStringTextActionType(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].tooltipKey\r\n )\r\n \"\r\n placement=\"bottom auto\"\r\n container=\"body\"\r\n [autoClose]=\"true\"\r\n tooltipClass=\"team-user-tooltip remove-on-scroll-class\"\r\n [ngbTooltip]=\"action.showTooltip ? action.tooltipData : null\"\r\n (click)=\"\r\n textActionClicked(\r\n ROW_DATA,\r\n action.id,\r\n columnDef.headerInfo[subLineIndex]\r\n )\r\n \"\r\n [disableTooltip]=\"!action.showTooltip\"\r\n >\r\n </i>\r\n\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'HTML_STRING'\">\r\n <p\r\n [innerHTML]=\"ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\r\n (click)=\"innerHTMLCellClicked($event, ROW_DATA)\"\r\n ></p>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'SVG_ICON'\">\r\n <anna-core-anna-icon-column\r\n [componentName]=\"gtGeneralConfig.component\"\r\n [dataObject]=\"ROW_DATA\"\r\n [iconToShow]=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n \"\r\n (onColumnIconClicked)=\"svgIconClicked($event)\"\r\n ></anna-core-anna-icon-column>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'TEXT_ACTIONS'\">\r\n <ng-container\r\n *ngFor=\"\r\n let text of ROW_DATA[\r\n columnDef.headerInfo[subLineIndex].actionKey\r\n ]\r\n \"\r\n >\r\n <button\r\n *ngIf=\"text.showTooltip\"\r\n (click)=\"\r\n textActionClicked(\r\n ROW_DATA,\r\n text.id,\r\n columnDef.headerInfo[subLineIndex]\r\n )\r\n \"\r\n [disabled]=\"text.isDisabled\"\r\n class=\"{{ text.class }}\"\r\n (mouseenter)=\"\r\n mouseEnterOnTextActionType(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].tooltipKey\r\n )\r\n \"\r\n [ngbTooltip]=\"textActionTooltipTemplate\"\r\n placement=\"auto\"\r\n container=\"body\"\r\n tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\r\n >\r\n {{ text.name }}\r\n </button>\r\n\r\n <button\r\n *ngIf=\"!text.showTooltip\"\r\n (click)=\"\r\n textActionClicked(\r\n ROW_DATA,\r\n text.id,\r\n columnDef.headerInfo[subLineIndex]\r\n )\r\n \"\r\n [disabled]=\"text.isDisabled\"\r\n class=\"{{ text.class }}\"\r\n >\r\n {{ text.name }}\r\n </button>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'CHECKBOX'\">\r\n <span\r\n *ngIf=\"ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\r\n [ngClass]=\"{\r\n 'disable-checkbox':\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].isDisabledKey]\r\n }\"\r\n class=\"material-icons custom-column-checkbox-checked\"\r\n (click)=\"\r\n selectOrUnselectCheckbox(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].objectKey,\r\n false\r\n )\r\n \"\r\n >\r\n check_box\r\n </span>\r\n <span\r\n *ngIf=\"!ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\r\n class=\"material-icons custom-column-checkbox-unchecked\"\r\n [ngClass]=\"{\r\n 'disable-checkbox':\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].isDisabledKey]\r\n }\"\r\n (click)=\"\r\n selectOrUnselectCheckbox(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].objectKey,\r\n true\r\n )\r\n \"\r\n >\r\n check_box_outline_blank\r\n </span>\r\n\r\n <ng-container\r\n *ngFor=\"\r\n let action of ROW_DATA[\r\n columnDef.headerInfo[subLineIndex].actionKey\r\n ]\r\n \"\r\n >\r\n <i\r\n *ngIf=\"action.showIcon\"\r\n [class]=\"action.iconClass\"\r\n [ngClass]=\"{ disabled: action.disabledIcon }\"\r\n (mouseenter)=\"\r\n mouseEnterOnStringTextActionTypeContainingTable(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].tooltipKey\r\n )\r\n \"\r\n placement=\"bottom auto\"\r\n container=\"body\"\r\n [autoClose]=\"true\"\r\n tooltipClass=\"tooltip-containing-table remove-on-scroll-class\"\r\n [ngbTooltip]=\"tooltipContainingTableTemplate\"\r\n >\r\n </i>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'CLICKABLE_DATA'\">\r\n <a\r\n *ngFor=\"\r\n let text of ROW_DATA[\r\n columnDef.headerInfo[subLineIndex].actionKey\r\n ]\r\n \"\r\n [class]=\"text.class\"\r\n (click)=\"onClickableDataClicked(ROW_DATA, text.id)\"\r\n >\r\n {{ text.name }}\r\n </a>\r\n <span\r\n *ngIf=\"\r\n subline.objectKey == 'displayBookedUnits' &&\r\n gtGeneralConfig.component == 'RATING'\r\n \"\r\n class=\"clickable-data\"\r\n (click)=\"spotDetailsDownloadClicked('DATAROW', ROW_DATA)\"\r\n [ngClass]=\"{ 'disabled-clickable-data': downloadInProgress }\"\r\n >{{ ROW_DATA.displayBookedUnits }}\r\n <span class=\"material-icons spot-details-download-icons\"\r\n >get_app</span\r\n >\r\n <ng-container\r\n *ngIf=\"\r\n downloadInProgress &&\r\n ROW_DATA.inventoryCodeId ==\r\n selectedInventoryIdForDownload &&\r\n ROW_DATA.demographic == selectedDemographicForDownload\r\n \"\r\n >\r\n <ng-container\r\n [ngTemplateOutlet]=\"circularProgressBar\"\r\n ></ng-container>\r\n </ng-container>\r\n </span>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'STRING___ICON_OR_TEXT_ACTION'\">\r\n <ng-container\r\n *ngFor=\"\r\n let action of ROW_DATA[\r\n columnDef.headerInfo[subLineIndex].actionKey\r\n ]\r\n \"\r\n >\r\n <span\r\n [class]=\"action.additionalTextBeforeLinkClass\"\r\n [innerHtml]=\"action.additionalTextBeforeLink\"\r\n ngbTooltip=\"{{ action.additionalTextBeforeLink }}\"\r\n placement=\"bottom\"\r\n container=\"body\"\r\n tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\r\n [disableTooltip]=\"!action.enableTooltipForAdditionalText\"\r\n ></span>\r\n\r\n <ng-container *ngIf=\"action && action.typeOfData == 'STRING'\">\r\n {{ action.data }}\r\n </ng-container>\r\n\r\n <a\r\n [id]=\"action.id\"\r\n *ngIf=\"action.showLink\"\r\n (click)=\"\r\n textActionClicked(\r\n ROW_DATA,\r\n action.id,\r\n columnDef.headerInfo[subLineIndex]\r\n )\r\n \"\r\n [class]=\"action.linkClass\"\r\n [ngClass]=\"{ disabled: action.disabledLink }\"\r\n >{{ action.data }}</a\r\n >\r\n <span\r\n ngbTooltip=\"{{ action.additionalTextAfterLink }}\"\r\n placement=\"bottom\"\r\n container=\"body\"\r\n [class]=\"action.additionalTextAfterLinkClass\"\r\n tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\r\n [disableTooltip]=\"!action.enableTooltipForAdditionalAfterText\"\r\n >\r\n {{ action.additionalTextAfterLink }}\r\n </span>\r\n\r\n <ng-container *ngIf=\"action.showTooltip\">\r\n <ng-container *ngIf=\"action.tooltipData.innerHtml\">\r\n <i\r\n *ngIf=\"action.showIcon\"\r\n [class]=\"action.iconClass\"\r\n [ngClass]=\"{ disabled: action.disabledIcon }\"\r\n (mouseenter)=\"\r\n mouseEnterOnStringTextActionTypeContainingTable(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].tooltipKey\r\n )\r\n \"\r\n placement=\"bottom auto\"\r\n container=\"body\"\r\n [autoClose]=\"true\"\r\n tooltipClass=\"tooltip-containing-table remove-on-scroll-class\"\r\n [ngbTooltip]=\"tooltipContainingTableTemplate\"\r\n >\r\n </i>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"!action.tooltipData.tooltipTableBody\">\r\n <i\r\n *ngIf=\"action.showIcon\"\r\n [class]=\"action.iconClass\"\r\n [ngClass]=\"{ disabled: action.disabledIcon }\"\r\n (click)=\"\r\n iconClickedOnStringIconActionType(\r\n ROW_DATA,\r\n action.id,\r\n columnDef.headerInfo[subLineIndex]\r\n )\r\n \"\r\n (mouseleave)=\"mouseLeaveTextActionType(ROW_DATA)\"\r\n (mouseenter)=\"\r\n mouseEnterOnStringTextActionType(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].tooltipKey\r\n )\r\n \"\r\n [placement]=\"\r\n action.tooltipPlacement\r\n ? action.tooltipPlacement\r\n : 'bottom auto'\r\n \"\r\n container=\"body\"\r\n [autoClose]=\"true\"\r\n tooltipClass=\"team-user-tooltip remove-on-scroll-class {{\r\n action.tooltipClass\r\n }}\"\r\n [ngbTooltip]=\"userLoggedInDetails\"\r\n >\r\n </i>\r\n <ng-container *ngIf=\"action['showSvgIcon']\">\r\n <anna-core-anna-est-icon-template\r\n class=\"float-right\"\r\n *ngIf=\"action['svgIconName'] == 'anna-icon'\"\r\n (mouseleave)=\"mouseLeaveTextActionType(ROW_DATA)\"\r\n (mouseenter)=\"\r\n mouseEnterOnStringTextActionType(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex]\r\n .tooltipKey\r\n )\r\n \"\r\n [placement]=\"\r\n action.tooltipPlacement\r\n ? action.tooltipPlacement\r\n : 'bottom auto'\r\n \"\r\n tooltipClass=\"team-user-tooltip remove-on-scroll-class {{\r\n action['tooltipClass']\r\n }}\"\r\n [ngbTooltip]=\"userLoggedInDetails\"\r\n container=\"body\"\r\n [autoClose]=\"true\"\r\n >\r\n </anna-core-anna-est-icon-template>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"!action.showTooltip\">\r\n <i\r\n *ngIf=\"action.showIcon\"\r\n [class]=\"action.iconClass\"\r\n [ngClass]=\"{ disabled: action.disabledIcon }\"\r\n (click)=\"\r\n iconClickedOnStringIconActionType(\r\n ROW_DATA,\r\n action.id,\r\n columnDef.headerInfo[subLineIndex]\r\n )\r\n \"\r\n >\r\n </i>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'STRING_OR_INPUT'\">\r\n <ng-container\r\n *ngIf=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]?.type ==\r\n 'STRING';\r\n else inputBox\r\n \"\r\n >\r\n <span\r\n [innerHtml]=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n ?.value\r\n \"\r\n ></span>\r\n </ng-container>\r\n <ng-template #inputBox>\r\n <input\r\n placeholder=\"{{\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n ?.placeholder\r\n }}\"\r\n showEllipsisTextOnHover\r\n class=\"{{\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n .className\r\n }}\"\r\n (keydown)=\"\r\n changesMadeInEditableInputBox(\r\n $event,\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey],\r\n false\r\n )\r\n \"\r\n (paste)=\"\r\n changesMadeInEditableInputBox(\r\n $event,\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey],\r\n true\r\n )\r\n \"\r\n (ngModelChange)=\"\r\n editableInputValueChanged(\r\n $event,\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].objectKey\r\n )\r\n \"\r\n [ngModel]=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey].value\r\n \"\r\n [disabled]=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n .disabled\r\n \"\r\n [ngClass]=\"{\r\n 'red-border':\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n .hasError\r\n }\"\r\n />\r\n\r\n <i\r\n *ngIf=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n .showIcon\r\n \"\r\n container=\"body\"\r\n [ngbTooltip]=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n .iconTooltip\r\n \"\r\n tooltipClass=\"gt-total-row-tooltip\"\r\n placement=\"bottom\"\r\n class=\"{{\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n .iconClass\r\n }}\"\r\n >\r\n </i>\r\n <ng-container\r\n *ngIf=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey][\r\n 'showSvgIcon'\r\n ]\r\n \"\r\n >\r\n <anna-core-anna-est-icon-template\r\n class=\"float-right\"\r\n *ngIf=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey][\r\n 'svgIconName'\r\n ] == 'anna-icon'\r\n \"\r\n [placement]=\"'bottom auto'\"\r\n tooltipClass=\"gt-total-row-tooltip\"\r\n [ngbTooltip]=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n .iconTooltip\r\n \"\r\n container=\"body\"\r\n >\r\n </anna-core-anna-est-icon-template>\r\n </ng-container>\r\n </ng-template>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'HTML'\">\r\n <span\r\n [innerHtml]=\"ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\r\n ></span>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'SINGLE_RADIO'\">\r\n <span\r\n *ngIf=\"ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\r\n [ngClass]=\"{\r\n 'disable-checkbox':\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].isDisabledKey]\r\n }\"\r\n class=\"mdi mdi-radiobox-marked\"\r\n (click)=\"(null)\"\r\n >\r\n </span>\r\n <span\r\n *ngIf=\"!ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\r\n class=\"mdi mdi-radiobox-blank\"\r\n [ngClass]=\"{\r\n 'disable-checkbox':\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].isDisabledKey]\r\n }\"\r\n (click)=\"\r\n selectOrUnselectCheckbox(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].objectKey,\r\n true\r\n )\r\n \"\r\n >\r\n </span>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'RADIO'\">\r\n <mat-radio-group\r\n *ngIf=\"ROW_DATA['RadioButtonConfig']\"\r\n [ngModel]=\"ROW_DATA[subline.objectKey]\"\r\n [disabled]=\"ROW_DATA['RadioButtonConfig'][0].isDisabled\"\r\n >\r\n <ng-container\r\n *ngFor=\"\r\n let radioButton of ROW_DATA['RadioButtonConfig'];\r\n let last = last\r\n \"\r\n >\r\n <mat-radio-button\r\n value=\"{{ radioButton.value }}\"\r\n class=\"{{ radioButton.class }}\"\r\n (click)=\"\r\n radioButtonClicked(\r\n ROW_DATA,\r\n radioButton.value,\r\n ROW_DATA['RadioButtonConfig'][0].isDisabled\r\n )\r\n \"\r\n >{{ radioButton.label }}\r\n </mat-radio-button>\r\n <i\r\n class=\" {{ radioButton.iconClass }}\"\r\n (click)=\"radioButtonIconClicked(ROW_DATA)\"\r\n ></i>\r\n <br *ngIf=\"!last\" />\r\n </ng-container>\r\n </mat-radio-group>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'STRING_WITH_TOOLTIP'\">\r\n <ng-container\r\n *ngFor=\"\r\n let action of ROW_DATA[\r\n columnDef.headerInfo[subLineIndex].actionKey\r\n ]\r\n \"\r\n >\r\n <span> {{ action?.dataToDisplay }}</span>\r\n <span\r\n *ngIf=\"action?.showTooltip\"\r\n [ngbTooltip]=\"textActionTooltipTemplate\"\r\n (mouseenter)=\"\r\n mouseEnterOnStringTextActionType(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].tooltipKey\r\n )\r\n \"\r\n [placement]=\"action?.tooltipPosition\"\r\n container=\"body\"\r\n [class]=\"action?.tooltipIconClass\"\r\n tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\r\n [disableTooltip]=\"action?.disableTooltip\"\r\n >\r\n </span>\r\n <span> {{ action?.dataToDisplayAfterTooltip }}</span>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchDefault>\r\n <ng-container *ngIf=\"subline.objectKey != 'description'\">\r\n <span>{{\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n }}</span>\r\n <i\r\n *ngIf=\"\r\n subline.objectKey == 'inventoryCode' &&\r\n ROW_DATA['isSellerGroup'] &&\r\n gtGeneralConfig.component == 'RATING'\r\n \"\r\n class=\"mi mdi-info-outline seller-tooltip\"\r\n [ngbTooltip]=\"sellerHierarchyTooltip\"\r\n placement=\"bottom auto\"\r\n container=\"body\"\r\n [autoClose]=\"true\"\r\n triggers=\"manual\"\r\n (hidden)=\"closeTooltip()\"\r\n #info=\"ngbTooltip\"\r\n tooltipClass=\"hierarchy-tooltip remove-on-scroll-class\"\r\n (mouseenter)=\"\r\n bindTheValueToSellerGroupTooltip(\r\n ROW_DATA.sellerGroupHierarchy,\r\n info\r\n )\r\n \"\r\n >\r\n </i>\r\n\r\n <i\r\n *ngIf=\"\r\n subline.objectKey == 'displayBookedAverageRating' &&\r\n gtGeneralConfig.component == 'RATING' &&\r\n ROW_DATA['showRatingAverageIcon']\r\n \"\r\n class=\"mi mdi-info-outline seller-tooltip\"\r\n placement=\"bottom auto\"\r\n container=\"body\"\r\n [autoClose]=\"true\"\r\n (mouseenter)=\"\r\n setIsDifference(ROW_DATA.isDifferenceLessThan25Percent)\r\n \"\r\n tooltipClass=\"posted-avg-tooltip remove-on-scroll-class\"\r\n [ngbTooltip]=\"postedRatingDifference\"\r\n >\r\n </i>\r\n\r\n <i\r\n *ngIf=\"\r\n subline.objectKey == 'displayBookedAverageImpression' &&\r\n gtGeneralConfig.component == 'RATING' &&\r\n ROW_DATA['showImpressionAverageIcon']\r\n \"\r\n class=\"mi mdi-info-outline seller-tooltip\"\r\n placement=\"bottom auto\"\r\n container=\"body\"\r\n [autoClose]=\"true\"\r\n (mouseenter)=\"\r\n setIsDifference(ROW_DATA.isDifferenceLessThan25Percent)\r\n \"\r\n tooltipClass=\"posted-avg-tooltip remove-on-scroll-class\"\r\n [ngbTooltip]=\"postedImpDifference\"\r\n >\r\n </i>\r\n </ng-container>\r\n <ng-container *ngIf=\"subline.objectKey == 'description'\">\r\n <p\r\n *ngIf=\"\r\n ROW_DATA.descriptionMessage ||\r\n ROW_DATA.descriptionEmailReferenceNum\r\n \"\r\n >\r\n <ng-container *ngIf=\"ROW_DATA.descriptionMessage\">\r\n {{ ROW_DATA.descriptionMessage }}\r\n <br />\r\n </ng-container>\r\n <ng-container\r\n *ngIf=\"\r\n ROW_DATA.descriptionEmailReferenceNum != '-' &&\r\n ROW_DATA.descriptionEmailReferenceNum != ''\r\n \"\r\n >\r\n Email Ref: {{ ROW_DATA.descriptionEmailReferenceNum }}\r\n <br />\r\n </ng-container>\r\n </p>\r\n <a\r\n href=\"{{ ROW_DATA.descriptionDetailsUrl }}\"\r\n target=\"_blank\"\r\n *ngIf=\"\r\n ROW_DATA.descriptionDetailsUrlType === 'PDF' ||\r\n ROW_DATA.descriptionDetailsUrlType === 'EXCEL'\r\n \"\r\n >\r\n <button class=\"btn viewDetailsAndEmailBtn\">Download</button>\r\n </a>\r\n <ng-container\r\n *ngIf=\"ROW_DATA.activityname.toLowerCase() == 'order onboarded'\"\r\n >\r\n <a\r\n *ngIf=\"ROW_DATA.descriptionDetailsUrlType === 'LINK'\"\r\n (click)=\"viewDetailsClicked(ROW_DATA)\"\r\n >\r\n <button class=\"btn viewDetailsAndEmailBtn order-onboarded\">\r\n View details\r\n </button>\r\n </a>\r\n </ng-container>\r\n\r\n <a\r\n href=\"{{ ROW_DATA.descriptionEmailUrl }}\"\r\n target=\"_blank\"\r\n *ngIf=\"\r\n ROW_DATA.descriptionEmailUrl != '-' &&\r\n ROW_DATA.descriptionEmailUrl != ''\r\n \"\r\n >\r\n <button class=\"btn viewDetailsAndEmailBtn\">View email</button>\r\n </a>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"isNoDataToDisplaySubject$ | async\">\r\n <div>\r\n {{ null }}\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n </td>\r\n </ng-container>\r\n </ng-container>\r\n </table>\r\n </div>\r\n <anna-core-no-data-lib\r\n [width]=\"noDataWidth\"\r\n [marginTop]=\"marginTop\"\r\n *ngIf=\"isNoDataToDisplaySubject$ | async\"\r\n >\r\n </anna-core-no-data-lib>\r\n</div>\r\n\r\n<!-- Checkbox template -->\r\n<ng-template #filterTooltip>\r\n <anna-core-anna-column-checkbox-filter\r\n [tableData]=\"tableData\"\r\n [showFilterHeaderTabs]=\"showFilterTooltipTabs\"\r\n [isLurAndCsrComponent]=\"false\"\r\n [clonedTableData]=\"clonedTableData\"\r\n [filterTabObjects]=\"filterTabObjects\"\r\n (filterAppliedToTable)=\"filterApplied($event)\"\r\n (sortingAppliedToTable)=\"sortingApplied($event)\"\r\n (closeTooltip)=\"closeTooltip()\"\r\n >\r\n </anna-core-anna-column-checkbox-filter>\r\n</ng-template>\r\n\r\n<!-- Slider template -->\r\n<ng-template #sliderToolTip>\r\n <anna-core-anna-column-slider-filter\r\n [tableData]=\"tableData\"\r\n [showFilterHeaderTabs]=\"showFilterTooltipTabs\"\r\n [isLurAndCsrComponent]=\"false\"\r\n [clonedTableData]=\"clonedTableData\"\r\n [filterTabObjects]=\"filterTabObjects\"\r\n (filterAppliedToTable)=\"filterApplied($event)\"\r\n (sortingAppliedToTable)=\"sortingApplied($event)\"\r\n (closeTooltip)=\"closeTooltip()\"\r\n >\r\n </anna-core-anna-column-slider-filter>\r\n</ng-template>\r\n\r\n<!-- Date Picker Template -->\r\n<ng-template #datePickerTooltip>\r\n <anna-core-anna-column-date-range-filter\r\n [tableData]=\"tableData\"\r\n [showFilterHeaderTabs]=\"showFilterTooltipTabs\"\r\n [isLurAndCsrComponent]=\"false\"\r\n [clonedTableData]=\"clonedTableData\"\r\n [filterTabObjects]=\"filterTabObjects\"\r\n (filterAppliedToTable)=\"filterApplied($event)\"\r\n (sortingAppliedToTable)=\"sortingApplied($event)\"\r\n (closeTooltip)=\"closeTooltip()\"\r\n >\r\n </anna-core-anna-column-date-range-filter>\r\n</ng-template>\r\n\r\n<!-- Week Picker Template -->\r\n<ng-template #weekPickerToolTip>\r\n <!-- <div class=\"weekpicker-container\">\r\n <anna-core-week-calendar-filter-lib\r\n [week-calendar-config]=\"gtGeneralConfig.multiWeekPickerConfig\"\r\n (apply)=\"applyWeekFilter($event)\"\r\n [from-date]=\"calendarMinEnabledDate\"\r\n [to-date]=\"calendarMaxEnabledDate\"\r\n >\r\n </anna-core-week-calendar-filter-lib>\r\n </div> -->\r\n</ng-template>\r\n\r\n<!-- Time Filter Template -->\r\n<ng-template #timeFilterToolTip>\r\n <anna-core-anna-column-time-filter\r\n [tableData]=\"tableData\"\r\n [showFilterHeaderTabs]=\"showFilterTooltipTabs\"\r\n [isLurAndCsrComponent]=\"false\"\r\n [showAllTimeRangeCheckboxes]=\"showCheckboxesForTimeFilter\"\r\n [clonedTableData]=\"clonedTableData\"\r\n [filterTabObjects]=\"filterTabObjects\"\r\n (filterAppliedToTable)=\"filterApplied($event)\"\r\n (sortingAppliedToTable)=\"sortingApplied($event)\"\r\n (closeTooltip)=\"closeTooltip()\"\r\n >\r\n </anna-core-anna-column-time-filter>\r\n</ng-template>\r\n\r\n<ng-template #columnInfoTooltip>\r\n <p style=\"color: black; white-space: nowrap\">This preemption is rejected and not marked for credit.</p>\r\n</ng-template>\r\n\r\n<ng-template #ratingInfoTooltip>\r\n <p class=\"first-row\">Shows 'Booked Rating' for Preemptions & MakeGood Offered spot(s).</p>\r\n <p class=\"second-row\">Shows 'Projected Rating' for ADU Offered spot(s).</p>\r\n</ng-template>\r\n\r\n<ng-template #impsInfoTooltip>\r\n <p class=\"first-row\">Shows 'Booked IMPS' for Preemptions & MakeGood Offered spot(s).</p>\r\n <p class=\"second-row\">Shows 'Projected IMPS' for ADU Offered spot(s).</p>\r\n</ng-template>\r\n\r\n<ng-template #spotsColumnEquivalizationMessageTooltip>\r\n <p class=\"spot-column-tooltip-message\">\r\n This consists of equivalized spots and un-equivalized Paid Programs & un-equivalized Non-spots.\r\n </p>\r\n</ng-template>\r\n\r\n<ng-template #underDeliveryTooltip>\r\n <p class=\"spot-column-tooltip-message\">\r\n Indicates the Under-delivery percentage based on booked and posted RTG/IMPS.\r\n </p>\r\n</ng-template>\r\n\r\n<ng-template #overDeliveryTooltip>\r\n <p class=\"spot-column-tooltip-message\">\r\n Indicates the Over-delivery percentage based on booked and posted RTG/IMPS.\r\n </p>\r\n</ng-template>\r\n\r\n<ng-template #rateInfoTooltip>\r\n <p class=\"first-row\">Shows 'Booked Rate' for Preemptions & MakeGood Offered spot(s).</p>\r\n <p class=\"second-row\">Shows 'Projected $ Value' for ADU Offered spot(s).</p>\r\n</ng-template>\r\n\r\n<ng-template #sellerHierarchyTooltip>\r\n <ng-container *ngIf=\"sellerGroupHierarchy.length > 0\">\r\n <section class=\"hierarchy-table-container\">\r\n <table class=\"seller-hierarchy-table\">\r\n <thead>\r\n <tr>\r\n <th>#</th>\r\n <th>Inventory Codes</th>\r\n <th>Program/Description</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let data of sellerGroupHierarchy; let tooltipIndex = index\">\r\n <td>{{ tooltipIndex + 1 }}</td>\r\n <td>\r\n <span showEllipsisTextOnHover>{{ data.InventoryCode }}</span>\r\n </td>\r\n <td>\r\n <span showEllipsisTextOnHover>{{ data.Program }}</span>\r\n </td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n </section>\r\n </ng-container>\r\n <ng-container *ngIf=\"sellerGroupHierarchy.length == 0\">\r\n <span style=\"color: #000\">Seller group not available for this inventory code</span>\r\n </ng-container>\r\n</ng-template>\r\n\r\n<ng-template #lurViolationInfoTooltip>\r\n <p class=\"first-row\">The values are for the entire week.</p>\r\n</ng-template>\r\n\r\n<ng-template #postedRatingDifference>\r\n <p class=\"difference-text\">\r\n The difference between posted and booked average rating is\r\n {{ isDifferenceLessThan25Percent ? \"less\" : \"more\" }} than 25%.\r\n </p>\r\n</ng-template>\r\n\r\n<ng-template #postedImpDifference>\r\n <p class=\"difference-text\">\r\n The difference between posted and booked average impression is\r\n {{ isDifferenceLessThan25Percent ? \"less\" : \"more\" }} than 25%.\r\n </p>\r\n</ng-template>\r\n\r\n<ng-template #ongoingRevBookedColumnTooltip>\r\n <p>The Booked $ value, Spots, GRP, CPP, IMPS, CPM corresponds on the last permanent revision generated</p>\r\n</ng-template>\r\n\r\n<ng-template #completedRevBookedColumnTooltip>\r\n <p>The Booked $ value corresponds on the last permanent revision generated</p>\r\n</ng-template>\r\n\r\n<ng-template #avgBookedRate>\r\n <p>This is the booked average Rate</p>\r\n</ng-template>\r\n\r\n<ng-template #avgBookedRtg>\r\n <p>This is the booked average RTG</p>\r\n</ng-template>\r\n\r\n<ng-template #avgBookedImps>\r\n <p>This is the booked average IMP(\u2019000)</p>\r\n</ng-template>\r\n\r\n<ng-template #projectedImpsRtg>\r\n <p>\r\n All projections are derived from the sum of actual posted information until the last posted date and estimates\r\n for the remaining selected period.\r\n </p>\r\n</ng-template>\r\n\r\n<ng-template #automationTooltip>\r\n <p>\r\n Please get the order business rules approved to activate the order for automation. Only for the\r\n automation-activated orders, any approved MGs, ADUs, or credited spots on ANNA will be fed into the traffic\r\n system i.e. ANNA revisions.\r\n <!-- removed below line as part of enhancmennt in 14.0 releas -->\r\n <!-- Additionally, ANNA will only enter buyer revisions into traffic for the selected\r\n Medialine/WOC orders. -->\r\n </p>\r\n</ng-template>\r\n\r\n<ng-template #rebateImpact>\r\n <p>Rebate impact value is for the originally ordered spot length and is not equivalized.</p>\r\n</ng-template>\r\n\r\n<ng-template #lurViolationTotalRowToolTip>\r\n <ul>\r\n <li>\r\n <strong>POLITICAL RATE VIOLATIONS:</strong>\r\n Violations flagged when non-political spots are booked at a rate lower than the minimum booked rate for\r\n political candidates for the same week, Inventory Code and Revenue Class.\r\n </li>\r\n <li>\r\n <strong>CANDIDATE TO CANDIDATE VIOLATION:</strong>\r\n Violations flagged when political spots are booked at different rates to other political spots for the same\r\n week, Inventory Code and Revenue Class.\r\n </li>\r\n </ul>\r\n</ng-template>\r\n\r\n<ng-template #circularProgressBar>\r\n <circle-progress\r\n [percent]=\"percentDone\"\r\n [radius]=\"5\"\r\n [showTitle]=\"false\"\r\n [showUnits]=\"false\"\r\n [showSubtitle]=\"false\"\r\n [outerStrokeWidth]=\"3\"\r\n [innerStrokeWidth]=\"3\"\r\n [space]=\"-3\"\r\n [outerStrokeColor]=\"'#268bff'\"\r\n [innerStrokeColor]=\"'#d5d5d5'\"\r\n [animationDuration]=\"10\"\r\n ></circle-progress>\r\n</ng-template>\r\n\r\n<ng-template #userLoggedInDetails>\r\n <div class=\"tooltip-div-container\">\r\n <ng-container *ngFor=\"let data of textActionTooltip\">\r\n <span *ngIf=\"data.key != 'read'\">\r\n {{ data.key }} <b> {{ data.value }}</b>\r\n </span>\r\n <span *ngIf=\"data.key == 'read'\">\r\n {{ data.value }}\r\n </span>\r\n </ng-container>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #markAsReadTip>\r\n <div class=\"notification-tooltip-div-container\">\r\n <ng-container *ngFor=\"let data of textActionTooltip\">\r\n {{ data.value }}\r\n </ng-container>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #textActionTooltipTemplate>\r\n <ng-container *ngFor=\"let data of textActionTooltip\">\r\n {{ data.key }} <b> {{ data.value }}</b>\r\n </ng-container>\r\n</ng-template>\r\n\r\n<ng-template #tooltipContainingTableTemplate>\r\n <div\r\n *ngIf=\"tooltipContainingTable\"\r\n [innerHTML]=\"tooltipContainingTable.innerHtml\"\r\n class=\"notification-tooltip-div-container\"\r\n >\r\n <!-- <ul>\r\n <li *ngFor=\"let headerMsg of tooltipContainingTable.tableHeaderMsg\">\r\n <b> {{headerMsg}} </b>\r\n </li>\r\n </ul>\r\n\r\n <table class=\"tooltip-table\">\r\n <thead>\r\n <tr>\r\n <th *ngFor=\"let header of tooltipContainingTable.tooltipTableHeader\">\r\n {{ header}}\r\n </th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let rows of tooltipContainingTable.tooltipTableBody\">\r\n <td *ngFor=\"let data of rows\">\r\n {{ data }}\r\n </td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n\r\n <ul>\r\n <li style=\"margin-top:10px; padding:0\" *ngFor=\"let footerMsg of tooltipContainingTable.tableFooterMsg\">\r\n {{ footerMsg }} \r\n </li>\r\n </ul> -->\r\n </div>\r\n</ng-template>\r\n<!-- <ng-template #textActionTooltipTemplate>\r\n <ng-container *ngFor=\"let data of textActionTooltip\">\r\n {{ data.key }} <b> {{data.value}}</b>\r\n </ng-container>\r\n</ng-template> -->\r\n", styles: [".sort-btn{background:#fff;border:none;border-right:1px solid #1b88ff;text-decoration:underline;font-family:Roboto;font-size:14px;font-weight:400;font-stretch:normal;font-style:normal;line-height:1.07;letter-spacing:normal;color:#1b88ff;cursor:pointer;flex:1;text-align:center}.sort-btn:last-of-type{border-right:none}.sort-btn.active{color:#202b47;text-decoration:none}p.sort-container{margin-top:8px;padding-bottom:8px;border-bottom:1px solid #e6e6e6;margin-bottom:0;display:flex}::ng-deep .tooltip-inner{max-height:22rem;background-color:#fff;border:1px solid white;border-radius:5px;box-shadow:0 2px 2px #0000003d,0 0 2px #0000001f;max-width:251px;width:100%;padding:0!important}::ng-deep .tooltip-inner div.radio-container{flex-wrap:wrap}::ng-deep .md-drppicker{box-shadow:unset!important}::ng-deep .available{color:#999}::ng-deep .bs-tooltip-bottom .arrow:before{border-bottom-color:#fff!important}::ng-deep .bs-tooltip-left .arrow:before{border-left-color:#fff!important}::ng-deep .tooltip.show{opacity:1}.input{text-align:left;margin:5px 10px 5px 5px;display:flex;align-items:center;width:230px;white-space:nowrap}.data{color:#000;font-weight:700;margin-left:5px;margin-right:5px}span.data{display:inline-block;text-overflow:ellipsis;white-space:pre;width:100%;overflow:hidden}.check-box{font-size:14px;cursor:pointer;position:relative;top:-1px}span.mdi-filter.active{color:#000;opacity:1!important;pointer-events:all!important}p{margin-bottom:0;line-height:initial}span.mdi-filter{color:#cbcbcb}::ng-deep .ngx-slider-pointer{top:-5px!important;width:12px!important;height:12px!important;background:#bdbdbd!important;border:1px solid #ffffff!important;box-shadow:0 1px 3px #0000004d!important;border-radius:16px!important}input:focus{outline:none}input::placeholder{color:#c8c8c8}.cancel-btn{background:#c7e1ff;color:#268bff}.apply-btn{background:#268bff;color:#fff;margin-left:.3125rem}div.radio-container{display:flex;white-space:nowrap;justify-content:space-between;background-color:#f4f4f4;border-radius:.125rem;margin:.4375rem .4375rem .25rem}div.radio-container div{flex:1;width:50%}div.radio-container div.full-width{width:100%}div.radio-container input{position:relative;top:.125rem;margin-right:.25rem}div.radio-container label{font-family:Roboto;font-size:.875rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:1.29;letter-spacing:0;color:#4a4a4a;margin:0;padding-left:.125rem}div.radio-container label:first-of-type{margin-right:.188rem}div.radio-container input[type=radio]{appearance:none;display:inline-block;width:.9375rem;height:.9375rem;padding:.125rem;background-clip:content-box;border:.125rem solid #268bff;background-color:transparent;border-radius:50%}div.radio-container input[type=radio]:checked{background-color:#268bff}.checkbox-filter-buttons-container{padding:0 8px!important}.buttons-container{display:flex;margin:0px auto .4375rem;justify-content:center;padding:0 12px}.buttons-container .button{padding:0 10px;width:100%;margin:8px 0 0;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.buttons-container button:last-of-type{background-color:#268bff;color:#fff;margin-left:.5rem}.buttons-container button.disabled{background:#bdbdbd;opacity:.5;color:#4a4a4a}.button{display:inline-block;margin:8px 4px 0 8px;padding:0 16px;border-radius:4px;text-align:center;outline:none;font-family:Roboto;font-size:.75rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:1.67;letter-spacing:normal;border:none;color:#268bff;background-color:#e5f1ff}.search-box{display:flex;align-items:center;color:#c8c8c8;border:1px solid #e6e6e6;border-radius:.125rem;margin:.25rem .4375rem .188rem;height:1.5rem;padding:.188rem 8px .188rem .5rem}.search-box .search-bar-close{margin-left:auto;float:right}.search-icon{margin:0 4px 0 0;font-size:1.125rem;color:#9b9b9b}.filter-icon{justify-content:right;margin-left:auto;color:#d4d4d4;color:#a1a1a1;font-size:16px;cursor:pointer}.data{margin:0 13px 0 8px;font-family:Roboto;font-size:.875rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:1.86;letter-spacing:\"\";color:#4a4a4a}.search-input{margin:1px 0 1px 4px;font-family:Roboto;font-size:.875rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal;color:#c8c8c8;width:calc(100% - 38px)}.check-box{color:#268bff}.tooltip-data-container{overflow-y:scroll;max-height:8rem}.searchbar{width:100%;display:flex;justify-content:flex-end;align-items:flex-end}.clear-button{opacity:.5;font-family:Roboto;font-size:.9375rem;font-weight:500;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal;text-decoration:underline;border:none;background-color:#fff;color:#4a4a4a;margin-left:.625rem;padding:0}.clear-button:focus{outline:none;box-shadow:none}.unchecked{color:#268bff}cdk-virtual-scroll-viewport.dropdown-data-container{max-height:12.3rem;width:100%;overflow-y:auto;overflow-x:hidden}cdk-virtual-scroll-viewport.dropdown-data-container p.input{margin-left:0}cdk-virtual-scroll-viewport.dropdown-data-container p.input span.mi{padding-left:.4375rem}cdk-virtual-scroll-viewport.dropdown-data-container p.input:hover{background-color:#ebebeb;cursor:pointer}cdk-virtual-scroll-viewport.dropdown-data-container::-webkit-scrollbar{width:.188rem}cdk-virtual-scroll-viewport.dropdown-data-container::-webkit-scrollbar-thumb{color:#d3d3d3;background:#d3d3d3}section.min-maxContainer{display:flex;justify-content:center;margin-bottom:-.125rem;margin-top:.5rem;width:100%}section.min-maxContainer input{width:30%;height:1.875rem;border:1px solid lightgray;color:gray}section.min-maxContainer span{display:inline-block;padding-left:.5rem;padding-right:.5rem;position:relative;top:.3125rem;color:#666}.time-container{width:100%;display:flex;padding:0 .75rem}.time-container input.form-control:disabled{background-color:#fff;width:2.813rem}.time-container input.numberInput:focus{box-shadow:none;border-color:#c2cfd6}.time-container .dot{color:#cbcbcb;position:relative;left:-7px;font-size:17px}.time-container div.arrow-container{flex-direction:column;display:flex;margin-top:.375rem;width:9px;height:18px;margin-right:1.1875rem}.time-container div.arrow-container i{color:#000;cursor:pointer;max-height:9px;font-size:25px;width:10px}.time-container div.arrow-container i:before{width:0;height:0;pointer-events:none;position:relative;left:-9px;top:-11px}.mdi-filter{cursor:pointer}.time-label-container{display:flex;justify-content:flex-start}.time-label-container label{margin-bottom:0;color:#4a4a4a;margin-top:.125rem;margin-left:.625rem;font-weight:700}.time-heading{color:#000;font-size:.8125rem;text-align:left;padding-left:.625rem;margin-top:.625rem;font-weight:700}.column-clear-all{width:94%;text-align:center;border:none;font-size:14px;background:none;text-decoration:underline;color:#268bff}.checkbox-container{display:flex;padding-inline:.625rem}.checkbox-container .data{text-align:left}.checkbox-container:first-of-type{margin-top:.625rem;font-weight:500}.column-clear-all{width:94%;text-align:center;border:none;background:none;text-decoration:underline;color:#268bff}.column-clear-all:disabled{opacity:.5;color:#4a4a4a;font-weight:400}.column-clear-all.align-center{text-align:center}span.mdi-filter-variant.disabled{pointer-events:none;opacity:.5}.datepicker-container{width:100%}span.mdi-filter-variant{color:#cbcbcb;cursor:pointer;font-size:.875rem}span.mdi-filter-variant.active{color:#000}p.filter-tab{font-family:Roboto;font-size:14px;font-weight:400;font-stretch:normal;font-style:normal;line-height:1.29;letter-spacing:normal;color:#1b88ff;border-radius:5px;background-color:#f4f4f4;padding-inline:8px;cursor:pointer;overflow:hidden;text-align:center;text-overflow:ellipsis}p.filter-tab.active{color:#fff;background-color:#1b88ff}button.filter-text-btn{background:#fff;text-decoration:underline;font-family:Roboto;font-size:14px;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal;border:none;color:#268bff;margin-inline:4px;margin-top:2px}button.filter-text-btn:disabled{color:#b1b1b1;cursor:not-allowed}::ng-deep .non-edit-datepicker-tooltip .tooltip-inner{max-width:310px!important;width:283px!important;overflow-y:initial!important;padding:0!important}input.slider-text::-webkit-outer-spin-button,input.slider-text::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input.slider-text{-moz-appearance:textfield}input.slider-text.red-border{border:1px solid #f44336!important}::ng-deep .checkbox-sort p.sort-container{margin-top:8px!important;padding-bottom:8px!important}i.mdi-close{cursor:pointer}i.mdi-close.disable-close-icon{pointer-events:none;cursor:not-allowed}input.error-border{border:1px solid #f44336!important}::ng-deep .non-edit-checkbox-tooltip .tooltip-inner{width:238px!important;padding:0!important}::ng-deep .non-edit-slider-tooltip .tooltip-inner{width:238px!important;padding:0!important}::ng-deep .non-edit-time-tooltip .tooltip-inner{width:250px!important;padding:0!important}::ng-deep .non-edit-time-tooltip.bs-tooltip-start{padding:.4rem}::ng-deep .non-edit-time-tooltip.bs-tooltip-start .tooltip-arrow{right:0;top:5px!important;width:var(--bs-tooltip-arrow-height);height:var(--bs-tooltip-arrow-width)}::ng-deep .non-edit-time-tooltip.bs-tooltip-start .tooltip-arrow:before{border-left-color:#fff;left:-1px;border-width:calc(var(--bs-tooltip-arrow-width) * .5) 0 calc(var(--bs-tooltip-arrow-width) * .5) var(--bs-tooltip-arrow-height)}::ng-deep .no-bottom-border p.sort-container{border-bottom:none!important}::ng-deep .ngx-slider-pointer-min:after{display:none}::ng-deep .ngx-slider-pointer-max:after{display:none}::ng-deep .ngx-slider span.ngx-slider-pointer{width:12px;height:12px;top:-5px;background-color:#bdbdbd}::ng-deep .ngx-slider span.ngx-slider-bar{height:3px;background:#ededed}::ng-deep .ngx-slider span.ngx-slider-selection{background:#bdbdbd}::ng-deep .ngx-slider span.ngx-slider-bubble{bottom:-22px;font-size:12px;color:#333}::ng-deep .show-min.ngx-slider span.ngx-slider-model-value{background:#fff;box-shadow:0 6px 10px #0000004d,0 2px 2px #0003}::ng-deep .show-max.ngx-slider span.ngx-slider-model-high{background:#fff;box-shadow:none}::ng-deep .ngx-slider span.ngx-slider-combined{background:#fff;box-shadow:0 6px 10px #0000004d,0 2px 2px #0003}::ng-deep .ngx-slider{top:10px!important;margin:5px 0 2px!important}::ng-deep .ngx-slider-animate{top:0!important}.sidebar-slider{margin-bottom:35px!important;margin-left:5px;margin-right:5px}.slider-placeholder{height:14px}::ng-deep .filter-calendar select.form-select:focus{border-color:#c2cfd6;box-shadow:none}::ng-deep .filter-calendar select.form-select{background-color:#fff}.no-data-case{padding-left:.4375rem!important;font-size:.875rem!important;margin-top:10px!important;cursor:pointer}.check-mark,.unread-mark{cursor:pointer}.on-hover:hover .unread-mark,.notificationHover .check-mark{opacity:0;cursor:pointer}.on-hover:hover .check-mark{opacity:1;cursor:pointer}:host ::ng-deep .gt{table-layout:fixed;margin-bottom:0;width:100%}:host ::ng-deep .gt th,:host ::ng-deep .gt td{padding:2px 8px;line-height:normal}:host ::ng-deep .gt thead tr th .upper-label{font-family:Roboto;font-size:.6875rem;font-weight:500;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:.3px;color:#4a4a4a;margin-bottom:0}:host ::ng-deep .gt thead tr th .lower-label{font-family:Roboto;font-size:.6875rem;font-weight:500;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:.3px;color:#a7a7a7;margin-bottom:0}:host ::ng-deep .gt thead tr th{background-color:#ededed;position:sticky;position:-webkit-sticky;top:0;border-top:none!important;border-bottom:none!important;outline:none!important;box-shadow:inset 0 1px #d4d4d4,inset 0 -1px #d4d4d4,inset -1px 0 #d4d4d4}:host ::ng-deep .gt thead tr th br{display:block;content:\"\";margin-top:-8px}:host ::ng-deep .gt thead tr th div.row{display:flex;flex-wrap:nowrap;justify-content:space-between;align-items:center;width:max-content}:host ::ng-deep .gt thead tr th div.sort-filter-container{display:flex;flex-wrap:nowrap;align-items:center;margin-left:.25rem;margin-right:auto}:host ::ng-deep .gt thead tr th span.mdi-filter-variant{font-size:13px!important;top:-1px!important;position:relative}:host ::ng-deep .gt thead tr th:first-of-type{box-shadow:inset 0 1px #d4d4d4,inset 0 -1px #d4d4d4,inset -1px 0 #d4d4d4,inset 1px 0 #d4d4d4}:host ::ng-deep .gt tbody tr td:first-of-type{box-shadow:inset 1px 0 #d4d4d4,inset -1px 0 #d4d4d4,inset 0 -1px #d4d4d4;border:none}:host ::ng-deep .gt tbody tr td:nth-of-type(n+2){box-shadow:inset -1px 0 #d4d4d4,inset 0 -1px #d4d4d4;border:none}:host ::ng-deep .gt tbody tr td .upper-label{font-family:Roboto;font-size:.75rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:0px;color:#000;display:inline-block;width:90%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}:host ::ng-deep .gt tbody tr td .lower-label{font-family:Roboto;font-size:.75rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:0px;color:#a7a7a7;display:inline-block;width:90%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}:host ::ng-deep .gt tbody tr br{display:block;content:\"\";margin-top:-8px}:host ::ng-deep .gt tbody tr:nth-of-type(1) td{border-top:none!important}:host ::ng-deep .gt .custom-column-checkbox-checked,:host ::ng-deep .gt .custom-column-checkbox-unchecked{font-size:.875rem;cursor:pointer}:host ::ng-deep .gt .custom-column-checkbox-checked{color:#268bff}:host ::ng-deep .gt .custom-column-checkbox-unchecked{color:#4a4a4a}:host ::ng-deep .bottom-border .gt tbody tr:last-of-type td:first-of-type{box-shadow:inset 1px 0 #d4d4d4,inset -1px 0 #d4d4d4}:host ::ng-deep .bottom-border .gt tbody tr:last-of-type td:nth-of-type(n+2){box-shadow:inset -1px 0 #d4d4d4}.table-container{overflow-x:auto;overflow-y:auto}.rowSelectCheckbox,#selectAllRowsCheckbox{cursor:pointer}.disable-checkbox{color:#dedede!important;pointer-events:none!important}.mdi-warning{color:#f3c639;font-size:16px;line-height:28px}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{opacity:1}.redcolor-status{color:#c62a2a}#no-filter-space{width:.875rem}::ng-deep .mat-button-toggle-appearance-standard .mat-button-toggle-label-content{line-height:1.875rem!important;width:2.625rem;padding:0 .625rem}input.numberInput{margin-right:-.8125rem;padding:0 0 0 .625rem;height:1.875rem}::ng-deep .mat-button-toggle-checked{background-color:#268bff!important;color:#fff!important}::ng-deep .mat-button-toggle-group-appearance-standard{border-radius:0}.hidden{display:none}.no-data-div{margin-top:2.5px}.no-data-div label{margin:0;width:auto;font-weight:500;background-color:#d3d3d3;padding:.3125rem 1.125rem;border-radius:.25rem}.column-values:nth-of-type(2){color:#a7a7a7!important}.custom-column-checkbox-checked,.custom-column-checkbox-unchecked{font-size:.875rem;cursor:pointer}.custom-column-checkbox-checked{color:#268bff}.custom-column-checkbox-unchecked{color:#4a4a4a}.time-filter-checkboxes>div>p{color:#151b1e}::ng-deep .margin-bottom-zero .mat-radio-label{margin-bottom:0}:host ::ng-deep mat-radio-group br{margin-top:0!important}:host ::ng-deep mat-radio-group mat-radio-button .mdc-radio__background{width:var(--mat-radio-size);height:var(--mat-radio-size)}:host ::ng-deep mat-radio-group mat-radio-button .mdc-radio__inner-circle{border-width:calc(var(--mat-radio-size) / 2)}:host ::ng-deep mat-radio-group mat-radio-button .mdc-form-field>label{margin:0 0 0 4px;padding:0;top:-2px;position:relative}:host ::ng-deep mat-radio-group mat-radio-button .mdc-radio--disabled+label{color:var(--primary-text-color-dark)!important}:host ::ng-deep mat-radio-group mat-radio-button.mat-mdc-radio-button .mdc-form-field .mdc-radio{padding:0}:host ::ng-deep mat-radio-group mat-radio-button .mdc-form-field>label{left:-94px;font-size:12px;color:#4a4a4a;position:relative}::ng-deep .reject.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-outer-circle{border-color:#ff0}::ng-deep .reject.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-inner-circle{background-color:#ff0}::ng-deep .resubmit.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-outer-circle{border-color:#ff0}::ng-deep .resubmit.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-inner-circle{background-color:#ff0}::ng-deep .noAction.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-outer-circle{border-color:green}::ng-deep .noAction.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-inner-circle{background-color:green}::ng-deep .approve.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-outer-circle{border-color:green}::ng-deep .approve.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-inner-circle{background-color:green}::ng-deep .credit.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-outer-circle{border-color:red}::ng-deep .credit.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-inner-circle{background-color:red}::ng-deep .mat-radio-button.mat-radio-disabled .mat-radio-outer-circle{border-color:#00000061!important}::ng-deep .mat-radio-button.mat-radio-disabled.mat-radio-checked .mat-radio-inner-circle{background-color:#00000061!important}::ng-deep tr.white-background-row{background:#fff}::ng-deep tr.gray-background-row{background:#e9e9e980!important}.remarks-tooltip,.mdi-information,.mdi-information-outline,.seller-tooltip{font-size:.875rem;color:#268bff;position:relative;top:.1875rem;cursor:pointer}.seller-tooltip{top:-1px;float:right}::ng-deep .remarks-info-tooltip .tooltip-inner{max-width:19.25rem!important}.rating-icon,.lur-violation-icon{color:#268bff;cursor:pointer;position:relative;left:-2px}::ng-deep .rating-info-tooltip .tooltip-inner{max-width:800px!important}.spots-info-icon{color:#268bff;cursor:pointer;margin:1px 2px 0 -14px}.spots-info-icon-ol{color:#268bff;cursor:pointer;margin:1px 4px 0 -2px}::ng-deep .spot-info-tooltip .tooltip-inner{position:relative;max-width:220px!important;background:#fff;word-break:break-word;display:flex}::ng-deep .spot-info-tooltip-for-orderlisting-table .tooltip-inner{max-width:220px!important;background:#fff;word-break:break-word;display:flex}p.first-row{padding:.5rem .5rem 0;color:#000;white-space:nowrap;text-align:left}p.second-row{padding:2px .5rem .5rem;color:#000;white-space:nowrap;text-align:left}::ng-deep .gt-total-row-tooltip{opacity:1!important}::ng-deep .gt-total-row-tooltip .tooltip-inner{color:#000;box-shadow:0 6px 10px #0000004d,0 2px 2px #0003;background-color:#fff;padding:4px!important;width:100%;border-radius:2px!important}::ng-deep .gt-total-row-tooltip .arrow:before{border-top-color:#fff!important}.info-label{margin-left:4px;color:#268bff;vertical-align:text-top}::ng-deep .hierarchy-tooltip{max-width:-moz-fit-content;max-width:fit-content;width:310px!important}::ng-deep .hierarchy-tooltip .tooltip-inner{padding:4px!important;max-width:22.75rem;max-height:11.25rem}table.seller-hierarchy-table{table-layout:fixed}table.seller-hierarchy-table tr th{font-family:Roboto;font-size:.75rem;font-weight:500;font-stretch:normal;font-style:normal;line-height:1.67;letter-spacing:normal;color:#5e5e5e;white-space:nowrap;background:#ededed;position:sticky;box-shadow:inset 0 1px #d4d4d4;top:0;z-index:1}table.seller-hierarchy-table tr th:nth-child(1){width:20px}table.seller-hierarchy-table tr th:first-of-type,table.seller-hierarchy-table tr td:first-of-type{width:20px;border-left:1px solid #d4d4d4}table.seller-hierarchy-table tr th:last-of-type,table.seller-hierarchy-table tr td:last-of-type{border-right:1px solid #d4d4d4;width:7.875rem!important}table.seller-hierarchy-table tr th:nth-of-type(2){width:7.75rem!important}table.seller-hierarchy-table tr td{font-family:Roboto;font-size:.75rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal;color:#4a4a4a;box-shadow:none!important;border-top:1px solid #d4d4d4;border-bottom:1px solid #d4d4d4}table.seller-hierarchy-table tr td:nth-of-type(2),table.seller-hierarchy-table tr td:nth-of-type(3){padding-top:.25rem}table.seller-hierarchy-table tr td span{display:inline-block;width:90%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;position:relative}section.hierarchy-table-container{max-height:8.75rem;overflow:auto}section.hierarchy-table-container::-webkit-scrollbar-track{margin-top:1.5rem}.difference-text{padding:.5rem;color:#000;text-align:left}::ng-deep .posted-avg-tooltip .tooltip-inner{width:13.8125rem!important}::ng-deep .drrBooked-info-tooltip{transform:translate(26px,6px)}::ng-deep .drrBooked-info-tooltip .tooltip-inner{max-width:307px!important;width:242px!important;background:#fff;word-break:break-word;display:flex;padding:4px!important;text-align:left}::ng-deep .drrBooked-info-tooltip .tooltip-inner p{color:#000}::ng-deep .drrBooked-info-tooltip .arrow:before{border-right-color:#fff!important}.clickable-data{cursor:pointer;color:#268bff!important;display:flex!important;align-items:center}.clickable-data .spot-details-download-icons{font-size:12px}.disabled-clickable-data{pointer-events:none;color:#d4d4d4!important}.spot-column-tooltip-message{color:#000;width:max-content;text-align:left}div.spinner-for-button-directive{position:relative;left:-1px}.clickable-row table tr.mat-row td{cursor:pointer!important}.tooltip-div-container{text-align:left!important;padding:12px 4px;color:#4a4a4a!important;font-size:12px!important;font-family:Roboto;font-size:12px;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}.notification-tooltip-div-container{text-align:left!important;padding:6px 8px;color:#4a4a4a!important;font-size:12px!important;font-family:Roboto;font-size:12px;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}.mdi-information,.mdi-information-outline{left:3px;top:1px}.mdi-information-outline{position:static}::ng-deep .team-user-tooltip.bs-tooltip-top .arrow:before{border-top:6px solid white}::ng-deep .team-user-tooltip.bs-tooltip-left .arrow:before{border-left:6px solid white}::ng-deep .team-user-tooltip.bs-tooltip-bottom .arrow:before{border-bottom:6px solid white}::ng-deep .team-user-tooltip.bs-tooltip-right .arrow:before{border-right:5px solid white}::ng-deep .team-user-tooltip .tooltip-inner{opacity:1!important;width:-moz-fit-content!important;width:fit-content!important;max-width:520px;border-radius:2px;padding:0 4px!important}::ng-deep .team-user-tooltip .tooltip-inner .tooltip-inner{color:#4a4a4a;text-align:left;padding:8px!important;border-radius:2px;background:#fff!important;box-shadow:0 6px 10px #0000004d,0 2px 2px #0003;font-family:Roboto;font-size:12px;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}::ng-deep .team-user-tooltip .tooltip-inner.bs-tooltip-top .arrow:before{border-top:6px solid white}::ng-deep .team-user-tooltip .tooltip-inner.bs-tooltip-left .arrow:before{border-left:6px solid white}::ng-deep .team-user-tooltip .tooltip-inner.bs-tooltip-bottom .arrow:before{border-bottom:6px solid white}::ng-deep .team-user-tooltip .tooltip-inner.bs-tooltip-right .arrow:before{border-right:5px solid white}::ng-deep .gt-icon-column-tooltip{opacity:1!important}::ng-deep .gt-icon-column-tooltip .tooltip-inner{color:#4a4a4a;text-align:left;padding:8px!important;border-radius:2px;background:#fff!important;box-shadow:0 6px 10px #0000004d,0 2px 2px #0003;font-family:Roboto;font-size:12px;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}::ng-deep .gt-icon-column-tooltip.bs-tooltip-top .arrow:before{border-top:6px solid white}::ng-deep .gt-icon-column-tooltip.bs-tooltip-left .arrow:before{border-left:6px solid white}::ng-deep .gt-icon-column-tooltip.bs-tooltip-bottom .arrow:before{border-bottom:6px solid white}::ng-deep .gt-icon-column-tooltip.bs-tooltip-right .arrow:before{border-right:5px solid white}::ng-deep .gt-icon-column-tooltip .tooltip-inner{width:100%}::ng-deep .tooltip-containing-table{opacity:1!important}::ng-deep .tooltip-containing-table .tooltip-inner{color:#4a4a4a;text-align:left;padding:8px!important;border-radius:2px;background:#fff!important;box-shadow:0 6px 10px #0000004d,0 2px 2px #0003;font-family:Roboto;font-size:12px;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}::ng-deep .tooltip-containing-table.bs-tooltip-top .arrow:before{border-top:6px solid white}::ng-deep .tooltip-containing-table.bs-tooltip-left .arrow:before{border-left:6px solid white}::ng-deep .tooltip-containing-table.bs-tooltip-bottom .arrow:before{border-bottom:6px solid white}::ng-deep .tooltip-containing-table.bs-tooltip-right .arrow:before{border-right:5px solid white}::ng-deep .tooltip-containing-table li{margin:0!important;padding:0!important}::ng-deep .tooltip-containing-table ul{margin:0!important;padding-left:8px!important}::ng-deep .tooltip-containing-table .tooltip-inner{width:100%;max-width:230px}table.tooltip-table{table-layout:fixed;margin:4px 0 0;width:100%}table.tooltip-table th,table.tooltip-table td{padding:2px 8px;line-height:normal}table.tooltip-table thead tr th:first-of-type{box-shadow:inset 0 1px #d4d4d4,inset 0 -1px #d4d4d4,inset -1px 0 #d4d4d4,inset 1px 0 #d4d4d4!important;border:none}table.tooltip-table thead tr th{color:#5e5e5e!important;font-size:12px;font-weight:500;font-family:Roboto;line-height:1.67;background-color:#ededed;border-top:none!important;border-bottom:none!important;outline:none!important;box-shadow:inset 0 1px #d4d4d4,inset 0 -1px #d4d4d4,inset -1px 0 #d4d4d4}table.tooltip-table thead tr th div.row{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center}table.tooltip-table tbody tr td{color:#5e5e5e!important;font-size:12px;font-weight:500;font-family:Roboto;line-height:1.67}table.tooltip-table tbody tr td:first-of-type{box-shadow:inset 1px 0 #d4d4d4,inset -1px 0 #d4d4d4,inset 0 -1px #d4d4d4;border:none}table.tooltip-table tbody tr td:nth-of-type(n+2){box-shadow:inset -1px 0 #d4d4d4,inset 0 -1px #d4d4d4;border:none}.bottom-border{border-bottom:1px solid #d4d4d4!important}i.disabled{pointer-events:none!important}\n"], dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "ngmodule", type: MatTableModule }, { kind: "component", type: i4.MatTable, selector: "mat-table, table[mat-table]", exportAs: ["matTable"] }, { kind: "directive", type: i4.MatHeaderCellDef, selector: "[matHeaderCellDef]" }, { kind: "directive", type: i4.MatHeaderRowDef, selector: "[matHeaderRowDef]", inputs: ["matHeaderRowDef", "matHeaderRowDefSticky"] }, { kind: "directive", type: i4.MatColumnDef, selector: "[matColumnDef]", inputs: ["sticky", "matColumnDef"] }, { kind: "directive", type: i4.MatCellDef, selector: "[matCellDef]" }, { kind: "directive", type: i4.MatRowDef, selector: "[matRowDef]", inputs: ["matRowDefColumns", "matRowDefWhen"] }, { kind: "directive", type: i4.MatHeaderCell, selector: "mat-header-cell, th[mat-header-cell]" }, { kind: "directive", type: i4.MatCell, selector: "mat-cell, td[mat-cell]" }, { kind: "component", type: i4.MatHeaderRow, selector: "mat-header-row, tr[mat-header-row]", exportAs: ["matHeaderRow"] }, { kind: "component", type: i4.MatRow, selector: "mat-row, tr[mat-row]", exportAs: ["matRow"] }, { kind: "directive", type: NgFor, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: NgbTooltip, selector: "[ngbTooltip]", inputs: ["animation", "autoClose", "placement", "popperOptions", "triggers", "positionTarget", "container", "disableTooltip", "tooltipClass", "openDelay", "closeDelay", "ngbTooltip"], outputs: ["shown", "hidden"], exportAs: ["ngbTooltip"] }, { kind: "ngmodule", type: NgxSkeletonLoaderModule }, { kind: "component", type: i5.NgxSkeletonLoaderComponent, selector: "ngx-skeleton-loader", inputs: ["count", "loadingText", "appearance", "animation", "ariaLabel", "theme"] }, { kind: "directive", type: showEllipsisTextOnHoverDirective, selector: "[showEllipsisTextOnHover]" }, { kind: "directive", type: NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "component", type: AnnaIconColumnComponent, selector: "anna-core-anna-icon-column", inputs: ["componentName", "iconToShow", "dataObject"], outputs: ["onColumnIconClicked"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i6.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i6.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i6.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: MatRadioModule }, { kind: "directive", type: i7.MatRadioGroup, selector: "mat-radio-group", exportAs: ["matRadioGroup"] }, { kind: "component", type: i7.MatRadioButton, selector: "mat-radio-button", inputs: ["disableRipple", "tabIndex"], exportAs: ["matRadioButton"] }, { kind: "directive", type: NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "component", type: AnnaNoDataComponent, selector: "anna-core-no-data-lib", inputs: ["width", "marginTop"] }, { kind: "component", type: AnnaColumnCheckboxFilterComponent, selector: "anna-core-anna-column-checkbox-filter", inputs: ["showFilterHeaderTabs", "isLurAndCsrComponent", "tableData", "clonedTableData", "filterTabObjects"], outputs: ["filterAppliedToTable", "sortingAppliedToTable", "getSortType", "closeTooltip"] }, { kind: "component", type: AnnaColumnSliderFilterComponent, selector: "anna-core-anna-column-slider-filter", inputs: ["filterTabObjects", "isLurAndCsrComponent", "tableData", "showFilterHeaderTabs", "clonedTableData"], outputs: ["closeTooltip", "filterAppliedToTable", "getSortType", "sortingAppliedToTable"] }, { kind: "component", type: AnnaColumnDateRangeFilterComponent, selector: "anna-core-anna-column-date-range-filter", inputs: ["tableData", "clonedTableData", "filterTabObjects", "isLurAndCsrComponent", "showFilterHeaderTabs"], outputs: ["filterAppliedToTable", "sortingAppliedToTable", "getSortType", "closeTooltip"] }, { kind: "component", type: AnnaColumnTimeFilterComponent, selector: "anna-core-anna-column-time-filter", inputs: ["tableData", "clonedTableData", "filterTabObjects", "showFilterHeaderTabs", "showAllTimeRangeCheckboxes", "isLurAndCsrComponent", "gtGeneralConfig", "showClearAllFilter", "startFromText", "endToText", "isSortAndFilterAbsent"], outputs: ["timeChanges", "filterAppliedToTable", "sortingAppliedToTable", "getSortType", "closeTooltip"] }, { kind: "ngmodule", type: NgCircleProgressModule }, { kind: "component", type: i8.CircleProgressComponent, selector: "circle-progress", inputs: ["name", "class", "backgroundGradient", "backgroundColor", "backgroundGradientStopColor", "backgroundOpacity", "backgroundStroke", "backgroundStrokeWidth", "backgroundPadding", "radius", "space", "percent", "toFixed", "maxPercent", "renderOnClick", "units", "unitsFontSize", "unitsFontWeight", "unitsColor", "outerStrokeGradient", "outerStrokeWidth", "outerStrokeColor", "outerStrokeGradientStopColor", "outerStrokeLinecap", "innerStrokeColor", "innerStrokeWidth", "titleFormat", "title", "titleColor", "titleFontSize", "titleFontWeight", "subtitleFormat", "subtitle", "subtitleColor", "subtitleFontSize", "subtitleFontWeight", "imageSrc", "imageHeight", "imageWidth", "animation", "animateTitle", "animateSubtitle", "animationDuration", "showTitle", "showSubtitle", "showUnits", "showImage", "showBackground", "showInnerStroke", "clockwise", "responsive", "startFromZero", "showZeroOuterStroke", "lazy", "options"], outputs: ["onClick"] }, { kind: "pipe", type: AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
748
+ }
749
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AnnaNonEditableGenericTableComponent, decorators: [{
750
+ type: Component,
751
+ args: [{ selector: 'anna-core-non-editable-generic-table-lib', changeDetection: ChangeDetectionStrategy.OnPush, standalone: true, imports: [
752
+ NgClass,
753
+ NgStyle,
754
+ MatTableModule,
755
+ NgFor,
756
+ NgIf,
757
+ NgTemplateOutlet,
758
+ NgbTooltip,
759
+ NgxSkeletonLoaderModule,
760
+ showEllipsisTextOnHoverDirective,
761
+ NgSwitch,
762
+ NgSwitchCase,
763
+ AnnaIconColumnComponent,
764
+ FormsModule,
765
+ MatRadioModule,
766
+ NgSwitchDefault,
767
+ AnnaNoDataComponent,
768
+ AnnaColumnCheckboxFilterComponent,
769
+ AnnaColumnSliderFilterComponent,
770
+ AnnaColumnDateRangeFilterComponent,
771
+ AnnaColumnTimeFilterComponent,
772
+ NgCircleProgressModule,
773
+ AsyncPipe,
774
+ ], template: "<div\r\n id=\"generic-table-conatiner\"\r\n class=\"table-container {{ gtGeneralConfig?.tableOuterContainerName }} {{ tableBottomBorderClass }}\"\r\n [ngClass]=\"{\r\n 'scroll-left-shadow-effect': isScrolledLeft,\r\n 'scroll-right-shadow-effect': !isScrollEnded,\r\n 'clickable-row': clickableRow,\r\n 'no-data-table': (isNoDataToDisplaySubject$ | async)\r\n }\"\r\n (scroll)=\"onTableContainerScroll($event)\"\r\n>\r\n <div\r\n [class]=\"gtGeneralConfig.tableContainerName\"\r\n class=\"horizontal-scroll-for-table-container\"\r\n [ngStyle]=\"{\r\n height:\r\n tableData.length < maximumRowsWhichCanBeRenderedWithoutScroll\r\n ? 'calc(' +\r\n (gtDimension.rowHeight * tableData.length +\r\n (!tableData.length || !gtGeneralConfig.totalRow\r\n ? gtDimension.headerHeight\r\n : gtDimension.headerHeight + gtDimension.rowHeight)) +\r\n 'px)'\r\n : gtDimension.tableHeight\r\n }\"\r\n >\r\n <table\r\n class=\"gt\"\r\n [ngClass]=\"tableClass\"\r\n mat-table\r\n [dataSource]=\"renderedData\"\r\n >\r\n <tr\r\n class=\"header-row\"\r\n mat-header-row\r\n *matHeaderRowDef=\"tableColumns; sticky: true\"\r\n [style.height.px]=\"gtDimension.headerHeight\"\r\n ></tr>\r\n <tr\r\n class=\"total-row\"\r\n mat-header-row\r\n [style.height.px]=\"gtDimension.rowHeight\"\r\n *matHeaderRowDef=\"totalRowColumns; sticky: true\"\r\n [class.hidden]=\"\r\n showSkeletonLoading ||\r\n (!showSkeletonLoading && !tableData.length) ||\r\n (isNoDataToDisplaySubject$ | async) ||\r\n (!showSkeletonLoading && !gtGeneralConfig.totalRow)\r\n \"\r\n ></tr>\r\n <tr\r\n [class]=\"rowData.gtClass\"\r\n [ngClass]=\"{ 'no-border-tr': (isNoDataToDisplaySubject$ | async) }\"\r\n mat-row\r\n *matRowDef=\"let rowData; columns: tableColumns\"\r\n [style.height.px]=\"gtDimension.rowHeight\"\r\n (click)=\"dataRowClicked(rowData)\"\r\n ></tr>\r\n\r\n <!-- TOTAL ROW -->\r\n <ng-container\r\n [matColumnDef]=\"column.colName\"\r\n *ngFor=\"let column of totalRowInfo; trackBy: trackByFn\"\r\n >\r\n <td\r\n mat-header-cell\r\n *matHeaderCellDef\r\n [attr.colspan]=\"column.colspan\"\r\n class=\"{{ column.class }}\"\r\n >\r\n <ng-container *ngIf=\"column['isActionColumn']\">\r\n <a\r\n *ngFor=\"let data of column.actionData\"\r\n [class]=\"data.class\"\r\n (click)=\"onClickableDataClicked({}, data.id)\"\r\n >\r\n {{ data.name }}\r\n </a>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"column['isIconColumn']\">\r\n <i\r\n class=\"{{ column?.iconData?.class }}\"\r\n (click)=\"iconClickedInTotalRow(column?.colName)\"\r\n >\r\n </i>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"!column['isActionColumn']\">\r\n <strong class=\"upper-label\">{{ column.data }}</strong>\r\n <ng-container *ngIf=\"column.lowerData\">\r\n <br />\r\n <span\r\n *ngIf=\"\r\n column.colName == 'total-potential-booked-unit' &&\r\n gtGeneralConfig.component == 'RATING';\r\n else columnLowerData\r\n \"\r\n class=\"clickable-data\"\r\n (click)=\"spotDetailsDownloadClicked('TOTALROW')\"\r\n [ngClass]=\"{ 'disabled-clickable-data': downloadInProgress }\"\r\n >{{ column.lowerData }}\r\n <span class=\"material-icons spot-details-download-icons\">get_app</span>\r\n <ng-container *ngIf=\"downloadInProgress && selectedRowTypeForDownload == 'TOTALROW'\">\r\n <ng-container [ngTemplateOutlet]=\"circularProgressBar\"></ng-container>\r\n </ng-container>\r\n </span>\r\n <ng-template #columnLowerData>\r\n <span class=\"lower-label\">{{ column.lowerData }}</span>\r\n </ng-template>\r\n </ng-container>\r\n <ng-container *ngIf=\"column.tooltipMessage && gtGeneralConfig.component != 'LUR_VIOLATIONS'\">\r\n <i\r\n class=\"{{ column.tooltipIconClass }}\"\r\n container=\"body\"\r\n [ngbTooltip]=\"column.tooltipMessage\"\r\n tooltipClass=\"gt-total-row-tooltip\"\r\n placement=\"bottom\"\r\n ></i>\r\n </ng-container>\r\n <ng-container *ngIf=\"gtGeneralConfig.component == 'LUR_VIOLATIONS' && column.tooltipMessage\">\r\n <i\r\n class=\"mi mdi-info-outline info-label\"\r\n container=\"body\"\r\n [ngbTooltip]=\"lurViolationTotalRowToolTip\"\r\n tooltipClass=\"gt-total-row-tooltip\"\r\n placement=\"bottom\"\r\n ></i>\r\n </ng-container>\r\n </ng-container>\r\n </td>\r\n </ng-container>\r\n\r\n <!-- MAIN ROW -->\r\n <ng-container\r\n [matColumnDef]=\"columnDef.headerInfo[0].objectKey\"\r\n *ngFor=\"let columnDef of tableHeaders; trackBy: trackByFn\"\r\n >\r\n <th\r\n #tableHeader\r\n nowrap\r\n mat-header-cell\r\n *matHeaderCellDef\r\n [style.width]=\"columnDef.width\"\r\n >\r\n <div\r\n class=\"row mx-0\"\r\n *ngFor=\"let header of columnDef.headerInfo; let j = index\"\r\n >\r\n <p\r\n *ngIf=\"header.typeOfHeaderData === 'STRING'\"\r\n [ngClass]=\"{ 'upper-label': j === 0, 'lower-label': j === 1 }\"\r\n >\r\n <ngx-skeleton-loader\r\n *ngIf=\"header.name == null\"\r\n count=\"1\"\r\n [theme]=\"{\r\n height: '10px',\r\n display: 'block',\r\n width: columnDef.width,\r\n 'max-width': 'calc(100% - 20px)'\r\n }\"\r\n >\r\n </ngx-skeleton-loader>\r\n <ng-container *ngIf=\"header.name\">\r\n {{ header.name }}\r\n </ng-container>\r\n <ng-container *ngIf=\"header.tooltip && header.tooltip.tooltipMessage\">\r\n <i\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"header.tooltip.tooltipMessage\"\r\n container=\"body\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n </ng-container>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'impsInfoTooltip'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"impsInfoTooltip\"\r\n container=\"body\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"\r\n header.tooltip && header.tooltip.name == 'spotsColumnEquivalizationMessageTooltip'\r\n \"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n container=\"body\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"spotsColumnEquivalizationMessageTooltip\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'underDeliveryTooltip'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n container=\"body\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"underDeliveryTooltip\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'overDeliveryTooltip'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n container=\"body\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"overDeliveryTooltip\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'ratingInfoTooltip'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"ratingInfoTooltip\"\r\n container=\"body\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'rateInfoTooltip'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"rateInfoTooltip\"\r\n container=\"body\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'ongoingRevBookedColumnTooltip'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"ongoingRevBookedColumnTooltip\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'completedRevBookedColumnTooltip'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"completedRevBookedColumnTooltip\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'avgBookedRate'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"avgBookedRate\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'avgBookedRtg'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"avgBookedRtg\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'avgBookedImps'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"avgBookedImps\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'automationTooltip'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"automationTooltip\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'rebateImpact'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"rebateImpact\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'projectedImpsRtg'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"projectedImpsRtg\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n </p>\r\n\r\n <ng-container *ngIf=\"header.typeOfHeaderData === 'CHECKBOX'\">\r\n <span\r\n *ngIf=\"gtGeneralConfig.isHeaderChecked\"\r\n class=\"material-icons custom-column-checkbox-checked\"\r\n (click)=\"selectUnselectAllRows()\"\r\n >\r\n check_box\r\n </span>\r\n <span\r\n *ngIf=\"!gtGeneralConfig.isHeaderChecked\"\r\n class=\"material-icons custom-column-checkbox-unchecked\"\r\n [ngClass]=\"{ 'disable-checkbox': gtGeneralConfig.disableHeaderCheckbox }\"\r\n (click)=\"selectUnselectAllRows()\"\r\n >\r\n check_box_outline_blank\r\n </span>\r\n </ng-container>\r\n\r\n <div\r\n *ngIf=\"gtGeneralConfig.showAllColumnFilter\"\r\n class=\"sort-filter-container\"\r\n >\r\n <ng-container *ngIf=\"header.showTooltipIcon\">\r\n <!-- Active tooltip Functionality -->\r\n <ng-container *ngIf=\"header.filter === 'CHECKBOX'\">\r\n <span\r\n class=\"mdi mdi-filter-variant\"\r\n [ngClass]=\"{\r\n active:\r\n annaFilterService.isFilterSortActive &&\r\n annaFilterService.isFilterSortActive[header.joinedFilterSortObjectKeys],\r\n disabled: header.disableTooltipIcon || showSkeletonLoading\r\n }\"\r\n [ngbTooltip]=\"filterTooltip\"\r\n placement=\"{{ filterAlignment }}\"\r\n container=\"body\"\r\n tooltipClass=\"non-edit-checkbox-tooltip\"\r\n [autoClose]=\"'outside'\"\r\n triggers=\"manual\"\r\n #t=\"ngbTooltip\"\r\n (click)=\"bindTheValueToToolTip(t, header)\"\r\n (hidden)=\"closeTooltip()\"\r\n >\r\n </span\r\n ><br />\r\n </ng-container>\r\n <ng-container *ngIf=\"header.filter === 'SLIDER'\">\r\n <span\r\n class=\"mdi mdi-filter-variant\"\r\n [ngClass]=\"{\r\n active:\r\n annaFilterService.isFilterSortActive &&\r\n annaFilterService.isFilterSortActive[header.joinedFilterSortObjectKeys],\r\n disabled: header.disableTooltipIcon || showSkeletonLoading\r\n }\"\r\n [ngbTooltip]=\"sliderToolTip\"\r\n placement=\"bottom left-top\"\r\n container=\"body\"\r\n tooltipClass=\"non-edit-slider-tooltip\"\r\n [autoClose]=\"'outside'\"\r\n triggers=\"manual\"\r\n #t1=\"ngbTooltip\"\r\n (click)=\"bindTheValueToToolTip(t1, header)\"\r\n (hidden)=\"closeTooltip()\"\r\n >\r\n </span\r\n ><br />\r\n </ng-container>\r\n <ng-container *ngIf=\"header.filter === 'DATE'\">\r\n <span\r\n class=\"mdi mdi-filter-variant\"\r\n [ngClass]=\"{\r\n active:\r\n annaFilterService.isFilterSortActive &&\r\n annaFilterService.isFilterSortActive[header.joinedFilterSortObjectKeys],\r\n disabled: header.disableTooltipIcon || showSkeletonLoading\r\n }\"\r\n [ngbTooltip]=\"datePickerTooltip\"\r\n placement=\"bottom auto\"\r\n container=\"body\"\r\n tooltipClass=\"non-edit-datepicker-tooltip\"\r\n [autoClose]=\"'outside'\"\r\n triggers=\"manual\"\r\n #t2=\"ngbTooltip\"\r\n (click)=\"bindTheValueToToolTip(t2, header)\"\r\n (hidden)=\"closeTooltip()\"\r\n >\r\n </span\r\n ><br />\r\n </ng-container>\r\n <ng-container *ngIf=\"header.filter === 'WEEK'\">\r\n <span\r\n class=\"mdi mdi-filter-variant\"\r\n [ngClass]=\"{\r\n active:\r\n annaFilterService.isFilterSortActive &&\r\n annaFilterService.isFilterSortActive[header.joinedFilterSortObjectKeys],\r\n disabled: header.disableTooltipIcon || showSkeletonLoading\r\n }\"\r\n [ngbTooltip]=\"weekPickerToolTip\"\r\n placement=\"bottom left-top\"\r\n container=\"body\"\r\n [autoClose]=\"'outside'\"\r\n triggers=\"manual\"\r\n #t3=\"ngbTooltip\"\r\n (click)=\"bindTheValueToToolTip(t3, header)\"\r\n (hidden)=\"closeTooltip()\"\r\n >\r\n </span\r\n ><br />\r\n </ng-container>\r\n <ng-container *ngIf=\"header.filter === 'TIME'\">\r\n <span\r\n class=\"mdi mdi-filter-variant\"\r\n [ngClass]=\"{\r\n active:\r\n annaFilterService.isFilterSortActive &&\r\n annaFilterService.isFilterSortActive[header.joinedFilterSortObjectKeys],\r\n disabled: header.disableTooltipIcon || showSkeletonLoading\r\n }\"\r\n [ngbTooltip]=\"timeFilterToolTip\"\r\n placement=\"bottom left-top auto\"\r\n container=\"body\"\r\n tooltipClass=\"non-edit-time-tooltip\"\r\n [autoClose]=\"'outside'\"\r\n triggers=\"manual\"\r\n #t4=\"ngbTooltip\"\r\n (click)=\"bindTheValueToToolTip(t4, header)\"\r\n (hidden)=\"closeTooltip()\"\r\n >\r\n </span\r\n ><br />\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"!header.showTooltipIcon\">\r\n <span id=\"no-filter-space\"></span><br />\r\n </ng-container>\r\n <i\r\n *ngIf=\"header.tooltip && header.tooltip.name == 'lurViolationInfoTooltip'\"\r\n class=\"{{ header['tooltip'].iconClass }}\"\r\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n #t=\"ngbTooltip\"\r\n container=\"body\"\r\n [ngbTooltip]=\"lurViolationInfoTooltip\"\r\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n >\r\n </i>\r\n </div>\r\n </div>\r\n </th>\r\n\r\n <ng-container *matCellDef=\"let ROW_DATA\">\r\n <td\r\n mat-cell\r\n [style.background]=\"ROW_DATA.backgroundColor\"\r\n [style.border]=\"ROW_DATA.border\"\r\n class=\"{{ ROW_DATA.rowClass }}\"\r\n [ngClass]=\"ROW_DATA[columnDef.headerInfo[0].objectKey + 'TdClass']\"\r\n [attr.rowspan]=\"ROW_DATA[columnDef.headerInfo[0].objectKey + 'Rowspan']\"\r\n *ngIf=\"\r\n !hideSomeTds ||\r\n (hideSomeTds && !ROW_DATA['hide' + columnDef.headerInfo[0].objectKey + 'Td'])\r\n \"\r\n >\r\n <ngx-skeleton-loader\r\n *ngIf=\"showSkeletonLoading\"\r\n count=\"1\"\r\n [theme]=\"{ height: '10px', display: 'block' }\"\r\n >\r\n </ngx-skeleton-loader>\r\n\r\n <ng-container *ngIf=\"!showSkeletonLoading\">\r\n <ng-container *ngIf=\"tableData.length > 0 && !(isNoDataToDisplaySubject$ | async)\">\r\n <ng-container\r\n *ngFor=\"\r\n let subline of columnDef.headerInfo;\r\n let subLineIndex = index;\r\n trackBy: trackByFn\r\n \"\r\n >\r\n <div showEllipsisTextOnHover>\r\n <ng-container [ngSwitch]=\"columnDef.headerInfo[subLineIndex].typeOfBodyData\">\r\n <ng-container *ngSwitchCase=\"'ICON'\">\r\n <i\r\n *ngIf=\"\r\n !(\r\n starredInProgress &&\r\n ROW_DATA.orderId == selectedStarredOrderId\r\n )\r\n \"\r\n [class]=\"ROW_DATA.iconClass\"\r\n (click)=\"iconClicked(ROW_DATA, ROW_DATA.iconClass)\"\r\n ngbTooltip=\"{{ ROW_DATA.iconTitleText }}\"\r\n placement=\"bottom\"\r\n container=\"body\"\r\n tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\r\n ></i>\r\n <ng-container\r\n *ngIf=\"\r\n starredInProgress && ROW_DATA.orderId == selectedStarredOrderId\r\n \"\r\n >\r\n <div class=\"spinner-for-button-directive\"></div>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'ICON_CELL'\">\r\n <ng-container\r\n *ngFor=\"\r\n let action of ROW_DATA[\r\n columnDef.headerInfo[subLineIndex].actionKey\r\n ]\r\n \"\r\n >\r\n <ng-container *ngIf=\"action.showObjectKey\">\r\n {{ ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey] }}\r\n </ng-container>\r\n\r\n <i\r\n *ngIf=\"action.showIcon\"\r\n [class]=\"action.iconClass\"\r\n (mouseenter)=\"\r\n mouseEnterOnStringTextActionType(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].tooltipKey\r\n )\r\n \"\r\n placement=\"bottom auto\"\r\n container=\"body\"\r\n [autoClose]=\"true\"\r\n tooltipClass=\"team-user-tooltip remove-on-scroll-class\"\r\n [ngbTooltip]=\"action.showTooltip ? action.tooltipData : null\"\r\n (click)=\"\r\n textActionClicked(\r\n ROW_DATA,\r\n action.id,\r\n columnDef.headerInfo[subLineIndex]\r\n )\r\n \"\r\n [disableTooltip]=\"!action.showTooltip\"\r\n >\r\n </i>\r\n\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'HTML_STRING'\">\r\n <p\r\n [innerHTML]=\"ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\r\n (click)=\"innerHTMLCellClicked($event, ROW_DATA)\"\r\n ></p>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'SVG_ICON'\">\r\n <anna-core-anna-icon-column\r\n [componentName]=\"gtGeneralConfig.component\"\r\n [dataObject]=\"ROW_DATA\"\r\n [iconToShow]=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n \"\r\n (onColumnIconClicked)=\"svgIconClicked($event)\"\r\n ></anna-core-anna-icon-column>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'TEXT_ACTIONS'\">\r\n <ng-container\r\n *ngFor=\"\r\n let text of ROW_DATA[\r\n columnDef.headerInfo[subLineIndex].actionKey\r\n ]\r\n \"\r\n >\r\n <button\r\n *ngIf=\"text.showTooltip\"\r\n (click)=\"\r\n textActionClicked(\r\n ROW_DATA,\r\n text.id,\r\n columnDef.headerInfo[subLineIndex]\r\n )\r\n \"\r\n [disabled]=\"text.isDisabled\"\r\n class=\"{{ text.class }}\"\r\n (mouseenter)=\"\r\n mouseEnterOnTextActionType(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].tooltipKey\r\n )\r\n \"\r\n [ngbTooltip]=\"textActionTooltipTemplate\"\r\n placement=\"auto\"\r\n container=\"body\"\r\n tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\r\n >\r\n {{ text.name }}\r\n </button>\r\n\r\n <button\r\n *ngIf=\"!text.showTooltip\"\r\n (click)=\"\r\n textActionClicked(\r\n ROW_DATA,\r\n text.id,\r\n columnDef.headerInfo[subLineIndex]\r\n )\r\n \"\r\n [disabled]=\"text.isDisabled\"\r\n class=\"{{ text.class }}\"\r\n >\r\n {{ text.name }}\r\n </button>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'CHECKBOX'\">\r\n <span\r\n *ngIf=\"ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\r\n [ngClass]=\"{\r\n 'disable-checkbox':\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].isDisabledKey]\r\n }\"\r\n class=\"material-icons custom-column-checkbox-checked\"\r\n (click)=\"\r\n selectOrUnselectCheckbox(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].objectKey,\r\n false\r\n )\r\n \"\r\n >\r\n check_box\r\n </span>\r\n <span\r\n *ngIf=\"!ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\r\n class=\"material-icons custom-column-checkbox-unchecked\"\r\n [ngClass]=\"{\r\n 'disable-checkbox':\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].isDisabledKey]\r\n }\"\r\n (click)=\"\r\n selectOrUnselectCheckbox(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].objectKey,\r\n true\r\n )\r\n \"\r\n >\r\n check_box_outline_blank\r\n </span>\r\n\r\n <ng-container\r\n *ngFor=\"\r\n let action of ROW_DATA[\r\n columnDef.headerInfo[subLineIndex].actionKey\r\n ]\r\n \"\r\n >\r\n <i\r\n *ngIf=\"action.showIcon\"\r\n [class]=\"action.iconClass\"\r\n [ngClass]=\"{ disabled: action.disabledIcon }\"\r\n (mouseenter)=\"\r\n mouseEnterOnStringTextActionTypeContainingTable(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].tooltipKey\r\n )\r\n \"\r\n placement=\"bottom auto\"\r\n container=\"body\"\r\n [autoClose]=\"true\"\r\n tooltipClass=\"tooltip-containing-table remove-on-scroll-class\"\r\n [ngbTooltip]=\"tooltipContainingTableTemplate\"\r\n >\r\n </i>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'CLICKABLE_DATA'\">\r\n <a\r\n *ngFor=\"\r\n let text of ROW_DATA[\r\n columnDef.headerInfo[subLineIndex].actionKey\r\n ]\r\n \"\r\n [class]=\"text.class\"\r\n (click)=\"onClickableDataClicked(ROW_DATA, text.id)\"\r\n >\r\n {{ text.name }}\r\n </a>\r\n <span\r\n *ngIf=\"\r\n subline.objectKey == 'displayBookedUnits' &&\r\n gtGeneralConfig.component == 'RATING'\r\n \"\r\n class=\"clickable-data\"\r\n (click)=\"spotDetailsDownloadClicked('DATAROW', ROW_DATA)\"\r\n [ngClass]=\"{ 'disabled-clickable-data': downloadInProgress }\"\r\n >{{ ROW_DATA.displayBookedUnits }}\r\n <span class=\"material-icons spot-details-download-icons\"\r\n >get_app</span\r\n >\r\n <ng-container\r\n *ngIf=\"\r\n downloadInProgress &&\r\n ROW_DATA.inventoryCodeId ==\r\n selectedInventoryIdForDownload &&\r\n ROW_DATA.demographic == selectedDemographicForDownload\r\n \"\r\n >\r\n <ng-container\r\n [ngTemplateOutlet]=\"circularProgressBar\"\r\n ></ng-container>\r\n </ng-container>\r\n </span>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'STRING___ICON_OR_TEXT_ACTION'\">\r\n <ng-container\r\n *ngFor=\"\r\n let action of ROW_DATA[\r\n columnDef.headerInfo[subLineIndex].actionKey\r\n ]\r\n \"\r\n >\r\n <span\r\n [class]=\"action.additionalTextBeforeLinkClass\"\r\n [innerHtml]=\"action.additionalTextBeforeLink\"\r\n ngbTooltip=\"{{ action.additionalTextBeforeLink }}\"\r\n placement=\"bottom\"\r\n container=\"body\"\r\n tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\r\n [disableTooltip]=\"!action.enableTooltipForAdditionalText\"\r\n ></span>\r\n\r\n <ng-container *ngIf=\"action && action.typeOfData == 'STRING'\">\r\n {{ action.data }}\r\n </ng-container>\r\n\r\n <a\r\n [id]=\"action.id\"\r\n *ngIf=\"action.showLink\"\r\n (click)=\"\r\n textActionClicked(\r\n ROW_DATA,\r\n action.id,\r\n columnDef.headerInfo[subLineIndex]\r\n )\r\n \"\r\n [class]=\"action.linkClass\"\r\n [ngClass]=\"{ disabled: action.disabledLink }\"\r\n >{{ action.data }}</a\r\n >\r\n <span\r\n ngbTooltip=\"{{ action.additionalTextAfterLink }}\"\r\n placement=\"bottom\"\r\n container=\"body\"\r\n [class]=\"action.additionalTextAfterLinkClass\"\r\n tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\r\n [disableTooltip]=\"!action.enableTooltipForAdditionalAfterText\"\r\n >\r\n {{ action.additionalTextAfterLink }}\r\n </span>\r\n\r\n <ng-container *ngIf=\"action.showTooltip\">\r\n <ng-container *ngIf=\"action.tooltipData.innerHtml\">\r\n <i\r\n *ngIf=\"action.showIcon\"\r\n [class]=\"action.iconClass\"\r\n [ngClass]=\"{ disabled: action.disabledIcon }\"\r\n (mouseenter)=\"\r\n mouseEnterOnStringTextActionTypeContainingTable(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].tooltipKey\r\n )\r\n \"\r\n placement=\"bottom auto\"\r\n container=\"body\"\r\n [autoClose]=\"true\"\r\n tooltipClass=\"tooltip-containing-table remove-on-scroll-class\"\r\n [ngbTooltip]=\"tooltipContainingTableTemplate\"\r\n >\r\n </i>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"!action.tooltipData.tooltipTableBody\">\r\n <i\r\n *ngIf=\"action.showIcon\"\r\n [class]=\"action.iconClass\"\r\n [ngClass]=\"{ disabled: action.disabledIcon }\"\r\n (click)=\"\r\n iconClickedOnStringIconActionType(\r\n ROW_DATA,\r\n action.id,\r\n columnDef.headerInfo[subLineIndex]\r\n )\r\n \"\r\n (mouseleave)=\"mouseLeaveTextActionType(ROW_DATA)\"\r\n (mouseenter)=\"\r\n mouseEnterOnStringTextActionType(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].tooltipKey\r\n )\r\n \"\r\n [placement]=\"\r\n action.tooltipPlacement\r\n ? action.tooltipPlacement\r\n : 'bottom auto'\r\n \"\r\n container=\"body\"\r\n [autoClose]=\"true\"\r\n tooltipClass=\"team-user-tooltip remove-on-scroll-class {{\r\n action.tooltipClass\r\n }}\"\r\n [ngbTooltip]=\"userLoggedInDetails\"\r\n >\r\n </i>\r\n <ng-container *ngIf=\"action['showSvgIcon']\">\r\n <anna-core-anna-est-icon-template\r\n class=\"float-right\"\r\n *ngIf=\"action['svgIconName'] == 'anna-icon'\"\r\n (mouseleave)=\"mouseLeaveTextActionType(ROW_DATA)\"\r\n (mouseenter)=\"\r\n mouseEnterOnStringTextActionType(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex]\r\n .tooltipKey\r\n )\r\n \"\r\n [placement]=\"\r\n action.tooltipPlacement\r\n ? action.tooltipPlacement\r\n : 'bottom auto'\r\n \"\r\n tooltipClass=\"team-user-tooltip remove-on-scroll-class {{\r\n action['tooltipClass']\r\n }}\"\r\n [ngbTooltip]=\"userLoggedInDetails\"\r\n container=\"body\"\r\n [autoClose]=\"true\"\r\n >\r\n </anna-core-anna-est-icon-template>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngIf=\"!action.showTooltip\">\r\n <i\r\n *ngIf=\"action.showIcon\"\r\n [class]=\"action.iconClass\"\r\n [ngClass]=\"{ disabled: action.disabledIcon }\"\r\n (click)=\"\r\n iconClickedOnStringIconActionType(\r\n ROW_DATA,\r\n action.id,\r\n columnDef.headerInfo[subLineIndex]\r\n )\r\n \"\r\n >\r\n </i>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'STRING_OR_INPUT'\">\r\n <ng-container\r\n *ngIf=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]?.type ==\r\n 'STRING';\r\n else inputBox\r\n \"\r\n >\r\n <span\r\n [innerHtml]=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n ?.value\r\n \"\r\n ></span>\r\n </ng-container>\r\n <ng-template #inputBox>\r\n <input\r\n placeholder=\"{{\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n ?.placeholder\r\n }}\"\r\n showEllipsisTextOnHover\r\n class=\"{{\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n .className\r\n }}\"\r\n (keydown)=\"\r\n changesMadeInEditableInputBox(\r\n $event,\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey],\r\n false\r\n )\r\n \"\r\n (paste)=\"\r\n changesMadeInEditableInputBox(\r\n $event,\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey],\r\n true\r\n )\r\n \"\r\n (ngModelChange)=\"\r\n editableInputValueChanged(\r\n $event,\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].objectKey\r\n )\r\n \"\r\n [ngModel]=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey].value\r\n \"\r\n [disabled]=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n .disabled\r\n \"\r\n [ngClass]=\"{\r\n 'red-border':\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n .hasError\r\n }\"\r\n />\r\n\r\n <i\r\n *ngIf=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n .showIcon\r\n \"\r\n container=\"body\"\r\n [ngbTooltip]=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n .iconTooltip\r\n \"\r\n tooltipClass=\"gt-total-row-tooltip\"\r\n placement=\"bottom\"\r\n class=\"{{\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n .iconClass\r\n }}\"\r\n >\r\n </i>\r\n <ng-container\r\n *ngIf=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey][\r\n 'showSvgIcon'\r\n ]\r\n \"\r\n >\r\n <anna-core-anna-est-icon-template\r\n class=\"float-right\"\r\n *ngIf=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey][\r\n 'svgIconName'\r\n ] == 'anna-icon'\r\n \"\r\n [placement]=\"'bottom auto'\"\r\n tooltipClass=\"gt-total-row-tooltip\"\r\n [ngbTooltip]=\"\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n .iconTooltip\r\n \"\r\n container=\"body\"\r\n >\r\n </anna-core-anna-est-icon-template>\r\n </ng-container>\r\n </ng-template>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'HTML'\">\r\n <span\r\n [innerHtml]=\"ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\r\n ></span>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'SINGLE_RADIO'\">\r\n <span\r\n *ngIf=\"ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\r\n [ngClass]=\"{\r\n 'disable-checkbox':\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].isDisabledKey]\r\n }\"\r\n class=\"mdi mdi-radiobox-marked\"\r\n (click)=\"(null)\"\r\n >\r\n </span>\r\n <span\r\n *ngIf=\"!ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\r\n class=\"mdi mdi-radiobox-blank\"\r\n [ngClass]=\"{\r\n 'disable-checkbox':\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].isDisabledKey]\r\n }\"\r\n (click)=\"\r\n selectOrUnselectCheckbox(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].objectKey,\r\n true\r\n )\r\n \"\r\n >\r\n </span>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'RADIO'\">\r\n <mat-radio-group\r\n *ngIf=\"ROW_DATA['RadioButtonConfig']\"\r\n [ngModel]=\"ROW_DATA[subline.objectKey]\"\r\n [disabled]=\"ROW_DATA['RadioButtonConfig'][0].isDisabled\"\r\n >\r\n <ng-container\r\n *ngFor=\"\r\n let radioButton of ROW_DATA['RadioButtonConfig'];\r\n let last = last\r\n \"\r\n >\r\n <mat-radio-button\r\n value=\"{{ radioButton.value }}\"\r\n class=\"{{ radioButton.class }}\"\r\n (click)=\"\r\n radioButtonClicked(\r\n ROW_DATA,\r\n radioButton.value,\r\n ROW_DATA['RadioButtonConfig'][0].isDisabled\r\n )\r\n \"\r\n >{{ radioButton.label }}\r\n </mat-radio-button>\r\n <i\r\n class=\" {{ radioButton.iconClass }}\"\r\n (click)=\"radioButtonIconClicked(ROW_DATA)\"\r\n ></i>\r\n <br *ngIf=\"!last\" />\r\n </ng-container>\r\n </mat-radio-group>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchCase=\"'STRING_WITH_TOOLTIP'\">\r\n <ng-container\r\n *ngFor=\"\r\n let action of ROW_DATA[\r\n columnDef.headerInfo[subLineIndex].actionKey\r\n ]\r\n \"\r\n >\r\n <span> {{ action?.dataToDisplay }}</span>\r\n <span\r\n *ngIf=\"action?.showTooltip\"\r\n [ngbTooltip]=\"textActionTooltipTemplate\"\r\n (mouseenter)=\"\r\n mouseEnterOnStringTextActionType(\r\n ROW_DATA,\r\n columnDef.headerInfo[subLineIndex].tooltipKey\r\n )\r\n \"\r\n [placement]=\"action?.tooltipPosition\"\r\n container=\"body\"\r\n [class]=\"action?.tooltipIconClass\"\r\n tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\r\n [disableTooltip]=\"action?.disableTooltip\"\r\n >\r\n </span>\r\n <span> {{ action?.dataToDisplayAfterTooltip }}</span>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-container *ngSwitchDefault>\r\n <ng-container *ngIf=\"subline.objectKey != 'description'\">\r\n <span>{{\r\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n }}</span>\r\n <i\r\n *ngIf=\"\r\n subline.objectKey == 'inventoryCode' &&\r\n ROW_DATA['isSellerGroup'] &&\r\n gtGeneralConfig.component == 'RATING'\r\n \"\r\n class=\"mi mdi-info-outline seller-tooltip\"\r\n [ngbTooltip]=\"sellerHierarchyTooltip\"\r\n placement=\"bottom auto\"\r\n container=\"body\"\r\n [autoClose]=\"true\"\r\n triggers=\"manual\"\r\n (hidden)=\"closeTooltip()\"\r\n #info=\"ngbTooltip\"\r\n tooltipClass=\"hierarchy-tooltip remove-on-scroll-class\"\r\n (mouseenter)=\"\r\n bindTheValueToSellerGroupTooltip(\r\n ROW_DATA.sellerGroupHierarchy,\r\n info\r\n )\r\n \"\r\n >\r\n </i>\r\n\r\n <i\r\n *ngIf=\"\r\n subline.objectKey == 'displayBookedAverageRating' &&\r\n gtGeneralConfig.component == 'RATING' &&\r\n ROW_DATA['showRatingAverageIcon']\r\n \"\r\n class=\"mi mdi-info-outline seller-tooltip\"\r\n placement=\"bottom auto\"\r\n container=\"body\"\r\n [autoClose]=\"true\"\r\n (mouseenter)=\"\r\n setIsDifference(ROW_DATA.isDifferenceLessThan25Percent)\r\n \"\r\n tooltipClass=\"posted-avg-tooltip remove-on-scroll-class\"\r\n [ngbTooltip]=\"postedRatingDifference\"\r\n >\r\n </i>\r\n\r\n <i\r\n *ngIf=\"\r\n subline.objectKey == 'displayBookedAverageImpression' &&\r\n gtGeneralConfig.component == 'RATING' &&\r\n ROW_DATA['showImpressionAverageIcon']\r\n \"\r\n class=\"mi mdi-info-outline seller-tooltip\"\r\n placement=\"bottom auto\"\r\n container=\"body\"\r\n [autoClose]=\"true\"\r\n (mouseenter)=\"\r\n setIsDifference(ROW_DATA.isDifferenceLessThan25Percent)\r\n \"\r\n tooltipClass=\"posted-avg-tooltip remove-on-scroll-class\"\r\n [ngbTooltip]=\"postedImpDifference\"\r\n >\r\n </i>\r\n </ng-container>\r\n <ng-container *ngIf=\"subline.objectKey == 'description'\">\r\n <p\r\n *ngIf=\"\r\n ROW_DATA.descriptionMessage ||\r\n ROW_DATA.descriptionEmailReferenceNum\r\n \"\r\n >\r\n <ng-container *ngIf=\"ROW_DATA.descriptionMessage\">\r\n {{ ROW_DATA.descriptionMessage }}\r\n <br />\r\n </ng-container>\r\n <ng-container\r\n *ngIf=\"\r\n ROW_DATA.descriptionEmailReferenceNum != '-' &&\r\n ROW_DATA.descriptionEmailReferenceNum != ''\r\n \"\r\n >\r\n Email Ref: {{ ROW_DATA.descriptionEmailReferenceNum }}\r\n <br />\r\n </ng-container>\r\n </p>\r\n <a\r\n href=\"{{ ROW_DATA.descriptionDetailsUrl }}\"\r\n target=\"_blank\"\r\n *ngIf=\"\r\n ROW_DATA.descriptionDetailsUrlType === 'PDF' ||\r\n ROW_DATA.descriptionDetailsUrlType === 'EXCEL'\r\n \"\r\n >\r\n <button class=\"btn viewDetailsAndEmailBtn\">Download</button>\r\n </a>\r\n <ng-container\r\n *ngIf=\"ROW_DATA.activityname.toLowerCase() == 'order onboarded'\"\r\n >\r\n <a\r\n *ngIf=\"ROW_DATA.descriptionDetailsUrlType === 'LINK'\"\r\n (click)=\"viewDetailsClicked(ROW_DATA)\"\r\n >\r\n <button class=\"btn viewDetailsAndEmailBtn order-onboarded\">\r\n View details\r\n </button>\r\n </a>\r\n </ng-container>\r\n\r\n <a\r\n href=\"{{ ROW_DATA.descriptionEmailUrl }}\"\r\n target=\"_blank\"\r\n *ngIf=\"\r\n ROW_DATA.descriptionEmailUrl != '-' &&\r\n ROW_DATA.descriptionEmailUrl != ''\r\n \"\r\n >\r\n <button class=\"btn viewDetailsAndEmailBtn\">View email</button>\r\n </a>\r\n </ng-container>\r\n </ng-container>\r\n </ng-container>\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"isNoDataToDisplaySubject$ | async\">\r\n <div>\r\n {{ null }}\r\n </div>\r\n </ng-container>\r\n </ng-container>\r\n </td>\r\n </ng-container>\r\n </ng-container>\r\n </table>\r\n </div>\r\n <anna-core-no-data-lib\r\n [width]=\"noDataWidth\"\r\n [marginTop]=\"marginTop\"\r\n *ngIf=\"isNoDataToDisplaySubject$ | async\"\r\n >\r\n </anna-core-no-data-lib>\r\n</div>\r\n\r\n<!-- Checkbox template -->\r\n<ng-template #filterTooltip>\r\n <anna-core-anna-column-checkbox-filter\r\n [tableData]=\"tableData\"\r\n [showFilterHeaderTabs]=\"showFilterTooltipTabs\"\r\n [isLurAndCsrComponent]=\"false\"\r\n [clonedTableData]=\"clonedTableData\"\r\n [filterTabObjects]=\"filterTabObjects\"\r\n (filterAppliedToTable)=\"filterApplied($event)\"\r\n (sortingAppliedToTable)=\"sortingApplied($event)\"\r\n (closeTooltip)=\"closeTooltip()\"\r\n >\r\n </anna-core-anna-column-checkbox-filter>\r\n</ng-template>\r\n\r\n<!-- Slider template -->\r\n<ng-template #sliderToolTip>\r\n <anna-core-anna-column-slider-filter\r\n [tableData]=\"tableData\"\r\n [showFilterHeaderTabs]=\"showFilterTooltipTabs\"\r\n [isLurAndCsrComponent]=\"false\"\r\n [clonedTableData]=\"clonedTableData\"\r\n [filterTabObjects]=\"filterTabObjects\"\r\n (filterAppliedToTable)=\"filterApplied($event)\"\r\n (sortingAppliedToTable)=\"sortingApplied($event)\"\r\n (closeTooltip)=\"closeTooltip()\"\r\n >\r\n </anna-core-anna-column-slider-filter>\r\n</ng-template>\r\n\r\n<!-- Date Picker Template -->\r\n<ng-template #datePickerTooltip>\r\n <anna-core-anna-column-date-range-filter\r\n [tableData]=\"tableData\"\r\n [showFilterHeaderTabs]=\"showFilterTooltipTabs\"\r\n [isLurAndCsrComponent]=\"false\"\r\n [clonedTableData]=\"clonedTableData\"\r\n [filterTabObjects]=\"filterTabObjects\"\r\n (filterAppliedToTable)=\"filterApplied($event)\"\r\n (sortingAppliedToTable)=\"sortingApplied($event)\"\r\n (closeTooltip)=\"closeTooltip()\"\r\n >\r\n </anna-core-anna-column-date-range-filter>\r\n</ng-template>\r\n\r\n<!-- Week Picker Template -->\r\n<ng-template #weekPickerToolTip>\r\n <!-- <div class=\"weekpicker-container\">\r\n <anna-core-week-calendar-filter-lib\r\n [week-calendar-config]=\"gtGeneralConfig.multiWeekPickerConfig\"\r\n (apply)=\"applyWeekFilter($event)\"\r\n [from-date]=\"calendarMinEnabledDate\"\r\n [to-date]=\"calendarMaxEnabledDate\"\r\n >\r\n </anna-core-week-calendar-filter-lib>\r\n </div> -->\r\n</ng-template>\r\n\r\n<!-- Time Filter Template -->\r\n<ng-template #timeFilterToolTip>\r\n <anna-core-anna-column-time-filter\r\n [tableData]=\"tableData\"\r\n [showFilterHeaderTabs]=\"showFilterTooltipTabs\"\r\n [isLurAndCsrComponent]=\"false\"\r\n [showAllTimeRangeCheckboxes]=\"showCheckboxesForTimeFilter\"\r\n [clonedTableData]=\"clonedTableData\"\r\n [filterTabObjects]=\"filterTabObjects\"\r\n (filterAppliedToTable)=\"filterApplied($event)\"\r\n (sortingAppliedToTable)=\"sortingApplied($event)\"\r\n (closeTooltip)=\"closeTooltip()\"\r\n >\r\n </anna-core-anna-column-time-filter>\r\n</ng-template>\r\n\r\n<ng-template #columnInfoTooltip>\r\n <p style=\"color: black; white-space: nowrap\">This preemption is rejected and not marked for credit.</p>\r\n</ng-template>\r\n\r\n<ng-template #ratingInfoTooltip>\r\n <p class=\"first-row\">Shows 'Booked Rating' for Preemptions & MakeGood Offered spot(s).</p>\r\n <p class=\"second-row\">Shows 'Projected Rating' for ADU Offered spot(s).</p>\r\n</ng-template>\r\n\r\n<ng-template #impsInfoTooltip>\r\n <p class=\"first-row\">Shows 'Booked IMPS' for Preemptions & MakeGood Offered spot(s).</p>\r\n <p class=\"second-row\">Shows 'Projected IMPS' for ADU Offered spot(s).</p>\r\n</ng-template>\r\n\r\n<ng-template #spotsColumnEquivalizationMessageTooltip>\r\n <p class=\"spot-column-tooltip-message\">\r\n This consists of equivalized spots and un-equivalized Paid Programs & un-equivalized Non-spots.\r\n </p>\r\n</ng-template>\r\n\r\n<ng-template #underDeliveryTooltip>\r\n <p class=\"spot-column-tooltip-message\">\r\n Indicates the Under-delivery percentage based on booked and posted RTG/IMPS.\r\n </p>\r\n</ng-template>\r\n\r\n<ng-template #overDeliveryTooltip>\r\n <p class=\"spot-column-tooltip-message\">\r\n Indicates the Over-delivery percentage based on booked and posted RTG/IMPS.\r\n </p>\r\n</ng-template>\r\n\r\n<ng-template #rateInfoTooltip>\r\n <p class=\"first-row\">Shows 'Booked Rate' for Preemptions & MakeGood Offered spot(s).</p>\r\n <p class=\"second-row\">Shows 'Projected $ Value' for ADU Offered spot(s).</p>\r\n</ng-template>\r\n\r\n<ng-template #sellerHierarchyTooltip>\r\n <ng-container *ngIf=\"sellerGroupHierarchy.length > 0\">\r\n <section class=\"hierarchy-table-container\">\r\n <table class=\"seller-hierarchy-table\">\r\n <thead>\r\n <tr>\r\n <th>#</th>\r\n <th>Inventory Codes</th>\r\n <th>Program/Description</th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let data of sellerGroupHierarchy; let tooltipIndex = index\">\r\n <td>{{ tooltipIndex + 1 }}</td>\r\n <td>\r\n <span showEllipsisTextOnHover>{{ data.InventoryCode }}</span>\r\n </td>\r\n <td>\r\n <span showEllipsisTextOnHover>{{ data.Program }}</span>\r\n </td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n </section>\r\n </ng-container>\r\n <ng-container *ngIf=\"sellerGroupHierarchy.length == 0\">\r\n <span style=\"color: #000\">Seller group not available for this inventory code</span>\r\n </ng-container>\r\n</ng-template>\r\n\r\n<ng-template #lurViolationInfoTooltip>\r\n <p class=\"first-row\">The values are for the entire week.</p>\r\n</ng-template>\r\n\r\n<ng-template #postedRatingDifference>\r\n <p class=\"difference-text\">\r\n The difference between posted and booked average rating is\r\n {{ isDifferenceLessThan25Percent ? \"less\" : \"more\" }} than 25%.\r\n </p>\r\n</ng-template>\r\n\r\n<ng-template #postedImpDifference>\r\n <p class=\"difference-text\">\r\n The difference between posted and booked average impression is\r\n {{ isDifferenceLessThan25Percent ? \"less\" : \"more\" }} than 25%.\r\n </p>\r\n</ng-template>\r\n\r\n<ng-template #ongoingRevBookedColumnTooltip>\r\n <p>The Booked $ value, Spots, GRP, CPP, IMPS, CPM corresponds on the last permanent revision generated</p>\r\n</ng-template>\r\n\r\n<ng-template #completedRevBookedColumnTooltip>\r\n <p>The Booked $ value corresponds on the last permanent revision generated</p>\r\n</ng-template>\r\n\r\n<ng-template #avgBookedRate>\r\n <p>This is the booked average Rate</p>\r\n</ng-template>\r\n\r\n<ng-template #avgBookedRtg>\r\n <p>This is the booked average RTG</p>\r\n</ng-template>\r\n\r\n<ng-template #avgBookedImps>\r\n <p>This is the booked average IMP(\u2019000)</p>\r\n</ng-template>\r\n\r\n<ng-template #projectedImpsRtg>\r\n <p>\r\n All projections are derived from the sum of actual posted information until the last posted date and estimates\r\n for the remaining selected period.\r\n </p>\r\n</ng-template>\r\n\r\n<ng-template #automationTooltip>\r\n <p>\r\n Please get the order business rules approved to activate the order for automation. Only for the\r\n automation-activated orders, any approved MGs, ADUs, or credited spots on ANNA will be fed into the traffic\r\n system i.e. ANNA revisions.\r\n <!-- removed below line as part of enhancmennt in 14.0 releas -->\r\n <!-- Additionally, ANNA will only enter buyer revisions into traffic for the selected\r\n Medialine/WOC orders. -->\r\n </p>\r\n</ng-template>\r\n\r\n<ng-template #rebateImpact>\r\n <p>Rebate impact value is for the originally ordered spot length and is not equivalized.</p>\r\n</ng-template>\r\n\r\n<ng-template #lurViolationTotalRowToolTip>\r\n <ul>\r\n <li>\r\n <strong>POLITICAL RATE VIOLATIONS:</strong>\r\n Violations flagged when non-political spots are booked at a rate lower than the minimum booked rate for\r\n political candidates for the same week, Inventory Code and Revenue Class.\r\n </li>\r\n <li>\r\n <strong>CANDIDATE TO CANDIDATE VIOLATION:</strong>\r\n Violations flagged when political spots are booked at different rates to other political spots for the same\r\n week, Inventory Code and Revenue Class.\r\n </li>\r\n </ul>\r\n</ng-template>\r\n\r\n<ng-template #circularProgressBar>\r\n <circle-progress\r\n [percent]=\"percentDone\"\r\n [radius]=\"5\"\r\n [showTitle]=\"false\"\r\n [showUnits]=\"false\"\r\n [showSubtitle]=\"false\"\r\n [outerStrokeWidth]=\"3\"\r\n [innerStrokeWidth]=\"3\"\r\n [space]=\"-3\"\r\n [outerStrokeColor]=\"'#268bff'\"\r\n [innerStrokeColor]=\"'#d5d5d5'\"\r\n [animationDuration]=\"10\"\r\n ></circle-progress>\r\n</ng-template>\r\n\r\n<ng-template #userLoggedInDetails>\r\n <div class=\"tooltip-div-container\">\r\n <ng-container *ngFor=\"let data of textActionTooltip\">\r\n <span *ngIf=\"data.key != 'read'\">\r\n {{ data.key }} <b> {{ data.value }}</b>\r\n </span>\r\n <span *ngIf=\"data.key == 'read'\">\r\n {{ data.value }}\r\n </span>\r\n </ng-container>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #markAsReadTip>\r\n <div class=\"notification-tooltip-div-container\">\r\n <ng-container *ngFor=\"let data of textActionTooltip\">\r\n {{ data.value }}\r\n </ng-container>\r\n </div>\r\n</ng-template>\r\n\r\n<ng-template #textActionTooltipTemplate>\r\n <ng-container *ngFor=\"let data of textActionTooltip\">\r\n {{ data.key }} <b> {{ data.value }}</b>\r\n </ng-container>\r\n</ng-template>\r\n\r\n<ng-template #tooltipContainingTableTemplate>\r\n <div\r\n *ngIf=\"tooltipContainingTable\"\r\n [innerHTML]=\"tooltipContainingTable.innerHtml\"\r\n class=\"notification-tooltip-div-container\"\r\n >\r\n <!-- <ul>\r\n <li *ngFor=\"let headerMsg of tooltipContainingTable.tableHeaderMsg\">\r\n <b> {{headerMsg}} </b>\r\n </li>\r\n </ul>\r\n\r\n <table class=\"tooltip-table\">\r\n <thead>\r\n <tr>\r\n <th *ngFor=\"let header of tooltipContainingTable.tooltipTableHeader\">\r\n {{ header}}\r\n </th>\r\n </tr>\r\n </thead>\r\n <tbody>\r\n <tr *ngFor=\"let rows of tooltipContainingTable.tooltipTableBody\">\r\n <td *ngFor=\"let data of rows\">\r\n {{ data }}\r\n </td>\r\n </tr>\r\n </tbody>\r\n </table>\r\n\r\n <ul>\r\n <li style=\"margin-top:10px; padding:0\" *ngFor=\"let footerMsg of tooltipContainingTable.tableFooterMsg\">\r\n {{ footerMsg }} \r\n </li>\r\n </ul> -->\r\n </div>\r\n</ng-template>\r\n<!-- <ng-template #textActionTooltipTemplate>\r\n <ng-container *ngFor=\"let data of textActionTooltip\">\r\n {{ data.key }} <b> {{data.value}}</b>\r\n </ng-container>\r\n</ng-template> -->\r\n", styles: [".sort-btn{background:#fff;border:none;border-right:1px solid #1b88ff;text-decoration:underline;font-family:Roboto;font-size:14px;font-weight:400;font-stretch:normal;font-style:normal;line-height:1.07;letter-spacing:normal;color:#1b88ff;cursor:pointer;flex:1;text-align:center}.sort-btn:last-of-type{border-right:none}.sort-btn.active{color:#202b47;text-decoration:none}p.sort-container{margin-top:8px;padding-bottom:8px;border-bottom:1px solid #e6e6e6;margin-bottom:0;display:flex}::ng-deep .tooltip-inner{max-height:22rem;background-color:#fff;border:1px solid white;border-radius:5px;box-shadow:0 2px 2px #0000003d,0 0 2px #0000001f;max-width:251px;width:100%;padding:0!important}::ng-deep .tooltip-inner div.radio-container{flex-wrap:wrap}::ng-deep .md-drppicker{box-shadow:unset!important}::ng-deep .available{color:#999}::ng-deep .bs-tooltip-bottom .arrow:before{border-bottom-color:#fff!important}::ng-deep .bs-tooltip-left .arrow:before{border-left-color:#fff!important}::ng-deep .tooltip.show{opacity:1}.input{text-align:left;margin:5px 10px 5px 5px;display:flex;align-items:center;width:230px;white-space:nowrap}.data{color:#000;font-weight:700;margin-left:5px;margin-right:5px}span.data{display:inline-block;text-overflow:ellipsis;white-space:pre;width:100%;overflow:hidden}.check-box{font-size:14px;cursor:pointer;position:relative;top:-1px}span.mdi-filter.active{color:#000;opacity:1!important;pointer-events:all!important}p{margin-bottom:0;line-height:initial}span.mdi-filter{color:#cbcbcb}::ng-deep .ngx-slider-pointer{top:-5px!important;width:12px!important;height:12px!important;background:#bdbdbd!important;border:1px solid #ffffff!important;box-shadow:0 1px 3px #0000004d!important;border-radius:16px!important}input:focus{outline:none}input::placeholder{color:#c8c8c8}.cancel-btn{background:#c7e1ff;color:#268bff}.apply-btn{background:#268bff;color:#fff;margin-left:.3125rem}div.radio-container{display:flex;white-space:nowrap;justify-content:space-between;background-color:#f4f4f4;border-radius:.125rem;margin:.4375rem .4375rem .25rem}div.radio-container div{flex:1;width:50%}div.radio-container div.full-width{width:100%}div.radio-container input{position:relative;top:.125rem;margin-right:.25rem}div.radio-container label{font-family:Roboto;font-size:.875rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:1.29;letter-spacing:0;color:#4a4a4a;margin:0;padding-left:.125rem}div.radio-container label:first-of-type{margin-right:.188rem}div.radio-container input[type=radio]{appearance:none;display:inline-block;width:.9375rem;height:.9375rem;padding:.125rem;background-clip:content-box;border:.125rem solid #268bff;background-color:transparent;border-radius:50%}div.radio-container input[type=radio]:checked{background-color:#268bff}.checkbox-filter-buttons-container{padding:0 8px!important}.buttons-container{display:flex;margin:0px auto .4375rem;justify-content:center;padding:0 12px}.buttons-container .button{padding:0 10px;width:100%;margin:8px 0 0;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.buttons-container button:last-of-type{background-color:#268bff;color:#fff;margin-left:.5rem}.buttons-container button.disabled{background:#bdbdbd;opacity:.5;color:#4a4a4a}.button{display:inline-block;margin:8px 4px 0 8px;padding:0 16px;border-radius:4px;text-align:center;outline:none;font-family:Roboto;font-size:.75rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:1.67;letter-spacing:normal;border:none;color:#268bff;background-color:#e5f1ff}.search-box{display:flex;align-items:center;color:#c8c8c8;border:1px solid #e6e6e6;border-radius:.125rem;margin:.25rem .4375rem .188rem;height:1.5rem;padding:.188rem 8px .188rem .5rem}.search-box .search-bar-close{margin-left:auto;float:right}.search-icon{margin:0 4px 0 0;font-size:1.125rem;color:#9b9b9b}.filter-icon{justify-content:right;margin-left:auto;color:#d4d4d4;color:#a1a1a1;font-size:16px;cursor:pointer}.data{margin:0 13px 0 8px;font-family:Roboto;font-size:.875rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:1.86;letter-spacing:\"\";color:#4a4a4a}.search-input{margin:1px 0 1px 4px;font-family:Roboto;font-size:.875rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal;color:#c8c8c8;width:calc(100% - 38px)}.check-box{color:#268bff}.tooltip-data-container{overflow-y:scroll;max-height:8rem}.searchbar{width:100%;display:flex;justify-content:flex-end;align-items:flex-end}.clear-button{opacity:.5;font-family:Roboto;font-size:.9375rem;font-weight:500;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal;text-decoration:underline;border:none;background-color:#fff;color:#4a4a4a;margin-left:.625rem;padding:0}.clear-button:focus{outline:none;box-shadow:none}.unchecked{color:#268bff}cdk-virtual-scroll-viewport.dropdown-data-container{max-height:12.3rem;width:100%;overflow-y:auto;overflow-x:hidden}cdk-virtual-scroll-viewport.dropdown-data-container p.input{margin-left:0}cdk-virtual-scroll-viewport.dropdown-data-container p.input span.mi{padding-left:.4375rem}cdk-virtual-scroll-viewport.dropdown-data-container p.input:hover{background-color:#ebebeb;cursor:pointer}cdk-virtual-scroll-viewport.dropdown-data-container::-webkit-scrollbar{width:.188rem}cdk-virtual-scroll-viewport.dropdown-data-container::-webkit-scrollbar-thumb{color:#d3d3d3;background:#d3d3d3}section.min-maxContainer{display:flex;justify-content:center;margin-bottom:-.125rem;margin-top:.5rem;width:100%}section.min-maxContainer input{width:30%;height:1.875rem;border:1px solid lightgray;color:gray}section.min-maxContainer span{display:inline-block;padding-left:.5rem;padding-right:.5rem;position:relative;top:.3125rem;color:#666}.time-container{width:100%;display:flex;padding:0 .75rem}.time-container input.form-control:disabled{background-color:#fff;width:2.813rem}.time-container input.numberInput:focus{box-shadow:none;border-color:#c2cfd6}.time-container .dot{color:#cbcbcb;position:relative;left:-7px;font-size:17px}.time-container div.arrow-container{flex-direction:column;display:flex;margin-top:.375rem;width:9px;height:18px;margin-right:1.1875rem}.time-container div.arrow-container i{color:#000;cursor:pointer;max-height:9px;font-size:25px;width:10px}.time-container div.arrow-container i:before{width:0;height:0;pointer-events:none;position:relative;left:-9px;top:-11px}.mdi-filter{cursor:pointer}.time-label-container{display:flex;justify-content:flex-start}.time-label-container label{margin-bottom:0;color:#4a4a4a;margin-top:.125rem;margin-left:.625rem;font-weight:700}.time-heading{color:#000;font-size:.8125rem;text-align:left;padding-left:.625rem;margin-top:.625rem;font-weight:700}.column-clear-all{width:94%;text-align:center;border:none;font-size:14px;background:none;text-decoration:underline;color:#268bff}.checkbox-container{display:flex;padding-inline:.625rem}.checkbox-container .data{text-align:left}.checkbox-container:first-of-type{margin-top:.625rem;font-weight:500}.column-clear-all{width:94%;text-align:center;border:none;background:none;text-decoration:underline;color:#268bff}.column-clear-all:disabled{opacity:.5;color:#4a4a4a;font-weight:400}.column-clear-all.align-center{text-align:center}span.mdi-filter-variant.disabled{pointer-events:none;opacity:.5}.datepicker-container{width:100%}span.mdi-filter-variant{color:#cbcbcb;cursor:pointer;font-size:.875rem}span.mdi-filter-variant.active{color:#000}p.filter-tab{font-family:Roboto;font-size:14px;font-weight:400;font-stretch:normal;font-style:normal;line-height:1.29;letter-spacing:normal;color:#1b88ff;border-radius:5px;background-color:#f4f4f4;padding-inline:8px;cursor:pointer;overflow:hidden;text-align:center;text-overflow:ellipsis}p.filter-tab.active{color:#fff;background-color:#1b88ff}button.filter-text-btn{background:#fff;text-decoration:underline;font-family:Roboto;font-size:14px;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal;border:none;color:#268bff;margin-inline:4px;margin-top:2px}button.filter-text-btn:disabled{color:#b1b1b1;cursor:not-allowed}::ng-deep .non-edit-datepicker-tooltip .tooltip-inner{max-width:310px!important;width:283px!important;overflow-y:initial!important;padding:0!important}input.slider-text::-webkit-outer-spin-button,input.slider-text::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input.slider-text{-moz-appearance:textfield}input.slider-text.red-border{border:1px solid #f44336!important}::ng-deep .checkbox-sort p.sort-container{margin-top:8px!important;padding-bottom:8px!important}i.mdi-close{cursor:pointer}i.mdi-close.disable-close-icon{pointer-events:none;cursor:not-allowed}input.error-border{border:1px solid #f44336!important}::ng-deep .non-edit-checkbox-tooltip .tooltip-inner{width:238px!important;padding:0!important}::ng-deep .non-edit-slider-tooltip .tooltip-inner{width:238px!important;padding:0!important}::ng-deep .non-edit-time-tooltip .tooltip-inner{width:250px!important;padding:0!important}::ng-deep .non-edit-time-tooltip.bs-tooltip-start{padding:.4rem}::ng-deep .non-edit-time-tooltip.bs-tooltip-start .tooltip-arrow{right:0;top:5px!important;width:var(--bs-tooltip-arrow-height);height:var(--bs-tooltip-arrow-width)}::ng-deep .non-edit-time-tooltip.bs-tooltip-start .tooltip-arrow:before{border-left-color:#fff;left:-1px;border-width:calc(var(--bs-tooltip-arrow-width) * .5) 0 calc(var(--bs-tooltip-arrow-width) * .5) var(--bs-tooltip-arrow-height)}::ng-deep .no-bottom-border p.sort-container{border-bottom:none!important}::ng-deep .ngx-slider-pointer-min:after{display:none}::ng-deep .ngx-slider-pointer-max:after{display:none}::ng-deep .ngx-slider span.ngx-slider-pointer{width:12px;height:12px;top:-5px;background-color:#bdbdbd}::ng-deep .ngx-slider span.ngx-slider-bar{height:3px;background:#ededed}::ng-deep .ngx-slider span.ngx-slider-selection{background:#bdbdbd}::ng-deep .ngx-slider span.ngx-slider-bubble{bottom:-22px;font-size:12px;color:#333}::ng-deep .show-min.ngx-slider span.ngx-slider-model-value{background:#fff;box-shadow:0 6px 10px #0000004d,0 2px 2px #0003}::ng-deep .show-max.ngx-slider span.ngx-slider-model-high{background:#fff;box-shadow:none}::ng-deep .ngx-slider span.ngx-slider-combined{background:#fff;box-shadow:0 6px 10px #0000004d,0 2px 2px #0003}::ng-deep .ngx-slider{top:10px!important;margin:5px 0 2px!important}::ng-deep .ngx-slider-animate{top:0!important}.sidebar-slider{margin-bottom:35px!important;margin-left:5px;margin-right:5px}.slider-placeholder{height:14px}::ng-deep .filter-calendar select.form-select:focus{border-color:#c2cfd6;box-shadow:none}::ng-deep .filter-calendar select.form-select{background-color:#fff}.no-data-case{padding-left:.4375rem!important;font-size:.875rem!important;margin-top:10px!important;cursor:pointer}.check-mark,.unread-mark{cursor:pointer}.on-hover:hover .unread-mark,.notificationHover .check-mark{opacity:0;cursor:pointer}.on-hover:hover .check-mark{opacity:1;cursor:pointer}:host ::ng-deep .gt{table-layout:fixed;margin-bottom:0;width:100%}:host ::ng-deep .gt th,:host ::ng-deep .gt td{padding:2px 8px;line-height:normal}:host ::ng-deep .gt thead tr th .upper-label{font-family:Roboto;font-size:.6875rem;font-weight:500;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:.3px;color:#4a4a4a;margin-bottom:0}:host ::ng-deep .gt thead tr th .lower-label{font-family:Roboto;font-size:.6875rem;font-weight:500;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:.3px;color:#a7a7a7;margin-bottom:0}:host ::ng-deep .gt thead tr th{background-color:#ededed;position:sticky;position:-webkit-sticky;top:0;border-top:none!important;border-bottom:none!important;outline:none!important;box-shadow:inset 0 1px #d4d4d4,inset 0 -1px #d4d4d4,inset -1px 0 #d4d4d4}:host ::ng-deep .gt thead tr th br{display:block;content:\"\";margin-top:-8px}:host ::ng-deep .gt thead tr th div.row{display:flex;flex-wrap:nowrap;justify-content:space-between;align-items:center;width:max-content}:host ::ng-deep .gt thead tr th div.sort-filter-container{display:flex;flex-wrap:nowrap;align-items:center;margin-left:.25rem;margin-right:auto}:host ::ng-deep .gt thead tr th span.mdi-filter-variant{font-size:13px!important;top:-1px!important;position:relative}:host ::ng-deep .gt thead tr th:first-of-type{box-shadow:inset 0 1px #d4d4d4,inset 0 -1px #d4d4d4,inset -1px 0 #d4d4d4,inset 1px 0 #d4d4d4}:host ::ng-deep .gt tbody tr td:first-of-type{box-shadow:inset 1px 0 #d4d4d4,inset -1px 0 #d4d4d4,inset 0 -1px #d4d4d4;border:none}:host ::ng-deep .gt tbody tr td:nth-of-type(n+2){box-shadow:inset -1px 0 #d4d4d4,inset 0 -1px #d4d4d4;border:none}:host ::ng-deep .gt tbody tr td .upper-label{font-family:Roboto;font-size:.75rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:0px;color:#000;display:inline-block;width:90%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}:host ::ng-deep .gt tbody tr td .lower-label{font-family:Roboto;font-size:.75rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:0px;color:#a7a7a7;display:inline-block;width:90%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}:host ::ng-deep .gt tbody tr br{display:block;content:\"\";margin-top:-8px}:host ::ng-deep .gt tbody tr:nth-of-type(1) td{border-top:none!important}:host ::ng-deep .gt .custom-column-checkbox-checked,:host ::ng-deep .gt .custom-column-checkbox-unchecked{font-size:.875rem;cursor:pointer}:host ::ng-deep .gt .custom-column-checkbox-checked{color:#268bff}:host ::ng-deep .gt .custom-column-checkbox-unchecked{color:#4a4a4a}:host ::ng-deep .bottom-border .gt tbody tr:last-of-type td:first-of-type{box-shadow:inset 1px 0 #d4d4d4,inset -1px 0 #d4d4d4}:host ::ng-deep .bottom-border .gt tbody tr:last-of-type td:nth-of-type(n+2){box-shadow:inset -1px 0 #d4d4d4}.table-container{overflow-x:auto;overflow-y:auto}.rowSelectCheckbox,#selectAllRowsCheckbox{cursor:pointer}.disable-checkbox{color:#dedede!important;pointer-events:none!important}.mdi-warning{color:#f3c639;font-size:16px;line-height:28px}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{opacity:1}.redcolor-status{color:#c62a2a}#no-filter-space{width:.875rem}::ng-deep .mat-button-toggle-appearance-standard .mat-button-toggle-label-content{line-height:1.875rem!important;width:2.625rem;padding:0 .625rem}input.numberInput{margin-right:-.8125rem;padding:0 0 0 .625rem;height:1.875rem}::ng-deep .mat-button-toggle-checked{background-color:#268bff!important;color:#fff!important}::ng-deep .mat-button-toggle-group-appearance-standard{border-radius:0}.hidden{display:none}.no-data-div{margin-top:2.5px}.no-data-div label{margin:0;width:auto;font-weight:500;background-color:#d3d3d3;padding:.3125rem 1.125rem;border-radius:.25rem}.column-values:nth-of-type(2){color:#a7a7a7!important}.custom-column-checkbox-checked,.custom-column-checkbox-unchecked{font-size:.875rem;cursor:pointer}.custom-column-checkbox-checked{color:#268bff}.custom-column-checkbox-unchecked{color:#4a4a4a}.time-filter-checkboxes>div>p{color:#151b1e}::ng-deep .margin-bottom-zero .mat-radio-label{margin-bottom:0}:host ::ng-deep mat-radio-group br{margin-top:0!important}:host ::ng-deep mat-radio-group mat-radio-button .mdc-radio__background{width:var(--mat-radio-size);height:var(--mat-radio-size)}:host ::ng-deep mat-radio-group mat-radio-button .mdc-radio__inner-circle{border-width:calc(var(--mat-radio-size) / 2)}:host ::ng-deep mat-radio-group mat-radio-button .mdc-form-field>label{margin:0 0 0 4px;padding:0;top:-2px;position:relative}:host ::ng-deep mat-radio-group mat-radio-button .mdc-radio--disabled+label{color:var(--primary-text-color-dark)!important}:host ::ng-deep mat-radio-group mat-radio-button.mat-mdc-radio-button .mdc-form-field .mdc-radio{padding:0}:host ::ng-deep mat-radio-group mat-radio-button .mdc-form-field>label{left:-94px;font-size:12px;color:#4a4a4a;position:relative}::ng-deep .reject.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-outer-circle{border-color:#ff0}::ng-deep .reject.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-inner-circle{background-color:#ff0}::ng-deep .resubmit.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-outer-circle{border-color:#ff0}::ng-deep .resubmit.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-inner-circle{background-color:#ff0}::ng-deep .noAction.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-outer-circle{border-color:green}::ng-deep .noAction.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-inner-circle{background-color:green}::ng-deep .approve.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-outer-circle{border-color:green}::ng-deep .approve.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-inner-circle{background-color:green}::ng-deep .credit.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-outer-circle{border-color:red}::ng-deep .credit.mat-radio-button.mat-accent.mat-radio-checked .mat-radio-inner-circle{background-color:red}::ng-deep .mat-radio-button.mat-radio-disabled .mat-radio-outer-circle{border-color:#00000061!important}::ng-deep .mat-radio-button.mat-radio-disabled.mat-radio-checked .mat-radio-inner-circle{background-color:#00000061!important}::ng-deep tr.white-background-row{background:#fff}::ng-deep tr.gray-background-row{background:#e9e9e980!important}.remarks-tooltip,.mdi-information,.mdi-information-outline,.seller-tooltip{font-size:.875rem;color:#268bff;position:relative;top:.1875rem;cursor:pointer}.seller-tooltip{top:-1px;float:right}::ng-deep .remarks-info-tooltip .tooltip-inner{max-width:19.25rem!important}.rating-icon,.lur-violation-icon{color:#268bff;cursor:pointer;position:relative;left:-2px}::ng-deep .rating-info-tooltip .tooltip-inner{max-width:800px!important}.spots-info-icon{color:#268bff;cursor:pointer;margin:1px 2px 0 -14px}.spots-info-icon-ol{color:#268bff;cursor:pointer;margin:1px 4px 0 -2px}::ng-deep .spot-info-tooltip .tooltip-inner{position:relative;max-width:220px!important;background:#fff;word-break:break-word;display:flex}::ng-deep .spot-info-tooltip-for-orderlisting-table .tooltip-inner{max-width:220px!important;background:#fff;word-break:break-word;display:flex}p.first-row{padding:.5rem .5rem 0;color:#000;white-space:nowrap;text-align:left}p.second-row{padding:2px .5rem .5rem;color:#000;white-space:nowrap;text-align:left}::ng-deep .gt-total-row-tooltip{opacity:1!important}::ng-deep .gt-total-row-tooltip .tooltip-inner{color:#000;box-shadow:0 6px 10px #0000004d,0 2px 2px #0003;background-color:#fff;padding:4px!important;width:100%;border-radius:2px!important}::ng-deep .gt-total-row-tooltip .arrow:before{border-top-color:#fff!important}.info-label{margin-left:4px;color:#268bff;vertical-align:text-top}::ng-deep .hierarchy-tooltip{max-width:-moz-fit-content;max-width:fit-content;width:310px!important}::ng-deep .hierarchy-tooltip .tooltip-inner{padding:4px!important;max-width:22.75rem;max-height:11.25rem}table.seller-hierarchy-table{table-layout:fixed}table.seller-hierarchy-table tr th{font-family:Roboto;font-size:.75rem;font-weight:500;font-stretch:normal;font-style:normal;line-height:1.67;letter-spacing:normal;color:#5e5e5e;white-space:nowrap;background:#ededed;position:sticky;box-shadow:inset 0 1px #d4d4d4;top:0;z-index:1}table.seller-hierarchy-table tr th:nth-child(1){width:20px}table.seller-hierarchy-table tr th:first-of-type,table.seller-hierarchy-table tr td:first-of-type{width:20px;border-left:1px solid #d4d4d4}table.seller-hierarchy-table tr th:last-of-type,table.seller-hierarchy-table tr td:last-of-type{border-right:1px solid #d4d4d4;width:7.875rem!important}table.seller-hierarchy-table tr th:nth-of-type(2){width:7.75rem!important}table.seller-hierarchy-table tr td{font-family:Roboto;font-size:.75rem;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal;color:#4a4a4a;box-shadow:none!important;border-top:1px solid #d4d4d4;border-bottom:1px solid #d4d4d4}table.seller-hierarchy-table tr td:nth-of-type(2),table.seller-hierarchy-table tr td:nth-of-type(3){padding-top:.25rem}table.seller-hierarchy-table tr td span{display:inline-block;width:90%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;position:relative}section.hierarchy-table-container{max-height:8.75rem;overflow:auto}section.hierarchy-table-container::-webkit-scrollbar-track{margin-top:1.5rem}.difference-text{padding:.5rem;color:#000;text-align:left}::ng-deep .posted-avg-tooltip .tooltip-inner{width:13.8125rem!important}::ng-deep .drrBooked-info-tooltip{transform:translate(26px,6px)}::ng-deep .drrBooked-info-tooltip .tooltip-inner{max-width:307px!important;width:242px!important;background:#fff;word-break:break-word;display:flex;padding:4px!important;text-align:left}::ng-deep .drrBooked-info-tooltip .tooltip-inner p{color:#000}::ng-deep .drrBooked-info-tooltip .arrow:before{border-right-color:#fff!important}.clickable-data{cursor:pointer;color:#268bff!important;display:flex!important;align-items:center}.clickable-data .spot-details-download-icons{font-size:12px}.disabled-clickable-data{pointer-events:none;color:#d4d4d4!important}.spot-column-tooltip-message{color:#000;width:max-content;text-align:left}div.spinner-for-button-directive{position:relative;left:-1px}.clickable-row table tr.mat-row td{cursor:pointer!important}.tooltip-div-container{text-align:left!important;padding:12px 4px;color:#4a4a4a!important;font-size:12px!important;font-family:Roboto;font-size:12px;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}.notification-tooltip-div-container{text-align:left!important;padding:6px 8px;color:#4a4a4a!important;font-size:12px!important;font-family:Roboto;font-size:12px;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}.mdi-information,.mdi-information-outline{left:3px;top:1px}.mdi-information-outline{position:static}::ng-deep .team-user-tooltip.bs-tooltip-top .arrow:before{border-top:6px solid white}::ng-deep .team-user-tooltip.bs-tooltip-left .arrow:before{border-left:6px solid white}::ng-deep .team-user-tooltip.bs-tooltip-bottom .arrow:before{border-bottom:6px solid white}::ng-deep .team-user-tooltip.bs-tooltip-right .arrow:before{border-right:5px solid white}::ng-deep .team-user-tooltip .tooltip-inner{opacity:1!important;width:-moz-fit-content!important;width:fit-content!important;max-width:520px;border-radius:2px;padding:0 4px!important}::ng-deep .team-user-tooltip .tooltip-inner .tooltip-inner{color:#4a4a4a;text-align:left;padding:8px!important;border-radius:2px;background:#fff!important;box-shadow:0 6px 10px #0000004d,0 2px 2px #0003;font-family:Roboto;font-size:12px;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}::ng-deep .team-user-tooltip .tooltip-inner.bs-tooltip-top .arrow:before{border-top:6px solid white}::ng-deep .team-user-tooltip .tooltip-inner.bs-tooltip-left .arrow:before{border-left:6px solid white}::ng-deep .team-user-tooltip .tooltip-inner.bs-tooltip-bottom .arrow:before{border-bottom:6px solid white}::ng-deep .team-user-tooltip .tooltip-inner.bs-tooltip-right .arrow:before{border-right:5px solid white}::ng-deep .gt-icon-column-tooltip{opacity:1!important}::ng-deep .gt-icon-column-tooltip .tooltip-inner{color:#4a4a4a;text-align:left;padding:8px!important;border-radius:2px;background:#fff!important;box-shadow:0 6px 10px #0000004d,0 2px 2px #0003;font-family:Roboto;font-size:12px;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}::ng-deep .gt-icon-column-tooltip.bs-tooltip-top .arrow:before{border-top:6px solid white}::ng-deep .gt-icon-column-tooltip.bs-tooltip-left .arrow:before{border-left:6px solid white}::ng-deep .gt-icon-column-tooltip.bs-tooltip-bottom .arrow:before{border-bottom:6px solid white}::ng-deep .gt-icon-column-tooltip.bs-tooltip-right .arrow:before{border-right:5px solid white}::ng-deep .gt-icon-column-tooltip .tooltip-inner{width:100%}::ng-deep .tooltip-containing-table{opacity:1!important}::ng-deep .tooltip-containing-table .tooltip-inner{color:#4a4a4a;text-align:left;padding:8px!important;border-radius:2px;background:#fff!important;box-shadow:0 6px 10px #0000004d,0 2px 2px #0003;font-family:Roboto;font-size:12px;font-weight:400;font-stretch:normal;font-style:normal;line-height:normal;letter-spacing:normal}::ng-deep .tooltip-containing-table.bs-tooltip-top .arrow:before{border-top:6px solid white}::ng-deep .tooltip-containing-table.bs-tooltip-left .arrow:before{border-left:6px solid white}::ng-deep .tooltip-containing-table.bs-tooltip-bottom .arrow:before{border-bottom:6px solid white}::ng-deep .tooltip-containing-table.bs-tooltip-right .arrow:before{border-right:5px solid white}::ng-deep .tooltip-containing-table li{margin:0!important;padding:0!important}::ng-deep .tooltip-containing-table ul{margin:0!important;padding-left:8px!important}::ng-deep .tooltip-containing-table .tooltip-inner{width:100%;max-width:230px}table.tooltip-table{table-layout:fixed;margin:4px 0 0;width:100%}table.tooltip-table th,table.tooltip-table td{padding:2px 8px;line-height:normal}table.tooltip-table thead tr th:first-of-type{box-shadow:inset 0 1px #d4d4d4,inset 0 -1px #d4d4d4,inset -1px 0 #d4d4d4,inset 1px 0 #d4d4d4!important;border:none}table.tooltip-table thead tr th{color:#5e5e5e!important;font-size:12px;font-weight:500;font-family:Roboto;line-height:1.67;background-color:#ededed;border-top:none!important;border-bottom:none!important;outline:none!important;box-shadow:inset 0 1px #d4d4d4,inset 0 -1px #d4d4d4,inset -1px 0 #d4d4d4}table.tooltip-table thead tr th div.row{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center}table.tooltip-table tbody tr td{color:#5e5e5e!important;font-size:12px;font-weight:500;font-family:Roboto;line-height:1.67}table.tooltip-table tbody tr td:first-of-type{box-shadow:inset 1px 0 #d4d4d4,inset -1px 0 #d4d4d4,inset 0 -1px #d4d4d4;border:none}table.tooltip-table tbody tr td:nth-of-type(n+2){box-shadow:inset -1px 0 #d4d4d4,inset 0 -1px #d4d4d4;border:none}.bottom-border{border-bottom:1px solid #d4d4d4!important}i.disabled{pointer-events:none!important}\n"] }]
775
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.AnnaSortService }, { type: i2.AnnaDateTimeFormatService }, { type: i3.AnnaFilterService }]; }, propDecorators: { showSkeletonLoading: [{
776
+ type: Input
777
+ }], tableHeaders: [{
778
+ type: Input
779
+ }], tableData: [{
780
+ type: Input
781
+ }], clonedTableData: [{
782
+ type: Input
783
+ }], gtGeneralConfig: [{
784
+ type: Input
785
+ }], totalRowInfo: [{
786
+ type: Input
787
+ }], gtDimension: [{
788
+ type: Input
789
+ }], tableClass: [{
790
+ type: Input
791
+ }], maximumRowsWhichCanBeRenderedWithoutScroll: [{
792
+ type: Input
793
+ }], fixNumberOfRowsForPopup: [{
794
+ type: Input
795
+ }], limit: [{
796
+ type: Input
797
+ }], includeBorderInTableHeight: [{
798
+ type: Input
799
+ }], downloadInProgress: [{
800
+ type: Input
801
+ }], percentDone: [{
802
+ type: Input
803
+ }], starredInProgress: [{
804
+ type: Input
805
+ }], clickableRow: [{
806
+ type: Input
807
+ }], setTableHeightWhenRowSizeIsFixed: [{
808
+ type: Input
809
+ }], tableBorderBottomClassRequired: [{
810
+ type: Input
811
+ }], hideSomeTds: [{
812
+ type: Input
813
+ }], tdsHaveRowSpan: [{
814
+ type: Input
815
+ }], multipleTablesPresent: [{
816
+ type: Input
817
+ }], toggleCheckbox: [{
818
+ type: Output
819
+ }], toggleRowCheckbox: [{
820
+ type: Output
821
+ }], toggleHeaderCheckbox: [{
822
+ type: Output
823
+ }], undoIconClicked: [{
824
+ type: Output
825
+ }], filterAppliedToTable: [{
826
+ type: Output
827
+ }], sortingAppliedToTable: [{
828
+ type: Output
829
+ }], rowClicked: [{
830
+ type: Output
831
+ }], radioButtonSelected: [{
832
+ type: Output
833
+ }], columnFilterOpened: [{
834
+ type: Output
835
+ }], columnFilterClosed: [{
836
+ type: Output
837
+ }], gtIconClicked: [{
838
+ type: Output
839
+ }], gtSVGIconClicked: [{
840
+ type: Output
841
+ }], gtTextActionClicked: [{
842
+ type: Output
843
+ }], gtViewDetailClicked: [{
844
+ type: Output
845
+ }], gtInnerHTMLClicked: [{
846
+ type: Output
847
+ }], downloadSpotDetails: [{
848
+ type: Output
849
+ }], clickableDataClicked: [{
850
+ type: Output
851
+ }], totalRowIconClicked: [{
852
+ type: Output
853
+ }], notificationIconHover: [{
854
+ type: Output
855
+ }], notificationIconHoverLeave: [{
856
+ type: Output
857
+ }], editableInputEdited: [{
858
+ type: Output
859
+ }], radioButtonMessageIconClicked: [{
860
+ type: Output
861
+ }], viewChildTableHeaders: [{
862
+ type: ViewChildren,
863
+ args: ['tableHeader']
864
+ }] } });
865
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"anna-non-editable-generic-table.component.js","sourceRoot":"","sources":["../../../../../../../projects/anna-core/src/lib/anna-generic-table-lib/components/anna-non-editable-generic-table/anna-non-editable-generic-table.component.ts","../../../../../../../projects/anna-core/src/lib/anna-generic-table-lib/components/anna-non-editable-generic-table/anna-non-editable-generic-table.component.html"],"names":[],"mappings":"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","sourcesContent":["// Angular import statements\r\nimport {\r\n    Component,\r\n    OnInit,\r\n    Input,\r\n    ViewChildren,\r\n    QueryList,\r\n    Output,\r\n    EventEmitter,\r\n    SimpleChanges,\r\n    OnChanges,\r\n    ChangeDetectorRef,\r\n    ElementRef,\r\n    AfterViewChecked,\r\n    ChangeDetectionStrategy,\r\n} from '@angular/core';\r\n\r\n// Third party import statements\r\nimport { cloneDeep, isEqual, uniq } from 'lodash-es';\r\n\r\n//sub-entries of anna lib import statement\r\nimport {\r\n    IGtGeneralConfig,\r\n    IGtTableHeader,\r\n    IHeaderInfo,\r\n    ITotalRowInfo,\r\n} from '../../../anna-core-shared-lib/models/anna-non-editable-gt-models';\r\nimport { AnnaDateTimeFormatService } from '../../../anna-core-shared-lib/services/anna-date-time-format.service';\r\nimport { IWeekCalendar } from '../../../anna-core-shared-lib/models/anna-global-dropdown-config.model';\r\nimport {\r\n    GtColumnIconEmittedData,\r\n    RatingSellerGroupHierarchy,\r\n} from '../../../anna-core-shared-lib/models/anna-generic-data-type.model';\r\nimport { radioButtonModel } from '../../../anna-core-shared-lib/models/anna-tooltip.model';\r\nimport { AnnaSortService } from '../../../anna-core-shared-lib/services/anna-sort.service';\r\nimport { AnnaFilterService } from '../../../anna-core-shared-lib/services/anna-filter.service';\r\nimport { BehaviorSubject } from 'rxjs';\r\nimport { NgCircleProgressModule } from 'ng-circle-progress';\r\nimport { AnnaColumnTimeFilterComponent } from '../anna-column-filters/anna-column-time-filter/anna-column-time-filter.component';\r\nimport { AnnaColumnDateRangeFilterComponent } from '../anna-column-filters/anna-column-date-range-filter/anna-column-date-range-filter.component';\r\nimport { AnnaColumnSliderFilterComponent } from '../anna-column-filters/anna-column-slider-filter/anna-column-slider-filter.component';\r\nimport { AnnaColumnCheckboxFilterComponent } from '../anna-column-filters/anna-column-checkbox-filter/anna-column-checkbox-filter.component';\r\nimport { AnnaNoDataComponent } from '../../../anna-core-shared-lib/components/anna-no-data/anna-no-data.component';\r\nimport { MatRadioModule } from '@angular/material/radio';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { AnnaIconColumnComponent } from '../../../anna-core-shared-lib/components/anna-icon-column/anna-icon-column.component';\r\nimport { showEllipsisTextOnHoverDirective } from '../../../anna-core-shared-lib/directives/show-ellipsis-text/show-ellipsis-text.directive';\r\nimport { NgxSkeletonLoaderModule } from 'ngx-skeleton-loader';\r\nimport { NgbTooltip } from '@ng-bootstrap/ng-bootstrap';\r\nimport { MatTableModule } from '@angular/material/table';\r\nimport {\r\n    NgClass,\r\n    NgStyle,\r\n    NgFor,\r\n    NgIf,\r\n    NgTemplateOutlet,\r\n    NgSwitch,\r\n    NgSwitchCase,\r\n    NgSwitchDefault,\r\n    AsyncPipe,\r\n} from '@angular/common';\r\n\r\ninterface keyValueTooltipType {\r\n    key: string;\r\n    value: string;\r\n}\r\ninterface tableTooltipType {\r\n    tooltipTableHeader: string[];\r\n    tooltipTableBody: string[][];\r\n    tableHeaderMsg: string[];\r\n    tableFooterMsg: string[];\r\n    innerHtml: string;\r\n}\r\n\r\n@Component({\r\n    selector: 'anna-core-non-editable-generic-table-lib',\r\n    templateUrl: './anna-non-editable-generic-table.component.html',\r\n    styleUrls: ['./anna-non-editable-generic-table.component.scss'],\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    standalone: true,\r\n    imports: [\r\n        NgClass,\r\n        NgStyle,\r\n        MatTableModule,\r\n        NgFor,\r\n        NgIf,\r\n        NgTemplateOutlet,\r\n        NgbTooltip,\r\n        NgxSkeletonLoaderModule,\r\n        showEllipsisTextOnHoverDirective,\r\n        NgSwitch,\r\n        NgSwitchCase,\r\n        AnnaIconColumnComponent,\r\n        FormsModule,\r\n        MatRadioModule,\r\n        NgSwitchDefault,\r\n        AnnaNoDataComponent,\r\n        AnnaColumnCheckboxFilterComponent,\r\n        AnnaColumnSliderFilterComponent,\r\n        AnnaColumnDateRangeFilterComponent,\r\n        AnnaColumnTimeFilterComponent,\r\n        NgCircleProgressModule,\r\n        AsyncPipe,\r\n    ],\r\n})\r\nexport class AnnaNonEditableGenericTableComponent implements OnInit, OnChanges, AfterViewChecked {\r\n    @Input() showSkeletonLoading: boolean;\r\n    @Input() tableHeaders: IGtTableHeader[];\r\n    @Input() tableData: any[];\r\n    @Input() clonedTableData: any[];\r\n    @Input() gtGeneralConfig: IGtGeneralConfig;\r\n    @Input() totalRowInfo?: ITotalRowInfo[];\r\n    @Input() gtDimension: {\r\n        rowHeight: number;\r\n        headerHeight: number;\r\n        dataOnTopHeight: number;\r\n        marginFromBottom: number;\r\n        tableHeight?: string;\r\n    };\r\n    @Input() tableClass: string;\r\n    @Input() maximumRowsWhichCanBeRenderedWithoutScroll: number = 5;\r\n    @Input() fixNumberOfRowsForPopup: boolean = false;\r\n    @Input() limit: number = 30;\r\n    @Input() includeBorderInTableHeight: boolean = true;\r\n    @Input() downloadInProgress: boolean;\r\n    @Input() percentDone: number;\r\n    @Input() starredInProgress: boolean;\r\n    @Input() clickableRow: boolean = false;\r\n    @Input() setTableHeightWhenRowSizeIsFixed: boolean = true;\r\n    @Input() tableBorderBottomClassRequired: boolean = true;\r\n    @Input() hideSomeTds: boolean = false;\r\n    @Input() tdsHaveRowSpan: boolean = false;\r\n    @Input() multipleTablesPresent: boolean = false;\r\n\r\n    @Output() toggleCheckbox = new EventEmitter();\r\n    @Output() toggleRowCheckbox = new EventEmitter();\r\n    @Output() toggleHeaderCheckbox = new EventEmitter();\r\n    @Output() undoIconClicked = new EventEmitter();\r\n    @Output() filterAppliedToTable = new EventEmitter();\r\n    @Output() sortingAppliedToTable = new EventEmitter();\r\n    @Output() rowClicked = new EventEmitter();\r\n    @Output() radioButtonSelected = new EventEmitter();\r\n    @Output() columnFilterOpened = new EventEmitter();\r\n    @Output() columnFilterClosed = new EventEmitter();\r\n    @Output() gtIconClicked = new EventEmitter();\r\n    @Output() gtSVGIconClicked = new EventEmitter();\r\n    @Output() gtTextActionClicked = new EventEmitter();\r\n    @Output() gtViewDetailClicked = new EventEmitter();\r\n    @Output() gtInnerHTMLClicked = new EventEmitter();\r\n    @Output() downloadSpotDetails = new EventEmitter();\r\n    @Output() clickableDataClicked = new EventEmitter();\r\n    @Output() totalRowIconClicked = new EventEmitter();\r\n    @Output() notificationIconHover = new EventEmitter();\r\n    @Output() notificationIconHoverLeave = new EventEmitter();\r\n    @Output() editableInputEdited = new EventEmitter();\r\n    @Output() radioButtonMessageIconClicked = new EventEmitter();\r\n\r\n    numberOfSkeletonRows: number[][] = Array(20).fill(0);\r\n    tableDataWrapper: any[];\r\n    rowChecked: boolean;\r\n    isAllRowsChecked: boolean;\r\n    noDataWidth: string = '50%';\r\n    markedForCreditStatus: string;\r\n    markedForMGStatus: string;\r\n    filterAlignment: string = 'bottom auto';\r\n\r\n    //Sort and Filter\r\n    tooltipRadioTextMap: Map<any, any>;\r\n    filterTabObjects: any[];\r\n    tooltip: any;\r\n    disableColumnClearAllBtn: boolean = true;\r\n    margin = 5;\r\n\r\n    //Week Filter\r\n    multiWeekPickerConfig: IWeekCalendar;\r\n\r\n    tableColumns: string[] = [];\r\n    totalRowColumns: string[] = null;\r\n    bindValueFuncCalled: boolean;\r\n\r\n    hierarchyTooltip: { open: () => void; close: () => void };\r\n    sellerGroupHierarchy: RatingSellerGroupHierarchy[];\r\n    showFilterTooltipTabs: boolean; //Change the Name\r\n\r\n    isScrolledLeft: boolean = false;\r\n    rowBorderWidth: number = 2;\r\n\r\n    sameTooltipClicked: boolean;\r\n    isScrollEnded: boolean = true;\r\n    marginTop: string = '';\r\n    @ViewChildren('tableHeader') viewChildTableHeaders: QueryList<ElementRef>;\r\n\r\n    isDifferenceLessThan25Percent: boolean;\r\n    start: number = 0;\r\n    end: number = this.limit + this.start;\r\n    renderedData: any[];\r\n    selectedInventoryIdForDownload: number;\r\n    selectedDemographicForDownload: any;\r\n    selectedRowTypeForDownload: string;\r\n    heightOfCheckboxTooltipFilter: number;\r\n    isNoDataToDisplaySubject$ = new BehaviorSubject<boolean>(false);\r\n    selectedStarredOrderId: string;\r\n\r\n    textActionTooltip: keyValueTooltipType[] = [];\r\n    tooltipContainingTable: tableTooltipType = null;\r\n    tableBottomBorderClass: string = null;\r\n    showCheckboxesForTimeFilter: boolean = false;\r\n\r\n    constructor(\r\n        private cdRef: ChangeDetectorRef,\r\n        private annaSortService: AnnaSortService,\r\n        public annaDateTimeFormatService: AnnaDateTimeFormatService,\r\n        public annaFilterService: AnnaFilterService,\r\n    ) {\r\n        this.setTooltipRadioNames();\r\n    }\r\n\r\n    ngAfterViewChecked(): void {\r\n        this.setMarginLeftForFilterIcon();\r\n    }\r\n\r\n    ngOnInit() {\r\n        this.setFilterAlignmentBasedOnScreenResolution();\r\n    }\r\n\r\n    detectChanges() {\r\n        this.cdRef.detectChanges();\r\n    }\r\n\r\n    ngOnChanges(changes: SimpleChanges) {\r\n        if (\r\n            changes &&\r\n            changes['gtDimension'] &&\r\n            changes['gtDimension'].currentValue &&\r\n            this.setTableHeightWhenRowSizeIsFixed\r\n        ) {\r\n            this.setTableHeight();\r\n            this.setTableBottomBorder();\r\n        }\r\n        if (this.showSkeletonLoading) {\r\n            this.tableData = this.numberOfSkeletonRows;\r\n            this.renderedData = this.numberOfSkeletonRows;\r\n            this.isNoDataToDisplaySubject$.next(false);\r\n            this.setTableBottomBorder();\r\n        } else if (\r\n            changes['percentDone'] ||\r\n            changes['downloadInProgress'] ||\r\n            (changes['starredInProgress'] && changes['starredInProgress'].currentValue != undefined)\r\n        ) {\r\n            //no task will be performed\r\n        } else {\r\n            this.setInitialRowsForTable();\r\n            this.disableEnableEachColumnTooltipIcon();\r\n            this.tableColumns = this.tableHeaders.filter((x) => x.visible).map((x) => x.headerInfo[0].objectKey);\r\n            if (\r\n                (this.tableData && this.tableData.length == 0) ||\r\n                (this.tableData.length == 2 && this.checkIfAllTheElementsAreZero())\r\n            ) {\r\n                this.tableData = Array(2).fill(0);\r\n                this.renderedData = cloneDeep(this.tableData);\r\n                this.marginTop = -this.gtDimension.rowHeight - this.gtDimension.rowHeight / 2 + 'px';\r\n                this.isNoDataToDisplaySubject$.next(true);\r\n            } else {\r\n                this.isNoDataToDisplaySubject$.next(false);\r\n            }\r\n\r\n            this.showSkeletonLoading = false;\r\n            this.setTableBottomBorder();\r\n        }\r\n\r\n        //setting table column here as well because while showing skeleton loader, we should show table headers.\r\n        if (\r\n            changes['tableHeaders'] &&\r\n            !isEqual(changes['tableHeaders'].currentValue, changes['tableHeaders'].previousValue)\r\n        ) {\r\n            this.tableColumns = this.tableHeaders.filter((x) => x.visible).map((x) => x.headerInfo[0].objectKey);\r\n            this.annaSortService.columnSortState = new Map();\r\n            this.annaFilterService.initialValueMap = new Map();\r\n            // this.setColumnSortStateMap();\r\n            this.setActiveStateObject();\r\n        }\r\n\r\n        if (changes['totalRowInfo'] && changes['totalRowInfo'].currentValue) {\r\n            this.totalRowColumns = this.totalRowInfo.map((x) => x.colName);\r\n        }\r\n        this.cdRef.detectChanges();\r\n    }\r\n\r\n    setFilterAlignmentBasedOnScreenResolution() {\r\n        let viewportHeight = window.innerHeight;\r\n        if (viewportHeight < 740) {\r\n            this.filterAlignment = 'left right';\r\n        } else {\r\n            this.filterAlignment = 'bottom left right';\r\n        }\r\n    }\r\n\r\n    setTableBottomBorder() {\r\n        if (\r\n            this.tableBorderBottomClassRequired &&\r\n            this.tableData &&\r\n            this.tableData.length &&\r\n            this.maximumRowsWhichCanBeRenderedWithoutScroll < this.tableData.length\r\n        ) {\r\n            this.tableBottomBorderClass = 'bottom-border';\r\n        } else {\r\n            this.tableBottomBorderClass = null;\r\n        }\r\n    }\r\n\r\n    checkIfAllTheElementsAreZero() {\r\n        return !this.tableData.some((item) => item != 0);\r\n    }\r\n\r\n    setTableHeight() {\r\n        let viewportHeight = window.innerHeight;\r\n        let rowHeight = this.gtDimension.rowHeight;\r\n        let headerHeight = this.gtDimension.headerHeight;\r\n        let dataOnTopHeight = this.gtDimension.dataOnTopHeight;\r\n        let marginFromBottom = this.gtDimension.marginFromBottom;\r\n        let actualTableHeight;\r\n\r\n        if (this.fixNumberOfRowsForPopup) {\r\n            let maxNoOfRowsToDisplay = viewportHeight < 740 ? 5 : 10;\r\n            this.maximumRowsWhichCanBeRenderedWithoutScroll = maxNoOfRowsToDisplay;\r\n            actualTableHeight = this.maximumRowsWhichCanBeRenderedWithoutScroll * rowHeight + headerHeight;\r\n        } else {\r\n            let minHeightForTable = headerHeight + 3 * rowHeight;\r\n            viewportHeight = viewportHeight <= dataOnTopHeight ? dataOnTopHeight + minHeightForTable : viewportHeight;\r\n            let heightLeftForTable = viewportHeight - dataOnTopHeight - marginFromBottom;\r\n            this.maximumRowsWhichCanBeRenderedWithoutScroll =\r\n                Math.ceil((heightLeftForTable - headerHeight - rowHeight) / rowHeight) + 1;\r\n            actualTableHeight = viewportHeight - dataOnTopHeight - marginFromBottom;\r\n        }\r\n\r\n        // let actualTableHeight = heightLeftForTable - ((heightLeftForTable - headerHeight - rowHeight) % rowHeight);\r\n\r\n        this.gtDimension.tableHeight = `${actualTableHeight}px`;\r\n\r\n        this.numberOfSkeletonRows = this.maximumRowsWhichCanBeRenderedWithoutScroll\r\n            ? Array(this.maximumRowsWhichCanBeRenderedWithoutScroll).fill(0)\r\n            : Array(5).fill(0);\r\n    }\r\n\r\n    trackByFn(index: number) {\r\n        return index;\r\n    }\r\n\r\n    setTooltipRadioNames() {\r\n        this.tooltipRadioTextMap = new Map();\r\n        this.tooltipRadioTextMap.set('StartTimeForFilter', 'Start Time');\r\n        this.tooltipRadioTextMap.set('EndTimeForFilter', 'End Time');\r\n        this.tooltipRadioTextMap.set('startTimeForFilter', 'Start Time');\r\n        this.tooltipRadioTextMap.set('endTimeForFilter', 'End Time');\r\n        this.tooltipRadioTextMap.set('start_time_for_filter', 'Start Time');\r\n        this.tooltipRadioTextMap.set('end_time_for_filter', 'End Time');\r\n        this.tooltipRadioTextMap.set('primaryAEName', 'Primary AE');\r\n        this.tooltipRadioTextMap.set('region', 'Region');\r\n        this.tooltipRadioTextMap.set('agencyName', 'Agency');\r\n        this.tooltipRadioTextMap.set('location', 'Location');\r\n        this.tooltipRadioTextMap.set('advertiserName', 'Advertiser');\r\n        this.tooltipRadioTextMap.set('productCode', 'Product Code');\r\n        this.tooltipRadioTextMap.set('flightStartDate', 'Start Date');\r\n        this.tooltipRadioTextMap.set('flightEndDate', 'End Date');\r\n        this.tooltipRadioTextMap.set('orderIdAndRevNumber', 'STN Order#-Rev#');\r\n        this.tooltipRadioTextMap.set('stationOrderNumber', 'STN Order#');\r\n        this.tooltipRadioTextMap.set('alternateOrderId', 'Alt/Rep Order #');\r\n        this.tooltipRadioTextMap.set('grp', 'GRP');\r\n        this.tooltipRadioTextMap.set('cpp', 'CPP');\r\n        this.tooltipRadioTextMap.set('imps', 'IMPS');\r\n        this.tooltipRadioTextMap.set('cpm', 'CPM');\r\n        this.tooltipRadioTextMap.set('offeredMGs', 'Offered MG');\r\n        this.tooltipRadioTextMap.set('outstandingPE', 'O/S PE');\r\n        this.tooltipRadioTextMap.set('offeredADUs', 'Offered ADUs');\r\n        this.tooltipRadioTextMap.set('udDeficitValue', 'O/S Aud Delta');\r\n        this.tooltipRadioTextMap.set('startEndTimeMulti', 'Time');\r\n        this.tooltipRadioTextMap.set('bookedValue', 'Booked');\r\n        this.tooltipRadioTextMap.set('bookedSpots', 'Spots');\r\n        this.tooltipRadioTextMap.set('UserCreditedValue', 'User Credited');\r\n        this.tooltipRadioTextMap.set('UserUnresolvedValue', 'User Unresolved');\r\n        this.tooltipRadioTextMap.set('BuyerAddedValue', 'Buyer Added');\r\n        this.tooltipRadioTextMap.set('BuyerDeletedValue', 'Buyer Deleted');\r\n        this.tooltipRadioTextMap.set('userChanges', 'User Changes');\r\n        this.tooltipRadioTextMap.set('buyerChanges', 'Buyer Changes');\r\n        this.tooltipRadioTextMap.set('userMG', 'User MG');\r\n        this.tooltipRadioTextMap.set('userADUs', 'User ADUs');\r\n        this.tooltipRadioTextMap.set('inventoryCode', 'Inventory Code');\r\n        this.tooltipRadioTextMap.set('program', 'Program');\r\n        this.tooltipRadioTextMap.set('agency', 'Agency');\r\n        this.tooltipRadioTextMap.set('advertiser', 'Advertiser');\r\n        this.tooltipRadioTextMap.set('startDate', 'Start Date');\r\n        this.tooltipRadioTextMap.set('endDate', 'End Date');\r\n        this.tooltipRadioTextMap.set('date', 'Date');\r\n        this.tooltipRadioTextMap.set('rcvPreempt', '$ Madegood PEs');\r\n        this.tooltipRadioTextMap.set('osPreempt', '$ O/S PEs');\r\n        this.tooltipRadioTextMap.set('rcvUnderDly', 'Recovered UD');\r\n        this.tooltipRadioTextMap.set('osUnderDly', 'O/s Under Dly');\r\n        this.tooltipRadioTextMap.set('primaryAe', 'Primary AE');\r\n        this.tooltipRadioTextMap.set('region', 'Region');\r\n        this.tooltipRadioTextMap.set('revCode1', 'Rev code 1');\r\n        this.tooltipRadioTextMap.set('orderNoRevNo', 'STN Order#-Rev#');\r\n        this.tooltipRadioTextMap.set('revCode2', 'Rev code 2');\r\n        this.tooltipRadioTextMap.set('revCode3', 'Rev code 3');\r\n        this.tooltipRadioTextMap.set('booked', '$ Booked');\r\n        this.tooltipRadioTextMap.set('spots', 'Spots');\r\n        this.tooltipRadioTextMap.set('postedAudPercent', 'Posted %');\r\n        this.tooltipRadioTextMap.set('revision', 'Revision');\r\n        this.tooltipRadioTextMap.set('buyerOrderId', 'ALT/REP Order#');\r\n        this.tooltipRadioTextMap.set('demo', 'Demo');\r\n        this.tooltipRadioTextMap.set('postedAdu', '$ Posted ADUs');\r\n        this.tooltipRadioTextMap.set('scheduledAdu', '$ Scheduled ADUs');\r\n        this.tooltipRadioTextMap.set('audienceDeficit', '$ O/S Audience');\r\n        this.tooltipRadioTextMap.set('postedAudPercent', 'Posted Audience %');\r\n        this.tooltipRadioTextMap.set('potentialUnitsValue', 'POT Units');\r\n        this.tooltipRadioTextMap.set('bookedUnitsValue', 'Booked Eq Units');\r\n        this.tooltipRadioTextMap.set('bookedAmountWithZeroRatingValue', 'Total $ Booked');\r\n        this.tooltipRadioTextMap.set('bookedAmountPercentageWithZeroRatingValue', '% Against All Demos');\r\n        this.tooltipRadioTextMap.set('bookedAmountWithoutZeroRatingValue', '$Booked With Imps(’000)');\r\n        this.tooltipRadioTextMap.set('bookedAmountPercentageWithoutZeroRatingValue', '% Against All Demos');\r\n\r\n        this.tooltipRadioTextMap.set('totalBookedAmountValue', 'Total $Booked');\r\n        this.tooltipRadioTextMap.set('averageUnitRateValue', ' AUR');\r\n        this.tooltipRadioTextMap.set('totalBookedAmountWithRatingValue', '$Booked With Rating');\r\n        this.tooltipRadioTextMap.set('averageUnitRateWithRatingValue', 'AUR With Rating');\r\n\r\n        this.tooltipRadioTextMap.set('totalBookedAmountWithImpressionValue', '$Booked With IMPS');\r\n        this.tooltipRadioTextMap.set('averageUnitRateWithImpressionValue', 'AUR With IMPS');\r\n\r\n        this.tooltipRadioTextMap.set('bookedUnitsWithRatingValue', 'Booked Units With Rating');\r\n        this.tooltipRadioTextMap.set('postedUnitsWithRatingValue', 'Posted Units With Rating');\r\n\r\n        this.tooltipRadioTextMap.set('bookedUnitsWithImpressionValue', 'Booked Units With IMPS');\r\n        this.tooltipRadioTextMap.set('postedUnitsWithImpressionValue', 'Posted Units With IMPS');\r\n\r\n        this.tooltipRadioTextMap.set('bookedRatings', 'Booked Rating');\r\n        this.tooltipRadioTextMap.set('postedRatings', 'POSTED Rating');\r\n        this.tooltipRadioTextMap.set('PostedRating', 'Posted RTG');\r\n\r\n        this.tooltipRadioTextMap.set('bookedImpressions', \"Booked IMP('000)\");\r\n        this.tooltipRadioTextMap.set('postedImpressions', \"Posted IMP('000)\");\r\n        this.tooltipRadioTextMap.set('PostedImpressions', \"Posted IMP('000)\");\r\n\r\n        this.tooltipRadioTextMap.set('bookedAverageRating', 'Booked AU Rating');\r\n        this.tooltipRadioTextMap.set('postedAverageRating', 'Posted AU Rating');\r\n\r\n        this.tooltipRadioTextMap.set('bookedAverageImpression', 'Booked AU IMPS');\r\n        this.tooltipRadioTextMap.set('postedAverageImpression', 'Posted AU IMPS');\r\n\r\n        this.tooltipRadioTextMap.set('bookedCppValue', 'Booked CPP');\r\n        this.tooltipRadioTextMap.set('bookedEffectiveCppValue', 'Effective CPP');\r\n\r\n        this.tooltipRadioTextMap.set('bookedCpmValue', 'Booked CPM');\r\n        this.tooltipRadioTextMap.set('bookedEffectiveCpmValue', 'Effective CPM');\r\n\r\n        this.tooltipRadioTextMap.set('orderSource', 'Order Route');\r\n        this.tooltipRadioTextMap.set('orderCategory', 'Rev Category');\r\n        this.tooltipRadioTextMap.set('cashOrTrade', 'C/T');\r\n        this.tooltipRadioTextMap.set('revisionStartDate', 'Revision Start Date');\r\n        this.tooltipRadioTextMap.set('name', 'name');\r\n        this.tooltipRadioTextMap.set('role', 'role');\r\n        this.tooltipRadioTextMap.set('stationCount', 'stationCount');\r\n        this.tooltipRadioTextMap.set('stationList', 'stationList');\r\n        this.tooltipRadioTextMap.set('approvedOn', 'Approved On');\r\n        this.tooltipRadioTextMap.set('approvedBy', 'Approved By');\r\n        this.tooltipRadioTextMap.set('ODImps', 'Proj. OD IMPS');\r\n        this.tooltipRadioTextMap.set('UDImps', 'Proj. UD IMPS');\r\n        this.tooltipRadioTextMap.set('ODGrp', 'Proj. OD GRP');\r\n        this.tooltipRadioTextMap.set('UDGrp', 'Proj. UD GRP');\r\n        this.tooltipRadioTextMap.set('udImpsPercent', 'Proj. UD %');\r\n        this.tooltipRadioTextMap.set('udGrpPercent', 'Proj. UD GRP %');\r\n        this.tooltipRadioTextMap.set('odImpsPercent', 'Proj. OD %');\r\n        this.tooltipRadioTextMap.set('odGrpPercent', 'Proj. OD GRP %');\r\n\r\n        this.tooltipRadioTextMap.set('RevisionNumber', 'Revision #');\r\n        this.tooltipRadioTextMap.set('RevisionType', 'Revision Type');\r\n        this.tooltipRadioTextMap.set('GeneratedOn', 'Generated On');\r\n        this.tooltipRadioTextMap.set('BookedValueForDisplay', '$ BOOKED');\r\n        this.tooltipRadioTextMap.set('BookedValue', '$ Booked');\r\n        this.tooltipRadioTextMap.set('BookedSpots', 'Spots');\r\n        this.tooltipRadioTextMap.set('BookedGRP', 'GRP');\r\n        this.tooltipRadioTextMap.set('BookedIMPSRevTab', \"IMPS'(000)\");\r\n        this.tooltipRadioTextMap.set('BookedCPP', 'CPP');\r\n        this.tooltipRadioTextMap.set('BookedCPM', 'CPM');\r\n        this.tooltipRadioTextMap.set('MGsValueForDisplay', '$ MGS');\r\n        this.tooltipRadioTextMap.set('MGsValue', '$ MGS');\r\n        this.tooltipRadioTextMap.set('ADUsValueForDisplay', '$ ADUS');\r\n        this.tooltipRadioTextMap.set('ADUsValue', '$ ADUS');\r\n        this.tooltipRadioTextMap.set('BuyerChangesValueForDisplay', '$ Buyer Change');\r\n        this.tooltipRadioTextMap.set('BuyerChangesValue', '$ Buyer Change');\r\n        this.tooltipRadioTextMap.set('UserChangesValueForDisplay', '$ Seller User Change');\r\n        this.tooltipRadioTextMap.set('UserChangesValue', '$ Seller User Change');\r\n        this.tooltipRadioTextMap.set('SellerLine', 'Seller Line #');\r\n        this.tooltipRadioTextMap.set('BuyerLine', 'Buy Line #');\r\n        this.tooltipRadioTextMap.set('SpotStatus', 'Spot Status');\r\n        this.tooltipRadioTextMap.set('InventoryCode', 'Inventory Code');\r\n        this.tooltipRadioTextMap.set('BuyerProgramName', 'Buyer Program Name');\r\n        this.tooltipRadioTextMap.set('RevenueClass', 'Revenue Class');\r\n        this.tooltipRadioTextMap.set('WeeklyAUR', 'Booked Avg. Rate');\r\n        this.tooltipRadioTextMap.set('BookedRate', 'Booked Rate');\r\n        this.tooltipRadioTextMap.set('averageRate', 'Average Rate');\r\n        this.tooltipRadioTextMap.set('bookedAverageRate','Booked AVG. Rate')\r\n        this.tooltipRadioTextMap.set('dollarIMPSImpact', '$ IMPS Impact');\r\n        this.tooltipRadioTextMap.set('dollarRTGImpact', '$ RTG IMPACT');\r\n        this.tooltipRadioTextMap.set('IMPSImpact', \"IMPS ('000) IMPACT\");\r\n        this.tooltipRadioTextMap.set('RTGImpact', 'RTG Impact');\r\n\r\n        this.tooltipRadioTextMap.set('inventoryFillPercentageSameWeek', 'Inv Fill Same Week');\r\n        this.tooltipRadioTextMap.set('inventoryFillPercentageFinal', 'Inv Fill Final');\r\n\r\n        this.tooltipRadioTextMap.set('projectedRTG', 'Projected RTG');\r\n        this.tooltipRadioTextMap.set('projectedIMPS', \"Projected IMPS('000)\");\r\n        this.tooltipRadioTextMap.set('desiredCPM', 'Desired CPM');\r\n        this.tooltipRadioTextMap.set('desiredCPP', 'Desired CPP');\r\n        this.tooltipRadioTextMap.set('origin', 'Origin');\r\n\r\n        this.tooltipRadioTextMap.set('BookedRTG', 'Booked RTG');\r\n        this.tooltipRadioTextMap.set('BookedIMPS', \"Booked IMPS('000)\");\r\n        this.tooltipRadioTextMap.set('IMPS', \"IMP('000)\");\r\n        this.tooltipRadioTextMap.set('AURTG', 'Avg RTG');\r\n        this.tooltipRadioTextMap.set('AUIMPS', \"Avg IMP('000)\");\r\n        this.tooltipRadioTextMap.set('PostedRatingsOrImpressions', 'Posted RTG');\r\n        this.tooltipRadioTextMap.set('ScheduleFlightWeek', 'Schedule Week');\r\n        this.tooltipRadioTextMap.set('ScheduledDay', 'Scheduled Day');\r\n        this.tooltipRadioTextMap.set('AirStatus', 'Air Status');\r\n        this.tooltipRadioTextMap.set('AirDateAndTime', 'Air Date & Time');\r\n        this.tooltipRadioTextMap.set('AirDate', 'Air Date');\r\n        this.tooltipRadioTextMap.set('NormalizedOrderedRating', 'Normalized Booked RTG');\r\n        this.tooltipRadioTextMap.set('NormalizedOrderedImpressions', \"Normalized Booked IMP('000)\");\r\n        this.tooltipRadioTextMap.set('NormalizedPostedRating', 'Normalized Posted RTG');\r\n        this.tooltipRadioTextMap.set('NormalizedPostedImpressions', \"Normalized Posted IMP('000)\");\r\n        this.tooltipRadioTextMap.set('AdId', 'Ad-Id');\r\n\r\n        this.tooltipRadioTextMap.set('displayimps', 'IMPS');\r\n        this.tooltipRadioTextMap.set('displayGrp', 'GRP');\r\n        this.tooltipRadioTextMap.set('bookedSpotsForDisplay', 'Spots');\r\n        this.tooltipRadioTextMap.set('displaySpots', 'Spots');\r\n\r\n        this.tooltipRadioTextMap.set('estimateNo', 'Estimate#');\r\n        this.tooltipRadioTextMap.set('primaryBuyer', 'Primary Buyer');\r\n        this.tooltipRadioTextMap.set('primaryBuyerName', 'Primary Buyer');\r\n        this.tooltipRadioTextMap.set('secondaryBuyerName', 'Secondary Buyer');\r\n        this.tooltipRadioTextMap.set('secondaryBuyer', 'Secondary Buyer');\r\n        this.tooltipRadioTextMap.set('timeoutDate', 'Timeout Date');\r\n        this.tooltipRadioTextMap.set('DisplaytSpotStatusBI', 'Spot Status');\r\n        this.tooltipRadioTextMap.set('LineSpot', 'Line.Spot');\r\n        this.tooltipRadioTextMap.set('LurWindowName', 'Political Window');\r\n\r\n        this.tooltipRadioTextMap.set('length', 'Length');\r\n        this.tooltipRadioTextMap.set('revClass', 'Rev Class');\r\n\r\n        // this.tooltipRadioTextMap.set(\"udValue\", \"$ UD\");\r\n        // this.tooltipRadioTextMap.set(\"odValue\", \"$ OD\");\r\n        this.tooltipRadioTextMap.set('udValue', 'Proj. $ UD');\r\n        this.tooltipRadioTextMap.set('odValue', 'Proj. $ OD');\r\n\r\n        this.tooltipRadioTextMap.set('OtherAvailableSpotsTableInventoryCode', 'Inventory Code');\r\n        this.tooltipRadioTextMap.set('OtherAvailableSpotsTableBuyerProgramName', 'Buyer Program Name');\r\n        this.tooltipRadioTextMap.set('OtherAvailableSpotsTableStartTime', 'Start Time');\r\n        this.tooltipRadioTextMap.set('OtherAvailableSpotsTableEndTime', 'End Time');\r\n        this.tooltipRadioTextMap.set('OtherAvailableSpotsTableWeeklyAUR', 'Booked Avg. Rate');\r\n        this.tooltipRadioTextMap.set('OtherAvailableSpotsTableDisplayRevenueClass', 'Rev Class');\r\n        this.tooltipRadioTextMap.set('OtherAvailableSpotsTableActualWeekStartDate', 'Week');\r\n        this.tooltipRadioTextMap.set('OtherAvailableSpotsTableWeekDay', 'Day');\r\n        this.tooltipRadioTextMap.set('OtherAvailableSpotsTableDisplayLength', 'Length');\r\n\r\n        this.tooltipRadioTextMap.set('ProjectedImpressions', \"Projected IMP('000)\");\r\n        this.tooltipRadioTextMap.set('ProjectedRtg', 'Projected RTG');\r\n    }\r\n\r\n    selectOrUnselectCheckbox(rowData: any, columnKeys: any, isCheckboxSelected: any) {\r\n        rowData[columnKeys] = !rowData[columnKeys];\r\n        this.toggleCheckbox.emit({ rowData, columnKeys, isCheckboxSelected });\r\n    }\r\n\r\n    selectOrUnselectRadiobox(rowData: any, columnKeys: any, isCheckboxSelected: boolean) {\r\n        if (rowData[columnKeys] == isCheckboxSelected) return;\r\n        rowData[columnKeys] = isCheckboxSelected;\r\n        this.toggleCheckbox.emit({ rowData, columnKeys, isCheckboxSelected });\r\n    }\r\n\r\n    selectUnselectAllRows() {\r\n        this.toggleHeaderCheckbox.emit();\r\n    }\r\n\r\n    selectUnselectRow(rowData: any) {\r\n        this.toggleRowCheckbox.emit(rowData);\r\n    }\r\n\r\n    undoCreditedSpot(data: any) {\r\n        this.undoIconClicked.emit({ data, mgOrCredit: 'Credit' });\r\n    }\r\n\r\n    undoMgSpot(data: any) {\r\n        this.undoIconClicked.emit({ data, mgOrCredit: 'MakeGood' });\r\n    }\r\n\r\n    //Sort and Filter Logic begins!\r\n    closeTooltip() {\r\n        if (this.tooltip && this.tooltip.isOpen()) {\r\n            this.tooltip.close();\r\n        }\r\n        this.tooltip = null;\r\n        if (!this.bindValueFuncCalled) {\r\n            this.columnFilterClosed.emit();\r\n        }\r\n    }\r\n\r\n    isTooltipActive(header: any[]) {\r\n        return this.annaFilterService.isTooltipActive(header, this.annaSortService.columnSortState);\r\n    }\r\n\r\n    bindTheValueToToolTip(tooltip: any, header: IHeaderInfo) {\r\n        this.bindValueFuncCalled = true;\r\n        // if same tooltip opened close it\r\n        if (tooltip == this.tooltip) {\r\n            this.bindValueFuncCalled = false;\r\n            this.closeTooltip();\r\n        } else {\r\n            let enabledHeaders: any[] = [];\r\n            this.checkIfUniqueValuePresentForTheHeader(header, enabledHeaders);\r\n            this.openTooltip(tooltip, enabledHeaders, header);\r\n\r\n            if (\r\n                window.innerWidth < 1500 &&\r\n                window.innerHeight < 768 &&\r\n                !this.annaFilterService.sliderSet.has(header.filterSortObjectKeys[0])\r\n            ) {\r\n                this.columnFilterOpened.emit();\r\n            }\r\n\r\n            this.showCheckboxesForTimeFilter =\r\n                this.gtGeneralConfig.component == 'SPOTDETAILS' ||\r\n                this.gtGeneralConfig.component == 'EXCLUDEINVENTORYPOPUP' ||\r\n                this.gtGeneralConfig.component == 'RATING';\r\n            this.showFilterTooltipTabs = header.filterSortObjectKeys.length > 1;\r\n            this.bindValueFuncCalled = false;\r\n        }\r\n    }\r\n\r\n    checkIfUniqueValuePresentForTheHeader(header: IHeaderInfo, enabledHeaders: any[]) {\r\n        header.filterSortObjectKeys.forEach((item: string) => {\r\n            let dataToCheck = this.annaFilterService.getFilterOptionsData(this.tableData, this.clonedTableData, item);\r\n            if (item == 'period') {\r\n                let uniqStartDate = uniq(dataToCheck.map((u: { [x: string]: any }) => u['startDate']));\r\n                let uniqEndDate = uniq(dataToCheck.map((u: { [x: string]: any }) => u['endDate']));\r\n                if (uniqStartDate.length > 1 || uniqEndDate.length > 1 || this.isTooltipActive([item])) {\r\n                    enabledHeaders.push(item);\r\n                }\r\n            } else {\r\n                let values = dataToCheck.map((u: { [x: string]: any }) => u[item]);\r\n                // if last applied filter is this header, push it alos as enabledHeader\r\n                let activeAndLastlyAppliedHeader = false;\r\n                if (\r\n                    this.annaFilterService.appliedFiltersArray.length > 0 &&\r\n                    this.annaFilterService.appliedFiltersArray[this.annaFilterService.appliedFiltersArray.length - 1] ==\r\n                        item\r\n                ) {\r\n                    activeAndLastlyAppliedHeader = true;\r\n                }\r\n                if (\r\n                    header.filter == 'CHECKBOX' &&\r\n                    (uniq(values).filter((n) => n != null).length > 1 || activeAndLastlyAppliedHeader)\r\n                ) {\r\n                    enabledHeaders.push(item);\r\n                } else if (\r\n                    header.filter != 'CHECKBOX' &&\r\n                    (uniq(values).filter((n) => n != null && n != '-').length > 1 || activeAndLastlyAppliedHeader)\r\n                ) {\r\n                    enabledHeaders.push(item);\r\n                }\r\n            }\r\n        });\r\n    }\r\n\r\n    openTooltip(tooltip: any, header: any, columnHeader: IHeaderInfo) {\r\n        this.closeTooltip();\r\n        this.tooltip = tooltip;\r\n        this.tooltip.open();\r\n        //convert key into the header\r\n        this.filterTabObjects = header.map((key: string, index: number) => {\r\n            let value = this.tooltipRadioTextMap.has(key) ? this.tooltipRadioTextMap.get(key) : key; //change to display name\r\n            return new radioButtonModel(\r\n                key,\r\n                value,\r\n                columnHeader.isSortRequired[index],\r\n                columnHeader.isFilterRequired[index],\r\n            );\r\n        });\r\n    }\r\n\r\n    disableEnableEachColumnTooltipIcon() {\r\n        this.tableHeaders.forEach((header) => {\r\n            header.headerInfo.forEach((item) => {\r\n                if (item.showTooltipIcon) {\r\n                    let values = [];\r\n                    item.disableTooltipIcon = true;\r\n\r\n                    item.filterSortObjectKeys.forEach((key) => {\r\n                        let latestFilters = this.annaFilterService.appliedFiltersArray;\r\n\r\n                        if (\r\n                            latestFilters.length > 0 &&\r\n                            item.disableTooltipIcon &&\r\n                            latestFilters[latestFilters.length - 1] == key\r\n                        ) {\r\n                            item.disableTooltipIcon = false;\r\n                        }\r\n\r\n                        if (item.disableTooltipIcon) {\r\n                            if (key == 'period') {\r\n                                let uniqStartDate = uniq(\r\n                                    this.tableData.map((u: { [x: string]: any }) => u['startDate']),\r\n                                );\r\n                                let uniqEndDate = uniq(this.tableData.map((u: { [x: string]: any }) => u['endDate']));\r\n\r\n                                item.disableTooltipIcon =\r\n                                    uniqStartDate.length > 1 || uniqEndDate.length > 1 ? false : true;\r\n                            } else {\r\n                                values = this.tableData.map((u: { [x: string]: any }) => u[key]);\r\n                                if (\r\n                                    (item.filter == 'CHECKBOX' && uniq(values).filter((n) => n != null).length > 1) ||\r\n                                    (item.filter != 'CHECKBOX' &&\r\n                                        uniq(values).filter((n) => n != null && n != '-').length > 1)\r\n                                ) {\r\n                                    item.disableTooltipIcon = false;\r\n                                }\r\n                            }\r\n                        }\r\n                    });\r\n                }\r\n            });\r\n        });\r\n    }\r\n\r\n    setMarginLeftForFilterIcon() {\r\n        let elementArr = this.viewChildTableHeaders.toArray();\r\n        elementArr.forEach((item) => {\r\n            let childDivElements = item.nativeElement.children;\r\n\r\n            if (childDivElements.length == 2) {\r\n                let firstParagraphOffsetWidth: number = childDivElements[0]?.children[0]?.offsetWidth\r\n                    ? childDivElements[0]?.children[0]?.offsetWidth\r\n                    : 0;\r\n                let secondParagraphOffsetWidth: number = childDivElements[1].children[0]?.offsetWidth\r\n                    ? childDivElements[1].children[0]?.offsetWidth\r\n                    : 0;\r\n\r\n                if (firstParagraphOffsetWidth > secondParagraphOffsetWidth) {\r\n                    let diff = firstParagraphOffsetWidth - secondParagraphOffsetWidth;\r\n                    if (childDivElements[0].children.length == 2) {\r\n                        childDivElements[0].children[1].style.marginLeft = 4 + 'px';\r\n                    }\r\n\r\n                    if (childDivElements[1].children.length == 2) {\r\n                        childDivElements[1].children[1].style.marginLeft = diff + 4 + 'px';\r\n                    }\r\n                } else {\r\n                    let diff = secondParagraphOffsetWidth - firstParagraphOffsetWidth;\r\n                    if (childDivElements[0].children.length == 2) {\r\n                        childDivElements[0].children[1].style.marginLeft = diff + 4 + 'px';\r\n                    }\r\n\r\n                    if (childDivElements[1].children.length == 2) {\r\n                        childDivElements[1].children[1].style.marginLeft = 4 + 'px';\r\n                    }\r\n                }\r\n            }\r\n        });\r\n    }\r\n\r\n    dataRowClicked(rowData: any) {\r\n        this.rowClicked.emit(rowData);\r\n    }\r\n\r\n    radioButtonClicked(data: any, action: string, isDisabled: boolean) {\r\n        if (!isDisabled) {\r\n            this.radioButtonSelected.emit({ data, action });\r\n        }\r\n    }\r\n\r\n    bindTheValueToSellerGroupTooltip(sellerGroupHierarchy: RatingSellerGroupHierarchy[], tooltip: any): void {\r\n        if (this.hierarchyTooltip && this.hierarchyTooltip.open) {\r\n            this.hierarchyTooltip.close();\r\n        }\r\n        this.sellerGroupHierarchy = sellerGroupHierarchy;\r\n        this.hierarchyTooltip = tooltip;\r\n        this.hierarchyTooltip.open();\r\n    }\r\n\r\n    iconClicked(rowData: any, iconClass: string) {\r\n        if ('orderId' in rowData && iconClass.includes('mdi-star')) {\r\n            this.selectedStarredOrderId = rowData.orderId;\r\n        }\r\n\r\n        this.gtIconClicked.emit({ data: rowData, iconClass: iconClass });\r\n    }\r\n\r\n    svgIconClicked(data: GtColumnIconEmittedData) {\r\n        this.gtSVGIconClicked.emit(data);\r\n    }\r\n\r\n    textActionClicked(rowData: any, id: any, columnHeader: IHeaderInfo) {\r\n        this.gtTextActionClicked.emit({ data: rowData, id: id, columnHeader: columnHeader, isIconClicked: false });\r\n    }\r\n\r\n    iconClickedOnStringIconActionType(rowData: any, id: any, columnHeader: IHeaderInfo) {\r\n        this.gtTextActionClicked.emit({ data: rowData, id: id, columnHeader: columnHeader, isIconClicked: true });\r\n    }\r\n\r\n    innerHTMLCellClicked(event: any, rowData: any) {\r\n        this.gtInnerHTMLClicked.emit({ event, rowData });\r\n    }\r\n\r\n    viewDetailsClicked(rowData: any) {\r\n        this.gtViewDetailClicked.emit({ data: rowData });\r\n    }\r\n\r\n    setActiveStateObject() {\r\n        this.annaFilterService.isFilterSortActive =\r\n            !this.annaFilterService.resetFilterSortActiveStatus || this.multipleTablesPresent\r\n                ? this.annaFilterService.isFilterSortActive\r\n                : {};\r\n        this.tableHeaders.forEach((item) => {\r\n            item.headerInfo.forEach((header) => {\r\n                if (header.showTooltipIcon) {\r\n                    let key = header.filterSortObjectKeys.join(',');\r\n                    header.joinedFilterSortObjectKeys = key;\r\n                    // ANNA-4113 fix\r\n                    if (this.annaFilterService.resetFilterSortActiveStatus) {\r\n                        this.annaFilterService.isFilterSortActive[key] = false;\r\n                    }\r\n                }\r\n            });\r\n        });\r\n        this.annaFilterService.resetFilterSortActiveStatus = true;\r\n    }\r\n\r\n    setIsDifference(value: boolean) {\r\n        this.isDifferenceLessThan25Percent = value;\r\n    }\r\n\r\n    resetIndex() {\r\n        this.start = 0;\r\n        this.end = this.limit + this.start;\r\n    }\r\n\r\n    onTableContainerScroll(e: any) {\r\n        const tableViewHeight = e.target.offsetHeight; // viewport\r\n        const tableScrollHeight = e.target.scrollHeight; // length of all table\r\n        const scrollLocation = e.target.scrollTop; // how far user scrolled\r\n\r\n        this.removeTooltipOnScroll();\r\n\r\n        // If the user has scrolled within 150px of the bottom, add more data\r\n        const buffer = 150;\r\n        const limit = tableScrollHeight - tableViewHeight - buffer;\r\n        if (scrollLocation > limit) {\r\n            let data = this.getTableData(this.start, this.end);\r\n            this.renderedData = this.renderedData.concat(data);\r\n            this.updateIndex();\r\n        }\r\n        this.tableContainerScrolled(e);\r\n    }\r\n\r\n    getTableData(start: number, end: number) {\r\n        return this.tableData.filter((value, index) => index >= start && index < end);\r\n    }\r\n\r\n    updateIndex() {\r\n        this.start = this.end;\r\n        this.end = this.limit + this.start;\r\n    }\r\n\r\n    setInitialRowsForTable() {\r\n        this.resetIndex();\r\n        this.renderedData = this.getTableData(this.start, this.end);\r\n        this.updateIndex();\r\n    }\r\n\r\n    spotDetailsDownloadClicked(parentChildOrTotalRow: 'DATAROW' | 'TOTALROW', rowdata?: any) {\r\n        if (rowdata) {\r\n            this.selectedInventoryIdForDownload = rowdata.inventoryCodeId;\r\n            this.selectedDemographicForDownload = rowdata.demographic;\r\n        } else {\r\n            this.selectedInventoryIdForDownload = null;\r\n            this.selectedDemographicForDownload = null;\r\n        }\r\n        this.selectedRowTypeForDownload = parentChildOrTotalRow;\r\n        this.downloadSpotDetails.emit({\r\n            parentChildOrTotalRow: parentChildOrTotalRow,\r\n            inventoryCodeId: this.selectedInventoryIdForDownload,\r\n            demographic: this.selectedDemographicForDownload,\r\n        });\r\n    }\r\n\r\n    tableContainerScrolled(event: any) {\r\n        this.isScrolledLeft = event.target.scrollLeft > 0;\r\n        this.isScrollEnded = Math.round(event.target.scrollLeft) == event.target.scrollWidth - event.target.clientWidth;\r\n        this.removeTooltipOnScroll();\r\n    }\r\n\r\n    mouseEnterOnStringTextActionType(rowData: any, tooltipKey: string) {\r\n        this.textActionTooltip = rowData[tooltipKey];\r\n        this.notificationIconHover.emit({ rowData: rowData, type: 'on-enter' });\r\n    }\r\n\r\n    mouseEnterOnStringTextActionTypeContainingTable(rowData: any, tooltipKey: string) {\r\n        this.tooltipContainingTable = rowData[tooltipKey];\r\n    }\r\n\r\n    mouseLeaveTextActionType(rowData: any) {\r\n        this.notificationIconHoverLeave.emit({ rowData: rowData, type: 'on-leave' });\r\n    }\r\n\r\n    mouseEnterOnTextActionType(rowData: any, tooltipKey: string) {\r\n        this.textActionTooltip = rowData[tooltipKey];\r\n    }\r\n\r\n    onClickableDataClicked(Rowdata: any, id: number) {\r\n        this.clickableDataClicked.emit({ data: Rowdata, id: id });\r\n    }\r\n\r\n    removeTooltipOnScroll() {\r\n        const elements = document.getElementsByClassName('remarks-info-tooltip');\r\n        // const tooltipElements = document.getElementsByClassName(\"tooltip\");\r\n        const gtTooltip = document.getElementsByClassName('remove-on-scroll-class');\r\n        const tooltipElements = document.getElementsByClassName('tooltip');\r\n\r\n        while (elements && elements.length > 0) {\r\n            elements[0].remove();\r\n        }\r\n        while (tooltipElements && tooltipElements.length > 0) {\r\n            tooltipElements[0].remove();\r\n            this.tooltip = null;\r\n        }\r\n        while (gtTooltip && gtTooltip.length > 0) {\r\n            gtTooltip[0].remove();\r\n        }\r\n    }\r\n\r\n    iconClickedInTotalRow(colName: string) {\r\n        this.totalRowIconClicked.emit(colName);\r\n    }\r\n\r\n    changesMadeInEditableInputBox(event: any, editedObject: any, pasteEvent: boolean) {\r\n        let enteredValue = pasteEvent ? event.clipboardData.getData('text') : event.key;\r\n        let dotIndex = editedObject.value.indexOf('.');\r\n\r\n        if (\r\n            event.keyCode != 8 &&\r\n            event.keyCode != 46 &&\r\n            !(event.keyCode >= 37 && event.keyCode <= 40) &&\r\n            ((!editedObject?.allowSpecialCharacters && !/[`0-9.]/.test(enteredValue)) ||\r\n                (editedObject.isDecimalPointCheckRequired &&\r\n                    dotIndex >= 0 &&\r\n                    event?.target?.selectionStart > dotIndex &&\r\n                    editedObject.value.length - (dotIndex + 1) >= editedObject.maxDecimalPointsAllowed))\r\n        ) {\r\n            event.preventDefault();\r\n        }\r\n    }\r\n\r\n    editableInputValueChanged(value: any, row: any, keyEdited: string) {\r\n        this.editableInputEdited.emit({ row: row, value: value, keyEdited: keyEdited });\r\n    }\r\n\r\n    radioButtonIconClicked(data: any) {\r\n        this.radioButtonMessageIconClicked.emit(data);\r\n    }\r\n\r\n    filterApplied(tableData: any[]) {\r\n        this.tableData = tableData;\r\n        this.setInitialRowsForTable();\r\n        this.disableEnableEachColumnTooltipIcon();\r\n        this.filterAppliedToTable.emit(tableData);\r\n        this.closeTooltip();\r\n    }\r\n\r\n    sortingApplied(tableData: any[]) {\r\n        this.tableData = tableData;\r\n        this.setInitialRowsForTable();\r\n        this.disableEnableEachColumnTooltipIcon();\r\n        this.sortingAppliedToTable.emit(tableData);\r\n        this.closeTooltip();\r\n    }\r\n}\r\n","<div\r\n    id=\"generic-table-conatiner\"\r\n    class=\"table-container {{ gtGeneralConfig?.tableOuterContainerName }} {{ tableBottomBorderClass }}\"\r\n    [ngClass]=\"{\r\n        'scroll-left-shadow-effect': isScrolledLeft,\r\n        'scroll-right-shadow-effect': !isScrollEnded,\r\n        'clickable-row': clickableRow,\r\n        'no-data-table': (isNoDataToDisplaySubject$ | async)\r\n    }\"\r\n    (scroll)=\"onTableContainerScroll($event)\"\r\n>\r\n    <div\r\n        [class]=\"gtGeneralConfig.tableContainerName\"\r\n        class=\"horizontal-scroll-for-table-container\"\r\n        [ngStyle]=\"{\r\n            height:\r\n                tableData.length < maximumRowsWhichCanBeRenderedWithoutScroll\r\n                    ? 'calc(' +\r\n                      (gtDimension.rowHeight * tableData.length +\r\n                          (!tableData.length || !gtGeneralConfig.totalRow\r\n                              ? gtDimension.headerHeight\r\n                              : gtDimension.headerHeight + gtDimension.rowHeight)) +\r\n                      'px)'\r\n                    : gtDimension.tableHeight\r\n        }\"\r\n    >\r\n        <table\r\n            class=\"gt\"\r\n            [ngClass]=\"tableClass\"\r\n            mat-table\r\n            [dataSource]=\"renderedData\"\r\n        >\r\n            <tr\r\n                class=\"header-row\"\r\n                mat-header-row\r\n                *matHeaderRowDef=\"tableColumns; sticky: true\"\r\n                [style.height.px]=\"gtDimension.headerHeight\"\r\n            ></tr>\r\n            <tr\r\n                class=\"total-row\"\r\n                mat-header-row\r\n                [style.height.px]=\"gtDimension.rowHeight\"\r\n                *matHeaderRowDef=\"totalRowColumns; sticky: true\"\r\n                [class.hidden]=\"\r\n                    showSkeletonLoading ||\r\n                    (!showSkeletonLoading && !tableData.length) ||\r\n                    (isNoDataToDisplaySubject$ | async) ||\r\n                    (!showSkeletonLoading && !gtGeneralConfig.totalRow)\r\n                \"\r\n            ></tr>\r\n            <tr\r\n                [class]=\"rowData.gtClass\"\r\n                [ngClass]=\"{ 'no-border-tr': (isNoDataToDisplaySubject$ | async) }\"\r\n                mat-row\r\n                *matRowDef=\"let rowData; columns: tableColumns\"\r\n                [style.height.px]=\"gtDimension.rowHeight\"\r\n                (click)=\"dataRowClicked(rowData)\"\r\n            ></tr>\r\n\r\n            <!-- TOTAL ROW -->\r\n            <ng-container\r\n                [matColumnDef]=\"column.colName\"\r\n                *ngFor=\"let column of totalRowInfo; trackBy: trackByFn\"\r\n            >\r\n                <td\r\n                    mat-header-cell\r\n                    *matHeaderCellDef\r\n                    [attr.colspan]=\"column.colspan\"\r\n                    class=\"{{ column.class }}\"\r\n                >\r\n                    <ng-container *ngIf=\"column['isActionColumn']\">\r\n                        <a\r\n                            *ngFor=\"let data of column.actionData\"\r\n                            [class]=\"data.class\"\r\n                            (click)=\"onClickableDataClicked({}, data.id)\"\r\n                        >\r\n                            {{ data.name }}\r\n                        </a>\r\n                    </ng-container>\r\n\r\n                    <ng-container *ngIf=\"column['isIconColumn']\">\r\n                        <i\r\n                            class=\"{{ column?.iconData?.class }}\"\r\n                            (click)=\"iconClickedInTotalRow(column?.colName)\"\r\n                        >\r\n                        </i>\r\n                    </ng-container>\r\n\r\n                    <ng-container *ngIf=\"!column['isActionColumn']\">\r\n                        <strong class=\"upper-label\">{{ column.data }}</strong>\r\n                        <ng-container *ngIf=\"column.lowerData\">\r\n                            <br />\r\n                            <span\r\n                                *ngIf=\"\r\n                                    column.colName == 'total-potential-booked-unit' &&\r\n                                        gtGeneralConfig.component == 'RATING';\r\n                                    else columnLowerData\r\n                                \"\r\n                                class=\"clickable-data\"\r\n                                (click)=\"spotDetailsDownloadClicked('TOTALROW')\"\r\n                                [ngClass]=\"{ 'disabled-clickable-data': downloadInProgress }\"\r\n                                >{{ column.lowerData }}\r\n                                <span class=\"material-icons spot-details-download-icons\">get_app</span>\r\n                                <ng-container *ngIf=\"downloadInProgress && selectedRowTypeForDownload == 'TOTALROW'\">\r\n                                    <ng-container [ngTemplateOutlet]=\"circularProgressBar\"></ng-container>\r\n                                </ng-container>\r\n                            </span>\r\n                            <ng-template #columnLowerData>\r\n                                <span class=\"lower-label\">{{ column.lowerData }}</span>\r\n                            </ng-template>\r\n                        </ng-container>\r\n                        <ng-container *ngIf=\"column.tooltipMessage && gtGeneralConfig.component != 'LUR_VIOLATIONS'\">\r\n                            <i\r\n                                class=\"{{ column.tooltipIconClass }}\"\r\n                                container=\"body\"\r\n                                [ngbTooltip]=\"column.tooltipMessage\"\r\n                                tooltipClass=\"gt-total-row-tooltip\"\r\n                                placement=\"bottom\"\r\n                            ></i>\r\n                        </ng-container>\r\n                        <ng-container *ngIf=\"gtGeneralConfig.component == 'LUR_VIOLATIONS' && column.tooltipMessage\">\r\n                            <i\r\n                                class=\"mi mdi-info-outline info-label\"\r\n                                container=\"body\"\r\n                                [ngbTooltip]=\"lurViolationTotalRowToolTip\"\r\n                                tooltipClass=\"gt-total-row-tooltip\"\r\n                                placement=\"bottom\"\r\n                            ></i>\r\n                        </ng-container>\r\n                    </ng-container>\r\n                </td>\r\n            </ng-container>\r\n\r\n            <!-- MAIN ROW -->\r\n            <ng-container\r\n                [matColumnDef]=\"columnDef.headerInfo[0].objectKey\"\r\n                *ngFor=\"let columnDef of tableHeaders; trackBy: trackByFn\"\r\n            >\r\n                <th\r\n                    #tableHeader\r\n                    nowrap\r\n                    mat-header-cell\r\n                    *matHeaderCellDef\r\n                    [style.width]=\"columnDef.width\"\r\n                >\r\n                    <div\r\n                        class=\"row mx-0\"\r\n                        *ngFor=\"let header of columnDef.headerInfo; let j = index\"\r\n                    >\r\n                        <p\r\n                            *ngIf=\"header.typeOfHeaderData === 'STRING'\"\r\n                            [ngClass]=\"{ 'upper-label': j === 0, 'lower-label': j === 1 }\"\r\n                        >\r\n                            <ngx-skeleton-loader\r\n                                *ngIf=\"header.name == null\"\r\n                                count=\"1\"\r\n                                [theme]=\"{\r\n                                    height: '10px',\r\n                                    display: 'block',\r\n                                    width: columnDef.width,\r\n                                    'max-width': 'calc(100% - 20px)'\r\n                                }\"\r\n                            >\r\n                            </ngx-skeleton-loader>\r\n                            <ng-container *ngIf=\"header.name\">\r\n                                {{ header.name }}\r\n                            </ng-container>\r\n                            <ng-container *ngIf=\"header.tooltip && header.tooltip.tooltipMessage\">\r\n                                <i\r\n                                    class=\"{{ header['tooltip'].iconClass }}\"\r\n                                    [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n                                    #t=\"ngbTooltip\"\r\n                                    container=\"body\"\r\n                                    [ngbTooltip]=\"header.tooltip.tooltipMessage\"\r\n                                    container=\"body\"\r\n                                    placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n                                    tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n                                >\r\n                                </i>\r\n                            </ng-container>\r\n                            <i\r\n                                *ngIf=\"header.tooltip && header.tooltip.name == 'impsInfoTooltip'\"\r\n                                class=\"{{ header['tooltip'].iconClass }}\"\r\n                                [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n                                #t=\"ngbTooltip\"\r\n                                container=\"body\"\r\n                                [ngbTooltip]=\"impsInfoTooltip\"\r\n                                container=\"body\"\r\n                                placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n                                tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n                            >\r\n                            </i>\r\n                            <i\r\n                                *ngIf=\"\r\n                                    header.tooltip && header.tooltip.name == 'spotsColumnEquivalizationMessageTooltip'\r\n                                \"\r\n                                class=\"{{ header['tooltip'].iconClass }}\"\r\n                                [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n                                container=\"body\"\r\n                                #t=\"ngbTooltip\"\r\n                                container=\"body\"\r\n                                [ngbTooltip]=\"spotsColumnEquivalizationMessageTooltip\"\r\n                                placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n                                tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n                            >\r\n                            </i>\r\n                            <i\r\n                                *ngIf=\"header.tooltip && header.tooltip.name == 'underDeliveryTooltip'\"\r\n                                class=\"{{ header['tooltip'].iconClass }}\"\r\n                                [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n                                container=\"body\"\r\n                                #t=\"ngbTooltip\"\r\n                                container=\"body\"\r\n                                [ngbTooltip]=\"underDeliveryTooltip\"\r\n                                placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n                                tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n                            >\r\n                            </i>\r\n                            <i\r\n                                *ngIf=\"header.tooltip && header.tooltip.name == 'overDeliveryTooltip'\"\r\n                                class=\"{{ header['tooltip'].iconClass }}\"\r\n                                [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n                                container=\"body\"\r\n                                #t=\"ngbTooltip\"\r\n                                container=\"body\"\r\n                                [ngbTooltip]=\"overDeliveryTooltip\"\r\n                                placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n                                tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n                            >\r\n                            </i>\r\n                            <i\r\n                                *ngIf=\"header.tooltip && header.tooltip.name == 'ratingInfoTooltip'\"\r\n                                class=\"{{ header['tooltip'].iconClass }}\"\r\n                                [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n                                #t=\"ngbTooltip\"\r\n                                container=\"body\"\r\n                                [ngbTooltip]=\"ratingInfoTooltip\"\r\n                                container=\"body\"\r\n                                placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n                                tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n                            >\r\n                            </i>\r\n                            <i\r\n                                *ngIf=\"header.tooltip && header.tooltip.name == 'rateInfoTooltip'\"\r\n                                class=\"{{ header['tooltip'].iconClass }}\"\r\n                                [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n                                #t=\"ngbTooltip\"\r\n                                container=\"body\"\r\n                                [ngbTooltip]=\"rateInfoTooltip\"\r\n                                container=\"body\"\r\n                                placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n                                tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n                            >\r\n                            </i>\r\n                            <i\r\n                                *ngIf=\"header.tooltip && header.tooltip.name == 'ongoingRevBookedColumnTooltip'\"\r\n                                class=\"{{ header['tooltip'].iconClass }}\"\r\n                                [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n                                #t=\"ngbTooltip\"\r\n                                container=\"body\"\r\n                                [ngbTooltip]=\"ongoingRevBookedColumnTooltip\"\r\n                                placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n                                tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n                            >\r\n                            </i>\r\n                            <i\r\n                                *ngIf=\"header.tooltip && header.tooltip.name == 'completedRevBookedColumnTooltip'\"\r\n                                class=\"{{ header['tooltip'].iconClass }}\"\r\n                                [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n                                #t=\"ngbTooltip\"\r\n                                container=\"body\"\r\n                                [ngbTooltip]=\"completedRevBookedColumnTooltip\"\r\n                                placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n                                tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n                            >\r\n                            </i>\r\n                            <i\r\n                                *ngIf=\"header.tooltip && header.tooltip.name == 'avgBookedRate'\"\r\n                                class=\"{{ header['tooltip'].iconClass }}\"\r\n                                [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n                                #t=\"ngbTooltip\"\r\n                                container=\"body\"\r\n                                [ngbTooltip]=\"avgBookedRate\"\r\n                                placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n                                tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n                            >\r\n                            </i>\r\n                            <i\r\n                                *ngIf=\"header.tooltip && header.tooltip.name == 'avgBookedRtg'\"\r\n                                class=\"{{ header['tooltip'].iconClass }}\"\r\n                                [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n                                #t=\"ngbTooltip\"\r\n                                container=\"body\"\r\n                                [ngbTooltip]=\"avgBookedRtg\"\r\n                                placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n                                tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n                            >\r\n                            </i>\r\n                            <i\r\n                                *ngIf=\"header.tooltip && header.tooltip.name == 'avgBookedImps'\"\r\n                                class=\"{{ header['tooltip'].iconClass }}\"\r\n                                [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n                                #t=\"ngbTooltip\"\r\n                                container=\"body\"\r\n                                [ngbTooltip]=\"avgBookedImps\"\r\n                                placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n                                tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n                            >\r\n                            </i>\r\n\r\n                            <i\r\n                                *ngIf=\"header.tooltip && header.tooltip.name == 'automationTooltip'\"\r\n                                class=\"{{ header['tooltip'].iconClass }}\"\r\n                                [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n                                #t=\"ngbTooltip\"\r\n                                container=\"body\"\r\n                                [ngbTooltip]=\"automationTooltip\"\r\n                                placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n                                tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n                            >\r\n                            </i>\r\n\r\n                            <i\r\n                                *ngIf=\"header.tooltip && header.tooltip.name == 'rebateImpact'\"\r\n                                class=\"{{ header['tooltip'].iconClass }}\"\r\n                                [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n                                #t=\"ngbTooltip\"\r\n                                container=\"body\"\r\n                                [ngbTooltip]=\"rebateImpact\"\r\n                                placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n                                tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n                            >\r\n                            </i>\r\n\r\n                            <i\r\n                                *ngIf=\"header.tooltip && header.tooltip.name == 'projectedImpsRtg'\"\r\n                                class=\"{{ header['tooltip'].iconClass }}\"\r\n                                [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n                                #t=\"ngbTooltip\"\r\n                                container=\"body\"\r\n                                [ngbTooltip]=\"projectedImpsRtg\"\r\n                                placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n                                tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n                            >\r\n                            </i>\r\n                        </p>\r\n\r\n                        <ng-container *ngIf=\"header.typeOfHeaderData === 'CHECKBOX'\">\r\n                            <span\r\n                                *ngIf=\"gtGeneralConfig.isHeaderChecked\"\r\n                                class=\"material-icons custom-column-checkbox-checked\"\r\n                                (click)=\"selectUnselectAllRows()\"\r\n                            >\r\n                                check_box\r\n                            </span>\r\n                            <span\r\n                                *ngIf=\"!gtGeneralConfig.isHeaderChecked\"\r\n                                class=\"material-icons custom-column-checkbox-unchecked\"\r\n                                [ngClass]=\"{ 'disable-checkbox': gtGeneralConfig.disableHeaderCheckbox }\"\r\n                                (click)=\"selectUnselectAllRows()\"\r\n                            >\r\n                                check_box_outline_blank\r\n                            </span>\r\n                        </ng-container>\r\n\r\n                        <div\r\n                            *ngIf=\"gtGeneralConfig.showAllColumnFilter\"\r\n                            class=\"sort-filter-container\"\r\n                        >\r\n                            <ng-container *ngIf=\"header.showTooltipIcon\">\r\n                                <!-- Active tooltip Functionality -->\r\n                                <ng-container *ngIf=\"header.filter === 'CHECKBOX'\">\r\n                                    <span\r\n                                        class=\"mdi mdi-filter-variant\"\r\n                                        [ngClass]=\"{\r\n                                            active:\r\n                                                annaFilterService.isFilterSortActive &&\r\n                                                annaFilterService.isFilterSortActive[header.joinedFilterSortObjectKeys],\r\n                                            disabled: header.disableTooltipIcon || showSkeletonLoading\r\n                                        }\"\r\n                                        [ngbTooltip]=\"filterTooltip\"\r\n                                        placement=\"{{ filterAlignment }}\"\r\n                                        container=\"body\"\r\n                                        tooltipClass=\"non-edit-checkbox-tooltip\"\r\n                                        [autoClose]=\"'outside'\"\r\n                                        triggers=\"manual\"\r\n                                        #t=\"ngbTooltip\"\r\n                                        (click)=\"bindTheValueToToolTip(t, header)\"\r\n                                        (hidden)=\"closeTooltip()\"\r\n                                    >\r\n                                    </span\r\n                                    ><br />\r\n                                </ng-container>\r\n                                <ng-container *ngIf=\"header.filter === 'SLIDER'\">\r\n                                    <span\r\n                                        class=\"mdi mdi-filter-variant\"\r\n                                        [ngClass]=\"{\r\n                                            active:\r\n                                                annaFilterService.isFilterSortActive &&\r\n                                                annaFilterService.isFilterSortActive[header.joinedFilterSortObjectKeys],\r\n                                            disabled: header.disableTooltipIcon || showSkeletonLoading\r\n                                        }\"\r\n                                        [ngbTooltip]=\"sliderToolTip\"\r\n                                        placement=\"bottom left-top\"\r\n                                        container=\"body\"\r\n                                        tooltipClass=\"non-edit-slider-tooltip\"\r\n                                        [autoClose]=\"'outside'\"\r\n                                        triggers=\"manual\"\r\n                                        #t1=\"ngbTooltip\"\r\n                                        (click)=\"bindTheValueToToolTip(t1, header)\"\r\n                                        (hidden)=\"closeTooltip()\"\r\n                                    >\r\n                                    </span\r\n                                    ><br />\r\n                                </ng-container>\r\n                                <ng-container *ngIf=\"header.filter === 'DATE'\">\r\n                                    <span\r\n                                        class=\"mdi mdi-filter-variant\"\r\n                                        [ngClass]=\"{\r\n                                            active:\r\n                                                annaFilterService.isFilterSortActive &&\r\n                                                annaFilterService.isFilterSortActive[header.joinedFilterSortObjectKeys],\r\n                                            disabled: header.disableTooltipIcon || showSkeletonLoading\r\n                                        }\"\r\n                                        [ngbTooltip]=\"datePickerTooltip\"\r\n                                        placement=\"bottom auto\"\r\n                                        container=\"body\"\r\n                                        tooltipClass=\"non-edit-datepicker-tooltip\"\r\n                                        [autoClose]=\"'outside'\"\r\n                                        triggers=\"manual\"\r\n                                        #t2=\"ngbTooltip\"\r\n                                        (click)=\"bindTheValueToToolTip(t2, header)\"\r\n                                        (hidden)=\"closeTooltip()\"\r\n                                    >\r\n                                    </span\r\n                                    ><br />\r\n                                </ng-container>\r\n                                <ng-container *ngIf=\"header.filter === 'WEEK'\">\r\n                                    <span\r\n                                        class=\"mdi mdi-filter-variant\"\r\n                                        [ngClass]=\"{\r\n                                            active:\r\n                                                annaFilterService.isFilterSortActive &&\r\n                                                annaFilterService.isFilterSortActive[header.joinedFilterSortObjectKeys],\r\n                                            disabled: header.disableTooltipIcon || showSkeletonLoading\r\n                                        }\"\r\n                                        [ngbTooltip]=\"weekPickerToolTip\"\r\n                                        placement=\"bottom left-top\"\r\n                                        container=\"body\"\r\n                                        [autoClose]=\"'outside'\"\r\n                                        triggers=\"manual\"\r\n                                        #t3=\"ngbTooltip\"\r\n                                        (click)=\"bindTheValueToToolTip(t3, header)\"\r\n                                        (hidden)=\"closeTooltip()\"\r\n                                    >\r\n                                    </span\r\n                                    ><br />\r\n                                </ng-container>\r\n                                <ng-container *ngIf=\"header.filter === 'TIME'\">\r\n                                    <span\r\n                                        class=\"mdi mdi-filter-variant\"\r\n                                        [ngClass]=\"{\r\n                                            active:\r\n                                                annaFilterService.isFilterSortActive &&\r\n                                                annaFilterService.isFilterSortActive[header.joinedFilterSortObjectKeys],\r\n                                            disabled: header.disableTooltipIcon || showSkeletonLoading\r\n                                        }\"\r\n                                        [ngbTooltip]=\"timeFilterToolTip\"\r\n                                        placement=\"bottom left-top auto\"\r\n                                        container=\"body\"\r\n                                        tooltipClass=\"non-edit-time-tooltip\"\r\n                                        [autoClose]=\"'outside'\"\r\n                                        triggers=\"manual\"\r\n                                        #t4=\"ngbTooltip\"\r\n                                        (click)=\"bindTheValueToToolTip(t4, header)\"\r\n                                        (hidden)=\"closeTooltip()\"\r\n                                    >\r\n                                    </span\r\n                                    ><br />\r\n                                </ng-container>\r\n                            </ng-container>\r\n                            <ng-container *ngIf=\"!header.showTooltipIcon\">\r\n                                <span id=\"no-filter-space\"></span><br />\r\n                            </ng-container>\r\n                            <i\r\n                                *ngIf=\"header.tooltip && header.tooltip.name == 'lurViolationInfoTooltip'\"\r\n                                class=\"{{ header['tooltip'].iconClass }}\"\r\n                                [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\r\n                                #t=\"ngbTooltip\"\r\n                                container=\"body\"\r\n                                [ngbTooltip]=\"lurViolationInfoTooltip\"\r\n                                placement=\"{{ header['tooltip'].tooltipPosition }}\"\r\n                                tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\r\n                            >\r\n                            </i>\r\n                        </div>\r\n                    </div>\r\n                </th>\r\n\r\n                <ng-container *matCellDef=\"let ROW_DATA\">\r\n                    <td\r\n                        mat-cell\r\n                        [style.background]=\"ROW_DATA.backgroundColor\"\r\n                        [style.border]=\"ROW_DATA.border\"\r\n                        class=\"{{ ROW_DATA.rowClass }}\"\r\n                        [ngClass]=\"ROW_DATA[columnDef.headerInfo[0].objectKey + 'TdClass']\"\r\n                        [attr.rowspan]=\"ROW_DATA[columnDef.headerInfo[0].objectKey + 'Rowspan']\"\r\n                        *ngIf=\"\r\n                            !hideSomeTds ||\r\n                            (hideSomeTds && !ROW_DATA['hide' + columnDef.headerInfo[0].objectKey + 'Td'])\r\n                        \"\r\n                    >\r\n                        <ngx-skeleton-loader\r\n                            *ngIf=\"showSkeletonLoading\"\r\n                            count=\"1\"\r\n                            [theme]=\"{ height: '10px', display: 'block' }\"\r\n                        >\r\n                        </ngx-skeleton-loader>\r\n\r\n                        <ng-container *ngIf=\"!showSkeletonLoading\">\r\n                            <ng-container *ngIf=\"tableData.length > 0 && !(isNoDataToDisplaySubject$ | async)\">\r\n                                <ng-container\r\n                                    *ngFor=\"\r\n                                        let subline of columnDef.headerInfo;\r\n                                        let subLineIndex = index;\r\n                                        trackBy: trackByFn\r\n                                    \"\r\n                                >\r\n                                    <div showEllipsisTextOnHover>\r\n                                        <ng-container [ngSwitch]=\"columnDef.headerInfo[subLineIndex].typeOfBodyData\">\r\n                                            <ng-container *ngSwitchCase=\"'ICON'\">\r\n                                                <i\r\n                                                    *ngIf=\"\r\n                                                        !(\r\n                                                            starredInProgress &&\r\n                                                            ROW_DATA.orderId == selectedStarredOrderId\r\n                                                        )\r\n                                                    \"\r\n                                                    [class]=\"ROW_DATA.iconClass\"\r\n                                                    (click)=\"iconClicked(ROW_DATA, ROW_DATA.iconClass)\"\r\n                                                    ngbTooltip=\"{{ ROW_DATA.iconTitleText }}\"\r\n                                                    placement=\"bottom\"\r\n                                                    container=\"body\"\r\n                                                    tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\r\n                                                ></i>\r\n                                                <ng-container\r\n                                                    *ngIf=\"\r\n                                                        starredInProgress && ROW_DATA.orderId == selectedStarredOrderId\r\n                                                    \"\r\n                                                >\r\n                                                    <div class=\"spinner-for-button-directive\"></div>\r\n                                                </ng-container>\r\n                                            </ng-container>\r\n\r\n                                            <ng-container *ngSwitchCase=\"'ICON_CELL'\">\r\n                                                <ng-container\r\n                                                    *ngFor=\"\r\n                                                        let action of ROW_DATA[\r\n                                                            columnDef.headerInfo[subLineIndex].actionKey\r\n                                                        ]\r\n                                                    \"\r\n                                                >\r\n                                                    <ng-container *ngIf=\"action.showObjectKey\">\r\n                                                        {{ ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey] }}\r\n                                                    </ng-container>\r\n\r\n                                                    <i\r\n                                                        *ngIf=\"action.showIcon\"\r\n                                                        [class]=\"action.iconClass\"\r\n                                                        (mouseenter)=\"\r\n                                                            mouseEnterOnStringTextActionType(\r\n                                                                ROW_DATA,\r\n                                                                columnDef.headerInfo[subLineIndex].tooltipKey\r\n                                                            )\r\n                                                        \"\r\n                                                        placement=\"bottom auto\"\r\n                                                        container=\"body\"\r\n                                                        [autoClose]=\"true\"\r\n                                                        tooltipClass=\"team-user-tooltip remove-on-scroll-class\"\r\n                                                        [ngbTooltip]=\"action.showTooltip ? action.tooltipData : null\"\r\n                                                        (click)=\"\r\n                                                            textActionClicked(\r\n                                                                ROW_DATA,\r\n                                                                action.id,\r\n                                                                columnDef.headerInfo[subLineIndex]\r\n                                                            )\r\n                                                        \"\r\n                                                        [disableTooltip]=\"!action.showTooltip\"\r\n                                                    >\r\n                                                    </i>\r\n\r\n                                                </ng-container>\r\n                                            </ng-container>\r\n\r\n                                            <ng-container *ngSwitchCase=\"'HTML_STRING'\">\r\n                                                <p\r\n                                                    [innerHTML]=\"ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\r\n                                                    (click)=\"innerHTMLCellClicked($event, ROW_DATA)\"\r\n                                                ></p>\r\n                                            </ng-container>\r\n\r\n                                            <ng-container *ngSwitchCase=\"'SVG_ICON'\">\r\n                                                <anna-core-anna-icon-column\r\n                                                    [componentName]=\"gtGeneralConfig.component\"\r\n                                                    [dataObject]=\"ROW_DATA\"\r\n                                                    [iconToShow]=\"\r\n                                                        ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n                                                    \"\r\n                                                    (onColumnIconClicked)=\"svgIconClicked($event)\"\r\n                                                ></anna-core-anna-icon-column>\r\n                                            </ng-container>\r\n\r\n                                            <ng-container *ngSwitchCase=\"'TEXT_ACTIONS'\">\r\n                                                <ng-container\r\n                                                    *ngFor=\"\r\n                                                        let text of ROW_DATA[\r\n                                                            columnDef.headerInfo[subLineIndex].actionKey\r\n                                                        ]\r\n                                                    \"\r\n                                                >\r\n                                                    <button\r\n                                                        *ngIf=\"text.showTooltip\"\r\n                                                        (click)=\"\r\n                                                            textActionClicked(\r\n                                                                ROW_DATA,\r\n                                                                text.id,\r\n                                                                columnDef.headerInfo[subLineIndex]\r\n                                                            )\r\n                                                        \"\r\n                                                        [disabled]=\"text.isDisabled\"\r\n                                                        class=\"{{ text.class }}\"\r\n                                                        (mouseenter)=\"\r\n                                                            mouseEnterOnTextActionType(\r\n                                                                ROW_DATA,\r\n                                                                columnDef.headerInfo[subLineIndex].tooltipKey\r\n                                                            )\r\n                                                        \"\r\n                                                        [ngbTooltip]=\"textActionTooltipTemplate\"\r\n                                                        placement=\"auto\"\r\n                                                        container=\"body\"\r\n                                                        tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\r\n                                                    >\r\n                                                        {{ text.name }}\r\n                                                    </button>\r\n\r\n                                                    <button\r\n                                                        *ngIf=\"!text.showTooltip\"\r\n                                                        (click)=\"\r\n                                                            textActionClicked(\r\n                                                                ROW_DATA,\r\n                                                                text.id,\r\n                                                                columnDef.headerInfo[subLineIndex]\r\n                                                            )\r\n                                                        \"\r\n                                                        [disabled]=\"text.isDisabled\"\r\n                                                        class=\"{{ text.class }}\"\r\n                                                    >\r\n                                                        {{ text.name }}\r\n                                                    </button>\r\n                                                </ng-container>\r\n                                            </ng-container>\r\n\r\n                                            <ng-container *ngSwitchCase=\"'CHECKBOX'\">\r\n                                                <span\r\n                                                    *ngIf=\"ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\r\n                                                    [ngClass]=\"{\r\n                                                        'disable-checkbox':\r\n                                                            ROW_DATA[columnDef.headerInfo[subLineIndex].isDisabledKey]\r\n                                                    }\"\r\n                                                    class=\"material-icons custom-column-checkbox-checked\"\r\n                                                    (click)=\"\r\n                                                        selectOrUnselectCheckbox(\r\n                                                            ROW_DATA,\r\n                                                            columnDef.headerInfo[subLineIndex].objectKey,\r\n                                                            false\r\n                                                        )\r\n                                                    \"\r\n                                                >\r\n                                                    check_box\r\n                                                </span>\r\n                                                <span\r\n                                                    *ngIf=\"!ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\r\n                                                    class=\"material-icons custom-column-checkbox-unchecked\"\r\n                                                    [ngClass]=\"{\r\n                                                        'disable-checkbox':\r\n                                                            ROW_DATA[columnDef.headerInfo[subLineIndex].isDisabledKey]\r\n                                                    }\"\r\n                                                    (click)=\"\r\n                                                        selectOrUnselectCheckbox(\r\n                                                            ROW_DATA,\r\n                                                            columnDef.headerInfo[subLineIndex].objectKey,\r\n                                                            true\r\n                                                        )\r\n                                                    \"\r\n                                                >\r\n                                                    check_box_outline_blank\r\n                                                </span>\r\n\r\n                                                <ng-container\r\n                                                    *ngFor=\"\r\n                                                        let action of ROW_DATA[\r\n                                                            columnDef.headerInfo[subLineIndex].actionKey\r\n                                                        ]\r\n                                                    \"\r\n                                                >\r\n                                                    <i\r\n                                                        *ngIf=\"action.showIcon\"\r\n                                                        [class]=\"action.iconClass\"\r\n                                                        [ngClass]=\"{ disabled: action.disabledIcon }\"\r\n                                                        (mouseenter)=\"\r\n                                                            mouseEnterOnStringTextActionTypeContainingTable(\r\n                                                                ROW_DATA,\r\n                                                                columnDef.headerInfo[subLineIndex].tooltipKey\r\n                                                            )\r\n                                                        \"\r\n                                                        placement=\"bottom auto\"\r\n                                                        container=\"body\"\r\n                                                        [autoClose]=\"true\"\r\n                                                        tooltipClass=\"tooltip-containing-table remove-on-scroll-class\"\r\n                                                        [ngbTooltip]=\"tooltipContainingTableTemplate\"\r\n                                                    >\r\n                                                    </i>\r\n                                                </ng-container>\r\n                                            </ng-container>\r\n\r\n                                            <ng-container *ngSwitchCase=\"'CLICKABLE_DATA'\">\r\n                                                <a\r\n                                                    *ngFor=\"\r\n                                                        let text of ROW_DATA[\r\n                                                            columnDef.headerInfo[subLineIndex].actionKey\r\n                                                        ]\r\n                                                    \"\r\n                                                    [class]=\"text.class\"\r\n                                                    (click)=\"onClickableDataClicked(ROW_DATA, text.id)\"\r\n                                                >\r\n                                                    {{ text.name }}\r\n                                                </a>\r\n                                                <span\r\n                                                    *ngIf=\"\r\n                                                        subline.objectKey == 'displayBookedUnits' &&\r\n                                                        gtGeneralConfig.component == 'RATING'\r\n                                                    \"\r\n                                                    class=\"clickable-data\"\r\n                                                    (click)=\"spotDetailsDownloadClicked('DATAROW', ROW_DATA)\"\r\n                                                    [ngClass]=\"{ 'disabled-clickable-data': downloadInProgress }\"\r\n                                                    >{{ ROW_DATA.displayBookedUnits }}\r\n                                                    <span class=\"material-icons spot-details-download-icons\"\r\n                                                        >get_app</span\r\n                                                    >\r\n                                                    <ng-container\r\n                                                        *ngIf=\"\r\n                                                            downloadInProgress &&\r\n                                                            ROW_DATA.inventoryCodeId ==\r\n                                                                selectedInventoryIdForDownload &&\r\n                                                            ROW_DATA.demographic == selectedDemographicForDownload\r\n                                                        \"\r\n                                                    >\r\n                                                        <ng-container\r\n                                                            [ngTemplateOutlet]=\"circularProgressBar\"\r\n                                                        ></ng-container>\r\n                                                    </ng-container>\r\n                                                </span>\r\n                                            </ng-container>\r\n\r\n                                            <ng-container *ngSwitchCase=\"'STRING___ICON_OR_TEXT_ACTION'\">\r\n                                                <ng-container\r\n                                                    *ngFor=\"\r\n                                                        let action of ROW_DATA[\r\n                                                            columnDef.headerInfo[subLineIndex].actionKey\r\n                                                        ]\r\n                                                    \"\r\n                                                >\r\n                                                    <span\r\n                                                        [class]=\"action.additionalTextBeforeLinkClass\"\r\n                                                        [innerHtml]=\"action.additionalTextBeforeLink\"\r\n                                                        ngbTooltip=\"{{ action.additionalTextBeforeLink }}\"\r\n                                                        placement=\"bottom\"\r\n                                                        container=\"body\"\r\n                                                        tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\r\n                                                        [disableTooltip]=\"!action.enableTooltipForAdditionalText\"\r\n                                                    ></span>\r\n\r\n                                                    <ng-container *ngIf=\"action && action.typeOfData == 'STRING'\">\r\n                                                        {{ action.data }}\r\n                                                    </ng-container>\r\n\r\n                                                    <a\r\n                                                        [id]=\"action.id\"\r\n                                                        *ngIf=\"action.showLink\"\r\n                                                        (click)=\"\r\n                                                            textActionClicked(\r\n                                                                ROW_DATA,\r\n                                                                action.id,\r\n                                                                columnDef.headerInfo[subLineIndex]\r\n                                                            )\r\n                                                        \"\r\n                                                        [class]=\"action.linkClass\"\r\n                                                        [ngClass]=\"{ disabled: action.disabledLink }\"\r\n                                                        >{{ action.data }}</a\r\n                                                    >\r\n                                                    <span\r\n                                                        ngbTooltip=\"{{ action.additionalTextAfterLink }}\"\r\n                                                        placement=\"bottom\"\r\n                                                        container=\"body\"\r\n                                                        [class]=\"action.additionalTextAfterLinkClass\"\r\n                                                        tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\r\n                                                        [disableTooltip]=\"!action.enableTooltipForAdditionalAfterText\"\r\n                                                    >\r\n                                                        {{ action.additionalTextAfterLink }}\r\n                                                    </span>\r\n\r\n                                                    <ng-container *ngIf=\"action.showTooltip\">\r\n                                                        <ng-container *ngIf=\"action.tooltipData.innerHtml\">\r\n                                                            <i\r\n                                                                *ngIf=\"action.showIcon\"\r\n                                                                [class]=\"action.iconClass\"\r\n                                                                [ngClass]=\"{ disabled: action.disabledIcon }\"\r\n                                                                (mouseenter)=\"\r\n                                                                    mouseEnterOnStringTextActionTypeContainingTable(\r\n                                                                        ROW_DATA,\r\n                                                                        columnDef.headerInfo[subLineIndex].tooltipKey\r\n                                                                    )\r\n                                                                \"\r\n                                                                placement=\"bottom auto\"\r\n                                                                container=\"body\"\r\n                                                                [autoClose]=\"true\"\r\n                                                                tooltipClass=\"tooltip-containing-table remove-on-scroll-class\"\r\n                                                                [ngbTooltip]=\"tooltipContainingTableTemplate\"\r\n                                                            >\r\n                                                            </i>\r\n                                                        </ng-container>\r\n\r\n                                                        <ng-container *ngIf=\"!action.tooltipData.tooltipTableBody\">\r\n                                                            <i\r\n                                                                *ngIf=\"action.showIcon\"\r\n                                                                [class]=\"action.iconClass\"\r\n                                                                [ngClass]=\"{ disabled: action.disabledIcon }\"\r\n                                                                (click)=\"\r\n                                                                    iconClickedOnStringIconActionType(\r\n                                                                        ROW_DATA,\r\n                                                                        action.id,\r\n                                                                        columnDef.headerInfo[subLineIndex]\r\n                                                                    )\r\n                                                                \"\r\n                                                                (mouseleave)=\"mouseLeaveTextActionType(ROW_DATA)\"\r\n                                                                (mouseenter)=\"\r\n                                                                    mouseEnterOnStringTextActionType(\r\n                                                                        ROW_DATA,\r\n                                                                        columnDef.headerInfo[subLineIndex].tooltipKey\r\n                                                                    )\r\n                                                                \"\r\n                                                                [placement]=\"\r\n                                                                    action.tooltipPlacement\r\n                                                                        ? action.tooltipPlacement\r\n                                                                        : 'bottom auto'\r\n                                                                \"\r\n                                                                container=\"body\"\r\n                                                                [autoClose]=\"true\"\r\n                                                                tooltipClass=\"team-user-tooltip remove-on-scroll-class {{\r\n                                                                    action.tooltipClass\r\n                                                                }}\"\r\n                                                                [ngbTooltip]=\"userLoggedInDetails\"\r\n                                                            >\r\n                                                            </i>\r\n                                                            <ng-container *ngIf=\"action['showSvgIcon']\">\r\n                                                                <anna-core-anna-est-icon-template\r\n                                                                    class=\"float-right\"\r\n                                                                    *ngIf=\"action['svgIconName'] == 'anna-icon'\"\r\n                                                                    (mouseleave)=\"mouseLeaveTextActionType(ROW_DATA)\"\r\n                                                                    (mouseenter)=\"\r\n                                                                        mouseEnterOnStringTextActionType(\r\n                                                                            ROW_DATA,\r\n                                                                            columnDef.headerInfo[subLineIndex]\r\n                                                                                .tooltipKey\r\n                                                                        )\r\n                                                                    \"\r\n                                                                    [placement]=\"\r\n                                                                        action.tooltipPlacement\r\n                                                                            ? action.tooltipPlacement\r\n                                                                            : 'bottom auto'\r\n                                                                    \"\r\n                                                                    tooltipClass=\"team-user-tooltip remove-on-scroll-class {{\r\n                                                                        action['tooltipClass']\r\n                                                                    }}\"\r\n                                                                    [ngbTooltip]=\"userLoggedInDetails\"\r\n                                                                    container=\"body\"\r\n                                                                    [autoClose]=\"true\"\r\n                                                                >\r\n                                                                </anna-core-anna-est-icon-template>\r\n                                                            </ng-container>\r\n                                                        </ng-container>\r\n                                                    </ng-container>\r\n\r\n                                                    <ng-container *ngIf=\"!action.showTooltip\">\r\n                                                        <i\r\n                                                            *ngIf=\"action.showIcon\"\r\n                                                            [class]=\"action.iconClass\"\r\n                                                            [ngClass]=\"{ disabled: action.disabledIcon }\"\r\n                                                            (click)=\"\r\n                                                                iconClickedOnStringIconActionType(\r\n                                                                    ROW_DATA,\r\n                                                                    action.id,\r\n                                                                    columnDef.headerInfo[subLineIndex]\r\n                                                                )\r\n                                                            \"\r\n                                                        >\r\n                                                        </i>\r\n                                                    </ng-container>\r\n                                                </ng-container>\r\n                                            </ng-container>\r\n\r\n                                            <ng-container *ngSwitchCase=\"'STRING_OR_INPUT'\">\r\n                                                <ng-container\r\n                                                    *ngIf=\"\r\n                                                        ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]?.type ==\r\n                                                            'STRING';\r\n                                                        else inputBox\r\n                                                    \"\r\n                                                >\r\n                                                    <span\r\n                                                        [innerHtml]=\"\r\n                                                            ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n                                                                ?.value\r\n                                                        \"\r\n                                                    ></span>\r\n                                                </ng-container>\r\n                                                <ng-template #inputBox>\r\n                                                    <input\r\n                                                        placeholder=\"{{\r\n                                                            ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n                                                                ?.placeholder\r\n                                                        }}\"\r\n                                                        showEllipsisTextOnHover\r\n                                                        class=\"{{\r\n                                                            ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n                                                                .className\r\n                                                        }}\"\r\n                                                        (keydown)=\"\r\n                                                            changesMadeInEditableInputBox(\r\n                                                                $event,\r\n                                                                ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey],\r\n                                                                false\r\n                                                            )\r\n                                                        \"\r\n                                                        (paste)=\"\r\n                                                            changesMadeInEditableInputBox(\r\n                                                                $event,\r\n                                                                ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey],\r\n                                                                true\r\n                                                            )\r\n                                                        \"\r\n                                                        (ngModelChange)=\"\r\n                                                            editableInputValueChanged(\r\n                                                                $event,\r\n                                                                ROW_DATA,\r\n                                                                columnDef.headerInfo[subLineIndex].objectKey\r\n                                                            )\r\n                                                        \"\r\n                                                        [ngModel]=\"\r\n                                                            ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey].value\r\n                                                        \"\r\n                                                        [disabled]=\"\r\n                                                            ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n                                                                .disabled\r\n                                                        \"\r\n                                                        [ngClass]=\"{\r\n                                                            'red-border':\r\n                                                                ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n                                                                    .hasError\r\n                                                        }\"\r\n                                                    />\r\n\r\n                                                    <i\r\n                                                        *ngIf=\"\r\n                                                            ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n                                                                .showIcon\r\n                                                        \"\r\n                                                        container=\"body\"\r\n                                                        [ngbTooltip]=\"\r\n                                                            ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n                                                                .iconTooltip\r\n                                                        \"\r\n                                                        tooltipClass=\"gt-total-row-tooltip\"\r\n                                                        placement=\"bottom\"\r\n                                                        class=\"{{\r\n                                                            ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n                                                                .iconClass\r\n                                                        }}\"\r\n                                                    >\r\n                                                    </i>\r\n                                                    <ng-container\r\n                                                        *ngIf=\"\r\n                                                            ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey][\r\n                                                                'showSvgIcon'\r\n                                                            ]\r\n                                                        \"\r\n                                                    >\r\n                                                        <anna-core-anna-est-icon-template\r\n                                                            class=\"float-right\"\r\n                                                            *ngIf=\"\r\n                                                                ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey][\r\n                                                                    'svgIconName'\r\n                                                                ] == 'anna-icon'\r\n                                                            \"\r\n                                                            [placement]=\"'bottom auto'\"\r\n                                                            tooltipClass=\"gt-total-row-tooltip\"\r\n                                                            [ngbTooltip]=\"\r\n                                                                ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n                                                                    .iconTooltip\r\n                                                            \"\r\n                                                            container=\"body\"\r\n                                                        >\r\n                                                        </anna-core-anna-est-icon-template>\r\n                                                    </ng-container>\r\n                                                </ng-template>\r\n                                            </ng-container>\r\n\r\n                                            <ng-container *ngSwitchCase=\"'HTML'\">\r\n                                                <span\r\n                                                    [innerHtml]=\"ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\r\n                                                ></span>\r\n                                            </ng-container>\r\n\r\n                                            <ng-container *ngSwitchCase=\"'SINGLE_RADIO'\">\r\n                                                <span\r\n                                                    *ngIf=\"ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\r\n                                                    [ngClass]=\"{\r\n                                                        'disable-checkbox':\r\n                                                            ROW_DATA[columnDef.headerInfo[subLineIndex].isDisabledKey]\r\n                                                    }\"\r\n                                                    class=\"mdi mdi-radiobox-marked\"\r\n                                                    (click)=\"(null)\"\r\n                                                >\r\n                                                </span>\r\n                                                <span\r\n                                                    *ngIf=\"!ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\r\n                                                    class=\"mdi mdi-radiobox-blank\"\r\n                                                    [ngClass]=\"{\r\n                                                        'disable-checkbox':\r\n                                                            ROW_DATA[columnDef.headerInfo[subLineIndex].isDisabledKey]\r\n                                                    }\"\r\n                                                    (click)=\"\r\n                                                        selectOrUnselectCheckbox(\r\n                                                            ROW_DATA,\r\n                                                            columnDef.headerInfo[subLineIndex].objectKey,\r\n                                                            true\r\n                                                        )\r\n                                                    \"\r\n                                                >\r\n                                                </span>\r\n                                            </ng-container>\r\n\r\n                                            <ng-container *ngSwitchCase=\"'RADIO'\">\r\n                                                <mat-radio-group\r\n                                                    *ngIf=\"ROW_DATA['RadioButtonConfig']\"\r\n                                                    [ngModel]=\"ROW_DATA[subline.objectKey]\"\r\n                                                    [disabled]=\"ROW_DATA['RadioButtonConfig'][0].isDisabled\"\r\n                                                >\r\n                                                    <ng-container\r\n                                                        *ngFor=\"\r\n                                                            let radioButton of ROW_DATA['RadioButtonConfig'];\r\n                                                            let last = last\r\n                                                        \"\r\n                                                    >\r\n                                                        <mat-radio-button\r\n                                                            value=\"{{ radioButton.value }}\"\r\n                                                            class=\"{{ radioButton.class }}\"\r\n                                                            (click)=\"\r\n                                                                radioButtonClicked(\r\n                                                                    ROW_DATA,\r\n                                                                    radioButton.value,\r\n                                                                    ROW_DATA['RadioButtonConfig'][0].isDisabled\r\n                                                                )\r\n                                                            \"\r\n                                                            >{{ radioButton.label }}\r\n                                                        </mat-radio-button>\r\n                                                        <i\r\n                                                            class=\" {{ radioButton.iconClass }}\"\r\n                                                            (click)=\"radioButtonIconClicked(ROW_DATA)\"\r\n                                                        ></i>\r\n                                                        <br *ngIf=\"!last\" />\r\n                                                    </ng-container>\r\n                                                </mat-radio-group>\r\n                                            </ng-container>\r\n\r\n                                            <ng-container *ngSwitchCase=\"'STRING_WITH_TOOLTIP'\">\r\n                                                <ng-container\r\n                                                    *ngFor=\"\r\n                                                        let action of ROW_DATA[\r\n                                                            columnDef.headerInfo[subLineIndex].actionKey\r\n                                                        ]\r\n                                                    \"\r\n                                                >\r\n                                                    <span> {{ action?.dataToDisplay }}</span>\r\n                                                    <span\r\n                                                        *ngIf=\"action?.showTooltip\"\r\n                                                        [ngbTooltip]=\"textActionTooltipTemplate\"\r\n                                                        (mouseenter)=\"\r\n                                                            mouseEnterOnStringTextActionType(\r\n                                                                ROW_DATA,\r\n                                                                columnDef.headerInfo[subLineIndex].tooltipKey\r\n                                                            )\r\n                                                        \"\r\n                                                        [placement]=\"action?.tooltipPosition\"\r\n                                                        container=\"body\"\r\n                                                        [class]=\"action?.tooltipIconClass\"\r\n                                                        tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\r\n                                                        [disableTooltip]=\"action?.disableTooltip\"\r\n                                                    >\r\n                                                    </span>\r\n                                                    <span> {{ action?.dataToDisplayAfterTooltip }}</span>\r\n                                                </ng-container>\r\n                                            </ng-container>\r\n\r\n                                            <ng-container *ngSwitchDefault>\r\n                                                <ng-container *ngIf=\"subline.objectKey != 'description'\">\r\n                                                    <span>{{\r\n                                                        ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\r\n                                                    }}</span>\r\n                                                    <i\r\n                                                        *ngIf=\"\r\n                                                            subline.objectKey == 'inventoryCode' &&\r\n                                                            ROW_DATA['isSellerGroup'] &&\r\n                                                            gtGeneralConfig.component == 'RATING'\r\n                                                        \"\r\n                                                        class=\"mi mdi-info-outline seller-tooltip\"\r\n                                                        [ngbTooltip]=\"sellerHierarchyTooltip\"\r\n                                                        placement=\"bottom auto\"\r\n                                                        container=\"body\"\r\n                                                        [autoClose]=\"true\"\r\n                                                        triggers=\"manual\"\r\n                                                        (hidden)=\"closeTooltip()\"\r\n                                                        #info=\"ngbTooltip\"\r\n                                                        tooltipClass=\"hierarchy-tooltip remove-on-scroll-class\"\r\n                                                        (mouseenter)=\"\r\n                                                            bindTheValueToSellerGroupTooltip(\r\n                                                                ROW_DATA.sellerGroupHierarchy,\r\n                                                                info\r\n                                                            )\r\n                                                        \"\r\n                                                    >\r\n                                                    </i>\r\n\r\n                                                    <i\r\n                                                        *ngIf=\"\r\n                                                            subline.objectKey == 'displayBookedAverageRating' &&\r\n                                                            gtGeneralConfig.component == 'RATING' &&\r\n                                                            ROW_DATA['showRatingAverageIcon']\r\n                                                        \"\r\n                                                        class=\"mi mdi-info-outline seller-tooltip\"\r\n                                                        placement=\"bottom auto\"\r\n                                                        container=\"body\"\r\n                                                        [autoClose]=\"true\"\r\n                                                        (mouseenter)=\"\r\n                                                            setIsDifference(ROW_DATA.isDifferenceLessThan25Percent)\r\n                                                        \"\r\n                                                        tooltipClass=\"posted-avg-tooltip remove-on-scroll-class\"\r\n                                                        [ngbTooltip]=\"postedRatingDifference\"\r\n                                                    >\r\n                                                    </i>\r\n\r\n                                                    <i\r\n                                                        *ngIf=\"\r\n                                                            subline.objectKey == 'displayBookedAverageImpression' &&\r\n                                                            gtGeneralConfig.component == 'RATING' &&\r\n                                                            ROW_DATA['showImpressionAverageIcon']\r\n                                                        \"\r\n                                                        class=\"mi mdi-info-outline seller-tooltip\"\r\n                                                        placement=\"bottom auto\"\r\n                                                        container=\"body\"\r\n                                                        [autoClose]=\"true\"\r\n                                                        (mouseenter)=\"\r\n                                                            setIsDifference(ROW_DATA.isDifferenceLessThan25Percent)\r\n                                                        \"\r\n                                                        tooltipClass=\"posted-avg-tooltip remove-on-scroll-class\"\r\n                                                        [ngbTooltip]=\"postedImpDifference\"\r\n                                                    >\r\n                                                    </i>\r\n                                                </ng-container>\r\n                                                <ng-container *ngIf=\"subline.objectKey == 'description'\">\r\n                                                    <p\r\n                                                        *ngIf=\"\r\n                                                            ROW_DATA.descriptionMessage ||\r\n                                                            ROW_DATA.descriptionEmailReferenceNum\r\n                                                        \"\r\n                                                    >\r\n                                                        <ng-container *ngIf=\"ROW_DATA.descriptionMessage\">\r\n                                                            {{ ROW_DATA.descriptionMessage }}\r\n                                                            <br />\r\n                                                        </ng-container>\r\n                                                        <ng-container\r\n                                                            *ngIf=\"\r\n                                                                ROW_DATA.descriptionEmailReferenceNum != '-' &&\r\n                                                                ROW_DATA.descriptionEmailReferenceNum != ''\r\n                                                            \"\r\n                                                        >\r\n                                                            Email Ref: {{ ROW_DATA.descriptionEmailReferenceNum }}\r\n                                                            <br />\r\n                                                        </ng-container>\r\n                                                    </p>\r\n                                                    <a\r\n                                                        href=\"{{ ROW_DATA.descriptionDetailsUrl }}\"\r\n                                                        target=\"_blank\"\r\n                                                        *ngIf=\"\r\n                                                            ROW_DATA.descriptionDetailsUrlType === 'PDF' ||\r\n                                                            ROW_DATA.descriptionDetailsUrlType === 'EXCEL'\r\n                                                        \"\r\n                                                    >\r\n                                                        <button class=\"btn viewDetailsAndEmailBtn\">Download</button>\r\n                                                    </a>\r\n                                                    <ng-container\r\n                                                        *ngIf=\"ROW_DATA.activityname.toLowerCase() == 'order onboarded'\"\r\n                                                    >\r\n                                                        <a\r\n                                                            *ngIf=\"ROW_DATA.descriptionDetailsUrlType === 'LINK'\"\r\n                                                            (click)=\"viewDetailsClicked(ROW_DATA)\"\r\n                                                        >\r\n                                                            <button class=\"btn viewDetailsAndEmailBtn order-onboarded\">\r\n                                                                View details\r\n                                                            </button>\r\n                                                        </a>\r\n                                                    </ng-container>\r\n\r\n                                                    <a\r\n                                                        href=\"{{ ROW_DATA.descriptionEmailUrl }}\"\r\n                                                        target=\"_blank\"\r\n                                                        *ngIf=\"\r\n                                                            ROW_DATA.descriptionEmailUrl != '-' &&\r\n                                                            ROW_DATA.descriptionEmailUrl != ''\r\n                                                        \"\r\n                                                    >\r\n                                                        <button class=\"btn viewDetailsAndEmailBtn\">View email</button>\r\n                                                    </a>\r\n                                                </ng-container>\r\n                                            </ng-container>\r\n                                        </ng-container>\r\n                                    </div>\r\n                                </ng-container>\r\n                            </ng-container>\r\n                            <ng-container *ngIf=\"isNoDataToDisplaySubject$ | async\">\r\n                                <div>\r\n                                    {{ null }}\r\n                                </div>\r\n                            </ng-container>\r\n                        </ng-container>\r\n                    </td>\r\n                </ng-container>\r\n            </ng-container>\r\n        </table>\r\n    </div>\r\n    <anna-core-no-data-lib\r\n        [width]=\"noDataWidth\"\r\n        [marginTop]=\"marginTop\"\r\n        *ngIf=\"isNoDataToDisplaySubject$ | async\"\r\n    >\r\n    </anna-core-no-data-lib>\r\n</div>\r\n\r\n<!-- Checkbox template -->\r\n<ng-template #filterTooltip>\r\n    <anna-core-anna-column-checkbox-filter\r\n        [tableData]=\"tableData\"\r\n        [showFilterHeaderTabs]=\"showFilterTooltipTabs\"\r\n        [isLurAndCsrComponent]=\"false\"\r\n        [clonedTableData]=\"clonedTableData\"\r\n        [filterTabObjects]=\"filterTabObjects\"\r\n        (filterAppliedToTable)=\"filterApplied($event)\"\r\n        (sortingAppliedToTable)=\"sortingApplied($event)\"\r\n        (closeTooltip)=\"closeTooltip()\"\r\n    >\r\n    </anna-core-anna-column-checkbox-filter>\r\n</ng-template>\r\n\r\n<!-- Slider template -->\r\n<ng-template #sliderToolTip>\r\n    <anna-core-anna-column-slider-filter\r\n        [tableData]=\"tableData\"\r\n        [showFilterHeaderTabs]=\"showFilterTooltipTabs\"\r\n        [isLurAndCsrComponent]=\"false\"\r\n        [clonedTableData]=\"clonedTableData\"\r\n        [filterTabObjects]=\"filterTabObjects\"\r\n        (filterAppliedToTable)=\"filterApplied($event)\"\r\n        (sortingAppliedToTable)=\"sortingApplied($event)\"\r\n        (closeTooltip)=\"closeTooltip()\"\r\n    >\r\n    </anna-core-anna-column-slider-filter>\r\n</ng-template>\r\n\r\n<!-- Date Picker Template -->\r\n<ng-template #datePickerTooltip>\r\n    <anna-core-anna-column-date-range-filter\r\n        [tableData]=\"tableData\"\r\n        [showFilterHeaderTabs]=\"showFilterTooltipTabs\"\r\n        [isLurAndCsrComponent]=\"false\"\r\n        [clonedTableData]=\"clonedTableData\"\r\n        [filterTabObjects]=\"filterTabObjects\"\r\n        (filterAppliedToTable)=\"filterApplied($event)\"\r\n        (sortingAppliedToTable)=\"sortingApplied($event)\"\r\n        (closeTooltip)=\"closeTooltip()\"\r\n    >\r\n    </anna-core-anna-column-date-range-filter>\r\n</ng-template>\r\n\r\n<!-- Week Picker Template -->\r\n<ng-template #weekPickerToolTip>\r\n    <!-- <div class=\"weekpicker-container\">\r\n        <anna-core-week-calendar-filter-lib\r\n            [week-calendar-config]=\"gtGeneralConfig.multiWeekPickerConfig\"\r\n            (apply)=\"applyWeekFilter($event)\"\r\n            [from-date]=\"calendarMinEnabledDate\"\r\n            [to-date]=\"calendarMaxEnabledDate\"\r\n        >\r\n        </anna-core-week-calendar-filter-lib>\r\n    </div> -->\r\n</ng-template>\r\n\r\n<!-- Time Filter Template -->\r\n<ng-template #timeFilterToolTip>\r\n    <anna-core-anna-column-time-filter\r\n        [tableData]=\"tableData\"\r\n        [showFilterHeaderTabs]=\"showFilterTooltipTabs\"\r\n        [isLurAndCsrComponent]=\"false\"\r\n        [showAllTimeRangeCheckboxes]=\"showCheckboxesForTimeFilter\"\r\n        [clonedTableData]=\"clonedTableData\"\r\n        [filterTabObjects]=\"filterTabObjects\"\r\n        (filterAppliedToTable)=\"filterApplied($event)\"\r\n        (sortingAppliedToTable)=\"sortingApplied($event)\"\r\n        (closeTooltip)=\"closeTooltip()\"\r\n    >\r\n    </anna-core-anna-column-time-filter>\r\n</ng-template>\r\n\r\n<ng-template #columnInfoTooltip>\r\n    <p style=\"color: black; white-space: nowrap\">This preemption is rejected and not marked for credit.</p>\r\n</ng-template>\r\n\r\n<ng-template #ratingInfoTooltip>\r\n    <p class=\"first-row\">Shows 'Booked Rating' for Preemptions & MakeGood Offered spot(s).</p>\r\n    <p class=\"second-row\">Shows 'Projected Rating' for ADU Offered spot(s).</p>\r\n</ng-template>\r\n\r\n<ng-template #impsInfoTooltip>\r\n    <p class=\"first-row\">Shows 'Booked IMPS' for Preemptions & MakeGood Offered spot(s).</p>\r\n    <p class=\"second-row\">Shows 'Projected IMPS' for ADU Offered spot(s).</p>\r\n</ng-template>\r\n\r\n<ng-template #spotsColumnEquivalizationMessageTooltip>\r\n    <p class=\"spot-column-tooltip-message\">\r\n        This consists of equivalized spots and un-equivalized Paid Programs & un-equivalized Non-spots.\r\n    </p>\r\n</ng-template>\r\n\r\n<ng-template #underDeliveryTooltip>\r\n    <p class=\"spot-column-tooltip-message\">\r\n        Indicates the Under-delivery percentage based on booked and posted RTG/IMPS.\r\n    </p>\r\n</ng-template>\r\n\r\n<ng-template #overDeliveryTooltip>\r\n    <p class=\"spot-column-tooltip-message\">\r\n        Indicates the Over-delivery percentage based on booked and posted RTG/IMPS.\r\n    </p>\r\n</ng-template>\r\n\r\n<ng-template #rateInfoTooltip>\r\n    <p class=\"first-row\">Shows 'Booked Rate' for Preemptions & MakeGood Offered spot(s).</p>\r\n    <p class=\"second-row\">Shows 'Projected $ Value' for ADU Offered spot(s).</p>\r\n</ng-template>\r\n\r\n<ng-template #sellerHierarchyTooltip>\r\n    <ng-container *ngIf=\"sellerGroupHierarchy.length > 0\">\r\n        <section class=\"hierarchy-table-container\">\r\n            <table class=\"seller-hierarchy-table\">\r\n                <thead>\r\n                    <tr>\r\n                        <th>#</th>\r\n                        <th>Inventory Codes</th>\r\n                        <th>Program/Description</th>\r\n                    </tr>\r\n                </thead>\r\n                <tbody>\r\n                    <tr *ngFor=\"let data of sellerGroupHierarchy; let tooltipIndex = index\">\r\n                        <td>{{ tooltipIndex + 1 }}</td>\r\n                        <td>\r\n                            <span showEllipsisTextOnHover>{{ data.InventoryCode }}</span>\r\n                        </td>\r\n                        <td>\r\n                            <span showEllipsisTextOnHover>{{ data.Program }}</span>\r\n                        </td>\r\n                    </tr>\r\n                </tbody>\r\n            </table>\r\n        </section>\r\n    </ng-container>\r\n    <ng-container *ngIf=\"sellerGroupHierarchy.length == 0\">\r\n        <span style=\"color: #000\">Seller group not available for this inventory code</span>\r\n    </ng-container>\r\n</ng-template>\r\n\r\n<ng-template #lurViolationInfoTooltip>\r\n    <p class=\"first-row\">The values are for the entire week.</p>\r\n</ng-template>\r\n\r\n<ng-template #postedRatingDifference>\r\n    <p class=\"difference-text\">\r\n        The difference between posted and booked average rating is\r\n        {{ isDifferenceLessThan25Percent ? \"less\" : \"more\" }} than 25%.\r\n    </p>\r\n</ng-template>\r\n\r\n<ng-template #postedImpDifference>\r\n    <p class=\"difference-text\">\r\n        The difference between posted and booked average impression is\r\n        {{ isDifferenceLessThan25Percent ? \"less\" : \"more\" }} than 25%.\r\n    </p>\r\n</ng-template>\r\n\r\n<ng-template #ongoingRevBookedColumnTooltip>\r\n    <p>The Booked $ value, Spots, GRP, CPP, IMPS, CPM corresponds on the last permanent revision generated</p>\r\n</ng-template>\r\n\r\n<ng-template #completedRevBookedColumnTooltip>\r\n    <p>The Booked $ value corresponds on the last permanent revision generated</p>\r\n</ng-template>\r\n\r\n<ng-template #avgBookedRate>\r\n    <p>This is the booked average Rate</p>\r\n</ng-template>\r\n\r\n<ng-template #avgBookedRtg>\r\n    <p>This is the booked average RTG</p>\r\n</ng-template>\r\n\r\n<ng-template #avgBookedImps>\r\n    <p>This is the booked average IMP(’000)</p>\r\n</ng-template>\r\n\r\n<ng-template #projectedImpsRtg>\r\n    <p>\r\n        All projections are derived from the sum of actual posted information until the last posted date and estimates\r\n        for the remaining selected period.\r\n    </p>\r\n</ng-template>\r\n\r\n<ng-template #automationTooltip>\r\n    <p>\r\n        Please get the order business rules approved to activate the order for automation. Only for the\r\n        automation-activated orders, any approved MGs, ADUs, or credited spots on ANNA will be fed into the traffic\r\n        system i.e. ANNA revisions.\r\n        <!-- removed below line as part of enhancmennt in 14.0 releas -->\r\n        <!-- Additionally, ANNA will only enter buyer revisions into traffic for the selected\r\n        Medialine/WOC orders. -->\r\n    </p>\r\n</ng-template>\r\n\r\n<ng-template #rebateImpact>\r\n    <p>Rebate impact value is for the originally ordered spot length and is not equivalized.</p>\r\n</ng-template>\r\n\r\n<ng-template #lurViolationTotalRowToolTip>\r\n    <ul>\r\n        <li>\r\n            <strong>POLITICAL RATE VIOLATIONS:</strong>\r\n            Violations flagged when non-political spots are booked at a rate lower than the minimum booked rate for\r\n            political candidates for the same week, Inventory Code and Revenue Class.\r\n        </li>\r\n        <li>\r\n            <strong>CANDIDATE TO CANDIDATE VIOLATION:</strong>\r\n            Violations flagged when political spots are booked at different rates to other political spots for the same\r\n            week, Inventory Code and Revenue Class.\r\n        </li>\r\n    </ul>\r\n</ng-template>\r\n\r\n<ng-template #circularProgressBar>\r\n    <circle-progress\r\n        [percent]=\"percentDone\"\r\n        [radius]=\"5\"\r\n        [showTitle]=\"false\"\r\n        [showUnits]=\"false\"\r\n        [showSubtitle]=\"false\"\r\n        [outerStrokeWidth]=\"3\"\r\n        [innerStrokeWidth]=\"3\"\r\n        [space]=\"-3\"\r\n        [outerStrokeColor]=\"'#268bff'\"\r\n        [innerStrokeColor]=\"'#d5d5d5'\"\r\n        [animationDuration]=\"10\"\r\n    ></circle-progress>\r\n</ng-template>\r\n\r\n<ng-template #userLoggedInDetails>\r\n    <div class=\"tooltip-div-container\">\r\n        <ng-container *ngFor=\"let data of textActionTooltip\">\r\n            <span *ngIf=\"data.key != 'read'\">\r\n                {{ data.key }} <b> {{ data.value }}</b>\r\n            </span>\r\n            <span *ngIf=\"data.key == 'read'\">\r\n                {{ data.value }}\r\n            </span>\r\n        </ng-container>\r\n    </div>\r\n</ng-template>\r\n\r\n<ng-template #markAsReadTip>\r\n    <div class=\"notification-tooltip-div-container\">\r\n        <ng-container *ngFor=\"let data of textActionTooltip\">\r\n            {{ data.value }}\r\n        </ng-container>\r\n    </div>\r\n</ng-template>\r\n\r\n<ng-template #textActionTooltipTemplate>\r\n    <ng-container *ngFor=\"let data of textActionTooltip\">\r\n        {{ data.key }} <b> {{ data.value }}</b>\r\n    </ng-container>\r\n</ng-template>\r\n\r\n<ng-template #tooltipContainingTableTemplate>\r\n    <div\r\n        *ngIf=\"tooltipContainingTable\"\r\n        [innerHTML]=\"tooltipContainingTable.innerHtml\"\r\n        class=\"notification-tooltip-div-container\"\r\n    >\r\n        <!-- <ul>\r\n      <li *ngFor=\"let headerMsg of tooltipContainingTable.tableHeaderMsg\">\r\n        <b> {{headerMsg}}  </b>\r\n      </li>\r\n    </ul>\r\n\r\n    <table class=\"tooltip-table\">\r\n      <thead>\r\n        <tr>\r\n          <th *ngFor=\"let header of tooltipContainingTable.tooltipTableHeader\">\r\n            {{ header}}\r\n          </th>\r\n        </tr>\r\n      </thead>\r\n      <tbody>\r\n        <tr *ngFor=\"let rows of tooltipContainingTable.tooltipTableBody\">\r\n          <td *ngFor=\"let data of rows\">\r\n            {{ data }}\r\n          </td>\r\n        </tr>\r\n      </tbody>\r\n    </table>\r\n\r\n    <ul>\r\n      <li style=\"margin-top:10px; padding:0\" *ngFor=\"let footerMsg of tooltipContainingTable.tableFooterMsg\">\r\n        {{ footerMsg }} \r\n      </li>\r\n    </ul> -->\r\n    </div>\r\n</ng-template>\r\n<!-- <ng-template #textActionTooltipTemplate>\r\n   <ng-container *ngFor=\"let data of textActionTooltip\">\r\n      {{ data.key }} <b> {{data.value}}</b>\r\n   </ng-container>\r\n</ng-template> -->\r\n"]}