@sproutsocial/seeds-react-data-viz 0.6.3 → 0.7.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.
- package/dist/esm/index.js +15 -12
- package/dist/esm/index.js.map +1 -1
- package/dist/index.js +15 -12
- package/dist/index.js.map +1 -1
- package/package.json +9 -9
package/dist/esm/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/components/AreaChart/AreaChart.tsx","../../src/components/AreaChart/components/AreaChartLegend.tsx","../../src/components/ChartLegend/ChartLegend.tsx","../../src/components/ChartLegend/components/ChartLegendLabel.tsx","../../src/components/ColorBox/ColorBox.tsx","../../../seeds-react-theme-provider/src/index.tsx","../../src/components/ColorBox/DatavizColorBox.tsx","../../src/components/ColorBox/NetworkColorBox.tsx","../../src/components/ChartLegend/components/ChartLegendLabelContentWithIcon.tsx","../../src/components/AreaChart/components/AreaChartTooltip.tsx","../../src/components/ChartTooltip/ChartTooltip.tsx","../../src/components/ChartTooltip/components/ChartTooltipFooter.tsx","../../src/components/ChartTooltip/components/ChartTooltipHeader.tsx","../../src/components/ChartTooltip/components/ChartTooltipPortal.tsx","../../src/components/ChartTooltip/components/ChartTooltipTable.tsx","../../src/components/ChartTable/ChartTable.tsx","../../src/components/ChartTooltip/components/ChartTooltipTitle.tsx","../../src/components/ChartXAnnotationMarker/components/ChartXAnnotationMarkerPortal.tsx","../../src/helpers/transformDataToSeries.ts","../../src/helpers/transformTimeSeriesTooltipData.ts","../../src/helpers/yAxisLabelFormatter.ts","../../src/helpers/xAxisLabelFormatter.ts","../../src/helpers/isHourlyTimeData.ts","../../src/helpers/isCategoricalHourData.ts","../../src/helpers/getStorybookRandomColor.ts","../../src/helpers/getStorybookCategoricalData.ts","../../src/helpers/getStorybookSparseTimelineData.ts","../../src/hooks/useTimeSeriesChartOptions.ts","../../src/constants/chartOptions.ts","../../src/styles/chartStyles.ts","../../src/components/ChartXAnnotationDetails/ChartXAnnotationDetails.tsx","../../src/components/ChartXAnnotationMarker/ChartXAnnotationMarker.tsx","../../src/components/DonutChart/DonutChart.tsx","../../src/components/DonutChart/components/DonutChartLegend.tsx","../../src/components/DonutChart/components/DonutChartTooltip.tsx","../../src/components/DonutChart/helpers/transformDonutChartTooltipData.ts","../../src/components/DonutChart/components/DonutChartLegendTable.tsx","../../src/components/LineChart/LineChart.tsx","../../src/components/LineChart/components/LineChartLegend.tsx","../../src/components/LineChart/components/LineChartTooltip.tsx","../../src/components/VerticalBarChart/VerticalBarChart.tsx","../../src/components/VerticalBarChart/components/VerticalBarChartLegend.tsx","../../src/components/VerticalBarChart/components/VerticalBarChartTooltip.tsx","../../src/components/VerticalBarChart/styles.ts"],"sourcesContent":["import { memo, type ReactNode } from \"react\";\nimport Highcharts, { type AnnotationsOptions } from \"highcharts\";\nimport { HighchartsReact } from \"highcharts-react-official\";\nimport highchartsAccessibility from \"highcharts/modules/accessibility\";\nimport highchartsAnnotations from \"highcharts/modules/annotations\";\nimport styled from \"styled-components\";\nimport { Box } from \"@sproutsocial/seeds-react-box\";\n\nimport { AreaChartLegend } from \"./components/AreaChartLegend\";\nimport { AreaChartTooltip } from \"./components/AreaChartTooltip\";\n\nimport { ChartTooltipPortal } from \"../ChartTooltip/components/ChartTooltipPortal\";\nimport { ChartXAnnotationMarkerPortal } from \"../ChartXAnnotationMarker/components/ChartXAnnotationMarkerPortal\";\nimport { transformTimeSeriesTooltipData } from \"../../helpers\";\nimport { useTimeSeriesChartOptions } from \"../../hooks\";\nimport { areaChartStyles, GlobalChartStyleOverrides } from \"../../styles\";\nimport type {\n TypeChartDataPoint,\n TypeChartDataStyles,\n TypeChartNumberFormat,\n TypeChartTimeFormat,\n TypeChartTooltipDateFormatter,\n TypeChartTooltipProps,\n TypeChartYAxisLabelFormatter,\n TypeChartXAnnotations,\n} from \"../../types\";\nimport { theme } from \"@sproutsocial/seeds-react-theme\";\n\n// init modules\nhighchartsAccessibility(Highcharts);\nhighchartsAnnotations(Highcharts);\n\n// styled components\nconst StyledBox = styled(Box)`\n ${areaChartStyles}\n`;\n\n// types\nexport type TypeAreaChartProps = Readonly<{\n data: ReadonlyArray<\n Readonly<{\n name: string;\n points: ReadonlyArray<TypeChartDataPoint>;\n // optional\n icon?: ReactNode;\n styles?: TypeChartDataStyles;\n }>\n >;\n invalidNumberLabel: ReactNode;\n numberLocale: Intl.LocalesArgument;\n textLocale: Intl.LocalesArgument;\n tooltipDateFormatter: TypeChartTooltipDateFormatter;\n tooltipTotalLabel: ReactNode;\n // optional\n currency?: string;\n disableTooltips?: boolean;\n numberFormat?: TypeChartNumberFormat;\n tooltip?: ({\n data,\n total,\n x,\n }: TypeChartTooltipProps & Readonly<{ total: number | null }>) => ReactNode;\n yAxisLabelFormatter?: TypeChartYAxisLabelFormatter;\n onClick?: ({ x }: Readonly<{ x: number }>) => void;\n tooltipClickLabel?: ReactNode;\n timeFormat?: TypeChartTimeFormat;\n xAnnotations?: TypeChartXAnnotations;\n}>;\n\nexport const AreaChart = memo<TypeAreaChartProps>(function AreaChart(\n props: TypeAreaChartProps\n) {\n const { data } = props;\n\n return data.length === 0 ? null : <AreaChartWithData {...props} />;\n});\n\nconst AreaChartWithData = memo<TypeAreaChartProps>(function AreaChartWithData({\n data,\n invalidNumberLabel,\n numberLocale = \"en-us\",\n textLocale = \"en-us\",\n tooltipDateFormatter,\n tooltipTotalLabel,\n // optional\n currency = \"USD\",\n disableTooltips = false,\n numberFormat = \"decimal\",\n tooltip,\n yAxisLabelFormatter,\n onClick,\n tooltipClickLabel,\n timeFormat = \"12\",\n xAnnotations,\n}: TypeAreaChartProps) {\n const { options, chart, callback } = useTimeSeriesChartOptions({\n currency,\n data,\n disableTooltips,\n numberFormat,\n numberLocale,\n seriesType: \"areaspline\",\n textLocale,\n yAxisLabelFormatter,\n onClick,\n timeFormat,\n xAnnotations,\n });\n\n const colors = data.map(\n (series, index) =>\n series.styles?.color ?? theme.colors.DATAVIZ_COLORS_LIST[index]\n );\n\n return (\n <>\n <GlobalChartStyleOverrides />\n <StyledBox\n // @ts-ignore\n $colors={colors}\n $hasOnClick={Boolean(onClick)}\n bg=\"container.background.base\"\n >\n <HighchartsReact\n highcharts={Highcharts}\n options={options}\n callback={callback}\n />\n {chart && chart.annotations?.length ? (\n <ChartXAnnotationMarkerPortal\n xAnnotations={xAnnotations}\n annotationContext={chart.annotations?.[0] as AnnotationsOptions}\n />\n ) : null}\n {chart && !disableTooltips ? (\n <ChartTooltipPortal\n chart={chart}\n renderContent={(context) => {\n const tooltipData = transformTimeSeriesTooltipData({\n context,\n data,\n });\n const x = context.x as number;\n const total = context.total as number;\n\n const xAnnotationDetails = xAnnotations?.[x]?.details;\n\n return tooltip ? (\n tooltip({ data: tooltipData, total, x })\n ) : (\n <AreaChartTooltip\n currency={currency}\n data={tooltipData}\n invalidNumberLabel={invalidNumberLabel}\n numberFormat={numberFormat}\n numberLocale={numberLocale}\n textLocale={textLocale}\n tooltipDateFormatter={tooltipDateFormatter}\n tooltipTotalLabel={tooltipTotalLabel}\n total={total}\n x={x}\n onClick={onClick}\n tooltipClickLabel={tooltipClickLabel}\n xAnnotationDetails={xAnnotationDetails}\n />\n );\n }}\n />\n ) : null}\n <Box mt={350}>\n <AreaChartLegend data={data} />\n </Box>\n </StyledBox>\n </>\n );\n});\n","import { memo } from \"react\";\nimport { theme } from \"@sproutsocial/seeds-react-theme\";\n\nimport type { TypeAreaChartProps } from \"../AreaChart\";\nimport { ChartLegend, type TypeChartLegendProps } from \"../../ChartLegend\";\nimport { ChartLegendLabelContentWithIcon } from \"../../ChartLegend/components/ChartLegendLabelContentWithIcon\";\n\n// exported for testing\nexport const getAreaChartLegendLabels = ({\n data,\n}: Readonly<{\n data: TypeAreaChartProps[\"data\"];\n}>): TypeChartLegendProps[\"legendLabels\"] => {\n return data.map((series, index) => ({\n content: (\n <ChartLegendLabelContentWithIcon icon={series.icon}>\n {series.name}\n </ChartLegendLabelContentWithIcon>\n ),\n color: series.styles?.color || theme.colors.DATAVIZ_COLORS_LIST[index],\n }));\n};\n\ntype TypeAreaChartLegendProps = Readonly<{\n data: TypeAreaChartProps[\"data\"];\n}>;\n\nexport const AreaChartLegend = memo<TypeAreaChartLegendProps>(\n function AreaChartLegend({ data }: TypeAreaChartLegendProps) {\n return <ChartLegend legendLabels={getAreaChartLegendLabels({ data })} />;\n }\n);\n","import { memo } from \"react\";\nimport { Box, type TypeBoxProps } from \"@sproutsocial/seeds-react-box\";\nimport { theme } from \"@sproutsocial/seeds-react-theme\";\n\nimport { ChartLegendLabel } from \"./components/ChartLegendLabel\";\n\nexport type TypeLegendLabel = Readonly<{\n content: React.ReactNode;\n color?: string;\n}>;\n\nexport type TypeChartLegendProps = Readonly<{\n legendLabels: ReadonlyArray<TypeLegendLabel>;\n // optional\n containerBoxProps?: TypeBoxProps;\n stacked?: boolean;\n}>;\n\nexport const ChartLegend = memo<TypeChartLegendProps>(function ChartLegend({\n legendLabels,\n containerBoxProps = {},\n stacked = false,\n}: TypeChartLegendProps) {\n return (\n <Box\n as=\"ul\"\n aria-hidden=\"true\"\n display=\"flex\"\n justifyContent=\"center\"\n flexDirection={stacked ? \"column\" : \"row\"}\n flexWrap=\"wrap\"\n columnGap={450}\n rowGap={200}\n m={0}\n p={0}\n {...containerBoxProps}\n >\n {legendLabels.map(({ color, content }, index) => (\n <ChartLegendLabel\n key={`chart-legend-label-${index}`}\n color={color || theme.colors.DATAVIZ_COLORS_LIST[index]}\n containerBoxProps={{ as: \"li\" }}\n >\n {content}\n </ChartLegendLabel>\n ))}\n </Box>\n );\n});\n","import styled from \"styled-components\";\nimport { memo } from \"react\";\nimport { Box, type TypeBoxProps } from \"@sproutsocial/seeds-react-box\";\nimport { Text } from \"@sproutsocial/seeds-react-text\";\n\nimport type { TypeLegendLabel } from \"../ChartLegend\";\n\nimport { ColorBox } from \"../../ColorBox\";\n\nconst StyledBox = styled(Box)<TypeBoxProps>`\n list-style: none;\n display: flex;\n align-items: center;\n gap: ${({ theme }) => theme.space[300]};\n`;\n\nexport type TypeChartLegendLabelProps = Readonly<{\n children: TypeLegendLabel[\"content\"];\n color: TypeLegendLabel[\"color\"];\n // optional\n containerBoxProps?: TypeBoxProps;\n}>;\n\nexport const ChartLegendLabel = memo<TypeChartLegendLabelProps>(\n function ChartLegendLabel({\n children,\n color = \"#CCC\",\n containerBoxProps = {},\n }: TypeChartLegendLabelProps) {\n return (\n <StyledBox {...containerBoxProps}>\n <ColorBox bg={color} />\n <Text as=\"div\" fontSize={200} color=\"text.subtext\">\n {children}\n </Text>\n </StyledBox>\n );\n }\n);\n","import { css, type CSSProp } from \"styled-components\";\nimport { Box, type TypeBoxProps } from \"@sproutsocial/seeds-react-box\";\nimport ThemeProvider from \"@sproutsocial/seeds-react-theme-provider\";\nimport { type TypeSproutTheme } from \"@sproutsocial/seeds-react-theme\";\n\nexport type TypeColorBoxProps = TypeBoxProps;\n\n/**\n * ColorBox extends Box to apply basic styles.\n */\nexport const ColorBox = ({\n display = \"inline-block\",\n height = \"16px\",\n width = \"16px\",\n minWidth = width,\n borderRadius = \"400\",\n ...props\n}: TypeColorBoxProps) => {\n return (\n <Box\n {...props}\n display={display}\n height={height}\n width={width}\n minWidth={minWidth}\n borderRadius={borderRadius}\n css={\n css`\n cursor: ${(\n props: typeof ThemeProvider & {\n onClick: ((e: React.MouseEvent<HTMLElement>) => void) | void;\n }\n ) => (props?.onClick ? \"pointer\" : \"default\")};\n ` as CSSProp<TypeSproutTheme>\n }\n />\n );\n};\n","import * as React from \"react\";\nimport { ThemeProvider as BaseThemeProvider } from \"styled-components\";\nimport { theme } from \"@sproutsocial/seeds-react-theme\";\nimport type {\n TypeSproutTheme,\n TypeTheme,\n} from \"@sproutsocial/seeds-react-theme\";\n\n// We can append additional themes types here\ntype TypeAllThemes = TypeTheme | TypeSproutTheme;\n\ntype TypeProps = {\n readonly theme?: TypeAllThemes;\n readonly children?: React.ReactNode;\n};\n\nconst ThemeProvider = (props: TypeProps) => (\n <BaseThemeProvider {...props} theme={props.theme || theme} />\n);\n\nexport default ThemeProvider;\n","import type * as React from \"react\";\nimport styled from \"styled-components\";\nimport { theme } from \"@sproutsocial/seeds-react-theme\";\nimport { ColorBox, type TypeColorBoxProps } from \"./ColorBox\";\n\nexport type TypeDatavizColorBoxProps = Readonly<\n Partial<TypeColorBoxProps> & {\n colorIndex: number;\n }\n>;\nexport type TypeDatavizColorBox = (\n props: TypeDatavizColorBoxProps\n) => React.JSXElementConstructor<TypeDatavizColorBoxProps>;\n\n/**\n * DatavizColorBox extends ColorBox to set the background color from a rotation of <a href=\"https://seeds.sproutsocial.com/visual/dataviz#color-combinations-for-general-sprout-social-data-visualizations\">dataviz colors</a>.\n */\nexport const DatavizColorBox = styled(ColorBox).attrs(\n ({ colorIndex }: TypeDatavizColorBoxProps) => ({\n style: {\n background: getDatavizColor(colorIndex),\n opacity: getDatavizOpacity(colorIndex),\n },\n })\n)<TypeDatavizColorBoxProps>``;\n\nexport const getDatavizColor = (colorIndex: number): string =>\n theme.colors.DATAVIZ_COLORS_LIST[\n colorIndex % theme.colors.DATAVIZ_COLORS_LIST.length\n ] || \"\";\n\nexport const getDatavizOpacity = (colorIndex: number): number => {\n const opacitySteps = [1, 0.6, 0.4, 0.2];\n const opacityStep =\n Math.floor(colorIndex / theme.colors.DATAVIZ_COLORS_LIST.length) %\n opacitySteps.length;\n // @ts-ignore\n return opacitySteps[opacityStep];\n};\n\n// information on 8 digit hex codes can be found here: https://css-tricks.com/8-digit-hex-codes/\nexport const getDatavizColorWithAlpha = (colorIndex: number): string => {\n const color = getDatavizColor(colorIndex);\n const opacity = getDatavizOpacity(colorIndex);\n\n // make sure the opacity is always between 0 and 1\n if (opacity < 0 || opacity > 1) {\n return color;\n }\n\n // sourced from https://stackoverflow.com/a/66143374\n return `${color}${Math.floor(opacity * 255)\n .toString(16)\n .padStart(2, \"0\")}`;\n};\n","import NETWORK_COLORS from \"@sproutsocial/seeds-networkcolor\";\n\nimport { ColorBox, type TypeColorBoxProps } from \"./ColorBox\";\n\n// $Keys<typeof NETWORK_COLORS>\ntype TypeNetworkColor =\n | \"NETWORK_COLOR_TWITTER\"\n | \"NETWORK_COLOR_TWITTER_LIKE\"\n | \"NETWORK_COLOR_FACEBOOK\"\n | \"NETWORK_COLOR_FACEBOOK_AUDIENCE_NETWORK\"\n | \"NETWORK_COLOR_LINKEDIN\"\n | \"NETWORK_COLOR_INSTAGRAM\"\n | \"NETWORK_COLOR_FEEDLY\"\n | \"NETWORK_COLOR_ANALYTICS\"\n | \"NETWORK_COLOR_YOUTUBE\"\n | \"NETWORK_COLOR_MESSENGER\"\n | \"NETWORK_COLOR_SNAPCHAT\"\n | \"NETWORK_COLOR_PINTEREST\"\n | \"NETWORK_COLOR_REDDIT\"\n | \"NETWORK_COLOR_TUMBLR\"\n | \"NETWORK_COLOR_GOOGLE_MY_BUSINESS\"\n | \"NETWORK_COLOR_TIKTOK\"\n | \"NETWORK_COLOR_TRIPADVISOR\"\n | \"NETWORK_COLOR_GLASSDOOR\"\n | \"NETWORK_COLOR_SALESFORCE\"\n | \"NETWORK_COLOR_ZENDESK\"\n | \"NETWORK_COLOR_HUBSPOT\"\n | \"NETWORK_COLOR_MICROSOFT_DYNAMICS\";\n\ntype TypeNetworkColorBoxProps = Readonly<\n TypeColorBoxProps & {\n networkColor: TypeNetworkColor;\n }\n>;\n\n/**\n * NetworkColorBox extends ColorBox to set the background color to a <a href=\"https://seeds.sproutsocial.com/visual/color#full-color-palette\">network color</a>.\n */\nexport const NetworkColorBox = ({\n networkColor,\n ...props\n}: TypeNetworkColorBoxProps) => {\n return <ColorBox {...props} bg={NETWORK_COLORS[networkColor]} />;\n};\n","import { memo } from \"react\";\nimport { Box } from \"@sproutsocial/seeds-react-box\";\n\nexport type TypeChartLegendLabelContentWithIconProps = Readonly<{\n children: React.ReactNode;\n // optional\n icon?: React.ReactNode;\n}>;\n\nexport const ChartLegendLabelContentWithIcon =\n memo<TypeChartLegendLabelContentWithIconProps>(\n function ChartLegendLabelContentWithIcon({\n children,\n icon,\n }: TypeChartLegendLabelContentWithIconProps) {\n return icon ? (\n <Box display=\"flex\" alignItems=\"center\" gap={200}>\n {icon}\n {children}\n </Box>\n ) : (\n children\n );\n }\n );\n","import { memo } from \"react\";\nimport { Box } from \"@sproutsocial/seeds-react-box\";\nimport { Duration } from \"@sproutsocial/seeds-react-duration\";\nimport { Icon } from \"@sproutsocial/seeds-react-icon\";\nimport { Numeral } from \"@sproutsocial/seeds-react-numeral\";\nimport { Text } from \"@sproutsocial/seeds-react-text\";\nimport { type TypeChartXAnnotationsDetails } from \"../../../types\";\n\nimport type { TypeAreaChartProps } from \"../AreaChart\";\n\nimport {\n ChartTooltip,\n ChartTooltipFooter,\n ChartTooltipTable,\n ChartTooltipTitle,\n type TypeChartTooltipTableProps,\n} from \"../../ChartTooltip\";\nimport type { TypeChartTooltipProps } from \"../../../types\";\nimport { ChartLegendLabel } from \"../../ChartLegend/components/ChartLegendLabel\";\nimport { ChartLegendLabelContentWithIcon } from \"../../ChartLegend/components/ChartLegendLabelContentWithIcon\";\n\nexport type TypeAreaChartTooltipProps = Readonly<{\n data: TypeChartTooltipProps[\"data\"];\n invalidNumberLabel: TypeAreaChartProps[\"invalidNumberLabel\"];\n numberLocale: TypeAreaChartProps[\"numberLocale\"];\n textLocale: TypeAreaChartProps[\"textLocale\"];\n tooltipDateFormatter: TypeAreaChartProps[\"tooltipDateFormatter\"];\n tooltipTotalLabel: TypeAreaChartProps[\"tooltipTotalLabel\"];\n total: number | null;\n x: TypeChartTooltipProps[\"x\"];\n // optional\n currency?: TypeAreaChartProps[\"currency\"];\n numberFormat?: TypeAreaChartProps[\"numberFormat\"];\n onClick?: TypeAreaChartProps[\"onClick\"];\n tooltipClickLabel?: TypeAreaChartProps[\"tooltipClickLabel\"];\n xAnnotationDetails?: TypeChartXAnnotationsDetails;\n}>;\n\nexport const AreaChartTooltip = memo<TypeAreaChartTooltipProps>(\n function AreaChartTooltip({\n data,\n invalidNumberLabel,\n numberLocale,\n textLocale,\n tooltipDateFormatter,\n tooltipTotalLabel,\n total,\n x,\n // optional\n currency = \"USD\",\n numberFormat = \"decimal\",\n onClick,\n tooltipClickLabel,\n xAnnotationDetails,\n }: TypeAreaChartTooltipProps) {\n const rows = data.map(({ color, icon, name, value }) => {\n return {\n cells: [\n {\n content: (\n <ChartLegendLabel color={color}>\n <ChartLegendLabelContentWithIcon icon={icon}>\n <Text aria-label={`${name}: `}>{name}</Text>\n </ChartLegendLabelContentWithIcon>\n </ChartLegendLabel>\n ),\n },\n {\n content:\n value === null && invalidNumberLabel ? (\n <Text>{invalidNumberLabel}</Text>\n ) : numberFormat === \"duration\" ? (\n <Duration locale={textLocale} milliseconds={value} />\n ) : (\n <Numeral\n abbreviate={false}\n currency={currency}\n format={numberFormat}\n locale={numberLocale as string}\n number={value}\n />\n ),\n align: \"right\",\n },\n ],\n };\n });\n\n const appendedRows =\n data.length > 1\n ? [\n {\n cells: [\n {\n content: (\n <Text\n fontWeight=\"semibold\"\n aria-label={`${tooltipTotalLabel}: `}\n >\n {tooltipTotalLabel}\n </Text>\n ),\n },\n {\n content: (\n <Text fontWeight=\"bold\">\n {total === null && invalidNumberLabel ? (\n invalidNumberLabel\n ) : numberFormat === \"duration\" ? (\n <Duration locale={textLocale} milliseconds={total} />\n ) : (\n <Numeral\n abbreviate={false}\n currency={currency}\n format={numberFormat}\n locale={numberLocale as string}\n number={total}\n />\n )}\n </Text>\n ),\n align: \"right\",\n },\n ],\n isAppendedRow: true,\n },\n ]\n : [];\n\n return (\n <ChartTooltip>\n {xAnnotationDetails ? xAnnotationDetails() : undefined}\n <ChartTooltipTitle>{tooltipDateFormatter({ x })}</ChartTooltipTitle>\n <ChartTooltipTable\n rows={\n [...rows, ...appendedRows] as TypeChartTooltipTableProps[\"rows\"]\n }\n />\n {onClick && tooltipClickLabel ? (\n <ChartTooltipFooter>\n {typeof tooltipClickLabel === \"string\" ? (\n <Box display=\"flex\" alignItems=\"center\" gap={300}>\n <Icon name=\"hand-pointer-clicking-outline\" color=\"icon.base\" />\n <Text color=\"text.subtext\" fontSize={200}>\n {tooltipClickLabel}\n </Text>\n </Box>\n ) : (\n tooltipClickLabel\n )}\n </ChartTooltipFooter>\n ) : null}\n </ChartTooltip>\n );\n }\n);\n","import { memo } from \"react\";\nimport styled from \"styled-components\";\nimport { Box } from \"@sproutsocial/seeds-react-box\";\n\n// styled components\nconst StyledBox = styled(Box)`\n .Icon,\n .logo {\n stroke: none;\n }\n`;\n\n// Chart Tooltip\ntype TypeChartTooltipProps = Readonly<{\n children: React.ReactNode;\n}>;\n\nexport const ChartTooltip = memo<TypeChartTooltipProps>(function ChartTooltip({\n children,\n}: TypeChartTooltipProps) {\n return (\n <StyledBox\n bg=\"container.background.base\"\n boxShadow=\"medium\"\n border={500}\n borderColor=\"container.border.base\"\n borderRadius={500}\n p={400}\n minWidth={285}\n >\n <Box display=\"flex\" flexDirection=\"column\" gap={350}>\n {children}\n </Box>\n </StyledBox>\n );\n});\n","import { memo } from \"react\";\nimport { Box } from \"@sproutsocial/seeds-react-box\";\n\ntype TypeChartTooltipFooterProps = {\n children: React.ReactNode;\n};\n\nexport const ChartTooltipFooter = memo<TypeChartTooltipFooterProps>(\n function ChartTooltipFooter({ children }: TypeChartTooltipFooterProps) {\n return (\n <Box\n borderTop={500}\n borderColor=\"container.border.base\"\n mx={-400}\n mb={-200}\n px={400}\n pt={350}\n >\n {children}\n </Box>\n );\n }\n);\n","import { memo } from \"react\";\nimport { Box } from \"@sproutsocial/seeds-react-box\";\n\ntype TypeChartTooltipHeaderProps = {\n children: React.ReactNode;\n};\n\nexport const ChartTooltipHeader = memo<TypeChartTooltipHeaderProps>(\n function ChartTooltipHeader({ children }: TypeChartTooltipHeaderProps) {\n return (\n <Box\n borderBottom={500}\n borderColor=\"container.border.base\"\n mx={-400}\n mt={-200}\n px={400}\n pb={350}\n >\n {children}\n </Box>\n );\n }\n);\n","import { memo, useState, useRef, useEffect, type ReactNode } from \"react\";\nimport { createPortal } from \"react-dom\";\nimport type {\n Tooltip,\n Chart,\n TooltipFormatterContextObject,\n TooltipFormatterCallbackFunction,\n} from \"highcharts\";\n\ninterface ExtendedHighchartsTooltip extends Tooltip {\n label: {\n box: { attr({ height, width }: { height: number; width: number }): void };\n text: { element: HTMLElement };\n };\n}\n\nexport const generateChartTooltipPortalId = (chartId: number) =>\n `highcharts-custom-tooltip-${chartId}`;\n\ntype ChartTooltipPortalProps = Readonly<{\n chart: Chart;\n renderContent: (context: TooltipFormatterContextObject) => ReactNode;\n}>;\n\nexport const ChartTooltipPortal = memo<ChartTooltipPortalProps>(\n function ChartTooltipPortal({\n chart,\n renderContent,\n }: ChartTooltipPortalProps) {\n const isInitialized = useRef<boolean>(false);\n const [node, setNode] = useState<HTMLElement | null>(null);\n const [context, setContext] =\n useState<TooltipFormatterContextObject | null>(null);\n\n useEffect(() => {\n const formatter: TooltipFormatterCallbackFunction = function () {\n // Ensures that tooltip DOM container is rendered before React portal is created.\n if (!isInitialized.current) {\n isInitialized.current = true;\n chart.tooltip.refresh.apply(chart.tooltip, [this.point]);\n chart.tooltip.hide(0);\n }\n\n setContext(this);\n\n return `<div id=\"${generateChartTooltipPortalId(\n chart.index\n )}\" role='tooltip'></div>`;\n };\n\n chart.update({ tooltip: { formatter } });\n }, [chart]);\n\n useEffect(() => {\n // In some cases tooltip is not available on the chart yet\n if (context?.series?.chart?.tooltip) {\n const tooltip = context.series.chart\n .tooltip as ExtendedHighchartsTooltip;\n const textElement = tooltip.label.text.element;\n\n tooltip.label.box.attr({\n height: textElement.offsetHeight,\n width: textElement.offsetWidth,\n });\n\n setNode(\n document.getElementById(generateChartTooltipPortalId(chart.index))\n );\n }\n }, [context, chart.index]);\n\n return node && context ? createPortal(renderContent(context), node) : null;\n }\n);\n","import { memo } from \"react\";\n\nimport { ChartTable, type TypeChartTableProps } from \"../../ChartTable\";\n\nexport type TypeChartTooltipTableProps = {\n rows: TypeChartTableProps[\"rows\"];\n};\n\nexport const ChartTooltipTable = memo<TypeChartTooltipTableProps>(\n function ChartTooltipTable({ rows }: TypeChartTooltipTableProps) {\n return <ChartTable rows={rows} />;\n }\n);\n","import { memo } from \"react\";\nimport styled from \"styled-components\";\nimport { Text } from \"@sproutsocial/seeds-react-text\";\nimport { Table as SeedsTable } from \"@sproutsocial/seeds-react-table\";\n\nconst StyledSeedsTable = styled<typeof SeedsTable>(SeedsTable)`\n tbody tr:last-child {\n border-bottom: none;\n }\n tr:last-child td,\n tr:last-child th {\n padding-bottom: 0;\n }\n tr:first-child td,\n tr:first-child th {\n padding-top: 0;\n }\n tr th {\n padding-left: 0;\n }\n tr td:last-child {\n padding-right: 0;\n }\n`;\n\nconst StyledSeedsTableRow = styled(SeedsTable.TableRow)<{\n $isAppendedRow?: boolean;\n}>`\n ${({ $isAppendedRow, theme }) =>\n $isAppendedRow\n ? `border-top: 2px solid ${theme.colors.container.border.base}`\n : \"\"}\n`;\n\nexport type TypeChartTableProps = Readonly<{\n rows: ReadonlyArray<{\n cells: ReadonlyArray<{\n content: React.ReactNode;\n align?: React.ComponentProps<typeof SeedsTable.Cell>[\"align\"];\n colSpan?: React.ComponentProps<typeof SeedsTable.Cell>[\"colSpan\"];\n }>;\n isAppendedRow?: boolean;\n }>;\n}>;\n\nexport const ChartTable = memo<TypeChartTableProps>(function ChartTable({\n rows,\n}: TypeChartTableProps) {\n if (!rows || rows.length === 0) {\n return null;\n }\n\n return (\n <StyledSeedsTable>\n <SeedsTable.TableBody>\n {rows.map(({ cells, isAppendedRow }, rowIndex) => {\n if (!cells || cells.length === 0) {\n return null;\n }\n\n return (\n <StyledSeedsTableRow\n key={`chart-tooltip-table-row-${rowIndex}`}\n $isAppendedRow={isAppendedRow}\n >\n {cells.map(\n ({ content, align = \"left\", colSpan = 1 }, cellIndex) => {\n const uniqueIdentifier = `chart-tooltip-table-cell-${cellIndex}`;\n return (\n <SeedsTable.Cell\n key={uniqueIdentifier}\n id={uniqueIdentifier}\n scope={cellIndex === 0 ? \"row\" : undefined}\n align={align}\n colSpan={colSpan}\n py={200}\n >\n <Text.SmallBodyCopy as=\"div\">\n {content}\n </Text.SmallBodyCopy>\n </SeedsTable.Cell>\n );\n }\n )}\n </StyledSeedsTableRow>\n );\n })}\n </SeedsTable.TableBody>\n </StyledSeedsTable>\n );\n});\n","import { memo } from \"react\";\nimport { Text } from \"@sproutsocial/seeds-react-text\";\n\ntype TypeChartTooltipTitleProps = {\n children: React.ReactNode;\n};\n\nexport const ChartTooltipTitle = memo<TypeChartTooltipTitleProps>(\n function ChartTooltipTitle({ children }: TypeChartTooltipTitleProps) {\n return <Text.SmallSubHeadline as=\"p\">{children}</Text.SmallSubHeadline>;\n }\n);\n","import { memo, useEffect, useState, useRef } from \"react\";\nimport { createPortal } from \"react-dom\";\nimport { type TypeChartXAnnotations } from \"../../../types\";\nimport {\n type AnnotationsOptions,\n type AnnotationsLabelOptions,\n} from \"highcharts\";\n\n// add in types that Highcharts doesn't include by default\nexport interface TypeExtendedLabelOptions extends AnnotationsLabelOptions {\n graphic?: {\n div?: HTMLDivElement;\n };\n options?: {\n point?: {\n x?: number;\n };\n };\n}\n\nexport const ChartXAnnotationMarkerPortal = memo(\n function ChartXAnnotationMarkerPortal({\n xAnnotations,\n annotationContext,\n }: {\n xAnnotations: TypeChartXAnnotations;\n annotationContext: AnnotationsOptions;\n }) {\n const annotationContainers = useRef<Record<number, HTMLDivElement>>({});\n const [renderCount, setRenderCount] = useState(0); // used to trigger react to re-render\n const forceRender = () => setRenderCount((prev) => prev + 1);\n useEffect(() => {\n if (annotationContext.labels) {\n const newContainers: Record<number, HTMLDivElement> = {};\n const existingAnnotationContainers = document.querySelectorAll(\n \"div[data-annotation-marker='true']\"\n );\n\n // 1. Mark all existing annotations as \"false\" before updating\n // Highcharts doesn't clean these up, so we'll need to at the end\n existingAnnotationContainers.forEach((annotation) =>\n annotation.setAttribute(\"data-annotation-marker\", \"false\")\n );\n\n annotationContext.labels.forEach((label: TypeExtendedLabelOptions) => {\n const labelElement = label.graphic?.div;\n if (labelElement) {\n // 2. Remove old annotations markers inside the current container\n labelElement\n .querySelectorAll(\"div[data-annotation-marker]\")\n .forEach((component) => component.remove());\n\n // 3. Create a new annotation div\n const annotationDiv = document.createElement(\"div\");\n annotationDiv.setAttribute(\"data-annotation-marker\", \"true\");\n labelElement.appendChild(annotationDiv);\n\n const xValue = label.options?.point?.x as number;\n newContainers[xValue] = annotationDiv;\n }\n });\n\n annotationContainers.current = newContainers;\n forceRender(); // Triggers re-render so the portal attaches to updated containers\n\n // 4. Remove stale parent annotation containers\n requestAnimationFrame(() => {\n document\n .querySelectorAll(\"div.highcharts-annotation\")\n .forEach((annotationDiv) => {\n const reactAnnotations = annotationDiv.querySelectorAll(\n \"div[data-annotation-marker]\"\n );\n\n const hasActiveAnnotations = Array.from(reactAnnotations).some(\n (div) => div.getAttribute(\"data-annotation-marker\") === \"true\"\n );\n\n // Remove if all child markers are stale\n if (!hasActiveAnnotations) {\n annotationDiv.remove();\n }\n });\n });\n }\n }, [annotationContext.labels, xAnnotations]);\n\n return (\n <>\n {Object.entries(annotationContainers.current).map(\n ([xValue, container]) => {\n const annotationComponent = xAnnotations?.[Number(xValue)]?.marker;\n return annotationComponent\n ? createPortal(annotationComponent(), container)\n : null;\n }\n )}\n </>\n );\n }\n);\n","import type {\n SeriesSplineOptions,\n SeriesAreasplineOptions,\n SeriesColumnOptions,\n} from \"highcharts\";\n\nimport type { TypeAreaChartProps } from \"../components/AreaChart\";\nimport type { TypeLineChartProps } from \"../components/LineChart\";\nimport type { TypeVerticalBarChartProps, TypeSeriesType } from \"../types\";\n\ntype TypeTimeSeriesOptions =\n | SeriesSplineOptions\n | SeriesAreasplineOptions\n | SeriesColumnOptions;\n\n// returns a transformed set of data to series with some logic for handling null values\nexport const transformDataToSeries = (\n {\n data,\n }: {\n data:\n | TypeAreaChartProps[\"data\"]\n | TypeLineChartProps[\"data\"]\n | TypeVerticalBarChartProps[\"data\"];\n },\n type: TypeSeriesType\n): TypeTimeSeriesOptions[] => {\n // Check if we have categorical data (string x values)\n const hasCategoricalData = data.some((series) =>\n series.points.some((point) => typeof point.x === \"string\")\n );\n\n return data.map((dataItem, dataIndex) => {\n const points = dataItem.points || [];\n const dataPoints = points.map((point, pointsIndex) => {\n let enableMarker = false;\n const isFirstPoint = pointsIndex === 0;\n const isLastPoint = pointsIndex === points.length - 1;\n\n // @ts-ignore\n const previousY = isFirstPoint ? null : points[pointsIndex - 1].y;\n // @ts-ignore\n const nextY = isLastPoint ? null : points[pointsIndex + 1].y;\n\n if (isFirstPoint && nextY === null) {\n // if the first point has data and the second point is null, show a marker for the first point\n enableMarker = true;\n } else if (isLastPoint && previousY === null) {\n // if the last point has data and the second to last point is null, show a marker for the last point\n enableMarker = true;\n } else if (previousY === null && nextY === null) {\n // if the a point has null values on both sides, show a marker\n enableMarker = true;\n }\n\n return {\n x: hasCategoricalData ? pointsIndex : point.x,\n y: point.y,\n marker: {\n enabled: enableMarker ? enableMarker : undefined,\n symbol: enableMarker ? \"circle\" : undefined,\n },\n // For categorical data, store the original category name\n ...(hasCategoricalData && { name: point.x }),\n };\n });\n\n return {\n colorIndex: dataIndex,\n data: dataPoints as TypeTimeSeriesOptions[\"data\"],\n name: dataItem.name as TypeTimeSeriesOptions[\"name\"],\n type: type,\n };\n });\n};\n","import type { TooltipFormatterContextObject } from \"highcharts\";\nimport { theme } from \"@sproutsocial/seeds-react-theme\";\n\nimport type { TypeAreaChartProps } from \"../components/AreaChart\";\nimport type { TypeLineChartProps } from \"../components/LineChart\";\nimport type { TypeChartTooltipProps } from \"../types\";\n\ntype TypeTransformTimeSeriesTooltipDataProps = Readonly<{\n context: TooltipFormatterContextObject;\n data: TypeAreaChartProps[\"data\"] | TypeLineChartProps[\"data\"];\n}>;\ntype TypeTransformTimeSeriesTooltipDataReturn = TypeChartTooltipProps[\"data\"];\n\nexport const transformTimeSeriesTooltipData = ({\n context,\n data,\n}: TypeTransformTimeSeriesTooltipDataProps): TypeTransformTimeSeriesTooltipDataReturn => {\n // @ts-ignore\n return (context.series.chart.series || []).map((series, index) => {\n const pointIndex = context.point.index;\n // @ts-ignore\n const { y } = series.points[pointIndex];\n\n return {\n color:\n data[index]?.styles?.color || theme.colors.DATAVIZ_COLORS_LIST[index],\n ...(data[index]?.icon ? { icon: data[index]?.icon } : {}),\n name: series.name,\n value: typeof y === \"number\" ? y : null,\n };\n });\n};\n","import type {\n AxisLabelsFormatterContextObject,\n AxisTickPositionsArray,\n} from \"highcharts\";\nimport { formatDuration } from \"@sproutsocial/seeds-react-duration\";\nimport { formatNumeral } from \"@sproutsocial/seeds-react-numeral\";\n\nimport type { TypeChartNumberFormat } from \"../types\";\n\ntype TypeYAxisLabelFormatterProps = Readonly<{\n numberLocale: Intl.LocalesArgument;\n textLocale: Intl.LocalesArgument;\n tickPositions: AxisTickPositionsArray;\n value: AxisLabelsFormatterContextObject[\"value\"];\n // optional\n currency?: string;\n numberFormat?: TypeChartNumberFormat;\n}>;\n\nexport const yAxisLabelFormatter = ({\n numberLocale,\n textLocale,\n tickPositions,\n value,\n currency = \"USD\",\n numberFormat = \"decimal\",\n}: TypeYAxisLabelFormatterProps): string => {\n const numberValue = Number(value);\n\n if (numberValue === 0) {\n return formatNumeral({\n locale: numberLocale as string,\n number: numberValue,\n });\n }\n\n if (numberFormat === \"duration\") {\n return formatDuration({\n display: \"narrow\",\n locale: textLocale,\n milliseconds: numberValue,\n });\n }\n\n // Seeds formatNumeral helper starts abbreviating numbers above 10,000. this maxValue logic\n // helps bring that threshold down to 1,000 if the last tick on the y axis is greater than 9,999\n // so we render \"2k 4k 6k 8k 10k\" instead of \"2,000 4,000 6,000 8,000 10k\"\n const maxValue =\n tickPositions && tickPositions.length > 0\n ? tickPositions[tickPositions.length - 1]\n : undefined;\n const abbreviate =\n typeof maxValue === \"number\" && maxValue > 9999 ? 1000 : true;\n\n return formatNumeral({\n abbreviate,\n currency,\n format: numberFormat,\n locale: numberLocale as string,\n number: numberValue,\n });\n};\n","import type {\n AxisLabelsFormatterContextObject,\n AxisTickPositionsArray,\n} from \"highcharts\";\n\nimport type {\n ExtendedTimeTicksInfoObject,\n TypeChartTimeFormat,\n} from \"../types\";\n\ntype TypeXAxisLabelFormatterProps = Readonly<{\n textLocale: Intl.LocalesArgument;\n tickPositions: AxisTickPositionsArray;\n unitName: ExtendedTimeTicksInfoObject[\"unitName\"];\n value: AxisLabelsFormatterContextObject[\"value\"];\n // optional\n timeFormat?: TypeChartTimeFormat;\n}>;\n\nexport const xAxisLabelFormatter = ({\n textLocale,\n tickPositions = [],\n unitName,\n value,\n // optional\n timeFormat = \"12\",\n}: TypeXAxisLabelFormatterProps): string => {\n // Handle categorical (string) data\n if (typeof value === \"string\") {\n return `<span>${value}</span>`;\n }\n const tickIndex = tickPositions.indexOf(value as number);\n const isFirst = tickIndex === 0;\n const previousValue = tickPositions[tickIndex - 1];\n\n const valueDate = new Date(value);\n // @ts-ignore\n const previousValueDate = new Date(previousValue);\n\n let firstPartOptions = {};\n let secondPartOptions = {};\n\n switch (unitName) {\n case \"hour\":\n firstPartOptions =\n timeFormat === \"24\"\n ? { hour: \"numeric\", minute: \"numeric\", hour12: false }\n : { hour: \"numeric\" };\n if (\n isFirst ||\n valueDate.getUTCDate() !== previousValueDate.getUTCDate()\n ) {\n secondPartOptions = { day: \"numeric\", month: \"short\" };\n }\n break;\n case \"day\":\n case \"week\":\n firstPartOptions = { day: \"numeric\" };\n if (\n isFirst ||\n valueDate.getUTCMonth() !== previousValueDate.getUTCMonth()\n ) {\n secondPartOptions = { month: \"short\" };\n }\n break;\n case \"month\":\n firstPartOptions = { month: \"short\" };\n if (\n isFirst ||\n valueDate.getUTCFullYear() !== previousValueDate.getUTCFullYear()\n ) {\n secondPartOptions = { year: \"numeric\" };\n }\n break;\n case \"year\":\n firstPartOptions = { year: \"numeric\" };\n break;\n default:\n firstPartOptions = {};\n break;\n }\n\n // highcharts by default uses UTC: https://api.highcharts.com/highcharts/time.useUTC\n const firstPart = new Intl.DateTimeFormat(textLocale, {\n ...firstPartOptions,\n timeZone: \"UTC\",\n }).format(valueDate);\n const secondPart =\n Object.keys(secondPartOptions).length > 0\n ? new Intl.DateTimeFormat(textLocale, {\n ...secondPartOptions,\n timeZone: \"UTC\",\n }).format(valueDate)\n : undefined;\n\n return `<span>${firstPart}</span>${\n secondPart ? `<span>${secondPart}</span>` : \"\"\n }`;\n};\n","/**\n * Helper to detect if data is hourly time data (all x values are hours of the same day)\n * @param data - Array of series data with points containing x values\n * @returns boolean indicating if all x values are hours of the same day\n */\nexport function isHourlyTimeData(\n data: ReadonlyArray<\n Readonly<{ points: ReadonlyArray<{ x: number | string }> }>\n >\n): boolean {\n // Return false if there is no data.\n if (!data.length) return false;\n\n // Flatten all data points into a single array of x values.\n const xVals = data.flatMap((series) => series.points.map((p) => p.x));\n\n // Return false if there are no x values.\n if (!xVals.length) return false;\n\n // Return false if any x values are strings (categorical data)\n if (xVals.some((x) => typeof x === \"string\")) return false;\n\n // Check if all x values are on the same calendar date.\n // We do this by converting each timestamp to a YYYY-MM-DD string and checking if there's only one unique date string.\n const dates = (xVals as number[]).map((x) => {\n const d = new Date(x);\n return `${d.getUTCFullYear()}-${d.getUTCMonth()}-${d.getUTCDate()}`;\n });\n const uniqueDates = new Set(dates);\n if (uniqueDates.size !== 1) return false;\n\n // Check if all x values are exactly on the hour (e.g., 2:00:00, not 2:00:01).\n // We also check that the hour is within the valid 0-23 range.\n return (xVals as number[]).every((x) => {\n const d = new Date(x);\n const hour = d.getUTCHours();\n const minutes = d.getUTCMinutes();\n const seconds = d.getUTCSeconds();\n return hour >= 0 && hour <= 23 && minutes === 0 && seconds === 0;\n });\n}\n","/**\n * Helper to detect if data is categorical hour data (all x values are hour strings)\n * Supports both 12-hour format (\"12 AM\", \"1 PM\") and 24-hour format (\"00:00\", \"13:00\", \"23:00\")\n * @param data - Array of series data with points containing x values\n * @returns boolean indicating if all x values are hour strings\n */\nexport function isCategoricalHourData(\n data: ReadonlyArray<\n Readonly<{ points: ReadonlyArray<{ x: number | string }> }>\n >\n): boolean {\n // Return false if there is no data.\n if (!data.length) return false;\n\n // Flatten all data points into a single array of x values.\n const xVals = data.flatMap((series) => series.points.map((p) => p.x));\n\n // Return false if there are no x values.\n if (!xVals.length) return false;\n\n // Return false if any x values are not strings (numerical data)\n if (xVals.some((x) => typeof x !== \"string\")) return false;\n\n // Check if all x values match either 12-hour or 24-hour format patterns\n const hour12Pattern = /^\\d{1,2} (AM|PM)$/; // \"12 AM\", \"1 PM\", \"10 AM\"\n const hour24Pattern = /^([01]?\\d|2[0-3]):([0-5]\\d)$/; // \"00:00\", \"13:00\", \"23:59\"\n\n const stringValues = xVals as string[];\n\n // Check if all values match 12-hour format\n const allMatch12Hour = stringValues.every((x) => hour12Pattern.test(x));\n\n // Check if all values match 24-hour format\n const allMatch24Hour = stringValues.every((x) => hour24Pattern.test(x));\n\n return allMatch12Hour || allMatch24Hour;\n}\n","export const getStorybookRandomColor = (): string => {\n const letters = \"0123456789ABCDEF\";\n let color = \"#\";\n for (let i = 0; i < 6; i++) {\n color += letters[Math.floor(Math.random() * 16)];\n }\n return color;\n};\n","import { getStorybookRandomColor } from \"./getStorybookRandomColor\";\n\nexport const getStorybookCategoricalData = ({\n showNulls,\n showNegativeValues,\n numberOfSeries,\n yAxisMax,\n showCustomColors,\n showDashedLines,\n categoryType,\n}: {\n showNulls: boolean;\n showNegativeValues: boolean;\n numberOfSeries: number;\n yAxisMax: number;\n showCustomColors: boolean;\n showDashedLines: boolean;\n categoryType: \"hours\" | \"hours24\" | \"days\" | \"months\" | \"custom\";\n}) => {\n // Define different category sets\n const categoryOptions = {\n hours: [\n \"12 AM\",\n \"1 AM\",\n \"2 AM\",\n \"3 AM\",\n \"4 AM\",\n \"5 AM\",\n \"6 AM\",\n \"7 AM\",\n \"8 AM\",\n \"9 AM\",\n \"10 AM\",\n \"11 AM\",\n \"12 PM\",\n \"1 PM\",\n \"2 PM\",\n \"3 PM\",\n \"4 PM\",\n \"5 PM\",\n \"6 PM\",\n \"7 PM\",\n \"8 PM\",\n \"9 PM\",\n \"10 PM\",\n \"11 PM\",\n ],\n hours24: [\n \"00:00\",\n \"01:00\",\n \"02:00\",\n \"03:00\",\n \"04:00\",\n \"05:00\",\n \"06:00\",\n \"07:00\",\n \"08:00\",\n \"09:00\",\n \"10:00\",\n \"11:00\",\n \"12:00\",\n \"13:00\",\n \"14:00\",\n \"15:00\",\n \"16:00\",\n \"17:00\",\n \"18:00\",\n \"19:00\",\n \"20:00\",\n \"21:00\",\n \"22:00\",\n \"23:00\",\n ],\n days: [\n \"Monday\",\n \"Tuesday\",\n \"Wednesday\",\n \"Thursday\",\n \"Friday\",\n \"Saturday\",\n \"Sunday\",\n ],\n months: [\n \"January\",\n \"February\",\n \"March\",\n \"April\",\n \"May\",\n \"June\",\n \"July\",\n \"August\",\n \"September\",\n \"October\",\n \"November\",\n \"December\",\n ],\n custom: [\n \"Category A\",\n \"Category B\",\n \"Category C\",\n \"Category D\",\n \"Category E\",\n ],\n };\n\n const categories = categoryOptions[categoryType];\n const numberOfPoints = categories.length;\n\n return [...Array(numberOfSeries).keys()].map((seriesIndex) => {\n let nullsArray: ReadonlyArray<number> = [];\n\n if (showNulls) {\n const nullsArrayLength = Math.floor(numberOfPoints / 5);\n nullsArray = [...Array(nullsArrayLength)].map(() =>\n Math.floor(Math.random() * numberOfPoints)\n );\n }\n\n return {\n points: categories.map((category, pointIndex) => {\n const showNull =\n nullsArray && nullsArray.length > 0\n ? nullsArray.includes(pointIndex)\n : false;\n const randomValue = Math.random();\n const positiveOrNegativeYAxisMax = showNegativeValues\n ? randomValue < 0.5\n ? -yAxisMax\n : yAxisMax\n : yAxisMax;\n\n return {\n x: category,\n y: showNull\n ? null\n : Math.floor(randomValue * positiveOrNegativeYAxisMax),\n };\n }),\n name: `Series ${seriesIndex + 1}`,\n styles: {\n color: showCustomColors ? getStorybookRandomColor() : undefined,\n pattern: showDashedLines ? \"dashed\" : \"solid\",\n },\n };\n });\n};\n","import { getStorybookRandomColor } from \"./getStorybookRandomColor\";\n\nexport const getStorybookSparseTimelineData = ({\n showNulls,\n showNegativeValues,\n numberOfSeries,\n yAxisMax,\n showCustomColors,\n showDashedLines,\n numberOfPoints = 5,\n timeSpanHours = 24,\n}: {\n showNulls: boolean;\n showNegativeValues: boolean;\n numberOfSeries: number;\n yAxisMax: number;\n showCustomColors: boolean;\n showDashedLines: boolean;\n numberOfPoints?: number;\n timeSpanHours?: number;\n}) => {\n const seriesNames = [\n \"Posts Published\",\n \"Comments\",\n \"Likes\",\n \"Shares\",\n \"Clicks\",\n \"Views\",\n \"Saves\",\n \"Reposts\",\n \"Mentions\",\n \"Reactions\",\n ];\n\n const baseDate = new Date(\"2024-01-01T00:00:00Z\");\n const timeSpanMs = timeSpanHours * 60 * 60 * 1000;\n\n return [...Array(numberOfSeries).keys()].map((seriesIndex) => {\n let nullsArray: ReadonlyArray<number> = [];\n\n if (showNulls) {\n const nullsArrayLength = Math.floor(numberOfPoints / 5);\n nullsArray = [...Array(nullsArrayLength)].map(() =>\n Math.floor(Math.random() * numberOfPoints)\n );\n }\n\n // Generate random timestamps for this series\n const timestamps = [...Array(numberOfPoints)]\n .map(() => {\n const randomOffset = Math.random() * timeSpanMs;\n return baseDate.getTime() + randomOffset;\n })\n .sort((a, b) => a - b); // Sort chronologically\n\n return {\n points: timestamps.map((timestamp, pointIndex) => {\n const showNull =\n nullsArray && nullsArray.length > 0\n ? nullsArray.includes(pointIndex)\n : false;\n const randomValue = Math.random();\n const positiveOrNegativeYAxisMax = showNegativeValues\n ? randomValue < 0.5\n ? -yAxisMax\n : yAxisMax\n : yAxisMax;\n\n return {\n x: timestamp,\n y: showNull\n ? null\n : Math.floor(randomValue * positiveOrNegativeYAxisMax),\n };\n }),\n name: seriesNames[seriesIndex] || `Series ${seriesIndex + 1}`,\n styles: {\n color: showCustomColors ? getStorybookRandomColor() : undefined,\n pattern: showDashedLines ? \"dashed\" : \"solid\",\n },\n };\n });\n};\n","import { useState, useCallback, useMemo } from \"react\";\nimport type {\n Chart,\n Annotation,\n Series,\n Point,\n AxisLabelsFormatterContextObject,\n SeriesClickEventObject,\n} from \"highcharts\";\n\nimport {\n lineChartOptions,\n areaChartOptions,\n columnChartOptions,\n} from \"../constants\";\nimport type { TypeAreaChartProps } from \"../components/AreaChart\";\nimport type { TypeLineChartProps } from \"../components/LineChart\";\nimport type { TypeVerticalBarChartProps } from \"../types\";\nimport {\n yAxisLabelFormatter as defaultYAxisLabelFormatter,\n transformDataToSeries,\n xAxisLabelFormatter,\n} from \"../helpers\";\nimport type {\n TypeChartNumberFormat,\n TypeChartTimeFormat,\n ExtendedAxisLabelsFormatterContextObject,\n TypeChartYAxisLabelFormatter,\n TypeChartXAnnotations,\n TypeSeriesType,\n} from \"../types\";\nimport { generateChartTooltipPortalId } from \"../components/ChartTooltip/components/ChartTooltipPortal\";\nimport { merge } from \"lodash\";\n\nexport type TypeUseTimeSeriesChartOptionsProps = {\n xAnnotations: TypeChartXAnnotations;\n data:\n | TypeAreaChartProps[\"data\"]\n | TypeLineChartProps[\"data\"]\n | TypeVerticalBarChartProps[\"data\"];\n numberLocale: Intl.LocalesArgument;\n seriesType: TypeSeriesType;\n textLocale: Intl.LocalesArgument;\n // optional\n currency?: string;\n disableTooltips?: boolean;\n numberFormat?: TypeChartNumberFormat;\n yAxisLabelFormatter?: TypeChartYAxisLabelFormatter;\n onClick?: ({ x }: Readonly<{ x: number }>) => void;\n timeFormat?: TypeChartTimeFormat;\n xAxisLabelFormatter?: (params: {\n textLocale: Intl.LocalesArgument;\n tickPositions: number[];\n unitName: string;\n value: number | string;\n timeFormat?: string;\n }) => string;\n};\nexport interface TypeExtendedChart extends Chart {\n // Highcharts doesn't include the annotations type by default, so we have to add it\n annotations?: Annotation[];\n}\n\nexport const useTimeSeriesChartOptions = ({\n xAnnotations,\n data,\n numberLocale,\n seriesType,\n textLocale,\n currency = \"USD\",\n disableTooltips = false,\n numberFormat = \"decimal\",\n yAxisLabelFormatter,\n onClick,\n timeFormat = \"12\",\n xAxisLabelFormatter,\n}: TypeUseTimeSeriesChartOptionsProps) => {\n const [chart, setChart] = useState<TypeExtendedChart | null>(null);\n\n const callback = useCallback((chartInstance: Chart) => {\n setChart(chartInstance);\n }, []);\n\n function attachTooltipEventListeners(series: Series[], tooltipId: string) {\n const handleFocus = (point: Point) =>\n point.series.chart.tooltip.refresh(point);\n const handleBlur = (point: Point) => point.series.chart.tooltip.hide(0);\n\n series\n .flatMap((item) => item.data)\n .forEach((point) => {\n const pointElement = point?.graphic?.element;\n if (pointElement) {\n pointElement.setAttribute(\"aria-describedby\", tooltipId);\n pointElement.addEventListener(\"focus\", () => handleFocus(point));\n pointElement.addEventListener(\"blur\", () => handleBlur(point));\n }\n });\n }\n\n const formattedXAnnotations = (annotations?: TypeChartXAnnotations) => {\n if (annotations) {\n return Object.entries(annotations).map(([x]) => ({\n point: {\n x: Number(x), // Convert key (which is a string) to a number\n y: 0,\n xAxis: 0,\n yAxis: 0,\n },\n text: \" \", // space is necessary because empty string reverts to showing default label\n }));\n }\n };\n\n const chartMarginTop = xAnnotations ? 24 : null;\n\n const getBaseChartOptions = (type: TypeSeriesType) => {\n switch (type) {\n case \"areaspline\":\n return areaChartOptions;\n case \"spline\":\n return lineChartOptions;\n case \"column\":\n return columnChartOptions;\n default:\n return lineChartOptions; // fallback to line chart as default\n }\n };\n\n const baseChartOptions = getBaseChartOptions(seriesType);\n\n // Detect if we have categorical data (string x values)\n const hasCategoricalData = data.some((series) =>\n series.points.some((point) => typeof point.x === \"string\")\n );\n\n // Extract categories for categorical data\n const categories = hasCategoricalData\n ? data[0]?.points.map((point) => point.x as string) || []\n : [];\n\n // Detect sparse timeline data (numerical x values with gaps that need wider columns)\n const hasSparseTimelineData = !hasCategoricalData && seriesType === \"column\";\n\n const options = useMemo(() => {\n return merge({}, baseChartOptions, {\n accessibility: {\n point: {\n descriptionFormatter: function () {\n return \" \"; // space is necessary because empty string reverts to defaults\n },\n },\n },\n annotations: [\n {\n labels: xAnnotations\n ? formattedXAnnotations(xAnnotations)\n : undefined,\n },\n ],\n chart: {\n marginTop: chartMarginTop,\n events: {\n click: onClick\n ? function (this: TypeExtendedChart) {\n return onClick({ x: this?.hoverPoint?.x as number });\n }\n : undefined,\n load: function (this: TypeExtendedChart) {\n const tooltipId = generateChartTooltipPortalId(this.index);\n attachTooltipEventListeners(this.series, tooltipId);\n },\n },\n },\n plotOptions: {\n areaspline: {\n events: {\n click:\n onClick && seriesType === \"areaspline\"\n ? function (event: SeriesClickEventObject) {\n return onClick({ x: event.point.x });\n }\n : undefined,\n },\n },\n spline: {\n events: {\n click:\n onClick && seriesType === \"spline\"\n ? function (event: SeriesClickEventObject) {\n return onClick({ x: event.point.x });\n }\n : undefined,\n },\n },\n column: {\n // For sparse timeline data, set explicit point width to make columns wider\n ...(hasSparseTimelineData && {\n pointWidth: 20, // Fixed width in pixels for sparse timeline data\n }),\n point: {\n events: {\n /*\n Custom hover behavior for multi-series column charts.\n \n In multi-series column charts, multiple columns\n can share the same x-axis position (stacked or grouped). When hovering\n over one column, we want ALL columns at that x-position to highlight\n together for better visual feedback. Simple CSS :hover only affects the\n individual element being hovered, not related columns at the same position.\n \n This custom behavior ensures that when you hover over any column at a\n specific x-position, all columns at that same position get the \"column-hover\"\n class, creating a unified highlight effect across all series.\n */\n mouseOver: function (this: any) {\n const x = this.x;\n if (\n this.series &&\n this.series.chart &&\n this.series.chart.series\n ) {\n this.series.chart.series.forEach((series: any) => {\n if (series.type === \"column\") {\n series.data.forEach((point: any) => {\n if (point.x === x) {\n const el = point.graphic && point.graphic.element;\n if (el) {\n el.classList.add(\"column-hover\");\n }\n }\n });\n }\n });\n }\n },\n mouseOut: function (this: any) {\n if (\n this.series &&\n this.series.chart &&\n this.series.chart.series\n ) {\n this.series.chart.series.forEach((series: any) => {\n if (series.type === \"column\") {\n series.data.forEach((point: any) => {\n const el = point.graphic && point.graphic.element;\n if (el) {\n el.classList.remove(\"column-hover\");\n }\n });\n }\n });\n }\n },\n },\n },\n },\n },\n series: transformDataToSeries({ data }, seriesType),\n tooltip: {\n enabled: !disableTooltips,\n },\n xAxis: {\n labels: {\n formatter: function (this: AxisLabelsFormatterContextObject) {\n const tickPositions = (this.axis.tickPositions || []).map(\n Number\n ) as number[];\n const value = this.value;\n const unitName = (this as ExtendedAxisLabelsFormatterContextObject)\n .tickPositionInfo?.unitName;\n if (typeof xAxisLabelFormatter === \"function\") {\n return xAxisLabelFormatter({\n textLocale,\n tickPositions,\n timeFormat,\n unitName,\n value,\n });\n }\n if (typeof xAxisLabelFormatterDefault === \"function\") {\n return xAxisLabelFormatterDefault({\n textLocale,\n tickPositions,\n timeFormat,\n unitName,\n value,\n });\n }\n return \"\";\n },\n },\n // Override xAxis type for categorical data\n ...(hasCategoricalData && {\n type: \"category\",\n categories,\n crosshair: false,\n }),\n },\n yAxis: {\n labels: {\n formatter: function (this: AxisLabelsFormatterContextObject) {\n return yAxisLabelFormatter\n ? yAxisLabelFormatter({\n y: this.value as number,\n yValues: this.axis.tickPositions as ReadonlyArray<number>,\n })\n : defaultYAxisLabelFormatter({\n currency,\n numberFormat,\n numberLocale,\n textLocale,\n tickPositions: this.axis.tickPositions || [],\n value: this.value,\n });\n },\n },\n },\n });\n }, [\n baseChartOptions,\n categories,\n currency,\n data,\n hasCategoricalData,\n hasSparseTimelineData,\n numberFormat,\n numberLocale,\n onClick,\n seriesType,\n textLocale,\n timeFormat,\n xAnnotations,\n yAxisLabelFormatter,\n xAxisLabelFormatter,\n ]);\n\n return { options, chart, callback };\n};\n\n// Alias the default formatter to avoid shadowing\nconst xAxisLabelFormatterDefault = xAxisLabelFormatter;\n","import type { Options } from \"highcharts\";\nimport _ from \"lodash\";\n\n// options that should apply to all charts\n// this is being exported because it's needed for the listening bubble chart component.\n// when that components gets moved into the data-viz package, we can remove the export here\nexport const baseChartOptions: Options = {\n chart: {\n animation: false,\n styledMode: true,\n },\n credits: {\n enabled: false,\n },\n exporting: {\n enabled: false,\n fallbackToExportServer: false,\n },\n legend: {\n enabled: false,\n },\n title: {\n text: undefined,\n },\n tooltip: {\n hideDelay: 0,\n outside: true,\n padding: 0,\n shape: \"rect\",\n shared: true,\n useHTML: true,\n },\n};\n\n// options that should apply to time series charts\nexport const TIME_SERIES_CHART_HEIGHT = 275;\nexport const timeSeriesChartOptions: Options = _.merge({}, baseChartOptions, {\n annotations: [\n {\n draggable: \"\",\n labelOptions: {\n useHTML: true,\n padding: 0, // removes \"left\" property padding created by highcharts so that label is centered\n },\n },\n ],\n chart: {\n // events.click is set at the component level because of the optional onClick prop\n height: TIME_SERIES_CHART_HEIGHT,\n spacing: [5, 1, 0, 2],\n },\n plotOptions: {\n series: {\n animation: false,\n clip: false,\n marker: {\n enabled: false,\n states: {\n hover: {\n enabled: false,\n },\n },\n },\n },\n },\n xAxis: {\n crosshair: {\n zIndex: 3,\n },\n minPadding: 0, // must be handled dynamically instead of css\n maxPadding: 0, // must be handled dynamically instead of css\n type: \"datetime\",\n labels: {\n useHTML: true,\n // formatter is set at the component level because of the required text locale prop\n },\n },\n yAxis: {\n labels: {\n useHTML: true,\n // formatter is set at the component level because of the optional yAxisLabelFormatter prop\n },\n softMax: 0,\n softMin: 0,\n title: {\n text: undefined,\n },\n plotLines: [\n /* Adds a custom plotLine at y=0 to represent the chart baseline.\n This approach allows full control over the line's appearance (e.g., color, z-index),\n unlike relying on the default xAxis line, which always renders at the bottom of the chart\n even when y=0 appears elsewhere (e.g., with negative values).\n */\n {\n className: \"y-axis-zero-line\",\n value: 0,\n zIndex: 3, // ensures the line appears over the default y=0 line, which we can't seleect as specifically\n },\n ],\n },\n});\n\n// options that should apply to LineChart\nexport const lineChartOptions: Options = _.merge({}, timeSeriesChartOptions, {\n // plotOptions.spline.events.click is set at the component level because of the optional onClick prop\n});\n\n// options that should apply to AreaChart\nexport const areaChartOptions: Options = _.merge({}, timeSeriesChartOptions, {\n plotOptions: {\n areaspline: {\n // events.click is set at the component level because of the optional onClick prop\n stacking: \"normal\",\n },\n },\n});\n\nexport const columnChartOptions: Options = _.merge({}, timeSeriesChartOptions, {\n plotOptions: {\n column: {\n stacking: \"normal\",\n pointPadding: 0.25,\n groupPadding: 0.25,\n borderRadius: 4,\n },\n },\n xAxis: {\n crosshair: false,\n },\n yAxis: {\n plotLines: [\n {\n // For stacked column charts with visible borders (e.g., white for contrast),\n // we raise the zIndex of the y=0 plotLine to ensure it remains visible\n // and isn't visually covered by overlapping column borders.\n zIndex: 5,\n },\n ],\n },\n});\n\n/**\n * The default series limit for VerticalBarChart.\n * This limit is recommended to maintain chart readability and accessibility.\n * @see {VerticalBarChart}\n */\nexport const VERTICAL_BAR_CHART_DEFAULT_SERIES_LIMIT = 10;\n\n// options that should apply to DonutChart\nexport const DONUT_CHART_HALO_SIZE = 10; // 10 is the default from highcharts\nexport const DONUT_CHART_HEIGHT = 250 + DONUT_CHART_HALO_SIZE * 2;\nexport const DONUT_CHART_WIDTH = DONUT_CHART_HEIGHT;\nexport const donutChartOptions: Options = _.merge({}, baseChartOptions, {\n chart: {\n height: DONUT_CHART_HEIGHT,\n spacing: [0, 0, 0, 0],\n },\n plotOptions: {\n pie: {\n animation: false,\n borderRadius: 0, // must be handled here instead of css because of path rendering\n dataLabels: {\n enabled: false,\n },\n innerSize: \"50%\",\n },\n },\n});\n","import { css, createGlobalStyle } from \"styled-components\";\nimport { theme } from \"@sproutsocial/seeds-react-theme\";\nimport {\n type TypeChartStyleColor,\n type TypeChartStyleHasOnClick,\n type TypeChartStylePattern,\n} from \"../types\";\nimport \"highcharts/css/highcharts.css\";\n\nexport const GlobalChartStyleOverrides = createGlobalStyle`\n // USAGE NOTE:\n // Put general styles in baseChartStyles instead when possible to avoid excessive global styling.\n // This global component is only for styles that can't override highcharts defaults when scoped.\n\n .highcharts-tooltip-container {\n z-index: 7 !important;\n }\n .highcharts-tooltip-box {\n fill: transparent !important;\n }\n`;\n\n// options that should apply to all charts\nexport const baseChartStyles = css<\n Readonly<{ $colors: ReadonlyArray<TypeChartStyleColor> }>\n>`\n --highcharts-background-color: ${({ theme }) =>\n theme.colors.container.background.base};\n\n // set color variables and map to each series\n ${({ $colors }) =>\n $colors\n .map((color, index) => {\n const chartColor = color || theme.colors.DATAVIZ_COLORS_LIST[index];\n return `\n\t\t\t\t// map colors to custom assigned colors or fallback to default data viz color rotation\n\t\t\t\t--highcharts-color-${index}: ${chartColor};\n\n\t\t\t\t// highcharts already accounts for 10 series, but if we have more, we need to add them\n\t\t\t\t.highcharts-color-${index} {\n\t\t\t\t\tcolor: var(--highcharts-color-${index});\n\t\t\t\t\tstroke: var(--highcharts-color-${index});\n\t\t\t\t\tfill: var(--highcharts-color-${index});\n\t\t\t\t}`;\n })\n .join(\"\\n\")}\n\n // set overall chart background color\n .highcharts-background {\n fill: ${({ theme }) => theme.colors.container.background.base};\n }\n\n g.highcharts-annotation-label {\n display: none;\n }\n\n div.highcharts-annotation-label {\n top: 0 !important;\n transform: translateX(-50%); // centers the label on the targeted axis point\n pointer-events: none; // prevents tooltip hover from being interrupted by this element since it renders after on the dom\n }\n`;\n\n// options that should apply to time series charts\nexport const timeSeriesChartStyles = css<\n Readonly<{\n $colors: ReadonlyArray<TypeChartStyleColor>;\n $hasOnClick: TypeChartStyleHasOnClick;\n }>\n>`\n ${baseChartStyles}\n\n // vertical crosshair styles\n\t.highcharts-crosshair {\n stroke: ${({ theme }) => theme.colors.container.border.decorative.neutral};\n stroke-width: 1;\n }\n\n // axis and gridline styles\n .highcharts-grid-line {\n stroke: ${({ theme }) => theme.colors.container.border.base};\n }\n\n .highcharts-axis-line {\n stroke: ${({ theme }) => theme.colors.container.border.base};\n }\n\n .highcharts-tick {\n stroke: none;\n }\n .highcharts-xaxis-labels,\n .highcharts-yaxis-labels {\n > span {\n font-family: ${({ theme }) => theme.fontFamily};\n ${({ theme }) => theme.typography[100]};\n font-weight: ${({ theme }) => theme.fontWeights.normal};\n color: ${({ theme }) => theme.colors.text.subtext};\n }\n }\n .highcharts-xaxis-labels {\n > span {\n display: flex;\n flex-direction: column;\n align-items: center;\n > span:nth-of-type(2) {\n font-weight: ${({ theme }) => theme.fontWeights.semibold};\n }\n }\n }\n\n // we don't want to drop the opacity when another item is hovered\n .highcharts-series-inactive {\n opacity: 1;\n }\n\n // apply cursor pointer when click functionality is turned on\n ${({ $hasOnClick }) =>\n $hasOnClick &&\n `\n \t\t\t.highcharts-series,\n \t\t\t.highcharts-point {\n \t\t\t\tcursor: pointer;\n \t\t\t}\n \t\t\t.highcharts-plot-background,\n \t\t\t.highcharts-crosshair,\n \t\t\t.highcharts-grid-line {\n \t\t\t\tfill: transparent;\n \t\t\t\tcursor: pointer;\n \t\t}`}\n\n path.highcharts-plot-line.y-axis-zero-line {\n stroke: ${({ theme }) => theme.colors.container.border.decorative.neutral};\n }\n`;\n\n// options that should apply to line charts\nexport const lineChartStyles = css<\n Readonly<{\n $colors: ReadonlyArray<TypeChartStyleColor>;\n $patterns: ReadonlyArray<TypeChartStylePattern>;\n $hasOnClick: TypeChartStyleHasOnClick;\n }>\n>`\n ${timeSeriesChartStyles}\n\n // set the line stroke\n\t.highcharts-graph {\n stroke-width: 3;\n }\n\n // dashed line styles\n ${({ $patterns }) =>\n $patterns.map((pattern, index) => {\n return pattern === \"dashed\"\n ? `\n \t\t\t\t\t// highcharts already accounts for 10 series, but if we have more, we need to add them\n \t\t\t\t\t.highcharts-series-${index} {\n \t\t\t\t\t\tstroke-dasharray: 2, 8;\n \t\t\t\t\t}`\n : \"\";\n })}\n`;\n\n// options that should apply to area charts\nexport const areaChartStyles = css`\n ${timeSeriesChartStyles}\n\n // don't need to show a stroke for the line part of each area\n\t.highcharts-graph {\n stroke-width: 0;\n }\n\n // fill areas to full opacity\n .highcharts-area {\n fill-opacity: 1;\n }\n`;\n\n// options that should apply to donut charts\nexport const donutChartStyles = css<\n Readonly<{\n $colors: ReadonlyArray<TypeChartStyleColor>;\n $hasOnClick: TypeChartStyleHasOnClick;\n }>\n>`\n ${baseChartStyles}\n\n // remove 250ms fade in/out when hovering over different donut chart slices\n\t.highcharts-point {\n transition: opacity 0s;\n }\n\n // remove stroke on donut slices\n .highcharts-pie-series .highcharts-point {\n stroke: none;\n }\n\n // don't reduce opacity when hovering\n .highcharts-point-hover {\n fill-opacity: none;\n }\n\n // apply cursor pointer when click functionality is turned on\n ${({ $hasOnClick }) =>\n $hasOnClick &&\n `\n \t\t\t.highcharts-series,\n \t\t\t.highcharts-point {\n \t\t\t\tcursor: pointer;\n \t\t\t}\n \t\t\t.highcharts-plot-background,\n \t\t\t.highcharts-crosshair,\n \t\t\t.highcharts-grid-line {\n \t\t\t\tfill: transparent;\n \t\t\t\tcursor: pointer;\n \t\t}`}\n`;\n","import { memo } from \"react\";\nimport { Box } from \"@sproutsocial/seeds-react-box\";\nimport { Icon, type TypeIconName } from \"@sproutsocial/seeds-react-icon\";\nimport { Text } from \"@sproutsocial/seeds-react-text\";\nimport { ChartTooltipHeader } from \"../ChartTooltip\";\n\ntype TypeChartXAnnotationDetailsProps = Readonly<{\n iconName: TypeIconName;\n text: string;\n}>;\n\nexport const ChartXAnnotationDetails = memo<TypeChartXAnnotationDetailsProps>(\n ({ iconName, text }) => {\n return (\n <ChartTooltipHeader>\n <Box display=\"flex\" alignItems=\"center\" gap={300}>\n <Icon name={iconName} size=\"mini\" color=\"icon.base\" />\n <Text color=\"text.body\" fontSize={200}>\n {text}\n </Text>\n </Box>\n </ChartTooltipHeader>\n );\n }\n);\n","import { memo } from \"react\";\nimport { Box } from \"@sproutsocial/seeds-react-box\";\nimport { Icon, type TypeIconName } from \"@sproutsocial/seeds-react-icon\";\nimport ThemeProvider from \"@sproutsocial/seeds-react-theme-provider\";\n\ntype TypeChartXAnnotationMarkerProps = Readonly<{\n iconName: TypeIconName;\n}>;\n\nexport const ChartXAnnotationMarker = memo<TypeChartXAnnotationMarkerProps>(\n ({ iconName }) => {\n return (\n <Box display=\"flex\" flexDirection=\"column\" alignItems=\"center\" gap={200}>\n <Box\n display=\"flex\"\n alignItems=\"center\"\n justifyContent=\"center\"\n width=\"20px\"\n height=\"20px\"\n bg=\"icon.base\"\n borderRadius=\"50%\"\n >\n <Icon name={iconName} size=\"mini\" color=\"icon.inverse\" />\n </Box>\n {/* Marker line height is hard coded for simplicity since chart height is hard coded. If that changes, we'll need to make this dynamic */}\n <Box height={`199px`} width=\"0.5px\" bg=\"neutral.200\" />\n </Box>\n );\n }\n);\n","import { memo, useState, useEffect, useCallback, type ReactNode } from \"react\";\nimport Highcharts, { type Chart, type Options } from \"highcharts\";\nimport { HighchartsReact } from \"highcharts-react-official\";\nimport highchartsAccessibility from \"highcharts/modules/accessibility\";\nimport styled from \"styled-components\";\nimport { Box } from \"@sproutsocial/seeds-react-box\";\n\nimport { DonutChartLegend } from \"./components/DonutChartLegend\";\nimport { DonutChartTooltip } from \"./components/DonutChartTooltip\";\nimport { transformDonutChartTooltipData } from \"./helpers/transformDonutChartTooltipData\";\n\nimport {\n ChartTooltipPortal,\n generateChartTooltipPortalId,\n} from \"../ChartTooltip/components/ChartTooltipPortal\";\nimport { donutChartOptions } from \"../../constants/chartOptions\";\nimport { GlobalChartStyleOverrides, donutChartStyles } from \"../../styles\";\nimport type { TypeChartDataStyles, TypeChartNumberFormat } from \"../../types\";\nimport { theme } from \"@sproutsocial/seeds-react-theme\";\n\n// init modules\nhighchartsAccessibility(Highcharts);\n\n// styled components\nconst StyledBox = styled(Box)`\n ${donutChartStyles}\n`;\n\n// types\nexport type TypeDonutChartTooltipProps = Readonly<{\n color: string;\n name: string;\n percent: number | null;\n value: number | null;\n // optional\n icon?: ReactNode;\n}>;\n\nexport type TypeDonutChartDataItem = Readonly<{\n name: string;\n value: number;\n // optional\n key?: string;\n icon?: ReactNode;\n styles?: TypeChartDataStyles;\n}>;\n\nexport type TypeDonutChartProps = Readonly<{\n data: ReadonlyArray<TypeDonutChartDataItem>;\n numberLocale: Intl.LocalesArgument;\n textLocale: Intl.LocalesArgument;\n // optional\n currency?: string;\n disableTooltips?: boolean;\n hideLegend?: boolean;\n numberFormat?: TypeChartNumberFormat;\n tooltip?: ({\n color,\n name,\n percent,\n value,\n }: TypeDonutChartTooltipProps) => ReactNode;\n onClick?: (data: Readonly<{ x: string } & TypeDonutChartDataItem>) => void;\n tooltipClickLabel?: ReactNode;\n}>;\n\nexport const DonutChart = memo<TypeDonutChartProps>(function DonutChart(\n props: TypeDonutChartProps\n) {\n const { data } = props;\n\n return data.length === 0 ? null : <DonutChartWithData {...props} />;\n});\n\nconst DonutChartWithData = memo<TypeDonutChartProps>(\n function DonutChartWithData({\n data,\n numberLocale = \"en-us\",\n textLocale = \"en-us\",\n // optional\n currency = \"USD\",\n disableTooltips = false,\n hideLegend = false,\n numberFormat = \"decimal\",\n tooltip,\n onClick,\n tooltipClickLabel,\n }: TypeDonutChartProps) {\n const [options, setOptions] = useState<Options>(donutChartOptions);\n const [chart, setChart] = useState<Chart | null>(null);\n\n const callback = useCallback((chartInstance: Chart) => {\n setChart(chartInstance);\n }, []);\n\n useEffect(() => {\n setOptions({\n accessibility: {\n point: {\n descriptionFormatter: function () {\n return \" \"; // space is necessary because empty string reverts to defaults\n },\n },\n },\n chart: {\n events: {\n render: function () {\n const allSlices = this.series[0]?.data ?? [];\n const tooltipId = generateChartTooltipPortalId(this.index);\n\n allSlices.forEach((slice) => {\n const sliceElement = slice?.graphic?.element;\n sliceElement?.setAttribute(\"aria-describedby\", tooltipId);\n\n // Update tooltip on focus\n sliceElement?.addEventListener(\"focus\", () => {\n slice.series.chart.tooltip.refresh(slice);\n });\n\n // Hide tooltip on blur\n sliceElement?.addEventListener(\"blur\", () => {\n slice.series.chart.tooltip.hide(0);\n });\n });\n },\n },\n },\n series: [\n {\n type: \"pie\",\n data: data.map((item, index) => {\n return {\n name: item.name,\n y: item.value,\n colorIndex: index,\n events: onClick\n ? {\n click: function () {\n onClick({ x: item.name, ...item });\n },\n }\n : undefined,\n };\n }),\n },\n ],\n tooltip: {\n enabled: !disableTooltips,\n },\n });\n }, [data]);\n\n const colors = data.map(\n (series, index) =>\n series.styles?.color ?? theme.colors.DATAVIZ_COLORS_LIST[index] ?? \"\"\n );\n\n return (\n <>\n <GlobalChartStyleOverrides />\n <StyledBox\n $colors={colors}\n $hasOnClick={Boolean(onClick)}\n bg=\"container.background.base\"\n >\n <HighchartsReact\n highcharts={Highcharts}\n options={options}\n callback={callback}\n />\n {chart && !disableTooltips ? (\n <ChartTooltipPortal\n chart={chart}\n renderContent={(context) => {\n const { color, icon, name, percent, value } =\n transformDonutChartTooltipData({ context, data });\n\n return tooltip ? (\n tooltip({ color, icon, name, percent, value })\n ) : (\n <DonutChartTooltip\n color={color}\n currency={currency}\n icon={icon}\n name={name}\n numberFormat={numberFormat}\n numberLocale={numberLocale}\n percent={percent}\n textLocale={textLocale}\n value={value}\n onClick={onClick}\n tooltipClickLabel={tooltipClickLabel}\n />\n );\n }}\n />\n ) : null}\n {hideLegend ? null : (\n <Box mt={350}>\n <DonutChartLegend data={data} />\n </Box>\n )}\n </StyledBox>\n </>\n );\n }\n);\n","import { memo } from \"react\";\nimport { theme } from \"@sproutsocial/seeds-react-theme\";\n\nimport type { TypeDonutChartProps } from \"../DonutChart\";\nimport { ChartLegend, type TypeChartLegendProps } from \"../../ChartLegend\";\nimport { ChartLegendLabelContentWithIcon } from \"../../ChartLegend/components/ChartLegendLabelContentWithIcon\";\n\n// exported for testing\nexport const getDonutChartLegendLabels = ({\n data,\n}: Readonly<{\n data: TypeDonutChartProps[\"data\"];\n}>): TypeChartLegendProps[\"legendLabels\"] => {\n return data.map((slice, index) => ({\n content: (\n <ChartLegendLabelContentWithIcon icon={slice.icon}>\n {slice.name}\n </ChartLegendLabelContentWithIcon>\n ),\n color: slice.styles?.color || theme.colors.DATAVIZ_COLORS_LIST[index],\n }));\n};\n\ntype TypeDonutChartLegendProps = Readonly<{\n data: TypeDonutChartProps[\"data\"];\n}>;\n\nexport const DonutChartLegend = memo<TypeDonutChartLegendProps>(\n function DonutChartLegend({ data }: TypeDonutChartLegendProps) {\n return <ChartLegend legendLabels={getDonutChartLegendLabels({ data })} />;\n }\n);\n","import { memo } from \"react\";\nimport { Box } from \"@sproutsocial/seeds-react-box\";\nimport { Duration } from \"@sproutsocial/seeds-react-duration\";\nimport { Icon } from \"@sproutsocial/seeds-react-icon\";\nimport { Numeral } from \"@sproutsocial/seeds-react-numeral\";\nimport { Text } from \"@sproutsocial/seeds-react-text\";\n\nimport {\n ChartTooltip,\n ChartTooltipFooter,\n ChartTooltipTable,\n type TypeChartTooltipTableProps,\n} from \"../../ChartTooltip\";\nimport type {\n TypeDonutChartProps,\n TypeDonutChartTooltipProps as TypeDonutTooltipProps,\n} from \"../../DonutChart\";\nimport { ChartLegendLabel } from \"../../ChartLegend/components/ChartLegendLabel\";\nimport { ChartLegendLabelContentWithIcon } from \"../../ChartLegend/components/ChartLegendLabelContentWithIcon\";\n\nexport type TypeDonutChartTooltipProps = Readonly<{\n color: TypeDonutTooltipProps[\"color\"];\n name: TypeDonutTooltipProps[\"name\"];\n numberLocale: TypeDonutChartProps[\"numberLocale\"];\n percent: TypeDonutTooltipProps[\"percent\"];\n textLocale: TypeDonutChartProps[\"textLocale\"];\n value: TypeDonutTooltipProps[\"value\"];\n // optional\n currency?: TypeDonutChartProps[\"currency\"];\n icon?: TypeDonutTooltipProps[\"icon\"];\n numberFormat?: TypeDonutChartProps[\"numberFormat\"];\n onClick?: TypeDonutChartProps[\"onClick\"];\n tooltipClickLabel?: TypeDonutChartProps[\"tooltipClickLabel\"];\n}>;\n\nexport const DonutChartTooltip = memo<TypeDonutChartTooltipProps>(\n function DonutChartTooltip({\n color,\n name,\n numberLocale,\n percent,\n textLocale,\n value,\n currency,\n icon,\n numberFormat,\n onClick,\n tooltipClickLabel,\n }: TypeDonutChartTooltipProps) {\n const rows = [\n {\n cells: [\n {\n content: (\n <ChartLegendLabel color={color}>\n <ChartLegendLabelContentWithIcon icon={icon}>\n <Text aria-label={`${name}: `}>{name}</Text>\n </ChartLegendLabelContentWithIcon>\n </ChartLegendLabel>\n ),\n },\n {\n content: (\n <Box display=\"inline-flex\" alignItems=\"center\" gap={350}>\n <Numeral\n number={percent}\n format=\"percent\"\n abbreviate={false}\n locale={numberLocale as string}\n />\n <Text fontWeight=\"semibold\">\n {numberFormat === \"duration\" ? (\n <Duration locale={textLocale} milliseconds={value} />\n ) : (\n <Numeral\n abbreviate={false}\n currency={currency}\n format={numberFormat}\n locale={numberLocale as string}\n number={value}\n />\n )}\n </Text>\n </Box>\n ),\n align: \"right\",\n },\n ],\n },\n ];\n\n return (\n <ChartTooltip>\n <ChartTooltipTable rows={rows as TypeChartTooltipTableProps[\"rows\"]} />\n {onClick && tooltipClickLabel ? (\n <ChartTooltipFooter>\n {typeof tooltipClickLabel === \"string\" ? (\n <Box display=\"flex\" alignItems=\"center\" gap={300}>\n <Icon name=\"hand-pointer-clicking-outline\" color=\"icon.base\" />\n <Text color=\"text.subtext\" fontSize={200}>\n {tooltipClickLabel}\n </Text>\n </Box>\n ) : (\n tooltipClickLabel\n )}\n </ChartTooltipFooter>\n ) : null}\n </ChartTooltip>\n );\n }\n);\n","import type { TooltipFormatterContextObject } from \"highcharts\";\nimport { theme } from \"@sproutsocial/seeds-react-theme\";\n\nimport type {\n TypeDonutChartProps,\n TypeDonutChartTooltipProps,\n} from \"../DonutChart\";\n\ntype TypeTransformDonutChartTooltipDataProps = Readonly<{\n context: TooltipFormatterContextObject;\n data: TypeDonutChartProps[\"data\"];\n}>;\ntype TypeTransformDonutChartTooltipDataReturn = TypeDonutChartTooltipProps;\n\nexport const transformDonutChartTooltipData = ({\n context,\n data,\n}: TypeTransformDonutChartTooltipDataProps): TypeTransformDonutChartTooltipDataReturn => {\n const colorIndex = context.colorIndex;\n\n return {\n color:\n data[colorIndex]?.styles?.color ??\n theme.colors.DATAVIZ_COLORS_LIST[colorIndex] ??\n \"\",\n ...(data[colorIndex]?.icon ? { icon: data[colorIndex]?.icon } : {}),\n name: context.key as string,\n percent: context.percentage,\n value: context.y as number,\n };\n};\n","import { memo } from \"react\";\nimport { Box } from \"@sproutsocial/seeds-react-box\";\nimport { Duration } from \"@sproutsocial/seeds-react-duration\";\nimport { Numeral } from \"@sproutsocial/seeds-react-numeral\";\nimport { Text } from \"@sproutsocial/seeds-react-text\";\nimport { theme } from \"@sproutsocial/seeds-react-theme\";\n\nimport type { TypeDonutChartProps } from \"..\";\nimport { ChartTable, type TypeChartTableProps } from \"../../ChartTable\";\nimport { ChartLegendLabel } from \"../../ChartLegend/components/ChartLegendLabel\";\nimport { ChartLegendLabelContentWithIcon } from \"../../ChartLegend/components/ChartLegendLabelContentWithIcon\";\n\nexport type TypeDonutChartLegendTableProps = Readonly<{\n data: TypeDonutChartProps[\"data\"];\n numberLocale: TypeDonutChartProps[\"numberLocale\"];\n textLocale: TypeDonutChartProps[\"textLocale\"];\n totalLabel: React.ReactNode;\n // optional\n currency?: TypeDonutChartProps[\"currency\"];\n numberFormat?: TypeDonutChartProps[\"numberFormat\"];\n}>;\n\nexport const DonutChartLegendTable = memo<TypeDonutChartLegendTableProps>(\n function DonutChartLegendTable({\n data,\n numberLocale = \"en-us\",\n textLocale = \"en-us\",\n totalLabel,\n // optional\n currency = \"USD\",\n numberFormat = \"decimal\",\n }: TypeDonutChartLegendTableProps) {\n const total = data.reduce(\n (accumulator, dataItem) => accumulator + dataItem.value,\n 0\n );\n\n const rows = data.map((dataPoint, index) => {\n const { name, icon, styles, value } = dataPoint;\n const color = styles?.color || theme.colors.DATAVIZ_COLORS_LIST[index];\n\n return {\n cells: [\n {\n content: (\n <ChartLegendLabel color={color}>\n <ChartLegendLabelContentWithIcon icon={icon}>\n {name}\n </ChartLegendLabelContentWithIcon>\n </ChartLegendLabel>\n ),\n },\n {\n content: (\n <Box display=\"inline-flex\" alignItems=\"center\" gap={350}>\n <Text color=\"text.body\">\n <Numeral\n abbreviate={false}\n format=\"percent\"\n locale={numberLocale as string}\n number={(value / total) * 100}\n />\n </Text>\n <Text color=\"text.body\" fontWeight=\"semibold\">\n {numberFormat === \"duration\" ? (\n <Duration locale={textLocale} milliseconds={value} />\n ) : (\n <Numeral\n abbreviate={false}\n currency={currency}\n format={numberFormat}\n locale={numberLocale as string}\n number={value}\n />\n )}\n </Text>\n </Box>\n ),\n align: \"right\",\n },\n ],\n };\n });\n\n const totalRow = [\n {\n cells: [\n {\n content: (\n <Text fontWeight=\"semibold\" color=\"text.headline\">\n {totalLabel}\n </Text>\n ),\n },\n {\n content: (\n <Text color=\"text.body\" fontWeight=\"bold\">\n {numberFormat === \"duration\" ? (\n <Duration locale={textLocale} milliseconds={total} />\n ) : (\n <Numeral\n abbreviate={false}\n currency={currency}\n format={numberFormat}\n locale={numberLocale as string}\n number={total}\n />\n )}\n </Text>\n ),\n align: \"right\",\n },\n ],\n isAppendedRow: true,\n },\n ];\n\n return (\n <ChartTable\n rows={[...rows, ...totalRow] as TypeChartTableProps[\"rows\"]}\n />\n );\n }\n);\n","import { memo, type ReactNode } from \"react\";\nimport Highcharts, { type AnnotationsOptions } from \"highcharts\";\nimport { HighchartsReact } from \"highcharts-react-official\";\nimport highchartsAccessibility from \"highcharts/modules/accessibility\";\nimport highchartsAnnotations from \"highcharts/modules/annotations\";\nimport styled from \"styled-components\";\nimport { Box } from \"@sproutsocial/seeds-react-box\";\n\nimport { LineChartLegend } from \"./components/LineChartLegend\";\nimport { LineChartTooltip } from \"./components/LineChartTooltip\";\n\nimport { ChartTooltipPortal } from \"../ChartTooltip/components/ChartTooltipPortal\";\nimport { transformTimeSeriesTooltipData } from \"../../helpers\";\nimport { useTimeSeriesChartOptions } from \"../../hooks\";\nimport { GlobalChartStyleOverrides, lineChartStyles } from \"../../styles\";\nimport type {\n TypeChartDataPoint,\n TypeChartDataStyles,\n TypeChartNumberFormat,\n TypeChartStyleColor,\n TypeChartStylePattern,\n TypeChartTimeFormat,\n TypeChartTooltipDateFormatter,\n TypeChartTooltipProps,\n TypeChartYAxisLabelFormatter,\n TypeChartXAnnotations,\n} from \"../../types\";\nimport { theme } from \"@sproutsocial/seeds-react-theme\";\nimport { ChartXAnnotationMarkerPortal } from \"../ChartXAnnotationMarker/components/ChartXAnnotationMarkerPortal\";\n\n// init modules\nhighchartsAccessibility(Highcharts);\nhighchartsAnnotations(Highcharts);\n\n// styled components\nconst StyledBox = styled(Box)`\n ${lineChartStyles}\n`;\n\n// types\nexport type TypeLineChartProps = Readonly<{\n data: ReadonlyArray<\n Readonly<{\n name: string;\n points: ReadonlyArray<TypeChartDataPoint>;\n // optional\n icon?: ReactNode;\n styles?: TypeChartDataStyles &\n Readonly<{ pattern?: TypeChartStylePattern }>;\n }>\n >;\n invalidNumberLabel: ReactNode;\n numberLocale: Intl.LocalesArgument;\n textLocale: Intl.LocalesArgument;\n tooltipDateFormatter: TypeChartTooltipDateFormatter;\n // optional\n currency?: string;\n disableTooltips?: boolean;\n numberFormat?: TypeChartNumberFormat;\n tooltip?: ({ data, x }: TypeChartTooltipProps) => ReactNode;\n yAxisLabelFormatter?: TypeChartYAxisLabelFormatter;\n onClick?: ({ x }: Readonly<{ x: number }>) => void;\n tooltipClickLabel?: ReactNode;\n timeFormat?: TypeChartTimeFormat;\n xAnnotations?: TypeChartXAnnotations;\n xAxisLabelFormatter?: (params: {\n textLocale: Intl.LocalesArgument;\n tickPositions: number[];\n unitName: string;\n value: string | number;\n timeFormat?: string;\n }) => string;\n}>;\n\nexport const LineChart = memo<TypeLineChartProps>(function LineChart(\n props: TypeLineChartProps\n) {\n const { data } = props;\n\n return data.length === 0 ? null : <LineChartWithData {...props} />;\n});\n\nconst LineChartWithData = memo<TypeLineChartProps>(function LineChartWithData({\n data,\n invalidNumberLabel,\n numberLocale = \"en-us\",\n textLocale = \"en-us\",\n tooltipDateFormatter,\n // optional\n currency = \"USD\",\n disableTooltips = false,\n numberFormat = \"decimal\",\n tooltip,\n yAxisLabelFormatter,\n onClick,\n tooltipClickLabel,\n timeFormat = \"12\",\n xAnnotations,\n xAxisLabelFormatter,\n}: TypeLineChartProps) {\n const { options, chart, callback } = useTimeSeriesChartOptions({\n currency,\n data,\n disableTooltips,\n numberFormat,\n numberLocale,\n seriesType: \"spline\",\n textLocale,\n yAxisLabelFormatter,\n onClick,\n timeFormat,\n xAnnotations,\n xAxisLabelFormatter,\n });\n\n const { colors, patterns } = data.reduce(\n (acc, item, index) => {\n // @ts-ignore\n acc.colors.push(\n item.styles?.color ?? theme.colors.DATAVIZ_COLORS_LIST[index] ?? \"\"\n );\n acc.patterns.push(item.styles?.pattern ?? \"solid\");\n return acc;\n },\n {\n colors: [] as TypeChartStyleColor[],\n patterns: [] as TypeChartStylePattern[],\n }\n );\n\n return (\n <>\n <GlobalChartStyleOverrides />\n <StyledBox\n $colors={colors}\n $patterns={patterns}\n $hasOnClick={Boolean(onClick)}\n bg=\"container.background.base\"\n >\n <HighchartsReact\n highcharts={Highcharts}\n options={options}\n callback={callback}\n />\n {chart && chart.annotations?.length ? (\n <ChartXAnnotationMarkerPortal\n xAnnotations={xAnnotations}\n annotationContext={chart.annotations?.[0] as AnnotationsOptions}\n />\n ) : null}\n {chart && !disableTooltips ? (\n <ChartTooltipPortal\n chart={chart}\n renderContent={(context) => {\n const tooltipData = transformTimeSeriesTooltipData({\n context,\n data,\n });\n const x = context.x as number;\n\n const xAnnotationDetails = xAnnotations?.[x]?.details;\n\n return tooltip ? (\n tooltip({ data: tooltipData, x })\n ) : (\n <LineChartTooltip\n currency={currency}\n data={tooltipData}\n invalidNumberLabel={invalidNumberLabel}\n numberFormat={numberFormat}\n numberLocale={numberLocale}\n textLocale={textLocale}\n tooltipDateFormatter={tooltipDateFormatter}\n onClick={onClick}\n tooltipClickLabel={tooltipClickLabel}\n x={x}\n xAnnotationDetails={xAnnotationDetails}\n />\n );\n }}\n />\n ) : null}\n <Box mt={350}>\n <LineChartLegend data={data} />\n </Box>\n </StyledBox>\n </>\n );\n});\n","import { memo } from \"react\";\nimport { theme } from \"@sproutsocial/seeds-react-theme\";\n\nimport type { TypeLineChartProps } from \"../LineChart\";\nimport { ChartLegend, type TypeChartLegendProps } from \"../../ChartLegend\";\nimport { ChartLegendLabelContentWithIcon } from \"../../ChartLegend/components/ChartLegendLabelContentWithIcon\";\n\n// exported for testing\nexport const getLineChartLegendLabels = ({\n data,\n}: Readonly<{\n data: TypeLineChartProps[\"data\"];\n}>): TypeChartLegendProps[\"legendLabels\"] => {\n return data.map((series, index) => ({\n content: (\n <ChartLegendLabelContentWithIcon icon={series.icon}>\n {series.name}\n </ChartLegendLabelContentWithIcon>\n ),\n color: series.styles?.color || theme.colors.DATAVIZ_COLORS_LIST[index],\n }));\n};\n\ntype TypeLineChartLegendProps = Readonly<{\n data: TypeLineChartProps[\"data\"];\n}>;\n\nexport const LineChartLegend = memo<TypeLineChartLegendProps>(\n function LineChartLegend({ data }: TypeLineChartLegendProps) {\n return <ChartLegend legendLabels={getLineChartLegendLabels({ data })} />;\n }\n);\n","import { memo } from \"react\";\nimport { Box } from \"@sproutsocial/seeds-react-box\";\nimport { Duration } from \"@sproutsocial/seeds-react-duration\";\nimport { Icon } from \"@sproutsocial/seeds-react-icon\";\nimport { Numeral } from \"@sproutsocial/seeds-react-numeral\";\nimport { Text } from \"@sproutsocial/seeds-react-text\";\n\nimport type { TypeLineChartProps } from \"../LineChart\";\n\nimport {\n ChartTooltip,\n ChartTooltipFooter,\n ChartTooltipTable,\n ChartTooltipTitle,\n type TypeChartTooltipTableProps,\n} from \"../../ChartTooltip\";\nimport type {\n TypeChartTooltipProps,\n TypeChartXAnnotationsDetails,\n} from \"../../../types\";\nimport { ChartLegendLabel } from \"../../ChartLegend/components/ChartLegendLabel\";\nimport { ChartLegendLabelContentWithIcon } from \"../../ChartLegend/components/ChartLegendLabelContentWithIcon\";\n\nexport type TypeLineChartTooltipProps = Readonly<{\n data: TypeChartTooltipProps[\"data\"];\n invalidNumberLabel: TypeLineChartProps[\"invalidNumberLabel\"];\n numberLocale: TypeLineChartProps[\"numberLocale\"];\n textLocale: TypeLineChartProps[\"textLocale\"];\n tooltipDateFormatter: TypeLineChartProps[\"tooltipDateFormatter\"];\n x: TypeChartTooltipProps[\"x\"];\n // optional\n currency?: TypeLineChartProps[\"currency\"];\n numberFormat?: TypeLineChartProps[\"numberFormat\"];\n onClick?: TypeLineChartProps[\"onClick\"];\n tooltipClickLabel?: TypeLineChartProps[\"tooltipClickLabel\"];\n xAnnotationDetails?: TypeChartXAnnotationsDetails;\n}>;\n\nexport const LineChartTooltip = memo<TypeLineChartTooltipProps>(\n function LineChartTooltip({\n data,\n invalidNumberLabel,\n numberLocale,\n textLocale,\n tooltipDateFormatter,\n x,\n // optional\n currency = \"USD\",\n numberFormat = \"decimal\",\n onClick,\n tooltipClickLabel,\n xAnnotationDetails,\n }: TypeLineChartTooltipProps) {\n const rows = data.map(({ color, icon, name, value }) => {\n return {\n cells: [\n {\n content: (\n <ChartLegendLabel color={color}>\n <ChartLegendLabelContentWithIcon icon={icon}>\n <Text aria-label={`${name}: `}>{name}</Text>\n </ChartLegendLabelContentWithIcon>\n </ChartLegendLabel>\n ),\n },\n {\n content:\n value === null && invalidNumberLabel ? (\n <Text>{invalidNumberLabel}</Text>\n ) : numberFormat === \"duration\" ? (\n <Duration locale={textLocale} milliseconds={value} />\n ) : (\n <Numeral\n abbreviate={false}\n currency={currency}\n format={numberFormat}\n locale={numberLocale as string}\n number={value}\n />\n ),\n align: \"right\",\n },\n ],\n };\n });\n\n return (\n <ChartTooltip>\n {xAnnotationDetails ? xAnnotationDetails() : undefined}\n <ChartTooltipTitle>{tooltipDateFormatter({ x })}</ChartTooltipTitle>\n <ChartTooltipTable rows={rows as TypeChartTooltipTableProps[\"rows\"]} />\n {onClick && tooltipClickLabel ? (\n <ChartTooltipFooter>\n {typeof tooltipClickLabel === \"string\" ? (\n <Box display=\"flex\" alignItems=\"center\" gap={300}>\n <Icon name=\"hand-pointer-clicking-outline\" color=\"icon.base\" />\n <Text color=\"text.subtext\" fontSize={200}>\n {tooltipClickLabel}\n </Text>\n </Box>\n ) : (\n tooltipClickLabel\n )}\n </ChartTooltipFooter>\n ) : null}\n </ChartTooltip>\n );\n }\n);\n","import { memo, type ReactNode } from \"react\";\nimport Highcharts, { type AnnotationsOptions } from \"highcharts\";\nimport { HighchartsReact } from \"highcharts-react-official\";\nimport highchartsAccessibility from \"highcharts/modules/accessibility\";\nimport highchartsAnnotations from \"highcharts/modules/annotations\";\nimport styled from \"styled-components\";\nimport { Box } from \"@sproutsocial/seeds-react-box\";\n\nimport { VerticalBarChartLegend } from \"./components/VerticalBarChartLegend\";\nimport { VerticalBarChartTooltip } from \"./components/VerticalBarChartTooltip\";\n\nimport { ChartTooltipPortal } from \"../ChartTooltip/components/ChartTooltipPortal\";\nimport {\n transformTimeSeriesTooltipData,\n isHourlyTimeData,\n isCategoricalHourData,\n} from \"../../helpers\";\nimport { useTimeSeriesChartOptions } from \"../../hooks\";\nimport { GlobalChartStyleOverrides } from \"../../styles\";\nimport type {\n TypeChartStyleColor,\n TypeChartStylePattern,\n TypeVerticalBarChartProps,\n} from \"../../types\";\nimport { theme } from \"@sproutsocial/seeds-react-theme\";\nimport { ChartXAnnotationMarkerPortal } from \"../ChartXAnnotationMarker/components/ChartXAnnotationMarkerPortal\";\nimport { verticalBarChartStyles } from \"./styles\";\nimport { VERTICAL_BAR_CHART_DEFAULT_SERIES_LIMIT } from \"../../constants\";\n\n// init modules\nhighchartsAccessibility(Highcharts);\nhighchartsAnnotations(Highcharts);\n\n// styled components\nconst StyledBox = styled(Box)`\n ${verticalBarChartStyles}\n`;\n\nexport const VerticalBarChart = memo<TypeVerticalBarChartProps>(\n function VerticalBarChart(props: TypeVerticalBarChartProps) {\n const { data, showSeriesLimitWarning = true } = props;\n const seriesLimit =\n props.seriesLimit ?? VERTICAL_BAR_CHART_DEFAULT_SERIES_LIMIT;\n const isSeriesLimitOverridden = props.seriesLimit !== undefined;\n\n if (data.length === 0) {\n return null;\n }\n\n let chartData = data;\n if (data.length > seriesLimit) {\n if (!isSeriesLimitOverridden && showSeriesLimitWarning) {\n console.warn(\n `VerticalBarChart: Maximum number of series (${seriesLimit}) exceeded. Only the first ${seriesLimit} series will be displayed.`\n );\n }\n chartData = data.slice(0, seriesLimit);\n }\n\n return <VerticalBarChartWithData {...props} data={chartData} />;\n }\n);\n\nconst VerticalBarChartWithData = memo<TypeVerticalBarChartProps>(\n function VerticalBarChartWithData({\n data,\n invalidNumberLabel,\n numberLocale = \"en-us\",\n textLocale = \"en-us\",\n tooltipDateFormatter,\n // optional\n currency = \"USD\",\n numberFormat = \"decimal\",\n tooltip,\n yAxisLabelFormatter,\n onClick,\n tooltipClickLabel,\n timeFormat = \"12\",\n xAnnotations,\n xAxisLabelFormatter,\n }: TypeVerticalBarChartProps) {\n // Automatically use time-of-day formatter if data is hourly (timestamp) or categorical hour data\n const shouldUseTimeFormatter =\n isHourlyTimeData(data) || isCategoricalHourData(data);\n\n const autoTimeXAxisLabelFormatter = ({\n value,\n timeFormat,\n }: {\n textLocale: Intl.LocalesArgument;\n tickPositions: number[];\n unitName: string;\n value: string | number;\n timeFormat?: string;\n }) => {\n // Handle categorical hour data (strings)\n if (typeof value === \"string\") {\n // Handle 12-hour format (e.g., \"12 AM\", \"1 PM\")\n const hour12Match = value.match(/^(\\d{1,2}) (AM|PM)$/);\n if (hour12Match) {\n const [, hourStr = \"0\", period = \"\"] = hour12Match;\n const hour = parseInt(hourStr, 10);\n if (hour === 12) return `<span>12</span><span>${period}</span>`;\n return `<span>${hour}</span>`;\n }\n\n // Handle 24-hour format (e.g., \"00:00\", \"13:00\", \"23:00\")\n const hour24Match = value.match(/^([01]?\\d|2[0-3]):([0-5]\\d)$/);\n if (hour24Match) {\n const [, hourStr = \"0\"] = hour24Match;\n const hour = parseInt(hourStr, 10);\n\n if (timeFormat === \"24\") {\n // For 24-hour format, just show the hour padded to 2 digits\n return `<span>${hour.toString().padStart(2, \"0\")}</span>`;\n } else {\n // For 12-hour display of 24-hour data, convert to 12-hour\n const displayHour = hour % 12 === 0 ? 12 : hour % 12;\n const period = hour < 12 ? \"AM\" : \"PM\";\n if (hour === 0 || hour === 12)\n return `<span>12</span><span>${period}</span>`;\n return `<span>${displayHour}</span>`;\n }\n }\n\n // Fallback: return original value if not recognized hour format\n return value;\n }\n\n // Handle numerical timestamp data\n const numValue = typeof value === \"string\" ? Number(value) : value;\n if (isNaN(numValue)) return \"\";\n const date = new Date(numValue);\n let hour = date.getUTCHours();\n let displayHour = hour % 12 === 0 ? 12 : hour % 12;\n if (hour === 0) return \"<span>12</span><span>AM</span>\";\n if (hour === 12) return \"<span>12</span><span>PM</span>\";\n return `<span>${displayHour}</span>`;\n };\n\n const resolvedXAxisLabelFormatter =\n shouldUseTimeFormatter && !xAxisLabelFormatter\n ? (params: {\n textLocale: Intl.LocalesArgument;\n tickPositions: number[];\n unitName: string;\n value: string | number;\n timeFormat?: string;\n }) => autoTimeXAxisLabelFormatter({ ...params, timeFormat })\n : xAxisLabelFormatter;\n\n const { options, chart, callback } = useTimeSeriesChartOptions({\n currency,\n data,\n numberFormat,\n numberLocale,\n // Although we call this chart vertical bar chart, highcharts uses the term \"column\"\n seriesType: \"column\",\n textLocale,\n yAxisLabelFormatter,\n onClick,\n timeFormat,\n xAnnotations,\n xAxisLabelFormatter: resolvedXAxisLabelFormatter,\n });\n\n const { colors, patterns } = data.reduce(\n (\n acc: {\n colors: TypeChartStyleColor[];\n patterns: TypeChartStylePattern[];\n },\n item,\n index\n ) => {\n acc.colors.push(\n item.styles?.color ?? theme.colors.DATAVIZ_COLORS_LIST[index] ?? \"\"\n );\n acc.patterns.push(item.styles?.pattern ?? \"solid\");\n return acc;\n },\n {\n colors: [] as TypeChartStyleColor[],\n patterns: [] as TypeChartStylePattern[],\n }\n );\n\n return (\n <>\n <GlobalChartStyleOverrides />\n <StyledBox\n $colors={colors}\n $hasOnClick={Boolean(onClick)}\n bg=\"container.background.base\"\n >\n <HighchartsReact\n highcharts={Highcharts}\n options={options}\n callback={callback}\n />\n {chart && chart.annotations?.length ? (\n <ChartXAnnotationMarkerPortal\n xAnnotations={xAnnotations}\n annotationContext={chart.annotations?.[0] as AnnotationsOptions}\n />\n ) : null}\n {chart ? (\n <ChartTooltipPortal\n chart={chart}\n renderContent={(context) => {\n const tooltipData = transformTimeSeriesTooltipData({\n context,\n data,\n });\n const x = context.x as number | string;\n\n const xAnnotationDetails =\n typeof x === \"number\"\n ? xAnnotations?.[x]?.details\n : undefined;\n\n return tooltip ? (\n tooltip({ data: tooltipData, x })\n ) : (\n <VerticalBarChartTooltip\n currency={currency}\n data={tooltipData}\n invalidNumberLabel={invalidNumberLabel}\n numberFormat={numberFormat}\n numberLocale={numberLocale}\n textLocale={textLocale}\n tooltipDateFormatter={tooltipDateFormatter}\n onClick={onClick}\n tooltipClickLabel={tooltipClickLabel}\n x={x}\n xAnnotationDetails={xAnnotationDetails}\n />\n );\n }}\n />\n ) : null}\n <Box mt={350}>\n <VerticalBarChartLegend data={data} />\n </Box>\n </StyledBox>\n </>\n );\n }\n);\n","import { memo } from \"react\";\nimport { theme } from \"@sproutsocial/seeds-react-theme\";\n\nimport type { TypeVerticalBarChartProps } from \"../../../types\";\nimport { ChartLegend, type TypeChartLegendProps } from \"../../ChartLegend\";\nimport { ChartLegendLabelContentWithIcon } from \"../../ChartLegend/components/ChartLegendLabelContentWithIcon\";\n\n// exported for testing\nexport const getVerticalBarChartLegendLabels = ({\n data,\n}: Readonly<{\n data: TypeVerticalBarChartProps[\"data\"];\n}>): TypeChartLegendProps[\"legendLabels\"] => {\n return data.map((series, index) => ({\n content: (\n <ChartLegendLabelContentWithIcon icon={series.icon}>\n {series.name}\n </ChartLegendLabelContentWithIcon>\n ),\n color: series.styles?.color || theme.colors.DATAVIZ_COLORS_LIST[index],\n }));\n};\n\ntype VerticalBarChartLegendProps = Readonly<{\n data: TypeVerticalBarChartProps[\"data\"];\n}>;\n\nexport const VerticalBarChartLegend = memo<VerticalBarChartLegendProps>(\n function VerticalbarChartLegend({ data }: VerticalBarChartLegendProps) {\n return (\n <ChartLegend legendLabels={getVerticalBarChartLegendLabels({ data })} />\n );\n }\n);\n","import { memo } from \"react\";\nimport { Box } from \"@sproutsocial/seeds-react-box\";\nimport { Duration } from \"@sproutsocial/seeds-react-duration\";\nimport { Icon } from \"@sproutsocial/seeds-react-icon\";\nimport { Numeral } from \"@sproutsocial/seeds-react-numeral\";\nimport { Text } from \"@sproutsocial/seeds-react-text\";\n\nimport type { TypeVerticalBarChartProps } from \"../../../types\";\n\nimport {\n ChartTooltip,\n ChartTooltipFooter,\n ChartTooltipTable,\n ChartTooltipTitle,\n type TypeChartTooltipTableProps,\n} from \"../../ChartTooltip\";\nimport type {\n TypeChartTooltipProps,\n TypeChartXAnnotationsDetails,\n} from \"../../../types\";\nimport { ChartLegendLabel } from \"../../ChartLegend/components/ChartLegendLabel\";\nimport { ChartLegendLabelContentWithIcon } from \"../../ChartLegend/components/ChartLegendLabelContentWithIcon\";\n\nexport type TypeVerticalBarChartTooltipProps = Readonly<{\n data: TypeChartTooltipProps[\"data\"];\n invalidNumberLabel: TypeVerticalBarChartProps[\"invalidNumberLabel\"];\n numberLocale: TypeVerticalBarChartProps[\"numberLocale\"];\n textLocale: TypeVerticalBarChartProps[\"textLocale\"];\n tooltipDateFormatter: TypeVerticalBarChartProps[\"tooltipDateFormatter\"];\n x: TypeChartTooltipProps[\"x\"];\n // optional\n currency?: TypeVerticalBarChartProps[\"currency\"];\n numberFormat?: TypeVerticalBarChartProps[\"numberFormat\"];\n onClick?: TypeVerticalBarChartProps[\"onClick\"];\n tooltipClickLabel?: TypeVerticalBarChartProps[\"tooltipClickLabel\"];\n xAnnotationDetails?: TypeChartXAnnotationsDetails;\n}>;\n\nexport const VerticalBarChartTooltip = memo<TypeVerticalBarChartTooltipProps>(\n function VerticalBarChartTooltip({\n data,\n invalidNumberLabel,\n numberLocale,\n textLocale,\n tooltipDateFormatter,\n x,\n // optional\n currency = \"USD\",\n numberFormat = \"decimal\",\n onClick,\n tooltipClickLabel,\n xAnnotationDetails,\n }: TypeVerticalBarChartTooltipProps) {\n const rows = data.map(({ color, icon, name, value }) => {\n return {\n cells: [\n {\n content: (\n <ChartLegendLabel color={color}>\n <ChartLegendLabelContentWithIcon icon={icon}>\n <Text aria-label={`${name}: `}>{name}</Text>\n </ChartLegendLabelContentWithIcon>\n </ChartLegendLabel>\n ),\n },\n {\n content:\n value === null && invalidNumberLabel ? (\n <Text>{invalidNumberLabel}</Text>\n ) : numberFormat === \"duration\" ? (\n <Duration locale={textLocale} milliseconds={value} />\n ) : (\n <Numeral\n abbreviate={false}\n currency={currency}\n format={numberFormat}\n locale={numberLocale as string}\n number={value}\n />\n ),\n align: \"right\",\n },\n ],\n };\n });\n\n return (\n <ChartTooltip>\n {xAnnotationDetails ? xAnnotationDetails() : undefined}\n <ChartTooltipTitle>{tooltipDateFormatter({ x })}</ChartTooltipTitle>\n <ChartTooltipTable rows={rows as TypeChartTooltipTableProps[\"rows\"]} />\n {onClick && tooltipClickLabel ? (\n <ChartTooltipFooter>\n {typeof tooltipClickLabel === \"string\" ? (\n <Box display=\"flex\" alignItems=\"center\" gap={300}>\n <Icon name=\"hand-pointer-clicking-outline\" color=\"icon.base\" />\n <Text color=\"text.subtext\" fontSize={200}>\n {tooltipClickLabel}\n </Text>\n </Box>\n ) : (\n tooltipClickLabel\n )}\n </ChartTooltipFooter>\n ) : null}\n </ChartTooltip>\n );\n }\n);\n","import { timeSeriesChartStyles } from \"../../styles/chartStyles\";\nimport { css } from \"styled-components\";\nimport type {\n TypeChartStyleColor,\n TypeChartStyleHasOnClick,\n} from \"../../types\";\n\n// options that should apply to line charts\nexport const verticalBarChartStyles = css<\n Readonly<{\n $colors: ReadonlyArray<TypeChartStyleColor>;\n $hasOnClick: TypeChartStyleHasOnClick;\n }>\n>`\n ${timeSeriesChartStyles}\n\n /*\n When the chart container is hovered, reduce the opacity of all columns.\n Then, for the column that is being hovered, restore its opacity.\n This gives the effect of fading out the non-hovered columns.\n */\n .highcharts-container:hover .highcharts-point {\n fill-opacity: 0.3;\n }\n\n .highcharts-point.column-hover {\n fill-opacity: 1 !important;\n }\n`;\n"],"mappings":"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","names":["memo","styled","Box","memo","theme","memo","Box","theme","styled","Box","jsx","props","theme","theme","jsx","jsx","styled","Box","theme","ChartLegendLabel","jsx","memo","ChartLegend","Box","theme","memo","Box","jsxs","ChartLegendLabelContentWithIcon","jsx","theme","memo","AreaChartLegend","memo","Box","Text","memo","styled","Box","jsx","StyledBox","ChartTooltip","memo","Box","jsx","ChartTooltipFooter","memo","Box","jsx","ChartTooltipHeader","memo","ChartTooltipPortal","memo","memo","styled","Text","jsx","theme","ChartTable","jsx","memo","ChartTooltipTable","memo","Text","jsx","ChartTooltipTitle","jsx","jsxs","memo","AreaChartTooltip","Text","Box","memo","useEffect","useState","useRef","createPortal","jsx","memo","ChartXAnnotationMarkerPortal","useRef","useState","useEffect","createPortal","theme","useState","yAxisLabelFormatter","xAxisLabelFormatter","useState","baseChartOptions","css","theme","css","theme","theme","Fragment","jsx","jsxs","StyledBox","styled","Box","memo","AreaChart","AreaChartWithData","yAxisLabelFormatter","memo","Box","Icon","Text","jsx","jsxs","memo","Box","Icon","Text","memo","Box","Icon","jsx","jsxs","memo","Box","Icon","memo","useState","useEffect","useCallback","Highcharts","HighchartsReact","highchartsAccessibility","styled","Box","memo","theme","jsx","theme","memo","DonutChartLegend","memo","Box","Duration","Icon","Numeral","Text","jsx","jsxs","memo","DonutChartTooltip","Text","Box","Numeral","Duration","Icon","theme","theme","Fragment","jsx","jsxs","highchartsAccessibility","Highcharts","StyledBox","styled","Box","memo","DonutChart","DonutChartWithData","useState","useCallback","useEffect","HighchartsReact","memo","Box","Duration","Numeral","Text","theme","jsx","jsxs","memo","DonutChartLegendTable","theme","Box","Text","Numeral","Duration","memo","Highcharts","HighchartsReact","highchartsAccessibility","highchartsAnnotations","styled","Box","memo","theme","jsx","theme","memo","LineChartLegend","memo","Box","Duration","Icon","Numeral","Text","jsx","jsxs","memo","LineChartTooltip","Text","Duration","Numeral","Box","Icon","theme","Fragment","jsx","jsxs","highchartsAccessibility","Highcharts","highchartsAnnotations","StyledBox","styled","Box","memo","LineChart","LineChartWithData","yAxisLabelFormatter","xAxisLabelFormatter","theme","HighchartsReact","memo","Highcharts","HighchartsReact","highchartsAccessibility","highchartsAnnotations","styled","Box","memo","theme","jsx","theme","memo","memo","Box","Duration","Icon","Numeral","Text","jsx","jsxs","memo","VerticalBarChartTooltip","Text","Duration","Numeral","Box","Icon","theme","css","Fragment","jsx","jsxs","highchartsAccessibility","Highcharts","highchartsAnnotations","StyledBox","styled","Box","memo","VerticalBarChart","VerticalBarChartWithData","yAxisLabelFormatter","xAxisLabelFormatter","timeFormat","hour","displayHour","theme","HighchartsReact"]}
|
|
1
|
+
{"version":3,"sources":["../../src/components/AreaChart/AreaChart.tsx","../../src/components/AreaChart/components/AreaChartLegend.tsx","../../src/components/ChartLegend/ChartLegend.tsx","../../src/components/ChartLegend/components/ChartLegendLabel.tsx","../../src/components/ColorBox/ColorBox.tsx","../../../seeds-react-theme-provider/src/index.tsx","../../src/components/ColorBox/DatavizColorBox.tsx","../../src/components/ColorBox/NetworkColorBox.tsx","../../src/components/ChartLegend/components/ChartLegendLabelContentWithIcon.tsx","../../src/components/AreaChart/components/AreaChartTooltip.tsx","../../src/components/ChartTooltip/ChartTooltip.tsx","../../src/components/ChartTooltip/components/ChartTooltipFooter.tsx","../../src/components/ChartTooltip/components/ChartTooltipHeader.tsx","../../src/components/ChartTooltip/components/ChartTooltipPortal.tsx","../../src/components/ChartTooltip/components/ChartTooltipTable.tsx","../../src/components/ChartTable/ChartTable.tsx","../../src/components/ChartTooltip/components/ChartTooltipTitle.tsx","../../src/components/ChartXAnnotationMarker/components/ChartXAnnotationMarkerPortal.tsx","../../src/helpers/transformDataToSeries.ts","../../src/helpers/transformTimeSeriesTooltipData.ts","../../src/helpers/yAxisLabelFormatter.ts","../../src/helpers/xAxisLabelFormatter.ts","../../src/helpers/isHourlyTimeData.ts","../../src/helpers/isCategoricalHourData.ts","../../src/helpers/getStorybookRandomColor.ts","../../src/helpers/getStorybookCategoricalData.ts","../../src/helpers/getStorybookSparseTimelineData.ts","../../src/hooks/useTimeSeriesChartOptions.ts","../../src/constants/chartOptions.ts","../../src/styles/chartStyles.ts","../../src/components/ChartXAnnotationDetails/ChartXAnnotationDetails.tsx","../../src/components/ChartXAnnotationMarker/ChartXAnnotationMarker.tsx","../../src/components/DonutChart/DonutChart.tsx","../../src/components/DonutChart/components/DonutChartLegend.tsx","../../src/components/DonutChart/components/DonutChartTooltip.tsx","../../src/components/DonutChart/helpers/transformDonutChartTooltipData.ts","../../src/components/DonutChart/components/DonutChartLegendTable.tsx","../../src/components/LineChart/LineChart.tsx","../../src/components/LineChart/components/LineChartLegend.tsx","../../src/components/LineChart/components/LineChartTooltip.tsx","../../src/components/VerticalBarChart/VerticalBarChart.tsx","../../src/components/VerticalBarChart/components/VerticalBarChartLegend.tsx","../../src/components/VerticalBarChart/components/VerticalBarChartTooltip.tsx","../../src/components/VerticalBarChart/styles.ts"],"sourcesContent":["import { memo, type ReactNode } from \"react\";\nimport Highcharts, { type AnnotationsOptions } from \"highcharts\";\nimport { HighchartsReact } from \"highcharts-react-official\";\nimport highchartsAccessibility from \"highcharts/modules/accessibility\";\nimport highchartsAnnotations from \"highcharts/modules/annotations\";\nimport styled from \"styled-components\";\nimport { Box } from \"@sproutsocial/seeds-react-box\";\n\nimport { AreaChartLegend } from \"./components/AreaChartLegend\";\nimport { AreaChartTooltip } from \"./components/AreaChartTooltip\";\n\nimport { ChartTooltipPortal } from \"../ChartTooltip/components/ChartTooltipPortal\";\nimport { ChartXAnnotationMarkerPortal } from \"../ChartXAnnotationMarker/components/ChartXAnnotationMarkerPortal\";\nimport { transformTimeSeriesTooltipData } from \"../../helpers\";\nimport { useTimeSeriesChartOptions } from \"../../hooks\";\nimport { areaChartStyles, GlobalChartStyleOverrides } from \"../../styles\";\nimport type {\n TypeChartDataPoint,\n TypeChartDataStyles,\n TypeChartNumberFormat,\n TypeChartTimeFormat,\n TypeChartTooltipDateFormatter,\n TypeChartTooltipProps,\n TypeChartYAxisLabelFormatter,\n TypeChartXAnnotations,\n} from \"../../types\";\nimport { theme } from \"@sproutsocial/seeds-react-theme\";\n\n// init modules\nhighchartsAccessibility(Highcharts);\nhighchartsAnnotations(Highcharts);\n\n// styled components\nconst StyledBox = styled(Box)`\n ${areaChartStyles}\n`;\n\n// types\nexport type TypeAreaChartProps = Readonly<{\n data: ReadonlyArray<\n Readonly<{\n name: string;\n points: ReadonlyArray<TypeChartDataPoint>;\n // optional\n icon?: ReactNode;\n styles?: TypeChartDataStyles;\n }>\n >;\n invalidNumberLabel: ReactNode;\n numberLocale: Intl.LocalesArgument;\n textLocale: Intl.LocalesArgument;\n tooltipDateFormatter: TypeChartTooltipDateFormatter;\n tooltipTotalLabel: ReactNode;\n // optional\n currency?: string;\n disableTooltips?: boolean;\n numberFormat?: TypeChartNumberFormat;\n tooltip?: ({\n data,\n total,\n x,\n }: TypeChartTooltipProps & Readonly<{ total: number | null }>) => ReactNode;\n yAxisLabelFormatter?: TypeChartYAxisLabelFormatter;\n onClick?: ({ x }: Readonly<{ x: number }>) => void;\n tooltipClickLabel?: ReactNode;\n timeFormat?: TypeChartTimeFormat;\n xAnnotations?: TypeChartXAnnotations;\n}>;\n\nexport const AreaChart = memo<TypeAreaChartProps>(function AreaChart(\n props: TypeAreaChartProps\n) {\n const { data } = props;\n\n return data.length === 0 ? null : <AreaChartWithData {...props} />;\n});\n\nconst AreaChartWithData = memo<TypeAreaChartProps>(function AreaChartWithData({\n data,\n invalidNumberLabel,\n numberLocale = \"en-us\",\n textLocale = \"en-us\",\n tooltipDateFormatter,\n tooltipTotalLabel,\n // optional\n currency = \"USD\",\n disableTooltips = false,\n numberFormat = \"decimal\",\n tooltip,\n yAxisLabelFormatter,\n onClick,\n tooltipClickLabel,\n timeFormat = \"12\",\n xAnnotations,\n}: TypeAreaChartProps) {\n const { options, chart, callback } = useTimeSeriesChartOptions({\n currency,\n data,\n disableTooltips,\n numberFormat,\n numberLocale,\n seriesType: \"areaspline\",\n textLocale,\n yAxisLabelFormatter,\n onClick,\n timeFormat,\n xAnnotations,\n });\n\n const colors = data.map(\n (series, index) =>\n series.styles?.color ?? theme.colors.DATAVIZ_COLORS_LIST[index]\n );\n\n return (\n <>\n <GlobalChartStyleOverrides />\n <StyledBox\n // @ts-ignore\n $colors={colors}\n $hasOnClick={Boolean(onClick)}\n bg=\"container.background.base\"\n >\n <HighchartsReact\n highcharts={Highcharts}\n options={options}\n callback={callback}\n />\n {chart && chart.annotations?.length ? (\n <ChartXAnnotationMarkerPortal\n xAnnotations={xAnnotations}\n annotationContext={chart.annotations?.[0] as AnnotationsOptions}\n />\n ) : null}\n {chart && !disableTooltips ? (\n <ChartTooltipPortal\n chart={chart}\n renderContent={(context) => {\n const tooltipData = transformTimeSeriesTooltipData({\n context,\n data,\n });\n const x = context.x as number;\n const total = context.total as number;\n\n const xAnnotationDetails = xAnnotations?.[x]?.details;\n\n return tooltip ? (\n tooltip({ data: tooltipData, total, x })\n ) : (\n <AreaChartTooltip\n currency={currency}\n data={tooltipData}\n invalidNumberLabel={invalidNumberLabel}\n numberFormat={numberFormat}\n numberLocale={numberLocale}\n textLocale={textLocale}\n tooltipDateFormatter={tooltipDateFormatter}\n tooltipTotalLabel={tooltipTotalLabel}\n total={total}\n x={x}\n onClick={onClick}\n tooltipClickLabel={tooltipClickLabel}\n xAnnotationDetails={xAnnotationDetails}\n />\n );\n }}\n />\n ) : null}\n <Box mt={350}>\n <AreaChartLegend data={data} />\n </Box>\n </StyledBox>\n </>\n );\n});\n","import { memo } from \"react\";\nimport { theme } from \"@sproutsocial/seeds-react-theme\";\n\nimport type { TypeAreaChartProps } from \"../AreaChart\";\nimport { ChartLegend, type TypeChartLegendProps } from \"../../ChartLegend\";\nimport { ChartLegendLabelContentWithIcon } from \"../../ChartLegend/components/ChartLegendLabelContentWithIcon\";\n\n// exported for testing\nexport const getAreaChartLegendLabels = ({\n data,\n}: Readonly<{\n data: TypeAreaChartProps[\"data\"];\n}>): TypeChartLegendProps[\"legendLabels\"] => {\n return data.map((series, index) => ({\n content: (\n <ChartLegendLabelContentWithIcon icon={series.icon}>\n {series.name}\n </ChartLegendLabelContentWithIcon>\n ),\n color: series.styles?.color || theme.colors.DATAVIZ_COLORS_LIST[index],\n }));\n};\n\ntype TypeAreaChartLegendProps = Readonly<{\n data: TypeAreaChartProps[\"data\"];\n}>;\n\nexport const AreaChartLegend = memo<TypeAreaChartLegendProps>(\n function AreaChartLegend({ data }: TypeAreaChartLegendProps) {\n return <ChartLegend legendLabels={getAreaChartLegendLabels({ data })} />;\n }\n);\n","import { memo } from \"react\";\nimport { Box, type TypeBoxProps } from \"@sproutsocial/seeds-react-box\";\nimport { theme } from \"@sproutsocial/seeds-react-theme\";\n\nimport { ChartLegendLabel } from \"./components/ChartLegendLabel\";\n\nexport type TypeLegendLabel = Readonly<{\n content: React.ReactNode;\n color?: string;\n}>;\n\nexport type TypeChartLegendProps = Readonly<{\n legendLabels: ReadonlyArray<TypeLegendLabel>;\n // optional\n containerBoxProps?: TypeBoxProps;\n stacked?: boolean;\n}>;\n\nexport const ChartLegend = memo<TypeChartLegendProps>(function ChartLegend({\n legendLabels,\n containerBoxProps = {},\n stacked = false,\n}: TypeChartLegendProps) {\n return (\n <Box\n as=\"ul\"\n aria-hidden=\"true\"\n display=\"flex\"\n justifyContent=\"center\"\n flexDirection={stacked ? \"column\" : \"row\"}\n flexWrap=\"wrap\"\n columnGap={450}\n rowGap={200}\n m={0}\n p={0}\n {...containerBoxProps}\n >\n {legendLabels.map(({ color, content }, index) => (\n <ChartLegendLabel\n key={`chart-legend-label-${index}`}\n color={color || theme.colors.DATAVIZ_COLORS_LIST[index]}\n containerBoxProps={{ as: \"li\" }}\n >\n {content}\n </ChartLegendLabel>\n ))}\n </Box>\n );\n});\n","import styled from \"styled-components\";\nimport { memo } from \"react\";\nimport { Box, type TypeBoxProps } from \"@sproutsocial/seeds-react-box\";\nimport { Text } from \"@sproutsocial/seeds-react-text\";\n\nimport type { TypeLegendLabel } from \"../ChartLegend\";\n\nimport { ColorBox } from \"../../ColorBox\";\n\nconst StyledBox = styled(Box)<TypeBoxProps>`\n list-style: none;\n display: flex;\n align-items: center;\n gap: ${({ theme }) => theme.space[300]};\n`;\n\nexport type TypeChartLegendLabelProps = Readonly<{\n children: TypeLegendLabel[\"content\"];\n color: TypeLegendLabel[\"color\"];\n // optional\n containerBoxProps?: TypeBoxProps;\n}>;\n\nexport const ChartLegendLabel = memo<TypeChartLegendLabelProps>(\n function ChartLegendLabel({\n children,\n color = \"#CCC\",\n containerBoxProps = {},\n }: TypeChartLegendLabelProps) {\n return (\n <StyledBox {...containerBoxProps}>\n <ColorBox bg={color} />\n <Text as=\"div\" fontSize={200} color=\"text.subtext\">\n {children}\n </Text>\n </StyledBox>\n );\n }\n);\n","import { css, type CSSProp } from \"styled-components\";\nimport { Box, type TypeBoxProps } from \"@sproutsocial/seeds-react-box\";\nimport ThemeProvider from \"@sproutsocial/seeds-react-theme-provider\";\nimport { type TypeSproutTheme } from \"@sproutsocial/seeds-react-theme\";\n\nexport type TypeColorBoxProps = TypeBoxProps;\n\n/**\n * ColorBox extends Box to apply basic styles.\n */\nexport const ColorBox = ({\n display = \"inline-block\",\n height = \"16px\",\n width = \"16px\",\n minWidth = width,\n borderRadius = \"400\",\n ...props\n}: TypeColorBoxProps) => {\n return (\n <Box\n {...props}\n display={display}\n height={height}\n width={width}\n minWidth={minWidth}\n borderRadius={borderRadius}\n css={\n css`\n cursor: ${(\n props: typeof ThemeProvider & {\n onClick: ((e: React.MouseEvent<HTMLElement>) => void) | void;\n }\n ) => (props?.onClick ? \"pointer\" : \"default\")};\n ` as CSSProp<TypeSproutTheme>\n }\n />\n );\n};\n","import * as React from \"react\";\nimport { ThemeProvider as BaseThemeProvider } from \"styled-components\";\nimport { theme } from \"@sproutsocial/seeds-react-theme\";\nimport type {\n TypeSproutTheme,\n TypeTheme,\n} from \"@sproutsocial/seeds-react-theme\";\n\n// We can append additional themes types here\ntype TypeAllThemes = TypeTheme | TypeSproutTheme;\n\ntype TypeProps = {\n readonly theme?: TypeAllThemes;\n readonly children?: React.ReactNode;\n};\n\nconst ThemeProvider = (props: TypeProps) => (\n <BaseThemeProvider {...props} theme={props.theme || theme} />\n);\n\nexport default ThemeProvider;\n","import type * as React from \"react\";\nimport styled from \"styled-components\";\nimport { theme } from \"@sproutsocial/seeds-react-theme\";\nimport { ColorBox, type TypeColorBoxProps } from \"./ColorBox\";\n\nexport type TypeDatavizColorBoxProps = Readonly<\n Partial<TypeColorBoxProps> & {\n colorIndex: number;\n }\n>;\nexport type TypeDatavizColorBox = (\n props: TypeDatavizColorBoxProps\n) => React.JSXElementConstructor<TypeDatavizColorBoxProps>;\n\n/**\n * DatavizColorBox extends ColorBox to set the background color from a rotation of <a href=\"https://seeds.sproutsocial.com/visual/dataviz#color-combinations-for-general-sprout-social-data-visualizations\">dataviz colors</a>.\n */\nexport const DatavizColorBox = styled(ColorBox).attrs(\n ({ colorIndex }: TypeDatavizColorBoxProps) => ({\n style: {\n background: getDatavizColor(colorIndex),\n opacity: getDatavizOpacity(colorIndex),\n },\n })\n)<TypeDatavizColorBoxProps>``;\n\nexport const getDatavizColor = (colorIndex: number): string =>\n theme.colors.DATAVIZ_COLORS_LIST[\n colorIndex % theme.colors.DATAVIZ_COLORS_LIST.length\n ] || \"\";\n\nexport const getDatavizOpacity = (colorIndex: number): number => {\n const opacitySteps = [1, 0.6, 0.4, 0.2];\n const opacityStep =\n Math.floor(colorIndex / theme.colors.DATAVIZ_COLORS_LIST.length) %\n opacitySteps.length;\n // @ts-ignore\n return opacitySteps[opacityStep];\n};\n\n// information on 8 digit hex codes can be found here: https://css-tricks.com/8-digit-hex-codes/\nexport const getDatavizColorWithAlpha = (colorIndex: number): string => {\n const color = getDatavizColor(colorIndex);\n const opacity = getDatavizOpacity(colorIndex);\n\n // make sure the opacity is always between 0 and 1\n if (opacity < 0 || opacity > 1) {\n return color;\n }\n\n // sourced from https://stackoverflow.com/a/66143374\n return `${color}${Math.floor(opacity * 255)\n .toString(16)\n .padStart(2, \"0\")}`;\n};\n","import NETWORK_COLORS from \"@sproutsocial/seeds-networkcolor\";\n\nimport { ColorBox, type TypeColorBoxProps } from \"./ColorBox\";\n\n// $Keys<typeof NETWORK_COLORS>\ntype TypeNetworkColor =\n | \"NETWORK_COLOR_TWITTER\"\n | \"NETWORK_COLOR_TWITTER_LIKE\"\n | \"NETWORK_COLOR_FACEBOOK\"\n | \"NETWORK_COLOR_FACEBOOK_AUDIENCE_NETWORK\"\n | \"NETWORK_COLOR_LINKEDIN\"\n | \"NETWORK_COLOR_INSTAGRAM\"\n | \"NETWORK_COLOR_FEEDLY\"\n | \"NETWORK_COLOR_ANALYTICS\"\n | \"NETWORK_COLOR_YOUTUBE\"\n | \"NETWORK_COLOR_MESSENGER\"\n | \"NETWORK_COLOR_SNAPCHAT\"\n | \"NETWORK_COLOR_PINTEREST\"\n | \"NETWORK_COLOR_REDDIT\"\n | \"NETWORK_COLOR_TUMBLR\"\n | \"NETWORK_COLOR_GOOGLE_MY_BUSINESS\"\n | \"NETWORK_COLOR_TIKTOK\"\n | \"NETWORK_COLOR_TRIPADVISOR\"\n | \"NETWORK_COLOR_GLASSDOOR\"\n | \"NETWORK_COLOR_SALESFORCE\"\n | \"NETWORK_COLOR_ZENDESK\"\n | \"NETWORK_COLOR_HUBSPOT\"\n | \"NETWORK_COLOR_MICROSOFT_DYNAMICS\";\n\ntype TypeNetworkColorBoxProps = Readonly<\n TypeColorBoxProps & {\n networkColor: TypeNetworkColor;\n }\n>;\n\n/**\n * NetworkColorBox extends ColorBox to set the background color to a <a href=\"https://seeds.sproutsocial.com/visual/color#full-color-palette\">network color</a>.\n */\nexport const NetworkColorBox = ({\n networkColor,\n ...props\n}: TypeNetworkColorBoxProps) => {\n return <ColorBox {...props} bg={NETWORK_COLORS[networkColor]} />;\n};\n","import { memo } from \"react\";\nimport { Box } from \"@sproutsocial/seeds-react-box\";\n\nexport type TypeChartLegendLabelContentWithIconProps = Readonly<{\n children: React.ReactNode;\n // optional\n icon?: React.ReactNode;\n}>;\n\nexport const ChartLegendLabelContentWithIcon =\n memo<TypeChartLegendLabelContentWithIconProps>(\n function ChartLegendLabelContentWithIcon({\n children,\n icon,\n }: TypeChartLegendLabelContentWithIconProps) {\n return icon ? (\n <Box display=\"flex\" alignItems=\"center\" gap={200}>\n {icon}\n {children}\n </Box>\n ) : (\n children\n );\n }\n );\n","import { memo } from \"react\";\nimport { Box } from \"@sproutsocial/seeds-react-box\";\nimport { Duration } from \"@sproutsocial/seeds-react-duration\";\nimport { Icon } from \"@sproutsocial/seeds-react-icon\";\nimport { Numeral } from \"@sproutsocial/seeds-react-numeral\";\nimport { Text } from \"@sproutsocial/seeds-react-text\";\nimport { type TypeChartXAnnotationsDetails } from \"../../../types\";\n\nimport type { TypeAreaChartProps } from \"../AreaChart\";\n\nimport {\n ChartTooltip,\n ChartTooltipFooter,\n ChartTooltipTable,\n ChartTooltipTitle,\n type TypeChartTooltipTableProps,\n} from \"../../ChartTooltip\";\nimport type { TypeChartTooltipProps } from \"../../../types\";\nimport { ChartLegendLabel } from \"../../ChartLegend/components/ChartLegendLabel\";\nimport { ChartLegendLabelContentWithIcon } from \"../../ChartLegend/components/ChartLegendLabelContentWithIcon\";\n\nexport type TypeAreaChartTooltipProps = Readonly<{\n data: TypeChartTooltipProps[\"data\"];\n invalidNumberLabel: TypeAreaChartProps[\"invalidNumberLabel\"];\n numberLocale: TypeAreaChartProps[\"numberLocale\"];\n textLocale: TypeAreaChartProps[\"textLocale\"];\n tooltipDateFormatter: TypeAreaChartProps[\"tooltipDateFormatter\"];\n tooltipTotalLabel: TypeAreaChartProps[\"tooltipTotalLabel\"];\n total: number | null;\n x: TypeChartTooltipProps[\"x\"];\n // optional\n currency?: TypeAreaChartProps[\"currency\"];\n numberFormat?: TypeAreaChartProps[\"numberFormat\"];\n onClick?: TypeAreaChartProps[\"onClick\"];\n tooltipClickLabel?: TypeAreaChartProps[\"tooltipClickLabel\"];\n xAnnotationDetails?: TypeChartXAnnotationsDetails;\n}>;\n\nexport const AreaChartTooltip = memo<TypeAreaChartTooltipProps>(\n function AreaChartTooltip({\n data,\n invalidNumberLabel,\n numberLocale,\n textLocale,\n tooltipDateFormatter,\n tooltipTotalLabel,\n total,\n x,\n // optional\n currency = \"USD\",\n numberFormat = \"decimal\",\n onClick,\n tooltipClickLabel,\n xAnnotationDetails,\n }: TypeAreaChartTooltipProps) {\n const rows = data.map(({ color, icon, name, value }) => {\n return {\n cells: [\n {\n content: (\n <ChartLegendLabel color={color}>\n <ChartLegendLabelContentWithIcon icon={icon}>\n <Text aria-label={`${name}: `}>{name}</Text>\n </ChartLegendLabelContentWithIcon>\n </ChartLegendLabel>\n ),\n },\n {\n content:\n value === null && invalidNumberLabel ? (\n <Text>{invalidNumberLabel}</Text>\n ) : numberFormat === \"duration\" ? (\n <Duration locale={textLocale} milliseconds={value} />\n ) : (\n <Numeral\n abbreviate={false}\n currency={currency}\n format={numberFormat}\n locale={numberLocale as string}\n number={value}\n />\n ),\n align: \"right\",\n },\n ],\n };\n });\n\n const appendedRows =\n data.length > 1\n ? [\n {\n cells: [\n {\n content: (\n <Text\n fontWeight=\"semibold\"\n aria-label={`${tooltipTotalLabel}: `}\n >\n {tooltipTotalLabel}\n </Text>\n ),\n },\n {\n content: (\n <Text fontWeight=\"bold\">\n {total === null && invalidNumberLabel ? (\n invalidNumberLabel\n ) : numberFormat === \"duration\" ? (\n <Duration locale={textLocale} milliseconds={total} />\n ) : (\n <Numeral\n abbreviate={false}\n currency={currency}\n format={numberFormat}\n locale={numberLocale as string}\n number={total}\n />\n )}\n </Text>\n ),\n align: \"right\",\n },\n ],\n isAppendedRow: true,\n },\n ]\n : [];\n\n return (\n <ChartTooltip>\n {xAnnotationDetails ? xAnnotationDetails() : undefined}\n <ChartTooltipTitle>{tooltipDateFormatter({ x })}</ChartTooltipTitle>\n <ChartTooltipTable\n rows={\n [...rows, ...appendedRows] as TypeChartTooltipTableProps[\"rows\"]\n }\n />\n {onClick && tooltipClickLabel ? (\n <ChartTooltipFooter>\n {typeof tooltipClickLabel === \"string\" ? (\n <Box display=\"flex\" alignItems=\"center\" gap={300}>\n <Icon name=\"hand-pointer-clicking-outline\" color=\"icon.base\" />\n <Text color=\"text.subtext\" fontSize={200}>\n {tooltipClickLabel}\n </Text>\n </Box>\n ) : (\n tooltipClickLabel\n )}\n </ChartTooltipFooter>\n ) : null}\n </ChartTooltip>\n );\n }\n);\n","import { memo } from \"react\";\nimport styled from \"styled-components\";\nimport { Box } from \"@sproutsocial/seeds-react-box\";\n\n// styled components\nconst StyledBox = styled(Box)`\n .Icon,\n .logo {\n stroke: none;\n }\n`;\n\n// Chart Tooltip\ntype TypeChartTooltipProps = Readonly<{\n children: React.ReactNode;\n}>;\n\nexport const ChartTooltip = memo<TypeChartTooltipProps>(function ChartTooltip({\n children,\n}: TypeChartTooltipProps) {\n return (\n <StyledBox\n bg=\"container.background.base\"\n boxShadow=\"medium\"\n border={500}\n borderColor=\"container.border.base\"\n borderRadius={500}\n p={400}\n minWidth={285}\n >\n <Box display=\"flex\" flexDirection=\"column\" gap={350}>\n {children}\n </Box>\n </StyledBox>\n );\n});\n","import { memo } from \"react\";\nimport { Box } from \"@sproutsocial/seeds-react-box\";\n\ntype TypeChartTooltipFooterProps = {\n children: React.ReactNode;\n};\n\nexport const ChartTooltipFooter = memo<TypeChartTooltipFooterProps>(\n function ChartTooltipFooter({ children }: TypeChartTooltipFooterProps) {\n return (\n <Box\n borderTop={500}\n borderColor=\"container.border.base\"\n mx={-400}\n mb={-200}\n px={400}\n pt={350}\n >\n {children}\n </Box>\n );\n }\n);\n","import { memo } from \"react\";\nimport { Box } from \"@sproutsocial/seeds-react-box\";\n\ntype TypeChartTooltipHeaderProps = {\n children: React.ReactNode;\n};\n\nexport const ChartTooltipHeader = memo<TypeChartTooltipHeaderProps>(\n function ChartTooltipHeader({ children }: TypeChartTooltipHeaderProps) {\n return (\n <Box\n borderBottom={500}\n borderColor=\"container.border.base\"\n mx={-400}\n mt={-200}\n px={400}\n pb={350}\n >\n {children}\n </Box>\n );\n }\n);\n","import { memo, useState, useRef, useEffect, type ReactNode } from \"react\";\nimport { createPortal } from \"react-dom\";\nimport type {\n Tooltip,\n Chart,\n TooltipFormatterContextObject,\n TooltipFormatterCallbackFunction,\n} from \"highcharts\";\n\ninterface ExtendedHighchartsTooltip extends Tooltip {\n label: {\n box: { attr({ height, width }: { height: number; width: number }): void };\n text: { element: HTMLElement };\n };\n}\n\nexport const generateChartTooltipPortalId = (chartId: number) =>\n `highcharts-custom-tooltip-${chartId}`;\n\ntype ChartTooltipPortalProps = Readonly<{\n chart: Chart;\n renderContent: (context: TooltipFormatterContextObject) => ReactNode;\n}>;\n\nexport const ChartTooltipPortal = memo<ChartTooltipPortalProps>(\n function ChartTooltipPortal({\n chart,\n renderContent,\n }: ChartTooltipPortalProps) {\n const isInitialized = useRef<boolean>(false);\n const [node, setNode] = useState<HTMLElement | null>(null);\n const [context, setContext] =\n useState<TooltipFormatterContextObject | null>(null);\n\n useEffect(() => {\n const formatter: TooltipFormatterCallbackFunction = function () {\n // Ensures that tooltip DOM container is rendered before React portal is created.\n if (!isInitialized.current) {\n isInitialized.current = true;\n chart.tooltip.refresh.apply(chart.tooltip, [this.point]);\n chart.tooltip.hide(0);\n }\n\n setContext(this);\n\n return `<div id=\"${generateChartTooltipPortalId(\n chart.index\n )}\" role='tooltip'></div>`;\n };\n\n chart.update({ tooltip: { formatter } });\n }, [chart]);\n\n useEffect(() => {\n // In some cases tooltip is not available on the chart yet\n if (context?.series?.chart?.tooltip) {\n const tooltip = context.series.chart\n .tooltip as ExtendedHighchartsTooltip;\n const textElement = tooltip.label.text.element;\n\n tooltip.label.box.attr({\n height: textElement.offsetHeight,\n width: textElement.offsetWidth,\n });\n\n setNode(\n document.getElementById(generateChartTooltipPortalId(chart.index))\n );\n }\n }, [context, chart.index]);\n\n return node && context ? createPortal(renderContent(context), node) : null;\n }\n);\n","import { memo } from \"react\";\n\nimport { ChartTable, type TypeChartTableProps } from \"../../ChartTable\";\n\nexport type TypeChartTooltipTableProps = {\n rows: TypeChartTableProps[\"rows\"];\n};\n\nexport const ChartTooltipTable = memo<TypeChartTooltipTableProps>(\n function ChartTooltipTable({ rows }: TypeChartTooltipTableProps) {\n return <ChartTable rows={rows} />;\n }\n);\n","import { memo } from \"react\";\nimport styled from \"styled-components\";\nimport { Text } from \"@sproutsocial/seeds-react-text\";\nimport { Table as SeedsTable } from \"@sproutsocial/seeds-react-table\";\n\nconst StyledSeedsTable = styled<typeof SeedsTable>(SeedsTable)`\n tbody tr:last-child {\n border-bottom: none;\n }\n tr:last-child td,\n tr:last-child th {\n padding-bottom: 0;\n }\n tr:first-child td,\n tr:first-child th {\n padding-top: 0;\n }\n tr th {\n padding-left: 0;\n }\n tr td:last-child {\n padding-right: 0;\n }\n`;\n\nconst StyledSeedsTableRow = styled(SeedsTable.TableRow)<{\n $isAppendedRow?: boolean;\n}>`\n ${({ $isAppendedRow, theme }) =>\n $isAppendedRow\n ? `border-top: 2px solid ${theme.colors.container.border.base}`\n : \"\"}\n`;\n\nexport type TypeChartTableProps = Readonly<{\n rows: ReadonlyArray<{\n cells: ReadonlyArray<{\n content: React.ReactNode;\n align?: React.ComponentProps<typeof SeedsTable.Cell>[\"align\"];\n colSpan?: React.ComponentProps<typeof SeedsTable.Cell>[\"colSpan\"];\n }>;\n isAppendedRow?: boolean;\n }>;\n}>;\n\nexport const ChartTable = memo<TypeChartTableProps>(function ChartTable({\n rows,\n}: TypeChartTableProps) {\n if (!rows || rows.length === 0) {\n return null;\n }\n\n return (\n <StyledSeedsTable>\n <SeedsTable.TableBody>\n {rows.map(({ cells, isAppendedRow }, rowIndex) => {\n if (!cells || cells.length === 0) {\n return null;\n }\n\n return (\n <StyledSeedsTableRow\n key={`chart-tooltip-table-row-${rowIndex}`}\n $isAppendedRow={isAppendedRow}\n >\n {cells.map(\n ({ content, align = \"left\", colSpan = 1 }, cellIndex) => {\n const uniqueIdentifier = `chart-tooltip-table-cell-${cellIndex}`;\n return (\n <SeedsTable.Cell\n key={uniqueIdentifier}\n id={uniqueIdentifier}\n scope={cellIndex === 0 ? \"row\" : undefined}\n align={align}\n colSpan={colSpan}\n py={200}\n >\n <Text.SmallBodyCopy as=\"div\">\n {content}\n </Text.SmallBodyCopy>\n </SeedsTable.Cell>\n );\n }\n )}\n </StyledSeedsTableRow>\n );\n })}\n </SeedsTable.TableBody>\n </StyledSeedsTable>\n );\n});\n","import { memo } from \"react\";\nimport { Text } from \"@sproutsocial/seeds-react-text\";\n\ntype TypeChartTooltipTitleProps = {\n children: React.ReactNode;\n};\n\nexport const ChartTooltipTitle = memo<TypeChartTooltipTitleProps>(\n function ChartTooltipTitle({ children }: TypeChartTooltipTitleProps) {\n return <Text.SmallSubHeadline as=\"p\">{children}</Text.SmallSubHeadline>;\n }\n);\n","import { memo, useEffect, useState, useRef } from \"react\";\nimport { createPortal } from \"react-dom\";\nimport { type TypeChartXAnnotations } from \"../../../types\";\nimport {\n type AnnotationsOptions,\n type AnnotationsLabelOptions,\n} from \"highcharts\";\n\n// add in types that Highcharts doesn't include by default\nexport interface TypeExtendedLabelOptions extends AnnotationsLabelOptions {\n graphic?: {\n div?: HTMLDivElement;\n };\n options?: {\n point?: {\n x?: number;\n };\n };\n}\n\nexport const ChartXAnnotationMarkerPortal = memo(\n function ChartXAnnotationMarkerPortal({\n xAnnotations,\n annotationContext,\n }: {\n xAnnotations: TypeChartXAnnotations;\n annotationContext: AnnotationsOptions;\n }) {\n const annotationContainers = useRef<Record<number, HTMLDivElement>>({});\n const [renderCount, setRenderCount] = useState(0); // used to trigger react to re-render\n const forceRender = () => setRenderCount((prev) => prev + 1);\n useEffect(() => {\n if (annotationContext.labels) {\n const newContainers: Record<number, HTMLDivElement> = {};\n const existingAnnotationContainers = document.querySelectorAll(\n \"div[data-annotation-marker='true']\"\n );\n\n // 1. Mark all existing annotations as \"false\" before updating\n // Highcharts doesn't clean these up, so we'll need to at the end\n existingAnnotationContainers.forEach((annotation) =>\n annotation.setAttribute(\"data-annotation-marker\", \"false\")\n );\n\n annotationContext.labels.forEach((label: TypeExtendedLabelOptions) => {\n const labelElement = label.graphic?.div;\n if (labelElement) {\n // 2. Remove old annotations markers inside the current container\n labelElement\n .querySelectorAll(\"div[data-annotation-marker]\")\n .forEach((component) => component.remove());\n\n // 3. Create a new annotation div\n const annotationDiv = document.createElement(\"div\");\n annotationDiv.setAttribute(\"data-annotation-marker\", \"true\");\n labelElement.appendChild(annotationDiv);\n\n const xValue = label.options?.point?.x as number;\n newContainers[xValue] = annotationDiv;\n }\n });\n\n annotationContainers.current = newContainers;\n forceRender(); // Triggers re-render so the portal attaches to updated containers\n\n // 4. Remove stale parent annotation containers\n requestAnimationFrame(() => {\n document\n .querySelectorAll(\"div.highcharts-annotation\")\n .forEach((annotationDiv) => {\n const reactAnnotations = annotationDiv.querySelectorAll(\n \"div[data-annotation-marker]\"\n );\n\n const hasActiveAnnotations = Array.from(reactAnnotations).some(\n (div) => div.getAttribute(\"data-annotation-marker\") === \"true\"\n );\n\n // Remove if all child markers are stale\n if (!hasActiveAnnotations) {\n annotationDiv.remove();\n }\n });\n });\n }\n }, [annotationContext.labels, xAnnotations]);\n\n return (\n <>\n {Object.entries(annotationContainers.current).map(\n ([xValue, container]) => {\n const annotationComponent = xAnnotations?.[Number(xValue)]?.marker;\n return annotationComponent\n ? createPortal(annotationComponent(), container)\n : null;\n }\n )}\n </>\n );\n }\n);\n","import type {\n SeriesSplineOptions,\n SeriesAreasplineOptions,\n SeriesColumnOptions,\n} from \"highcharts\";\n\nimport type { TypeAreaChartProps } from \"../components/AreaChart\";\nimport type { TypeLineChartProps } from \"../components/LineChart\";\nimport type { TypeVerticalBarChartProps, TypeSeriesType } from \"../types\";\n\ntype TypeTimeSeriesOptions =\n | SeriesSplineOptions\n | SeriesAreasplineOptions\n | SeriesColumnOptions;\n\n// returns a transformed set of data to series with some logic for handling null values\nexport const transformDataToSeries = (\n {\n data,\n }: {\n data:\n | TypeAreaChartProps[\"data\"]\n | TypeLineChartProps[\"data\"]\n | TypeVerticalBarChartProps[\"data\"];\n },\n type: TypeSeriesType\n): TypeTimeSeriesOptions[] => {\n // Check if we have categorical data (string x values)\n const hasCategoricalData = data.some((series) =>\n series.points.some((point) => typeof point.x === \"string\")\n );\n\n return data.map((dataItem, dataIndex) => {\n const points = dataItem.points || [];\n const dataPoints = points.map((point, pointsIndex) => {\n let enableMarker = false;\n const isFirstPoint = pointsIndex === 0;\n const isLastPoint = pointsIndex === points.length - 1;\n\n // @ts-ignore\n const previousY = isFirstPoint ? null : points[pointsIndex - 1].y;\n // @ts-ignore\n const nextY = isLastPoint ? null : points[pointsIndex + 1].y;\n\n if (isFirstPoint && nextY === null) {\n // if the first point has data and the second point is null, show a marker for the first point\n enableMarker = true;\n } else if (isLastPoint && previousY === null) {\n // if the last point has data and the second to last point is null, show a marker for the last point\n enableMarker = true;\n } else if (previousY === null && nextY === null) {\n // if the a point has null values on both sides, show a marker\n enableMarker = true;\n }\n\n return {\n x: hasCategoricalData ? pointsIndex : point.x,\n y: point.y,\n marker: {\n enabled: enableMarker ? enableMarker : undefined,\n symbol: enableMarker ? \"circle\" : undefined,\n },\n // For categorical data, store the original category name\n ...(hasCategoricalData && { name: point.x }),\n };\n });\n\n return {\n colorIndex: dataIndex,\n data: dataPoints as TypeTimeSeriesOptions[\"data\"],\n name: dataItem.name as TypeTimeSeriesOptions[\"name\"],\n type: type,\n };\n });\n};\n","import type { TooltipFormatterContextObject } from \"highcharts\";\nimport { theme } from \"@sproutsocial/seeds-react-theme\";\n\nimport type { TypeAreaChartProps } from \"../components/AreaChart\";\nimport type { TypeLineChartProps } from \"../components/LineChart\";\nimport type { TypeChartTooltipProps } from \"../types\";\n\ntype TypeTransformTimeSeriesTooltipDataProps = Readonly<{\n context: TooltipFormatterContextObject;\n data: TypeAreaChartProps[\"data\"] | TypeLineChartProps[\"data\"];\n}>;\ntype TypeTransformTimeSeriesTooltipDataReturn = TypeChartTooltipProps[\"data\"];\n\nexport const transformTimeSeriesTooltipData = ({\n context,\n data,\n}: TypeTransformTimeSeriesTooltipDataProps): TypeTransformTimeSeriesTooltipDataReturn => {\n // @ts-ignore\n return (context.series.chart.series || []).map((series, index) => {\n const pointIndex = context.point.index;\n // @ts-ignore\n const { y } = series.points[pointIndex];\n\n return {\n color:\n data[index]?.styles?.color || theme.colors.DATAVIZ_COLORS_LIST[index],\n ...(data[index]?.icon ? { icon: data[index]?.icon } : {}),\n name: series.name,\n value: typeof y === \"number\" ? y : null,\n };\n });\n};\n","import type {\n AxisLabelsFormatterContextObject,\n AxisTickPositionsArray,\n} from \"highcharts\";\nimport { formatDuration } from \"@sproutsocial/seeds-react-duration\";\nimport { formatNumeral } from \"@sproutsocial/seeds-react-numeral\";\n\nimport type { TypeChartNumberFormat } from \"../types\";\n\ntype TypeYAxisLabelFormatterProps = Readonly<{\n numberLocale: Intl.LocalesArgument;\n textLocale: Intl.LocalesArgument;\n tickPositions: AxisTickPositionsArray;\n value: AxisLabelsFormatterContextObject[\"value\"];\n // optional\n currency?: string;\n numberFormat?: TypeChartNumberFormat;\n}>;\n\nexport const yAxisLabelFormatter = ({\n numberLocale,\n textLocale,\n tickPositions,\n value,\n currency = \"USD\",\n numberFormat = \"decimal\",\n}: TypeYAxisLabelFormatterProps): string => {\n const numberValue = Number(value);\n\n if (numberValue === 0) {\n return formatNumeral({\n locale: numberLocale as string,\n number: numberValue,\n });\n }\n\n if (numberFormat === \"duration\") {\n return formatDuration({\n display: \"narrow\",\n locale: textLocale,\n milliseconds: numberValue,\n });\n }\n\n // Seeds formatNumeral helper starts abbreviating numbers above 10,000. this maxValue logic\n // helps bring that threshold down to 1,000 if the last tick on the y axis is greater than 9,999\n // so we render \"2k 4k 6k 8k 10k\" instead of \"2,000 4,000 6,000 8,000 10k\"\n const maxValue =\n tickPositions && tickPositions.length > 0\n ? tickPositions[tickPositions.length - 1]\n : undefined;\n const abbreviate =\n typeof maxValue === \"number\" && maxValue > 9999 ? 1000 : true;\n\n return formatNumeral({\n abbreviate,\n currency,\n format: numberFormat,\n locale: numberLocale as string,\n number: numberValue,\n });\n};\n","import type {\n AxisLabelsFormatterContextObject,\n AxisTickPositionsArray,\n} from \"highcharts\";\n\nimport type {\n ExtendedTimeTicksInfoObject,\n TypeChartTimeFormat,\n} from \"../types\";\n\ntype TypeXAxisLabelFormatterProps = Readonly<{\n textLocale: Intl.LocalesArgument;\n tickPositions: AxisTickPositionsArray;\n unitName: ExtendedTimeTicksInfoObject[\"unitName\"];\n value: AxisLabelsFormatterContextObject[\"value\"];\n // optional\n timeFormat?: TypeChartTimeFormat;\n}>;\n\nexport const xAxisLabelFormatter = ({\n textLocale,\n tickPositions = [],\n unitName,\n value,\n // optional\n timeFormat = \"12\",\n}: TypeXAxisLabelFormatterProps): string => {\n // Handle categorical (string) data\n if (typeof value === \"string\") {\n return `<span>${value}</span>`;\n }\n const tickIndex = tickPositions.indexOf(value as number);\n const isFirst = tickIndex === 0;\n const previousValue = tickPositions[tickIndex - 1];\n\n const valueDate = new Date(value);\n // @ts-ignore\n const previousValueDate = new Date(previousValue);\n\n let firstPartOptions = {};\n let secondPartOptions = {};\n\n switch (unitName) {\n case \"hour\":\n firstPartOptions =\n timeFormat === \"24\"\n ? { hour: \"numeric\", minute: \"numeric\", hour12: false }\n : { hour: \"numeric\" };\n if (\n isFirst ||\n valueDate.getUTCDate() !== previousValueDate.getUTCDate()\n ) {\n secondPartOptions = { day: \"numeric\", month: \"short\" };\n }\n break;\n case \"day\":\n case \"week\":\n firstPartOptions = { day: \"numeric\" };\n if (\n isFirst ||\n valueDate.getUTCMonth() !== previousValueDate.getUTCMonth()\n ) {\n secondPartOptions = { month: \"short\" };\n }\n break;\n case \"month\":\n firstPartOptions = { month: \"short\" };\n if (\n isFirst ||\n valueDate.getUTCFullYear() !== previousValueDate.getUTCFullYear()\n ) {\n secondPartOptions = { year: \"numeric\" };\n }\n break;\n case \"year\":\n firstPartOptions = { year: \"numeric\" };\n break;\n default:\n firstPartOptions = {};\n break;\n }\n\n // highcharts by default uses UTC: https://api.highcharts.com/highcharts/time.useUTC\n const firstPart = new Intl.DateTimeFormat(textLocale, {\n ...firstPartOptions,\n timeZone: \"UTC\",\n }).format(valueDate);\n const secondPart =\n Object.keys(secondPartOptions).length > 0\n ? new Intl.DateTimeFormat(textLocale, {\n ...secondPartOptions,\n timeZone: \"UTC\",\n }).format(valueDate)\n : undefined;\n\n return `<span>${firstPart}</span>${\n secondPart ? `<span>${secondPart}</span>` : \"\"\n }`;\n};\n","/**\n * Helper to detect if data is hourly time data (all x values are hours of the same day)\n * @param data - Array of series data with points containing x values\n * @returns boolean indicating if all x values are hours of the same day\n */\nexport function isHourlyTimeData(\n data: ReadonlyArray<\n Readonly<{ points: ReadonlyArray<{ x: number | string }> }>\n >\n): boolean {\n // Return false if there is no data.\n if (!data.length) return false;\n\n // Flatten all data points into a single array of x values.\n const xVals = data.flatMap((series) => series.points.map((p) => p.x));\n\n // Return false if there are no x values.\n if (!xVals.length) return false;\n\n // Return false if any x values are strings (categorical data)\n if (xVals.some((x) => typeof x === \"string\")) return false;\n\n // Check if all x values are on the same calendar date.\n // We do this by converting each timestamp to a YYYY-MM-DD string and checking if there's only one unique date string.\n const dates = (xVals as number[]).map((x) => {\n const d = new Date(x);\n return `${d.getUTCFullYear()}-${d.getUTCMonth()}-${d.getUTCDate()}`;\n });\n const uniqueDates = new Set(dates);\n if (uniqueDates.size !== 1) return false;\n\n // Check if all x values are exactly on the hour (e.g., 2:00:00, not 2:00:01).\n // We also check that the hour is within the valid 0-23 range.\n return (xVals as number[]).every((x) => {\n const d = new Date(x);\n const hour = d.getUTCHours();\n const minutes = d.getUTCMinutes();\n const seconds = d.getUTCSeconds();\n return hour >= 0 && hour <= 23 && minutes === 0 && seconds === 0;\n });\n}\n","/**\n * Helper to detect if data is categorical hour data (all x values are hour strings)\n * Supports both 12-hour format (\"12 AM\", \"1 PM\") and 24-hour format (\"00:00\", \"13:00\", \"23:00\")\n * @param data - Array of series data with points containing x values\n * @returns boolean indicating if all x values are hour strings\n */\nexport function isCategoricalHourData(\n data: ReadonlyArray<\n Readonly<{ points: ReadonlyArray<{ x: number | string }> }>\n >\n): boolean {\n // Return false if there is no data.\n if (!data.length) return false;\n\n // Flatten all data points into a single array of x values.\n const xVals = data.flatMap((series) => series.points.map((p) => p.x));\n\n // Return false if there are no x values.\n if (!xVals.length) return false;\n\n // Return false if any x values are not strings (numerical data)\n if (xVals.some((x) => typeof x !== \"string\")) return false;\n\n // Check if all x values match either 12-hour or 24-hour format patterns\n const hour12Pattern = /^\\d{1,2} (AM|PM)$/; // \"12 AM\", \"1 PM\", \"10 AM\"\n const hour24Pattern = /^([01]?\\d|2[0-3]):([0-5]\\d)$/; // \"00:00\", \"13:00\", \"23:59\"\n\n const stringValues = xVals as string[];\n\n // Check if all values match 12-hour format\n const allMatch12Hour = stringValues.every((x) => hour12Pattern.test(x));\n\n // Check if all values match 24-hour format\n const allMatch24Hour = stringValues.every((x) => hour24Pattern.test(x));\n\n return allMatch12Hour || allMatch24Hour;\n}\n","export const getStorybookRandomColor = (): string => {\n const letters = \"0123456789ABCDEF\";\n let color = \"#\";\n for (let i = 0; i < 6; i++) {\n color += letters[Math.floor(Math.random() * 16)];\n }\n return color;\n};\n","import { getStorybookRandomColor } from \"./getStorybookRandomColor\";\n\nexport const getStorybookCategoricalData = ({\n showNulls,\n showNegativeValues,\n numberOfSeries,\n yAxisMax,\n showCustomColors,\n showDashedLines,\n categoryType,\n}: {\n showNulls: boolean;\n showNegativeValues: boolean;\n numberOfSeries: number;\n yAxisMax: number;\n showCustomColors: boolean;\n showDashedLines: boolean;\n categoryType: \"hours\" | \"hours24\" | \"days\" | \"months\" | \"custom\";\n}) => {\n // Define different category sets\n const categoryOptions = {\n hours: [\n \"12 AM\",\n \"1 AM\",\n \"2 AM\",\n \"3 AM\",\n \"4 AM\",\n \"5 AM\",\n \"6 AM\",\n \"7 AM\",\n \"8 AM\",\n \"9 AM\",\n \"10 AM\",\n \"11 AM\",\n \"12 PM\",\n \"1 PM\",\n \"2 PM\",\n \"3 PM\",\n \"4 PM\",\n \"5 PM\",\n \"6 PM\",\n \"7 PM\",\n \"8 PM\",\n \"9 PM\",\n \"10 PM\",\n \"11 PM\",\n ],\n hours24: [\n \"00:00\",\n \"01:00\",\n \"02:00\",\n \"03:00\",\n \"04:00\",\n \"05:00\",\n \"06:00\",\n \"07:00\",\n \"08:00\",\n \"09:00\",\n \"10:00\",\n \"11:00\",\n \"12:00\",\n \"13:00\",\n \"14:00\",\n \"15:00\",\n \"16:00\",\n \"17:00\",\n \"18:00\",\n \"19:00\",\n \"20:00\",\n \"21:00\",\n \"22:00\",\n \"23:00\",\n ],\n days: [\n \"Monday\",\n \"Tuesday\",\n \"Wednesday\",\n \"Thursday\",\n \"Friday\",\n \"Saturday\",\n \"Sunday\",\n ],\n months: [\n \"January\",\n \"February\",\n \"March\",\n \"April\",\n \"May\",\n \"June\",\n \"July\",\n \"August\",\n \"September\",\n \"October\",\n \"November\",\n \"December\",\n ],\n custom: [\n \"Category A\",\n \"Category B\",\n \"Category C\",\n \"Category D\",\n \"Category E\",\n ],\n };\n\n const categories = categoryOptions[categoryType];\n const numberOfPoints = categories.length;\n\n return [...Array(numberOfSeries).keys()].map((seriesIndex) => {\n let nullsArray: ReadonlyArray<number> = [];\n\n if (showNulls) {\n const nullsArrayLength = Math.floor(numberOfPoints / 5);\n nullsArray = [...Array(nullsArrayLength)].map(() =>\n Math.floor(Math.random() * numberOfPoints)\n );\n }\n\n return {\n points: categories.map((category, pointIndex) => {\n const showNull =\n nullsArray && nullsArray.length > 0\n ? nullsArray.includes(pointIndex)\n : false;\n const randomValue = Math.random();\n const positiveOrNegativeYAxisMax = showNegativeValues\n ? randomValue < 0.5\n ? -yAxisMax\n : yAxisMax\n : yAxisMax;\n\n return {\n x: category,\n y: showNull\n ? null\n : Math.floor(randomValue * positiveOrNegativeYAxisMax),\n };\n }),\n name: `Series ${seriesIndex + 1}`,\n styles: {\n color: showCustomColors ? getStorybookRandomColor() : undefined,\n pattern: showDashedLines ? \"dashed\" : \"solid\",\n },\n };\n });\n};\n","import { getStorybookRandomColor } from \"./getStorybookRandomColor\";\n\nexport const getStorybookSparseTimelineData = ({\n showNulls,\n showNegativeValues,\n numberOfSeries,\n yAxisMax,\n showCustomColors,\n showDashedLines,\n numberOfPoints = 5,\n timeSpanHours = 24,\n}: {\n showNulls: boolean;\n showNegativeValues: boolean;\n numberOfSeries: number;\n yAxisMax: number;\n showCustomColors: boolean;\n showDashedLines: boolean;\n numberOfPoints?: number;\n timeSpanHours?: number;\n}) => {\n const seriesNames = [\n \"Posts Published\",\n \"Comments\",\n \"Likes\",\n \"Shares\",\n \"Clicks\",\n \"Views\",\n \"Saves\",\n \"Reposts\",\n \"Mentions\",\n \"Reactions\",\n ];\n\n const baseDate = new Date(\"2024-01-01T00:00:00Z\");\n const timeSpanMs = timeSpanHours * 60 * 60 * 1000;\n\n return [...Array(numberOfSeries).keys()].map((seriesIndex) => {\n let nullsArray: ReadonlyArray<number> = [];\n\n if (showNulls) {\n const nullsArrayLength = Math.floor(numberOfPoints / 5);\n nullsArray = [...Array(nullsArrayLength)].map(() =>\n Math.floor(Math.random() * numberOfPoints)\n );\n }\n\n // Generate random timestamps for this series\n const timestamps = [...Array(numberOfPoints)]\n .map(() => {\n const randomOffset = Math.random() * timeSpanMs;\n return baseDate.getTime() + randomOffset;\n })\n .sort((a, b) => a - b); // Sort chronologically\n\n return {\n points: timestamps.map((timestamp, pointIndex) => {\n const showNull =\n nullsArray && nullsArray.length > 0\n ? nullsArray.includes(pointIndex)\n : false;\n const randomValue = Math.random();\n const positiveOrNegativeYAxisMax = showNegativeValues\n ? randomValue < 0.5\n ? -yAxisMax\n : yAxisMax\n : yAxisMax;\n\n return {\n x: timestamp,\n y: showNull\n ? null\n : Math.floor(randomValue * positiveOrNegativeYAxisMax),\n };\n }),\n name: seriesNames[seriesIndex] || `Series ${seriesIndex + 1}`,\n styles: {\n color: showCustomColors ? getStorybookRandomColor() : undefined,\n pattern: showDashedLines ? \"dashed\" : \"solid\",\n },\n };\n });\n};\n","import { useState, useCallback, useMemo } from \"react\";\nimport type {\n Chart,\n Annotation,\n Series,\n Point,\n AxisLabelsFormatterContextObject,\n SeriesClickEventObject,\n} from \"highcharts\";\n\nimport {\n lineChartOptions,\n areaChartOptions,\n columnChartOptions,\n} from \"../constants\";\nimport type { TypeAreaChartProps } from \"../components/AreaChart\";\nimport type { TypeLineChartProps } from \"../components/LineChart\";\nimport type { TypeVerticalBarChartProps } from \"../types\";\nimport {\n yAxisLabelFormatter as defaultYAxisLabelFormatter,\n transformDataToSeries,\n xAxisLabelFormatter,\n} from \"../helpers\";\nimport type {\n TypeChartNumberFormat,\n TypeChartTimeFormat,\n ExtendedAxisLabelsFormatterContextObject,\n TypeChartYAxisLabelFormatter,\n TypeChartXAnnotations,\n TypeSeriesType,\n} from \"../types\";\nimport { generateChartTooltipPortalId } from \"../components/ChartTooltip/components/ChartTooltipPortal\";\nimport { merge } from \"lodash\";\n\nexport type TypeUseTimeSeriesChartOptionsProps = {\n xAnnotations: TypeChartXAnnotations;\n data:\n | TypeAreaChartProps[\"data\"]\n | TypeLineChartProps[\"data\"]\n | TypeVerticalBarChartProps[\"data\"];\n numberLocale: Intl.LocalesArgument;\n seriesType: TypeSeriesType;\n textLocale: Intl.LocalesArgument;\n // optional\n currency?: string;\n disableTooltips?: boolean;\n numberFormat?: TypeChartNumberFormat;\n yAxisLabelFormatter?: TypeChartYAxisLabelFormatter;\n onClick?: ({ x }: Readonly<{ x: number }>) => void;\n timeFormat?: TypeChartTimeFormat;\n xAxisLabelFormatter?: (params: {\n textLocale: Intl.LocalesArgument;\n tickPositions: number[];\n unitName: string;\n value: number | string;\n timeFormat?: string;\n }) => string;\n};\nexport interface TypeExtendedChart extends Chart {\n // Highcharts doesn't include the annotations type by default, so we have to add it\n annotations?: Annotation[];\n}\n\nexport const useTimeSeriesChartOptions = ({\n xAnnotations,\n data,\n numberLocale,\n seriesType,\n textLocale,\n currency = \"USD\",\n disableTooltips = false,\n numberFormat = \"decimal\",\n yAxisLabelFormatter,\n onClick,\n timeFormat = \"12\",\n xAxisLabelFormatter,\n}: TypeUseTimeSeriesChartOptionsProps) => {\n const [chart, setChart] = useState<TypeExtendedChart | null>(null);\n\n const callback = useCallback((chartInstance: Chart) => {\n setChart(chartInstance);\n }, []);\n\n function attachTooltipEventListeners(series: Series[], tooltipId: string) {\n const handleFocus = (point: Point) =>\n point.series.chart.tooltip.refresh(point);\n const handleBlur = (point: Point) => point.series.chart.tooltip.hide(0);\n\n series\n .flatMap((item) => item.data)\n .forEach((point) => {\n const pointElement = point?.graphic?.element;\n if (pointElement) {\n pointElement.setAttribute(\"aria-describedby\", tooltipId);\n pointElement.addEventListener(\"focus\", () => handleFocus(point));\n pointElement.addEventListener(\"blur\", () => handleBlur(point));\n }\n });\n }\n\n const formattedXAnnotations = (annotations?: TypeChartXAnnotations) => {\n if (annotations) {\n return Object.entries(annotations).map(([x]) => ({\n point: {\n x: Number(x), // Convert key (which is a string) to a number\n y: 0,\n xAxis: 0,\n yAxis: 0,\n },\n text: \" \", // space is necessary because empty string reverts to showing default label\n }));\n }\n };\n\n const chartMarginTop = xAnnotations ? 24 : null;\n\n const getBaseChartOptions = (type: TypeSeriesType) => {\n switch (type) {\n case \"areaspline\":\n return areaChartOptions;\n case \"spline\":\n return lineChartOptions;\n case \"column\":\n return columnChartOptions;\n default:\n return lineChartOptions; // fallback to line chart as default\n }\n };\n\n const baseChartOptions = getBaseChartOptions(seriesType);\n\n // Detect if we have categorical data (string x values)\n const hasCategoricalData = data.some((series) =>\n series.points.some((point) => typeof point.x === \"string\")\n );\n\n // Extract categories for categorical data\n const categories = hasCategoricalData\n ? data[0]?.points.map((point) => point.x as string) || []\n : [];\n\n // Detect sparse timeline data (numerical x values with gaps that need wider columns)\n const hasSparseTimelineData = !hasCategoricalData && seriesType === \"column\";\n\n const options = useMemo(() => {\n return merge({}, baseChartOptions, {\n accessibility: {\n point: {\n descriptionFormatter: function () {\n return \" \"; // space is necessary because empty string reverts to defaults\n },\n },\n },\n annotations: [\n {\n labels: xAnnotations\n ? formattedXAnnotations(xAnnotations)\n : undefined,\n },\n ],\n chart: {\n marginTop: chartMarginTop,\n events: {\n click: onClick\n ? function (this: TypeExtendedChart) {\n return onClick({ x: this?.hoverPoint?.x as number });\n }\n : undefined,\n load: function (this: TypeExtendedChart) {\n const tooltipId = generateChartTooltipPortalId(this.index);\n attachTooltipEventListeners(this.series, tooltipId);\n },\n },\n },\n plotOptions: {\n areaspline: {\n events: {\n click:\n onClick && seriesType === \"areaspline\"\n ? function (event: SeriesClickEventObject) {\n return onClick({ x: event.point.x });\n }\n : undefined,\n },\n },\n spline: {\n events: {\n click:\n onClick && seriesType === \"spline\"\n ? function (event: SeriesClickEventObject) {\n return onClick({ x: event.point.x });\n }\n : undefined,\n },\n },\n column: {\n // For sparse timeline data, set explicit point width to make columns wider\n ...(hasSparseTimelineData && {\n pointWidth: 20, // Fixed width in pixels for sparse timeline data\n }),\n point: {\n events: {\n /*\n Custom hover behavior for multi-series column charts.\n\n In multi-series column charts, multiple columns\n can share the same x-axis position (stacked or grouped). When hovering\n over one column, we want ALL columns at that x-position to highlight\n together for better visual feedback. Simple CSS :hover only affects the\n individual element being hovered, not related columns at the same position.\n\n This custom behavior ensures that when you hover over any column at a\n specific x-position, all columns at that same position get the \"column-hover\"\n class, creating a unified highlight effect across all series.\n */\n click:\n onClick && seriesType === \"column\"\n ? function (event: SeriesClickEventObject) {\n return onClick({ x: event.point.x });\n }\n : undefined,\n mouseOver: function (this: any) {\n const x = this.x;\n if (\n this.series &&\n this.series.chart &&\n this.series.chart.series\n ) {\n this.series.chart.series.forEach((series: any) => {\n if (series.type === \"column\") {\n series.data.forEach((point: any) => {\n if (point.x === x) {\n const el = point.graphic && point.graphic.element;\n if (el) {\n el.classList.add(\"column-hover\");\n }\n }\n });\n }\n });\n }\n },\n mouseOut: function (this: any) {\n if (\n this.series &&\n this.series.chart &&\n this.series.chart.series\n ) {\n this.series.chart.series.forEach((series: any) => {\n if (series.type === \"column\") {\n series.data.forEach((point: any) => {\n const el = point.graphic && point.graphic.element;\n if (el) {\n el.classList.remove(\"column-hover\");\n }\n });\n }\n });\n }\n },\n },\n },\n },\n },\n series: transformDataToSeries({ data }, seriesType),\n tooltip: {\n enabled: !disableTooltips,\n },\n xAxis: {\n labels: {\n formatter: function (this: AxisLabelsFormatterContextObject) {\n const tickPositions = (this.axis.tickPositions || []).map(\n Number\n ) as number[];\n const value = this.value;\n const unitName = (this as ExtendedAxisLabelsFormatterContextObject)\n .tickPositionInfo?.unitName;\n if (typeof xAxisLabelFormatter === \"function\") {\n return xAxisLabelFormatter({\n textLocale,\n tickPositions,\n timeFormat,\n unitName,\n value,\n });\n }\n if (typeof xAxisLabelFormatterDefault === \"function\") {\n return xAxisLabelFormatterDefault({\n textLocale,\n tickPositions,\n timeFormat,\n unitName,\n value,\n });\n }\n return \"\";\n },\n },\n // Override xAxis type for categorical data\n ...(hasCategoricalData && {\n type: \"category\",\n categories,\n crosshair: false,\n }),\n },\n yAxis: {\n labels: {\n formatter: function (this: AxisLabelsFormatterContextObject) {\n return yAxisLabelFormatter\n ? yAxisLabelFormatter({\n y: this.value as number,\n yValues: this.axis.tickPositions as ReadonlyArray<number>,\n })\n : defaultYAxisLabelFormatter({\n currency,\n numberFormat,\n numberLocale,\n textLocale,\n tickPositions: this.axis.tickPositions || [],\n value: this.value,\n });\n },\n },\n },\n });\n }, [\n baseChartOptions,\n categories,\n currency,\n data,\n hasCategoricalData,\n hasSparseTimelineData,\n numberFormat,\n numberLocale,\n onClick,\n seriesType,\n textLocale,\n timeFormat,\n xAnnotations,\n yAxisLabelFormatter,\n xAxisLabelFormatter,\n ]);\n\n return { options, chart, callback };\n};\n\n// Alias the default formatter to avoid shadowing\nconst xAxisLabelFormatterDefault = xAxisLabelFormatter;\n","import type { Options } from \"highcharts\";\nimport _ from \"lodash\";\n\n// options that should apply to all charts\n// this is being exported because it's needed for the listening bubble chart component.\n// when that components gets moved into the data-viz package, we can remove the export here\nexport const baseChartOptions: Options = {\n chart: {\n animation: false,\n styledMode: true,\n },\n credits: {\n enabled: false,\n },\n exporting: {\n enabled: false,\n fallbackToExportServer: false,\n },\n legend: {\n enabled: false,\n },\n title: {\n text: undefined,\n },\n tooltip: {\n hideDelay: 0,\n outside: true,\n padding: 0,\n shape: \"rect\",\n shared: true,\n useHTML: true,\n },\n};\n\n// options that should apply to time series charts\nexport const TIME_SERIES_CHART_HEIGHT = 275;\nexport const timeSeriesChartOptions: Options = _.merge({}, baseChartOptions, {\n annotations: [\n {\n draggable: \"\",\n labelOptions: {\n useHTML: true,\n padding: 0, // removes \"left\" property padding created by highcharts so that label is centered\n },\n },\n ],\n chart: {\n // events.click is set at the component level because of the optional onClick prop\n height: TIME_SERIES_CHART_HEIGHT,\n spacing: [5, 1, 0, 2],\n },\n plotOptions: {\n series: {\n animation: false,\n clip: false,\n marker: {\n enabled: false,\n states: {\n hover: {\n enabled: false,\n },\n },\n },\n },\n },\n xAxis: {\n crosshair: {\n zIndex: 3,\n },\n minPadding: 0, // must be handled dynamically instead of css\n maxPadding: 0, // must be handled dynamically instead of css\n type: \"datetime\",\n labels: {\n useHTML: true,\n // formatter is set at the component level because of the required text locale prop\n },\n },\n yAxis: {\n labels: {\n useHTML: true,\n // formatter is set at the component level because of the optional yAxisLabelFormatter prop\n },\n softMax: 0,\n softMin: 0,\n title: {\n text: undefined,\n },\n plotLines: [\n /* Adds a custom plotLine at y=0 to represent the chart baseline.\n This approach allows full control over the line's appearance (e.g., color, z-index),\n unlike relying on the default xAxis line, which always renders at the bottom of the chart\n even when y=0 appears elsewhere (e.g., with negative values).\n */\n {\n className: \"y-axis-zero-line\",\n value: 0,\n zIndex: 3, // ensures the line appears over the default y=0 line, which we can't seleect as specifically\n },\n ],\n },\n});\n\n// options that should apply to LineChart\nexport const lineChartOptions: Options = _.merge({}, timeSeriesChartOptions, {\n // plotOptions.spline.events.click is set at the component level because of the optional onClick prop\n});\n\n// options that should apply to AreaChart\nexport const areaChartOptions: Options = _.merge({}, timeSeriesChartOptions, {\n plotOptions: {\n areaspline: {\n // events.click is set at the component level because of the optional onClick prop\n stacking: \"normal\",\n },\n },\n});\n\nexport const columnChartOptions: Options = _.merge({}, timeSeriesChartOptions, {\n plotOptions: {\n column: {\n stacking: \"normal\",\n pointPadding: 0.25,\n groupPadding: 0.25,\n borderRadius: 4,\n },\n },\n xAxis: {\n crosshair: false,\n },\n yAxis: {\n plotLines: [\n {\n // For stacked column charts with visible borders (e.g., white for contrast),\n // we raise the zIndex of the y=0 plotLine to ensure it remains visible\n // and isn't visually covered by overlapping column borders.\n zIndex: 5,\n },\n ],\n },\n});\n\n/**\n * The default series limit for VerticalBarChart.\n * This limit is recommended to maintain chart readability and accessibility.\n * @see {VerticalBarChart}\n */\nexport const VERTICAL_BAR_CHART_DEFAULT_SERIES_LIMIT = 10;\n\n// options that should apply to DonutChart\nexport const DONUT_CHART_HALO_SIZE = 10; // 10 is the default from highcharts\nexport const DONUT_CHART_HEIGHT = 250 + DONUT_CHART_HALO_SIZE * 2;\nexport const DONUT_CHART_WIDTH = DONUT_CHART_HEIGHT;\nexport const donutChartOptions: Options = _.merge({}, baseChartOptions, {\n chart: {\n height: DONUT_CHART_HEIGHT,\n spacing: [0, 0, 0, 0],\n },\n plotOptions: {\n pie: {\n animation: false,\n borderRadius: 0, // must be handled here instead of css because of path rendering\n dataLabels: {\n enabled: false,\n },\n innerSize: \"50%\",\n },\n },\n});\n","import { css, createGlobalStyle } from \"styled-components\";\nimport { theme } from \"@sproutsocial/seeds-react-theme\";\nimport {\n type TypeChartStyleColor,\n type TypeChartStyleHasOnClick,\n type TypeChartStylePattern,\n} from \"../types\";\nimport \"highcharts/css/highcharts.css\";\n\nexport const GlobalChartStyleOverrides = createGlobalStyle`\n // USAGE NOTE:\n // Put general styles in baseChartStyles instead when possible to avoid excessive global styling.\n // This global component is only for styles that can't override highcharts defaults when scoped.\n\n .highcharts-tooltip-container {\n z-index: 7 !important;\n }\n .highcharts-tooltip-box {\n fill: transparent !important;\n }\n`;\n\n// options that should apply to all charts\nexport const baseChartStyles = css<\n Readonly<{ $colors: ReadonlyArray<TypeChartStyleColor> }>\n>`\n --highcharts-background-color: ${({ theme }) =>\n theme.colors.container.background.base};\n\n // set color variables and map to each series\n ${({ $colors }) =>\n $colors\n .map((color, index) => {\n const chartColor = color || theme.colors.DATAVIZ_COLORS_LIST[index];\n return `\n\t\t\t\t// map colors to custom assigned colors or fallback to default data viz color rotation\n\t\t\t\t--highcharts-color-${index}: ${chartColor};\n\n\t\t\t\t// highcharts already accounts for 10 series, but if we have more, we need to add them\n\t\t\t\t.highcharts-color-${index} {\n\t\t\t\t\tcolor: var(--highcharts-color-${index});\n\t\t\t\t\tstroke: var(--highcharts-color-${index});\n\t\t\t\t\tfill: var(--highcharts-color-${index});\n\t\t\t\t}`;\n })\n .join(\"\\n\")}\n\n // set overall chart background color\n .highcharts-background {\n fill: ${({ theme }) => theme.colors.container.background.base};\n }\n\n g.highcharts-annotation-label {\n display: none;\n }\n\n div.highcharts-annotation-label {\n top: 0 !important;\n transform: translateX(-50%); // centers the label on the targeted axis point\n pointer-events: none; // prevents tooltip hover from being interrupted by this element since it renders after on the dom\n }\n`;\n\n// options that should apply to time series charts\nexport const timeSeriesChartStyles = css<\n Readonly<{\n $colors: ReadonlyArray<TypeChartStyleColor>;\n $hasOnClick: TypeChartStyleHasOnClick;\n }>\n>`\n ${baseChartStyles}\n\n // vertical crosshair styles\n\t.highcharts-crosshair {\n stroke: ${({ theme }) => theme.colors.container.border.decorative.neutral};\n stroke-width: 1;\n }\n\n // axis and gridline styles\n .highcharts-grid-line {\n stroke: ${({ theme }) => theme.colors.container.border.base};\n }\n\n .highcharts-axis-line {\n stroke: ${({ theme }) => theme.colors.container.border.base};\n }\n\n .highcharts-tick {\n stroke: none;\n }\n .highcharts-xaxis-labels,\n .highcharts-yaxis-labels {\n > span {\n font-family: ${({ theme }) => theme.fontFamily};\n ${({ theme }) => theme.typography[100]};\n font-weight: ${({ theme }) => theme.fontWeights.normal};\n color: ${({ theme }) => theme.colors.text.subtext};\n }\n }\n .highcharts-xaxis-labels {\n > span {\n display: flex;\n flex-direction: column;\n align-items: center;\n > span:nth-of-type(2) {\n font-weight: ${({ theme }) => theme.fontWeights.semibold};\n }\n }\n }\n\n // we don't want to drop the opacity when another item is hovered\n .highcharts-series-inactive {\n opacity: 1;\n }\n\n // apply cursor pointer when click functionality is turned on\n ${({ $hasOnClick }) =>\n $hasOnClick &&\n `\n \t\t\t.highcharts-series,\n \t\t\t.highcharts-point {\n \t\t\t\tcursor: pointer;\n \t\t\t}\n \t\t\t.highcharts-plot-background,\n \t\t\t.highcharts-crosshair,\n \t\t\t.highcharts-grid-line {\n \t\t\t\tfill: transparent;\n \t\t\t\tcursor: pointer;\n \t\t}`}\n\n path.highcharts-plot-line.y-axis-zero-line {\n stroke: ${({ theme }) => theme.colors.container.border.decorative.neutral};\n }\n`;\n\n// options that should apply to line charts\nexport const lineChartStyles = css<\n Readonly<{\n $colors: ReadonlyArray<TypeChartStyleColor>;\n $patterns: ReadonlyArray<TypeChartStylePattern>;\n $hasOnClick: TypeChartStyleHasOnClick;\n }>\n>`\n ${timeSeriesChartStyles}\n\n // set the line stroke\n\t.highcharts-graph {\n stroke-width: 3;\n }\n\n // dashed line styles\n ${({ $patterns }) =>\n $patterns.map((pattern, index) => {\n return pattern === \"dashed\"\n ? `\n \t\t\t\t\t// highcharts already accounts for 10 series, but if we have more, we need to add them\n \t\t\t\t\t.highcharts-series-${index} {\n \t\t\t\t\t\tstroke-dasharray: 2, 8;\n \t\t\t\t\t}`\n : \"\";\n })}\n`;\n\n// options that should apply to area charts\nexport const areaChartStyles = css`\n ${timeSeriesChartStyles}\n\n // don't need to show a stroke for the line part of each area\n\t.highcharts-graph {\n stroke-width: 0;\n }\n\n // fill areas to full opacity\n .highcharts-area {\n fill-opacity: 1;\n }\n`;\n\n// options that should apply to donut charts\nexport const donutChartStyles = css<\n Readonly<{\n $colors: ReadonlyArray<TypeChartStyleColor>;\n $hasOnClick: TypeChartStyleHasOnClick;\n }>\n>`\n ${baseChartStyles}\n\n // remove 250ms fade in/out when hovering over different donut chart slices\n\t.highcharts-point {\n transition: opacity 0s;\n }\n\n // remove stroke on donut slices\n .highcharts-pie-series .highcharts-point {\n stroke: none;\n }\n\n // don't reduce opacity when hovering\n .highcharts-point-hover {\n fill-opacity: none;\n }\n\n // apply cursor pointer when click functionality is turned on\n ${({ $hasOnClick }) =>\n $hasOnClick &&\n `\n \t\t\t.highcharts-series,\n \t\t\t.highcharts-point {\n \t\t\t\tcursor: pointer;\n \t\t\t}\n \t\t\t.highcharts-plot-background,\n \t\t\t.highcharts-crosshair,\n \t\t\t.highcharts-grid-line {\n \t\t\t\tfill: transparent;\n \t\t\t\tcursor: pointer;\n \t\t}`}\n`;\n","import { memo } from \"react\";\nimport { Box } from \"@sproutsocial/seeds-react-box\";\nimport { Icon, type TypeIconName } from \"@sproutsocial/seeds-react-icon\";\nimport { Text } from \"@sproutsocial/seeds-react-text\";\nimport { ChartTooltipHeader } from \"../ChartTooltip\";\n\ntype TypeChartXAnnotationDetailsProps = Readonly<{\n iconName: TypeIconName;\n text: string;\n}>;\n\nexport const ChartXAnnotationDetails = memo<TypeChartXAnnotationDetailsProps>(\n ({ iconName, text }) => {\n return (\n <ChartTooltipHeader>\n <Box display=\"flex\" alignItems=\"center\" gap={300}>\n <Icon name={iconName} size=\"mini\" color=\"icon.base\" />\n <Text color=\"text.body\" fontSize={200}>\n {text}\n </Text>\n </Box>\n </ChartTooltipHeader>\n );\n }\n);\n","import { memo } from \"react\";\nimport { Box } from \"@sproutsocial/seeds-react-box\";\nimport { Icon, type TypeIconName } from \"@sproutsocial/seeds-react-icon\";\nimport ThemeProvider from \"@sproutsocial/seeds-react-theme-provider\";\n\ntype TypeChartXAnnotationMarkerProps = Readonly<{\n iconName: TypeIconName;\n}>;\n\nexport const ChartXAnnotationMarker = memo<TypeChartXAnnotationMarkerProps>(\n ({ iconName }) => {\n return (\n <Box display=\"flex\" flexDirection=\"column\" alignItems=\"center\" gap={200}>\n <Box\n display=\"flex\"\n alignItems=\"center\"\n justifyContent=\"center\"\n width=\"20px\"\n height=\"20px\"\n bg=\"icon.base\"\n borderRadius=\"50%\"\n >\n <Icon name={iconName} size=\"mini\" color=\"icon.inverse\" />\n </Box>\n {/* Marker line height is hard coded for simplicity since chart height is hard coded. If that changes, we'll need to make this dynamic */}\n <Box height={`199px`} width=\"0.5px\" bg=\"neutral.200\" />\n </Box>\n );\n }\n);\n","import { memo, useState, useEffect, useCallback, type ReactNode } from \"react\";\nimport Highcharts, { type Chart, type Options } from \"highcharts\";\nimport { HighchartsReact } from \"highcharts-react-official\";\nimport highchartsAccessibility from \"highcharts/modules/accessibility\";\nimport styled from \"styled-components\";\nimport { Box } from \"@sproutsocial/seeds-react-box\";\n\nimport { DonutChartLegend } from \"./components/DonutChartLegend\";\nimport { DonutChartTooltip } from \"./components/DonutChartTooltip\";\nimport { transformDonutChartTooltipData } from \"./helpers/transformDonutChartTooltipData\";\n\nimport {\n ChartTooltipPortal,\n generateChartTooltipPortalId,\n} from \"../ChartTooltip/components/ChartTooltipPortal\";\nimport { donutChartOptions } from \"../../constants/chartOptions\";\nimport { GlobalChartStyleOverrides, donutChartStyles } from \"../../styles\";\nimport type { TypeChartDataStyles, TypeChartNumberFormat } from \"../../types\";\nimport { theme } from \"@sproutsocial/seeds-react-theme\";\n\n// init modules\nhighchartsAccessibility(Highcharts);\n\n// styled components\nconst StyledBox = styled(Box)`\n ${donutChartStyles}\n`;\n\n// types\nexport type TypeDonutChartTooltipProps = Readonly<{\n color: string;\n name: string;\n percent: number | null;\n value: number | null;\n // optional\n icon?: ReactNode;\n}>;\n\nexport type TypeDonutChartDataItem = Readonly<{\n name: string;\n value: number;\n // optional\n key?: string;\n icon?: ReactNode;\n styles?: TypeChartDataStyles;\n}>;\n\nexport type TypeDonutChartProps = Readonly<{\n data: ReadonlyArray<TypeDonutChartDataItem>;\n numberLocale: Intl.LocalesArgument;\n textLocale: Intl.LocalesArgument;\n // optional\n currency?: string;\n disableTooltips?: boolean;\n hideLegend?: boolean;\n numberFormat?: TypeChartNumberFormat;\n tooltip?: ({\n color,\n name,\n percent,\n value,\n }: TypeDonutChartTooltipProps) => ReactNode;\n onClick?: (data: Readonly<{ x: string } & TypeDonutChartDataItem>) => void;\n tooltipClickLabel?: ReactNode;\n}>;\n\nexport const DonutChart = memo<TypeDonutChartProps>(function DonutChart(\n props: TypeDonutChartProps\n) {\n const { data } = props;\n\n return data.length === 0 ? null : <DonutChartWithData {...props} />;\n});\n\nconst DonutChartWithData = memo<TypeDonutChartProps>(\n function DonutChartWithData({\n data,\n numberLocale = \"en-us\",\n textLocale = \"en-us\",\n // optional\n currency = \"USD\",\n disableTooltips = false,\n hideLegend = false,\n numberFormat = \"decimal\",\n tooltip,\n onClick,\n tooltipClickLabel,\n }: TypeDonutChartProps) {\n const [options, setOptions] = useState<Options>(donutChartOptions);\n const [chart, setChart] = useState<Chart | null>(null);\n\n const callback = useCallback((chartInstance: Chart) => {\n setChart(chartInstance);\n }, []);\n\n useEffect(() => {\n setOptions({\n accessibility: {\n point: {\n descriptionFormatter: function () {\n return \" \"; // space is necessary because empty string reverts to defaults\n },\n },\n },\n chart: {\n events: {\n render: function () {\n const allSlices = this.series[0]?.data ?? [];\n const tooltipId = generateChartTooltipPortalId(this.index);\n\n allSlices.forEach((slice) => {\n const sliceElement = slice?.graphic?.element;\n sliceElement?.setAttribute(\"aria-describedby\", tooltipId);\n\n // Update tooltip on focus\n sliceElement?.addEventListener(\"focus\", () => {\n slice.series.chart.tooltip.refresh(slice);\n });\n\n // Hide tooltip on blur\n sliceElement?.addEventListener(\"blur\", () => {\n slice.series.chart.tooltip.hide(0);\n });\n });\n },\n },\n },\n series: [\n {\n type: \"pie\",\n data: data.map((item, index) => {\n return {\n name: item.name,\n y: item.value,\n colorIndex: index,\n events: onClick\n ? {\n click: function () {\n onClick({ x: item.name, ...item });\n },\n }\n : undefined,\n };\n }),\n },\n ],\n tooltip: {\n enabled: !disableTooltips,\n },\n });\n }, [data]);\n\n const colors = data.map(\n (series, index) =>\n series.styles?.color ?? theme.colors.DATAVIZ_COLORS_LIST[index] ?? \"\"\n );\n\n return (\n <>\n <GlobalChartStyleOverrides />\n <StyledBox\n $colors={colors}\n $hasOnClick={Boolean(onClick)}\n bg=\"container.background.base\"\n >\n <HighchartsReact\n highcharts={Highcharts}\n options={options}\n callback={callback}\n />\n {chart && !disableTooltips ? (\n <ChartTooltipPortal\n chart={chart}\n renderContent={(context) => {\n const { color, icon, name, percent, value } =\n transformDonutChartTooltipData({ context, data });\n\n return tooltip ? (\n tooltip({ color, icon, name, percent, value })\n ) : (\n <DonutChartTooltip\n color={color}\n currency={currency}\n icon={icon}\n name={name}\n numberFormat={numberFormat}\n numberLocale={numberLocale}\n percent={percent}\n textLocale={textLocale}\n value={value}\n onClick={onClick}\n tooltipClickLabel={tooltipClickLabel}\n />\n );\n }}\n />\n ) : null}\n {hideLegend ? null : (\n <Box mt={350}>\n <DonutChartLegend data={data} />\n </Box>\n )}\n </StyledBox>\n </>\n );\n }\n);\n","import { memo } from \"react\";\nimport { theme } from \"@sproutsocial/seeds-react-theme\";\n\nimport type { TypeDonutChartProps } from \"../DonutChart\";\nimport { ChartLegend, type TypeChartLegendProps } from \"../../ChartLegend\";\nimport { ChartLegendLabelContentWithIcon } from \"../../ChartLegend/components/ChartLegendLabelContentWithIcon\";\n\n// exported for testing\nexport const getDonutChartLegendLabels = ({\n data,\n}: Readonly<{\n data: TypeDonutChartProps[\"data\"];\n}>): TypeChartLegendProps[\"legendLabels\"] => {\n return data.map((slice, index) => ({\n content: (\n <ChartLegendLabelContentWithIcon icon={slice.icon}>\n {slice.name}\n </ChartLegendLabelContentWithIcon>\n ),\n color: slice.styles?.color || theme.colors.DATAVIZ_COLORS_LIST[index],\n }));\n};\n\ntype TypeDonutChartLegendProps = Readonly<{\n data: TypeDonutChartProps[\"data\"];\n}>;\n\nexport const DonutChartLegend = memo<TypeDonutChartLegendProps>(\n function DonutChartLegend({ data }: TypeDonutChartLegendProps) {\n return <ChartLegend legendLabels={getDonutChartLegendLabels({ data })} />;\n }\n);\n","import { memo } from \"react\";\nimport { Box } from \"@sproutsocial/seeds-react-box\";\nimport { Duration } from \"@sproutsocial/seeds-react-duration\";\nimport { Icon } from \"@sproutsocial/seeds-react-icon\";\nimport { Numeral } from \"@sproutsocial/seeds-react-numeral\";\nimport { Text } from \"@sproutsocial/seeds-react-text\";\n\nimport {\n ChartTooltip,\n ChartTooltipFooter,\n ChartTooltipTable,\n type TypeChartTooltipTableProps,\n} from \"../../ChartTooltip\";\nimport type {\n TypeDonutChartProps,\n TypeDonutChartTooltipProps as TypeDonutTooltipProps,\n} from \"../../DonutChart\";\nimport { ChartLegendLabel } from \"../../ChartLegend/components/ChartLegendLabel\";\nimport { ChartLegendLabelContentWithIcon } from \"../../ChartLegend/components/ChartLegendLabelContentWithIcon\";\n\nexport type TypeDonutChartTooltipProps = Readonly<{\n color: TypeDonutTooltipProps[\"color\"];\n name: TypeDonutTooltipProps[\"name\"];\n numberLocale: TypeDonutChartProps[\"numberLocale\"];\n percent: TypeDonutTooltipProps[\"percent\"];\n textLocale: TypeDonutChartProps[\"textLocale\"];\n value: TypeDonutTooltipProps[\"value\"];\n // optional\n currency?: TypeDonutChartProps[\"currency\"];\n icon?: TypeDonutTooltipProps[\"icon\"];\n numberFormat?: TypeDonutChartProps[\"numberFormat\"];\n onClick?: TypeDonutChartProps[\"onClick\"];\n tooltipClickLabel?: TypeDonutChartProps[\"tooltipClickLabel\"];\n}>;\n\nexport const DonutChartTooltip = memo<TypeDonutChartTooltipProps>(\n function DonutChartTooltip({\n color,\n name,\n numberLocale,\n percent,\n textLocale,\n value,\n currency,\n icon,\n numberFormat,\n onClick,\n tooltipClickLabel,\n }: TypeDonutChartTooltipProps) {\n const rows = [\n {\n cells: [\n {\n content: (\n <ChartLegendLabel color={color}>\n <ChartLegendLabelContentWithIcon icon={icon}>\n <Text aria-label={`${name}: `}>{name}</Text>\n </ChartLegendLabelContentWithIcon>\n </ChartLegendLabel>\n ),\n },\n {\n content: (\n <Box display=\"inline-flex\" alignItems=\"center\" gap={350}>\n <Numeral\n number={percent}\n format=\"percent\"\n abbreviate={false}\n locale={numberLocale as string}\n />\n <Text fontWeight=\"semibold\">\n {numberFormat === \"duration\" ? (\n <Duration locale={textLocale} milliseconds={value} />\n ) : (\n <Numeral\n abbreviate={false}\n currency={currency}\n format={numberFormat}\n locale={numberLocale as string}\n number={value}\n />\n )}\n </Text>\n </Box>\n ),\n align: \"right\",\n },\n ],\n },\n ];\n\n return (\n <ChartTooltip>\n <ChartTooltipTable rows={rows as TypeChartTooltipTableProps[\"rows\"]} />\n {onClick && tooltipClickLabel ? (\n <ChartTooltipFooter>\n {typeof tooltipClickLabel === \"string\" ? (\n <Box display=\"flex\" alignItems=\"center\" gap={300}>\n <Icon name=\"hand-pointer-clicking-outline\" color=\"icon.base\" />\n <Text color=\"text.subtext\" fontSize={200}>\n {tooltipClickLabel}\n </Text>\n </Box>\n ) : (\n tooltipClickLabel\n )}\n </ChartTooltipFooter>\n ) : null}\n </ChartTooltip>\n );\n }\n);\n","import type { TooltipFormatterContextObject } from \"highcharts\";\nimport { theme } from \"@sproutsocial/seeds-react-theme\";\n\nimport type {\n TypeDonutChartProps,\n TypeDonutChartTooltipProps,\n} from \"../DonutChart\";\n\ntype TypeTransformDonutChartTooltipDataProps = Readonly<{\n context: TooltipFormatterContextObject;\n data: TypeDonutChartProps[\"data\"];\n}>;\ntype TypeTransformDonutChartTooltipDataReturn = TypeDonutChartTooltipProps;\n\nexport const transformDonutChartTooltipData = ({\n context,\n data,\n}: TypeTransformDonutChartTooltipDataProps): TypeTransformDonutChartTooltipDataReturn => {\n const colorIndex = context.colorIndex;\n\n return {\n color:\n data[colorIndex]?.styles?.color ??\n theme.colors.DATAVIZ_COLORS_LIST[colorIndex] ??\n \"\",\n ...(data[colorIndex]?.icon ? { icon: data[colorIndex]?.icon } : {}),\n name: context.key as string,\n percent: context.percentage,\n value: context.y as number,\n };\n};\n","import { memo } from \"react\";\nimport { Box } from \"@sproutsocial/seeds-react-box\";\nimport { Duration } from \"@sproutsocial/seeds-react-duration\";\nimport { Numeral } from \"@sproutsocial/seeds-react-numeral\";\nimport { Text } from \"@sproutsocial/seeds-react-text\";\nimport { theme } from \"@sproutsocial/seeds-react-theme\";\n\nimport type { TypeDonutChartProps } from \"..\";\nimport { ChartTable, type TypeChartTableProps } from \"../../ChartTable\";\nimport { ChartLegendLabel } from \"../../ChartLegend/components/ChartLegendLabel\";\nimport { ChartLegendLabelContentWithIcon } from \"../../ChartLegend/components/ChartLegendLabelContentWithIcon\";\n\nexport type TypeDonutChartLegendTableProps = Readonly<{\n data: TypeDonutChartProps[\"data\"];\n numberLocale: TypeDonutChartProps[\"numberLocale\"];\n textLocale: TypeDonutChartProps[\"textLocale\"];\n totalLabel: React.ReactNode;\n // optional\n currency?: TypeDonutChartProps[\"currency\"];\n numberFormat?: TypeDonutChartProps[\"numberFormat\"];\n}>;\n\nexport const DonutChartLegendTable = memo<TypeDonutChartLegendTableProps>(\n function DonutChartLegendTable({\n data,\n numberLocale = \"en-us\",\n textLocale = \"en-us\",\n totalLabel,\n // optional\n currency = \"USD\",\n numberFormat = \"decimal\",\n }: TypeDonutChartLegendTableProps) {\n const total = data.reduce(\n (accumulator, dataItem) => accumulator + dataItem.value,\n 0\n );\n\n const rows = data.map((dataPoint, index) => {\n const { name, icon, styles, value } = dataPoint;\n const color = styles?.color || theme.colors.DATAVIZ_COLORS_LIST[index];\n\n return {\n cells: [\n {\n content: (\n <ChartLegendLabel color={color}>\n <ChartLegendLabelContentWithIcon icon={icon}>\n {name}\n </ChartLegendLabelContentWithIcon>\n </ChartLegendLabel>\n ),\n },\n {\n content: (\n <Box display=\"inline-flex\" alignItems=\"center\" gap={350}>\n <Text color=\"text.body\">\n <Numeral\n abbreviate={false}\n format=\"percent\"\n locale={numberLocale as string}\n number={(value / total) * 100}\n />\n </Text>\n <Text color=\"text.body\" fontWeight=\"semibold\">\n {numberFormat === \"duration\" ? (\n <Duration locale={textLocale} milliseconds={value} />\n ) : (\n <Numeral\n abbreviate={false}\n currency={currency}\n format={numberFormat}\n locale={numberLocale as string}\n number={value}\n />\n )}\n </Text>\n </Box>\n ),\n align: \"right\",\n },\n ],\n };\n });\n\n const totalRow = [\n {\n cells: [\n {\n content: (\n <Text fontWeight=\"semibold\" color=\"text.headline\">\n {totalLabel}\n </Text>\n ),\n },\n {\n content: (\n <Text color=\"text.body\" fontWeight=\"bold\">\n {numberFormat === \"duration\" ? (\n <Duration locale={textLocale} milliseconds={total} />\n ) : (\n <Numeral\n abbreviate={false}\n currency={currency}\n format={numberFormat}\n locale={numberLocale as string}\n number={total}\n />\n )}\n </Text>\n ),\n align: \"right\",\n },\n ],\n isAppendedRow: true,\n },\n ];\n\n return (\n <ChartTable\n rows={[...rows, ...totalRow] as TypeChartTableProps[\"rows\"]}\n />\n );\n }\n);\n","import { memo, type ReactNode } from \"react\";\nimport Highcharts, { type AnnotationsOptions } from \"highcharts\";\nimport { HighchartsReact } from \"highcharts-react-official\";\nimport highchartsAccessibility from \"highcharts/modules/accessibility\";\nimport highchartsAnnotations from \"highcharts/modules/annotations\";\nimport styled from \"styled-components\";\nimport { Box } from \"@sproutsocial/seeds-react-box\";\n\nimport { LineChartLegend } from \"./components/LineChartLegend\";\nimport { LineChartTooltip } from \"./components/LineChartTooltip\";\n\nimport { ChartTooltipPortal } from \"../ChartTooltip/components/ChartTooltipPortal\";\nimport { transformTimeSeriesTooltipData } from \"../../helpers\";\nimport { useTimeSeriesChartOptions } from \"../../hooks\";\nimport { GlobalChartStyleOverrides, lineChartStyles } from \"../../styles\";\nimport type {\n TypeChartDataPoint,\n TypeChartDataStyles,\n TypeChartNumberFormat,\n TypeChartStyleColor,\n TypeChartStylePattern,\n TypeChartTimeFormat,\n TypeChartTooltipDateFormatter,\n TypeChartTooltipProps,\n TypeChartYAxisLabelFormatter,\n TypeChartXAnnotations,\n} from \"../../types\";\nimport { theme } from \"@sproutsocial/seeds-react-theme\";\nimport { ChartXAnnotationMarkerPortal } from \"../ChartXAnnotationMarker/components/ChartXAnnotationMarkerPortal\";\n\n// init modules\nhighchartsAccessibility(Highcharts);\nhighchartsAnnotations(Highcharts);\n\n// styled components\nconst StyledBox = styled(Box)`\n ${lineChartStyles}\n`;\n\n// types\nexport type TypeLineChartProps = Readonly<{\n data: ReadonlyArray<\n Readonly<{\n name: string;\n points: ReadonlyArray<TypeChartDataPoint>;\n // optional\n icon?: ReactNode;\n styles?: TypeChartDataStyles &\n Readonly<{ pattern?: TypeChartStylePattern }>;\n }>\n >;\n invalidNumberLabel: ReactNode;\n numberLocale: Intl.LocalesArgument;\n textLocale: Intl.LocalesArgument;\n tooltipDateFormatter: TypeChartTooltipDateFormatter;\n // optional\n currency?: string;\n disableTooltips?: boolean;\n numberFormat?: TypeChartNumberFormat;\n tooltip?: ({ data, x }: TypeChartTooltipProps) => ReactNode;\n yAxisLabelFormatter?: TypeChartYAxisLabelFormatter;\n onClick?: ({ x }: Readonly<{ x: number }>) => void;\n tooltipClickLabel?: ReactNode;\n timeFormat?: TypeChartTimeFormat;\n xAnnotations?: TypeChartXAnnotations;\n xAxisLabelFormatter?: (params: {\n textLocale: Intl.LocalesArgument;\n tickPositions: number[];\n unitName: string;\n value: string | number;\n timeFormat?: string;\n }) => string;\n}>;\n\nexport const LineChart = memo<TypeLineChartProps>(function LineChart(\n props: TypeLineChartProps\n) {\n const { data } = props;\n\n return data.length === 0 ? null : <LineChartWithData {...props} />;\n});\n\nconst LineChartWithData = memo<TypeLineChartProps>(function LineChartWithData({\n data,\n invalidNumberLabel,\n numberLocale = \"en-us\",\n textLocale = \"en-us\",\n tooltipDateFormatter,\n // optional\n currency = \"USD\",\n disableTooltips = false,\n numberFormat = \"decimal\",\n tooltip,\n yAxisLabelFormatter,\n onClick,\n tooltipClickLabel,\n timeFormat = \"12\",\n xAnnotations,\n xAxisLabelFormatter,\n}: TypeLineChartProps) {\n const { options, chart, callback } = useTimeSeriesChartOptions({\n currency,\n data,\n disableTooltips,\n numberFormat,\n numberLocale,\n seriesType: \"spline\",\n textLocale,\n yAxisLabelFormatter,\n onClick,\n timeFormat,\n xAnnotations,\n xAxisLabelFormatter,\n });\n\n const { colors, patterns } = data.reduce(\n (acc, item, index) => {\n // @ts-ignore\n acc.colors.push(\n item.styles?.color ?? theme.colors.DATAVIZ_COLORS_LIST[index] ?? \"\"\n );\n acc.patterns.push(item.styles?.pattern ?? \"solid\");\n return acc;\n },\n {\n colors: [] as TypeChartStyleColor[],\n patterns: [] as TypeChartStylePattern[],\n }\n );\n\n return (\n <>\n <GlobalChartStyleOverrides />\n <StyledBox\n $colors={colors}\n $patterns={patterns}\n $hasOnClick={Boolean(onClick)}\n bg=\"container.background.base\"\n >\n <HighchartsReact\n highcharts={Highcharts}\n options={options}\n callback={callback}\n />\n {chart && chart.annotations?.length ? (\n <ChartXAnnotationMarkerPortal\n xAnnotations={xAnnotations}\n annotationContext={chart.annotations?.[0] as AnnotationsOptions}\n />\n ) : null}\n {chart && !disableTooltips ? (\n <ChartTooltipPortal\n chart={chart}\n renderContent={(context) => {\n const tooltipData = transformTimeSeriesTooltipData({\n context,\n data,\n });\n const x = context.x as number;\n\n const xAnnotationDetails = xAnnotations?.[x]?.details;\n\n return tooltip ? (\n tooltip({ data: tooltipData, x })\n ) : (\n <LineChartTooltip\n currency={currency}\n data={tooltipData}\n invalidNumberLabel={invalidNumberLabel}\n numberFormat={numberFormat}\n numberLocale={numberLocale}\n textLocale={textLocale}\n tooltipDateFormatter={tooltipDateFormatter}\n onClick={onClick}\n tooltipClickLabel={tooltipClickLabel}\n x={x}\n xAnnotationDetails={xAnnotationDetails}\n />\n );\n }}\n />\n ) : null}\n <Box mt={350}>\n <LineChartLegend data={data} />\n </Box>\n </StyledBox>\n </>\n );\n});\n","import { memo } from \"react\";\nimport { theme } from \"@sproutsocial/seeds-react-theme\";\n\nimport type { TypeLineChartProps } from \"../LineChart\";\nimport { ChartLegend, type TypeChartLegendProps } from \"../../ChartLegend\";\nimport { ChartLegendLabelContentWithIcon } from \"../../ChartLegend/components/ChartLegendLabelContentWithIcon\";\n\n// exported for testing\nexport const getLineChartLegendLabels = ({\n data,\n}: Readonly<{\n data: TypeLineChartProps[\"data\"];\n}>): TypeChartLegendProps[\"legendLabels\"] => {\n return data.map((series, index) => ({\n content: (\n <ChartLegendLabelContentWithIcon icon={series.icon}>\n {series.name}\n </ChartLegendLabelContentWithIcon>\n ),\n color: series.styles?.color || theme.colors.DATAVIZ_COLORS_LIST[index],\n }));\n};\n\ntype TypeLineChartLegendProps = Readonly<{\n data: TypeLineChartProps[\"data\"];\n}>;\n\nexport const LineChartLegend = memo<TypeLineChartLegendProps>(\n function LineChartLegend({ data }: TypeLineChartLegendProps) {\n return <ChartLegend legendLabels={getLineChartLegendLabels({ data })} />;\n }\n);\n","import { memo } from \"react\";\nimport { Box } from \"@sproutsocial/seeds-react-box\";\nimport { Duration } from \"@sproutsocial/seeds-react-duration\";\nimport { Icon } from \"@sproutsocial/seeds-react-icon\";\nimport { Numeral } from \"@sproutsocial/seeds-react-numeral\";\nimport { Text } from \"@sproutsocial/seeds-react-text\";\n\nimport type { TypeLineChartProps } from \"../LineChart\";\n\nimport {\n ChartTooltip,\n ChartTooltipFooter,\n ChartTooltipTable,\n ChartTooltipTitle,\n type TypeChartTooltipTableProps,\n} from \"../../ChartTooltip\";\nimport type {\n TypeChartTooltipProps,\n TypeChartXAnnotationsDetails,\n} from \"../../../types\";\nimport { ChartLegendLabel } from \"../../ChartLegend/components/ChartLegendLabel\";\nimport { ChartLegendLabelContentWithIcon } from \"../../ChartLegend/components/ChartLegendLabelContentWithIcon\";\n\nexport type TypeLineChartTooltipProps = Readonly<{\n data: TypeChartTooltipProps[\"data\"];\n invalidNumberLabel: TypeLineChartProps[\"invalidNumberLabel\"];\n numberLocale: TypeLineChartProps[\"numberLocale\"];\n textLocale: TypeLineChartProps[\"textLocale\"];\n tooltipDateFormatter: TypeLineChartProps[\"tooltipDateFormatter\"];\n x: TypeChartTooltipProps[\"x\"];\n // optional\n currency?: TypeLineChartProps[\"currency\"];\n numberFormat?: TypeLineChartProps[\"numberFormat\"];\n onClick?: TypeLineChartProps[\"onClick\"];\n tooltipClickLabel?: TypeLineChartProps[\"tooltipClickLabel\"];\n xAnnotationDetails?: TypeChartXAnnotationsDetails;\n}>;\n\nexport const LineChartTooltip = memo<TypeLineChartTooltipProps>(\n function LineChartTooltip({\n data,\n invalidNumberLabel,\n numberLocale,\n textLocale,\n tooltipDateFormatter,\n x,\n // optional\n currency = \"USD\",\n numberFormat = \"decimal\",\n onClick,\n tooltipClickLabel,\n xAnnotationDetails,\n }: TypeLineChartTooltipProps) {\n const rows = data.map(({ color, icon, name, value }) => {\n return {\n cells: [\n {\n content: (\n <ChartLegendLabel color={color}>\n <ChartLegendLabelContentWithIcon icon={icon}>\n <Text aria-label={`${name}: `}>{name}</Text>\n </ChartLegendLabelContentWithIcon>\n </ChartLegendLabel>\n ),\n },\n {\n content:\n value === null && invalidNumberLabel ? (\n <Text>{invalidNumberLabel}</Text>\n ) : numberFormat === \"duration\" ? (\n <Duration locale={textLocale} milliseconds={value} />\n ) : (\n <Numeral\n abbreviate={false}\n currency={currency}\n format={numberFormat}\n locale={numberLocale as string}\n number={value}\n />\n ),\n align: \"right\",\n },\n ],\n };\n });\n\n return (\n <ChartTooltip>\n {xAnnotationDetails ? xAnnotationDetails() : undefined}\n <ChartTooltipTitle>{tooltipDateFormatter({ x })}</ChartTooltipTitle>\n <ChartTooltipTable rows={rows as TypeChartTooltipTableProps[\"rows\"]} />\n {onClick && tooltipClickLabel ? (\n <ChartTooltipFooter>\n {typeof tooltipClickLabel === \"string\" ? (\n <Box display=\"flex\" alignItems=\"center\" gap={300}>\n <Icon name=\"hand-pointer-clicking-outline\" color=\"icon.base\" />\n <Text color=\"text.subtext\" fontSize={200}>\n {tooltipClickLabel}\n </Text>\n </Box>\n ) : (\n tooltipClickLabel\n )}\n </ChartTooltipFooter>\n ) : null}\n </ChartTooltip>\n );\n }\n);\n","import { memo, type ReactNode } from \"react\";\nimport Highcharts, { type AnnotationsOptions } from \"highcharts\";\nimport { HighchartsReact } from \"highcharts-react-official\";\nimport highchartsAccessibility from \"highcharts/modules/accessibility\";\nimport highchartsAnnotations from \"highcharts/modules/annotations\";\nimport styled from \"styled-components\";\nimport { Box } from \"@sproutsocial/seeds-react-box\";\n\nimport { VerticalBarChartLegend } from \"./components/VerticalBarChartLegend\";\nimport { VerticalBarChartTooltip } from \"./components/VerticalBarChartTooltip\";\n\nimport { ChartTooltipPortal } from \"../ChartTooltip/components/ChartTooltipPortal\";\nimport {\n transformTimeSeriesTooltipData,\n isHourlyTimeData,\n isCategoricalHourData,\n} from \"../../helpers\";\nimport { useTimeSeriesChartOptions } from \"../../hooks\";\nimport { GlobalChartStyleOverrides } from \"../../styles\";\nimport type {\n TypeChartStyleColor,\n TypeChartStylePattern,\n TypeVerticalBarChartProps,\n} from \"../../types\";\nimport { theme } from \"@sproutsocial/seeds-react-theme\";\nimport { ChartXAnnotationMarkerPortal } from \"../ChartXAnnotationMarker/components/ChartXAnnotationMarkerPortal\";\nimport { verticalBarChartStyles } from \"./styles\";\nimport { VERTICAL_BAR_CHART_DEFAULT_SERIES_LIMIT } from \"../../constants\";\n\n// init modules\nhighchartsAccessibility(Highcharts);\nhighchartsAnnotations(Highcharts);\n\n// styled components\nconst StyledBox = styled(Box)`\n ${verticalBarChartStyles}\n`;\n\nexport const VerticalBarChart = memo<TypeVerticalBarChartProps>(\n function VerticalBarChart(props: TypeVerticalBarChartProps) {\n const { data, showSeriesLimitWarning = true } = props;\n const seriesLimit =\n props.seriesLimit ?? VERTICAL_BAR_CHART_DEFAULT_SERIES_LIMIT;\n const isSeriesLimitOverridden = props.seriesLimit !== undefined;\n\n if (data.length === 0) {\n return null;\n }\n\n let chartData = data;\n if (data.length > seriesLimit) {\n if (!isSeriesLimitOverridden && showSeriesLimitWarning) {\n console.warn(\n `VerticalBarChart: Maximum number of series (${seriesLimit}) exceeded. Only the first ${seriesLimit} series will be displayed.`\n );\n }\n chartData = data.slice(0, seriesLimit);\n }\n\n return <VerticalBarChartWithData {...props} data={chartData} />;\n }\n);\n\nconst VerticalBarChartWithData = memo<TypeVerticalBarChartProps>(\n function VerticalBarChartWithData({\n data,\n invalidNumberLabel,\n numberLocale = \"en-us\",\n textLocale = \"en-us\",\n tooltipDateFormatter,\n // optional\n currency = \"USD\",\n numberFormat = \"decimal\",\n tooltip,\n yAxisLabelFormatter,\n onClick,\n tooltipClickLabel,\n timeFormat = \"12\",\n xAnnotations,\n xAxisLabelFormatter,\n }: TypeVerticalBarChartProps) {\n // Automatically use time-of-day formatter if data is hourly (timestamp) or categorical hour data\n const shouldUseTimeFormatter =\n isHourlyTimeData(data) || isCategoricalHourData(data);\n\n const autoTimeXAxisLabelFormatter = ({\n value,\n timeFormat,\n }: {\n textLocale: Intl.LocalesArgument;\n tickPositions: number[];\n unitName: string;\n value: string | number;\n timeFormat?: string;\n }) => {\n // Handle categorical hour data (strings)\n if (typeof value === \"string\") {\n // Handle 12-hour format (e.g., \"12 AM\", \"1 PM\")\n const hour12Match = value.match(/^(\\d{1,2}) (AM|PM)$/);\n if (hour12Match) {\n const [, hourStr = \"0\", period = \"\"] = hour12Match;\n const hour = parseInt(hourStr, 10);\n if (hour === 12) return `<span>12</span><span>${period}</span>`;\n return `<span>${hour}</span>`;\n }\n\n // Handle 24-hour format (e.g., \"00:00\", \"13:00\", \"23:00\")\n const hour24Match = value.match(/^([01]?\\d|2[0-3]):([0-5]\\d)$/);\n if (hour24Match) {\n const [, hourStr = \"0\"] = hour24Match;\n const hour = parseInt(hourStr, 10);\n\n if (timeFormat === \"24\") {\n // For 24-hour format, just show the hour padded to 2 digits\n return `<span>${hour.toString().padStart(2, \"0\")}</span>`;\n } else {\n // For 12-hour display of 24-hour data, convert to 12-hour\n const displayHour = hour % 12 === 0 ? 12 : hour % 12;\n const period = hour < 12 ? \"AM\" : \"PM\";\n if (hour === 0 || hour === 12)\n return `<span>12</span><span>${period}</span>`;\n return `<span>${displayHour}</span>`;\n }\n }\n\n // Fallback: return original value if not recognized hour format\n return value;\n }\n\n // Handle numerical timestamp data\n const numValue = typeof value === \"string\" ? Number(value) : value;\n if (isNaN(numValue)) return \"\";\n const date = new Date(numValue);\n let hour = date.getUTCHours();\n let displayHour = hour % 12 === 0 ? 12 : hour % 12;\n if (hour === 0) return \"<span>12</span><span>AM</span>\";\n if (hour === 12) return \"<span>12</span><span>PM</span>\";\n return `<span>${displayHour}</span>`;\n };\n\n const resolvedXAxisLabelFormatter =\n shouldUseTimeFormatter && !xAxisLabelFormatter\n ? (params: {\n textLocale: Intl.LocalesArgument;\n tickPositions: number[];\n unitName: string;\n value: string | number;\n timeFormat?: string;\n }) => autoTimeXAxisLabelFormatter({ ...params, timeFormat })\n : xAxisLabelFormatter;\n\n const { options, chart, callback } = useTimeSeriesChartOptions({\n currency,\n data,\n numberFormat,\n numberLocale,\n // Although we call this chart vertical bar chart, highcharts uses the term \"column\"\n seriesType: \"column\",\n textLocale,\n yAxisLabelFormatter,\n onClick,\n timeFormat,\n xAnnotations,\n xAxisLabelFormatter: resolvedXAxisLabelFormatter,\n });\n\n const { colors, patterns } = data.reduce(\n (\n acc: {\n colors: TypeChartStyleColor[];\n patterns: TypeChartStylePattern[];\n },\n item,\n index\n ) => {\n acc.colors.push(\n item.styles?.color ?? theme.colors.DATAVIZ_COLORS_LIST[index] ?? \"\"\n );\n acc.patterns.push(item.styles?.pattern ?? \"solid\");\n return acc;\n },\n {\n colors: [] as TypeChartStyleColor[],\n patterns: [] as TypeChartStylePattern[],\n }\n );\n\n return (\n <>\n <GlobalChartStyleOverrides />\n <StyledBox\n $colors={colors}\n $hasOnClick={Boolean(onClick)}\n bg=\"container.background.base\"\n >\n <HighchartsReact\n highcharts={Highcharts}\n options={options}\n callback={callback}\n />\n {chart && chart.annotations?.length ? (\n <ChartXAnnotationMarkerPortal\n xAnnotations={xAnnotations}\n annotationContext={chart.annotations?.[0] as AnnotationsOptions}\n />\n ) : null}\n {chart ? (\n <ChartTooltipPortal\n chart={chart}\n renderContent={(context) => {\n const tooltipData = transformTimeSeriesTooltipData({\n context,\n data,\n });\n const x = context.x as number | string;\n\n const xAnnotationDetails =\n typeof x === \"number\"\n ? xAnnotations?.[x]?.details\n : undefined;\n\n return tooltip ? (\n tooltip({ data: tooltipData, x })\n ) : (\n <VerticalBarChartTooltip\n currency={currency}\n data={tooltipData}\n invalidNumberLabel={invalidNumberLabel}\n numberFormat={numberFormat}\n numberLocale={numberLocale}\n textLocale={textLocale}\n tooltipDateFormatter={tooltipDateFormatter}\n onClick={onClick}\n tooltipClickLabel={tooltipClickLabel}\n x={x}\n xAnnotationDetails={xAnnotationDetails}\n />\n );\n }}\n />\n ) : null}\n <Box mt={350}>\n <VerticalBarChartLegend data={data} />\n </Box>\n </StyledBox>\n </>\n );\n }\n);\n","import { memo } from \"react\";\nimport { theme } from \"@sproutsocial/seeds-react-theme\";\n\nimport type { TypeVerticalBarChartProps } from \"../../../types\";\nimport { ChartLegend, type TypeChartLegendProps } from \"../../ChartLegend\";\nimport { ChartLegendLabelContentWithIcon } from \"../../ChartLegend/components/ChartLegendLabelContentWithIcon\";\n\n// exported for testing\nexport const getVerticalBarChartLegendLabels = ({\n data,\n}: Readonly<{\n data: TypeVerticalBarChartProps[\"data\"];\n}>): TypeChartLegendProps[\"legendLabels\"] => {\n return data.map((series, index) => ({\n content: (\n <ChartLegendLabelContentWithIcon icon={series.icon}>\n {series.name}\n </ChartLegendLabelContentWithIcon>\n ),\n color: series.styles?.color || theme.colors.DATAVIZ_COLORS_LIST[index],\n }));\n};\n\ntype VerticalBarChartLegendProps = Readonly<{\n data: TypeVerticalBarChartProps[\"data\"];\n}>;\n\nexport const VerticalBarChartLegend = memo<VerticalBarChartLegendProps>(\n function VerticalbarChartLegend({ data }: VerticalBarChartLegendProps) {\n return (\n <ChartLegend legendLabels={getVerticalBarChartLegendLabels({ data })} />\n );\n }\n);\n","import { memo } from \"react\";\nimport { Box } from \"@sproutsocial/seeds-react-box\";\nimport { Duration } from \"@sproutsocial/seeds-react-duration\";\nimport { Icon } from \"@sproutsocial/seeds-react-icon\";\nimport { Numeral } from \"@sproutsocial/seeds-react-numeral\";\nimport { Text } from \"@sproutsocial/seeds-react-text\";\n\nimport type { TypeVerticalBarChartProps } from \"../../../types\";\n\nimport {\n ChartTooltip,\n ChartTooltipFooter,\n ChartTooltipTable,\n ChartTooltipTitle,\n type TypeChartTooltipTableProps,\n} from \"../../ChartTooltip\";\nimport type {\n TypeChartTooltipProps,\n TypeChartXAnnotationsDetails,\n} from \"../../../types\";\nimport { ChartLegendLabel } from \"../../ChartLegend/components/ChartLegendLabel\";\nimport { ChartLegendLabelContentWithIcon } from \"../../ChartLegend/components/ChartLegendLabelContentWithIcon\";\n\nexport type TypeVerticalBarChartTooltipProps = Readonly<{\n data: TypeChartTooltipProps[\"data\"];\n invalidNumberLabel: TypeVerticalBarChartProps[\"invalidNumberLabel\"];\n numberLocale: TypeVerticalBarChartProps[\"numberLocale\"];\n textLocale: TypeVerticalBarChartProps[\"textLocale\"];\n tooltipDateFormatter: TypeVerticalBarChartProps[\"tooltipDateFormatter\"];\n x: TypeChartTooltipProps[\"x\"];\n // optional\n currency?: TypeVerticalBarChartProps[\"currency\"];\n numberFormat?: TypeVerticalBarChartProps[\"numberFormat\"];\n onClick?: TypeVerticalBarChartProps[\"onClick\"];\n tooltipClickLabel?: TypeVerticalBarChartProps[\"tooltipClickLabel\"];\n xAnnotationDetails?: TypeChartXAnnotationsDetails;\n}>;\n\nexport const VerticalBarChartTooltip = memo<TypeVerticalBarChartTooltipProps>(\n function VerticalBarChartTooltip({\n data,\n invalidNumberLabel,\n numberLocale,\n textLocale,\n tooltipDateFormatter,\n x,\n // optional\n currency = \"USD\",\n numberFormat = \"decimal\",\n onClick,\n tooltipClickLabel,\n xAnnotationDetails,\n }: TypeVerticalBarChartTooltipProps) {\n const rows = data.map(({ color, icon, name, value }) => {\n return {\n cells: [\n {\n content: (\n <ChartLegendLabel color={color}>\n <ChartLegendLabelContentWithIcon icon={icon}>\n <Text aria-label={`${name}: `}>{name}</Text>\n </ChartLegendLabelContentWithIcon>\n </ChartLegendLabel>\n ),\n },\n {\n content:\n value === null && invalidNumberLabel ? (\n <Text>{invalidNumberLabel}</Text>\n ) : numberFormat === \"duration\" ? (\n <Duration locale={textLocale} milliseconds={value} />\n ) : (\n <Numeral\n abbreviate={false}\n currency={currency}\n format={numberFormat}\n locale={numberLocale as string}\n number={value}\n />\n ),\n align: \"right\",\n },\n ],\n };\n });\n\n return (\n <ChartTooltip>\n {xAnnotationDetails ? xAnnotationDetails() : undefined}\n <ChartTooltipTitle>{tooltipDateFormatter({ x })}</ChartTooltipTitle>\n <ChartTooltipTable rows={rows as TypeChartTooltipTableProps[\"rows\"]} />\n {onClick && tooltipClickLabel ? (\n <ChartTooltipFooter>\n {typeof tooltipClickLabel === \"string\" ? (\n <Box display=\"flex\" alignItems=\"center\" gap={300}>\n <Icon name=\"hand-pointer-clicking-outline\" color=\"icon.base\" />\n <Text color=\"text.subtext\" fontSize={200}>\n {tooltipClickLabel}\n </Text>\n </Box>\n ) : (\n tooltipClickLabel\n )}\n </ChartTooltipFooter>\n ) : null}\n </ChartTooltip>\n );\n }\n);\n","import { timeSeriesChartStyles } from \"../../styles/chartStyles\";\nimport { css } from \"styled-components\";\nimport type {\n TypeChartStyleColor,\n TypeChartStyleHasOnClick,\n} from \"../../types\";\n\n// options that should apply to line charts\nexport const verticalBarChartStyles = css<\n Readonly<{\n $colors: ReadonlyArray<TypeChartStyleColor>;\n $hasOnClick: TypeChartStyleHasOnClick;\n }>\n>`\n ${timeSeriesChartStyles}\n\n /*\n When the chart container is hovered, reduce the opacity of all columns.\n Then, for the column that is being hovered, restore its opacity.\n This gives the effect of fading out the non-hovered columns.\n */\n .highcharts-container:hover .highcharts-point {\n fill-opacity: 0.3;\n }\n\n .highcharts-point.column-hover {\n fill-opacity: 1 !important;\n }\n`;\n"],"mappings":"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","names":["memo","styled","Box","memo","theme","memo","Box","theme","styled","Box","jsx","props","theme","theme","jsx","jsx","styled","Box","theme","ChartLegendLabel","jsx","memo","ChartLegend","Box","theme","memo","Box","jsxs","ChartLegendLabelContentWithIcon","jsx","theme","memo","AreaChartLegend","memo","Box","Text","memo","styled","Box","jsx","StyledBox","ChartTooltip","memo","Box","jsx","ChartTooltipFooter","memo","Box","jsx","ChartTooltipHeader","memo","ChartTooltipPortal","memo","memo","styled","Text","jsx","theme","ChartTable","jsx","memo","ChartTooltipTable","memo","Text","jsx","ChartTooltipTitle","jsx","jsxs","memo","AreaChartTooltip","Text","Box","memo","useEffect","useState","useRef","createPortal","jsx","memo","ChartXAnnotationMarkerPortal","useRef","useState","useEffect","createPortal","theme","useState","yAxisLabelFormatter","xAxisLabelFormatter","useState","baseChartOptions","css","theme","css","theme","theme","Fragment","jsx","jsxs","StyledBox","styled","Box","memo","AreaChart","AreaChartWithData","yAxisLabelFormatter","memo","Box","Icon","Text","jsx","jsxs","memo","Box","Icon","Text","memo","Box","Icon","jsx","jsxs","memo","Box","Icon","memo","useState","useEffect","useCallback","Highcharts","HighchartsReact","highchartsAccessibility","styled","Box","memo","theme","jsx","theme","memo","DonutChartLegend","memo","Box","Duration","Icon","Numeral","Text","jsx","jsxs","memo","DonutChartTooltip","Text","Box","Numeral","Duration","Icon","theme","theme","Fragment","jsx","jsxs","highchartsAccessibility","Highcharts","StyledBox","styled","Box","memo","DonutChart","DonutChartWithData","useState","useCallback","useEffect","HighchartsReact","memo","Box","Duration","Numeral","Text","theme","jsx","jsxs","memo","DonutChartLegendTable","theme","Box","Text","Numeral","Duration","memo","Highcharts","HighchartsReact","highchartsAccessibility","highchartsAnnotations","styled","Box","memo","theme","jsx","theme","memo","LineChartLegend","memo","Box","Duration","Icon","Numeral","Text","jsx","jsxs","memo","LineChartTooltip","Text","Duration","Numeral","Box","Icon","theme","Fragment","jsx","jsxs","highchartsAccessibility","Highcharts","highchartsAnnotations","StyledBox","styled","Box","memo","LineChart","LineChartWithData","yAxisLabelFormatter","xAxisLabelFormatter","theme","HighchartsReact","memo","Highcharts","HighchartsReact","highchartsAccessibility","highchartsAnnotations","styled","Box","memo","theme","jsx","theme","memo","memo","Box","Duration","Icon","Numeral","Text","jsx","jsxs","memo","VerticalBarChartTooltip","Text","Duration","Numeral","Box","Icon","theme","css","Fragment","jsx","jsxs","highchartsAccessibility","Highcharts","highchartsAnnotations","StyledBox","styled","Box","memo","VerticalBarChart","VerticalBarChartWithData","yAxisLabelFormatter","xAxisLabelFormatter","timeFormat","hour","displayHour","theme","HighchartsReact"]}
|