kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
186 lines (153 loc) • 23.8 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"] = MapPopoverFactory;
var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
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 _layerHoverInfo = _interopRequireDefault(require("./layer-hover-info"));
var _coordinateInfo = _interopRequireDefault(require("./coordinate-info"));
var _icons = require("../common/icons");
var _reactIntl = require("react-intl");
var _localization = require("../../localization");
var _headless = _interopRequireDefault(require("@tippyjs/react/headless"));
var _templateObject, _templateObject2, _templateObject3, _templateObject4;
var MAX_WIDTH = 500;
var MAX_HEIGHT = 600;
var StyledMapPopover = _styledComponents["default"].div(_templateObject || (_templateObject = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n max-width: ", "px;\n max-height: ", "px;\n padding: 14px;\n & > * + * {\n margin-top: 6px;\n }\n ", ";\n font-family: ", ";\n font-size: 11px;\n font-weight: 500;\n background-color: ", ";\n color: ", ";\n z-index: 1000;\n overflow-x: auto;\n box-shadow: ", ";\n\n :hover {\n background-color: ", ";\n }\n\n .primary-label {\n color: ", ";\n font-size: 10px;\n }\n\n .map-popover__layer-info,\n .coordingate-hover-info {\n & > * + * {\n margin-top: 7px;\n }\n }\n\n table {\n width: auto;\n display: grid;\n border-collapse: collapse;\n row-gap: 5px;\n column-gap: 5px;\n }\n\n .coordingate-hover-info > table {\n grid-template-columns: auto auto auto;\n }\n .map-popover__layer-info > table {\n grid-template-columns: auto auto;\n }\n\n tbody,\n tr {\n display: contents;\n }\n\n td {\n border-color: transparent;\n color: ", ";\n }\n\n td.row__value {\n text-align: right;\n font-weight: 500;\n color: ", ";\n }\n"])), MAX_WIDTH, MAX_HEIGHT, function (props) {
return props.theme.scrollBar;
}, function (props) {
return props.theme.fontFamily;
}, function (props) {
return props.theme.panelBackground;
}, function (props) {
return props.theme.textColor;
}, function (props) {
return props.theme.panelBoxShadow;
}, function (props) {
return "".concat(props.theme.panelBackground, "dd");
}, function (props) {
return props.theme.notificationColors.success;
}, function (props) {
return props.theme.textColor;
}, function (props) {
return props.theme.textColorHl;
});
var PinnedButtons = _styledComponents["default"].div(_templateObject2 || (_templateObject2 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n align-self: center;\n align-items: center;\n justify-items: center;\n & > * + * {\n margin-left: 10px;\n }\n"])));
var PopoverContent = _styledComponents["default"].div(_templateObject3 || (_templateObject3 = (0, _taggedTemplateLiteral2["default"])(["\n display: flex;\n flex-direction: column;\n & > * + * {\n margin-top: 12px;\n }\n"])));
var StyledIcon = _styledComponents["default"].div(_templateObject4 || (_templateObject4 = (0, _taggedTemplateLiteral2["default"])(["\n color: ", ";\n\n &.popover-pin {\n transform: rotate(30deg);\n }\n\n :hover {\n cursor: pointer;\n color: ", ";\n }\n"])), function (props) {
return props.theme.activeColor;
}, function (props) {
return props.theme.linkBtnColor;
});
MapPopoverFactory.deps = [_layerHoverInfo["default"], _coordinateInfo["default"]];
function createVirtualReference(container, x, y) {
var size = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 0;
var bounds = container && container.getBoundingClientRect ? container.getBoundingClientRect() : {};
var left = (bounds.left || 0) + x - size / 2;
var top = (bounds.top || 0) + y - size / 2;
return {
left: left,
top: top,
right: left + size,
bottom: top + size,
width: size,
height: size
};
}
function getOffsetForPlacement(_ref) {
var placement = _ref.placement,
reference = _ref.reference,
popper = _ref.popper;
var gap = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 20;
switch (placement) {
case 'top-start':
case 'bottom-start':
return [gap, gap];
case 'top-end':
case 'bottom-end':
return [-gap, gap];
default:
return [0, 0];
}
}
function getPopperOptions(container) {
return {
modifiers: [{
name: 'preventOverflow',
options: {
boundary: container
}
}]
};
}
function MapPopoverFactory(LayerHoverInfo, CoordinateInfo) {
/** @type {typeof import('./map-popover').MapPopover} */
var MapPopover = function MapPopover(_ref2) {
var x = _ref2.x,
y = _ref2.y,
frozen = _ref2.frozen,
coordinate = _ref2.coordinate,
layerHoverProp = _ref2.layerHoverProp,
isBase = _ref2.isBase,
zoom = _ref2.zoom,
container = _ref2.container,
onClose = _ref2.onClose;
var _useState = (0, _react.useState)('start'),
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
horizontalPlacement = _useState2[0],
setHorizontalPlacement = _useState2[1];
var moveLeft = function moveLeft() {
return setHorizontalPlacement('end');
};
var moveRight = function moveRight() {
return setHorizontalPlacement('start');
};
return /*#__PURE__*/_react["default"].createElement(_headless["default"], {
popperOptions: getPopperOptions(container),
zIndex: 999
/* should be below Modal which has zIndex=1000 */
,
visible: true,
interactive: true,
getReferenceClientRect: function getReferenceClientRect() {
return createVirtualReference(container, x, y);
} // @ts-ignore
,
placement: "bottom-".concat(horizontalPlacement) // @ts-ignore
,
offset: getOffsetForPlacement,
appendTo: document.body,
render: function render(attrs) {
return /*#__PURE__*/_react["default"].createElement(StyledMapPopover, (0, _extends2["default"])({}, attrs, {
className: "map-popover"
}), frozen ? /*#__PURE__*/_react["default"].createElement(PinnedButtons, null, horizontalPlacement === 'start' && /*#__PURE__*/_react["default"].createElement(StyledIcon, {
className: "popover-arrow-left",
onClick: moveLeft
}, /*#__PURE__*/_react["default"].createElement(_icons.ArrowLeft, null)), /*#__PURE__*/_react["default"].createElement(StyledIcon, {
className: "popover-pin",
onClick: onClose
}, /*#__PURE__*/_react["default"].createElement(_icons.Pin, {
height: "16px"
})), horizontalPlacement === 'end' && /*#__PURE__*/_react["default"].createElement(StyledIcon, {
className: "popover-arrow-right",
onClick: moveRight
}, /*#__PURE__*/_react["default"].createElement(_icons.ArrowRight, null)), isBase && /*#__PURE__*/_react["default"].createElement("div", {
className: "primary-label"
}, /*#__PURE__*/_react["default"].createElement(_localization.FormattedMessage, {
id: "mapPopover.primary"
}))) : null, /*#__PURE__*/_react["default"].createElement(PopoverContent, null, Array.isArray(coordinate) && /*#__PURE__*/_react["default"].createElement(CoordinateInfo, {
coordinate: coordinate,
zoom: zoom
}), layerHoverProp && /*#__PURE__*/_react["default"].createElement(LayerHoverInfo, layerHoverProp)));
}
});
};
return (0, _reactIntl.injectIntl)(MapPopover);
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/components/map/map-popover.js"],"names":["MAX_WIDTH","MAX_HEIGHT","StyledMapPopover","styled","div","props","theme","scrollBar","fontFamily","panelBackground","textColor","panelBoxShadow","notificationColors","success","textColorHl","PinnedButtons","PopoverContent","StyledIcon","activeColor","linkBtnColor","MapPopoverFactory","deps","LayerHoverInfoFactory","CoordinateInfoFactory","createVirtualReference","container","x","y","size","bounds","getBoundingClientRect","left","top","right","bottom","width","height","getOffsetForPlacement","placement","reference","popper","gap","getPopperOptions","modifiers","name","options","boundary","LayerHoverInfo","CoordinateInfo","MapPopover","frozen","coordinate","layerHoverProp","isBase","zoom","onClose","horizontalPlacement","setHorizontalPlacement","moveLeft","moveRight","document","body","attrs","Array","isArray"],"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, {useState} from 'react';\nimport styled from 'styled-components';\nimport LayerHoverInfoFactory from './layer-hover-info';\nimport CoordinateInfoFactory from './coordinate-info';\nimport {ArrowLeft, ArrowRight, Pin} from 'components/common/icons';\nimport {injectIntl} from 'react-intl';\nimport {FormattedMessage} from 'localization';\nimport Tippy from '@tippyjs/react/headless';\n\nconst MAX_WIDTH = 500;\nconst MAX_HEIGHT = 600;\n\nconst StyledMapPopover = styled.div`\n  display: flex;\n  flex-direction: column;\n  max-width: ${MAX_WIDTH}px;\n  max-height: ${MAX_HEIGHT}px;\n  padding: 14px;\n  & > * + * {\n    margin-top: 6px;\n  }\n  ${props => props.theme.scrollBar};\n  font-family: ${props => props.theme.fontFamily};\n  font-size: 11px;\n  font-weight: 500;\n  background-color: ${props => props.theme.panelBackground};\n  color: ${props => props.theme.textColor};\n  z-index: 1000;\n  overflow-x: auto;\n  box-shadow: ${props => props.theme.panelBoxShadow};\n\n  :hover {\n    background-color: ${props => `${props.theme.panelBackground}dd`};\n  }\n\n  .primary-label {\n    color: ${props => props.theme.notificationColors.success};\n    font-size: 10px;\n  }\n\n  .map-popover__layer-info,\n  .coordingate-hover-info {\n    & > * + * {\n      margin-top: 7px;\n    }\n  }\n\n  table {\n    width: auto;\n    display: grid;\n    border-collapse: collapse;\n    row-gap: 5px;\n    column-gap: 5px;\n  }\n\n  .coordingate-hover-info > table {\n    grid-template-columns: auto auto auto;\n  }\n  .map-popover__layer-info > table {\n    grid-template-columns: auto auto;\n  }\n\n  tbody,\n  tr {\n    display: contents;\n  }\n\n  td {\n    border-color: transparent;\n    color: ${props => props.theme.textColor};\n  }\n\n  td.row__value {\n    text-align: right;\n    font-weight: 500;\n    color: ${props => props.theme.textColorHl};\n  }\n`;\n\nconst PinnedButtons = styled.div`\n  display: flex;\n  align-self: center;\n  align-items: center;\n  justify-items: center;\n  & > * + * {\n    margin-left: 10px;\n  }\n`;\n\nconst PopoverContent = styled.div`\n  display: flex;\n  flex-direction: column;\n  & > * + * {\n    margin-top: 12px;\n  }\n`;\n\nconst StyledIcon = styled.div`\n  color: ${props => props.theme.activeColor};\n\n  &.popover-pin {\n    transform: rotate(30deg);\n  }\n\n  :hover {\n    cursor: pointer;\n    color: ${props => props.theme.linkBtnColor};\n  }\n`;\n\nMapPopoverFactory.deps = [LayerHoverInfoFactory, CoordinateInfoFactory];\n\nfunction createVirtualReference(container, x, y, size = 0) {\n  const bounds =\n    container && container.getBoundingClientRect ? container.getBoundingClientRect() : {};\n  const left = (bounds.left || 0) + x - size / 2;\n  const top = (bounds.top || 0) + y - size / 2;\n  return {\n    left,\n    top,\n    right: left + size,\n    bottom: top + size,\n    width: size,\n    height: size\n  };\n}\n\nfunction getOffsetForPlacement({placement, reference, popper}, gap = 20) {\n  switch (placement) {\n    case 'top-start':\n    case 'bottom-start':\n      return [gap, gap];\n    case 'top-end':\n    case 'bottom-end':\n      return [-gap, gap];\n    default:\n      return [0, 0];\n  }\n}\n\nfunction getPopperOptions(container) {\n  return {\n    modifiers: [\n      {\n        name: 'preventOverflow',\n        options: {\n          boundary: container\n        }\n      }\n    ]\n  };\n}\n\nexport default function MapPopoverFactory(LayerHoverInfo, CoordinateInfo) {\n  /** @type {typeof import('./map-popover').MapPopover} */\n  const MapPopover = ({\n    x,\n    y,\n    frozen,\n    coordinate,\n    layerHoverProp,\n    isBase,\n    zoom,\n    container,\n    onClose\n  }) => {\n    const [horizontalPlacement, setHorizontalPlacement] = useState('start');\n    const moveLeft = () => setHorizontalPlacement('end');\n    const moveRight = () => setHorizontalPlacement('start');\n    return (\n      <Tippy\n        popperOptions={getPopperOptions(container)}\n        zIndex={999} /* should be below Modal which has zIndex=1000 */\n        visible={true}\n        interactive={true}\n        getReferenceClientRect={() => createVirtualReference(container, x, y)}\n        // @ts-ignore\n        placement={`bottom-${horizontalPlacement}`}\n        // @ts-ignore\n        offset={getOffsetForPlacement}\n        appendTo={document.body}\n        render={attrs => (\n          <StyledMapPopover {...attrs} className=\"map-popover\">\n            {frozen ? (\n              <PinnedButtons>\n                {horizontalPlacement === 'start' && (\n                  <StyledIcon className=\"popover-arrow-left\" onClick={moveLeft}>\n                    <ArrowLeft />\n                  </StyledIcon>\n                )}\n                <StyledIcon className=\"popover-pin\" onClick={onClose}>\n                  <Pin height=\"16px\" />\n                </StyledIcon>\n                {horizontalPlacement === 'end' && (\n                  <StyledIcon className=\"popover-arrow-right\" onClick={moveRight}>\n                    <ArrowRight />\n                  </StyledIcon>\n                )}\n                {isBase && (\n                  <div className=\"primary-label\">\n                    <FormattedMessage id=\"mapPopover.primary\" />\n                  </div>\n                )}\n              </PinnedButtons>\n            ) : null}\n            <PopoverContent>\n              {Array.isArray(coordinate) && <CoordinateInfo coordinate={coordinate} zoom={zoom} />}\n              {layerHoverProp && <LayerHoverInfo {...layerHoverProp} />}\n            </PopoverContent>\n          </StyledMapPopover>\n        )}\n      />\n    );\n  };\n  return injectIntl(MapPopover);\n}\n"]}