UNPKG

kepler.gl

Version:

kepler.gl is a webgl based application to visualize large scale location data in the browser

140 lines (139 loc) 29.1 kB
"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 _taggedTemplateLiteral2 = _interopRequireDefault(require("@babel/runtime/helpers/taggedTemplateLiteral")); var _react = _interopRequireWildcard(require("react")); var _styledComponents = _interopRequireDefault(require("styled-components")); var _localization = require("@kepler.gl/localization"); var _styledComponents2 = require("../common/styled-components"); var _icons = require("../common/icons"); var _switch = _interopRequireDefault(require("../common/switch")); var _classnames = _interopRequireDefault(require("classnames")); var _templateObject, _templateObject2, _templateObject3, _templateObject4, _templateObject5, _templateObject6, _templateObject7, _templateObject8; // 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; } var StyledMapControlPanel = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n background-color: ", ";\n flex-grow: 1;\n z-index: 1;\n p {\n margin-bottom: 0;\n }\n"])), function (props) { return props.theme.mapPanelBackgroundColor; }); var StyledMapControlPanelContent = _styledComponents["default"].div.attrs({ className: 'map-control__panel-content' })(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n ", ";\n max-height: 500px;\n min-height: 100px;\n min-width: ", "px;\n overflow: ", ";\n"])), function (props) { return props.theme.sidePanelScrollBar; }, function (props) { return props.theme.mapControl.width; }, function (props) { return props.isExport ? 'hidden' : 'overlay'; }); var StyledMapControlPanelHeader = _styledComponents["default"].div.attrs({ className: 'map-control__panel-header' })(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n justify-content: space-between;\n background-color: ", ";\n height: 32px;\n padding: 6px 12px;\n font-family: ", ";\n font-size: 11px;\n color: ", ";\n position: relative;\n box-sizing: border-box;\n align-items: center;\n\n button {\n width: 18px;\n height: 18px;\n }\n"])), function (props) { return props.theme.mapPanelHeaderBackgroundColor; }, function (props) { return props.theme.fontFamily; }, function (props) { return props.theme.titleTextColor; }); var StyledMapControlPanelHeaderSplitViewportsTools = (0, _styledComponents["default"])(StyledMapControlPanelHeader).attrs({ className: 'map-control__panel-split-viewport-tools' })(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n justify-content: space-between;\n align-items: self-start;\n height: unset;\n"]))); var StyledSBCenterFlexbox = (0, _styledComponents["default"])(_styledComponents2.CenterFlexbox)(_templateObject5 || (_templateObject5 = (0, _taggedTemplateLiteral2["default"])(["\n width: 100%;\n justify-content: space-between;\n flex-direction: row;\n"]))); var StyledDisableableText = _styledComponents["default"].span(_templateObject6 || (_templateObject6 = (0, _taggedTemplateLiteral2["default"])(["\n opacity: ", ";\n pointer-events: ", ";\n"])), function (props) { return props.disabled ? 0.4 : 1; }, function (props) { return props.disabled ? 'none' : 'all'; }); var StyledDisableableSwitch = (0, _styledComponents["default"])(_switch["default"])(_templateObject7 || (_templateObject7 = (0, _taggedTemplateLiteral2["default"])(["\n opacity: ", ";\n pointer-events: ", ";\n"])), function (props) { return props.disabled ? 0.4 : 1; }, function (props) { return props.disabled ? 'none' : 'all'; }); var StyledIcon = (0, _styledComponents["default"])(_styledComponents2.IconRoundSmall)(_templateObject8 || (_templateObject8 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n background-color: transparent;\n\n &:hover {\n cursor: pointer;\n background-color: transparent;\n color: ", ";\n }\n"])), function (props) { return props.theme.activeColor; }, function (props) { return props.theme.floatingBtnActColor; }); function MapControlPanelFactory() { var MapControlPanel = /*#__PURE__*/_react["default"].memo(function (_ref) { var children = _ref.children, header = _ref.header, pinnable = _ref.pinnable, disableClose = _ref.disableClose, onPinClick = _ref.onPinClick, onClick = _ref.onClick, _ref$scale = _ref.scale, scale = _ref$scale === void 0 ? 1 : _ref$scale, isExport = _ref.isExport, logoComponent = _ref.logoComponent, mapState = _ref.mapState, onToggleSplitMapViewport = _ref.onToggleSplitMapViewport, isViewportUnsyncAllowed = _ref.isViewportUnsyncAllowed, _ref$className = _ref.className, className = _ref$className === void 0 ? 'map-control-panel' : _ref$className; var _ref2 = mapState || {}, isViewportSynced = _ref2.isViewportSynced, isZoomLocked = _ref2.isZoomLocked; var onUnlockViewportChange = (0, _react.useCallback)(function () { onToggleSplitMapViewport === null || onToggleSplitMapViewport === void 0 || onToggleSplitMapViewport({ isViewportSynced: !isViewportSynced }); }, [isViewportSynced, onToggleSplitMapViewport]); var onSyncZoomChange = (0, _react.useCallback)(function () { onToggleSplitMapViewport === null || onToggleSplitMapViewport === void 0 || onToggleSplitMapViewport({ isZoomLocked: !isZoomLocked }); }, [isZoomLocked, onToggleSplitMapViewport]); return /*#__PURE__*/_react["default"].createElement(StyledMapControlPanel, { style: { transform: "scale(".concat(scale, ")"), marginBottom: '8px !important' }, className: (0, _classnames["default"])('map-control-panel', className) }, mapState !== null && mapState !== void 0 && mapState.isSplit && isViewportUnsyncAllowed ? /*#__PURE__*/_react["default"].createElement(StyledMapControlPanelHeaderSplitViewportsTools, null, /*#__PURE__*/_react["default"].createElement(StyledSBCenterFlexbox, { style: { paddingBottom: '6px' } }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: "Unlock Viewport" }), /*#__PURE__*/_react["default"].createElement(StyledDisableableSwitch, { checked: !(mapState !== null && mapState !== void 0 && mapState.isViewportSynced), id: "unlock-viewport-toggle", onChange: onUnlockViewportChange })), /*#__PURE__*/_react["default"].createElement(StyledSBCenterFlexbox, null, /*#__PURE__*/_react["default"].createElement(StyledDisableableText, { disabled: mapState === null || mapState === void 0 ? void 0 : mapState.isViewportSynced }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: "Sync Zoom" })), /*#__PURE__*/_react["default"].createElement(StyledDisableableSwitch, { checked: mapState === null || mapState === void 0 ? void 0 : mapState.isZoomLocked, id: "sync-zoom-toggle", onChange: onSyncZoomChange, disabled: mapState === null || mapState === void 0 ? void 0 : mapState.isViewportSynced }))) : null, /*#__PURE__*/_react["default"].createElement(StyledMapControlPanelHeader, null, isExport && logoComponent ? logoComponent : header ? /*#__PURE__*/_react["default"].createElement("span", { style: { verticalAlign: 'middle' } }, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, { id: header })) : null, isExport ? null : /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, pinnable && /*#__PURE__*/_react["default"].createElement(StyledIcon, { className: "pin-map-control-item", onClick: onPinClick }, /*#__PURE__*/_react["default"].createElement(_icons.Pin, { height: "16px" })), disableClose ? null : /*#__PURE__*/_react["default"].createElement(StyledIcon, { className: "close-map-control-item", onClick: onClick }, /*#__PURE__*/_react["default"].createElement(_icons.Close, { height: "16px" })))), /*#__PURE__*/_react["default"].createElement(StyledMapControlPanelContent, { isExport: isExport }, children)); }); MapControlPanel.displayName = 'MapControlPanel'; return MapControlPanel; } var _default = exports["default"] = MapControlPanelFactory; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_styledComponents","_interopRequireDefault","_localization","_styledComponents2","_icons","_switch","_classnames","_templateObject","_templateObject2","_templateObject3","_templateObject4","_templateObject5","_templateObject6","_templateObject7","_templateObject8","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","_typeof","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","StyledMapControlPanel","styled","div","_taggedTemplateLiteral2","props","theme","mapPanelBackgroundColor","StyledMapControlPanelContent","attrs","className","sidePanelScrollBar","mapControl","width","isExport","StyledMapControlPanelHeader","mapPanelHeaderBackgroundColor","fontFamily","titleTextColor","StyledMapControlPanelHeaderSplitViewportsTools","StyledSBCenterFlexbox","CenterFlexbox","StyledDisableableText","span","disabled","StyledDisableableSwitch","Switch","StyledIcon","IconRoundSmall","activeColor","floatingBtnActColor","MapControlPanelFactory","MapControlPanel","React","memo","_ref","children","header","pinnable","disableClose","onPinClick","onClick","_ref$scale","scale","logoComponent","mapState","onToggleSplitMapViewport","isViewportUnsyncAllowed","_ref$className","_ref2","isViewportSynced","isZoomLocked","onUnlockViewportChange","useCallback","onSyncZoomChange","createElement","style","transform","concat","marginBottom","classNames","isSplit","paddingBottom","FormattedMessage","id","checked","onChange","verticalAlign","Fragment","Pin","height","Close","displayName","_default","exports"],"sources":["../../src/map/map-control-panel.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 {FormattedMessage} from '@kepler.gl/localization';\nimport {CenterFlexbox, IconRoundSmall} from '../common/styled-components';\nimport {Close, Pin} from '../common/icons';\nimport Switch from '../common/switch';\nimport {MapState} from '@kepler.gl/types';\nimport {ActionHandler, toggleSplitMapViewport} from '@kepler.gl/actions';\nimport classNames from 'classnames';\n\nconst StyledMapControlPanel = styled.div`\n  background-color: ${props => props.theme.mapPanelBackgroundColor};\n  flex-grow: 1;\n  z-index: 1;\n  p {\n    margin-bottom: 0;\n  }\n`;\n\ntype StyledMapControlPanelContentProps = {\n  isExport?: boolean;\n};\n\nconst StyledMapControlPanelContent = styled.div.attrs({\n  className: 'map-control__panel-content'\n})<StyledMapControlPanelContentProps>`\n  ${props => props.theme.sidePanelScrollBar};\n  max-height: 500px;\n  min-height: 100px;\n  min-width: ${props => props.theme.mapControl.width}px;\n  overflow: ${props => (props.isExport ? 'hidden' : 'overlay')};\n`;\n\ntype MapControlPanelHeaderProps = {\n  children?: React.ReactNode[];\n};\n\nconst StyledMapControlPanelHeader = styled.div.attrs({\n  className: 'map-control__panel-header'\n})<MapControlPanelHeaderProps>`\n  display: flex;\n  justify-content: space-between;\n  background-color: ${props => props.theme.mapPanelHeaderBackgroundColor};\n  height: 32px;\n  padding: 6px 12px;\n  font-family: ${props => props.theme.fontFamily};\n  font-size: 11px;\n  color: ${props => props.theme.titleTextColor};\n  position: relative;\n  box-sizing: border-box;\n  align-items: center;\n\n  button {\n    width: 18px;\n    height: 18px;\n  }\n`;\n\nconst StyledMapControlPanelHeaderSplitViewportsTools = styled(StyledMapControlPanelHeader).attrs({\n  className: 'map-control__panel-split-viewport-tools'\n})`\n  display: flex;\n  flex-direction: column;\n  justify-content: space-between;\n  align-items: self-start;\n  height: unset;\n`;\n\nconst StyledSBCenterFlexbox = styled(CenterFlexbox)`\n  width: 100%;\n  justify-content: space-between;\n  flex-direction: row;\n`;\n\ninterface StyledDisableableTextProps {\n  disabled?: boolean;\n}\n\nconst StyledDisableableText = styled.span<StyledDisableableTextProps>`\n  opacity: ${props => (props.disabled ? 0.4 : 1)};\n  pointer-events: ${props => (props.disabled ? 'none' : 'all')};\n`;\n\nconst StyledDisableableSwitch = styled(Switch)`\n  opacity: ${props => (props.disabled ? 0.4 : 1)};\n  pointer-events: ${props => (props.disabled ? 'none' : 'all')};\n`;\n\nconst StyledIcon = styled(IconRoundSmall)`\n  color: ${props => props.theme.activeColor};\n  background-color: transparent;\n\n  &:hover {\n    cursor: pointer;\n    background-color: transparent;\n    color: ${props => props.theme.floatingBtnActColor};\n  }\n`;\n\nexport type MapControlPanelProps = {\n  header?: string;\n  scale?: number;\n  onClick?: React.MouseEventHandler<HTMLDivElement>;\n  onPinClick?: React.MouseEventHandler<HTMLDivElement>;\n  pinnable?: boolean;\n  disableClose?: boolean;\n  isExport?: boolean;\n  logoComponent?: Element;\n  mapState?: MapState;\n  onToggleSplitMapViewport?: ActionHandler<typeof toggleSplitMapViewport>;\n  isViewportUnsyncAllowed?: boolean;\n  children?: React.ReactNode;\n  className?: string;\n};\n\nfunction MapControlPanelFactory() {\n  const MapControlPanel: React.FC<MapControlPanelProps> = React.memo(\n    ({\n      children,\n      header,\n      pinnable,\n      disableClose,\n      onPinClick,\n      onClick,\n      scale = 1,\n      isExport,\n      logoComponent,\n      mapState,\n      onToggleSplitMapViewport,\n      isViewportUnsyncAllowed,\n      className = 'map-control-panel'\n    }) => {\n      const {isViewportSynced, isZoomLocked} = mapState || {};\n      const onUnlockViewportChange = useCallback(() => {\n        onToggleSplitMapViewport?.({isViewportSynced: !isViewportSynced});\n      }, [isViewportSynced, onToggleSplitMapViewport]);\n\n      const onSyncZoomChange = useCallback(() => {\n        onToggleSplitMapViewport?.({isZoomLocked: !isZoomLocked});\n      }, [isZoomLocked, onToggleSplitMapViewport]);\n\n      return (\n        <StyledMapControlPanel\n          style={{\n            transform: `scale(${scale})`,\n            marginBottom: '8px !important'\n          }}\n          className={classNames('map-control-panel', className)}\n        >\n          {mapState?.isSplit && isViewportUnsyncAllowed ? (\n            <StyledMapControlPanelHeaderSplitViewportsTools>\n              <StyledSBCenterFlexbox style={{paddingBottom: '6px'}}>\n                <FormattedMessage id=\"Unlock Viewport\" />\n                <StyledDisableableSwitch\n                  checked={!mapState?.isViewportSynced}\n                  id=\"unlock-viewport-toggle\"\n                  onChange={onUnlockViewportChange}\n                />\n              </StyledSBCenterFlexbox>\n              <StyledSBCenterFlexbox>\n                <StyledDisableableText disabled={mapState?.isViewportSynced}>\n                  <FormattedMessage id=\"Sync Zoom\" />\n                </StyledDisableableText>\n                <StyledDisableableSwitch\n                  checked={mapState?.isZoomLocked}\n                  id=\"sync-zoom-toggle\"\n                  onChange={onSyncZoomChange}\n                  disabled={mapState?.isViewportSynced}\n                />\n              </StyledSBCenterFlexbox>\n            </StyledMapControlPanelHeaderSplitViewportsTools>\n          ) : null}\n\n          <StyledMapControlPanelHeader>\n            {\n              (isExport && logoComponent ? (\n                logoComponent\n              ) : header ? (\n                <span style={{verticalAlign: 'middle'}}>\n                  <FormattedMessage id={header} />\n                </span>\n              ) : null) as React.ReactNode\n            }\n            {isExport ? null : (\n              <>\n                {pinnable && (\n                  <StyledIcon className=\"pin-map-control-item\" onClick={onPinClick}>\n                    <Pin height=\"16px\" />\n                  </StyledIcon>\n                )}\n                {disableClose ? null : (\n                  <StyledIcon className=\"close-map-control-item\" onClick={onClick}>\n                    <Close height=\"16px\" />\n                  </StyledIcon>\n                )}\n              </>\n            )}\n          </StyledMapControlPanelHeader>\n          <StyledMapControlPanelContent isExport={isExport}>\n            {children}\n          </StyledMapControlPanelContent>\n        </StyledMapControlPanel>\n      );\n    }\n  );\n\n  MapControlPanel.displayName = 'MapControlPanel';\n\n  return MapControlPanel;\n}\n\nexport default MapControlPanelFactory;\n"],"mappings":"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","ignoreList":[]}