From 96af4490a3b89c59388495c36ccf6031a602dc0d Mon Sep 17 00:00:00 2001 From: Tung Du Date: Tue, 14 Dec 2021 07:46:10 +0700 Subject: [PATCH] Switch to correct view if inner block is selected (#5358) --- assets/js/blocks/cart-checkout/cart/edit.js | 26 ++++++------ .../cart-checkout/mini-cart-contents/edit.tsx | 27 ++++++------ .../shared/use-view-switcher.tsx | 42 ++++++++++++++++++- 3 files changed, 69 insertions(+), 26 deletions(-) diff --git a/assets/js/blocks/cart-checkout/cart/edit.js b/assets/js/blocks/cart-checkout/cart/edit.js index d511ba71630..07f12aab06d 100644 --- a/assets/js/blocks/cart-checkout/cart/edit.js +++ b/assets/js/blocks/cart-checkout/cart/edit.js @@ -46,6 +46,19 @@ const ALLOWED_BLOCKS = [ 'woocommerce/empty-cart-block', ]; +const views = [ + { + view: 'woocommerce/filled-cart-block', + label: __( 'Filled Cart', 'woo-gutenberg-products-block' ), + icon: , + }, + { + view: 'woocommerce/empty-cart-block', + label: __( 'Empty Cart', 'woo-gutenberg-products-block' ), + icon: , + }, +]; + const BlockSettings = ( { attributes, setAttributes } ) => { const { hasDarkControls } = attributes; const { currentPostId } = useEditorContext(); @@ -104,18 +117,7 @@ export const Edit = ( { className, attributes, setAttributes, clientId } ) => { const { hasDarkControls } = attributes; const { currentView, component: ViewSwitcherComponent } = useViewSwitcher( clientId, - [ - { - view: 'woocommerce/filled-cart-block', - label: __( 'Filled Cart', 'woo-gutenberg-products-block' ), - icon: , - }, - { - view: 'woocommerce/empty-cart-block', - label: __( 'Empty Cart', 'woo-gutenberg-products-block' ), - icon: , - }, - ] + views ); const defaultTemplate = [ [ 'woocommerce/filled-cart-block', {}, [] ], diff --git a/assets/js/blocks/cart-checkout/mini-cart-contents/edit.tsx b/assets/js/blocks/cart-checkout/mini-cart-contents/edit.tsx index cf3b2bf474d..9407ba63e20 100644 --- a/assets/js/blocks/cart-checkout/mini-cart-contents/edit.tsx +++ b/assets/js/blocks/cart-checkout/mini-cart-contents/edit.tsx @@ -22,6 +22,20 @@ const ALLOWED_BLOCKS = [ 'woocommerce/filled-mini-cart-contents-block', 'woocommerce/empty-mini-cart-contents-block', ]; + +const views = [ + { + view: 'woocommerce/filled-mini-cart-contents-block', + label: __( 'Filled Mini Cart', 'woo-gutenberg-products-block' ), + icon: , + }, + { + view: 'woocommerce/empty-mini-cart-contents-block', + label: __( 'Empty Mini Cart', 'woo-gutenberg-products-block' ), + icon: , + }, +]; + interface Props { clientId: string; } @@ -36,18 +50,7 @@ const Edit = ( { clientId }: Props ): ReactElement => { const { currentView, component: ViewSwitcherComponent } = useViewSwitcher( clientId, - [ - { - view: 'woocommerce/filled-mini-cart-contents-block', - label: __( 'Filled Mini Cart', 'woo-gutenberg-products-block' ), - icon: , - }, - { - view: 'woocommerce/empty-mini-cart-contents-block', - label: __( 'Empty Mini Cart', 'woo-gutenberg-products-block' ), - icon: , - }, - ] + views ); useForcedLayout( { diff --git a/assets/js/blocks/cart-checkout/shared/use-view-switcher.tsx b/assets/js/blocks/cart-checkout/shared/use-view-switcher.tsx index b15452695b3..d9a92290c96 100644 --- a/assets/js/blocks/cart-checkout/shared/use-view-switcher.tsx +++ b/assets/js/blocks/cart-checkout/shared/use-view-switcher.tsx @@ -2,7 +2,7 @@ * External dependencies */ import { __ } from '@wordpress/i18n'; -import { useState } from '@wordpress/element'; +import { useState, useEffect } from '@wordpress/element'; import { useDispatch, select } from '@wordpress/data'; import { ToolbarGroup, ToolbarDropdownMenu } from '@wordpress/components'; import { Icon, eye } from '@woocommerce/icons'; @@ -24,7 +24,45 @@ export const useViewSwitcher = ( const initialView = views[ 0 ]; const [ currentView, setCurrentView ] = useState( initialView ); const { selectBlock } = useDispatch( 'core/block-editor' ); - const { getBlock } = select( blockEditorStore ); + const { + getBlock, + getSelectedBlockClientId, + getBlockParentsByBlockName, + } = select( blockEditorStore ); + const selectedBlockClientId = getSelectedBlockClientId(); + + useEffect( () => { + const viewNames = views.map( ( { view } ) => view ); + const parentBlockIds = getBlockParentsByBlockName( + selectedBlockClientId, + viewNames + ); + + if ( parentBlockIds.length !== 1 ) { + return; + } + const parentBlock = getBlock( parentBlockIds[ 0 ] ); + + if ( currentView.view === parentBlock.name ) { + return; + } + + const filteredViews = views.filter( + ( { view } ) => view === parentBlock.name + ); + + if ( filteredViews.length !== 1 ) { + return; + } + + setCurrentView( filteredViews[ 0 ] ); + }, [ + getBlockParentsByBlockName, + selectedBlockClientId, + getBlock, + currentView.view, + views, + ] ); const ViewSwitcherComponent = (