From 426e2360b3ebf34907a834c9e8d5376c648b54eb Mon Sep 17 00:00:00 2001 From: Sean Hatfield <seanhatfield5@gmail.com> Date: Thu, 12 Dec 2024 09:00:30 +0800 Subject: [PATCH] Redirect to default thread on thread deletion (#2808) * redirect to default thread on thread deletion * reset submodule * handle redirect on bulk delete thread * redirect on bulk thread delete only if deleted thread is selected * redirect only on single delete of active thread * lint * patch threadSlug for clarity --------- Co-authored-by: Timothy Carambat <rambat1010@gmail.com> --- .../ThreadContainer/ThreadItem/index.jsx | 16 ++++++++++++++-- .../ActiveWorkspaces/ThreadContainer/index.jsx | 5 +++++ 2 files changed, 19 insertions(+), 2 deletions(-) diff --git a/frontend/src/components/Sidebar/ActiveWorkspaces/ThreadContainer/ThreadItem/index.jsx b/frontend/src/components/Sidebar/ActiveWorkspaces/ThreadContainer/ThreadItem/index.jsx index cbe3b6301..4947de08f 100644 --- a/frontend/src/components/Sidebar/ActiveWorkspaces/ThreadContainer/ThreadItem/index.jsx +++ b/frontend/src/components/Sidebar/ActiveWorkspaces/ThreadContainer/ThreadItem/index.jsx @@ -24,7 +24,7 @@ export default function ThreadItem({ hasNext, ctrlPressed = false, }) { - const { slug } = useParams(); + const { slug, threadSlug = null } = useParams(); const optionsContainer = useRef(null); const [showOptions, setShowOptions] = useState(false); const linkTo = !thread.slug @@ -142,6 +142,7 @@ export default function ThreadItem({ thread={thread} onRemove={onRemove} close={() => setShowOptions(false)} + currentThreadSlug={threadSlug} /> )} </div> @@ -151,7 +152,14 @@ export default function ThreadItem({ ); } -function OptionsMenu({ containerRef, workspace, thread, onRemove, close }) { +function OptionsMenu({ + containerRef, + workspace, + thread, + onRemove, + close, + currentThreadSlug, +}) { const menuRef = useRef(null); // Ref menu options @@ -227,6 +235,10 @@ function OptionsMenu({ containerRef, workspace, thread, onRemove, close }) { if (success) { showToast("Thread deleted successfully!", "success", { clear: true }); onRemove(thread.id); + // Redirect if deleting the active thread + if (currentThreadSlug === thread.slug) { + window.location.href = paths.workspace.chat(workspace.slug); + } return; } }; diff --git a/frontend/src/components/Sidebar/ActiveWorkspaces/ThreadContainer/index.jsx b/frontend/src/components/Sidebar/ActiveWorkspaces/ThreadContainer/index.jsx index 157e6623e..f9c0ea4ed 100644 --- a/frontend/src/components/Sidebar/ActiveWorkspaces/ThreadContainer/index.jsx +++ b/frontend/src/components/Sidebar/ActiveWorkspaces/ThreadContainer/index.jsx @@ -87,6 +87,11 @@ export default function ThreadContainer({ workspace }) { const slugs = threads.filter((t) => t.deleted === true).map((t) => t.slug); await Workspace.threads.deleteBulk(workspace.slug, slugs); setThreads((prev) => prev.filter((t) => !t.deleted)); + + // Only redirect if current thread is being deleted + if (slugs.includes(threadSlug)) { + window.location.href = paths.workspace.chat(workspace.slug); + } }; function removeThread(threadId) { -- GitLab