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
JavaScript
"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","light","_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":[]}