From dc71e3b424b9bd4b035247f97caf998f4d2d9eb1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Mat=C3=ADas=20Ventura?= Date: Wed, 3 Feb 2021 12:27:11 +0100 Subject: [PATCH 1/5] Use display title for template part block type toolbar anchor. Removes the display of "block type: block label" in favor of label. --- .../src/components/block-switcher/index.js | 11 ++++++----- .../src/components/block-title/index.js | 7 ++----- packages/block-library/src/template-part/index.js | 2 +- packages/blocks/README.md | 14 ++++++++++++++ packages/blocks/src/api/index.js | 1 + packages/blocks/src/api/registration.js | 13 +++++++++++++ 6 files changed, 37 insertions(+), 11 deletions(-) diff --git a/packages/block-editor/src/components/block-switcher/index.js b/packages/block-editor/src/components/block-switcher/index.js index dc3048bdda80b5..444e7d162ea2d8 100644 --- a/packages/block-editor/src/components/block-switcher/index.js +++ b/packages/block-editor/src/components/block-switcher/index.js @@ -1,7 +1,7 @@ /** * External dependencies */ -import { castArray, uniq, truncate } from 'lodash'; +import { castArray, uniq } from 'lodash'; /** * WordPress dependencies @@ -17,6 +17,7 @@ import { switchToBlockType, store as blocksStore, isReusableBlock, + isTemplatePart, } from '@wordpress/blocks'; import { useSelect, useDispatch } from '@wordpress/data'; import { stack } from '@wordpress/icons'; @@ -27,6 +28,7 @@ import { stack } from '@wordpress/icons'; import { store as blockEditorStore } from '../../store'; import useBlockDisplayInformation from '../use-block-display-information'; import BlockIcon from '../block-icon'; +import BlockTitle from '../block-title'; import BlockTransformationsMenu from './block-transformations-menu'; import BlockStylesMenu from './block-styles-menu'; @@ -88,6 +90,7 @@ export const BlockSwitcherDropdownMenu = ( { clientIds, blocks } ) => { ); const isReusable = blocks.length === 1 && isReusableBlock( blocks[ 0 ] ); + const isTemplate = blocks.length === 1 && isTemplatePart( blocks[ 0 ] ); const onTransform = ( name ) => replaceBlocks( clientIds, switchToBlockType( blocks, name ) ); @@ -139,11 +142,9 @@ export const BlockSwitcherDropdownMenu = ( { clientIds, blocks } ) => { className="block-editor-block-switcher__toggle" showColors /> - { isReusable && ( + { ( isReusable || isTemplate ) && ( - { truncate( blockTitle, { - length: 35, - } ) } + ) } diff --git a/packages/block-editor/src/components/block-title/index.js b/packages/block-editor/src/components/block-title/index.js index e19125a6c95f5b..df2c4b88daa3d1 100644 --- a/packages/block-editor/src/components/block-title/index.js +++ b/packages/block-editor/src/components/block-title/index.js @@ -65,16 +65,13 @@ export default function BlockTitle( { clientId } ) { const blockInformation = useBlockDisplayInformation( clientId ); if ( ! name || ! blockInformation ) return null; const blockType = getBlockType( name ); - const label = getBlockLabel( blockType, attributes ); + const label = reusableBlockTitle || getBlockLabel( blockType, attributes ); // Label will fallback to the title if no label is defined for the // current label context. We do not want "Paragraph: Paragraph". // If label is defined we prioritize it over possible possible // block variation match title. if ( label !== blockType.title ) { - return `${ blockType.title }: ${ truncate( label, { length: 15 } ) }`; - } - if ( reusableBlockTitle ) { - return truncate( reusableBlockTitle, { length: 35 } ); + return truncate( label, { length: 35 } ); } return blockInformation.title; } diff --git a/packages/block-library/src/template-part/index.js b/packages/block-library/src/template-part/index.js index 456dda84664a0b..8aa83fd1a036d8 100644 --- a/packages/block-library/src/template-part/index.js +++ b/packages/block-library/src/template-part/index.js @@ -20,6 +20,6 @@ export { metadata, name }; export const settings = { title: _x( 'Template Part', 'block title' ), keywords: [ __( 'template part' ) ], - __experimentalLabel: ( { slug } ) => startCase( slug ), + __experimentalLabel: ( { title: slug } ) => startCase( slug ), edit, }; diff --git a/packages/blocks/README.md b/packages/blocks/README.md index 2f3e282cab2ca4..f2347725ba74b9 100644 --- a/packages/blocks/README.md +++ b/packages/blocks/README.md @@ -534,6 +534,20 @@ _Returns_ - `boolean`: Whether the given block is a reusable block. +# **isTemplatePart** + +Determines whether or not the given block is a template part. This is a +special block type that allows composing a page template out of reusable +design elements. + +_Parameters_ + +- _blockOrType_ `Object`: Block or Block Type to test. + +_Returns_ + +- `boolean`: Whether the given block is a template part. + # **isUnmodifiedDefaultBlock** Determines whether the block is a default block diff --git a/packages/blocks/src/api/index.js b/packages/blocks/src/api/index.js index cedca941340778..afc632fe4942bc 100644 --- a/packages/blocks/src/api/index.js +++ b/packages/blocks/src/api/index.js @@ -123,6 +123,7 @@ export { hasBlockSupport, getBlockVariations, isReusableBlock, + isTemplatePart, getChildBlockNames, hasChildBlocks, hasChildBlocksWithInserterSupport, diff --git a/packages/blocks/src/api/registration.js b/packages/blocks/src/api/registration.js index 8aa2f025410adf..6d327d3b0e2c88 100644 --- a/packages/blocks/src/api/registration.js +++ b/packages/blocks/src/api/registration.js @@ -474,6 +474,19 @@ export function isReusableBlock( blockOrType ) { return blockOrType.name === 'core/block'; } +/** + * Determines whether or not the given block is a template part. This is a + * special block type that allows composing a page template out of reusable + * design elements. + * + * @param {Object} blockOrType Block or Block Type to test. + * + * @return {boolean} Whether the given block is a template part. + */ +export function isTemplatePart( blockOrType ) { + return blockOrType.name === 'core/template-part'; +} + /** * Returns an array with the child blocks of a given block. * From f1b28fd801c1c8649786ddeb7b0387e405d3acfd Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Mat=C3=ADas=20Ventura?= Date: Wed, 3 Feb 2021 12:50:43 +0100 Subject: [PATCH 2/5] Remove unnecessary code now that we use BlockTitle --- .../src/components/block-switcher/index.js | 17 ++++------------- .../block-library/src/template-part/index.js | 2 +- 2 files changed, 5 insertions(+), 14 deletions(-) diff --git a/packages/block-editor/src/components/block-switcher/index.js b/packages/block-editor/src/components/block-switcher/index.js index 444e7d162ea2d8..ef0d601c495c86 100644 --- a/packages/block-editor/src/components/block-switcher/index.js +++ b/packages/block-editor/src/components/block-switcher/index.js @@ -42,11 +42,9 @@ export const BlockSwitcherDropdownMenu = ( { clientIds, blocks } ) => { blockTitle, } = useSelect( ( select ) => { - const { - getBlockRootClientId, - getBlockTransformItems, - __experimentalGetReusableBlockTitle, - } = select( blockEditorStore ); + const { getBlockRootClientId, getBlockTransformItems } = select( + blockEditorStore + ); const { getBlockStyles, getBlockType } = select( blocksStore ); const rootClientId = getBlockRootClientId( @@ -57,14 +55,8 @@ export const BlockSwitcherDropdownMenu = ( { clientIds, blocks } ) => { const styles = _isSingleBlockSelected && getBlockStyles( firstBlockName ); let _icon; - let reusableBlockTitle; if ( _isSingleBlockSelected ) { _icon = blockInformation?.icon; // Take into account active block variations. - reusableBlockTitle = - isReusableBlock( blocks[ 0 ] ) && - __experimentalGetReusableBlockTitle( - blocks[ 0 ].attributes.ref - ); } else { const isSelectionOfSameType = uniq( blocks.map( ( { name } ) => name ) ).length === 1; @@ -82,8 +74,7 @@ export const BlockSwitcherDropdownMenu = ( { clientIds, blocks } ) => { ), hasBlockStyles: !! styles?.length, icon: _icon, - blockTitle: - reusableBlockTitle || getBlockType( firstBlockName ).title, + blockTitle: getBlockType( firstBlockName ).title, }; }, [ clientIds, blocks, blockInformation?.icon ] diff --git a/packages/block-library/src/template-part/index.js b/packages/block-library/src/template-part/index.js index 8aa83fd1a036d8..456dda84664a0b 100644 --- a/packages/block-library/src/template-part/index.js +++ b/packages/block-library/src/template-part/index.js @@ -20,6 +20,6 @@ export { metadata, name }; export const settings = { title: _x( 'Template Part', 'block title' ), keywords: [ __( 'template part' ) ], - __experimentalLabel: ( { title: slug } ) => startCase( slug ), + __experimentalLabel: ( { slug } ) => startCase( slug ), edit, }; From f00064406e8f25fa690999fbe44f1ebd83b3030b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Mat=C3=ADas=20Ventura?= Date: Thu, 4 Feb 2021 11:05:51 +0100 Subject: [PATCH 3/5] Account for show-text-buttons preference. --- .../src/components/block-switcher/style.scss | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/packages/block-editor/src/components/block-switcher/style.scss b/packages/block-editor/src/components/block-switcher/style.scss index 55c978bb500d5a..a3d17760fcdca8 100644 --- a/packages/block-editor/src/components/block-switcher/style.scss +++ b/packages/block-editor/src/components/block-switcher/style.scss @@ -22,6 +22,15 @@ .block-editor-block-switcher__toggle-text { margin-left: $grid-unit-10; + + // Account for double label when show-text-buttons is set. + .show-icon-labels & { + display: none; + } +} + +.show-icon-labels .block-editor-block-toolbar .block-editor-block-switcher .components-button.has-icon::after { + font-size: 14px; } // Indent the popover to match the button position. From b2b450289bf611496d4144be10826d84b428436f Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Mat=C3=ADas=20Ventura?= Date: Thu, 4 Feb 2021 11:15:00 +0100 Subject: [PATCH 4/5] Tweak block title comment --- packages/block-editor/src/components/block-title/index.js | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) diff --git a/packages/block-editor/src/components/block-title/index.js b/packages/block-editor/src/components/block-title/index.js index df2c4b88daa3d1..5a4b9a3e0e1219 100644 --- a/packages/block-editor/src/components/block-title/index.js +++ b/packages/block-editor/src/components/block-title/index.js @@ -66,10 +66,9 @@ export default function BlockTitle( { clientId } ) { if ( ! name || ! blockInformation ) return null; const blockType = getBlockType( name ); const label = reusableBlockTitle || getBlockLabel( blockType, attributes ); - // Label will fallback to the title if no label is defined for the - // current label context. We do not want "Paragraph: Paragraph". - // If label is defined we prioritize it over possible possible - // block variation match title. + // Label will fallback to the title if no label is defined for the current + // label context. If the label is defined we prioritize it over possible + // possible block variation title match. if ( label !== blockType.title ) { return truncate( label, { length: 35 } ); } From d7825b82b07155f712b8e250d5d5e920c28d11fc Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Mat=C3=ADas=20Ventura?= Date: Thu, 4 Feb 2021 11:52:17 +0100 Subject: [PATCH 5/5] Correct block title tests. --- .../block-editor/src/components/block-title/test/index.js | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) diff --git a/packages/block-editor/src/components/block-title/test/index.js b/packages/block-editor/src/components/block-title/test/index.js index 23af6288130e01..e2fb00937ba045 100644 --- a/packages/block-editor/src/components/block-title/test/index.js +++ b/packages/block-editor/src/components/block-title/test/index.js @@ -103,7 +103,7 @@ describe( 'BlockTitle', () => { const wrapper = shallow( ); - expect( wrapper.text() ).toBe( 'Block With Label: Test Label' ); + expect( wrapper.text() ).toBe( 'Test Label' ); } ); it( 'truncates the label if it is too long', () => { @@ -116,8 +116,6 @@ describe( 'BlockTitle', () => { ); - expect( wrapper.text() ).toBe( - 'Block With Long Label: This is a lo...' - ); + expect( wrapper.text() ).toBe( 'This is a longer label than typi...' ); } ); } );