axidio-styleguide-library1-v2 0.2.25 → 0.2.27

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.
@@ -114,6 +114,9 @@ export class GroupChartComponent extends ComponentUniqueId {
114
114
  var alternate_text = false;
115
115
  var short_tick_length = 4;
116
116
  var long_tick_length = 16;
117
+ /**
118
+ * longer tick length needed for weekly charts
119
+ */
117
120
  var short_tick_length_bg = 5;
118
121
  var long_tick_length_bg = 30;
119
122
  var leftAndRightSpaces = 50;
@@ -125,6 +128,9 @@ export class GroupChartComponent extends ComponentUniqueId {
125
128
  data = this.chartData.data;
126
129
  metaData = this.chartData.metaData;
127
130
  lineData = this.chartData.lineData;
131
+ // if (lineData || this.chartData.targetLineData) {
132
+ // rightSvgWidth = 60;
133
+ // }
128
134
  if (!metaData.colorAboveTarget) {
129
135
  metaData['colorAboveTarget'] = metaData.colors;
130
136
  }
@@ -161,10 +167,16 @@ export class GroupChartComponent extends ComponentUniqueId {
161
167
  else
162
168
  width = this.chartData.data.length * 160;
163
169
  }
170
+ // if (this.chartData.data.length > 8) {
171
+ // width = this.chartData.data.length * 140;
172
+ // }
164
173
  var height = parseInt(verticalstackedcontainer.style('height')) *
165
174
  (self.chartConfiguration.svgHeight / 100) -
166
175
  margin.top -
167
176
  margin.bottom;
177
+ /**
178
+ * entire height used in weekly charts as x axis needed to be displayed at the bottom of the chart
179
+ */
168
180
  if (this.chartConfiguration.isFullScreen != undefined &&
169
181
  this.chartConfiguration.isFullScreen) {
170
182
  height =
@@ -186,15 +198,30 @@ export class GroupChartComponent extends ComponentUniqueId {
186
198
  margin.bottom -
187
199
  100;
188
200
  }
201
+ /**
202
+ * for hiding header
203
+ * used by weekly charts
204
+ */
189
205
  if (this.chartConfiguration.isHeaderVisible != undefined)
190
206
  this.isHeaderVisible = this.chartConfiguration.isHeaderVisible;
207
+ /**
208
+ * for hiding legends
209
+ * used by weekly charts
210
+ */
191
211
  if (this.chartConfiguration.legendVisible != undefined) {
192
212
  this.legendVisible = this.chartConfiguration.legendVisible;
193
213
  }
214
+ /**
215
+ * for removing background color so that it can take parents color
216
+ *
217
+ */
194
218
  if (this.chartConfiguration.isTransparentBackground != undefined) {
195
219
  this.isTransparentBackground =
196
220
  this.chartConfiguration.isTransparentBackground;
197
221
  }
222
+ /**
223
+ * format data values based on configuration received
224
+ */
198
225
  if (this.chartConfiguration.textFormatter != undefined) {
199
226
  formatFromBackend = ChartHelper.dataValueFormatter(this.chartConfiguration.textFormatter);
200
227
  formatForHugeNumbers = ChartHelper.dataValueFormatter('.2s');
@@ -207,6 +234,7 @@ export class GroupChartComponent extends ComponentUniqueId {
207
234
  .style('height', height)
208
235
  .style('overflow-x', 'hidden')
209
236
  .style('padding-left', `${margin.left}px`)
237
+ // .call(ChartHelper.responsivefy)
210
238
  .style('padding-right', `${rightSvgWidth}px`)
211
239
  .style('margin-left', '15px');
212
240
  var svgYAxisLeft = outerContainer
@@ -234,8 +262,10 @@ export class GroupChartComponent extends ComponentUniqueId {
234
262
  .style('overflow-x', 'auto');
235
263
  var svg = innerContainer
236
264
  .append('svg')
265
+ // .attr('id', self.uniqueId)
237
266
  .attr('width', width - rightSvgWidth)
238
267
  .attr('height', height + margin.top + margin.bottom + 30)
268
+ // .call(ChartHelper.responsivefy)
239
269
  .append('g')
240
270
  .attr('transform', 'translate(' + 0 + ',' + margin.top + ')');
241
271
  var subgroups = keyList;
@@ -244,6 +274,9 @@ export class GroupChartComponent extends ComponentUniqueId {
244
274
  return d.name;
245
275
  })
246
276
  .keys();
277
+ /**
278
+ * x axis range made similar to line chart or vertical stack so that all the charts will get aligned with each other.
279
+ */
247
280
  if (this.chartConfiguration.isMultiChartGridLine != undefined) {
248
281
  x = d3
249
282
  .scaleBand()
@@ -261,11 +294,27 @@ export class GroupChartComponent extends ComponentUniqueId {
261
294
  .range([leftAndRightSpaces, width - rightSvgWidth - leftAndRightSpaces])
262
295
  .padding([0.3]);
263
296
  }
297
+ // x.bandwidth(96);
264
298
  var xScaleFromOrigin = d3
265
299
  .scaleBand()
266
300
  .domain(groups)
267
301
  .range([0, width - rightSvgWidth]);
302
+ // .padding([0.2]);
303
+ /**
304
+ * draw second x axis on top
305
+ */
306
+ // if (self.chartConfiguration.showXaxisTop) {
307
+ // svg
308
+ // .append('g')
309
+ // .attr('class', 'lib-line-axis-text lib-line-x-axis-text x-axis')
310
+ // .attr('style', self.chartConfiguration.xAxisCustomTextStyles)
311
+ // .call(d3.axisBottom(x).tickSize(0));
312
+ // }
313
+ // d3.svg.axis().scale(x).orient('bottom').ticks(1).innerTickSize(-height);
268
314
  if (this.chartConfiguration.isMultiChartGridLine == undefined) {
315
+ /**
316
+ * normal ticks for all dashboard charts
317
+ */
269
318
  svg
270
319
  .append('g')
271
320
  .attr('class', 'x1 axis1')
@@ -278,7 +327,7 @@ export class GroupChartComponent extends ComponentUniqueId {
278
327
  .selectAll('g.x1.axis1 g.tick text')
279
328
  .attr('class', 'lib-xaxis-labels-texts-drilldown')
280
329
  .style('fill', 'var(--chart-text-color)')
281
- .attr('y', 32);
330
+ .attr('y', 32); // Increase distance from bars (default is ~9)
282
331
  }
283
332
  else {
284
333
  svg
@@ -286,14 +335,32 @@ export class GroupChartComponent extends ComponentUniqueId {
286
335
  .attr('class', 'lib-xaxis-labels-texts-drilldown')
287
336
  .style('fill', 'var(--chart-text-color)');
288
337
  }
338
+ // .attr('y', function () {
339
+ // if (alternate_text) {
340
+ // alternate_text = false;
341
+ // return long_tick_length + 1;
342
+ // } else {
343
+ // alternate_text = true;
344
+ // return short_tick_length + 1;
345
+ // }
346
+ // });
289
347
  }
290
348
  else {
349
+ /**
350
+ * bigger ticks for weekly charts and more space from x axis to labels
351
+ */
352
+ /**
353
+ * draw x axis
354
+ */
291
355
  svg
292
356
  .append('g')
293
357
  .attr('class', 'x1 axis1')
294
358
  .attr('transform', 'translate(0,' + height + ')')
295
359
  .call(d3.axisBottom(x).tickSize(0))
296
360
  .call((g) => g.select('.domain').attr('fill', 'none'));
361
+ /**
362
+ * tick line size in alternate fashion
363
+ */
297
364
  svg.selectAll('g.x1.axis1 g.tick line').attr('y2', function () {
298
365
  if (alternate_text &&
299
366
  self.chartConfiguration.isNoAlternateXaxisText == undefined) {
@@ -305,7 +372,14 @@ export class GroupChartComponent extends ComponentUniqueId {
305
372
  return short_tick_length_bg - 4;
306
373
  }
307
374
  });
375
+ /**
376
+ * reset the flag so that values can be shown in same alternate fashion
377
+ */
308
378
  alternate_text = false;
379
+ /**
380
+ * print x-axis label texts
381
+ * used by weekly charts
382
+ */
309
383
  svg
310
384
  .selectAll('g.x1.axis1 g.tick text')
311
385
  .attr('class', 'lib-xaxis-labels-texts-weeklycharts')
@@ -354,6 +428,7 @@ export class GroupChartComponent extends ComponentUniqueId {
354
428
  return '';
355
429
  });
356
430
  }
431
+ /**y scale for left y axis */
357
432
  var y = d3.scaleLinear().rangeRound([height, 0]);
358
433
  var maxValue = d3.max(data, (d) => d3.max(keyList, (key) => +d[key]));
359
434
  if (maxValue == 0) {
@@ -364,7 +439,27 @@ export class GroupChartComponent extends ComponentUniqueId {
364
439
  maxValue = 100;
365
440
  }
366
441
  }
442
+ if (self.chartConfiguration.yAxisGrid) {
443
+ // svg
444
+ // .append('g')
445
+ // .attr('class', 'grid')
446
+ // .call(
447
+ // d3
448
+ // .axisLeft(y)
449
+ // .ticks(self.chartConfiguration.numberOfYTicks)
450
+ // .tickSize(-width)
451
+ // .tickFormat('')
452
+ // )
453
+ // // .style('stroke-dasharray', '5 5')
454
+ // .style('color', '#B9B9B9')
455
+ // .style('opacity', '0.5')
456
+ // .call((g) => g.select('.domain').remove());
457
+ }
367
458
  if (this.chartConfiguration.customYscale) {
459
+ /**
460
+ * increase y-scale so that values wont cross or exceed out of range
461
+ * used in weekly charts
462
+ */
368
463
  maxValue = maxValue * this.chartConfiguration.customYscale;
369
464
  }
370
465
  if (this.chartData.targetLineData &&
@@ -402,6 +497,10 @@ export class GroupChartComponent extends ComponentUniqueId {
402
497
  .tickSize(0)
403
498
  .tickFormat(self.chartConfiguration.yLineAxisLabelFomatter);
404
499
  }
500
+ /**
501
+ * show x-axis grid between labels
502
+ * used by weekly charts
503
+ */
405
504
  if (self.chartConfiguration.isXgridBetweenLabels) {
406
505
  svg
407
506
  .append('g')
@@ -413,6 +512,9 @@ export class GroupChartComponent extends ComponentUniqueId {
413
512
  .call((g) => g.select('.domain').remove());
414
513
  }
415
514
  if (this.chartConfiguration.yAxisGrid) {
515
+ /**
516
+ * draw y axis
517
+ */
416
518
  svg
417
519
  .append('g')
418
520
  .call(d3
@@ -436,12 +538,22 @@ export class GroupChartComponent extends ComponentUniqueId {
436
538
  xSubgroup.range([0, x.bandwidth()]);
437
539
  }
438
540
  else {
541
+ /**
542
+ * used to make grouped bars with lesser width as we are not using padding for width
543
+ * used by weekly charts
544
+ */
439
545
  xSubgroup.range([0, x.bandwidth()]);
440
546
  }
547
+ // if (this.chartConfiguration.isDrilldownChart) {
548
+ // }
441
549
  var color = d3
442
550
  .scaleOrdinal()
443
551
  .domain(subgroups)
444
552
  .range(Object.values(metaData.colors));
553
+ // var colorAboveTarget = d3
554
+ // .scaleOrdinal()
555
+ // .domain(subgroups)
556
+ // .range(Object.values(metaData.colorAboveTarget));
445
557
  var state = svg
446
558
  .append('g')
447
559
  .selectAll('.state')
@@ -456,8 +568,10 @@ export class GroupChartComponent extends ComponentUniqueId {
456
568
  .data(function (d) {
457
569
  let newList = [];
458
570
  subgroups.map(function (key) {
571
+ // if (key !== "group") {
459
572
  let obj = { key: key, value: d[key], name: d.name };
460
573
  newList.push(obj);
574
+ // }
461
575
  });
462
576
  return newList;
463
577
  })
@@ -470,6 +584,7 @@ export class GroupChartComponent extends ComponentUniqueId {
470
584
  !metaData.barWithoutClick.length ||
471
585
  (!metaData.barWithoutClick.includes(d?.name) &&
472
586
  !metaData.barWithoutClick.includes(d?.key)))
587
+ // self.handleClick(d.data.name);
473
588
  self.handleClick(d);
474
589
  }
475
590
  })
@@ -486,12 +601,14 @@ export class GroupChartComponent extends ComponentUniqueId {
486
601
  0 + (x.bandwidth() - 200) / 2,
487
602
  x.bandwidth() - (x.bandwidth() - 200) / 2,
488
603
  ]);
604
+ // .padding(0.05);
489
605
  }
490
606
  else
491
607
  tempScale.range([
492
608
  0 + (x.bandwidth() - 300) / 2,
493
609
  x.bandwidth() - (x.bandwidth() - 300) / 2,
494
610
  ]);
611
+ // .padding(0.05);
495
612
  }
496
613
  else
497
614
  tempScale.range([
@@ -510,6 +627,7 @@ export class GroupChartComponent extends ComponentUniqueId {
510
627
  })
511
628
  .attr('width', function (d) {
512
629
  if (self.chartConfiguration.isDrilldownChart) {
630
+ // var tempScale;
513
631
  data.map((indiv) => {
514
632
  if (indiv.name == d.name) {
515
633
  let keys = Object.keys(indiv).filter((temp, i) => i != 0);
@@ -522,12 +640,14 @@ export class GroupChartComponent extends ComponentUniqueId {
522
640
  0 + (x.bandwidth() - 200) / 2,
523
641
  x.bandwidth() - (x.bandwidth() - 200) / 2,
524
642
  ]);
643
+ // .padding(0.05);
525
644
  }
526
645
  else
527
646
  tempScale.range([
528
647
  0 + (x.bandwidth() - 300) / 2,
529
648
  x.bandwidth() - (x.bandwidth() - 300) / 2,
530
649
  ]);
650
+ // .padding(0.05);
531
651
  }
532
652
  else
533
653
  tempScale.range([
@@ -549,6 +669,7 @@ export class GroupChartComponent extends ComponentUniqueId {
549
669
  return height - y(d.value);
550
670
  return height - y(0);
551
671
  })
672
+ // .style('cursor', 'pointer')
552
673
  .style('cursor', function (d) {
553
674
  if (metaData.hasDrillDown && !isria)
554
675
  return 'pointer';
@@ -563,6 +684,9 @@ export class GroupChartComponent extends ComponentUniqueId {
563
684
  return self.chartData.metaData.colorAboveTarget[d.key];
564
685
  return self.chartData.metaData.colors[d.key];
565
686
  });
687
+ /**
688
+ * display angled texts on the bars
689
+ */
566
690
  if (this.chartConfiguration.textsOnBar != undefined && !this.isZoomedOut) {
567
691
  state
568
692
  .selectAll('text')
@@ -623,12 +747,14 @@ export class GroupChartComponent extends ComponentUniqueId {
623
747
  0 + (x.bandwidth() - 200) / 2,
624
748
  x.bandwidth() - (x.bandwidth() - 200) / 2,
625
749
  ]);
750
+ // .padding(0.05);
626
751
  }
627
752
  else
628
753
  tempScale.range([
629
754
  0 + (x.bandwidth() - 300) / 2,
630
755
  x.bandwidth() - (x.bandwidth() - 300) / 2,
631
756
  ]);
757
+ // .padding(0.05);
632
758
  }
633
759
  else
634
760
  tempScale.range([
@@ -638,9 +764,16 @@ export class GroupChartComponent extends ComponentUniqueId {
638
764
  }
639
765
  }
640
766
  });
767
+ /**
768
+ * if set, then all texts ll be horizontal
769
+ */
641
770
  if (self.chartConfiguration.textAlwaysHorizontal) {
642
771
  return ('translate(' + xSubgroup(d.key) + ',' + (y(d.value) - 3) + ')');
643
772
  }
773
+ /**
774
+ * rotate texts having more than one digits
775
+ */
776
+ // if (d.value > 9)
644
777
  if (!isNaN(tempScale(d.key)))
645
778
  return ('translate(' +
646
779
  (tempScale(d.key) + tempScale.bandwidth() * 0.55) +
@@ -648,6 +781,14 @@ export class GroupChartComponent extends ComponentUniqueId {
648
781
  (y(0) - 10) +
649
782
  ') rotate(270)');
650
783
  return 'translate(0,0)';
784
+ // else
785
+ // return (
786
+ // 'translate(' +
787
+ // (tempScale(d.key) + tempScale.bandwidth() / 2) +
788
+ // ',' +
789
+ // y(0) +
790
+ // ')'
791
+ // );
651
792
  })
652
793
  .on('click', function (d) {
653
794
  if (!metaData.barWithoutClick ||
@@ -676,6 +817,7 @@ export class GroupChartComponent extends ComponentUniqueId {
676
817
  svg
677
818
  .append('foreignObject')
678
819
  .attr('x', function () {
820
+ // var tempScale;
679
821
  var elementsCounter;
680
822
  data.map((indiv) => {
681
823
  if (indiv.name == d.name) {
@@ -689,12 +831,14 @@ export class GroupChartComponent extends ComponentUniqueId {
689
831
  0 + (x.bandwidth() - 200) / 2,
690
832
  x.bandwidth() - (x.bandwidth() - 200) / 2,
691
833
  ]);
834
+ // .padding(0.05);
692
835
  }
693
836
  else
694
837
  tempScale.range([
695
838
  0 + (x.bandwidth() - 300) / 2,
696
839
  x.bandwidth() - (x.bandwidth() - 300) / 2,
697
840
  ]);
841
+ // .padding(0.05);
698
842
  }
699
843
  else
700
844
  tempScale.range([
@@ -724,6 +868,7 @@ export class GroupChartComponent extends ComponentUniqueId {
724
868
  return d.class;
725
869
  })
726
870
  .attr('width', function () {
871
+ // var tempScale;
727
872
  data.map((indiv) => {
728
873
  if (indiv.name == d.name) {
729
874
  let keys = Object.keys(indiv).filter((temp, i) => i != 0);
@@ -735,12 +880,14 @@ export class GroupChartComponent extends ComponentUniqueId {
735
880
  0 + (x.bandwidth() - 200) / 2,
736
881
  x.bandwidth() - (x.bandwidth() - 200) / 2,
737
882
  ]);
883
+ // .padding(0.05);
738
884
  }
739
885
  else
740
886
  tempScale.range([
741
887
  0 + (x.bandwidth() - 300) / 2,
742
888
  x.bandwidth() - (x.bandwidth() - 300) / 2,
743
889
  ]);
890
+ // .padding(0.05);
744
891
  }
745
892
  else
746
893
  tempScale.range([
@@ -827,18 +974,35 @@ export class GroupChartComponent extends ComponentUniqueId {
827
974
  .attr('transform', 'translate(0,0)')
828
975
  .call(y)
829
976
  .style('display', 'none');
977
+ /**
978
+ * hide x axis labels
979
+ * config is there for future use
980
+ * used by weekly charts
981
+ */
830
982
  if (this.chartConfiguration.isXaxisLabelHidden != undefined &&
831
983
  this.chartConfiguration.isXaxisLabelHidden) {
832
984
  d3.selectAll('g.lib-line-x-axis-text > g > text').attr('class', 'lib-display-hidden');
833
985
  }
986
+ /**
987
+ * hide y axis labels
988
+ * used by weekly charts
989
+ */
834
990
  if (this.chartConfiguration.isYaxisLabelHidden != undefined &&
835
991
  this.chartConfiguration.isYaxisLabelHidden) {
836
992
  d3.selectAll('.yaxis-dashed > g > text').attr('class', 'lib-display-hidden');
837
993
  }
994
+ /**
995
+ * hide y axis labels
996
+ * config is there for future use
997
+ */
838
998
  if (this.chartConfiguration.isYaxisHidden != undefined &&
839
999
  this.chartConfiguration.isYaxisHidden) {
840
1000
  d3.selectAll('.yaxis-dashed').attr('class', 'lib-display-hidden');
841
1001
  }
1002
+ /**
1003
+ * dashed y axis
1004
+ * used by weekly charts
1005
+ */
842
1006
  if (this.chartConfiguration.isYaxisDashed != undefined &&
843
1007
  this.chartConfiguration.isYaxisDashed) {
844
1008
  d3.selectAll('.yaxis-dashed')
@@ -855,11 +1019,17 @@ export class GroupChartComponent extends ComponentUniqueId {
855
1019
  .call(yLineAxis);
856
1020
  }
857
1021
  }
1022
+ /**
1023
+ * used to display y label
1024
+ */
858
1025
  if (this.isZoomedOut) {
859
1026
  svg
860
1027
  .selectAll('.lib-xaxis-labels-texts-drilldown')
861
1028
  .attr('class', 'lib-display-hidden');
862
1029
  }
1030
+ /**
1031
+ * used to write y labels based on configuration
1032
+ */
863
1033
  if (metaData.yLabel) {
864
1034
  svgYAxisLeft
865
1035
  .append('text')
@@ -878,6 +1048,9 @@ export class GroupChartComponent extends ComponentUniqueId {
878
1048
  .text(metaData.yLabel);
879
1049
  }
880
1050
  else {
1051
+ /**
1052
+ * used by weekly charts
1053
+ */
881
1054
  svg
882
1055
  .selectAll('.lib-axis-group-label')
883
1056
  .attr('class', 'lib-ylabel-weeklyCharts')
@@ -918,6 +1091,13 @@ export class GroupChartComponent extends ComponentUniqueId {
918
1091
  .attr('y2', yZero)
919
1092
  .style('stroke-dasharray', '5 5')
920
1093
  .style('stroke', this.chartData.targetLineData.color);
1094
+ // svgYAxisRight
1095
+ // .append('line')
1096
+ // .attr('x1', 0)
1097
+ // .attr('x2', rightSvgWidth)
1098
+ // .attr('y1', yZero)
1099
+ // .attr('y2', yZero)
1100
+ // .style('stroke', this.chartData.targetLineData.color);
921
1101
  svgYAxisRight
922
1102
  .append('foreignObject')
923
1103
  .attr('transform', 'translate(' + 0 + ',' + (yZero - 30) + ')')
@@ -945,6 +1125,13 @@ export class GroupChartComponent extends ComponentUniqueId {
945
1125
  });
946
1126
  }
947
1127
  if (this.chartConfiguration.isDrilldownChart) {
1128
+ /**
1129
+ * used by drilldown charts
1130
+ */
1131
+ // svg
1132
+ // .selectAll('.lib-axis-group-label')
1133
+ // .attr('class', 'lib-ylabel-drilldowncharts')
1134
+ // .text(metaData.yLabel.toLowerCase());
948
1135
  svg.selectAll('g.x1.axis1 g.tick line').style('display', 'none');
949
1136
  }
950
1137
  if (metaData.lineyLabel) {
@@ -1059,4 +1246,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
1059
1246
  }], headerMenuclickEvent: [{
1060
1247
  type: Output
1061
1248
  }] } });
1062
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"group-chart.component.js","sourceRoot":"","sources":["../../../../../projects/axidio-styleguide-library/src/lib/group-chart/group-chart.component.ts","../../../../../projects/axidio-styleguide-library/src/lib/group-chart/group-chart.component.html"],"names":[],"mappings":"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","sourcesContent":["  import {\r\n    Component,\r\n    OnInit,\r\n    ViewChild,\r\n    ElementRef,\r\n    Input,\r\n    Output,\r\n    EventEmitter,\r\n    ViewEncapsulation,\r\n  } from '@angular/core';\r\n  import { ComponentUniqueId } from '../unique-id';\r\n  import ChartHelper from '../chart-helper';\r\n  import * as d3 from 'd3';\r\n  import { ResizedEvent } from 'angular-resize-event';\r\n  import HeaderConfigHelper from '../header-config';\r\n\r\n  @Component({\r\n    selector: 'lib-group-chart',\r\n    templateUrl: './group-chart.component.html',\r\n    styleUrls: ['./group-chart.component.less', '../common-styles.less'],\r\n    encapsulation: ViewEncapsulation.None,\r\n  })\r\n  export class GroupChartComponent extends ComponentUniqueId implements OnInit {\r\n      @ViewChild('groupchartcontainer', { static: true })\r\n      containerElt!: ElementRef;\r\n    \r\n      @ViewChild('groupcontainer', { static: true })\r\n      groupcontainerElt!: ElementRef;\r\n    \r\n      @Input() chartData: any;\r\n      @Input() customChartConfiguration: any;\r\n      @Output() clickEvent = new EventEmitter<any>();\r\n      @Output() headerMenuclickEvent = new EventEmitter<any>();\r\n      isHeaderVisible: boolean = true;\r\n      legendVisible: boolean = true;\r\n      isTransparentBackground: boolean = false;\r\n      chartConfiguration: any = {};\r\n      objectKeys = Object.keys;\r\n    \r\n      defaultConfiguration: any = {\r\n        margin: { top: 20, right: 20, bottom: 20, left: 40 },\r\n        labelFormatter: ChartHelper.defaultFormatter,\r\n        svgHeight: 70,\r\n        numberOfYTicks: 5,\r\n        legendJustified: true,\r\n        yLineAxisLabelFomatter: ChartHelper.defaultFormatter,\r\n        yAxisLabelFomatter: ChartHelper.defaultFormatter,\r\n        lineGraphColor: '#F6D283',\r\n        showLineChartAxis: true,\r\n        showValues: true,\r\n        headerMenuOptions: HeaderConfigHelper.headerConfig.headerMenuOptions,\r\n        xAxisGrid: undefined,\r\n        yAxisGrid: false,\r\n        legendVisible: true,\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: undefined,\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      };\r\n    \r\n      uniqueId: any = this.getUniqueId();\r\n      isZoomedOut: boolean = false;\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(option => option.id === 'editAlert');\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\r\n   let isria = this.customChartConfiguration.isRia\r\n\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    \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('transform', 'translate(' + (margin.left + 15) + ',' + margin.top + ')');\r\n    \r\n        var svgYAxisRight = outerContainer\r\n          .append('svg')\r\n          .attr('width', rightSvgWidth)\r\n          .attr('height', height + margin.top + margin.bottom + 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 + 30)\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 (alternate_text) {\r\n                alternate_text = false;\r\n                return long_tick_length_bg;\r\n              } else {\r\n                alternate_text = true;\r\n                return short_tick_length_bg;\r\n              }\r\n            });\r\n        }\r\n        if (self.chartConfiguration.xLabelsOnSameLine) {\r\n          svg\r\n            .selectAll('g.x1.axis1 g.tick text')\r\n            .attr('class', 'lib-xaxis-labels-texts-drilldown')\r\n            .attr('y', short_tick_length_bg)\r\n            .text(function (d) {\r\n              var isValueToBeIgnored = false;\r\n              data.map((indiv: any) => {\r\n                if (\r\n                  indiv.name.toLowerCase() == d.trim().toLowerCase() &&\r\n                  indiv[metaData.keyList[0]] == -1\r\n                ) {\r\n                  isValueToBeIgnored = true;\r\n                }\r\n              });\r\n              if (isValueToBeIgnored) {\r\n                return '';\r\n              }\r\n              if (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          svg\r\n            .selectAll('g.x1.axis1 g.tick')\r\n            .append('text')\r\n            .attr('class', 'lib-xaxis-labels-texts-drilldown')\r\n            .attr('y', long_tick_length_bg)\r\n            .attr('fill', 'currentColor')\r\n            .text(function (d) {\r\n              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        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) => g.select('.domain').remove());\r\n        } else {\r\n          svg\r\n            .append('g')\r\n            .call(d3.axisLeft(y).ticks(self.chartConfiguration.numberOfYTicks))\r\n            .style('color', '#B9B9B9')\r\n            .style('opacity', '0.5')\r\n            .call((g) => g.select('.domain').remove());\r\n        }\r\n    \r\n        var xSubgroup = d3.scaleBand().domain(subgroups);\r\n        if (this.chartConfiguration.isMultiChartGridLine == undefined) {\r\n          xSubgroup.range([0, x.bandwidth()]);\r\n        } else {\r\n          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                    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              return tempScale(d.key);\r\n            }\r\n            return xSubgroup(d.key);\r\n          })\r\n          .attr('y', function (d) {\r\n            return y(d.value);\r\n          })\r\n          .attr('width', 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                  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              return tempScale.bandwidth();\r\n            }\r\n            return xSubgroup.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            if (d.value) return height - y(d.value);\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 >= parseInt(self.chartData.targetLineData.target) &&\r\n              self.chartData.metaData.colorAboveTarget\r\n            )\r\n              return self.chartData.metaData.colorAboveTarget[d.key];\r\n            return self.chartData.metaData.colors[d.key];\r\n          });\r\n        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('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.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.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;\r\n            })\r\n            .attr('dy', function () {\r\n              return d.class;\r\n            })\r\n            .attr('width', function () {\r\n    \r\n              data.map((indiv: any) => {\r\n                if (indiv.name == d.name) {\r\n                  let keys = Object.keys(indiv).filter((temp, i) => i != 0);\r\n                  tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);\r\n                  if (x.bandwidth() > 100) {\r\n                    if (self.chartData.data.length == 1) {\r\n                      if (Object.keys(self.chartData.data[0]).length == 2) {\r\n                        tempScale.range([\r\n                          0 + (x.bandwidth() - 200) / 2,\r\n                          x.bandwidth() - (x.bandwidth() - 200) / 2,\r\n                        ]);\r\n                      } else\r\n                        tempScale.range([\r\n                          0 + (x.bandwidth() - 300) / 2,\r\n                          x.bandwidth() - (x.bandwidth() - 300) / 2,\r\n                        ]);\r\n                    } else\r\n                      tempScale.range([\r\n                        0 + (x.bandwidth() - 125) / 2,\r\n                        x.bandwidth() - (x.bandwidth() - 125) / 2,\r\n                      ]);\r\n                  }\r\n                }\r\n              });\r\n              if (metaData.hasDrillDown) {\r\n                if (tempScale.bandwidth() + leftAndRightSpaces * 2 > 180) {\r\n                  return '180px';\r\n                }\r\n                return tempScale.bandwidth() + leftAndRightSpaces * 2;\r\n              } else return tempScale.bandwidth() + leftAndRightSpaces * 2;\r\n            })\r\n            .attr('height', 40)\r\n            .append('xhtml:div')\r\n            .attr('class', 'title')\r\n            .style('z-index', 99)\r\n            .html(function () {\r\n              let dataType = metaData.dataType ? metaData.dataType : '';\r\n              if (!self.isZoomedOut) {\r\n                let desiredText =\r\n                  '<span class=\"title-bar-name\">' + d.name + '</span>';\r\n                desiredText +=\r\n                  '<span class=\"title-bar-value\"><span>' +\r\n                  d.value +\r\n                  '</span>' +\r\n                  dataType +\r\n                  '</span>';\r\n                return desiredText;\r\n              } else {\r\n                let tempKey =\r\n                  d.name.length <= 8 ? d.name : d.name.substring(0, 5) + '...';\r\n                let desiredText =\r\n                  '<span class=\"title-bar-name\">' +\r\n                  tempKey +\r\n                  ':' +\r\n                  d.value +\r\n                  dataType +\r\n                  '</span>';\r\n                desiredText +=\r\n                  '<span class=\"title-bar-value\">' + d.name + '</span>';\r\n                return desiredText;\r\n              }\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', '#000')\r\n    \r\n          .call(d3.axisBottom(xScaleFromOrigin).tickSize(0))\r\n          .call((g) => g.select('.domain').attr('fill', 'none'));\r\n        svg.selectAll('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(self.chartConfiguration.yAxisLabelFomatter)\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', '#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        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        if (metaData.yLabel) {\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', 0 - margin.left / 2 - 30)\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          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 (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      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 + ' ,' + (height + margin.top + 20) + ')'\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 (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        if (metaData.lineyLabel) {\r\n          svgYAxisRight\r\n            .append('text')\r\n            .attr('class', 'lib-axis-group-label lib-line-axis')\r\n            .attr('style', self.chartConfiguration.yAxisCustomlabelStyles)\r\n            .attr('transform', 'translate(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', 'pointer')\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('color', self.chartConfiguration.lineGraphColor)\r\n              .attr('style', 'font-size: ' + '.85em')\r\n              .attr('x', function (d, i) {\r\n                return x(d.name) + x.bandwidth() / 2;\r\n              })\r\n              .attr('y', function (d) {\r\n                return lineYscale(d.value);\r\n              })\r\n              .attr('dy', '-1em')\r\n              .text(function (d) {\r\n                return self.chartConfiguration.labelFormatter(d.value);\r\n              });\r\n          }\r\n        }\r\n      }\r\n    \r\n      handleClick(d: any) {\r\n        if (this.chartData.metaData.hasDrillDown || d?.toggleFrom)\r\n          this.clickEvent.emit(d);\r\n      }\r\n      handleHeaderMenuClick(id) {\r\n        this.headerMenuclickEvent.emit(id);\r\n      }\r\n      handleDD1Click(event) {\r\n        this.isDD1Open = true;\r\n        this.isDD2Open = false;\r\n      }\r\n      handleDD2Click(event) {\r\n        this.isDD2Open = true;\r\n        this.isDD1Open = false;\r\n      }\r\n      handleCompareByFilterSelection(event) {\r\n        this.clickEvent.emit(event);\r\n      }  \r\n  }","<div\r\n  #groupcontainer\r\n  class=\"lib-chart-wrapper\"\r\n  [ngClass]=\"{ 'lib-no-background': isTransparentBackground }\"\r\n  style=\"background-color: var(--card-bg);\"\r\n  (resized)=\"onResized($event)\"\r\n>\r\n\r\n<div class=\"header-alt\" *ngIf=\"!isHeaderVisible\">\r\n  <lib-chart-header-v2\r\n    [chartData]=\"chartData\"\r\n    [chartConfiguration]=\"chartConfiguration\"\r\n    (clickEvent)=\"handleClick($event)\"\r\n  ></lib-chart-header-v2>\r\n  <lib-chart-header-v3\r\n    [chartData]=\"chartData\"\r\n    [chartConfiguration]=\"chartConfiguration\"\r\n    (compareByFilterSelection)=\"handleCompareByFilterSelection($event)\"\r\n    (zoomInZoomOutClick)=\"handleZoominZoomoutClick($event)\"\r\n  ></lib-chart-header-v3>\r\n</div>\r\n\r\n  <lib-chart-header-v1\r\n  [title]=\"chartData.metaData.title\"\r\n  [hasDrillDown]=\"chartData.metaData.hasDrillDown\"\r\n  [isEditEnabled]=\"chartData.metaData.isEditEnabled\"\r\n  [menuOptions]=\"chartConfiguration.headerMenuOptions\"\r\n  [isria]=\"customChartConfiguration.isRia\"\r\n  [selectedKpiTooltop]=\"chartConfiguration.selectedKpiTooltop\"\r\n  (menuOptionClickEvent)=\"handleHeaderMenuClick($event)\"\r\n  [isAlertEnabled]=\"isAlertEnabled\"\r\n  *ngIf=\"isHeaderVisible\"\r\n></lib-chart-header-v1>\r\n\r\n  <div\r\n    [style.height]=\"chartConfiguration.svgHeight\"\r\n    id=\"groupchartcontainer\"\r\n    #groupchartcontainer\r\n    class=\"lib-chart-svg\"\r\n  ></div>\r\n</div>\r\n"]}
1249
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"group-chart.component.js","sourceRoot":"","sources":["../../../../../projects/axidio-styleguide-library/src/lib/group-chart/group-chart.component.ts","../../../../../projects/axidio-styleguide-library/src/lib/group-chart/group-chart.component.html"],"names":[],"mappings":"AAAE,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;;;;;;;AAQlD,MAAM,OAAO,mBAAoB,SAAQ,iBAAiB;IAsEtD;QACE,KAAK,EAAE,CAAC;QA9DA,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,IAAI;YACnB,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,SAAS;YAC3B,iBAAiB,EAAE,SAAS;YAC5B,eAAe,EAAE,SAAS;YAC1B,aAAa,EAAE,SAAS;YACxB,2BAA2B,EAAE,SAAS;YACtC,0BAA0B,EAAE,CAAC;YAC7B,aAAa,EAAE,SAAS;SACzB,CAAC;QAEF,aAAQ,GAAQ,IAAI,CAAC,WAAW,EAAE,CAAC;QACnC,gBAAW,GAAY,KAAK,CAAC;QAC7B,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;IAKC,IAAI,cAAc;QACxB,OAAO,IAAI,CAAC,kBAAkB,EAAE,iBAAiB,EAAE,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE,KAAK,WAAW,CAAC,CAAC;IAC/F,CAAC;IACK,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;QAE9B,IAAI,KAAK,GAAG,IAAI,CAAC,wBAAwB,CAAC,KAAK,CAAA;QAG1C,IAAI,CAAM,CAAC;QAEX,IAAI,cAAc,GAAG,KAAK,CAAC;QAC3B,IAAI,iBAAiB,GAAG,CAAC,CAAC;QAC1B,IAAI,gBAAgB,GAAG,EAAE,CAAC;QAC1B;;WAEG;QACH,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;QAEnC,mDAAmD;QACnD,wBAAwB;QACxB,IAAI;QACJ,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;QACD,wCAAwC;QACxC,8CAA8C;QAC9C,IAAI;QAEJ,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;QAEhB;;WAEG;QACH,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;QACC,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;QACH;;;WAGG;QACH,IAAI,IAAI,CAAC,kBAAkB,CAAC,eAAe,IAAI,SAAS;YACtD,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,kBAAkB,CAAC,eAAe,CAAC;QACjE;;;WAGG;QACH,IAAI,IAAI,CAAC,kBAAkB,CAAC,aAAa,IAAI,SAAS,EAAE,CAAC;YACvD,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,kBAAkB,CAAC,aAAa,CAAC;QAC7D,CAAC;QAED;;;WAGG;QACH,IAAI,IAAI,CAAC,kBAAkB,CAAC,uBAAuB,IAAI,SAAS,EAAE,CAAC;YACjE,IAAI,CAAC,uBAAuB;gBAC1B,IAAI,CAAC,kBAAkB,CAAC,uBAAuB,CAAC;QACpD,CAAC;QACD;;WAEG;QACH,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;YAC1C,kCAAkC;aAEjC,KAAK,CAAC,eAAe,EAAE,GAAG,aAAa,IAAI,CAAC;aAC5C,KAAK,CAAC,aAAa,EAAC,MAAM,CAAC,CAAC;QAC/B,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,CAAC,WAAW,EAAE,YAAY,GAAG,CAAC,MAAM,CAAC,IAAI,GAAG,EAAE,CAAC,GAAG,GAAG,GAAG,MAAM,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC;QAEjF,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;YACd,6BAA6B;aAC5B,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;YACzD,kCAAkC;aACjC,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;QAEV;;WAEG;QACH,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,mBAAmB;QACnB,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,mBAAmB;QACnB;;WAEG;QACH,8CAA8C;QAC9C,QAAQ;QACR,mBAAmB;QACnB,uEAAuE;QACvE,oEAAoE;QACpE,2CAA2C;QAC3C,IAAI;QACJ,2EAA2E;QAC3E,IAAI,IAAI,CAAC,kBAAkB,CAAC,oBAAoB,IAAI,SAAS,EAAE,CAAC;YAC9D;;eAEG;YACH,GAAG;iBACF,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;YAEzC,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,CAAC,8CAA8C;YAClE,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;YACP,2BAA2B;YAC3B,0BAA0B;YAC1B,8BAA8B;YAC9B,mCAAmC;YACnC,aAAa;YACb,6BAA6B;YAC7B,oCAAoC;YACpC,MAAM;YACN,MAAM;QACR,CAAC;aAAM,CAAC;YACN;;eAEG;YACH;;eAEG;YACH,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;;eAEG;YACH,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;;eAEG;YACH,cAAc,GAAG,KAAK,CAAC;YACvB;;;eAGG;YACH,GAAG;iBACA,SAAS,CAAC,wBAAwB,CAAC;iBACnC,IAAI,CAAC,OAAO,EAAE,qCAAqC,CAAC;iBACpD,IAAI,CAAC,GAAG,EAAE;gBACT,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,GAAG;iBACA,SAAS,CAAC,wBAAwB,CAAC;iBACnC,IAAI,CAAC,OAAO,EAAE,kCAAkC,CAAC;iBACjD,IAAI,CAAC,GAAG,EAAE,oBAAoB,CAAC;iBAC/B,IAAI,CAAC,UAAU,CAAC;gBACf,IAAI,kBAAkB,GAAG,KAAK,CAAC;gBAC/B,IAAI,CAAC,GAAG,CAAC,CAAC,KAAU,EAAE,EAAE;oBACtB,IACE,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,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;YACL,GAAG;iBACA,SAAS,CAAC,mBAAmB,CAAC;iBAC9B,MAAM,CAAC,MAAM,CAAC;iBACd,IAAI,CAAC,OAAO,EAAE,kCAAkC,CAAC;iBACjD,IAAI,CAAC,GAAG,EAAE,mBAAmB,CAAC;iBAC9B,IAAI,CAAC,MAAM,EAAE,cAAc,CAAC;iBAC5B,IAAI,CAAC,UAAU,CAAC;gBACf,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,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,WAAW,EAAE,CAAC;gBACpE,CAAC;gBACD,OAAO,EAAE,CAAC;YACZ,CAAC,CAAC,CAAC;QACP,CAAC;QACD,6BAA6B;QAC7B,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,SAAS,EAAE,CAAC;YACtC,MAAM;YACN,iBAAiB;YACjB,2BAA2B;YAC3B,WAAW;YACX,SAAS;YACT,qBAAqB;YACrB,uDAAuD;YACvD,0BAA0B;YAC1B,wBAAwB;YACxB,MAAM;YACN,yCAAyC;YACzC,+BAA+B;YAC/B,6BAA6B;YAC7B,gDAAgD;QAClD,CAAC;QACD,IAAI,IAAI,CAAC,kBAAkB,CAAC,YAAY,EAAE,CAAC;YACzC;;;eAGG;YACH,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;;;WAGG;QACH,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;;eAEG;YACH,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,CAAC,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC;QAC/C,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,SAAS,CAAC;iBACzB,KAAK,CAAC,SAAS,EAAE,KAAK,CAAC;iBACvB,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC;QAC/C,CAAC;QAED,IAAI,SAAS,GAAG,EAAE,CAAC,SAAS,EAAE,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;QACjD,IAAI,IAAI,CAAC,kBAAkB,CAAC,oBAAoB,IAAI,SAAS,EAAE,CAAC;YAC9D,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC;QACtC,CAAC;aAAM,CAAC;YACN;;;eAGG;YACH,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC;QACtC,CAAC;QACD,kDAAkD;QAElD,IAAI;QACJ,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,4BAA4B;QAC5B,oBAAoB;QACpB,uBAAuB;QACvB,sDAAsD;QACtD,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,yBAAyB;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;gBAClB,IAAI;YACN,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,iCAAiC;oBACjC,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,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;oCACH,kBAAkB;gCACpB,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;gCACL,kBAAkB;4BACpB,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,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,OAAO,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;QACpB,CAAC,CAAC;aACD,IAAI,CAAC,OAAO,EAAE,UAAU,CAAC;YACxB,IAAI,IAAI,CAAC,kBAAkB,CAAC,gBAAgB,EAAE,CAAC;gBAC7C,iBAAiB;gBAEjB,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;oCACH,kBAAkB;gCACpB,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;gCACL,kBAAkB;4BACpB,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,OAAO,SAAS,CAAC,SAAS,EAAE,CAAC;YAC/B,CAAC;YACD,OAAO,SAAS,CAAC,SAAS,EAAE,CAAC;QAC/B,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;YACD,IAAI,CAAC,CAAC,KAAK;gBAAE,OAAO,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;YACxC,OAAO,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QACvB,CAAC,CAAC;YACF,8BAA8B;aAC7B,KAAK,CAAC,QAAQ,EAAE,UAAU,CAAC;YAC1B,IAAI,QAAQ,CAAC,YAAY,IAAI,CAAC,KAAK;gBAAE,OAAO,SAAS,CAAC;;gBACjD,OAAO,SAAS,CAAC;QACxB,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,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC,MAAM,CAAC;gBACzD,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,gBAAgB;gBAExC,OAAO,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,gBAAgB,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;YACzD,OAAO,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QAC/C,CAAC,CAAC,CAAC;QAEL;;WAEG;QACH,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,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,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;oCACH,kBAAkB;gCACpB,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;gCACL,kBAAkB;4BACpB,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;;mBAEG;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;;mBAEG;gBACH,mBAAmB;gBACnB,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;gBACxB,OAAO;gBACP,aAAa;gBACb,qBAAqB;gBACrB,uDAAuD;gBACvD,YAAY;gBACZ,aAAa;gBACb,UAAU;gBACV,OAAO;YACT,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;YACH,IAAI,CAAC,KAAK,EAAE,CAAC;gBACX,KAAK,CAAC,SAAS,CAAC,+BAA+B,CAAC;qBAC7C,EAAE,CAAC,UAAU,EAAE,cAAc,CAAC;qBAC9B,EAAE,CAAC,WAAW,EAAE,eAAe,CAAC,CAAC;YACtC,CAAC;QACL,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;gBACD,KAAK;qBAC1B,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,iBAAiB;gBACjB,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;oCACH,kBAAkB;gCACpB,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;gCACL,kBAAkB;4BACpB,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,CAAC;YAC7B,CAAC,CAAC;iBACD,IAAI,CAAC,IAAI,EAAE;gBACV,OAAO,CAAC,CAAC,KAAK,CAAC;YACjB,CAAC,CAAC;iBACD,IAAI,CAAC,OAAO,EAAE;gBACb,iBAAiB;gBAEjB,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;oCACH,kBAAkB;gCACpB,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;gCACL,kBAAkB;4BACpB,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,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC;gBAC1D,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC;oBACtB,IAAI,WAAW,GACb,+BAA+B,GAAG,CAAC,CAAC,IAAI,GAAG,SAAS,CAAC;oBACvD,WAAW;wBACT,sCAAsC;4BACtC,CAAC,CAAC,KAAK;4BACP,SAAS;4BACT,QAAQ;4BACR,SAAS,CAAC;oBACZ,OAAO,WAAW,CAAC;gBACrB,CAAC;qBAAM,CAAC;oBACN,IAAI,OAAO,GACT,CAAC,CAAC,IAAI,CAAC,MAAM,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,KAAK,CAAC;oBAC/D,IAAI,WAAW,GACb,+BAA+B;wBAC/B,OAAO;wBACP,GAAG;wBACH,CAAC,CAAC,KAAK;wBACP,QAAQ;wBACR,SAAS,CAAC;oBACZ,WAAW;wBACT,gCAAgC,GAAG,CAAC,CAAC,IAAI,GAAG,SAAS,CAAC;oBACxD,OAAO,WAAW,CAAC;gBACrB,CAAC;YACH,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,MAAM,CAAC;aAEtB,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,IAAI,CAAC,kBAAkB,CAAC,kBAAkB,CAAC,CAC1D;aACA,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;;;;WAIG;QACH,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;;;WAGG;QACH,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;;;WAGG;QACH,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;;;WAGG;QACH,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,SAAS,CAAC,CAAC;QAC/B,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;QACD;;WAEG;QACH,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;YACrB,GAAG;iBACA,SAAS,CAAC,mCAAmC,CAAC;iBAC9C,IAAI,CAAC,OAAO,EAAE,oBAAoB,CAAC,CAAC;QACzC,CAAC;QAED;;WAEG;QACH,IAAI,QAAQ,CAAC,MAAM,EAAE,CAAC;YACpB,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,CAAC,GAAG,MAAM,CAAC,IAAI,GAAG,CAAC,GAAG,EAAE,CAAC;iBACnC,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;YAC3C,IAAI,IAAI,CAAC,kBAAkB,CAAC,oBAAoB,IAAI,SAAS,EAAE,CAAC;gBAC9D,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;;mBAEG;gBACH,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;QAEO,IAAI,QAAQ,CAAC,MAAM,EAAE,CAAC;YAChC,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;YAC9D,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,CAAC,MAAM,GAAG,MAAM,CAAC,GAAG,GAAG,EAAE,CAAC,GAAG,GAAG,CACnE;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;QACG,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,gBAAgB;YAChB,oBAAoB;YACpB,mBAAmB;YACnB,+BAA+B;YAC/B,uBAAuB;YACvB,uBAAuB;YACvB,2DAA2D;YAC3D,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;;eAEG;YACH,MAAM;YACN,wCAAwC;YACxC,iDAAiD;YACjD,0CAA0C;YAC1C,GAAG,CAAC,SAAS,CAAC,wBAAwB,CAAC,CAAC,KAAK,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;QACnE,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,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,SAAS,CAAC;iBAC1B,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,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;+GAtyCQ,mBAAmB;mGAAnB,mBAAmB,ofCtBlC,07CAyCA;;4FDnBe,mBAAmB;kBAN/B,SAAS;+BACE,iBAAiB,iBAGZ,iBAAiB,CAAC,IAAI;wDAInC,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\n  import { ComponentUniqueId } from '../unique-id';\r\n  import ChartHelper from '../chart-helper';\r\n  import * as d3 from 'd3';\r\n  import { ResizedEvent } from 'angular-resize-event';\r\n  import HeaderConfigHelper from '../header-config';\r\n\r\n  @Component({\r\n    selector: 'lib-group-chart',\r\n    templateUrl: './group-chart.component.html',\r\n    styleUrls: ['./group-chart.component.less', '../common-styles.less'],\r\n    encapsulation: ViewEncapsulation.None,\r\n  })\r\n  export class GroupChartComponent extends ComponentUniqueId implements OnInit {\r\n      @ViewChild('groupchartcontainer', { static: true })\r\n      containerElt!: ElementRef;\r\n    \r\n      @ViewChild('groupcontainer', { static: true })\r\n      groupcontainerElt!: ElementRef;\r\n    \r\n      @Input() chartData: any;\r\n      @Input() customChartConfiguration: any;\r\n      @Output() clickEvent = new EventEmitter<any>();\r\n      @Output() headerMenuclickEvent = new EventEmitter<any>();\r\n      isHeaderVisible: boolean = true;\r\n      legendVisible: boolean = true;\r\n      isTransparentBackground: boolean = false;\r\n      chartConfiguration: any = {};\r\n      objectKeys = Object.keys;\r\n    \r\n      defaultConfiguration: any = {\r\n        margin: { top: 20, right: 20, bottom: 20, left: 40 },\r\n        labelFormatter: ChartHelper.defaultFormatter,\r\n        svgHeight: 70,\r\n        numberOfYTicks: 5,\r\n        legendJustified: true,\r\n        yLineAxisLabelFomatter: ChartHelper.defaultFormatter,\r\n        yAxisLabelFomatter: ChartHelper.defaultFormatter,\r\n        lineGraphColor: '#F6D283',\r\n        showLineChartAxis: true,\r\n        showValues: true,\r\n        headerMenuOptions: HeaderConfigHelper.headerConfig.headerMenuOptions,\r\n        xAxisGrid: undefined,\r\n        yAxisGrid: false,\r\n        legendVisible: true,\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: undefined,\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      };\r\n    \r\n      uniqueId: any = this.getUniqueId();\r\n      isZoomedOut: boolean = false;\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(option => option.id === 'editAlert');\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\r\n   let isria = this.customChartConfiguration.isRia\r\n\r\n    \r\n        var x: any;\r\n    \r\n        var alternate_text = false;\r\n        var short_tick_length = 4;\r\n        var long_tick_length = 16;\r\n        /**\r\n         * longer tick length needed for weekly charts\r\n         */\r\n        var short_tick_length_bg = 5;\r\n        var long_tick_length_bg = 30;\r\n        var leftAndRightSpaces = 50;\r\n        var rightSvgWidth = 60;\r\n        var tempScale;\r\n    \r\n        for (var i in this.defaultConfiguration) {\r\n          this.chartConfiguration[i] = ChartHelper.getValueByConfigurationType(\r\n            i,\r\n            this.defaultConfiguration,\r\n            this.customChartConfiguration\r\n          );\r\n        }\r\n    \r\n        data = this.chartData.data;\r\n        metaData = this.chartData.metaData;\r\n        lineData = this.chartData.lineData;\r\n    \r\n        // if (lineData || this.chartData.targetLineData) {\r\n        //   rightSvgWidth = 60;\r\n        // }\r\n        if (!metaData.colorAboveTarget) {\r\n          metaData['colorAboveTarget'] = metaData.colors;\r\n        }\r\n        colorMap = metaData.colors;\r\n        keyList = metaData.keyList;\r\n    \r\n        var chartContainer = d3.select(this.containerElt.nativeElement);\r\n        var verticalstackedcontainer = d3.select(\r\n          this.groupcontainerElt.nativeElement\r\n        );\r\n        var margin = this.chartConfiguration.margin;\r\n        var width =\r\n          parseInt(chartContainer.style('width')) - margin.left - margin.right;\r\n        if (this.chartData.data.length > 30 && this.isZoomedOut) {\r\n          width =\r\n            width > this.chartData.data.length * 40\r\n              ? this.chartData.dropdownData1\r\n                ? this.chartData.data.length * 60\r\n                : width\r\n              : this.chartData.dropdownData1\r\n              ? this.chartData.data.length * 60\r\n              : this.chartData.data.length * 40;\r\n    \r\n          width =\r\n            width > this.chartData.data.length * 40\r\n              ? width\r\n              : this.chartData.data.length * 40;\r\n        }\r\n        if (\r\n          this.chartData.dropdownData2 &&\r\n          width < this.chartData.data.length * 120 &&\r\n          this.isZoomedOut\r\n        ) {\r\n          width = this.chartData.data.length * 120;\r\n        }\r\n        if (this.chartData.data.length > 8 && !this.isZoomedOut) {\r\n          if (\r\n            this.chartData.dropdownData2 &&\r\n            width < this.chartData.data.length * 250\r\n          ) {\r\n            width = this.chartData.data.length * 250;\r\n          } else width = this.chartData.data.length * 160;\r\n        }\r\n        // if (this.chartData.data.length > 8) {\r\n        //   width = this.chartData.data.length * 140;\r\n        // }\r\n    \r\n        var height =\r\n          parseInt(verticalstackedcontainer.style('height')) *\r\n            (self.chartConfiguration.svgHeight / 100) -\r\n          margin.top -\r\n          margin.bottom;\r\n    \r\n        /**\r\n         * entire height used in weekly charts as x axis needed to be displayed at the bottom of the chart\r\n         */\r\n        if (\r\n          this.chartConfiguration.isFullScreen != undefined &&\r\n          this.chartConfiguration.isFullScreen\r\n        ) {\r\n          height =\r\n            this.chartConfiguration.svgHeight != 70\r\n              ? this.chartConfiguration.svgHeight\r\n              : parseInt(verticalstackedcontainer.style('height'));\r\n        }\r\n          if (this.chartConfiguration.isDrilldownChart && !this.isHeaderVisible) {\r\n            height =\r\n              parseInt(verticalstackedcontainer.style('height')) -\r\n              margin.top -\r\n              margin.bottom -\r\n              130;\r\n          }\r\n\r\n          if (this.chartConfiguration.isHeaderVisible) {\r\n            height =\r\n              parseInt(verticalstackedcontainer.style('height')) -\r\n              margin.top -\r\n              margin.bottom -\r\n              100;\r\n          }\r\n        /**\r\n         * for hiding header\r\n         * used by weekly charts\r\n         */\r\n        if (this.chartConfiguration.isHeaderVisible != undefined)\r\n          this.isHeaderVisible = this.chartConfiguration.isHeaderVisible;\r\n        /**\r\n         * for hiding legends\r\n         * used by weekly charts\r\n         */\r\n        if (this.chartConfiguration.legendVisible != undefined) {\r\n          this.legendVisible = this.chartConfiguration.legendVisible;\r\n        }\r\n    \r\n        /**\r\n         * for removing background color so that it can take parents color\r\n         *\r\n         */\r\n        if (this.chartConfiguration.isTransparentBackground != undefined) {\r\n          this.isTransparentBackground =\r\n            this.chartConfiguration.isTransparentBackground;\r\n        }\r\n        /**\r\n         * format data values based on configuration received\r\n         */\r\n        if (this.chartConfiguration.textFormatter != undefined) {\r\n          formatFromBackend = ChartHelper.dataValueFormatter(\r\n            this.chartConfiguration.textFormatter\r\n          );\r\n          formatForHugeNumbers = ChartHelper.dataValueFormatter('.2s');\r\n        }\r\n        var outerContainer = chartContainer\r\n          .append('div')\r\n          .attr('id', self.uniqueId)\r\n          .attr('class', 'outer-container')\r\n          .style('width', '100%')\r\n          .style('height', height)\r\n    \r\n          .style('overflow-x', 'hidden')\r\n          .style('padding-left', `${margin.left}px`)\r\n          // .call(ChartHelper.responsivefy)\r\n    \r\n          .style('padding-right', `${rightSvgWidth}px`)\r\n          .style('margin-left','15px');\r\n        var svgYAxisLeft = outerContainer\r\n          .append('svg')\r\n          .attr('width', '100')\r\n          .attr('height', height + margin.top + margin.bottom + 10)\r\n          .style('position', 'absolute')\r\n          .style('left', '0')\r\n          .style('z-index', 1)\r\n          .append('g')\r\n          .attr('transform', 'translate(' + (margin.left + 15) + ',' + margin.top + ')');\r\n    \r\n        var svgYAxisRight = outerContainer\r\n          .append('svg')\r\n          .attr('width', rightSvgWidth)\r\n          .attr('height', height + margin.top + margin.bottom + 10)\r\n          .style('position', 'absolute')\r\n          .style('right', '12px')\r\n          .style('z-index', 1)\r\n          .append('g')\r\n          .attr('transform', 'translate(' + 0 + ',' + margin.top + ')');\r\n    \r\n        var innerContainer = outerContainer\r\n          .append('div')\r\n          .attr('class', 'inner-container')\r\n          .style('width', '100%')\r\n          .style('overflow-x', 'auto');\r\n    \r\n        var svg = innerContainer\r\n          .append('svg')\r\n          // .attr('id', self.uniqueId)\r\n          .attr('width', width - rightSvgWidth)\r\n          .attr('height', height + margin.top + margin.bottom + 30)\r\n          // .call(ChartHelper.responsivefy)\r\n          .append('g')\r\n          .attr('transform', 'translate(' + 0 + ',' + margin.top + ')');\r\n    \r\n        var subgroups: any = keyList;\r\n    \r\n        var groups = d3\r\n          .map(data, function (d) {\r\n            return d.name;\r\n          })\r\n          .keys();\r\n    \r\n        /**\r\n         * x axis range made similar to line chart or vertical stack so that all the charts will get aligned with each other.\r\n         */\r\n        if (this.chartConfiguration.isMultiChartGridLine != undefined) {\r\n          x = d3\r\n            .scaleBand()\r\n            .rangeRound([width, 0])\r\n            .align(0.5)\r\n            .padding([0.5])\r\n            .domain(\r\n              data.map(function (d: any) {\r\n                return d.name.toLowerCase();\r\n              })\r\n            );\r\n        } else {\r\n          x = d3\r\n            .scaleBand()\r\n            .domain(groups)\r\n            .range([leftAndRightSpaces, width - rightSvgWidth - leftAndRightSpaces])\r\n            .padding([0.3]);\r\n        }\r\n        // x.bandwidth(96);\r\n        var xScaleFromOrigin = d3\r\n          .scaleBand()\r\n          .domain(groups)\r\n          .range([0, width - rightSvgWidth]);\r\n        // .padding([0.2]);\r\n        /**\r\n         * draw second x axis on top\r\n         */\r\n        // if (self.chartConfiguration.showXaxisTop) {\r\n        //   svg\r\n        //     .append('g')\r\n        //     .attr('class', 'lib-line-axis-text lib-line-x-axis-text x-axis')\r\n        //     .attr('style', self.chartConfiguration.xAxisCustomTextStyles)\r\n        //     .call(d3.axisBottom(x).tickSize(0));\r\n        // }\r\n        // d3.svg.axis().scale(x).orient('bottom').ticks(1).innerTickSize(-height);\r\n        if (this.chartConfiguration.isMultiChartGridLine == undefined) {\r\n          /**\r\n           * normal ticks for all dashboard charts\r\n           */\r\n          svg\r\n          .append('g')\r\n          .attr('class', 'x1 axis1')\r\n          .attr('transform', 'translate(0,' + height + ')')\r\n          .call(d3.axisBottom(x))\r\n          .call((g) => g.select('.domain').remove());\r\n        \r\n        svg.selectAll('g.x1.axis1 g.tick line').remove();\r\n\r\n                if (subgroups.length > 1 && !metaData.xLabel) {\r\n                  svg\r\n                    .selectAll('g.x1.axis1 g.tick text')\r\n                    .attr('class', 'lib-xaxis-labels-texts-drilldown')\r\n                    .style('fill', 'var(--chart-text-color)')\r\n                    .attr('y', 32); // Increase distance from bars (default is ~9)\r\n                } else {\r\n                  svg\r\n                    .selectAll('g.x1.axis1 g.tick text')\r\n                    .attr('class', 'lib-xaxis-labels-texts-drilldown')\r\n                    .style('fill', 'var(--chart-text-color)');\r\n                }\r\n          // .attr('y', function () {\r\n          //   if (alternate_text) {\r\n          //     alternate_text = false;\r\n          //     return long_tick_length + 1;\r\n          //   } else {\r\n          //     alternate_text = true;\r\n          //     return short_tick_length + 1;\r\n          //   }\r\n          // });\r\n        } else {\r\n          /**\r\n           * bigger ticks for weekly charts and more space from x axis to labels\r\n           */\r\n          /**\r\n           * draw x axis\r\n           */\r\n          svg\r\n            .append('g')\r\n            .attr('class', 'x1 axis1')\r\n            .attr('transform', 'translate(0,' + height + ')')\r\n            .call(d3.axisBottom(x).tickSize(0))\r\n            .call((g) => g.select('.domain').attr('fill', 'none'));\r\n          /**\r\n           * tick line size in alternate fashion\r\n           */\r\n          svg.selectAll('g.x1.axis1 g.tick line').attr('y2', function () {\r\n            if (\r\n              alternate_text &&\r\n              self.chartConfiguration.isNoAlternateXaxisText == undefined\r\n            ) {\r\n              alternate_text = false;\r\n              return long_tick_length_bg - 7;\r\n            } else {\r\n              alternate_text = true;\r\n              return short_tick_length_bg - 4;\r\n            }\r\n          });\r\n          /**\r\n           * reset the flag so that values can be shown in same alternate fashion\r\n           */\r\n          alternate_text = false;\r\n          /**\r\n           * print x-axis label texts\r\n           * used by weekly charts\r\n           */\r\n          svg\r\n            .selectAll('g.x1.axis1 g.tick text')\r\n            .attr('class', 'lib-xaxis-labels-texts-weeklycharts')\r\n            .attr('y', function () {\r\n              if (alternate_text) {\r\n                alternate_text = false;\r\n                return long_tick_length_bg;\r\n              } else {\r\n                alternate_text = true;\r\n                return short_tick_length_bg;\r\n              }\r\n            });\r\n        }\r\n        if (self.chartConfiguration.xLabelsOnSameLine) {\r\n          svg\r\n            .selectAll('g.x1.axis1 g.tick text')\r\n            .attr('class', 'lib-xaxis-labels-texts-drilldown')\r\n            .attr('y', short_tick_length_bg)\r\n            .text(function (d) {\r\n              var isValueToBeIgnored = false;\r\n              data.map((indiv: any) => {\r\n                if (\r\n                  indiv.name.toLowerCase() == d.trim().toLowerCase() &&\r\n                  indiv[metaData.keyList[0]] == -1\r\n                ) {\r\n                  isValueToBeIgnored = true;\r\n                }\r\n              });\r\n              if (isValueToBeIgnored) {\r\n                return '';\r\n              }\r\n              if (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          svg\r\n            .selectAll('g.x1.axis1 g.tick')\r\n            .append('text')\r\n            .attr('class', 'lib-xaxis-labels-texts-drilldown')\r\n            .attr('y', long_tick_length_bg)\r\n            .attr('fill', 'currentColor')\r\n            .text(function (d) {\r\n              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        /**y scale for left y axis */\r\n        var y = d3.scaleLinear().rangeRound([height, 0]);\r\n        var maxValue = d3.max(data, (d) => d3.max(keyList, (key) => +d[key]));\r\n        if (maxValue == 0) {\r\n          if (this.chartData.targetLineData) {\r\n            maxValue = this.chartData.targetLineData.target + 20;\r\n          } else {\r\n            maxValue = 100;\r\n          }\r\n        }\r\n        if (self.chartConfiguration.yAxisGrid) {\r\n          // svg\r\n          //   .append('g')\r\n          //   .attr('class', 'grid')\r\n          //   .call(\r\n          //     d3\r\n          //       .axisLeft(y)\r\n          //       .ticks(self.chartConfiguration.numberOfYTicks)\r\n          //       .tickSize(-width)\r\n          //       .tickFormat('')\r\n          //   )\r\n          //   // .style('stroke-dasharray', '5 5')\r\n          //   .style('color', '#B9B9B9')\r\n          //   .style('opacity', '0.5')\r\n          //   .call((g) => g.select('.domain').remove());\r\n        }\r\n        if (this.chartConfiguration.customYscale) {\r\n          /**\r\n           * increase y-scale so that values wont cross or exceed out of range\r\n           * used in weekly charts\r\n           */\r\n          maxValue = maxValue * this.chartConfiguration.customYscale;\r\n        }\r\n        if (\r\n          this.chartData.targetLineData &&\r\n          maxValue < this.chartData.targetLineData.target\r\n        ) {\r\n          maxValue =\r\n            maxValue < 10 && this.chartData.targetLineData.target < 10\r\n              ? this.chartData.targetLineData.target + 3\r\n              : this.chartData.targetLineData.target + 20;\r\n        }\r\n        y.domain([0, maxValue]).nice();\r\n        let lineYscale;\r\n        \r\n        if (lineData != null) {\r\n          let maxLineValue = d3.max(lineData, function (d) {\r\n            return +d.value;\r\n          });\r\n    \r\n          maxLineValue = maxLineValue * this.chartConfiguration.customYscale;\r\n    \r\n          let minLineValue = d3.min(lineData, function (d) {\r\n            return +d.value;\r\n          });\r\n          if (maxLineValue > 0) minLineValue = minLineValue - 3;\r\n          if (minLineValue > 0) {\r\n            minLineValue = 0;\r\n          }\r\n          lineYscale = d3\r\n            .scaleLinear()\r\n            .domain([minLineValue, maxLineValue])\r\n            .range([height, minLineValue]);\r\n        }\r\n        let yLineAxis;\r\n        if (lineYscale != null) {\r\n          yLineAxis = d3\r\n            .axisRight(lineYscale)\r\n            .ticks(self.chartConfiguration.numberOfYTicks)\r\n            .tickSize(0)\r\n            .tickFormat(self.chartConfiguration.yLineAxisLabelFomatter);\r\n        }\r\n        /**\r\n         * show x-axis grid between labels\r\n         * used by weekly charts\r\n         */\r\n        if (self.chartConfiguration.isXgridBetweenLabels) {\r\n          svg\r\n            .append('g')\r\n            .attr('class', 'grid')\r\n            .attr(\r\n              'transform',\r\n              'translate(' + x.bandwidth() / 2 + ',' + height + ')'\r\n            )\r\n            .call(d3.axisBottom(x).tickSize(-height).tickFormat(''))\r\n            .style('stroke-dasharray', '5 5')\r\n            .style('color', 'var(--chart-grid-color, #999999)')\r\n            .call((g) => g.select('.domain').remove());\r\n        }\r\n    \r\n        if (this.chartConfiguration.yAxisGrid) {\r\n          /**\r\n           * draw y axis\r\n           */\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) => g.select('.domain').remove());\r\n        } else {\r\n          svg\r\n            .append('g')\r\n            .call(d3.axisLeft(y).ticks(self.chartConfiguration.numberOfYTicks))\r\n            .style('color', '#B9B9B9')\r\n            .style('opacity', '0.5')\r\n            .call((g) => g.select('.domain').remove());\r\n        }\r\n    \r\n        var xSubgroup = d3.scaleBand().domain(subgroups);\r\n        if (this.chartConfiguration.isMultiChartGridLine == undefined) {\r\n          xSubgroup.range([0, x.bandwidth()]);\r\n        } else {\r\n          /**\r\n           * used to make grouped bars with lesser width as we are not using padding for width\r\n           * used by weekly charts\r\n           */\r\n          xSubgroup.range([0, x.bandwidth()]);\r\n        }\r\n        // if (this.chartConfiguration.isDrilldownChart) {\r\n    \r\n        // }\r\n        var color = d3\r\n          .scaleOrdinal()\r\n          .domain(subgroups)\r\n          .range(Object.values(metaData.colors));\r\n        // var colorAboveTarget = d3\r\n        //   .scaleOrdinal()\r\n        //   .domain(subgroups)\r\n        //   .range(Object.values(metaData.colorAboveTarget));\r\n        var state = svg\r\n          .append('g')\r\n          .selectAll('.state')\r\n          .data(data)\r\n          .enter()\r\n          .append('g')\r\n          .attr('transform', function (d) {\r\n            return 'translate(' + x(d.name) + ',0)';\r\n          });\r\n        state\r\n          .selectAll('rect')\r\n          .data(function (d) {\r\n            let newList: any = [];\r\n            subgroups.map(function (key) {\r\n              // if (key !== \"group\") {\r\n              let obj: any = { key: key, value: d[key], name: d.name };\r\n              newList.push(obj);\r\n              // }\r\n            });\r\n            return newList;\r\n          })\r\n          .enter()\r\n          .append('rect')\r\n          .attr('class', 'bars')\r\n          .on('click', function (d) {\r\n            if (d.key != 'Target') {\r\n              if (\r\n                !metaData.barWithoutClick ||\r\n                !metaData.barWithoutClick.length ||\r\n                (!metaData.barWithoutClick.includes(d?.name) &&\r\n                  !metaData.barWithoutClick.includes(d?.key))\r\n              )\r\n                // self.handleClick(d.data.name);\r\n                self.handleClick(d);\r\n            }\r\n          })\r\n          .attr('x', function (d) {\r\n            if (self.chartConfiguration.isDrilldownChart) {\r\n              data.map((indiv: any) => {\r\n                if (indiv.name == d.name) {\r\n                  let keys = Object.keys(indiv).filter((temp, i) => i != 0);\r\n                  tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);\r\n                  if (x.bandwidth() > 100) {\r\n                    if (self.chartData.data.length == 1) {\r\n                      if (Object.keys(self.chartData.data[0]).length == 2) {\r\n                        tempScale.range([\r\n                          0 + (x.bandwidth() - 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              return tempScale(d.key);\r\n            }\r\n            return xSubgroup(d.key);\r\n          })\r\n          .attr('y', function (d) {\r\n            return y(d.value);\r\n          })\r\n          .attr('width', function (d) {\r\n            if (self.chartConfiguration.isDrilldownChart) {\r\n              // var tempScale;\r\n    \r\n              data.map((indiv: any) => {\r\n                if (indiv.name == d.name) {\r\n                  let keys = Object.keys(indiv).filter((temp, i) => i != 0);\r\n                  var temp;\r\n                  tempScale = d3.scaleBand().domain(keys).range([0, x.bandwidth()]);\r\n                  if (x.bandwidth() > 100) {\r\n                    if (self.chartData.data.length == 1) {\r\n                      if (Object.keys(self.chartData.data[0]).length == 2) {\r\n                        tempScale.range([\r\n                          0 + (x.bandwidth() - 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              return tempScale.bandwidth();\r\n            }\r\n            return xSubgroup.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            if (d.value) return height - y(d.value);\r\n            return height - y(0);\r\n          })\r\n          // .style('cursor', 'pointer')\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 >= parseInt(self.chartData.targetLineData.target) &&\r\n              self.chartData.metaData.colorAboveTarget\r\n            )\r\n              return self.chartData.metaData.colorAboveTarget[d.key];\r\n            return self.chartData.metaData.colors[d.key];\r\n          });\r\n    \r\n        /**\r\n         * display angled texts on the bars\r\n         */\r\n        if (this.chartConfiguration.textsOnBar != undefined && !this.isZoomedOut) {\r\n          state\r\n            .selectAll('text')\r\n            .data(function (d) {\r\n              let newList: any = [];\r\n              subgroups.map(function (key) {\r\n                let obj: any = { key: key, value: d[key], name: d.name };\r\n                newList.push(obj);\r\n              });\r\n              return newList;\r\n            })\r\n            .enter()\r\n            .append('text')\r\n            .attr('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.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.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 tempScale;\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                        // .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              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;\r\n            })\r\n            .attr('dy', function () {\r\n              return d.class;\r\n            })\r\n            .attr('width', function () {\r\n              // var tempScale;\r\n    \r\n              data.map((indiv: any) => {\r\n                if (indiv.name == d.name) {\r\n                  let keys = Object.keys(indiv).filter((temp, i) => i != 0);\r\n                  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              if (metaData.hasDrillDown) {\r\n                if (tempScale.bandwidth() + leftAndRightSpaces * 2 > 180) {\r\n                  return '180px';\r\n                }\r\n                return tempScale.bandwidth() + leftAndRightSpaces * 2;\r\n              } else return tempScale.bandwidth() + leftAndRightSpaces * 2;\r\n            })\r\n            .attr('height', 40)\r\n            .append('xhtml:div')\r\n            .attr('class', 'title')\r\n            .style('z-index', 99)\r\n            .html(function () {\r\n              let dataType = metaData.dataType ? metaData.dataType : '';\r\n              if (!self.isZoomedOut) {\r\n                let desiredText =\r\n                  '<span class=\"title-bar-name\">' + d.name + '</span>';\r\n                desiredText +=\r\n                  '<span class=\"title-bar-value\"><span>' +\r\n                  d.value +\r\n                  '</span>' +\r\n                  dataType +\r\n                  '</span>';\r\n                return desiredText;\r\n              } else {\r\n                let tempKey =\r\n                  d.name.length <= 8 ? d.name : d.name.substring(0, 5) + '...';\r\n                let desiredText =\r\n                  '<span class=\"title-bar-name\">' +\r\n                  tempKey +\r\n                  ':' +\r\n                  d.value +\r\n                  dataType +\r\n                  '</span>';\r\n                desiredText +=\r\n                  '<span class=\"title-bar-value\">' + d.name + '</span>';\r\n                return desiredText;\r\n              }\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', '#000')\r\n    \r\n          .call(d3.axisBottom(xScaleFromOrigin).tickSize(0))\r\n          .call((g) => g.select('.domain').attr('fill', 'none'));\r\n        svg.selectAll('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(self.chartConfiguration.yAxisLabelFomatter)\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', '#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         * used to display y label\r\n         */\r\n        if (this.isZoomedOut) {\r\n          svg\r\n            .selectAll('.lib-xaxis-labels-texts-drilldown')\r\n            .attr('class', 'lib-display-hidden');\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          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', 0 - margin.left / 2 - 30)\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          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            /**\r\n             * used by weekly charts\r\n             */\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 (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      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 + ' ,' + (height + margin.top + 20) + ')'\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 (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        if (metaData.lineyLabel) {\r\n          svgYAxisRight\r\n            .append('text')\r\n            .attr('class', 'lib-axis-group-label lib-line-axis')\r\n            .attr('style', self.chartConfiguration.yAxisCustomlabelStyles)\r\n            .attr('transform', 'translate(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', 'pointer')\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('color', self.chartConfiguration.lineGraphColor)\r\n              .attr('style', 'font-size: ' + '.85em')\r\n              .attr('x', function (d, i) {\r\n                return x(d.name) + x.bandwidth() / 2;\r\n              })\r\n              .attr('y', function (d) {\r\n                return lineYscale(d.value);\r\n              })\r\n              .attr('dy', '-1em')\r\n              .text(function (d) {\r\n                return self.chartConfiguration.labelFormatter(d.value);\r\n              });\r\n          }\r\n        }\r\n      }\r\n    \r\n      handleClick(d: any) {\r\n        if (this.chartData.metaData.hasDrillDown || d?.toggleFrom)\r\n          this.clickEvent.emit(d);\r\n      }\r\n      handleHeaderMenuClick(id) {\r\n        this.headerMenuclickEvent.emit(id);\r\n      }\r\n      handleDD1Click(event) {\r\n        this.isDD1Open = true;\r\n        this.isDD2Open = false;\r\n      }\r\n      handleDD2Click(event) {\r\n        this.isDD2Open = true;\r\n        this.isDD1Open = false;\r\n      }\r\n      handleCompareByFilterSelection(event) {\r\n        this.clickEvent.emit(event);\r\n      }  \r\n  }","<div\r\n  #groupcontainer\r\n  class=\"lib-chart-wrapper\"\r\n  [ngClass]=\"{ 'lib-no-background': isTransparentBackground }\"\r\n  style=\"background-color: var(--card-bg);\"\r\n  (resized)=\"onResized($event)\"\r\n>\r\n\r\n<div class=\"header-alt\" *ngIf=\"!isHeaderVisible\">\r\n  <lib-chart-header-v2\r\n    [chartData]=\"chartData\"\r\n    [chartConfiguration]=\"chartConfiguration\"\r\n    (clickEvent)=\"handleClick($event)\"\r\n  ></lib-chart-header-v2>\r\n  <lib-chart-header-v3\r\n    [chartData]=\"chartData\"\r\n    [chartConfiguration]=\"chartConfiguration\"\r\n    (compareByFilterSelection)=\"handleCompareByFilterSelection($event)\"\r\n    (zoomInZoomOutClick)=\"handleZoominZoomoutClick($event)\"\r\n  ></lib-chart-header-v3>\r\n</div>\r\n\r\n  <lib-chart-header-v1\r\n  [title]=\"chartData.metaData.title\"\r\n  [hasDrillDown]=\"chartData.metaData.hasDrillDown\"\r\n  [isEditEnabled]=\"chartData.metaData.isEditEnabled\"\r\n  [menuOptions]=\"chartConfiguration.headerMenuOptions\"\r\n  [isria]=\"customChartConfiguration.isRia\"\r\n  [selectedKpiTooltop]=\"chartConfiguration.selectedKpiTooltop\"\r\n  (menuOptionClickEvent)=\"handleHeaderMenuClick($event)\"\r\n  [isAlertEnabled]=\"isAlertEnabled\"\r\n  *ngIf=\"isHeaderVisible\"\r\n></lib-chart-header-v1>\r\n\r\n  <div\r\n    [style.height]=\"chartConfiguration.svgHeight\"\r\n    id=\"groupchartcontainer\"\r\n    #groupchartcontainer\r\n    class=\"lib-chart-svg\"\r\n  ></div>\r\n</div>\r\n"]}