fix: stabilize minimalShellMode toggling by introducing modified thresholds (supersedes #938) (#942)
* add separate scroll up/down thresholds to prevent rapid state changes * set `DY_LIMIT_DOWN` to 150 * Use a different scroll dy limit on web/mobile --------- Co-authored-by: Sehyun Chung <sehyun.chung@icloud.com>zio/stable
parent
7ee7d968e5
commit
97f0d3431c
|
@ -4,7 +4,8 @@ import {RootStoreModel} from 'state/index'
|
||||||
import {s} from 'lib/styles'
|
import {s} from 'lib/styles'
|
||||||
import {isDesktopWeb} from 'platform/detection'
|
import {isDesktopWeb} from 'platform/detection'
|
||||||
|
|
||||||
const DY_LIMIT = isDesktopWeb ? 30 : 10
|
const DY_LIMIT_UP = isDesktopWeb ? 30 : 10
|
||||||
|
const DY_LIMIT_DOWN = isDesktopWeb ? 150 : 10
|
||||||
|
|
||||||
export type OnScrollCb = (
|
export type OnScrollCb = (
|
||||||
event: NativeSyntheticEvent<NativeScrollEvent>,
|
event: NativeSyntheticEvent<NativeScrollEvent>,
|
||||||
|
@ -23,12 +24,9 @@ export function useOnMainScroll(
|
||||||
const dy = y - (lastY.current || 0)
|
const dy = y - (lastY.current || 0)
|
||||||
lastY.current = y
|
lastY.current = y
|
||||||
|
|
||||||
if (!store.shell.minimalShellMode && y > 10 && dy > DY_LIMIT) {
|
if (!store.shell.minimalShellMode && dy > DY_LIMIT_DOWN) {
|
||||||
store.shell.setMinimalShellMode(true)
|
store.shell.setMinimalShellMode(true)
|
||||||
} else if (
|
} else if (store.shell.minimalShellMode && dy < DY_LIMIT_UP * -1) {
|
||||||
store.shell.minimalShellMode &&
|
|
||||||
(y <= 10 || dy < DY_LIMIT * -1)
|
|
||||||
) {
|
|
||||||
store.shell.setMinimalShellMode(false)
|
store.shell.setMinimalShellMode(false)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue