axidio-styleguide-library1-v2 0.2.43 → 0.2.45

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.
@@ -27,17 +27,11 @@ export class HorizontalBarsWithScrollZoomComponent extends ComponentUniqueId {
27
27
  LONG_TICK_LENGTH: 16,
28
28
  SHORT_TICK_LENGTH_BG: 5,
29
29
  LONG_TICK_LENGTH_BG: 30,
30
- // Mobile settings - larger bars with good spacing
31
- MIN_MOBILE_BAR_WIDTH: 35,
32
- MOBILE_BAR_PADDING: 15,
33
- MOBILE_BAR_SPACING: 0.4, // 40% spacing between bars
34
- // Tablet settings - balanced approach
35
- TABLET_MIN_BAR_WIDTH: 45,
36
- TABLET_BAR_PADDING: 18,
37
- TABLET_BAR_SPACING: 0.35, // 35% spacing between bars
38
- // Desktop settings
39
- DESKTOP_MIN_BAR_WIDTH: 50,
40
- DESKTOP_BAR_SPACING: 0.3, // 30% spacing between bars
30
+ MIN_MOBILE_BAR_WIDTH: 35, // Increased from 28
31
+ DESKTOP_MIN_BAR_WIDTH: 40,
32
+ TABLET_MIN_BAR_WIDTH: 30, // Reduced from 35
33
+ MOBILE_BAR_PADDING: 8, // Reduced from 10
34
+ TABLET_BAR_PADDING: 6, // Reduced from 8
41
35
  ZOOM_THRESHOLD: 30,
42
36
  ZOOM_IN_THRESHOLD: 8,
43
37
  };
@@ -105,36 +99,37 @@ export class HorizontalBarsWithScrollZoomComponent extends ComponentUniqueId {
105
99
  getDeviceConfig() {
106
100
  const width = window.innerWidth;
107
101
  return {
108
- isMobile: width < 768,
109
- isTablet: width >= 768 && width < 1024,
110
- isDesktop: width >= 1024,
102
+ isMobile: width < 768, // Changed from 576 to 768 for better mobile coverage
103
+ isTablet: width >= 768 && width < 1024, // Changed from 576-992 to 768-1024
104
+ isDesktop: width >= 1024, // Changed from 992 to 1024
111
105
  };
112
106
  }
113
107
  configureResponsiveSettings(device) {
114
108
  if (device.isMobile) {
115
- this.chartConfiguration.margin = { top: 20, right: 10, bottom: 50, left: 30 };
109
+ this.chartConfiguration.margin = { top: 15, right: 5, bottom: 45, left: 25 }; // Increased bottom
116
110
  this.chartConfiguration.numberOfYTicks = 4;
117
- this.chartConfiguration.svgHeight = 60;
111
+ this.chartConfiguration.svgHeight = 55;
118
112
  }
119
113
  else if (device.isTablet) {
120
- this.chartConfiguration.margin = { top: 25, right: 20, bottom: 55, left: 45 };
114
+ this.chartConfiguration.margin = { top: 20, right: 15, bottom: 50, left: 35 }; // Increased bottom
121
115
  this.chartConfiguration.numberOfYTicks = 5;
122
- this.chartConfiguration.svgHeight = 70;
116
+ this.chartConfiguration.svgHeight = 65;
123
117
  }
124
118
  else {
119
+ // Desktop/Large screens
125
120
  const width = window.innerWidth;
126
121
  if (width >= 1920) {
127
- this.chartConfiguration.margin = { top: 35, right: 35, bottom: 60, left: 70 };
122
+ this.chartConfiguration.margin = { top: 35, right: 35, bottom: 55, left: 70 };
128
123
  this.chartConfiguration.numberOfYTicks = 8;
129
124
  this.chartConfiguration.svgHeight = 85;
130
125
  }
131
126
  else if (width >= 1366) {
132
- this.chartConfiguration.margin = { top: 30, right: 30, bottom: 55, left: 60 };
127
+ this.chartConfiguration.margin = { top: 30, right: 30, bottom: 50, left: 60 };
133
128
  this.chartConfiguration.numberOfYTicks = 7;
134
129
  this.chartConfiguration.svgHeight = 80;
135
130
  }
136
131
  else {
137
- this.chartConfiguration.margin = { top: 25, right: 25, bottom: 50, left: 50 };
132
+ this.chartConfiguration.margin = { top: 25, right: 25, bottom: 45, left: 50 };
138
133
  this.chartConfiguration.numberOfYTicks = 6;
139
134
  this.chartConfiguration.svgHeight = 75;
140
135
  }
@@ -163,33 +158,20 @@ export class HorizontalBarsWithScrollZoomComponent extends ComponentUniqueId {
163
158
  const containerHeight = verticalContainer.node().getBoundingClientRect().height;
164
159
  let width = containerWidth - margin.left - margin.right;
165
160
  let height = containerHeight * (this.chartConfiguration.svgHeight / 100) - margin.top - margin.bottom;
166
- // Calculate minimum width based on device and data length
167
- if (device.isMobile) {
168
- const minBarWidth = this.CONSTANTS.MIN_MOBILE_BAR_WIDTH;
169
- const minPadding = this.CONSTANTS.MOBILE_BAR_PADDING;
170
- const minWidthNeeded = (minBarWidth + minPadding) * dataLength + this.CONSTANTS.LEFT_RIGHT_SPACES * 2;
171
- width = Math.max(width, minWidthNeeded);
172
- }
173
- else if (device.isTablet) {
174
- const minBarWidth = this.CONSTANTS.TABLET_MIN_BAR_WIDTH;
175
- const minPadding = this.CONSTANTS.TABLET_BAR_PADDING;
176
- const minWidthNeeded = (minBarWidth + minPadding) * dataLength + this.CONSTANTS.LEFT_RIGHT_SPACES * 2;
177
- width = Math.max(width, minWidthNeeded);
178
- }
179
- // Zoom handling with proper spacing
161
+ // Responsive zoom handling
180
162
  if (dataLength > this.CONSTANTS.ZOOM_THRESHOLD && this.isZoomedOut) {
181
163
  const minWidth = device.isMobile
182
- ? dataLength * 15
164
+ ? dataLength * 15 // Increased from 12
183
165
  : device.isTablet
184
- ? dataLength * 25
185
- : dataLength * 30;
166
+ ? dataLength * 22 // Increased from 20
167
+ : dataLength * 25;
186
168
  width = Math.max(width, minWidth);
187
169
  }
188
170
  if (dataLength > this.CONSTANTS.ZOOM_IN_THRESHOLD && !this.isZoomedOut) {
189
171
  width = device.isMobile
190
- ? dataLength * 60
172
+ ? dataLength * 55 // Increased from 50
191
173
  : device.isTablet
192
- ? dataLength * 100
174
+ ? dataLength * 80 // Reduced from 90
193
175
  : dataLength * 130;
194
176
  }
195
177
  if (this.chartConfiguration.isFullScreen) {
@@ -198,7 +180,7 @@ export class HorizontalBarsWithScrollZoomComponent extends ComponentUniqueId {
198
180
  : containerHeight;
199
181
  }
200
182
  if (this.chartConfiguration.isDrilldownChart) {
201
- const offset = device.isMobile ? 70 : device.isTablet ? 100 : 130;
183
+ const offset = device.isMobile ? 70 : device.isTablet ? 80 : 130;
202
184
  height = containerHeight - margin.top - margin.bottom - offset;
203
185
  }
204
186
  let barWidth;
@@ -207,21 +189,17 @@ export class HorizontalBarsWithScrollZoomComponent extends ComponentUniqueId {
207
189
  if (device.isMobile) {
208
190
  barWidth = this.CONSTANTS.MIN_MOBILE_BAR_WIDTH;
209
191
  barPadding = this.CONSTANTS.MOBILE_BAR_PADDING;
210
- // Calculate total width with proper spacing
211
- const totalBarSpace = (barWidth + barPadding) * dataLength;
212
- requiredSvgWidth = Math.max(width - this.CONSTANTS.RIGHT_SVG_WIDTH, totalBarSpace + this.CONSTANTS.LEFT_RIGHT_SPACES * 2);
192
+ requiredSvgWidth = Math.max(width - this.CONSTANTS.RIGHT_SVG_WIDTH, (barWidth + barPadding) * dataLength + this.CONSTANTS.LEFT_RIGHT_SPACES * 2 +
193
+ this.CONSTANTS.RIGHT_SVG_WIDTH - barPadding);
213
194
  }
214
195
  else if (device.isTablet) {
215
196
  barWidth = this.CONSTANTS.TABLET_MIN_BAR_WIDTH;
216
197
  barPadding = this.CONSTANTS.TABLET_BAR_PADDING;
217
- const totalBarSpace = (barWidth + barPadding) * dataLength;
218
- requiredSvgWidth = Math.max(width - this.CONSTANTS.RIGHT_SVG_WIDTH, totalBarSpace + this.CONSTANTS.LEFT_RIGHT_SPACES * 2);
198
+ requiredSvgWidth = Math.max(width - this.CONSTANTS.RIGHT_SVG_WIDTH, (barWidth + barPadding) * dataLength + this.CONSTANTS.LEFT_RIGHT_SPACES * 2 +
199
+ this.CONSTANTS.RIGHT_SVG_WIDTH);
219
200
  }
220
201
  else {
221
- // Desktop: calculate dynamically but ensure minimum width
222
- const availableWidth = width - this.CONSTANTS.RIGHT_SVG_WIDTH - this.CONSTANTS.LEFT_RIGHT_SPACES * 2;
223
- barWidth = Math.max(this.CONSTANTS.DESKTOP_MIN_BAR_WIDTH, availableWidth / (dataLength * 1.3) // 1.3 factor accounts for spacing
224
- );
202
+ barWidth = Math.max(this.CONSTANTS.DESKTOP_MIN_BAR_WIDTH, (width - this.CONSTANTS.RIGHT_SVG_WIDTH - this.CONSTANTS.LEFT_RIGHT_SPACES * 2) / dataLength);
225
203
  barPadding = 0;
226
204
  requiredSvgWidth = width - this.CONSTANTS.RIGHT_SVG_WIDTH;
227
205
  }
@@ -278,18 +256,9 @@ export class HorizontalBarsWithScrollZoomComponent extends ComponentUniqueId {
278
256
  return { svg, svgYAxisLeft, svgYAxisRight, innerContainer };
279
257
  }
280
258
  createScales(data, layers, lineData, dimensions, device) {
281
- const { width, height } = dimensions;
282
- // Device-specific padding for proper spacing
283
- let padding;
284
- if (device.isMobile) {
285
- padding = this.CONSTANTS.MOBILE_BAR_SPACING;
286
- }
287
- else if (device.isTablet) {
288
- padding = this.CONSTANTS.TABLET_BAR_SPACING;
289
- }
290
- else {
291
- padding = this.CONSTANTS.DESKTOP_BAR_SPACING;
292
- }
259
+ const { width, height, barWidth, barPadding } = dimensions;
260
+ // Adjust padding based on device
261
+ const padding = device.isMobile ? 0.15 : device.isTablet ? 0.3 : 0.5;
293
262
  const xScale = d3
294
263
  .scaleBand()
295
264
  .rangeRound([
@@ -297,8 +266,7 @@ export class HorizontalBarsWithScrollZoomComponent extends ComponentUniqueId {
297
266
  width - this.CONSTANTS.RIGHT_SVG_WIDTH - this.CONSTANTS.LEFT_RIGHT_SPACES
298
267
  ])
299
268
  .domain(data.map(d => d.name).reverse())
300
- .padding(padding)
301
- .paddingOuter(0.2); // Extra padding on the outer edges
269
+ .padding(padding);
302
270
  const xScaleFromOrigin = d3
303
271
  .scaleBand()
304
272
  .rangeRound([width - this.CONSTANTS.RIGHT_SVG_WIDTH, 0])
@@ -384,10 +352,9 @@ export class HorizontalBarsWithScrollZoomComponent extends ComponentUniqueId {
384
352
  })
385
353
  .attr('x', (d, i) => {
386
354
  if (device.isMobile || device.isTablet) {
387
- // For mobile and tablet: use manual positioning with exact spacing
355
+ // Use consistent positioning for mobile and tablet
388
356
  return this.CONSTANTS.LEFT_RIGHT_SPACES + i * (barWidth + barPadding);
389
357
  }
390
- // For desktop: use D3's scaleBand positioning
391
358
  if (!this.chartConfiguration.isMultiChartGridLine) {
392
359
  return xScale(d.data.name);
393
360
  }
@@ -404,14 +371,10 @@ export class HorizontalBarsWithScrollZoomComponent extends ComponentUniqueId {
404
371
  return 0;
405
372
  })
406
373
  .attr('width', (d) => {
407
- if (device.isMobile || device.isTablet) {
408
- // Fixed width for mobile/tablet
374
+ if (device.isMobile || device.isTablet)
409
375
  return barWidth;
410
- }
411
- // Dynamic width for desktop
412
- if (!this.chartConfiguration.isMultiChartGridLine) {
376
+ if (!this.chartConfiguration.isMultiChartGridLine)
413
377
  return xScale.bandwidth();
414
- }
415
378
  if (this.chartConfiguration.isDrilldownChart && this.chartData.data.length <= 3) {
416
379
  return 70;
417
380
  }
@@ -468,16 +431,14 @@ export class HorizontalBarsWithScrollZoomComponent extends ComponentUniqueId {
468
431
  if (isNaN(value))
469
432
  return;
470
433
  const device = this.getDeviceConfig();
471
- const bandwidth = device.isMobile || device.isTablet
472
- ? this.CONSTANTS.MIN_MOBILE_BAR_WIDTH
473
- : xScale.bandwidth();
474
- // Responsive tooltip width with better sizing
434
+ const bandwidth = xScale.bandwidth();
435
+ // Responsive tooltip width
475
436
  let width;
476
437
  if (device.isMobile) {
477
- width = Math.min(120, bandwidth * 2);
438
+ width = Math.min(bandwidth + 40, 150);
478
439
  }
479
440
  else if (device.isTablet) {
480
- width = Math.min(160, bandwidth * 1.8);
441
+ width = Math.min(bandwidth + 60, 200);
481
442
  }
482
443
  else {
483
444
  width = /week/i.test(d.data.name) && /\d{4}-\d{2}-\d{2}/.test(d.data.name)
@@ -486,16 +447,9 @@ export class HorizontalBarsWithScrollZoomComponent extends ComponentUniqueId {
486
447
  ? '180px'
487
448
  : bandwidth + this.CONSTANTS.LEFT_RIGHT_SPACES * 2;
488
449
  }
489
- const xPosition = device.isMobile || device.isTablet
490
- ? this.CONSTANTS.LEFT_RIGHT_SPACES +
491
- scales.xScale.domain().reverse().indexOf(d.data.name) *
492
- (this.CONSTANTS.MIN_MOBILE_BAR_WIDTH + this.CONSTANTS.MOBILE_BAR_PADDING) +
493
- this.CONSTANTS.MIN_MOBILE_BAR_WIDTH / 2 -
494
- (typeof width === 'number' ? width : parseInt(width)) / 2
495
- : this.calculateTooltipX(d, xScale, width);
496
450
  svg
497
451
  .append('foreignObject')
498
- .attr('x', xPosition)
452
+ .attr('x', this.calculateTooltipX(d, xScale, width))
499
453
  .attr('class', 'lib-verticalstack-title-ontop')
500
454
  .attr('y', yScale(d[1]) - 51)
501
455
  .attr('width', width)
@@ -694,12 +648,30 @@ export class HorizontalBarsWithScrollZoomComponent extends ComponentUniqueId {
694
648
  this.applyAxisConfigurations(svg, scales, dimensions, data);
695
649
  }
696
650
  renderStandardAxes(svg, axes, scales, dimensions, device, data) {
697
- if (device.isMobile || device.isTablet) {
698
- // Use custom rendering for mobile and tablet
699
- this.renderMobileXAxis(svg, data, dimensions, device);
651
+ if (device.isMobile) {
652
+ this.renderMobileXAxis(svg, data, dimensions);
653
+ }
654
+ else if (device.isTablet) {
655
+ // Tablet: Render with rotation
656
+ svg
657
+ .append('g')
658
+ .attr('transform', `translate(0,${dimensions.height})`)
659
+ .attr('class', 'lib-stacked-x-axis-text')
660
+ .call(axes.xAxis)
661
+ .selectAll('text')
662
+ .style('fill', 'var(--chart-text-color)')
663
+ .style('font-size', '10px')
664
+ .attr('text-anchor', 'end')
665
+ .attr('dx', '-.8em')
666
+ .attr('dy', '.15em')
667
+ .attr('transform', 'rotate(-45)')
668
+ .text((d) => {
669
+ // Truncate long labels for tablet
670
+ return d.length > 12 ? d.substring(0, 10) + '...' : d;
671
+ });
700
672
  }
701
673
  else {
702
- // Standard desktop rendering
674
+ // Desktop: Standard horizontal labels
703
675
  svg
704
676
  .append('g')
705
677
  .attr('transform', `translate(0,${dimensions.height})`)
@@ -713,7 +685,6 @@ export class HorizontalBarsWithScrollZoomComponent extends ComponentUniqueId {
713
685
  .attr('dy', '0.71em')
714
686
  .attr('transform', null);
715
687
  }
716
- // Y-axis remains the same for all devices
717
688
  svg
718
689
  .append('g')
719
690
  .attr('class', 'lib-stacked-y-axis-text')
@@ -722,48 +693,44 @@ export class HorizontalBarsWithScrollZoomComponent extends ComponentUniqueId {
722
693
  .selectAll('text')
723
694
  .style('fill', 'var(--chart-text-color)');
724
695
  }
725
- renderMobileXAxis(svg, data, dimensions, device) {
696
+ renderMobileXAxis(svg, data, dimensions) {
726
697
  svg.selectAll('.custom-x-label').remove();
727
- const { barWidth, barPadding } = dimensions;
728
- const maxLabelLength = Math.max(...data.map(d => d.name.length));
729
- // Determine if we need to rotate labels
730
- const shouldRotate = data.length > 6 || maxLabelLength > 8;
698
+ // Adaptive font size based on label length
699
+ const maxLength = Math.max(...data.map(d => d.name.length));
700
+ let fontSize = '9px';
701
+ if (maxLength > 15)
702
+ fontSize = '7px';
703
+ else if (maxLength > 10)
704
+ fontSize = '8px';
731
705
  data.forEach((d, i) => {
732
- const xPosition = this.CONSTANTS.LEFT_RIGHT_SPACES +
733
- i * (barWidth + barPadding) +
734
- barWidth / 2;
735
- const label = svg
706
+ const xVal = this.CONSTANTS.LEFT_RIGHT_SPACES +
707
+ i * (dimensions.barWidth + dimensions.barPadding) +
708
+ dimensions.barWidth / 2;
709
+ // Truncate labels intelligently for mobile
710
+ let labelText = d.name;
711
+ if (labelText.length > 8) {
712
+ // Try to truncate at word boundary
713
+ const words = labelText.split(' ');
714
+ if (words.length > 1) {
715
+ labelText = words[0].substring(0, 4) + '...';
716
+ }
717
+ else {
718
+ labelText = labelText.substring(0, 6) + '...';
719
+ }
720
+ }
721
+ svg
736
722
  .append('text')
737
723
  .attr('class', 'custom-x-label')
738
- .attr('x', xPosition)
739
- .attr('y', dimensions.height + (shouldRotate ? 12 : 20))
740
- .attr('text-anchor', shouldRotate ? 'end' : 'middle')
741
- .style('font-size', device.isMobile ? '9px' : '10px')
724
+ .attr('x', 0)
725
+ .attr('y', dimensions.height + 15) // Adjusted positioning
726
+ .attr('text-anchor', 'middle')
727
+ .attr('transform', `translate(${xVal + 15},0)`)
728
+ .style('font-size', fontSize)
742
729
  .style('fill', 'var(--chart-text-color)')
743
- .text(this.formatXAxisLabel(d.name, device));
744
- if (shouldRotate) {
745
- label
746
- .attr('transform', `rotate(-45, ${xPosition}, ${dimensions.height + 12})`)
747
- .attr('dx', '-0.5em');
748
- }
730
+ .style('writing-mode', 'sideways-lr')
731
+ .text(labelText);
749
732
  });
750
733
  }
751
- formatXAxisLabel(label, device) {
752
- if (device.isMobile) {
753
- // Mobile: truncate longer labels
754
- if (label.length > 8) {
755
- return label.substring(0, 6) + '...';
756
- }
757
- return label;
758
- }
759
- else {
760
- // Tablet: slightly longer labels allowed
761
- if (label.length > 12) {
762
- return label.substring(0, 10) + '...';
763
- }
764
- return label;
765
- }
766
- }
767
734
  renderDrilldownAxes(svg, svgYAxisLeft, svgYAxisRight, axes, scales, dimensions) {
768
735
  svg
769
736
  .append('g')
@@ -1140,4 +1107,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
1140
1107
  }], headerMenuclickEvent: [{
1141
1108
  type: Output
1142
1109
  }] } });
1143
- //# 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 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\nprivate 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  \r\n  // Mobile settings - larger bars with good spacing\r\n  MIN_MOBILE_BAR_WIDTH: 35,\r\n  MOBILE_BAR_PADDING: 15,\r\n  MOBILE_BAR_SPACING: 0.4,  // 40% spacing between bars\r\n  \r\n  // Tablet settings - balanced approach\r\n  TABLET_MIN_BAR_WIDTH: 45,\r\n  TABLET_BAR_PADDING: 18,\r\n  TABLET_BAR_SPACING: 0.35,  // 35% spacing between bars\r\n  \r\n  // Desktop settings\r\n  DESKTOP_MIN_BAR_WIDTH: 50,\r\n  DESKTOP_BAR_SPACING: 0.3,  // 30% spacing between bars\r\n  \r\n  ZOOM_THRESHOLD: 30,\r\n  ZOOM_IN_THRESHOLD: 8,\r\n};\r\n\r\n  defaultConfiguration = {\r\n    margin: { top: 20, right: 20, bottom: 20, left: 40 },\r\n    svgHeight: 70,\r\n    legendHeight: '10%',\r\n    numberOfYTicks: 5,\r\n    labelFormatter: ChartHelper.defaultFormatter,\r\n    xAxisLabelFomatter: ChartHelper.defaultFormatter,\r\n    yAxisLabelFomatter: ChartHelper.defaultFormatter,\r\n    yLineAxisLabelFomatter: ChartHelper.defaultFormatter,\r\n    lineGraphColor: '#F6D283',\r\n    showLineChartAxis: true,\r\n    showLegend: false,\r\n    forComparison: true,\r\n    headerMenuOptions: HeaderConfigHelper.headerConfig.headerMenuOptions,\r\n    yAxisGrid: false,\r\n    // Optional configs with undefined defaults\r\n    isHeaderVisible: undefined,\r\n    isTransparentBackground: undefined,\r\n    isTopCaptionVisible: undefined,\r\n    isMultiChartGridLine: undefined,\r\n    isFullScreen: undefined,\r\n    customYscale: undefined,\r\n    isXaxisLabelHidden: undefined,\r\n    isYaxisLabelHidden: undefined,\r\n    isYaxisHidden: undefined,\r\n    isYaxisDashed: undefined,\r\n    isXaxisColor: undefined,\r\n    textFormatter: undefined,\r\n    showTotalOnTop: undefined,\r\n    backendFormatterHasPriority: undefined,\r\n    showAngledLabels: undefined,\r\n    isNoAlternateXaxisText: undefined,\r\n    isXgridBetweenLabels: undefined,\r\n    showXaxisTop: undefined,\r\n    xAxisGrid: undefined,\r\n    xLabelsOnSameLine: undefined,\r\n    hideXaxisTick: undefined,\r\n    isDrilldownChart: undefined,\r\n    isTargetLine: undefined,\r\n    displayTitleOnTop: undefined,\r\n    isToggleVisible: undefined,\r\n    isTitleHidden: undefined,\r\n  };\r\n\r\n  constructor() {\r\n    super();\r\n  }\r\n\r\n  ngOnChanges() {\r\n    this.removeExistingChart();\r\n    this.initializeStackedChart();\r\n  }\r\n\r\n  onResized(event: ResizedEvent) {\r\n    setTimeout(() => {\r\n      this.removeExistingChart();\r\n      this.initializeStackedChart();\r\n    }, 10);\r\n  }\r\n\r\n  isZoomOutSelected(isZoomOut: boolean) {\r\n    this.isZoomedOut = isZoomOut;\r\n    this.ngOnChanges();\r\n  }\r\n\r\n  private removeExistingChart() {\r\n    d3.select('#' + this.uniqueId).remove();\r\n  }\r\n\r\n  private getDeviceConfig(): DeviceConfig {\r\n    const width = window.innerWidth;\r\n    return {\r\n      isMobile: width < 768,\r\n      isTablet: width >= 768 && width < 1024,\r\n      isDesktop: width >= 1024,\r\n    };\r\n  }\r\n\r\nprivate configureResponsiveSettings(device: DeviceConfig) {\r\n  if (device.isMobile) {\r\n    this.chartConfiguration.margin = { top: 20, right: 10, bottom: 50, 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: 55, left: 45 };\r\n    this.chartConfiguration.numberOfYTicks = 5;\r\n    this.chartConfiguration.svgHeight = 70;\r\n  } else {\r\n    const width = window.innerWidth;\r\n    if (width >= 1920) {\r\n      this.chartConfiguration.margin = { top: 35, right: 35, bottom: 60, left: 70 };\r\n      this.chartConfiguration.numberOfYTicks = 8;\r\n      this.chartConfiguration.svgHeight = 85;\r\n    } else if (width >= 1366) {\r\n      this.chartConfiguration.margin = { top: 30, right: 30, bottom: 55, left: 60 };\r\n      this.chartConfiguration.numberOfYTicks = 7;\r\n      this.chartConfiguration.svgHeight = 80;\r\n    } else {\r\n      this.chartConfiguration.margin = { top: 25, right: 25, bottom: 50, left: 50 };\r\n      this.chartConfiguration.numberOfYTicks = 6;\r\n      this.chartConfiguration.svgHeight = 75;\r\n    }\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\nprivate 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  // Calculate minimum width based on device and data length\r\n  if (device.isMobile) {\r\n    const minBarWidth = this.CONSTANTS.MIN_MOBILE_BAR_WIDTH;\r\n    const minPadding = this.CONSTANTS.MOBILE_BAR_PADDING;\r\n    const minWidthNeeded = (minBarWidth + minPadding) * dataLength + this.CONSTANTS.LEFT_RIGHT_SPACES * 2;\r\n    width = Math.max(width, minWidthNeeded);\r\n  } else if (device.isTablet) {\r\n    const minBarWidth = this.CONSTANTS.TABLET_MIN_BAR_WIDTH;\r\n    const minPadding = this.CONSTANTS.TABLET_BAR_PADDING;\r\n    const minWidthNeeded = (minBarWidth + minPadding) * dataLength + this.CONSTANTS.LEFT_RIGHT_SPACES * 2;\r\n    width = Math.max(width, minWidthNeeded);\r\n  }\r\n\r\n  // Zoom handling with proper spacing\r\n  if (dataLength > this.CONSTANTS.ZOOM_THRESHOLD && this.isZoomedOut) {\r\n    const minWidth = device.isMobile \r\n      ? dataLength * 15\r\n      : device.isTablet \r\n        ? dataLength * 25\r\n        : dataLength * 30;\r\n    width = Math.max(width, minWidth);\r\n  }\r\n\r\n  if (dataLength > this.CONSTANTS.ZOOM_IN_THRESHOLD && !this.isZoomedOut) {\r\n    width = device.isMobile \r\n      ? dataLength * 60\r\n      : device.isTablet \r\n        ? dataLength * 100\r\n        : dataLength * 130;\r\n  }\r\n\r\n  if (this.chartConfiguration.isFullScreen) {\r\n    height = this.chartConfiguration.svgHeight !== 80\r\n      ? this.chartConfiguration.svgHeight\r\n      : containerHeight;\r\n  }\r\n\r\n  if (this.chartConfiguration.isDrilldownChart) {\r\n    const offset = device.isMobile ? 70 : device.isTablet ? 100 : 130;\r\n    height = containerHeight - margin.top - margin.bottom - offset;\r\n  }\r\n\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    // Calculate total width with proper spacing\r\n    const totalBarSpace = (barWidth + barPadding) * dataLength;\r\n    requiredSvgWidth = Math.max(\r\n      width - this.CONSTANTS.RIGHT_SVG_WIDTH,\r\n      totalBarSpace + this.CONSTANTS.LEFT_RIGHT_SPACES * 2\r\n    );\r\n  } else if (device.isTablet) {\r\n    barWidth = this.CONSTANTS.TABLET_MIN_BAR_WIDTH;\r\n    barPadding = this.CONSTANTS.TABLET_BAR_PADDING;\r\n    const totalBarSpace = (barWidth + barPadding) * dataLength;\r\n    requiredSvgWidth = Math.max(\r\n      width - this.CONSTANTS.RIGHT_SVG_WIDTH,\r\n      totalBarSpace + this.CONSTANTS.LEFT_RIGHT_SPACES * 2\r\n    );\r\n  } else {\r\n    // Desktop: calculate dynamically but ensure minimum width\r\n    const availableWidth = width - this.CONSTANTS.RIGHT_SVG_WIDTH - this.CONSTANTS.LEFT_RIGHT_SPACES * 2;\r\n    barWidth = Math.max(\r\n      this.CONSTANTS.DESKTOP_MIN_BAR_WIDTH,\r\n      availableWidth / (dataLength * 1.3)  // 1.3 factor accounts for spacing\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\nprivate 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 } = dimensions;\r\n  \r\n  // Device-specific padding for proper spacing\r\n  let padding: number;\r\n  if (device.isMobile) {\r\n    padding = this.CONSTANTS.MOBILE_BAR_SPACING;\r\n  } else if (device.isTablet) {\r\n    padding = this.CONSTANTS.TABLET_BAR_SPACING;\r\n  } else {\r\n    padding = this.CONSTANTS.DESKTOP_BAR_SPACING;\r\n  }\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(padding)\r\n    .paddingOuter(0.2);  // Extra padding on the outer edges\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\nprivate 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 || device.isTablet) {\r\n        // For mobile and tablet: use manual positioning with exact spacing\r\n        return this.CONSTANTS.LEFT_RIGHT_SPACES + i * (barWidth + barPadding);\r\n      }\r\n      // For desktop: use D3's scaleBand positioning\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 || device.isTablet) {\r\n        // Fixed width for mobile/tablet\r\n        return barWidth;\r\n      }\r\n      // Dynamic width for desktop\r\n      if (!this.chartConfiguration.isMultiChartGridLine) {\r\n        return xScale.bandwidth();\r\n      }\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\nprivate 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 device = this.getDeviceConfig();\r\n  const bandwidth = device.isMobile || device.isTablet \r\n    ? this.CONSTANTS.MIN_MOBILE_BAR_WIDTH \r\n    : xScale.bandwidth();\r\n  \r\n  // Responsive tooltip width with better sizing\r\n  let width: string | number;\r\n  if (device.isMobile) {\r\n    width = Math.min(120, bandwidth * 2);\r\n  } else if (device.isTablet) {\r\n    width = Math.min(160, bandwidth * 1.8);\r\n  } else {\r\n    width = /week/i.test(d.data.name) && /\\d{4}-\\d{2}-\\d{2}/.test(d.data.name)\r\n      ? '250px'\r\n      : bandwidth + this.CONSTANTS.LEFT_RIGHT_SPACES * 2 > 180\r\n        ? '180px'\r\n        : bandwidth + this.CONSTANTS.LEFT_RIGHT_SPACES * 2;\r\n  }\r\n\r\n  const xPosition = device.isMobile || device.isTablet\r\n    ? this.CONSTANTS.LEFT_RIGHT_SPACES + \r\n      scales.xScale.domain().reverse().indexOf(d.data.name) * \r\n      (this.CONSTANTS.MIN_MOBILE_BAR_WIDTH + this.CONSTANTS.MOBILE_BAR_PADDING) +\r\n      this.CONSTANTS.MIN_MOBILE_BAR_WIDTH / 2 -\r\n      (typeof width === 'number' ? width : parseInt(width)) / 2\r\n    : this.calculateTooltipX(d, xScale, width);\r\n\r\n  svg\r\n    .append('foreignObject')\r\n    .attr('x', xPosition)\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    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    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\nprivate 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 || device.isTablet) {\r\n    // Use custom rendering for mobile and tablet\r\n    this.renderMobileXAxis(svg, data, dimensions, device);\r\n  } else {\r\n    // Standard desktop rendering\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  // Y-axis remains the same for all devices\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\nprivate renderMobileXAxis(svg: any, data: any[], dimensions: Dimensions, device: DeviceConfig) {\r\n  svg.selectAll('.custom-x-label').remove();\r\n  \r\n  const { barWidth, barPadding } = dimensions;\r\n  const maxLabelLength = Math.max(...data.map(d => d.name.length));\r\n  \r\n  // Determine if we need to rotate labels\r\n  const shouldRotate = data.length > 6 || maxLabelLength > 8;\r\n  \r\n  data.forEach((d, i) => {\r\n    const xPosition = this.CONSTANTS.LEFT_RIGHT_SPACES + \r\n                     i * (barWidth + barPadding) + \r\n                     barWidth / 2;\r\n    \r\n    const label = svg\r\n      .append('text')\r\n      .attr('class', 'custom-x-label')\r\n      .attr('x', xPosition)\r\n      .attr('y', dimensions.height + (shouldRotate ? 12 : 20))\r\n      .attr('text-anchor', shouldRotate ? 'end' : 'middle')\r\n      .style('font-size', device.isMobile ? '9px' : '10px')\r\n      .style('fill', 'var(--chart-text-color)')\r\n      .text(this.formatXAxisLabel(d.name, device));\r\n    \r\n    if (shouldRotate) {\r\n      label\r\n        .attr('transform', `rotate(-45, ${xPosition}, ${dimensions.height + 12})`)\r\n        .attr('dx', '-0.5em');\r\n    }\r\n  });\r\n}\r\n\r\nprivate formatXAxisLabel(label: string, device: DeviceConfig): string {\r\n  if (device.isMobile) {\r\n    // Mobile: truncate longer labels\r\n    if (label.length > 8) {\r\n      return label.substring(0, 6) + '...';\r\n    }\r\n    return label;\r\n  } else {\r\n    // Tablet: slightly longer labels allowed\r\n    if (label.length > 12) {\r\n      return label.substring(0, 10) + '...';\r\n    }\r\n    return label;\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"]}
1110
+ //# 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 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: 35,          // Increased from 28\r\n    DESKTOP_MIN_BAR_WIDTH: 40,\r\n    TABLET_MIN_BAR_WIDTH: 30,          // Reduced from 35\r\n    MOBILE_BAR_PADDING: 8,             // Reduced from 10\r\n    TABLET_BAR_PADDING: 6,             // Reduced from 8\r\n    ZOOM_THRESHOLD: 30,\r\n    ZOOM_IN_THRESHOLD: 8,\r\n  };\r\n\r\n  defaultConfiguration = {\r\n    margin: { top: 20, right: 20, bottom: 20, left: 40 },\r\n    svgHeight: 70,\r\n    legendHeight: '10%',\r\n    numberOfYTicks: 5,\r\n    labelFormatter: ChartHelper.defaultFormatter,\r\n    xAxisLabelFomatter: ChartHelper.defaultFormatter,\r\n    yAxisLabelFomatter: ChartHelper.defaultFormatter,\r\n    yLineAxisLabelFomatter: ChartHelper.defaultFormatter,\r\n    lineGraphColor: '#F6D283',\r\n    showLineChartAxis: true,\r\n    showLegend: false,\r\n    forComparison: true,\r\n    headerMenuOptions: HeaderConfigHelper.headerConfig.headerMenuOptions,\r\n    yAxisGrid: false,\r\n    // Optional configs with undefined defaults\r\n    isHeaderVisible: undefined,\r\n    isTransparentBackground: undefined,\r\n    isTopCaptionVisible: undefined,\r\n    isMultiChartGridLine: undefined,\r\n    isFullScreen: undefined,\r\n    customYscale: undefined,\r\n    isXaxisLabelHidden: undefined,\r\n    isYaxisLabelHidden: undefined,\r\n    isYaxisHidden: undefined,\r\n    isYaxisDashed: undefined,\r\n    isXaxisColor: undefined,\r\n    textFormatter: undefined,\r\n    showTotalOnTop: undefined,\r\n    backendFormatterHasPriority: undefined,\r\n    showAngledLabels: undefined,\r\n    isNoAlternateXaxisText: undefined,\r\n    isXgridBetweenLabels: undefined,\r\n    showXaxisTop: undefined,\r\n    xAxisGrid: undefined,\r\n    xLabelsOnSameLine: undefined,\r\n    hideXaxisTick: undefined,\r\n    isDrilldownChart: undefined,\r\n    isTargetLine: undefined,\r\n    displayTitleOnTop: undefined,\r\n    isToggleVisible: undefined,\r\n    isTitleHidden: undefined,\r\n  };\r\n\r\n  constructor() {\r\n    super();\r\n  }\r\n\r\n  ngOnChanges() {\r\n    this.removeExistingChart();\r\n    this.initializeStackedChart();\r\n  }\r\n\r\n  onResized(event: ResizedEvent) {\r\n    setTimeout(() => {\r\n      this.removeExistingChart();\r\n      this.initializeStackedChart();\r\n    }, 10);\r\n  }\r\n\r\n  isZoomOutSelected(isZoomOut: boolean) {\r\n    this.isZoomedOut = isZoomOut;\r\n    this.ngOnChanges();\r\n  }\r\n\r\n  private removeExistingChart() {\r\n    d3.select('#' + this.uniqueId).remove();\r\n  }\r\n\r\n  private getDeviceConfig(): DeviceConfig {\r\n    const width = window.innerWidth;\r\n    return {\r\n      isMobile: width < 768,      // Changed from 576 to 768 for better mobile coverage\r\n      isTablet: width >= 768 && width < 1024,  // Changed from 576-992 to 768-1024\r\n      isDesktop: width >= 1024,   // Changed from 992 to 1024\r\n    };\r\n  }\r\n\r\nprivate configureResponsiveSettings(device: DeviceConfig) {\r\n  if (device.isMobile) {\r\n    this.chartConfiguration.margin = { top: 15, right: 5, bottom: 45, left: 25 }; // Increased bottom\r\n    this.chartConfiguration.numberOfYTicks = 4;\r\n    this.chartConfiguration.svgHeight = 55;\r\n  } else if (device.isTablet) {\r\n    this.chartConfiguration.margin = { top: 20, right: 15, bottom: 50, left: 35 }; // Increased bottom\r\n    this.chartConfiguration.numberOfYTicks = 5;\r\n    this.chartConfiguration.svgHeight = 65;\r\n  } else {\r\n    // Desktop/Large screens\r\n    const width = window.innerWidth;\r\n    if (width >= 1920) {\r\n      this.chartConfiguration.margin = { top: 35, right: 35, bottom: 55, left: 70 };\r\n      this.chartConfiguration.numberOfYTicks = 8;\r\n      this.chartConfiguration.svgHeight = 85;\r\n    } else if (width >= 1366) {\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    } else {\r\n      this.chartConfiguration.margin = { top: 25, right: 25, bottom: 45, left: 50 };\r\n      this.chartConfiguration.numberOfYTicks = 6;\r\n      this.chartConfiguration.svgHeight = 75;\r\n    }\r\n  }\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\nprivate 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  // Responsive zoom handling\r\n  if (dataLength > this.CONSTANTS.ZOOM_THRESHOLD && this.isZoomedOut) {\r\n    const minWidth = device.isMobile \r\n      ? dataLength * 15  // Increased from 12\r\n      : device.isTablet \r\n        ? dataLength * 22  // Increased from 20\r\n        : dataLength * 25;\r\n    width = Math.max(width, minWidth);\r\n  }\r\n\r\n  if (dataLength > this.CONSTANTS.ZOOM_IN_THRESHOLD && !this.isZoomedOut) {\r\n    width = device.isMobile \r\n      ? dataLength * 55  // Increased from 50\r\n      : device.isTablet \r\n        ? dataLength * 80  // Reduced from 90\r\n        : dataLength * 130;\r\n  }\r\n\r\n  if (this.chartConfiguration.isFullScreen) {\r\n    height = this.chartConfiguration.svgHeight !== 80\r\n      ? this.chartConfiguration.svgHeight\r\n      : containerHeight;\r\n  }\r\n\r\n  if (this.chartConfiguration.isDrilldownChart) {\r\n    const offset = device.isMobile ? 70 : device.isTablet ? 80 : 130;\r\n    height = containerHeight - margin.top - margin.bottom - offset;\r\n  }\r\n\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 if (device.isTablet) {\r\n    barWidth = this.CONSTANTS.TABLET_MIN_BAR_WIDTH;\r\n    barPadding = this.CONSTANTS.TABLET_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\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    // Adjust padding based on device\r\n    const padding = device.isMobile ? 0.15 : device.isTablet ? 0.3 : 0.5;\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(padding);\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\nprivate 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 || device.isTablet) {\r\n        // Use consistent positioning for mobile and tablet\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 || device.isTablet) 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 device = this.getDeviceConfig();\r\n    const bandwidth = xScale.bandwidth();\r\n    \r\n    // Responsive tooltip width\r\n    let width: string | number;\r\n    if (device.isMobile) {\r\n      width = Math.min(bandwidth + 40, 150);\r\n    } else if (device.isTablet) {\r\n      width = Math.min(bandwidth + 60, 200);\r\n    } else {\r\n      width = /week/i.test(d.data.name) && /\\d{4}-\\d{2}-\\d{2}/.test(d.data.name)\r\n        ? '250px'\r\n        : bandwidth + this.CONSTANTS.LEFT_RIGHT_SPACES * 2 > 180\r\n          ? '180px'\r\n          : bandwidth + this.CONSTANTS.LEFT_RIGHT_SPACES * 2;\r\n    }\r\n\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    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    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\nprivate 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 if (device.isTablet) {\r\n    // Tablet: Render with rotation\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', '10px')\r\n      .attr('text-anchor', 'end')\r\n      .attr('dx', '-.8em')\r\n      .attr('dy', '.15em')\r\n      .attr('transform', 'rotate(-45)')\r\n      .text((d: string) => {\r\n        // Truncate long labels for tablet\r\n        return d.length > 12 ? d.substring(0, 10) + '...' : d;\r\n      });\r\n  } else {\r\n    // Desktop: Standard horizontal labels\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\nprivate renderMobileXAxis(svg: any, data: any[], dimensions: Dimensions) {\r\n  svg.selectAll('.custom-x-label').remove();\r\n  \r\n  // Adaptive font size based on label length\r\n  const maxLength = Math.max(...data.map(d => d.name.length));\r\n  let fontSize = '9px';\r\n  if (maxLength > 15) fontSize = '7px';\r\n  else if (maxLength > 10) fontSize = '8px';\r\n  \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    \r\n    // Truncate labels intelligently for mobile\r\n    let labelText = d.name;\r\n    if (labelText.length > 8) {\r\n      // Try to truncate at word boundary\r\n      const words = labelText.split(' ');\r\n      if (words.length > 1) {\r\n        labelText = words[0].substring(0, 4) + '...';\r\n      } else {\r\n        labelText = labelText.substring(0, 6) + '...';\r\n      }\r\n    }\r\n    \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 + 15) // Adjusted positioning\r\n      .attr('text-anchor', 'middle')\r\n      .attr('transform', `translate(${xVal + 15},0)`)\r\n      .style('font-size', fontSize)\r\n      .style('fill', 'var(--chart-text-color)')\r\n      .style('writing-mode', 'sideways-lr')\r\n      .text(labelText);\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"]}