From: ThibG Date: Sun, 25 Aug 2019 13:48:50 +0000 (+0200) Subject: Change window resize handler to switch to/from mobile layout as soon as needed (... X-Git-Url: https://git.xn--scling-oua.cat.family/?a=commitdiff_plain;h=bd4099d976b52f7ec00e00b23cfe6e2766ff1e4d;p=mastodon.git Change window resize handler to switch to/from mobile layout as soon as needed (#11656) --- diff --git a/app/javascript/mastodon/features/ui/index.js b/app/javascript/mastodon/features/ui/index.js index f0c3eff83..9d284c221 100644 --- a/app/javascript/mastodon/features/ui/index.js +++ b/app/javascript/mastodon/features/ui/index.js @@ -141,14 +141,24 @@ class SwitchingColumnsArea extends React.PureComponent { return location.state !== previewMediaState && location.state !== previewVideoState; } - handleResize = debounce(() => { + handleLayoutChange = debounce(() => { // The cached heights are no longer accurate, invalidate this.props.onLayoutChange(); - - this.setState({ mobile: isMobile(window.innerWidth) }); }, 500, { trailing: true, - }); + }) + + handleResize = () => { + const mobile = isMobile(window.innerWidth); + + if (mobile !== this.state.mobile) { + this.handleLayoutChange.cancel(); + this.props.onLayoutChange(); + this.setState({ mobile }); + } else { + this.handleLayoutChange(); + } + } setRef = c => { this.node = c.getWrappedInstance();