Skip to content

Commit

Permalink
Allow id to be null
Browse files Browse the repository at this point in the history
  • Loading branch information
envex committed Mar 6, 2024
1 parent a7f136e commit bd09112
Show file tree
Hide file tree
Showing 5 changed files with 93 additions and 7 deletions.
8 changes: 8 additions & 0 deletions packages/polaris-viz/CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,14 @@ and adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0.html).

- Fixed the positioning of the `<ZeroLine />` for the Stacked Horizontal Chart when all values are negative.

### Changed

- Allow `useWatchActiveSeries` to accept `null` as an `id` to disable attaching events.

## Added

- Export `setActiveSeriesListener()`.

## [10.5.2] - 2024-02-22

### Added
Expand Down
5 changes: 4 additions & 1 deletion packages/polaris-viz/src/hooks/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -29,5 +29,8 @@ export {
getSeriesColors,
usePrevious,
} from '@shopify/polaris-viz-core';
export {useWatchActiveSeries} from './useWatchActiveSeries';
export {
useWatchActiveSeries,
setActiveSeriesListener,
} from './useWatchActiveSeries';
export {useExternalHideEvents, setHiddenItems} from './ExternalEvents';
62 changes: 62 additions & 0 deletions packages/polaris-viz/src/hooks/tests/useWatchActiveSeries.test.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,62 @@
import {mount} from '@shopify/react-testing';
import {COLOR_VISION_SINGLE_ITEM} from '@shopify/polaris-viz-core';

import {
useWatchActiveSeries,
setActiveSeriesListener,
} from '../useWatchActiveSeries';
import {getEventName} from '../ColorVisionA11y';

describe('useWatchActiveSeries()', () => {
describe('useWatchActiveSeries()', () => {
it('attaches event listener to window when id is passed', () => {
const addEventListenerSpy = jest.spyOn(window, 'addEventListener');

function MockComponent() {
useWatchActiveSeries('id', () => {});

return null;
}

mount(<MockComponent />);

expect(addEventListenerSpy).toHaveBeenCalledWith(
'id:color-vision-event:singleItem',
expect.any(Function),
);
});

it('removes event listener from window when component is unmounted', () => {
const removeEventListenerSpy = jest.spyOn(window, 'removeEventListener');

function MockComponent() {
useWatchActiveSeries('id', () => {});

return null;
}

const component = mount(<MockComponent />);

component.unmount();

expect(removeEventListenerSpy).toHaveBeenCalledWith(
'id:color-vision-event:singleItem',
expect.any(Function),
);
});
});

describe('setActiveSeriesListener()', () => {
it('generates an event name using the given ID', () => {
const id = getEventName('someChartId', COLOR_VISION_SINGLE_ITEM);
const addEventListenerSpy = jest.spyOn(window, 'addEventListener');

setActiveSeriesListener('someChartId', () => {});

expect(addEventListenerSpy).toHaveBeenCalledWith(
id,
expect.any(Function),
);
});
});
});
24 changes: 18 additions & 6 deletions packages/polaris-viz/src/hooks/useWatchActiveSeries.ts
Original file line number Diff line number Diff line change
Expand Up @@ -13,12 +13,24 @@ export function useWatchActiveSeries(
const onIndexChangeCallback = useCallbackRef(onIndexChange);

useEffect(() => {
const eventName = getEventName(id, COLOR_VISION_SINGLE_ITEM);
const clearActiveSeriesListener = setActiveSeriesListener(
id,
onIndexChangeCallback,
);

window.addEventListener(eventName, onIndexChangeCallback);

return () => {
window.removeEventListener(eventName, onIndexChangeCallback);
};
return () => clearActiveSeriesListener();
}, [id, onIndexChangeCallback]);
}

export function setActiveSeriesListener(
id: string,
onIndexChange: (event: ColorVisionEventReturn) => void,
) {
const eventName = getEventName(id, COLOR_VISION_SINGLE_ITEM);

window.addEventListener(eventName, onIndexChange);

return () => {
window.removeEventListener(eventName, onIndexChange);
};
}
1 change: 1 addition & 0 deletions packages/polaris-viz/src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -86,6 +86,7 @@ export {renderLinearTooltipContent, setSingleSeriesActive} from './utilities';

export {
useWatchActiveSeries,
setActiveSeriesListener,
setHiddenItems,
useRenderTooltipContent,
} from './hooks';

0 comments on commit bd09112

Please sign in to comment.