UNPKG

@nebula.gl/layers

Version:

A suite of 3D-enabled data editing layers, suitable for deck.gl

172 lines (129 loc) 19.5 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.DrawPolygonHandler = void 0; var _modeHandler = require("./mode-handler"); function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); } function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); } function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(n); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); } function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && Symbol.iterator in Object(iter)) return Array.from(iter); } function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); } function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } function _defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; } function _get(target, property, receiver) { if (typeof Reflect !== "undefined" && Reflect.get) { _get = Reflect.get; } else { _get = function _get(target, property, receiver) { var base = _superPropBase(target, property); if (!base) return; var desc = Object.getOwnPropertyDescriptor(base, property); if (desc.get) { return desc.get.call(receiver); } return desc.value; }; } return _get(target, property, receiver || target); } function _superPropBase(object, property) { while (!Object.prototype.hasOwnProperty.call(object, property)) { object = _getPrototypeOf(object); if (object === null) break; } return object; } function _createSuper(Derived) { return function () { var Super = _getPrototypeOf(Derived), result; if (_isNativeReflectConstruct()) { var NewTarget = _getPrototypeOf(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; } function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); } function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; } function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Date.prototype.toString.call(Reflect.construct(Date, [], function () {})); return true; } catch (e) { return false; } } function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); } function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function"); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, writable: true, configurable: true } }); if (superClass) _setPrototypeOf(subClass, superClass); } function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); } // TODO edit-modes: delete handlers once EditMode fully implemented var DrawPolygonHandler = /*#__PURE__*/function (_ModeHandler) { _inherits(DrawPolygonHandler, _ModeHandler); var _super = _createSuper(DrawPolygonHandler); function DrawPolygonHandler() { _classCallCheck(this, DrawPolygonHandler); return _super.apply(this, arguments); } _createClass(DrawPolygonHandler, [{ key: "getEditHandles", value: function getEditHandles(picks, groundCoords) { var handles = _get(_getPrototypeOf(DrawPolygonHandler.prototype), "getEditHandles", this).call(this, picks, groundCoords); if (this._tentativeFeature) { handles = handles.concat((0, _modeHandler.getEditHandlesForGeometry)(this._tentativeFeature.geometry, -1)); // Slice off the handles that are are next to the pointer if (this._tentativeFeature && this._tentativeFeature.geometry.type === 'LineString') { // Remove the last existing handle handles = handles.slice(0, -1); } else if (this._tentativeFeature && this._tentativeFeature.geometry.type === 'Polygon') { // Remove the last existing handle handles = handles.slice(0, -1); } } return handles; } }, { key: "handleClick", value: function handleClick(event) { _get(_getPrototypeOf(DrawPolygonHandler.prototype), "handleClick", this).call(this, event); var picks = event.picks; var tentativeFeature = this.getTentativeFeature(); var editAction = null; var clickedEditHandle = (0, _modeHandler.getPickedEditHandle)(picks); if (clickedEditHandle) { // User clicked an edit handle. // Remove it from the click sequence, so it isn't added as a new point. var clickSequence = this.getClickSequence(); clickSequence.splice(clickSequence.length - 1, 1); } if (tentativeFeature && tentativeFeature.geometry.type === 'Polygon') { var polygon = tentativeFeature.geometry; if (clickedEditHandle && clickedEditHandle.featureIndex === -1 && (clickedEditHandle.positionIndexes[1] === 0 || clickedEditHandle.positionIndexes[1] === polygon.coordinates[0].length - 3)) { // They clicked the first or last point (or double-clicked), so complete the polygon // Remove the hovered position var polygonToAdd = { type: 'Polygon', coordinates: [[].concat(_toConsumableArray(polygon.coordinates[0].slice(0, -2)), [polygon.coordinates[0][0]])] }; this.resetClickSequence(); this._setTentativeFeature(null); editAction = this.getAddFeatureOrBooleanPolygonAction(polygonToAdd); } } // Trigger pointer move right away in order for it to update edit handles (to support double-click) var fakePointerMoveEvent = { screenCoords: [-1, -1], groundCoords: event.groundCoords, picks: [], isDragging: false, pointerDownPicks: null, pointerDownScreenCoords: null, pointerDownGroundCoords: null, sourceEvent: null }; // @ts-ignore this.handlePointerMove(fakePointerMoveEvent); return editAction; } }, { key: "handlePointerMove", value: function handlePointerMove(_ref) { var groundCoords = _ref.groundCoords; var clickSequence = this.getClickSequence(); var result = { editAction: null, cancelMapPan: false }; if (clickSequence.length === 0) { // nothing to do yet return result; } if (clickSequence.length < 3) { // Draw a LineString connecting all the clicked points with the hovered point this._setTentativeFeature({ type: 'Feature', geometry: { type: 'LineString', coordinates: [].concat(_toConsumableArray(clickSequence), [groundCoords]) } }); } else { // Draw a Polygon connecting all the clicked points with the hovered point this._setTentativeFeature({ type: 'Feature', geometry: { type: 'Polygon', coordinates: [[].concat(_toConsumableArray(clickSequence), [groundCoords, clickSequence[0]])] } }); } return result; } }]); return DrawPolygonHandler; }(_modeHandler.ModeHandler); exports.DrawPolygonHandler = DrawPolygonHandler; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/mode-handlers/draw-polygon-handler.ts"],"names":["DrawPolygonHandler","picks","groundCoords","handles","_tentativeFeature","concat","geometry","type","slice","event","tentativeFeature","getTentativeFeature","editAction","clickedEditHandle","clickSequence","getClickSequence","splice","length","polygon","featureIndex","positionIndexes","coordinates","polygonToAdd","resetClickSequence","_setTentativeFeature","getAddFeatureOrBooleanPolygonAction","fakePointerMoveEvent","screenCoords","isDragging","pointerDownPicks","pointerDownScreenCoords","pointerDownGroundCoords","sourceEvent","handlePointerMove","result","cancelMapPan","ModeHandler"],"mappings":"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","sourcesContent":["import { Polygon, Position } from '@nebula.gl/edit-modes';\nimport { ClickEvent, PointerMoveEvent } from '../event-types';\nimport {\n  EditAction,\n  EditHandle,\n  ModeHandler,\n  getPickedEditHandle,\n  getEditHandlesForGeometry,\n} from './mode-handler';\n\n// TODO edit-modes: delete handlers once EditMode fully implemented\nexport class DrawPolygonHandler extends ModeHandler {\n  getEditHandles(picks?: Array<Record<string, any>>, groundCoords?: Position): EditHandle[] {\n    let handles = super.getEditHandles(picks, groundCoords);\n\n    if (this._tentativeFeature) {\n      handles = handles.concat(getEditHandlesForGeometry(this._tentativeFeature.geometry, -1));\n      // Slice off the handles that are are next to the pointer\n      if (this._tentativeFeature && this._tentativeFeature.geometry.type === 'LineString') {\n        // Remove the last existing handle\n        handles = handles.slice(0, -1);\n      } else if (this._tentativeFeature && this._tentativeFeature.geometry.type === 'Polygon') {\n        // Remove the last existing handle\n        handles = handles.slice(0, -1);\n      }\n    }\n\n    return handles;\n  }\n\n  handleClick(event: ClickEvent): EditAction | null | undefined {\n    super.handleClick(event);\n\n    const { picks } = event;\n    const tentativeFeature = this.getTentativeFeature();\n\n    let editAction: EditAction | null | undefined = null;\n    const clickedEditHandle = getPickedEditHandle(picks);\n\n    if (clickedEditHandle) {\n      // User clicked an edit handle.\n      // Remove it from the click sequence, so it isn't added as a new point.\n      const clickSequence = this.getClickSequence();\n      clickSequence.splice(clickSequence.length - 1, 1);\n    }\n\n    if (tentativeFeature && tentativeFeature.geometry.type === 'Polygon') {\n      const polygon: Polygon = tentativeFeature.geometry;\n\n      if (\n        clickedEditHandle &&\n        clickedEditHandle.featureIndex === -1 &&\n        (clickedEditHandle.positionIndexes[1] === 0 ||\n          clickedEditHandle.positionIndexes[1] === polygon.coordinates[0].length - 3)\n      ) {\n        // They clicked the first or last point (or double-clicked), so complete the polygon\n\n        // Remove the hovered position\n        const polygonToAdd: Polygon = {\n          type: 'Polygon',\n          coordinates: [[...polygon.coordinates[0].slice(0, -2), polygon.coordinates[0][0]]],\n        };\n\n        this.resetClickSequence();\n        this._setTentativeFeature(null);\n        editAction = this.getAddFeatureOrBooleanPolygonAction(polygonToAdd);\n      }\n    }\n\n    // Trigger pointer move right away in order for it to update edit handles (to support double-click)\n    const fakePointerMoveEvent = {\n      screenCoords: [-1, -1],\n      groundCoords: event.groundCoords,\n      picks: [],\n      isDragging: false,\n      pointerDownPicks: null,\n      pointerDownScreenCoords: null,\n      pointerDownGroundCoords: null,\n      sourceEvent: null,\n    };\n    // @ts-ignore\n    this.handlePointerMove(fakePointerMoveEvent);\n\n    return editAction;\n  }\n\n  handlePointerMove({\n    groundCoords,\n  }: PointerMoveEvent): { editAction: EditAction | null | undefined; cancelMapPan: boolean } {\n    const clickSequence = this.getClickSequence();\n    const result = { editAction: null, cancelMapPan: false };\n\n    if (clickSequence.length === 0) {\n      // nothing to do yet\n      return result;\n    }\n\n    if (clickSequence.length < 3) {\n      // Draw a LineString connecting all the clicked points with the hovered point\n      this._setTentativeFeature({\n        type: 'Feature',\n        geometry: {\n          type: 'LineString',\n          coordinates: [...clickSequence, groundCoords],\n        },\n      });\n    } else {\n      // Draw a Polygon connecting all the clicked points with the hovered point\n      this._setTentativeFeature({\n        type: 'Feature',\n        geometry: {\n          type: 'Polygon',\n          coordinates: [[...clickSequence, groundCoords, clickSequence[0]]],\n        },\n      });\n    }\n\n    return result;\n  }\n}\n"]}