From 171f92d3e80f6dacf6b93c127d2b1617cda5935e Mon Sep 17 00:00:00 2001 From: George Mamadashvili Date: Fri, 13 Oct 2023 16:33:52 +0400 Subject: [PATCH] Block Editor: Optimize 'customClassName' controls --- .../src/hooks/custom-class-name.js | 67 ++++++++++--------- 1 file changed, 36 insertions(+), 31 deletions(-) diff --git a/packages/block-editor/src/hooks/custom-class-name.js b/packages/block-editor/src/hooks/custom-class-name.js index 087fdffe23255a..c6e7e5409ea99f 100644 --- a/packages/block-editor/src/hooks/custom-class-name.js +++ b/packages/block-editor/src/hooks/custom-class-name.js @@ -39,6 +39,30 @@ export function addAttribute( settings ) { return settings; } +function CustomClassNameControls( { attributes, setAttributes } ) { + const blockEditingMode = useBlockEditingMode(); + if ( blockEditingMode !== 'default' ) { + return null; + } + + return ( + + { + setAttributes( { + className: nextValue !== '' ? nextValue : undefined, + } ); + } } + help={ __( 'Separate multiple classes with spaces.' ) } + /> + + ); +} + /** * Override the default edit UI to include a new block inspector control for * assigning the custom class name, if block supports custom class name. @@ -51,42 +75,23 @@ export function addAttribute( settings ) { export const withInspectorControl = createHigherOrderComponent( ( BlockEdit ) => { return ( props ) => { - const blockEditingMode = useBlockEditingMode(); const hasCustomClassName = hasBlockSupport( props.name, 'customClassName', true ); - if ( hasCustomClassName && props.isSelected ) { - return ( - <> - - { blockEditingMode === 'default' && ( - - { - props.setAttributes( { - className: - nextValue !== '' - ? nextValue - : undefined, - } ); - } } - help={ __( - 'Separate multiple classes with spaces.' - ) } - /> - - ) } - - ); - } - - return ; + + return ( + <> + { hasCustomClassName && props.isSelected && ( + + ) } + + + ); }; }, 'withInspectorControl'