UNPKG

kepler.gl

Version:

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

246 lines (236 loc) 31.5 kB
"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 PickingInfo type in deck typings doesn't include viewport and pixel info, _ref3) { var _viewport$width, _pixel$, _viewport$height, _pixel$2, _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$width = viewport === null || viewport === void 0 ? void 0 : viewport.width) !== null && _viewport$width !== void 0 ? _viewport$width : 0) - ((_pixel$ = pixel === null || pixel === void 0 ? void 0 : pixel[0]) !== null && _pixel$ !== void 0 ? _pixel$ : 0) < MIN_DISTANCE_TO_LEFT_EDGE; var closeToBottomEdge = ((_viewport$height = viewport === null || viewport === void 0 ? void 0 : viewport.height) !== null && _viewport$height !== void 0 ? _viewport$height : 0) - ((_pixel$2 = pixel === null || pixel === void 0 ? void 0 : pixel[1]) !== null && _pixel$2 !== void 0 ? _pixel$2 : 0) < 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","_viewport$width","_pixel$","_viewport$height","_pixel$2","_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 {Editor, Feature, FeatureSelectionContext, PickInfo} 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,\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,\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 PickingInfo type in deck typings doesn't include viewport and pixel\n  info: PickInfo & {viewport: {width?: number; height?: number}; pixel: number[]},\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 ?? 0) - (pixel?.[0] ?? 0) < MIN_DISTANCE_TO_LEFT_EDGE;\n  const closeToBottomEdge =\n    (viewport?.height ?? 0) - (pixel?.[1] ?? 0) < 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 (\n      (layer?.state as {mode?: {_clickSequence?: unknown[]}} | undefined)?.mode?._clickSequence\n        ?.length\n    ) {\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":[]}