axidio-styleguide-library1-v2 0.2.27 → 0.2.28

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.
@@ -101,1014 +101,1955 @@ export class HorizontalGroupedBarWithScrollZoomComponent extends ComponentUnique
101
101
  get isAlertEnabled() {
102
102
  return this.chartConfiguration?.headerMenuOptions?.some((option) => option.id === 'editAlert');
103
103
  }
104
+ // initializegroupChart() {
105
+ // var self = this;
106
+ // let data = [];
107
+ // let metaData: any = null;
108
+ // let keyList = null;
109
+ // let lineData = null;
110
+ // let colorMap = {};
111
+ // var formatFromBackend;
112
+ // var formatForHugeNumbers;
113
+ // const isMobile = window.innerWidth < 576;
114
+ // const isTablet = window.innerWidth >= 576 && window.innerWidth < 992;
115
+ // const isDesktop = window.innerWidth >= 992;
116
+ // let isria = this.customChartConfiguration.isRia
117
+ // var x: any;
118
+ // var alternate_text = false;
119
+ // var short_tick_length = 4;
120
+ // var long_tick_length = 16;
121
+ // /**
122
+ // * longer tick length needed for weekly charts
123
+ // */
124
+ // var short_tick_length_bg = 5;
125
+ // var long_tick_length_bg = 30;
126
+ // var leftAndRightSpaces = 50;
127
+ // var rightSvgWidth = 60;
128
+ // var tempScale;
129
+ // for (var i in this.defaultConfiguration) {
130
+ // this.chartConfiguration[i] = ChartHelper.getValueByConfigurationType(
131
+ // i,
132
+ // this.defaultConfiguration,
133
+ // this.customChartConfiguration
134
+ // );
135
+ // }
136
+ // data = this.chartData.data;
137
+ // metaData = this.chartData.metaData;
138
+ // lineData = this.chartData.lineData;
139
+ // // if (lineData || this.chartData.targetLineData) {
140
+ // // rightSvgWidth = 60;
141
+ // // }
142
+ // if (!metaData.colorAboveTarget) {
143
+ // metaData['colorAboveTarget'] = metaData.colors;
144
+ // }
145
+ // colorMap = metaData.colors;
146
+ // keyList = metaData.keyList;
147
+ // var chartContainer = d3.select(this.containerElt.nativeElement);
148
+ // var verticalstackedcontainer = d3.select(
149
+ // this.groupcontainerElt.nativeElement
150
+ // );
151
+ // var margin = this.chartConfiguration.margin;
152
+ // const { width, height } = this.calculateChartDimensions(
153
+ // chartContainer,
154
+ // verticalstackedcontainer,
155
+ // margin,
156
+ // self
157
+ // );
158
+ // /**
159
+ // * for hiding header
160
+ // * used by weekly charts
161
+ // */
162
+ // if (this.chartConfiguration.isHeaderVisible != undefined)
163
+ // this.isHeaderVisible = this.chartConfiguration.isHeaderVisible;
164
+ // /**
165
+ // * for hiding legends
166
+ // * used by weekly charts
167
+ // */
168
+ // if (this.chartConfiguration.legendVisible != undefined) {
169
+ // this.legendVisible = this.chartConfiguration.legendVisible;
170
+ // }
171
+ // /**
172
+ // * for removing background color so that it can take parents color
173
+ // *
174
+ // */
175
+ // if (this.chartConfiguration.isTransparentBackground != undefined) {
176
+ // this.isTransparentBackground =
177
+ // this.chartConfiguration.isTransparentBackground;
178
+ // }
179
+ // /**
180
+ // * format data values based on configuration received
181
+ // */
182
+ // if (this.chartConfiguration.textFormatter != undefined) {
183
+ // formatFromBackend = ChartHelper.dataValueFormatter(
184
+ // this.chartConfiguration.textFormatter
185
+ // );
186
+ // formatForHugeNumbers = ChartHelper.dataValueFormatter('.2s');
187
+ // }
188
+ // const {
189
+ // outerContainer,
190
+ // svgYAxisLeft,
191
+ // svgYAxisRight,
192
+ // innerContainer,
193
+ // svg
194
+ // } = this.createChartContainers(chartContainer, margin, height, rightSvgWidth, self, width);
195
+ // var subgroups: any = keyList;
196
+ // var groups = d3
197
+ // .map(data, function (d) {
198
+ // return d.name;
199
+ // })
200
+ // .keys();
201
+ // /**
202
+ // * x axis range made similar to line chart or vertical stack so that all the charts will get aligned with each other.
203
+ // */
204
+ // if (this.chartConfiguration.isMultiChartGridLine != undefined) {
205
+ // x = d3
206
+ // .scaleBand()
207
+ // .rangeRound([width, 0])
208
+ // .align(0.5)
209
+ // .padding([0.5])
210
+ // .domain(
211
+ // data.map(function (d: any) {
212
+ // return d.name.toLowerCase();
213
+ // })
214
+ // );
215
+ // } else {
216
+ // x = d3
217
+ // .scaleBand()
218
+ // .domain(groups)
219
+ // .range([leftAndRightSpaces, width - rightSvgWidth - leftAndRightSpaces])
220
+ // .padding([0.3]);
221
+ // }
222
+ // // x.bandwidth(96);
223
+ // var xScaleFromOrigin = d3
224
+ // .scaleBand()
225
+ // .domain(groups)
226
+ // .range([0, width - rightSvgWidth]);
227
+ // // .padding([0.2]);
228
+ // if (this.chartConfiguration.isMultiChartGridLine == undefined) {
229
+ // /**
230
+ // * normal ticks for all dashboard charts
231
+ // */
232
+ // svg
233
+ // .append('g')
234
+ // .attr('class', 'x1 axis1')
235
+ // .attr('transform', 'translate(0,' + height + ')')
236
+ // .call(d3.axisBottom(x))
237
+ // .call((g) => g.select('.domain').remove());
238
+ // svg.selectAll('g.x1.axis1 g.tick line').remove();
239
+ // // Only move x-axis labels further down for grouped charts if there is no xLabel
240
+ // if (subgroups.length > 1 && !metaData.xLabel) {
241
+ // svg
242
+ // .selectAll('g.x1.axis1 g.tick text')
243
+ // .attr('class', 'lib-xaxis-labels-texts-drilldown')
244
+ // .style('fill', 'var(--chart-text-color)')
245
+ // .attr('y', 32); // Increase distance from bars (default is ~9)
246
+ // } else {
247
+ // svg
248
+ // .selectAll('g.x1.axis1 g.tick text')
249
+ // .attr('class', 'lib-xaxis-labels-texts-drilldown')
250
+ // .style('fill', 'var(--chart-text-color)');
251
+ // }
252
+ // }
253
+ // else {
254
+ // /**
255
+ // * bigger ticks for weekly charts and more space from x axis to labels
256
+ // */
257
+ // /**
258
+ // * draw x axis
259
+ // */
260
+ // svg
261
+ // .append('g')
262
+ // .attr('class', 'x1 axis1')
263
+ // .attr('transform', 'translate(0,' + height + ')')
264
+ // .call(d3.axisBottom(x).tickSize(0))
265
+ // .call((g) => g.select('.domain').attr('fill', 'none'));
266
+ // /**
267
+ // * tick line size in alternate fashion
268
+ // */
269
+ // svg.selectAll('g.x1.axis1 g.tick line').attr('y2', function () {
270
+ // if (
271
+ // alternate_text &&
272
+ // self.chartConfiguration.isNoAlternateXaxisText == undefined
273
+ // ) {
274
+ // alternate_text = false;
275
+ // return long_tick_length_bg - 7;
276
+ // } else {
277
+ // alternate_text = true;
278
+ // return short_tick_length_bg - 4;
279
+ // }
280
+ // });
281
+ // /**
282
+ // * reset the flag so that values can be shown in same alternate fashion
283
+ // */
284
+ // alternate_text = false;
285
+ // /**
286
+ // * print x-axis label texts
287
+ // * used by weekly charts
288
+ // */
289
+ // svg
290
+ // .selectAll('g.x1.axis1 g.tick text')
291
+ // .attr('class', 'lib-xaxis-labels-texts-weeklycharts')
292
+ // .attr('y', function () {
293
+ // // Minimize gap in maximized (fullscreen) view for weekly charts
294
+ // if (self.chartConfiguration.isFullScreen) {
295
+ // return short_tick_length_bg;
296
+ // }
297
+ // if (alternate_text) {
298
+ // alternate_text = false;
299
+ // return long_tick_length_bg;
300
+ // } else {
301
+ // alternate_text = true;
302
+ // return short_tick_length_bg;
303
+ // }
304
+ // });
305
+ // }
306
+ // if (self.chartConfiguration.xLabelsOnSameLine) {
307
+ // const xAxisLabels = svg
308
+ // .selectAll('g.x1.axis1 g.tick text')
309
+ // .attr('class', 'lib-xaxis-labels-texts-drilldown')
310
+ // .style('font-size', this.isHeaderVisible ? '18px' : '14px')
311
+ // .attr('text-anchor', 'middle')
312
+ // .attr('y', function(d) {
313
+ // // For grouped bar charts with many bars and xLabel present, only add 5 if the label is a date
314
+ // if (subgroups.length > 1 && data.length > 8 && metaData.xLabel) {
315
+ // const isDateLabel = /\d{2,4}[-\/]/.test(d);
316
+ // if (self.chartConfiguration.isFullScreen) {
317
+ // return isDateLabel ? short_tick_length_bg + 14 : short_tick_length_bg;
318
+ // }
319
+ // return isDateLabel ? short_tick_length_bg + 14 : short_tick_length_bg;
320
+ // }
321
+ // // For grouped bar charts with many bars and NO xLabel, add space as before, but reduce in fullscreen
322
+ // if (subgroups.length > 1 && data.length > 8 && !metaData.xLabel) {
323
+ // const chartHasExtraBottom = (self.chartConfiguration.margin && self.chartConfiguration.margin.bottom >= 40);
324
+ // if (self.chartConfiguration.isFullScreen) {
325
+ // // Reduce extra gap in maximized view
326
+ // return short_tick_length_bg + 2;
327
+ // }
328
+ // return chartHasExtraBottom ? short_tick_length_bg : short_tick_length_bg + 10;
329
+ // }
330
+ // // Default/fallback logic for other cases
331
+ // let baseY = self.isHeaderVisible ? short_tick_length_bg + 25 : short_tick_length_bg;
332
+ // if (
333
+ // subgroups.length > 1 &&
334
+ // !metaData.xLabel &&
335
+ // (/\d{2,4}[-\/]\d{2}[-\/]\d{2,4}/.test(d) || /\d{2,4}[-\/]\d{2,4}/.test(d))
336
+ // ) {
337
+ // baseY = self.isHeaderVisible ? short_tick_length_bg + 15 : short_tick_length_bg + 25;
338
+ // }
339
+ // if (/\d{2,4}[-\/]\d{2,4}/.test(d) && d.indexOf(' ') > -1) {
340
+ // baseY += 4;
341
+ // }
342
+ // // In maximized view, reduce baseY slightly for grouped bars
343
+ // if (self.chartConfiguration.isFullScreen && subgroups.length > 1) {
344
+ // baseY = Math.max(short_tick_length_bg, baseY - 10);
345
+ // }
346
+ // return baseY;
347
+ // })
348
+ // .attr('x', function (d) {
349
+ // if (self.chartData.data.length > 8 && !self.isZoomedOut) {
350
+ // return 1; // Move first line text slightly to the left in zoom-in view for better alignment
351
+ // }
352
+ // return 0; // Default position
353
+ // })
354
+ // .text(function (d) {
355
+ // var isValueToBeIgnored = false;
356
+ // if (isMobile && !self.isHeaderVisible) {
357
+ // let firstPart = d.split(/[\s\-]+/)[0];
358
+ // return firstPart.substring(0, 3).toLowerCase();
359
+ // }
360
+ // (data as any[]).map((indiv: any) => {
361
+ // if (
362
+ // indiv.name &&
363
+ // indiv.name.toLowerCase() == d.trim().toLowerCase() &&
364
+ // indiv[metaData.keyList[0]] == -1
365
+ // ) {
366
+ // isValueToBeIgnored = true;
367
+ // }
368
+ // });
369
+ // if (isValueToBeIgnored) {
370
+ // return '';
371
+ // }
372
+ // // Always add space before and after hyphen for date range labels, even when header is visible and label is single line
373
+ // // Apply for grouped bar charts and single bar charts, header visible, single line
374
+ // const dateRangeRegex = /(\d{2,4}[-\/]\d{2}[-\/]\d{2,4})\s*-\s*(\d{2,4}[-\/]\d{2}[-\/]\d{2,4})/;
375
+ // if (dateRangeRegex.test(d.trim())) {
376
+ // return d.trim().replace(dateRangeRegex, (m, d1, d2) => `${d1} - ${d2}`);
377
+ // }
378
+ // // Split date and week labels into two lines in grouped bar zoom-in view (and minimized view)
379
+ // const isDateLabel = /\d{2,4}[-\/]/.test(d);
380
+ // const isWeekLabel = /week|wk|w\d+/i.test(d);
381
+ // if (
382
+ // subgroups.length > 1 && !self.isZoomedOut && data.length > 8 && d.indexOf(' ') > -1 && (isDateLabel || isWeekLabel)
383
+ // ) {
384
+ // var first = d.substring(0, d.indexOf(' '));
385
+ // var second = d.substring(d.indexOf(' ') + 1).trim();
386
+ // return first + '\n' + second;
387
+ // }
388
+ // // Also keep previous logic for minimized view
389
+ // if (isDateLabel) {
390
+ // if (!self.isHeaderVisible && data.length > 8 && d.indexOf(' ') > -1) {
391
+ // var first = d.substring(0, d.indexOf(' '));
392
+ // var second = d.substring(d.indexOf(' ') + 1).trim();
393
+ // return first + '\n' + second;
394
+ // } else {
395
+ // return d;
396
+ // }
397
+ // }
398
+ // if (d.trim().indexOf(' ') > -1) {
399
+ // return d.trim().substring(0, d.indexOf(' ')).toLowerCase();
400
+ // }
401
+ // return d.toLowerCase();
402
+ // // If label looks like a date (contains digits and - or /)
403
+ // const isDateLabel2 = /\d{2,4}[-\/]/.test(d);
404
+ // // Only split date/week labels if there are many grouped bars and header is not visible
405
+ // if (isDateLabel) {
406
+ // if (!self.isHeaderVisible && data.length > 8 && d.indexOf(' ') > -1) {
407
+ // var first = d.substring(0, d.indexOf(' '));
408
+ // var second = d.substring(d.indexOf(' ') + 1).trim();
409
+ // return first + '\n' + second;
410
+ // } else {
411
+ // return d;
412
+ // }
413
+ // }
414
+ // if (d.trim().indexOf(' ') > -1) {
415
+ // return d.trim().substring(0, d.indexOf(' ')).toLowerCase();
416
+ // }
417
+ // return d.toLowerCase();
418
+ // });
419
+ // // Now apply writing-mode: sideways-lr for grouped charts with date labels in zoomed-out view and many bars
420
+ // xAxisLabels.each(function(this: SVGTextElement, d: any) {
421
+ // // Only apply writing-mode for exact date labels, not those containing 'week' or similar
422
+ // const isDateLabel = /^(\d{2,4}[-\/])?\d{2,4}[-\/]\d{2,4}$/.test(d.trim());
423
+ // const isWeekLabel = /week|wk|w\d+/i.test(d);
424
+ // if (subgroups.length > 1 && self.isZoomedOut && data.length > 8 && isDateLabel && !isWeekLabel) {
425
+ // d3.select(this).style('writing-mode', 'sideways-lr');
426
+ // }
427
+ // });
428
+ // if (!isMobile) {
429
+ // svg
430
+ // .selectAll('g.x1.axis1 g.tick')
431
+ // .filter(function (d) {
432
+ // return !/\d{2,4}[-\/]/.test(d); // Only process non-date labels
433
+ // })
434
+ // .append('text')
435
+ // .attr('class', 'lib-xaxis-labels-texts-drilldown')
436
+ // .attr('y', long_tick_length_bg)
437
+ // .attr('fill', 'var(--chart-text-color)')
438
+ // .attr('x', function (d) {
439
+ // if (self.chartData.data.length > 8 && !self.isZoomedOut) {
440
+ // return 1; // Move text slightly to the left
441
+ // }
442
+ // return 0; // Default position
443
+ // })
444
+ // .text(function (d) {
445
+ // if (d.trim().indexOf(' ') > -1) {
446
+ // return d.trim().substring(d.indexOf(' '), d.length).toLowerCase();
447
+ // }
448
+ // return '';
449
+ // });
450
+ // }
451
+ // }
452
+ // if (isria && self.chartData.data.length > 8) {
453
+ // svg
454
+ // .selectAll('g.x1.axis1 g.tick text')
455
+ // .classed('mobile-xaxis-override', true)
456
+ // .text(function (d: string) {
457
+ // return d.substring(0, 3);
458
+ // })
459
+ // .style('font-size', '12px')
460
+ // .attr('y', 5)
461
+ // .attr('x', 5)
462
+ // .style('text-anchor', 'middle');
463
+ // }
464
+ // if (isMobile && !this.isHeaderVisible) {
465
+ // svg
466
+ // .selectAll('g.x1.axis1 g.tick text')
467
+ // .classed('mobile-xaxis-override', true);
468
+ // }
469
+ // /**y scale for left y axis */
470
+ // var y = d3.scaleLinear().rangeRound([height, 0]);
471
+ // var maxValue = d3.max(data, (d) => d3.max(keyList, (key) => +d[key]));
472
+ // if (maxValue == 0) {
473
+ // if (this.chartData.targetLineData) {
474
+ // maxValue = this.chartData.targetLineData.target + 20;
475
+ // } else {
476
+ // maxValue = 100;
477
+ // }
478
+ // }
479
+ // if (this.chartConfiguration.customYscale) {
480
+ // /**
481
+ // * increase y-scale so that values wont cross or exceed out of range
482
+ // * used in weekly charts
483
+ // */
484
+ // maxValue = maxValue * this.chartConfiguration.customYscale;
485
+ // }
486
+ // if (
487
+ // this.chartData.targetLineData &&
488
+ // maxValue < this.chartData.targetLineData.target
489
+ // ) {
490
+ // maxValue =
491
+ // maxValue < 10 && this.chartData.targetLineData.target < 10
492
+ // ? this.chartData.targetLineData.target + 3
493
+ // : this.chartData.targetLineData.target + 20;
494
+ // }
495
+ // y.domain([0, maxValue]).nice();
496
+ // let lineYscale;
497
+ // if (lineData != null) {
498
+ // let maxLineValue = d3.max(lineData, function (d) {
499
+ // return +d.value;
500
+ // });
501
+ // maxLineValue = maxLineValue * this.chartConfiguration.customYscale;
502
+ // let minLineValue = d3.min(lineData, function (d) {
503
+ // return +d.value;
504
+ // });
505
+ // if (maxLineValue > 0) minLineValue = minLineValue - 3;
506
+ // if (minLineValue > 0) {
507
+ // minLineValue = 0;
508
+ // }
509
+ // lineYscale = d3
510
+ // .scaleLinear()
511
+ // .domain([minLineValue, maxLineValue])
512
+ // .range([height, minLineValue]);
513
+ // }
514
+ // let yLineAxis;
515
+ // if (lineYscale != null) {
516
+ // yLineAxis = d3
517
+ // .axisRight(lineYscale)
518
+ // .ticks(self.chartConfiguration.numberOfYTicks)
519
+ // .tickSize(0)
520
+ // .tickFormat(self.chartConfiguration.yLineAxisLabelFomatter);
521
+ // }
522
+ // /**
523
+ // * show x-axis grid between labels
524
+ // * used by weekly charts
525
+ // */
526
+ // if (self.chartConfiguration.isXgridBetweenLabels) {
527
+ // svg
528
+ // .append('g')
529
+ // .attr('class', 'grid')
530
+ // .attr(
531
+ // 'transform',
532
+ // 'translate(' + x.bandwidth() / 2 + ',' + height + ')'
533
+ // )
534
+ // .call(d3.axisBottom(x).tickSize(-height).tickFormat(''))
535
+ // .style('stroke-dasharray', '5 5')
536
+ // .style('color', 'var(--chart-grid-color, #999999)') // Use CSS variable
537
+ // .call((g) => g.select('.domain').remove());
538
+ // }
539
+ // if (this.chartConfiguration.yAxisGrid) {
540
+ // svg
541
+ // .append('g')
542
+ // .call(
543
+ // d3
544
+ // .axisLeft(y)
545
+ // .ticks(self.chartConfiguration.numberOfYTicks)
546
+ // .tickSize(-width)
547
+ // )
548
+ // .style('color', 'var(--chart-axis-color, #B9B9B9)')
549
+ // .style('opacity', '0.5')
550
+ // .call((g) => {
551
+ // g.select('.domain')
552
+ // .remove()
553
+ // .style('stroke', 'var(--chart-domain-color, #000000)'); // Add CSS variable for domain
554
+ // });
555
+ // } else {
556
+ // svg
557
+ // .append('g')
558
+ // .call(d3.axisLeft(y).ticks(self.chartConfiguration.numberOfYTicks))
559
+ // .style('color', 'var(--chart-axis-color, #B9B9B9)')
560
+ // .style('opacity', '0.5')
561
+ // .call((g) => {
562
+ // g.select('.domain')
563
+ // .style('stroke', 'var(--chart-domain-color, #000000)') // Add CSS variable for domain
564
+ // .style('stroke-width', '1px'); // Ensure visibility
565
+ // });
566
+ // }
567
+ // var xSubgroup = d3.scaleBand().domain(subgroups);
568
+ // if (subgroups.length > 1 && !this.isZoomedOut) {
569
+ // // For grouped bar charts in zoom-in view, use full x.bandwidth() for subgroups
570
+ // xSubgroup.range([0, x.bandwidth()]);
571
+ // } else if (subgroups.length === 1 && !this.isZoomedOut) {
572
+ // // For single-bar (non-grouped) charts in zoom-in view, set bar width to 100 (increased from 80)
573
+ // xSubgroup.range([0, 100]);
574
+ // } else if (this.chartConfiguration.isMultiChartGridLine == undefined) {
575
+ // xSubgroup.range([0, x.bandwidth()]);
576
+ // } else {
577
+ // // used to make grouped bars with lesser width as we are not using padding for width
578
+ // xSubgroup.range([0, x.bandwidth()]);
579
+ // }
580
+ // // if (this.chartConfiguration.isDrilldownChart) {
581
+ // // }
582
+ // var color = d3
583
+ // .scaleOrdinal()
584
+ // .domain(subgroups)
585
+ // .range(Object.values(metaData.colors));
586
+ // // var colorAboveTarget = d3
587
+ // // .scaleOrdinal()
588
+ // // .domain(subgroups)
589
+ // // .range(Object.values(metaData.colorAboveTarget));
590
+ // var state = svg
591
+ // .append('g')
592
+ // .selectAll('.state')
593
+ // .data(data)
594
+ // .enter()
595
+ // .append('g')
596
+ // .attr('transform', function (d) {
597
+ // return 'translate(' + x(d.name) + ',0)';
598
+ // });
599
+ // state
600
+ // .selectAll('rect')
601
+ // .data(function (d) {
602
+ // let newList: any = [];
603
+ // subgroups.map(function (key) {
604
+ // // if (key !== "group") {
605
+ // let obj: any = { key: key, value: d[key], name: d.name };
606
+ // newList.push(obj);
607
+ // // }
608
+ // });
609
+ // return newList;
610
+ // })
611
+ // .enter()
612
+ // .append('rect')
613
+ // .attr('class', 'bars')
614
+ // .on('click', function (d) {
615
+ // if (d.key != 'Target') {
616
+ // if (
617
+ // !metaData.barWithoutClick ||
618
+ // !metaData.barWithoutClick.length ||
619
+ // (!metaData.barWithoutClick.includes(d?.name) &&
620
+ // !metaData.barWithoutClick.includes(d?.key))
621
+ // )
622
+ // // self.handleClick(d.data.name);
623
+ // self.handleClick(d);
624
+ // }
625
+ // })
626
+ // .attr('x', function (d) {
627
+ // if (self.chartConfiguration.isDrilldownChart) {
628
+ // data.map((indiv: any) => {
629
+ // if (indiv.name == d.name) {
630
+ // let keys = Object.keys(indiv).filter((temp, i) => i != 0);
631
+ // tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);
632
+ // if (x.bandwidth() > 100) {
633
+ // // Increase bar width a bit in zoom-in view
634
+ // let reducedBarWidth = 60;
635
+ // if (!self.isZoomedOut) {
636
+ // reducedBarWidth = 30;
637
+ // }
638
+ // if (self.chartData.data.length == 1) {
639
+ // if (Object.keys(self.chartData.data[0]).length == 2) {
640
+ // tempScale.range([
641
+ // 0 + (x.bandwidth() - reducedBarWidth) / 2,
642
+ // x.bandwidth() - (x.bandwidth() - reducedBarWidth) / 2,
643
+ // ]);
644
+ // } else
645
+ // tempScale.range([
646
+ // 0 + (x.bandwidth() - reducedBarWidth) / 2,
647
+ // x.bandwidth() - (x.bandwidth() - reducedBarWidth) / 2,
648
+ // ]);
649
+ // } else
650
+ // tempScale.range([
651
+ // 0 + (x.bandwidth() - reducedBarWidth) / 2,
652
+ // x.bandwidth() - (x.bandwidth() - reducedBarWidth) / 2,
653
+ // ]);
654
+ // }
655
+ // }
656
+ // });
657
+ // return tempScale(d.key);
658
+ // }
659
+ // return xSubgroup(d.key);
660
+ // })
661
+ // .attr('y', function (d) {
662
+ // if (d.value == -1) {
663
+ // return y(0);
664
+ // }
665
+ // if (d.value >= 0) {
666
+ // const barHeight = height - y(d.value);
667
+ // const minHeight = self.chartConfiguration.defaultBarHeight || 2;
668
+ // return barHeight < minHeight ? y(0) - minHeight : y(d.value);
669
+ // }
670
+ // return y(0);
671
+ // })
672
+ // .attr('width', function (d) {
673
+ // // For grouped bar charts in zoom-in view, set bar width to 50 for maximum thickness
674
+ // if (subgroups.length > 1 && !self.isZoomedOut) {
675
+ // return 50;
676
+ // }
677
+ // // For single-bar (non-grouped) charts in zoom-in view, set bar width to 80
678
+ // if (subgroups.length === 1 && !self.isZoomedOut) {
679
+ // return 80;
680
+ // }
681
+ // let tempScale = d3.scaleBand().domain([]).range([0, 0]);
682
+ // // Default logic for other chart types
683
+ // if (self.chartConfiguration.isDrilldownChart) {
684
+ // data.map((indiv: any) => {
685
+ // if (indiv.name == d.name) {
686
+ // let keys = Object.keys(indiv).filter((temp, i) => i != 0);
687
+ // tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);
688
+ // if (x.bandwidth() > 100) {
689
+ // // Increase bar width a bit in zoom-in view
690
+ // let reducedBarWidth = 60;
691
+ // if (!self.isZoomedOut) {
692
+ // reducedBarWidth = 100;
693
+ // }
694
+ // if (self.chartData.data.length == 1) {
695
+ // if (Object.keys(self.chartData.data[0]).length == 2) {
696
+ // tempScale.range([
697
+ // 0 + (x.bandwidth() - reducedBarWidth) / 2,
698
+ // x.bandwidth() - (x.bandwidth() - reducedBarWidth) / 2,
699
+ // ]);
700
+ // } else
701
+ // tempScale.range([
702
+ // 0 + (x.bandwidth() - reducedBarWidth) / 2,
703
+ // x.bandwidth() - (x.bandwidth() - reducedBarWidth) / 2,
704
+ // ]);
705
+ // } else
706
+ // tempScale.range([
707
+ // 0 + (x.bandwidth() - reducedBarWidth) / 2,
708
+ // x.bandwidth() - (x.bandwidth() - reducedBarWidth) / 2,
709
+ // ]);
710
+ // }
711
+ // }
712
+ // });
713
+ // return self.isZoomedOut
714
+ // ? tempScale.bandwidth()
715
+ // : self.chartData.data.length && self.chartData.data.length > 8
716
+ // ? tempScale.bandwidth()
717
+ // : tempScale.bandwidth();
718
+ // }
719
+ // return self.isZoomedOut
720
+ // ? tempScale.bandwidth()
721
+ // : self.chartData.data.length && self.chartData.data.length > 8
722
+ // ? tempScale.bandwidth()
723
+ // : tempScale.bandwidth();
724
+ // })
725
+ // .attr('height', function (d) {
726
+ // if (d.value == -1) {
727
+ // return height - y(0);
728
+ // }
729
+ // if (d.value >= 0) {
730
+ // const barHeight = height - y(d.value);
731
+ // const minHeight = self.chartConfiguration.defaultBarHeight || 2;
732
+ // return Math.max(barHeight, minHeight);
733
+ // }
734
+ // return height - y(0);
735
+ // })
736
+ // .style('cursor', function (d) {
737
+ // if (metaData.hasDrillDown && !isria) return 'pointer';
738
+ // else return 'default';
739
+ // })
740
+ // .attr('fill', function (d) {
741
+ // if (
742
+ // d.value &&
743
+ // self.chartData.targetLineData &&
744
+ // d.value >= parseFloat(self.chartData.targetLineData.target) &&
745
+ // self.chartData.metaData.colorAboveTarget
746
+ // ) {
747
+ // const key = d.key.toLowerCase();
748
+ // const colorAboveTarget = Object.keys(self.chartData.metaData.colorAboveTarget).find(
749
+ // k => k.toLowerCase() === key
750
+ // );
751
+ // if (colorAboveTarget) {
752
+ // return self.chartData.metaData.colorAboveTarget[colorAboveTarget];
753
+ // }
754
+ // }
755
+ // return self.chartData.metaData.colors[d.key];
756
+ // });
757
+ // /**
758
+ // * display angled texts on the bars
759
+ // */
760
+ // if (this.chartConfiguration.textsOnBar != undefined && !this.isZoomedOut) {
761
+ // state
762
+ // .selectAll('text')
763
+ // .data(function (d) {
764
+ // let newList: any = [];
765
+ // subgroups.map(function (key) {
766
+ // let obj: any = { key: key, value: d[key], name: d.name };
767
+ // newList.push(obj);
768
+ // });
769
+ // return newList;
770
+ // })
771
+ // .enter()
772
+ // .append('text')
773
+ // .attr('fill', 'var(--chart-text-color)')
774
+ // .attr('x', function (d) {
775
+ // return 0;
776
+ // })
777
+ // .attr('y', function (d) {
778
+ // return 0;
779
+ // })
780
+ // .attr('class', 'lib-data-labels-weeklycharts')
781
+ // .text(function (d) {
782
+ // return d.key && d.value
783
+ // ? d.key.length > 20
784
+ // ? d.key.substring(0, 17) + '...'
785
+ // : d.key
786
+ // : '';
787
+ // })
788
+ // .style('fill', function (d) {
789
+ // return '#000';
790
+ // })
791
+ // .style('font-weight', 'bold')
792
+ // .style('font-size', function (d) {
793
+ // if (self.isZoomedOut) {
794
+ // return '9px'; // 👈 Zoomed out mode
795
+ // }
796
+ // if (self.chartConfiguration.isDrilldownChart) {
797
+ // if (window.innerWidth > 1900) {
798
+ // return '18px';
799
+ // } else if (window.innerWidth < 1400) {
800
+ // return '10px';
801
+ // } else {
802
+ // return '14px';
803
+ // }
804
+ // } else {
805
+ // return '14px';
806
+ // }
807
+ // })
808
+ // .attr('transform', function (d) {
809
+ // data.map((indiv: any) => {
810
+ // if (indiv.name == d.name) {
811
+ // let keys = Object.keys(indiv).filter((temp, i) => i != 0);
812
+ // var temp;
813
+ // tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);
814
+ // if (x.bandwidth() > 100) {
815
+ // if (self.chartData.data.length == 1) {
816
+ // if (Object.keys(self.chartData.data[0]).length == 2) {
817
+ // tempScale.range([
818
+ // 0 + (x.bandwidth() - 200) / 2,
819
+ // x.bandwidth() - (x.bandwidth() - 200) / 2,
820
+ // ]);
821
+ // // .padding(0.05);
822
+ // } else
823
+ // tempScale.range([
824
+ // 0 + (x.bandwidth() - 300) / 2,
825
+ // x.bandwidth() - (x.bandwidth() - 300) / 2,
826
+ // ]);
827
+ // // .padding(0.05);
828
+ // } else
829
+ // tempScale.range([
830
+ // 0 + (x.bandwidth() - 125) / 2,
831
+ // x.bandwidth() - (x.bandwidth() - 125) / 2,
832
+ // ]);
833
+ // }
834
+ // }
835
+ // });
836
+ // /**
837
+ // * if set, then all texts ll be horizontal
838
+ // */
839
+ // if (self.chartConfiguration.textAlwaysHorizontal) {
840
+ // return (
841
+ // 'translate(' + xSubgroup(d.key) + ',' + (y(d.value) - 3) + ')'
842
+ // );
843
+ // }
844
+ // /**
845
+ // * rotate texts having more than one digits
846
+ // */
847
+ // // if (d.value > 9)
848
+ // if (!isNaN(tempScale(d.key)))
849
+ // return (
850
+ // 'translate(' +
851
+ // (tempScale(d.key) + tempScale.bandwidth() * 0.55) +
852
+ // ',' +
853
+ // (y(0) - 10) +
854
+ // ') rotate(270)'
855
+ // );
856
+ // return 'translate(0,0)';
857
+ // // else
858
+ // // return (
859
+ // // 'translate(' +
860
+ // // (tempScale(d.key) + tempScale.bandwidth() / 2) +
861
+ // // ',' +
862
+ // // y(0) +
863
+ // // ')'
864
+ // // );
865
+ // })
866
+ // .on('click', function (d) {
867
+ // if (
868
+ // !metaData.barWithoutClick ||
869
+ // !metaData.barWithoutClick.length ||
870
+ // (!metaData.barWithoutClick.includes(d?.name) &&
871
+ // !metaData.barWithoutClick.includes(d?.key))
872
+ // )
873
+ // self.handleClick(d);
874
+ // });
875
+ // if (!isria) {
876
+ // state
877
+ // .selectAll('.lib-data-labels-weeklycharts')
878
+ // .on('mouseout', handleMouseOut)
879
+ // .on('mouseover', handleMouseOver);
880
+ // }
881
+ // }
882
+ // if (this.chartConfiguration.displayTitleOnTop || (
883
+ // this.chartConfiguration.textsOnBar == undefined &&
884
+ // this.chartConfiguration.displayTitleOnTop == undefined
885
+ // )) {
886
+ // if (!isria) {
887
+ // state
888
+ // .selectAll('rect')
889
+ // .on('mouseout', handleMouseOut)
890
+ // .on('mouseover', handleMouseOver);
891
+ // }
892
+ // }
893
+ // function handleMouseOver(d, i) {
894
+ // svg.selectAll('.lib-verticalstack-title-ontop').remove();
895
+ // svg
896
+ // .append('foreignObject')
897
+ // .attr('x', function () {
898
+ // // ...existing code for tempScale calculation...
899
+ // var elementsCounter;
900
+ // data.map((indiv: any) => {
901
+ // if (indiv.name == d.name) {
902
+ // let keys = Object.keys(indiv).filter((temp, i) => i != 0);
903
+ // elementsCounter = keys.length;
904
+ // tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);
905
+ // if (x.bandwidth() > 100) {
906
+ // if (self.chartData.data.length == 1) {
907
+ // if (Object.keys(self.chartData.data[0]).length == 2) {
908
+ // tempScale.range([
909
+ // 0 + (x.bandwidth() - 200) / 2,
910
+ // x.bandwidth() - (x.bandwidth() - 200) / 2,
911
+ // ]);
912
+ // } else
913
+ // tempScale.range([
914
+ // 0 + (x.bandwidth() - 300) / 2,
915
+ // x.bandwidth() - (x.bandwidth() - 300) / 2,
916
+ // ]);
917
+ // } else
918
+ // tempScale.range([
919
+ // 0 + (x.bandwidth() - 125) / 2,
920
+ // x.bandwidth() - (x.bandwidth() - 125) / 2,
921
+ // ]);
922
+ // }
923
+ // }
924
+ // });
925
+ // if (metaData.hasDrillDown) {
926
+ // if (tempScale.bandwidth() + leftAndRightSpaces * 2 > 180) {
927
+ // return (
928
+ // x(d.name) + tempScale(d.key) + tempScale.bandwidth() / 2 - 90
929
+ // );
930
+ // }
931
+ // return (
932
+ // x(d.name) +
933
+ // tempScale(d.key) -
934
+ // (tempScale.bandwidth() + leftAndRightSpaces * 2) / 2 +
935
+ // tempScale.bandwidth() / 2
936
+ // );
937
+ // } else return x(d.name) + tempScale(d.key) - (tempScale.bandwidth() + leftAndRightSpaces * 2) / 2 + tempScale.bandwidth() / 2;
938
+ // })
939
+ // .attr('class', 'lib-verticalstack-title-ontop')
940
+ // .attr('y', function () {
941
+ // return y(d.value) - 3 - 40 - 10;
942
+ // })
943
+ // .attr('dy', function () {
944
+ // return d.class;
945
+ // })
946
+ // .attr('width', function () {
947
+ // data.map((indiv: any) => {
948
+ // if (indiv.name == d.name) {
949
+ // let keys = Object.keys(indiv).filter((temp, i) => i != 0);
950
+ // tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);
951
+ // if (x.bandwidth() > 100) {
952
+ // if (self.chartData.data.length == 1) {
953
+ // if (Object.keys(self.chartData.data[0]).length == 2) {
954
+ // tempScale.range([
955
+ // 0 + (x.bandwidth() - 200) / 2,
956
+ // x.bandwidth() - (x.bandwidth() - 200) / 2,
957
+ // ]);
958
+ // } else
959
+ // tempScale.range([
960
+ // 0 + (x.bandwidth() - 300) / 2,
961
+ // x.bandwidth() - (x.bandwidth() - 300) / 2,
962
+ // ]);
963
+ // } else
964
+ // tempScale.range([
965
+ // 0 + (x.bandwidth() - 125) / 2,
966
+ // x.bandwidth() - (x.bandwidth() - 125) / 2,
967
+ // ]);
968
+ // }
969
+ // }
970
+ // });
971
+ // if (metaData.hasDrillDown) {
972
+ // if (tempScale.bandwidth() + leftAndRightSpaces * 2 > 180) {
973
+ // return '180px';
974
+ // }
975
+ // return tempScale.bandwidth() + leftAndRightSpaces * 2;
976
+ // } else return tempScale.bandwidth() + leftAndRightSpaces * 2;
977
+ // })
978
+ // .attr('height', 50)
979
+ // .append('xhtml:div')
980
+ // .attr('class', 'title')
981
+ // .style('z-index', 99)
982
+ // .html(function () {
983
+ // let barLabel = d.key;
984
+ // let dataType = metaData.dataType ? metaData.dataType : '';
985
+ // let value = d.value;
986
+ // let desiredText =
987
+ // '<span class="title-bar-name">' + barLabel + '</span>';
988
+ // desiredText +=
989
+ // '<span class="title-bar-value"><span>' +
990
+ // value +
991
+ // '</span>' +
992
+ // dataType +
993
+ // '</span>';
994
+ // return desiredText;
995
+ // });
996
+ // }
997
+ // function handleMouseOut(d, i) {
998
+ // svg.selectAll('.lib-verticalstack-title-ontop').remove();
999
+ // }
1000
+ // svg
1001
+ // .append('g')
1002
+ // .attr('class', 'x2 axis2')
1003
+ // .attr('transform', 'translate(0,' + height + ')')
1004
+ // .style('color', 'var(--chart-axis-color, #000)') // Use CSS variable instead of hardcoded #000
1005
+ // .call(d3.axisBottom(xScaleFromOrigin).tickSize(0))
1006
+ // .call((g) => g.select('.domain').attr('fill', 'none'));
1007
+ // svg.selectAll('g.x2.axis2 g.tick text').style('display', 'none');
1008
+ // svg
1009
+ // .append('g')
1010
+ // .attr('class', 'lib-stacked-y-axis-text yaxis-dashed')
1011
+ // .attr('style', self.chartConfiguration.yAxisCustomTextStyles)
1012
+ // .attr('transform', 'translate(0,0)')
1013
+ // .call(y)
1014
+ // .style('display', 'none');
1015
+ // svgYAxisLeft
1016
+ // .append('g')
1017
+ // .append('g')
1018
+ // .attr('class', 'lib-yaxis-labels-texts-drilldown yaxis-dashed')
1019
+ // .attr('style', self.chartConfiguration.yAxisCustomTextStyles)
1020
+ // .attr('transform', 'translate(0,0)')
1021
+ // .call(
1022
+ // d3
1023
+ // .axisLeft(y)
1024
+ // .tickSize(0)
1025
+ // .ticks(self.chartConfiguration.numberOfYTicks)
1026
+ // .tickFormat(function (d) {
1027
+ // const formatted = self.chartConfiguration.yAxisLabelFomatter
1028
+ // ? self.chartConfiguration.yAxisLabelFomatter(d)
1029
+ // : d;
1030
+ // return formatted >= 1000 ? formatted / 1000 + 'k' : formatted;
1031
+ // })
1032
+ // )
1033
+ // .call((g) => {
1034
+ // // Style the domain line for theme support
1035
+ // g.select('.domain')
1036
+ // .style('stroke', 'var(--chart-domain-color, #000000)')
1037
+ // .style('stroke-width', '1px');
1038
+ // })
1039
+ // .selectAll('text')
1040
+ // .style('fill', 'var(--chart-text-color)');
1041
+ // svgYAxisRight
1042
+ // .append('g')
1043
+ // .attr('class', 'lib-yaxis-labels-texts-drilldown yaxis-dashed')
1044
+ // .attr('style', self.chartConfiguration.yAxisCustomTextStyles)
1045
+ // .attr('transform', 'translate(0,0)')
1046
+ // .call(y)
1047
+ // .style('display', 'none');
1048
+ // /**
1049
+ // * hide x axis labels
1050
+ // * config is there for future use
1051
+ // * used by weekly charts
1052
+ // */
1053
+ // if (
1054
+ // this.chartConfiguration.isXaxisLabelHidden != undefined &&
1055
+ // this.chartConfiguration.isXaxisLabelHidden
1056
+ // ) {
1057
+ // d3.selectAll('g.lib-line-x-axis-text > g > text').attr(
1058
+ // 'class',
1059
+ // 'lib-display-hidden'
1060
+ // );
1061
+ // }
1062
+ // /**
1063
+ // * hide y axis labels
1064
+ // * used by weekly charts
1065
+ // */
1066
+ // if (
1067
+ // this.chartConfiguration.isYaxisLabelHidden != undefined &&
1068
+ // this.chartConfiguration.isYaxisLabelHidden
1069
+ // ) {
1070
+ // d3.selectAll('.yaxis-dashed > g > text').attr(
1071
+ // 'class',
1072
+ // 'lib-display-hidden'
1073
+ // );
1074
+ // }
1075
+ // /**
1076
+ // * hide y axis labels
1077
+ // * config is there for future use
1078
+ // */
1079
+ // if (
1080
+ // this.chartConfiguration.isYaxisHidden != undefined &&
1081
+ // this.chartConfiguration.isYaxisHidden
1082
+ // ) {
1083
+ // d3.selectAll('.yaxis-dashed').attr('class', 'lib-display-hidden');
1084
+ // }
1085
+ // /**
1086
+ // * dashed y axis
1087
+ // * used by weekly charts
1088
+ // */
1089
+ // if (
1090
+ // this.chartConfiguration.isYaxisDashed != undefined &&
1091
+ // this.chartConfiguration.isYaxisDashed
1092
+ // ) {
1093
+ // d3.selectAll('.yaxis-dashed')
1094
+ // .style('stroke-dasharray', '5 5')
1095
+ // .style('color', 'var(--chart-axis-color, #999999)'); // Use CSS variable
1096
+ // }
1097
+ // if (lineData != null) {
1098
+ // if (lineData && self.chartConfiguration.showLineChartAxis) {
1099
+ // svgYAxisRight
1100
+ // .append('g')
1101
+ // .attr('class', 'lib-stacked-y-axis-text1')
1102
+ // .attr('style', self.chartConfiguration.yAxisCustomTextStyles)
1103
+ // .attr('transform', 'translate(' + 0 + ',0)')
1104
+ // .call(yLineAxis);
1105
+ // }
1106
+ // }
1107
+ // /**
1108
+ // * used to display y label
1109
+ // */
1110
+ // // if (this.isZoomedOut) {
1111
+ // // svg
1112
+ // // .selectAll('.lib-xaxis-labels-texts-drilldown')
1113
+ // // .attr('class', 'lib-display-hidden');
1114
+ // // }
1115
+ // if (this.isZoomedOut) {
1116
+ // svg
1117
+ // .selectAll('.lib-xaxis-labels-texts-drilldown')
1118
+ // .each((d, i, nodes) => {
1119
+ // const text = d3.select(nodes[i]);
1120
+ // const label = text.text();
1121
+ // if (label.indexOf('\n') > -1) {
1122
+ // const lines = label.split('\n');
1123
+ // text.text(null);
1124
+ // lines.forEach((line, idx) => {
1125
+ // text.append('tspan')
1126
+ // .text(line)
1127
+ // .attr('x', 0)
1128
+ // .attr('dy', idx === 0 ? '1em' : '1.1em');
1129
+ // });
1130
+ // } else {
1131
+ // const words = label.split(' ');
1132
+ // text.text(null);
1133
+ // words.forEach((word, index) => {
1134
+ // text.append('tspan').text(word);
1135
+ // });
1136
+ // }
1137
+ // })
1138
+ // .style('fill', 'var(--chart-text-color)')
1139
+ // .attr('transform', null);
1140
+ // svg
1141
+ // .select('.x-axis')
1142
+ // .attr('transform', `translate(0, ${height - margin.bottom + 10})`);
1143
+ // }
1144
+ // /**
1145
+ // * used to write y labels based on configuration
1146
+ // */
1147
+ // if (metaData.yLabel) {
1148
+ // const yPosition = isria ? 0 - margin.left / 2 - 30 : 0 - margin.left / 2 - 40;
1149
+ // svgYAxisLeft
1150
+ // .append('text')
1151
+ // .attr('class', 'lib-axis-group-label font-size-1')
1152
+ // .attr('style', self.chartConfiguration.yAxisCustomlabelStyles)
1153
+ // .attr('transform', 'rotate(-90)')
1154
+ // .attr('y', yPosition)
1155
+ // .attr('x', 0 - height / 2)
1156
+ // .attr('dy', '1em')
1157
+ // .style('text-anchor', 'middle')
1158
+ // .attr('fill', 'var(--chart-text-color)');
1159
+ // if (this.chartConfiguration.isMultiChartGridLine === undefined) {
1160
+ // svgYAxisLeft
1161
+ // .selectAll('.lib-axis-group-label')
1162
+ // .style('font-size', 'smaller')
1163
+ // .text(metaData.yLabel);
1164
+ // } else {
1165
+ // svg
1166
+ // .selectAll('.lib-axis-group-label')
1167
+ // .attr('class', 'lib-ylabel-weeklyCharts')
1168
+ // .text(metaData.yLabel.toLowerCase());
1169
+ // }
1170
+ // }
1171
+ // if (this.chartData.targetLineData) {
1172
+ // const yZero = y(this.chartData.targetLineData.target);
1173
+ // svg
1174
+ // .append('line')
1175
+ // .attr('x1', 0)
1176
+ // .attr('x2', width)
1177
+ // .attr('y1', yZero)
1178
+ // .attr('y2', yZero)
1179
+ // .style('stroke-dasharray', '5 5')
1180
+ // .style('stroke', this.chartData.targetLineData.color);
1181
+ // // svgYAxisRight
1182
+ // // .append('line')
1183
+ // // .attr('x1', 0)
1184
+ // // .attr('x2', rightSvgWidth)
1185
+ // // .attr('y1', yZero)
1186
+ // // .attr('y2', yZero)
1187
+ // // .style('stroke', this.chartData.targetLineData.color);
1188
+ // svgYAxisRight
1189
+ // .append('foreignObject')
1190
+ // .attr('transform', 'translate(' + 0 + ',' + (yZero - 30) + ')')
1191
+ // .attr('width', rightSvgWidth)
1192
+ // .attr('height', 50)
1193
+ // .append('xhtml:div')
1194
+ // .attr('class', 'target-display')
1195
+ // .style('color', 'var(--chart-text-color)')
1196
+ // .html(function () {
1197
+ // let dataTypeTemp = '';
1198
+ // let targetLineName = 'target';
1199
+ // if (metaData.dataType) {
1200
+ // dataTypeTemp = metaData.dataType;
1201
+ // }
1202
+ // if (
1203
+ // self.chartData.targetLineData &&
1204
+ // self.chartData.targetLineData.targetName
1205
+ // ) {
1206
+ // targetLineName = self.chartData.targetLineData.targetName;
1207
+ // }
1208
+ // return (
1209
+ // `<div>${targetLineName}</div>` +
1210
+ // '<div>' +
1211
+ // self.chartData.targetLineData.target +
1212
+ // '' +
1213
+ // dataTypeTemp +
1214
+ // '</div>'
1215
+ // );
1216
+ // });
1217
+ // }
1218
+ // if (this.chartConfiguration.isDrilldownChart) {
1219
+ // /**
1220
+ // * used by drilldown charts
1221
+ // */
1222
+ // // svg
1223
+ // // .selectAll('.lib-axis-group-label')
1224
+ // // .attr('class', 'lib-ylabel-drilldowncharts')
1225
+ // // .text(metaData.yLabel.toLowerCase());
1226
+ // svg.selectAll('g.x1.axis1 g.tick line').style('display', 'none');
1227
+ // }
1228
+ // if (metaData.xLabel) {
1229
+ // function isAcronym(label) {
1230
+ // return (
1231
+ // (label.length <= 4 && /^[A-Z]+$/.test(label)) ||
1232
+ // (label === label.toUpperCase() && /[A-Z]/.test(label))
1233
+ // );
1234
+ // }
1235
+ // const xLabelText = metaData.xLabel;
1236
+ // const isAcr = isAcronym(xLabelText.replace(/[^A-Za-z]/g, ''));
1237
+ // const xPosition = isria ? (height + margin.top + margin.bottom) : (height + margin.top + margin.bottom + 40);
1238
+ // svg
1239
+ // .append('text')
1240
+ // .attr('class', function () {
1241
+ // let baseClass = 'lib-axis-group-label font-size-1';
1242
+ // if (self.chartConfiguration.isDrilldownChart)
1243
+ // return baseClass + ' lib-xlabel-drilldowncharts';
1244
+ // if (self.chartConfiguration.isMultiChartGridLine != undefined)
1245
+ // return baseClass + ' lib-xlabel-weeklyCharts';
1246
+ // return baseClass + ' lib-axis-waterfall-label';
1247
+ // })
1248
+ // .attr('style', self.chartConfiguration.xAxisCustomlabelStyles)
1249
+ // .attr(
1250
+ // 'transform',
1251
+ // 'translate(' + width / 2 + ' ,' + xPosition + ')'
1252
+ // )
1253
+ // .style('text-anchor', 'middle')
1254
+ // .style('fill', 'var(--chart-text-color)')
1255
+ // .text(isAcr ? xLabelText.toUpperCase() : xLabelText.toLowerCase())
1256
+ // .style('text-transform', isAcr ? 'none' : 'capitalize');
1257
+ // }
1258
+ // if (metaData.lineyLabel) {
1259
+ // svgYAxisRight
1260
+ // .append('text')
1261
+ // .attr('class', 'lib-axis-group-label lib-line-axis')
1262
+ // .attr('fill', 'var(--chart-text-color)')
1263
+ // .attr('style', self.chartConfiguration.yAxisCustomlabelStyles)
1264
+ // .attr('transform', 'translate(0,0) rotate(90)')
1265
+ // .attr('y', 0 - 100)
1266
+ // .attr('x', 0 + 100)
1267
+ // .attr('dy', '5em')
1268
+ // .style('text-anchor', 'middle')
1269
+ // .style('font-size', 'smaller')
1270
+ // .text(metaData.lineyLabel);
1271
+ // }
1272
+ // if (lineData) {
1273
+ // svg
1274
+ // .append('path')
1275
+ // .datum(lineData)
1276
+ // .attr('fill', 'none')
1277
+ // .attr('stroke', self.chartConfiguration.lineGraphColor)
1278
+ // .attr('stroke-width', 1.5)
1279
+ // .attr(
1280
+ // 'd',
1281
+ // d3
1282
+ // .line()
1283
+ // .x(function (d) {
1284
+ // return x(d.name) + x.bandwidth() / 2;
1285
+ // })
1286
+ // .y(function (d) {
1287
+ // return lineYscale(d.value);
1288
+ // })
1289
+ // );
1290
+ // var dot = svg
1291
+ // .selectAll('myCircles')
1292
+ // .data(lineData)
1293
+ // .enter()
1294
+ // .append('g')
1295
+ // .on('click', function (d) {
1296
+ // if (
1297
+ // !metaData.barWithoutClick ||
1298
+ // !metaData.barWithoutClick.length ||
1299
+ // (!metaData.barWithoutClick.includes(d?.name) &&
1300
+ // !metaData.barWithoutClick.includes(d?.key))
1301
+ // )
1302
+ // self.handleClick(d);
1303
+ // });
1304
+ // dot
1305
+ // .append('circle')
1306
+ // .attr('fill', function (d) {
1307
+ // return self.chartConfiguration.lineGraphColor;
1308
+ // })
1309
+ // .attr('stroke', 'none')
1310
+ // .attr('cx', function (d) {
1311
+ // return x(d.name) + x.bandwidth() / 2;
1312
+ // })
1313
+ // .attr('cy', function (d) {
1314
+ // return lineYscale(d.value);
1315
+ // })
1316
+ // .style('cursor', () =>
1317
+ // self.chartData.metaData.hasDrillDown ? 'pointer' : 'default'
1318
+ // )
1319
+ // .attr('r', 3);
1320
+ // if (self.chartConfiguration.lineGraphColor) {
1321
+ // dot
1322
+ // .append('text')
1323
+ // .attr('class', 'dot')
1324
+ // .attr('fill', 'var(--chart-text-color)')
1325
+ // .attr('color', self.chartConfiguration.lineGraphColor)
1326
+ // .attr('style', 'font-size: ' + '.85em')
1327
+ // .attr('x', function (d, i) {
1328
+ // return x(d.name) + x.bandwidth() / 2;
1329
+ // })
1330
+ // .attr('y', function (d) {
1331
+ // return lineYscale(d.value);
1332
+ // })
1333
+ // .attr('dy', '-1em')
1334
+ // .text(function (d) {
1335
+ // return self.chartConfiguration.labelFormatter(d.value);
1336
+ // });
1337
+ // }
1338
+ // }
1339
+ // }
104
1340
  initializegroupChart() {
105
- var self = this;
1341
+ // ==================== VARIABLE DECLARATIONS ====================
1342
+ const self = this;
106
1343
  let data = [];
107
1344
  let metaData = null;
108
1345
  let keyList = null;
109
1346
  let lineData = null;
110
1347
  let colorMap = {};
111
- var formatFromBackend;
112
- var formatForHugeNumbers;
1348
+ let formatFromBackend;
1349
+ let formatForHugeNumbers;
1350
+ // Device detection
113
1351
  const isMobile = window.innerWidth < 576;
114
1352
  const isTablet = window.innerWidth >= 576 && window.innerWidth < 992;
115
1353
  const isDesktop = window.innerWidth >= 992;
116
- let isria = this.customChartConfiguration.isRia;
117
- var x;
118
- var alternate_text = false;
119
- var short_tick_length = 4;
120
- var long_tick_length = 16;
121
- /**
122
- * longer tick length needed for weekly charts
123
- */
124
- var short_tick_length_bg = 5;
125
- var long_tick_length_bg = 30;
126
- var leftAndRightSpaces = 50;
127
- var rightSvgWidth = 60;
128
- var tempScale;
129
- for (var i in this.defaultConfiguration) {
130
- this.chartConfiguration[i] = ChartHelper.getValueByConfigurationType(i, this.defaultConfiguration, this.customChartConfiguration);
1354
+ const isria = this.customChartConfiguration.isRia;
1355
+ // Chart scale variables
1356
+ let x;
1357
+ let tempScale;
1358
+ // Tick length constants
1359
+ const SHORT_TICK_LENGTH = 4;
1360
+ const LONG_TICK_LENGTH = 16;
1361
+ const SHORT_TICK_LENGTH_BG = 5;
1362
+ const LONG_TICK_LENGTH_BG = 30;
1363
+ const LEFT_AND_RIGHT_SPACES = 50;
1364
+ const RIGHT_SVG_WIDTH = 60;
1365
+ // Flags
1366
+ let alternate_text = false;
1367
+ // ==================== CONFIGURATION SETUP ====================
1368
+ for (const key in this.defaultConfiguration) {
1369
+ this.chartConfiguration[key] = ChartHelper.getValueByConfigurationType(key, this.defaultConfiguration, this.customChartConfiguration);
131
1370
  }
1371
+ // Extract chart data
132
1372
  data = this.chartData.data;
133
1373
  metaData = this.chartData.metaData;
134
1374
  lineData = this.chartData.lineData;
135
- // if (lineData || this.chartData.targetLineData) {
136
- // rightSvgWidth = 60;
137
- // }
1375
+ // Setup color mappings
138
1376
  if (!metaData.colorAboveTarget) {
139
1377
  metaData['colorAboveTarget'] = metaData.colors;
140
1378
  }
141
1379
  colorMap = metaData.colors;
142
1380
  keyList = metaData.keyList;
143
- var chartContainer = d3.select(this.containerElt.nativeElement);
144
- var verticalstackedcontainer = d3.select(this.groupcontainerElt.nativeElement);
145
- var margin = this.chartConfiguration.margin;
1381
+ // ==================== CONTAINER SETUP ====================
1382
+ const chartContainer = d3.select(this.containerElt.nativeElement);
1383
+ const verticalstackedcontainer = d3.select(this.groupcontainerElt.nativeElement);
1384
+ const margin = this.chartConfiguration.margin;
146
1385
  const { width, height } = this.calculateChartDimensions(chartContainer, verticalstackedcontainer, margin, self);
147
- /**
148
- * for hiding header
149
- * used by weekly charts
150
- */
151
- if (this.chartConfiguration.isHeaderVisible != undefined)
1386
+ // ==================== VISIBILITY CONFIGURATION ====================
1387
+ if (this.chartConfiguration.isHeaderVisible !== undefined) {
152
1388
  this.isHeaderVisible = this.chartConfiguration.isHeaderVisible;
153
- /**
154
- * for hiding legends
155
- * used by weekly charts
156
- */
157
- if (this.chartConfiguration.legendVisible != undefined) {
1389
+ }
1390
+ if (this.chartConfiguration.legendVisible !== undefined) {
158
1391
  this.legendVisible = this.chartConfiguration.legendVisible;
159
1392
  }
160
- /**
161
- * for removing background color so that it can take parents color
162
- *
163
- */
164
- if (this.chartConfiguration.isTransparentBackground != undefined) {
165
- this.isTransparentBackground =
166
- this.chartConfiguration.isTransparentBackground;
167
- }
168
- /**
169
- * format data values based on configuration received
170
- */
171
- if (this.chartConfiguration.textFormatter != undefined) {
1393
+ if (this.chartConfiguration.isTransparentBackground !== undefined) {
1394
+ this.isTransparentBackground = this.chartConfiguration.isTransparentBackground;
1395
+ }
1396
+ // ==================== DATA FORMATTING ====================
1397
+ if (this.chartConfiguration.textFormatter !== undefined) {
172
1398
  formatFromBackend = ChartHelper.dataValueFormatter(this.chartConfiguration.textFormatter);
173
1399
  formatForHugeNumbers = ChartHelper.dataValueFormatter('.2s');
174
1400
  }
175
- const { outerContainer, svgYAxisLeft, svgYAxisRight, innerContainer, svg } = this.createChartContainers(chartContainer, margin, height, rightSvgWidth, self, width);
176
- var subgroups = keyList;
177
- var groups = d3
178
- .map(data, function (d) {
179
- return d.name;
180
- })
181
- .keys();
182
- /**
183
- * x axis range made similar to line chart or vertical stack so that all the charts will get aligned with each other.
184
- */
185
- if (this.chartConfiguration.isMultiChartGridLine != undefined) {
186
- x = d3
187
- .scaleBand()
1401
+ // ==================== SVG CONTAINERS CREATION ====================
1402
+ const { outerContainer, svgYAxisLeft, svgYAxisRight, innerContainer, svg } = this.createChartContainers(chartContainer, margin, height, RIGHT_SVG_WIDTH, self, width);
1403
+ // ==================== SCALES SETUP ====================
1404
+ const subgroups = keyList;
1405
+ const groups = d3.map(data, (d) => d.name).keys();
1406
+ // X-axis scale configuration
1407
+ if (this.chartConfiguration.isMultiChartGridLine !== undefined) {
1408
+ x = d3.scaleBand()
188
1409
  .rangeRound([width, 0])
189
1410
  .align(0.5)
190
1411
  .padding([0.5])
191
- .domain(data.map(function (d) {
192
- return d.name.toLowerCase();
193
- }));
1412
+ .domain(data.map((d) => d.name.toLowerCase()));
194
1413
  }
195
1414
  else {
196
- x = d3
197
- .scaleBand()
1415
+ x = d3.scaleBand()
198
1416
  .domain(groups)
199
- .range([leftAndRightSpaces, width - rightSvgWidth - leftAndRightSpaces])
1417
+ .range([LEFT_AND_RIGHT_SPACES, width - RIGHT_SVG_WIDTH - LEFT_AND_RIGHT_SPACES])
200
1418
  .padding([0.3]);
201
1419
  }
202
- // x.bandwidth(96);
203
- var xScaleFromOrigin = d3
204
- .scaleBand()
1420
+ const xScaleFromOrigin = d3.scaleBand()
205
1421
  .domain(groups)
206
- .range([0, width - rightSvgWidth]);
207
- // .padding([0.2]);
208
- if (this.chartConfiguration.isMultiChartGridLine == undefined) {
209
- /**
210
- * normal ticks for all dashboard charts
211
- */
212
- svg
213
- .append('g')
1422
+ .range([0, width - RIGHT_SVG_WIDTH]);
1423
+ // ==================== X-AXIS RENDERING ====================
1424
+ this.renderXAxis(svg, x, height, metaData, subgroups, data, SHORT_TICK_LENGTH_BG, LONG_TICK_LENGTH_BG, self, isria, isMobile);
1425
+ // ==================== Y-AXIS SETUP ====================
1426
+ const y = d3.scaleLinear().rangeRound([height, 0]);
1427
+ let maxValue = this.calculateMaxValue(data, keyList);
1428
+ if (this.chartConfiguration.customYscale) {
1429
+ maxValue = maxValue * this.chartConfiguration.customYscale;
1430
+ }
1431
+ if (this.chartData.targetLineData && maxValue < this.chartData.targetLineData.target) {
1432
+ maxValue = maxValue < 10 && this.chartData.targetLineData.target < 10
1433
+ ? this.chartData.targetLineData.target + 3
1434
+ : this.chartData.targetLineData.target + 20;
1435
+ }
1436
+ y.domain([0, maxValue]).nice();
1437
+ // ==================== LINE CHART Y-SCALE ====================
1438
+ let lineYscale;
1439
+ let yLineAxis;
1440
+ if (lineData != null) {
1441
+ const result = this.setupLineYScale(lineData, height, self);
1442
+ lineYscale = result.lineYscale;
1443
+ yLineAxis = result.yLineAxis;
1444
+ }
1445
+ // ==================== GRID LINES ====================
1446
+ this.renderGridLines(svg, x, y, height, width, self);
1447
+ // ==================== BARS RENDERING ====================
1448
+ const xSubgroup = this.setupXSubgroupScale(subgroups, x, self);
1449
+ const color = d3.scaleOrdinal()
1450
+ .domain(subgroups)
1451
+ .range(Object.values(metaData.colors));
1452
+ this.renderBars(svg, data, subgroups, x, xSubgroup, y, height, color, metaData, self, LEFT_AND_RIGHT_SPACES, tempScale, isria);
1453
+ // ==================== BAR LABELS ====================
1454
+ if (this.chartConfiguration.textsOnBar !== undefined && !this.isZoomedOut) {
1455
+ this.renderBarLabels(svg, data, subgroups, x, xSubgroup, y, height, metaData, self, tempScale, isria);
1456
+ }
1457
+ // ==================== Y-AXIS RENDERING ====================
1458
+ this.renderYAxis(svg, svgYAxisLeft, svgYAxisRight, y, yLineAxis, lineData, self, isria, margin);
1459
+ // ==================== AXIS LABELS ====================
1460
+ this.renderAxisLabels(svg, svgYAxisLeft, svgYAxisRight, metaData, width, height, margin, self, isria, RIGHT_SVG_WIDTH);
1461
+ // ==================== TARGET LINE ====================
1462
+ if (this.chartData.targetLineData) {
1463
+ this.renderTargetLine(svg, svgYAxisRight, y, width, RIGHT_SVG_WIDTH, metaData, self);
1464
+ }
1465
+ // ==================== LINE CHART ====================
1466
+ if (lineData) {
1467
+ this.renderLineChart(svg, lineData, x, lineYscale, metaData, self);
1468
+ }
1469
+ // ==================== ZOOM HANDLING ====================
1470
+ if (this.isZoomedOut) {
1471
+ this.handleZoomOut(svg, height, margin);
1472
+ }
1473
+ }
1474
+ // ==================== HELPER METHODS ====================
1475
+ renderXAxis(svg, x, height, metaData, subgroups, data, shortTickLengthBg, longTickLengthBg, self, isria, isMobile) {
1476
+ let alternate_text = false;
1477
+ if (this.chartConfiguration.isMultiChartGridLine === undefined) {
1478
+ // Normal ticks for dashboard charts
1479
+ svg.append('g')
214
1480
  .attr('class', 'x1 axis1')
215
- .attr('transform', 'translate(0,' + height + ')')
1481
+ .attr('transform', `translate(0,${height})`)
216
1482
  .call(d3.axisBottom(x))
217
1483
  .call((g) => g.select('.domain').remove());
218
1484
  svg.selectAll('g.x1.axis1 g.tick line').remove();
219
- // Only move x-axis labels further down for grouped charts if there is no xLabel
220
- if (subgroups.length > 1 && !metaData.xLabel) {
221
- svg
222
- .selectAll('g.x1.axis1 g.tick text')
223
- .attr('class', 'lib-xaxis-labels-texts-drilldown')
224
- .style('fill', 'var(--chart-text-color)')
225
- .attr('y', 32); // Increase distance from bars (default is ~9)
226
- }
227
- else {
228
- svg
229
- .selectAll('g.x1.axis1 g.tick text')
230
- .attr('class', 'lib-xaxis-labels-texts-drilldown')
231
- .style('fill', 'var(--chart-text-color)');
232
- }
1485
+ const yOffset = subgroups.length > 1 && !metaData.xLabel ? 32 : 0;
1486
+ svg.selectAll('g.x1.axis1 g.tick text')
1487
+ .attr('class', 'lib-xaxis-labels-texts-drilldown')
1488
+ .style('fill', 'var(--chart-text-color)')
1489
+ .attr('y', yOffset || null);
233
1490
  }
234
1491
  else {
235
- /**
236
- * bigger ticks for weekly charts and more space from x axis to labels
237
- */
238
- /**
239
- * draw x axis
240
- */
241
- svg
242
- .append('g')
1492
+ // Bigger ticks for weekly charts
1493
+ svg.append('g')
243
1494
  .attr('class', 'x1 axis1')
244
- .attr('transform', 'translate(0,' + height + ')')
1495
+ .attr('transform', `translate(0,${height})`)
245
1496
  .call(d3.axisBottom(x).tickSize(0))
246
1497
  .call((g) => g.select('.domain').attr('fill', 'none'));
247
- /**
248
- * tick line size in alternate fashion
249
- */
1498
+ // Alternate tick line sizes
250
1499
  svg.selectAll('g.x1.axis1 g.tick line').attr('y2', function () {
251
- if (alternate_text &&
252
- self.chartConfiguration.isNoAlternateXaxisText == undefined) {
1500
+ if (alternate_text && self.chartConfiguration.isNoAlternateXaxisText === undefined) {
253
1501
  alternate_text = false;
254
- return long_tick_length_bg - 7;
1502
+ return longTickLengthBg - 7;
255
1503
  }
256
1504
  else {
257
1505
  alternate_text = true;
258
- return short_tick_length_bg - 4;
1506
+ return shortTickLengthBg - 4;
259
1507
  }
260
1508
  });
261
- /**
262
- * reset the flag so that values can be shown in same alternate fashion
263
- */
264
1509
  alternate_text = false;
265
- /**
266
- * print x-axis label texts
267
- * used by weekly charts
268
- */
269
- svg
270
- .selectAll('g.x1.axis1 g.tick text')
1510
+ // X-axis label texts
1511
+ svg.selectAll('g.x1.axis1 g.tick text')
271
1512
  .attr('class', 'lib-xaxis-labels-texts-weeklycharts')
272
1513
  .attr('y', function () {
273
- // Minimize gap in maximized (fullscreen) view for weekly charts
274
1514
  if (self.chartConfiguration.isFullScreen) {
275
- return short_tick_length_bg;
1515
+ return shortTickLengthBg;
276
1516
  }
277
1517
  if (alternate_text) {
278
1518
  alternate_text = false;
279
- return long_tick_length_bg;
1519
+ return longTickLengthBg;
280
1520
  }
281
1521
  else {
282
1522
  alternate_text = true;
283
- return short_tick_length_bg;
1523
+ return shortTickLengthBg;
284
1524
  }
285
1525
  });
286
1526
  }
1527
+ // Apply labels on same line configuration
287
1528
  if (self.chartConfiguration.xLabelsOnSameLine) {
288
- const xAxisLabels = svg
289
- .selectAll('g.x1.axis1 g.tick text')
290
- .attr('class', 'lib-xaxis-labels-texts-drilldown')
291
- .style('font-size', this.isHeaderVisible ? '18px' : '14px')
292
- .attr('text-anchor', 'middle')
293
- .attr('y', function (d) {
294
- // For grouped bar charts with many bars and xLabel present, only add 5 if the label is a date
295
- if (subgroups.length > 1 && data.length > 8 && metaData.xLabel) {
296
- const isDateLabel = /\d{2,4}[-\/]/.test(d);
297
- if (self.chartConfiguration.isFullScreen) {
298
- return isDateLabel ? short_tick_length_bg + 14 : short_tick_length_bg;
299
- }
300
- return isDateLabel ? short_tick_length_bg + 14 : short_tick_length_bg;
301
- }
302
- // For grouped bar charts with many bars and NO xLabel, add space as before, but reduce in fullscreen
303
- if (subgroups.length > 1 && data.length > 8 && !metaData.xLabel) {
304
- const chartHasExtraBottom = (self.chartConfiguration.margin && self.chartConfiguration.margin.bottom >= 40);
305
- if (self.chartConfiguration.isFullScreen) {
306
- // Reduce extra gap in maximized view
307
- return short_tick_length_bg + 2;
308
- }
309
- return chartHasExtraBottom ? short_tick_length_bg : short_tick_length_bg + 10;
310
- }
311
- // Default/fallback logic for other cases
312
- let baseY = self.isHeaderVisible ? short_tick_length_bg + 25 : short_tick_length_bg;
313
- if (subgroups.length > 1 &&
314
- !metaData.xLabel &&
315
- (/\d{2,4}[-\/]\d{2}[-\/]\d{2,4}/.test(d) || /\d{2,4}[-\/]\d{2,4}/.test(d))) {
316
- baseY = self.isHeaderVisible ? short_tick_length_bg + 15 : short_tick_length_bg + 25;
317
- }
318
- if (/\d{2,4}[-\/]\d{2,4}/.test(d) && d.indexOf(' ') > -1) {
319
- baseY += 4;
320
- }
321
- // In maximized view, reduce baseY slightly for grouped bars
322
- if (self.chartConfiguration.isFullScreen && subgroups.length > 1) {
323
- baseY = Math.max(short_tick_length_bg, baseY - 10);
324
- }
325
- return baseY;
326
- })
327
- .attr('x', function (d) {
328
- if (self.chartData.data.length > 8 && !self.isZoomedOut) {
329
- return 1; // Move first line text slightly to the left in zoom-in view for better alignment
330
- }
331
- return 0; // Default position
332
- })
333
- .text(function (d) {
334
- var isValueToBeIgnored = false;
335
- if (isMobile && !self.isHeaderVisible) {
336
- let firstPart = d.split(/[\s\-]+/)[0];
337
- return firstPart.substring(0, 3).toLowerCase();
338
- }
339
- data.map((indiv) => {
340
- if (indiv.name &&
341
- indiv.name.toLowerCase() == d.trim().toLowerCase() &&
342
- indiv[metaData.keyList[0]] == -1) {
343
- isValueToBeIgnored = true;
344
- }
345
- });
346
- if (isValueToBeIgnored) {
347
- return '';
348
- }
349
- // Always add space before and after hyphen for date range labels, even when header is visible and label is single line
350
- // Apply for grouped bar charts and single bar charts, header visible, single line
351
- const dateRangeRegex = /(\d{2,4}[-\/]\d{2}[-\/]\d{2,4})\s*-\s*(\d{2,4}[-\/]\d{2}[-\/]\d{2,4})/;
352
- if (dateRangeRegex.test(d.trim())) {
353
- return d.trim().replace(dateRangeRegex, (m, d1, d2) => `${d1} - ${d2}`);
354
- }
355
- // Split date and week labels into two lines in grouped bar zoom-in view (and minimized view)
356
- const isDateLabel = /\d{2,4}[-\/]/.test(d);
357
- const isWeekLabel = /week|wk|w\d+/i.test(d);
358
- if (subgroups.length > 1 && !self.isZoomedOut && data.length > 8 && d.indexOf(' ') > -1 && (isDateLabel || isWeekLabel)) {
359
- var first = d.substring(0, d.indexOf(' '));
360
- var second = d.substring(d.indexOf(' ') + 1).trim();
361
- return first + '\n' + second;
362
- }
363
- // Also keep previous logic for minimized view
364
- if (isDateLabel) {
365
- if (!self.isHeaderVisible && data.length > 8 && d.indexOf(' ') > -1) {
366
- var first = d.substring(0, d.indexOf(' '));
367
- var second = d.substring(d.indexOf(' ') + 1).trim();
368
- return first + '\n' + second;
369
- }
370
- else {
371
- return d;
372
- }
373
- }
374
- if (d.trim().indexOf(' ') > -1) {
375
- return d.trim().substring(0, d.indexOf(' ')).toLowerCase();
376
- }
377
- return d.toLowerCase();
378
- // If label looks like a date (contains digits and - or /)
379
- const isDateLabel2 = /\d{2,4}[-\/]/.test(d);
380
- // Only split date/week labels if there are many grouped bars and header is not visible
381
- if (isDateLabel) {
382
- if (!self.isHeaderVisible && data.length > 8 && d.indexOf(' ') > -1) {
383
- var first = d.substring(0, d.indexOf(' '));
384
- var second = d.substring(d.indexOf(' ') + 1).trim();
385
- return first + '\n' + second;
386
- }
387
- else {
388
- return d;
389
- }
390
- }
391
- if (d.trim().indexOf(' ') > -1) {
392
- return d.trim().substring(0, d.indexOf(' ')).toLowerCase();
393
- }
394
- return d.toLowerCase();
395
- });
396
- // Now apply writing-mode: sideways-lr for grouped charts with date labels in zoomed-out view and many bars
397
- xAxisLabels.each(function (d) {
398
- // Only apply writing-mode for exact date labels, not those containing 'week' or similar
399
- const isDateLabel = /^(\d{2,4}[-\/])?\d{2,4}[-\/]\d{2,4}$/.test(d.trim());
400
- const isWeekLabel = /week|wk|w\d+/i.test(d);
401
- if (subgroups.length > 1 && self.isZoomedOut && data.length > 8 && isDateLabel && !isWeekLabel) {
402
- d3.select(this).style('writing-mode', 'sideways-lr');
403
- }
404
- });
405
- if (!isMobile) {
406
- svg
407
- .selectAll('g.x1.axis1 g.tick')
408
- .filter(function (d) {
409
- return !/\d{2,4}[-\/]/.test(d); // Only process non-date labels
410
- })
411
- .append('text')
412
- .attr('class', 'lib-xaxis-labels-texts-drilldown')
413
- .attr('y', long_tick_length_bg)
414
- .attr('fill', 'var(--chart-text-color)')
415
- .attr('x', function (d) {
416
- if (self.chartData.data.length > 8 && !self.isZoomedOut) {
417
- return 1; // Move text slightly to the left
418
- }
419
- return 0; // Default position
420
- })
421
- .text(function (d) {
422
- if (d.trim().indexOf(' ') > -1) {
423
- return d.trim().substring(d.indexOf(' '), d.length).toLowerCase();
424
- }
425
- return '';
426
- });
427
- }
1529
+ this.applyXLabelsOnSameLine(svg, subgroups, data, metaData, self, shortTickLengthBg, isMobile, isria);
428
1530
  }
1531
+ // Mobile override for RIA
429
1532
  if (isria && self.chartData.data.length > 8) {
430
- svg
431
- .selectAll('g.x1.axis1 g.tick text')
1533
+ svg.selectAll('g.x1.axis1 g.tick text')
432
1534
  .classed('mobile-xaxis-override', true)
433
- .text(function (d) {
434
- return d.substring(0, 3);
435
- })
1535
+ .text((d) => d.substring(0, 3))
436
1536
  .style('font-size', '12px')
437
1537
  .attr('y', 5)
438
1538
  .attr('x', 5)
439
1539
  .style('text-anchor', 'middle');
440
1540
  }
1541
+ // Mobile override
441
1542
  if (isMobile && !this.isHeaderVisible) {
442
- svg
443
- .selectAll('g.x1.axis1 g.tick text')
1543
+ svg.selectAll('g.x1.axis1 g.tick text')
444
1544
  .classed('mobile-xaxis-override', true);
445
1545
  }
446
- /**y scale for left y axis */
447
- var y = d3.scaleLinear().rangeRound([height, 0]);
448
- var maxValue = d3.max(data, (d) => d3.max(keyList, (key) => +d[key]));
449
- if (maxValue == 0) {
450
- if (this.chartData.targetLineData) {
451
- maxValue = this.chartData.targetLineData.target + 20;
1546
+ }
1547
+ applyXLabelsOnSameLine(svg, subgroups, data, metaData, self, shortTickLengthBg, isMobile, isria) {
1548
+ const xAxisLabels = svg.selectAll('g.x1.axis1 g.tick text')
1549
+ .attr('class', 'lib-xaxis-labels-texts-drilldown')
1550
+ .style('font-size', this.isHeaderVisible ? '18px' : '14px')
1551
+ .attr('text-anchor', 'middle')
1552
+ .attr('y', (d) => this.calculateXLabelYPosition(d, subgroups, data, metaData, self, shortTickLengthBg))
1553
+ .attr('x', (d) => (self.chartData.data.length > 8 && !self.isZoomedOut) ? 1 : 0)
1554
+ .text((d) => this.formatXLabelText(d, data, metaData, subgroups, self, isMobile));
1555
+ // Apply writing-mode for grouped charts with date labels in zoomed-out view
1556
+ xAxisLabels.each(function (d) {
1557
+ const isDateLabel = /^(\d{2,4}[-\/])?\d{2,4}[-\/]\d{2,4}$/.test(d.trim());
1558
+ const isWeekLabel = /week|wk|w\d+/i.test(d);
1559
+ if (subgroups.length > 1 && self.isZoomedOut && data.length > 8 && isDateLabel && !isWeekLabel) {
1560
+ d3.select(this).style('writing-mode', 'sideways-lr');
452
1561
  }
453
- else {
454
- maxValue = 100;
1562
+ });
1563
+ // Add second line for non-date labels on desktop
1564
+ if (!isMobile) {
1565
+ svg.selectAll('g.x1.axis1 g.tick')
1566
+ .filter((d) => !/\d{2,4}[-\/]/.test(d))
1567
+ .append('text')
1568
+ .attr('class', 'lib-xaxis-labels-texts-drilldown')
1569
+ .attr('y', 30)
1570
+ .attr('fill', 'var(--chart-text-color)')
1571
+ .attr('x', (d) => (self.chartData.data.length > 8 && !self.isZoomedOut) ? 1 : 0)
1572
+ .text((d) => {
1573
+ if (d.trim().indexOf(' ') > -1) {
1574
+ return d.trim().substring(d.indexOf(' '), d.length).toLowerCase();
1575
+ }
1576
+ return '';
1577
+ });
1578
+ }
1579
+ }
1580
+ calculateXLabelYPosition(d, subgroups, data, metaData, self, shortTickLengthBg) {
1581
+ // For grouped bar charts with many bars and xLabel present
1582
+ if (subgroups.length > 1 && data.length > 8 && metaData.xLabel) {
1583
+ const isDateLabel = /\d{2,4}[-\/]/.test(d);
1584
+ return isDateLabel ? shortTickLengthBg + 14 : shortTickLengthBg;
1585
+ }
1586
+ // For grouped bar charts with many bars and NO xLabel
1587
+ if (subgroups.length > 1 && data.length > 8 && !metaData.xLabel) {
1588
+ const chartHasExtraBottom = self.chartConfiguration.margin && self.chartConfiguration.margin.bottom >= 40;
1589
+ if (self.chartConfiguration.isFullScreen) {
1590
+ return shortTickLengthBg + 2;
455
1591
  }
1592
+ return chartHasExtraBottom ? shortTickLengthBg : shortTickLengthBg + 10;
456
1593
  }
457
- if (this.chartConfiguration.customYscale) {
458
- /**
459
- * increase y-scale so that values wont cross or exceed out of range
460
- * used in weekly charts
461
- */
462
- maxValue = maxValue * this.chartConfiguration.customYscale;
1594
+ // Default/fallback logic
1595
+ let baseY = self.isHeaderVisible ? shortTickLengthBg + 25 : shortTickLengthBg;
1596
+ if (subgroups.length > 1 && !metaData.xLabel &&
1597
+ (/\d{2,4}[-\/]\d{2}[-\/]\d{2,4}/.test(d) || /\d{2,4}[-\/]\d{2,4}/.test(d))) {
1598
+ baseY = self.isHeaderVisible ? shortTickLengthBg + 15 : shortTickLengthBg + 25;
463
1599
  }
464
- if (this.chartData.targetLineData &&
465
- maxValue < this.chartData.targetLineData.target) {
466
- maxValue =
467
- maxValue < 10 && this.chartData.targetLineData.target < 10
468
- ? this.chartData.targetLineData.target + 3
469
- : this.chartData.targetLineData.target + 20;
1600
+ if (/\d{2,4}[-\/]\d{2,4}/.test(d) && d.indexOf(' ') > -1) {
1601
+ baseY += 4;
470
1602
  }
471
- y.domain([0, maxValue]).nice();
472
- let lineYscale;
473
- if (lineData != null) {
474
- let maxLineValue = d3.max(lineData, function (d) {
475
- return +d.value;
476
- });
477
- maxLineValue = maxLineValue * this.chartConfiguration.customYscale;
478
- let minLineValue = d3.min(lineData, function (d) {
479
- return +d.value;
480
- });
481
- if (maxLineValue > 0)
482
- minLineValue = minLineValue - 3;
483
- if (minLineValue > 0) {
484
- minLineValue = 0;
1603
+ if (self.chartConfiguration.isFullScreen && subgroups.length > 1) {
1604
+ baseY = Math.max(shortTickLengthBg, baseY - 10);
1605
+ }
1606
+ return baseY;
1607
+ }
1608
+ formatXLabelText(d, data, metaData, subgroups, self, isMobile) {
1609
+ if (isMobile && !self.isHeaderVisible) {
1610
+ const firstPart = d.split(/[\s\-]+/)[0];
1611
+ return firstPart.substring(0, 3).toLowerCase();
1612
+ }
1613
+ // Check if value should be ignored
1614
+ const isValueToBeIgnored = data.some((indiv) => indiv.name && indiv.name.toLowerCase() === d.trim().toLowerCase() &&
1615
+ indiv[metaData.keyList[0]] === -1);
1616
+ if (isValueToBeIgnored) {
1617
+ return '';
1618
+ }
1619
+ // Handle date range labels
1620
+ const dateRangeRegex = /(\d{2,4}[-\/]\d{2}[-\/]\d{2,4})\s*-\s*(\d{2,4}[-\/]\d{2}[-\/]\d{2,4})/;
1621
+ if (dateRangeRegex.test(d.trim())) {
1622
+ return d.trim().replace(dateRangeRegex, (m, d1, d2) => `${d1} - ${d2}`);
1623
+ }
1624
+ // Split date and week labels into two lines
1625
+ const isDateLabel = /\d{2,4}[-\/]/.test(d);
1626
+ const isWeekLabel = /week|wk|w\d+/i.test(d);
1627
+ if (subgroups.length > 1 && !self.isZoomedOut && data.length > 8 &&
1628
+ d.indexOf(' ') > -1 && (isDateLabel || isWeekLabel)) {
1629
+ const first = d.substring(0, d.indexOf(' '));
1630
+ const second = d.substring(d.indexOf(' ') + 1).trim();
1631
+ return `${first}\n${second}`;
1632
+ }
1633
+ // Handle date labels in minimized view
1634
+ if (isDateLabel) {
1635
+ if (!self.isHeaderVisible && data.length > 8 && d.indexOf(' ') > -1) {
1636
+ const first = d.substring(0, d.indexOf(' '));
1637
+ const second = d.substring(d.indexOf(' ') + 1).trim();
1638
+ return `${first}\n${second}`;
485
1639
  }
486
- lineYscale = d3
487
- .scaleLinear()
488
- .domain([minLineValue, maxLineValue])
489
- .range([height, minLineValue]);
1640
+ return d;
490
1641
  }
491
- let yLineAxis;
492
- if (lineYscale != null) {
493
- yLineAxis = d3
494
- .axisRight(lineYscale)
495
- .ticks(self.chartConfiguration.numberOfYTicks)
496
- .tickSize(0)
497
- .tickFormat(self.chartConfiguration.yLineAxisLabelFomatter);
498
- }
499
- /**
500
- * show x-axis grid between labels
501
- * used by weekly charts
502
- */
1642
+ // Handle labels with spaces
1643
+ if (d.trim().indexOf(' ') > -1) {
1644
+ return d.trim().substring(0, d.indexOf(' ')).toLowerCase();
1645
+ }
1646
+ return d.toLowerCase();
1647
+ }
1648
+ calculateMaxValue(data, keyList) {
1649
+ let maxValue = d3.max(data, (d) => d3.max(keyList, (key) => +d[key]));
1650
+ if (maxValue === 0) {
1651
+ if (this.chartData.targetLineData) {
1652
+ maxValue = this.chartData.targetLineData.target + 20;
1653
+ }
1654
+ else {
1655
+ maxValue = 100;
1656
+ }
1657
+ }
1658
+ return maxValue;
1659
+ }
1660
+ setupLineYScale(lineData, height, self) {
1661
+ let maxLineValue = d3.max(lineData, (d) => +d.value);
1662
+ maxLineValue = maxLineValue * self.chartConfiguration.customYscale;
1663
+ let minLineValue = d3.min(lineData, (d) => +d.value);
1664
+ if (maxLineValue > 0)
1665
+ minLineValue = minLineValue - 3;
1666
+ if (minLineValue > 0)
1667
+ minLineValue = 0;
1668
+ const lineYscale = d3.scaleLinear()
1669
+ .domain([minLineValue, maxLineValue])
1670
+ .range([height, minLineValue]);
1671
+ const yLineAxis = d3.axisRight(lineYscale)
1672
+ .ticks(self.chartConfiguration.numberOfYTicks)
1673
+ .tickSize(0)
1674
+ .tickFormat(self.chartConfiguration.yLineAxisLabelFomatter);
1675
+ return { lineYscale, yLineAxis };
1676
+ }
1677
+ renderGridLines(svg, x, y, height, width, self) {
1678
+ // X-axis grid between labels
503
1679
  if (self.chartConfiguration.isXgridBetweenLabels) {
504
- svg
505
- .append('g')
1680
+ svg.append('g')
506
1681
  .attr('class', 'grid')
507
- .attr('transform', 'translate(' + x.bandwidth() / 2 + ',' + height + ')')
1682
+ .attr('transform', `translate(${x.bandwidth() / 2},${height})`)
508
1683
  .call(d3.axisBottom(x).tickSize(-height).tickFormat(''))
509
1684
  .style('stroke-dasharray', '5 5')
510
- .style('color', 'var(--chart-grid-color, #999999)') // Use CSS variable
1685
+ .style('color', 'var(--chart-grid-color, #999999)')
511
1686
  .call((g) => g.select('.domain').remove());
512
1687
  }
1688
+ // Y-axis grid
513
1689
  if (this.chartConfiguration.yAxisGrid) {
514
- svg
515
- .append('g')
516
- .call(d3
517
- .axisLeft(y)
518
- .ticks(self.chartConfiguration.numberOfYTicks)
519
- .tickSize(-width))
1690
+ svg.append('g')
1691
+ .call(d3.axisLeft(y).ticks(self.chartConfiguration.numberOfYTicks).tickSize(-width))
520
1692
  .style('color', 'var(--chart-axis-color, #B9B9B9)')
521
1693
  .style('opacity', '0.5')
522
- .call((g) => {
523
- g.select('.domain')
524
- .remove()
525
- .style('stroke', 'var(--chart-domain-color, #000000)'); // Add CSS variable for domain
526
- });
1694
+ .call((g) => g.select('.domain').remove().style('stroke', 'var(--chart-domain-color, #000000)'));
527
1695
  }
528
1696
  else {
529
- svg
530
- .append('g')
1697
+ svg.append('g')
531
1698
  .call(d3.axisLeft(y).ticks(self.chartConfiguration.numberOfYTicks))
532
1699
  .style('color', 'var(--chart-axis-color, #B9B9B9)')
533
1700
  .style('opacity', '0.5')
534
- .call((g) => {
535
- g.select('.domain')
536
- .style('stroke', 'var(--chart-domain-color, #000000)') // Add CSS variable for domain
537
- .style('stroke-width', '1px'); // Ensure visibility
538
- });
1701
+ .call((g) => g.select('.domain')
1702
+ .style('stroke', 'var(--chart-domain-color, #000000)')
1703
+ .style('stroke-width', '1px'));
539
1704
  }
540
- var xSubgroup = d3.scaleBand().domain(subgroups);
1705
+ }
1706
+ setupXSubgroupScale(subgroups, x, self) {
1707
+ const xSubgroup = d3.scaleBand().domain(subgroups);
541
1708
  if (subgroups.length > 1 && !this.isZoomedOut) {
542
- // For grouped bar charts in zoom-in view, use full x.bandwidth() for subgroups
543
1709
  xSubgroup.range([0, x.bandwidth()]);
544
1710
  }
545
1711
  else if (subgroups.length === 1 && !this.isZoomedOut) {
546
- // For single-bar (non-grouped) charts in zoom-in view, set bar width to 100 (increased from 80)
547
1712
  xSubgroup.range([0, 100]);
548
1713
  }
549
- else if (this.chartConfiguration.isMultiChartGridLine == undefined) {
1714
+ else if (this.chartConfiguration.isMultiChartGridLine === undefined) {
550
1715
  xSubgroup.range([0, x.bandwidth()]);
551
1716
  }
552
1717
  else {
553
- // used to make grouped bars with lesser width as we are not using padding for width
554
1718
  xSubgroup.range([0, x.bandwidth()]);
555
1719
  }
556
- // if (this.chartConfiguration.isDrilldownChart) {
557
- // }
558
- var color = d3
559
- .scaleOrdinal()
560
- .domain(subgroups)
561
- .range(Object.values(metaData.colors));
562
- // var colorAboveTarget = d3
563
- // .scaleOrdinal()
564
- // .domain(subgroups)
565
- // .range(Object.values(metaData.colorAboveTarget));
566
- var state = svg
567
- .append('g')
1720
+ return xSubgroup;
1721
+ }
1722
+ renderBars(svg, data, subgroups, x, xSubgroup, y, height, color, metaData, self, leftAndRightSpaces, tempScale, isria) {
1723
+ const state = svg.append('g')
568
1724
  .selectAll('.state')
569
1725
  .data(data)
570
1726
  .enter()
571
1727
  .append('g')
572
- .attr('transform', function (d) {
573
- return 'translate(' + x(d.name) + ',0)';
574
- });
575
- state
576
- .selectAll('rect')
577
- .data(function (d) {
578
- let newList = [];
579
- subgroups.map(function (key) {
580
- // if (key !== "group") {
581
- let obj = { key: key, value: d[key], name: d.name };
582
- newList.push(obj);
583
- // }
584
- });
585
- return newList;
586
- })
1728
+ .attr('transform', (d) => `translate(${x(d.name)},0)`);
1729
+ const bars = state.selectAll('rect')
1730
+ .data((d) => this.prepareBarData(d, subgroups))
587
1731
  .enter()
588
1732
  .append('rect')
589
1733
  .attr('class', 'bars')
590
- .on('click', function (d) {
591
- if (d.key != 'Target') {
592
- if (!metaData.barWithoutClick ||
593
- !metaData.barWithoutClick.length ||
594
- (!metaData.barWithoutClick.includes(d?.name) &&
595
- !metaData.barWithoutClick.includes(d?.key)))
596
- // self.handleClick(d.data.name);
597
- self.handleClick(d);
598
- }
599
- })
600
- .attr('x', function (d) {
601
- if (self.chartConfiguration.isDrilldownChart) {
602
- data.map((indiv) => {
603
- if (indiv.name == d.name) {
604
- let keys = Object.keys(indiv).filter((temp, i) => i != 0);
605
- tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);
606
- if (x.bandwidth() > 100) {
607
- // Increase bar width a bit in zoom-in view
608
- let reducedBarWidth = 60;
609
- if (!self.isZoomedOut) {
610
- reducedBarWidth = 30;
611
- }
612
- if (self.chartData.data.length == 1) {
613
- if (Object.keys(self.chartData.data[0]).length == 2) {
614
- tempScale.range([
615
- 0 + (x.bandwidth() - reducedBarWidth) / 2,
616
- x.bandwidth() - (x.bandwidth() - reducedBarWidth) / 2,
617
- ]);
618
- }
619
- else
620
- tempScale.range([
621
- 0 + (x.bandwidth() - reducedBarWidth) / 2,
622
- x.bandwidth() - (x.bandwidth() - reducedBarWidth) / 2,
623
- ]);
624
- }
625
- else
626
- tempScale.range([
627
- 0 + (x.bandwidth() - reducedBarWidth) / 2,
628
- x.bandwidth() - (x.bandwidth() - reducedBarWidth) / 2,
629
- ]);
630
- }
631
- }
632
- });
633
- return tempScale(d.key);
634
- }
635
- return xSubgroup(d.key);
636
- })
637
- .attr('y', function (d) {
638
- if (d.value == -1) {
639
- return y(0);
640
- }
641
- if (d.value >= 0) {
642
- const barHeight = height - y(d.value);
643
- const minHeight = self.chartConfiguration.defaultBarHeight || 2;
644
- return barHeight < minHeight ? y(0) - minHeight : y(d.value);
645
- }
646
- return y(0);
647
- })
648
- .attr('width', function (d) {
649
- // For grouped bar charts in zoom-in view, set bar width to 50 for maximum thickness
650
- if (subgroups.length > 1 && !self.isZoomedOut) {
651
- return 50;
652
- }
653
- // For single-bar (non-grouped) charts in zoom-in view, set bar width to 80
654
- if (subgroups.length === 1 && !self.isZoomedOut) {
655
- return 80;
656
- }
657
- let tempScale = d3.scaleBand().domain([]).range([0, 0]);
658
- // Default logic for other chart types
659
- if (self.chartConfiguration.isDrilldownChart) {
660
- data.map((indiv) => {
661
- if (indiv.name == d.name) {
662
- let keys = Object.keys(indiv).filter((temp, i) => i != 0);
663
- tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);
664
- if (x.bandwidth() > 100) {
665
- // Increase bar width a bit in zoom-in view
666
- let reducedBarWidth = 60;
667
- if (!self.isZoomedOut) {
668
- reducedBarWidth = 100;
669
- }
670
- if (self.chartData.data.length == 1) {
671
- if (Object.keys(self.chartData.data[0]).length == 2) {
672
- tempScale.range([
673
- 0 + (x.bandwidth() - reducedBarWidth) / 2,
674
- x.bandwidth() - (x.bandwidth() - reducedBarWidth) / 2,
675
- ]);
676
- }
677
- else
678
- tempScale.range([
679
- 0 + (x.bandwidth() - reducedBarWidth) / 2,
680
- x.bandwidth() - (x.bandwidth() - reducedBarWidth) / 2,
681
- ]);
682
- }
683
- else
684
- tempScale.range([
685
- 0 + (x.bandwidth() - reducedBarWidth) / 2,
686
- x.bandwidth() - (x.bandwidth() - reducedBarWidth) / 2,
687
- ]);
688
- }
689
- }
690
- });
691
- return self.isZoomedOut
692
- ? tempScale.bandwidth()
693
- : self.chartData.data.length && self.chartData.data.length > 8
694
- ? tempScale.bandwidth()
695
- : tempScale.bandwidth();
696
- }
697
- return self.isZoomedOut
698
- ? tempScale.bandwidth()
699
- : self.chartData.data.length && self.chartData.data.length > 8
700
- ? tempScale.bandwidth()
701
- : tempScale.bandwidth();
702
- })
703
- .attr('height', function (d) {
704
- if (d.value == -1) {
705
- return height - y(0);
706
- }
707
- if (d.value >= 0) {
708
- const barHeight = height - y(d.value);
709
- const minHeight = self.chartConfiguration.defaultBarHeight || 2;
710
- return Math.max(barHeight, minHeight);
1734
+ .on('click', (d) => this.handleBarClick(d, metaData, self))
1735
+ .attr('x', (d) => this.calculateBarX(d, data, x, xSubgroup, self, tempScale))
1736
+ .attr('y', (d) => this.calculateBarY(d, y, height, self))
1737
+ .attr('width', (d) => this.calculateBarWidth(d, data, subgroups, x, xSubgroup, self, tempScale))
1738
+ .attr('height', (d) => this.calculateBarHeight(d, y, height, self))
1739
+ .style('cursor', () => (metaData.hasDrillDown && !isria) ? 'pointer' : 'default')
1740
+ .attr('fill', (d) => this.getBarColor(d, metaData, self));
1741
+ // Attach mouse events if not RIA
1742
+ if (!isria && (this.chartConfiguration.displayTitleOnTop ||
1743
+ (this.chartConfiguration.textsOnBar === undefined &&
1744
+ this.chartConfiguration.displayTitleOnTop === undefined))) {
1745
+ bars.on('mouseout', (d, i) => this.handleMouseOut(svg))
1746
+ .on('mouseover', (d, i) => this.handleMouseOver(d, svg, data, x, y, height, metaData, self, leftAndRightSpaces, tempScale));
1747
+ }
1748
+ }
1749
+ prepareBarData(d, subgroups) {
1750
+ const newList = [];
1751
+ subgroups.forEach((key) => {
1752
+ newList.push({ key: key, value: d[key], name: d.name });
1753
+ });
1754
+ return newList;
1755
+ }
1756
+ handleBarClick(d, metaData, self) {
1757
+ if (d.key !== 'Target') {
1758
+ if (!metaData.barWithoutClick || !metaData.barWithoutClick.length ||
1759
+ (!metaData.barWithoutClick.includes(d?.name) &&
1760
+ !metaData.barWithoutClick.includes(d?.key))) {
1761
+ self.handleClick(d);
711
1762
  }
712
- return height - y(0);
713
- })
714
- .style('cursor', function (d) {
715
- if (metaData.hasDrillDown && !isria)
716
- return 'pointer';
717
- else
718
- return 'default';
719
- })
720
- .attr('fill', function (d) {
721
- if (d.value &&
722
- self.chartData.targetLineData &&
723
- d.value >= parseFloat(self.chartData.targetLineData.target) &&
724
- self.chartData.metaData.colorAboveTarget) {
725
- const key = d.key.toLowerCase();
726
- const colorAboveTarget = Object.keys(self.chartData.metaData.colorAboveTarget).find(k => k.toLowerCase() === key);
727
- if (colorAboveTarget) {
728
- return self.chartData.metaData.colorAboveTarget[colorAboveTarget];
1763
+ }
1764
+ }
1765
+ calculateBarX(d, data, x, xSubgroup, self, tempScale) {
1766
+ if (self.chartConfiguration.isDrilldownChart) {
1767
+ return this.calculateDrilldownBarX(d, data, x, self, tempScale);
1768
+ }
1769
+ return xSubgroup(d.key);
1770
+ }
1771
+ calculateDrilldownBarX(d, data, x, self, tempScale) {
1772
+ data.forEach((indiv) => {
1773
+ if (indiv.name === d.name) {
1774
+ const keys = Object.keys(indiv).filter((temp, i) => i !== 0);
1775
+ tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);
1776
+ if (x.bandwidth() > 100) {
1777
+ const reducedBarWidth = self.isZoomedOut ? 60 : 30;
1778
+ const offset = (x.bandwidth() - reducedBarWidth) / 2;
1779
+ tempScale.range([offset, x.bandwidth() - offset]);
729
1780
  }
730
1781
  }
731
- return self.chartData.metaData.colors[d.key];
732
1782
  });
733
- /**
734
- * display angled texts on the bars
735
- */
736
- if (this.chartConfiguration.textsOnBar != undefined && !this.isZoomedOut) {
737
- state
738
- .selectAll('text')
739
- .data(function (d) {
740
- let newList = [];
741
- subgroups.map(function (key) {
742
- let obj = { key: key, value: d[key], name: d.name };
743
- newList.push(obj);
744
- });
745
- return newList;
746
- })
747
- .enter()
748
- .append('text')
749
- .attr('fill', 'var(--chart-text-color)')
750
- .attr('x', function (d) {
751
- return 0;
752
- })
753
- .attr('y', function (d) {
754
- return 0;
755
- })
756
- .attr('class', 'lib-data-labels-weeklycharts')
757
- .text(function (d) {
758
- return d.key && d.value
759
- ? d.key.length > 20
760
- ? d.key.substring(0, 17) + '...'
761
- : d.key
762
- : '';
763
- })
764
- .style('fill', function (d) {
765
- return '#000';
766
- })
767
- .style('font-weight', 'bold')
768
- .style('font-size', function (d) {
769
- if (self.isZoomedOut) {
770
- return '9px'; // 👈 Zoomed out mode
771
- }
772
- if (self.chartConfiguration.isDrilldownChart) {
773
- if (window.innerWidth > 1900) {
774
- return '18px';
775
- }
776
- else if (window.innerWidth < 1400) {
777
- return '10px';
778
- }
779
- else {
780
- return '14px';
781
- }
782
- }
783
- else {
784
- return '14px';
785
- }
786
- })
787
- .attr('transform', function (d) {
788
- data.map((indiv) => {
789
- if (indiv.name == d.name) {
790
- let keys = Object.keys(indiv).filter((temp, i) => i != 0);
791
- var temp;
792
- tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);
793
- if (x.bandwidth() > 100) {
794
- if (self.chartData.data.length == 1) {
795
- if (Object.keys(self.chartData.data[0]).length == 2) {
796
- tempScale.range([
797
- 0 + (x.bandwidth() - 200) / 2,
798
- x.bandwidth() - (x.bandwidth() - 200) / 2,
799
- ]);
800
- // .padding(0.05);
801
- }
802
- else
803
- tempScale.range([
804
- 0 + (x.bandwidth() - 300) / 2,
805
- x.bandwidth() - (x.bandwidth() - 300) / 2,
806
- ]);
807
- // .padding(0.05);
808
- }
809
- else
810
- tempScale.range([
811
- 0 + (x.bandwidth() - 125) / 2,
812
- x.bandwidth() - (x.bandwidth() - 125) / 2,
813
- ]);
814
- }
1783
+ return tempScale(d.key);
1784
+ }
1785
+ calculateBarY(d, y, height, self) {
1786
+ if (d.value === -1) {
1787
+ return y(0);
1788
+ }
1789
+ if (d.value >= 0) {
1790
+ const barHeight = height - y(d.value);
1791
+ const minHeight = self.chartConfiguration.defaultBarHeight || 2;
1792
+ return barHeight < minHeight ? y(0) - minHeight : y(d.value);
1793
+ }
1794
+ return y(0);
1795
+ }
1796
+ calculateBarWidth(d, data, subgroups, x, xSubgroup, self, tempScale) {
1797
+ // For grouped bar charts in zoom-in view
1798
+ if (subgroups.length > 1 && !self.isZoomedOut) {
1799
+ return 50;
1800
+ }
1801
+ // For single-bar charts in zoom-in view
1802
+ if (subgroups.length === 1 && !self.isZoomedOut) {
1803
+ return 80;
1804
+ }
1805
+ // Default logic for drilldown charts
1806
+ if (self.chartConfiguration.isDrilldownChart) {
1807
+ let calculatedScale = d3.scaleBand().domain([]).range([0, 0]);
1808
+ data.forEach((indiv) => {
1809
+ if (indiv.name === d.name) {
1810
+ const keys = Object.keys(indiv).filter((temp, i) => i !== 0);
1811
+ calculatedScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);
1812
+ if (x.bandwidth() > 100) {
1813
+ const reducedBarWidth = self.isZoomedOut ? 60 : 100;
1814
+ const offset = (x.bandwidth() - reducedBarWidth) / 2;
1815
+ calculatedScale.range([offset, x.bandwidth() - offset]);
815
1816
  }
816
- });
817
- /**
818
- * if set, then all texts ll be horizontal
819
- */
820
- if (self.chartConfiguration.textAlwaysHorizontal) {
821
- return ('translate(' + xSubgroup(d.key) + ',' + (y(d.value) - 3) + ')');
822
1817
  }
823
- /**
824
- * rotate texts having more than one digits
825
- */
826
- // if (d.value > 9)
827
- if (!isNaN(tempScale(d.key)))
828
- return ('translate(' +
829
- (tempScale(d.key) + tempScale.bandwidth() * 0.55) +
830
- ',' +
831
- (y(0) - 10) +
832
- ') rotate(270)');
833
- return 'translate(0,0)';
834
- // else
835
- // return (
836
- // 'translate(' +
837
- // (tempScale(d.key) + tempScale.bandwidth() / 2) +
838
- // ',' +
839
- // y(0) +
840
- // ')'
841
- // );
842
- })
843
- .on('click', function (d) {
844
- if (!metaData.barWithoutClick ||
845
- !metaData.barWithoutClick.length ||
846
- (!metaData.barWithoutClick.includes(d?.name) &&
847
- !metaData.barWithoutClick.includes(d?.key)))
848
- self.handleClick(d);
849
1818
  });
850
- if (!isria) {
851
- state
852
- .selectAll('.lib-data-labels-weeklycharts')
853
- .on('mouseout', handleMouseOut)
854
- .on('mouseover', handleMouseOver);
855
- }
1819
+ return calculatedScale.bandwidth();
1820
+ }
1821
+ return xSubgroup.bandwidth();
1822
+ }
1823
+ calculateBarHeight(d, y, height, self) {
1824
+ if (d.value === -1) {
1825
+ return height - y(0);
856
1826
  }
857
- if (this.chartConfiguration.displayTitleOnTop || (this.chartConfiguration.textsOnBar == undefined &&
858
- this.chartConfiguration.displayTitleOnTop == undefined)) {
859
- if (!isria) {
860
- state
861
- .selectAll('rect')
862
- .on('mouseout', handleMouseOut)
863
- .on('mouseover', handleMouseOver);
1827
+ if (d.value >= 0) {
1828
+ const barHeight = height - y(d.value);
1829
+ const minHeight = self.chartConfiguration.defaultBarHeight || 2;
1830
+ return Math.max(barHeight, minHeight);
1831
+ }
1832
+ return height - y(0);
1833
+ }
1834
+ getBarColor(d, metaData, self) {
1835
+ if (d.value && self.chartData.targetLineData &&
1836
+ d.value >= parseFloat(self.chartData.targetLineData.target) &&
1837
+ self.chartData.metaData.colorAboveTarget) {
1838
+ const key = d.key.toLowerCase();
1839
+ const colorAboveTarget = Object.keys(self.chartData.metaData.colorAboveTarget)
1840
+ .find(k => k.toLowerCase() === key);
1841
+ if (colorAboveTarget) {
1842
+ return self.chartData.metaData.colorAboveTarget[colorAboveTarget];
864
1843
  }
865
1844
  }
866
- function handleMouseOver(d, i) {
867
- svg.selectAll('.lib-verticalstack-title-ontop').remove();
868
- svg
869
- .append('foreignObject')
870
- .attr('x', function () {
871
- // ...existing code for tempScale calculation...
872
- var elementsCounter;
873
- data.map((indiv) => {
874
- if (indiv.name == d.name) {
875
- let keys = Object.keys(indiv).filter((temp, i) => i != 0);
876
- elementsCounter = keys.length;
877
- tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);
878
- if (x.bandwidth() > 100) {
879
- if (self.chartData.data.length == 1) {
880
- if (Object.keys(self.chartData.data[0]).length == 2) {
881
- tempScale.range([
882
- 0 + (x.bandwidth() - 200) / 2,
883
- x.bandwidth() - (x.bandwidth() - 200) / 2,
884
- ]);
885
- }
886
- else
887
- tempScale.range([
888
- 0 + (x.bandwidth() - 300) / 2,
889
- x.bandwidth() - (x.bandwidth() - 300) / 2,
890
- ]);
891
- }
892
- else
893
- tempScale.range([
894
- 0 + (x.bandwidth() - 125) / 2,
895
- x.bandwidth() - (x.bandwidth() - 125) / 2,
896
- ]);
897
- }
1845
+ return self.chartData.metaData.colors[d.key];
1846
+ }
1847
+ renderBarLabels(svg, data, subgroups, x, xSubgroup, y, height, metaData, self, tempScale, isria) {
1848
+ const state = svg.selectAll('.state');
1849
+ const labels = state.selectAll('text')
1850
+ .data((d) => this.prepareBarData(d, subgroups))
1851
+ .enter()
1852
+ .append('text')
1853
+ .attr('fill', 'var(--chart-text-color)')
1854
+ .attr('x', 0)
1855
+ .attr('y', 0)
1856
+ .attr('class', 'lib-data-labels-weeklycharts')
1857
+ .text((d) => this.formatBarLabel(d))
1858
+ .style('fill', '#000')
1859
+ .style('font-weight', 'bold')
1860
+ .style('font-size', (d) => this.calculateLabelFontSize(self))
1861
+ .attr('transform', (d) => this.calculateLabelTransform(d, data, x, xSubgroup, y, self, tempScale))
1862
+ .on('click', (d) => this.handleBarClick(d, metaData, self));
1863
+ if (!isria) {
1864
+ labels.on('mouseout', () => this.handleMouseOut(svg))
1865
+ .on('mouseover', (d) => this.handleMouseOver(d, svg, data, x, y, height, metaData, self, 50, tempScale));
1866
+ }
1867
+ }
1868
+ formatBarLabel(d) {
1869
+ if (!d.key || !d.value)
1870
+ return '';
1871
+ return d.key.length > 20 ? d.key.substring(0, 17) + '...' : d.key;
1872
+ }
1873
+ calculateLabelFontSize(self) {
1874
+ if (self.isZoomedOut)
1875
+ return '9px';
1876
+ if (self.chartConfiguration.isDrilldownChart) {
1877
+ if (window.innerWidth > 1900)
1878
+ return '18px';
1879
+ if (window.innerWidth < 1400)
1880
+ return '10px';
1881
+ return '14px';
1882
+ }
1883
+ return '14px';
1884
+ }
1885
+ calculateLabelTransform(d, data, x, xSubgroup, y, self, tempScale) {
1886
+ let calculatedScale;
1887
+ data.forEach((indiv) => {
1888
+ if (indiv.name === d.name) {
1889
+ const keys = Object.keys(indiv).filter((temp, i) => i !== 0);
1890
+ calculatedScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);
1891
+ if (x.bandwidth() > 100) {
1892
+ if (self.chartData.data.length === 1) {
1893
+ const reducedWidth = Object.keys(self.chartData.data[0]).length === 2 ? 200 : 300;
1894
+ const offset = (x.bandwidth() - reducedWidth) / 2;
1895
+ calculatedScale.range([offset, x.bandwidth() - offset]);
898
1896
  }
899
- });
900
- if (metaData.hasDrillDown) {
901
- if (tempScale.bandwidth() + leftAndRightSpaces * 2 > 180) {
902
- return (x(d.name) + tempScale(d.key) + tempScale.bandwidth() / 2 - 90);
1897
+ else {
1898
+ const offset = (x.bandwidth() - 125) / 2;
1899
+ calculatedScale.range([offset, x.bandwidth() - offset]);
903
1900
  }
904
- return (x(d.name) +
905
- tempScale(d.key) -
906
- (tempScale.bandwidth() + leftAndRightSpaces * 2) / 2 +
907
- tempScale.bandwidth() / 2);
908
1901
  }
909
- else
910
- return x(d.name) + tempScale(d.key) - (tempScale.bandwidth() + leftAndRightSpaces * 2) / 2 + tempScale.bandwidth() / 2;
911
- })
912
- .attr('class', 'lib-verticalstack-title-ontop')
913
- .attr('y', function () {
914
- return y(d.value) - 3 - 40 - 10;
915
- })
916
- .attr('dy', function () {
917
- return d.class;
918
- })
919
- .attr('width', function () {
920
- data.map((indiv) => {
921
- if (indiv.name == d.name) {
922
- let keys = Object.keys(indiv).filter((temp, i) => i != 0);
923
- tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);
924
- if (x.bandwidth() > 100) {
925
- if (self.chartData.data.length == 1) {
926
- if (Object.keys(self.chartData.data[0]).length == 2) {
927
- tempScale.range([
928
- 0 + (x.bandwidth() - 200) / 2,
929
- x.bandwidth() - (x.bandwidth() - 200) / 2,
930
- ]);
931
- }
932
- else
933
- tempScale.range([
934
- 0 + (x.bandwidth() - 300) / 2,
935
- x.bandwidth() - (x.bandwidth() - 300) / 2,
936
- ]);
937
- }
938
- else
939
- tempScale.range([
940
- 0 + (x.bandwidth() - 125) / 2,
941
- x.bandwidth() - (x.bandwidth() - 125) / 2,
942
- ]);
943
- }
1902
+ }
1903
+ });
1904
+ if (self.chartConfiguration.textAlwaysHorizontal) {
1905
+ return `translate(${xSubgroup(d.key)},${y(d.value) - 3})`;
1906
+ }
1907
+ if (!isNaN(calculatedScale(d.key))) {
1908
+ return `translate(${calculatedScale(d.key) + calculatedScale.bandwidth() * 0.55},${y(0) - 10}) rotate(270)`;
1909
+ }
1910
+ return 'translate(0,0)';
1911
+ }
1912
+ handleMouseOver(d, svg, data, x, y, height, metaData, self, leftAndRightSpaces, tempScale) {
1913
+ svg.selectAll('.lib-verticalstack-title-ontop').remove();
1914
+ let calculatedScale;
1915
+ let elementsCounter;
1916
+ data.forEach((indiv) => {
1917
+ if (indiv.name === d.name) {
1918
+ const keys = Object.keys(indiv).filter((temp, i) => i !== 0);
1919
+ elementsCounter = keys.length;
1920
+ calculatedScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);
1921
+ if (x.bandwidth() > 100) {
1922
+ if (self.chartData.data.length === 1) {
1923
+ const reducedWidth = Object.keys(self.chartData.data[0]).length === 2 ? 200 : 300;
1924
+ const offset = (x.bandwidth() - reducedWidth) / 2;
1925
+ calculatedScale.range([offset, x.bandwidth() - offset]);
944
1926
  }
945
- });
946
- if (metaData.hasDrillDown) {
947
- if (tempScale.bandwidth() + leftAndRightSpaces * 2 > 180) {
948
- return '180px';
1927
+ else {
1928
+ const offset = (x.bandwidth() - 125) / 2;
1929
+ calculatedScale.range([offset, x.bandwidth() - offset]);
949
1930
  }
950
- return tempScale.bandwidth() + leftAndRightSpaces * 2;
951
1931
  }
952
- else
953
- return tempScale.bandwidth() + leftAndRightSpaces * 2;
954
- })
955
- .attr('height', 50)
956
- .append('xhtml:div')
957
- .attr('class', 'title')
958
- .style('z-index', 99)
959
- .html(function () {
960
- let barLabel = d.key;
961
- let dataType = metaData.dataType ? metaData.dataType : '';
962
- let value = d.value;
963
- let desiredText = '<span class="title-bar-name">' + barLabel + '</span>';
964
- desiredText +=
965
- '<span class="title-bar-value"><span>' +
966
- value +
967
- '</span>' +
968
- dataType +
969
- '</span>';
970
- return desiredText;
971
- });
1932
+ }
1933
+ });
1934
+ const xPosition = this.calculateTooltipX(d, x, calculatedScale, metaData, leftAndRightSpaces);
1935
+ const width = this.calculateTooltipWidth(calculatedScale, metaData, leftAndRightSpaces);
1936
+ svg.append('foreignObject')
1937
+ .attr('x', xPosition)
1938
+ .attr('class', 'lib-verticalstack-title-ontop')
1939
+ .attr('y', y(d.value) - 3 - 40 - 10)
1940
+ .attr('dy', d.class)
1941
+ .attr('width', width)
1942
+ .attr('height', 50)
1943
+ .append('xhtml:div')
1944
+ .attr('class', 'title')
1945
+ .style('z-index', 99)
1946
+ .html(() => this.generateTooltipHTML(d, metaData));
1947
+ }
1948
+ calculateTooltipX(d, x, calculatedScale, metaData, leftAndRightSpaces) {
1949
+ if (metaData.hasDrillDown) {
1950
+ if (calculatedScale.bandwidth() + leftAndRightSpaces * 2 > 180) {
1951
+ return x(d.name) + calculatedScale(d.key) + calculatedScale.bandwidth() / 2 - 90;
1952
+ }
1953
+ return x(d.name) + calculatedScale(d.key) -
1954
+ (calculatedScale.bandwidth() + leftAndRightSpaces * 2) / 2 +
1955
+ calculatedScale.bandwidth() / 2;
972
1956
  }
973
- function handleMouseOut(d, i) {
974
- svg.selectAll('.lib-verticalstack-title-ontop').remove();
1957
+ return x(d.name) + calculatedScale(d.key) -
1958
+ (calculatedScale.bandwidth() + leftAndRightSpaces * 2) / 2 +
1959
+ calculatedScale.bandwidth() / 2;
1960
+ }
1961
+ calculateTooltipWidth(calculatedScale, metaData, leftAndRightSpaces) {
1962
+ if (metaData.hasDrillDown) {
1963
+ if (calculatedScale.bandwidth() + leftAndRightSpaces * 2 > 180) {
1964
+ return '180px';
1965
+ }
1966
+ return calculatedScale.bandwidth() + leftAndRightSpaces * 2;
975
1967
  }
976
- svg
977
- .append('g')
978
- .attr('class', 'x2 axis2')
979
- .attr('transform', 'translate(0,' + height + ')')
980
- .style('color', 'var(--chart-axis-color, #000)') // Use CSS variable instead of hardcoded #000
981
- .call(d3.axisBottom(xScaleFromOrigin).tickSize(0))
982
- .call((g) => g.select('.domain').attr('fill', 'none'));
983
- svg.selectAll('g.x2.axis2 g.tick text').style('display', 'none');
984
- svg
985
- .append('g')
1968
+ return calculatedScale.bandwidth() + leftAndRightSpaces * 2;
1969
+ }
1970
+ generateTooltipHTML(d, metaData) {
1971
+ const barLabel = d.key;
1972
+ const dataType = metaData.dataType || '';
1973
+ const value = d.value;
1974
+ let html = `<span class="title-bar-name">${barLabel}</span>`;
1975
+ html += `<span class="title-bar-value"><span>${value}</span>${dataType}</span>`;
1976
+ return html;
1977
+ }
1978
+ handleMouseOut(svg) {
1979
+ svg.selectAll('.lib-verticalstack-title-ontop').remove();
1980
+ }
1981
+ renderYAxis(svg, svgYAxisLeft, svgYAxisRight, y, yLineAxis, lineData, self, isria, margin) {
1982
+ // Hidden y-axis for reference
1983
+ svg.append('g')
986
1984
  .attr('class', 'lib-stacked-y-axis-text yaxis-dashed')
987
1985
  .attr('style', self.chartConfiguration.yAxisCustomTextStyles)
988
1986
  .attr('transform', 'translate(0,0)')
989
1987
  .call(y)
990
1988
  .style('display', 'none');
991
- svgYAxisLeft
992
- .append('g')
1989
+ // Left y-axis
1990
+ svgYAxisLeft.append('g')
993
1991
  .append('g')
994
1992
  .attr('class', 'lib-yaxis-labels-texts-drilldown yaxis-dashed')
995
1993
  .attr('style', self.chartConfiguration.yAxisCustomTextStyles)
996
1994
  .attr('transform', 'translate(0,0)')
997
- .call(d3
998
- .axisLeft(y)
1995
+ .call(d3.axisLeft(y)
999
1996
  .tickSize(0)
1000
1997
  .ticks(self.chartConfiguration.numberOfYTicks)
1001
- .tickFormat(function (d) {
1998
+ .tickFormat((d) => {
1002
1999
  const formatted = self.chartConfiguration.yAxisLabelFomatter
1003
2000
  ? self.chartConfiguration.yAxisLabelFomatter(d)
1004
2001
  : d;
1005
2002
  return formatted >= 1000 ? formatted / 1000 + 'k' : formatted;
1006
2003
  }))
1007
2004
  .call((g) => {
1008
- // Style the domain line for theme support
1009
2005
  g.select('.domain')
1010
2006
  .style('stroke', 'var(--chart-domain-color, #000000)')
1011
2007
  .style('stroke-width', '1px');
1012
2008
  })
1013
2009
  .selectAll('text')
1014
2010
  .style('fill', 'var(--chart-text-color)');
1015
- svgYAxisRight
1016
- .append('g')
2011
+ // Right y-axis (hidden by default)
2012
+ svgYAxisRight.append('g')
1017
2013
  .attr('class', 'lib-yaxis-labels-texts-drilldown yaxis-dashed')
1018
2014
  .attr('style', self.chartConfiguration.yAxisCustomTextStyles)
1019
2015
  .attr('transform', 'translate(0,0)')
1020
2016
  .call(y)
1021
2017
  .style('display', 'none');
1022
- /**
1023
- * hide x axis labels
1024
- * config is there for future use
1025
- * used by weekly charts
1026
- */
1027
- if (this.chartConfiguration.isXaxisLabelHidden != undefined &&
1028
- this.chartConfiguration.isXaxisLabelHidden) {
1029
- d3.selectAll('g.lib-line-x-axis-text > g > text').attr('class', 'lib-display-hidden');
1030
- }
1031
- /**
1032
- * hide y axis labels
1033
- * used by weekly charts
1034
- */
1035
- if (this.chartConfiguration.isYaxisLabelHidden != undefined &&
1036
- this.chartConfiguration.isYaxisLabelHidden) {
1037
- d3.selectAll('.yaxis-dashed > g > text').attr('class', 'lib-display-hidden');
1038
- }
1039
- /**
1040
- * hide y axis labels
1041
- * config is there for future use
1042
- */
1043
- if (this.chartConfiguration.isYaxisHidden != undefined &&
1044
- this.chartConfiguration.isYaxisHidden) {
1045
- d3.selectAll('.yaxis-dashed').attr('class', 'lib-display-hidden');
1046
- }
1047
- /**
1048
- * dashed y axis
1049
- * used by weekly charts
1050
- */
1051
- if (this.chartConfiguration.isYaxisDashed != undefined &&
1052
- this.chartConfiguration.isYaxisDashed) {
2018
+ // Line chart axis if applicable
2019
+ if (lineData != null && lineData && self.chartConfiguration.showLineChartAxis) {
2020
+ svgYAxisRight.append('g')
2021
+ .attr('class', 'lib-stacked-y-axis-text1')
2022
+ .attr('style', self.chartConfiguration.yAxisCustomTextStyles)
2023
+ .attr('transform', 'translate(0,0)')
2024
+ .call(yLineAxis);
2025
+ }
2026
+ // Apply axis visibility configurations
2027
+ this.applyAxisVisibilityConfig(self);
2028
+ }
2029
+ applyAxisVisibilityConfig(self) {
2030
+ if (self.chartConfiguration.isXaxisLabelHidden) {
2031
+ d3.selectAll('g.lib-line-x-axis-text > g > text')
2032
+ .attr('class', 'lib-display-hidden');
2033
+ }
2034
+ if (self.chartConfiguration.isYaxisLabelHidden) {
2035
+ d3.selectAll('.yaxis-dashed > g > text')
2036
+ .attr('class', 'lib-display-hidden');
2037
+ }
2038
+ if (self.chartConfiguration.isYaxisHidden) {
1053
2039
  d3.selectAll('.yaxis-dashed')
1054
- .style('stroke-dasharray', '5 5')
1055
- .style('color', 'var(--chart-axis-color, #999999)'); // Use CSS variable
2040
+ .attr('class', 'lib-display-hidden');
1056
2041
  }
1057
- if (lineData != null) {
1058
- if (lineData && self.chartConfiguration.showLineChartAxis) {
1059
- svgYAxisRight
1060
- .append('g')
1061
- .attr('class', 'lib-stacked-y-axis-text1')
1062
- .attr('style', self.chartConfiguration.yAxisCustomTextStyles)
1063
- .attr('transform', 'translate(' + 0 + ',0)')
1064
- .call(yLineAxis);
1065
- }
2042
+ if (self.chartConfiguration.isYaxisDashed) {
2043
+ d3.selectAll('.yaxis-dashed')
2044
+ .style('stroke-dasharray', '5 5')
2045
+ .style('color', 'var(--chart-axis-color, #999999)');
1066
2046
  }
1067
- /**
1068
- * used to display y label
1069
- */
1070
- // if (this.isZoomedOut) {
1071
- // svg
1072
- // .selectAll('.lib-xaxis-labels-texts-drilldown')
1073
- // .attr('class', 'lib-display-hidden');
1074
- // }
1075
- if (this.isZoomedOut) {
1076
- svg
1077
- .selectAll('.lib-xaxis-labels-texts-drilldown')
1078
- .each((d, i, nodes) => {
1079
- const text = d3.select(nodes[i]);
1080
- const label = text.text();
1081
- if (label.indexOf('\n') > -1) {
1082
- const lines = label.split('\n');
1083
- text.text(null);
1084
- lines.forEach((line, idx) => {
1085
- text.append('tspan')
1086
- .text(line)
1087
- .attr('x', 0)
1088
- .attr('dy', idx === 0 ? '1em' : '1.1em');
1089
- });
1090
- }
1091
- else {
1092
- const words = label.split(' ');
1093
- text.text(null);
1094
- words.forEach((word, index) => {
1095
- text.append('tspan').text(word);
1096
- });
1097
- }
1098
- })
1099
- .style('fill', 'var(--chart-text-color)')
1100
- .attr('transform', null);
1101
- svg
1102
- .select('.x-axis')
1103
- .attr('transform', `translate(0, ${height - margin.bottom + 10})`);
1104
- }
1105
- /**
1106
- * used to write y labels based on configuration
1107
- */
2047
+ }
2048
+ renderAxisLabels(svg, svgYAxisLeft, svgYAxisRight, metaData, width, height, margin, self, isria, rightSvgWidth) {
2049
+ // Y-axis label
1108
2050
  if (metaData.yLabel) {
1109
2051
  const yPosition = isria ? 0 - margin.left / 2 - 30 : 0 - margin.left / 2 - 40;
1110
- svgYAxisLeft
1111
- .append('text')
2052
+ svgYAxisLeft.append('text')
1112
2053
  .attr('class', 'lib-axis-group-label font-size-1')
1113
2054
  .attr('style', self.chartConfiguration.yAxisCustomlabelStyles)
1114
2055
  .attr('transform', 'rotate(-90)')
@@ -1118,171 +2059,156 @@ export class HorizontalGroupedBarWithScrollZoomComponent extends ComponentUnique
1118
2059
  .style('text-anchor', 'middle')
1119
2060
  .attr('fill', 'var(--chart-text-color)');
1120
2061
  if (this.chartConfiguration.isMultiChartGridLine === undefined) {
1121
- svgYAxisLeft
1122
- .selectAll('.lib-axis-group-label')
2062
+ svgYAxisLeft.selectAll('.lib-axis-group-label')
1123
2063
  .style('font-size', 'smaller')
1124
2064
  .text(metaData.yLabel);
1125
2065
  }
1126
2066
  else {
1127
- svg
1128
- .selectAll('.lib-axis-group-label')
2067
+ svg.selectAll('.lib-axis-group-label')
1129
2068
  .attr('class', 'lib-ylabel-weeklyCharts')
1130
2069
  .text(metaData.yLabel.toLowerCase());
1131
2070
  }
1132
2071
  }
1133
- if (this.chartData.targetLineData) {
1134
- const yZero = y(this.chartData.targetLineData.target);
1135
- svg
1136
- .append('line')
1137
- .attr('x1', 0)
1138
- .attr('x2', width)
1139
- .attr('y1', yZero)
1140
- .attr('y2', yZero)
1141
- .style('stroke-dasharray', '5 5')
1142
- .style('stroke', this.chartData.targetLineData.color);
1143
- // svgYAxisRight
1144
- // .append('line')
1145
- // .attr('x1', 0)
1146
- // .attr('x2', rightSvgWidth)
1147
- // .attr('y1', yZero)
1148
- // .attr('y2', yZero)
1149
- // .style('stroke', this.chartData.targetLineData.color);
1150
- svgYAxisRight
1151
- .append('foreignObject')
1152
- .attr('transform', 'translate(' + 0 + ',' + (yZero - 30) + ')')
1153
- .attr('width', rightSvgWidth)
1154
- .attr('height', 50)
1155
- .append('xhtml:div')
1156
- .attr('class', 'target-display')
1157
- .style('color', 'var(--chart-text-color)')
1158
- .html(function () {
1159
- let dataTypeTemp = '';
1160
- let targetLineName = 'target';
1161
- if (metaData.dataType) {
1162
- dataTypeTemp = metaData.dataType;
1163
- }
1164
- if (self.chartData.targetLineData &&
1165
- self.chartData.targetLineData.targetName) {
1166
- targetLineName = self.chartData.targetLineData.targetName;
1167
- }
1168
- return (`<div>${targetLineName}</div>` +
1169
- '<div>' +
1170
- self.chartData.targetLineData.target +
1171
- '' +
1172
- dataTypeTemp +
1173
- '</div>');
1174
- });
1175
- }
1176
- if (this.chartConfiguration.isDrilldownChart) {
1177
- /**
1178
- * used by drilldown charts
1179
- */
1180
- // svg
1181
- // .selectAll('.lib-axis-group-label')
1182
- // .attr('class', 'lib-ylabel-drilldowncharts')
1183
- // .text(metaData.yLabel.toLowerCase());
1184
- svg.selectAll('g.x1.axis1 g.tick line').style('display', 'none');
1185
- }
2072
+ // X-axis label
1186
2073
  if (metaData.xLabel) {
1187
- function isAcronym(label) {
1188
- return ((label.length <= 4 && /^[A-Z]+$/.test(label)) ||
1189
- (label === label.toUpperCase() && /[A-Z]/.test(label)));
1190
- }
1191
- const xLabelText = metaData.xLabel;
1192
- const isAcr = isAcronym(xLabelText.replace(/[^A-Za-z]/g, ''));
1193
- const xPosition = isria ? (height + margin.top + margin.bottom) : (height + margin.top + margin.bottom + 40);
1194
- svg
1195
- .append('text')
1196
- .attr('class', function () {
1197
- let baseClass = 'lib-axis-group-label font-size-1';
1198
- if (self.chartConfiguration.isDrilldownChart)
1199
- return baseClass + ' lib-xlabel-drilldowncharts';
1200
- if (self.chartConfiguration.isMultiChartGridLine != undefined)
1201
- return baseClass + ' lib-xlabel-weeklyCharts';
1202
- return baseClass + ' lib-axis-waterfall-label';
1203
- })
2074
+ const isAcronym = this.isLabelAcronym(metaData.xLabel);
2075
+ const xPosition = isria
2076
+ ? (height + margin.top + margin.bottom)
2077
+ : (height + margin.top + margin.bottom + 40);
2078
+ svg.append('text')
2079
+ .attr('class', this.getXLabelClass(self))
1204
2080
  .attr('style', self.chartConfiguration.xAxisCustomlabelStyles)
1205
- .attr('transform', 'translate(' + width / 2 + ' ,' + xPosition + ')')
2081
+ .attr('transform', `translate(${width / 2},${xPosition})`)
1206
2082
  .style('text-anchor', 'middle')
1207
2083
  .style('fill', 'var(--chart-text-color)')
1208
- .text(isAcr ? xLabelText.toUpperCase() : xLabelText.toLowerCase())
1209
- .style('text-transform', isAcr ? 'none' : 'capitalize');
2084
+ .text(isAcronym ? metaData.xLabel.toUpperCase() : metaData.xLabel.toLowerCase())
2085
+ .style('text-transform', isAcronym ? 'none' : 'capitalize');
1210
2086
  }
2087
+ // Line y-axis label
1211
2088
  if (metaData.lineyLabel) {
1212
- svgYAxisRight
1213
- .append('text')
2089
+ svgYAxisRight.append('text')
1214
2090
  .attr('class', 'lib-axis-group-label lib-line-axis')
1215
2091
  .attr('fill', 'var(--chart-text-color)')
1216
2092
  .attr('style', self.chartConfiguration.yAxisCustomlabelStyles)
1217
2093
  .attr('transform', 'translate(0,0) rotate(90)')
1218
- .attr('y', 0 - 100)
1219
- .attr('x', 0 + 100)
2094
+ .attr('y', -100)
2095
+ .attr('x', 100)
1220
2096
  .attr('dy', '5em')
1221
2097
  .style('text-anchor', 'middle')
1222
2098
  .style('font-size', 'smaller')
1223
2099
  .text(metaData.lineyLabel);
1224
2100
  }
1225
- if (lineData) {
1226
- svg
1227
- .append('path')
1228
- .datum(lineData)
1229
- .attr('fill', 'none')
1230
- .attr('stroke', self.chartConfiguration.lineGraphColor)
1231
- .attr('stroke-width', 1.5)
1232
- .attr('d', d3
1233
- .line()
1234
- .x(function (d) {
1235
- return x(d.name) + x.bandwidth() / 2;
1236
- })
1237
- .y(function (d) {
1238
- return lineYscale(d.value);
1239
- }));
1240
- var dot = svg
1241
- .selectAll('myCircles')
1242
- .data(lineData)
1243
- .enter()
1244
- .append('g')
1245
- .on('click', function (d) {
1246
- if (!metaData.barWithoutClick ||
1247
- !metaData.barWithoutClick.length ||
1248
- (!metaData.barWithoutClick.includes(d?.name) &&
1249
- !metaData.barWithoutClick.includes(d?.key)))
1250
- self.handleClick(d);
1251
- });
1252
- dot
1253
- .append('circle')
1254
- .attr('fill', function (d) {
1255
- return self.chartConfiguration.lineGraphColor;
1256
- })
1257
- .attr('stroke', 'none')
1258
- .attr('cx', function (d) {
1259
- return x(d.name) + x.bandwidth() / 2;
1260
- })
1261
- .attr('cy', function (d) {
1262
- return lineYscale(d.value);
1263
- })
1264
- .style('cursor', () => self.chartData.metaData.hasDrillDown ? 'pointer' : 'default')
1265
- .attr('r', 3);
1266
- if (self.chartConfiguration.lineGraphColor) {
1267
- dot
1268
- .append('text')
1269
- .attr('class', 'dot')
1270
- .attr('fill', 'var(--chart-text-color)')
1271
- .attr('color', self.chartConfiguration.lineGraphColor)
1272
- .attr('style', 'font-size: ' + '.85em')
1273
- .attr('x', function (d, i) {
1274
- return x(d.name) + x.bandwidth() / 2;
1275
- })
1276
- .attr('y', function (d) {
1277
- return lineYscale(d.value);
1278
- })
1279
- .attr('dy', '-1em')
1280
- .text(function (d) {
1281
- return self.chartConfiguration.labelFormatter(d.value);
1282
- });
2101
+ // Apply drilldown chart specific styles
2102
+ if (this.chartConfiguration.isDrilldownChart) {
2103
+ svg.selectAll('g.x1.axis1 g.tick line').style('display', 'none');
2104
+ }
2105
+ }
2106
+ isLabelAcronym(label) {
2107
+ return (label.length <= 4 && /^[A-Z]+$/.test(label)) ||
2108
+ (label === label.toUpperCase() && /[A-Z]/.test(label));
2109
+ }
2110
+ getXLabelClass(self) {
2111
+ let baseClass = 'lib-axis-group-label font-size-1';
2112
+ if (self.chartConfiguration.isDrilldownChart) {
2113
+ return baseClass + ' lib-xlabel-drilldowncharts';
2114
+ }
2115
+ if (self.chartConfiguration.isMultiChartGridLine !== undefined) {
2116
+ return baseClass + ' lib-xlabel-weeklyCharts';
2117
+ }
2118
+ return baseClass + ' lib-axis-waterfall-label';
2119
+ }
2120
+ renderTargetLine(svg, svgYAxisRight, y, width, rightSvgWidth, metaData, self) {
2121
+ const yZero = y(this.chartData.targetLineData.target);
2122
+ // Draw target line
2123
+ svg.append('line')
2124
+ .attr('x1', 0)
2125
+ .attr('x2', width)
2126
+ .attr('y1', yZero)
2127
+ .attr('y2', yZero)
2128
+ .style('stroke-dasharray', '5 5')
2129
+ .style('stroke', this.chartData.targetLineData.color);
2130
+ // Add target label
2131
+ const dataTypeTemp = metaData.dataType || '';
2132
+ const targetLineName = this.chartData.targetLineData.targetName || 'target';
2133
+ svgYAxisRight.append('foreignObject')
2134
+ .attr('transform', `translate(0,${yZero - 30})`)
2135
+ .attr('width', rightSvgWidth)
2136
+ .attr('height', 50)
2137
+ .append('xhtml:div')
2138
+ .attr('class', 'target-display')
2139
+ .style('color', 'var(--chart-text-color)')
2140
+ .html(`<div>${targetLineName}</div><div>${self.chartData.targetLineData.target}${dataTypeTemp}</div>`);
2141
+ }
2142
+ renderLineChart(svg, lineData, x, lineYscale, metaData, self) {
2143
+ // Draw line path
2144
+ svg.append('path')
2145
+ .datum(lineData)
2146
+ .attr('fill', 'none')
2147
+ .attr('stroke', self.chartConfiguration.lineGraphColor)
2148
+ .attr('stroke-width', 1.5)
2149
+ .attr('d', d3.line()
2150
+ .x((d) => x(d.name) + x.bandwidth() / 2)
2151
+ .y((d) => lineYscale(d.value)));
2152
+ // Add dots
2153
+ const dot = svg.selectAll('myCircles')
2154
+ .data(lineData)
2155
+ .enter()
2156
+ .append('g')
2157
+ .on('click', (d) => {
2158
+ if (!metaData.barWithoutClick || !metaData.barWithoutClick.length ||
2159
+ (!metaData.barWithoutClick.includes(d?.name) &&
2160
+ !metaData.barWithoutClick.includes(d?.key))) {
2161
+ self.handleClick(d);
1283
2162
  }
2163
+ });
2164
+ dot.append('circle')
2165
+ .attr('fill', self.chartConfiguration.lineGraphColor)
2166
+ .attr('stroke', 'none')
2167
+ .attr('cx', (d) => x(d.name) + x.bandwidth() / 2)
2168
+ .attr('cy', (d) => lineYscale(d.value))
2169
+ .style('cursor', () => self.chartData.metaData.hasDrillDown ? 'pointer' : 'default')
2170
+ .attr('r', 3);
2171
+ // Add value labels
2172
+ if (self.chartConfiguration.lineGraphColor) {
2173
+ dot.append('text')
2174
+ .attr('class', 'dot')
2175
+ .attr('fill', 'var(--chart-text-color)')
2176
+ .attr('color', self.chartConfiguration.lineGraphColor)
2177
+ .attr('style', 'font-size: .85em')
2178
+ .attr('x', (d) => x(d.name) + x.bandwidth() / 2)
2179
+ .attr('y', (d) => lineYscale(d.value))
2180
+ .attr('dy', '-1em')
2181
+ .text((d) => self.chartConfiguration.labelFormatter(d.value));
1284
2182
  }
1285
2183
  }
2184
+ handleZoomOut(svg, height, margin) {
2185
+ svg.selectAll('.lib-xaxis-labels-texts-drilldown')
2186
+ .each((d, i, nodes) => {
2187
+ const text = d3.select(nodes[i]);
2188
+ const label = text.text();
2189
+ if (label.indexOf('\n') > -1) {
2190
+ const lines = label.split('\n');
2191
+ text.text(null);
2192
+ lines.forEach((line, idx) => {
2193
+ text.append('tspan')
2194
+ .text(line)
2195
+ .attr('x', 0)
2196
+ .attr('dy', idx === 0 ? '1em' : '1.1em');
2197
+ });
2198
+ }
2199
+ else {
2200
+ const words = label.split(' ');
2201
+ text.text(null);
2202
+ words.forEach((word) => {
2203
+ text.append('tspan').text(word);
2204
+ });
2205
+ }
2206
+ })
2207
+ .style('fill', 'var(--chart-text-color)')
2208
+ .attr('transform', null);
2209
+ svg.select('.x-axis')
2210
+ .attr('transform', `translate(0, ${height - margin.bottom + 10})`);
2211
+ }
1286
2212
  calculateChartDimensions(chartContainer, verticalstackedcontainer, margin, self) {
1287
2213
  let width = parseInt(chartContainer.style('width')) - margin.left - margin.right;
1288
2214
  const dataLength = this.chartData.data.length;
@@ -1426,4 +2352,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
1426
2352
  }], headerMenuclickEvent: [{
1427
2353
  type: Output
1428
2354
  }] } });
1429
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"horizontal-grouped-bar-with-scroll-zoom.component.js","sourceRoot":"","sources":["../../../../../projects/axidio-styleguide-library/src/lib/horizontal-grouped-bar-with-scroll-zoom/horizontal-grouped-bar-with-scroll-zoom.component.ts","../../../../../projects/axidio-styleguide-library/src/lib/horizontal-grouped-bar-with-scroll-zoom/horizontal-grouped-bar-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} 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@Component({\r\n  selector: 'lib-horizontal-grouped-bar-with-scroll-zoom',\r\n  templateUrl: './horizontal-grouped-bar-with-scroll-zoom.component.html',\r\n  styleUrls: [\r\n    './horizontal-grouped-bar-with-scroll-zoom.component.less',\r\n    '../common-styles.less',\r\n  ],\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class HorizontalGroupedBarWithScrollZoomComponent\r\n  extends ComponentUniqueId\r\n  implements OnInit\r\n{\r\n  @ViewChild('groupchartcontainer', { static: true })\r\n  containerElt!: ElementRef;\r\n\r\n  @ViewChild('groupcontainer', { static: true })\r\n  groupcontainerElt!: ElementRef;\r\n\r\n  @Input() chartData: any;\r\n  @Input() customChartConfiguration: any;\r\n  @Output() clickEvent = new EventEmitter<any>();\r\n  @Output() headerMenuclickEvent = new EventEmitter<any>();\r\n  isHeaderVisible: boolean = true;\r\n  legendVisible: boolean = true;\r\n  isTransparentBackground: boolean = false;\r\n  chartConfiguration: any = {};\r\n  objectKeys = Object.keys;\r\n\r\n  defaultConfiguration: any = {\r\n    margin: { top: 20, right: 20, bottom: 20, left: 40 },\r\n    labelFormatter: ChartHelper.defaultFormatter,\r\n    svgHeight: 70,\r\n    numberOfYTicks: 5,\r\n    legendJustified: true,\r\n    yLineAxisLabelFomatter: ChartHelper.defaultFormatter,\r\n    yAxisLabelFomatter: ChartHelper.defaultFormatter,\r\n    lineGraphColor: '#F6D283',\r\n    showLineChartAxis: true,\r\n    showValues: true,\r\n    headerMenuOptions: HeaderConfigHelper.headerConfig.headerMenuOptions,\r\n    xAxisGrid: undefined,\r\n    yAxisGrid: false,\r\n    legendVisible: false,\r\n    isHeaderVisible: undefined,\r\n    isTransparentBackground: undefined,\r\n    isMultiChartGridLine: undefined,\r\n    isFullScreen: undefined,\r\n    customYscale: undefined,\r\n    textsOnBar: undefined,\r\n    isXaxisLabelHidden: undefined,\r\n    isYaxisLabelHidden: false,\r\n    isYaxisHidden: undefined,\r\n    isYaxisDashed: undefined,\r\n    textFormatter: undefined,\r\n    isNoAlternateXaxisText: undefined,\r\n    isXgridBetweenLabels: undefined,\r\n    backgroundColor: '#FFFFFF',\r\n    hideLegendOnTop: true,\r\n    isXaxisColor: '#999999',\r\n    labelOverlapMinorFix: true,\r\n    noHoverEffect: true,\r\n    noHoverDisplayData: true,\r\n    showXaxisTop: true,\r\n    displayYaxisLabels: undefined,\r\n    xLabelsOnSameLine: undefined,\r\n    textAlwaysHorizontal: undefined,\r\n    legendAtTopRight: undefined,\r\n    isDrilldownChart: true,\r\n    displayTitleOnTop: undefined,\r\n    isToggleVisible: undefined,\r\n    isTitleHidden: undefined,\r\n    isDisplayBarDetailsAtBottom: undefined,\r\n    howmanyBarDetailsToDisplay: 0,\r\n    barVauleColor: undefined,\r\n    defaultBarHeight: 2,\r\n  };\r\n\r\n  uniqueId: any = this.getUniqueId();\r\n  isZoomedOut: boolean = true;\r\n  isDD1Open: boolean = false;\r\n  isDD2Open: boolean = false;\r\n\r\n  constructor() {\r\n    super();\r\n  }\r\n\r\n  onResized(event: ResizedEvent) {\r\n    let self = this;\r\n    setTimeout(\r\n      function () {\r\n        d3.select('#' + self.uniqueId).remove();\r\n        self.initializegroupChart();\r\n      }.bind(self),\r\n      10\r\n    );\r\n  }\r\n  isZoomOutSelected(isZoomOut, event) {\r\n    this.isZoomedOut = isZoomOut;\r\n    this.onResized(event);\r\n  }\r\n  handleZoominZoomoutClick({ isZoomOut, event }) {\r\n    this.isZoomOutSelected(isZoomOut, event);\r\n  }\r\n  ngOnInit() {}\r\n  isLegendVisible() {\r\n    if (\r\n      this.chartData &&\r\n      this.chartData.metaData.colors &&\r\n      Object.keys(this.chartData.metaData.colors).length > 1\r\n    ) {\r\n      return true;\r\n    }\r\n    return false;\r\n  }\r\n  keepOrder = (a, b) => {\r\n    return a;\r\n  };\r\n\r\n  get isAlertEnabled(): boolean {\r\n    return this.chartConfiguration?.headerMenuOptions?.some(\r\n      (option) => option.id === 'editAlert'\r\n    );\r\n  }  \r\n  initializegroupChart() {\r\n    var self = this;\r\n    let data = [];\r\n    let metaData: any = null;\r\n    let keyList = null;\r\n    let lineData = null;\r\n    let colorMap = {};\r\n    var formatFromBackend;\r\n    var formatForHugeNumbers;\r\n    const isMobile = window.innerWidth < 576;\r\n    const isTablet = window.innerWidth >= 576 && window.innerWidth < 992;\r\n    const isDesktop = window.innerWidth >= 992;\r\n\r\n   let isria = this.customChartConfiguration.isRia\r\n\r\n    var x: any;\r\n\r\n    var alternate_text = false;\r\n    var short_tick_length = 4;\r\n    var long_tick_length = 16;\r\n    /**\r\n     * longer tick length needed for weekly charts\r\n     */\r\n    var short_tick_length_bg = 5;\r\n    var long_tick_length_bg = 30;\r\n    var leftAndRightSpaces = 50;\r\n    var rightSvgWidth = 60;\r\n    var tempScale;\r\n\r\n    for (var i in this.defaultConfiguration) {\r\n      this.chartConfiguration[i] = ChartHelper.getValueByConfigurationType(\r\n        i,\r\n        this.defaultConfiguration,\r\n        this.customChartConfiguration\r\n      );\r\n    }\r\n\r\n    data = this.chartData.data;\r\n    metaData = this.chartData.metaData;\r\n    lineData = this.chartData.lineData;\r\n\r\n    // if (lineData || this.chartData.targetLineData) {\r\n    //   rightSvgWidth = 60;\r\n    // }\r\n    if (!metaData.colorAboveTarget) {\r\n      metaData['colorAboveTarget'] = metaData.colors;\r\n    }\r\n    colorMap = metaData.colors;\r\n    keyList = metaData.keyList;\r\n\r\n    var chartContainer = d3.select(this.containerElt.nativeElement);\r\n    var verticalstackedcontainer = d3.select(\r\n      this.groupcontainerElt.nativeElement\r\n    );\r\n    var margin = this.chartConfiguration.margin;\r\n    const { width, height } = this.calculateChartDimensions(\r\n    chartContainer,\r\n    verticalstackedcontainer,\r\n    margin,\r\n    self\r\n  );\r\n    /**\r\n     * for hiding header\r\n     * used by weekly charts\r\n     */\r\n    if (this.chartConfiguration.isHeaderVisible != undefined)\r\n      this.isHeaderVisible = this.chartConfiguration.isHeaderVisible;\r\n    /**\r\n     * for hiding legends\r\n     * used by weekly charts\r\n     */\r\n    if (this.chartConfiguration.legendVisible != undefined) {\r\n      this.legendVisible = this.chartConfiguration.legendVisible;\r\n    }\r\n\r\n    /**\r\n     * for removing background color so that it can take parents color\r\n     *\r\n     */\r\n    if (this.chartConfiguration.isTransparentBackground != undefined) {\r\n      this.isTransparentBackground =\r\n        this.chartConfiguration.isTransparentBackground;\r\n    }\r\n    /**\r\n     * format data values based on configuration received\r\n     */\r\n    if (this.chartConfiguration.textFormatter != undefined) {\r\n      formatFromBackend = ChartHelper.dataValueFormatter(\r\n        this.chartConfiguration.textFormatter\r\n      );\r\n      formatForHugeNumbers = ChartHelper.dataValueFormatter('.2s');\r\n    }\r\n    const {\r\n    outerContainer,\r\n    svgYAxisLeft,\r\n    svgYAxisRight,\r\n    innerContainer,\r\n    svg\r\n  } = this.createChartContainers(chartContainer, margin, height, rightSvgWidth, self, width);\r\n    var subgroups: any = keyList;\r\n\r\n    var groups = d3\r\n      .map(data, function (d) {\r\n        return d.name;\r\n      })\r\n      .keys();\r\n\r\n    /**\r\n     * x axis range made similar to line chart or vertical stack so that all the charts will get aligned with each other.\r\n     */\r\n    if (this.chartConfiguration.isMultiChartGridLine != undefined) {\r\n      x = d3\r\n        .scaleBand()\r\n        .rangeRound([width, 0])\r\n        .align(0.5)\r\n        .padding([0.5])\r\n        .domain(\r\n          data.map(function (d: any) {\r\n            return d.name.toLowerCase();\r\n          })\r\n        );\r\n    } else {\r\n      x = d3\r\n        .scaleBand()\r\n        .domain(groups)\r\n        .range([leftAndRightSpaces, width - rightSvgWidth - leftAndRightSpaces])\r\n        .padding([0.3]);\r\n    }\r\n    // x.bandwidth(96);\r\n    var xScaleFromOrigin = d3\r\n      .scaleBand()\r\n      .domain(groups)\r\n      .range([0, width - rightSvgWidth]);\r\n    // .padding([0.2]);\r\n\r\n    if (this.chartConfiguration.isMultiChartGridLine == undefined) {\r\n      /**\r\n       * normal ticks for all dashboard charts\r\n       */\r\n      svg\r\n        .append('g')\r\n        .attr('class', 'x1 axis1')\r\n        .attr('transform', 'translate(0,' + height + ')')\r\n        .call(d3.axisBottom(x))\r\n        .call((g) => g.select('.domain').remove());\r\n\r\n      svg.selectAll('g.x1.axis1 g.tick line').remove();\r\n\r\n      // Only move x-axis labels further down for grouped charts if there is no xLabel\r\n      if (subgroups.length > 1 && !metaData.xLabel) {\r\n        svg\r\n          .selectAll('g.x1.axis1 g.tick text')\r\n          .attr('class', 'lib-xaxis-labels-texts-drilldown')\r\n          .style('fill', 'var(--chart-text-color)')\r\n          .attr('y', 32); // Increase distance from bars (default is ~9)\r\n      } else {\r\n        svg\r\n          .selectAll('g.x1.axis1 g.tick text')\r\n          .attr('class', 'lib-xaxis-labels-texts-drilldown')\r\n          .style('fill', 'var(--chart-text-color)');\r\n      }\r\n    } \r\n    else {\r\n      /**\r\n       * bigger ticks for weekly charts and more space from x axis to labels\r\n       */\r\n      /**\r\n       * draw x axis\r\n       */\r\n      svg\r\n        .append('g')\r\n        .attr('class', 'x1 axis1')\r\n        .attr('transform', 'translate(0,' + height + ')')\r\n        .call(d3.axisBottom(x).tickSize(0))\r\n        .call((g) => g.select('.domain').attr('fill', 'none'));\r\n      /**\r\n       * tick line size in alternate fashion\r\n       */\r\n      svg.selectAll('g.x1.axis1 g.tick line').attr('y2', function () {\r\n        if (\r\n          alternate_text &&\r\n          self.chartConfiguration.isNoAlternateXaxisText == undefined\r\n        ) {\r\n          alternate_text = false;\r\n          return long_tick_length_bg - 7;\r\n        } else {\r\n          alternate_text = true;\r\n          return short_tick_length_bg - 4;\r\n        }\r\n      });\r\n      /**\r\n       * reset the flag so that values can be shown in same alternate fashion\r\n       */\r\n      alternate_text = false;\r\n      /**\r\n       * print x-axis label texts\r\n       * used by weekly charts\r\n       */\r\n      svg\r\n        .selectAll('g.x1.axis1 g.tick text')\r\n        .attr('class', 'lib-xaxis-labels-texts-weeklycharts')\r\n        .attr('y', function () {\r\n          // Minimize gap in maximized (fullscreen) view for weekly charts\r\n          if (self.chartConfiguration.isFullScreen) {\r\n            return short_tick_length_bg;\r\n          }\r\n          if (alternate_text) {\r\n            alternate_text = false;\r\n            return long_tick_length_bg;\r\n          } else {\r\n            alternate_text = true;\r\n            return short_tick_length_bg;\r\n          }\r\n        });\r\n    }\r\n    if (self.chartConfiguration.xLabelsOnSameLine) {\r\n      const xAxisLabels = svg\r\n        .selectAll('g.x1.axis1 g.tick text')\r\n        .attr('class', 'lib-xaxis-labels-texts-drilldown')\r\n        .style('font-size', this.isHeaderVisible ? '18px' : '14px')\r\n        .attr('text-anchor', 'middle')\r\n        .attr('y', function(d) {\r\n          // For grouped bar charts with many bars and xLabel present, only add 5 if the label is a date\r\n          if (subgroups.length > 1 && data.length > 8 && metaData.xLabel) {\r\n            const isDateLabel = /\\d{2,4}[-\\/]/.test(d);\r\n            if (self.chartConfiguration.isFullScreen) {\r\n              return isDateLabel ? short_tick_length_bg + 14 : short_tick_length_bg;\r\n            }\r\n            return isDateLabel ? short_tick_length_bg + 14 : short_tick_length_bg;\r\n          }\r\n          // For grouped bar charts with many bars and NO xLabel, add space as before, but reduce in fullscreen\r\n          if (subgroups.length > 1 && data.length > 8 && !metaData.xLabel) {\r\n            const chartHasExtraBottom = (self.chartConfiguration.margin && self.chartConfiguration.margin.bottom >= 40);\r\n            if (self.chartConfiguration.isFullScreen) {\r\n              // Reduce extra gap in maximized view\r\n              return short_tick_length_bg + 2;\r\n            }\r\n            return chartHasExtraBottom ? short_tick_length_bg : short_tick_length_bg + 10;\r\n          }\r\n          // Default/fallback logic for other cases\r\n          let baseY = self.isHeaderVisible ? short_tick_length_bg + 25 : short_tick_length_bg;\r\n          if (\r\n            subgroups.length > 1 &&\r\n            !metaData.xLabel &&\r\n            (/\\d{2,4}[-\\/]\\d{2}[-\\/]\\d{2,4}/.test(d) || /\\d{2,4}[-\\/]\\d{2,4}/.test(d))\r\n          ) {\r\n            baseY = self.isHeaderVisible ? short_tick_length_bg + 15 : short_tick_length_bg + 25;\r\n          }\r\n          if (/\\d{2,4}[-\\/]\\d{2,4}/.test(d) && d.indexOf(' ') > -1) {\r\n            baseY += 4;\r\n          }\r\n          // In maximized view, reduce baseY slightly for grouped bars\r\n          if (self.chartConfiguration.isFullScreen && subgroups.length > 1) {\r\n            baseY = Math.max(short_tick_length_bg, baseY - 10);\r\n          }\r\n          return baseY;\r\n        })\r\n        .attr('x', function (d) {\r\n          if (self.chartData.data.length > 8 && !self.isZoomedOut) {\r\n            return 1; // Move first line text slightly to the left in zoom-in view for better alignment\r\n          }\r\n          return 0; // Default position\r\n        })\r\n        .text(function (d) {\r\n          var isValueToBeIgnored = false;\r\n          if (isMobile && !self.isHeaderVisible) {\r\n            let firstPart = d.split(/[\\s\\-]+/)[0];\r\n            return firstPart.substring(0, 3).toLowerCase();\r\n          }\r\n          (data as any[]).map((indiv: any) => {\r\n            if (\r\n              indiv.name &&\r\n              indiv.name.toLowerCase() == d.trim().toLowerCase() &&\r\n              indiv[metaData.keyList[0]] == -1\r\n            ) {\r\n              isValueToBeIgnored = true;\r\n            }\r\n          });\r\n          if (isValueToBeIgnored) {\r\n            return '';\r\n          }\r\n          // Always add space before and after hyphen for date range labels, even when header is visible and label is single line\r\n          // Apply for grouped bar charts and single bar charts, header visible, single line\r\n          const dateRangeRegex = /(\\d{2,4}[-\\/]\\d{2}[-\\/]\\d{2,4})\\s*-\\s*(\\d{2,4}[-\\/]\\d{2}[-\\/]\\d{2,4})/;\r\n          if (dateRangeRegex.test(d.trim())) {\r\n            return d.trim().replace(dateRangeRegex, (m, d1, d2) => `${d1} - ${d2}`);\r\n          }\r\n          // Split date and week labels into two lines in grouped bar zoom-in view (and minimized view)\r\n          const isDateLabel = /\\d{2,4}[-\\/]/.test(d);\r\n          const isWeekLabel = /week|wk|w\\d+/i.test(d);\r\n          if (\r\n            subgroups.length > 1 && !self.isZoomedOut && data.length > 8 && d.indexOf(' ') > -1 && (isDateLabel || isWeekLabel)\r\n          ) {\r\n            var first = d.substring(0, d.indexOf(' '));\r\n            var second = d.substring(d.indexOf(' ') + 1).trim();\r\n            return first + '\\n' + second;\r\n          }\r\n          // Also keep previous logic for minimized view\r\n          if (isDateLabel) {\r\n            if (!self.isHeaderVisible && data.length > 8 && d.indexOf(' ') > -1) {\r\n              var first = d.substring(0, d.indexOf(' '));\r\n              var second = d.substring(d.indexOf(' ') + 1).trim();\r\n              return first + '\\n' + second;\r\n            } else {\r\n              return d;\r\n            }\r\n          }\r\n          if (d.trim().indexOf(' ') > -1) {\r\n            return d.trim().substring(0, d.indexOf(' ')).toLowerCase();\r\n          }\r\n          return d.toLowerCase();\r\n          // If label looks like a date (contains digits and - or /)\r\n          const isDateLabel2 = /\\d{2,4}[-\\/]/.test(d);\r\n          // Only split date/week labels if there are many grouped bars and header is not visible\r\n          if (isDateLabel) {\r\n            if (!self.isHeaderVisible && data.length > 8 && d.indexOf(' ') > -1) {\r\n              var first = d.substring(0, d.indexOf(' '));\r\n              var second = d.substring(d.indexOf(' ') + 1).trim();\r\n              return first + '\\n' + second;\r\n            } else {\r\n              return d;\r\n            }\r\n          }\r\n          if (d.trim().indexOf(' ') > -1) {\r\n            return d.trim().substring(0, d.indexOf(' ')).toLowerCase();\r\n          }\r\n          return d.toLowerCase();\r\n        });\r\n\r\n      // Now apply writing-mode: sideways-lr for grouped charts with date labels in zoomed-out view and many bars\r\n      xAxisLabels.each(function(this: SVGTextElement, d: any) {\r\n        // Only apply writing-mode for exact date labels, not those containing 'week' or similar\r\n        const isDateLabel = /^(\\d{2,4}[-\\/])?\\d{2,4}[-\\/]\\d{2,4}$/.test(d.trim());\r\n        const isWeekLabel = /week|wk|w\\d+/i.test(d);\r\n        if (subgroups.length > 1 && self.isZoomedOut && data.length > 8 && isDateLabel && !isWeekLabel) {\r\n          d3.select(this).style('writing-mode', 'sideways-lr');\r\n        }\r\n      });\r\n      if (!isMobile) {\r\n        svg\r\n          .selectAll('g.x1.axis1 g.tick')\r\n          .filter(function (d) {\r\n            return !/\\d{2,4}[-\\/]/.test(d); // Only process non-date labels\r\n          })\r\n          .append('text')\r\n          .attr('class', 'lib-xaxis-labels-texts-drilldown')\r\n          .attr('y', long_tick_length_bg)\r\n          .attr('fill', 'var(--chart-text-color)')\r\n          .attr('x', function (d) {\r\n            if (self.chartData.data.length > 8 && !self.isZoomedOut) {\r\n              return 1; // Move text slightly to the left\r\n            }\r\n            return 0; // Default position\r\n          })\r\n          .text(function (d) {\r\n            if (d.trim().indexOf(' ') > -1) {\r\n              return d.trim().substring(d.indexOf(' '), d.length).toLowerCase();\r\n            }\r\n            return '';\r\n          });\r\n      }\r\n    }\r\n        if (isria && self.chartData.data.length > 8) {\r\n      svg\r\n        .selectAll('g.x1.axis1 g.tick text')\r\n        .classed('mobile-xaxis-override', true)\r\n        .text(function (d: string) {\r\n          return d.substring(0, 3);\r\n        })\r\n        .style('font-size', '12px') \r\n        .attr('y', 5)               \r\n        .attr('x', 5)                \r\n        .style('text-anchor', 'middle');\r\n    }\r\n    if (isMobile && !this.isHeaderVisible) {\r\n      svg\r\n        .selectAll('g.x1.axis1 g.tick text')\r\n        .classed('mobile-xaxis-override', true);\r\n    }\r\n    /**y scale for left y axis */\r\n    var y = d3.scaleLinear().rangeRound([height, 0]);\r\n    var maxValue = d3.max(data, (d) => d3.max(keyList, (key) => +d[key]));\r\n    if (maxValue == 0) {\r\n      if (this.chartData.targetLineData) {\r\n        maxValue = this.chartData.targetLineData.target + 20;\r\n      } else {\r\n        maxValue = 100;\r\n      }\r\n    }\r\n\r\n    if (this.chartConfiguration.customYscale) {\r\n      /**\r\n       * increase y-scale so that values wont cross or exceed out of range\r\n       * used in weekly charts\r\n       */\r\n      maxValue = maxValue * this.chartConfiguration.customYscale;\r\n    }\r\n    if (\r\n      this.chartData.targetLineData &&\r\n      maxValue < this.chartData.targetLineData.target\r\n    ) {\r\n      maxValue =\r\n        maxValue < 10 && this.chartData.targetLineData.target < 10\r\n          ? this.chartData.targetLineData.target + 3\r\n          : this.chartData.targetLineData.target + 20;\r\n    }\r\n    y.domain([0, maxValue]).nice();\r\n    let lineYscale;\r\n\r\n    if (lineData != null) {\r\n      let maxLineValue = d3.max(lineData, function (d) {\r\n        return +d.value;\r\n      });\r\n\r\n      maxLineValue = maxLineValue * this.chartConfiguration.customYscale;\r\n\r\n      let minLineValue = d3.min(lineData, function (d) {\r\n        return +d.value;\r\n      });\r\n      if (maxLineValue > 0) minLineValue = minLineValue - 3;\r\n      if (minLineValue > 0) {\r\n        minLineValue = 0;\r\n      }\r\n      lineYscale = d3\r\n        .scaleLinear()\r\n        .domain([minLineValue, maxLineValue])\r\n        .range([height, minLineValue]);\r\n    }\r\n    let yLineAxis;\r\n    if (lineYscale != null) {\r\n      yLineAxis = d3\r\n        .axisRight(lineYscale)\r\n        .ticks(self.chartConfiguration.numberOfYTicks)\r\n        .tickSize(0)\r\n        .tickFormat(self.chartConfiguration.yLineAxisLabelFomatter);\r\n    }\r\n    /**\r\n     * show x-axis grid between labels\r\n     * used by weekly charts\r\n     */\r\n    if (self.chartConfiguration.isXgridBetweenLabels) {\r\n      svg\r\n        .append('g')\r\n        .attr('class', 'grid')\r\n        .attr(\r\n          'transform',\r\n          'translate(' + x.bandwidth() / 2 + ',' + height + ')'\r\n        )\r\n        .call(d3.axisBottom(x).tickSize(-height).tickFormat(''))\r\n        .style('stroke-dasharray', '5 5')\r\n        .style('color', 'var(--chart-grid-color, #999999)') // Use CSS variable\r\n        .call((g) => g.select('.domain').remove());\r\n    }\r\n\r\n    if (this.chartConfiguration.yAxisGrid) {\r\n      svg\r\n        .append('g')\r\n        .call(\r\n          d3\r\n            .axisLeft(y)\r\n            .ticks(self.chartConfiguration.numberOfYTicks)\r\n            .tickSize(-width)\r\n        )\r\n        .style('color', 'var(--chart-axis-color, #B9B9B9)')\r\n        .style('opacity', '0.5')\r\n        .call((g) => {\r\n          g.select('.domain')\r\n            .remove()\r\n            .style('stroke', 'var(--chart-domain-color, #000000)'); // Add CSS variable for domain\r\n        });\r\n    } else {\r\n      svg\r\n        .append('g')\r\n        .call(d3.axisLeft(y).ticks(self.chartConfiguration.numberOfYTicks))\r\n        .style('color', 'var(--chart-axis-color, #B9B9B9)')\r\n        .style('opacity', '0.5')\r\n        .call((g) => {\r\n          g.select('.domain')\r\n            .style('stroke', 'var(--chart-domain-color, #000000)') // Add CSS variable for domain\r\n            .style('stroke-width', '1px'); // Ensure visibility\r\n        });\r\n    }\r\n\r\n    var xSubgroup = d3.scaleBand().domain(subgroups);\r\n    if (subgroups.length > 1 && !this.isZoomedOut) {\r\n  // For grouped bar charts in zoom-in view, use full x.bandwidth() for subgroups\r\n  xSubgroup.range([0, x.bandwidth()]);\r\n    } else if (subgroups.length === 1 && !this.isZoomedOut) {\r\n      // For single-bar (non-grouped) charts in zoom-in view, set bar width to 100 (increased from 80)\r\n      xSubgroup.range([0, 100]);\r\n    } else if (this.chartConfiguration.isMultiChartGridLine == undefined) {\r\n      xSubgroup.range([0, x.bandwidth()]);\r\n    } else {\r\n      // used to make grouped bars with lesser width as we are not using padding for width\r\n      xSubgroup.range([0, x.bandwidth()]);\r\n    }\r\n    // if (this.chartConfiguration.isDrilldownChart) {\r\n\r\n    // }\r\n    var color = d3\r\n      .scaleOrdinal()\r\n      .domain(subgroups)\r\n      .range(Object.values(metaData.colors));\r\n    // var colorAboveTarget = d3\r\n    //   .scaleOrdinal()\r\n    //   .domain(subgroups)\r\n    //   .range(Object.values(metaData.colorAboveTarget));\r\n    var state = svg\r\n      .append('g')\r\n      .selectAll('.state')\r\n      .data(data)\r\n      .enter()\r\n      .append('g')\r\n      .attr('transform', function (d) {\r\n        return 'translate(' + x(d.name) + ',0)';\r\n      });\r\n    state\r\n      .selectAll('rect')\r\n      .data(function (d) {\r\n        let newList: any = [];\r\n        subgroups.map(function (key) {\r\n          // if (key !== \"group\") {\r\n          let obj: any = { key: key, value: d[key], name: d.name };\r\n          newList.push(obj);\r\n          // }\r\n        });\r\n        return newList;\r\n      })\r\n      .enter()\r\n      .append('rect')\r\n      .attr('class', 'bars')\r\n      .on('click', function (d) {\r\n        if (d.key != 'Target') {\r\n          if (\r\n            !metaData.barWithoutClick ||\r\n            !metaData.barWithoutClick.length ||\r\n            (!metaData.barWithoutClick.includes(d?.name) &&\r\n              !metaData.barWithoutClick.includes(d?.key))\r\n          )\r\n            // self.handleClick(d.data.name);\r\n            self.handleClick(d);\r\n        }\r\n      })\r\n      .attr('x', function (d) {\r\n        if (self.chartConfiguration.isDrilldownChart) {\r\n          data.map((indiv: any) => {\r\n            if (indiv.name == d.name) {\r\n              let keys = Object.keys(indiv).filter((temp, i) => i != 0);\r\n              tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);\r\n              if (x.bandwidth() > 100) {\r\n                // Increase bar width a bit in zoom-in view\r\n                let reducedBarWidth = 60;\r\n                if (!self.isZoomedOut) {\r\n                  reducedBarWidth = 30;\r\n                }\r\n                if (self.chartData.data.length == 1) {\r\n                  if (Object.keys(self.chartData.data[0]).length == 2) {\r\n                    tempScale.range([\r\n                      0 + (x.bandwidth() - reducedBarWidth) / 2,\r\n                      x.bandwidth() - (x.bandwidth() - reducedBarWidth) / 2,\r\n                    ]);\r\n                  } else\r\n                    tempScale.range([\r\n                      0 + (x.bandwidth() - reducedBarWidth) / 2,\r\n                      x.bandwidth() - (x.bandwidth() - reducedBarWidth) / 2,\r\n                    ]);\r\n                } else\r\n                  tempScale.range([\r\n                    0 + (x.bandwidth() - reducedBarWidth) / 2,\r\n                    x.bandwidth() - (x.bandwidth() - reducedBarWidth) / 2,\r\n                  ]);\r\n              }\r\n            }\r\n          });\r\n          return tempScale(d.key);\r\n        }\r\n        return xSubgroup(d.key);\r\n      })\r\n      .attr('y', function (d) {\r\n        if (d.value == -1) {\r\n          return y(0);\r\n        }\r\n\r\n        if (d.value >= 0) {\r\n          const barHeight = height - y(d.value);\r\n          const minHeight = self.chartConfiguration.defaultBarHeight || 2;\r\n          return barHeight < minHeight ? y(0) - minHeight : y(d.value);\r\n        }\r\n\r\n        return y(0);\r\n      })\r\n      .attr('width', function (d) {\r\n        // For grouped bar charts in zoom-in view, set bar width to 50 for maximum thickness\r\n        if (subgroups.length > 1 && !self.isZoomedOut) {\r\n          return 50;\r\n        }\r\n        // For single-bar (non-grouped) charts in zoom-in view, set bar width to 80\r\n        if (subgroups.length === 1 && !self.isZoomedOut) {\r\n          return 80;\r\n        }\r\n          let tempScale = d3.scaleBand().domain([]).range([0, 0]);\r\n        // Default logic for other chart types\r\n        if (self.chartConfiguration.isDrilldownChart) {\r\n          data.map((indiv: any) => {\r\n            if (indiv.name == d.name) {\r\n              let keys = Object.keys(indiv).filter((temp, i) => i != 0);\r\n              tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);\r\n              if (x.bandwidth() > 100) {\r\n                // Increase bar width a bit in zoom-in view\r\n                let reducedBarWidth = 60;\r\n                if (!self.isZoomedOut) {\r\n                  reducedBarWidth = 100;\r\n                }\r\n                if (self.chartData.data.length == 1) {\r\n                  if (Object.keys(self.chartData.data[0]).length == 2) {\r\n                    tempScale.range([\r\n                      0 + (x.bandwidth() - reducedBarWidth) / 2,\r\n                      x.bandwidth() - (x.bandwidth() - reducedBarWidth) / 2,\r\n                    ]);\r\n                  } else\r\n                    tempScale.range([\r\n                      0 + (x.bandwidth() - reducedBarWidth) / 2,\r\n                      x.bandwidth() - (x.bandwidth() - reducedBarWidth) / 2,\r\n                    ]);\r\n                } else\r\n                  tempScale.range([\r\n                    0 + (x.bandwidth() - reducedBarWidth) / 2,\r\n                    x.bandwidth() - (x.bandwidth() - reducedBarWidth) / 2,\r\n                  ]);\r\n              }\r\n            }\r\n          });\r\n          return self.isZoomedOut\r\n            ? tempScale.bandwidth()\r\n            : self.chartData.data.length && self.chartData.data.length > 8\r\n            ? tempScale.bandwidth() \r\n            : tempScale.bandwidth();\r\n        }\r\n        return self.isZoomedOut\r\n          ? tempScale.bandwidth()\r\n          : self.chartData.data.length && self.chartData.data.length > 8\r\n          ? tempScale.bandwidth()\r\n          : tempScale.bandwidth();\r\n      })\r\n      .attr('height', function (d) {\r\n        if (d.value == -1) {\r\n          return height - y(0);\r\n        }\r\n\r\n        if (d.value >= 0) {\r\n          const barHeight = height - y(d.value);\r\n          const minHeight = self.chartConfiguration.defaultBarHeight || 2;\r\n          return Math.max(barHeight, minHeight);\r\n        }\r\n\r\n        return height - y(0);\r\n      })\r\n      .style('cursor', function (d) {\r\n        if (metaData.hasDrillDown && !isria) return 'pointer';\r\n          else return 'default';\r\n      })\r\n      .attr('fill', function (d) {\r\n        if (\r\n          d.value &&\r\n          self.chartData.targetLineData &&\r\n          d.value >= parseFloat(self.chartData.targetLineData.target) &&\r\n          self.chartData.metaData.colorAboveTarget\r\n        ) {\r\n          const key = d.key.toLowerCase();\r\n          const colorAboveTarget = Object.keys(self.chartData.metaData.colorAboveTarget).find(\r\n            k => k.toLowerCase() === key\r\n          );\r\n          if (colorAboveTarget) {\r\n            return self.chartData.metaData.colorAboveTarget[colorAboveTarget];\r\n          }\r\n        }\r\n        return self.chartData.metaData.colors[d.key];\r\n      });\r\n\r\n    /**\r\n     * display angled texts on the bars\r\n     */\r\n    if (this.chartConfiguration.textsOnBar != undefined && !this.isZoomedOut) {\r\n      state\r\n        .selectAll('text')\r\n        .data(function (d) {\r\n          let newList: any = [];\r\n          subgroups.map(function (key) {\r\n            let obj: any = { key: key, value: d[key], name: d.name };\r\n            newList.push(obj);\r\n          });\r\n          return newList;\r\n        })\r\n        .enter()\r\n        .append('text')\r\n        .attr('fill', 'var(--chart-text-color)')\r\n        .attr('x', function (d) {\r\n          return 0;\r\n        })\r\n        .attr('y', function (d) {\r\n          return 0;\r\n        })\r\n        .attr('class', 'lib-data-labels-weeklycharts')\r\n        .text(function (d) {\r\n          return d.key && d.value\r\n            ? d.key.length > 20\r\n              ? d.key.substring(0, 17) + '...'\r\n              : d.key\r\n            : '';\r\n        })\r\n        .style('fill', function (d) {\r\n          return '#000';\r\n        })\r\n        .style('font-weight', 'bold')\r\n        .style('font-size', function (d) {\r\n          if (self.isZoomedOut) {\r\n            return '9px'; // 👈 Zoomed out mode\r\n          }\r\n\r\n          if (self.chartConfiguration.isDrilldownChart) {\r\n            if (window.innerWidth > 1900) {\r\n              return '18px';\r\n            } else if (window.innerWidth < 1400) {\r\n              return '10px';\r\n            } else {\r\n              return '14px';\r\n            }\r\n          } else {\r\n            return '14px';\r\n          }\r\n        })\r\n        .attr('transform', function (d) {\r\n          data.map((indiv: any) => {\r\n            if (indiv.name == d.name) {\r\n              let keys = Object.keys(indiv).filter((temp, i) => i != 0);\r\n              var temp;\r\n              tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);\r\n              if (x.bandwidth() > 100) {\r\n                if (self.chartData.data.length == 1) {\r\n                  if (Object.keys(self.chartData.data[0]).length == 2) {\r\n                    tempScale.range([\r\n                      0 + (x.bandwidth() - 200) / 2,\r\n                      x.bandwidth() - (x.bandwidth() - 200) / 2,\r\n                    ]);\r\n                    // .padding(0.05);\r\n                  } else\r\n                    tempScale.range([\r\n                      0 + (x.bandwidth() - 300) / 2,\r\n                      x.bandwidth() - (x.bandwidth() - 300) / 2,\r\n                    ]);\r\n                  // .padding(0.05);\r\n                } else\r\n                  tempScale.range([\r\n                    0 + (x.bandwidth() - 125) / 2,\r\n                    x.bandwidth() - (x.bandwidth() - 125) / 2,\r\n                  ]);\r\n              }\r\n            }\r\n          });\r\n          /**\r\n           * if set, then all texts ll be horizontal\r\n           */\r\n          if (self.chartConfiguration.textAlwaysHorizontal) {\r\n            return (\r\n              'translate(' + xSubgroup(d.key) + ',' + (y(d.value) - 3) + ')'\r\n            );\r\n          }\r\n          /**\r\n           * rotate texts having more than one digits\r\n           */\r\n          // if (d.value > 9)\r\n          if (!isNaN(tempScale(d.key)))\r\n            return (\r\n              'translate(' +\r\n              (tempScale(d.key) + tempScale.bandwidth() * 0.55) +\r\n              ',' +\r\n              (y(0) - 10) +\r\n              ') rotate(270)'\r\n            );\r\n          return 'translate(0,0)';\r\n          // else\r\n          //   return (\r\n          //     'translate(' +\r\n          //     (tempScale(d.key) + tempScale.bandwidth() / 2) +\r\n          //     ',' +\r\n          //     y(0) +\r\n          //     ')'\r\n          //   );\r\n        })\r\n        .on('click', function (d) {\r\n          if (\r\n            !metaData.barWithoutClick ||\r\n            !metaData.barWithoutClick.length ||\r\n            (!metaData.barWithoutClick.includes(d?.name) &&\r\n              !metaData.barWithoutClick.includes(d?.key))\r\n          )\r\n            self.handleClick(d);\r\n        });\r\n            if (!isria) {\r\n                    state\r\n        .selectAll('.lib-data-labels-weeklycharts')\r\n        .on('mouseout', handleMouseOut)\r\n        .on('mouseover', handleMouseOver);\r\n            }\r\n    }\r\n    if (this.chartConfiguration.displayTitleOnTop || (\r\n      this.chartConfiguration.textsOnBar == undefined &&\r\n      this.chartConfiguration.displayTitleOnTop == undefined\r\n    )) {\r\n\r\n                  if (!isria) {\r\n                          state\r\n        .selectAll('rect')\r\n        .on('mouseout', handleMouseOut)\r\n        .on('mouseover', handleMouseOver);\r\n                  }\r\n    }\r\n    function handleMouseOver(d, i) {\r\n      svg.selectAll('.lib-verticalstack-title-ontop').remove();\r\n      svg\r\n        .append('foreignObject')\r\n        .attr('x', function () {\r\n          // ...existing code for tempScale calculation...\r\n          var elementsCounter;\r\n          data.map((indiv: any) => {\r\n            if (indiv.name == d.name) {\r\n              let keys = Object.keys(indiv).filter((temp, i) => i != 0);\r\n              elementsCounter = keys.length;\r\n              tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);\r\n              if (x.bandwidth() > 100) {\r\n                if (self.chartData.data.length == 1) {\r\n                  if (Object.keys(self.chartData.data[0]).length == 2) {\r\n                    tempScale.range([\r\n                      0 + (x.bandwidth() - 200) / 2,\r\n                      x.bandwidth() - (x.bandwidth() - 200) / 2,\r\n                    ]);\r\n                  } else\r\n                    tempScale.range([\r\n                      0 + (x.bandwidth() - 300) / 2,\r\n                      x.bandwidth() - (x.bandwidth() - 300) / 2,\r\n                    ]);\r\n                } else\r\n                  tempScale.range([\r\n                    0 + (x.bandwidth() - 125) / 2,\r\n                    x.bandwidth() - (x.bandwidth() - 125) / 2,\r\n                  ]);\r\n              }\r\n            }\r\n          });\r\n          if (metaData.hasDrillDown) {\r\n            if (tempScale.bandwidth() + leftAndRightSpaces * 2 > 180) {\r\n              return (\r\n                x(d.name) + tempScale(d.key) + tempScale.bandwidth() / 2 - 90\r\n              );\r\n            }\r\n            return (\r\n              x(d.name) +\r\n              tempScale(d.key) -\r\n              (tempScale.bandwidth() + leftAndRightSpaces * 2) / 2 +\r\n              tempScale.bandwidth() / 2\r\n            );\r\n          } else return x(d.name) + tempScale(d.key) - (tempScale.bandwidth() + leftAndRightSpaces * 2) / 2 + tempScale.bandwidth() / 2;\r\n        })\r\n        .attr('class', 'lib-verticalstack-title-ontop')\r\n        .attr('y', function () {\r\n          return y(d.value) - 3 - 40 - 10;\r\n        })\r\n        .attr('dy', function () {\r\n          return d.class;\r\n        })\r\n        .attr('width', function () {\r\n          data.map((indiv: any) => {\r\n            if (indiv.name == d.name) {\r\n              let keys = Object.keys(indiv).filter((temp, i) => i != 0);\r\n              tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);\r\n              if (x.bandwidth() > 100) {\r\n                if (self.chartData.data.length == 1) {\r\n                  if (Object.keys(self.chartData.data[0]).length == 2) {\r\n                    tempScale.range([\r\n                      0 + (x.bandwidth() - 200) / 2,\r\n                      x.bandwidth() - (x.bandwidth() - 200) / 2,\r\n                    ]);\r\n                  } else\r\n                    tempScale.range([\r\n                      0 + (x.bandwidth() - 300) / 2,\r\n                      x.bandwidth() - (x.bandwidth() - 300) / 2,\r\n                    ]);\r\n                } else\r\n                  tempScale.range([\r\n                    0 + (x.bandwidth() - 125) / 2,\r\n                    x.bandwidth() - (x.bandwidth() - 125) / 2,\r\n                  ]);\r\n              }\r\n            }\r\n          });\r\n          if (metaData.hasDrillDown) {\r\n            if (tempScale.bandwidth() + leftAndRightSpaces * 2 > 180) {\r\n              return '180px';\r\n            }\r\n            return tempScale.bandwidth() + leftAndRightSpaces * 2;\r\n          } else return tempScale.bandwidth() + leftAndRightSpaces * 2;\r\n        })\r\n        .attr('height', 50)\r\n        .append('xhtml:div')\r\n        .attr('class', 'title')\r\n        .style('z-index', 99)\r\n        .html(function () {\r\n          let barLabel = d.key;\r\n          let dataType = metaData.dataType ? metaData.dataType : '';\r\n          let value = d.value;\r\n          let desiredText =\r\n            '<span class=\"title-bar-name\">' + barLabel + '</span>';\r\n          desiredText +=\r\n            '<span class=\"title-bar-value\"><span>' +\r\n            value +\r\n            '</span>' +\r\n            dataType +\r\n            '</span>';\r\n          return desiredText;\r\n        });\r\n    }\r\n    function handleMouseOut(d, i) {\r\n      svg.selectAll('.lib-verticalstack-title-ontop').remove();\r\n    }\r\n    svg\r\n      .append('g')\r\n      .attr('class', 'x2 axis2')\r\n      .attr('transform', 'translate(0,' + height + ')')\r\n      .style('color', 'var(--chart-axis-color, #000)') // Use CSS variable instead of hardcoded #000\r\n      .call(d3.axisBottom(xScaleFromOrigin).tickSize(0))\r\n      .call((g) => g.select('.domain').attr('fill', 'none'));\r\n    svg.selectAll('g.x2.axis2 g.tick text').style('display', 'none');\r\n    svg\r\n      .append('g')\r\n      .attr('class', 'lib-stacked-y-axis-text yaxis-dashed')\r\n      .attr('style', self.chartConfiguration.yAxisCustomTextStyles)\r\n      .attr('transform', 'translate(0,0)')\r\n      .call(y)\r\n      .style('display', 'none');\r\n    svgYAxisLeft\r\n      .append('g')\r\n      .append('g')\r\n      .attr('class', 'lib-yaxis-labels-texts-drilldown yaxis-dashed')\r\n      .attr('style', self.chartConfiguration.yAxisCustomTextStyles)\r\n      .attr('transform', 'translate(0,0)')\r\n      .call(\r\n        d3\r\n          .axisLeft(y)\r\n          .tickSize(0)\r\n          .ticks(self.chartConfiguration.numberOfYTicks)\r\n          .tickFormat(function (d) {\r\n            const formatted = self.chartConfiguration.yAxisLabelFomatter\r\n              ? self.chartConfiguration.yAxisLabelFomatter(d)\r\n              : d;\r\n            return formatted >= 1000 ? formatted / 1000 + 'k' : formatted;\r\n          })\r\n      )\r\n      .call((g) => {\r\n        // Style the domain line for theme support\r\n        g.select('.domain')\r\n          .style('stroke', 'var(--chart-domain-color, #000000)')\r\n          .style('stroke-width', '1px');\r\n      })\r\n      .selectAll('text')\r\n      .style('fill', 'var(--chart-text-color)');\r\n    svgYAxisRight\r\n      .append('g')\r\n      .attr('class', 'lib-yaxis-labels-texts-drilldown yaxis-dashed')\r\n      .attr('style', self.chartConfiguration.yAxisCustomTextStyles)\r\n      .attr('transform', 'translate(0,0)')\r\n      .call(y)\r\n      .style('display', 'none');\r\n    /**\r\n     * hide x axis labels\r\n     * config is there for future use\r\n     * used by weekly charts\r\n     */\r\n    if (\r\n      this.chartConfiguration.isXaxisLabelHidden != undefined &&\r\n      this.chartConfiguration.isXaxisLabelHidden\r\n    ) {\r\n      d3.selectAll('g.lib-line-x-axis-text > g > text').attr(\r\n        'class',\r\n        'lib-display-hidden'\r\n      );\r\n    }\r\n    /**\r\n     * hide y axis labels\r\n     * used by weekly charts\r\n     */\r\n    if (\r\n      this.chartConfiguration.isYaxisLabelHidden != undefined &&\r\n      this.chartConfiguration.isYaxisLabelHidden\r\n    ) {\r\n      d3.selectAll('.yaxis-dashed > g > text').attr(\r\n        'class',\r\n        'lib-display-hidden'\r\n      );\r\n    }\r\n    /**\r\n     * hide y axis labels\r\n     * config is there for future use\r\n     */\r\n    if (\r\n      this.chartConfiguration.isYaxisHidden != undefined &&\r\n      this.chartConfiguration.isYaxisHidden\r\n    ) {\r\n      d3.selectAll('.yaxis-dashed').attr('class', 'lib-display-hidden');\r\n    }\r\n    /**\r\n     * dashed y axis\r\n     * used by weekly charts\r\n     */\r\n    if (\r\n      this.chartConfiguration.isYaxisDashed != undefined &&\r\n      this.chartConfiguration.isYaxisDashed\r\n    ) {\r\n      d3.selectAll('.yaxis-dashed')\r\n        .style('stroke-dasharray', '5 5')\r\n        .style('color', 'var(--chart-axis-color, #999999)'); // Use CSS variable\r\n    }\r\n    if (lineData != null) {\r\n      if (lineData && self.chartConfiguration.showLineChartAxis) {\r\n        svgYAxisRight\r\n          .append('g')\r\n          .attr('class', 'lib-stacked-y-axis-text1')\r\n          .attr('style', self.chartConfiguration.yAxisCustomTextStyles)\r\n          .attr('transform', 'translate(' + 0 + ',0)')\r\n          .call(yLineAxis);\r\n      }\r\n    }\r\n    /**\r\n     * used to display y label\r\n     */\r\n\r\n    // if (this.isZoomedOut) {\r\n    //   svg\r\n    //     .selectAll('.lib-xaxis-labels-texts-drilldown')\r\n    //     .attr('class', 'lib-display-hidden');\r\n    // }\r\n\r\n    if (this.isZoomedOut) {\r\n      svg\r\n        .selectAll('.lib-xaxis-labels-texts-drilldown')\r\n        .each((d, i, nodes) => {\r\n          const text = d3.select(nodes[i]);\r\n          const label = text.text();\r\n          if (label.indexOf('\\n') > -1) {\r\n            const lines = label.split('\\n');\r\n            text.text(null);\r\n            lines.forEach((line, idx) => {\r\n              text.append('tspan')\r\n                .text(line)\r\n                .attr('x', 0)\r\n                .attr('dy', idx === 0 ? '1em' : '1.1em');\r\n            });\r\n          } else {\r\n            const words = label.split(' ');\r\n            text.text(null);\r\n            words.forEach((word, index) => {\r\n              text.append('tspan').text(word);\r\n            });\r\n          }\r\n        })\r\n        .style('fill', 'var(--chart-text-color)')\r\n        .attr('transform', null); \r\n      svg\r\n        .select('.x-axis')\r\n        .attr('transform', `translate(0, ${height - margin.bottom + 10})`);\r\n    }\r\n\r\n    /**\r\n     * used to write y labels based on configuration\r\n     */\r\nif (metaData.yLabel) {\r\n  const yPosition = isria ? 0 - margin.left / 2 - 30 : 0 - margin.left / 2 - 40;\r\n\r\n  svgYAxisLeft\r\n    .append('text')\r\n    .attr('class', 'lib-axis-group-label font-size-1')\r\n    .attr('style', self.chartConfiguration.yAxisCustomlabelStyles)\r\n    .attr('transform', 'rotate(-90)')\r\n    .attr('y', yPosition)\r\n    .attr('x', 0 - height / 2)\r\n    .attr('dy', '1em')\r\n    .style('text-anchor', 'middle')\r\n    .attr('fill', 'var(--chart-text-color)');\r\n\r\n  if (this.chartConfiguration.isMultiChartGridLine === undefined) {\r\n    svgYAxisLeft\r\n      .selectAll('.lib-axis-group-label')\r\n      .style('font-size', 'smaller')\r\n      .text(metaData.yLabel);\r\n  } else {\r\n    svg\r\n      .selectAll('.lib-axis-group-label')\r\n      .attr('class', 'lib-ylabel-weeklyCharts')\r\n      .text(metaData.yLabel.toLowerCase());\r\n  }\r\n}\r\n\r\n    if (this.chartData.targetLineData) {\r\n      const yZero = y(this.chartData.targetLineData.target);\r\n      svg\r\n        .append('line')\r\n        .attr('x1', 0)\r\n        .attr('x2', width)\r\n        .attr('y1', yZero)\r\n        .attr('y2', yZero)\r\n        .style('stroke-dasharray', '5 5')\r\n        .style('stroke', this.chartData.targetLineData.color);\r\n      // svgYAxisRight\r\n      //   .append('line')\r\n      //   .attr('x1', 0)\r\n      //   .attr('x2', rightSvgWidth)\r\n      //   .attr('y1', yZero)\r\n      //   .attr('y2', yZero)\r\n      //   .style('stroke', this.chartData.targetLineData.color);\r\n      svgYAxisRight\r\n        .append('foreignObject')\r\n        .attr('transform', 'translate(' + 0 + ',' + (yZero - 30) + ')')\r\n        .attr('width', rightSvgWidth)\r\n        .attr('height', 50)\r\n        .append('xhtml:div')\r\n        .attr('class', 'target-display')\r\n        .style('color', 'var(--chart-text-color)')\r\n        .html(function () {\r\n          let dataTypeTemp = '';\r\n          let targetLineName = 'target';\r\n          if (metaData.dataType) {\r\n            dataTypeTemp = metaData.dataType;\r\n          }\r\n          if (\r\n            self.chartData.targetLineData &&\r\n            self.chartData.targetLineData.targetName\r\n          ) {\r\n            targetLineName = self.chartData.targetLineData.targetName;\r\n          }\r\n          return (\r\n            `<div>${targetLineName}</div>` +\r\n            '<div>' +\r\n            self.chartData.targetLineData.target +\r\n            '' +\r\n            dataTypeTemp +\r\n            '</div>'\r\n          );\r\n        });\r\n    }\r\n    if (this.chartConfiguration.isDrilldownChart) {\r\n      /**\r\n       * used by drilldown charts\r\n       */\r\n      // svg\r\n      //   .selectAll('.lib-axis-group-label')\r\n      //   .attr('class', 'lib-ylabel-drilldowncharts')\r\n      //   .text(metaData.yLabel.toLowerCase());\r\n      svg.selectAll('g.x1.axis1 g.tick line').style('display', 'none');\r\n    }\r\n\r\n    if (metaData.xLabel) {\r\n      function isAcronym(label) {\r\n        return (\r\n          (label.length <= 4 && /^[A-Z]+$/.test(label)) ||\r\n          (label === label.toUpperCase() && /[A-Z]/.test(label))\r\n        );\r\n      }\r\n      const xLabelText = metaData.xLabel;\r\n      const isAcr = isAcronym(xLabelText.replace(/[^A-Za-z]/g, ''));\r\n\r\n        const xPosition = isria ? (height + margin.top + margin.bottom) : (height + margin.top + margin.bottom + 40);\r\n\r\n      svg\r\n        .append('text')\r\n        .attr('class', function () {\r\n          let baseClass = 'lib-axis-group-label font-size-1';\r\n          if (self.chartConfiguration.isDrilldownChart)\r\n            return baseClass + ' lib-xlabel-drilldowncharts';\r\n          if (self.chartConfiguration.isMultiChartGridLine != undefined)\r\n            return baseClass + ' lib-xlabel-weeklyCharts';\r\n          return baseClass + ' lib-axis-waterfall-label';\r\n        })\r\n        .attr('style', self.chartConfiguration.xAxisCustomlabelStyles)\r\n        .attr(\r\n          'transform',\r\n          'translate(' + width / 2 + ' ,' + xPosition + ')'\r\n        )\r\n        .style('text-anchor', 'middle')\r\n        .style('fill', 'var(--chart-text-color)')\r\n        .text(isAcr ? xLabelText.toUpperCase() : xLabelText.toLowerCase())\r\n        .style('text-transform', isAcr ? 'none' : 'capitalize');\r\n    }\r\n    if (metaData.lineyLabel) {\r\n      svgYAxisRight\r\n        .append('text')\r\n        .attr('class', 'lib-axis-group-label lib-line-axis')\r\n        .attr('fill', 'var(--chart-text-color)')\r\n        .attr('style', self.chartConfiguration.yAxisCustomlabelStyles)\r\n        .attr('transform', 'translate(0,0) rotate(90)')\r\n        .attr('y', 0 - 100)\r\n        .attr('x', 0 + 100)\r\n        .attr('dy', '5em')\r\n        .style('text-anchor', 'middle')\r\n        .style('font-size', 'smaller')\r\n        .text(metaData.lineyLabel);\r\n    }\r\n    if (lineData) {\r\n      svg\r\n        .append('path')\r\n        .datum(lineData)\r\n        .attr('fill', 'none')\r\n        .attr('stroke', self.chartConfiguration.lineGraphColor)\r\n        .attr('stroke-width', 1.5)\r\n        .attr(\r\n          'd',\r\n          d3\r\n            .line()\r\n            .x(function (d) {\r\n              return x(d.name) + x.bandwidth() / 2;\r\n            })\r\n            .y(function (d) {\r\n              return lineYscale(d.value);\r\n            })\r\n        );\r\n\r\n      var dot = svg\r\n        .selectAll('myCircles')\r\n        .data(lineData)\r\n        .enter()\r\n        .append('g')\r\n        .on('click', function (d) {\r\n          if (\r\n            !metaData.barWithoutClick ||\r\n            !metaData.barWithoutClick.length ||\r\n            (!metaData.barWithoutClick.includes(d?.name) &&\r\n              !metaData.barWithoutClick.includes(d?.key))\r\n          )\r\n            self.handleClick(d);\r\n        });\r\n\r\n      dot\r\n        .append('circle')\r\n        .attr('fill', function (d) {\r\n          return self.chartConfiguration.lineGraphColor;\r\n        })\r\n        .attr('stroke', 'none')\r\n        .attr('cx', function (d) {\r\n          return x(d.name) + x.bandwidth() / 2;\r\n        })\r\n        .attr('cy', function (d) {\r\n          return lineYscale(d.value);\r\n        })\r\n        .style('cursor', () =>\r\n          self.chartData.metaData.hasDrillDown ? 'pointer' : 'default'\r\n        )\r\n        .attr('r', 3);\r\n\r\n      if (self.chartConfiguration.lineGraphColor) {\r\n        dot\r\n          .append('text')\r\n          .attr('class', 'dot')\r\n          .attr('fill', 'var(--chart-text-color)')\r\n          .attr('color', self.chartConfiguration.lineGraphColor)\r\n          .attr('style', 'font-size: ' + '.85em')\r\n          .attr('x', function (d, i) {\r\n            return x(d.name) + x.bandwidth() / 2;\r\n          })\r\n          .attr('y', function (d) {\r\n            return lineYscale(d.value);\r\n          })\r\n          .attr('dy', '-1em')\r\n          .text(function (d) {\r\n            return self.chartConfiguration.labelFormatter(d.value);\r\n          });\r\n      }\r\n    }\r\n  }\r\n\r\nprivate calculateChartDimensions(chartContainer: any, verticalstackedcontainer: any, margin: any, self: any) {\r\n  let width = parseInt(chartContainer.style('width')) - margin.left - margin.right;\r\n  const dataLength = this.chartData.data.length;\r\n\r\n  // ---- Width Logic (no change) ----\r\n  if (dataLength > 30 && this.isZoomedOut) {\r\n    width =\r\n      width > dataLength * 40\r\n        ? this.chartData.dropdownData1\r\n          ? dataLength * 60\r\n          : width\r\n        : this.chartData.dropdownData1\r\n        ? dataLength * 60\r\n        : dataLength * 40;\r\n\r\n    width = width > dataLength * 40 ? width : dataLength * 40;\r\n  }\r\n\r\n  if (\r\n    this.chartData.dropdownData2 &&\r\n    width < dataLength * 120 &&\r\n    this.isZoomedOut\r\n  ) {\r\n    width = dataLength * 120;\r\n  }\r\n\r\n  if (dataLength > 8 && !this.isZoomedOut) {\r\n    if (\r\n      this.chartData.dropdownData2 &&\r\n      width < dataLength * 250\r\n    ) {\r\n      width = dataLength * 250;\r\n    } else {\r\n      width = dataLength * 160;\r\n    }\r\n  }\r\n\r\n  // ---- Height Logic (no change) ----\r\n  let height =\r\n    parseInt(verticalstackedcontainer.style('height')) *\r\n      (self.chartConfiguration.svgHeight / 100) -\r\n    margin.top -\r\n    margin.bottom;\r\n\r\n  if (\r\n    this.chartConfiguration.isFullScreen !== undefined &&\r\n    this.chartConfiguration.isFullScreen\r\n  ) {\r\n    height =\r\n      this.chartConfiguration.svgHeight !== 70\r\n        ? this.chartConfiguration.svgHeight\r\n        : parseInt(verticalstackedcontainer.style('height'));\r\n  }\r\n\r\n  if (this.chartConfiguration.isDrilldownChart && !this.isHeaderVisible) {\r\n    height =\r\n      parseInt(verticalstackedcontainer.style('height')) -\r\n      margin.top -\r\n      margin.bottom -\r\n      130;\r\n  }\r\n\r\n  if (this.chartConfiguration.isHeaderVisible) {\r\n    height =\r\n      parseInt(verticalstackedcontainer.style('height')) -\r\n      margin.top -\r\n      margin.bottom -\r\n      100;\r\n  }\r\n\r\n  return { width, height };\r\n}\r\nprivate createChartContainers(\r\n  chartContainer: any,\r\n  margin: any,\r\n  height: number,\r\n  rightSvgWidth: number,\r\n  self: any,\r\n  width: number\r\n) {\r\n  // Outer container\r\n  const outerContainer = chartContainer\r\n    .append('div')\r\n    .attr('id', self.uniqueId)\r\n    .attr('class', 'outer-container')\r\n    .style('width', '100%')\r\n    .style('height', height)\r\n    .style('overflow-x', 'hidden')\r\n    .style('padding-left', `${margin.left}px`)\r\n    .style('padding-right', `${rightSvgWidth}px`)\r\n    .style('margin-left', '15px');\r\n\r\n  // Left Y-Axis\r\n  const svgYAxisLeft = outerContainer\r\n    .append('svg')\r\n    .attr('width', '100')\r\n    .attr('height', height + margin.top + margin.bottom + 10)\r\n    .style('position', 'absolute')\r\n    .style('left', '0')\r\n    .style('z-index', 1)\r\n    .append('g')\r\n    .attr('transform', `translate(${margin.left + 15},${margin.top})`);\r\n\r\n  // Right Y-Axis\r\n  const svgYAxisRight = outerContainer\r\n    .append('svg')\r\n    .attr('width', rightSvgWidth)\r\n    .attr('height', height + margin.top + margin.bottom + 10)\r\n    .style('position', 'absolute')\r\n    .style('right', '12px')\r\n    .style('z-index', 1)\r\n    .append('g')\r\n    .attr('transform', `translate(0,${margin.top})`);\r\n\r\n  // Inner scrollable container\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  // Main SVG\r\n  const svg = innerContainer\r\n    .append('svg')\r\n    .attr('width', width - rightSvgWidth)\r\n    .attr('height', height + margin.top + margin.bottom + 60)\r\n    .append('g')\r\n    .attr('transform', `translate(0,${margin.top})`);\r\n\r\n  return { outerContainer, svgYAxisLeft, svgYAxisRight, innerContainer, svg };\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  handleHeaderMenuClick(id) {\r\n    this.headerMenuclickEvent.emit(id);\r\n  }\r\n  handleDD1Click(event) {\r\n    this.isDD1Open = true;\r\n    this.isDD2Open = false;\r\n  }\r\n  handleDD2Click(event) {\r\n    this.isDD2Open = true;\r\n    this.isDD1Open = false;\r\n  }\r\n  handleCompareByFilterSelection(event) {\r\n    this.clickEvent.emit(event);\r\n  }\r\n}\r\n","<div\r\n  #groupcontainer\r\n  class=\"lib-chart-wrapper\"\r\n  [ngClass]=\"{ 'lib-no-background': isTransparentBackground }\"\r\n  style=\"background-color: var(--card-bg);\"\r\n  (resized)=\"onResized($event)\"\r\n>\r\n  <div class=\"header-alt\" *ngIf=\"!isHeaderVisible\">\r\n    <lib-chart-header-v2\r\n      [chartData]=\"chartData\"\r\n      [chartConfiguration]=\"chartConfiguration\"\r\n      (clickEvent)=\"handleClick($event)\"\r\n    ></lib-chart-header-v2>\r\n    <lib-chart-header-v3\r\n      [chartData]=\"chartData\"\r\n      [chartConfiguration]=\"chartConfiguration\"\r\n      (compareByFilterSelection)=\"handleCompareByFilterSelection($event)\"\r\n      (zoomInZoomOutClick)=\"handleZoominZoomoutClick($event)\"\r\n    ></lib-chart-header-v3>\r\n  </div>\r\n  <lib-chart-header-v1\r\n    [title]=\"chartData.metaData.title\"\r\n    [hasDrillDown]=\"chartData.metaData.hasDrillDown\"\r\n    [isEditEnabled]=\"chartData.metaData.isEditEnabled\"\r\n    [menuOptions]=\"chartConfiguration.headerMenuOptions\"\r\n    [isria]=\"customChartConfiguration.isRia\"\r\n    [selectedKpiTooltop]=\"chartConfiguration.selectedKpiTooltop\"\r\n    (menuOptionClickEvent)=\"handleHeaderMenuClick($event)\"\r\n    [isAlertEnabled]=\"isAlertEnabled\"\r\n    *ngIf=\"isHeaderVisible\"\r\n  ></lib-chart-header-v1>\r\n  <div\r\n    *ngIf=\"\r\n      chartData &&\r\n      chartData.metaData &&\r\n      chartConfiguration.legendJustified &&\r\n      legendVisible &&\r\n      chartConfiguration.legendAtTopRight\r\n    \"\r\n    class=\"legend-holder-right\"\r\n    [style.height]=\"chartConfiguration.footerHeight\"\r\n  >\r\n    <ul class=\"display-flex\">\r\n      <li\r\n        class=\"legends-positioning-inline\"\r\n        *ngFor=\"let item of chartData.metaData.colors | keyvalue : keepOrder\"\r\n      >\r\n        <span\r\n          class=\"lib-donut-justified-label-icon-drilldown\"\r\n          [style.background-color]=\"item.value\"\r\n        ></span\r\n        ><span>{{ item.key }}</span>\r\n      </li>\r\n    </ul>\r\n  </div>\r\n  <div\r\n    [style.height]=\"chartConfiguration.svgHeight\"\r\n    id=\"groupchartcontainer\"\r\n    #groupchartcontainer\r\n    class=\"lib-chart-svg\"\r\n  ></div>\r\n\r\n\r\n  <!-- <div\r\n    *ngIf=\"\r\n      chartData &&\r\n      chartData.metaData &&\r\n      chartConfiguration.legendJustified &&\r\n      legendVisible &&\r\n      !chartConfiguration.legendAtTopRight\r\n    \"\r\n    class=\"lib-donut-chart-footer\"\r\n    [style.height]=\"chartConfiguration.footerHeight\"\r\n  >\r\n    <ul class=\"lib-donut-justified-label-wrapper\">\r\n      <li\r\n        class=\"lib-donut-justified-label-item\"\r\n        *ngFor=\"let item of chartData.metaData.colors | keyvalue\"\r\n      >\r\n        <span\r\n          class=\"lib-donut-justified-label-icon\"\r\n          [style.background-color]=\"item.value\"\r\n        ></span\r\n        ><span>{{ item.key }}</span>\r\n      </li>\r\n    </ul>\r\n  </div> -->\r\n\r\n\r\n  <!-- <div *ngIf=\"chartConfiguration?.isDisplayBarDetailsAtBottom\">\r\n    <div\r\n      class=\"bar-values lib-display-flex lib-justify-content-center lib-align-items-center\"\r\n      *ngFor=\"\r\n        let item of chartData.metaData.colors | keyvalue : keepOrder;\r\n        let i = index\r\n      \">\r\n      <div\r\n        class=\"bar-name font-size-1\"\r\n        *ngIf=\"\r\n          chartData.data[0][item.key] &&\r\n          i <= chartConfiguration.howmanyBarDetailsToDisplay\r\n        \"\r\n      >\r\n        {{ item.key }}\r\n      </div>\r\n      <div\r\n        class=\"bar-value lib-display-flex lib-align-items-center font-size-1\"\r\n        [style.color]=\"\r\n          chartConfiguration.barVauleColor ? barVauleColor : item.value\r\n        \"\r\n        *ngIf=\"\r\n          chartData.data[0][item.key] &&\r\n          i <= chartConfiguration.howmanyBarDetailsToDisplay\r\n        \"\r\n      >\r\n        {{ chartData.data[0][item.key] }}\r\n      </div>\r\n    </div>\r\n  </div> -->\r\n</div>\r\n"]}
2355
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"horizontal-grouped-bar-with-scroll-zoom.component.js","sourceRoot":"","sources":["../../../../../projects/axidio-styleguide-library/src/lib/horizontal-grouped-bar-with-scroll-zoom/horizontal-grouped-bar-with-scroll-zoom.component.ts","../../../../../projects/axidio-styleguide-library/src/lib/horizontal-grouped-bar-with-scroll-zoom/horizontal-grouped-bar-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} 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@Component({\r\n  selector: 'lib-horizontal-grouped-bar-with-scroll-zoom',\r\n  templateUrl: './horizontal-grouped-bar-with-scroll-zoom.component.html',\r\n  styleUrls: [\r\n    './horizontal-grouped-bar-with-scroll-zoom.component.less',\r\n    '../common-styles.less',\r\n  ],\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class HorizontalGroupedBarWithScrollZoomComponent\r\n  extends ComponentUniqueId\r\n  implements OnInit\r\n{\r\n  @ViewChild('groupchartcontainer', { static: true })\r\n  containerElt!: ElementRef;\r\n\r\n  @ViewChild('groupcontainer', { static: true })\r\n  groupcontainerElt!: ElementRef;\r\n\r\n  @Input() chartData: any;\r\n  @Input() customChartConfiguration: any;\r\n  @Output() clickEvent = new EventEmitter<any>();\r\n  @Output() headerMenuclickEvent = new EventEmitter<any>();\r\n  isHeaderVisible: boolean = true;\r\n  legendVisible: boolean = true;\r\n  isTransparentBackground: boolean = false;\r\n  chartConfiguration: any = {};\r\n  objectKeys = Object.keys;\r\n\r\n  defaultConfiguration: any = {\r\n    margin: { top: 20, right: 20, bottom: 20, left: 40 },\r\n    labelFormatter: ChartHelper.defaultFormatter,\r\n    svgHeight: 70,\r\n    numberOfYTicks: 5,\r\n    legendJustified: true,\r\n    yLineAxisLabelFomatter: ChartHelper.defaultFormatter,\r\n    yAxisLabelFomatter: ChartHelper.defaultFormatter,\r\n    lineGraphColor: '#F6D283',\r\n    showLineChartAxis: true,\r\n    showValues: true,\r\n    headerMenuOptions: HeaderConfigHelper.headerConfig.headerMenuOptions,\r\n    xAxisGrid: undefined,\r\n    yAxisGrid: false,\r\n    legendVisible: false,\r\n    isHeaderVisible: undefined,\r\n    isTransparentBackground: undefined,\r\n    isMultiChartGridLine: undefined,\r\n    isFullScreen: undefined,\r\n    customYscale: undefined,\r\n    textsOnBar: undefined,\r\n    isXaxisLabelHidden: undefined,\r\n    isYaxisLabelHidden: false,\r\n    isYaxisHidden: undefined,\r\n    isYaxisDashed: undefined,\r\n    textFormatter: undefined,\r\n    isNoAlternateXaxisText: undefined,\r\n    isXgridBetweenLabels: undefined,\r\n    backgroundColor: '#FFFFFF',\r\n    hideLegendOnTop: true,\r\n    isXaxisColor: '#999999',\r\n    labelOverlapMinorFix: true,\r\n    noHoverEffect: true,\r\n    noHoverDisplayData: true,\r\n    showXaxisTop: true,\r\n    displayYaxisLabels: undefined,\r\n    xLabelsOnSameLine: undefined,\r\n    textAlwaysHorizontal: undefined,\r\n    legendAtTopRight: undefined,\r\n    isDrilldownChart: true,\r\n    displayTitleOnTop: undefined,\r\n    isToggleVisible: undefined,\r\n    isTitleHidden: undefined,\r\n    isDisplayBarDetailsAtBottom: undefined,\r\n    howmanyBarDetailsToDisplay: 0,\r\n    barVauleColor: undefined,\r\n    defaultBarHeight: 2,\r\n  };\r\n\r\n  uniqueId: any = this.getUniqueId();\r\n  isZoomedOut: boolean = true;\r\n  isDD1Open: boolean = false;\r\n  isDD2Open: boolean = false;\r\n\r\n  constructor() {\r\n    super();\r\n  }\r\n\r\n  onResized(event: ResizedEvent) {\r\n    let self = this;\r\n    setTimeout(\r\n      function () {\r\n        d3.select('#' + self.uniqueId).remove();\r\n        self.initializegroupChart();\r\n      }.bind(self),\r\n      10\r\n    );\r\n  }\r\n  isZoomOutSelected(isZoomOut, event) {\r\n    this.isZoomedOut = isZoomOut;\r\n    this.onResized(event);\r\n  }\r\n  handleZoominZoomoutClick({ isZoomOut, event }) {\r\n    this.isZoomOutSelected(isZoomOut, event);\r\n  }\r\n  ngOnInit() {}\r\n  isLegendVisible() {\r\n    if (\r\n      this.chartData &&\r\n      this.chartData.metaData.colors &&\r\n      Object.keys(this.chartData.metaData.colors).length > 1\r\n    ) {\r\n      return true;\r\n    }\r\n    return false;\r\n  }\r\n  keepOrder = (a, b) => {\r\n    return a;\r\n  };\r\n\r\n  get isAlertEnabled(): boolean {\r\n    return this.chartConfiguration?.headerMenuOptions?.some(\r\n      (option) => option.id === 'editAlert'\r\n    );\r\n  }  \r\n//   initializegroupChart() {\r\n//     var self = this;\r\n//     let data = [];\r\n//     let metaData: any = null;\r\n//     let keyList = null;\r\n//     let lineData = null;\r\n//     let colorMap = {};\r\n//     var formatFromBackend;\r\n//     var formatForHugeNumbers;\r\n//     const isMobile = window.innerWidth < 576;\r\n//     const isTablet = window.innerWidth >= 576 && window.innerWidth < 992;\r\n//     const isDesktop = window.innerWidth >= 992;\r\n\r\n//    let isria = this.customChartConfiguration.isRia\r\n\r\n//     var x: any;\r\n\r\n//     var alternate_text = false;\r\n//     var short_tick_length = 4;\r\n//     var long_tick_length = 16;\r\n//     /**\r\n//      * longer tick length needed for weekly charts\r\n//      */\r\n//     var short_tick_length_bg = 5;\r\n//     var long_tick_length_bg = 30;\r\n//     var leftAndRightSpaces = 50;\r\n//     var rightSvgWidth = 60;\r\n//     var tempScale;\r\n\r\n//     for (var i in this.defaultConfiguration) {\r\n//       this.chartConfiguration[i] = ChartHelper.getValueByConfigurationType(\r\n//         i,\r\n//         this.defaultConfiguration,\r\n//         this.customChartConfiguration\r\n//       );\r\n//     }\r\n\r\n//     data = this.chartData.data;\r\n//     metaData = this.chartData.metaData;\r\n//     lineData = this.chartData.lineData;\r\n\r\n//     // if (lineData || this.chartData.targetLineData) {\r\n//     //   rightSvgWidth = 60;\r\n//     // }\r\n//     if (!metaData.colorAboveTarget) {\r\n//       metaData['colorAboveTarget'] = metaData.colors;\r\n//     }\r\n//     colorMap = metaData.colors;\r\n//     keyList = metaData.keyList;\r\n\r\n//     var chartContainer = d3.select(this.containerElt.nativeElement);\r\n//     var verticalstackedcontainer = d3.select(\r\n//       this.groupcontainerElt.nativeElement\r\n//     );\r\n//     var margin = this.chartConfiguration.margin;\r\n//     const { width, height } = this.calculateChartDimensions(\r\n//     chartContainer,\r\n//     verticalstackedcontainer,\r\n//     margin,\r\n//     self\r\n//   );\r\n//     /**\r\n//      * for hiding header\r\n//      * used by weekly charts\r\n//      */\r\n//     if (this.chartConfiguration.isHeaderVisible != undefined)\r\n//       this.isHeaderVisible = this.chartConfiguration.isHeaderVisible;\r\n//     /**\r\n//      * for hiding legends\r\n//      * used by weekly charts\r\n//      */\r\n//     if (this.chartConfiguration.legendVisible != undefined) {\r\n//       this.legendVisible = this.chartConfiguration.legendVisible;\r\n//     }\r\n\r\n//     /**\r\n//      * for removing background color so that it can take parents color\r\n//      *\r\n//      */\r\n//     if (this.chartConfiguration.isTransparentBackground != undefined) {\r\n//       this.isTransparentBackground =\r\n//         this.chartConfiguration.isTransparentBackground;\r\n//     }\r\n//     /**\r\n//      * format data values based on configuration received\r\n//      */\r\n//     if (this.chartConfiguration.textFormatter != undefined) {\r\n//       formatFromBackend = ChartHelper.dataValueFormatter(\r\n//         this.chartConfiguration.textFormatter\r\n//       );\r\n//       formatForHugeNumbers = ChartHelper.dataValueFormatter('.2s');\r\n//     }\r\n//     const {\r\n//     outerContainer,\r\n//     svgYAxisLeft,\r\n//     svgYAxisRight,\r\n//     innerContainer,\r\n//     svg\r\n//   } = this.createChartContainers(chartContainer, margin, height, rightSvgWidth, self, width);\r\n//     var subgroups: any = keyList;\r\n\r\n//     var groups = d3\r\n//       .map(data, function (d) {\r\n//         return d.name;\r\n//       })\r\n//       .keys();\r\n\r\n//     /**\r\n//      * x axis range made similar to line chart or vertical stack so that all the charts will get aligned with each other.\r\n//      */\r\n//     if (this.chartConfiguration.isMultiChartGridLine != undefined) {\r\n//       x = d3\r\n//         .scaleBand()\r\n//         .rangeRound([width, 0])\r\n//         .align(0.5)\r\n//         .padding([0.5])\r\n//         .domain(\r\n//           data.map(function (d: any) {\r\n//             return d.name.toLowerCase();\r\n//           })\r\n//         );\r\n//     } else {\r\n//       x = d3\r\n//         .scaleBand()\r\n//         .domain(groups)\r\n//         .range([leftAndRightSpaces, width - rightSvgWidth - leftAndRightSpaces])\r\n//         .padding([0.3]);\r\n//     }\r\n//     // x.bandwidth(96);\r\n//     var xScaleFromOrigin = d3\r\n//       .scaleBand()\r\n//       .domain(groups)\r\n//       .range([0, width - rightSvgWidth]);\r\n//     // .padding([0.2]);\r\n\r\n//     if (this.chartConfiguration.isMultiChartGridLine == undefined) {\r\n//       /**\r\n//        * normal ticks for all dashboard charts\r\n//        */\r\n//       svg\r\n//         .append('g')\r\n//         .attr('class', 'x1 axis1')\r\n//         .attr('transform', 'translate(0,' + height + ')')\r\n//         .call(d3.axisBottom(x))\r\n//         .call((g) => g.select('.domain').remove());\r\n\r\n//       svg.selectAll('g.x1.axis1 g.tick line').remove();\r\n\r\n//       // Only move x-axis labels further down for grouped charts if there is no xLabel\r\n//       if (subgroups.length > 1 && !metaData.xLabel) {\r\n//         svg\r\n//           .selectAll('g.x1.axis1 g.tick text')\r\n//           .attr('class', 'lib-xaxis-labels-texts-drilldown')\r\n//           .style('fill', 'var(--chart-text-color)')\r\n//           .attr('y', 32); // Increase distance from bars (default is ~9)\r\n//       } else {\r\n//         svg\r\n//           .selectAll('g.x1.axis1 g.tick text')\r\n//           .attr('class', 'lib-xaxis-labels-texts-drilldown')\r\n//           .style('fill', 'var(--chart-text-color)');\r\n//       }\r\n//     } \r\n//     else {\r\n//       /**\r\n//        * bigger ticks for weekly charts and more space from x axis to labels\r\n//        */\r\n//       /**\r\n//        * draw x axis\r\n//        */\r\n//       svg\r\n//         .append('g')\r\n//         .attr('class', 'x1 axis1')\r\n//         .attr('transform', 'translate(0,' + height + ')')\r\n//         .call(d3.axisBottom(x).tickSize(0))\r\n//         .call((g) => g.select('.domain').attr('fill', 'none'));\r\n//       /**\r\n//        * tick line size in alternate fashion\r\n//        */\r\n//       svg.selectAll('g.x1.axis1 g.tick line').attr('y2', function () {\r\n//         if (\r\n//           alternate_text &&\r\n//           self.chartConfiguration.isNoAlternateXaxisText == undefined\r\n//         ) {\r\n//           alternate_text = false;\r\n//           return long_tick_length_bg - 7;\r\n//         } else {\r\n//           alternate_text = true;\r\n//           return short_tick_length_bg - 4;\r\n//         }\r\n//       });\r\n//       /**\r\n//        * reset the flag so that values can be shown in same alternate fashion\r\n//        */\r\n//       alternate_text = false;\r\n//       /**\r\n//        * print x-axis label texts\r\n//        * used by weekly charts\r\n//        */\r\n//       svg\r\n//         .selectAll('g.x1.axis1 g.tick text')\r\n//         .attr('class', 'lib-xaxis-labels-texts-weeklycharts')\r\n//         .attr('y', function () {\r\n//           // Minimize gap in maximized (fullscreen) view for weekly charts\r\n//           if (self.chartConfiguration.isFullScreen) {\r\n//             return short_tick_length_bg;\r\n//           }\r\n//           if (alternate_text) {\r\n//             alternate_text = false;\r\n//             return long_tick_length_bg;\r\n//           } else {\r\n//             alternate_text = true;\r\n//             return short_tick_length_bg;\r\n//           }\r\n//         });\r\n//     }\r\n//     if (self.chartConfiguration.xLabelsOnSameLine) {\r\n//       const xAxisLabels = svg\r\n//         .selectAll('g.x1.axis1 g.tick text')\r\n//         .attr('class', 'lib-xaxis-labels-texts-drilldown')\r\n//         .style('font-size', this.isHeaderVisible ? '18px' : '14px')\r\n//         .attr('text-anchor', 'middle')\r\n//         .attr('y', function(d) {\r\n//           // For grouped bar charts with many bars and xLabel present, only add 5 if the label is a date\r\n//           if (subgroups.length > 1 && data.length > 8 && metaData.xLabel) {\r\n//             const isDateLabel = /\\d{2,4}[-\\/]/.test(d);\r\n//             if (self.chartConfiguration.isFullScreen) {\r\n//               return isDateLabel ? short_tick_length_bg + 14 : short_tick_length_bg;\r\n//             }\r\n//             return isDateLabel ? short_tick_length_bg + 14 : short_tick_length_bg;\r\n//           }\r\n//           // For grouped bar charts with many bars and NO xLabel, add space as before, but reduce in fullscreen\r\n//           if (subgroups.length > 1 && data.length > 8 && !metaData.xLabel) {\r\n//             const chartHasExtraBottom = (self.chartConfiguration.margin && self.chartConfiguration.margin.bottom >= 40);\r\n//             if (self.chartConfiguration.isFullScreen) {\r\n//               // Reduce extra gap in maximized view\r\n//               return short_tick_length_bg + 2;\r\n//             }\r\n//             return chartHasExtraBottom ? short_tick_length_bg : short_tick_length_bg + 10;\r\n//           }\r\n//           // Default/fallback logic for other cases\r\n//           let baseY = self.isHeaderVisible ? short_tick_length_bg + 25 : short_tick_length_bg;\r\n//           if (\r\n//             subgroups.length > 1 &&\r\n//             !metaData.xLabel &&\r\n//             (/\\d{2,4}[-\\/]\\d{2}[-\\/]\\d{2,4}/.test(d) || /\\d{2,4}[-\\/]\\d{2,4}/.test(d))\r\n//           ) {\r\n//             baseY = self.isHeaderVisible ? short_tick_length_bg + 15 : short_tick_length_bg + 25;\r\n//           }\r\n//           if (/\\d{2,4}[-\\/]\\d{2,4}/.test(d) && d.indexOf(' ') > -1) {\r\n//             baseY += 4;\r\n//           }\r\n//           // In maximized view, reduce baseY slightly for grouped bars\r\n//           if (self.chartConfiguration.isFullScreen && subgroups.length > 1) {\r\n//             baseY = Math.max(short_tick_length_bg, baseY - 10);\r\n//           }\r\n//           return baseY;\r\n//         })\r\n//         .attr('x', function (d) {\r\n//           if (self.chartData.data.length > 8 && !self.isZoomedOut) {\r\n//             return 1; // Move first line text slightly to the left in zoom-in view for better alignment\r\n//           }\r\n//           return 0; // Default position\r\n//         })\r\n//         .text(function (d) {\r\n//           var isValueToBeIgnored = false;\r\n//           if (isMobile && !self.isHeaderVisible) {\r\n//             let firstPart = d.split(/[\\s\\-]+/)[0];\r\n//             return firstPart.substring(0, 3).toLowerCase();\r\n//           }\r\n//           (data as any[]).map((indiv: any) => {\r\n//             if (\r\n//               indiv.name &&\r\n//               indiv.name.toLowerCase() == d.trim().toLowerCase() &&\r\n//               indiv[metaData.keyList[0]] == -1\r\n//             ) {\r\n//               isValueToBeIgnored = true;\r\n//             }\r\n//           });\r\n//           if (isValueToBeIgnored) {\r\n//             return '';\r\n//           }\r\n//           // Always add space before and after hyphen for date range labels, even when header is visible and label is single line\r\n//           // Apply for grouped bar charts and single bar charts, header visible, single line\r\n//           const dateRangeRegex = /(\\d{2,4}[-\\/]\\d{2}[-\\/]\\d{2,4})\\s*-\\s*(\\d{2,4}[-\\/]\\d{2}[-\\/]\\d{2,4})/;\r\n//           if (dateRangeRegex.test(d.trim())) {\r\n//             return d.trim().replace(dateRangeRegex, (m, d1, d2) => `${d1} - ${d2}`);\r\n//           }\r\n//           // Split date and week labels into two lines in grouped bar zoom-in view (and minimized view)\r\n//           const isDateLabel = /\\d{2,4}[-\\/]/.test(d);\r\n//           const isWeekLabel = /week|wk|w\\d+/i.test(d);\r\n//           if (\r\n//             subgroups.length > 1 && !self.isZoomedOut && data.length > 8 && d.indexOf(' ') > -1 && (isDateLabel || isWeekLabel)\r\n//           ) {\r\n//             var first = d.substring(0, d.indexOf(' '));\r\n//             var second = d.substring(d.indexOf(' ') + 1).trim();\r\n//             return first + '\\n' + second;\r\n//           }\r\n//           // Also keep previous logic for minimized view\r\n//           if (isDateLabel) {\r\n//             if (!self.isHeaderVisible && data.length > 8 && d.indexOf(' ') > -1) {\r\n//               var first = d.substring(0, d.indexOf(' '));\r\n//               var second = d.substring(d.indexOf(' ') + 1).trim();\r\n//               return first + '\\n' + second;\r\n//             } else {\r\n//               return d;\r\n//             }\r\n//           }\r\n//           if (d.trim().indexOf(' ') > -1) {\r\n//             return d.trim().substring(0, d.indexOf(' ')).toLowerCase();\r\n//           }\r\n//           return d.toLowerCase();\r\n//           // If label looks like a date (contains digits and - or /)\r\n//           const isDateLabel2 = /\\d{2,4}[-\\/]/.test(d);\r\n//           // Only split date/week labels if there are many grouped bars and header is not visible\r\n//           if (isDateLabel) {\r\n//             if (!self.isHeaderVisible && data.length > 8 && d.indexOf(' ') > -1) {\r\n//               var first = d.substring(0, d.indexOf(' '));\r\n//               var second = d.substring(d.indexOf(' ') + 1).trim();\r\n//               return first + '\\n' + second;\r\n//             } else {\r\n//               return d;\r\n//             }\r\n//           }\r\n//           if (d.trim().indexOf(' ') > -1) {\r\n//             return d.trim().substring(0, d.indexOf(' ')).toLowerCase();\r\n//           }\r\n//           return d.toLowerCase();\r\n//         });\r\n\r\n//       // Now apply writing-mode: sideways-lr for grouped charts with date labels in zoomed-out view and many bars\r\n//       xAxisLabels.each(function(this: SVGTextElement, d: any) {\r\n//         // Only apply writing-mode for exact date labels, not those containing 'week' or similar\r\n//         const isDateLabel = /^(\\d{2,4}[-\\/])?\\d{2,4}[-\\/]\\d{2,4}$/.test(d.trim());\r\n//         const isWeekLabel = /week|wk|w\\d+/i.test(d);\r\n//         if (subgroups.length > 1 && self.isZoomedOut && data.length > 8 && isDateLabel && !isWeekLabel) {\r\n//           d3.select(this).style('writing-mode', 'sideways-lr');\r\n//         }\r\n//       });\r\n//       if (!isMobile) {\r\n//         svg\r\n//           .selectAll('g.x1.axis1 g.tick')\r\n//           .filter(function (d) {\r\n//             return !/\\d{2,4}[-\\/]/.test(d); // Only process non-date labels\r\n//           })\r\n//           .append('text')\r\n//           .attr('class', 'lib-xaxis-labels-texts-drilldown')\r\n//           .attr('y', long_tick_length_bg)\r\n//           .attr('fill', 'var(--chart-text-color)')\r\n//           .attr('x', function (d) {\r\n//             if (self.chartData.data.length > 8 && !self.isZoomedOut) {\r\n//               return 1; // Move text slightly to the left\r\n//             }\r\n//             return 0; // Default position\r\n//           })\r\n//           .text(function (d) {\r\n//             if (d.trim().indexOf(' ') > -1) {\r\n//               return d.trim().substring(d.indexOf(' '), d.length).toLowerCase();\r\n//             }\r\n//             return '';\r\n//           });\r\n//       }\r\n//     }\r\n//         if (isria && self.chartData.data.length > 8) {\r\n//       svg\r\n//         .selectAll('g.x1.axis1 g.tick text')\r\n//         .classed('mobile-xaxis-override', true)\r\n//         .text(function (d: string) {\r\n//           return d.substring(0, 3);\r\n//         })\r\n//         .style('font-size', '12px') \r\n//         .attr('y', 5)               \r\n//         .attr('x', 5)                \r\n//         .style('text-anchor', 'middle');\r\n//     }\r\n//     if (isMobile && !this.isHeaderVisible) {\r\n//       svg\r\n//         .selectAll('g.x1.axis1 g.tick text')\r\n//         .classed('mobile-xaxis-override', true);\r\n//     }\r\n//     /**y scale for left y axis */\r\n//     var y = d3.scaleLinear().rangeRound([height, 0]);\r\n//     var maxValue = d3.max(data, (d) => d3.max(keyList, (key) => +d[key]));\r\n//     if (maxValue == 0) {\r\n//       if (this.chartData.targetLineData) {\r\n//         maxValue = this.chartData.targetLineData.target + 20;\r\n//       } else {\r\n//         maxValue = 100;\r\n//       }\r\n//     }\r\n\r\n//     if (this.chartConfiguration.customYscale) {\r\n//       /**\r\n//        * increase y-scale so that values wont cross or exceed out of range\r\n//        * used in weekly charts\r\n//        */\r\n//       maxValue = maxValue * this.chartConfiguration.customYscale;\r\n//     }\r\n//     if (\r\n//       this.chartData.targetLineData &&\r\n//       maxValue < this.chartData.targetLineData.target\r\n//     ) {\r\n//       maxValue =\r\n//         maxValue < 10 && this.chartData.targetLineData.target < 10\r\n//           ? this.chartData.targetLineData.target + 3\r\n//           : this.chartData.targetLineData.target + 20;\r\n//     }\r\n//     y.domain([0, maxValue]).nice();\r\n//     let lineYscale;\r\n\r\n//     if (lineData != null) {\r\n//       let maxLineValue = d3.max(lineData, function (d) {\r\n//         return +d.value;\r\n//       });\r\n\r\n//       maxLineValue = maxLineValue * this.chartConfiguration.customYscale;\r\n\r\n//       let minLineValue = d3.min(lineData, function (d) {\r\n//         return +d.value;\r\n//       });\r\n//       if (maxLineValue > 0) minLineValue = minLineValue - 3;\r\n//       if (minLineValue > 0) {\r\n//         minLineValue = 0;\r\n//       }\r\n//       lineYscale = d3\r\n//         .scaleLinear()\r\n//         .domain([minLineValue, maxLineValue])\r\n//         .range([height, minLineValue]);\r\n//     }\r\n//     let yLineAxis;\r\n//     if (lineYscale != null) {\r\n//       yLineAxis = d3\r\n//         .axisRight(lineYscale)\r\n//         .ticks(self.chartConfiguration.numberOfYTicks)\r\n//         .tickSize(0)\r\n//         .tickFormat(self.chartConfiguration.yLineAxisLabelFomatter);\r\n//     }\r\n//     /**\r\n//      * show x-axis grid between labels\r\n//      * used by weekly charts\r\n//      */\r\n//     if (self.chartConfiguration.isXgridBetweenLabels) {\r\n//       svg\r\n//         .append('g')\r\n//         .attr('class', 'grid')\r\n//         .attr(\r\n//           'transform',\r\n//           'translate(' + x.bandwidth() / 2 + ',' + height + ')'\r\n//         )\r\n//         .call(d3.axisBottom(x).tickSize(-height).tickFormat(''))\r\n//         .style('stroke-dasharray', '5 5')\r\n//         .style('color', 'var(--chart-grid-color, #999999)') // Use CSS variable\r\n//         .call((g) => g.select('.domain').remove());\r\n//     }\r\n\r\n//     if (this.chartConfiguration.yAxisGrid) {\r\n//       svg\r\n//         .append('g')\r\n//         .call(\r\n//           d3\r\n//             .axisLeft(y)\r\n//             .ticks(self.chartConfiguration.numberOfYTicks)\r\n//             .tickSize(-width)\r\n//         )\r\n//         .style('color', 'var(--chart-axis-color, #B9B9B9)')\r\n//         .style('opacity', '0.5')\r\n//         .call((g) => {\r\n//           g.select('.domain')\r\n//             .remove()\r\n//             .style('stroke', 'var(--chart-domain-color, #000000)'); // Add CSS variable for domain\r\n//         });\r\n//     } else {\r\n//       svg\r\n//         .append('g')\r\n//         .call(d3.axisLeft(y).ticks(self.chartConfiguration.numberOfYTicks))\r\n//         .style('color', 'var(--chart-axis-color, #B9B9B9)')\r\n//         .style('opacity', '0.5')\r\n//         .call((g) => {\r\n//           g.select('.domain')\r\n//             .style('stroke', 'var(--chart-domain-color, #000000)') // Add CSS variable for domain\r\n//             .style('stroke-width', '1px'); // Ensure visibility\r\n//         });\r\n//     }\r\n\r\n//     var xSubgroup = d3.scaleBand().domain(subgroups);\r\n//     if (subgroups.length > 1 && !this.isZoomedOut) {\r\n//   // For grouped bar charts in zoom-in view, use full x.bandwidth() for subgroups\r\n//   xSubgroup.range([0, x.bandwidth()]);\r\n//     } else if (subgroups.length === 1 && !this.isZoomedOut) {\r\n//       // For single-bar (non-grouped) charts in zoom-in view, set bar width to 100 (increased from 80)\r\n//       xSubgroup.range([0, 100]);\r\n//     } else if (this.chartConfiguration.isMultiChartGridLine == undefined) {\r\n//       xSubgroup.range([0, x.bandwidth()]);\r\n//     } else {\r\n//       // used to make grouped bars with lesser width as we are not using padding for width\r\n//       xSubgroup.range([0, x.bandwidth()]);\r\n//     }\r\n//     // if (this.chartConfiguration.isDrilldownChart) {\r\n\r\n//     // }\r\n//     var color = d3\r\n//       .scaleOrdinal()\r\n//       .domain(subgroups)\r\n//       .range(Object.values(metaData.colors));\r\n//     // var colorAboveTarget = d3\r\n//     //   .scaleOrdinal()\r\n//     //   .domain(subgroups)\r\n//     //   .range(Object.values(metaData.colorAboveTarget));\r\n//     var state = svg\r\n//       .append('g')\r\n//       .selectAll('.state')\r\n//       .data(data)\r\n//       .enter()\r\n//       .append('g')\r\n//       .attr('transform', function (d) {\r\n//         return 'translate(' + x(d.name) + ',0)';\r\n//       });\r\n//     state\r\n//       .selectAll('rect')\r\n//       .data(function (d) {\r\n//         let newList: any = [];\r\n//         subgroups.map(function (key) {\r\n//           // if (key !== \"group\") {\r\n//           let obj: any = { key: key, value: d[key], name: d.name };\r\n//           newList.push(obj);\r\n//           // }\r\n//         });\r\n//         return newList;\r\n//       })\r\n//       .enter()\r\n//       .append('rect')\r\n//       .attr('class', 'bars')\r\n//       .on('click', function (d) {\r\n//         if (d.key != 'Target') {\r\n//           if (\r\n//             !metaData.barWithoutClick ||\r\n//             !metaData.barWithoutClick.length ||\r\n//             (!metaData.barWithoutClick.includes(d?.name) &&\r\n//               !metaData.barWithoutClick.includes(d?.key))\r\n//           )\r\n//             // self.handleClick(d.data.name);\r\n//             self.handleClick(d);\r\n//         }\r\n//       })\r\n//       .attr('x', function (d) {\r\n//         if (self.chartConfiguration.isDrilldownChart) {\r\n//           data.map((indiv: any) => {\r\n//             if (indiv.name == d.name) {\r\n//               let keys = Object.keys(indiv).filter((temp, i) => i != 0);\r\n//               tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);\r\n//               if (x.bandwidth() > 100) {\r\n//                 // Increase bar width a bit in zoom-in view\r\n//                 let reducedBarWidth = 60;\r\n//                 if (!self.isZoomedOut) {\r\n//                   reducedBarWidth = 30;\r\n//                 }\r\n//                 if (self.chartData.data.length == 1) {\r\n//                   if (Object.keys(self.chartData.data[0]).length == 2) {\r\n//                     tempScale.range([\r\n//                       0 + (x.bandwidth() - reducedBarWidth) / 2,\r\n//                       x.bandwidth() - (x.bandwidth() - reducedBarWidth) / 2,\r\n//                     ]);\r\n//                   } else\r\n//                     tempScale.range([\r\n//                       0 + (x.bandwidth() - reducedBarWidth) / 2,\r\n//                       x.bandwidth() - (x.bandwidth() - reducedBarWidth) / 2,\r\n//                     ]);\r\n//                 } else\r\n//                   tempScale.range([\r\n//                     0 + (x.bandwidth() - reducedBarWidth) / 2,\r\n//                     x.bandwidth() - (x.bandwidth() - reducedBarWidth) / 2,\r\n//                   ]);\r\n//               }\r\n//             }\r\n//           });\r\n//           return tempScale(d.key);\r\n//         }\r\n//         return xSubgroup(d.key);\r\n//       })\r\n//       .attr('y', function (d) {\r\n//         if (d.value == -1) {\r\n//           return y(0);\r\n//         }\r\n\r\n//         if (d.value >= 0) {\r\n//           const barHeight = height - y(d.value);\r\n//           const minHeight = self.chartConfiguration.defaultBarHeight || 2;\r\n//           return barHeight < minHeight ? y(0) - minHeight : y(d.value);\r\n//         }\r\n\r\n//         return y(0);\r\n//       })\r\n//       .attr('width', function (d) {\r\n//         // For grouped bar charts in zoom-in view, set bar width to 50 for maximum thickness\r\n//         if (subgroups.length > 1 && !self.isZoomedOut) {\r\n//           return 50;\r\n//         }\r\n//         // For single-bar (non-grouped) charts in zoom-in view, set bar width to 80\r\n//         if (subgroups.length === 1 && !self.isZoomedOut) {\r\n//           return 80;\r\n//         }\r\n//           let tempScale = d3.scaleBand().domain([]).range([0, 0]);\r\n//         // Default logic for other chart types\r\n//         if (self.chartConfiguration.isDrilldownChart) {\r\n//           data.map((indiv: any) => {\r\n//             if (indiv.name == d.name) {\r\n//               let keys = Object.keys(indiv).filter((temp, i) => i != 0);\r\n//               tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);\r\n//               if (x.bandwidth() > 100) {\r\n//                 // Increase bar width a bit in zoom-in view\r\n//                 let reducedBarWidth = 60;\r\n//                 if (!self.isZoomedOut) {\r\n//                   reducedBarWidth = 100;\r\n//                 }\r\n//                 if (self.chartData.data.length == 1) {\r\n//                   if (Object.keys(self.chartData.data[0]).length == 2) {\r\n//                     tempScale.range([\r\n//                       0 + (x.bandwidth() - reducedBarWidth) / 2,\r\n//                       x.bandwidth() - (x.bandwidth() - reducedBarWidth) / 2,\r\n//                     ]);\r\n//                   } else\r\n//                     tempScale.range([\r\n//                       0 + (x.bandwidth() - reducedBarWidth) / 2,\r\n//                       x.bandwidth() - (x.bandwidth() - reducedBarWidth) / 2,\r\n//                     ]);\r\n//                 } else\r\n//                   tempScale.range([\r\n//                     0 + (x.bandwidth() - reducedBarWidth) / 2,\r\n//                     x.bandwidth() - (x.bandwidth() - reducedBarWidth) / 2,\r\n//                   ]);\r\n//               }\r\n//             }\r\n//           });\r\n//           return self.isZoomedOut\r\n//             ? tempScale.bandwidth()\r\n//             : self.chartData.data.length && self.chartData.data.length > 8\r\n//             ? tempScale.bandwidth() \r\n//             : tempScale.bandwidth();\r\n//         }\r\n//         return self.isZoomedOut\r\n//           ? tempScale.bandwidth()\r\n//           : self.chartData.data.length && self.chartData.data.length > 8\r\n//           ? tempScale.bandwidth()\r\n//           : tempScale.bandwidth();\r\n//       })\r\n//       .attr('height', function (d) {\r\n//         if (d.value == -1) {\r\n//           return height - y(0);\r\n//         }\r\n\r\n//         if (d.value >= 0) {\r\n//           const barHeight = height - y(d.value);\r\n//           const minHeight = self.chartConfiguration.defaultBarHeight || 2;\r\n//           return Math.max(barHeight, minHeight);\r\n//         }\r\n\r\n//         return height - y(0);\r\n//       })\r\n//       .style('cursor', function (d) {\r\n//         if (metaData.hasDrillDown && !isria) return 'pointer';\r\n//           else return 'default';\r\n//       })\r\n//       .attr('fill', function (d) {\r\n//         if (\r\n//           d.value &&\r\n//           self.chartData.targetLineData &&\r\n//           d.value >= parseFloat(self.chartData.targetLineData.target) &&\r\n//           self.chartData.metaData.colorAboveTarget\r\n//         ) {\r\n//           const key = d.key.toLowerCase();\r\n//           const colorAboveTarget = Object.keys(self.chartData.metaData.colorAboveTarget).find(\r\n//             k => k.toLowerCase() === key\r\n//           );\r\n//           if (colorAboveTarget) {\r\n//             return self.chartData.metaData.colorAboveTarget[colorAboveTarget];\r\n//           }\r\n//         }\r\n//         return self.chartData.metaData.colors[d.key];\r\n//       });\r\n\r\n//     /**\r\n//      * display angled texts on the bars\r\n//      */\r\n//     if (this.chartConfiguration.textsOnBar != undefined && !this.isZoomedOut) {\r\n//       state\r\n//         .selectAll('text')\r\n//         .data(function (d) {\r\n//           let newList: any = [];\r\n//           subgroups.map(function (key) {\r\n//             let obj: any = { key: key, value: d[key], name: d.name };\r\n//             newList.push(obj);\r\n//           });\r\n//           return newList;\r\n//         })\r\n//         .enter()\r\n//         .append('text')\r\n//         .attr('fill', 'var(--chart-text-color)')\r\n//         .attr('x', function (d) {\r\n//           return 0;\r\n//         })\r\n//         .attr('y', function (d) {\r\n//           return 0;\r\n//         })\r\n//         .attr('class', 'lib-data-labels-weeklycharts')\r\n//         .text(function (d) {\r\n//           return d.key && d.value\r\n//             ? d.key.length > 20\r\n//               ? d.key.substring(0, 17) + '...'\r\n//               : d.key\r\n//             : '';\r\n//         })\r\n//         .style('fill', function (d) {\r\n//           return '#000';\r\n//         })\r\n//         .style('font-weight', 'bold')\r\n//         .style('font-size', function (d) {\r\n//           if (self.isZoomedOut) {\r\n//             return '9px'; // 👈 Zoomed out mode\r\n//           }\r\n\r\n//           if (self.chartConfiguration.isDrilldownChart) {\r\n//             if (window.innerWidth > 1900) {\r\n//               return '18px';\r\n//             } else if (window.innerWidth < 1400) {\r\n//               return '10px';\r\n//             } else {\r\n//               return '14px';\r\n//             }\r\n//           } else {\r\n//             return '14px';\r\n//           }\r\n//         })\r\n//         .attr('transform', function (d) {\r\n//           data.map((indiv: any) => {\r\n//             if (indiv.name == d.name) {\r\n//               let keys = Object.keys(indiv).filter((temp, i) => i != 0);\r\n//               var temp;\r\n//               tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);\r\n//               if (x.bandwidth() > 100) {\r\n//                 if (self.chartData.data.length == 1) {\r\n//                   if (Object.keys(self.chartData.data[0]).length == 2) {\r\n//                     tempScale.range([\r\n//                       0 + (x.bandwidth() - 200) / 2,\r\n//                       x.bandwidth() - (x.bandwidth() - 200) / 2,\r\n//                     ]);\r\n//                     // .padding(0.05);\r\n//                   } else\r\n//                     tempScale.range([\r\n//                       0 + (x.bandwidth() - 300) / 2,\r\n//                       x.bandwidth() - (x.bandwidth() - 300) / 2,\r\n//                     ]);\r\n//                   // .padding(0.05);\r\n//                 } else\r\n//                   tempScale.range([\r\n//                     0 + (x.bandwidth() - 125) / 2,\r\n//                     x.bandwidth() - (x.bandwidth() - 125) / 2,\r\n//                   ]);\r\n//               }\r\n//             }\r\n//           });\r\n//           /**\r\n//            * if set, then all texts ll be horizontal\r\n//            */\r\n//           if (self.chartConfiguration.textAlwaysHorizontal) {\r\n//             return (\r\n//               'translate(' + xSubgroup(d.key) + ',' + (y(d.value) - 3) + ')'\r\n//             );\r\n//           }\r\n//           /**\r\n//            * rotate texts having more than one digits\r\n//            */\r\n//           // if (d.value > 9)\r\n//           if (!isNaN(tempScale(d.key)))\r\n//             return (\r\n//               'translate(' +\r\n//               (tempScale(d.key) + tempScale.bandwidth() * 0.55) +\r\n//               ',' +\r\n//               (y(0) - 10) +\r\n//               ') rotate(270)'\r\n//             );\r\n//           return 'translate(0,0)';\r\n//           // else\r\n//           //   return (\r\n//           //     'translate(' +\r\n//           //     (tempScale(d.key) + tempScale.bandwidth() / 2) +\r\n//           //     ',' +\r\n//           //     y(0) +\r\n//           //     ')'\r\n//           //   );\r\n//         })\r\n//         .on('click', function (d) {\r\n//           if (\r\n//             !metaData.barWithoutClick ||\r\n//             !metaData.barWithoutClick.length ||\r\n//             (!metaData.barWithoutClick.includes(d?.name) &&\r\n//               !metaData.barWithoutClick.includes(d?.key))\r\n//           )\r\n//             self.handleClick(d);\r\n//         });\r\n//             if (!isria) {\r\n//                     state\r\n//         .selectAll('.lib-data-labels-weeklycharts')\r\n//         .on('mouseout', handleMouseOut)\r\n//         .on('mouseover', handleMouseOver);\r\n//             }\r\n//     }\r\n//     if (this.chartConfiguration.displayTitleOnTop || (\r\n//       this.chartConfiguration.textsOnBar == undefined &&\r\n//       this.chartConfiguration.displayTitleOnTop == undefined\r\n//     )) {\r\n\r\n//                   if (!isria) {\r\n//                           state\r\n//         .selectAll('rect')\r\n//         .on('mouseout', handleMouseOut)\r\n//         .on('mouseover', handleMouseOver);\r\n//                   }\r\n//     }\r\n//     function handleMouseOver(d, i) {\r\n//       svg.selectAll('.lib-verticalstack-title-ontop').remove();\r\n//       svg\r\n//         .append('foreignObject')\r\n//         .attr('x', function () {\r\n//           // ...existing code for tempScale calculation...\r\n//           var elementsCounter;\r\n//           data.map((indiv: any) => {\r\n//             if (indiv.name == d.name) {\r\n//               let keys = Object.keys(indiv).filter((temp, i) => i != 0);\r\n//               elementsCounter = keys.length;\r\n//               tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);\r\n//               if (x.bandwidth() > 100) {\r\n//                 if (self.chartData.data.length == 1) {\r\n//                   if (Object.keys(self.chartData.data[0]).length == 2) {\r\n//                     tempScale.range([\r\n//                       0 + (x.bandwidth() - 200) / 2,\r\n//                       x.bandwidth() - (x.bandwidth() - 200) / 2,\r\n//                     ]);\r\n//                   } else\r\n//                     tempScale.range([\r\n//                       0 + (x.bandwidth() - 300) / 2,\r\n//                       x.bandwidth() - (x.bandwidth() - 300) / 2,\r\n//                     ]);\r\n//                 } else\r\n//                   tempScale.range([\r\n//                     0 + (x.bandwidth() - 125) / 2,\r\n//                     x.bandwidth() - (x.bandwidth() - 125) / 2,\r\n//                   ]);\r\n//               }\r\n//             }\r\n//           });\r\n//           if (metaData.hasDrillDown) {\r\n//             if (tempScale.bandwidth() + leftAndRightSpaces * 2 > 180) {\r\n//               return (\r\n//                 x(d.name) + tempScale(d.key) + tempScale.bandwidth() / 2 - 90\r\n//               );\r\n//             }\r\n//             return (\r\n//               x(d.name) +\r\n//               tempScale(d.key) -\r\n//               (tempScale.bandwidth() + leftAndRightSpaces * 2) / 2 +\r\n//               tempScale.bandwidth() / 2\r\n//             );\r\n//           } else return x(d.name) + tempScale(d.key) - (tempScale.bandwidth() + leftAndRightSpaces * 2) / 2 + tempScale.bandwidth() / 2;\r\n//         })\r\n//         .attr('class', 'lib-verticalstack-title-ontop')\r\n//         .attr('y', function () {\r\n//           return y(d.value) - 3 - 40 - 10;\r\n//         })\r\n//         .attr('dy', function () {\r\n//           return d.class;\r\n//         })\r\n//         .attr('width', function () {\r\n//           data.map((indiv: any) => {\r\n//             if (indiv.name == d.name) {\r\n//               let keys = Object.keys(indiv).filter((temp, i) => i != 0);\r\n//               tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);\r\n//               if (x.bandwidth() > 100) {\r\n//                 if (self.chartData.data.length == 1) {\r\n//                   if (Object.keys(self.chartData.data[0]).length == 2) {\r\n//                     tempScale.range([\r\n//                       0 + (x.bandwidth() - 200) / 2,\r\n//                       x.bandwidth() - (x.bandwidth() - 200) / 2,\r\n//                     ]);\r\n//                   } else\r\n//                     tempScale.range([\r\n//                       0 + (x.bandwidth() - 300) / 2,\r\n//                       x.bandwidth() - (x.bandwidth() - 300) / 2,\r\n//                     ]);\r\n//                 } else\r\n//                   tempScale.range([\r\n//                     0 + (x.bandwidth() - 125) / 2,\r\n//                     x.bandwidth() - (x.bandwidth() - 125) / 2,\r\n//                   ]);\r\n//               }\r\n//             }\r\n//           });\r\n//           if (metaData.hasDrillDown) {\r\n//             if (tempScale.bandwidth() + leftAndRightSpaces * 2 > 180) {\r\n//               return '180px';\r\n//             }\r\n//             return tempScale.bandwidth() + leftAndRightSpaces * 2;\r\n//           } else return tempScale.bandwidth() + leftAndRightSpaces * 2;\r\n//         })\r\n//         .attr('height', 50)\r\n//         .append('xhtml:div')\r\n//         .attr('class', 'title')\r\n//         .style('z-index', 99)\r\n//         .html(function () {\r\n//           let barLabel = d.key;\r\n//           let dataType = metaData.dataType ? metaData.dataType : '';\r\n//           let value = d.value;\r\n//           let desiredText =\r\n//             '<span class=\"title-bar-name\">' + barLabel + '</span>';\r\n//           desiredText +=\r\n//             '<span class=\"title-bar-value\"><span>' +\r\n//             value +\r\n//             '</span>' +\r\n//             dataType +\r\n//             '</span>';\r\n//           return desiredText;\r\n//         });\r\n//     }\r\n//     function handleMouseOut(d, i) {\r\n//       svg.selectAll('.lib-verticalstack-title-ontop').remove();\r\n//     }\r\n//     svg\r\n//       .append('g')\r\n//       .attr('class', 'x2 axis2')\r\n//       .attr('transform', 'translate(0,' + height + ')')\r\n//       .style('color', 'var(--chart-axis-color, #000)') // Use CSS variable instead of hardcoded #000\r\n//       .call(d3.axisBottom(xScaleFromOrigin).tickSize(0))\r\n//       .call((g) => g.select('.domain').attr('fill', 'none'));\r\n//     svg.selectAll('g.x2.axis2 g.tick text').style('display', 'none');\r\n//     svg\r\n//       .append('g')\r\n//       .attr('class', 'lib-stacked-y-axis-text yaxis-dashed')\r\n//       .attr('style', self.chartConfiguration.yAxisCustomTextStyles)\r\n//       .attr('transform', 'translate(0,0)')\r\n//       .call(y)\r\n//       .style('display', 'none');\r\n//     svgYAxisLeft\r\n//       .append('g')\r\n//       .append('g')\r\n//       .attr('class', 'lib-yaxis-labels-texts-drilldown yaxis-dashed')\r\n//       .attr('style', self.chartConfiguration.yAxisCustomTextStyles)\r\n//       .attr('transform', 'translate(0,0)')\r\n//       .call(\r\n//         d3\r\n//           .axisLeft(y)\r\n//           .tickSize(0)\r\n//           .ticks(self.chartConfiguration.numberOfYTicks)\r\n//           .tickFormat(function (d) {\r\n//             const formatted = self.chartConfiguration.yAxisLabelFomatter\r\n//               ? self.chartConfiguration.yAxisLabelFomatter(d)\r\n//               : d;\r\n//             return formatted >= 1000 ? formatted / 1000 + 'k' : formatted;\r\n//           })\r\n//       )\r\n//       .call((g) => {\r\n//         // Style the domain line for theme support\r\n//         g.select('.domain')\r\n//           .style('stroke', 'var(--chart-domain-color, #000000)')\r\n//           .style('stroke-width', '1px');\r\n//       })\r\n//       .selectAll('text')\r\n//       .style('fill', 'var(--chart-text-color)');\r\n//     svgYAxisRight\r\n//       .append('g')\r\n//       .attr('class', 'lib-yaxis-labels-texts-drilldown yaxis-dashed')\r\n//       .attr('style', self.chartConfiguration.yAxisCustomTextStyles)\r\n//       .attr('transform', 'translate(0,0)')\r\n//       .call(y)\r\n//       .style('display', 'none');\r\n//     /**\r\n//      * hide x axis labels\r\n//      * config is there for future use\r\n//      * used by weekly charts\r\n//      */\r\n//     if (\r\n//       this.chartConfiguration.isXaxisLabelHidden != undefined &&\r\n//       this.chartConfiguration.isXaxisLabelHidden\r\n//     ) {\r\n//       d3.selectAll('g.lib-line-x-axis-text > g > text').attr(\r\n//         'class',\r\n//         'lib-display-hidden'\r\n//       );\r\n//     }\r\n//     /**\r\n//      * hide y axis labels\r\n//      * used by weekly charts\r\n//      */\r\n//     if (\r\n//       this.chartConfiguration.isYaxisLabelHidden != undefined &&\r\n//       this.chartConfiguration.isYaxisLabelHidden\r\n//     ) {\r\n//       d3.selectAll('.yaxis-dashed > g > text').attr(\r\n//         'class',\r\n//         'lib-display-hidden'\r\n//       );\r\n//     }\r\n//     /**\r\n//      * hide y axis labels\r\n//      * config is there for future use\r\n//      */\r\n//     if (\r\n//       this.chartConfiguration.isYaxisHidden != undefined &&\r\n//       this.chartConfiguration.isYaxisHidden\r\n//     ) {\r\n//       d3.selectAll('.yaxis-dashed').attr('class', 'lib-display-hidden');\r\n//     }\r\n//     /**\r\n//      * dashed y axis\r\n//      * used by weekly charts\r\n//      */\r\n//     if (\r\n//       this.chartConfiguration.isYaxisDashed != undefined &&\r\n//       this.chartConfiguration.isYaxisDashed\r\n//     ) {\r\n//       d3.selectAll('.yaxis-dashed')\r\n//         .style('stroke-dasharray', '5 5')\r\n//         .style('color', 'var(--chart-axis-color, #999999)'); // Use CSS variable\r\n//     }\r\n//     if (lineData != null) {\r\n//       if (lineData && self.chartConfiguration.showLineChartAxis) {\r\n//         svgYAxisRight\r\n//           .append('g')\r\n//           .attr('class', 'lib-stacked-y-axis-text1')\r\n//           .attr('style', self.chartConfiguration.yAxisCustomTextStyles)\r\n//           .attr('transform', 'translate(' + 0 + ',0)')\r\n//           .call(yLineAxis);\r\n//       }\r\n//     }\r\n//     /**\r\n//      * used to display y label\r\n//      */\r\n\r\n//     // if (this.isZoomedOut) {\r\n//     //   svg\r\n//     //     .selectAll('.lib-xaxis-labels-texts-drilldown')\r\n//     //     .attr('class', 'lib-display-hidden');\r\n//     // }\r\n\r\n//     if (this.isZoomedOut) {\r\n//       svg\r\n//         .selectAll('.lib-xaxis-labels-texts-drilldown')\r\n//         .each((d, i, nodes) => {\r\n//           const text = d3.select(nodes[i]);\r\n//           const label = text.text();\r\n//           if (label.indexOf('\\n') > -1) {\r\n//             const lines = label.split('\\n');\r\n//             text.text(null);\r\n//             lines.forEach((line, idx) => {\r\n//               text.append('tspan')\r\n//                 .text(line)\r\n//                 .attr('x', 0)\r\n//                 .attr('dy', idx === 0 ? '1em' : '1.1em');\r\n//             });\r\n//           } else {\r\n//             const words = label.split(' ');\r\n//             text.text(null);\r\n//             words.forEach((word, index) => {\r\n//               text.append('tspan').text(word);\r\n//             });\r\n//           }\r\n//         })\r\n//         .style('fill', 'var(--chart-text-color)')\r\n//         .attr('transform', null); \r\n//       svg\r\n//         .select('.x-axis')\r\n//         .attr('transform', `translate(0, ${height - margin.bottom + 10})`);\r\n//     }\r\n\r\n//     /**\r\n//      * used to write y labels based on configuration\r\n//      */\r\n// if (metaData.yLabel) {\r\n//   const yPosition = isria ? 0 - margin.left / 2 - 30 : 0 - margin.left / 2 - 40;\r\n\r\n//   svgYAxisLeft\r\n//     .append('text')\r\n//     .attr('class', 'lib-axis-group-label font-size-1')\r\n//     .attr('style', self.chartConfiguration.yAxisCustomlabelStyles)\r\n//     .attr('transform', 'rotate(-90)')\r\n//     .attr('y', yPosition)\r\n//     .attr('x', 0 - height / 2)\r\n//     .attr('dy', '1em')\r\n//     .style('text-anchor', 'middle')\r\n//     .attr('fill', 'var(--chart-text-color)');\r\n\r\n//   if (this.chartConfiguration.isMultiChartGridLine === undefined) {\r\n//     svgYAxisLeft\r\n//       .selectAll('.lib-axis-group-label')\r\n//       .style('font-size', 'smaller')\r\n//       .text(metaData.yLabel);\r\n//   } else {\r\n//     svg\r\n//       .selectAll('.lib-axis-group-label')\r\n//       .attr('class', 'lib-ylabel-weeklyCharts')\r\n//       .text(metaData.yLabel.toLowerCase());\r\n//   }\r\n// }\r\n\r\n//     if (this.chartData.targetLineData) {\r\n//       const yZero = y(this.chartData.targetLineData.target);\r\n//       svg\r\n//         .append('line')\r\n//         .attr('x1', 0)\r\n//         .attr('x2', width)\r\n//         .attr('y1', yZero)\r\n//         .attr('y2', yZero)\r\n//         .style('stroke-dasharray', '5 5')\r\n//         .style('stroke', this.chartData.targetLineData.color);\r\n//       // svgYAxisRight\r\n//       //   .append('line')\r\n//       //   .attr('x1', 0)\r\n//       //   .attr('x2', rightSvgWidth)\r\n//       //   .attr('y1', yZero)\r\n//       //   .attr('y2', yZero)\r\n//       //   .style('stroke', this.chartData.targetLineData.color);\r\n//       svgYAxisRight\r\n//         .append('foreignObject')\r\n//         .attr('transform', 'translate(' + 0 + ',' + (yZero - 30) + ')')\r\n//         .attr('width', rightSvgWidth)\r\n//         .attr('height', 50)\r\n//         .append('xhtml:div')\r\n//         .attr('class', 'target-display')\r\n//         .style('color', 'var(--chart-text-color)')\r\n//         .html(function () {\r\n//           let dataTypeTemp = '';\r\n//           let targetLineName = 'target';\r\n//           if (metaData.dataType) {\r\n//             dataTypeTemp = metaData.dataType;\r\n//           }\r\n//           if (\r\n//             self.chartData.targetLineData &&\r\n//             self.chartData.targetLineData.targetName\r\n//           ) {\r\n//             targetLineName = self.chartData.targetLineData.targetName;\r\n//           }\r\n//           return (\r\n//             `<div>${targetLineName}</div>` +\r\n//             '<div>' +\r\n//             self.chartData.targetLineData.target +\r\n//             '' +\r\n//             dataTypeTemp +\r\n//             '</div>'\r\n//           );\r\n//         });\r\n//     }\r\n//     if (this.chartConfiguration.isDrilldownChart) {\r\n//       /**\r\n//        * used by drilldown charts\r\n//        */\r\n//       // svg\r\n//       //   .selectAll('.lib-axis-group-label')\r\n//       //   .attr('class', 'lib-ylabel-drilldowncharts')\r\n//       //   .text(metaData.yLabel.toLowerCase());\r\n//       svg.selectAll('g.x1.axis1 g.tick line').style('display', 'none');\r\n//     }\r\n\r\n//     if (metaData.xLabel) {\r\n//       function isAcronym(label) {\r\n//         return (\r\n//           (label.length <= 4 && /^[A-Z]+$/.test(label)) ||\r\n//           (label === label.toUpperCase() && /[A-Z]/.test(label))\r\n//         );\r\n//       }\r\n//       const xLabelText = metaData.xLabel;\r\n//       const isAcr = isAcronym(xLabelText.replace(/[^A-Za-z]/g, ''));\r\n\r\n//         const xPosition = isria ? (height + margin.top + margin.bottom) : (height + margin.top + margin.bottom + 40);\r\n\r\n//       svg\r\n//         .append('text')\r\n//         .attr('class', function () {\r\n//           let baseClass = 'lib-axis-group-label font-size-1';\r\n//           if (self.chartConfiguration.isDrilldownChart)\r\n//             return baseClass + ' lib-xlabel-drilldowncharts';\r\n//           if (self.chartConfiguration.isMultiChartGridLine != undefined)\r\n//             return baseClass + ' lib-xlabel-weeklyCharts';\r\n//           return baseClass + ' lib-axis-waterfall-label';\r\n//         })\r\n//         .attr('style', self.chartConfiguration.xAxisCustomlabelStyles)\r\n//         .attr(\r\n//           'transform',\r\n//           'translate(' + width / 2 + ' ,' + xPosition + ')'\r\n//         )\r\n//         .style('text-anchor', 'middle')\r\n//         .style('fill', 'var(--chart-text-color)')\r\n//         .text(isAcr ? xLabelText.toUpperCase() : xLabelText.toLowerCase())\r\n//         .style('text-transform', isAcr ? 'none' : 'capitalize');\r\n//     }\r\n//     if (metaData.lineyLabel) {\r\n//       svgYAxisRight\r\n//         .append('text')\r\n//         .attr('class', 'lib-axis-group-label lib-line-axis')\r\n//         .attr('fill', 'var(--chart-text-color)')\r\n//         .attr('style', self.chartConfiguration.yAxisCustomlabelStyles)\r\n//         .attr('transform', 'translate(0,0) rotate(90)')\r\n//         .attr('y', 0 - 100)\r\n//         .attr('x', 0 + 100)\r\n//         .attr('dy', '5em')\r\n//         .style('text-anchor', 'middle')\r\n//         .style('font-size', 'smaller')\r\n//         .text(metaData.lineyLabel);\r\n//     }\r\n//     if (lineData) {\r\n//       svg\r\n//         .append('path')\r\n//         .datum(lineData)\r\n//         .attr('fill', 'none')\r\n//         .attr('stroke', self.chartConfiguration.lineGraphColor)\r\n//         .attr('stroke-width', 1.5)\r\n//         .attr(\r\n//           'd',\r\n//           d3\r\n//             .line()\r\n//             .x(function (d) {\r\n//               return x(d.name) + x.bandwidth() / 2;\r\n//             })\r\n//             .y(function (d) {\r\n//               return lineYscale(d.value);\r\n//             })\r\n//         );\r\n\r\n//       var dot = svg\r\n//         .selectAll('myCircles')\r\n//         .data(lineData)\r\n//         .enter()\r\n//         .append('g')\r\n//         .on('click', function (d) {\r\n//           if (\r\n//             !metaData.barWithoutClick ||\r\n//             !metaData.barWithoutClick.length ||\r\n//             (!metaData.barWithoutClick.includes(d?.name) &&\r\n//               !metaData.barWithoutClick.includes(d?.key))\r\n//           )\r\n//             self.handleClick(d);\r\n//         });\r\n\r\n//       dot\r\n//         .append('circle')\r\n//         .attr('fill', function (d) {\r\n//           return self.chartConfiguration.lineGraphColor;\r\n//         })\r\n//         .attr('stroke', 'none')\r\n//         .attr('cx', function (d) {\r\n//           return x(d.name) + x.bandwidth() / 2;\r\n//         })\r\n//         .attr('cy', function (d) {\r\n//           return lineYscale(d.value);\r\n//         })\r\n//         .style('cursor', () =>\r\n//           self.chartData.metaData.hasDrillDown ? 'pointer' : 'default'\r\n//         )\r\n//         .attr('r', 3);\r\n\r\n//       if (self.chartConfiguration.lineGraphColor) {\r\n//         dot\r\n//           .append('text')\r\n//           .attr('class', 'dot')\r\n//           .attr('fill', 'var(--chart-text-color)')\r\n//           .attr('color', self.chartConfiguration.lineGraphColor)\r\n//           .attr('style', 'font-size: ' + '.85em')\r\n//           .attr('x', function (d, i) {\r\n//             return x(d.name) + x.bandwidth() / 2;\r\n//           })\r\n//           .attr('y', function (d) {\r\n//             return lineYscale(d.value);\r\n//           })\r\n//           .attr('dy', '-1em')\r\n//           .text(function (d) {\r\n//             return self.chartConfiguration.labelFormatter(d.value);\r\n//           });\r\n//       }\r\n//     }\r\n//   }\r\n\r\ninitializegroupChart() {\r\n  // ==================== VARIABLE DECLARATIONS ====================\r\n  const self = this;\r\n  let data = [];\r\n  let metaData: any = null;\r\n  let keyList = null;\r\n  let lineData = null;\r\n  let colorMap = {};\r\n  let formatFromBackend;\r\n  let formatForHugeNumbers;\r\n  \r\n  // Device detection\r\n  const isMobile = window.innerWidth < 576;\r\n  const isTablet = window.innerWidth >= 576 && window.innerWidth < 992;\r\n  const isDesktop = window.innerWidth >= 992;\r\n  const isria = this.customChartConfiguration.isRia;\r\n\r\n  // Chart scale variables\r\n  let x: any;\r\n  let tempScale;\r\n\r\n  // Tick length constants\r\n  const SHORT_TICK_LENGTH = 4;\r\n  const LONG_TICK_LENGTH = 16;\r\n  const SHORT_TICK_LENGTH_BG = 5;\r\n  const LONG_TICK_LENGTH_BG = 30;\r\n  const LEFT_AND_RIGHT_SPACES = 50;\r\n  const RIGHT_SVG_WIDTH = 60;\r\n  \r\n  // Flags\r\n  let alternate_text = false;\r\n\r\n  // ==================== CONFIGURATION SETUP ====================\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  // Extract chart data\r\n  data = this.chartData.data;\r\n  metaData = this.chartData.metaData;\r\n  lineData = this.chartData.lineData;\r\n\r\n  // Setup color mappings\r\n  if (!metaData.colorAboveTarget) {\r\n    metaData['colorAboveTarget'] = metaData.colors;\r\n  }\r\n  colorMap = metaData.colors;\r\n  keyList = metaData.keyList;\r\n\r\n  // ==================== CONTAINER SETUP ====================\r\n  const chartContainer = d3.select(this.containerElt.nativeElement);\r\n  const verticalstackedcontainer = d3.select(this.groupcontainerElt.nativeElement);\r\n  const margin = this.chartConfiguration.margin;\r\n  \r\n  const { width, height } = this.calculateChartDimensions(\r\n    chartContainer,\r\n    verticalstackedcontainer,\r\n    margin,\r\n    self\r\n  );\r\n\r\n  // ==================== VISIBILITY CONFIGURATION ====================\r\n  if (this.chartConfiguration.isHeaderVisible !== undefined) {\r\n    this.isHeaderVisible = this.chartConfiguration.isHeaderVisible;\r\n  }\r\n\r\n  if (this.chartConfiguration.legendVisible !== undefined) {\r\n    this.legendVisible = this.chartConfiguration.legendVisible;\r\n  }\r\n\r\n  if (this.chartConfiguration.isTransparentBackground !== undefined) {\r\n    this.isTransparentBackground = this.chartConfiguration.isTransparentBackground;\r\n  }\r\n\r\n  // ==================== DATA FORMATTING ====================\r\n  if (this.chartConfiguration.textFormatter !== undefined) {\r\n    formatFromBackend = ChartHelper.dataValueFormatter(this.chartConfiguration.textFormatter);\r\n    formatForHugeNumbers = ChartHelper.dataValueFormatter('.2s');\r\n  }\r\n\r\n  // ==================== SVG CONTAINERS CREATION ====================\r\n  const {\r\n    outerContainer,\r\n    svgYAxisLeft,\r\n    svgYAxisRight,\r\n    innerContainer,\r\n    svg\r\n  } = this.createChartContainers(chartContainer, margin, height, RIGHT_SVG_WIDTH, self, width);\r\n\r\n  // ==================== SCALES SETUP ====================\r\n  const subgroups: any = keyList;\r\n  const groups = d3.map(data, (d) => d.name).keys();\r\n\r\n  // X-axis scale configuration\r\n  if (this.chartConfiguration.isMultiChartGridLine !== undefined) {\r\n    x = d3.scaleBand()\r\n      .rangeRound([width, 0])\r\n      .align(0.5)\r\n      .padding([0.5])\r\n      .domain(data.map((d: any) => d.name.toLowerCase()));\r\n  } else {\r\n    x = d3.scaleBand()\r\n      .domain(groups)\r\n      .range([LEFT_AND_RIGHT_SPACES, width - RIGHT_SVG_WIDTH - LEFT_AND_RIGHT_SPACES])\r\n      .padding([0.3]);\r\n  }\r\n\r\n  const xScaleFromOrigin = d3.scaleBand()\r\n    .domain(groups)\r\n    .range([0, width - RIGHT_SVG_WIDTH]);\r\n\r\n  // ==================== X-AXIS RENDERING ====================\r\n  this.renderXAxis(svg, x, height, metaData, subgroups, data, \r\n    SHORT_TICK_LENGTH_BG, LONG_TICK_LENGTH_BG, self, isria, isMobile);\r\n\r\n  // ==================== Y-AXIS SETUP ====================\r\n  const y = d3.scaleLinear().rangeRound([height, 0]);\r\n  let maxValue = this.calculateMaxValue(data, keyList);\r\n\r\n  if (this.chartConfiguration.customYscale) {\r\n    maxValue = maxValue * this.chartConfiguration.customYscale;\r\n  }\r\n\r\n  if (this.chartData.targetLineData && maxValue < this.chartData.targetLineData.target) {\r\n    maxValue = maxValue < 10 && this.chartData.targetLineData.target < 10\r\n      ? this.chartData.targetLineData.target + 3\r\n      : this.chartData.targetLineData.target + 20;\r\n  }\r\n\r\n  y.domain([0, maxValue]).nice();\r\n\r\n  // ==================== LINE CHART Y-SCALE ====================\r\n  let lineYscale;\r\n  let yLineAxis;\r\n\r\n  if (lineData != null) {\r\n    const result = this.setupLineYScale(lineData, height, self);\r\n    lineYscale = result.lineYscale;\r\n    yLineAxis = result.yLineAxis;\r\n  }\r\n\r\n  // ==================== GRID LINES ====================\r\n  this.renderGridLines(svg, x, y, height, width, self);\r\n\r\n  // ==================== BARS RENDERING ====================\r\n  const xSubgroup = this.setupXSubgroupScale(subgroups, x, self);\r\n  const color = d3.scaleOrdinal()\r\n    .domain(subgroups)\r\n    .range(Object.values(metaData.colors));\r\n\r\n  this.renderBars(svg, data, subgroups, x, xSubgroup, y, height, color, \r\n    metaData, self, LEFT_AND_RIGHT_SPACES, tempScale, isria);\r\n\r\n  // ==================== BAR LABELS ====================\r\n  if (this.chartConfiguration.textsOnBar !== undefined && !this.isZoomedOut) {\r\n    this.renderBarLabels(svg, data, subgroups, x, xSubgroup, y, height, \r\n      metaData, self, tempScale, isria);\r\n  }\r\n\r\n  // ==================== Y-AXIS RENDERING ====================\r\n  this.renderYAxis(svg, svgYAxisLeft, svgYAxisRight, y, yLineAxis, \r\n    lineData, self, isria, margin);\r\n\r\n  // ==================== AXIS LABELS ====================\r\n  this.renderAxisLabels(svg, svgYAxisLeft, svgYAxisRight, metaData, \r\n    width, height, margin, self, isria, RIGHT_SVG_WIDTH);\r\n\r\n  // ==================== TARGET LINE ====================\r\n  if (this.chartData.targetLineData) {\r\n    this.renderTargetLine(svg, svgYAxisRight, y, width, RIGHT_SVG_WIDTH, \r\n      metaData, self);\r\n  }\r\n\r\n  // ==================== LINE CHART ====================\r\n  if (lineData) {\r\n    this.renderLineChart(svg, lineData, x, lineYscale, metaData, self);\r\n  }\r\n\r\n  // ==================== ZOOM HANDLING ====================\r\n  if (this.isZoomedOut) {\r\n    this.handleZoomOut(svg, height, margin);\r\n  }\r\n}\r\n\r\n// ==================== HELPER METHODS ====================\r\n\r\nprivate renderXAxis(svg, x, height, metaData, subgroups, data, \r\n  shortTickLengthBg, longTickLengthBg, self, isria, isMobile) {\r\n  \r\n  let alternate_text = false;\r\n\r\n  if (this.chartConfiguration.isMultiChartGridLine === undefined) {\r\n    // Normal ticks for dashboard charts\r\n    svg.append('g')\r\n      .attr('class', 'x1 axis1')\r\n      .attr('transform', `translate(0,${height})`)\r\n      .call(d3.axisBottom(x))\r\n      .call((g) => g.select('.domain').remove());\r\n\r\n    svg.selectAll('g.x1.axis1 g.tick line').remove();\r\n\r\n    const yOffset = subgroups.length > 1 && !metaData.xLabel ? 32 : 0;\r\n    svg.selectAll('g.x1.axis1 g.tick text')\r\n      .attr('class', 'lib-xaxis-labels-texts-drilldown')\r\n      .style('fill', 'var(--chart-text-color)')\r\n      .attr('y', yOffset || null);\r\n  } else {\r\n    // Bigger ticks for weekly charts\r\n    svg.append('g')\r\n      .attr('class', 'x1 axis1')\r\n      .attr('transform', `translate(0,${height})`)\r\n      .call(d3.axisBottom(x).tickSize(0))\r\n      .call((g) => g.select('.domain').attr('fill', 'none'));\r\n\r\n    // Alternate tick line sizes\r\n    svg.selectAll('g.x1.axis1 g.tick line').attr('y2', function () {\r\n      if (alternate_text && self.chartConfiguration.isNoAlternateXaxisText === undefined) {\r\n        alternate_text = false;\r\n        return longTickLengthBg - 7;\r\n      } else {\r\n        alternate_text = true;\r\n        return shortTickLengthBg - 4;\r\n      }\r\n    });\r\n\r\n    alternate_text = false;\r\n\r\n    // X-axis label texts\r\n    svg.selectAll('g.x1.axis1 g.tick text')\r\n      .attr('class', 'lib-xaxis-labels-texts-weeklycharts')\r\n      .attr('y', function () {\r\n        if (self.chartConfiguration.isFullScreen) {\r\n          return shortTickLengthBg;\r\n        }\r\n        if (alternate_text) {\r\n          alternate_text = false;\r\n          return longTickLengthBg;\r\n        } else {\r\n          alternate_text = true;\r\n          return shortTickLengthBg;\r\n        }\r\n      });\r\n  }\r\n\r\n  // Apply labels on same line configuration\r\n  if (self.chartConfiguration.xLabelsOnSameLine) {\r\n    this.applyXLabelsOnSameLine(svg, subgroups, data, metaData, self, \r\n      shortTickLengthBg, isMobile, isria);\r\n  }\r\n\r\n  // Mobile override for RIA\r\n  if (isria && self.chartData.data.length > 8) {\r\n    svg.selectAll('g.x1.axis1 g.tick text')\r\n      .classed('mobile-xaxis-override', true)\r\n      .text((d: string) => d.substring(0, 3))\r\n      .style('font-size', '12px')\r\n      .attr('y', 5)\r\n      .attr('x', 5)\r\n      .style('text-anchor', 'middle');\r\n  }\r\n\r\n  // Mobile override\r\n  if (isMobile && !this.isHeaderVisible) {\r\n    svg.selectAll('g.x1.axis1 g.tick text')\r\n      .classed('mobile-xaxis-override', true);\r\n  }\r\n}\r\n\r\nprivate applyXLabelsOnSameLine(svg, subgroups, data, metaData, self, \r\n  shortTickLengthBg, isMobile, isria) {\r\n  \r\n  const xAxisLabels = svg.selectAll('g.x1.axis1 g.tick text')\r\n    .attr('class', 'lib-xaxis-labels-texts-drilldown')\r\n    .style('font-size', this.isHeaderVisible ? '18px' : '14px')\r\n    .attr('text-anchor', 'middle')\r\n    .attr('y', (d) => this.calculateXLabelYPosition(d, subgroups, data, metaData, self, shortTickLengthBg))\r\n    .attr('x', (d) => (self.chartData.data.length > 8 && !self.isZoomedOut) ? 1 : 0)\r\n    .text((d) => this.formatXLabelText(d, data, metaData, subgroups, self, isMobile));\r\n\r\n  // Apply writing-mode for grouped charts with date labels in zoomed-out view\r\n  xAxisLabels.each(function(this: SVGTextElement, d: any) {\r\n    const isDateLabel = /^(\\d{2,4}[-\\/])?\\d{2,4}[-\\/]\\d{2,4}$/.test(d.trim());\r\n    const isWeekLabel = /week|wk|w\\d+/i.test(d);\r\n    \r\n    if (subgroups.length > 1 && self.isZoomedOut && data.length > 8 && isDateLabel && !isWeekLabel) {\r\n      d3.select(this).style('writing-mode', 'sideways-lr');\r\n    }\r\n  });\r\n\r\n  // Add second line for non-date labels on desktop\r\n  if (!isMobile) {\r\n    svg.selectAll('g.x1.axis1 g.tick')\r\n      .filter((d) => !/\\d{2,4}[-\\/]/.test(d))\r\n      .append('text')\r\n      .attr('class', 'lib-xaxis-labels-texts-drilldown')\r\n      .attr('y', 30)\r\n      .attr('fill', 'var(--chart-text-color)')\r\n      .attr('x', (d) => (self.chartData.data.length > 8 && !self.isZoomedOut) ? 1 : 0)\r\n      .text((d) => {\r\n        if (d.trim().indexOf(' ') > -1) {\r\n          return d.trim().substring(d.indexOf(' '), d.length).toLowerCase();\r\n        }\r\n        return '';\r\n      });\r\n  }\r\n}\r\n\r\nprivate calculateXLabelYPosition(d, subgroups, data, metaData, self, shortTickLengthBg) {\r\n  // For grouped bar charts with many bars and xLabel present\r\n  if (subgroups.length > 1 && data.length > 8 && metaData.xLabel) {\r\n    const isDateLabel = /\\d{2,4}[-\\/]/.test(d);\r\n    return isDateLabel ? shortTickLengthBg + 14 : shortTickLengthBg;\r\n  }\r\n\r\n  // For grouped bar charts with many bars and NO xLabel\r\n  if (subgroups.length > 1 && data.length > 8 && !metaData.xLabel) {\r\n    const chartHasExtraBottom = self.chartConfiguration.margin && self.chartConfiguration.margin.bottom >= 40;\r\n    if (self.chartConfiguration.isFullScreen) {\r\n      return shortTickLengthBg + 2;\r\n    }\r\n    return chartHasExtraBottom ? shortTickLengthBg : shortTickLengthBg + 10;\r\n  }\r\n\r\n  // Default/fallback logic\r\n  let baseY = self.isHeaderVisible ? shortTickLengthBg + 25 : shortTickLengthBg;\r\n  \r\n  if (subgroups.length > 1 && !metaData.xLabel && \r\n      (/\\d{2,4}[-\\/]\\d{2}[-\\/]\\d{2,4}/.test(d) || /\\d{2,4}[-\\/]\\d{2,4}/.test(d))) {\r\n    baseY = self.isHeaderVisible ? shortTickLengthBg + 15 : shortTickLengthBg + 25;\r\n  }\r\n\r\n  if (/\\d{2,4}[-\\/]\\d{2,4}/.test(d) && d.indexOf(' ') > -1) {\r\n    baseY += 4;\r\n  }\r\n\r\n  if (self.chartConfiguration.isFullScreen && subgroups.length > 1) {\r\n    baseY = Math.max(shortTickLengthBg, baseY - 10);\r\n  }\r\n\r\n  return baseY;\r\n}\r\n\r\nprivate formatXLabelText(d, data, metaData, subgroups, self, isMobile) {\r\n  if (isMobile && !self.isHeaderVisible) {\r\n    const firstPart = d.split(/[\\s\\-]+/)[0];\r\n    return firstPart.substring(0, 3).toLowerCase();\r\n  }\r\n\r\n  // Check if value should be ignored\r\n  const isValueToBeIgnored = data.some((indiv: any) => \r\n    indiv.name && indiv.name.toLowerCase() === d.trim().toLowerCase() && \r\n    indiv[metaData.keyList[0]] === -1\r\n  );\r\n\r\n  if (isValueToBeIgnored) {\r\n    return '';\r\n  }\r\n\r\n  // Handle date range labels\r\n  const dateRangeRegex = /(\\d{2,4}[-\\/]\\d{2}[-\\/]\\d{2,4})\\s*-\\s*(\\d{2,4}[-\\/]\\d{2}[-\\/]\\d{2,4})/;\r\n  if (dateRangeRegex.test(d.trim())) {\r\n    return d.trim().replace(dateRangeRegex, (m, d1, d2) => `${d1} - ${d2}`);\r\n  }\r\n\r\n  // Split date and week labels into two lines\r\n  const isDateLabel = /\\d{2,4}[-\\/]/.test(d);\r\n  const isWeekLabel = /week|wk|w\\d+/i.test(d);\r\n  \r\n  if (subgroups.length > 1 && !self.isZoomedOut && data.length > 8 && \r\n      d.indexOf(' ') > -1 && (isDateLabel || isWeekLabel)) {\r\n    const first = d.substring(0, d.indexOf(' '));\r\n    const second = d.substring(d.indexOf(' ') + 1).trim();\r\n    return `${first}\\n${second}`;\r\n  }\r\n\r\n  // Handle date labels in minimized view\r\n  if (isDateLabel) {\r\n    if (!self.isHeaderVisible && data.length > 8 && d.indexOf(' ') > -1) {\r\n      const first = d.substring(0, d.indexOf(' '));\r\n      const second = d.substring(d.indexOf(' ') + 1).trim();\r\n      return `${first}\\n${second}`;\r\n    }\r\n    return d;\r\n  }\r\n\r\n  // Handle labels with spaces\r\n  if (d.trim().indexOf(' ') > -1) {\r\n    return d.trim().substring(0, d.indexOf(' ')).toLowerCase();\r\n  }\r\n\r\n  return d.toLowerCase();\r\n}\r\n\r\nprivate calculateMaxValue(data, keyList) {\r\n  let maxValue = d3.max(data, (d) => d3.max(keyList, (key) => +d[key]));\r\n  \r\n  if (maxValue === 0) {\r\n    if (this.chartData.targetLineData) {\r\n      maxValue = this.chartData.targetLineData.target + 20;\r\n    } else {\r\n      maxValue = 100;\r\n    }\r\n  }\r\n\r\n  return maxValue;\r\n}\r\n\r\nprivate setupLineYScale(lineData, height, self) {\r\n  let maxLineValue = d3.max(lineData, (d) => +d.value);\r\n  maxLineValue = maxLineValue * self.chartConfiguration.customYscale;\r\n\r\n  let minLineValue = d3.min(lineData, (d) => +d.value);\r\n  if (maxLineValue > 0) minLineValue = minLineValue - 3;\r\n  if (minLineValue > 0) minLineValue = 0;\r\n\r\n  const lineYscale = d3.scaleLinear()\r\n    .domain([minLineValue, maxLineValue])\r\n    .range([height, minLineValue]);\r\n\r\n  const yLineAxis = d3.axisRight(lineYscale)\r\n    .ticks(self.chartConfiguration.numberOfYTicks)\r\n    .tickSize(0)\r\n    .tickFormat(self.chartConfiguration.yLineAxisLabelFomatter);\r\n\r\n  return { lineYscale, yLineAxis };\r\n}\r\n\r\nprivate renderGridLines(svg, x, y, height, width, self) {\r\n  // X-axis grid between labels\r\n  if (self.chartConfiguration.isXgridBetweenLabels) {\r\n    svg.append('g')\r\n      .attr('class', 'grid')\r\n      .attr('transform', `translate(${x.bandwidth() / 2},${height})`)\r\n      .call(d3.axisBottom(x).tickSize(-height).tickFormat(''))\r\n      .style('stroke-dasharray', '5 5')\r\n      .style('color', 'var(--chart-grid-color, #999999)')\r\n      .call((g) => g.select('.domain').remove());\r\n  }\r\n\r\n  // Y-axis grid\r\n  if (this.chartConfiguration.yAxisGrid) {\r\n    svg.append('g')\r\n      .call(d3.axisLeft(y).ticks(self.chartConfiguration.numberOfYTicks).tickSize(-width))\r\n      .style('color', 'var(--chart-axis-color, #B9B9B9)')\r\n      .style('opacity', '0.5')\r\n      .call((g) => g.select('.domain').remove().style('stroke', 'var(--chart-domain-color, #000000)'));\r\n  } else {\r\n    svg.append('g')\r\n      .call(d3.axisLeft(y).ticks(self.chartConfiguration.numberOfYTicks))\r\n      .style('color', 'var(--chart-axis-color, #B9B9B9)')\r\n      .style('opacity', '0.5')\r\n      .call((g) => g.select('.domain')\r\n        .style('stroke', 'var(--chart-domain-color, #000000)')\r\n        .style('stroke-width', '1px'));\r\n  }\r\n}\r\n\r\nprivate setupXSubgroupScale(subgroups, x, self) {\r\n  const xSubgroup = d3.scaleBand().domain(subgroups);\r\n\r\n  if (subgroups.length > 1 && !this.isZoomedOut) {\r\n    xSubgroup.range([0, x.bandwidth()]);\r\n  } else if (subgroups.length === 1 && !this.isZoomedOut) {\r\n    xSubgroup.range([0, 100]);\r\n  } else if (this.chartConfiguration.isMultiChartGridLine === undefined) {\r\n    xSubgroup.range([0, x.bandwidth()]);\r\n  } else {\r\n    xSubgroup.range([0, x.bandwidth()]);\r\n  }\r\n\r\n  return xSubgroup;\r\n}\r\n\r\nprivate renderBars(svg, data, subgroups, x, xSubgroup, y, height, color, \r\n  metaData, self, leftAndRightSpaces, tempScale, isria) {\r\n  \r\n  const state = svg.append('g')\r\n    .selectAll('.state')\r\n    .data(data)\r\n    .enter()\r\n    .append('g')\r\n    .attr('transform', (d) => `translate(${x(d.name)},0)`);\r\n\r\n  const bars = state.selectAll('rect')\r\n    .data((d) => this.prepareBarData(d, subgroups))\r\n    .enter()\r\n    .append('rect')\r\n    .attr('class', 'bars')\r\n    .on('click', (d) => this.handleBarClick(d, metaData, self))\r\n    .attr('x', (d) => this.calculateBarX(d, data, x, xSubgroup, self, tempScale))\r\n    .attr('y', (d) => this.calculateBarY(d, y, height, self))\r\n    .attr('width', (d) => this.calculateBarWidth(d, data, subgroups, x, xSubgroup, self, tempScale))\r\n    .attr('height', (d) => this.calculateBarHeight(d, y, height, self))\r\n    .style('cursor', () => (metaData.hasDrillDown && !isria) ? 'pointer' : 'default')\r\n    .attr('fill', (d) => this.getBarColor(d, metaData, self));\r\n\r\n  // Attach mouse events if not RIA\r\n  if (!isria && (this.chartConfiguration.displayTitleOnTop || \r\n      (this.chartConfiguration.textsOnBar === undefined && \r\n       this.chartConfiguration.displayTitleOnTop === undefined))) {\r\n    bars.on('mouseout', (d, i) => this.handleMouseOut(svg))\r\n        .on('mouseover', (d, i) => this.handleMouseOver(d, svg, data, x, y, height, metaData, self, leftAndRightSpaces, tempScale));\r\n  }\r\n}\r\n\r\nprivate prepareBarData(d, subgroups) {\r\n  const newList: any = [];\r\n  subgroups.forEach((key) => {\r\n    newList.push({ key: key, value: d[key], name: d.name });\r\n  });\r\n  return newList;\r\n}\r\n\r\nprivate handleBarClick(d, metaData, self) {\r\n  if (d.key !== 'Target') {\r\n    if (!metaData.barWithoutClick || !metaData.barWithoutClick.length ||\r\n        (!metaData.barWithoutClick.includes(d?.name) && \r\n         !metaData.barWithoutClick.includes(d?.key))) {\r\n      self.handleClick(d);\r\n    }\r\n  }\r\n}\r\n\r\nprivate calculateBarX(d, data, x, xSubgroup, self, tempScale) {\r\n  if (self.chartConfiguration.isDrilldownChart) {\r\n    return this.calculateDrilldownBarX(d, data, x, self, tempScale);\r\n  }\r\n  return xSubgroup(d.key);\r\n}\r\n\r\nprivate calculateDrilldownBarX(d, data, x, self, tempScale) {\r\n  data.forEach((indiv: any) => {\r\n    if (indiv.name === d.name) {\r\n      const keys = Object.keys(indiv).filter((temp, i) => i !== 0);\r\n      tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);\r\n      \r\n      if (x.bandwidth() > 100) {\r\n        const reducedBarWidth = self.isZoomedOut ? 60 : 30;\r\n        const offset = (x.bandwidth() - reducedBarWidth) / 2;\r\n        tempScale.range([offset, x.bandwidth() - offset]);\r\n      }\r\n    }\r\n  });\r\n  return tempScale(d.key);\r\n}\r\n\r\nprivate calculateBarY(d, y, height, self) {\r\n  if (d.value === -1) {\r\n    return y(0);\r\n  }\r\n\r\n  if (d.value >= 0) {\r\n    const barHeight = height - y(d.value);\r\n    const minHeight = self.chartConfiguration.defaultBarHeight || 2;\r\n    return barHeight < minHeight ? y(0) - minHeight : y(d.value);\r\n  }\r\n\r\n  return y(0);\r\n}\r\n\r\nprivate calculateBarWidth(d, data, subgroups, x, xSubgroup, self, tempScale) {\r\n  // For grouped bar charts in zoom-in view\r\n  if (subgroups.length > 1 && !self.isZoomedOut) {\r\n    return 50;\r\n  }\r\n\r\n  // For single-bar charts in zoom-in view\r\n  if (subgroups.length === 1 && !self.isZoomedOut) {\r\n    return 80;\r\n  }\r\n\r\n  // Default logic for drilldown charts\r\n  if (self.chartConfiguration.isDrilldownChart) {\r\n    let calculatedScale = d3.scaleBand().domain([]).range([0, 0]);\r\n    \r\n    data.forEach((indiv: any) => {\r\n      if (indiv.name === d.name) {\r\n        const keys = Object.keys(indiv).filter((temp, i) => i !== 0);\r\n        calculatedScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);\r\n        \r\n        if (x.bandwidth() > 100) {\r\n          const reducedBarWidth = self.isZoomedOut ? 60 : 100;\r\n          const offset = (x.bandwidth() - reducedBarWidth) / 2;\r\n          calculatedScale.range([offset, x.bandwidth() - offset]);\r\n        }\r\n      }\r\n    });\r\n    \r\n    return calculatedScale.bandwidth();\r\n  }\r\n\r\n  return xSubgroup.bandwidth();\r\n}\r\n\r\nprivate calculateBarHeight(d, y, height, self) {\r\n  if (d.value === -1) {\r\n    return height - y(0);\r\n  }\r\n\r\n  if (d.value >= 0) {\r\n    const barHeight = height - y(d.value);\r\n    const minHeight = self.chartConfiguration.defaultBarHeight || 2;\r\n    return Math.max(barHeight, minHeight);\r\n  }\r\n\r\n  return height - y(0);\r\n}\r\n\r\nprivate getBarColor(d, metaData, self) {\r\n  if (d.value && self.chartData.targetLineData && \r\n      d.value >= parseFloat(self.chartData.targetLineData.target) && \r\n      self.chartData.metaData.colorAboveTarget) {\r\n    \r\n    const key = d.key.toLowerCase();\r\n    const colorAboveTarget = Object.keys(self.chartData.metaData.colorAboveTarget)\r\n      .find(k => k.toLowerCase() === key);\r\n    \r\n    if (colorAboveTarget) {\r\n      return self.chartData.metaData.colorAboveTarget[colorAboveTarget];\r\n    }\r\n  }\r\n  return self.chartData.metaData.colors[d.key];\r\n}\r\n\r\nprivate renderBarLabels(svg, data, subgroups, x, xSubgroup, y, height, \r\n  metaData, self, tempScale, isria) {\r\n  \r\n  const state = svg.selectAll('.state');\r\n  \r\n  const labels = state.selectAll('text')\r\n    .data((d) => this.prepareBarData(d, subgroups))\r\n    .enter()\r\n    .append('text')\r\n    .attr('fill', 'var(--chart-text-color)')\r\n    .attr('x', 0)\r\n    .attr('y', 0)\r\n    .attr('class', 'lib-data-labels-weeklycharts')\r\n    .text((d) => this.formatBarLabel(d))\r\n    .style('fill', '#000')\r\n    .style('font-weight', 'bold')\r\n    .style('font-size', (d) => this.calculateLabelFontSize(self))\r\n    .attr('transform', (d) => this.calculateLabelTransform(d, data, x, xSubgroup, y, self, tempScale))\r\n    .on('click', (d) => this.handleBarClick(d, metaData, self));\r\n\r\n  if (!isria) {\r\n    labels.on('mouseout', () => this.handleMouseOut(svg))\r\n          .on('mouseover', (d) => this.handleMouseOver(d, svg, data, x, y, height, metaData, self, 50, tempScale));\r\n  }\r\n}\r\n\r\nprivate formatBarLabel(d) {\r\n  if (!d.key || !d.value) return '';\r\n  return d.key.length > 20 ? d.key.substring(0, 17) + '...' : d.key;\r\n}\r\n\r\nprivate calculateLabelFontSize(self) {\r\n  if (self.isZoomedOut) return '9px';\r\n\r\n  if (self.chartConfiguration.isDrilldownChart) {\r\n    if (window.innerWidth > 1900) return '18px';\r\n    if (window.innerWidth < 1400) return '10px';\r\n    return '14px';\r\n  }\r\n\r\n  return '14px';\r\n}\r\n\r\nprivate calculateLabelTransform(d, data, x, xSubgroup, y, self, tempScale) {\r\n  let calculatedScale;\r\n  \r\n  data.forEach((indiv: any) => {\r\n    if (indiv.name === d.name) {\r\n      const keys = Object.keys(indiv).filter((temp, i) => i !== 0);\r\n      calculatedScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);\r\n      \r\n      if (x.bandwidth() > 100) {\r\n        if (self.chartData.data.length === 1) {\r\n          const reducedWidth = Object.keys(self.chartData.data[0]).length === 2 ? 200 : 300;\r\n          const offset = (x.bandwidth() - reducedWidth) / 2;\r\n          calculatedScale.range([offset, x.bandwidth() - offset]);\r\n        } else {\r\n          const offset = (x.bandwidth() - 125) / 2;\r\n          calculatedScale.range([offset, x.bandwidth() - offset]);\r\n        }\r\n      }\r\n    }\r\n  });\r\n\r\n  if (self.chartConfiguration.textAlwaysHorizontal) {\r\n    return `translate(${xSubgroup(d.key)},${y(d.value) - 3})`;\r\n  }\r\n\r\n  if (!isNaN(calculatedScale(d.key))) {\r\n    return `translate(${calculatedScale(d.key) + calculatedScale.bandwidth() * 0.55},${y(0) - 10}) rotate(270)`;\r\n  }\r\n\r\n  return 'translate(0,0)';\r\n}\r\n\r\nprivate handleMouseOver(d, svg, data, x, y, height, metaData, self, leftAndRightSpaces, tempScale) {\r\n  svg.selectAll('.lib-verticalstack-title-ontop').remove();\r\n\r\n  let calculatedScale;\r\n  let elementsCounter;\r\n\r\n  data.forEach((indiv: any) => {\r\n    if (indiv.name === d.name) {\r\n      const keys = Object.keys(indiv).filter((temp, i) => i !== 0);\r\n      elementsCounter = keys.length;\r\n      calculatedScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);\r\n      \r\n      if (x.bandwidth() > 100) {\r\n        if (self.chartData.data.length === 1) {\r\n          const reducedWidth = Object.keys(self.chartData.data[0]).length === 2 ? 200 : 300;\r\n          const offset = (x.bandwidth() - reducedWidth) / 2;\r\n          calculatedScale.range([offset, x.bandwidth() - offset]);\r\n        } else {\r\n          const offset = (x.bandwidth() - 125) / 2;\r\n          calculatedScale.range([offset, x.bandwidth() - offset]);\r\n        }\r\n      }\r\n    }\r\n  });\r\n\r\n  const xPosition = this.calculateTooltipX(d, x, calculatedScale, metaData, leftAndRightSpaces);\r\n  const width = this.calculateTooltipWidth(calculatedScale, metaData, leftAndRightSpaces);\r\n\r\n  svg.append('foreignObject')\r\n    .attr('x', xPosition)\r\n    .attr('class', 'lib-verticalstack-title-ontop')\r\n    .attr('y', y(d.value) - 3 - 40 - 10)\r\n    .attr('dy', d.class)\r\n    .attr('width', width)\r\n    .attr('height', 50)\r\n    .append('xhtml:div')\r\n    .attr('class', 'title')\r\n    .style('z-index', 99)\r\n    .html(() => this.generateTooltipHTML(d, metaData));\r\n}\r\n\r\nprivate calculateTooltipX(d, x, calculatedScale, metaData, leftAndRightSpaces) {\r\n  if (metaData.hasDrillDown) {\r\n    if (calculatedScale.bandwidth() + leftAndRightSpaces * 2 > 180) {\r\n      return x(d.name) + calculatedScale(d.key) + calculatedScale.bandwidth() / 2 - 90;\r\n    }\r\n    return x(d.name) + calculatedScale(d.key) - \r\n           (calculatedScale.bandwidth() + leftAndRightSpaces * 2) / 2 + \r\n           calculatedScale.bandwidth() / 2;\r\n  }\r\n  return x(d.name) + calculatedScale(d.key) - \r\n         (calculatedScale.bandwidth() + leftAndRightSpaces * 2) / 2 + \r\n         calculatedScale.bandwidth() / 2;\r\n}\r\n\r\nprivate calculateTooltipWidth(calculatedScale, metaData, leftAndRightSpaces) {\r\n  if (metaData.hasDrillDown) {\r\n    if (calculatedScale.bandwidth() + leftAndRightSpaces * 2 > 180) {\r\n      return '180px';\r\n    }\r\n    return calculatedScale.bandwidth() + leftAndRightSpaces * 2;\r\n  }\r\n  return calculatedScale.bandwidth() + leftAndRightSpaces * 2;\r\n}\r\n\r\nprivate generateTooltipHTML(d, metaData) {\r\n  const barLabel = d.key;\r\n  const dataType = metaData.dataType || '';\r\n  const value = d.value;\r\n  \r\n  let html = `<span class=\"title-bar-name\">${barLabel}</span>`;\r\n  html += `<span class=\"title-bar-value\"><span>${value}</span>${dataType}</span>`;\r\n  \r\n  return html;\r\n}\r\n\r\nprivate handleMouseOut(svg) {\r\n  svg.selectAll('.lib-verticalstack-title-ontop').remove();\r\n}\r\n\r\nprivate renderYAxis(svg, svgYAxisLeft, svgYAxisRight, y, yLineAxis, lineData, self, isria, margin) {\r\n  // Hidden y-axis for reference\r\n  svg.append('g')\r\n    .attr('class', 'lib-stacked-y-axis-text yaxis-dashed')\r\n    .attr('style', self.chartConfiguration.yAxisCustomTextStyles)\r\n    .attr('transform', 'translate(0,0)')\r\n    .call(y)\r\n    .style('display', 'none');\r\n\r\n  // Left y-axis\r\n  svgYAxisLeft.append('g')\r\n    .append('g')\r\n    .attr('class', 'lib-yaxis-labels-texts-drilldown yaxis-dashed')\r\n    .attr('style', self.chartConfiguration.yAxisCustomTextStyles)\r\n    .attr('transform', 'translate(0,0)')\r\n    .call(d3.axisLeft(y)\r\n      .tickSize(0)\r\n      .ticks(self.chartConfiguration.numberOfYTicks)\r\n      .tickFormat((d) => {\r\n        const formatted = self.chartConfiguration.yAxisLabelFomatter \r\n          ? self.chartConfiguration.yAxisLabelFomatter(d) \r\n          : d;\r\n        return formatted >= 1000 ? formatted / 1000 + 'k' : formatted;\r\n      }))\r\n    .call((g) => {\r\n      g.select('.domain')\r\n        .style('stroke', 'var(--chart-domain-color, #000000)')\r\n        .style('stroke-width', '1px');\r\n    })\r\n    .selectAll('text')\r\n    .style('fill', 'var(--chart-text-color)');\r\n\r\n  // Right y-axis (hidden by default)\r\n  svgYAxisRight.append('g')\r\n    .attr('class', 'lib-yaxis-labels-texts-drilldown yaxis-dashed')\r\n    .attr('style', self.chartConfiguration.yAxisCustomTextStyles)\r\n    .attr('transform', 'translate(0,0)')\r\n    .call(y)\r\n    .style('display', 'none');\r\n\r\n  // Line chart axis if applicable\r\n  if (lineData != null && lineData && self.chartConfiguration.showLineChartAxis) {\r\n    svgYAxisRight.append('g')\r\n      .attr('class', 'lib-stacked-y-axis-text1')\r\n      .attr('style', self.chartConfiguration.yAxisCustomTextStyles)\r\n      .attr('transform', 'translate(0,0)')\r\n      .call(yLineAxis);\r\n  }\r\n\r\n  // Apply axis visibility configurations\r\n  this.applyAxisVisibilityConfig(self);\r\n}\r\n\r\nprivate applyAxisVisibilityConfig(self) {\r\n  if (self.chartConfiguration.isXaxisLabelHidden) {\r\n    d3.selectAll('g.lib-line-x-axis-text > g > text')\r\n      .attr('class', 'lib-display-hidden');\r\n  }\r\n\r\n  if (self.chartConfiguration.isYaxisLabelHidden) {\r\n    d3.selectAll('.yaxis-dashed > g > text')\r\n      .attr('class', 'lib-display-hidden');\r\n  }\r\n\r\n  if (self.chartConfiguration.isYaxisHidden) {\r\n    d3.selectAll('.yaxis-dashed')\r\n      .attr('class', 'lib-display-hidden');\r\n  }\r\n\r\n  if (self.chartConfiguration.isYaxisDashed) {\r\n    d3.selectAll('.yaxis-dashed')\r\n      .style('stroke-dasharray', '5 5')\r\n      .style('color', 'var(--chart-axis-color, #999999)');\r\n  }\r\n}\r\n\r\nprivate renderAxisLabels(svg, svgYAxisLeft, svgYAxisRight, metaData, width, height, margin, self, isria, rightSvgWidth) {\r\n  // Y-axis label\r\n  if (metaData.yLabel) {\r\n    const yPosition = isria ? 0 - margin.left / 2 - 30 : 0 - margin.left / 2 - 40;\r\n\r\n    svgYAxisLeft.append('text')\r\n      .attr('class', 'lib-axis-group-label font-size-1')\r\n      .attr('style', self.chartConfiguration.yAxisCustomlabelStyles)\r\n      .attr('transform', 'rotate(-90)')\r\n      .attr('y', yPosition)\r\n      .attr('x', 0 - height / 2)\r\n      .attr('dy', '1em')\r\n      .style('text-anchor', 'middle')\r\n      .attr('fill', 'var(--chart-text-color)');\r\n\r\n    if (this.chartConfiguration.isMultiChartGridLine === undefined) {\r\n      svgYAxisLeft.selectAll('.lib-axis-group-label')\r\n        .style('font-size', 'smaller')\r\n        .text(metaData.yLabel);\r\n    } else {\r\n      svg.selectAll('.lib-axis-group-label')\r\n        .attr('class', 'lib-ylabel-weeklyCharts')\r\n        .text(metaData.yLabel.toLowerCase());\r\n    }\r\n  }\r\n\r\n  // X-axis label\r\n  if (metaData.xLabel) {\r\n    const isAcronym = this.isLabelAcronym(metaData.xLabel);\r\n    const xPosition = isria \r\n      ? (height + margin.top + margin.bottom) \r\n      : (height + margin.top + margin.bottom + 40);\r\n\r\n    svg.append('text')\r\n      .attr('class', this.getXLabelClass(self))\r\n      .attr('style', self.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 ? metaData.xLabel.toUpperCase() : metaData.xLabel.toLowerCase())\r\n      .style('text-transform', isAcronym ? 'none' : 'capitalize');\r\n  }\r\n\r\n  // Line y-axis label\r\n  if (metaData.lineyLabel) {\r\n    svgYAxisRight.append('text')\r\n      .attr('class', 'lib-axis-group-label lib-line-axis')\r\n      .attr('fill', 'var(--chart-text-color)')\r\n      .attr('style', self.chartConfiguration.yAxisCustomlabelStyles)\r\n      .attr('transform', 'translate(0,0) rotate(90)')\r\n      .attr('y', -100)\r\n      .attr('x', 100)\r\n      .attr('dy', '5em')\r\n      .style('text-anchor', 'middle')\r\n      .style('font-size', 'smaller')\r\n      .text(metaData.lineyLabel);\r\n  }\r\n\r\n  // Apply drilldown chart specific styles\r\n  if (this.chartConfiguration.isDrilldownChart) {\r\n    svg.selectAll('g.x1.axis1 g.tick line').style('display', 'none');\r\n  }\r\n}\r\n\r\nprivate isLabelAcronym(label) {\r\n  return (label.length <= 4 && /^[A-Z]+$/.test(label)) ||\r\n         (label === label.toUpperCase() && /[A-Z]/.test(label));\r\n}\r\n\r\nprivate getXLabelClass(self) {\r\n  let baseClass = 'lib-axis-group-label font-size-1';\r\n  \r\n  if (self.chartConfiguration.isDrilldownChart) {\r\n    return baseClass + ' lib-xlabel-drilldowncharts';\r\n  }\r\n  \r\n  if (self.chartConfiguration.isMultiChartGridLine !== undefined) {\r\n    return baseClass + ' lib-xlabel-weeklyCharts';\r\n  }\r\n  \r\n  return baseClass + ' lib-axis-waterfall-label';\r\n}\r\n\r\nprivate renderTargetLine(svg, svgYAxisRight, y, width, rightSvgWidth, metaData, self) {\r\n  const yZero = y(this.chartData.targetLineData.target);\r\n\r\n  // Draw target line\r\n  svg.append('line')\r\n    .attr('x1', 0)\r\n    .attr('x2', width)\r\n    .attr('y1', yZero)\r\n    .attr('y2', yZero)\r\n    .style('stroke-dasharray', '5 5')\r\n    .style('stroke', this.chartData.targetLineData.color);\r\n\r\n  // Add target label\r\n  const dataTypeTemp = metaData.dataType || '';\r\n  const targetLineName = this.chartData.targetLineData.targetName || 'target';\r\n\r\n  svgYAxisRight.append('foreignObject')\r\n    .attr('transform', `translate(0,${yZero - 30})`)\r\n    .attr('width', rightSvgWidth)\r\n    .attr('height', 50)\r\n    .append('xhtml:div')\r\n    .attr('class', 'target-display')\r\n    .style('color', 'var(--chart-text-color)')\r\n    .html(`<div>${targetLineName}</div><div>${self.chartData.targetLineData.target}${dataTypeTemp}</div>`);\r\n}\r\n\r\nprivate renderLineChart(svg, lineData, x, lineYscale, metaData, self) {\r\n  // Draw line path\r\n  svg.append('path')\r\n    .datum(lineData)\r\n    .attr('fill', 'none')\r\n    .attr('stroke', self.chartConfiguration.lineGraphColor)\r\n    .attr('stroke-width', 1.5)\r\n    .attr('d', d3.line()\r\n      .x((d) => x(d.name) + x.bandwidth() / 2)\r\n      .y((d) => lineYscale(d.value)));\r\n\r\n  // Add dots\r\n  const dot = svg.selectAll('myCircles')\r\n    .data(lineData)\r\n    .enter()\r\n    .append('g')\r\n    .on('click', (d) => {\r\n      if (!metaData.barWithoutClick || !metaData.barWithoutClick.length ||\r\n          (!metaData.barWithoutClick.includes(d?.name) && \r\n           !metaData.barWithoutClick.includes(d?.key))) {\r\n        self.handleClick(d);\r\n      }\r\n    });\r\n\r\n  dot.append('circle')\r\n    .attr('fill', self.chartConfiguration.lineGraphColor)\r\n    .attr('stroke', 'none')\r\n    .attr('cx', (d) => x(d.name) + x.bandwidth() / 2)\r\n    .attr('cy', (d) => lineYscale(d.value))\r\n    .style('cursor', () => self.chartData.metaData.hasDrillDown ? 'pointer' : 'default')\r\n    .attr('r', 3);\r\n\r\n  // Add value labels\r\n  if (self.chartConfiguration.lineGraphColor) {\r\n    dot.append('text')\r\n      .attr('class', 'dot')\r\n      .attr('fill', 'var(--chart-text-color)')\r\n      .attr('color', self.chartConfiguration.lineGraphColor)\r\n      .attr('style', 'font-size: .85em')\r\n      .attr('x', (d) => x(d.name) + x.bandwidth() / 2)\r\n      .attr('y', (d) => lineYscale(d.value))\r\n      .attr('dy', '-1em')\r\n      .text((d) => self.chartConfiguration.labelFormatter(d.value));\r\n  }\r\n}\r\n\r\nprivate handleZoomOut(svg, height, margin) {\r\n  svg.selectAll('.lib-xaxis-labels-texts-drilldown')\r\n    .each((d, i, nodes) => {\r\n      const text = d3.select(nodes[i]);\r\n      const label = text.text();\r\n      \r\n      if (label.indexOf('\\n') > -1) {\r\n        const lines = label.split('\\n');\r\n        text.text(null);\r\n        lines.forEach((line, idx) => {\r\n          text.append('tspan')\r\n            .text(line)\r\n            .attr('x', 0)\r\n            .attr('dy', idx === 0 ? '1em' : '1.1em');\r\n        });\r\n      } else {\r\n        const words = label.split(' ');\r\n        text.text(null);\r\n        words.forEach((word) => {\r\n          text.append('tspan').text(word);\r\n        });\r\n      }\r\n    })\r\n    .style('fill', 'var(--chart-text-color)')\r\n    .attr('transform', null);\r\n\r\n  svg.select('.x-axis')\r\n    .attr('transform', `translate(0, ${height - margin.bottom + 10})`);\r\n}\r\n\r\nprivate calculateChartDimensions(chartContainer: any, verticalstackedcontainer: any, margin: any, self: any) {\r\n  let width = parseInt(chartContainer.style('width')) - margin.left - margin.right;\r\n  const dataLength = this.chartData.data.length;\r\n\r\n  // ---- Width Logic (no change) ----\r\n  if (dataLength > 30 && this.isZoomedOut) {\r\n    width =\r\n      width > dataLength * 40\r\n        ? this.chartData.dropdownData1\r\n          ? dataLength * 60\r\n          : width\r\n        : this.chartData.dropdownData1\r\n        ? dataLength * 60\r\n        : dataLength * 40;\r\n\r\n    width = width > dataLength * 40 ? width : dataLength * 40;\r\n  }\r\n\r\n  if (\r\n    this.chartData.dropdownData2 &&\r\n    width < dataLength * 120 &&\r\n    this.isZoomedOut\r\n  ) {\r\n    width = dataLength * 120;\r\n  }\r\n\r\n  if (dataLength > 8 && !this.isZoomedOut) {\r\n    if (\r\n      this.chartData.dropdownData2 &&\r\n      width < dataLength * 250\r\n    ) {\r\n      width = dataLength * 250;\r\n    } else {\r\n      width = dataLength * 160;\r\n    }\r\n  }\r\n\r\n  // ---- Height Logic (no change) ----\r\n  let height =\r\n    parseInt(verticalstackedcontainer.style('height')) *\r\n      (self.chartConfiguration.svgHeight / 100) -\r\n    margin.top -\r\n    margin.bottom;\r\n\r\n  if (\r\n    this.chartConfiguration.isFullScreen !== undefined &&\r\n    this.chartConfiguration.isFullScreen\r\n  ) {\r\n    height =\r\n      this.chartConfiguration.svgHeight !== 70\r\n        ? this.chartConfiguration.svgHeight\r\n        : parseInt(verticalstackedcontainer.style('height'));\r\n  }\r\n\r\n  if (this.chartConfiguration.isDrilldownChart && !this.isHeaderVisible) {\r\n    height =\r\n      parseInt(verticalstackedcontainer.style('height')) -\r\n      margin.top -\r\n      margin.bottom -\r\n      130;\r\n  }\r\n\r\n  if (this.chartConfiguration.isHeaderVisible) {\r\n    height =\r\n      parseInt(verticalstackedcontainer.style('height')) -\r\n      margin.top -\r\n      margin.bottom -\r\n      100;\r\n  }\r\n\r\n  return { width, height };\r\n}\r\nprivate createChartContainers(\r\n  chartContainer: any,\r\n  margin: any,\r\n  height: number,\r\n  rightSvgWidth: number,\r\n  self: any,\r\n  width: number\r\n) {\r\n  // Outer container\r\n  const outerContainer = chartContainer\r\n    .append('div')\r\n    .attr('id', self.uniqueId)\r\n    .attr('class', 'outer-container')\r\n    .style('width', '100%')\r\n    .style('height', height)\r\n    .style('overflow-x', 'hidden')\r\n    .style('padding-left', `${margin.left}px`)\r\n    .style('padding-right', `${rightSvgWidth}px`)\r\n    .style('margin-left', '15px');\r\n\r\n  // Left Y-Axis\r\n  const svgYAxisLeft = outerContainer\r\n    .append('svg')\r\n    .attr('width', '100')\r\n    .attr('height', height + margin.top + margin.bottom + 10)\r\n    .style('position', 'absolute')\r\n    .style('left', '0')\r\n    .style('z-index', 1)\r\n    .append('g')\r\n    .attr('transform', `translate(${margin.left + 15},${margin.top})`);\r\n\r\n  // Right Y-Axis\r\n  const svgYAxisRight = outerContainer\r\n    .append('svg')\r\n    .attr('width', rightSvgWidth)\r\n    .attr('height', height + margin.top + margin.bottom + 10)\r\n    .style('position', 'absolute')\r\n    .style('right', '12px')\r\n    .style('z-index', 1)\r\n    .append('g')\r\n    .attr('transform', `translate(0,${margin.top})`);\r\n\r\n  // Inner scrollable container\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  // Main SVG\r\n  const svg = innerContainer\r\n    .append('svg')\r\n    .attr('width', width - rightSvgWidth)\r\n    .attr('height', height + margin.top + margin.bottom + 60)\r\n    .append('g')\r\n    .attr('transform', `translate(0,${margin.top})`);\r\n\r\n  return { outerContainer, svgYAxisLeft, svgYAxisRight, innerContainer, svg };\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  handleHeaderMenuClick(id) {\r\n    this.headerMenuclickEvent.emit(id);\r\n  }\r\n  handleDD1Click(event) {\r\n    this.isDD1Open = true;\r\n    this.isDD2Open = false;\r\n  }\r\n  handleDD2Click(event) {\r\n    this.isDD2Open = true;\r\n    this.isDD1Open = false;\r\n  }\r\n  handleCompareByFilterSelection(event) {\r\n    this.clickEvent.emit(event);\r\n  }\r\n}\r\n","<div\r\n  #groupcontainer\r\n  class=\"lib-chart-wrapper\"\r\n  [ngClass]=\"{ 'lib-no-background': isTransparentBackground }\"\r\n  style=\"background-color: var(--card-bg);\"\r\n  (resized)=\"onResized($event)\"\r\n>\r\n  <div class=\"header-alt\" *ngIf=\"!isHeaderVisible\">\r\n    <lib-chart-header-v2\r\n      [chartData]=\"chartData\"\r\n      [chartConfiguration]=\"chartConfiguration\"\r\n      (clickEvent)=\"handleClick($event)\"\r\n    ></lib-chart-header-v2>\r\n    <lib-chart-header-v3\r\n      [chartData]=\"chartData\"\r\n      [chartConfiguration]=\"chartConfiguration\"\r\n      (compareByFilterSelection)=\"handleCompareByFilterSelection($event)\"\r\n      (zoomInZoomOutClick)=\"handleZoominZoomoutClick($event)\"\r\n    ></lib-chart-header-v3>\r\n  </div>\r\n  <lib-chart-header-v1\r\n    [title]=\"chartData.metaData.title\"\r\n    [hasDrillDown]=\"chartData.metaData.hasDrillDown\"\r\n    [isEditEnabled]=\"chartData.metaData.isEditEnabled\"\r\n    [menuOptions]=\"chartConfiguration.headerMenuOptions\"\r\n    [isria]=\"customChartConfiguration.isRia\"\r\n    [selectedKpiTooltop]=\"chartConfiguration.selectedKpiTooltop\"\r\n    (menuOptionClickEvent)=\"handleHeaderMenuClick($event)\"\r\n    [isAlertEnabled]=\"isAlertEnabled\"\r\n    *ngIf=\"isHeaderVisible\"\r\n  ></lib-chart-header-v1>\r\n  <div\r\n    *ngIf=\"\r\n      chartData &&\r\n      chartData.metaData &&\r\n      chartConfiguration.legendJustified &&\r\n      legendVisible &&\r\n      chartConfiguration.legendAtTopRight\r\n    \"\r\n    class=\"legend-holder-right\"\r\n    [style.height]=\"chartConfiguration.footerHeight\"\r\n  >\r\n    <ul class=\"display-flex\">\r\n      <li\r\n        class=\"legends-positioning-inline\"\r\n        *ngFor=\"let item of chartData.metaData.colors | keyvalue : keepOrder\"\r\n      >\r\n        <span\r\n          class=\"lib-donut-justified-label-icon-drilldown\"\r\n          [style.background-color]=\"item.value\"\r\n        ></span\r\n        ><span>{{ item.key }}</span>\r\n      </li>\r\n    </ul>\r\n  </div>\r\n  <div\r\n    [style.height]=\"chartConfiguration.svgHeight\"\r\n    id=\"groupchartcontainer\"\r\n    #groupchartcontainer\r\n    class=\"lib-chart-svg\"\r\n  ></div>\r\n\r\n\r\n  <!-- <div\r\n    *ngIf=\"\r\n      chartData &&\r\n      chartData.metaData &&\r\n      chartConfiguration.legendJustified &&\r\n      legendVisible &&\r\n      !chartConfiguration.legendAtTopRight\r\n    \"\r\n    class=\"lib-donut-chart-footer\"\r\n    [style.height]=\"chartConfiguration.footerHeight\"\r\n  >\r\n    <ul class=\"lib-donut-justified-label-wrapper\">\r\n      <li\r\n        class=\"lib-donut-justified-label-item\"\r\n        *ngFor=\"let item of chartData.metaData.colors | keyvalue\"\r\n      >\r\n        <span\r\n          class=\"lib-donut-justified-label-icon\"\r\n          [style.background-color]=\"item.value\"\r\n        ></span\r\n        ><span>{{ item.key }}</span>\r\n      </li>\r\n    </ul>\r\n  </div> -->\r\n\r\n\r\n  <!-- <div *ngIf=\"chartConfiguration?.isDisplayBarDetailsAtBottom\">\r\n    <div\r\n      class=\"bar-values lib-display-flex lib-justify-content-center lib-align-items-center\"\r\n      *ngFor=\"\r\n        let item of chartData.metaData.colors | keyvalue : keepOrder;\r\n        let i = index\r\n      \">\r\n      <div\r\n        class=\"bar-name font-size-1\"\r\n        *ngIf=\"\r\n          chartData.data[0][item.key] &&\r\n          i <= chartConfiguration.howmanyBarDetailsToDisplay\r\n        \"\r\n      >\r\n        {{ item.key }}\r\n      </div>\r\n      <div\r\n        class=\"bar-value lib-display-flex lib-align-items-center font-size-1\"\r\n        [style.color]=\"\r\n          chartConfiguration.barVauleColor ? barVauleColor : item.value\r\n        \"\r\n        *ngIf=\"\r\n          chartData.data[0][item.key] &&\r\n          i <= chartConfiguration.howmanyBarDetailsToDisplay\r\n        \"\r\n      >\r\n        {{ chartData.data[0][item.key] }}\r\n      </div>\r\n    </div>\r\n  </div> -->\r\n</div>\r\n"]}