From 5f5cb0d36d08df13aeec325b6a4ca7dcd8bbce9d Mon Sep 17 00:00:00 2001 From: Nolan Lawson Date: Tue, 20 Nov 2018 08:58:13 -0800 Subject: [PATCH] fix(scroll): fix offsetHeight for scrolling whole document (#664) --- .../virtualList/VirtualListContainer.html | 25 ++++++++++++++----- routes/_utils/scrollContainer.js | 8 ++++++ 2 files changed, 27 insertions(+), 6 deletions(-) diff --git a/routes/_components/virtualList/VirtualListContainer.html b/routes/_components/virtualList/VirtualListContainer.html index 14636b7..23a69d1 100644 --- a/routes/_components/virtualList/VirtualListContainer.html +++ b/routes/_components/virtualList/VirtualListContainer.html @@ -6,7 +6,13 @@ import { mark, stop } from '../../_utils/marks' import { doubleRAF } from '../../_utils/doubleRAF' import { observe } from 'svelte-extras' - import { addScrollListener, removeScrollListener, getScrollContainer } from '../../_utils/scrollContainer' + import { + addScrollListener, + removeScrollListener, + getScrollContainer, + getOffsetHeight + } from '../../_utils/scrollContainer' + import { registerResizeListener, unregisterResizeListener } from '../../_utils/resize' const SCROLL_EVENT_DELAY = 300 @@ -19,7 +25,9 @@ this.store.setCurrentRealm(realm) this.setupScroll() this.setupFullscreen() + this.onResize = this.onResize.bind(this) let { scrollTop } = this.store.get() + let scrollContainer = getScrollContainer() if (scrollTop > 0) { this.observe('allVisibleItemsHaveHeight', allVisibleItemsHaveHeight => { console.log('allVisibleItemsHaveHeight', allVisibleItemsHaveHeight) @@ -28,7 +36,7 @@ this.set({ 'initializedScrollTop': true }) mark('set scrollTop') console.log('forcing scroll top to ', scrollTop) - getScrollContainer().scrollTop = scrollTop + scrollContainer.scrollTop = scrollTop stop('set scrollTop') doubleRAF(() => { console.log('initialized VirtualList') @@ -44,17 +52,16 @@ this.fire('initialized') } }) - this.store.setForRealm({ - scrollHeight: getScrollContainer().scrollHeight, - offsetHeight: getScrollContainer().offsetHeight - }) + this.onResize() } + registerResizeListener(this.onResize) stop('onCreate VirtualListContainer') }, ondestroy () { this.teardownScroll() this.teardownFullscreen() this.store.setCurrentRealm(null) + unregisterResizeListener(this.onResize) }, store: () => virtualListStore, methods: { @@ -96,6 +103,12 @@ console.log('is fullscreen? ', isFullscreen()) this.set({ fullscreen: isFullscreen() }) stop('onFullscreenChange') + }, + onResize () { + this.store.setForRealm({ + scrollHeight: getScrollContainer().scrollHeight, + offsetHeight: getOffsetHeight() + }) } }, computed: { diff --git a/routes/_utils/scrollContainer.js b/routes/_utils/scrollContainer.js index 4744fa5..9d77ae7 100644 --- a/routes/_utils/scrollContainer.js +++ b/routes/_utils/scrollContainer.js @@ -9,3 +9,11 @@ export function addScrollListener (listener) { export function removeScrollListener (listener) { document.removeEventListener('scroll', listener) } + +export function getOffsetHeight () { + // in a subscroller, this would be element.offsetHeight, but here + // document.scrollingElement.offsetHeight is too short for some reason. + // This one is exact, such that scrollHeight - scrollTop - offsetHeight === 0 + // when you are scrolled to the bottom. + return window.innerHeight +}