-
Notifications
You must be signed in to change notification settings - Fork 4.3k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Block Quick Inserter: Prioritize showing patterns instead of blocks. #38709
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -23,6 +23,7 @@ import { store as blockEditorStore } from '../../store'; | |
const SEARCH_THRESHOLD = 6; | ||
const SHOWN_BLOCK_TYPES = 6; | ||
const SHOWN_BLOCK_PATTERNS = 2; | ||
const SHOWN_BLOCK_PATTERNS_WITH_PRIORITIZATION = 4; | ||
|
||
export default function QuickInserter( { | ||
onSelect, | ||
|
@@ -46,26 +47,39 @@ export default function QuickInserter( { | |
onInsertBlocks, | ||
destinationRootClientId | ||
); | ||
const showPatterns = patterns.length && !! filterValue; | ||
const showSearch = | ||
( showPatterns && patterns.length > SEARCH_THRESHOLD ) || | ||
blockTypes.length > SEARCH_THRESHOLD; | ||
|
||
const { setInserterIsOpened, insertionIndex } = useSelect( | ||
const { | ||
setInserterIsOpened, | ||
insertionIndex, | ||
prioritizePatterns, | ||
} = useSelect( | ||
( select ) => { | ||
const { getSettings, getBlockIndex, getBlockCount } = select( | ||
blockEditorStore | ||
); | ||
const settings = getSettings(); | ||
const index = getBlockIndex( clientId ); | ||
const blockCount = getBlockCount(); | ||
|
||
return { | ||
setInserterIsOpened: getSettings() | ||
.__experimentalSetIsInserterOpened, | ||
insertionIndex: index === -1 ? getBlockCount() : index, | ||
setInserterIsOpened: settings.__experimentalSetIsInserterOpened, | ||
prioritizePatterns: | ||
settings.__experimentalPreferPatternsOnRoot && | ||
! rootClientId && | ||
index > 0 && | ||
( index < blockCount || blockCount === 0 ), | ||
insertionIndex: index === -1 ? blockCount : index, | ||
}; | ||
}, | ||
[ clientId, rootClientId ] | ||
); | ||
|
||
const showPatterns = | ||
patterns.length && ( !! filterValue || prioritizePatterns ); | ||
const showSearch = | ||
( showPatterns && patterns.length > SEARCH_THRESHOLD ) || | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Edge case here in the case of prioritizing patterns where the There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Hi @ntsekouras, I think here SHOWN_BLOCK_PATTERNS_WITH_PRIORITIZATION is not relevant, patterns.length contains the full number of patterns e.g: if we have 34 patterns and SHOWN_BLOCK_PATTERNS_WITH_PRIORITIZATION is 2 and SEARCH_THRESHOLD is 3 we are going to show search anyway as expected because we have 34 patterns. |
||
blockTypes.length > SEARCH_THRESHOLD; | ||
|
||
useEffect( () => { | ||
if ( setInserterIsOpened ) { | ||
setInserterIsOpened( false ); | ||
|
@@ -78,6 +92,13 @@ export default function QuickInserter( { | |
setInserterIsOpened( { rootClientId, insertionIndex, filterValue } ); | ||
}; | ||
|
||
let maxBlockPatterns = 0; | ||
if ( showPatterns ) { | ||
maxBlockPatterns = prioritizePatterns | ||
? SHOWN_BLOCK_PATTERNS_WITH_PRIORITIZATION | ||
: SHOWN_BLOCK_PATTERNS; | ||
} | ||
|
||
return ( | ||
<div | ||
className={ classnames( 'block-editor-inserter__quick-inserter', { | ||
|
@@ -104,9 +125,10 @@ export default function QuickInserter( { | |
rootClientId={ rootClientId } | ||
clientId={ clientId } | ||
isAppender={ isAppender } | ||
maxBlockPatterns={ showPatterns ? SHOWN_BLOCK_PATTERNS : 0 } | ||
maxBlockPatterns={ maxBlockPatterns } | ||
maxBlockTypes={ SHOWN_BLOCK_TYPES } | ||
isDraggable={ false } | ||
prioritizePatterns={ prioritizePatterns } | ||
/> | ||
</div> | ||
|
||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -48,6 +48,7 @@ function InserterSearchResults( { | |
showBlockDirectory = false, | ||
isDraggable = true, | ||
shouldFocusBlock = true, | ||
prioritizePatterns, | ||
} ) { | ||
const debouncedSpeak = useDebounce( speak, 500 ); | ||
|
||
|
@@ -70,16 +71,34 @@ function InserterSearchResults( { | |
destinationRootClientId | ||
); | ||
|
||
const filteredBlockPatterns = useMemo( () => { | ||
if ( maxBlockPatterns === 0 ) { | ||
return []; | ||
} | ||
const results = searchItems( patterns, filterValue ); | ||
return maxBlockPatterns !== undefined | ||
? results.slice( 0, maxBlockPatterns ) | ||
: results; | ||
}, [ filterValue, patterns, maxBlockPatterns ] ); | ||
|
||
let maxBlockTypesToShow = maxBlockTypes; | ||
if ( prioritizePatterns && filteredBlockPatterns.length > 2 ) { | ||
maxBlockTypesToShow = 0; | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Nit: For both filteredPatterns and filteredBlocks, we could bail early if the max is 0 (for perf reasons but really not sure whether it has any impact) |
||
} | ||
|
||
const filteredBlockTypes = useMemo( () => { | ||
if ( maxBlockTypesToShow === 0 ) { | ||
return []; | ||
} | ||
const results = searchBlockItems( | ||
orderBy( blockTypes, [ 'frecency' ], [ 'desc' ] ), | ||
blockTypeCategories, | ||
blockTypeCollections, | ||
filterValue | ||
); | ||
|
||
return maxBlockTypes !== undefined | ||
? results.slice( 0, maxBlockTypes ) | ||
return maxBlockTypesToShow !== undefined | ||
? results.slice( 0, maxBlockTypesToShow ) | ||
: results; | ||
}, [ | ||
filterValue, | ||
|
@@ -89,13 +108,6 @@ function InserterSearchResults( { | |
maxBlockTypes, | ||
] ); | ||
|
||
const filteredBlockPatterns = useMemo( () => { | ||
const results = searchItems( patterns, filterValue ); | ||
return maxBlockPatterns !== undefined | ||
? results.slice( 0, maxBlockPatterns ) | ||
: results; | ||
}, [ filterValue, patterns, maxBlockPatterns ] ); | ||
|
||
// Announce search results on change | ||
useEffect( () => { | ||
if ( ! filterValue ) { | ||
|
@@ -122,49 +134,49 @@ function InserterSearchResults( { | |
const hasItems = | ||
! isEmpty( filteredBlockTypes ) || ! isEmpty( filteredBlockPatterns ); | ||
|
||
const blocksUI = !! filteredBlockTypes.length && ( | ||
<InserterPanel | ||
title={ <VisuallyHidden>{ __( 'Blocks' ) }</VisuallyHidden> } | ||
> | ||
<BlockTypesList | ||
items={ currentShownBlockTypes } | ||
onSelect={ onSelectBlockType } | ||
onHover={ onHover } | ||
label={ __( 'Blocks' ) } | ||
isDraggable={ isDraggable } | ||
/> | ||
</InserterPanel> | ||
); | ||
|
||
const patternsUI = !! filteredBlockPatterns.length && ( | ||
<InserterPanel | ||
title={ | ||
<VisuallyHidden>{ __( 'Block Patterns' ) }</VisuallyHidden> | ||
} | ||
> | ||
<div className="block-editor-inserter__quick-inserter-patterns"> | ||
<BlockPatternsList | ||
shownPatterns={ currentShownPatterns } | ||
blockPatterns={ filteredBlockPatterns } | ||
onClickPattern={ onSelectBlockPattern } | ||
isDraggable={ isDraggable } | ||
/> | ||
</div> | ||
</InserterPanel> | ||
); | ||
|
||
return ( | ||
<InserterListbox> | ||
{ ! showBlockDirectory && ! hasItems && <InserterNoResults /> } | ||
|
||
{ !! filteredBlockTypes.length && ( | ||
<InserterPanel | ||
title={ | ||
<VisuallyHidden>{ __( 'Blocks' ) }</VisuallyHidden> | ||
} | ||
> | ||
<BlockTypesList | ||
items={ currentShownBlockTypes } | ||
onSelect={ onSelectBlockType } | ||
onHover={ onHover } | ||
label={ __( 'Blocks' ) } | ||
isDraggable={ isDraggable } | ||
/> | ||
</InserterPanel> | ||
) } | ||
{ prioritizePatterns ? patternsUI : blocksUI } | ||
|
||
{ !! filteredBlockTypes.length && | ||
!! filteredBlockPatterns.length && ( | ||
<div className="block-editor-inserter__quick-inserter-separator" /> | ||
) } | ||
|
||
{ !! filteredBlockPatterns.length && ( | ||
<InserterPanel | ||
title={ | ||
<VisuallyHidden> | ||
{ __( 'Block Patterns' ) } | ||
</VisuallyHidden> | ||
} | ||
> | ||
<div className="block-editor-inserter__quick-inserter-patterns"> | ||
<BlockPatternsList | ||
shownPatterns={ currentShownPatterns } | ||
blockPatterns={ filteredBlockPatterns } | ||
onClickPattern={ onSelectBlockPattern } | ||
isDraggable={ isDraggable } | ||
/> | ||
</div> | ||
</InserterPanel> | ||
) } | ||
{ prioritizePatterns ? blocksUI : patternsUI } | ||
|
||
{ showBlockDirectory && ( | ||
<__unstableInserterMenuExtension.Slot | ||
|
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.
What about these positions? If I create a new empty template I should see patterns in the inserter, no? Same goes for the last index if it's top level.
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.
Hi @ntsekouras,
The conditions are following what @mtias specified on the issue:
I added a condition to also show the behavior when the template is empty.
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.
Yes, we'll need to do some extra work on empty templates regardless.