From 5d3fe7e6b7e8db054019533ffc5928d8e7d107dd Mon Sep 17 00:00:00 2001 From: rayangler <27821750+rayangler@users.noreply.github.com> Date: Tue, 13 Feb 2024 13:40:11 -0500 Subject: [PATCH] DOP-4355: Extend grab area of lab drawer handle (#1008) --- src/components/Instruqt/LabDrawer.js | 39 +++++++++++++++++++++++----- 1 file changed, 33 insertions(+), 6 deletions(-) diff --git a/src/components/Instruqt/LabDrawer.js b/src/components/Instruqt/LabDrawer.js index 07f21f260..d8aeeef4f 100644 --- a/src/components/Instruqt/LabDrawer.js +++ b/src/components/Instruqt/LabDrawer.js @@ -32,20 +32,27 @@ const handleContainerStyle = css` justify-content: center; `; -const handleStyle = css` +const handleGrabArea = css` position: absolute; - border-radius: 4px; cursor: ns-resize; top: 10px; - background-color: ${palette.white}; - width: 50px; - height: 4px; + + // Allows element to be bigger in size while maintaining visual size + padding: 10px 20px 20px 20px; + margin: -10px -20px -20px -20px; @media ${theme.screenSize.upToMedium} { display: none; } `; +const handleStyle = css` + border-radius: 4px; + background-color: ${palette.white}; + width: 50px; + height: 4px; +`; + const topContainerStyle = css` position: relative; padding: 0 17px; @@ -75,11 +82,25 @@ const titleStyle = css` } `; +const iframeOverlayStyle = css` + position: absolute; + bottom: 0; + left: 0; + z-index: 1; + opacity: 0; + width: 100%; +`; + const CustomResizeHandle = React.forwardRef((props, ref) => { + // handleAxis is being filtered out to avoid prop warning for div + // restProps along with ref are what actually allows react-resizable to treat this as a handle const { handleAxis, ...restProps } = props; return (
-
+ {/* Allow grab area to be bigger than the actual shape of the handle */} +
+
+
); }); @@ -88,6 +109,7 @@ const LabDrawer = ({ title, embedValue }) => { const viewportSize = useViewport(); const { isMobile } = useScreenSize(); const labTitle = title || 'MongoDB Interactive Lab'; + const [isResizing, setIsResizing] = useState(false); const defaultMeasurement = 200; const defaultHeight = (viewportSize.height * 2) / 3 ?? defaultMeasurement; @@ -135,6 +157,8 @@ const LabDrawer = ({ title, embedValue }) => { resizeHandles={['n']} handle={} onResize={handleResize} + onResizeStart={() => setIsResizing(true)} + onResizeStop={() => setIsResizing(false)} > {/* Need this div with style as a wrapper to help with resizing */}
@@ -148,6 +172,9 @@ const LabDrawer = ({ title, embedValue }) => { setHeight={setHeight} />
+ {/* Having an overlaying div allows dragging to not bug out when mouse crosses over into the iframe */} + {/* Keep height separate from css style to avoid constant css updates */} + {isResizing &&
}
,