diff options
| author | Adam Mathes <adam@adammathes.com> | 2026-02-16 15:25:12 -0800 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2026-02-16 15:25:12 -0800 |
| commit | feea1a814a212efd9b14b8f05e84104ace3c473a (patch) | |
| tree | 32cb971915aaa560e6fa433a5b8aee3cfbd5f8cf /frontend-vanilla/src/main.ts | |
| parent | 2321d5bcf17e416244e75f5727f0710f9cdd9a1a (diff) | |
| parent | 4555ee294a5acdfbc4b1026d99df54d07c74ed97 (diff) | |
| download | neko-feea1a814a212efd9b14b8f05e84104ace3c473a.tar.gz neko-feea1a814a212efd9b14b8f05e84104ace3c473a.tar.bz2 neko-feea1a814a212efd9b14b8f05e84104ace3c473a.zip | |
Merge pull request #6 from adammathes/claude/fix-mobile-scroll-read-yVmVk
Fix mobile scroll not marking items as read in v3 UI
Diffstat (limited to 'frontend-vanilla/src/main.ts')
| -rw-r--r-- | frontend-vanilla/src/main.ts | 11 |
1 files changed, 7 insertions, 4 deletions
diff --git a/frontend-vanilla/src/main.ts b/frontend-vanilla/src/main.ts index 94f5727..c310144 100644 --- a/frontend-vanilla/src/main.ts +++ b/frontend-vanilla/src/main.ts @@ -262,6 +262,9 @@ export function renderItems() { ${store.hasMore ? '<div id="load-more-sentinel" class="loading-more">Loading more...</div>' : ''} `; + // Use the actual scroll container as IntersectionObserver root + const scrollRoot = document.getElementById('main-content'); + // Setup infinite scroll const sentinel = document.getElementById('load-more-sentinel'); if (sentinel) { @@ -269,14 +272,14 @@ export function renderItems() { if (entries[0].isIntersecting && !store.loading && store.hasMore) { loadMore(); } - }, { threshold: 0.1 }); + }, { root: scrollRoot, threshold: 0.1 }); observer.observe(sentinel); } - // Setup item observer for marking read + // Setup item observer for marking read when items scroll past (above viewport) itemObserver = new IntersectionObserver((entries) => { entries.forEach(entry => { - if (entry.isIntersecting) { + if (!entry.isIntersecting && entry.boundingClientRect.bottom < (entry.rootBounds?.top ?? 0)) { const target = entry.target as HTMLElement; const id = parseInt(target.getAttribute('data-id') || '0'); if (id) { @@ -288,7 +291,7 @@ export function renderItems() { } } }); - }, { threshold: 1.0 }); + }, { root: scrollRoot, threshold: 0 }); contentArea.querySelectorAll('.feed-item').forEach(el => itemObserver!.observe(el)); } |
