kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
150 lines (149 loc) • 31.3 kB
JavaScript
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 _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
var _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral"));
var _react = _interopRequireWildcard(require("react"));
var _styledComponents = _interopRequireDefault(require("styled-components"));
var _reactIntl = require("react-intl");
var _localization = require("@kepler.gl/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 _constants = require("@kepler.gl/constants");
var _fieldSelector = _interopRequireDefault(require("../../common/field-selector"));
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; }
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2["default"])(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
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,
onDisplayFormatChange = _ref.onDisplayFormatChange;
var dataId = dataset.id;
var handleClick = (0, _react.useCallback)(function () {
return onChange(_objectSpread(_objectSpread({}, config), {}, {
fieldsToShow: _objectSpread(_objectSpread({}, config.fieldsToShow), {}, (0, _defineProperty2["default"])({}, dataId, []))
}));
}, [config, dataId, onChange]);
var findSelectedHelper = (0, _react.useCallback)(function (selected, tooltipFields) {
return selected.map(function (f) {
return tooltipFields.find(function (tooltipField) {
return tooltipField.name === f.name;
}) || {
name: f.name,
// default initial tooltip is null
format: null
};
});
}, []);
var handleSelect = (0, _react.useCallback)(function (selected) {
var newConfig = _objectSpread(_objectSpread({}, config), {}, {
fieldsToShow: _objectSpread(_objectSpread({}, config.fieldsToShow), {}, (0, _defineProperty2["default"])({}, dataId, findSelectedHelper(selected, config.fieldsToShow[dataId])))
});
onChange(newConfig);
}, [config, dataId, onChange, findSelectedHelper]);
var handleReorderItems = (0, _react.useCallback)(function (newOrder) {
return onChange(_objectSpread(_objectSpread({}, config), {}, {
fieldsToShow: _objectSpread(_objectSpread({}, config.fieldsToShow), {}, (0, _defineProperty2["default"])({}, dataId, newOrder))
}));
}, [config, dataId, onChange]);
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: handleClick,
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: handleSelect,
reorderItems: handleReorderItems,
closeOnSelect: false,
multiSelect: true,
inputTheme: "secondary",
CustomChickletComponent: (0, _tooltipChicklet["default"])(dataId, config, onChange, dataset.fields, onDisplayFormatChange)
}));
};
var TooltipConfig = function TooltipConfig(_ref2) {
var config = _ref2.config,
datasets = _ref2.datasets,
_onChange = _ref2.onChange,
onDisplayFormatChange = _ref2.onDisplayFormatChange,
intl = _ref2.intl;
var handleChange = (0, _react.useCallback)(function (option) {
return _onChange(_objectSpread(_objectSpread({}, config), {}, {
compareType: option
}));
}, [config, _onChange]);
return /*#__PURE__*/_react["default"].createElement(TooltipConfigWrapper, null, Object.keys(config.fieldsToShow).map(function (dataId) {
return dataId === _constants.GEOCODER_DATASET_NAME ? null : /*#__PURE__*/_react["default"].createElement(DatasetTooltipConfig, {
key: dataId,
config: config,
onChange: _onChange,
dataset: datasets[dataId],
onDisplayFormatChange: onDisplayFormatChange
});
}), /*#__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(_constants.COMPARE_TYPES),
multiSelect: false,
searchable: false,
inputTheme: 'secondary',
getOptionValue: function getOptionValue(d) {
return d;
},
onChange: handleChange
})));
};
return (0, _reactIntl.injectIntl)(TooltipConfig);
}
var _default = exports["default"] = TooltipConfigFactory;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_reactIntl","_localization","_styledComponents2","_datasetTag","_tooltipChicklet","_switch","_itemSelector","_constants","_fieldSelector","_templateObject","_templateObject2","_templateObject3","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ownKeys","keys","getOwnPropertySymbols","o","filter","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty2","getOwnPropertyDescriptors","defineProperties","TooltipConfigWrapper","styled","div","_taggedTemplateLiteral2","ButtonWrapper","props","theme","subtextColor","textColor","CompareSwitchWrapper","labelColor","inputFontSize","TooltipConfigFactory","deps","DatasetTagFactory","FieldSelectorFactory","DatasetTag","FieldSelector","DatasetTooltipConfig","_ref","config","onChange","dataset","onDisplayFormatChange","dataId","id","handleClick","useCallback","fieldsToShow","findSelectedHelper","selected","tooltipFields","map","f","find","tooltipField","name","format","handleSelect","newConfig","handleReorderItems","newOrder","createElement","SidePanelSection","key","SBFlexboxNoMargin","Boolean","Button","className","onClick","width","secondary","FormattedMessage","fields","value","onSelect","reorderItems","closeOnSelect","multiSelect","inputTheme","CustomChickletComponent","TooltipChickletFactory","TooltipConfig","_ref2","datasets","intl","handleChange","option","compareType","GEOCODER_DATASET_NAME","checked","compareMode","PanelLabel","disabled","displayOption","d","formatMessage","concat","selectedItems","options","values","COMPARE_TYPES","searchable","getOptionValue","injectIntl","_default","exports"],"sources":["../../../src/side-panel/interaction-panel/tooltip-config.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useCallback} from 'react';\nimport styled from 'styled-components';\nimport {injectIntl, IntlShape} from 'react-intl';\nimport {FormattedMessage} from '@kepler.gl/localization';\n\nimport {\n  SidePanelSection,\n  SBFlexboxNoMargin,\n  Button,\n  PanelLabel\n} from '../../common/styled-components';\nimport DatasetTagFactory from '../common/dataset-tag';\nimport TooltipChickletFactory from './tooltip-config/tooltip-chicklet';\nimport Switch from '../../common/switch';\nimport ItemSelector from '../../common/item-selector/item-selector';\nimport {COMPARE_TYPES, GEOCODER_DATASET_NAME} from '@kepler.gl/constants';\nimport FieldSelectorFactory from '../../common/field-selector';\nimport KeplerTable, {Datasets} from '@kepler.gl/table';\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\ntype TooltipConfigProps = {\n  config: {\n    fieldsToShow: {\n      [key: string]: {name: string; format: string | null}[];\n    };\n    compareMode: boolean;\n    compareType: string | null;\n  };\n  onChange: (config: {\n    fieldsToShow: {\n      [key: string]: {name: string; format: string | null}[];\n    };\n    compareMode: boolean;\n    compareType: string | null;\n  }) => void;\n  datasets: Datasets;\n  intl: IntlShape;\n  onDisplayFormatChange: (dataId, column, displayFormat) => void;\n};\n\ntype DatasetTooltipConfigProps = {\n  config: {\n    fieldsToShow: {\n      [key: string]: {name: string; format: string | null}[];\n    };\n    compareMode: boolean;\n    compareType: string | null;\n  };\n  onChange: (config: {\n    fieldsToShow: {\n      [key: string]: {name: string; format: string | null}[];\n    };\n    compareMode: boolean;\n    compareType: string | null;\n  }) => void;\n  dataset: KeplerTable;\n  onDisplayFormatChange: (dataId, column, displayFormat) => void;\n};\n\nTooltipConfigFactory.deps = [DatasetTagFactory, FieldSelectorFactory];\nfunction TooltipConfigFactory(\n  DatasetTag: ReturnType<typeof DatasetTagFactory>,\n  FieldSelector: ReturnType<typeof FieldSelectorFactory>\n) {\n  const DatasetTooltipConfig = ({\n    config,\n    onChange,\n    dataset,\n    onDisplayFormatChange\n  }: DatasetTooltipConfigProps) => {\n    const dataId = dataset.id;\n\n    const handleClick = useCallback(\n      () =>\n        onChange({\n          ...config,\n          fieldsToShow: {\n            ...config.fieldsToShow,\n            [dataId]: []\n          }\n        }),\n      [config, dataId, onChange]\n    );\n\n    const findSelectedHelper = useCallback((selected, tooltipFields) => {\n      return selected.map(\n        f =>\n          tooltipFields.find(tooltipField => tooltipField.name === f.name) || {\n            name: f.name,\n            // default initial tooltip is null\n            format: null\n          }\n      );\n    }, []);\n\n    const handleSelect = useCallback(\n      selected => {\n        const newConfig: DatasetTooltipConfigProps['config'] = {\n          ...config,\n          fieldsToShow: {\n            ...config.fieldsToShow,\n            [dataId]: findSelectedHelper(selected, config.fieldsToShow[dataId])\n          }\n        };\n        onChange(newConfig);\n      },\n      [config, dataId, onChange, findSelectedHelper]\n    );\n\n    const handleReorderItems = useCallback(\n      newOrder =>\n        onChange({\n          ...config,\n          fieldsToShow: {\n            ...config.fieldsToShow,\n            [dataId]: newOrder\n          }\n        }),\n      [config, dataId, onChange]\n    );\n    return (\n      <SidePanelSection key={dataId}>\n        <SBFlexboxNoMargin>\n          <DatasetTag dataset={dataset} />\n          {Boolean(config.fieldsToShow[dataId].length) && (\n            <ButtonWrapper>\n              <Button className=\"clear-all\" onClick={handleClick} width=\"54px\" secondary>\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={handleSelect}\n          reorderItems={handleReorderItems}\n          closeOnSelect={false}\n          multiSelect\n          inputTheme=\"secondary\"\n          CustomChickletComponent={TooltipChickletFactory(\n            dataId,\n            config,\n            onChange,\n            dataset.fields,\n            onDisplayFormatChange\n          )}\n        />\n      </SidePanelSection>\n    );\n  };\n\n  const TooltipConfig = ({\n    config,\n    datasets,\n    onChange,\n    onDisplayFormatChange,\n    intl\n  }: TooltipConfigProps) => {\n    const handleChange = useCallback(\n      (option: string | number | boolean | object | null) =>\n        onChange({\n          ...config,\n          compareType: option as string | null\n        }),\n      [config, onChange]\n    );\n\n    return (\n      <TooltipConfigWrapper>\n        {Object.keys(config.fieldsToShow).map(dataId =>\n          dataId === GEOCODER_DATASET_NAME ? null : (\n            <DatasetTooltipConfig\n              key={dataId}\n              config={config}\n              onChange={onChange}\n              dataset={datasets[dataId]}\n              onDisplayFormatChange={onDisplayFormatChange}\n            />\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={handleChange}\n          />\n        </SidePanelSection>\n      </TooltipConfigWrapper>\n    );\n  };\n\n  return injectIntl(TooltipConfig);\n}\n\nexport default TooltipConfigFactory;\n"],"mappings":"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","ignoreList":[]}
;