axidio-styleguide-library1-v2 0.0.890 → 0.0.892

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -14,181 +14,206 @@ export class GroupChartComponent extends ComponentUniqueId {
14
14
  super();
15
15
  this.clickEvent = new EventEmitter();
16
16
  this.headerMenuclickEvent = new EventEmitter();
17
- this.chartConfiguration = {};
18
17
  this.isHeaderVisible = true;
19
- this.isTopCaptionVisible = true;
20
- this.uniqueId = this.getUniqueId();
18
+ this.legendVisible = true;
21
19
  this.isTransparentBackground = false;
20
+ this.chartConfiguration = {};
21
+ this.objectKeys = Object.keys;
22
22
  this.defaultConfiguration = {
23
23
  margin: { top: 20, right: 20, bottom: 20, left: 40 },
24
+ labelFormatter: ChartHelper.defaultFormatter,
24
25
  svgHeight: 70,
25
- legendHeight: '10%',
26
26
  numberOfYTicks: 5,
27
- labelFormatter: ChartHelper.defaultFormatter,
28
- xAxisLabelFomatter: ChartHelper.defaultFormatter,
29
- yAxisLabelFomatter: ChartHelper.defaultFormatter,
27
+ legendJustified: true,
30
28
  yLineAxisLabelFomatter: ChartHelper.defaultFormatter,
29
+ yAxisLabelFomatter: ChartHelper.defaultFormatter,
31
30
  lineGraphColor: '#F6D283',
32
31
  showLineChartAxis: true,
33
- showLegend: false,
34
- forComparison: true,
32
+ showValues: true,
35
33
  headerMenuOptions: HeaderConfigHelper.headerConfig.headerMenuOptions,
34
+ xAxisGrid: undefined,
36
35
  yAxisGrid: false,
36
+ legendVisible: false,
37
37
  isHeaderVisible: undefined,
38
38
  isTransparentBackground: undefined,
39
- isTopCaptionVisible: undefined,
40
39
  isMultiChartGridLine: undefined,
41
40
  isFullScreen: undefined,
42
41
  customYscale: undefined,
42
+ textsOnBar: undefined,
43
43
  isXaxisLabelHidden: undefined,
44
- isYaxisLabelHidden: undefined,
44
+ isYaxisLabelHidden: false,
45
45
  isYaxisHidden: undefined,
46
46
  isYaxisDashed: undefined,
47
- isXaxisColor: undefined,
48
47
  textFormatter: undefined,
49
- showTotalOnTop: undefined,
50
- backendFormatterHasPriority: undefined,
51
- showAngledLabels: undefined,
52
48
  isNoAlternateXaxisText: undefined,
53
49
  isXgridBetweenLabels: undefined,
54
- showXaxisTop: undefined,
55
- xAxisGrid: undefined,
50
+ backgroundColor: '#FFFFFF',
51
+ hideLegendOnTop: true,
52
+ isXaxisColor: '#999999',
53
+ labelOverlapMinorFix: true,
54
+ noHoverEffect: true,
55
+ noHoverDisplayData: true,
56
+ showXaxisTop: true,
57
+ displayYaxisLabels: undefined,
56
58
  xLabelsOnSameLine: undefined,
57
- hideXaxisTick: undefined,
58
- isDrilldownChart: undefined,
59
- isTargetLine: undefined,
59
+ textAlwaysHorizontal: undefined,
60
+ legendAtTopRight: undefined,
61
+ isDrilldownChart: true,
60
62
  displayTitleOnTop: undefined,
61
63
  isToggleVisible: undefined,
62
64
  isTitleHidden: undefined,
65
+ isDisplayBarDetailsAtBottom: undefined,
66
+ howmanyBarDetailsToDisplay: 0,
67
+ barVauleColor: undefined,
68
+ defaultBarHeight: 2,
69
+ };
70
+ this.uniqueId = this.getUniqueId();
71
+ this.isZoomedOut = true;
72
+ this.isDD1Open = false;
73
+ this.isDD2Open = false;
74
+ this.keepOrder = (a, b) => {
75
+ return a;
63
76
  };
64
- this.isCC = false;
65
- this.isZoomedOut = false;
66
- }
67
- isZoomOutSelected(isZoomOut) {
68
- this.isZoomedOut = isZoomOut;
69
- this.ngOnChanges();
70
- }
71
- ngOnChanges() {
72
- let self = this;
73
- d3.select('#' + self.uniqueId).remove();
74
- this.initializeStackedChart();
75
77
  }
76
78
  onResized(event) {
77
79
  let self = this;
78
80
  setTimeout(function () {
79
81
  d3.select('#' + self.uniqueId).remove();
80
- self.initializeStackedChart();
82
+ self.initializegroupChart();
81
83
  }.bind(self), 10);
82
84
  }
85
+ isZoomOutSelected(isZoomOut, event) {
86
+ this.isZoomedOut = isZoomOut;
87
+ this.onResized(event);
88
+ }
89
+ handleZoominZoomoutClick({ isZoomOut, event }) {
90
+ this.isZoomOutSelected(isZoomOut, event);
91
+ }
83
92
  ngOnInit() { }
84
- initializeStackedChart() {
93
+ isLegendVisible() {
94
+ if (this.chartData &&
95
+ this.chartData.metaData.colors &&
96
+ Object.keys(this.chartData.metaData.colors).length > 1) {
97
+ return true;
98
+ }
99
+ return false;
100
+ }
101
+ get isAlertEnabled() {
102
+ return this.chartConfiguration?.headerMenuOptions?.some((option) => option.id === 'editAlert');
103
+ }
104
+ initializegroupChart() {
85
105
  var self = this;
86
106
  let data = [];
87
107
  let metaData = null;
88
108
  let keyList = null;
89
109
  let lineData = null;
90
- let colors = 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;
91
118
  var alternate_text = false;
92
- var alternate_label = false;
93
119
  var short_tick_length = 4;
94
120
  var long_tick_length = 16;
121
+ /**
122
+ * longer tick length needed for weekly charts
123
+ */
95
124
  var short_tick_length_bg = 5;
96
125
  var long_tick_length_bg = 30;
97
- var formatFromBackend;
98
- var formatForHugeNumbers;
99
- var tempObjectHolder = {};
100
- var rightSvgWidth = 60;
101
126
  var leftAndRightSpaces = 50;
102
- let isria = this.customChartConfiguration.isRia;
103
- // Responsive breakpoints
104
- const isMobile = window.innerWidth < 576;
105
- const isTablet = window.innerWidth >= 576 && window.innerWidth < 992;
106
- const isDesktop = window.innerWidth >= 992;
107
- // Adjust margins and font sizes based on device
108
- if (isMobile) {
109
- this.chartConfiguration.margin = { top: 20, right: 10, bottom: 40, left: 30 };
110
- this.chartConfiguration.numberOfYTicks = 4;
111
- this.chartConfiguration.svgHeight = 60;
112
- }
113
- else if (isTablet) {
114
- this.chartConfiguration.margin = { top: 25, right: 20, bottom: 45, left: 40 };
115
- this.chartConfiguration.numberOfYTicks = 6;
116
- this.chartConfiguration.svgHeight = 70;
117
- }
118
- else {
119
- this.chartConfiguration.margin = { top: 30, right: 30, bottom: 50, left: 60 };
120
- this.chartConfiguration.numberOfYTicks = 7;
121
- this.chartConfiguration.svgHeight = 80;
122
- }
127
+ var rightSvgWidth = 60;
128
+ var tempScale;
123
129
  for (var i in this.defaultConfiguration) {
124
130
  this.chartConfiguration[i] = ChartHelper.getValueByConfigurationType(i, this.defaultConfiguration, this.customChartConfiguration);
125
131
  }
126
132
  data = this.chartData.data;
127
133
  metaData = this.chartData.metaData;
128
- if (metaData.unit == undefined)
129
- metaData.unit = '';
130
- if (metaData.isCC) {
131
- this.isCC = metaData.isCC;
132
- }
133
- if (metaData.barWithoutClick && metaData.barWithoutClick.length) {
134
- metaData.barWithoutClick = metaData.barWithoutClick.map((ele) => ele.toLowerCase());
135
- }
136
- else {
137
- metaData.barWithoutClick = [];
138
- }
139
134
  lineData = this.chartData.lineData;
140
- colors = metaData.colors;
135
+ // if (lineData || this.chartData.targetLineData) {
136
+ // rightSvgWidth = 60;
137
+ // }
138
+ if (!metaData.colorAboveTarget) {
139
+ metaData['colorAboveTarget'] = metaData.colors;
140
+ }
141
+ colorMap = metaData.colors;
141
142
  keyList = metaData.keyList;
142
143
  var chartContainer = d3.select(this.containerElt.nativeElement);
143
144
  var verticalstackedcontainer = d3.select(this.groupcontainerElt.nativeElement);
144
- let parsedNum = parseFloat(this.chartData?.targetLineData?.target);
145
- if (!isNaN(parsedNum)) {
146
- if (Number.isInteger(parsedNum)) {
147
- parsedNum = parseInt(this.chartData.targetLineData.target);
148
- }
149
- else {
150
- parsedNum = parseFloat(this.chartData.targetLineData.target);
151
- }
152
- }
153
145
  var margin = this.chartConfiguration.margin;
154
- // Responsive width and height
155
- var containerWidth = chartContainer.node().getBoundingClientRect().width;
156
- var containerHeight = verticalstackedcontainer.node().getBoundingClientRect().height;
157
- var width = containerWidth - margin.left - margin.right;
158
- var height = containerHeight * (self.chartConfiguration.svgHeight / 100) - margin.top - margin.bottom;
159
- // Adjust width for large datasets and zoom
146
+ var width = parseInt(chartContainer.style('width')) - margin.left - margin.right;
160
147
  if (this.chartData.data.length > 30 && this.isZoomedOut) {
161
- width = width > this.chartData.data.length * (isMobile ? 15 : 25)
162
- ? width
163
- : this.chartData.data.length * (isMobile ? 15 : 25);
148
+ width =
149
+ width > this.chartData.data.length * 40
150
+ ? this.chartData.dropdownData1
151
+ ? this.chartData.data.length * 60
152
+ : width
153
+ : this.chartData.dropdownData1
154
+ ? this.chartData.data.length * 60
155
+ : this.chartData.data.length * 40;
156
+ width =
157
+ width > this.chartData.data.length * 40
158
+ ? width
159
+ : this.chartData.data.length * 40;
160
+ }
161
+ if (this.chartData.dropdownData2 &&
162
+ width < this.chartData.data.length * 120 &&
163
+ this.isZoomedOut) {
164
+ width = this.chartData.data.length * 120;
164
165
  }
165
166
  if (this.chartData.data.length > 8 && !this.isZoomedOut) {
166
- width = this.chartData.data.length * (isMobile ? 60 : 130);
167
+ if (this.chartData.dropdownData2 &&
168
+ width < this.chartData.data.length * 250) {
169
+ width = this.chartData.data.length * 250;
170
+ }
171
+ else
172
+ width = this.chartData.data.length * 160;
173
+ }
174
+ // if (this.chartData.data.length > 8) {
175
+ // width = this.chartData.data.length * 140;
176
+ // }
177
+ var height = parseInt(verticalstackedcontainer.style('height')) *
178
+ (self.chartConfiguration.svgHeight / 100) -
179
+ margin.top -
180
+ margin.bottom;
181
+ /**
182
+ * entire height used in weekly charts as x axis needed to be displayed at the bottom of the chart
183
+ */
184
+ if (this.chartConfiguration.isFullScreen != undefined &&
185
+ this.chartConfiguration.isFullScreen) {
186
+ height =
187
+ this.chartConfiguration.svgHeight != 70
188
+ ? this.chartConfiguration.svgHeight
189
+ : parseInt(verticalstackedcontainer.style('height'));
167
190
  }
168
- // Fullscreen and drilldown adjustments
169
- if (this.chartConfiguration.isFullScreen != undefined && this.chartConfiguration.isFullScreen) {
170
- height = this.chartConfiguration.svgHeight != 80
171
- ? this.chartConfiguration.svgHeight
172
- : containerHeight;
191
+ if (this.chartConfiguration.isDrilldownChart && !this.isHeaderVisible) {
192
+ height =
193
+ parseInt(verticalstackedcontainer.style('height')) -
194
+ margin.top -
195
+ margin.bottom -
196
+ 130;
173
197
  }
174
- if (this.chartConfiguration.isDrilldownChart) {
175
- height = containerHeight - margin.top - margin.bottom - (isMobile ? 60 : 130);
198
+ if (this.chartConfiguration.isHeaderVisible) {
199
+ height =
200
+ parseInt(verticalstackedcontainer.style('height')) -
201
+ margin.top -
202
+ margin.bottom -
203
+ 100;
176
204
  }
177
- // ...existing code...
178
205
  /**
179
206
  * for hiding header
180
207
  * used by weekly charts
181
208
  */
182
- if (this.chartConfiguration.isHeaderVisible != undefined) {
209
+ if (this.chartConfiguration.isHeaderVisible != undefined)
183
210
  this.isHeaderVisible = this.chartConfiguration.isHeaderVisible;
184
- }
185
211
  /**
186
212
  * for hiding legends
187
213
  * used by weekly charts
188
214
  */
189
- if (this.chartConfiguration.isTopCaptionVisible != undefined) {
190
- //UPDATENAME
191
- this.isTopCaptionVisible = this.chartConfiguration.isTopCaptionVisible;
215
+ if (this.chartConfiguration.legendVisible != undefined) {
216
+ this.legendVisible = this.chartConfiguration.legendVisible;
192
217
  }
193
218
  /**
194
219
  * for removing background color so that it can take parents color
@@ -213,23 +238,24 @@ export class GroupChartComponent extends ComponentUniqueId {
213
238
  .style('height', height)
214
239
  .style('overflow-x', 'hidden')
215
240
  .style('padding-left', `${margin.left}px`)
216
- .style('margin-left', '10px')
217
- .style('padding-right', `${rightSvgWidth}px`);
241
+ // .call(ChartHelper.responsivefy)
242
+ .style('padding-right', `${rightSvgWidth}px`)
243
+ .style('margin-left', '15px');
218
244
  var svgYAxisLeft = outerContainer
219
245
  .append('svg')
220
- .attr('width', '80')
221
- .attr('height', height + margin.top + margin.bottom)
246
+ .attr('width', '100')
247
+ .attr('height', height + margin.top + margin.bottom + 10)
222
248
  .style('position', 'absolute')
223
249
  .style('left', '0')
224
250
  .style('z-index', 1)
225
251
  .append('g')
226
- .attr('transform', 'translate(' + (margin.left + 10) + ',' + margin.top + ')');
252
+ .attr('transform', 'translate(' + (margin.left + 15) + ',' + margin.top + ')');
227
253
  var svgYAxisRight = outerContainer
228
254
  .append('svg')
229
255
  .attr('width', rightSvgWidth)
230
- .attr('height', height + margin.top + margin.bottom)
256
+ .attr('height', height + margin.top + margin.bottom + 10)
231
257
  .style('position', 'absolute')
232
- .style('right', '2px')
258
+ .style('right', '12px')
233
259
  .style('z-index', 1)
234
260
  .append('g')
235
261
  .attr('transform', 'translate(' + 0 + ',' + margin.top + ')');
@@ -238,109 +264,201 @@ export class GroupChartComponent extends ComponentUniqueId {
238
264
  .attr('class', 'inner-container')
239
265
  .style('width', '100%')
240
266
  .style('overflow-x', 'auto');
241
- // Calculate bar width and padding for mobile to avoid overlap and add space between bars
242
- let barWidth;
243
- let barPadding = 12; // px, space between bars on mobile
244
- let requiredSvgWidth;
245
- if (isMobile) {
246
- // Use a minimum width per bar and add padding between bars
247
- const minBarWidth = 32; // px, can adjust as needed
248
- barWidth = minBarWidth;
249
- requiredSvgWidth = Math.max(width - rightSvgWidth, (barWidth + barPadding) * data.length + leftAndRightSpaces * 2 + rightSvgWidth - barPadding // no padding after last bar
250
- );
251
- innerContainer.style('overflow-x', 'auto');
252
- }
253
- else {
254
- barWidth = Math.max(40, (width - rightSvgWidth - leftAndRightSpaces * 2) / data.length);
255
- barPadding = 0;
256
- requiredSvgWidth = width - rightSvgWidth;
257
- }
258
267
  var svg = innerContainer
259
268
  .append('svg')
260
- .attr('width', requiredSvgWidth)
269
+ // .attr('id', self.uniqueId)
270
+ .attr('width', width - rightSvgWidth)
261
271
  .attr('height', height + margin.top + margin.bottom + 30)
272
+ // .call(ChartHelper.responsivefy)
262
273
  .append('g')
263
274
  .attr('transform', 'translate(' + 0 + ',' + margin.top + ')');
264
- let stackKey = keyList;
265
- var stack = d3
266
- .stack()
267
- .keys(stackKey)
268
- /*.order(d3.stackOrder)*/
269
- .offset(d3.stackOffsetNone);
270
- var layers = stack(data);
271
- data.sort(function (a, b) {
272
- return b.total - a.total;
273
- });
274
- let lineYscale;
275
- if (lineData != null) {
276
- lineYscale = d3
277
- .scaleLinear()
278
- .domain([
279
- 0,
280
- d3.max(lineData, function (d) {
281
- return +d.value;
282
- }),
283
- ])
284
- .range([height, 0]);
285
- }
286
- // Calculate bar width for mobile to avoid overlap
287
- // ...barWidth is now calculated above, remove duplicate...
288
- var xScale = d3
289
- .scaleBand()
290
- .rangeRound([
291
- leftAndRightSpaces,
292
- width - rightSvgWidth - leftAndRightSpaces
293
- ])
294
- .domain(data.map(function (d) {
295
- return d.name;
296
- }))
297
- .padding(isMobile ? 0.2 : 0.5);
298
- var xScaleFromOrigin = d3
299
- .scaleBand()
300
- .rangeRound([width - rightSvgWidth, 0])
301
- .domain(data.map(function (d) {
275
+ var subgroups = keyList;
276
+ var groups = d3
277
+ .map(data, function (d) {
302
278
  return d.name;
303
- }));
304
- // ...existing code...
279
+ })
280
+ .keys();
305
281
  /**
306
- * draw second x axis on top
282
+ * x axis range made similar to line chart or vertical stack so that all the charts will get aligned with each other.
307
283
  */
308
- if (self.chartConfiguration.showXaxisTop) {
309
- svg
310
- .append('g')
311
- .attr('class', 'lib-line-axis-text lib-line-x-axis-text x-axis')
312
- .attr('style', self.chartConfiguration.xAxisCustomTextStyles)
313
- .call(d3.axisBottom(xScale).tickSize(0));
314
- svg.selectAll('.x-axis > g > text').attr('class', 'lib-display-hidden');
284
+ if (this.chartConfiguration.isMultiChartGridLine != undefined) {
285
+ x = d3
286
+ .scaleBand()
287
+ .rangeRound([width, 0])
288
+ .align(0.5)
289
+ .padding([0.5])
290
+ .domain(data.map(function (d) {
291
+ return d.name.toLowerCase();
292
+ }));
293
+ }
294
+ else {
295
+ x = d3
296
+ .scaleBand()
297
+ .domain(groups)
298
+ .range([leftAndRightSpaces, width - rightSvgWidth - leftAndRightSpaces])
299
+ .padding([0.3]);
315
300
  }
301
+ // x.bandwidth(96);
302
+ var xScaleFromOrigin = d3
303
+ .scaleBand()
304
+ .domain(groups)
305
+ .range([0, width - rightSvgWidth]);
306
+ // .padding([0.2]);
316
307
  /**
317
308
  * draw second x axis on top
318
309
  */
319
- // if (self.chartConfiguration.showXaxisAtTarget) {
310
+ // if (self.chartConfiguration.showXaxisTop) {
320
311
  // svg
321
312
  // .append('g')
322
313
  // .attr('class', 'lib-line-axis-text lib-line-x-axis-text x-axis')
323
314
  // .attr('style', self.chartConfiguration.xAxisCustomTextStyles)
324
- // .call(d3.axisBottom(xScale).tickSize(0));
325
- // svg.selectAll('.x-axis > g > text').attr('class', 'lib-display-hidden');
315
+ // .call(d3.axisBottom(x).tickSize(0));
326
316
  // }
327
- if (this.chartConfiguration.xAxisGrid) {
328
- for (var j = 0; j < this.chartConfiguration.xAxisGrid.length; j++) {
317
+ // d3.svg.axis().scale(x).orient('bottom').ticks(1).innerTickSize(-height);
318
+ if (this.chartConfiguration.isMultiChartGridLine == undefined) {
319
+ /**
320
+ * normal ticks for all dashboard charts
321
+ */
322
+ svg
323
+ .append('g')
324
+ .attr('class', 'x1 axis1')
325
+ .attr('transform', 'translate(0,' + height + ')')
326
+ .call(d3.axisBottom(x))
327
+ .call((g) => g.select('.domain').remove());
328
+ svg.selectAll('g.x1.axis1 g.tick line').remove();
329
+ svg
330
+ .selectAll('g.x1.axis1 g.tick text')
331
+ .attr('class', 'lib-xaxis-labels-texts-drilldown')
332
+ .style('fill', 'var(--chart-text-color)');
333
+ // .attr('y', function () {
334
+ // if (alternate_text) {
335
+ // alternate_text = false;
336
+ // return long_tick_length + 1;
337
+ // } else {
338
+ // alternate_text = true;
339
+ // return short_tick_length + 1;
340
+ // }
341
+ // });
342
+ }
343
+ else {
344
+ /**
345
+ * bigger ticks for weekly charts and more space from x axis to labels
346
+ */
347
+ /**
348
+ * draw x axis
349
+ */
350
+ svg
351
+ .append('g')
352
+ .attr('class', 'x1 axis1')
353
+ .attr('transform', 'translate(0,' + height + ')')
354
+ .call(d3.axisBottom(x).tickSize(0))
355
+ .call((g) => g.select('.domain').attr('fill', 'none'));
356
+ /**
357
+ * tick line size in alternate fashion
358
+ */
359
+ svg.selectAll('g.x1.axis1 g.tick line').attr('y2', function () {
360
+ if (alternate_text &&
361
+ self.chartConfiguration.isNoAlternateXaxisText == undefined) {
362
+ alternate_text = false;
363
+ return long_tick_length_bg - 7;
364
+ }
365
+ else {
366
+ alternate_text = true;
367
+ return short_tick_length_bg - 4;
368
+ }
369
+ });
370
+ /**
371
+ * reset the flag so that values can be shown in same alternate fashion
372
+ */
373
+ alternate_text = false;
374
+ /**
375
+ * print x-axis label texts
376
+ * used by weekly charts
377
+ */
378
+ svg
379
+ .selectAll('g.x1.axis1 g.tick text')
380
+ .attr('class', 'lib-xaxis-labels-texts-weeklycharts')
381
+ .attr('y', function () {
382
+ if (alternate_text) {
383
+ alternate_text = false;
384
+ return long_tick_length_bg;
385
+ }
386
+ else {
387
+ alternate_text = true;
388
+ return short_tick_length_bg;
389
+ }
390
+ });
391
+ }
392
+ if (self.chartConfiguration.xLabelsOnSameLine) {
393
+ svg
394
+ .selectAll('g.x1.axis1 g.tick text')
395
+ .attr('class', 'lib-xaxis-labels-texts-drilldown')
396
+ .style('font-size', this.isHeaderVisible ? '18px' : '14px')
397
+ .attr('y', this.isHeaderVisible
398
+ ? short_tick_length_bg + 25
399
+ : short_tick_length_bg)
400
+ .attr('x', function (d) {
401
+ if (self.chartData.data.length > 8 && !self.isZoomedOut) {
402
+ return -25; // Move first line text slightly to the left too
403
+ }
404
+ return 0; // Default position
405
+ })
406
+ .text(function (d) {
407
+ var isValueToBeIgnored = false;
408
+ if (isMobile && !self.isHeaderVisible) {
409
+ let firstPart = d.split(/[\s\-]+/)[0];
410
+ return firstPart.substring(0, 3).toLowerCase();
411
+ }
412
+ data.map((indiv) => {
413
+ if (indiv.name.toLowerCase() == d.trim().toLowerCase() &&
414
+ indiv[metaData.keyList[0]] == -1) {
415
+ isValueToBeIgnored = true;
416
+ }
417
+ });
418
+ if (isValueToBeIgnored) {
419
+ return '';
420
+ }
421
+ // If label looks like a date (contains digits and - or /), show full label as one line
422
+ if (/\d{2,4}[-\/]/.test(d)) {
423
+ return d;
424
+ }
425
+ if (d.trim().indexOf(' ') > -1) {
426
+ return d.trim().substring(0, d.indexOf(' ')).toLowerCase();
427
+ }
428
+ return d.toLowerCase();
429
+ });
430
+ if (!isMobile) {
329
431
  svg
330
- .append('g')
331
- .attr('class', `x${j + 2} axis${j + 2}`)
332
- .style('color', 'var(--chart-grid-color)') // Use CSS variable instead of hardcoded
333
- .attr('transform', 'translate(0,' + height * this.chartConfiguration.xAxisGrid[j] + ')')
334
- .call(d3.axisBottom(xScale).tickSize(0).ticks(5).tickFormat(''))
335
- .style('fill', 'var(--chart-text-color)');
432
+ .selectAll('g.x1.axis1 g.tick')
433
+ .filter(function (d) {
434
+ return !/\d{2,4}[-\/]/.test(d); // Only process non-date labels
435
+ })
436
+ .append('text')
437
+ .attr('class', 'lib-xaxis-labels-texts-drilldown')
438
+ .attr('y', long_tick_length_bg)
439
+ .attr('fill', 'var(--chart-text-color)')
440
+ .attr('x', function (d) {
441
+ if (self.chartData.data.length > 8 && !self.isZoomedOut) {
442
+ return -25; // Move text slightly to the left
443
+ }
444
+ return 0; // Default position
445
+ })
446
+ .text(function (d) {
447
+ if (d.trim().indexOf(' ') > -1) {
448
+ return d.trim().substring(d.indexOf(' '), d.length).toLowerCase();
449
+ }
450
+ return '';
451
+ });
336
452
  }
337
453
  }
338
- let yScale = d3.scaleLinear().rangeRound([height, 0]);
339
- /**
340
- * update max vakues so that the vakue wont exceed the max limit
341
- * used by weekly charts
342
- */
343
- var maxValue = d3.max(layers, (d) => d3.max(d, (d) => d[1]));
454
+ if (isMobile && !this.isHeaderVisible) {
455
+ svg
456
+ .selectAll('g.x1.axis1 g.tick text')
457
+ .classed('mobile-xaxis-override', true);
458
+ }
459
+ /**y scale for left y axis */
460
+ var y = d3.scaleLinear().rangeRound([height, 0]);
461
+ var maxValue = d3.max(data, (d) => d3.max(keyList, (key) => +d[key]));
344
462
  if (maxValue == 0) {
345
463
  if (this.chartData.targetLineData) {
346
464
  maxValue = this.chartData.targetLineData.target + 20;
@@ -349,7 +467,27 @@ export class GroupChartComponent extends ComponentUniqueId {
349
467
  maxValue = 100;
350
468
  }
351
469
  }
470
+ if (self.chartConfiguration.yAxisGrid) {
471
+ // svg
472
+ // .append('g')
473
+ // .attr('class', 'grid')
474
+ // .call(
475
+ // d3
476
+ // .axisLeft(y)
477
+ // .ticks(self.chartConfiguration.numberOfYTicks)
478
+ // .tickSize(-width)
479
+ // .tickFormat('')
480
+ // )
481
+ // // .style('stroke-dasharray', '5 5')
482
+ // .style('color', '#B9B9B9')
483
+ // .style('opacity', '0.5')
484
+ // .call((g) => g.select('.domain').remove());
485
+ }
352
486
  if (this.chartConfiguration.customYscale) {
487
+ /**
488
+ * increase y-scale so that values wont cross or exceed out of range
489
+ * used in weekly charts
490
+ */
353
491
  maxValue = maxValue * this.chartConfiguration.customYscale;
354
492
  }
355
493
  if (this.chartData.targetLineData &&
@@ -359,16 +497,26 @@ export class GroupChartComponent extends ComponentUniqueId {
359
497
  ? this.chartData.targetLineData.target + 3
360
498
  : this.chartData.targetLineData.target + 20;
361
499
  }
362
- yScale.domain([0, maxValue]).nice();
363
- let xAxis = d3
364
- .axisBottom(xScale)
365
- .tickSize(0)
366
- .tickFormat(self.chartConfiguration.xAxisLabelFomatter);
367
- let yAxis = d3
368
- .axisLeft(yScale)
369
- .ticks(self.chartConfiguration.numberOfYTicks)
370
- .tickSize(0)
371
- .tickFormat(self.chartConfiguration.yAxisLabelFomatter);
500
+ y.domain([0, maxValue]).nice();
501
+ let lineYscale;
502
+ if (lineData != null) {
503
+ let maxLineValue = d3.max(lineData, function (d) {
504
+ return +d.value;
505
+ });
506
+ maxLineValue = maxLineValue * this.chartConfiguration.customYscale;
507
+ let minLineValue = d3.min(lineData, function (d) {
508
+ return +d.value;
509
+ });
510
+ if (maxLineValue > 0)
511
+ minLineValue = minLineValue - 3;
512
+ if (minLineValue > 0) {
513
+ minLineValue = 0;
514
+ }
515
+ lineYscale = d3
516
+ .scaleLinear()
517
+ .domain([minLineValue, maxLineValue])
518
+ .range([height, minLineValue]);
519
+ }
372
520
  let yLineAxis;
373
521
  if (lineYscale != null) {
374
522
  yLineAxis = d3
@@ -378,634 +526,565 @@ export class GroupChartComponent extends ComponentUniqueId {
378
526
  .tickFormat(self.chartConfiguration.yLineAxisLabelFomatter);
379
527
  }
380
528
  /**
381
- * between x-axis label used by weekly charts
382
- * isXgridBetweenLabels will be undefined for dashboard charts
529
+ * show x-axis grid between labels
530
+ * used by weekly charts
383
531
  */
384
532
  if (self.chartConfiguration.isXgridBetweenLabels) {
385
533
  svg
386
534
  .append('g')
387
535
  .attr('class', 'grid')
388
- .attr('transform', 'translate(' + xScale.bandwidth() / 2 + ',' + height + ')')
389
- .call(d3.axisBottom(xScale).tickSize(-height).tickFormat(''))
536
+ .attr('transform', 'translate(' + x.bandwidth() / 2 + ',' + height + ')')
537
+ .call(d3.axisBottom(x).tickSize(-height).tickFormat(''))
390
538
  .style('stroke-dasharray', '5 5')
391
- .style('color', '#999999')
392
- // .style("opacity", "0.5")
539
+ .style('color', 'var(--chart-grid-color, #999999)') // Use CSS variable
393
540
  .call((g) => g.select('.domain').remove());
394
541
  }
395
- /**
396
- * used to draw y-axis grid
397
- */
398
- if (self.chartConfiguration.yAxisGrid) {
542
+ if (this.chartConfiguration.yAxisGrid) {
399
543
  svg
400
544
  .append('g')
401
- .attr('class', 'grid')
402
545
  .call(d3
403
- .axisLeft(yScale)
546
+ .axisLeft(y)
404
547
  .ticks(self.chartConfiguration.numberOfYTicks)
405
- .tickSize(-width)
406
- .tickFormat(''))
407
- // Remove hardcoded colors and use CSS variables
408
- .style('color', 'var(--chart-grid-color)')
548
+ .tickSize(-width))
549
+ .style('color', 'var(--chart-axis-color, #B9B9B9)')
409
550
  .style('opacity', '0.5')
410
- .call((g) => g.select('.domain').remove());
551
+ .call((g) => {
552
+ g.select('.domain')
553
+ .remove()
554
+ .style('stroke', 'var(--chart-domain-color, #000000)'); // Add CSS variable for domain
555
+ });
556
+ }
557
+ else {
558
+ svg
559
+ .append('g')
560
+ .call(d3.axisLeft(y).ticks(self.chartConfiguration.numberOfYTicks))
561
+ .style('color', 'var(--chart-axis-color, #B9B9B9)')
562
+ .style('opacity', '0.5')
563
+ .call((g) => {
564
+ g.select('.domain')
565
+ .style('stroke', 'var(--chart-domain-color, #000000)') // Add CSS variable for domain
566
+ .style('stroke-width', '1px'); // Ensure visibility
567
+ });
568
+ }
569
+ var xSubgroup = d3.scaleBand().domain(subgroups);
570
+ if (this.chartConfiguration.isMultiChartGridLine == undefined) {
571
+ xSubgroup.range([0, x.bandwidth()]);
572
+ }
573
+ else {
574
+ /**
575
+ * used to make grouped bars with lesser width as we are not using padding for width
576
+ * used by weekly charts
577
+ */
578
+ xSubgroup.range([0, x.bandwidth()]);
411
579
  }
412
- var layer = svg
413
- .selectAll('.layer')
414
- .data(layers)
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)
415
594
  .enter()
416
595
  .append('g')
417
- .attr('class', 'layer')
418
- .style('fill', function (d, i) {
419
- return metaData.colors[d.key];
596
+ .attr('transform', function (d) {
597
+ return 'translate(' + x(d.name) + ',0)';
420
598
  });
421
- var rect = layer
599
+ state
422
600
  .selectAll('rect')
423
601
  .data(function (d) {
424
- return d;
602
+ let newList = [];
603
+ subgroups.map(function (key) {
604
+ // if (key !== "group") {
605
+ let obj = { key: key, value: d[key], name: d.name };
606
+ newList.push(obj);
607
+ // }
608
+ });
609
+ return newList;
425
610
  })
426
- .enter();
427
- rect
611
+ .enter()
428
612
  .append('rect')
613
+ .attr('class', 'bars')
429
614
  .on('click', function (d) {
430
- if (!lineData || self.chartConfiguration.forComparison) {
615
+ if (d.key != 'Target') {
431
616
  if (!metaData.barWithoutClick ||
432
617
  !metaData.barWithoutClick.length ||
433
- !metaData.barWithoutClick.includes(d.data.name.toLowerCase()))
434
- self.handleClick(d.data.name);
618
+ (!metaData.barWithoutClick.includes(d?.name) &&
619
+ !metaData.barWithoutClick.includes(d?.key)))
620
+ // self.handleClick(d.data.name);
621
+ self.handleClick(d);
435
622
  }
436
623
  })
437
- .attr('y', function (d) {
438
- if (!isNaN(d[0]) && !isNaN(d[1])) {
439
- const actualHeight = yScale(d[0]) - yScale(d[1]);
440
- return actualHeight < 3 ? yScale(d[0]) - 3 : yScale(d[1]);
624
+ .attr('x', function (d) {
625
+ if (self.chartConfiguration.isDrilldownChart) {
626
+ data.map((indiv) => {
627
+ if (indiv.name == d.name) {
628
+ let keys = Object.keys(indiv).filter((temp, i) => i != 0);
629
+ tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);
630
+ if (x.bandwidth() > 100) {
631
+ if (self.chartData.data.length == 1) {
632
+ if (Object.keys(self.chartData.data[0]).length == 2) {
633
+ tempScale.range([
634
+ 0 + (x.bandwidth() - 125) / 2,
635
+ x.bandwidth() - (x.bandwidth() - 125) / 2,
636
+ ]);
637
+ // .padding(0.05);
638
+ }
639
+ else
640
+ tempScale.range([
641
+ 0 + (x.bandwidth() - 125) / 2,
642
+ x.bandwidth() - (x.bandwidth() - 125) / 2,
643
+ ]);
644
+ // .padding(0.05);
645
+ }
646
+ else
647
+ tempScale.range([
648
+ 0 + (x.bandwidth() - 125) / 2,
649
+ x.bandwidth() - (x.bandwidth() - 125) / 2,
650
+ ]);
651
+ }
652
+ }
653
+ });
654
+ return tempScale(d.key);
441
655
  }
442
- return 0;
656
+ return xSubgroup(d.key);
443
657
  })
444
- .attr('x', function (d, i) {
445
- if (isMobile) {
446
- // On mobile, position bars with padding
447
- return leftAndRightSpaces + i * (barWidth + barPadding);
448
- }
449
- if (self.chartConfiguration.isMultiChartGridLine == undefined) {
450
- return xScale(d.data.name);
451
- }
452
- else {
453
- if (self.chartConfiguration.isDrilldownChart &&
454
- self.chartData.data.length <= 3) {
455
- return xScale(d.data.name) + xScale.bandwidth() / 2 - 35;
456
- }
457
- return xScale(d.data.name) + xScale.bandwidth() * 0.1;
658
+ .attr('y', function (d) {
659
+ if (d.value == -1) {
660
+ return y(0);
458
661
  }
459
- })
460
- .attr('height', function (d) {
461
- if (!isNaN(d[0]) && !isNaN(d[1])) {
462
- const actualHeight = yScale(d[0]) - yScale(d[1]);
463
- return actualHeight < 3 ? 3 : actualHeight;
662
+ if (d.value >= 0) {
663
+ const barHeight = height - y(d.value);
664
+ const minHeight = self.chartConfiguration.defaultBarHeight || 2;
665
+ return barHeight < minHeight ? y(0) - minHeight : y(d.value);
464
666
  }
465
- return 0;
667
+ return y(0);
466
668
  })
467
669
  .attr('width', function (d) {
468
- // Use calculated barWidth for mobile, otherwise scale
469
- if (isMobile) {
470
- return barWidth;
670
+ if (self.chartConfiguration.isDrilldownChart) {
671
+ // var tempScale;
672
+ data.map((indiv) => {
673
+ if (indiv.name == d.name) {
674
+ let keys = Object.keys(indiv).filter((temp, i) => i != 0);
675
+ var temp;
676
+ tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);
677
+ if (x.bandwidth() > 100) {
678
+ if (self.chartData.data.length == 1) {
679
+ if (Object.keys(self.chartData.data[0]).length == 2) {
680
+ tempScale.range([
681
+ 0 + (x.bandwidth() - 125) / 2,
682
+ x.bandwidth() - (x.bandwidth() - 125) / 2,
683
+ ]);
684
+ // .padding(0.05);
685
+ }
686
+ else
687
+ tempScale.range([
688
+ 0 + (x.bandwidth() - 125) / 2,
689
+ x.bandwidth() - (x.bandwidth() - 125) / 2,
690
+ ]);
691
+ // .padding(0.05);
692
+ }
693
+ else
694
+ tempScale.range([
695
+ 0 + (x.bandwidth() - 125) / 2,
696
+ x.bandwidth() - (x.bandwidth() - 125) / 2,
697
+ ]);
698
+ }
699
+ }
700
+ });
701
+ return self.isZoomedOut
702
+ ? tempScale.bandwidth()
703
+ : self.chartData.data.length && self.chartData.data.length > 8
704
+ ? tempScale.bandwidth() * 0.5
705
+ : tempScale.bandwidth();
471
706
  }
472
- return self.chartConfiguration.isMultiChartGridLine == undefined
473
- ? xScale.bandwidth()
474
- : self.chartConfiguration.isDrilldownChart &&
475
- self.chartData.data.length <= 3
476
- ? 70
477
- : xScale.bandwidth() * 0.8;
707
+ return self.isZoomedOut
708
+ ? tempScale.bandwidth()
709
+ : self.chartData.data.length && self.chartData.data.length > 8
710
+ ? tempScale.bandwidth() * 0.5
711
+ : tempScale.bandwidth();
478
712
  })
479
- // .style('cursor', 'pointer');
480
- .style('cursor', function (d) {
481
- if (metaData.hasDrillDown) {
482
- if (metaData.barWithoutClick.length > 0 &&
483
- metaData.barWithoutClick.includes(d.data.name.toLowerCase())) {
484
- return 'default';
485
- }
486
- return 'pointer';
713
+ .attr('height', function (d) {
714
+ if (d.value == -1) {
715
+ return height - y(0);
487
716
  }
488
- else
489
- return 'default';
717
+ if (d.value >= 0) {
718
+ const barHeight = height - y(d.value);
719
+ const minHeight = self.chartConfiguration.defaultBarHeight || 2;
720
+ return Math.max(barHeight, minHeight);
721
+ }
722
+ return height - y(0);
490
723
  })
491
- .style('fill', function (d) {
492
- if (!isNaN(d[0]) &&
493
- !isNaN(d[1]) &&
724
+ .style('cursor', () => self.chartData.metaData.hasDrillDown ? 'pointer' : 'default')
725
+ .attr('fill', function (d) {
726
+ if (d.value &&
494
727
  self.chartData.targetLineData &&
495
- parseFloat(d[1]) - parseFloat(d[0]) >=
496
- parseFloat(self.chartData.targetLineData.target))
497
- return self.chartData?.targetLineData?.barAboveTargetColor;
498
- return metaData.colors[d.key];
728
+ d.value >= parseInt(self.chartData.targetLineData.target) &&
729
+ self.chartData.metaData.colorAboveTarget)
730
+ return self.chartData.metaData.colorAboveTarget[d.key];
731
+ return self.chartData.metaData.colors[d.key];
499
732
  });
500
733
  /**
501
- * do not show valus on hover as its alreay dislayed
734
+ * display angled texts on the bars
502
735
  */
503
- if (!this.isCC && !self.chartConfiguration.isMultiChartGridLine) {
504
- rect
505
- .append('svg:title') // TITLE APPENDED HERE
506
- .text(function (d) {
507
- return d[1] - d[0];
508
- });
509
- }
510
- if (this.isCC) {
511
- rect
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()
512
748
  .append('text')
749
+ .attr('fill', 'var(--chart-text-color)')
513
750
  .attr('x', function (d) {
514
- return xScale(d.data.name);
515
- })
516
- .attr('text-anchor', function (d) {
517
- if (!d[0]) {
518
- return 'end';
519
- }
520
- else {
521
- return 'start';
522
- }
751
+ return 0;
523
752
  })
524
- .attr('class', 'verticalbar__text')
525
753
  .attr('y', function (d) {
526
- if (!d[0]) {
527
- return yScale(d[1]);
528
- }
529
- else {
530
- return yScale(d[1]) - 7;
531
- }
532
- })
533
- // .attr("y", function (d) { return yScale(d[0]) - yScale(d[1]); })
534
- .attr('dy', function (d) {
535
- return d.class;
754
+ return 0;
536
755
  })
756
+ .attr('class', 'lib-data-labels-weeklycharts')
537
757
  .text(function (d) {
538
- if (!d[0]) {
539
- if (!isNaN(d[1] - d[0])) {
540
- return Math.round((d[1] - d[0]) * 100) / 100;
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';
541
781
  }
542
- else
543
- return;
544
782
  }
545
783
  else {
546
- if (!isNaN(d[1])) {
547
- return Math.round(d[1] * 100) / 100;
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
+ }
548
815
  }
549
- else
550
- return;
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) + ')');
551
822
  }
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);
552
849
  });
850
+ state
851
+ .selectAll('.lib-data-labels-weeklycharts')
852
+ .on('mouseout', handleMouseOut)
853
+ .on('mouseover', handleMouseOver);
553
854
  }
554
- /**
555
- svg
556
- .append('foreignObject')
557
- .attr('transform', 'translate(' + 0 + ',' + (yZero - 25) + ')')
558
- .attr('width', width)
559
- .attr('height', 30)
560
- .append('xhtml:div')
561
- .attr('class', 'target-display')
562
- .style('color', this.chartData.targetLineData.color)
563
- */
564
- /**
565
- * on hover, display title on top
566
- */
567
- function handleMouseOver(d, i) {
568
- if (!self.chartConfiguration.displayTitleOnTop) {
569
- return;
570
- }
571
- svg
855
+ if (this.chartConfiguration.displayTitleOnTop) {
856
+ state
572
857
  .selectAll('rect')
573
- .filter(function (data) {
574
- return data == d;
575
- })
576
- .style('fill', function (d) {
577
- if (!isNaN(d[0]) &&
578
- !isNaN(d[1]) &&
579
- self.chartData.targetLineData &&
580
- parseFloat(d[1]) - parseFloat(d[0]) >=
581
- parseFloat(self.chartData.targetLineData.target))
582
- return self.chartData.targetLineData.barAboveTargetHoverColor
583
- ? self.chartData.targetLineData.barAboveTargetHoverColor
584
- : self.chartData?.targetLineData?.barAboveTargetColor
585
- ? self.chartData?.targetLineData?.barAboveTargetColor
586
- : '';
587
- return metaData.hoverColor ? metaData.hoverColor : '';
588
- });
858
+ .on('mouseout', handleMouseOut)
859
+ .on('mouseover', handleMouseOver);
860
+ }
861
+ function handleMouseOver(d, i) {
589
862
  svg
590
863
  .append('foreignObject')
591
864
  .attr('x', function () {
592
- if (xScale.bandwidth() + leftAndRightSpaces * 2 > 180) {
593
- return (xScale(d.data.name) -
594
- leftAndRightSpaces +
595
- (xScale.bandwidth() + leftAndRightSpaces * 2 - 180) / 2);
865
+ // ...existing code for tempScale calculation...
866
+ var elementsCounter;
867
+ data.map((indiv) => {
868
+ if (indiv.name == d.name) {
869
+ let keys = Object.keys(indiv).filter((temp, i) => i != 0);
870
+ elementsCounter = keys.length;
871
+ tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);
872
+ if (x.bandwidth() > 100) {
873
+ if (self.chartData.data.length == 1) {
874
+ if (Object.keys(self.chartData.data[0]).length == 2) {
875
+ tempScale.range([
876
+ 0 + (x.bandwidth() - 200) / 2,
877
+ x.bandwidth() - (x.bandwidth() - 200) / 2,
878
+ ]);
879
+ }
880
+ else
881
+ tempScale.range([
882
+ 0 + (x.bandwidth() - 300) / 2,
883
+ x.bandwidth() - (x.bandwidth() - 300) / 2,
884
+ ]);
885
+ }
886
+ else
887
+ tempScale.range([
888
+ 0 + (x.bandwidth() - 125) / 2,
889
+ x.bandwidth() - (x.bandwidth() - 125) / 2,
890
+ ]);
891
+ }
892
+ }
893
+ });
894
+ if (metaData.hasDrillDown) {
895
+ if (tempScale.bandwidth() + leftAndRightSpaces * 2 > 180) {
896
+ return (x(d.name) + tempScale(d.key) + tempScale.bandwidth() / 2 - 90);
897
+ }
898
+ return (x(d.name) +
899
+ tempScale(d.key) -
900
+ (tempScale.bandwidth() + leftAndRightSpaces * 2) / 2 +
901
+ tempScale.bandwidth() / 2);
596
902
  }
597
- return xScale(d.data.name) - leftAndRightSpaces;
903
+ else
904
+ return x(d.name) + tempScale(d.key) - (tempScale.bandwidth() + leftAndRightSpaces * 2) / 2 + tempScale.bandwidth() / 2;
598
905
  })
599
906
  .attr('class', 'lib-verticalstack-title-ontop')
600
907
  .attr('y', function () {
601
- // Increase the gap between the bar and the tooltip (was -1 - 40)
602
- return yScale(d[1]) - 1 - 50; // 10px more gap
908
+ return y(d.value) - 3 - 40 - 10;
603
909
  })
604
910
  .attr('dy', function () {
605
911
  return d.class;
606
912
  })
607
913
  .attr('width', function () {
608
- if (xScale.bandwidth() + leftAndRightSpaces * 2 > 180) {
609
- return '180px';
914
+ data.map((indiv) => {
915
+ if (indiv.name == d.name) {
916
+ let keys = Object.keys(indiv).filter((temp, i) => i != 0);
917
+ tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);
918
+ if (x.bandwidth() > 100) {
919
+ if (self.chartData.data.length == 1) {
920
+ if (Object.keys(self.chartData.data[0]).length == 2) {
921
+ tempScale.range([
922
+ 0 + (x.bandwidth() - 200) / 2,
923
+ x.bandwidth() - (x.bandwidth() - 200) / 2,
924
+ ]);
925
+ }
926
+ else
927
+ tempScale.range([
928
+ 0 + (x.bandwidth() - 300) / 2,
929
+ x.bandwidth() - (x.bandwidth() - 300) / 2,
930
+ ]);
931
+ }
932
+ else
933
+ tempScale.range([
934
+ 0 + (x.bandwidth() - 125) / 2,
935
+ x.bandwidth() - (x.bandwidth() - 125) / 2,
936
+ ]);
937
+ }
938
+ }
939
+ });
940
+ if (metaData.hasDrillDown) {
941
+ if (tempScale.bandwidth() + leftAndRightSpaces * 2 > 180) {
942
+ return '180px';
943
+ }
944
+ return tempScale.bandwidth() + leftAndRightSpaces * 2;
610
945
  }
611
- return xScale.bandwidth() + leftAndRightSpaces * 2;
946
+ else
947
+ return tempScale.bandwidth() + leftAndRightSpaces * 2;
612
948
  })
613
949
  .attr('height', 40)
614
950
  .append('xhtml:div')
615
951
  .attr('class', 'title')
616
952
  .style('z-index', 99)
617
953
  .html(function () {
618
- // Tooltip content without any arrow mark
619
- if (!isNaN(d[1] - d[0])) {
620
- if (d[1] - d[0] === 0) {
621
- return '<span class="title-top-text">0</span>';
622
- }
623
- var dataType = metaData.dataType ? metaData.dataType : '';
624
- var desiredText = '';
625
- // Always show the full x-axis label (category name) in the tooltip
626
- desiredText =
627
- '<span class="title-bar-name">' +
628
- (d.data.name ? d.data.name : '') +
629
- '</span>';
630
- desiredText += metaData.unit
631
- ? '<span class="title-top-text">' +
632
- metaData.unit +
633
- (d[1] - d[0]) +
634
- dataType +
635
- '</span>'
636
- : '<span class="title-top-text">' +
637
- (d[1] - d[0]) +
638
- dataType +
639
- '</span>';
640
- // No arrow mark or arrow HTML/CSS in tooltip
641
- return desiredText;
642
- }
643
- else
644
- return;
954
+ // Show the x-axis label (bar name) for this bar, not the date or any other value
955
+ let barLabel = d.name; // This is the x-axis label for the bar
956
+ let dataType = metaData.dataType ? metaData.dataType : '';
957
+ let value = d.value;
958
+ let key = d.key;
959
+ // Tooltip: show x-axis label and value, but do not show date
960
+ let desiredText = '<span class="title-bar-name">' + barLabel + '</span>';
961
+ desiredText +=
962
+ '<span class="title-bar-value"><span>' +
963
+ value +
964
+ '</span>' +
965
+ dataType +
966
+ '</span>';
967
+ return desiredText;
645
968
  });
646
969
  }
647
970
  function handleMouseOut(d, i) {
648
971
  if (!self.chartConfiguration.displayTitleOnTop) {
649
972
  return;
650
973
  }
651
- // svg.selectAll('rect').style('fill', metaData.colors[d.key]);
652
- svg.selectAll('rect').style('fill', function (d) {
653
- if (!isNaN(d[0]) &&
654
- !isNaN(d[1]) &&
655
- self.chartData.targetLineData &&
656
- parseFloat(d[1]) - parseFloat(d[0]) >=
657
- parseFloat(self.chartData.targetLineData.target))
658
- return self.chartData?.targetLineData?.barAboveTargetColor;
659
- return metaData.colors[d.key];
660
- });
661
974
  svg.selectAll('.lib-verticalstack-title-ontop').remove();
662
975
  }
663
976
  /**
664
- * used to show value on top of the bars
665
- * need to be used by bar charts only(one bar should contain one value)
666
- * used by weekly charts
977
+ * display data values on mouse over
978
+ * used by dashboard charts
667
979
  */
668
- if (this.chartConfiguration.showTotalOnTop != undefined) {
669
- rect
670
- .append('text')
671
- .attr('x', function (d) {
672
- return xScale(d.data.name) + xScale.bandwidth() / 2;
673
- })
674
- .attr('class', 'lib-verticalstack-labels-ontop-weklycharts')
675
- .attr('y', function (d) {
676
- return yScale(d[1]) - 3;
677
- })
678
- .attr('dy', function (d) {
679
- return d.class;
680
- })
681
- .text(function (d) {
682
- if (!isNaN(d[1] - d[0])) {
683
- if (d[1] - d[0] == 0) {
684
- return;
685
- }
686
- if (d[1] - d[0] <= 999)
687
- return metaData.unit
688
- ? metaData.unit + formatFromBackend(d[1] - d[0])
689
- : formatFromBackend(d[1] - d[0]);
690
- else
691
- return metaData.unit
692
- ? metaData.unit + formatForHugeNumbers(d[1] - d[0])
693
- : formatForHugeNumbers(d[1] - d[0]);
694
- }
695
- else
696
- return;
697
- });
698
- }
699
- /**
700
- * used to show angled values on top of the bars
701
- * used by weekly charts
702
- */
703
- if (this.chartConfiguration.showAngledLabels != undefined) {
704
- rect
705
- .append('text')
706
- .attr('x', 0)
707
- .attr('fill', function (d, i) {
708
- return metaData.colors[d.key];
709
- })
710
- .attr('class', 'lib-data-labels-angled-weeklycharts')
711
- .attr('y', 0)
712
- .attr('dy', function (d) {
713
- return d.class;
714
- })
715
- .text(function (d) {
716
- if (!isNaN(d[1] - d[0]) && d[1] - d[0] > 0) {
717
- if (d[1] - d[0] <= 999)
718
- return metaData.unit
719
- ? metaData.unit + formatFromBackend(d[1] - d[0])
720
- : formatFromBackend(d[1] - d[0]);
721
- else
722
- return metaData.unit + formatForHugeNumbers(d[1] - d[0]);
723
- }
724
- else
725
- return;
980
+ if (this.chartConfiguration.textsOnBar == undefined &&
981
+ this.chartConfiguration.displayTitleOnTop == undefined) {
982
+ state
983
+ .selectAll('rect')
984
+ .on('mouseout', function (d) {
985
+ state.selectAll('.barstext').remove();
726
986
  })
727
- .attr('transform', function (d) {
728
- if (!isNaN(d[1] - d[0]) && d[1] - d[0] > 0) {
729
- var total = 0;
730
- var incrementer = 1;
731
- metaData.keyList.forEach((key) => {
732
- if (d.data[key])
733
- total = total + d.data[key];
734
- else
735
- incrementer = 2;
736
- });
737
- if (tempObjectHolder[d.data.name] == undefined) {
738
- tempObjectHolder[d.data.name] = 1;
739
- }
740
- else {
741
- tempObjectHolder[d.data.name] =
742
- tempObjectHolder[d.data.name] + incrementer;
743
- }
744
- switch (tempObjectHolder[d.data.name]) {
745
- case 1:
746
- return ('translate(' +
747
- (xScale(d.data.name) + xScale.bandwidth() / 3) +
748
- ',' +
749
- (yScale(total) - 3) +
750
- ') rotate(270)');
751
- case 2:
752
- return ('translate(' +
753
- (xScale(d.data.name) + xScale.bandwidth() / 2 + 2) +
754
- ',' +
755
- (yScale(total) - 3) +
756
- ') rotate(270)');
757
- default:
758
- return ('translate(' +
759
- (xScale(d.data.name) + (xScale.bandwidth() * 3) / 4) +
760
- ',' +
761
- (yScale(total) - 3) +
762
- ') rotate(270)');
763
- }
764
- }
765
- return 'rotate(0)';
766
- });
767
- }
768
- if (this.chartConfiguration.isMultiChartGridLine == undefined) {
769
- if (isMobile) {
770
- // Custom x-axis label rendering for mobile: evenly distribute under each bar
771
- svg.selectAll('.custom-x-label').remove();
772
- data.forEach(function (d, i) {
773
- const xVal = leftAndRightSpaces + i * (barWidth + barPadding) + barWidth / 2;
774
- svg.append('text')
775
- .attr('class', 'custom-x-label')
776
- .attr('x', 0)
777
- .attr('y', height + 18)
778
- .attr('text-anchor', 'middle')
779
- .attr('transform', 'translate(' + (xVal + 20) + ',0)') // current value + 20
780
- .style('font-size', '10px')
781
- .style('fill', 'var(--chart-text-color)')
782
- .style('writing-mode', 'sideways-lr') // writing mode for mobile
783
- .text(d.name.substring(0, 3));
784
- });
785
- }
786
- else {
787
- svg
788
- .append('g')
789
- .attr('transform', 'translate(0,' + height + ')')
790
- .attr('class', 'lib-stacked-x-axis-text')
791
- .call(xAxis)
987
+ .on('mouseover', function (d1) {
988
+ state
792
989
  .selectAll('text')
793
- .style('fill', 'var(--chart-text-color)')
794
- .style('font-size', '12px')
795
- .attr('text-anchor', 'middle')
796
- .attr('dx', '0')
797
- .attr('dy', '0.71em')
798
- .attr('transform', null)
990
+ .data(function (d) {
991
+ let newList = [];
992
+ subgroups.map(function (key) {
993
+ if (key !== 'name' &&
994
+ d1.key == key &&
995
+ d1.value == d[key] &&
996
+ d1.name == d.name) {
997
+ let obj = { key: key, value: d[key], name: d.name };
998
+ newList.push(obj);
999
+ }
1000
+ });
1001
+ return newList;
1002
+ })
1003
+ .enter()
1004
+ .append('text')
1005
+ .attr('fill', 'var(--chart-text-color)')
1006
+ .attr('class', 'barstext')
1007
+ .attr('x', function (d) {
1008
+ return xSubgroup(d.key);
1009
+ })
1010
+ .attr('y', function (d) {
1011
+ return y(d.value);
1012
+ })
1013
+ .attr('style', 'font-size: ' + '.85em' + ';' + ' font-weight:' + 'bold' + ';')
1014
+ .style('fill', function (d) {
1015
+ return metaData.colors[d.key];
1016
+ })
1017
+ .attr('width', self.isZoomedOut ? xSubgroup.bandwidth() : xSubgroup.bandwidth())
799
1018
  .text(function (d) {
800
- return d;
1019
+ return d.value;
801
1020
  });
802
- }
803
- svg
804
- .append('g')
805
- .attr('class', 'lib-stacked-y-axis-text')
806
- .attr('style', self.chartConfiguration.yAxisCustomTextStyles)
807
- .attr('transform', 'translate(0,0)')
808
- .call(yAxis)
809
- .selectAll('text')
810
- .style('fill', 'var(--chart-text-color)');
811
- }
812
- else if (this.chartConfiguration.isDrilldownChart) {
813
- svg
814
- .append('g')
815
- .attr('transform', 'translate(0,' + height + ')')
816
- .attr('class', 'lib-stacked-x-axis-text multichart1')
817
- .call(xAxis)
818
- .style('display', 'none');
819
- svgYAxisLeft
820
- .append('g')
821
- .attr('class', 'lib-yaxis-labels-texts-drilldown yaxis-dashed')
822
- .attr('style', self.chartConfiguration.yAxisCustomTextStyles)
823
- .attr('transform', 'translate(0,0)')
824
- .call(yAxis)
825
- .selectAll('text')
826
- .style('fill', 'var(--chart-text-color)');
827
- svgYAxisRight
828
- .append('g')
829
- .attr('class', 'lib-yaxis-labels-texts-drilldown yaxis-dashed')
830
- .attr('style', self.chartConfiguration.yAxisCustomTextStyles)
831
- .attr('transform', 'translate(0,0)')
832
- .call(yAxis)
833
- .style('display', 'none');
834
- }
835
- else {
836
- svg
837
- .append('g')
838
- .attr('transform', 'translate(0,' + height + ')')
839
- .attr('class', 'lib-stacked-x-axis-text multichart')
840
- .attr('transform', 'translate(0,' + height + ')')
841
- .call(xAxis)
842
- .selectAll('text')
843
- .style('fill', 'var(--chart-text-color)');
844
- svg
845
- .append('g')
846
- .attr('class', 'lib-stacked-y-axis-text yaxis-dashed')
847
- .attr('style', self.chartConfiguration.yAxisCustomTextStyles)
848
- .attr('transform', 'translate(0,0)')
849
- .call(yAxis)
850
- .selectAll('text')
851
- .style('fill', 'var(--chart-text-color)');
852
- }
853
- /**
854
- * for existing charts, place xaxis labels nearer to xaxis
855
- * used by existing charts
856
- */
857
- if (this.chartConfiguration.isMultiChartGridLine == undefined) {
858
- d3.selectAll('g.lib-stacked-x-axis-text g.tick text').attr('y', function () {
859
- if (alternate_text) {
860
- alternate_text = false;
861
- return long_tick_length + 1;
862
- }
863
- else {
864
- alternate_text = true;
865
- return short_tick_length + 1;
866
- }
867
1021
  });
868
1022
  }
869
- else {
870
- d3.selectAll('.multichart > g > text').attr('class', 'lib-display-hidden');
871
- }
1023
+ svg
1024
+ .append('g')
1025
+ .attr('class', 'x2 axis2')
1026
+ .attr('transform', 'translate(0,' + height + ')')
1027
+ .style('color', 'var(--chart-axis-color, #000)') // Use CSS variable instead of hardcoded #000
1028
+ .call(d3.axisBottom(xScaleFromOrigin).tickSize(0))
1029
+ .call((g) => g.select('.domain').attr('fill', 'none'));
1030
+ svg.selectAll('g.x2.axis2 g.tick text').style('display', 'none');
1031
+ svg
1032
+ .append('g')
1033
+ .attr('class', 'lib-stacked-y-axis-text yaxis-dashed')
1034
+ .attr('style', self.chartConfiguration.yAxisCustomTextStyles)
1035
+ .attr('transform', 'translate(0,0)')
1036
+ .call(y)
1037
+ .style('display', 'none');
1038
+ svgYAxisLeft
1039
+ .append('g')
1040
+ .append('g')
1041
+ .attr('class', 'lib-yaxis-labels-texts-drilldown yaxis-dashed')
1042
+ .attr('style', self.chartConfiguration.yAxisCustomTextStyles)
1043
+ .attr('transform', 'translate(0,0)')
1044
+ .call(d3
1045
+ .axisLeft(y)
1046
+ .tickSize(0)
1047
+ .ticks(self.chartConfiguration.numberOfYTicks)
1048
+ .tickFormat(function (d) {
1049
+ const formatted = self.chartConfiguration.yAxisLabelFomatter
1050
+ ? self.chartConfiguration.yAxisLabelFomatter(d)
1051
+ : d;
1052
+ return formatted >= 1000 ? formatted / 1000 + 'k' : formatted;
1053
+ }))
1054
+ .call((g) => {
1055
+ // Style the domain line for theme support
1056
+ g.select('.domain')
1057
+ .style('stroke', 'var(--chart-domain-color, #000000)')
1058
+ .style('stroke-width', '1px');
1059
+ })
1060
+ .selectAll('text')
1061
+ .style('fill', 'var(--chart-text-color)');
1062
+ svgYAxisRight
1063
+ .append('g')
1064
+ .attr('class', 'lib-yaxis-labels-texts-drilldown yaxis-dashed')
1065
+ .attr('style', self.chartConfiguration.yAxisCustomTextStyles)
1066
+ .attr('transform', 'translate(0,0)')
1067
+ .call(y)
1068
+ .style('display', 'none');
872
1069
  /**
873
- * based of the flag, hide or show xaxis texts
1070
+ * hide x axis labels
1071
+ * config is there for future use
874
1072
  * used by weekly charts
875
1073
  */
876
1074
  if (this.chartConfiguration.isXaxisLabelHidden != undefined &&
877
1075
  this.chartConfiguration.isXaxisLabelHidden) {
878
- d3.selectAll('.multichart > g > text').attr('class', 'lib-display-hidden');
879
- }
880
- else if (this.chartConfiguration.isXaxisLabelHidden != undefined) {
881
- svg
882
- .append('g')
883
- .attr('class', 'x1 axis1')
884
- .attr('transform', 'translate(0,' + height + ')')
885
- .style('color', '#000')
886
- .call(d3.axisBottom(xScale).tickSize(0))
887
- .call((g) => g.select('.domain').attr('fill', 'none'));
888
- svg
889
- .append('g')
890
- .attr('class', 'x2 axis2')
891
- .attr('transform', 'translate(0,' + height + ')')
892
- .style('color', '#000')
893
- .call(d3.axisBottom(xScaleFromOrigin).tickSize(0))
894
- .call((g) => g.select('.domain').attr('fill', 'none'));
895
- svg.selectAll('.axis2 > g > text').attr('class', 'lib-display-hidden');
896
- // svg.selectAll('g.x2.axis2 g.tick text').style('display', 'none');
897
- svg.selectAll('.x1.axis1 .tick line').attr('y2', function () {
898
- if (self.chartConfiguration.hideXaxisTick) {
899
- return 0;
900
- }
901
- /**
902
- * isNoAlternateXaxisText is used to prevent x-axis label to be displayed in alternate fashion
903
- * for future use
904
- */
905
- if (alternate_text &&
906
- self.chartConfiguration.isNoAlternateXaxisText == undefined) {
907
- alternate_text = false;
908
- return long_tick_length_bg - 7;
909
- }
910
- else {
911
- alternate_text = true;
912
- return short_tick_length_bg - 4;
913
- }
914
- });
915
- /**
916
- * reset the flag so that texts also follow the pattern of ticks
917
- * used by weekly charts
918
- */
919
- alternate_text = false;
920
- svg
921
- .selectAll('g.x1.axis1 g.tick text')
922
- // .attr('class', 'lib-xaxis-labels-texts-weeklycharts')
923
- .attr('class', function () {
924
- if (self.chartConfiguration.isDrilldownChart) {
925
- if (data && data.length > 8) {
926
- return 'lib-xaxis-labels-texts-drilldown-alt';
927
- }
928
- return 'lib-xaxis-labels-texts-drilldown';
929
- }
930
- else
931
- return 'lib-xaxis-labels-texts-weeklycharts';
932
- })
933
- .attr('y', function () {
934
- if (alternate_text) {
935
- alternate_text = false;
936
- return long_tick_length_bg;
937
- }
938
- else {
939
- alternate_text = true;
940
- return short_tick_length_bg;
941
- }
942
- });
943
- }
944
- if (self.chartConfiguration.xLabelsOnSameLine) {
945
- svg
946
- .selectAll('g.x1.axis1 g.tick text')
947
- .attr('class', 'lib-xaxis-labels-texts-drilldown')
948
- .attr('y', short_tick_length_bg)
949
- .text(function (d, i) {
950
- if (isMobile) {
951
- // If label has more than one word, show only first 3 letters of first word
952
- var firstWord = d.split(' ')[0];
953
- return firstWord.substring(0, 3);
954
- }
955
- if (d.trim().indexOf(' ') > -1) {
956
- return d.trim().substring(0, d.indexOf(' ')).toLowerCase();
957
- }
958
- return d.toLowerCase();
959
- })
960
- .attr('transform', function (d, i) {
961
- if (isMobile) {
962
- var totalBars = 0;
963
- if (this.parentNode && this.parentNode.parentNode) {
964
- totalBars = d3.select(this.parentNode.parentNode).selectAll('g.tick').size();
965
- }
966
- if (totalBars === 2) {
967
- return 'translate(0,0)';
968
- }
969
- else {
970
- return 'translate(' + (i * 30) + ',0)';
971
- }
972
- }
973
- return null;
974
- });
975
- svg
976
- .selectAll('g.x1.axis1 g.tick')
977
- .append('text')
978
- .attr('class', 'lib-xaxis-labels-texts-drilldown')
979
- .attr('y', long_tick_length_bg)
980
- .attr('fill', 'currentColor')
981
- .text(function (d) {
982
- // For mobile, do not print the second word at all
983
- if (isMobile) {
984
- return '';
985
- }
986
- if (d.trim().indexOf(' ') > -1) {
987
- return d.trim().substring(d.indexOf(' '), d.length).toLowerCase();
988
- }
989
- return '';
990
- })
991
- .attr('transform', function (d, i) {
992
- if (isMobile && i === 0) {
993
- return 'translate(20,0)';
994
- }
995
- return null;
996
- });
1076
+ d3.selectAll('g.lib-line-x-axis-text > g > text').attr('class', 'lib-display-hidden');
997
1077
  }
998
1078
  /**
999
- * hide yaxis values
1079
+ * hide y axis labels
1000
1080
  * used by weekly charts
1001
1081
  */
1002
1082
  if (this.chartConfiguration.isYaxisLabelHidden != undefined &&
1003
1083
  this.chartConfiguration.isYaxisLabelHidden) {
1004
- svg
1005
- .selectAll('.yaxis-dashed > g > text')
1006
- .attr('class', 'lib-display-hidden');
1084
+ d3.selectAll('.yaxis-dashed > g > text').attr('class', 'lib-display-hidden');
1007
1085
  }
1008
- /** hide y axis labels
1086
+ /**
1087
+ * hide y axis labels
1009
1088
  * config is there for future use
1010
1089
  */
1011
1090
  if (this.chartConfiguration.isYaxisHidden != undefined &&
@@ -1020,69 +1099,86 @@ export class GroupChartComponent extends ComponentUniqueId {
1020
1099
  this.chartConfiguration.isYaxisDashed) {
1021
1100
  d3.selectAll('.yaxis-dashed')
1022
1101
  .style('stroke-dasharray', '5 5')
1023
- .style('color', 'var(--chart-grid-color)'); // Use CSS variable
1102
+ .style('color', 'var(--chart-axis-color, #999999)'); // Use CSS variable
1024
1103
  }
1025
- /**
1026
- * x axis color
1027
- * used by weekly charts
1028
- */
1029
- if (this.chartConfiguration.isXaxisColor != undefined) {
1030
- d3.selectAll('.multichart').style('color', this.chartConfiguration.isXaxisColor || 'var(--chart-text-color)');
1104
+ if (lineData != null) {
1105
+ if (lineData && self.chartConfiguration.showLineChartAxis) {
1106
+ svgYAxisRight
1107
+ .append('g')
1108
+ .attr('class', 'lib-stacked-y-axis-text1')
1109
+ .attr('style', self.chartConfiguration.yAxisCustomTextStyles)
1110
+ .attr('transform', 'translate(' + 0 + ',0)')
1111
+ .call(yLineAxis);
1112
+ }
1031
1113
  }
1032
1114
  /**
1033
1115
  * used to display y label
1034
1116
  */
1117
+ // if (this.isZoomedOut) {
1118
+ // svg
1119
+ // .selectAll('.lib-xaxis-labels-texts-drilldown')
1120
+ // .attr('class', 'lib-display-hidden');
1121
+ // }
1035
1122
  if (this.isZoomedOut) {
1123
+ // svg
1124
+ // .selectAll('.lib-xaxis-labels-texts-drilldown')
1125
+ // .attr('transform', 'rotate(-30)')
1126
+ // .attr('text-anchor', 'end')
1127
+ // .attr('x', '-5')
1128
+ // .attr('dy', null)
1129
+ // .style('fill', 'var(--chart-text-color)');
1036
1130
  svg
1037
1131
  .selectAll('.lib-xaxis-labels-texts-drilldown')
1038
- .attr('transform', 'rotate(-90)')
1039
- .attr('text-anchor', 'end')
1040
- .attr('x', '-5')
1041
- .attr('dy', null);
1042
- }
1043
- function styleAxisDomain() {
1044
- svg.selectAll('.domain')
1045
- .style('stroke', 'var(--chart-axis-color)')
1046
- .style('stroke-width', '1px');
1047
- svgYAxisLeft.selectAll('.domain')
1048
- .style('stroke', 'var(--chart-axis-color)')
1049
- .style('stroke-width', '1px');
1050
- svgYAxisRight.selectAll('.domain')
1051
- .style('stroke', 'var(--chart-axis-color)')
1052
- .style('stroke-width', '1px');
1132
+ .each((d, i, nodes) => {
1133
+ const text = d3.select(nodes[i]);
1134
+ const label = text.text();
1135
+ const words = label.split(' ');
1136
+ text.text(null); // Clear current text
1137
+ // Add each word to a new tspan
1138
+ words.forEach((word, index) => {
1139
+ text.append('tspan').text(word);
1140
+ // .attr('x', '15')
1141
+ // .attr('dy', index === 0 ? '0em' : '0.9em') // Reduced vertical spacing
1142
+ // .attr('text-anchor', 'end');
1143
+ });
1144
+ })
1145
+ .style('fill', 'var(--chart-text-color)')
1146
+ .attr('transform', null); // Remove rotate if using line breaks
1147
+ // Optional: Adjust bottom margin or chart layout
1148
+ svg
1149
+ .select('.x-axis')
1150
+ .attr('transform', `translate(0, ${height - margin.bottom + 10})`);
1053
1151
  }
1054
- styleAxisDomain();
1152
+ /**
1153
+ * used to write y labels based on configuration
1154
+ */
1055
1155
  if (metaData.yLabel) {
1056
- svgYAxisLeft.selectAll('.lib-axis-group-label, .lib-ylabel-drilldowncharts, .lib-ylabel-weeklyCharts').remove();
1057
- function isAcronym(label) {
1058
- return (label.length <= 4 && /^[A-Z]+$/.test(label)) || (label === label.toUpperCase() && /[A-Z]/.test(label));
1059
- }
1060
- const yLabelText = metaData.yLabel;
1061
- const isAcr = isAcronym(yLabelText.replace(/[^A-Za-z]/g, ''));
1062
1156
  const yPosition = isria ? 0 - margin.left / 2 - 30 : 0 - margin.left / 2 - 40;
1063
1157
  svgYAxisLeft
1064
1158
  .append('text')
1065
- .attr('class', function () {
1066
- let baseClass = 'lib-axis-group-label font-size-1';
1067
- if (self.chartConfiguration.isDrilldownChart)
1068
- return baseClass + ' lib-ylabel-drilldowncharts';
1069
- if (self.chartConfiguration.isMultiChartGridLine != undefined)
1070
- return baseClass + ' lib-ylabel-weeklyCharts';
1071
- return baseClass + ' lib-axis-waterfall-label';
1072
- })
1159
+ .attr('class', 'lib-axis-group-label font-size-1')
1073
1160
  .attr('style', self.chartConfiguration.yAxisCustomlabelStyles)
1074
1161
  .attr('transform', 'rotate(-90)')
1075
1162
  .attr('y', yPosition)
1076
1163
  .attr('x', 0 - height / 2)
1077
1164
  .attr('dy', '1em')
1078
1165
  .style('text-anchor', 'middle')
1079
- .style('fill', 'var(--chart-text-color)')
1080
- .style('color', 'var(--chart-text-color)')
1081
- .text(isAcr ? yLabelText.toUpperCase() : yLabelText.toLowerCase())
1082
- .style('text-transform', isAcr ? 'none' : 'capitalize');
1166
+ .attr('fill', 'var(--chart-text-color)');
1167
+ if (this.chartConfiguration.isMultiChartGridLine === undefined) {
1168
+ svgYAxisLeft
1169
+ .selectAll('.lib-axis-group-label')
1170
+ .style('font-size', 'smaller')
1171
+ .text(metaData.yLabel);
1172
+ }
1173
+ else {
1174
+ svg
1175
+ .selectAll('.lib-axis-group-label')
1176
+ .attr('class', 'lib-ylabel-weeklyCharts')
1177
+ .text(metaData.yLabel.toLowerCase());
1178
+ }
1083
1179
  }
1084
1180
  if (this.chartData.targetLineData) {
1085
- const yZero = yScale(parsedNum);
1181
+ const yZero = y(this.chartData.targetLineData.target);
1086
1182
  svg
1087
1183
  .append('line')
1088
1184
  .attr('x1', 0)
@@ -1106,7 +1202,7 @@ export class GroupChartComponent extends ComponentUniqueId {
1106
1202
  .append('xhtml:div')
1107
1203
  .attr('class', 'target-display')
1108
1204
  .style('color', 'var(--chart-text-color)')
1109
- .html(function (d, i) {
1205
+ .html(function () {
1110
1206
  let dataTypeTemp = '';
1111
1207
  let targetLineName = 'target';
1112
1208
  if (metaData.dataType) {
@@ -1124,21 +1220,15 @@ export class GroupChartComponent extends ComponentUniqueId {
1124
1220
  '</div>');
1125
1221
  });
1126
1222
  }
1127
- rect
1128
- .selectAll('rect')
1129
- .on('mouseenter', handleMouseOver)
1130
- .on('mouseout', handleMouseOut);
1131
- if (metaData.lineyLabel) {
1132
- svg
1133
- .append('text')
1134
- .attr('class', 'lib-axis-group-label lib-line-axis')
1135
- .attr('style', self.chartConfiguration.yAxisCustomlabelStyles)
1136
- .attr('transform', 'translate(' + (width - 20) + ',0) rotate(90)')
1137
- .attr('y', 0 - margin.right * 3)
1138
- .attr('x', height / 2)
1139
- .attr('dy', '5em')
1140
- .style('text-anchor', 'middle')
1141
- .text(metaData.lineyLabel);
1223
+ if (this.chartConfiguration.isDrilldownChart) {
1224
+ /**
1225
+ * used by drilldown charts
1226
+ */
1227
+ // svg
1228
+ // .selectAll('.lib-axis-group-label')
1229
+ // .attr('class', 'lib-ylabel-drilldowncharts')
1230
+ // .text(metaData.yLabel.toLowerCase());
1231
+ svg.selectAll('g.x1.axis1 g.tick line').style('display', 'none');
1142
1232
  }
1143
1233
  if (metaData.xLabel) {
1144
1234
  function isAcronym(label) {
@@ -1165,109 +1255,105 @@ export class GroupChartComponent extends ComponentUniqueId {
1165
1255
  .text(isAcr ? xLabelText.toUpperCase() : xLabelText.toLowerCase())
1166
1256
  .style('text-transform', isAcr ? 'none' : 'capitalize');
1167
1257
  }
1168
- if (lineData && colors) {
1169
- var dataGroup = d3
1170
- .nest()
1171
- .key(function (d) {
1172
- return d.category;
1173
- })
1174
- .entries(lineData);
1175
- var lineGen = d3
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('d', d3
1176
1280
  .line()
1177
1281
  .x(function (d) {
1178
- return xScale(d.name) + xScale.bandwidth() / 2;
1282
+ return x(d.name) + x.bandwidth() / 2;
1179
1283
  })
1180
1284
  .y(function (d) {
1181
1285
  return lineYscale(d.value);
1286
+ }));
1287
+ var dot = svg
1288
+ .selectAll('myCircles')
1289
+ .data(lineData)
1290
+ .enter()
1291
+ .append('g')
1292
+ .on('click', function (d) {
1293
+ if (!metaData.barWithoutClick ||
1294
+ !metaData.barWithoutClick.length ||
1295
+ (!metaData.barWithoutClick.includes(d?.name) &&
1296
+ !metaData.barWithoutClick.includes(d?.key)))
1297
+ self.handleClick(d);
1182
1298
  });
1183
- var calculateCX = (d) => {
1184
- return xScale(d.name) + xScale.bandwidth() / 2;
1185
- };
1186
- var calculateCY = (d) => {
1299
+ dot
1300
+ .append('circle')
1301
+ .attr('fill', function (d) {
1302
+ return self.chartConfiguration.lineGraphColor;
1303
+ })
1304
+ .attr('stroke', 'none')
1305
+ .attr('cx', function (d) {
1306
+ return x(d.name) + x.bandwidth() / 2;
1307
+ })
1308
+ .attr('cy', function (d) {
1187
1309
  return lineYscale(d.value);
1188
- };
1189
- dataGroup.forEach(function (d, i) {
1190
- svg
1191
- .append('path')
1192
- .datum(d.values)
1193
- .attr('fill', 'none')
1194
- .attr('stroke', function (d) {
1195
- if ('category' in d[0]) {
1196
- return colors[d[0].category];
1197
- }
1198
- else {
1199
- return self.chartConfiguration.lineGraphColor;
1200
- }
1201
- })
1202
- .attr('stroke-width', 2.5) /**line thinkness */
1203
- .attr('d', lineGen(d.values));
1204
- var dot = svg
1205
- .selectAll('myCircles')
1206
- .data(d.values)
1207
- .enter()
1208
- .append('g')
1209
- .on('click', function (d) {
1210
- self.handleClick(d);
1211
- });
1310
+ })
1311
+ .style('cursor', () => self.chartData.metaData.hasDrillDown ? 'pointer' : 'default')
1312
+ .attr('r', 3);
1313
+ if (self.chartConfiguration.lineGraphColor) {
1212
1314
  dot
1213
- .append('circle')
1214
- .attr('fill', function (d) {
1215
- if ('category' in d) {
1216
- return colors[d.category];
1217
- }
1218
- else {
1219
- return self.chartConfiguration.lineGraphColor;
1220
- }
1315
+ .append('text')
1316
+ .attr('class', 'dot')
1317
+ .attr('fill', 'var(--chart-text-color)')
1318
+ .attr('color', self.chartConfiguration.lineGraphColor)
1319
+ .attr('style', 'font-size: ' + '.85em')
1320
+ .attr('x', function (d, i) {
1321
+ return x(d.name) + x.bandwidth() / 2;
1221
1322
  })
1222
- .attr('stroke', 'none')
1223
- .attr('cx', function (d, i) {
1224
- return xScale(d.name) + xScale.bandwidth() / 2;
1225
- })
1226
- .attr('cy', function (d, i) {
1323
+ .attr('y', function (d) {
1227
1324
  return lineYscale(d.value);
1228
1325
  })
1229
- .attr('r', 3) /**radius of circle=5 */
1230
- .style('cursor', 'pointer');
1231
- if (self.chartConfiguration.lineGraphColor) {
1232
- dot
1233
- .append('text')
1234
- .attr('class', 'dots')
1235
- .attr('fill', self.chartConfiguration.lineGraphColor)
1236
- .attr('style', 'font-size: ' + '.85em;' + 'font-weight:' + 'bold')
1237
- .attr('x', function (d, i) {
1238
- return xScale(d.name) + xScale.bandwidth() / 2;
1239
- })
1240
- .attr('y', function (d, i) {
1241
- return lineYscale(d.value);
1242
- })
1243
- .attr('dy', '-1em')
1244
- .text(function (d, i) {
1245
- return self.chartConfiguration.labelFormatter(d.value);
1246
- });
1247
- }
1248
- });
1326
+ .attr('dy', '-1em')
1327
+ .text(function (d) {
1328
+ return self.chartConfiguration.labelFormatter(d.value);
1329
+ });
1330
+ }
1249
1331
  }
1250
- // svg.attr('width', 150).style('max-width', 150).style('overflow-x', 'auto');
1251
1332
  }
1252
1333
  handleClick(d) {
1253
- if (this.chartData?.metaData?.hasDrillDown || d?.toggleFrom)
1334
+ if (this.chartData.metaData.hasDrillDown || d?.toggleFrom)
1254
1335
  this.clickEvent.emit(d);
1255
1336
  }
1256
1337
  handleHeaderMenuClick(id) {
1257
1338
  this.headerMenuclickEvent.emit(id);
1258
1339
  }
1340
+ handleDD1Click(event) {
1341
+ this.isDD1Open = true;
1342
+ this.isDD2Open = false;
1343
+ }
1344
+ handleDD2Click(event) {
1345
+ this.isDD2Open = true;
1346
+ this.isDD1Open = false;
1347
+ }
1259
1348
  handleCompareByFilterSelection(event) {
1260
1349
  this.clickEvent.emit(event);
1261
1350
  }
1262
- handleZoominZoomoutClick({ isZoomOut, event }) {
1263
- this.isZoomOutSelected(isZoomOut);
1264
- }
1265
1351
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: GroupChartComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
1266
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: GroupChartComponent, selector: "lib-group-chart", inputs: { chartData: "chartData", customChartConfiguration: "customChartConfiguration" }, outputs: { clickEvent: "clickEvent", headerMenuclickEvent: "headerMenuclickEvent" }, viewQueries: [{ propertyName: "containerElt", first: true, predicate: ["groupchartcontainer"], descendants: true, static: true }, { propertyName: "groupcontainerElt", first: true, predicate: ["groupcontainer"], descendants: true, static: true }], usesInheritance: true, usesOnChanges: true, ngImport: i0, template: "<div\r\n #groupcontainer\r\n class=\"lib-chart-wrapper\"\r\n [ngClass]=\"{ 'lib-no-background': isTransparentBackground }\"\r\n [style.background-color]=\"chartConfiguration.backgroundColor\"\r\n (resized)=\"onResized($event)\"\r\n>\r\n\r\n<div class=\"header-alt\" *ngIf=\"!isHeaderVisible\">\r\n <lib-chart-header-v2\r\n [chartData]=\"chartData\"\r\n [chartConfiguration]=\"chartConfiguration\"\r\n (clickEvent)=\"handleClick($event)\"\r\n ></lib-chart-header-v2>\r\n <lib-chart-header-v3\r\n [chartData]=\"chartData\"\r\n [chartConfiguration]=\"chartConfiguration\"\r\n (compareByFilterSelection)=\"handleCompareByFilterSelection($event)\"\r\n (zoomInZoomOutClick)=\"handleZoominZoomoutClick($event)\"\r\n ></lib-chart-header-v3>\r\n</div>\r\n\r\n <lib-chart-header-v1\r\n [title]=\"chartData.metaData.title\"\r\n [hasDrillDown]=\"chartData.metaData.hasDrillDown\"\r\n [isEditEnabled]=\"chartData.metaData.isEditEnabled\"\r\n [menuOptions]=\"chartConfiguration.headerMenuOptions\"\r\n [isria]=\"customChartConfiguration.isRia\"\r\n [selectedKpiTooltop]=\"chartConfiguration.selectedKpiTooltop\"\r\n (menuOptionClickEvent)=\"handleHeaderMenuClick($event)\"\r\n [isAlertEnabled]=\"isAlertEnabled\"\r\n *ngIf=\"isHeaderVisible\"\r\n></lib-chart-header-v1>\r\n\r\n <div\r\n [style.height]=\"chartConfiguration.svgHeight\"\r\n id=\"groupchartcontainer\"\r\n #groupchartcontainer\r\n class=\"lib-chart-svg\"\r\n ></div>\r\n</div>\r\n", styles: [".lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-weight:400;letter-spacing:0px;color:#000;opacity:1;font-size:1.2em}.lib-axis-group-label{font-size:.85em;font-weight:600;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:0px;color:#000;opacity:1}.dots{font-size:10px}.inline__display{display:flex;justify-content:space-around;padding-top:2%}.verticalbar__text{font-style:normal;font-variant:normal;font-weight:400;font-size:13px;line-height:20px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:0px;opacity:1}.lib-line-label-item{display:inline-block!important;font-size:.85em;margin-right:10px;font-weight:600}.lib-line-label-wrapper-vertical{display:flex;justify-content:center}.target-display{font-size:12px;line-height:14.52px;font-weight:700;text-transform:uppercase;float:right}.title{background-color:#d9d9d9;height:35px;display:flex;flex-direction:column;justify-content:center;align-items:center;border-radius:3px;line-height:1}.title:after{content:\"\";position:absolute;bottom:0;left:50%;margin-left:-10px;width:0;height:0;border-top:solid 10px #d3d3d3;border-left:solid 10px transparent;border-right:solid 10px transparent}.title-top-text{color:#000;font-size:14px;font-weight:600}.title-bar-name{color:#000;font-size:12px;font-weight:700;text-transform:capitalize}.title-bottom-text{color:#4f4f4f;font-size:12px}.zoomIcons-holder{display:flex;align-items:center;margin-right:15px}.zoomIcons{border:.5px solid #b6b6b6;cursor:pointer;display:flex;justify-content:center;align-items:center;width:30px;height:30px;color:var(--color)!important}.zoom-active{background-color:#2d5ca0;opacity:1}.zoom-inactive{background-color:#d9d9d9;opacity:.5}@media screen and (min-width: 1024px) and (min-height: 400px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:10px!important}.dots{font-size:10px!important}}@media screen and (min-width: 1024px) and (min-height: 1000px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:10px!important}.dots{font-size:10px!important}}@media screen and (min-width: 1024px) and (min-height: 1500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:10px!important}.dots{font-size:10px!important}}@media screen and (min-width: 1366px) and (min-height: 400px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:12px!important}.dots{font-size:12px!important}}@media screen and (min-width: 1366px) and (min-height: 1000px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:12px!important}.dots{font-size:12px!important}}@media screen and (min-width: 1366px) and (min-height: 1500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:12px!important}.dots{font-size:12px!important}}@media screen and (min-width: 1920px) and (min-height: 400px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:14px!important}.dots{font-size:14px!important}}@media screen and (min-width: 1920px) and (min-height: 1000px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:14px!important}.dots{font-size:14px!important}}@media screen and (min-width: 1920px) and (min-height: 1500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:14px!important}.dots{font-size:14px!important}}@media screen and (min-width: 2560px) and (min-height: 500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:16px!important}.dots{font-size:16px!important}}@media screen and (min-width: 2560px) and (min-height: 1000px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:16px!important}.dots{font-size:16px!important}}@media screen and (min-width: 2560px) and (min-height: 1500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:16px!important}}.bottom__text{position:absolute!important;bottom:0!important;display:flex!important;justify-content:center!important;align-items:center!important;width:100%!important}.box__heightwidth{opacity:1;height:10px;width:10px;border:none!important;border-radius:50%}.label__text{margin-right:10px;display:flex;justify-content:center;align-items:center;font-style:normal;font-variant:normal;font-weight:400;font-size:10px;line-height:13px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;letter-spacing:.2px;color:#707070!important}.lib-verticalstack-labels-ontop-weklycharts{font-style:normal;font-variant:normal;font-weight:700;font-size:10px;line-height:11px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.05px;text-anchor:middle;fill:#000}.lib-verticalstack-title-ontop{font-style:normal;font-variant:normal;font-size:14px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.05px;text-anchor:middle;fill:#000}.marginLeft-20{margin-left:20px}.flex-inline{display:flex;justify-content:center;align-items:center;font-size:14px}\n", ".lib-chart-wrapper{width:100%;height:100%;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;background:#fff 0% 0% no-repeat padding-box;position:relative}.lib-chart-wrapper-wo-shadow{width:100%;height:100%;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto}.lib-chart-wrapper:hover .chart-header-v1{background-color:#2e3640}.lib-chart-wrapper:hover .chart-title{color:#fff}.lib-chart-svg{width:100%}.lib-chart-header{text-align:center;background-color:#052340;color:#fff;width:100%;height:17%;word-spacing:.5px;line-height:1.8;font-weight:700;padding-top:2%;letter-spacing:0;font-size:1.2em}.lib-donut-chart-footer{width:100%;text-align:right}.lib-donut-label-text{font-size:.9em;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-weight:400;letter-spacing:0px;color:#000;opacity:1}.lib-donut-label-icon{display:inline-block;width:10px;height:10px;margin-right:20px;border-radius:3px}.lib-donut-label-item{font-weight:400;font-size:.85em;color:#2f2f2f}.lib-donut-justified-label-wrapper{width:100%;display:inline-block;text-align:center;list-style-type:none}.lib-donut-justified-label-item{font-weight:400;font-size:.85em;color:#2f2f2f;display:inline-block;text-align:left;padding:0 10px}.lib-donut-justified-label-icon{display:inline-block;width:10px;height:10px;margin-right:5px;border-radius:3px}.lib-no-background{background:none!important}.lib-display-hidden{display:none}.lib-ylabel-weeklyCharts{font-style:normal;font-variant:normal;font-weight:800;font-size:10px;line-height:12px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.07px;text-transform:capitalize;color:#000}.lib-data-labels-weeklycharts{font-style:normal;font-variant:normal;font-weight:400;font-size:12px;line-height:14px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.06px;color:#000}.lib-data-labels-angled-weeklycharts{font-style:normal;font-variant:normal;font-weight:800;font-size:9.5px;line-height:11px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:.4px;text-anchor:start}.lib-xaxis-labels-texts-weeklycharts{font-style:normal;font-variant:normal;font-weight:800;font-size:10px;line-height:11px;letter-spacing:-.05px;fill:#000}.lib-xaxis-labels-texts-drilldown{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:14px;letter-spacing:-1px;color:#000;opacity:1;text-transform:capitalize}.lib-white-space-nowrap{white-space:nowrap}.lib-xaxis-labels-texts-drilldown-alt{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:10px;letter-spacing:0px;color:#000;opacity:1;text-transform:capitalize}.lib-yaxis-labels-texts-drilldown{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:14px;letter-spacing:0px;color:#000!important;opacity:1}.lib-ylabel-drilldowncharts,.lib-xlabel-drilldowncharts{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:16px;letter-spacing:-.1px;color:#000!important;opacity:1}.lib-donut-justified-label-icon-drilldown{display:inline-block;width:14px;height:14px;margin-right:10px;border-radius:50%}.marginright-2{margin-right:2%}.margintop-5{margin-top:5%}.width-100{width:100%}.float-right{float:right}.marginBottom-10{margin-bottom:10px}.header-alt{align-items:center;margin-bottom:10px}input::placeholder{font-size:20px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:0px;color:#000;opacity:1}.padding-5{padding:5px}.hidden{visibility:hidden}.font-weight-bold{font-weight:900}.textalign-center{text-align:center}.cursor-pointer{cursor:pointer}.cursor-default{cursor:default}.font-weight-600{font-weight:600}.marginRight-15{margin-right:15px}.marginRight-20{margin-right:20px}.switch{position:relative;display:inline-block;width:46px;height:24px;margin-left:5px;margin-right:5px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:#2d5ca0;-webkit-transition:.4s;transition:.4s}.slider:before{position:absolute;content:\"\";height:18px;width:18px;right:3px;bottom:3px;background-color:#fff;-webkit-transition:.4s;transition:.4s}.slider.round{border-radius:18px}.slider.round:before{border-radius:50%}.slider1{position:absolute;cursor:pointer;inset:0;background-color:#015ba2cf;-webkit-transition:.4s;transition:.4s}.slider1:before{position:absolute;content:\"\";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;-webkit-transition:.4s;transition:.4s}.slider1.round1{border-radius:18px}.slider1.round1:before{border-radius:50%}.lib-display-flex{display:flex}.lib-align-items-center{align-items:center}.lib-flex-direction-column{flex-direction:column}.lib-justify-content-space-between{justify-content:space-between}.lib-justify-content-space-around{justify-content:space-around}.lib-justify-content-center{justify-content:center}.lib-justify-content-start{justify-content:start}.lib-justify-content-end{justify-content:end}.lib-ml-20{margin-left:20px}.lib-position-absolute{position:absolute}.lib-z-index-9{z-index:9}.marginright-3{margin-right:3px}@media (min-height: 900px){.lib-chart-wrapper{border-radius:8px}.header-font-size-1{font-size:18px!important}.font-size-1{font-size:14px!important}.font-size-2{font-size:16px!important}.font-size-3{font-size:14px!important}.font-size-4{font-size:22px!important}.font-size-5{font-size:24px!important}}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.ResizedDirective, selector: "[resized]", outputs: ["resized"] }, { kind: "component", type: i3.ChartHeaderV1Component, selector: "lib-chart-header-v1", inputs: ["isAlertEnabled", "title", "menuOptions", "isEditEnabled", "isria", "hasDrillDown", "selectedKpiTooltop"], outputs: ["menuOptionClickEvent"] }, { kind: "component", type: i4.ChartHeaderV2Component, selector: "lib-chart-header-v2", inputs: ["chartData", "chartConfiguration"], outputs: ["clickEvent", "zoomInZoomOutClick"] }, { kind: "component", type: i5.ChartHeaderV3Component, selector: "lib-chart-header-v3", inputs: ["chartData", "chartConfiguration"], outputs: ["compareByFilterSelection", "zoomInZoomOutClick"] }], encapsulation: i0.ViewEncapsulation.None }); }
1352
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: GroupChartComponent, selector: "lib-group-chart", inputs: { chartData: "chartData", customChartConfiguration: "customChartConfiguration" }, outputs: { clickEvent: "clickEvent", headerMenuclickEvent: "headerMenuclickEvent" }, viewQueries: [{ propertyName: "containerElt", first: true, predicate: ["groupchartcontainer"], descendants: true, static: true }, { propertyName: "groupcontainerElt", first: true, predicate: ["groupcontainer"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<div\r\n #groupcontainer\r\n class=\"lib-chart-wrapper\"\r\n [ngClass]=\"{ 'lib-no-background': isTransparentBackground }\"\r\n [style.background-color]=\"chartConfiguration.backgroundColor\"\r\n (resized)=\"onResized($event)\"\r\n>\r\n\r\n<div class=\"header-alt\" *ngIf=\"!isHeaderVisible\">\r\n <lib-chart-header-v2\r\n [chartData]=\"chartData\"\r\n [chartConfiguration]=\"chartConfiguration\"\r\n (clickEvent)=\"handleClick($event)\"\r\n ></lib-chart-header-v2>\r\n <lib-chart-header-v3\r\n [chartData]=\"chartData\"\r\n [chartConfiguration]=\"chartConfiguration\"\r\n (compareByFilterSelection)=\"handleCompareByFilterSelection($event)\"\r\n (zoomInZoomOutClick)=\"handleZoominZoomoutClick($event)\"\r\n ></lib-chart-header-v3>\r\n</div>\r\n\r\n <lib-chart-header-v1\r\n [title]=\"chartData.metaData.title\"\r\n [hasDrillDown]=\"chartData.metaData.hasDrillDown\"\r\n [isEditEnabled]=\"chartData.metaData.isEditEnabled\"\r\n [menuOptions]=\"chartConfiguration.headerMenuOptions\"\r\n [isria]=\"customChartConfiguration.isRia\"\r\n [selectedKpiTooltop]=\"chartConfiguration.selectedKpiTooltop\"\r\n (menuOptionClickEvent)=\"handleHeaderMenuClick($event)\"\r\n [isAlertEnabled]=\"isAlertEnabled\"\r\n *ngIf=\"isHeaderVisible\"\r\n></lib-chart-header-v1>\r\n\r\n <div\r\n [style.height]=\"chartConfiguration.svgHeight\"\r\n id=\"groupchartcontainer\"\r\n #groupchartcontainer\r\n class=\"lib-chart-svg\"\r\n ></div>\r\n</div>\r\n", styles: [".lib-axis-group-label{font-size:.85em;font-weight:600;letter-spacing:0px;color:#000;opacity:1}.text-transform-uppercase{text-transform:uppercase!important}.text-transform-capitalize{text-transform:capitalize!important}.legend-holder-right{display:flex;justify-content:flex-end}.display-flex{display:flex}.legends-positioning-inline{display:flex;align-items:center;justify-content:center;margin-right:10px;margin-left:35px;font-size:18px;font-weight:700;letter-spacing:0px;color:#000;opacity:1}.title{background-color:#d9d9d9;height:35px;display:flex;flex-direction:column;justify-content:center;align-items:center;border-radius:3px;line-height:1}.title:after{content:\"\";position:absolute;bottom:0;margin-bottom:-10px;left:50%;margin-left:-10px;width:0;height:0;border-top:solid 10px #d3d3d3;border-left:solid 10px transparent;border-right:solid 10px transparent}.title-bar-name{color:var(--font-color)!important;font-size:17px;font-weight:700;text-transform:capitalize}.title-bar-value{color:var(--font-color)!important;font-size:14px}.title-bar-value>span{font-weight:600}.zoomIcons-holder{display:flex;align-items:center}.legends-latest{height:14px;width:14px;display:flex;margin-right:10px}.legend-latest-holder{font-size:12px;display:flex;justify-content:flex-start;align-items:center}.marginRight-30{margin-right:30px}.zoomIcons-holder{display:flex;align-items:center;margin-right:15px}.zoomIcons{border:.5px solid #b6b6b6;cursor:pointer;display:flex;justify-content:center;align-items:center;width:30px;height:30px;color:var(--color)!important}.zoom-active{background-color:#2d5ca0;opacity:1}.zoom-inactive{background-color:#d9d9d9;opacity:.5}.flex-inline{display:flex;justify-content:center;align-items:center;font-size:14px}.marginLeft-20{margin-left:20px}.target-display{font-size:12px;line-height:14.52px;font-weight:700;text-transform:uppercase;float:right}.legend-style{font-weight:600;text-transform:capitalize}.bar-values{margin-top:10px}.bar-name{font-weight:600;margin-right:10px;text-transform:capitalize}.lib-chart-svg{margin-top:10px}.bar-value{height:29px;background-color:#f4f4f4;padding-left:15px;padding-right:15px;border-radius:8px;box-shadow:-2px 2px 10px #0000004d,2px 2px 10px #0000004d;font-weight:600}.mobile-xaxis-override{writing-mode:sideways-lr}@media (min-height: 900px){.legends-latest{height:17px;width:17px}}\n", ".lib-chart-wrapper{width:100%;height:100%;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;background:#fff 0% 0% no-repeat padding-box;position:relative}.lib-chart-wrapper-wo-shadow{width:100%;height:100%;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto}.lib-chart-wrapper:hover .chart-header-v1{background-color:#2e3640}.lib-chart-wrapper:hover .chart-title{color:#fff}.lib-chart-svg{width:100%}.lib-chart-header{text-align:center;background-color:#052340;color:#fff;width:100%;height:17%;word-spacing:.5px;line-height:1.8;font-weight:700;padding-top:2%;letter-spacing:0;font-size:1.2em}.lib-donut-chart-footer{width:100%;text-align:right}.lib-donut-label-text{font-size:.9em;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-weight:400;letter-spacing:0px;color:#000;opacity:1}.lib-donut-label-icon{display:inline-block;width:10px;height:10px;margin-right:20px;border-radius:3px}.lib-donut-label-item{font-weight:400;font-size:.85em;color:#2f2f2f}.lib-donut-justified-label-wrapper{width:100%;display:inline-block;text-align:center;list-style-type:none}.lib-donut-justified-label-item{font-weight:400;font-size:.85em;color:#2f2f2f;display:inline-block;text-align:left;padding:0 10px}.lib-donut-justified-label-icon{display:inline-block;width:10px;height:10px;margin-right:5px;border-radius:3px}.lib-no-background{background:none!important}.lib-display-hidden{display:none}.lib-ylabel-weeklyCharts{font-style:normal;font-variant:normal;font-weight:800;font-size:10px;line-height:12px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.07px;text-transform:capitalize;color:#000}.lib-data-labels-weeklycharts{font-style:normal;font-variant:normal;font-weight:400;font-size:12px;line-height:14px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.06px;color:#000}.lib-data-labels-angled-weeklycharts{font-style:normal;font-variant:normal;font-weight:800;font-size:9.5px;line-height:11px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:.4px;text-anchor:start}.lib-xaxis-labels-texts-weeklycharts{font-style:normal;font-variant:normal;font-weight:800;font-size:10px;line-height:11px;letter-spacing:-.05px;fill:#000}.lib-xaxis-labels-texts-drilldown{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:14px;letter-spacing:-1px;color:#000;opacity:1;text-transform:capitalize}.lib-white-space-nowrap{white-space:nowrap}.lib-xaxis-labels-texts-drilldown-alt{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:10px;letter-spacing:0px;color:#000;opacity:1;text-transform:capitalize}.lib-yaxis-labels-texts-drilldown{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:14px;letter-spacing:0px;color:#000!important;opacity:1}.lib-ylabel-drilldowncharts,.lib-xlabel-drilldowncharts{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:16px;letter-spacing:-.1px;color:#000!important;opacity:1}.lib-donut-justified-label-icon-drilldown{display:inline-block;width:14px;height:14px;margin-right:10px;border-radius:50%}.marginright-2{margin-right:2%}.margintop-5{margin-top:5%}.width-100{width:100%}.float-right{float:right}.marginBottom-10{margin-bottom:10px}.header-alt{align-items:center;margin-bottom:10px}input::placeholder{font-size:20px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:0px;color:#000;opacity:1}.padding-5{padding:5px}.hidden{visibility:hidden}.font-weight-bold{font-weight:900}.textalign-center{text-align:center}.cursor-pointer{cursor:pointer}.cursor-default{cursor:default}.font-weight-600{font-weight:600}.marginRight-15{margin-right:15px}.marginRight-20{margin-right:20px}.switch{position:relative;display:inline-block;width:46px;height:24px;margin-left:5px;margin-right:5px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:#2d5ca0;-webkit-transition:.4s;transition:.4s}.slider:before{position:absolute;content:\"\";height:18px;width:18px;right:3px;bottom:3px;background-color:#fff;-webkit-transition:.4s;transition:.4s}.slider.round{border-radius:18px}.slider.round:before{border-radius:50%}.slider1{position:absolute;cursor:pointer;inset:0;background-color:#015ba2cf;-webkit-transition:.4s;transition:.4s}.slider1:before{position:absolute;content:\"\";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;-webkit-transition:.4s;transition:.4s}.slider1.round1{border-radius:18px}.slider1.round1:before{border-radius:50%}.lib-display-flex{display:flex}.lib-align-items-center{align-items:center}.lib-flex-direction-column{flex-direction:column}.lib-justify-content-space-between{justify-content:space-between}.lib-justify-content-space-around{justify-content:space-around}.lib-justify-content-center{justify-content:center}.lib-justify-content-start{justify-content:start}.lib-justify-content-end{justify-content:end}.lib-ml-20{margin-left:20px}.lib-position-absolute{position:absolute}.lib-z-index-9{z-index:9}.marginright-3{margin-right:3px}@media (min-height: 900px){.lib-chart-wrapper{border-radius:8px}.header-font-size-1{font-size:18px!important}.font-size-1{font-size:14px!important}.font-size-2{font-size:16px!important}.font-size-3{font-size:14px!important}.font-size-4{font-size:22px!important}.font-size-5{font-size:24px!important}}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.ResizedDirective, selector: "[resized]", outputs: ["resized"] }, { kind: "component", type: i3.ChartHeaderV1Component, selector: "lib-chart-header-v1", inputs: ["isAlertEnabled", "title", "menuOptions", "isEditEnabled", "isria", "hasDrillDown", "selectedKpiTooltop"], outputs: ["menuOptionClickEvent"] }, { kind: "component", type: i4.ChartHeaderV2Component, selector: "lib-chart-header-v2", inputs: ["chartData", "chartConfiguration"], outputs: ["clickEvent", "zoomInZoomOutClick"] }, { kind: "component", type: i5.ChartHeaderV3Component, selector: "lib-chart-header-v3", inputs: ["chartData", "chartConfiguration"], outputs: ["compareByFilterSelection", "zoomInZoomOutClick"] }], encapsulation: i0.ViewEncapsulation.None }); }
1267
1353
  }
1268
1354
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: GroupChartComponent, decorators: [{
1269
1355
  type: Component,
1270
- args: [{ selector: 'lib-group-chart', encapsulation: ViewEncapsulation.None, template: "<div\r\n #groupcontainer\r\n class=\"lib-chart-wrapper\"\r\n [ngClass]=\"{ 'lib-no-background': isTransparentBackground }\"\r\n [style.background-color]=\"chartConfiguration.backgroundColor\"\r\n (resized)=\"onResized($event)\"\r\n>\r\n\r\n<div class=\"header-alt\" *ngIf=\"!isHeaderVisible\">\r\n <lib-chart-header-v2\r\n [chartData]=\"chartData\"\r\n [chartConfiguration]=\"chartConfiguration\"\r\n (clickEvent)=\"handleClick($event)\"\r\n ></lib-chart-header-v2>\r\n <lib-chart-header-v3\r\n [chartData]=\"chartData\"\r\n [chartConfiguration]=\"chartConfiguration\"\r\n (compareByFilterSelection)=\"handleCompareByFilterSelection($event)\"\r\n (zoomInZoomOutClick)=\"handleZoominZoomoutClick($event)\"\r\n ></lib-chart-header-v3>\r\n</div>\r\n\r\n <lib-chart-header-v1\r\n [title]=\"chartData.metaData.title\"\r\n [hasDrillDown]=\"chartData.metaData.hasDrillDown\"\r\n [isEditEnabled]=\"chartData.metaData.isEditEnabled\"\r\n [menuOptions]=\"chartConfiguration.headerMenuOptions\"\r\n [isria]=\"customChartConfiguration.isRia\"\r\n [selectedKpiTooltop]=\"chartConfiguration.selectedKpiTooltop\"\r\n (menuOptionClickEvent)=\"handleHeaderMenuClick($event)\"\r\n [isAlertEnabled]=\"isAlertEnabled\"\r\n *ngIf=\"isHeaderVisible\"\r\n></lib-chart-header-v1>\r\n\r\n <div\r\n [style.height]=\"chartConfiguration.svgHeight\"\r\n id=\"groupchartcontainer\"\r\n #groupchartcontainer\r\n class=\"lib-chart-svg\"\r\n ></div>\r\n</div>\r\n", styles: [".lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-weight:400;letter-spacing:0px;color:#000;opacity:1;font-size:1.2em}.lib-axis-group-label{font-size:.85em;font-weight:600;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:0px;color:#000;opacity:1}.dots{font-size:10px}.inline__display{display:flex;justify-content:space-around;padding-top:2%}.verticalbar__text{font-style:normal;font-variant:normal;font-weight:400;font-size:13px;line-height:20px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:0px;opacity:1}.lib-line-label-item{display:inline-block!important;font-size:.85em;margin-right:10px;font-weight:600}.lib-line-label-wrapper-vertical{display:flex;justify-content:center}.target-display{font-size:12px;line-height:14.52px;font-weight:700;text-transform:uppercase;float:right}.title{background-color:#d9d9d9;height:35px;display:flex;flex-direction:column;justify-content:center;align-items:center;border-radius:3px;line-height:1}.title:after{content:\"\";position:absolute;bottom:0;left:50%;margin-left:-10px;width:0;height:0;border-top:solid 10px #d3d3d3;border-left:solid 10px transparent;border-right:solid 10px transparent}.title-top-text{color:#000;font-size:14px;font-weight:600}.title-bar-name{color:#000;font-size:12px;font-weight:700;text-transform:capitalize}.title-bottom-text{color:#4f4f4f;font-size:12px}.zoomIcons-holder{display:flex;align-items:center;margin-right:15px}.zoomIcons{border:.5px solid #b6b6b6;cursor:pointer;display:flex;justify-content:center;align-items:center;width:30px;height:30px;color:var(--color)!important}.zoom-active{background-color:#2d5ca0;opacity:1}.zoom-inactive{background-color:#d9d9d9;opacity:.5}@media screen and (min-width: 1024px) and (min-height: 400px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:10px!important}.dots{font-size:10px!important}}@media screen and (min-width: 1024px) and (min-height: 1000px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:10px!important}.dots{font-size:10px!important}}@media screen and (min-width: 1024px) and (min-height: 1500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:10px!important}.dots{font-size:10px!important}}@media screen and (min-width: 1366px) and (min-height: 400px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:12px!important}.dots{font-size:12px!important}}@media screen and (min-width: 1366px) and (min-height: 1000px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:12px!important}.dots{font-size:12px!important}}@media screen and (min-width: 1366px) and (min-height: 1500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:12px!important}.dots{font-size:12px!important}}@media screen and (min-width: 1920px) and (min-height: 400px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:14px!important}.dots{font-size:14px!important}}@media screen and (min-width: 1920px) and (min-height: 1000px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:14px!important}.dots{font-size:14px!important}}@media screen and (min-width: 1920px) and (min-height: 1500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:14px!important}.dots{font-size:14px!important}}@media screen and (min-width: 2560px) and (min-height: 500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:16px!important}.dots{font-size:16px!important}}@media screen and (min-width: 2560px) and (min-height: 1000px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:16px!important}.dots{font-size:16px!important}}@media screen and (min-width: 2560px) and (min-height: 1500px){.lib-stacked-y-axis-text text,.lib-stacked-x-axis-text text{font-size:16px!important}}.bottom__text{position:absolute!important;bottom:0!important;display:flex!important;justify-content:center!important;align-items:center!important;width:100%!important}.box__heightwidth{opacity:1;height:10px;width:10px;border:none!important;border-radius:50%}.label__text{margin-right:10px;display:flex;justify-content:center;align-items:center;font-style:normal;font-variant:normal;font-weight:400;font-size:10px;line-height:13px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;letter-spacing:.2px;color:#707070!important}.lib-verticalstack-labels-ontop-weklycharts{font-style:normal;font-variant:normal;font-weight:700;font-size:10px;line-height:11px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.05px;text-anchor:middle;fill:#000}.lib-verticalstack-title-ontop{font-style:normal;font-variant:normal;font-size:14px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.05px;text-anchor:middle;fill:#000}.marginLeft-20{margin-left:20px}.flex-inline{display:flex;justify-content:center;align-items:center;font-size:14px}\n", ".lib-chart-wrapper{width:100%;height:100%;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;background:#fff 0% 0% no-repeat padding-box;position:relative}.lib-chart-wrapper-wo-shadow{width:100%;height:100%;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto}.lib-chart-wrapper:hover .chart-header-v1{background-color:#2e3640}.lib-chart-wrapper:hover .chart-title{color:#fff}.lib-chart-svg{width:100%}.lib-chart-header{text-align:center;background-color:#052340;color:#fff;width:100%;height:17%;word-spacing:.5px;line-height:1.8;font-weight:700;padding-top:2%;letter-spacing:0;font-size:1.2em}.lib-donut-chart-footer{width:100%;text-align:right}.lib-donut-label-text{font-size:.9em;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-weight:400;letter-spacing:0px;color:#000;opacity:1}.lib-donut-label-icon{display:inline-block;width:10px;height:10px;margin-right:20px;border-radius:3px}.lib-donut-label-item{font-weight:400;font-size:.85em;color:#2f2f2f}.lib-donut-justified-label-wrapper{width:100%;display:inline-block;text-align:center;list-style-type:none}.lib-donut-justified-label-item{font-weight:400;font-size:.85em;color:#2f2f2f;display:inline-block;text-align:left;padding:0 10px}.lib-donut-justified-label-icon{display:inline-block;width:10px;height:10px;margin-right:5px;border-radius:3px}.lib-no-background{background:none!important}.lib-display-hidden{display:none}.lib-ylabel-weeklyCharts{font-style:normal;font-variant:normal;font-weight:800;font-size:10px;line-height:12px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.07px;text-transform:capitalize;color:#000}.lib-data-labels-weeklycharts{font-style:normal;font-variant:normal;font-weight:400;font-size:12px;line-height:14px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.06px;color:#000}.lib-data-labels-angled-weeklycharts{font-style:normal;font-variant:normal;font-weight:800;font-size:9.5px;line-height:11px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:.4px;text-anchor:start}.lib-xaxis-labels-texts-weeklycharts{font-style:normal;font-variant:normal;font-weight:800;font-size:10px;line-height:11px;letter-spacing:-.05px;fill:#000}.lib-xaxis-labels-texts-drilldown{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:14px;letter-spacing:-1px;color:#000;opacity:1;text-transform:capitalize}.lib-white-space-nowrap{white-space:nowrap}.lib-xaxis-labels-texts-drilldown-alt{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:10px;letter-spacing:0px;color:#000;opacity:1;text-transform:capitalize}.lib-yaxis-labels-texts-drilldown{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:14px;letter-spacing:0px;color:#000!important;opacity:1}.lib-ylabel-drilldowncharts,.lib-xlabel-drilldowncharts{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:16px;letter-spacing:-.1px;color:#000!important;opacity:1}.lib-donut-justified-label-icon-drilldown{display:inline-block;width:14px;height:14px;margin-right:10px;border-radius:50%}.marginright-2{margin-right:2%}.margintop-5{margin-top:5%}.width-100{width:100%}.float-right{float:right}.marginBottom-10{margin-bottom:10px}.header-alt{align-items:center;margin-bottom:10px}input::placeholder{font-size:20px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:0px;color:#000;opacity:1}.padding-5{padding:5px}.hidden{visibility:hidden}.font-weight-bold{font-weight:900}.textalign-center{text-align:center}.cursor-pointer{cursor:pointer}.cursor-default{cursor:default}.font-weight-600{font-weight:600}.marginRight-15{margin-right:15px}.marginRight-20{margin-right:20px}.switch{position:relative;display:inline-block;width:46px;height:24px;margin-left:5px;margin-right:5px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:#2d5ca0;-webkit-transition:.4s;transition:.4s}.slider:before{position:absolute;content:\"\";height:18px;width:18px;right:3px;bottom:3px;background-color:#fff;-webkit-transition:.4s;transition:.4s}.slider.round{border-radius:18px}.slider.round:before{border-radius:50%}.slider1{position:absolute;cursor:pointer;inset:0;background-color:#015ba2cf;-webkit-transition:.4s;transition:.4s}.slider1:before{position:absolute;content:\"\";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;-webkit-transition:.4s;transition:.4s}.slider1.round1{border-radius:18px}.slider1.round1:before{border-radius:50%}.lib-display-flex{display:flex}.lib-align-items-center{align-items:center}.lib-flex-direction-column{flex-direction:column}.lib-justify-content-space-between{justify-content:space-between}.lib-justify-content-space-around{justify-content:space-around}.lib-justify-content-center{justify-content:center}.lib-justify-content-start{justify-content:start}.lib-justify-content-end{justify-content:end}.lib-ml-20{margin-left:20px}.lib-position-absolute{position:absolute}.lib-z-index-9{z-index:9}.marginright-3{margin-right:3px}@media (min-height: 900px){.lib-chart-wrapper{border-radius:8px}.header-font-size-1{font-size:18px!important}.font-size-1{font-size:14px!important}.font-size-2{font-size:16px!important}.font-size-3{font-size:14px!important}.font-size-4{font-size:22px!important}.font-size-5{font-size:24px!important}}\n"] }]
1356
+ args: [{ selector: 'lib-group-chart', encapsulation: ViewEncapsulation.None, template: "<div\r\n #groupcontainer\r\n class=\"lib-chart-wrapper\"\r\n [ngClass]=\"{ 'lib-no-background': isTransparentBackground }\"\r\n [style.background-color]=\"chartConfiguration.backgroundColor\"\r\n (resized)=\"onResized($event)\"\r\n>\r\n\r\n<div class=\"header-alt\" *ngIf=\"!isHeaderVisible\">\r\n <lib-chart-header-v2\r\n [chartData]=\"chartData\"\r\n [chartConfiguration]=\"chartConfiguration\"\r\n (clickEvent)=\"handleClick($event)\"\r\n ></lib-chart-header-v2>\r\n <lib-chart-header-v3\r\n [chartData]=\"chartData\"\r\n [chartConfiguration]=\"chartConfiguration\"\r\n (compareByFilterSelection)=\"handleCompareByFilterSelection($event)\"\r\n (zoomInZoomOutClick)=\"handleZoominZoomoutClick($event)\"\r\n ></lib-chart-header-v3>\r\n</div>\r\n\r\n <lib-chart-header-v1\r\n [title]=\"chartData.metaData.title\"\r\n [hasDrillDown]=\"chartData.metaData.hasDrillDown\"\r\n [isEditEnabled]=\"chartData.metaData.isEditEnabled\"\r\n [menuOptions]=\"chartConfiguration.headerMenuOptions\"\r\n [isria]=\"customChartConfiguration.isRia\"\r\n [selectedKpiTooltop]=\"chartConfiguration.selectedKpiTooltop\"\r\n (menuOptionClickEvent)=\"handleHeaderMenuClick($event)\"\r\n [isAlertEnabled]=\"isAlertEnabled\"\r\n *ngIf=\"isHeaderVisible\"\r\n></lib-chart-header-v1>\r\n\r\n <div\r\n [style.height]=\"chartConfiguration.svgHeight\"\r\n id=\"groupchartcontainer\"\r\n #groupchartcontainer\r\n class=\"lib-chart-svg\"\r\n ></div>\r\n</div>\r\n", styles: [".lib-axis-group-label{font-size:.85em;font-weight:600;letter-spacing:0px;color:#000;opacity:1}.text-transform-uppercase{text-transform:uppercase!important}.text-transform-capitalize{text-transform:capitalize!important}.legend-holder-right{display:flex;justify-content:flex-end}.display-flex{display:flex}.legends-positioning-inline{display:flex;align-items:center;justify-content:center;margin-right:10px;margin-left:35px;font-size:18px;font-weight:700;letter-spacing:0px;color:#000;opacity:1}.title{background-color:#d9d9d9;height:35px;display:flex;flex-direction:column;justify-content:center;align-items:center;border-radius:3px;line-height:1}.title:after{content:\"\";position:absolute;bottom:0;margin-bottom:-10px;left:50%;margin-left:-10px;width:0;height:0;border-top:solid 10px #d3d3d3;border-left:solid 10px transparent;border-right:solid 10px transparent}.title-bar-name{color:var(--font-color)!important;font-size:17px;font-weight:700;text-transform:capitalize}.title-bar-value{color:var(--font-color)!important;font-size:14px}.title-bar-value>span{font-weight:600}.zoomIcons-holder{display:flex;align-items:center}.legends-latest{height:14px;width:14px;display:flex;margin-right:10px}.legend-latest-holder{font-size:12px;display:flex;justify-content:flex-start;align-items:center}.marginRight-30{margin-right:30px}.zoomIcons-holder{display:flex;align-items:center;margin-right:15px}.zoomIcons{border:.5px solid #b6b6b6;cursor:pointer;display:flex;justify-content:center;align-items:center;width:30px;height:30px;color:var(--color)!important}.zoom-active{background-color:#2d5ca0;opacity:1}.zoom-inactive{background-color:#d9d9d9;opacity:.5}.flex-inline{display:flex;justify-content:center;align-items:center;font-size:14px}.marginLeft-20{margin-left:20px}.target-display{font-size:12px;line-height:14.52px;font-weight:700;text-transform:uppercase;float:right}.legend-style{font-weight:600;text-transform:capitalize}.bar-values{margin-top:10px}.bar-name{font-weight:600;margin-right:10px;text-transform:capitalize}.lib-chart-svg{margin-top:10px}.bar-value{height:29px;background-color:#f4f4f4;padding-left:15px;padding-right:15px;border-radius:8px;box-shadow:-2px 2px 10px #0000004d,2px 2px 10px #0000004d;font-weight:600}.mobile-xaxis-override{writing-mode:sideways-lr}@media (min-height: 900px){.legends-latest{height:17px;width:17px}}\n", ".lib-chart-wrapper{width:100%;height:100%;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;background:#fff 0% 0% no-repeat padding-box;position:relative}.lib-chart-wrapper-wo-shadow{width:100%;height:100%;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto}.lib-chart-wrapper:hover .chart-header-v1{background-color:#2e3640}.lib-chart-wrapper:hover .chart-title{color:#fff}.lib-chart-svg{width:100%}.lib-chart-header{text-align:center;background-color:#052340;color:#fff;width:100%;height:17%;word-spacing:.5px;line-height:1.8;font-weight:700;padding-top:2%;letter-spacing:0;font-size:1.2em}.lib-donut-chart-footer{width:100%;text-align:right}.lib-donut-label-text{font-size:.9em;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-weight:400;letter-spacing:0px;color:#000;opacity:1}.lib-donut-label-icon{display:inline-block;width:10px;height:10px;margin-right:20px;border-radius:3px}.lib-donut-label-item{font-weight:400;font-size:.85em;color:#2f2f2f}.lib-donut-justified-label-wrapper{width:100%;display:inline-block;text-align:center;list-style-type:none}.lib-donut-justified-label-item{font-weight:400;font-size:.85em;color:#2f2f2f;display:inline-block;text-align:left;padding:0 10px}.lib-donut-justified-label-icon{display:inline-block;width:10px;height:10px;margin-right:5px;border-radius:3px}.lib-no-background{background:none!important}.lib-display-hidden{display:none}.lib-ylabel-weeklyCharts{font-style:normal;font-variant:normal;font-weight:800;font-size:10px;line-height:12px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.07px;text-transform:capitalize;color:#000}.lib-data-labels-weeklycharts{font-style:normal;font-variant:normal;font-weight:400;font-size:12px;line-height:14px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:-.06px;color:#000}.lib-data-labels-angled-weeklycharts{font-style:normal;font-variant:normal;font-weight:800;font-size:9.5px;line-height:11px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:.4px;text-anchor:start}.lib-xaxis-labels-texts-weeklycharts{font-style:normal;font-variant:normal;font-weight:800;font-size:10px;line-height:11px;letter-spacing:-.05px;fill:#000}.lib-xaxis-labels-texts-drilldown{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:14px;letter-spacing:-1px;color:#000;opacity:1;text-transform:capitalize}.lib-white-space-nowrap{white-space:nowrap}.lib-xaxis-labels-texts-drilldown-alt{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:10px;letter-spacing:0px;color:#000;opacity:1;text-transform:capitalize}.lib-yaxis-labels-texts-drilldown{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:14px;letter-spacing:0px;color:#000!important;opacity:1}.lib-ylabel-drilldowncharts,.lib-xlabel-drilldowncharts{font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;font-size:16px;letter-spacing:-.1px;color:#000!important;opacity:1}.lib-donut-justified-label-icon-drilldown{display:inline-block;width:14px;height:14px;margin-right:10px;border-radius:50%}.marginright-2{margin-right:2%}.margintop-5{margin-top:5%}.width-100{width:100%}.float-right{float:right}.marginBottom-10{margin-bottom:10px}.header-alt{align-items:center;margin-bottom:10px}input::placeholder{font-size:20px;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto;letter-spacing:0px;color:#000;opacity:1}.padding-5{padding:5px}.hidden{visibility:hidden}.font-weight-bold{font-weight:900}.textalign-center{text-align:center}.cursor-pointer{cursor:pointer}.cursor-default{cursor:default}.font-weight-600{font-weight:600}.marginRight-15{margin-right:15px}.marginRight-20{margin-right:20px}.switch{position:relative;display:inline-block;width:46px;height:24px;margin-left:5px;margin-right:5px}.switch input{opacity:0;width:0;height:0}.slider{position:absolute;cursor:pointer;inset:0;background-color:#2d5ca0;-webkit-transition:.4s;transition:.4s}.slider:before{position:absolute;content:\"\";height:18px;width:18px;right:3px;bottom:3px;background-color:#fff;-webkit-transition:.4s;transition:.4s}.slider.round{border-radius:18px}.slider.round:before{border-radius:50%}.slider1{position:absolute;cursor:pointer;inset:0;background-color:#015ba2cf;-webkit-transition:.4s;transition:.4s}.slider1:before{position:absolute;content:\"\";height:18px;width:18px;left:3px;bottom:3px;background-color:#fff;-webkit-transition:.4s;transition:.4s}.slider1.round1{border-radius:18px}.slider1.round1:before{border-radius:50%}.lib-display-flex{display:flex}.lib-align-items-center{align-items:center}.lib-flex-direction-column{flex-direction:column}.lib-justify-content-space-between{justify-content:space-between}.lib-justify-content-space-around{justify-content:space-around}.lib-justify-content-center{justify-content:center}.lib-justify-content-start{justify-content:start}.lib-justify-content-end{justify-content:end}.lib-ml-20{margin-left:20px}.lib-position-absolute{position:absolute}.lib-z-index-9{z-index:9}.marginright-3{margin-right:3px}@media (min-height: 900px){.lib-chart-wrapper{border-radius:8px}.header-font-size-1{font-size:18px!important}.font-size-1{font-size:14px!important}.font-size-2{font-size:16px!important}.font-size-3{font-size:14px!important}.font-size-4{font-size:22px!important}.font-size-5{font-size:24px!important}}\n"] }]
1271
1357
  }], ctorParameters: () => [], propDecorators: { containerElt: [{
1272
1358
  type: ViewChild,
1273
1359
  args: ['groupchartcontainer', { static: true }]
@@ -1283,4 +1369,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
1283
1369
  }], headerMenuclickEvent: [{
1284
1370
  type: Output
1285
1371
  }] } });
1286
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"group-chart.component.js","sourceRoot":"","sources":["../../../../../projects/axidio-styleguide-library/src/lib/group-chart/group-chart.component.ts","../../../../../projects/axidio-styleguide-library/src/lib/group-chart/group-chart.component.html"],"names":[],"mappings":"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","sourcesContent":["  import {\r\n    Component,\r\n    OnInit,\r\n    ViewChild,\r\n    ElementRef,\r\n    Input,\r\n    Output,\r\n    EventEmitter,\r\n    ViewEncapsulation,\r\n  } from '@angular/core';\r\n  import { ComponentUniqueId } from '../unique-id';\r\n  import ChartHelper from '../chart-helper';\r\n  import * as d3 from 'd3';\r\n  import { ResizedEvent } from 'angular-resize-event';\r\n  import HeaderConfigHelper from '../header-config';\r\n\r\n  @Component({\r\n    selector: 'lib-group-chart',\r\n    templateUrl: './group-chart.component.html',\r\n    styleUrls: ['./group-chart.component.less', '../common-styles.less'],\r\n    encapsulation: ViewEncapsulation.None,\r\n  })\r\n  export class GroupChartComponent extends ComponentUniqueId implements OnInit {\r\n    @ViewChild('groupchartcontainer', { static: true })\r\n    containerElt!: ElementRef;\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    chartConfiguration: any = {};\r\n    isHeaderVisible: boolean = true;\r\n    isTopCaptionVisible: boolean = true;\r\n    uniqueId: any = this.getUniqueId();\r\n    isTransparentBackground: boolean = false;\r\n    defaultConfiguration: any = {\r\n      margin: { top: 20, right: 20, bottom: 20, left: 40 },\r\n      svgHeight: 70,\r\n      legendHeight: '10%',\r\n      numberOfYTicks: 5,\r\n      labelFormatter: ChartHelper.defaultFormatter,\r\n      xAxisLabelFomatter: ChartHelper.defaultFormatter,\r\n      yAxisLabelFomatter: ChartHelper.defaultFormatter,\r\n      yLineAxisLabelFomatter: ChartHelper.defaultFormatter,\r\n      lineGraphColor: '#F6D283',\r\n      showLineChartAxis: true,\r\n      showLegend: false,\r\n      forComparison: true,\r\n      headerMenuOptions: HeaderConfigHelper.headerConfig.headerMenuOptions,\r\n      yAxisGrid: false,\r\n      isHeaderVisible: undefined,\r\n      isTransparentBackground: undefined,\r\n      isTopCaptionVisible: undefined,\r\n      isMultiChartGridLine: undefined,\r\n      isFullScreen: undefined,\r\n      customYscale: undefined,\r\n      isXaxisLabelHidden: undefined,\r\n      isYaxisLabelHidden: undefined,\r\n      isYaxisHidden: undefined,\r\n      isYaxisDashed: undefined,\r\n      isXaxisColor: undefined,\r\n      textFormatter: undefined,\r\n      showTotalOnTop: undefined,\r\n      backendFormatterHasPriority: undefined,\r\n      showAngledLabels: undefined,\r\n      isNoAlternateXaxisText: undefined,\r\n      isXgridBetweenLabels: undefined,\r\n      showXaxisTop: undefined,\r\n      xAxisGrid: undefined,\r\n      xLabelsOnSameLine: undefined,\r\n      hideXaxisTick: undefined,\r\n      isDrilldownChart: undefined,\r\n      isTargetLine: undefined,\r\n      displayTitleOnTop: undefined,\r\n      isToggleVisible: undefined,\r\n      isTitleHidden: undefined,\r\n    };\r\n    isCC: boolean = false;\r\n    isZoomedOut: boolean = false;\r\n  \r\n    constructor() {\r\n      super();\r\n    }\r\n    isZoomOutSelected(isZoomOut) {\r\n      this.isZoomedOut = isZoomOut;\r\n      this.ngOnChanges();\r\n    }\r\n    ngOnChanges() {\r\n      let self = this;\r\n      d3.select('#' + self.uniqueId).remove();\r\n      this.initializeStackedChart();\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.initializeStackedChart();\r\n        }.bind(self),\r\n        10\r\n      );\r\n    }\r\n    ngOnInit() { }\r\n  \r\n    initializeStackedChart() {\r\n      var self = this;\r\n      let data: any = [];\r\n      let metaData: any = null;\r\n      let keyList = null;\r\n      let lineData = null;\r\n      let colors: any = null;\r\n      var alternate_text = false;\r\n      var alternate_label = false;\r\n      var short_tick_length = 4;\r\n      var long_tick_length = 16;\r\n      var short_tick_length_bg = 5;\r\n      var long_tick_length_bg = 30;\r\n      var formatFromBackend;\r\n      var formatForHugeNumbers;\r\n      var tempObjectHolder = {};\r\n      var rightSvgWidth = 60;\r\n      var leftAndRightSpaces = 50;\r\n  \r\n         let isria = this.customChartConfiguration.isRia\r\n  \r\n      // Responsive breakpoints\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      // Adjust margins and font sizes based on device\r\n      if (isMobile) {\r\n        this.chartConfiguration.margin = { top: 20, right: 10, bottom: 40, left: 30 };\r\n        this.chartConfiguration.numberOfYTicks = 4;\r\n        this.chartConfiguration.svgHeight = 60;\r\n      } else if (isTablet) {\r\n        this.chartConfiguration.margin = { top: 25, right: 20, bottom: 45, left: 40 };\r\n        this.chartConfiguration.numberOfYTicks = 6;\r\n        this.chartConfiguration.svgHeight = 70;\r\n      } else {\r\n        this.chartConfiguration.margin = { top: 30, right: 30, bottom: 50, left: 60 };\r\n        this.chartConfiguration.numberOfYTicks = 7;\r\n        this.chartConfiguration.svgHeight = 80;\r\n      }\r\n  \r\n      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      data = this.chartData.data;\r\n      metaData = this.chartData.metaData;\r\n      if (metaData.unit == undefined) metaData.unit = '';\r\n      if (metaData.isCC) {\r\n        this.isCC = metaData.isCC;\r\n      }\r\n      if (metaData.barWithoutClick && metaData.barWithoutClick.length) {\r\n        metaData.barWithoutClick = metaData.barWithoutClick.map((ele) =>\r\n          ele.toLowerCase()\r\n        );\r\n      } else {\r\n        metaData.barWithoutClick = [];\r\n      }\r\n      lineData = this.chartData.lineData;\r\n      colors = 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  \r\n      let parsedNum = parseFloat(this.chartData?.targetLineData?.target);\r\n      if (!isNaN(parsedNum)) {\r\n        if (Number.isInteger(parsedNum)) {\r\n          parsedNum = parseInt(this.chartData.targetLineData.target);\r\n        } else {\r\n          parsedNum = parseFloat(this.chartData.targetLineData.target);\r\n        }\r\n      }\r\n      var margin = this.chartConfiguration.margin;\r\n  \r\n      // Responsive width and height\r\n      var containerWidth = chartContainer.node().getBoundingClientRect().width;\r\n      var containerHeight = verticalstackedcontainer.node().getBoundingClientRect().height;\r\n      var width = containerWidth - margin.left - margin.right;\r\n      var height = containerHeight * (self.chartConfiguration.svgHeight / 100) - margin.top - margin.bottom;\r\n  \r\n      // Adjust width for large datasets and zoom\r\n      if (this.chartData.data.length > 30 && this.isZoomedOut) {\r\n        width = width > this.chartData.data.length * (isMobile ? 15 : 25)\r\n          ? width\r\n          : this.chartData.data.length * (isMobile ? 15 : 25);\r\n      }\r\n      if (this.chartData.data.length > 8 && !this.isZoomedOut) {\r\n        width = this.chartData.data.length * (isMobile ? 60 : 130);\r\n      }\r\n  \r\n      // Fullscreen and drilldown adjustments\r\n      if (this.chartConfiguration.isFullScreen != undefined && this.chartConfiguration.isFullScreen) {\r\n        height = this.chartConfiguration.svgHeight != 80\r\n          ? this.chartConfiguration.svgHeight\r\n          : containerHeight;\r\n      }\r\n      if (this.chartConfiguration.isDrilldownChart) {\r\n        height = containerHeight - margin.top - margin.bottom - (isMobile ? 60 : 130);\r\n      }\r\n  \r\n      // ...existing code...\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      /**\r\n       * for hiding legends\r\n       * used by weekly charts\r\n       */\r\n      if (this.chartConfiguration.isTopCaptionVisible != undefined) {\r\n        //UPDATENAME\r\n        this.isTopCaptionVisible = this.chartConfiguration.isTopCaptionVisible;\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      var 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  \r\n        .style('overflow-x', 'hidden')\r\n        .style('padding-left', `${margin.left}px`)\r\n        .style('margin-left', '10px')\r\n        .style('padding-right', `${rightSvgWidth}px`);\r\n  \r\n      var svgYAxisLeft = outerContainer\r\n        .append('svg')\r\n        .attr('width', '80')\r\n        .attr('height', height + margin.top + margin.bottom)\r\n        .style('position', 'absolute')\r\n        .style('left', '0')\r\n        .style('z-index', 1)\r\n        .append('g')\r\n        .attr('transform', 'translate(' + (margin.left + 10) + ',' + margin.top + ')');\r\n  \r\n      var svgYAxisRight = outerContainer\r\n        .append('svg')\r\n        .attr('width', rightSvgWidth)\r\n        .attr('height', height + margin.top + margin.bottom)\r\n        .style('position', 'absolute')\r\n        .style('right', '2px')\r\n        .style('z-index', 1)\r\n        .append('g')\r\n        .attr('transform', 'translate(' + 0 + ',' + margin.top + ')');\r\n  \r\n      var 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  \r\n      // Calculate bar width and padding for mobile to avoid overlap and add space between bars\r\n      let barWidth;\r\n      let barPadding = 12; // px, space between bars on mobile\r\n      let requiredSvgWidth;\r\n      if (isMobile) {\r\n        // Use a minimum width per bar and add padding between bars\r\n        const minBarWidth = 32; // px, can adjust as needed\r\n        barWidth = minBarWidth;\r\n        requiredSvgWidth = Math.max(\r\n          width - rightSvgWidth,\r\n          (barWidth + barPadding) * data.length + leftAndRightSpaces * 2 + rightSvgWidth - barPadding // no padding after last bar\r\n        );\r\n        innerContainer.style('overflow-x', 'auto');\r\n      } else {\r\n        barWidth = Math.max(40, (width - rightSvgWidth - leftAndRightSpaces * 2) / data.length);\r\n        barPadding = 0;\r\n        requiredSvgWidth = width - rightSvgWidth;\r\n      }\r\n  \r\n      var svg = innerContainer\r\n        .append('svg')\r\n        .attr('width', requiredSvgWidth)\r\n        .attr('height', height + margin.top + margin.bottom + 30)\r\n        .append('g')\r\n        .attr('transform', 'translate(' + 0 + ',' + margin.top + ')');\r\n  \r\n      let stackKey = keyList;\r\n      var stack: any = d3\r\n        .stack()\r\n        .keys(stackKey)\r\n        /*.order(d3.stackOrder)*/\r\n        .offset(d3.stackOffsetNone);\r\n      var layers: any = stack(data);\r\n      data.sort(function (a, b) {\r\n        return b.total - a.total;\r\n      });\r\n      let lineYscale;\r\n      if (lineData != null) {\r\n        lineYscale = d3\r\n          .scaleLinear()\r\n          .domain([\r\n            0,\r\n            d3.max(lineData, function (d) {\r\n              return +d.value;\r\n            }),\r\n          ])\r\n          .range([height, 0]);\r\n      }\r\n  \r\n      // Calculate bar width for mobile to avoid overlap\r\n      // ...barWidth is now calculated above, remove duplicate...\r\n  \r\n      var xScale = d3\r\n        .scaleBand()\r\n        .rangeRound([\r\n          leftAndRightSpaces,\r\n          width - rightSvgWidth - leftAndRightSpaces\r\n        ])\r\n        .domain(\r\n          data.map(function (d) {\r\n            return d.name;\r\n          })\r\n        )\r\n        .padding(isMobile ? 0.2 : 0.5);\r\n  \r\n      var xScaleFromOrigin = d3\r\n        .scaleBand()\r\n        .rangeRound([width - rightSvgWidth, 0])\r\n        .domain(\r\n          data.map(function (d) {\r\n            return d.name;\r\n          })\r\n        );\r\n      // ...existing code...\r\n      /**\r\n       * draw second x axis on top\r\n       */\r\n      if (self.chartConfiguration.showXaxisTop) {\r\n        svg\r\n          .append('g')\r\n          .attr('class', 'lib-line-axis-text lib-line-x-axis-text x-axis')\r\n          .attr('style', self.chartConfiguration.xAxisCustomTextStyles)\r\n          .call(d3.axisBottom(xScale).tickSize(0));\r\n        svg.selectAll('.x-axis > g > text').attr('class', 'lib-display-hidden');\r\n      }\r\n      /**\r\n       * draw second x axis on top\r\n       */\r\n      // if (self.chartConfiguration.showXaxisAtTarget) {\r\n      //   svg\r\n      //     .append('g')\r\n      //     .attr('class', 'lib-line-axis-text lib-line-x-axis-text x-axis')\r\n      //     .attr('style', self.chartConfiguration.xAxisCustomTextStyles)\r\n      //     .call(d3.axisBottom(xScale).tickSize(0));\r\n      //   svg.selectAll('.x-axis > g > text').attr('class', 'lib-display-hidden');\r\n      // }\r\n  if (this.chartConfiguration.xAxisGrid) {\r\n    for (var j = 0; j < this.chartConfiguration.xAxisGrid.length; j++) {\r\n      svg\r\n        .append('g')\r\n        .attr('class', `x${j + 2} axis${j + 2}`)\r\n        .style('color', 'var(--chart-grid-color)') // Use CSS variable instead of hardcoded\r\n        .attr(\r\n          'transform',\r\n          'translate(0,' + height * this.chartConfiguration.xAxisGrid[j] + ')'\r\n        )\r\n        .call(d3.axisBottom(xScale).tickSize(0).ticks(5).tickFormat(''))\r\n        .style('fill', 'var(--chart-text-color)');\r\n    }\r\n  }\r\n  \r\n      let yScale = d3.scaleLinear().rangeRound([height, 0]);\r\n      /**\r\n       * update max vakues so that the vakue wont exceed the max limit\r\n       * used by weekly charts\r\n       */\r\n      var maxValue = d3.max(layers, (d) => d3.max(d, (d) => d[1]));\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      if (this.chartConfiguration.customYscale) {\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      yScale.domain([0, maxValue]).nice();\r\n  \r\n      let xAxis = d3\r\n        .axisBottom(xScale)\r\n        .tickSize(0)\r\n        .tickFormat(self.chartConfiguration.xAxisLabelFomatter);\r\n  \r\n      let yAxis = d3\r\n        .axisLeft(yScale)\r\n        .ticks(self.chartConfiguration.numberOfYTicks)\r\n        .tickSize(0)\r\n        .tickFormat(self.chartConfiguration.yAxisLabelFomatter);\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       * between x-axis label used by weekly charts\r\n       * isXgridBetweenLabels will be undefined for dashboard 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(' + xScale.bandwidth() / 2 + ',' + height + ')'\r\n          )\r\n          .call(d3.axisBottom(xScale).tickSize(-height).tickFormat(''))\r\n          .style('stroke-dasharray', '5 5')\r\n          .style('color', '#999999')\r\n          // .style(\"opacity\", \"0.5\")\r\n          .call((g) => g.select('.domain').remove());\r\n      }\r\n      /**\r\n       * used to draw y-axis grid\r\n       */\r\n  if (self.chartConfiguration.yAxisGrid) {\r\n    svg\r\n      .append('g')\r\n      .attr('class', 'grid')\r\n      .call(\r\n        d3\r\n          .axisLeft(yScale)\r\n          .ticks(self.chartConfiguration.numberOfYTicks)\r\n          .tickSize(-width)\r\n          .tickFormat('')\r\n      )\r\n      // Remove hardcoded colors and use CSS variables\r\n      .style('color', 'var(--chart-grid-color)')\r\n      .style('opacity', '0.5')\r\n      .call((g) => g.select('.domain').remove());\r\n  }\r\n  \r\n  \r\n      var layer = svg\r\n        .selectAll('.layer')\r\n        .data(layers)\r\n        .enter()\r\n        .append('g')\r\n        .attr('class', 'layer')\r\n        .style('fill', function (d, i) {\r\n          return metaData.colors[d.key];\r\n        });\r\n  \r\n      var rect = layer\r\n        .selectAll('rect')\r\n        .data(function (d) {\r\n          return d;\r\n        })\r\n        .enter();\r\n  \r\n      rect\r\n        .append('rect')\r\n        .on('click', function (d) {\r\n          if (!lineData || self.chartConfiguration.forComparison) {\r\n            if (\r\n              !metaData.barWithoutClick ||\r\n              !metaData.barWithoutClick.length ||\r\n              !metaData.barWithoutClick.includes(d.data.name.toLowerCase())\r\n            )\r\n              self.handleClick(d.data.name);\r\n          }\r\n        })\r\n        .attr('y', function (d) {\r\n          if (!isNaN(d[0]) && !isNaN(d[1])) {\r\n            const actualHeight = yScale(d[0]) - yScale(d[1]);\r\n            return actualHeight < 3 ? yScale(d[0]) - 3 : yScale(d[1]);\r\n          }\r\n          return 0;\r\n        })\r\n        .attr('x', function (d, i) {\r\n          if (isMobile) {\r\n            // On mobile, position bars with padding\r\n            return leftAndRightSpaces + i * (barWidth + barPadding);\r\n          }\r\n          if (self.chartConfiguration.isMultiChartGridLine == undefined) {\r\n            return xScale(d.data.name);\r\n          } else {\r\n            if (\r\n              self.chartConfiguration.isDrilldownChart &&\r\n              self.chartData.data.length <= 3\r\n            ) {\r\n              return xScale(d.data.name) + xScale.bandwidth() / 2 - 35;\r\n            }\r\n            return xScale(d.data.name) + xScale.bandwidth() * 0.1;\r\n          }\r\n        })\r\n        .attr('height', function (d) {\r\n          if (!isNaN(d[0]) && !isNaN(d[1])) {\r\n            const actualHeight = yScale(d[0]) - yScale(d[1]);\r\n            return actualHeight < 3 ? 3 : actualHeight;\r\n          }\r\n          return 0;\r\n        })\r\n        .attr('width', function (d) {\r\n          // Use calculated barWidth for mobile, otherwise scale\r\n          if (isMobile) {\r\n            return barWidth;\r\n          }\r\n          return self.chartConfiguration.isMultiChartGridLine == undefined\r\n            ? xScale.bandwidth()\r\n            : self.chartConfiguration.isDrilldownChart &&\r\n              self.chartData.data.length <= 3\r\n              ? 70\r\n              : xScale.bandwidth() * 0.8;\r\n        })\r\n        // .style('cursor', 'pointer');\r\n        .style('cursor', function (d) {\r\n          if (metaData.hasDrillDown) {\r\n            if (\r\n              metaData.barWithoutClick.length > 0 &&\r\n              metaData.barWithoutClick.includes(d.data.name.toLowerCase())\r\n            ) {\r\n              return 'default';\r\n            }\r\n            return 'pointer';\r\n          } else return 'default';\r\n        })\r\n        .style('fill', function (d) {\r\n          if (\r\n            !isNaN(d[0]) &&\r\n            !isNaN(d[1]) &&\r\n            self.chartData.targetLineData &&\r\n            parseFloat(d[1]) - parseFloat(d[0]) >=\r\n            parseFloat(self.chartData.targetLineData.target)\r\n          )\r\n            return self.chartData?.targetLineData?.barAboveTargetColor;\r\n  \r\n          return metaData.colors[d.key];\r\n        });\r\n      /**\r\n       * do not show valus on hover as its alreay dislayed\r\n       */\r\n      if (!this.isCC && !self.chartConfiguration.isMultiChartGridLine) {\r\n        rect\r\n          .append('svg:title') // TITLE APPENDED HERE\r\n          .text(function (d) {\r\n            return d[1] - d[0];\r\n          });\r\n      }\r\n      if (this.isCC) {\r\n        rect\r\n          .append('text')\r\n          .attr('x', function (d) {\r\n            return xScale(d.data.name);\r\n          })\r\n          .attr('text-anchor', function (d) {\r\n            if (!d[0]) {\r\n              return 'end';\r\n            } else {\r\n              return 'start';\r\n            }\r\n          })\r\n          .attr('class', 'verticalbar__text')\r\n          .attr('y', function (d) {\r\n            if (!d[0]) {\r\n              return yScale(d[1]);\r\n            } else {\r\n              return yScale(d[1]) - 7;\r\n            }\r\n          })\r\n          // .attr(\"y\", function (d) { return yScale(d[0]) - yScale(d[1]); })\r\n          .attr('dy', function (d) {\r\n            return d.class;\r\n          })\r\n          .text(function (d) {\r\n            if (!d[0]) {\r\n              if (!isNaN(d[1] - d[0])) {\r\n                return Math.round((d[1] - d[0]) * 100) / 100;\r\n              } else return;\r\n            } else {\r\n              if (!isNaN(d[1])) {\r\n                return Math.round(d[1] * 100) / 100;\r\n              } else return;\r\n            }\r\n          });\r\n      }\r\n  \r\n      /**\r\n         svg\r\n          .append('foreignObject')\r\n          .attr('transform', 'translate(' + 0 + ',' + (yZero - 25) + ')')\r\n          .attr('width', width)\r\n          .attr('height', 30)\r\n          .append('xhtml:div')\r\n          .attr('class', 'target-display')\r\n          .style('color', this.chartData.targetLineData.color)\r\n   */\r\n  \r\n      /**\r\n       * on hover, display title on top\r\n       */\r\n      function handleMouseOver(d, i) {\r\n        if (!self.chartConfiguration.displayTitleOnTop) {\r\n          return;\r\n        }\r\n        svg\r\n          .selectAll('rect')\r\n          .filter(function (data) {\r\n            return data == d;\r\n          })\r\n          .style('fill', function (d) {\r\n            if (\r\n              !isNaN(d[0]) &&\r\n              !isNaN(d[1]) &&\r\n              self.chartData.targetLineData &&\r\n              parseFloat(d[1]) - parseFloat(d[0]) >=\r\n              parseFloat(self.chartData.targetLineData.target)\r\n            )\r\n              return self.chartData.targetLineData.barAboveTargetHoverColor\r\n                ? self.chartData.targetLineData.barAboveTargetHoverColor\r\n                : self.chartData?.targetLineData?.barAboveTargetColor\r\n                  ? self.chartData?.targetLineData?.barAboveTargetColor\r\n                  : '';\r\n  \r\n            return metaData.hoverColor ? metaData.hoverColor : '';\r\n          });\r\n  \r\n        svg\r\n          .append('foreignObject')\r\n          .attr('x', function () {\r\n            if (xScale.bandwidth() + leftAndRightSpaces * 2 > 180) {\r\n              return (\r\n                xScale(d.data.name) -\r\n                leftAndRightSpaces +\r\n                (xScale.bandwidth() + leftAndRightSpaces * 2 - 180) / 2\r\n              );\r\n            }\r\n            return xScale(d.data.name) - leftAndRightSpaces;\r\n          })\r\n          .attr('class', 'lib-verticalstack-title-ontop')\r\n          .attr('y', function () {\r\n            // Increase the gap between the bar and the tooltip (was -1 - 40)\r\n            return yScale(d[1]) - 1 - 50; // 10px more gap\r\n          })\r\n          .attr('dy', function () {\r\n            return d.class;\r\n          })\r\n          .attr('width', function () {\r\n            if (xScale.bandwidth() + leftAndRightSpaces * 2 > 180) {\r\n              return '180px';\r\n            }\r\n            return xScale.bandwidth() + leftAndRightSpaces * 2;\r\n          })\r\n          .attr('height', 40)\r\n          .append('xhtml:div')\r\n          .attr('class', 'title')\r\n          .style('z-index', 99)\r\n          .html(function () {\r\n            // Tooltip content without any arrow mark\r\n            if (!isNaN(d[1] - d[0])) {\r\n              if (d[1] - d[0] === 0) {\r\n                return '<span class=\"title-top-text\">0</span>';\r\n              }\r\n              var dataType = metaData.dataType ? metaData.dataType : '';\r\n              var desiredText = '';\r\n              // Always show the full x-axis label (category name) in the tooltip\r\n              desiredText =\r\n                '<span class=\"title-bar-name\">' +\r\n                (d.data.name ? d.data.name : '') +\r\n                '</span>';\r\n  \r\n              desiredText += metaData.unit\r\n                ? '<span class=\"title-top-text\">' +\r\n                metaData.unit +\r\n                (d[1] - d[0]) +\r\n                dataType +\r\n                '</span>'\r\n                : '<span class=\"title-top-text\">' +\r\n                (d[1] - d[0]) +\r\n                dataType +\r\n                '</span>';\r\n  \r\n              // No arrow mark or arrow HTML/CSS in tooltip\r\n              return desiredText;\r\n            } else return;\r\n          });\r\n  \r\n      }\r\n      function handleMouseOut(d, i) {\r\n        if (!self.chartConfiguration.displayTitleOnTop) {\r\n          return;\r\n        }\r\n        // svg.selectAll('rect').style('fill', metaData.colors[d.key]);\r\n        svg.selectAll('rect').style('fill', function (d) {\r\n          if (\r\n            !isNaN(d[0]) &&\r\n            !isNaN(d[1]) &&\r\n            self.chartData.targetLineData &&\r\n            parseFloat(d[1]) - parseFloat(d[0]) >=\r\n            parseFloat(self.chartData.targetLineData.target)\r\n          )\r\n            return self.chartData?.targetLineData?.barAboveTargetColor;\r\n  \r\n          return metaData.colors[d.key];\r\n        });\r\n        svg.selectAll('.lib-verticalstack-title-ontop').remove();\r\n      }\r\n  \r\n      /**\r\n       * used to show value on top of the bars\r\n       * need to be used by bar charts only(one bar should contain one value)\r\n       * used by weekly charts\r\n       */\r\n      if (this.chartConfiguration.showTotalOnTop != undefined) {\r\n        rect\r\n          .append('text')\r\n          .attr('x', function (d) {\r\n            return xScale(d.data.name) + xScale.bandwidth() / 2;\r\n          })\r\n          .attr('class', 'lib-verticalstack-labels-ontop-weklycharts')\r\n          .attr('y', function (d) {\r\n            return yScale(d[1]) - 3;\r\n          })\r\n          .attr('dy', function (d) {\r\n            return d.class;\r\n          })\r\n          .text(function (d) {\r\n            if (!isNaN(d[1] - d[0])) {\r\n              if (d[1] - d[0] == 0) {\r\n                return;\r\n              }\r\n              if (d[1] - d[0] <= 999)\r\n                return metaData.unit\r\n                  ? metaData.unit + formatFromBackend(d[1] - d[0])\r\n                  : formatFromBackend(d[1] - d[0]);\r\n              else\r\n                return metaData.unit\r\n                  ? metaData.unit + formatForHugeNumbers(d[1] - d[0])\r\n                  : formatForHugeNumbers(d[1] - d[0]);\r\n            } else return;\r\n          });\r\n      }\r\n      /**\r\n       * used to show angled values on top of the bars\r\n       * used by weekly charts\r\n       */\r\n      if (this.chartConfiguration.showAngledLabels != undefined) {\r\n        rect\r\n          .append('text')\r\n          .attr('x', 0)\r\n          .attr('fill', function (d, i) {\r\n            return metaData.colors[d.key];\r\n          })\r\n          .attr('class', 'lib-data-labels-angled-weeklycharts')\r\n          .attr('y', 0)\r\n          .attr('dy', function (d) {\r\n            return d.class;\r\n          })\r\n          .text(function (d) {\r\n            if (!isNaN(d[1] - d[0]) && d[1] - d[0] > 0) {\r\n              if (d[1] - d[0] <= 999)\r\n                return metaData.unit\r\n                  ? metaData.unit + formatFromBackend(d[1] - d[0])\r\n                  : formatFromBackend(d[1] - d[0]);\r\n              else return metaData.unit + formatForHugeNumbers(d[1] - d[0]);\r\n            } else return;\r\n          })\r\n          .attr('transform', function (d) {\r\n            if (!isNaN(d[1] - d[0]) && d[1] - d[0] > 0) {\r\n              var total = 0;\r\n              var incrementer: number = 1;\r\n              metaData.keyList.forEach((key) => {\r\n                if (d.data[key]) total = total + d.data[key];\r\n                else incrementer = 2;\r\n              });\r\n              if (tempObjectHolder[d.data.name] == undefined) {\r\n                tempObjectHolder[d.data.name] = 1;\r\n              } else {\r\n                tempObjectHolder[d.data.name] =\r\n                  tempObjectHolder[d.data.name] + incrementer;\r\n              }\r\n              switch (tempObjectHolder[d.data.name]) {\r\n                case 1:\r\n                  return (\r\n                    'translate(' +\r\n                    (xScale(d.data.name) + xScale.bandwidth() / 3) +\r\n                    ',' +\r\n                    (yScale(total) - 3) +\r\n                    ') rotate(270)'\r\n                  );\r\n                case 2:\r\n                  return (\r\n                    'translate(' +\r\n                    (xScale(d.data.name) + xScale.bandwidth() / 2 + 2) +\r\n                    ',' +\r\n                    (yScale(total) - 3) +\r\n                    ') rotate(270)'\r\n                  );\r\n                default:\r\n                  return (\r\n                    'translate(' +\r\n                    (xScale(d.data.name) + (xScale.bandwidth() * 3) / 4) +\r\n                    ',' +\r\n                    (yScale(total) - 3) +\r\n                    ') rotate(270)'\r\n                  );\r\n              }\r\n            }\r\n            return 'rotate(0)';\r\n          });\r\n      }\r\n  if (this.chartConfiguration.isMultiChartGridLine == undefined) {\r\n    if (isMobile) {\r\n      // Custom x-axis label rendering for mobile: evenly distribute under each bar\r\n      svg.selectAll('.custom-x-label').remove();\r\n      data.forEach(function (d, i) {\r\n        const xVal = leftAndRightSpaces + i * (barWidth + barPadding) + barWidth / 2;\r\n        svg.append('text')\r\n          .attr('class', 'custom-x-label')\r\n          .attr('x', 0)\r\n          .attr('y', height + 18)\r\n          .attr('text-anchor', 'middle')\r\n          .attr('transform', 'translate(' + (xVal + 20) + ',0)') // current value + 20\r\n          .style('font-size', '10px')\r\n          .style('fill', 'var(--chart-text-color)')\r\n          .style('writing-mode', 'sideways-lr') // writing mode for mobile\r\n          .text(d.name.substring(0, 3));\r\n      });\r\n    } else {\r\n      svg\r\n        .append('g')\r\n        .attr('transform', 'translate(0,' + height + ')')\r\n        .attr('class', 'lib-stacked-x-axis-text')\r\n        .call(xAxis)\r\n        .selectAll('text')\r\n        .style('fill', 'var(--chart-text-color)')\r\n        .style('font-size', '12px')\r\n        .attr('text-anchor', 'middle')\r\n        .attr('dx', '0')\r\n        .attr('dy', '0.71em')\r\n        .attr('transform', null)\r\n        .text(function (d) {\r\n          return d;\r\n        });\r\n    }\r\n  \r\n    svg\r\n      .append('g')\r\n      .attr('class', 'lib-stacked-y-axis-text')\r\n      .attr('style', self.chartConfiguration.yAxisCustomTextStyles)\r\n      .attr('transform', 'translate(0,0)')\r\n      .call(yAxis)\r\n      .selectAll('text')\r\n    .style('fill', 'var(--chart-text-color)');\r\n  }else if (this.chartConfiguration.isDrilldownChart) {\r\n    svg\r\n      .append('g')\r\n      .attr('transform', 'translate(0,' + height + ')')\r\n      .attr('class', 'lib-stacked-x-axis-text multichart1')\r\n      .call(xAxis)\r\n      .style('display', 'none')\r\n  \r\n    svgYAxisLeft\r\n      .append('g')\r\n      .attr('class', 'lib-yaxis-labels-texts-drilldown yaxis-dashed')\r\n      .attr('style', self.chartConfiguration.yAxisCustomTextStyles)\r\n      .attr('transform', 'translate(0,0)')\r\n      .call(yAxis)\r\n        .selectAll('text')\r\n    .style('fill', 'var(--chart-text-color)');\r\n      \r\n    svgYAxisRight\r\n      .append('g')\r\n      .attr('class', 'lib-yaxis-labels-texts-drilldown yaxis-dashed')\r\n      .attr('style', self.chartConfiguration.yAxisCustomTextStyles)\r\n      .attr('transform', 'translate(0,0)')\r\n      .call(yAxis)\r\n      .style('display', 'none')\r\n  }\r\n  else {\r\n    svg\r\n      .append('g')\r\n      .attr('transform', 'translate(0,' + height + ')')\r\n      .attr('class', 'lib-stacked-x-axis-text multichart')\r\n      .attr('transform', 'translate(0,' + height + ')')\r\n      .call(xAxis)\r\n      .selectAll('text')\r\n    .style('fill', 'var(--chart-text-color)');\r\n  \r\n    svg\r\n      .append('g')\r\n      .attr('class', 'lib-stacked-y-axis-text yaxis-dashed')\r\n      .attr('style', self.chartConfiguration.yAxisCustomTextStyles)\r\n      .attr('transform', 'translate(0,0)')\r\n      .call(yAxis)\r\n        .selectAll('text')\r\n    .style('fill', 'var(--chart-text-color)');\r\n  }\r\n      /**\r\n       * for existing charts, place xaxis labels nearer to xaxis\r\n       * used by existing charts\r\n       */\r\n      if (this.chartConfiguration.isMultiChartGridLine == undefined) {\r\n        d3.selectAll('g.lib-stacked-x-axis-text g.tick text').attr(\r\n          'y',\r\n          function () {\r\n            if (alternate_text) {\r\n              alternate_text = false;\r\n              return long_tick_length + 1;\r\n            } else {\r\n              alternate_text = true;\r\n              return short_tick_length + 1;\r\n            }\r\n          }\r\n        );\r\n      } else {\r\n        d3.selectAll('.multichart > g > text').attr(\r\n          'class',\r\n          'lib-display-hidden'\r\n        );\r\n      }\r\n      /**\r\n       * based of the flag, hide or show xaxis texts\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('.multichart > g > text').attr(\r\n          'class',\r\n          'lib-display-hidden'\r\n        );\r\n      } else if (this.chartConfiguration.isXaxisLabelHidden != undefined) {\r\n        svg\r\n          .append('g')\r\n          .attr('class', 'x1 axis1')\r\n          .attr('transform', 'translate(0,' + height + ')')\r\n          .style('color', '#000')\r\n  \r\n          .call(d3.axisBottom(xScale).tickSize(0))\r\n          .call((g) => g.select('.domain').attr('fill', 'none'));\r\n        svg\r\n          .append('g')\r\n          .attr('class', 'x2 axis2')\r\n          .attr('transform', 'translate(0,' + height + ')')\r\n          .style('color', '#000')\r\n  \r\n          .call(d3.axisBottom(xScaleFromOrigin).tickSize(0))\r\n          .call((g) => g.select('.domain').attr('fill', 'none'));\r\n        svg.selectAll('.axis2 > g > text').attr('class', 'lib-display-hidden');\r\n        // svg.selectAll('g.x2.axis2 g.tick text').style('display', 'none');\r\n        svg.selectAll('.x1.axis1 .tick line').attr('y2', function () {\r\n          if (self.chartConfiguration.hideXaxisTick) {\r\n            return 0;\r\n          }\r\n          /**\r\n           * isNoAlternateXaxisText is used to prevent x-axis label to be displayed in alternate fashion\r\n           * for future use\r\n           */\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 texts also follow the pattern of ticks\r\n         * used by weekly charts\r\n         */\r\n        alternate_text = false;\r\n        svg\r\n          .selectAll('g.x1.axis1 g.tick text')\r\n          // .attr('class', 'lib-xaxis-labels-texts-weeklycharts')\r\n          .attr('class', function () {\r\n            if (self.chartConfiguration.isDrilldownChart) {\r\n              if (data && data.length > 8) {\r\n                return 'lib-xaxis-labels-texts-drilldown-alt';\r\n              }\r\n              return 'lib-xaxis-labels-texts-drilldown';\r\n            } else return 'lib-xaxis-labels-texts-weeklycharts';\r\n          })\r\n          .attr('y', function () {\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        svg\r\n          .selectAll('g.x1.axis1 g.tick text')\r\n          .attr('class', 'lib-xaxis-labels-texts-drilldown')\r\n          .attr('y', short_tick_length_bg)\r\n          .text(function (d, i) {\r\n            if (isMobile) {\r\n              // If label has more than one word, show only first 3 letters of first word\r\n              var firstWord = d.split(' ')[0];\r\n              return firstWord.substring(0, 3);\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          .attr('transform', function(this: SVGTextElement, d, i) {\r\n            if (isMobile) {\r\n              var totalBars = 0;\r\n              if (this.parentNode && this.parentNode.parentNode) {\r\n                totalBars = d3.select(this.parentNode.parentNode).selectAll('g.tick').size();\r\n              }\r\n              if (totalBars === 2) {\r\n                return 'translate(0,0)';\r\n              } else {\r\n                return 'translate(' + (i * 30) + ',0)';\r\n              }\r\n            }\r\n            return null;\r\n          });\r\n        svg\r\n          .selectAll('g.x1.axis1 g.tick')\r\n          .append('text')\r\n          .attr('class', 'lib-xaxis-labels-texts-drilldown')\r\n          .attr('y', long_tick_length_bg)\r\n          .attr('fill', 'currentColor')\r\n          .text(function (d) {\r\n            // For mobile, do not print the second word at all\r\n            if (isMobile) {\r\n              return '';\r\n            }\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          .attr('transform', function(d, i) {\r\n            if (isMobile && i === 0) {\r\n              return 'translate(20,0)';\r\n            }\r\n            return null;\r\n          });\r\n      }\r\n      /**\r\n       * hide yaxis values\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        svg\r\n          .selectAll('.yaxis-dashed > g > text')\r\n          .attr('class', 'lib-display-hidden');\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-grid-color)'); // Use CSS variable\r\n  }\r\n      /**\r\n       * x axis color\r\n       * used by weekly charts\r\n       */\r\n  if (this.chartConfiguration.isXaxisColor != undefined) {\r\n    d3.selectAll('.multichart').style(\r\n      'color',\r\n      this.chartConfiguration.isXaxisColor || 'var(--chart-text-color)'\r\n    );\r\n  }\r\n      /**\r\n       * used to display y label\r\n       */\r\n  if (this.isZoomedOut) {\r\n    svg\r\n      .selectAll('.lib-xaxis-labels-texts-drilldown')\r\n      .attr('transform', 'rotate(-90)')\r\n      .attr('text-anchor', 'end')\r\n      .attr('x', '-5')\r\n      .attr('dy', null);\r\n  }\r\n  \r\n  function styleAxisDomain() {\r\n    svg.selectAll('.domain')\r\n      .style('stroke', 'var(--chart-axis-color)')\r\n      .style('stroke-width', '1px');\r\n    \r\n    svgYAxisLeft.selectAll('.domain')\r\n      .style('stroke', 'var(--chart-axis-color)')\r\n      .style('stroke-width', '1px');\r\n      \r\n    svgYAxisRight.selectAll('.domain')\r\n      .style('stroke', 'var(--chart-axis-color)')\r\n      .style('stroke-width', '1px');\r\n  }\r\n  \r\n  styleAxisDomain();\r\n  \r\n      if (metaData.yLabel) {\r\n        svgYAxisLeft.selectAll('.lib-axis-group-label, .lib-ylabel-drilldowncharts, .lib-ylabel-weeklyCharts').remove();\r\n        function isAcronym(label) {\r\n          return (label.length <= 4 && /^[A-Z]+$/.test(label)) || (label === label.toUpperCase() && /[A-Z]/.test(label));\r\n        }\r\n        const yLabelText = metaData.yLabel;\r\n        const isAcr = isAcronym(yLabelText.replace(/[^A-Za-z]/g, ''));\r\n  \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  \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-ylabel-drilldowncharts';\r\n            if (self.chartConfiguration.isMultiChartGridLine != undefined)\r\n              return baseClass + ' lib-ylabel-weeklyCharts';\r\n            return baseClass + ' lib-axis-waterfall-label';\r\n          })\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          .style('fill', 'var(--chart-text-color)')\r\n          .style('color', 'var(--chart-text-color)')\r\n          .text(isAcr ? yLabelText.toUpperCase() : yLabelText.toLowerCase())\r\n          .style('text-transform', isAcr ? 'none' : 'capitalize');\r\n      }\r\n      if (this.chartData.targetLineData) {\r\n        const yZero = yScale(parsedNum);\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  \r\n          .html(function (d, i) {\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      rect\r\n        .selectAll('rect')\r\n        .on('mouseenter', handleMouseOver)\r\n        .on('mouseout', handleMouseOut);\r\n      if (metaData.lineyLabel) {\r\n        svg\r\n          .append('text')\r\n          .attr('class', 'lib-axis-group-label lib-line-axis')\r\n          .attr('style', self.chartConfiguration.yAxisCustomlabelStyles)\r\n          .attr('transform', 'translate(' + (width - 20) + ',0) rotate(90)')\r\n          .attr('y', 0 - margin.right * 3)\r\n          .attr('x', height / 2)\r\n          .attr('dy', '5em')\r\n          .style('text-anchor', 'middle')\r\n          .text(metaData.lineyLabel);\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 + 10);\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      \r\n      if (lineData && colors) {\r\n        var dataGroup = d3\r\n          .nest()\r\n          .key(function (d) {\r\n            return d.category;\r\n          })\r\n          .entries(lineData);\r\n  \r\n        var lineGen = d3\r\n          .line()\r\n          .x(function (d) {\r\n            return xScale(d.name) + xScale.bandwidth() / 2;\r\n          })\r\n          .y(function (d) {\r\n            return lineYscale(d.value);\r\n          });\r\n  \r\n        var calculateCX = (d) => {\r\n          return xScale(d.name) + xScale.bandwidth() / 2;\r\n        };\r\n  \r\n        var calculateCY = (d) => {\r\n          return lineYscale(d.value);\r\n        };\r\n  \r\n        dataGroup.forEach(function (d, i) {\r\n          svg\r\n            .append('path')\r\n            .datum(d.values)\r\n            .attr('fill', 'none')\r\n            .attr('stroke', function (d) {\r\n              if ('category' in d[0]) {\r\n                return colors[d[0].category];\r\n              } else {\r\n                return self.chartConfiguration.lineGraphColor;\r\n              }\r\n            })\r\n            .attr('stroke-width', 2.5) /**line thinkness */\r\n            .attr('d', lineGen(d.values));\r\n  \r\n          var dot = svg\r\n            .selectAll('myCircles')\r\n            .data(d.values)\r\n            .enter()\r\n            .append('g')\r\n            .on('click', function (d) {\r\n              self.handleClick(d);\r\n            });\r\n  \r\n          dot\r\n            .append('circle')\r\n            .attr('fill', function (d) {\r\n              if ('category' in d) {\r\n                return colors[d.category];\r\n              } else {\r\n                return self.chartConfiguration.lineGraphColor;\r\n              }\r\n            })\r\n            .attr('stroke', 'none')\r\n            .attr('cx', function (d, i) {\r\n              return xScale(d.name) + xScale.bandwidth() / 2;\r\n            })\r\n            .attr('cy', function (d, i) {\r\n              return lineYscale(d.value);\r\n            })\r\n            .attr('r', 3) /**radius of circle=5 */\r\n            .style('cursor', 'pointer');\r\n  \r\n          if (self.chartConfiguration.lineGraphColor) {\r\n            dot\r\n              .append('text')\r\n              .attr('class', 'dots')\r\n              .attr('fill', self.chartConfiguration.lineGraphColor)\r\n              .attr('style', 'font-size: ' + '.85em;' + 'font-weight:' + 'bold')\r\n              .attr('x', function (d, i) {\r\n                return xScale(d.name) + xScale.bandwidth() / 2;\r\n              })\r\n              .attr('y', function (d, i) {\r\n                return lineYscale(d.value);\r\n              })\r\n              .attr('dy', '-1em')\r\n              .text(function (d, i) {\r\n                return self.chartConfiguration.labelFormatter(d.value);\r\n              });\r\n          }\r\n        });\r\n      }\r\n      // svg.attr('width', 150).style('max-width', 150).style('overflow-x', 'auto');\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    handleCompareByFilterSelection(event) {\r\n      this.clickEvent.emit(event);\r\n    }\r\n    handleZoominZoomoutClick({ isZoomOut, event }) {\r\n      this.isZoomOutSelected(isZoomOut);\r\n    } \r\n  }","<div\r\n  #groupcontainer\r\n  class=\"lib-chart-wrapper\"\r\n  [ngClass]=\"{ 'lib-no-background': isTransparentBackground }\"\r\n  [style.background-color]=\"chartConfiguration.backgroundColor\"\r\n  (resized)=\"onResized($event)\"\r\n>\r\n\r\n<div class=\"header-alt\" *ngIf=\"!isHeaderVisible\">\r\n  <lib-chart-header-v2\r\n    [chartData]=\"chartData\"\r\n    [chartConfiguration]=\"chartConfiguration\"\r\n    (clickEvent)=\"handleClick($event)\"\r\n  ></lib-chart-header-v2>\r\n  <lib-chart-header-v3\r\n    [chartData]=\"chartData\"\r\n    [chartConfiguration]=\"chartConfiguration\"\r\n    (compareByFilterSelection)=\"handleCompareByFilterSelection($event)\"\r\n    (zoomInZoomOutClick)=\"handleZoominZoomoutClick($event)\"\r\n  ></lib-chart-header-v3>\r\n</div>\r\n\r\n  <lib-chart-header-v1\r\n  [title]=\"chartData.metaData.title\"\r\n  [hasDrillDown]=\"chartData.metaData.hasDrillDown\"\r\n  [isEditEnabled]=\"chartData.metaData.isEditEnabled\"\r\n  [menuOptions]=\"chartConfiguration.headerMenuOptions\"\r\n  [isria]=\"customChartConfiguration.isRia\"\r\n  [selectedKpiTooltop]=\"chartConfiguration.selectedKpiTooltop\"\r\n  (menuOptionClickEvent)=\"handleHeaderMenuClick($event)\"\r\n  [isAlertEnabled]=\"isAlertEnabled\"\r\n  *ngIf=\"isHeaderVisible\"\r\n></lib-chart-header-v1>\r\n\r\n  <div\r\n    [style.height]=\"chartConfiguration.svgHeight\"\r\n    id=\"groupchartcontainer\"\r\n    #groupchartcontainer\r\n    class=\"lib-chart-svg\"\r\n  ></div>\r\n</div>\r\n"]}
1372
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"group-chart.component.js","sourceRoot":"","sources":["../../../../../projects/axidio-styleguide-library/src/lib/group-chart/group-chart.component.ts","../../../../../projects/axidio-styleguide-library/src/lib/group-chart/group-chart.component.html"],"names":[],"mappings":"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","sourcesContent":["  import {\r\n    Component,\r\n    OnInit,\r\n    ViewChild,\r\n    ElementRef,\r\n    Input,\r\n    Output,\r\n    EventEmitter,\r\n    ViewEncapsulation,\r\n  } from '@angular/core';\r\n  import { ComponentUniqueId } from '../unique-id';\r\n  import ChartHelper from '../chart-helper';\r\n  import * as d3 from 'd3';\r\n  import { ResizedEvent } from 'angular-resize-event';\r\n  import HeaderConfigHelper from '../header-config';\r\n\r\n  @Component({\r\n    selector: 'lib-group-chart',\r\n    templateUrl: './group-chart.component.html',\r\n    styleUrls: ['./group-chart.component.less', '../common-styles.less'],\r\n    encapsulation: ViewEncapsulation.None,\r\n  })\r\n  export class GroupChartComponent extends ComponentUniqueId implements OnInit {\r\n      @ViewChild('groupchartcontainer', { static: true })\r\n      containerElt!: ElementRef;\r\n    \r\n      @ViewChild('groupcontainer', { static: true })\r\n      groupcontainerElt!: ElementRef;\r\n\r\n        @Input() chartData: any;\r\n        @Input() customChartConfiguration: any;\r\n        @Output() clickEvent = new EventEmitter<any>();\r\n        @Output() headerMenuclickEvent = new EventEmitter<any>();\r\n        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          var width =\r\n            parseInt(chartContainer.style('width')) - margin.left - margin.right;\r\n          if (this.chartData.data.length > 30 && this.isZoomedOut) {\r\n            width =\r\n              width > this.chartData.data.length * 40\r\n                ? this.chartData.dropdownData1\r\n                  ? this.chartData.data.length * 60\r\n                  : width\r\n                : this.chartData.dropdownData1\r\n                ? this.chartData.data.length * 60\r\n                : this.chartData.data.length * 40;\r\n      \r\n            width =\r\n              width > this.chartData.data.length * 40\r\n                ? width\r\n                : this.chartData.data.length * 40;\r\n          }\r\n          if (\r\n            this.chartData.dropdownData2 &&\r\n            width < this.chartData.data.length * 120 &&\r\n            this.isZoomedOut\r\n          ) {\r\n            width = this.chartData.data.length * 120;\r\n          }\r\n          if (this.chartData.data.length > 8 && !this.isZoomedOut) {\r\n            if (\r\n              this.chartData.dropdownData2 &&\r\n              width < this.chartData.data.length * 250\r\n            ) {\r\n              width = this.chartData.data.length * 250;\r\n            } else width = this.chartData.data.length * 160;\r\n          }\r\n          // if (this.chartData.data.length > 8) {\r\n          //   width = this.chartData.data.length * 140;\r\n          // }\r\n      \r\n          var 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           * entire height used in weekly charts as x axis needed to be displayed at the bottom of the chart\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          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           * 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          var 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      \r\n            .style('overflow-x', 'hidden')\r\n            .style('padding-left', `${margin.left}px`)\r\n            // .call(ChartHelper.responsivefy)\r\n      \r\n            .style('padding-right', `${rightSvgWidth}px`)\r\n            .style('margin-left', '15px');\r\n          var 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(\r\n              'transform',\r\n              'translate(' + (margin.left + 15) + ',' + margin.top + ')'\r\n            );\r\n      \r\n          var 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          var 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          var svg = innerContainer\r\n            .append('svg')\r\n            // .attr('id', self.uniqueId)\r\n            .attr('width', width - rightSvgWidth)\r\n            .attr('height', height + margin.top + margin.bottom + 30)\r\n            // .call(ChartHelper.responsivefy)\r\n            .append('g')\r\n            .attr('transform', 'translate(' + 0 + ',' + margin.top + ')');\r\n      \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           * draw second x axis on top\r\n           */\r\n          // if (self.chartConfiguration.showXaxisTop) {\r\n          //   svg\r\n          //     .append('g')\r\n          //     .attr('class', 'lib-line-axis-text lib-line-x-axis-text x-axis')\r\n          //     .attr('style', self.chartConfiguration.xAxisCustomTextStyles)\r\n          //     .call(d3.axisBottom(x).tickSize(0));\r\n          // }\r\n          // d3.svg.axis().scale(x).orient('bottom').ticks(1).innerTickSize(-height);\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            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            // .attr('y', function () {\r\n            //   if (alternate_text) {\r\n            //     alternate_text = false;\r\n            //     return long_tick_length + 1;\r\n            //   } else {\r\n            //     alternate_text = true;\r\n            //     return short_tick_length + 1;\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                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            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(\r\n                'y',\r\n                this.isHeaderVisible\r\n                  ? short_tick_length_bg + 25\r\n                  : short_tick_length_bg\r\n              )\r\n              .attr('x', function (d) {\r\n                if (self.chartData.data.length > 8 && !self.isZoomedOut) {\r\n                  return -25; // Move first line text slightly to the left too\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      \r\n                  return firstPart.substring(0, 3).toLowerCase();\r\n                }\r\n                data.map((indiv: any) => {\r\n                  if (\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                // If label looks like a date (contains digits and - or /), show full label as one line\r\n                if (/\\d{2,4}[-\\/]/.test(d)) {\r\n                  return d;\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            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 -25; // 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 (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          if (self.chartConfiguration.yAxisGrid) {\r\n            // svg\r\n            //   .append('g')\r\n            //   .attr('class', 'grid')\r\n            //   .call(\r\n            //     d3\r\n            //       .axisLeft(y)\r\n            //       .ticks(self.chartConfiguration.numberOfYTicks)\r\n            //       .tickSize(-width)\r\n            //       .tickFormat('')\r\n            //   )\r\n            //   // .style('stroke-dasharray', '5 5')\r\n            //   .style('color', '#B9B9B9')\r\n            //   .style('opacity', '0.5')\r\n            //   .call((g) => g.select('.domain').remove());\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 (this.chartConfiguration.isMultiChartGridLine == undefined) {\r\n            xSubgroup.range([0, x.bandwidth()]);\r\n          } else {\r\n            /**\r\n             * used to make grouped bars with lesser width as we are not using padding for width\r\n             * used by weekly charts\r\n             */\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                      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() - 125) / 2,\r\n                            x.bandwidth() - (x.bandwidth() - 125) / 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                        // .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                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              if (self.chartConfiguration.isDrilldownChart) {\r\n                // var tempScale;\r\n      \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() - 125) / 2,\r\n                            x.bandwidth() - (x.bandwidth() - 125) / 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                        // .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                return self.isZoomedOut\r\n                  ? tempScale.bandwidth()\r\n                  : self.chartData.data.length && self.chartData.data.length > 8\r\n                  ? tempScale.bandwidth() * 0.5\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() * 0.5\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', () =>\r\n              self.chartData.metaData.hasDrillDown ? 'pointer' : '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 >= parseInt(self.chartData.targetLineData.target) &&\r\n                self.chartData.metaData.colorAboveTarget\r\n              )\r\n                return self.chartData.metaData.colorAboveTarget[d.key];\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            state\r\n              .selectAll('.lib-data-labels-weeklycharts')\r\n              .on('mouseout', handleMouseOut)\r\n              .on('mouseover', handleMouseOver);\r\n          }\r\n          if (this.chartConfiguration.displayTitleOnTop) {\r\n            state\r\n              .selectAll('rect')\r\n              .on('mouseout', handleMouseOut)\r\n              .on('mouseover', handleMouseOver);\r\n          }\r\n          function handleMouseOver(d, i) {\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', 40)\r\n              .append('xhtml:div')\r\n              .attr('class', 'title')\r\n              .style('z-index', 99)\r\n              .html(function () {\r\n                // Show the x-axis label (bar name) for this bar, not the date or any other value\r\n                let barLabel = d.name; // This is the x-axis label for the bar\r\n                let dataType = metaData.dataType ? metaData.dataType : '';\r\n                let value = d.value;\r\n                let key = d.key;\r\n                // Tooltip: show x-axis label and value, but do not show date\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            if (!self.chartConfiguration.displayTitleOnTop) {\r\n              return;\r\n            }\r\n            svg.selectAll('.lib-verticalstack-title-ontop').remove();\r\n          }\r\n          /**\r\n           * display data values on mouse over\r\n           * used by dashboard charts\r\n           */\r\n          if (\r\n            this.chartConfiguration.textsOnBar == undefined &&\r\n            this.chartConfiguration.displayTitleOnTop == undefined\r\n          ) {\r\n            state\r\n              .selectAll('rect')\r\n              .on('mouseout', function (d) {\r\n                state.selectAll('.barstext').remove();\r\n              })\r\n              .on('mouseover', function (d1) {\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                      if (\r\n                        key !== 'name' &&\r\n                        d1.key == key &&\r\n                        d1.value == d[key] &&\r\n                        d1.name == d.name\r\n                      ) {\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('text')\r\n                  .attr('fill', 'var(--chart-text-color)')\r\n                  .attr('class', 'barstext')\r\n                  .attr('x', function (d) {\r\n                    return xSubgroup(d.key);\r\n                  })\r\n                  .attr('y', function (d) {\r\n                    return y(d.value);\r\n                  })\r\n                  .attr(\r\n                    'style',\r\n                    'font-size: ' + '.85em' + ';' + ' font-weight:' + 'bold' + ';'\r\n                  )\r\n                  .style('fill', function (d) {\r\n                    return metaData.colors[d.key];\r\n                  })\r\n                  .attr(\r\n                    'width',\r\n                    self.isZoomedOut ? xSubgroup.bandwidth() : xSubgroup.bandwidth()\r\n                  )\r\n                  .text(function (d) {\r\n                    return d.value;\r\n                  });\r\n              });\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            //   .attr('transform', 'rotate(-30)')\r\n            //   .attr('text-anchor', 'end')\r\n            //   .attr('x', '-5')\r\n            //   .attr('dy', null)\r\n            //   .style('fill', 'var(--chart-text-color)');\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                const words = label.split(' ');\r\n      \r\n                text.text(null); // Clear current text\r\n      \r\n                // Add each word to a new tspan\r\n                words.forEach((word, index) => {\r\n                  text.append('tspan').text(word);\r\n                  // .attr('x', '15')\r\n                  // .attr('dy', index === 0 ? '0em' : '0.9em') // Reduced vertical spacing\r\n                  // .attr('text-anchor', 'end');\r\n                });\r\n              })\r\n              .style('fill', 'var(--chart-text-color)')\r\n              .attr('transform', null); // Remove rotate if using line breaks\r\n      \r\n            // Optional: Adjust bottom margin or chart layout\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 + 10);\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\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  }","<div\r\n  #groupcontainer\r\n  class=\"lib-chart-wrapper\"\r\n  [ngClass]=\"{ 'lib-no-background': isTransparentBackground }\"\r\n  [style.background-color]=\"chartConfiguration.backgroundColor\"\r\n  (resized)=\"onResized($event)\"\r\n>\r\n\r\n<div class=\"header-alt\" *ngIf=\"!isHeaderVisible\">\r\n  <lib-chart-header-v2\r\n    [chartData]=\"chartData\"\r\n    [chartConfiguration]=\"chartConfiguration\"\r\n    (clickEvent)=\"handleClick($event)\"\r\n  ></lib-chart-header-v2>\r\n  <lib-chart-header-v3\r\n    [chartData]=\"chartData\"\r\n    [chartConfiguration]=\"chartConfiguration\"\r\n    (compareByFilterSelection)=\"handleCompareByFilterSelection($event)\"\r\n    (zoomInZoomOutClick)=\"handleZoominZoomoutClick($event)\"\r\n  ></lib-chart-header-v3>\r\n</div>\r\n\r\n  <lib-chart-header-v1\r\n  [title]=\"chartData.metaData.title\"\r\n  [hasDrillDown]=\"chartData.metaData.hasDrillDown\"\r\n  [isEditEnabled]=\"chartData.metaData.isEditEnabled\"\r\n  [menuOptions]=\"chartConfiguration.headerMenuOptions\"\r\n  [isria]=\"customChartConfiguration.isRia\"\r\n  [selectedKpiTooltop]=\"chartConfiguration.selectedKpiTooltop\"\r\n  (menuOptionClickEvent)=\"handleHeaderMenuClick($event)\"\r\n  [isAlertEnabled]=\"isAlertEnabled\"\r\n  *ngIf=\"isHeaderVisible\"\r\n></lib-chart-header-v1>\r\n\r\n  <div\r\n    [style.height]=\"chartConfiguration.svgHeight\"\r\n    id=\"groupchartcontainer\"\r\n    #groupchartcontainer\r\n    class=\"lib-chart-svg\"\r\n  ></div>\r\n</div>\r\n"]}