From eb90385ee9d87eaf95e5411da107a5241bad2489 Mon Sep 17 00:00:00 2001 From: Cyprien P Date: Thu, 21 Jan 2021 10:33:08 +0100 Subject: [PATCH] (core) Keeps side panels closed when opening doc on a narrow screen Test Plan: Includes nbrowser tests. Reviewers: paulfitz Reviewed By: paulfitz Differential Revision: https://phab.getgrist.com/D2709 --- app/client/ui/AppUI.ts | 19 ++++++++++++++----- app/client/ui2018/cssVars.ts | 4 ++++ 2 files changed, 18 insertions(+), 5 deletions(-) diff --git a/app/client/ui/AppUI.ts b/app/client/ui/AppUI.ts index c035836d..6fac8efa 100644 --- a/app/client/ui/AppUI.ts +++ b/app/client/ui/AppUI.ts @@ -15,7 +15,7 @@ import {pagePanels} from 'app/client/ui/PagePanels'; import {RightPanel} from 'app/client/ui/RightPanel'; import {createTopBarDoc, createTopBarHome} from 'app/client/ui/TopBar'; import {WelcomePage} from 'app/client/ui/WelcomePage'; -import {testId} from 'app/client/ui2018/cssVars'; +import {isNarrowScreen, testId} from 'app/client/ui2018/cssVars'; import {Computed, dom, IDisposable, IDisposableOwner, Observable, replaceContent, subscribe} from 'grainjs'; // When integrating into the old app, we might in theory switch between new-style and old-style @@ -103,15 +103,24 @@ function pagePanelsHome(owner: IDisposableOwner, appModel: AppModel) { }); } +// Create session observable. But if device is a narrow screen create a regular observable. +function createPanelObs(owner: IDisposableOwner, key: string, _default: T, isValid: (val: any) => val is T) { + if (isNarrowScreen()) { + return Observable.create(owner, _default); + } + return createSessionObs(owner, key, _default, isValid); +} + function pagePanelsDoc(owner: IDisposableOwner, appModel: AppModel, appObj: App) { const pageModel = DocPageModelImpl.create(owner, appObj, appModel); // To simplify manual inspection in the common case, keep the most recently created // DocPageModel available as a global variable. (window as any).gristDocPageModel = pageModel; - const leftPanelOpen = createSessionObs(owner, "leftPanelOpen", true, isBoolean); - const rightPanelOpen = createSessionObs(owner, "rightPanelOpen", false, isBoolean); - const leftPanelWidth = createSessionObs(owner, "leftPanelWidth", 240, isNumber); - const rightPanelWidth = createSessionObs(owner, "rightPanelWidth", 240, isNumber); + const leftPanelOpen = createPanelObs(owner, "leftPanelOpen", isNarrowScreen() ? false : true, + isBoolean); + const rightPanelOpen = createPanelObs(owner, "rightPanelOpen", false, isBoolean); + const leftPanelWidth = createPanelObs(owner, "leftPanelWidth", 240, isNumber); + const rightPanelWidth = createPanelObs(owner, "rightPanelWidth", 240, isNumber); // The RightPanel component gets created only when an instance of GristDoc is set in pageModel. // use.owner is a feature of grainjs to make the new RightPanel owned by the computed itself: diff --git a/app/client/ui2018/cssVars.ts b/app/client/ui2018/cssVars.ts index de825a0b..ec72d398 100644 --- a/app/client/ui2018/cssVars.ts +++ b/app/client/ui2018/cssVars.ts @@ -157,6 +157,10 @@ export const testId: TestId = makeTestId('test-'); // Max width for narrow screen layout (in px). Note: 768px is bootstrap's definition of small screen export const maxNarrowScreenWidth = 768; +export function isNarrowScreen() { + return window.innerWidth <= 768; +} + export const cssHideForNarrowScreen = styled('div', ` @media (max-width: ${maxNarrowScreenWidth}px) { & {