react-instantsearch
Version:
⚡ Lightning-fast search for React, by Algolia
26 lines • 1.88 kB
JavaScript
var _excluded = ["hit", "attribute", "highlightedTagName", "nonHighlightedTagName", "separator"];
function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); }
function _objectWithoutProperties(e, t) { if (null == e) return {}; var o, r, i = _objectWithoutPropertiesLoose(e, t); if (Object.getOwnPropertySymbols) { var n = Object.getOwnPropertySymbols(e); for (r = 0; r < n.length; r++) o = n[r], -1 === t.indexOf(o) && {}.propertyIsEnumerable.call(e, o) && (i[o] = e[o]); } return i; }
function _objectWithoutPropertiesLoose(r, e) { if (null == r) return {}; var t = {}; for (var n in r) if ({}.hasOwnProperty.call(r, n)) { if (-1 !== e.indexOf(n)) continue; t[n] = r[n]; } return t; }
import { getHighlightedParts, getPropertyByPath, unescape } from "instantsearch.js/es/lib/utils/index.js";
import React from 'react';
import { Snippet as SnippetUiComponent } from "../ui/Snippet.js";
export function Snippet(_ref) {
var hit = _ref.hit,
attribute = _ref.attribute,
highlightedTagName = _ref.highlightedTagName,
nonHighlightedTagName = _ref.nonHighlightedTagName,
separator = _ref.separator,
props = _objectWithoutProperties(_ref, _excluded);
var property = getPropertyByPath(hit._snippetResult, attribute) || [];
var properties = Array.isArray(property) ? property : [property];
var parts = properties.map(function (singleValue) {
return getHighlightedParts(unescape(singleValue.value || ''));
});
return /*#__PURE__*/React.createElement(SnippetUiComponent, _extends({}, props, {
parts: parts,
highlightedTagName: highlightedTagName,
nonHighlightedTagName: nonHighlightedTagName,
separator: separator
}));
}