UNPKG

kepler.gl

Version:

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

163 lines (133 loc) 21.9 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = void 0; var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty")); var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireDefault(require("react")); var _styledComponents = _interopRequireDefault(require("styled-components")); var _reactIntl = require("react-intl"); var _localization = require("../../../localization"); var _styledComponents2 = require("../../common/styled-components"); var _datasetTag = _interopRequireDefault(require("../common/dataset-tag")); var _tooltipChicklet = _interopRequireDefault(require("./tooltip-config/tooltip-chicklet")); var _switch = _interopRequireDefault(require("../../common/switch")); var _itemSelector = _interopRequireDefault(require("../../common/item-selector/item-selector")); var _tooltip = require("../../../constants/tooltip"); var _fieldSelector = _interopRequireDefault(require("../../common/field-selector")); var _templateObject, _templateObject2, _templateObject3; function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } var TooltipConfigWrapper = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n .item-selector > div > div {\n overflow: visible;\n }\n"]))); var ButtonWrapper = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: inherit;\n padding: 0;\n\n .button.clear-all {\n background: transparent;\n color: ", ";\n margin: 0 0 0 8px;\n padding: 0;\n\n &:hover {\n color: ", ";\n }\n }\n"])), function (props) { return props.theme.subtextColor; }, function (props) { return props.theme.textColor; }); var CompareSwitchWrapper = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n display: flex;\n font-size: ", ";\n justify-content: space-between;\n line-height: 11px;\n margin-bottom: 8px;\n"])), function (props) { return props.theme.labelColor; }, function (props) { return props.theme.inputFontSize; }); TooltipConfigFactory.deps = [_datasetTag["default"], _fieldSelector["default"]]; function TooltipConfigFactory(DatasetTag, FieldSelector) { var DatasetTooltipConfig = function DatasetTooltipConfig(_ref) { var config = _ref.config, onChange = _ref.onChange, dataset = _ref.dataset; var dataId = dataset.id; return /*#__PURE__*/_react["default"].createElement(_styledComponents2.SidePanelSection, { key: dataId }, /*#__PURE__*/_react["default"].createElement(_styledComponents2.SBFlexboxNoMargin, null, /*#__PURE__*/_react["default"].createElement(DatasetTag, { dataset: dataset }), Boolean(config.fieldsToShow[dataId].length) && /*#__PURE__*/_react["default"].createElement(ButtonWrapper, null, /*#__PURE__*/_react["default"].createElement(_styledComponents2.Button, { className: "clear-all", onClick: function onClick() { var newConfig = _objectSpread(_objectSpread({}, config), {}, { fieldsToShow: _objectSpread(_objectSpread({}, config.fieldsToShow), {}, (0, _defineProperty2["default"])({}, dataId, [])) }); onChange(newConfig); }, width: "54px", secondary: true }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: "fieldSelector.clearAll" })))), /*#__PURE__*/_react["default"].createElement(FieldSelector, { fields: dataset.fields, value: config.fieldsToShow[dataId], onSelect: function onSelect(selected) { var newConfig = _objectSpread(_objectSpread({}, config), {}, { fieldsToShow: _objectSpread(_objectSpread({}, config.fieldsToShow), {}, (0, _defineProperty2["default"])({}, dataId, selected.map(function (f) { return config.fieldsToShow[dataId].find(function (tooltipField) { return tooltipField.name === f.name; }) || { name: f.name, // default initial tooltip is null format: null }; }))) }); onChange(newConfig); }, closeOnSelect: false, multiSelect: true, inputTheme: "secondary", CustomChickletComponent: (0, _tooltipChicklet["default"])(dataId, config, onChange, dataset.fields) })); }; var TooltipConfig = function TooltipConfig(_ref2) { var config = _ref2.config, datasets = _ref2.datasets, _onChange = _ref2.onChange, intl = _ref2.intl; return /*#__PURE__*/_react["default"].createElement(TooltipConfigWrapper, null, Object.keys(config.fieldsToShow).map(function (dataId) { return /*#__PURE__*/_react["default"].createElement(DatasetTooltipConfig, { key: dataId, config: config, onChange: _onChange, dataset: datasets[dataId] }); }), /*#__PURE__*/_react["default"].createElement(CompareSwitchWrapper, null, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: "compare.modeLabel" }), /*#__PURE__*/_react["default"].createElement(_switch["default"], { checked: config.compareMode, id: "compare-mode-toggle", onChange: function onChange() { var newConfig = _objectSpread(_objectSpread({}, config), {}, { compareMode: !config.compareMode }); _onChange(newConfig); }, secondary: true })), /*#__PURE__*/_react["default"].createElement(_styledComponents2.SidePanelSection, null, /*#__PURE__*/_react["default"].createElement(_styledComponents2.PanelLabel, null, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: "compare.typeLabel" })), /*#__PURE__*/_react["default"].createElement(_itemSelector["default"], { disabled: !config.compareMode, displayOption: function displayOption(d) { return intl.formatMessage({ id: "compare.types.".concat(d) }); }, selectedItems: config.compareType, options: Object.values(_tooltip.COMPARE_TYPES), multiSelect: false, searchable: false, inputTheme: 'secondary', getOptionValue: function getOptionValue(d) { return d; }, onChange: function onChange(option) { var newConfig = _objectSpread(_objectSpread({}, config), {}, { compareType: option }); _onChange(newConfig); } }))); }; return (0, _reactIntl.injectIntl)(TooltipConfig); } var _default = TooltipConfigFactory; exports["default"] = _default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/components/side-panel/interaction-panel/tooltip-config.js"],"names":["TooltipConfigWrapper","styled","div","ButtonWrapper","props","theme","subtextColor","textColor","CompareSwitchWrapper","labelColor","inputFontSize","TooltipConfigFactory","deps","DatasetTagFactory","FieldSelectorFactory","DatasetTag","FieldSelector","DatasetTooltipConfig","config","onChange","dataset","dataId","id","Boolean","fieldsToShow","length","newConfig","fields","selected","map","f","find","tooltipField","name","format","TooltipConfig","datasets","intl","Object","keys","compareMode","d","formatMessage","compareType","values","COMPARE_TYPES","option"],"mappings":"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","sourcesContent":["// Copyright (c) 2021 Uber Technologies, Inc.\n//\n// Permission is hereby granted, free of charge, to any person obtaining a copy\n// of this software and associated documentation files (the \"Software\"), to deal\n// in the Software without restriction, including without limitation the rights\n// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell\n// copies of the Software, and to permit persons to whom the Software is\n// furnished to do so, subject to the following conditions:\n//\n// The above copyright notice and this permission notice shall be included in\n// all copies or substantial portions of the Software.\n//\n// THE SOFTWARE IS PROVIDED \"AS IS\", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR\n// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,\n// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE\n// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER\n// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,\n// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN\n// THE SOFTWARE.\n\nimport React from 'react';\nimport styled from 'styled-components';\nimport {injectIntl} from 'react-intl';\nimport {FormattedMessage} from 'localization';\n\nimport {\n  SidePanelSection,\n  SBFlexboxNoMargin,\n  Button,\n  PanelLabel\n} from 'components/common/styled-components';\nimport DatasetTagFactory from 'components/side-panel/common/dataset-tag';\nimport TooltipChickletFactory from './tooltip-config/tooltip-chicklet';\nimport Switch from 'components/common/switch';\nimport ItemSelector from 'components/common/item-selector/item-selector';\nimport {COMPARE_TYPES} from 'constants/tooltip';\nimport FieldSelectorFactory from '../../common/field-selector';\n\nconst TooltipConfigWrapper = styled.div`\n  .item-selector > div > div {\n    overflow: visible;\n  }\n`;\n\nconst ButtonWrapper = styled.div`\n  display: inherit;\n  padding: 0;\n\n  .button.clear-all {\n    background: transparent;\n    color: ${props => props.theme.subtextColor};\n    margin: 0 0 0 8px;\n    padding: 0;\n\n    &:hover {\n      color: ${props => props.theme.textColor};\n    }\n  }\n`;\n\nconst CompareSwitchWrapper = styled.div`\n  color: ${props => props.theme.labelColor};\n  display: flex;\n  font-size: ${props => props.theme.inputFontSize};\n  justify-content: space-between;\n  line-height: 11px;\n  margin-bottom: 8px;\n`;\n\nTooltipConfigFactory.deps = [DatasetTagFactory, FieldSelectorFactory];\nfunction TooltipConfigFactory(DatasetTag, FieldSelector) {\n  const DatasetTooltipConfig = ({config, onChange, dataset}) => {\n    const dataId = dataset.id;\n    return (\n      <SidePanelSection key={dataId}>\n        <SBFlexboxNoMargin>\n          <DatasetTag dataset={dataset} />\n          {Boolean(config.fieldsToShow[dataId].length) && (\n            <ButtonWrapper>\n              <Button\n                className=\"clear-all\"\n                onClick={() => {\n                  const newConfig = {\n                    ...config,\n                    fieldsToShow: {\n                      ...config.fieldsToShow,\n                      [dataId]: []\n                    }\n                  };\n                  onChange(newConfig);\n                }}\n                width=\"54px\"\n                secondary\n              >\n                <FormattedMessage id=\"fieldSelector.clearAll\" />\n              </Button>\n            </ButtonWrapper>\n          )}\n        </SBFlexboxNoMargin>\n        <FieldSelector\n          fields={dataset.fields}\n          value={config.fieldsToShow[dataId]}\n          onSelect={selected => {\n            const newConfig = {\n              ...config,\n              fieldsToShow: {\n                ...config.fieldsToShow,\n                [dataId]: selected.map(\n                  f =>\n                    config.fieldsToShow[dataId].find(\n                      tooltipField => tooltipField.name === f.name\n                    ) || {\n                      name: f.name,\n                      // default initial tooltip is null\n                      format: null\n                    }\n                )\n              }\n            };\n            onChange(newConfig);\n          }}\n          closeOnSelect={false}\n          multiSelect\n          inputTheme=\"secondary\"\n          CustomChickletComponent={TooltipChickletFactory(dataId, config, onChange, dataset.fields)}\n        />\n      </SidePanelSection>\n    );\n  };\n\n  const TooltipConfig = ({config, datasets, onChange, intl}) => {\n    return (\n      <TooltipConfigWrapper>\n        {Object.keys(config.fieldsToShow).map(dataId => (\n          <DatasetTooltipConfig\n            key={dataId}\n            config={config}\n            onChange={onChange}\n            dataset={datasets[dataId]}\n          />\n        ))}\n        <CompareSwitchWrapper>\n          <FormattedMessage id=\"compare.modeLabel\" />\n          <Switch\n            checked={config.compareMode}\n            id=\"compare-mode-toggle\"\n            onChange={() => {\n              const newConfig = {\n                ...config,\n                compareMode: !config.compareMode\n              };\n              onChange(newConfig);\n            }}\n            secondary\n          />\n        </CompareSwitchWrapper>\n        <SidePanelSection>\n          <PanelLabel>\n            <FormattedMessage id=\"compare.typeLabel\" />\n          </PanelLabel>\n          <ItemSelector\n            disabled={!config.compareMode}\n            displayOption={d =>\n              intl.formatMessage({\n                id: `compare.types.${d}`\n              })\n            }\n            selectedItems={config.compareType}\n            options={Object.values(COMPARE_TYPES)}\n            multiSelect={false}\n            searchable={false}\n            inputTheme={'secondary'}\n            getOptionValue={d => d}\n            onChange={option => {\n              const newConfig = {\n                ...config,\n                compareType: option\n              };\n              onChange(newConfig);\n            }}\n          />\n        </SidePanelSection>\n      </TooltipConfigWrapper>\n    );\n  };\n\n  return injectIntl(TooltipConfig);\n}\n\nexport default TooltipConfigFactory;\n"]}