UNPKG

kepler.gl

Version:

kepler.gl is a webgl based application to visualize large scale location data in the browser

258 lines (253 loc) 40.4 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); var _typeof = require("@babel/runtime/helpers/typeof"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = exports.classList = exports.ListItem = void 0; var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray")); 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 _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits")); var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireWildcard(require("react")); var _classnames = _interopRequireDefault(require("classnames")); var _styledComponents = _interopRequireDefault(require("styled-components")); var _constants = require("@kepler.gl/constants"); var _templateObject, _templateObject2; // SPDX-License-Identifier: MIT // Copyright contributors to the kepler.gl project 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 && {}.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 _callSuper(t, o, e) { return o = (0, _getPrototypeOf2["default"])(o), (0, _possibleConstructorReturn2["default"])(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], (0, _getPrototypeOf2["default"])(t).constructor) : o.apply(t, e)); } function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); } var LEFT_BUTTON = 0; var classList = exports.classList = { list: 'list-selector', listHeader: 'list__header', listSection: 'list__section', listItem: 'list__item', listItemAnchor: 'list__item__anchor', listItemFixed: 'list__item__fixed' }; var defaultDisplay = function defaultDisplay(d) { return d; }; var ListItem = exports.ListItem = function ListItem(_ref) { var value = _ref.value, _ref$displayOption = _ref.displayOption, displayOption = _ref$displayOption === void 0 ? defaultDisplay : _ref$displayOption, disabled = _ref.disabled; var displayValue = displayOption(value); return /*#__PURE__*/_react["default"].createElement("span", { title: displayValue, className: (0, _classnames["default"])(classList.listItemAnchor, { disabled: disabled }) }, displayValue); }; var DropdownListWrapper = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n background-color: ", ";\n border-top: 1px solid\n ", ";\n ", ";\n"])), function (props) { return props.light ? props.theme.dropdownListBgdLT : props.theme.dropdownListBgd; }, function (props) { return props.light ? props.theme.dropdownListBorderTopLT : props.theme.dropdownListBorderTop; }, function (props) { return props.light ? props.theme.dropdownListLT : props.theme.dropdownList; }); var DropdownFooterWrapper = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n height: '0px';\n"]))); // TODO: make Option a generic type var DropdownList = exports["default"] = /*#__PURE__*/function (_Component) { function DropdownList(props) { var _this; (0, _classCallCheck2["default"])(this, DropdownList); _this = _callSuper(this, DropdownList, [props]); (0, _defineProperty2["default"])(_this, "initNumberOfOptions", void 0); (0, _defineProperty2["default"])(_this, "page", void 0); (0, _defineProperty2["default"])(_this, "prevY", void 0); (0, _defineProperty2["default"])(_this, "loadingRef", void 0); (0, _defineProperty2["default"])(_this, "observer", void 0); (0, _defineProperty2["default"])(_this, "handleObserver", function (entities) { var y = entities[0].boundingClientRect.y; if (_this.prevY > y) { var options = _this._getOptions(_this.page); if (options) _this.setState({ options: options }); } _this.prevY = y; }); _this.state = { options: [] }; _this.initNumberOfOptions = _constants.INIT_FILTER_ITEMS_IN_DROPDOWN; _this.page = 0; _this.prevY = 0; _this.loadingRef = /*#__PURE__*/_react["default"].createRef(); return _this; } (0, _inherits2["default"])(DropdownList, _Component); return (0, _createClass2["default"])(DropdownList, [{ key: "componentDidMount", value: function componentDidMount() { var options = this._getOptions(this.page); this.setState({ options: options }); var divOptions = { root: null, rootMargin: '0%', threshold: 1.0 }; if (this.loadingRef.current) { this.observer = new IntersectionObserver(this.handleObserver, divOptions); this.observer.observe(this.loadingRef.current); } } }, { key: "getSnapshotBeforeUpdate", value: function getSnapshotBeforeUpdate(prevProps) { if (prevProps.options !== this.props.options) { // check if user searching, reset state.options at the first time var options = this._getOptions(0); this.setState({ options: options }); } return null; } // prevent console warning: getSnapshotBeforeUpdate() should be used with componentDidUpdate(). }, { key: "componentDidUpdate", value: function componentDidUpdate() { return; } }, { key: "componentWillUnmount", value: function componentWillUnmount() { if (this.loadingRef.current) { var _this$observer, _this$loadingRef; (_this$observer = this.observer) === null || _this$observer === void 0 || _this$observer.unobserve((_this$loadingRef = this.loadingRef) === null || _this$loadingRef === void 0 ? void 0 : _this$loadingRef.current); this.page = 0; this.prevY = 0; } } }, { key: "_getOptions", value: function _getOptions(page) { if (!this.props.options) { return []; } var n = this.props.options.length; if (n === 0) { return []; } var start = page * this.initNumberOfOptions; var end = start + this.initNumberOfOptions > n ? n : start + this.initNumberOfOptions; if (start < end && end <= n) { this.page = page + 1; // in case of user searching, props.options will be updated // so "page" value will be set to 0 and previous state.options will be discarded return [].concat((0, _toConsumableArray2["default"])(page > 0 ? this.state.options || [] : []), (0, _toConsumableArray2["default"])(this.props.options.slice(start, end))); } return null; } }, { key: "_onClick", value: function _onClick(result, event) { event.preventDefault(); // only work when left is clicked if (event.type === 'mousedown' && event.button === LEFT_BUTTON || event.type === 'click') { var _this$props$onOptionS, _this$props; (_this$props$onOptionS = (_this$props = this.props).onOptionSelected) === null || _this$props$onOptionS === void 0 || _this$props$onOptionS.call(_this$props, result, event); } } }, { key: "render", value: function render() { var _this$props$options, _this$props$customCla, _this$props$customCla2, _this2 = this, _this$state$options; var _this$props2 = this.props, fixedOptions = _this$props2.fixedOptions, light = _this$props2.light, _this$props2$allowCus = _this$props2.allowCustomValues, allowCustomValues = _this$props2$allowCus === void 0 ? 0 : _this$props2$allowCus, _this$props2$customLi = _this$props2.customListItemComponent, CustomListItemComponent = _this$props2$customLi === void 0 ? ListItem : _this$props2$customLi; var _this$props$displayOp = this.props.displayOption, display = _this$props$displayOp === void 0 ? defaultDisplay : _this$props$displayOp; // Don't render if there are no options to display if (!((_this$props$options = this.props.options) !== null && _this$props$options !== void 0 && _this$props$options.length) && allowCustomValues <= 0) { return /*#__PURE__*/_react["default"].createElement("div", null); } var valueOffset = Array.isArray(fixedOptions) ? fixedOptions.length : 0; // For some reason onClick is not fired when clicked on an option // onMouseDown is used here as a workaround of #205 and other return /*#__PURE__*/_react["default"].createElement(DropdownListWrapper, { className: (0, _classnames["default"])(classList.list, (_this$props$customCla = this.props.customClasses) === null || _this$props$customCla === void 0 ? void 0 : _this$props$customCla.results), light: light }, this.props.customListHeaderComponent ? /*#__PURE__*/_react["default"].createElement("div", { className: (0, _classnames["default"])(classList.listHeader, (_this$props$customCla2 = this.props.customClasses) === null || _this$props$customCla2 === void 0 ? void 0 : _this$props$customCla2.listHeader) }, /*#__PURE__*/_react["default"].createElement(this.props.customListHeaderComponent, null)) : null, valueOffset > 0 ? /*#__PURE__*/_react["default"].createElement("div", { className: classList.listSection }, fixedOptions === null || fixedOptions === void 0 ? void 0 : fixedOptions.map(function (value, i) { var _this2$props$customCl; return /*#__PURE__*/_react["default"].createElement("div", { className: (0, _classnames["default"])(classList.listItem, (0, _defineProperty2["default"])({ hover: _this2.props.selectionIndex === i }, classList.listItemFixed, true), (_this2$props$customCl = _this2.props.customClasses) === null || _this2$props$customCl === void 0 ? void 0 : _this2$props$customCl.listItem), key: "".concat(display(value), "_").concat(i), onMouseDown: function onMouseDown(e) { return _this2._onClick(value, e); }, onClick: function onClick(e) { return _this2._onClick(value, e); } }, /*#__PURE__*/_react["default"].createElement(CustomListItemComponent, { value: value, displayOption: display, light: light })); })) : null, (_this$state$options = this.state.options) === null || _this$state$options === void 0 ? void 0 : _this$state$options.map(function (value, i) { var _this2$props$customCl2; return /*#__PURE__*/_react["default"].createElement("div", { className: (0, _classnames["default"])(classList.listItem, { hover: _this2.props.selectionIndex === i + valueOffset, selected: (_this2.props.selectedItems || []).find(function (item) { return display(item) === display(value); }) }, (_this2$props$customCl2 = _this2.props.customClasses) === null || _this2$props$customCl2 === void 0 ? void 0 : _this2$props$customCl2.listItem), key: "".concat(display(value), "_").concat(i), onMouseDown: function onMouseDown(e) { return _this2._onClick(value, e); }, onClick: function onClick(e) { return _this2._onClick(value, e); } }, /*#__PURE__*/_react["default"].createElement(CustomListItemComponent, { value: value, displayOption: display })); }), /*#__PURE__*/_react["default"].createElement(DropdownFooterWrapper, { ref: this.loadingRef })); } }]); }(_react.Component); (0, _defineProperty2["default"])(DropdownList, "defaultProps", { customClasses: {}, customListItemComponent: ListItem, customListHeaderComponent: null, allowCustomValues: 0, customValues: [], displayOption: defaultDisplay, onOptionSelected: function onOptionSelected() { return; }, defaultClassNames: true, selectionIndex: null }); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_classnames","_interopRequireDefault","_styledComponents","_constants","_templateObject","_templateObject2","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","_callSuper","o","_getPrototypeOf2","_possibleConstructorReturn2","_isNativeReflectConstruct","Reflect","construct","constructor","apply","Boolean","prototype","valueOf","LEFT_BUTTON","classList","exports","list","listHeader","listSection","listItem","listItemAnchor","listItemFixed","defaultDisplay","d","ListItem","_ref","value","_ref$displayOption","displayOption","disabled","displayValue","createElement","title","className","classNames","DropdownListWrapper","styled","div","_taggedTemplateLiteral2","props","light","theme","dropdownListBgdLT","dropdownListBgd","dropdownListBorderTopLT","dropdownListBorderTop","dropdownListLT","dropdownList","DropdownFooterWrapper","DropdownList","_Component","_this","_classCallCheck2","_defineProperty2","entities","y","boundingClientRect","prevY","options","_getOptions","page","setState","state","initNumberOfOptions","INIT_FILTER_ITEMS_IN_DROPDOWN","loadingRef","React","createRef","_inherits2","_createClass2","key","componentDidMount","divOptions","root","rootMargin","threshold","current","observer","IntersectionObserver","handleObserver","observe","getSnapshotBeforeUpdate","prevProps","componentDidUpdate","componentWillUnmount","_this$observer","_this$loadingRef","unobserve","length","start","end","concat","_toConsumableArray2","slice","_onClick","result","event","preventDefault","type","button","_this$props$onOptionS","_this$props","onOptionSelected","render","_this$props$options","_this$props$customCla","_this$props$customCla2","_this2","_this$state$options","_this$props2","fixedOptions","_this$props2$allowCus","allowCustomValues","_this$props2$customLi","customListItemComponent","CustomListItemComponent","_this$props$displayOp","display","valueOffset","Array","isArray","customClasses","results","customListHeaderComponent","map","_this2$props$customCl","hover","selectionIndex","onMouseDown","onClick","_this2$props$customCl2","selected","selectedItems","find","item","ref","Component","customValues","defaultClassNames"],"sources":["../../../src/common/item-selector/dropdown-list.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {Component, ElementType} from 'react';\nimport classNames from 'classnames';\nimport styled, {IStyledComponent} from 'styled-components';\nimport {INIT_FILTER_ITEMS_IN_DROPDOWN} from '@kepler.gl/constants';\nimport {BaseComponentProps} from '../../types';\n\nconst LEFT_BUTTON = 0;\n\nexport const classList = {\n  list: 'list-selector',\n  listHeader: 'list__header',\n  listSection: 'list__section',\n  listItem: 'list__item',\n  listItemAnchor: 'list__item__anchor',\n  listItemFixed: 'list__item__fixed'\n};\n\nexport type ListItemProps<Option> = {\n  value: Option;\n  displayOption: (opt: Option) => string;\n  disabled?: boolean;\n  light?: boolean;\n};\n\nconst defaultDisplay = d => d;\nexport const ListItem = ({value, displayOption = defaultDisplay, disabled}: ListItemProps<any>) => {\n  const displayValue = displayOption(value);\n  return (\n    <span title={displayValue} className={classNames(classList.listItemAnchor, {disabled})}>\n      {displayValue}\n    </span>\n  );\n};\n\nexport type DropdownListWrapperProps = BaseComponentProps & {\n  light?: boolean;\n};\n\nconst DropdownListWrapper: IStyledComponent<\n  'web',\n  DropdownListWrapperProps\n> = styled.div<DropdownListWrapperProps>`\n  background-color: ${props =>\n    props.light ? props.theme.dropdownListBgdLT : props.theme.dropdownListBgd};\n  border-top: 1px solid\n    ${props =>\n      props.light ? props.theme.dropdownListBorderTopLT : props.theme.dropdownListBorderTop};\n  ${props => (props.light ? props.theme.dropdownListLT : props.theme.dropdownList)};\n`;\n\nconst DropdownFooterWrapper = styled.div`\n  height: '0px';\n`;\n\ntype Option = string | number | boolean | object | any;\n// TODO: make Option a generic type\ninterface DropdownListProps {\n  options?: Option[];\n  allowCustomValues?: number;\n  customClasses?: {listHeader?: string; listItem?: string; results?: string};\n  customValues?: any[];\n  customListItemComponent?: ElementType;\n  customListHeaderComponent?: ElementType;\n  selectionIndex?: number;\n  onOptionSelected?: (option: Option, event: React.MouseEvent) => void;\n  displayOption?: (option: Option) => string;\n  defaultClassNames?: boolean;\n  areResultsTruncated?: boolean;\n  resultsTruncatedMessage?: string;\n  listItemComponent?: ElementType;\n  light?: boolean;\n  fixedOptions?: any[];\n  selectedItems?: any[]; // Passed through by Typeahead\n}\n\ninterface DropdownListState {\n  options: Array<any> | null;\n}\n\nexport default class DropdownList extends Component<DropdownListProps, DropdownListState> {\n  static defaultProps = {\n    customClasses: {},\n    customListItemComponent: ListItem,\n    customListHeaderComponent: null,\n    allowCustomValues: 0,\n    customValues: [],\n    displayOption: defaultDisplay,\n    onOptionSelected: () => {\n      return;\n    },\n    defaultClassNames: true,\n    selectionIndex: null\n  };\n\n  initNumberOfOptions: number;\n  page: number;\n  prevY: number;\n  loadingRef: React.RefObject<HTMLDivElement>;\n  observer: IntersectionObserver | undefined;\n\n  constructor(props) {\n    super(props);\n\n    this.state = {options: []};\n    this.initNumberOfOptions = INIT_FILTER_ITEMS_IN_DROPDOWN;\n    this.page = 0;\n    this.prevY = 0;\n    this.loadingRef = React.createRef();\n  }\n\n  componentDidMount() {\n    const options = this._getOptions(this.page);\n    this.setState({options});\n\n    const divOptions = {\n      root: null,\n      rootMargin: '0%',\n      threshold: 1.0\n    };\n\n    if (this.loadingRef.current) {\n      this.observer = new IntersectionObserver(this.handleObserver, divOptions);\n      this.observer.observe(this.loadingRef.current);\n    }\n  }\n\n  getSnapshotBeforeUpdate(prevProps: DropdownListProps) {\n    if (prevProps.options !== this.props.options) {\n      // check if user searching, reset state.options at the first time\n      const options = this._getOptions(0);\n      this.setState({options});\n    }\n    return null;\n  }\n\n  // prevent console warning: getSnapshotBeforeUpdate() should be used with componentDidUpdate().\n  componentDidUpdate() {\n    return;\n  }\n\n  componentWillUnmount() {\n    if (this.loadingRef.current) {\n      this.observer?.unobserve(this.loadingRef?.current);\n      this.page = 0;\n      this.prevY = 0;\n    }\n  }\n\n  handleObserver = entities => {\n    const y = entities[0].boundingClientRect.y;\n    if (this.prevY > y) {\n      const options = this._getOptions(this.page);\n      if (options) this.setState({options});\n    }\n    this.prevY = y;\n  };\n\n  _getOptions(page) {\n    if (!this.props.options) {\n      return [];\n    }\n\n    const n = this.props.options.length;\n    if (n === 0) {\n      return [];\n    }\n    const start = page * this.initNumberOfOptions;\n    const end = start + this.initNumberOfOptions > n ? n : start + this.initNumberOfOptions;\n\n    if (start < end && end <= n) {\n      this.page = page + 1;\n      // in case of user searching, props.options will be updated\n      // so \"page\" value will be set to 0 and previous state.options will be discarded\n      return [\n        ...(page > 0 ? this.state.options || [] : []),\n        ...this.props.options.slice(start, end)\n      ];\n    }\n\n    return null;\n  }\n\n  _onClick(result, event) {\n    event.preventDefault();\n    // only work when left is clicked\n    if ((event.type === 'mousedown' && event.button === LEFT_BUTTON) || event.type === 'click') {\n      this.props.onOptionSelected?.(result, event);\n    }\n  }\n\n  render() {\n    const {\n      fixedOptions,\n      light,\n      allowCustomValues = 0,\n      customListItemComponent: CustomListItemComponent = ListItem\n    } = this.props;\n    const {displayOption: display = defaultDisplay} = this.props;\n\n    // Don't render if there are no options to display\n    if (!this.props.options?.length && allowCustomValues <= 0) {\n      return <div />;\n    }\n\n    const valueOffset = Array.isArray(fixedOptions) ? fixedOptions.length : 0;\n\n    // For some reason onClick is not fired when clicked on an option\n    // onMouseDown is used here as a workaround of #205 and other\n    return (\n      <DropdownListWrapper\n        className={classNames(classList.list, this.props.customClasses?.results)}\n        light={light}\n      >\n        {this.props.customListHeaderComponent ? (\n          <div className={classNames(classList.listHeader, this.props.customClasses?.listHeader)}>\n            <this.props.customListHeaderComponent />\n          </div>\n        ) : null}\n\n        {valueOffset > 0 ? (\n          <div className={classList.listSection}>\n            {fixedOptions?.map((value, i) => (\n              <div\n                className={classNames(\n                  classList.listItem,\n                  {\n                    hover: this.props.selectionIndex === i,\n                    [classList.listItemFixed]: true\n                  },\n                  this.props.customClasses?.listItem\n                )}\n                key={`${display(value)}_${i}`}\n                onMouseDown={e => this._onClick(value, e)}\n                onClick={e => this._onClick(value, e)}\n              >\n                <CustomListItemComponent value={value} displayOption={display} light={light} />\n              </div>\n            ))}\n          </div>\n        ) : null}\n\n        {this.state.options?.map((value, i) => (\n          <div\n            className={classNames(\n              classList.listItem,\n              {\n                hover: this.props.selectionIndex === i + valueOffset,\n                selected: (this.props.selectedItems || []).find(\n                  item => display(item) === display(value)\n                )\n              },\n              this.props.customClasses?.listItem\n            )}\n            key={`${display(value)}_${i}`}\n            onMouseDown={e => this._onClick(value, e)}\n            onClick={e => this._onClick(value, e)}\n          >\n            <CustomListItemComponent value={value} displayOption={display} />\n          </div>\n        ))}\n\n        <DropdownFooterWrapper ref={this.loadingRef} />\n      </DropdownListWrapper>\n    );\n  }\n}\n"],"mappings":"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","ignoreList":[]}