v3/packages/design-system/atoms/breakpoints/BreakpointProvider.tsx
Katalina 7d681d69d6
Feat/editor category pass2 (#290)
* feat(design-system): add editor skeletons

* use css media queries rather than JS media queries

* init remake

* feat: add basis of toggle atom

* finish toggle

* use pointer cursor with toggle

* sync

* feat: add server message in editor

* cleanup storybook

* add short editor item and data model for categories

* chore: fix build by moving jest version downward

* chore: remove old category editor

* chore: fix EditorCategoryShort index

* add editor wiring and styling updates

* fix linting issues
2021-07-05 12:18:40 -05:00

56 lines
1.8 KiB
TypeScript

import * as React from 'react';
import { mediaQueryDefs } from './Breakpoints';
import { BreakpointContext, BreakpointProps, ScreenSize } from './Context';
export const BreakpointsProvider = (props: { children: React.ReactNode }) => {
const [screenSize, setScreenSize] = React.useState<ScreenSize>({
onDesktop: false,
onTablet: false,
onSmallScreen: true, // Always true to be a viable "failback"
});
React.useEffect(() => {
const mediaQueries = {
onSmallScreen: window.matchMedia(
mediaQueryDefs.onSmallScreen.replace('@media screen and', '')
),
onTablet: window.matchMedia(
mediaQueryDefs.onTablet.replace('@media screen and', '')
),
onDesktop: window.matchMedia(
mediaQueryDefs.onDesktop.replace('@media screen and', '')
),
};
const updateScreenSize = () => {
setScreenSize({
onDesktop: mediaQueries.onDesktop.matches,
onTablet: mediaQueries.onTablet.matches,
onSmallScreen: true, // Always true to be a viable "failback"
});
};
updateScreenSize();
setImmediate(() => updateScreenSize());
mediaQueries.onDesktop.addEventListener('change', updateScreenSize);
mediaQueries.onTablet.addEventListener('change', updateScreenSize);
mediaQueries.onSmallScreen.addEventListener('change', updateScreenSize);
return () => {
mediaQueries.onDesktop.removeEventListener('change', updateScreenSize);
mediaQueries.onTablet.removeEventListener('change', updateScreenSize);
mediaQueries.onSmallScreen.removeEventListener('change', updateScreenSize);
};
}, []);
const breakpointsValue: BreakpointProps = {
screenSize,
};
return (
<BreakpointContext.Provider value={breakpointsValue}>
{props.children}
</BreakpointContext.Provider>
);
};