diff --git a/frontend/src/components/Sidebar/ActiveWorkspaces/ThreadContainer/ThreadItem/index.jsx b/frontend/src/components/Sidebar/ActiveWorkspaces/ThreadContainer/ThreadItem/index.jsx index cbe3b630142da529db2ac7d3c4b6e9dc2b17eb33..4947de08ff51922391321fc0caa367677df4d295 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 157e6623e8d9374108bc97c6fdadad7c94c46f6b..f9c0ea4edb73e112df23cd65c94ec94f745b4be5 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) {