UNPKG

@wordpress/components

Version:
93 lines (83 loc) 2.89 kB
import { createElement } from "@wordpress/element"; /** * WordPress dependencies */ import { useEffect, useRef } from '@wordpress/element'; import { __, _n, sprintf } from '@wordpress/i18n'; /** * Internal dependencies */ import withSpokenMessages from '../../higher-order/with-spoken-messages'; import { useNavigationMenuContext } from './context'; import { useNavigationContext } from '../context'; import { MenuTitleSearchUI } from '../styles/navigation-styles'; import { SEARCH_FOCUS_DELAY } from '../constants'; function MenuTitleSearch(_ref) { let { debouncedSpeak, onCloseSearch, onSearch, search, title } = _ref; const { navigationTree: { items } } = useNavigationContext(); const { menu } = useNavigationMenuContext(); const inputRef = useRef(null); // Wait for the slide-in animation to complete before autofocusing the input. // This prevents scrolling to the input during the animation. useEffect(() => { const delayedFocus = setTimeout(() => { var _inputRef$current; (_inputRef$current = inputRef.current) === null || _inputRef$current === void 0 ? void 0 : _inputRef$current.focus(); }, SEARCH_FOCUS_DELAY); return () => { clearTimeout(delayedFocus); }; }, []); useEffect(() => { if (!search) { return; } const count = Object.values(items).filter(item => item._isVisible).length; const resultsFoundMessage = sprintf( /* translators: %d: number of results. */ _n('%d result found.', '%d results found.', count), count); debouncedSpeak(resultsFoundMessage); // Ignore exhaustive-deps rule for now. See https://github.com/WordPress/gutenberg/pull/44090 // eslint-disable-next-line react-hooks/exhaustive-deps }, [items, search]); const onClose = () => { onSearch === null || onSearch === void 0 ? void 0 : onSearch(''); onCloseSearch(); }; const onKeyDown = event => { if (event.code === 'Escape' && !event.defaultPrevented) { event.preventDefault(); onClose(); } }; const inputId = `components-navigation__menu-title-search-${menu}`; const placeholder = sprintf( /* translators: placeholder for menu search box. %s: menu title */ __('Search %s'), title === null || title === void 0 ? void 0 : title.toLowerCase()).trim(); return createElement("div", { className: "components-navigation__menu-title-search" }, createElement(MenuTitleSearchUI, { autoComplete: "off", className: "components-navigation__menu-search-input", id: inputId, onChange: value => onSearch === null || onSearch === void 0 ? void 0 : onSearch(value), onKeyDown: onKeyDown, placeholder: placeholder, onClose: onClose, ref: inputRef, type: "search", value: search })); } export default withSpokenMessages(MenuTitleSearch); //# sourceMappingURL=menu-title-search.js.map