From 1ff96f2b51c7e7608a0d58e09a4b0f1144e4d3e1 Mon Sep 17 00:00:00 2001 From: Susie Kim Date: Thu, 25 Jan 2024 14:18:54 -0500 Subject: [PATCH] Watch dimension change in useColorVisionEvents --- .../src/components/DonutChart/Chart.tsx | 2 +- .../src/components/HorizontalBarChart/Chart.tsx | 2 +- .../src/components/LineChart/Chart.tsx | 2 +- .../src/components/SimpleBarChart/Chart.tsx | 2 +- .../src/components/StackedAreaChart/Chart.tsx | 2 +- .../src/components/VerticalBarChart/Chart.tsx | 2 +- .../ColorVisionA11y/useColorVisionEvents.ts | 17 ++++++++++++++--- 7 files changed, 20 insertions(+), 9 deletions(-) diff --git a/packages/polaris-viz/src/components/DonutChart/Chart.tsx b/packages/polaris-viz/src/components/DonutChart/Chart.tsx index 27089445f3..2eeffd11e2 100644 --- a/packages/polaris-viz/src/components/DonutChart/Chart.tsx +++ b/packages/polaris-viz/src/components/DonutChart/Chart.tsx @@ -132,7 +132,7 @@ export function Chart({ width && height && isLegendMounted, ); - useColorVisionEvents(shouldUseColorVisionEvents); + useColorVisionEvents({enabled: shouldUseColorVisionEvents}); useWatchColorVisionEvents({ type: COLOR_VISION_SINGLE_ITEM, diff --git a/packages/polaris-viz/src/components/HorizontalBarChart/Chart.tsx b/packages/polaris-viz/src/components/HorizontalBarChart/Chart.tsx index 0006ad6639..3807c7e40a 100644 --- a/packages/polaris-viz/src/components/HorizontalBarChart/Chart.tsx +++ b/packages/polaris-viz/src/components/HorizontalBarChart/Chart.tsx @@ -79,7 +79,7 @@ export function Chart({ xAxisOptions, yAxisOptions, }: ChartProps) { - useColorVisionEvents(data.length > 1); + useColorVisionEvents({enabled: data.length > 1}); const selectedTheme = useTheme(); const id = useMemo(() => uniqueId('HorizontalBarChart'), []); diff --git a/packages/polaris-viz/src/components/LineChart/Chart.tsx b/packages/polaris-viz/src/components/LineChart/Chart.tsx index c4e4b38d0f..164e0a971b 100644 --- a/packages/polaris-viz/src/components/LineChart/Chart.tsx +++ b/packages/polaris-viz/src/components/LineChart/Chart.tsx @@ -101,7 +101,7 @@ export function Chart({ yAxisOptions, enableHideLegendOverflow = false, }: ChartProps) { - useColorVisionEvents(data.length > 1); + useColorVisionEvents({enabled: data.length > 1, dimensions}); const selectedTheme = useTheme(theme); const {isPerformanceImpacted} = useChartContext(); diff --git a/packages/polaris-viz/src/components/SimpleBarChart/Chart.tsx b/packages/polaris-viz/src/components/SimpleBarChart/Chart.tsx index a1442a509c..71bfdf81c4 100644 --- a/packages/polaris-viz/src/components/SimpleBarChart/Chart.tsx +++ b/packages/polaris-viz/src/components/SimpleBarChart/Chart.tsx @@ -52,7 +52,7 @@ export function Chart({ xAxisOptions, yAxisOptions, }: ChartProps) { - useColorVisionEvents(data.length > 1); + useColorVisionEvents({enabled: data.length > 1}); const id = useMemo(() => uniqueId('SimpleBarChart'), []); diff --git a/packages/polaris-viz/src/components/StackedAreaChart/Chart.tsx b/packages/polaris-viz/src/components/StackedAreaChart/Chart.tsx index d40e801dd5..ec73771b83 100644 --- a/packages/polaris-viz/src/components/StackedAreaChart/Chart.tsx +++ b/packages/polaris-viz/src/components/StackedAreaChart/Chart.tsx @@ -93,7 +93,7 @@ export function Chart({ theme, yAxisOptions, }: Props) { - useColorVisionEvents(data.length > 1); + useColorVisionEvents({enabled: data.length > 1}); const selectedTheme = useTheme(theme); const seriesColors = useThemeSeriesColors(data, selectedTheme); diff --git a/packages/polaris-viz/src/components/VerticalBarChart/Chart.tsx b/packages/polaris-viz/src/components/VerticalBarChart/Chart.tsx index fdf249250c..553151627e 100644 --- a/packages/polaris-viz/src/components/VerticalBarChart/Chart.tsx +++ b/packages/polaris-viz/src/components/VerticalBarChart/Chart.tsx @@ -82,7 +82,7 @@ export function Chart({ xAxisOptions, yAxisOptions, }: Props) { - useColorVisionEvents(data.length > 1); + useColorVisionEvents({enabled: data.length > 1}); const selectedTheme = useTheme(); const {characterWidths} = useChartContext(); diff --git a/packages/polaris-viz/src/hooks/ColorVisionA11y/useColorVisionEvents.ts b/packages/polaris-viz/src/hooks/ColorVisionA11y/useColorVisionEvents.ts index de0bdc67ce..424f151ac0 100644 --- a/packages/polaris-viz/src/hooks/ColorVisionA11y/useColorVisionEvents.ts +++ b/packages/polaris-viz/src/hooks/ColorVisionA11y/useColorVisionEvents.ts @@ -1,11 +1,22 @@ import {useEffect} from 'react'; -import {COLOR_VISION_EVENT, useChartContext} from '@shopify/polaris-viz-core'; +import { + BoundingRect, + COLOR_VISION_EVENT, + useChartContext, +} from '@shopify/polaris-viz-core'; import {useExternalHideEvents} from '../ExternalEvents'; import {getDataSetItem, getEventName} from './utilities'; -export function useColorVisionEvents(enabled = true) { +export interface Props { + enabled?: boolean; + dimensions?: BoundingRect; +} + +export function useColorVisionEvents(props?: Partial) { + const {enabled = true, dimensions} = props || {}; + const {id} = useChartContext(); const {hiddenIndexes} = useExternalHideEvents(); @@ -70,5 +81,5 @@ export function useColorVisionEvents(enabled = true) { item.removeEventListener('blur', onMouseLeave); }); }; - }, [id, enabled, hiddenIndexes]); + }, [id, enabled, hiddenIndexes, dimensions]); }