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
JavaScript
;
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"]}