UNPKG

kepler.gl

Version:

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

153 lines (149 loc) 22.2 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.getEditorLayer = getEditorLayer; var _editableLayers = require("@deck.gl-community/editable-layers"); var _extensions = require("@deck.gl/extensions"); var _constants = require("@kepler.gl/constants"); var _commonUtils = require("@kepler.gl/common-utils"); var _constants2 = require("./constants"); var _featureStyles = require("./feature-styles"); var _modifyModeExtended = require("./modify-mode-extended"); var _editorLayerUtils = require("./editor-layer-utils"); // SPDX-License-Identifier: MIT // Copyright contributors to the kepler.gl project var DEFAULT_COMPOSITE_MODE = new _editableLayers.CompositeMode([new _editableLayers.TranslateMode(), new _modifyModeExtended.ModifyModeExtended()]); /** * Returns editable layer to edit polygon filters. * @param params * @param params.editorMenuActive Indicates whether the editor side menu is active. * @param params.editor * @param params.onSetFeatures A callback to set features. * @param params.setSelectedFeature A callback to set selected feature and selection context. * @param params.viewport Current viewport. * @param params.featureCollection Feature collection with an array of features * @param params.selectedFeatureIndexes An array with index of currently selected feature. */ function getEditorLayer(_ref) { var editorMenuActive = _ref.editorMenuActive, editor = _ref.editor, onSetFeatures = _ref.onSetFeatures, setSelectedFeature = _ref.setSelectedFeature, featureCollection = _ref.featureCollection, selectedFeatureIndexes = _ref.selectedFeatureIndexes, viewport = _ref.viewport; var editorMode = editor.mode; var mode = DEFAULT_COMPOSITE_MODE; if (editorMenuActive) { // @ts-ignore if (editorMode === _constants.EDITOR_MODES.DRAW_POLYGON) mode = _editableLayers.DrawPolygonMode; // @ts-ignore else if (editorMode === _constants.EDITOR_MODES.DRAW_RECTANGLE) mode = _editableLayers.DrawRectangleMode; } // @ts-ignore return new _editableLayers.EditableGeoJsonLayer({ id: _constants.EDITOR_LAYER_ID, mode: mode, // @ts-ignore data: featureCollection, selectedFeatureIndexes: selectedFeatureIndexes, visible: editor.visible, pickable: true, pickingRadius: _constants.EDITOR_LAYER_PICKING_RADIUS, modeConfig: { viewport: viewport, screenSpace: true, lockRectangles: true }, pickingLineWidthExtraPixels: 5, // Only show fill when polygons are selected, // there is no way atm to enable fill for only one feature filled: selectedFeatureIndexes.length > 0, onEdit: function onEdit(_ref2) { var updatedData = _ref2.updatedData, editType = _ref2.editType; switch (editType) { case _constants2.EDIT_TYPES.ADD_FEATURE: { var _features = updatedData.features; if (_features.length) { var lastFeature = _features[_features.length - 1]; if (lastFeature.properties) lastFeature.properties.isClosed = true; lastFeature.id = (0, _commonUtils.generateHashId)(6); onSetFeatures(updatedData.features); setSelectedFeature(lastFeature); } break; } case _constants2.EDIT_TYPES.ADD_POSITION: case _constants2.EDIT_TYPES.MOVE_POSITION: case _constants2.EDIT_TYPES.TRANSLATING: onSetFeatures(updatedData.features); break; default: break; } }, // prevent self-highlights with tentative features autoHighlight: !(0, _editorLayerUtils.isDrawingActive)(editorMenuActive, editorMode), // @ts-ignore highlightColor: function highlightColor(info) { // Note: lines are reported as parent polygon var object = info.object; if (object) { var _editor$selectedFeatu; if (object.id === ((_editor$selectedFeatu = editor.selectedFeature) === null || _editor$selectedFeatu === void 0 ? void 0 : _editor$selectedFeatu.id)) { return _featureStyles.FEATURE_STYLE.highlightMultiplierNone; } var type = object.properties.editHandleType; if (type === 'intermediate') return _featureStyles.EDIT_HANDLE_STYLE.highlightMultiplierNone;else if (type === 'existing') return _featureStyles.EDIT_HANDLE_STYLE.highlightMultiplier; } // Note: highlight color affects even transparent filled polygons return selectedFeatureIndexes.length ? _featureStyles.FEATURE_STYLE.highlightMultiplier : _featureStyles.LINE_STYLE.highlightMultiplier; }, extensions: [new _extensions.PathStyleExtension({ dash: true })], dashGapPickable: true, getDashArray: function getDashArray(feature) { var _feature$properties, _editor$selectedFeatu2; if ((feature === null || feature === void 0 || (_feature$properties = feature.properties) === null || _feature$properties === void 0 ? void 0 : _feature$properties.guideType) === 'tentative') { return _featureStyles.LINE_STYLE.dashArray; } if ((feature === null || feature === void 0 ? void 0 : feature.id) === ((_editor$selectedFeatu2 = editor.selectedFeature) === null || _editor$selectedFeatu2 === void 0 ? void 0 : _editor$selectedFeatu2.id)) return _featureStyles.LINE_STYLE.solidArray; return _featureStyles.LINE_STYLE.dashArray; }, getLineColor: _featureStyles.LINE_STYLE.getColor, getFillColor: _featureStyles.FEATURE_STYLE.getColor, getRadius: _featureStyles.EDIT_HANDLE_STYLE.getRadius, // @ts-ignore getLineWidth: _featureStyles.LINE_STYLE.getWidth, getEditHandlePointRadius: _featureStyles.EDIT_HANDLE_STYLE.getRadius, getEditHandlePointColor: _featureStyles.EDIT_HANDLE_STYLE.getFillColor, getEditHandlePointOutlineColor: _featureStyles.EDIT_HANDLE_STYLE.getOutlineColor, getTentativeLineColor: _featureStyles.LINE_STYLE.getTentativeLineColor, // @ts-ignore getTentativeLineWidth: _featureStyles.LINE_STYLE.getTentativeLineWidth, getTentativeFillColor: _featureStyles.LINE_STYLE.getTentativeFillColor, parameters: {}, shadowEnabled: false, _subLayerProps: { geojson: { shadowEnabled: false }, guides: { shadowEnabled: false }, tooltips: { shadowEnabled: false, _subLayerProps: { characters: { shadowEnabled: false } } } } }); } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_editableLayers","require","_extensions","_constants","_commonUtils","_constants2","_featureStyles","_modifyModeExtended","_editorLayerUtils","DEFAULT_COMPOSITE_MODE","CompositeMode","TranslateMode","ModifyModeExtended","getEditorLayer","_ref","editorMenuActive","editor","onSetFeatures","setSelectedFeature","featureCollection","selectedFeatureIndexes","viewport","editorMode","mode","EDITOR_MODES","DRAW_POLYGON","DrawPolygonMode","DRAW_RECTANGLE","DrawRectangleMode","EditableGeoJsonLayer","id","EDITOR_LAYER_ID","data","visible","pickable","pickingRadius","EDITOR_LAYER_PICKING_RADIUS","modeConfig","screenSpace","lockRectangles","pickingLineWidthExtraPixels","filled","length","onEdit","_ref2","updatedData","editType","EDIT_TYPES","ADD_FEATURE","_features","features","lastFeature","properties","isClosed","generateHashId","ADD_POSITION","MOVE_POSITION","TRANSLATING","autoHighlight","isDrawingActive","highlightColor","info","object","_editor$selectedFeatu","selectedFeature","FEATURE_STYLE","highlightMultiplierNone","type","editHandleType","EDIT_HANDLE_STYLE","highlightMultiplier","LINE_STYLE","extensions","PathStyleExtension","dash","dashGapPickable","getDashArray","feature","_feature$properties","_editor$selectedFeatu2","guideType","dashArray","solidArray","getLineColor","getColor","getFillColor","getRadius","getLineWidth","getWidth","getEditHandlePointRadius","getEditHandlePointColor","getEditHandlePointOutlineColor","getOutlineColor","getTentativeLineColor","getTentativeLineWidth","getTentativeFillColor","parameters","shadowEnabled","_subLayerProps","geojson","guides","tooltips","characters"],"sources":["../../src/editor-layer/editor-layer.ts"],"sourcesContent":["// SPDX-License-Identifier: MIT\n// Copyright contributors to the kepler.gl project\n\nimport {EditableGeoJsonLayer} from '@deck.gl-community/editable-layers';\nimport {Layer as DeckLayer, LayerProps as DeckLayerProps} from '@deck.gl/core';\nimport {\n  DrawPolygonMode,\n  TranslateMode,\n  CompositeMode,\n  DrawRectangleMode,\n  GeoJsonEditMode\n} from '@deck.gl-community/editable-layers';\nimport {PathStyleExtension} from '@deck.gl/extensions';\n\nimport {EDITOR_LAYER_ID, EDITOR_MODES, EDITOR_LAYER_PICKING_RADIUS} from '@kepler.gl/constants';\nimport {Viewport, Editor, Feature, FeatureSelectionContext} from '@kepler.gl/types';\nimport {generateHashId} from '@kepler.gl/common-utils';\n\nimport {EDIT_TYPES} from './constants';\nimport {LINE_STYLE, FEATURE_STYLE, EDIT_HANDLE_STYLE} from './feature-styles';\nimport {ModifyModeExtended} from './modify-mode-extended';\nimport {isDrawingActive} from './editor-layer-utils';\n\nconst DEFAULT_COMPOSITE_MODE = new CompositeMode([\n  new TranslateMode() as unknown as GeoJsonEditMode,\n  new ModifyModeExtended() as unknown as GeoJsonEditMode\n]);\n\nexport type GetEditorLayerProps = {\n  editorMenuActive: boolean;\n  editor: Editor;\n  onSetFeatures: (features: Feature[]) => any;\n  setSelectedFeature: (feature: Feature | null, selectionContext?: FeatureSelectionContext) => any;\n  viewport: Viewport;\n  featureCollection: {\n    type: string;\n    features: Feature[];\n  };\n  selectedFeatureIndexes: number[];\n};\n\n/**\n * Returns editable layer to edit polygon filters.\n * @param params\n * @param params.editorMenuActive Indicates whether the editor side menu is active.\n * @param params.editor\n * @param params.onSetFeatures A callback to set features.\n * @param params.setSelectedFeature A callback to set selected feature and selection context.\n * @param params.viewport Current viewport.\n * @param params.featureCollection Feature collection with an array of features\n * @param params.selectedFeatureIndexes An array with index of currently selected feature.\n */\nexport function getEditorLayer({\n  editorMenuActive,\n  editor,\n  onSetFeatures,\n  setSelectedFeature,\n  featureCollection,\n  selectedFeatureIndexes,\n  viewport\n}: GetEditorLayerProps): DeckLayer<DeckLayerProps> {\n  const {mode: editorMode} = editor;\n\n  let mode = DEFAULT_COMPOSITE_MODE;\n  if (editorMenuActive) {\n    // @ts-ignore\n    if (editorMode === EDITOR_MODES.DRAW_POLYGON) mode = DrawPolygonMode;\n    // @ts-ignore\n    else if (editorMode === EDITOR_MODES.DRAW_RECTANGLE) mode = DrawRectangleMode;\n  }\n\n  // @ts-ignore\n  return new EditableGeoJsonLayer({\n    id: EDITOR_LAYER_ID,\n    mode,\n    // @ts-ignore\n    data: featureCollection,\n    selectedFeatureIndexes,\n    visible: editor.visible,\n    pickable: true,\n    pickingRadius: EDITOR_LAYER_PICKING_RADIUS,\n    modeConfig: {\n      viewport,\n      screenSpace: true,\n      lockRectangles: true\n    },\n\n    pickingLineWidthExtraPixels: 5,\n\n    // Only show fill when polygons are selected,\n    // there is no way atm to enable fill for only one feature\n    filled: selectedFeatureIndexes.length > 0,\n\n    onEdit: ({updatedData, editType}) => {\n      switch (editType) {\n        case EDIT_TYPES.ADD_FEATURE: {\n          const {features: _features} = updatedData;\n          if (_features.length) {\n            const lastFeature = _features[_features.length - 1];\n            if (lastFeature.properties) lastFeature.properties.isClosed = true;\n            lastFeature.id = generateHashId(6);\n            onSetFeatures(updatedData.features as unknown as Feature[]);\n            setSelectedFeature(lastFeature as unknown as Feature);\n          }\n          break;\n        }\n        case EDIT_TYPES.ADD_POSITION:\n        case EDIT_TYPES.MOVE_POSITION:\n        case EDIT_TYPES.TRANSLATING:\n          onSetFeatures(updatedData.features as unknown as Feature[]);\n          break;\n        default:\n          break;\n      }\n    },\n\n    // prevent self-highlights with tentative features\n    autoHighlight: !isDrawingActive(editorMenuActive, editorMode),\n    // @ts-ignore\n    highlightColor: info => {\n      // Note: lines are reported as parent polygon\n      const {object} = info;\n      if (object) {\n        if (object.id === editor.selectedFeature?.id) {\n          return FEATURE_STYLE.highlightMultiplierNone;\n        }\n\n        const type = object.properties.editHandleType;\n        if (type === 'intermediate') return EDIT_HANDLE_STYLE.highlightMultiplierNone;\n        else if (type === 'existing') return EDIT_HANDLE_STYLE.highlightMultiplier;\n      }\n\n      // Note: highlight color affects even transparent filled polygons\n      return selectedFeatureIndexes.length\n        ? FEATURE_STYLE.highlightMultiplier\n        : LINE_STYLE.highlightMultiplier;\n    },\n\n    extensions: [new PathStyleExtension({dash: true})],\n    dashGapPickable: true,\n    getDashArray: feature => {\n      if (feature?.properties?.guideType === 'tentative') {\n        return LINE_STYLE.dashArray;\n      }\n\n      if (feature?.id === editor.selectedFeature?.id) return LINE_STYLE.solidArray;\n\n      return LINE_STYLE.dashArray;\n    },\n\n    getLineColor: LINE_STYLE.getColor,\n    getFillColor: FEATURE_STYLE.getColor,\n\n    getRadius: EDIT_HANDLE_STYLE.getRadius,\n    // @ts-ignore\n    getLineWidth: LINE_STYLE.getWidth,\n\n    getEditHandlePointRadius: EDIT_HANDLE_STYLE.getRadius,\n    getEditHandlePointColor: EDIT_HANDLE_STYLE.getFillColor,\n    getEditHandlePointOutlineColor: EDIT_HANDLE_STYLE.getOutlineColor,\n\n    getTentativeLineColor: LINE_STYLE.getTentativeLineColor,\n    // @ts-ignore\n    getTentativeLineWidth: LINE_STYLE.getTentativeLineWidth,\n    getTentativeFillColor: LINE_STYLE.getTentativeFillColor,\n\n    parameters: {},\n    shadowEnabled: false,\n    _subLayerProps: {\n      geojson: {shadowEnabled: false},\n      guides: {shadowEnabled: false},\n      tooltips: {\n        shadowEnabled: false,\n        _subLayerProps: {\n          characters: {shadowEnabled: false}\n        }\n      }\n    }\n  });\n}\n"],"mappings":"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","ignoreList":[]}