UNPKG

@wordpress/block-editor

Version:
90 lines (74 loc) 2.58 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 _i18n = require("@wordpress/i18n"); var _data = require("@wordpress/data"); var _keyboardShortcuts = require("@wordpress/keyboard-shortcuts"); var _icons = require("@wordpress/icons"); var _ = _interopRequireDefault(require("./")); var _store = require("../../store"); /** * WordPress dependencies */ /** * Internal dependencies */ function BlockNavigationDropdownToggle({ isEnabled, onToggle, isOpen, innerRef, ...props }) { (0, _keyboardShortcuts.useShortcut)('core/edit-post/toggle-block-navigation', (0, _element.useCallback)(onToggle, [onToggle]), { bindGlobal: true, isDisabled: !isEnabled }); const shortcut = (0, _data.useSelect)(select => select(_keyboardShortcuts.store).getShortcutRepresentation('core/edit-post/toggle-block-navigation'), []); return (0, _element.createElement)(_components.Button, (0, _extends2.default)({}, props, { ref: innerRef, icon: _icons.listView, "aria-expanded": isOpen, "aria-haspopup": "true", onClick: isEnabled ? onToggle : undefined /* translators: button label text should, if possible, be under 16 characters. */ , label: (0, _i18n.__)('List view'), className: "block-editor-block-navigation", shortcut: shortcut, "aria-disabled": !isEnabled })); } function BlockNavigationDropdown({ isDisabled, __experimentalFeatures, ...props }, ref) { const hasBlocks = (0, _data.useSelect)(select => !!select(_store.store).getBlockCount(), []); const isEnabled = hasBlocks && !isDisabled; return (0, _element.createElement)(_components.Dropdown, { contentClassName: "block-editor-block-navigation__popover", position: "bottom right", renderToggle: ({ isOpen, onToggle }) => (0, _element.createElement)(BlockNavigationDropdownToggle, (0, _extends2.default)({}, props, { innerRef: ref, isOpen: isOpen, onToggle: onToggle, isEnabled: isEnabled })), renderContent: () => (0, _element.createElement)(_.default, { __experimentalFeatures: __experimentalFeatures }) }); } var _default = (0, _element.forwardRef)(BlockNavigationDropdown); exports.default = _default; //# sourceMappingURL=dropdown.js.map