-
Notifications
You must be signed in to change notification settings - Fork 4.3k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add template replace flow to template inspector (#54609)
* Add a modal to allow template switching * fetch template info * Allow switching to different patterns * Allow switching to different patterns * Add columns * move availble templates to the actions * filter for the correct templates * create the right data structure in the use select * move to a hook * inject theme attribute into pattern again * put the overlay over the top of the dropdown * fix the pattern to templates hook * set the template on click * Also set the blocks * remove calls to set template with the current template, since setting blocks correctly updates the content in the editor * serialize blocks so that we have correctly processed template parts * remove duplicated code * Remove unnecessary mapping * refactor * memoize the patterns * combine the useSelect * Update packages/edit-site/src/components/sidebar-edit-mode/page-panels/hooks.js Co-authored-by: Andrei Draganescu <[email protected]> * Fix ESLint error * Only show the button is there is more than 1 pattern * Copy update * Move the hook to a subdir * check that there are patterns * move the check * remove useCallback * change condition to show the button * change condition * move to use editEntityRecord * combine filters * add comments * Update packages/edit-site/src/components/sidebar-edit-mode/template-panel/replace-template-button.js Co-authored-by: Andrei Draganescu <[email protected]> --------- Co-authored-by: Andrei Draganescu <[email protected]> Co-authored-by: Andrei Draganescu <[email protected]> Co-authored-by: George Mamadashvili <[email protected]>
- Loading branch information
1 parent
8b264bf
commit 39b57b0
Showing
5 changed files
with
232 additions
and
12 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
97 changes: 97 additions & 0 deletions
97
packages/edit-site/src/components/sidebar-edit-mode/template-panel/hooks.js
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,97 @@ | ||
/** | ||
* WordPress dependencies | ||
*/ | ||
import { useSelect } from '@wordpress/data'; | ||
import { useMemo } from '@wordpress/element'; | ||
import { store as coreStore } from '@wordpress/core-data'; | ||
import { parse } from '@wordpress/blocks'; | ||
|
||
/** | ||
* Internal dependencies | ||
*/ | ||
import { store as editSiteStore } from '../../../store'; | ||
import { PATTERN_CORE_SOURCES, PATTERN_TYPES } from '../../../utils/constants'; | ||
import { unlock } from '../../../lock-unlock'; | ||
|
||
function injectThemeAttributeInBlockTemplateContent( | ||
block, | ||
currentThemeStylesheet | ||
) { | ||
block.innerBlocks = block.innerBlocks.map( ( innerBlock ) => { | ||
return injectThemeAttributeInBlockTemplateContent( | ||
innerBlock, | ||
currentThemeStylesheet | ||
); | ||
} ); | ||
|
||
if ( | ||
block.name === 'core/template-part' && | ||
block.attributes.theme === undefined | ||
) { | ||
block.attributes.theme = currentThemeStylesheet; | ||
} | ||
return block; | ||
} | ||
|
||
function preparePatterns( patterns, template, currentThemeStylesheet ) { | ||
// Filter out duplicates. | ||
const filterOutDuplicatesByName = ( currentItem, index, items ) => | ||
index === items.findIndex( ( item ) => currentItem.name === item.name ); | ||
|
||
// Filter out core patterns. | ||
const filterOutCorePatterns = ( pattern ) => | ||
! PATTERN_CORE_SOURCES.includes( pattern.source ); | ||
|
||
// Filter only the patterns that are compatible with the current template. | ||
const filterCompatiblePatterns = ( pattern ) => | ||
pattern.templateTypes?.includes( template.slug ); | ||
|
||
return patterns | ||
.filter( | ||
filterOutCorePatterns && | ||
filterOutDuplicatesByName && | ||
filterCompatiblePatterns | ||
) | ||
.map( ( pattern ) => ( { | ||
...pattern, | ||
keywords: pattern.keywords || [], | ||
type: PATTERN_TYPES.theme, | ||
blocks: parse( pattern.content, { | ||
__unstableSkipMigrationLogs: true, | ||
} ).map( ( block ) => | ||
injectThemeAttributeInBlockTemplateContent( | ||
block, | ||
currentThemeStylesheet | ||
) | ||
), | ||
} ) ); | ||
} | ||
|
||
export function useAvailablePatterns( template ) { | ||
const { blockPatterns, restBlockPatterns, currentThemeStylesheet } = | ||
useSelect( ( select ) => { | ||
const { getSettings } = unlock( select( editSiteStore ) ); | ||
const settings = getSettings(); | ||
|
||
return { | ||
blockPatterns: | ||
settings.__experimentalAdditionalBlockPatterns ?? | ||
settings.__experimentalBlockPatterns, | ||
restBlockPatterns: select( coreStore ).getBlockPatterns(), | ||
currentThemeStylesheet: | ||
select( coreStore ).getCurrentTheme().stylesheet, | ||
}; | ||
}, [] ); | ||
|
||
return useMemo( () => { | ||
const mergedPatterns = [ | ||
...( blockPatterns || [] ), | ||
...( restBlockPatterns || [] ), | ||
]; | ||
return preparePatterns( | ||
mergedPatterns, | ||
template, | ||
currentThemeStylesheet | ||
); | ||
}, [ blockPatterns, restBlockPatterns, template, currentThemeStylesheet ] ); | ||
} |
89 changes: 89 additions & 0 deletions
89
...ages/edit-site/src/components/sidebar-edit-mode/template-panel/replace-template-button.js
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,89 @@ | ||
/** | ||
* WordPress dependencies | ||
*/ | ||
import { useSelect, useDispatch } from '@wordpress/data'; | ||
import { useState } from '@wordpress/element'; | ||
import { __experimentalBlockPatternsList as BlockPatternsList } from '@wordpress/block-editor'; | ||
import { MenuItem, Modal } from '@wordpress/components'; | ||
import { __ } from '@wordpress/i18n'; | ||
import { store as coreStore } from '@wordpress/core-data'; | ||
import { useAsyncList } from '@wordpress/compose'; | ||
import { serialize } from '@wordpress/blocks'; | ||
|
||
/** | ||
* Internal dependencies | ||
*/ | ||
import { store as editSiteStore } from '../../../store'; | ||
|
||
export default function ReplaceTemplateButton( { | ||
onClick, | ||
availableTemplates, | ||
} ) { | ||
const { editEntityRecord } = useDispatch( coreStore ); | ||
const [ showModal, setShowModal ] = useState( false ); | ||
const onClose = () => { | ||
setShowModal( false ); | ||
}; | ||
|
||
const { postId, postType } = useSelect( ( select ) => { | ||
return { | ||
postId: select( editSiteStore ).getEditedPostId(), | ||
postType: select( editSiteStore ).getEditedPostType(), | ||
}; | ||
}, [] ); | ||
|
||
const onTemplateSelect = async ( selectedTemplate ) => { | ||
onClose(); // Close the template suggestions modal first. | ||
onClick(); | ||
await editEntityRecord( 'postType', postType, postId, { | ||
blocks: selectedTemplate.blocks, | ||
content: serialize( selectedTemplate.blocks ), | ||
} ); | ||
}; | ||
|
||
if ( ! availableTemplates.length || availableTemplates.length < 1 ) { | ||
return null; | ||
} | ||
|
||
return ( | ||
<> | ||
<MenuItem | ||
info={ __( | ||
'Replace the contents of this template with another.' | ||
) } | ||
onClick={ () => setShowModal( true ) } | ||
> | ||
{ __( 'Replace template' ) } | ||
</MenuItem> | ||
|
||
{ showModal && ( | ||
<Modal | ||
title={ __( 'Choose a template' ) } | ||
onRequestClose={ onClose } | ||
overlayClassName="edit-site-template-panel__replace-template-modal" | ||
isFullScreen | ||
> | ||
<div className="edit-site-template-panel__replace-template-modal__content"> | ||
<TemplatesList | ||
availableTemplates={ availableTemplates } | ||
onSelect={ onTemplateSelect } | ||
/> | ||
</div> | ||
</Modal> | ||
) } | ||
</> | ||
); | ||
} | ||
|
||
function TemplatesList( { availableTemplates, onSelect } ) { | ||
const shownTemplates = useAsyncList( availableTemplates ); | ||
|
||
return ( | ||
<BlockPatternsList | ||
label={ __( 'Templates' ) } | ||
blockPatterns={ availableTemplates } | ||
shownPatterns={ shownTemplates } | ||
onClickPattern={ onSelect } | ||
/> | ||
); | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
39b57b0
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Flaky tests detected in 39b57b0.
Some tests passed with failed attempts. The failures may not be related to this commit but are still reported for visibility. See the documentation for more information.
🔍 Workflow run URL: https://github.com/WordPress/gutenberg/actions/runs/6397951748
📝 Reported issues:
/test/e2e/specs/editor/various/multi-block-selection.spec.js