Keep selected card in view when opening preview
Opening the preview panel narrows .grid-area and reflows the auto-fill grid to fewer columns, moving the clicked card to a new row. The single-frame scrollIntoView ran while the browser's scroll-anchoring re-adjusted scrollTop mid-reflow, so the card scrolled out of view. Disable scroll anchoring on .grid-area (overflow-anchor:none) and defer the scroll by two animation frames against the settled layout, centring the card (block:'center'). Co-Authored-By: Claude Fable 5 <noreply@anthropic.com>
This commit is contained in:
parent
d82a0d6004
commit
7c1c2b390d
@ -27,6 +27,8 @@ Version numbers follow [Semantic Versioning](https://semver.org/spec/v2.0.0.html
|
|||||||
|
|
||||||
### Fixed
|
### Fixed
|
||||||
|
|
||||||
|
- **Selected card scrolled out of view when opening the preview** — opening the preview panel narrows `.grid-area`, which reflows the `auto-fill` grid to fewer columns and moves every card to a new row. The single-frame `scrollIntoView` ran while the browser's scroll-anchoring re-adjusted `scrollTop` mid-reflow, fighting the scroll so the clicked card ended up off-screen. Fixed by disabling scroll anchoring on `.grid-area` (`overflow-anchor: none`) and deferring the scroll by two animation frames so it runs against the settled layout; the card is now centred (`block: 'center'`) instead of `'nearest'` so it stays clearly visible.
|
||||||
|
|
||||||
- **Cards not shown after browser refresh** — when the browser reconnected to the SSE stream after a completed scan, the `scan_phase` events in the replay buffer temporarily set `S._m365ScanRunning = true` (all running flags start at `false` after a page reload). The watchdog's `loadHistorySession` call fired in this window and bailed on the stale flag; once `scan_done` cleared the flag, `_initialStatusChecked` was already `true` so `loadHistorySession` was never retried. Fixed by having the `sse_replay_done` handler retry `loadHistorySession(null)` when no scan is running and `S._historyRefScanId` is still `null` after replay.
|
- **Cards not shown after browser refresh** — when the browser reconnected to the SSE stream after a completed scan, the `scan_phase` events in the replay buffer temporarily set `S._m365ScanRunning = true` (all running flags start at `false` after a page reload). The watchdog's `loadHistorySession` call fired in this window and bailed on the stale flag; once `scan_done` cleared the flag, `_initialStatusChecked` was already `true` so `loadHistorySession` was never retried. Fixed by having the `sse_replay_done` handler retry `loadHistorySession(null)` when no scan is running and `S._historyRefScanId` is still `null` after replay.
|
||||||
|
|
||||||
- **Settings modal too narrow for seven tabs** — widened from 640 px to 720 px so all tab labels fit on one line without wrapping.
|
- **Settings modal too narrow for seven tabs** — widened from 640 px to 720 px so all tab labels fit on one line without wrapping.
|
||||||
|
|||||||
@ -118,7 +118,11 @@ async function openPreview(f) {
|
|||||||
panel.classList.remove('hidden');
|
panel.classList.remove('hidden');
|
||||||
const _savedW = sessionStorage.getItem('gdpr_preview_width');
|
const _savedW = sessionStorage.getItem('gdpr_preview_width');
|
||||||
if (_savedW) panel.style.width = _savedW + 'px';
|
if (_savedW) panel.style.width = _savedW + 'px';
|
||||||
if (cardEl) requestAnimationFrame(() => cardEl.scrollIntoView({ behavior: 'smooth', block: 'nearest' }));
|
// Opening the panel narrows .grid-area and reflows the grid to fewer columns,
|
||||||
|
// moving the selected card to a new row. Defer the scroll by two frames so it
|
||||||
|
// runs against the settled layout, and centre the card so it stays visible.
|
||||||
|
if (cardEl) requestAnimationFrame(() => requestAnimationFrame(() =>
|
||||||
|
cardEl.scrollIntoView({ behavior: 'smooth', block: 'center' })));
|
||||||
title.textContent = f.name;
|
title.textContent = f.name;
|
||||||
frame.style.display = 'none';
|
frame.style.display = 'none';
|
||||||
loading.style.display = 'flex';
|
loading.style.display = 'flex';
|
||||||
|
|||||||
@ -197,7 +197,7 @@
|
|||||||
.filter-clear:hover { border-color: var(--danger); color: var(--danger); }
|
.filter-clear:hover { border-color: var(--danger); color: var(--danger); }
|
||||||
|
|
||||||
/* Grid */
|
/* Grid */
|
||||||
.grid-area { flex: 1; overflow-y: auto; padding: 24px; min-width: 0; scrollbar-width: thin; scrollbar-color: var(--border) transparent; }
|
.grid-area { flex: 1; overflow-y: auto; overflow-anchor: none; padding: 24px; min-width: 0; scrollbar-width: thin; scrollbar-color: var(--border) transparent; }
|
||||||
.grid-area::-webkit-scrollbar { width: 4px; }
|
.grid-area::-webkit-scrollbar { width: 4px; }
|
||||||
.grid-area::-webkit-scrollbar-track { background: transparent; }
|
.grid-area::-webkit-scrollbar-track { background: transparent; }
|
||||||
.grid-area::-webkit-scrollbar-thumb { background: var(--border); border-radius: 2px; }
|
.grid-area::-webkit-scrollbar-thumb { background: var(--border); border-radius: 2px; }
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user