kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
115 lines (114 loc) • 22.1 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 _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 _switch = _interopRequireDefault(require("../../common/switch"));
var _brushConfig = _interopRequireDefault(require("./brush-config"));
var _tooltipConfig = _interopRequireDefault(require("./tooltip-config"));
var _styledComponents2 = require("../../common/styled-components");
var _icons = require("../../common/icons");
var _localization = require("@kepler.gl/localization");
var _templateObject; // 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 StyledInteractionPanel = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n padding-bottom: 6px;\n contain: layout paint;\n"])));
InteractionPanelFactory.deps = [_tooltipConfig["default"], _brushConfig["default"]];
var INTERACTION_CONFIG_ICONS = {
tooltip: _icons.Messages,
geocoder: _icons.Pin,
brush: _icons.Crosshairs,
coordinate: _icons.CursorClick
};
function InteractionPanelFactory(TooltipConfig, BrushConfig) {
var InteractionPanel = function InteractionPanel(_ref) {
var config = _ref.config,
onConfigChange = _ref.onConfigChange,
datasets = _ref.datasets,
setColumnDisplayFormat = _ref.setColumnDisplayFormat,
_ref$interactionConfi = _ref.interactionConfigIcons,
interactionConfigIcons = _ref$interactionConfi === void 0 ? INTERACTION_CONFIG_ICONS : _ref$interactionConfi;
var _useState = (0, _react.useState)(false),
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
isConfigActive = _useState2[0],
setIsConfigAction = _useState2[1];
var _updateConfig = (0, _react.useCallback)(function (newProp) {
onConfigChange(_objectSpread(_objectSpread({}, config), newProp));
}, [onConfigChange, config]);
var onDisplayFormatChange = (0, _react.useCallback)(function (dataId, column, displayFormat) {
setColumnDisplayFormat(dataId, (0, _defineProperty2["default"])({}, column, displayFormat));
}, [setColumnDisplayFormat]);
var togglePanelActive = (0, _react.useCallback)(function () {
setIsConfigAction(!isConfigActive);
}, [setIsConfigAction, isConfigActive]);
var enabled = config.enabled;
var toggleEnableConfig = (0, _react.useCallback)(function () {
_updateConfig({
enabled: !enabled
});
}, [_updateConfig, enabled]);
var onChange = (0, _react.useCallback)(function (newConfig) {
return _updateConfig({
config: newConfig
});
}, [_updateConfig]);
var IconComponent = interactionConfigIcons[config.id];
var template = null;
switch (config.id) {
case 'tooltip':
template = /*#__PURE__*/_react["default"].createElement(TooltipConfig, {
datasets: datasets,
config: config.config,
onChange: onChange,
onDisplayFormatChange: onDisplayFormatChange
});
break;
case 'brush':
template = /*#__PURE__*/_react["default"].createElement(BrushConfig, {
config: config.config,
onChange: onChange
});
break;
default:
break;
}
return /*#__PURE__*/_react["default"].createElement(StyledInteractionPanel, {
className: "interaction-panel"
}, /*#__PURE__*/_react["default"].createElement(_styledComponents2.StyledPanelHeader, {
className: "interaction-panel__header",
onClick: togglePanelActive
}, /*#__PURE__*/_react["default"].createElement(_styledComponents2.PanelHeaderContent, {
className: "interaction-panel__header__content"
}, /*#__PURE__*/_react["default"].createElement("div", {
className: "interaction-panel__header__icon icon"
}, IconComponent ? /*#__PURE__*/_react["default"].createElement(IconComponent, {
height: "16px"
}) : null), /*#__PURE__*/_react["default"].createElement("div", {
className: "interaction-panel__header__title"
}, /*#__PURE__*/_react["default"].createElement(_styledComponents2.PanelHeaderTitle, null, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: config.label
})))), /*#__PURE__*/_react["default"].createElement("div", {
className: "interaction-panel__header__actions"
}, /*#__PURE__*/_react["default"].createElement(_switch["default"], {
checked: config.enabled,
id: "".concat(config.id, "-toggle"),
onChange: toggleEnableConfig,
secondary: true
}))), config.enabled && template && /*#__PURE__*/_react["default"].createElement(_styledComponents2.PanelContent, {
className: "interaction-panel__content"
}, template));
};
return InteractionPanel;
}
var _default = exports["default"] = InteractionPanelFactory;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_switch","_brushConfig","_tooltipConfig","_styledComponents2","_icons","_localization","_templateObject","_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","StyledInteractionPanel","styled","div","_taggedTemplateLiteral2","InteractionPanelFactory","deps","TooltipConfigFactory","BrushConfigFactory","INTERACTION_CONFIG_ICONS","tooltip","Messages","geocoder","Pin","brush","Crosshairs","coordinate","CursorClick","TooltipConfig","BrushConfig","InteractionPanel","_ref","config","onConfigChange","datasets","setColumnDisplayFormat","_ref$interactionConfi","interactionConfigIcons","_useState","useState","_useState2","_slicedToArray2","isConfigActive","setIsConfigAction","_updateConfig","useCallback","newProp","onDisplayFormatChange","dataId","column","displayFormat","togglePanelActive","enabled","toggleEnableConfig","onChange","newConfig","IconComponent","id","template","createElement","className","StyledPanelHeader","onClick","PanelHeaderContent","height","PanelHeaderTitle","FormattedMessage","label","checked","concat","secondary","PanelContent","_default","exports"],"sources":["../../../src/side-panel/interaction-panel/interaction-panel.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useState, ComponentType, ReactElement, useCallback} from 'react';\nimport styled from 'styled-components';\nimport Switch from '../../common/switch';\nimport BrushConfigFactory from './brush-config';\nimport TooltipConfigFactory from './tooltip-config';\nimport {Datasets} from '@kepler.gl/table';\nimport {InteractionConfig, ValueOf} from '@kepler.gl/types';\nimport {\n  setColumnDisplayFormat as setColumnDisplayFormatAction,\n  ActionHandler\n} from '@kepler.gl/actions';\n\nimport {\n  StyledPanelHeader,\n  PanelHeaderTitle,\n  PanelHeaderContent,\n  PanelContent\n} from '../../common/styled-components';\nimport {Messages, Crosshairs, CursorClick, Pin} from '../../common/icons';\n\nimport {FormattedMessage} from '@kepler.gl/localization';\n\ninterface InteractionPanelProps {\n  datasets: Datasets;\n  config: ValueOf<InteractionConfig>;\n  onConfigChange: any;\n  interactionConfigIcons?: {\n    [key: string]: React.ElementType;\n  };\n  setColumnDisplayFormat: ActionHandler<typeof setColumnDisplayFormatAction>;\n}\n\nconst StyledInteractionPanel = styled.div`\n  padding-bottom: 6px;\n  contain: layout paint;\n`;\n\nInteractionPanelFactory.deps = [TooltipConfigFactory, BrushConfigFactory];\n\nconst INTERACTION_CONFIG_ICONS: {[key: string]: React.ElementType} = {\n  tooltip: Messages,\n  geocoder: Pin,\n  brush: Crosshairs,\n  coordinate: CursorClick\n};\n\nfunction InteractionPanelFactory(\n  TooltipConfig: ReturnType<typeof TooltipConfigFactory>,\n  BrushConfig: ReturnType<typeof BrushConfigFactory>\n): ComponentType<InteractionPanelProps> {\n  const InteractionPanel: React.FC<InteractionPanelProps> = ({\n    config,\n    onConfigChange,\n    datasets,\n    setColumnDisplayFormat,\n    interactionConfigIcons = INTERACTION_CONFIG_ICONS\n  }) => {\n    const [isConfigActive, setIsConfigAction] = useState(false);\n\n    const _updateConfig = useCallback(\n      newProp => {\n        onConfigChange({\n          ...config,\n          ...newProp\n        });\n      },\n      [onConfigChange, config]\n    );\n\n    const onDisplayFormatChange = useCallback(\n      (dataId, column, displayFormat) => {\n        setColumnDisplayFormat(dataId, {[column]: displayFormat});\n      },\n      [setColumnDisplayFormat]\n    );\n\n    const togglePanelActive = useCallback(() => {\n      setIsConfigAction(!isConfigActive);\n    }, [setIsConfigAction, isConfigActive]);\n\n    const {enabled} = config;\n    const toggleEnableConfig = useCallback(() => {\n      _updateConfig({enabled: !enabled});\n    }, [_updateConfig, enabled]);\n\n    const onChange = useCallback(newConfig => _updateConfig({config: newConfig}), [_updateConfig]);\n\n    const IconComponent = interactionConfigIcons[config.id];\n\n    let template: ReactElement | null = null;\n\n    switch (config.id) {\n      case 'tooltip':\n        template = (\n          <TooltipConfig\n            datasets={datasets}\n            config={config.config}\n            onChange={onChange}\n            onDisplayFormatChange={onDisplayFormatChange}\n          />\n        );\n        break;\n      case 'brush':\n        template = <BrushConfig config={config.config} onChange={onChange} />;\n        break;\n\n      default:\n        break;\n    }\n    return (\n      <StyledInteractionPanel className=\"interaction-panel\">\n        <StyledPanelHeader className=\"interaction-panel__header\" onClick={togglePanelActive}>\n          <PanelHeaderContent className=\"interaction-panel__header__content\">\n            <div className=\"interaction-panel__header__icon icon\">\n              {IconComponent ? <IconComponent height=\"16px\" /> : null}\n            </div>\n            <div className=\"interaction-panel__header__title\">\n              <PanelHeaderTitle>\n                <FormattedMessage id={config.label} />\n              </PanelHeaderTitle>\n            </div>\n          </PanelHeaderContent>\n          <div className=\"interaction-panel__header__actions\">\n            <Switch\n              checked={config.enabled}\n              id={`${config.id}-toggle`}\n              onChange={toggleEnableConfig}\n              secondary\n            />\n          </div>\n        </StyledPanelHeader>\n        {config.enabled && template && (\n          <PanelContent className=\"interaction-panel__content\">{template}</PanelContent>\n        )}\n      </StyledInteractionPanel>\n    );\n  };\n\n  return InteractionPanel;\n}\n\nexport default InteractionPanelFactory;\n"],"mappings":"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","ignoreList":[]}