@codecademy/gamut 67.6.1-alpha.1bf8a5.0 → 67.6.1-alpha.74920d.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.
Files changed (35) hide show
  1. package/dist/BarChart/Bar/elements.d.ts +1392 -0
  2. package/dist/BarChart/Bar/elements.js +59 -0
  3. package/dist/BarChart/Bar/index.d.ts +1 -0
  4. package/dist/BarChart/Bar/index.js +2 -0
  5. package/dist/BarChart/BarChartProvider.d.ts +33 -0
  6. package/dist/BarChart/BarChartProvider.js +39 -0
  7. package/dist/BarChart/BarRow.d.ts +6 -0
  8. package/dist/BarChart/BarRow.js +179 -0
  9. package/dist/BarChart/GridLines.d.ts +5 -0
  10. package/dist/BarChart/GridLines.js +57 -0
  11. package/dist/BarChart/ScaleChartHeader.d.ts +10 -0
  12. package/dist/BarChart/ScaleChartHeader.js +65 -0
  13. package/dist/BarChart/index.d.ts +4 -0
  14. package/dist/BarChart/index.js +68 -0
  15. package/dist/BarChart/types.d.ts +56 -0
  16. package/dist/BarChart/types.js +1 -0
  17. package/dist/BarChart/utils/index.d.ts +72 -0
  18. package/dist/BarChart/utils/index.js +144 -0
  19. package/dist/ConnectedForm/ConnectedFormGroup.d.ts +0 -5
  20. package/dist/ConnectedForm/ConnectedFormGroup.js +1 -1
  21. package/dist/Form/elements/FormGroupLabel.js +2 -8
  22. package/dist/GridForm/GridFormInputGroup/__fixtures__/renderers.d.ts +0 -4
  23. package/dist/GridForm/types.d.ts +0 -5
  24. package/dist/Tip/InfoTip/InfoTipButton.js +2 -5
  25. package/dist/Tip/InfoTip/elements.d.ts +12 -0
  26. package/dist/Tip/InfoTip/elements.js +9 -0
  27. package/dist/Tip/InfoTip/index.d.ts +0 -18
  28. package/dist/Tip/InfoTip/index.js +66 -37
  29. package/dist/Tip/__tests__/helpers.d.ts +26 -5
  30. package/dist/Tip/shared/FloatingTip.js +3 -3
  31. package/dist/Tip/shared/InlineTip.js +1 -4
  32. package/dist/Tip/shared/types.d.ts +1 -1
  33. package/dist/index.d.ts +1 -0
  34. package/dist/index.js +1 -0
  35. package/package.json +2 -2
@@ -0,0 +1,59 @@
1
+ import _styled from "@emotion/styled/base";
2
+ import { css } from '@codecademy/gamut-styles';
3
+ import { motion } from 'framer-motion';
4
+ import { Box } from '../../Box';
5
+ export const minBarWidth = 8;
6
+ const baseBarStyles = {
7
+ alignItems: 'center',
8
+ border: 1,
9
+ borderColor: 'border-primary',
10
+ borderRadius: 'inherit',
11
+ display: 'flex',
12
+ height: '100%',
13
+ left: 0,
14
+ position: 'absolute'
15
+ };
16
+
17
+ /**
18
+ * Animated bar element for background/total value display
19
+ */
20
+ export const BackgroundBar = /*#__PURE__*/_styled(motion.create(Box), {
21
+ target: "e1lnm2ux2",
22
+ label: "BackgroundBar"
23
+ })(css({
24
+ ...baseBarStyles
25
+ }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9CYXJDaGFydC9CYXIvZWxlbWVudHMudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXNCNkIiLCJmaWxlIjoiLi4vLi4vLi4vc3JjL0JhckNoYXJ0L0Jhci9lbGVtZW50cy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjc3MgfSBmcm9tICdAY29kZWNhZGVteS9nYW11dC1zdHlsZXMnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgbW90aW9uIH0gZnJvbSAnZnJhbWVyLW1vdGlvbic7XG5cbmltcG9ydCB7IEJveCB9IGZyb20gJy4uLy4uL0JveCc7XG5cbmV4cG9ydCBjb25zdCBtaW5CYXJXaWR0aCA9IDg7XG5cbmNvbnN0IGJhc2VCYXJTdHlsZXMgPSB7XG4gIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICBib3JkZXI6IDEsXG4gIGJvcmRlckNvbG9yOiAnYm9yZGVyLXByaW1hcnknLFxuICBib3JkZXJSYWRpdXM6ICdpbmhlcml0JyxcbiAgZGlzcGxheTogJ2ZsZXgnLFxuICBoZWlnaHQ6ICcxMDAlJyxcbiAgbGVmdDogMCxcbiAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG59IGFzIGNvbnN0O1xuXG4vKipcbiAqIEFuaW1hdGVkIGJhciBlbGVtZW50IGZvciBiYWNrZ3JvdW5kL3RvdGFsIHZhbHVlIGRpc3BsYXlcbiAqL1xuZXhwb3J0IGNvbnN0IEJhY2tncm91bmRCYXIgPSBzdHlsZWQobW90aW9uLmNyZWF0ZShCb3gpKShcbiAgY3NzKHtcbiAgICAuLi5iYXNlQmFyU3R5bGVzLFxuICB9KVxuKTtcblxuLyoqXG4gKiBGb3JlZ3JvdW5kIGJhciBmb3Igc3RhY2tlZCBkaXNwbGF5IChwcm9ncmVzcyB2YWx1ZSlcbiAqIENvbG9yIHNob3VsZCBiZSBwYXNzZWQgdmlhIGJnIHByb3AgZnJvbSBwYXJlbnRcbiAqL1xuZXhwb3J0IGNvbnN0IEZvcmVncm91bmRCYXIgPSBzdHlsZWQobW90aW9uLmNyZWF0ZShCb3gpKShcbiAgY3NzKHtcbiAgICAuLi5iYXNlQmFyU3R5bGVzLFxuICB9KVxuKTtcblxuLyoqXG4gKiBDb250YWluZXIgZm9yIGJhcnMgd2l0aCByZXNwb25zaXZlIGhlaWdodFxuICovXG5leHBvcnQgY29uc3QgQmFyV3JhcHBlciA9IHN0eWxlZChCb3gpKFxuICBjc3Moe1xuICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICBvdmVyZmxvdzogJ2hpZGRlbicsXG4gICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgZmxleDogMSxcbiAgICBoZWlnaHQ6IHsgXzogMTIsIHNtOiAyMCB9LFxuICAgIGJvcmRlclJhZGl1czogeyBfOiAnbWQnLCBzbTogJ3hsJyB9LFxuICAgIHdpZHRoOiAnMTAwJScsXG4gIH0pXG4pO1xuIl19 */");
26
+
27
+ /**
28
+ * Foreground bar for stacked display (progress value)
29
+ * Color should be passed via bg prop from parent
30
+ */
31
+ export const ForegroundBar = /*#__PURE__*/_styled(motion.create(Box), {
32
+ target: "e1lnm2ux1",
33
+ label: "ForegroundBar"
34
+ })(css({
35
+ ...baseBarStyles
36
+ }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9CYXJDaGFydC9CYXIvZWxlbWVudHMudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWdDNkIiLCJmaWxlIjoiLi4vLi4vLi4vc3JjL0JhckNoYXJ0L0Jhci9lbGVtZW50cy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjc3MgfSBmcm9tICdAY29kZWNhZGVteS9nYW11dC1zdHlsZXMnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgbW90aW9uIH0gZnJvbSAnZnJhbWVyLW1vdGlvbic7XG5cbmltcG9ydCB7IEJveCB9IGZyb20gJy4uLy4uL0JveCc7XG5cbmV4cG9ydCBjb25zdCBtaW5CYXJXaWR0aCA9IDg7XG5cbmNvbnN0IGJhc2VCYXJTdHlsZXMgPSB7XG4gIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICBib3JkZXI6IDEsXG4gIGJvcmRlckNvbG9yOiAnYm9yZGVyLXByaW1hcnknLFxuICBib3JkZXJSYWRpdXM6ICdpbmhlcml0JyxcbiAgZGlzcGxheTogJ2ZsZXgnLFxuICBoZWlnaHQ6ICcxMDAlJyxcbiAgbGVmdDogMCxcbiAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG59IGFzIGNvbnN0O1xuXG4vKipcbiAqIEFuaW1hdGVkIGJhciBlbGVtZW50IGZvciBiYWNrZ3JvdW5kL3RvdGFsIHZhbHVlIGRpc3BsYXlcbiAqL1xuZXhwb3J0IGNvbnN0IEJhY2tncm91bmRCYXIgPSBzdHlsZWQobW90aW9uLmNyZWF0ZShCb3gpKShcbiAgY3NzKHtcbiAgICAuLi5iYXNlQmFyU3R5bGVzLFxuICB9KVxuKTtcblxuLyoqXG4gKiBGb3JlZ3JvdW5kIGJhciBmb3Igc3RhY2tlZCBkaXNwbGF5IChwcm9ncmVzcyB2YWx1ZSlcbiAqIENvbG9yIHNob3VsZCBiZSBwYXNzZWQgdmlhIGJnIHByb3AgZnJvbSBwYXJlbnRcbiAqL1xuZXhwb3J0IGNvbnN0IEZvcmVncm91bmRCYXIgPSBzdHlsZWQobW90aW9uLmNyZWF0ZShCb3gpKShcbiAgY3NzKHtcbiAgICAuLi5iYXNlQmFyU3R5bGVzLFxuICB9KVxuKTtcblxuLyoqXG4gKiBDb250YWluZXIgZm9yIGJhcnMgd2l0aCByZXNwb25zaXZlIGhlaWdodFxuICovXG5leHBvcnQgY29uc3QgQmFyV3JhcHBlciA9IHN0eWxlZChCb3gpKFxuICBjc3Moe1xuICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICBvdmVyZmxvdzogJ2hpZGRlbicsXG4gICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgZmxleDogMSxcbiAgICBoZWlnaHQ6IHsgXzogMTIsIHNtOiAyMCB9LFxuICAgIGJvcmRlclJhZGl1czogeyBfOiAnbWQnLCBzbTogJ3hsJyB9LFxuICAgIHdpZHRoOiAnMTAwJScsXG4gIH0pXG4pO1xuIl19 */");
37
+
38
+ /**
39
+ * Container for bars with responsive height
40
+ */
41
+ export const BarWrapper = /*#__PURE__*/_styled(Box, {
42
+ target: "e1lnm2ux0",
43
+ label: "BarWrapper"
44
+ })(css({
45
+ display: 'flex',
46
+ overflow: 'hidden',
47
+ position: 'relative',
48
+ alignItems: 'center',
49
+ flex: 1,
50
+ height: {
51
+ _: 12,
52
+ sm: 20
53
+ },
54
+ borderRadius: {
55
+ _: 'md',
56
+ sm: 'xl'
57
+ },
58
+ width: '100%'
59
+ }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9CYXJDaGFydC9CYXIvZWxlbWVudHMudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXlDMEIiLCJmaWxlIjoiLi4vLi4vLi4vc3JjL0JhckNoYXJ0L0Jhci9lbGVtZW50cy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjc3MgfSBmcm9tICdAY29kZWNhZGVteS9nYW11dC1zdHlsZXMnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgbW90aW9uIH0gZnJvbSAnZnJhbWVyLW1vdGlvbic7XG5cbmltcG9ydCB7IEJveCB9IGZyb20gJy4uLy4uL0JveCc7XG5cbmV4cG9ydCBjb25zdCBtaW5CYXJXaWR0aCA9IDg7XG5cbmNvbnN0IGJhc2VCYXJTdHlsZXMgPSB7XG4gIGFsaWduSXRlbXM6ICdjZW50ZXInLFxuICBib3JkZXI6IDEsXG4gIGJvcmRlckNvbG9yOiAnYm9yZGVyLXByaW1hcnknLFxuICBib3JkZXJSYWRpdXM6ICdpbmhlcml0JyxcbiAgZGlzcGxheTogJ2ZsZXgnLFxuICBoZWlnaHQ6ICcxMDAlJyxcbiAgbGVmdDogMCxcbiAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG59IGFzIGNvbnN0O1xuXG4vKipcbiAqIEFuaW1hdGVkIGJhciBlbGVtZW50IGZvciBiYWNrZ3JvdW5kL3RvdGFsIHZhbHVlIGRpc3BsYXlcbiAqL1xuZXhwb3J0IGNvbnN0IEJhY2tncm91bmRCYXIgPSBzdHlsZWQobW90aW9uLmNyZWF0ZShCb3gpKShcbiAgY3NzKHtcbiAgICAuLi5iYXNlQmFyU3R5bGVzLFxuICB9KVxuKTtcblxuLyoqXG4gKiBGb3JlZ3JvdW5kIGJhciBmb3Igc3RhY2tlZCBkaXNwbGF5IChwcm9ncmVzcyB2YWx1ZSlcbiAqIENvbG9yIHNob3VsZCBiZSBwYXNzZWQgdmlhIGJnIHByb3AgZnJvbSBwYXJlbnRcbiAqL1xuZXhwb3J0IGNvbnN0IEZvcmVncm91bmRCYXIgPSBzdHlsZWQobW90aW9uLmNyZWF0ZShCb3gpKShcbiAgY3NzKHtcbiAgICAuLi5iYXNlQmFyU3R5bGVzLFxuICB9KVxuKTtcblxuLyoqXG4gKiBDb250YWluZXIgZm9yIGJhcnMgd2l0aCByZXNwb25zaXZlIGhlaWdodFxuICovXG5leHBvcnQgY29uc3QgQmFyV3JhcHBlciA9IHN0eWxlZChCb3gpKFxuICBjc3Moe1xuICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICBvdmVyZmxvdzogJ2hpZGRlbicsXG4gICAgcG9zaXRpb246ICdyZWxhdGl2ZScsXG4gICAgYWxpZ25JdGVtczogJ2NlbnRlcicsXG4gICAgZmxleDogMSxcbiAgICBoZWlnaHQ6IHsgXzogMTIsIHNtOiAyMCB9LFxuICAgIGJvcmRlclJhZGl1czogeyBfOiAnbWQnLCBzbTogJ3hsJyB9LFxuICAgIHdpZHRoOiAnMTAwJScsXG4gIH0pXG4pO1xuIl19 */");
@@ -0,0 +1 @@
1
+ export * from './elements';
@@ -0,0 +1,2 @@
1
+ // Re-export bar elements
2
+ export * from './elements';
@@ -0,0 +1,33 @@
1
+ /// <reference types="react" />
2
+ import { BarChartStyles } from './types';
3
+ export interface BarChartContextProps {
4
+ minRange: number;
5
+ maxRange: number;
6
+ xScale: number;
7
+ unit: string;
8
+ styleConfig: Required<BarChartStyles>;
9
+ animate: boolean;
10
+ }
11
+ export declare const BarChartContext: import("react").Context<BarChartContextProps>;
12
+ export declare const BarChartProvider: import("react").Provider<BarChartContextProps>;
13
+ export declare function useBarChartContext(): BarChartContextProps;
14
+ export interface UseBarChartOptions {
15
+ minRange: number;
16
+ maxRange: number;
17
+ xScale?: number;
18
+ unit?: string;
19
+ styleConfig?: BarChartStyles;
20
+ animate?: boolean;
21
+ }
22
+ export declare function useBarChart({ minRange, maxRange, xScale, unit, styleConfig, animate, }: UseBarChartOptions): {
23
+ minRange: number;
24
+ maxRange: number;
25
+ xScale: number;
26
+ unit: string;
27
+ styleConfig: {
28
+ textColor: "text" | "background" | "primary" | "secondary" | "danger" | "interface" | "text-secondary" | "text-accent" | "text-disabled" | "feedback-error" | "feedback-success" | "feedback-warning" | "background-primary" | "background-disabled" | "background-error" | "background-success" | "background-warning" | "background-contrast" | "background-current" | "background-selected" | "background-hover" | "shadow-primary" | "shadow-secondary" | "primary-hover" | "primary-inverse" | "secondary-hover" | "danger-hover" | "interface-hover" | "border-primary" | "border-secondary" | "border-disabled" | "border-tertiary";
29
+ foregroundBarColor: "text" | "background" | "primary" | "secondary" | "danger" | "interface" | "text-secondary" | "text-accent" | "text-disabled" | "feedback-error" | "feedback-success" | "feedback-warning" | "background-primary" | "background-disabled" | "background-error" | "background-success" | "background-warning" | "background-contrast" | "background-current" | "background-selected" | "background-hover" | "shadow-primary" | "shadow-secondary" | "primary-hover" | "primary-inverse" | "secondary-hover" | "danger-hover" | "interface-hover" | "border-primary" | "border-secondary" | "border-disabled" | "border-tertiary";
30
+ backgroundBarColor: "text" | "background" | "primary" | "secondary" | "danger" | "interface" | "text-secondary" | "text-accent" | "text-disabled" | "feedback-error" | "feedback-success" | "feedback-warning" | "background-primary" | "background-disabled" | "background-error" | "background-success" | "background-warning" | "background-contrast" | "background-current" | "background-selected" | "background-hover" | "shadow-primary" | "shadow-secondary" | "primary-hover" | "primary-inverse" | "secondary-hover" | "danger-hover" | "interface-hover" | "border-primary" | "border-secondary" | "border-disabled" | "border-tertiary";
31
+ };
32
+ animate: boolean;
33
+ };
@@ -0,0 +1,39 @@
1
+ import { createContext, useContext, useMemo } from 'react';
2
+ const defaultStyleConfig = {
3
+ textColor: 'text',
4
+ foregroundBarColor: 'feedback-warning',
5
+ backgroundBarColor: 'background-primary'
6
+ };
7
+ export const BarChartContext = /*#__PURE__*/createContext({
8
+ minRange: 0,
9
+ maxRange: 100,
10
+ xScale: 10,
11
+ unit: '',
12
+ styleConfig: defaultStyleConfig,
13
+ animate: false
14
+ });
15
+ BarChartContext.displayName = 'BarChartContext';
16
+ export const BarChartProvider = BarChartContext.Provider;
17
+ export function useBarChartContext() {
18
+ return useContext(BarChartContext);
19
+ }
20
+ export function useBarChart({
21
+ minRange,
22
+ maxRange,
23
+ xScale,
24
+ unit = '',
25
+ styleConfig,
26
+ animate = false
27
+ }) {
28
+ return useMemo(() => ({
29
+ minRange,
30
+ maxRange,
31
+ xScale: xScale ?? Math.ceil((maxRange - minRange) / 5),
32
+ unit,
33
+ styleConfig: {
34
+ ...defaultStyleConfig,
35
+ ...styleConfig
36
+ },
37
+ animate
38
+ }), [minRange, maxRange, xScale, unit, styleConfig, animate]);
39
+ }
@@ -0,0 +1,6 @@
1
+ /// <reference types="react" />
2
+ import { BarProps } from './types';
3
+ export interface BarRowProps extends BarProps {
4
+ index?: number;
5
+ }
6
+ export declare const BarRow: import("react").ForwardRefExoticComponent<BarRowProps & import("react").RefAttributes<HTMLDivElement | HTMLAnchorElement | HTMLButtonElement>>;
@@ -0,0 +1,179 @@
1
+ import _styled from "@emotion/styled/base";
2
+ function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }
3
+ import { css, styledOptions } from '@codecademy/gamut-styles';
4
+ import { forwardRef } from 'react';
5
+ import { FlexBox } from '../Box';
6
+ import { Text } from '../Typography';
7
+ import { BackgroundBar, BarWrapper, ForegroundBar, minBarWidth } from './Bar/elements';
8
+ import { useBarChartContext } from './BarChartProvider';
9
+ import { calculateBarWidth, getValuesSummary } from './utils';
10
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
11
+ const rowBaseStyles = css({
12
+ display: 'flex',
13
+ alignItems: 'center',
14
+ width: '100%',
15
+ gap: 16,
16
+ py: 8,
17
+ px: 16,
18
+ bg: 'transparent',
19
+ border: 'none',
20
+ textDecoration: 'none',
21
+ cursor: 'inherit',
22
+ '&:focus': {
23
+ outline: 'none'
24
+ },
25
+ '&:focus-visible': {
26
+ outline: '2px solid',
27
+ outlineColor: 'primary',
28
+ outlineOffset: '2px'
29
+ }
30
+ });
31
+ const interactiveStyles = css({
32
+ cursor: 'pointer',
33
+ '&:hover': {
34
+ bg: 'background-hover'
35
+ }
36
+ });
37
+ const RowWrapper = /*#__PURE__*/_styled('div', _extends({}, {
38
+ target: "eew7ix72",
39
+ label: "RowWrapper"
40
+ }, styledOptions()))(rowBaseStyles, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9CYXJDaGFydC9CYXJSb3cudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTRDbUIiLCJmaWxlIjoiLi4vLi4vc3JjL0JhckNoYXJ0L0JhclJvdy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjc3MsIHN0eWxlZE9wdGlvbnMgfSBmcm9tICdAY29kZWNhZGVteS9nYW11dC1zdHlsZXMnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgZm9yd2FyZFJlZiwgTW91c2VFdmVudCwgTXV0YWJsZVJlZk9iamVjdCB9IGZyb20gJ3JlYWN0JztcblxuaW1wb3J0IHsgRmxleEJveCB9IGZyb20gJy4uL0JveCc7XG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vVHlwb2dyYXBoeSc7XG5pbXBvcnQge1xuICBCYWNrZ3JvdW5kQmFyLFxuICBCYXJXcmFwcGVyLFxuICBGb3JlZ3JvdW5kQmFyLFxuICBtaW5CYXJXaWR0aCxcbn0gZnJvbSAnLi9CYXIvZWxlbWVudHMnO1xuaW1wb3J0IHsgdXNlQmFyQ2hhcnRDb250ZXh0IH0gZnJvbSAnLi9CYXJDaGFydFByb3ZpZGVyJztcbmltcG9ydCB7IEJhclByb3BzIH0gZnJvbSAnLi90eXBlcyc7XG5pbXBvcnQgeyBjYWxjdWxhdGVCYXJXaWR0aCwgZ2V0VmFsdWVzU3VtbWFyeSB9IGZyb20gJy4vdXRpbHMnO1xuXG5jb25zdCByb3dCYXNlU3R5bGVzID0gY3NzKHtcbiAgZGlzcGxheTogJ2ZsZXgnLFxuICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgd2lkdGg6ICcxMDAlJyxcbiAgZ2FwOiAxNixcbiAgcHk6IDgsXG4gIHB4OiAxNixcbiAgYmc6ICd0cmFuc3BhcmVudCcsXG4gIGJvcmRlcjogJ25vbmUnLFxuICB0ZXh0RGVjb3JhdGlvbjogJ25vbmUnLFxuICBjdXJzb3I6ICdpbmhlcml0JyxcbiAgJyY6Zm9jdXMnOiB7XG4gICAgb3V0bGluZTogJ25vbmUnLFxuICB9LFxuICAnJjpmb2N1cy12aXNpYmxlJzoge1xuICAgIG91dGxpbmU6ICcycHggc29saWQnLFxuICAgIG91dGxpbmVDb2xvcjogJ3ByaW1hcnknLFxuICAgIG91dGxpbmVPZmZzZXQ6ICcycHgnLFxuICB9LFxufSk7XG5cbmNvbnN0IGludGVyYWN0aXZlU3R5bGVzID0gY3NzKHtcbiAgY3Vyc29yOiAncG9pbnRlcicsXG4gICcmOmhvdmVyJzoge1xuICAgIGJnOiAnYmFja2dyb3VuZC1ob3ZlcicsXG4gIH0sXG59KTtcblxuY29uc3QgUm93V3JhcHBlciA9IHN0eWxlZCgnZGl2Jywgc3R5bGVkT3B0aW9uczwnZGl2Jz4oKSkocm93QmFzZVN0eWxlcyk7XG5jb25zdCBSb3dCdXR0b24gPSBzdHlsZWQoJ2J1dHRvbicsIHN0eWxlZE9wdGlvbnM8J2J1dHRvbic+KCkpKFxuICByb3dCYXNlU3R5bGVzLFxuICBpbnRlcmFjdGl2ZVN0eWxlc1xuKTtcbmNvbnN0IFJvd0FuY2hvciA9IHN0eWxlZCgnYScsIHN0eWxlZE9wdGlvbnM8J2EnPigpKShcbiAgcm93QmFzZVN0eWxlcyxcbiAgaW50ZXJhY3RpdmVTdHlsZXNcbik7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQmFyUm93UHJvcHMgZXh0ZW5kcyBCYXJQcm9wcyB7XG4gIGluZGV4PzogbnVtYmVyO1xufVxuXG5leHBvcnQgY29uc3QgQmFyUm93ID0gZm9yd2FyZFJlZjxcbiAgSFRNTERpdkVsZW1lbnQgfCBIVE1MQnV0dG9uRWxlbWVudCB8IEhUTUxBbmNob3JFbGVtZW50LFxuICBCYXJSb3dQcm9wc1xuPihcbiAgKFxuICAgIHtcbiAgICAgIHlMYWJlbCxcbiAgICAgIHNlcmllc09uZVZhbHVlLFxuICAgICAgc2VyaWVzVHdvVmFsdWUsXG4gICAgICBpY29uOiBJY29uLFxuICAgICAgb25DbGljayxcbiAgICAgIGhyZWYsXG4gICAgICBpbmRleCA9IDAsXG4gICAgfSxcbiAgICByZWZcbiAgKSA9PiB7XG4gICAgY29uc3QgeyBtaW5SYW5nZSwgbWF4UmFuZ2UsIHVuaXQsIHN0eWxlQ29uZmlnLCBhbmltYXRlIH0gPVxuICAgICAgdXNlQmFyQ2hhcnRDb250ZXh0KCk7XG5cbiAgICBjb25zdCBpc1N0YWNrZWQgPSBzZXJpZXNUd29WYWx1ZSAhPT0gdW5kZWZpbmVkO1xuICAgIGNvbnN0IGRpc3BsYXlWYWx1ZSA9IGlzU3RhY2tlZCA/IHNlcmllc1R3b1ZhbHVlIDogc2VyaWVzT25lVmFsdWU7XG5cbiAgICBjb25zdCBiYWNrZ3JvdW5kQmFyV2lkdGggPSBjYWxjdWxhdGVCYXJXaWR0aCh7XG4gICAgICB2YWx1ZTogZGlzcGxheVZhbHVlLFxuICAgICAgbWluUmFuZ2UsXG4gICAgICBtYXhSYW5nZSxcbiAgICB9KTtcblxuICAgIGNvbnN0IGZvcmVncm91bmRCYXJXaWR0aCA9IGlzU3RhY2tlZFxuICAgICAgPyBjYWxjdWxhdGVCYXJXaWR0aCh7XG4gICAgICAgICAgdmFsdWU6IHNlcmllc09uZVZhbHVlLFxuICAgICAgICAgIG1pblJhbmdlLFxuICAgICAgICAgIG1heFJhbmdlLFxuICAgICAgICB9KVxuICAgICAgOiAwO1xuXG4gICAgY29uc3QgYmdXaWR0aFN0ciA9IGAke01hdGgubWF4KG1pbkJhcldpZHRoLCBiYWNrZ3JvdW5kQmFyV2lkdGgpfSVgO1xuICAgIGNvbnN0IGZnV2lkdGhTdHIgPSBgJHtNYXRoLm1heChtaW5CYXJXaWR0aCwgZm9yZWdyb3VuZEJhcldpZHRoKX0lYDtcblxuICAgIGNvbnN0IHZhbHVlc1N1bW1hcnkgPSBnZXRWYWx1ZXNTdW1tYXJ5KHtcbiAgICAgIHlMYWJlbCxcbiAgICAgIHNlcmllc09uZVZhbHVlLFxuICAgICAgc2VyaWVzVHdvVmFsdWUsXG4gICAgICB1bml0LFxuICAgIH0pO1xuXG4gICAgY29uc3QgYW5pbWF0aW9uRGVsYXkgPSBhbmltYXRlID8gaW5kZXggKiAwLjEgOiAwO1xuXG4gICAgY29uc3Qgcm93Q29udGVudCA9IChcbiAgICAgIDw+XG4gICAgICAgIDxGbGV4Qm94XG4gICAgICAgICAgYWxpZ25JdGVtcz1cImNlbnRlclwiXG4gICAgICAgICAgY29sb3I9e3N0eWxlQ29uZmlnLnRleHRDb2xvcn1cbiAgICAgICAgICBmbGV4U2hyaW5rPXswfVxuICAgICAgICAgIGdhcD17OH1cbiAgICAgICAgICBtaW5XaWR0aD1cIjIwMHB4XCJcbiAgICAgICAgPlxuICAgICAgICAgIHtJY29uICYmIDxJY29uIHNpemU9ezE2fSAvPn1cbiAgICAgICAgICA8VGV4dCBmb250V2VpZ2h0PVwiYm9sZFwiIHRydW5jYXRlPVwiZWxsaXBzaXNcIiB0cnVuY2F0ZUxpbmVzPXsxfT5cbiAgICAgICAgICAgIHt5TGFiZWx9XG4gICAgICAgICAgPC9UZXh0PlxuICAgICAgICA8L0ZsZXhCb3g+XG5cbiAgICAgICAgPEJhcldyYXBwZXI+XG4gICAgICAgICAgPEJhY2tncm91bmRCYXJcbiAgICAgICAgICAgIGFuaW1hdGU9e2FuaW1hdGUgPyB7IHdpZHRoOiBiZ1dpZHRoU3RyIH0gOiB1bmRlZmluZWR9XG4gICAgICAgICAgICBiZz17c3R5bGVDb25maWcuYmFja2dyb3VuZEJhckNvbG9yfVxuICAgICAgICAgICAgZGF0YS10ZXN0aWQ9XCJiYWNrZ3JvdW5kLWJhclwiXG4gICAgICAgICAgICBpbml0aWFsPXthbmltYXRlID8geyB3aWR0aDogJzAlJyB9IDogdW5kZWZpbmVkfVxuICAgICAgICAgICAgdHJhbnNpdGlvbj17eyBkdXJhdGlvbjogMC41LCBkZWxheTogYW5pbWF0aW9uRGVsYXkgfX1cbiAgICAgICAgICAgIHdpZHRoPXshYW5pbWF0ZSA/IGJnV2lkdGhTdHIgOiB1bmRlZmluZWR9XG4gICAgICAgICAgLz5cbiAgICAgICAgICB7aXNTdGFja2VkICYmIChcbiAgICAgICAgICAgIDxGb3JlZ3JvdW5kQmFyXG4gICAgICAgICAgICAgIGFuaW1hdGU9e2FuaW1hdGUgPyB7IHdpZHRoOiBmZ1dpZHRoU3RyIH0gOiB1bmRlZmluZWR9XG4gICAgICAgICAgICAgIGJnPXtzdHlsZUNvbmZpZy5mb3JlZ3JvdW5kQmFyQ29sb3J9XG4gICAgICAgICAgICAgIGRhdGEtdGVzdGlkPVwiZm9yZWdyb3VuZC1iYXJcIlxuICAgICAgICAgICAgICBpbml0aWFsPXthbmltYXRlID8geyB3aWR0aDogJzAlJyB9IDogdW5kZWZpbmVkfVxuICAgICAgICAgICAgICB0cmFuc2l0aW9uPXt7IGR1cmF0aW9uOiAwLjUsIGRlbGF5OiBhbmltYXRpb25EZWxheSArIDAuMjUgfX1cbiAgICAgICAgICAgICAgd2lkdGg9eyFhbmltYXRlID8gZmdXaWR0aFN0ciA6IHVuZGVmaW5lZH1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgKX1cbiAgICAgICAgPC9CYXJXcmFwcGVyPlxuXG4gICAgICAgIDxGbGV4Qm94XG4gICAgICAgICAgYWxpZ25JdGVtcz1cImNlbnRlclwiXG4gICAgICAgICAgZmxleFNocmluaz17MH1cbiAgICAgICAgICBqdXN0aWZ5Q29udGVudD1cImZsZXgtZW5kXCJcbiAgICAgICAgICBtaW5XaWR0aD17eyBfOiA0MCwgc206IDYwIH19XG4gICAgICAgID5cbiAgICAgICAgICA8VGV4dCBjb2xvcj17c3R5bGVDb25maWcudGV4dENvbG9yfSB2YXJpYW50PVwicC1zbWFsbFwiPlxuICAgICAgICAgICAge2Rpc3BsYXlWYWx1ZS50b0xvY2FsZVN0cmluZygpfVxuICAgICAgICAgICAge3VuaXQgJiYgYCAke3VuaXR9YH1cbiAgICAgICAgICA8L1RleHQ+XG4gICAgICAgIDwvRmxleEJveD5cbiAgICAgIDwvPlxuICAgICk7XG5cbiAgICBpZiAoaHJlZikge1xuICAgICAgcmV0dXJuIChcbiAgICAgICAgPGxpPlxuICAgICAgICAgIDxSb3dBbmNob3JcbiAgICAgICAgICAgIGFyaWEtbGFiZWw9e3ZhbHVlc1N1bW1hcnl9XG4gICAgICAgICAgICBocmVmPXtocmVmfVxuICAgICAgICAgICAgcmVmPXtyZWYgYXMgTXV0YWJsZVJlZk9iamVjdDxIVE1MQW5jaG9yRWxlbWVudD59XG4gICAgICAgICAgPlxuICAgICAgICAgICAge3Jvd0NvbnRlbnR9XG4gICAgICAgICAgPC9Sb3dBbmNob3I+XG4gICAgICAgIDwvbGk+XG4gICAgICApO1xuICAgIH1cblxuICAgIGlmIChvbkNsaWNrKSB7XG4gICAgICByZXR1cm4gKFxuICAgICAgICA8bGk+XG4gICAgICAgICAgPFJvd0J1dHRvblxuICAgICAgICAgICAgYXJpYS1sYWJlbD17dmFsdWVzU3VtbWFyeX1cbiAgICAgICAgICAgIHJlZj17cmVmIGFzIE11dGFibGVSZWZPYmplY3Q8SFRNTEJ1dHRvbkVsZW1lbnQ+fVxuICAgICAgICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICAgICAgICBvbkNsaWNrPXtvbkNsaWNrfVxuICAgICAgICAgICAgb25LZXlEb3duPXsoZSkgPT4ge1xuICAgICAgICAgICAgICBpZiAoZS5rZXkgPT09ICdFbnRlcicpIHtcbiAgICAgICAgICAgICAgICBvbkNsaWNrKGUgYXMgdW5rbm93biBhcyBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50Pik7XG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH19XG4gICAgICAgICAgPlxuICAgICAgICAgICAge3Jvd0NvbnRlbnR9XG4gICAgICAgICAgPC9Sb3dCdXR0b24+XG4gICAgICAgIDwvbGk+XG4gICAgICApO1xuICAgIH1cblxuICAgIHJldHVybiAoXG4gICAgICA8bGk+XG4gICAgICAgIDxSb3dXcmFwcGVyXG4gICAgICAgICAgYXJpYS1sYWJlbD17dmFsdWVzU3VtbWFyeX1cbiAgICAgICAgICByZWY9e3JlZiBhcyBNdXRhYmxlUmVmT2JqZWN0PEhUTUxEaXZFbGVtZW50Pn1cbiAgICAgICAgPlxuICAgICAgICAgIHtyb3dDb250ZW50fVxuICAgICAgICA8L1Jvd1dyYXBwZXI+XG4gICAgICA8L2xpPlxuICAgICk7XG4gIH1cbik7XG4iXX0= */");
41
+ const RowButton = /*#__PURE__*/_styled('button', _extends({}, {
42
+ target: "eew7ix71",
43
+ label: "RowButton"
44
+ }, styledOptions()))(rowBaseStyles, interactiveStyles, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9CYXJDaGFydC9CYXJSb3cudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTZDa0IiLCJmaWxlIjoiLi4vLi4vc3JjL0JhckNoYXJ0L0JhclJvdy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjc3MsIHN0eWxlZE9wdGlvbnMgfSBmcm9tICdAY29kZWNhZGVteS9nYW11dC1zdHlsZXMnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgZm9yd2FyZFJlZiwgTW91c2VFdmVudCwgTXV0YWJsZVJlZk9iamVjdCB9IGZyb20gJ3JlYWN0JztcblxuaW1wb3J0IHsgRmxleEJveCB9IGZyb20gJy4uL0JveCc7XG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vVHlwb2dyYXBoeSc7XG5pbXBvcnQge1xuICBCYWNrZ3JvdW5kQmFyLFxuICBCYXJXcmFwcGVyLFxuICBGb3JlZ3JvdW5kQmFyLFxuICBtaW5CYXJXaWR0aCxcbn0gZnJvbSAnLi9CYXIvZWxlbWVudHMnO1xuaW1wb3J0IHsgdXNlQmFyQ2hhcnRDb250ZXh0IH0gZnJvbSAnLi9CYXJDaGFydFByb3ZpZGVyJztcbmltcG9ydCB7IEJhclByb3BzIH0gZnJvbSAnLi90eXBlcyc7XG5pbXBvcnQgeyBjYWxjdWxhdGVCYXJXaWR0aCwgZ2V0VmFsdWVzU3VtbWFyeSB9IGZyb20gJy4vdXRpbHMnO1xuXG5jb25zdCByb3dCYXNlU3R5bGVzID0gY3NzKHtcbiAgZGlzcGxheTogJ2ZsZXgnLFxuICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgd2lkdGg6ICcxMDAlJyxcbiAgZ2FwOiAxNixcbiAgcHk6IDgsXG4gIHB4OiAxNixcbiAgYmc6ICd0cmFuc3BhcmVudCcsXG4gIGJvcmRlcjogJ25vbmUnLFxuICB0ZXh0RGVjb3JhdGlvbjogJ25vbmUnLFxuICBjdXJzb3I6ICdpbmhlcml0JyxcbiAgJyY6Zm9jdXMnOiB7XG4gICAgb3V0bGluZTogJ25vbmUnLFxuICB9LFxuICAnJjpmb2N1cy12aXNpYmxlJzoge1xuICAgIG91dGxpbmU6ICcycHggc29saWQnLFxuICAgIG91dGxpbmVDb2xvcjogJ3ByaW1hcnknLFxuICAgIG91dGxpbmVPZmZzZXQ6ICcycHgnLFxuICB9LFxufSk7XG5cbmNvbnN0IGludGVyYWN0aXZlU3R5bGVzID0gY3NzKHtcbiAgY3Vyc29yOiAncG9pbnRlcicsXG4gICcmOmhvdmVyJzoge1xuICAgIGJnOiAnYmFja2dyb3VuZC1ob3ZlcicsXG4gIH0sXG59KTtcblxuY29uc3QgUm93V3JhcHBlciA9IHN0eWxlZCgnZGl2Jywgc3R5bGVkT3B0aW9uczwnZGl2Jz4oKSkocm93QmFzZVN0eWxlcyk7XG5jb25zdCBSb3dCdXR0b24gPSBzdHlsZWQoJ2J1dHRvbicsIHN0eWxlZE9wdGlvbnM8J2J1dHRvbic+KCkpKFxuICByb3dCYXNlU3R5bGVzLFxuICBpbnRlcmFjdGl2ZVN0eWxlc1xuKTtcbmNvbnN0IFJvd0FuY2hvciA9IHN0eWxlZCgnYScsIHN0eWxlZE9wdGlvbnM8J2EnPigpKShcbiAgcm93QmFzZVN0eWxlcyxcbiAgaW50ZXJhY3RpdmVTdHlsZXNcbik7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQmFyUm93UHJvcHMgZXh0ZW5kcyBCYXJQcm9wcyB7XG4gIGluZGV4PzogbnVtYmVyO1xufVxuXG5leHBvcnQgY29uc3QgQmFyUm93ID0gZm9yd2FyZFJlZjxcbiAgSFRNTERpdkVsZW1lbnQgfCBIVE1MQnV0dG9uRWxlbWVudCB8IEhUTUxBbmNob3JFbGVtZW50LFxuICBCYXJSb3dQcm9wc1xuPihcbiAgKFxuICAgIHtcbiAgICAgIHlMYWJlbCxcbiAgICAgIHNlcmllc09uZVZhbHVlLFxuICAgICAgc2VyaWVzVHdvVmFsdWUsXG4gICAgICBpY29uOiBJY29uLFxuICAgICAgb25DbGljayxcbiAgICAgIGhyZWYsXG4gICAgICBpbmRleCA9IDAsXG4gICAgfSxcbiAgICByZWZcbiAgKSA9PiB7XG4gICAgY29uc3QgeyBtaW5SYW5nZSwgbWF4UmFuZ2UsIHVuaXQsIHN0eWxlQ29uZmlnLCBhbmltYXRlIH0gPVxuICAgICAgdXNlQmFyQ2hhcnRDb250ZXh0KCk7XG5cbiAgICBjb25zdCBpc1N0YWNrZWQgPSBzZXJpZXNUd29WYWx1ZSAhPT0gdW5kZWZpbmVkO1xuICAgIGNvbnN0IGRpc3BsYXlWYWx1ZSA9IGlzU3RhY2tlZCA/IHNlcmllc1R3b1ZhbHVlIDogc2VyaWVzT25lVmFsdWU7XG5cbiAgICBjb25zdCBiYWNrZ3JvdW5kQmFyV2lkdGggPSBjYWxjdWxhdGVCYXJXaWR0aCh7XG4gICAgICB2YWx1ZTogZGlzcGxheVZhbHVlLFxuICAgICAgbWluUmFuZ2UsXG4gICAgICBtYXhSYW5nZSxcbiAgICB9KTtcblxuICAgIGNvbnN0IGZvcmVncm91bmRCYXJXaWR0aCA9IGlzU3RhY2tlZFxuICAgICAgPyBjYWxjdWxhdGVCYXJXaWR0aCh7XG4gICAgICAgICAgdmFsdWU6IHNlcmllc09uZVZhbHVlLFxuICAgICAgICAgIG1pblJhbmdlLFxuICAgICAgICAgIG1heFJhbmdlLFxuICAgICAgICB9KVxuICAgICAgOiAwO1xuXG4gICAgY29uc3QgYmdXaWR0aFN0ciA9IGAke01hdGgubWF4KG1pbkJhcldpZHRoLCBiYWNrZ3JvdW5kQmFyV2lkdGgpfSVgO1xuICAgIGNvbnN0IGZnV2lkdGhTdHIgPSBgJHtNYXRoLm1heChtaW5CYXJXaWR0aCwgZm9yZWdyb3VuZEJhcldpZHRoKX0lYDtcblxuICAgIGNvbnN0IHZhbHVlc1N1bW1hcnkgPSBnZXRWYWx1ZXNTdW1tYXJ5KHtcbiAgICAgIHlMYWJlbCxcbiAgICAgIHNlcmllc09uZVZhbHVlLFxuICAgICAgc2VyaWVzVHdvVmFsdWUsXG4gICAgICB1bml0LFxuICAgIH0pO1xuXG4gICAgY29uc3QgYW5pbWF0aW9uRGVsYXkgPSBhbmltYXRlID8gaW5kZXggKiAwLjEgOiAwO1xuXG4gICAgY29uc3Qgcm93Q29udGVudCA9IChcbiAgICAgIDw+XG4gICAgICAgIDxGbGV4Qm94XG4gICAgICAgICAgYWxpZ25JdGVtcz1cImNlbnRlclwiXG4gICAgICAgICAgY29sb3I9e3N0eWxlQ29uZmlnLnRleHRDb2xvcn1cbiAgICAgICAgICBmbGV4U2hyaW5rPXswfVxuICAgICAgICAgIGdhcD17OH1cbiAgICAgICAgICBtaW5XaWR0aD1cIjIwMHB4XCJcbiAgICAgICAgPlxuICAgICAgICAgIHtJY29uICYmIDxJY29uIHNpemU9ezE2fSAvPn1cbiAgICAgICAgICA8VGV4dCBmb250V2VpZ2h0PVwiYm9sZFwiIHRydW5jYXRlPVwiZWxsaXBzaXNcIiB0cnVuY2F0ZUxpbmVzPXsxfT5cbiAgICAgICAgICAgIHt5TGFiZWx9XG4gICAgICAgICAgPC9UZXh0PlxuICAgICAgICA8L0ZsZXhCb3g+XG5cbiAgICAgICAgPEJhcldyYXBwZXI+XG4gICAgICAgICAgPEJhY2tncm91bmRCYXJcbiAgICAgICAgICAgIGFuaW1hdGU9e2FuaW1hdGUgPyB7IHdpZHRoOiBiZ1dpZHRoU3RyIH0gOiB1bmRlZmluZWR9XG4gICAgICAgICAgICBiZz17c3R5bGVDb25maWcuYmFja2dyb3VuZEJhckNvbG9yfVxuICAgICAgICAgICAgZGF0YS10ZXN0aWQ9XCJiYWNrZ3JvdW5kLWJhclwiXG4gICAgICAgICAgICBpbml0aWFsPXthbmltYXRlID8geyB3aWR0aDogJzAlJyB9IDogdW5kZWZpbmVkfVxuICAgICAgICAgICAgdHJhbnNpdGlvbj17eyBkdXJhdGlvbjogMC41LCBkZWxheTogYW5pbWF0aW9uRGVsYXkgfX1cbiAgICAgICAgICAgIHdpZHRoPXshYW5pbWF0ZSA/IGJnV2lkdGhTdHIgOiB1bmRlZmluZWR9XG4gICAgICAgICAgLz5cbiAgICAgICAgICB7aXNTdGFja2VkICYmIChcbiAgICAgICAgICAgIDxGb3JlZ3JvdW5kQmFyXG4gICAgICAgICAgICAgIGFuaW1hdGU9e2FuaW1hdGUgPyB7IHdpZHRoOiBmZ1dpZHRoU3RyIH0gOiB1bmRlZmluZWR9XG4gICAgICAgICAgICAgIGJnPXtzdHlsZUNvbmZpZy5mb3JlZ3JvdW5kQmFyQ29sb3J9XG4gICAgICAgICAgICAgIGRhdGEtdGVzdGlkPVwiZm9yZWdyb3VuZC1iYXJcIlxuICAgICAgICAgICAgICBpbml0aWFsPXthbmltYXRlID8geyB3aWR0aDogJzAlJyB9IDogdW5kZWZpbmVkfVxuICAgICAgICAgICAgICB0cmFuc2l0aW9uPXt7IGR1cmF0aW9uOiAwLjUsIGRlbGF5OiBhbmltYXRpb25EZWxheSArIDAuMjUgfX1cbiAgICAgICAgICAgICAgd2lkdGg9eyFhbmltYXRlID8gZmdXaWR0aFN0ciA6IHVuZGVmaW5lZH1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgKX1cbiAgICAgICAgPC9CYXJXcmFwcGVyPlxuXG4gICAgICAgIDxGbGV4Qm94XG4gICAgICAgICAgYWxpZ25JdGVtcz1cImNlbnRlclwiXG4gICAgICAgICAgZmxleFNocmluaz17MH1cbiAgICAgICAgICBqdXN0aWZ5Q29udGVudD1cImZsZXgtZW5kXCJcbiAgICAgICAgICBtaW5XaWR0aD17eyBfOiA0MCwgc206IDYwIH19XG4gICAgICAgID5cbiAgICAgICAgICA8VGV4dCBjb2xvcj17c3R5bGVDb25maWcudGV4dENvbG9yfSB2YXJpYW50PVwicC1zbWFsbFwiPlxuICAgICAgICAgICAge2Rpc3BsYXlWYWx1ZS50b0xvY2FsZVN0cmluZygpfVxuICAgICAgICAgICAge3VuaXQgJiYgYCAke3VuaXR9YH1cbiAgICAgICAgICA8L1RleHQ+XG4gICAgICAgIDwvRmxleEJveD5cbiAgICAgIDwvPlxuICAgICk7XG5cbiAgICBpZiAoaHJlZikge1xuICAgICAgcmV0dXJuIChcbiAgICAgICAgPGxpPlxuICAgICAgICAgIDxSb3dBbmNob3JcbiAgICAgICAgICAgIGFyaWEtbGFiZWw9e3ZhbHVlc1N1bW1hcnl9XG4gICAgICAgICAgICBocmVmPXtocmVmfVxuICAgICAgICAgICAgcmVmPXtyZWYgYXMgTXV0YWJsZVJlZk9iamVjdDxIVE1MQW5jaG9yRWxlbWVudD59XG4gICAgICAgICAgPlxuICAgICAgICAgICAge3Jvd0NvbnRlbnR9XG4gICAgICAgICAgPC9Sb3dBbmNob3I+XG4gICAgICAgIDwvbGk+XG4gICAgICApO1xuICAgIH1cblxuICAgIGlmIChvbkNsaWNrKSB7XG4gICAgICByZXR1cm4gKFxuICAgICAgICA8bGk+XG4gICAgICAgICAgPFJvd0J1dHRvblxuICAgICAgICAgICAgYXJpYS1sYWJlbD17dmFsdWVzU3VtbWFyeX1cbiAgICAgICAgICAgIHJlZj17cmVmIGFzIE11dGFibGVSZWZPYmplY3Q8SFRNTEJ1dHRvbkVsZW1lbnQ+fVxuICAgICAgICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICAgICAgICBvbkNsaWNrPXtvbkNsaWNrfVxuICAgICAgICAgICAgb25LZXlEb3duPXsoZSkgPT4ge1xuICAgICAgICAgICAgICBpZiAoZS5rZXkgPT09ICdFbnRlcicpIHtcbiAgICAgICAgICAgICAgICBvbkNsaWNrKGUgYXMgdW5rbm93biBhcyBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50Pik7XG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH19XG4gICAgICAgICAgPlxuICAgICAgICAgICAge3Jvd0NvbnRlbnR9XG4gICAgICAgICAgPC9Sb3dCdXR0b24+XG4gICAgICAgIDwvbGk+XG4gICAgICApO1xuICAgIH1cblxuICAgIHJldHVybiAoXG4gICAgICA8bGk+XG4gICAgICAgIDxSb3dXcmFwcGVyXG4gICAgICAgICAgYXJpYS1sYWJlbD17dmFsdWVzU3VtbWFyeX1cbiAgICAgICAgICByZWY9e3JlZiBhcyBNdXRhYmxlUmVmT2JqZWN0PEhUTUxEaXZFbGVtZW50Pn1cbiAgICAgICAgPlxuICAgICAgICAgIHtyb3dDb250ZW50fVxuICAgICAgICA8L1Jvd1dyYXBwZXI+XG4gICAgICA8L2xpPlxuICAgICk7XG4gIH1cbik7XG4iXX0= */");
45
+ const RowAnchor = /*#__PURE__*/_styled('a', _extends({}, {
46
+ target: "eew7ix70",
47
+ label: "RowAnchor"
48
+ }, styledOptions()))(rowBaseStyles, interactiveStyles, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9CYXJDaGFydC9CYXJSb3cudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlEa0IiLCJmaWxlIjoiLi4vLi4vc3JjL0JhckNoYXJ0L0JhclJvdy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjc3MsIHN0eWxlZE9wdGlvbnMgfSBmcm9tICdAY29kZWNhZGVteS9nYW11dC1zdHlsZXMnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgZm9yd2FyZFJlZiwgTW91c2VFdmVudCwgTXV0YWJsZVJlZk9iamVjdCB9IGZyb20gJ3JlYWN0JztcblxuaW1wb3J0IHsgRmxleEJveCB9IGZyb20gJy4uL0JveCc7XG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vVHlwb2dyYXBoeSc7XG5pbXBvcnQge1xuICBCYWNrZ3JvdW5kQmFyLFxuICBCYXJXcmFwcGVyLFxuICBGb3JlZ3JvdW5kQmFyLFxuICBtaW5CYXJXaWR0aCxcbn0gZnJvbSAnLi9CYXIvZWxlbWVudHMnO1xuaW1wb3J0IHsgdXNlQmFyQ2hhcnRDb250ZXh0IH0gZnJvbSAnLi9CYXJDaGFydFByb3ZpZGVyJztcbmltcG9ydCB7IEJhclByb3BzIH0gZnJvbSAnLi90eXBlcyc7XG5pbXBvcnQgeyBjYWxjdWxhdGVCYXJXaWR0aCwgZ2V0VmFsdWVzU3VtbWFyeSB9IGZyb20gJy4vdXRpbHMnO1xuXG5jb25zdCByb3dCYXNlU3R5bGVzID0gY3NzKHtcbiAgZGlzcGxheTogJ2ZsZXgnLFxuICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgd2lkdGg6ICcxMDAlJyxcbiAgZ2FwOiAxNixcbiAgcHk6IDgsXG4gIHB4OiAxNixcbiAgYmc6ICd0cmFuc3BhcmVudCcsXG4gIGJvcmRlcjogJ25vbmUnLFxuICB0ZXh0RGVjb3JhdGlvbjogJ25vbmUnLFxuICBjdXJzb3I6ICdpbmhlcml0JyxcbiAgJyY6Zm9jdXMnOiB7XG4gICAgb3V0bGluZTogJ25vbmUnLFxuICB9LFxuICAnJjpmb2N1cy12aXNpYmxlJzoge1xuICAgIG91dGxpbmU6ICcycHggc29saWQnLFxuICAgIG91dGxpbmVDb2xvcjogJ3ByaW1hcnknLFxuICAgIG91dGxpbmVPZmZzZXQ6ICcycHgnLFxuICB9LFxufSk7XG5cbmNvbnN0IGludGVyYWN0aXZlU3R5bGVzID0gY3NzKHtcbiAgY3Vyc29yOiAncG9pbnRlcicsXG4gICcmOmhvdmVyJzoge1xuICAgIGJnOiAnYmFja2dyb3VuZC1ob3ZlcicsXG4gIH0sXG59KTtcblxuY29uc3QgUm93V3JhcHBlciA9IHN0eWxlZCgnZGl2Jywgc3R5bGVkT3B0aW9uczwnZGl2Jz4oKSkocm93QmFzZVN0eWxlcyk7XG5jb25zdCBSb3dCdXR0b24gPSBzdHlsZWQoJ2J1dHRvbicsIHN0eWxlZE9wdGlvbnM8J2J1dHRvbic+KCkpKFxuICByb3dCYXNlU3R5bGVzLFxuICBpbnRlcmFjdGl2ZVN0eWxlc1xuKTtcbmNvbnN0IFJvd0FuY2hvciA9IHN0eWxlZCgnYScsIHN0eWxlZE9wdGlvbnM8J2EnPigpKShcbiAgcm93QmFzZVN0eWxlcyxcbiAgaW50ZXJhY3RpdmVTdHlsZXNcbik7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQmFyUm93UHJvcHMgZXh0ZW5kcyBCYXJQcm9wcyB7XG4gIGluZGV4PzogbnVtYmVyO1xufVxuXG5leHBvcnQgY29uc3QgQmFyUm93ID0gZm9yd2FyZFJlZjxcbiAgSFRNTERpdkVsZW1lbnQgfCBIVE1MQnV0dG9uRWxlbWVudCB8IEhUTUxBbmNob3JFbGVtZW50LFxuICBCYXJSb3dQcm9wc1xuPihcbiAgKFxuICAgIHtcbiAgICAgIHlMYWJlbCxcbiAgICAgIHNlcmllc09uZVZhbHVlLFxuICAgICAgc2VyaWVzVHdvVmFsdWUsXG4gICAgICBpY29uOiBJY29uLFxuICAgICAgb25DbGljayxcbiAgICAgIGhyZWYsXG4gICAgICBpbmRleCA9IDAsXG4gICAgfSxcbiAgICByZWZcbiAgKSA9PiB7XG4gICAgY29uc3QgeyBtaW5SYW5nZSwgbWF4UmFuZ2UsIHVuaXQsIHN0eWxlQ29uZmlnLCBhbmltYXRlIH0gPVxuICAgICAgdXNlQmFyQ2hhcnRDb250ZXh0KCk7XG5cbiAgICBjb25zdCBpc1N0YWNrZWQgPSBzZXJpZXNUd29WYWx1ZSAhPT0gdW5kZWZpbmVkO1xuICAgIGNvbnN0IGRpc3BsYXlWYWx1ZSA9IGlzU3RhY2tlZCA/IHNlcmllc1R3b1ZhbHVlIDogc2VyaWVzT25lVmFsdWU7XG5cbiAgICBjb25zdCBiYWNrZ3JvdW5kQmFyV2lkdGggPSBjYWxjdWxhdGVCYXJXaWR0aCh7XG4gICAgICB2YWx1ZTogZGlzcGxheVZhbHVlLFxuICAgICAgbWluUmFuZ2UsXG4gICAgICBtYXhSYW5nZSxcbiAgICB9KTtcblxuICAgIGNvbnN0IGZvcmVncm91bmRCYXJXaWR0aCA9IGlzU3RhY2tlZFxuICAgICAgPyBjYWxjdWxhdGVCYXJXaWR0aCh7XG4gICAgICAgICAgdmFsdWU6IHNlcmllc09uZVZhbHVlLFxuICAgICAgICAgIG1pblJhbmdlLFxuICAgICAgICAgIG1heFJhbmdlLFxuICAgICAgICB9KVxuICAgICAgOiAwO1xuXG4gICAgY29uc3QgYmdXaWR0aFN0ciA9IGAke01hdGgubWF4KG1pbkJhcldpZHRoLCBiYWNrZ3JvdW5kQmFyV2lkdGgpfSVgO1xuICAgIGNvbnN0IGZnV2lkdGhTdHIgPSBgJHtNYXRoLm1heChtaW5CYXJXaWR0aCwgZm9yZWdyb3VuZEJhcldpZHRoKX0lYDtcblxuICAgIGNvbnN0IHZhbHVlc1N1bW1hcnkgPSBnZXRWYWx1ZXNTdW1tYXJ5KHtcbiAgICAgIHlMYWJlbCxcbiAgICAgIHNlcmllc09uZVZhbHVlLFxuICAgICAgc2VyaWVzVHdvVmFsdWUsXG4gICAgICB1bml0LFxuICAgIH0pO1xuXG4gICAgY29uc3QgYW5pbWF0aW9uRGVsYXkgPSBhbmltYXRlID8gaW5kZXggKiAwLjEgOiAwO1xuXG4gICAgY29uc3Qgcm93Q29udGVudCA9IChcbiAgICAgIDw+XG4gICAgICAgIDxGbGV4Qm94XG4gICAgICAgICAgYWxpZ25JdGVtcz1cImNlbnRlclwiXG4gICAgICAgICAgY29sb3I9e3N0eWxlQ29uZmlnLnRleHRDb2xvcn1cbiAgICAgICAgICBmbGV4U2hyaW5rPXswfVxuICAgICAgICAgIGdhcD17OH1cbiAgICAgICAgICBtaW5XaWR0aD1cIjIwMHB4XCJcbiAgICAgICAgPlxuICAgICAgICAgIHtJY29uICYmIDxJY29uIHNpemU9ezE2fSAvPn1cbiAgICAgICAgICA8VGV4dCBmb250V2VpZ2h0PVwiYm9sZFwiIHRydW5jYXRlPVwiZWxsaXBzaXNcIiB0cnVuY2F0ZUxpbmVzPXsxfT5cbiAgICAgICAgICAgIHt5TGFiZWx9XG4gICAgICAgICAgPC9UZXh0PlxuICAgICAgICA8L0ZsZXhCb3g+XG5cbiAgICAgICAgPEJhcldyYXBwZXI+XG4gICAgICAgICAgPEJhY2tncm91bmRCYXJcbiAgICAgICAgICAgIGFuaW1hdGU9e2FuaW1hdGUgPyB7IHdpZHRoOiBiZ1dpZHRoU3RyIH0gOiB1bmRlZmluZWR9XG4gICAgICAgICAgICBiZz17c3R5bGVDb25maWcuYmFja2dyb3VuZEJhckNvbG9yfVxuICAgICAgICAgICAgZGF0YS10ZXN0aWQ9XCJiYWNrZ3JvdW5kLWJhclwiXG4gICAgICAgICAgICBpbml0aWFsPXthbmltYXRlID8geyB3aWR0aDogJzAlJyB9IDogdW5kZWZpbmVkfVxuICAgICAgICAgICAgdHJhbnNpdGlvbj17eyBkdXJhdGlvbjogMC41LCBkZWxheTogYW5pbWF0aW9uRGVsYXkgfX1cbiAgICAgICAgICAgIHdpZHRoPXshYW5pbWF0ZSA/IGJnV2lkdGhTdHIgOiB1bmRlZmluZWR9XG4gICAgICAgICAgLz5cbiAgICAgICAgICB7aXNTdGFja2VkICYmIChcbiAgICAgICAgICAgIDxGb3JlZ3JvdW5kQmFyXG4gICAgICAgICAgICAgIGFuaW1hdGU9e2FuaW1hdGUgPyB7IHdpZHRoOiBmZ1dpZHRoU3RyIH0gOiB1bmRlZmluZWR9XG4gICAgICAgICAgICAgIGJnPXtzdHlsZUNvbmZpZy5mb3JlZ3JvdW5kQmFyQ29sb3J9XG4gICAgICAgICAgICAgIGRhdGEtdGVzdGlkPVwiZm9yZWdyb3VuZC1iYXJcIlxuICAgICAgICAgICAgICBpbml0aWFsPXthbmltYXRlID8geyB3aWR0aDogJzAlJyB9IDogdW5kZWZpbmVkfVxuICAgICAgICAgICAgICB0cmFuc2l0aW9uPXt7IGR1cmF0aW9uOiAwLjUsIGRlbGF5OiBhbmltYXRpb25EZWxheSArIDAuMjUgfX1cbiAgICAgICAgICAgICAgd2lkdGg9eyFhbmltYXRlID8gZmdXaWR0aFN0ciA6IHVuZGVmaW5lZH1cbiAgICAgICAgICAgIC8+XG4gICAgICAgICAgKX1cbiAgICAgICAgPC9CYXJXcmFwcGVyPlxuXG4gICAgICAgIDxGbGV4Qm94XG4gICAgICAgICAgYWxpZ25JdGVtcz1cImNlbnRlclwiXG4gICAgICAgICAgZmxleFNocmluaz17MH1cbiAgICAgICAgICBqdXN0aWZ5Q29udGVudD1cImZsZXgtZW5kXCJcbiAgICAgICAgICBtaW5XaWR0aD17eyBfOiA0MCwgc206IDYwIH19XG4gICAgICAgID5cbiAgICAgICAgICA8VGV4dCBjb2xvcj17c3R5bGVDb25maWcudGV4dENvbG9yfSB2YXJpYW50PVwicC1zbWFsbFwiPlxuICAgICAgICAgICAge2Rpc3BsYXlWYWx1ZS50b0xvY2FsZVN0cmluZygpfVxuICAgICAgICAgICAge3VuaXQgJiYgYCAke3VuaXR9YH1cbiAgICAgICAgICA8L1RleHQ+XG4gICAgICAgIDwvRmxleEJveD5cbiAgICAgIDwvPlxuICAgICk7XG5cbiAgICBpZiAoaHJlZikge1xuICAgICAgcmV0dXJuIChcbiAgICAgICAgPGxpPlxuICAgICAgICAgIDxSb3dBbmNob3JcbiAgICAgICAgICAgIGFyaWEtbGFiZWw9e3ZhbHVlc1N1bW1hcnl9XG4gICAgICAgICAgICBocmVmPXtocmVmfVxuICAgICAgICAgICAgcmVmPXtyZWYgYXMgTXV0YWJsZVJlZk9iamVjdDxIVE1MQW5jaG9yRWxlbWVudD59XG4gICAgICAgICAgPlxuICAgICAgICAgICAge3Jvd0NvbnRlbnR9XG4gICAgICAgICAgPC9Sb3dBbmNob3I+XG4gICAgICAgIDwvbGk+XG4gICAgICApO1xuICAgIH1cblxuICAgIGlmIChvbkNsaWNrKSB7XG4gICAgICByZXR1cm4gKFxuICAgICAgICA8bGk+XG4gICAgICAgICAgPFJvd0J1dHRvblxuICAgICAgICAgICAgYXJpYS1sYWJlbD17dmFsdWVzU3VtbWFyeX1cbiAgICAgICAgICAgIHJlZj17cmVmIGFzIE11dGFibGVSZWZPYmplY3Q8SFRNTEJ1dHRvbkVsZW1lbnQ+fVxuICAgICAgICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICAgICAgICBvbkNsaWNrPXtvbkNsaWNrfVxuICAgICAgICAgICAgb25LZXlEb3duPXsoZSkgPT4ge1xuICAgICAgICAgICAgICBpZiAoZS5rZXkgPT09ICdFbnRlcicpIHtcbiAgICAgICAgICAgICAgICBvbkNsaWNrKGUgYXMgdW5rbm93biBhcyBNb3VzZUV2ZW50PEhUTUxCdXR0b25FbGVtZW50Pik7XG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH19XG4gICAgICAgICAgPlxuICAgICAgICAgICAge3Jvd0NvbnRlbnR9XG4gICAgICAgICAgPC9Sb3dCdXR0b24+XG4gICAgICAgIDwvbGk+XG4gICAgICApO1xuICAgIH1cblxuICAgIHJldHVybiAoXG4gICAgICA8bGk+XG4gICAgICAgIDxSb3dXcmFwcGVyXG4gICAgICAgICAgYXJpYS1sYWJlbD17dmFsdWVzU3VtbWFyeX1cbiAgICAgICAgICByZWY9e3JlZiBhcyBNdXRhYmxlUmVmT2JqZWN0PEhUTUxEaXZFbGVtZW50Pn1cbiAgICAgICAgPlxuICAgICAgICAgIHtyb3dDb250ZW50fVxuICAgICAgICA8L1Jvd1dyYXBwZXI+XG4gICAgICA8L2xpPlxuICAgICk7XG4gIH1cbik7XG4iXX0= */");
49
+ export const BarRow = /*#__PURE__*/forwardRef(({
50
+ yLabel,
51
+ seriesOneValue,
52
+ seriesTwoValue,
53
+ icon: Icon,
54
+ onClick,
55
+ href,
56
+ index = 0
57
+ }, ref) => {
58
+ const {
59
+ minRange,
60
+ maxRange,
61
+ unit,
62
+ styleConfig,
63
+ animate
64
+ } = useBarChartContext();
65
+ const isStacked = seriesTwoValue !== undefined;
66
+ const displayValue = isStacked ? seriesTwoValue : seriesOneValue;
67
+ const backgroundBarWidth = calculateBarWidth({
68
+ value: displayValue,
69
+ minRange,
70
+ maxRange
71
+ });
72
+ const foregroundBarWidth = isStacked ? calculateBarWidth({
73
+ value: seriesOneValue,
74
+ minRange,
75
+ maxRange
76
+ }) : 0;
77
+ const bgWidthStr = `${Math.max(minBarWidth, backgroundBarWidth)}%`;
78
+ const fgWidthStr = `${Math.max(minBarWidth, foregroundBarWidth)}%`;
79
+ const valuesSummary = getValuesSummary({
80
+ yLabel,
81
+ seriesOneValue,
82
+ seriesTwoValue,
83
+ unit
84
+ });
85
+ const animationDelay = animate ? index * 0.1 : 0;
86
+ const rowContent = /*#__PURE__*/_jsxs(_Fragment, {
87
+ children: [/*#__PURE__*/_jsxs(FlexBox, {
88
+ alignItems: "center",
89
+ color: styleConfig.textColor,
90
+ flexShrink: 0,
91
+ gap: 8,
92
+ minWidth: "200px",
93
+ children: [Icon && /*#__PURE__*/_jsx(Icon, {
94
+ size: 16
95
+ }), /*#__PURE__*/_jsx(Text, {
96
+ fontWeight: "bold",
97
+ truncate: "ellipsis",
98
+ truncateLines: 1,
99
+ children: yLabel
100
+ })]
101
+ }), /*#__PURE__*/_jsxs(BarWrapper, {
102
+ children: [/*#__PURE__*/_jsx(BackgroundBar, {
103
+ animate: animate ? {
104
+ width: bgWidthStr
105
+ } : undefined,
106
+ bg: styleConfig.backgroundBarColor,
107
+ "data-testid": "background-bar",
108
+ initial: animate ? {
109
+ width: '0%'
110
+ } : undefined,
111
+ transition: {
112
+ duration: 0.5,
113
+ delay: animationDelay
114
+ },
115
+ width: !animate ? bgWidthStr : undefined
116
+ }), isStacked && /*#__PURE__*/_jsx(ForegroundBar, {
117
+ animate: animate ? {
118
+ width: fgWidthStr
119
+ } : undefined,
120
+ bg: styleConfig.foregroundBarColor,
121
+ "data-testid": "foreground-bar",
122
+ initial: animate ? {
123
+ width: '0%'
124
+ } : undefined,
125
+ transition: {
126
+ duration: 0.5,
127
+ delay: animationDelay + 0.25
128
+ },
129
+ width: !animate ? fgWidthStr : undefined
130
+ })]
131
+ }), /*#__PURE__*/_jsx(FlexBox, {
132
+ alignItems: "center",
133
+ flexShrink: 0,
134
+ justifyContent: "flex-end",
135
+ minWidth: {
136
+ _: 40,
137
+ sm: 60
138
+ },
139
+ children: /*#__PURE__*/_jsxs(Text, {
140
+ color: styleConfig.textColor,
141
+ variant: "p-small",
142
+ children: [displayValue.toLocaleString(), unit && ` ${unit}`]
143
+ })
144
+ })]
145
+ });
146
+ if (href) {
147
+ return /*#__PURE__*/_jsx("li", {
148
+ children: /*#__PURE__*/_jsx(RowAnchor, {
149
+ "aria-label": valuesSummary,
150
+ href: href,
151
+ ref: ref,
152
+ children: rowContent
153
+ })
154
+ });
155
+ }
156
+ if (onClick) {
157
+ return /*#__PURE__*/_jsx("li", {
158
+ children: /*#__PURE__*/_jsx(RowButton, {
159
+ "aria-label": valuesSummary,
160
+ ref: ref,
161
+ type: "button",
162
+ onClick: onClick,
163
+ onKeyDown: e => {
164
+ if (e.key === 'Enter') {
165
+ onClick(e);
166
+ }
167
+ },
168
+ children: rowContent
169
+ })
170
+ });
171
+ }
172
+ return /*#__PURE__*/_jsx("li", {
173
+ children: /*#__PURE__*/_jsx(RowWrapper, {
174
+ "aria-label": valuesSummary,
175
+ ref: ref,
176
+ children: rowContent
177
+ })
178
+ });
179
+ });
@@ -0,0 +1,5 @@
1
+ /// <reference types="react" />
2
+ export interface GridLinesProps {
3
+ tickCount: number;
4
+ }
5
+ export declare const GridLines: React.FC<GridLinesProps>;
@@ -0,0 +1,57 @@
1
+ import _styled from "@emotion/styled/base";
2
+ import { css } from '@codecademy/gamut-styles';
3
+ import { Box } from '../Box';
4
+ import { jsx as _jsx } from "react/jsx-runtime";
5
+ const GridLineContainer = /*#__PURE__*/_styled(Box, {
6
+ target: "e1y7txrp2",
7
+ label: "GridLineContainer"
8
+ })(css({
9
+ bottom: 0,
10
+ display: {
11
+ _: 'none',
12
+ sm: 'flex'
13
+ },
14
+ left: '200px',
15
+ pointerEvents: 'none',
16
+ position: 'absolute',
17
+ right: '60px',
18
+ top: 0,
19
+ borderLeft: 1,
20
+ borderRight: 1,
21
+ borderColor: 'background-disabled',
22
+ zIndex: 0
23
+ }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9CYXJDaGFydC9HcmlkTGluZXMudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUswQiIsImZpbGUiOiIuLi8uLi9zcmMvQmFyQ2hhcnQvR3JpZExpbmVzLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0Bjb2RlY2FkZW15L2dhbXV0LXN0eWxlcyc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5cbmltcG9ydCB7IEJveCB9IGZyb20gJy4uL0JveCc7XG5cbmNvbnN0IEdyaWRMaW5lQ29udGFpbmVyID0gc3R5bGVkKEJveCkoXG4gIGNzcyh7XG4gICAgYm90dG9tOiAwLFxuICAgIGRpc3BsYXk6IHsgXzogJ25vbmUnLCBzbTogJ2ZsZXgnIH0sXG4gICAgbGVmdDogJzIwMHB4JyxcbiAgICBwb2ludGVyRXZlbnRzOiAnbm9uZScsXG4gICAgcG9zaXRpb246ICdhYnNvbHV0ZScsXG4gICAgcmlnaHQ6ICc2MHB4JyxcbiAgICB0b3A6IDAsXG4gICAgYm9yZGVyTGVmdDogMSxcbiAgICBib3JkZXJSaWdodDogMSxcbiAgICBib3JkZXJDb2xvcjogJ2JhY2tncm91bmQtZGlzYWJsZWQnLFxuICAgIHpJbmRleDogMCxcbiAgfSlcbik7XG5cbmNvbnN0IEdyaWRMaW5lV3JhcHBlciA9IHN0eWxlZChCb3gpKFxuICBjc3Moe1xuICAgIGZsZXg6IDEsXG4gICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgIGhlaWdodDogJzEwMCUnLFxuICB9KVxuKTtcblxuY29uc3QgR3JpZExpbmUgPSBzdHlsZWQoQm94KShcbiAgY3NzKHtcbiAgICBib3JkZXJMZWZ0OiAxLFxuICAgIGJvcmRlckNvbG9yTGVmdDogJ2JhY2tncm91bmQtZGlzYWJsZWQnLFxuICAgIGhlaWdodDogJzEwMCUnLFxuICAgIHdpZHRoOiAwLFxuICB9KVxuKTtcblxuZXhwb3J0IGludGVyZmFjZSBHcmlkTGluZXNQcm9wcyB7XG4gIHRpY2tDb3VudDogbnVtYmVyO1xufVxuXG5leHBvcnQgY29uc3QgR3JpZExpbmVzOiBSZWFjdC5GQzxHcmlkTGluZXNQcm9wcz4gPSAoeyB0aWNrQ291bnQgfSkgPT4ge1xuICBjb25zdCBsaW5lcyA9IEFycmF5LmZyb20oeyBsZW5ndGg6IHRpY2tDb3VudCAtIDIgfSwgKF8sIGkpID0+IHtcbiAgICByZXR1cm4gKFxuICAgICAgPEdyaWRMaW5lV3JhcHBlciBhcmlhLWhpZGRlbiBqdXN0aWZ5Q29udGVudD1cImNlbnRlclwiIGtleT17aX0+XG4gICAgICAgIDxHcmlkTGluZSAvPlxuICAgICAgPC9HcmlkTGluZVdyYXBwZXI+XG4gICAgKTtcbiAgfSk7XG5cbiAgcmV0dXJuIDxHcmlkTGluZUNvbnRhaW5lciBhcmlhLWhpZGRlbj57bGluZXN9PC9HcmlkTGluZUNvbnRhaW5lcj47XG59O1xuIl19 */");
24
+ const GridLineWrapper = /*#__PURE__*/_styled(Box, {
25
+ target: "e1y7txrp1",
26
+ label: "GridLineWrapper"
27
+ })(css({
28
+ flex: 1,
29
+ display: 'flex',
30
+ height: '100%'
31
+ }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9CYXJDaGFydC9HcmlkTGluZXMudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFCd0IiLCJmaWxlIjoiLi4vLi4vc3JjL0JhckNoYXJ0L0dyaWRMaW5lcy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjc3MgfSBmcm9tICdAY29kZWNhZGVteS9nYW11dC1zdHlsZXMnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG5pbXBvcnQgeyBCb3ggfSBmcm9tICcuLi9Cb3gnO1xuXG5jb25zdCBHcmlkTGluZUNvbnRhaW5lciA9IHN0eWxlZChCb3gpKFxuICBjc3Moe1xuICAgIGJvdHRvbTogMCxcbiAgICBkaXNwbGF5OiB7IF86ICdub25lJywgc206ICdmbGV4JyB9LFxuICAgIGxlZnQ6ICcyMDBweCcsXG4gICAgcG9pbnRlckV2ZW50czogJ25vbmUnLFxuICAgIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICAgIHJpZ2h0OiAnNjBweCcsXG4gICAgdG9wOiAwLFxuICAgIGJvcmRlckxlZnQ6IDEsXG4gICAgYm9yZGVyUmlnaHQ6IDEsXG4gICAgYm9yZGVyQ29sb3I6ICdiYWNrZ3JvdW5kLWRpc2FibGVkJyxcbiAgICB6SW5kZXg6IDAsXG4gIH0pXG4pO1xuXG5jb25zdCBHcmlkTGluZVdyYXBwZXIgPSBzdHlsZWQoQm94KShcbiAgY3NzKHtcbiAgICBmbGV4OiAxLFxuICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICBoZWlnaHQ6ICcxMDAlJyxcbiAgfSlcbik7XG5cbmNvbnN0IEdyaWRMaW5lID0gc3R5bGVkKEJveCkoXG4gIGNzcyh7XG4gICAgYm9yZGVyTGVmdDogMSxcbiAgICBib3JkZXJDb2xvckxlZnQ6ICdiYWNrZ3JvdW5kLWRpc2FibGVkJyxcbiAgICBoZWlnaHQ6ICcxMDAlJyxcbiAgICB3aWR0aDogMCxcbiAgfSlcbik7XG5cbmV4cG9ydCBpbnRlcmZhY2UgR3JpZExpbmVzUHJvcHMge1xuICB0aWNrQ291bnQ6IG51bWJlcjtcbn1cblxuZXhwb3J0IGNvbnN0IEdyaWRMaW5lczogUmVhY3QuRkM8R3JpZExpbmVzUHJvcHM+ID0gKHsgdGlja0NvdW50IH0pID0+IHtcbiAgY29uc3QgbGluZXMgPSBBcnJheS5mcm9tKHsgbGVuZ3RoOiB0aWNrQ291bnQgLSAyIH0sIChfLCBpKSA9PiB7XG4gICAgcmV0dXJuIChcbiAgICAgIDxHcmlkTGluZVdyYXBwZXIgYXJpYS1oaWRkZW4ganVzdGlmeUNvbnRlbnQ9XCJjZW50ZXJcIiBrZXk9e2l9PlxuICAgICAgICA8R3JpZExpbmUgLz5cbiAgICAgIDwvR3JpZExpbmVXcmFwcGVyPlxuICAgICk7XG4gIH0pO1xuXG4gIHJldHVybiA8R3JpZExpbmVDb250YWluZXIgYXJpYS1oaWRkZW4+e2xpbmVzfTwvR3JpZExpbmVDb250YWluZXI+O1xufTtcbiJdfQ== */");
32
+ const GridLine = /*#__PURE__*/_styled(Box, {
33
+ target: "e1y7txrp0",
34
+ label: "GridLine"
35
+ })(css({
36
+ borderLeft: 1,
37
+ borderColorLeft: 'background-disabled',
38
+ height: '100%',
39
+ width: 0
40
+ }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9CYXJDaGFydC9HcmlkTGluZXMudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTZCaUIiLCJmaWxlIjoiLi4vLi4vc3JjL0JhckNoYXJ0L0dyaWRMaW5lcy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjc3MgfSBmcm9tICdAY29kZWNhZGVteS9nYW11dC1zdHlsZXMnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuXG5pbXBvcnQgeyBCb3ggfSBmcm9tICcuLi9Cb3gnO1xuXG5jb25zdCBHcmlkTGluZUNvbnRhaW5lciA9IHN0eWxlZChCb3gpKFxuICBjc3Moe1xuICAgIGJvdHRvbTogMCxcbiAgICBkaXNwbGF5OiB7IF86ICdub25lJywgc206ICdmbGV4JyB9LFxuICAgIGxlZnQ6ICcyMDBweCcsXG4gICAgcG9pbnRlckV2ZW50czogJ25vbmUnLFxuICAgIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICAgIHJpZ2h0OiAnNjBweCcsXG4gICAgdG9wOiAwLFxuICAgIGJvcmRlckxlZnQ6IDEsXG4gICAgYm9yZGVyUmlnaHQ6IDEsXG4gICAgYm9yZGVyQ29sb3I6ICdiYWNrZ3JvdW5kLWRpc2FibGVkJyxcbiAgICB6SW5kZXg6IDAsXG4gIH0pXG4pO1xuXG5jb25zdCBHcmlkTGluZVdyYXBwZXIgPSBzdHlsZWQoQm94KShcbiAgY3NzKHtcbiAgICBmbGV4OiAxLFxuICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICBoZWlnaHQ6ICcxMDAlJyxcbiAgfSlcbik7XG5cbmNvbnN0IEdyaWRMaW5lID0gc3R5bGVkKEJveCkoXG4gIGNzcyh7XG4gICAgYm9yZGVyTGVmdDogMSxcbiAgICBib3JkZXJDb2xvckxlZnQ6ICdiYWNrZ3JvdW5kLWRpc2FibGVkJyxcbiAgICBoZWlnaHQ6ICcxMDAlJyxcbiAgICB3aWR0aDogMCxcbiAgfSlcbik7XG5cbmV4cG9ydCBpbnRlcmZhY2UgR3JpZExpbmVzUHJvcHMge1xuICB0aWNrQ291bnQ6IG51bWJlcjtcbn1cblxuZXhwb3J0IGNvbnN0IEdyaWRMaW5lczogUmVhY3QuRkM8R3JpZExpbmVzUHJvcHM+ID0gKHsgdGlja0NvdW50IH0pID0+IHtcbiAgY29uc3QgbGluZXMgPSBBcnJheS5mcm9tKHsgbGVuZ3RoOiB0aWNrQ291bnQgLSAyIH0sIChfLCBpKSA9PiB7XG4gICAgcmV0dXJuIChcbiAgICAgIDxHcmlkTGluZVdyYXBwZXIgYXJpYS1oaWRkZW4ganVzdGlmeUNvbnRlbnQ9XCJjZW50ZXJcIiBrZXk9e2l9PlxuICAgICAgICA8R3JpZExpbmUgLz5cbiAgICAgIDwvR3JpZExpbmVXcmFwcGVyPlxuICAgICk7XG4gIH0pO1xuXG4gIHJldHVybiA8R3JpZExpbmVDb250YWluZXIgYXJpYS1oaWRkZW4+e2xpbmVzfTwvR3JpZExpbmVDb250YWluZXI+O1xufTtcbiJdfQ== */");
41
+ export const GridLines = ({
42
+ tickCount
43
+ }) => {
44
+ const lines = Array.from({
45
+ length: tickCount - 2
46
+ }, (_, i) => {
47
+ return /*#__PURE__*/_jsx(GridLineWrapper, {
48
+ "aria-hidden": true,
49
+ justifyContent: "center",
50
+ children: /*#__PURE__*/_jsx(GridLine, {})
51
+ }, i);
52
+ });
53
+ return /*#__PURE__*/_jsx(GridLineContainer, {
54
+ "aria-hidden": true,
55
+ children: lines
56
+ });
57
+ };
@@ -0,0 +1,10 @@
1
+ /// <reference types="react" />
2
+ export interface ScaleChartHeaderProps {
3
+ /** Minimum value on the scale */
4
+ min: number;
5
+ /** Maximum value on the scale */
6
+ max: number;
7
+ /** Number of labels to display */
8
+ labelCount: number;
9
+ }
10
+ export declare const ScaleChartHeader: React.FC<ScaleChartHeaderProps>;
@@ -0,0 +1,65 @@
1
+ import _styled from "@emotion/styled/base";
2
+ import { css } from '@codecademy/gamut-styles';
3
+ import { Box, FlexBox } from '../Box';
4
+ import { Text } from '../Typography';
5
+ import { useBarChartContext } from './BarChartProvider';
6
+ import { formatNumberUSCompact, getLabel } from './utils';
7
+ import { jsx as _jsx } from "react/jsx-runtime";
8
+ const StyledLabelText = /*#__PURE__*/_styled(Text, {
9
+ target: "egjxop1",
10
+ label: "StyledLabelText"
11
+ })(css({
12
+ flex: 1
13
+ }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9CYXJDaGFydC9TY2FsZUNoYXJ0SGVhZGVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFpQndCIiwiZmlsZSI6Ii4uLy4uL3NyYy9CYXJDaGFydC9TY2FsZUNoYXJ0SGVhZGVyLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0Bjb2RlY2FkZW15L2dhbXV0LXN0eWxlcyc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5cbmltcG9ydCB7IEJveCwgRmxleEJveCB9IGZyb20gJy4uL0JveCc7XG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vVHlwb2dyYXBoeSc7XG5pbXBvcnQgeyB1c2VCYXJDaGFydENvbnRleHQgfSBmcm9tICcuL0JhckNoYXJ0UHJvdmlkZXInO1xuaW1wb3J0IHsgZm9ybWF0TnVtYmVyVVNDb21wYWN0LCBnZXRMYWJlbCB9IGZyb20gJy4vdXRpbHMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFNjYWxlQ2hhcnRIZWFkZXJQcm9wcyB7XG4gIC8qKiBNaW5pbXVtIHZhbHVlIG9uIHRoZSBzY2FsZSAqL1xuICBtaW46IG51bWJlcjtcbiAgLyoqIE1heGltdW0gdmFsdWUgb24gdGhlIHNjYWxlICovXG4gIG1heDogbnVtYmVyO1xuICAvKiogTnVtYmVyIG9mIGxhYmVscyB0byBkaXNwbGF5ICovXG4gIGxhYmVsQ291bnQ6IG51bWJlcjtcbn1cblxuY29uc3QgU3R5bGVkTGFiZWxUZXh0ID0gc3R5bGVkKFRleHQpKFxuICBjc3Moe1xuICAgIGZsZXg6IDEsXG4gIH0pXG4pO1xuXG5jb25zdCBTdHlsZWRIZWFkZXJDb250YWluZXIgPSBzdHlsZWQoRmxleEJveCkoXG4gIGNzcyh7XG4gICAgbWFyZ2luTGVmdDogJzIwMHB4JyxcbiAgICBwYWRkaW5nUmlnaHQ6ICc2MHB4JyxcbiAgICB3aWR0aDogJ2NhbGMoMTAwJSAtIDIwMHB4IC0gNjBweCknLFxuICB9KVxuKTtcblxuZXhwb3J0IGNvbnN0IFNjYWxlQ2hhcnRIZWFkZXI6IFJlYWN0LkZDPFNjYWxlQ2hhcnRIZWFkZXJQcm9wcz4gPSAoe1xuICBsYWJlbENvdW50LFxuICBtaW4sXG4gIG1heCxcbn0pID0+IHtcbiAgY29uc3QgeyBzdHlsZUNvbmZpZyB9ID0gdXNlQmFyQ2hhcnRDb250ZXh0KCk7XG5cbiAgY29uc3Qgc2NhbGVMYWJlbHMgPSBBcnJheS5mcm9tKHsgbGVuZ3RoOiBsYWJlbENvdW50IH0sIChfLCBpKSA9PiB7XG4gICAgY29uc3QgaXNGaXJzdCA9IGkgPT09IDA7XG4gICAgY29uc3QgaXNMYXN0ID0gaSA9PT0gbGFiZWxDb3VudCAtIDE7XG4gICAgY29uc3QgdGV4dEFsaWduID0gaXNGaXJzdCA/ICdsZWZ0JyA6IGlzTGFzdCA/ICdyaWdodCcgOiAnY2VudGVyJztcblxuICAgIHJldHVybiAoXG4gICAgICA8U3R5bGVkTGFiZWxUZXh0XG4gICAgICAgIGRhdGEtdGVzdGlkPVwiY2hhcnQtaGVhZGVyLWxhYmVsXCJcbiAgICAgICAga2V5PXtpfVxuICAgICAgICB0ZXh0QWxpZ249e3RleHRBbGlnbn1cbiAgICAgICAgdGV4dENvbG9yPXtzdHlsZUNvbmZpZy50ZXh0Q29sb3J9XG4gICAgICAgIHZhcmlhbnQ9XCJwLXNtYWxsXCJcbiAgICAgID5cbiAgICAgICAge2Zvcm1hdE51bWJlclVTQ29tcGFjdCh7XG4gICAgICAgICAgbnVtOiBnZXRMYWJlbCh7IGxhYmVsQ291bnQsIGxhYmVsSW5kZXg6IGksIG1pbiwgbWF4IH0pLFxuICAgICAgICB9KX1cbiAgICAgIDwvU3R5bGVkTGFiZWxUZXh0PlxuICAgICk7XG4gIH0pO1xuXG4gIHJldHVybiAoXG4gICAgPEJveCBiZz1cInJlZFwiIHdpZHRoPXsxfT5cbiAgICAgIDxTdHlsZWRIZWFkZXJDb250YWluZXJcbiAgICAgICAgYXJpYS1oaWRkZW49XCJ0cnVlXCJcbiAgICAgICAgZGlzcGxheT17eyBfOiAnbm9uZScsIHNtOiAnZmxleCcgfX1cbiAgICAgICAganVzdGlmeUNvbnRlbnQ9XCJzcGFjZS1iZXR3ZWVuXCJcbiAgICAgICAgbWI9ezh9XG4gICAgICA+XG4gICAgICAgIHtzY2FsZUxhYmVsc31cbiAgICAgIDwvU3R5bGVkSGVhZGVyQ29udGFpbmVyPlxuICAgIDwvQm94PlxuICApO1xufTtcbiJdfQ== */");
14
+ const StyledHeaderContainer = /*#__PURE__*/_styled(FlexBox, {
15
+ target: "egjxop0",
16
+ label: "StyledHeaderContainer"
17
+ })(css({
18
+ marginLeft: '200px',
19
+ paddingRight: '60px',
20
+ width: 'calc(100% - 200px - 60px)'
21
+ }), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9CYXJDaGFydC9TY2FsZUNoYXJ0SGVhZGVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF1QjhCIiwiZmlsZSI6Ii4uLy4uL3NyYy9CYXJDaGFydC9TY2FsZUNoYXJ0SGVhZGVyLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNzcyB9IGZyb20gJ0Bjb2RlY2FkZW15L2dhbXV0LXN0eWxlcyc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5cbmltcG9ydCB7IEJveCwgRmxleEJveCB9IGZyb20gJy4uL0JveCc7XG5pbXBvcnQgeyBUZXh0IH0gZnJvbSAnLi4vVHlwb2dyYXBoeSc7XG5pbXBvcnQgeyB1c2VCYXJDaGFydENvbnRleHQgfSBmcm9tICcuL0JhckNoYXJ0UHJvdmlkZXInO1xuaW1wb3J0IHsgZm9ybWF0TnVtYmVyVVNDb21wYWN0LCBnZXRMYWJlbCB9IGZyb20gJy4vdXRpbHMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIFNjYWxlQ2hhcnRIZWFkZXJQcm9wcyB7XG4gIC8qKiBNaW5pbXVtIHZhbHVlIG9uIHRoZSBzY2FsZSAqL1xuICBtaW46IG51bWJlcjtcbiAgLyoqIE1heGltdW0gdmFsdWUgb24gdGhlIHNjYWxlICovXG4gIG1heDogbnVtYmVyO1xuICAvKiogTnVtYmVyIG9mIGxhYmVscyB0byBkaXNwbGF5ICovXG4gIGxhYmVsQ291bnQ6IG51bWJlcjtcbn1cblxuY29uc3QgU3R5bGVkTGFiZWxUZXh0ID0gc3R5bGVkKFRleHQpKFxuICBjc3Moe1xuICAgIGZsZXg6IDEsXG4gIH0pXG4pO1xuXG5jb25zdCBTdHlsZWRIZWFkZXJDb250YWluZXIgPSBzdHlsZWQoRmxleEJveCkoXG4gIGNzcyh7XG4gICAgbWFyZ2luTGVmdDogJzIwMHB4JyxcbiAgICBwYWRkaW5nUmlnaHQ6ICc2MHB4JyxcbiAgICB3aWR0aDogJ2NhbGMoMTAwJSAtIDIwMHB4IC0gNjBweCknLFxuICB9KVxuKTtcblxuZXhwb3J0IGNvbnN0IFNjYWxlQ2hhcnRIZWFkZXI6IFJlYWN0LkZDPFNjYWxlQ2hhcnRIZWFkZXJQcm9wcz4gPSAoe1xuICBsYWJlbENvdW50LFxuICBtaW4sXG4gIG1heCxcbn0pID0+IHtcbiAgY29uc3QgeyBzdHlsZUNvbmZpZyB9ID0gdXNlQmFyQ2hhcnRDb250ZXh0KCk7XG5cbiAgY29uc3Qgc2NhbGVMYWJlbHMgPSBBcnJheS5mcm9tKHsgbGVuZ3RoOiBsYWJlbENvdW50IH0sIChfLCBpKSA9PiB7XG4gICAgY29uc3QgaXNGaXJzdCA9IGkgPT09IDA7XG4gICAgY29uc3QgaXNMYXN0ID0gaSA9PT0gbGFiZWxDb3VudCAtIDE7XG4gICAgY29uc3QgdGV4dEFsaWduID0gaXNGaXJzdCA/ICdsZWZ0JyA6IGlzTGFzdCA/ICdyaWdodCcgOiAnY2VudGVyJztcblxuICAgIHJldHVybiAoXG4gICAgICA8U3R5bGVkTGFiZWxUZXh0XG4gICAgICAgIGRhdGEtdGVzdGlkPVwiY2hhcnQtaGVhZGVyLWxhYmVsXCJcbiAgICAgICAga2V5PXtpfVxuICAgICAgICB0ZXh0QWxpZ249e3RleHRBbGlnbn1cbiAgICAgICAgdGV4dENvbG9yPXtzdHlsZUNvbmZpZy50ZXh0Q29sb3J9XG4gICAgICAgIHZhcmlhbnQ9XCJwLXNtYWxsXCJcbiAgICAgID5cbiAgICAgICAge2Zvcm1hdE51bWJlclVTQ29tcGFjdCh7XG4gICAgICAgICAgbnVtOiBnZXRMYWJlbCh7IGxhYmVsQ291bnQsIGxhYmVsSW5kZXg6IGksIG1pbiwgbWF4IH0pLFxuICAgICAgICB9KX1cbiAgICAgIDwvU3R5bGVkTGFiZWxUZXh0PlxuICAgICk7XG4gIH0pO1xuXG4gIHJldHVybiAoXG4gICAgPEJveCBiZz1cInJlZFwiIHdpZHRoPXsxfT5cbiAgICAgIDxTdHlsZWRIZWFkZXJDb250YWluZXJcbiAgICAgICAgYXJpYS1oaWRkZW49XCJ0cnVlXCJcbiAgICAgICAgZGlzcGxheT17eyBfOiAnbm9uZScsIHNtOiAnZmxleCcgfX1cbiAgICAgICAganVzdGlmeUNvbnRlbnQ9XCJzcGFjZS1iZXR3ZWVuXCJcbiAgICAgICAgbWI9ezh9XG4gICAgICA+XG4gICAgICAgIHtzY2FsZUxhYmVsc31cbiAgICAgIDwvU3R5bGVkSGVhZGVyQ29udGFpbmVyPlxuICAgIDwvQm94PlxuICApO1xufTtcbiJdfQ== */");
22
+ export const ScaleChartHeader = ({
23
+ labelCount,
24
+ min,
25
+ max
26
+ }) => {
27
+ const {
28
+ styleConfig
29
+ } = useBarChartContext();
30
+ const scaleLabels = Array.from({
31
+ length: labelCount
32
+ }, (_, i) => {
33
+ const isFirst = i === 0;
34
+ const isLast = i === labelCount - 1;
35
+ const textAlign = isFirst ? 'left' : isLast ? 'right' : 'center';
36
+ return /*#__PURE__*/_jsx(StyledLabelText, {
37
+ "data-testid": "chart-header-label",
38
+ textAlign: textAlign,
39
+ textColor: styleConfig.textColor,
40
+ variant: "p-small",
41
+ children: formatNumberUSCompact({
42
+ num: getLabel({
43
+ labelCount,
44
+ labelIndex: i,
45
+ min,
46
+ max
47
+ })
48
+ })
49
+ }, i);
50
+ });
51
+ return /*#__PURE__*/_jsx(Box, {
52
+ bg: "red",
53
+ width: 1,
54
+ children: /*#__PURE__*/_jsx(StyledHeaderContainer, {
55
+ "aria-hidden": "true",
56
+ display: {
57
+ _: 'none',
58
+ sm: 'flex'
59
+ },
60
+ justifyContent: "space-between",
61
+ mb: 8,
62
+ children: scaleLabels
63
+ })
64
+ });
65
+ };
@@ -0,0 +1,4 @@
1
+ /// <reference types="react" />
2
+ import { BarChartProps } from './types';
3
+ export declare const BarChart: React.FC<BarChartProps>;
4
+ export * from './types';
@@ -0,0 +1,68 @@
1
+ import { useMemo } from 'react';
2
+ import { Box } from '../Box';
3
+ import { BarChartProvider, useBarChart } from './BarChartProvider';
4
+ import { BarRow } from './BarRow';
5
+ import { GridLines } from './GridLines';
6
+ import { ScaleChartHeader } from './ScaleChartHeader';
7
+ import { sortBars } from './utils';
8
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
9
+ export const BarChart = ({
10
+ 'aria-label': ariaLabel,
11
+ 'aria-labelledby': ariaLabelledBy,
12
+ animate = false,
13
+ barValues,
14
+ maxRange,
15
+ minRange,
16
+ order = 'ascending',
17
+ sortBy = 'none',
18
+ unit = '',
19
+ styleConfig,
20
+ xScale
21
+ }) => {
22
+ const contextValue = useBarChart({
23
+ minRange,
24
+ maxRange,
25
+ xScale,
26
+ unit,
27
+ styleConfig,
28
+ animate
29
+ });
30
+ const sortedBars = useMemo(() => sortBars({
31
+ bars: barValues,
32
+ sortBy,
33
+ order
34
+ }), [barValues, sortBy, order]);
35
+
36
+ // Calculate number of ticks for the scale header
37
+ const tickCount = Math.ceil((maxRange - minRange) / contextValue.xScale) + 1;
38
+ return /*#__PURE__*/_jsx(BarChartProvider, {
39
+ value: contextValue,
40
+ children: /*#__PURE__*/_jsxs(Box, {
41
+ position: "relative",
42
+ width: "100%",
43
+ children: [/*#__PURE__*/_jsx(ScaleChartHeader, {
44
+ labelCount: tickCount,
45
+ max: maxRange,
46
+ min: minRange
47
+ }), /*#__PURE__*/_jsxs(Box, {
48
+ position: "relative",
49
+ width: "100%",
50
+ children: [/*#__PURE__*/_jsx(GridLines, {
51
+ tickCount: tickCount
52
+ }), /*#__PURE__*/_jsx(Box, {
53
+ "aria-label": ariaLabel,
54
+ "aria-labelledby": ariaLabelledBy,
55
+ as: "ul",
56
+ listStyle: "none",
57
+ m: 0,
58
+ p: 0,
59
+ children: sortedBars.map((bar, index) => /*#__PURE__*/_jsx(BarRow, {
60
+ index: index,
61
+ ...bar
62
+ }, `${bar.yLabel}-${index}`))
63
+ })]
64
+ })]
65
+ })
66
+ });
67
+ };
68
+ export * from './types';