Skip to content

Commit

Permalink
Site Editor: patterns and templates cannot be edited from sidebar mob…
Browse files Browse the repository at this point in the history
…ile view (#63002)

* In mobile mode, check for canvas edit mode so the "Edit" callback redirect the browser to the block editor in edit mode

* I suspect that the transition is causing intermittent crashing in Chrome in mobile viewports. Turning it off as it appears more stable in local testing.

* Revert unintentional change

Co-authored-by: ramonjd <[email protected]>
Co-authored-by: andrewserong <[email protected]>
Co-authored-by: youknowriad <[email protected]>
Co-authored-by: t-hamano <[email protected]>
Co-authored-by: priethor <[email protected]>
Co-authored-by: annezazu <[email protected]>
Co-authored-by: ironprogrammer <[email protected]>
Co-authored-by: ivan-ottinger <[email protected]>
Co-authored-by: mrfoxtalbot <[email protected]>
  • Loading branch information
10 people authored Jul 2, 2024
1 parent 352f568 commit 9cebb6a
Show file tree
Hide file tree
Showing 2 changed files with 22 additions and 18 deletions.
30 changes: 15 additions & 15 deletions packages/edit-site/src/components/layout/router.js
Original file line number Diff line number Diff line change
Expand Up @@ -75,6 +75,7 @@ function useRedirectOldPaths() {
export default function useLayoutAreas() {
const { params } = useLocation();
const { postType, postId, path, layout, isCustom, canvas } = params;
const hasEditCanvasMode = canvas === 'edit';
useRedirectOldPaths();

// Page list
Expand All @@ -91,13 +92,12 @@ export default function useLayoutAreas() {
/>
),
content: <PostsList postType={ postType } />,
preview: ( isListLayout || canvas === 'edit' ) && <Editor />,
mobile:
canvas === 'edit' ? (
<Editor />
) : (
<PostsList postType={ postType } />
),
preview: ( isListLayout || hasEditCanvasMode ) && <Editor />,
mobile: hasEditCanvasMode ? (
<Editor />
) : (
<PostsList postType={ postType } />
),
},
widths: {
content: isListLayout ? 380 : undefined,
Expand All @@ -115,8 +115,8 @@ export default function useLayoutAreas() {
<SidebarNavigationScreenTemplatesBrowse backPath={ {} } />
),
content: <PageTemplates />,
preview: ( isListLayout || canvas === 'edit' ) && <Editor />,
mobile: <PageTemplates />,
preview: ( isListLayout || hasEditCanvasMode ) && <Editor />,
mobile: hasEditCanvasMode ? <Editor /> : <PageTemplates />,
},
widths: {
content: isListLayout ? 380 : undefined,
Expand All @@ -133,8 +133,8 @@ export default function useLayoutAreas() {
areas: {
sidebar: <SidebarNavigationScreenPatterns backPath={ {} } />,
content: <PagePatterns />,
mobile: <PagePatterns />,
preview: canvas === 'edit' && <Editor />,
mobile: hasEditCanvasMode ? <Editor /> : <PagePatterns />,
preview: hasEditCanvasMode && <Editor />,
},
};
}
Expand All @@ -148,7 +148,7 @@ export default function useLayoutAreas() {
<SidebarNavigationScreenGlobalStyles backPath={ {} } />
),
preview: <Editor />,
mobile: canvas === 'edit' && <Editor />,
mobile: hasEditCanvasMode && <Editor />,
},
};
}
Expand All @@ -165,7 +165,7 @@ export default function useLayoutAreas() {
/>
),
preview: <Editor />,
mobile: canvas === 'edit' && <Editor />,
mobile: hasEditCanvasMode && <Editor />,
},
};
}
Expand All @@ -176,7 +176,7 @@ export default function useLayoutAreas() {
<SidebarNavigationScreenNavigationMenus backPath={ {} } />
),
preview: <Editor />,
mobile: canvas === 'edit' && <Editor />,
mobile: hasEditCanvasMode && <Editor />,
},
};
}
Expand All @@ -187,7 +187,7 @@ export default function useLayoutAreas() {
areas: {
sidebar: <SidebarNavigationScreenMain />,
preview: <Editor />,
mobile: canvas === 'edit' && <Editor />,
mobile: hasEditCanvasMode && <Editor />,
},
};
}
10 changes: 7 additions & 3 deletions packages/edit-site/src/store/private-actions.js
Original file line number Diff line number Diff line change
Expand Up @@ -13,10 +13,10 @@ import { store as editorStore } from '@wordpress/editor';
export const setCanvasMode =
( mode ) =>
( { registry, dispatch } ) => {
const isMediumOrBigger =
window.matchMedia( '(min-width: 782px)' ).matches;
const switchCanvasMode = () => {
registry.batch( () => {
const isMediumOrBigger =
window.matchMedia( '(min-width: 782px)' ).matches;
registry.dispatch( blockEditorStore ).clearSelectedBlock();
registry.dispatch( editorStore ).setDeviceType( 'Desktop' );
registry
Expand Down Expand Up @@ -59,7 +59,11 @@ export const setCanvasMode =
} );
};

if ( ! document.startViewTransition ) {
/*
* Skip transition in mobile, otherwise it crashes the browser.
* See: https://github.com/WordPress/gutenberg/pull/63002.
*/
if ( ! isMediumOrBigger || ! document.startViewTransition ) {
switchCanvasMode();
} else {
document.documentElement.classList.add(
Expand Down

0 comments on commit 9cebb6a

Please sign in to comment.