From 9ae0b8bf2f1853e7c308b54f15be7445e4c7708e Mon Sep 17 00:00:00 2001 From: Phil Johnston Date: Mon, 15 May 2023 11:51:34 -0400 Subject: [PATCH 1/2] Try moving blocks to their own modular directories --- .../index.tsx => blocks/pattern-block/PatternEdit.tsx} | 0 .../pattern-block}/registerPatternBlock.ts | 9 ++++++++- .../pattern-block/test/PatternEdit.tsx} | 8 ++++---- .../pattern-block}/test/registerPatternBlock.ts | 0 wp-modules/editor/js/src/index.ts | 7 +------ wp-modules/editor/js/src/utils/filterOutPatterns.ts | 5 +++-- .../js/src/utils/{hasPmPatternBlock.ts => hasBlock.ts} | 7 ++++--- .../src/utils/test/{hasPmPatternBlock.ts => hasBlock.ts} | 6 +++--- 8 files changed, 23 insertions(+), 19 deletions(-) rename wp-modules/editor/js/src/{components/PatternEdit/index.tsx => blocks/pattern-block/PatternEdit.tsx} (100%) rename wp-modules/editor/js/src/{utils => blocks/pattern-block}/registerPatternBlock.ts (76%) rename wp-modules/editor/js/src/{components/PatternEdit/index.test.tsx => blocks/pattern-block/test/PatternEdit.tsx} (86%) rename wp-modules/editor/js/src/{utils => blocks/pattern-block}/test/registerPatternBlock.ts (100%) rename wp-modules/editor/js/src/utils/{hasPmPatternBlock.ts => hasBlock.ts} (58%) rename wp-modules/editor/js/src/utils/test/{hasPmPatternBlock.ts => hasBlock.ts} (89%) diff --git a/wp-modules/editor/js/src/components/PatternEdit/index.tsx b/wp-modules/editor/js/src/blocks/pattern-block/PatternEdit.tsx similarity index 100% rename from wp-modules/editor/js/src/components/PatternEdit/index.tsx rename to wp-modules/editor/js/src/blocks/pattern-block/PatternEdit.tsx diff --git a/wp-modules/editor/js/src/utils/registerPatternBlock.ts b/wp-modules/editor/js/src/blocks/pattern-block/registerPatternBlock.ts similarity index 76% rename from wp-modules/editor/js/src/utils/registerPatternBlock.ts rename to wp-modules/editor/js/src/blocks/pattern-block/registerPatternBlock.ts index 9ea391e5..1473f8fe 100644 --- a/wp-modules/editor/js/src/utils/registerPatternBlock.ts +++ b/wp-modules/editor/js/src/blocks/pattern-block/registerPatternBlock.ts @@ -1,5 +1,12 @@ import { __ } from '@wordpress/i18n'; -import PatternEdit from '../components/PatternEdit'; +import { addFilter } from '@wordpress/hooks'; +import PatternEdit from './PatternEdit'; + +addFilter( + 'blocks.registerBlockType', + 'pattern-manager/registerPatternBlock', + registerPatternBlock +); export default function registerPatternBlock( settings: Record< string, unknown >, diff --git a/wp-modules/editor/js/src/components/PatternEdit/index.test.tsx b/wp-modules/editor/js/src/blocks/pattern-block/test/PatternEdit.tsx similarity index 86% rename from wp-modules/editor/js/src/components/PatternEdit/index.test.tsx rename to wp-modules/editor/js/src/blocks/pattern-block/test/PatternEdit.tsx index f69f4221..237af9ef 100644 --- a/wp-modules/editor/js/src/components/PatternEdit/index.test.tsx +++ b/wp-modules/editor/js/src/blocks/pattern-block/test/PatternEdit.tsx @@ -1,7 +1,7 @@ import { render } from '@testing-library/react'; -import PatternEdit from './'; +import PatternEdit from '../PatternEdit'; -jest.mock( '../../globals', () => { +jest.mock( '../../../globals', () => { return { patternManager: { patterns: { @@ -18,11 +18,11 @@ jest.mock( '../../globals', () => { }; } ); -jest.mock( '../../hooks/useSavedPostData', () => { +jest.mock( '../../../hooks/useSavedPostData', () => { return () => ( {} ); } ); -jest.mock( '../../../../../app/js/src/components/PatternPreview', () => { +jest.mock( '../../../../../../app/js/src/components/PatternPreview', () => { return () => null; } ); diff --git a/wp-modules/editor/js/src/utils/test/registerPatternBlock.ts b/wp-modules/editor/js/src/blocks/pattern-block/test/registerPatternBlock.ts similarity index 100% rename from wp-modules/editor/js/src/utils/test/registerPatternBlock.ts rename to wp-modules/editor/js/src/blocks/pattern-block/test/registerPatternBlock.ts diff --git a/wp-modules/editor/js/src/index.ts b/wp-modules/editor/js/src/index.ts index 99d94b38..7084fa2f 100644 --- a/wp-modules/editor/js/src/index.ts +++ b/wp-modules/editor/js/src/index.ts @@ -7,7 +7,7 @@ import PatternManagerMetaControls from './components/PatternManagerMetaControls' import changeWords from './utils/changeWords'; import preventTransform from './utils/preventTransform'; import receiveActiveTheme from './utils/receiveActiveTheme'; -import registerPatternBlock from './utils/registerPatternBlock'; +import './blocks/pattern-block/registerPatternBlock'; registerPlugin( 'pattern-manager-postmeta-for-patterns', { icon: null, @@ -25,11 +25,6 @@ addFilter( 'pattern-manager/preventTransform', preventTransform ); -addFilter( - 'blocks.registerBlockType', - 'pattern-manager/registerPatternBlock', - registerPatternBlock -); addAction( 'heartbeat.tick', 'pattern-manager/checkActiveTheme', diff --git a/wp-modules/editor/js/src/utils/filterOutPatterns.ts b/wp-modules/editor/js/src/utils/filterOutPatterns.ts index cac14c3e..2be8f80a 100644 --- a/wp-modules/editor/js/src/utils/filterOutPatterns.ts +++ b/wp-modules/editor/js/src/utils/filterOutPatterns.ts @@ -1,5 +1,5 @@ import { parse } from '@wordpress/blocks'; -import hasPmPatternBlock from './hasPmPatternBlock'; +import hasBlock from './hasBlock'; import type { Pattern, Patterns } from '../types'; /** @@ -14,7 +14,8 @@ export default function filterOutPatterns( ( accumulator, [ key, pattern ] ) => { return { ...accumulator, - ...( ! hasPmPatternBlock( + ...( ! hasBlock( + 'core/pattern', parse( pattern.content ), patternName ) && pattern.name !== patternName diff --git a/wp-modules/editor/js/src/utils/hasPmPatternBlock.ts b/wp-modules/editor/js/src/utils/hasBlock.ts similarity index 58% rename from wp-modules/editor/js/src/utils/hasPmPatternBlock.ts rename to wp-modules/editor/js/src/utils/hasBlock.ts index 732f6d99..632ba09f 100644 --- a/wp-modules/editor/js/src/utils/hasPmPatternBlock.ts +++ b/wp-modules/editor/js/src/utils/hasBlock.ts @@ -1,14 +1,15 @@ import type { Block, Pattern } from '../types'; -export default function hasPmPatternBlock( +export default function hasBlock( + blockName: String, blocks: Block[], patternName: Pattern[ 'name' ] ) { return blocks.some( ( block ) => { return ( - ( block.name === 'core/pattern' && + ( block.name === blockName && block.attributes?.slug === patternName ) || - hasPmPatternBlock( block?.innerBlocks ?? [], patternName ) + hasBlock( blockName, block?.innerBlocks ?? [], patternName ) ); } ); } diff --git a/wp-modules/editor/js/src/utils/test/hasPmPatternBlock.ts b/wp-modules/editor/js/src/utils/test/hasBlock.ts similarity index 89% rename from wp-modules/editor/js/src/utils/test/hasPmPatternBlock.ts rename to wp-modules/editor/js/src/utils/test/hasBlock.ts index 707ed36f..7c4acfc1 100644 --- a/wp-modules/editor/js/src/utils/test/hasPmPatternBlock.ts +++ b/wp-modules/editor/js/src/utils/test/hasBlock.ts @@ -1,6 +1,6 @@ -import hasPmPatternBlock from '../hasPmPatternBlock'; +import hasBlock from '../hasBlock'; -describe( 'hasPmPatternBlock', () => { +describe( 'hasBlock', () => { it.each( [ [ [ { name: '', attributes: {} } ], '', false ], [ [ { name: '', attributes: {} } ], 'example-slug', false ], @@ -75,7 +75,7 @@ describe( 'hasPmPatternBlock', () => { ] )( 'should get whether there is a Pattern Block', ( blocks, patternSlug, expected ) => { - expect( hasPmPatternBlock( blocks, patternSlug ) ).toEqual( + expect( hasBlock( 'core/pattern', blocks, patternSlug ) ).toEqual( expected ); } From 83b11c61c97ed1d50b40d05a0e4fc1ba8ce4abf5 Mon Sep 17 00:00:00 2001 From: Phil Johnston Date: Mon, 15 May 2023 15:34:32 -0400 Subject: [PATCH 2/2] Move addFilter back to index file --- .../js/src/blocks/pattern-block/registerPatternBlock.ts | 7 ------- wp-modules/editor/js/src/index.ts | 7 ++++++- 2 files changed, 6 insertions(+), 8 deletions(-) diff --git a/wp-modules/editor/js/src/blocks/pattern-block/registerPatternBlock.ts b/wp-modules/editor/js/src/blocks/pattern-block/registerPatternBlock.ts index 1473f8fe..6e25a220 100644 --- a/wp-modules/editor/js/src/blocks/pattern-block/registerPatternBlock.ts +++ b/wp-modules/editor/js/src/blocks/pattern-block/registerPatternBlock.ts @@ -1,13 +1,6 @@ import { __ } from '@wordpress/i18n'; -import { addFilter } from '@wordpress/hooks'; import PatternEdit from './PatternEdit'; -addFilter( - 'blocks.registerBlockType', - 'pattern-manager/registerPatternBlock', - registerPatternBlock -); - export default function registerPatternBlock( settings: Record< string, unknown >, name: string diff --git a/wp-modules/editor/js/src/index.ts b/wp-modules/editor/js/src/index.ts index 7084fa2f..4361eadb 100644 --- a/wp-modules/editor/js/src/index.ts +++ b/wp-modules/editor/js/src/index.ts @@ -7,7 +7,7 @@ import PatternManagerMetaControls from './components/PatternManagerMetaControls' import changeWords from './utils/changeWords'; import preventTransform from './utils/preventTransform'; import receiveActiveTheme from './utils/receiveActiveTheme'; -import './blocks/pattern-block/registerPatternBlock'; +import registerPatternBlock from './blocks/pattern-block/registerPatternBlock'; registerPlugin( 'pattern-manager-postmeta-for-patterns', { icon: null, @@ -25,6 +25,11 @@ addFilter( 'pattern-manager/preventTransform', preventTransform ); +addFilter( + 'blocks.registerBlockType', + 'pattern-manager/registerPatternBlock', + registerPatternBlock +); addAction( 'heartbeat.tick', 'pattern-manager/checkActiveTheme',