Skip to content

Commit

Permalink
Refactor for simplicity
Browse files Browse the repository at this point in the history
  • Loading branch information
jeryj committed Dec 3, 2024
1 parent dffbe14 commit 69c6cf2
Show file tree
Hide file tree
Showing 2 changed files with 28 additions and 23 deletions.
44 changes: 22 additions & 22 deletions packages/block-editor/src/hooks/use-zoom-out.js
Original file line number Diff line number Diff line change
Expand Up @@ -22,13 +22,12 @@ export function useZoomOut( zoomOut = true ) {
const { isZoomOut } = unlock( useSelect( blockEditorStore ) );

const toggleZoomOnUnmount = useRef( false );
const zoomStateOnMount = useRef( null );

// Let this hook know if the zoom state was changed manually.
const userZoomOutState = isZoomOut();
const userZoomState = useRef( null );
const isZoomedOut = isZoomOut();

useEffect( () => {
zoomStateOnMount.current = isZoomOut();
// Store the user's manually set zoom state on mount.
userZoomState.current = isZoomOut();

return () => {
if ( ! toggleZoomOnUnmount.current ) {
Expand All @@ -43,19 +42,16 @@ export function useZoomOut( zoomOut = true ) {
};
}, [] );

// This hook should only run when zoomOut changes, so we check for isZoomOut() within the
// hook rather than passing in
/**
* This hook should only run when the requested zoomOut changes. We don't want to
* update it when isZoomedOut changes.
*/
useEffect( () => {
const isZoomedOut = isZoomOut();

// Requested zoom and current zoom states are different, so toggle the state.
if ( zoomOut !== isZoomedOut ) {
// If we are in tracked mode (zoomStateOnMount !== null) and the zoomOut state
// changes back to the original state, then we should not reset the zoom level on unmount.
if (
zoomStateOnMount.current !== null &&
zoomStateOnMount.current === zoomOut
) {
// If the requested zoomOut matches the user's manually set zoom state,
// do not toggle the zoom level on unmount.
if ( userZoomState.current === zoomOut ) {
toggleZoomOnUnmount.current = false;
} else {
toggleZoomOnUnmount.current = true;
Expand All @@ -67,21 +63,25 @@ export function useZoomOut( zoomOut = true ) {
setZoomLevel( 'auto-scaled' );
}
}
}, [ zoomOut, setZoomLevel, isZoomOut, resetZoomLevel ] );
// Intentionally excluding isZoomedOut so this hook will not recursively udpate.
// eslint-disable-next-line react-hooks/exhaustive-deps
}, [ zoomOut, setZoomLevel, resetZoomLevel ] );

/**
* This hook tracks if the zoom state was changed manually by the user via clicking
* the zoom out button.
*/
useEffect( () => {
// If the zoom state changed (isZoomOut) and it does not match the requested zoom
// state (zoomOut), then it means the user manually changed the zoom state and we should
// not toggle the zoom level on unmount.
if ( userZoomOutState !== zoomOut ) {
if ( isZoomedOut !== zoomOut ) {
toggleZoomOnUnmount.current = false;
// We no longer care about the zoom state on mount.
// We are tracking the toggle on unmount based on if this hook changes.
zoomStateOnMount.current = null;
userZoomState.current = zoomOut;
}

// Intentionally excluding zoomOut from the dependency array. We want to catch instances where
// the zoom out state changes due to user interaction and not due to the hook.
// eslint-disable-next-line react-hooks/rules-of-hooks
}, [ userZoomOutState ] );
// eslint-disable-next-line react-hooks/exhaustive-deps
}, [ isZoomedOut ] );
}
7 changes: 6 additions & 1 deletion test/e2e/specs/site-editor/site-editor-inserter.spec.js
Original file line number Diff line number Diff line change
Expand Up @@ -146,6 +146,7 @@ test.describe( 'Site Editor Inserter', () => {
const blocksTab = InserterUtils.getBlockLibraryTab( 'Blocks' );
await blocksTab.click();
await expect( blocksTab ).toHaveAttribute( 'data-active-item', 'true' );

// Zoom out should disengage
await expect( await InserterUtils.getZoomCanvas() ).toBeHidden();

Expand Down Expand Up @@ -199,6 +200,8 @@ test.describe( 'Site Editor Inserter', () => {
const blockLibrary = InserterUtils.getBlockLibrary();

await inserterButton.click();

// Go to patterns tab which should enter zoom out
const patternsTab = InserterUtils.getBlockLibraryTab( 'Patterns' );
await patternsTab.click();
await expect( patternsTab ).toHaveAttribute(
Expand All @@ -207,9 +210,11 @@ test.describe( 'Site Editor Inserter', () => {
);
await expect( await InserterUtils.getZoomCanvas() ).toBeVisible();

// Manually toggle zoom out off
await zoomOutButton.click();
await expect( await InserterUtils.getZoomCanvas() ).toBeHidden();
// Toggle again to return to zoom state

// Manually toggle zoom out again to return to zoomed-in state set by the patterns tab.
await zoomOutButton.click();
await expect( await InserterUtils.getZoomCanvas() ).toBeVisible();

Expand Down

0 comments on commit 69c6cf2

Please sign in to comment.