UNPKG

react-instantsearch

Version:
72 lines (71 loc) 4.62 kB
"use strict"; function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); } Object.defineProperty(exports, "__esModule", { value: true }); exports.Hits = Hits; var _instantsearchUiComponents = require("instantsearch-ui-components"); var _react = _interopRequireWildcard(require("react")); var _reactInstantsearchCore = require("react-instantsearch-core"); var _excluded = ["escapeHTML", "transformItems", "hitComponent", "bannerComponent"], _excluded2 = ["hit", "index"]; function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(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; } function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); } function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; } function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; } // @MAJOR: Move default hit component back to the UI library // once flavour specificities are erased function DefaultHitComponent(_ref) { var hit = _ref.hit; return /*#__PURE__*/_react.default.createElement("div", { style: { wordBreak: 'break-all' } }, JSON.stringify(hit).slice(0, 100), "\u2026"); } var HitsUiComponent = (0, _instantsearchUiComponents.createHitsComponent)({ createElement: _react.createElement, Fragment: _react.Fragment }); function Hits(_ref2) { var escapeHTML = _ref2.escapeHTML, transformItems = _ref2.transformItems, _ref2$hitComponent = _ref2.hitComponent, HitComponent = _ref2$hitComponent === void 0 ? DefaultHitComponent : _ref2$hitComponent, BannerComponent = _ref2.bannerComponent, props = _objectWithoutProperties(_ref2, _excluded); var _useHits = (0, _reactInstantsearchCore.useHits)({ escapeHTML: escapeHTML, transformItems: transformItems }, { $$widgetType: 'ais.hits' }), hits = _useHits.hits, banner = _useHits.banner, sendEvent = _useHits.sendEvent; var itemComponent = (0, _react.useMemo)(function () { return function (_ref3) { var hit = _ref3.hit, index = _ref3.index, itemProps = _objectWithoutProperties(_ref3, _excluded2); return /*#__PURE__*/_react.default.createElement("li", _extends({ key: hit.objectID }, itemProps), /*#__PURE__*/_react.default.createElement(HitComponent, { hit: hit, sendEvent: sendEvent })); }; }, [HitComponent, sendEvent]); var bannerComponent = BannerComponent === false ? function () { return null; } : BannerComponent; var uiProps = { hits: hits, sendEvent: sendEvent, itemComponent: itemComponent, banner: banner, bannerComponent: bannerComponent }; return /*#__PURE__*/_react.default.createElement(HitsUiComponent, _extends({}, props, uiProps)); }