web: fix Settings pane unreachable on mobile (push ?pane= atomically)
Opening the settings pane on mobile set activePaneIdx, but the ?pane= URL-sync effect snapped it back to the chat pane on the panes change, so the pane never showed. toggleSettingsPane now returns the new pane id (id generated outside the updater, strict-mode safe); Session's toggleSettingsAndSync pushes ?pane=<id> on mobile when opening (and drops it on close) so the sync effect keeps it active — mirrors the existing addPaneAndSwitch pattern. Desktop unaffected. Co-Authored-By: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
This commit is contained in:
@@ -123,6 +123,20 @@ function SessionInner({ sessionId }: { sessionId: string }) {
|
||||
};
|
||||
}, [sessionId]);
|
||||
|
||||
// v2.3: opening the settings pane on mobile must push ?pane= atomically, or
|
||||
// the URL-sync effect below snaps activePaneIdx back to the chat pane and the
|
||||
// settings pane never shows (same fix as addPaneAndSwitch). toggleSettingsPane
|
||||
// returns the new pane id when it opens (null when it closes → drop ?pane= so
|
||||
// the effect falls back to pane 0). Desktop has no URL pane state — no-op.
|
||||
const toggleSettingsAndSync = useCallback(() => {
|
||||
const openedId = panesHook.toggleSettingsPane();
|
||||
if (!isMobile) return;
|
||||
const params = new URLSearchParams(location.search);
|
||||
if (openedId) params.set('pane', openedId);
|
||||
else params.delete('pane');
|
||||
navigate(`${location.pathname}?${params.toString()}`);
|
||||
}, [panesHook, isMobile, navigate, location.pathname, location.search]);
|
||||
|
||||
useEffect(() => {
|
||||
return sessionEvents.subscribe((event) => {
|
||||
if (event.type === 'session_renamed' && event.session_id === sessionId) {
|
||||
@@ -156,10 +170,10 @@ function SessionInner({ sessionId }: { sessionId: string }) {
|
||||
// Sidebar Settings button broadcasts this when a session is mounted;
|
||||
// toggleSettingsPane opens on first click, closes on second.
|
||||
if (event.type === 'open_settings_pane') {
|
||||
panesHook.toggleSettingsPane();
|
||||
toggleSettingsAndSync();
|
||||
}
|
||||
});
|
||||
}, [sessionId, editingName, navigate, project, panesHook]);
|
||||
}, [sessionId, editingName, navigate, project, toggleSettingsAndSync]);
|
||||
|
||||
// v1.8: URL ?pane= sync (mobile only). Lifted from Workspace.tsx so
|
||||
// MobileTabSwitcher's onSwitchPane can push the same URL state and the
|
||||
|
||||
Reference in New Issue
Block a user