kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
142 lines (122 loc) • 17 kB
JavaScript
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard");
Object.defineProperty(exports, "__esModule", {
value: true
});
exports["default"] = void 0;
var _react = _interopRequireWildcard(require("react"));
var _classnames = _interopRequireDefault(require("classnames"));
var _defaultSettings = require("../../constants/default-settings");
var _icons = require("../common/icons");
var _styledComponents = require("../common/styled-components");
var _toolbarItem = _interopRequireDefault(require("../common/toolbar-item"));
var _mapControlTooltip = _interopRequireDefault(require("./map-control-tooltip"));
var _mapControlPanel = _interopRequireDefault(require("./map-control-panel"));
var _mapControlToolbar = _interopRequireDefault(require("./map-control-toolbar"));
// Copyright (c) 2021 Uber Technologies, Inc.
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to deal
// in the Software without restriction, including without limitation the rights
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
// copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in
// all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
// THE SOFTWARE.
MapDrawPanelFactory.deps = [_mapControlTooltip["default"], _mapControlPanel["default"], _mapControlToolbar["default"]];
function MapDrawPanelFactory(MapControlTooltip, MapControlPanel, MapControlToolbar) {
var defaultActionIcons = {
visible: _icons.EyeSeen,
hidden: _icons.EyeUnseen,
polygon: _icons.DrawPolygon,
cursor: _icons.CursorClick,
innerPolygon: _icons.Polygon,
rectangle: _icons.Rectangle
};
/** @type {import('./map-draw-panel').MapDrawPanelComponent} */
var MapDrawPanel = /*#__PURE__*/_react["default"].memo(function (_ref) {
var _mapControls$mapDraw, _mapControls$mapDraw2;
var editor = _ref.editor,
mapControls = _ref.mapControls,
onToggleMapControl = _ref.onToggleMapControl,
onSetEditorMode = _ref.onSetEditorMode,
onToggleEditorVisibility = _ref.onToggleEditorVisibility,
_ref$actionIcons = _ref.actionIcons,
actionIcons = _ref$actionIcons === void 0 ? defaultActionIcons : _ref$actionIcons;
var isActive = mapControls === null || mapControls === void 0 ? void 0 : (_mapControls$mapDraw = mapControls.mapDraw) === null || _mapControls$mapDraw === void 0 ? void 0 : _mapControls$mapDraw.active;
var onToggleMenuPanel = (0, _react.useCallback)(function () {
return onToggleMapControl('mapDraw');
}, [onToggleMapControl]);
if (!(mapControls !== null && mapControls !== void 0 && (_mapControls$mapDraw2 = mapControls.mapDraw) !== null && _mapControls$mapDraw2 !== void 0 && _mapControls$mapDraw2.show)) {
return null;
}
return /*#__PURE__*/_react["default"].createElement("div", {
className: "map-draw-controls",
style: {
position: 'relative'
}
}, isActive ? /*#__PURE__*/_react["default"].createElement(MapControlToolbar, {
show: isActive
}, /*#__PURE__*/_react["default"].createElement(_toolbarItem["default"], {
className: "edit-feature",
onClick: function onClick() {
return onSetEditorMode(_defaultSettings.EDITOR_MODES.EDIT);
},
label: "toolbar.select",
icon: actionIcons.cursor,
active: editor.mode === _defaultSettings.EDITOR_MODES.EDIT
}), /*#__PURE__*/_react["default"].createElement(_toolbarItem["default"], {
className: "draw-feature",
onClick: function onClick() {
return onSetEditorMode(_defaultSettings.EDITOR_MODES.DRAW_POLYGON);
},
label: "toolbar.polygon",
icon: actionIcons.innerPolygon,
active: editor.mode === _defaultSettings.EDITOR_MODES.DRAW_POLYGON
}), /*#__PURE__*/_react["default"].createElement(_toolbarItem["default"], {
className: "draw-rectangle",
onClick: function onClick() {
return onSetEditorMode(_defaultSettings.EDITOR_MODES.DRAW_RECTANGLE);
},
label: "toolbar.rectangle",
icon: actionIcons.rectangle,
active: editor.mode === _defaultSettings.EDITOR_MODES.DRAW_RECTANGLE
}), /*#__PURE__*/_react["default"].createElement(_toolbarItem["default"], {
className: "toggle-features",
onClick: onToggleEditorVisibility,
label: editor.visible ? 'toolbar.hide' : 'toolbar.show',
icon: editor.visible ? actionIcons.visible : actionIcons.hidden
})) : null, /*#__PURE__*/_react["default"].createElement(_styledComponents.MapControlButton, {
onClick: function onClick(e) {
e.preventDefault();
onToggleMenuPanel();
},
active: isActive,
className: (0, _classnames["default"])('map-control-button', 'map-draw', {
isActive: isActive
}),
"data-tip": true,
"data-for": "map-draw"
}, /*#__PURE__*/_react["default"].createElement(actionIcons.polygon, {
height: "22px"
}), /*#__PURE__*/_react["default"].createElement(MapControlTooltip, {
id: "map-draw",
message: "tooltip.DrawOnMap"
})));
});
MapDrawPanel.displayName = 'MapDrawPanel';
return MapDrawPanel;
}
var _default = MapDrawPanelFactory;
exports["default"] = _default;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/map/map-draw-panel.js"],"names":["MapDrawPanelFactory","deps","MapControlTooltipFactory","MapControlPanelFactory","MapControlToolbarFactory","MapControlTooltip","MapControlPanel","MapControlToolbar","defaultActionIcons","visible","EyeSeen","hidden","EyeUnseen","polygon","DrawPolygon","cursor","CursorClick","innerPolygon","Polygon","rectangle","Rectangle","MapDrawPanel","React","memo","editor","mapControls","onToggleMapControl","onSetEditorMode","onToggleEditorVisibility","actionIcons","isActive","mapDraw","active","onToggleMenuPanel","show","position","EDITOR_MODES","EDIT","mode","DRAW_POLYGON","DRAW_RECTANGLE","e","preventDefault","displayName"],"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, {useCallback} from 'react';\nimport classnames from 'classnames';\n\nimport {EDITOR_MODES} from 'constants/default-settings';\nimport {\n  CursorClick,\n  DrawPolygon,\n  EyeSeen,\n  EyeUnseen,\n  Polygon,\n  Rectangle\n} from 'components/common/icons';\nimport {MapControlButton} from 'components/common/styled-components';\nimport ToolbarItem from 'components/common/toolbar-item';\nimport MapControlTooltipFactory from './map-control-tooltip';\nimport MapControlPanelFactory from './map-control-panel';\nimport MapControlToolbarFactory from './map-control-toolbar';\n\nMapDrawPanelFactory.deps = [\n  MapControlTooltipFactory,\n  MapControlPanelFactory,\n  MapControlToolbarFactory\n];\nfunction MapDrawPanelFactory(MapControlTooltip, MapControlPanel, MapControlToolbar) {\n  const defaultActionIcons = {\n    visible: EyeSeen,\n    hidden: EyeUnseen,\n    polygon: DrawPolygon,\n    cursor: CursorClick,\n    innerPolygon: Polygon,\n    rectangle: Rectangle\n  };\n  /** @type {import('./map-draw-panel').MapDrawPanelComponent} */\n  const MapDrawPanel = React.memo(\n    ({\n      editor,\n      mapControls,\n      onToggleMapControl,\n      onSetEditorMode,\n      onToggleEditorVisibility,\n      actionIcons = defaultActionIcons\n    }) => {\n      const isActive = mapControls?.mapDraw?.active;\n      const onToggleMenuPanel = useCallback(() => onToggleMapControl('mapDraw'), [\n        onToggleMapControl\n      ]);\n      if (!mapControls?.mapDraw?.show) {\n        return null;\n      }\n      return (\n        <div className=\"map-draw-controls\" style={{position: 'relative'}}>\n          {isActive ? (\n            <MapControlToolbar show={isActive}>\n              <ToolbarItem\n                className=\"edit-feature\"\n                onClick={() => onSetEditorMode(EDITOR_MODES.EDIT)}\n                label=\"toolbar.select\"\n                icon={actionIcons.cursor}\n                active={editor.mode === EDITOR_MODES.EDIT}\n              />\n              <ToolbarItem\n                className=\"draw-feature\"\n                onClick={() => onSetEditorMode(EDITOR_MODES.DRAW_POLYGON)}\n                label=\"toolbar.polygon\"\n                icon={actionIcons.innerPolygon}\n                active={editor.mode === EDITOR_MODES.DRAW_POLYGON}\n              />\n              <ToolbarItem\n                className=\"draw-rectangle\"\n                onClick={() => onSetEditorMode(EDITOR_MODES.DRAW_RECTANGLE)}\n                label=\"toolbar.rectangle\"\n                icon={actionIcons.rectangle}\n                active={editor.mode === EDITOR_MODES.DRAW_RECTANGLE}\n              />\n              <ToolbarItem\n                className=\"toggle-features\"\n                onClick={onToggleEditorVisibility}\n                label={editor.visible ? 'toolbar.hide' : 'toolbar.show'}\n                icon={editor.visible ? actionIcons.visible : actionIcons.hidden}\n              />\n            </MapControlToolbar>\n          ) : null}\n          <MapControlButton\n            onClick={e => {\n              e.preventDefault();\n              onToggleMenuPanel();\n            }}\n            active={isActive}\n            className={classnames('map-control-button', 'map-draw', {isActive})}\n            data-tip\n            data-for=\"map-draw\"\n          >\n            <actionIcons.polygon height=\"22px\" />\n            <MapControlTooltip id=\"map-draw\" message=\"tooltip.DrawOnMap\" />\n          </MapControlButton>\n        </div>\n      );\n    }\n  );\n\n  MapDrawPanel.displayName = 'MapDrawPanel';\n  return MapDrawPanel;\n}\n\nexport default MapDrawPanelFactory;\n"]}