kepler.gl
Version:
kepler.gl is a webgl based application to visualize large scale location data in the browser
246 lines (236 loc) • 30.5 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.getCursor = getCursor;
exports.getTooltip = getTooltip;
exports.isDrawingActive = isDrawingActive;
exports.onClick = onClick;
exports.onHover = onHover;
var _constants = require("@kepler.gl/constants");
// SPDX-License-Identifier: MIT
// Copyright contributors to the kepler.gl project
/**
* Returns true if drawing is active.
* @param editorMenuActive Indicates whether the editor side menu is active.
* @param mode Current editing mode.
* @returs Returns true if drawing is active.
*/
function isDrawingActive(editorMenuActive, mode) {
return editorMenuActive && (mode === _constants.EDITOR_MODES.DRAW_POLYGON || mode === _constants.EDITOR_MODES.DRAW_RECTANGLE);
}
/**
* Handles click event for Editor layer.
* @param info Information about clicked object.
* @param event Event object.
* @param params
* @param params.editorMenuActive
* @param params.editor
* @param params.onLayerClick
* @param params.setSelectedFeature
* @param params.mapIndex
* @returns Returns true is the click is handled.
*/
// eslint-disable-next-line complexity
function onClick(info, event, _ref) {
var _info$layer;
var editorMenuActive = _ref.editorMenuActive,
editor = _ref.editor,
setSelectedFeature = _ref.setSelectedFeature,
onLayerClick = _ref.onLayerClick,
_ref$mapIndex = _ref.mapIndex,
mapIndex = _ref$mapIndex === void 0 ? 0 : _ref$mapIndex;
var drawingActive = isDrawingActive(editorMenuActive, editor.mode);
if ((info === null || info === void 0 || (_info$layer = info.layer) === null || _info$layer === void 0 ? void 0 : _info$layer.id) === _constants.EDITOR_LAYER_ID && info !== null && info !== void 0 && info.object) {
var _info$object$geometry;
var objectType = (_info$object$geometry = info.object.geometry) === null || _info$object$geometry === void 0 ? void 0 : _info$object$geometry.type;
if (drawingActive) {
if (editor.selectedFeature) {
setSelectedFeature(null);
}
} else if (objectType !== null && objectType !== void 0 && objectType.endsWith('Polygon') || objectType !== null && objectType !== void 0 && objectType.endsWith('Point')) {
var _event$srcEvent;
var clickContext;
if (event.rightButton && Array.isArray((_event$srcEvent = event.srcEvent) === null || _event$srcEvent === void 0 ? void 0 : _event$srcEvent.point)) {
var point = event.srcEvent.point;
clickContext = {
mapIndex: mapIndex,
rightClick: true,
position: {
x: point[0],
y: point[1]
}
};
}
if (objectType !== null && objectType !== void 0 && objectType.endsWith('Polygon')) {
setSelectedFeature(info.object, clickContext);
} else {
// don't select points
setSelectedFeature(editor.selectedFeature, clickContext);
}
}
// hide tooltips from regular data layers
onLayerClick(null, event);
} else if (drawingActive) {
// prevent interaction with other layers
onLayerClick(null, event);
} else {
if (editor.selectedFeature) {
if (event.rightButton) {
return true;
}
// click outside removes selection
setSelectedFeature(null);
}
return false;
}
return true;
}
/**
* Handles hover event for Editor layer.
* @param info Information about hovered object.
* @param params
* @param params.editorMenuActive
* @param params.editor
* @param params.hoverInfo
* @returns Returns true is hover is handled.
*/
function onHover(info, _ref2) {
var _info$layer2, _hoverInfo$layer;
var hoverInfo = _ref2.hoverInfo,
editor = _ref2.editor,
editorMenuActive = _ref2.editorMenuActive;
if (isDrawingActive(editorMenuActive, editor.mode)) {
return true;
}
return (info === null || info === void 0 || (_info$layer2 = info.layer) === null || _info$layer2 === void 0 ? void 0 : _info$layer2.id) === _constants.EDITOR_LAYER_ID && (hoverInfo === null || hoverInfo === void 0 || (_hoverInfo$layer = hoverInfo.layer) === null || _hoverInfo$layer === void 0 ? void 0 : _hoverInfo$layer.id) === _constants.EDITOR_LAYER_ID;
}
/**
* For small tooltips with short messages, e.g. "Drag to move the point",
* use the values below to decide when to position a tooltip to the left
* of the cursor or above the cursor, depending on proximity to the edge of
* the viewport to prevent the tooltip from being cut off.
*/
var MIN_DISTANCE_TO_LEFT_EDGE = 200;
var MIN_DISTANCE_TO_BOTTOM_EDGE = 100;
/**
* Returns tooltip based on interactions with Editor layer.
* @param info Information about hovered object.
* @param params
* @param params.editorMenuActive
* @param params.editor
* @param params.theme
* @raturns Returns a tooltip object compatible with Deck.getTooltip()
*/
// eslint-disable-next-line complexity
function getTooltip(
// TODO PickInfo type in deck typings doesn't include viewport and pixel
info, _ref3) {
var _editor$selectionCont;
var editor = _ref3.editor,
theme = _ref3.theme,
editorMenuActive = _ref3.editorMenuActive;
var object = info.object,
layer = info.layer,
_info$viewport = info.viewport,
viewport = _info$viewport === void 0 ? {} : _info$viewport,
_info$pixel = info.pixel,
pixel = _info$pixel === void 0 ? [] : _info$pixel;
var closeToLeftEdge = (viewport === null || viewport === void 0 ? void 0 : viewport.width) - pixel[0] < MIN_DISTANCE_TO_LEFT_EDGE;
var closeToBottomEdge = (viewport === null || viewport === void 0 ? void 0 : viewport.height) - pixel[1] < MIN_DISTANCE_TO_BOTTOM_EDGE;
// don't show the tooltip when the menu is visible
if ((_editor$selectionCont = editor.selectionContext) !== null && _editor$selectionCont !== void 0 && _editor$selectionCont.rightClick) {
return null;
}
if (isDrawingActive(editorMenuActive, editor.mode)) {
var _layer$state;
// TODO save interaction state in editor object
if (layer !== null && layer !== void 0 && (_layer$state = layer.state) !== null && _layer$state !== void 0 && (_layer$state = _layer$state.mode) !== null && _layer$state !== void 0 && (_layer$state = _layer$state._clickSequence) !== null && _layer$state !== void 0 && _layer$state.length) {
return null;
}
return getTooltipObject('Click to start new feature', theme, {
leftOfCursor: closeToLeftEdge,
aboveCursor: closeToBottomEdge
});
}
if ((layer === null || layer === void 0 ? void 0 : layer.id) === _constants.EDITOR_LAYER_ID) {
var _object$properties, _object$geometry, _object$properties2;
var selectedFeature = editor.selectedFeature;
if (selectedFeature) {
if (!object || object.id && object.id === selectedFeature.id) {
return getTooltipObject('Right click to view options\nDrag to move the feature', theme, {
leftOfCursor: closeToLeftEdge,
aboveCursor: closeToBottomEdge
});
}
}
if ((object === null || object === void 0 || (_object$properties = object.properties) === null || _object$properties === void 0 ? void 0 : _object$properties.editHandleType) === 'intermediate') {
return getTooltipObject('Click to insert a point', theme, {
leftOfCursor: closeToLeftEdge,
aboveCursor: closeToBottomEdge
});
}
if ((object === null || object === void 0 || (_object$geometry = object.geometry) === null || _object$geometry === void 0 ? void 0 : _object$geometry.type) === 'Point' || (object === null || object === void 0 || (_object$properties2 = object.properties) === null || _object$properties2 === void 0 ? void 0 : _object$properties2.guideType) === 'tentative') {
return getTooltipObject('Drag to move the point', theme, {
leftOfCursor: closeToLeftEdge,
aboveCursor: closeToBottomEdge
});
}
return getTooltipObject('Click to select the feature\nRight click to view options', theme, {
leftOfCursor: closeToLeftEdge,
aboveCursor: closeToBottomEdge
});
}
return null;
}
/**
* Returns cursor type based on interactions with Editor layer.
* @param params
* @param params.editorMenuActive
* @param params.editor
* @param params.hoverInfo
* @returns Returns cursor type.
*/
function getCursor(_ref4) {
var _hoverInfo$layer2;
var editorMenuActive = _ref4.editorMenuActive,
editor = _ref4.editor,
hoverInfo = _ref4.hoverInfo;
if (isDrawingActive(editorMenuActive, editor.mode)) {
return 'crosshair';
}
if ((hoverInfo === null || hoverInfo === void 0 || (_hoverInfo$layer2 = hoverInfo.layer) === null || _hoverInfo$layer2 === void 0 ? void 0 : _hoverInfo$layer2.id) === _constants.EDITOR_LAYER_ID && editor.selectedFeature) {
return 'move';
}
return null;
}
/**
* Returns a tooltip object that can be used as a Deck tooltip.
* Positioning can be modified if the cursor is close to the bottom or left edge of the viewport.
* @param text Text to show.
* @param theme Current theme.
* @param position.leftOfCursor Tooltip should display to the left of the cursor.
* @param position.aboveCursor Tooltip should display above cursor.
*/
function getTooltipObject(text, theme, position) {
var leftOfCursor = position.leftOfCursor,
aboveCursor = position.aboveCursor;
var marginTop = aboveCursor ? '-70px' : '15px';
var marginLeft = leftOfCursor ? '-200px' : '15px';
return {
text: text,
style: {
'margin-top': marginTop,
'margin-left': marginLeft,
'font-family': theme.fontFamily,
'font-size': theme.tooltipFontSize,
'font-weight': 400,
padding: '7px 18px',
'box-shadow': theme.tooltipBoxShadow,
'background-color': theme.tooltipBg,
color: theme.tooltipColor,
'border-radius': theme.primaryBtnRadius
}
};
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_constants","require","isDrawingActive","editorMenuActive","mode","EDITOR_MODES","DRAW_POLYGON","DRAW_RECTANGLE","onClick","info","event","_ref","_info$layer","editor","setSelectedFeature","onLayerClick","_ref$mapIndex","mapIndex","drawingActive","layer","id","EDITOR_LAYER_ID","object","_info$object$geometry","objectType","geometry","type","selectedFeature","endsWith","_event$srcEvent","clickContext","rightButton","Array","isArray","srcEvent","point","rightClick","position","x","y","onHover","_ref2","_info$layer2","_hoverInfo$layer","hoverInfo","MIN_DISTANCE_TO_LEFT_EDGE","MIN_DISTANCE_TO_BOTTOM_EDGE","getTooltip","_ref3","_editor$selectionCont","theme","_info$viewport","viewport","_info$pixel","pixel","closeToLeftEdge","width","closeToBottomEdge","height","selectionContext","_layer$state","state","_clickSequence","length","getTooltipObject","leftOfCursor","aboveCursor","_object$properties","_object$geometry","_object$properties2","properties","editHandleType","guideType","getCursor","_ref4","_hoverInfo$layer2","text","marginTop","marginLeft","style","fontFamily","tooltipFontSize","padding","tooltipBoxShadow","tooltipBg","color","tooltipColor","primaryBtnRadius"],"sources":["../../src/editor-layer/editor-layer-utils.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport {PickInfo} from '@deck.gl/core/lib/deck';\nimport {Editor, Feature, FeatureSelectionContext} from '@kepler.gl/types';\nimport {EDITOR_LAYER_ID, EDITOR_MODES} from '@kepler.gl/constants';\n\n/**\n * Returns true if drawing is active.\n * @param editorMenuActive Indicates whether the editor side menu is active.\n * @param mode Current editing mode.\n * @returs Returns true if drawing is active.\n */\nexport function isDrawingActive(editorMenuActive: boolean, mode: string): boolean {\n  return (\n    editorMenuActive && (mode === EDITOR_MODES.DRAW_POLYGON || mode === EDITOR_MODES.DRAW_RECTANGLE)\n  );\n}\n\n/**\n * Handles click event for Editor layer.\n * @param info Information about clicked object.\n * @param event Event object.\n * @param params\n * @param params.editorMenuActive\n * @param params.editor\n * @param params.onLayerClick\n * @param params.setSelectedFeature\n * @param params.mapIndex\n * @returns Returns true is the click is handled.\n */\n// eslint-disable-next-line complexity\nexport function onClick(\n  info: PickInfo<any>,\n  event: any,\n  {\n    editorMenuActive,\n    editor,\n    setSelectedFeature,\n    onLayerClick,\n    mapIndex = 0\n  }: {\n    editorMenuActive: boolean;\n    editor: Editor;\n    onLayerClick: (data, clickEvent) => any;\n    setSelectedFeature: (\n      feature: Feature | null,\n      selectionContext?: FeatureSelectionContext\n    ) => any;\n    mapIndex?: number;\n  }\n): boolean {\n  const drawingActive = isDrawingActive(editorMenuActive, editor.mode);\n\n  if (info?.layer?.id === EDITOR_LAYER_ID && info?.object) {\n    const objectType = info.object.geometry?.type;\n\n    if (drawingActive) {\n      if (editor.selectedFeature) {\n        setSelectedFeature(null);\n      }\n    } else if (objectType?.endsWith('Polygon') || objectType?.endsWith('Point')) {\n      let clickContext;\n      if (event.rightButton && Array.isArray(event.srcEvent?.point)) {\n        const {point} = event.srcEvent;\n        clickContext = {\n          mapIndex,\n          rightClick: true,\n          position: {\n            x: point[0],\n            y: point[1]\n          }\n        };\n      }\n\n      if (objectType?.endsWith('Polygon')) {\n        setSelectedFeature(info.object, clickContext);\n      } else {\n        // don't select points\n        setSelectedFeature(editor.selectedFeature, clickContext);\n      }\n    }\n    // hide tooltips from regular data layers\n    onLayerClick(null, event);\n  } else if (drawingActive) {\n    // prevent interaction with other layers\n    onLayerClick(null, event);\n  } else {\n    if (editor.selectedFeature) {\n      if (event.rightButton) {\n        return true;\n      }\n\n      // click outside removes selection\n      setSelectedFeature(null);\n    }\n\n    return false;\n  }\n  return true;\n}\n\n/**\n * Handles hover event for Editor layer.\n * @param info Information about hovered object.\n * @param params\n * @param params.editorMenuActive\n * @param params.editor\n * @param params.hoverInfo\n * @returns Returns true is hover is handled.\n */\nexport function onHover(\n  info: PickInfo<any>,\n  {hoverInfo, editor, editorMenuActive}: {editorMenuActive: boolean; editor: Editor; hoverInfo}\n): boolean {\n  if (isDrawingActive(editorMenuActive, editor.mode)) {\n    return true;\n  }\n\n  return info?.layer?.id === EDITOR_LAYER_ID && hoverInfo?.layer?.id === EDITOR_LAYER_ID;\n}\n\n/**\n * For small tooltips with short messages, e.g. \"Drag to move the point\",\n * use the values below to decide when to position a tooltip to the left\n * of the cursor or above the cursor, depending on proximity to the edge of\n * the viewport to prevent the tooltip from being cut off.\n */\nconst MIN_DISTANCE_TO_LEFT_EDGE = 200;\nconst MIN_DISTANCE_TO_BOTTOM_EDGE = 100;\n\n/**\n * Returns tooltip based on interactions with Editor layer.\n * @param info Information about hovered object.\n * @param params\n * @param params.editorMenuActive\n * @param params.editor\n * @param params.theme\n * @raturns Returns a tooltip object compatible with Deck.getTooltip()\n */\n// eslint-disable-next-line complexity\nexport function getTooltip(\n  // TODO PickInfo type in deck typings doesn't include viewport and pixel\n  info: PickInfo<any> & {viewport: any; pixel: any[]},\n  {editor, theme, editorMenuActive}: {editorMenuActive: boolean; editor: Editor; theme: any}\n): object | null {\n  const {object, layer, viewport = {}, pixel = []} = info;\n  const closeToLeftEdge = viewport?.width - pixel[0] < MIN_DISTANCE_TO_LEFT_EDGE;\n  const closeToBottomEdge = viewport?.height - pixel[1] < MIN_DISTANCE_TO_BOTTOM_EDGE;\n\n  // don't show the tooltip when the menu is visible\n  if (editor.selectionContext?.rightClick) {\n    return null;\n  }\n\n  if (isDrawingActive(editorMenuActive, editor.mode)) {\n    // TODO save interaction state in editor object\n    if (layer?.state?.mode?._clickSequence?.length) {\n      return null;\n    }\n\n    return getTooltipObject('Click to start new feature', theme, {\n      leftOfCursor: closeToLeftEdge,\n      aboveCursor: closeToBottomEdge\n    });\n  }\n\n  if (layer?.id === EDITOR_LAYER_ID) {\n    const {selectedFeature} = editor;\n\n    if (selectedFeature) {\n      if (!object || (object.id && object.id === selectedFeature.id)) {\n        return getTooltipObject('Right click to view options\\nDrag to move the feature', theme, {\n          leftOfCursor: closeToLeftEdge,\n          aboveCursor: closeToBottomEdge\n        });\n      }\n    }\n\n    if (object?.properties?.editHandleType === 'intermediate') {\n      return getTooltipObject('Click to insert a point', theme, {\n        leftOfCursor: closeToLeftEdge,\n        aboveCursor: closeToBottomEdge\n      });\n    }\n\n    if (object?.geometry?.type === 'Point' || object?.properties?.guideType === 'tentative') {\n      return getTooltipObject('Drag to move the point', theme, {\n        leftOfCursor: closeToLeftEdge,\n        aboveCursor: closeToBottomEdge\n      });\n    }\n\n    return getTooltipObject('Click to select the feature\\nRight click to view options', theme, {\n      leftOfCursor: closeToLeftEdge,\n      aboveCursor: closeToBottomEdge\n    });\n  }\n\n  return null;\n}\n\n/**\n * Returns cursor type based on interactions with Editor layer.\n * @param params\n * @param params.editorMenuActive\n * @param params.editor\n * @param params.hoverInfo\n * @returns Returns cursor type.\n */\nexport function getCursor({\n  editorMenuActive,\n  editor,\n  hoverInfo\n}: {\n  editorMenuActive: boolean;\n  editor: Editor;\n  hoverInfo: any;\n}): string | null {\n  if (isDrawingActive(editorMenuActive, editor.mode)) {\n    return 'crosshair';\n  }\n\n  if (hoverInfo?.layer?.id === EDITOR_LAYER_ID && editor.selectedFeature) {\n    return 'move';\n  }\n\n  return null;\n}\n\n/**\n * Returns a tooltip object that can be used as a Deck tooltip.\n * Positioning can be modified if the cursor is close to the bottom or left edge of the viewport.\n * @param text Text to show.\n * @param theme Current theme.\n * @param position.leftOfCursor Tooltip should display to the left of the cursor.\n * @param position.aboveCursor Tooltip should display above cursor.\n */\nfunction getTooltipObject(\n  text: string,\n  theme: any,\n  position: {leftOfCursor: boolean; aboveCursor: boolean}\n): {text: string; style: object} {\n  const {leftOfCursor, aboveCursor} = position;\n  const marginTop = aboveCursor ? '-70px' : '15px';\n  const marginLeft = leftOfCursor ? '-200px' : '15px';\n  return {\n    text,\n    style: {\n      'margin-top': marginTop,\n      'margin-left': marginLeft,\n      'font-family': theme.fontFamily,\n      'font-size': theme.tooltipFontSize,\n      'font-weight': 400,\n      padding: '7px 18px',\n      'box-shadow': theme.tooltipBoxShadow,\n      'background-color': theme.tooltipBg,\n      color: theme.tooltipColor,\n      'border-radius': theme.primaryBtnRadius\n    }\n  };\n}\n"],"mappings":"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","ignoreList":[]}