UNPKG

@wordpress/block-editor

Version:
108 lines (96 loc) 3.52 kB
import { createElement, Fragment } from "@wordpress/element"; /** * WordPress dependencies */ import { useSelect } from '@wordpress/data'; import { createBlock, createBlocksFromInnerBlocksTemplate } from '@wordpress/blocks'; import { useMemo } from '@wordpress/element'; /** * Internal dependencies */ import { searchBlockItems } from '../components/inserter/search-items'; import useBlockTypesState from '../components/inserter/hooks/use-block-types-state'; import BlockIcon from '../components/block-icon'; import { store as blockEditorStore } from '../store'; import { orderBy } from '../utils/sorting'; import { orderInserterBlockItems } from '../utils/order-inserter-block-items'; const noop = () => {}; const SHOWN_BLOCK_TYPES = 9; /** @typedef {import('@wordpress/components').WPCompleter} WPCompleter */ /** * Creates a blocks repeater for replacing the current block with a selected block type. * * @return {WPCompleter} A blocks completer. */ function createBlockCompleter() { return { name: 'blocks', className: 'block-editor-autocompleters__block', triggerPrefix: '/', useItems(filterValue) { const { rootClientId, selectedBlockName, prioritizedBlocks } = useSelect(select => { const { getSelectedBlockClientId, getBlockName, getBlockInsertionPoint, getBlockListSettings } = select(blockEditorStore); const selectedBlockClientId = getSelectedBlockClientId(); const _rootClientId = getBlockInsertionPoint().rootClientId; return { selectedBlockName: selectedBlockClientId ? getBlockName(selectedBlockClientId) : null, rootClientId: _rootClientId, prioritizedBlocks: getBlockListSettings(_rootClientId)?.prioritizedInserterBlocks }; }, []); const [items, categories, collections] = useBlockTypesState(rootClientId, noop); const filteredItems = useMemo(() => { const initialFilteredItems = !!filterValue.trim() ? searchBlockItems(items, categories, collections, filterValue) : orderInserterBlockItems(orderBy(items, 'frecency', 'desc'), prioritizedBlocks); return initialFilteredItems.filter(item => item.name !== selectedBlockName).slice(0, SHOWN_BLOCK_TYPES); }, [filterValue, selectedBlockName, items, categories, collections, prioritizedBlocks]); const options = useMemo(() => filteredItems.map(blockItem => { const { title, icon, isDisabled } = blockItem; return { key: `block-${blockItem.id}`, value: blockItem, label: createElement(Fragment, null, createElement(BlockIcon, { key: "icon", icon: icon, showColors: true }), title), isDisabled }; }), [filteredItems]); return [options]; }, allowContext(before, after) { return !(/\S/.test(before) || /\S/.test(after)); }, getOptionCompletion(inserterItem) { const { name, initialAttributes, innerBlocks } = inserterItem; return { action: 'replace', value: createBlock(name, initialAttributes, createBlocksFromInnerBlocksTemplate(innerBlocks)) }; } }; } /** * Creates a blocks repeater for replacing the current block with a selected block type. * * @return {WPCompleter} A blocks completer. */ export default createBlockCompleter(); //# sourceMappingURL=block.js.map