1 | ;
|
2 |
|
3 | Object.defineProperty(exports, "__esModule", {
|
4 | value: true
|
5 | });
|
6 | exports["default"] = void 0;
|
7 |
|
8 | var _reactMapGl = require("react-map-gl");
|
9 |
|
10 | var _react = _interopRequireWildcard(require("react"));
|
11 |
|
12 | var _editModes = require("@nebula.gl/edit-modes");
|
13 |
|
14 | var _memoize = _interopRequireDefault(require("./memoize"));
|
15 |
|
16 | var _constants = require("./constants");
|
17 |
|
18 | var _utils = require("./edit-modes/utils");
|
19 |
|
20 | var _editModes2 = require("./edit-modes");
|
21 |
|
22 | var _Object$freeze;
|
23 |
|
24 | function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; }
|
25 |
|
26 | function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; }
|
27 |
|
28 | function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; if (obj != null) { var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
29 |
|
30 | function _typeof(obj) { 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); }
|
31 |
|
32 | function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); keys.push.apply(keys, symbols); } return keys; }
|
33 |
|
34 | function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(source, true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(source).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
35 |
|
36 | function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } }
|
37 |
|
38 | 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); } }
|
39 |
|
40 | function _createClass(Constructor, protoProps, staticProps) { if (protoProps) _defineProperties(Constructor.prototype, protoProps); if (staticProps) _defineProperties(Constructor, staticProps); return Constructor; }
|
41 |
|
42 | function _possibleConstructorReturn(self, call) { if (call && (_typeof(call) === "object" || typeof call === "function")) { return call; } return _assertThisInitialized(self); }
|
43 |
|
44 | function _getPrototypeOf(o) { _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf : function _getPrototypeOf(o) { return o.__proto__ || Object.getPrototypeOf(o); }; return _getPrototypeOf(o); }
|
45 |
|
46 | function _assertThisInitialized(self) { if (self === void 0) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return self; }
|
47 |
|
48 | 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); }
|
49 |
|
50 | function _setPrototypeOf(o, p) { _setPrototypeOf = Object.setPrototypeOf || function _setPrototypeOf(o, p) { o.__proto__ = p; return o; }; return _setPrototypeOf(o, p); }
|
51 |
|
52 | function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
53 |
|
54 | var MODE_TO_HANDLER = Object.freeze((_Object$freeze = {}, _defineProperty(_Object$freeze, _constants.MODES.READ_ONLY, null), _defineProperty(_Object$freeze, _constants.MODES.SELECT, _editModes2.SelectMode), _defineProperty(_Object$freeze, _constants.MODES.EDITING, _editModes2.EditingMode), _defineProperty(_Object$freeze, _constants.MODES.DRAW_POINT, _editModes2.DrawPointMode), _defineProperty(_Object$freeze, _constants.MODES.DRAW_PATH, _editModes2.DrawLineStringMode), _defineProperty(_Object$freeze, _constants.MODES.DRAW_RECTANGLE, _editModes2.DrawRectangleMode), _defineProperty(_Object$freeze, _constants.MODES.DRAW_POLYGON, _editModes2.DrawPolygonMode), _defineProperty(_Object$freeze, _constants.MODES.DRAW_CIRCLE, _editModes2.DrawCircleMode), _Object$freeze));
|
55 | var defaultProps = {
|
56 | mode: _constants.MODES.READ_ONLY,
|
57 | features: null,
|
58 | onSelect: null,
|
59 | onUpdate: null
|
60 | };
|
61 | var defaultState = {
|
62 | featureCollection: new _editModes.ImmutableFeatureCollection({
|
63 | type: 'FeatureCollection',
|
64 | features: []
|
65 | }),
|
66 | selectedFeatureIndex: null,
|
67 | // index, isGuide, mapCoords, screenCoords
|
68 | hovered: null,
|
69 | isDragging: false,
|
70 | didDrag: false,
|
71 | lastPointerMoveEvent: null,
|
72 | pointerDownPicks: null,
|
73 | pointerDownScreenCoords: null,
|
74 | pointerDownMapCoords: null
|
75 | };
|
76 |
|
77 | var ModeHandler =
|
78 | /*#__PURE__*/
|
79 | function (_PureComponent) {
|
80 | _inherits(ModeHandler, _PureComponent);
|
81 |
|
82 | function ModeHandler() {
|
83 | var _this;
|
84 |
|
85 | _classCallCheck(this, ModeHandler);
|
86 |
|
87 | _this = _possibleConstructorReturn(this, _getPrototypeOf(ModeHandler).call(this));
|
88 |
|
89 | _defineProperty(_assertThisInitialized(_this), "_events", void 0);
|
90 |
|
91 | _defineProperty(_assertThisInitialized(_this), "_eventsRegistered", void 0);
|
92 |
|
93 | _defineProperty(_assertThisInitialized(_this), "_modeHandler", void 0);
|
94 |
|
95 | _defineProperty(_assertThisInitialized(_this), "_context", void 0);
|
96 |
|
97 | _defineProperty(_assertThisInitialized(_this), "_containerRef", void 0);
|
98 |
|
99 | _defineProperty(_assertThisInitialized(_this), "getFeatures", function () {
|
100 | var featureCollection = _this._getFeatureCollection();
|
101 |
|
102 | featureCollection = featureCollection && featureCollection.getObject();
|
103 | return featureCollection && featureCollection.features;
|
104 | });
|
105 |
|
106 | _defineProperty(_assertThisInitialized(_this), "addFeatures", function (features) {
|
107 | var featureCollection = _this._getFeatureCollection();
|
108 |
|
109 | if (featureCollection) {
|
110 | if (!Array.isArray(features)) {
|
111 | features = [features];
|
112 | }
|
113 |
|
114 | featureCollection = featureCollection.addFeatures(features);
|
115 |
|
116 | _this.setState({
|
117 | featureCollection: featureCollection
|
118 | });
|
119 | }
|
120 | });
|
121 |
|
122 | _defineProperty(_assertThisInitialized(_this), "deleteFeatures", function (featureIndexes) {
|
123 | var featureCollection = _this._getFeatureCollection();
|
124 |
|
125 | var selectedFeatureIndex = _this._getSelectedFeatureIndex();
|
126 |
|
127 | if (featureCollection) {
|
128 | if (!Array.isArray(featureIndexes)) {
|
129 | featureIndexes = [featureIndexes];
|
130 | }
|
131 |
|
132 | featureCollection = featureCollection.deleteFeatures(featureIndexes);
|
133 | var newState = {
|
134 | featureCollection: featureCollection
|
135 | };
|
136 |
|
137 | if (featureIndexes.findIndex(function (index) {
|
138 | return selectedFeatureIndex === index;
|
139 | }) >= 0) {
|
140 | newState.selectedFeatureIndex = null;
|
141 | }
|
142 |
|
143 | _this.setState(newState);
|
144 | }
|
145 | });
|
146 |
|
147 | _defineProperty(_assertThisInitialized(_this), "_getMemorizedFeatureCollection", (0, _memoize["default"])(function (_ref) {
|
148 | var propsFeatures = _ref.propsFeatures,
|
149 | stateFeatures = _ref.stateFeatures;
|
150 | var features = propsFeatures || stateFeatures; // Any changes in ImmutableFeatureCollection will create a new object
|
151 |
|
152 | if (features instanceof _editModes.ImmutableFeatureCollection) {
|
153 | return features;
|
154 | }
|
155 |
|
156 | if (features && features.type === 'FeatureCollection') {
|
157 | return new _editModes.ImmutableFeatureCollection({
|
158 | type: 'FeatureCollection',
|
159 | features: features.features
|
160 | });
|
161 | }
|
162 |
|
163 | return new _editModes.ImmutableFeatureCollection({
|
164 | type: 'FeatureCollection',
|
165 | features: features || []
|
166 | });
|
167 | }));
|
168 |
|
169 | _defineProperty(_assertThisInitialized(_this), "_getFeatureCollection", function () {
|
170 | return _this._getMemorizedFeatureCollection({
|
171 | propsFeatures: _this.props.features,
|
172 | stateFeatures: _this.state.featureCollection
|
173 | });
|
174 | });
|
175 |
|
176 | _defineProperty(_assertThisInitialized(_this), "_setupModeHandler", function () {
|
177 | var mode = _this.props.mode;
|
178 |
|
179 | if (!mode || mode === _constants.MODES.READ_ONLY) {
|
180 | _this._degregisterEvents();
|
181 |
|
182 | _this._modeHandler = null;
|
183 | return;
|
184 | }
|
185 |
|
186 | _this._registerEvents();
|
187 |
|
188 | var HandlerClass = MODE_TO_HANDLER[mode];
|
189 | _this._modeHandler = HandlerClass ? new HandlerClass() : null;
|
190 | });
|
191 |
|
192 | _defineProperty(_assertThisInitialized(_this), "_clearEditingState", function () {
|
193 | _this.setState({
|
194 | selectedFeatureIndex: null,
|
195 | hovered: null,
|
196 | pointerDownPicks: null,
|
197 | pointerDownScreenCoords: null,
|
198 | pointerDownMapCoords: null,
|
199 | isDragging: false,
|
200 | didDrag: false
|
201 | });
|
202 | });
|
203 |
|
204 | _defineProperty(_assertThisInitialized(_this), "_getSelectedFeatureIndex", function () {
|
205 | if ('selectedFeatureIndex' in _this.props) {
|
206 | return _this.props.selectedFeatureIndex;
|
207 | }
|
208 |
|
209 | return _this.state.selectedFeatureIndex;
|
210 | });
|
211 |
|
212 | _defineProperty(_assertThisInitialized(_this), "_getSelectedFeature", function (featureIndex) {
|
213 | var features = _this.getFeatures();
|
214 |
|
215 | featureIndex = (0, _utils.isNumeric)(featureIndex) ? featureIndex : _this._getSelectedFeatureIndex();
|
216 | return features[featureIndex];
|
217 | });
|
218 |
|
219 | _defineProperty(_assertThisInitialized(_this), "_onSelect", function (selected) {
|
220 | _this.setState({
|
221 | selectedFeatureIndex: selected && selected.selectedFeatureIndex
|
222 | });
|
223 |
|
224 | if (_this.props.onSelect) {
|
225 | _this.props.onSelect(selected);
|
226 | }
|
227 | });
|
228 |
|
229 | _defineProperty(_assertThisInitialized(_this), "_onUpdate", function (editAction, isInternal) {
|
230 | var editType = editAction.editType,
|
231 | updatedData = editAction.updatedData,
|
232 | editContext = editAction.editContext;
|
233 |
|
234 | _this.setState({
|
235 | featureCollection: new _editModes.ImmutableFeatureCollection(updatedData)
|
236 | });
|
237 |
|
238 | if (_this.props.onUpdate && !isInternal) {
|
239 | _this.props.onUpdate({
|
240 | data: updatedData && updatedData.features,
|
241 | editType: editType,
|
242 | editContext: editContext
|
243 | });
|
244 | }
|
245 | });
|
246 |
|
247 | _defineProperty(_assertThisInitialized(_this), "_onEdit", function (editAction) {
|
248 | var mode = _this.props.mode;
|
249 | var editType = editAction.editType,
|
250 | updatedData = editAction.updatedData;
|
251 |
|
252 | switch (editType) {
|
253 | case _constants.EDIT_TYPE.MOVE_POSITION:
|
254 | // intermediate feature, do not need forward to application
|
255 | // only need update editor internal state
|
256 | _this._onUpdate(editAction, true);
|
257 |
|
258 | break;
|
259 |
|
260 | case _constants.EDIT_TYPE.ADD_FEATURE:
|
261 | _this._onUpdate(editAction);
|
262 |
|
263 | if (mode === _constants.MODES.DRAW_PATH) {
|
264 | var context = editAction.editContext && editAction.editContext[0] || {};
|
265 | var screenCoords = context.screenCoords,
|
266 | mapCoords = context.mapCoords;
|
267 | var featureIndex = updatedData.features.length - 1;
|
268 |
|
269 | var selectedFeature = _this._getSelectedFeature(featureIndex);
|
270 |
|
271 | _this._onSelect({
|
272 | selectedFeature: selectedFeature,
|
273 | selectedFeatureIndex: featureIndex,
|
274 | selectedEditHandleIndex: null,
|
275 | screenCoords: screenCoords,
|
276 | mapCoords: mapCoords
|
277 | });
|
278 | }
|
279 |
|
280 | break;
|
281 |
|
282 | case _constants.EDIT_TYPE.ADD_POSITION:
|
283 | case _constants.EDIT_TYPE.REMOVE_POSITION:
|
284 | case _constants.EDIT_TYPE.FINISH_MOVE_POSITION:
|
285 | _this._onUpdate(editAction);
|
286 |
|
287 | break;
|
288 |
|
289 | default:
|
290 | }
|
291 | });
|
292 |
|
293 | _defineProperty(_assertThisInitialized(_this), "_degregisterEvents", function () {
|
294 | var eventManager = _this._context && _this._context.eventManager;
|
295 |
|
296 | if (!_this._events || !eventManager) {
|
297 | return;
|
298 | }
|
299 |
|
300 | if (_this._eventsRegistered) {
|
301 | eventManager.off(_this._events);
|
302 | _this._eventsRegistered = false;
|
303 | }
|
304 | });
|
305 |
|
306 | _defineProperty(_assertThisInitialized(_this), "_registerEvents", function () {
|
307 | var ref = _this._containerRef;
|
308 | var eventManager = _this._context && _this._context.eventManager;
|
309 |
|
310 | if (!_this._events || !ref || !eventManager) {
|
311 | return;
|
312 | }
|
313 |
|
314 | if (_this._eventsRegistered) {
|
315 | return;
|
316 | }
|
317 |
|
318 | eventManager.on(_this._events, ref);
|
319 | _this._eventsRegistered = true;
|
320 | });
|
321 |
|
322 | _defineProperty(_assertThisInitialized(_this), "_onEvent", function (handler, evt, stopPropagation) {
|
323 | var event = _this._getEvent(evt);
|
324 |
|
325 | handler(event);
|
326 |
|
327 | if (stopPropagation) {
|
328 | evt.stopImmediatePropagation();
|
329 | }
|
330 | });
|
331 |
|
332 | _defineProperty(_assertThisInitialized(_this), "_onClick", function (event) {
|
333 | var mode = _this.props.mode;
|
334 |
|
335 | if (mode === _constants.MODES.SELECT || mode === _constants.MODES.EDITING) {
|
336 | var mapCoords = event.mapCoords,
|
337 | screenCoords = event.screenCoords;
|
338 | var pickedObject = event.picks && event.picks[0] && event.picks[0].object;
|
339 |
|
340 | if (pickedObject && (0, _utils.isNumeric)(pickedObject.featureIndex)) {
|
341 | var selectedFeatureIndex = pickedObject.featureIndex;
|
342 |
|
343 | var selectedFeature = _this._getSelectedFeature(selectedFeatureIndex);
|
344 |
|
345 | _this._onSelect({
|
346 | selectedFeature: selectedFeature,
|
347 | selectedFeatureIndex: selectedFeatureIndex,
|
348 | selectedEditHandleIndex: pickedObject.type === _constants.ELEMENT_TYPE.EDIT_HANDLE ? pickedObject.index : null,
|
349 | mapCoords: mapCoords,
|
350 | screenCoords: screenCoords
|
351 | });
|
352 | } else {
|
353 | _this._onSelect({
|
354 | selectedFeature: null,
|
355 | selectedFeatureIndex: null,
|
356 | selectedEditHandleIndex: null,
|
357 | mapCoords: mapCoords,
|
358 | screenCoords: screenCoords
|
359 | });
|
360 | }
|
361 | }
|
362 |
|
363 | var modeProps = _this.getModeProps();
|
364 |
|
365 | if (_this._modeHandler) {
|
366 | _this._modeHandler.handleClick(event, modeProps);
|
367 | }
|
368 | });
|
369 |
|
370 | _defineProperty(_assertThisInitialized(_this), "_onPointerMove", function (event) {
|
371 | // hovering
|
372 | var hovered = _this._getHoverState(event);
|
373 |
|
374 | var _this$state = _this.state,
|
375 | isDragging = _this$state.isDragging,
|
376 | didDrag = _this$state.didDrag,
|
377 | pointerDownPicks = _this$state.pointerDownPicks,
|
378 | pointerDownScreenCoords = _this$state.pointerDownScreenCoords,
|
379 | pointerDownMapCoords = _this$state.pointerDownMapCoords;
|
380 |
|
381 | if (isDragging && !didDrag && pointerDownScreenCoords) {
|
382 | var dx = event.screenCoords[0] - pointerDownScreenCoords[0];
|
383 | var dy = event.screenCoords[1] - pointerDownScreenCoords[1];
|
384 |
|
385 | if (dx * dx + dy * dy > 5) {
|
386 | _this.setState({
|
387 | didDrag: true
|
388 | });
|
389 | }
|
390 | }
|
391 |
|
392 | var pointerMoveEvent = _objectSpread({}, event, {
|
393 | isDragging: isDragging,
|
394 | pointerDownPicks: pointerDownPicks,
|
395 | pointerDownScreenCoords: pointerDownScreenCoords,
|
396 | pointerDownMapCoords: pointerDownMapCoords
|
397 | }); // how to fire pointerMove event properly for circle
|
398 | // if (this.state.didDrag) {
|
399 |
|
400 |
|
401 | var modeProps = _this.getModeProps();
|
402 |
|
403 | _this._modeHandler.handlePointerMove(pointerMoveEvent, modeProps); // }
|
404 |
|
405 |
|
406 | _this.setState({
|
407 | hovered: hovered,
|
408 | lastPointerMoveEvent: pointerMoveEvent
|
409 | });
|
410 | });
|
411 |
|
412 | _defineProperty(_assertThisInitialized(_this), "_onPointerDown", function (event) {
|
413 | var pickedObject = event.picks && event.picks[0] && event.picks[0].object;
|
414 |
|
415 | var startDraggingEvent = _objectSpread({}, event, {
|
416 | pointerDownScreenCoords: event.screenCoords,
|
417 | pointerDownMapCoords: event.mapCoords
|
418 | });
|
419 |
|
420 | var newState = {
|
421 | isDragging: pickedObject && (0, _utils.isNumeric)(pickedObject.featureIndex),
|
422 | pointerDownPicks: event.picks,
|
423 | pointerDownScreenCoords: event.screenCoords,
|
424 | pointerDownMapCoords: event.mapCoords
|
425 | };
|
426 |
|
427 | _this.setState(newState);
|
428 |
|
429 | var modeProps = _this.getModeProps();
|
430 |
|
431 | _this._modeHandler.handleStartDragging(startDraggingEvent, modeProps);
|
432 | });
|
433 |
|
434 | _defineProperty(_assertThisInitialized(_this), "_onPointerUp", function (event) {
|
435 | var stopDraggingEvent = _objectSpread({}, event, {
|
436 | pointerDownScreenCoords: _this.state.pointerDownScreenCoords,
|
437 | pointerDownMapCoords: _this.state.pointerDownMapCoords
|
438 | });
|
439 |
|
440 | var newState = {
|
441 | isDragging: false,
|
442 | didDrag: false,
|
443 | pointerDownPicks: null,
|
444 | pointerDownScreenCoords: null,
|
445 | pointerDownMapCoords: null
|
446 | };
|
447 |
|
448 | _this.setState(newState);
|
449 |
|
450 | var modeProps = _this.getModeProps();
|
451 |
|
452 | _this._modeHandler.handleStopDragging(stopDraggingEvent, modeProps);
|
453 | });
|
454 |
|
455 | _defineProperty(_assertThisInitialized(_this), "_onPan", function (event) {
|
456 | var isDragging = _this.state.isDragging;
|
457 |
|
458 | if (isDragging) {
|
459 | event.sourceEvent.stopImmediatePropagation();
|
460 | }
|
461 | });
|
462 |
|
463 | _defineProperty(_assertThisInitialized(_this), "project", function (pt) {
|
464 | var viewport = _this._context && _this._context.viewport;
|
465 | return viewport && viewport.project(pt);
|
466 | });
|
467 |
|
468 | _defineProperty(_assertThisInitialized(_this), "unproject", function (pt) {
|
469 | var viewport = _this._context && _this._context.viewport;
|
470 | return viewport && viewport.unproject(pt);
|
471 | });
|
472 |
|
473 | _defineProperty(_assertThisInitialized(_this), "_getHoverState", function (event) {
|
474 | var object = event.picks && event.picks[0] && event.picks[0].object;
|
475 |
|
476 | if (!object) {
|
477 | return null;
|
478 | }
|
479 |
|
480 | return _objectSpread({
|
481 | screenCoords: event.screenCoords,
|
482 | mapCoords: event.mapCoords
|
483 | }, object);
|
484 | });
|
485 |
|
486 | _this.state = defaultState;
|
487 | _this._eventsRegistered = false;
|
488 | _this._events = {
|
489 | anyclick: function anyclick(evt) {
|
490 | return _this._onEvent(_this._onClick, evt, true);
|
491 | },
|
492 | click: function click(evt) {
|
493 | return evt.stopImmediatePropagation();
|
494 | },
|
495 | pointermove: function pointermove(evt) {
|
496 | return _this._onEvent(_this._onPointerMove, evt, true);
|
497 | },
|
498 | pointerdown: function pointerdown(evt) {
|
499 | return _this._onEvent(_this._onPointerDown, evt, true);
|
500 | },
|
501 | pointerup: function pointerup(evt) {
|
502 | return _this._onEvent(_this._onPointerUp, evt, true);
|
503 | },
|
504 | panmove: function panmove(evt) {
|
505 | return _this._onEvent(_this._onPan, evt, false);
|
506 | },
|
507 | panstart: function panstart(evt) {
|
508 | return _this._onEvent(_this._onPan, evt, false);
|
509 | },
|
510 | panend: function panend(evt) {
|
511 | return _this._onEvent(_this._onPan, evt, false);
|
512 | }
|
513 | };
|
514 | return _this;
|
515 | }
|
516 |
|
517 | _createClass(ModeHandler, [{
|
518 | key: "componentDidMount",
|
519 | value: function componentDidMount() {
|
520 | this._setupModeHandler();
|
521 | }
|
522 | }, {
|
523 | key: "componentDidUpdate",
|
524 | value: function componentDidUpdate(prevProps) {
|
525 | if (prevProps.mode !== this.props.mode) {
|
526 | this._clearEditingState();
|
527 |
|
528 | this._setupModeHandler();
|
529 | }
|
530 | }
|
531 | }, {
|
532 | key: "componentWillUnmount",
|
533 | value: function componentWillUnmount() {
|
534 | this._degregisterEvents();
|
535 | }
|
536 | }, {
|
537 | key: "getModeProps",
|
538 | value: function getModeProps() {
|
539 | var featureCollection = this._getFeatureCollection();
|
540 |
|
541 | var lastPointerMoveEvent = this.state.lastPointerMoveEvent;
|
542 |
|
543 | var selectedFeatureIndex = this._getSelectedFeatureIndex();
|
544 |
|
545 | var viewport = this._context && this._context.viewport;
|
546 | return {
|
547 | data: featureCollection,
|
548 | selectedIndexes: [selectedFeatureIndex],
|
549 | lastPointerMoveEvent: lastPointerMoveEvent,
|
550 | viewport: viewport,
|
551 | onEdit: this._onEdit
|
552 | };
|
553 | }
|
554 | /* MEMORIZERS */
|
555 |
|
556 | }, {
|
557 | key: "_getEvent",
|
558 | value: function _getEvent(evt) {
|
559 | var picked = (0, _utils.parseEventElement)(evt);
|
560 | var screenCoords = (0, _utils.getScreenCoords)(evt);
|
561 | var mapCoords = this.unproject(screenCoords);
|
562 | return {
|
563 | picks: picked ? [picked] : null,
|
564 | screenCoords: screenCoords,
|
565 | mapCoords: mapCoords,
|
566 | sourceEvent: evt
|
567 | };
|
568 | }
|
569 | }, {
|
570 | key: "_isDrawing",
|
571 | value: function _isDrawing() {
|
572 | var mode = this.props.mode;
|
573 | return _constants.DRAWING_MODE.findIndex(function (m) {
|
574 | return m === mode;
|
575 | }) >= 0;
|
576 | }
|
577 | }, {
|
578 | key: "render",
|
579 | value: function render(child) {
|
580 | var _this2 = this;
|
581 |
|
582 | return _react["default"].createElement(_reactMapGl._MapContext.Consumer, null, function (context) {
|
583 | _this2._context = context;
|
584 | var viewport = context && context.viewport;
|
585 |
|
586 | if (!viewport || viewport.height <= 0 || viewport.width <= 0) {
|
587 | return null;
|
588 | }
|
589 |
|
590 | return child;
|
591 | });
|
592 | }
|
593 | }]);
|
594 |
|
595 | return ModeHandler;
|
596 | }(_react.PureComponent);
|
597 |
|
598 | exports["default"] = ModeHandler;
|
599 |
|
600 | _defineProperty(ModeHandler, "defaultProps", defaultProps);
|
601 |
|
602 | ModeHandler.displayName = 'ModeHandler';
|
603 | //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../src/mode-handler.js"],"names":["MODE_TO_HANDLER","Object","freeze","MODES","READ_ONLY","SELECT","SelectMode","EDITING","EditingMode","DRAW_POINT","DrawPointMode","DRAW_PATH","DrawLineStringMode","DRAW_RECTANGLE","DrawRectangleMode","DRAW_POLYGON","DrawPolygonMode","DRAW_CIRCLE","DrawCircleMode","defaultProps","mode","features","onSelect","onUpdate","defaultState","featureCollection","ImmutableFeatureCollection","type","selectedFeatureIndex","hovered","isDragging","didDrag","lastPointerMoveEvent","pointerDownPicks","pointerDownScreenCoords","pointerDownMapCoords","ModeHandler","_getFeatureCollection","getObject","Array","isArray","addFeatures","setState","featureIndexes","_getSelectedFeatureIndex","deleteFeatures","newState","findIndex","index","propsFeatures","stateFeatures","_getMemorizedFeatureCollection","props","state","_degregisterEvents","_modeHandler","_registerEvents","HandlerClass","featureIndex","getFeatures","selected","editAction","isInternal","editType","updatedData","editContext","data","EDIT_TYPE","MOVE_POSITION","_onUpdate","ADD_FEATURE","context","screenCoords","mapCoords","length","selectedFeature","_getSelectedFeature","_onSelect","selectedEditHandleIndex","ADD_POSITION","REMOVE_POSITION","FINISH_MOVE_POSITION","eventManager","_context","_events","_eventsRegistered","off","ref","_containerRef","on","handler","evt","stopPropagation","event","_getEvent","stopImmediatePropagation","pickedObject","picks","object","ELEMENT_TYPE","EDIT_HANDLE","modeProps","getModeProps","handleClick","_getHoverState","dx","dy","pointerMoveEvent","handlePointerMove","startDraggingEvent","handleStartDragging","stopDraggingEvent","handleStopDragging","sourceEvent","pt","viewport","project","unproject","anyclick","_onEvent","_onClick","click","pointermove","_onPointerMove","pointerdown","_onPointerDown","pointerup","_onPointerUp","panmove","_onPan","panstart","panend","_setupModeHandler","prevProps","_clearEditingState","selectedIndexes","onEdit","_onEdit","picked","DRAWING_MODE","m","child","height","width","PureComponent","displayName"],"mappings":"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","sourcesContent":["// @flow\nimport { _MapContext as MapContext } from 'react-map-gl';\nimport React, { PureComponent } from 'react';\nimport { ImmutableFeatureCollection } from '@nebula.gl/edit-modes';\n\nimport type { Feature, Position, EditAction } from '@nebula.gl/edit-modes';\nimport type { MjolnirEvent } from 'mjolnir.js';\nimport type { BaseEvent, EditorProps, EditorState, SelectAction } from './types';\nimport memoize from './memoize';\n\nimport { DRAWING_MODE, EDIT_TYPE, ELEMENT_TYPE, MODES } from './constants';\nimport { getScreenCoords, isNumeric, parseEventElement } from './edit-modes/utils';\nimport {\n  SelectMode,\n  EditingMode,\n  DrawPointMode,\n  DrawLineStringMode,\n  DrawRectangleMode,\n  DrawPolygonMode,\n  DrawCircleMode,\n} from './edit-modes';\n\nconst MODE_TO_HANDLER = Object.freeze({\n  [MODES.READ_ONLY]: null,\n  [MODES.SELECT]: SelectMode,\n  [MODES.EDITING]: EditingMode,\n  [MODES.DRAW_POINT]: DrawPointMode,\n  [MODES.DRAW_PATH]: DrawLineStringMode,\n  [MODES.DRAW_RECTANGLE]: DrawRectangleMode,\n  [MODES.DRAW_POLYGON]: DrawPolygonMode,\n  [MODES.DRAW_CIRCLE]: DrawCircleMode\n});\n\nconst defaultProps = {\n  mode: MODES.READ_ONLY,\n  features: null,\n  onSelect: null,\n  onUpdate: null\n};\n\nconst defaultState = {\n  featureCollection: new ImmutableFeatureCollection({\n    type: 'FeatureCollection',\n    features: []\n  }),\n\n  selectedFeatureIndex: null,\n\n  // index, isGuide, mapCoords, screenCoords\n  hovered: null,\n\n  isDragging: false,\n  didDrag: false,\n\n  lastPointerMoveEvent: null,\n\n  pointerDownPicks: null,\n  pointerDownScreenCoords: null,\n  pointerDownMapCoords: null\n};\n\nexport default class ModeHandler extends PureComponent<EditorProps, EditorState> {\n  static defaultProps = defaultProps;\n\n  constructor() {\n    super();\n    this.state = defaultState;\n    this._eventsRegistered = false;\n\n    this._events = {\n      anyclick: evt => this._onEvent(this._onClick, evt, true),\n      click: evt => evt.stopImmediatePropagation(),\n      pointermove: evt => this._onEvent(this._onPointerMove, evt, true),\n      pointerdown: evt => this._onEvent(this._onPointerDown, evt, true),\n      pointerup: evt => this._onEvent(this._onPointerUp, evt, true),\n      panmove: evt => this._onEvent(this._onPan, evt, false),\n      panstart: evt => this._onEvent(this._onPan, evt, false),\n      panend: evt => this._onEvent(this._onPan, evt, false)\n    };\n  }\n\n  componentDidMount() {\n    this._setupModeHandler();\n  }\n\n  componentDidUpdate(prevProps: EditorProps) {\n    if (prevProps.mode !== this.props.mode) {\n      this._clearEditingState();\n      this._setupModeHandler();\n    }\n  }\n\n  componentWillUnmount() {\n    this._degregisterEvents();\n  }\n\n  _events: any;\n  _eventsRegistered: boolean;\n  _modeHandler: any;\n  _context: ?MapContext;\n  _containerRef: ?HTMLElement;\n\n  getFeatures = () => {\n    let featureCollection = this._getFeatureCollection();\n    featureCollection = featureCollection && featureCollection.getObject();\n    return featureCollection && featureCollection.features;\n  };\n\n  addFeatures = (features: Feature | Feature[]) => {\n    let featureCollection = this._getFeatureCollection();\n    if (featureCollection) {\n      if (!Array.isArray(features)) {\n        features = [features];\n      }\n\n      featureCollection = featureCollection.addFeatures(features);\n      this.setState({ featureCollection });\n    }\n  };\n\n  deleteFeatures = (featureIndexes: number | number[]) => {\n    let featureCollection = this._getFeatureCollection();\n    const selectedFeatureIndex = this._getSelectedFeatureIndex();\n    if (featureCollection) {\n      if (!Array.isArray(featureIndexes)) {\n        featureIndexes = [featureIndexes];\n      }\n      featureCollection = featureCollection.deleteFeatures(featureIndexes);\n      const newState: any = { featureCollection };\n      if (featureIndexes.findIndex(index => selectedFeatureIndex === index) >= 0) {\n        newState.selectedFeatureIndex = null;\n      }\n      this.setState(newState);\n    }\n  };\n\n  getModeProps() {\n    const featureCollection = this._getFeatureCollection();\n\n    const { lastPointerMoveEvent } = this.state;\n    const selectedFeatureIndex = this._getSelectedFeatureIndex();\n    const viewport = this._context && this._context.viewport;\n\n    return {\n      data: featureCollection,\n      selectedIndexes: [selectedFeatureIndex],\n      lastPointerMoveEvent,\n      viewport,\n      onEdit: this._onEdit\n    };\n  }\n\n  /* MEMORIZERS */\n  _getMemorizedFeatureCollection = memoize(({ propsFeatures, stateFeatures }: any) => {\n    const features = propsFeatures || stateFeatures;\n    // Any changes in ImmutableFeatureCollection will create a new object\n    if (features instanceof ImmutableFeatureCollection) {\n      return features;\n    }\n\n    if (features && features.type === 'FeatureCollection') {\n      return new ImmutableFeatureCollection({\n        type: 'FeatureCollection',\n        features: features.features\n      });\n    }\n\n    return new ImmutableFeatureCollection({\n      type: 'FeatureCollection',\n      features: features || []\n    });\n  });\n\n  _getFeatureCollection = () => {\n    return this._getMemorizedFeatureCollection({\n      propsFeatures: this.props.features,\n      stateFeatures: this.state.featureCollection\n    });\n  };\n\n  _setupModeHandler = () => {\n    const mode = this.props.mode;\n\n    if (!mode || mode === MODES.READ_ONLY) {\n      this._degregisterEvents();\n      this._modeHandler = null;\n      return;\n    }\n\n    this._registerEvents();\n\n    const HandlerClass = MODE_TO_HANDLER[mode];\n    this._modeHandler = HandlerClass ? new HandlerClass() : null;\n  };\n\n  /* EDITING OPERATIONS */\n  _clearEditingState = () => {\n    this.setState({\n      selectedFeatureIndex: null,\n\n      hovered: null,\n\n      pointerDownPicks: null,\n      pointerDownScreenCoords: null,\n      pointerDownMapCoords: null,\n\n      isDragging: false,\n      didDrag: false\n    });\n  };\n\n  _getSelectedFeatureIndex = () => {\n    if ('selectedFeatureIndex' in this.props) {\n      return this.props.selectedFeatureIndex;\n    }\n    return this.state.selectedFeatureIndex;\n  };\n\n  _getSelectedFeature = (featureIndex: ?number) => {\n    const features = this.getFeatures();\n    featureIndex = isNumeric(featureIndex) ? featureIndex : this._getSelectedFeatureIndex();\n    return features[featureIndex];\n  };\n\n  _onSelect = (selected: SelectAction) => {\n    this.setState({ selectedFeatureIndex: selected && selected.selectedFeatureIndex });\n    if (this.props.onSelect) {\n      this.props.onSelect(selected);\n    }\n  };\n\n  _onUpdate = (editAction: EditAction, isInternal: ?boolean) => {\n    const { editType, updatedData, editContext } = editAction;\n    this.setState({ featureCollection: new ImmutableFeatureCollection(updatedData) });\n    if (this.props.onUpdate && !isInternal) {\n      this.props.onUpdate({\n        data: updatedData && updatedData.features,\n        editType,\n        editContext\n      });\n    }\n  };\n\n  _onEdit = (editAction: EditAction) => {\n    const { mode } = this.props;\n    const { editType, updatedData } = editAction;\n\n    switch (editType) {\n      case EDIT_TYPE.MOVE_POSITION:\n        // intermediate feature, do not need forward to application\n        // only need update editor internal state\n        this._onUpdate(editAction, true);\n        break;\n      case EDIT_TYPE.ADD_FEATURE:\n        this._onUpdate(editAction);\n        if (mode === MODES.DRAW_PATH) {\n          const context = (editAction.editContext && editAction.editContext[0]) || {};\n          const { screenCoords, mapCoords } = context;\n          const featureIndex = updatedData.features.length - 1;\n          const selectedFeature = this._getSelectedFeature(featureIndex);\n          this._onSelect({\n            selectedFeature,\n            selectedFeatureIndex: featureIndex,\n            selectedEditHandleIndex: null,\n            screenCoords,\n            mapCoords\n          });\n        }\n        break;\n      case EDIT_TYPE.ADD_POSITION:\n      case EDIT_TYPE.REMOVE_POSITION:\n      case EDIT_TYPE.FINISH_MOVE_POSITION:\n        this._onUpdate(editAction);\n        break;\n\n      default:\n    }\n  };\n\n  /* EVENTS */\n  _degregisterEvents = () => {\n    const eventManager = this._context && this._context.eventManager;\n    if (!this._events || !eventManager) {\n      return;\n    }\n\n    if (this._eventsRegistered) {\n      eventManager.off(this._events);\n      this._eventsRegistered = false;\n    }\n  };\n\n  _registerEvents = () => {\n    const ref = this._containerRef;\n    const eventManager = this._context && this._context.eventManager;\n    if (!this._events || !ref || !eventManager) {\n      return;\n    }\n\n    if (this._eventsRegistered) {\n      return;\n    }\n\n    eventManager.on(this._events, ref);\n    this._eventsRegistered = true;\n  };\n\n  _onEvent = (handler: Function, evt: MjolnirEvent, stopPropagation: boolean) => {\n    const event = this._getEvent(evt);\n    handler(event);\n\n    if (stopPropagation) {\n      evt.stopImmediatePropagation();\n    }\n  };\n\n  _onClick = (event: BaseEvent) => {\n    const { mode } = this.props;\n    if (mode === MODES.SELECT || mode === MODES.EDITING) {\n      const { mapCoords, screenCoords } = event;\n      const pickedObject = event.picks && event.picks[0] && event.picks[0].object;\n      if (pickedObject && isNumeric(pickedObject.featureIndex)) {\n        const selectedFeatureIndex = pickedObject.featureIndex;\n        const selectedFeature = this._getSelectedFeature(selectedFeatureIndex);\n        this._onSelect({\n          selectedFeature,\n          selectedFeatureIndex,\n          selectedEditHandleIndex:\n            pickedObject.type === ELEMENT_TYPE.EDIT_HANDLE ? pickedObject.index : null,\n          mapCoords,\n          screenCoords\n        });\n      } else {\n        this._onSelect({\n          selectedFeature: null,\n          selectedFeatureIndex: null,\n          selectedEditHandleIndex: null,\n          mapCoords,\n          screenCoords\n        });\n      }\n    }\n\n    const modeProps = this.getModeProps();\n    if(this._modeHandler) {\n      this._modeHandler.handleClick(event, modeProps);\n    }\n  };\n\n  _onPointerMove = (event: BaseEvent) => {\n    // hovering\n    const hovered = this._getHoverState(event);\n    const {\n      isDragging,\n      didDrag,\n      pointerDownPicks,\n      pointerDownScreenCoords,\n      pointerDownMapCoords\n    } = this.state;\n\n    if (isDragging && !didDrag && pointerDownScreenCoords) {\n      const dx = event.screenCoords[0] - pointerDownScreenCoords[0];\n      const dy = event.screenCoords[1] - pointerDownScreenCoords[1];\n      if (dx * dx + dy * dy > 5) {\n        this.setState({ didDrag: true });\n      }\n    }\n\n    const pointerMoveEvent = {\n      ...event,\n      isDragging,\n      pointerDownPicks,\n      pointerDownScreenCoords,\n      pointerDownMapCoords\n    };\n    // how to fire pointerMove event properly for circle\n    // if (this.state.didDrag) {\n      const modeProps = this.getModeProps();\n      this._modeHandler.handlePointerMove(pointerMoveEvent, modeProps);\n    // }\n\n    this.setState({\n      hovered,\n      lastPointerMoveEvent: pointerMoveEvent\n    });\n  };\n\n  _onPointerDown = (event: BaseEvent) => {\n    const pickedObject = event.picks && event.picks[0] && event.picks[0].object;\n    const startDraggingEvent = {\n      ...event,\n      pointerDownScreenCoords: event.screenCoords,\n      pointerDownMapCoords: event.mapCoords\n    };\n\n    const newState = {\n      isDragging: pickedObject && isNumeric(pickedObject.featureIndex),\n      pointerDownPicks: event.picks,\n      pointerDownScreenCoords: event.screenCoords,\n      pointerDownMapCoords: event.mapCoords\n    };\n\n    this.setState(newState);\n\n    const modeProps = this.getModeProps();\n    this._modeHandler.handleStartDragging(startDraggingEvent, modeProps);\n  };\n\n  _onPointerUp = (event: MjolnirEvent) => {\n    const stopDraggingEvent = {\n      ...event,\n      pointerDownScreenCoords: this.state.pointerDownScreenCoords,\n      pointerDownMapCoords: this.state.pointerDownMapCoords\n    };\n\n    const newState = {\n      isDragging: false,\n      didDrag: false,\n      pointerDownPicks: null,\n      pointerDownScreenCoords: null,\n      pointerDownMapCoords: null\n    };\n\n    this.setState(newState);\n\n    const modeProps = this.getModeProps();\n    this._modeHandler.handleStopDragging(stopDraggingEvent, modeProps);\n  };\n\n  _onPan = (event: BaseEvent) => {\n    const { isDragging } = this.state;\n    if (isDragging) {\n      event.sourceEvent.stopImmediatePropagation();\n    }\n  };\n\n  /* HELPERS */\n  project = (pt: Position) => {\n    const viewport = this._context && this._context.viewport;\n    return viewport && viewport.project(pt);\n  };\n\n  unproject = (pt: Position) => {\n    const viewport = this._context && this._context.viewport;\n    return viewport && viewport.unproject(pt);\n  };\n\n  _getEvent(evt: MjolnirEvent) {\n    const picked = parseEventElement(evt);\n    const screenCoords = getScreenCoords(evt);\n    const mapCoords = this.unproject(screenCoords);\n\n    return {\n      picks: picked ? [picked] : null,\n      screenCoords,\n      mapCoords,\n      sourceEvent: evt\n    };\n  }\n\n  _getHoverState = (event: BaseEvent) => {\n    const object = event.picks && event.picks[0] && event.picks[0].object;\n    if (!object) {\n      return null;\n    }\n\n    return {\n      screenCoords: event.screenCoords,\n      mapCoords: event.mapCoords,\n      ...object\n    };\n  };\n\n  _isDrawing() {\n    const { mode } = this.props;\n    return DRAWING_MODE.findIndex(m => m === mode) >= 0;\n  }\n\n  render(child: any) {\n    return (\n      <MapContext.Consumer>\n        {context => {\n          this._context = context;\n          const viewport = context && context.viewport;\n\n          if (!viewport || viewport.height <= 0 || viewport.width <= 0) {\n            return null;\n          }\n\n          return child;\n        }}\n      </MapContext.Consumer>\n    );\n  }\n}\n\nModeHandler.displayName = 'ModeHandler';\n"]} |
\ | No newline at end of file |