mirror of
https://github.com/excalidraw/excalidraw.git
synced 2025-10-23 16:04:33 +02:00
Calculate collisionPadding dynamically based on container
This commit is contained in:
@@ -41,6 +41,19 @@ export const PropertiesPopover = React.forwardRef<
|
||||
) => {
|
||||
const device = useDevice();
|
||||
|
||||
const collisionPadding = React.useMemo(() => {
|
||||
if (!container) {
|
||||
return 8;
|
||||
}
|
||||
const rect = container.getBoundingClientRect();
|
||||
return {
|
||||
top: Math.max(8, rect.top),
|
||||
right: Math.max(8, window.innerWidth - rect.right),
|
||||
bottom: Math.max(8, window.innerHeight - rect.bottom),
|
||||
left: Math.max(8, rect.left),
|
||||
};
|
||||
}, [container]);
|
||||
|
||||
return (
|
||||
<Popover.Portal container={container}>
|
||||
<Popover.Content
|
||||
@@ -60,7 +73,7 @@ export const PropertiesPopover = React.forwardRef<
|
||||
alignOffset={-16}
|
||||
sideOffset={20}
|
||||
collisionBoundary={container ?? undefined}
|
||||
collisionPadding={8}
|
||||
collisionPadding={collisionPadding}
|
||||
style={{
|
||||
zIndex: "var(--zIndex-ui-styles-popup)",
|
||||
marginLeft: device.editor.isMobile ? "0.5rem" : undefined,
|
||||
|
Reference in New Issue
Block a user