UNPKG

@collectionspace/cspace-public-browser

Version:
115 lines (113 loc) 4.37 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _react = _interopRequireWildcard(require("react")); var _propTypes = _interopRequireDefault(require("prop-types")); var _reactIntl = require("react-intl"); var _immutable = _interopRequireDefault(require("immutable")); var _FilterList = _interopRequireDefault(require("./FilterList")); var _config = _interopRequireDefault(require("../../../config")); var _FilterPanel = _interopRequireDefault(require("../../../../styles/cspace/FilterPanel.css")); var _dimensions = _interopRequireDefault(require("../../../../styles/dimensions.css")); function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; } 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 && {}.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; } /* global window */ const propTypes = { api: _propTypes.default.func, isExpanded: _propTypes.default.bool, isPending: _propTypes.default.bool, result: _propTypes.default.instanceOf(_immutable.default.Map) }; const defaultProps = { api: () => undefined, isExpanded: false, isPending: false, result: _immutable.default.Map() }; const messages = (0, _reactIntl.defineMessages)({ title: { "id": "FilterPanel.title", "defaultMessage": "Refine results:" } }); const { filterPanelCutoffWidth: cssFilterPanelCutoffWidth } = _dimensions.default; const filterPanelCutoffWidth = parseInt(cssFilterPanelCutoffWidth, 10); class FilterPanel extends _react.Component { constructor() { super(); this.handleResize = this.handleResize.bind(this); this.handleScroll = this.handleScroll.bind(this); this.ref = /*#__PURE__*/_react.default.createRef(); this.state = {}; } componentDidMount() { const { api } = this.props; window.addEventListener('resize', this.handleResize); window.addEventListener('scroll', this.handleScroll); api({ setHeight: this.setHeight.bind(this) }); this.setHeight(); } componentWillUnmount() { window.removeEventListener('resize', this.handleResize); window.removeEventListener('scroll', this.handleScroll); } handleResize() { this.setHeight(); } handleScroll() { this.setHeight(); } setHeight() { const height = window.innerHeight; const rect = this.ref.current.getBoundingClientRect(); const maxHeight = height - rect.top; this.setState({ height: maxHeight }); } renderContent() { const { isExpanded, isPending, result } = this.props; const isVisible = window.innerWidth > filterPanelCutoffWidth || isExpanded; if (!isVisible || !result.get('total')) { return undefined; } return /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement("header", null, /*#__PURE__*/_react.default.createElement(_reactIntl.FormattedMessage, messages.title)), /*#__PURE__*/_react.default.createElement(_FilterList.default, { aggregations: result.get('aggregations'), config: _config.default.get('filters'), isPending: isPending })); } render() { const { isExpanded } = this.props; const { height } = this.state; const className = isExpanded ? _FilterPanel.default.expanded : _FilterPanel.default.collapsed; const inlineStyle = height ? { height } : undefined; return /*#__PURE__*/_react.default.createElement("div", { className: className, ref: this.ref, style: inlineStyle }, this.renderContent()); } } exports.default = FilterPanel; FilterPanel.propTypes = propTypes; FilterPanel.defaultProps = defaultProps;