axidio-styleguide-library1-v2 0.2.24 → 0.2.25

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.
@@ -20,15 +20,18 @@ export class HorizontalBarsWithScrollZoomComponent extends ComponentUniqueId {
20
20
  this.isTransparentBackground = false;
21
21
  this.isCC = false;
22
22
  this.isZoomedOut = true;
23
- this.TICK_LENGTHS = {
24
- short: 4,
25
- long: 16,
26
- shortBg: 5,
27
- longBg: 30,
28
- };
29
- this.SPACING = {
30
- rightSvgWidth: 60,
31
- leftAndRight: 50,
23
+ this.CONSTANTS = {
24
+ RIGHT_SVG_WIDTH: 60,
25
+ LEFT_RIGHT_SPACES: 50,
26
+ SHORT_TICK_LENGTH: 4,
27
+ LONG_TICK_LENGTH: 16,
28
+ SHORT_TICK_LENGTH_BG: 5,
29
+ LONG_TICK_LENGTH_BG: 30,
30
+ MIN_MOBILE_BAR_WIDTH: 32,
31
+ DESKTOP_MIN_BAR_WIDTH: 40,
32
+ MOBILE_BAR_PADDING: 12,
33
+ ZOOM_THRESHOLD: 30,
34
+ ZOOM_IN_THRESHOLD: 8,
32
35
  };
33
36
  this.defaultConfiguration = {
34
37
  margin: { top: 20, right: 20, bottom: 20, left: 40 },
@@ -45,24 +48,54 @@ export class HorizontalBarsWithScrollZoomComponent extends ComponentUniqueId {
45
48
  forComparison: true,
46
49
  headerMenuOptions: HeaderConfigHelper.headerConfig.headerMenuOptions,
47
50
  yAxisGrid: false,
51
+ // Optional configs with undefined defaults
52
+ isHeaderVisible: undefined,
53
+ isTransparentBackground: undefined,
54
+ isTopCaptionVisible: undefined,
55
+ isMultiChartGridLine: undefined,
56
+ isFullScreen: undefined,
57
+ customYscale: undefined,
58
+ isXaxisLabelHidden: undefined,
59
+ isYaxisLabelHidden: undefined,
60
+ isYaxisHidden: undefined,
61
+ isYaxisDashed: undefined,
62
+ isXaxisColor: undefined,
63
+ textFormatter: undefined,
64
+ showTotalOnTop: undefined,
65
+ backendFormatterHasPriority: undefined,
66
+ showAngledLabels: undefined,
67
+ isNoAlternateXaxisText: undefined,
68
+ isXgridBetweenLabels: undefined,
69
+ showXaxisTop: undefined,
70
+ xAxisGrid: undefined,
71
+ xLabelsOnSameLine: undefined,
72
+ hideXaxisTick: undefined,
73
+ isDrilldownChart: undefined,
74
+ isTargetLine: undefined,
75
+ displayTitleOnTop: undefined,
76
+ isToggleVisible: undefined,
77
+ isTitleHidden: undefined,
48
78
  };
49
79
  }
50
80
  ngOnInit() { }
51
- ngOnChanges(changes) {
52
- this.redrawChart();
81
+ ngOnChanges() {
82
+ this.removeExistingChart();
83
+ this.initializeStackedChart();
53
84
  }
54
85
  onResized(event) {
55
- setTimeout(() => this.redrawChart(), 10);
86
+ setTimeout(() => {
87
+ this.removeExistingChart();
88
+ this.initializeStackedChart();
89
+ }, 10);
56
90
  }
57
91
  isZoomOutSelected(isZoomOut) {
58
92
  this.isZoomedOut = isZoomOut;
59
- this.redrawChart();
93
+ this.ngOnChanges();
60
94
  }
61
- redrawChart() {
95
+ removeExistingChart() {
62
96
  d3.select('#' + this.uniqueId).remove();
63
- this.initializeStackedChart();
64
97
  }
65
- getDeviceBreakpoints() {
98
+ getDeviceConfig() {
66
99
  const width = window.innerWidth;
67
100
  return {
68
101
  isMobile: width < 576,
@@ -70,7 +103,7 @@ export class HorizontalBarsWithScrollZoomComponent extends ComponentUniqueId {
70
103
  isDesktop: width >= 992,
71
104
  };
72
105
  }
73
- applyResponsiveConfig(device) {
106
+ configureResponsiveSettings(device) {
74
107
  if (device.isMobile) {
75
108
  this.chartConfiguration.margin = { top: 20, right: 10, bottom: 40, left: 30 };
76
109
  this.chartConfiguration.numberOfYTicks = 4;
@@ -88,9 +121,9 @@ export class HorizontalBarsWithScrollZoomComponent extends ComponentUniqueId {
88
121
  }
89
122
  }
90
123
  mergeConfigurations() {
91
- Object.keys(this.defaultConfiguration).forEach((key) => {
124
+ for (const key in this.defaultConfiguration) {
92
125
  this.chartConfiguration[key] = ChartHelper.getValueByConfigurationType(key, this.defaultConfiguration, this.customChartConfiguration);
93
- });
126
+ }
94
127
  }
95
128
  prepareMetaData(metaData) {
96
129
  if (!metaData.unit)
@@ -105,183 +138,70 @@ export class HorizontalBarsWithScrollZoomComponent extends ComponentUniqueId {
105
138
  }
106
139
  return metaData;
107
140
  }
108
- parseTargetValue(targetLineData) {
109
- if (!targetLineData?.target)
110
- return null;
111
- const parsedNum = parseFloat(String(targetLineData.target));
112
- if (isNaN(parsedNum))
113
- return null;
114
- return Number.isInteger(parsedNum)
115
- ? parseInt(String(targetLineData.target))
116
- : parsedNum;
117
- }
118
- calculateDimensions(containerWidth, containerHeight, margin, device) {
141
+ calculateDimensions(chartContainer, verticalContainer, margin, device, dataLength) {
142
+ const containerWidth = chartContainer.node().getBoundingClientRect().width;
143
+ const containerHeight = verticalContainer.node().getBoundingClientRect().height;
119
144
  let width = containerWidth - margin.left - margin.right;
120
145
  let height = containerHeight * (this.chartConfiguration.svgHeight / 100) - margin.top - margin.bottom;
121
- // Adjust width for zoom levels
122
- const dataLength = this.chartData.data.length;
123
- if (dataLength > 30 && this.isZoomedOut) {
146
+ // Handle zoom out scenario
147
+ if (dataLength > this.CONSTANTS.ZOOM_THRESHOLD && this.isZoomedOut) {
124
148
  const minWidth = dataLength * (device.isMobile ? 15 : 25);
125
149
  width = Math.max(width, minWidth);
126
150
  }
127
- if (dataLength > 8 && !this.isZoomedOut) {
151
+ // Handle zoom in scenario
152
+ if (dataLength > this.CONSTANTS.ZOOM_IN_THRESHOLD && !this.isZoomedOut) {
128
153
  width = dataLength * (device.isMobile ? 60 : 130);
129
154
  }
130
- // Apply special height configurations
131
- if (this.chartConfiguration.isFullScreen && this.chartConfiguration.svgHeight !== 80) {
132
- height = this.chartConfiguration.svgHeight;
133
- }
134
- else if (this.chartConfiguration.isFullScreen) {
135
- height = containerHeight;
155
+ // Handle full screen
156
+ if (this.chartConfiguration.isFullScreen) {
157
+ height = this.chartConfiguration.svgHeight !== 80
158
+ ? this.chartConfiguration.svgHeight
159
+ : containerHeight;
136
160
  }
161
+ // Handle drilldown
137
162
  if (this.chartConfiguration.isDrilldownChart) {
138
163
  height = containerHeight - margin.top - margin.bottom - (device.isMobile ? 60 : 130);
139
164
  }
140
- return { width, height };
141
- }
142
- calculateBarDimensions(width, dataLength, device) {
165
+ // Calculate bar dimensions
143
166
  let barWidth;
144
167
  let barPadding;
145
168
  let requiredSvgWidth;
146
169
  if (device.isMobile) {
147
- const minBarWidth = 32;
148
- barWidth = minBarWidth;
149
- barPadding = 12;
150
- requiredSvgWidth = Math.max(width - this.SPACING.rightSvgWidth, (barWidth + barPadding) * dataLength + this.SPACING.leftAndRight * 2 +
151
- this.SPACING.rightSvgWidth - barPadding);
170
+ barWidth = this.CONSTANTS.MIN_MOBILE_BAR_WIDTH;
171
+ barPadding = this.CONSTANTS.MOBILE_BAR_PADDING;
172
+ requiredSvgWidth = Math.max(width - this.CONSTANTS.RIGHT_SVG_WIDTH, (barWidth + barPadding) * dataLength + this.CONSTANTS.LEFT_RIGHT_SPACES * 2 +
173
+ this.CONSTANTS.RIGHT_SVG_WIDTH - barPadding);
152
174
  }
153
175
  else {
154
- barWidth = Math.max(40, (width - this.SPACING.rightSvgWidth - this.SPACING.leftAndRight * 2) / dataLength);
176
+ barWidth = Math.max(this.CONSTANTS.DESKTOP_MIN_BAR_WIDTH, (width - this.CONSTANTS.RIGHT_SVG_WIDTH - this.CONSTANTS.LEFT_RIGHT_SPACES * 2) / dataLength);
155
177
  barPadding = 0;
156
- requiredSvgWidth = width - this.SPACING.rightSvgWidth;
178
+ requiredSvgWidth = width - this.CONSTANTS.RIGHT_SVG_WIDTH;
157
179
  }
158
- return { barWidth, barPadding, requiredSvgWidth };
159
- }
160
- createScales(data, height, width, device) {
161
- const xScale = d3
162
- .scaleBand()
163
- .rangeRound([
164
- this.SPACING.leftAndRight,
165
- width - this.SPACING.rightSvgWidth - this.SPACING.leftAndRight
166
- ])
167
- .domain(data.map(d => d.name).reverse())
168
- .padding(device.isMobile ? 0.2 : 0.5);
169
- const yScale = d3.scaleLinear().rangeRound([height, 0]);
170
- return { xScale, yScale };
171
- }
172
- calculateYScaleDomain(layers, targetValue) {
173
- let maxValue = d3.max(layers, (d) => d3.max(d, (d) => d[1])) || 0;
174
- if (maxValue === 0) {
175
- maxValue = targetValue ? targetValue + 20 : 100;
176
- }
177
- if (this.chartConfiguration.customYscale) {
178
- maxValue *= this.chartConfiguration.customYscale;
179
- }
180
- if (targetValue && maxValue < targetValue) {
181
- maxValue = maxValue < 10 && targetValue < 10
182
- ? targetValue + 3
183
- : targetValue + 20;
184
- }
185
- return maxValue;
186
- }
187
- shouldShowTargetLineColor(d, targetValue) {
188
- return !!(!isNaN(d[0]) &&
189
- !isNaN(d[1]) &&
190
- this.chartData.targetLineData &&
191
- targetValue &&
192
- parseFloat(d[1]) - parseFloat(d[0]) >= targetValue);
193
- }
194
- getBarFillColor(d, key, metaData, targetValue) {
195
- if (this.shouldShowTargetLineColor(d, targetValue)) {
196
- return this.chartData.targetLineData?.barAboveTargetColor || metaData.colors[key];
197
- }
198
- return metaData.colors[key];
199
- }
200
- isAcronym(label) {
201
- const alphaOnly = label.replace(/[^A-Za-z]/g, '');
202
- return (label.length <= 4 && /^[A-Z]+$/.test(label)) ||
203
- (label === label.toUpperCase() && /[A-Z]/.test(label));
204
- }
205
- formatAxisLabel(text) {
206
- const isAcr = this.isAcronym(text);
207
180
  return {
208
- formatted: isAcr ? text.toUpperCase() : text.toLowerCase(),
209
- isAcronym: isAcr
181
+ width,
182
+ height,
183
+ containerWidth,
184
+ containerHeight,
185
+ barWidth,
186
+ barPadding,
187
+ requiredSvgWidth,
210
188
  };
211
189
  }
212
- initializeStackedChart() {
213
- const device = this.getDeviceBreakpoints();
214
- this.applyResponsiveConfig(device);
215
- this.mergeConfigurations();
216
- const { data, metaData, lineData } = this.chartData;
217
- const preparedMetaData = this.prepareMetaData(metaData);
218
- const targetValue = this.parseTargetValue(this.chartData.targetLineData);
219
- const chartContainer = d3.select(this.containerElt.nativeElement);
220
- const verticalstackedcontainer = d3.select(this.verticalstackedcontainerElt.nativeElement);
221
- const margin = this.chartConfiguration.margin;
222
- const containerWidth = chartContainer.node().getBoundingClientRect().width;
223
- const containerHeight = verticalstackedcontainer.node().getBoundingClientRect().height;
224
- const { width, height } = this.calculateDimensions(containerWidth, containerHeight, margin, device);
225
- // Apply visibility configurations
226
- if (this.chartConfiguration.isHeaderVisible !== undefined) {
227
- this.isHeaderVisible = this.chartConfiguration.isHeaderVisible;
228
- }
229
- if (this.chartConfiguration.isTopCaptionVisible !== undefined) {
230
- this.isTopCaptionVisible = this.chartConfiguration.isTopCaptionVisible;
231
- }
232
- if (this.chartConfiguration.isTransparentBackground !== undefined) {
233
- this.isTransparentBackground = this.chartConfiguration.isTransparentBackground;
234
- }
235
- // Create formatters
236
- const formatFromBackend = this.chartConfiguration.textFormatter
237
- ? ChartHelper.dataValueFormatter(this.chartConfiguration.textFormatter)
238
- : null;
239
- const formatForHugeNumbers = ChartHelper.dataValueFormatter('.2s');
240
- // Create SVG containers
241
- const { barWidth, barPadding, requiredSvgWidth } = this.calculateBarDimensions(width, data.length, device);
242
- const outerContainer = this.createOuterContainer(chartContainer, height, margin);
243
- const { svgYAxisLeft, svgYAxisRight } = this.createAxisContainers(outerContainer, height, margin);
244
- const { innerContainer, svg } = this.createInnerContainer(outerContainer, requiredSvgWidth, height, margin, device);
245
- // Create scales
246
- const { xScale, yScale } = this.createScales(data, height, width, device);
247
- // Stack data
248
- const stack = d3
249
- .stack()
250
- .keys(preparedMetaData.keyList)
251
- .offset(d3.stackOffsetNone);
252
- const layers = stack(data);
253
- // Set Y scale domain
254
- const maxValue = this.calculateYScaleDomain(layers, targetValue || undefined);
255
- yScale.domain([0, maxValue]).nice();
256
- // Render chart elements
257
- this.renderGrids(svg, xScale, yScale, height, width);
258
- this.renderBars(svg, layers, xScale, yScale, preparedMetaData, device, barWidth, barPadding, targetValue, formatFromBackend, formatForHugeNumbers);
259
- this.renderAxes(svg, svgYAxisLeft, svgYAxisRight, xScale, yScale, data, height, width, device);
260
- this.renderLabels(svg, svgYAxisLeft, preparedMetaData, height, width, margin);
261
- if (this.chartData.targetLineData && targetValue) {
262
- this.renderTargetLine(svg, svgYAxisRight, yScale, width, targetValue, preparedMetaData);
263
- }
264
- if (lineData) {
265
- this.renderLineChart(svg, lineData, xScale, height, preparedMetaData.colors);
266
- }
267
- }
268
- createOuterContainer(chartContainer, height, margin) {
269
- return chartContainer
190
+ createSvgContainers(chartContainer, dimensions, margin) {
191
+ const outerContainer = chartContainer
270
192
  .append('div')
271
193
  .attr('id', this.uniqueId)
272
194
  .attr('class', 'outer-container')
273
195
  .style('width', '100%')
274
- .style('height', height)
196
+ .style('height', dimensions.height)
275
197
  .style('overflow-x', 'hidden')
276
198
  .style('padding-left', `${margin.left}px`)
277
199
  .style('margin-left', '10px')
278
- .style('padding-right', `${this.SPACING.rightSvgWidth}px`);
279
- }
280
- createAxisContainers(outerContainer, height, margin) {
200
+ .style('padding-right', `${this.CONSTANTS.RIGHT_SVG_WIDTH}px`);
281
201
  const svgYAxisLeft = outerContainer
282
202
  .append('svg')
283
203
  .attr('width', '80')
284
- .attr('height', height + margin.top + margin.bottom)
204
+ .attr('height', dimensions.height + margin.top + margin.bottom)
285
205
  .style('position', 'absolute')
286
206
  .style('left', '0')
287
207
  .style('z-index', 1)
@@ -289,65 +209,85 @@ export class HorizontalBarsWithScrollZoomComponent extends ComponentUniqueId {
289
209
  .attr('transform', `translate(${margin.left + 10},${margin.top})`);
290
210
  const svgYAxisRight = outerContainer
291
211
  .append('svg')
292
- .attr('width', this.SPACING.rightSvgWidth)
293
- .attr('height', height + margin.top + margin.bottom)
212
+ .attr('width', this.CONSTANTS.RIGHT_SVG_WIDTH)
213
+ .attr('height', dimensions.height + margin.top + margin.bottom)
294
214
  .style('position', 'absolute')
295
215
  .style('right', '2px')
296
216
  .style('z-index', 1)
297
217
  .append('g')
298
218
  .attr('transform', `translate(0,${margin.top})`);
299
- return { svgYAxisLeft, svgYAxisRight };
300
- }
301
- createInnerContainer(outerContainer, requiredSvgWidth, height, margin, device) {
302
219
  const innerContainer = outerContainer
303
220
  .append('div')
304
221
  .attr('class', 'inner-container')
305
222
  .style('width', '100%')
306
- .style('overflow-x', device.isMobile ? 'auto' : 'auto');
223
+ .style('overflow-x', 'auto');
307
224
  const svg = innerContainer
308
225
  .append('svg')
309
- .attr('width', requiredSvgWidth)
310
- .attr('height', height + margin.top + margin.bottom + 30)
226
+ .attr('width', dimensions.requiredSvgWidth)
227
+ .attr('height', dimensions.height + margin.top + margin.bottom + 30)
311
228
  .append('g')
312
229
  .attr('transform', `translate(0,${margin.top})`);
313
- return { innerContainer, svg };
230
+ return { svg, svgYAxisLeft, svgYAxisRight, innerContainer };
314
231
  }
315
- renderGrids(svg, xScale, yScale, height, width) {
316
- if (this.chartConfiguration.isXgridBetweenLabels) {
317
- svg
318
- .append('g')
319
- .attr('class', 'grid')
320
- .attr('transform', `translate(${xScale.bandwidth() / 2},${height})`)
321
- .call(d3.axisBottom(xScale).tickSize(-height).tickFormat(''))
322
- .style('stroke-dasharray', '5 5')
323
- .style('color', '#999999')
324
- .call((g) => g.select('.domain').remove());
232
+ createScales(data, layers, lineData, dimensions, device) {
233
+ const { width, height, barWidth, barPadding } = dimensions;
234
+ const xScale = d3
235
+ .scaleBand()
236
+ .rangeRound([
237
+ this.CONSTANTS.LEFT_RIGHT_SPACES,
238
+ width - this.CONSTANTS.RIGHT_SVG_WIDTH - this.CONSTANTS.LEFT_RIGHT_SPACES
239
+ ])
240
+ .domain(data.map(d => d.name).reverse())
241
+ .padding(device.isMobile ? 0.2 : 0.5);
242
+ const xScaleFromOrigin = d3
243
+ .scaleBand()
244
+ .rangeRound([width - this.CONSTANTS.RIGHT_SVG_WIDTH, 0])
245
+ .domain(data.map(d => d.name).reverse());
246
+ const yScale = d3.scaleLinear().rangeRound([height, 0]);
247
+ let maxValue = d3.max(layers, (d) => d3.max(d, (d) => d[1]));
248
+ if (maxValue === 0) {
249
+ maxValue = this.chartData.targetLineData
250
+ ? Number(this.chartData.targetLineData.target) + 20
251
+ : 100;
325
252
  }
326
- if (this.chartConfiguration.yAxisGrid) {
327
- svg
328
- .append('g')
329
- .attr('class', 'grid')
330
- .call(d3
331
- .axisLeft(yScale)
332
- .ticks(this.chartConfiguration.numberOfYTicks)
333
- .tickSize(-width)
334
- .tickFormat(''))
335
- .style('color', 'var(--chart-grid-color)')
336
- .style('opacity', '1');
253
+ if (this.chartConfiguration.customYscale) {
254
+ maxValue *= this.chartConfiguration.customYscale;
337
255
  }
338
- if (this.chartConfiguration.xAxisGrid) {
339
- this.chartConfiguration.xAxisGrid.forEach((gridPos, index) => {
340
- svg
341
- .append('g')
342
- .attr('class', `x${index + 2} axis${index + 2}`)
343
- .style('color', 'var(--chart-grid-color)')
344
- .attr('transform', `translate(0,${height * gridPos})`)
345
- .call(d3.axisBottom(xScale).tickSize(0).ticks(5).tickFormat(''))
346
- .style('fill', 'var(--chart-text-color)');
347
- });
256
+ if (this.chartData.targetLineData && maxValue < Number(this.chartData.targetLineData.target)) {
257
+ const target = Number(this.chartData.targetLineData.target);
258
+ maxValue = maxValue < 10 && target < 10 ? target + 3 : target + 20;
259
+ }
260
+ yScale.domain([0, maxValue]).nice();
261
+ let lineYscale = null;
262
+ if (lineData) {
263
+ lineYscale = d3
264
+ .scaleLinear()
265
+ .domain([0, d3.max(lineData, d => +d.value)])
266
+ .range([height, 0]);
267
+ }
268
+ return { xScale, xScaleFromOrigin, yScale, lineYscale };
269
+ }
270
+ createAxes(scales) {
271
+ const xAxis = d3
272
+ .axisBottom(scales.xScale)
273
+ .tickSize(0)
274
+ .tickFormat(this.chartConfiguration.xAxisLabelFomatter);
275
+ const yAxis = d3
276
+ .axisLeft(scales.yScale)
277
+ .ticks(this.chartConfiguration.numberOfYTicks)
278
+ .tickSize(0)
279
+ .tickFormat(this.chartConfiguration.yAxisLabelFomatter);
280
+ let yLineAxis = null;
281
+ if (scales.lineYscale) {
282
+ yLineAxis = d3
283
+ .axisRight(scales.lineYscale)
284
+ .ticks(this.chartConfiguration.numberOfYTicks)
285
+ .tickSize(0)
286
+ .tickFormat(this.chartConfiguration.yLineAxisLabelFomatter);
348
287
  }
288
+ return { xAxis, yAxis, yLineAxis };
349
289
  }
350
- renderBars(svg, layers, xScale, yScale, metaData, device, barWidth, barPadding, targetValue, formatFromBackend, formatForHugeNumbers) {
290
+ renderBars(svg, layers, scales, metaData, dimensions, device) {
351
291
  const layer = svg
352
292
  .selectAll('.layer')
353
293
  .data(layers)
@@ -355,7 +295,17 @@ export class HorizontalBarsWithScrollZoomComponent extends ComponentUniqueId {
355
295
  .append('g')
356
296
  .attr('class', 'layer')
357
297
  .style('fill', (d) => metaData.colors[d.key]);
358
- const rect = layer.selectAll('rect').data((d) => d).enter();
298
+ const rect = layer
299
+ .selectAll('rect')
300
+ .data((d) => d)
301
+ .enter();
302
+ this.appendRectangles(rect, scales, metaData, dimensions, device);
303
+ this.addInteractions(rect, svg, metaData, scales);
304
+ return rect;
305
+ }
306
+ appendRectangles(rect, scales, metaData, dimensions, device) {
307
+ const { barWidth, barPadding } = dimensions;
308
+ const { xScale, yScale } = scales;
359
309
  rect
360
310
  .append('rect')
361
311
  .on('click', (d) => {
@@ -374,9 +324,9 @@ export class HorizontalBarsWithScrollZoomComponent extends ComponentUniqueId {
374
324
  })
375
325
  .attr('x', (d, i) => {
376
326
  if (device.isMobile) {
377
- return this.SPACING.leftAndRight + i * (barWidth + barPadding);
327
+ return this.CONSTANTS.LEFT_RIGHT_SPACES + i * (barWidth + barPadding);
378
328
  }
379
- if (this.chartConfiguration.isMultiChartGridLine === undefined) {
329
+ if (!this.chartConfiguration.isMultiChartGridLine) {
380
330
  return xScale(d.data.name);
381
331
  }
382
332
  if (this.chartConfiguration.isDrilldownChart && this.chartData.data.length <= 3) {
@@ -394,99 +344,307 @@ export class HorizontalBarsWithScrollZoomComponent extends ComponentUniqueId {
394
344
  .attr('width', (d) => {
395
345
  if (device.isMobile)
396
346
  return barWidth;
397
- if (this.chartConfiguration.isMultiChartGridLine === undefined) {
347
+ if (!this.chartConfiguration.isMultiChartGridLine)
398
348
  return xScale.bandwidth();
349
+ if (this.chartConfiguration.isDrilldownChart && this.chartData.data.length <= 3) {
350
+ return 70;
399
351
  }
400
- return this.chartConfiguration.isDrilldownChart && this.chartData.data.length <= 3
401
- ? 70
402
- : xScale.bandwidth() * 0.8;
352
+ return xScale.bandwidth() * 0.8;
403
353
  })
404
354
  .style('cursor', (d) => {
405
- if (!metaData.hasDrillDown)
406
- return 'default';
407
- if (metaData.barWithoutClick?.includes(d.data.name.toLowerCase())) {
408
- return 'default';
355
+ if (metaData.hasDrillDown) {
356
+ if (metaData.barWithoutClick?.includes(d.data.name.toLowerCase())) {
357
+ return 'default';
358
+ }
359
+ return 'pointer';
409
360
  }
410
- return 'pointer';
361
+ return 'default';
411
362
  })
412
- .style('fill', (d) => this.getBarFillColor(d, d.key, metaData, targetValue || undefined));
413
- // Add tooltips and labels
414
- if (!this.isCC && !this.chartConfiguration.isMultiChartGridLine) {
415
- rect.append('svg:title').text((d) => d[1] - d[0]);
363
+ .style('fill', (d) => this.getBarColor(d, metaData));
364
+ }
365
+ getBarColor(d, metaData) {
366
+ if (!isNaN(d[0]) &&
367
+ !isNaN(d[1]) &&
368
+ this.chartData.targetLineData &&
369
+ parseFloat(d[1]) - parseFloat(d[0]) >= parseFloat(String(this.chartData.targetLineData.target))) {
370
+ return this.chartData.targetLineData.barAboveTargetColor || metaData.colors[d.key];
416
371
  }
417
- this.addBarLabels(rect, xScale, yScale, metaData, formatFromBackend, formatForHugeNumbers);
372
+ return metaData.colors[d.key];
418
373
  }
419
- addBarLabels(rect, xScale, yScale, metaData, formatFromBackend, formatForHugeNumbers) {
420
- if (this.chartConfiguration.showTotalOnTop) {
421
- rect
422
- .append('text')
423
- .attr('x', (d) => xScale(d.data.name) + xScale.bandwidth() / 2)
424
- .attr('class', 'lib-verticalstack-labels-ontop-weklycharts')
425
- .attr('y', (d) => yScale(d[1]) - 3)
426
- .text((d) => {
427
- if (!isNaN(d[1] - d[0]) && d[1] - d[0] !== 0) {
428
- const value = d[1] - d[0];
429
- const formatter = value <= 999 ? formatFromBackend : formatForHugeNumbers;
430
- return metaData.unit ? metaData.unit + formatter(value) : formatter(value);
431
- }
432
- });
374
+ addInteractions(rect, svg, metaData, scales) {
375
+ rect
376
+ .selectAll('rect')
377
+ .on('mouseenter', (d) => this.handleMouseOver(d, svg, metaData, scales))
378
+ .on('mouseout', (d) => this.handleMouseOut(svg, metaData));
379
+ }
380
+ handleMouseOver(d, svg, metaData, scales) {
381
+ if (!this.chartConfiguration.displayTitleOnTop)
382
+ return;
383
+ svg.selectAll('rect')
384
+ .filter((data) => data === d)
385
+ .style('fill', (d) => this.getHoverColor(d, metaData));
386
+ this.displayTooltip(d, svg, metaData, scales);
387
+ }
388
+ getHoverColor(d, metaData) {
389
+ if (!isNaN(d[0]) &&
390
+ !isNaN(d[1]) &&
391
+ this.chartData.targetLineData &&
392
+ parseFloat(d[1]) - parseFloat(d[0]) >= parseFloat(String(this.chartData.targetLineData.target))) {
393
+ return this.chartData.targetLineData.barAboveTargetHoverColor ||
394
+ this.chartData.targetLineData.barAboveTargetColor ||
395
+ metaData.colors[d.key];
433
396
  }
397
+ return metaData.hoverColor || metaData.colors[d.key];
434
398
  }
435
- renderAxes(svg, svgYAxisLeft, svgYAxisRight, xScale, yScale, data, height, width, device) {
436
- const xAxis = d3
437
- .axisBottom(xScale)
438
- .tickSize(0)
439
- .tickFormat(this.chartConfiguration.xAxisLabelFomatter);
440
- const yAxis = d3
441
- .axisLeft(yScale)
442
- .ticks(this.chartConfiguration.numberOfYTicks)
443
- .tickSize(0)
444
- .tickFormat(this.chartConfiguration.yAxisLabelFomatter);
445
- // Render based on chart type
446
- if (this.chartConfiguration.isMultiChartGridLine === undefined) {
447
- this.renderStandardAxes(svg, xAxis, yAxis, data, height, device);
399
+ displayTooltip(d, svg, metaData, scales) {
400
+ const { xScale, yScale } = scales;
401
+ const value = d[1] - d[0];
402
+ if (isNaN(value))
403
+ return;
404
+ const width = /week/i.test(d.data.name) && /\d{4}-\d{2}-\d{2}/.test(d.data.name)
405
+ ? '250px'
406
+ : xScale.bandwidth() + this.CONSTANTS.LEFT_RIGHT_SPACES * 2 > 180
407
+ ? '180px'
408
+ : xScale.bandwidth() + this.CONSTANTS.LEFT_RIGHT_SPACES * 2;
409
+ svg
410
+ .append('foreignObject')
411
+ .attr('x', this.calculateTooltipX(d, xScale, width))
412
+ .attr('class', 'lib-verticalstack-title-ontop')
413
+ .attr('y', yScale(d[1]) - 51)
414
+ .attr('width', width)
415
+ .attr('height', 40)
416
+ .append('xhtml:div')
417
+ .attr('class', 'title')
418
+ .style('z-index', 99)
419
+ .html(this.generateTooltipHtml(d, metaData, value));
420
+ }
421
+ calculateTooltipX(d, xScale, width) {
422
+ const bandwidth = xScale.bandwidth();
423
+ const numericWidth = typeof width === 'string' ? parseInt(width) : width;
424
+ if (bandwidth + this.CONSTANTS.LEFT_RIGHT_SPACES * 2 > 180) {
425
+ return xScale(d.data.name) - this.CONSTANTS.LEFT_RIGHT_SPACES +
426
+ (bandwidth + this.CONSTANTS.LEFT_RIGHT_SPACES * 2 - 180) / 2;
427
+ }
428
+ return xScale(d.data.name) - this.CONSTANTS.LEFT_RIGHT_SPACES;
429
+ }
430
+ generateTooltipHtml(d, metaData, value) {
431
+ if (value === 0)
432
+ return '<span class="title-top-text">0</span>';
433
+ const dataType = metaData.dataType || '';
434
+ const name = d.data.name ? `<span class="title-bar-name">${d.data.name}</span>` : '';
435
+ const valueText = metaData.unit
436
+ ? `${metaData.unit}${value} ${dataType}`
437
+ : `${value} ${dataType}`;
438
+ return `${name}<span class="title-top-text">${valueText}</span>`;
439
+ }
440
+ handleMouseOut(svg, metaData) {
441
+ if (!this.chartConfiguration.displayTitleOnTop)
442
+ return;
443
+ svg.selectAll('rect')
444
+ .style('fill', (d) => this.getBarColor(d, metaData));
445
+ svg.selectAll('.lib-verticalstack-title-ontop').remove();
446
+ }
447
+ renderAxisLabels(svg, svgYAxisLeft, metaData, dimensions, margin) {
448
+ if (metaData.yLabel) {
449
+ this.addYAxisLabel(svgYAxisLeft, metaData.yLabel, dimensions.height, margin);
450
+ }
451
+ if (metaData.xLabel) {
452
+ this.addXAxisLabel(svg, metaData.xLabel, dimensions.width, dimensions.height, margin);
453
+ }
454
+ }
455
+ addYAxisLabel(svgYAxisLeft, label, height, margin) {
456
+ const isria = this.customChartConfiguration?.isRia;
457
+ const isAcronym = this.isAcronymLabel(label);
458
+ const yPosition = isria ? -margin.left / 2 - 30 : -margin.left / 2 - 40;
459
+ svgYAxisLeft.selectAll('.lib-axis-group-label, .lib-ylabel-drilldowncharts, .lib-ylabel-weeklyCharts').remove();
460
+ svgYAxisLeft
461
+ .append('text')
462
+ .attr('class', this.getYAxisLabelClass())
463
+ .attr('style', this.chartConfiguration.yAxisCustomlabelStyles)
464
+ .attr('transform', 'rotate(-90)')
465
+ .attr('y', yPosition)
466
+ .attr('x', -height / 2)
467
+ .attr('dy', '1em')
468
+ .style('text-anchor', 'middle')
469
+ .style('fill', 'var(--chart-text-color)')
470
+ .text(isAcronym ? label.toUpperCase() : label.toLowerCase())
471
+ .style('text-transform', isAcronym ? 'none' : 'capitalize');
472
+ }
473
+ addXAxisLabel(svg, label, width, height, margin) {
474
+ const isria = this.customChartConfiguration?.isRia;
475
+ const isAcronym = this.isAcronymLabel(label);
476
+ const xPosition = isria
477
+ ? height + margin.top + margin.bottom
478
+ : height + margin.top + margin.bottom + 10;
479
+ svg
480
+ .append('text')
481
+ .attr('class', this.getXAxisLabelClass())
482
+ .attr('style', this.chartConfiguration.xAxisCustomlabelStyles)
483
+ .attr('transform', `translate(${width / 2},${xPosition})`)
484
+ .style('text-anchor', 'middle')
485
+ .style('fill', 'var(--chart-text-color)')
486
+ .text(isAcronym ? label.toUpperCase() : label.toLowerCase())
487
+ .style('text-transform', isAcronym ? 'none' : 'capitalize');
488
+ }
489
+ isAcronymLabel(label) {
490
+ const cleanLabel = label.replace(/[^A-Za-z]/g, '');
491
+ return (label.length <= 4 && /^[A-Z]+$/.test(label)) ||
492
+ (label === label.toUpperCase() && /[A-Z]/.test(label));
493
+ }
494
+ getYAxisLabelClass() {
495
+ let baseClass = 'lib-axis-group-label font-size-1';
496
+ if (this.chartConfiguration.isDrilldownChart) {
497
+ return `${baseClass} lib-ylabel-drilldowncharts`;
498
+ }
499
+ if (this.chartConfiguration.isMultiChartGridLine !== undefined) {
500
+ return `${baseClass} lib-ylabel-weeklyCharts`;
501
+ }
502
+ return `${baseClass} lib-axis-waterfall-label`;
503
+ }
504
+ getXAxisLabelClass() {
505
+ let baseClass = 'lib-axis-group-label font-size-1';
506
+ if (this.chartConfiguration.isDrilldownChart) {
507
+ return `${baseClass} lib-xlabel-drilldowncharts`;
508
+ }
509
+ if (this.chartConfiguration.isMultiChartGridLine !== undefined) {
510
+ return `${baseClass} lib-xlabel-weeklyCharts`;
511
+ }
512
+ return `${baseClass} lib-axis-waterfall-label`;
513
+ }
514
+ applyConfigurationFlags() {
515
+ if (this.chartConfiguration.isHeaderVisible !== undefined) {
516
+ this.isHeaderVisible = this.chartConfiguration.isHeaderVisible;
517
+ }
518
+ if (this.chartConfiguration.isTopCaptionVisible !== undefined) {
519
+ this.isTopCaptionVisible = this.chartConfiguration.isTopCaptionVisible;
520
+ }
521
+ if (this.chartConfiguration.isTransparentBackground !== undefined) {
522
+ this.isTransparentBackground = this.chartConfiguration.isTransparentBackground;
523
+ }
524
+ }
525
+ initializeStackedChart() {
526
+ const device = this.getDeviceConfig();
527
+ this.configureResponsiveSettings(device);
528
+ this.mergeConfigurations();
529
+ this.applyConfigurationFlags();
530
+ const data = this.chartData.data;
531
+ const metaData = this.prepareMetaData(this.chartData.metaData);
532
+ const lineData = this.chartData.lineData;
533
+ const colors = metaData.colors;
534
+ const keyList = metaData.keyList;
535
+ const chartContainer = d3.select(this.containerElt.nativeElement);
536
+ const verticalstackedcontainer = d3.select(this.verticalstackedcontainerElt.nativeElement);
537
+ const margin = this.chartConfiguration.margin;
538
+ const dimensions = this.calculateDimensions(chartContainer, verticalstackedcontainer, margin, device, data.length);
539
+ const { svg, svgYAxisLeft, svgYAxisRight } = this.createSvgContainers(chartContainer, dimensions, margin);
540
+ // Create stack and layers
541
+ const stack = d3.stack().keys(keyList).offset(d3.stackOffsetNone);
542
+ const layers = stack(data);
543
+ data.sort((a, b) => b.total - a.total);
544
+ const scales = this.createScales(data, layers, lineData, dimensions, device);
545
+ const axes = this.createAxes(scales);
546
+ // Render chart elements
547
+ this.renderGrids(svg, scales, dimensions);
548
+ const rect = this.renderBars(svg, layers, scales, metaData, dimensions, device);
549
+ this.renderAxes(svg, svgYAxisLeft, svgYAxisRight, axes, scales, dimensions, device, data);
550
+ this.renderAxisLabels(svg, svgYAxisLeft, metaData, dimensions, margin);
551
+ this.renderTargetLine(svg, svgYAxisRight, scales, dimensions, metaData);
552
+ this.renderDataLabels(rect, scales, metaData, dimensions);
553
+ this.renderLineChart(svg, lineData, scales, colors, metaData);
554
+ }
555
+ renderGrids(svg, scales, dimensions) {
556
+ if (this.chartConfiguration.isXgridBetweenLabels) {
557
+ svg
558
+ .append('g')
559
+ .attr('class', 'grid')
560
+ .attr('transform', `translate(${scales.xScale.bandwidth() / 2},${dimensions.height})`)
561
+ .call(d3.axisBottom(scales.xScale).tickSize(-dimensions.height).tickFormat(''))
562
+ .style('stroke-dasharray', '5 5')
563
+ .style('color', '#999999')
564
+ .call((g) => g.select('.domain').remove());
565
+ }
566
+ if (this.chartConfiguration.yAxisGrid) {
567
+ svg
568
+ .append('g')
569
+ .attr('class', 'grid')
570
+ .call(d3
571
+ .axisLeft(scales.yScale)
572
+ .ticks(this.chartConfiguration.numberOfYTicks)
573
+ .tickSize(-dimensions.width)
574
+ .tickFormat(''))
575
+ .style('color', 'var(--chart-grid-color)')
576
+ .style('opacity', '1');
577
+ }
578
+ if (this.chartConfiguration.xAxisGrid) {
579
+ for (let j = 0; j < this.chartConfiguration.xAxisGrid.length; j++) {
580
+ svg
581
+ .append('g')
582
+ .attr('class', `x${j + 2} axis${j + 2}`)
583
+ .style('color', 'var(--chart-grid-color)')
584
+ .attr('transform', `translate(0,${dimensions.height * this.chartConfiguration.xAxisGrid[j]})`)
585
+ .call(d3.axisBottom(scales.xScale).tickSize(0).ticks(5).tickFormat(''))
586
+ .style('fill', 'var(--chart-text-color)');
587
+ }
588
+ }
589
+ }
590
+ renderAxes(svg, svgYAxisLeft, svgYAxisRight, axes, scales, dimensions, device, data) {
591
+ if (this.chartConfiguration.showXaxisTop) {
592
+ svg
593
+ .append('g')
594
+ .attr('class', 'lib-line-axis-text lib-line-x-axis-text x-axis')
595
+ .attr('style', this.chartConfiguration.xAxisCustomTextStyles)
596
+ .call(d3.axisBottom(scales.xScale).tickSize(0));
597
+ svg.selectAll('.x-axis > g > text').attr('class', 'lib-display-hidden');
598
+ }
599
+ if (!this.chartConfiguration.isMultiChartGridLine) {
600
+ this.renderStandardAxes(svg, axes, scales, dimensions, device, data);
448
601
  }
449
602
  else if (this.chartConfiguration.isDrilldownChart) {
450
- this.renderDrilldownAxes(svg, svgYAxisLeft, svgYAxisRight, xAxis, yAxis, height);
603
+ this.renderDrilldownAxes(svg, svgYAxisLeft, svgYAxisRight, axes, scales, dimensions);
451
604
  }
452
605
  else {
453
- this.renderMultiChartAxes(svg, xAxis, yAxis, height);
606
+ this.renderMultiChartAxes(svg, axes, scales, dimensions);
454
607
  }
455
- this.styleAxisDomains(svg, svgYAxisLeft, svgYAxisRight);
608
+ this.applyAxisStyling(svg, svgYAxisLeft, svgYAxisRight);
609
+ this.applyAxisConfigurations(svg, scales, dimensions, data);
456
610
  }
457
- renderStandardAxes(svg, xAxis, yAxis, data, height, device) {
611
+ renderStandardAxes(svg, axes, scales, dimensions, device, data) {
458
612
  if (device.isMobile) {
459
- this.renderMobileXAxis(svg, data, height, device);
613
+ this.renderMobileXAxis(svg, data, dimensions);
460
614
  }
461
615
  else {
462
616
  svg
463
617
  .append('g')
464
- .attr('transform', `translate(0,${height})`)
618
+ .attr('transform', `translate(0,${dimensions.height})`)
465
619
  .attr('class', 'lib-stacked-x-axis-text')
466
- .call(xAxis)
620
+ .call(axes.xAxis)
467
621
  .selectAll('text')
468
622
  .style('fill', 'var(--chart-text-color)')
469
623
  .style('font-size', '12px')
470
- .attr('text-anchor', 'middle');
624
+ .attr('text-anchor', 'middle')
625
+ .attr('dx', '0')
626
+ .attr('dy', '0.71em')
627
+ .attr('transform', null);
471
628
  }
472
629
  svg
473
630
  .append('g')
474
631
  .attr('class', 'lib-stacked-y-axis-text')
475
- .call(yAxis)
632
+ .attr('style', this.chartConfiguration.yAxisCustomTextStyles)
633
+ .call(axes.yAxis)
476
634
  .selectAll('text')
477
635
  .style('fill', 'var(--chart-text-color)');
478
636
  }
479
- renderMobileXAxis(svg, data, height, device) {
480
- const barWidth = 32;
481
- const barPadding = 12;
637
+ renderMobileXAxis(svg, data, dimensions) {
482
638
  svg.selectAll('.custom-x-label').remove();
483
639
  data.forEach((d, i) => {
484
- const xVal = this.SPACING.leftAndRight + i * (barWidth + barPadding) + barWidth / 2;
640
+ const xVal = this.CONSTANTS.LEFT_RIGHT_SPACES +
641
+ i * (dimensions.barWidth + dimensions.barPadding) +
642
+ dimensions.barWidth / 2;
485
643
  svg
486
644
  .append('text')
487
645
  .attr('class', 'custom-x-label')
488
646
  .attr('x', 0)
489
- .attr('y', height + 18)
647
+ .attr('y', dimensions.height + 18)
490
648
  .attr('text-anchor', 'middle')
491
649
  .attr('transform', `translate(${xVal + 20},0)`)
492
650
  .style('font-size', '10px')
@@ -495,204 +653,350 @@ export class HorizontalBarsWithScrollZoomComponent extends ComponentUniqueId {
495
653
  .text(d.name.substring(0, 3));
496
654
  });
497
655
  }
498
- renderDrilldownAxes(svg, svgYAxisLeft, svgYAxisRight, xAxis, yAxis, height) {
656
+ renderDrilldownAxes(svg, svgYAxisLeft, svgYAxisRight, axes, scales, dimensions) {
499
657
  svg
500
658
  .append('g')
501
- .attr('transform', `translate(0,${height})`)
659
+ .attr('transform', `translate(0,${dimensions.height})`)
502
660
  .attr('class', 'lib-stacked-x-axis-text multichart1')
503
- .call(xAxis)
661
+ .call(axes.xAxis)
504
662
  .style('display', 'none');
505
663
  svgYAxisLeft
506
664
  .append('g')
507
665
  .attr('class', 'lib-yaxis-labels-texts-drilldown yaxis-dashed')
508
- .call(yAxis)
666
+ .attr('style', this.chartConfiguration.yAxisCustomTextStyles)
667
+ .call(axes.yAxis)
509
668
  .selectAll('text')
510
669
  .style('fill', 'var(--chart-text-color)');
511
670
  svgYAxisRight
512
671
  .append('g')
513
672
  .attr('class', 'lib-yaxis-labels-texts-drilldown yaxis-dashed')
514
- .call(yAxis)
673
+ .attr('style', this.chartConfiguration.yAxisCustomTextStyles)
674
+ .call(axes.yAxis)
515
675
  .style('display', 'none');
516
676
  }
517
- renderMultiChartAxes(svg, xAxis, yAxis, height) {
677
+ renderMultiChartAxes(svg, axes, scales, dimensions) {
518
678
  svg
519
679
  .append('g')
520
- .attr('transform', `translate(0,${height})`)
680
+ .attr('transform', `translate(0,${dimensions.height})`)
521
681
  .attr('class', 'lib-stacked-x-axis-text multichart')
522
- .call(xAxis)
682
+ .call(axes.xAxis)
523
683
  .selectAll('text')
524
684
  .style('fill', 'var(--chart-text-color)');
525
685
  svg
526
686
  .append('g')
527
687
  .attr('class', 'lib-stacked-y-axis-text yaxis-dashed')
528
- .call(yAxis)
688
+ .attr('style', this.chartConfiguration.yAxisCustomTextStyles)
689
+ .call(axes.yAxis)
529
690
  .selectAll('text')
530
691
  .style('fill', 'var(--chart-text-color)');
531
692
  }
532
- styleAxisDomains(svg, svgYAxisLeft, svgYAxisRight) {
533
- const axisStyle = {
534
- stroke: 'var(--chart-axis-color)',
535
- 'stroke-width': '1px'
693
+ applyAxisStyling(svg, svgYAxisLeft, svgYAxisRight) {
694
+ const styleAxisDomain = (container) => {
695
+ container.selectAll('.domain')
696
+ .style('stroke', 'var(--chart-axis-color)')
697
+ .style('stroke-width', '1px');
536
698
  };
537
- [svg, svgYAxisLeft, svgYAxisRight].forEach(element => {
538
- element.selectAll('.domain')
539
- .style('stroke', axisStyle.stroke)
540
- .style('stroke-width', axisStyle['stroke-width']);
541
- });
542
- }
543
- renderLabels(svg, svgYAxisLeft, metaData, height, width, margin) {
544
- if (metaData.yLabel) {
545
- this.renderYAxisLabel(svgYAxisLeft, metaData.yLabel, height, margin);
699
+ styleAxisDomain(svg);
700
+ styleAxisDomain(svgYAxisLeft);
701
+ styleAxisDomain(svgYAxisRight);
702
+ if (this.chartConfiguration.isYaxisDashed) {
703
+ d3.selectAll('.yaxis-dashed')
704
+ .style('stroke-dasharray', '5 5')
705
+ .style('color', 'var(--chart-grid-color)');
546
706
  }
547
- if (metaData.xLabel) {
548
- this.renderXAxisLabel(svg, metaData.xLabel, height, width, margin);
707
+ if (this.chartConfiguration.isXaxisColor) {
708
+ d3.selectAll('.multichart').style('color', this.chartConfiguration.isXaxisColor || 'var(--chart-text-color)');
549
709
  }
550
710
  }
551
- renderYAxisLabel(svgYAxisLeft, yLabel, height, margin) {
552
- svgYAxisLeft.selectAll('.lib-axis-group-label, .lib-ylabel-drilldowncharts, .lib-ylabel-weeklyCharts').remove();
553
- const { formatted, isAcronym } = this.formatAxisLabel(yLabel);
554
- const isRia = this.customChartConfiguration?.isRia;
555
- const yPosition = isRia ? -margin.left / 2 - 30 : -margin.left / 2 - 40;
556
- let labelClass = 'lib-axis-group-label font-size-1';
557
- if (this.chartConfiguration.isDrilldownChart) {
558
- labelClass += ' lib-ylabel-drilldowncharts';
711
+ applyAxisConfigurations(svg, scales, dimensions, data) {
712
+ if (this.chartConfiguration.isMultiChartGridLine !== undefined) {
713
+ d3.selectAll('.multichart > g > text').attr('class', 'lib-display-hidden');
559
714
  }
560
- else if (this.chartConfiguration.isMultiChartGridLine !== undefined) {
561
- labelClass += ' lib-ylabel-weeklyCharts';
715
+ if (this.chartConfiguration.isXaxisLabelHidden) {
716
+ d3.selectAll('.multichart > g > text').attr('class', 'lib-display-hidden');
562
717
  }
563
- else {
564
- labelClass += ' lib-axis-waterfall-label';
718
+ else if (this.chartConfiguration.isXaxisLabelHidden !== undefined) {
719
+ this.renderCustomXAxis(svg, scales, dimensions, data);
565
720
  }
566
- svgYAxisLeft
721
+ if (this.chartConfiguration.isYaxisLabelHidden) {
722
+ svg.selectAll('.yaxis-dashed > g > text').attr('class', 'lib-display-hidden');
723
+ }
724
+ if (this.chartConfiguration.isYaxisHidden) {
725
+ d3.selectAll('.yaxis-dashed').attr('class', 'lib-display-hidden');
726
+ }
727
+ if (this.isZoomedOut && data.length > 9) {
728
+ svg
729
+ .selectAll('.lib-xaxis-labels-texts-drilldown')
730
+ .attr('transform', 'rotate(-90)')
731
+ .attr('text-anchor', 'end')
732
+ .attr('x', '-5')
733
+ .attr('dy', null);
734
+ }
735
+ }
736
+ renderCustomXAxis(svg, scales, dimensions, data) {
737
+ const device = this.getDeviceConfig();
738
+ svg
739
+ .append('g')
740
+ .attr('class', 'x1 axis1')
741
+ .attr('transform', `translate(0,${dimensions.height})`)
742
+ .style('color', '#000')
743
+ .call(d3.axisBottom(scales.xScale).tickSize(0))
744
+ .call((g) => g.select('.domain').attr('fill', 'none'));
745
+ this.styleCustomXAxisTicks(svg, data, device);
746
+ if (this.chartConfiguration.xLabelsOnSameLine) {
747
+ this.applyXLabelsOnSameLine(svg, device);
748
+ }
749
+ }
750
+ styleCustomXAxisTicks(svg, data, device) {
751
+ let alternateText = false;
752
+ svg.selectAll('.x1.axis1 .tick line').attr('y2', () => {
753
+ if (this.chartConfiguration.hideXaxisTick)
754
+ return 0;
755
+ if (alternateText && !this.chartConfiguration.isNoAlternateXaxisText) {
756
+ alternateText = false;
757
+ return this.CONSTANTS.LONG_TICK_LENGTH_BG - 7;
758
+ }
759
+ alternateText = true;
760
+ return this.CONSTANTS.SHORT_TICK_LENGTH_BG - 4;
761
+ });
762
+ alternateText = false;
763
+ svg
764
+ .selectAll('g.x1.axis1 g.tick text')
765
+ .attr('class', () => {
766
+ if (this.chartConfiguration.isDrilldownChart) {
767
+ return data.length > 8
768
+ ? 'lib-xaxis-labels-texts-drilldown-alt'
769
+ : 'lib-xaxis-labels-texts-drilldown';
770
+ }
771
+ return 'lib-xaxis-labels-texts-weeklycharts';
772
+ })
773
+ .attr('y', () => {
774
+ if (alternateText) {
775
+ alternateText = false;
776
+ return this.CONSTANTS.LONG_TICK_LENGTH_BG;
777
+ }
778
+ alternateText = true;
779
+ return this.CONSTANTS.SHORT_TICK_LENGTH_BG;
780
+ });
781
+ }
782
+ applyXLabelsOnSameLine(svg, device) {
783
+ svg
784
+ .selectAll('g.x1.axis1 g.tick text')
785
+ .attr('class', 'lib-xaxis-labels-texts-drilldown')
786
+ .attr('y', this.CONSTANTS.SHORT_TICK_LENGTH_BG)
787
+ .text((d) => {
788
+ if (device.isMobile) {
789
+ return d.split(' ')[0].substring(0, 3);
790
+ }
791
+ const trimmed = d.trim();
792
+ const spaceIndex = trimmed.indexOf(' ');
793
+ return spaceIndex > -1
794
+ ? trimmed.substring(0, spaceIndex).toLowerCase()
795
+ : trimmed.toLowerCase();
796
+ })
797
+ .attr('transform', function (d, i) {
798
+ if (device.isMobile) {
799
+ const parent = this.parentNode?.parentNode;
800
+ const totalBars = parent ? d3.select(parent).selectAll('g.tick').size() : 0;
801
+ return totalBars === 2 ? 'translate(0,0)' : `translate(${i * 30},0)`;
802
+ }
803
+ return null;
804
+ });
805
+ svg
806
+ .selectAll('g.x1.axis1 g.tick')
567
807
  .append('text')
568
- .attr('class', labelClass)
569
- .attr('style', this.chartConfiguration.yAxisCustomlabelStyles)
570
- .attr('transform', 'rotate(-90)')
571
- .attr('y', yPosition)
572
- .attr('x', -height / 2)
573
- .attr('dy', '1em')
574
- .style('text-anchor', 'middle')
575
- .style('fill', 'var(--chart-text-color)')
576
- .text(formatted)
577
- .style('text-transform', isAcronym ? 'none' : 'capitalize');
808
+ .attr('class', 'lib-xaxis-labels-texts-drilldown')
809
+ .attr('y', this.CONSTANTS.LONG_TICK_LENGTH_BG)
810
+ .attr('fill', 'currentColor')
811
+ .text((d) => {
812
+ if (device.isMobile)
813
+ return '';
814
+ const trimmed = d.trim();
815
+ const spaceIndex = trimmed.indexOf(' ');
816
+ return spaceIndex > -1
817
+ ? trimmed.substring(spaceIndex).toLowerCase()
818
+ : '';
819
+ })
820
+ .attr('transform', (d, i) => {
821
+ return device.isMobile && i === 0 ? 'translate(20,0)' : null;
822
+ });
578
823
  }
579
- renderXAxisLabel(svg, xLabel, height, width, margin) {
580
- const { formatted, isAcronym } = this.formatAxisLabel(xLabel);
581
- const isRia = this.customChartConfiguration?.isRia;
582
- const xPosition = isRia
583
- ? height + margin.top + margin.bottom
584
- : height + margin.top + margin.bottom + 10;
585
- let labelClass = 'lib-axis-group-label font-size-1';
586
- if (this.chartConfiguration.isDrilldownChart) {
587
- labelClass += ' lib-xlabel-drilldowncharts';
824
+ renderDataLabels(rect, scales, metaData, dimensions) {
825
+ if (!this.isCC && !this.chartConfiguration.isMultiChartGridLine) {
826
+ rect.append('svg:title').text((d) => d[1] - d[0]);
588
827
  }
589
- else if (this.chartConfiguration.isMultiChartGridLine !== undefined) {
590
- labelClass += ' lib-xlabel-weeklyCharts';
828
+ if (this.chartConfiguration.showTotalOnTop) {
829
+ this.renderTopLabels(rect, scales, metaData);
591
830
  }
592
- else {
593
- labelClass += ' lib-axis-waterfall-label';
831
+ if (this.chartConfiguration.showAngledLabels) {
832
+ this.renderAngledLabels(rect, scales, metaData);
594
833
  }
595
- svg
834
+ }
835
+ renderTopLabels(rect, scales, metaData) {
836
+ const formatFromBackend = this.chartConfiguration.textFormatter
837
+ ? ChartHelper.dataValueFormatter(this.chartConfiguration.textFormatter)
838
+ : (d) => d;
839
+ const formatForHugeNumbers = ChartHelper.dataValueFormatter('.2s');
840
+ rect
596
841
  .append('text')
597
- .attr('class', labelClass)
598
- .attr('style', this.chartConfiguration.xAxisCustomlabelStyles)
599
- .attr('transform', `translate(${width / 2},${xPosition})`)
600
- .style('text-anchor', 'middle')
601
- .style('fill', 'var(--chart-text-color)')
602
- .text(formatted)
603
- .style('text-transform', isAcronym ? 'none' : 'capitalize');
842
+ .attr('x', (d) => scales.xScale(d.data.name) + scales.xScale.bandwidth() / 2)
843
+ .attr('class', 'lib-verticalstack-labels-ontop-weklycharts')
844
+ .attr('y', (d) => scales.yScale(d[1]) - 3)
845
+ .text((d) => {
846
+ const value = d[1] - d[0];
847
+ if (isNaN(value) || value === 0)
848
+ return;
849
+ const formattedValue = value <= 999
850
+ ? formatFromBackend(value)
851
+ : formatForHugeNumbers(value);
852
+ return metaData.unit ? metaData.unit + formattedValue : formattedValue;
853
+ });
854
+ }
855
+ renderAngledLabels(rect, scales, metaData) {
856
+ const formatFromBackend = this.chartConfiguration.textFormatter
857
+ ? ChartHelper.dataValueFormatter(this.chartConfiguration.textFormatter)
858
+ : (d) => d;
859
+ const formatForHugeNumbers = ChartHelper.dataValueFormatter('.2s');
860
+ const tempObjectHolder = {};
861
+ rect
862
+ .append('text')
863
+ .attr('x', 0)
864
+ .attr('y', 0)
865
+ .attr('fill', (d) => metaData.colors[d.key])
866
+ .attr('class', 'lib-data-labels-angled-weeklycharts')
867
+ .text((d) => {
868
+ const value = d[1] - d[0];
869
+ if (isNaN(value) || value <= 0)
870
+ return;
871
+ const formattedValue = value <= 999
872
+ ? formatFromBackend(value)
873
+ : formatForHugeNumbers(value);
874
+ return metaData.unit ? metaData.unit + formattedValue : formattedValue;
875
+ })
876
+ .attr('transform', (d) => {
877
+ const value = d[1] - d[0];
878
+ if (isNaN(value) || value <= 0)
879
+ return 'rotate(0)';
880
+ let total = 0;
881
+ let incrementer = 1;
882
+ metaData.keyList.forEach(key => {
883
+ if (d.data[key]) {
884
+ total += d.data[key];
885
+ }
886
+ else {
887
+ incrementer = 2;
888
+ }
889
+ });
890
+ tempObjectHolder[d.data.name] = (tempObjectHolder[d.data.name] || 0) + incrementer;
891
+ const position = tempObjectHolder[d.data.name];
892
+ const xPos = scales.xScale(d.data.name);
893
+ const bandwidth = scales.xScale.bandwidth();
894
+ const yPos = scales.yScale(total) - 3;
895
+ switch (position) {
896
+ case 1:
897
+ return `translate(${xPos + bandwidth / 3},${yPos}) rotate(270)`;
898
+ case 2:
899
+ return `translate(${xPos + bandwidth / 2 + 2},${yPos}) rotate(270)`;
900
+ default:
901
+ return `translate(${xPos + (bandwidth * 3) / 4},${yPos}) rotate(270)`;
902
+ }
903
+ });
604
904
  }
605
- renderTargetLine(svg, svgYAxisRight, yScale, width, targetValue, metaData) {
606
- const yZero = yScale(targetValue);
607
- // Draw target line
905
+ renderTargetLine(svg, svgYAxisRight, scales, dimensions, metaData) {
906
+ if (!this.chartData.targetLineData)
907
+ return;
908
+ const parsedTarget = this.parseTargetValue(this.chartData.targetLineData.target);
909
+ const yZero = scales.yScale(parsedTarget);
608
910
  svg
609
911
  .append('line')
610
912
  .attr('x1', 0)
611
- .attr('x2', width)
913
+ .attr('x2', dimensions.width)
612
914
  .attr('y1', yZero)
613
915
  .attr('y2', yZero)
614
916
  .style('stroke-dasharray', '5 5')
615
917
  .style('stroke', this.chartData.targetLineData.color);
616
- // Add target label
617
- const targetLineName = this.chartData.targetLineData?.targetName || 'target';
918
+ this.renderTargetLabel(svgYAxisRight, yZero, metaData);
919
+ }
920
+ parseTargetValue(target) {
921
+ const parsed = parseFloat(String(target));
922
+ if (isNaN(parsed))
923
+ return 0;
924
+ return Number.isInteger(parsed) ? parseInt(String(target)) : parsed;
925
+ }
926
+ renderTargetLabel(svgYAxisRight, yZero, metaData) {
618
927
  const dataType = metaData.dataType || '';
928
+ const targetName = this.chartData.targetLineData.targetName || 'target';
619
929
  svgYAxisRight
620
930
  .append('foreignObject')
621
931
  .attr('transform', `translate(0,${yZero - 13})`)
622
- .attr('width', this.SPACING.rightSvgWidth)
932
+ .attr('width', this.CONSTANTS.RIGHT_SVG_WIDTH)
623
933
  .attr('height', 50)
624
934
  .append('xhtml:div')
625
935
  .attr('class', 'target-display')
626
936
  .style('color', 'var(--chart-text-color)')
627
- .html(`
628
- <div>${targetLineName}</div>
629
- <div>${targetValue}${dataType}</div>
630
- `);
631
- }
632
- renderLineChart(svg, lineData, xScale, height, colors) {
633
- const lineYscale = d3
634
- .scaleLinear()
635
- .domain([0, d3.max(lineData, (d) => +d.value) || 0])
636
- .range([height, 0]);
937
+ .html(`<div>${targetName}</div><div>${this.chartData.targetLineData.target}${dataType}</div>`);
938
+ }
939
+ renderLineChart(svg, lineData, scales, colors, metaData) {
940
+ if (!lineData || !colors)
941
+ return;
637
942
  const dataGroup = d3
638
943
  .nest()
639
944
  .key((d) => d.category)
640
945
  .entries(lineData);
641
946
  const lineGen = d3
642
947
  .line()
643
- .x((d) => xScale(d.name) + xScale.bandwidth() / 2)
644
- .y((d) => lineYscale(d.value));
948
+ .x((d) => scales.xScale(d.name) + scales.xScale.bandwidth() / 2)
949
+ .y((d) => scales.lineYscale(d.value));
645
950
  dataGroup.forEach((group) => {
646
- // Draw line
647
951
  svg
648
952
  .append('path')
649
953
  .datum(group.values)
650
954
  .attr('fill', 'none')
651
955
  .attr('stroke', (d) => {
652
- if (d[0] && 'category' in d[0]) {
653
- return colors[d[0].category];
654
- }
655
- return this.chartConfiguration.lineGraphColor;
956
+ return d[0]?.category
957
+ ? colors[d[0].category]
958
+ : this.chartConfiguration.lineGraphColor;
656
959
  })
657
960
  .attr('stroke-width', 2.5)
658
- .attr('d', lineGen(group.values));
659
- // Draw dots
660
- const dot = svg
661
- .selectAll('myCircles')
662
- .data(group.values)
663
- .enter()
664
- .append('g')
665
- .on('click', (d) => this.handleClick(d));
666
- dot
667
- .append('circle')
668
- .attr('fill', (d) => {
669
- if ('category' in d) {
670
- return colors[d.category];
671
- }
672
- return this.chartConfiguration.lineGraphColor;
673
- })
674
- .attr('stroke', 'none')
675
- .attr('cx', (d) => xScale(d.name) + xScale.bandwidth() / 2)
676
- .attr('cy', (d) => lineYscale(d.value))
677
- .attr('r', 3)
678
- .style('cursor', 'pointer');
679
- // Add labels if configured
680
- if (this.chartConfiguration.lineGraphColor) {
681
- dot
682
- .append('text')
683
- .attr('class', 'dots')
684
- .attr('fill', this.chartConfiguration.lineGraphColor)
685
- .attr('style', 'font-size: 0.85em; font-weight: bold')
686
- .attr('x', (d) => xScale(d.name) + xScale.bandwidth() / 2)
687
- .attr('y', (d) => lineYscale(d.value))
688
- .attr('dy', '-1em')
689
- .text((d) => this.chartConfiguration.labelFormatter(d.value));
690
- }
961
+ .attr('d', lineGen);
962
+ this.renderLineDots(svg, group.values, scales, colors);
691
963
  });
692
964
  }
693
- handleClick(data) {
694
- if (this.chartData?.metaData?.hasDrillDown || data?.toggleFrom) {
695
- this.clickEvent.emit(data);
965
+ renderLineDots(svg, values, scales, colors) {
966
+ const dot = svg
967
+ .selectAll('.line-dots')
968
+ .data(values)
969
+ .enter()
970
+ .append('g')
971
+ .on('click', (d) => this.handleClick(d));
972
+ dot
973
+ .append('circle')
974
+ .attr('fill', (d) => {
975
+ return d.category
976
+ ? colors[d.category]
977
+ : this.chartConfiguration.lineGraphColor;
978
+ })
979
+ .attr('stroke', 'none')
980
+ .attr('cx', (d) => scales.xScale(d.name) + scales.xScale.bandwidth() / 2)
981
+ .attr('cy', (d) => scales.lineYscale(d.value))
982
+ .attr('r', 3)
983
+ .style('cursor', 'pointer');
984
+ if (this.chartConfiguration.lineGraphColor) {
985
+ dot
986
+ .append('text')
987
+ .attr('class', 'dots')
988
+ .attr('fill', this.chartConfiguration.lineGraphColor)
989
+ .style('font-size', '.85em')
990
+ .style('font-weight', 'bold')
991
+ .attr('x', (d) => scales.xScale(d.name) + scales.xScale.bandwidth() / 2)
992
+ .attr('y', (d) => scales.lineYscale(d.value))
993
+ .attr('dy', '-1em')
994
+ .text((d) => this.chartConfiguration.labelFormatter(d.value));
995
+ }
996
+ }
997
+ handleClick(d) {
998
+ if (this.chartData?.metaData?.hasDrillDown || d?.toggleFrom) {
999
+ this.clickEvent.emit(d);
696
1000
  }
697
1001
  }
698
1002
  handleHeaderMenuClick(id) {
@@ -725,4 +1029,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
725
1029
  }], headerMenuclickEvent: [{
726
1030
  type: Output
727
1031
  }] } });
728
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"horizontal-bars-with-scroll-zoom.component.js","sourceRoot":"","sources":["../../../../../projects/axidio-styleguide-library/src/lib/horizontal-bars-with-scroll-zoom/horizontal-bars-with-scroll-zoom.component.ts","../../../../../projects/axidio-styleguide-library/src/lib/horizontal-bars-with-scroll-zoom/horizontal-bars-with-scroll-zoom.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  SimpleChanges,\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 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  colors: { [key: string]: string };\r\n  keyList: string[];\r\n  unit?: string;\r\n  isCC?: boolean;\r\n  barWithoutClick?: string[];\r\n  hasDrillDown?: boolean;\r\n  hoverColor?: string;\r\n  dataType?: string;\r\n  yLabel?: string;\r\n  lineyLabel?: string;\r\n  xLabel?: string;\r\n}\r\n\r\ninterface TargetLineData {\r\n  target: number | string;\r\n  targetName?: string;\r\n  color: string;\r\n  barAboveTargetColor?: string;\r\n  barAboveTargetHoverColor?: string;\r\n}\r\n\r\ninterface DeviceBreakpoints {\r\n  isMobile: boolean;\r\n  isTablet: boolean;\r\n  isDesktop: boolean;\r\n}\r\n\r\n@Component({\r\n  selector: 'lib-horizontal-bars-with-scroll-zoom',\r\n  templateUrl: './horizontal-bars-with-scroll-zoom.component.html',\r\n  styleUrls: [\r\n    './horizontal-bars-with-scroll-zoom.component.less',\r\n    '../common-styles.less',\r\n  ],\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class HorizontalBarsWithScrollZoomComponent\r\n  extends ComponentUniqueId\r\n  implements OnInit, OnChanges {\r\n  \r\n  @ViewChild('verticalstackedchartcontainer', { static: true })\r\n  containerElt!: ElementRef;\r\n\r\n  @ViewChild('verticalstackedcontainer', { static: true })\r\n  verticalstackedcontainerElt!: ElementRef;\r\n\r\n  @Input() chartData!: ChartData;\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: string = this.getUniqueId();\r\n  isTransparentBackground = false;\r\n  isCC = false;\r\n  isZoomedOut = true;\r\n\r\n  private readonly TICK_LENGTHS = {\r\n    short: 4,\r\n    long: 16,\r\n    shortBg: 5,\r\n    longBg: 30,\r\n  };\r\n\r\n  private readonly SPACING = {\r\n    rightSvgWidth: 60,\r\n    leftAndRight: 50,\r\n  };\r\n\r\n  private readonly 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  };\r\n\r\n  constructor() {\r\n    super();\r\n  }\r\n\r\n  ngOnInit(): void {}\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    this.redrawChart();\r\n  }\r\n\r\n  onResized(event: ResizedEvent): void {\r\n    setTimeout(() => this.redrawChart(), 10);\r\n  }\r\n\r\n  isZoomOutSelected(isZoomOut: boolean): void {\r\n    this.isZoomedOut = isZoomOut;\r\n    this.redrawChart();\r\n  }\r\n\r\n  private redrawChart(): void {\r\n    d3.select('#' + this.uniqueId).remove();\r\n    this.initializeStackedChart();\r\n  }\r\n\r\n  private getDeviceBreakpoints(): DeviceBreakpoints {\r\n    const width = window.innerWidth;\r\n    return {\r\n      isMobile: width < 576,\r\n      isTablet: width >= 576 && width < 992,\r\n      isDesktop: width >= 992,\r\n    };\r\n  }\r\n\r\n  private applyResponsiveConfig(device: DeviceBreakpoints): void {\r\n    if (device.isMobile) {\r\n      this.chartConfiguration.margin = { top: 20, right: 10, bottom: 40, left: 30 };\r\n      this.chartConfiguration.numberOfYTicks = 4;\r\n      this.chartConfiguration.svgHeight = 60;\r\n    } else if (device.isTablet) {\r\n      this.chartConfiguration.margin = { top: 25, right: 20, bottom: 45, left: 40 };\r\n      this.chartConfiguration.numberOfYTicks = 6;\r\n      this.chartConfiguration.svgHeight = 70;\r\n    } else {\r\n      this.chartConfiguration.margin = { top: 30, right: 30, bottom: 50, left: 60 };\r\n      this.chartConfiguration.numberOfYTicks = 7;\r\n      this.chartConfiguration.svgHeight = 80;\r\n    }\r\n  }\r\n\r\n  private mergeConfigurations(): void {\r\n    Object.keys(this.defaultConfiguration).forEach((key) => {\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\n  private parseTargetValue(targetLineData?: TargetLineData): number | null {\r\n    if (!targetLineData?.target) return null;\r\n    \r\n    const parsedNum = parseFloat(String(targetLineData.target));\r\n    if (isNaN(parsedNum)) return null;\r\n    \r\n    return Number.isInteger(parsedNum) \r\n      ? parseInt(String(targetLineData.target)) \r\n      : parsedNum;\r\n  }\r\n\r\n  private calculateDimensions(\r\n    containerWidth: number,\r\n    containerHeight: number,\r\n    margin: any,\r\n    device: DeviceBreakpoints\r\n  ): { width: number; height: number } {\r\n    let width = containerWidth - margin.left - margin.right;\r\n    let height = containerHeight * (this.chartConfiguration.svgHeight / 100) - margin.top - margin.bottom;\r\n\r\n    // Adjust width for zoom levels\r\n    const dataLength = this.chartData.data.length;\r\n    if (dataLength > 30 && this.isZoomedOut) {\r\n      const minWidth = dataLength * (device.isMobile ? 15 : 25);\r\n      width = Math.max(width, minWidth);\r\n    }\r\n    if (dataLength > 8 && !this.isZoomedOut) {\r\n      width = dataLength * (device.isMobile ? 60 : 130);\r\n    }\r\n\r\n    // Apply special height configurations\r\n    if (this.chartConfiguration.isFullScreen && this.chartConfiguration.svgHeight !== 80) {\r\n      height = this.chartConfiguration.svgHeight;\r\n    } else if (this.chartConfiguration.isFullScreen) {\r\n      height = containerHeight;\r\n    }\r\n\r\n    if (this.chartConfiguration.isDrilldownChart) {\r\n      height = containerHeight - margin.top - margin.bottom - (device.isMobile ? 60 : 130);\r\n    }\r\n\r\n    return { width, height };\r\n  }\r\n\r\n  private calculateBarDimensions(\r\n    width: number,\r\n    dataLength: number,\r\n    device: DeviceBreakpoints\r\n  ): { barWidth: number; barPadding: number; requiredSvgWidth: number } {\r\n    let barWidth: number;\r\n    let barPadding: number;\r\n    let requiredSvgWidth: number;\r\n\r\n    if (device.isMobile) {\r\n      const minBarWidth = 32;\r\n      barWidth = minBarWidth;\r\n      barPadding = 12;\r\n      requiredSvgWidth = Math.max(\r\n        width - this.SPACING.rightSvgWidth,\r\n        (barWidth + barPadding) * dataLength + this.SPACING.leftAndRight * 2 + \r\n        this.SPACING.rightSvgWidth - barPadding\r\n      );\r\n    } else {\r\n      barWidth = Math.max(\r\n        40,\r\n        (width - this.SPACING.rightSvgWidth - this.SPACING.leftAndRight * 2) / dataLength\r\n      );\r\n      barPadding = 0;\r\n      requiredSvgWidth = width - this.SPACING.rightSvgWidth;\r\n    }\r\n\r\n    return { barWidth, barPadding, requiredSvgWidth };\r\n  }\r\n\r\n  private createScales(data: any[], height: number, width: number, device: DeviceBreakpoints) {\r\n    const xScale = d3\r\n      .scaleBand()\r\n      .rangeRound([\r\n        this.SPACING.leftAndRight,\r\n        width - this.SPACING.rightSvgWidth - this.SPACING.leftAndRight\r\n      ])\r\n      .domain(data.map(d => d.name).reverse())\r\n      .padding(device.isMobile ? 0.2 : 0.5);\r\n\r\n    const yScale = d3.scaleLinear().rangeRound([height, 0]);\r\n\r\n    return { xScale, yScale };\r\n  }\r\n\r\n  private calculateYScaleDomain(layers: any[], targetValue?: number): number {\r\n    let maxValue = d3.max(layers, (d: any) => d3.max(d, (d: any) => d[1])) || 0;\r\n\r\n    if (maxValue === 0) {\r\n      maxValue = targetValue ? targetValue + 20 : 100;\r\n    }\r\n\r\n    if (this.chartConfiguration.customYscale) {\r\n      maxValue *= this.chartConfiguration.customYscale;\r\n    }\r\n\r\n    if (targetValue && maxValue < targetValue) {\r\n      maxValue = maxValue < 10 && targetValue < 10 \r\n        ? targetValue + 3 \r\n        : targetValue + 20;\r\n    }\r\n\r\n    return maxValue;\r\n  }\r\n\r\n  private shouldShowTargetLineColor(d: any, targetValue?: number): boolean {\r\n    return !!(\r\n      !isNaN(d[0]) &&\r\n      !isNaN(d[1]) &&\r\n      this.chartData.targetLineData &&\r\n      targetValue &&\r\n      parseFloat(d[1]) - parseFloat(d[0]) >= targetValue\r\n    );\r\n  }\r\n\r\n  private getBarFillColor(d: any, key: string, metaData: ChartMetaData, targetValue?: number): string {\r\n    if (this.shouldShowTargetLineColor(d, targetValue)) {\r\n      return this.chartData.targetLineData?.barAboveTargetColor || metaData.colors[key];\r\n    }\r\n    return metaData.colors[key];\r\n  }\r\n\r\n  private isAcronym(label: string): boolean {\r\n    const alphaOnly = 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 formatAxisLabel(text: string): { formatted: string; isAcronym: boolean } {\r\n    const isAcr = this.isAcronym(text);\r\n    return {\r\n      formatted: isAcr ? text.toUpperCase() : text.toLowerCase(),\r\n      isAcronym: isAcr\r\n    };\r\n  }\r\n\r\n  initializeStackedChart(): void {\r\n    const device = this.getDeviceBreakpoints();\r\n    this.applyResponsiveConfig(device);\r\n    this.mergeConfigurations();\r\n\r\n    const { data, metaData, lineData } = this.chartData;\r\n    const preparedMetaData = this.prepareMetaData(metaData);\r\n    const targetValue = this.parseTargetValue(this.chartData.targetLineData);\r\n\r\n    const chartContainer = d3.select(this.containerElt.nativeElement);\r\n    const verticalstackedcontainer = d3.select(this.verticalstackedcontainerElt.nativeElement);\r\n\r\n    const margin = this.chartConfiguration.margin;\r\n    const containerWidth = chartContainer.node().getBoundingClientRect().width;\r\n    const containerHeight = verticalstackedcontainer.node().getBoundingClientRect().height;\r\n\r\n    const { width, height } = this.calculateDimensions(\r\n      containerWidth,\r\n      containerHeight,\r\n      margin,\r\n      device\r\n    );\r\n\r\n    // Apply visibility configurations\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    // Create formatters\r\n    const formatFromBackend = this.chartConfiguration.textFormatter\r\n      ? ChartHelper.dataValueFormatter(this.chartConfiguration.textFormatter)\r\n      : null;\r\n    const formatForHugeNumbers = ChartHelper.dataValueFormatter('.2s');\r\n\r\n    // Create SVG containers\r\n    const { barWidth, barPadding, requiredSvgWidth } = this.calculateBarDimensions(\r\n      width,\r\n      data.length,\r\n      device\r\n    );\r\n\r\n    const outerContainer = this.createOuterContainer(chartContainer, height, margin);\r\n    const { svgYAxisLeft, svgYAxisRight } = this.createAxisContainers(\r\n      outerContainer,\r\n      height,\r\n      margin\r\n    );\r\n    const { innerContainer, svg } = this.createInnerContainer(\r\n      outerContainer,\r\n      requiredSvgWidth,\r\n      height,\r\n      margin,\r\n      device\r\n    );\r\n\r\n    // Create scales\r\n    const { xScale, yScale } = this.createScales(data, height, width, device);\r\n    \r\n    // Stack data\r\n    const stack: any = d3\r\n      .stack()\r\n      .keys(preparedMetaData.keyList)\r\n      .offset(d3.stackOffsetNone);\r\n    const layers: any = stack(data);\r\n\r\n    // Set Y scale domain\r\n    const maxValue = this.calculateYScaleDomain(layers, targetValue || undefined);\r\n    yScale.domain([0, maxValue]).nice();\r\n\r\n    // Render chart elements\r\n    this.renderGrids(svg, xScale, yScale, height, width);\r\n    this.renderBars(\r\n      svg,\r\n      layers,\r\n      xScale,\r\n      yScale,\r\n      preparedMetaData,\r\n      device,\r\n      barWidth,\r\n      barPadding,\r\n      targetValue,\r\n      formatFromBackend,\r\n      formatForHugeNumbers\r\n    );\r\n    this.renderAxes(svg, svgYAxisLeft, svgYAxisRight, xScale, yScale, data, height, width, device);\r\n    this.renderLabels(svg, svgYAxisLeft, preparedMetaData, height, width, margin);\r\n    \r\n    if (this.chartData.targetLineData && targetValue) {\r\n      this.renderTargetLine(svg, svgYAxisRight, yScale, width, targetValue, preparedMetaData);\r\n    }\r\n\r\n    if (lineData) {\r\n      this.renderLineChart(svg, lineData, xScale, height, preparedMetaData.colors);\r\n    }\r\n  }\r\n\r\n  private createOuterContainer(chartContainer: any, height: number, margin: any): any {\r\n    return 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('margin-left', '10px')\r\n      .style('padding-right', `${this.SPACING.rightSvgWidth}px`);\r\n  }\r\n\r\n  private createAxisContainers(outerContainer: any, height: number, margin: any): any {\r\n    const svgYAxisLeft = outerContainer\r\n      .append('svg')\r\n      .attr('width', '80')\r\n      .attr('height', height + margin.top + margin.bottom)\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 + 10},${margin.top})`);\r\n\r\n    const svgYAxisRight = outerContainer\r\n      .append('svg')\r\n      .attr('width', this.SPACING.rightSvgWidth)\r\n      .attr('height', height + margin.top + margin.bottom)\r\n      .style('position', 'absolute')\r\n      .style('right', '2px')\r\n      .style('z-index', 1)\r\n      .append('g')\r\n      .attr('transform', `translate(0,${margin.top})`);\r\n\r\n    return { svgYAxisLeft, svgYAxisRight };\r\n  }\r\n\r\n  private createInnerContainer(\r\n    outerContainer: any,\r\n    requiredSvgWidth: number,\r\n    height: number,\r\n    margin: any,\r\n    device: DeviceBreakpoints\r\n  ): any {\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', device.isMobile ? 'auto' : 'auto');\r\n\r\n    const svg = innerContainer\r\n      .append('svg')\r\n      .attr('width', requiredSvgWidth)\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 { innerContainer, svg };\r\n  }\r\n\r\n  private renderGrids(svg: any, xScale: any, yScale: any, height: number, width: number): void {\r\n    if (this.chartConfiguration.isXgridBetweenLabels) {\r\n      svg\r\n        .append('g')\r\n        .attr('class', 'grid')\r\n        .attr('transform', `translate(${xScale.bandwidth() / 2},${height})`)\r\n        .call(d3.axisBottom(xScale).tickSize(-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.yAxisGrid) {\r\n      svg\r\n        .append('g')\r\n        .attr('class', 'grid')\r\n        .call(\r\n          d3\r\n            .axisLeft(yScale)\r\n            .ticks(this.chartConfiguration.numberOfYTicks)\r\n            .tickSize(-width)\r\n            .tickFormat('')\r\n        )\r\n        .style('color', 'var(--chart-grid-color)')\r\n        .style('opacity', '1');\r\n    }\r\n\r\n    if (this.chartConfiguration.xAxisGrid) {\r\n      this.chartConfiguration.xAxisGrid.forEach((gridPos: number, index: number) => {\r\n        svg\r\n          .append('g')\r\n          .attr('class', `x${index + 2} axis${index + 2}`)\r\n          .style('color', 'var(--chart-grid-color)')\r\n          .attr('transform', `translate(0,${height * gridPos})`)\r\n          .call(d3.axisBottom(xScale).tickSize(0).ticks(5).tickFormat(''))\r\n          .style('fill', 'var(--chart-text-color)');\r\n      });\r\n    }\r\n  }\r\n\r\n  private renderBars(\r\n    svg: any,\r\n    layers: any,\r\n    xScale: any,\r\n    yScale: any,\r\n    metaData: ChartMetaData,\r\n    device: DeviceBreakpoints,\r\n    barWidth: number,\r\n    barPadding: number,\r\n    targetValue: number | null,\r\n    formatFromBackend: any,\r\n    formatForHugeNumbers: any\r\n  ): void {\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.selectAll('rect').data((d: any) => d).enter();\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, i: number) => {\r\n        if (device.isMobile) {\r\n          return this.SPACING.leftAndRight + i * (barWidth + barPadding);\r\n        }\r\n        if (this.chartConfiguration.isMultiChartGridLine === undefined) {\r\n          return xScale(d.data.name);\r\n        }\r\n        if (this.chartConfiguration.isDrilldownChart && this.chartData.data.length <= 3) {\r\n          return xScale(d.data.name) + xScale.bandwidth() / 2 - 35;\r\n        }\r\n        return xScale(d.data.name) + xScale.bandwidth() * 0.1;\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 (device.isMobile) return barWidth;\r\n        \r\n        if (this.chartConfiguration.isMultiChartGridLine === undefined) {\r\n          return xScale.bandwidth();\r\n        }\r\n        return this.chartConfiguration.isDrilldownChart && this.chartData.data.length <= 3\r\n          ? 70\r\n          : xScale.bandwidth() * 0.8;\r\n      })\r\n      .style('cursor', (d: any) => {\r\n        if (!metaData.hasDrillDown) return 'default';\r\n        if (metaData.barWithoutClick?.includes(d.data.name.toLowerCase())) {\r\n          return 'default';\r\n        }\r\n        return 'pointer';\r\n      })\r\n      .style('fill', (d: any) => this.getBarFillColor(d, d.key, metaData, targetValue || undefined));\r\n\r\n    // Add tooltips and labels\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    this.addBarLabels(rect, xScale, yScale, metaData, formatFromBackend, formatForHugeNumbers);\r\n  }\r\n\r\n  private addBarLabels(\r\n    rect: any,\r\n    xScale: any,\r\n    yScale: any,\r\n    metaData: ChartMetaData,\r\n    formatFromBackend: any,\r\n    formatForHugeNumbers: any\r\n  ): void {\r\n    if (this.chartConfiguration.showTotalOnTop) {\r\n      rect\r\n        .append('text')\r\n        .attr('x', (d: any) => xScale(d.data.name) + xScale.bandwidth() / 2)\r\n        .attr('class', 'lib-verticalstack-labels-ontop-weklycharts')\r\n        .attr('y', (d: any) => yScale(d[1]) - 3)\r\n        .text((d: any) => {\r\n          if (!isNaN(d[1] - d[0]) && d[1] - d[0] !== 0) {\r\n            const value = d[1] - d[0];\r\n            const formatter = value <= 999 ? formatFromBackend : formatForHugeNumbers;\r\n            return metaData.unit ? metaData.unit + formatter(value) : formatter(value);\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    xScale: any,\r\n    yScale: any,\r\n    data: any[],\r\n    height: number,\r\n    width: number,\r\n    device: DeviceBreakpoints\r\n  ): void {\r\n    const xAxis = d3\r\n      .axisBottom(xScale)\r\n      .tickSize(0)\r\n      .tickFormat(this.chartConfiguration.xAxisLabelFomatter);\r\n\r\n    const yAxis = d3\r\n      .axisLeft(yScale)\r\n      .ticks(this.chartConfiguration.numberOfYTicks)\r\n      .tickSize(0)\r\n      .tickFormat(this.chartConfiguration.yAxisLabelFomatter);\r\n\r\n    // Render based on chart type\r\n    if (this.chartConfiguration.isMultiChartGridLine === undefined) {\r\n      this.renderStandardAxes(svg, xAxis, yAxis, data, height, device);\r\n    } else if (this.chartConfiguration.isDrilldownChart) {\r\n      this.renderDrilldownAxes(svg, svgYAxisLeft, svgYAxisRight, xAxis, yAxis, height);\r\n    } else {\r\n      this.renderMultiChartAxes(svg, xAxis, yAxis, height);\r\n    }\r\n\r\n    this.styleAxisDomains(svg, svgYAxisLeft, svgYAxisRight);\r\n  }\r\n\r\n  private renderStandardAxes(\r\n    svg: any,\r\n    xAxis: any,\r\n    yAxis: any,\r\n    data: any[],\r\n    height: number,\r\n    device: DeviceBreakpoints\r\n  ): void {\r\n    if (device.isMobile) {\r\n      this.renderMobileXAxis(svg, data, height, device);\r\n    } else {\r\n      svg\r\n        .append('g')\r\n        .attr('transform', `translate(0,${height})`)\r\n        .attr('class', 'lib-stacked-x-axis-text')\r\n        .call(xAxis)\r\n        .selectAll('text')\r\n        .style('fill', 'var(--chart-text-color)')\r\n        .style('font-size', '12px')\r\n        .attr('text-anchor', 'middle');\r\n    }\r\n\r\n    svg\r\n      .append('g')\r\n      .attr('class', 'lib-stacked-y-axis-text')\r\n      .call(yAxis)\r\n      .selectAll('text')\r\n      .style('fill', 'var(--chart-text-color)');\r\n  }\r\n\r\n  private renderMobileXAxis(svg: any, data: any[], height: number, device: DeviceBreakpoints): void {\r\n    const barWidth = 32;\r\n    const barPadding = 12;\r\n    \r\n    svg.selectAll('.custom-x-label').remove();\r\n    data.forEach((d: any, i: number) => {\r\n      const xVal = this.SPACING.leftAndRight + i * (barWidth + barPadding) + barWidth / 2;\r\n      svg\r\n        .append('text')\r\n        .attr('class', 'custom-x-label')\r\n        .attr('x', 0)\r\n        .attr('y', height + 18)\r\n        .attr('text-anchor', 'middle')\r\n        .attr('transform', `translate(${xVal + 20},0)`)\r\n        .style('font-size', '10px')\r\n        .style('fill', 'var(--chart-text-color)')\r\n        .style('writing-mode', 'sideways-lr')\r\n        .text(d.name.substring(0, 3));\r\n    });\r\n  }\r\n\r\n  private renderDrilldownAxes(\r\n    svg: any,\r\n    svgYAxisLeft: any,\r\n    svgYAxisRight: any,\r\n    xAxis: any,\r\n    yAxis: any,\r\n    height: number\r\n  ): void {\r\n    svg\r\n      .append('g')\r\n      .attr('transform', `translate(0,${height})`)\r\n      .attr('class', 'lib-stacked-x-axis-text multichart1')\r\n      .call(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      .call(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      .call(yAxis)\r\n      .style('display', 'none');\r\n  }\r\n\r\n  private renderMultiChartAxes(svg: any, xAxis: any, yAxis: any, height: number): void {\r\n    svg\r\n      .append('g')\r\n      .attr('transform', `translate(0,${height})`)\r\n      .attr('class', 'lib-stacked-x-axis-text multichart')\r\n      .call(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      .call(yAxis)\r\n      .selectAll('text')\r\n      .style('fill', 'var(--chart-text-color)');\r\n  }\r\n\r\n  private styleAxisDomains(svg: any, svgYAxisLeft: any, svgYAxisRight: any): void {\r\n    const axisStyle = {\r\n      stroke: 'var(--chart-axis-color)',\r\n      'stroke-width': '1px'\r\n    };\r\n\r\n    [svg, svgYAxisLeft, svgYAxisRight].forEach(element => {\r\n      element.selectAll('.domain')\r\n        .style('stroke', axisStyle.stroke)\r\n        .style('stroke-width', axisStyle['stroke-width']);\r\n    });\r\n  }\r\n\r\n  private renderLabels(\r\n    svg: any,\r\n    svgYAxisLeft: any,\r\n    metaData: ChartMetaData,\r\n    height: number,\r\n    width: number,\r\n    margin: any\r\n  ): void {\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, height, width, margin);\r\n    }\r\n  }\r\n\r\n  private renderYAxisLabel(\r\n    svgYAxisLeft: any,\r\n    yLabel: string,\r\n    height: number,\r\n    margin: any\r\n  ): void {\r\n    svgYAxisLeft.selectAll('.lib-axis-group-label, .lib-ylabel-drilldowncharts, .lib-ylabel-weeklyCharts').remove();\r\n    \r\n    const { formatted, isAcronym } = this.formatAxisLabel(yLabel);\r\n    const isRia = this.customChartConfiguration?.isRia;\r\n    const yPosition = isRia ? -margin.left / 2 - 30 : -margin.left / 2 - 40;\r\n\r\n    let labelClass = 'lib-axis-group-label font-size-1';\r\n    if (this.chartConfiguration.isDrilldownChart) {\r\n      labelClass += ' lib-ylabel-drilldowncharts';\r\n    } else if (this.chartConfiguration.isMultiChartGridLine !== undefined) {\r\n      labelClass += ' lib-ylabel-weeklyCharts';\r\n    } else {\r\n      labelClass += ' lib-axis-waterfall-label';\r\n    }\r\n\r\n    svgYAxisLeft\r\n      .append('text')\r\n      .attr('class', labelClass)\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(formatted)\r\n      .style('text-transform', isAcronym ? 'none' : 'capitalize');\r\n  }\r\n\r\n  private renderXAxisLabel(\r\n    svg: any,\r\n    xLabel: string,\r\n    height: number,\r\n    width: number,\r\n    margin: any\r\n  ): void {\r\n    const { formatted, isAcronym } = this.formatAxisLabel(xLabel);\r\n    const isRia = this.customChartConfiguration?.isRia;\r\n    const xPosition = isRia \r\n      ? height + margin.top + margin.bottom \r\n      : height + margin.top + margin.bottom + 10;\r\n\r\n    let labelClass = 'lib-axis-group-label font-size-1';\r\n    if (this.chartConfiguration.isDrilldownChart) {\r\n      labelClass += ' lib-xlabel-drilldowncharts';\r\n    } else if (this.chartConfiguration.isMultiChartGridLine !== undefined) {\r\n      labelClass += ' lib-xlabel-weeklyCharts';\r\n    } else {\r\n      labelClass += ' lib-axis-waterfall-label';\r\n    }\r\n\r\n    svg\r\n      .append('text')\r\n      .attr('class', labelClass)\r\n      .attr('style', this.chartConfiguration.xAxisCustomlabelStyles)\r\n      .attr('transform', `translate(${width / 2},${xPosition})`)\r\n      .style('text-anchor', 'middle')\r\n      .style('fill', 'var(--chart-text-color)')\r\n      .text(formatted)\r\n      .style('text-transform', isAcronym ? 'none' : 'capitalize');\r\n  }\r\n\r\n  private renderTargetLine(\r\n    svg: any,\r\n    svgYAxisRight: any,\r\n    yScale: any,\r\n    width: number,\r\n    targetValue: number,\r\n    metaData: ChartMetaData\r\n  ): void {\r\n    const yZero = yScale(targetValue);\r\n    \r\n    // Draw target line\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', this.chartData.targetLineData!.color);\r\n\r\n    // Add target label\r\n    const targetLineName = this.chartData.targetLineData?.targetName || 'target';\r\n    const dataType = metaData.dataType || '';\r\n\r\n    svgYAxisRight\r\n      .append('foreignObject')\r\n      .attr('transform', `translate(0,${yZero - 13})`)\r\n      .attr('width', this.SPACING.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        <div>${targetLineName}</div>\r\n        <div>${targetValue}${dataType}</div>\r\n      `);\r\n  }\r\n\r\n  private renderLineChart(\r\n    svg: any,\r\n    lineData: any[],\r\n    xScale: any,\r\n    height: number,\r\n    colors: { [key: string]: string }\r\n  ): void {\r\n    const lineYscale = d3\r\n      .scaleLinear()\r\n      .domain([0, d3.max(lineData, (d: any) => +d.value) || 0])\r\n      .range([height, 0]);\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) => xScale(d.name) + xScale.bandwidth() / 2)\r\n      .y((d: any) => lineYscale(d.value));\r\n\r\n    dataGroup.forEach((group: any) => {\r\n      // Draw line\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          if (d[0] && 'category' in d[0]) {\r\n            return colors[d[0].category];\r\n          }\r\n          return this.chartConfiguration.lineGraphColor;\r\n        })\r\n        .attr('stroke-width', 2.5)\r\n        .attr('d', lineGen(group.values));\r\n\r\n      // Draw dots\r\n      const dot = svg\r\n        .selectAll('myCircles')\r\n        .data(group.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          if ('category' in d) {\r\n            return colors[d.category];\r\n          }\r\n          return this.chartConfiguration.lineGraphColor;\r\n        })\r\n        .attr('stroke', 'none')\r\n        .attr('cx', (d: any) => xScale(d.name) + xScale.bandwidth() / 2)\r\n        .attr('cy', (d: any) => lineYscale(d.value))\r\n        .attr('r', 3)\r\n        .style('cursor', 'pointer');\r\n\r\n      // Add labels if configured\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          .attr('style', 'font-size: 0.85em; font-weight: bold')\r\n          .attr('x', (d: any) => xScale(d.name) + xScale.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\r\n  handleClick(data: any): void {\r\n    if (this.chartData?.metaData?.hasDrillDown || data?.toggleFrom) {\r\n      this.clickEvent.emit(data);\r\n    }\r\n  }\r\n\r\n  handleHeaderMenuClick(id: string): void {\r\n    this.headerMenuclickEvent.emit(id);\r\n  }\r\n\r\n  handleCompareByFilterSelection(event: any): void {\r\n    this.clickEvent.emit(event);\r\n  }\r\n\r\n  handleZoominZoomoutClick({ isZoomOut, event }: { isZoomOut: boolean; event: any }): void {\r\n    this.isZoomOutSelected(isZoomOut);\r\n  }\r\n}","<meta http-equiv=\"CACHE-CONTROL\" content=\"NO-CACHE\" />\r\n<meta http-equiv=\"EXPIRES\" content=\"Sat, 01 Jun 2004 11:12:01 GMT\" />\r\n<div\r\n  #verticalstackedcontainer\r\n  class=\"lib-chart-wrapper\"\r\n  [ngClass]=\"{ 'lib-no-background': isTransparentBackground }\"\r\n    style=\"background-color: var(--card-bg);\"\r\n\r\n  (resized)=\"onResized($event)\"\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\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  <div\r\n    [style.height]=\"chartConfiguration.svgHeight\"\r\n    id=\"verticalstackedchartcontainer\"\r\n    #verticalstackedchartcontainer\r\n    class=\"lib-chart-svg\"\r\n  ></div>\r\n</div>\r\n"]}
1032
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"horizontal-bars-with-scroll-zoom.component.js","sourceRoot":"","sources":["../../../../../projects/axidio-styleguide-library/src/lib/horizontal-bars-with-scroll-zoom/horizontal-bars-with-scroll-zoom.component.ts","../../../../../projects/axidio-styleguide-library/src/lib/horizontal-bars-with-scroll-zoom/horizontal-bars-with-scroll-zoom.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\ninterface DeviceConfig {\r\n  isMobile: boolean;\r\n  isTablet: boolean;\r\n  isDesktop: boolean;\r\n}\r\n\r\n@Component({\r\n  selector: 'lib-horizontal-bars-with-scroll-zoom',\r\n  templateUrl: './horizontal-bars-with-scroll-zoom.component.html',\r\n  styleUrls: [\r\n    './horizontal-bars-with-scroll-zoom.component.less',\r\n    '../common-styles.less',\r\n  ],\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class HorizontalBarsWithScrollZoomComponent\r\n  extends ComponentUniqueId\r\n  implements OnInit, OnChanges {\r\n  \r\n  @ViewChild('verticalstackedchartcontainer', { static: true })\r\n  containerElt!: ElementRef;\r\n\r\n  @ViewChild('verticalstackedcontainer', { static: true })\r\n  verticalstackedcontainerElt!: 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    MIN_MOBILE_BAR_WIDTH: 32,\r\n    DESKTOP_MIN_BAR_WIDTH: 40,\r\n    MOBILE_BAR_PADDING: 12,\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  ngOnInit() {}\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 getDeviceConfig(): DeviceConfig {\r\n    const width = window.innerWidth;\r\n    return {\r\n      isMobile: width < 576,\r\n      isTablet: width >= 576 && width < 992,\r\n      isDesktop: width >= 992,\r\n    };\r\n  }\r\n\r\n  private configureResponsiveSettings(device: DeviceConfig) {\r\n    if (device.isMobile) {\r\n      this.chartConfiguration.margin = { top: 20, right: 10, bottom: 40, left: 30 };\r\n      this.chartConfiguration.numberOfYTicks = 4;\r\n      this.chartConfiguration.svgHeight = 60;\r\n    } else if (device.isTablet) {\r\n      this.chartConfiguration.margin = { top: 25, right: 20, bottom: 45, left: 40 };\r\n      this.chartConfiguration.numberOfYTicks = 6;\r\n      this.chartConfiguration.svgHeight = 70;\r\n    } else {\r\n      this.chartConfiguration.margin = { top: 30, right: 30, bottom: 50, left: 60 };\r\n      this.chartConfiguration.numberOfYTicks = 7;\r\n      this.chartConfiguration.svgHeight = 80;\r\n    }\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\n  private calculateDimensions(\r\n    chartContainer: any,\r\n    verticalContainer: any,\r\n    margin: any,\r\n    device: DeviceConfig,\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    let width = containerWidth - margin.left - margin.right;\r\n    let height = containerHeight * (this.chartConfiguration.svgHeight / 100) - margin.top - margin.bottom;\r\n\r\n    // Handle zoom out scenario\r\n    if (dataLength > this.CONSTANTS.ZOOM_THRESHOLD && this.isZoomedOut) {\r\n      const minWidth = dataLength * (device.isMobile ? 15 : 25);\r\n      width = Math.max(width, minWidth);\r\n    }\r\n\r\n    // Handle zoom in scenario\r\n    if (dataLength > this.CONSTANTS.ZOOM_IN_THRESHOLD && !this.isZoomedOut) {\r\n      width = dataLength * (device.isMobile ? 60 : 130);\r\n    }\r\n\r\n    // Handle full screen\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    // Handle drilldown\r\n    if (this.chartConfiguration.isDrilldownChart) {\r\n      height = containerHeight - margin.top - margin.bottom - (device.isMobile ? 60 : 130);\r\n    }\r\n\r\n    // Calculate bar dimensions\r\n    let barWidth: number;\r\n    let barPadding: number;\r\n    let requiredSvgWidth: number;\r\n\r\n    if (device.isMobile) {\r\n      barWidth = this.CONSTANTS.MIN_MOBILE_BAR_WIDTH;\r\n      barPadding = this.CONSTANTS.MOBILE_BAR_PADDING;\r\n      requiredSvgWidth = Math.max(\r\n        width - this.CONSTANTS.RIGHT_SVG_WIDTH,\r\n        (barWidth + barPadding) * dataLength + this.CONSTANTS.LEFT_RIGHT_SPACES * 2 + \r\n        this.CONSTANTS.RIGHT_SVG_WIDTH - barPadding\r\n      );\r\n    } else {\r\n      barWidth = Math.max(\r\n        this.CONSTANTS.DESKTOP_MIN_BAR_WIDTH,\r\n        (width - this.CONSTANTS.RIGHT_SVG_WIDTH - this.CONSTANTS.LEFT_RIGHT_SPACES * 2) / dataLength\r\n      );\r\n      barPadding = 0;\r\n      requiredSvgWidth = width - this.CONSTANTS.RIGHT_SVG_WIDTH;\r\n    }\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\n  private createSvgContainers(\r\n    chartContainer: any,\r\n    dimensions: Dimensions,\r\n    margin: any\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', dimensions.height)\r\n      .style('overflow-x', 'hidden')\r\n      .style('padding-left', `${margin.left}px`)\r\n      .style('margin-left', '10px')\r\n      .style('padding-right', `${this.CONSTANTS.RIGHT_SVG_WIDTH}px`);\r\n\r\n    const svgYAxisLeft = outerContainer\r\n      .append('svg')\r\n      .attr('width', '80')\r\n      .attr('height', dimensions.height + margin.top + margin.bottom)\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 + 10},${margin.top})`);\r\n\r\n    const svgYAxisRight = outerContainer\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      .style('position', 'absolute')\r\n      .style('right', '2px')\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.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    return { svg, svgYAxisLeft, svgYAxisRight, innerContainer };\r\n  }\r\n\r\n  private createScales(\r\n    data: any[],\r\n    layers: any[],\r\n    lineData: any[],\r\n    dimensions: Dimensions,\r\n    device: DeviceConfig\r\n  ) {\r\n    const { width, height, barWidth, barPadding } = dimensions;\r\n    \r\n    const xScale = d3\r\n      .scaleBand()\r\n      .rangeRound([\r\n        this.CONSTANTS.LEFT_RIGHT_SPACES,\r\n        width - this.CONSTANTS.RIGHT_SVG_WIDTH - this.CONSTANTS.LEFT_RIGHT_SPACES\r\n      ])\r\n      .domain(data.map(d => d.name).reverse())\r\n      .padding(device.isMobile ? 0.2 : 0.5);\r\n\r\n    const xScaleFromOrigin = d3\r\n      .scaleBand()\r\n      .rangeRound([width - this.CONSTANTS.RIGHT_SVG_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  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    device: DeviceConfig\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, device);\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    device: DeviceConfig\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, i: number) => {\r\n        if (device.isMobile) {\r\n          return this.CONSTANTS.LEFT_RIGHT_SPACES + i * (barWidth + barPadding);\r\n        }\r\n        if (!this.chartConfiguration.isMultiChartGridLine) {\r\n          return xScale(d.data.name);\r\n        }\r\n        if (this.chartConfiguration.isDrilldownChart && this.chartData.data.length <= 3) {\r\n          return xScale(d.data.name) + xScale.bandwidth() / 2 - 35;\r\n        }\r\n        return xScale(d.data.name) + xScale.bandwidth() * 0.1;\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 (device.isMobile) return barWidth;\r\n        if (!this.chartConfiguration.isMultiChartGridLine) return xScale.bandwidth();\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 width = /week/i.test(d.data.name) && /\\d{4}-\\d{2}-\\d{2}/.test(d.data.name)\r\n      ? '250px'\r\n      : xScale.bandwidth() + this.CONSTANTS.LEFT_RIGHT_SPACES * 2 > 180\r\n        ? '180px'\r\n        : xScale.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    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(svg, metaData.xLabel, dimensions.width, dimensions.height, margin);\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\n  private addXAxisLabel(svg: any, label: string, width: number, height: number, margin: any) {\r\n    const isria = this.customChartConfiguration?.isRia;\r\n    const isAcronym = this.isAcronymLabel(label);\r\n    const xPosition = isria \r\n      ? height + margin.top + margin.bottom \r\n      : height + margin.top + margin.bottom + 10;\r\n\r\n    svg\r\n      .append('text')\r\n      .attr('class', this.getXAxisLabelClass())\r\n      .attr('style', this.chartConfiguration.xAxisCustomlabelStyles)\r\n      .attr('transform', `translate(${width / 2},${xPosition})`)\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\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 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    const device = this.getDeviceConfig();\r\n    this.configureResponsiveSettings(device);\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.verticalstackedcontainerElt.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      device,\r\n      data.length\r\n    );\r\n\r\n    const { svg, svgYAxisLeft, svgYAxisRight } = this.createSvgContainers(\r\n      chartContainer,\r\n      dimensions,\r\n      margin\r\n    );\r\n\r\n    // Create stack and layers\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, device);\r\n    const axes = this.createAxes(scales);\r\n\r\n    // Render chart elements\r\n    this.renderGrids(svg, scales, dimensions);\r\n    const rect = this.renderBars(svg, layers, scales, metaData, dimensions, device);\r\n    this.renderAxes(svg, svgYAxisLeft, svgYAxisRight, axes, scales, dimensions, device, data);\r\n    this.renderAxisLabels(svg, svgYAxisLeft, 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\n  private 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')\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.yAxisGrid) {\r\n      svg\r\n        .append('g')\r\n        .attr('class', 'grid')\r\n        .call(\r\n          d3\r\n            .axisLeft(scales.yScale)\r\n            .ticks(this.chartConfiguration.numberOfYTicks)\r\n            .tickSize(-dimensions.width)\r\n            .tickFormat('')\r\n        )\r\n        .style('color', 'var(--chart-grid-color)')\r\n        .style('opacity', '1');\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  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    device: DeviceConfig,\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, device, 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\n  private renderStandardAxes(\r\n    svg: any,\r\n    axes: any,\r\n    scales: any,\r\n    dimensions: Dimensions,\r\n    device: DeviceConfig,\r\n    data: any[]\r\n  ) {\r\n    if (device.isMobile) {\r\n      this.renderMobileXAxis(svg, data, dimensions);\r\n    } else {\r\n      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        .selectAll('text')\r\n        .style('fill', 'var(--chart-text-color)')\r\n        .style('font-size', '12px')\r\n        .attr('text-anchor', 'middle')\r\n        .attr('dx', '0')\r\n        .attr('dy', '0.71em')\r\n        .attr('transform', null);\r\n    }\r\n\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 renderMobileXAxis(svg: any, data: any[], dimensions: Dimensions) {\r\n    svg.selectAll('.custom-x-label').remove();\r\n    data.forEach((d, i) => {\r\n      const xVal = this.CONSTANTS.LEFT_RIGHT_SPACES + \r\n                   i * (dimensions.barWidth + dimensions.barPadding) + \r\n                   dimensions.barWidth / 2;\r\n      svg\r\n        .append('text')\r\n        .attr('class', 'custom-x-label')\r\n        .attr('x', 0)\r\n        .attr('y', dimensions.height + 18)\r\n        .attr('text-anchor', 'middle')\r\n        .attr('transform', `translate(${xVal + 20},0)`)\r\n        .style('font-size', '10px')\r\n        .style('fill', 'var(--chart-text-color)')\r\n        .style('writing-mode', 'sideways-lr')\r\n        .text(d.name.substring(0, 3));\r\n    });\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    const device = this.getDeviceConfig();\r\n    \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, device);\r\n\r\n    if (this.chartConfiguration.xLabelsOnSameLine) {\r\n      this.applyXLabelsOnSameLine(svg, device);\r\n    }\r\n  }\r\n\r\n  private styleCustomXAxisTicks(svg: any, data: any[], device: DeviceConfig) {\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, device: DeviceConfig) {\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        if (device.isMobile) {\r\n          return d.split(' ')[0].substring(0, 3);\r\n        }\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      .attr('transform', function(this: SVGTextElement, d: string, i: number) {\r\n        if (device.isMobile) {\r\n          const parent = this.parentNode?.parentNode as any;\r\n          const totalBars = parent ? d3.select(parent).selectAll('g.tick').size() : 0;\r\n          return totalBars === 2 ? 'translate(0,0)' : `translate(${i * 30},0)`;\r\n        }\r\n        return null;\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        if (device.isMobile) return '';\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      .attr('transform', (d: string, i: number) => {\r\n        return device.isMobile && i === 0 ? 'translate(20,0)' : null;\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}","<meta http-equiv=\"CACHE-CONTROL\" content=\"NO-CACHE\" />\r\n<meta http-equiv=\"EXPIRES\" content=\"Sat, 01 Jun 2004 11:12:01 GMT\" />\r\n<div\r\n  #verticalstackedcontainer\r\n  class=\"lib-chart-wrapper\"\r\n  [ngClass]=\"{ 'lib-no-background': isTransparentBackground }\"\r\n    style=\"background-color: var(--card-bg);\"\r\n\r\n  (resized)=\"onResized($event)\"\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\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  <div\r\n    [style.height]=\"chartConfiguration.svgHeight\"\r\n    id=\"verticalstackedchartcontainer\"\r\n    #verticalstackedchartcontainer\r\n    class=\"lib-chart-svg\"\r\n  ></div>\r\n</div>\r\n"]}