try to implement load more without scrolling

This commit is contained in:
Nolan Lawson 2022-05-14 12:54:04 -07:00
parent 78687479df
commit 7bc2b02a1b
3 changed files with 28 additions and 1 deletions

View File

@ -149,6 +149,7 @@ export default {
<li><kbd>j</kbd> or <kbd></kbd> to activate the next toot</li> <li><kbd>j</kbd> or <kbd></kbd> to activate the next toot</li>
<li><kbd>k</kbd> or <kbd></kbd> to activate the previous toot</li> <li><kbd>k</kbd> or <kbd></kbd> to activate the previous toot</li>
<li><kbd>.</kbd> to show more and scroll to top</li> <li><kbd>.</kbd> to show more and scroll to top</li>
<li><kbd>,</kbd> to show more without scrolling</li>
<li><kbd>o</kbd> to open</li> <li><kbd>o</kbd> to open</li>
<li><kbd>f</kbd> to favorite</li> <li><kbd>f</kbd> to favorite</li>
<li><kbd>b</kbd> to boost</li> <li><kbd>b</kbd> to boost</li>

View File

@ -0,0 +1,23 @@
import { showMoreItemsForCurrentTimeline } from './timeline.js'
import { getScrollContainer } from '../_utils/scrollContainer.js'
import { tryToFocusElement } from '../_utils/tryToFocusElement.js'
import { doubleRAF } from '../_utils/doubleRAF.js'
export async function showMoreWithoutScrollingToTop () {
// Similar to "." (showMoreAndScrollToTop), except it doesn't scroll to the top
const id = document.activeElement && document.activeElement.id
const { scrollHeight, scrollTop } = getScrollContainer()
await showMoreItemsForCurrentTimeline()
// There seems to be some kind of race condition with what the timeline is doing. This is a best
// effort to maintain scroll position.
await new Promise(resolve => doubleRAF(resolve))
await new Promise(resolve => doubleRAF(resolve))
// restore scroll position
const { scrollHeight: newScrollHeight } = getScrollContainer()
const newScrollTop = scrollTop + (newScrollHeight - scrollHeight)
console.log({ scrollHeight, scrollTop, newScrollHeight, newScrollTop })
getScrollContainer().scrollTop = newScrollTop
if (id) {
await tryToFocusElement(id)
}
}

View File

@ -23,6 +23,7 @@
</div> </div>
</FocusRestoration> </FocusRestoration>
<Shortcut scope="global" key="." on:pressed="showMoreAndScrollToTop()" /> <Shortcut scope="global" key="." on:pressed="showMoreAndScrollToTop()" />
<Shortcut scope="global" key="," on:pressed="showMoreWithoutScrollingToTop()" />
<ScrollListShortcuts /> <ScrollListShortcuts />
<script> <script>
import { store } from '../../_store/store.js' import { store } from '../../_store/store.js'
@ -50,6 +51,7 @@
import { observe } from 'svelte-extras' import { observe } from 'svelte-extras'
import { createMakeProps } from '../../_actions/createMakeProps.js' import { createMakeProps } from '../../_actions/createMakeProps.js'
import { showMoreAndScrollToTop } from '../../_actions/showMoreAndScrollToTop.js' import { showMoreAndScrollToTop } from '../../_actions/showMoreAndScrollToTop.js'
import { showMoreWithoutScrollingToTop } from '../../_actions/showMoreWithoutScrollingToTop.js'
import FocusRestoration from '../FocusRestoration.html' import FocusRestoration from '../FocusRestoration.html'
export default { export default {
@ -227,7 +229,8 @@
console.log('timeline preinitialized') console.log('timeline preinitialized')
this.store.set({ timelinePreinitialized: true }) this.store.set({ timelinePreinitialized: true })
}, },
showMoreAndScrollToTop showMoreAndScrollToTop,
showMoreWithoutScrollingToTop
}, },
components: { components: {
ScrollListShortcuts, ScrollListShortcuts,