UNPKG

kepler.gl

Version:

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

129 lines (128 loc) 22 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"] = void 0; var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray")); var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireWildcard(require("react")); var _styledComponents = _interopRequireDefault(require("styled-components")); var _localization = require("@kepler.gl/localization"); var _react2 = _interopRequireDefault(require("@tippyjs/react")); var _icons = require("../common/icons"); var _styledComponents2 = require("../common/styled-components"); var _typeahead = _interopRequireDefault(require("../common/item-selector/typeahead")); var _accessor = _interopRequireDefault(require("../common/item-selector/accessor")); var _reactIntl = require("react-intl"); var _context = require("../context"); var _templateObject, _templateObject2, _templateObject3; // 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; } var DropdownContainer = _styledComponents["default"].div.attrs({ className: 'add-layer-menu-dropdown' })(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n .list-selector {\n border-top: 1px solid ", ";\n width: 100%;\n /* disable scrolling, currently set to 280px internally */\n max-height: unset;\n }\n .list__item > div {\n display: flex;\n flex-direction: row;\n justify-content: flex-start;\n line-height: 18px;\n padding: 0;\n svg {\n margin-right: 10px;\n }\n }\n"])), function (props) { return props.theme.secondaryInputBorderColor; }); var DropdownMenu = _styledComponents["default"].div.attrs({ className: 'dropdown-menu' })(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n min-width: 240px;\n max-width: 240px;\n position: absolute;\n top: 100%;\n left: -53px;\n z-index: 5;\n"]))); var ListItemWrapper = _styledComponents["default"].div.attrs({ className: 'dropdown-menu-list-item-wrapper' })(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n color: ", ";\n font-size: 11px;\n letter-spacing: 0.2px;\n overflow: auto;\n .dataset-color {\n flex-shrink: 0;\n margin-top: 3px;\n }\n .dataset-name {\n white-space: nowrap;\n overflow: hidden;\n text-overflow: ellipsis;\n }\n"])), function (props) { return props.theme.textColor; }); var TYPEAHEAD_CLASS = 'typeahead'; var TYPEAHEAD_INPUT_CLASS = 'typeahead__input'; var ListItem = function ListItem(_ref) { var value = _ref.value; return /*#__PURE__*/_react["default"].createElement(ListItemWrapper, null, /*#__PURE__*/_react["default"].createElement(_styledComponents2.DatasetSquare, { className: "dataset-color", backgroundColor: value.color }), /*#__PURE__*/_react["default"].createElement("div", { className: "dataset-name", title: value.label }, value.label)); }; var AddByDatasetButton = function AddByDatasetButton(_ref2) { var datasets = _ref2.datasets, onAdd = _ref2.onAdd, buttonIntlId = _ref2.buttonIntlId, className = _ref2.className, inactive = _ref2.inactive; var _useState = (0, _react.useState)(), _useState2 = (0, _slicedToArray2["default"])(_useState, 2), tippyInstance = _useState2[0], setTippyInstance = _useState2[1]; var options = (0, _react.useMemo)(function () { return Object.values(datasets).map(function (ds) { return { label: ds.label, value: ds.id, color: ds.color }; }); }, [datasets]); var onClickBtn = (0, _react.useCallback)(function () { if (options.length === 1) { onAdd(options[0].value); } return; }, [options, onAdd]); var onOptionSelected = (0, _react.useCallback)(function (option) { if (!option) { return; } onAdd(option.value); if (tippyInstance) { // @ts-ignore tippyInstance.hide(); } }, [onAdd, tippyInstance]); var intl = (0, _reactIntl.useIntl)(); var buttonRendered = /*#__PURE__*/_react["default"].createElement(_styledComponents2.Button, { tabIndex: -1, className: className || 'add-by-dataset-button', onClick: onClickBtn, disabled: !options.length || inactive }, /*#__PURE__*/_react["default"].createElement(_icons.Add, { height: "12px" }), /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: buttonIntlId })); return options.length === 1 ? buttonRendered : /*#__PURE__*/_react["default"].createElement(_context.RootContext.Consumer, null, function (context) { return /*#__PURE__*/_react["default"].createElement(_react2["default"], { trigger: "click", arrow: false, interactive: true, placement: "bottom", appendTo: (context === null || context === void 0 ? void 0 : context.current) || 'parent' // @ts-ignore , onCreate: setTippyInstance, duration: 0, content: /*#__PURE__*/_react["default"].createElement(DropdownMenu, null, /*#__PURE__*/_react["default"].createElement(DropdownContainer, null, /*#__PURE__*/_react["default"].createElement(_typeahead["default"], { className: TYPEAHEAD_CLASS, customClasses: { results: 'list-selector', input: TYPEAHEAD_INPUT_CLASS, listItem: 'list__item' }, placeholder: intl ? intl.formatMessage({ id: 'placeholder.search' }) : 'Search', selectedItems: null, options: options, displayOption: _accessor["default"].generateOptionToStringFor('label'), filterOption: 'label', searchable: true, onOptionSelected: onOptionSelected, customListItemComponent: ListItem }))) }, buttonRendered); }); }; var _default = exports["default"] = AddByDatasetButton; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_localization","_react2","_icons","_styledComponents2","_typeahead","_accessor","_reactIntl","_context","_templateObject","_templateObject2","_templateObject3","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","DropdownContainer","styled","div","attrs","className","_taggedTemplateLiteral2","props","theme","secondaryInputBorderColor","DropdownMenu","ListItemWrapper","textColor","TYPEAHEAD_CLASS","TYPEAHEAD_INPUT_CLASS","ListItem","_ref","value","createElement","DatasetSquare","backgroundColor","color","title","label","AddByDatasetButton","_ref2","datasets","onAdd","buttonIntlId","inactive","_useState","useState","_useState2","_slicedToArray2","tippyInstance","setTippyInstance","options","useMemo","values","map","ds","id","onClickBtn","useCallback","length","onOptionSelected","option","hide","intl","useIntl","buttonRendered","Button","tabIndex","onClick","disabled","Add","height","FormattedMessage","RootContext","Consumer","context","trigger","arrow","interactive","placement","appendTo","current","onCreate","duration","content","customClasses","results","input","listItem","placeholder","formatMessage","selectedItems","displayOption","Accessor","generateOptionToStringFor","filterOption","searchable","customListItemComponent","_default","exports"],"sources":["../../src/side-panel/add-by-dataset-button.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useCallback, useMemo, useState} from 'react';\nimport styled from 'styled-components';\nimport {FormattedMessage} from '@kepler.gl/localization';\nimport {Datasets, KeplerTable} from '@kepler.gl/table';\n\nimport Tippy from '@tippyjs/react';\nimport {Add} from '../common/icons';\nimport {Button, DatasetSquare} from '../common/styled-components';\nimport Typeahead from '../common/item-selector/typeahead';\nimport Accessor from '../common/item-selector/accessor';\nimport {useIntl} from 'react-intl';\nimport {RootContext} from '../context';\n\nconst DropdownContainer = styled.div.attrs({\n  className: 'add-layer-menu-dropdown'\n})`\n  .list-selector {\n    border-top: 1px solid ${props => props.theme.secondaryInputBorderColor};\n    width: 100%;\n    /* disable scrolling, currently set to 280px internally */\n    max-height: unset;\n  }\n  .list__item > div {\n    display: flex;\n    flex-direction: row;\n    justify-content: flex-start;\n    line-height: 18px;\n    padding: 0;\n    svg {\n      margin-right: 10px;\n    }\n  }\n`;\n\nconst DropdownMenu = styled.div.attrs({\n  className: 'dropdown-menu'\n})`\n  display: flex;\n  flex-direction: column;\n  min-width: 240px;\n  max-width: 240px;\n  position: absolute;\n  top: 100%;\n  left: -53px;\n  z-index: 5;\n`;\n\nconst ListItemWrapper = styled.div.attrs({\n  className: 'dropdown-menu-list-item-wrapper'\n})`\n  display: flex;\n  color: ${props => props.theme.textColor};\n  font-size: 11px;\n  letter-spacing: 0.2px;\n  overflow: auto;\n  .dataset-color {\n    flex-shrink: 0;\n    margin-top: 3px;\n  }\n  .dataset-name {\n    white-space: nowrap;\n    overflow: hidden;\n    text-overflow: ellipsis;\n  }\n`;\n\nconst TYPEAHEAD_CLASS = 'typeahead';\nconst TYPEAHEAD_INPUT_CLASS = 'typeahead__input';\n\nexport type AddByDatasetButtonProps = {\n  datasets: Datasets;\n  onAdd: (dataId: string) => void;\n  buttonIntlId: string;\n  inactive?: boolean;\n  className?: string;\n};\n\nconst ListItem = ({value}) => (\n  <ListItemWrapper>\n    <DatasetSquare className=\"dataset-color\" backgroundColor={value.color} />\n    <div className=\"dataset-name\" title={value.label}>\n      {value.label}\n    </div>\n  </ListItemWrapper>\n);\n\nconst AddByDatasetButton: React.FC<AddByDatasetButtonProps> = ({\n  datasets,\n  onAdd,\n  buttonIntlId,\n  className,\n  inactive\n}) => {\n  const [tippyInstance, setTippyInstance] = useState();\n\n  const options = useMemo(() => {\n    return Object.values(datasets).map((ds: KeplerTable) => ({\n      label: ds.label,\n      value: ds.id,\n      color: ds.color\n    }));\n  }, [datasets]);\n\n  const onClickBtn = useCallback(() => {\n    if (options.length === 1) {\n      onAdd(options[0].value);\n    }\n\n    return;\n  }, [options, onAdd]);\n\n  const onOptionSelected = useCallback(\n    option => {\n      if (!option) {\n        return;\n      }\n      onAdd(option.value);\n      if (tippyInstance) {\n        // @ts-ignore\n        tippyInstance.hide();\n      }\n    },\n    [onAdd, tippyInstance]\n  );\n\n  const intl = useIntl();\n\n  const buttonRendered = (\n    <Button\n      tabIndex={-1}\n      className={className || 'add-by-dataset-button'}\n      onClick={onClickBtn}\n      disabled={!options.length || inactive}\n    >\n      <Add height=\"12px\" />\n      <FormattedMessage id={buttonIntlId} />\n    </Button>\n  );\n\n  return options.length === 1 ? (\n    buttonRendered\n  ) : (\n    <RootContext.Consumer>\n      {context => (\n        <Tippy\n          trigger=\"click\"\n          arrow={false}\n          interactive\n          placement=\"bottom\"\n          appendTo={context?.current || 'parent'}\n          // @ts-ignore\n          onCreate={setTippyInstance}\n          duration={0}\n          content={\n            <DropdownMenu>\n              <DropdownContainer>\n                <Typeahead\n                  className={TYPEAHEAD_CLASS}\n                  customClasses={{\n                    results: 'list-selector',\n                    input: TYPEAHEAD_INPUT_CLASS,\n                    listItem: 'list__item'\n                  }}\n                  placeholder={intl ? intl.formatMessage({id: 'placeholder.search'}) : 'Search'}\n                  selectedItems={null}\n                  options={options}\n                  displayOption={Accessor.generateOptionToStringFor('label')}\n                  filterOption={'label'}\n                  searchable\n                  onOptionSelected={onOptionSelected}\n                  customListItemComponent={ListItem}\n                />\n              </DropdownContainer>\n            </DropdownMenu>\n          }\n        >\n          {buttonRendered}\n        </Tippy>\n      )}\n    </RootContext.Consumer>\n  );\n};\n\nexport default AddByDatasetButton;\n"],"mappings":"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","ignoreList":[]}