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
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"] = 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":[]}