UNPKG

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