From 2844a2bd71dcf1eb17a53992c10129b7496332e0 Mon Sep 17 00:00:00 2001 From: Armand Philippot Date: Tue, 31 Oct 2023 17:41:43 +0100 Subject: feat(components): add an Overlay component * add useScrollbarWidth hook * add useScrollLock hook * add a new component to lock scroll with an overlay (it can be useful especially on small screens to prevent background contents to be scrolled) --- src/components/atoms/overlay/overlay.stories.tsx | 63 ++++++++++++++++++++++++ 1 file changed, 63 insertions(+) create mode 100644 src/components/atoms/overlay/overlay.stories.tsx (limited to 'src/components/atoms/overlay/overlay.stories.tsx') diff --git a/src/components/atoms/overlay/overlay.stories.tsx b/src/components/atoms/overlay/overlay.stories.tsx new file mode 100644 index 0000000..f9c478c --- /dev/null +++ b/src/components/atoms/overlay/overlay.stories.tsx @@ -0,0 +1,63 @@ +import type { ComponentMeta, ComponentStory } from '@storybook/react'; +import { useToggle } from '../../../utils/hooks'; +import { Button } from '../buttons'; +import { Overlay } from './overlay'; + +/** + * Overlay - Storybook Meta + */ +export default { + title: 'Atoms/Overlay', + component: Overlay, + argTypes: {}, +} as ComponentMeta; + +const Template: ComponentStory = ({ isVisible, ...props }) => { + const [isActive, toggle] = useToggle(isVisible); + + return ( +
+

+ Itaque reprehenderit sint rerum placeat et sapiente similique ut + distinctio. Libero illo reprehenderit qui quaerat dolorem. Officiis + asperiores sapiente eaque. Aut numquam porro quasi delectus excepturi + aut eaque et. Commodi et necessitatibus provident blanditiis rem qui + atque. +

+

+ Aut architecto vitae dolor hic explicabo iure quia quae beatae. + Exercitationem nulla dignissimos doloribus sunt at nisi. A modi quasi + est sed quas repellendus vel sed dolores. Sed neque aperiam adipisci eos + autem. Libero omnis quis aut quas omnis magni harum et. +

+ + +
+ ); +}; + +/** + * Overlay Stories - Hidden + */ +export const Hidden = Template.bind({}); +Hidden.args = { + children: ( +
+ Some modal contents. +
+ ), + isVisible: false, +}; + +/** + * Overlay Stories - Visible + */ +export const Visible = Template.bind({}); +Visible.args = { + children: ( +
+ Some modal contents. +
+ ), + isVisible: true, +}; -- cgit v1.2.3