@elastic/react-search-ui
Version:
A React library for building search experiences
195 lines (164 loc) • 18.9 kB
JavaScript
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = exports.FacetContainer = void 0;
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _propTypes = _interopRequireDefault(require("prop-types"));
var _react = require("react");
var _reactSearchUiViews = require("@elastic/react-search-ui-views");
var _types = require("../types");
var _helpers = require("../helpers");
var _ = require("..");
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { keys.push.apply(keys, Object.getOwnPropertySymbols(object)); } if (enumerableOnly) keys = keys.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); return keys; }
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { (0, _defineProperty2.default)(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
function findFacetValueInFilters(name, filters, filterType) {
var filter = filters.find(function (f) {
return f.field === name && f.type === filterType;
});
if (!filter) return;
return filter.values;
}
var FacetContainer =
/*#__PURE__*/
function (_Component) {
(0, _inherits2.default)(FacetContainer, _Component);
function FacetContainer(_ref) {
var _this;
var _ref$show = _ref.show,
show = _ref$show === void 0 ? 5 : _ref$show;
(0, _classCallCheck2.default)(this, FacetContainer);
_this = (0, _possibleConstructorReturn2.default)(this, (0, _getPrototypeOf2.default)(FacetContainer).call(this));
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "handleClickMore", function (totalOptions) {
_this.setState(function (_ref2) {
var more = _ref2.more;
var visibleOptionsCount = more + 10;
var showingAll = visibleOptionsCount >= totalOptions;
if (showingAll) visibleOptionsCount = totalOptions;
_this.props.a11yNotify("moreFilters", {
visibleOptionsCount: visibleOptionsCount,
showingAll: showingAll
});
return {
more: visibleOptionsCount
};
});
});
(0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "handleFacetSearch", function (searchTerm) {
_this.setState({
searchTerm: searchTerm
});
});
_this.state = {
more: show,
searchTerm: ""
};
return _this;
}
(0, _createClass2.default)(FacetContainer, [{
key: "render",
value: function render() {
var _this2 = this;
var _this$state = this.state,
more = _this$state.more,
searchTerm = _this$state.searchTerm;
var _this$props = this.props,
addFilter = _this$props.addFilter,
className = _this$props.className,
facets = _this$props.facets,
field = _this$props.field,
filterType = _this$props.filterType,
filters = _this$props.filters,
label = _this$props.label,
removeFilter = _this$props.removeFilter,
setFilter = _this$props.setFilter,
view = _this$props.view,
isFilterable = _this$props.isFilterable,
a11yNotify = _this$props.a11yNotify,
rest = (0, _objectWithoutProperties2.default)(_this$props, ["addFilter", "className", "facets", "field", "filterType", "filters", "label", "removeFilter", "setFilter", "view", "isFilterable", "a11yNotify"]);
var facetValues = facets[field];
if (!facetValues) return null;
var options = facetValues[0].data;
var selectedValues = findFacetValueInFilters(field, filters, filterType) || [];
if (!options.length && !selectedValues.length) return null;
if (searchTerm.trim()) {
options = options.filter(function (option) {
return (0, _helpers.accentFold)(option.value).toLowerCase().includes((0, _helpers.accentFold)(searchTerm).toLowerCase());
});
}
var View = view || _reactSearchUiViews.MultiCheckboxFacet;
return View(_objectSpread({
className: className,
label: label,
onMoreClick: this.handleClickMore.bind(this, options.length),
onRemove: function onRemove(value) {
removeFilter(field, value, filterType);
},
onChange: function onChange(value) {
setFilter(field, value, filterType);
},
onSelect: function onSelect(value) {
addFilter(field, value, filterType);
},
options: options.slice(0, more),
showMore: options.length > more,
values: selectedValues,
showSearch: isFilterable,
onSearch: function onSearch(value) {
_this2.handleFacetSearch(value);
},
searchPlaceholder: "Filter ".concat(field)
}, rest));
}
}]);
return FacetContainer;
}(_react.Component);
exports.FacetContainer = FacetContainer;
(0, _defineProperty2.default)(FacetContainer, "propTypes", {
// Props
className: _propTypes.default.string,
field: _propTypes.default.string.isRequired,
label: _propTypes.default.string.isRequired,
filterType: _types.FilterType,
show: _propTypes.default.number,
view: _propTypes.default.func,
isFilterable: _propTypes.default.bool,
// State
filters: _propTypes.default.arrayOf(_types.Filter).isRequired,
facets: _propTypes.default.objectOf(_propTypes.default.arrayOf(_types.Facet)).isRequired,
// Actions
addFilter: _propTypes.default.func.isRequired,
removeFilter: _propTypes.default.func.isRequired,
setFilter: _propTypes.default.func.isRequired,
a11yNotify: _propTypes.default.func.isRequired
});
(0, _defineProperty2.default)(FacetContainer, "defaultProps", {
filterType: "all",
isFilterable: false
});
var _default = (0, _.withSearch)(function (_ref3) {
var filters = _ref3.filters,
facets = _ref3.facets,
addFilter = _ref3.addFilter,
removeFilter = _ref3.removeFilter,
setFilter = _ref3.setFilter,
a11yNotify = _ref3.a11yNotify;
return {
filters: filters,
facets: facets,
addFilter: addFilter,
removeFilter: removeFilter,
setFilter: setFilter,
a11yNotify: a11yNotify
};
})(FacetContainer);
exports.default = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/containers/Facet.js"],"names":["findFacetValueInFilters","name","filters","filterType","filter","find","f","field","type","values","FacetContainer","show","totalOptions","setState","more","visibleOptionsCount","showingAll","props","a11yNotify","searchTerm","state","addFilter","className","facets","label","removeFilter","setFilter","view","isFilterable","rest","facetValues","options","data","selectedValues","length","trim","option","value","toLowerCase","includes","View","MultiCheckboxFacet","onMoreClick","handleClickMore","bind","onRemove","onChange","onSelect","slice","showMore","showSearch","onSearch","handleFacetSearch","searchPlaceholder","Component","PropTypes","string","isRequired","FilterType","number","func","bool","arrayOf","Filter","objectOf","Facet"],"mappings":"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","sourcesContent":["import PropTypes from \"prop-types\";\nimport { Component } from \"react\";\nimport { MultiCheckboxFacet } from \"@elastic/react-search-ui-views\";\n\nimport { Facet, Filter, FilterType } from \"../types\";\nimport { accentFold } from \"../helpers\";\n\nimport { withSearch } from \"..\";\n\nfunction findFacetValueInFilters(name, filters, filterType) {\n  const filter = filters.find(f => f.field === name && f.type === filterType);\n  if (!filter) return;\n  return filter.values;\n}\n\nexport class FacetContainer extends Component {\n  static propTypes = {\n    // Props\n    className: PropTypes.string,\n    field: PropTypes.string.isRequired,\n    label: PropTypes.string.isRequired,\n    filterType: FilterType,\n    show: PropTypes.number,\n    view: PropTypes.func,\n    isFilterable: PropTypes.bool,\n    // State\n    filters: PropTypes.arrayOf(Filter).isRequired,\n    facets: PropTypes.objectOf(PropTypes.arrayOf(Facet)).isRequired,\n    // Actions\n    addFilter: PropTypes.func.isRequired,\n    removeFilter: PropTypes.func.isRequired,\n    setFilter: PropTypes.func.isRequired,\n    a11yNotify: PropTypes.func.isRequired\n  };\n\n  static defaultProps = {\n    filterType: \"all\",\n    isFilterable: false\n  };\n\n  constructor({ show = 5 }) {\n    super();\n    this.state = {\n      more: show,\n      searchTerm: \"\"\n    };\n  }\n\n  handleClickMore = totalOptions => {\n    this.setState(({ more }) => {\n      let visibleOptionsCount = more + 10;\n      const showingAll = visibleOptionsCount >= totalOptions;\n      if (showingAll) visibleOptionsCount = totalOptions;\n\n      this.props.a11yNotify(\"moreFilters\", { visibleOptionsCount, showingAll });\n\n      return { more: visibleOptionsCount };\n    });\n  };\n\n  handleFacetSearch = searchTerm => {\n    this.setState({ searchTerm });\n  };\n\n  render() {\n    const { more, searchTerm } = this.state;\n    const {\n      addFilter,\n      className,\n      facets,\n      field,\n      filterType,\n      filters,\n      label,\n      removeFilter,\n      setFilter,\n      view,\n      isFilterable,\n      // eslint-disable-next-line no-unused-vars\n      a11yNotify,\n      ...rest\n    } = this.props;\n    const facetValues = facets[field];\n\n    if (!facetValues) return null;\n\n    let options = facetValues[0].data;\n    const selectedValues =\n      findFacetValueInFilters(field, filters, filterType) || [];\n\n    if (!options.length && !selectedValues.length) return null;\n\n    if (searchTerm.trim()) {\n      options = options.filter(option =>\n        accentFold(option.value)\n          .toLowerCase()\n          .includes(accentFold(searchTerm).toLowerCase())\n      );\n    }\n\n    const View = view || MultiCheckboxFacet;\n\n    return View({\n      className,\n      label: label,\n      onMoreClick: this.handleClickMore.bind(this, options.length),\n      onRemove: value => {\n        removeFilter(field, value, filterType);\n      },\n      onChange: value => {\n        setFilter(field, value, filterType);\n      },\n      onSelect: value => {\n        addFilter(field, value, filterType);\n      },\n      options: options.slice(0, more),\n      showMore: options.length > more,\n      values: selectedValues,\n      showSearch: isFilterable,\n      onSearch: value => {\n        this.handleFacetSearch(value);\n      },\n      searchPlaceholder: `Filter ${field}`,\n      ...rest\n    });\n  }\n}\n\nexport default withSearch(\n  ({ filters, facets, addFilter, removeFilter, setFilter, a11yNotify }) => ({\n    filters,\n    facets,\n    addFilter,\n    removeFilter,\n    setFilter,\n    a11yNotify\n  })\n)(FacetContainer);\n"]}
;