From 66ede2519f8cbc020de3b6ec88c33f1b92bd638b Mon Sep 17 00:00:00 2001 From: Ella Date: Tue, 10 Dec 2024 10:44:24 +0900 Subject: [PATCH] Details block: remove auto-close behaviour --- packages/block-library/src/details/edit.js | 32 +++++++--------------- 1 file changed, 10 insertions(+), 22 deletions(-) diff --git a/packages/block-library/src/details/edit.js b/packages/block-library/src/details/edit.js index 314556ba6d591..6c274a90973ea 100644 --- a/packages/block-library/src/details/edit.js +++ b/packages/block-library/src/details/edit.js @@ -5,12 +5,11 @@ import { RichText, useBlockProps, useInnerBlocksProps, - store as blockEditorStore, InspectorControls, } from '@wordpress/block-editor'; -import { useSelect } from '@wordpress/data'; import { PanelBody, ToggleControl } from '@wordpress/components'; import { __ } from '@wordpress/i18n'; +import { useState } from '@wordpress/element'; const TEMPLATE = [ [ @@ -21,27 +20,14 @@ const TEMPLATE = [ ], ]; -function DetailsEdit( { attributes, setAttributes, clientId } ) { +function DetailsEdit( { attributes, setAttributes } ) { const { showContent, summary } = attributes; const blockProps = useBlockProps(); const innerBlocksProps = useInnerBlocksProps( blockProps, { template: TEMPLATE, __experimentalCaptureToolbars: true, } ); - - // Check if either the block or the inner blocks are selected. - const hasSelection = useSelect( - ( select ) => { - const { isBlockSelected, hasSelectedInnerBlock } = - select( blockEditorStore ); - /* Sets deep to true to also find blocks inside the details content block. */ - return ( - hasSelectedInnerBlock( clientId, true ) || - isBlockSelected( clientId ) - ); - }, - [ clientId ] - ); + const [ isOpen, setIsOpen ] = useState( showContent ); return ( <> @@ -59,11 +45,13 @@ function DetailsEdit( { attributes, setAttributes, clientId } ) { /> -
- event.preventDefault() }> +
+ { + event.preventDefault(); + setIsOpen( ! isOpen ); + } } + >