kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
98 lines (96 loc) • 16.7 kB
JavaScript
"use strict";
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 _react = _interopRequireWildcard(require("react"));
var _classnames = _interopRequireDefault(require("classnames"));
var _constants = require("@kepler.gl/constants");
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 _mapControlToolbar = _interopRequireDefault(require("./map-control-toolbar"));
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; }
// SPDX-License-Identifier: MIT
// Copyright contributors to the kepler.gl project
MapDrawPanelFactory.deps = [_mapControlTooltip["default"], _mapControlToolbar["default"]];
function MapDrawPanelFactory(MapControlTooltip, MapControlToolbar) {
var defaultActionIcons = {
visible: _icons.EyeSeen,
hidden: _icons.EyeUnseen,
polygon: _icons.DrawPolygon,
cursor: _icons.CursorClick,
innerPolygon: _icons.Polygon,
rectangle: _icons.Rectangle
};
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,
_ref$actionIcons = _ref.actionIcons,
actionIcons = _ref$actionIcons === void 0 ? defaultActionIcons : _ref$actionIcons;
var isActive = mapControls === null || mapControls === 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(_constants.EDITOR_MODES.EDIT);
},
label: "toolbar.select",
icon: actionIcons.cursor,
active: editor.mode === _constants.EDITOR_MODES.EDIT
}), /*#__PURE__*/_react["default"].createElement(_toolbarItem["default"], {
className: "draw-feature",
onClick: function onClick() {
return onSetEditorMode(_constants.EDITOR_MODES.DRAW_POLYGON);
},
label: "toolbar.polygon",
icon: actionIcons.innerPolygon,
active: editor.mode === _constants.EDITOR_MODES.DRAW_POLYGON
}), /*#__PURE__*/_react["default"].createElement(_toolbarItem["default"], {
className: "draw-rectangle",
onClick: function onClick() {
return onSetEditorMode(_constants.EDITOR_MODES.DRAW_RECTANGLE);
},
label: "toolbar.rectangle",
icon: actionIcons.rectangle,
active: editor.mode === _constants.EDITOR_MODES.DRAW_RECTANGLE
})) : null, /*#__PURE__*/_react["default"].createElement(MapControlTooltip, {
id: "map-draw",
message: "tooltip.DrawOnMap"
}, /*#__PURE__*/_react["default"].createElement(_styledComponents.MapControlButton, {
className: (0, _classnames["default"])('map-control-button', 'map-draw', {
isActive: isActive
}),
onClick: function onClick(e) {
e.preventDefault();
onToggleMenuPanel();
},
active: isActive
}, /*#__PURE__*/_react["default"].createElement(actionIcons.polygon, {
height: "22px"
}))));
});
MapDrawPanel.displayName = 'MapDrawPanel';
return MapDrawPanel;
}
var _default = exports["default"] = MapDrawPanelFactory;
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_classnames","_interopRequireDefault","_constants","_icons","_styledComponents","_toolbarItem","_mapControlTooltip","_mapControlToolbar","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","MapDrawPanelFactory","deps","MapControlTooltipFactory","MapControlToolbarFactory","MapControlTooltip","MapControlToolbar","defaultActionIcons","visible","EyeSeen","hidden","EyeUnseen","polygon","DrawPolygon","cursor","CursorClick","innerPolygon","Polygon","rectangle","Rectangle","MapDrawPanel","React","memo","_ref","_mapControls$mapDraw","_mapControls$mapDraw2","editor","mapControls","onToggleMapControl","onSetEditorMode","_ref$actionIcons","actionIcons","isActive","mapDraw","active","onToggleMenuPanel","useCallback","show","createElement","className","style","position","onClick","EDITOR_MODES","EDIT","label","icon","mode","DRAW_POLYGON","DRAW_RECTANGLE","id","message","MapControlButton","classnames","preventDefault","height","displayName","_default","exports"],"sources":["../../src/map/map-draw-panel.tsx"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport React, {useCallback} from 'react';\nimport classnames from 'classnames';\n\nimport {EDITOR_MODES} from '@kepler.gl/constants';\nimport {CursorClick, DrawPolygon, EyeSeen, EyeUnseen, Polygon, Rectangle} from '../common/icons';\nimport {MapControlButton} from '../common/styled-components';\nimport ToolbarItem from '../common/toolbar-item';\nimport MapControlTooltipFactory from './map-control-tooltip';\nimport MapControlToolbarFactory from './map-control-toolbar';\nimport {Editor, MapControls} from '@kepler.gl/types';\nimport {BaseProps} from '../common/icons';\n\nMapDrawPanelFactory.deps = [MapControlTooltipFactory, MapControlToolbarFactory];\n\nexport type MapDrawPanelProps = {\n  editor: Editor;\n  mapControls: MapControls;\n  onToggleMapControl: (control: string) => void;\n  onSetEditorMode: (mode: string) => void;\n  onToggleEditorVisibility: () => void;\n  actionIcons: {[id: string]: React.ComponentType<Partial<BaseProps>>};\n};\n\nfunction MapDrawPanelFactory(\n  MapControlTooltip: ReturnType<typeof MapControlTooltipFactory>,\n  MapControlToolbar: ReturnType<typeof MapControlToolbarFactory>\n) {\n  const defaultActionIcons = {\n    visible: EyeSeen,\n    hidden: EyeUnseen,\n    polygon: DrawPolygon,\n    cursor: CursorClick,\n    innerPolygon: Polygon,\n    rectangle: Rectangle\n  };\n\n  const MapDrawPanel: React.FC<MapDrawPanelProps> = React.memo(\n    ({\n      editor,\n      mapControls,\n      onToggleMapControl,\n      onSetEditorMode,\n      actionIcons = defaultActionIcons\n    }) => {\n      const isActive = mapControls?.mapDraw?.active;\n      const onToggleMenuPanel = useCallback(\n        () => 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            </MapControlToolbar>\n          ) : null}\n          <MapControlTooltip id=\"map-draw\" message=\"tooltip.DrawOnMap\">\n            <MapControlButton\n              className={classnames('map-control-button', 'map-draw', {isActive})}\n              onClick={e => {\n                e.preventDefault();\n                onToggleMenuPanel();\n              }}\n              active={isActive}\n            >\n              <actionIcons.polygon height=\"22px\" />\n            </MapControlButton>\n          </MapControlTooltip>\n        </div>\n      );\n    }\n  );\n\n  MapDrawPanel.displayName = 'MapDrawPanel';\n  return MapDrawPanel;\n}\n\nexport default MapDrawPanelFactory;\n"],"mappings":"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","ignoreList":[]}