axidio-styleguide-library1-v2 0.4.22 → 0.4.24

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.
@@ -14,856 +14,1033 @@ export class GroupChartComponent extends ComponentUniqueId {
14
14
  super();
15
15
  this.clickEvent = new EventEmitter();
16
16
  this.headerMenuclickEvent = new EventEmitter();
17
+ this.chartConfiguration = {};
17
18
  this.isHeaderVisible = true;
18
- this.legendVisible = true;
19
+ this.isTopCaptionVisible = true;
20
+ this.uniqueId = this.getUniqueId();
19
21
  this.isTransparentBackground = false;
20
- this.chartConfiguration = {};
21
- this.objectKeys = Object.keys;
22
+ this.isCC = false;
23
+ this.isZoomedOut = true;
24
+ this.CONSTANTS = {
25
+ RIGHT_SVG_WIDTH: 60,
26
+ LEFT_RIGHT_SPACES: 50,
27
+ SHORT_TICK_LENGTH: 4,
28
+ LONG_TICK_LENGTH: 16,
29
+ SHORT_TICK_LENGTH_BG: 5,
30
+ LONG_TICK_LENGTH_BG: 30,
31
+ DESKTOP_BAR_WIDTH: 40, // Desktop bar width
32
+ MOBILE_BAR_WIDTH: 25, // Mobile/Tablet bar width (reduced)
33
+ BAR_GAP: 30, // Gap between bars (increased for better separation)
34
+ ZOOM_THRESHOLD: 30,
35
+ ZOOM_IN_THRESHOLD: 8,
36
+ };
22
37
  this.defaultConfiguration = {
23
38
  margin: { top: 20, right: 20, bottom: 20, left: 40 },
24
- labelFormatter: ChartHelper.defaultFormatter,
25
39
  svgHeight: 70,
40
+ legendHeight: '10%',
26
41
  numberOfYTicks: 5,
27
- legendJustified: true,
28
- yLineAxisLabelFomatter: ChartHelper.defaultFormatter,
42
+ labelFormatter: ChartHelper.defaultFormatter,
43
+ xAxisLabelFomatter: ChartHelper.defaultFormatter,
29
44
  yAxisLabelFomatter: ChartHelper.defaultFormatter,
45
+ yLineAxisLabelFomatter: ChartHelper.defaultFormatter,
30
46
  lineGraphColor: '#F6D283',
31
47
  showLineChartAxis: true,
32
- showValues: true,
48
+ showLegend: false,
49
+ forComparison: true,
33
50
  headerMenuOptions: HeaderConfigHelper.headerConfig.headerMenuOptions,
34
51
  yAxisGrid: false,
35
- legendVisible: true,
36
- isYaxisLabelHidden: false,
37
- backgroundColor: '#FFFFFF',
38
- hideLegendOnTop: true,
39
- isXaxisColor: '#999999',
40
- labelOverlapMinorFix: true,
41
- noHoverEffect: true,
42
- noHoverDisplayData: true,
43
- showXaxisTop: true,
44
- howmanyBarDetailsToDisplay: 0,
52
+ // Optional configs with undefined defaults
53
+ isHeaderVisible: undefined,
54
+ isTransparentBackground: undefined,
55
+ isTopCaptionVisible: undefined,
56
+ isMultiChartGridLine: undefined,
57
+ isFullScreen: undefined,
58
+ customYscale: undefined,
59
+ isXaxisLabelHidden: undefined,
60
+ isYaxisLabelHidden: undefined,
61
+ isYaxisHidden: undefined,
62
+ isYaxisDashed: undefined,
63
+ isXaxisColor: undefined,
64
+ textFormatter: undefined,
65
+ showTotalOnTop: undefined,
66
+ backendFormatterHasPriority: undefined,
67
+ showAngledLabels: undefined,
68
+ isNoAlternateXaxisText: undefined,
69
+ isXgridBetweenLabels: undefined,
70
+ showXaxisTop: undefined,
71
+ xAxisGrid: undefined,
72
+ xLabelsOnSameLine: undefined,
73
+ hideXaxisTick: undefined,
74
+ isDrilldownChart: undefined,
75
+ isTargetLine: undefined,
76
+ displayTitleOnTop: undefined,
77
+ isToggleVisible: undefined,
78
+ isTitleHidden: undefined,
45
79
  };
46
- this.uniqueId = this.getUniqueId();
47
- this.isZoomedOut = false;
48
- this.isDD1Open = false;
49
- this.isDD2Open = false;
50
- this.keepOrder = (a, b) => a;
51
80
  }
52
- ngOnInit() { }
53
- get isAlertEnabled() {
54
- return this.chartConfiguration?.headerMenuOptions?.some((option) => option.id === 'editAlert');
81
+ ngOnChanges() {
82
+ this.removeExistingChart();
83
+ this.initializeStackedChart();
55
84
  }
56
85
  onResized(event) {
57
86
  setTimeout(() => {
58
- d3.select('#' + this.uniqueId).remove();
59
- this.initializegroupChart();
87
+ this.removeExistingChart();
88
+ this.initializeStackedChart();
60
89
  }, 10);
61
90
  }
62
- isZoomOutSelected(isZoomOut, event) {
91
+ isZoomOutSelected(isZoomOut) {
63
92
  this.isZoomedOut = isZoomOut;
64
- this.onResized(event);
65
- }
66
- handleZoominZoomoutClick({ isZoomOut, event }) {
67
- this.isZoomOutSelected(isZoomOut, event);
68
- }
69
- isLegendVisible() {
70
- return !!(this.chartData?.metaData?.colors &&
71
- Object.keys(this.chartData.metaData.colors).length > 1);
93
+ this.ngOnChanges();
72
94
  }
73
- initializegroupChart() {
74
- this.mergeConfigurations();
75
- const chartContext = this.prepareChartData();
76
- const dimensions = this.calculateDimensions(chartContext);
77
- const scales = this.createScales(chartContext, dimensions);
78
- const svgElements = this.createSVGStructure(dimensions);
79
- this.renderAxes(svgElements, scales, chartContext, dimensions);
80
- this.renderBars(svgElements.svg, chartContext, scales, dimensions);
81
- this.renderLabels(svgElements, scales, chartContext, dimensions);
82
- this.renderTargetLine(svgElements, scales, chartContext, dimensions);
83
- this.renderLineGraph(svgElements.svg, chartContext, scales);
95
+ removeExistingChart() {
96
+ d3.select('#' + this.uniqueId).remove();
84
97
  }
85
98
  mergeConfigurations() {
86
99
  for (const key in this.defaultConfiguration) {
87
100
  this.chartConfiguration[key] = ChartHelper.getValueByConfigurationType(key, this.defaultConfiguration, this.customChartConfiguration);
88
101
  }
89
- if (this.chartConfiguration.isHeaderVisible !== undefined) {
90
- this.isHeaderVisible = this.chartConfiguration.isHeaderVisible;
91
- }
92
- if (this.chartConfiguration.legendVisible !== undefined) {
93
- this.legendVisible = this.chartConfiguration.legendVisible;
94
- }
95
- if (this.chartConfiguration.isTransparentBackground !== undefined) {
96
- this.isTransparentBackground = this.chartConfiguration.isTransparentBackground;
97
- }
98
102
  }
99
- prepareChartData() {
100
- const data = this.chartData.data;
101
- const metaData = this.chartData.metaData;
102
- const lineData = this.chartData.lineData;
103
- if (!metaData.colorAboveTarget) {
104
- metaData.colorAboveTarget = metaData.colors;
103
+ prepareMetaData(metaData) {
104
+ if (!metaData.unit)
105
+ metaData.unit = '';
106
+ if (metaData.isCC)
107
+ this.isCC = metaData.isCC;
108
+ if (metaData.barWithoutClick?.length) {
109
+ metaData.barWithoutClick = metaData.barWithoutClick.map(el => el.toLowerCase());
105
110
  }
106
- return {
107
- data,
108
- metaData,
109
- lineData,
110
- keyList: metaData.keyList,
111
- colorMap: metaData.colors,
112
- isRia: this.customChartConfiguration?.isRia || false,
113
- };
114
- }
115
- calculateDimensions(chartContext) {
116
- const chartContainer = d3.select(this.containerElt.nativeElement);
117
- const verticalstackedcontainer = d3.select(this.groupcontainerElt.nativeElement);
118
- const margin = this.chartConfiguration.margin;
119
- let width = this.calculateWidth(chartContainer, margin);
120
- let height = this.calculateHeight(verticalstackedcontainer, margin);
121
- return { width, height, margin, chartContainer, verticalstackedcontainer };
122
- }
123
- calculateWidth(chartContainer, margin) {
124
- const baseWidth = parseInt(chartContainer.style('width')) - margin.left - margin.right;
125
- const dataLength = this.chartData.data.length;
126
- let width = baseWidth;
127
- if (dataLength > 30 && this.isZoomedOut) {
128
- const multiplier = this.chartData.dropdownData1 ? 60 : 40;
129
- width = Math.max(width, dataLength * multiplier);
130
- }
131
- if (this.chartData.dropdownData2 && width < dataLength * 120 && this.isZoomedOut) {
132
- width = dataLength * 120;
133
- }
134
- if (dataLength > 8 && !this.isZoomedOut) {
135
- if (this.chartData.dropdownData2 && width < dataLength * 250) {
136
- width = dataLength * 250;
137
- }
138
- else {
139
- width = dataLength * 160;
140
- }
111
+ else {
112
+ metaData.barWithoutClick = [];
141
113
  }
142
- return width;
114
+ return metaData;
143
115
  }
144
- calculateHeight(verticalstackedcontainer, margin) {
145
- let height = parseInt(verticalstackedcontainer.style('height')) *
146
- (this.chartConfiguration.svgHeight / 100) -
147
- margin.top -
148
- margin.bottom;
149
- if (this.chartConfiguration.isFullScreen && this.chartConfiguration.svgHeight !== 70) {
150
- height = this.chartConfiguration.svgHeight;
116
+ calculateDimensions(chartContainer, verticalContainer, margin, dataLength) {
117
+ const containerWidth = chartContainer.node().getBoundingClientRect().width;
118
+ const containerHeight = verticalContainer.node().getBoundingClientRect().height;
119
+ const leftAxisWidth = 80;
120
+ const rightAxisWidth = this.CONSTANTS.RIGHT_SVG_WIDTH;
121
+ const availableWidth = containerWidth - leftAxisWidth - rightAxisWidth;
122
+ let width = availableWidth;
123
+ let height = containerHeight * (this.chartConfiguration.svgHeight / 100) - margin.top - margin.bottom;
124
+ if (dataLength > this.CONSTANTS.ZOOM_THRESHOLD && this.isZoomedOut) {
125
+ const minWidth = dataLength * 25;
126
+ width = Math.max(width, minWidth);
151
127
  }
152
- else if (this.chartConfiguration.isFullScreen) {
153
- height = parseInt(verticalstackedcontainer.style('height'));
128
+ if (dataLength > this.CONSTANTS.ZOOM_IN_THRESHOLD && !this.isZoomedOut) {
129
+ width = dataLength * 130;
154
130
  }
155
- if (this.chartConfiguration.isDrilldownChart && !this.isHeaderVisible) {
156
- height = parseInt(verticalstackedcontainer.style('height')) - margin.top - margin.bottom - 130;
131
+ if (this.chartConfiguration.isFullScreen) {
132
+ height = this.chartConfiguration.svgHeight !== 80
133
+ ? this.chartConfiguration.svgHeight
134
+ : containerHeight;
157
135
  }
158
- if (this.chartConfiguration.isHeaderVisible) {
159
- height = parseInt(verticalstackedcontainer.style('height')) - margin.top - margin.bottom - 100;
136
+ if (this.chartConfiguration.isDrilldownChart) {
137
+ height = containerHeight - margin.top - margin.bottom - 130;
160
138
  }
161
- return height;
162
- }
163
- createScales(chartContext, dimensions) {
164
- const { data, metaData, lineData, keyList } = chartContext;
165
- const { width, height, margin } = dimensions;
166
- const leftAndRightSpaces = 50;
167
- const rightSvgWidth = 60;
168
- const groups = d3.map(data, (d) => d.name).keys();
169
- let x;
170
- if (this.chartConfiguration.isMultiChartGridLine !== undefined) {
171
- x = d3
172
- .scaleBand()
173
- .rangeRound([width, 0])
174
- .align(0.5)
175
- .padding(0.5)
176
- .domain(data.map((d) => d.name.toLowerCase()));
139
+ const isMobileOrTablet = window.innerWidth < 1024;
140
+ let barWidth;
141
+ let barPadding;
142
+ if (isMobileOrTablet) {
143
+ if (dataLength === 1) {
144
+ barWidth = 60;
145
+ barPadding = 0;
146
+ }
147
+ else if (dataLength === 2) {
148
+ barWidth = 50;
149
+ barPadding = 45;
150
+ }
151
+ else if (dataLength === 3) {
152
+ barWidth = 45;
153
+ barPadding = 40;
154
+ }
155
+ else if (dataLength <= 5) {
156
+ barWidth = 35;
157
+ barPadding = 30;
158
+ }
159
+ else {
160
+ barWidth = 25;
161
+ barPadding = 25;
162
+ }
177
163
  }
178
164
  else {
179
- x = d3
180
- .scaleBand()
181
- .domain(groups)
182
- .range([leftAndRightSpaces, width - rightSvgWidth - leftAndRightSpaces])
183
- .padding(0.3);
184
- }
185
- const xScaleFromOrigin = d3.scaleBand().domain(groups).range([0, width - rightSvgWidth]);
186
- const xSubgroup = d3.scaleBand().domain(keyList).range([0, x.bandwidth()]);
187
- const maxValue = this.calculateMaxValue(data, keyList);
188
- const y = d3.scaleLinear().domain([0, maxValue]).nice().rangeRound([height, 0]);
189
- let lineYscale = null;
190
- if (lineData) {
191
- lineYscale = this.createLineYScale(lineData, height);
165
+ barWidth = this.CONSTANTS.DESKTOP_BAR_WIDTH;
166
+ barPadding = this.CONSTANTS.BAR_GAP;
192
167
  }
193
- const color = d3.scaleOrdinal().domain(keyList).range(Object.values(metaData.colors));
168
+ const totalBarsWidth = barWidth * dataLength;
169
+ const totalGaps = barPadding * (dataLength - 1);
170
+ const minRequiredWidth = totalBarsWidth + totalGaps + (this.CONSTANTS.LEFT_RIGHT_SPACES * 2);
171
+ const requiredSvgWidth = Math.max(availableWidth, minRequiredWidth);
194
172
  return {
195
- x,
196
- xScaleFromOrigin,
197
- xSubgroup,
198
- y,
199
- lineYscale,
200
- color,
201
- leftAndRightSpaces,
202
- rightSvgWidth,
173
+ width,
174
+ height,
175
+ containerWidth,
176
+ containerHeight,
177
+ barWidth,
178
+ barPadding,
179
+ requiredSvgWidth,
203
180
  };
204
181
  }
205
- calculateMaxValue(data, keyList) {
206
- let maxValue = d3.max(data, (d) => d3.max(keyList, (key) => +d[key])) || 0;
207
- if (maxValue === 0) {
208
- maxValue = this.chartData.targetLineData
209
- ? this.chartData.targetLineData.target + 20
210
- : 100;
211
- }
212
- if (this.chartConfiguration.customYscale) {
213
- maxValue *= this.chartConfiguration.customYscale;
214
- }
215
- if (this.chartData.targetLineData && maxValue < this.chartData.targetLineData.target) {
216
- const target = this.chartData.targetLineData.target;
217
- maxValue = maxValue < 10 && target < 10 ? target + 3 : target + 20;
218
- }
219
- return maxValue;
220
- }
221
- createLineYScale(lineData, height) {
222
- let maxLineValue = d3.max(lineData, (d) => +d.value) || 0;
223
- maxLineValue *= this.chartConfiguration.customYscale || 1;
224
- let minLineValue = d3.min(lineData, (d) => +d.value) || 0;
225
- if (maxLineValue > 0)
226
- minLineValue -= 3;
227
- if (minLineValue > 0)
228
- minLineValue = 0;
229
- return d3.scaleLinear().domain([minLineValue, maxLineValue]).range([height, minLineValue]);
230
- }
231
- createSVGStructure(dimensions) {
232
- const { chartContainer, height, margin } = dimensions;
233
- const rightSvgWidth = 60;
234
- const outerContainer = chartContainer
182
+ createSvgContainers(chartContainer, dimensions, margin, hasXLabel // Add this parameter
183
+ ) {
184
+ // Calculate total height including space for X-axis label if present
185
+ const xLabelSpace = hasXLabel ? 30 : 0;
186
+ const totalHeight = dimensions.height + margin.top + margin.bottom + xLabelSpace;
187
+ // Main wrapper
188
+ const chartWrapper = chartContainer
235
189
  .append('div')
236
190
  .attr('id', this.uniqueId)
237
- .attr('class', 'outer-container')
191
+ .attr('class', 'chart-wrapper-main')
192
+ .style('position', 'relative')
238
193
  .style('width', '100%')
239
- .style('height', height)
240
- .style('overflow-x', 'hidden')
241
- .style('padding-left', `${margin.left}px`)
242
- .style('padding-right', `${rightSvgWidth}px`)
243
- .style('margin-left', '15px');
244
- const svgYAxisLeft = outerContainer
245
- .append('svg')
246
- .attr('width', 100)
247
- .attr('height', height + margin.top + margin.bottom + 10)
194
+ .style('height', `${totalHeight}px`); // Include X-label space
195
+ const leftAxisContainer = chartWrapper
196
+ .append('div')
197
+ .attr('class', 'left-axis-container')
248
198
  .style('position', 'absolute')
249
199
  .style('left', '0')
250
- .style('z-index', 1)
251
- .append('g')
252
- .attr('transform', `translate(${margin.left + 15},${margin.top})`);
253
- const svgYAxisRight = outerContainer
200
+ .style('top', '0')
201
+ .style('width', '80px')
202
+ .style('height', `${dimensions.height + margin.top + margin.bottom}px`)
203
+ .style('background-color', 'var(--card-bg)')
204
+ .style('z-index', '10');
205
+ const svgYAxisLeft = leftAxisContainer
254
206
  .append('svg')
255
- .attr('width', rightSvgWidth)
256
- .attr('height', height + margin.top + margin.bottom + 10)
207
+ .attr('width', '80')
208
+ .attr('height', dimensions.height + margin.top + margin.bottom)
209
+ .append('g')
210
+ .attr('transform', `translate(79,${margin.top})`);
211
+ // Right Y-axis - Fixed
212
+ const rightAxisContainer = chartWrapper
213
+ .append('div')
214
+ .attr('class', 'right-axis-container')
257
215
  .style('position', 'absolute')
258
- .style('right', '12px')
259
- .style('z-index', 1)
216
+ .style('right', '0')
217
+ .style('top', '0')
218
+ .style('width', `${this.CONSTANTS.RIGHT_SVG_WIDTH}px`)
219
+ .style('height', `${dimensions.height + margin.top + margin.bottom}px`) // Exclude X-label space
220
+ .style('background-color', 'var(--card-bg)')
221
+ .style('z-index', '10');
222
+ const svgYAxisRight = rightAxisContainer
223
+ .append('svg')
224
+ .attr('width', this.CONSTANTS.RIGHT_SVG_WIDTH)
225
+ .attr('height', dimensions.height + margin.top + margin.bottom)
260
226
  .append('g')
261
227
  .attr('transform', `translate(0,${margin.top})`);
262
- const innerContainer = outerContainer
228
+ // Scrollable middle area
229
+ const scrollableContainer = chartWrapper
263
230
  .append('div')
264
- .attr('class', 'inner-container')
265
- .style('width', '100%')
266
- .style('overflow-x', 'auto');
231
+ .attr('class', 'scrollable-chart-container')
232
+ .style('position', 'absolute')
233
+ .style('left', '80px') // Exactly where left container ends
234
+ .style('right', `${this.CONSTANTS.RIGHT_SVG_WIDTH}px`)
235
+ .style('top', '0')
236
+ .style('width', 'auto')
237
+ .style('height', `${dimensions.height + margin.top + margin.bottom}px`)
238
+ .style('overflow-x', 'auto')
239
+ .style('overflow-y', 'hidden');
240
+ const innerContainer = scrollableContainer
241
+ .append('div')
242
+ .attr('class', 'inner-chart-container')
243
+ .style('min-width', '100%');
267
244
  const svg = innerContainer
268
245
  .append('svg')
269
- .attr('width', dimensions.width - rightSvgWidth)
270
- .attr('height', height + margin.top + margin.bottom + 30)
246
+ .attr('width', dimensions.requiredSvgWidth)
247
+ .attr('height', dimensions.height + margin.top + margin.bottom + 30)
271
248
  .append('g')
272
249
  .attr('transform', `translate(0,${margin.top})`);
273
- return { outerContainer, svgYAxisLeft, svgYAxisRight, svg };
274
- }
275
- renderAxes(svgElements, scales, chartContext, dimensions) {
276
- const { svg, svgYAxisLeft, svgYAxisRight } = svgElements;
277
- const { x, xScaleFromOrigin, y, lineYscale } = scales;
278
- const { height } = dimensions;
279
- const { metaData, lineData, keyList } = chartContext;
280
- this.renderXAxis(svg, x, xScaleFromOrigin, height, chartContext, keyList);
281
- this.renderYAxis(svg, svgYAxisLeft, svgYAxisRight, y, dimensions);
282
- if (this.chartConfiguration.yAxisGrid) {
283
- this.renderYAxisGrid(svg, y, dimensions.width);
250
+ // Fixed bottom container for X-axis label
251
+ const bottomLabelContainer = chartWrapper
252
+ .append('div')
253
+ .attr('class', 'bottom-label-container')
254
+ .style('position', 'absolute')
255
+ .style('left', '80px')
256
+ .style('right', `${this.CONSTANTS.RIGHT_SVG_WIDTH}px`)
257
+ .style('bottom', '0')
258
+ .style('height', `${xLabelSpace}px`)
259
+ .style('display', 'flex')
260
+ .style('justify-content', 'center')
261
+ .style('align-items', 'center')
262
+ .style('background-color', 'var(--card-bg)')
263
+ .style('z-index', '10');
264
+ return { svg, svgYAxisLeft, svgYAxisRight, innerContainer, bottomLabelContainer };
265
+ }
266
+ createScales(data, layers, lineData, dimensions) {
267
+ const { width, height, barWidth, barPadding } = dimensions;
268
+ // Calculate bar positioning
269
+ const totalBarsWidth = data.length * barWidth;
270
+ const totalSpacing = (data.length - 1) * barPadding;
271
+ const requiredWidth = totalBarsWidth + totalSpacing + (this.CONSTANTS.LEFT_RIGHT_SPACES * 2);
272
+ const effectiveWidth = Math.max(width, requiredWidth);
273
+ const paddingRatio = barPadding / (barWidth + barPadding);
274
+ // X-scale starts from 0 (no left spacing for grid alignment)
275
+ const xScale = d3
276
+ .scaleBand()
277
+ .rangeRound([0, dimensions.requiredSvgWidth])
278
+ .domain(data.map(d => d.name).reverse())
279
+ .paddingInner(paddingRatio)
280
+ .paddingOuter(0.1) // Small padding for visual spacing
281
+ .align(0.5);
282
+ const xScaleFromOrigin = d3
283
+ .scaleBand()
284
+ .rangeRound([width, 0])
285
+ .domain(data.map(d => d.name).reverse());
286
+ const yScale = d3.scaleLinear().rangeRound([height, 0]);
287
+ let maxValue = d3.max(layers, (d) => d3.max(d, (d) => d[1]));
288
+ if (maxValue === 0) {
289
+ maxValue = this.chartData.targetLineData
290
+ ? Number(this.chartData.targetLineData.target) + 20
291
+ : 100;
284
292
  }
285
- if (this.chartConfiguration.isXgridBetweenLabels) {
286
- this.renderXAxisGrid(svg, x, height);
293
+ if (this.chartConfiguration.customYscale) {
294
+ maxValue *= this.chartConfiguration.customYscale;
287
295
  }
288
- if (lineData && this.chartConfiguration.showLineChartAxis && lineYscale) {
289
- this.renderLineYAxis(svgYAxisRight, lineYscale);
296
+ if (this.chartData.targetLineData && maxValue < Number(this.chartData.targetLineData.target)) {
297
+ const target = Number(this.chartData.targetLineData.target);
298
+ maxValue = maxValue < 10 && target < 10 ? target + 3 : target + 20;
290
299
  }
300
+ yScale.domain([0, maxValue]).nice();
301
+ let lineYscale = null;
302
+ if (lineData) {
303
+ lineYscale = d3
304
+ .scaleLinear()
305
+ .domain([0, d3.max(lineData, d => +d.value)])
306
+ .range([height, 0]);
307
+ }
308
+ return { xScale, xScaleFromOrigin, yScale, lineYscale };
291
309
  }
292
- renderXAxis(svg, x, xScaleFromOrigin, height, chartContext, keyList) {
293
- const { data, metaData } = chartContext;
294
- if (this.chartConfiguration.isMultiChartGridLine === undefined) {
295
- svg
296
- .append('g')
297
- .attr('class', 'x1 axis1')
298
- .attr('transform', `translate(0,${height})`)
299
- .call(d3.axisBottom(x))
300
- .call((g) => g.select('.domain').remove());
301
- svg.selectAll('g.x1.axis1 g.tick line').remove();
302
- const textClass = 'lib-xaxis-labels-texts-drilldown';
303
- const textSelection = svg.selectAll('g.x1.axis1 g.tick text').attr('class', textClass).style('fill', 'var(--chart-text-color)');
304
- if (keyList.length > 1 && !metaData.xLabel) {
305
- textSelection.attr('y', 32);
306
- }
310
+ createAxes(scales) {
311
+ const xAxis = d3
312
+ .axisBottom(scales.xScale)
313
+ .tickSize(0)
314
+ .tickFormat(this.chartConfiguration.xAxisLabelFomatter);
315
+ const yAxis = d3
316
+ .axisLeft(scales.yScale)
317
+ .ticks(this.chartConfiguration.numberOfYTicks)
318
+ .tickSize(0)
319
+ .tickFormat(this.chartConfiguration.yAxisLabelFomatter);
320
+ let yLineAxis = null;
321
+ if (scales.lineYscale) {
322
+ yLineAxis = d3
323
+ .axisRight(scales.lineYscale)
324
+ .ticks(this.chartConfiguration.numberOfYTicks)
325
+ .tickSize(0)
326
+ .tickFormat(this.chartConfiguration.yLineAxisLabelFomatter);
307
327
  }
308
- else {
309
- this.renderMultiChartXAxis(svg, x, height, data, metaData);
328
+ return { xAxis, yAxis, yLineAxis };
329
+ }
330
+ renderBars(svg, layers, scales, metaData, dimensions) {
331
+ const layer = svg
332
+ .selectAll('.layer')
333
+ .data(layers)
334
+ .enter()
335
+ .append('g')
336
+ .attr('class', 'layer')
337
+ .style('fill', (d) => metaData.colors[d.key]);
338
+ const rect = layer
339
+ .selectAll('rect')
340
+ .data((d) => d)
341
+ .enter();
342
+ this.appendRectangles(rect, scales, metaData, dimensions);
343
+ this.addInteractions(rect, svg, metaData, scales);
344
+ return rect;
345
+ }
346
+ appendRectangles(rect, scales, metaData, dimensions) {
347
+ const { barWidth, barPadding } = dimensions;
348
+ const { xScale, yScale } = scales;
349
+ rect
350
+ .append('rect')
351
+ .on('click', (d) => {
352
+ if (!this.chartData.lineData || this.chartConfiguration.forComparison) {
353
+ if (!metaData.barWithoutClick?.includes(d.data.name.toLowerCase())) {
354
+ this.handleClick(d.data.name);
355
+ }
356
+ }
357
+ })
358
+ .attr('y', (d) => {
359
+ if (!isNaN(d[0]) && !isNaN(d[1])) {
360
+ const actualHeight = yScale(d[0]) - yScale(d[1]);
361
+ return actualHeight < 3 ? yScale(d[0]) - 3 : yScale(d[1]);
362
+ }
363
+ return 0;
364
+ })
365
+ .attr('x', (d) => {
366
+ const xPosition = xScale(d.data.name);
367
+ const bandwidth = xScale.bandwidth();
368
+ if (!this.chartConfiguration.isMultiChartGridLine) {
369
+ return xPosition + (bandwidth - barWidth) / 2;
370
+ }
371
+ if (this.chartConfiguration.isDrilldownChart && this.chartData.data.length <= 3) {
372
+ return xPosition + bandwidth / 2 - 35;
373
+ }
374
+ const calculatedWidth = bandwidth * 0.8;
375
+ return xPosition + (bandwidth - calculatedWidth) / 2;
376
+ })
377
+ .attr('height', (d) => {
378
+ if (!isNaN(d[0]) && !isNaN(d[1])) {
379
+ const actualHeight = yScale(d[0]) - yScale(d[1]);
380
+ return actualHeight < 3 ? 3 : actualHeight;
381
+ }
382
+ return 0;
383
+ })
384
+ .attr('width', (d) => {
385
+ if (!this.chartConfiguration.isMultiChartGridLine)
386
+ return barWidth;
387
+ if (this.chartConfiguration.isDrilldownChart && this.chartData.data.length <= 3) {
388
+ return 70;
389
+ }
390
+ return xScale.bandwidth() * 0.8;
391
+ })
392
+ .style('cursor', (d) => {
393
+ if (metaData.hasDrillDown) {
394
+ if (metaData.barWithoutClick?.includes(d.data.name.toLowerCase())) {
395
+ return 'default';
396
+ }
397
+ return 'pointer';
398
+ }
399
+ return 'default';
400
+ })
401
+ .style('fill', (d) => this.getBarColor(d, metaData));
402
+ }
403
+ getBarColor(d, metaData) {
404
+ if (!isNaN(d[0]) &&
405
+ !isNaN(d[1]) &&
406
+ this.chartData.targetLineData &&
407
+ parseFloat(d[1]) - parseFloat(d[0]) >= parseFloat(String(this.chartData.targetLineData.target))) {
408
+ return this.chartData.targetLineData.barAboveTargetColor || metaData.colors[d.key];
310
409
  }
311
- if (this.chartConfiguration.xLabelsOnSameLine) {
312
- this.renderXLabelsOnSameLine(svg, data, metaData);
410
+ return metaData.colors[d.key];
411
+ }
412
+ addInteractions(rect, svg, metaData, scales) {
413
+ rect
414
+ .selectAll('rect')
415
+ .on('mouseenter', (d) => this.handleMouseOver(d, svg, metaData, scales))
416
+ .on('mouseout', (d) => this.handleMouseOut(svg, metaData));
417
+ }
418
+ handleMouseOver(d, svg, metaData, scales) {
419
+ if (!this.chartConfiguration.displayTitleOnTop)
420
+ return;
421
+ svg.selectAll('rect')
422
+ .filter((data) => data === d)
423
+ .style('fill', (d) => this.getHoverColor(d, metaData));
424
+ this.displayTooltip(d, svg, metaData, scales);
425
+ }
426
+ getHoverColor(d, metaData) {
427
+ if (!isNaN(d[0]) &&
428
+ !isNaN(d[1]) &&
429
+ this.chartData.targetLineData &&
430
+ parseFloat(d[1]) - parseFloat(d[0]) >= parseFloat(String(this.chartData.targetLineData.target))) {
431
+ return this.chartData.targetLineData.barAboveTargetHoverColor ||
432
+ this.chartData.targetLineData.barAboveTargetColor ||
433
+ metaData.colors[d.key];
313
434
  }
314
- // Render bottom x-axis
435
+ return metaData.hoverColor || metaData.colors[d.key];
436
+ }
437
+ displayTooltip(d, svg, metaData, scales) {
438
+ const { xScale, yScale } = scales;
439
+ const value = d[1] - d[0];
440
+ if (isNaN(value))
441
+ return;
442
+ const bandwidth = xScale.bandwidth();
443
+ // Fixed tooltip width for all resolutions
444
+ const width = /week/i.test(d.data.name) && /\d{4}-\d{2}-\d{2}/.test(d.data.name)
445
+ ? '250px'
446
+ : bandwidth + this.CONSTANTS.LEFT_RIGHT_SPACES * 2 > 180
447
+ ? '180px'
448
+ : bandwidth + this.CONSTANTS.LEFT_RIGHT_SPACES * 2;
315
449
  svg
316
- .append('g')
317
- .attr('class', 'x2 axis2')
318
- .attr('transform', `translate(0,${height})`)
319
- .style('color', '#000')
320
- .call(d3.axisBottom(xScaleFromOrigin).tickSize(0))
321
- .call((g) => g.select('.domain').attr('fill', 'none'));
322
- svg.selectAll('g.x2.axis2 g.tick text').style('display', 'none');
323
- if (this.isZoomedOut) {
324
- svg.selectAll('.lib-xaxis-labels-texts-drilldown').attr('class', 'lib-display-hidden');
450
+ .append('foreignObject')
451
+ .attr('x', this.calculateTooltipX(d, xScale, width))
452
+ .attr('class', 'lib-verticalstack-title-ontop')
453
+ .attr('y', yScale(d[1]) - 51)
454
+ .attr('width', width)
455
+ .attr('height', 40)
456
+ .append('xhtml:div')
457
+ .attr('class', 'title')
458
+ .style('z-index', 99)
459
+ .html(this.generateTooltipHtml(d, metaData, value));
460
+ }
461
+ calculateTooltipX(d, xScale, width) {
462
+ const bandwidth = xScale.bandwidth();
463
+ const numericWidth = typeof width === 'string' ? parseInt(width) : width;
464
+ if (bandwidth + this.CONSTANTS.LEFT_RIGHT_SPACES * 2 > 180) {
465
+ return xScale(d.data.name) - this.CONSTANTS.LEFT_RIGHT_SPACES +
466
+ (bandwidth + this.CONSTANTS.LEFT_RIGHT_SPACES * 2 - 180) / 2;
325
467
  }
468
+ return xScale(d.data.name) - this.CONSTANTS.LEFT_RIGHT_SPACES;
326
469
  }
327
- renderMultiChartXAxis(svg, x, height, data, metaData) {
328
- let alternate_text = false;
329
- const short_tick_length_bg = 5;
330
- const long_tick_length_bg = 30;
331
- svg
470
+ generateTooltipHtml(d, metaData, value) {
471
+ if (value === 0)
472
+ return '<span class="title-top-text">0</span>';
473
+ const dataType = metaData.dataType || '';
474
+ const name = d.data.name ? `<span class="title-bar-name">${d.data.name}</span>` : '';
475
+ const valueText = metaData.unit
476
+ ? `${metaData.unit}${value} ${dataType}`
477
+ : `${value} ${dataType}`;
478
+ return `${name}<span class="title-top-text">${valueText}</span>`;
479
+ }
480
+ handleMouseOut(svg, metaData) {
481
+ if (!this.chartConfiguration.displayTitleOnTop)
482
+ return;
483
+ svg.selectAll('rect')
484
+ .style('fill', (d) => this.getBarColor(d, metaData));
485
+ svg.selectAll('.lib-verticalstack-title-ontop').remove();
486
+ }
487
+ renderAxisLabels(svg, svgYAxisLeft, bottomLabelContainer, metaData, dimensions, margin) {
488
+ if (metaData.yLabel) {
489
+ this.addYAxisLabel(svgYAxisLeft, metaData.yLabel, dimensions.height, margin);
490
+ }
491
+ if (metaData.xLabel) {
492
+ this.addXAxisLabel(bottomLabelContainer, metaData.xLabel);
493
+ }
494
+ }
495
+ addYAxisLabel(svgYAxisLeft, label, height, margin) {
496
+ const isria = this.customChartConfiguration?.isRia;
497
+ const isAcronym = this.isAcronymLabel(label);
498
+ const yPosition = isria ? -margin.left / 2 - 30 : -margin.left / 2 - 40;
499
+ svgYAxisLeft.selectAll('.lib-axis-group-label, .lib-ylabel-drilldowncharts, .lib-ylabel-weeklyCharts').remove();
500
+ svgYAxisLeft
501
+ .append('text')
502
+ .attr('class', this.getYAxisLabelClass())
503
+ .attr('style', this.chartConfiguration.yAxisCustomlabelStyles)
504
+ .attr('transform', 'rotate(-90)')
505
+ .attr('y', yPosition)
506
+ .attr('x', -height / 2)
507
+ .attr('dy', '1em')
508
+ .style('text-anchor', 'middle')
509
+ .style('fill', 'var(--chart-text-color)')
510
+ .text(isAcronym ? label.toUpperCase() : label.toLowerCase())
511
+ .style('text-transform', isAcronym ? 'none' : 'capitalize');
512
+ }
513
+ addXAxisLabel(bottomLabelContainer, label) {
514
+ const isAcronym = this.isAcronymLabel(label);
515
+ bottomLabelContainer
516
+ .append('div')
517
+ .style('width', '100%')
518
+ .style('text-align', 'center')
519
+ .style('font-size', '12px')
520
+ .style('font-weight', '600')
521
+ .style('font-family', 'system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto')
522
+ .style('color', 'var(--chart-text-color)')
523
+ .style('text-transform', isAcronym ? 'none' : 'capitalize')
524
+ .text(isAcronym ? label.toUpperCase() : label.toLowerCase());
525
+ }
526
+ isAcronymLabel(label) {
527
+ const cleanLabel = label.replace(/[^A-Za-z]/g, '');
528
+ return (label.length <= 4 && /^[A-Z]+$/.test(label)) ||
529
+ (label === label.toUpperCase() && /[A-Z]/.test(label));
530
+ }
531
+ getYAxisLabelClass() {
532
+ let baseClass = 'lib-axis-group-label font-size-1';
533
+ if (this.chartConfiguration.isDrilldownChart) {
534
+ return `${baseClass} lib-ylabel-drilldowncharts`;
535
+ }
536
+ if (this.chartConfiguration.isMultiChartGridLine !== undefined) {
537
+ return `${baseClass} lib-ylabel-weeklyCharts`;
538
+ }
539
+ return `${baseClass} lib-axis-waterfall-label`;
540
+ }
541
+ getXAxisLabelClass() {
542
+ let baseClass = 'lib-axis-group-label font-size-1';
543
+ if (this.chartConfiguration.isDrilldownChart) {
544
+ return `${baseClass} lib-xlabel-drilldowncharts`;
545
+ }
546
+ if (this.chartConfiguration.isMultiChartGridLine !== undefined) {
547
+ return `${baseClass} lib-xlabel-weeklyCharts`;
548
+ }
549
+ return `${baseClass} lib-axis-waterfall-label`;
550
+ }
551
+ renderGridsFromLeftAxis(svgMain, svgYAxisLeft, scales, dimensions) {
552
+ if (!this.chartConfiguration.yAxisGrid)
553
+ return;
554
+ // We want horizontal grid lines to span the full visible width:
555
+ // the inner SVG (requiredSvgWidth) plus the right axis width.
556
+ const gridSpan = dimensions.requiredSvgWidth + this.CONSTANTS.RIGHT_SVG_WIDTH;
557
+ // Append the grid to the main (inner) SVG so lines are rendered across the scrollable area.
558
+ svgMain
332
559
  .append('g')
333
- .attr('class', 'x1 axis1')
334
- .attr('transform', `translate(0,${height})`)
335
- .call(d3.axisBottom(x).tickSize(0))
336
- .call((g) => g.select('.domain').attr('fill', 'none'));
337
- svg.selectAll('g.x1.axis1 g.tick line').attr('y2', () => {
338
- if (alternate_text && !this.chartConfiguration.isNoAlternateXaxisText) {
339
- alternate_text = false;
340
- return long_tick_length_bg - 7;
341
- }
342
- else {
343
- alternate_text = true;
344
- return short_tick_length_bg - 4;
345
- }
560
+ .attr('class', 'grid horizontal-grid-from-left')
561
+ .attr('transform', 'translate(0,0)')
562
+ .call(d3
563
+ .axisLeft(scales.yScale)
564
+ .ticks(this.chartConfiguration.numberOfYTicks)
565
+ .tickSize(-gridSpan)
566
+ .tickFormat(''))
567
+ .style('color', 'var(--chart-grid-color)')
568
+ .style('opacity', '1')
569
+ .call((g) => {
570
+ g.select('.domain').remove();
571
+ g.selectAll('.tick line')
572
+ .style('stroke', 'var(--chart-grid-color)')
573
+ .style('stroke-width', '1px');
346
574
  });
347
- alternate_text = false;
348
- svg.selectAll('g.x1.axis1 g.tick text').attr('class', 'lib-xaxis-labels-texts-weeklycharts').attr('y', () => {
349
- if (alternate_text) {
350
- alternate_text = false;
351
- return long_tick_length_bg;
352
- }
353
- else {
354
- alternate_text = true;
355
- return short_tick_length_bg;
575
+ }
576
+ applyConfigurationFlags() {
577
+ if (this.chartConfiguration.isHeaderVisible !== undefined) {
578
+ this.isHeaderVisible = this.chartConfiguration.isHeaderVisible;
579
+ }
580
+ if (this.chartConfiguration.isTopCaptionVisible !== undefined) {
581
+ this.isTopCaptionVisible = this.chartConfiguration.isTopCaptionVisible;
582
+ }
583
+ if (this.chartConfiguration.isTransparentBackground !== undefined) {
584
+ this.isTransparentBackground = this.chartConfiguration.isTransparentBackground;
585
+ }
586
+ }
587
+ initializeStackedChart() {
588
+ // Use fixed configuration for all resolutions
589
+ this.chartConfiguration.margin = { top: 20, right: 20, bottom: 40, left: 40 };
590
+ this.chartConfiguration.numberOfYTicks = 5;
591
+ this.chartConfiguration.svgHeight = 70;
592
+ this.mergeConfigurations();
593
+ this.applyConfigurationFlags();
594
+ const data = this.chartData.data;
595
+ const metaData = this.prepareMetaData(this.chartData.metaData);
596
+ const lineData = this.chartData.lineData;
597
+ const colors = metaData.colors;
598
+ const keyList = metaData.keyList;
599
+ const chartContainer = d3.select(this.containerElt.nativeElement);
600
+ const verticalstackedcontainer = d3.select(this.groupcontainerElt.nativeElement);
601
+ const margin = this.chartConfiguration.margin;
602
+ const dimensions = this.calculateDimensions(chartContainer, verticalstackedcontainer, margin, data.length);
603
+ const hasXLabel = !!metaData.xLabel;
604
+ const { svg, svgYAxisLeft, svgYAxisRight, bottomLabelContainer } = this.createSvgContainers(chartContainer, dimensions, margin, hasXLabel);
605
+ const stack = d3.stack().keys(keyList).offset(d3.stackOffsetNone);
606
+ const layers = stack(data);
607
+ data.sort((a, b) => b.total - a.total);
608
+ const scales = this.createScales(data, layers, lineData, dimensions);
609
+ const axes = this.createAxes(scales);
610
+ this.renderGridsFromLeftAxis(svg, svgYAxisLeft, scales, dimensions);
611
+ this.renderGrids(svg, scales, dimensions);
612
+ const rect = this.renderBars(svg, layers, scales, metaData, dimensions);
613
+ this.renderAxes(svg, svgYAxisLeft, svgYAxisRight, axes, scales, dimensions, data);
614
+ this.renderAxisLabels(svg, svgYAxisLeft, bottomLabelContainer, metaData, dimensions, margin);
615
+ this.renderTargetLine(svg, svgYAxisRight, scales, dimensions, metaData);
616
+ this.renderDataLabels(rect, scales, metaData, dimensions);
617
+ this.renderLineChart(svg, lineData, scales, colors, metaData);
618
+ }
619
+ renderGrids(svg, scales, dimensions) {
620
+ if (this.chartConfiguration.isXgridBetweenLabels) {
621
+ svg
622
+ .append('g')
623
+ .attr('class', 'grid vertical-grid')
624
+ .attr('transform', `translate(${scales.xScale.bandwidth() / 2},${dimensions.height})`)
625
+ .call(d3.axisBottom(scales.xScale).tickSize(-dimensions.height).tickFormat(''))
626
+ .style('stroke-dasharray', '5 5')
627
+ .style('color', '#999999')
628
+ .call((g) => g.select('.domain').remove());
629
+ }
630
+ if (this.chartConfiguration.xAxisGrid) {
631
+ for (let j = 0; j < this.chartConfiguration.xAxisGrid.length; j++) {
632
+ svg
633
+ .append('g')
634
+ .attr('class', `x${j + 2} axis${j + 2}`)
635
+ .style('color', 'var(--chart-grid-color)')
636
+ .attr('transform', `translate(0,${dimensions.height * this.chartConfiguration.xAxisGrid[j]})`)
637
+ .call(d3.axisBottom(scales.xScale).tickSize(0).ticks(5).tickFormat(''))
638
+ .style('fill', 'var(--chart-text-color)');
356
639
  }
357
- });
640
+ }
358
641
  }
359
- renderXLabelsOnSameLine(svg, data, metaData) {
360
- const short_tick_length_bg = 5;
361
- const long_tick_length_bg = 30;
362
- svg
363
- .selectAll('g.x1.axis1 g.tick text')
364
- .attr('class', 'lib-xaxis-labels-texts-drilldown')
365
- .attr('y', short_tick_length_bg)
366
- .text((d) => {
367
- const isValueToBeIgnored = data.some((indiv) => indiv.name.toLowerCase() === d.trim().toLowerCase() &&
368
- indiv[metaData.keyList[0]] === -1);
369
- if (isValueToBeIgnored)
370
- return '';
371
- if (d.trim().indexOf(' ') > -1) {
372
- return d.trim().substring(0, d.indexOf(' ')).toLowerCase();
642
+ renderAxes(svg, svgYAxisLeft, svgYAxisRight, axes, scales, dimensions, data) {
643
+ if (this.chartConfiguration.showXaxisTop) {
644
+ svg
645
+ .append('g')
646
+ .attr('class', 'lib-line-axis-text lib-line-x-axis-text x-axis')
647
+ .attr('style', this.chartConfiguration.xAxisCustomTextStyles)
648
+ .call(d3.axisBottom(scales.xScale).tickSize(0));
649
+ svg.selectAll('.x-axis > g > text').attr('class', 'lib-display-hidden');
650
+ }
651
+ if (!this.chartConfiguration.isMultiChartGridLine) {
652
+ this.renderStandardAxes(svg, axes, scales, dimensions, data);
653
+ }
654
+ else if (this.chartConfiguration.isDrilldownChart) {
655
+ this.renderDrilldownAxes(svg, svgYAxisLeft, svgYAxisRight, axes, scales, dimensions);
656
+ }
657
+ else {
658
+ this.renderMultiChartAxes(svg, axes, scales, dimensions);
659
+ }
660
+ this.applyAxisStyling(svg, svgYAxisLeft, svgYAxisRight);
661
+ this.applyAxisConfigurations(svg, scales, dimensions, data);
662
+ }
663
+ renderStandardAxes(svg, axes, scales, dimensions, data) {
664
+ const isMobileOrTablet = window.innerWidth < 1024;
665
+ // X-axis with labels
666
+ const xAxisGroup = svg
667
+ .append('g')
668
+ .attr('transform', `translate(0,${dimensions.height})`)
669
+ .attr('class', 'lib-stacked-x-axis-text')
670
+ .call(axes.xAxis);
671
+ // Style X-axis labels
672
+ xAxisGroup
673
+ .selectAll('text')
674
+ .style('fill', 'var(--chart-text-color)')
675
+ .style('font-size', isMobileOrTablet ? '10px' : '12px')
676
+ .attr('text-anchor', 'middle')
677
+ .attr('dy', '1em')
678
+ .each(function (d) {
679
+ const textElement = d3.select(this);
680
+ const text = textElement.text();
681
+ if (isMobileOrTablet && text.length > 12) {
682
+ textElement.text(text.substring(0, 10) + '...');
373
683
  }
374
- return d.toLowerCase();
375
684
  });
685
+ // Ensure X-axis line starts exactly at x=0
686
+ xAxisGroup
687
+ .select('.domain')
688
+ .style('stroke', 'var(--chart-axis-color)')
689
+ .style('stroke-width', '1px')
690
+ .attr('d', `M0,0.5H${dimensions.requiredSvgWidth}`);
691
+ // Y-axis
376
692
  svg
377
- .selectAll('g.x1.axis1 g.tick')
378
- .append('text')
379
- .attr('class', 'lib-xaxis-labels-texts-drilldown')
380
- .attr('y', long_tick_length_bg)
381
- .attr('fill', 'currentColor')
382
- .text((d) => {
383
- if (d.trim().indexOf(' ') > -1) {
384
- return d.trim().substring(d.indexOf(' ')).toLowerCase();
385
- }
386
- return '';
387
- });
693
+ .append('g')
694
+ .attr('class', 'lib-stacked-y-axis-text')
695
+ .attr('style', this.chartConfiguration.yAxisCustomTextStyles)
696
+ .call(axes.yAxis)
697
+ .selectAll('text')
698
+ .style('fill', 'var(--chart-text-color)');
388
699
  }
389
- renderYAxis(svg, svgYAxisLeft, svgYAxisRight, y, dimensions) {
700
+ renderDrilldownAxes(svg, svgYAxisLeft, svgYAxisRight, axes, scales, dimensions) {
390
701
  svg
391
702
  .append('g')
392
- .attr('class', 'lib-stacked-y-axis-text yaxis-dashed')
393
- .attr('style', this.chartConfiguration.yAxisCustomTextStyles)
394
- .attr('transform', 'translate(0,0)')
395
- .call(y)
703
+ .attr('transform', `translate(0,${dimensions.height})`)
704
+ .attr('class', 'lib-stacked-x-axis-text multichart1')
705
+ .call(axes.xAxis)
396
706
  .style('display', 'none');
397
707
  svgYAxisLeft
398
- .append('g')
399
708
  .append('g')
400
709
  .attr('class', 'lib-yaxis-labels-texts-drilldown yaxis-dashed')
401
710
  .attr('style', this.chartConfiguration.yAxisCustomTextStyles)
402
- .attr('transform', 'translate(0,0)')
403
- .call(d3
404
- .axisLeft(y)
405
- .tickSize(0)
406
- .ticks(this.chartConfiguration.numberOfYTicks)
407
- .tickFormat(this.chartConfiguration.yAxisLabelFomatter))
711
+ .call(axes.yAxis)
408
712
  .selectAll('text')
409
713
  .style('fill', 'var(--chart-text-color)');
410
714
  svgYAxisRight
411
715
  .append('g')
412
716
  .attr('class', 'lib-yaxis-labels-texts-drilldown yaxis-dashed')
413
717
  .attr('style', this.chartConfiguration.yAxisCustomTextStyles)
414
- .attr('transform', 'translate(0,0)')
415
- .call(y)
718
+ .call(axes.yAxis)
416
719
  .style('display', 'none');
417
- this.applyAxisVisibilitySettings();
418
- }
419
- applyAxisVisibilitySettings() {
420
- if (this.chartConfiguration.isXaxisLabelHidden) {
421
- d3.selectAll('g.lib-line-x-axis-text > g > text').attr('class', 'lib-display-hidden');
422
- }
423
- if (this.chartConfiguration.isYaxisLabelHidden) {
424
- d3.selectAll('.yaxis-dashed > g > text').attr('class', 'lib-display-hidden');
425
- }
426
- if (this.chartConfiguration.isYaxisHidden) {
427
- d3.selectAll('.yaxis-dashed').attr('class', 'lib-display-hidden');
428
- }
429
- if (this.chartConfiguration.isYaxisDashed) {
430
- d3.selectAll('.yaxis-dashed').style('stroke-dasharray', '5 5').style('color', '#999999');
431
- }
432
720
  }
433
- renderYAxisGrid(svg, y, width) {
721
+ renderMultiChartAxes(svg, axes, scales, dimensions) {
434
722
  svg
435
723
  .append('g')
436
- .call(d3.axisLeft(y).ticks(this.chartConfiguration.numberOfYTicks).tickSize(-width))
437
- .style('color', 'var(--chart-axis-color, #B9B9B9)')
438
- .style('opacity', '0.5')
439
- .call((g) => g.select('.domain').remove());
440
- }
441
- renderXAxisGrid(svg, x, height) {
724
+ .attr('transform', `translate(0,${dimensions.height})`)
725
+ .attr('class', 'lib-stacked-x-axis-text multichart')
726
+ .call(axes.xAxis)
727
+ .selectAll('text')
728
+ .style('fill', 'var(--chart-text-color)');
442
729
  svg
443
730
  .append('g')
444
- .attr('class', 'grid')
445
- .attr('transform', `translate(${x.bandwidth() / 2},${height})`)
446
- .call(d3.axisBottom(x).tickSize(-height).tickFormat(''))
447
- .style('stroke-dasharray', '5 5')
448
- .style('color', 'var(--chart-grid-color, #999999)')
449
- .call((g) => g.select('.domain').remove());
450
- }
451
- renderLineYAxis(svgYAxisRight, lineYscale) {
452
- const yLineAxis = d3
453
- .axisRight(lineYscale)
454
- .ticks(this.chartConfiguration.numberOfYTicks)
455
- .tickSize(0)
456
- .tickFormat(this.chartConfiguration.yLineAxisLabelFomatter);
457
- svgYAxisRight
458
- .append('g')
459
- .attr('class', 'lib-stacked-y-axis-text1')
731
+ .attr('class', 'lib-stacked-y-axis-text yaxis-dashed')
460
732
  .attr('style', this.chartConfiguration.yAxisCustomTextStyles)
461
- .attr('transform', 'translate(0,0)')
462
- .call(yLineAxis);
733
+ .call(axes.yAxis)
734
+ .selectAll('text')
735
+ .style('fill', 'var(--chart-text-color)');
463
736
  }
464
- renderBars(svg, chartContext, scales, dimensions) {
465
- const { data, metaData, keyList, isRia } = chartContext;
466
- const { x, xSubgroup, y } = scales;
467
- const { height } = dimensions;
468
- const state = svg
469
- .append('g')
470
- .selectAll('.state')
471
- .data(data)
472
- .enter()
473
- .append('g')
474
- .attr('transform', (d) => `translate(${x(d.name)},0)`);
475
- state
476
- .selectAll('rect')
477
- .data((d) => this.prepareBarData(d, keyList))
478
- .enter()
479
- .append('rect')
480
- .attr('class', 'bars')
481
- .on('click', (d) => this.handleBarClick(d, metaData))
482
- .attr('x', (d) => this.getBarX(d, data, x, xSubgroup))
483
- .attr('y', (d) => y(d.value))
484
- .attr('width', (d) => this.getBarWidth(d, data, x, xSubgroup))
485
- .attr('height', (d) => this.getBarHeight(d, y, height))
486
- .style('cursor', (d) => (metaData.hasDrillDown && !isRia ? 'pointer' : 'default'))
487
- .attr('fill', (d) => this.getBarColor(d, metaData));
488
- if (!isRia && (this.chartConfiguration.displayTitleOnTop || (!this.chartConfiguration.textsOnBar && !this.chartConfiguration.displayTitleOnTop))) {
489
- state.selectAll('rect').on('mouseout', (d, i) => this.handleMouseOut(svg)).on('mouseover', (d, i) => this.handleMouseOver(svg, d, data, metaData, x, y, scales.leftAndRightSpaces));
490
- }
491
- if (this.chartConfiguration.textsOnBar && !this.isZoomedOut) {
492
- this.renderBarTexts(state, data, metaData, keyList, x, xSubgroup, y, isRia, svg);
737
+ applyAxisStyling(svg, svgYAxisLeft, svgYAxisRight) {
738
+ const styleAxisDomain = (container) => {
739
+ container.selectAll('.domain')
740
+ .style('stroke', 'var(--chart-axis-color)')
741
+ .style('stroke-width', '1px');
742
+ };
743
+ styleAxisDomain(svg);
744
+ styleAxisDomain(svgYAxisLeft);
745
+ styleAxisDomain(svgYAxisRight);
746
+ if (this.chartConfiguration.isYaxisDashed) {
747
+ d3.selectAll('.yaxis-dashed')
748
+ .style('stroke-dasharray', '5 5')
749
+ .style('color', 'var(--chart-grid-color)');
493
750
  }
494
- if (this.chartConfiguration.isDrilldownChart) {
495
- svg.selectAll('g.x1.axis1 g.tick line').style('display', 'none');
751
+ if (this.chartConfiguration.isXaxisColor) {
752
+ d3.selectAll('.multichart').style('color', this.chartConfiguration.isXaxisColor || 'var(--chart-text-color)');
496
753
  }
497
754
  }
498
- prepareBarData(d, keyList) {
499
- return keyList.map((key) => ({ key, value: d[key], name: d.name }));
500
- }
501
- handleBarClick(d, metaData) {
502
- if (d.key === 'Target')
503
- return;
504
- if (!metaData.barWithoutClick?.length ||
505
- (!metaData.barWithoutClick.includes(d?.name) && !metaData.barWithoutClick.includes(d?.key))) {
506
- this.handleClick(d);
755
+ applyAxisConfigurations(svg, scales, dimensions, data) {
756
+ if (this.chartConfiguration.isMultiChartGridLine !== undefined) {
757
+ d3.selectAll('.multichart > g > text').attr('class', 'lib-display-hidden');
507
758
  }
508
- }
509
- getBarX(d, data, x, xSubgroup) {
510
- if (this.chartConfiguration.isDrilldownChart) {
511
- return this.calculateDrilldownBarX(d, data, x);
512
- }
513
- return xSubgroup(d.key);
514
- }
515
- calculateDrilldownBarX(d, data, x) {
516
- let tempScale;
517
- data.forEach((indiv) => {
518
- if (indiv.name === d.name) {
519
- const keys = Object.keys(indiv).filter((temp, i) => i !== 0);
520
- tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);
521
- if (x.bandwidth() > 100) {
522
- tempScale = this.adjustDrilldownScale(tempScale, data, x);
523
- }
524
- }
525
- });
526
- return tempScale ? tempScale(d.key) : 0;
527
- }
528
- adjustDrilldownScale(tempScale, data, x) {
529
- if (this.chartData.data.length === 1) {
530
- const keysLength = Object.keys(this.chartData.data[0]).length;
531
- const offset = keysLength === 2 ? 200 : 300;
532
- tempScale.range([
533
- 0 + (x.bandwidth() - offset) / 2,
534
- x.bandwidth() - (x.bandwidth() - offset) / 2,
535
- ]);
759
+ if (this.chartConfiguration.isXaxisLabelHidden) {
760
+ d3.selectAll('.multichart > g > text').attr('class', 'lib-display-hidden');
536
761
  }
537
- else {
538
- tempScale.range([
539
- 0 + (x.bandwidth() - 125) / 2,
540
- x.bandwidth() - (x.bandwidth() - 125) / 2,
541
- ]);
762
+ else if (this.chartConfiguration.isXaxisLabelHidden !== undefined) {
763
+ this.renderCustomXAxis(svg, scales, dimensions, data);
542
764
  }
543
- return tempScale;
544
- }
545
- getBarWidth(d, data, x, xSubgroup) {
546
- if (this.chartConfiguration.isDrilldownChart) {
547
- let tempScale;
548
- data.forEach((indiv) => {
549
- if (indiv.name === d.name) {
550
- const keys = Object.keys(indiv).filter((temp, i) => i !== 0);
551
- tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);
552
- if (x.bandwidth() > 100) {
553
- tempScale = this.adjustDrilldownScale(tempScale, data, x);
554
- }
555
- }
556
- });
557
- return tempScale ? tempScale.bandwidth() : 0;
765
+ if (this.chartConfiguration.isYaxisLabelHidden) {
766
+ svg.selectAll('.yaxis-dashed > g > text').attr('class', 'lib-display-hidden');
558
767
  }
559
- return xSubgroup.bandwidth();
560
- }
561
- getBarHeight(d, y, height) {
562
- if (d.value === -1)
563
- return height - y(0);
564
- if (d.value)
565
- return height - y(d.value);
566
- return height - y(0);
567
- }
568
- getBarColor(d, metaData) {
569
- if (d.value &&
570
- this.chartData.targetLineData &&
571
- d.value >= parseInt(this.chartData.targetLineData.target) &&
572
- this.chartData.metaData.colorAboveTarget) {
573
- return this.chartData.metaData.colorAboveTarget[d.key];
768
+ if (this.chartConfiguration.isYaxisHidden) {
769
+ d3.selectAll('.yaxis-dashed').attr('class', 'lib-display-hidden');
574
770
  }
575
- return this.chartData.metaData.colors[d.key];
576
- }
577
- renderBarTexts(state, data, metaData, keyList, x, xSubgroup, y, isRia, svg) {
578
- state
579
- .selectAll('text')
580
- .data((d) => this.prepareBarData(d, keyList))
581
- .enter()
582
- .append('text')
583
- .attr('x', 0)
584
- .attr('y', 0)
585
- .attr('class', 'lib-data-labels-weeklycharts')
586
- .text((d) => this.getBarTextLabel(d))
587
- .style('fill', '#000')
588
- .style('font-weight', 'bold')
589
- .style('font-size', () => this.getBarTextFontSize())
590
- .attr('transform', (d) => this.getBarTextTransform(d, data, x, xSubgroup, y))
591
- .on('click', (d) => this.handleBarClick(d, metaData));
592
- if (!isRia) {
593
- state
594
- .selectAll('.lib-data-labels-weeklycharts')
595
- .on('mouseout', (d, i) => this.handleMouseOut(svg))
596
- .on('mouseover', (d, i) => this.handleMouseOver(svg, d, data, metaData, x, y, x.bandwidth()));
597
- }
598
- }
599
- getBarTextLabel(d) {
600
- if (!d.key || !d.value)
601
- return '';
602
- return d.key.length > 20 ? d.key.substring(0, 17) + '...' : d.key;
603
- }
604
- getBarTextFontSize() {
605
- if (this.chartConfiguration.isDrilldownChart) {
606
- if (window.innerWidth > 1900)
607
- return '18px';
608
- if (window.innerWidth < 1400)
609
- return '10px';
610
- return '14px';
611
- }
612
- return '14px';
613
- }
614
- getBarTextTransform(d, data, x, xSubgroup, y) {
615
- let tempScale;
616
- data.forEach((indiv) => {
617
- if (indiv.name === d.name) {
618
- const keys = Object.keys(indiv).filter((temp, i) => i !== 0);
619
- tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);
620
- if (x.bandwidth() > 100) {
621
- tempScale = this.adjustDrilldownScale(tempScale, data, x);
622
- }
623
- }
624
- });
625
- if (this.chartConfiguration.textAlwaysHorizontal) {
626
- return `translate(${xSubgroup(d.key)},${y(d.value) - 3})`;
771
+ if (this.isZoomedOut && data.length > 9) {
772
+ svg
773
+ .selectAll('.lib-xaxis-labels-texts-drilldown')
774
+ .attr('transform', 'rotate(-90)')
775
+ .attr('text-anchor', 'end')
776
+ .attr('x', '-5')
777
+ .attr('dy', null);
627
778
  }
628
- if (tempScale && !isNaN(tempScale(d.key))) {
629
- return `translate(${tempScale(d.key) + tempScale.bandwidth() * 0.55},${y(0) - 10}) rotate(270)`;
779
+ }
780
+ renderCustomXAxis(svg, scales, dimensions, data) {
781
+ svg
782
+ .append('g')
783
+ .attr('class', 'x1 axis1')
784
+ .attr('transform', `translate(0,${dimensions.height})`)
785
+ .style('color', '#000')
786
+ .call(d3.axisBottom(scales.xScale).tickSize(0))
787
+ .call((g) => g.select('.domain').attr('fill', 'none'));
788
+ this.styleCustomXAxisTicks(svg, data);
789
+ if (this.chartConfiguration.xLabelsOnSameLine) {
790
+ this.applyXLabelsOnSameLine(svg);
630
791
  }
631
- return 'translate(0,0)';
632
792
  }
633
- handleMouseOver(svg, d, data, metaData, x, y, leftAndRightSpaces) {
634
- svg.selectAll('.lib-verticalstack-title-ontop').remove();
635
- let tempScale;
636
- data.forEach((indiv) => {
637
- if (indiv.name === d.name) {
638
- const keys = Object.keys(indiv).filter((temp, i) => i !== 0);
639
- tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);
640
- if (x.bandwidth() > 100) {
641
- tempScale = this.adjustDrilldownScale(tempScale, data, x);
642
- }
793
+ styleCustomXAxisTicks(svg, data) {
794
+ let alternateText = false;
795
+ svg.selectAll('.x1.axis1 .tick line').attr('y2', () => {
796
+ if (this.chartConfiguration.hideXaxisTick)
797
+ return 0;
798
+ if (alternateText && !this.chartConfiguration.isNoAlternateXaxisText) {
799
+ alternateText = false;
800
+ return this.CONSTANTS.LONG_TICK_LENGTH_BG - 7;
643
801
  }
802
+ alternateText = true;
803
+ return this.CONSTANTS.SHORT_TICK_LENGTH_BG - 4;
644
804
  });
645
- const foreignObject = svg
646
- .append('foreignObject')
647
- .attr('x', () => this.calculateTooltipX(d, x, tempScale, metaData, leftAndRightSpaces))
648
- .attr('y', () => y(d.value) - 43)
649
- .attr('class', 'lib-verticalstack-title-ontop')
650
- .attr('width', () => this.calculateTooltipWidth(tempScale, metaData, leftAndRightSpaces))
651
- .attr('height', 40);
652
- foreignObject
653
- .append('xhtml:div')
654
- .attr('class', 'title')
655
- .style('z-index', 99)
656
- .html(() => this.getTooltipHTML(d, metaData));
657
- }
658
- calculateTooltipX(d, x, tempScale, metaData, leftAndRightSpaces) {
659
- if (metaData.hasDrillDown) {
660
- if (tempScale.bandwidth() + leftAndRightSpaces * 2 > 180) {
661
- return x(d.name) + tempScale(d.key) + tempScale.bandwidth() / 2 - 90;
805
+ alternateText = false;
806
+ svg
807
+ .selectAll('g.x1.axis1 g.tick text')
808
+ .attr('class', () => {
809
+ if (this.chartConfiguration.isDrilldownChart) {
810
+ return data.length > 8
811
+ ? 'lib-xaxis-labels-texts-drilldown-alt'
812
+ : 'lib-xaxis-labels-texts-drilldown';
662
813
  }
663
- return (x(d.name) +
664
- tempScale(d.key) -
665
- (tempScale.bandwidth() + leftAndRightSpaces * 2) / 2 +
666
- tempScale.bandwidth() / 2);
667
- }
668
- return (x(d.name) +
669
- tempScale(d.key) -
670
- (tempScale.bandwidth() + leftAndRightSpaces * 2) / 2 +
671
- tempScale.bandwidth() / 2);
672
- }
673
- calculateTooltipWidth(tempScale, metaData, leftAndRightSpaces) {
674
- if (metaData.hasDrillDown) {
675
- if (tempScale.bandwidth() + leftAndRightSpaces * 2 > 180) {
676
- return '180px';
814
+ return 'lib-xaxis-labels-texts-weeklycharts';
815
+ })
816
+ .attr('y', () => {
817
+ if (alternateText) {
818
+ alternateText = false;
819
+ return this.CONSTANTS.LONG_TICK_LENGTH_BG;
677
820
  }
678
- return tempScale.bandwidth() + leftAndRightSpaces * 2;
679
- }
680
- return tempScale.bandwidth() + leftAndRightSpaces * 2;
681
- }
682
- getTooltipHTML(d, metaData) {
683
- const dataType = metaData.dataType || '';
684
- if (!this.isZoomedOut) {
685
- return `<span class="title-bar-name">${d.name}</span><span class="title-bar-value"><span>${d.value}</span>${dataType}</span>`;
686
- }
687
- else {
688
- const tempKey = d.name.length <= 8 ? d.name : d.name.substring(0, 5) + '...';
689
- return `<span class="title-bar-name">${tempKey}:${d.value}${dataType}</span><span class="title-bar-value">${d.name}</span>`;
690
- }
691
- }
692
- handleMouseOut(svg) {
693
- svg.selectAll('.lib-verticalstack-title-ontop').remove();
694
- }
695
- renderLabels(svgElements, scales, chartContext, dimensions) {
696
- const { svg, svgYAxisLeft, svgYAxisRight } = svgElements;
697
- const { metaData } = chartContext;
698
- const { width, height, margin } = dimensions;
699
- if (metaData.yLabel) {
700
- this.renderYAxisLabel(svgYAxisLeft, metaData.yLabel, height, margin);
701
- }
702
- if (metaData.xLabel) {
703
- this.renderXAxisLabel(svg, metaData.xLabel, width, height, margin);
704
- }
705
- if (metaData.lineyLabel) {
706
- this.renderLineYAxisLabel(svgYAxisRight, metaData.lineyLabel);
707
- }
821
+ alternateText = true;
822
+ return this.CONSTANTS.SHORT_TICK_LENGTH_BG;
823
+ });
708
824
  }
709
- renderYAxisLabel(svgYAxisLeft, yLabel, height, margin) {
710
- svgYAxisLeft
825
+ applyXLabelsOnSameLine(svg) {
826
+ svg
827
+ .selectAll('g.x1.axis1 g.tick text')
828
+ .attr('class', 'lib-xaxis-labels-texts-drilldown')
829
+ .attr('y', this.CONSTANTS.SHORT_TICK_LENGTH_BG)
830
+ .text((d) => {
831
+ const trimmed = d.trim();
832
+ const spaceIndex = trimmed.indexOf(' ');
833
+ return spaceIndex > -1
834
+ ? trimmed.substring(0, spaceIndex).toLowerCase()
835
+ : trimmed.toLowerCase();
836
+ });
837
+ svg
838
+ .selectAll('g.x1.axis1 g.tick')
711
839
  .append('text')
712
- .attr('class', 'lib-axis-group-label font-size-1')
713
- .attr('style', this.chartConfiguration.yAxisCustomlabelStyles)
714
- .attr('transform', 'rotate(-90)')
715
- .attr('y', 0 - margin.left / 2 - 30)
716
- .attr('x', 0 - height / 2)
717
- .attr('dy', '1em')
718
- .style('text-anchor', 'middle')
719
- .attr('fill', 'var(--chart-text-color)');
720
- if (this.chartConfiguration.isMultiChartGridLine === undefined) {
721
- svgYAxisLeft.selectAll('.lib-axis-group-label').style('font-size', 'smaller').text(yLabel);
722
- }
723
- else {
724
- svgYAxisLeft
725
- .selectAll('.lib-axis-group-label')
726
- .attr('class', 'lib-ylabel-weeklyCharts')
727
- .text(yLabel.toLowerCase());
728
- }
840
+ .attr('class', 'lib-xaxis-labels-texts-drilldown')
841
+ .attr('y', this.CONSTANTS.LONG_TICK_LENGTH_BG)
842
+ .attr('fill', 'currentColor')
843
+ .text((d) => {
844
+ const trimmed = d.trim();
845
+ const spaceIndex = trimmed.indexOf(' ');
846
+ return spaceIndex > -1
847
+ ? trimmed.substring(spaceIndex).toLowerCase()
848
+ : '';
849
+ });
729
850
  }
730
- renderXAxisLabel(svg, xLabel, width, height, margin) {
731
- const isAcronym = this.isAcronym(xLabel.replace(/[^A-Za-z]/g, ''));
732
- let baseClass = 'lib-axis-group-label font-size-1';
733
- if (this.chartConfiguration.isDrilldownChart) {
734
- baseClass += ' lib-xlabel-drilldowncharts';
851
+ renderDataLabels(rect, scales, metaData, dimensions) {
852
+ if (!this.isCC && !this.chartConfiguration.isMultiChartGridLine) {
853
+ rect.append('svg:title').text((d) => d[1] - d[0]);
735
854
  }
736
- else if (this.chartConfiguration.isMultiChartGridLine !== undefined) {
737
- baseClass += ' lib-xlabel-weeklyCharts';
855
+ if (this.chartConfiguration.showTotalOnTop) {
856
+ this.renderTopLabels(rect, scales, metaData);
738
857
  }
739
- else {
740
- baseClass += ' lib-axis-waterfall-label';
858
+ if (this.chartConfiguration.showAngledLabels) {
859
+ this.renderAngledLabels(rect, scales, metaData);
741
860
  }
742
- svg
743
- .append('text')
744
- .attr('class', baseClass)
745
- .attr('style', this.chartConfiguration.xAxisCustomlabelStyles)
746
- .attr('transform', `translate(${width / 2},${height + margin.top + 20})`)
747
- .style('text-anchor', 'middle')
748
- .style('fill', 'var(--chart-text-color)')
749
- .text(isAcronym ? xLabel.toUpperCase() : xLabel.toLowerCase())
750
- .style('text-transform', isAcronym ? 'none' : 'capitalize');
751
861
  }
752
- isAcronym(label) {
753
- return ((label.length <= 4 && /^[A-Z]+$/.test(label)) ||
754
- (label === label.toUpperCase() && /[A-Z]/.test(label)));
862
+ renderTopLabels(rect, scales, metaData) {
863
+ const formatFromBackend = this.chartConfiguration.textFormatter
864
+ ? ChartHelper.dataValueFormatter(this.chartConfiguration.textFormatter)
865
+ : (d) => d;
866
+ const formatForHugeNumbers = ChartHelper.dataValueFormatter('.2s');
867
+ rect
868
+ .append('text')
869
+ .attr('x', (d) => scales.xScale(d.data.name) + scales.xScale.bandwidth() / 2)
870
+ .attr('class', 'lib-verticalstack-labels-ontop-weklycharts')
871
+ .attr('y', (d) => scales.yScale(d[1]) - 3)
872
+ .text((d) => {
873
+ const value = d[1] - d[0];
874
+ if (isNaN(value) || value === 0)
875
+ return;
876
+ const formattedValue = value <= 999
877
+ ? formatFromBackend(value)
878
+ : formatForHugeNumbers(value);
879
+ return metaData.unit ? metaData.unit + formattedValue : formattedValue;
880
+ });
755
881
  }
756
- renderLineYAxisLabel(svgYAxisRight, lineyLabel) {
757
- svgYAxisRight
882
+ renderAngledLabels(rect, scales, metaData) {
883
+ const formatFromBackend = this.chartConfiguration.textFormatter
884
+ ? ChartHelper.dataValueFormatter(this.chartConfiguration.textFormatter)
885
+ : (d) => d;
886
+ const formatForHugeNumbers = ChartHelper.dataValueFormatter('.2s');
887
+ const tempObjectHolder = {};
888
+ rect
758
889
  .append('text')
759
- .attr('class', 'lib-axis-group-label lib-line-axis')
760
- .attr('style', this.chartConfiguration.yAxisCustomlabelStyles)
761
- .attr('transform', 'translate(0,0) rotate(90)')
762
- .attr('y', -100)
763
- .attr('x', 100)
764
- .attr('dy', '5em')
765
- .style('text-anchor', 'middle')
766
- .style('font-size', 'smaller')
767
- .text(lineyLabel);
890
+ .attr('x', 0)
891
+ .attr('y', 0)
892
+ .attr('fill', (d) => metaData.colors[d.key])
893
+ .attr('class', 'lib-data-labels-angled-weeklycharts')
894
+ .text((d) => {
895
+ const value = d[1] - d[0];
896
+ if (isNaN(value) || value <= 0)
897
+ return;
898
+ const formattedValue = value <= 999
899
+ ? formatFromBackend(value)
900
+ : formatForHugeNumbers(value);
901
+ return metaData.unit ? metaData.unit + formattedValue : formattedValue;
902
+ })
903
+ .attr('transform', (d) => {
904
+ const value = d[1] - d[0];
905
+ if (isNaN(value) || value <= 0)
906
+ return 'rotate(0)';
907
+ let total = 0;
908
+ let incrementer = 1;
909
+ metaData.keyList.forEach(key => {
910
+ if (d.data[key]) {
911
+ total += d.data[key];
912
+ }
913
+ else {
914
+ incrementer = 2;
915
+ }
916
+ });
917
+ tempObjectHolder[d.data.name] = (tempObjectHolder[d.data.name] || 0) + incrementer;
918
+ const position = tempObjectHolder[d.data.name];
919
+ const xPos = scales.xScale(d.data.name);
920
+ const bandwidth = scales.xScale.bandwidth();
921
+ const yPos = scales.yScale(total) - 3;
922
+ switch (position) {
923
+ case 1:
924
+ return `translate(${xPos + bandwidth / 3},${yPos}) rotate(270)`;
925
+ case 2:
926
+ return `translate(${xPos + bandwidth / 2 + 2},${yPos}) rotate(270)`;
927
+ default:
928
+ return `translate(${xPos + (bandwidth * 3) / 4},${yPos}) rotate(270)`;
929
+ }
930
+ });
768
931
  }
769
- renderTargetLine(svgElements, scales, chartContext, dimensions) {
932
+ renderTargetLine(svg, svgYAxisRight, scales, dimensions, metaData) {
770
933
  if (!this.chartData.targetLineData)
771
934
  return;
772
- const { svg, svgYAxisRight } = svgElements;
773
- const { y } = scales;
774
- const { width } = dimensions;
775
- const { metaData } = chartContext;
776
- const targetData = this.chartData.targetLineData;
777
- const yZero = y(targetData.target);
935
+ const parsedTarget = this.parseTargetValue(this.chartData.targetLineData.target);
936
+ const yZero = scales.yScale(parsedTarget);
778
937
  svg
779
938
  .append('line')
780
939
  .attr('x1', 0)
781
- .attr('x2', width)
940
+ .attr('x2', dimensions.width)
782
941
  .attr('y1', yZero)
783
942
  .attr('y2', yZero)
784
943
  .style('stroke-dasharray', '5 5')
785
- .style('stroke', targetData.color);
786
- const rightSvgWidth = 60;
944
+ .style('stroke', this.chartData.targetLineData.color);
945
+ this.renderTargetLabel(svgYAxisRight, yZero, metaData);
946
+ }
947
+ parseTargetValue(target) {
948
+ const parsed = parseFloat(String(target));
949
+ if (isNaN(parsed))
950
+ return 0;
951
+ return Number.isInteger(parsed) ? parseInt(String(target)) : parsed;
952
+ }
953
+ renderTargetLabel(svgYAxisRight, yZero, metaData) {
954
+ const dataType = metaData.dataType || '';
955
+ const targetName = this.chartData.targetLineData.targetName || 'target';
787
956
  svgYAxisRight
788
957
  .append('foreignObject')
789
- .attr('transform', `translate(0,${yZero - 30})`)
790
- .attr('width', rightSvgWidth)
958
+ .attr('transform', `translate(0,${yZero - 13})`)
959
+ .attr('width', this.CONSTANTS.RIGHT_SVG_WIDTH)
791
960
  .attr('height', 50)
792
961
  .append('xhtml:div')
793
962
  .attr('class', 'target-display')
794
963
  .style('color', 'var(--chart-text-color)')
795
- .html(() => {
796
- const dataType = metaData.dataType || '';
797
- const targetName = targetData.targetName || 'target';
798
- return `<div>${targetName}</div><div>${targetData.target}${dataType}</div>`;
799
- });
964
+ .html(`<div>${targetName}</div><div>${this.chartData.targetLineData.target}${dataType}</div>`);
800
965
  }
801
- renderLineGraph(svg, chartContext, scales) {
802
- const { lineData, metaData } = chartContext;
803
- if (!lineData)
966
+ renderLineChart(svg, lineData, scales, colors, metaData) {
967
+ if (!lineData || !colors)
804
968
  return;
805
- const { x, lineYscale } = scales;
806
- svg
807
- .append('path')
808
- .datum(lineData)
809
- .attr('fill', 'none')
810
- .attr('stroke', this.chartConfiguration.lineGraphColor)
811
- .attr('stroke-width', 1.5)
812
- .attr('d', d3
969
+ const dataGroup = d3
970
+ .nest()
971
+ .key((d) => d.category)
972
+ .entries(lineData);
973
+ const lineGen = d3
813
974
  .line()
814
- .x((d) => x(d.name) + x.bandwidth() / 2)
815
- .y((d) => lineYscale(d.value)));
975
+ .x((d) => scales.xScale(d.name) + scales.xScale.bandwidth() / 2)
976
+ .y((d) => scales.lineYscale(d.value));
977
+ dataGroup.forEach((group) => {
978
+ svg
979
+ .append('path')
980
+ .datum(group.values)
981
+ .attr('fill', 'none')
982
+ .attr('stroke', (d) => {
983
+ return d[0]?.category
984
+ ? colors[d[0].category]
985
+ : this.chartConfiguration.lineGraphColor;
986
+ })
987
+ .attr('stroke-width', 2.5)
988
+ .attr('d', lineGen);
989
+ this.renderLineDots(svg, group.values, scales, colors);
990
+ });
991
+ }
992
+ renderLineDots(svg, values, scales, colors) {
816
993
  const dot = svg
817
- .selectAll('myCircles')
818
- .data(lineData)
994
+ .selectAll('.line-dots')
995
+ .data(values)
819
996
  .enter()
820
997
  .append('g')
821
- .on('click', (d) => this.handleBarClick(d, metaData));
998
+ .on('click', (d) => this.handleClick(d));
822
999
  dot
823
1000
  .append('circle')
824
- .attr('fill', this.chartConfiguration.lineGraphColor)
1001
+ .attr('fill', (d) => {
1002
+ return d.category
1003
+ ? colors[d.category]
1004
+ : this.chartConfiguration.lineGraphColor;
1005
+ })
825
1006
  .attr('stroke', 'none')
826
- .attr('cx', (d) => x(d.name) + x.bandwidth() / 2)
827
- .attr('cy', (d) => lineYscale(d.value))
828
- .style('cursor', 'pointer')
829
- .attr('r', 3);
1007
+ .attr('cx', (d) => scales.xScale(d.name) + scales.xScale.bandwidth() / 2)
1008
+ .attr('cy', (d) => scales.lineYscale(d.value))
1009
+ .attr('r', 3)
1010
+ .style('cursor', 'pointer');
830
1011
  if (this.chartConfiguration.lineGraphColor) {
831
1012
  dot
832
1013
  .append('text')
833
- .attr('class', 'dot')
834
- .attr('color', this.chartConfiguration.lineGraphColor)
835
- .attr('style', 'font-size: .85em')
836
- .attr('x', (d) => x(d.name) + x.bandwidth() / 2)
837
- .attr('y', (d) => lineYscale(d.value))
1014
+ .attr('class', 'dots')
1015
+ .attr('fill', this.chartConfiguration.lineGraphColor)
1016
+ .style('font-size', '.85em')
1017
+ .style('font-weight', 'bold')
1018
+ .attr('x', (d) => scales.xScale(d.name) + scales.xScale.bandwidth() / 2)
1019
+ .attr('y', (d) => scales.lineYscale(d.value))
838
1020
  .attr('dy', '-1em')
839
1021
  .text((d) => this.chartConfiguration.labelFormatter(d.value));
840
1022
  }
841
1023
  }
842
1024
  handleClick(d) {
843
- if (this.chartData.metaData.hasDrillDown || d?.toggleFrom) {
1025
+ if (this.chartData?.metaData?.hasDrillDown || d?.toggleFrom) {
844
1026
  this.clickEvent.emit(d);
845
1027
  }
846
1028
  }
847
1029
  handleHeaderMenuClick(id) {
848
1030
  this.headerMenuclickEvent.emit(id);
849
1031
  }
850
- handleDD1Click(event) {
851
- this.isDD1Open = true;
852
- this.isDD2Open = false;
853
- }
854
- handleDD2Click(event) {
855
- this.isDD2Open = true;
856
- this.isDD1Open = false;
857
- }
858
1032
  handleCompareByFilterSelection(event) {
859
1033
  this.clickEvent.emit(event);
860
1034
  }
1035
+ handleZoominZoomoutClick({ isZoomOut, event }) {
1036
+ this.isZoomOutSelected(isZoomOut);
1037
+ }
861
1038
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: GroupChartComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
862
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: GroupChartComponent, selector: "lib-group-chart", inputs: { chartData: "chartData", customChartConfiguration: "customChartConfiguration" }, outputs: { clickEvent: "clickEvent", headerMenuclickEvent: "headerMenuclickEvent" }, viewQueries: [{ propertyName: "containerElt", first: true, predicate: ["groupchartcontainer"], descendants: true, static: true }, { propertyName: "groupcontainerElt", first: true, predicate: ["groupcontainer"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<div\r\n #groupcontainer\r\n class=\"lib-chart-wrapper\"\r\n [ngClass]=\"{ 'lib-no-background': isTransparentBackground }\"\r\n style=\"background-color: var(--card-bg);\"\r\n (resized)=\"onResized($event)\"\r\n>\r\n\r\n<div class=\"header-alt\" *ngIf=\"!isHeaderVisible\">\r\n <lib-chart-header-v2\r\n [chartData]=\"chartData\"\r\n [chartConfiguration]=\"chartConfiguration\"\r\n (clickEvent)=\"handleClick($event)\"\r\n ></lib-chart-header-v2>\r\n <lib-chart-header-v3\r\n [chartData]=\"chartData\"\r\n [chartConfiguration]=\"chartConfiguration\"\r\n (compareByFilterSelection)=\"handleCompareByFilterSelection($event)\"\r\n (zoomInZoomOutClick)=\"handleZoominZoomoutClick($event)\"\r\n ></lib-chart-header-v3>\r\n</div>\r\n\r\n <lib-chart-header-v1\r\n [title]=\"chartData.metaData.title\"\r\n [hasDrillDown]=\"chartData.metaData.hasDrillDown\"\r\n [isEditEnabled]=\"chartData.metaData.isEditEnabled\"\r\n [menuOptions]=\"chartConfiguration.headerMenuOptions\"\r\n [isria]=\"customChartConfiguration.isRia\"\r\n [selectedKpiTooltop]=\"chartConfiguration.selectedKpiTooltop\"\r\n (menuOptionClickEvent)=\"handleHeaderMenuClick($event)\"\r\n [isAlertEnabled]=\"isAlertEnabled\"\r\n *ngIf=\"isHeaderVisible\"\r\n></lib-chart-header-v1>\r\n\r\n <div\r\n [style.height]=\"chartConfiguration.svgHeight\"\r\n id=\"groupchartcontainer\"\r\n #groupchartcontainer\r\n class=\"lib-chart-svg\"\r\n ></div>\r\n</div>\r\n", styles: [".lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-weight:400;letter-spacing:0px;color:#000;opacity:1;font-size:1.2em}.lib-axis-group-label{font-size:.85em;font-weight:600;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:0px;color:#000;opacity:1}.dots{font-size:10px}.inline__display{display:flex;justify-content:space-around;padding-top:2%}.verticalbar__text{font-style:normal;font-variant:normal;font-weight:400;font-size:13px;line-height:20px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:0px;opacity:1}.lib-line-label-item{display:inline-block!important;font-size:.85em;margin-right:10px;font-weight:600}.lib-line-label-wrapper-vertical{display:flex;justify-content:center}.target-display{font-size:12px;line-height:14.52px;font-weight:700;text-transform:uppercase;float:right}.title{background-color:#d9d9d9;height:35px;display:flex;flex-direction:column;justify-content:center;align-items:center;border-radius:3px;line-height:1}.title:after{content:\"\";position:absolute;bottom:0;left:50%;margin-left:-10px;width:0;height:0;border-top:solid 10px #d3d3d3;border-left:solid 10px transparent;border-right:solid 10px transparent}.title-top-text{color:#000;font-size:14px;font-weight:600}.title-bar-name{color:#000;font-size:12px;font-weight:700;text-transform:capitalize}.title-bottom-text{color:#4f4f4f;font-size:12px}.zoomIcons-holder{display:flex;align-items:center;margin-right:15px}.zoomIcons{border:.5px solid #b6b6b6;cursor:pointer;display:flex;justify-content:center;align-items:center;width:30px;height:30px;color:var(--color)!important}.zoom-active{background-color:#2d5ca0;opacity:1}.zoom-inactive{background-color:#d9d9d9;opacity:.5}@media screen and (min-width: 1024px) and (min-height: 400px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:10px!important}.dots{font-size:10px!important}}@media screen and (min-width: 1024px) and (min-height: 1000px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:10px!important}.dots{font-size:10px!important}}@media screen and (min-width: 1024px) and (min-height: 1500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:10px!important}.dots{font-size:10px!important}}@media screen and (min-width: 1366px) and (min-height: 400px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:12px!important}.dots{font-size:12px!important}}@media screen and (min-width: 1366px) and (min-height: 1000px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:12px!important}.dots{font-size:12px!important}}@media screen and (min-width: 1366px) and (min-height: 1500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:12px!important}.dots{font-size:12px!important}}@media screen and (min-width: 1920px) and (min-height: 400px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:14px!important}.dots{font-size:14px!important}}@media screen and (min-width: 1920px) and (min-height: 1000px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:14px!important}.dots{font-size:14px!important}}@media screen and (min-width: 1920px) and (min-height: 1500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:14px!important}.dots{font-size:14px!important}}@media screen and (min-width: 2560px) and (min-height: 500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:16px!important}.dots{font-size:16px!important}}@media screen and (min-width: 2560px) and (min-height: 1000px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:16px!important}.dots{font-size:16px!important}}@media screen and (min-width: 2560px) and (min-height: 1500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:16px!important}}.bottom__text{position:absolute!important;bottom:0!important;display:flex!important;justify-content:center!important;align-items:center!important;width:100%!important}.box__heightwidth{opacity:1;height:10px;width:10px;border:none!important;border-radius:50%}.label__text{margin-right:10px;display:flex;justify-content:center;align-items:center;font-style:normal;font-variant:normal;font-weight:400;font-size:10px;line-height:13px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;letter-spacing:.2px;color:#707070!important}.lib-verticalstack-labels-ontop-weklycharts{font-style:normal;font-variant:normal;font-weight:700;font-size:10px;line-height:11px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.05px;text-anchor:middle;fill:#000}.lib-verticalstack-title-ontop{font-style:normal;font-variant:normal;font-size:14px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.05px;text-anchor:middle;fill:#000}.marginLeft-20{margin-left:20px}.flex-inline{display:flex;justify-content:center;align-items:center;font-size:14px}\n", ".lib-chart-wrapper{width:100%;height:100%;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;background:#fff 0% 0% no-repeat padding-box;position:relative}.lib-chart-wrapper-wo-shadow{width:100%;height:100%;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto}.lib-chart-wrapper:hover .chart-header-v1:not(.header-no-background){background-color:#2e3640}.lib-chart-wrapper:hover .chart-header-v1:not(.header-no-background) .chart-title{color:#fff}.lib-chart-svg{width:100%}.lib-chart-header{text-align:center;background-color:#052340;color:#fff;width:100%;height:17%;word-spacing:.5px;line-height:1.8;font-weight:700;padding-top:2%;letter-spacing:0;font-size:1.2em}.lib-donut-chart-footer{width:100%;text-align:right}.lib-donut-label-text{font-size:.9em;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-weight:400;letter-spacing:0px;color:#000;opacity:1}.lib-donut-label-icon{display:inline-block;width:10px;height:10px;margin-right:20px;border-radius:3px}.lib-donut-label-item{font-weight:400;font-size:.85em;color:#2f2f2f}.lib-donut-justified-label-wrapper{width:100%;display:inline-block;text-align:center;list-style-type:none}.lib-donut-justified-label-item{font-weight:400;font-size:.85em;color:#2f2f2f;display:inline-block;text-align:left;padding:0 10px}.lib-donut-justified-label-icon{display:inline-block;width:10px;height:10px;margin-right:5px;border-radius:3px}.lib-no-background{background:none!important}.lib-display-hidden{display:none}.lib-ylabel-weeklyCharts{font-style:normal;font-variant:normal;font-weight:800;font-size:10px;line-height:12px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.07px;text-transform:capitalize;color:#000}.lib-data-labels-weeklycharts{font-style:normal;font-variant:normal;font-weight:400;font-size:12px;line-height:14px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.06px;color:#000}.lib-data-labels-angled-weeklycharts{font-style:normal;font-variant:normal;font-weight:800;font-size:9.5px;line-height:11px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:.4px;text-anchor:start}.lib-xaxis-labels-texts-weeklycharts{font-style:normal;font-variant:normal;font-weight:800;font-size:10px;line-height:11px;letter-spacing:-.05px;fill:#000}.lib-xaxis-labels-texts-drilldown{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:14px;letter-spacing:-1px;color:#000;opacity:1;text-transform:capitalize}.lib-white-space-nowrap{white-space:nowrap}.lib-xaxis-labels-texts-drilldown-alt{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:10px;letter-spacing:0px;color:#000;opacity:1;text-transform:capitalize}.lib-yaxis-labels-texts-drilldown{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:14px;letter-spacing:0px;color:#000!important;opacity:1}.lib-ylabel-drilldowncharts,.lib-xlabel-drilldowncharts{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:16px;letter-spacing:-.1px;color:#000!important;opacity:1}.lib-donut-justified-label-icon-drilldown{display:inline-block;width:14px;height:14px;margin-right:10px;border-radius:50%}.marginright-2{margin-right:2%}.margintop-5{margin-top:5%}.width-100{width:100%}.float-right{float:right}.marginBottom-10{margin-bottom:10px}.header-alt{align-items:center;margin-bottom:10px}input::placeholder{font-size:20px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:0px;color:#000;opacity:1}.padding-5{padding:5px}.hidden{visibility:hidden}.font-weight-bold{font-weight:900}.textalign-center{text-align:center}.cursor-pointer{cursor:pointer}.cursor-default{cursor:default}.font-weight-600{font-weight:600}.marginRight-15{margin-right:15px}.marginRight-20{margin-right:20px}.switch{position:relative;display:inline-block;width:46px;height:24px;margin-left:5px;margin-right:5px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:#2d5ca0;-webkit-transition:.4s;transition:.4s}.slider:before{position:absolute;content:\"\";height:18px;width:18px;right:3px;bottom:3px;background-color:#fff;-webkit-transition:.4s;transition:.4s}.slider.round{border-radius:18px}.slider.round:before{border-radius:50%}.slider1{position:absolute;cursor:pointer;inset:0;background-color:#015ba2cf;-webkit-transition:.4s;transition:.4s}.slider1:before{position:absolute;content:\"\";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;-webkit-transition:.4s;transition:.4s}.slider1.round1{border-radius:18px}.slider1.round1:before{border-radius:50%}.lib-display-flex{display:flex}.lib-align-items-center{align-items:center}.lib-flex-direction-column{flex-direction:column}.lib-justify-content-space-between{justify-content:space-between}.lib-justify-content-space-around{justify-content:space-around}.lib-justify-content-center{justify-content:center}.lib-justify-content-start{justify-content:start}.lib-justify-content-end{justify-content:end}.lib-ml-20{margin-left:20px}.lib-position-absolute{position:absolute}.lib-z-index-9{z-index:9}.marginright-3{margin-right:3px}@media (min-height: 900px){.lib-chart-wrapper{border-radius:8px}.header-font-size-1{font-size:18px!important}.font-size-1{font-size:14px!important}.font-size-2{font-size:16px!important}.font-size-3{font-size:14px!important}.font-size-4{font-size:22px!important}.font-size-5{font-size:24px!important}}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.ResizedDirective, selector: "[resized]", outputs: ["resized"] }, { kind: "component", type: i3.ChartHeaderV1Component, selector: "lib-chart-header-v1", inputs: ["isAlertEnabled", "title", "menuOptions", "isEditEnabled", "isria", "hasDrillDown", "selectedKpiTooltop"], outputs: ["menuOptionClickEvent"] }, { kind: "component", type: i4.ChartHeaderV2Component, selector: "lib-chart-header-v2", inputs: ["chartData", "chartConfiguration"], outputs: ["clickEvent", "zoomInZoomOutClick"] }, { kind: "component", type: i5.ChartHeaderV3Component, selector: "lib-chart-header-v3", inputs: ["chartData", "chartConfiguration"], outputs: ["compareByFilterSelection", "zoomInZoomOutClick"] }], encapsulation: i0.ViewEncapsulation.None }); }
1039
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: GroupChartComponent, selector: "lib-group-chart", inputs: { chartData: "chartData", customChartConfiguration: "customChartConfiguration" }, outputs: { clickEvent: "clickEvent", headerMenuclickEvent: "headerMenuclickEvent" }, viewQueries: [{ propertyName: "containerElt", first: true, predicate: ["groupchartcontainer"], descendants: true, static: true }, { propertyName: "groupcontainerElt", first: true, predicate: ["groupcontainer"], descendants: true, static: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div\r\n #groupcontainer\r\n class=\"lib-chart-wrapper\"\r\n [ngClass]=\"{ 'lib-no-background': isTransparentBackground }\"\r\n style=\"background-color: var(--card-bg);\"\r\n (resized)=\"onResized($event)\"\r\n>\r\n\r\n<div class=\"header-alt\" *ngIf=\"!isHeaderVisible\">\r\n <lib-chart-header-v2\r\n [chartData]=\"chartData\"\r\n [chartConfiguration]=\"chartConfiguration\"\r\n (clickEvent)=\"handleClick($event)\"\r\n ></lib-chart-header-v2>\r\n <lib-chart-header-v3\r\n [chartData]=\"chartData\"\r\n [chartConfiguration]=\"chartConfiguration\"\r\n (compareByFilterSelection)=\"handleCompareByFilterSelection($event)\"\r\n (zoomInZoomOutClick)=\"handleZoominZoomoutClick($event)\"\r\n ></lib-chart-header-v3>\r\n</div>\r\n\r\n <lib-chart-header-v1\r\n [title]=\"chartData.metaData.title\"\r\n [hasDrillDown]=\"chartData.metaData.hasDrillDown\"\r\n [isEditEnabled]=\"chartData.metaData.isEditEnabled\"\r\n [menuOptions]=\"chartConfiguration.headerMenuOptions\"\r\n [isria]=\"customChartConfiguration.isRia\"\r\n [selectedKpiTooltop]=\"chartConfiguration.selectedKpiTooltop\"\r\n (menuOptionClickEvent)=\"handleHeaderMenuClick($event)\"\r\n [isAlertEnabled]=\"isAlertEnabled\"\r\n *ngIf=\"isHeaderVisible\"\r\n></lib-chart-header-v1>\r\n\r\n <div\r\n [style.height]=\"chartConfiguration.svgHeight\"\r\n id=\"groupchartcontainer\"\r\n #groupchartcontainer\r\n class=\"lib-chart-svg\"\r\n ></div>\r\n</div>\r\n", styles: [".lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-weight:400;letter-spacing:0px;color:#000;opacity:1;font-size:12px}.lib-axis-group-label{font-size:12px;font-weight:600;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:0px;color:#000;opacity:1}.dots{font-size:10px}.inline__display{display:flex;justify-content:space-around;padding-top:2%}.verticalbar__text{font-style:normal;font-variant:normal;font-weight:400;font-size:13px;line-height:20px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:0px;opacity:1}.lib-line-label-item{display:inline-block!important;font-size:.85em;margin-right:10px;font-weight:600}.lib-line-label-wrapper-vertical{display:flex;justify-content:center}.target-display{font-size:11px;line-height:13px;font-weight:700;text-transform:uppercase;float:right}.title{background-color:#d9d9d9;height:40px;display:flex;flex-direction:column;justify-content:center;align-items:center;border-radius:3px;line-height:1;padding:4px 8px;box-sizing:border-box}.title-top-text{color:var(--font-color)!important;font-size:12px;font-weight:600}.title-bar-name{color:var(--font-color)!important;font-size:14px;font-weight:700;text-transform:capitalize}.title-bottom-text{color:var(--font-color)!important;font-size:11px}.zoomIcons-holder{display:flex;align-items:center;margin-right:15px}.zoomIcons{border:.5px solid #b6b6b6;cursor:pointer;display:flex;justify-content:center;align-items:center;width:30px;height:30px;color:var(--color)!important}.zoom-active{background-color:#2d5ca0;opacity:1}.zoom-inactive{background-color:#d9d9d9;opacity:.5}.bottom__text{position:absolute!important;bottom:0!important;display:flex!important;justify-content:center!important;align-items:center!important;width:100%!important}.box__heightwidth{opacity:1;height:10px;width:10px;border:none!important;border-radius:50%}.label__text{margin-right:10px;display:flex;justify-content:center;align-items:center;font-style:normal;font-variant:normal;font-weight:400;font-size:10px;line-height:13px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;letter-spacing:.2px;color:#707070!important}.lib-verticalstack-labels-ontop-weklycharts{font-style:normal;font-variant:normal;font-weight:700;font-size:10px;line-height:11px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.05px;text-anchor:middle;fill:#000}.lib-verticalstack-title-ontop{font-style:normal;font-variant:normal;font-size:14px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.05px;text-anchor:middle;fill:#000}.marginLeft-20{margin-left:20px}.flex-inline{display:flex;justify-content:center;align-items:center;font-size:14px}.lib-xaxis-labels-texts-drilldown,.lib-xaxis-labels-texts-drilldown-alt,.lib-xaxis-labels-texts-weeklycharts{font-size:12px}.lib-display-hidden{display:none!important}.chart-wrapper-main{position:relative;width:100%;box-sizing:border-box}.left-axis-container,.right-axis-container{pointer-events:none;overflow:hidden;-webkit-user-select:none;user-select:none}.scrollable-chart-container{-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:#888 #f1f1f1}.scrollable-chart-container::-webkit-scrollbar{height:8px}.scrollable-chart-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.scrollable-chart-container::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.scrollable-chart-container::-webkit-scrollbar-thumb:hover{background:#555}.inner-chart-container{position:relative}.grid line{stroke-width:1;shape-rendering:crispEdges}.horizontal-grid line{stroke-opacity:.7}.vertical-grid line{stroke-opacity:.7}.lib-y-axis-hidden{opacity:0!important;pointer-events:none}.lib-stacked-x-axis-text .domain{stroke:var(--chart-axis-color);stroke-width:1px}.lib-stacked-x-axis-text text{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-weight:400;font-size:12px;fill:var(--chart-text-color)}.lib-stacked-y-axis-text .domain{stroke:var(--chart-axis-color);stroke-width:1px}.lib-stacked-y-axis-text text{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-weight:400;font-size:12px;fill:var(--chart-text-color)}@media (max-width: 1024px){.scrollable-chart-container::-webkit-scrollbar{height:6px}.lib-stacked-x-axis-text text{font-size:10px}}@media (max-width: 768px){.scrollable-chart-container::-webkit-scrollbar{height:4px}}.left-axis-container svg{pointer-events:none;overflow:visible!important}.horizontal-grid-from-left line{pointer-events:none}\n", ".lib-chart-wrapper{width:100%;height:100%;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;background:#fff 0% 0% no-repeat padding-box;position:relative}.lib-chart-wrapper-wo-shadow{width:100%;height:100%;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto}.lib-chart-wrapper:hover .chart-header-v1:not(.header-no-background){background-color:#2e3640}.lib-chart-wrapper:hover .chart-header-v1:not(.header-no-background) .chart-title{color:#fff}.lib-chart-svg{width:100%}.lib-chart-header{text-align:center;background-color:#052340;color:#fff;width:100%;height:17%;word-spacing:.5px;line-height:1.8;font-weight:700;padding-top:2%;letter-spacing:0;font-size:1.2em}.lib-donut-chart-footer{width:100%;text-align:right}.lib-donut-label-text{font-size:.9em;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-weight:400;letter-spacing:0px;color:#000;opacity:1}.lib-donut-label-icon{display:inline-block;width:10px;height:10px;margin-right:20px;border-radius:3px}.lib-donut-label-item{font-weight:400;font-size:.85em;color:#2f2f2f}.lib-donut-justified-label-wrapper{width:100%;display:inline-block;text-align:center;list-style-type:none}.lib-donut-justified-label-item{font-weight:400;font-size:.85em;color:#2f2f2f;display:inline-block;text-align:left;padding:0 10px}.lib-donut-justified-label-icon{display:inline-block;width:10px;height:10px;margin-right:5px;border-radius:3px}.lib-no-background{background:none!important}.lib-display-hidden{display:none}.lib-ylabel-weeklyCharts{font-style:normal;font-variant:normal;font-weight:800;font-size:10px;line-height:12px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.07px;text-transform:capitalize;color:#000}.lib-data-labels-weeklycharts{font-style:normal;font-variant:normal;font-weight:400;font-size:12px;line-height:14px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.06px;color:#000}.lib-data-labels-angled-weeklycharts{font-style:normal;font-variant:normal;font-weight:800;font-size:9.5px;line-height:11px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:.4px;text-anchor:start}.lib-xaxis-labels-texts-weeklycharts{font-style:normal;font-variant:normal;font-weight:800;font-size:10px;line-height:11px;letter-spacing:-.05px;fill:#000}.lib-xaxis-labels-texts-drilldown{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:14px;letter-spacing:-1px;color:#000;opacity:1;text-transform:capitalize}.lib-white-space-nowrap{white-space:nowrap}.lib-xaxis-labels-texts-drilldown-alt{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:10px;letter-spacing:0px;color:#000;opacity:1;text-transform:capitalize}.lib-yaxis-labels-texts-drilldown{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:14px;letter-spacing:0px;color:#000!important;opacity:1}.lib-ylabel-drilldowncharts,.lib-xlabel-drilldowncharts{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:16px;letter-spacing:-.1px;color:#000!important;opacity:1}.lib-donut-justified-label-icon-drilldown{display:inline-block;width:14px;height:14px;margin-right:10px;border-radius:50%}.marginright-2{margin-right:2%}.margintop-5{margin-top:5%}.width-100{width:100%}.float-right{float:right}.marginBottom-10{margin-bottom:10px}.header-alt{align-items:center;margin-bottom:10px}input::placeholder{font-size:20px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:0px;color:#000;opacity:1}.padding-5{padding:5px}.hidden{visibility:hidden}.font-weight-bold{font-weight:900}.textalign-center{text-align:center}.cursor-pointer{cursor:pointer}.cursor-default{cursor:default}.font-weight-600{font-weight:600}.marginRight-15{margin-right:15px}.marginRight-20{margin-right:20px}.switch{position:relative;display:inline-block;width:46px;height:24px;margin-left:5px;margin-right:5px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:#2d5ca0;-webkit-transition:.4s;transition:.4s}.slider:before{position:absolute;content:\"\";height:18px;width:18px;right:3px;bottom:3px;background-color:#fff;-webkit-transition:.4s;transition:.4s}.slider.round{border-radius:18px}.slider.round:before{border-radius:50%}.slider1{position:absolute;cursor:pointer;inset:0;background-color:#015ba2cf;-webkit-transition:.4s;transition:.4s}.slider1:before{position:absolute;content:\"\";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;-webkit-transition:.4s;transition:.4s}.slider1.round1{border-radius:18px}.slider1.round1:before{border-radius:50%}.lib-display-flex{display:flex}.lib-align-items-center{align-items:center}.lib-flex-direction-column{flex-direction:column}.lib-justify-content-space-between{justify-content:space-between}.lib-justify-content-space-around{justify-content:space-around}.lib-justify-content-center{justify-content:center}.lib-justify-content-start{justify-content:start}.lib-justify-content-end{justify-content:end}.lib-ml-20{margin-left:20px}.lib-position-absolute{position:absolute}.lib-z-index-9{z-index:9}.marginright-3{margin-right:3px}@media (min-height: 900px){.lib-chart-wrapper{border-radius:8px}.header-font-size-1{font-size:18px!important}.font-size-1{font-size:14px!important}.font-size-2{font-size:16px!important}.font-size-3{font-size:14px!important}.font-size-4{font-size:22px!important}.font-size-5{font-size:24px!important}}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.ResizedDirective, selector: "[resized]", outputs: ["resized"] }, { kind: "component", type: i3.ChartHeaderV1Component, selector: "lib-chart-header-v1", inputs: ["isAlertEnabled", "title", "menuOptions", "isEditEnabled", "isria", "hasDrillDown", "selectedKpiTooltop"], outputs: ["menuOptionClickEvent"] }, { kind: "component", type: i4.ChartHeaderV2Component, selector: "lib-chart-header-v2", inputs: ["chartData", "chartConfiguration"], outputs: ["clickEvent", "zoomInZoomOutClick"] }, { kind: "component", type: i5.ChartHeaderV3Component, selector: "lib-chart-header-v3", inputs: ["chartData", "chartConfiguration"], outputs: ["compareByFilterSelection", "zoomInZoomOutClick"] }], encapsulation: i0.ViewEncapsulation.None }); }
863
1040
  }
864
1041
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: GroupChartComponent, decorators: [{
865
1042
  type: Component,
866
- args: [{ selector: 'lib-group-chart', encapsulation: ViewEncapsulation.None, template: "<div\r\n #groupcontainer\r\n class=\"lib-chart-wrapper\"\r\n [ngClass]=\"{ 'lib-no-background': isTransparentBackground }\"\r\n style=\"background-color: var(--card-bg);\"\r\n (resized)=\"onResized($event)\"\r\n>\r\n\r\n<div class=\"header-alt\" *ngIf=\"!isHeaderVisible\">\r\n <lib-chart-header-v2\r\n [chartData]=\"chartData\"\r\n [chartConfiguration]=\"chartConfiguration\"\r\n (clickEvent)=\"handleClick($event)\"\r\n ></lib-chart-header-v2>\r\n <lib-chart-header-v3\r\n [chartData]=\"chartData\"\r\n [chartConfiguration]=\"chartConfiguration\"\r\n (compareByFilterSelection)=\"handleCompareByFilterSelection($event)\"\r\n (zoomInZoomOutClick)=\"handleZoominZoomoutClick($event)\"\r\n ></lib-chart-header-v3>\r\n</div>\r\n\r\n <lib-chart-header-v1\r\n [title]=\"chartData.metaData.title\"\r\n [hasDrillDown]=\"chartData.metaData.hasDrillDown\"\r\n [isEditEnabled]=\"chartData.metaData.isEditEnabled\"\r\n [menuOptions]=\"chartConfiguration.headerMenuOptions\"\r\n [isria]=\"customChartConfiguration.isRia\"\r\n [selectedKpiTooltop]=\"chartConfiguration.selectedKpiTooltop\"\r\n (menuOptionClickEvent)=\"handleHeaderMenuClick($event)\"\r\n [isAlertEnabled]=\"isAlertEnabled\"\r\n *ngIf=\"isHeaderVisible\"\r\n></lib-chart-header-v1>\r\n\r\n <div\r\n [style.height]=\"chartConfiguration.svgHeight\"\r\n id=\"groupchartcontainer\"\r\n #groupchartcontainer\r\n class=\"lib-chart-svg\"\r\n ></div>\r\n</div>\r\n", styles: [".lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-weight:400;letter-spacing:0px;color:#000;opacity:1;font-size:1.2em}.lib-axis-group-label{font-size:.85em;font-weight:600;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:0px;color:#000;opacity:1}.dots{font-size:10px}.inline__display{display:flex;justify-content:space-around;padding-top:2%}.verticalbar__text{font-style:normal;font-variant:normal;font-weight:400;font-size:13px;line-height:20px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:0px;opacity:1}.lib-line-label-item{display:inline-block!important;font-size:.85em;margin-right:10px;font-weight:600}.lib-line-label-wrapper-vertical{display:flex;justify-content:center}.target-display{font-size:12px;line-height:14.52px;font-weight:700;text-transform:uppercase;float:right}.title{background-color:#d9d9d9;height:35px;display:flex;flex-direction:column;justify-content:center;align-items:center;border-radius:3px;line-height:1}.title:after{content:\"\";position:absolute;bottom:0;left:50%;margin-left:-10px;width:0;height:0;border-top:solid 10px #d3d3d3;border-left:solid 10px transparent;border-right:solid 10px transparent}.title-top-text{color:#000;font-size:14px;font-weight:600}.title-bar-name{color:#000;font-size:12px;font-weight:700;text-transform:capitalize}.title-bottom-text{color:#4f4f4f;font-size:12px}.zoomIcons-holder{display:flex;align-items:center;margin-right:15px}.zoomIcons{border:.5px solid #b6b6b6;cursor:pointer;display:flex;justify-content:center;align-items:center;width:30px;height:30px;color:var(--color)!important}.zoom-active{background-color:#2d5ca0;opacity:1}.zoom-inactive{background-color:#d9d9d9;opacity:.5}@media screen and (min-width: 1024px) and (min-height: 400px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:10px!important}.dots{font-size:10px!important}}@media screen and (min-width: 1024px) and (min-height: 1000px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:10px!important}.dots{font-size:10px!important}}@media screen and (min-width: 1024px) and (min-height: 1500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:10px!important}.dots{font-size:10px!important}}@media screen and (min-width: 1366px) and (min-height: 400px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:12px!important}.dots{font-size:12px!important}}@media screen and (min-width: 1366px) and (min-height: 1000px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:12px!important}.dots{font-size:12px!important}}@media screen and (min-width: 1366px) and (min-height: 1500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:12px!important}.dots{font-size:12px!important}}@media screen and (min-width: 1920px) and (min-height: 400px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:14px!important}.dots{font-size:14px!important}}@media screen and (min-width: 1920px) and (min-height: 1000px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:14px!important}.dots{font-size:14px!important}}@media screen and (min-width: 1920px) and (min-height: 1500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:14px!important}.dots{font-size:14px!important}}@media screen and (min-width: 2560px) and (min-height: 500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:16px!important}.dots{font-size:16px!important}}@media screen and (min-width: 2560px) and (min-height: 1000px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:16px!important}.dots{font-size:16px!important}}@media screen and (min-width: 2560px) and (min-height: 1500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:16px!important}}.bottom__text{position:absolute!important;bottom:0!important;display:flex!important;justify-content:center!important;align-items:center!important;width:100%!important}.box__heightwidth{opacity:1;height:10px;width:10px;border:none!important;border-radius:50%}.label__text{margin-right:10px;display:flex;justify-content:center;align-items:center;font-style:normal;font-variant:normal;font-weight:400;font-size:10px;line-height:13px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;letter-spacing:.2px;color:#707070!important}.lib-verticalstack-labels-ontop-weklycharts{font-style:normal;font-variant:normal;font-weight:700;font-size:10px;line-height:11px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.05px;text-anchor:middle;fill:#000}.lib-verticalstack-title-ontop{font-style:normal;font-variant:normal;font-size:14px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.05px;text-anchor:middle;fill:#000}.marginLeft-20{margin-left:20px}.flex-inline{display:flex;justify-content:center;align-items:center;font-size:14px}\n", ".lib-chart-wrapper{width:100%;height:100%;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;background:#fff 0% 0% no-repeat padding-box;position:relative}.lib-chart-wrapper-wo-shadow{width:100%;height:100%;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto}.lib-chart-wrapper:hover .chart-header-v1:not(.header-no-background){background-color:#2e3640}.lib-chart-wrapper:hover .chart-header-v1:not(.header-no-background) .chart-title{color:#fff}.lib-chart-svg{width:100%}.lib-chart-header{text-align:center;background-color:#052340;color:#fff;width:100%;height:17%;word-spacing:.5px;line-height:1.8;font-weight:700;padding-top:2%;letter-spacing:0;font-size:1.2em}.lib-donut-chart-footer{width:100%;text-align:right}.lib-donut-label-text{font-size:.9em;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-weight:400;letter-spacing:0px;color:#000;opacity:1}.lib-donut-label-icon{display:inline-block;width:10px;height:10px;margin-right:20px;border-radius:3px}.lib-donut-label-item{font-weight:400;font-size:.85em;color:#2f2f2f}.lib-donut-justified-label-wrapper{width:100%;display:inline-block;text-align:center;list-style-type:none}.lib-donut-justified-label-item{font-weight:400;font-size:.85em;color:#2f2f2f;display:inline-block;text-align:left;padding:0 10px}.lib-donut-justified-label-icon{display:inline-block;width:10px;height:10px;margin-right:5px;border-radius:3px}.lib-no-background{background:none!important}.lib-display-hidden{display:none}.lib-ylabel-weeklyCharts{font-style:normal;font-variant:normal;font-weight:800;font-size:10px;line-height:12px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.07px;text-transform:capitalize;color:#000}.lib-data-labels-weeklycharts{font-style:normal;font-variant:normal;font-weight:400;font-size:12px;line-height:14px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.06px;color:#000}.lib-data-labels-angled-weeklycharts{font-style:normal;font-variant:normal;font-weight:800;font-size:9.5px;line-height:11px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:.4px;text-anchor:start}.lib-xaxis-labels-texts-weeklycharts{font-style:normal;font-variant:normal;font-weight:800;font-size:10px;line-height:11px;letter-spacing:-.05px;fill:#000}.lib-xaxis-labels-texts-drilldown{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:14px;letter-spacing:-1px;color:#000;opacity:1;text-transform:capitalize}.lib-white-space-nowrap{white-space:nowrap}.lib-xaxis-labels-texts-drilldown-alt{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:10px;letter-spacing:0px;color:#000;opacity:1;text-transform:capitalize}.lib-yaxis-labels-texts-drilldown{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:14px;letter-spacing:0px;color:#000!important;opacity:1}.lib-ylabel-drilldowncharts,.lib-xlabel-drilldowncharts{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:16px;letter-spacing:-.1px;color:#000!important;opacity:1}.lib-donut-justified-label-icon-drilldown{display:inline-block;width:14px;height:14px;margin-right:10px;border-radius:50%}.marginright-2{margin-right:2%}.margintop-5{margin-top:5%}.width-100{width:100%}.float-right{float:right}.marginBottom-10{margin-bottom:10px}.header-alt{align-items:center;margin-bottom:10px}input::placeholder{font-size:20px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:0px;color:#000;opacity:1}.padding-5{padding:5px}.hidden{visibility:hidden}.font-weight-bold{font-weight:900}.textalign-center{text-align:center}.cursor-pointer{cursor:pointer}.cursor-default{cursor:default}.font-weight-600{font-weight:600}.marginRight-15{margin-right:15px}.marginRight-20{margin-right:20px}.switch{position:relative;display:inline-block;width:46px;height:24px;margin-left:5px;margin-right:5px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:#2d5ca0;-webkit-transition:.4s;transition:.4s}.slider:before{position:absolute;content:\"\";height:18px;width:18px;right:3px;bottom:3px;background-color:#fff;-webkit-transition:.4s;transition:.4s}.slider.round{border-radius:18px}.slider.round:before{border-radius:50%}.slider1{position:absolute;cursor:pointer;inset:0;background-color:#015ba2cf;-webkit-transition:.4s;transition:.4s}.slider1:before{position:absolute;content:\"\";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;-webkit-transition:.4s;transition:.4s}.slider1.round1{border-radius:18px}.slider1.round1:before{border-radius:50%}.lib-display-flex{display:flex}.lib-align-items-center{align-items:center}.lib-flex-direction-column{flex-direction:column}.lib-justify-content-space-between{justify-content:space-between}.lib-justify-content-space-around{justify-content:space-around}.lib-justify-content-center{justify-content:center}.lib-justify-content-start{justify-content:start}.lib-justify-content-end{justify-content:end}.lib-ml-20{margin-left:20px}.lib-position-absolute{position:absolute}.lib-z-index-9{z-index:9}.marginright-3{margin-right:3px}@media (min-height: 900px){.lib-chart-wrapper{border-radius:8px}.header-font-size-1{font-size:18px!important}.font-size-1{font-size:14px!important}.font-size-2{font-size:16px!important}.font-size-3{font-size:14px!important}.font-size-4{font-size:22px!important}.font-size-5{font-size:24px!important}}\n"] }]
1043
+ args: [{ selector: 'lib-group-chart', encapsulation: ViewEncapsulation.None, template: "<div\r\n #groupcontainer\r\n class=\"lib-chart-wrapper\"\r\n [ngClass]=\"{ 'lib-no-background': isTransparentBackground }\"\r\n style=\"background-color: var(--card-bg);\"\r\n (resized)=\"onResized($event)\"\r\n>\r\n\r\n<div class=\"header-alt\" *ngIf=\"!isHeaderVisible\">\r\n <lib-chart-header-v2\r\n [chartData]=\"chartData\"\r\n [chartConfiguration]=\"chartConfiguration\"\r\n (clickEvent)=\"handleClick($event)\"\r\n ></lib-chart-header-v2>\r\n <lib-chart-header-v3\r\n [chartData]=\"chartData\"\r\n [chartConfiguration]=\"chartConfiguration\"\r\n (compareByFilterSelection)=\"handleCompareByFilterSelection($event)\"\r\n (zoomInZoomOutClick)=\"handleZoominZoomoutClick($event)\"\r\n ></lib-chart-header-v3>\r\n</div>\r\n\r\n <lib-chart-header-v1\r\n [title]=\"chartData.metaData.title\"\r\n [hasDrillDown]=\"chartData.metaData.hasDrillDown\"\r\n [isEditEnabled]=\"chartData.metaData.isEditEnabled\"\r\n [menuOptions]=\"chartConfiguration.headerMenuOptions\"\r\n [isria]=\"customChartConfiguration.isRia\"\r\n [selectedKpiTooltop]=\"chartConfiguration.selectedKpiTooltop\"\r\n (menuOptionClickEvent)=\"handleHeaderMenuClick($event)\"\r\n [isAlertEnabled]=\"isAlertEnabled\"\r\n *ngIf=\"isHeaderVisible\"\r\n></lib-chart-header-v1>\r\n\r\n <div\r\n [style.height]=\"chartConfiguration.svgHeight\"\r\n id=\"groupchartcontainer\"\r\n #groupchartcontainer\r\n class=\"lib-chart-svg\"\r\n ></div>\r\n</div>\r\n", styles: [".lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-weight:400;letter-spacing:0px;color:#000;opacity:1;font-size:12px}.lib-axis-group-label{font-size:12px;font-weight:600;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:0px;color:#000;opacity:1}.dots{font-size:10px}.inline__display{display:flex;justify-content:space-around;padding-top:2%}.verticalbar__text{font-style:normal;font-variant:normal;font-weight:400;font-size:13px;line-height:20px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:0px;opacity:1}.lib-line-label-item{display:inline-block!important;font-size:.85em;margin-right:10px;font-weight:600}.lib-line-label-wrapper-vertical{display:flex;justify-content:center}.target-display{font-size:11px;line-height:13px;font-weight:700;text-transform:uppercase;float:right}.title{background-color:#d9d9d9;height:40px;display:flex;flex-direction:column;justify-content:center;align-items:center;border-radius:3px;line-height:1;padding:4px 8px;box-sizing:border-box}.title-top-text{color:var(--font-color)!important;font-size:12px;font-weight:600}.title-bar-name{color:var(--font-color)!important;font-size:14px;font-weight:700;text-transform:capitalize}.title-bottom-text{color:var(--font-color)!important;font-size:11px}.zoomIcons-holder{display:flex;align-items:center;margin-right:15px}.zoomIcons{border:.5px solid #b6b6b6;cursor:pointer;display:flex;justify-content:center;align-items:center;width:30px;height:30px;color:var(--color)!important}.zoom-active{background-color:#2d5ca0;opacity:1}.zoom-inactive{background-color:#d9d9d9;opacity:.5}.bottom__text{position:absolute!important;bottom:0!important;display:flex!important;justify-content:center!important;align-items:center!important;width:100%!important}.box__heightwidth{opacity:1;height:10px;width:10px;border:none!important;border-radius:50%}.label__text{margin-right:10px;display:flex;justify-content:center;align-items:center;font-style:normal;font-variant:normal;font-weight:400;font-size:10px;line-height:13px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;letter-spacing:.2px;color:#707070!important}.lib-verticalstack-labels-ontop-weklycharts{font-style:normal;font-variant:normal;font-weight:700;font-size:10px;line-height:11px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.05px;text-anchor:middle;fill:#000}.lib-verticalstack-title-ontop{font-style:normal;font-variant:normal;font-size:14px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.05px;text-anchor:middle;fill:#000}.marginLeft-20{margin-left:20px}.flex-inline{display:flex;justify-content:center;align-items:center;font-size:14px}.lib-xaxis-labels-texts-drilldown,.lib-xaxis-labels-texts-drilldown-alt,.lib-xaxis-labels-texts-weeklycharts{font-size:12px}.lib-display-hidden{display:none!important}.chart-wrapper-main{position:relative;width:100%;box-sizing:border-box}.left-axis-container,.right-axis-container{pointer-events:none;overflow:hidden;-webkit-user-select:none;user-select:none}.scrollable-chart-container{-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:#888 #f1f1f1}.scrollable-chart-container::-webkit-scrollbar{height:8px}.scrollable-chart-container::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.scrollable-chart-container::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.scrollable-chart-container::-webkit-scrollbar-thumb:hover{background:#555}.inner-chart-container{position:relative}.grid line{stroke-width:1;shape-rendering:crispEdges}.horizontal-grid line{stroke-opacity:.7}.vertical-grid line{stroke-opacity:.7}.lib-y-axis-hidden{opacity:0!important;pointer-events:none}.lib-stacked-x-axis-text .domain{stroke:var(--chart-axis-color);stroke-width:1px}.lib-stacked-x-axis-text text{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-weight:400;font-size:12px;fill:var(--chart-text-color)}.lib-stacked-y-axis-text .domain{stroke:var(--chart-axis-color);stroke-width:1px}.lib-stacked-y-axis-text text{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-weight:400;font-size:12px;fill:var(--chart-text-color)}@media (max-width: 1024px){.scrollable-chart-container::-webkit-scrollbar{height:6px}.lib-stacked-x-axis-text text{font-size:10px}}@media (max-width: 768px){.scrollable-chart-container::-webkit-scrollbar{height:4px}}.left-axis-container svg{pointer-events:none;overflow:visible!important}.horizontal-grid-from-left line{pointer-events:none}\n", ".lib-chart-wrapper{width:100%;height:100%;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;background:#fff 0% 0% no-repeat padding-box;position:relative}.lib-chart-wrapper-wo-shadow{width:100%;height:100%;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto}.lib-chart-wrapper:hover .chart-header-v1:not(.header-no-background){background-color:#2e3640}.lib-chart-wrapper:hover .chart-header-v1:not(.header-no-background) .chart-title{color:#fff}.lib-chart-svg{width:100%}.lib-chart-header{text-align:center;background-color:#052340;color:#fff;width:100%;height:17%;word-spacing:.5px;line-height:1.8;font-weight:700;padding-top:2%;letter-spacing:0;font-size:1.2em}.lib-donut-chart-footer{width:100%;text-align:right}.lib-donut-label-text{font-size:.9em;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-weight:400;letter-spacing:0px;color:#000;opacity:1}.lib-donut-label-icon{display:inline-block;width:10px;height:10px;margin-right:20px;border-radius:3px}.lib-donut-label-item{font-weight:400;font-size:.85em;color:#2f2f2f}.lib-donut-justified-label-wrapper{width:100%;display:inline-block;text-align:center;list-style-type:none}.lib-donut-justified-label-item{font-weight:400;font-size:.85em;color:#2f2f2f;display:inline-block;text-align:left;padding:0 10px}.lib-donut-justified-label-icon{display:inline-block;width:10px;height:10px;margin-right:5px;border-radius:3px}.lib-no-background{background:none!important}.lib-display-hidden{display:none}.lib-ylabel-weeklyCharts{font-style:normal;font-variant:normal;font-weight:800;font-size:10px;line-height:12px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.07px;text-transform:capitalize;color:#000}.lib-data-labels-weeklycharts{font-style:normal;font-variant:normal;font-weight:400;font-size:12px;line-height:14px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.06px;color:#000}.lib-data-labels-angled-weeklycharts{font-style:normal;font-variant:normal;font-weight:800;font-size:9.5px;line-height:11px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:.4px;text-anchor:start}.lib-xaxis-labels-texts-weeklycharts{font-style:normal;font-variant:normal;font-weight:800;font-size:10px;line-height:11px;letter-spacing:-.05px;fill:#000}.lib-xaxis-labels-texts-drilldown{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:14px;letter-spacing:-1px;color:#000;opacity:1;text-transform:capitalize}.lib-white-space-nowrap{white-space:nowrap}.lib-xaxis-labels-texts-drilldown-alt{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:10px;letter-spacing:0px;color:#000;opacity:1;text-transform:capitalize}.lib-yaxis-labels-texts-drilldown{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:14px;letter-spacing:0px;color:#000!important;opacity:1}.lib-ylabel-drilldowncharts,.lib-xlabel-drilldowncharts{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:16px;letter-spacing:-.1px;color:#000!important;opacity:1}.lib-donut-justified-label-icon-drilldown{display:inline-block;width:14px;height:14px;margin-right:10px;border-radius:50%}.marginright-2{margin-right:2%}.margintop-5{margin-top:5%}.width-100{width:100%}.float-right{float:right}.marginBottom-10{margin-bottom:10px}.header-alt{align-items:center;margin-bottom:10px}input::placeholder{font-size:20px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:0px;color:#000;opacity:1}.padding-5{padding:5px}.hidden{visibility:hidden}.font-weight-bold{font-weight:900}.textalign-center{text-align:center}.cursor-pointer{cursor:pointer}.cursor-default{cursor:default}.font-weight-600{font-weight:600}.marginRight-15{margin-right:15px}.marginRight-20{margin-right:20px}.switch{position:relative;display:inline-block;width:46px;height:24px;margin-left:5px;margin-right:5px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:#2d5ca0;-webkit-transition:.4s;transition:.4s}.slider:before{position:absolute;content:\"\";height:18px;width:18px;right:3px;bottom:3px;background-color:#fff;-webkit-transition:.4s;transition:.4s}.slider.round{border-radius:18px}.slider.round:before{border-radius:50%}.slider1{position:absolute;cursor:pointer;inset:0;background-color:#015ba2cf;-webkit-transition:.4s;transition:.4s}.slider1:before{position:absolute;content:\"\";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;-webkit-transition:.4s;transition:.4s}.slider1.round1{border-radius:18px}.slider1.round1:before{border-radius:50%}.lib-display-flex{display:flex}.lib-align-items-center{align-items:center}.lib-flex-direction-column{flex-direction:column}.lib-justify-content-space-between{justify-content:space-between}.lib-justify-content-space-around{justify-content:space-around}.lib-justify-content-center{justify-content:center}.lib-justify-content-start{justify-content:start}.lib-justify-content-end{justify-content:end}.lib-ml-20{margin-left:20px}.lib-position-absolute{position:absolute}.lib-z-index-9{z-index:9}.marginright-3{margin-right:3px}@media (min-height: 900px){.lib-chart-wrapper{border-radius:8px}.header-font-size-1{font-size:18px!important}.font-size-1{font-size:14px!important}.font-size-2{font-size:16px!important}.font-size-3{font-size:14px!important}.font-size-4{font-size:22px!important}.font-size-5{font-size:24px!important}}\n"] }]
867
1044
  }], ctorParameters: () => [], propDecorators: { containerElt: [{
868
1045
  type: ViewChild,
869
1046
  args: ['groupchartcontainer', { static: true }]
@@ -879,4 +1056,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
879
1056
  }], headerMenuclickEvent: [{
880
1057
  type: Output
881
1058
  }] } });
882
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"group-chart.component.js","sourceRoot":"","sources":["../../../../../projects/axidio-styleguide-library/src/lib/group-chart/group-chart.component.ts","../../../../../projects/axidio-styleguide-library/src/lib/group-chart/group-chart.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  ViewChild,\r\n  ElementRef,\r\n  Input,\r\n  Output,\r\n  EventEmitter,\r\n  ViewEncapsulation,\r\n} from '@angular/core';\r\nimport { ComponentUniqueId } from '../unique-id';\r\nimport ChartHelper from '../chart-helper';\r\nimport * as d3 from 'd3';\r\nimport { ResizedEvent } from 'angular-resize-event';\r\nimport HeaderConfigHelper from '../header-config';\r\n\r\ninterface ChartMetaData {\r\n  colors: { [key: string]: string };\r\n  colorAboveTarget?: { [key: string]: string };\r\n  keyList: string[];\r\n  hasDrillDown?: boolean;\r\n  barWithoutClick?: string[];\r\n  dataType?: string;\r\n  yLabel?: string;\r\n  xLabel?: string;\r\n  lineyLabel?: string;\r\n}\r\n\r\ninterface TargetLineData {\r\n  target: number;\r\n  color: string;\r\n  targetName?: string;\r\n}\r\n\r\ninterface ChartConfiguration {\r\n  margin: { top: number; right: number; bottom: number; left: number };\r\n  labelFormatter: (value: any) => string;\r\n  svgHeight: number;\r\n  numberOfYTicks: number;\r\n  legendJustified: boolean;\r\n  yLineAxisLabelFomatter: (value: any) => string;\r\n  yAxisLabelFomatter: (value: any) => string;\r\n  lineGraphColor: string;\r\n  showLineChartAxis: boolean;\r\n  showValues: boolean;\r\n  headerMenuOptions: any[];\r\n  xAxisGrid?: boolean;\r\n  yAxisGrid: boolean;\r\n  legendVisible: boolean;\r\n  isHeaderVisible?: boolean;\r\n  isTransparentBackground?: boolean;\r\n  isMultiChartGridLine?: boolean;\r\n  isFullScreen?: boolean;\r\n  customYscale?: number;\r\n  textsOnBar?: boolean;\r\n  isXaxisLabelHidden?: boolean;\r\n  isYaxisLabelHidden: boolean;\r\n  isYaxisHidden?: boolean;\r\n  isYaxisDashed?: boolean;\r\n  textFormatter?: string;\r\n  isNoAlternateXaxisText?: boolean;\r\n  isXgridBetweenLabels?: boolean;\r\n  backgroundColor: string;\r\n  hideLegendOnTop: boolean;\r\n  isXaxisColor: string;\r\n  labelOverlapMinorFix: boolean;\r\n  noHoverEffect: boolean;\r\n  noHoverDisplayData: boolean;\r\n  showXaxisTop: boolean;\r\n  displayYaxisLabels?: boolean;\r\n  xLabelsOnSameLine?: boolean;\r\n  textAlwaysHorizontal?: boolean;\r\n  legendAtTopRight?: boolean;\r\n  isDrilldownChart?: boolean;\r\n  displayTitleOnTop?: boolean;\r\n  isToggleVisible?: boolean;\r\n  isTitleHidden?: boolean;\r\n  isDisplayBarDetailsAtBottom?: boolean;\r\n  howmanyBarDetailsToDisplay: number;\r\n  barVauleColor?: string;\r\n  yAxisCustomTextStyles?: string;\r\n  yAxisCustomlabelStyles?: string;\r\n  xAxisCustomlabelStyles?: string;\r\n  isRia?: boolean;\r\n}\r\n\r\n@Component({\r\n  selector: 'lib-group-chart',\r\n  templateUrl: './group-chart.component.html',\r\n  styleUrls: ['./group-chart.component.less', '../common-styles.less'],\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class GroupChartComponent extends ComponentUniqueId implements OnInit {\r\n  @ViewChild('groupchartcontainer', { static: true })\r\n  containerElt!: ElementRef;\r\n\r\n  @ViewChild('groupcontainer', { static: true })\r\n  groupcontainerElt!: ElementRef;\r\n\r\n  @Input() chartData: any;\r\n  @Input() customChartConfiguration: any;\r\n  @Output() clickEvent = new EventEmitter<any>();\r\n  @Output() headerMenuclickEvent = new EventEmitter<any>();\r\n\r\n  isHeaderVisible = true;\r\n  legendVisible = true;\r\n  isTransparentBackground = false;\r\n  chartConfiguration: ChartConfiguration = {} as ChartConfiguration;\r\n  objectKeys = Object.keys;\r\n\r\n  private readonly defaultConfiguration: Partial<ChartConfiguration> = {\r\n    margin: { top: 20, right: 20, bottom: 20, left: 40 },\r\n    labelFormatter: ChartHelper.defaultFormatter,\r\n    svgHeight: 70,\r\n    numberOfYTicks: 5,\r\n    legendJustified: true,\r\n    yLineAxisLabelFomatter: ChartHelper.defaultFormatter,\r\n    yAxisLabelFomatter: ChartHelper.defaultFormatter,\r\n    lineGraphColor: '#F6D283',\r\n    showLineChartAxis: true,\r\n    showValues: true,\r\n    headerMenuOptions: HeaderConfigHelper.headerConfig.headerMenuOptions,\r\n    yAxisGrid: false,\r\n    legendVisible: true,\r\n    isYaxisLabelHidden: false,\r\n    backgroundColor: '#FFFFFF',\r\n    hideLegendOnTop: true,\r\n    isXaxisColor: '#999999',\r\n    labelOverlapMinorFix: true,\r\n    noHoverEffect: true,\r\n    noHoverDisplayData: true,\r\n    showXaxisTop: true,\r\n    howmanyBarDetailsToDisplay: 0,\r\n  };\r\n\r\n  uniqueId: any = this.getUniqueId();\r\n  isZoomedOut = false;\r\n  isDD1Open = false;\r\n  isDD2Open = false;\r\n\r\n  constructor() {\r\n    super();\r\n  }\r\n\r\n  ngOnInit() {}\r\n\r\n  get isAlertEnabled(): boolean {\r\n    return this.chartConfiguration?.headerMenuOptions?.some(\r\n      (option) => option.id === 'editAlert'\r\n    );\r\n  }\r\n\r\n  onResized(event: ResizedEvent): void {\r\n    setTimeout(() => {\r\n      d3.select('#' + this.uniqueId).remove();\r\n      this.initializegroupChart();\r\n    }, 10);\r\n  }\r\n\r\n  isZoomOutSelected(isZoomOut: boolean, event: any): void {\r\n    this.isZoomedOut = isZoomOut;\r\n    this.onResized(event);\r\n  }\r\n\r\n  handleZoominZoomoutClick({ isZoomOut, event }): void {\r\n    this.isZoomOutSelected(isZoomOut, event);\r\n  }\r\n\r\n  isLegendVisible(): boolean {\r\n    return !!(\r\n      this.chartData?.metaData?.colors &&\r\n      Object.keys(this.chartData.metaData.colors).length > 1\r\n    );\r\n  }\r\n\r\n  keepOrder = (a, b) => a;\r\n\r\n  initializegroupChart(): void {\r\n    this.mergeConfigurations();\r\n    const chartContext = this.prepareChartData();\r\n    const dimensions = this.calculateDimensions(chartContext);\r\n    const scales = this.createScales(chartContext, dimensions);\r\n    const svgElements = this.createSVGStructure(dimensions);\r\n\r\n    this.renderAxes(svgElements, scales, chartContext, dimensions);\r\n    this.renderBars(svgElements.svg, chartContext, scales, dimensions);\r\n    this.renderLabels(svgElements, scales, chartContext, dimensions);\r\n    this.renderTargetLine(svgElements, scales, chartContext, dimensions);\r\n    this.renderLineGraph(svgElements.svg, chartContext, scales);\r\n  }\r\n\r\n  private mergeConfigurations(): void {\r\n    for (const key in this.defaultConfiguration) {\r\n      this.chartConfiguration[key] = ChartHelper.getValueByConfigurationType(\r\n        key,\r\n        this.defaultConfiguration,\r\n        this.customChartConfiguration\r\n      );\r\n    }\r\n\r\n    if (this.chartConfiguration.isHeaderVisible !== undefined) {\r\n      this.isHeaderVisible = this.chartConfiguration.isHeaderVisible;\r\n    }\r\n    if (this.chartConfiguration.legendVisible !== undefined) {\r\n      this.legendVisible = this.chartConfiguration.legendVisible;\r\n    }\r\n    if (this.chartConfiguration.isTransparentBackground !== undefined) {\r\n      this.isTransparentBackground = this.chartConfiguration.isTransparentBackground;\r\n    }\r\n  }\r\n\r\n  private prepareChartData() {\r\n    const data = this.chartData.data;\r\n    const metaData: ChartMetaData = this.chartData.metaData;\r\n    const lineData = this.chartData.lineData;\r\n\r\n    if (!metaData.colorAboveTarget) {\r\n      metaData.colorAboveTarget = metaData.colors;\r\n    }\r\n\r\n    return {\r\n      data,\r\n      metaData,\r\n      lineData,\r\n      keyList: metaData.keyList,\r\n      colorMap: metaData.colors,\r\n      isRia: this.customChartConfiguration?.isRia || false,\r\n    };\r\n  }\r\n\r\n  private calculateDimensions(chartContext: any) {\r\n    const chartContainer = d3.select(this.containerElt.nativeElement);\r\n    const verticalstackedcontainer = d3.select(this.groupcontainerElt.nativeElement);\r\n    const margin = this.chartConfiguration.margin;\r\n\r\n    let width = this.calculateWidth(chartContainer, margin);\r\n    let height = this.calculateHeight(verticalstackedcontainer, margin);\r\n\r\n    return { width, height, margin, chartContainer, verticalstackedcontainer };\r\n  }\r\n\r\n  private calculateWidth(chartContainer: any, margin: any): number {\r\n    const baseWidth = parseInt(chartContainer.style('width')) - margin.left - margin.right;\r\n    const dataLength = this.chartData.data.length;\r\n    let width = baseWidth;\r\n\r\n    if (dataLength > 30 && this.isZoomedOut) {\r\n      const multiplier = this.chartData.dropdownData1 ? 60 : 40;\r\n      width = Math.max(width, dataLength * multiplier);\r\n    }\r\n\r\n    if (this.chartData.dropdownData2 && width < dataLength * 120 && this.isZoomedOut) {\r\n      width = dataLength * 120;\r\n    }\r\n\r\n    if (dataLength > 8 && !this.isZoomedOut) {\r\n      if (this.chartData.dropdownData2 && width < dataLength * 250) {\r\n        width = dataLength * 250;\r\n      } else {\r\n        width = dataLength * 160;\r\n      }\r\n    }\r\n\r\n    return width;\r\n  }\r\n\r\n  private calculateHeight(verticalstackedcontainer: any, margin: any): number {\r\n    let height =\r\n      parseInt(verticalstackedcontainer.style('height')) *\r\n        (this.chartConfiguration.svgHeight / 100) -\r\n      margin.top -\r\n      margin.bottom;\r\n\r\n    if (this.chartConfiguration.isFullScreen && this.chartConfiguration.svgHeight !== 70) {\r\n      height = this.chartConfiguration.svgHeight;\r\n    } else if (this.chartConfiguration.isFullScreen) {\r\n      height = parseInt(verticalstackedcontainer.style('height'));\r\n    }\r\n\r\n    if (this.chartConfiguration.isDrilldownChart && !this.isHeaderVisible) {\r\n      height = parseInt(verticalstackedcontainer.style('height')) - margin.top - margin.bottom - 130;\r\n    }\r\n\r\n    if (this.chartConfiguration.isHeaderVisible) {\r\n      height = parseInt(verticalstackedcontainer.style('height')) - margin.top - margin.bottom - 100;\r\n    }\r\n\r\n    return height;\r\n  }\r\n\r\n  private createScales(chartContext: any, dimensions: any) {\r\n    const { data, metaData, lineData, keyList } = chartContext;\r\n    const { width, height, margin } = dimensions;\r\n    const leftAndRightSpaces = 50;\r\n    const rightSvgWidth = 60;\r\n\r\n    const groups = d3.map(data, (d) => d.name).keys();\r\n\r\n    let x: any;\r\n    if (this.chartConfiguration.isMultiChartGridLine !== undefined) {\r\n      x = d3\r\n        .scaleBand()\r\n        .rangeRound([width, 0])\r\n        .align(0.5)\r\n        .padding(0.5)\r\n        .domain(data.map((d: any) => d.name.toLowerCase()));\r\n    } else {\r\n      x = d3\r\n        .scaleBand()\r\n        .domain(groups)\r\n        .range([leftAndRightSpaces, width - rightSvgWidth - leftAndRightSpaces])\r\n        .padding(0.3);\r\n    }\r\n\r\n    const xScaleFromOrigin = d3.scaleBand().domain(groups).range([0, width - rightSvgWidth]);\r\n\r\n    const xSubgroup = d3.scaleBand().domain(keyList).range([0, x.bandwidth()]);\r\n\r\n    const maxValue = this.calculateMaxValue(data, keyList);\r\n    const y = d3.scaleLinear().domain([0, maxValue]).nice().rangeRound([height, 0]);\r\n\r\n    let lineYscale = null;\r\n    if (lineData) {\r\n      lineYscale = this.createLineYScale(lineData, height);\r\n    }\r\n\r\n    const color = d3.scaleOrdinal().domain(keyList).range(Object.values(metaData.colors));\r\n\r\n    return {\r\n      x,\r\n      xScaleFromOrigin,\r\n      xSubgroup,\r\n      y,\r\n      lineYscale,\r\n      color,\r\n      leftAndRightSpaces,\r\n      rightSvgWidth,\r\n    };\r\n  }\r\n\r\n  private calculateMaxValue(data: any[], keyList: string[]): number {\r\n    let maxValue = d3.max(data, (d) => d3.max(keyList, (key) => +d[key])) || 0;\r\n\r\n    if (maxValue === 0) {\r\n      maxValue = this.chartData.targetLineData\r\n        ? this.chartData.targetLineData.target + 20\r\n        : 100;\r\n    }\r\n\r\n    if (this.chartConfiguration.customYscale) {\r\n      maxValue *= this.chartConfiguration.customYscale;\r\n    }\r\n\r\n    if (this.chartData.targetLineData && maxValue < this.chartData.targetLineData.target) {\r\n      const target = this.chartData.targetLineData.target;\r\n      maxValue = maxValue < 10 && target < 10 ? target + 3 : target + 20;\r\n    }\r\n\r\n    return maxValue;\r\n  }\r\n\r\n  private createLineYScale(lineData: any[], height: number) {\r\n    let maxLineValue = d3.max(lineData, (d) => +d.value) || 0;\r\n    maxLineValue *= this.chartConfiguration.customYscale || 1;\r\n\r\n    let minLineValue = d3.min(lineData, (d) => +d.value) || 0;\r\n    if (maxLineValue > 0) minLineValue -= 3;\r\n    if (minLineValue > 0) minLineValue = 0;\r\n\r\n    return d3.scaleLinear().domain([minLineValue, maxLineValue]).range([height, minLineValue]);\r\n  }\r\n\r\n  private createSVGStructure(dimensions: any) {\r\n    const { chartContainer, height, margin } = dimensions;\r\n    const rightSvgWidth = 60;\r\n\r\n    const outerContainer = chartContainer\r\n      .append('div')\r\n      .attr('id', this.uniqueId)\r\n      .attr('class', 'outer-container')\r\n      .style('width', '100%')\r\n      .style('height', height)\r\n      .style('overflow-x', 'hidden')\r\n      .style('padding-left', `${margin.left}px`)\r\n      .style('padding-right', `${rightSvgWidth}px`)\r\n      .style('margin-left', '15px');\r\n\r\n    const svgYAxisLeft = outerContainer\r\n      .append('svg')\r\n      .attr('width', 100)\r\n      .attr('height', height + margin.top + margin.bottom + 10)\r\n      .style('position', 'absolute')\r\n      .style('left', '0')\r\n      .style('z-index', 1)\r\n      .append('g')\r\n      .attr('transform', `translate(${margin.left + 15},${margin.top})`);\r\n\r\n    const svgYAxisRight = outerContainer\r\n      .append('svg')\r\n      .attr('width', rightSvgWidth)\r\n      .attr('height', height + margin.top + margin.bottom + 10)\r\n      .style('position', 'absolute')\r\n      .style('right', '12px')\r\n      .style('z-index', 1)\r\n      .append('g')\r\n      .attr('transform', `translate(0,${margin.top})`);\r\n\r\n    const innerContainer = outerContainer\r\n      .append('div')\r\n      .attr('class', 'inner-container')\r\n      .style('width', '100%')\r\n      .style('overflow-x', 'auto');\r\n\r\n    const svg = innerContainer\r\n      .append('svg')\r\n      .attr('width', dimensions.width - rightSvgWidth)\r\n      .attr('height', height + margin.top + margin.bottom + 30)\r\n      .append('g')\r\n      .attr('transform', `translate(0,${margin.top})`);\r\n\r\n    return { outerContainer, svgYAxisLeft, svgYAxisRight, svg };\r\n  }\r\n\r\n  private renderAxes(svgElements: any, scales: any, chartContext: any, dimensions: any): void {\r\n    const { svg, svgYAxisLeft, svgYAxisRight } = svgElements;\r\n    const { x, xScaleFromOrigin, y, lineYscale } = scales;\r\n    const { height } = dimensions;\r\n    const { metaData, lineData, keyList } = chartContext;\r\n\r\n    this.renderXAxis(svg, x, xScaleFromOrigin, height, chartContext, keyList);\r\n    this.renderYAxis(svg, svgYAxisLeft, svgYAxisRight, y, dimensions);\r\n\r\n    if (this.chartConfiguration.yAxisGrid) {\r\n      this.renderYAxisGrid(svg, y, dimensions.width);\r\n    }\r\n\r\n    if (this.chartConfiguration.isXgridBetweenLabels) {\r\n      this.renderXAxisGrid(svg, x, height);\r\n    }\r\n\r\n    if (lineData && this.chartConfiguration.showLineChartAxis && lineYscale) {\r\n      this.renderLineYAxis(svgYAxisRight, lineYscale);\r\n    }\r\n  }\r\n\r\n  private renderXAxis(\r\n    svg: any,\r\n    x: any,\r\n    xScaleFromOrigin: any,\r\n    height: number,\r\n    chartContext: any,\r\n    keyList: string[]\r\n  ): void {\r\n    const { data, metaData } = chartContext;\r\n\r\n    if (this.chartConfiguration.isMultiChartGridLine === undefined) {\r\n      svg\r\n        .append('g')\r\n        .attr('class', 'x1 axis1')\r\n        .attr('transform', `translate(0,${height})`)\r\n        .call(d3.axisBottom(x))\r\n        .call((g) => g.select('.domain').remove());\r\n\r\n      svg.selectAll('g.x1.axis1 g.tick line').remove();\r\n\r\n      const textClass = 'lib-xaxis-labels-texts-drilldown';\r\n      const textSelection = svg.selectAll('g.x1.axis1 g.tick text').attr('class', textClass).style('fill', 'var(--chart-text-color)');\r\n\r\n      if (keyList.length > 1 && !metaData.xLabel) {\r\n        textSelection.attr('y', 32);\r\n      }\r\n    } else {\r\n      this.renderMultiChartXAxis(svg, x, height, data, metaData);\r\n    }\r\n\r\n    if (this.chartConfiguration.xLabelsOnSameLine) {\r\n      this.renderXLabelsOnSameLine(svg, data, metaData);\r\n    }\r\n\r\n    // Render bottom x-axis\r\n    svg\r\n      .append('g')\r\n      .attr('class', 'x2 axis2')\r\n      .attr('transform', `translate(0,${height})`)\r\n      .style('color', '#000')\r\n      .call(d3.axisBottom(xScaleFromOrigin).tickSize(0))\r\n      .call((g) => g.select('.domain').attr('fill', 'none'));\r\n\r\n    svg.selectAll('g.x2.axis2 g.tick text').style('display', 'none');\r\n\r\n    if (this.isZoomedOut) {\r\n      svg.selectAll('.lib-xaxis-labels-texts-drilldown').attr('class', 'lib-display-hidden');\r\n    }\r\n  }\r\n\r\n  private renderMultiChartXAxis(svg: any, x: any, height: number, data: any[], metaData: any): void {\r\n    let alternate_text = false;\r\n    const short_tick_length_bg = 5;\r\n    const long_tick_length_bg = 30;\r\n\r\n    svg\r\n      .append('g')\r\n      .attr('class', 'x1 axis1')\r\n      .attr('transform', `translate(0,${height})`)\r\n      .call(d3.axisBottom(x).tickSize(0))\r\n      .call((g) => g.select('.domain').attr('fill', 'none'));\r\n\r\n    svg.selectAll('g.x1.axis1 g.tick line').attr('y2', () => {\r\n      if (alternate_text && !this.chartConfiguration.isNoAlternateXaxisText) {\r\n        alternate_text = false;\r\n        return long_tick_length_bg - 7;\r\n      } else {\r\n        alternate_text = true;\r\n        return short_tick_length_bg - 4;\r\n      }\r\n    });\r\n\r\n    alternate_text = false;\r\n    svg.selectAll('g.x1.axis1 g.tick text').attr('class', 'lib-xaxis-labels-texts-weeklycharts').attr('y', () => {\r\n      if (alternate_text) {\r\n        alternate_text = false;\r\n        return long_tick_length_bg;\r\n      } else {\r\n        alternate_text = true;\r\n        return short_tick_length_bg;\r\n      }\r\n    });\r\n  }\r\n\r\n  private renderXLabelsOnSameLine(svg: any, data: any[], metaData: any): void {\r\n    const short_tick_length_bg = 5;\r\n    const long_tick_length_bg = 30;\r\n\r\n    svg\r\n      .selectAll('g.x1.axis1 g.tick text')\r\n      .attr('class', 'lib-xaxis-labels-texts-drilldown')\r\n      .attr('y', short_tick_length_bg)\r\n      .text((d) => {\r\n        const isValueToBeIgnored = data.some(\r\n          (indiv: any) =>\r\n            indiv.name.toLowerCase() === d.trim().toLowerCase() &&\r\n            indiv[metaData.keyList[0]] === -1\r\n        );\r\n        if (isValueToBeIgnored) return '';\r\n\r\n        if (d.trim().indexOf(' ') > -1) {\r\n          return d.trim().substring(0, d.indexOf(' ')).toLowerCase();\r\n        }\r\n        return d.toLowerCase();\r\n      });\r\n\r\n    svg\r\n      .selectAll('g.x1.axis1 g.tick')\r\n      .append('text')\r\n      .attr('class', 'lib-xaxis-labels-texts-drilldown')\r\n      .attr('y', long_tick_length_bg)\r\n      .attr('fill', 'currentColor')\r\n      .text((d) => {\r\n        if (d.trim().indexOf(' ') > -1) {\r\n          return d.trim().substring(d.indexOf(' ')).toLowerCase();\r\n        }\r\n        return '';\r\n      });\r\n  }\r\n\r\n  private renderYAxis(svg: any, svgYAxisLeft: any, svgYAxisRight: any, y: any, dimensions: any): void {\r\n    svg\r\n      .append('g')\r\n      .attr('class', 'lib-stacked-y-axis-text yaxis-dashed')\r\n      .attr('style', this.chartConfiguration.yAxisCustomTextStyles)\r\n      .attr('transform', 'translate(0,0)')\r\n      .call(y)\r\n      .style('display', 'none');\r\n\r\n    svgYAxisLeft\r\n      .append('g')\r\n      .append('g')\r\n      .attr('class', 'lib-yaxis-labels-texts-drilldown yaxis-dashed')\r\n      .attr('style', this.chartConfiguration.yAxisCustomTextStyles)\r\n      .attr('transform', 'translate(0,0)')\r\n      .call(\r\n        d3\r\n          .axisLeft(y)\r\n          .tickSize(0)\r\n          .ticks(this.chartConfiguration.numberOfYTicks)\r\n          .tickFormat(this.chartConfiguration.yAxisLabelFomatter)\r\n      )\r\n      .selectAll('text')\r\n      .style('fill', 'var(--chart-text-color)');\r\n\r\n    svgYAxisRight\r\n      .append('g')\r\n      .attr('class', 'lib-yaxis-labels-texts-drilldown yaxis-dashed')\r\n      .attr('style', this.chartConfiguration.yAxisCustomTextStyles)\r\n      .attr('transform', 'translate(0,0)')\r\n      .call(y)\r\n      .style('display', 'none');\r\n\r\n    this.applyAxisVisibilitySettings();\r\n  }\r\n\r\n  private applyAxisVisibilitySettings(): void {\r\n    if (this.chartConfiguration.isXaxisLabelHidden) {\r\n      d3.selectAll('g.lib-line-x-axis-text > g > text').attr('class', 'lib-display-hidden');\r\n    }\r\n    if (this.chartConfiguration.isYaxisLabelHidden) {\r\n      d3.selectAll('.yaxis-dashed > g > text').attr('class', 'lib-display-hidden');\r\n    }\r\n    if (this.chartConfiguration.isYaxisHidden) {\r\n      d3.selectAll('.yaxis-dashed').attr('class', 'lib-display-hidden');\r\n    }\r\n    if (this.chartConfiguration.isYaxisDashed) {\r\n      d3.selectAll('.yaxis-dashed').style('stroke-dasharray', '5 5').style('color', '#999999');\r\n    }\r\n  }\r\n\r\n  private renderYAxisGrid(svg: any, y: any, width: number): void {\r\n    svg\r\n      .append('g')\r\n      .call(d3.axisLeft(y).ticks(this.chartConfiguration.numberOfYTicks).tickSize(-width))\r\n      .style('color', 'var(--chart-axis-color, #B9B9B9)')\r\n      .style('opacity', '0.5')\r\n      .call((g) => g.select('.domain').remove());\r\n  }\r\n\r\n  private renderXAxisGrid(svg: any, x: any, height: number): void {\r\n    svg\r\n      .append('g')\r\n      .attr('class', 'grid')\r\n      .attr('transform', `translate(${x.bandwidth() / 2},${height})`)\r\n      .call(d3.axisBottom(x).tickSize(-height).tickFormat(''))\r\n      .style('stroke-dasharray', '5 5')\r\n      .style('color', 'var(--chart-grid-color, #999999)')\r\n      .call((g) => g.select('.domain').remove());\r\n  }\r\n\r\n  private renderLineYAxis(svgYAxisRight: any, lineYscale: any): void {\r\n    const yLineAxis = d3\r\n      .axisRight(lineYscale)\r\n      .ticks(this.chartConfiguration.numberOfYTicks)\r\n      .tickSize(0)\r\n      .tickFormat(this.chartConfiguration.yLineAxisLabelFomatter);\r\n\r\n    svgYAxisRight\r\n      .append('g')\r\n      .attr('class', 'lib-stacked-y-axis-text1')\r\n      .attr('style', this.chartConfiguration.yAxisCustomTextStyles)\r\n      .attr('transform', 'translate(0,0)')\r\n      .call(yLineAxis);\r\n  }\r\n\r\n  private renderBars(svg: any, chartContext: any, scales: any, dimensions: any): void {\r\n    const { data, metaData, keyList, isRia } = chartContext;\r\n    const { x, xSubgroup, y } = scales;\r\n    const { height } = dimensions;\r\n\r\n    const state = svg\r\n      .append('g')\r\n      .selectAll('.state')\r\n      .data(data)\r\n      .enter()\r\n      .append('g')\r\n      .attr('transform', (d) => `translate(${x(d.name)},0)`);\r\n\r\n    state\r\n      .selectAll('rect')\r\n      .data((d) => this.prepareBarData(d, keyList))\r\n      .enter()\r\n      .append('rect')\r\n      .attr('class', 'bars')\r\n      .on('click', (d) => this.handleBarClick(d, metaData))\r\n      .attr('x', (d) => this.getBarX(d, data, x, xSubgroup))\r\n      .attr('y', (d) => y(d.value))\r\n      .attr('width', (d) => this.getBarWidth(d, data, x, xSubgroup))\r\n      .attr('height', (d) => this.getBarHeight(d, y, height))\r\n      .style('cursor', (d) => (metaData.hasDrillDown && !isRia ? 'pointer' : 'default'))\r\n      .attr('fill', (d) => this.getBarColor(d, metaData));\r\n\r\n    if (!isRia && (this.chartConfiguration.displayTitleOnTop || (!this.chartConfiguration.textsOnBar && !this.chartConfiguration.displayTitleOnTop))) {\r\n      state.selectAll('rect').on('mouseout', (d, i) => this.handleMouseOut(svg)).on('mouseover', (d, i) => this.handleMouseOver(svg, d, data, metaData, x, y, scales.leftAndRightSpaces));\r\n    }\r\n\r\n    if (this.chartConfiguration.textsOnBar && !this.isZoomedOut) {\r\n      this.renderBarTexts(state, data, metaData, keyList, x, xSubgroup, y, isRia, svg);\r\n    }\r\n\r\n    if (this.chartConfiguration.isDrilldownChart) {\r\n      svg.selectAll('g.x1.axis1 g.tick line').style('display', 'none');\r\n    }\r\n  }\r\n\r\n  private prepareBarData(d: any, keyList: string[]): any[] {\r\n    return keyList.map((key) => ({ key, value: d[key], name: d.name }));\r\n  }\r\n\r\n  private handleBarClick(d: any, metaData: any): void {\r\n    if (d.key === 'Target') return;\r\n    if (\r\n      !metaData.barWithoutClick?.length ||\r\n      (!metaData.barWithoutClick.includes(d?.name) && !metaData.barWithoutClick.includes(d?.key))\r\n    ) {\r\n      this.handleClick(d);\r\n    }\r\n  }\r\n\r\n  private getBarX(d: any, data: any[], x: any, xSubgroup: any): number {\r\n    if (this.chartConfiguration.isDrilldownChart) {\r\n      return this.calculateDrilldownBarX(d, data, x);\r\n    }\r\n    return xSubgroup(d.key);\r\n  }\r\n\r\n  private calculateDrilldownBarX(d: any, data: any[], x: any): number {\r\n    let tempScale;\r\n    data.forEach((indiv: any) => {\r\n      if (indiv.name === d.name) {\r\n        const keys = Object.keys(indiv).filter((temp, i) => i !== 0);\r\n        tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);\r\n        if (x.bandwidth() > 100) {\r\n          tempScale = this.adjustDrilldownScale(tempScale, data, x);\r\n        }\r\n      }\r\n    });\r\n    return tempScale ? tempScale(d.key) : 0;\r\n  }\r\n\r\n  private adjustDrilldownScale(tempScale: any, data: any[], x: any): any {\r\n    if (this.chartData.data.length === 1) {\r\n      const keysLength = Object.keys(this.chartData.data[0]).length;\r\n      const offset = keysLength === 2 ? 200 : 300;\r\n      tempScale.range([\r\n        0 + (x.bandwidth() - offset) / 2,\r\n        x.bandwidth() - (x.bandwidth() - offset) / 2,\r\n      ]);\r\n    } else {\r\n      tempScale.range([\r\n        0 + (x.bandwidth() - 125) / 2,\r\n        x.bandwidth() - (x.bandwidth() - 125) / 2,\r\n      ]);\r\n    }\r\n    return tempScale;\r\n  }\r\n\r\n  private getBarWidth(d: any, data: any[], x: any, xSubgroup: any): number {\r\n    if (this.chartConfiguration.isDrilldownChart) {\r\n      let tempScale;\r\n      data.forEach((indiv: any) => {\r\n        if (indiv.name === d.name) {\r\n          const keys = Object.keys(indiv).filter((temp, i) => i !== 0);\r\n          tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);\r\n          if (x.bandwidth() > 100) {\r\n            tempScale = this.adjustDrilldownScale(tempScale, data, x);\r\n          }\r\n        }\r\n      });\r\n      return tempScale ? tempScale.bandwidth() : 0;\r\n    }\r\n    return xSubgroup.bandwidth();\r\n  }\r\n\r\n  private getBarHeight(d: any, y: any, height: number): number {\r\n    if (d.value === -1) return height - y(0);\r\n    if (d.value) return height - y(d.value);\r\n    return height - y(0);\r\n  }\r\n\r\n  private getBarColor(d: any, metaData: any): string {\r\n    if (\r\n      d.value &&\r\n      this.chartData.targetLineData &&\r\n      d.value >= parseInt(this.chartData.targetLineData.target) &&\r\n      this.chartData.metaData.colorAboveTarget\r\n    ) {\r\n      return this.chartData.metaData.colorAboveTarget[d.key];\r\n    }\r\n    return this.chartData.metaData.colors[d.key];\r\n  }\r\n\r\n  private renderBarTexts(\r\n    state: any,\r\n    data: any[],\r\n    metaData: any,\r\n    keyList: string[],\r\n    x: any,\r\n    xSubgroup: any,\r\n    y: any,\r\n    isRia: boolean,\r\n    svg: any\r\n  ): void {\r\n    state\r\n      .selectAll('text')\r\n      .data((d) => this.prepareBarData(d, keyList))\r\n      .enter()\r\n      .append('text')\r\n      .attr('x', 0)\r\n      .attr('y', 0)\r\n      .attr('class', 'lib-data-labels-weeklycharts')\r\n      .text((d) => this.getBarTextLabel(d))\r\n      .style('fill', '#000')\r\n      .style('font-weight', 'bold')\r\n      .style('font-size', () => this.getBarTextFontSize())\r\n      .attr('transform', (d) => this.getBarTextTransform(d, data, x, xSubgroup, y))\r\n      .on('click', (d) => this.handleBarClick(d, metaData));\r\n\r\n    if (!isRia) {\r\n      state\r\n        .selectAll('.lib-data-labels-weeklycharts')\r\n        .on('mouseout', (d, i) => this.handleMouseOut(svg))\r\n        .on('mouseover', (d, i) =>\r\n          this.handleMouseOver(svg, d, data, metaData, x, y, x.bandwidth())\r\n        );\r\n    }\r\n  }\r\n\r\n  private getBarTextLabel(d: any): string {\r\n    if (!d.key || !d.value) return '';\r\n    return d.key.length > 20 ? d.key.substring(0, 17) + '...' : d.key;\r\n  }\r\n\r\n  private getBarTextFontSize(): string {\r\n    if (this.chartConfiguration.isDrilldownChart) {\r\n      if (window.innerWidth > 1900) return '18px';\r\n      if (window.innerWidth < 1400) return '10px';\r\n      return '14px';\r\n    }\r\n    return '14px';\r\n  }\r\n\r\n  private getBarTextTransform(d: any, data: any[], x: any, xSubgroup: any, y: any): string {\r\n    let tempScale;\r\n    data.forEach((indiv: any) => {\r\n      if (indiv.name === d.name) {\r\n        const keys = Object.keys(indiv).filter((temp, i) => i !== 0);\r\n        tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);\r\n        if (x.bandwidth() > 100) {\r\n          tempScale = this.adjustDrilldownScale(tempScale, data, x);\r\n        }\r\n      }\r\n    });\r\n\r\n    if (this.chartConfiguration.textAlwaysHorizontal) {\r\n      return `translate(${xSubgroup(d.key)},${y(d.value) - 3})`;\r\n    }\r\n\r\n    if (tempScale && !isNaN(tempScale(d.key))) {\r\n      return `translate(${tempScale(d.key) + tempScale.bandwidth() * 0.55},${y(0) - 10}) rotate(270)`;\r\n    }\r\n    return 'translate(0,0)';\r\n  }\r\n\r\n  private handleMouseOver(\r\n    svg: any,\r\n    d: any,\r\n    data: any[],\r\n    metaData: any,\r\n    x: any,\r\n    y: any,\r\n    leftAndRightSpaces: number\r\n  ): void {\r\n    svg.selectAll('.lib-verticalstack-title-ontop').remove();\r\n\r\n    let tempScale;\r\n    data.forEach((indiv: any) => {\r\n      if (indiv.name === d.name) {\r\n        const keys = Object.keys(indiv).filter((temp, i) => i !== 0);\r\n        tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);\r\n        if (x.bandwidth() > 100) {\r\n          tempScale = this.adjustDrilldownScale(tempScale, data, x);\r\n        }\r\n      }\r\n    });\r\n\r\n    const foreignObject = svg\r\n      .append('foreignObject')\r\n      .attr('x', () => this.calculateTooltipX(d, x, tempScale, metaData, leftAndRightSpaces))\r\n      .attr('y', () => y(d.value) - 43)\r\n      .attr('class', 'lib-verticalstack-title-ontop')\r\n      .attr('width', () => this.calculateTooltipWidth(tempScale, metaData, leftAndRightSpaces))\r\n      .attr('height', 40);\r\n\r\n    foreignObject\r\n      .append('xhtml:div')\r\n      .attr('class', 'title')\r\n      .style('z-index', 99)\r\n      .html(() => this.getTooltipHTML(d, metaData));\r\n  }\r\n\r\n  private calculateTooltipX(\r\n    d: any,\r\n    x: any,\r\n    tempScale: any,\r\n    metaData: any,\r\n    leftAndRightSpaces: number\r\n  ): number {\r\n    if (metaData.hasDrillDown) {\r\n      if (tempScale.bandwidth() + leftAndRightSpaces * 2 > 180) {\r\n        return x(d.name) + tempScale(d.key) + tempScale.bandwidth() / 2 - 90;\r\n      }\r\n      return (\r\n        x(d.name) +\r\n        tempScale(d.key) -\r\n        (tempScale.bandwidth() + leftAndRightSpaces * 2) / 2 +\r\n        tempScale.bandwidth() / 2\r\n      );\r\n    }\r\n    return (\r\n      x(d.name) +\r\n      tempScale(d.key) -\r\n      (tempScale.bandwidth() + leftAndRightSpaces * 2) / 2 +\r\n      tempScale.bandwidth() / 2\r\n    );\r\n  }\r\n\r\n  private calculateTooltipWidth(tempScale: any, metaData: any, leftAndRightSpaces: number): string {\r\n    if (metaData.hasDrillDown) {\r\n      if (tempScale.bandwidth() + leftAndRightSpaces * 2 > 180) {\r\n        return '180px';\r\n      }\r\n      return tempScale.bandwidth() + leftAndRightSpaces * 2;\r\n    }\r\n    return tempScale.bandwidth() + leftAndRightSpaces * 2;\r\n  }\r\n\r\n  private getTooltipHTML(d: any, metaData: any): string {\r\n    const dataType = metaData.dataType || '';\r\n    if (!this.isZoomedOut) {\r\n      return `<span class=\"title-bar-name\">${d.name}</span><span class=\"title-bar-value\"><span>${d.value}</span>${dataType}</span>`;\r\n    } else {\r\n      const tempKey = d.name.length <= 8 ? d.name : d.name.substring(0, 5) + '...';\r\n      return `<span class=\"title-bar-name\">${tempKey}:${d.value}${dataType}</span><span class=\"title-bar-value\">${d.name}</span>`;\r\n    }\r\n  }\r\n\r\n  private handleMouseOut(svg: any): void {\r\n    svg.selectAll('.lib-verticalstack-title-ontop').remove();\r\n  }\r\n\r\n  private renderLabels(svgElements: any, scales: any, chartContext: any, dimensions: any): void {\r\n    const { svg, svgYAxisLeft, svgYAxisRight } = svgElements;\r\n    const { metaData } = chartContext;\r\n    const { width, height, margin } = dimensions;\r\n\r\n    if (metaData.yLabel) {\r\n      this.renderYAxisLabel(svgYAxisLeft, metaData.yLabel, height, margin);\r\n    }\r\n\r\n    if (metaData.xLabel) {\r\n      this.renderXAxisLabel(svg, metaData.xLabel, width, height, margin);\r\n    }\r\n\r\n    if (metaData.lineyLabel) {\r\n      this.renderLineYAxisLabel(svgYAxisRight, metaData.lineyLabel);\r\n    }\r\n  }\r\n\r\n  private renderYAxisLabel(svgYAxisLeft: any, yLabel: string, height: number, margin: any): void {\r\n    svgYAxisLeft\r\n      .append('text')\r\n      .attr('class', 'lib-axis-group-label font-size-1')\r\n      .attr('style', this.chartConfiguration.yAxisCustomlabelStyles)\r\n      .attr('transform', 'rotate(-90)')\r\n      .attr('y', 0 - margin.left / 2 - 30)\r\n      .attr('x', 0 - height / 2)\r\n      .attr('dy', '1em')\r\n      .style('text-anchor', 'middle')\r\n      .attr('fill', 'var(--chart-text-color)');\r\n\r\n    if (this.chartConfiguration.isMultiChartGridLine === undefined) {\r\n      svgYAxisLeft.selectAll('.lib-axis-group-label').style('font-size', 'smaller').text(yLabel);\r\n    } else {\r\n      svgYAxisLeft\r\n        .selectAll('.lib-axis-group-label')\r\n        .attr('class', 'lib-ylabel-weeklyCharts')\r\n        .text(yLabel.toLowerCase());\r\n    }\r\n  }\r\n\r\n  private renderXAxisLabel(svg: any, xLabel: string, width: number, height: number, margin: any): void {\r\n    const isAcronym = this.isAcronym(xLabel.replace(/[^A-Za-z]/g, ''));\r\n\r\n    let baseClass = 'lib-axis-group-label font-size-1';\r\n    if (this.chartConfiguration.isDrilldownChart) {\r\n      baseClass += ' lib-xlabel-drilldowncharts';\r\n    } else if (this.chartConfiguration.isMultiChartGridLine !== undefined) {\r\n      baseClass += ' lib-xlabel-weeklyCharts';\r\n    } else {\r\n      baseClass += ' lib-axis-waterfall-label';\r\n    }\r\n\r\n    svg\r\n      .append('text')\r\n      .attr('class', baseClass)\r\n      .attr('style', this.chartConfiguration.xAxisCustomlabelStyles)\r\n      .attr('transform', `translate(${width / 2},${height + margin.top + 20})`)\r\n      .style('text-anchor', 'middle')\r\n      .style('fill', 'var(--chart-text-color)')\r\n      .text(isAcronym ? xLabel.toUpperCase() : xLabel.toLowerCase())\r\n      .style('text-transform', isAcronym ? 'none' : 'capitalize');\r\n  }\r\n\r\n  private isAcronym(label: string): boolean {\r\n    return (\r\n      (label.length <= 4 && /^[A-Z]+$/.test(label)) ||\r\n      (label === label.toUpperCase() && /[A-Z]/.test(label))\r\n    );\r\n  }\r\n\r\n  private renderLineYAxisLabel(svgYAxisRight: any, lineyLabel: string): void {\r\n    svgYAxisRight\r\n      .append('text')\r\n      .attr('class', 'lib-axis-group-label lib-line-axis')\r\n      .attr('style', this.chartConfiguration.yAxisCustomlabelStyles)\r\n      .attr('transform', 'translate(0,0) rotate(90)')\r\n      .attr('y', -100)\r\n      .attr('x', 100)\r\n      .attr('dy', '5em')\r\n      .style('text-anchor', 'middle')\r\n      .style('font-size', 'smaller')\r\n      .text(lineyLabel);\r\n  }\r\n\r\n  private renderTargetLine(svgElements: any, scales: any, chartContext: any, dimensions: any): void {\r\n    if (!this.chartData.targetLineData) return;\r\n\r\n    const { svg, svgYAxisRight } = svgElements;\r\n    const { y } = scales;\r\n    const { width } = dimensions;\r\n    const { metaData } = chartContext;\r\n    const targetData: TargetLineData = this.chartData.targetLineData;\r\n\r\n    const yZero = y(targetData.target);\r\n\r\n    svg\r\n      .append('line')\r\n      .attr('x1', 0)\r\n      .attr('x2', width)\r\n      .attr('y1', yZero)\r\n      .attr('y2', yZero)\r\n      .style('stroke-dasharray', '5 5')\r\n      .style('stroke', targetData.color);\r\n\r\n    const rightSvgWidth = 60;\r\n    svgYAxisRight\r\n      .append('foreignObject')\r\n      .attr('transform', `translate(0,${yZero - 30})`)\r\n      .attr('width', rightSvgWidth)\r\n      .attr('height', 50)\r\n      .append('xhtml:div')\r\n      .attr('class', 'target-display')\r\n      .style('color', 'var(--chart-text-color)')\r\n      .html(() => {\r\n        const dataType = metaData.dataType || '';\r\n        const targetName = targetData.targetName || 'target';\r\n        return `<div>${targetName}</div><div>${targetData.target}${dataType}</div>`;\r\n      });\r\n  }\r\n\r\n  private renderLineGraph(svg: any, chartContext: any, scales: any): void {\r\n    const { lineData, metaData } = chartContext;\r\n    if (!lineData) return;\r\n\r\n    const { x, lineYscale } = scales;\r\n\r\n    svg\r\n      .append('path')\r\n      .datum(lineData)\r\n      .attr('fill', 'none')\r\n      .attr('stroke', this.chartConfiguration.lineGraphColor)\r\n      .attr('stroke-width', 1.5)\r\n      .attr(\r\n        'd',\r\n        d3\r\n          .line()\r\n          .x((d: any) => x(d.name) + x.bandwidth() / 2)\r\n          .y((d: any) => lineYscale(d.value))\r\n      );\r\n\r\n    const dot = svg\r\n      .selectAll('myCircles')\r\n      .data(lineData)\r\n      .enter()\r\n      .append('g')\r\n      .on('click', (d) => this.handleBarClick(d, metaData));\r\n\r\n    dot\r\n      .append('circle')\r\n      .attr('fill', this.chartConfiguration.lineGraphColor)\r\n      .attr('stroke', 'none')\r\n      .attr('cx', (d: any) => x(d.name) + x.bandwidth() / 2)\r\n      .attr('cy', (d: any) => lineYscale(d.value))\r\n      .style('cursor', 'pointer')\r\n      .attr('r', 3);\r\n\r\n    if (this.chartConfiguration.lineGraphColor) {\r\n      dot\r\n        .append('text')\r\n        .attr('class', 'dot')\r\n        .attr('color', this.chartConfiguration.lineGraphColor)\r\n        .attr('style', 'font-size: .85em')\r\n        .attr('x', (d: any) => x(d.name) + x.bandwidth() / 2)\r\n        .attr('y', (d: any) => lineYscale(d.value))\r\n        .attr('dy', '-1em')\r\n        .text((d: any) => this.chartConfiguration.labelFormatter(d.value));\r\n    }\r\n  }\r\n\r\n  handleClick(d: any): void {\r\n    if (this.chartData.metaData.hasDrillDown || d?.toggleFrom) {\r\n      this.clickEvent.emit(d);\r\n    }\r\n  }\r\n\r\n  handleHeaderMenuClick(id: string): void {\r\n    this.headerMenuclickEvent.emit(id);\r\n  }\r\n\r\n  handleDD1Click(event: any): void {\r\n    this.isDD1Open = true;\r\n    this.isDD2Open = false;\r\n  }\r\n\r\n  handleDD2Click(event: any): void {\r\n    this.isDD2Open = true;\r\n    this.isDD1Open = false;\r\n  }\r\n\r\n  handleCompareByFilterSelection(event: any): void {\r\n    this.clickEvent.emit(event);\r\n  }\r\n}","<div\r\n  #groupcontainer\r\n  class=\"lib-chart-wrapper\"\r\n  [ngClass]=\"{ 'lib-no-background': isTransparentBackground }\"\r\n  style=\"background-color: var(--card-bg);\"\r\n  (resized)=\"onResized($event)\"\r\n>\r\n\r\n<div class=\"header-alt\" *ngIf=\"!isHeaderVisible\">\r\n  <lib-chart-header-v2\r\n    [chartData]=\"chartData\"\r\n    [chartConfiguration]=\"chartConfiguration\"\r\n    (clickEvent)=\"handleClick($event)\"\r\n  ></lib-chart-header-v2>\r\n  <lib-chart-header-v3\r\n    [chartData]=\"chartData\"\r\n    [chartConfiguration]=\"chartConfiguration\"\r\n    (compareByFilterSelection)=\"handleCompareByFilterSelection($event)\"\r\n    (zoomInZoomOutClick)=\"handleZoominZoomoutClick($event)\"\r\n  ></lib-chart-header-v3>\r\n</div>\r\n\r\n  <lib-chart-header-v1\r\n  [title]=\"chartData.metaData.title\"\r\n  [hasDrillDown]=\"chartData.metaData.hasDrillDown\"\r\n  [isEditEnabled]=\"chartData.metaData.isEditEnabled\"\r\n  [menuOptions]=\"chartConfiguration.headerMenuOptions\"\r\n  [isria]=\"customChartConfiguration.isRia\"\r\n  [selectedKpiTooltop]=\"chartConfiguration.selectedKpiTooltop\"\r\n  (menuOptionClickEvent)=\"handleHeaderMenuClick($event)\"\r\n  [isAlertEnabled]=\"isAlertEnabled\"\r\n  *ngIf=\"isHeaderVisible\"\r\n></lib-chart-header-v1>\r\n\r\n  <div\r\n    [style.height]=\"chartConfiguration.svgHeight\"\r\n    id=\"groupchartcontainer\"\r\n    #groupchartcontainer\r\n    class=\"lib-chart-svg\"\r\n  ></div>\r\n</div>\r\n"]}
1059
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"group-chart.component.js","sourceRoot":"","sources":["../../../../../projects/axidio-styleguide-library/src/lib/group-chart/group-chart.component.ts","../../../../../projects/axidio-styleguide-library/src/lib/group-chart/group-chart.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  ViewChild,\r\n  ElementRef,\r\n  Input,\r\n  Output,\r\n  EventEmitter,\r\n  ViewEncapsulation,\r\n  OnChanges,\r\n} from '@angular/core';\r\nimport { ComponentUniqueId } from '../unique-id';\r\nimport ChartHelper from '../chart-helper';\r\nimport * as d3 from 'd3';\r\nimport { ResizedEvent } from 'angular-resize-event';\r\nimport HeaderConfigHelper from '../header-config';\r\n\r\n// Types\r\ninterface ChartData {\r\n  data: any[];\r\n  metaData: ChartMetaData;\r\n  lineData?: any[];\r\n  targetLineData?: TargetLineData;\r\n}\r\n\r\ninterface ChartMetaData {\r\n  unit?: string;\r\n  isCC?: boolean;\r\n  barWithoutClick?: string[];\r\n  colors: { [key: string]: string };\r\n  keyList: string[];\r\n  dataType?: string;\r\n  hasDrillDown?: boolean;\r\n  hoverColor?: string;\r\n  yLabel?: string;\r\n  xLabel?: string;\r\n  lineyLabel?: string;\r\n}\r\n\r\ninterface TargetLineData {\r\n  target: string | number;\r\n  color: string;\r\n  targetName?: string;\r\n  barAboveTargetColor?: string;\r\n  barAboveTargetHoverColor?: string;\r\n}\r\n\r\ninterface Dimensions {\r\n  width: number;\r\n  height: number;\r\n  containerWidth: number;\r\n  containerHeight: number;\r\n  barWidth: number;\r\n  barPadding: number;\r\n  requiredSvgWidth: number;\r\n}\r\n\r\n@Component({\r\n  selector: 'lib-group-chart',\r\n  templateUrl: './group-chart.component.html',\r\n  styleUrls: ['./group-chart.component.less', '../common-styles.less'],\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class GroupChartComponent extends ComponentUniqueId{\r\n  @ViewChild('groupchartcontainer', { static: true })\r\n  containerElt!: ElementRef;\r\n\r\n  @ViewChild('groupcontainer', { static: true })\r\n  groupcontainerElt!: ElementRef;\r\n\r\n  @Input() chartData: ChartData | any ;\r\n  @Input() customChartConfiguration: any;\r\n  @Output() clickEvent = new EventEmitter<any>();\r\n  @Output() headerMenuclickEvent = new EventEmitter<any>();\r\n\r\n  chartConfiguration: any = {};\r\n  isHeaderVisible = true;\r\n  isTopCaptionVisible = true;\r\n  uniqueId = this.getUniqueId();\r\n  isTransparentBackground = false;\r\n  isCC = false;\r\n  isZoomedOut = true;\r\n\r\n  private readonly CONSTANTS = {\r\n    RIGHT_SVG_WIDTH: 60,\r\n    LEFT_RIGHT_SPACES: 50,\r\n    SHORT_TICK_LENGTH: 4,\r\n    LONG_TICK_LENGTH: 16,\r\n    SHORT_TICK_LENGTH_BG: 5,\r\n    LONG_TICK_LENGTH_BG: 30,\r\n    DESKTOP_BAR_WIDTH: 40,      // Desktop bar width\r\n    MOBILE_BAR_WIDTH: 25,       // Mobile/Tablet bar width (reduced)\r\n    BAR_GAP: 30,                // Gap between bars (increased for better separation)\r\n    ZOOM_THRESHOLD: 30,\r\n    ZOOM_IN_THRESHOLD: 8,\r\n  };\r\n\r\n  defaultConfiguration = {\r\n    margin: { top: 20, right: 20, bottom: 20, left: 40 },\r\n    svgHeight: 70,\r\n    legendHeight: '10%',\r\n    numberOfYTicks: 5,\r\n    labelFormatter: ChartHelper.defaultFormatter,\r\n    xAxisLabelFomatter: ChartHelper.defaultFormatter,\r\n    yAxisLabelFomatter: ChartHelper.defaultFormatter,\r\n    yLineAxisLabelFomatter: ChartHelper.defaultFormatter,\r\n    lineGraphColor: '#F6D283',\r\n    showLineChartAxis: true,\r\n    showLegend: false,\r\n    forComparison: true,\r\n    headerMenuOptions: HeaderConfigHelper.headerConfig.headerMenuOptions,\r\n    yAxisGrid: false,\r\n    // Optional configs with undefined defaults\r\n    isHeaderVisible: undefined,\r\n    isTransparentBackground: undefined,\r\n    isTopCaptionVisible: undefined,\r\n    isMultiChartGridLine: undefined,\r\n    isFullScreen: undefined,\r\n    customYscale: undefined,\r\n    isXaxisLabelHidden: undefined,\r\n    isYaxisLabelHidden: undefined,\r\n    isYaxisHidden: undefined,\r\n    isYaxisDashed: undefined,\r\n    isXaxisColor: undefined,\r\n    textFormatter: undefined,\r\n    showTotalOnTop: undefined,\r\n    backendFormatterHasPriority: undefined,\r\n    showAngledLabels: undefined,\r\n    isNoAlternateXaxisText: undefined,\r\n    isXgridBetweenLabels: undefined,\r\n    showXaxisTop: undefined,\r\n    xAxisGrid: undefined,\r\n    xLabelsOnSameLine: undefined,\r\n    hideXaxisTick: undefined,\r\n    isDrilldownChart: undefined,\r\n    isTargetLine: undefined,\r\n    displayTitleOnTop: undefined,\r\n    isToggleVisible: undefined,\r\n    isTitleHidden: undefined,\r\n  };\r\n\r\n  constructor() {\r\n    super();\r\n  }\r\n\r\n  ngOnChanges() {\r\n    this.removeExistingChart();\r\n    this.initializeStackedChart();\r\n  }\r\n\r\n  onResized(event: ResizedEvent) {\r\n    setTimeout(() => {\r\n      this.removeExistingChart();\r\n      this.initializeStackedChart();\r\n    }, 10);\r\n  }\r\n\r\n  isZoomOutSelected(isZoomOut: boolean) {\r\n    this.isZoomedOut = isZoomOut;\r\n    this.ngOnChanges();\r\n  }\r\n\r\n  private removeExistingChart() {\r\n    d3.select('#' + this.uniqueId).remove();\r\n  }\r\n\r\n  private mergeConfigurations() {\r\n    for (const key in this.defaultConfiguration) {\r\n      this.chartConfiguration[key] = ChartHelper.getValueByConfigurationType(\r\n        key,\r\n        this.defaultConfiguration,\r\n        this.customChartConfiguration\r\n      );\r\n    }\r\n  }\r\n\r\n  private prepareMetaData(metaData: ChartMetaData): ChartMetaData {\r\n    if (!metaData.unit) metaData.unit = '';\r\n    if (metaData.isCC) this.isCC = metaData.isCC;\r\n    \r\n    if (metaData.barWithoutClick?.length) {\r\n      metaData.barWithoutClick = metaData.barWithoutClick.map(el => el.toLowerCase());\r\n    } else {\r\n      metaData.barWithoutClick = [];\r\n    }\r\n    \r\n    return metaData;\r\n  }\r\n\r\nprivate calculateDimensions(\r\n  chartContainer: any,\r\n  verticalContainer: any,\r\n  margin: any,\r\n  dataLength: number\r\n): Dimensions {\r\n  const containerWidth = chartContainer.node().getBoundingClientRect().width;\r\n  const containerHeight = verticalContainer.node().getBoundingClientRect().height;\r\n  \r\n  const leftAxisWidth = 80;\r\n  const rightAxisWidth = this.CONSTANTS.RIGHT_SVG_WIDTH;\r\n  const availableWidth = containerWidth - leftAxisWidth - rightAxisWidth;\r\n  \r\n  let width = availableWidth;\r\n  let height = containerHeight * (this.chartConfiguration.svgHeight / 100) - margin.top - margin.bottom;\r\n\r\n  if (dataLength > this.CONSTANTS.ZOOM_THRESHOLD && this.isZoomedOut) {\r\n    const minWidth = dataLength * 25;\r\n    width = Math.max(width, minWidth);\r\n  }\r\n\r\n  if (dataLength > this.CONSTANTS.ZOOM_IN_THRESHOLD && !this.isZoomedOut) {\r\n    width = dataLength * 130;\r\n  }\r\n\r\n  if (this.chartConfiguration.isFullScreen) {\r\n    height = this.chartConfiguration.svgHeight !== 80\r\n      ? this.chartConfiguration.svgHeight\r\n      : containerHeight;\r\n  }\r\n\r\n  if (this.chartConfiguration.isDrilldownChart) {\r\n    height = containerHeight - margin.top - margin.bottom - 130;\r\n  }\r\n\r\n  const isMobileOrTablet = window.innerWidth < 1024;\r\n  let barWidth: number;\r\n  let barPadding: number;\r\n  \r\n  if (isMobileOrTablet) {\r\n    if (dataLength === 1) {\r\n      barWidth = 60;\r\n      barPadding = 0;\r\n    } else if (dataLength === 2) {\r\n      barWidth = 50;\r\n      barPadding = 45;\r\n    } else if (dataLength === 3) {\r\n      barWidth = 45;\r\n      barPadding = 40;\r\n    } else if (dataLength <= 5) {\r\n      barWidth = 35;\r\n      barPadding = 30;\r\n    } else {\r\n      barWidth = 25;\r\n      barPadding = 25;\r\n    }\r\n  } else {\r\n    barWidth = this.CONSTANTS.DESKTOP_BAR_WIDTH;\r\n    barPadding = this.CONSTANTS.BAR_GAP;\r\n  }\r\n  \r\n  const totalBarsWidth = barWidth * dataLength;\r\n  const totalGaps = barPadding * (dataLength - 1);\r\n  const minRequiredWidth = totalBarsWidth + totalGaps + (this.CONSTANTS.LEFT_RIGHT_SPACES * 2);\r\n  const requiredSvgWidth = Math.max(availableWidth, minRequiredWidth);\r\n\r\n  return {\r\n    width,\r\n    height,\r\n    containerWidth,\r\n    containerHeight,\r\n    barWidth,\r\n    barPadding,\r\n    requiredSvgWidth,\r\n  };\r\n}\r\n\r\nprivate createSvgContainers(\r\n  chartContainer: any,\r\n  dimensions: Dimensions,\r\n  margin: any,\r\n  hasXLabel: boolean  // Add this parameter\r\n) {\r\n  // Calculate total height including space for X-axis label if present\r\n  const xLabelSpace = hasXLabel ? 30 : 0;\r\n  const totalHeight = dimensions.height + margin.top + margin.bottom + xLabelSpace;\r\n\r\n  // Main wrapper\r\n  const chartWrapper = chartContainer\r\n    .append('div')\r\n    .attr('id', this.uniqueId)\r\n    .attr('class', 'chart-wrapper-main')\r\n    .style('position', 'relative')\r\n    .style('width', '100%')\r\n    .style('height', `${totalHeight}px`);  // Include X-label space\r\n\r\nconst leftAxisContainer = chartWrapper\r\n  .append('div')\r\n  .attr('class', 'left-axis-container')\r\n  .style('position', 'absolute')\r\n  .style('left', '0')\r\n  .style('top', '0')\r\n  .style('width', '80px')\r\n  .style('height', `${dimensions.height + margin.top + margin.bottom}px`)\r\n  .style('background-color', 'var(--card-bg)')\r\n  .style('z-index', '10');\r\n\r\nconst svgYAxisLeft = leftAxisContainer\r\n  .append('svg')\r\n  .attr('width', '80')\r\n  .attr('height', dimensions.height + margin.top + margin.bottom)\r\n  .append('g')\r\n  .attr('transform', `translate(79,${margin.top})`);\r\n\r\n  // Right Y-axis - Fixed\r\n  const rightAxisContainer = chartWrapper\r\n    .append('div')\r\n    .attr('class', 'right-axis-container')\r\n    .style('position', 'absolute')\r\n    .style('right', '0')\r\n    .style('top', '0')\r\n    .style('width', `${this.CONSTANTS.RIGHT_SVG_WIDTH}px`)\r\n    .style('height', `${dimensions.height + margin.top + margin.bottom}px`)  // Exclude X-label space\r\n    .style('background-color', 'var(--card-bg)')\r\n    .style('z-index', '10');\r\n\r\n  const svgYAxisRight = rightAxisContainer\r\n    .append('svg')\r\n    .attr('width', this.CONSTANTS.RIGHT_SVG_WIDTH)\r\n    .attr('height', dimensions.height + margin.top + margin.bottom)\r\n    .append('g')\r\n    .attr('transform', `translate(0,${margin.top})`);\r\n\r\n  // Scrollable middle area\r\nconst scrollableContainer = chartWrapper\r\n  .append('div')\r\n  .attr('class', 'scrollable-chart-container')\r\n  .style('position', 'absolute')\r\n  .style('left', '80px')  // Exactly where left container ends\r\n  .style('right', `${this.CONSTANTS.RIGHT_SVG_WIDTH}px`)\r\n  .style('top', '0')\r\n  .style('width', 'auto')\r\n  .style('height', `${dimensions.height + margin.top + margin.bottom}px`)\r\n  .style('overflow-x', 'auto')\r\n  .style('overflow-y', 'hidden');\r\n\r\n\r\nconst innerContainer = scrollableContainer\r\n  .append('div')\r\n  .attr('class', 'inner-chart-container')\r\n  .style('min-width', '100%');\r\n\r\nconst svg = innerContainer\r\n  .append('svg')\r\n  .attr('width', dimensions.requiredSvgWidth)\r\n  .attr('height', dimensions.height + margin.top + margin.bottom + 30)\r\n  .append('g')\r\n  .attr('transform', `translate(0,${margin.top})`);\r\n\r\n  // Fixed bottom container for X-axis label\r\n  const bottomLabelContainer = chartWrapper\r\n    .append('div')\r\n    .attr('class', 'bottom-label-container')\r\n    .style('position', 'absolute')\r\n    .style('left', '80px')\r\n    .style('right', `${this.CONSTANTS.RIGHT_SVG_WIDTH}px`)\r\n    .style('bottom', '0')\r\n    .style('height', `${xLabelSpace}px`)\r\n    .style('display', 'flex')\r\n    .style('justify-content', 'center')\r\n    .style('align-items', 'center')\r\n    .style('background-color', 'var(--card-bg)')\r\n    .style('z-index', '10');\r\n\r\n  return { svg, svgYAxisLeft, svgYAxisRight, innerContainer, bottomLabelContainer };\r\n}\r\n\r\nprivate createScales(\r\n  data: any[],\r\n  layers: any[],\r\n  lineData: any[],\r\n  dimensions: Dimensions\r\n) {\r\n  const { width, height, barWidth, barPadding } = dimensions;\r\n  \r\n  // Calculate bar positioning\r\n  const totalBarsWidth = data.length * barWidth;\r\n  const totalSpacing = (data.length - 1) * barPadding;\r\n  const requiredWidth = totalBarsWidth + totalSpacing + (this.CONSTANTS.LEFT_RIGHT_SPACES * 2);\r\n  const effectiveWidth = Math.max(width, requiredWidth);\r\n  \r\n  const paddingRatio = barPadding / (barWidth + barPadding);\r\n  \r\n  // X-scale starts from 0 (no left spacing for grid alignment)\r\nconst xScale = d3\r\n  .scaleBand()\r\n  .rangeRound([0, dimensions.requiredSvgWidth])\r\n  .domain(data.map(d => d.name).reverse())\r\n  .paddingInner(paddingRatio)\r\n  .paddingOuter(0.1)  // Small padding for visual spacing\r\n  .align(0.5);\r\n\r\n  const xScaleFromOrigin = d3\r\n    .scaleBand()\r\n    .rangeRound([width, 0])\r\n    .domain(data.map(d => d.name).reverse());\r\n\r\n  const yScale = d3.scaleLinear().rangeRound([height, 0]);\r\n  \r\n  let maxValue = d3.max(layers, (d: any) => d3.max(d, (d: any) => d[1]));\r\n  \r\n  if (maxValue === 0) {\r\n    maxValue = this.chartData.targetLineData \r\n      ? Number(this.chartData.targetLineData.target) + 20 \r\n      : 100;\r\n  }\r\n\r\n  if (this.chartConfiguration.customYscale) {\r\n    maxValue *= this.chartConfiguration.customYscale;\r\n  }\r\n\r\n  if (this.chartData.targetLineData && maxValue < Number(this.chartData.targetLineData.target)) {\r\n    const target = Number(this.chartData.targetLineData.target);\r\n    maxValue = maxValue < 10 && target < 10 ? target + 3 : target + 20;\r\n  }\r\n\r\n  yScale.domain([0, maxValue]).nice();\r\n\r\n  let lineYscale = null;\r\n  if (lineData) {\r\n    lineYscale = d3\r\n      .scaleLinear()\r\n      .domain([0, d3.max(lineData, d => +d.value)])\r\n      .range([height, 0]);\r\n  }\r\n\r\n  return { xScale, xScaleFromOrigin, yScale, lineYscale };\r\n}\r\n\r\n\r\n  private createAxes(scales: any) {\r\n    const xAxis = d3\r\n      .axisBottom(scales.xScale)\r\n      .tickSize(0)\r\n      .tickFormat(this.chartConfiguration.xAxisLabelFomatter);\r\n\r\n    const yAxis = d3\r\n      .axisLeft(scales.yScale)\r\n      .ticks(this.chartConfiguration.numberOfYTicks)\r\n      .tickSize(0)\r\n      .tickFormat(this.chartConfiguration.yAxisLabelFomatter);\r\n\r\n    let yLineAxis = null;\r\n    if (scales.lineYscale) {\r\n      yLineAxis = d3\r\n        .axisRight(scales.lineYscale)\r\n        .ticks(this.chartConfiguration.numberOfYTicks)\r\n        .tickSize(0)\r\n        .tickFormat(this.chartConfiguration.yLineAxisLabelFomatter);\r\n    }\r\n\r\n    return { xAxis, yAxis, yLineAxis };\r\n  }\r\n\r\n  private renderBars(\r\n    svg: any,\r\n    layers: any[],\r\n    scales: any,\r\n    metaData: ChartMetaData,\r\n    dimensions: Dimensions\r\n  ) {\r\n    const layer = svg\r\n      .selectAll('.layer')\r\n      .data(layers)\r\n      .enter()\r\n      .append('g')\r\n      .attr('class', 'layer')\r\n      .style('fill', (d: any) => metaData.colors[d.key]);\r\n\r\n    const rect = layer\r\n      .selectAll('rect')\r\n      .data((d: any) => d)\r\n      .enter();\r\n\r\n    this.appendRectangles(rect, scales, metaData, dimensions);\r\n    this.addInteractions(rect, svg, metaData, scales);\r\n    \r\n    return rect;\r\n  }\r\n\r\n  private appendRectangles(\r\n  rect: any,\r\n  scales: any,\r\n  metaData: ChartMetaData,\r\n  dimensions: Dimensions\r\n) {\r\n  const { barWidth, barPadding } = dimensions;\r\n  const { xScale, yScale } = scales;\r\n\r\n  rect\r\n    .append('rect')\r\n    .on('click', (d: any) => {\r\n      if (!this.chartData.lineData || this.chartConfiguration.forComparison) {\r\n        if (!metaData.barWithoutClick?.includes(d.data.name.toLowerCase())) {\r\n          this.handleClick(d.data.name);\r\n        }\r\n      }\r\n    })\r\n    .attr('y', (d: any) => {\r\n      if (!isNaN(d[0]) && !isNaN(d[1])) {\r\n        const actualHeight = yScale(d[0]) - yScale(d[1]);\r\n        return actualHeight < 3 ? yScale(d[0]) - 3 : yScale(d[1]);\r\n      }\r\n      return 0;\r\n    })\r\n    .attr('x', (d: any) => {\r\n      const xPosition = xScale(d.data.name);\r\n      const bandwidth = xScale.bandwidth();\r\n      \r\n      if (!this.chartConfiguration.isMultiChartGridLine) {\r\n        return xPosition + (bandwidth - barWidth) / 2;\r\n      }\r\n      if (this.chartConfiguration.isDrilldownChart && this.chartData.data.length <= 3) {\r\n        return xPosition + bandwidth / 2 - 35;\r\n      }\r\n      const calculatedWidth = bandwidth * 0.8;\r\n      return xPosition + (bandwidth - calculatedWidth) / 2;\r\n    })\r\n    .attr('height', (d: any) => {\r\n      if (!isNaN(d[0]) && !isNaN(d[1])) {\r\n        const actualHeight = yScale(d[0]) - yScale(d[1]);\r\n        return actualHeight < 3 ? 3 : actualHeight;\r\n      }\r\n      return 0;\r\n    })\r\n    .attr('width', (d: any) => {\r\n      if (!this.chartConfiguration.isMultiChartGridLine) return barWidth;\r\n      if (this.chartConfiguration.isDrilldownChart && this.chartData.data.length <= 3) {\r\n        return 70;\r\n      }\r\n      return xScale.bandwidth() * 0.8;\r\n    })\r\n    .style('cursor', (d: any) => {\r\n      if (metaData.hasDrillDown) {\r\n        if (metaData.barWithoutClick?.includes(d.data.name.toLowerCase())) {\r\n          return 'default';\r\n        }\r\n        return 'pointer';\r\n      }\r\n      return 'default';\r\n    })\r\n    .style('fill', (d: any) => this.getBarColor(d, metaData));\r\n}\r\n\r\n  private getBarColor(d: any, metaData: ChartMetaData): string {\r\n    if (\r\n      !isNaN(d[0]) &&\r\n      !isNaN(d[1]) &&\r\n      this.chartData.targetLineData &&\r\n      parseFloat(d[1]) - parseFloat(d[0]) >= parseFloat(String(this.chartData.targetLineData.target))\r\n    ) {\r\n      return this.chartData.targetLineData.barAboveTargetColor || metaData.colors[d.key];\r\n    }\r\n    return metaData.colors[d.key];\r\n  }\r\n\r\n  private addInteractions(rect: any, svg: any, metaData: ChartMetaData, scales: any) {\r\n    rect\r\n      .selectAll('rect')\r\n      .on('mouseenter', (d: any) => this.handleMouseOver(d, svg, metaData, scales))\r\n      .on('mouseout', (d: any) => this.handleMouseOut(svg, metaData));\r\n  }\r\n\r\n  private handleMouseOver(d: any, svg: any, metaData: ChartMetaData, scales: any) {\r\n    if (!this.chartConfiguration.displayTitleOnTop) return;\r\n\r\n    svg.selectAll('rect')\r\n      .filter((data: any) => data === d)\r\n      .style('fill', (d: any) => this.getHoverColor(d, metaData));\r\n\r\n    this.displayTooltip(d, svg, metaData, scales);\r\n  }\r\n\r\n  private getHoverColor(d: any, metaData: ChartMetaData): string {\r\n    if (\r\n      !isNaN(d[0]) &&\r\n      !isNaN(d[1]) &&\r\n      this.chartData.targetLineData &&\r\n      parseFloat(d[1]) - parseFloat(d[0]) >= parseFloat(String(this.chartData.targetLineData.target))\r\n    ) {\r\n      return this.chartData.targetLineData.barAboveTargetHoverColor ||\r\n             this.chartData.targetLineData.barAboveTargetColor ||\r\n             metaData.colors[d.key];\r\n    }\r\n    return metaData.hoverColor || metaData.colors[d.key];\r\n  }\r\n\r\n  private displayTooltip(d: any, svg: any, metaData: ChartMetaData, scales: any) {\r\n    const { xScale, yScale } = scales;\r\n    const value = d[1] - d[0];\r\n    \r\n    if (isNaN(value)) return;\r\n\r\n    const bandwidth = xScale.bandwidth();\r\n    \r\n    // Fixed tooltip width for all resolutions\r\n    const width = /week/i.test(d.data.name) && /\\d{4}-\\d{2}-\\d{2}/.test(d.data.name)\r\n      ? '250px'\r\n      : bandwidth + this.CONSTANTS.LEFT_RIGHT_SPACES * 2 > 180\r\n        ? '180px'\r\n        : bandwidth + this.CONSTANTS.LEFT_RIGHT_SPACES * 2;\r\n\r\n    svg\r\n      .append('foreignObject')\r\n      .attr('x', this.calculateTooltipX(d, xScale, width))\r\n      .attr('class', 'lib-verticalstack-title-ontop')\r\n      .attr('y', yScale(d[1]) - 51)\r\n      .attr('width', width)\r\n      .attr('height', 40)\r\n      .append('xhtml:div')\r\n      .attr('class', 'title')\r\n      .style('z-index', 99)\r\n      .html(this.generateTooltipHtml(d, metaData, value));\r\n  }\r\n\r\n  private calculateTooltipX(d: any, xScale: any, width: string | number): number {\r\n    const bandwidth = xScale.bandwidth();\r\n    const numericWidth = typeof width === 'string' ? parseInt(width) : width;\r\n    \r\n    if (bandwidth + this.CONSTANTS.LEFT_RIGHT_SPACES * 2 > 180) {\r\n      return xScale(d.data.name) - this.CONSTANTS.LEFT_RIGHT_SPACES +\r\n             (bandwidth + this.CONSTANTS.LEFT_RIGHT_SPACES * 2 - 180) / 2;\r\n    }\r\n    return xScale(d.data.name) - this.CONSTANTS.LEFT_RIGHT_SPACES;\r\n  }\r\n\r\n  private generateTooltipHtml(d: any, metaData: ChartMetaData, value: number): string {\r\n    if (value === 0) return '<span class=\"title-top-text\">0</span>';\r\n\r\n    const dataType = metaData.dataType || '';\r\n    const name = d.data.name ? `<span class=\"title-bar-name\">${d.data.name}</span>` : '';\r\n    const valueText = metaData.unit\r\n      ? `${metaData.unit}${value} ${dataType}`\r\n      : `${value} ${dataType}`;\r\n\r\n    return `${name}<span class=\"title-top-text\">${valueText}</span>`;\r\n  }\r\n\r\n  private handleMouseOut(svg: any, metaData: ChartMetaData) {\r\n    if (!this.chartConfiguration.displayTitleOnTop) return;\r\n\r\n    svg.selectAll('rect')\r\n      .style('fill', (d: any) => this.getBarColor(d, metaData));\r\n    svg.selectAll('.lib-verticalstack-title-ontop').remove();\r\n  }\r\n\r\n  private renderAxisLabels(\r\n    svg: any,\r\n    svgYAxisLeft: any,\r\n    bottomLabelContainer: any,\r\n    metaData: ChartMetaData,\r\n    dimensions: Dimensions,\r\n    margin: any\r\n  ) {\r\n    if (metaData.yLabel) {\r\n      this.addYAxisLabel(svgYAxisLeft, metaData.yLabel, dimensions.height, margin);\r\n    }\r\n\r\n    if (metaData.xLabel) {\r\n      this.addXAxisLabel(bottomLabelContainer, metaData.xLabel);\r\n    }\r\n  }\r\n\r\n  private addYAxisLabel(svgYAxisLeft: any, label: string, height: number, margin: any) {\r\n    const isria = this.customChartConfiguration?.isRia;\r\n    const isAcronym = this.isAcronymLabel(label);\r\n    const yPosition = isria ? -margin.left / 2 - 30 : -margin.left / 2 - 40;\r\n\r\n    svgYAxisLeft.selectAll('.lib-axis-group-label, .lib-ylabel-drilldowncharts, .lib-ylabel-weeklyCharts').remove();\r\n\r\n    svgYAxisLeft\r\n      .append('text')\r\n      .attr('class', this.getYAxisLabelClass())\r\n      .attr('style', this.chartConfiguration.yAxisCustomlabelStyles)\r\n      .attr('transform', 'rotate(-90)')\r\n      .attr('y', yPosition)\r\n      .attr('x', -height / 2)\r\n      .attr('dy', '1em')\r\n      .style('text-anchor', 'middle')\r\n      .style('fill', 'var(--chart-text-color)')\r\n      .text(isAcronym ? label.toUpperCase() : label.toLowerCase())\r\n      .style('text-transform', isAcronym ? 'none' : 'capitalize');\r\n  }\r\n\r\nprivate addXAxisLabel(bottomLabelContainer: any, label: string) {\r\n  const isAcronym = this.isAcronymLabel(label);\r\n\r\n  bottomLabelContainer\r\n    .append('div')\r\n    .style('width', '100%')\r\n    .style('text-align', 'center')\r\n    .style('font-size', '12px')\r\n    .style('font-weight', '600')\r\n    .style('font-family', 'system-ui, -apple-system, BlinkMacSystemFont, \"Segoe UI\", Roboto')\r\n    .style('color', 'var(--chart-text-color)')\r\n    .style('text-transform', isAcronym ? 'none' : 'capitalize')\r\n    .text(isAcronym ? label.toUpperCase() : label.toLowerCase());\r\n}\r\n\r\n  private isAcronymLabel(label: string): boolean {\r\n    const cleanLabel = label.replace(/[^A-Za-z]/g, '');\r\n    return (label.length <= 4 && /^[A-Z]+$/.test(label)) ||\r\n           (label === label.toUpperCase() && /[A-Z]/.test(label));\r\n  }\r\n\r\n  private getYAxisLabelClass(): string {\r\n    let baseClass = 'lib-axis-group-label font-size-1';\r\n    if (this.chartConfiguration.isDrilldownChart) {\r\n      return `${baseClass} lib-ylabel-drilldowncharts`;\r\n    }\r\n    if (this.chartConfiguration.isMultiChartGridLine !== undefined) {\r\n      return `${baseClass} lib-ylabel-weeklyCharts`;\r\n    }\r\n    return `${baseClass} lib-axis-waterfall-label`;\r\n  }\r\n\r\n  private getXAxisLabelClass(): string {\r\n    let baseClass = 'lib-axis-group-label font-size-1';\r\n    if (this.chartConfiguration.isDrilldownChart) {\r\n      return `${baseClass} lib-xlabel-drilldowncharts`;\r\n    }\r\n    if (this.chartConfiguration.isMultiChartGridLine !== undefined) {\r\n      return `${baseClass} lib-xlabel-weeklyCharts`;\r\n    }\r\n    return `${baseClass} lib-axis-waterfall-label`;\r\n  }\r\n\r\n  private renderGridsFromLeftAxis(\r\n    svgMain: any,\r\n    svgYAxisLeft: any,\r\n    scales: any,\r\n    dimensions: Dimensions\r\n  ) {\r\n    if (!this.chartConfiguration.yAxisGrid) return;\r\n\r\n    // We want horizontal grid lines to span the full visible width:\r\n    // the inner SVG (requiredSvgWidth) plus the right axis width.\r\n    const gridSpan = dimensions.requiredSvgWidth + this.CONSTANTS.RIGHT_SVG_WIDTH;\r\n    // Append the grid to the main (inner) SVG so lines are rendered across the scrollable area.\r\n    svgMain\r\n      .append('g')\r\n      .attr('class', 'grid horizontal-grid-from-left')\r\n      .attr('transform', 'translate(0,0)')\r\n      .call(\r\n        d3\r\n          .axisLeft(scales.yScale)\r\n          .ticks(this.chartConfiguration.numberOfYTicks)\r\n          .tickSize(-gridSpan)\r\n          .tickFormat('')\r\n      )\r\n      .style('color', 'var(--chart-grid-color)')\r\n      .style('opacity', '1')\r\n      .call((g: any) => {\r\n        g.select('.domain').remove();\r\n        g.selectAll('.tick line')\r\n          .style('stroke', 'var(--chart-grid-color)')\r\n          .style('stroke-width', '1px');\r\n      });\r\n}\r\n\r\n  private applyConfigurationFlags() {\r\n    if (this.chartConfiguration.isHeaderVisible !== undefined) {\r\n      this.isHeaderVisible = this.chartConfiguration.isHeaderVisible;\r\n    }\r\n    if (this.chartConfiguration.isTopCaptionVisible !== undefined) {\r\n      this.isTopCaptionVisible = this.chartConfiguration.isTopCaptionVisible;\r\n    }\r\n    if (this.chartConfiguration.isTransparentBackground !== undefined) {\r\n      this.isTransparentBackground = this.chartConfiguration.isTransparentBackground;\r\n    }\r\n  }\r\n\r\n  initializeStackedChart() {\r\n    // Use fixed configuration for all resolutions\r\n    this.chartConfiguration.margin = { top: 20, right: 20, bottom: 40, left: 40 };\r\n    this.chartConfiguration.numberOfYTicks = 5;\r\n    this.chartConfiguration.svgHeight = 70;\r\n    \r\n    this.mergeConfigurations();\r\n    this.applyConfigurationFlags();\r\n\r\n    const data = this.chartData.data;\r\n    const metaData = this.prepareMetaData(this.chartData.metaData);\r\n    const lineData = this.chartData.lineData;\r\n    const colors = metaData.colors;\r\n    const keyList = metaData.keyList;\r\n\r\n    const chartContainer = d3.select(this.containerElt.nativeElement);\r\n    const verticalstackedcontainer = d3.select(this.groupcontainerElt.nativeElement);\r\n    \r\n    const margin = this.chartConfiguration.margin;\r\n    const dimensions = this.calculateDimensions(\r\n      chartContainer,\r\n      verticalstackedcontainer,\r\n      margin,\r\n      data.length\r\n    );\r\n\r\n    const hasXLabel = !!metaData.xLabel;\r\n\r\n    const { svg, svgYAxisLeft, svgYAxisRight, bottomLabelContainer } = this.createSvgContainers(\r\n      chartContainer,\r\n      dimensions,\r\n      margin,\r\n      hasXLabel\r\n    );\r\n\r\n    const stack: any = d3.stack().keys(keyList).offset(d3.stackOffsetNone);\r\n    const layers: any = stack(data);\r\n    data.sort((a, b) => b.total - a.total);\r\n\r\n    const scales = this.createScales(data, layers, lineData, dimensions);\r\n    const axes = this.createAxes(scales);\r\n\r\n    this.renderGridsFromLeftAxis(svg, svgYAxisLeft, scales, dimensions);\r\n    this.renderGrids(svg, scales, dimensions);\r\n    const rect = this.renderBars(svg, layers, scales, metaData, dimensions);\r\n    this.renderAxes(svg, svgYAxisLeft, svgYAxisRight, axes, scales, dimensions, data);\r\n    this.renderAxisLabels(svg, svgYAxisLeft,bottomLabelContainer, metaData, dimensions, margin);\r\n    this.renderTargetLine(svg, svgYAxisRight, scales, dimensions, metaData);\r\n    this.renderDataLabels(rect, scales, metaData, dimensions);\r\n    this.renderLineChart(svg, lineData, scales, colors, metaData);\r\n  }\r\n\r\nprivate renderGrids(svg: any, scales: any, dimensions: Dimensions) {\r\n  if (this.chartConfiguration.isXgridBetweenLabels) {\r\n    svg\r\n      .append('g')\r\n      .attr('class', 'grid vertical-grid')\r\n      .attr('transform', `translate(${scales.xScale.bandwidth() / 2},${dimensions.height})`)\r\n      .call(d3.axisBottom(scales.xScale).tickSize(-dimensions.height).tickFormat(''))\r\n      .style('stroke-dasharray', '5 5')\r\n      .style('color', '#999999')\r\n      .call((g: any) => g.select('.domain').remove());\r\n  }\r\n\r\n  if (this.chartConfiguration.xAxisGrid) {\r\n    for (let j = 0; j < this.chartConfiguration.xAxisGrid.length; j++) {\r\n      svg\r\n        .append('g')\r\n        .attr('class', `x${j + 2} axis${j + 2}`)\r\n        .style('color', 'var(--chart-grid-color)')\r\n        .attr('transform', `translate(0,${dimensions.height * this.chartConfiguration.xAxisGrid[j]})`)\r\n        .call(d3.axisBottom(scales.xScale).tickSize(0).ticks(5).tickFormat(''))\r\n        .style('fill', 'var(--chart-text-color)');\r\n    }\r\n  }\r\n}\r\n\r\n\r\n  private renderAxes(\r\n    svg: any,\r\n    svgYAxisLeft: any,\r\n    svgYAxisRight: any,\r\n    axes: any,\r\n    scales: any,\r\n    dimensions: Dimensions,\r\n    data: any[]\r\n  ) {\r\n    if (this.chartConfiguration.showXaxisTop) {\r\n      svg\r\n        .append('g')\r\n        .attr('class', 'lib-line-axis-text lib-line-x-axis-text x-axis')\r\n        .attr('style', this.chartConfiguration.xAxisCustomTextStyles)\r\n        .call(d3.axisBottom(scales.xScale).tickSize(0));\r\n      svg.selectAll('.x-axis > g > text').attr('class', 'lib-display-hidden');\r\n    }\r\n\r\n    if (!this.chartConfiguration.isMultiChartGridLine) {\r\n      this.renderStandardAxes(svg, axes, scales, dimensions, data);\r\n    } else if (this.chartConfiguration.isDrilldownChart) {\r\n      this.renderDrilldownAxes(svg, svgYAxisLeft, svgYAxisRight, axes, scales, dimensions);\r\n    } else {\r\n      this.renderMultiChartAxes(svg, axes, scales, dimensions);\r\n    }\r\n\r\n    this.applyAxisStyling(svg, svgYAxisLeft, svgYAxisRight);\r\n    this.applyAxisConfigurations(svg, scales, dimensions, data);\r\n  }\r\n\r\nprivate renderStandardAxes(\r\n  svg: any,\r\n  axes: any,\r\n  scales: any,\r\n  dimensions: Dimensions,\r\n  data: any[]\r\n) {\r\n  const isMobileOrTablet = window.innerWidth < 1024;\r\n  \r\n  // X-axis with labels\r\n  const xAxisGroup = svg\r\n    .append('g')\r\n    .attr('transform', `translate(0,${dimensions.height})`)\r\n    .attr('class', 'lib-stacked-x-axis-text')\r\n    .call(axes.xAxis);\r\n\r\n  // Style X-axis labels\r\n  xAxisGroup\r\n    .selectAll('text')\r\n    .style('fill', 'var(--chart-text-color)')\r\n    .style('font-size', isMobileOrTablet ? '10px' : '12px')\r\n    .attr('text-anchor', 'middle')\r\n    .attr('dy', '1em')\r\n    .each(function(this: SVGTextElement, d: any) {\r\n      const textElement = d3.select(this);\r\n      const text = textElement.text();\r\n        \r\n      if (isMobileOrTablet && text.length > 12) {\r\n        textElement.text(text.substring(0, 10) + '...');\r\n      }\r\n    });\r\n\r\n// Ensure X-axis line starts exactly at x=0\r\n  xAxisGroup\r\n    .select('.domain')\r\n    .style('stroke', 'var(--chart-axis-color)')\r\n    .style('stroke-width', '1px')\r\n    .attr('d', `M0,0.5H${dimensions.requiredSvgWidth}`);\r\n\r\n  // Y-axis\r\n  svg\r\n    .append('g')\r\n    .attr('class', 'lib-stacked-y-axis-text')\r\n    .attr('style', this.chartConfiguration.yAxisCustomTextStyles)\r\n    .call(axes.yAxis)\r\n    .selectAll('text')\r\n    .style('fill', 'var(--chart-text-color)');\r\n}\r\n\r\n  private renderDrilldownAxes(\r\n    svg: any,\r\n    svgYAxisLeft: any,\r\n    svgYAxisRight: any,\r\n    axes: any,\r\n    scales: any,\r\n    dimensions: Dimensions\r\n  ) {\r\n    svg\r\n      .append('g')\r\n      .attr('transform', `translate(0,${dimensions.height})`)\r\n      .attr('class', 'lib-stacked-x-axis-text multichart1')\r\n      .call(axes.xAxis)\r\n      .style('display', 'none');\r\n\r\n    svgYAxisLeft\r\n      .append('g')\r\n      .attr('class', 'lib-yaxis-labels-texts-drilldown yaxis-dashed')\r\n      .attr('style', this.chartConfiguration.yAxisCustomTextStyles)\r\n      .call(axes.yAxis)\r\n      .selectAll('text')\r\n      .style('fill', 'var(--chart-text-color)');\r\n\r\n    svgYAxisRight\r\n      .append('g')\r\n      .attr('class', 'lib-yaxis-labels-texts-drilldown yaxis-dashed')\r\n      .attr('style', this.chartConfiguration.yAxisCustomTextStyles)\r\n      .call(axes.yAxis)\r\n      .style('display', 'none');\r\n  }\r\n\r\n  private renderMultiChartAxes(svg: any, axes: any, scales: any, dimensions: Dimensions) {\r\n    svg\r\n      .append('g')\r\n      .attr('transform', `translate(0,${dimensions.height})`)\r\n      .attr('class', 'lib-stacked-x-axis-text multichart')\r\n      .call(axes.xAxis)\r\n      .selectAll('text')\r\n      .style('fill', 'var(--chart-text-color)');\r\n\r\n    svg\r\n      .append('g')\r\n      .attr('class', 'lib-stacked-y-axis-text yaxis-dashed')\r\n      .attr('style', this.chartConfiguration.yAxisCustomTextStyles)\r\n      .call(axes.yAxis)\r\n      .selectAll('text')\r\n      .style('fill', 'var(--chart-text-color)');\r\n  }\r\n\r\n  private applyAxisStyling(svg: any, svgYAxisLeft: any, svgYAxisRight: any) {\r\n    const styleAxisDomain = (container: any) => {\r\n      container.selectAll('.domain')\r\n        .style('stroke', 'var(--chart-axis-color)')\r\n        .style('stroke-width', '1px');\r\n    };\r\n\r\n    styleAxisDomain(svg);\r\n    styleAxisDomain(svgYAxisLeft);\r\n    styleAxisDomain(svgYAxisRight);\r\n\r\n    if (this.chartConfiguration.isYaxisDashed) {\r\n      d3.selectAll('.yaxis-dashed')\r\n        .style('stroke-dasharray', '5 5')\r\n        .style('color', 'var(--chart-grid-color)');\r\n    }\r\n\r\n    if (this.chartConfiguration.isXaxisColor) {\r\n      d3.selectAll('.multichart').style(\r\n        'color',\r\n        this.chartConfiguration.isXaxisColor || 'var(--chart-text-color)'\r\n      );\r\n    }\r\n  }\r\n\r\n  private applyAxisConfigurations(svg: any, scales: any, dimensions: Dimensions, data: any[]) {\r\n    if (this.chartConfiguration.isMultiChartGridLine !== undefined) {\r\n      d3.selectAll('.multichart > g > text').attr('class', 'lib-display-hidden');\r\n    }\r\n\r\n    if (this.chartConfiguration.isXaxisLabelHidden) {\r\n      d3.selectAll('.multichart > g > text').attr('class', 'lib-display-hidden');\r\n    } else if (this.chartConfiguration.isXaxisLabelHidden !== undefined) {\r\n      this.renderCustomXAxis(svg, scales, dimensions, data);\r\n    }\r\n\r\n    if (this.chartConfiguration.isYaxisLabelHidden) {\r\n      svg.selectAll('.yaxis-dashed > g > text').attr('class', 'lib-display-hidden');\r\n    }\r\n\r\n    if (this.chartConfiguration.isYaxisHidden) {\r\n      d3.selectAll('.yaxis-dashed').attr('class', 'lib-display-hidden');\r\n    }\r\n\r\n    if (this.isZoomedOut && data.length > 9) {\r\n      svg\r\n        .selectAll('.lib-xaxis-labels-texts-drilldown')\r\n        .attr('transform', 'rotate(-90)')\r\n        .attr('text-anchor', 'end')\r\n        .attr('x', '-5')\r\n        .attr('dy', null);\r\n    }\r\n  }\r\n\r\n  private renderCustomXAxis(svg: any, scales: any, dimensions: Dimensions, data: any[]) {\r\n    svg\r\n      .append('g')\r\n      .attr('class', 'x1 axis1')\r\n      .attr('transform', `translate(0,${dimensions.height})`)\r\n      .style('color', '#000')\r\n      .call(d3.axisBottom(scales.xScale).tickSize(0))\r\n      .call((g: any) => g.select('.domain').attr('fill', 'none'));\r\n\r\n    this.styleCustomXAxisTicks(svg, data);\r\n\r\n    if (this.chartConfiguration.xLabelsOnSameLine) {\r\n      this.applyXLabelsOnSameLine(svg);\r\n    }\r\n  }\r\n\r\n  private styleCustomXAxisTicks(svg: any, data: any[]) {\r\n    let alternateText = false;\r\n\r\n    svg.selectAll('.x1.axis1 .tick line').attr('y2', () => {\r\n      if (this.chartConfiguration.hideXaxisTick) return 0;\r\n      \r\n      if (alternateText && !this.chartConfiguration.isNoAlternateXaxisText) {\r\n        alternateText = false;\r\n        return this.CONSTANTS.LONG_TICK_LENGTH_BG - 7;\r\n      }\r\n      alternateText = true;\r\n      return this.CONSTANTS.SHORT_TICK_LENGTH_BG - 4;\r\n    });\r\n\r\n    alternateText = false;\r\n    svg\r\n      .selectAll('g.x1.axis1 g.tick text')\r\n      .attr('class', () => {\r\n        if (this.chartConfiguration.isDrilldownChart) {\r\n          return data.length > 8 \r\n            ? 'lib-xaxis-labels-texts-drilldown-alt'\r\n            : 'lib-xaxis-labels-texts-drilldown';\r\n        }\r\n        return 'lib-xaxis-labels-texts-weeklycharts';\r\n      })\r\n      .attr('y', () => {\r\n        if (alternateText) {\r\n          alternateText = false;\r\n          return this.CONSTANTS.LONG_TICK_LENGTH_BG;\r\n        }\r\n        alternateText = true;\r\n        return this.CONSTANTS.SHORT_TICK_LENGTH_BG;\r\n      });\r\n  }\r\n\r\n  private applyXLabelsOnSameLine(svg: any) {\r\n    svg\r\n      .selectAll('g.x1.axis1 g.tick text')\r\n      .attr('class', 'lib-xaxis-labels-texts-drilldown')\r\n      .attr('y', this.CONSTANTS.SHORT_TICK_LENGTH_BG)\r\n      .text((d: string) => {\r\n        const trimmed = d.trim();\r\n        const spaceIndex = trimmed.indexOf(' ');\r\n        return spaceIndex > -1 \r\n          ? trimmed.substring(0, spaceIndex).toLowerCase()\r\n          : trimmed.toLowerCase();\r\n      });\r\n\r\n    svg\r\n      .selectAll('g.x1.axis1 g.tick')\r\n      .append('text')\r\n      .attr('class', 'lib-xaxis-labels-texts-drilldown')\r\n      .attr('y', this.CONSTANTS.LONG_TICK_LENGTH_BG)\r\n      .attr('fill', 'currentColor')\r\n      .text((d: string) => {\r\n        const trimmed = d.trim();\r\n        const spaceIndex = trimmed.indexOf(' ');\r\n        return spaceIndex > -1 \r\n          ? trimmed.substring(spaceIndex).toLowerCase()\r\n          : '';\r\n      });\r\n  }\r\n\r\n  private renderDataLabels(rect: any, scales: any, metaData: ChartMetaData, dimensions: Dimensions) {\r\n    if (!this.isCC && !this.chartConfiguration.isMultiChartGridLine) {\r\n      rect.append('svg:title').text((d: any) => d[1] - d[0]);\r\n    }\r\n\r\n    if (this.chartConfiguration.showTotalOnTop) {\r\n      this.renderTopLabels(rect, scales, metaData);\r\n    }\r\n\r\n    if (this.chartConfiguration.showAngledLabels) {\r\n      this.renderAngledLabels(rect, scales, metaData);\r\n    }\r\n  }\r\n\r\n  private renderTopLabels(rect: any, scales: any, metaData: ChartMetaData) {\r\n    const formatFromBackend = this.chartConfiguration.textFormatter\r\n      ? ChartHelper.dataValueFormatter(this.chartConfiguration.textFormatter)\r\n      : (d: any) => d;\r\n    const formatForHugeNumbers = ChartHelper.dataValueFormatter('.2s');\r\n\r\n    rect\r\n      .append('text')\r\n      .attr('x', (d: any) => scales.xScale(d.data.name) + scales.xScale.bandwidth() / 2)\r\n      .attr('class', 'lib-verticalstack-labels-ontop-weklycharts')\r\n      .attr('y', (d: any) => scales.yScale(d[1]) - 3)\r\n      .text((d: any) => {\r\n        const value = d[1] - d[0];\r\n        if (isNaN(value) || value === 0) return;\r\n        \r\n        const formattedValue = value <= 999 \r\n          ? formatFromBackend(value)\r\n          : formatForHugeNumbers(value);\r\n        \r\n        return metaData.unit ? metaData.unit + formattedValue : formattedValue;\r\n      });\r\n  }\r\n\r\n  private renderAngledLabels(rect: any, scales: any, metaData: ChartMetaData) {\r\n    const formatFromBackend = this.chartConfiguration.textFormatter\r\n      ? ChartHelper.dataValueFormatter(this.chartConfiguration.textFormatter)\r\n      : (d: any) => d;\r\n    const formatForHugeNumbers = ChartHelper.dataValueFormatter('.2s');\r\n    const tempObjectHolder: { [key: string]: number } = {};\r\n\r\n    rect\r\n      .append('text')\r\n      .attr('x', 0)\r\n      .attr('y', 0)\r\n      .attr('fill', (d: any) => metaData.colors[d.key])\r\n      .attr('class', 'lib-data-labels-angled-weeklycharts')\r\n      .text((d: any) => {\r\n        const value = d[1] - d[0];\r\n        if (isNaN(value) || value <= 0) return;\r\n        \r\n        const formattedValue = value <= 999\r\n          ? formatFromBackend(value)\r\n          : formatForHugeNumbers(value);\r\n        \r\n        return metaData.unit ? metaData.unit + formattedValue : formattedValue;\r\n      })\r\n      .attr('transform', (d: any) => {\r\n        const value = d[1] - d[0];\r\n        if (isNaN(value) || value <= 0) return 'rotate(0)';\r\n\r\n        let total = 0;\r\n        let incrementer = 1;\r\n        metaData.keyList.forEach(key => {\r\n          if (d.data[key]) {\r\n            total += d.data[key];\r\n          } else {\r\n            incrementer = 2;\r\n          }\r\n        });\r\n\r\n        tempObjectHolder[d.data.name] = (tempObjectHolder[d.data.name] || 0) + incrementer;\r\n        const position = tempObjectHolder[d.data.name];\r\n        const xPos = scales.xScale(d.data.name);\r\n        const bandwidth = scales.xScale.bandwidth();\r\n        const yPos = scales.yScale(total) - 3;\r\n\r\n        switch (position) {\r\n          case 1:\r\n            return `translate(${xPos + bandwidth / 3},${yPos}) rotate(270)`;\r\n          case 2:\r\n            return `translate(${xPos + bandwidth / 2 + 2},${yPos}) rotate(270)`;\r\n          default:\r\n            return `translate(${xPos + (bandwidth * 3) / 4},${yPos}) rotate(270)`;\r\n        }\r\n      });\r\n  }\r\n\r\n  private renderTargetLine(\r\n    svg: any,\r\n    svgYAxisRight: any,\r\n    scales: any,\r\n    dimensions: Dimensions,\r\n    metaData: ChartMetaData\r\n  ) {\r\n    if (!this.chartData.targetLineData) return;\r\n\r\n    const parsedTarget = this.parseTargetValue(this.chartData.targetLineData.target);\r\n    const yZero = scales.yScale(parsedTarget);\r\n\r\n    svg\r\n      .append('line')\r\n      .attr('x1', 0)\r\n      .attr('x2', dimensions.width)\r\n      .attr('y1', yZero)\r\n      .attr('y2', yZero)\r\n      .style('stroke-dasharray', '5 5')\r\n      .style('stroke', this.chartData.targetLineData.color);\r\n\r\n    this.renderTargetLabel(svgYAxisRight, yZero, metaData);\r\n  }\r\n\r\n  private parseTargetValue(target: string | number): number {\r\n    const parsed = parseFloat(String(target));\r\n    if (isNaN(parsed)) return 0;\r\n    return Number.isInteger(parsed) ? parseInt(String(target)) : parsed;\r\n  }\r\n\r\n  private renderTargetLabel(svgYAxisRight: any, yZero: number, metaData: ChartMetaData) {\r\n    const dataType = metaData.dataType || '';\r\n    const targetName = this.chartData.targetLineData.targetName || 'target';\r\n\r\n    svgYAxisRight\r\n      .append('foreignObject')\r\n      .attr('transform', `translate(0,${yZero - 13})`)\r\n      .attr('width', this.CONSTANTS.RIGHT_SVG_WIDTH)\r\n      .attr('height', 50)\r\n      .append('xhtml:div')\r\n      .attr('class', 'target-display')\r\n      .style('color', 'var(--chart-text-color)')\r\n      .html(`<div>${targetName}</div><div>${this.chartData.targetLineData.target}${dataType}</div>`);\r\n  }\r\n\r\n  private renderLineChart(svg: any, lineData: any[], scales: any, colors: any, metaData: ChartMetaData) {\r\n    if (!lineData || !colors) return;\r\n\r\n    const dataGroup = d3\r\n      .nest()\r\n      .key((d: any) => d.category)\r\n      .entries(lineData);\r\n\r\n    const lineGen = d3\r\n      .line()\r\n      .x((d: any) => scales.xScale(d.name) + scales.xScale.bandwidth() / 2)\r\n      .y((d: any) => scales.lineYscale(d.value));\r\n\r\n    dataGroup.forEach((group: any) => {\r\n      svg\r\n        .append('path')\r\n        .datum(group.values)\r\n        .attr('fill', 'none')\r\n        .attr('stroke', (d: any) => {\r\n          return d[0]?.category \r\n            ? colors[d[0].category]\r\n            : this.chartConfiguration.lineGraphColor;\r\n        })\r\n        .attr('stroke-width', 2.5)\r\n        .attr('d', lineGen);\r\n\r\n      this.renderLineDots(svg, group.values, scales, colors);\r\n    });\r\n  }\r\n\r\n  private renderLineDots(svg: any, values: any[], scales: any, colors: any) {\r\n    const dot = svg\r\n      .selectAll('.line-dots')\r\n      .data(values)\r\n      .enter()\r\n      .append('g')\r\n      .on('click', (d: any) => this.handleClick(d));\r\n\r\n    dot\r\n      .append('circle')\r\n      .attr('fill', (d: any) => {\r\n        return d.category \r\n          ? colors[d.category]\r\n          : this.chartConfiguration.lineGraphColor;\r\n      })\r\n      .attr('stroke', 'none')\r\n      .attr('cx', (d: any) => scales.xScale(d.name) + scales.xScale.bandwidth() / 2)\r\n      .attr('cy', (d: any) => scales.lineYscale(d.value))\r\n      .attr('r', 3)\r\n      .style('cursor', 'pointer');\r\n\r\n    if (this.chartConfiguration.lineGraphColor) {\r\n      dot\r\n        .append('text')\r\n        .attr('class', 'dots')\r\n        .attr('fill', this.chartConfiguration.lineGraphColor)\r\n        .style('font-size', '.85em')\r\n        .style('font-weight', 'bold')\r\n        .attr('x', (d: any) => scales.xScale(d.name) + scales.xScale.bandwidth() / 2)\r\n        .attr('y', (d: any) => scales.lineYscale(d.value))\r\n        .attr('dy', '-1em')\r\n        .text((d: any) => this.chartConfiguration.labelFormatter(d.value));\r\n    }\r\n  }\r\n\r\n  handleClick(d: any) {\r\n    if (this.chartData?.metaData?.hasDrillDown || d?.toggleFrom) {\r\n      this.clickEvent.emit(d);\r\n    }\r\n  }\r\n\r\n  handleHeaderMenuClick(id: any) {\r\n    this.headerMenuclickEvent.emit(id);\r\n  }\r\n\r\n  handleCompareByFilterSelection(event: any) {\r\n    this.clickEvent.emit(event);\r\n  }\r\n\r\n  handleZoominZoomoutClick({ isZoomOut, event }: { isZoomOut: boolean; event: any }) {\r\n    this.isZoomOutSelected(isZoomOut);\r\n  }\r\n}","<div\r\n  #groupcontainer\r\n  class=\"lib-chart-wrapper\"\r\n  [ngClass]=\"{ 'lib-no-background': isTransparentBackground }\"\r\n  style=\"background-color: var(--card-bg);\"\r\n  (resized)=\"onResized($event)\"\r\n>\r\n\r\n<div class=\"header-alt\" *ngIf=\"!isHeaderVisible\">\r\n  <lib-chart-header-v2\r\n    [chartData]=\"chartData\"\r\n    [chartConfiguration]=\"chartConfiguration\"\r\n    (clickEvent)=\"handleClick($event)\"\r\n  ></lib-chart-header-v2>\r\n  <lib-chart-header-v3\r\n    [chartData]=\"chartData\"\r\n    [chartConfiguration]=\"chartConfiguration\"\r\n    (compareByFilterSelection)=\"handleCompareByFilterSelection($event)\"\r\n    (zoomInZoomOutClick)=\"handleZoominZoomoutClick($event)\"\r\n  ></lib-chart-header-v3>\r\n</div>\r\n\r\n  <lib-chart-header-v1\r\n  [title]=\"chartData.metaData.title\"\r\n  [hasDrillDown]=\"chartData.metaData.hasDrillDown\"\r\n  [isEditEnabled]=\"chartData.metaData.isEditEnabled\"\r\n  [menuOptions]=\"chartConfiguration.headerMenuOptions\"\r\n  [isria]=\"customChartConfiguration.isRia\"\r\n  [selectedKpiTooltop]=\"chartConfiguration.selectedKpiTooltop\"\r\n  (menuOptionClickEvent)=\"handleHeaderMenuClick($event)\"\r\n  [isAlertEnabled]=\"isAlertEnabled\"\r\n  *ngIf=\"isHeaderVisible\"\r\n></lib-chart-header-v1>\r\n\r\n  <div\r\n    [style.height]=\"chartConfiguration.svgHeight\"\r\n    id=\"groupchartcontainer\"\r\n    #groupchartcontainer\r\n    class=\"lib-chart-svg\"\r\n  ></div>\r\n</div>\r\n"]}