@annalib/anna-core 24.1.12 → 24.1.13

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 (55) hide show
  1. package/README.md +28 -28
  2. package/esm2022/lib/anna-core-shared-lib/components/anna-buyer-approval-icon-template/anna-buyer-approval-icon-template.component.mjs +3 -3
  3. package/esm2022/lib/anna-core-shared-lib/components/anna-deleted-order-icon-template/anna-deleted-order-icon-template.component.mjs +3 -3
  4. package/esm2022/lib/anna-core-shared-lib/components/anna-est-icon-template/anna-est-icon-template.component.mjs +3 -3
  5. package/esm2022/lib/anna-core-shared-lib/components/anna-icon-column/anna-icon-column.component.mjs +6 -4
  6. package/esm2022/lib/anna-core-shared-lib/components/anna-live-icon-template/anna-live-icon-template.component.mjs +3 -3
  7. package/esm2022/lib/anna-core-shared-lib/components/anna-no-data/anna-no-data.component.mjs +3 -3
  8. package/esm2022/lib/anna-core-shared-lib/components/anna-notify-icon-template/anna-notify-icon-template.component.mjs +3 -3
  9. package/esm2022/lib/anna-core-shared-lib/components/anna-pay-for-performance-icon-template/anna-pay-for-performance-icon-template.component.mjs +3 -3
  10. package/esm2022/lib/anna-core-shared-lib/components/anna-rejected-icon-template/anna-rejected-icon-template.component.mjs +3 -3
  11. package/esm2022/lib/anna-core-shared-lib/models/anna-generic-data-type.model.mjs +1 -1
  12. package/esm2022/lib/anna-core-shared-lib/models/anna-non-editable-gt-models.mjs +1 -15
  13. package/esm2022/lib/anna-core-shared-lib/services/anna-filter.service.mjs +4 -2
  14. package/esm2022/lib/anna-core.module.mjs +10 -4
  15. package/esm2022/lib/anna-generic-table-lib/components/anna-non-editable-generic-normal-table/anna-non-editable-generic-normal-table.component.mjs +982 -0
  16. package/esm2022/lib/anna-generic-table-lib/components/anna-non-editable-generic-table/anna-non-editable-generic-table.component.mjs +10 -4
  17. package/esm2022/lib/anna-generic-table-lib/components/anna-sort/anna-sort.component.mjs +3 -3
  18. package/esm2022/public-api.mjs +2 -1
  19. package/fesm2022/annalib-anna-core.mjs +1187 -239
  20. package/fesm2022/annalib-anna-core.mjs.map +1 -1
  21. package/lib/anna-core-shared-lib/models/anna-non-editable-gt-models.d.ts +7 -14
  22. package/lib/anna-core.module.d.ts +2 -1
  23. package/lib/anna-generic-table-lib/components/anna-non-editable-generic-normal-table/anna-non-editable-generic-normal-table.component.d.ts +179 -0
  24. package/lib/anna-generic-table-lib/components/anna-non-editable-generic-table/anna-non-editable-generic-table.component.d.ts +3 -1
  25. package/package.json +1 -1
  26. package/public-api.d.ts +1 -0
  27. package/src/lib/anna-common-scss/_animate.scss +27 -27
  28. package/src/lib/anna-common-scss/_application-spacing.scss +7 -7
  29. package/src/lib/anna-common-scss/_bootstrap-tooltip.scss +27 -27
  30. package/src/lib/anna-common-scss/_button.scss +18 -18
  31. package/src/lib/anna-common-scss/_colors.scss +107 -107
  32. package/src/lib/anna-common-scss/_common-order-listing-table.scss +176 -176
  33. package/src/lib/anna-common-scss/_custom-anna-datepicker.scss +14 -14
  34. package/src/lib/anna-common-scss/_customDropdown.scss +123 -123
  35. package/src/lib/anna-common-scss/_dashboard-partials.scss +106 -106
  36. package/src/lib/anna-common-scss/_date-picker-form.scss +87 -87
  37. package/src/lib/anna-common-scss/_edit-filter-popup.scss +70 -70
  38. package/src/lib/anna-common-scss/_font.scss +9 -9
  39. package/src/lib/anna-common-scss/_fonts.scss +86 -86
  40. package/src/lib/anna-common-scss/_generic-modal.scss +63 -63
  41. package/src/lib/anna-common-scss/_generic-table-common.scss +198 -198
  42. package/src/lib/anna-common-scss/_gt-table.scss +425 -425
  43. package/src/lib/anna-common-scss/_icons.scss +3 -3
  44. package/src/lib/anna-common-scss/_legend.scss +11 -11
  45. package/src/lib/anna-common-scss/_mat-menu.scss +17 -17
  46. package/src/lib/anna-common-scss/_mixins.scss +187 -187
  47. package/src/lib/anna-common-scss/_modal.scss +37 -37
  48. package/src/lib/anna-common-scss/_popup-filter-toggle-button.scss +36 -36
  49. package/src/lib/anna-common-scss/_scrollbar.scss +14 -14
  50. package/src/lib/anna-common-scss/_sort.scss +30 -30
  51. package/src/lib/anna-common-scss/_toggle.scss +86 -86
  52. package/src/lib/anna-common-scss/style.scss +1 -1
  53. package/src/lib/anna-common-scss/third-party-lib/_angular-material-mat-radio.scss +25 -25
  54. package/src/lib/anna-common-scss/third-party-lib/_anna-mat-button-toggle-group-size-lg.scss +34 -34
  55. package/src/lib/anna-common-scss/third-party-lib/_mat-autocomplete.scss +31 -31
@@ -0,0 +1,982 @@
1
+ import { AsyncPipe, NgClass, NgFor, NgIf, NgStyle, NgSwitch, NgSwitchCase, NgSwitchDefault, NgTemplateOutlet, } from "@angular/common";
2
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, Input, Output, QueryList, ViewChild, ViewChildren, } from "@angular/core";
3
+ import { FormsModule } from "@angular/forms";
4
+ import { MatRadioModule } from "@angular/material/radio";
5
+ import { NgbTooltip } from "@ng-bootstrap/ng-bootstrap";
6
+ // Third party import statements
7
+ import { cloneDeep, isEqual, uniq } from "lodash-es";
8
+ import { NgCircleProgressModule } from "ng-circle-progress";
9
+ import { NgxSkeletonLoaderModule } from "ngx-skeleton-loader";
10
+ import { BehaviorSubject } from "rxjs";
11
+ import { AnnaEstIconTemplateComponent } from "../../../anna-core-shared-lib/components/anna-est-icon-template/anna-est-icon-template.component";
12
+ // eslint-disable-next-line max-len
13
+ import { AnnaIconColumnComponent } from "../../../anna-core-shared-lib/components/anna-icon-column/anna-icon-column.component";
14
+ import { AnnaNoDataComponent } from "../../../anna-core-shared-lib/components/anna-no-data/anna-no-data.component";
15
+ // eslint-disable-next-line max-len
16
+ import { ShowEllipsisTextOnHoverDirective } from "../../../anna-core-shared-lib/directives/show-ellipsis-text/show-ellipsis-text.directive";
17
+ import { RadioButtonModel } from "../../../anna-core-shared-lib/models/anna-tooltip.model";
18
+ import { AnnaDateTimeFormatService } from "../../../anna-core-shared-lib/services/anna-date-time-format.service";
19
+ import { AnnaFilterService } from "../../../anna-core-shared-lib/services/anna-filter.service";
20
+ import { AnnaSortService } from "../../../anna-core-shared-lib/services/anna-sort.service";
21
+ // eslint-disable-next-line max-len
22
+ import { AnnaColumnCheckboxFilterComponent } from "../anna-column-filters/anna-column-checkbox-filter/anna-column-checkbox-filter.component";
23
+ // eslint-disable-next-line max-len
24
+ import { AnnaColumnDateRangeFilterComponent } from "../anna-column-filters/anna-column-date-range-filter/anna-column-date-range-filter.component";
25
+ // eslint-disable-next-line max-len
26
+ import { AnnaColumnSliderFilterComponent } from "../anna-column-filters/anna-column-slider-filter/anna-column-slider-filter.component";
27
+ import { AnnaColumnTimeFilterComponent } from "../anna-column-filters/anna-column-time-filter/anna-column-time-filter.component";
28
+ import * as i0 from "@angular/core";
29
+ import * as i1 from "../../../anna-core-shared-lib/services/anna-sort.service";
30
+ import * as i2 from "../../../anna-core-shared-lib/services/anna-date-time-format.service";
31
+ import * as i3 from "../../../anna-core-shared-lib/services/anna-filter.service";
32
+ import * as i4 from "ngx-skeleton-loader";
33
+ import * as i5 from "@angular/forms";
34
+ import * as i6 from "@angular/material/radio";
35
+ import * as i7 from "ng-circle-progress";
36
+ export class AnnaNonEditableGenericNormalTableComponent {
37
+ constructor(cdRef, annaSortService, annaDateTimeFormatService, annaFilterService) {
38
+ this.cdRef = cdRef;
39
+ this.annaSortService = annaSortService;
40
+ this.annaDateTimeFormatService = annaDateTimeFormatService;
41
+ this.annaFilterService = annaFilterService;
42
+ this.maximumRowsWhichCanBeRenderedWithoutScroll = 5;
43
+ this.fixNumberOfRowsForPopup = false;
44
+ this.limit = 30;
45
+ this.includeBorderInTableHeight = true;
46
+ this.clickableRow = false;
47
+ this.setTableHeightWhenRowSizeIsFixed = true;
48
+ this.tableBorderBottomClassRequired = true;
49
+ this.hideSomeTds = false;
50
+ this.tdsHaveRowSpan = false;
51
+ this.multipleTablesPresent = false;
52
+ this.showOrHideToggleForTotalRow = false;
53
+ this.toggleCheckbox = new EventEmitter();
54
+ this.toggleRowCheckbox = new EventEmitter();
55
+ this.toggleHeaderCheckbox = new EventEmitter();
56
+ this.undoIconClicked = new EventEmitter();
57
+ this.filterAppliedToTable = new EventEmitter();
58
+ this.sortingAppliedToTable = new EventEmitter();
59
+ this.rowClicked = new EventEmitter();
60
+ this.radioButtonSelected = new EventEmitter();
61
+ this.columnFilterOpened = new EventEmitter();
62
+ this.columnFilterClosed = new EventEmitter();
63
+ this.gtIconClicked = new EventEmitter();
64
+ this.gtSVGIconClicked = new EventEmitter();
65
+ this.gtTextActionClicked = new EventEmitter();
66
+ this.gtViewDetailClicked = new EventEmitter();
67
+ this.gtInnerHTMLClicked = new EventEmitter();
68
+ this.downloadSpotDetails = new EventEmitter();
69
+ this.clickableDataClicked = new EventEmitter();
70
+ this.totalRowIconClicked = new EventEmitter();
71
+ this.notificationIconHover = new EventEmitter();
72
+ this.notificationIconHoverLeave = new EventEmitter();
73
+ this.editableInputEdited = new EventEmitter();
74
+ this.radioButtonMessageIconClicked = new EventEmitter();
75
+ this.numberOfSkeletonRows = Array(20).fill(0);
76
+ this.noDataWidth = "50%";
77
+ this.filterAlignment = "bottom auto";
78
+ this.disableColumnClearAllBtn = true;
79
+ this.margin = 5;
80
+ this.tableColumns = [];
81
+ this.totalRowColumns = null;
82
+ this.isScrolledLeft = false;
83
+ this.rowBorderWidth = 2;
84
+ this.isScrollEnded = true;
85
+ this.marginTop = "";
86
+ this.start = 0;
87
+ this.end = this.limit + this.start;
88
+ this.isNoDataToDisplaySubject$ = new BehaviorSubject(false);
89
+ this.textActionTooltip = [];
90
+ this.tooltipContainingTable = null;
91
+ this.tableBottomBorderClass = null;
92
+ this.showCheckboxesForTimeFilter = false;
93
+ console.log("constructor");
94
+ this.setTooltipRadioNames();
95
+ }
96
+ ngAfterViewChecked() {
97
+ // if (this.setMarginLeft) {
98
+ this.annaFilterService.setMarginLeftForFilterIcon(this.viewChildTableHeaders);
99
+ // }
100
+ }
101
+ ngOnInit() {
102
+ document.documentElement.style.setProperty(`--hide-total-row-scrollbar-offset`, "0px");
103
+ this.setFilterAlignmentBasedOnScreenResolution();
104
+ }
105
+ detectChanges() {
106
+ this.cdRef.detectChanges();
107
+ }
108
+ ngOnChanges(changes) {
109
+ if (changes &&
110
+ changes.gtDimension &&
111
+ changes.gtDimension.currentValue &&
112
+ this.setTableHeightWhenRowSizeIsFixed) {
113
+ this.setTableHeight();
114
+ this.setTableBottomBorder();
115
+ }
116
+ if (this.showSkeletonLoading) {
117
+ this.tableElementRef.nativeElement.scrollTop = 0;
118
+ this.tableElementRef.nativeElement.scrollLeft = 0;
119
+ this.tableData = this.numberOfSkeletonRows;
120
+ this.renderedData = this.numberOfSkeletonRows;
121
+ this.isNoDataToDisplaySubject$.next(false);
122
+ this.setTableBottomBorder();
123
+ }
124
+ else if (changes.percentDone ||
125
+ changes.downloadInProgress ||
126
+ (changes.starredInProgress && changes.starredInProgress.currentValue !== undefined)) {
127
+ // no task will be performed
128
+ }
129
+ else {
130
+ this.setInitialRowsForTable();
131
+ this.disableEnableEachColumnTooltipIcon();
132
+ this.tableColumns = this.tableHeaders.filter((x) => x.visible).map((x) => x.headerInfo[0].objectKey);
133
+ if ((this.tableData && this.tableData.length === 0) ||
134
+ (this.tableData.length === 2 && this.checkIfAllTheElementsAreZero())) {
135
+ this.tableData = Array(2).fill(0);
136
+ this.renderedData = cloneDeep(this.tableData);
137
+ this.marginTop = `${-this.gtDimension.rowHeight - this.gtDimension.rowHeight / 2}px`;
138
+ this.isNoDataToDisplaySubject$.next(true);
139
+ }
140
+ else {
141
+ this.isNoDataToDisplaySubject$.next(false);
142
+ }
143
+ this.showSkeletonLoading = false;
144
+ this.setTableBottomBorder();
145
+ }
146
+ // setting table column here as well because while showing skeleton loader, we should show table headers.
147
+ if (changes.tableHeaders && !isEqual(changes.tableHeaders.currentValue, changes.tableHeaders.previousValue)) {
148
+ this.tableColumns = this.tableHeaders.filter((x) => x.visible).map((x) => x.headerInfo[0].objectKey);
149
+ this.annaSortService.columnSortState = new Map();
150
+ this.annaFilterService.initialValueMap = new Map();
151
+ // this.setColumnSortStateMap();
152
+ this.setActiveStateObject();
153
+ }
154
+ if (changes.totalRowInfo && changes.totalRowInfo.currentValue) {
155
+ this.totalRowColumns = this.totalRowInfo.map((x) => x.colName);
156
+ }
157
+ // this.cdRef.detectChanges();
158
+ }
159
+ setFilterAlignmentBasedOnScreenResolution() {
160
+ const viewportHeight = window.innerHeight;
161
+ if (viewportHeight < 740) {
162
+ this.filterAlignment = "left right top bottom";
163
+ }
164
+ else {
165
+ this.filterAlignment = "bottom left right top";
166
+ }
167
+ }
168
+ setTableBottomBorder() {
169
+ if (this.tableBorderBottomClassRequired &&
170
+ this.tableData &&
171
+ this.tableData.length &&
172
+ this.maximumRowsWhichCanBeRenderedWithoutScroll < this.tableData.length) {
173
+ this.tableBottomBorderClass = "bottom-border";
174
+ }
175
+ else {
176
+ this.tableBottomBorderClass = null;
177
+ }
178
+ }
179
+ checkIfAllTheElementsAreZero() {
180
+ return !this.tableData.some((item) => item !== 0);
181
+ }
182
+ showHideTotalRow() {
183
+ this.gtGeneralConfig.totalRow = !this.gtGeneralConfig.totalRow;
184
+ if (!this.gtGeneralConfig.totalRow) {
185
+ document.documentElement.style.setProperty(`--hide-total-row-scrollbar-offset`, "50px");
186
+ }
187
+ else {
188
+ document.documentElement.style.setProperty(`--hide-total-row-scrollbar-offset`, "0px");
189
+ }
190
+ }
191
+ setTableHeight() {
192
+ let viewportHeight = window.innerHeight;
193
+ const { rowHeight } = this.gtDimension;
194
+ const { headerHeight } = this.gtDimension;
195
+ const { dataOnTopHeight } = this.gtDimension;
196
+ const { marginFromBottom } = this.gtDimension;
197
+ let actualTableHeight;
198
+ if (this.fixNumberOfRowsForPopup) {
199
+ const maxNoOfRowsToDisplay = viewportHeight < 740 ? 5 : 10;
200
+ this.maximumRowsWhichCanBeRenderedWithoutScroll = maxNoOfRowsToDisplay;
201
+ actualTableHeight = this.maximumRowsWhichCanBeRenderedWithoutScroll * rowHeight + headerHeight;
202
+ }
203
+ else {
204
+ const minHeightForTable = headerHeight + 3 * rowHeight;
205
+ viewportHeight = viewportHeight <= dataOnTopHeight ? dataOnTopHeight + minHeightForTable : viewportHeight;
206
+ const heightLeftForTable = viewportHeight - dataOnTopHeight - marginFromBottom;
207
+ this.maximumRowsWhichCanBeRenderedWithoutScroll =
208
+ Math.ceil((heightLeftForTable - headerHeight - rowHeight) / rowHeight) + 1;
209
+ actualTableHeight = viewportHeight - dataOnTopHeight - marginFromBottom;
210
+ }
211
+ // let actualTableHeight = heightLeftForTable - ((heightLeftForTable - headerHeight - rowHeight) % rowHeight);
212
+ this.gtDimension.tableHeight = `${actualTableHeight}px`;
213
+ this.numberOfSkeletonRows = this.maximumRowsWhichCanBeRenderedWithoutScroll
214
+ ? Array(this.maximumRowsWhichCanBeRenderedWithoutScroll).fill(0)
215
+ : Array(5).fill(0);
216
+ }
217
+ trackByHeaderFn(index, item) {
218
+ return item.headerInfo[0].name;
219
+ }
220
+ trackByTotalRowFn(index, item) {
221
+ return item.colName;
222
+ }
223
+ trackByFn(index) {
224
+ return index;
225
+ }
226
+ setTooltipRadioNames() {
227
+ this.tooltipRadioTextMap = new Map();
228
+ this.tooltipRadioTextMap.set("StartTimeForFilter", "Start Time");
229
+ this.tooltipRadioTextMap.set("EndTimeForFilter", "End Time");
230
+ this.tooltipRadioTextMap.set("startTimeForFilter", "Start Time");
231
+ this.tooltipRadioTextMap.set("endTimeForFilter", "End Time");
232
+ this.tooltipRadioTextMap.set("start_time_for_filter", "Start Time");
233
+ this.tooltipRadioTextMap.set("end_time_for_filter", "End Time");
234
+ this.tooltipRadioTextMap.set("primaryAEName", "Primary AE");
235
+ this.tooltipRadioTextMap.set("region", "Region");
236
+ this.tooltipRadioTextMap.set("agencyName", "Agency");
237
+ this.tooltipRadioTextMap.set("location", "Location");
238
+ this.tooltipRadioTextMap.set("advertiserName", "Advertiser");
239
+ this.tooltipRadioTextMap.set("productCode", "Product Code");
240
+ this.tooltipRadioTextMap.set("flightStartDate", "Start Date");
241
+ this.tooltipRadioTextMap.set("flightEndDate", "End Date");
242
+ this.tooltipRadioTextMap.set("orderIdAndRevNumber", "STN Order#-Rev#");
243
+ this.tooltipRadioTextMap.set("stationOrderNumber", "STN Order#");
244
+ this.tooltipRadioTextMap.set("alternateOrderId", "Alt/Rep Order #");
245
+ this.tooltipRadioTextMap.set("grp", "GRP");
246
+ this.tooltipRadioTextMap.set("cpp", "CPP");
247
+ this.tooltipRadioTextMap.set("imps", "IMPS");
248
+ this.tooltipRadioTextMap.set("cpm", "CPM");
249
+ this.tooltipRadioTextMap.set("offeredMGs", "Offered MG");
250
+ this.tooltipRadioTextMap.set("outstandingPE", "O/S PE");
251
+ this.tooltipRadioTextMap.set("offeredADUs", "Offered ADUs");
252
+ this.tooltipRadioTextMap.set("udDeficitValue", "O/S Aud Delta");
253
+ this.tooltipRadioTextMap.set("startEndTimeMulti", "Time");
254
+ this.tooltipRadioTextMap.set("bookedValue", "Booked");
255
+ this.tooltipRadioTextMap.set("bookedSpots", "Spots");
256
+ this.tooltipRadioTextMap.set("UserCreditedValue", "User Credited");
257
+ this.tooltipRadioTextMap.set("UserUnresolvedValue", "User Unresolved");
258
+ this.tooltipRadioTextMap.set("BuyerAddedValue", "Buyer Added");
259
+ this.tooltipRadioTextMap.set("BuyerDeletedValue", "Buyer Deleted");
260
+ this.tooltipRadioTextMap.set("userChanges", "User Changes");
261
+ this.tooltipRadioTextMap.set("buyerChanges", "Buyer Changes");
262
+ this.tooltipRadioTextMap.set("userMG", "User MG");
263
+ this.tooltipRadioTextMap.set("userADUs", "User ADUs");
264
+ this.tooltipRadioTextMap.set("inventoryCode", "Inventory Code");
265
+ this.tooltipRadioTextMap.set("program", "Program");
266
+ this.tooltipRadioTextMap.set("agency", "Agency");
267
+ this.tooltipRadioTextMap.set("advertiser", "Advertiser");
268
+ this.tooltipRadioTextMap.set("startDate", "Start Date");
269
+ this.tooltipRadioTextMap.set("endDate", "End Date");
270
+ this.tooltipRadioTextMap.set("date", "Date");
271
+ this.tooltipRadioTextMap.set("rcvPreempt", "$ Madegood PEs");
272
+ this.tooltipRadioTextMap.set("osPreempt", "$ O/S PEs");
273
+ this.tooltipRadioTextMap.set("rcvUnderDly", "Recovered UD");
274
+ this.tooltipRadioTextMap.set("osUnderDly", "O/s Under Dly");
275
+ this.tooltipRadioTextMap.set("primaryAe", "Primary AE");
276
+ this.tooltipRadioTextMap.set("region", "Region");
277
+ this.tooltipRadioTextMap.set("revCode1", "Rev code 1");
278
+ this.tooltipRadioTextMap.set("orderNoRevNo", "STN Order#-Rev#");
279
+ this.tooltipRadioTextMap.set("revCode2", "Rev code 2");
280
+ this.tooltipRadioTextMap.set("revCode3", "Rev code 3");
281
+ this.tooltipRadioTextMap.set("booked", "$ Booked");
282
+ this.tooltipRadioTextMap.set("spots", "Spots");
283
+ this.tooltipRadioTextMap.set("postedAudPercent", "Posted %");
284
+ this.tooltipRadioTextMap.set("revision", "Revision");
285
+ this.tooltipRadioTextMap.set("buyerOrderId", "ALT/REP Order#");
286
+ this.tooltipRadioTextMap.set("demo", "Demo");
287
+ this.tooltipRadioTextMap.set("averageRateThisYear", "Avg. Rate (TY)");
288
+ this.tooltipRadioTextMap.set("averageRateLastYear", "Avg. Rat (LY)");
289
+ this.tooltipRadioTextMap.set("averageCPP", "Avg. CPP");
290
+ this.tooltipRadioTextMap.set("projectedCPP", "Proj. CPP (30s)");
291
+ this.tooltipRadioTextMap.set("projectedCPM", "Proj. CPM (30s)");
292
+ this.tooltipRadioTextMap.set("averageCPM", "Avg. CPM");
293
+ this.tooltipRadioTextMap.set("IMPSDiff", "IMPS ('000) Diff.");
294
+ this.tooltipRadioTextMap.set("RTGDiff", "RTG Diff.");
295
+ this.tooltipRadioTextMap.set("bookedEqCpmValue", "Booked CPM (30s)");
296
+ this.tooltipRadioTextMap.set("bookedEqCppValue", "Booked CPP (30s)");
297
+ this.tooltipRadioTextMap.set("postedAdu", "$ Posted ADUs");
298
+ this.tooltipRadioTextMap.set("scheduledAdu", "$ Scheduled ADUs");
299
+ this.tooltipRadioTextMap.set("audienceDeficit", "$ O/S Audience");
300
+ this.tooltipRadioTextMap.set("postedAudPercent", "Posted Audience %");
301
+ this.tooltipRadioTextMap.set("potentialUnitsValue", "POT Units");
302
+ this.tooltipRadioTextMap.set("bookedUnitsValue", "Booked Eq Units");
303
+ this.tooltipRadioTextMap.set("bookedAmountWithZeroRatingValue", "Total $ Booked");
304
+ this.tooltipRadioTextMap.set("bookedAmountPercentageWithZeroRatingValue", "% Against All Demos");
305
+ this.tooltipRadioTextMap.set("bookedAmountWithoutZeroRatingValue", "$Booked With Imps(’000)");
306
+ this.tooltipRadioTextMap.set("bookedAmountPercentageWithoutZeroRatingValue", "% Against All Demos");
307
+ this.tooltipRadioTextMap.set("totalBookedAmountValue", "Total $Booked");
308
+ this.tooltipRadioTextMap.set("averageUnitRateValue", " AUR");
309
+ this.tooltipRadioTextMap.set("totalBookedAmountWithRatingValue", "$Booked With Rating");
310
+ this.tooltipRadioTextMap.set("averageUnitRateWithRatingValue", "AUR With Rating");
311
+ this.tooltipRadioTextMap.set("totalBookedAmountValue", "Total $Booked");
312
+ this.tooltipRadioTextMap.set("averageUnitRateValue", " AUR");
313
+ this.tooltipRadioTextMap.set("totalBookedAmountWithRatingValue", "$Booked With Rating");
314
+ this.tooltipRadioTextMap.set("averageUnitRateWithRatingValue", "AUR With Rating");
315
+ this.tooltipRadioTextMap.set("totalBookedAmountWithImpressionValue", "$Booked With IMPS");
316
+ this.tooltipRadioTextMap.set("averageUnitRateWithImpressionValue", "AUR With IMPS");
317
+ this.tooltipRadioTextMap.set("totalBookedAmountWithImpressionValue", "$Booked With IMPS");
318
+ this.tooltipRadioTextMap.set("averageUnitRateWithImpressionValue", "AUR With IMPS");
319
+ this.tooltipRadioTextMap.set("bookedUnitsWithRatingValue", "Booked Units With Rating");
320
+ this.tooltipRadioTextMap.set("postedUnitsWithRatingValue", "Posted Units With Rating");
321
+ this.tooltipRadioTextMap.set("bookedUnitsWithRatingValue", "Booked Units With Rating");
322
+ this.tooltipRadioTextMap.set("postedUnitsWithRatingValue", "Posted Units With Rating");
323
+ this.tooltipRadioTextMap.set("bookedUnitsWithImpressionValue", "Booked Units With IMPS");
324
+ this.tooltipRadioTextMap.set("postedUnitsWithImpressionValue", "Posted Units With IMPS");
325
+ this.tooltipRadioTextMap.set("bookedUnitsWithImpressionValue", "Booked Units With IMPS");
326
+ this.tooltipRadioTextMap.set("postedUnitsWithImpressionValue", "Posted Units With IMPS");
327
+ this.tooltipRadioTextMap.set("bookedRatings", "Booked Rating");
328
+ this.tooltipRadioTextMap.set("postedRatings", "POSTED Rating");
329
+ this.tooltipRadioTextMap.set("PostedRating", "Posted RTG");
330
+ this.tooltipRadioTextMap.set("bookedRatings", "Booked Rating");
331
+ this.tooltipRadioTextMap.set("postedRatings", "POSTED Rating");
332
+ this.tooltipRadioTextMap.set("PostedRating", "Posted RTG");
333
+ this.tooltipRadioTextMap.set("bookedImpressions", "Booked IMP('000)");
334
+ this.tooltipRadioTextMap.set("postedImpressions", "Posted IMP('000)");
335
+ this.tooltipRadioTextMap.set("PostedImpressions", "Posted IMP('000)");
336
+ this.tooltipRadioTextMap.set("bookedImpressions", "Booked IMP('000)");
337
+ this.tooltipRadioTextMap.set("postedImpressions", "Posted IMP('000)");
338
+ this.tooltipRadioTextMap.set("PostedImpressions", "Posted IMP('000)");
339
+ this.tooltipRadioTextMap.set("bookedAverageRating", "Booked AU Rating");
340
+ this.tooltipRadioTextMap.set("postedAverageRating", "Posted AU Rating");
341
+ this.tooltipRadioTextMap.set("bookedAverageRating", "Booked AU Rating");
342
+ this.tooltipRadioTextMap.set("postedAverageRating", "Posted AU Rating");
343
+ this.tooltipRadioTextMap.set("bookedAverageImpression", "Booked AU IMPS");
344
+ this.tooltipRadioTextMap.set("postedAverageImpression", "Posted AU IMPS");
345
+ this.tooltipRadioTextMap.set("bookedAverageImpression", "Booked AU IMPS");
346
+ this.tooltipRadioTextMap.set("postedAverageImpression", "Posted AU IMPS");
347
+ this.tooltipRadioTextMap.set("bookedCppValue", "Booked CPP");
348
+ this.tooltipRadioTextMap.set("bookedEffectiveCppValue", "Effective CPP");
349
+ this.tooltipRadioTextMap.set("bookedCppValue", "Booked CPP");
350
+ this.tooltipRadioTextMap.set("bookedEffectiveCppValue", "Effective CPP");
351
+ this.tooltipRadioTextMap.set("bookedCpmValue", "Booked CPM");
352
+ this.tooltipRadioTextMap.set("bookedEffectiveCpmValue", "Effective CPM");
353
+ this.tooltipRadioTextMap.set("bookedCpmValue", "Booked CPM");
354
+ this.tooltipRadioTextMap.set("bookedEffectiveCpmValue", "Effective CPM");
355
+ this.tooltipRadioTextMap.set("orderSource", "Order Route");
356
+ this.tooltipRadioTextMap.set("orderCategory", "Rev Category");
357
+ this.tooltipRadioTextMap.set("cashOrTrade", "C/T");
358
+ this.tooltipRadioTextMap.set("revisionStartDate", "Revision Start Date");
359
+ this.tooltipRadioTextMap.set("name", "name");
360
+ this.tooltipRadioTextMap.set("role", "role");
361
+ this.tooltipRadioTextMap.set("stationCount", "stationCount");
362
+ this.tooltipRadioTextMap.set("stationList", "stationList");
363
+ this.tooltipRadioTextMap.set("approvedOn", "Approved On");
364
+ this.tooltipRadioTextMap.set("approvedBy", "Approved By");
365
+ this.tooltipRadioTextMap.set("ODImps", "Proj. OD IMPS");
366
+ this.tooltipRadioTextMap.set("UDImps", "Proj. UD IMPS");
367
+ this.tooltipRadioTextMap.set("ODGrp", "Proj. OD GRP");
368
+ this.tooltipRadioTextMap.set("UDGrp", "Proj. UD GRP");
369
+ this.tooltipRadioTextMap.set("udImpsPercent", "Proj. UD %");
370
+ this.tooltipRadioTextMap.set("udGrpPercent", "Proj. UD GRP %");
371
+ this.tooltipRadioTextMap.set("odImpsPercent", "Proj. OD %");
372
+ this.tooltipRadioTextMap.set("odGrpPercent", "Proj. OD GRP %");
373
+ this.tooltipRadioTextMap.set("orderSource", "Order Route");
374
+ this.tooltipRadioTextMap.set("orderCategory", "Rev Category");
375
+ this.tooltipRadioTextMap.set("cashOrTrade", "C/T");
376
+ this.tooltipRadioTextMap.set("revisionStartDate", "Revision Start Date");
377
+ this.tooltipRadioTextMap.set("name", "name");
378
+ this.tooltipRadioTextMap.set("role", "role");
379
+ this.tooltipRadioTextMap.set("stationCount", "stationCount");
380
+ this.tooltipRadioTextMap.set("stationList", "stationList");
381
+ this.tooltipRadioTextMap.set("approvedOn", "Approved On");
382
+ this.tooltipRadioTextMap.set("approvedBy", "Approved By");
383
+ this.tooltipRadioTextMap.set("ODImps", "Proj. OD IMPS");
384
+ this.tooltipRadioTextMap.set("UDImps", "Proj. UD IMPS");
385
+ this.tooltipRadioTextMap.set("ODGrp", "Proj. OD GRP");
386
+ this.tooltipRadioTextMap.set("UDGrp", "Proj. UD GRP");
387
+ this.tooltipRadioTextMap.set("udImpsPercent", "Proj. UD %");
388
+ this.tooltipRadioTextMap.set("udGrpPercent", "Proj. UD GRP %");
389
+ this.tooltipRadioTextMap.set("odImpsPercent", "Proj. OD %");
390
+ this.tooltipRadioTextMap.set("odGrpPercent", "Proj. OD GRP %");
391
+ this.tooltipRadioTextMap.set("RevisionNumber", "Revision #");
392
+ this.tooltipRadioTextMap.set("RevisionType", "Revision Type");
393
+ this.tooltipRadioTextMap.set("GeneratedOn", "Generated On");
394
+ this.tooltipRadioTextMap.set("BookedValueForDisplay", "$ BOOKED");
395
+ this.tooltipRadioTextMap.set("BookedValue", "$ Booked");
396
+ this.tooltipRadioTextMap.set("BookedSpots", "Spots");
397
+ this.tooltipRadioTextMap.set("BookedGRP", "GRP");
398
+ this.tooltipRadioTextMap.set("BookedIMPSRevTab", "IMPS'(000)");
399
+ this.tooltipRadioTextMap.set("BookedCPP", "CPP");
400
+ this.tooltipRadioTextMap.set("BookedCPM", "CPM");
401
+ this.tooltipRadioTextMap.set("MGsValueForDisplay", "$ MGS");
402
+ this.tooltipRadioTextMap.set("MGsValue", "$ MGS");
403
+ this.tooltipRadioTextMap.set("ADUsValueForDisplay", "$ ADUS");
404
+ this.tooltipRadioTextMap.set("ADUsValue", "$ ADUS");
405
+ this.tooltipRadioTextMap.set("BuyerChangesValueForDisplay", "$ Buyer Change");
406
+ this.tooltipRadioTextMap.set("BuyerChangesValue", "$ Buyer Change");
407
+ this.tooltipRadioTextMap.set("UserChangesValueForDisplay", "$ Seller User Change");
408
+ this.tooltipRadioTextMap.set("UserChangesValue", "$ Seller User Change");
409
+ this.tooltipRadioTextMap.set("SellerLine", "Seller Line #");
410
+ this.tooltipRadioTextMap.set("BuyerLine", "Buy Line #");
411
+ this.tooltipRadioTextMap.set("SpotStatus", "Spot Status");
412
+ this.tooltipRadioTextMap.set("InventoryCode", "Inventory Code");
413
+ this.tooltipRadioTextMap.set("BuyerProgramName", "Buyer Program Name");
414
+ this.tooltipRadioTextMap.set("RevenueClass", "Revenue Class");
415
+ this.tooltipRadioTextMap.set("WeeklyAUR", "Booked Avg. Rate");
416
+ this.tooltipRadioTextMap.set("BookedRate", "Booked Rate");
417
+ this.tooltipRadioTextMap.set("averageRate", "Average Rate");
418
+ this.tooltipRadioTextMap.set("bookedAverageRate", "Booked AVG. Rate");
419
+ this.tooltipRadioTextMap.set("dollarIMPSImpact", "$ IMPS Impact");
420
+ this.tooltipRadioTextMap.set("dollarRTGImpact", "$ RTG IMPACT");
421
+ this.tooltipRadioTextMap.set("IMPSImpact", "IMPS ('000) IMPACT");
422
+ this.tooltipRadioTextMap.set("RTGImpact", "RTG Impact");
423
+ this.tooltipRadioTextMap.set("RevisionNumber", "Revision #");
424
+ this.tooltipRadioTextMap.set("RevisionType", "Revision Type");
425
+ this.tooltipRadioTextMap.set("GeneratedOn", "Generated On");
426
+ this.tooltipRadioTextMap.set("BookedValueForDisplay", "$ BOOKED");
427
+ this.tooltipRadioTextMap.set("BookedValue", "$ Booked");
428
+ this.tooltipRadioTextMap.set("BookedSpots", "Spots");
429
+ this.tooltipRadioTextMap.set("BookedGRP", "GRP");
430
+ this.tooltipRadioTextMap.set("BookedIMPSRevTab", "IMPS'(000)");
431
+ this.tooltipRadioTextMap.set("BookedCPP", "CPP");
432
+ this.tooltipRadioTextMap.set("BookedCPM", "CPM");
433
+ this.tooltipRadioTextMap.set("MGsValueForDisplay", "$ MGS");
434
+ this.tooltipRadioTextMap.set("MGsValue", "$ MGS");
435
+ this.tooltipRadioTextMap.set("ADUsValueForDisplay", "$ ADUS");
436
+ this.tooltipRadioTextMap.set("ADUsValue", "$ ADUS");
437
+ this.tooltipRadioTextMap.set("BuyerChangesValueForDisplay", "$ Buyer Change");
438
+ this.tooltipRadioTextMap.set("BuyerChangesValue", "$ Buyer Change");
439
+ this.tooltipRadioTextMap.set("UserChangesValueForDisplay", "$ Seller User Change");
440
+ this.tooltipRadioTextMap.set("UserChangesValue", "$ Seller User Change");
441
+ this.tooltipRadioTextMap.set("SellerLine", "Seller Line #");
442
+ this.tooltipRadioTextMap.set("BuyerLine", "Buy Line #");
443
+ this.tooltipRadioTextMap.set("SpotStatus", "Spot Status");
444
+ this.tooltipRadioTextMap.set("InventoryCode", "Inventory Code");
445
+ this.tooltipRadioTextMap.set("BuyerProgramName", "Buyer Program Name");
446
+ this.tooltipRadioTextMap.set("RevenueClass", "Revenue Class");
447
+ this.tooltipRadioTextMap.set("WeeklyAUR", "Booked Avg. Rate");
448
+ this.tooltipRadioTextMap.set("BookedRate", "Booked Rate");
449
+ this.tooltipRadioTextMap.set("averageRate", "Average Rate");
450
+ this.tooltipRadioTextMap.set("bookedAverageRate", "Booked AVG. Rate");
451
+ this.tooltipRadioTextMap.set("dollarIMPSImpact", "$ IMPS Impact");
452
+ this.tooltipRadioTextMap.set("dollarRTGImpact", "$ RTG IMPACT");
453
+ this.tooltipRadioTextMap.set("IMPSImpact", "IMPS ('000) IMPACT");
454
+ this.tooltipRadioTextMap.set("RTGImpact", "RTG Impact");
455
+ this.tooltipRadioTextMap.set("inventoryFillPercentageSameWeek", "Inv Fill Same Week (LY)");
456
+ this.tooltipRadioTextMap.set("inventoryFillPercentageFinal", "Inv Fill Final (LY)");
457
+ this.tooltipRadioTextMap.set("inventoryFillPercentageSameWeek", "Inv Fill Same Week (LY)");
458
+ this.tooltipRadioTextMap.set("inventoryFillPercentageFinal", "Inv Fill Final (LY)");
459
+ this.tooltipRadioTextMap.set("projectedRTG", "Projected RTG");
460
+ this.tooltipRadioTextMap.set("projectedIMPS", "Projected IMPS('000)");
461
+ this.tooltipRadioTextMap.set("desiredCPM", "Desired CPM");
462
+ this.tooltipRadioTextMap.set("desiredCPP", "Desired CPP");
463
+ this.tooltipRadioTextMap.set("origin", "Origin");
464
+ this.tooltipRadioTextMap.set("projectedRTG", "Projected RTG");
465
+ this.tooltipRadioTextMap.set("projectedIMPS", "Projected IMPS('000)");
466
+ this.tooltipRadioTextMap.set("desiredCPM", "Desired CPM");
467
+ this.tooltipRadioTextMap.set("desiredCPP", "Desired CPP");
468
+ this.tooltipRadioTextMap.set("origin", "Origin");
469
+ this.tooltipRadioTextMap.set("BookedRTG", "Booked RTG");
470
+ this.tooltipRadioTextMap.set("BookedIMPS", "Booked IMPS('000)");
471
+ this.tooltipRadioTextMap.set("IMPS", "IMP('000)");
472
+ this.tooltipRadioTextMap.set("AURTG", "Avg RTG");
473
+ this.tooltipRadioTextMap.set("AUIMPS", "Avg IMP('000)");
474
+ this.tooltipRadioTextMap.set("PostedRatingsOrImpressions", "Posted RTG");
475
+ this.tooltipRadioTextMap.set("ScheduleFlightWeek", "Schedule Week");
476
+ this.tooltipRadioTextMap.set("ScheduledDay", "Scheduled Day");
477
+ this.tooltipRadioTextMap.set("AirStatus", "Air Status");
478
+ this.tooltipRadioTextMap.set("AirDateAndTime", "Air Date & Time");
479
+ this.tooltipRadioTextMap.set("AirDate", "Air Date");
480
+ this.tooltipRadioTextMap.set("NormalizedOrderedRating", "Normalized Booked RTG");
481
+ this.tooltipRadioTextMap.set("NormalizedOrderedImpressions", "Normalized Booked IMP('000)");
482
+ this.tooltipRadioTextMap.set("BuyerLineNumber", "Buy Line #");
483
+ this.tooltipRadioTextMap.set("NormalizedPostedRating", "Normalized Posted RTG");
484
+ this.tooltipRadioTextMap.set("NormalizedPostedImpressions", "Normalized Posted IMP('000)");
485
+ this.tooltipRadioTextMap.set("AdId", "Ad-Id");
486
+ this.tooltipRadioTextMap.set("BookedRTG", "Booked RTG");
487
+ this.tooltipRadioTextMap.set("BookedIMPS", "Booked IMPS('000)");
488
+ this.tooltipRadioTextMap.set("IMPS", "IMP('000)");
489
+ this.tooltipRadioTextMap.set("AURTG", "Avg RTG");
490
+ this.tooltipRadioTextMap.set("AUIMPS", "Avg IMP('000)");
491
+ this.tooltipRadioTextMap.set("PostedRatingsOrImpressions", "Posted RTG");
492
+ this.tooltipRadioTextMap.set("ScheduleFlightWeek", "Schedule Week");
493
+ this.tooltipRadioTextMap.set("ScheduledDay", "Scheduled Day");
494
+ this.tooltipRadioTextMap.set("AirStatus", "Air Status");
495
+ this.tooltipRadioTextMap.set("AirDateAndTime", "Air Date & Time");
496
+ this.tooltipRadioTextMap.set("AirDate", "Air Date");
497
+ this.tooltipRadioTextMap.set("NormalizedOrderedRating", "Normalized Booked RTG");
498
+ this.tooltipRadioTextMap.set("NormalizedOrderedImpressions", "Normalized Booked IMP('000)");
499
+ this.tooltipRadioTextMap.set("NormalizedPostedRating", "Normalized Posted RTG");
500
+ this.tooltipRadioTextMap.set("NormalizedPostedImpressions", "Normalized Posted IMP('000)");
501
+ this.tooltipRadioTextMap.set("AdId", "Ad-Id");
502
+ this.tooltipRadioTextMap.set("displayimps", "IMPS");
503
+ this.tooltipRadioTextMap.set("displayGrp", "GRP");
504
+ this.tooltipRadioTextMap.set("bookedSpotsForDisplay", "Spots");
505
+ this.tooltipRadioTextMap.set("displaySpots", "Spots");
506
+ this.tooltipRadioTextMap.set("estimateNo", "Estimate#");
507
+ this.tooltipRadioTextMap.set("primaryBuyer", "Primary Buyer");
508
+ this.tooltipRadioTextMap.set("primaryBuyerName", "Primary Buyer");
509
+ this.tooltipRadioTextMap.set("secondaryBuyerName", "Secondary Buyer");
510
+ this.tooltipRadioTextMap.set("secondaryBuyer", "Secondary Buyer");
511
+ this.tooltipRadioTextMap.set("timeoutDate", "Timeout Date");
512
+ this.tooltipRadioTextMap.set("DisplaytSpotStatusBI", "Spot Status");
513
+ this.tooltipRadioTextMap.set("LineSpot", "Line.Spot");
514
+ this.tooltipRadioTextMap.set("LurWindowName", "Political Window");
515
+ this.tooltipRadioTextMap.set("lineAndSpotNumber", "Line.Spot#");
516
+ this.tooltipRadioTextMap.set("length", "Length");
517
+ this.tooltipRadioTextMap.set("revClass", "Rev Class");
518
+ // this.tooltipRadioTextMap.set("udValue", "$ UD");
519
+ // this.tooltipRadioTextMap.set("odValue", "$ OD");
520
+ this.tooltipRadioTextMap.set("udValue", "Proj. $ UD");
521
+ this.tooltipRadioTextMap.set("odValue", "Proj. $ OD");
522
+ this.tooltipRadioTextMap.set("InventoryCode", "Inventory Code");
523
+ this.tooltipRadioTextMap.set("BuyerProgramName", "Buyer Program Name");
524
+ this.tooltipRadioTextMap.set("StartTime", "Start Time");
525
+ this.tooltipRadioTextMap.set("EndTime", "End Time");
526
+ this.tooltipRadioTextMap.set("WeeklyAUR", "Booked Avg. Rate");
527
+ this.tooltipRadioTextMap.set("DisplayRevenueClass", "Rev Class");
528
+ this.tooltipRadioTextMap.set("ActualWeekStartDate", "Week");
529
+ this.tooltipRadioTextMap.set("WeekDay", "Day");
530
+ this.tooltipRadioTextMap.set("DisplayLength", "Length");
531
+ this.tooltipRadioTextMap.set("OtherAvailableSpotsTableInventoryCode", "Inventory Code");
532
+ this.tooltipRadioTextMap.set("OtherAvailableSpotsTableBuyerProgramName", "Buyer Program Name");
533
+ this.tooltipRadioTextMap.set("OtherAvailableSpotsTableStartTime", "Start Time");
534
+ this.tooltipRadioTextMap.set("OtherAvailableSpotsTableEndTime", "End Time");
535
+ this.tooltipRadioTextMap.set("OtherAvailableSpotsTableWeeklyAUR", "Booked Avg. Rate");
536
+ this.tooltipRadioTextMap.set("OtherAvailableSpotsTableDisplayRevenueClass", "Rev Class");
537
+ this.tooltipRadioTextMap.set("OtherAvailableSpotsTableActualWeekStartDate", "Week");
538
+ this.tooltipRadioTextMap.set("OtherAvailableSpotsTableWeekDay", "Day");
539
+ this.tooltipRadioTextMap.set("OtherAvailableSpotsTableDisplayLength", "Length");
540
+ this.tooltipRadioTextMap.set("ProjectedImpressions", "Projected IMP('000)");
541
+ this.tooltipRadioTextMap.set("ProjectedRtg", "Projected RTG");
542
+ this.tooltipRadioTextMap.set("ProjectedImpressions", "Projected IMP('000)");
543
+ this.tooltipRadioTextMap.set("ProjectedRtg", "Projected RTG");
544
+ }
545
+ selectOrUnselectCheckbox(rowData, columnKeys, isCheckboxSelected) {
546
+ rowData[columnKeys] = !rowData[columnKeys];
547
+ this.toggleCheckbox.emit({ rowData, columnKeys, isCheckboxSelected });
548
+ }
549
+ selectOrUnselectRadiobox(rowData, columnKeys, isCheckboxSelected) {
550
+ if (rowData[columnKeys] === isCheckboxSelected)
551
+ return;
552
+ rowData[columnKeys] = isCheckboxSelected;
553
+ this.toggleCheckbox.emit({ rowData, columnKeys, isCheckboxSelected });
554
+ }
555
+ selectUnselectAllRows() {
556
+ this.toggleHeaderCheckbox.emit();
557
+ }
558
+ selectUnselectRow(rowData) {
559
+ this.toggleRowCheckbox.emit(rowData);
560
+ }
561
+ undoCreditedSpot(data) {
562
+ this.undoIconClicked.emit({ data, mgOrCredit: "Credit" });
563
+ }
564
+ undoMgSpot(data) {
565
+ this.undoIconClicked.emit({ data, mgOrCredit: "MakeGood" });
566
+ }
567
+ // Sort and Filter Logic begins!
568
+ closeTooltip() {
569
+ if (this.tooltip && this.tooltip.isOpen()) {
570
+ this.tooltip.close();
571
+ }
572
+ this.tooltip = null;
573
+ if (!this.bindValueFuncCalled) {
574
+ this.columnFilterClosed.emit();
575
+ }
576
+ }
577
+ isTooltipActive(header) {
578
+ return this.annaFilterService.isTooltipActive(header, this.annaSortService.columnSortState);
579
+ }
580
+ bindTheValueToToolTip(tooltip, header) {
581
+ this.bindValueFuncCalled = true;
582
+ // if same tooltip opened close it
583
+ if (tooltip === this.tooltip) {
584
+ this.bindValueFuncCalled = false;
585
+ this.closeTooltip();
586
+ }
587
+ else {
588
+ const enabledHeaders = [];
589
+ this.checkIfUniqueValuePresentForTheHeader(header, enabledHeaders);
590
+ this.openTooltip(tooltip, enabledHeaders, header);
591
+ if (window.innerWidth < 1500 &&
592
+ window.innerHeight < 768 &&
593
+ !this.annaFilterService.sliderSet.has(header.filterSortObjectKeys[0])) {
594
+ this.columnFilterOpened.emit();
595
+ }
596
+ this.showCheckboxesForTimeFilter =
597
+ this.gtGeneralConfig.component === "SPOTDETAILS" ||
598
+ this.gtGeneralConfig.component === "EXCLUDEINVENTORYPOPUP" ||
599
+ this.gtGeneralConfig.component === "RATING";
600
+ this.showFilterTooltipTabs = header.filterSortObjectKeys.length > 1;
601
+ this.bindValueFuncCalled = false;
602
+ }
603
+ }
604
+ checkIfUniqueValuePresentForTheHeader(header, enabledHeaders) {
605
+ header.filterSortObjectKeys.forEach((item) => {
606
+ const dataToCheck = this.annaFilterService.getFilterOptionsData(this.tableData, this.clonedTableData, item);
607
+ if (item === "period") {
608
+ const uniqStartDate = uniq(dataToCheck.map((u) => u.startDate));
609
+ const uniqEndDate = uniq(dataToCheck.map((u) => u.endDate));
610
+ if (uniqStartDate.length > 1 || uniqEndDate.length > 1 || this.isTooltipActive([item])) {
611
+ enabledHeaders.push(item);
612
+ }
613
+ }
614
+ else {
615
+ const values = dataToCheck.map((u) => u[item]);
616
+ // if last applied filter is this header, push it alos as enabledHeader
617
+ let activeAndLastlyAppliedHeader = false;
618
+ if (this.annaFilterService.appliedFiltersArray.length > 0 &&
619
+ this.annaFilterService.appliedFiltersArray[this.annaFilterService.appliedFiltersArray.length - 1] === item) {
620
+ activeAndLastlyAppliedHeader = true;
621
+ }
622
+ if (header.filter === "CHECKBOX" &&
623
+ (uniq(values).filter((n) => n != null).length > 1 || activeAndLastlyAppliedHeader)) {
624
+ enabledHeaders.push(item);
625
+ }
626
+ else if (header.filter !== "CHECKBOX" &&
627
+ (uniq(values).filter((n) => n != null && n !== "-").length > 1 || activeAndLastlyAppliedHeader)) {
628
+ enabledHeaders.push(item);
629
+ }
630
+ }
631
+ });
632
+ }
633
+ openTooltip(tooltip, header, columnHeader) {
634
+ this.closeTooltip();
635
+ this.tooltip = tooltip;
636
+ this.tooltip.open();
637
+ // convert key into the header
638
+ this.filterTabObjects = header.map((key, index) => {
639
+ // change to display name
640
+ const value = this.tooltipRadioTextMap.has(key) ? this.tooltipRadioTextMap.get(key) : key;
641
+ return new RadioButtonModel(key, value, columnHeader.isSortRequired[index], columnHeader.isFilterRequired[index]);
642
+ });
643
+ }
644
+ disableEnableEachColumnTooltipIcon() {
645
+ this.tableHeaders.forEach((header) => {
646
+ header.headerInfo.forEach((item) => {
647
+ if (item.showTooltipIcon) {
648
+ let values = [];
649
+ item.disableTooltipIcon = true;
650
+ item.filterSortObjectKeys.forEach((key) => {
651
+ const latestFilters = this.annaFilterService.appliedFiltersArray;
652
+ if (latestFilters.length > 0 &&
653
+ item.disableTooltipIcon &&
654
+ latestFilters[latestFilters.length - 1] === key) {
655
+ item.disableTooltipIcon = false;
656
+ }
657
+ if (item.disableTooltipIcon) {
658
+ if (key === "period") {
659
+ const uniqStartDate = uniq(this.tableData.map((u) => u.startDate));
660
+ const uniqEndDate = uniq(this.tableData.map((u) => u.endDate));
661
+ item.disableTooltipIcon = !(uniqStartDate.length > 1 || uniqEndDate.length > 1);
662
+ }
663
+ else {
664
+ values = this.tableData.map((u) => u[key]);
665
+ if ((item.filter === "CHECKBOX" && uniq(values).filter((n) => n != null).length > 1) ||
666
+ (item.filter !== "CHECKBOX" &&
667
+ uniq(values).filter((n) => n != null && n !== "-").length > 1)) {
668
+ item.disableTooltipIcon = false;
669
+ }
670
+ }
671
+ }
672
+ });
673
+ }
674
+ });
675
+ });
676
+ }
677
+ dataRowClicked(rowData) {
678
+ this.rowClicked.emit(rowData);
679
+ }
680
+ radioButtonClicked(data, action, isDisabled) {
681
+ if (!isDisabled) {
682
+ this.radioButtonSelected.emit({ data, action });
683
+ }
684
+ }
685
+ bindTheValueToSellerGroupTooltip(sellerGroupHierarchy, tooltip) {
686
+ if (this.hierarchyTooltip && this.hierarchyTooltip.open) {
687
+ this.hierarchyTooltip.close();
688
+ }
689
+ this.sellerGroupHierarchy = sellerGroupHierarchy;
690
+ this.hierarchyTooltip = tooltip;
691
+ this.hierarchyTooltip.open();
692
+ }
693
+ iconClicked(rowData, iconClass) {
694
+ if ("orderId" in rowData && iconClass.includes("mdi-star")) {
695
+ this.selectedStarredOrderId = rowData.orderId;
696
+ }
697
+ this.gtIconClicked.emit({ data: rowData, iconClass });
698
+ }
699
+ svgIconClicked(data) {
700
+ this.gtSVGIconClicked.emit(data);
701
+ }
702
+ textActionClicked(rowData, id, columnHeader) {
703
+ this.gtTextActionClicked.emit({ data: rowData, id, columnHeader, isIconClicked: false });
704
+ }
705
+ iconClickedOnStringIconActionType(rowData, id, columnHeader) {
706
+ this.gtTextActionClicked.emit({ data: rowData, id, columnHeader, isIconClicked: true });
707
+ }
708
+ innerHTMLCellClicked(event, rowData) {
709
+ this.gtInnerHTMLClicked.emit({ event, rowData });
710
+ }
711
+ viewDetailsClicked(rowData) {
712
+ this.gtViewDetailClicked.emit({ data: rowData });
713
+ }
714
+ setActiveStateObject() {
715
+ this.annaFilterService.isFilterSortActive =
716
+ !this.annaFilterService.resetFilterSortActiveStatus || this.multipleTablesPresent
717
+ ? this.annaFilterService.isFilterSortActive
718
+ : {};
719
+ this.tableHeaders.forEach((item) => {
720
+ item.headerInfo.forEach((header) => {
721
+ if (header.showTooltipIcon) {
722
+ const key = header.filterSortObjectKeys.join(",");
723
+ header.joinedFilterSortObjectKeys = key;
724
+ // ANNA-4113 fix
725
+ if (this.annaFilterService.resetFilterSortActiveStatus) {
726
+ this.annaFilterService.isFilterSortActive[key] = false;
727
+ }
728
+ }
729
+ });
730
+ });
731
+ this.annaFilterService.resetFilterSortActiveStatus = true;
732
+ }
733
+ setIsDifference(value) {
734
+ this.isDifferenceLessThan25Percent = value;
735
+ }
736
+ resetIndex() {
737
+ this.start = 0;
738
+ this.end = this.limit + this.start;
739
+ }
740
+ onTableContainerScroll(e) {
741
+ const tableViewHeight = e.target.offsetHeight; // viewport
742
+ const tableScrollHeight = e.target.scrollHeight; // length of all table
743
+ const scrollLocation = e.target.scrollTop; // how far user scrolled
744
+ this.removeTooltipOnScroll();
745
+ // If the user has scrolled within 150px of the bottom, add more data
746
+ const buffer = 150;
747
+ const limit = tableScrollHeight - tableViewHeight - buffer;
748
+ if (scrollLocation > limit) {
749
+ const data = this.getTableData(this.start, this.end);
750
+ this.renderedData = this.renderedData.concat(data);
751
+ this.updateIndex();
752
+ }
753
+ this.tableContainerScrolled(e);
754
+ }
755
+ getTableData(start, end) {
756
+ return this.tableData?.filter((value, index) => index >= start && index < end);
757
+ }
758
+ updateIndex() {
759
+ this.start = this.end;
760
+ this.end = this.limit + this.start;
761
+ }
762
+ setInitialRowsForTable() {
763
+ this.resetIndex();
764
+ this.renderedData = this.getTableData(this.start, this.end);
765
+ this.updateIndex();
766
+ }
767
+ spotDetailsDownloadClicked(parentChildOrTotalRow, rowdata) {
768
+ if (rowdata) {
769
+ this.selectedInventoryIdForDownload = rowdata.inventoryCodeId;
770
+ this.selectedDemographicForDownload = rowdata.demographic;
771
+ }
772
+ else {
773
+ this.selectedInventoryIdForDownload = null;
774
+ this.selectedDemographicForDownload = null;
775
+ }
776
+ this.selectedRowTypeForDownload = parentChildOrTotalRow;
777
+ this.downloadSpotDetails.emit({
778
+ parentChildOrTotalRow,
779
+ inventoryCodeId: this.selectedInventoryIdForDownload,
780
+ demographic: this.selectedDemographicForDownload,
781
+ });
782
+ }
783
+ tableContainerScrolled(event) {
784
+ this.isScrolledLeft = event.target.scrollLeft > 0;
785
+ this.isScrollEnded =
786
+ Math.round(event.target.scrollLeft) === event.target.scrollWidth - event.target.clientWidth;
787
+ this.removeTooltipOnScroll();
788
+ }
789
+ mouseEnterOnStringTextActionType(rowData, tooltipKey) {
790
+ this.textActionTooltip = rowData[tooltipKey];
791
+ this.notificationIconHover.emit({ rowData, type: "on-enter" });
792
+ }
793
+ mouseEnterOnStringTextActionTypeContainingTable(rowData, tooltipKey) {
794
+ this.tooltipContainingTable = rowData[tooltipKey];
795
+ }
796
+ mouseLeaveTextActionType(rowData) {
797
+ this.notificationIconHoverLeave.emit({ rowData, type: "on-leave" });
798
+ }
799
+ mouseEnterOnTextActionType(rowData, tooltipKey) {
800
+ this.textActionTooltip = rowData[tooltipKey];
801
+ }
802
+ onClickableDataClicked(Rowdata, id) {
803
+ this.clickableDataClicked.emit({ data: Rowdata, id });
804
+ }
805
+ removeTooltipOnScroll() {
806
+ const elements = document.getElementsByClassName("remarks-info-tooltip");
807
+ // const tooltipElements = document.getElementsByClassName("tooltip");
808
+ const gtTooltip = document.getElementsByClassName("remove-on-scroll-class");
809
+ document.querySelectorAll(".tooltip:not(.keep-on-scroll-tooltip)").forEach((e) => {
810
+ e.remove();
811
+ this.tooltip = null;
812
+ });
813
+ while (elements && elements.length > 0) {
814
+ elements[0].remove();
815
+ }
816
+ while (gtTooltip && gtTooltip.length > 0) {
817
+ gtTooltip[0].remove();
818
+ }
819
+ }
820
+ iconClickedInTotalRow(colName) {
821
+ this.totalRowIconClicked.emit(colName);
822
+ }
823
+ changesMadeInEditableInputBox(event, editedObject, pasteEvent) {
824
+ const enteredValue = pasteEvent ? event.clipboardData.getData("text") : event.key;
825
+ const dotIndex = editedObject.value.indexOf(".");
826
+ if (event.keyCode !== 8 &&
827
+ event.keyCode !== 46 &&
828
+ !(event.keyCode >= 37 && event.keyCode <= 40) &&
829
+ ((!editedObject?.allowSpecialCharacters && !/[`0-9.]/.test(enteredValue)) ||
830
+ (editedObject?.charactersToRestrict && editedObject?.charactersToRestrict.includes(enteredValue)) ||
831
+ (editedObject.isDecimalPointCheckRequired &&
832
+ dotIndex >= 0 &&
833
+ event?.target?.selectionStart > dotIndex &&
834
+ editedObject.value.length - (dotIndex + 1) >= editedObject.maxDecimalPointsAllowed))) {
835
+ event.preventDefault();
836
+ }
837
+ }
838
+ editableInputValueChanged(value, row, keyEdited) {
839
+ this.editableInputEdited.emit({ row, value, keyEdited });
840
+ }
841
+ radioButtonIconClicked(data) {
842
+ this.radioButtonMessageIconClicked.emit(data);
843
+ }
844
+ filterApplied(tableData) {
845
+ this.tableData = tableData;
846
+ this.setInitialRowsForTable();
847
+ this.disableEnableEachColumnTooltipIcon();
848
+ this.filterAppliedToTable.emit(tableData);
849
+ this.closeTooltip();
850
+ }
851
+ sortingApplied(tableData) {
852
+ this.tableData = tableData;
853
+ this.setInitialRowsForTable();
854
+ this.disableEnableEachColumnTooltipIcon();
855
+ this.sortingAppliedToTable.emit(tableData);
856
+ this.closeTooltip();
857
+ }
858
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AnnaNonEditableGenericNormalTableComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.AnnaSortService }, { token: i2.AnnaDateTimeFormatService }, { token: i3.AnnaFilterService }], target: i0.ɵɵFactoryTarget.Component }); }
859
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: AnnaNonEditableGenericNormalTableComponent, isStandalone: true, selector: "anna-core-anna-non-editable-generic-normal-table", 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", showOrHideToggleForTotalRow: "showOrHideToggleForTotalRow" }, 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: "tableElementRef", first: true, predicate: ["tableElementRef"], descendants: true, static: true }, { propertyName: "viewChildTableHeaders", predicate: ["tableHeader"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div\n id=\"generic-table-conatiner\"\n #tableElementRef\n class=\"table-container {{ gtGeneralConfig?.tableOuterContainerName }} {{ tableBottomBorderClass }}\"\n [ngClass]=\"{\n 'scroll-left-shadow-effect': isScrolledLeft,\n 'scroll-right-shadow-effect': !isScrollEnded,\n 'clickable-row': clickableRow,\n 'no-data-table': (isNoDataToDisplaySubject$ | async),\n 'table-with-show-hide-total-row-toggle': showOrHideToggleForTotalRow\n }\"\n (scroll)=\"onTableContainerScroll($event)\"\n>\n <div\n [class]=\"gtGeneralConfig.tableContainerName\"\n class=\"horizontal-scroll-for-table-container\"\n [ngStyle]=\"{\n height:\n tableData.length < maximumRowsWhichCanBeRenderedWithoutScroll\n ? 'calc(' +\n (gtDimension.rowHeight * tableData.length +\n (!tableData.length || !gtGeneralConfig.totalRow\n ? gtDimension.headerHeight\n : gtDimension.headerHeight + gtDimension.rowHeight)) +\n 'px)'\n : gtDimension.tableHeight\n }\"\n >\n <button\n *ngIf=\"showOrHideToggleForTotalRow && !showSkeletonLoading && (isNoDataToDisplaySubject$ | async) === false\"\n [ngClass]=\"{\n 'shift-toggle-top-on-total-row-click': !gtGeneralConfig.totalRow\n }\"\n class=\"show-or-hide-toggle-btn\"\n (click)=\"showHideTotalRow()\"\n >\n <i\n class=\"mdi mdi-menu-swap\"\n tooltipClass=\"show-or-hide-toggle-tooltip\"\n placement=\"auto\"\n container=\"body\"\n [ngbTooltip]=\"showOrHideToggleForTotalRowTooltip\"\n ></i>\n </button>\n <table\n class=\"gt\"\n [ngClass]=\"tableClass\"\n >\n <thead>\n <tr\n class=\"header-row\"\n mat-header-row\n [style.height.px]=\"gtDimension.headerHeight\"\n >\n <ng-container *ngFor=\"let columnDef of tableHeaders; trackBy: trackByFn\">\n <th\n #tableHeader\n nowrap\n [style.width]=\"columnDef.width\"\n >\n <div\n class=\"row mx-0\"\n *ngFor=\"let header of columnDef.headerInfo; let j = index\"\n >\n <p\n *ngIf=\"header.typeOfHeaderData === 'STRING'\"\n [ngClass]=\"{ 'upper-label': j === 0, 'lower-label': j === 1 }\"\n >\n <ngx-skeleton-loader\n *ngIf=\"header.name == null\"\n count=\"1\"\n [theme]=\"{\n height: '10px',\n display: 'block',\n width: columnDef.width,\n 'max-width': 'calc(100% - 20px)'\n }\"\n >\n </ngx-skeleton-loader>\n <ng-container *ngIf=\"header.name\">\n {{ header.name }}\n </ng-container>\n <ng-container *ngIf=\"header.tooltip && header.tooltip.tooltipMessage\">\n <i\n class=\"{{ header['tooltip'].iconClass }}\"\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n #t=\"ngbTooltip\"\n container=\"body\"\n [ngbTooltip]=\"header.tooltip.tooltipMessage\"\n container=\"body\"\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n >\n </i>\n </ng-container>\n <i\n *ngIf=\"header.tooltip && header.tooltip.name === 'impsInfoTooltip'\"\n class=\"{{ header['tooltip'].iconClass }}\"\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n #t=\"ngbTooltip\"\n container=\"body\"\n [ngbTooltip]=\"impsInfoTooltip\"\n container=\"body\"\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n >\n </i>\n <i\n *ngIf=\"\n header.tooltip &&\n header.tooltip.name === 'spotsColumnEquivalizationMessageTooltip'\n \"\n class=\"{{ header['tooltip'].iconClass }}\"\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n container=\"body\"\n #t=\"ngbTooltip\"\n container=\"body\"\n [ngbTooltip]=\"spotsColumnEquivalizationMessageTooltip\"\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n >\n </i>\n <i\n *ngIf=\"header.tooltip && header.tooltip.name === 'underDeliveryTooltip'\"\n class=\"{{ header['tooltip'].iconClass }}\"\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n container=\"body\"\n #t=\"ngbTooltip\"\n container=\"body\"\n [ngbTooltip]=\"underDeliveryTooltip\"\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n >\n </i>\n <i\n *ngIf=\"header.tooltip && header.tooltip.name === 'overDeliveryTooltip'\"\n class=\"{{ header['tooltip'].iconClass }}\"\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n container=\"body\"\n #t=\"ngbTooltip\"\n container=\"body\"\n [ngbTooltip]=\"overDeliveryTooltip\"\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n >\n </i>\n <i\n *ngIf=\"header.tooltip && header.tooltip.name === 'ratingInfoTooltip'\"\n class=\"{{ header['tooltip'].iconClass }}\"\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n #t=\"ngbTooltip\"\n container=\"body\"\n [ngbTooltip]=\"ratingInfoTooltip\"\n container=\"body\"\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n >\n </i>\n <i\n *ngIf=\"header.tooltip && header.tooltip.name === 'rateInfoTooltip'\"\n class=\"{{ header['tooltip'].iconClass }}\"\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n #t=\"ngbTooltip\"\n container=\"body\"\n [ngbTooltip]=\"rateInfoTooltip\"\n container=\"body\"\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n >\n </i>\n <i\n *ngIf=\"\n header.tooltip && header.tooltip.name === 'ongoingRevBookedColumnTooltip'\n \"\n class=\"{{ header['tooltip'].iconClass }}\"\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n #t=\"ngbTooltip\"\n container=\"body\"\n [ngbTooltip]=\"ongoingRevBookedColumnTooltip\"\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n >\n </i>\n <i\n *ngIf=\"\n header.tooltip && header.tooltip.name === 'completedRevBookedColumnTooltip'\n \"\n class=\"{{ header['tooltip'].iconClass }}\"\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n #t=\"ngbTooltip\"\n container=\"body\"\n [ngbTooltip]=\"completedRevBookedColumnTooltip\"\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n >\n </i>\n <i\n *ngIf=\"header.tooltip && header.tooltip.name === 'avgBookedRate'\"\n class=\"{{ header['tooltip'].iconClass }}\"\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n #t=\"ngbTooltip\"\n container=\"body\"\n [ngbTooltip]=\"avgBookedRate\"\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n >\n </i>\n <i\n *ngIf=\"header.tooltip && header.tooltip.name === 'avgBookedRtg'\"\n class=\"{{ header['tooltip'].iconClass }}\"\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n #t=\"ngbTooltip\"\n container=\"body\"\n [ngbTooltip]=\"avgBookedRtg\"\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n >\n </i>\n <i\n *ngIf=\"header.tooltip && header.tooltip.name === 'avgBookedImps'\"\n class=\"{{ header['tooltip'].iconClass }}\"\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n #t=\"ngbTooltip\"\n container=\"body\"\n [ngbTooltip]=\"avgBookedImps\"\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n >\n </i>\n\n <i\n *ngIf=\"header.tooltip && header.tooltip.name === 'automationTooltip'\"\n class=\"{{ header['tooltip'].iconClass }}\"\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n #t=\"ngbTooltip\"\n container=\"body\"\n [ngbTooltip]=\"automationTooltip\"\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n >\n </i>\n\n <i\n *ngIf=\"header.tooltip && header.tooltip.name === 'rebateImpact'\"\n class=\"{{ header['tooltip'].iconClass }}\"\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n #t=\"ngbTooltip\"\n container=\"body\"\n [ngbTooltip]=\"rebateImpact\"\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n >\n </i>\n\n <i\n *ngIf=\"header.tooltip && header.tooltip.name === 'projectedImpsRtg'\"\n class=\"{{ header['tooltip'].iconClass }}\"\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n #t=\"ngbTooltip\"\n container=\"body\"\n [ngbTooltip]=\"projectedImpsRtg\"\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n >\n </i>\n </p>\n\n <ng-container *ngIf=\"header.typeOfHeaderData === 'CHECKBOX'\">\n <span\n *ngIf=\"gtGeneralConfig.isHeaderChecked\"\n class=\"material-icons custom-column-checkbox-checked\"\n (click)=\"selectUnselectAllRows()\"\n >\n check_box\n </span>\n <span\n *ngIf=\"!gtGeneralConfig.isHeaderChecked\"\n class=\"material-icons custom-column-checkbox-unchecked\"\n [ngClass]=\"{ 'disable-checkbox': gtGeneralConfig.disableHeaderCheckbox }\"\n (click)=\"selectUnselectAllRows()\"\n >\n check_box_outline_blank\n </span>\n </ng-container>\n\n <div\n *ngIf=\"gtGeneralConfig.showAllColumnFilter\"\n class=\"sort-filter-container\"\n >\n <ng-container *ngIf=\"header.showTooltipIcon\">\n <!-- Active tooltip Functionality -->\n <ng-container *ngIf=\"header.filter === 'CHECKBOX'\">\n <span\n class=\"mdi mdi-filter-variant\"\n [ngClass]=\"{\n active:\n annaFilterService.isFilterSortActive &&\n annaFilterService.isFilterSortActive[\n header.joinedFilterSortObjectKeys\n ],\n disabled: header.disableTooltipIcon || showSkeletonLoading\n }\"\n [ngbTooltip]=\"filterTooltip\"\n placement=\"{{ filterAlignment }}\"\n container=\"body\"\n tooltipClass=\"non-edit-checkbox-tooltip\"\n [autoClose]=\"'outside'\"\n triggers=\"manual\"\n #t=\"ngbTooltip\"\n (click)=\"bindTheValueToToolTip(t, header)\"\n (hidden)=\"closeTooltip()\"\n >\n </span\n ><br />\n </ng-container>\n <ng-container *ngIf=\"header.filter === 'SLIDER'\">\n <span\n class=\"mdi mdi-filter-variant\"\n [ngClass]=\"{\n active:\n annaFilterService.isFilterSortActive &&\n annaFilterService.isFilterSortActive[\n header.joinedFilterSortObjectKeys\n ],\n disabled: header.disableTooltipIcon || showSkeletonLoading\n }\"\n [ngbTooltip]=\"sliderToolTip\"\n placement=\"bottom left-top\"\n container=\"body\"\n tooltipClass=\"non-edit-slider-tooltip\"\n [autoClose]=\"'outside'\"\n triggers=\"manual\"\n #t1=\"ngbTooltip\"\n (click)=\"bindTheValueToToolTip(t1, header)\"\n (hidden)=\"closeTooltip()\"\n >\n </span\n ><br />\n </ng-container>\n <ng-container *ngIf=\"header.filter === 'DATE'\">\n <span\n class=\"mdi mdi-filter-variant\"\n [ngClass]=\"{\n active:\n annaFilterService.isFilterSortActive &&\n annaFilterService.isFilterSortActive[\n header.joinedFilterSortObjectKeys\n ],\n disabled: header.disableTooltipIcon || showSkeletonLoading\n }\"\n [ngbTooltip]=\"datePickerTooltip\"\n placement=\"bottom auto\"\n container=\"body\"\n tooltipClass=\"non-edit-datepicker-tooltip\"\n [autoClose]=\"'outside'\"\n triggers=\"manual\"\n #t2=\"ngbTooltip\"\n (click)=\"bindTheValueToToolTip(t2, header)\"\n (hidden)=\"closeTooltip()\"\n >\n </span\n ><br />\n </ng-container>\n <ng-container *ngIf=\"header.filter === 'WEEK'\">\n <span\n class=\"mdi mdi-filter-variant\"\n [ngClass]=\"{\n active:\n annaFilterService.isFilterSortActive &&\n annaFilterService.isFilterSortActive[\n header.joinedFilterSortObjectKeys\n ],\n disabled: header.disableTooltipIcon || showSkeletonLoading\n }\"\n [ngbTooltip]=\"weekPickerToolTip\"\n placement=\"bottom left-top\"\n container=\"body\"\n [autoClose]=\"'outside'\"\n triggers=\"manual\"\n #t3=\"ngbTooltip\"\n (click)=\"bindTheValueToToolTip(t3, header)\"\n (hidden)=\"closeTooltip()\"\n >\n </span\n ><br />\n </ng-container>\n <ng-container *ngIf=\"header.filter === 'TIME'\">\n <span\n class=\"mdi mdi-filter-variant\"\n [ngClass]=\"{\n active:\n annaFilterService.isFilterSortActive &&\n annaFilterService.isFilterSortActive[\n header.joinedFilterSortObjectKeys\n ],\n disabled: header.disableTooltipIcon || showSkeletonLoading\n }\"\n [ngbTooltip]=\"timeFilterToolTip\"\n placement=\"bottom left-top auto\"\n container=\"body\"\n tooltipClass=\"non-edit-time-tooltip\"\n [autoClose]=\"'outside'\"\n triggers=\"manual\"\n #t4=\"ngbTooltip\"\n (click)=\"bindTheValueToToolTip(t4, header)\"\n (hidden)=\"closeTooltip()\"\n >\n </span\n ><br />\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"!header.showTooltipIcon\">\n <span id=\"no-filter-space\"></span><br />\n </ng-container>\n <i\n *ngIf=\"header.tooltip && header.tooltip.name === 'lurViolationInfoTooltip'\"\n class=\"{{ header['tooltip'].iconClass }}\"\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n #t=\"ngbTooltip\"\n container=\"body\"\n [ngbTooltip]=\"lurViolationInfoTooltip\"\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n >\n </i>\n </div>\n </div>\n </th>\n </ng-container>\n </tr>\n <tr\n class=\"total-row\"\n [style.height.px]=\"gtDimension.rowHeight\"\n *ngIf=\"\n !showSkeletonLoading &&\n tableData.length > 0 &&\n gtGeneralConfig.totalRow &&\n (isNoDataToDisplaySubject$ | async) === false\n \"\n >\n <ng-container *ngFor=\"let column of totalRowInfo; trackBy: trackByFn\">\n <td\n [attr.colspan]=\"column.colspan\"\n class=\"{{ column.class }}\"\n >\n <ng-container *ngIf=\"column['isActionColumn']\">\n <a\n *ngFor=\"let data of column.actionData\"\n [class]=\"data.class\"\n (click)=\"onClickableDataClicked({}, data.id)\"\n >\n {{ data.name }}\n </a>\n </ng-container>\n\n <ng-container *ngIf=\"column['isIconColumn']\">\n <i\n class=\"{{ column?.iconData?.class }}\"\n (click)=\"iconClickedInTotalRow(column?.colName)\"\n >\n </i>\n </ng-container>\n\n <ng-container *ngIf=\"!column['isActionColumn']\">\n <strong class=\"upper-label\"\n >{{ column.data }}\n <span\n class=\"red-text-totol-row\"\n *ngIf=\"column.additionalRedTextAfterData\"\n >{{ column.additionalRedTextAfterData }}</span\n ></strong\n >\n <ng-container *ngIf=\"column.lowerData\">\n <br />\n <span\n *ngIf=\"\n column.colName === 'total-potential-booked-unit' &&\n gtGeneralConfig.component === 'RATING';\n else columnLowerData\n \"\n class=\"clickable-data\"\n (click)=\"spotDetailsDownloadClicked('TOTALROW')\"\n [ngClass]=\"{ 'disabled-clickable-data': downloadInProgress }\"\n >{{ column.lowerData }}\n <span class=\"material-icons spot-details-download-icons\">get_app</span>\n <ng-container\n *ngIf=\"downloadInProgress && selectedRowTypeForDownload === 'TOTALROW'\"\n >\n <ng-container [ngTemplateOutlet]=\"circularProgressBar\"></ng-container>\n </ng-container>\n </span>\n <ng-template #columnLowerData>\n <span class=\"lower-label\">{{ column.lowerData }}</span>\n </ng-template>\n </ng-container>\n <ng-container\n *ngIf=\"column.tooltipMessage && gtGeneralConfig.component !== 'LUR_VIOLATIONS'\"\n >\n <i\n class=\"{{ column.tooltipIconClass }}\"\n container=\"body\"\n [ngbTooltip]=\"column.tooltipMessage\"\n tooltipClass=\"gt-total-row-tooltip\"\n placement=\"top bottom\"\n ></i>\n </ng-container>\n <ng-container\n *ngIf=\"gtGeneralConfig.component === 'LUR_VIOLATIONS' && column.tooltipMessage\"\n >\n <i\n class=\"mi mdi-info-outline info-label\"\n container=\"body\"\n [ngbTooltip]=\"lurViolationTotalRowToolTip\"\n tooltipClass=\"gt-total-row-tooltip\"\n placement=\"bottom\"\n ></i>\n </ng-container>\n </ng-container>\n </td>\n </ng-container>\n </tr>\n </thead>\n <tbody>\n <tr\n [class]=\"ROW_DATA.gtClass\"\n [ngClass]=\"{ 'no-border-tr': (isNoDataToDisplaySubject$ | async) }\"\n [style.height.px]=\"gtDimension.rowHeight\"\n (click)=\"dataRowClicked(ROW_DATA)\"\n *ngFor=\"let ROW_DATA of renderedData; trackBy: trackByFn\"\n >\n <ng-container *ngFor=\"let columnDef of tableHeaders; trackBy: trackByFn\">\n <td\n [style.background]=\"ROW_DATA.backgroundColor\"\n [style.border]=\"ROW_DATA.border\"\n class=\"{{ ROW_DATA.rowClass }}\"\n [ngClass]=\"ROW_DATA[columnDef.headerInfo[0].objectKey + 'TdClass']\"\n [attr.rowspan]=\"ROW_DATA[columnDef.headerInfo[0].objectKey + 'Rowspan']\"\n *ngIf=\"\n !hideSomeTds ||\n (hideSomeTds && !ROW_DATA['hide' + columnDef.headerInfo[0].objectKey + 'Td'])\n \"\n >\n <ngx-skeleton-loader\n *ngIf=\"showSkeletonLoading\"\n count=\"1\"\n [theme]=\"{ height: '10px', display: 'block' }\"\n >\n </ngx-skeleton-loader>\n\n <ng-container *ngIf=\"!showSkeletonLoading\">\n <ng-container\n *ngIf=\"tableData.length > 0 && (isNoDataToDisplaySubject$ | async) === false\"\n >\n <ng-container\n *ngFor=\"\n let subline of columnDef.headerInfo;\n let subLineIndex = index;\n trackBy: trackByFn\n \"\n >\n <div annaCoreShowEllipsisTextOnHover>\n <ng-container\n [ngSwitch]=\"columnDef.headerInfo[subLineIndex].typeOfBodyData\"\n >\n <ng-container *ngSwitchCase=\"'ICON'\">\n <i\n *ngIf=\"\n !(\n starredInProgress &&\n ROW_DATA.orderId === selectedStarredOrderId\n )\n \"\n [class]=\"ROW_DATA.iconClass\"\n (click)=\"iconClicked(ROW_DATA, ROW_DATA.iconClass)\"\n ngbTooltip=\"{{ ROW_DATA.iconTitleText }}\"\n placement=\"bottom\"\n container=\"body\"\n tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\n ></i>\n <ng-container\n *ngIf=\"\n starredInProgress &&\n ROW_DATA.orderId === selectedStarredOrderId\n \"\n >\n <div class=\"spinner-for-button-directive\"></div>\n </ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'ICON_CELL'\">\n <ng-container\n *ngFor=\"\n let action of ROW_DATA[\n columnDef.headerInfo[subLineIndex].actionKey\n ]\n \"\n >\n <ng-container *ngIf=\"action.showObjectKey\">\n {{ ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey] }}\n </ng-container>\n\n <i\n *ngIf=\"action.showIcon\"\n [class]=\"action.iconClass\"\n (mouseenter)=\"\n mouseEnterOnStringTextActionType(\n ROW_DATA,\n columnDef.headerInfo[subLineIndex].tooltipKey\n )\n \"\n placement=\"bottom auto\"\n container=\"body\"\n [autoClose]=\"true\"\n tooltipClass=\"team-user-tooltip remove-on-scroll-class\"\n [ngbTooltip]=\"\n action.showTooltip ? action.tooltipData : null\n \"\n (click)=\"\n textActionClicked(\n ROW_DATA,\n action.id,\n columnDef.headerInfo[subLineIndex]\n )\n \"\n [disableTooltip]=\"!action.showTooltip\"\n >\n </i>\n </ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'HTML_STRING'\">\n <p\n [innerHTML]=\"\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n \"\n (click)=\"innerHTMLCellClicked($event, ROW_DATA)\"\n ></p>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'SVG_ICON'\">\n <anna-core-icon-column\n [componentName]=\"gtGeneralConfig.component\"\n [dataObject]=\"ROW_DATA\"\n [iconToShow]=\"\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n \"\n (columnIconClicked)=\"svgIconClicked($event)\"\n ></anna-core-icon-column>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'TEXT_ACTIONS'\">\n <ng-container\n *ngFor=\"\n let text of ROW_DATA[\n columnDef.headerInfo[subLineIndex].actionKey\n ]\n \"\n >\n <button\n *ngIf=\"text.showTooltip\"\n (click)=\"\n textActionClicked(\n ROW_DATA,\n text.id,\n columnDef.headerInfo[subLineIndex]\n )\n \"\n [disabled]=\"text.isDisabled\"\n class=\"{{ text.class }}\"\n (mouseenter)=\"\n mouseEnterOnTextActionType(\n ROW_DATA,\n columnDef.headerInfo[subLineIndex].tooltipKey\n )\n \"\n [ngbTooltip]=\"textActionTooltipTemplate\"\n placement=\"auto\"\n container=\"body\"\n tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\n >\n {{ text.name }}\n </button>\n\n <button\n *ngIf=\"!text.showTooltip\"\n (click)=\"\n textActionClicked(\n ROW_DATA,\n text.id,\n columnDef.headerInfo[subLineIndex]\n )\n \"\n [disabled]=\"text.isDisabled\"\n class=\"{{ text.class }}\"\n >\n {{ text.name }}\n </button>\n </ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'CHECKBOX'\">\n <span\n *ngIf=\"ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\n [ngClass]=\"{\n 'disable-checkbox':\n ROW_DATA[\n columnDef.headerInfo[subLineIndex].isDisabledKey\n ]\n }\"\n class=\"material-icons custom-column-checkbox-checked\"\n (click)=\"\n selectOrUnselectCheckbox(\n ROW_DATA,\n columnDef.headerInfo[subLineIndex].objectKey,\n false\n )\n \"\n >\n check_box\n </span>\n <span\n *ngIf=\"!ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\n class=\"material-icons custom-column-checkbox-unchecked\"\n [ngClass]=\"{\n 'disable-checkbox':\n ROW_DATA[\n columnDef.headerInfo[subLineIndex].isDisabledKey\n ]\n }\"\n (click)=\"\n selectOrUnselectCheckbox(\n ROW_DATA,\n columnDef.headerInfo[subLineIndex].objectKey,\n true\n )\n \"\n >\n check_box_outline_blank\n </span>\n\n <ng-container\n *ngFor=\"\n let action of ROW_DATA[\n columnDef.headerInfo[subLineIndex].actionKey\n ]\n \"\n >\n <i\n *ngIf=\"action.showIcon\"\n [class]=\"action.iconClass\"\n [ngClass]=\"{ disabled: action.disabledIcon }\"\n (mouseenter)=\"\n mouseEnterOnStringTextActionTypeContainingTable(\n ROW_DATA,\n columnDef.headerInfo[subLineIndex].tooltipKey\n )\n \"\n placement=\"bottom auto\"\n container=\"body\"\n [autoClose]=\"true\"\n tooltipClass=\"tooltip-containing-table remove-on-scroll-class\"\n [ngbTooltip]=\"tooltipContainingTableTemplate\"\n >\n </i>\n </ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'CLICKABLE_DATA'\">\n <a\n *ngFor=\"\n let text of ROW_DATA[\n columnDef.headerInfo[subLineIndex].actionKey\n ]\n \"\n [class]=\"text.class\"\n (click)=\"onClickableDataClicked(ROW_DATA, text.id)\"\n >\n {{ text.name }}\n </a>\n <span\n *ngIf=\"\n subline.objectKey === 'displayBookedUnits' &&\n gtGeneralConfig.component === 'RATING'\n \"\n class=\"clickable-data\"\n (click)=\"spotDetailsDownloadClicked('DATAROW', ROW_DATA)\"\n [ngClass]=\"{ 'disabled-clickable-data': downloadInProgress }\"\n >{{ ROW_DATA.displayBookedUnits }}\n <span class=\"material-icons spot-details-download-icons\"\n >get_app</span\n >\n <ng-container\n *ngIf=\"\n downloadInProgress &&\n ROW_DATA.inventoryCodeId ===\n selectedInventoryIdForDownload &&\n ROW_DATA.demographic === selectedDemographicForDownload\n \"\n >\n <ng-container\n [ngTemplateOutlet]=\"circularProgressBar\"\n ></ng-container>\n </ng-container>\n </span>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'STRING___ICON_OR_TEXT_ACTION'\">\n <ng-container\n *ngFor=\"\n let action of ROW_DATA[\n columnDef.headerInfo[subLineIndex].actionKey\n ]\n \"\n >\n <span\n [class]=\"action.additionalTextBeforeLinkClass\"\n [innerHtml]=\"action.additionalTextBeforeLink\"\n ngbTooltip=\"{{ action.additionalTextBeforeLink }}\"\n placement=\"bottom\"\n container=\"body\"\n tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\n [disableTooltip]=\"!action.enableTooltipForAdditionalText\"\n ></span>\n\n <ng-container *ngIf=\"action && action.typeOfData === 'STRING'\">\n {{ action.data }}\n </ng-container>\n\n <a\n [id]=\"action.id\"\n *ngIf=\"action.showLink\"\n (click)=\"\n textActionClicked(\n ROW_DATA,\n action.id,\n columnDef.headerInfo[subLineIndex]\n )\n \"\n [class]=\"action.linkClass\"\n [ngClass]=\"{ disabled: action.disabledLink }\"\n >{{ action.data }}</a\n >\n <span\n ngbTooltip=\"{{ action.additionalTextAfterLink }}\"\n placement=\"bottom\"\n container=\"body\"\n [class]=\"action.additionalTextAfterLinkClass\"\n tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\n [disableTooltip]=\"\n !action.enableTooltipForAdditionalAfterText\n \"\n >\n {{ action.additionalTextAfterLink }}\n </span>\n\n <ng-container *ngIf=\"action.showTooltip\">\n <ng-container *ngIf=\"action.tooltipData.innerHtml\">\n <i\n *ngIf=\"action.showIcon\"\n [class]=\"action.iconClass\"\n [ngClass]=\"{ disabled: action.disabledIcon }\"\n (mouseenter)=\"\n mouseEnterOnStringTextActionTypeContainingTable(\n ROW_DATA,\n columnDef.headerInfo[subLineIndex]\n .tooltipKey\n )\n \"\n placement=\"bottom auto\"\n container=\"body\"\n [autoClose]=\"true\"\n tooltipClass=\"tooltip-containing-table remove-on-scroll-class\"\n [ngbTooltip]=\"tooltipContainingTableTemplate\"\n >\n </i>\n </ng-container>\n\n <ng-container *ngIf=\"!action.tooltipData.tooltipTableBody\">\n <i\n *ngIf=\"action.showIcon\"\n [class]=\"action.iconClass\"\n [ngClass]=\"{ disabled: action.disabledIcon }\"\n (click)=\"\n iconClickedOnStringIconActionType(\n ROW_DATA,\n action.id,\n columnDef.headerInfo[subLineIndex]\n )\n \"\n (mouseleave)=\"mouseLeaveTextActionType(ROW_DATA)\"\n (mouseenter)=\"\n mouseEnterOnStringTextActionType(\n ROW_DATA,\n columnDef.headerInfo[subLineIndex]\n .tooltipKey\n )\n \"\n [placement]=\"\n action.tooltipPlacement\n ? action.tooltipPlacement\n : 'bottom auto'\n \"\n container=\"body\"\n [autoClose]=\"true\"\n tooltipClass=\"team-user-tooltip remove-on-scroll-class {{\n action.tooltipClass\n }}\"\n [ngbTooltip]=\"userLoggedInDetails\"\n >\n </i>\n <ng-container *ngIf=\"action['showSvgIcon']\">\n <anna-core-anna-est-icon-template\n class=\"float-right\"\n *ngIf=\"action['svgIconName'] === 'anna-icon'\"\n (mouseleave)=\"\n mouseLeaveTextActionType(ROW_DATA)\n \"\n (mouseenter)=\"\n mouseEnterOnStringTextActionType(\n ROW_DATA,\n columnDef.headerInfo[subLineIndex]\n .tooltipKey\n )\n \"\n [placement]=\"\n action.tooltipPlacement\n ? action.tooltipPlacement\n : 'bottom auto'\n \"\n tooltipClass=\"team-user-tooltip remove-on-scroll-class {{\n action['tooltipClass']\n }}\"\n [ngbTooltip]=\"userLoggedInDetails\"\n container=\"body\"\n [autoClose]=\"true\"\n >\n </anna-core-anna-est-icon-template>\n </ng-container>\n </ng-container>\n </ng-container>\n\n <ng-container *ngIf=\"!action.showTooltip\">\n <i\n *ngIf=\"action.showIcon\"\n [class]=\"action.iconClass\"\n [ngClass]=\"{ disabled: action.disabledIcon }\"\n (click)=\"\n iconClickedOnStringIconActionType(\n ROW_DATA,\n action.id,\n columnDef.headerInfo[subLineIndex]\n )\n \"\n >\n </i>\n </ng-container>\n </ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'STRING_OR_INPUT'\">\n <ng-container\n *ngIf=\"\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n ?.type === 'STRING';\n else inputBox\n \"\n >\n <span\n [innerHtml]=\"\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n ?.value\n \"\n ></span>\n </ng-container>\n <ng-template #inputBox>\n <input\n placeholder=\"{{\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n ?.placeholder\n }}\"\n annaCoreShowEllipsisTextOnHover\n class=\"{{\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n .className\n }}\"\n (keydown)=\"\n changesMadeInEditableInputBox(\n $event,\n ROW_DATA[\n columnDef.headerInfo[subLineIndex].objectKey\n ],\n false\n )\n \"\n (paste)=\"\n changesMadeInEditableInputBox(\n $event,\n ROW_DATA[\n columnDef.headerInfo[subLineIndex].objectKey\n ],\n true\n )\n \"\n (ngModelChange)=\"\n editableInputValueChanged(\n $event,\n ROW_DATA,\n columnDef.headerInfo[subLineIndex].objectKey\n )\n \"\n [ngModel]=\"\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n .value\n \"\n [disabled]=\"\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n .disabled\n \"\n [ngClass]=\"{\n 'red-border':\n ROW_DATA[\n columnDef.headerInfo[subLineIndex].objectKey\n ].hasError\n }\"\n />\n\n <i\n *ngIf=\"\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n .showIcon\n \"\n container=\"body\"\n [ngbTooltip]=\"\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n .iconTooltip\n \"\n tooltipClass=\"gt-total-row-tooltip\"\n placement=\"bottom\"\n class=\"{{\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n .iconClass\n }}\"\n >\n </i>\n <ng-container\n *ngIf=\"\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey][\n 'showSvgIcon'\n ]\n \"\n >\n <anna-core-anna-est-icon-template\n class=\"float-right\"\n *ngIf=\"\n ROW_DATA[\n columnDef.headerInfo[subLineIndex].objectKey\n ]['svgIconName'] === 'anna-icon'\n \"\n [placement]=\"'bottom auto'\"\n tooltipClass=\"gt-total-row-tooltip\"\n [ngbTooltip]=\"\n ROW_DATA[\n columnDef.headerInfo[subLineIndex].objectKey\n ].iconTooltip\n \"\n container=\"body\"\n >\n </anna-core-anna-est-icon-template>\n </ng-container>\n </ng-template>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'HTML'\">\n <span\n [innerHtml]=\"\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n \"\n ></span>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'SINGLE_RADIO'\">\n <span\n *ngIf=\"ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\n [ngClass]=\"{\n 'disable-checkbox':\n ROW_DATA[\n columnDef.headerInfo[subLineIndex].isDisabledKey\n ]\n }\"\n class=\"mdi mdi-radiobox-marked\"\n (click)=\"(null)\"\n >\n </span>\n <span\n *ngIf=\"!ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\n class=\"mdi mdi-radiobox-blank\"\n [ngClass]=\"{\n 'disable-checkbox':\n ROW_DATA[\n columnDef.headerInfo[subLineIndex].isDisabledKey\n ]\n }\"\n (click)=\"\n selectOrUnselectCheckbox(\n ROW_DATA,\n columnDef.headerInfo[subLineIndex].objectKey,\n true\n )\n \"\n >\n </span>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'RADIO'\">\n <mat-radio-group\n *ngIf=\"ROW_DATA['RadioButtonConfig']\"\n [ngModel]=\"ROW_DATA[subline.objectKey]\"\n [disabled]=\"ROW_DATA['RadioButtonConfig'][0].isDisabled\"\n >\n <ng-container\n *ngFor=\"\n let radioButton of ROW_DATA['RadioButtonConfig'];\n let last = last\n \"\n >\n <mat-radio-button\n value=\"{{ radioButton.value }}\"\n class=\"{{ radioButton.class }}\"\n (click)=\"\n radioButtonClicked(\n ROW_DATA,\n radioButton.value,\n ROW_DATA['RadioButtonConfig'][0].isDisabled\n )\n \"\n >{{ radioButton.label }}\n </mat-radio-button>\n <i\n class=\" {{ radioButton.iconClass }}\"\n (click)=\"radioButtonIconClicked(ROW_DATA)\"\n ></i>\n <br *ngIf=\"!last\" />\n </ng-container>\n </mat-radio-group>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'STRING_WITH_TOOLTIP'\">\n <ng-container\n *ngFor=\"\n let action of ROW_DATA[\n columnDef.headerInfo[subLineIndex].actionKey\n ]\n \"\n >\n <span> {{ action?.dataToDisplay }}</span>\n <span\n *ngIf=\"action?.showTooltip\"\n [ngbTooltip]=\"textActionTooltipTemplate\"\n (mouseenter)=\"\n mouseEnterOnStringTextActionType(\n ROW_DATA,\n columnDef.headerInfo[subLineIndex].tooltipKey\n )\n \"\n [placement]=\"action?.tooltipPosition\"\n container=\"body\"\n [class]=\"action?.tooltipIconClass\"\n tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\n [disableTooltip]=\"action?.disableTooltip\"\n >\n </span>\n <span> {{ action?.dataToDisplayAfterTooltip }}</span>\n </ng-container>\n </ng-container>\n\n <ng-container *ngSwitchDefault>\n <ng-container *ngIf=\"subline.objectKey !== 'description'\">\n <span>{{\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n }}</span>\n <i\n *ngIf=\"\n subline.objectKey === 'inventoryCode' &&\n ROW_DATA['isSellerGroup'] &&\n gtGeneralConfig.component === 'RATING'\n \"\n class=\"mi mdi-info-outline seller-tooltip\"\n [ngbTooltip]=\"sellerHierarchyTooltip\"\n placement=\"bottom auto\"\n container=\"body\"\n [autoClose]=\"true\"\n triggers=\"manual\"\n (hidden)=\"closeTooltip()\"\n #info=\"ngbTooltip\"\n tooltipClass=\"hierarchy-tooltip remove-on-scroll-class\"\n (mouseenter)=\"\n bindTheValueToSellerGroupTooltip(\n ROW_DATA.sellerGroupHierarchy,\n info\n )\n \"\n >\n </i>\n\n <i\n *ngIf=\"\n subline.objectKey === 'displayBookedAverageRating' &&\n gtGeneralConfig.component === 'RATING' &&\n ROW_DATA['showRatingAverageIcon']\n \"\n class=\"mi mdi-info-outline seller-tooltip\"\n placement=\"bottom auto\"\n container=\"body\"\n [autoClose]=\"true\"\n (mouseenter)=\"\n setIsDifference(ROW_DATA.isDifferenceLessThan25Percent)\n \"\n tooltipClass=\"posted-avg-tooltip remove-on-scroll-class\"\n [ngbTooltip]=\"postedRatingDifference\"\n >\n </i>\n\n <i\n *ngIf=\"\n subline.objectKey ===\n 'displayBookedAverageImpression' &&\n gtGeneralConfig.component === 'RATING' &&\n ROW_DATA['showImpressionAverageIcon']\n \"\n class=\"mi mdi-info-outline seller-tooltip\"\n placement=\"bottom auto\"\n container=\"body\"\n [autoClose]=\"true\"\n (mouseenter)=\"\n setIsDifference(ROW_DATA.isDifferenceLessThan25Percent)\n \"\n tooltipClass=\"posted-avg-tooltip remove-on-scroll-class\"\n [ngbTooltip]=\"postedImpDifference\"\n >\n </i>\n </ng-container>\n <ng-container *ngIf=\"subline.objectKey === 'description'\">\n <p\n *ngIf=\"\n ROW_DATA.descriptionMessage ||\n ROW_DATA.descriptionEmailReferenceNum\n \"\n >\n <ng-container *ngIf=\"ROW_DATA.descriptionMessage\">\n {{ ROW_DATA.descriptionMessage }}\n <br />\n </ng-container>\n <ng-container\n *ngIf=\"\n ROW_DATA.descriptionEmailReferenceNum !== '-' &&\n ROW_DATA.descriptionEmailReferenceNum !== ''\n \"\n >\n Email Ref: {{ ROW_DATA.descriptionEmailReferenceNum }}\n <br />\n </ng-container>\n </p>\n <a\n href=\"{{ ROW_DATA.descriptionDetailsUrl }}\"\n target=\"_blank\"\n *ngIf=\"\n ROW_DATA.descriptionDetailsUrlType === 'PDF' ||\n ROW_DATA.descriptionDetailsUrlType === 'EXCEL'\n \"\n >\n <button class=\"btn viewDetailsAndEmailBtn\">Download</button>\n </a>\n <ng-container\n *ngIf=\"\n ROW_DATA.activityname.toLowerCase() ===\n 'order onboarded'\n \"\n >\n <a\n *ngIf=\"ROW_DATA.descriptionDetailsUrlType === 'LINK'\"\n (click)=\"viewDetailsClicked(ROW_DATA)\"\n >\n <button\n class=\"btn viewDetailsAndEmailBtn order-onboarded\"\n >\n View details\n </button>\n </a>\n </ng-container>\n\n <a\n href=\"{{ ROW_DATA.descriptionEmailUrl }}\"\n target=\"_blank\"\n *ngIf=\"\n ROW_DATA.descriptionEmailUrl !== '-' &&\n ROW_DATA.descriptionEmailUrl !== ''\n \"\n >\n <button class=\"btn viewDetailsAndEmailBtn\">\n View email\n </button>\n </a>\n </ng-container>\n </ng-container>\n </ng-container>\n </div>\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"isNoDataToDisplaySubject$ | async\">\n <div>\n {{ null }}\n </div>\n </ng-container>\n </ng-container>\n </td>\n </ng-container>\n </tr>\n </tbody>\n </table>\n </div>\n <anna-core-no-data-lib\n [width]=\"noDataWidth\"\n [marginTop]=\"marginTop\"\n *ngIf=\"isNoDataToDisplaySubject$ | async\"\n >\n </anna-core-no-data-lib>\n</div>\n\n<!-- Checkbox template -->\n<ng-template #filterTooltip>\n <anna-core-anna-column-checkbox-filter\n [tableData]=\"tableData\"\n [showFilterHeaderTabs]=\"showFilterTooltipTabs\"\n [isLurAndCsrComponent]=\"false\"\n [clonedTableData]=\"clonedTableData\"\n [filterTabObjects]=\"filterTabObjects\"\n (filterAppliedToTable)=\"filterApplied($event)\"\n (sortingAppliedToTable)=\"sortingApplied($event)\"\n (closeTooltip)=\"closeTooltip()\"\n >\n </anna-core-anna-column-checkbox-filter>\n</ng-template>\n\n<!-- Slider template -->\n<ng-template #sliderToolTip>\n <anna-core-anna-column-slider-filter\n [tableData]=\"tableData\"\n [showFilterHeaderTabs]=\"showFilterTooltipTabs\"\n [isLurAndCsrComponent]=\"false\"\n [clonedTableData]=\"clonedTableData\"\n [filterTabObjects]=\"filterTabObjects\"\n (filterAppliedToTable)=\"filterApplied($event)\"\n (sortingAppliedToTable)=\"sortingApplied($event)\"\n (closeTooltip)=\"closeTooltip()\"\n >\n </anna-core-anna-column-slider-filter>\n</ng-template>\n\n<!-- Date Picker Template -->\n<ng-template #datePickerTooltip>\n <anna-core-anna-column-date-range-filter\n [tableData]=\"tableData\"\n [showFilterHeaderTabs]=\"showFilterTooltipTabs\"\n [isLurAndCsrComponent]=\"false\"\n [clonedTableData]=\"clonedTableData\"\n [filterTabObjects]=\"filterTabObjects\"\n (filterAppliedToTable)=\"filterApplied($event)\"\n (sortingAppliedToTable)=\"sortingApplied($event)\"\n (closeTooltip)=\"closeTooltip()\"\n >\n </anna-core-anna-column-date-range-filter>\n</ng-template>\n\n<!-- Week Picker Template -->\n<ng-template #weekPickerToolTip>\n <!-- <div class=\"weekpicker-container\">\n <anna-core-week-calendar-filter-lib\n [week-calendar-config]=\"gtGeneralConfig.multiWeekPickerConfig\"\n (apply)=\"applyWeekFilter($event)\"\n [from-date]=\"calendarMinEnabledDate\"\n [to-date]=\"calendarMaxEnabledDate\"\n >\n </anna-core-week-calendar-filter-lib>\n </div> -->\n</ng-template>\n\n<!-- Time Filter Template -->\n<ng-template #timeFilterToolTip>\n <anna-core-anna-column-time-filter\n [tableData]=\"tableData\"\n [showFilterHeaderTabs]=\"showFilterTooltipTabs\"\n [isLurAndCsrComponent]=\"false\"\n [showAllTimeRangeCheckboxes]=\"showCheckboxesForTimeFilter\"\n [clonedTableData]=\"clonedTableData\"\n [filterTabObjects]=\"filterTabObjects\"\n (filterAppliedToTable)=\"filterApplied($event)\"\n (sortingAppliedToTable)=\"sortingApplied($event)\"\n (closeTooltip)=\"closeTooltip()\"\n >\n </anna-core-anna-column-time-filter>\n</ng-template>\n\n<ng-template #columnInfoTooltip>\n <p class=\"black-color-text white-space-nowrap\">This preemption is rejected and not marked for credit.</p>\n</ng-template>\n\n<ng-template #ratingInfoTooltip>\n <p class=\"first-row\">Shows 'Booked Rating' for Preemptions & MakeGood Offered spot(s).</p>\n <p class=\"second-row\">Shows 'Projected Rating' for ADU Offered spot(s).</p>\n</ng-template>\n\n<ng-template #impsInfoTooltip>\n <p class=\"first-row\">Shows 'Booked IMPS' for Preemptions & MakeGood Offered spot(s).</p>\n <p class=\"second-row\">Shows 'Projected IMPS' for ADU Offered spot(s).</p>\n</ng-template>\n\n<ng-template #spotsColumnEquivalizationMessageTooltip>\n <p class=\"spot-column-tooltip-message\">\n This consists of equivalized spots and un-equivalized Paid Programs & un-equivalized Non-spots.\n </p>\n</ng-template>\n\n<ng-template #underDeliveryTooltip>\n <p class=\"spot-column-tooltip-message\">\n Indicates the Under-delivery percentage based on booked and posted RTG/IMPS.\n </p>\n</ng-template>\n\n<ng-template #overDeliveryTooltip>\n <p class=\"spot-column-tooltip-message\">\n Indicates the Over-delivery percentage based on booked and posted RTG/IMPS.\n </p>\n</ng-template>\n\n<ng-template #rateInfoTooltip>\n <p class=\"first-row\">Shows 'Booked Rate' for Preemptions & MakeGood Offered spot(s).</p>\n <p class=\"second-row\">Shows 'Projected $ Value' for ADU Offered spot(s).</p>\n</ng-template>\n\n<ng-template #sellerHierarchyTooltip>\n <ng-container *ngIf=\"sellerGroupHierarchy.length > 0\">\n <section class=\"hierarchy-table-container\">\n <table class=\"seller-hierarchy-table\">\n <thead>\n <tr>\n <th>#</th>\n <th>Inventory Codes</th>\n <th>Program/Description</th>\n </tr>\n </thead>\n <tbody>\n <tr *ngFor=\"let data of sellerGroupHierarchy; let tooltipIndex = index\">\n <td>{{ tooltipIndex + 1 }}</td>\n <td>\n <span annaCoreShowEllipsisTextOnHover>{{ data.InventoryCode }}</span>\n </td>\n <td>\n <span annaCoreShowEllipsisTextOnHover>{{ data.Program }}</span>\n </td>\n </tr>\n </tbody>\n </table>\n </section>\n </ng-container>\n <ng-container *ngIf=\"sellerGroupHierarchy.length === 0\">\n <span class=\"black-color-text\">Seller group not available for this inventory code</span>\n </ng-container>\n</ng-template>\n\n<ng-template #lurViolationInfoTooltip>\n <p class=\"first-row\">The values are for the entire week.</p>\n</ng-template>\n\n<ng-template #postedRatingDifference>\n <p class=\"difference-text\">\n The difference between posted and booked average rating is\n {{ isDifferenceLessThan25Percent ? \"less\" : \"more\" }} than 25%.\n </p>\n</ng-template>\n\n<ng-template #postedImpDifference>\n <p class=\"difference-text\">\n The difference between posted and booked average impression is\n {{ isDifferenceLessThan25Percent ? \"less\" : \"more\" }} than 25%.\n </p>\n</ng-template>\n\n<ng-template #ongoingRevBookedColumnTooltip>\n <p>The Booked $ value, Spots, GRP, CPP, IMPS, CPM corresponds on the last permanent revision generated</p>\n</ng-template>\n\n<ng-template #completedRevBookedColumnTooltip>\n <p>The Booked $ value corresponds on the last permanent revision generated</p>\n</ng-template>\n\n<ng-template #avgBookedRate>\n <p>This is the booked average Rate</p>\n</ng-template>\n\n<ng-template #avgBookedRtg>\n <p>This is the booked average RTG</p>\n</ng-template>\n\n<ng-template #avgBookedImps>\n <p>This is the booked average IMP(\u2019000)</p>\n</ng-template>\n\n<ng-template #projectedImpsRtg>\n <p>\n All projections are derived from the sum of actual posted information until the last posted date and estimates\n for the remaining selected period.\n </p>\n</ng-template>\n\n<ng-template #automationTooltip>\n <p>\n Please get the order business rules approved to activate the order for automation. Only for the\n automation-activated orders, any approved MGs, ADUs, or credited spots on ANNA will be fed into the traffic\n system i.e. ANNA revisions.\n <!-- removed below line as part of enhancmennt in 14.0 releas -->\n <!-- Additionally, ANNA will only enter buyer revisions into traffic for the selected\n Medialine/WOC orders. -->\n </p>\n</ng-template>\n\n<ng-template #rebateImpact>\n <p>Rebate impact value is for the originally ordered spot length and is not equivalized.</p>\n</ng-template>\n\n<ng-template #lurViolationTotalRowToolTip>\n <ul>\n <li>\n <strong>POLITICAL RATE VIOLATIONS:</strong>\n Violations flagged when non-political spots are booked at a rate lower than the minimum booked rate for\n political candidates for the same week, Inventory Code and Revenue Class.\n </li>\n <li>\n <strong>CANDIDATE TO CANDIDATE VIOLATION:</strong>\n Violations flagged when political spots are booked at different rates to other political spots for the same\n week, Inventory Code and Revenue Class.\n </li>\n </ul>\n</ng-template>\n\n<ng-template #circularProgressBar>\n <circle-progress\n [percent]=\"percentDone\"\n [radius]=\"5\"\n [showTitle]=\"false\"\n [showUnits]=\"false\"\n [showSubtitle]=\"false\"\n [outerStrokeWidth]=\"3\"\n [innerStrokeWidth]=\"3\"\n [space]=\"-3\"\n [outerStrokeColor]=\"'#268bff'\"\n [innerStrokeColor]=\"'#d5d5d5'\"\n [animationDuration]=\"10\"\n ></circle-progress>\n</ng-template>\n\n<ng-template #userLoggedInDetails>\n <div class=\"tooltip-div-container\">\n <ng-container *ngFor=\"let data of textActionTooltip\">\n <span *ngIf=\"data.key !== 'read'\">\n {{ data.key }} <b> {{ data.value }}</b>\n </span>\n <span *ngIf=\"data.key === 'read'\">\n {{ data.value }}\n </span>\n </ng-container>\n </div>\n</ng-template>\n\n<ng-template #markAsReadTip>\n <div class=\"notification-tooltip-div-container\">\n <ng-container *ngFor=\"let data of textActionTooltip\">\n {{ data.value }}\n </ng-container>\n </div>\n</ng-template>\n\n<ng-template #textActionTooltipTemplate>\n <ng-container *ngFor=\"let data of textActionTooltip\">\n {{ data.key }} <b> {{ data.value }}</b>\n </ng-container>\n</ng-template>\n\n<ng-template #showOrHideToggleForTotalRowTooltip>\n <div>\n {{ showOrHideToggleForTotalRow && !gtGeneralConfig.totalRow ? \"Show Total Row\" : \"Hide Total Row\" }}\n </div>\n</ng-template>\n\n<ng-template #tooltipContainingTableTemplate>\n <div\n *ngIf=\"tooltipContainingTable\"\n [innerHTML]=\"tooltipContainingTable.innerHtml\"\n class=\"notification-tooltip-div-container\"\n >\n <!-- <ul>\n <li *ngFor=\"let headerMsg of tooltipContainingTable.tableHeaderMsg\">\n <b> {{headerMsg}} </b>\n </li>\n </ul>\n\n <table class=\"tooltip-table\">\n <thead>\n <tr>\n <th *ngFor=\"let header of tooltipContainingTable.tooltipTableHeader\">\n {{ header}}\n </th>\n </tr>\n </thead>\n <tbody>\n <tr *ngFor=\"let rows of tooltipContainingTable.tooltipTableBody\">\n <td *ngFor=\"let data of rows\">\n {{ data }}\n </td>\n </tr>\n </tbody>\n </table>\n\n <ul>\n <li style=\"margin-top:10px; padding:0\" *ngFor=\"let footerMsg of tooltipContainingTable.tableFooterMsg\">\n {{ footerMsg }} \n </li>\n </ul> -->\n </div>\n</ng-template>\n<!-- <ng-template #textActionTooltipTemplate>\n <ng-container *ngFor=\"let data of textActionTooltip\">\n {{ data.key }} <b> {{data.value}}</b>\n </ng-container>\n</ng-template> -->\n", styles: ["::ng-deep .show-or-hide-toggle-tooltip .tooltip-inner{max-width:229px}.show-or-hide-toggle-btn.shift-toggle-top-on-total-row-click{transform:translate(calc(var(--app-left-space-show-hide-total-row-icon) - 12px),48px)}.show-or-hide-toggle-btn{width:16px;height:16px;padding:0;margin:0;border-radius:50%;position:absolute;transform:translate(calc(var(--app-left-space-show-hide-total-row-icon) - 12px),73px);z-index:999;background-color:#d9d9d9}.show-or-hide-toggle-btn i.mdi.mdi-menu-swap{font-size:16px;display:flex}#generic-table-conatiner.table-with-show-hide-total-row-toggle .total-row td:nth-of-type(2){padding-left:16px!important}.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{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);margin:1px 0 1px 2px;border:none;padding:0}.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:.75rem;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}.virtual-scroll-div{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.red-text-totol-row{color:#f44336!important}.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 ul.pl-16{padding-left:16px!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}.black-color-text{color:#000}.white-space-nowrap{white-space:nowrap}\n"], dependencies: [{ kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { 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: i4.NgxSkeletonLoaderComponent, selector: "ngx-skeleton-loader", inputs: ["count", "loadingText", "appearance", "animation", "ariaLabel", "theme"] }, { kind: "directive", type: ShowEllipsisTextOnHoverDirective, selector: "[annaCoreShowEllipsisTextOnHover]" }, { kind: "directive", type: NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "component", type: AnnaIconColumnComponent, selector: "anna-core-icon-column", inputs: ["componentName", "iconToShow", "dataObject"], outputs: ["columnIconClicked"] }, { kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i5.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: i5.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i5.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "ngmodule", type: MatRadioModule }, { kind: "directive", type: i6.MatRadioGroup, selector: "mat-radio-group", exportAs: ["matRadioGroup"] }, { kind: "component", type: i6.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: i7.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" }, { kind: "component", type: AnnaEstIconTemplateComponent, selector: "anna-core-anna-est-icon-template" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
860
+ }
861
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: AnnaNonEditableGenericNormalTableComponent, decorators: [{
862
+ type: Component,
863
+ args: [{ selector: "anna-core-anna-non-editable-generic-normal-table", standalone: true, imports: [
864
+ NgClass,
865
+ NgStyle,
866
+ NgFor,
867
+ NgIf,
868
+ NgTemplateOutlet,
869
+ NgbTooltip,
870
+ NgxSkeletonLoaderModule,
871
+ ShowEllipsisTextOnHoverDirective,
872
+ NgSwitch,
873
+ NgSwitchCase,
874
+ AnnaIconColumnComponent,
875
+ FormsModule,
876
+ MatRadioModule,
877
+ NgSwitchDefault,
878
+ AnnaNoDataComponent,
879
+ AnnaColumnCheckboxFilterComponent,
880
+ AnnaColumnSliderFilterComponent,
881
+ AnnaColumnDateRangeFilterComponent,
882
+ AnnaColumnTimeFilterComponent,
883
+ NgCircleProgressModule,
884
+ AsyncPipe,
885
+ AnnaEstIconTemplateComponent,
886
+ ], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div\n id=\"generic-table-conatiner\"\n #tableElementRef\n class=\"table-container {{ gtGeneralConfig?.tableOuterContainerName }} {{ tableBottomBorderClass }}\"\n [ngClass]=\"{\n 'scroll-left-shadow-effect': isScrolledLeft,\n 'scroll-right-shadow-effect': !isScrollEnded,\n 'clickable-row': clickableRow,\n 'no-data-table': (isNoDataToDisplaySubject$ | async),\n 'table-with-show-hide-total-row-toggle': showOrHideToggleForTotalRow\n }\"\n (scroll)=\"onTableContainerScroll($event)\"\n>\n <div\n [class]=\"gtGeneralConfig.tableContainerName\"\n class=\"horizontal-scroll-for-table-container\"\n [ngStyle]=\"{\n height:\n tableData.length < maximumRowsWhichCanBeRenderedWithoutScroll\n ? 'calc(' +\n (gtDimension.rowHeight * tableData.length +\n (!tableData.length || !gtGeneralConfig.totalRow\n ? gtDimension.headerHeight\n : gtDimension.headerHeight + gtDimension.rowHeight)) +\n 'px)'\n : gtDimension.tableHeight\n }\"\n >\n <button\n *ngIf=\"showOrHideToggleForTotalRow && !showSkeletonLoading && (isNoDataToDisplaySubject$ | async) === false\"\n [ngClass]=\"{\n 'shift-toggle-top-on-total-row-click': !gtGeneralConfig.totalRow\n }\"\n class=\"show-or-hide-toggle-btn\"\n (click)=\"showHideTotalRow()\"\n >\n <i\n class=\"mdi mdi-menu-swap\"\n tooltipClass=\"show-or-hide-toggle-tooltip\"\n placement=\"auto\"\n container=\"body\"\n [ngbTooltip]=\"showOrHideToggleForTotalRowTooltip\"\n ></i>\n </button>\n <table\n class=\"gt\"\n [ngClass]=\"tableClass\"\n >\n <thead>\n <tr\n class=\"header-row\"\n mat-header-row\n [style.height.px]=\"gtDimension.headerHeight\"\n >\n <ng-container *ngFor=\"let columnDef of tableHeaders; trackBy: trackByFn\">\n <th\n #tableHeader\n nowrap\n [style.width]=\"columnDef.width\"\n >\n <div\n class=\"row mx-0\"\n *ngFor=\"let header of columnDef.headerInfo; let j = index\"\n >\n <p\n *ngIf=\"header.typeOfHeaderData === 'STRING'\"\n [ngClass]=\"{ 'upper-label': j === 0, 'lower-label': j === 1 }\"\n >\n <ngx-skeleton-loader\n *ngIf=\"header.name == null\"\n count=\"1\"\n [theme]=\"{\n height: '10px',\n display: 'block',\n width: columnDef.width,\n 'max-width': 'calc(100% - 20px)'\n }\"\n >\n </ngx-skeleton-loader>\n <ng-container *ngIf=\"header.name\">\n {{ header.name }}\n </ng-container>\n <ng-container *ngIf=\"header.tooltip && header.tooltip.tooltipMessage\">\n <i\n class=\"{{ header['tooltip'].iconClass }}\"\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n #t=\"ngbTooltip\"\n container=\"body\"\n [ngbTooltip]=\"header.tooltip.tooltipMessage\"\n container=\"body\"\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n >\n </i>\n </ng-container>\n <i\n *ngIf=\"header.tooltip && header.tooltip.name === 'impsInfoTooltip'\"\n class=\"{{ header['tooltip'].iconClass }}\"\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n #t=\"ngbTooltip\"\n container=\"body\"\n [ngbTooltip]=\"impsInfoTooltip\"\n container=\"body\"\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n >\n </i>\n <i\n *ngIf=\"\n header.tooltip &&\n header.tooltip.name === 'spotsColumnEquivalizationMessageTooltip'\n \"\n class=\"{{ header['tooltip'].iconClass }}\"\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n container=\"body\"\n #t=\"ngbTooltip\"\n container=\"body\"\n [ngbTooltip]=\"spotsColumnEquivalizationMessageTooltip\"\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n >\n </i>\n <i\n *ngIf=\"header.tooltip && header.tooltip.name === 'underDeliveryTooltip'\"\n class=\"{{ header['tooltip'].iconClass }}\"\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n container=\"body\"\n #t=\"ngbTooltip\"\n container=\"body\"\n [ngbTooltip]=\"underDeliveryTooltip\"\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n >\n </i>\n <i\n *ngIf=\"header.tooltip && header.tooltip.name === 'overDeliveryTooltip'\"\n class=\"{{ header['tooltip'].iconClass }}\"\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n container=\"body\"\n #t=\"ngbTooltip\"\n container=\"body\"\n [ngbTooltip]=\"overDeliveryTooltip\"\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n >\n </i>\n <i\n *ngIf=\"header.tooltip && header.tooltip.name === 'ratingInfoTooltip'\"\n class=\"{{ header['tooltip'].iconClass }}\"\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n #t=\"ngbTooltip\"\n container=\"body\"\n [ngbTooltip]=\"ratingInfoTooltip\"\n container=\"body\"\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n >\n </i>\n <i\n *ngIf=\"header.tooltip && header.tooltip.name === 'rateInfoTooltip'\"\n class=\"{{ header['tooltip'].iconClass }}\"\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n #t=\"ngbTooltip\"\n container=\"body\"\n [ngbTooltip]=\"rateInfoTooltip\"\n container=\"body\"\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n >\n </i>\n <i\n *ngIf=\"\n header.tooltip && header.tooltip.name === 'ongoingRevBookedColumnTooltip'\n \"\n class=\"{{ header['tooltip'].iconClass }}\"\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n #t=\"ngbTooltip\"\n container=\"body\"\n [ngbTooltip]=\"ongoingRevBookedColumnTooltip\"\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n >\n </i>\n <i\n *ngIf=\"\n header.tooltip && header.tooltip.name === 'completedRevBookedColumnTooltip'\n \"\n class=\"{{ header['tooltip'].iconClass }}\"\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n #t=\"ngbTooltip\"\n container=\"body\"\n [ngbTooltip]=\"completedRevBookedColumnTooltip\"\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n >\n </i>\n <i\n *ngIf=\"header.tooltip && header.tooltip.name === 'avgBookedRate'\"\n class=\"{{ header['tooltip'].iconClass }}\"\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n #t=\"ngbTooltip\"\n container=\"body\"\n [ngbTooltip]=\"avgBookedRate\"\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n >\n </i>\n <i\n *ngIf=\"header.tooltip && header.tooltip.name === 'avgBookedRtg'\"\n class=\"{{ header['tooltip'].iconClass }}\"\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n #t=\"ngbTooltip\"\n container=\"body\"\n [ngbTooltip]=\"avgBookedRtg\"\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n >\n </i>\n <i\n *ngIf=\"header.tooltip && header.tooltip.name === 'avgBookedImps'\"\n class=\"{{ header['tooltip'].iconClass }}\"\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n #t=\"ngbTooltip\"\n container=\"body\"\n [ngbTooltip]=\"avgBookedImps\"\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n >\n </i>\n\n <i\n *ngIf=\"header.tooltip && header.tooltip.name === 'automationTooltip'\"\n class=\"{{ header['tooltip'].iconClass }}\"\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n #t=\"ngbTooltip\"\n container=\"body\"\n [ngbTooltip]=\"automationTooltip\"\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n >\n </i>\n\n <i\n *ngIf=\"header.tooltip && header.tooltip.name === 'rebateImpact'\"\n class=\"{{ header['tooltip'].iconClass }}\"\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n #t=\"ngbTooltip\"\n container=\"body\"\n [ngbTooltip]=\"rebateImpact\"\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n >\n </i>\n\n <i\n *ngIf=\"header.tooltip && header.tooltip.name === 'projectedImpsRtg'\"\n class=\"{{ header['tooltip'].iconClass }}\"\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n #t=\"ngbTooltip\"\n container=\"body\"\n [ngbTooltip]=\"projectedImpsRtg\"\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n >\n </i>\n </p>\n\n <ng-container *ngIf=\"header.typeOfHeaderData === 'CHECKBOX'\">\n <span\n *ngIf=\"gtGeneralConfig.isHeaderChecked\"\n class=\"material-icons custom-column-checkbox-checked\"\n (click)=\"selectUnselectAllRows()\"\n >\n check_box\n </span>\n <span\n *ngIf=\"!gtGeneralConfig.isHeaderChecked\"\n class=\"material-icons custom-column-checkbox-unchecked\"\n [ngClass]=\"{ 'disable-checkbox': gtGeneralConfig.disableHeaderCheckbox }\"\n (click)=\"selectUnselectAllRows()\"\n >\n check_box_outline_blank\n </span>\n </ng-container>\n\n <div\n *ngIf=\"gtGeneralConfig.showAllColumnFilter\"\n class=\"sort-filter-container\"\n >\n <ng-container *ngIf=\"header.showTooltipIcon\">\n <!-- Active tooltip Functionality -->\n <ng-container *ngIf=\"header.filter === 'CHECKBOX'\">\n <span\n class=\"mdi mdi-filter-variant\"\n [ngClass]=\"{\n active:\n annaFilterService.isFilterSortActive &&\n annaFilterService.isFilterSortActive[\n header.joinedFilterSortObjectKeys\n ],\n disabled: header.disableTooltipIcon || showSkeletonLoading\n }\"\n [ngbTooltip]=\"filterTooltip\"\n placement=\"{{ filterAlignment }}\"\n container=\"body\"\n tooltipClass=\"non-edit-checkbox-tooltip\"\n [autoClose]=\"'outside'\"\n triggers=\"manual\"\n #t=\"ngbTooltip\"\n (click)=\"bindTheValueToToolTip(t, header)\"\n (hidden)=\"closeTooltip()\"\n >\n </span\n ><br />\n </ng-container>\n <ng-container *ngIf=\"header.filter === 'SLIDER'\">\n <span\n class=\"mdi mdi-filter-variant\"\n [ngClass]=\"{\n active:\n annaFilterService.isFilterSortActive &&\n annaFilterService.isFilterSortActive[\n header.joinedFilterSortObjectKeys\n ],\n disabled: header.disableTooltipIcon || showSkeletonLoading\n }\"\n [ngbTooltip]=\"sliderToolTip\"\n placement=\"bottom left-top\"\n container=\"body\"\n tooltipClass=\"non-edit-slider-tooltip\"\n [autoClose]=\"'outside'\"\n triggers=\"manual\"\n #t1=\"ngbTooltip\"\n (click)=\"bindTheValueToToolTip(t1, header)\"\n (hidden)=\"closeTooltip()\"\n >\n </span\n ><br />\n </ng-container>\n <ng-container *ngIf=\"header.filter === 'DATE'\">\n <span\n class=\"mdi mdi-filter-variant\"\n [ngClass]=\"{\n active:\n annaFilterService.isFilterSortActive &&\n annaFilterService.isFilterSortActive[\n header.joinedFilterSortObjectKeys\n ],\n disabled: header.disableTooltipIcon || showSkeletonLoading\n }\"\n [ngbTooltip]=\"datePickerTooltip\"\n placement=\"bottom auto\"\n container=\"body\"\n tooltipClass=\"non-edit-datepicker-tooltip\"\n [autoClose]=\"'outside'\"\n triggers=\"manual\"\n #t2=\"ngbTooltip\"\n (click)=\"bindTheValueToToolTip(t2, header)\"\n (hidden)=\"closeTooltip()\"\n >\n </span\n ><br />\n </ng-container>\n <ng-container *ngIf=\"header.filter === 'WEEK'\">\n <span\n class=\"mdi mdi-filter-variant\"\n [ngClass]=\"{\n active:\n annaFilterService.isFilterSortActive &&\n annaFilterService.isFilterSortActive[\n header.joinedFilterSortObjectKeys\n ],\n disabled: header.disableTooltipIcon || showSkeletonLoading\n }\"\n [ngbTooltip]=\"weekPickerToolTip\"\n placement=\"bottom left-top\"\n container=\"body\"\n [autoClose]=\"'outside'\"\n triggers=\"manual\"\n #t3=\"ngbTooltip\"\n (click)=\"bindTheValueToToolTip(t3, header)\"\n (hidden)=\"closeTooltip()\"\n >\n </span\n ><br />\n </ng-container>\n <ng-container *ngIf=\"header.filter === 'TIME'\">\n <span\n class=\"mdi mdi-filter-variant\"\n [ngClass]=\"{\n active:\n annaFilterService.isFilterSortActive &&\n annaFilterService.isFilterSortActive[\n header.joinedFilterSortObjectKeys\n ],\n disabled: header.disableTooltipIcon || showSkeletonLoading\n }\"\n [ngbTooltip]=\"timeFilterToolTip\"\n placement=\"bottom left-top auto\"\n container=\"body\"\n tooltipClass=\"non-edit-time-tooltip\"\n [autoClose]=\"'outside'\"\n triggers=\"manual\"\n #t4=\"ngbTooltip\"\n (click)=\"bindTheValueToToolTip(t4, header)\"\n (hidden)=\"closeTooltip()\"\n >\n </span\n ><br />\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"!header.showTooltipIcon\">\n <span id=\"no-filter-space\"></span><br />\n </ng-container>\n <i\n *ngIf=\"header.tooltip && header.tooltip.name === 'lurViolationInfoTooltip'\"\n class=\"{{ header['tooltip'].iconClass }}\"\n [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n #t=\"ngbTooltip\"\n container=\"body\"\n [ngbTooltip]=\"lurViolationInfoTooltip\"\n placement=\"{{ header['tooltip'].tooltipPosition }}\"\n tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n >\n </i>\n </div>\n </div>\n </th>\n </ng-container>\n </tr>\n <tr\n class=\"total-row\"\n [style.height.px]=\"gtDimension.rowHeight\"\n *ngIf=\"\n !showSkeletonLoading &&\n tableData.length > 0 &&\n gtGeneralConfig.totalRow &&\n (isNoDataToDisplaySubject$ | async) === false\n \"\n >\n <ng-container *ngFor=\"let column of totalRowInfo; trackBy: trackByFn\">\n <td\n [attr.colspan]=\"column.colspan\"\n class=\"{{ column.class }}\"\n >\n <ng-container *ngIf=\"column['isActionColumn']\">\n <a\n *ngFor=\"let data of column.actionData\"\n [class]=\"data.class\"\n (click)=\"onClickableDataClicked({}, data.id)\"\n >\n {{ data.name }}\n </a>\n </ng-container>\n\n <ng-container *ngIf=\"column['isIconColumn']\">\n <i\n class=\"{{ column?.iconData?.class }}\"\n (click)=\"iconClickedInTotalRow(column?.colName)\"\n >\n </i>\n </ng-container>\n\n <ng-container *ngIf=\"!column['isActionColumn']\">\n <strong class=\"upper-label\"\n >{{ column.data }}\n <span\n class=\"red-text-totol-row\"\n *ngIf=\"column.additionalRedTextAfterData\"\n >{{ column.additionalRedTextAfterData }}</span\n ></strong\n >\n <ng-container *ngIf=\"column.lowerData\">\n <br />\n <span\n *ngIf=\"\n column.colName === 'total-potential-booked-unit' &&\n gtGeneralConfig.component === 'RATING';\n else columnLowerData\n \"\n class=\"clickable-data\"\n (click)=\"spotDetailsDownloadClicked('TOTALROW')\"\n [ngClass]=\"{ 'disabled-clickable-data': downloadInProgress }\"\n >{{ column.lowerData }}\n <span class=\"material-icons spot-details-download-icons\">get_app</span>\n <ng-container\n *ngIf=\"downloadInProgress && selectedRowTypeForDownload === 'TOTALROW'\"\n >\n <ng-container [ngTemplateOutlet]=\"circularProgressBar\"></ng-container>\n </ng-container>\n </span>\n <ng-template #columnLowerData>\n <span class=\"lower-label\">{{ column.lowerData }}</span>\n </ng-template>\n </ng-container>\n <ng-container\n *ngIf=\"column.tooltipMessage && gtGeneralConfig.component !== 'LUR_VIOLATIONS'\"\n >\n <i\n class=\"{{ column.tooltipIconClass }}\"\n container=\"body\"\n [ngbTooltip]=\"column.tooltipMessage\"\n tooltipClass=\"gt-total-row-tooltip\"\n placement=\"top bottom\"\n ></i>\n </ng-container>\n <ng-container\n *ngIf=\"gtGeneralConfig.component === 'LUR_VIOLATIONS' && column.tooltipMessage\"\n >\n <i\n class=\"mi mdi-info-outline info-label\"\n container=\"body\"\n [ngbTooltip]=\"lurViolationTotalRowToolTip\"\n tooltipClass=\"gt-total-row-tooltip\"\n placement=\"bottom\"\n ></i>\n </ng-container>\n </ng-container>\n </td>\n </ng-container>\n </tr>\n </thead>\n <tbody>\n <tr\n [class]=\"ROW_DATA.gtClass\"\n [ngClass]=\"{ 'no-border-tr': (isNoDataToDisplaySubject$ | async) }\"\n [style.height.px]=\"gtDimension.rowHeight\"\n (click)=\"dataRowClicked(ROW_DATA)\"\n *ngFor=\"let ROW_DATA of renderedData; trackBy: trackByFn\"\n >\n <ng-container *ngFor=\"let columnDef of tableHeaders; trackBy: trackByFn\">\n <td\n [style.background]=\"ROW_DATA.backgroundColor\"\n [style.border]=\"ROW_DATA.border\"\n class=\"{{ ROW_DATA.rowClass }}\"\n [ngClass]=\"ROW_DATA[columnDef.headerInfo[0].objectKey + 'TdClass']\"\n [attr.rowspan]=\"ROW_DATA[columnDef.headerInfo[0].objectKey + 'Rowspan']\"\n *ngIf=\"\n !hideSomeTds ||\n (hideSomeTds && !ROW_DATA['hide' + columnDef.headerInfo[0].objectKey + 'Td'])\n \"\n >\n <ngx-skeleton-loader\n *ngIf=\"showSkeletonLoading\"\n count=\"1\"\n [theme]=\"{ height: '10px', display: 'block' }\"\n >\n </ngx-skeleton-loader>\n\n <ng-container *ngIf=\"!showSkeletonLoading\">\n <ng-container\n *ngIf=\"tableData.length > 0 && (isNoDataToDisplaySubject$ | async) === false\"\n >\n <ng-container\n *ngFor=\"\n let subline of columnDef.headerInfo;\n let subLineIndex = index;\n trackBy: trackByFn\n \"\n >\n <div annaCoreShowEllipsisTextOnHover>\n <ng-container\n [ngSwitch]=\"columnDef.headerInfo[subLineIndex].typeOfBodyData\"\n >\n <ng-container *ngSwitchCase=\"'ICON'\">\n <i\n *ngIf=\"\n !(\n starredInProgress &&\n ROW_DATA.orderId === selectedStarredOrderId\n )\n \"\n [class]=\"ROW_DATA.iconClass\"\n (click)=\"iconClicked(ROW_DATA, ROW_DATA.iconClass)\"\n ngbTooltip=\"{{ ROW_DATA.iconTitleText }}\"\n placement=\"bottom\"\n container=\"body\"\n tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\n ></i>\n <ng-container\n *ngIf=\"\n starredInProgress &&\n ROW_DATA.orderId === selectedStarredOrderId\n \"\n >\n <div class=\"spinner-for-button-directive\"></div>\n </ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'ICON_CELL'\">\n <ng-container\n *ngFor=\"\n let action of ROW_DATA[\n columnDef.headerInfo[subLineIndex].actionKey\n ]\n \"\n >\n <ng-container *ngIf=\"action.showObjectKey\">\n {{ ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey] }}\n </ng-container>\n\n <i\n *ngIf=\"action.showIcon\"\n [class]=\"action.iconClass\"\n (mouseenter)=\"\n mouseEnterOnStringTextActionType(\n ROW_DATA,\n columnDef.headerInfo[subLineIndex].tooltipKey\n )\n \"\n placement=\"bottom auto\"\n container=\"body\"\n [autoClose]=\"true\"\n tooltipClass=\"team-user-tooltip remove-on-scroll-class\"\n [ngbTooltip]=\"\n action.showTooltip ? action.tooltipData : null\n \"\n (click)=\"\n textActionClicked(\n ROW_DATA,\n action.id,\n columnDef.headerInfo[subLineIndex]\n )\n \"\n [disableTooltip]=\"!action.showTooltip\"\n >\n </i>\n </ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'HTML_STRING'\">\n <p\n [innerHTML]=\"\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n \"\n (click)=\"innerHTMLCellClicked($event, ROW_DATA)\"\n ></p>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'SVG_ICON'\">\n <anna-core-icon-column\n [componentName]=\"gtGeneralConfig.component\"\n [dataObject]=\"ROW_DATA\"\n [iconToShow]=\"\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n \"\n (columnIconClicked)=\"svgIconClicked($event)\"\n ></anna-core-icon-column>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'TEXT_ACTIONS'\">\n <ng-container\n *ngFor=\"\n let text of ROW_DATA[\n columnDef.headerInfo[subLineIndex].actionKey\n ]\n \"\n >\n <button\n *ngIf=\"text.showTooltip\"\n (click)=\"\n textActionClicked(\n ROW_DATA,\n text.id,\n columnDef.headerInfo[subLineIndex]\n )\n \"\n [disabled]=\"text.isDisabled\"\n class=\"{{ text.class }}\"\n (mouseenter)=\"\n mouseEnterOnTextActionType(\n ROW_DATA,\n columnDef.headerInfo[subLineIndex].tooltipKey\n )\n \"\n [ngbTooltip]=\"textActionTooltipTemplate\"\n placement=\"auto\"\n container=\"body\"\n tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\n >\n {{ text.name }}\n </button>\n\n <button\n *ngIf=\"!text.showTooltip\"\n (click)=\"\n textActionClicked(\n ROW_DATA,\n text.id,\n columnDef.headerInfo[subLineIndex]\n )\n \"\n [disabled]=\"text.isDisabled\"\n class=\"{{ text.class }}\"\n >\n {{ text.name }}\n </button>\n </ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'CHECKBOX'\">\n <span\n *ngIf=\"ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\n [ngClass]=\"{\n 'disable-checkbox':\n ROW_DATA[\n columnDef.headerInfo[subLineIndex].isDisabledKey\n ]\n }\"\n class=\"material-icons custom-column-checkbox-checked\"\n (click)=\"\n selectOrUnselectCheckbox(\n ROW_DATA,\n columnDef.headerInfo[subLineIndex].objectKey,\n false\n )\n \"\n >\n check_box\n </span>\n <span\n *ngIf=\"!ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\n class=\"material-icons custom-column-checkbox-unchecked\"\n [ngClass]=\"{\n 'disable-checkbox':\n ROW_DATA[\n columnDef.headerInfo[subLineIndex].isDisabledKey\n ]\n }\"\n (click)=\"\n selectOrUnselectCheckbox(\n ROW_DATA,\n columnDef.headerInfo[subLineIndex].objectKey,\n true\n )\n \"\n >\n check_box_outline_blank\n </span>\n\n <ng-container\n *ngFor=\"\n let action of ROW_DATA[\n columnDef.headerInfo[subLineIndex].actionKey\n ]\n \"\n >\n <i\n *ngIf=\"action.showIcon\"\n [class]=\"action.iconClass\"\n [ngClass]=\"{ disabled: action.disabledIcon }\"\n (mouseenter)=\"\n mouseEnterOnStringTextActionTypeContainingTable(\n ROW_DATA,\n columnDef.headerInfo[subLineIndex].tooltipKey\n )\n \"\n placement=\"bottom auto\"\n container=\"body\"\n [autoClose]=\"true\"\n tooltipClass=\"tooltip-containing-table remove-on-scroll-class\"\n [ngbTooltip]=\"tooltipContainingTableTemplate\"\n >\n </i>\n </ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'CLICKABLE_DATA'\">\n <a\n *ngFor=\"\n let text of ROW_DATA[\n columnDef.headerInfo[subLineIndex].actionKey\n ]\n \"\n [class]=\"text.class\"\n (click)=\"onClickableDataClicked(ROW_DATA, text.id)\"\n >\n {{ text.name }}\n </a>\n <span\n *ngIf=\"\n subline.objectKey === 'displayBookedUnits' &&\n gtGeneralConfig.component === 'RATING'\n \"\n class=\"clickable-data\"\n (click)=\"spotDetailsDownloadClicked('DATAROW', ROW_DATA)\"\n [ngClass]=\"{ 'disabled-clickable-data': downloadInProgress }\"\n >{{ ROW_DATA.displayBookedUnits }}\n <span class=\"material-icons spot-details-download-icons\"\n >get_app</span\n >\n <ng-container\n *ngIf=\"\n downloadInProgress &&\n ROW_DATA.inventoryCodeId ===\n selectedInventoryIdForDownload &&\n ROW_DATA.demographic === selectedDemographicForDownload\n \"\n >\n <ng-container\n [ngTemplateOutlet]=\"circularProgressBar\"\n ></ng-container>\n </ng-container>\n </span>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'STRING___ICON_OR_TEXT_ACTION'\">\n <ng-container\n *ngFor=\"\n let action of ROW_DATA[\n columnDef.headerInfo[subLineIndex].actionKey\n ]\n \"\n >\n <span\n [class]=\"action.additionalTextBeforeLinkClass\"\n [innerHtml]=\"action.additionalTextBeforeLink\"\n ngbTooltip=\"{{ action.additionalTextBeforeLink }}\"\n placement=\"bottom\"\n container=\"body\"\n tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\n [disableTooltip]=\"!action.enableTooltipForAdditionalText\"\n ></span>\n\n <ng-container *ngIf=\"action && action.typeOfData === 'STRING'\">\n {{ action.data }}\n </ng-container>\n\n <a\n [id]=\"action.id\"\n *ngIf=\"action.showLink\"\n (click)=\"\n textActionClicked(\n ROW_DATA,\n action.id,\n columnDef.headerInfo[subLineIndex]\n )\n \"\n [class]=\"action.linkClass\"\n [ngClass]=\"{ disabled: action.disabledLink }\"\n >{{ action.data }}</a\n >\n <span\n ngbTooltip=\"{{ action.additionalTextAfterLink }}\"\n placement=\"bottom\"\n container=\"body\"\n [class]=\"action.additionalTextAfterLinkClass\"\n tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\n [disableTooltip]=\"\n !action.enableTooltipForAdditionalAfterText\n \"\n >\n {{ action.additionalTextAfterLink }}\n </span>\n\n <ng-container *ngIf=\"action.showTooltip\">\n <ng-container *ngIf=\"action.tooltipData.innerHtml\">\n <i\n *ngIf=\"action.showIcon\"\n [class]=\"action.iconClass\"\n [ngClass]=\"{ disabled: action.disabledIcon }\"\n (mouseenter)=\"\n mouseEnterOnStringTextActionTypeContainingTable(\n ROW_DATA,\n columnDef.headerInfo[subLineIndex]\n .tooltipKey\n )\n \"\n placement=\"bottom auto\"\n container=\"body\"\n [autoClose]=\"true\"\n tooltipClass=\"tooltip-containing-table remove-on-scroll-class\"\n [ngbTooltip]=\"tooltipContainingTableTemplate\"\n >\n </i>\n </ng-container>\n\n <ng-container *ngIf=\"!action.tooltipData.tooltipTableBody\">\n <i\n *ngIf=\"action.showIcon\"\n [class]=\"action.iconClass\"\n [ngClass]=\"{ disabled: action.disabledIcon }\"\n (click)=\"\n iconClickedOnStringIconActionType(\n ROW_DATA,\n action.id,\n columnDef.headerInfo[subLineIndex]\n )\n \"\n (mouseleave)=\"mouseLeaveTextActionType(ROW_DATA)\"\n (mouseenter)=\"\n mouseEnterOnStringTextActionType(\n ROW_DATA,\n columnDef.headerInfo[subLineIndex]\n .tooltipKey\n )\n \"\n [placement]=\"\n action.tooltipPlacement\n ? action.tooltipPlacement\n : 'bottom auto'\n \"\n container=\"body\"\n [autoClose]=\"true\"\n tooltipClass=\"team-user-tooltip remove-on-scroll-class {{\n action.tooltipClass\n }}\"\n [ngbTooltip]=\"userLoggedInDetails\"\n >\n </i>\n <ng-container *ngIf=\"action['showSvgIcon']\">\n <anna-core-anna-est-icon-template\n class=\"float-right\"\n *ngIf=\"action['svgIconName'] === 'anna-icon'\"\n (mouseleave)=\"\n mouseLeaveTextActionType(ROW_DATA)\n \"\n (mouseenter)=\"\n mouseEnterOnStringTextActionType(\n ROW_DATA,\n columnDef.headerInfo[subLineIndex]\n .tooltipKey\n )\n \"\n [placement]=\"\n action.tooltipPlacement\n ? action.tooltipPlacement\n : 'bottom auto'\n \"\n tooltipClass=\"team-user-tooltip remove-on-scroll-class {{\n action['tooltipClass']\n }}\"\n [ngbTooltip]=\"userLoggedInDetails\"\n container=\"body\"\n [autoClose]=\"true\"\n >\n </anna-core-anna-est-icon-template>\n </ng-container>\n </ng-container>\n </ng-container>\n\n <ng-container *ngIf=\"!action.showTooltip\">\n <i\n *ngIf=\"action.showIcon\"\n [class]=\"action.iconClass\"\n [ngClass]=\"{ disabled: action.disabledIcon }\"\n (click)=\"\n iconClickedOnStringIconActionType(\n ROW_DATA,\n action.id,\n columnDef.headerInfo[subLineIndex]\n )\n \"\n >\n </i>\n </ng-container>\n </ng-container>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'STRING_OR_INPUT'\">\n <ng-container\n *ngIf=\"\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n ?.type === 'STRING';\n else inputBox\n \"\n >\n <span\n [innerHtml]=\"\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n ?.value\n \"\n ></span>\n </ng-container>\n <ng-template #inputBox>\n <input\n placeholder=\"{{\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n ?.placeholder\n }}\"\n annaCoreShowEllipsisTextOnHover\n class=\"{{\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n .className\n }}\"\n (keydown)=\"\n changesMadeInEditableInputBox(\n $event,\n ROW_DATA[\n columnDef.headerInfo[subLineIndex].objectKey\n ],\n false\n )\n \"\n (paste)=\"\n changesMadeInEditableInputBox(\n $event,\n ROW_DATA[\n columnDef.headerInfo[subLineIndex].objectKey\n ],\n true\n )\n \"\n (ngModelChange)=\"\n editableInputValueChanged(\n $event,\n ROW_DATA,\n columnDef.headerInfo[subLineIndex].objectKey\n )\n \"\n [ngModel]=\"\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n .value\n \"\n [disabled]=\"\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n .disabled\n \"\n [ngClass]=\"{\n 'red-border':\n ROW_DATA[\n columnDef.headerInfo[subLineIndex].objectKey\n ].hasError\n }\"\n />\n\n <i\n *ngIf=\"\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n .showIcon\n \"\n container=\"body\"\n [ngbTooltip]=\"\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n .iconTooltip\n \"\n tooltipClass=\"gt-total-row-tooltip\"\n placement=\"bottom\"\n class=\"{{\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n .iconClass\n }}\"\n >\n </i>\n <ng-container\n *ngIf=\"\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey][\n 'showSvgIcon'\n ]\n \"\n >\n <anna-core-anna-est-icon-template\n class=\"float-right\"\n *ngIf=\"\n ROW_DATA[\n columnDef.headerInfo[subLineIndex].objectKey\n ]['svgIconName'] === 'anna-icon'\n \"\n [placement]=\"'bottom auto'\"\n tooltipClass=\"gt-total-row-tooltip\"\n [ngbTooltip]=\"\n ROW_DATA[\n columnDef.headerInfo[subLineIndex].objectKey\n ].iconTooltip\n \"\n container=\"body\"\n >\n </anna-core-anna-est-icon-template>\n </ng-container>\n </ng-template>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'HTML'\">\n <span\n [innerHtml]=\"\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n \"\n ></span>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'SINGLE_RADIO'\">\n <span\n *ngIf=\"ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\n [ngClass]=\"{\n 'disable-checkbox':\n ROW_DATA[\n columnDef.headerInfo[subLineIndex].isDisabledKey\n ]\n }\"\n class=\"mdi mdi-radiobox-marked\"\n (click)=\"(null)\"\n >\n </span>\n <span\n *ngIf=\"!ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\n class=\"mdi mdi-radiobox-blank\"\n [ngClass]=\"{\n 'disable-checkbox':\n ROW_DATA[\n columnDef.headerInfo[subLineIndex].isDisabledKey\n ]\n }\"\n (click)=\"\n selectOrUnselectCheckbox(\n ROW_DATA,\n columnDef.headerInfo[subLineIndex].objectKey,\n true\n )\n \"\n >\n </span>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'RADIO'\">\n <mat-radio-group\n *ngIf=\"ROW_DATA['RadioButtonConfig']\"\n [ngModel]=\"ROW_DATA[subline.objectKey]\"\n [disabled]=\"ROW_DATA['RadioButtonConfig'][0].isDisabled\"\n >\n <ng-container\n *ngFor=\"\n let radioButton of ROW_DATA['RadioButtonConfig'];\n let last = last\n \"\n >\n <mat-radio-button\n value=\"{{ radioButton.value }}\"\n class=\"{{ radioButton.class }}\"\n (click)=\"\n radioButtonClicked(\n ROW_DATA,\n radioButton.value,\n ROW_DATA['RadioButtonConfig'][0].isDisabled\n )\n \"\n >{{ radioButton.label }}\n </mat-radio-button>\n <i\n class=\" {{ radioButton.iconClass }}\"\n (click)=\"radioButtonIconClicked(ROW_DATA)\"\n ></i>\n <br *ngIf=\"!last\" />\n </ng-container>\n </mat-radio-group>\n </ng-container>\n\n <ng-container *ngSwitchCase=\"'STRING_WITH_TOOLTIP'\">\n <ng-container\n *ngFor=\"\n let action of ROW_DATA[\n columnDef.headerInfo[subLineIndex].actionKey\n ]\n \"\n >\n <span> {{ action?.dataToDisplay }}</span>\n <span\n *ngIf=\"action?.showTooltip\"\n [ngbTooltip]=\"textActionTooltipTemplate\"\n (mouseenter)=\"\n mouseEnterOnStringTextActionType(\n ROW_DATA,\n columnDef.headerInfo[subLineIndex].tooltipKey\n )\n \"\n [placement]=\"action?.tooltipPosition\"\n container=\"body\"\n [class]=\"action?.tooltipIconClass\"\n tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\n [disableTooltip]=\"action?.disableTooltip\"\n >\n </span>\n <span> {{ action?.dataToDisplayAfterTooltip }}</span>\n </ng-container>\n </ng-container>\n\n <ng-container *ngSwitchDefault>\n <ng-container *ngIf=\"subline.objectKey !== 'description'\">\n <span>{{\n ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n }}</span>\n <i\n *ngIf=\"\n subline.objectKey === 'inventoryCode' &&\n ROW_DATA['isSellerGroup'] &&\n gtGeneralConfig.component === 'RATING'\n \"\n class=\"mi mdi-info-outline seller-tooltip\"\n [ngbTooltip]=\"sellerHierarchyTooltip\"\n placement=\"bottom auto\"\n container=\"body\"\n [autoClose]=\"true\"\n triggers=\"manual\"\n (hidden)=\"closeTooltip()\"\n #info=\"ngbTooltip\"\n tooltipClass=\"hierarchy-tooltip remove-on-scroll-class\"\n (mouseenter)=\"\n bindTheValueToSellerGroupTooltip(\n ROW_DATA.sellerGroupHierarchy,\n info\n )\n \"\n >\n </i>\n\n <i\n *ngIf=\"\n subline.objectKey === 'displayBookedAverageRating' &&\n gtGeneralConfig.component === 'RATING' &&\n ROW_DATA['showRatingAverageIcon']\n \"\n class=\"mi mdi-info-outline seller-tooltip\"\n placement=\"bottom auto\"\n container=\"body\"\n [autoClose]=\"true\"\n (mouseenter)=\"\n setIsDifference(ROW_DATA.isDifferenceLessThan25Percent)\n \"\n tooltipClass=\"posted-avg-tooltip remove-on-scroll-class\"\n [ngbTooltip]=\"postedRatingDifference\"\n >\n </i>\n\n <i\n *ngIf=\"\n subline.objectKey ===\n 'displayBookedAverageImpression' &&\n gtGeneralConfig.component === 'RATING' &&\n ROW_DATA['showImpressionAverageIcon']\n \"\n class=\"mi mdi-info-outline seller-tooltip\"\n placement=\"bottom auto\"\n container=\"body\"\n [autoClose]=\"true\"\n (mouseenter)=\"\n setIsDifference(ROW_DATA.isDifferenceLessThan25Percent)\n \"\n tooltipClass=\"posted-avg-tooltip remove-on-scroll-class\"\n [ngbTooltip]=\"postedImpDifference\"\n >\n </i>\n </ng-container>\n <ng-container *ngIf=\"subline.objectKey === 'description'\">\n <p\n *ngIf=\"\n ROW_DATA.descriptionMessage ||\n ROW_DATA.descriptionEmailReferenceNum\n \"\n >\n <ng-container *ngIf=\"ROW_DATA.descriptionMessage\">\n {{ ROW_DATA.descriptionMessage }}\n <br />\n </ng-container>\n <ng-container\n *ngIf=\"\n ROW_DATA.descriptionEmailReferenceNum !== '-' &&\n ROW_DATA.descriptionEmailReferenceNum !== ''\n \"\n >\n Email Ref: {{ ROW_DATA.descriptionEmailReferenceNum }}\n <br />\n </ng-container>\n </p>\n <a\n href=\"{{ ROW_DATA.descriptionDetailsUrl }}\"\n target=\"_blank\"\n *ngIf=\"\n ROW_DATA.descriptionDetailsUrlType === 'PDF' ||\n ROW_DATA.descriptionDetailsUrlType === 'EXCEL'\n \"\n >\n <button class=\"btn viewDetailsAndEmailBtn\">Download</button>\n </a>\n <ng-container\n *ngIf=\"\n ROW_DATA.activityname.toLowerCase() ===\n 'order onboarded'\n \"\n >\n <a\n *ngIf=\"ROW_DATA.descriptionDetailsUrlType === 'LINK'\"\n (click)=\"viewDetailsClicked(ROW_DATA)\"\n >\n <button\n class=\"btn viewDetailsAndEmailBtn order-onboarded\"\n >\n View details\n </button>\n </a>\n </ng-container>\n\n <a\n href=\"{{ ROW_DATA.descriptionEmailUrl }}\"\n target=\"_blank\"\n *ngIf=\"\n ROW_DATA.descriptionEmailUrl !== '-' &&\n ROW_DATA.descriptionEmailUrl !== ''\n \"\n >\n <button class=\"btn viewDetailsAndEmailBtn\">\n View email\n </button>\n </a>\n </ng-container>\n </ng-container>\n </ng-container>\n </div>\n </ng-container>\n </ng-container>\n <ng-container *ngIf=\"isNoDataToDisplaySubject$ | async\">\n <div>\n {{ null }}\n </div>\n </ng-container>\n </ng-container>\n </td>\n </ng-container>\n </tr>\n </tbody>\n </table>\n </div>\n <anna-core-no-data-lib\n [width]=\"noDataWidth\"\n [marginTop]=\"marginTop\"\n *ngIf=\"isNoDataToDisplaySubject$ | async\"\n >\n </anna-core-no-data-lib>\n</div>\n\n<!-- Checkbox template -->\n<ng-template #filterTooltip>\n <anna-core-anna-column-checkbox-filter\n [tableData]=\"tableData\"\n [showFilterHeaderTabs]=\"showFilterTooltipTabs\"\n [isLurAndCsrComponent]=\"false\"\n [clonedTableData]=\"clonedTableData\"\n [filterTabObjects]=\"filterTabObjects\"\n (filterAppliedToTable)=\"filterApplied($event)\"\n (sortingAppliedToTable)=\"sortingApplied($event)\"\n (closeTooltip)=\"closeTooltip()\"\n >\n </anna-core-anna-column-checkbox-filter>\n</ng-template>\n\n<!-- Slider template -->\n<ng-template #sliderToolTip>\n <anna-core-anna-column-slider-filter\n [tableData]=\"tableData\"\n [showFilterHeaderTabs]=\"showFilterTooltipTabs\"\n [isLurAndCsrComponent]=\"false\"\n [clonedTableData]=\"clonedTableData\"\n [filterTabObjects]=\"filterTabObjects\"\n (filterAppliedToTable)=\"filterApplied($event)\"\n (sortingAppliedToTable)=\"sortingApplied($event)\"\n (closeTooltip)=\"closeTooltip()\"\n >\n </anna-core-anna-column-slider-filter>\n</ng-template>\n\n<!-- Date Picker Template -->\n<ng-template #datePickerTooltip>\n <anna-core-anna-column-date-range-filter\n [tableData]=\"tableData\"\n [showFilterHeaderTabs]=\"showFilterTooltipTabs\"\n [isLurAndCsrComponent]=\"false\"\n [clonedTableData]=\"clonedTableData\"\n [filterTabObjects]=\"filterTabObjects\"\n (filterAppliedToTable)=\"filterApplied($event)\"\n (sortingAppliedToTable)=\"sortingApplied($event)\"\n (closeTooltip)=\"closeTooltip()\"\n >\n </anna-core-anna-column-date-range-filter>\n</ng-template>\n\n<!-- Week Picker Template -->\n<ng-template #weekPickerToolTip>\n <!-- <div class=\"weekpicker-container\">\n <anna-core-week-calendar-filter-lib\n [week-calendar-config]=\"gtGeneralConfig.multiWeekPickerConfig\"\n (apply)=\"applyWeekFilter($event)\"\n [from-date]=\"calendarMinEnabledDate\"\n [to-date]=\"calendarMaxEnabledDate\"\n >\n </anna-core-week-calendar-filter-lib>\n </div> -->\n</ng-template>\n\n<!-- Time Filter Template -->\n<ng-template #timeFilterToolTip>\n <anna-core-anna-column-time-filter\n [tableData]=\"tableData\"\n [showFilterHeaderTabs]=\"showFilterTooltipTabs\"\n [isLurAndCsrComponent]=\"false\"\n [showAllTimeRangeCheckboxes]=\"showCheckboxesForTimeFilter\"\n [clonedTableData]=\"clonedTableData\"\n [filterTabObjects]=\"filterTabObjects\"\n (filterAppliedToTable)=\"filterApplied($event)\"\n (sortingAppliedToTable)=\"sortingApplied($event)\"\n (closeTooltip)=\"closeTooltip()\"\n >\n </anna-core-anna-column-time-filter>\n</ng-template>\n\n<ng-template #columnInfoTooltip>\n <p class=\"black-color-text white-space-nowrap\">This preemption is rejected and not marked for credit.</p>\n</ng-template>\n\n<ng-template #ratingInfoTooltip>\n <p class=\"first-row\">Shows 'Booked Rating' for Preemptions & MakeGood Offered spot(s).</p>\n <p class=\"second-row\">Shows 'Projected Rating' for ADU Offered spot(s).</p>\n</ng-template>\n\n<ng-template #impsInfoTooltip>\n <p class=\"first-row\">Shows 'Booked IMPS' for Preemptions & MakeGood Offered spot(s).</p>\n <p class=\"second-row\">Shows 'Projected IMPS' for ADU Offered spot(s).</p>\n</ng-template>\n\n<ng-template #spotsColumnEquivalizationMessageTooltip>\n <p class=\"spot-column-tooltip-message\">\n This consists of equivalized spots and un-equivalized Paid Programs & un-equivalized Non-spots.\n </p>\n</ng-template>\n\n<ng-template #underDeliveryTooltip>\n <p class=\"spot-column-tooltip-message\">\n Indicates the Under-delivery percentage based on booked and posted RTG/IMPS.\n </p>\n</ng-template>\n\n<ng-template #overDeliveryTooltip>\n <p class=\"spot-column-tooltip-message\">\n Indicates the Over-delivery percentage based on booked and posted RTG/IMPS.\n </p>\n</ng-template>\n\n<ng-template #rateInfoTooltip>\n <p class=\"first-row\">Shows 'Booked Rate' for Preemptions & MakeGood Offered spot(s).</p>\n <p class=\"second-row\">Shows 'Projected $ Value' for ADU Offered spot(s).</p>\n</ng-template>\n\n<ng-template #sellerHierarchyTooltip>\n <ng-container *ngIf=\"sellerGroupHierarchy.length > 0\">\n <section class=\"hierarchy-table-container\">\n <table class=\"seller-hierarchy-table\">\n <thead>\n <tr>\n <th>#</th>\n <th>Inventory Codes</th>\n <th>Program/Description</th>\n </tr>\n </thead>\n <tbody>\n <tr *ngFor=\"let data of sellerGroupHierarchy; let tooltipIndex = index\">\n <td>{{ tooltipIndex + 1 }}</td>\n <td>\n <span annaCoreShowEllipsisTextOnHover>{{ data.InventoryCode }}</span>\n </td>\n <td>\n <span annaCoreShowEllipsisTextOnHover>{{ data.Program }}</span>\n </td>\n </tr>\n </tbody>\n </table>\n </section>\n </ng-container>\n <ng-container *ngIf=\"sellerGroupHierarchy.length === 0\">\n <span class=\"black-color-text\">Seller group not available for this inventory code</span>\n </ng-container>\n</ng-template>\n\n<ng-template #lurViolationInfoTooltip>\n <p class=\"first-row\">The values are for the entire week.</p>\n</ng-template>\n\n<ng-template #postedRatingDifference>\n <p class=\"difference-text\">\n The difference between posted and booked average rating is\n {{ isDifferenceLessThan25Percent ? \"less\" : \"more\" }} than 25%.\n </p>\n</ng-template>\n\n<ng-template #postedImpDifference>\n <p class=\"difference-text\">\n The difference between posted and booked average impression is\n {{ isDifferenceLessThan25Percent ? \"less\" : \"more\" }} than 25%.\n </p>\n</ng-template>\n\n<ng-template #ongoingRevBookedColumnTooltip>\n <p>The Booked $ value, Spots, GRP, CPP, IMPS, CPM corresponds on the last permanent revision generated</p>\n</ng-template>\n\n<ng-template #completedRevBookedColumnTooltip>\n <p>The Booked $ value corresponds on the last permanent revision generated</p>\n</ng-template>\n\n<ng-template #avgBookedRate>\n <p>This is the booked average Rate</p>\n</ng-template>\n\n<ng-template #avgBookedRtg>\n <p>This is the booked average RTG</p>\n</ng-template>\n\n<ng-template #avgBookedImps>\n <p>This is the booked average IMP(\u2019000)</p>\n</ng-template>\n\n<ng-template #projectedImpsRtg>\n <p>\n All projections are derived from the sum of actual posted information until the last posted date and estimates\n for the remaining selected period.\n </p>\n</ng-template>\n\n<ng-template #automationTooltip>\n <p>\n Please get the order business rules approved to activate the order for automation. Only for the\n automation-activated orders, any approved MGs, ADUs, or credited spots on ANNA will be fed into the traffic\n system i.e. ANNA revisions.\n <!-- removed below line as part of enhancmennt in 14.0 releas -->\n <!-- Additionally, ANNA will only enter buyer revisions into traffic for the selected\n Medialine/WOC orders. -->\n </p>\n</ng-template>\n\n<ng-template #rebateImpact>\n <p>Rebate impact value is for the originally ordered spot length and is not equivalized.</p>\n</ng-template>\n\n<ng-template #lurViolationTotalRowToolTip>\n <ul>\n <li>\n <strong>POLITICAL RATE VIOLATIONS:</strong>\n Violations flagged when non-political spots are booked at a rate lower than the minimum booked rate for\n political candidates for the same week, Inventory Code and Revenue Class.\n </li>\n <li>\n <strong>CANDIDATE TO CANDIDATE VIOLATION:</strong>\n Violations flagged when political spots are booked at different rates to other political spots for the same\n week, Inventory Code and Revenue Class.\n </li>\n </ul>\n</ng-template>\n\n<ng-template #circularProgressBar>\n <circle-progress\n [percent]=\"percentDone\"\n [radius]=\"5\"\n [showTitle]=\"false\"\n [showUnits]=\"false\"\n [showSubtitle]=\"false\"\n [outerStrokeWidth]=\"3\"\n [innerStrokeWidth]=\"3\"\n [space]=\"-3\"\n [outerStrokeColor]=\"'#268bff'\"\n [innerStrokeColor]=\"'#d5d5d5'\"\n [animationDuration]=\"10\"\n ></circle-progress>\n</ng-template>\n\n<ng-template #userLoggedInDetails>\n <div class=\"tooltip-div-container\">\n <ng-container *ngFor=\"let data of textActionTooltip\">\n <span *ngIf=\"data.key !== 'read'\">\n {{ data.key }} <b> {{ data.value }}</b>\n </span>\n <span *ngIf=\"data.key === 'read'\">\n {{ data.value }}\n </span>\n </ng-container>\n </div>\n</ng-template>\n\n<ng-template #markAsReadTip>\n <div class=\"notification-tooltip-div-container\">\n <ng-container *ngFor=\"let data of textActionTooltip\">\n {{ data.value }}\n </ng-container>\n </div>\n</ng-template>\n\n<ng-template #textActionTooltipTemplate>\n <ng-container *ngFor=\"let data of textActionTooltip\">\n {{ data.key }} <b> {{ data.value }}</b>\n </ng-container>\n</ng-template>\n\n<ng-template #showOrHideToggleForTotalRowTooltip>\n <div>\n {{ showOrHideToggleForTotalRow && !gtGeneralConfig.totalRow ? \"Show Total Row\" : \"Hide Total Row\" }}\n </div>\n</ng-template>\n\n<ng-template #tooltipContainingTableTemplate>\n <div\n *ngIf=\"tooltipContainingTable\"\n [innerHTML]=\"tooltipContainingTable.innerHtml\"\n class=\"notification-tooltip-div-container\"\n >\n <!-- <ul>\n <li *ngFor=\"let headerMsg of tooltipContainingTable.tableHeaderMsg\">\n <b> {{headerMsg}} </b>\n </li>\n </ul>\n\n <table class=\"tooltip-table\">\n <thead>\n <tr>\n <th *ngFor=\"let header of tooltipContainingTable.tooltipTableHeader\">\n {{ header}}\n </th>\n </tr>\n </thead>\n <tbody>\n <tr *ngFor=\"let rows of tooltipContainingTable.tooltipTableBody\">\n <td *ngFor=\"let data of rows\">\n {{ data }}\n </td>\n </tr>\n </tbody>\n </table>\n\n <ul>\n <li style=\"margin-top:10px; padding:0\" *ngFor=\"let footerMsg of tooltipContainingTable.tableFooterMsg\">\n {{ footerMsg }} \n </li>\n </ul> -->\n </div>\n</ng-template>\n<!-- <ng-template #textActionTooltipTemplate>\n <ng-container *ngFor=\"let data of textActionTooltip\">\n {{ data.key }} <b> {{data.value}}</b>\n </ng-container>\n</ng-template> -->\n", styles: ["::ng-deep .show-or-hide-toggle-tooltip .tooltip-inner{max-width:229px}.show-or-hide-toggle-btn.shift-toggle-top-on-total-row-click{transform:translate(calc(var(--app-left-space-show-hide-total-row-icon) - 12px),48px)}.show-or-hide-toggle-btn{width:16px;height:16px;padding:0;margin:0;border-radius:50%;position:absolute;transform:translate(calc(var(--app-left-space-show-hide-total-row-icon) - 12px),73px);z-index:999;background-color:#d9d9d9}.show-or-hide-toggle-btn i.mdi.mdi-menu-swap{font-size:16px;display:flex}#generic-table-conatiner.table-with-show-hide-total-row-toggle .total-row td:nth-of-type(2){padding-left:16px!important}.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{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);margin:1px 0 1px 2px;border:none;padding:0}.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:.75rem;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}.virtual-scroll-div{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none}.red-text-totol-row{color:#f44336!important}.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 ul.pl-16{padding-left:16px!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}.black-color-text{color:#000}.white-space-nowrap{white-space:nowrap}\n"] }]
887
+ }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }, { type: i1.AnnaSortService }, { type: i2.AnnaDateTimeFormatService }, { type: i3.AnnaFilterService }]; }, propDecorators: { showSkeletonLoading: [{
888
+ type: Input
889
+ }], tableHeaders: [{
890
+ type: Input
891
+ }], tableData: [{
892
+ type: Input
893
+ }], clonedTableData: [{
894
+ type: Input
895
+ }], gtGeneralConfig: [{
896
+ type: Input
897
+ }], totalRowInfo: [{
898
+ type: Input
899
+ }], gtDimension: [{
900
+ type: Input
901
+ }], tableClass: [{
902
+ type: Input
903
+ }], maximumRowsWhichCanBeRenderedWithoutScroll: [{
904
+ type: Input
905
+ }], fixNumberOfRowsForPopup: [{
906
+ type: Input
907
+ }], limit: [{
908
+ type: Input
909
+ }], includeBorderInTableHeight: [{
910
+ type: Input
911
+ }], downloadInProgress: [{
912
+ type: Input
913
+ }], percentDone: [{
914
+ type: Input
915
+ }], starredInProgress: [{
916
+ type: Input
917
+ }], clickableRow: [{
918
+ type: Input
919
+ }], setTableHeightWhenRowSizeIsFixed: [{
920
+ type: Input
921
+ }], tableBorderBottomClassRequired: [{
922
+ type: Input
923
+ }], hideSomeTds: [{
924
+ type: Input
925
+ }], tdsHaveRowSpan: [{
926
+ type: Input
927
+ }], multipleTablesPresent: [{
928
+ type: Input
929
+ }], showOrHideToggleForTotalRow: [{
930
+ type: Input
931
+ }], toggleCheckbox: [{
932
+ type: Output
933
+ }], toggleRowCheckbox: [{
934
+ type: Output
935
+ }], toggleHeaderCheckbox: [{
936
+ type: Output
937
+ }], undoIconClicked: [{
938
+ type: Output
939
+ }], filterAppliedToTable: [{
940
+ type: Output
941
+ }], sortingAppliedToTable: [{
942
+ type: Output
943
+ }], rowClicked: [{
944
+ type: Output
945
+ }], radioButtonSelected: [{
946
+ type: Output
947
+ }], columnFilterOpened: [{
948
+ type: Output
949
+ }], columnFilterClosed: [{
950
+ type: Output
951
+ }], gtIconClicked: [{
952
+ type: Output
953
+ }], gtSVGIconClicked: [{
954
+ type: Output
955
+ }], gtTextActionClicked: [{
956
+ type: Output
957
+ }], gtViewDetailClicked: [{
958
+ type: Output
959
+ }], gtInnerHTMLClicked: [{
960
+ type: Output
961
+ }], downloadSpotDetails: [{
962
+ type: Output
963
+ }], clickableDataClicked: [{
964
+ type: Output
965
+ }], totalRowIconClicked: [{
966
+ type: Output
967
+ }], notificationIconHover: [{
968
+ type: Output
969
+ }], notificationIconHoverLeave: [{
970
+ type: Output
971
+ }], editableInputEdited: [{
972
+ type: Output
973
+ }], radioButtonMessageIconClicked: [{
974
+ type: Output
975
+ }], viewChildTableHeaders: [{
976
+ type: ViewChildren,
977
+ args: ["tableHeader"]
978
+ }], tableElementRef: [{
979
+ type: ViewChild,
980
+ args: ["tableElementRef", { static: true }]
981
+ }] } });
982
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"anna-non-editable-generic-normal-table.component.js","sourceRoot":"","sources":["../../../../../../../projects/anna-core/src/lib/anna-generic-table-lib/components/anna-non-editable-generic-normal-table/anna-non-editable-generic-normal-table.component.ts","../../../../../../../projects/anna-core/src/lib/anna-generic-table-lib/components/anna-non-editable-generic-normal-table/anna-non-editable-generic-normal-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AsyncPipe,\n    NgClass,\n    NgFor,\n    NgIf,\n    NgStyle,\n    NgSwitch,\n    NgSwitchCase,\n    NgSwitchDefault,\n    NgTemplateOutlet,\n} from \"@angular/common\";\nimport {\n    AfterViewChecked,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    Input,\n    OnChanges,\n    OnInit,\n    Output,\n    QueryList,\n    SimpleChanges,\n    ViewChild,\n    ViewChildren,\n} from \"@angular/core\";\nimport { FormsModule } from \"@angular/forms\";\nimport { MatRadioModule } from \"@angular/material/radio\";\nimport { NgbTooltip } from \"@ng-bootstrap/ng-bootstrap\";\n// Third party import statements\nimport { cloneDeep, isEqual, uniq } from \"lodash-es\";\nimport { NgCircleProgressModule } from \"ng-circle-progress\";\nimport { NgxSkeletonLoaderModule } from \"ngx-skeleton-loader\";\nimport { BehaviorSubject } from \"rxjs\";\n\nimport { AnnaEstIconTemplateComponent } from \"../../../anna-core-shared-lib/components/anna-est-icon-template/anna-est-icon-template.component\";\n// eslint-disable-next-line max-len\nimport { AnnaIconColumnComponent } from \"../../../anna-core-shared-lib/components/anna-icon-column/anna-icon-column.component\";\nimport { AnnaNoDataComponent } from \"../../../anna-core-shared-lib/components/anna-no-data/anna-no-data.component\";\n// eslint-disable-next-line max-len\nimport { ShowEllipsisTextOnHoverDirective } from \"../../../anna-core-shared-lib/directives/show-ellipsis-text/show-ellipsis-text.directive\";\nimport {\n    GtColumnIconEmittedData,\n    RatingSellerGroupHierarchy,\n} from \"../../../anna-core-shared-lib/models/anna-generic-data-type.model\";\nimport { IWeekCalendar } from \"../../../anna-core-shared-lib/models/anna-global-dropdown-config.model\";\nimport {\n    IGtGeneralConfig,\n    IGtTableHeader,\n    IHeaderInfo,\n    ITotalRowInfo,\n} from \"../../../anna-core-shared-lib/models/anna-non-editable-gt-models\";\nimport { RadioButtonModel } from \"../../../anna-core-shared-lib/models/anna-tooltip.model\";\nimport { AnnaDateTimeFormatService } from \"../../../anna-core-shared-lib/services/anna-date-time-format.service\";\nimport { AnnaFilterService } from \"../../../anna-core-shared-lib/services/anna-filter.service\";\nimport { AnnaSortService } from \"../../../anna-core-shared-lib/services/anna-sort.service\";\n// eslint-disable-next-line max-len\nimport { AnnaColumnCheckboxFilterComponent } from \"../anna-column-filters/anna-column-checkbox-filter/anna-column-checkbox-filter.component\";\n// eslint-disable-next-line max-len\nimport { AnnaColumnDateRangeFilterComponent } from \"../anna-column-filters/anna-column-date-range-filter/anna-column-date-range-filter.component\";\n// eslint-disable-next-line max-len\nimport { AnnaColumnSliderFilterComponent } from \"../anna-column-filters/anna-column-slider-filter/anna-column-slider-filter.component\";\nimport { AnnaColumnTimeFilterComponent } from \"../anna-column-filters/anna-column-time-filter/anna-column-time-filter.component\";\n\ninterface KeyValueTooltipType {\n    key: string;\n    value: string;\n}\n\ninterface TableTooltipType {\n    tooltipTableHeader: string[];\n    tooltipTableBody: string[][];\n    tableHeaderMsg: string[];\n    tableFooterMsg: string[];\n    innerHtml: string;\n}\n\n@Component({\n    selector: \"anna-core-anna-non-editable-generic-normal-table\",\n    standalone: true,\n    imports: [\n        NgClass,\n        NgStyle,\n        NgFor,\n        NgIf,\n        NgTemplateOutlet,\n        NgbTooltip,\n        NgxSkeletonLoaderModule,\n        ShowEllipsisTextOnHoverDirective,\n        NgSwitch,\n        NgSwitchCase,\n        AnnaIconColumnComponent,\n        FormsModule,\n        MatRadioModule,\n        NgSwitchDefault,\n        AnnaNoDataComponent,\n        AnnaColumnCheckboxFilterComponent,\n        AnnaColumnSliderFilterComponent,\n        AnnaColumnDateRangeFilterComponent,\n        AnnaColumnTimeFilterComponent,\n        NgCircleProgressModule,\n        AsyncPipe,\n        AnnaEstIconTemplateComponent,\n    ],\n    templateUrl: \"./anna-non-editable-generic-normal-table.component.html\",\n    styleUrls: [\"./anna-non-editable-generic-normal-table.component.scss\"],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class AnnaNonEditableGenericNormalTableComponent implements OnInit, OnChanges, AfterViewChecked {\n    @Input() showSkeletonLoading: boolean;\n    @Input() tableHeaders: IGtTableHeader[];\n    @Input() tableData: any[];\n    @Input() clonedTableData: any[];\n    @Input() gtGeneralConfig: IGtGeneralConfig;\n    @Input() totalRowInfo?: ITotalRowInfo[];\n    @Input() gtDimension: {\n        rowHeight: number;\n        headerHeight: number;\n        dataOnTopHeight: number;\n        marginFromBottom: number;\n        tableHeight?: string;\n    };\n    @Input() tableClass: string;\n    @Input() maximumRowsWhichCanBeRenderedWithoutScroll: number = 5;\n    @Input() fixNumberOfRowsForPopup: boolean = false;\n    @Input() limit: number = 30;\n    @Input() includeBorderInTableHeight: boolean = true;\n    @Input() downloadInProgress: boolean;\n    @Input() percentDone: number;\n    @Input() starredInProgress: boolean;\n    @Input() clickableRow: boolean = false;\n    @Input() setTableHeightWhenRowSizeIsFixed: boolean = true;\n    @Input() tableBorderBottomClassRequired: boolean = true;\n    @Input() hideSomeTds: boolean = false;\n    @Input() tdsHaveRowSpan: boolean = false;\n    @Input() multipleTablesPresent: boolean = false;\n    @Input() showOrHideToggleForTotalRow: boolean = false;\n\n    @Output() toggleCheckbox = new EventEmitter();\n    @Output() toggleRowCheckbox = new EventEmitter();\n    @Output() toggleHeaderCheckbox = new EventEmitter();\n    @Output() undoIconClicked = new EventEmitter();\n    @Output() filterAppliedToTable = new EventEmitter();\n    @Output() sortingAppliedToTable = new EventEmitter();\n    @Output() rowClicked = new EventEmitter();\n    @Output() radioButtonSelected = new EventEmitter();\n    @Output() columnFilterOpened = new EventEmitter();\n    @Output() columnFilterClosed = new EventEmitter();\n    @Output() gtIconClicked = new EventEmitter();\n    @Output() gtSVGIconClicked = new EventEmitter();\n    @Output() gtTextActionClicked = new EventEmitter();\n    @Output() gtViewDetailClicked = new EventEmitter();\n    @Output() gtInnerHTMLClicked = new EventEmitter();\n    @Output() downloadSpotDetails = new EventEmitter();\n    @Output() clickableDataClicked = new EventEmitter();\n    @Output() totalRowIconClicked = new EventEmitter();\n    @Output() notificationIconHover = new EventEmitter();\n    @Output() notificationIconHoverLeave = new EventEmitter();\n    @Output() editableInputEdited = new EventEmitter();\n    @Output() radioButtonMessageIconClicked = new EventEmitter();\n\n    numberOfSkeletonRows: number[][] = Array(20).fill(0);\n    tableDataWrapper: any[];\n    rowChecked: boolean;\n    isAllRowsChecked: boolean;\n    noDataWidth: string = \"50%\";\n    markedForCreditStatus: string;\n    markedForMGStatus: string;\n    filterAlignment: string = \"bottom auto\";\n\n    // Sort and Filter\n    tooltipRadioTextMap: Map<any, any>;\n    filterTabObjects: any[];\n    tooltip: any;\n    disableColumnClearAllBtn: boolean = true;\n    margin = 5;\n\n    // Week Filter\n    multiWeekPickerConfig: IWeekCalendar;\n\n    tableColumns: string[] = [];\n    totalRowColumns: string[] = null;\n    bindValueFuncCalled: boolean;\n\n    hierarchyTooltip: { open: () => void; close: () => void };\n    sellerGroupHierarchy: RatingSellerGroupHierarchy[];\n    showFilterTooltipTabs: boolean; // Change the Name\n\n    isScrolledLeft: boolean = false;\n    rowBorderWidth: number = 2;\n\n    sameTooltipClicked: boolean;\n    isScrollEnded: boolean = true;\n    marginTop: string = \"\";\n    @ViewChildren(\"tableHeader\") viewChildTableHeaders: QueryList<ElementRef>;\n    @ViewChild(\"tableElementRef\", { static: true }) tableElementRef: ElementRef;\n\n    isDifferenceLessThan25Percent: boolean;\n    start: number = 0;\n    end: number = this.limit + this.start;\n    renderedData: any[];\n    selectedInventoryIdForDownload: number;\n    selectedDemographicForDownload: any;\n    selectedRowTypeForDownload: string;\n    heightOfCheckboxTooltipFilter: number;\n    isNoDataToDisplaySubject$ = new BehaviorSubject<boolean>(false);\n    selectedStarredOrderId: string;\n\n    textActionTooltip: KeyValueTooltipType[] = [];\n    tooltipContainingTable: TableTooltipType = null;\n    tableBottomBorderClass: string = null;\n    showCheckboxesForTimeFilter: boolean = false;\n\n    constructor(\n        private cdRef: ChangeDetectorRef,\n        private annaSortService: AnnaSortService,\n        public annaDateTimeFormatService: AnnaDateTimeFormatService,\n        public annaFilterService: AnnaFilterService,\n    ) {\n        console.log(\"constructor\");\n        this.setTooltipRadioNames();\n    }\n\n    ngAfterViewChecked(): void {\n        // if (this.setMarginLeft) {\n        this.annaFilterService.setMarginLeftForFilterIcon(this.viewChildTableHeaders);\n        // }\n    }\n\n    ngOnInit() {\n        document.documentElement.style.setProperty(`--hide-total-row-scrollbar-offset`, \"0px\");\n        this.setFilterAlignmentBasedOnScreenResolution();\n    }\n\n    detectChanges() {\n        this.cdRef.detectChanges();\n    }\n\n    ngOnChanges(changes: SimpleChanges) {\n        if (\n            changes &&\n            changes.gtDimension &&\n            changes.gtDimension.currentValue &&\n            this.setTableHeightWhenRowSizeIsFixed\n        ) {\n            this.setTableHeight();\n            this.setTableBottomBorder();\n        }\n        if (this.showSkeletonLoading) {\n            this.tableElementRef.nativeElement.scrollTop = 0;\n            this.tableElementRef.nativeElement.scrollLeft = 0;\n            this.tableData = this.numberOfSkeletonRows;\n            this.renderedData = this.numberOfSkeletonRows;\n            this.isNoDataToDisplaySubject$.next(false);\n            this.setTableBottomBorder();\n        } else if (\n            changes.percentDone ||\n            changes.downloadInProgress ||\n            (changes.starredInProgress && changes.starredInProgress.currentValue !== undefined)\n        ) {\n            // no task will be performed\n        } else {\n            this.setInitialRowsForTable();\n            this.disableEnableEachColumnTooltipIcon();\n            this.tableColumns = this.tableHeaders.filter((x) => x.visible).map((x) => x.headerInfo[0].objectKey);\n            if (\n                (this.tableData && this.tableData.length === 0) ||\n                (this.tableData.length === 2 && this.checkIfAllTheElementsAreZero())\n            ) {\n                this.tableData = Array(2).fill(0);\n                this.renderedData = cloneDeep(this.tableData);\n                this.marginTop = `${-this.gtDimension.rowHeight - this.gtDimension.rowHeight / 2}px`;\n                this.isNoDataToDisplaySubject$.next(true);\n            } else {\n                this.isNoDataToDisplaySubject$.next(false);\n            }\n\n            this.showSkeletonLoading = false;\n            this.setTableBottomBorder();\n        }\n\n        // setting table column here as well because while showing skeleton loader, we should show table headers.\n        if (changes.tableHeaders && !isEqual(changes.tableHeaders.currentValue, changes.tableHeaders.previousValue)) {\n            this.tableColumns = this.tableHeaders.filter((x) => x.visible).map((x) => x.headerInfo[0].objectKey);\n            this.annaSortService.columnSortState = new Map();\n            this.annaFilterService.initialValueMap = new Map();\n            // this.setColumnSortStateMap();\n            this.setActiveStateObject();\n        }\n\n        if (changes.totalRowInfo && changes.totalRowInfo.currentValue) {\n            this.totalRowColumns = this.totalRowInfo.map((x) => x.colName);\n        }\n        // this.cdRef.detectChanges();\n    }\n\n    setFilterAlignmentBasedOnScreenResolution() {\n        const viewportHeight = window.innerHeight;\n        if (viewportHeight < 740) {\n            this.filterAlignment = \"left right top bottom\";\n        } else {\n            this.filterAlignment = \"bottom left right top\";\n        }\n    }\n\n    setTableBottomBorder() {\n        if (\n            this.tableBorderBottomClassRequired &&\n            this.tableData &&\n            this.tableData.length &&\n            this.maximumRowsWhichCanBeRenderedWithoutScroll < this.tableData.length\n        ) {\n            this.tableBottomBorderClass = \"bottom-border\";\n        } else {\n            this.tableBottomBorderClass = null;\n        }\n    }\n\n    checkIfAllTheElementsAreZero() {\n        return !this.tableData.some((item) => item !== 0);\n    }\n\n    showHideTotalRow() {\n        this.gtGeneralConfig.totalRow = !this.gtGeneralConfig.totalRow;\n        if (!this.gtGeneralConfig.totalRow) {\n            document.documentElement.style.setProperty(`--hide-total-row-scrollbar-offset`, \"50px\");\n        } else {\n            document.documentElement.style.setProperty(`--hide-total-row-scrollbar-offset`, \"0px\");\n        }\n    }\n\n    setTableHeight() {\n        let viewportHeight = window.innerHeight;\n        const { rowHeight } = this.gtDimension;\n        const { headerHeight } = this.gtDimension;\n        const { dataOnTopHeight } = this.gtDimension;\n        const { marginFromBottom } = this.gtDimension;\n        let actualTableHeight;\n\n        if (this.fixNumberOfRowsForPopup) {\n            const maxNoOfRowsToDisplay = viewportHeight < 740 ? 5 : 10;\n            this.maximumRowsWhichCanBeRenderedWithoutScroll = maxNoOfRowsToDisplay;\n            actualTableHeight = this.maximumRowsWhichCanBeRenderedWithoutScroll * rowHeight + headerHeight;\n        } else {\n            const minHeightForTable = headerHeight + 3 * rowHeight;\n            viewportHeight = viewportHeight <= dataOnTopHeight ? dataOnTopHeight + minHeightForTable : viewportHeight;\n            const heightLeftForTable = viewportHeight - dataOnTopHeight - marginFromBottom;\n            this.maximumRowsWhichCanBeRenderedWithoutScroll =\n                Math.ceil((heightLeftForTable - headerHeight - rowHeight) / rowHeight) + 1;\n            actualTableHeight = viewportHeight - dataOnTopHeight - marginFromBottom;\n        }\n\n        // let actualTableHeight = heightLeftForTable - ((heightLeftForTable - headerHeight - rowHeight) % rowHeight);\n\n        this.gtDimension.tableHeight = `${actualTableHeight}px`;\n\n        this.numberOfSkeletonRows = this.maximumRowsWhichCanBeRenderedWithoutScroll\n            ? Array(this.maximumRowsWhichCanBeRenderedWithoutScroll).fill(0)\n            : Array(5).fill(0);\n    }\n\n    trackByHeaderFn(index: number, item: IGtTableHeader) {\n        return item.headerInfo[0].name;\n    }\n\n    trackByTotalRowFn(index: number, item: ITotalRowInfo) {\n        return item.colName;\n    }\n\n    trackByFn(index: number) {\n        return index;\n    }\n\n    setTooltipRadioNames() {\n        this.tooltipRadioTextMap = new Map();\n        this.tooltipRadioTextMap.set(\"StartTimeForFilter\", \"Start Time\");\n        this.tooltipRadioTextMap.set(\"EndTimeForFilter\", \"End Time\");\n        this.tooltipRadioTextMap.set(\"startTimeForFilter\", \"Start Time\");\n        this.tooltipRadioTextMap.set(\"endTimeForFilter\", \"End Time\");\n        this.tooltipRadioTextMap.set(\"start_time_for_filter\", \"Start Time\");\n        this.tooltipRadioTextMap.set(\"end_time_for_filter\", \"End Time\");\n        this.tooltipRadioTextMap.set(\"primaryAEName\", \"Primary AE\");\n        this.tooltipRadioTextMap.set(\"region\", \"Region\");\n        this.tooltipRadioTextMap.set(\"agencyName\", \"Agency\");\n        this.tooltipRadioTextMap.set(\"location\", \"Location\");\n        this.tooltipRadioTextMap.set(\"advertiserName\", \"Advertiser\");\n        this.tooltipRadioTextMap.set(\"productCode\", \"Product Code\");\n        this.tooltipRadioTextMap.set(\"flightStartDate\", \"Start Date\");\n        this.tooltipRadioTextMap.set(\"flightEndDate\", \"End Date\");\n        this.tooltipRadioTextMap.set(\"orderIdAndRevNumber\", \"STN Order#-Rev#\");\n        this.tooltipRadioTextMap.set(\"stationOrderNumber\", \"STN Order#\");\n        this.tooltipRadioTextMap.set(\"alternateOrderId\", \"Alt/Rep Order #\");\n        this.tooltipRadioTextMap.set(\"grp\", \"GRP\");\n        this.tooltipRadioTextMap.set(\"cpp\", \"CPP\");\n        this.tooltipRadioTextMap.set(\"imps\", \"IMPS\");\n        this.tooltipRadioTextMap.set(\"cpm\", \"CPM\");\n        this.tooltipRadioTextMap.set(\"offeredMGs\", \"Offered MG\");\n        this.tooltipRadioTextMap.set(\"outstandingPE\", \"O/S PE\");\n        this.tooltipRadioTextMap.set(\"offeredADUs\", \"Offered ADUs\");\n        this.tooltipRadioTextMap.set(\"udDeficitValue\", \"O/S Aud Delta\");\n        this.tooltipRadioTextMap.set(\"startEndTimeMulti\", \"Time\");\n        this.tooltipRadioTextMap.set(\"bookedValue\", \"Booked\");\n        this.tooltipRadioTextMap.set(\"bookedSpots\", \"Spots\");\n        this.tooltipRadioTextMap.set(\"UserCreditedValue\", \"User Credited\");\n        this.tooltipRadioTextMap.set(\"UserUnresolvedValue\", \"User Unresolved\");\n        this.tooltipRadioTextMap.set(\"BuyerAddedValue\", \"Buyer Added\");\n        this.tooltipRadioTextMap.set(\"BuyerDeletedValue\", \"Buyer Deleted\");\n        this.tooltipRadioTextMap.set(\"userChanges\", \"User Changes\");\n        this.tooltipRadioTextMap.set(\"buyerChanges\", \"Buyer Changes\");\n        this.tooltipRadioTextMap.set(\"userMG\", \"User MG\");\n        this.tooltipRadioTextMap.set(\"userADUs\", \"User ADUs\");\n        this.tooltipRadioTextMap.set(\"inventoryCode\", \"Inventory Code\");\n        this.tooltipRadioTextMap.set(\"program\", \"Program\");\n        this.tooltipRadioTextMap.set(\"agency\", \"Agency\");\n        this.tooltipRadioTextMap.set(\"advertiser\", \"Advertiser\");\n        this.tooltipRadioTextMap.set(\"startDate\", \"Start Date\");\n        this.tooltipRadioTextMap.set(\"endDate\", \"End Date\");\n        this.tooltipRadioTextMap.set(\"date\", \"Date\");\n        this.tooltipRadioTextMap.set(\"rcvPreempt\", \"$ Madegood PEs\");\n        this.tooltipRadioTextMap.set(\"osPreempt\", \"$ O/S PEs\");\n        this.tooltipRadioTextMap.set(\"rcvUnderDly\", \"Recovered UD\");\n        this.tooltipRadioTextMap.set(\"osUnderDly\", \"O/s Under Dly\");\n        this.tooltipRadioTextMap.set(\"primaryAe\", \"Primary AE\");\n        this.tooltipRadioTextMap.set(\"region\", \"Region\");\n        this.tooltipRadioTextMap.set(\"revCode1\", \"Rev code 1\");\n        this.tooltipRadioTextMap.set(\"orderNoRevNo\", \"STN Order#-Rev#\");\n        this.tooltipRadioTextMap.set(\"revCode2\", \"Rev code 2\");\n        this.tooltipRadioTextMap.set(\"revCode3\", \"Rev code 3\");\n        this.tooltipRadioTextMap.set(\"booked\", \"$ Booked\");\n        this.tooltipRadioTextMap.set(\"spots\", \"Spots\");\n        this.tooltipRadioTextMap.set(\"postedAudPercent\", \"Posted %\");\n        this.tooltipRadioTextMap.set(\"revision\", \"Revision\");\n        this.tooltipRadioTextMap.set(\"buyerOrderId\", \"ALT/REP Order#\");\n        this.tooltipRadioTextMap.set(\"demo\", \"Demo\");\n\n        this.tooltipRadioTextMap.set(\"averageRateThisYear\", \"Avg. Rate (TY)\");\n        this.tooltipRadioTextMap.set(\"averageRateLastYear\", \"Avg. Rat (LY)\");\n        this.tooltipRadioTextMap.set(\"averageCPP\", \"Avg. CPP\");\n        this.tooltipRadioTextMap.set(\"projectedCPP\", \"Proj. CPP (30s)\");\n        this.tooltipRadioTextMap.set(\"projectedCPM\", \"Proj. CPM (30s)\");\n        this.tooltipRadioTextMap.set(\"averageCPM\", \"Avg. CPM\");\n        this.tooltipRadioTextMap.set(\"IMPSDiff\", \"IMPS ('000) Diff.\");\n        this.tooltipRadioTextMap.set(\"RTGDiff\", \"RTG Diff.\");\n        this.tooltipRadioTextMap.set(\"bookedEqCpmValue\", \"Booked CPM (30s)\");\n        this.tooltipRadioTextMap.set(\"bookedEqCppValue\", \"Booked CPP (30s)\");\n        this.tooltipRadioTextMap.set(\"postedAdu\", \"$ Posted ADUs\");\n        this.tooltipRadioTextMap.set(\"scheduledAdu\", \"$ Scheduled ADUs\");\n        this.tooltipRadioTextMap.set(\"audienceDeficit\", \"$ O/S Audience\");\n        this.tooltipRadioTextMap.set(\"postedAudPercent\", \"Posted Audience %\");\n        this.tooltipRadioTextMap.set(\"potentialUnitsValue\", \"POT Units\");\n        this.tooltipRadioTextMap.set(\"bookedUnitsValue\", \"Booked Eq Units\");\n        this.tooltipRadioTextMap.set(\"bookedAmountWithZeroRatingValue\", \"Total $ Booked\");\n        this.tooltipRadioTextMap.set(\"bookedAmountPercentageWithZeroRatingValue\", \"% Against All Demos\");\n        this.tooltipRadioTextMap.set(\"bookedAmountWithoutZeroRatingValue\", \"$Booked With Imps(’000)\");\n        this.tooltipRadioTextMap.set(\"bookedAmountPercentageWithoutZeroRatingValue\", \"% Against All Demos\");\n\n        this.tooltipRadioTextMap.set(\"totalBookedAmountValue\", \"Total $Booked\");\n        this.tooltipRadioTextMap.set(\"averageUnitRateValue\", \" AUR\");\n        this.tooltipRadioTextMap.set(\"totalBookedAmountWithRatingValue\", \"$Booked With Rating\");\n        this.tooltipRadioTextMap.set(\"averageUnitRateWithRatingValue\", \"AUR With Rating\");\n        this.tooltipRadioTextMap.set(\"totalBookedAmountValue\", \"Total $Booked\");\n        this.tooltipRadioTextMap.set(\"averageUnitRateValue\", \" AUR\");\n        this.tooltipRadioTextMap.set(\"totalBookedAmountWithRatingValue\", \"$Booked With Rating\");\n        this.tooltipRadioTextMap.set(\"averageUnitRateWithRatingValue\", \"AUR With Rating\");\n\n        this.tooltipRadioTextMap.set(\"totalBookedAmountWithImpressionValue\", \"$Booked With IMPS\");\n        this.tooltipRadioTextMap.set(\"averageUnitRateWithImpressionValue\", \"AUR With IMPS\");\n        this.tooltipRadioTextMap.set(\"totalBookedAmountWithImpressionValue\", \"$Booked With IMPS\");\n        this.tooltipRadioTextMap.set(\"averageUnitRateWithImpressionValue\", \"AUR With IMPS\");\n\n        this.tooltipRadioTextMap.set(\"bookedUnitsWithRatingValue\", \"Booked Units With Rating\");\n        this.tooltipRadioTextMap.set(\"postedUnitsWithRatingValue\", \"Posted Units With Rating\");\n        this.tooltipRadioTextMap.set(\"bookedUnitsWithRatingValue\", \"Booked Units With Rating\");\n        this.tooltipRadioTextMap.set(\"postedUnitsWithRatingValue\", \"Posted Units With Rating\");\n\n        this.tooltipRadioTextMap.set(\"bookedUnitsWithImpressionValue\", \"Booked Units With IMPS\");\n        this.tooltipRadioTextMap.set(\"postedUnitsWithImpressionValue\", \"Posted Units With IMPS\");\n        this.tooltipRadioTextMap.set(\"bookedUnitsWithImpressionValue\", \"Booked Units With IMPS\");\n        this.tooltipRadioTextMap.set(\"postedUnitsWithImpressionValue\", \"Posted Units With IMPS\");\n\n        this.tooltipRadioTextMap.set(\"bookedRatings\", \"Booked Rating\");\n        this.tooltipRadioTextMap.set(\"postedRatings\", \"POSTED Rating\");\n        this.tooltipRadioTextMap.set(\"PostedRating\", \"Posted RTG\");\n        this.tooltipRadioTextMap.set(\"bookedRatings\", \"Booked Rating\");\n        this.tooltipRadioTextMap.set(\"postedRatings\", \"POSTED Rating\");\n        this.tooltipRadioTextMap.set(\"PostedRating\", \"Posted RTG\");\n\n        this.tooltipRadioTextMap.set(\"bookedImpressions\", \"Booked IMP('000)\");\n        this.tooltipRadioTextMap.set(\"postedImpressions\", \"Posted IMP('000)\");\n        this.tooltipRadioTextMap.set(\"PostedImpressions\", \"Posted IMP('000)\");\n        this.tooltipRadioTextMap.set(\"bookedImpressions\", \"Booked IMP('000)\");\n        this.tooltipRadioTextMap.set(\"postedImpressions\", \"Posted IMP('000)\");\n        this.tooltipRadioTextMap.set(\"PostedImpressions\", \"Posted IMP('000)\");\n\n        this.tooltipRadioTextMap.set(\"bookedAverageRating\", \"Booked AU Rating\");\n        this.tooltipRadioTextMap.set(\"postedAverageRating\", \"Posted AU Rating\");\n        this.tooltipRadioTextMap.set(\"bookedAverageRating\", \"Booked AU Rating\");\n        this.tooltipRadioTextMap.set(\"postedAverageRating\", \"Posted AU Rating\");\n\n        this.tooltipRadioTextMap.set(\"bookedAverageImpression\", \"Booked AU IMPS\");\n        this.tooltipRadioTextMap.set(\"postedAverageImpression\", \"Posted AU IMPS\");\n        this.tooltipRadioTextMap.set(\"bookedAverageImpression\", \"Booked AU IMPS\");\n        this.tooltipRadioTextMap.set(\"postedAverageImpression\", \"Posted AU IMPS\");\n\n        this.tooltipRadioTextMap.set(\"bookedCppValue\", \"Booked CPP\");\n        this.tooltipRadioTextMap.set(\"bookedEffectiveCppValue\", \"Effective CPP\");\n        this.tooltipRadioTextMap.set(\"bookedCppValue\", \"Booked CPP\");\n        this.tooltipRadioTextMap.set(\"bookedEffectiveCppValue\", \"Effective CPP\");\n\n        this.tooltipRadioTextMap.set(\"bookedCpmValue\", \"Booked CPM\");\n        this.tooltipRadioTextMap.set(\"bookedEffectiveCpmValue\", \"Effective CPM\");\n        this.tooltipRadioTextMap.set(\"bookedCpmValue\", \"Booked CPM\");\n        this.tooltipRadioTextMap.set(\"bookedEffectiveCpmValue\", \"Effective CPM\");\n\n        this.tooltipRadioTextMap.set(\"orderSource\", \"Order Route\");\n        this.tooltipRadioTextMap.set(\"orderCategory\", \"Rev Category\");\n        this.tooltipRadioTextMap.set(\"cashOrTrade\", \"C/T\");\n        this.tooltipRadioTextMap.set(\"revisionStartDate\", \"Revision Start Date\");\n        this.tooltipRadioTextMap.set(\"name\", \"name\");\n        this.tooltipRadioTextMap.set(\"role\", \"role\");\n        this.tooltipRadioTextMap.set(\"stationCount\", \"stationCount\");\n        this.tooltipRadioTextMap.set(\"stationList\", \"stationList\");\n        this.tooltipRadioTextMap.set(\"approvedOn\", \"Approved On\");\n        this.tooltipRadioTextMap.set(\"approvedBy\", \"Approved By\");\n        this.tooltipRadioTextMap.set(\"ODImps\", \"Proj. OD IMPS\");\n        this.tooltipRadioTextMap.set(\"UDImps\", \"Proj. UD IMPS\");\n        this.tooltipRadioTextMap.set(\"ODGrp\", \"Proj. OD GRP\");\n        this.tooltipRadioTextMap.set(\"UDGrp\", \"Proj. UD GRP\");\n        this.tooltipRadioTextMap.set(\"udImpsPercent\", \"Proj. UD %\");\n        this.tooltipRadioTextMap.set(\"udGrpPercent\", \"Proj. UD GRP %\");\n        this.tooltipRadioTextMap.set(\"odImpsPercent\", \"Proj. OD %\");\n        this.tooltipRadioTextMap.set(\"odGrpPercent\", \"Proj. OD GRP %\");\n        this.tooltipRadioTextMap.set(\"orderSource\", \"Order Route\");\n        this.tooltipRadioTextMap.set(\"orderCategory\", \"Rev Category\");\n        this.tooltipRadioTextMap.set(\"cashOrTrade\", \"C/T\");\n        this.tooltipRadioTextMap.set(\"revisionStartDate\", \"Revision Start Date\");\n        this.tooltipRadioTextMap.set(\"name\", \"name\");\n        this.tooltipRadioTextMap.set(\"role\", \"role\");\n        this.tooltipRadioTextMap.set(\"stationCount\", \"stationCount\");\n        this.tooltipRadioTextMap.set(\"stationList\", \"stationList\");\n        this.tooltipRadioTextMap.set(\"approvedOn\", \"Approved On\");\n        this.tooltipRadioTextMap.set(\"approvedBy\", \"Approved By\");\n        this.tooltipRadioTextMap.set(\"ODImps\", \"Proj. OD IMPS\");\n        this.tooltipRadioTextMap.set(\"UDImps\", \"Proj. UD IMPS\");\n        this.tooltipRadioTextMap.set(\"ODGrp\", \"Proj. OD GRP\");\n        this.tooltipRadioTextMap.set(\"UDGrp\", \"Proj. UD GRP\");\n        this.tooltipRadioTextMap.set(\"udImpsPercent\", \"Proj. UD %\");\n        this.tooltipRadioTextMap.set(\"udGrpPercent\", \"Proj. UD GRP %\");\n        this.tooltipRadioTextMap.set(\"odImpsPercent\", \"Proj. OD %\");\n        this.tooltipRadioTextMap.set(\"odGrpPercent\", \"Proj. OD GRP %\");\n\n        this.tooltipRadioTextMap.set(\"RevisionNumber\", \"Revision #\");\n        this.tooltipRadioTextMap.set(\"RevisionType\", \"Revision Type\");\n        this.tooltipRadioTextMap.set(\"GeneratedOn\", \"Generated On\");\n        this.tooltipRadioTextMap.set(\"BookedValueForDisplay\", \"$ BOOKED\");\n        this.tooltipRadioTextMap.set(\"BookedValue\", \"$ Booked\");\n        this.tooltipRadioTextMap.set(\"BookedSpots\", \"Spots\");\n        this.tooltipRadioTextMap.set(\"BookedGRP\", \"GRP\");\n        this.tooltipRadioTextMap.set(\"BookedIMPSRevTab\", \"IMPS'(000)\");\n        this.tooltipRadioTextMap.set(\"BookedCPP\", \"CPP\");\n        this.tooltipRadioTextMap.set(\"BookedCPM\", \"CPM\");\n        this.tooltipRadioTextMap.set(\"MGsValueForDisplay\", \"$ MGS\");\n        this.tooltipRadioTextMap.set(\"MGsValue\", \"$ MGS\");\n        this.tooltipRadioTextMap.set(\"ADUsValueForDisplay\", \"$ ADUS\");\n        this.tooltipRadioTextMap.set(\"ADUsValue\", \"$ ADUS\");\n        this.tooltipRadioTextMap.set(\"BuyerChangesValueForDisplay\", \"$ Buyer Change\");\n        this.tooltipRadioTextMap.set(\"BuyerChangesValue\", \"$ Buyer Change\");\n        this.tooltipRadioTextMap.set(\"UserChangesValueForDisplay\", \"$ Seller User Change\");\n        this.tooltipRadioTextMap.set(\"UserChangesValue\", \"$ Seller User Change\");\n        this.tooltipRadioTextMap.set(\"SellerLine\", \"Seller Line #\");\n        this.tooltipRadioTextMap.set(\"BuyerLine\", \"Buy Line #\");\n        this.tooltipRadioTextMap.set(\"SpotStatus\", \"Spot Status\");\n        this.tooltipRadioTextMap.set(\"InventoryCode\", \"Inventory Code\");\n        this.tooltipRadioTextMap.set(\"BuyerProgramName\", \"Buyer Program Name\");\n        this.tooltipRadioTextMap.set(\"RevenueClass\", \"Revenue Class\");\n        this.tooltipRadioTextMap.set(\"WeeklyAUR\", \"Booked Avg. Rate\");\n        this.tooltipRadioTextMap.set(\"BookedRate\", \"Booked Rate\");\n        this.tooltipRadioTextMap.set(\"averageRate\", \"Average Rate\");\n        this.tooltipRadioTextMap.set(\"bookedAverageRate\", \"Booked AVG. Rate\");\n        this.tooltipRadioTextMap.set(\"dollarIMPSImpact\", \"$ IMPS Impact\");\n        this.tooltipRadioTextMap.set(\"dollarRTGImpact\", \"$ RTG IMPACT\");\n        this.tooltipRadioTextMap.set(\"IMPSImpact\", \"IMPS ('000) IMPACT\");\n        this.tooltipRadioTextMap.set(\"RTGImpact\", \"RTG Impact\");\n        this.tooltipRadioTextMap.set(\"RevisionNumber\", \"Revision #\");\n        this.tooltipRadioTextMap.set(\"RevisionType\", \"Revision Type\");\n        this.tooltipRadioTextMap.set(\"GeneratedOn\", \"Generated On\");\n        this.tooltipRadioTextMap.set(\"BookedValueForDisplay\", \"$ BOOKED\");\n        this.tooltipRadioTextMap.set(\"BookedValue\", \"$ Booked\");\n        this.tooltipRadioTextMap.set(\"BookedSpots\", \"Spots\");\n        this.tooltipRadioTextMap.set(\"BookedGRP\", \"GRP\");\n        this.tooltipRadioTextMap.set(\"BookedIMPSRevTab\", \"IMPS'(000)\");\n        this.tooltipRadioTextMap.set(\"BookedCPP\", \"CPP\");\n        this.tooltipRadioTextMap.set(\"BookedCPM\", \"CPM\");\n        this.tooltipRadioTextMap.set(\"MGsValueForDisplay\", \"$ MGS\");\n        this.tooltipRadioTextMap.set(\"MGsValue\", \"$ MGS\");\n        this.tooltipRadioTextMap.set(\"ADUsValueForDisplay\", \"$ ADUS\");\n        this.tooltipRadioTextMap.set(\"ADUsValue\", \"$ ADUS\");\n        this.tooltipRadioTextMap.set(\"BuyerChangesValueForDisplay\", \"$ Buyer Change\");\n        this.tooltipRadioTextMap.set(\"BuyerChangesValue\", \"$ Buyer Change\");\n        this.tooltipRadioTextMap.set(\"UserChangesValueForDisplay\", \"$ Seller User Change\");\n        this.tooltipRadioTextMap.set(\"UserChangesValue\", \"$ Seller User Change\");\n        this.tooltipRadioTextMap.set(\"SellerLine\", \"Seller Line #\");\n        this.tooltipRadioTextMap.set(\"BuyerLine\", \"Buy Line #\");\n        this.tooltipRadioTextMap.set(\"SpotStatus\", \"Spot Status\");\n        this.tooltipRadioTextMap.set(\"InventoryCode\", \"Inventory Code\");\n        this.tooltipRadioTextMap.set(\"BuyerProgramName\", \"Buyer Program Name\");\n        this.tooltipRadioTextMap.set(\"RevenueClass\", \"Revenue Class\");\n        this.tooltipRadioTextMap.set(\"WeeklyAUR\", \"Booked Avg. Rate\");\n        this.tooltipRadioTextMap.set(\"BookedRate\", \"Booked Rate\");\n        this.tooltipRadioTextMap.set(\"averageRate\", \"Average Rate\");\n        this.tooltipRadioTextMap.set(\"bookedAverageRate\", \"Booked AVG. Rate\");\n        this.tooltipRadioTextMap.set(\"dollarIMPSImpact\", \"$ IMPS Impact\");\n        this.tooltipRadioTextMap.set(\"dollarRTGImpact\", \"$ RTG IMPACT\");\n        this.tooltipRadioTextMap.set(\"IMPSImpact\", \"IMPS ('000) IMPACT\");\n        this.tooltipRadioTextMap.set(\"RTGImpact\", \"RTG Impact\");\n\n        this.tooltipRadioTextMap.set(\"inventoryFillPercentageSameWeek\", \"Inv Fill Same Week (LY)\");\n        this.tooltipRadioTextMap.set(\"inventoryFillPercentageFinal\", \"Inv Fill Final (LY)\");\n        this.tooltipRadioTextMap.set(\"inventoryFillPercentageSameWeek\", \"Inv Fill Same Week (LY)\");\n        this.tooltipRadioTextMap.set(\"inventoryFillPercentageFinal\", \"Inv Fill Final (LY)\");\n\n        this.tooltipRadioTextMap.set(\"projectedRTG\", \"Projected RTG\");\n        this.tooltipRadioTextMap.set(\"projectedIMPS\", \"Projected IMPS('000)\");\n        this.tooltipRadioTextMap.set(\"desiredCPM\", \"Desired CPM\");\n        this.tooltipRadioTextMap.set(\"desiredCPP\", \"Desired CPP\");\n        this.tooltipRadioTextMap.set(\"origin\", \"Origin\");\n        this.tooltipRadioTextMap.set(\"projectedRTG\", \"Projected RTG\");\n        this.tooltipRadioTextMap.set(\"projectedIMPS\", \"Projected IMPS('000)\");\n        this.tooltipRadioTextMap.set(\"desiredCPM\", \"Desired CPM\");\n        this.tooltipRadioTextMap.set(\"desiredCPP\", \"Desired CPP\");\n        this.tooltipRadioTextMap.set(\"origin\", \"Origin\");\n\n        this.tooltipRadioTextMap.set(\"BookedRTG\", \"Booked RTG\");\n        this.tooltipRadioTextMap.set(\"BookedIMPS\", \"Booked IMPS('000)\");\n        this.tooltipRadioTextMap.set(\"IMPS\", \"IMP('000)\");\n        this.tooltipRadioTextMap.set(\"AURTG\", \"Avg RTG\");\n        this.tooltipRadioTextMap.set(\"AUIMPS\", \"Avg IMP('000)\");\n        this.tooltipRadioTextMap.set(\"PostedRatingsOrImpressions\", \"Posted RTG\");\n        this.tooltipRadioTextMap.set(\"ScheduleFlightWeek\", \"Schedule Week\");\n        this.tooltipRadioTextMap.set(\"ScheduledDay\", \"Scheduled Day\");\n        this.tooltipRadioTextMap.set(\"AirStatus\", \"Air Status\");\n        this.tooltipRadioTextMap.set(\"AirDateAndTime\", \"Air Date & Time\");\n        this.tooltipRadioTextMap.set(\"AirDate\", \"Air Date\");\n        this.tooltipRadioTextMap.set(\"NormalizedOrderedRating\", \"Normalized Booked RTG\");\n        this.tooltipRadioTextMap.set(\"NormalizedOrderedImpressions\", \"Normalized Booked IMP('000)\");\n        this.tooltipRadioTextMap.set(\"BuyerLineNumber\", \"Buy Line #\");\n        this.tooltipRadioTextMap.set(\"NormalizedPostedRating\", \"Normalized Posted RTG\");\n        this.tooltipRadioTextMap.set(\"NormalizedPostedImpressions\", \"Normalized Posted IMP('000)\");\n        this.tooltipRadioTextMap.set(\"AdId\", \"Ad-Id\");\n        this.tooltipRadioTextMap.set(\"BookedRTG\", \"Booked RTG\");\n        this.tooltipRadioTextMap.set(\"BookedIMPS\", \"Booked IMPS('000)\");\n        this.tooltipRadioTextMap.set(\"IMPS\", \"IMP('000)\");\n        this.tooltipRadioTextMap.set(\"AURTG\", \"Avg RTG\");\n        this.tooltipRadioTextMap.set(\"AUIMPS\", \"Avg IMP('000)\");\n        this.tooltipRadioTextMap.set(\"PostedRatingsOrImpressions\", \"Posted RTG\");\n        this.tooltipRadioTextMap.set(\"ScheduleFlightWeek\", \"Schedule Week\");\n        this.tooltipRadioTextMap.set(\"ScheduledDay\", \"Scheduled Day\");\n        this.tooltipRadioTextMap.set(\"AirStatus\", \"Air Status\");\n        this.tooltipRadioTextMap.set(\"AirDateAndTime\", \"Air Date & Time\");\n        this.tooltipRadioTextMap.set(\"AirDate\", \"Air Date\");\n        this.tooltipRadioTextMap.set(\"NormalizedOrderedRating\", \"Normalized Booked RTG\");\n        this.tooltipRadioTextMap.set(\"NormalizedOrderedImpressions\", \"Normalized Booked IMP('000)\");\n        this.tooltipRadioTextMap.set(\"NormalizedPostedRating\", \"Normalized Posted RTG\");\n        this.tooltipRadioTextMap.set(\"NormalizedPostedImpressions\", \"Normalized Posted IMP('000)\");\n        this.tooltipRadioTextMap.set(\"AdId\", \"Ad-Id\");\n\n        this.tooltipRadioTextMap.set(\"displayimps\", \"IMPS\");\n        this.tooltipRadioTextMap.set(\"displayGrp\", \"GRP\");\n        this.tooltipRadioTextMap.set(\"bookedSpotsForDisplay\", \"Spots\");\n        this.tooltipRadioTextMap.set(\"displaySpots\", \"Spots\");\n\n        this.tooltipRadioTextMap.set(\"estimateNo\", \"Estimate#\");\n        this.tooltipRadioTextMap.set(\"primaryBuyer\", \"Primary Buyer\");\n        this.tooltipRadioTextMap.set(\"primaryBuyerName\", \"Primary Buyer\");\n        this.tooltipRadioTextMap.set(\"secondaryBuyerName\", \"Secondary Buyer\");\n        this.tooltipRadioTextMap.set(\"secondaryBuyer\", \"Secondary Buyer\");\n        this.tooltipRadioTextMap.set(\"timeoutDate\", \"Timeout Date\");\n        this.tooltipRadioTextMap.set(\"DisplaytSpotStatusBI\", \"Spot Status\");\n        this.tooltipRadioTextMap.set(\"LineSpot\", \"Line.Spot\");\n        this.tooltipRadioTextMap.set(\"LurWindowName\", \"Political Window\");\n        this.tooltipRadioTextMap.set(\"lineAndSpotNumber\", \"Line.Spot#\");\n        this.tooltipRadioTextMap.set(\"length\", \"Length\");\n        this.tooltipRadioTextMap.set(\"revClass\", \"Rev Class\");\n\n        // this.tooltipRadioTextMap.set(\"udValue\", \"$ UD\");\n        // this.tooltipRadioTextMap.set(\"odValue\", \"$ OD\");\n        this.tooltipRadioTextMap.set(\"udValue\", \"Proj. $ UD\");\n        this.tooltipRadioTextMap.set(\"odValue\", \"Proj. $ OD\");\n\n        this.tooltipRadioTextMap.set(\"InventoryCode\", \"Inventory Code\");\n        this.tooltipRadioTextMap.set(\"BuyerProgramName\", \"Buyer Program Name\");\n        this.tooltipRadioTextMap.set(\"StartTime\", \"Start Time\");\n        this.tooltipRadioTextMap.set(\"EndTime\", \"End Time\");\n        this.tooltipRadioTextMap.set(\"WeeklyAUR\", \"Booked Avg. Rate\");\n        this.tooltipRadioTextMap.set(\"DisplayRevenueClass\", \"Rev Class\");\n        this.tooltipRadioTextMap.set(\"ActualWeekStartDate\", \"Week\");\n        this.tooltipRadioTextMap.set(\"WeekDay\", \"Day\");\n        this.tooltipRadioTextMap.set(\"DisplayLength\", \"Length\");\n\n        this.tooltipRadioTextMap.set(\"OtherAvailableSpotsTableInventoryCode\", \"Inventory Code\");\n        this.tooltipRadioTextMap.set(\"OtherAvailableSpotsTableBuyerProgramName\", \"Buyer Program Name\");\n        this.tooltipRadioTextMap.set(\"OtherAvailableSpotsTableStartTime\", \"Start Time\");\n        this.tooltipRadioTextMap.set(\"OtherAvailableSpotsTableEndTime\", \"End Time\");\n        this.tooltipRadioTextMap.set(\"OtherAvailableSpotsTableWeeklyAUR\", \"Booked Avg. Rate\");\n        this.tooltipRadioTextMap.set(\"OtherAvailableSpotsTableDisplayRevenueClass\", \"Rev Class\");\n        this.tooltipRadioTextMap.set(\"OtherAvailableSpotsTableActualWeekStartDate\", \"Week\");\n        this.tooltipRadioTextMap.set(\"OtherAvailableSpotsTableWeekDay\", \"Day\");\n        this.tooltipRadioTextMap.set(\"OtherAvailableSpotsTableDisplayLength\", \"Length\");\n\n        this.tooltipRadioTextMap.set(\"ProjectedImpressions\", \"Projected IMP('000)\");\n        this.tooltipRadioTextMap.set(\"ProjectedRtg\", \"Projected RTG\");\n        this.tooltipRadioTextMap.set(\"ProjectedImpressions\", \"Projected IMP('000)\");\n        this.tooltipRadioTextMap.set(\"ProjectedRtg\", \"Projected RTG\");\n    }\n\n    selectOrUnselectCheckbox(rowData: any, columnKeys: any, isCheckboxSelected: any) {\n        rowData[columnKeys] = !rowData[columnKeys];\n        this.toggleCheckbox.emit({ rowData, columnKeys, isCheckboxSelected });\n    }\n\n    selectOrUnselectRadiobox(rowData: any, columnKeys: any, isCheckboxSelected: boolean) {\n        if (rowData[columnKeys] === isCheckboxSelected) return;\n        rowData[columnKeys] = isCheckboxSelected;\n        this.toggleCheckbox.emit({ rowData, columnKeys, isCheckboxSelected });\n    }\n\n    selectUnselectAllRows() {\n        this.toggleHeaderCheckbox.emit();\n    }\n\n    selectUnselectRow(rowData: any) {\n        this.toggleRowCheckbox.emit(rowData);\n    }\n\n    undoCreditedSpot(data: any) {\n        this.undoIconClicked.emit({ data, mgOrCredit: \"Credit\" });\n    }\n\n    undoMgSpot(data: any) {\n        this.undoIconClicked.emit({ data, mgOrCredit: \"MakeGood\" });\n    }\n\n    // Sort and Filter Logic begins!\n    closeTooltip() {\n        if (this.tooltip && this.tooltip.isOpen()) {\n            this.tooltip.close();\n        }\n        this.tooltip = null;\n        if (!this.bindValueFuncCalled) {\n            this.columnFilterClosed.emit();\n        }\n    }\n\n    isTooltipActive(header: any[]) {\n        return this.annaFilterService.isTooltipActive(header, this.annaSortService.columnSortState);\n    }\n\n    bindTheValueToToolTip(tooltip: any, header: IHeaderInfo) {\n        this.bindValueFuncCalled = true;\n        // if same tooltip opened close it\n        if (tooltip === this.tooltip) {\n            this.bindValueFuncCalled = false;\n            this.closeTooltip();\n        } else {\n            const enabledHeaders: any[] = [];\n            this.checkIfUniqueValuePresentForTheHeader(header, enabledHeaders);\n            this.openTooltip(tooltip, enabledHeaders, header);\n\n            if (\n                window.innerWidth < 1500 &&\n                window.innerHeight < 768 &&\n                !this.annaFilterService.sliderSet.has(header.filterSortObjectKeys[0])\n            ) {\n                this.columnFilterOpened.emit();\n            }\n\n            this.showCheckboxesForTimeFilter =\n                this.gtGeneralConfig.component === \"SPOTDETAILS\" ||\n                this.gtGeneralConfig.component === \"EXCLUDEINVENTORYPOPUP\" ||\n                this.gtGeneralConfig.component === \"RATING\";\n            this.showFilterTooltipTabs = header.filterSortObjectKeys.length > 1;\n            this.bindValueFuncCalled = false;\n        }\n    }\n\n    checkIfUniqueValuePresentForTheHeader(header: IHeaderInfo, enabledHeaders: any[]) {\n        header.filterSortObjectKeys.forEach((item: string) => {\n            const dataToCheck = this.annaFilterService.getFilterOptionsData(this.tableData, this.clonedTableData, item);\n            if (item === \"period\") {\n                const uniqStartDate = uniq(dataToCheck.map((u: { [x: string]: any }) => u.startDate));\n                const uniqEndDate = uniq(dataToCheck.map((u: { [x: string]: any }) => u.endDate));\n                if (uniqStartDate.length > 1 || uniqEndDate.length > 1 || this.isTooltipActive([item])) {\n                    enabledHeaders.push(item);\n                }\n            } else {\n                const values = dataToCheck.map((u: { [x: string]: any }) => u[item]);\n                // if last applied filter is this header, push it alos as enabledHeader\n                let activeAndLastlyAppliedHeader = false;\n                if (\n                    this.annaFilterService.appliedFiltersArray.length > 0 &&\n                    this.annaFilterService.appliedFiltersArray[\n                        this.annaFilterService.appliedFiltersArray.length - 1\n                    ] === item\n                ) {\n                    activeAndLastlyAppliedHeader = true;\n                }\n                if (\n                    header.filter === \"CHECKBOX\" &&\n                    (uniq(values).filter((n) => n != null).length > 1 || activeAndLastlyAppliedHeader)\n                ) {\n                    enabledHeaders.push(item);\n                } else if (\n                    header.filter !== \"CHECKBOX\" &&\n                    (uniq(values).filter((n) => n != null && n !== \"-\").length > 1 || activeAndLastlyAppliedHeader)\n                ) {\n                    enabledHeaders.push(item);\n                }\n            }\n        });\n    }\n\n    openTooltip(tooltip: any, header: any, columnHeader: IHeaderInfo) {\n        this.closeTooltip();\n        this.tooltip = tooltip;\n        this.tooltip.open();\n        // convert key into the header\n        this.filterTabObjects = header.map((key: string, index: number) => {\n            // change to display name\n            const value = this.tooltipRadioTextMap.has(key) ? this.tooltipRadioTextMap.get(key) : key;\n            return new RadioButtonModel(\n                key,\n                value,\n                columnHeader.isSortRequired[index],\n                columnHeader.isFilterRequired[index],\n            );\n        });\n    }\n\n    disableEnableEachColumnTooltipIcon() {\n        this.tableHeaders.forEach((header) => {\n            header.headerInfo.forEach((item) => {\n                if (item.showTooltipIcon) {\n                    let values = [];\n                    item.disableTooltipIcon = true;\n\n                    item.filterSortObjectKeys.forEach((key) => {\n                        const latestFilters = this.annaFilterService.appliedFiltersArray;\n\n                        if (\n                            latestFilters.length > 0 &&\n                            item.disableTooltipIcon &&\n                            latestFilters[latestFilters.length - 1] === key\n                        ) {\n                            item.disableTooltipIcon = false;\n                        }\n\n                        if (item.disableTooltipIcon) {\n                            if (key === \"period\") {\n                                const uniqStartDate = uniq(\n                                    this.tableData.map((u: { [x: string]: any }) => u.startDate),\n                                );\n                                const uniqEndDate = uniq(this.tableData.map((u: { [x: string]: any }) => u.endDate));\n\n                                item.disableTooltipIcon = !(uniqStartDate.length > 1 || uniqEndDate.length > 1);\n                            } else {\n                                values = this.tableData.map((u: { [x: string]: any }) => u[key]);\n                                if (\n                                    (item.filter === \"CHECKBOX\" && uniq(values).filter((n) => n != null).length > 1) ||\n                                    (item.filter !== \"CHECKBOX\" &&\n                                        uniq(values).filter((n) => n != null && n !== \"-\").length > 1)\n                                ) {\n                                    item.disableTooltipIcon = false;\n                                }\n                            }\n                        }\n                    });\n                }\n            });\n        });\n    }\n\n    dataRowClicked(rowData: any) {\n        this.rowClicked.emit(rowData);\n    }\n\n    radioButtonClicked(data: any, action: string, isDisabled: boolean) {\n        if (!isDisabled) {\n            this.radioButtonSelected.emit({ data, action });\n        }\n    }\n\n    bindTheValueToSellerGroupTooltip(sellerGroupHierarchy: RatingSellerGroupHierarchy[], tooltip: any): void {\n        if (this.hierarchyTooltip && this.hierarchyTooltip.open) {\n            this.hierarchyTooltip.close();\n        }\n        this.sellerGroupHierarchy = sellerGroupHierarchy;\n        this.hierarchyTooltip = tooltip;\n        this.hierarchyTooltip.open();\n    }\n\n    iconClicked(rowData: any, iconClass: string) {\n        if (\"orderId\" in rowData && iconClass.includes(\"mdi-star\")) {\n            this.selectedStarredOrderId = rowData.orderId;\n        }\n\n        this.gtIconClicked.emit({ data: rowData, iconClass });\n    }\n\n    svgIconClicked(data: GtColumnIconEmittedData) {\n        this.gtSVGIconClicked.emit(data);\n    }\n\n    textActionClicked(rowData: any, id: any, columnHeader: IHeaderInfo) {\n        this.gtTextActionClicked.emit({ data: rowData, id, columnHeader, isIconClicked: false });\n    }\n\n    iconClickedOnStringIconActionType(rowData: any, id: any, columnHeader: IHeaderInfo) {\n        this.gtTextActionClicked.emit({ data: rowData, id, columnHeader, isIconClicked: true });\n    }\n\n    innerHTMLCellClicked(event: any, rowData: any) {\n        this.gtInnerHTMLClicked.emit({ event, rowData });\n    }\n\n    viewDetailsClicked(rowData: any) {\n        this.gtViewDetailClicked.emit({ data: rowData });\n    }\n\n    setActiveStateObject() {\n        this.annaFilterService.isFilterSortActive =\n            !this.annaFilterService.resetFilterSortActiveStatus || this.multipleTablesPresent\n                ? this.annaFilterService.isFilterSortActive\n                : {};\n        this.tableHeaders.forEach((item) => {\n            item.headerInfo.forEach((header) => {\n                if (header.showTooltipIcon) {\n                    const key = header.filterSortObjectKeys.join(\",\");\n                    header.joinedFilterSortObjectKeys = key;\n                    // ANNA-4113 fix\n                    if (this.annaFilterService.resetFilterSortActiveStatus) {\n                        this.annaFilterService.isFilterSortActive[key] = false;\n                    }\n                }\n            });\n        });\n        this.annaFilterService.resetFilterSortActiveStatus = true;\n    }\n\n    setIsDifference(value: boolean) {\n        this.isDifferenceLessThan25Percent = value;\n    }\n\n    resetIndex() {\n        this.start = 0;\n        this.end = this.limit + this.start;\n    }\n\n    onTableContainerScroll(e: any) {\n        const tableViewHeight = e.target.offsetHeight; // viewport\n        const tableScrollHeight = e.target.scrollHeight; // length of all table\n        const scrollLocation = e.target.scrollTop; // how far user scrolled\n\n        this.removeTooltipOnScroll();\n\n        // If the user has scrolled within 150px of the bottom, add more data\n        const buffer = 150;\n        const limit = tableScrollHeight - tableViewHeight - buffer;\n        if (scrollLocation > limit) {\n            const data = this.getTableData(this.start, this.end);\n            this.renderedData = this.renderedData.concat(data);\n            this.updateIndex();\n        }\n        this.tableContainerScrolled(e);\n    }\n\n    getTableData(start: number, end: number) {\n        return this.tableData?.filter((value, index) => index >= start && index < end);\n    }\n\n    updateIndex() {\n        this.start = this.end;\n        this.end = this.limit + this.start;\n    }\n\n    setInitialRowsForTable() {\n        this.resetIndex();\n        this.renderedData = this.getTableData(this.start, this.end);\n        this.updateIndex();\n    }\n\n    spotDetailsDownloadClicked(parentChildOrTotalRow: \"DATAROW\" | \"TOTALROW\", rowdata?: any) {\n        if (rowdata) {\n            this.selectedInventoryIdForDownload = rowdata.inventoryCodeId;\n            this.selectedDemographicForDownload = rowdata.demographic;\n        } else {\n            this.selectedInventoryIdForDownload = null;\n            this.selectedDemographicForDownload = null;\n        }\n        this.selectedRowTypeForDownload = parentChildOrTotalRow;\n        this.downloadSpotDetails.emit({\n            parentChildOrTotalRow,\n            inventoryCodeId: this.selectedInventoryIdForDownload,\n            demographic: this.selectedDemographicForDownload,\n        });\n    }\n\n    tableContainerScrolled(event: any) {\n        this.isScrolledLeft = event.target.scrollLeft > 0;\n        this.isScrollEnded =\n            Math.round(event.target.scrollLeft) === event.target.scrollWidth - event.target.clientWidth;\n        this.removeTooltipOnScroll();\n    }\n\n    mouseEnterOnStringTextActionType(rowData: any, tooltipKey: string) {\n        this.textActionTooltip = rowData[tooltipKey];\n        this.notificationIconHover.emit({ rowData, type: \"on-enter\" });\n    }\n\n    mouseEnterOnStringTextActionTypeContainingTable(rowData: any, tooltipKey: string) {\n        this.tooltipContainingTable = rowData[tooltipKey];\n    }\n\n    mouseLeaveTextActionType(rowData: any) {\n        this.notificationIconHoverLeave.emit({ rowData, type: \"on-leave\" });\n    }\n\n    mouseEnterOnTextActionType(rowData: any, tooltipKey: string) {\n        this.textActionTooltip = rowData[tooltipKey];\n    }\n\n    onClickableDataClicked(Rowdata: any, id: number) {\n        this.clickableDataClicked.emit({ data: Rowdata, id });\n    }\n\n    removeTooltipOnScroll() {\n        const elements = document.getElementsByClassName(\"remarks-info-tooltip\");\n        // const tooltipElements = document.getElementsByClassName(\"tooltip\");\n        const gtTooltip = document.getElementsByClassName(\"remove-on-scroll-class\");\n        document.querySelectorAll(\".tooltip:not(.keep-on-scroll-tooltip)\").forEach((e) => {\n            e.remove();\n            this.tooltip = null;\n        });\n\n        while (elements && elements.length > 0) {\n            elements[0].remove();\n        }\n        while (gtTooltip && gtTooltip.length > 0) {\n            gtTooltip[0].remove();\n        }\n    }\n\n    iconClickedInTotalRow(colName: string) {\n        this.totalRowIconClicked.emit(colName);\n    }\n\n    changesMadeInEditableInputBox(event: any, editedObject: any, pasteEvent: boolean) {\n        const enteredValue = pasteEvent ? event.clipboardData.getData(\"text\") : event.key;\n        const dotIndex = editedObject.value.indexOf(\".\");\n\n        if (\n            event.keyCode !== 8 &&\n            event.keyCode !== 46 &&\n            !(event.keyCode >= 37 && event.keyCode <= 40) &&\n            ((!editedObject?.allowSpecialCharacters && !/[`0-9.]/.test(enteredValue)) ||\n                (editedObject?.charactersToRestrict && editedObject?.charactersToRestrict.includes(enteredValue)) ||\n                (editedObject.isDecimalPointCheckRequired &&\n                    dotIndex >= 0 &&\n                    event?.target?.selectionStart > dotIndex &&\n                    editedObject.value.length - (dotIndex + 1) >= editedObject.maxDecimalPointsAllowed))\n        ) {\n            event.preventDefault();\n        }\n    }\n\n    editableInputValueChanged(value: any, row: any, keyEdited: string) {\n        this.editableInputEdited.emit({ row, value, keyEdited });\n    }\n\n    radioButtonIconClicked(data: any) {\n        this.radioButtonMessageIconClicked.emit(data);\n    }\n\n    filterApplied(tableData: any[]) {\n        this.tableData = tableData;\n        this.setInitialRowsForTable();\n        this.disableEnableEachColumnTooltipIcon();\n        this.filterAppliedToTable.emit(tableData);\n        this.closeTooltip();\n    }\n\n    sortingApplied(tableData: any[]) {\n        this.tableData = tableData;\n        this.setInitialRowsForTable();\n        this.disableEnableEachColumnTooltipIcon();\n        this.sortingAppliedToTable.emit(tableData);\n        this.closeTooltip();\n    }\n}\n","<div\n    id=\"generic-table-conatiner\"\n    #tableElementRef\n    class=\"table-container {{ gtGeneralConfig?.tableOuterContainerName }} {{ tableBottomBorderClass }}\"\n    [ngClass]=\"{\n        'scroll-left-shadow-effect': isScrolledLeft,\n        'scroll-right-shadow-effect': !isScrollEnded,\n        'clickable-row': clickableRow,\n        'no-data-table': (isNoDataToDisplaySubject$ | async),\n        'table-with-show-hide-total-row-toggle': showOrHideToggleForTotalRow\n    }\"\n    (scroll)=\"onTableContainerScroll($event)\"\n>\n    <div\n        [class]=\"gtGeneralConfig.tableContainerName\"\n        class=\"horizontal-scroll-for-table-container\"\n        [ngStyle]=\"{\n            height:\n                tableData.length < maximumRowsWhichCanBeRenderedWithoutScroll\n                    ? 'calc(' +\n                      (gtDimension.rowHeight * tableData.length +\n                          (!tableData.length || !gtGeneralConfig.totalRow\n                              ? gtDimension.headerHeight\n                              : gtDimension.headerHeight + gtDimension.rowHeight)) +\n                      'px)'\n                    : gtDimension.tableHeight\n        }\"\n    >\n        <button\n            *ngIf=\"showOrHideToggleForTotalRow && !showSkeletonLoading && (isNoDataToDisplaySubject$ | async) === false\"\n            [ngClass]=\"{\n                'shift-toggle-top-on-total-row-click': !gtGeneralConfig.totalRow\n            }\"\n            class=\"show-or-hide-toggle-btn\"\n            (click)=\"showHideTotalRow()\"\n        >\n            <i\n                class=\"mdi mdi-menu-swap\"\n                tooltipClass=\"show-or-hide-toggle-tooltip\"\n                placement=\"auto\"\n                container=\"body\"\n                [ngbTooltip]=\"showOrHideToggleForTotalRowTooltip\"\n            ></i>\n        </button>\n        <table\n            class=\"gt\"\n            [ngClass]=\"tableClass\"\n        >\n            <thead>\n                <tr\n                    class=\"header-row\"\n                    mat-header-row\n                    [style.height.px]=\"gtDimension.headerHeight\"\n                >\n                    <ng-container *ngFor=\"let columnDef of tableHeaders; trackBy: trackByFn\">\n                        <th\n                            #tableHeader\n                            nowrap\n                            [style.width]=\"columnDef.width\"\n                        >\n                            <div\n                                class=\"row mx-0\"\n                                *ngFor=\"let header of columnDef.headerInfo; let j = index\"\n                            >\n                                <p\n                                    *ngIf=\"header.typeOfHeaderData === 'STRING'\"\n                                    [ngClass]=\"{ 'upper-label': j === 0, 'lower-label': j === 1 }\"\n                                >\n                                    <ngx-skeleton-loader\n                                        *ngIf=\"header.name == null\"\n                                        count=\"1\"\n                                        [theme]=\"{\n                                            height: '10px',\n                                            display: 'block',\n                                            width: columnDef.width,\n                                            'max-width': 'calc(100% - 20px)'\n                                        }\"\n                                    >\n                                    </ngx-skeleton-loader>\n                                    <ng-container *ngIf=\"header.name\">\n                                        {{ header.name }}\n                                    </ng-container>\n                                    <ng-container *ngIf=\"header.tooltip && header.tooltip.tooltipMessage\">\n                                        <i\n                                            class=\"{{ header['tooltip'].iconClass }}\"\n                                            [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n                                            #t=\"ngbTooltip\"\n                                            container=\"body\"\n                                            [ngbTooltip]=\"header.tooltip.tooltipMessage\"\n                                            container=\"body\"\n                                            placement=\"{{ header['tooltip'].tooltipPosition }}\"\n                                            tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n                                        >\n                                        </i>\n                                    </ng-container>\n                                    <i\n                                        *ngIf=\"header.tooltip && header.tooltip.name === 'impsInfoTooltip'\"\n                                        class=\"{{ header['tooltip'].iconClass }}\"\n                                        [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n                                        #t=\"ngbTooltip\"\n                                        container=\"body\"\n                                        [ngbTooltip]=\"impsInfoTooltip\"\n                                        container=\"body\"\n                                        placement=\"{{ header['tooltip'].tooltipPosition }}\"\n                                        tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n                                    >\n                                    </i>\n                                    <i\n                                        *ngIf=\"\n                                            header.tooltip &&\n                                            header.tooltip.name === 'spotsColumnEquivalizationMessageTooltip'\n                                        \"\n                                        class=\"{{ header['tooltip'].iconClass }}\"\n                                        [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n                                        container=\"body\"\n                                        #t=\"ngbTooltip\"\n                                        container=\"body\"\n                                        [ngbTooltip]=\"spotsColumnEquivalizationMessageTooltip\"\n                                        placement=\"{{ header['tooltip'].tooltipPosition }}\"\n                                        tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n                                    >\n                                    </i>\n                                    <i\n                                        *ngIf=\"header.tooltip && header.tooltip.name === 'underDeliveryTooltip'\"\n                                        class=\"{{ header['tooltip'].iconClass }}\"\n                                        [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n                                        container=\"body\"\n                                        #t=\"ngbTooltip\"\n                                        container=\"body\"\n                                        [ngbTooltip]=\"underDeliveryTooltip\"\n                                        placement=\"{{ header['tooltip'].tooltipPosition }}\"\n                                        tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n                                    >\n                                    </i>\n                                    <i\n                                        *ngIf=\"header.tooltip && header.tooltip.name === 'overDeliveryTooltip'\"\n                                        class=\"{{ header['tooltip'].iconClass }}\"\n                                        [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n                                        container=\"body\"\n                                        #t=\"ngbTooltip\"\n                                        container=\"body\"\n                                        [ngbTooltip]=\"overDeliveryTooltip\"\n                                        placement=\"{{ header['tooltip'].tooltipPosition }}\"\n                                        tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n                                    >\n                                    </i>\n                                    <i\n                                        *ngIf=\"header.tooltip && header.tooltip.name === 'ratingInfoTooltip'\"\n                                        class=\"{{ header['tooltip'].iconClass }}\"\n                                        [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n                                        #t=\"ngbTooltip\"\n                                        container=\"body\"\n                                        [ngbTooltip]=\"ratingInfoTooltip\"\n                                        container=\"body\"\n                                        placement=\"{{ header['tooltip'].tooltipPosition }}\"\n                                        tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n                                    >\n                                    </i>\n                                    <i\n                                        *ngIf=\"header.tooltip && header.tooltip.name === 'rateInfoTooltip'\"\n                                        class=\"{{ header['tooltip'].iconClass }}\"\n                                        [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n                                        #t=\"ngbTooltip\"\n                                        container=\"body\"\n                                        [ngbTooltip]=\"rateInfoTooltip\"\n                                        container=\"body\"\n                                        placement=\"{{ header['tooltip'].tooltipPosition }}\"\n                                        tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n                                    >\n                                    </i>\n                                    <i\n                                        *ngIf=\"\n                                            header.tooltip && header.tooltip.name === 'ongoingRevBookedColumnTooltip'\n                                        \"\n                                        class=\"{{ header['tooltip'].iconClass }}\"\n                                        [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n                                        #t=\"ngbTooltip\"\n                                        container=\"body\"\n                                        [ngbTooltip]=\"ongoingRevBookedColumnTooltip\"\n                                        placement=\"{{ header['tooltip'].tooltipPosition }}\"\n                                        tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n                                    >\n                                    </i>\n                                    <i\n                                        *ngIf=\"\n                                            header.tooltip && header.tooltip.name === 'completedRevBookedColumnTooltip'\n                                        \"\n                                        class=\"{{ header['tooltip'].iconClass }}\"\n                                        [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n                                        #t=\"ngbTooltip\"\n                                        container=\"body\"\n                                        [ngbTooltip]=\"completedRevBookedColumnTooltip\"\n                                        placement=\"{{ header['tooltip'].tooltipPosition }}\"\n                                        tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n                                    >\n                                    </i>\n                                    <i\n                                        *ngIf=\"header.tooltip && header.tooltip.name === 'avgBookedRate'\"\n                                        class=\"{{ header['tooltip'].iconClass }}\"\n                                        [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n                                        #t=\"ngbTooltip\"\n                                        container=\"body\"\n                                        [ngbTooltip]=\"avgBookedRate\"\n                                        placement=\"{{ header['tooltip'].tooltipPosition }}\"\n                                        tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n                                    >\n                                    </i>\n                                    <i\n                                        *ngIf=\"header.tooltip && header.tooltip.name === 'avgBookedRtg'\"\n                                        class=\"{{ header['tooltip'].iconClass }}\"\n                                        [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n                                        #t=\"ngbTooltip\"\n                                        container=\"body\"\n                                        [ngbTooltip]=\"avgBookedRtg\"\n                                        placement=\"{{ header['tooltip'].tooltipPosition }}\"\n                                        tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n                                    >\n                                    </i>\n                                    <i\n                                        *ngIf=\"header.tooltip && header.tooltip.name === 'avgBookedImps'\"\n                                        class=\"{{ header['tooltip'].iconClass }}\"\n                                        [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n                                        #t=\"ngbTooltip\"\n                                        container=\"body\"\n                                        [ngbTooltip]=\"avgBookedImps\"\n                                        placement=\"{{ header['tooltip'].tooltipPosition }}\"\n                                        tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n                                    >\n                                    </i>\n\n                                    <i\n                                        *ngIf=\"header.tooltip && header.tooltip.name === 'automationTooltip'\"\n                                        class=\"{{ header['tooltip'].iconClass }}\"\n                                        [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n                                        #t=\"ngbTooltip\"\n                                        container=\"body\"\n                                        [ngbTooltip]=\"automationTooltip\"\n                                        placement=\"{{ header['tooltip'].tooltipPosition }}\"\n                                        tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n                                    >\n                                    </i>\n\n                                    <i\n                                        *ngIf=\"header.tooltip && header.tooltip.name === 'rebateImpact'\"\n                                        class=\"{{ header['tooltip'].iconClass }}\"\n                                        [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n                                        #t=\"ngbTooltip\"\n                                        container=\"body\"\n                                        [ngbTooltip]=\"rebateImpact\"\n                                        placement=\"{{ header['tooltip'].tooltipPosition }}\"\n                                        tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n                                    >\n                                    </i>\n\n                                    <i\n                                        *ngIf=\"header.tooltip && header.tooltip.name === 'projectedImpsRtg'\"\n                                        class=\"{{ header['tooltip'].iconClass }}\"\n                                        [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n                                        #t=\"ngbTooltip\"\n                                        container=\"body\"\n                                        [ngbTooltip]=\"projectedImpsRtg\"\n                                        placement=\"{{ header['tooltip'].tooltipPosition }}\"\n                                        tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n                                    >\n                                    </i>\n                                </p>\n\n                                <ng-container *ngIf=\"header.typeOfHeaderData === 'CHECKBOX'\">\n                                    <span\n                                        *ngIf=\"gtGeneralConfig.isHeaderChecked\"\n                                        class=\"material-icons custom-column-checkbox-checked\"\n                                        (click)=\"selectUnselectAllRows()\"\n                                    >\n                                        check_box\n                                    </span>\n                                    <span\n                                        *ngIf=\"!gtGeneralConfig.isHeaderChecked\"\n                                        class=\"material-icons custom-column-checkbox-unchecked\"\n                                        [ngClass]=\"{ 'disable-checkbox': gtGeneralConfig.disableHeaderCheckbox }\"\n                                        (click)=\"selectUnselectAllRows()\"\n                                    >\n                                        check_box_outline_blank\n                                    </span>\n                                </ng-container>\n\n                                <div\n                                    *ngIf=\"gtGeneralConfig.showAllColumnFilter\"\n                                    class=\"sort-filter-container\"\n                                >\n                                    <ng-container *ngIf=\"header.showTooltipIcon\">\n                                        <!-- Active tooltip Functionality -->\n                                        <ng-container *ngIf=\"header.filter === 'CHECKBOX'\">\n                                            <span\n                                                class=\"mdi mdi-filter-variant\"\n                                                [ngClass]=\"{\n                                                    active:\n                                                        annaFilterService.isFilterSortActive &&\n                                                        annaFilterService.isFilterSortActive[\n                                                            header.joinedFilterSortObjectKeys\n                                                        ],\n                                                    disabled: header.disableTooltipIcon || showSkeletonLoading\n                                                }\"\n                                                [ngbTooltip]=\"filterTooltip\"\n                                                placement=\"{{ filterAlignment }}\"\n                                                container=\"body\"\n                                                tooltipClass=\"non-edit-checkbox-tooltip\"\n                                                [autoClose]=\"'outside'\"\n                                                triggers=\"manual\"\n                                                #t=\"ngbTooltip\"\n                                                (click)=\"bindTheValueToToolTip(t, header)\"\n                                                (hidden)=\"closeTooltip()\"\n                                            >\n                                            </span\n                                            ><br />\n                                        </ng-container>\n                                        <ng-container *ngIf=\"header.filter === 'SLIDER'\">\n                                            <span\n                                                class=\"mdi mdi-filter-variant\"\n                                                [ngClass]=\"{\n                                                    active:\n                                                        annaFilterService.isFilterSortActive &&\n                                                        annaFilterService.isFilterSortActive[\n                                                            header.joinedFilterSortObjectKeys\n                                                        ],\n                                                    disabled: header.disableTooltipIcon || showSkeletonLoading\n                                                }\"\n                                                [ngbTooltip]=\"sliderToolTip\"\n                                                placement=\"bottom left-top\"\n                                                container=\"body\"\n                                                tooltipClass=\"non-edit-slider-tooltip\"\n                                                [autoClose]=\"'outside'\"\n                                                triggers=\"manual\"\n                                                #t1=\"ngbTooltip\"\n                                                (click)=\"bindTheValueToToolTip(t1, header)\"\n                                                (hidden)=\"closeTooltip()\"\n                                            >\n                                            </span\n                                            ><br />\n                                        </ng-container>\n                                        <ng-container *ngIf=\"header.filter === 'DATE'\">\n                                            <span\n                                                class=\"mdi mdi-filter-variant\"\n                                                [ngClass]=\"{\n                                                    active:\n                                                        annaFilterService.isFilterSortActive &&\n                                                        annaFilterService.isFilterSortActive[\n                                                            header.joinedFilterSortObjectKeys\n                                                        ],\n                                                    disabled: header.disableTooltipIcon || showSkeletonLoading\n                                                }\"\n                                                [ngbTooltip]=\"datePickerTooltip\"\n                                                placement=\"bottom auto\"\n                                                container=\"body\"\n                                                tooltipClass=\"non-edit-datepicker-tooltip\"\n                                                [autoClose]=\"'outside'\"\n                                                triggers=\"manual\"\n                                                #t2=\"ngbTooltip\"\n                                                (click)=\"bindTheValueToToolTip(t2, header)\"\n                                                (hidden)=\"closeTooltip()\"\n                                            >\n                                            </span\n                                            ><br />\n                                        </ng-container>\n                                        <ng-container *ngIf=\"header.filter === 'WEEK'\">\n                                            <span\n                                                class=\"mdi mdi-filter-variant\"\n                                                [ngClass]=\"{\n                                                    active:\n                                                        annaFilterService.isFilterSortActive &&\n                                                        annaFilterService.isFilterSortActive[\n                                                            header.joinedFilterSortObjectKeys\n                                                        ],\n                                                    disabled: header.disableTooltipIcon || showSkeletonLoading\n                                                }\"\n                                                [ngbTooltip]=\"weekPickerToolTip\"\n                                                placement=\"bottom left-top\"\n                                                container=\"body\"\n                                                [autoClose]=\"'outside'\"\n                                                triggers=\"manual\"\n                                                #t3=\"ngbTooltip\"\n                                                (click)=\"bindTheValueToToolTip(t3, header)\"\n                                                (hidden)=\"closeTooltip()\"\n                                            >\n                                            </span\n                                            ><br />\n                                        </ng-container>\n                                        <ng-container *ngIf=\"header.filter === 'TIME'\">\n                                            <span\n                                                class=\"mdi mdi-filter-variant\"\n                                                [ngClass]=\"{\n                                                    active:\n                                                        annaFilterService.isFilterSortActive &&\n                                                        annaFilterService.isFilterSortActive[\n                                                            header.joinedFilterSortObjectKeys\n                                                        ],\n                                                    disabled: header.disableTooltipIcon || showSkeletonLoading\n                                                }\"\n                                                [ngbTooltip]=\"timeFilterToolTip\"\n                                                placement=\"bottom left-top auto\"\n                                                container=\"body\"\n                                                tooltipClass=\"non-edit-time-tooltip\"\n                                                [autoClose]=\"'outside'\"\n                                                triggers=\"manual\"\n                                                #t4=\"ngbTooltip\"\n                                                (click)=\"bindTheValueToToolTip(t4, header)\"\n                                                (hidden)=\"closeTooltip()\"\n                                            >\n                                            </span\n                                            ><br />\n                                        </ng-container>\n                                    </ng-container>\n                                    <ng-container *ngIf=\"!header.showTooltipIcon\">\n                                        <span id=\"no-filter-space\"></span><br />\n                                    </ng-container>\n                                    <i\n                                        *ngIf=\"header.tooltip && header.tooltip.name === 'lurViolationInfoTooltip'\"\n                                        class=\"{{ header['tooltip'].iconClass }}\"\n                                        [ngStyle]=\"{ float: header['tooltip'].iconPosition }\"\n                                        #t=\"ngbTooltip\"\n                                        container=\"body\"\n                                        [ngbTooltip]=\"lurViolationInfoTooltip\"\n                                        placement=\"{{ header['tooltip'].tooltipPosition }}\"\n                                        tooltipClass=\"{{ header['tooltip'].tooltipClass }}\"\n                                    >\n                                    </i>\n                                </div>\n                            </div>\n                        </th>\n                    </ng-container>\n                </tr>\n                <tr\n                    class=\"total-row\"\n                    [style.height.px]=\"gtDimension.rowHeight\"\n                    *ngIf=\"\n                        !showSkeletonLoading &&\n                        tableData.length > 0 &&\n                        gtGeneralConfig.totalRow &&\n                        (isNoDataToDisplaySubject$ | async) === false\n                    \"\n                >\n                    <ng-container *ngFor=\"let column of totalRowInfo; trackBy: trackByFn\">\n                        <td\n                            [attr.colspan]=\"column.colspan\"\n                            class=\"{{ column.class }}\"\n                        >\n                            <ng-container *ngIf=\"column['isActionColumn']\">\n                                <a\n                                    *ngFor=\"let data of column.actionData\"\n                                    [class]=\"data.class\"\n                                    (click)=\"onClickableDataClicked({}, data.id)\"\n                                >\n                                    {{ data.name }}\n                                </a>\n                            </ng-container>\n\n                            <ng-container *ngIf=\"column['isIconColumn']\">\n                                <i\n                                    class=\"{{ column?.iconData?.class }}\"\n                                    (click)=\"iconClickedInTotalRow(column?.colName)\"\n                                >\n                                </i>\n                            </ng-container>\n\n                            <ng-container *ngIf=\"!column['isActionColumn']\">\n                                <strong class=\"upper-label\"\n                                    >{{ column.data }}\n                                    <span\n                                        class=\"red-text-totol-row\"\n                                        *ngIf=\"column.additionalRedTextAfterData\"\n                                        >{{ column.additionalRedTextAfterData }}</span\n                                    ></strong\n                                >\n                                <ng-container *ngIf=\"column.lowerData\">\n                                    <br />\n                                    <span\n                                        *ngIf=\"\n                                            column.colName === 'total-potential-booked-unit' &&\n                                                gtGeneralConfig.component === 'RATING';\n                                            else columnLowerData\n                                        \"\n                                        class=\"clickable-data\"\n                                        (click)=\"spotDetailsDownloadClicked('TOTALROW')\"\n                                        [ngClass]=\"{ 'disabled-clickable-data': downloadInProgress }\"\n                                        >{{ column.lowerData }}\n                                        <span class=\"material-icons spot-details-download-icons\">get_app</span>\n                                        <ng-container\n                                            *ngIf=\"downloadInProgress && selectedRowTypeForDownload === 'TOTALROW'\"\n                                        >\n                                            <ng-container [ngTemplateOutlet]=\"circularProgressBar\"></ng-container>\n                                        </ng-container>\n                                    </span>\n                                    <ng-template #columnLowerData>\n                                        <span class=\"lower-label\">{{ column.lowerData }}</span>\n                                    </ng-template>\n                                </ng-container>\n                                <ng-container\n                                    *ngIf=\"column.tooltipMessage && gtGeneralConfig.component !== 'LUR_VIOLATIONS'\"\n                                >\n                                    <i\n                                        class=\"{{ column.tooltipIconClass }}\"\n                                        container=\"body\"\n                                        [ngbTooltip]=\"column.tooltipMessage\"\n                                        tooltipClass=\"gt-total-row-tooltip\"\n                                        placement=\"top bottom\"\n                                    ></i>\n                                </ng-container>\n                                <ng-container\n                                    *ngIf=\"gtGeneralConfig.component === 'LUR_VIOLATIONS' && column.tooltipMessage\"\n                                >\n                                    <i\n                                        class=\"mi mdi-info-outline info-label\"\n                                        container=\"body\"\n                                        [ngbTooltip]=\"lurViolationTotalRowToolTip\"\n                                        tooltipClass=\"gt-total-row-tooltip\"\n                                        placement=\"bottom\"\n                                    ></i>\n                                </ng-container>\n                            </ng-container>\n                        </td>\n                    </ng-container>\n                </tr>\n            </thead>\n            <tbody>\n                <tr\n                    [class]=\"ROW_DATA.gtClass\"\n                    [ngClass]=\"{ 'no-border-tr': (isNoDataToDisplaySubject$ | async) }\"\n                    [style.height.px]=\"gtDimension.rowHeight\"\n                    (click)=\"dataRowClicked(ROW_DATA)\"\n                    *ngFor=\"let ROW_DATA of renderedData; trackBy: trackByFn\"\n                >\n                    <ng-container *ngFor=\"let columnDef of tableHeaders; trackBy: trackByFn\">\n                        <td\n                            [style.background]=\"ROW_DATA.backgroundColor\"\n                            [style.border]=\"ROW_DATA.border\"\n                            class=\"{{ ROW_DATA.rowClass }}\"\n                            [ngClass]=\"ROW_DATA[columnDef.headerInfo[0].objectKey + 'TdClass']\"\n                            [attr.rowspan]=\"ROW_DATA[columnDef.headerInfo[0].objectKey + 'Rowspan']\"\n                            *ngIf=\"\n                                !hideSomeTds ||\n                                (hideSomeTds && !ROW_DATA['hide' + columnDef.headerInfo[0].objectKey + 'Td'])\n                            \"\n                        >\n                            <ngx-skeleton-loader\n                                *ngIf=\"showSkeletonLoading\"\n                                count=\"1\"\n                                [theme]=\"{ height: '10px', display: 'block' }\"\n                            >\n                            </ngx-skeleton-loader>\n\n                            <ng-container *ngIf=\"!showSkeletonLoading\">\n                                <ng-container\n                                    *ngIf=\"tableData.length > 0 && (isNoDataToDisplaySubject$ | async) === false\"\n                                >\n                                    <ng-container\n                                        *ngFor=\"\n                                            let subline of columnDef.headerInfo;\n                                            let subLineIndex = index;\n                                            trackBy: trackByFn\n                                        \"\n                                    >\n                                        <div annaCoreShowEllipsisTextOnHover>\n                                            <ng-container\n                                                [ngSwitch]=\"columnDef.headerInfo[subLineIndex].typeOfBodyData\"\n                                            >\n                                                <ng-container *ngSwitchCase=\"'ICON'\">\n                                                    <i\n                                                        *ngIf=\"\n                                                            !(\n                                                                starredInProgress &&\n                                                                ROW_DATA.orderId === selectedStarredOrderId\n                                                            )\n                                                        \"\n                                                        [class]=\"ROW_DATA.iconClass\"\n                                                        (click)=\"iconClicked(ROW_DATA, ROW_DATA.iconClass)\"\n                                                        ngbTooltip=\"{{ ROW_DATA.iconTitleText }}\"\n                                                        placement=\"bottom\"\n                                                        container=\"body\"\n                                                        tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\n                                                    ></i>\n                                                    <ng-container\n                                                        *ngIf=\"\n                                                            starredInProgress &&\n                                                            ROW_DATA.orderId === selectedStarredOrderId\n                                                        \"\n                                                    >\n                                                        <div class=\"spinner-for-button-directive\"></div>\n                                                    </ng-container>\n                                                </ng-container>\n\n                                                <ng-container *ngSwitchCase=\"'ICON_CELL'\">\n                                                    <ng-container\n                                                        *ngFor=\"\n                                                            let action of ROW_DATA[\n                                                                columnDef.headerInfo[subLineIndex].actionKey\n                                                            ]\n                                                        \"\n                                                    >\n                                                        <ng-container *ngIf=\"action.showObjectKey\">\n                                                            {{ ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey] }}\n                                                        </ng-container>\n\n                                                        <i\n                                                            *ngIf=\"action.showIcon\"\n                                                            [class]=\"action.iconClass\"\n                                                            (mouseenter)=\"\n                                                                mouseEnterOnStringTextActionType(\n                                                                    ROW_DATA,\n                                                                    columnDef.headerInfo[subLineIndex].tooltipKey\n                                                                )\n                                                            \"\n                                                            placement=\"bottom auto\"\n                                                            container=\"body\"\n                                                            [autoClose]=\"true\"\n                                                            tooltipClass=\"team-user-tooltip remove-on-scroll-class\"\n                                                            [ngbTooltip]=\"\n                                                                action.showTooltip ? action.tooltipData : null\n                                                            \"\n                                                            (click)=\"\n                                                                textActionClicked(\n                                                                    ROW_DATA,\n                                                                    action.id,\n                                                                    columnDef.headerInfo[subLineIndex]\n                                                                )\n                                                            \"\n                                                            [disableTooltip]=\"!action.showTooltip\"\n                                                        >\n                                                        </i>\n                                                    </ng-container>\n                                                </ng-container>\n\n                                                <ng-container *ngSwitchCase=\"'HTML_STRING'\">\n                                                    <p\n                                                        [innerHTML]=\"\n                                                            ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n                                                        \"\n                                                        (click)=\"innerHTMLCellClicked($event, ROW_DATA)\"\n                                                    ></p>\n                                                </ng-container>\n\n                                                <ng-container *ngSwitchCase=\"'SVG_ICON'\">\n                                                    <anna-core-icon-column\n                                                        [componentName]=\"gtGeneralConfig.component\"\n                                                        [dataObject]=\"ROW_DATA\"\n                                                        [iconToShow]=\"\n                                                            ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n                                                        \"\n                                                        (columnIconClicked)=\"svgIconClicked($event)\"\n                                                    ></anna-core-icon-column>\n                                                </ng-container>\n\n                                                <ng-container *ngSwitchCase=\"'TEXT_ACTIONS'\">\n                                                    <ng-container\n                                                        *ngFor=\"\n                                                            let text of ROW_DATA[\n                                                                columnDef.headerInfo[subLineIndex].actionKey\n                                                            ]\n                                                        \"\n                                                    >\n                                                        <button\n                                                            *ngIf=\"text.showTooltip\"\n                                                            (click)=\"\n                                                                textActionClicked(\n                                                                    ROW_DATA,\n                                                                    text.id,\n                                                                    columnDef.headerInfo[subLineIndex]\n                                                                )\n                                                            \"\n                                                            [disabled]=\"text.isDisabled\"\n                                                            class=\"{{ text.class }}\"\n                                                            (mouseenter)=\"\n                                                                mouseEnterOnTextActionType(\n                                                                    ROW_DATA,\n                                                                    columnDef.headerInfo[subLineIndex].tooltipKey\n                                                                )\n                                                            \"\n                                                            [ngbTooltip]=\"textActionTooltipTemplate\"\n                                                            placement=\"auto\"\n                                                            container=\"body\"\n                                                            tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\n                                                        >\n                                                            {{ text.name }}\n                                                        </button>\n\n                                                        <button\n                                                            *ngIf=\"!text.showTooltip\"\n                                                            (click)=\"\n                                                                textActionClicked(\n                                                                    ROW_DATA,\n                                                                    text.id,\n                                                                    columnDef.headerInfo[subLineIndex]\n                                                                )\n                                                            \"\n                                                            [disabled]=\"text.isDisabled\"\n                                                            class=\"{{ text.class }}\"\n                                                        >\n                                                            {{ text.name }}\n                                                        </button>\n                                                    </ng-container>\n                                                </ng-container>\n\n                                                <ng-container *ngSwitchCase=\"'CHECKBOX'\">\n                                                    <span\n                                                        *ngIf=\"ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\n                                                        [ngClass]=\"{\n                                                            'disable-checkbox':\n                                                                ROW_DATA[\n                                                                    columnDef.headerInfo[subLineIndex].isDisabledKey\n                                                                ]\n                                                        }\"\n                                                        class=\"material-icons custom-column-checkbox-checked\"\n                                                        (click)=\"\n                                                            selectOrUnselectCheckbox(\n                                                                ROW_DATA,\n                                                                columnDef.headerInfo[subLineIndex].objectKey,\n                                                                false\n                                                            )\n                                                        \"\n                                                    >\n                                                        check_box\n                                                    </span>\n                                                    <span\n                                                        *ngIf=\"!ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\n                                                        class=\"material-icons custom-column-checkbox-unchecked\"\n                                                        [ngClass]=\"{\n                                                            'disable-checkbox':\n                                                                ROW_DATA[\n                                                                    columnDef.headerInfo[subLineIndex].isDisabledKey\n                                                                ]\n                                                        }\"\n                                                        (click)=\"\n                                                            selectOrUnselectCheckbox(\n                                                                ROW_DATA,\n                                                                columnDef.headerInfo[subLineIndex].objectKey,\n                                                                true\n                                                            )\n                                                        \"\n                                                    >\n                                                        check_box_outline_blank\n                                                    </span>\n\n                                                    <ng-container\n                                                        *ngFor=\"\n                                                            let action of ROW_DATA[\n                                                                columnDef.headerInfo[subLineIndex].actionKey\n                                                            ]\n                                                        \"\n                                                    >\n                                                        <i\n                                                            *ngIf=\"action.showIcon\"\n                                                            [class]=\"action.iconClass\"\n                                                            [ngClass]=\"{ disabled: action.disabledIcon }\"\n                                                            (mouseenter)=\"\n                                                                mouseEnterOnStringTextActionTypeContainingTable(\n                                                                    ROW_DATA,\n                                                                    columnDef.headerInfo[subLineIndex].tooltipKey\n                                                                )\n                                                            \"\n                                                            placement=\"bottom auto\"\n                                                            container=\"body\"\n                                                            [autoClose]=\"true\"\n                                                            tooltipClass=\"tooltip-containing-table remove-on-scroll-class\"\n                                                            [ngbTooltip]=\"tooltipContainingTableTemplate\"\n                                                        >\n                                                        </i>\n                                                    </ng-container>\n                                                </ng-container>\n\n                                                <ng-container *ngSwitchCase=\"'CLICKABLE_DATA'\">\n                                                    <a\n                                                        *ngFor=\"\n                                                            let text of ROW_DATA[\n                                                                columnDef.headerInfo[subLineIndex].actionKey\n                                                            ]\n                                                        \"\n                                                        [class]=\"text.class\"\n                                                        (click)=\"onClickableDataClicked(ROW_DATA, text.id)\"\n                                                    >\n                                                        {{ text.name }}\n                                                    </a>\n                                                    <span\n                                                        *ngIf=\"\n                                                            subline.objectKey === 'displayBookedUnits' &&\n                                                            gtGeneralConfig.component === 'RATING'\n                                                        \"\n                                                        class=\"clickable-data\"\n                                                        (click)=\"spotDetailsDownloadClicked('DATAROW', ROW_DATA)\"\n                                                        [ngClass]=\"{ 'disabled-clickable-data': downloadInProgress }\"\n                                                        >{{ ROW_DATA.displayBookedUnits }}\n                                                        <span class=\"material-icons spot-details-download-icons\"\n                                                            >get_app</span\n                                                        >\n                                                        <ng-container\n                                                            *ngIf=\"\n                                                                downloadInProgress &&\n                                                                ROW_DATA.inventoryCodeId ===\n                                                                    selectedInventoryIdForDownload &&\n                                                                ROW_DATA.demographic === selectedDemographicForDownload\n                                                            \"\n                                                        >\n                                                            <ng-container\n                                                                [ngTemplateOutlet]=\"circularProgressBar\"\n                                                            ></ng-container>\n                                                        </ng-container>\n                                                    </span>\n                                                </ng-container>\n\n                                                <ng-container *ngSwitchCase=\"'STRING___ICON_OR_TEXT_ACTION'\">\n                                                    <ng-container\n                                                        *ngFor=\"\n                                                            let action of ROW_DATA[\n                                                                columnDef.headerInfo[subLineIndex].actionKey\n                                                            ]\n                                                        \"\n                                                    >\n                                                        <span\n                                                            [class]=\"action.additionalTextBeforeLinkClass\"\n                                                            [innerHtml]=\"action.additionalTextBeforeLink\"\n                                                            ngbTooltip=\"{{ action.additionalTextBeforeLink }}\"\n                                                            placement=\"bottom\"\n                                                            container=\"body\"\n                                                            tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\n                                                            [disableTooltip]=\"!action.enableTooltipForAdditionalText\"\n                                                        ></span>\n\n                                                        <ng-container *ngIf=\"action && action.typeOfData === 'STRING'\">\n                                                            {{ action.data }}\n                                                        </ng-container>\n\n                                                        <a\n                                                            [id]=\"action.id\"\n                                                            *ngIf=\"action.showLink\"\n                                                            (click)=\"\n                                                                textActionClicked(\n                                                                    ROW_DATA,\n                                                                    action.id,\n                                                                    columnDef.headerInfo[subLineIndex]\n                                                                )\n                                                            \"\n                                                            [class]=\"action.linkClass\"\n                                                            [ngClass]=\"{ disabled: action.disabledLink }\"\n                                                            >{{ action.data }}</a\n                                                        >\n                                                        <span\n                                                            ngbTooltip=\"{{ action.additionalTextAfterLink }}\"\n                                                            placement=\"bottom\"\n                                                            container=\"body\"\n                                                            [class]=\"action.additionalTextAfterLinkClass\"\n                                                            tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\n                                                            [disableTooltip]=\"\n                                                                !action.enableTooltipForAdditionalAfterText\n                                                            \"\n                                                        >\n                                                            {{ action.additionalTextAfterLink }}\n                                                        </span>\n\n                                                        <ng-container *ngIf=\"action.showTooltip\">\n                                                            <ng-container *ngIf=\"action.tooltipData.innerHtml\">\n                                                                <i\n                                                                    *ngIf=\"action.showIcon\"\n                                                                    [class]=\"action.iconClass\"\n                                                                    [ngClass]=\"{ disabled: action.disabledIcon }\"\n                                                                    (mouseenter)=\"\n                                                                        mouseEnterOnStringTextActionTypeContainingTable(\n                                                                            ROW_DATA,\n                                                                            columnDef.headerInfo[subLineIndex]\n                                                                                .tooltipKey\n                                                                        )\n                                                                    \"\n                                                                    placement=\"bottom auto\"\n                                                                    container=\"body\"\n                                                                    [autoClose]=\"true\"\n                                                                    tooltipClass=\"tooltip-containing-table remove-on-scroll-class\"\n                                                                    [ngbTooltip]=\"tooltipContainingTableTemplate\"\n                                                                >\n                                                                </i>\n                                                            </ng-container>\n\n                                                            <ng-container *ngIf=\"!action.tooltipData.tooltipTableBody\">\n                                                                <i\n                                                                    *ngIf=\"action.showIcon\"\n                                                                    [class]=\"action.iconClass\"\n                                                                    [ngClass]=\"{ disabled: action.disabledIcon }\"\n                                                                    (click)=\"\n                                                                        iconClickedOnStringIconActionType(\n                                                                            ROW_DATA,\n                                                                            action.id,\n                                                                            columnDef.headerInfo[subLineIndex]\n                                                                        )\n                                                                    \"\n                                                                    (mouseleave)=\"mouseLeaveTextActionType(ROW_DATA)\"\n                                                                    (mouseenter)=\"\n                                                                        mouseEnterOnStringTextActionType(\n                                                                            ROW_DATA,\n                                                                            columnDef.headerInfo[subLineIndex]\n                                                                                .tooltipKey\n                                                                        )\n                                                                    \"\n                                                                    [placement]=\"\n                                                                        action.tooltipPlacement\n                                                                            ? action.tooltipPlacement\n                                                                            : 'bottom auto'\n                                                                    \"\n                                                                    container=\"body\"\n                                                                    [autoClose]=\"true\"\n                                                                    tooltipClass=\"team-user-tooltip remove-on-scroll-class {{\n                                                                        action.tooltipClass\n                                                                    }}\"\n                                                                    [ngbTooltip]=\"userLoggedInDetails\"\n                                                                >\n                                                                </i>\n                                                                <ng-container *ngIf=\"action['showSvgIcon']\">\n                                                                    <anna-core-anna-est-icon-template\n                                                                        class=\"float-right\"\n                                                                        *ngIf=\"action['svgIconName'] === 'anna-icon'\"\n                                                                        (mouseleave)=\"\n                                                                            mouseLeaveTextActionType(ROW_DATA)\n                                                                        \"\n                                                                        (mouseenter)=\"\n                                                                            mouseEnterOnStringTextActionType(\n                                                                                ROW_DATA,\n                                                                                columnDef.headerInfo[subLineIndex]\n                                                                                    .tooltipKey\n                                                                            )\n                                                                        \"\n                                                                        [placement]=\"\n                                                                            action.tooltipPlacement\n                                                                                ? action.tooltipPlacement\n                                                                                : 'bottom auto'\n                                                                        \"\n                                                                        tooltipClass=\"team-user-tooltip remove-on-scroll-class {{\n                                                                            action['tooltipClass']\n                                                                        }}\"\n                                                                        [ngbTooltip]=\"userLoggedInDetails\"\n                                                                        container=\"body\"\n                                                                        [autoClose]=\"true\"\n                                                                    >\n                                                                    </anna-core-anna-est-icon-template>\n                                                                </ng-container>\n                                                            </ng-container>\n                                                        </ng-container>\n\n                                                        <ng-container *ngIf=\"!action.showTooltip\">\n                                                            <i\n                                                                *ngIf=\"action.showIcon\"\n                                                                [class]=\"action.iconClass\"\n                                                                [ngClass]=\"{ disabled: action.disabledIcon }\"\n                                                                (click)=\"\n                                                                    iconClickedOnStringIconActionType(\n                                                                        ROW_DATA,\n                                                                        action.id,\n                                                                        columnDef.headerInfo[subLineIndex]\n                                                                    )\n                                                                \"\n                                                            >\n                                                            </i>\n                                                        </ng-container>\n                                                    </ng-container>\n                                                </ng-container>\n\n                                                <ng-container *ngSwitchCase=\"'STRING_OR_INPUT'\">\n                                                    <ng-container\n                                                        *ngIf=\"\n                                                            ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n                                                                ?.type === 'STRING';\n                                                            else inputBox\n                                                        \"\n                                                    >\n                                                        <span\n                                                            [innerHtml]=\"\n                                                                ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n                                                                    ?.value\n                                                            \"\n                                                        ></span>\n                                                    </ng-container>\n                                                    <ng-template #inputBox>\n                                                        <input\n                                                            placeholder=\"{{\n                                                                ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n                                                                    ?.placeholder\n                                                            }}\"\n                                                            annaCoreShowEllipsisTextOnHover\n                                                            class=\"{{\n                                                                ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n                                                                    .className\n                                                            }}\"\n                                                            (keydown)=\"\n                                                                changesMadeInEditableInputBox(\n                                                                    $event,\n                                                                    ROW_DATA[\n                                                                        columnDef.headerInfo[subLineIndex].objectKey\n                                                                    ],\n                                                                    false\n                                                                )\n                                                            \"\n                                                            (paste)=\"\n                                                                changesMadeInEditableInputBox(\n                                                                    $event,\n                                                                    ROW_DATA[\n                                                                        columnDef.headerInfo[subLineIndex].objectKey\n                                                                    ],\n                                                                    true\n                                                                )\n                                                            \"\n                                                            (ngModelChange)=\"\n                                                                editableInputValueChanged(\n                                                                    $event,\n                                                                    ROW_DATA,\n                                                                    columnDef.headerInfo[subLineIndex].objectKey\n                                                                )\n                                                            \"\n                                                            [ngModel]=\"\n                                                                ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n                                                                    .value\n                                                            \"\n                                                            [disabled]=\"\n                                                                ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n                                                                    .disabled\n                                                            \"\n                                                            [ngClass]=\"{\n                                                                'red-border':\n                                                                    ROW_DATA[\n                                                                        columnDef.headerInfo[subLineIndex].objectKey\n                                                                    ].hasError\n                                                            }\"\n                                                        />\n\n                                                        <i\n                                                            *ngIf=\"\n                                                                ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n                                                                    .showIcon\n                                                            \"\n                                                            container=\"body\"\n                                                            [ngbTooltip]=\"\n                                                                ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n                                                                    .iconTooltip\n                                                            \"\n                                                            tooltipClass=\"gt-total-row-tooltip\"\n                                                            placement=\"bottom\"\n                                                            class=\"{{\n                                                                ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n                                                                    .iconClass\n                                                            }}\"\n                                                        >\n                                                        </i>\n                                                        <ng-container\n                                                            *ngIf=\"\n                                                                ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey][\n                                                                    'showSvgIcon'\n                                                                ]\n                                                            \"\n                                                        >\n                                                            <anna-core-anna-est-icon-template\n                                                                class=\"float-right\"\n                                                                *ngIf=\"\n                                                                    ROW_DATA[\n                                                                        columnDef.headerInfo[subLineIndex].objectKey\n                                                                    ]['svgIconName'] === 'anna-icon'\n                                                                \"\n                                                                [placement]=\"'bottom auto'\"\n                                                                tooltipClass=\"gt-total-row-tooltip\"\n                                                                [ngbTooltip]=\"\n                                                                    ROW_DATA[\n                                                                        columnDef.headerInfo[subLineIndex].objectKey\n                                                                    ].iconTooltip\n                                                                \"\n                                                                container=\"body\"\n                                                            >\n                                                            </anna-core-anna-est-icon-template>\n                                                        </ng-container>\n                                                    </ng-template>\n                                                </ng-container>\n\n                                                <ng-container *ngSwitchCase=\"'HTML'\">\n                                                    <span\n                                                        [innerHtml]=\"\n                                                            ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n                                                        \"\n                                                    ></span>\n                                                </ng-container>\n\n                                                <ng-container *ngSwitchCase=\"'SINGLE_RADIO'\">\n                                                    <span\n                                                        *ngIf=\"ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\n                                                        [ngClass]=\"{\n                                                            'disable-checkbox':\n                                                                ROW_DATA[\n                                                                    columnDef.headerInfo[subLineIndex].isDisabledKey\n                                                                ]\n                                                        }\"\n                                                        class=\"mdi mdi-radiobox-marked\"\n                                                        (click)=\"(null)\"\n                                                    >\n                                                    </span>\n                                                    <span\n                                                        *ngIf=\"!ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\"\n                                                        class=\"mdi mdi-radiobox-blank\"\n                                                        [ngClass]=\"{\n                                                            'disable-checkbox':\n                                                                ROW_DATA[\n                                                                    columnDef.headerInfo[subLineIndex].isDisabledKey\n                                                                ]\n                                                        }\"\n                                                        (click)=\"\n                                                            selectOrUnselectCheckbox(\n                                                                ROW_DATA,\n                                                                columnDef.headerInfo[subLineIndex].objectKey,\n                                                                true\n                                                            )\n                                                        \"\n                                                    >\n                                                    </span>\n                                                </ng-container>\n\n                                                <ng-container *ngSwitchCase=\"'RADIO'\">\n                                                    <mat-radio-group\n                                                        *ngIf=\"ROW_DATA['RadioButtonConfig']\"\n                                                        [ngModel]=\"ROW_DATA[subline.objectKey]\"\n                                                        [disabled]=\"ROW_DATA['RadioButtonConfig'][0].isDisabled\"\n                                                    >\n                                                        <ng-container\n                                                            *ngFor=\"\n                                                                let radioButton of ROW_DATA['RadioButtonConfig'];\n                                                                let last = last\n                                                            \"\n                                                        >\n                                                            <mat-radio-button\n                                                                value=\"{{ radioButton.value }}\"\n                                                                class=\"{{ radioButton.class }}\"\n                                                                (click)=\"\n                                                                    radioButtonClicked(\n                                                                        ROW_DATA,\n                                                                        radioButton.value,\n                                                                        ROW_DATA['RadioButtonConfig'][0].isDisabled\n                                                                    )\n                                                                \"\n                                                                >{{ radioButton.label }}\n                                                            </mat-radio-button>\n                                                            <i\n                                                                class=\" {{ radioButton.iconClass }}\"\n                                                                (click)=\"radioButtonIconClicked(ROW_DATA)\"\n                                                            ></i>\n                                                            <br *ngIf=\"!last\" />\n                                                        </ng-container>\n                                                    </mat-radio-group>\n                                                </ng-container>\n\n                                                <ng-container *ngSwitchCase=\"'STRING_WITH_TOOLTIP'\">\n                                                    <ng-container\n                                                        *ngFor=\"\n                                                            let action of ROW_DATA[\n                                                                columnDef.headerInfo[subLineIndex].actionKey\n                                                            ]\n                                                        \"\n                                                    >\n                                                        <span> {{ action?.dataToDisplay }}</span>\n                                                        <span\n                                                            *ngIf=\"action?.showTooltip\"\n                                                            [ngbTooltip]=\"textActionTooltipTemplate\"\n                                                            (mouseenter)=\"\n                                                                mouseEnterOnStringTextActionType(\n                                                                    ROW_DATA,\n                                                                    columnDef.headerInfo[subLineIndex].tooltipKey\n                                                                )\n                                                            \"\n                                                            [placement]=\"action?.tooltipPosition\"\n                                                            container=\"body\"\n                                                            [class]=\"action?.tooltipIconClass\"\n                                                            tooltipClass=\"gt-icon-column-tooltip remove-on-scroll-class\"\n                                                            [disableTooltip]=\"action?.disableTooltip\"\n                                                        >\n                                                        </span>\n                                                        <span> {{ action?.dataToDisplayAfterTooltip }}</span>\n                                                    </ng-container>\n                                                </ng-container>\n\n                                                <ng-container *ngSwitchDefault>\n                                                    <ng-container *ngIf=\"subline.objectKey !== 'description'\">\n                                                        <span>{{\n                                                            ROW_DATA[columnDef.headerInfo[subLineIndex].objectKey]\n                                                        }}</span>\n                                                        <i\n                                                            *ngIf=\"\n                                                                subline.objectKey === 'inventoryCode' &&\n                                                                ROW_DATA['isSellerGroup'] &&\n                                                                gtGeneralConfig.component === 'RATING'\n                                                            \"\n                                                            class=\"mi mdi-info-outline seller-tooltip\"\n                                                            [ngbTooltip]=\"sellerHierarchyTooltip\"\n                                                            placement=\"bottom auto\"\n                                                            container=\"body\"\n                                                            [autoClose]=\"true\"\n                                                            triggers=\"manual\"\n                                                            (hidden)=\"closeTooltip()\"\n                                                            #info=\"ngbTooltip\"\n                                                            tooltipClass=\"hierarchy-tooltip remove-on-scroll-class\"\n                                                            (mouseenter)=\"\n                                                                bindTheValueToSellerGroupTooltip(\n                                                                    ROW_DATA.sellerGroupHierarchy,\n                                                                    info\n                                                                )\n                                                            \"\n                                                        >\n                                                        </i>\n\n                                                        <i\n                                                            *ngIf=\"\n                                                                subline.objectKey === 'displayBookedAverageRating' &&\n                                                                gtGeneralConfig.component === 'RATING' &&\n                                                                ROW_DATA['showRatingAverageIcon']\n                                                            \"\n                                                            class=\"mi mdi-info-outline seller-tooltip\"\n                                                            placement=\"bottom auto\"\n                                                            container=\"body\"\n                                                            [autoClose]=\"true\"\n                                                            (mouseenter)=\"\n                                                                setIsDifference(ROW_DATA.isDifferenceLessThan25Percent)\n                                                            \"\n                                                            tooltipClass=\"posted-avg-tooltip remove-on-scroll-class\"\n                                                            [ngbTooltip]=\"postedRatingDifference\"\n                                                        >\n                                                        </i>\n\n                                                        <i\n                                                            *ngIf=\"\n                                                                subline.objectKey ===\n                                                                    'displayBookedAverageImpression' &&\n                                                                gtGeneralConfig.component === 'RATING' &&\n                                                                ROW_DATA['showImpressionAverageIcon']\n                                                            \"\n                                                            class=\"mi mdi-info-outline seller-tooltip\"\n                                                            placement=\"bottom auto\"\n                                                            container=\"body\"\n                                                            [autoClose]=\"true\"\n                                                            (mouseenter)=\"\n                                                                setIsDifference(ROW_DATA.isDifferenceLessThan25Percent)\n                                                            \"\n                                                            tooltipClass=\"posted-avg-tooltip remove-on-scroll-class\"\n                                                            [ngbTooltip]=\"postedImpDifference\"\n                                                        >\n                                                        </i>\n                                                    </ng-container>\n                                                    <ng-container *ngIf=\"subline.objectKey === 'description'\">\n                                                        <p\n                                                            *ngIf=\"\n                                                                ROW_DATA.descriptionMessage ||\n                                                                ROW_DATA.descriptionEmailReferenceNum\n                                                            \"\n                                                        >\n                                                            <ng-container *ngIf=\"ROW_DATA.descriptionMessage\">\n                                                                {{ ROW_DATA.descriptionMessage }}\n                                                                <br />\n                                                            </ng-container>\n                                                            <ng-container\n                                                                *ngIf=\"\n                                                                    ROW_DATA.descriptionEmailReferenceNum !== '-' &&\n                                                                    ROW_DATA.descriptionEmailReferenceNum !== ''\n                                                                \"\n                                                            >\n                                                                Email Ref: {{ ROW_DATA.descriptionEmailReferenceNum }}\n                                                                <br />\n                                                            </ng-container>\n                                                        </p>\n                                                        <a\n                                                            href=\"{{ ROW_DATA.descriptionDetailsUrl }}\"\n                                                            target=\"_blank\"\n                                                            *ngIf=\"\n                                                                ROW_DATA.descriptionDetailsUrlType === 'PDF' ||\n                                                                ROW_DATA.descriptionDetailsUrlType === 'EXCEL'\n                                                            \"\n                                                        >\n                                                            <button class=\"btn viewDetailsAndEmailBtn\">Download</button>\n                                                        </a>\n                                                        <ng-container\n                                                            *ngIf=\"\n                                                                ROW_DATA.activityname.toLowerCase() ===\n                                                                'order onboarded'\n                                                            \"\n                                                        >\n                                                            <a\n                                                                *ngIf=\"ROW_DATA.descriptionDetailsUrlType === 'LINK'\"\n                                                                (click)=\"viewDetailsClicked(ROW_DATA)\"\n                                                            >\n                                                                <button\n                                                                    class=\"btn viewDetailsAndEmailBtn order-onboarded\"\n                                                                >\n                                                                    View details\n                                                                </button>\n                                                            </a>\n                                                        </ng-container>\n\n                                                        <a\n                                                            href=\"{{ ROW_DATA.descriptionEmailUrl }}\"\n                                                            target=\"_blank\"\n                                                            *ngIf=\"\n                                                                ROW_DATA.descriptionEmailUrl !== '-' &&\n                                                                ROW_DATA.descriptionEmailUrl !== ''\n                                                            \"\n                                                        >\n                                                            <button class=\"btn viewDetailsAndEmailBtn\">\n                                                                View email\n                                                            </button>\n                                                        </a>\n                                                    </ng-container>\n                                                </ng-container>\n                                            </ng-container>\n                                        </div>\n                                    </ng-container>\n                                </ng-container>\n                                <ng-container *ngIf=\"isNoDataToDisplaySubject$ | async\">\n                                    <div>\n                                        {{ null }}\n                                    </div>\n                                </ng-container>\n                            </ng-container>\n                        </td>\n                    </ng-container>\n                </tr>\n            </tbody>\n        </table>\n    </div>\n    <anna-core-no-data-lib\n        [width]=\"noDataWidth\"\n        [marginTop]=\"marginTop\"\n        *ngIf=\"isNoDataToDisplaySubject$ | async\"\n    >\n    </anna-core-no-data-lib>\n</div>\n\n<!-- Checkbox template -->\n<ng-template #filterTooltip>\n    <anna-core-anna-column-checkbox-filter\n        [tableData]=\"tableData\"\n        [showFilterHeaderTabs]=\"showFilterTooltipTabs\"\n        [isLurAndCsrComponent]=\"false\"\n        [clonedTableData]=\"clonedTableData\"\n        [filterTabObjects]=\"filterTabObjects\"\n        (filterAppliedToTable)=\"filterApplied($event)\"\n        (sortingAppliedToTable)=\"sortingApplied($event)\"\n        (closeTooltip)=\"closeTooltip()\"\n    >\n    </anna-core-anna-column-checkbox-filter>\n</ng-template>\n\n<!-- Slider template -->\n<ng-template #sliderToolTip>\n    <anna-core-anna-column-slider-filter\n        [tableData]=\"tableData\"\n        [showFilterHeaderTabs]=\"showFilterTooltipTabs\"\n        [isLurAndCsrComponent]=\"false\"\n        [clonedTableData]=\"clonedTableData\"\n        [filterTabObjects]=\"filterTabObjects\"\n        (filterAppliedToTable)=\"filterApplied($event)\"\n        (sortingAppliedToTable)=\"sortingApplied($event)\"\n        (closeTooltip)=\"closeTooltip()\"\n    >\n    </anna-core-anna-column-slider-filter>\n</ng-template>\n\n<!-- Date Picker Template -->\n<ng-template #datePickerTooltip>\n    <anna-core-anna-column-date-range-filter\n        [tableData]=\"tableData\"\n        [showFilterHeaderTabs]=\"showFilterTooltipTabs\"\n        [isLurAndCsrComponent]=\"false\"\n        [clonedTableData]=\"clonedTableData\"\n        [filterTabObjects]=\"filterTabObjects\"\n        (filterAppliedToTable)=\"filterApplied($event)\"\n        (sortingAppliedToTable)=\"sortingApplied($event)\"\n        (closeTooltip)=\"closeTooltip()\"\n    >\n    </anna-core-anna-column-date-range-filter>\n</ng-template>\n\n<!-- Week Picker Template -->\n<ng-template #weekPickerToolTip>\n    <!-- <div class=\"weekpicker-container\">\n        <anna-core-week-calendar-filter-lib\n            [week-calendar-config]=\"gtGeneralConfig.multiWeekPickerConfig\"\n            (apply)=\"applyWeekFilter($event)\"\n            [from-date]=\"calendarMinEnabledDate\"\n            [to-date]=\"calendarMaxEnabledDate\"\n        >\n        </anna-core-week-calendar-filter-lib>\n    </div> -->\n</ng-template>\n\n<!-- Time Filter Template -->\n<ng-template #timeFilterToolTip>\n    <anna-core-anna-column-time-filter\n        [tableData]=\"tableData\"\n        [showFilterHeaderTabs]=\"showFilterTooltipTabs\"\n        [isLurAndCsrComponent]=\"false\"\n        [showAllTimeRangeCheckboxes]=\"showCheckboxesForTimeFilter\"\n        [clonedTableData]=\"clonedTableData\"\n        [filterTabObjects]=\"filterTabObjects\"\n        (filterAppliedToTable)=\"filterApplied($event)\"\n        (sortingAppliedToTable)=\"sortingApplied($event)\"\n        (closeTooltip)=\"closeTooltip()\"\n    >\n    </anna-core-anna-column-time-filter>\n</ng-template>\n\n<ng-template #columnInfoTooltip>\n    <p class=\"black-color-text white-space-nowrap\">This preemption is rejected and not marked for credit.</p>\n</ng-template>\n\n<ng-template #ratingInfoTooltip>\n    <p class=\"first-row\">Shows 'Booked Rating' for Preemptions & MakeGood Offered spot(s).</p>\n    <p class=\"second-row\">Shows 'Projected Rating' for ADU Offered spot(s).</p>\n</ng-template>\n\n<ng-template #impsInfoTooltip>\n    <p class=\"first-row\">Shows 'Booked IMPS' for Preemptions & MakeGood Offered spot(s).</p>\n    <p class=\"second-row\">Shows 'Projected IMPS' for ADU Offered spot(s).</p>\n</ng-template>\n\n<ng-template #spotsColumnEquivalizationMessageTooltip>\n    <p class=\"spot-column-tooltip-message\">\n        This consists of equivalized spots and un-equivalized Paid Programs & un-equivalized Non-spots.\n    </p>\n</ng-template>\n\n<ng-template #underDeliveryTooltip>\n    <p class=\"spot-column-tooltip-message\">\n        Indicates the Under-delivery percentage based on booked and posted RTG/IMPS.\n    </p>\n</ng-template>\n\n<ng-template #overDeliveryTooltip>\n    <p class=\"spot-column-tooltip-message\">\n        Indicates the Over-delivery percentage based on booked and posted RTG/IMPS.\n    </p>\n</ng-template>\n\n<ng-template #rateInfoTooltip>\n    <p class=\"first-row\">Shows 'Booked Rate' for Preemptions & MakeGood Offered spot(s).</p>\n    <p class=\"second-row\">Shows 'Projected $ Value' for ADU Offered spot(s).</p>\n</ng-template>\n\n<ng-template #sellerHierarchyTooltip>\n    <ng-container *ngIf=\"sellerGroupHierarchy.length > 0\">\n        <section class=\"hierarchy-table-container\">\n            <table class=\"seller-hierarchy-table\">\n                <thead>\n                    <tr>\n                        <th>#</th>\n                        <th>Inventory Codes</th>\n                        <th>Program/Description</th>\n                    </tr>\n                </thead>\n                <tbody>\n                    <tr *ngFor=\"let data of sellerGroupHierarchy; let tooltipIndex = index\">\n                        <td>{{ tooltipIndex + 1 }}</td>\n                        <td>\n                            <span annaCoreShowEllipsisTextOnHover>{{ data.InventoryCode }}</span>\n                        </td>\n                        <td>\n                            <span annaCoreShowEllipsisTextOnHover>{{ data.Program }}</span>\n                        </td>\n                    </tr>\n                </tbody>\n            </table>\n        </section>\n    </ng-container>\n    <ng-container *ngIf=\"sellerGroupHierarchy.length === 0\">\n        <span class=\"black-color-text\">Seller group not available for this inventory code</span>\n    </ng-container>\n</ng-template>\n\n<ng-template #lurViolationInfoTooltip>\n    <p class=\"first-row\">The values are for the entire week.</p>\n</ng-template>\n\n<ng-template #postedRatingDifference>\n    <p class=\"difference-text\">\n        The difference between posted and booked average rating is\n        {{ isDifferenceLessThan25Percent ? \"less\" : \"more\" }} than 25%.\n    </p>\n</ng-template>\n\n<ng-template #postedImpDifference>\n    <p class=\"difference-text\">\n        The difference between posted and booked average impression is\n        {{ isDifferenceLessThan25Percent ? \"less\" : \"more\" }} than 25%.\n    </p>\n</ng-template>\n\n<ng-template #ongoingRevBookedColumnTooltip>\n    <p>The Booked $ value, Spots, GRP, CPP, IMPS, CPM corresponds on the last permanent revision generated</p>\n</ng-template>\n\n<ng-template #completedRevBookedColumnTooltip>\n    <p>The Booked $ value corresponds on the last permanent revision generated</p>\n</ng-template>\n\n<ng-template #avgBookedRate>\n    <p>This is the booked average Rate</p>\n</ng-template>\n\n<ng-template #avgBookedRtg>\n    <p>This is the booked average RTG</p>\n</ng-template>\n\n<ng-template #avgBookedImps>\n    <p>This is the booked average IMP(’000)</p>\n</ng-template>\n\n<ng-template #projectedImpsRtg>\n    <p>\n        All projections are derived from the sum of actual posted information until the last posted date and estimates\n        for the remaining selected period.\n    </p>\n</ng-template>\n\n<ng-template #automationTooltip>\n    <p>\n        Please get the order business rules approved to activate the order for automation. Only for the\n        automation-activated orders, any approved MGs, ADUs, or credited spots on ANNA will be fed into the traffic\n        system i.e. ANNA revisions.\n        <!-- removed below line as part of enhancmennt in 14.0 releas -->\n        <!-- Additionally, ANNA will only enter buyer revisions into traffic for the selected\n        Medialine/WOC orders. -->\n    </p>\n</ng-template>\n\n<ng-template #rebateImpact>\n    <p>Rebate impact value is for the originally ordered spot length and is not equivalized.</p>\n</ng-template>\n\n<ng-template #lurViolationTotalRowToolTip>\n    <ul>\n        <li>\n            <strong>POLITICAL RATE VIOLATIONS:</strong>\n            Violations flagged when non-political spots are booked at a rate lower than the minimum booked rate for\n            political candidates for the same week, Inventory Code and Revenue Class.\n        </li>\n        <li>\n            <strong>CANDIDATE TO CANDIDATE VIOLATION:</strong>\n            Violations flagged when political spots are booked at different rates to other political spots for the same\n            week, Inventory Code and Revenue Class.\n        </li>\n    </ul>\n</ng-template>\n\n<ng-template #circularProgressBar>\n    <circle-progress\n        [percent]=\"percentDone\"\n        [radius]=\"5\"\n        [showTitle]=\"false\"\n        [showUnits]=\"false\"\n        [showSubtitle]=\"false\"\n        [outerStrokeWidth]=\"3\"\n        [innerStrokeWidth]=\"3\"\n        [space]=\"-3\"\n        [outerStrokeColor]=\"'#268bff'\"\n        [innerStrokeColor]=\"'#d5d5d5'\"\n        [animationDuration]=\"10\"\n    ></circle-progress>\n</ng-template>\n\n<ng-template #userLoggedInDetails>\n    <div class=\"tooltip-div-container\">\n        <ng-container *ngFor=\"let data of textActionTooltip\">\n            <span *ngIf=\"data.key !== 'read'\">\n                {{ data.key }} <b> {{ data.value }}</b>\n            </span>\n            <span *ngIf=\"data.key === 'read'\">\n                {{ data.value }}\n            </span>\n        </ng-container>\n    </div>\n</ng-template>\n\n<ng-template #markAsReadTip>\n    <div class=\"notification-tooltip-div-container\">\n        <ng-container *ngFor=\"let data of textActionTooltip\">\n            {{ data.value }}\n        </ng-container>\n    </div>\n</ng-template>\n\n<ng-template #textActionTooltipTemplate>\n    <ng-container *ngFor=\"let data of textActionTooltip\">\n        {{ data.key }} <b> {{ data.value }}</b>\n    </ng-container>\n</ng-template>\n\n<ng-template #showOrHideToggleForTotalRowTooltip>\n    <div>\n        {{ showOrHideToggleForTotalRow && !gtGeneralConfig.totalRow ? \"Show Total Row\" : \"Hide Total Row\" }}\n    </div>\n</ng-template>\n\n<ng-template #tooltipContainingTableTemplate>\n    <div\n        *ngIf=\"tooltipContainingTable\"\n        [innerHTML]=\"tooltipContainingTable.innerHtml\"\n        class=\"notification-tooltip-div-container\"\n    >\n        <!-- <ul>\n      <li *ngFor=\"let headerMsg of tooltipContainingTable.tableHeaderMsg\">\n        <b> {{headerMsg}}  </b>\n      </li>\n    </ul>\n\n    <table class=\"tooltip-table\">\n      <thead>\n        <tr>\n          <th *ngFor=\"let header of tooltipContainingTable.tooltipTableHeader\">\n            {{ header}}\n          </th>\n        </tr>\n      </thead>\n      <tbody>\n        <tr *ngFor=\"let rows of tooltipContainingTable.tooltipTableBody\">\n          <td *ngFor=\"let data of rows\">\n            {{ data }}\n          </td>\n        </tr>\n      </tbody>\n    </table>\n\n    <ul>\n      <li style=\"margin-top:10px; padding:0\" *ngFor=\"let footerMsg of tooltipContainingTable.tableFooterMsg\">\n        {{ footerMsg }} \n      </li>\n    </ul> -->\n    </div>\n</ng-template>\n<!-- <ng-template #textActionTooltipTemplate>\n   <ng-container *ngFor=\"let data of textActionTooltip\">\n      {{ data.key }} <b> {{data.value}}</b>\n   </ng-container>\n</ng-template> -->\n"]}