UNPKG

react-elegant-ui

Version:

Elegant UI components, made by BEM best practices for react

70 lines (69 loc) 3.58 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.withInlineSearch = void 0; var _react = _interopRequireWildcard(require("react")); var _compose = require("../../../lib/compose"); var _useInlineKeyboardSearch = require("../../../hooks/behavior/useInlineKeyboardSearch"); var _Menu = require("../Menu"); function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); } function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && Object.prototype.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; } var __assign = void 0 && (void 0).__assign || function () { __assign = Object.assign || function (t) { for (var s, i = 1, n = arguments.length; i < n; i++) { s = arguments[i]; for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p]; } return t; }; return __assign.apply(this, arguments); }; var __rest = void 0 && (void 0).__rest || function (s, e) { var t = {}; for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0) t[p] = s[p]; if (s != null && typeof Object.getOwnPropertySymbols === "function") for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) { if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i])) t[p[i]] = s[p[i]]; } return t; }; var defaultPredicate = function (searchText, item) { // Skip disabled and hidden items if (!(0, _Menu.isAvailableItem)(item)) return false; var itemText = (0, _Menu.getTextOfItem)(item); // Skip items which not contain text if (itemText === undefined) return false; var substr = itemText.slice(0, searchText.length); return substr.toLowerCase() === searchText.toLowerCase(); }; /** * HOC to search items by input while focus. * * It search by item text, that may be `content` or `textContent` */ var withInlineSearch = exports.withInlineSearch = (0, _compose.withHOCConstructor)({}, function (Menu) { return function (_a) { var inlineSearch = _a.inlineSearch, inlineSearchPredicate = _a.inlineSearchPredicate, props = __rest(_a, ["inlineSearch", "inlineSearchPredicate"]); var items = props.items, cursorIndex = props.cursorIndex, setCursorIndex = props.setCursorIndex, isFocused = props.isFocused, disabled = props.disabled; var flattenItems = (0, _react.useMemo)(function () { return (0, _Menu.flattenItemsWithoutEmptyGroups)(items); }, [items]); var enableInlineSearch = !disabled && !!inlineSearch && !!isFocused; var searchPredicate = inlineSearchPredicate || defaultPredicate; (0, _useInlineKeyboardSearch.useInlineKeyboardSearch)({ enabled: enableInlineSearch, items: flattenItems, cursor: cursorIndex !== null && cursorIndex !== void 0 ? cursorIndex : -1, setCursor: setCursorIndex, predicate: searchPredicate, loop: true }); return /*#__PURE__*/_react.default.createElement(Menu, __assign({}, props)); }; });