UNPKG

@nebula.gl/layers

Version:

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

280 lines (216 loc) 30.6 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports["default"] = exports.SELECTION_TYPE = void 0; var _core = require("@deck.gl/core"); var _layers = require("@deck.gl/layers"); var _helpers = require("@turf/helpers"); var _buffer = _interopRequireDefault(require("@turf/buffer")); var _difference = _interopRequireDefault(require("@turf/difference")); var _editModes = require("@nebula.gl/edit-modes"); var _editableGeojsonLayer = _interopRequireDefault(require("./editable-geojson-layer")); var _MODE_MAP; function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { "default": obj }; } 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 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; } function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; } 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 _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 _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); } function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure 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 _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 _iterableToArrayLimit(arr, i) { if (typeof Symbol === "undefined" || !(Symbol.iterator in Object(arr))) return; var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; } 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 _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); } 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; } var SELECTION_TYPE = { NONE: null, RECTANGLE: 'rectangle', POLYGON: 'polygon' }; exports.SELECTION_TYPE = SELECTION_TYPE; var MODE_MAP = (_MODE_MAP = {}, _defineProperty(_MODE_MAP, SELECTION_TYPE.RECTANGLE, _editModes.DrawRectangleMode), _defineProperty(_MODE_MAP, SELECTION_TYPE.POLYGON, _editModes.DrawPolygonMode), _MODE_MAP); var MODE_CONFIG_MAP = _defineProperty({}, SELECTION_TYPE.RECTANGLE, { dragToDraw: true }); var defaultProps = { selectionType: SELECTION_TYPE.RECTANGLE, layerIds: [], onSelect: function onSelect() {} }; var EMPTY_DATA = { type: 'FeatureCollection', features: [] }; var EXPANSION_KM = 50; var LAYER_ID_GEOJSON = 'selection-geojson'; var LAYER_ID_BLOCKER = 'selection-blocker'; var PASS_THROUGH_PROPS = ['lineWidthScale', 'lineWidthMinPixels', 'lineWidthMaxPixels', 'lineWidthUnits', 'lineJointRounded', 'lineMiterLimit', 'pointRadiusScale', 'pointRadiusMinPixels', 'pointRadiusMaxPixels', 'lineDashJustified', 'getLineColor', 'getFillColor', 'getRadius', 'getLineWidth', 'getLineDashArray', 'getTentativeLineDashArray', 'getTentativeLineColor', 'getTentativeFillColor', 'getTentativeLineWidth']; var SelectionLayer = /*#__PURE__*/function (_CompositeLayer) { _inherits(SelectionLayer, _CompositeLayer); var _super = _createSuper(SelectionLayer); function SelectionLayer() { _classCallCheck(this, SelectionLayer); return _super.apply(this, arguments); } _createClass(SelectionLayer, [{ key: "_selectRectangleObjects", value: function _selectRectangleObjects(coordinates) { var _this$props = this.props, layerIds = _this$props.layerIds, onSelect = _this$props.onSelect; // @ts-ignore var _this$context$viewpor = this.context.viewport.project(coordinates[0][0]), _this$context$viewpor2 = _slicedToArray(_this$context$viewpor, 2), x1 = _this$context$viewpor2[0], y1 = _this$context$viewpor2[1]; // @ts-ignore var _this$context$viewpor3 = this.context.viewport.project(coordinates[0][2]), _this$context$viewpor4 = _slicedToArray(_this$context$viewpor3, 2), x2 = _this$context$viewpor4[0], y2 = _this$context$viewpor4[1]; // @ts-ignore var pickingInfos = this.context.deck.pickObjects({ x: Math.min(x1, x2), y: Math.min(y1, y2), width: Math.abs(x2 - x1), height: Math.abs(y2 - y1), layerIds: layerIds }); onSelect({ pickingInfos: pickingInfos }); } }, { key: "_selectPolygonObjects", value: function _selectPolygonObjects(coordinates) { var _this = this; var _this$props2 = this.props, layerIds = _this$props2.layerIds, onSelect = _this$props2.onSelect; // @ts-ignore var mousePoints = coordinates[0].map(function (c) { return _this.context.viewport.project(c); }); var allX = mousePoints.map(function (mousePoint) { return mousePoint[0]; }); var allY = mousePoints.map(function (mousePoint) { return mousePoint[1]; }); var x = Math.min.apply(Math, _toConsumableArray(allX)); var y = Math.min.apply(Math, _toConsumableArray(allY)); var maxX = Math.max.apply(Math, _toConsumableArray(allX)); var maxY = Math.max.apply(Math, _toConsumableArray(allY)); // Use a polygon to hide the outside, because pickObjects() // does not support polygons var landPointsPoly = (0, _helpers.polygon)(coordinates); var bigBuffer = (0, _buffer["default"])(landPointsPoly, EXPANSION_KM); var bigPolygon; try { // turfDifference throws an exception if the polygon // intersects with itself (TODO: check if true in all versions) bigPolygon = (0, _difference["default"])(bigBuffer, landPointsPoly); } catch (e) { // invalid selection polygon console.log('turfDifference() error', e); // eslint-disable-line return; } this.setState({ pendingPolygonSelection: { bigPolygon: bigPolygon } }); var blockerId = "".concat(this.props.id, "-").concat(LAYER_ID_BLOCKER); // HACK, find a better way setTimeout(function () { // @ts-ignore var pickingInfos = _this.context.deck.pickObjects({ x: x, y: y, width: maxX - x, height: maxY - y, layerIds: [blockerId].concat(_toConsumableArray(layerIds)) }); onSelect({ pickingInfos: pickingInfos.filter(function (item) { return item.layer.id !== _this.props.id; }) }); }, 250); } }, { key: "renderLayers", value: function renderLayers() { var _this2 = this; var pendingPolygonSelection = this.state.pendingPolygonSelection; var mode = MODE_MAP[this.props.selectionType] || _editModes.ViewMode; var modeConfig = MODE_CONFIG_MAP[this.props.selectionType]; var inheritedProps = {}; PASS_THROUGH_PROPS.forEach(function (p) { if (_this2.props[p] !== undefined) inheritedProps[p] = _this2.props[p]; }); var layers = [new _editableGeojsonLayer["default"](this.getSubLayerProps(_objectSpread({ id: LAYER_ID_GEOJSON, pickable: true, mode: mode, modeConfig: modeConfig, selectedFeatureIndexes: [], data: EMPTY_DATA, onEdit: function onEdit(_ref) { var updatedData = _ref.updatedData, editType = _ref.editType; if (editType === 'addFeature') { var coordinates = updatedData.features[0].geometry.coordinates; if (_this2.props.selectionType === SELECTION_TYPE.RECTANGLE) { _this2._selectRectangleObjects(coordinates); } else if (_this2.props.selectionType === SELECTION_TYPE.POLYGON) { _this2._selectPolygonObjects(coordinates); } } } }, inheritedProps)))]; if (pendingPolygonSelection) { var bigPolygon = pendingPolygonSelection.bigPolygon; layers.push(new _layers.PolygonLayer( // @ts-ignore this.getSubLayerProps({ id: LAYER_ID_BLOCKER, pickable: true, stroked: false, opacity: 1.0, data: [bigPolygon], getLineColor: function getLineColor(obj) { return [0, 0, 0, 1]; }, getFillColor: function getFillColor(obj) { return [0, 0, 0, 1]; }, getPolygon: function getPolygon(o) { return o.geometry.coordinates; } }))); } return layers; } }, { key: "shouldUpdateState", value: function shouldUpdateState(_ref2) { var _ref2$changeFlags = _ref2.changeFlags, stateChanged = _ref2$changeFlags.stateChanged, propsOrDataChanged = _ref2$changeFlags.propsOrDataChanged; return stateChanged || propsOrDataChanged; } }]); return SelectionLayer; }(_core.CompositeLayer); exports["default"] = SelectionLayer; _defineProperty(SelectionLayer, "layerName", 'SelectionLayer'); _defineProperty(SelectionLayer, "defaultProps", defaultProps); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/layers/selection-layer.ts"],"names":["SELECTION_TYPE","NONE","RECTANGLE","POLYGON","MODE_MAP","DrawRectangleMode","DrawPolygonMode","MODE_CONFIG_MAP","dragToDraw","defaultProps","selectionType","layerIds","onSelect","EMPTY_DATA","type","features","EXPANSION_KM","LAYER_ID_GEOJSON","LAYER_ID_BLOCKER","PASS_THROUGH_PROPS","SelectionLayer","coordinates","props","context","viewport","project","x1","y1","x2","y2","pickingInfos","deck","pickObjects","x","Math","min","y","width","abs","height","mousePoints","map","c","allX","mousePoint","allY","maxX","max","maxY","landPointsPoly","bigBuffer","bigPolygon","e","console","log","setState","pendingPolygonSelection","blockerId","id","setTimeout","filter","item","layer","state","mode","ViewMode","modeConfig","inheritedProps","forEach","p","undefined","layers","EditableGeoJsonLayer","getSubLayerProps","pickable","selectedFeatureIndexes","data","onEdit","updatedData","editType","geometry","_selectRectangleObjects","_selectPolygonObjects","push","PolygonLayer","stroked","opacity","getLineColor","obj","getFillColor","getPolygon","o","changeFlags","stateChanged","propsOrDataChanged","CompositeLayer"],"mappings":";;;;;;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAEA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEO,IAAMA,cAAc,GAAG;AAC5BC,EAAAA,IAAI,EAAE,IADsB;AAE5BC,EAAAA,SAAS,EAAE,WAFiB;AAG5BC,EAAAA,OAAO,EAAE;AAHmB,CAAvB;;AAMP,IAAMC,QAAQ,+CACXJ,cAAc,CAACE,SADJ,EACgBG,4BADhB,8BAEXL,cAAc,CAACG,OAFJ,EAEcG,0BAFd,aAAd;;AAKA,IAAMC,eAAe,uBAClBP,cAAc,CAACE,SADG,EACS;AAAEM,EAAAA,UAAU,EAAE;AAAd,CADT,CAArB;;AAIA,IAAMC,YAAY,GAAG;AACnBC,EAAAA,aAAa,EAAEV,cAAc,CAACE,SADX;AAEnBS,EAAAA,QAAQ,EAAE,EAFS;AAGnBC,EAAAA,QAAQ,EAAE,oBAAM,CAAE;AAHC,CAArB;AAMA,IAAMC,UAAU,GAAG;AACjBC,EAAAA,IAAI,EAAE,mBADW;AAEjBC,EAAAA,QAAQ,EAAE;AAFO,CAAnB;AAKA,IAAMC,YAAY,GAAG,EAArB;AACA,IAAMC,gBAAgB,GAAG,mBAAzB;AACA,IAAMC,gBAAgB,GAAG,mBAAzB;AAEA,IAAMC,kBAAkB,GAAG,CACzB,gBADyB,EAEzB,oBAFyB,EAGzB,oBAHyB,EAIzB,gBAJyB,EAKzB,kBALyB,EAMzB,gBANyB,EAOzB,kBAPyB,EAQzB,sBARyB,EASzB,sBATyB,EAUzB,mBAVyB,EAWzB,cAXyB,EAYzB,cAZyB,EAazB,WAbyB,EAczB,cAdyB,EAezB,kBAfyB,EAgBzB,2BAhByB,EAiBzB,uBAjByB,EAkBzB,uBAlByB,EAmBzB,uBAnByB,CAA3B;;IAsBqBC,c;;;;;;;;;;;;;4CAIKC,W,EAAkB;AAAA,wBACT,KAAKC,KADI;AAAA,UAChCX,QADgC,eAChCA,QADgC;AAAA,UACtBC,QADsB,eACtBA,QADsB,EAExC;;AAFwC,kCAGvB,KAAKW,OAAL,CAAaC,QAAb,CAAsBC,OAAtB,CAA8BJ,WAAW,CAAC,CAAD,CAAX,CAAe,CAAf,CAA9B,CAHuB;AAAA;AAAA,UAGjCK,EAHiC;AAAA,UAG7BC,EAH6B,8BAIxC;;;AAJwC,mCAKvB,KAAKJ,OAAL,CAAaC,QAAb,CAAsBC,OAAtB,CAA8BJ,WAAW,CAAC,CAAD,CAAX,CAAe,CAAf,CAA9B,CALuB;AAAA;AAAA,UAKjCO,EALiC;AAAA,UAK7BC,EAL6B,8BAMxC;;;AACA,UAAMC,YAAY,GAAG,KAAKP,OAAL,CAAaQ,IAAb,CAAkBC,WAAlB,CAA8B;AACjDC,QAAAA,CAAC,EAAEC,IAAI,CAACC,GAAL,CAAST,EAAT,EAAaE,EAAb,CAD8C;AAEjDQ,QAAAA,CAAC,EAAEF,IAAI,CAACC,GAAL,CAASR,EAAT,EAAaE,EAAb,CAF8C;AAGjDQ,QAAAA,KAAK,EAAEH,IAAI,CAACI,GAAL,CAASV,EAAE,GAAGF,EAAd,CAH0C;AAIjDa,QAAAA,MAAM,EAAEL,IAAI,CAACI,GAAL,CAAST,EAAE,GAAGF,EAAd,CAJyC;AAKjDhB,QAAAA,QAAQ,EAARA;AALiD,OAA9B,CAArB;AAQAC,MAAAA,QAAQ,CAAC;AAAEkB,QAAAA,YAAY,EAAZA;AAAF,OAAD,CAAR;AACD;;;0CAEqBT,W,EAAkB;AAAA;;AAAA,yBACP,KAAKC,KADE;AAAA,UAC9BX,QAD8B,gBAC9BA,QAD8B;AAAA,UACpBC,QADoB,gBACpBA,QADoB,EAEtC;;AACA,UAAM4B,WAAW,GAAGnB,WAAW,CAAC,CAAD,CAAX,CAAeoB,GAAf,CAAmB,UAACC,CAAD;AAAA,eAAO,KAAI,CAACnB,OAAL,CAAaC,QAAb,CAAsBC,OAAtB,CAA8BiB,CAA9B,CAAP;AAAA,OAAnB,CAApB;AAEA,UAAMC,IAAI,GAAGH,WAAW,CAACC,GAAZ,CAAgB,UAACG,UAAD;AAAA,eAAgBA,UAAU,CAAC,CAAD,CAA1B;AAAA,OAAhB,CAAb;AACA,UAAMC,IAAI,GAAGL,WAAW,CAACC,GAAZ,CAAgB,UAACG,UAAD;AAAA,eAAgBA,UAAU,CAAC,CAAD,CAA1B;AAAA,OAAhB,CAAb;AACA,UAAMX,CAAC,GAAGC,IAAI,CAACC,GAAL,OAAAD,IAAI,qBAAQS,IAAR,EAAd;AACA,UAAMP,CAAC,GAAGF,IAAI,CAACC,GAAL,OAAAD,IAAI,qBAAQW,IAAR,EAAd;AACA,UAAMC,IAAI,GAAGZ,IAAI,CAACa,GAAL,OAAAb,IAAI,qBAAQS,IAAR,EAAjB;AACA,UAAMK,IAAI,GAAGd,IAAI,CAACa,GAAL,OAAAb,IAAI,qBAAQW,IAAR,EAAjB,CAVsC,CAYtC;AACA;;AACA,UAAMI,cAAc,GAAG,sBAAQ5B,WAAR,CAAvB;AACA,UAAM6B,SAAS,GAAG,wBAAWD,cAAX,EAA2BjC,YAA3B,CAAlB;AACA,UAAImC,UAAJ;;AACA,UAAI;AACF;AACA;AACAA,QAAAA,UAAU,GAAG,4BAAeD,SAAf,EAA0BD,cAA1B,CAAb;AACD,OAJD,CAIE,OAAOG,CAAP,EAAU;AACV;AACAC,QAAAA,OAAO,CAACC,GAAR,CAAY,wBAAZ,EAAsCF,CAAtC,EAFU,CAEgC;;AAC1C;AACD;;AAED,WAAKG,QAAL,CAAc;AACZC,QAAAA,uBAAuB,EAAE;AACvBL,UAAAA,UAAU,EAAVA;AADuB;AADb,OAAd;AAMA,UAAMM,SAAS,aAAM,KAAKnC,KAAL,CAAWoC,EAAjB,cAAuBxC,gBAAvB,CAAf,CAjCsC,CAmCtC;;AACAyC,MAAAA,UAAU,CAAC,YAAM;AACf;AACA,YAAM7B,YAAY,GAAG,KAAI,CAACP,OAAL,CAAaQ,IAAb,CAAkBC,WAAlB,CAA8B;AACjDC,UAAAA,CAAC,EAADA,CADiD;AAEjDG,UAAAA,CAAC,EAADA,CAFiD;AAGjDC,UAAAA,KAAK,EAAES,IAAI,GAAGb,CAHmC;AAIjDM,UAAAA,MAAM,EAAES,IAAI,GAAGZ,CAJkC;AAKjDzB,UAAAA,QAAQ,GAAG8C,SAAH,4BAAiB9C,QAAjB;AALyC,SAA9B,CAArB;;AAQAC,QAAAA,QAAQ,CAAC;AACPkB,UAAAA,YAAY,EAAEA,YAAY,CAAC8B,MAAb,CAAoB,UAACC,IAAD;AAAA,mBAAUA,IAAI,CAACC,KAAL,CAAWJ,EAAX,KAAkB,KAAI,CAACpC,KAAL,CAAWoC,EAAvC;AAAA,WAApB;AADP,SAAD,CAAR;AAGD,OAbS,EAaP,GAbO,CAAV;AAcD;;;mCAEc;AAAA;;AAAA,UACLF,uBADK,GACuB,KAAKO,KAD5B,CACLP,uBADK;AAGb,UAAMQ,IAAI,GAAG5D,QAAQ,CAAC,KAAKkB,KAAL,CAAWZ,aAAZ,CAAR,IAAsCuD,mBAAnD;AACA,UAAMC,UAAU,GAAG3D,eAAe,CAAC,KAAKe,KAAL,CAAWZ,aAAZ,CAAlC;AAEA,UAAMyD,cAAc,GAAG,EAAvB;AACAhD,MAAAA,kBAAkB,CAACiD,OAAnB,CAA2B,UAACC,CAAD,EAAO;AAChC,YAAI,MAAI,CAAC/C,KAAL,CAAW+C,CAAX,MAAkBC,SAAtB,EAAiCH,cAAc,CAACE,CAAD,CAAd,GAAoB,MAAI,CAAC/C,KAAL,CAAW+C,CAAX,CAApB;AAClC,OAFD;AAIA,UAAME,MAAM,GAAG,CACb,IAAIC,gCAAJ,CACE,KAAKC,gBAAL;AACEf,QAAAA,EAAE,EAAEzC,gBADN;AAEEyD,QAAAA,QAAQ,EAAE,IAFZ;AAGEV,QAAAA,IAAI,EAAJA,IAHF;AAIEE,QAAAA,UAAU,EAAVA,UAJF;AAKES,QAAAA,sBAAsB,EAAE,EAL1B;AAMEC,QAAAA,IAAI,EAAE/D,UANR;AAOEgE,QAAAA,MAAM,EAAE,sBAA+B;AAAA,cAA5BC,WAA4B,QAA5BA,WAA4B;AAAA,cAAfC,QAAe,QAAfA,QAAe;;AACrC,cAAIA,QAAQ,KAAK,YAAjB,EAA+B;AAAA,gBACrB1D,WADqB,GACLyD,WAAW,CAAC/D,QAAZ,CAAqB,CAArB,EAAwBiE,QADnB,CACrB3D,WADqB;;AAG7B,gBAAI,MAAI,CAACC,KAAL,CAAWZ,aAAX,KAA6BV,cAAc,CAACE,SAAhD,EAA2D;AACzD,cAAA,MAAI,CAAC+E,uBAAL,CAA6B5D,WAA7B;AACD,aAFD,MAEO,IAAI,MAAI,CAACC,KAAL,CAAWZ,aAAX,KAA6BV,cAAc,CAACG,OAAhD,EAAyD;AAC9D,cAAA,MAAI,CAAC+E,qBAAL,CAA2B7D,WAA3B;AACD;AACF;AACF;AAjBH,SAkBK8C,cAlBL,EADF,CADa,CAAf;;AAyBA,UAAIX,uBAAJ,EAA6B;AAAA,YACnBL,UADmB,GACJK,uBADI,CACnBL,UADmB;AAE3BoB,QAAAA,MAAM,CAACY,IAAP,CACE,IAAIC,oBAAJ,EACE;AACA,aAAKX,gBAAL,CAAsB;AACpBf,UAAAA,EAAE,EAAExC,gBADgB;AAEpBwD,UAAAA,QAAQ,EAAE,IAFU;AAGpBW,UAAAA,OAAO,EAAE,KAHW;AAIpBC,UAAAA,OAAO,EAAE,GAJW;AAKpBV,UAAAA,IAAI,EAAE,CAACzB,UAAD,CALc;AAMpBoC,UAAAA,YAAY,EAAE,sBAACC,GAAD;AAAA,mBAAS,CAAC,CAAD,EAAI,CAAJ,EAAO,CAAP,EAAU,CAAV,CAAT;AAAA,WANM;AAOpBC,UAAAA,YAAY,EAAE,sBAACD,GAAD;AAAA,mBAAS,CAAC,CAAD,EAAI,CAAJ,EAAO,CAAP,EAAU,CAAV,CAAT;AAAA,WAPM;AAQpBE,UAAAA,UAAU,EAAE,oBAACC,CAAD;AAAA,mBAAOA,CAAC,CAACX,QAAF,CAAW3D,WAAlB;AAAA;AARQ,SAAtB,CAFF,CADF;AAeD;;AAED,aAAOkD,MAAP;AACD;;;6CAE6F;AAAA,oCAA1EqB,WAA0E;AAAA,UAA3DC,YAA2D,qBAA3DA,YAA2D;AAAA,UAA7CC,kBAA6C,qBAA7CA,kBAA6C;AAC5F,aAAOD,YAAY,IAAIC,kBAAvB;AACD;;;;EAtIyCC,oB;;;;gBAAvB3E,c,eACA,gB;;gBADAA,c,kBAEGX,Y","sourcesContent":["/* eslint-env browser */\nimport { CompositeLayer } from '@deck.gl/core';\nimport { PolygonLayer } from '@deck.gl/layers';\nimport { polygon } from '@turf/helpers';\nimport turfBuffer from '@turf/buffer';\nimport turfDifference from '@turf/difference';\nimport { DrawRectangleMode, DrawPolygonMode, ViewMode } from '@nebula.gl/edit-modes';\n\nimport EditableGeoJsonLayer from './editable-geojson-layer';\n\nexport const SELECTION_TYPE = {\n  NONE: null,\n  RECTANGLE: 'rectangle',\n  POLYGON: 'polygon',\n};\n\nconst MODE_MAP = {\n  [SELECTION_TYPE.RECTANGLE]: DrawRectangleMode,\n  [SELECTION_TYPE.POLYGON]: DrawPolygonMode,\n};\n\nconst MODE_CONFIG_MAP = {\n  [SELECTION_TYPE.RECTANGLE]: { dragToDraw: true },\n};\n\nconst defaultProps = {\n  selectionType: SELECTION_TYPE.RECTANGLE,\n  layerIds: [],\n  onSelect: () => {},\n};\n\nconst EMPTY_DATA = {\n  type: 'FeatureCollection',\n  features: [],\n};\n\nconst EXPANSION_KM = 50;\nconst LAYER_ID_GEOJSON = 'selection-geojson';\nconst LAYER_ID_BLOCKER = 'selection-blocker';\n\nconst PASS_THROUGH_PROPS = [\n  'lineWidthScale',\n  'lineWidthMinPixels',\n  'lineWidthMaxPixels',\n  'lineWidthUnits',\n  'lineJointRounded',\n  'lineMiterLimit',\n  'pointRadiusScale',\n  'pointRadiusMinPixels',\n  'pointRadiusMaxPixels',\n  'lineDashJustified',\n  'getLineColor',\n  'getFillColor',\n  'getRadius',\n  'getLineWidth',\n  'getLineDashArray',\n  'getTentativeLineDashArray',\n  'getTentativeLineColor',\n  'getTentativeFillColor',\n  'getTentativeLineWidth',\n];\n\nexport default class SelectionLayer extends CompositeLayer<any> {\n  static layerName = 'SelectionLayer';\n  static defaultProps = defaultProps;\n\n  _selectRectangleObjects(coordinates: any) {\n    const { layerIds, onSelect } = this.props;\n    // @ts-ignore\n    const [x1, y1] = this.context.viewport.project(coordinates[0][0]);\n    // @ts-ignore\n    const [x2, y2] = this.context.viewport.project(coordinates[0][2]);\n    // @ts-ignore\n    const pickingInfos = this.context.deck.pickObjects({\n      x: Math.min(x1, x2),\n      y: Math.min(y1, y2),\n      width: Math.abs(x2 - x1),\n      height: Math.abs(y2 - y1),\n      layerIds,\n    });\n\n    onSelect({ pickingInfos });\n  }\n\n  _selectPolygonObjects(coordinates: any) {\n    const { layerIds, onSelect } = this.props;\n    // @ts-ignore\n    const mousePoints = coordinates[0].map((c) => this.context.viewport.project(c));\n\n    const allX = mousePoints.map((mousePoint) => mousePoint[0]);\n    const allY = mousePoints.map((mousePoint) => mousePoint[1]);\n    const x = Math.min(...allX);\n    const y = Math.min(...allY);\n    const maxX = Math.max(...allX);\n    const maxY = Math.max(...allY);\n\n    // Use a polygon to hide the outside, because pickObjects()\n    // does not support polygons\n    const landPointsPoly = polygon(coordinates);\n    const bigBuffer = turfBuffer(landPointsPoly, EXPANSION_KM);\n    let bigPolygon;\n    try {\n      // turfDifference throws an exception if the polygon\n      // intersects with itself (TODO: check if true in all versions)\n      bigPolygon = turfDifference(bigBuffer, landPointsPoly);\n    } catch (e) {\n      // invalid selection polygon\n      console.log('turfDifference() error', e); // eslint-disable-line\n      return;\n    }\n\n    this.setState({\n      pendingPolygonSelection: {\n        bigPolygon,\n      },\n    });\n\n    const blockerId = `${this.props.id}-${LAYER_ID_BLOCKER}`;\n\n    // HACK, find a better way\n    setTimeout(() => {\n      // @ts-ignore\n      const pickingInfos = this.context.deck.pickObjects({\n        x,\n        y,\n        width: maxX - x,\n        height: maxY - y,\n        layerIds: [blockerId, ...layerIds],\n      });\n\n      onSelect({\n        pickingInfos: pickingInfos.filter((item) => item.layer.id !== this.props.id),\n      });\n    }, 250);\n  }\n\n  renderLayers() {\n    const { pendingPolygonSelection } = this.state;\n\n    const mode = MODE_MAP[this.props.selectionType] || ViewMode;\n    const modeConfig = MODE_CONFIG_MAP[this.props.selectionType];\n\n    const inheritedProps = {};\n    PASS_THROUGH_PROPS.forEach((p) => {\n      if (this.props[p] !== undefined) inheritedProps[p] = this.props[p];\n    });\n\n    const layers = [\n      new EditableGeoJsonLayer(\n        this.getSubLayerProps({\n          id: LAYER_ID_GEOJSON,\n          pickable: true,\n          mode,\n          modeConfig,\n          selectedFeatureIndexes: [],\n          data: EMPTY_DATA,\n          onEdit: ({ updatedData, editType }) => {\n            if (editType === 'addFeature') {\n              const { coordinates } = updatedData.features[0].geometry;\n\n              if (this.props.selectionType === SELECTION_TYPE.RECTANGLE) {\n                this._selectRectangleObjects(coordinates);\n              } else if (this.props.selectionType === SELECTION_TYPE.POLYGON) {\n                this._selectPolygonObjects(coordinates);\n              }\n            }\n          },\n          ...inheritedProps,\n        })\n      ),\n    ];\n\n    if (pendingPolygonSelection) {\n      const { bigPolygon } = pendingPolygonSelection;\n      layers.push(\n        new PolygonLayer(\n          // @ts-ignore\n          this.getSubLayerProps({\n            id: LAYER_ID_BLOCKER,\n            pickable: true,\n            stroked: false,\n            opacity: 1.0,\n            data: [bigPolygon],\n            getLineColor: (obj) => [0, 0, 0, 1],\n            getFillColor: (obj) => [0, 0, 0, 1],\n            getPolygon: (o) => o.geometry.coordinates,\n          })\n        )\n      );\n    }\n\n    return layers;\n  }\n\n  shouldUpdateState({ changeFlags: { stateChanged, propsOrDataChanged } }: Record<string, any>) {\n    return stateChanged || propsOrDataChanged;\n  }\n}\n"]}