axidio-styleguide-library1-v2 0.2.24 → 0.2.26
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.
- package/esm2022/lib/group-chart/group-chart.component.mjs +189 -2
- package/esm2022/lib/horizontal-bars-with-scroll-zoom/horizontal-bars-with-scroll-zoom.component.mjs +1081 -519
- package/esm2022/lib/horizontal-grouped-bar-with-scroll-zoom/horizontal-grouped-bar-with-scroll-zoom.component.mjs +348 -314
- package/fesm2022/axidio-styleguide-library1-v2.mjs +1767 -984
- package/fesm2022/axidio-styleguide-library1-v2.mjs.map +1 -1
- package/lib/horizontal-bars-with-scroll-zoom/horizontal-bars-with-scroll-zoom.component.d.ts +12 -74
- package/lib/horizontal-grouped-bar-with-scroll-zoom/horizontal-grouped-bar-with-scroll-zoom.component.d.ts +10 -0
- package/package.json +1 -1
|
@@ -118,6 +118,9 @@ export class HorizontalGroupedBarWithScrollZoomComponent extends ComponentUnique
|
|
|
118
118
|
var alternate_text = false;
|
|
119
119
|
var short_tick_length = 4;
|
|
120
120
|
var long_tick_length = 16;
|
|
121
|
+
/**
|
|
122
|
+
* longer tick length needed for weekly charts
|
|
123
|
+
*/
|
|
121
124
|
var short_tick_length_bg = 5;
|
|
122
125
|
var long_tick_length_bg = 30;
|
|
123
126
|
var leftAndRightSpaces = 50;
|
|
@@ -137,59 +140,7 @@ export class HorizontalGroupedBarWithScrollZoomComponent extends ComponentUnique
|
|
|
137
140
|
var chartContainer = d3.select(this.containerElt.nativeElement);
|
|
138
141
|
var verticalstackedcontainer = d3.select(this.groupcontainerElt.nativeElement);
|
|
139
142
|
var margin = this.chartConfiguration.margin;
|
|
140
|
-
|
|
141
|
-
if (this.chartData.data.length > 30 && this.isZoomedOut) {
|
|
142
|
-
width =
|
|
143
|
-
width > this.chartData.data.length * 40
|
|
144
|
-
? this.chartData.dropdownData1
|
|
145
|
-
? this.chartData.data.length * 60
|
|
146
|
-
: width
|
|
147
|
-
: this.chartData.dropdownData1
|
|
148
|
-
? this.chartData.data.length * 60
|
|
149
|
-
: this.chartData.data.length * 40;
|
|
150
|
-
width =
|
|
151
|
-
width > this.chartData.data.length * 40
|
|
152
|
-
? width
|
|
153
|
-
: this.chartData.data.length * 40;
|
|
154
|
-
}
|
|
155
|
-
if (this.chartData.dropdownData2 &&
|
|
156
|
-
width < this.chartData.data.length * 120 &&
|
|
157
|
-
this.isZoomedOut) {
|
|
158
|
-
width = this.chartData.data.length * 120;
|
|
159
|
-
}
|
|
160
|
-
if (this.chartData.data.length > 8 && !this.isZoomedOut) {
|
|
161
|
-
if (this.chartData.dropdownData2 &&
|
|
162
|
-
width < this.chartData.data.length * 250) {
|
|
163
|
-
width = this.chartData.data.length * 250;
|
|
164
|
-
}
|
|
165
|
-
else
|
|
166
|
-
width = this.chartData.data.length * 160;
|
|
167
|
-
}
|
|
168
|
-
var height = parseInt(verticalstackedcontainer.style('height')) *
|
|
169
|
-
(self.chartConfiguration.svgHeight / 100) -
|
|
170
|
-
margin.top -
|
|
171
|
-
margin.bottom;
|
|
172
|
-
if (this.chartConfiguration.isFullScreen != undefined &&
|
|
173
|
-
this.chartConfiguration.isFullScreen) {
|
|
174
|
-
height =
|
|
175
|
-
this.chartConfiguration.svgHeight != 70
|
|
176
|
-
? this.chartConfiguration.svgHeight
|
|
177
|
-
: parseInt(verticalstackedcontainer.style('height'));
|
|
178
|
-
}
|
|
179
|
-
if (this.chartConfiguration.isDrilldownChart && !this.isHeaderVisible) {
|
|
180
|
-
height =
|
|
181
|
-
parseInt(verticalstackedcontainer.style('height')) -
|
|
182
|
-
margin.top -
|
|
183
|
-
margin.bottom -
|
|
184
|
-
130;
|
|
185
|
-
}
|
|
186
|
-
if (this.chartConfiguration.isHeaderVisible) {
|
|
187
|
-
height =
|
|
188
|
-
parseInt(verticalstackedcontainer.style('height')) -
|
|
189
|
-
margin.top -
|
|
190
|
-
margin.bottom -
|
|
191
|
-
100;
|
|
192
|
-
}
|
|
143
|
+
const { width, height } = this.calculateChartDimensions(chartContainer, verticalstackedcontainer, margin, self);
|
|
193
144
|
if (this.chartConfiguration.isHeaderVisible != undefined)
|
|
194
145
|
this.isHeaderVisible = this.chartConfiguration.isHeaderVisible;
|
|
195
146
|
if (this.chartConfiguration.legendVisible != undefined) {
|
|
@@ -203,45 +154,7 @@ export class HorizontalGroupedBarWithScrollZoomComponent extends ComponentUnique
|
|
|
203
154
|
formatFromBackend = ChartHelper.dataValueFormatter(this.chartConfiguration.textFormatter);
|
|
204
155
|
formatForHugeNumbers = ChartHelper.dataValueFormatter('.2s');
|
|
205
156
|
}
|
|
206
|
-
|
|
207
|
-
.append('div')
|
|
208
|
-
.attr('id', self.uniqueId)
|
|
209
|
-
.attr('class', 'outer-container')
|
|
210
|
-
.style('width', '100%')
|
|
211
|
-
.style('height', height)
|
|
212
|
-
.style('overflow-x', 'hidden')
|
|
213
|
-
.style('padding-left', `${margin.left}px`)
|
|
214
|
-
.style('padding-right', `${rightSvgWidth}px`)
|
|
215
|
-
.style('margin-left', '15px');
|
|
216
|
-
var svgYAxisLeft = outerContainer
|
|
217
|
-
.append('svg')
|
|
218
|
-
.attr('width', '100')
|
|
219
|
-
.attr('height', height + margin.top + margin.bottom + 10)
|
|
220
|
-
.style('position', 'absolute')
|
|
221
|
-
.style('left', '0')
|
|
222
|
-
.style('z-index', 1)
|
|
223
|
-
.append('g')
|
|
224
|
-
.attr('transform', 'translate(' + (margin.left + 15) + ',' + margin.top + ')');
|
|
225
|
-
var svgYAxisRight = outerContainer
|
|
226
|
-
.append('svg')
|
|
227
|
-
.attr('width', rightSvgWidth)
|
|
228
|
-
.attr('height', height + margin.top + margin.bottom + 10)
|
|
229
|
-
.style('position', 'absolute')
|
|
230
|
-
.style('right', '12px')
|
|
231
|
-
.style('z-index', 1)
|
|
232
|
-
.append('g')
|
|
233
|
-
.attr('transform', 'translate(' + 0 + ',' + margin.top + ')');
|
|
234
|
-
var innerContainer = outerContainer
|
|
235
|
-
.append('div')
|
|
236
|
-
.attr('class', 'inner-container')
|
|
237
|
-
.style('width', '100%')
|
|
238
|
-
.style('overflow-x', 'auto');
|
|
239
|
-
var svg = innerContainer
|
|
240
|
-
.append('svg')
|
|
241
|
-
.attr('width', width - rightSvgWidth)
|
|
242
|
-
.attr('height', height + margin.top + margin.bottom + 60)
|
|
243
|
-
.append('g')
|
|
244
|
-
.attr('transform', 'translate(' + 0 + ',' + margin.top + ')');
|
|
157
|
+
const { outerContainer, svgYAxisLeft, svgYAxisRight, innerContainer, svg } = this.createChartContainers(chartContainer, margin, height, rightSvgWidth, self, width);
|
|
245
158
|
var subgroups = keyList;
|
|
246
159
|
var groups = d3
|
|
247
160
|
.map(data, function (d) {
|
|
@@ -269,220 +182,11 @@ export class HorizontalGroupedBarWithScrollZoomComponent extends ComponentUnique
|
|
|
269
182
|
.scaleBand()
|
|
270
183
|
.domain(groups)
|
|
271
184
|
.range([0, width - rightSvgWidth]);
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
.append('g')
|
|
275
|
-
.attr('class', 'x1 axis1')
|
|
276
|
-
.attr('transform', 'translate(0,' + height + ')')
|
|
277
|
-
.call(d3.axisBottom(x))
|
|
278
|
-
.call((g) => g.select('.domain').remove());
|
|
279
|
-
svg.selectAll('g.x1.axis1 g.tick line').remove();
|
|
280
|
-
if (subgroups.length > 1 && !metaData.xLabel) {
|
|
281
|
-
svg
|
|
282
|
-
.selectAll('g.x1.axis1 g.tick text')
|
|
283
|
-
.attr('class', 'lib-xaxis-labels-texts-drilldown')
|
|
284
|
-
.style('fill', 'var(--chart-text-color)')
|
|
285
|
-
.attr('y', 32);
|
|
286
|
-
}
|
|
287
|
-
else {
|
|
288
|
-
svg
|
|
289
|
-
.selectAll('g.x1.axis1 g.tick text')
|
|
290
|
-
.attr('class', 'lib-xaxis-labels-texts-drilldown')
|
|
291
|
-
.style('fill', 'var(--chart-text-color)');
|
|
292
|
-
}
|
|
293
|
-
}
|
|
294
|
-
else {
|
|
295
|
-
svg
|
|
296
|
-
.append('g')
|
|
297
|
-
.attr('class', 'x1 axis1')
|
|
298
|
-
.attr('transform', 'translate(0,' + height + ')')
|
|
299
|
-
.call(d3.axisBottom(x).tickSize(0))
|
|
300
|
-
.call((g) => g.select('.domain').attr('fill', 'none'));
|
|
301
|
-
svg.selectAll('g.x1.axis1 g.tick line').attr('y2', function () {
|
|
302
|
-
if (alternate_text &&
|
|
303
|
-
self.chartConfiguration.isNoAlternateXaxisText == undefined) {
|
|
304
|
-
alternate_text = false;
|
|
305
|
-
return long_tick_length_bg - 7;
|
|
306
|
-
}
|
|
307
|
-
else {
|
|
308
|
-
alternate_text = true;
|
|
309
|
-
return short_tick_length_bg - 4;
|
|
310
|
-
}
|
|
311
|
-
});
|
|
312
|
-
alternate_text = false;
|
|
313
|
-
svg
|
|
314
|
-
.selectAll('g.x1.axis1 g.tick text')
|
|
315
|
-
.attr('class', 'lib-xaxis-labels-texts-weeklycharts')
|
|
316
|
-
.attr('y', function () {
|
|
317
|
-
if (self.chartConfiguration.isFullScreen) {
|
|
318
|
-
return short_tick_length_bg;
|
|
319
|
-
}
|
|
320
|
-
if (alternate_text) {
|
|
321
|
-
alternate_text = false;
|
|
322
|
-
return long_tick_length_bg;
|
|
323
|
-
}
|
|
324
|
-
else {
|
|
325
|
-
alternate_text = true;
|
|
326
|
-
return short_tick_length_bg;
|
|
327
|
-
}
|
|
328
|
-
});
|
|
329
|
-
}
|
|
330
|
-
if (self.chartConfiguration.xLabelsOnSameLine) {
|
|
331
|
-
const xAxisLabels = svg
|
|
332
|
-
.selectAll('g.x1.axis1 g.tick text')
|
|
333
|
-
.attr('class', 'lib-xaxis-labels-texts-drilldown')
|
|
334
|
-
.style('font-size', this.isHeaderVisible ? '18px' : '14px')
|
|
335
|
-
.attr('text-anchor', 'middle')
|
|
336
|
-
.attr('y', function (d) {
|
|
337
|
-
if (subgroups.length > 1 && data.length > 8 && metaData.xLabel) {
|
|
338
|
-
const isDateLabel = /\d{2,4}[-\/]/.test(d);
|
|
339
|
-
if (self.chartConfiguration.isFullScreen) {
|
|
340
|
-
return isDateLabel ? short_tick_length_bg + 14 : short_tick_length_bg;
|
|
341
|
-
}
|
|
342
|
-
return isDateLabel ? short_tick_length_bg + 14 : short_tick_length_bg;
|
|
343
|
-
}
|
|
344
|
-
if (subgroups.length > 1 && data.length > 8 && !metaData.xLabel) {
|
|
345
|
-
const chartHasExtraBottom = (self.chartConfiguration.margin && self.chartConfiguration.margin.bottom >= 40);
|
|
346
|
-
if (self.chartConfiguration.isFullScreen) {
|
|
347
|
-
return short_tick_length_bg + 2;
|
|
348
|
-
}
|
|
349
|
-
return chartHasExtraBottom ? short_tick_length_bg : short_tick_length_bg + 10;
|
|
350
|
-
}
|
|
351
|
-
let baseY = self.isHeaderVisible ? short_tick_length_bg + 25 : short_tick_length_bg;
|
|
352
|
-
if (subgroups.length > 1 &&
|
|
353
|
-
!metaData.xLabel &&
|
|
354
|
-
(/\d{2,4}[-\/]\d{2}[-\/]\d{2,4}/.test(d) || /\d{2,4}[-\/]\d{2,4}/.test(d))) {
|
|
355
|
-
baseY = self.isHeaderVisible ? short_tick_length_bg + 15 : short_tick_length_bg + 25;
|
|
356
|
-
}
|
|
357
|
-
if (/\d{2,4}[-\/]\d{2,4}/.test(d) && d.indexOf(' ') > -1) {
|
|
358
|
-
baseY += 4;
|
|
359
|
-
}
|
|
360
|
-
if (self.chartConfiguration.isFullScreen && subgroups.length > 1) {
|
|
361
|
-
baseY = Math.max(short_tick_length_bg, baseY - 10);
|
|
362
|
-
}
|
|
363
|
-
return baseY;
|
|
364
|
-
})
|
|
365
|
-
.attr('x', function (d) {
|
|
366
|
-
if (self.chartData.data.length > 8 && !self.isZoomedOut) {
|
|
367
|
-
return 1;
|
|
368
|
-
}
|
|
369
|
-
return 0;
|
|
370
|
-
})
|
|
371
|
-
.text(function (d) {
|
|
372
|
-
var isValueToBeIgnored = false;
|
|
373
|
-
if (isMobile && !self.isHeaderVisible) {
|
|
374
|
-
let firstPart = d.split(/[\s\-]+/)[0];
|
|
375
|
-
return firstPart.substring(0, 3).toLowerCase();
|
|
376
|
-
}
|
|
377
|
-
data.map((indiv) => {
|
|
378
|
-
if (indiv.name &&
|
|
379
|
-
indiv.name.toLowerCase() == d.trim().toLowerCase() &&
|
|
380
|
-
indiv[metaData.keyList[0]] == -1) {
|
|
381
|
-
isValueToBeIgnored = true;
|
|
382
|
-
}
|
|
383
|
-
});
|
|
384
|
-
if (isValueToBeIgnored) {
|
|
385
|
-
return '';
|
|
386
|
-
}
|
|
387
|
-
const dateRangeRegex = /(\d{2,4}[-\/]\d{2}[-\/]\d{2,4})\s*-\s*(\d{2,4}[-\/]\d{2}[-\/]\d{2,4})/;
|
|
388
|
-
if (dateRangeRegex.test(d.trim())) {
|
|
389
|
-
return d.trim().replace(dateRangeRegex, (m, d1, d2) => `${d1} - ${d2}`);
|
|
390
|
-
}
|
|
391
|
-
const isDateLabel = /\d{2,4}[-\/]/.test(d);
|
|
392
|
-
const isWeekLabel = /week|wk|w\d+/i.test(d);
|
|
393
|
-
if (subgroups.length > 1 && !self.isZoomedOut && data.length > 8 && d.indexOf(' ') > -1 && (isDateLabel || isWeekLabel)) {
|
|
394
|
-
var first = d.substring(0, d.indexOf(' '));
|
|
395
|
-
var second = d.substring(d.indexOf(' ') + 1).trim();
|
|
396
|
-
return first + '\n' + second;
|
|
397
|
-
}
|
|
398
|
-
if (isDateLabel) {
|
|
399
|
-
if (!self.isHeaderVisible && data.length > 8 && d.indexOf(' ') > -1) {
|
|
400
|
-
var first = d.substring(0, d.indexOf(' '));
|
|
401
|
-
var second = d.substring(d.indexOf(' ') + 1).trim();
|
|
402
|
-
return first + '\n' + second;
|
|
403
|
-
}
|
|
404
|
-
else {
|
|
405
|
-
return d;
|
|
406
|
-
}
|
|
407
|
-
}
|
|
408
|
-
if (d.trim().indexOf(' ') > -1) {
|
|
409
|
-
return d.trim().substring(0, d.indexOf(' ')).toLowerCase();
|
|
410
|
-
}
|
|
411
|
-
return d.toLowerCase();
|
|
412
|
-
const isDateLabel2 = /\d{2,4}[-\/]/.test(d);
|
|
413
|
-
if (isDateLabel) {
|
|
414
|
-
if (!self.isHeaderVisible && data.length > 8 && d.indexOf(' ') > -1) {
|
|
415
|
-
var first = d.substring(0, d.indexOf(' '));
|
|
416
|
-
var second = d.substring(d.indexOf(' ') + 1).trim();
|
|
417
|
-
return first + '\n' + second;
|
|
418
|
-
}
|
|
419
|
-
else {
|
|
420
|
-
return d;
|
|
421
|
-
}
|
|
422
|
-
}
|
|
423
|
-
if (d.trim().indexOf(' ') > -1) {
|
|
424
|
-
return d.trim().substring(0, d.indexOf(' ')).toLowerCase();
|
|
425
|
-
}
|
|
426
|
-
return d.toLowerCase();
|
|
427
|
-
});
|
|
428
|
-
xAxisLabels.each(function (d) {
|
|
429
|
-
const isDateLabel = /^(\d{2,4}[-\/])?\d{2,4}[-\/]\d{2,4}$/.test(d.trim());
|
|
430
|
-
const isWeekLabel = /week|wk|w\d+/i.test(d);
|
|
431
|
-
if (subgroups.length > 1 && self.isZoomedOut && data.length > 8 && isDateLabel && !isWeekLabel) {
|
|
432
|
-
d3.select(this).style('writing-mode', 'sideways-lr');
|
|
433
|
-
}
|
|
434
|
-
});
|
|
435
|
-
if (!isMobile) {
|
|
436
|
-
svg
|
|
437
|
-
.selectAll('g.x1.axis1 g.tick')
|
|
438
|
-
.filter(function (d) {
|
|
439
|
-
return !/\d{2,4}[-\/]/.test(d);
|
|
440
|
-
})
|
|
441
|
-
.append('text')
|
|
442
|
-
.attr('class', 'lib-xaxis-labels-texts-drilldown')
|
|
443
|
-
.attr('y', long_tick_length_bg)
|
|
444
|
-
.attr('fill', 'var(--chart-text-color)')
|
|
445
|
-
.attr('x', function (d) {
|
|
446
|
-
if (self.chartData.data.length > 8 && !self.isZoomedOut) {
|
|
447
|
-
return 1;
|
|
448
|
-
}
|
|
449
|
-
return 0;
|
|
450
|
-
})
|
|
451
|
-
.text(function (d) {
|
|
452
|
-
if (d.trim().indexOf(' ') > -1) {
|
|
453
|
-
return d.trim().substring(d.indexOf(' '), d.length).toLowerCase();
|
|
454
|
-
}
|
|
455
|
-
return '';
|
|
456
|
-
});
|
|
457
|
-
}
|
|
458
|
-
}
|
|
459
|
-
if (isria && self.chartData.data.length > 8) {
|
|
460
|
-
svg
|
|
461
|
-
.selectAll('g.x1.axis1 g.tick text')
|
|
462
|
-
.classed('mobile-xaxis-override', true)
|
|
463
|
-
.text(function (d) {
|
|
464
|
-
return d.substring(0, 3);
|
|
465
|
-
})
|
|
466
|
-
.style('font-size', '12px')
|
|
467
|
-
.attr('y', 5)
|
|
468
|
-
.attr('x', 5)
|
|
469
|
-
.style('text-anchor', 'middle');
|
|
470
|
-
}
|
|
471
|
-
if (isMobile && !this.isHeaderVisible) {
|
|
472
|
-
svg
|
|
473
|
-
.selectAll('g.x1.axis1 g.tick text')
|
|
474
|
-
.classed('mobile-xaxis-override', true);
|
|
475
|
-
}
|
|
185
|
+
this.renderXAxis(svg, x, height, subgroups, metaData, this.chartConfiguration, alternate_text, short_tick_length_bg, long_tick_length_bg, this);
|
|
186
|
+
this.renderXAxisLabels(svg, data, subgroups, metaData, this.chartConfiguration, short_tick_length_bg, long_tick_length_bg, isMobile, isria, this);
|
|
476
187
|
var y = d3.scaleLinear().rangeRound([height, 0]);
|
|
477
188
|
var maxValue = d3.max(data, (d) => d3.max(keyList, (key) => +d[key]));
|
|
478
|
-
|
|
479
|
-
if (this.chartData.targetLineData) {
|
|
480
|
-
maxValue = this.chartData.targetLineData.target + 20;
|
|
481
|
-
}
|
|
482
|
-
else {
|
|
483
|
-
maxValue = 100;
|
|
484
|
-
}
|
|
485
|
-
}
|
|
189
|
+
maxValue = this.calculateMaxValue(maxValue);
|
|
486
190
|
if (this.chartConfiguration.customYscale) {
|
|
487
191
|
maxValue = maxValue * this.chartConfiguration.customYscale;
|
|
488
192
|
}
|
|
@@ -589,8 +293,10 @@ export class HorizontalGroupedBarWithScrollZoomComponent extends ComponentUnique
|
|
|
589
293
|
.data(function (d) {
|
|
590
294
|
let newList = [];
|
|
591
295
|
subgroups.map(function (key) {
|
|
296
|
+
// if (key !== "group") {
|
|
592
297
|
let obj = { key: key, value: d[key], name: d.name };
|
|
593
298
|
newList.push(obj);
|
|
299
|
+
// }
|
|
594
300
|
});
|
|
595
301
|
return newList;
|
|
596
302
|
})
|
|
@@ -603,6 +309,7 @@ export class HorizontalGroupedBarWithScrollZoomComponent extends ComponentUnique
|
|
|
603
309
|
!metaData.barWithoutClick.length ||
|
|
604
310
|
(!metaData.barWithoutClick.includes(d?.name) &&
|
|
605
311
|
!metaData.barWithoutClick.includes(d?.key)))
|
|
312
|
+
// self.handleClick(d.data.name);
|
|
606
313
|
self.handleClick(d);
|
|
607
314
|
}
|
|
608
315
|
})
|
|
@@ -613,6 +320,7 @@ export class HorizontalGroupedBarWithScrollZoomComponent extends ComponentUnique
|
|
|
613
320
|
let keys = Object.keys(indiv).filter((temp, i) => i != 0);
|
|
614
321
|
tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);
|
|
615
322
|
if (x.bandwidth() > 100) {
|
|
323
|
+
// Increase bar width a bit in zoom-in view
|
|
616
324
|
let reducedBarWidth = 60;
|
|
617
325
|
if (!self.isZoomedOut) {
|
|
618
326
|
reducedBarWidth = 30;
|
|
@@ -654,19 +362,23 @@ export class HorizontalGroupedBarWithScrollZoomComponent extends ComponentUnique
|
|
|
654
362
|
return y(0);
|
|
655
363
|
})
|
|
656
364
|
.attr('width', function (d) {
|
|
365
|
+
// For grouped bar charts in zoom-in view, set bar width to 50 for maximum thickness
|
|
657
366
|
if (subgroups.length > 1 && !self.isZoomedOut) {
|
|
658
367
|
return 50;
|
|
659
368
|
}
|
|
369
|
+
// For single-bar (non-grouped) charts in zoom-in view, set bar width to 80
|
|
660
370
|
if (subgroups.length === 1 && !self.isZoomedOut) {
|
|
661
371
|
return 80;
|
|
662
372
|
}
|
|
663
373
|
let tempScale = d3.scaleBand().domain([]).range([0, 0]);
|
|
374
|
+
// Default logic for other chart types
|
|
664
375
|
if (self.chartConfiguration.isDrilldownChart) {
|
|
665
376
|
data.map((indiv) => {
|
|
666
377
|
if (indiv.name == d.name) {
|
|
667
378
|
let keys = Object.keys(indiv).filter((temp, i) => i != 0);
|
|
668
379
|
tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);
|
|
669
380
|
if (x.bandwidth() > 100) {
|
|
381
|
+
// Increase bar width a bit in zoom-in view
|
|
670
382
|
let reducedBarWidth = 60;
|
|
671
383
|
if (!self.isZoomedOut) {
|
|
672
384
|
reducedBarWidth = 100;
|
|
@@ -727,13 +439,16 @@ export class HorizontalGroupedBarWithScrollZoomComponent extends ComponentUnique
|
|
|
727
439
|
d.value >= parseFloat(self.chartData.targetLineData.target) &&
|
|
728
440
|
self.chartData.metaData.colorAboveTarget) {
|
|
729
441
|
const key = d.key.toLowerCase();
|
|
730
|
-
const colorAboveTarget = Object.keys(self.chartData.metaData.colorAboveTarget).find(k => k.toLowerCase() === key);
|
|
442
|
+
const colorAboveTarget = Object.keys(self.chartData.metaData.colorAboveTarget).find((k) => k.toLowerCase() === key);
|
|
731
443
|
if (colorAboveTarget) {
|
|
732
444
|
return self.chartData.metaData.colorAboveTarget[colorAboveTarget];
|
|
733
445
|
}
|
|
734
446
|
}
|
|
735
447
|
return self.chartData.metaData.colors[d.key];
|
|
736
448
|
});
|
|
449
|
+
/**
|
|
450
|
+
* display angled texts on the bars
|
|
451
|
+
*/
|
|
737
452
|
if (this.chartConfiguration.textsOnBar != undefined && !this.isZoomedOut) {
|
|
738
453
|
state
|
|
739
454
|
.selectAll('text')
|
|
@@ -768,7 +483,7 @@ export class HorizontalGroupedBarWithScrollZoomComponent extends ComponentUnique
|
|
|
768
483
|
.style('font-weight', 'bold')
|
|
769
484
|
.style('font-size', function (d) {
|
|
770
485
|
if (self.isZoomedOut) {
|
|
771
|
-
return '9px';
|
|
486
|
+
return '9px'; // 👈 Zoomed out mode
|
|
772
487
|
}
|
|
773
488
|
if (self.chartConfiguration.isDrilldownChart) {
|
|
774
489
|
if (window.innerWidth > 1900) {
|
|
@@ -798,12 +513,14 @@ export class HorizontalGroupedBarWithScrollZoomComponent extends ComponentUnique
|
|
|
798
513
|
0 + (x.bandwidth() - 200) / 2,
|
|
799
514
|
x.bandwidth() - (x.bandwidth() - 200) / 2,
|
|
800
515
|
]);
|
|
516
|
+
// .padding(0.05);
|
|
801
517
|
}
|
|
802
518
|
else
|
|
803
519
|
tempScale.range([
|
|
804
520
|
0 + (x.bandwidth() - 300) / 2,
|
|
805
521
|
x.bandwidth() - (x.bandwidth() - 300) / 2,
|
|
806
522
|
]);
|
|
523
|
+
// .padding(0.05);
|
|
807
524
|
}
|
|
808
525
|
else
|
|
809
526
|
tempScale.range([
|
|
@@ -813,9 +530,16 @@ export class HorizontalGroupedBarWithScrollZoomComponent extends ComponentUnique
|
|
|
813
530
|
}
|
|
814
531
|
}
|
|
815
532
|
});
|
|
533
|
+
/**
|
|
534
|
+
* if set, then all texts ll be horizontal
|
|
535
|
+
*/
|
|
816
536
|
if (self.chartConfiguration.textAlwaysHorizontal) {
|
|
817
537
|
return ('translate(' + xSubgroup(d.key) + ',' + (y(d.value) - 3) + ')');
|
|
818
538
|
}
|
|
539
|
+
/**
|
|
540
|
+
* rotate texts having more than one digits
|
|
541
|
+
*/
|
|
542
|
+
// if (d.value > 9)
|
|
819
543
|
if (!isNaN(tempScale(d.key)))
|
|
820
544
|
return ('translate(' +
|
|
821
545
|
(tempScale(d.key) + tempScale.bandwidth() * 0.55) +
|
|
@@ -823,6 +547,14 @@ export class HorizontalGroupedBarWithScrollZoomComponent extends ComponentUnique
|
|
|
823
547
|
(y(0) - 10) +
|
|
824
548
|
') rotate(270)');
|
|
825
549
|
return 'translate(0,0)';
|
|
550
|
+
// else
|
|
551
|
+
// return (
|
|
552
|
+
// 'translate(' +
|
|
553
|
+
// (tempScale(d.key) + tempScale.bandwidth() / 2) +
|
|
554
|
+
// ',' +
|
|
555
|
+
// y(0) +
|
|
556
|
+
// ')'
|
|
557
|
+
// );
|
|
826
558
|
})
|
|
827
559
|
.on('click', function (d) {
|
|
828
560
|
if (!metaData.barWithoutClick ||
|
|
@@ -838,8 +570,9 @@ export class HorizontalGroupedBarWithScrollZoomComponent extends ComponentUnique
|
|
|
838
570
|
.on('mouseover', handleMouseOver);
|
|
839
571
|
}
|
|
840
572
|
}
|
|
841
|
-
if (this.chartConfiguration.displayTitleOnTop ||
|
|
842
|
-
this.chartConfiguration.
|
|
573
|
+
if (this.chartConfiguration.displayTitleOnTop ||
|
|
574
|
+
(this.chartConfiguration.textsOnBar == undefined &&
|
|
575
|
+
this.chartConfiguration.displayTitleOnTop == undefined)) {
|
|
843
576
|
if (!isria) {
|
|
844
577
|
state
|
|
845
578
|
.selectAll('rect')
|
|
@@ -852,6 +585,7 @@ export class HorizontalGroupedBarWithScrollZoomComponent extends ComponentUnique
|
|
|
852
585
|
svg
|
|
853
586
|
.append('foreignObject')
|
|
854
587
|
.attr('x', function () {
|
|
588
|
+
// ...existing code for tempScale calculation...
|
|
855
589
|
var elementsCounter;
|
|
856
590
|
data.map((indiv) => {
|
|
857
591
|
if (indiv.name == d.name) {
|
|
@@ -960,7 +694,7 @@ export class HorizontalGroupedBarWithScrollZoomComponent extends ComponentUnique
|
|
|
960
694
|
.append('g')
|
|
961
695
|
.attr('class', 'x2 axis2')
|
|
962
696
|
.attr('transform', 'translate(0,' + height + ')')
|
|
963
|
-
.style('color', 'var(--chart-axis-color, #000)')
|
|
697
|
+
.style('color', 'var(--chart-axis-color, #000)') // Use CSS variable instead of hardcoded #000
|
|
964
698
|
.call(d3.axisBottom(xScaleFromOrigin).tickSize(0))
|
|
965
699
|
.call((g) => g.select('.domain').attr('fill', 'none'));
|
|
966
700
|
svg.selectAll('g.x2.axis2 g.tick text').style('display', 'none');
|
|
@@ -988,6 +722,7 @@ export class HorizontalGroupedBarWithScrollZoomComponent extends ComponentUnique
|
|
|
988
722
|
return formatted >= 1000 ? formatted / 1000 + 'k' : formatted;
|
|
989
723
|
}))
|
|
990
724
|
.call((g) => {
|
|
725
|
+
// Style the domain line for theme support
|
|
991
726
|
g.select('.domain')
|
|
992
727
|
.style('stroke', 'var(--chart-domain-color, #000000)')
|
|
993
728
|
.style('stroke-width', '1px');
|
|
@@ -1001,23 +736,40 @@ export class HorizontalGroupedBarWithScrollZoomComponent extends ComponentUnique
|
|
|
1001
736
|
.attr('transform', 'translate(0,0)')
|
|
1002
737
|
.call(y)
|
|
1003
738
|
.style('display', 'none');
|
|
739
|
+
/**
|
|
740
|
+
* hide x axis labels
|
|
741
|
+
* config is there for future use
|
|
742
|
+
* used by weekly charts
|
|
743
|
+
*/
|
|
1004
744
|
if (this.chartConfiguration.isXaxisLabelHidden != undefined &&
|
|
1005
745
|
this.chartConfiguration.isXaxisLabelHidden) {
|
|
1006
746
|
d3.selectAll('g.lib-line-x-axis-text > g > text').attr('class', 'lib-display-hidden');
|
|
1007
747
|
}
|
|
748
|
+
/**
|
|
749
|
+
* hide y axis labels
|
|
750
|
+
* used by weekly charts
|
|
751
|
+
*/
|
|
1008
752
|
if (this.chartConfiguration.isYaxisLabelHidden != undefined &&
|
|
1009
753
|
this.chartConfiguration.isYaxisLabelHidden) {
|
|
1010
754
|
d3.selectAll('.yaxis-dashed > g > text').attr('class', 'lib-display-hidden');
|
|
1011
755
|
}
|
|
756
|
+
/**
|
|
757
|
+
* hide y axis labels
|
|
758
|
+
* config is there for future use
|
|
759
|
+
*/
|
|
1012
760
|
if (this.chartConfiguration.isYaxisHidden != undefined &&
|
|
1013
761
|
this.chartConfiguration.isYaxisHidden) {
|
|
1014
762
|
d3.selectAll('.yaxis-dashed').attr('class', 'lib-display-hidden');
|
|
1015
763
|
}
|
|
764
|
+
/**
|
|
765
|
+
* dashed y axis
|
|
766
|
+
* used by weekly charts
|
|
767
|
+
*/
|
|
1016
768
|
if (this.chartConfiguration.isYaxisDashed != undefined &&
|
|
1017
769
|
this.chartConfiguration.isYaxisDashed) {
|
|
1018
770
|
d3.selectAll('.yaxis-dashed')
|
|
1019
771
|
.style('stroke-dasharray', '5 5')
|
|
1020
|
-
.style('color', 'var(--chart-axis-color, #999999)');
|
|
772
|
+
.style('color', 'var(--chart-axis-color, #999999)'); // Use CSS variable
|
|
1021
773
|
}
|
|
1022
774
|
if (lineData != null) {
|
|
1023
775
|
if (lineData && self.chartConfiguration.showLineChartAxis) {
|
|
@@ -1029,6 +781,14 @@ export class HorizontalGroupedBarWithScrollZoomComponent extends ComponentUnique
|
|
|
1029
781
|
.call(yLineAxis);
|
|
1030
782
|
}
|
|
1031
783
|
}
|
|
784
|
+
/**
|
|
785
|
+
* used to display y label
|
|
786
|
+
*/
|
|
787
|
+
// if (this.isZoomedOut) {
|
|
788
|
+
// svg
|
|
789
|
+
// .selectAll('.lib-xaxis-labels-texts-drilldown')
|
|
790
|
+
// .attr('class', 'lib-display-hidden');
|
|
791
|
+
// }
|
|
1032
792
|
if (this.isZoomedOut) {
|
|
1033
793
|
svg
|
|
1034
794
|
.selectAll('.lib-xaxis-labels-texts-drilldown')
|
|
@@ -1039,7 +799,8 @@ export class HorizontalGroupedBarWithScrollZoomComponent extends ComponentUnique
|
|
|
1039
799
|
const lines = label.split('\n');
|
|
1040
800
|
text.text(null);
|
|
1041
801
|
lines.forEach((line, idx) => {
|
|
1042
|
-
text
|
|
802
|
+
text
|
|
803
|
+
.append('tspan')
|
|
1043
804
|
.text(line)
|
|
1044
805
|
.attr('x', 0)
|
|
1045
806
|
.attr('dy', idx === 0 ? '1em' : '1.1em');
|
|
@@ -1059,8 +820,13 @@ export class HorizontalGroupedBarWithScrollZoomComponent extends ComponentUnique
|
|
|
1059
820
|
.select('.x-axis')
|
|
1060
821
|
.attr('transform', `translate(0, ${height - margin.bottom + 10})`);
|
|
1061
822
|
}
|
|
823
|
+
/**
|
|
824
|
+
* used to write y labels based on configuration
|
|
825
|
+
*/
|
|
1062
826
|
if (metaData.yLabel) {
|
|
1063
|
-
const yPosition = isria
|
|
827
|
+
const yPosition = isria
|
|
828
|
+
? 0 - margin.left / 2 - 30
|
|
829
|
+
: 0 - margin.left / 2 - 40;
|
|
1064
830
|
svgYAxisLeft
|
|
1065
831
|
.append('text')
|
|
1066
832
|
.attr('class', 'lib-axis-group-label font-size-1')
|
|
@@ -1094,6 +860,13 @@ export class HorizontalGroupedBarWithScrollZoomComponent extends ComponentUnique
|
|
|
1094
860
|
.attr('y2', yZero)
|
|
1095
861
|
.style('stroke-dasharray', '5 5')
|
|
1096
862
|
.style('stroke', this.chartData.targetLineData.color);
|
|
863
|
+
// svgYAxisRight
|
|
864
|
+
// .append('line')
|
|
865
|
+
// .attr('x1', 0)
|
|
866
|
+
// .attr('x2', rightSvgWidth)
|
|
867
|
+
// .attr('y1', yZero)
|
|
868
|
+
// .attr('y2', yZero)
|
|
869
|
+
// .style('stroke', this.chartData.targetLineData.color);
|
|
1097
870
|
svgYAxisRight
|
|
1098
871
|
.append('foreignObject')
|
|
1099
872
|
.attr('transform', 'translate(' + 0 + ',' + (yZero - 30) + ')')
|
|
@@ -1121,6 +894,13 @@ export class HorizontalGroupedBarWithScrollZoomComponent extends ComponentUnique
|
|
|
1121
894
|
});
|
|
1122
895
|
}
|
|
1123
896
|
if (this.chartConfiguration.isDrilldownChart) {
|
|
897
|
+
/**
|
|
898
|
+
* used by drilldown charts
|
|
899
|
+
*/
|
|
900
|
+
// svg
|
|
901
|
+
// .selectAll('.lib-axis-group-label')
|
|
902
|
+
// .attr('class', 'lib-ylabel-drilldowncharts')
|
|
903
|
+
// .text(metaData.yLabel.toLowerCase());
|
|
1124
904
|
svg.selectAll('g.x1.axis1 g.tick line').style('display', 'none');
|
|
1125
905
|
}
|
|
1126
906
|
if (metaData.xLabel) {
|
|
@@ -1130,7 +910,9 @@ export class HorizontalGroupedBarWithScrollZoomComponent extends ComponentUnique
|
|
|
1130
910
|
}
|
|
1131
911
|
const xLabelText = metaData.xLabel;
|
|
1132
912
|
const isAcr = isAcronym(xLabelText.replace(/[^A-Za-z]/g, ''));
|
|
1133
|
-
const xPosition = isria
|
|
913
|
+
const xPosition = isria
|
|
914
|
+
? height + margin.top + margin.bottom
|
|
915
|
+
: height + margin.top + margin.bottom + 40;
|
|
1134
916
|
svg
|
|
1135
917
|
.append('text')
|
|
1136
918
|
.attr('class', function () {
|
|
@@ -1223,6 +1005,258 @@ export class HorizontalGroupedBarWithScrollZoomComponent extends ComponentUnique
|
|
|
1223
1005
|
}
|
|
1224
1006
|
}
|
|
1225
1007
|
}
|
|
1008
|
+
calculateChartDimensions(chartContainer, verticalstackedcontainer, margin, self) {
|
|
1009
|
+
let width = parseInt(chartContainer.style('width')) - margin.left - margin.right;
|
|
1010
|
+
const dataLength = this.chartData.data.length;
|
|
1011
|
+
// ---- Width Logic (no change) ----
|
|
1012
|
+
if (dataLength > 30 && this.isZoomedOut) {
|
|
1013
|
+
width =
|
|
1014
|
+
width > dataLength * 40
|
|
1015
|
+
? this.chartData.dropdownData1
|
|
1016
|
+
? dataLength * 60
|
|
1017
|
+
: width
|
|
1018
|
+
: this.chartData.dropdownData1
|
|
1019
|
+
? dataLength * 60
|
|
1020
|
+
: dataLength * 40;
|
|
1021
|
+
width = width > dataLength * 40 ? width : dataLength * 40;
|
|
1022
|
+
}
|
|
1023
|
+
if (this.chartData.dropdownData2 &&
|
|
1024
|
+
width < dataLength * 120 &&
|
|
1025
|
+
this.isZoomedOut) {
|
|
1026
|
+
width = dataLength * 120;
|
|
1027
|
+
}
|
|
1028
|
+
if (dataLength > 8 && !this.isZoomedOut) {
|
|
1029
|
+
if (this.chartData.dropdownData2 && width < dataLength * 250) {
|
|
1030
|
+
width = dataLength * 250;
|
|
1031
|
+
}
|
|
1032
|
+
else {
|
|
1033
|
+
width = dataLength * 160;
|
|
1034
|
+
}
|
|
1035
|
+
}
|
|
1036
|
+
// ---- Height Logic (no change) ----
|
|
1037
|
+
let height = parseInt(verticalstackedcontainer.style('height')) *
|
|
1038
|
+
(self.chartConfiguration.svgHeight / 100) -
|
|
1039
|
+
margin.top -
|
|
1040
|
+
margin.bottom;
|
|
1041
|
+
if (this.chartConfiguration.isFullScreen !== undefined &&
|
|
1042
|
+
this.chartConfiguration.isFullScreen) {
|
|
1043
|
+
height =
|
|
1044
|
+
this.chartConfiguration.svgHeight !== 70
|
|
1045
|
+
? this.chartConfiguration.svgHeight
|
|
1046
|
+
: parseInt(verticalstackedcontainer.style('height'));
|
|
1047
|
+
}
|
|
1048
|
+
if (this.chartConfiguration.isDrilldownChart && !this.isHeaderVisible) {
|
|
1049
|
+
height =
|
|
1050
|
+
parseInt(verticalstackedcontainer.style('height')) -
|
|
1051
|
+
margin.top -
|
|
1052
|
+
margin.bottom -
|
|
1053
|
+
130;
|
|
1054
|
+
}
|
|
1055
|
+
if (this.chartConfiguration.isHeaderVisible) {
|
|
1056
|
+
height =
|
|
1057
|
+
parseInt(verticalstackedcontainer.style('height')) -
|
|
1058
|
+
margin.top -
|
|
1059
|
+
margin.bottom -
|
|
1060
|
+
100;
|
|
1061
|
+
}
|
|
1062
|
+
return { width, height };
|
|
1063
|
+
}
|
|
1064
|
+
createChartContainers(chartContainer, margin, height, rightSvgWidth, self, width) {
|
|
1065
|
+
// Outer container
|
|
1066
|
+
const outerContainer = chartContainer
|
|
1067
|
+
.append('div')
|
|
1068
|
+
.attr('id', self.uniqueId)
|
|
1069
|
+
.attr('class', 'outer-container')
|
|
1070
|
+
.style('width', '100%')
|
|
1071
|
+
.style('height', height)
|
|
1072
|
+
.style('overflow-x', 'hidden')
|
|
1073
|
+
.style('padding-left', `${margin.left}px`)
|
|
1074
|
+
.style('padding-right', `${rightSvgWidth}px`)
|
|
1075
|
+
.style('margin-left', '15px');
|
|
1076
|
+
// Left Y-Axis
|
|
1077
|
+
const svgYAxisLeft = outerContainer
|
|
1078
|
+
.append('svg')
|
|
1079
|
+
.attr('width', '100')
|
|
1080
|
+
.attr('height', height + margin.top + margin.bottom + 10)
|
|
1081
|
+
.style('position', 'absolute')
|
|
1082
|
+
.style('left', '0')
|
|
1083
|
+
.style('z-index', 1)
|
|
1084
|
+
.append('g')
|
|
1085
|
+
.attr('transform', `translate(${margin.left + 15},${margin.top})`);
|
|
1086
|
+
// Right Y-Axis
|
|
1087
|
+
const svgYAxisRight = outerContainer
|
|
1088
|
+
.append('svg')
|
|
1089
|
+
.attr('width', rightSvgWidth)
|
|
1090
|
+
.attr('height', height + margin.top + margin.bottom + 10)
|
|
1091
|
+
.style('position', 'absolute')
|
|
1092
|
+
.style('right', '12px')
|
|
1093
|
+
.style('z-index', 1)
|
|
1094
|
+
.append('g')
|
|
1095
|
+
.attr('transform', `translate(0,${margin.top})`);
|
|
1096
|
+
// Inner scrollable container
|
|
1097
|
+
const innerContainer = outerContainer
|
|
1098
|
+
.append('div')
|
|
1099
|
+
.attr('class', 'inner-container')
|
|
1100
|
+
.style('width', '100%')
|
|
1101
|
+
.style('overflow-x', 'auto');
|
|
1102
|
+
// Main SVG
|
|
1103
|
+
const svg = innerContainer
|
|
1104
|
+
.append('svg')
|
|
1105
|
+
.attr('width', width - rightSvgWidth)
|
|
1106
|
+
.attr('height', height + margin.top + margin.bottom + 60)
|
|
1107
|
+
.append('g')
|
|
1108
|
+
.attr('transform', `translate(0,${margin.top})`);
|
|
1109
|
+
return { outerContainer, svgYAxisLeft, svgYAxisRight, innerContainer, svg };
|
|
1110
|
+
}
|
|
1111
|
+
renderXAxis(svg, x, height, subgroups, metaData, chartConfig, alternate_text, short_tick_length_bg, long_tick_length_bg, self) {
|
|
1112
|
+
if (chartConfig.isMultiChartGridLine == undefined) {
|
|
1113
|
+
// Normal dashboard charts
|
|
1114
|
+
svg
|
|
1115
|
+
.append('g')
|
|
1116
|
+
.attr('class', 'x1 axis1')
|
|
1117
|
+
.attr('transform', `translate(0,${height})`)
|
|
1118
|
+
.call(d3.axisBottom(x))
|
|
1119
|
+
.call((g) => g.select('.domain').remove());
|
|
1120
|
+
svg.selectAll('g.x1.axis1 g.tick line').remove();
|
|
1121
|
+
if (subgroups.length > 1 && !metaData.xLabel) {
|
|
1122
|
+
svg
|
|
1123
|
+
.selectAll('g.x1.axis1 g.tick text')
|
|
1124
|
+
.attr('class', 'lib-xaxis-labels-texts-drilldown')
|
|
1125
|
+
.style('fill', 'var(--chart-text-color)')
|
|
1126
|
+
.attr('y', 32);
|
|
1127
|
+
}
|
|
1128
|
+
else {
|
|
1129
|
+
svg
|
|
1130
|
+
.selectAll('g.x1.axis1 g.tick text')
|
|
1131
|
+
.attr('class', 'lib-xaxis-labels-texts-drilldown')
|
|
1132
|
+
.style('fill', 'var(--chart-text-color)');
|
|
1133
|
+
}
|
|
1134
|
+
}
|
|
1135
|
+
else {
|
|
1136
|
+
// Weekly charts / multi-chart
|
|
1137
|
+
svg
|
|
1138
|
+
.append('g')
|
|
1139
|
+
.attr('class', 'x1 axis1')
|
|
1140
|
+
.attr('transform', `translate(0,${height})`)
|
|
1141
|
+
.call(d3.axisBottom(x).tickSize(0))
|
|
1142
|
+
.call((g) => g.select('.domain').attr('fill', 'none'));
|
|
1143
|
+
// Tick line size in alternate fashion
|
|
1144
|
+
svg.selectAll('g.x1.axis1 g.tick line').attr('y2', function () {
|
|
1145
|
+
if (alternate_text && chartConfig.isNoAlternateXaxisText == undefined) {
|
|
1146
|
+
alternate_text = false;
|
|
1147
|
+
return long_tick_length_bg - 7;
|
|
1148
|
+
}
|
|
1149
|
+
else {
|
|
1150
|
+
alternate_text = true;
|
|
1151
|
+
return short_tick_length_bg - 4;
|
|
1152
|
+
}
|
|
1153
|
+
});
|
|
1154
|
+
// Reset flag
|
|
1155
|
+
alternate_text = false;
|
|
1156
|
+
// X-axis labels
|
|
1157
|
+
svg
|
|
1158
|
+
.selectAll('g.x1.axis1 g.tick text')
|
|
1159
|
+
.attr('class', 'lib-xaxis-labels-texts-weeklycharts')
|
|
1160
|
+
.attr('y', function () {
|
|
1161
|
+
if (chartConfig.isFullScreen)
|
|
1162
|
+
return short_tick_length_bg;
|
|
1163
|
+
if (alternate_text) {
|
|
1164
|
+
alternate_text = false;
|
|
1165
|
+
return long_tick_length_bg;
|
|
1166
|
+
}
|
|
1167
|
+
else {
|
|
1168
|
+
alternate_text = true;
|
|
1169
|
+
return short_tick_length_bg;
|
|
1170
|
+
}
|
|
1171
|
+
});
|
|
1172
|
+
}
|
|
1173
|
+
}
|
|
1174
|
+
renderXAxisLabels(svg, data, subgroups, metaData, chartConfig, short_tick_length_bg, long_tick_length_bg, isMobile, isria, self) {
|
|
1175
|
+
if (!chartConfig.xLabelsOnSameLine)
|
|
1176
|
+
return;
|
|
1177
|
+
const xAxisLabels = svg.selectAll('g.x1.axis1 g.tick text');
|
|
1178
|
+
this.applyLabelStyles(xAxisLabels, data, subgroups, metaData, chartConfig, short_tick_length_bg, long_tick_length_bg, isMobile, self);
|
|
1179
|
+
this.handleLabelText(xAxisLabels, data, subgroups, metaData, chartConfig, isMobile, self);
|
|
1180
|
+
if (isria && data.length > 8) {
|
|
1181
|
+
this.applyRiaLabelOverride(xAxisLabels);
|
|
1182
|
+
}
|
|
1183
|
+
if (isMobile && !self.isHeaderVisible) {
|
|
1184
|
+
xAxisLabels.classed('mobile-xaxis-override', true);
|
|
1185
|
+
}
|
|
1186
|
+
}
|
|
1187
|
+
applyLabelStyles(labels, data, subgroups, metaData, chartConfig, short_tick_length_bg, long_tick_length_bg, isMobile, self) {
|
|
1188
|
+
labels
|
|
1189
|
+
.attr('class', 'lib-xaxis-labels-texts-drilldown')
|
|
1190
|
+
.style('font-size', self.isHeaderVisible ? '18px' : '14px')
|
|
1191
|
+
.attr('text-anchor', 'middle')
|
|
1192
|
+
.attr('y', (d) => this.calculateLabelY(d, data, subgroups, metaData, chartConfig, short_tick_length_bg, long_tick_length_bg, self))
|
|
1193
|
+
.attr('x', (d) => this.calculateLabelX(d, data, self));
|
|
1194
|
+
}
|
|
1195
|
+
calculateLabelY(d, data, subgroups, metaData, chartConfig, short_tick_length_bg, long_tick_length_bg, self) {
|
|
1196
|
+
// Logic from your original code for y positioning
|
|
1197
|
+
if (subgroups.length > 1 && data.length > 8 && metaData.xLabel) {
|
|
1198
|
+
return short_tick_length_bg + 14;
|
|
1199
|
+
}
|
|
1200
|
+
if (subgroups.length > 1 && data.length > 8 && !metaData.xLabel) {
|
|
1201
|
+
return chartConfig.isFullScreen
|
|
1202
|
+
? short_tick_length_bg + 2
|
|
1203
|
+
: short_tick_length_bg + 10;
|
|
1204
|
+
}
|
|
1205
|
+
let baseY = self.isHeaderVisible
|
|
1206
|
+
? short_tick_length_bg + 25
|
|
1207
|
+
: short_tick_length_bg;
|
|
1208
|
+
return baseY;
|
|
1209
|
+
}
|
|
1210
|
+
calculateLabelX(d, data, self) {
|
|
1211
|
+
if (data.length > 8 && !self.isZoomedOut)
|
|
1212
|
+
return 1;
|
|
1213
|
+
return 0;
|
|
1214
|
+
}
|
|
1215
|
+
handleLabelText(labels, data, subgroups, metaData, chartConfig, isMobile, self) {
|
|
1216
|
+
labels.text((d) => {
|
|
1217
|
+
if (isMobile && !self.isHeaderVisible) {
|
|
1218
|
+
return d
|
|
1219
|
+
.split(/[\s\-]+/)[0]
|
|
1220
|
+
.substring(0, 3)
|
|
1221
|
+
.toLowerCase();
|
|
1222
|
+
}
|
|
1223
|
+
// Split dates or weeks, ignore -1 values, etc.
|
|
1224
|
+
// Keep all your previous text-processing logic here
|
|
1225
|
+
return d.toLowerCase(); // fallback
|
|
1226
|
+
});
|
|
1227
|
+
// Example of handling sideways labels for grouped zoomed-out charts
|
|
1228
|
+
labels.each(function (d) {
|
|
1229
|
+
const isDateLabel = /^(\d{2,4}[-\/])?\d{2,4}[-\/]\d{2,4}$/.test(d.trim());
|
|
1230
|
+
const isWeekLabel = /week|wk|w\d+/i.test(d);
|
|
1231
|
+
if (subgroups.length > 1 &&
|
|
1232
|
+
self.isZoomedOut &&
|
|
1233
|
+
data.length > 8 &&
|
|
1234
|
+
isDateLabel &&
|
|
1235
|
+
!isWeekLabel) {
|
|
1236
|
+
d3.select(this).style('writing-mode', 'sideways-lr');
|
|
1237
|
+
}
|
|
1238
|
+
});
|
|
1239
|
+
}
|
|
1240
|
+
applyRiaLabelOverride(labels) {
|
|
1241
|
+
labels
|
|
1242
|
+
.classed('mobile-xaxis-override', true)
|
|
1243
|
+
.text((d) => d.substring(0, 3))
|
|
1244
|
+
.style('font-size', '12px')
|
|
1245
|
+
.attr('y', 5)
|
|
1246
|
+
.attr('x', 5)
|
|
1247
|
+
.style('text-anchor', 'middle');
|
|
1248
|
+
}
|
|
1249
|
+
calculateMaxValue(maxValue) {
|
|
1250
|
+
if (maxValue === 0) {
|
|
1251
|
+
if (this.chartData.targetLineData) {
|
|
1252
|
+
return this.chartData.targetLineData.target + 20;
|
|
1253
|
+
}
|
|
1254
|
+
else {
|
|
1255
|
+
return 100;
|
|
1256
|
+
}
|
|
1257
|
+
}
|
|
1258
|
+
return maxValue;
|
|
1259
|
+
}
|
|
1226
1260
|
handleClick(d) {
|
|
1227
1261
|
if (this.chartData.metaData.hasDrillDown || d?.toggleFrom)
|
|
1228
1262
|
this.clickEvent.emit(d);
|
|
@@ -1262,4 +1296,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
1262
1296
|
}], headerMenuclickEvent: [{
|
|
1263
1297
|
type: Output
|
|
1264
1298
|
}] } });
|
|
1265
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"horizontal-grouped-bar-with-scroll-zoom.component.js","sourceRoot":"","sources":["../../../../../projects/axidio-styleguide-library/src/lib/horizontal-grouped-bar-with-scroll-zoom/horizontal-grouped-bar-with-scroll-zoom.component.ts","../../../../../projects/axidio-styleguide-library/src/lib/horizontal-grouped-bar-with-scroll-zoom/horizontal-grouped-bar-with-scroll-zoom.component.html"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EAET,SAAS,EAET,KAAK,EACL,MAAM,EACN,YAAY,EACZ,iBAAiB,GAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;AACjD,OAAO,WAAW,MAAM,iBAAiB,CAAC;AAC1C,OAAO,KAAK,EAAE,MAAM,IAAI,CAAC;AAEzB,OAAO,kBAAkB,MAAM,kBAAkB,CAAC;;;;;;;AAWlD,MAAM,OAAO,2CACX,SAAQ,iBAAiB;IAyEzB;QACE,KAAK,EAAE,CAAC;QA/DA,eAAU,GAAG,IAAI,YAAY,EAAO,CAAC;QACrC,yBAAoB,GAAG,IAAI,YAAY,EAAO,CAAC;QACzD,oBAAe,GAAY,IAAI,CAAC;QAChC,kBAAa,GAAY,IAAI,CAAC;QAC9B,4BAAuB,GAAY,KAAK,CAAC;QACzC,uBAAkB,GAAQ,EAAE,CAAC;QAC7B,eAAU,GAAG,MAAM,CAAC,IAAI,CAAC;QAEzB,yBAAoB,GAAQ;YAC1B,MAAM,EAAE,EAAE,GAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,MAAM,EAAE,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE;YACpD,cAAc,EAAE,WAAW,CAAC,gBAAgB;YAC5C,SAAS,EAAE,EAAE;YACb,cAAc,EAAE,CAAC;YACjB,eAAe,EAAE,IAAI;YACrB,sBAAsB,EAAE,WAAW,CAAC,gBAAgB;YACpD,kBAAkB,EAAE,WAAW,CAAC,gBAAgB;YAChD,cAAc,EAAE,SAAS;YACzB,iBAAiB,EAAE,IAAI;YACvB,UAAU,EAAE,IAAI;YAChB,iBAAiB,EAAE,kBAAkB,CAAC,YAAY,CAAC,iBAAiB;YACpE,SAAS,EAAE,SAAS;YACpB,SAAS,EAAE,KAAK;YAChB,aAAa,EAAE,KAAK;YACpB,eAAe,EAAE,SAAS;YAC1B,uBAAuB,EAAE,SAAS;YAClC,oBAAoB,EAAE,SAAS;YAC/B,YAAY,EAAE,SAAS;YACvB,YAAY,EAAE,SAAS;YACvB,UAAU,EAAE,SAAS;YACrB,kBAAkB,EAAE,SAAS;YAC7B,kBAAkB,EAAE,KAAK;YACzB,aAAa,EAAE,SAAS;YACxB,aAAa,EAAE,SAAS;YACxB,aAAa,EAAE,SAAS;YACxB,sBAAsB,EAAE,SAAS;YACjC,oBAAoB,EAAE,SAAS;YAC/B,eAAe,EAAE,SAAS;YAC1B,eAAe,EAAE,IAAI;YACrB,YAAY,EAAE,SAAS;YACvB,oBAAoB,EAAE,IAAI;YAC1B,aAAa,EAAE,IAAI;YACnB,kBAAkB,EAAE,IAAI;YACxB,YAAY,EAAE,IAAI;YAClB,kBAAkB,EAAE,SAAS;YAC7B,iBAAiB,EAAE,SAAS;YAC5B,oBAAoB,EAAE,SAAS;YAC/B,gBAAgB,EAAE,SAAS;YAC3B,gBAAgB,EAAE,IAAI;YACtB,iBAAiB,EAAE,SAAS;YAC5B,eAAe,EAAE,SAAS;YAC1B,aAAa,EAAE,SAAS;YACxB,2BAA2B,EAAE,SAAS;YACtC,0BAA0B,EAAE,CAAC;YAC7B,aAAa,EAAE,SAAS;YACxB,gBAAgB,EAAE,CAAC;SACpB,CAAC;QAEF,aAAQ,GAAQ,IAAI,CAAC,WAAW,EAAE,CAAC;QACnC,gBAAW,GAAY,IAAI,CAAC;QAC5B,cAAS,GAAY,KAAK,CAAC;QAC3B,cAAS,GAAY,KAAK,CAAC;QAkC3B,cAAS,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;YACnB,OAAO,CAAC,CAAC;QACX,CAAC,CAAC;IAhCF,CAAC;IAED,SAAS,CAAC,KAAmB;QAC3B,IAAI,IAAI,GAAG,IAAI,CAAC;QAChB,UAAU,CACR;YACE,EAAE,CAAC,MAAM,CAAC,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM,EAAE,CAAC;YACxC,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC9B,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EACZ,EAAE,CACH,CAAC;IACJ,CAAC;IACD,iBAAiB,CAAC,SAAS,EAAE,KAAK;QAChC,IAAI,CAAC,WAAW,GAAG,SAAS,CAAC;QAC7B,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;IACxB,CAAC;IACD,wBAAwB,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE;QAC3C,IAAI,CAAC,iBAAiB,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;IAC3C,CAAC;IACD,QAAQ,KAAI,CAAC;IACb,eAAe;QACb,IACE,IAAI,CAAC,SAAS;YACd,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,MAAM;YAC9B,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,MAAM,GAAG,CAAC,EACtD,CAAC;YACD,OAAO,IAAI,CAAC;QACd,CAAC;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IAKD,IAAI,cAAc;QAChB,OAAO,IAAI,CAAC,kBAAkB,EAAE,iBAAiB,EAAE,IAAI,CACrD,CAAC,MAAM,EAAE,EAAE,CAAC,MAAM,CAAC,EAAE,KAAK,WAAW,CACtC,CAAC;IACJ,CAAC;IACD,oBAAoB;QAClB,IAAI,IAAI,GAAG,IAAI,CAAC;QAChB,IAAI,IAAI,GAAG,EAAE,CAAC;QACd,IAAI,QAAQ,GAAQ,IAAI,CAAC;QACzB,IAAI,OAAO,GAAG,IAAI,CAAC;QACnB,IAAI,QAAQ,GAAG,IAAI,CAAC;QACpB,IAAI,QAAQ,GAAG,EAAE,CAAC;QAClB,IAAI,iBAAiB,CAAC;QACtB,IAAI,oBAAoB,CAAC;QACzB,MAAM,QAAQ,GAAG,MAAM,CAAC,UAAU,GAAG,GAAG,CAAC;QACzC,MAAM,QAAQ,GAAG,MAAM,CAAC,UAAU,IAAI,GAAG,IAAI,MAAM,CAAC,UAAU,GAAG,GAAG,CAAC;QACrE,MAAM,SAAS,GAAG,MAAM,CAAC,UAAU,IAAI,GAAG,CAAC;QAE5C,IAAI,KAAK,GAAG,IAAI,CAAC,wBAAwB,CAAC,KAAK,CAAA;QAE9C,IAAI,CAAM,CAAC;QAEX,IAAI,cAAc,GAAG,KAAK,CAAC;QAC3B,IAAI,iBAAiB,GAAG,CAAC,CAAC;QAC1B,IAAI,gBAAgB,GAAG,EAAE,CAAC;QAC1B,IAAI,oBAAoB,GAAG,CAAC,CAAC;QAC7B,IAAI,mBAAmB,GAAG,EAAE,CAAC;QAC7B,IAAI,kBAAkB,GAAG,EAAE,CAAC;QAC5B,IAAI,aAAa,GAAG,EAAE,CAAC;QACvB,IAAI,SAAS,CAAC;QAEd,KAAK,IAAI,CAAC,IAAI,IAAI,CAAC,oBAAoB,EAAE,CAAC;YACxC,IAAI,CAAC,kBAAkB,CAAC,CAAC,CAAC,GAAG,WAAW,CAAC,2BAA2B,CAClE,CAAC,EACD,IAAI,CAAC,oBAAoB,EACzB,IAAI,CAAC,wBAAwB,CAC9B,CAAC;QACJ,CAAC;QAED,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC;QAC3B,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC;QACnC,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC;QACnC,IAAI,CAAC,QAAQ,CAAC,gBAAgB,EAAE,CAAC;YAC/B,QAAQ,CAAC,kBAAkB,CAAC,GAAG,QAAQ,CAAC,MAAM,CAAC;QACjD,CAAC;QACD,QAAQ,GAAG,QAAQ,CAAC,MAAM,CAAC;QAC3B,OAAO,GAAG,QAAQ,CAAC,OAAO,CAAC;QAE3B,IAAI,cAAc,GAAG,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC;QAChE,IAAI,wBAAwB,GAAG,EAAE,CAAC,MAAM,CACtC,IAAI,CAAC,iBAAiB,CAAC,aAAa,CACrC,CAAC;QACF,IAAI,MAAM,GAAG,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC;QAC5C,IAAI,KAAK,GACP,QAAQ,CAAC,cAAc,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,GAAG,MAAM,CAAC,IAAI,GAAG,MAAM,CAAC,KAAK,CAAC;QACvE,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,GAAG,EAAE,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACxD,KAAK;gBACH,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,GAAG,EAAE;oBACrC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa;wBAC5B,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,GAAG,EAAE;wBACjC,CAAC,CAAC,KAAK;oBACT,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,aAAa;wBAC9B,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,GAAG,EAAE;wBACjC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;YAEtC,KAAK;gBACH,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,GAAG,EAAE;oBACrC,CAAC,CAAC,KAAK;oBACP,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;QACxC,CAAC;QACD,IACE,IAAI,CAAC,SAAS,CAAC,aAAa;YAC5B,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,GAAG,GAAG;YACxC,IAAI,CAAC,WAAW,EAChB,CAAC;YACD,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC;QAC3C,CAAC;QACD,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;YACxD,IACE,IAAI,CAAC,SAAS,CAAC,aAAa;gBAC5B,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,GAAG,GAAG,EACxC,CAAC;gBACD,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC;YAC3C,CAAC;;gBAAM,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,GAAG,GAAG,CAAC;QAClD,CAAC;QAED,IAAI,MAAM,GACR,QAAQ,CAAC,wBAAwB,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;YAChD,CAAC,IAAI,CAAC,kBAAkB,CAAC,SAAS,GAAG,GAAG,CAAC;YAC3C,MAAM,CAAC,GAAG;YACV,MAAM,CAAC,MAAM,CAAC;QAChB,IACE,IAAI,CAAC,kBAAkB,CAAC,YAAY,IAAI,SAAS;YACjD,IAAI,CAAC,kBAAkB,CAAC,YAAY,EACpC,CAAC;YACD,MAAM;gBACJ,IAAI,CAAC,kBAAkB,CAAC,SAAS,IAAI,EAAE;oBACrC,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,SAAS;oBACnC,CAAC,CAAC,QAAQ,CAAC,wBAAwB,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC;QAC3D,CAAC;QACD,IAAI,IAAI,CAAC,kBAAkB,CAAC,gBAAgB,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC;YACtE,MAAM;gBACJ,QAAQ,CAAC,wBAAwB,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;oBAClD,MAAM,CAAC,GAAG;oBACV,MAAM,CAAC,MAAM;oBACb,GAAG,CAAC;QACR,CAAC;QAED,IAAI,IAAI,CAAC,kBAAkB,CAAC,eAAe,EAAE,CAAC;YAC5C,MAAM;gBACJ,QAAQ,CAAC,wBAAwB,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;oBAClD,MAAM,CAAC,GAAG;oBACV,MAAM,CAAC,MAAM;oBACb,GAAG,CAAC;QACR,CAAC;QACD,IAAI,IAAI,CAAC,kBAAkB,CAAC,eAAe,IAAI,SAAS;YACtD,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,kBAAkB,CAAC,eAAe,CAAC;QACjE,IAAI,IAAI,CAAC,kBAAkB,CAAC,aAAa,IAAI,SAAS,EAAE,CAAC;YACvD,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,kBAAkB,CAAC,aAAa,CAAC;QAC7D,CAAC;QACD,IAAI,IAAI,CAAC,kBAAkB,CAAC,uBAAuB,IAAI,SAAS,EAAE,CAAC;YACjE,IAAI,CAAC,uBAAuB;gBAC1B,IAAI,CAAC,kBAAkB,CAAC,uBAAuB,CAAC;QACpD,CAAC;QACD,IAAI,IAAI,CAAC,kBAAkB,CAAC,aAAa,IAAI,SAAS,EAAE,CAAC;YACvD,iBAAiB,GAAG,WAAW,CAAC,kBAAkB,CAChD,IAAI,CAAC,kBAAkB,CAAC,aAAa,CACtC,CAAC;YACF,oBAAoB,GAAG,WAAW,CAAC,kBAAkB,CAAC,KAAK,CAAC,CAAC;QAC/D,CAAC;QACD,IAAI,cAAc,GAAG,cAAc;aAChC,MAAM,CAAC,KAAK,CAAC;aACb,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,QAAQ,CAAC;aACzB,IAAI,CAAC,OAAO,EAAE,iBAAiB,CAAC;aAChC,KAAK,CAAC,OAAO,EAAE,MAAM,CAAC;aACtB,KAAK,CAAC,QAAQ,EAAE,MAAM,CAAC;aAEvB,KAAK,CAAC,YAAY,EAAE,QAAQ,CAAC;aAC7B,KAAK,CAAC,cAAc,EAAE,GAAG,MAAM,CAAC,IAAI,IAAI,CAAC;aAEzC,KAAK,CAAC,eAAe,EAAE,GAAG,aAAa,IAAI,CAAC;aAC5C,KAAK,CAAC,aAAa,EAAE,MAAM,CAAC,CAAC;QAChC,IAAI,YAAY,GAAG,cAAc;aAC9B,MAAM,CAAC,KAAK,CAAC;aACb,IAAI,CAAC,OAAO,EAAE,KAAK,CAAC;aACpB,IAAI,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,CAAC,GAAG,GAAG,MAAM,CAAC,MAAM,GAAG,EAAE,CAAC;aACxD,KAAK,CAAC,UAAU,EAAE,UAAU,CAAC;aAC7B,KAAK,CAAC,MAAM,EAAE,GAAG,CAAC;aAClB,KAAK,CAAC,SAAS,EAAE,CAAC,CAAC;aACnB,MAAM,CAAC,GAAG,CAAC;aACX,IAAI,CACH,WAAW,EACX,YAAY,GAAG,CAAC,MAAM,CAAC,IAAI,GAAG,EAAE,CAAC,GAAG,GAAG,GAAG,MAAM,CAAC,GAAG,GAAG,GAAG,CAC3D,CAAC;QAEJ,IAAI,aAAa,GAAG,cAAc;aAC/B,MAAM,CAAC,KAAK,CAAC;aACb,IAAI,CAAC,OAAO,EAAE,aAAa,CAAC;aAC5B,IAAI,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,CAAC,GAAG,GAAG,MAAM,CAAC,MAAM,GAAG,EAAE,CAAC;aACxD,KAAK,CAAC,UAAU,EAAE,UAAU,CAAC;aAC7B,KAAK,CAAC,OAAO,EAAE,MAAM,CAAC;aACtB,KAAK,CAAC,SAAS,EAAE,CAAC,CAAC;aACnB,MAAM,CAAC,GAAG,CAAC;aACX,IAAI,CAAC,WAAW,EAAE,YAAY,GAAG,CAAC,GAAG,GAAG,GAAG,MAAM,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC;QAEhE,IAAI,cAAc,GAAG,cAAc;aAChC,MAAM,CAAC,KAAK,CAAC;aACb,IAAI,CAAC,OAAO,EAAE,iBAAiB,CAAC;aAChC,KAAK,CAAC,OAAO,EAAE,MAAM,CAAC;aACtB,KAAK,CAAC,YAAY,EAAE,MAAM,CAAC,CAAC;QAE/B,IAAI,GAAG,GAAG,cAAc;aACrB,MAAM,CAAC,KAAK,CAAC;aACb,IAAI,CAAC,OAAO,EAAE,KAAK,GAAG,aAAa,CAAC;aACpC,IAAI,CAAC,QAAQ,EAAE,MAAM,GAAG,MAAM,CAAC,GAAG,GAAG,MAAM,CAAC,MAAM,GAAG,EAAE,CAAC;aACxD,MAAM,CAAC,GAAG,CAAC;aACX,IAAI,CAAC,WAAW,EAAE,YAAY,GAAG,CAAC,GAAG,GAAG,GAAG,MAAM,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC;QAEhE,IAAI,SAAS,GAAQ,OAAO,CAAC;QAE7B,IAAI,MAAM,GAAG,EAAE;aACZ,GAAG,CAAC,IAAI,EAAE,UAAU,CAAC;YACpB,OAAO,CAAC,CAAC,IAAI,CAAC;QAChB,CAAC,CAAC;aACD,IAAI,EAAE,CAAC;QACV,IAAI,IAAI,CAAC,kBAAkB,CAAC,oBAAoB,IAAI,SAAS,EAAE,CAAC;YAC9D,CAAC,GAAG,EAAE;iBACH,SAAS,EAAE;iBACX,UAAU,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;iBACtB,KAAK,CAAC,GAAG,CAAC;iBACV,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC;iBACd,MAAM,CACL,IAAI,CAAC,GAAG,CAAC,UAAU,CAAM;gBACvB,OAAO,CAAC,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;YAC9B,CAAC,CAAC,CACH,CAAC;QACN,CAAC;aAAM,CAAC;YACN,CAAC,GAAG,EAAE;iBACH,SAAS,EAAE;iBACX,MAAM,CAAC,MAAM,CAAC;iBACd,KAAK,CAAC,CAAC,kBAAkB,EAAE,KAAK,GAAG,aAAa,GAAG,kBAAkB,CAAC,CAAC;iBACvE,OAAO,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;QACpB,CAAC;QACD,IAAI,gBAAgB,GAAG,EAAE;aACtB,SAAS,EAAE;aACX,MAAM,CAAC,MAAM,CAAC;aACd,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,GAAG,aAAa,CAAC,CAAC,CAAC;QACrC,IAAI,IAAI,CAAC,kBAAkB,CAAC,oBAAoB,IAAI,SAAS,EAAE,CAAC;YAC9D,GAAG;iBACA,MAAM,CAAC,GAAG,CAAC;iBACX,IAAI,CAAC,OAAO,EAAE,UAAU,CAAC;iBACzB,IAAI,CAAC,WAAW,EAAE,cAAc,GAAG,MAAM,GAAG,GAAG,CAAC;iBAChD,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;iBACtB,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC;YAE7C,GAAG,CAAC,SAAS,CAAC,wBAAwB,CAAC,CAAC,MAAM,EAAE,CAAC;YAEjD,IAAI,SAAS,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC;gBAC7C,GAAG;qBACA,SAAS,CAAC,wBAAwB,CAAC;qBACnC,IAAI,CAAC,OAAO,EAAE,kCAAkC,CAAC;qBACjD,KAAK,CAAC,MAAM,EAAE,yBAAyB,CAAC;qBACxC,IAAI,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;YACnB,CAAC;iBAAM,CAAC;gBACN,GAAG;qBACA,SAAS,CAAC,wBAAwB,CAAC;qBACnC,IAAI,CAAC,OAAO,EAAE,kCAAkC,CAAC;qBACjD,KAAK,CAAC,MAAM,EAAE,yBAAyB,CAAC,CAAC;YAC9C,CAAC;QACH,CAAC;aAAM,CAAC;YACN,GAAG;iBACA,MAAM,CAAC,GAAG,CAAC;iBACX,IAAI,CAAC,OAAO,EAAE,UAAU,CAAC;iBACzB,IAAI,CAAC,WAAW,EAAE,cAAc,GAAG,MAAM,GAAG,GAAG,CAAC;iBAChD,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;iBAClC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC;YACzD,GAAG,CAAC,SAAS,CAAC,wBAAwB,CAAC,CAAC,IAAI,CAAC,IAAI,EAAE;gBACjD,IACE,cAAc;oBACd,IAAI,CAAC,kBAAkB,CAAC,sBAAsB,IAAI,SAAS,EAC3D,CAAC;oBACD,cAAc,GAAG,KAAK,CAAC;oBACvB,OAAO,mBAAmB,GAAG,CAAC,CAAC;gBACjC,CAAC;qBAAM,CAAC;oBACN,cAAc,GAAG,IAAI,CAAC;oBACtB,OAAO,oBAAoB,GAAG,CAAC,CAAC;gBAClC,CAAC;YACH,CAAC,CAAC,CAAC;YACH,cAAc,GAAG,KAAK,CAAC;YACvB,GAAG;iBACA,SAAS,CAAC,wBAAwB,CAAC;iBACnC,IAAI,CAAC,OAAO,EAAE,qCAAqC,CAAC;iBACpD,IAAI,CAAC,GAAG,EAAE;gBACT,IAAI,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;oBACzC,OAAO,oBAAoB,CAAC;gBAC9B,CAAC;gBACD,IAAI,cAAc,EAAE,CAAC;oBACnB,cAAc,GAAG,KAAK,CAAC;oBACvB,OAAO,mBAAmB,CAAC;gBAC7B,CAAC;qBAAM,CAAC;oBACN,cAAc,GAAG,IAAI,CAAC;oBACtB,OAAO,oBAAoB,CAAC;gBAC9B,CAAC;YACH,CAAC,CAAC,CAAC;QACP,CAAC;QACD,IAAI,IAAI,CAAC,kBAAkB,CAAC,iBAAiB,EAAE,CAAC;YAC9C,MAAM,WAAW,GAAG,GAAG;iBACpB,SAAS,CAAC,wBAAwB,CAAC;iBACnC,IAAI,CAAC,OAAO,EAAE,kCAAkC,CAAC;iBACjD,KAAK,CAAC,WAAW,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC;iBAC1D,IAAI,CAAC,aAAa,EAAE,QAAQ,CAAC;iBAC7B,IAAI,CAAC,GAAG,EAAE,UAAS,CAAC;gBACnB,IAAI,SAAS,CAAC,MAAM,GAAG,CAAC,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,QAAQ,CAAC,MAAM,EAAE,CAAC;oBAC/D,MAAM,WAAW,GAAG,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;oBAC3C,IAAI,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;wBACzC,OAAO,WAAW,CAAC,CAAC,CAAC,oBAAoB,GAAG,EAAE,CAAC,CAAC,CAAC,oBAAoB,CAAC;oBACxE,CAAC;oBACD,OAAO,WAAW,CAAC,CAAC,CAAC,oBAAoB,GAAG,EAAE,CAAC,CAAC,CAAC,oBAAoB,CAAC;gBACxE,CAAC;gBACD,IAAI,SAAS,CAAC,MAAM,GAAG,CAAC,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,MAAM,EAAE,CAAC;oBAChE,MAAM,mBAAmB,GAAG,CAAC,IAAI,CAAC,kBAAkB,CAAC,MAAM,IAAI,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,MAAM,IAAI,EAAE,CAAC,CAAC;oBAC5G,IAAI,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;wBACzC,OAAO,oBAAoB,GAAG,CAAC,CAAC;oBAClC,CAAC;oBACD,OAAO,mBAAmB,CAAC,CAAC,CAAC,oBAAoB,CAAC,CAAC,CAAC,oBAAoB,GAAG,EAAE,CAAC;gBAChF,CAAC;gBACD,IAAI,KAAK,GAAG,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,oBAAoB,GAAG,EAAE,CAAC,CAAC,CAAC,oBAAoB,CAAC;gBACpF,IACE,SAAS,CAAC,MAAM,GAAG,CAAC;oBACpB,CAAC,QAAQ,CAAC,MAAM;oBAChB,CAAC,+BAA+B,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,qBAAqB,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,EAC1E,CAAC;oBACD,KAAK,GAAG,IAAI,CAAC,eAAe,CAAC,CAAC,CAAC,oBAAoB,GAAG,EAAE,CAAC,CAAC,CAAC,oBAAoB,GAAG,EAAE,CAAC;gBACvF,CAAC;gBACD,IAAI,qBAAqB,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;oBACzD,KAAK,IAAI,CAAC,CAAC;gBACb,CAAC;gBACD,IAAI,IAAI,CAAC,kBAAkB,CAAC,YAAY,IAAI,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;oBACjE,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,oBAAoB,EAAE,KAAK,GAAG,EAAE,CAAC,CAAC;gBACrD,CAAC;gBACD,OAAO,KAAK,CAAC;YACf,CAAC,CAAC;iBACD,IAAI,CAAC,GAAG,EAAE,UAAU,CAAC;gBACpB,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;oBACxD,OAAO,CAAC,CAAC;gBACX,CAAC;gBACD,OAAO,CAAC,CAAC;YACX,CAAC,CAAC;iBACD,IAAI,CAAC,UAAU,CAAC;gBACf,IAAI,kBAAkB,GAAG,KAAK,CAAC;gBAC/B,IAAI,QAAQ,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC;oBACtC,IAAI,SAAS,GAAG,CAAC,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;oBACtC,OAAO,SAAS,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;gBACjD,CAAC;gBACA,IAAc,CAAC,GAAG,CAAC,CAAC,KAAU,EAAE,EAAE;oBACjC,IACE,KAAK,CAAC,IAAI;wBACV,KAAK,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC,IAAI,EAAE,CAAC,WAAW,EAAE;wBAClD,KAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,EAChC,CAAC;wBACD,kBAAkB,GAAG,IAAI,CAAC;oBAC5B,CAAC;gBACH,CAAC,CAAC,CAAC;gBACH,IAAI,kBAAkB,EAAE,CAAC;oBACvB,OAAO,EAAE,CAAC;gBACZ,CAAC;gBACD,MAAM,cAAc,GAAG,uEAAuE,CAAC;gBAC/F,IAAI,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,EAAE,CAAC;oBAClC,OAAO,CAAC,CAAC,IAAI,EAAE,CAAC,OAAO,CAAC,cAAc,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,GAAG,EAAE,MAAM,EAAE,EAAE,CAAC,CAAC;gBAC1E,CAAC;gBACD,MAAM,WAAW,GAAG,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;gBAC3C,MAAM,WAAW,GAAG,eAAe,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;gBAC5C,IACE,SAAS,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,WAAW,IAAI,WAAW,CAAC,EACnH,CAAC;oBACD,IAAI,KAAK,GAAG,CAAC,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC;oBAC3C,IAAI,MAAM,GAAG,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;oBACpD,OAAO,KAAK,GAAG,IAAI,GAAG,MAAM,CAAC;gBAC/B,CAAC;gBACD,IAAI,WAAW,EAAE,CAAC;oBAChB,IAAI,CAAC,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;wBACpE,IAAI,KAAK,GAAG,CAAC,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC;wBAC3C,IAAI,MAAM,GAAG,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;wBACpD,OAAO,KAAK,GAAG,IAAI,GAAG,MAAM,CAAC;oBAC/B,CAAC;yBAAM,CAAC;wBACN,OAAO,CAAC,CAAC;oBACX,CAAC;gBACH,CAAC;gBACD,IAAI,CAAC,CAAC,IAAI,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;oBAC/B,OAAO,CAAC,CAAC,IAAI,EAAE,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;gBAC7D,CAAC;gBACD,OAAO,CAAC,CAAC,WAAW,EAAE,CAAC;gBACvB,MAAM,YAAY,GAAG,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;gBAC5C,IAAI,WAAW,EAAE,CAAC;oBAChB,IAAI,CAAC,IAAI,CAAC,eAAe,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;wBACpE,IAAI,KAAK,GAAG,CAAC,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC;wBAC3C,IAAI,MAAM,GAAG,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;wBACpD,OAAO,KAAK,GAAG,IAAI,GAAG,MAAM,CAAC;oBAC/B,CAAC;yBAAM,CAAC;wBACN,OAAO,CAAC,CAAC;oBACX,CAAC;gBACH,CAAC;gBACD,IAAI,CAAC,CAAC,IAAI,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;oBAC/B,OAAO,CAAC,CAAC,IAAI,EAAE,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;gBAC7D,CAAC;gBACD,OAAO,CAAC,CAAC,WAAW,EAAE,CAAC;YACzB,CAAC,CAAC,CAAC;YAEL,WAAW,CAAC,IAAI,CAAC,UAA+B,CAAM;gBACpD,MAAM,WAAW,GAAG,sCAAsC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,CAAC;gBAC1E,MAAM,WAAW,GAAG,eAAe,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;gBAC5C,IAAI,SAAS,CAAC,MAAM,GAAG,CAAC,IAAI,IAAI,CAAC,WAAW,IAAI,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,WAAW,IAAI,CAAC,WAAW,EAAE,CAAC;oBAC/F,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,cAAc,EAAE,aAAa,CAAC,CAAC;gBACvD,CAAC;YACH,CAAC,CAAC,CAAC;YACH,IAAI,CAAC,QAAQ,EAAE,CAAC;gBACd,GAAG;qBACA,SAAS,CAAC,mBAAmB,CAAC;qBAC9B,MAAM,CAAC,UAAU,CAAC;oBACjB,OAAO,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;gBACjC,CAAC,CAAC;qBACD,MAAM,CAAC,MAAM,CAAC;qBACd,IAAI,CAAC,OAAO,EAAE,kCAAkC,CAAC;qBACjD,IAAI,CAAC,GAAG,EAAE,mBAAmB,CAAC;qBAC9B,IAAI,CAAC,MAAM,EAAE,yBAAyB,CAAC;qBACvC,IAAI,CAAC,GAAG,EAAE,UAAU,CAAC;oBACpB,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;wBACxD,OAAO,CAAC,CAAC;oBACX,CAAC;oBACD,OAAO,CAAC,CAAC;gBACX,CAAC,CAAC;qBACD,IAAI,CAAC,UAAU,CAAC;oBACf,IAAI,CAAC,CAAC,IAAI,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;wBAC/B,OAAO,CAAC,CAAC,IAAI,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,WAAW,EAAE,CAAC;oBACpE,CAAC;oBACD,OAAO,EAAE,CAAC;gBACZ,CAAC,CAAC,CAAC;YACP,CAAC;QACH,CAAC;QACG,IAAI,KAAK,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAChD,GAAG;iBACA,SAAS,CAAC,wBAAwB,CAAC;iBACnC,OAAO,CAAC,uBAAuB,EAAE,IAAI,CAAC;iBACtC,IAAI,CAAC,UAAU,CAAS;gBACvB,OAAO,CAAC,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;YAC3B,CAAC,CAAC;iBACD,KAAK,CAAC,WAAW,EAAE,MAAM,CAAC;iBAC1B,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;iBACZ,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;iBACZ,KAAK,CAAC,aAAa,EAAE,QAAQ,CAAC,CAAC;QACpC,CAAC;QACD,IAAI,QAAQ,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC;YACtC,GAAG;iBACA,SAAS,CAAC,wBAAwB,CAAC;iBACnC,OAAO,CAAC,uBAAuB,EAAE,IAAI,CAAC,CAAC;QAC5C,CAAC;QACD,IAAI,CAAC,GAAG,EAAE,CAAC,WAAW,EAAE,CAAC,UAAU,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC,CAAC;QACjD,IAAI,QAAQ,GAAG,EAAE,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;QACtE,IAAI,QAAQ,IAAI,CAAC,EAAE,CAAC;YAClB,IAAI,IAAI,CAAC,SAAS,CAAC,cAAc,EAAE,CAAC;gBAClC,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,MAAM,GAAG,EAAE,CAAC;YACvD,CAAC;iBAAM,CAAC;gBACN,QAAQ,GAAG,GAAG,CAAC;YACjB,CAAC;QACH,CAAC;QACD,IAAI,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;YACzC,QAAQ,GAAG,QAAQ,GAAG,IAAI,CAAC,kBAAkB,CAAC,YAAY,CAAC;QAC7D,CAAC;QACD,IACE,IAAI,CAAC,SAAS,CAAC,cAAc;YAC7B,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,MAAM,EAC/C,CAAC;YACD,QAAQ;gBACN,QAAQ,GAAG,EAAE,IAAI,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,MAAM,GAAG,EAAE;oBACxD,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,MAAM,GAAG,CAAC;oBAC1C,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,MAAM,GAAG,EAAE,CAAC;QAClD,CAAC;QACD,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;QAC/B,IAAI,UAAU,CAAC;QAEf,IAAI,QAAQ,IAAI,IAAI,EAAE,CAAC;YACrB,IAAI,YAAY,GAAG,EAAE,CAAC,GAAG,CAAC,QAAQ,EAAE,UAAU,CAAC;gBAC7C,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC;YAClB,CAAC,CAAC,CAAC;YAEH,YAAY,GAAG,YAAY,GAAG,IAAI,CAAC,kBAAkB,CAAC,YAAY,CAAC;YAEnE,IAAI,YAAY,GAAG,EAAE,CAAC,GAAG,CAAC,QAAQ,EAAE,UAAU,CAAC;gBAC7C,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC;YAClB,CAAC,CAAC,CAAC;YACH,IAAI,YAAY,GAAG,CAAC;gBAAE,YAAY,GAAG,YAAY,GAAG,CAAC,CAAC;YACtD,IAAI,YAAY,GAAG,CAAC,EAAE,CAAC;gBACrB,YAAY,GAAG,CAAC,CAAC;YACnB,CAAC;YACD,UAAU,GAAG,EAAE;iBACZ,WAAW,EAAE;iBACb,MAAM,CAAC,CAAC,YAAY,EAAE,YAAY,CAAC,CAAC;iBACpC,KAAK,CAAC,CAAC,MAAM,EAAE,YAAY,CAAC,CAAC,CAAC;QACnC,CAAC;QACD,IAAI,SAAS,CAAC;QACd,IAAI,UAAU,IAAI,IAAI,EAAE,CAAC;YACvB,SAAS,GAAG,EAAE;iBACX,SAAS,CAAC,UAAU,CAAC;iBACrB,KAAK,CAAC,IAAI,CAAC,kBAAkB,CAAC,cAAc,CAAC;iBAC7C,QAAQ,CAAC,CAAC,CAAC;iBACX,UAAU,CAAC,IAAI,CAAC,kBAAkB,CAAC,sBAAsB,CAAC,CAAC;QAChE,CAAC;QACD,IAAI,IAAI,CAAC,kBAAkB,CAAC,oBAAoB,EAAE,CAAC;YACjD,GAAG;iBACA,MAAM,CAAC,GAAG,CAAC;iBACX,IAAI,CAAC,OAAO,EAAE,MAAM,CAAC;iBACrB,IAAI,CACH,WAAW,EACX,YAAY,GAAG,CAAC,CAAC,SAAS,EAAE,GAAG,CAAC,GAAG,GAAG,GAAG,MAAM,GAAG,GAAG,CACtD;iBACA,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;iBACvD,KAAK,CAAC,kBAAkB,EAAE,KAAK,CAAC;iBAChC,KAAK,CAAC,OAAO,EAAE,kCAAkC,CAAC;iBAClD,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC;QAC/C,CAAC;QAED,IAAI,IAAI,CAAC,kBAAkB,CAAC,SAAS,EAAE,CAAC;YACtC,GAAG;iBACA,MAAM,CAAC,GAAG,CAAC;iBACX,IAAI,CACH,EAAE;iBACC,QAAQ,CAAC,CAAC,CAAC;iBACX,KAAK,CAAC,IAAI,CAAC,kBAAkB,CAAC,cAAc,CAAC;iBAC7C,QAAQ,CAAC,CAAC,KAAK,CAAC,CACpB;iBACA,KAAK,CAAC,OAAO,EAAE,kCAAkC,CAAC;iBAClD,KAAK,CAAC,SAAS,EAAE,KAAK,CAAC;iBACvB,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE;gBACV,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC;qBAChB,MAAM,EAAE;qBACR,KAAK,CAAC,QAAQ,EAAE,oCAAoC,CAAC,CAAC;YAC3D,CAAC,CAAC,CAAC;QACP,CAAC;aAAM,CAAC;YACN,GAAG;iBACA,MAAM,CAAC,GAAG,CAAC;iBACX,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,kBAAkB,CAAC,cAAc,CAAC,CAAC;iBAClE,KAAK,CAAC,OAAO,EAAE,kCAAkC,CAAC;iBAClD,KAAK,CAAC,SAAS,EAAE,KAAK,CAAC;iBACvB,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE;gBACV,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC;qBAChB,KAAK,CAAC,QAAQ,EAAE,oCAAoC,CAAC;qBACrD,KAAK,CAAC,cAAc,EAAE,KAAK,CAAC,CAAC;YAClC,CAAC,CAAC,CAAC;QACP,CAAC;QAED,IAAI,SAAS,GAAG,EAAE,CAAC,SAAS,EAAE,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;QACjD,IAAI,SAAS,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;YAClD,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC;QAClC,CAAC;aAAM,IAAI,SAAS,CAAC,MAAM,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;YACvD,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC;QAC5B,CAAC;aAAM,IAAI,IAAI,CAAC,kBAAkB,CAAC,oBAAoB,IAAI,SAAS,EAAE,CAAC;YACrE,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC;QACtC,CAAC;aAAM,CAAC;YACN,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC;QACtC,CAAC;QACD,IAAI,KAAK,GAAG,EAAE;aACX,YAAY,EAAE;aACd,MAAM,CAAC,SAAS,CAAC;aACjB,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC;QACzC,IAAI,KAAK,GAAG,GAAG;aACZ,MAAM,CAAC,GAAG,CAAC;aACX,SAAS,CAAC,QAAQ,CAAC;aACnB,IAAI,CAAC,IAAI,CAAC;aACV,KAAK,EAAE;aACP,MAAM,CAAC,GAAG,CAAC;aACX,IAAI,CAAC,WAAW,EAAE,UAAU,CAAC;YAC5B,OAAO,YAAY,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,KAAK,CAAC;QAC1C,CAAC,CAAC,CAAC;QACL,KAAK;aACF,SAAS,CAAC,MAAM,CAAC;aACjB,IAAI,CAAC,UAAU,CAAC;YACf,IAAI,OAAO,GAAQ,EAAE,CAAC;YACtB,SAAS,CAAC,GAAG,CAAC,UAAU,GAAG;gBACzB,IAAI,GAAG,GAAQ,EAAE,GAAG,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC;gBACzD,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YACpB,CAAC,CAAC,CAAC;YACH,OAAO,OAAO,CAAC;QACjB,CAAC,CAAC;aACD,KAAK,EAAE;aACP,MAAM,CAAC,MAAM,CAAC;aACd,IAAI,CAAC,OAAO,EAAE,MAAM,CAAC;aACrB,EAAE,CAAC,OAAO,EAAE,UAAU,CAAC;YACtB,IAAI,CAAC,CAAC,GAAG,IAAI,QAAQ,EAAE,CAAC;gBACtB,IACE,CAAC,QAAQ,CAAC,eAAe;oBACzB,CAAC,QAAQ,CAAC,eAAe,CAAC,MAAM;oBAChC,CAAC,CAAC,QAAQ,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC,EAAE,IAAI,CAAC;wBAC1C,CAAC,QAAQ,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;oBAE7C,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;YACxB,CAAC;QACH,CAAC,CAAC;aACD,IAAI,CAAC,GAAG,EAAE,UAAU,CAAC;YACpB,IAAI,IAAI,CAAC,kBAAkB,CAAC,gBAAgB,EAAE,CAAC;gBAC7C,IAAI,CAAC,GAAG,CAAC,CAAC,KAAU,EAAE,EAAE;oBACtB,IAAI,KAAK,CAAC,IAAI,IAAI,CAAC,CAAC,IAAI,EAAE,CAAC;wBACzB,IAAI,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;wBAC1D,SAAS,GAAG,EAAE,CAAC,SAAS,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC;wBAClE,IAAI,CAAC,CAAC,SAAS,EAAE,GAAG,GAAG,EAAE,CAAC;4BACxB,IAAI,eAAe,GAAG,EAAE,CAAC;4BACzB,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;gCACtB,eAAe,GAAG,EAAE,CAAC;4BACvB,CAAC;4BACD,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;gCACpC,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;oCACpD,SAAS,CAAC,KAAK,CAAC;wCACd,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,GAAG,eAAe,CAAC,GAAG,CAAC;wCACzC,CAAC,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,GAAG,eAAe,CAAC,GAAG,CAAC;qCACtD,CAAC,CAAC;gCACL,CAAC;;oCACC,SAAS,CAAC,KAAK,CAAC;wCACd,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,GAAG,eAAe,CAAC,GAAG,CAAC;wCACzC,CAAC,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,GAAG,eAAe,CAAC,GAAG,CAAC;qCACtD,CAAC,CAAC;4BACP,CAAC;;gCACC,SAAS,CAAC,KAAK,CAAC;oCACd,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,GAAG,eAAe,CAAC,GAAG,CAAC;oCACzC,CAAC,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,GAAG,eAAe,CAAC,GAAG,CAAC;iCACtD,CAAC,CAAC;wBACP,CAAC;oBACH,CAAC;gBACH,CAAC,CAAC,CAAC;gBACH,OAAO,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;YAC1B,CAAC;YACD,OAAO,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QAC1B,CAAC,CAAC;aACD,IAAI,CAAC,GAAG,EAAE,UAAU,CAAC;YACpB,IAAI,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,EAAE,CAAC;gBAClB,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;YACd,CAAC;YAED,IAAI,CAAC,CAAC,KAAK,IAAI,CAAC,EAAE,CAAC;gBACjB,MAAM,SAAS,GAAG,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;gBACtC,MAAM,SAAS,GAAG,IAAI,CAAC,kBAAkB,CAAC,gBAAgB,IAAI,CAAC,CAAC;gBAChE,OAAO,SAAS,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;YAC/D,CAAC;YAED,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;QACd,CAAC,CAAC;aACD,IAAI,CAAC,OAAO,EAAE,UAAU,CAAC;YACxB,IAAI,SAAS,CAAC,MAAM,GAAG,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;gBAC9C,OAAO,EAAE,CAAC;YACZ,CAAC;YACD,IAAI,SAAS,CAAC,MAAM,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;gBAChD,OAAO,EAAE,CAAC;YACZ,CAAC;YACC,IAAI,SAAS,GAAG,EAAE,CAAC,SAAS,EAAE,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;YAC1D,IAAI,IAAI,CAAC,kBAAkB,CAAC,gBAAgB,EAAE,CAAC;gBAC7C,IAAI,CAAC,GAAG,CAAC,CAAC,KAAU,EAAE,EAAE;oBACtB,IAAI,KAAK,CAAC,IAAI,IAAI,CAAC,CAAC,IAAI,EAAE,CAAC;wBACzB,IAAI,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;wBAC1D,SAAS,GAAG,EAAE,CAAC,SAAS,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC;wBAClE,IAAI,CAAC,CAAC,SAAS,EAAE,GAAG,GAAG,EAAE,CAAC;4BACxB,IAAI,eAAe,GAAG,EAAE,CAAC;4BACzB,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;gCACtB,eAAe,GAAG,GAAG,CAAC;4BACxB,CAAC;4BACD,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;gCACpC,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;oCACpD,SAAS,CAAC,KAAK,CAAC;wCACd,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,GAAG,eAAe,CAAC,GAAG,CAAC;wCACzC,CAAC,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,GAAG,eAAe,CAAC,GAAG,CAAC;qCACtD,CAAC,CAAC;gCACL,CAAC;;oCACC,SAAS,CAAC,KAAK,CAAC;wCACd,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,GAAG,eAAe,CAAC,GAAG,CAAC;wCACzC,CAAC,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,GAAG,eAAe,CAAC,GAAG,CAAC;qCACtD,CAAC,CAAC;4BACP,CAAC;;gCACC,SAAS,CAAC,KAAK,CAAC;oCACd,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,GAAG,eAAe,CAAC,GAAG,CAAC;oCACzC,CAAC,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,GAAG,eAAe,CAAC,GAAG,CAAC;iCACtD,CAAC,CAAC;wBACP,CAAC;oBACH,CAAC;gBACH,CAAC,CAAC,CAAC;gBACH,OAAO,IAAI,CAAC,WAAW;oBACrB,CAAC,CAAC,SAAS,CAAC,SAAS,EAAE;oBACvB,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC;wBAC9D,CAAC,CAAC,SAAS,CAAC,SAAS,EAAE;wBACvB,CAAC,CAAC,SAAS,CAAC,SAAS,EAAE,CAAC;YAC5B,CAAC;YACD,OAAO,IAAI,CAAC,WAAW;gBACrB,CAAC,CAAC,SAAS,CAAC,SAAS,EAAE;gBACvB,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC;oBAC9D,CAAC,CAAC,SAAS,CAAC,SAAS,EAAE;oBACvB,CAAC,CAAC,SAAS,CAAC,SAAS,EAAE,CAAC;QAC5B,CAAC,CAAC;aACD,IAAI,CAAC,QAAQ,EAAE,UAAU,CAAC;YACzB,IAAI,CAAC,CAAC,KAAK,IAAI,CAAC,CAAC,EAAE,CAAC;gBAClB,OAAO,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;YACvB,CAAC;YAED,IAAI,CAAC,CAAC,KAAK,IAAI,CAAC,EAAE,CAAC;gBACjB,MAAM,SAAS,GAAG,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;gBACtC,MAAM,SAAS,GAAG,IAAI,CAAC,kBAAkB,CAAC,gBAAgB,IAAI,CAAC,CAAC;gBAChE,OAAO,IAAI,CAAC,GAAG,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;YACxC,CAAC;YAED,OAAO,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QACvB,CAAC,CAAC;aACD,KAAK,CAAC,QAAQ,EAAE,UAAU,CAAC;YAC1B,IAAI,QAAQ,CAAC,YAAY,IAAI,CAAC,KAAK;gBAAE,OAAO,SAAS,CAAC;;gBAC/C,OAAO,SAAS,CAAC;QAC1B,CAAC,CAAC;aACD,IAAI,CAAC,MAAM,EAAE,UAAU,CAAC;YACvB,IACE,CAAC,CAAC,KAAK;gBACP,IAAI,CAAC,SAAS,CAAC,cAAc;gBAC7B,CAAC,CAAC,KAAK,IAAI,UAAU,CAAC,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,MAAM,CAAC;gBAC3D,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,gBAAgB,EACxC,CAAC;gBACD,MAAM,GAAG,GAAG,CAAC,CAAC,GAAG,CAAC,WAAW,EAAE,CAAC;gBAChC,MAAM,gBAAgB,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,gBAAgB,CAAC,CAAC,IAAI,CACjF,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,KAAK,GAAG,CAC7B,CAAC;gBACF,IAAI,gBAAgB,EAAE,CAAC;oBACrB,OAAO,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,gBAAgB,CAAC,gBAAgB,CAAC,CAAC;gBACpE,CAAC;YACH,CAAC;YACD,OAAO,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QAC/C,CAAC,CAAC,CAAC;QAEL,IAAI,IAAI,CAAC,kBAAkB,CAAC,UAAU,IAAI,SAAS,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;YACzE,KAAK;iBACF,SAAS,CAAC,MAAM,CAAC;iBACjB,IAAI,CAAC,UAAU,CAAC;gBACf,IAAI,OAAO,GAAQ,EAAE,CAAC;gBACtB,SAAS,CAAC,GAAG,CAAC,UAAU,GAAG;oBACzB,IAAI,GAAG,GAAQ,EAAE,GAAG,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC;oBACzD,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;gBACpB,CAAC,CAAC,CAAC;gBACH,OAAO,OAAO,CAAC;YACjB,CAAC,CAAC;iBACD,KAAK,EAAE;iBACP,MAAM,CAAC,MAAM,CAAC;iBACd,IAAI,CAAC,MAAM,EAAE,yBAAyB,CAAC;iBACvC,IAAI,CAAC,GAAG,EAAE,UAAU,CAAC;gBACpB,OAAO,CAAC,CAAC;YACX,CAAC,CAAC;iBACD,IAAI,CAAC,GAAG,EAAE,UAAU,CAAC;gBACpB,OAAO,CAAC,CAAC;YACX,CAAC,CAAC;iBACD,IAAI,CAAC,OAAO,EAAE,8BAA8B,CAAC;iBAC7C,IAAI,CAAC,UAAU,CAAC;gBACf,OAAO,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,KAAK;oBACrB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,GAAG,EAAE;wBACjB,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,KAAK;wBAChC,CAAC,CAAC,CAAC,CAAC,GAAG;oBACT,CAAC,CAAC,EAAE,CAAC;YACT,CAAC,CAAC;iBACD,KAAK,CAAC,MAAM,EAAE,UAAU,CAAC;gBACxB,OAAO,MAAM,CAAC;YAChB,CAAC,CAAC;iBACD,KAAK,CAAC,aAAa,EAAE,MAAM,CAAC;iBAC5B,KAAK,CAAC,WAAW,EAAE,UAAU,CAAC;gBAC7B,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;oBACrB,OAAO,KAAK,CAAC;gBACf,CAAC;gBAED,IAAI,IAAI,CAAC,kBAAkB,CAAC,gBAAgB,EAAE,CAAC;oBAC7C,IAAI,MAAM,CAAC,UAAU,GAAG,IAAI,EAAE,CAAC;wBAC7B,OAAO,MAAM,CAAC;oBAChB,CAAC;yBAAM,IAAI,MAAM,CAAC,UAAU,GAAG,IAAI,EAAE,CAAC;wBACpC,OAAO,MAAM,CAAC;oBAChB,CAAC;yBAAM,CAAC;wBACN,OAAO,MAAM,CAAC;oBAChB,CAAC;gBACH,CAAC;qBAAM,CAAC;oBACN,OAAO,MAAM,CAAC;gBAChB,CAAC;YACH,CAAC,CAAC;iBACD,IAAI,CAAC,WAAW,EAAE,UAAU,CAAC;gBAC5B,IAAI,CAAC,GAAG,CAAC,CAAC,KAAU,EAAE,EAAE;oBACtB,IAAI,KAAK,CAAC,IAAI,IAAI,CAAC,CAAC,IAAI,EAAE,CAAC;wBACzB,IAAI,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;wBAC1D,IAAI,IAAI,CAAC;wBACT,SAAS,GAAG,EAAE,CAAC,SAAS,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC;wBAClE,IAAI,CAAC,CAAC,SAAS,EAAE,GAAG,GAAG,EAAE,CAAC;4BACxB,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;gCACpC,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;oCACpD,SAAS,CAAC,KAAK,CAAC;wCACd,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,GAAG,GAAG,CAAC,GAAG,CAAC;wCAC7B,CAAC,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,GAAG,GAAG,CAAC,GAAG,CAAC;qCAC1C,CAAC,CAAC;gCACL,CAAC;;oCACC,SAAS,CAAC,KAAK,CAAC;wCACd,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,GAAG,GAAG,CAAC,GAAG,CAAC;wCAC7B,CAAC,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,GAAG,GAAG,CAAC,GAAG,CAAC;qCAC1C,CAAC,CAAC;4BACP,CAAC;;gCACC,SAAS,CAAC,KAAK,CAAC;oCACd,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,GAAG,GAAG,CAAC,GAAG,CAAC;oCAC7B,CAAC,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,GAAG,GAAG,CAAC,GAAG,CAAC;iCAC1C,CAAC,CAAC;wBACP,CAAC;oBACH,CAAC;gBACH,CAAC,CAAC,CAAC;gBACH,IAAI,IAAI,CAAC,kBAAkB,CAAC,oBAAoB,EAAE,CAAC;oBACjD,OAAO,CACL,YAAY,GAAG,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,GAAG,CAC/D,CAAC;gBACJ,CAAC;gBACD,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;oBAC1B,OAAO,CACL,YAAY;wBACZ,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,SAAS,CAAC,SAAS,EAAE,GAAG,IAAI,CAAC;wBACjD,GAAG;wBACH,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC;wBACX,eAAe,CAChB,CAAC;gBACJ,OAAO,gBAAgB,CAAC;YAC1B,CAAC,CAAC;iBACD,EAAE,CAAC,OAAO,EAAE,UAAU,CAAC;gBACtB,IACE,CAAC,QAAQ,CAAC,eAAe;oBACzB,CAAC,QAAQ,CAAC,eAAe,CAAC,MAAM;oBAChC,CAAC,CAAC,QAAQ,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC,EAAE,IAAI,CAAC;wBAC1C,CAAC,QAAQ,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;oBAE7C,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;YACxB,CAAC,CAAC,CAAC;YACC,IAAI,CAAC,KAAK,EAAE,CAAC;gBACL,KAAK;qBAChB,SAAS,CAAC,+BAA+B,CAAC;qBAC1C,EAAE,CAAC,UAAU,EAAE,cAAc,CAAC;qBAC9B,EAAE,CAAC,WAAW,EAAE,eAAe,CAAC,CAAC;YAC9B,CAAC;QACT,CAAC;QACD,IAAI,IAAI,CAAC,kBAAkB,CAAC,iBAAiB,IAAI,CAC/C,IAAI,CAAC,kBAAkB,CAAC,UAAU,IAAI,SAAS;YAC/C,IAAI,CAAC,kBAAkB,CAAC,iBAAiB,IAAI,SAAS,CACvD,EAAE,CAAC;YAEU,IAAI,CAAC,KAAK,EAAE,CAAC;gBACL,KAAK;qBACtB,SAAS,CAAC,MAAM,CAAC;qBACjB,EAAE,CAAC,UAAU,EAAE,cAAc,CAAC;qBAC9B,EAAE,CAAC,WAAW,EAAE,eAAe,CAAC,CAAC;YACxB,CAAC;QACf,CAAC;QACD,SAAS,eAAe,CAAC,CAAC,EAAE,CAAC;YAC3B,GAAG,CAAC,SAAS,CAAC,gCAAgC,CAAC,CAAC,MAAM,EAAE,CAAC;YACzD,GAAG;iBACA,MAAM,CAAC,eAAe,CAAC;iBACvB,IAAI,CAAC,GAAG,EAAE;gBACT,IAAI,eAAe,CAAC;gBACpB,IAAI,CAAC,GAAG,CAAC,CAAC,KAAU,EAAE,EAAE;oBACtB,IAAI,KAAK,CAAC,IAAI,IAAI,CAAC,CAAC,IAAI,EAAE,CAAC;wBACzB,IAAI,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;wBAC1D,eAAe,GAAG,IAAI,CAAC,MAAM,CAAC;wBAC9B,SAAS,GAAG,EAAE,CAAC,SAAS,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC;wBAClE,IAAI,CAAC,CAAC,SAAS,EAAE,GAAG,GAAG,EAAE,CAAC;4BACxB,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;gCACpC,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;oCACpD,SAAS,CAAC,KAAK,CAAC;wCACd,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,GAAG,GAAG,CAAC,GAAG,CAAC;wCAC7B,CAAC,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,GAAG,GAAG,CAAC,GAAG,CAAC;qCAC1C,CAAC,CAAC;gCACL,CAAC;;oCACC,SAAS,CAAC,KAAK,CAAC;wCACd,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,GAAG,GAAG,CAAC,GAAG,CAAC;wCAC7B,CAAC,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,GAAG,GAAG,CAAC,GAAG,CAAC;qCAC1C,CAAC,CAAC;4BACP,CAAC;;gCACC,SAAS,CAAC,KAAK,CAAC;oCACd,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,GAAG,GAAG,CAAC,GAAG,CAAC;oCAC7B,CAAC,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,GAAG,GAAG,CAAC,GAAG,CAAC;iCAC1C,CAAC,CAAC;wBACP,CAAC;oBACH,CAAC;gBACH,CAAC,CAAC,CAAC;gBACH,IAAI,QAAQ,CAAC,YAAY,EAAE,CAAC;oBAC1B,IAAI,SAAS,CAAC,SAAS,EAAE,GAAG,kBAAkB,GAAG,CAAC,GAAG,GAAG,EAAE,CAAC;wBACzD,OAAO,CACL,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,SAAS,CAAC,SAAS,EAAE,GAAG,CAAC,GAAG,EAAE,CAC9D,CAAC;oBACJ,CAAC;oBACD,OAAO,CACL,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;wBACT,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC;wBAChB,CAAC,SAAS,CAAC,SAAS,EAAE,GAAG,kBAAkB,GAAG,CAAC,CAAC,GAAG,CAAC;wBACpD,SAAS,CAAC,SAAS,EAAE,GAAG,CAAC,CAC1B,CAAC;gBACJ,CAAC;;oBAAM,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,CAAC,SAAS,CAAC,SAAS,EAAE,GAAG,kBAAkB,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,SAAS,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC;YAChI,CAAC,CAAC;iBACD,IAAI,CAAC,OAAO,EAAE,+BAA+B,CAAC;iBAC9C,IAAI,CAAC,GAAG,EAAE;gBACT,OAAO,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE,GAAG,EAAE,CAAC;YAClC,CAAC,CAAC;iBACD,IAAI,CAAC,IAAI,EAAE;gBACV,OAAO,CAAC,CAAC,KAAK,CAAC;YACjB,CAAC,CAAC;iBACD,IAAI,CAAC,OAAO,EAAE;gBACb,IAAI,CAAC,GAAG,CAAC,CAAC,KAAU,EAAE,EAAE;oBACtB,IAAI,KAAK,CAAC,IAAI,IAAI,CAAC,CAAC,IAAI,EAAE,CAAC;wBACzB,IAAI,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC;wBAC1D,SAAS,GAAG,EAAE,CAAC,SAAS,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC;wBAClE,IAAI,CAAC,CAAC,SAAS,EAAE,GAAG,GAAG,EAAE,CAAC;4BACxB,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;gCACpC,IAAI,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,IAAI,CAAC,EAAE,CAAC;oCACpD,SAAS,CAAC,KAAK,CAAC;wCACd,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,GAAG,GAAG,CAAC,GAAG,CAAC;wCAC7B,CAAC,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,GAAG,GAAG,CAAC,GAAG,CAAC;qCAC1C,CAAC,CAAC;gCACL,CAAC;;oCACC,SAAS,CAAC,KAAK,CAAC;wCACd,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,GAAG,GAAG,CAAC,GAAG,CAAC;wCAC7B,CAAC,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,GAAG,GAAG,CAAC,GAAG,CAAC;qCAC1C,CAAC,CAAC;4BACP,CAAC;;gCACC,SAAS,CAAC,KAAK,CAAC;oCACd,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,GAAG,GAAG,CAAC,GAAG,CAAC;oCAC7B,CAAC,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,GAAG,GAAG,CAAC,GAAG,CAAC;iCAC1C,CAAC,CAAC;wBACP,CAAC;oBACH,CAAC;gBACH,CAAC,CAAC,CAAC;gBACH,IAAI,QAAQ,CAAC,YAAY,EAAE,CAAC;oBAC1B,IAAI,SAAS,CAAC,SAAS,EAAE,GAAG,kBAAkB,GAAG,CAAC,GAAG,GAAG,EAAE,CAAC;wBACzD,OAAO,OAAO,CAAC;oBACjB,CAAC;oBACD,OAAO,SAAS,CAAC,SAAS,EAAE,GAAG,kBAAkB,GAAG,CAAC,CAAC;gBACxD,CAAC;;oBAAM,OAAO,SAAS,CAAC,SAAS,EAAE,GAAG,kBAAkB,GAAG,CAAC,CAAC;YAC/D,CAAC,CAAC;iBACD,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC;iBAClB,MAAM,CAAC,WAAW,CAAC;iBACnB,IAAI,CAAC,OAAO,EAAE,OAAO,CAAC;iBACtB,KAAK,CAAC,SAAS,EAAE,EAAE,CAAC;iBACpB,IAAI,CAAC;gBACJ,IAAI,QAAQ,GAAG,CAAC,CAAC,GAAG,CAAC;gBACrB,IAAI,QAAQ,GAAG,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC;gBAC1D,IAAI,KAAK,GAAG,CAAC,CAAC,KAAK,CAAC;gBACpB,IAAI,WAAW,GACb,+BAA+B,GAAG,QAAQ,GAAG,SAAS,CAAC;gBACzD,WAAW;oBACT,sCAAsC;wBACtC,KAAK;wBACL,SAAS;wBACT,QAAQ;wBACR,SAAS,CAAC;gBACZ,OAAO,WAAW,CAAC;YACrB,CAAC,CAAC,CAAC;QACP,CAAC;QACD,SAAS,cAAc,CAAC,CAAC,EAAE,CAAC;YAC1B,GAAG,CAAC,SAAS,CAAC,gCAAgC,CAAC,CAAC,MAAM,EAAE,CAAC;QAC3D,CAAC;QACD,GAAG;aACA,MAAM,CAAC,GAAG,CAAC;aACX,IAAI,CAAC,OAAO,EAAE,UAAU,CAAC;aACzB,IAAI,CAAC,WAAW,EAAE,cAAc,GAAG,MAAM,GAAG,GAAG,CAAC;aAChD,KAAK,CAAC,OAAO,EAAE,+BAA+B,CAAC;aAC/C,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,gBAAgB,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;aACjD,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC,CAAC;QACzD,GAAG,CAAC,SAAS,CAAC,wBAAwB,CAAC,CAAC,KAAK,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;QACjE,GAAG;aACA,MAAM,CAAC,GAAG,CAAC;aACX,IAAI,CAAC,OAAO,EAAE,sCAAsC,CAAC;aACrD,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,kBAAkB,CAAC,qBAAqB,CAAC;aAC5D,IAAI,CAAC,WAAW,EAAE,gBAAgB,CAAC;aACnC,IAAI,CAAC,CAAC,CAAC;aACP,KAAK,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;QAC5B,YAAY;aACT,MAAM,CAAC,GAAG,CAAC;aACX,MAAM,CAAC,GAAG,CAAC;aACX,IAAI,CAAC,OAAO,EAAE,+CAA+C,CAAC;aAC9D,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,kBAAkB,CAAC,qBAAqB,CAAC;aAC5D,IAAI,CAAC,WAAW,EAAE,gBAAgB,CAAC;aACnC,IAAI,CACH,EAAE;aACC,QAAQ,CAAC,CAAC,CAAC;aACX,QAAQ,CAAC,CAAC,CAAC;aACX,KAAK,CAAC,IAAI,CAAC,kBAAkB,CAAC,cAAc,CAAC;aAC7C,UAAU,CAAC,UAAU,CAAC;YACrB,MAAM,SAAS,GAAG,IAAI,CAAC,kBAAkB,CAAC,kBAAkB;gBAC1D,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,kBAAkB,CAAC,CAAC,CAAC;gBAC/C,CAAC,CAAC,CAAC,CAAC;YACN,OAAO,SAAS,IAAI,IAAI,CAAC,CAAC,CAAC,SAAS,GAAG,IAAI,GAAG,GAAG,CAAC,CAAC,CAAC,SAAS,CAAC;QAChE,CAAC,CAAC,CACL;aACA,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE;YACV,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC;iBAChB,KAAK,CAAC,QAAQ,EAAE,oCAAoC,CAAC;iBACrD,KAAK,CAAC,cAAc,EAAE,KAAK,CAAC,CAAC;QAClC,CAAC,CAAC;aACD,SAAS,CAAC,MAAM,CAAC;aACjB,KAAK,CAAC,MAAM,EAAE,yBAAyB,CAAC,CAAC;QAC5C,aAAa;aACV,MAAM,CAAC,GAAG,CAAC;aACX,IAAI,CAAC,OAAO,EAAE,+CAA+C,CAAC;aAC9D,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,kBAAkB,CAAC,qBAAqB,CAAC;aAC5D,IAAI,CAAC,WAAW,EAAE,gBAAgB,CAAC;aACnC,IAAI,CAAC,CAAC,CAAC;aACP,KAAK,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;QAC5B,IACE,IAAI,CAAC,kBAAkB,CAAC,kBAAkB,IAAI,SAAS;YACvD,IAAI,CAAC,kBAAkB,CAAC,kBAAkB,EAC1C,CAAC;YACD,EAAE,CAAC,SAAS,CAAC,mCAAmC,CAAC,CAAC,IAAI,CACpD,OAAO,EACP,oBAAoB,CACrB,CAAC;QACJ,CAAC;QACD,IACE,IAAI,CAAC,kBAAkB,CAAC,kBAAkB,IAAI,SAAS;YACvD,IAAI,CAAC,kBAAkB,CAAC,kBAAkB,EAC1C,CAAC;YACD,EAAE,CAAC,SAAS,CAAC,0BAA0B,CAAC,CAAC,IAAI,CAC3C,OAAO,EACP,oBAAoB,CACrB,CAAC;QACJ,CAAC;QACD,IACE,IAAI,CAAC,kBAAkB,CAAC,aAAa,IAAI,SAAS;YAClD,IAAI,CAAC,kBAAkB,CAAC,aAAa,EACrC,CAAC;YACD,EAAE,CAAC,SAAS,CAAC,eAAe,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE,oBAAoB,CAAC,CAAC;QACpE,CAAC;QACD,IACE,IAAI,CAAC,kBAAkB,CAAC,aAAa,IAAI,SAAS;YAClD,IAAI,CAAC,kBAAkB,CAAC,aAAa,EACrC,CAAC;YACD,EAAE,CAAC,SAAS,CAAC,eAAe,CAAC;iBAC1B,KAAK,CAAC,kBAAkB,EAAE,KAAK,CAAC;iBAChC,KAAK,CAAC,OAAO,EAAE,kCAAkC,CAAC,CAAC;QACxD,CAAC;QACD,IAAI,QAAQ,IAAI,IAAI,EAAE,CAAC;YACrB,IAAI,QAAQ,IAAI,IAAI,CAAC,kBAAkB,CAAC,iBAAiB,EAAE,CAAC;gBAC1D,aAAa;qBACV,MAAM,CAAC,GAAG,CAAC;qBACX,IAAI,CAAC,OAAO,EAAE,0BAA0B,CAAC;qBACzC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,kBAAkB,CAAC,qBAAqB,CAAC;qBAC5D,IAAI,CAAC,WAAW,EAAE,YAAY,GAAG,CAAC,GAAG,KAAK,CAAC;qBAC3C,IAAI,CAAC,SAAS,CAAC,CAAC;YACrB,CAAC;QACH,CAAC;QAED,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACrB,GAAG;iBACA,SAAS,CAAC,mCAAmC,CAAC;iBAC9C,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE;gBACpB,MAAM,IAAI,GAAG,EAAE,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;gBACjC,MAAM,KAAK,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC;gBAC1B,IAAI,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,CAAC;oBAC7B,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;oBAChC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;oBAChB,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,GAAG,EAAE,EAAE;wBAC1B,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC;6BACjB,IAAI,CAAC,IAAI,CAAC;6BACV,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC;6BACZ,IAAI,CAAC,IAAI,EAAE,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;oBAC7C,CAAC,CAAC,CAAC;gBACL,CAAC;qBAAM,CAAC;oBACN,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;oBAC/B,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;oBAChB,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE;wBAC5B,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;oBAClC,CAAC,CAAC,CAAC;gBACL,CAAC;YACH,CAAC,CAAC;iBACD,KAAK,CAAC,MAAM,EAAE,yBAAyB,CAAC;iBACxC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC;YAE3B,GAAG;iBACA,MAAM,CAAC,SAAS,CAAC;iBACjB,IAAI,CAAC,WAAW,EAAE,gBAAgB,MAAM,GAAG,MAAM,CAAC,MAAM,GAAG,EAAE,GAAG,CAAC,CAAC;QACvE,CAAC;QACL,IAAI,QAAQ,CAAC,MAAM,EAAE,CAAC;YACpB,MAAM,SAAS,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,IAAI,GAAG,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,IAAI,GAAG,CAAC,GAAG,EAAE,CAAC;YAE9E,YAAY;iBACT,MAAM,CAAC,MAAM,CAAC;iBACd,IAAI,CAAC,OAAO,EAAE,kCAAkC,CAAC;iBACjD,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,kBAAkB,CAAC,sBAAsB,CAAC;iBAC7D,IAAI,CAAC,WAAW,EAAE,aAAa,CAAC;iBAChC,IAAI,CAAC,GAAG,EAAE,SAAS,CAAC;iBACpB,IAAI,CAAC,GAAG,EAAE,CAAC,GAAG,MAAM,GAAG,CAAC,CAAC;iBACzB,IAAI,CAAC,IAAI,EAAE,KAAK,CAAC;iBACjB,KAAK,CAAC,aAAa,EAAE,QAAQ,CAAC;iBAC9B,IAAI,CAAC,MAAM,EAAE,yBAAyB,CAAC,CAAC;YAE3C,IAAI,IAAI,CAAC,kBAAkB,CAAC,oBAAoB,KAAK,SAAS,EAAE,CAAC;gBAC/D,YAAY;qBACT,SAAS,CAAC,uBAAuB,CAAC;qBAClC,KAAK,CAAC,WAAW,EAAE,SAAS,CAAC;qBAC7B,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;YAC3B,CAAC;iBAAM,CAAC;gBACN,GAAG;qBACA,SAAS,CAAC,uBAAuB,CAAC;qBAClC,IAAI,CAAC,OAAO,EAAE,yBAAyB,CAAC;qBACxC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC,CAAC;YACzC,CAAC;QACH,CAAC;QAEG,IAAI,IAAI,CAAC,SAAS,CAAC,cAAc,EAAE,CAAC;YAClC,MAAM,KAAK,GAAG,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;YACtD,GAAG;iBACA,MAAM,CAAC,MAAM,CAAC;iBACd,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;iBACb,IAAI,CAAC,IAAI,EAAE,KAAK,CAAC;iBACjB,IAAI,CAAC,IAAI,EAAE,KAAK,CAAC;iBACjB,IAAI,CAAC,IAAI,EAAE,KAAK,CAAC;iBACjB,KAAK,CAAC,kBAAkB,EAAE,KAAK,CAAC;iBAChC,KAAK,CAAC,QAAQ,EAAE,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;YACxD,aAAa;iBACV,MAAM,CAAC,eAAe,CAAC;iBACvB,IAAI,CAAC,WAAW,EAAE,YAAY,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,KAAK,GAAG,EAAE,CAAC,GAAG,GAAG,CAAC;iBAC9D,IAAI,CAAC,OAAO,EAAE,aAAa,CAAC;iBAC5B,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC;iBAClB,MAAM,CAAC,WAAW,CAAC;iBACnB,IAAI,CAAC,OAAO,EAAE,gBAAgB,CAAC;iBAC/B,KAAK,CAAC,OAAO,EAAE,yBAAyB,CAAC;iBACzC,IAAI,CAAC;gBACJ,IAAI,YAAY,GAAG,EAAE,CAAC;gBACtB,IAAI,cAAc,GAAG,QAAQ,CAAC;gBAC9B,IAAI,QAAQ,CAAC,QAAQ,EAAE,CAAC;oBACtB,YAAY,GAAG,QAAQ,CAAC,QAAQ,CAAC;gBACnC,CAAC;gBACD,IACE,IAAI,CAAC,SAAS,CAAC,cAAc;oBAC7B,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,UAAU,EACxC,CAAC;oBACD,cAAc,GAAG,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,UAAU,CAAC;gBAC5D,CAAC;gBACD,OAAO,CACL,QAAQ,cAAc,QAAQ;oBAC9B,OAAO;oBACP,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,MAAM;oBACpC,EAAE;oBACF,YAAY;oBACZ,QAAQ,CACT,CAAC;YACJ,CAAC,CAAC,CAAC;QACP,CAAC;QACD,IAAI,IAAI,CAAC,kBAAkB,CAAC,gBAAgB,EAAE,CAAC;YAC7C,GAAG,CAAC,SAAS,CAAC,wBAAwB,CAAC,CAAC,KAAK,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;QACnE,CAAC;QAED,IAAI,QAAQ,CAAC,MAAM,EAAE,CAAC;YACpB,SAAS,SAAS,CAAC,KAAK;gBACtB,OAAO,CACL,CAAC,KAAK,CAAC,MAAM,IAAI,CAAC,IAAI,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;oBAC7C,CAAC,KAAK,KAAK,KAAK,CAAC,WAAW,EAAE,IAAI,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CACvD,CAAC;YACJ,CAAC;YACD,MAAM,UAAU,GAAG,QAAQ,CAAC,MAAM,CAAC;YACnC,MAAM,KAAK,GAAG,SAAS,CAAC,UAAU,CAAC,OAAO,CAAC,YAAY,EAAE,EAAE,CAAC,CAAC,CAAC;YAE5D,MAAM,SAAS,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,MAAM,CAAC,GAAG,GAAG,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,GAAG,MAAM,CAAC,GAAG,GAAG,MAAM,CAAC,MAAM,GAAG,EAAE,CAAC,CAAC;YAE/G,GAAG;iBACA,MAAM,CAAC,MAAM,CAAC;iBACd,IAAI,CAAC,OAAO,EAAE;gBACb,IAAI,SAAS,GAAG,kCAAkC,CAAC;gBACnD,IAAI,IAAI,CAAC,kBAAkB,CAAC,gBAAgB;oBAC1C,OAAO,SAAS,GAAG,6BAA6B,CAAC;gBACnD,IAAI,IAAI,CAAC,kBAAkB,CAAC,oBAAoB,IAAI,SAAS;oBAC3D,OAAO,SAAS,GAAG,0BAA0B,CAAC;gBAChD,OAAO,SAAS,GAAG,2BAA2B,CAAC;YACjD,CAAC,CAAC;iBACD,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,kBAAkB,CAAC,sBAAsB,CAAC;iBAC7D,IAAI,CACH,WAAW,EACX,YAAY,GAAG,KAAK,GAAG,CAAC,GAAG,IAAI,GAAG,SAAS,GAAG,GAAG,CAClD;iBACA,KAAK,CAAC,aAAa,EAAE,QAAQ,CAAC;iBAC9B,KAAK,CAAC,MAAM,EAAE,yBAAyB,CAAC;iBACxC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,UAAU,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,WAAW,EAAE,CAAC;iBACjE,KAAK,CAAC,gBAAgB,EAAE,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC;QAC5D,CAAC;QACD,IAAI,QAAQ,CAAC,UAAU,EAAE,CAAC;YACxB,aAAa;iBACV,MAAM,CAAC,MAAM,CAAC;iBACd,IAAI,CAAC,OAAO,EAAE,oCAAoC,CAAC;iBACnD,IAAI,CAAC,MAAM,EAAE,yBAAyB,CAAC;iBACvC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,kBAAkB,CAAC,sBAAsB,CAAC;iBAC7D,IAAI,CAAC,WAAW,EAAE,2BAA2B,CAAC;iBAC9C,IAAI,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,CAAC;iBAClB,IAAI,CAAC,GAAG,EAAE,CAAC,GAAG,GAAG,CAAC;iBAClB,IAAI,CAAC,IAAI,EAAE,KAAK,CAAC;iBACjB,KAAK,CAAC,aAAa,EAAE,QAAQ,CAAC;iBAC9B,KAAK,CAAC,WAAW,EAAE,SAAS,CAAC;iBAC7B,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC;QAC/B,CAAC;QACD,IAAI,QAAQ,EAAE,CAAC;YACb,GAAG;iBACA,MAAM,CAAC,MAAM,CAAC;iBACd,KAAK,CAAC,QAAQ,CAAC;iBACf,IAAI,CAAC,MAAM,EAAE,MAAM,CAAC;iBACpB,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,kBAAkB,CAAC,cAAc,CAAC;iBACtD,IAAI,CAAC,cAAc,EAAE,GAAG,CAAC;iBACzB,IAAI,CACH,GAAG,EACH,EAAE;iBACC,IAAI,EAAE;iBACN,CAAC,CAAC,UAAU,CAAC;gBACZ,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC;YACvC,CAAC,CAAC;iBACD,CAAC,CAAC,UAAU,CAAC;gBACZ,OAAO,UAAU,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;YAC7B,CAAC,CAAC,CACL,CAAC;YAEJ,IAAI,GAAG,GAAG,GAAG;iBACV,SAAS,CAAC,WAAW,CAAC;iBACtB,IAAI,CAAC,QAAQ,CAAC;iBACd,KAAK,EAAE;iBACP,MAAM,CAAC,GAAG,CAAC;iBACX,EAAE,CAAC,OAAO,EAAE,UAAU,CAAC;gBACtB,IACE,CAAC,QAAQ,CAAC,eAAe;oBACzB,CAAC,QAAQ,CAAC,eAAe,CAAC,MAAM;oBAChC,CAAC,CAAC,QAAQ,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC,EAAE,IAAI,CAAC;wBAC1C,CAAC,QAAQ,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;oBAE7C,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,CAAC;YACxB,CAAC,CAAC,CAAC;YAEL,GAAG;iBACA,MAAM,CAAC,QAAQ,CAAC;iBAChB,IAAI,CAAC,MAAM,EAAE,UAAU,CAAC;gBACvB,OAAO,IAAI,CAAC,kBAAkB,CAAC,cAAc,CAAC;YAChD,CAAC,CAAC;iBACD,IAAI,CAAC,QAAQ,EAAE,MAAM,CAAC;iBACtB,IAAI,CAAC,IAAI,EAAE,UAAU,CAAC;gBACrB,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC;YACvC,CAAC,CAAC;iBACD,IAAI,CAAC,IAAI,EAAE,UAAU,CAAC;gBACrB,OAAO,UAAU,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;YAC7B,CAAC,CAAC;iBACD,KAAK,CAAC,QAAQ,EAAE,GAAG,EAAE,CACpB,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,YAAY,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAC7D;iBACA,IAAI,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC;YAEhB,IAAI,IAAI,CAAC,kBAAkB,CAAC,cAAc,EAAE,CAAC;gBAC3C,GAAG;qBACA,MAAM,CAAC,MAAM,CAAC;qBACd,IAAI,CAAC,OAAO,EAAE,KAAK,CAAC;qBACpB,IAAI,CAAC,MAAM,EAAE,yBAAyB,CAAC;qBACvC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,kBAAkB,CAAC,cAAc,CAAC;qBACrD,IAAI,CAAC,OAAO,EAAE,aAAa,GAAG,OAAO,CAAC;qBACtC,IAAI,CAAC,GAAG,EAAE,UAAU,CAAC,EAAE,CAAC;oBACvB,OAAO,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,SAAS,EAAE,GAAG,CAAC,CAAC;gBACvC,CAAC,CAAC;qBACD,IAAI,CAAC,GAAG,EAAE,UAAU,CAAC;oBACpB,OAAO,UAAU,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;gBAC7B,CAAC,CAAC;qBACD,IAAI,CAAC,IAAI,EAAE,MAAM,CAAC;qBAClB,IAAI,CAAC,UAAU,CAAC;oBACf,OAAO,IAAI,CAAC,kBAAkB,CAAC,cAAc,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;gBACzD,CAAC,CAAC,CAAC;YACP,CAAC;QACH,CAAC;IACH,CAAC;IAED,WAAW,CAAC,CAAM;QAChB,IAAI,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,YAAY,IAAI,CAAC,EAAE,UAAU;YACvD,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAC5B,CAAC;IACD,qBAAqB,CAAC,EAAE;QACtB,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACrC,CAAC;IACD,cAAc,CAAC,KAAK;QAClB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;IACzB,CAAC;IACD,cAAc,CAAC,KAAK;QAClB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;IACzB,CAAC;IACD,8BAA8B,CAAC,KAAK;QAClC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC9B,CAAC;+GAp0CU,2CAA2C;mGAA3C,2CAA2C,ghBCzBxD,k7HAwHA;;4FD/Fa,2CAA2C;kBATvD,SAAS;+BACE,6CAA6C,iBAMxC,iBAAiB,CAAC,IAAI;wDAOrC,YAAY;sBADX,SAAS;uBAAC,qBAAqB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAIlD,iBAAiB;sBADhB,SAAS;uBAAC,gBAAgB,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;gBAGpC,SAAS;sBAAjB,KAAK;gBACG,wBAAwB;sBAAhC,KAAK;gBACI,UAAU;sBAAnB,MAAM;gBACG,oBAAoB;sBAA7B,MAAM","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  ViewChild,\r\n  ElementRef,\r\n  Input,\r\n  Output,\r\n  EventEmitter,\r\n  ViewEncapsulation,\r\n} from '@angular/core';\r\nimport { ComponentUniqueId } from '../unique-id';\r\nimport ChartHelper from '../chart-helper';\r\nimport * as d3 from 'd3';\r\nimport { ResizedEvent } from 'angular-resize-event';\r\nimport HeaderConfigHelper from '../header-config';\r\n\r\n@Component({\r\n  selector: 'lib-horizontal-grouped-bar-with-scroll-zoom',\r\n  templateUrl: './horizontal-grouped-bar-with-scroll-zoom.component.html',\r\n  styleUrls: [\r\n    './horizontal-grouped-bar-with-scroll-zoom.component.less',\r\n    '../common-styles.less',\r\n  ],\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class HorizontalGroupedBarWithScrollZoomComponent\r\n  extends ComponentUniqueId\r\n  implements OnInit\r\n{\r\n  @ViewChild('groupchartcontainer', { static: true })\r\n  containerElt!: ElementRef;\r\n\r\n  @ViewChild('groupcontainer', { static: true })\r\n  groupcontainerElt!: ElementRef;\r\n\r\n  @Input() chartData: any;\r\n  @Input() customChartConfiguration: any;\r\n  @Output() clickEvent = new EventEmitter<any>();\r\n  @Output() headerMenuclickEvent = new EventEmitter<any>();\r\n  isHeaderVisible: boolean = true;\r\n  legendVisible: boolean = true;\r\n  isTransparentBackground: boolean = false;\r\n  chartConfiguration: any = {};\r\n  objectKeys = Object.keys;\r\n\r\n  defaultConfiguration: any = {\r\n    margin: { top: 20, right: 20, bottom: 20, left: 40 },\r\n    labelFormatter: ChartHelper.defaultFormatter,\r\n    svgHeight: 70,\r\n    numberOfYTicks: 5,\r\n    legendJustified: true,\r\n    yLineAxisLabelFomatter: ChartHelper.defaultFormatter,\r\n    yAxisLabelFomatter: ChartHelper.defaultFormatter,\r\n    lineGraphColor: '#F6D283',\r\n    showLineChartAxis: true,\r\n    showValues: true,\r\n    headerMenuOptions: HeaderConfigHelper.headerConfig.headerMenuOptions,\r\n    xAxisGrid: undefined,\r\n    yAxisGrid: false,\r\n    legendVisible: false,\r\n    isHeaderVisible: undefined,\r\n    isTransparentBackground: undefined,\r\n    isMultiChartGridLine: undefined,\r\n    isFullScreen: undefined,\r\n    customYscale: undefined,\r\n    textsOnBar: undefined,\r\n    isXaxisLabelHidden: undefined,\r\n    isYaxisLabelHidden: false,\r\n    isYaxisHidden: undefined,\r\n    isYaxisDashed: undefined,\r\n    textFormatter: undefined,\r\n    isNoAlternateXaxisText: undefined,\r\n    isXgridBetweenLabels: undefined,\r\n    backgroundColor: '#FFFFFF',\r\n    hideLegendOnTop: true,\r\n    isXaxisColor: '#999999',\r\n    labelOverlapMinorFix: true,\r\n    noHoverEffect: true,\r\n    noHoverDisplayData: true,\r\n    showXaxisTop: true,\r\n    displayYaxisLabels: undefined,\r\n    xLabelsOnSameLine: undefined,\r\n    textAlwaysHorizontal: undefined,\r\n    legendAtTopRight: undefined,\r\n    isDrilldownChart: true,\r\n    displayTitleOnTop: undefined,\r\n    isToggleVisible: undefined,\r\n    isTitleHidden: undefined,\r\n    isDisplayBarDetailsAtBottom: undefined,\r\n    howmanyBarDetailsToDisplay: 0,\r\n    barVauleColor: undefined,\r\n    defaultBarHeight: 2,\r\n  };\r\n\r\n  uniqueId: any = this.getUniqueId();\r\n  isZoomedOut: boolean = true;\r\n  isDD1Open: boolean = false;\r\n  isDD2Open: boolean = false;\r\n\r\n  constructor() {\r\n    super();\r\n  }\r\n\r\n  onResized(event: ResizedEvent) {\r\n    let self = this;\r\n    setTimeout(\r\n      function () {\r\n        d3.select('#' + self.uniqueId).remove();\r\n        self.initializegroupChart();\r\n      }.bind(self),\r\n      10\r\n    );\r\n  }\r\n  isZoomOutSelected(isZoomOut, event) {\r\n    this.isZoomedOut = isZoomOut;\r\n    this.onResized(event);\r\n  }\r\n  handleZoominZoomoutClick({ isZoomOut, event }) {\r\n    this.isZoomOutSelected(isZoomOut, event);\r\n  }\r\n  ngOnInit() {}\r\n  isLegendVisible() {\r\n    if (\r\n      this.chartData &&\r\n      this.chartData.metaData.colors &&\r\n      Object.keys(this.chartData.metaData.colors).length > 1\r\n    ) {\r\n      return true;\r\n    }\r\n    return false;\r\n  }\r\n  keepOrder = (a, b) => {\r\n    return a;\r\n  };\r\n\r\n  get isAlertEnabled(): boolean {\r\n    return this.chartConfiguration?.headerMenuOptions?.some(\r\n      (option) => option.id === 'editAlert'\r\n    );\r\n  }  \r\n  initializegroupChart() {\r\n    var self = this;\r\n    let data = [];\r\n    let metaData: any = null;\r\n    let keyList = null;\r\n    let lineData = null;\r\n    let colorMap = {};\r\n    var formatFromBackend;\r\n    var formatForHugeNumbers;\r\n    const isMobile = window.innerWidth < 576;\r\n    const isTablet = window.innerWidth >= 576 && window.innerWidth < 992;\r\n    const isDesktop = window.innerWidth >= 992;\r\n\r\n   let isria = this.customChartConfiguration.isRia\r\n\r\n    var x: any;\r\n\r\n    var alternate_text = false;\r\n    var short_tick_length = 4;\r\n    var long_tick_length = 16;\r\n    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    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\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    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    if (this.chartConfiguration.isHeaderVisible != undefined)\r\n      this.isHeaderVisible = this.chartConfiguration.isHeaderVisible;\r\n    if (this.chartConfiguration.legendVisible != undefined) {\r\n      this.legendVisible = this.chartConfiguration.legendVisible;\r\n    }\r\n    if (this.chartConfiguration.isTransparentBackground != undefined) {\r\n      this.isTransparentBackground =\r\n        this.chartConfiguration.isTransparentBackground;\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\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('width', width - rightSvgWidth)\r\n      .attr('height', height + margin.top + margin.bottom + 60)\r\n      .append('g')\r\n      .attr('transform', 'translate(' + 0 + ',' + margin.top + ')');\r\n\r\n    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    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    var xScaleFromOrigin = d3\r\n      .scaleBand()\r\n      .domain(groups)\r\n      .range([0, width - rightSvgWidth]);\r\n    if (this.chartConfiguration.isMultiChartGridLine == undefined) {\r\n      svg\r\n        .append('g')\r\n        .attr('class', 'x1 axis1')\r\n        .attr('transform', 'translate(0,' + height + ')')\r\n        .call(d3.axisBottom(x))\r\n        .call((g) => g.select('.domain').remove());\r\n\r\n      svg.selectAll('g.x1.axis1 g.tick line').remove();\r\n\r\n      if (subgroups.length > 1 && !metaData.xLabel) {\r\n        svg\r\n          .selectAll('g.x1.axis1 g.tick text')\r\n          .attr('class', 'lib-xaxis-labels-texts-drilldown')\r\n          .style('fill', 'var(--chart-text-color)')\r\n          .attr('y', 32);\r\n      } else {\r\n        svg\r\n          .selectAll('g.x1.axis1 g.tick text')\r\n          .attr('class', 'lib-xaxis-labels-texts-drilldown')\r\n          .style('fill', 'var(--chart-text-color)');\r\n      }\r\n    } else {\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      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      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('y', function () {\r\n          if (self.chartConfiguration.isFullScreen) {\r\n            return short_tick_length_bg;\r\n          }\r\n          if (alternate_text) {\r\n            alternate_text = false;\r\n            return long_tick_length_bg;\r\n          } else {\r\n            alternate_text = true;\r\n            return short_tick_length_bg;\r\n          }\r\n        });\r\n    }\r\n    if (self.chartConfiguration.xLabelsOnSameLine) {\r\n      const xAxisLabels = svg\r\n        .selectAll('g.x1.axis1 g.tick text')\r\n        .attr('class', 'lib-xaxis-labels-texts-drilldown')\r\n        .style('font-size', this.isHeaderVisible ? '18px' : '14px')\r\n        .attr('text-anchor', 'middle')\r\n        .attr('y', function(d) {\r\n          if (subgroups.length > 1 && data.length > 8 && metaData.xLabel) {\r\n            const isDateLabel = /\\d{2,4}[-\\/]/.test(d);\r\n            if (self.chartConfiguration.isFullScreen) {\r\n              return isDateLabel ? short_tick_length_bg + 14 : short_tick_length_bg;\r\n            }\r\n            return isDateLabel ? short_tick_length_bg + 14 : short_tick_length_bg;\r\n          }\r\n          if (subgroups.length > 1 && data.length > 8 && !metaData.xLabel) {\r\n            const chartHasExtraBottom = (self.chartConfiguration.margin && self.chartConfiguration.margin.bottom >= 40);\r\n            if (self.chartConfiguration.isFullScreen) {\r\n              return short_tick_length_bg + 2;\r\n            }\r\n            return chartHasExtraBottom ? short_tick_length_bg : short_tick_length_bg + 10;\r\n          }\r\n          let baseY = self.isHeaderVisible ? short_tick_length_bg + 25 : short_tick_length_bg;\r\n          if (\r\n            subgroups.length > 1 &&\r\n            !metaData.xLabel &&\r\n            (/\\d{2,4}[-\\/]\\d{2}[-\\/]\\d{2,4}/.test(d) || /\\d{2,4}[-\\/]\\d{2,4}/.test(d))\r\n          ) {\r\n            baseY = self.isHeaderVisible ? short_tick_length_bg + 15 : short_tick_length_bg + 25;\r\n          }\r\n          if (/\\d{2,4}[-\\/]\\d{2,4}/.test(d) && d.indexOf(' ') > -1) {\r\n            baseY += 4;\r\n          }\r\n          if (self.chartConfiguration.isFullScreen && subgroups.length > 1) {\r\n            baseY = Math.max(short_tick_length_bg, baseY - 10);\r\n          }\r\n          return baseY;\r\n        })\r\n        .attr('x', function (d) {\r\n          if (self.chartData.data.length > 8 && !self.isZoomedOut) {\r\n            return 1;\r\n          }\r\n          return 0;\r\n        })\r\n        .text(function (d) {\r\n          var isValueToBeIgnored = false;\r\n          if (isMobile && !self.isHeaderVisible) {\r\n            let firstPart = d.split(/[\\s\\-]+/)[0];\r\n            return firstPart.substring(0, 3).toLowerCase();\r\n          }\r\n          (data as any[]).map((indiv: any) => {\r\n            if (\r\n              indiv.name &&\r\n              indiv.name.toLowerCase() == d.trim().toLowerCase() &&\r\n              indiv[metaData.keyList[0]] == -1\r\n            ) {\r\n              isValueToBeIgnored = true;\r\n            }\r\n          });\r\n          if (isValueToBeIgnored) {\r\n            return '';\r\n          }\r\n          const dateRangeRegex = /(\\d{2,4}[-\\/]\\d{2}[-\\/]\\d{2,4})\\s*-\\s*(\\d{2,4}[-\\/]\\d{2}[-\\/]\\d{2,4})/;\r\n          if (dateRangeRegex.test(d.trim())) {\r\n            return d.trim().replace(dateRangeRegex, (m, d1, d2) => `${d1} - ${d2}`);\r\n          }\r\n          const isDateLabel = /\\d{2,4}[-\\/]/.test(d);\r\n          const isWeekLabel = /week|wk|w\\d+/i.test(d);\r\n          if (\r\n            subgroups.length > 1 && !self.isZoomedOut && data.length > 8 && d.indexOf(' ') > -1 && (isDateLabel || isWeekLabel)\r\n          ) {\r\n            var first = d.substring(0, d.indexOf(' '));\r\n            var second = d.substring(d.indexOf(' ') + 1).trim();\r\n            return first + '\\n' + second;\r\n          }\r\n          if (isDateLabel) {\r\n            if (!self.isHeaderVisible && data.length > 8 && d.indexOf(' ') > -1) {\r\n              var first = d.substring(0, d.indexOf(' '));\r\n              var second = d.substring(d.indexOf(' ') + 1).trim();\r\n              return first + '\\n' + second;\r\n            } else {\r\n              return d;\r\n            }\r\n          }\r\n          if (d.trim().indexOf(' ') > -1) {\r\n            return d.trim().substring(0, d.indexOf(' ')).toLowerCase();\r\n          }\r\n          return d.toLowerCase();\r\n          const isDateLabel2 = /\\d{2,4}[-\\/]/.test(d);\r\n          if (isDateLabel) {\r\n            if (!self.isHeaderVisible && data.length > 8 && d.indexOf(' ') > -1) {\r\n              var first = d.substring(0, d.indexOf(' '));\r\n              var second = d.substring(d.indexOf(' ') + 1).trim();\r\n              return first + '\\n' + second;\r\n            } else {\r\n              return d;\r\n            }\r\n          }\r\n          if (d.trim().indexOf(' ') > -1) {\r\n            return d.trim().substring(0, d.indexOf(' ')).toLowerCase();\r\n          }\r\n          return d.toLowerCase();\r\n        });\r\n\r\n      xAxisLabels.each(function(this: SVGTextElement, d: any) {\r\n        const isDateLabel = /^(\\d{2,4}[-\\/])?\\d{2,4}[-\\/]\\d{2,4}$/.test(d.trim());\r\n        const isWeekLabel = /week|wk|w\\d+/i.test(d);\r\n        if (subgroups.length > 1 && self.isZoomedOut && data.length > 8 && isDateLabel && !isWeekLabel) {\r\n          d3.select(this).style('writing-mode', 'sideways-lr');\r\n        }\r\n      });\r\n      if (!isMobile) {\r\n        svg\r\n          .selectAll('g.x1.axis1 g.tick')\r\n          .filter(function (d) {\r\n            return !/\\d{2,4}[-\\/]/.test(d);\r\n          })\r\n          .append('text')\r\n          .attr('class', 'lib-xaxis-labels-texts-drilldown')\r\n          .attr('y', long_tick_length_bg)\r\n          .attr('fill', 'var(--chart-text-color)')\r\n          .attr('x', function (d) {\r\n            if (self.chartData.data.length > 8 && !self.isZoomedOut) {\r\n              return 1;\r\n            }\r\n            return 0;\r\n          })\r\n          .text(function (d) {\r\n            if (d.trim().indexOf(' ') > -1) {\r\n              return d.trim().substring(d.indexOf(' '), d.length).toLowerCase();\r\n            }\r\n            return '';\r\n          });\r\n      }\r\n    }\r\n        if (isria && self.chartData.data.length > 8) {\r\n      svg\r\n        .selectAll('g.x1.axis1 g.tick text')\r\n        .classed('mobile-xaxis-override', true)\r\n        .text(function (d: string) {\r\n          return d.substring(0, 3);\r\n        })\r\n        .style('font-size', '12px') \r\n        .attr('y', 5)               \r\n        .attr('x', 5)                \r\n        .style('text-anchor', 'middle');\r\n    }\r\n    if (isMobile && !this.isHeaderVisible) {\r\n      svg\r\n        .selectAll('g.x1.axis1 g.tick text')\r\n        .classed('mobile-xaxis-override', true);\r\n    }\r\n    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 (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    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    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)')\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)');\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)')\r\n            .style('stroke-width', '1px');\r\n        });\r\n    }\r\n\r\n    var xSubgroup = d3.scaleBand().domain(subgroups);\r\n    if (subgroups.length > 1 && !this.isZoomedOut) {\r\n  xSubgroup.range([0, x.bandwidth()]);\r\n    } else if (subgroups.length === 1 && !this.isZoomedOut) {\r\n      xSubgroup.range([0, 100]);\r\n    } else if (this.chartConfiguration.isMultiChartGridLine == undefined) {\r\n      xSubgroup.range([0, x.bandwidth()]);\r\n    } else {\r\n      xSubgroup.range([0, x.bandwidth()]);\r\n    }\r\n    var color = d3\r\n      .scaleOrdinal()\r\n      .domain(subgroups)\r\n      .range(Object.values(metaData.colors));\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          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('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);\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                let reducedBarWidth = 60;\r\n                if (!self.isZoomedOut) {\r\n                  reducedBarWidth = 30;\r\n                }\r\n                if (self.chartData.data.length == 1) {\r\n                  if (Object.keys(self.chartData.data[0]).length == 2) {\r\n                    tempScale.range([\r\n                      0 + (x.bandwidth() - reducedBarWidth) / 2,\r\n                      x.bandwidth() - (x.bandwidth() - reducedBarWidth) / 2,\r\n                    ]);\r\n                  } else\r\n                    tempScale.range([\r\n                      0 + (x.bandwidth() - reducedBarWidth) / 2,\r\n                      x.bandwidth() - (x.bandwidth() - reducedBarWidth) / 2,\r\n                    ]);\r\n                } else\r\n                  tempScale.range([\r\n                    0 + (x.bandwidth() - reducedBarWidth) / 2,\r\n                    x.bandwidth() - (x.bandwidth() - reducedBarWidth) / 2,\r\n                  ]);\r\n              }\r\n            }\r\n          });\r\n          return tempScale(d.key);\r\n        }\r\n        return xSubgroup(d.key);\r\n      })\r\n      .attr('y', function (d) {\r\n        if (d.value == -1) {\r\n          return y(0);\r\n        }\r\n\r\n        if (d.value >= 0) {\r\n          const barHeight = height - y(d.value);\r\n          const minHeight = self.chartConfiguration.defaultBarHeight || 2;\r\n          return barHeight < minHeight ? y(0) - minHeight : y(d.value);\r\n        }\r\n\r\n        return y(0);\r\n      })\r\n      .attr('width', function (d) {\r\n        if (subgroups.length > 1 && !self.isZoomedOut) {\r\n          return 50;\r\n        }\r\n        if (subgroups.length === 1 && !self.isZoomedOut) {\r\n          return 80;\r\n        }\r\n          let tempScale = d3.scaleBand().domain([]).range([0, 0]);\r\n        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                let reducedBarWidth = 60;\r\n                if (!self.isZoomedOut) {\r\n                  reducedBarWidth = 100;\r\n                }\r\n                if (self.chartData.data.length == 1) {\r\n                  if (Object.keys(self.chartData.data[0]).length == 2) {\r\n                    tempScale.range([\r\n                      0 + (x.bandwidth() - reducedBarWidth) / 2,\r\n                      x.bandwidth() - (x.bandwidth() - reducedBarWidth) / 2,\r\n                    ]);\r\n                  } else\r\n                    tempScale.range([\r\n                      0 + (x.bandwidth() - reducedBarWidth) / 2,\r\n                      x.bandwidth() - (x.bandwidth() - reducedBarWidth) / 2,\r\n                    ]);\r\n                } else\r\n                  tempScale.range([\r\n                    0 + (x.bandwidth() - reducedBarWidth) / 2,\r\n                    x.bandwidth() - (x.bandwidth() - reducedBarWidth) / 2,\r\n                  ]);\r\n              }\r\n            }\r\n          });\r\n          return self.isZoomedOut\r\n            ? tempScale.bandwidth()\r\n            : self.chartData.data.length && self.chartData.data.length > 8\r\n            ? tempScale.bandwidth() \r\n            : tempScale.bandwidth();\r\n        }\r\n        return self.isZoomedOut\r\n          ? tempScale.bandwidth()\r\n          : self.chartData.data.length && self.chartData.data.length > 8\r\n          ? tempScale.bandwidth()\r\n          : tempScale.bandwidth();\r\n      })\r\n      .attr('height', function (d) {\r\n        if (d.value == -1) {\r\n          return height - y(0);\r\n        }\r\n\r\n        if (d.value >= 0) {\r\n          const barHeight = height - y(d.value);\r\n          const minHeight = self.chartConfiguration.defaultBarHeight || 2;\r\n          return Math.max(barHeight, minHeight);\r\n        }\r\n\r\n        return height - y(0);\r\n      })\r\n      .style('cursor', function (d) {\r\n        if (metaData.hasDrillDown && !isria) return 'pointer';\r\n          else return 'default';\r\n      })\r\n      .attr('fill', function (d) {\r\n        if (\r\n          d.value &&\r\n          self.chartData.targetLineData &&\r\n          d.value >= parseFloat(self.chartData.targetLineData.target) &&\r\n          self.chartData.metaData.colorAboveTarget\r\n        ) {\r\n          const key = d.key.toLowerCase();\r\n          const colorAboveTarget = Object.keys(self.chartData.metaData.colorAboveTarget).find(\r\n            k => k.toLowerCase() === key\r\n          );\r\n          if (colorAboveTarget) {\r\n            return self.chartData.metaData.colorAboveTarget[colorAboveTarget];\r\n          }\r\n        }\r\n        return self.chartData.metaData.colors[d.key];\r\n      });\r\n\r\n    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';\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                  } 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 (self.chartConfiguration.textAlwaysHorizontal) {\r\n            return (\r\n              'translate(' + xSubgroup(d.key) + ',' + (y(d.value) - 3) + ')'\r\n            );\r\n          }\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        })\r\n        .on('click', function (d) {\r\n          if (\r\n            !metaData.barWithoutClick ||\r\n            !metaData.barWithoutClick.length ||\r\n            (!metaData.barWithoutClick.includes(d?.name) &&\r\n              !metaData.barWithoutClick.includes(d?.key))\r\n          )\r\n            self.handleClick(d);\r\n        });\r\n            if (!isria) {\r\n                    state\r\n        .selectAll('.lib-data-labels-weeklycharts')\r\n        .on('mouseout', handleMouseOut)\r\n        .on('mouseover', handleMouseOver);\r\n            }\r\n    }\r\n    if (this.chartConfiguration.displayTitleOnTop || (\r\n      this.chartConfiguration.textsOnBar == undefined &&\r\n      this.chartConfiguration.displayTitleOnTop == undefined\r\n    )) {\r\n\r\n                  if (!isria) {\r\n                          state\r\n        .selectAll('rect')\r\n        .on('mouseout', handleMouseOut)\r\n        .on('mouseover', handleMouseOver);\r\n                  }\r\n    }\r\n    function handleMouseOver(d, i) {\r\n      svg.selectAll('.lib-verticalstack-title-ontop').remove();\r\n      svg\r\n        .append('foreignObject')\r\n        .attr('x', function () {\r\n          var elementsCounter;\r\n          data.map((indiv: any) => {\r\n            if (indiv.name == d.name) {\r\n              let keys = Object.keys(indiv).filter((temp, i) => i != 0);\r\n              elementsCounter = keys.length;\r\n              tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);\r\n              if (x.bandwidth() > 100) {\r\n                if (self.chartData.data.length == 1) {\r\n                  if (Object.keys(self.chartData.data[0]).length == 2) {\r\n                    tempScale.range([\r\n                      0 + (x.bandwidth() - 200) / 2,\r\n                      x.bandwidth() - (x.bandwidth() - 200) / 2,\r\n                    ]);\r\n                  } else\r\n                    tempScale.range([\r\n                      0 + (x.bandwidth() - 300) / 2,\r\n                      x.bandwidth() - (x.bandwidth() - 300) / 2,\r\n                    ]);\r\n                } else\r\n                  tempScale.range([\r\n                    0 + (x.bandwidth() - 125) / 2,\r\n                    x.bandwidth() - (x.bandwidth() - 125) / 2,\r\n                  ]);\r\n              }\r\n            }\r\n          });\r\n          if (metaData.hasDrillDown) {\r\n            if (tempScale.bandwidth() + leftAndRightSpaces * 2 > 180) {\r\n              return (\r\n                x(d.name) + tempScale(d.key) + tempScale.bandwidth() / 2 - 90\r\n              );\r\n            }\r\n            return (\r\n              x(d.name) +\r\n              tempScale(d.key) -\r\n              (tempScale.bandwidth() + leftAndRightSpaces * 2) / 2 +\r\n              tempScale.bandwidth() / 2\r\n            );\r\n          } else return x(d.name) + tempScale(d.key) - (tempScale.bandwidth() + leftAndRightSpaces * 2) / 2 + tempScale.bandwidth() / 2;\r\n        })\r\n        .attr('class', 'lib-verticalstack-title-ontop')\r\n        .attr('y', function () {\r\n          return y(d.value) - 3 - 40 - 10;\r\n        })\r\n        .attr('dy', function () {\r\n          return d.class;\r\n        })\r\n        .attr('width', function () {\r\n          data.map((indiv: any) => {\r\n            if (indiv.name == d.name) {\r\n              let keys = Object.keys(indiv).filter((temp, i) => i != 0);\r\n              tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);\r\n              if (x.bandwidth() > 100) {\r\n                if (self.chartData.data.length == 1) {\r\n                  if (Object.keys(self.chartData.data[0]).length == 2) {\r\n                    tempScale.range([\r\n                      0 + (x.bandwidth() - 200) / 2,\r\n                      x.bandwidth() - (x.bandwidth() - 200) / 2,\r\n                    ]);\r\n                  } else\r\n                    tempScale.range([\r\n                      0 + (x.bandwidth() - 300) / 2,\r\n                      x.bandwidth() - (x.bandwidth() - 300) / 2,\r\n                    ]);\r\n                } else\r\n                  tempScale.range([\r\n                    0 + (x.bandwidth() - 125) / 2,\r\n                    x.bandwidth() - (x.bandwidth() - 125) / 2,\r\n                  ]);\r\n              }\r\n            }\r\n          });\r\n          if (metaData.hasDrillDown) {\r\n            if (tempScale.bandwidth() + leftAndRightSpaces * 2 > 180) {\r\n              return '180px';\r\n            }\r\n            return tempScale.bandwidth() + leftAndRightSpaces * 2;\r\n          } else return tempScale.bandwidth() + leftAndRightSpaces * 2;\r\n        })\r\n        .attr('height', 50)\r\n        .append('xhtml:div')\r\n        .attr('class', 'title')\r\n        .style('z-index', 99)\r\n        .html(function () {\r\n          let barLabel = d.key;\r\n          let dataType = metaData.dataType ? metaData.dataType : '';\r\n          let value = d.value;\r\n          let desiredText =\r\n            '<span class=\"title-bar-name\">' + barLabel + '</span>';\r\n          desiredText +=\r\n            '<span class=\"title-bar-value\"><span>' +\r\n            value +\r\n            '</span>' +\r\n            dataType +\r\n            '</span>';\r\n          return desiredText;\r\n        });\r\n    }\r\n    function handleMouseOut(d, i) {\r\n      svg.selectAll('.lib-verticalstack-title-ontop').remove();\r\n    }\r\n    svg\r\n      .append('g')\r\n      .attr('class', 'x2 axis2')\r\n      .attr('transform', 'translate(0,' + height + ')')\r\n      .style('color', 'var(--chart-axis-color, #000)')\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        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    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    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    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    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)');\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    if (this.isZoomedOut) {\r\n      svg\r\n        .selectAll('.lib-xaxis-labels-texts-drilldown')\r\n        .each((d, i, nodes) => {\r\n          const text = d3.select(nodes[i]);\r\n          const label = text.text();\r\n          if (label.indexOf('\\n') > -1) {\r\n            const lines = label.split('\\n');\r\n            text.text(null);\r\n            lines.forEach((line, idx) => {\r\n              text.append('tspan')\r\n                .text(line)\r\n                .attr('x', 0)\r\n                .attr('dy', idx === 0 ? '1em' : '1.1em');\r\n            });\r\n          } else {\r\n            const words = label.split(' ');\r\n            text.text(null);\r\n            words.forEach((word, index) => {\r\n              text.append('tspan').text(word);\r\n            });\r\n          }\r\n        })\r\n        .style('fill', 'var(--chart-text-color)')\r\n        .attr('transform', null);\r\n\r\n      svg\r\n        .select('.x-axis')\r\n        .attr('transform', `translate(0, ${height - margin.bottom + 10})`);\r\n    }\r\nif (metaData.yLabel) {\r\n  const yPosition = isria ? 0 - margin.left / 2 - 30 : 0 - margin.left / 2 - 40;\r\n\r\n  svgYAxisLeft\r\n    .append('text')\r\n    .attr('class', 'lib-axis-group-label font-size-1')\r\n    .attr('style', self.chartConfiguration.yAxisCustomlabelStyles)\r\n    .attr('transform', 'rotate(-90)')\r\n    .attr('y', yPosition)\r\n    .attr('x', 0 - height / 2)\r\n    .attr('dy', '1em')\r\n    .style('text-anchor', 'middle')\r\n    .attr('fill', 'var(--chart-text-color)');\r\n\r\n  if (this.chartConfiguration.isMultiChartGridLine === undefined) {\r\n    svgYAxisLeft\r\n      .selectAll('.lib-axis-group-label')\r\n      .style('font-size', 'smaller')\r\n      .text(metaData.yLabel);\r\n  } else {\r\n    svg\r\n      .selectAll('.lib-axis-group-label')\r\n      .attr('class', 'lib-ylabel-weeklyCharts')\r\n      .text(metaData.yLabel.toLowerCase());\r\n  }\r\n}\r\n\r\n    if (this.chartData.targetLineData) {\r\n      const yZero = y(this.chartData.targetLineData.target);\r\n      svg\r\n        .append('line')\r\n        .attr('x1', 0)\r\n        .attr('x2', width)\r\n        .attr('y1', yZero)\r\n        .attr('y2', yZero)\r\n        .style('stroke-dasharray', '5 5')\r\n        .style('stroke', this.chartData.targetLineData.color);\r\n      svgYAxisRight\r\n        .append('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      svg.selectAll('g.x1.axis1 g.tick line').style('display', 'none');\r\n    }\r\n\r\n    if (metaData.xLabel) {\r\n      function isAcronym(label) {\r\n        return (\r\n          (label.length <= 4 && /^[A-Z]+$/.test(label)) ||\r\n          (label === label.toUpperCase() && /[A-Z]/.test(label))\r\n        );\r\n      }\r\n      const xLabelText = metaData.xLabel;\r\n      const isAcr = isAcronym(xLabelText.replace(/[^A-Za-z]/g, ''));\r\n\r\n        const xPosition = isria ? (height + margin.top + margin.bottom) : (height + margin.top + margin.bottom + 40);\r\n\r\n      svg\r\n        .append('text')\r\n        .attr('class', function () {\r\n          let baseClass = 'lib-axis-group-label font-size-1';\r\n          if (self.chartConfiguration.isDrilldownChart)\r\n            return baseClass + ' lib-xlabel-drilldowncharts';\r\n          if (self.chartConfiguration.isMultiChartGridLine != undefined)\r\n            return baseClass + ' lib-xlabel-weeklyCharts';\r\n          return baseClass + ' lib-axis-waterfall-label';\r\n        })\r\n        .attr('style', self.chartConfiguration.xAxisCustomlabelStyles)\r\n        .attr(\r\n          'transform',\r\n          'translate(' + width / 2 + ' ,' + xPosition + ')'\r\n        )\r\n        .style('text-anchor', 'middle')\r\n        .style('fill', 'var(--chart-text-color)')\r\n        .text(isAcr ? xLabelText.toUpperCase() : xLabelText.toLowerCase())\r\n        .style('text-transform', isAcr ? 'none' : 'capitalize');\r\n    }\r\n    if (metaData.lineyLabel) {\r\n      svgYAxisRight\r\n        .append('text')\r\n        .attr('class', 'lib-axis-group-label lib-line-axis')\r\n        .attr('fill', 'var(--chart-text-color)')\r\n        .attr('style', self.chartConfiguration.yAxisCustomlabelStyles)\r\n        .attr('transform', 'translate(0,0) rotate(90)')\r\n        .attr('y', 0 - 100)\r\n        .attr('x', 0 + 100)\r\n        .attr('dy', '5em')\r\n        .style('text-anchor', 'middle')\r\n        .style('font-size', 'smaller')\r\n        .text(metaData.lineyLabel);\r\n    }\r\n    if (lineData) {\r\n      svg\r\n        .append('path')\r\n        .datum(lineData)\r\n        .attr('fill', 'none')\r\n        .attr('stroke', self.chartConfiguration.lineGraphColor)\r\n        .attr('stroke-width', 1.5)\r\n        .attr(\r\n          'd',\r\n          d3\r\n            .line()\r\n            .x(function (d) {\r\n              return x(d.name) + x.bandwidth() / 2;\r\n            })\r\n            .y(function (d) {\r\n              return lineYscale(d.value);\r\n            })\r\n        );\r\n\r\n      var dot = svg\r\n        .selectAll('myCircles')\r\n        .data(lineData)\r\n        .enter()\r\n        .append('g')\r\n        .on('click', function (d) {\r\n          if (\r\n            !metaData.barWithoutClick ||\r\n            !metaData.barWithoutClick.length ||\r\n            (!metaData.barWithoutClick.includes(d?.name) &&\r\n              !metaData.barWithoutClick.includes(d?.key))\r\n          )\r\n            self.handleClick(d);\r\n        });\r\n\r\n      dot\r\n        .append('circle')\r\n        .attr('fill', function (d) {\r\n          return self.chartConfiguration.lineGraphColor;\r\n        })\r\n        .attr('stroke', 'none')\r\n        .attr('cx', function (d) {\r\n          return x(d.name) + x.bandwidth() / 2;\r\n        })\r\n        .attr('cy', function (d) {\r\n          return lineYscale(d.value);\r\n        })\r\n        .style('cursor', () =>\r\n          self.chartData.metaData.hasDrillDown ? 'pointer' : 'default'\r\n        )\r\n        .attr('r', 3);\r\n\r\n      if (self.chartConfiguration.lineGraphColor) {\r\n        dot\r\n          .append('text')\r\n          .attr('class', 'dot')\r\n          .attr('fill', 'var(--chart-text-color)')\r\n          .attr('color', self.chartConfiguration.lineGraphColor)\r\n          .attr('style', 'font-size: ' + '.85em')\r\n          .attr('x', function (d, i) {\r\n            return x(d.name) + x.bandwidth() / 2;\r\n          })\r\n          .attr('y', function (d) {\r\n            return lineYscale(d.value);\r\n          })\r\n          .attr('dy', '-1em')\r\n          .text(function (d) {\r\n            return self.chartConfiguration.labelFormatter(d.value);\r\n          });\r\n      }\r\n    }\r\n  }\r\n\r\n  handleClick(d: any) {\r\n    if (this.chartData.metaData.hasDrillDown || d?.toggleFrom)\r\n      this.clickEvent.emit(d);\r\n  }\r\n  handleHeaderMenuClick(id) {\r\n    this.headerMenuclickEvent.emit(id);\r\n  }\r\n  handleDD1Click(event) {\r\n    this.isDD1Open = true;\r\n    this.isDD2Open = false;\r\n  }\r\n  handleDD2Click(event) {\r\n    this.isDD2Open = true;\r\n    this.isDD1Open = false;\r\n  }\r\n  handleCompareByFilterSelection(event) {\r\n    this.clickEvent.emit(event);\r\n  }\r\n}\r\n","<div\r\n  #groupcontainer\r\n  class=\"lib-chart-wrapper\"\r\n  [ngClass]=\"{ 'lib-no-background': isTransparentBackground }\"\r\n  style=\"background-color: var(--card-bg);\"\r\n  (resized)=\"onResized($event)\"\r\n>\r\n  <div class=\"header-alt\" *ngIf=\"!isHeaderVisible\">\r\n    <lib-chart-header-v2\r\n      [chartData]=\"chartData\"\r\n      [chartConfiguration]=\"chartConfiguration\"\r\n      (clickEvent)=\"handleClick($event)\"\r\n    ></lib-chart-header-v2>\r\n    <lib-chart-header-v3\r\n      [chartData]=\"chartData\"\r\n      [chartConfiguration]=\"chartConfiguration\"\r\n      (compareByFilterSelection)=\"handleCompareByFilterSelection($event)\"\r\n      (zoomInZoomOutClick)=\"handleZoominZoomoutClick($event)\"\r\n    ></lib-chart-header-v3>\r\n  </div>\r\n  <lib-chart-header-v1\r\n    [title]=\"chartData.metaData.title\"\r\n    [hasDrillDown]=\"chartData.metaData.hasDrillDown\"\r\n    [isEditEnabled]=\"chartData.metaData.isEditEnabled\"\r\n    [menuOptions]=\"chartConfiguration.headerMenuOptions\"\r\n    [isria]=\"customChartConfiguration.isRia\"\r\n    [selectedKpiTooltop]=\"chartConfiguration.selectedKpiTooltop\"\r\n    (menuOptionClickEvent)=\"handleHeaderMenuClick($event)\"\r\n    [isAlertEnabled]=\"isAlertEnabled\"\r\n    *ngIf=\"isHeaderVisible\"\r\n  ></lib-chart-header-v1>\r\n  <div\r\n    *ngIf=\"\r\n      chartData &&\r\n      chartData.metaData &&\r\n      chartConfiguration.legendJustified &&\r\n      legendVisible &&\r\n      chartConfiguration.legendAtTopRight\r\n    \"\r\n    class=\"legend-holder-right\"\r\n    [style.height]=\"chartConfiguration.footerHeight\"\r\n  >\r\n    <ul class=\"display-flex\">\r\n      <li\r\n        class=\"legends-positioning-inline\"\r\n        *ngFor=\"let item of chartData.metaData.colors | keyvalue : keepOrder\"\r\n      >\r\n        <span\r\n          class=\"lib-donut-justified-label-icon-drilldown\"\r\n          [style.background-color]=\"item.value\"\r\n        ></span\r\n        ><span>{{ item.key }}</span>\r\n      </li>\r\n    </ul>\r\n  </div>\r\n  <div\r\n    [style.height]=\"chartConfiguration.svgHeight\"\r\n    id=\"groupchartcontainer\"\r\n    #groupchartcontainer\r\n    class=\"lib-chart-svg\"\r\n  ></div>\r\n\r\n\r\n  <!-- <div\r\n    *ngIf=\"\r\n      chartData &&\r\n      chartData.metaData &&\r\n      chartConfiguration.legendJustified &&\r\n      legendVisible &&\r\n      !chartConfiguration.legendAtTopRight\r\n    \"\r\n    class=\"lib-donut-chart-footer\"\r\n    [style.height]=\"chartConfiguration.footerHeight\"\r\n  >\r\n    <ul class=\"lib-donut-justified-label-wrapper\">\r\n      <li\r\n        class=\"lib-donut-justified-label-item\"\r\n        *ngFor=\"let item of chartData.metaData.colors | keyvalue\"\r\n      >\r\n        <span\r\n          class=\"lib-donut-justified-label-icon\"\r\n          [style.background-color]=\"item.value\"\r\n        ></span\r\n        ><span>{{ item.key }}</span>\r\n      </li>\r\n    </ul>\r\n  </div> -->\r\n\r\n\r\n  <!-- <div *ngIf=\"chartConfiguration?.isDisplayBarDetailsAtBottom\">\r\n    <div\r\n      class=\"bar-values lib-display-flex lib-justify-content-center lib-align-items-center\"\r\n      *ngFor=\"\r\n        let item of chartData.metaData.colors | keyvalue : keepOrder;\r\n        let i = index\r\n      \">\r\n      <div\r\n        class=\"bar-name font-size-1\"\r\n        *ngIf=\"\r\n          chartData.data[0][item.key] &&\r\n          i <= chartConfiguration.howmanyBarDetailsToDisplay\r\n        \"\r\n      >\r\n        {{ item.key }}\r\n      </div>\r\n      <div\r\n        class=\"bar-value lib-display-flex lib-align-items-center font-size-1\"\r\n        [style.color]=\"\r\n          chartConfiguration.barVauleColor ? barVauleColor : item.value\r\n        \"\r\n        *ngIf=\"\r\n          chartData.data[0][item.key] &&\r\n          i <= chartConfiguration.howmanyBarDetailsToDisplay\r\n        \"\r\n      >\r\n        {{ chartData.data[0][item.key] }}\r\n      </div>\r\n    </div>\r\n  </div> -->\r\n</div>\r\n"]}
|
|
1299
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"horizontal-grouped-bar-with-scroll-zoom.component.js","sourceRoot":"","sources":["../../../../../projects/axidio-styleguide-library/src/lib/horizontal-grouped-bar-with-scroll-zoom/horizontal-grouped-bar-with-scroll-zoom.component.ts","../../../../../projects/axidio-styleguide-library/src/lib/horizontal-grouped-bar-with-scroll-zoom/horizontal-grouped-bar-with-scroll-zoom.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  OnInit,\r\n  ViewChild,\r\n  ElementRef,\r\n  Input,\r\n  Output,\r\n  EventEmitter,\r\n  ViewEncapsulation,\r\n} from '@angular/core';\r\nimport { ComponentUniqueId } from '../unique-id';\r\nimport ChartHelper from '../chart-helper';\r\nimport * as d3 from 'd3';\r\nimport { ResizedEvent } from 'angular-resize-event';\r\nimport HeaderConfigHelper from '../header-config';\r\n\r\n@Component({\r\n  selector: 'lib-horizontal-grouped-bar-with-scroll-zoom',\r\n  templateUrl: './horizontal-grouped-bar-with-scroll-zoom.component.html',\r\n  styleUrls: [\r\n    './horizontal-grouped-bar-with-scroll-zoom.component.less',\r\n    '../common-styles.less',\r\n  ],\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class HorizontalGroupedBarWithScrollZoomComponent\r\n  extends ComponentUniqueId\r\n  implements OnInit\r\n{\r\n  @ViewChild('groupchartcontainer', { static: true })\r\n  containerElt!: ElementRef;\r\n\r\n  @ViewChild('groupcontainer', { static: true })\r\n  groupcontainerElt!: ElementRef;\r\n\r\n  @Input() chartData: any;\r\n  @Input() customChartConfiguration: any;\r\n  @Output() clickEvent = new EventEmitter<any>();\r\n  @Output() headerMenuclickEvent = new EventEmitter<any>();\r\n  isHeaderVisible: boolean = true;\r\n  legendVisible: boolean = true;\r\n  isTransparentBackground: boolean = false;\r\n  chartConfiguration: any = {};\r\n  objectKeys = Object.keys;\r\n\r\n  defaultConfiguration: any = {\r\n    margin: { top: 20, right: 20, bottom: 20, left: 40 },\r\n    labelFormatter: ChartHelper.defaultFormatter,\r\n    svgHeight: 70,\r\n    numberOfYTicks: 5,\r\n    legendJustified: true,\r\n    yLineAxisLabelFomatter: ChartHelper.defaultFormatter,\r\n    yAxisLabelFomatter: ChartHelper.defaultFormatter,\r\n    lineGraphColor: '#F6D283',\r\n    showLineChartAxis: true,\r\n    showValues: true,\r\n    headerMenuOptions: HeaderConfigHelper.headerConfig.headerMenuOptions,\r\n    xAxisGrid: undefined,\r\n    yAxisGrid: false,\r\n    legendVisible: false,\r\n    isHeaderVisible: undefined,\r\n    isTransparentBackground: undefined,\r\n    isMultiChartGridLine: undefined,\r\n    isFullScreen: undefined,\r\n    customYscale: undefined,\r\n    textsOnBar: undefined,\r\n    isXaxisLabelHidden: undefined,\r\n    isYaxisLabelHidden: false,\r\n    isYaxisHidden: undefined,\r\n    isYaxisDashed: undefined,\r\n    textFormatter: undefined,\r\n    isNoAlternateXaxisText: undefined,\r\n    isXgridBetweenLabels: undefined,\r\n    backgroundColor: '#FFFFFF',\r\n    hideLegendOnTop: true,\r\n    isXaxisColor: '#999999',\r\n    labelOverlapMinorFix: true,\r\n    noHoverEffect: true,\r\n    noHoverDisplayData: true,\r\n    showXaxisTop: true,\r\n    displayYaxisLabels: undefined,\r\n    xLabelsOnSameLine: undefined,\r\n    textAlwaysHorizontal: undefined,\r\n    legendAtTopRight: undefined,\r\n    isDrilldownChart: true,\r\n    displayTitleOnTop: undefined,\r\n    isToggleVisible: undefined,\r\n    isTitleHidden: undefined,\r\n    isDisplayBarDetailsAtBottom: undefined,\r\n    howmanyBarDetailsToDisplay: 0,\r\n    barVauleColor: undefined,\r\n    defaultBarHeight: 2,\r\n  };\r\n\r\n  uniqueId: any = this.getUniqueId();\r\n  isZoomedOut: boolean = true;\r\n  isDD1Open: boolean = false;\r\n  isDD2Open: boolean = false;\r\n\r\n  constructor() {\r\n    super();\r\n  }\r\n\r\n  onResized(event: ResizedEvent) {\r\n    let self = this;\r\n    setTimeout(\r\n      function () {\r\n        d3.select('#' + self.uniqueId).remove();\r\n        self.initializegroupChart();\r\n      }.bind(self),\r\n      10\r\n    );\r\n  }\r\n  isZoomOutSelected(isZoomOut, event) {\r\n    this.isZoomedOut = isZoomOut;\r\n    this.onResized(event);\r\n  }\r\n  handleZoominZoomoutClick({ isZoomOut, event }) {\r\n    this.isZoomOutSelected(isZoomOut, event);\r\n  }\r\n  ngOnInit() {}\r\n  isLegendVisible() {\r\n    if (\r\n      this.chartData &&\r\n      this.chartData.metaData.colors &&\r\n      Object.keys(this.chartData.metaData.colors).length > 1\r\n    ) {\r\n      return true;\r\n    }\r\n    return false;\r\n  }\r\n  keepOrder = (a, b) => {\r\n    return a;\r\n  };\r\n\r\n  get isAlertEnabled(): boolean {\r\n    return this.chartConfiguration?.headerMenuOptions?.some(\r\n      (option) => option.id === 'editAlert'\r\n    );\r\n  }\r\n  initializegroupChart() {\r\n    var self = this;\r\n    let data = [];\r\n    let metaData: any = null;\r\n    let keyList = null;\r\n    let lineData = null;\r\n    let colorMap = {};\r\n    var formatFromBackend;\r\n    var formatForHugeNumbers;\r\n    const isMobile = window.innerWidth < 576;\r\n    const isTablet = window.innerWidth >= 576 && window.innerWidth < 992;\r\n    const isDesktop = window.innerWidth >= 992;\r\n\r\n    let isria = this.customChartConfiguration.isRia;\r\n\r\n    var x: any;\r\n\r\n    var alternate_text = false;\r\n    var short_tick_length = 4;\r\n    var long_tick_length = 16;\r\n    /**\r\n     * longer tick length needed for weekly charts\r\n     */\r\n    var short_tick_length_bg = 5;\r\n    var long_tick_length_bg = 30;\r\n    var leftAndRightSpaces = 50;\r\n    var rightSvgWidth = 60;\r\n    var tempScale;\r\n\r\n    for (var i in this.defaultConfiguration) {\r\n      this.chartConfiguration[i] = ChartHelper.getValueByConfigurationType(\r\n        i,\r\n        this.defaultConfiguration,\r\n        this.customChartConfiguration\r\n      );\r\n    }\r\n    data = this.chartData.data;\r\n    metaData = this.chartData.metaData;\r\n    lineData = this.chartData.lineData;\r\n    if (!metaData.colorAboveTarget) {\r\n      metaData['colorAboveTarget'] = metaData.colors;\r\n    }\r\n    colorMap = metaData.colors;\r\n    keyList = metaData.keyList;\r\n\r\n    var chartContainer = d3.select(this.containerElt.nativeElement);\r\n    var verticalstackedcontainer = d3.select(\r\n      this.groupcontainerElt.nativeElement\r\n    );\r\n    var margin = this.chartConfiguration.margin;\r\n    const { width, height } = this.calculateChartDimensions(\r\n      chartContainer,\r\n      verticalstackedcontainer,\r\n      margin,\r\n      self\r\n    );\r\n\r\n    if (this.chartConfiguration.isHeaderVisible != undefined)\r\n      this.isHeaderVisible = this.chartConfiguration.isHeaderVisible;\r\n    if (this.chartConfiguration.legendVisible != undefined) {\r\n      this.legendVisible = this.chartConfiguration.legendVisible;\r\n    }\r\n    if (this.chartConfiguration.isTransparentBackground != undefined) {\r\n      this.isTransparentBackground =\r\n        this.chartConfiguration.isTransparentBackground;\r\n    }\r\n    if (this.chartConfiguration.textFormatter != undefined) {\r\n      formatFromBackend = ChartHelper.dataValueFormatter(\r\n        this.chartConfiguration.textFormatter\r\n      );\r\n      formatForHugeNumbers = ChartHelper.dataValueFormatter('.2s');\r\n    }\r\n    const { outerContainer, svgYAxisLeft, svgYAxisRight, innerContainer, svg } =\r\n      this.createChartContainers(\r\n        chartContainer,\r\n        margin,\r\n        height,\r\n        rightSvgWidth,\r\n        self,\r\n        width\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    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\r\n    var xScaleFromOrigin = d3\r\n      .scaleBand()\r\n      .domain(groups)\r\n      .range([0, width - rightSvgWidth]);\r\n\r\n    this.renderXAxis(\r\n      svg,\r\n      x,\r\n      height,\r\n      subgroups,\r\n      metaData,\r\n      this.chartConfiguration,\r\n      alternate_text,\r\n      short_tick_length_bg,\r\n      long_tick_length_bg,\r\n      this\r\n    );\r\n\r\n    this.renderXAxisLabels(\r\n      svg,\r\n      data,\r\n      subgroups,\r\n      metaData,\r\n      this.chartConfiguration,\r\n      short_tick_length_bg,\r\n      long_tick_length_bg,\r\n      isMobile,\r\n      isria,\r\n      this\r\n    );\r\n\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    maxValue = this.calculateMaxValue(maxValue);\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    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    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)')\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)');\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)')\r\n            .style('stroke-width', '1px');\r\n        });\r\n    }\r\n\r\n    var xSubgroup = d3.scaleBand().domain(subgroups);\r\n    if (subgroups.length > 1 && !this.isZoomedOut) {\r\n      xSubgroup.range([0, x.bandwidth()]);\r\n    } else if (subgroups.length === 1 && !this.isZoomedOut) {\r\n      xSubgroup.range([0, 100]);\r\n    } else if (this.chartConfiguration.isMultiChartGridLine == undefined) {\r\n      xSubgroup.range([0, x.bandwidth()]);\r\n    } else {\r\n      xSubgroup.range([0, x.bandwidth()]);\r\n    }\r\n\r\n    var color = d3\r\n      .scaleOrdinal()\r\n      .domain(subgroups)\r\n      .range(Object.values(metaData.colors));\r\n    var state = svg\r\n      .append('g')\r\n      .selectAll('.state')\r\n      .data(data)\r\n      .enter()\r\n      .append('g')\r\n      .attr('transform', function (d) {\r\n        return 'translate(' + x(d.name) + ',0)';\r\n      });\r\n    state\r\n      .selectAll('rect')\r\n      .data(function (d) {\r\n        let newList: any = [];\r\n        subgroups.map(function (key) {\r\n          // if (key !== \"group\") {\r\n          let obj: any = { key: key, value: d[key], name: d.name };\r\n          newList.push(obj);\r\n          // }\r\n        });\r\n        return newList;\r\n      })\r\n      .enter()\r\n      .append('rect')\r\n      .attr('class', 'bars')\r\n      .on('click', function (d) {\r\n        if (d.key != 'Target') {\r\n          if (\r\n            !metaData.barWithoutClick ||\r\n            !metaData.barWithoutClick.length ||\r\n            (!metaData.barWithoutClick.includes(d?.name) &&\r\n              !metaData.barWithoutClick.includes(d?.key))\r\n          )\r\n            // self.handleClick(d.data.name);\r\n            self.handleClick(d);\r\n        }\r\n      })\r\n      .attr('x', function (d) {\r\n        if (self.chartConfiguration.isDrilldownChart) {\r\n          data.map((indiv: any) => {\r\n            if (indiv.name == d.name) {\r\n              let keys = Object.keys(indiv).filter((temp, i) => i != 0);\r\n              tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);\r\n              if (x.bandwidth() > 100) {\r\n                // Increase bar width a bit in zoom-in view\r\n                let reducedBarWidth = 60;\r\n                if (!self.isZoomedOut) {\r\n                  reducedBarWidth = 30;\r\n                }\r\n                if (self.chartData.data.length == 1) {\r\n                  if (Object.keys(self.chartData.data[0]).length == 2) {\r\n                    tempScale.range([\r\n                      0 + (x.bandwidth() - reducedBarWidth) / 2,\r\n                      x.bandwidth() - (x.bandwidth() - reducedBarWidth) / 2,\r\n                    ]);\r\n                  } else\r\n                    tempScale.range([\r\n                      0 + (x.bandwidth() - reducedBarWidth) / 2,\r\n                      x.bandwidth() - (x.bandwidth() - reducedBarWidth) / 2,\r\n                    ]);\r\n                } else\r\n                  tempScale.range([\r\n                    0 + (x.bandwidth() - reducedBarWidth) / 2,\r\n                    x.bandwidth() - (x.bandwidth() - reducedBarWidth) / 2,\r\n                  ]);\r\n              }\r\n            }\r\n          });\r\n          return tempScale(d.key);\r\n        }\r\n        return xSubgroup(d.key);\r\n      })\r\n      .attr('y', function (d) {\r\n        if (d.value == -1) {\r\n          return y(0);\r\n        }\r\n\r\n        if (d.value >= 0) {\r\n          const barHeight = height - y(d.value);\r\n          const minHeight = self.chartConfiguration.defaultBarHeight || 2;\r\n          return barHeight < minHeight ? y(0) - minHeight : y(d.value);\r\n        }\r\n\r\n        return y(0);\r\n      })\r\n      .attr('width', function (d) {\r\n        // For grouped bar charts in zoom-in view, set bar width to 50 for maximum thickness\r\n        if (subgroups.length > 1 && !self.isZoomedOut) {\r\n          return 50;\r\n        }\r\n        // For single-bar (non-grouped) charts in zoom-in view, set bar width to 80\r\n        if (subgroups.length === 1 && !self.isZoomedOut) {\r\n          return 80;\r\n        }\r\n        let tempScale = d3.scaleBand().domain([]).range([0, 0]);\r\n        // Default logic for other chart types\r\n        if (self.chartConfiguration.isDrilldownChart) {\r\n          data.map((indiv: any) => {\r\n            if (indiv.name == d.name) {\r\n              let keys = Object.keys(indiv).filter((temp, i) => i != 0);\r\n              tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);\r\n              if (x.bandwidth() > 100) {\r\n                // Increase bar width a bit in zoom-in view\r\n                let reducedBarWidth = 60;\r\n                if (!self.isZoomedOut) {\r\n                  reducedBarWidth = 100;\r\n                }\r\n                if (self.chartData.data.length == 1) {\r\n                  if (Object.keys(self.chartData.data[0]).length == 2) {\r\n                    tempScale.range([\r\n                      0 + (x.bandwidth() - reducedBarWidth) / 2,\r\n                      x.bandwidth() - (x.bandwidth() - reducedBarWidth) / 2,\r\n                    ]);\r\n                  } else\r\n                    tempScale.range([\r\n                      0 + (x.bandwidth() - reducedBarWidth) / 2,\r\n                      x.bandwidth() - (x.bandwidth() - reducedBarWidth) / 2,\r\n                    ]);\r\n                } else\r\n                  tempScale.range([\r\n                    0 + (x.bandwidth() - reducedBarWidth) / 2,\r\n                    x.bandwidth() - (x.bandwidth() - reducedBarWidth) / 2,\r\n                  ]);\r\n              }\r\n            }\r\n          });\r\n          return self.isZoomedOut\r\n            ? tempScale.bandwidth()\r\n            : self.chartData.data.length && self.chartData.data.length > 8\r\n            ? tempScale.bandwidth()\r\n            : tempScale.bandwidth();\r\n        }\r\n        return self.isZoomedOut\r\n          ? tempScale.bandwidth()\r\n          : self.chartData.data.length && self.chartData.data.length > 8\r\n          ? tempScale.bandwidth()\r\n          : tempScale.bandwidth();\r\n      })\r\n      .attr('height', function (d) {\r\n        if (d.value == -1) {\r\n          return height - y(0);\r\n        }\r\n\r\n        if (d.value >= 0) {\r\n          const barHeight = height - y(d.value);\r\n          const minHeight = self.chartConfiguration.defaultBarHeight || 2;\r\n          return Math.max(barHeight, minHeight);\r\n        }\r\n\r\n        return height - y(0);\r\n      })\r\n      .style('cursor', function (d) {\r\n        if (metaData.hasDrillDown && !isria) return 'pointer';\r\n        else return 'default';\r\n      })\r\n      .attr('fill', function (d) {\r\n        if (\r\n          d.value &&\r\n          self.chartData.targetLineData &&\r\n          d.value >= parseFloat(self.chartData.targetLineData.target) &&\r\n          self.chartData.metaData.colorAboveTarget\r\n        ) {\r\n          const key = d.key.toLowerCase();\r\n          const colorAboveTarget = Object.keys(\r\n            self.chartData.metaData.colorAboveTarget\r\n          ).find((k) => k.toLowerCase() === key);\r\n          if (colorAboveTarget) {\r\n            return self.chartData.metaData.colorAboveTarget[colorAboveTarget];\r\n          }\r\n        }\r\n        return self.chartData.metaData.colors[d.key];\r\n      });\r\n\r\n    /**\r\n     * display angled texts on the bars\r\n     */\r\n    if (this.chartConfiguration.textsOnBar != undefined && !this.isZoomedOut) {\r\n      state\r\n        .selectAll('text')\r\n        .data(function (d) {\r\n          let newList: any = [];\r\n          subgroups.map(function (key) {\r\n            let obj: any = { key: key, value: d[key], name: d.name };\r\n            newList.push(obj);\r\n          });\r\n          return newList;\r\n        })\r\n        .enter()\r\n        .append('text')\r\n        .attr('fill', 'var(--chart-text-color)')\r\n        .attr('x', function (d) {\r\n          return 0;\r\n        })\r\n        .attr('y', function (d) {\r\n          return 0;\r\n        })\r\n        .attr('class', 'lib-data-labels-weeklycharts')\r\n        .text(function (d) {\r\n          return d.key && d.value\r\n            ? d.key.length > 20\r\n              ? d.key.substring(0, 17) + '...'\r\n              : d.key\r\n            : '';\r\n        })\r\n        .style('fill', function (d) {\r\n          return '#000';\r\n        })\r\n        .style('font-weight', 'bold')\r\n        .style('font-size', function (d) {\r\n          if (self.isZoomedOut) {\r\n            return '9px'; // 👈 Zoomed out mode\r\n          }\r\n\r\n          if (self.chartConfiguration.isDrilldownChart) {\r\n            if (window.innerWidth > 1900) {\r\n              return '18px';\r\n            } else if (window.innerWidth < 1400) {\r\n              return '10px';\r\n            } else {\r\n              return '14px';\r\n            }\r\n          } else {\r\n            return '14px';\r\n          }\r\n        })\r\n        .attr('transform', function (d) {\r\n          data.map((indiv: any) => {\r\n            if (indiv.name == d.name) {\r\n              let keys = Object.keys(indiv).filter((temp, i) => i != 0);\r\n              var temp;\r\n              tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);\r\n              if (x.bandwidth() > 100) {\r\n                if (self.chartData.data.length == 1) {\r\n                  if (Object.keys(self.chartData.data[0]).length == 2) {\r\n                    tempScale.range([\r\n                      0 + (x.bandwidth() - 200) / 2,\r\n                      x.bandwidth() - (x.bandwidth() - 200) / 2,\r\n                    ]);\r\n                    // .padding(0.05);\r\n                  } else\r\n                    tempScale.range([\r\n                      0 + (x.bandwidth() - 300) / 2,\r\n                      x.bandwidth() - (x.bandwidth() - 300) / 2,\r\n                    ]);\r\n                  // .padding(0.05);\r\n                } else\r\n                  tempScale.range([\r\n                    0 + (x.bandwidth() - 125) / 2,\r\n                    x.bandwidth() - (x.bandwidth() - 125) / 2,\r\n                  ]);\r\n              }\r\n            }\r\n          });\r\n          /**\r\n           * if set, then all texts ll be horizontal\r\n           */\r\n          if (self.chartConfiguration.textAlwaysHorizontal) {\r\n            return (\r\n              'translate(' + xSubgroup(d.key) + ',' + (y(d.value) - 3) + ')'\r\n            );\r\n          }\r\n          /**\r\n           * rotate texts having more than one digits\r\n           */\r\n          // if (d.value > 9)\r\n          if (!isNaN(tempScale(d.key)))\r\n            return (\r\n              'translate(' +\r\n              (tempScale(d.key) + tempScale.bandwidth() * 0.55) +\r\n              ',' +\r\n              (y(0) - 10) +\r\n              ') rotate(270)'\r\n            );\r\n          return 'translate(0,0)';\r\n          // else\r\n          //   return (\r\n          //     'translate(' +\r\n          //     (tempScale(d.key) + tempScale.bandwidth() / 2) +\r\n          //     ',' +\r\n          //     y(0) +\r\n          //     ')'\r\n          //   );\r\n        })\r\n        .on('click', function (d) {\r\n          if (\r\n            !metaData.barWithoutClick ||\r\n            !metaData.barWithoutClick.length ||\r\n            (!metaData.barWithoutClick.includes(d?.name) &&\r\n              !metaData.barWithoutClick.includes(d?.key))\r\n          )\r\n            self.handleClick(d);\r\n        });\r\n      if (!isria) {\r\n        state\r\n          .selectAll('.lib-data-labels-weeklycharts')\r\n          .on('mouseout', handleMouseOut)\r\n          .on('mouseover', handleMouseOver);\r\n      }\r\n    }\r\n    if (\r\n      this.chartConfiguration.displayTitleOnTop ||\r\n      (this.chartConfiguration.textsOnBar == undefined &&\r\n        this.chartConfiguration.displayTitleOnTop == undefined)\r\n    ) {\r\n      if (!isria) {\r\n        state\r\n          .selectAll('rect')\r\n          .on('mouseout', handleMouseOut)\r\n          .on('mouseover', handleMouseOver);\r\n      }\r\n    }\r\n    function handleMouseOver(d, i) {\r\n      svg.selectAll('.lib-verticalstack-title-ontop').remove();\r\n      svg\r\n        .append('foreignObject')\r\n        .attr('x', function () {\r\n          // ...existing code for tempScale calculation...\r\n          var elementsCounter;\r\n          data.map((indiv: any) => {\r\n            if (indiv.name == d.name) {\r\n              let keys = Object.keys(indiv).filter((temp, i) => i != 0);\r\n              elementsCounter = keys.length;\r\n              tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);\r\n              if (x.bandwidth() > 100) {\r\n                if (self.chartData.data.length == 1) {\r\n                  if (Object.keys(self.chartData.data[0]).length == 2) {\r\n                    tempScale.range([\r\n                      0 + (x.bandwidth() - 200) / 2,\r\n                      x.bandwidth() - (x.bandwidth() - 200) / 2,\r\n                    ]);\r\n                  } else\r\n                    tempScale.range([\r\n                      0 + (x.bandwidth() - 300) / 2,\r\n                      x.bandwidth() - (x.bandwidth() - 300) / 2,\r\n                    ]);\r\n                } else\r\n                  tempScale.range([\r\n                    0 + (x.bandwidth() - 125) / 2,\r\n                    x.bandwidth() - (x.bandwidth() - 125) / 2,\r\n                  ]);\r\n              }\r\n            }\r\n          });\r\n          if (metaData.hasDrillDown) {\r\n            if (tempScale.bandwidth() + leftAndRightSpaces * 2 > 180) {\r\n              return (\r\n                x(d.name) + tempScale(d.key) + tempScale.bandwidth() / 2 - 90\r\n              );\r\n            }\r\n            return (\r\n              x(d.name) +\r\n              tempScale(d.key) -\r\n              (tempScale.bandwidth() + leftAndRightSpaces * 2) / 2 +\r\n              tempScale.bandwidth() / 2\r\n            );\r\n          } else return x(d.name) + tempScale(d.key) - (tempScale.bandwidth() + leftAndRightSpaces * 2) / 2 + tempScale.bandwidth() / 2;\r\n        })\r\n        .attr('class', 'lib-verticalstack-title-ontop')\r\n        .attr('y', function () {\r\n          return y(d.value) - 3 - 40 - 10;\r\n        })\r\n        .attr('dy', function () {\r\n          return d.class;\r\n        })\r\n        .attr('width', function () {\r\n          data.map((indiv: any) => {\r\n            if (indiv.name == d.name) {\r\n              let keys = Object.keys(indiv).filter((temp, i) => i != 0);\r\n              tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);\r\n              if (x.bandwidth() > 100) {\r\n                if (self.chartData.data.length == 1) {\r\n                  if (Object.keys(self.chartData.data[0]).length == 2) {\r\n                    tempScale.range([\r\n                      0 + (x.bandwidth() - 200) / 2,\r\n                      x.bandwidth() - (x.bandwidth() - 200) / 2,\r\n                    ]);\r\n                  } else\r\n                    tempScale.range([\r\n                      0 + (x.bandwidth() - 300) / 2,\r\n                      x.bandwidth() - (x.bandwidth() - 300) / 2,\r\n                    ]);\r\n                } else\r\n                  tempScale.range([\r\n                    0 + (x.bandwidth() - 125) / 2,\r\n                    x.bandwidth() - (x.bandwidth() - 125) / 2,\r\n                  ]);\r\n              }\r\n            }\r\n          });\r\n          if (metaData.hasDrillDown) {\r\n            if (tempScale.bandwidth() + leftAndRightSpaces * 2 > 180) {\r\n              return '180px';\r\n            }\r\n            return tempScale.bandwidth() + leftAndRightSpaces * 2;\r\n          } else return tempScale.bandwidth() + leftAndRightSpaces * 2;\r\n        })\r\n        .attr('height', 50)\r\n        .append('xhtml:div')\r\n        .attr('class', 'title')\r\n        .style('z-index', 99)\r\n        .html(function () {\r\n          let barLabel = d.key;\r\n          let dataType = metaData.dataType ? metaData.dataType : '';\r\n          let value = d.value;\r\n          let desiredText =\r\n            '<span class=\"title-bar-name\">' + barLabel + '</span>';\r\n          desiredText +=\r\n            '<span class=\"title-bar-value\"><span>' +\r\n            value +\r\n            '</span>' +\r\n            dataType +\r\n            '</span>';\r\n          return desiredText;\r\n        });\r\n    }\r\n    function handleMouseOut(d, i) {\r\n      svg.selectAll('.lib-verticalstack-title-ontop').remove();\r\n    }\r\n    svg\r\n      .append('g')\r\n      .attr('class', 'x2 axis2')\r\n      .attr('transform', 'translate(0,' + height + ')')\r\n      .style('color', 'var(--chart-axis-color, #000)') // Use CSS variable instead of hardcoded #000\r\n      .call(d3.axisBottom(xScaleFromOrigin).tickSize(0))\r\n      .call((g) => g.select('.domain').attr('fill', 'none'));\r\n    svg.selectAll('g.x2.axis2 g.tick text').style('display', 'none');\r\n    svg\r\n      .append('g')\r\n      .attr('class', 'lib-stacked-y-axis-text yaxis-dashed')\r\n      .attr('style', self.chartConfiguration.yAxisCustomTextStyles)\r\n      .attr('transform', 'translate(0,0)')\r\n      .call(y)\r\n      .style('display', 'none');\r\n    svgYAxisLeft\r\n      .append('g')\r\n      .append('g')\r\n      .attr('class', 'lib-yaxis-labels-texts-drilldown yaxis-dashed')\r\n      .attr('style', self.chartConfiguration.yAxisCustomTextStyles)\r\n      .attr('transform', 'translate(0,0)')\r\n      .call(\r\n        d3\r\n          .axisLeft(y)\r\n          .tickSize(0)\r\n          .ticks(self.chartConfiguration.numberOfYTicks)\r\n          .tickFormat(function (d) {\r\n            const formatted = self.chartConfiguration.yAxisLabelFomatter\r\n              ? self.chartConfiguration.yAxisLabelFomatter(d)\r\n              : d;\r\n            return formatted >= 1000 ? formatted / 1000 + 'k' : formatted;\r\n          })\r\n      )\r\n      .call((g) => {\r\n        // Style the domain line for theme support\r\n        g.select('.domain')\r\n          .style('stroke', 'var(--chart-domain-color, #000000)')\r\n          .style('stroke-width', '1px');\r\n      })\r\n      .selectAll('text')\r\n      .style('fill', 'var(--chart-text-color)');\r\n    svgYAxisRight\r\n      .append('g')\r\n      .attr('class', 'lib-yaxis-labels-texts-drilldown yaxis-dashed')\r\n      .attr('style', self.chartConfiguration.yAxisCustomTextStyles)\r\n      .attr('transform', 'translate(0,0)')\r\n      .call(y)\r\n      .style('display', 'none');\r\n    /**\r\n     * hide x axis labels\r\n     * config is there for future use\r\n     * used by weekly charts\r\n     */\r\n    if (\r\n      this.chartConfiguration.isXaxisLabelHidden != undefined &&\r\n      this.chartConfiguration.isXaxisLabelHidden\r\n    ) {\r\n      d3.selectAll('g.lib-line-x-axis-text > g > text').attr(\r\n        'class',\r\n        'lib-display-hidden'\r\n      );\r\n    }\r\n    /**\r\n     * hide y axis labels\r\n     * used by weekly charts\r\n     */\r\n    if (\r\n      this.chartConfiguration.isYaxisLabelHidden != undefined &&\r\n      this.chartConfiguration.isYaxisLabelHidden\r\n    ) {\r\n      d3.selectAll('.yaxis-dashed > g > text').attr(\r\n        'class',\r\n        'lib-display-hidden'\r\n      );\r\n    }\r\n    /**\r\n     * hide y axis labels\r\n     * config is there for future use\r\n     */\r\n    if (\r\n      this.chartConfiguration.isYaxisHidden != undefined &&\r\n      this.chartConfiguration.isYaxisHidden\r\n    ) {\r\n      d3.selectAll('.yaxis-dashed').attr('class', 'lib-display-hidden');\r\n    }\r\n    /**\r\n     * dashed y axis\r\n     * used by weekly charts\r\n     */\r\n    if (\r\n      this.chartConfiguration.isYaxisDashed != undefined &&\r\n      this.chartConfiguration.isYaxisDashed\r\n    ) {\r\n      d3.selectAll('.yaxis-dashed')\r\n        .style('stroke-dasharray', '5 5')\r\n        .style('color', 'var(--chart-axis-color, #999999)'); // Use CSS variable\r\n    }\r\n    if (lineData != null) {\r\n      if (lineData && self.chartConfiguration.showLineChartAxis) {\r\n        svgYAxisRight\r\n          .append('g')\r\n          .attr('class', 'lib-stacked-y-axis-text1')\r\n          .attr('style', self.chartConfiguration.yAxisCustomTextStyles)\r\n          .attr('transform', 'translate(' + 0 + ',0)')\r\n          .call(yLineAxis);\r\n      }\r\n    }\r\n    /**\r\n     * used to display y label\r\n     */\r\n\r\n    // if (this.isZoomedOut) {\r\n    //   svg\r\n    //     .selectAll('.lib-xaxis-labels-texts-drilldown')\r\n    //     .attr('class', 'lib-display-hidden');\r\n    // }\r\n\r\n    if (this.isZoomedOut) {\r\n      svg\r\n        .selectAll('.lib-xaxis-labels-texts-drilldown')\r\n        .each((d, i, nodes) => {\r\n          const text = d3.select(nodes[i]);\r\n          const label = text.text();\r\n          if (label.indexOf('\\n') > -1) {\r\n            const lines = label.split('\\n');\r\n            text.text(null);\r\n            lines.forEach((line, idx) => {\r\n              text\r\n                .append('tspan')\r\n                .text(line)\r\n                .attr('x', 0)\r\n                .attr('dy', idx === 0 ? '1em' : '1.1em');\r\n            });\r\n          } else {\r\n            const words = label.split(' ');\r\n            text.text(null);\r\n            words.forEach((word, index) => {\r\n              text.append('tspan').text(word);\r\n            });\r\n          }\r\n        })\r\n        .style('fill', 'var(--chart-text-color)')\r\n        .attr('transform', null);\r\n      svg\r\n        .select('.x-axis')\r\n        .attr('transform', `translate(0, ${height - margin.bottom + 10})`);\r\n    }\r\n\r\n    /**\r\n     * used to write y labels based on configuration\r\n     */\r\n    if (metaData.yLabel) {\r\n      const yPosition = isria\r\n        ? 0 - margin.left / 2 - 30\r\n        : 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\r\n        ? height + margin.top + margin.bottom\r\n        : height + margin.top + margin.bottom + 40;\r\n\r\n      svg\r\n        .append('text')\r\n        .attr('class', function () {\r\n          let baseClass = 'lib-axis-group-label font-size-1';\r\n          if (self.chartConfiguration.isDrilldownChart)\r\n            return baseClass + ' lib-xlabel-drilldowncharts';\r\n          if (self.chartConfiguration.isMultiChartGridLine != undefined)\r\n            return baseClass + ' lib-xlabel-weeklyCharts';\r\n          return baseClass + ' lib-axis-waterfall-label';\r\n        })\r\n        .attr('style', self.chartConfiguration.xAxisCustomlabelStyles)\r\n        .attr('transform', 'translate(' + width / 2 + ' ,' + xPosition + ')')\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  private calculateChartDimensions(\r\n    chartContainer: any,\r\n    verticalstackedcontainer: any,\r\n    margin: any,\r\n    self: any\r\n  ) {\r\n    let width =\r\n      parseInt(chartContainer.style('width')) - margin.left - margin.right;\r\n    const dataLength = this.chartData.data.length;\r\n\r\n    // ---- Width Logic (no change) ----\r\n    if (dataLength > 30 && this.isZoomedOut) {\r\n      width =\r\n        width > dataLength * 40\r\n          ? this.chartData.dropdownData1\r\n            ? dataLength * 60\r\n            : width\r\n          : this.chartData.dropdownData1\r\n          ? dataLength * 60\r\n          : dataLength * 40;\r\n\r\n      width = width > dataLength * 40 ? width : dataLength * 40;\r\n    }\r\n\r\n    if (\r\n      this.chartData.dropdownData2 &&\r\n      width < dataLength * 120 &&\r\n      this.isZoomedOut\r\n    ) {\r\n      width = dataLength * 120;\r\n    }\r\n\r\n    if (dataLength > 8 && !this.isZoomedOut) {\r\n      if (this.chartData.dropdownData2 && width < dataLength * 250) {\r\n        width = dataLength * 250;\r\n      } else {\r\n        width = dataLength * 160;\r\n      }\r\n    }\r\n\r\n    // ---- Height Logic (no change) ----\r\n    let height =\r\n      parseInt(verticalstackedcontainer.style('height')) *\r\n        (self.chartConfiguration.svgHeight / 100) -\r\n      margin.top -\r\n      margin.bottom;\r\n\r\n    if (\r\n      this.chartConfiguration.isFullScreen !== undefined &&\r\n      this.chartConfiguration.isFullScreen\r\n    ) {\r\n      height =\r\n        this.chartConfiguration.svgHeight !== 70\r\n          ? this.chartConfiguration.svgHeight\r\n          : parseInt(verticalstackedcontainer.style('height'));\r\n    }\r\n\r\n    if (this.chartConfiguration.isDrilldownChart && !this.isHeaderVisible) {\r\n      height =\r\n        parseInt(verticalstackedcontainer.style('height')) -\r\n        margin.top -\r\n        margin.bottom -\r\n        130;\r\n    }\r\n\r\n    if (this.chartConfiguration.isHeaderVisible) {\r\n      height =\r\n        parseInt(verticalstackedcontainer.style('height')) -\r\n        margin.top -\r\n        margin.bottom -\r\n        100;\r\n    }\r\n\r\n    return { width, height };\r\n  }\r\n  private createChartContainers(\r\n    chartContainer: any,\r\n    margin: any,\r\n    height: number,\r\n    rightSvgWidth: number,\r\n    self: any,\r\n    width: number\r\n  ) {\r\n    // Outer container\r\n    const outerContainer = chartContainer\r\n      .append('div')\r\n      .attr('id', self.uniqueId)\r\n      .attr('class', 'outer-container')\r\n      .style('width', '100%')\r\n      .style('height', height)\r\n      .style('overflow-x', 'hidden')\r\n      .style('padding-left', `${margin.left}px`)\r\n      .style('padding-right', `${rightSvgWidth}px`)\r\n      .style('margin-left', '15px');\r\n\r\n    // Left Y-Axis\r\n    const svgYAxisLeft = outerContainer\r\n      .append('svg')\r\n      .attr('width', '100')\r\n      .attr('height', height + margin.top + margin.bottom + 10)\r\n      .style('position', 'absolute')\r\n      .style('left', '0')\r\n      .style('z-index', 1)\r\n      .append('g')\r\n      .attr('transform', `translate(${margin.left + 15},${margin.top})`);\r\n\r\n    // Right Y-Axis\r\n    const svgYAxisRight = outerContainer\r\n      .append('svg')\r\n      .attr('width', rightSvgWidth)\r\n      .attr('height', height + margin.top + margin.bottom + 10)\r\n      .style('position', 'absolute')\r\n      .style('right', '12px')\r\n      .style('z-index', 1)\r\n      .append('g')\r\n      .attr('transform', `translate(0,${margin.top})`);\r\n\r\n    // Inner scrollable container\r\n    const innerContainer = outerContainer\r\n      .append('div')\r\n      .attr('class', 'inner-container')\r\n      .style('width', '100%')\r\n      .style('overflow-x', 'auto');\r\n\r\n    // Main SVG\r\n    const svg = innerContainer\r\n      .append('svg')\r\n      .attr('width', width - rightSvgWidth)\r\n      .attr('height', height + margin.top + margin.bottom + 60)\r\n      .append('g')\r\n      .attr('transform', `translate(0,${margin.top})`);\r\n\r\n    return { outerContainer, svgYAxisLeft, svgYAxisRight, innerContainer, svg };\r\n  }\r\n\r\n  private renderXAxis(\r\n    svg: any,\r\n    x: any,\r\n    height: number,\r\n    subgroups: any[],\r\n    metaData: any,\r\n    chartConfig: any,\r\n    alternate_text: boolean,\r\n    short_tick_length_bg: number,\r\n    long_tick_length_bg: number,\r\n    self: any\r\n  ) {\r\n    if (chartConfig.isMultiChartGridLine == undefined) {\r\n      // Normal dashboard charts\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: any) => g.select('.domain').remove());\r\n\r\n      svg.selectAll('g.x1.axis1 g.tick line').remove();\r\n\r\n      if (subgroups.length > 1 && !metaData.xLabel) {\r\n        svg\r\n          .selectAll('g.x1.axis1 g.tick text')\r\n          .attr('class', 'lib-xaxis-labels-texts-drilldown')\r\n          .style('fill', 'var(--chart-text-color)')\r\n          .attr('y', 32);\r\n      } else {\r\n        svg\r\n          .selectAll('g.x1.axis1 g.tick text')\r\n          .attr('class', 'lib-xaxis-labels-texts-drilldown')\r\n          .style('fill', 'var(--chart-text-color)');\r\n      }\r\n    } else {\r\n      // Weekly charts / multi-chart\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: any) => g.select('.domain').attr('fill', 'none'));\r\n\r\n      // Tick line size in alternate fashion\r\n      svg.selectAll('g.x1.axis1 g.tick line').attr('y2', function () {\r\n        if (alternate_text && chartConfig.isNoAlternateXaxisText == undefined) {\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 flag\r\n      alternate_text = false;\r\n\r\n      // X-axis labels\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 (chartConfig.isFullScreen) return short_tick_length_bg;\r\n          if (alternate_text) {\r\n            alternate_text = false;\r\n            return long_tick_length_bg;\r\n          } else {\r\n            alternate_text = true;\r\n            return short_tick_length_bg;\r\n          }\r\n        });\r\n    }\r\n  }\r\n  private renderXAxisLabels(\r\n    svg: any,\r\n    data: any[],\r\n    subgroups: any[],\r\n    metaData: any,\r\n    chartConfig: any,\r\n    short_tick_length_bg: number,\r\n    long_tick_length_bg: number,\r\n    isMobile: boolean,\r\n    isria: boolean,\r\n    self: any\r\n  ) {\r\n    if (!chartConfig.xLabelsOnSameLine) return;\r\n\r\n    const xAxisLabels = svg.selectAll('g.x1.axis1 g.tick text');\r\n\r\n    this.applyLabelStyles(\r\n      xAxisLabels,\r\n      data,\r\n      subgroups,\r\n      metaData,\r\n      chartConfig,\r\n      short_tick_length_bg,\r\n      long_tick_length_bg,\r\n      isMobile,\r\n      self\r\n    );\r\n\r\n    this.handleLabelText(\r\n      xAxisLabels,\r\n      data,\r\n      subgroups,\r\n      metaData,\r\n      chartConfig,\r\n      isMobile,\r\n      self\r\n    );\r\n\r\n    if (isria && data.length > 8) {\r\n      this.applyRiaLabelOverride(xAxisLabels);\r\n    }\r\n\r\n    if (isMobile && !self.isHeaderVisible) {\r\n      xAxisLabels.classed('mobile-xaxis-override', true);\r\n    }\r\n  }\r\n  private applyLabelStyles(\r\n    labels: any,\r\n    data: any[],\r\n    subgroups: any[],\r\n    metaData: any,\r\n    chartConfig: any,\r\n    short_tick_length_bg: number,\r\n    long_tick_length_bg: number,\r\n    isMobile: boolean,\r\n    self: any\r\n  ) {\r\n    labels\r\n      .attr('class', 'lib-xaxis-labels-texts-drilldown')\r\n      .style('font-size', self.isHeaderVisible ? '18px' : '14px')\r\n      .attr('text-anchor', 'middle')\r\n      .attr('y', (d: any) =>\r\n        this.calculateLabelY(\r\n          d,\r\n          data,\r\n          subgroups,\r\n          metaData,\r\n          chartConfig,\r\n          short_tick_length_bg,\r\n          long_tick_length_bg,\r\n          self\r\n        )\r\n      )\r\n      .attr('x', (d: any) => this.calculateLabelX(d, data, self));\r\n  }\r\n  private calculateLabelY(\r\n    d: any,\r\n    data: any[],\r\n    subgroups: any[],\r\n    metaData: any,\r\n    chartConfig: any,\r\n    short_tick_length_bg: number,\r\n    long_tick_length_bg: number,\r\n    self: any\r\n  ): number {\r\n    // Logic from your original code for y positioning\r\n    if (subgroups.length > 1 && data.length > 8 && metaData.xLabel) {\r\n      return short_tick_length_bg + 14;\r\n    }\r\n    if (subgroups.length > 1 && data.length > 8 && !metaData.xLabel) {\r\n      return chartConfig.isFullScreen\r\n        ? short_tick_length_bg + 2\r\n        : short_tick_length_bg + 10;\r\n    }\r\n    let baseY = self.isHeaderVisible\r\n      ? short_tick_length_bg + 25\r\n      : short_tick_length_bg;\r\n    return baseY;\r\n  }\r\n  private calculateLabelX(d: any, data: any[], self: any): number {\r\n    if (data.length > 8 && !self.isZoomedOut) return 1;\r\n    return 0;\r\n  }\r\n  private handleLabelText(\r\n    labels: any,\r\n    data: any[],\r\n    subgroups: any[],\r\n    metaData: any,\r\n    chartConfig: any,\r\n    isMobile: boolean,\r\n    self: any\r\n  ) {\r\n    labels.text((d: any) => {\r\n      if (isMobile && !self.isHeaderVisible) {\r\n        return d\r\n          .split(/[\\s\\-]+/)[0]\r\n          .substring(0, 3)\r\n          .toLowerCase();\r\n      }\r\n      // Split dates or weeks, ignore -1 values, etc.\r\n      // Keep all your previous text-processing logic here\r\n      return d.toLowerCase(); // fallback\r\n    });\r\n\r\n    // Example of handling sideways labels for grouped zoomed-out charts\r\n    labels.each(function (this: SVGTextElement, d: any) {\r\n      const isDateLabel = /^(\\d{2,4}[-\\/])?\\d{2,4}[-\\/]\\d{2,4}$/.test(d.trim());\r\n      const isWeekLabel = /week|wk|w\\d+/i.test(d);\r\n      if (\r\n        subgroups.length > 1 &&\r\n        self.isZoomedOut &&\r\n        data.length > 8 &&\r\n        isDateLabel &&\r\n        !isWeekLabel\r\n      ) {\r\n        d3.select(this).style('writing-mode', 'sideways-lr');\r\n      }\r\n    });\r\n  }\r\n  private applyRiaLabelOverride(labels: any) {\r\n    labels\r\n      .classed('mobile-xaxis-override', true)\r\n      .text((d: string) => d.substring(0, 3))\r\n      .style('font-size', '12px')\r\n      .attr('y', 5)\r\n      .attr('x', 5)\r\n      .style('text-anchor', 'middle');\r\n  }\r\n  private calculateMaxValue(maxValue: number): number {\r\n    if (maxValue === 0) {\r\n      if (this.chartData.targetLineData) {\r\n        return this.chartData.targetLineData.target + 20;\r\n      } else {\r\n        return 100;\r\n      }\r\n    }\r\n    return maxValue;\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}\r\n","<div\r\n  #groupcontainer\r\n  class=\"lib-chart-wrapper\"\r\n  [ngClass]=\"{ 'lib-no-background': isTransparentBackground }\"\r\n  style=\"background-color: var(--card-bg);\"\r\n  (resized)=\"onResized($event)\"\r\n>\r\n  <div class=\"header-alt\" *ngIf=\"!isHeaderVisible\">\r\n    <lib-chart-header-v2\r\n      [chartData]=\"chartData\"\r\n      [chartConfiguration]=\"chartConfiguration\"\r\n      (clickEvent)=\"handleClick($event)\"\r\n    ></lib-chart-header-v2>\r\n    <lib-chart-header-v3\r\n      [chartData]=\"chartData\"\r\n      [chartConfiguration]=\"chartConfiguration\"\r\n      (compareByFilterSelection)=\"handleCompareByFilterSelection($event)\"\r\n      (zoomInZoomOutClick)=\"handleZoominZoomoutClick($event)\"\r\n    ></lib-chart-header-v3>\r\n  </div>\r\n  <lib-chart-header-v1\r\n    [title]=\"chartData.metaData.title\"\r\n    [hasDrillDown]=\"chartData.metaData.hasDrillDown\"\r\n    [isEditEnabled]=\"chartData.metaData.isEditEnabled\"\r\n    [menuOptions]=\"chartConfiguration.headerMenuOptions\"\r\n    [isria]=\"customChartConfiguration.isRia\"\r\n    [selectedKpiTooltop]=\"chartConfiguration.selectedKpiTooltop\"\r\n    (menuOptionClickEvent)=\"handleHeaderMenuClick($event)\"\r\n    [isAlertEnabled]=\"isAlertEnabled\"\r\n    *ngIf=\"isHeaderVisible\"\r\n  ></lib-chart-header-v1>\r\n  <div\r\n    *ngIf=\"\r\n      chartData &&\r\n      chartData.metaData &&\r\n      chartConfiguration.legendJustified &&\r\n      legendVisible &&\r\n      chartConfiguration.legendAtTopRight\r\n    \"\r\n    class=\"legend-holder-right\"\r\n    [style.height]=\"chartConfiguration.footerHeight\"\r\n  >\r\n    <ul class=\"display-flex\">\r\n      <li\r\n        class=\"legends-positioning-inline\"\r\n        *ngFor=\"let item of chartData.metaData.colors | keyvalue : keepOrder\"\r\n      >\r\n        <span\r\n          class=\"lib-donut-justified-label-icon-drilldown\"\r\n          [style.background-color]=\"item.value\"\r\n        ></span\r\n        ><span>{{ item.key }}</span>\r\n      </li>\r\n    </ul>\r\n  </div>\r\n  <div\r\n    [style.height]=\"chartConfiguration.svgHeight\"\r\n    id=\"groupchartcontainer\"\r\n    #groupchartcontainer\r\n    class=\"lib-chart-svg\"\r\n  ></div>\r\n\r\n\r\n  <!-- <div\r\n    *ngIf=\"\r\n      chartData &&\r\n      chartData.metaData &&\r\n      chartConfiguration.legendJustified &&\r\n      legendVisible &&\r\n      !chartConfiguration.legendAtTopRight\r\n    \"\r\n    class=\"lib-donut-chart-footer\"\r\n    [style.height]=\"chartConfiguration.footerHeight\"\r\n  >\r\n    <ul class=\"lib-donut-justified-label-wrapper\">\r\n      <li\r\n        class=\"lib-donut-justified-label-item\"\r\n        *ngFor=\"let item of chartData.metaData.colors | keyvalue\"\r\n      >\r\n        <span\r\n          class=\"lib-donut-justified-label-icon\"\r\n          [style.background-color]=\"item.value\"\r\n        ></span\r\n        ><span>{{ item.key }}</span>\r\n      </li>\r\n    </ul>\r\n  </div> -->\r\n\r\n\r\n  <!-- <div *ngIf=\"chartConfiguration?.isDisplayBarDetailsAtBottom\">\r\n    <div\r\n      class=\"bar-values lib-display-flex lib-justify-content-center lib-align-items-center\"\r\n      *ngFor=\"\r\n        let item of chartData.metaData.colors | keyvalue : keepOrder;\r\n        let i = index\r\n      \">\r\n      <div\r\n        class=\"bar-name font-size-1\"\r\n        *ngIf=\"\r\n          chartData.data[0][item.key] &&\r\n          i <= chartConfiguration.howmanyBarDetailsToDisplay\r\n        \"\r\n      >\r\n        {{ item.key }}\r\n      </div>\r\n      <div\r\n        class=\"bar-value lib-display-flex lib-align-items-center font-size-1\"\r\n        [style.color]=\"\r\n          chartConfiguration.barVauleColor ? barVauleColor : item.value\r\n        \"\r\n        *ngIf=\"\r\n          chartData.data[0][item.key] &&\r\n          i <= chartConfiguration.howmanyBarDetailsToDisplay\r\n        \"\r\n      >\r\n        {{ chartData.data[0][item.key] }}\r\n      </div>\r\n    </div>\r\n  </div> -->\r\n</div>\r\n"]}
|