UNPKG

@wordpress/block-editor

Version:
115 lines (96 loc) 4.44 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.default = LinkControlSearchResults; var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _i18n = require("@wordpress/i18n"); var _components = require("@wordpress/components"); var _classnames = _interopRequireDefault(require("classnames")); var _element = require("@wordpress/element"); var _searchCreateButton = _interopRequireDefault(require("./search-create-button")); var _searchItem = _interopRequireDefault(require("./search-item")); var _constants = require("./constants"); /** * WordPress dependencies */ /** * External dependencies */ /** * Internal dependencies */ function LinkControlSearchResults({ instanceId, withCreateSuggestion, currentInputValue, handleSuggestionClick, suggestionsListProps, buildSuggestionItemProps, suggestions, selectedSuggestion, isLoading, isInitialSuggestions, createSuggestionButtonText, suggestionsQuery }) { const resultsListClasses = (0, _classnames.default)('block-editor-link-control__search-results', { 'is-loading': isLoading }); const directLinkEntryTypes = ['url', 'mailto', 'tel', 'internal']; const isSingleDirectEntryResult = suggestions.length === 1 && directLinkEntryTypes.includes(suggestions[0].type.toLowerCase()); const shouldShowCreateSuggestion = withCreateSuggestion && !isSingleDirectEntryResult && !isInitialSuggestions; // If the query has a specified type, then we can skip showing them in the result. See #24839. const shouldShowSuggestionsTypes = !(suggestionsQuery !== null && suggestionsQuery !== void 0 && suggestionsQuery.type); // According to guidelines aria-label should be added if the label // itself is not visible. // See: https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Roles/listbox_role const searchResultsLabelId = `block-editor-link-control-search-results-label-${instanceId}`; const labelText = isInitialSuggestions ? (0, _i18n.__)('Recently updated') : (0, _i18n.sprintf)( /* translators: %s: search term. */ (0, _i18n.__)('Search results for "%s"'), currentInputValue); // VisuallyHidden rightly doesn't accept custom classNames // so we conditionally render it as a wrapper to visually hide the label // when that is required. const searchResultsLabel = (0, _element.createElement)(isInitialSuggestions ? _element.Fragment : _components.VisuallyHidden, {}, // empty props (0, _element.createElement)("span", { className: "block-editor-link-control__search-results-label", id: searchResultsLabelId }, labelText)); return (0, _element.createElement)("div", { className: "block-editor-link-control__search-results-wrapper" }, searchResultsLabel, (0, _element.createElement)("div", (0, _extends2.default)({}, suggestionsListProps, { className: resultsListClasses, "aria-labelledby": searchResultsLabelId }), suggestions.map((suggestion, index) => { if (shouldShowCreateSuggestion && _constants.CREATE_TYPE === suggestion.type) { return (0, _element.createElement)(_searchCreateButton.default, { searchTerm: currentInputValue, buttonText: createSuggestionButtonText, onClick: () => handleSuggestionClick(suggestion) // Intentionally only using `type` here as // the constant is enough to uniquely // identify the single "CREATE" suggestion. , key: suggestion.type, itemProps: buildSuggestionItemProps(suggestion, index), isSelected: index === selectedSuggestion }); } // If we're not handling "Create" suggestions above then // we don't want them in the main results so exit early if (_constants.CREATE_TYPE === suggestion.type) { return null; } return (0, _element.createElement)(_searchItem.default, { key: `${suggestion.id}-${suggestion.type}`, itemProps: buildSuggestionItemProps(suggestion, index), suggestion: suggestion, index: index, onClick: () => { handleSuggestionClick(suggestion); }, isSelected: index === selectedSuggestion, isURL: directLinkEntryTypes.includes(suggestion.type.toLowerCase()), searchTerm: currentInputValue, shouldShowType: shouldShowSuggestionsTypes }); }))); } //# sourceMappingURL=search-results.js.map