UNPKG

@wordpress/block-editor

Version:
60 lines (47 loc) 1.55 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _element = require("@wordpress/element"); var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _components = require("@wordpress/components"); var _context = _interopRequireDefault(require("./context")); /** * WordPress dependencies */ /** * Internal dependencies */ function InserterListboxItem({ isFirst, as: Component, children, ...props }, ref) { const state = (0, _element.useContext)(_context.default); return (0, _element.createElement)(_components.__unstableCompositeItem, (0, _extends2.default)({ ref: ref, state: state, role: "option" // Use the CompositeItem `focusable` prop over Button's // isFocusable. The latter was shown to cause an issue // with tab order in the inserter list. , focusable: true }, props), htmlProps => { const propsWithTabIndex = { ...htmlProps, tabIndex: isFirst ? 0 : htmlProps.tabIndex }; if (Component) { return (0, _element.createElement)(Component, propsWithTabIndex, children); } if (typeof children === 'function') { return children(propsWithTabIndex); } return (0, _element.createElement)(_components.Button, propsWithTabIndex, children); }); } var _default = (0, _element.forwardRef)(InserterListboxItem); exports.default = _default; //# sourceMappingURL=item.js.map