@rivet-health/design-system 35.9.0 → 35.10.0

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.
@@ -55,6 +55,11 @@ export var Chart;
55
55
  console.warn("Heads up! Labeled series aren't currently supported for line charts");
56
56
  return emptyChart;
57
57
  }
58
+ if (hiddenData.supplementaryYs && hiddenData.supplementaryYs.length > 0) {
59
+ // eslint-disable-next-line no-console
60
+ console.warn("Heads up! Supplementary y values aren't supported for non-bar charts");
61
+ return emptyChart;
62
+ }
58
63
  //This assignment makes typescript recognize the actual type (TimeseriesData)
59
64
  const data = hiddenData;
60
65
  const xScale = scaleUtc(timeseriesDomain(data), xRange(dimensions, config));
@@ -152,6 +157,12 @@ export var Chart;
152
157
  console.warn("Heads up! Data labels aren't supported for any stacked chart type");
153
158
  return emptyChart;
154
159
  }
160
+ if (uncheckedData.supplementaryYs &&
161
+ uncheckedData.supplementaryYs.length > 0) {
162
+ // eslint-disable-next-line no-console
163
+ console.warn("Heads up! Supplementary y values aren't supported for non-bar charts");
164
+ return emptyChart;
165
+ }
155
166
  //This assignment makes typescript recognize the actual type (TimeseriesData)
156
167
  const data = uncheckedData;
157
168
  const xScale = scaleUtc(timeseriesDomain(data), xRange(dimensions, config));
@@ -255,11 +266,23 @@ export var Chart;
255
266
  console.warn("Heads up! Labeled series aren't currently supported for vertical bar charts");
256
267
  return emptyChart;
257
268
  }
258
- if (config.showDataLabels == true && config.groupingType == 'stacked') {
269
+ //When there's only 1 series, the distinction between 'stacked' and 'clustered' doesn't apply
270
+ const isSingleSeries = uncheckedData.ys.length == 1;
271
+ if (config.showDataLabels == true &&
272
+ config.groupingType == 'stacked' &&
273
+ !isSingleSeries) {
259
274
  // eslint-disable-next-line no-console
260
275
  console.warn("Heads up! Data labels aren't supported for any stacked chart type");
261
276
  return emptyChart;
262
277
  }
278
+ if (uncheckedData.supplementaryYs &&
279
+ uncheckedData.supplementaryYs.length > 0 &&
280
+ config.groupingType == 'clustered' &&
281
+ !isSingleSeries) {
282
+ // eslint-disable-next-line no-console
283
+ console.warn("Heads up! Supplementary y values aren't supported for clustered data (just use another normal y series)");
284
+ return emptyChart;
285
+ }
263
286
  //This assignment makes typescript recognize the actual type (TimeseriesData)
264
287
  const data = uncheckedData;
265
288
  const { range: xRange, binSize } = barXRange(dimensions, data, config);
@@ -287,6 +310,14 @@ export var Chart;
287
310
  const offset = yIndex * (width + SMALL_PADDING);
288
311
  xValue = xValue + offset;
289
312
  }
313
+ const yInclSuppCount = data.supplementaryYs
314
+ ? data.supplementaryYs.filter(y => y.associatedYIndex == yIndex)
315
+ .length + 1
316
+ : 1;
317
+ if (yInclSuppCount > 1) {
318
+ width =
319
+ (binSize - (yInclSuppCount - 1) * SMALL_PADDING) / yInclSuppCount;
320
+ }
290
321
  return {
291
322
  x: xValue,
292
323
  y: yValue,
@@ -294,6 +325,31 @@ export var Chart;
294
325
  height,
295
326
  };
296
327
  }));
328
+ let suppBars = [];
329
+ if (data.supplementaryYs) {
330
+ suppBars = data.supplementaryYs.map((y, yIndex) => y.values.map((_, index) => {
331
+ const { yValue, height } = getBarYInfo(data, yIndex, index, scale, config.groupingType == 'stacked', true);
332
+ let xValue = xScale(data.x[index]) - halfBinSize;
333
+ let width = binSize;
334
+ const matchingYSupps = data.supplementaryYs
335
+ ? data.supplementaryYs.filter(suppY => suppY.associatedYIndex == y.associatedYIndex)
336
+ : [];
337
+ const yInclSuppCount = matchingYSupps.length + 1;
338
+ const ySuppMatchingIndex = y.supplementalIndex + 1;
339
+ if (yInclSuppCount > 1) {
340
+ const xCalc = calculateXValueAndOffsetForBars(binSize, yInclSuppCount, ySuppMatchingIndex, xValue);
341
+ width = xCalc.width;
342
+ xValue = xCalc.xValue;
343
+ }
344
+ return {
345
+ x: xValue,
346
+ y: yValue,
347
+ width,
348
+ height,
349
+ };
350
+ }));
351
+ bars.push(...suppBars);
352
+ }
297
353
  const zeroAxisPosVal = scale(0, true);
298
354
  const dataLabels = data.ys.flatMap((y, yIndex) => {
299
355
  const subLabels = y.values.map((val, xIndex) => {
@@ -313,10 +369,45 @@ export var Chart;
313
369
  });
314
370
  return subLabels;
315
371
  });
372
+ if (data.supplementaryYs) {
373
+ const suppDataLabels = data.supplementaryYs.flatMap((y, yIndex) => {
374
+ const subLabels = y.values.map((val, xIndex) => {
375
+ const isNegativeBar = suppBars[yIndex][xIndex].y >= zeroAxisPosVal &&
376
+ suppBars[yIndex][xIndex].height > 0;
377
+ const yOffset = isNegativeBar
378
+ ? SMALL_PADDING +
379
+ DATA_LABEL_HEIGHT +
380
+ suppBars[yIndex][xIndex].height
381
+ : -SMALL_PADDING;
382
+ return {
383
+ label: (checkIfSecondary(data, yIndex, xIndex, true)
384
+ ? secondaryPipe.transform(val)
385
+ : pipe.transform(val)) ?? '',
386
+ yPos: suppBars[yIndex][xIndex].y + yOffset,
387
+ xPos: suppBars[yIndex][xIndex].x + suppBars[yIndex][xIndex].width / 2,
388
+ anchor: 'middle',
389
+ };
390
+ });
391
+ return subLabels;
392
+ });
393
+ dataLabels.push(...suppDataLabels);
394
+ }
316
395
  function hover(pos) {
317
396
  const xIndex = findNearestIndex(data.x, xScale.invert(pos.x).getTime());
318
397
  const x = xScale(data.x[xIndex]);
319
- const ys = data.ys.map((_, mapYIndex) => getBarYInfo(data, mapYIndex, xIndex, scale, config.groupingType == 'stacked').yValue);
398
+ let isSuppValue = false;
399
+ let suppIndexVal = 0;
400
+ let yInclSuppCount = 1;
401
+ if (data.supplementaryYs) {
402
+ yInclSuppCount = getClusterCountWithSupp(data);
403
+ suppIndexVal = findSubIndex(x, pos.x, binSize, yInclSuppCount) - 1;
404
+ if (suppIndexVal >= 0) {
405
+ isSuppValue = true;
406
+ }
407
+ }
408
+ const ys = data.ys.map((_, mapYIndex) => isSuppValue
409
+ ? getSuppBarYInfoViaYIndex(data, mapYIndex, suppIndexVal, xIndex, scale, config.groupingType == 'stacked').yValue
410
+ : getBarYInfo(data, mapYIndex, xIndex, scale, config.groupingType == 'stacked').yValue);
320
411
  const yPosSign = zeroAxisPosVal - pos.y;
321
412
  let visibleYIndex = -1;
322
413
  if (yPosSign < 0 && data.ys.find(y => y.values.find(val => val < 0))) {
@@ -347,8 +438,23 @@ export var Chart;
347
438
  }
348
439
  }
349
440
  const yIndex = visibleIndices[visibleYIndex];
350
- const { yValue, height } = getBarYInfo(data, yIndex, xIndex, scale, config.groupingType == 'stacked');
351
- const anchor = new DOMRect(pos.rect.x + bars[visibleYIndex][xIndex].x - SMALL_PADDING, pos.rect.y + yValue, bars[visibleYIndex][xIndex].width + SMALL_PADDING * 2, height);
441
+ const { yValue, height } = isSuppValue
442
+ ? getSuppBarYInfoViaYIndex(data, yIndex, suppIndexVal, xIndex, scale, config.groupingType == 'stacked')
443
+ : getBarYInfo(data, yIndex, xIndex, scale, config.groupingType == 'stacked');
444
+ const xCalc = calculateXValueAndOffsetForBars(binSize, yInclSuppCount, suppIndexVal + 1, xScale(data.x[xIndex]) - halfBinSize);
445
+ const anchorX = isSuppValue
446
+ ? xCalc.xValue
447
+ : bars[visibleYIndex][xIndex].x;
448
+ const anchorWidth = isSuppValue
449
+ ? xCalc.width
450
+ : bars[visibleYIndex][xIndex].width;
451
+ const anchor = new DOMRect(pos.rect.x + anchorX - SMALL_PADDING, pos.rect.y + yValue, anchorWidth + SMALL_PADDING * 2, height);
452
+ //We need to preserve the original index for the later checkIfSecondary call
453
+ const ysForMetrics = isSuppValue && data.supplementaryYs
454
+ ? data.supplementaryYs
455
+ .map((suppY, index) => ({ data: suppY, originalIndex: index }))
456
+ .filter(suppY => suppY.data.supplementalIndex == suppIndexVal)
457
+ : data.ys.map((y, index) => ({ data: y, originalIndex: index }));
352
458
  return {
353
459
  x,
354
460
  xIndex,
@@ -358,13 +464,15 @@ export var Chart;
358
464
  tooltip: {
359
465
  anchor,
360
466
  date: utcFormat('%B %d, %Y')(new Date(data.x[xIndex])),
361
- metrics: data.ys
467
+ metrics: ysForMetrics
362
468
  .map((y, index) => ({
363
- color: colors[index % colors.length],
364
- label: y.label,
365
- value: (checkIfSecondary(data, index, xIndex)
366
- ? secondaryFullPipe.transform(y.values[xIndex])
367
- : fullPipe.transform(y.values[xIndex])) ?? '-',
469
+ color: colors['associatedYIndex' in y.data
470
+ ? y.data.associatedYIndex
471
+ : index % colors.length],
472
+ label: y.data.label,
473
+ value: (checkIfSecondary(data, y.originalIndex, xIndex, isSuppValue)
474
+ ? secondaryFullPipe.transform(y.data.values[xIndex])
475
+ : fullPipe.transform(y.data.values[xIndex])) ?? '-',
368
476
  }))
369
477
  .filter((_, i) => config.groupedTooltip || i == visibleYIndex),
370
478
  },
@@ -396,13 +504,24 @@ export var Chart;
396
504
  data.ys.length ==
397
505
  data.ys.filter(y => y.values.filter(val => val != 0).length == 1)
398
506
  .length;
507
+ //When there's only 1 series, the distinction between 'stacked' and 'clustered' doesn't apply
508
+ const isSingleSeries = data.ys.length == 1;
399
509
  if (config.showDataLabels == true &&
400
510
  config.groupingType == 'stacked' &&
401
- !isMetricChart) {
511
+ !isMetricChart &&
512
+ !isSingleSeries) {
402
513
  // eslint-disable-next-line no-console
403
514
  console.warn("Heads up! Data labels aren't supported for any stacked chart type");
404
515
  return emptyChart;
405
516
  }
517
+ if (data.supplementaryYs &&
518
+ data.supplementaryYs.length > 0 &&
519
+ config.groupingType == 'clustered' &&
520
+ !isSingleSeries) {
521
+ // eslint-disable-next-line no-console
522
+ console.warn("Heads up! Supplementary y values aren't supported for clustered data (just use another normal y series)");
523
+ return emptyChart;
524
+ }
406
525
  const { range: yRange } = barYRange(dimensions, data, config);
407
526
  let yScale = data.type == 'labeled'
408
527
  ? scaleLinear(indexDomain(data), yRange)
@@ -438,6 +557,17 @@ export var Chart;
438
557
  const offset = (yIndex - centerIndex) * (HORIZONTAL_BAR_HEIGHT + SMALL_PADDING);
439
558
  yValue = yValue + offset;
440
559
  }
560
+ const matchingYSupps = data.supplementaryYs
561
+ ? data.supplementaryYs.filter(suppY => suppY.associatedYIndex == yIndex)
562
+ : [];
563
+ const yInclSuppCount = matchingYSupps.length + 1;
564
+ const ySuppMatchingIndex = 0;
565
+ if (yInclSuppCount > 1) {
566
+ const centerIndex = yInclSuppCount / 2 - 0.5;
567
+ const offset = (ySuppMatchingIndex - centerIndex) *
568
+ (HORIZONTAL_BAR_HEIGHT + SMALL_PADDING);
569
+ yValue = yValue + offset;
570
+ }
441
571
  const horR = Math.min(4, Math.floor(width / 2));
442
572
  const verR = Math.min(4, Math.floor(HORIZONTAL_BAR_HEIGHT / 2));
443
573
  subSimpHorBars.push({
@@ -477,63 +607,85 @@ export var Chart;
477
607
  .map(y => y.values[index])
478
608
  .filter(val => val < 0).length == 0 && !hasAnyPositiveBars;
479
609
  const rightSideRound = config.groupingType == 'clustered' || allRightZero;
480
- if (leftSideRound && rightSideRound) {
481
- //Both-sides rounding variation
482
- const pathD = `
483
- M ${xValue + horR},${yValue}
484
- h ${width - horR * 2}
485
- q${horR},0 ${horR},${verR}
486
- v ${HORIZONTAL_BAR_HEIGHT - verR * 2}
487
- q0,${verR} -${horR},${verR}
488
- h ${-(width - horR * 2)}
489
- q-${horR},0 -${horR},-${verR}
490
- v -${HORIZONTAL_BAR_HEIGHT - verR * 2}
491
- q0,-${verR} ${horR},-${verR}
492
- Z
493
- `;
494
- return pathD;
495
- }
496
- if (leftSideRound) {
497
- //Left-side rounding variation
498
- const pathD = `
499
- M ${xValue + horR},${yValue}
500
- h ${width - horR}
501
- v ${HORIZONTAL_BAR_HEIGHT}
502
- h ${-(width - horR)}
503
- q-${horR},0 -${horR},-${verR}
504
- v -${HORIZONTAL_BAR_HEIGHT - verR * 2}
505
- q0,-${verR} ${horR},-${verR}
506
- Z
507
- `;
508
- return pathD;
509
- }
510
- if (rightSideRound) {
511
- //Right-side rounding variation
512
- const pathD = `
513
- M ${xValue},${yValue}
514
- h ${width - horR}
515
- q${horR},0 ${horR},${verR}
516
- v ${HORIZONTAL_BAR_HEIGHT - verR * 2}
517
- q0,${verR} -${horR},${verR}
518
- h ${-(width - horR)}
519
- Z
520
- `;
521
- return pathD;
522
- }
523
- //No-rounding variation
524
- const pathD = `
525
- M ${xValue},${yValue}
526
- h ${width}
527
- v ${HORIZONTAL_BAR_HEIGHT}
528
- h ${-width}
529
- v -${HORIZONTAL_BAR_HEIGHT}
530
- Z
531
- `;
610
+ const pathD = calculateHorizontalBarPath(leftSideRound, rightSideRound, xValue, yValue, horR, verR, width);
532
611
  return pathD;
533
612
  });
534
613
  simplifiedHorizontalBars.push(subSimpHorBars);
535
614
  return retVal;
536
615
  });
616
+ const suppYs = data.supplementaryYs;
617
+ const simplifiedSuppHorizontalBars = [];
618
+ if (suppYs) {
619
+ const suppHorizontalBars = suppYs.map((y, yIndex) => {
620
+ const subSimpHorBars = [];
621
+ const retVal = y.values.map((_, index) => {
622
+ const { xValue, width } = getBarXInfo(data, yIndex, index, scale, config.groupingType == 'stacked', true);
623
+ let yValue = yScale(data.type == 'labeled' ? index : data.x[index]) -
624
+ HORIZONTAL_BAR_HEIGHT * 1.5;
625
+ const matchingYSupps = data.supplementaryYs
626
+ ? data.supplementaryYs.filter(suppY => suppY.associatedYIndex == y.associatedYIndex)
627
+ : [];
628
+ const yInclSuppCount = matchingYSupps.length + 1;
629
+ const ySuppMatchingIndex = y.supplementalIndex + 1;
630
+ if (yInclSuppCount > 1) {
631
+ const centerIndex = yInclSuppCount / 2 - 0.5;
632
+ const offset = (ySuppMatchingIndex - centerIndex) *
633
+ (HORIZONTAL_BAR_HEIGHT + SMALL_PADDING);
634
+ yValue = yValue + offset;
635
+ }
636
+ const horR = Math.min(4, Math.floor(width / 2));
637
+ const verR = Math.min(4, Math.floor(HORIZONTAL_BAR_HEIGHT / 2));
638
+ subSimpHorBars.push({
639
+ xPos: xValue,
640
+ yPos: yValue,
641
+ width,
642
+ });
643
+ //Don't draw anything for zero-value bars
644
+ if (width == 0) {
645
+ return '';
646
+ }
647
+ const isPositive = suppYs[yIndex].values[index] > 0;
648
+ const hasAnyNegativeBars = suppYs
649
+ .filter(suppY => suppY.supplementalIndex == y.supplementalIndex)
650
+ .map(y => y.values[index])
651
+ .find(val => val < 0);
652
+ const hasAnyPositiveBars = suppYs
653
+ .filter(suppY => suppY.supplementalIndex == y.supplementalIndex)
654
+ .map(y => y.values[index])
655
+ .find(val => val > 0);
656
+ //These checks are to make sure we still round if all previous/later values are 0
657
+ const allLeftZero = isPositive
658
+ ? suppYs
659
+ .slice(0, yIndex)
660
+ .filter(suppY => suppY.supplementalIndex == y.supplementalIndex)
661
+ .map(y => y.values[index])
662
+ .filter(val => val > 0).length == 0 && !hasAnyNegativeBars
663
+ : suppYs
664
+ .slice(yIndex + 1, suppYs.length)
665
+ .filter(suppY => suppY.supplementalIndex == y.supplementalIndex)
666
+ .map(y => y.values[index])
667
+ .filter(val => val < 0).length == 0;
668
+ const leftSideRound = config.groupingType == 'clustered' || allLeftZero;
669
+ const allRightZero = isPositive
670
+ ? suppYs
671
+ .slice(yIndex + 1, suppYs.length)
672
+ .filter(suppY => suppY.supplementalIndex == y.supplementalIndex)
673
+ .map(y => y.values[index])
674
+ .filter(val => val > 0).length == 0
675
+ : suppYs
676
+ .slice(0, yIndex)
677
+ .filter(suppY => suppY.supplementalIndex == y.supplementalIndex)
678
+ .map(y => y.values[index])
679
+ .filter(val => val < 0).length == 0 && !hasAnyPositiveBars;
680
+ const rightSideRound = config.groupingType == 'clustered' || allRightZero;
681
+ const pathD = calculateHorizontalBarPath(leftSideRound, rightSideRound, xValue, yValue, horR, verR, width);
682
+ return pathD;
683
+ });
684
+ simplifiedSuppHorizontalBars.push(subSimpHorBars);
685
+ return retVal;
686
+ });
687
+ horizontalBars.push(...suppHorizontalBars);
688
+ }
537
689
  const yOffset = HORIZONTAL_BAR_HEIGHT;
538
690
  const dataLabels = data.ys.flatMap((y, yIndex) => {
539
691
  const subLabels = y.values.map((val, xIndex) => {
@@ -553,6 +705,29 @@ export var Chart;
553
705
  });
554
706
  return subLabels;
555
707
  });
708
+ if (suppYs) {
709
+ const suppDataLabels = suppYs.flatMap((y, yIndex) => {
710
+ const subLabels = y.values.map((val, xIndex) => {
711
+ const barIsNegative = simplifiedSuppHorizontalBars[yIndex][xIndex].xPos <
712
+ zeroAxisPosVal &&
713
+ simplifiedSuppHorizontalBars[yIndex][xIndex].width > 0;
714
+ const xOffset = barIsNegative
715
+ ? -SMALL_PADDING
716
+ : simplifiedSuppHorizontalBars[yIndex][xIndex].width +
717
+ SMALL_PADDING;
718
+ return {
719
+ label: (checkIfSecondary(data, yIndex, xIndex, true)
720
+ ? secondaryPipe.transform(val)
721
+ : pipe.transform(val)) ?? '',
722
+ yPos: simplifiedSuppHorizontalBars[yIndex][xIndex].yPos + yOffset,
723
+ xPos: simplifiedSuppHorizontalBars[yIndex][xIndex].xPos + xOffset,
724
+ anchor: barIsNegative ? 'end' : 'start',
725
+ };
726
+ });
727
+ return subLabels;
728
+ });
729
+ dataLabels.push(...suppDataLabels);
730
+ }
556
731
  function hover(pos) {
557
732
  let xIndex = 0;
558
733
  let x = 0;
@@ -565,7 +740,19 @@ export var Chart;
565
740
  xIndex = findNearestIndexString(data.x, yScale.invert(pos.y));
566
741
  x = yScale(xIndex) - SMALL_PADDING;
567
742
  }
568
- const fullYs = data.ys.map((_, mapYIndex) => getBarXInfo(data, mapYIndex, xIndex, scale, config.groupingType == 'stacked'));
743
+ let isSuppValue = false;
744
+ let suppIndexVal = 0;
745
+ let yInclSuppCount = 1;
746
+ if (data.supplementaryYs) {
747
+ yInclSuppCount = getClusterCountWithSupp(data);
748
+ suppIndexVal = findSubIndexHorizontal(x, pos.y, yInclSuppCount) - 1;
749
+ if (suppIndexVal >= 0) {
750
+ isSuppValue = true;
751
+ }
752
+ }
753
+ const fullYs = data.ys.map((_, mapYIndex) => isSuppValue
754
+ ? getSuppBarXInfoViaYIndex(data, mapYIndex, suppIndexVal, xIndex, scale, config.groupingType == 'stacked')
755
+ : getBarXInfo(data, mapYIndex, xIndex, scale, config.groupingType == 'stacked'));
569
756
  const ys = fullYs.map(y => y.xValue);
570
757
  let visibleYIndex = -1;
571
758
  for (let i = 0; i < fullYs.length; i++) {
@@ -617,10 +804,26 @@ export var Chart;
617
804
  }
618
805
  }
619
806
  }
620
- const anchor = new DOMRect(pos.rect.x +
621
- simplifiedHorizontalBars[visibleYIndex][xIndex].xPos -
622
- SMALL_PADDING, pos.rect.y + simplifiedHorizontalBars[visibleYIndex][xIndex].yPos, simplifiedHorizontalBars[visibleYIndex][xIndex].width +
623
- SMALL_PADDING * 2, HORIZONTAL_BAR_HEIGHT);
807
+ const suppYIndex = isSuppValue && suppYs
808
+ ? suppYs.findIndex(suppY => suppY.associatedYIndex == visibleYIndex &&
809
+ suppY.supplementalIndex == suppIndexVal)
810
+ : -1;
811
+ const barXPos = isSuppValue
812
+ ? simplifiedSuppHorizontalBars[suppYIndex][xIndex].xPos
813
+ : simplifiedHorizontalBars[visibleYIndex][xIndex].xPos;
814
+ const barYPos = isSuppValue
815
+ ? simplifiedSuppHorizontalBars[suppYIndex][xIndex].yPos
816
+ : simplifiedHorizontalBars[visibleYIndex][xIndex].yPos;
817
+ const barWidth = isSuppValue
818
+ ? simplifiedSuppHorizontalBars[suppYIndex][xIndex].width
819
+ : simplifiedHorizontalBars[visibleYIndex][xIndex].width;
820
+ const anchor = new DOMRect(pos.rect.x + barXPos - SMALL_PADDING, pos.rect.y + barYPos, barWidth + SMALL_PADDING * 2, HORIZONTAL_BAR_HEIGHT);
821
+ //We need to preserve the original index for the later checkIfSecondary call
822
+ const ysForMetrics = isSuppValue && suppYs
823
+ ? suppYs
824
+ .map((suppY, index) => ({ data: suppY, originalIndex: index }))
825
+ .filter(suppY => suppY.data.supplementalIndex == suppIndexVal)
826
+ : data.ys.map((y, index) => ({ data: y, originalIndex: index }));
624
827
  return {
625
828
  x,
626
829
  xIndex,
@@ -632,13 +835,15 @@ export var Chart;
632
835
  date: data.type == 'labeled'
633
836
  ? data.x[xIndex].label
634
837
  : utcFormat('%B %d, %Y')(new Date(data.x[xIndex])),
635
- metrics: data.ys
838
+ metrics: ysForMetrics
636
839
  .map((y, index) => ({
637
- color: colors[index % colors.length],
638
- label: y.label,
639
- value: (checkIfSecondary(data, index, xIndex)
640
- ? secondaryFullPipe.transform(y.values[xIndex])
641
- : fullPipe.transform(y.values[xIndex])) ?? '-',
840
+ color: colors['associatedYIndex' in y.data
841
+ ? y.data.associatedYIndex
842
+ : index % colors.length],
843
+ label: y.data.label,
844
+ value: (checkIfSecondary(data, y.originalIndex, xIndex, isSuppValue)
845
+ ? secondaryFullPipe.transform(y.data.values[xIndex])
846
+ : fullPipe.transform(y.data.values[xIndex])) ?? '-',
642
847
  }))
643
848
  .filter((_, i) => config.groupedTooltip || i == visibleYIndex),
644
849
  },
@@ -668,6 +873,11 @@ export var Chart;
668
873
  console.warn("Heads up! Two axes with percentage aren't supported for donut charts");
669
874
  return emptyChart;
670
875
  }
876
+ if (allData.supplementaryYs && allData.supplementaryYs.length > 0) {
877
+ // eslint-disable-next-line no-console
878
+ console.warn("Heads up! Supplementary y values aren't supported for non-bar charts");
879
+ return emptyChart;
880
+ }
671
881
  const { data: unstackedData, visibleIndices } = hide(allData);
672
882
  const donutData = Chart.convertChartDataToDonutData(unstackedData);
673
883
  const hasNonZeroValue = donutData.some(d => d.value > 0);
@@ -778,6 +988,12 @@ export var Chart;
778
988
  console.warn("Heads up! Time-based series aren't currently supported for waterfall charts");
779
989
  return emptyChart;
780
990
  }
991
+ if (uncheckedData.supplementaryYs &&
992
+ uncheckedData.supplementaryYs.length > 0) {
993
+ // eslint-disable-next-line no-console
994
+ console.warn("Heads up! Supplementary y values aren't supported for non-bar charts");
995
+ return emptyChart;
996
+ }
781
997
  if (config.secondaryValueType) {
782
998
  // eslint-disable-next-line no-console
783
999
  console.warn('Heads up! Waterfall charts do not currently have two-axis support');
@@ -1083,10 +1299,6 @@ export var Chart;
1083
1299
  ];
1084
1300
  }
1085
1301
  function calcYScalesAndTicks(data, dimensions, pipe, secondaryPipe, isStacked, config) {
1086
- const primaryData = {
1087
- ...data,
1088
- ys: data.ys.filter(y => !y.isSecondary),
1089
- };
1090
1302
  const secondaryData = {
1091
1303
  ...data,
1092
1304
  ys: data.ys.filter(y => y.isSecondary),
@@ -1094,8 +1306,11 @@ export var Chart;
1094
1306
  const scaleRange = yRange(dimensions, config, data);
1095
1307
  //Simpler path for data w/o secondaries
1096
1308
  if (secondaryData.ys.length == 0) {
1097
- const data = isStacked ? stack(primaryData) : primaryData;
1098
- const yScale = scaleLinear(yDomain(data), scaleRange);
1309
+ const yScaleDomainValues = calcYScaleDomainValues(data, isStacked, false);
1310
+ const yScale = scaleLinear([
1311
+ Math.min(...yScaleDomainValues.map(val => val.min)),
1312
+ Math.max(...yScaleDomainValues.map(val => val.max)),
1313
+ ], scaleRange);
1099
1314
  const yTicks = yScale.ticks(5).map(tick => ({
1100
1315
  y: yScale(tick),
1101
1316
  label: pipe.transform(tick),
@@ -1110,17 +1325,16 @@ export var Chart;
1110
1325
  yTicks,
1111
1326
  };
1112
1327
  }
1328
+ const primaryYScaleDomainValues = calcYScaleDomainValues(data, isStacked, false);
1329
+ const secondaryYScaleDomainValues = calcYScaleDomainValues(data, isStacked, true);
1113
1330
  let scaleDomainMultiple = 1;
1114
1331
  //Calculating how much we need to multiple the domain by to 'fit' both axes' data
1115
1332
  if (isStacked) {
1116
- //Stacking each individual data type makes finding the max easier
1117
- const primaryStacked = stack(primaryData);
1118
- const secondaryStacked = stack(secondaryData);
1119
- const primaryDataMax = Math.max(...primaryStacked.ys.map(y => Math.max(...y.values)));
1120
- const secondaryDataMax = Math.max(...secondaryStacked.ys.map(y => Math.max(...y.values)));
1121
- for (let i = 0; i < primaryStacked.x.length; i++) {
1122
- const primaryVal = Math.max(...primaryStacked.ys.map(y => y.values[i]));
1123
- const secondaryVal = Math.max(...secondaryStacked.ys.map(y => y.values[i]));
1333
+ const primaryDataMax = Math.max(...primaryYScaleDomainValues.map(val => val.max));
1334
+ const secondaryDataMax = Math.max(...secondaryYScaleDomainValues.map(val => val.max));
1335
+ for (let i = 0; i < primaryYScaleDomainValues.length; i++) {
1336
+ const primaryVal = primaryYScaleDomainValues[i].max;
1337
+ const secondaryVal = secondaryYScaleDomainValues[i].max;
1124
1338
  const primaryRatio = primaryDataMax != 0 ? primaryVal / primaryDataMax : 0;
1125
1339
  const secondaryRatio = secondaryDataMax != 0 ? secondaryVal / secondaryDataMax : 0;
1126
1340
  const multVal = primaryRatio + secondaryRatio;
@@ -1129,10 +1343,18 @@ export var Chart;
1129
1343
  }
1130
1344
  }
1131
1345
  }
1132
- const primaryYDomain = yDomain(isStacked ? stack(primaryData) : primaryData, scaleDomainMultiple);
1346
+ const primaryYDomain = [
1347
+ Math.min(...primaryYScaleDomainValues.map(val => val.min)),
1348
+ Math.max(...primaryYScaleDomainValues.map(val => val.max)) *
1349
+ scaleDomainMultiple,
1350
+ ];
1133
1351
  //Figuring out the best tick count to fit the two data srouces
1134
1352
  const yScalePrimaryProto = scaleLinear(primaryYDomain, scaleRange);
1135
- const yScaleSecondaryProto = scaleLinear(yDomain(isStacked ? stack(secondaryData) : secondaryData, scaleDomainMultiple), scaleRange);
1353
+ const yScaleSecondaryProto = scaleLinear([
1354
+ Math.min(...secondaryYScaleDomainValues.map(val => val.min)),
1355
+ Math.max(...secondaryYScaleDomainValues.map(val => val.max)) *
1356
+ scaleDomainMultiple,
1357
+ ], scaleRange);
1136
1358
  const tickCount = Math.max(5, yScalePrimaryProto.ticks(5).length, yScaleSecondaryProto.ticks(5).length);
1137
1359
  //Finding a domain for the secondary data such that it will result in round tick values when matched with the primary ticks
1138
1360
  const secondaryTicksProto = yScaleSecondaryProto
@@ -1174,17 +1396,183 @@ export var Chart;
1174
1396
  yTicks,
1175
1397
  };
1176
1398
  }
1399
+ function calcYScaleDomainValues(data, isStacked, forSecondary) {
1400
+ const possiblyStackedYs = data.ys.map((y, yIndex) => {
1401
+ //Handle stacking
1402
+ return isStacked
1403
+ ? y.values.map((val, xIndex) => {
1404
+ let prevRunningTotal = 0;
1405
+ for (let yI = 0; yI < yIndex; yI++) {
1406
+ if (checkIfSecondary(data, yIndex, xIndex, false) != forSecondary) {
1407
+ continue;
1408
+ }
1409
+ const addVal = data.ys[yI].values[xIndex];
1410
+ //Only stack values of the same sign
1411
+ if (addVal < 0 == val < 0) {
1412
+ prevRunningTotal += addVal;
1413
+ }
1414
+ }
1415
+ return val + prevRunningTotal;
1416
+ })
1417
+ : y.values;
1418
+ });
1419
+ const suppYs = data.supplementaryYs;
1420
+ let possiblyStackedSupYs = [];
1421
+ if (suppYs && suppYs.length > 0) {
1422
+ possiblyStackedSupYs = suppYs.map((y, yIndex) => {
1423
+ //Handle stacking
1424
+ return isStacked
1425
+ ? y.values.map((val, xIndex) => {
1426
+ let prevRunningTotal = 0;
1427
+ for (let yI = 0; yI < yIndex; yI++) {
1428
+ if (checkIfSecondary(data, yIndex, xIndex, true) !=
1429
+ forSecondary ||
1430
+ suppYs[yI].supplementalIndex != y.supplementalIndex) {
1431
+ continue;
1432
+ }
1433
+ const addVal = suppYs[yI].values[xIndex];
1434
+ //Only stack values of the same sign
1435
+ if (addVal < 0 == val < 0) {
1436
+ prevRunningTotal += addVal;
1437
+ }
1438
+ }
1439
+ return val + prevRunningTotal;
1440
+ })
1441
+ : y.values;
1442
+ });
1443
+ }
1444
+ const scaleRange = [];
1445
+ for (let i = 0; i < data.x.length; i++) {
1446
+ const maxNormY = Math.max(...possiblyStackedYs.map((y, yIndex) => {
1447
+ if (checkIfSecondary(data, yIndex, i, false) != forSecondary) {
1448
+ return 0;
1449
+ }
1450
+ return y[i];
1451
+ }));
1452
+ const minNormY = Math.min(...possiblyStackedYs.map((y, yIndex) => {
1453
+ if (checkIfSecondary(data, yIndex, i, false) != forSecondary) {
1454
+ return 0;
1455
+ }
1456
+ return y[i];
1457
+ }));
1458
+ const maxSupY = suppYs
1459
+ ? Math.max(...possiblyStackedSupYs.map((y, yIndex) => {
1460
+ if (checkIfSecondary(data, yIndex, i, true) != forSecondary) {
1461
+ return 0;
1462
+ }
1463
+ return y[i];
1464
+ }))
1465
+ : 0;
1466
+ const minSupY = suppYs
1467
+ ? Math.min(...possiblyStackedSupYs.map((y, yIndex) => {
1468
+ if (checkIfSecondary(data, yIndex, i, true) != forSecondary) {
1469
+ return 0;
1470
+ }
1471
+ return y[i];
1472
+ }))
1473
+ : 0;
1474
+ const max = maxNormY > 0 && maxNormY > maxSupY
1475
+ ? maxNormY
1476
+ : maxSupY > 0
1477
+ ? maxSupY
1478
+ : 0;
1479
+ const min = minNormY < 0 && minNormY < minSupY
1480
+ ? minNormY
1481
+ : minSupY < 0
1482
+ ? minSupY
1483
+ : 0;
1484
+ scaleRange.push({ max, min });
1485
+ }
1486
+ return scaleRange;
1487
+ }
1488
+ function getClusterCountWithSupp(data) {
1489
+ const suppYs = data.supplementaryYs;
1490
+ if (suppYs) {
1491
+ return Math.max(...suppYs.map(suppY => suppY.supplementalIndex)) + 2;
1492
+ }
1493
+ return 1;
1494
+ }
1495
+ function calculateXValueAndOffsetForBars(binSize, clusterCount, matchingIndex, originalXValue) {
1496
+ const width = (binSize - (clusterCount - 1) * SMALL_PADDING) / clusterCount;
1497
+ const offset = matchingIndex * (width + SMALL_PADDING);
1498
+ const xValue = originalXValue + offset;
1499
+ return {
1500
+ width,
1501
+ xValue,
1502
+ };
1503
+ }
1504
+ function calculateHorizontalBarPath(leftSideRound, rightSideRound, xValue, yValue, horR, verR, width) {
1505
+ if (leftSideRound && rightSideRound) {
1506
+ //Both-sides rounding variation
1507
+ const pathD = `
1508
+ M ${xValue + horR},${yValue}
1509
+ h ${width - horR * 2}
1510
+ q${horR},0 ${horR},${verR}
1511
+ v ${HORIZONTAL_BAR_HEIGHT - verR * 2}
1512
+ q0,${verR} -${horR},${verR}
1513
+ h ${-(width - horR * 2)}
1514
+ q-${horR},0 -${horR},-${verR}
1515
+ v -${HORIZONTAL_BAR_HEIGHT - verR * 2}
1516
+ q0,-${verR} ${horR},-${verR}
1517
+ Z
1518
+ `;
1519
+ return pathD;
1520
+ }
1521
+ if (leftSideRound) {
1522
+ //Left-side rounding variation
1523
+ const pathD = `
1524
+ M ${xValue + horR},${yValue}
1525
+ h ${width - horR}
1526
+ v ${HORIZONTAL_BAR_HEIGHT}
1527
+ h ${-(width - horR)}
1528
+ q-${horR},0 -${horR},-${verR}
1529
+ v -${HORIZONTAL_BAR_HEIGHT - verR * 2}
1530
+ q0,-${verR} ${horR},-${verR}
1531
+ Z
1532
+ `;
1533
+ return pathD;
1534
+ }
1535
+ if (rightSideRound) {
1536
+ //Right-side rounding variation
1537
+ const pathD = `
1538
+ M ${xValue},${yValue}
1539
+ h ${width - horR}
1540
+ q${horR},0 ${horR},${verR}
1541
+ v ${HORIZONTAL_BAR_HEIGHT - verR * 2}
1542
+ q0,${verR} -${horR},${verR}
1543
+ h ${-(width - horR)}
1544
+ Z
1545
+ `;
1546
+ return pathD;
1547
+ }
1548
+ //No-rounding variation
1549
+ const pathD = `
1550
+ M ${xValue},${yValue}
1551
+ h ${width}
1552
+ v ${HORIZONTAL_BAR_HEIGHT}
1553
+ h ${-width}
1554
+ v -${HORIZONTAL_BAR_HEIGHT}
1555
+ Z
1556
+ `;
1557
+ return pathD;
1558
+ }
1177
1559
  function calcXScalesAndTicks(data, dimensions, pipe, secondaryPipe, isStacked, config) {
1178
1560
  const primaryData = convertDataToJustOneValueType(data, false);
1179
1561
  const secondaryData = convertDataToJustOneValueType(data, true);
1180
- const largestLabelLength = Math.max(...data.ys.map((y, yIndex) => Math.max(...y.values.map((val, xIndex) => (checkIfSecondary(data, yIndex, xIndex)
1181
- ? secondaryPipe.transform(y.values[xIndex])
1182
- : pipe.transform(y.values[xIndex])).length))));
1562
+ const suppYs = data.supplementaryYs;
1563
+ const largestLabelLength = Math.max(...data.ys.map((y, yIndex) => Math.max(...y.values.map((val, xIndex) => (checkIfSecondary(data, yIndex, xIndex, false)
1564
+ ? secondaryPipe.transform(val)
1565
+ : pipe.transform(val)).length))), ...(suppYs ?? []).map((y, yIndex) => Math.max(...y.values.map((val, xIndex) => (checkIfSecondary(data, yIndex, xIndex, true)
1566
+ ? secondaryPipe.transform(val)
1567
+ : pipe.transform(val)).length))));
1183
1568
  const scaleRange = xRangeHorizontal(dimensions, data, largestLabelLength, config);
1184
1569
  //Simpler path for data w/o secondaries
1185
1570
  if (!secondaryData.ys.find(y => y.values.find(val => val != 0))) {
1186
- const data = isStacked ? stack(primaryData) : primaryData;
1187
- const xScale = scaleLinear(yDomain(data), scaleRange);
1571
+ const yScaleDomainValues = calcYScaleDomainValues(primaryData, isStacked, false);
1572
+ const xScale = scaleLinear([
1573
+ Math.min(...yScaleDomainValues.map(val => val.min)),
1574
+ Math.max(...yScaleDomainValues.map(val => val.max)),
1575
+ ], scaleRange);
1188
1576
  const xTicks = xScale.ticks(5).map(tick => ({
1189
1577
  x: xScale(tick),
1190
1578
  label: pipe.transform(tick),
@@ -1199,26 +1587,35 @@ export var Chart;
1199
1587
  xTicks,
1200
1588
  };
1201
1589
  }
1590
+ const primaryYScaleDomainValues = calcYScaleDomainValues(data, isStacked, false);
1591
+ const secondaryYScaleDomainValues = calcYScaleDomainValues(data, isStacked, true);
1202
1592
  let scaleDomainMultiple = 1;
1203
1593
  //Calculating how much we need to multiple the domain by to 'fit' both axes' data
1204
1594
  if (isStacked) {
1205
- //Stacking each individual data type makes finding the max easier
1206
- const primaryStacked = stack(primaryData);
1207
- const secondaryStacked = stack(secondaryData);
1208
- const primaryDataMax = Math.max(...primaryStacked.ys.map(y => Math.max(...y.values)));
1209
- const secondaryDataMax = Math.max(...secondaryStacked.ys.map(y => Math.max(...y.values)));
1210
- for (let i = 0; i < primaryStacked.x.length; i++) {
1211
- const primaryVal = Math.max(...primaryStacked.ys.map(y => y.values[i]));
1212
- const secondaryVal = Math.max(...secondaryStacked.ys.map(y => y.values[i]));
1213
- const multVal = primaryVal / primaryDataMax + secondaryVal / secondaryDataMax;
1595
+ const primaryDataMax = Math.max(...primaryYScaleDomainValues.map(val => val.max));
1596
+ const secondaryDataMax = Math.max(...secondaryYScaleDomainValues.map(val => val.max));
1597
+ for (let i = 0; i < primaryYScaleDomainValues.length; i++) {
1598
+ const primaryVal = primaryYScaleDomainValues[i].max;
1599
+ const secondaryVal = secondaryYScaleDomainValues[i].max;
1600
+ const primaryRatio = primaryDataMax != 0 ? primaryVal / primaryDataMax : 0;
1601
+ const secondaryRatio = secondaryDataMax != 0 ? secondaryVal / secondaryDataMax : 0;
1602
+ const multVal = primaryRatio + secondaryRatio;
1214
1603
  if (multVal > scaleDomainMultiple) {
1215
1604
  scaleDomainMultiple = multVal;
1216
1605
  }
1217
1606
  }
1218
1607
  }
1219
- const primaryXDomain = yDomain(isStacked ? stack(primaryData) : primaryData, scaleDomainMultiple);
1608
+ const primaryXDomain = [
1609
+ Math.min(...primaryYScaleDomainValues.map(val => val.min)),
1610
+ Math.max(...primaryYScaleDomainValues.map(val => val.max)) *
1611
+ scaleDomainMultiple,
1612
+ ];
1220
1613
  const xScalePrimaryProto = scaleLinear(primaryXDomain, scaleRange);
1221
- const xScaleSecondaryProto = scaleLinear(yDomain(isStacked ? stack(secondaryData) : secondaryData, scaleDomainMultiple), scaleRange);
1614
+ const xScaleSecondaryProto = scaleLinear([
1615
+ Math.min(...secondaryYScaleDomainValues.map(val => val.min)),
1616
+ Math.max(...secondaryYScaleDomainValues.map(val => val.max)) *
1617
+ scaleDomainMultiple,
1618
+ ], scaleRange);
1222
1619
  const tickCount = Math.max(5, xScalePrimaryProto.ticks(5).length, xScaleSecondaryProto.ticks(5).length);
1223
1620
  //Finding a domain for the secondary data such that it will result in round tick values when matched with the primary ticks
1224
1621
  const secondaryTicksProto = xScaleSecondaryProto
@@ -1303,7 +1700,7 @@ export var Chart;
1303
1700
  }, 0);
1304
1701
  }
1305
1702
  function findSubIndex(value, input, binSize, subBinCount) {
1306
- const subBinSize = (binSize - (subBinCount - 1 * SMALL_PADDING)) / subBinCount;
1703
+ const subBinSize = (binSize - (subBinCount - 1) * SMALL_PADDING) / subBinCount;
1307
1704
  const centerIndex = subBinCount / 2 - 0.5;
1308
1705
  let closestIndex = 0;
1309
1706
  let closenessVal = -1;
@@ -1333,14 +1730,24 @@ export var Chart;
1333
1730
  }
1334
1731
  return closestIndex;
1335
1732
  }
1336
- function getBarYInfo(data, yIndex, xIndex, scale, isStacked) {
1733
+ function getBarYInfo(data, yIndex, xIndex, scale, isStacked, isSupplementary = false) {
1337
1734
  const zeroVal = scale(0, true);
1338
- const scaleValue = scale(data.ys[yIndex].values[xIndex], checkIfSecondary(data, yIndex, xIndex));
1735
+ const yData = getMainOrSuppY(data, yIndex, isSupplementary);
1736
+ const scaleValue = scale(yData.values[xIndex], checkIfSecondary(data, yIndex, xIndex, isSupplementary));
1339
1737
  if (scaleValue > zeroVal) {
1340
1738
  let prevBarHeights = 0;
1341
1739
  if (isStacked) {
1342
1740
  for (let i = 0; i < yIndex; i++) {
1343
- const checkValue = scale(data.ys[i].values[xIndex], checkIfSecondary(data, i, xIndex));
1741
+ const checkData = getMainOrSuppY(data, i, isSupplementary);
1742
+ //Both yData and checkData are definitely SupplementaryDataYs if isSupplementary is true, but they don't realize it
1743
+ if (isSupplementary &&
1744
+ 'supplementalIndex' in yData &&
1745
+ 'supplementalIndex' in checkData) {
1746
+ if (yData.supplementalIndex != checkData.supplementalIndex) {
1747
+ continue;
1748
+ }
1749
+ }
1750
+ const checkValue = scale(checkData.values[xIndex], checkIfSecondary(data, i, xIndex, isSupplementary));
1344
1751
  //Skip positive values
1345
1752
  if (checkValue < zeroVal) {
1346
1753
  continue;
@@ -1355,7 +1762,16 @@ export var Chart;
1355
1762
  let prevBarHeights = 0;
1356
1763
  if (isStacked) {
1357
1764
  for (let i = 0; i < yIndex; i++) {
1358
- const checkValue = scale(data.ys[i].values[xIndex], checkIfSecondary(data, i, xIndex));
1765
+ const checkData = getMainOrSuppY(data, i, isSupplementary);
1766
+ //Both yData and checkData are definitely SupplementaryDataYs if isSupplementary is true, but they don't realize it
1767
+ if (isSupplementary &&
1768
+ 'supplementalIndex' in yData &&
1769
+ 'supplementalIndex' in checkData) {
1770
+ if (yData.supplementalIndex != checkData.supplementalIndex) {
1771
+ continue;
1772
+ }
1773
+ }
1774
+ const checkValue = scale(checkData.values[xIndex], checkIfSecondary(data, i, xIndex, isSupplementary));
1359
1775
  //Skip negative values
1360
1776
  if (checkValue > zeroVal) {
1361
1777
  continue;
@@ -1368,14 +1784,44 @@ export var Chart;
1368
1784
  const height = zeroVal - yValue - prevBarHeights;
1369
1785
  return { yValue, height };
1370
1786
  }
1371
- function getBarXInfo(data, yIndex, xIndex, scale, isStacked) {
1787
+ function getSuppBarYInfoViaYIndex(data, yIndex, suppIndex, xIndex, scale, isStacked) {
1788
+ const suppYs = data.supplementaryYs;
1789
+ if (!suppYs || suppYs.length == 0) {
1790
+ return { yValue: 0, height: 0 };
1791
+ }
1792
+ for (let i = 0; i < suppYs.length; i++) {
1793
+ if (suppYs[i].associatedYIndex == yIndex &&
1794
+ suppYs[i].supplementalIndex == suppIndex) {
1795
+ return getBarYInfo(data, i, xIndex, scale, isStacked, true);
1796
+ }
1797
+ }
1798
+ return { yValue: 0, height: 0 };
1799
+ }
1800
+ function getMainOrSuppY(data, yIndex, isSupplementary) {
1801
+ const suppYs = data.supplementaryYs;
1802
+ if (suppYs && isSupplementary) {
1803
+ return suppYs[yIndex];
1804
+ }
1805
+ return data.ys[yIndex];
1806
+ }
1807
+ function getBarXInfo(data, yIndex, xIndex, scale, isStacked, isSupplementary = false) {
1372
1808
  const zeroVal = scale(0, true);
1373
- const scaleValue = scale(data.ys[yIndex].values[xIndex], checkIfSecondary(data, yIndex, xIndex));
1809
+ const yData = getMainOrSuppY(data, yIndex, isSupplementary);
1810
+ const scaleValue = scale(yData.values[xIndex], checkIfSecondary(data, yIndex, xIndex, isSupplementary));
1374
1811
  if (scaleValue < zeroVal) {
1375
1812
  let prevBarWidths = 0;
1376
1813
  if (isStacked) {
1377
1814
  for (let i = 0; i < yIndex; i++) {
1378
- const checkVal = scale(data.ys[i].values[xIndex], checkIfSecondary(data, i, xIndex));
1815
+ const checkData = getMainOrSuppY(data, i, isSupplementary);
1816
+ //Both yData and checkData are definitely SupplementaryDataYs if isSupplementary is true, but they don't realize it
1817
+ if (isSupplementary &&
1818
+ 'supplementalIndex' in yData &&
1819
+ 'supplementalIndex' in checkData) {
1820
+ if (yData.supplementalIndex != checkData.supplementalIndex) {
1821
+ continue;
1822
+ }
1823
+ }
1824
+ const checkVal = scale(checkData.values[xIndex], checkIfSecondary(data, i, xIndex, isSupplementary));
1379
1825
  //Skip positive values
1380
1826
  if (checkVal > zeroVal) {
1381
1827
  continue;
@@ -1390,7 +1836,16 @@ export var Chart;
1390
1836
  let prevBarWidths = 0;
1391
1837
  if (isStacked) {
1392
1838
  for (let i = 0; i < yIndex; i++) {
1393
- const checkVal = scale(data.ys[i].values[xIndex], checkIfSecondary(data, i, xIndex));
1839
+ const checkData = getMainOrSuppY(data, i, isSupplementary);
1840
+ //Both yData and checkData are definitely SupplementaryDataYs if isSupplementary is true, but they don't realize it
1841
+ if (isSupplementary &&
1842
+ 'supplementalIndex' in yData &&
1843
+ 'supplementalIndex' in checkData) {
1844
+ if (yData.supplementalIndex != checkData.supplementalIndex) {
1845
+ continue;
1846
+ }
1847
+ }
1848
+ const checkVal = scale(checkData.values[xIndex], checkIfSecondary(data, i, xIndex, isSupplementary));
1394
1849
  //Skip negative values
1395
1850
  if (checkVal < zeroVal) {
1396
1851
  continue;
@@ -1402,13 +1857,26 @@ export var Chart;
1402
1857
  const width = scaleValue - zeroVal;
1403
1858
  return { xValue, width };
1404
1859
  }
1405
- function checkIfSecondary(data, yIndex, xIndex) {
1860
+ function getSuppBarXInfoViaYIndex(data, yIndex, suppIndex, xIndex, scale, isStacked) {
1861
+ const suppYs = data.supplementaryYs;
1862
+ if (!suppYs || suppYs.length == 0) {
1863
+ return { xValue: 0, width: 0 };
1864
+ }
1865
+ for (let i = 0; i < suppYs.length; i++) {
1866
+ if (suppYs[i].associatedYIndex == yIndex &&
1867
+ suppYs[i].supplementalIndex == suppIndex) {
1868
+ return getBarXInfo(data, i, xIndex, scale, isStacked, true);
1869
+ }
1870
+ }
1871
+ return { xValue: 0, width: 0 };
1872
+ }
1873
+ function checkIfSecondary(data, yIndex, xIndex, isSupplementary = false) {
1406
1874
  if (data.type == 'labeled') {
1407
1875
  if (data.x[xIndex].isSecondary == true) {
1408
1876
  return true;
1409
1877
  }
1410
1878
  }
1411
- return data.ys[yIndex].isSecondary == true;
1879
+ return getMainOrSuppY(data, yIndex, isSupplementary).isSecondary == true;
1412
1880
  }
1413
1881
  // stack returns a new data where each set of yValues is stacked
1414
1882
  // on top of the previous.
@@ -1538,4 +2006,4 @@ export var Chart;
1538
2006
  };
1539
2007
  }
1540
2008
  })(Chart || (Chart = {}));
1541
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chart.js","sourceRoot":"","sources":["../../../../../../projects/riv/src/lib/visualization/chart/chart.ts"],"names":[],"mappings":"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","sourcesContent":["import { CurrencyPipe } from '@angular/common';\nimport { ScaleLinear, scaleLinear, ScaleTime, scaleUtc } from 'd3-scale';\nimport { arc, area, line, pie } from 'd3-shape';\nimport { utcFormat } from 'd3-time-format';\nimport { isNumber } from 'lodash';\nimport { DaysPipe } from '../../format/pipes/days.pipe';\nimport { NumberPipe } from '../../format/pipes/number.pipe';\nimport { PercentagePipe } from '../../format/pipes/percentage.pipe';\nimport { SmallCurrencyPipe } from '../../format/pipes/small-currency.pipe';\n\nexport namespace Chart {\n  export const defaultColorPalette = [\n    //Base colors\n    '--baja-blast-50',\n    '--teal-diamond-50',\n    '--fyre-50',\n    '--tang-50',\n    '--purp-60',\n    '--rosi-70',\n    //Shift lighter from base by -20\n    '--baja-blast-30',\n    '--teal-diamond-30',\n    '--fyre-30',\n    '--tang-30',\n    '--purp-40',\n    '--rosi-50',\n    //Shift darker from base by +20\n    '--baja-blast-70',\n    '--teal-diamond-70',\n    '--fyre-70',\n    '--tang-70',\n    '--purp-80',\n    '--rosi-90',\n  ];\n\n  export function chart(config: Config, data: Data, dimensions: Dimensions) {\n    return config.type == 'line'\n      ? lines(config, data, dimensions)\n      : config.type == 'area'\n      ? areas(config, data, dimensions)\n      : config.type == 'donut'\n      ? arcs(config, data, dimensions)\n      : config.type == 'horizontal-bar'\n      ? horizontalBars(config, data, dimensions)\n      : config.type == 'bar'\n      ? bars(config, data, dimensions)\n      : config.type == 'waterfall'\n      ? waterfall(config, data, dimensions)\n      : emptyChart;\n  }\n  export function lines(\n    config: Config,\n    allData: Data,\n    dimensions: Dimensions,\n  ): RenderedChart {\n    const { data: hiddenData, visibleIndices } = hide(allData);\n    if (hiddenData.type == 'labeled') {\n      // eslint-disable-next-line no-console\n      console.warn(\n        \"Heads up! Labeled series aren't currently supported for line charts\",\n      );\n      return emptyChart;\n    }\n    //This assignment makes typescript recognize the actual type (TimeseriesData)\n    const data = hiddenData;\n    const xScale = scaleUtc(timeseriesDomain(data), xRange(dimensions, config));\n    const format = (date: Date) =>\n      formatedDate(config.dateFormat || 'day', date);\n\n    const tickCount = getTickCount(dimensions, config);\n    const xTicks = generateXTicks(data, xScale, tickCount, format);\n\n    const { pipe, fullPipe } = getPipes(config.valueType);\n    const { pipe: secondaryPipe, fullPipe: secondaryFullPipe } =\n      config.secondaryValueType\n        ? getPipes(config.secondaryValueType)\n        : {\n            pipe,\n            fullPipe,\n          };\n\n    const { scale, yTicks } = calcYScalesAndTicks(\n      data,\n      dimensions,\n      pipe,\n      secondaryPipe,\n      false,\n      config,\n    );\n\n    const colors = visibleIndices.map(\n      i => config.colors[i % config.colors.length],\n    );\n    const indices = data.x.map((_, i) => i);\n    const lines =\n      data.x.length > 1\n        ? data.ys.map(y =>\n            line<number>(\n              i => xScale(data.x[i]),\n              i => scale(y.values[i], y.isSecondary),\n            )(indices),\n          )\n        : [];\n    const circles =\n      data.x.length === 1\n        ? data.ys.map((ySeries, i) => ({\n            cx: xScale(data.x[0]),\n            cy: scale(ySeries.values[0], checkIfSecondary(data, i, 0)),\n          }))\n        : [];\n\n    const yOffset = SMALL_PADDING;\n    const dataLabels: DataLabel[] = data.ys.flatMap((y, yIndex) => {\n      const subLabels: DataLabel[] = y.values.map((val, xIndex) => ({\n        label:\n          (checkIfSecondary(data, yIndex, xIndex)\n            ? secondaryPipe.transform(val)\n            : pipe.transform(val)) ?? '',\n        yPos: scale(val, checkIfSecondary(data, yIndex, xIndex)) - yOffset,\n        xPos: xScale(data.x[xIndex]),\n        anchor: 'middle',\n      }));\n      return subLabels;\n    });\n\n    function hover(pos: { rect: DOMRect; x: number; y: number }) {\n      const xIndex = findNearestIndex(data.x, xScale.invert(pos.x).getTime());\n      const x = xScale(data.x[xIndex]);\n      const visibleYIndex = findNearestIndexWithSecondary(\n        data.ys.map((y, i) => ({\n          value: y.values[xIndex],\n          isSecondary: checkIfSecondary(data, i, xIndex),\n        })),\n        pos.y,\n        scale,\n      );\n      const yIndex = visibleIndices[visibleYIndex];\n      const ys = data.ys.map((y, i) =>\n        scale(y.values[xIndex], checkIfSecondary(data, i, xIndex)),\n      );\n\n      const format = (date: Date) =>\n        formatedDate(config.dateFormat || 'day', date);\n\n      const anchor = new DOMRect(\n        pos.rect.x + x,\n        pos.rect.y + ys[visibleYIndex],\n        8,\n        0,\n      );\n      return {\n        x,\n        xIndex,\n        ys,\n        yIndex,\n        visibleYIndex,\n        tooltip: {\n          anchor,\n          date: format(new Date(data.x[xIndex])),\n          metrics: data.ys\n            .map((y, index) => ({\n              color: colors[index % colors.length],\n              label: y.label,\n              value:\n                (checkIfSecondary(data, index, xIndex)\n                  ? secondaryFullPipe.transform(y.values[xIndex])\n                  : fullPipe.transform(y.values[xIndex])) ?? '-',\n            }))\n            .filter((_, i) => config.groupedTooltip || i == visibleYIndex),\n        },\n      };\n    }\n\n    return {\n      xTicks,\n      yTicks,\n      colors,\n      lines,\n      circles,\n      hover,\n      bars: [],\n      areas: [],\n      arcs: [],\n      horizontalBars: [],\n      dataLabels,\n      waterfallLines: [],\n    };\n  }\n\n  export function areas(\n    config: Config,\n    allData: Data,\n    dimensions: Dimensions,\n  ): RenderedChart {\n    const { data: uncheckedData, visibleIndices } = hide(allData);\n    if (uncheckedData.type == 'labeled') {\n      // eslint-disable-next-line no-console\n      console.warn(\n        \"Heads up! Labeled series aren't currently supported for area charts\",\n      );\n      return emptyChart;\n    }\n    if (config.showDataLabels == true) {\n      // eslint-disable-next-line no-console\n      console.warn(\n        \"Heads up! Data labels aren't supported for any stacked chart type\",\n      );\n      return emptyChart;\n    }\n    //This assignment makes typescript recognize the actual type (TimeseriesData)\n    const data = uncheckedData;\n    const xScale = scaleUtc(timeseriesDomain(data), xRange(dimensions, config));\n    const format = (date: Date) =>\n      formatedDate(config.dateFormat || 'day', date);\n    const tickCount = getTickCount(dimensions, config);\n    const xTicks = generateXTicks(data, xScale, tickCount, format);\n\n    const { pipe, fullPipe } = getPipes(config.valueType);\n    const { pipe: secondaryPipe, fullPipe: secondaryFullPipe } =\n      config.secondaryValueType\n        ? getPipes(config.secondaryValueType)\n        : {\n            pipe,\n            fullPipe,\n          };\n\n    const { scale, yTicks } = calcYScalesAndTicks(\n      data,\n      dimensions,\n      pipe,\n      secondaryPipe,\n      true,\n      config,\n    );\n    const zeroAxisPosVal = scale(0, true);\n\n    const indices = data.x.map((_, i) => i);\n    const colors = visibleIndices.map(\n      i => config.colors[i % config.colors.length],\n    );\n    const areas = data.ys.map((y, yIndex) =>\n      area<number>(\n        i => xScale(data.x[i]),\n        i => getBarYInfo(data, yIndex, i, scale, true).yValue,\n        i =>\n          getBarYInfo(data, yIndex, i, scale, true).yValue +\n          getBarYInfo(data, yIndex, i, scale, true).height,\n      )(indices),\n    );\n\n    function hover(pos: { rect: DOMRect; x: number; y: number }) {\n      const xIndex = findNearestIndex(data.x, xScale.invert(pos.x).getTime());\n      const x = xScale(data.x[xIndex]);\n      const fullYs = data.ys.map((_, mapYIndex) =>\n        getBarYInfo(data, mapYIndex, xIndex, scale, true),\n      );\n      const ys = fullYs.map(y => y.yValue);\n      //This is the ys array, but shifted so that the y position for negative values is away from the axis (for the hover circles)\n      const shiftedYs = fullYs.map(y => {\n        if (y.yValue >= zeroAxisPosVal) {\n          return y.yValue + y.height;\n        }\n        return y.yValue;\n      });\n      const yPosSign = zeroAxisPosVal - pos.y;\n      let visibleYIndex = -1;\n      if (yPosSign < 0 && data.ys.find(y => y.values.find(val => val < 0))) {\n        for (let i = ys.length - 1; i >= 0; i--) {\n          if (ys[i] >= zeroAxisPosVal && ys[i] < pos.y) {\n            visibleYIndex = i;\n            break;\n          }\n        }\n      } else {\n        for (let i = 0; i < ys.length; i++) {\n          if (ys[i] <= zeroAxisPosVal && ys[i] < pos.y) {\n            visibleYIndex = i;\n            break;\n          }\n        }\n      }\n      if (visibleYIndex == -1) {\n        if (pos.y < zeroAxisPosVal) {\n          visibleYIndex = ys.indexOf(Math.min(...ys));\n        }\n        if (pos.y > zeroAxisPosVal) {\n          visibleYIndex = ys.indexOf(Math.max(...ys));\n        }\n      }\n      const yIndex = visibleIndices[visibleYIndex];\n      const anchor = new DOMRect(\n        pos.rect.x + x,\n        pos.rect.y + shiftedYs[visibleYIndex],\n        SMALL_PADDING,\n        0,\n      );\n      return {\n        x,\n        xIndex,\n        ys: shiftedYs,\n        yIndex,\n        visibleYIndex,\n        tooltip: {\n          anchor,\n          date: utcFormat('%B %d, %Y')(new Date(data.x[xIndex])),\n          metrics: data.ys\n            .map((y, index) => ({\n              color: colors[index % colors.length],\n              label: y.label,\n              value:\n                (checkIfSecondary(data, index, xIndex)\n                  ? secondaryFullPipe.transform(y.values[xIndex])\n                  : fullPipe.transform(y.values[xIndex])) ?? '-',\n            }))\n            .filter((_, i) => config.groupedTooltip || i == visibleYIndex),\n        },\n      };\n    }\n\n    return {\n      xTicks,\n      yTicks,\n      colors,\n      areas,\n      lines: [],\n      circles: [],\n      hover,\n      bars: [],\n      arcs: [],\n      horizontalBars: [],\n      dataLabels: [],\n      waterfallLines: [],\n    };\n  }\n\n  export function bars(\n    config: BarConfig,\n    allData: Data,\n    dimensions: Dimensions,\n  ): RenderedChart {\n    const { data: uncheckedData, visibleIndices } = hide(allData);\n    if (uncheckedData.type == 'labeled') {\n      // eslint-disable-next-line no-console\n      console.warn(\n        \"Heads up! Labeled series aren't currently supported for vertical bar charts\",\n      );\n      return emptyChart;\n    }\n    if (config.showDataLabels == true && config.groupingType == 'stacked') {\n      // eslint-disable-next-line no-console\n      console.warn(\n        \"Heads up! Data labels aren't supported for any stacked chart type\",\n      );\n      return emptyChart;\n    }\n    //This assignment makes typescript recognize the actual type (TimeseriesData)\n    const data = uncheckedData;\n    const { range: xRange, binSize } = barXRange(dimensions, data, config);\n    const halfBinSize = binSize / 2;\n    const xScale = scaleUtc(timeseriesDomain(data), xRange);\n    const format = (date: Date) =>\n      formatedDate(config.dateFormat || 'day', date);\n    const tickCount = getTickCount(dimensions, config);\n    const xTicks = generateXTicks(data, xScale, tickCount, format);\n\n    const { pipe, fullPipe } = getPipes(config.valueType);\n    const { pipe: secondaryPipe, fullPipe: secondaryFullPipe } =\n      config.secondaryValueType\n        ? getPipes(config.secondaryValueType)\n        : {\n            pipe,\n            fullPipe,\n          };\n\n    const { scale, yTicks } = calcYScalesAndTicks(\n      data,\n      dimensions,\n      pipe,\n      secondaryPipe,\n      config.groupingType == 'stacked',\n      config,\n    );\n\n    const colors = visibleIndices.map(\n      i => config.colors[i % config.colors.length],\n    );\n    const bars = data.ys.map((y, yIndex) =>\n      y.values.map((_, index) => {\n        const { yValue, height } = getBarYInfo(\n          data,\n          yIndex,\n          index,\n          scale,\n          config.groupingType == 'stacked',\n        );\n        let xValue = xScale(data.x[index]) - halfBinSize;\n        let width = binSize;\n        if (config.groupingType == 'clustered') {\n          width =\n            (binSize - (data.ys.length - 1) * SMALL_PADDING) / data.ys.length;\n          const offset = yIndex * (width + SMALL_PADDING);\n          xValue = xValue + offset;\n        }\n        return {\n          x: xValue,\n          y: yValue,\n          width,\n          height,\n        };\n      }),\n    );\n    const zeroAxisPosVal = scale(0, true);\n    const dataLabels: DataLabel[] = data.ys.flatMap((y, yIndex) => {\n      const subLabels: DataLabel[] = y.values.map((val, xIndex) => {\n        const isNegativeBar =\n          bars[yIndex][xIndex].y >= zeroAxisPosVal &&\n          bars[yIndex][xIndex].height > 0;\n        const yOffset = isNegativeBar\n          ? SMALL_PADDING + DATA_LABEL_HEIGHT + bars[yIndex][xIndex].height\n          : -SMALL_PADDING;\n        return {\n          label:\n            (checkIfSecondary(data, yIndex, xIndex)\n              ? secondaryPipe.transform(val)\n              : pipe.transform(val)) ?? '',\n          yPos: bars[yIndex][xIndex].y + yOffset,\n          xPos: bars[yIndex][xIndex].x + bars[yIndex][xIndex].width / 2,\n          anchor: 'middle',\n        };\n      });\n      return subLabels;\n    });\n\n    function hover(pos: { rect: DOMRect; x: number; y: number }) {\n      const xIndex = findNearestIndex(data.x, xScale.invert(pos.x).getTime());\n      const x = xScale(data.x[xIndex]);\n      const ys = data.ys.map(\n        (_, mapYIndex) =>\n          getBarYInfo(\n            data,\n            mapYIndex,\n            xIndex,\n            scale,\n            config.groupingType == 'stacked',\n          ).yValue,\n      );\n      const yPosSign = zeroAxisPosVal - pos.y;\n      let visibleYIndex = -1;\n      if (yPosSign < 0 && data.ys.find(y => y.values.find(val => val < 0))) {\n        for (let i = ys.length - 1; i >= 0; i--) {\n          if (ys[i] >= zeroAxisPosVal && ys[i] < pos.y) {\n            visibleYIndex = i;\n            break;\n          }\n        }\n      } else {\n        for (let i = 0; i < ys.length; i++) {\n          if (ys[i] <= zeroAxisPosVal && ys[i] < pos.y) {\n            visibleYIndex = i;\n            break;\n          }\n        }\n      }\n      if (config.groupingType == 'clustered') {\n        visibleYIndex = findSubIndex(x, pos.x, binSize, data.ys.length);\n      }\n      if (visibleYIndex == -1) {\n        if (pos.y < zeroAxisPosVal) {\n          visibleYIndex = ys.indexOf(Math.min(...ys));\n        }\n        if (pos.y > zeroAxisPosVal) {\n          visibleYIndex = ys.indexOf(Math.max(...ys));\n        }\n      }\n      const yIndex = visibleIndices[visibleYIndex];\n      const { yValue, height } = getBarYInfo(\n        data,\n        yIndex,\n        xIndex,\n        scale,\n        config.groupingType == 'stacked',\n      );\n      const anchor = new DOMRect(\n        pos.rect.x + bars[visibleYIndex][xIndex].x - SMALL_PADDING,\n        pos.rect.y + yValue,\n        bars[visibleYIndex][xIndex].width + SMALL_PADDING * 2,\n        height,\n      );\n      return {\n        x,\n        xIndex,\n        ys,\n        yIndex,\n        visibleYIndex,\n        tooltip: {\n          anchor,\n          date: utcFormat('%B %d, %Y')(new Date(data.x[xIndex])),\n          metrics: data.ys\n            .map((y, index) => ({\n              color: colors[index % colors.length],\n              label: y.label,\n              value:\n                (checkIfSecondary(data, index, xIndex)\n                  ? secondaryFullPipe.transform(y.values[xIndex])\n                  : fullPipe.transform(y.values[xIndex])) ?? '-',\n            }))\n            .filter((_, i) => config.groupedTooltip || i == visibleYIndex),\n        },\n      };\n    }\n\n    return {\n      xTicks,\n      yTicks,\n      colors,\n      bars,\n      lines: [],\n      circles: [],\n      areas: [],\n      hover,\n      arcs: [],\n      horizontalBars: [],\n      dataLabels,\n      waterfallLines: [],\n    };\n  }\n\n  export function horizontalBars(\n    config: BarConfig,\n    allData: Data,\n    dimensions: Dimensions,\n  ): RenderedChart {\n    //Some of this stuff gets confusing, because x and y are essentially inverted here\n    //  So, if you see a situation where a variable is named 'y', but referencing\n    //  'x' (or vice versa), that's why\n    const { data, visibleIndices } = hide(allData);\n    //'Metric' charts are a special case for horizontal bar charts, where each series is also a bucket (and vice versa)\n    const isMetricChart =\n      data.x.length == data.ys.length &&\n      data.ys.length ==\n        data.ys.filter(y => y.values.filter(val => val != 0).length == 1)\n          .length;\n    if (\n      config.showDataLabels == true &&\n      config.groupingType == 'stacked' &&\n      !isMetricChart\n    ) {\n      // eslint-disable-next-line no-console\n      console.warn(\n        \"Heads up! Data labels aren't supported for any stacked chart type\",\n      );\n      return emptyChart;\n    }\n    const { range: yRange } = barYRange(dimensions, data, config);\n    let yScale =\n      data.type == 'labeled'\n        ? scaleLinear(indexDomain(data), yRange)\n        : scaleUtc(timeseriesDomain(data), yRange);\n    const dateFormat = (date: Date) =>\n      formatedDate(config.dateFormat || 'day', date);\n    const { pipe, fullPipe } = getPipes(config.valueType);\n    const { pipe: secondaryPipe, fullPipe: secondaryFullPipe } =\n      config.secondaryValueType\n        ? getPipes(config.secondaryValueType)\n        : {\n            pipe,\n            fullPipe,\n          };\n    const yTicks = yScale.ticks(Math.max(data.x.length - 1, 1)).map(tick => ({\n      y: yScale(tick),\n      label: isNumber(tick)\n        ? data.type == 'labeled'\n          ? data.x[tick].label\n          : '-'\n        : dateFormat(tick),\n    }));\n\n    const { scale, xTicks } = calcXScalesAndTicks(\n      data,\n      dimensions,\n      pipe,\n      secondaryPipe,\n      config.groupingType == 'stacked',\n      config,\n    );\n    const zeroAxisPosVal = scale(0, true);\n    const colors = visibleIndices.map(\n      i => config.colors[i % config.colors.length],\n    );\n    const simplifiedHorizontalBars: {\n      xPos: number;\n      yPos: number;\n      width: number;\n    }[][] = [];\n    const horizontalBars = data.ys.map((y, yIndex) => {\n      const subSimpHorBars: {\n        xPos: number;\n        yPos: number;\n        width: number;\n      }[] = [];\n      const retVal = y.values.map((_, index) => {\n        const { xValue, width } = getBarXInfo(\n          data,\n          yIndex,\n          index,\n          scale,\n          config.groupingType == 'stacked',\n        );\n\n        let yValue =\n          yScale(data.type == 'labeled' ? index : data.x[index]) -\n          HORIZONTAL_BAR_HEIGHT * 1.5;\n        if (config.groupingType == 'clustered') {\n          const centerIndex = data.ys.length / 2 - 0.5;\n          const offset =\n            (yIndex - centerIndex) * (HORIZONTAL_BAR_HEIGHT + SMALL_PADDING);\n          yValue = yValue + offset;\n        }\n\n        const horR = Math.min(4, Math.floor(width / 2));\n        const verR = Math.min(4, Math.floor(HORIZONTAL_BAR_HEIGHT / 2));\n        subSimpHorBars.push({\n          xPos: xValue,\n          yPos: yValue,\n          width,\n        });\n        //Don't draw anything for zero-value bars\n        if (width == 0) {\n          return '';\n        }\n\n        const isPositive = data.ys[yIndex].values[index] > 0;\n        const hasAnyNegativeBars = data.ys\n          .map(y => y.values[index])\n          .find(val => val < 0);\n        const hasAnyPositiveBars = data.ys\n          .map(y => y.values[index])\n          .find(val => val > 0);\n\n        //These checks are to make sure we still round if all previous/later values are 0\n        const allLeftZero = isPositive\n          ? data.ys\n              .slice(0, yIndex)\n              .map(y => y.values[index])\n              .filter(val => val > 0).length == 0 && !hasAnyNegativeBars\n          : data.ys\n              .slice(yIndex + 1, data.ys.length)\n              .map(y => y.values[index])\n              .filter(val => val < 0).length == 0;\n        const leftSideRound = config.groupingType == 'clustered' || allLeftZero;\n        const allRightZero = isPositive\n          ? data.ys\n              .slice(yIndex + 1, data.ys.length)\n              .map(y => y.values[index])\n              .filter(val => val > 0).length == 0\n          : data.ys\n              .slice(0, yIndex)\n              .map(y => y.values[index])\n              .filter(val => val < 0).length == 0 && !hasAnyPositiveBars;\n        const rightSideRound =\n          config.groupingType == 'clustered' || allRightZero;\n\n        if (leftSideRound && rightSideRound) {\n          //Both-sides rounding variation\n          const pathD = `\n            M ${xValue + horR},${yValue}\n            h ${width - horR * 2}\n            q${horR},0 ${horR},${verR}\n            v ${HORIZONTAL_BAR_HEIGHT - verR * 2}\n            q0,${verR} -${horR},${verR}\n            h ${-(width - horR * 2)}\n            q-${horR},0 -${horR},-${verR}\n            v -${HORIZONTAL_BAR_HEIGHT - verR * 2}\n            q0,-${verR} ${horR},-${verR}\n            Z\n          `;\n          return pathD;\n        }\n        if (leftSideRound) {\n          //Left-side rounding variation\n          const pathD = `\n            M ${xValue + horR},${yValue}\n            h ${width - horR}\n            v ${HORIZONTAL_BAR_HEIGHT}\n            h ${-(width - horR)}\n            q-${horR},0 -${horR},-${verR}\n            v -${HORIZONTAL_BAR_HEIGHT - verR * 2}\n            q0,-${verR} ${horR},-${verR}\n            Z\n          `;\n          return pathD;\n        }\n        if (rightSideRound) {\n          //Right-side rounding variation\n          const pathD = `\n            M ${xValue},${yValue}\n            h ${width - horR}\n            q${horR},0 ${horR},${verR}\n            v ${HORIZONTAL_BAR_HEIGHT - verR * 2}\n            q0,${verR} -${horR},${verR}\n            h ${-(width - horR)}\n            Z\n          `;\n          return pathD;\n        }\n        //No-rounding variation\n        const pathD = `\n          M ${xValue},${yValue}\n          h ${width}\n          v ${HORIZONTAL_BAR_HEIGHT}\n          h ${-width}\n          v -${HORIZONTAL_BAR_HEIGHT}\n          Z\n        `;\n        return pathD;\n      });\n      simplifiedHorizontalBars.push(subSimpHorBars);\n      return retVal;\n    });\n\n    const yOffset = HORIZONTAL_BAR_HEIGHT;\n    const dataLabels: DataLabel[] = data.ys.flatMap((y, yIndex) => {\n      const subLabels: DataLabel[] = y.values.map((val, xIndex) => {\n        const barIsNegative =\n          simplifiedHorizontalBars[yIndex][xIndex].xPos < zeroAxisPosVal &&\n          simplifiedHorizontalBars[yIndex][xIndex].width > 0;\n        const xOffset = barIsNegative\n          ? -SMALL_PADDING\n          : simplifiedHorizontalBars[yIndex][xIndex].width + SMALL_PADDING;\n        return {\n          label:\n            (checkIfSecondary(data, yIndex, xIndex)\n              ? secondaryPipe.transform(val)\n              : pipe.transform(val)) ?? '',\n          yPos: simplifiedHorizontalBars[yIndex][xIndex].yPos + yOffset,\n          xPos: simplifiedHorizontalBars[yIndex][xIndex].xPos + xOffset,\n          anchor: barIsNegative ? 'end' : 'start',\n        };\n      });\n      return subLabels;\n    });\n\n    function hover(pos: { rect: DOMRect; x: number; y: number }) {\n      let xIndex: number = 0;\n      let x = 0;\n      if (checkYScaleType(yScale, data.type) && data.type != 'labeled') {\n        xIndex = findNearestIndex(data.x, yScale.invert(pos.y).getTime());\n        x = yScale(data.x[xIndex]) - SMALL_PADDING;\n      } else if (\n        !checkYScaleType(yScale, data.type) &&\n        data.type == 'labeled'\n      ) {\n        xIndex = findNearestIndexString(data.x, yScale.invert(pos.y));\n        x = yScale(xIndex) - SMALL_PADDING;\n      }\n      const fullYs = data.ys.map((_, mapYIndex) =>\n        getBarXInfo(\n          data,\n          mapYIndex,\n          xIndex,\n          scale,\n          config.groupingType == 'stacked',\n        ),\n      );\n      const ys = fullYs.map(y => y.xValue);\n      let visibleYIndex = -1;\n      for (let i = 0; i < fullYs.length; i++) {\n        const leftBorder = fullYs[i].xValue;\n        const rightBorderCandidates = fullYs\n          .filter(y => y.xValue > leftBorder)\n          .map(y => y.xValue);\n        const rightBorder =\n          rightBorderCandidates.length > 0\n            ? Math.min(...rightBorderCandidates)\n            : leftBorder + fullYs[i].width;\n        if (pos.x > leftBorder && pos.x < rightBorder) {\n          visibleYIndex = i;\n        }\n      }\n      if (config.groupingType == 'clustered') {\n        visibleYIndex = findSubIndexHorizontal(x, pos.y, data.ys.length);\n      }\n\n      if (visibleYIndex == -1) {\n        if (pos.x > zeroAxisPosVal) {\n          visibleYIndex = ys.indexOf(Math.max(...ys));\n        }\n        if (pos.x < zeroAxisPosVal) {\n          visibleYIndex = ys.indexOf(Math.min(...ys));\n        }\n      }\n      const yIndex = visibleIndices[visibleYIndex];\n\n      //Check if we've landed on a zero-width bar (only really relevant on ends)\n      if (\n        simplifiedHorizontalBars[visibleYIndex][xIndex].width == 0 &&\n        config.groupingType == 'stacked'\n      ) {\n        let altBarFound = false;\n        //Check upwards\n        for (\n          let i = visibleYIndex + 1;\n          i < simplifiedHorizontalBars.length;\n          i++\n        ) {\n          if (altBarFound) {\n            break;\n          }\n          if (simplifiedHorizontalBars[i][xIndex].width != 0) {\n            visibleYIndex = i;\n            altBarFound = true;\n          }\n        }\n\n        //Check downwards\n        for (let i = visibleYIndex - 1; i >= 0; i--) {\n          if (altBarFound) {\n            break;\n          }\n          if (simplifiedHorizontalBars[i][xIndex].width != 0) {\n            visibleYIndex = i;\n            altBarFound = true;\n          }\n        }\n      }\n\n      const anchor = new DOMRect(\n        pos.rect.x +\n          simplifiedHorizontalBars[visibleYIndex][xIndex].xPos -\n          SMALL_PADDING,\n        pos.rect.y + simplifiedHorizontalBars[visibleYIndex][xIndex].yPos,\n        simplifiedHorizontalBars[visibleYIndex][xIndex].width +\n          SMALL_PADDING * 2,\n        HORIZONTAL_BAR_HEIGHT,\n      );\n      return {\n        x,\n        xIndex,\n        ys,\n        yIndex,\n        visibleYIndex,\n        tooltip: {\n          anchor,\n          date:\n            data.type == 'labeled'\n              ? data.x[xIndex].label\n              : utcFormat('%B %d, %Y')(new Date(data.x[xIndex])),\n          metrics: data.ys\n            .map((y, index) => ({\n              color: colors[index % colors.length],\n              label: y.label,\n              value:\n                (checkIfSecondary(data, index, xIndex)\n                  ? secondaryFullPipe.transform(y.values[xIndex])\n                  : fullPipe.transform(y.values[xIndex])) ?? '-',\n            }))\n            .filter((_, i) => config.groupedTooltip || i == visibleYIndex),\n        },\n      };\n    }\n\n    return {\n      xTicks: xTicks,\n      yTicks: yTicks,\n      hover,\n      colors,\n      bars: [],\n      lines: [],\n      circles: [],\n      areas: [],\n      arcs: [],\n      horizontalBars,\n      dataLabels,\n      waterfallLines: [],\n    };\n  }\n\n  export function arcs(\n    config: Config,\n    allData: Data,\n    dimensions: Dimensions,\n  ): RenderedChart {\n    if (\n      config.secondaryValueType &&\n      (config.valueType == 'percentage' ||\n        config.secondaryValueType == 'percentage')\n    ) {\n      // eslint-disable-next-line no-console\n      console.warn(\n        \"Heads up! Two axes with percentage aren't supported for donut charts\",\n      );\n      return emptyChart;\n    }\n    const { data: unstackedData, visibleIndices } = hide(allData);\n    const donutData = Chart.convertChartDataToDonutData(unstackedData);\n    const hasNonZeroValue = donutData.some(d => d.value > 0);\n    const arcData = hasNonZeroValue\n      ? donutData\n      : [\n          {\n            label: '',\n            value: 1,\n          },\n        ];\n    const colors = hasNonZeroValue\n      ? visibleIndices.map(i => config.colors[i % config.colors.length])\n      : ['--gray-30'];\n    const { pipe, fullPipe } = getPipes(config.valueType);\n    const { pipe: secondaryPipe, fullPipe: secondaryFullPipe } =\n      config.secondaryValueType\n        ? getPipes(config.secondaryValueType)\n        : {\n            pipe,\n            fullPipe,\n          };\n\n    const outer = (dimensions.height / 2) * 0.75;\n    const inner = outer - 12;\n\n    const pieArcs = pie<DonutData>()\n      .sortValues(null)\n      .value(d => Math.max(d.value, 0))(arcData);\n\n    const arcs = pieArcs.map(pieArc =>\n      arc<DonutData>()\n        .innerRadius(inner)\n        .outerRadius(outer)\n        .padAngle(0.013)\n        .startAngle(pieArc.startAngle)\n        .endAngle(pieArc.endAngle)(pieArc.data),\n    );\n\n    const dataLabels: DataLabel[] = hasNonZeroValue\n      ? pieArcs.map(arc => {\n          //Don't show data labels for zero-width donut slices (includes negative values)\n          if (arc.startAngle == arc.endAngle) {\n            return {\n              label: '',\n              yPos: 0,\n              xPos: 0,\n              anchor: 'middle',\n            };\n          }\n          const arcCenterAngle = (arc.startAngle + arc.endAngle) / 2;\n          const edgePoint = arcToPoint(arcCenterAngle, outer);\n          const lineEndPoint = arcToPoint(arcCenterAngle, outer + 16);\n          const middleArea = outer / 4;\n          let yOffset = 0;\n          let xOffset = 0;\n          if (lineEndPoint.y > 0) {\n            if (Math.abs(lineEndPoint.y) < middleArea) {\n              yOffset = SMALL_PADDING / 2;\n            } else {\n              yOffset = SMALL_PADDING;\n            }\n            if (Math.abs(lineEndPoint.x) < middleArea) {\n              yOffset += SMALL_PADDING / 2;\n            }\n          } else {\n            if (Math.abs(lineEndPoint.y) < middleArea) {\n              yOffset = SMALL_PADDING / 2;\n            }\n            if (Math.abs(lineEndPoint.x) < middleArea) {\n              yOffset -= SMALL_PADDING / 2;\n            }\n          }\n          return {\n            label:\n              (arc.data.isSecondary\n                ? secondaryPipe.transform(arc.data.value)\n                : pipe.transform(arc.data.value)) ?? '',\n            yPos: lineEndPoint.y + yOffset,\n            xPos: lineEndPoint.x + xOffset,\n            anchor:\n              Math.abs(lineEndPoint.x) < middleArea\n                ? 'middle'\n                : lineEndPoint.x < 0\n                ? 'end'\n                : 'start',\n            line: {\n              x1: edgePoint.x,\n              y1: edgePoint.y,\n              x2: lineEndPoint.x,\n              y2: lineEndPoint.y,\n            },\n          };\n        })\n      : [];\n\n    return {\n      xTicks: [],\n      yTicks: [],\n      areas: [],\n      lines: [],\n      circles: [],\n      bars: [],\n      colors,\n      arcs,\n      horizontalBars: [],\n      dataLabels,\n      waterfallLines: [],\n    };\n  }\n\n  export function waterfall(\n    config: Config,\n    allData: Data,\n    dimensions: Dimensions,\n  ): RenderedChart {\n    const { data: uncheckedData, visibleIndices } = hide(allData);\n    if (uncheckedData.type == 'timeseries') {\n      // eslint-disable-next-line no-console\n      console.warn(\n        \"Heads up! Time-based series aren't currently supported for waterfall charts\",\n      );\n      return emptyChart;\n    }\n    if (config.secondaryValueType) {\n      // eslint-disable-next-line no-console\n      console.warn(\n        'Heads up! Waterfall charts do not currently have two-axis support',\n      );\n      return emptyChart;\n    }\n    //This assignment makes typescript recognize the actual type (TimeseriesData)\n    const data = waterfallTransform(uncheckedData);\n    const { range: xRange, binSize } = barXRange(dimensions, data, config);\n    const halfBinSize = binSize / 2;\n    const xScale = scaleLinear(indexDomain(data), xRange);\n    const tickCount = getTickCount(dimensions, config);\n    const xTicks = generateLabelledXTicks(data, xScale, tickCount);\n\n    const { pipe, fullPipe } = getPipes(config.valueType);\n\n    const { scale, yTicks } = calcYScalesAndTicks(\n      data,\n      dimensions,\n      pipe,\n      pipe,\n      true,\n      config,\n    );\n    const zeroAxisPosVal = scale(0, true);\n\n    const colors = visibleIndices.map(\n      i => config.colors[i % config.colors.length],\n    );\n    const bars = data.ys.map((y, yIndex) =>\n      y.values.map((_, index) => {\n        const { yValue, height } = getBarYInfo(\n          data,\n          yIndex,\n          index,\n          scale,\n          true,\n        );\n        let xValue = xScale(index) - halfBinSize;\n        let width = binSize;\n        return {\n          x: xValue,\n          y: yValue,\n          width,\n          height,\n          offset: 0,\n        };\n      }),\n    );\n\n    //Move bars based on height of previous bars (except the total bar)\n    let barOffsetRunningTotal = 0;\n    const waterfallLines: {\n      x1: number;\n      x2: number;\n      y1: number;\n      y2: number;\n    }[] = [];\n    for (let i = 0; i < data.x.length - 1; i++) {\n      let barOffsetChange = 0;\n      for (let j = 0; j < bars.length; j++) {\n        const barIsNegative =\n          bars[j][i].y >= zeroAxisPosVal && bars[j][i].height > 0;\n        if (barIsNegative) {\n          barOffsetChange -= bars[j][i].height;\n        } else {\n          barOffsetChange += bars[j][i].height;\n        }\n        bars[j][i].offset = barOffsetRunningTotal;\n        bars[j][i].y -= barOffsetRunningTotal;\n        if (j == bars.length - 1) {\n          const x1 = bars[j][i].x + bars[bars.length - 1][i].width;\n          const y1 = bars[j][i].y + (barIsNegative ? bars[j][i].height : 0);\n          const x2 = bars[j][i + 1].x;\n          const y2 = y1;\n          waterfallLines.push({\n            x1,\n            y1,\n            x2,\n            y2,\n          });\n        }\n      }\n      barOffsetRunningTotal += barOffsetChange;\n    }\n\n    const dataLabels: DataLabel[] = data.ys.flatMap((y, yIndex) => {\n      const subLabels: DataLabel[] = y.values.map((val, xIndex) => {\n        const isNegativeBar =\n          bars[yIndex][xIndex].y >= zeroAxisPosVal &&\n          bars[yIndex][xIndex].height > 0;\n        const yOffset = isNegativeBar\n          ? SMALL_PADDING + DATA_LABEL_HEIGHT + bars[yIndex][xIndex].height\n          : -SMALL_PADDING;\n        return {\n          label: pipe.transform(val) ?? '',\n          yPos: bars[yIndex][xIndex].y + yOffset,\n          xPos: bars[yIndex][xIndex].x + bars[yIndex][xIndex].width / 2,\n          anchor: 'middle',\n        };\n      });\n      return subLabels;\n    });\n\n    function hover(pos: { rect: DOMRect; x: number; y: number }) {\n      const xIndex = findNearestIndexString(data.x, xScale.invert(pos.x));\n      const x = xScale(xIndex);\n      const ys = bars.map(bar => bar[xIndex].y);\n      const yPosSign = zeroAxisPosVal - pos.y;\n      let visibleYIndex = -1;\n      if (yPosSign < 0 && data.ys.find(y => y.values.find(val => val < 0))) {\n        for (let i = ys.length - 1; i >= 0; i--) {\n          if (ys[i] >= zeroAxisPosVal && ys[i] < pos.y) {\n            visibleYIndex = i;\n            break;\n          }\n        }\n      } else {\n        for (let i = 0; i < ys.length; i++) {\n          if (ys[i] <= zeroAxisPosVal && ys[i] < pos.y) {\n            visibleYIndex = i;\n            break;\n          }\n        }\n      }\n      if (visibleYIndex == -1) {\n        if (pos.y < zeroAxisPosVal) {\n          visibleYIndex = ys.indexOf(Math.min(...ys));\n        }\n        if (pos.y > zeroAxisPosVal) {\n          visibleYIndex = ys.indexOf(Math.max(...ys));\n        }\n      }\n      const yIndex = visibleIndices[visibleYIndex];\n      const { yValue, height } = getBarYInfo(data, yIndex, xIndex, scale, true);\n      const anchor = new DOMRect(\n        pos.rect.x + bars[visibleYIndex][xIndex].x - SMALL_PADDING,\n        pos.rect.y + yValue - bars[visibleYIndex][xIndex].offset,\n        bars[visibleYIndex][xIndex].width + SMALL_PADDING * 2,\n        height,\n      );\n      return {\n        x,\n        xIndex,\n        ys,\n        yIndex,\n        visibleYIndex,\n        tooltip: {\n          anchor,\n          date: data.x[xIndex].label,\n          metrics: data.ys\n            .map((y, index) => ({\n              color: colors[index % colors.length],\n              label: y.label,\n              value: fullPipe.transform(y.values[xIndex]) ?? '-',\n            }))\n            .filter((_, i) => config.groupedTooltip || i == visibleYIndex),\n        },\n      };\n    }\n\n    return {\n      xTicks,\n      yTicks,\n      colors,\n      bars,\n      lines: [],\n      circles: [],\n      areas: [],\n      hover,\n      arcs: [],\n      horizontalBars: [],\n      dataLabels,\n      waterfallLines,\n    };\n  }\n\n  const LEFT_PADDING = 48;\n  const LEFT_PADDING_WITH_DATA_LABELS = 56;\n  const LEFT_PADDING_DATE = 64;\n  export const LEFT_PADDING_LABEL_MAX = 192;\n  export const RIGHT_PADDING = 48;\n  const RIGHT_PADDING_HORIZONTAL = 96;\n  const TOP_PADDING = 16;\n  const TOP_PADDING_WITH_DATA_LABELS = 36;\n  const BOTTOM_PADDING = 24;\n  const BOTTOM_PADDING_WITH_DATA_LABELS = 44;\n  const SMALL_PADDING = 8;\n  const HORIZONTAL_BAR_HEIGHT = 8;\n  const WIDTH_PER_LETTER = 6.5;\n  const MIN_TICK_SPACING = 100;\n  const MAX_X_TICKS = 6;\n  const DATA_LABEL_HEIGHT = 12;\n\n  function getTickCount(dimensions: Dimensions, config: Config): number {\n    const availableWidth =\n      dimensions.width -\n      (config.showDataLabels ? LEFT_PADDING_WITH_DATA_LABELS : LEFT_PADDING) -\n      RIGHT_PADDING;\n    return Math.min(\n      MAX_X_TICKS,\n      Math.max(2, Math.floor(availableWidth / MIN_TICK_SPACING)),\n    );\n  }\n\n  function generateXTicks(\n    data: TimeseriesData,\n    xScale: ScaleTime<number, number, never>,\n    tickCount: number,\n    format: (date: Date) => string,\n  ): XTick[] {\n    if (data.x.length === 0) {\n      return [];\n    }\n    if (data.x.length === 1 || tickCount <= 1) {\n      return [{ x: xScale(data.x[0]), label: format(new Date(data.x[0])) }];\n    }\n\n    const lastIndex = data.x.length - 1;\n    const numTicks = Math.min(tickCount, data.x.length);\n    const step = lastIndex / (numTicks - 1);\n\n    // Always include first and last data points.\n    // Inner ticks are approximately evenly spaced using rounding.\n    const indices: number[] = [];\n    for (let i = 0; i < numTicks; i++) {\n      indices.push(Math.round(i * step));\n    }\n\n    return indices.map(i => ({\n      x: xScale(data.x[i]),\n      label: format(new Date(data.x[i])),\n    }));\n  }\n\n  function generateLabelledXTicks(\n    data: LabeledData,\n    xScale: ScaleLinear<number, number, never>,\n    tickCount: number,\n  ): XTick[] {\n    if (data.x.length === 0) {\n      return [];\n    }\n    if (data.x.length === 1 || tickCount <= 1) {\n      return [{ x: xScale(0), label: data.x[0].label }];\n    }\n\n    const xTicks: XTick[] = [];\n    for (let i = 0; i < data.x.length; i++) {\n      xTicks.push({\n        x: xScale(i),\n        label: data.x[i].label,\n      });\n    }\n\n    return xTicks;\n  }\n\n  export type Data = LabeledData | TimeseriesData;\n\n  type BaseData = {\n    ys: {\n      label: string;\n      hidden?: boolean;\n      isSecondary?: boolean;\n      values: number[];\n    }[];\n  };\n\n  //Currently only supported for horizontal bar charts\n  export type LabeledData = BaseData & {\n    type: 'labeled';\n    x: { label: string; isSecondary?: boolean }[];\n  };\n\n  export type TimeseriesData = BaseData & {\n    type: 'timeseries';\n    x: number[];\n  };\n\n  type DonutData = {\n    label: string;\n    hidden?: boolean;\n    value: number;\n    isSecondary?: boolean;\n  };\n\n  export type Dimensions = {\n    width: number;\n    height: number;\n  };\n\n  type BaseConfig = {\n    groupedTooltip: boolean;\n    colors: string[];\n    allowLegendToggle: boolean;\n    zeroStateMessage: string;\n    valueType: ValueType;\n    secondaryValueType?: ValueType;\n    truncateLegend: boolean;\n    dateFormat?: Interval;\n    showDataLabels?: boolean;\n  };\n\n  type DonutConfig = {\n    size: 'xsmall' | 'small' | 'medium' | 'large';\n    displayValue: string;\n    displayLabel?: string;\n  };\n\n  export type Config = BaseConfig &\n    (\n      | {\n          type: 'line' | 'area' | 'waterfall';\n        }\n      | {\n          type: 'bar' | 'horizontal-bar';\n          groupingType: 'stacked' | 'clustered';\n        }\n      | {\n          type: 'donut';\n          donutDisplayInfo: DonutConfig;\n        }\n    );\n\n  type BarConfig = Extract<Config, { type: 'bar' | 'horizontal-bar' }>;\n\n  export const defaultConfig: Config = {\n    type: 'line',\n    groupedTooltip: true,\n    colors: defaultColorPalette,\n    allowLegendToggle: false,\n    zeroStateMessage: 'No data to display.',\n    valueType: 'currency',\n    truncateLegend: true,\n    dateFormat: 'day',\n  };\n\n  export const defaultDonutConfig: Config = {\n    type: 'donut',\n    groupedTooltip: true,\n    colors: defaultColorPalette,\n    allowLegendToggle: false,\n    zeroStateMessage: 'No data to display.',\n    valueType: 'currency',\n    truncateLegend: true,\n    dateFormat: 'day',\n    donutDisplayInfo: {\n      size: 'medium',\n      displayValue: '',\n    },\n  };\n\n  export type Area = {\n    path: string | null;\n    fill: string;\n  };\n\n  export type XTick = {\n    x: number;\n    label: string;\n    secondaryLabel?: string;\n  };\n\n  export type YTick = {\n    y: number;\n    label: string;\n    secondaryLabel?: string;\n  };\n\n  type Rect = {\n    x: number;\n    y: number;\n    width: number;\n    height: number;\n  };\n\n  export type BarSeries = {\n    fill: string;\n    rects: Rect[];\n  };\n\n  type Circle = {\n    cx: number;\n    cy: number;\n  };\n\n  // Hover is a function that takes a viewport x and y and returns a rich\n  // set of information about what values are being hovered and what the tooltip\n  // should look like\n  export type Hover = (pos: { rect: DOMRect; x: number; y: number }) => {\n    // the indices into the data of the closest point\n    xIndex: number;\n    // we want to know which visible y index is hovered\n    // and which actual y index is hovered\n    yIndex: number;\n    visibleYIndex: number;\n\n    // the viewport x and ys of the hovered items\n    x: number;\n    ys: number[];\n\n    tooltip: {\n      anchor: DOMRect;\n      date: string;\n      metrics: {\n        color: string;\n        label: string;\n        value: string;\n      }[];\n    };\n  };\n\n  // RenderedChart represents all of the parts of a chart\n  // that end up on screen. Every chart has x and y ticks\n  // and hover functionality, even though they might be\n  // different from chart to chart.\n  type RenderedChart = {\n    xTicks: XTick[];\n    yTicks: YTick[];\n    hover?: Hover;\n    colors: string[];\n    lines: (string | null)[];\n    circles: Circle[]; //Line fallback for a single point\n    areas: (string | null)[];\n    bars: Rect[][];\n    arcs: (string | null)[];\n    horizontalBars: (string | null)[][];\n    dataLabels: DataLabel[];\n    waterfallLines: {\n      x1: number;\n      x2: number;\n      y1: number;\n      y2: number;\n    }[];\n  };\n\n  type DataLabel = {\n    label: string;\n    xPos: number;\n    yPos: number;\n    anchor: 'start' | 'middle' | 'end';\n    line?: {\n      x1: number;\n      y1: number;\n      x2: number;\n      y2: number;\n    };\n  };\n\n  const emptyChart: RenderedChart = {\n    xTicks: [],\n    yTicks: [],\n    colors: [],\n    lines: [],\n    circles: [],\n    areas: [],\n    bars: [],\n    arcs: [],\n    horizontalBars: [],\n    dataLabels: [],\n    waterfallLines: [],\n  };\n\n  function timeseriesDomain(data: TimeseriesData) {\n    return [Math.min(...data.x), Math.max(...data.x)];\n  }\n\n  function indexDomain(data: LabeledData) {\n    return [0, data.x.length - 1];\n  }\n\n  function yDomain(data: Data, scaleFactor: number = 1) {\n    const max =\n      Math.max(...data.ys.map(y => Math.max(...y.values))) * scaleFactor;\n    const min = Math.min(...data.ys.map(y => Math.min(...y.values)));\n    return [min < 0 ? min : 0, max <= 0 ? 1 : max];\n  }\n\n  function xRange(dimensions: Dimensions, config: Config) {\n    return [\n      config.showDataLabels ? LEFT_PADDING_WITH_DATA_LABELS : LEFT_PADDING,\n      dimensions.width - RIGHT_PADDING,\n    ];\n  }\n\n  function xRangeHorizontal(\n    dimensions: Dimensions,\n    data: Data,\n    largestLabelLength: number,\n    config: Config,\n  ) {\n    let leftPaddingMax =\n      data.type == 'labeled' ? LEFT_PADDING_LABEL_MAX : LEFT_PADDING_DATE;\n    let leftPaddingCalculated = leftPaddingMax;\n    if (data.type == 'labeled') {\n      const maxLabelSize = Math.max(...data.x.map(x => x.label.length));\n      leftPaddingCalculated = Math.min(\n        leftPaddingMax,\n        maxLabelSize * WIDTH_PER_LETTER,\n      );\n    }\n    //Space between label and chart\n    leftPaddingCalculated = leftPaddingCalculated + SMALL_PADDING;\n\n    //If data labels are on, and we have negative bars, we need even more left padding\n    const dataLabelPadding =\n      config.showDataLabels && data.ys.find(y => y.values.find(val => val < 0))\n        ? largestLabelLength * WIDTH_PER_LETTER\n        : 0;\n    return [\n      Math.max(leftPaddingCalculated, LEFT_PADDING) + dataLabelPadding,\n      dimensions.width - RIGHT_PADDING_HORIZONTAL,\n    ];\n  }\n\n  function barXRange(dimensions: Dimensions, data: Data, config: Config) {\n    const left = config.showDataLabels\n      ? LEFT_PADDING_WITH_DATA_LABELS\n      : LEFT_PADDING;\n    const right = dimensions.width - RIGHT_PADDING;\n    const width = right - left;\n    const binSize = width / (data.x.length || 1);\n    const halfBinSize = binSize / 2;\n    const range = [left + halfBinSize, right - halfBinSize];\n    return { binSize: Math.min(binSize * 0.7, 80), range };\n  }\n\n  function barYRange(dimensions: Dimensions, data: Data, config: Config) {\n    const top =\n      dimensions.height -\n      (config.showDataLabels ? TOP_PADDING_WITH_DATA_LABELS : TOP_PADDING);\n    const bottom = BOTTOM_PADDING;\n    const height = top - bottom;\n    const binSize = height / (data.x.length || 1);\n    const halfBinSize = binSize / 2;\n    const range = [bottom + halfBinSize, top - halfBinSize];\n    return { range };\n  }\n\n  function yRange(dimensions: Dimensions, config: Config, data: Data) {\n    const extraBottomPadding =\n      config.showDataLabels &&\n      data.ys.find(y => y.values.find(val => val < 0)) &&\n      (config.type == 'bar' || config.type == 'waterfall');\n    return [\n      dimensions.height -\n        (extraBottomPadding ? BOTTOM_PADDING_WITH_DATA_LABELS : BOTTOM_PADDING),\n      config.showDataLabels ? TOP_PADDING_WITH_DATA_LABELS : TOP_PADDING,\n    ];\n  }\n\n  function calcYScalesAndTicks(\n    data: Data,\n    dimensions: Dimensions,\n    pipe: NumberPipe | SmallCurrencyPipe | PercentagePipe | DaysPipe,\n    secondaryPipe: NumberPipe | SmallCurrencyPipe | PercentagePipe | DaysPipe,\n    isStacked: boolean,\n    config: Config,\n  ): {\n    yScale: ScaleLinear<number, number, never>;\n    yScaleSecondary: ScaleLinear<number, number, never>;\n    scale: (input: number, isSecondary: boolean | undefined) => number;\n    yTicks: YTick[];\n  } {\n    const primaryData = {\n      ...data,\n      ys: data.ys.filter(y => !y.isSecondary),\n    };\n    const secondaryData = {\n      ...data,\n      ys: data.ys.filter(y => y.isSecondary),\n    };\n    const scaleRange = yRange(dimensions, config, data);\n\n    //Simpler path for data w/o secondaries\n    if (secondaryData.ys.length == 0) {\n      const data = isStacked ? stack(primaryData) : primaryData;\n      const yScale = scaleLinear(yDomain(data), scaleRange);\n      const yTicks: YTick[] = yScale.ticks(5).map(tick => ({\n        y: yScale(tick),\n        label: pipe.transform(tick),\n      }));\n      const scale = (input: number): number => {\n        return yScale(input);\n      };\n      return {\n        yScale,\n        yScaleSecondary: yScale,\n        scale,\n        yTicks,\n      };\n    }\n\n    let scaleDomainMultiple = 1;\n    //Calculating how much we need to multiple the domain by to 'fit' both axes' data\n    if (isStacked) {\n      //Stacking each individual data type makes finding the max easier\n      const primaryStacked = stack(primaryData);\n      const secondaryStacked = stack(secondaryData);\n      const primaryDataMax = Math.max(\n        ...primaryStacked.ys.map(y => Math.max(...y.values)),\n      );\n      const secondaryDataMax = Math.max(\n        ...secondaryStacked.ys.map(y => Math.max(...y.values)),\n      );\n      for (let i = 0; i < primaryStacked.x.length; i++) {\n        const primaryVal = Math.max(...primaryStacked.ys.map(y => y.values[i]));\n        const secondaryVal = Math.max(\n          ...secondaryStacked.ys.map(y => y.values[i]),\n        );\n        const primaryRatio =\n          primaryDataMax != 0 ? primaryVal / primaryDataMax : 0;\n        const secondaryRatio =\n          secondaryDataMax != 0 ? secondaryVal / secondaryDataMax : 0;\n        const multVal = primaryRatio + secondaryRatio;\n        if (multVal > scaleDomainMultiple) {\n          scaleDomainMultiple = multVal;\n        }\n      }\n    }\n    const primaryYDomain = yDomain(\n      isStacked ? stack(primaryData) : primaryData,\n      scaleDomainMultiple,\n    );\n\n    //Figuring out the best tick count to fit the two data srouces\n    const yScalePrimaryProto = scaleLinear(primaryYDomain, scaleRange);\n    const yScaleSecondaryProto = scaleLinear(\n      yDomain(\n        isStacked ? stack(secondaryData) : secondaryData,\n        scaleDomainMultiple,\n      ),\n      scaleRange,\n    );\n    const tickCount = Math.max(\n      5,\n      yScalePrimaryProto.ticks(5).length,\n      yScaleSecondaryProto.ticks(5).length,\n    );\n\n    //Finding a domain for the secondary data such that it will result in round tick values when matched with the primary ticks\n    const secondaryTicksProto = yScaleSecondaryProto\n      .ticks(tickCount)\n      .map(tick => ({\n        y: yScaleSecondaryProto(tick),\n        rawY: tick,\n        label: secondaryPipe.transform(tick),\n      }));\n    const yScaleDomainMax = Math.max(...primaryYDomain);\n    const yScale = scaleLinear(primaryYDomain, scaleRange);\n    const yScaleTickMax = Math.max(...yScale.ticks(tickCount));\n    const secondaryGap =\n      secondaryTicksProto[1].rawY - secondaryTicksProto[0].rawY;\n    const gapCount = yScale.ticks(tickCount).length - 1;\n    let calcMax = secondaryGap * gapCount;\n    const tickMax = Math.max(\n      ...secondaryTicksProto.map(secTick => secTick.rawY),\n    );\n    while (calcMax < tickMax) {\n      calcMax = calcMax * 2;\n    }\n    while (calcMax > tickMax * 2) {\n      calcMax = calcMax / 2;\n    }\n    const yScaleSecondary = scaleLinear(\n      [0, calcMax * (yScaleDomainMax / yScaleTickMax)],\n      scaleRange,\n    );\n\n    const yTicks: YTick[] = yScale.ticks(tickCount).map(tick => ({\n      y: yScale(tick),\n      label: pipe.transform(tick),\n      secondaryLabel: secondaryPipe.transform(\n        yScaleSecondary.invert(yScale(tick)),\n      ),\n    }));\n\n    const scale = (input: number, isSecondary: boolean | undefined): number => {\n      if (isSecondary) {\n        return yScaleSecondary(input);\n      }\n      return yScale(input);\n    };\n    return {\n      yScale,\n      yScaleSecondary,\n      scale,\n      yTicks,\n    };\n  }\n\n  function calcXScalesAndTicks(\n    data: Data,\n    dimensions: Dimensions,\n    pipe: NumberPipe | SmallCurrencyPipe | PercentagePipe | DaysPipe,\n    secondaryPipe: NumberPipe | SmallCurrencyPipe | PercentagePipe | DaysPipe,\n    isStacked: boolean,\n    config: Config,\n  ): {\n    xScale: ScaleLinear<number, number, never>;\n    xScaleSecondary: ScaleLinear<number, number, never>;\n    scale: (input: number, isSecondary: boolean | undefined) => number;\n    xTicks: XTick[];\n  } {\n    const primaryData = convertDataToJustOneValueType(data, false);\n    const secondaryData = convertDataToJustOneValueType(data, true);\n\n    const largestLabelLength = Math.max(\n      ...data.ys.map((y, yIndex) =>\n        Math.max(\n          ...y.values.map(\n            (val, xIndex) =>\n              (checkIfSecondary(data, yIndex, xIndex)\n                ? secondaryPipe.transform(y.values[xIndex])\n                : pipe.transform(y.values[xIndex])\n              ).length,\n          ),\n        ),\n      ),\n    );\n    const scaleRange = xRangeHorizontal(\n      dimensions,\n      data,\n      largestLabelLength,\n      config,\n    );\n\n    //Simpler path for data w/o secondaries\n    if (!secondaryData.ys.find(y => y.values.find(val => val != 0))) {\n      const data = isStacked ? stack(primaryData) : primaryData;\n      const xScale = scaleLinear(yDomain(data), scaleRange);\n      const xTicks: XTick[] = xScale.ticks(5).map(tick => ({\n        x: xScale(tick),\n        label: pipe.transform(tick),\n      }));\n\n      const scale = (input: number): number => {\n        return xScale(input);\n      };\n      return {\n        xScale,\n        xScaleSecondary: xScale,\n        scale,\n        xTicks,\n      };\n    }\n    let scaleDomainMultiple = 1;\n\n    //Calculating how much we need to multiple the domain by to 'fit' both axes' data\n    if (isStacked) {\n      //Stacking each individual data type makes finding the max easier\n      const primaryStacked = stack(primaryData);\n      const secondaryStacked = stack(secondaryData);\n      const primaryDataMax = Math.max(\n        ...primaryStacked.ys.map(y => Math.max(...y.values)),\n      );\n      const secondaryDataMax = Math.max(\n        ...secondaryStacked.ys.map(y => Math.max(...y.values)),\n      );\n      for (let i = 0; i < primaryStacked.x.length; i++) {\n        const primaryVal = Math.max(...primaryStacked.ys.map(y => y.values[i]));\n        const secondaryVal = Math.max(\n          ...secondaryStacked.ys.map(y => y.values[i]),\n        );\n        const multVal =\n          primaryVal / primaryDataMax + secondaryVal / secondaryDataMax;\n        if (multVal > scaleDomainMultiple) {\n          scaleDomainMultiple = multVal;\n        }\n      }\n    }\n    const primaryXDomain = yDomain(\n      isStacked ? stack(primaryData) : primaryData,\n      scaleDomainMultiple,\n    );\n    const xScalePrimaryProto = scaleLinear(primaryXDomain, scaleRange);\n    const xScaleSecondaryProto = scaleLinear(\n      yDomain(\n        isStacked ? stack(secondaryData) : secondaryData,\n        scaleDomainMultiple,\n      ),\n      scaleRange,\n    );\n    const tickCount = Math.max(\n      5,\n      xScalePrimaryProto.ticks(5).length,\n      xScaleSecondaryProto.ticks(5).length,\n    );\n\n    //Finding a domain for the secondary data such that it will result in round tick values when matched with the primary ticks\n    const secondaryTicksProto = xScaleSecondaryProto\n      .ticks(tickCount)\n      .map(tick => ({\n        x: xScaleSecondaryProto(tick),\n        rawX: tick,\n        label: secondaryPipe.transform(tick),\n      }));\n    const xScaleDomainMax = Math.max(...primaryXDomain);\n    const xScale = scaleLinear(primaryXDomain, scaleRange);\n    const xScaleTickMax = Math.max(...xScale.ticks(tickCount));\n    const secondaryGap =\n      secondaryTicksProto[1].rawX - secondaryTicksProto[0].rawX;\n    const gapCount = xScale.ticks(tickCount).length - 1;\n    let calcMax = secondaryGap * gapCount;\n    const tickMax = Math.max(\n      ...secondaryTicksProto.map(secTick => secTick.rawX),\n    );\n    while (calcMax < tickMax) {\n      calcMax = calcMax * 2;\n    }\n    while (calcMax > tickMax * 2) {\n      calcMax = calcMax / 2;\n    }\n    const xScaleSecondary = scaleLinear(\n      [0, calcMax * (xScaleDomainMax / xScaleTickMax)],\n      scaleRange,\n    );\n\n    const xTicks: XTick[] = xScale.ticks(tickCount).map(tick => ({\n      x: xScale(tick),\n      label: pipe.transform(tick),\n      secondaryLabel: secondaryPipe.transform(\n        xScaleSecondary.invert(xScale(tick)),\n      ),\n    }));\n\n    const scale = (input: number, isSecondary: boolean | undefined): number => {\n      if (isSecondary) {\n        return xScaleSecondary(input);\n      }\n      return xScale(input);\n    };\n    return {\n      xScale,\n      xScaleSecondary,\n      scale,\n      xTicks,\n    };\n  }\n\n  function convertDataToJustOneValueType(\n    data: Data,\n    isSecondary: boolean,\n  ): Data {\n    const newData: Data = { ...data, ys: [] };\n    data.ys.forEach((y, yIndex) => {\n      newData.ys.push({ ...y, values: [] });\n      y.values.forEach((_, xIndex) => {\n        if (checkIfSecondary(data, yIndex, xIndex) != isSecondary) {\n          newData.ys[yIndex].values.push(0);\n        } else {\n          newData.ys[yIndex].values.push(data.ys[yIndex].values[xIndex]);\n        }\n      });\n    });\n    return newData;\n  }\n\n  function findNearestIndex(values: number[], input: number) {\n    return values.reduce((nearestIndex, value, index) => {\n      return Math.abs(value - input) < Math.abs(values[nearestIndex] - input)\n        ? index\n        : nearestIndex;\n    }, 0);\n  }\n\n  function findNearestIndexWithSecondary(\n    yInfo: { value: number; isSecondary: boolean }[],\n    yPos: number,\n    scale: (input: number, isSecondary: boolean | undefined) => number,\n  ) {\n    let foundIndex = 0;\n    let currMinDistance = Math.abs(\n      scale(yInfo[0].value, yInfo[0].isSecondary) - yPos,\n    );\n    for (let i = 1; i < yInfo.length; i++) {\n      const newDistance = Math.abs(\n        scale(yInfo[i].value, yInfo[i].isSecondary) - yPos,\n      );\n      if (newDistance < currMinDistance) {\n        foundIndex = i;\n        currMinDistance = newDistance;\n      }\n    }\n    return foundIndex;\n  }\n\n  function findNearestIndexString(values: unknown[], input: number) {\n    const numValues = values.map((_, i) => i);\n    return numValues.reduce((nearestIndex, value, index) => {\n      return Math.abs(value - input) < Math.abs(numValues[nearestIndex] - input)\n        ? index\n        : nearestIndex;\n    }, 0);\n  }\n\n  function findSubIndex(\n    value: number,\n    input: number,\n    binSize: number,\n    subBinCount: number,\n  ) {\n    const subBinSize =\n      (binSize - (subBinCount - 1 * SMALL_PADDING)) / subBinCount;\n    const centerIndex = subBinCount / 2 - 0.5;\n    let closestIndex = 0;\n    let closenessVal = -1;\n    for (let i = 0; i < subBinCount; i++) {\n      const offset = (i - centerIndex) * (subBinSize + SMALL_PADDING);\n      const subBinPos = value + offset;\n      const distance = Math.abs(input - subBinPos);\n      if (closenessVal < 0 || closenessVal > distance) {\n        closestIndex = i;\n        closenessVal = distance;\n      }\n    }\n    return closestIndex;\n  }\n\n  function findSubIndexHorizontal(\n    value: number,\n    input: number,\n    subBinCount: number,\n  ) {\n    const centerIndex = subBinCount / 2 - 0.5;\n    let closestIndex = 0;\n    let closenessVal = -1;\n    for (let i = 0; i < subBinCount; i++) {\n      const offset =\n        (i - centerIndex) * (HORIZONTAL_BAR_HEIGHT + SMALL_PADDING);\n      const subBinPos = value + offset;\n      const distance = Math.abs(input - subBinPos);\n      if (closenessVal < 0 || closenessVal > distance) {\n        closestIndex = i;\n        closenessVal = distance;\n      }\n    }\n    return closestIndex;\n  }\n\n  function getBarYInfo(\n    data: Data,\n    yIndex: number,\n    xIndex: number,\n    scale: (input: number, isSecondary: boolean | undefined) => number,\n    isStacked: boolean,\n  ): { yValue: number; height: number } {\n    const zeroVal = scale(0, true);\n    const scaleValue = scale(\n      data.ys[yIndex].values[xIndex],\n      checkIfSecondary(data, yIndex, xIndex),\n    );\n    if (scaleValue > zeroVal) {\n      let prevBarHeights = 0;\n      if (isStacked) {\n        for (let i = 0; i < yIndex; i++) {\n          const checkValue = scale(\n            data.ys[i].values[xIndex],\n            checkIfSecondary(data, i, xIndex),\n          );\n          //Skip positive values\n          if (checkValue < zeroVal) {\n            continue;\n          }\n          prevBarHeights = prevBarHeights + checkValue - zeroVal;\n        }\n      }\n      const yValue = zeroVal + prevBarHeights;\n      const height = scaleValue - yValue + prevBarHeights;\n      return { yValue, height };\n    }\n    let prevBarHeights = 0;\n    if (isStacked) {\n      for (let i = 0; i < yIndex; i++) {\n        const checkValue = scale(\n          data.ys[i].values[xIndex],\n          checkIfSecondary(data, i, xIndex),\n        );\n        //Skip negative values\n        if (checkValue > zeroVal) {\n          continue;\n        }\n        const prevBarYVal = checkValue - prevBarHeights;\n        prevBarHeights = zeroVal - prevBarYVal;\n      }\n    }\n    const yValue = scaleValue - prevBarHeights;\n    const height = zeroVal - yValue - prevBarHeights;\n    return { yValue, height };\n  }\n\n  function getBarXInfo(\n    data: Data,\n    yIndex: number,\n    xIndex: number,\n    scale: (input: number, isSecondary: boolean | undefined) => number,\n    isStacked: boolean,\n  ): { xValue: number; width: number } {\n    const zeroVal = scale(0, true);\n    const scaleValue = scale(\n      data.ys[yIndex].values[xIndex],\n      checkIfSecondary(data, yIndex, xIndex),\n    );\n    if (scaleValue < zeroVal) {\n      let prevBarWidths = 0;\n      if (isStacked) {\n        for (let i = 0; i < yIndex; i++) {\n          const checkVal = scale(\n            data.ys[i].values[xIndex],\n            checkIfSecondary(data, i, xIndex),\n          );\n          //Skip positive values\n          if (checkVal > zeroVal) {\n            continue;\n          }\n          prevBarWidths += zeroVal - checkVal;\n        }\n      }\n      const xValue = scaleValue - prevBarWidths;\n      const width = zeroVal - scaleValue;\n      return { xValue, width };\n    }\n    let prevBarWidths = 0;\n    if (isStacked) {\n      for (let i = 0; i < yIndex; i++) {\n        const checkVal = scale(\n          data.ys[i].values[xIndex],\n          checkIfSecondary(data, i, xIndex),\n        );\n        //Skip negative values\n        if (checkVal < zeroVal) {\n          continue;\n        }\n        prevBarWidths += checkVal - zeroVal;\n      }\n    }\n    const xValue = prevBarWidths + zeroVal;\n    const width = scaleValue - zeroVal;\n    return { xValue, width };\n  }\n\n  function checkIfSecondary(\n    data: Data,\n    yIndex: number,\n    xIndex: number,\n  ): boolean {\n    if (data.type == 'labeled') {\n      if (data.x[xIndex].isSecondary == true) {\n        return true;\n      }\n    }\n    return data.ys[yIndex].isSecondary == true;\n  }\n\n  // stack returns a new data where each set of yValues is stacked\n  // on top of the previous.\n  function stack(data: Data): Data {\n    const stacked: Data = {\n      ...data,\n      ys: data.ys.map(y => ({\n        label: y.label,\n        values: [],\n        isSecondary: y.isSecondary,\n      })),\n    };\n    for (let i = 0; i < data.x.length; i++) {\n      let posFrom = 0;\n      let negFrom = 0;\n      for (let j = 0; j < data.ys.length; j++) {\n        const sourceVal = data.ys[j].values[i];\n        if (sourceVal < 0) {\n          const to = negFrom + sourceVal;\n          stacked.ys[j].values.push(to);\n          negFrom = to;\n        } else {\n          const to = posFrom + sourceVal;\n          stacked.ys[j].values.push(to);\n          posFrom = to;\n        }\n      }\n    }\n    return stacked;\n  }\n\n  // hide strips out hidden y values while retaining the original indices\n  // for the remaining visible values\n  function hide(data: Data): { data: Data; visibleIndices: number[] } {\n    const visibleIndices = data.ys\n      .map((y, i) => ({ y, i }))\n      .filter(({ y }) => !y.hidden)\n      .map(({ i }) => i);\n    return {\n      data: { ...data, ys: visibleIndices.map(i => data.ys[i]) },\n      visibleIndices,\n    };\n  }\n\n  function waterfallTransform(data: LabeledData): LabeledData {\n    const newData = {\n      ...data,\n      x: [...data.x, { label: 'Total' }],\n      ys: [\n        ...data.ys.map(y => ({\n          ...y,\n          values: [...y.values, y.values.reduce((a, b) => a + b, 0)],\n        })),\n      ],\n    };\n    return newData;\n  }\n\n  type ValueType = 'count' | 'currency' | 'percentage' | 'days';\n\n  export function getPipes(valueType: ValueType) {\n    switch (valueType) {\n      case 'count': {\n        const pipe = new NumberPipe();\n        return { pipe, fullPipe: pipe };\n      }\n      case 'currency':\n        return {\n          pipe: new SmallCurrencyPipe(),\n          fullPipe: new CurrencyPipe('en-us'),\n        };\n      case 'percentage': {\n        const pipe = new PercentagePipe();\n        return { pipe, fullPipe: pipe };\n      }\n      case 'days': {\n        const pipe = new DaysPipe();\n        return { pipe, fullPipe: pipe };\n      }\n    }\n  }\n\n  export const intervals = ['year', 'quarter', 'month', 'week', 'day'] as const;\n  export type Interval = (typeof intervals)[number];\n\n  export function formatedDate(dateFormat: Interval, date: Date) {\n    if (dateFormat == 'quarter') {\n      const quarter = Math.ceil((date.getUTCMonth() + 1) / 3);\n      const year = utcFormat(getTimeIntervalFormat('year'))(date);\n      return `Q${quarter} ${year}`;\n    }\n    const format = getTimeIntervalFormat(dateFormat);\n    return utcFormat(format)(date);\n  }\n\n  export function getTimeIntervalFormat(interval: Interval): string {\n    switch (interval) {\n      case 'day':\n      case 'week':\n        return '%m/%d/%Y';\n      case 'month':\n      case 'quarter':\n        return '%b %Y';\n      case 'year':\n        return '%Y';\n    }\n  }\n\n  export function convertChartDataToDonutData(chartData: Data): DonutData[] {\n    if (chartData.ys.find(y => y.values.length > 1)) {\n      // eslint-disable-next-line no-console\n      console.warn(\n        \"Heads up! Pie charts don't support multiple values per series\",\n      );\n    }\n\n    const donutData = chartData.ys.map(y => ({\n      label: y.label,\n      hidden: y.hidden,\n      value: y.values.length >= 1 ? y.values[0] : 0,\n      isSecondary: y.isSecondary,\n    }));\n    return donutData;\n  }\n\n  function checkYScaleType(\n    input:\n      | ScaleTime<number, number, never>\n      | ScaleLinear<number, number, never>,\n    dataType: 'labeled' | 'timeseries' | undefined,\n  ): input is ScaleTime<number, number, never> {\n    if (dataType == 'labeled') {\n      return false;\n    }\n    return true;\n  }\n\n  function arcToPoint(angle: number, radius: number) {\n    return {\n      x: radius * Math.cos(angle - Math.PI / 2),\n      y: radius * Math.sin(angle - Math.PI / 2),\n    };\n  }\n}\n"]}
2009
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chart.js","sourceRoot":"","sources":["../../../../../../projects/riv/src/lib/visualization/chart/chart.ts"],"names":[],"mappings":"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","sourcesContent":["import { CurrencyPipe } from '@angular/common';\nimport { ScaleLinear, scaleLinear, ScaleTime, scaleUtc } from 'd3-scale';\nimport { arc, area, line, pie } from 'd3-shape';\nimport { utcFormat } from 'd3-time-format';\nimport { isNumber } from 'lodash';\nimport { DaysPipe } from '../../format/pipes/days.pipe';\nimport { NumberPipe } from '../../format/pipes/number.pipe';\nimport { PercentagePipe } from '../../format/pipes/percentage.pipe';\nimport { SmallCurrencyPipe } from '../../format/pipes/small-currency.pipe';\n\nexport namespace Chart {\n  export const defaultColorPalette = [\n    //Base colors\n    '--baja-blast-50',\n    '--teal-diamond-50',\n    '--fyre-50',\n    '--tang-50',\n    '--purp-60',\n    '--rosi-70',\n    //Shift lighter from base by -20\n    '--baja-blast-30',\n    '--teal-diamond-30',\n    '--fyre-30',\n    '--tang-30',\n    '--purp-40',\n    '--rosi-50',\n    //Shift darker from base by +20\n    '--baja-blast-70',\n    '--teal-diamond-70',\n    '--fyre-70',\n    '--tang-70',\n    '--purp-80',\n    '--rosi-90',\n  ];\n\n  export function chart(config: Config, data: Data, dimensions: Dimensions) {\n    return config.type == 'line'\n      ? lines(config, data, dimensions)\n      : config.type == 'area'\n      ? areas(config, data, dimensions)\n      : config.type == 'donut'\n      ? arcs(config, data, dimensions)\n      : config.type == 'horizontal-bar'\n      ? horizontalBars(config, data, dimensions)\n      : config.type == 'bar'\n      ? bars(config, data, dimensions)\n      : config.type == 'waterfall'\n      ? waterfall(config, data, dimensions)\n      : emptyChart;\n  }\n  export function lines(\n    config: Config,\n    allData: Data,\n    dimensions: Dimensions,\n  ): RenderedChart {\n    const { data: hiddenData, visibleIndices } = hide(allData);\n    if (hiddenData.type == 'labeled') {\n      // eslint-disable-next-line no-console\n      console.warn(\n        \"Heads up! Labeled series aren't currently supported for line charts\",\n      );\n      return emptyChart;\n    }\n    if (hiddenData.supplementaryYs && hiddenData.supplementaryYs.length > 0) {\n      // eslint-disable-next-line no-console\n      console.warn(\n        \"Heads up! Supplementary y values aren't supported for non-bar charts\",\n      );\n      return emptyChart;\n    }\n    //This assignment makes typescript recognize the actual type (TimeseriesData)\n    const data = hiddenData;\n    const xScale = scaleUtc(timeseriesDomain(data), xRange(dimensions, config));\n    const format = (date: Date) =>\n      formatedDate(config.dateFormat || 'day', date);\n\n    const tickCount = getTickCount(dimensions, config);\n    const xTicks = generateXTicks(data, xScale, tickCount, format);\n\n    const { pipe, fullPipe } = getPipes(config.valueType);\n    const { pipe: secondaryPipe, fullPipe: secondaryFullPipe } =\n      config.secondaryValueType\n        ? getPipes(config.secondaryValueType)\n        : {\n            pipe,\n            fullPipe,\n          };\n\n    const { scale, yTicks } = calcYScalesAndTicks(\n      data,\n      dimensions,\n      pipe,\n      secondaryPipe,\n      false,\n      config,\n    );\n\n    const colors = visibleIndices.map(\n      i => config.colors[i % config.colors.length],\n    );\n    const indices = data.x.map((_, i) => i);\n    const lines =\n      data.x.length > 1\n        ? data.ys.map(y =>\n            line<number>(\n              i => xScale(data.x[i]),\n              i => scale(y.values[i], y.isSecondary),\n            )(indices),\n          )\n        : [];\n    const circles =\n      data.x.length === 1\n        ? data.ys.map((ySeries, i) => ({\n            cx: xScale(data.x[0]),\n            cy: scale(ySeries.values[0], checkIfSecondary(data, i, 0)),\n          }))\n        : [];\n\n    const yOffset = SMALL_PADDING;\n    const dataLabels: DataLabel[] = data.ys.flatMap((y, yIndex) => {\n      const subLabels: DataLabel[] = y.values.map((val, xIndex) => ({\n        label:\n          (checkIfSecondary(data, yIndex, xIndex)\n            ? secondaryPipe.transform(val)\n            : pipe.transform(val)) ?? '',\n        yPos: scale(val, checkIfSecondary(data, yIndex, xIndex)) - yOffset,\n        xPos: xScale(data.x[xIndex]),\n        anchor: 'middle',\n      }));\n      return subLabels;\n    });\n\n    function hover(pos: { rect: DOMRect; x: number; y: number }) {\n      const xIndex = findNearestIndex(data.x, xScale.invert(pos.x).getTime());\n      const x = xScale(data.x[xIndex]);\n      const visibleYIndex = findNearestIndexWithSecondary(\n        data.ys.map((y, i) => ({\n          value: y.values[xIndex],\n          isSecondary: checkIfSecondary(data, i, xIndex),\n        })),\n        pos.y,\n        scale,\n      );\n      const yIndex = visibleIndices[visibleYIndex];\n      const ys = data.ys.map((y, i) =>\n        scale(y.values[xIndex], checkIfSecondary(data, i, xIndex)),\n      );\n\n      const format = (date: Date) =>\n        formatedDate(config.dateFormat || 'day', date);\n\n      const anchor = new DOMRect(\n        pos.rect.x + x,\n        pos.rect.y + ys[visibleYIndex],\n        8,\n        0,\n      );\n      return {\n        x,\n        xIndex,\n        ys,\n        yIndex,\n        visibleYIndex,\n        tooltip: {\n          anchor,\n          date: format(new Date(data.x[xIndex])),\n          metrics: data.ys\n            .map((y, index) => ({\n              color: colors[index % colors.length],\n              label: y.label,\n              value:\n                (checkIfSecondary(data, index, xIndex)\n                  ? secondaryFullPipe.transform(y.values[xIndex])\n                  : fullPipe.transform(y.values[xIndex])) ?? '-',\n            }))\n            .filter((_, i) => config.groupedTooltip || i == visibleYIndex),\n        },\n      };\n    }\n\n    return {\n      xTicks,\n      yTicks,\n      colors,\n      lines,\n      circles,\n      hover,\n      bars: [],\n      areas: [],\n      arcs: [],\n      horizontalBars: [],\n      dataLabels,\n      waterfallLines: [],\n    };\n  }\n\n  export function areas(\n    config: Config,\n    allData: Data,\n    dimensions: Dimensions,\n  ): RenderedChart {\n    const { data: uncheckedData, visibleIndices } = hide(allData);\n    if (uncheckedData.type == 'labeled') {\n      // eslint-disable-next-line no-console\n      console.warn(\n        \"Heads up! Labeled series aren't currently supported for area charts\",\n      );\n      return emptyChart;\n    }\n    if (config.showDataLabels == true) {\n      // eslint-disable-next-line no-console\n      console.warn(\n        \"Heads up! Data labels aren't supported for any stacked chart type\",\n      );\n      return emptyChart;\n    }\n    if (\n      uncheckedData.supplementaryYs &&\n      uncheckedData.supplementaryYs.length > 0\n    ) {\n      // eslint-disable-next-line no-console\n      console.warn(\n        \"Heads up! Supplementary y values aren't supported for non-bar charts\",\n      );\n      return emptyChart;\n    }\n    //This assignment makes typescript recognize the actual type (TimeseriesData)\n    const data = uncheckedData;\n    const xScale = scaleUtc(timeseriesDomain(data), xRange(dimensions, config));\n    const format = (date: Date) =>\n      formatedDate(config.dateFormat || 'day', date);\n    const tickCount = getTickCount(dimensions, config);\n    const xTicks = generateXTicks(data, xScale, tickCount, format);\n\n    const { pipe, fullPipe } = getPipes(config.valueType);\n    const { pipe: secondaryPipe, fullPipe: secondaryFullPipe } =\n      config.secondaryValueType\n        ? getPipes(config.secondaryValueType)\n        : {\n            pipe,\n            fullPipe,\n          };\n\n    const { scale, yTicks } = calcYScalesAndTicks(\n      data,\n      dimensions,\n      pipe,\n      secondaryPipe,\n      true,\n      config,\n    );\n    const zeroAxisPosVal = scale(0, true);\n\n    const indices = data.x.map((_, i) => i);\n    const colors = visibleIndices.map(\n      i => config.colors[i % config.colors.length],\n    );\n    const areas = data.ys.map((y, yIndex) =>\n      area<number>(\n        i => xScale(data.x[i]),\n        i => getBarYInfo(data, yIndex, i, scale, true).yValue,\n        i =>\n          getBarYInfo(data, yIndex, i, scale, true).yValue +\n          getBarYInfo(data, yIndex, i, scale, true).height,\n      )(indices),\n    );\n\n    function hover(pos: { rect: DOMRect; x: number; y: number }) {\n      const xIndex = findNearestIndex(data.x, xScale.invert(pos.x).getTime());\n      const x = xScale(data.x[xIndex]);\n      const fullYs = data.ys.map((_, mapYIndex) =>\n        getBarYInfo(data, mapYIndex, xIndex, scale, true),\n      );\n      const ys = fullYs.map(y => y.yValue);\n      //This is the ys array, but shifted so that the y position for negative values is away from the axis (for the hover circles)\n      const shiftedYs = fullYs.map(y => {\n        if (y.yValue >= zeroAxisPosVal) {\n          return y.yValue + y.height;\n        }\n        return y.yValue;\n      });\n      const yPosSign = zeroAxisPosVal - pos.y;\n      let visibleYIndex = -1;\n      if (yPosSign < 0 && data.ys.find(y => y.values.find(val => val < 0))) {\n        for (let i = ys.length - 1; i >= 0; i--) {\n          if (ys[i] >= zeroAxisPosVal && ys[i] < pos.y) {\n            visibleYIndex = i;\n            break;\n          }\n        }\n      } else {\n        for (let i = 0; i < ys.length; i++) {\n          if (ys[i] <= zeroAxisPosVal && ys[i] < pos.y) {\n            visibleYIndex = i;\n            break;\n          }\n        }\n      }\n      if (visibleYIndex == -1) {\n        if (pos.y < zeroAxisPosVal) {\n          visibleYIndex = ys.indexOf(Math.min(...ys));\n        }\n        if (pos.y > zeroAxisPosVal) {\n          visibleYIndex = ys.indexOf(Math.max(...ys));\n        }\n      }\n      const yIndex = visibleIndices[visibleYIndex];\n      const anchor = new DOMRect(\n        pos.rect.x + x,\n        pos.rect.y + shiftedYs[visibleYIndex],\n        SMALL_PADDING,\n        0,\n      );\n      return {\n        x,\n        xIndex,\n        ys: shiftedYs,\n        yIndex,\n        visibleYIndex,\n        tooltip: {\n          anchor,\n          date: utcFormat('%B %d, %Y')(new Date(data.x[xIndex])),\n          metrics: data.ys\n            .map((y, index) => ({\n              color: colors[index % colors.length],\n              label: y.label,\n              value:\n                (checkIfSecondary(data, index, xIndex)\n                  ? secondaryFullPipe.transform(y.values[xIndex])\n                  : fullPipe.transform(y.values[xIndex])) ?? '-',\n            }))\n            .filter((_, i) => config.groupedTooltip || i == visibleYIndex),\n        },\n      };\n    }\n\n    return {\n      xTicks,\n      yTicks,\n      colors,\n      areas,\n      lines: [],\n      circles: [],\n      hover,\n      bars: [],\n      arcs: [],\n      horizontalBars: [],\n      dataLabels: [],\n      waterfallLines: [],\n    };\n  }\n\n  export function bars(\n    config: BarConfig,\n    allData: Data,\n    dimensions: Dimensions,\n  ): RenderedChart {\n    const { data: uncheckedData, visibleIndices } = hide(allData);\n    if (uncheckedData.type == 'labeled') {\n      // eslint-disable-next-line no-console\n      console.warn(\n        \"Heads up! Labeled series aren't currently supported for vertical bar charts\",\n      );\n      return emptyChart;\n    }\n    //When there's only 1 series, the distinction between 'stacked' and 'clustered' doesn't apply\n    const isSingleSeries = uncheckedData.ys.length == 1;\n    if (\n      config.showDataLabels == true &&\n      config.groupingType == 'stacked' &&\n      !isSingleSeries\n    ) {\n      // eslint-disable-next-line no-console\n      console.warn(\n        \"Heads up! Data labels aren't supported for any stacked chart type\",\n      );\n      return emptyChart;\n    }\n    if (\n      uncheckedData.supplementaryYs &&\n      uncheckedData.supplementaryYs.length > 0 &&\n      config.groupingType == 'clustered' &&\n      !isSingleSeries\n    ) {\n      // eslint-disable-next-line no-console\n      console.warn(\n        \"Heads up! Supplementary y values aren't supported for clustered data (just use another normal y series)\",\n      );\n      return emptyChart;\n    }\n    //This assignment makes typescript recognize the actual type (TimeseriesData)\n    const data = uncheckedData;\n    const { range: xRange, binSize } = barXRange(dimensions, data, config);\n    const halfBinSize = binSize / 2;\n    const xScale = scaleUtc(timeseriesDomain(data), xRange);\n    const format = (date: Date) =>\n      formatedDate(config.dateFormat || 'day', date);\n    const tickCount = getTickCount(dimensions, config);\n    const xTicks = generateXTicks(data, xScale, tickCount, format);\n\n    const { pipe, fullPipe } = getPipes(config.valueType);\n    const { pipe: secondaryPipe, fullPipe: secondaryFullPipe } =\n      config.secondaryValueType\n        ? getPipes(config.secondaryValueType)\n        : {\n            pipe,\n            fullPipe,\n          };\n\n    const { scale, yTicks } = calcYScalesAndTicks(\n      data,\n      dimensions,\n      pipe,\n      secondaryPipe,\n      config.groupingType == 'stacked',\n      config,\n    );\n\n    const colors = visibleIndices.map(\n      i => config.colors[i % config.colors.length],\n    );\n    const bars = data.ys.map((y, yIndex) =>\n      y.values.map((_, index) => {\n        const { yValue, height } = getBarYInfo(\n          data,\n          yIndex,\n          index,\n          scale,\n          config.groupingType == 'stacked',\n        );\n        let xValue = xScale(data.x[index]) - halfBinSize;\n        let width = binSize;\n        if (config.groupingType == 'clustered') {\n          width =\n            (binSize - (data.ys.length - 1) * SMALL_PADDING) / data.ys.length;\n          const offset = yIndex * (width + SMALL_PADDING);\n          xValue = xValue + offset;\n        }\n        const yInclSuppCount = data.supplementaryYs\n          ? data.supplementaryYs.filter(y => y.associatedYIndex == yIndex)\n              .length + 1\n          : 1;\n        if (yInclSuppCount > 1) {\n          width =\n            (binSize - (yInclSuppCount - 1) * SMALL_PADDING) / yInclSuppCount;\n        }\n\n        return {\n          x: xValue,\n          y: yValue,\n          width,\n          height,\n        };\n      }),\n    );\n    let suppBars: {\n      x: number;\n      y: number;\n      width: number;\n      height: number;\n    }[][] = [];\n    if (data.supplementaryYs) {\n      suppBars = data.supplementaryYs.map((y, yIndex) =>\n        y.values.map((_, index) => {\n          const { yValue, height } = getBarYInfo(\n            data,\n            yIndex,\n            index,\n            scale,\n            config.groupingType == 'stacked',\n            true,\n          );\n          let xValue = xScale(data.x[index]) - halfBinSize;\n          let width = binSize;\n          const matchingYSupps = data.supplementaryYs\n            ? data.supplementaryYs.filter(\n                suppY => suppY.associatedYIndex == y.associatedYIndex,\n              )\n            : [];\n          const yInclSuppCount = matchingYSupps.length + 1;\n          const ySuppMatchingIndex = y.supplementalIndex + 1;\n          if (yInclSuppCount > 1) {\n            const xCalc = calculateXValueAndOffsetForBars(\n              binSize,\n              yInclSuppCount,\n              ySuppMatchingIndex,\n              xValue,\n            );\n            width = xCalc.width;\n            xValue = xCalc.xValue;\n          }\n          return {\n            x: xValue,\n            y: yValue,\n            width,\n            height,\n          };\n        }),\n      );\n      bars.push(...suppBars);\n    }\n    const zeroAxisPosVal = scale(0, true);\n    const dataLabels: DataLabel[] = data.ys.flatMap((y, yIndex) => {\n      const subLabels: DataLabel[] = y.values.map((val, xIndex) => {\n        const isNegativeBar =\n          bars[yIndex][xIndex].y >= zeroAxisPosVal &&\n          bars[yIndex][xIndex].height > 0;\n        const yOffset = isNegativeBar\n          ? SMALL_PADDING + DATA_LABEL_HEIGHT + bars[yIndex][xIndex].height\n          : -SMALL_PADDING;\n        return {\n          label:\n            (checkIfSecondary(data, yIndex, xIndex)\n              ? secondaryPipe.transform(val)\n              : pipe.transform(val)) ?? '',\n          yPos: bars[yIndex][xIndex].y + yOffset,\n          xPos: bars[yIndex][xIndex].x + bars[yIndex][xIndex].width / 2,\n          anchor: 'middle',\n        };\n      });\n      return subLabels;\n    });\n    if (data.supplementaryYs) {\n      const suppDataLabels: DataLabel[] = data.supplementaryYs.flatMap(\n        (y, yIndex) => {\n          const subLabels: DataLabel[] = y.values.map((val, xIndex) => {\n            const isNegativeBar =\n              suppBars[yIndex][xIndex].y >= zeroAxisPosVal &&\n              suppBars[yIndex][xIndex].height > 0;\n            const yOffset = isNegativeBar\n              ? SMALL_PADDING +\n                DATA_LABEL_HEIGHT +\n                suppBars[yIndex][xIndex].height\n              : -SMALL_PADDING;\n            return {\n              label:\n                (checkIfSecondary(data, yIndex, xIndex, true)\n                  ? secondaryPipe.transform(val)\n                  : pipe.transform(val)) ?? '',\n              yPos: suppBars[yIndex][xIndex].y + yOffset,\n              xPos:\n                suppBars[yIndex][xIndex].x + suppBars[yIndex][xIndex].width / 2,\n              anchor: 'middle',\n            };\n          });\n          return subLabels;\n        },\n      );\n      dataLabels.push(...suppDataLabels);\n    }\n\n    function hover(pos: { rect: DOMRect; x: number; y: number }) {\n      const xIndex = findNearestIndex(data.x, xScale.invert(pos.x).getTime());\n      const x = xScale(data.x[xIndex]);\n      let isSuppValue: boolean = false;\n      let suppIndexVal = 0;\n      let yInclSuppCount = 1;\n      if (data.supplementaryYs) {\n        yInclSuppCount = getClusterCountWithSupp(data);\n        suppIndexVal = findSubIndex(x, pos.x, binSize, yInclSuppCount) - 1;\n        if (suppIndexVal >= 0) {\n          isSuppValue = true;\n        }\n      }\n      const ys = data.ys.map((_, mapYIndex) =>\n        isSuppValue\n          ? getSuppBarYInfoViaYIndex(\n              data,\n              mapYIndex,\n              suppIndexVal,\n              xIndex,\n              scale,\n              config.groupingType == 'stacked',\n            ).yValue\n          : getBarYInfo(\n              data,\n              mapYIndex,\n              xIndex,\n              scale,\n              config.groupingType == 'stacked',\n            ).yValue,\n      );\n      const yPosSign = zeroAxisPosVal - pos.y;\n      let visibleYIndex = -1;\n      if (yPosSign < 0 && data.ys.find(y => y.values.find(val => val < 0))) {\n        for (let i = ys.length - 1; i >= 0; i--) {\n          if (ys[i] >= zeroAxisPosVal && ys[i] < pos.y) {\n            visibleYIndex = i;\n            break;\n          }\n        }\n      } else {\n        for (let i = 0; i < ys.length; i++) {\n          if (ys[i] <= zeroAxisPosVal && ys[i] < pos.y) {\n            visibleYIndex = i;\n            break;\n          }\n        }\n      }\n      if (config.groupingType == 'clustered') {\n        visibleYIndex = findSubIndex(x, pos.x, binSize, data.ys.length);\n      }\n      if (visibleYIndex == -1) {\n        if (pos.y < zeroAxisPosVal) {\n          visibleYIndex = ys.indexOf(Math.min(...ys));\n        }\n        if (pos.y > zeroAxisPosVal) {\n          visibleYIndex = ys.indexOf(Math.max(...ys));\n        }\n      }\n      const yIndex = visibleIndices[visibleYIndex];\n      const { yValue, height } = isSuppValue\n        ? getSuppBarYInfoViaYIndex(\n            data,\n            yIndex,\n            suppIndexVal,\n            xIndex,\n            scale,\n            config.groupingType == 'stacked',\n          )\n        : getBarYInfo(\n            data,\n            yIndex,\n            xIndex,\n            scale,\n            config.groupingType == 'stacked',\n          );\n\n      const xCalc = calculateXValueAndOffsetForBars(\n        binSize,\n        yInclSuppCount,\n        suppIndexVal + 1,\n        xScale(data.x[xIndex]) - halfBinSize,\n      );\n      const anchorX = isSuppValue\n        ? xCalc.xValue\n        : bars[visibleYIndex][xIndex].x;\n      const anchorWidth = isSuppValue\n        ? xCalc.width\n        : bars[visibleYIndex][xIndex].width;\n      const anchor = new DOMRect(\n        pos.rect.x + anchorX - SMALL_PADDING,\n        pos.rect.y + yValue,\n        anchorWidth + SMALL_PADDING * 2,\n        height,\n      );\n      //We need to preserve the original index for the later checkIfSecondary call\n      const ysForMetrics: {\n        data: SupplementaryDataY | DataY;\n        originalIndex: number;\n      }[] =\n        isSuppValue && data.supplementaryYs\n          ? data.supplementaryYs\n              .map((suppY, index) => ({ data: suppY, originalIndex: index }))\n              .filter(suppY => suppY.data.supplementalIndex == suppIndexVal)\n          : data.ys.map((y, index) => ({ data: y, originalIndex: index }));\n      return {\n        x,\n        xIndex,\n        ys,\n        yIndex,\n        visibleYIndex,\n        tooltip: {\n          anchor,\n          date: utcFormat('%B %d, %Y')(new Date(data.x[xIndex])),\n          metrics: ysForMetrics\n            .map((y, index) => ({\n              color:\n                colors[\n                  'associatedYIndex' in y.data\n                    ? y.data.associatedYIndex\n                    : index % colors.length\n                ],\n              label: y.data.label,\n              value:\n                (checkIfSecondary(data, y.originalIndex, xIndex, isSuppValue)\n                  ? secondaryFullPipe.transform(y.data.values[xIndex])\n                  : fullPipe.transform(y.data.values[xIndex])) ?? '-',\n            }))\n            .filter((_, i) => config.groupedTooltip || i == visibleYIndex),\n        },\n      };\n    }\n\n    return {\n      xTicks,\n      yTicks,\n      colors,\n      bars,\n      lines: [],\n      circles: [],\n      areas: [],\n      hover,\n      arcs: [],\n      horizontalBars: [],\n      dataLabels,\n      waterfallLines: [],\n    };\n  }\n\n  export function horizontalBars(\n    config: BarConfig,\n    allData: Data,\n    dimensions: Dimensions,\n  ): RenderedChart {\n    //Some of this stuff gets confusing, because x and y are essentially inverted here\n    //  So, if you see a situation where a variable is named 'y', but referencing\n    //  'x' (or vice versa), that's why\n    const { data, visibleIndices } = hide(allData);\n    //'Metric' charts are a special case for horizontal bar charts, where each series is also a bucket (and vice versa)\n    const isMetricChart =\n      data.x.length == data.ys.length &&\n      data.ys.length ==\n        data.ys.filter(y => y.values.filter(val => val != 0).length == 1)\n          .length;\n    //When there's only 1 series, the distinction between 'stacked' and 'clustered' doesn't apply\n    const isSingleSeries = data.ys.length == 1;\n    if (\n      config.showDataLabels == true &&\n      config.groupingType == 'stacked' &&\n      !isMetricChart &&\n      !isSingleSeries\n    ) {\n      // eslint-disable-next-line no-console\n      console.warn(\n        \"Heads up! Data labels aren't supported for any stacked chart type\",\n      );\n      return emptyChart;\n    }\n    if (\n      data.supplementaryYs &&\n      data.supplementaryYs.length > 0 &&\n      config.groupingType == 'clustered' &&\n      !isSingleSeries\n    ) {\n      // eslint-disable-next-line no-console\n      console.warn(\n        \"Heads up! Supplementary y values aren't supported for clustered data (just use another normal y series)\",\n      );\n      return emptyChart;\n    }\n    const { range: yRange } = barYRange(dimensions, data, config);\n    let yScale =\n      data.type == 'labeled'\n        ? scaleLinear(indexDomain(data), yRange)\n        : scaleUtc(timeseriesDomain(data), yRange);\n    const dateFormat = (date: Date) =>\n      formatedDate(config.dateFormat || 'day', date);\n    const { pipe, fullPipe } = getPipes(config.valueType);\n    const { pipe: secondaryPipe, fullPipe: secondaryFullPipe } =\n      config.secondaryValueType\n        ? getPipes(config.secondaryValueType)\n        : {\n            pipe,\n            fullPipe,\n          };\n    const yTicks = yScale.ticks(Math.max(data.x.length - 1, 1)).map(tick => ({\n      y: yScale(tick),\n      label: isNumber(tick)\n        ? data.type == 'labeled'\n          ? data.x[tick].label\n          : '-'\n        : dateFormat(tick),\n    }));\n\n    const { scale, xTicks } = calcXScalesAndTicks(\n      data,\n      dimensions,\n      pipe,\n      secondaryPipe,\n      config.groupingType == 'stacked',\n      config,\n    );\n    const zeroAxisPosVal = scale(0, true);\n    const colors = visibleIndices.map(\n      i => config.colors[i % config.colors.length],\n    );\n    const simplifiedHorizontalBars: {\n      xPos: number;\n      yPos: number;\n      width: number;\n    }[][] = [];\n    const horizontalBars = data.ys.map((y, yIndex) => {\n      const subSimpHorBars: {\n        xPos: number;\n        yPos: number;\n        width: number;\n      }[] = [];\n      const retVal = y.values.map((_, index) => {\n        const { xValue, width } = getBarXInfo(\n          data,\n          yIndex,\n          index,\n          scale,\n          config.groupingType == 'stacked',\n        );\n\n        let yValue =\n          yScale(data.type == 'labeled' ? index : data.x[index]) -\n          HORIZONTAL_BAR_HEIGHT * 1.5;\n        if (config.groupingType == 'clustered') {\n          const centerIndex = data.ys.length / 2 - 0.5;\n          const offset =\n            (yIndex - centerIndex) * (HORIZONTAL_BAR_HEIGHT + SMALL_PADDING);\n          yValue = yValue + offset;\n        }\n        const matchingYSupps = data.supplementaryYs\n          ? data.supplementaryYs.filter(\n              suppY => suppY.associatedYIndex == yIndex,\n            )\n          : [];\n        const yInclSuppCount = matchingYSupps.length + 1;\n        const ySuppMatchingIndex = 0;\n        if (yInclSuppCount > 1) {\n          const centerIndex = yInclSuppCount / 2 - 0.5;\n          const offset =\n            (ySuppMatchingIndex - centerIndex) *\n            (HORIZONTAL_BAR_HEIGHT + SMALL_PADDING);\n          yValue = yValue + offset;\n        }\n\n        const horR = Math.min(4, Math.floor(width / 2));\n        const verR = Math.min(4, Math.floor(HORIZONTAL_BAR_HEIGHT / 2));\n        subSimpHorBars.push({\n          xPos: xValue,\n          yPos: yValue,\n          width,\n        });\n        //Don't draw anything for zero-value bars\n        if (width == 0) {\n          return '';\n        }\n\n        const isPositive = data.ys[yIndex].values[index] > 0;\n        const hasAnyNegativeBars = data.ys\n          .map(y => y.values[index])\n          .find(val => val < 0);\n        const hasAnyPositiveBars = data.ys\n          .map(y => y.values[index])\n          .find(val => val > 0);\n\n        //These checks are to make sure we still round if all previous/later values are 0\n        const allLeftZero = isPositive\n          ? data.ys\n              .slice(0, yIndex)\n              .map(y => y.values[index])\n              .filter(val => val > 0).length == 0 && !hasAnyNegativeBars\n          : data.ys\n              .slice(yIndex + 1, data.ys.length)\n              .map(y => y.values[index])\n              .filter(val => val < 0).length == 0;\n        const leftSideRound = config.groupingType == 'clustered' || allLeftZero;\n        const allRightZero = isPositive\n          ? data.ys\n              .slice(yIndex + 1, data.ys.length)\n              .map(y => y.values[index])\n              .filter(val => val > 0).length == 0\n          : data.ys\n              .slice(0, yIndex)\n              .map(y => y.values[index])\n              .filter(val => val < 0).length == 0 && !hasAnyPositiveBars;\n        const rightSideRound =\n          config.groupingType == 'clustered' || allRightZero;\n        const pathD = calculateHorizontalBarPath(\n          leftSideRound,\n          rightSideRound,\n          xValue,\n          yValue,\n          horR,\n          verR,\n          width,\n        );\n        return pathD;\n      });\n      simplifiedHorizontalBars.push(subSimpHorBars);\n      return retVal;\n    });\n    const suppYs = data.supplementaryYs;\n    const simplifiedSuppHorizontalBars: {\n      xPos: number;\n      yPos: number;\n      width: number;\n    }[][] = [];\n    if (suppYs) {\n      const suppHorizontalBars = suppYs.map((y, yIndex) => {\n        const subSimpHorBars: {\n          xPos: number;\n          yPos: number;\n          width: number;\n        }[] = [];\n        const retVal = y.values.map((_, index) => {\n          const { xValue, width } = getBarXInfo(\n            data,\n            yIndex,\n            index,\n            scale,\n            config.groupingType == 'stacked',\n            true,\n          );\n\n          let yValue =\n            yScale(data.type == 'labeled' ? index : data.x[index]) -\n            HORIZONTAL_BAR_HEIGHT * 1.5;\n          const matchingYSupps = data.supplementaryYs\n            ? data.supplementaryYs.filter(\n                suppY => suppY.associatedYIndex == y.associatedYIndex,\n              )\n            : [];\n          const yInclSuppCount = matchingYSupps.length + 1;\n          const ySuppMatchingIndex = y.supplementalIndex + 1;\n          if (yInclSuppCount > 1) {\n            const centerIndex = yInclSuppCount / 2 - 0.5;\n            const offset =\n              (ySuppMatchingIndex - centerIndex) *\n              (HORIZONTAL_BAR_HEIGHT + SMALL_PADDING);\n            yValue = yValue + offset;\n          }\n\n          const horR = Math.min(4, Math.floor(width / 2));\n          const verR = Math.min(4, Math.floor(HORIZONTAL_BAR_HEIGHT / 2));\n          subSimpHorBars.push({\n            xPos: xValue,\n            yPos: yValue,\n            width,\n          });\n          //Don't draw anything for zero-value bars\n          if (width == 0) {\n            return '';\n          }\n\n          const isPositive = suppYs[yIndex].values[index] > 0;\n          const hasAnyNegativeBars = suppYs\n            .filter(suppY => suppY.supplementalIndex == y.supplementalIndex)\n            .map(y => y.values[index])\n            .find(val => val < 0);\n          const hasAnyPositiveBars = suppYs\n            .filter(suppY => suppY.supplementalIndex == y.supplementalIndex)\n            .map(y => y.values[index])\n            .find(val => val > 0);\n\n          //These checks are to make sure we still round if all previous/later values are 0\n          const allLeftZero = isPositive\n            ? suppYs\n                .slice(0, yIndex)\n                .filter(suppY => suppY.supplementalIndex == y.supplementalIndex)\n                .map(y => y.values[index])\n                .filter(val => val > 0).length == 0 && !hasAnyNegativeBars\n            : suppYs\n                .slice(yIndex + 1, suppYs.length)\n                .filter(suppY => suppY.supplementalIndex == y.supplementalIndex)\n                .map(y => y.values[index])\n                .filter(val => val < 0).length == 0;\n          const leftSideRound =\n            config.groupingType == 'clustered' || allLeftZero;\n          const allRightZero = isPositive\n            ? suppYs\n                .slice(yIndex + 1, suppYs.length)\n                .filter(suppY => suppY.supplementalIndex == y.supplementalIndex)\n                .map(y => y.values[index])\n                .filter(val => val > 0).length == 0\n            : suppYs\n                .slice(0, yIndex)\n                .filter(suppY => suppY.supplementalIndex == y.supplementalIndex)\n                .map(y => y.values[index])\n                .filter(val => val < 0).length == 0 && !hasAnyPositiveBars;\n          const rightSideRound =\n            config.groupingType == 'clustered' || allRightZero;\n          const pathD = calculateHorizontalBarPath(\n            leftSideRound,\n            rightSideRound,\n            xValue,\n            yValue,\n            horR,\n            verR,\n            width,\n          );\n          return pathD;\n        });\n        simplifiedSuppHorizontalBars.push(subSimpHorBars);\n        return retVal;\n      });\n      horizontalBars.push(...suppHorizontalBars);\n    }\n\n    const yOffset = HORIZONTAL_BAR_HEIGHT;\n    const dataLabels: DataLabel[] = data.ys.flatMap((y, yIndex) => {\n      const subLabels: DataLabel[] = y.values.map((val, xIndex) => {\n        const barIsNegative =\n          simplifiedHorizontalBars[yIndex][xIndex].xPos < zeroAxisPosVal &&\n          simplifiedHorizontalBars[yIndex][xIndex].width > 0;\n        const xOffset = barIsNegative\n          ? -SMALL_PADDING\n          : simplifiedHorizontalBars[yIndex][xIndex].width + SMALL_PADDING;\n        return {\n          label:\n            (checkIfSecondary(data, yIndex, xIndex)\n              ? secondaryPipe.transform(val)\n              : pipe.transform(val)) ?? '',\n          yPos: simplifiedHorizontalBars[yIndex][xIndex].yPos + yOffset,\n          xPos: simplifiedHorizontalBars[yIndex][xIndex].xPos + xOffset,\n          anchor: barIsNegative ? 'end' : 'start',\n        };\n      });\n      return subLabels;\n    });\n    if (suppYs) {\n      const suppDataLabels: DataLabel[] = suppYs.flatMap((y, yIndex) => {\n        const subLabels: DataLabel[] = y.values.map((val, xIndex) => {\n          const barIsNegative =\n            simplifiedSuppHorizontalBars[yIndex][xIndex].xPos <\n              zeroAxisPosVal &&\n            simplifiedSuppHorizontalBars[yIndex][xIndex].width > 0;\n          const xOffset = barIsNegative\n            ? -SMALL_PADDING\n            : simplifiedSuppHorizontalBars[yIndex][xIndex].width +\n              SMALL_PADDING;\n          return {\n            label:\n              (checkIfSecondary(data, yIndex, xIndex, true)\n                ? secondaryPipe.transform(val)\n                : pipe.transform(val)) ?? '',\n            yPos: simplifiedSuppHorizontalBars[yIndex][xIndex].yPos + yOffset,\n            xPos: simplifiedSuppHorizontalBars[yIndex][xIndex].xPos + xOffset,\n            anchor: barIsNegative ? 'end' : 'start',\n          };\n        });\n        return subLabels;\n      });\n      dataLabels.push(...suppDataLabels);\n    }\n\n    function hover(pos: { rect: DOMRect; x: number; y: number }) {\n      let xIndex: number = 0;\n      let x = 0;\n      if (checkYScaleType(yScale, data.type) && data.type != 'labeled') {\n        xIndex = findNearestIndex(data.x, yScale.invert(pos.y).getTime());\n        x = yScale(data.x[xIndex]) - SMALL_PADDING;\n      } else if (\n        !checkYScaleType(yScale, data.type) &&\n        data.type == 'labeled'\n      ) {\n        xIndex = findNearestIndexString(data.x, yScale.invert(pos.y));\n        x = yScale(xIndex) - SMALL_PADDING;\n      }\n      let isSuppValue: boolean = false;\n      let suppIndexVal = 0;\n      let yInclSuppCount = 1;\n      if (data.supplementaryYs) {\n        yInclSuppCount = getClusterCountWithSupp(data);\n        suppIndexVal = findSubIndexHorizontal(x, pos.y, yInclSuppCount) - 1;\n        if (suppIndexVal >= 0) {\n          isSuppValue = true;\n        }\n      }\n      const fullYs = data.ys.map((_, mapYIndex) =>\n        isSuppValue\n          ? getSuppBarXInfoViaYIndex(\n              data,\n              mapYIndex,\n              suppIndexVal,\n              xIndex,\n              scale,\n              config.groupingType == 'stacked',\n            )\n          : getBarXInfo(\n              data,\n              mapYIndex,\n              xIndex,\n              scale,\n              config.groupingType == 'stacked',\n            ),\n      );\n      const ys = fullYs.map(y => y.xValue);\n      let visibleYIndex = -1;\n      for (let i = 0; i < fullYs.length; i++) {\n        const leftBorder = fullYs[i].xValue;\n        const rightBorderCandidates = fullYs\n          .filter(y => y.xValue > leftBorder)\n          .map(y => y.xValue);\n        const rightBorder =\n          rightBorderCandidates.length > 0\n            ? Math.min(...rightBorderCandidates)\n            : leftBorder + fullYs[i].width;\n        if (pos.x > leftBorder && pos.x < rightBorder) {\n          visibleYIndex = i;\n        }\n      }\n      if (config.groupingType == 'clustered') {\n        visibleYIndex = findSubIndexHorizontal(x, pos.y, data.ys.length);\n      }\n\n      if (visibleYIndex == -1) {\n        if (pos.x > zeroAxisPosVal) {\n          visibleYIndex = ys.indexOf(Math.max(...ys));\n        }\n        if (pos.x < zeroAxisPosVal) {\n          visibleYIndex = ys.indexOf(Math.min(...ys));\n        }\n      }\n      const yIndex = visibleIndices[visibleYIndex];\n\n      //Check if we've landed on a zero-width bar (only really relevant on ends)\n      if (\n        simplifiedHorizontalBars[visibleYIndex][xIndex].width == 0 &&\n        config.groupingType == 'stacked'\n      ) {\n        let altBarFound = false;\n        //Check upwards\n        for (\n          let i = visibleYIndex + 1;\n          i < simplifiedHorizontalBars.length;\n          i++\n        ) {\n          if (altBarFound) {\n            break;\n          }\n          if (simplifiedHorizontalBars[i][xIndex].width != 0) {\n            visibleYIndex = i;\n            altBarFound = true;\n          }\n        }\n\n        //Check downwards\n        for (let i = visibleYIndex - 1; i >= 0; i--) {\n          if (altBarFound) {\n            break;\n          }\n          if (simplifiedHorizontalBars[i][xIndex].width != 0) {\n            visibleYIndex = i;\n            altBarFound = true;\n          }\n        }\n      }\n\n      const suppYIndex =\n        isSuppValue && suppYs\n          ? suppYs.findIndex(\n              suppY =>\n                suppY.associatedYIndex == visibleYIndex &&\n                suppY.supplementalIndex == suppIndexVal,\n            )\n          : -1;\n\n      const barXPos = isSuppValue\n        ? simplifiedSuppHorizontalBars[suppYIndex][xIndex].xPos\n        : simplifiedHorizontalBars[visibleYIndex][xIndex].xPos;\n      const barYPos = isSuppValue\n        ? simplifiedSuppHorizontalBars[suppYIndex][xIndex].yPos\n        : simplifiedHorizontalBars[visibleYIndex][xIndex].yPos;\n      const barWidth = isSuppValue\n        ? simplifiedSuppHorizontalBars[suppYIndex][xIndex].width\n        : simplifiedHorizontalBars[visibleYIndex][xIndex].width;\n\n      const anchor = new DOMRect(\n        pos.rect.x + barXPos - SMALL_PADDING,\n        pos.rect.y + barYPos,\n        barWidth + SMALL_PADDING * 2,\n        HORIZONTAL_BAR_HEIGHT,\n      );\n      //We need to preserve the original index for the later checkIfSecondary call\n      const ysForMetrics: {\n        data: SupplementaryDataY | DataY;\n        originalIndex: number;\n      }[] =\n        isSuppValue && suppYs\n          ? suppYs\n              .map((suppY, index) => ({ data: suppY, originalIndex: index }))\n              .filter(suppY => suppY.data.supplementalIndex == suppIndexVal)\n          : data.ys.map((y, index) => ({ data: y, originalIndex: index }));\n      return {\n        x,\n        xIndex,\n        ys,\n        yIndex,\n        visibleYIndex,\n        tooltip: {\n          anchor,\n          date:\n            data.type == 'labeled'\n              ? data.x[xIndex].label\n              : utcFormat('%B %d, %Y')(new Date(data.x[xIndex])),\n          metrics: ysForMetrics\n            .map((y, index) => ({\n              color:\n                colors[\n                  'associatedYIndex' in y.data\n                    ? y.data.associatedYIndex\n                    : index % colors.length\n                ],\n              label: y.data.label,\n              value:\n                (checkIfSecondary(data, y.originalIndex, xIndex, isSuppValue)\n                  ? secondaryFullPipe.transform(y.data.values[xIndex])\n                  : fullPipe.transform(y.data.values[xIndex])) ?? '-',\n            }))\n            .filter((_, i) => config.groupedTooltip || i == visibleYIndex),\n        },\n      };\n    }\n\n    return {\n      xTicks: xTicks,\n      yTicks: yTicks,\n      hover,\n      colors,\n      bars: [],\n      lines: [],\n      circles: [],\n      areas: [],\n      arcs: [],\n      horizontalBars,\n      dataLabels,\n      waterfallLines: [],\n    };\n  }\n\n  export function arcs(\n    config: Config,\n    allData: Data,\n    dimensions: Dimensions,\n  ): RenderedChart {\n    if (\n      config.secondaryValueType &&\n      (config.valueType == 'percentage' ||\n        config.secondaryValueType == 'percentage')\n    ) {\n      // eslint-disable-next-line no-console\n      console.warn(\n        \"Heads up! Two axes with percentage aren't supported for donut charts\",\n      );\n      return emptyChart;\n    }\n    if (allData.supplementaryYs && allData.supplementaryYs.length > 0) {\n      // eslint-disable-next-line no-console\n      console.warn(\n        \"Heads up! Supplementary y values aren't supported for non-bar charts\",\n      );\n      return emptyChart;\n    }\n    const { data: unstackedData, visibleIndices } = hide(allData);\n    const donutData = Chart.convertChartDataToDonutData(unstackedData);\n    const hasNonZeroValue = donutData.some(d => d.value > 0);\n    const arcData = hasNonZeroValue\n      ? donutData\n      : [\n          {\n            label: '',\n            value: 1,\n          },\n        ];\n    const colors = hasNonZeroValue\n      ? visibleIndices.map(i => config.colors[i % config.colors.length])\n      : ['--gray-30'];\n    const { pipe, fullPipe } = getPipes(config.valueType);\n    const { pipe: secondaryPipe, fullPipe: secondaryFullPipe } =\n      config.secondaryValueType\n        ? getPipes(config.secondaryValueType)\n        : {\n            pipe,\n            fullPipe,\n          };\n\n    const outer = (dimensions.height / 2) * 0.75;\n    const inner = outer - 12;\n\n    const pieArcs = pie<DonutData>()\n      .sortValues(null)\n      .value(d => Math.max(d.value, 0))(arcData);\n\n    const arcs = pieArcs.map(pieArc =>\n      arc<DonutData>()\n        .innerRadius(inner)\n        .outerRadius(outer)\n        .padAngle(0.013)\n        .startAngle(pieArc.startAngle)\n        .endAngle(pieArc.endAngle)(pieArc.data),\n    );\n\n    const dataLabels: DataLabel[] = hasNonZeroValue\n      ? pieArcs.map(arc => {\n          //Don't show data labels for zero-width donut slices (includes negative values)\n          if (arc.startAngle == arc.endAngle) {\n            return {\n              label: '',\n              yPos: 0,\n              xPos: 0,\n              anchor: 'middle',\n            };\n          }\n          const arcCenterAngle = (arc.startAngle + arc.endAngle) / 2;\n          const edgePoint = arcToPoint(arcCenterAngle, outer);\n          const lineEndPoint = arcToPoint(arcCenterAngle, outer + 16);\n          const middleArea = outer / 4;\n          let yOffset = 0;\n          let xOffset = 0;\n          if (lineEndPoint.y > 0) {\n            if (Math.abs(lineEndPoint.y) < middleArea) {\n              yOffset = SMALL_PADDING / 2;\n            } else {\n              yOffset = SMALL_PADDING;\n            }\n            if (Math.abs(lineEndPoint.x) < middleArea) {\n              yOffset += SMALL_PADDING / 2;\n            }\n          } else {\n            if (Math.abs(lineEndPoint.y) < middleArea) {\n              yOffset = SMALL_PADDING / 2;\n            }\n            if (Math.abs(lineEndPoint.x) < middleArea) {\n              yOffset -= SMALL_PADDING / 2;\n            }\n          }\n          return {\n            label:\n              (arc.data.isSecondary\n                ? secondaryPipe.transform(arc.data.value)\n                : pipe.transform(arc.data.value)) ?? '',\n            yPos: lineEndPoint.y + yOffset,\n            xPos: lineEndPoint.x + xOffset,\n            anchor:\n              Math.abs(lineEndPoint.x) < middleArea\n                ? 'middle'\n                : lineEndPoint.x < 0\n                ? 'end'\n                : 'start',\n            line: {\n              x1: edgePoint.x,\n              y1: edgePoint.y,\n              x2: lineEndPoint.x,\n              y2: lineEndPoint.y,\n            },\n          };\n        })\n      : [];\n\n    return {\n      xTicks: [],\n      yTicks: [],\n      areas: [],\n      lines: [],\n      circles: [],\n      bars: [],\n      colors,\n      arcs,\n      horizontalBars: [],\n      dataLabels,\n      waterfallLines: [],\n    };\n  }\n\n  export function waterfall(\n    config: Config,\n    allData: Data,\n    dimensions: Dimensions,\n  ): RenderedChart {\n    const { data: uncheckedData, visibleIndices } = hide(allData);\n    if (uncheckedData.type == 'timeseries') {\n      // eslint-disable-next-line no-console\n      console.warn(\n        \"Heads up! Time-based series aren't currently supported for waterfall charts\",\n      );\n      return emptyChart;\n    }\n    if (\n      uncheckedData.supplementaryYs &&\n      uncheckedData.supplementaryYs.length > 0\n    ) {\n      // eslint-disable-next-line no-console\n      console.warn(\n        \"Heads up! Supplementary y values aren't supported for non-bar charts\",\n      );\n      return emptyChart;\n    }\n    if (config.secondaryValueType) {\n      // eslint-disable-next-line no-console\n      console.warn(\n        'Heads up! Waterfall charts do not currently have two-axis support',\n      );\n      return emptyChart;\n    }\n    //This assignment makes typescript recognize the actual type (TimeseriesData)\n    const data = waterfallTransform(uncheckedData);\n    const { range: xRange, binSize } = barXRange(dimensions, data, config);\n    const halfBinSize = binSize / 2;\n    const xScale = scaleLinear(indexDomain(data), xRange);\n    const tickCount = getTickCount(dimensions, config);\n    const xTicks = generateLabelledXTicks(data, xScale, tickCount);\n\n    const { pipe, fullPipe } = getPipes(config.valueType);\n\n    const { scale, yTicks } = calcYScalesAndTicks(\n      data,\n      dimensions,\n      pipe,\n      pipe,\n      true,\n      config,\n    );\n    const zeroAxisPosVal = scale(0, true);\n\n    const colors = visibleIndices.map(\n      i => config.colors[i % config.colors.length],\n    );\n    const bars = data.ys.map((y, yIndex) =>\n      y.values.map((_, index) => {\n        const { yValue, height } = getBarYInfo(\n          data,\n          yIndex,\n          index,\n          scale,\n          true,\n        );\n        let xValue = xScale(index) - halfBinSize;\n        let width = binSize;\n        return {\n          x: xValue,\n          y: yValue,\n          width,\n          height,\n          offset: 0,\n        };\n      }),\n    );\n\n    //Move bars based on height of previous bars (except the total bar)\n    let barOffsetRunningTotal = 0;\n    const waterfallLines: {\n      x1: number;\n      x2: number;\n      y1: number;\n      y2: number;\n    }[] = [];\n    for (let i = 0; i < data.x.length - 1; i++) {\n      let barOffsetChange = 0;\n      for (let j = 0; j < bars.length; j++) {\n        const barIsNegative =\n          bars[j][i].y >= zeroAxisPosVal && bars[j][i].height > 0;\n        if (barIsNegative) {\n          barOffsetChange -= bars[j][i].height;\n        } else {\n          barOffsetChange += bars[j][i].height;\n        }\n        bars[j][i].offset = barOffsetRunningTotal;\n        bars[j][i].y -= barOffsetRunningTotal;\n        if (j == bars.length - 1) {\n          const x1 = bars[j][i].x + bars[bars.length - 1][i].width;\n          const y1 = bars[j][i].y + (barIsNegative ? bars[j][i].height : 0);\n          const x2 = bars[j][i + 1].x;\n          const y2 = y1;\n          waterfallLines.push({\n            x1,\n            y1,\n            x2,\n            y2,\n          });\n        }\n      }\n      barOffsetRunningTotal += barOffsetChange;\n    }\n\n    const dataLabels: DataLabel[] = data.ys.flatMap((y, yIndex) => {\n      const subLabels: DataLabel[] = y.values.map((val, xIndex) => {\n        const isNegativeBar =\n          bars[yIndex][xIndex].y >= zeroAxisPosVal &&\n          bars[yIndex][xIndex].height > 0;\n        const yOffset = isNegativeBar\n          ? SMALL_PADDING + DATA_LABEL_HEIGHT + bars[yIndex][xIndex].height\n          : -SMALL_PADDING;\n        return {\n          label: pipe.transform(val) ?? '',\n          yPos: bars[yIndex][xIndex].y + yOffset,\n          xPos: bars[yIndex][xIndex].x + bars[yIndex][xIndex].width / 2,\n          anchor: 'middle',\n        };\n      });\n      return subLabels;\n    });\n\n    function hover(pos: { rect: DOMRect; x: number; y: number }) {\n      const xIndex = findNearestIndexString(data.x, xScale.invert(pos.x));\n      const x = xScale(xIndex);\n      const ys = bars.map(bar => bar[xIndex].y);\n      const yPosSign = zeroAxisPosVal - pos.y;\n      let visibleYIndex = -1;\n      if (yPosSign < 0 && data.ys.find(y => y.values.find(val => val < 0))) {\n        for (let i = ys.length - 1; i >= 0; i--) {\n          if (ys[i] >= zeroAxisPosVal && ys[i] < pos.y) {\n            visibleYIndex = i;\n            break;\n          }\n        }\n      } else {\n        for (let i = 0; i < ys.length; i++) {\n          if (ys[i] <= zeroAxisPosVal && ys[i] < pos.y) {\n            visibleYIndex = i;\n            break;\n          }\n        }\n      }\n      if (visibleYIndex == -1) {\n        if (pos.y < zeroAxisPosVal) {\n          visibleYIndex = ys.indexOf(Math.min(...ys));\n        }\n        if (pos.y > zeroAxisPosVal) {\n          visibleYIndex = ys.indexOf(Math.max(...ys));\n        }\n      }\n      const yIndex = visibleIndices[visibleYIndex];\n      const { yValue, height } = getBarYInfo(data, yIndex, xIndex, scale, true);\n      const anchor = new DOMRect(\n        pos.rect.x + bars[visibleYIndex][xIndex].x - SMALL_PADDING,\n        pos.rect.y + yValue - bars[visibleYIndex][xIndex].offset,\n        bars[visibleYIndex][xIndex].width + SMALL_PADDING * 2,\n        height,\n      );\n      return {\n        x,\n        xIndex,\n        ys,\n        yIndex,\n        visibleYIndex,\n        tooltip: {\n          anchor,\n          date: data.x[xIndex].label,\n          metrics: data.ys\n            .map((y, index) => ({\n              color: colors[index % colors.length],\n              label: y.label,\n              value: fullPipe.transform(y.values[xIndex]) ?? '-',\n            }))\n            .filter((_, i) => config.groupedTooltip || i == visibleYIndex),\n        },\n      };\n    }\n\n    return {\n      xTicks,\n      yTicks,\n      colors,\n      bars,\n      lines: [],\n      circles: [],\n      areas: [],\n      hover,\n      arcs: [],\n      horizontalBars: [],\n      dataLabels,\n      waterfallLines,\n    };\n  }\n\n  const LEFT_PADDING = 48;\n  const LEFT_PADDING_WITH_DATA_LABELS = 56;\n  const LEFT_PADDING_DATE = 64;\n  export const LEFT_PADDING_LABEL_MAX = 192;\n  export const RIGHT_PADDING = 48;\n  const RIGHT_PADDING_HORIZONTAL = 96;\n  const TOP_PADDING = 16;\n  const TOP_PADDING_WITH_DATA_LABELS = 36;\n  const BOTTOM_PADDING = 24;\n  const BOTTOM_PADDING_WITH_DATA_LABELS = 44;\n  const SMALL_PADDING = 8;\n  const HORIZONTAL_BAR_HEIGHT = 8;\n  const WIDTH_PER_LETTER = 6.5;\n  const MIN_TICK_SPACING = 100;\n  const MAX_X_TICKS = 6;\n  const DATA_LABEL_HEIGHT = 12;\n\n  function getTickCount(dimensions: Dimensions, config: Config): number {\n    const availableWidth =\n      dimensions.width -\n      (config.showDataLabels ? LEFT_PADDING_WITH_DATA_LABELS : LEFT_PADDING) -\n      RIGHT_PADDING;\n    return Math.min(\n      MAX_X_TICKS,\n      Math.max(2, Math.floor(availableWidth / MIN_TICK_SPACING)),\n    );\n  }\n\n  function generateXTicks(\n    data: TimeseriesData,\n    xScale: ScaleTime<number, number, never>,\n    tickCount: number,\n    format: (date: Date) => string,\n  ): XTick[] {\n    if (data.x.length === 0) {\n      return [];\n    }\n    if (data.x.length === 1 || tickCount <= 1) {\n      return [{ x: xScale(data.x[0]), label: format(new Date(data.x[0])) }];\n    }\n\n    const lastIndex = data.x.length - 1;\n    const numTicks = Math.min(tickCount, data.x.length);\n    const step = lastIndex / (numTicks - 1);\n\n    // Always include first and last data points.\n    // Inner ticks are approximately evenly spaced using rounding.\n    const indices: number[] = [];\n    for (let i = 0; i < numTicks; i++) {\n      indices.push(Math.round(i * step));\n    }\n\n    return indices.map(i => ({\n      x: xScale(data.x[i]),\n      label: format(new Date(data.x[i])),\n    }));\n  }\n\n  function generateLabelledXTicks(\n    data: LabeledData,\n    xScale: ScaleLinear<number, number, never>,\n    tickCount: number,\n  ): XTick[] {\n    if (data.x.length === 0) {\n      return [];\n    }\n    if (data.x.length === 1 || tickCount <= 1) {\n      return [{ x: xScale(0), label: data.x[0].label }];\n    }\n\n    const xTicks: XTick[] = [];\n    for (let i = 0; i < data.x.length; i++) {\n      xTicks.push({\n        x: xScale(i),\n        label: data.x[i].label,\n      });\n    }\n\n    return xTicks;\n  }\n\n  export type Data = LabeledData | TimeseriesData;\n\n  type BaseData = {\n    ys: DataY[];\n    supplementaryYs?: SupplementaryDataY[];\n  };\n\n  type DataY = {\n    label: string;\n    hidden?: boolean;\n    isSecondary?: boolean;\n    values: number[];\n  };\n\n  type SupplementaryDataY = DataY & {\n    associatedYIndex: number;\n    supplementalIndex: number;\n  };\n\n  //Currently only supported for horizontal bar charts\n  export type LabeledData = BaseData & {\n    type: 'labeled';\n    x: { label: string; isSecondary?: boolean }[];\n  };\n\n  export type TimeseriesData = BaseData & {\n    type: 'timeseries';\n    x: number[];\n  };\n\n  type DonutData = {\n    label: string;\n    hidden?: boolean;\n    value: number;\n    isSecondary?: boolean;\n  };\n\n  export type Dimensions = {\n    width: number;\n    height: number;\n  };\n\n  type BaseConfig = {\n    groupedTooltip: boolean;\n    colors: string[];\n    allowLegendToggle: boolean;\n    zeroStateMessage: string;\n    valueType: ValueType;\n    secondaryValueType?: ValueType;\n    truncateLegend: boolean;\n    dateFormat?: Interval;\n    showDataLabels?: boolean;\n  };\n\n  type DonutConfig = {\n    size: 'xsmall' | 'small' | 'medium' | 'large';\n    displayValue: string;\n    displayLabel?: string;\n  };\n\n  export type Config = BaseConfig &\n    (\n      | {\n          type: 'line' | 'area' | 'waterfall';\n        }\n      | {\n          type: 'bar' | 'horizontal-bar';\n          groupingType: 'stacked' | 'clustered';\n        }\n      | {\n          type: 'donut';\n          donutDisplayInfo: DonutConfig;\n        }\n    );\n\n  type BarConfig = Extract<Config, { type: 'bar' | 'horizontal-bar' }>;\n\n  export const defaultConfig: Config = {\n    type: 'line',\n    groupedTooltip: true,\n    colors: defaultColorPalette,\n    allowLegendToggle: false,\n    zeroStateMessage: 'No data to display.',\n    valueType: 'currency',\n    truncateLegend: true,\n    dateFormat: 'day',\n  };\n\n  export const defaultDonutConfig: Config = {\n    type: 'donut',\n    groupedTooltip: true,\n    colors: defaultColorPalette,\n    allowLegendToggle: false,\n    zeroStateMessage: 'No data to display.',\n    valueType: 'currency',\n    truncateLegend: true,\n    dateFormat: 'day',\n    donutDisplayInfo: {\n      size: 'medium',\n      displayValue: '',\n    },\n  };\n\n  export type Area = {\n    path: string | null;\n    fill: string;\n  };\n\n  export type XTick = {\n    x: number;\n    label: string;\n    secondaryLabel?: string;\n  };\n\n  export type YTick = {\n    y: number;\n    label: string;\n    secondaryLabel?: string;\n  };\n\n  type Rect = {\n    x: number;\n    y: number;\n    width: number;\n    height: number;\n  };\n\n  export type BarSeries = {\n    fill: string;\n    rects: Rect[];\n  };\n\n  type Circle = {\n    cx: number;\n    cy: number;\n  };\n\n  // Hover is a function that takes a viewport x and y and returns a rich\n  // set of information about what values are being hovered and what the tooltip\n  // should look like\n  export type Hover = (pos: { rect: DOMRect; x: number; y: number }) => {\n    // the indices into the data of the closest point\n    xIndex: number;\n    // we want to know which visible y index is hovered\n    // and which actual y index is hovered\n    yIndex: number;\n    visibleYIndex: number;\n\n    // the viewport x and ys of the hovered items\n    x: number;\n    ys: number[];\n\n    tooltip: {\n      anchor: DOMRect;\n      date: string;\n      metrics: {\n        color: string;\n        label: string;\n        value: string;\n      }[];\n    };\n  };\n\n  // RenderedChart represents all of the parts of a chart\n  // that end up on screen. Every chart has x and y ticks\n  // and hover functionality, even though they might be\n  // different from chart to chart.\n  type RenderedChart = {\n    xTicks: XTick[];\n    yTicks: YTick[];\n    hover?: Hover;\n    colors: string[];\n    lines: (string | null)[];\n    circles: Circle[]; //Line fallback for a single point\n    areas: (string | null)[];\n    bars: Rect[][];\n    arcs: (string | null)[];\n    horizontalBars: (string | null)[][];\n    dataLabels: DataLabel[];\n    waterfallLines: {\n      x1: number;\n      x2: number;\n      y1: number;\n      y2: number;\n    }[];\n  };\n\n  type DataLabel = {\n    label: string;\n    xPos: number;\n    yPos: number;\n    anchor: 'start' | 'middle' | 'end';\n    line?: {\n      x1: number;\n      y1: number;\n      x2: number;\n      y2: number;\n    };\n  };\n\n  const emptyChart: RenderedChart = {\n    xTicks: [],\n    yTicks: [],\n    colors: [],\n    lines: [],\n    circles: [],\n    areas: [],\n    bars: [],\n    arcs: [],\n    horizontalBars: [],\n    dataLabels: [],\n    waterfallLines: [],\n  };\n\n  function timeseriesDomain(data: TimeseriesData) {\n    return [Math.min(...data.x), Math.max(...data.x)];\n  }\n\n  function indexDomain(data: LabeledData) {\n    return [0, data.x.length - 1];\n  }\n\n  function yDomain(data: Data, scaleFactor: number = 1) {\n    const max =\n      Math.max(...data.ys.map(y => Math.max(...y.values))) * scaleFactor;\n    const min = Math.min(...data.ys.map(y => Math.min(...y.values)));\n    return [min < 0 ? min : 0, max <= 0 ? 1 : max];\n  }\n\n  function xRange(dimensions: Dimensions, config: Config) {\n    return [\n      config.showDataLabels ? LEFT_PADDING_WITH_DATA_LABELS : LEFT_PADDING,\n      dimensions.width - RIGHT_PADDING,\n    ];\n  }\n\n  function xRangeHorizontal(\n    dimensions: Dimensions,\n    data: Data,\n    largestLabelLength: number,\n    config: Config,\n  ) {\n    let leftPaddingMax =\n      data.type == 'labeled' ? LEFT_PADDING_LABEL_MAX : LEFT_PADDING_DATE;\n    let leftPaddingCalculated = leftPaddingMax;\n    if (data.type == 'labeled') {\n      const maxLabelSize = Math.max(...data.x.map(x => x.label.length));\n      leftPaddingCalculated = Math.min(\n        leftPaddingMax,\n        maxLabelSize * WIDTH_PER_LETTER,\n      );\n    }\n    //Space between label and chart\n    leftPaddingCalculated = leftPaddingCalculated + SMALL_PADDING;\n\n    //If data labels are on, and we have negative bars, we need even more left padding\n    const dataLabelPadding =\n      config.showDataLabels && data.ys.find(y => y.values.find(val => val < 0))\n        ? largestLabelLength * WIDTH_PER_LETTER\n        : 0;\n    return [\n      Math.max(leftPaddingCalculated, LEFT_PADDING) + dataLabelPadding,\n      dimensions.width - RIGHT_PADDING_HORIZONTAL,\n    ];\n  }\n\n  function barXRange(dimensions: Dimensions, data: Data, config: Config) {\n    const left = config.showDataLabels\n      ? LEFT_PADDING_WITH_DATA_LABELS\n      : LEFT_PADDING;\n    const right = dimensions.width - RIGHT_PADDING;\n    const width = right - left;\n    const binSize = width / (data.x.length || 1);\n    const halfBinSize = binSize / 2;\n    const range = [left + halfBinSize, right - halfBinSize];\n    return { binSize: Math.min(binSize * 0.7, 80), range };\n  }\n\n  function barYRange(dimensions: Dimensions, data: Data, config: Config) {\n    const top =\n      dimensions.height -\n      (config.showDataLabels ? TOP_PADDING_WITH_DATA_LABELS : TOP_PADDING);\n    const bottom = BOTTOM_PADDING;\n    const height = top - bottom;\n    const binSize = height / (data.x.length || 1);\n    const halfBinSize = binSize / 2;\n    const range = [bottom + halfBinSize, top - halfBinSize];\n    return { range };\n  }\n\n  function yRange(dimensions: Dimensions, config: Config, data: Data) {\n    const extraBottomPadding =\n      config.showDataLabels &&\n      data.ys.find(y => y.values.find(val => val < 0)) &&\n      (config.type == 'bar' || config.type == 'waterfall');\n    return [\n      dimensions.height -\n        (extraBottomPadding ? BOTTOM_PADDING_WITH_DATA_LABELS : BOTTOM_PADDING),\n      config.showDataLabels ? TOP_PADDING_WITH_DATA_LABELS : TOP_PADDING,\n    ];\n  }\n\n  function calcYScalesAndTicks(\n    data: Data,\n    dimensions: Dimensions,\n    pipe: NumberPipe | SmallCurrencyPipe | PercentagePipe | DaysPipe,\n    secondaryPipe: NumberPipe | SmallCurrencyPipe | PercentagePipe | DaysPipe,\n    isStacked: boolean,\n    config: Config,\n  ): {\n    yScale: ScaleLinear<number, number, never>;\n    yScaleSecondary: ScaleLinear<number, number, never>;\n    scale: (input: number, isSecondary: boolean | undefined) => number;\n    yTicks: YTick[];\n  } {\n    const secondaryData = {\n      ...data,\n      ys: data.ys.filter(y => y.isSecondary),\n    };\n    const scaleRange = yRange(dimensions, config, data);\n\n    //Simpler path for data w/o secondaries\n    if (secondaryData.ys.length == 0) {\n      const yScaleDomainValues = calcYScaleDomainValues(data, isStacked, false);\n      const yScale = scaleLinear(\n        [\n          Math.min(...yScaleDomainValues.map(val => val.min)),\n          Math.max(...yScaleDomainValues.map(val => val.max)),\n        ],\n        scaleRange,\n      );\n      const yTicks: YTick[] = yScale.ticks(5).map(tick => ({\n        y: yScale(tick),\n        label: pipe.transform(tick),\n      }));\n      const scale = (input: number): number => {\n        return yScale(input);\n      };\n      return {\n        yScale,\n        yScaleSecondary: yScale,\n        scale,\n        yTicks,\n      };\n    }\n\n    const primaryYScaleDomainValues = calcYScaleDomainValues(\n      data,\n      isStacked,\n      false,\n    );\n    const secondaryYScaleDomainValues = calcYScaleDomainValues(\n      data,\n      isStacked,\n      true,\n    );\n\n    let scaleDomainMultiple = 1;\n    //Calculating how much we need to multiple the domain by to 'fit' both axes' data\n    if (isStacked) {\n      const primaryDataMax = Math.max(\n        ...primaryYScaleDomainValues.map(val => val.max),\n      );\n      const secondaryDataMax = Math.max(\n        ...secondaryYScaleDomainValues.map(val => val.max),\n      );\n      for (let i = 0; i < primaryYScaleDomainValues.length; i++) {\n        const primaryVal = primaryYScaleDomainValues[i].max;\n        const secondaryVal = secondaryYScaleDomainValues[i].max;\n        const primaryRatio =\n          primaryDataMax != 0 ? primaryVal / primaryDataMax : 0;\n        const secondaryRatio =\n          secondaryDataMax != 0 ? secondaryVal / secondaryDataMax : 0;\n        const multVal = primaryRatio + secondaryRatio;\n        if (multVal > scaleDomainMultiple) {\n          scaleDomainMultiple = multVal;\n        }\n      }\n    }\n    const primaryYDomain = [\n      Math.min(...primaryYScaleDomainValues.map(val => val.min)),\n      Math.max(...primaryYScaleDomainValues.map(val => val.max)) *\n        scaleDomainMultiple,\n    ];\n\n    //Figuring out the best tick count to fit the two data srouces\n    const yScalePrimaryProto = scaleLinear(primaryYDomain, scaleRange);\n    const yScaleSecondaryProto = scaleLinear(\n      [\n        Math.min(...secondaryYScaleDomainValues.map(val => val.min)),\n        Math.max(...secondaryYScaleDomainValues.map(val => val.max)) *\n          scaleDomainMultiple,\n      ],\n      scaleRange,\n    );\n    const tickCount = Math.max(\n      5,\n      yScalePrimaryProto.ticks(5).length,\n      yScaleSecondaryProto.ticks(5).length,\n    );\n\n    //Finding a domain for the secondary data such that it will result in round tick values when matched with the primary ticks\n    const secondaryTicksProto = yScaleSecondaryProto\n      .ticks(tickCount)\n      .map(tick => ({\n        y: yScaleSecondaryProto(tick),\n        rawY: tick,\n        label: secondaryPipe.transform(tick),\n      }));\n    const yScaleDomainMax = Math.max(...primaryYDomain);\n    const yScale = scaleLinear(primaryYDomain, scaleRange);\n    const yScaleTickMax = Math.max(...yScale.ticks(tickCount));\n    const secondaryGap =\n      secondaryTicksProto[1].rawY - secondaryTicksProto[0].rawY;\n    const gapCount = yScale.ticks(tickCount).length - 1;\n    let calcMax = secondaryGap * gapCount;\n    const tickMax = Math.max(\n      ...secondaryTicksProto.map(secTick => secTick.rawY),\n    );\n    while (calcMax < tickMax) {\n      calcMax = calcMax * 2;\n    }\n    while (calcMax > tickMax * 2) {\n      calcMax = calcMax / 2;\n    }\n    const yScaleSecondary = scaleLinear(\n      [0, calcMax * (yScaleDomainMax / yScaleTickMax)],\n      scaleRange,\n    );\n\n    const yTicks: YTick[] = yScale.ticks(tickCount).map(tick => ({\n      y: yScale(tick),\n      label: pipe.transform(tick),\n      secondaryLabel: secondaryPipe.transform(\n        yScaleSecondary.invert(yScale(tick)),\n      ),\n    }));\n\n    const scale = (input: number, isSecondary: boolean | undefined): number => {\n      if (isSecondary) {\n        return yScaleSecondary(input);\n      }\n      return yScale(input);\n    };\n    return {\n      yScale,\n      yScaleSecondary,\n      scale,\n      yTicks,\n    };\n  }\n\n  function calcYScaleDomainValues(\n    data: Data,\n    isStacked: boolean,\n    forSecondary: boolean,\n  ): { max: number; min: number }[] {\n    const possiblyStackedYs = data.ys.map((y, yIndex) => {\n      //Handle stacking\n      return isStacked\n        ? y.values.map((val, xIndex) => {\n            let prevRunningTotal = 0;\n            for (let yI = 0; yI < yIndex; yI++) {\n              if (\n                checkIfSecondary(data, yIndex, xIndex, false) != forSecondary\n              ) {\n                continue;\n              }\n              const addVal = data.ys[yI].values[xIndex];\n              //Only stack values of the same sign\n              if (addVal < 0 == val < 0) {\n                prevRunningTotal += addVal;\n              }\n            }\n            return val + prevRunningTotal;\n          })\n        : y.values;\n    });\n    const suppYs = data.supplementaryYs;\n    let possiblyStackedSupYs: number[][] = [];\n    if (suppYs && suppYs.length > 0) {\n      possiblyStackedSupYs = suppYs.map((y, yIndex) => {\n        //Handle stacking\n        return isStacked\n          ? y.values.map((val, xIndex) => {\n              let prevRunningTotal = 0;\n              for (let yI = 0; yI < yIndex; yI++) {\n                if (\n                  checkIfSecondary(data, yIndex, xIndex, true) !=\n                    forSecondary ||\n                  suppYs[yI].supplementalIndex != y.supplementalIndex\n                ) {\n                  continue;\n                }\n                const addVal = suppYs[yI].values[xIndex];\n                //Only stack values of the same sign\n                if (addVal < 0 == val < 0) {\n                  prevRunningTotal += addVal;\n                }\n              }\n              return val + prevRunningTotal;\n            })\n          : y.values;\n      });\n    }\n\n    const scaleRange: { max: number; min: number }[] = [];\n    for (let i = 0; i < data.x.length; i++) {\n      const maxNormY = Math.max(\n        ...possiblyStackedYs.map((y, yIndex) => {\n          if (checkIfSecondary(data, yIndex, i, false) != forSecondary) {\n            return 0;\n          }\n          return y[i];\n        }),\n      );\n      const minNormY = Math.min(\n        ...possiblyStackedYs.map((y, yIndex) => {\n          if (checkIfSecondary(data, yIndex, i, false) != forSecondary) {\n            return 0;\n          }\n          return y[i];\n        }),\n      );\n      const maxSupY = suppYs\n        ? Math.max(\n            ...possiblyStackedSupYs.map((y, yIndex) => {\n              if (checkIfSecondary(data, yIndex, i, true) != forSecondary) {\n                return 0;\n              }\n              return y[i];\n            }),\n          )\n        : 0;\n      const minSupY = suppYs\n        ? Math.min(\n            ...possiblyStackedSupYs.map((y, yIndex) => {\n              if (checkIfSecondary(data, yIndex, i, true) != forSecondary) {\n                return 0;\n              }\n              return y[i];\n            }),\n          )\n        : 0;\n      const max =\n        maxNormY > 0 && maxNormY > maxSupY\n          ? maxNormY\n          : maxSupY > 0\n          ? maxSupY\n          : 0;\n      const min =\n        minNormY < 0 && minNormY < minSupY\n          ? minNormY\n          : minSupY < 0\n          ? minSupY\n          : 0;\n      scaleRange.push({ max, min });\n    }\n    return scaleRange;\n  }\n\n  function getClusterCountWithSupp(data: Data): number {\n    const suppYs = data.supplementaryYs;\n    if (suppYs) {\n      return Math.max(...suppYs.map(suppY => suppY.supplementalIndex)) + 2;\n    }\n    return 1;\n  }\n\n  function calculateXValueAndOffsetForBars(\n    binSize: number,\n    clusterCount: number,\n    matchingIndex: number,\n    originalXValue: number,\n  ) {\n    const width = (binSize - (clusterCount - 1) * SMALL_PADDING) / clusterCount;\n    const offset = matchingIndex * (width + SMALL_PADDING);\n    const xValue = originalXValue + offset;\n    return {\n      width,\n      xValue,\n    };\n  }\n\n  function calculateHorizontalBarPath(\n    leftSideRound: boolean,\n    rightSideRound: boolean,\n    xValue: number,\n    yValue: number,\n    horR: number,\n    verR: number,\n    width: number,\n  ): string {\n    if (leftSideRound && rightSideRound) {\n      //Both-sides rounding variation\n      const pathD = `\n        M ${xValue + horR},${yValue}\n        h ${width - horR * 2}\n        q${horR},0 ${horR},${verR}\n        v ${HORIZONTAL_BAR_HEIGHT - verR * 2}\n        q0,${verR} -${horR},${verR}\n        h ${-(width - horR * 2)}\n        q-${horR},0 -${horR},-${verR}\n        v -${HORIZONTAL_BAR_HEIGHT - verR * 2}\n        q0,-${verR} ${horR},-${verR}\n        Z\n      `;\n      return pathD;\n    }\n    if (leftSideRound) {\n      //Left-side rounding variation\n      const pathD = `\n        M ${xValue + horR},${yValue}\n        h ${width - horR}\n        v ${HORIZONTAL_BAR_HEIGHT}\n        h ${-(width - horR)}\n        q-${horR},0 -${horR},-${verR}\n        v -${HORIZONTAL_BAR_HEIGHT - verR * 2}\n        q0,-${verR} ${horR},-${verR}\n        Z\n      `;\n      return pathD;\n    }\n    if (rightSideRound) {\n      //Right-side rounding variation\n      const pathD = `\n        M ${xValue},${yValue}\n        h ${width - horR}\n        q${horR},0 ${horR},${verR}\n        v ${HORIZONTAL_BAR_HEIGHT - verR * 2}\n        q0,${verR} -${horR},${verR}\n        h ${-(width - horR)}\n        Z\n      `;\n      return pathD;\n    }\n    //No-rounding variation\n    const pathD = `\n      M ${xValue},${yValue}\n      h ${width}\n      v ${HORIZONTAL_BAR_HEIGHT}\n      h ${-width}\n      v -${HORIZONTAL_BAR_HEIGHT}\n      Z\n    `;\n    return pathD;\n  }\n\n  function calcXScalesAndTicks(\n    data: Data,\n    dimensions: Dimensions,\n    pipe: NumberPipe | SmallCurrencyPipe | PercentagePipe | DaysPipe,\n    secondaryPipe: NumberPipe | SmallCurrencyPipe | PercentagePipe | DaysPipe,\n    isStacked: boolean,\n    config: Config,\n  ): {\n    xScale: ScaleLinear<number, number, never>;\n    xScaleSecondary: ScaleLinear<number, number, never>;\n    scale: (input: number, isSecondary: boolean | undefined) => number;\n    xTicks: XTick[];\n  } {\n    const primaryData = convertDataToJustOneValueType(data, false);\n    const secondaryData = convertDataToJustOneValueType(data, true);\n    const suppYs = data.supplementaryYs;\n\n    const largestLabelLength = Math.max(\n      ...data.ys.map((y, yIndex) =>\n        Math.max(\n          ...y.values.map(\n            (val, xIndex) =>\n              (checkIfSecondary(data, yIndex, xIndex, false)\n                ? secondaryPipe.transform(val)\n                : pipe.transform(val)\n              ).length,\n          ),\n        ),\n      ),\n      ...(suppYs ?? []).map((y, yIndex) =>\n        Math.max(\n          ...y.values.map(\n            (val, xIndex) =>\n              (checkIfSecondary(data, yIndex, xIndex, true)\n                ? secondaryPipe.transform(val)\n                : pipe.transform(val)\n              ).length,\n          ),\n        ),\n      ),\n    );\n    const scaleRange = xRangeHorizontal(\n      dimensions,\n      data,\n      largestLabelLength,\n      config,\n    );\n\n    //Simpler path for data w/o secondaries\n    if (!secondaryData.ys.find(y => y.values.find(val => val != 0))) {\n      const yScaleDomainValues = calcYScaleDomainValues(\n        primaryData,\n        isStacked,\n        false,\n      );\n      const xScale = scaleLinear(\n        [\n          Math.min(...yScaleDomainValues.map(val => val.min)),\n          Math.max(...yScaleDomainValues.map(val => val.max)),\n        ],\n        scaleRange,\n      );\n      const xTicks: XTick[] = xScale.ticks(5).map(tick => ({\n        x: xScale(tick),\n        label: pipe.transform(tick),\n      }));\n\n      const scale = (input: number): number => {\n        return xScale(input);\n      };\n      return {\n        xScale,\n        xScaleSecondary: xScale,\n        scale,\n        xTicks,\n      };\n    }\n    const primaryYScaleDomainValues = calcYScaleDomainValues(\n      data,\n      isStacked,\n      false,\n    );\n    const secondaryYScaleDomainValues = calcYScaleDomainValues(\n      data,\n      isStacked,\n      true,\n    );\n    let scaleDomainMultiple = 1;\n\n    //Calculating how much we need to multiple the domain by to 'fit' both axes' data\n    if (isStacked) {\n      const primaryDataMax = Math.max(\n        ...primaryYScaleDomainValues.map(val => val.max),\n      );\n      const secondaryDataMax = Math.max(\n        ...secondaryYScaleDomainValues.map(val => val.max),\n      );\n      for (let i = 0; i < primaryYScaleDomainValues.length; i++) {\n        const primaryVal = primaryYScaleDomainValues[i].max;\n        const secondaryVal = secondaryYScaleDomainValues[i].max;\n        const primaryRatio =\n          primaryDataMax != 0 ? primaryVal / primaryDataMax : 0;\n        const secondaryRatio =\n          secondaryDataMax != 0 ? secondaryVal / secondaryDataMax : 0;\n        const multVal = primaryRatio + secondaryRatio;\n        if (multVal > scaleDomainMultiple) {\n          scaleDomainMultiple = multVal;\n        }\n      }\n    }\n    const primaryXDomain = [\n      Math.min(...primaryYScaleDomainValues.map(val => val.min)),\n      Math.max(...primaryYScaleDomainValues.map(val => val.max)) *\n        scaleDomainMultiple,\n    ];\n    const xScalePrimaryProto = scaleLinear(primaryXDomain, scaleRange);\n    const xScaleSecondaryProto = scaleLinear(\n      [\n        Math.min(...secondaryYScaleDomainValues.map(val => val.min)),\n        Math.max(...secondaryYScaleDomainValues.map(val => val.max)) *\n          scaleDomainMultiple,\n      ],\n      scaleRange,\n    );\n    const tickCount = Math.max(\n      5,\n      xScalePrimaryProto.ticks(5).length,\n      xScaleSecondaryProto.ticks(5).length,\n    );\n\n    //Finding a domain for the secondary data such that it will result in round tick values when matched with the primary ticks\n    const secondaryTicksProto = xScaleSecondaryProto\n      .ticks(tickCount)\n      .map(tick => ({\n        x: xScaleSecondaryProto(tick),\n        rawX: tick,\n        label: secondaryPipe.transform(tick),\n      }));\n    const xScaleDomainMax = Math.max(...primaryXDomain);\n    const xScale = scaleLinear(primaryXDomain, scaleRange);\n    const xScaleTickMax = Math.max(...xScale.ticks(tickCount));\n    const secondaryGap =\n      secondaryTicksProto[1].rawX - secondaryTicksProto[0].rawX;\n    const gapCount = xScale.ticks(tickCount).length - 1;\n    let calcMax = secondaryGap * gapCount;\n    const tickMax = Math.max(\n      ...secondaryTicksProto.map(secTick => secTick.rawX),\n    );\n    while (calcMax < tickMax) {\n      calcMax = calcMax * 2;\n    }\n    while (calcMax > tickMax * 2) {\n      calcMax = calcMax / 2;\n    }\n    const xScaleSecondary = scaleLinear(\n      [0, calcMax * (xScaleDomainMax / xScaleTickMax)],\n      scaleRange,\n    );\n\n    const xTicks: XTick[] = xScale.ticks(tickCount).map(tick => ({\n      x: xScale(tick),\n      label: pipe.transform(tick),\n      secondaryLabel: secondaryPipe.transform(\n        xScaleSecondary.invert(xScale(tick)),\n      ),\n    }));\n\n    const scale = (input: number, isSecondary: boolean | undefined): number => {\n      if (isSecondary) {\n        return xScaleSecondary(input);\n      }\n      return xScale(input);\n    };\n    return {\n      xScale,\n      xScaleSecondary,\n      scale,\n      xTicks,\n    };\n  }\n\n  function convertDataToJustOneValueType(\n    data: Data,\n    isSecondary: boolean,\n  ): Data {\n    const newData: Data = { ...data, ys: [] };\n    data.ys.forEach((y, yIndex) => {\n      newData.ys.push({ ...y, values: [] });\n      y.values.forEach((_, xIndex) => {\n        if (checkIfSecondary(data, yIndex, xIndex) != isSecondary) {\n          newData.ys[yIndex].values.push(0);\n        } else {\n          newData.ys[yIndex].values.push(data.ys[yIndex].values[xIndex]);\n        }\n      });\n    });\n    return newData;\n  }\n\n  function findNearestIndex(values: number[], input: number) {\n    return values.reduce((nearestIndex, value, index) => {\n      return Math.abs(value - input) < Math.abs(values[nearestIndex] - input)\n        ? index\n        : nearestIndex;\n    }, 0);\n  }\n\n  function findNearestIndexWithSecondary(\n    yInfo: { value: number; isSecondary: boolean }[],\n    yPos: number,\n    scale: (input: number, isSecondary: boolean | undefined) => number,\n  ) {\n    let foundIndex = 0;\n    let currMinDistance = Math.abs(\n      scale(yInfo[0].value, yInfo[0].isSecondary) - yPos,\n    );\n    for (let i = 1; i < yInfo.length; i++) {\n      const newDistance = Math.abs(\n        scale(yInfo[i].value, yInfo[i].isSecondary) - yPos,\n      );\n      if (newDistance < currMinDistance) {\n        foundIndex = i;\n        currMinDistance = newDistance;\n      }\n    }\n    return foundIndex;\n  }\n\n  function findNearestIndexString(values: unknown[], input: number) {\n    const numValues = values.map((_, i) => i);\n    return numValues.reduce((nearestIndex, value, index) => {\n      return Math.abs(value - input) < Math.abs(numValues[nearestIndex] - input)\n        ? index\n        : nearestIndex;\n    }, 0);\n  }\n\n  function findSubIndex(\n    value: number,\n    input: number,\n    binSize: number,\n    subBinCount: number,\n  ) {\n    const subBinSize =\n      (binSize - (subBinCount - 1) * SMALL_PADDING) / subBinCount;\n    const centerIndex = subBinCount / 2 - 0.5;\n    let closestIndex = 0;\n    let closenessVal = -1;\n    for (let i = 0; i < subBinCount; i++) {\n      const offset = (i - centerIndex) * (subBinSize + SMALL_PADDING);\n      const subBinPos = value + offset;\n      const distance = Math.abs(input - subBinPos);\n      if (closenessVal < 0 || closenessVal > distance) {\n        closestIndex = i;\n        closenessVal = distance;\n      }\n    }\n    return closestIndex;\n  }\n\n  function findSubIndexHorizontal(\n    value: number,\n    input: number,\n    subBinCount: number,\n  ) {\n    const centerIndex = subBinCount / 2 - 0.5;\n    let closestIndex = 0;\n    let closenessVal = -1;\n    for (let i = 0; i < subBinCount; i++) {\n      const offset =\n        (i - centerIndex) * (HORIZONTAL_BAR_HEIGHT + SMALL_PADDING);\n      const subBinPos = value + offset;\n      const distance = Math.abs(input - subBinPos);\n      if (closenessVal < 0 || closenessVal > distance) {\n        closestIndex = i;\n        closenessVal = distance;\n      }\n    }\n    return closestIndex;\n  }\n\n  function getBarYInfo(\n    data: Data,\n    yIndex: number,\n    xIndex: number,\n    scale: (input: number, isSecondary: boolean | undefined) => number,\n    isStacked: boolean,\n    isSupplementary: boolean = false,\n  ): { yValue: number; height: number } {\n    const zeroVal = scale(0, true);\n    const yData = getMainOrSuppY(data, yIndex, isSupplementary);\n    const scaleValue = scale(\n      yData.values[xIndex],\n      checkIfSecondary(data, yIndex, xIndex, isSupplementary),\n    );\n    if (scaleValue > zeroVal) {\n      let prevBarHeights = 0;\n      if (isStacked) {\n        for (let i = 0; i < yIndex; i++) {\n          const checkData = getMainOrSuppY(data, i, isSupplementary);\n          //Both yData and checkData are definitely SupplementaryDataYs if isSupplementary is true, but they don't realize it\n          if (\n            isSupplementary &&\n            'supplementalIndex' in yData &&\n            'supplementalIndex' in checkData\n          ) {\n            if (yData.supplementalIndex != checkData.supplementalIndex) {\n              continue;\n            }\n          }\n          const checkValue = scale(\n            checkData.values[xIndex],\n            checkIfSecondary(data, i, xIndex, isSupplementary),\n          );\n          //Skip positive values\n          if (checkValue < zeroVal) {\n            continue;\n          }\n          prevBarHeights = prevBarHeights + checkValue - zeroVal;\n        }\n      }\n      const yValue = zeroVal + prevBarHeights;\n      const height = scaleValue - yValue + prevBarHeights;\n      return { yValue, height };\n    }\n    let prevBarHeights = 0;\n    if (isStacked) {\n      for (let i = 0; i < yIndex; i++) {\n        const checkData = getMainOrSuppY(data, i, isSupplementary);\n        //Both yData and checkData are definitely SupplementaryDataYs if isSupplementary is true, but they don't realize it\n        if (\n          isSupplementary &&\n          'supplementalIndex' in yData &&\n          'supplementalIndex' in checkData\n        ) {\n          if (yData.supplementalIndex != checkData.supplementalIndex) {\n            continue;\n          }\n        }\n        const checkValue = scale(\n          checkData.values[xIndex],\n          checkIfSecondary(data, i, xIndex, isSupplementary),\n        );\n        //Skip negative values\n        if (checkValue > zeroVal) {\n          continue;\n        }\n        const prevBarYVal = checkValue - prevBarHeights;\n        prevBarHeights = zeroVal - prevBarYVal;\n      }\n    }\n    const yValue = scaleValue - prevBarHeights;\n    const height = zeroVal - yValue - prevBarHeights;\n    return { yValue, height };\n  }\n\n  function getSuppBarYInfoViaYIndex(\n    data: Data,\n    yIndex: number,\n    suppIndex: number,\n    xIndex: number,\n    scale: (input: number, isSecondary: boolean | undefined) => number,\n    isStacked: boolean,\n  ): { yValue: number; height: number } {\n    const suppYs = data.supplementaryYs;\n    if (!suppYs || suppYs.length == 0) {\n      return { yValue: 0, height: 0 };\n    }\n    for (let i = 0; i < suppYs.length; i++) {\n      if (\n        suppYs[i].associatedYIndex == yIndex &&\n        suppYs[i].supplementalIndex == suppIndex\n      ) {\n        return getBarYInfo(data, i, xIndex, scale, isStacked, true);\n      }\n    }\n    return { yValue: 0, height: 0 };\n  }\n\n  function getMainOrSuppY(\n    data: Data,\n    yIndex: number,\n    isSupplementary: boolean,\n  ): DataY | SupplementaryDataY {\n    const suppYs = data.supplementaryYs;\n    if (suppYs && isSupplementary) {\n      return suppYs[yIndex];\n    }\n    return data.ys[yIndex];\n  }\n\n  function getBarXInfo(\n    data: Data,\n    yIndex: number,\n    xIndex: number,\n    scale: (input: number, isSecondary: boolean | undefined) => number,\n    isStacked: boolean,\n    isSupplementary: boolean = false,\n  ): { xValue: number; width: number } {\n    const zeroVal = scale(0, true);\n    const yData = getMainOrSuppY(data, yIndex, isSupplementary);\n    const scaleValue = scale(\n      yData.values[xIndex],\n      checkIfSecondary(data, yIndex, xIndex, isSupplementary),\n    );\n    if (scaleValue < zeroVal) {\n      let prevBarWidths = 0;\n      if (isStacked) {\n        for (let i = 0; i < yIndex; i++) {\n          const checkData = getMainOrSuppY(data, i, isSupplementary);\n          //Both yData and checkData are definitely SupplementaryDataYs if isSupplementary is true, but they don't realize it\n          if (\n            isSupplementary &&\n            'supplementalIndex' in yData &&\n            'supplementalIndex' in checkData\n          ) {\n            if (yData.supplementalIndex != checkData.supplementalIndex) {\n              continue;\n            }\n          }\n          const checkVal = scale(\n            checkData.values[xIndex],\n            checkIfSecondary(data, i, xIndex, isSupplementary),\n          );\n          //Skip positive values\n          if (checkVal > zeroVal) {\n            continue;\n          }\n          prevBarWidths += zeroVal - checkVal;\n        }\n      }\n      const xValue = scaleValue - prevBarWidths;\n      const width = zeroVal - scaleValue;\n      return { xValue, width };\n    }\n    let prevBarWidths = 0;\n    if (isStacked) {\n      for (let i = 0; i < yIndex; i++) {\n        const checkData = getMainOrSuppY(data, i, isSupplementary);\n        //Both yData and checkData are definitely SupplementaryDataYs if isSupplementary is true, but they don't realize it\n        if (\n          isSupplementary &&\n          'supplementalIndex' in yData &&\n          'supplementalIndex' in checkData\n        ) {\n          if (yData.supplementalIndex != checkData.supplementalIndex) {\n            continue;\n          }\n        }\n        const checkVal = scale(\n          checkData.values[xIndex],\n          checkIfSecondary(data, i, xIndex, isSupplementary),\n        );\n        //Skip negative values\n        if (checkVal < zeroVal) {\n          continue;\n        }\n        prevBarWidths += checkVal - zeroVal;\n      }\n    }\n    const xValue = prevBarWidths + zeroVal;\n    const width = scaleValue - zeroVal;\n    return { xValue, width };\n  }\n\n  function getSuppBarXInfoViaYIndex(\n    data: Data,\n    yIndex: number,\n    suppIndex: number,\n    xIndex: number,\n    scale: (input: number, isSecondary: boolean | undefined) => number,\n    isStacked: boolean,\n  ): { xValue: number; width: number } {\n    const suppYs = data.supplementaryYs;\n    if (!suppYs || suppYs.length == 0) {\n      return { xValue: 0, width: 0 };\n    }\n    for (let i = 0; i < suppYs.length; i++) {\n      if (\n        suppYs[i].associatedYIndex == yIndex &&\n        suppYs[i].supplementalIndex == suppIndex\n      ) {\n        return getBarXInfo(data, i, xIndex, scale, isStacked, true);\n      }\n    }\n    return { xValue: 0, width: 0 };\n  }\n\n  function checkIfSecondary(\n    data: Data,\n    yIndex: number,\n    xIndex: number,\n    isSupplementary: boolean = false,\n  ): boolean {\n    if (data.type == 'labeled') {\n      if (data.x[xIndex].isSecondary == true) {\n        return true;\n      }\n    }\n    return getMainOrSuppY(data, yIndex, isSupplementary).isSecondary == true;\n  }\n\n  // stack returns a new data where each set of yValues is stacked\n  // on top of the previous.\n  function stack(data: Data): Data {\n    const stacked: Data = {\n      ...data,\n      ys: data.ys.map(y => ({\n        label: y.label,\n        values: [],\n        isSecondary: y.isSecondary,\n      })),\n    };\n    for (let i = 0; i < data.x.length; i++) {\n      let posFrom = 0;\n      let negFrom = 0;\n      for (let j = 0; j < data.ys.length; j++) {\n        const sourceVal = data.ys[j].values[i];\n        if (sourceVal < 0) {\n          const to = negFrom + sourceVal;\n          stacked.ys[j].values.push(to);\n          negFrom = to;\n        } else {\n          const to = posFrom + sourceVal;\n          stacked.ys[j].values.push(to);\n          posFrom = to;\n        }\n      }\n    }\n    return stacked;\n  }\n\n  // hide strips out hidden y values while retaining the original indices\n  // for the remaining visible values\n  function hide(data: Data): { data: Data; visibleIndices: number[] } {\n    const visibleIndices = data.ys\n      .map((y, i) => ({ y, i }))\n      .filter(({ y }) => !y.hidden)\n      .map(({ i }) => i);\n    return {\n      data: { ...data, ys: visibleIndices.map(i => data.ys[i]) },\n      visibleIndices,\n    };\n  }\n\n  function waterfallTransform(data: LabeledData): LabeledData {\n    const newData = {\n      ...data,\n      x: [...data.x, { label: 'Total' }],\n      ys: [\n        ...data.ys.map(y => ({\n          ...y,\n          values: [...y.values, y.values.reduce((a, b) => a + b, 0)],\n        })),\n      ],\n    };\n    return newData;\n  }\n\n  type ValueType = 'count' | 'currency' | 'percentage' | 'days';\n\n  export function getPipes(valueType: ValueType) {\n    switch (valueType) {\n      case 'count': {\n        const pipe = new NumberPipe();\n        return { pipe, fullPipe: pipe };\n      }\n      case 'currency':\n        return {\n          pipe: new SmallCurrencyPipe(),\n          fullPipe: new CurrencyPipe('en-us'),\n        };\n      case 'percentage': {\n        const pipe = new PercentagePipe();\n        return { pipe, fullPipe: pipe };\n      }\n      case 'days': {\n        const pipe = new DaysPipe();\n        return { pipe, fullPipe: pipe };\n      }\n    }\n  }\n\n  export const intervals = ['year', 'quarter', 'month', 'week', 'day'] as const;\n  export type Interval = (typeof intervals)[number];\n\n  export function formatedDate(dateFormat: Interval, date: Date) {\n    if (dateFormat == 'quarter') {\n      const quarter = Math.ceil((date.getUTCMonth() + 1) / 3);\n      const year = utcFormat(getTimeIntervalFormat('year'))(date);\n      return `Q${quarter} ${year}`;\n    }\n    const format = getTimeIntervalFormat(dateFormat);\n    return utcFormat(format)(date);\n  }\n\n  export function getTimeIntervalFormat(interval: Interval): string {\n    switch (interval) {\n      case 'day':\n      case 'week':\n        return '%m/%d/%Y';\n      case 'month':\n      case 'quarter':\n        return '%b %Y';\n      case 'year':\n        return '%Y';\n    }\n  }\n\n  export function convertChartDataToDonutData(chartData: Data): DonutData[] {\n    if (chartData.ys.find(y => y.values.length > 1)) {\n      // eslint-disable-next-line no-console\n      console.warn(\n        \"Heads up! Pie charts don't support multiple values per series\",\n      );\n    }\n\n    const donutData = chartData.ys.map(y => ({\n      label: y.label,\n      hidden: y.hidden,\n      value: y.values.length >= 1 ? y.values[0] : 0,\n      isSecondary: y.isSecondary,\n    }));\n    return donutData;\n  }\n\n  function checkYScaleType(\n    input:\n      | ScaleTime<number, number, never>\n      | ScaleLinear<number, number, never>,\n    dataType: 'labeled' | 'timeseries' | undefined,\n  ): input is ScaleTime<number, number, never> {\n    if (dataType == 'labeled') {\n      return false;\n    }\n    return true;\n  }\n\n  function arcToPoint(angle: number, radius: number) {\n    return {\n      x: radius * Math.cos(angle - Math.PI / 2),\n      y: radius * Math.sin(angle - Math.PI / 2),\n    };\n  }\n}\n"]}