From 02c1a6790a87a985b62b874f13fe9a68fa99968e Mon Sep 17 00:00:00 2001 From: Ishaan Dey Date: Mon, 13 May 2024 22:43:56 -0700 Subject: [PATCH] fix resize observer --- backend/storage/src/index.ts | 35 +++++++++++++-------------- frontend/components/editor/editor.tsx | 30 ++++++++++------------- 2 files changed, 30 insertions(+), 35 deletions(-) diff --git a/backend/storage/src/index.ts b/backend/storage/src/index.ts index 9d8953a..c580605 100644 --- a/backend/storage/src/index.ts +++ b/backend/storage/src/index.ts @@ -16,35 +16,34 @@ export default { const path = url.pathname; const method = request.method; - if (path === '/api/size' && method === 'GET') { - const params = url.searchParams; - const sandboxId = params.get('sandboxId'); + if (path === '/api/size' && method === 'GET') { + const params = url.searchParams; + const sandboxId = params.get('sandboxId'); - if (sandboxId) { - const res = await env.R2.list({ prefix: `projects/${sandboxId}` }); + if (sandboxId) { + const res = await env.R2.list({ prefix: `projects/${sandboxId}` }); - // sum up the size of all files - let size = 0; - for (const file of res.objects) { - size += file.size; - } + // sum up the size of all files + let size = 0; + for (const file of res.objects) { + size += file.size; + } - return new Response(JSON.stringify({ size }), { status: 200 }); - } else return invalidRequest; - } - else if (path === '/api') { + return new Response(JSON.stringify({ size }), { status: 200 }); + } else return invalidRequest; + } else if (path === '/api') { if (method === 'GET') { const params = url.searchParams; const sandboxId = params.get('sandboxId'); - const folderId = params.get('folderId'); + const folderId = params.get('folderId'); const fileId = params.get('fileId'); if (sandboxId) { const res = await env.R2.list({ prefix: `projects/${sandboxId}` }); return new Response(JSON.stringify(res), { status: 200 }); - } else if (folderId) { - const res = await env.R2.list({ prefix: folderId }); - return new Response(JSON.stringify(res), { status: 200 }); + } else if (folderId) { + const res = await env.R2.list({ prefix: folderId }); + return new Response(JSON.stringify(res), { status: 200 }); } else if (fileId) { const obj = await env.R2.get(fileId); if (obj === null) { diff --git a/frontend/components/editor/editor.tsx b/frontend/components/editor/editor.tsx index 7558af1..816a114 100644 --- a/frontend/components/editor/editor.tsx +++ b/frontend/components/editor/editor.tsx @@ -104,16 +104,7 @@ export default function CodeEditor({ const generateRef = useRef(null); const generateWidgetRef = useRef(null); const previewPanelRef = useRef(null); - - // Resize observer tracks editor width for generate widget - const resizeObserver = new ResizeObserver((entries) => { - for (const entry of entries) { - const { width } = entry.contentRect; - setGenerate((prev) => { - return { ...prev, width }; - }); - } - }); + const editorPanelRef = useRef(null); // Pre-mount editor keybindings const handleEditorWillMount: BeforeMount = (monaco) => { @@ -230,8 +221,17 @@ export default function CodeEditor({ }, }; + // window width - sidebar width, times the percentage of the editor panel + const width = editorPanelRef.current + ? (editorPanelRef.current.getSize() / 100) * (window.innerWidth - 224) + : 400; //fallback + setGenerate((prev) => { - return { ...prev, widget: contentWidget }; + return { + ...prev, + widget: contentWidget, + width, + }; }); editorRef?.addContentWidget(contentWidget); @@ -348,17 +348,12 @@ export default function CodeEditor({ }; }, [editorRef, room, activeFileContent]); - // Connection/disconnection effect + resizeobserver + // Connection/disconnection effect useEffect(() => { socket.connect(); - if (editorContainerRef.current) { - resizeObserver.observe(editorContainerRef.current); - } - return () => { socket.disconnect(); - resizeObserver.disconnect(); }; }, []); @@ -637,6 +632,7 @@ export default function CodeEditor({ maxSize={80} minSize={30} defaultSize={60} + ref={editorPanelRef} >
{/* File tabs */}