diff --git a/src/components/Sheet/SheetContent.tsx b/src/components/Sheet/SheetContent.tsx index ec98f6ca5f..d4241e3ee0 100644 --- a/src/components/Sheet/SheetContent.tsx +++ b/src/components/Sheet/SheetContent.tsx @@ -71,7 +71,7 @@ class SheetContent extends React.Component(); sheetTitleRef = React.createRef(); velocityTracker = new VelocityTracker(); - observer: MutationObserver | null = null; + observer: ResizeObserver | null = null; state: SheetContentState = { startScrollTop: 0, @@ -408,6 +408,10 @@ class SheetContent extends React.Component { + if (!this.state.inWindowResizeScope) { + this.onResize(); + } + }); + this.observer.observe(this.sheetInnerContentRef.current); } } diff --git a/src/components/Sheet/__stories__/DefaultShowcase/DefaultShowcase.stories.tsx b/src/components/Sheet/__stories__/DefaultShowcase/DefaultShowcase.stories.tsx index 29ff9f71a9..cdd4bb1769 100644 --- a/src/components/Sheet/__stories__/DefaultShowcase/DefaultShowcase.stories.tsx +++ b/src/components/Sheet/__stories__/DefaultShowcase/DefaultShowcase.stories.tsx @@ -32,7 +32,10 @@ export default { component: Sheet, } as Meta; -export const Showcase: StoryFn = (args: SheetProps) => { +export const Default: StoryFn = ({ + allowHideOnContentScroll = false, + ...args +}: SheetProps) => { const [visible, setVisible] = React.useState(false); const [withExtraOuterContent, setWithExtraOuterContent] = React.useState(false); const [withExtraInnerContent, setWithExtraInnerContent] = React.useState(false); @@ -64,6 +67,7 @@ export const Showcase: StoryFn = (args: SheetProps) => { )} setVisible(false)} title={withTitle ? 'Sheet title' : undefined} diff --git a/src/components/Sheet/__stories__/MultipleSheetsShowcase/MultipleSheets.scss b/src/components/Sheet/__stories__/MultipleSheetsShowcase/MultipleSheets.scss new file mode 100644 index 0000000000..d31ae63709 --- /dev/null +++ b/src/components/Sheet/__stories__/MultipleSheetsShowcase/MultipleSheets.scss @@ -0,0 +1,15 @@ +.sheet-stories-with-multiple-sheets { + display: flex; + justify-content: center; + + &__show-btn { + margin: 20px 0; + } + + img { + object-fit: contain; + border: none; + max-width: 100%; + vertical-align: middle; + } +} diff --git a/src/components/Sheet/__stories__/MultipleSheetsShowcase/MultipleSheets.stories.tsx b/src/components/Sheet/__stories__/MultipleSheetsShowcase/MultipleSheets.stories.tsx new file mode 100644 index 0000000000..085efe501f --- /dev/null +++ b/src/components/Sheet/__stories__/MultipleSheetsShowcase/MultipleSheets.stories.tsx @@ -0,0 +1,67 @@ +import React from 'react'; + +import type {Meta, StoryFn} from '@storybook/react'; + +import {Button} from '../../..'; +import {cn} from '../../../utils/cn'; +import {Sheet} from '../../Sheet'; +import type {SheetProps} from '../../Sheet'; + +import './MultipleSheets.scss'; + +const b = cn('sheet-stories-with-multiple-sheets'); + +export default { + title: 'Components/Overlays/Sheet', + component: Sheet, +} as Meta; + +export const MultipleSheets: StoryFn = (args: SheetProps) => { + const [visible, setVisible] = React.useState(false); + const [moreContentVisible, setMoreContentVisible] = React.useState(false); + + return ( +
+ + setVisible(false)}> + example + + + setMoreContentVisible(false)} + > +
+ Lorem ipsum, dolor sit amet consectetur adipisicing elit. Aliquam consequatur + quasi quo temporibus. Optio tenetur, aliquam ratione natus asperiores + necessitatibus? Cumque nulla nesciunt esse minus cum nam rerum illum dicta. +
+
+ +
+
+
+ ); +}; diff --git a/src/components/Sheet/__stories__/Sheet.stories.tsx b/src/components/Sheet/__stories__/Sheet.stories.tsx index 29fe94b49e..4b5d79840a 100644 --- a/src/components/Sheet/__stories__/Sheet.stories.tsx +++ b/src/components/Sheet/__stories__/Sheet.stories.tsx @@ -2,18 +2,7 @@ import type {Meta} from '@storybook/react'; import {Sheet} from '../Sheet'; -import {Showcase} from './DefaultShowcase/DefaultShowcase.stories'; -import {WithMenuShowcase} from './WithMenuShowcase/WithMenuShowcase.stories'; - export default { title: 'Components/Overlays/Sheet', component: Sheet, } as Meta; - -export const Default = Showcase.bind({}); - -Default.args = { - allowHideOnContentScroll: false, -}; - -export const WithMenu = WithMenuShowcase.bind({});