UNPKG

@wordpress/block-editor

Version:
107 lines (95 loc) 3.43 kB
import { createElement } from "@wordpress/element"; /** * External dependencies */ import { last } from 'lodash'; import classnames from 'classnames'; /** * WordPress dependencies */ import { createContext } from '@wordpress/element'; import { withSelect } from '@wordpress/data'; import { getDefaultBlockName } from '@wordpress/blocks'; /** * Internal dependencies */ import DefaultBlockAppender from '../default-block-appender'; import ButtonBlockAppender from '../button-block-appender'; import { store as blockEditorStore } from '../../store'; // A Context to store the map of the appender map. export const AppenderNodesContext = createContext(); function stopPropagation(event) { event.stopPropagation(); } function BlockListAppender({ blockClientIds, rootClientId, canInsertDefaultBlock, isLocked, renderAppender: CustomAppender, className, selectedBlockClientId, tagName: TagName = 'div' }) { if (isLocked || CustomAppender === false) { return null; } let appender; if (CustomAppender) { // Prefer custom render prop if provided. appender = createElement(CustomAppender, null); } else { const isDocumentAppender = !rootClientId; const isParentSelected = selectedBlockClientId === rootClientId; const isAnotherDefaultAppenderAlreadyDisplayed = selectedBlockClientId && !blockClientIds.includes(selectedBlockClientId); if (!isDocumentAppender && !isParentSelected && (!selectedBlockClientId || isAnotherDefaultAppenderAlreadyDisplayed)) { return null; } if (canInsertDefaultBlock) { // Render the default block appender when renderAppender has not been // provided and the context supports use of the default appender. appender = createElement(DefaultBlockAppender, { rootClientId: rootClientId, lastBlockClientId: last(blockClientIds) }); } else { // Fallback in the case no renderAppender has been provided and the // default block can't be inserted. appender = createElement(ButtonBlockAppender, { rootClientId: rootClientId, className: "block-list-appender__toggle" }); } } return createElement(TagName // A `tabIndex` is used on the wrapping `div` element in order to // force a focus event to occur when an appender `button` element // is clicked. In some browsers (Firefox, Safari), button clicks do // not emit a focus event, which could cause this event to propagate // unexpectedly. The `tabIndex` ensures that the interaction is // captured as a focus, without also adding an extra tab stop. // // See: https://developer.mozilla.org/en-US/docs/Web/HTML/Element/button#Clicking_and_focus , { tabIndex: -1 // Prevent the block from being selected when the appender is // clicked. , onFocus: stopPropagation, className: classnames('block-list-appender', 'wp-block', className) }, appender); } export default withSelect((select, { rootClientId }) => { const { getBlockOrder, canInsertBlockType, getTemplateLock, getSelectedBlockClientId } = select(blockEditorStore); return { isLocked: !!getTemplateLock(rootClientId), blockClientIds: getBlockOrder(rootClientId), canInsertDefaultBlock: canInsertBlockType(getDefaultBlockName(), rootClientId), selectedBlockClientId: getSelectedBlockClientId() }; })(BlockListAppender); //# sourceMappingURL=index.js.map