diff options
| author | Adam <[email protected]> | 2026-03-24 18:49:14 -0500 |
|---|---|---|
| committer | Adam <[email protected]> | 2026-03-25 05:59:06 -0500 |
| commit | 2b0baf97bd176dfbb9afe81931c90bc6288ada34 (patch) | |
| tree | 9330af2e8af0b5ed504da2e10865045a3f3af1ba /packages/app/src/pages/session | |
| parent | 0dbfefa08088270a000496cfe94e11b5bf3ce821 (diff) | |
| download | opencode-2b0baf97bd176dfbb9afe81931c90bc6288ada34.tar.gz opencode-2b0baf97bd176dfbb9afe81931c90bc6288ada34.zip | |
Reapply "fix(app): more startup efficiency (#18985)"
This reverts commit cbe1337f2401066cf33eb9009b597eafb49123ba.
Diffstat (limited to 'packages/app/src/pages/session')
| -rw-r--r-- | packages/app/src/pages/session/use-session-hash-scroll.ts | 18 |
1 files changed, 18 insertions, 0 deletions
diff --git a/packages/app/src/pages/session/use-session-hash-scroll.ts b/packages/app/src/pages/session/use-session-hash-scroll.ts index 5fadb1f22..c582749d1 100644 --- a/packages/app/src/pages/session/use-session-hash-scroll.ts +++ b/packages/app/src/pages/session/use-session-hash-scroll.ts @@ -8,6 +8,9 @@ export const useSessionHashScroll = (input: { sessionID: () => string | undefined messagesReady: () => boolean visibleUserMessages: () => UserMessage[] + historyMore: () => boolean + historyLoading: () => boolean + loadMore: (sessionID: string) => Promise<void> turnStart: () => number currentMessageId: () => string | undefined pendingMessage: () => string | undefined @@ -181,6 +184,21 @@ export const useSessionHashScroll = (input: { queue(() => scrollToMessage(msg, "auto")) }) + createEffect(() => { + const sessionID = input.sessionID() + if (!sessionID || !input.messagesReady()) return + + visibleUserMessages() + + let targetId = input.pendingMessage() + if (!targetId && !clearing) targetId = messageIdFromHash(location.hash) + if (!targetId) return + if (messageById().has(targetId)) return + if (!input.historyMore() || input.historyLoading()) return + + void input.loadMore(sessionID) + }) + onMount(() => { if (typeof window !== "undefined" && "scrollRestoration" in window.history) { window.history.scrollRestoration = "manual" |
