qwc2 2025.10.13 → 2025.10.14

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (241) hide show
  1. package/actions/display.js +30 -1
  2. package/actions/editing.js +22 -1
  3. package/actions/layerinfo.js +13 -1
  4. package/actions/layers.js +213 -3
  5. package/actions/localConfig.js +58 -1
  6. package/actions/locale.js +21 -1
  7. package/actions/locate.js +26 -1
  8. package/actions/logging.js +10 -1
  9. package/actions/map.js +105 -2
  10. package/actions/measurement.js +12 -1
  11. package/actions/processNotifications.js +37 -1
  12. package/actions/redlining.js +18 -1
  13. package/actions/redliningPick.js +12 -1
  14. package/actions/search.js +12 -1
  15. package/actions/serviceinfo.js +12 -1
  16. package/actions/task.js +55 -3
  17. package/actions/theme.js +339 -19
  18. package/actions/windows.js +164 -5
  19. package/components/AppMenu.js +435 -3
  20. package/components/AttributeForm.js +928 -32
  21. package/components/AttributeTableWidget.js +1105 -13
  22. package/components/AutoEditForm.js +189 -3
  23. package/components/CoordinateDisplayer.js +78 -2
  24. package/components/EditComboField.js +190 -6
  25. package/components/EditUploadField.js +315 -3
  26. package/components/ExportSelection.js +203 -2
  27. package/components/FullscreenSwitcher.js +90 -3
  28. package/components/Icon.js +81 -2
  29. package/components/IdentifyViewer.js +1161 -6
  30. package/components/ImportLayer.js +718 -20
  31. package/components/LayerInfoWindow.js +145 -2
  32. package/components/LinkFeatureForm.js +246 -5
  33. package/components/MapButton.js +88 -2
  34. package/components/MapSelection.js +287 -8
  35. package/components/MessageBar.js +68 -2
  36. package/components/NumericInputWindow.js +359 -2
  37. package/components/PickFeature.js +266 -2
  38. package/components/PluginsContainer.js +227 -8
  39. package/components/PrintSelection.js +620 -49
  40. package/components/ProcessNotifications.js +104 -2
  41. package/components/QtDesignerForm.js +1137 -18
  42. package/components/ResizeableWindow.js +591 -8
  43. package/components/SearchBox.js +1307 -20
  44. package/components/ServiceInfoWindow.js +107 -2
  45. package/components/SideBar.js +204 -4
  46. package/components/StandardApp.js +381 -20
  47. package/components/Swipeable.js +15 -1
  48. package/components/TaskBar.js +85 -2
  49. package/components/ThemeLayersListWindow.js +216 -4
  50. package/components/ThemeList.js +381 -7
  51. package/components/Toolbar.js +106 -2
  52. package/components/WindowManager.js +178 -2
  53. package/components/map/OlLayer.js +257 -6
  54. package/components/map/OlMap.js +405 -5
  55. package/components/map/layers/BingLayer.js +31 -2
  56. package/components/map/layers/GoogleLayer.js +222 -19
  57. package/components/map/layers/GraticuleLayer.js +21 -1
  58. package/components/map/layers/ImageLayer.js +15 -1
  59. package/components/map/layers/MVTLayer.js +52 -2
  60. package/components/map/layers/OSMLayer.js +24 -2
  61. package/components/map/layers/OverlayLayer.js +55 -3
  62. package/components/map/layers/VectorLayer.js +173 -8
  63. package/components/map/layers/WFSLayer.js +220 -6
  64. package/components/map/layers/WMSLayer.js +180 -6
  65. package/components/map/layers/WMTSLayer.js +67 -3
  66. package/components/map/layers/XYZLayer.js +24 -2
  67. package/components/map/layers/index.js +28 -1
  68. package/components/map3d/EditDataset3D.js +190 -3
  69. package/components/map3d/HeightProfile3D.js +402 -3
  70. package/components/map3d/ImportObjects3D.js +162 -2
  71. package/components/map3d/Map3D.js +1304 -38
  72. package/components/map3d/MapControls3D.js +392 -7
  73. package/components/map3d/SearchField3D.js +183 -11
  74. package/components/map3d/View3DSwitcher.js +98 -2
  75. package/components/map3d/drawtool/CreateTool3D.js +174 -4
  76. package/components/map3d/drawtool/EditTool3D.js +590 -6
  77. package/components/map3d/drawtool/NumericInput3D.js +336 -4
  78. package/components/map3d/layers/GeoTIFFLayer3D.js +15 -1
  79. package/components/map3d/layers/VectorLayer3D.js +53 -2
  80. package/components/map3d/layers/WFSLayer3D.js +109 -3
  81. package/components/map3d/layers/WMSLayer3D.js +70 -2
  82. package/components/map3d/layers/WMTSLayer3D.js +27 -3
  83. package/components/map3d/layers/index.js +14 -1
  84. package/components/map3d/utils/FirstPersonControls3D.js +423 -16
  85. package/components/map3d/utils/MiscUtils3D.js +221 -13
  86. package/components/map3d/utils/OrbitControls3D.js +176 -5
  87. package/components/map3d/utils/Tiles3DStyle.js +238 -9
  88. package/components/share/ShareLink.js +54 -2
  89. package/components/share/ShareQRCode.js +62 -2
  90. package/components/share/ShareSocials.js +125 -3
  91. package/components/timeline/FixedTimeline.js +236 -5
  92. package/components/timeline/InfiniteTimeline.js +347 -8
  93. package/components/timeline/TimelineFeaturesSlider.js +439 -5
  94. package/components/widgets/AccordeonWidget.js +96 -2
  95. package/components/widgets/ButtonBar.js +124 -2
  96. package/components/widgets/ColorButton.js +201 -3
  97. package/components/widgets/ComboBox.js +166 -2
  98. package/components/widgets/CopyButton.js +110 -2
  99. package/components/widgets/DateTimeInput.js +100 -3
  100. package/components/widgets/EditableSelect.js +230 -3
  101. package/components/widgets/FileSelector.js +128 -4
  102. package/components/widgets/Input.js +124 -2
  103. package/components/widgets/InputContainer.js +96 -2
  104. package/components/widgets/LayerCatalogWidget.js +219 -3
  105. package/components/widgets/MenuButton.js +157 -1
  106. package/components/widgets/ModalDialog.js +64 -2
  107. package/components/widgets/NavBar.js +119 -2
  108. package/components/widgets/NumberInput.js +226 -4
  109. package/components/widgets/PopupMenu.js +72 -1
  110. package/components/widgets/Primitives.js +6 -1
  111. package/components/widgets/ReCaptchaWidget.js +55 -1
  112. package/components/widgets/SearchWidget.js +255 -2
  113. package/components/widgets/Spinner.js +44 -2
  114. package/components/widgets/SuggestionInput.js +77 -2
  115. package/components/widgets/TextInput.js +308 -2
  116. package/components/widgets/ToggleSwitch.js +85 -2
  117. package/components/widgets/VectorLayerPicker.js +85 -3
  118. package/libs/openlayers.js +225 -5
  119. package/package.json +1 -1
  120. package/plugins/API.js +358 -15
  121. package/plugins/AttributeTable.js +109 -3
  122. package/plugins/Authentication.js +130 -5
  123. package/plugins/BackgroundSwitcher.js +218 -4
  124. package/plugins/Bookmark.js +289 -3
  125. package/plugins/BottomBar.js +298 -4
  126. package/plugins/CookiePopup.js +67 -3
  127. package/plugins/Cyclomedia.js +442 -5
  128. package/plugins/Editing.js +497 -9
  129. package/plugins/FeatureForm.js +366 -4
  130. package/plugins/FeatureSearch.js +458 -3
  131. package/plugins/GeometryDigitizer.js +664 -7
  132. package/plugins/HeightProfile.js +763 -15
  133. package/plugins/Help.js +102 -3
  134. package/plugins/HomeButton.js +80 -3
  135. package/plugins/Identify.js +543 -5
  136. package/plugins/LayerCatalog.js +215 -4
  137. package/plugins/LayerTree.js +1194 -6
  138. package/plugins/LocateButton.js +94 -3
  139. package/plugins/Map.js +320 -16
  140. package/plugins/MapCompare.js +94 -3
  141. package/plugins/MapCopyright.js +127 -5
  142. package/plugins/MapExport.js +613 -20
  143. package/plugins/MapFilter.js +868 -12
  144. package/plugins/MapInfoTooltip.js +277 -3
  145. package/plugins/MapLegend.js +253 -4
  146. package/plugins/MapTip.js +290 -4
  147. package/plugins/Measure.js +220 -4
  148. package/plugins/NewsPopup.js +137 -3
  149. package/plugins/OverviewMap.js +167 -7
  150. package/plugins/Panoramax.js +340 -2
  151. package/plugins/Portal.js +199 -4
  152. package/plugins/Print.js +1231 -15
  153. package/plugins/Redlining.js +750 -6
  154. package/plugins/Reports.js +332 -3
  155. package/plugins/Routing.js +1278 -15
  156. package/plugins/ScratchDrawing.js +173 -5
  157. package/plugins/Settings.js +241 -4
  158. package/plugins/Share.js +198 -3
  159. package/plugins/StartupMarker.js +84 -4
  160. package/plugins/TaskButton.js +88 -3
  161. package/plugins/ThemeSwitcher.js +164 -4
  162. package/plugins/TimeManager.js +971 -10
  163. package/plugins/TopBar.js +300 -7
  164. package/plugins/TourGuide.js +213 -2
  165. package/plugins/ValueTool.js +419 -4
  166. package/plugins/View3D.js +519 -14
  167. package/plugins/ZoomButtons.js +165 -3
  168. package/plugins/map/EditingSupport.js +199 -7
  169. package/plugins/map/LocateSupport.js +260 -4
  170. package/plugins/map/MeasurementSupport.js +216 -8
  171. package/plugins/map/RedliningPickSupport.js +201 -7
  172. package/plugins/map/RedliningSupport.js +726 -17
  173. package/plugins/map/SnapInteraction.js +101 -1
  174. package/plugins/map/SnapSupport.js +210 -2
  175. package/plugins/map/SnappingSupport.js +356 -17
  176. package/plugins/map3d/BackgroundSwitcher3D.js +44 -3
  177. package/plugins/map3d/BottomBar3D.js +118 -3
  178. package/plugins/map3d/Compare3D.js +422 -8
  179. package/plugins/map3d/Draw3D.js +353 -6
  180. package/plugins/map3d/ExportObjects3D.js +393 -18
  181. package/plugins/map3d/HideObjects3D.js +313 -12
  182. package/plugins/map3d/Identify3D.js +283 -12
  183. package/plugins/map3d/LayerTree3D.js +323 -3
  184. package/plugins/map3d/MapCopyright3D.js +128 -5
  185. package/plugins/map3d/MapExport3D.js +590 -10
  186. package/plugins/map3d/MapLight3D.js +553 -6
  187. package/plugins/map3d/Measure3D.js +571 -20
  188. package/plugins/map3d/OverviewMap3D.js +169 -3
  189. package/plugins/map3d/Settings3D.js +73 -3
  190. package/plugins/map3d/TopBar3D.js +207 -9
  191. package/plugins/redlining/RedliningBufferSupport.js +206 -3
  192. package/reducers/display.js +34 -2
  193. package/reducers/editing.js +68 -3
  194. package/reducers/index.js +9 -1
  195. package/reducers/layerinfo.js +26 -2
  196. package/reducers/layers.js +456 -9
  197. package/reducers/localConfig.js +122 -2
  198. package/reducers/locale.js +38 -2
  199. package/reducers/locate.js +40 -2
  200. package/reducers/map.js +176 -5
  201. package/reducers/measurement.js +42 -2
  202. package/reducers/processNotifications.js +49 -2
  203. package/reducers/redlining.js +50 -2
  204. package/reducers/redliningPick.js +27 -2
  205. package/reducers/search.js +20 -1
  206. package/reducers/serviceinfo.js +25 -2
  207. package/reducers/task.js +45 -2
  208. package/reducers/theme.js +51 -2
  209. package/reducers/windows.js +203 -2
  210. package/scripts/dist.sh +1 -1
  211. package/scripts/gen-plugin-docs.js +152 -2
  212. package/scripts/makeIconkit.js +85 -6
  213. package/scripts/themesConfig.js +742 -40
  214. package/scripts/updateTranslations.js +251 -10
  215. package/selectors/searchproviders.js +44 -2
  216. package/stores/StandardStore.js +42 -2
  217. package/utils/ConfigUtils.js +84 -3
  218. package/utils/CoordinatesUtils.js +234 -23
  219. package/utils/DxfUtils.js +237 -11
  220. package/utils/EditingInterface.js +421 -87
  221. package/utils/EditingUtils.js +357 -13
  222. package/utils/ElevationInterface.js +83 -22
  223. package/utils/FeatureStyles.js +429 -5
  224. package/utils/IdentifyUtils.js +443 -7
  225. package/utils/ImageEditor.js +79 -9
  226. package/utils/LayerUtils.js +1516 -50
  227. package/utils/LocaleUtils.js +117 -7
  228. package/utils/MapUtils.js +241 -59
  229. package/utils/MeasureUtils.js +323 -2
  230. package/utils/MiscUtils.js +189 -11
  231. package/utils/PermaLinkUtils.js +429 -6
  232. package/utils/PluginStore.js +27 -1
  233. package/utils/ResourceRegistry.js +15 -1
  234. package/utils/RoutingInterface.js +307 -7
  235. package/utils/SearchProviders.js +722 -19
  236. package/utils/ServiceLayerUtils.js +669 -14
  237. package/utils/Signal.js +32 -2
  238. package/utils/ThemeUtils.js +341 -7
  239. package/utils/VectorLayerUtils.js +589 -15
  240. package/utils/expr_grammar/grammar.js +2239 -2
  241. package/utils/expr_grammar/test.js +65 -3
@@ -1,12 +1,397 @@
1
- function _typeof(o){"@babel/helpers - typeof";return _typeof="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(o){return typeof o}:function(o){return o&&"function"==typeof Symbol&&o.constructor===Symbol&&o!==Symbol.prototype?"symbol":typeof o},_typeof(o)}function _construct(t,e,r){if(_isNativeReflectConstruct())return Reflect.construct.apply(null,arguments);var o=[null];o.push.apply(o,e);var p=new(t.bind.apply(t,o));return r&&_setPrototypeOf(p,r.prototype),p}function _toConsumableArray(r){return _arrayWithoutHoles(r)||_iterableToArray(r)||_unsupportedIterableToArray(r)||_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(r,a){if(r){if("string"==typeof r)return _arrayLikeToArray(r,a);var t={}.toString.call(r).slice(8,-1);return"Object"===t&&r.constructor&&(t=r.constructor.name),"Map"===t||"Set"===t?Array.from(r):"Arguments"===t||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t)?_arrayLikeToArray(r,a):void 0}}function _iterableToArray(r){if("undefined"!=typeof Symbol&&null!=r[Symbol.iterator]||null!=r["@@iterator"])return Array.from(r)}function _arrayWithoutHoles(r){if(Array.isArray(r))return _arrayLikeToArray(r)}function _arrayLikeToArray(r,a){(null==a||a>r.length)&&(a=r.length);for(var e=0,n=Array(a);e<a;e++)n[e]=r[e];return n}function _classCallCheck(a,n){if(!(a instanceof n))throw new TypeError("Cannot call a class as a function")}function _defineProperties(e,r){for(var t=0;t<r.length;t++){var o=r[t];o.enumerable=o.enumerable||!1,o.configurable=!0,"value"in o&&(o.writable=!0),Object.defineProperty(e,_toPropertyKey(o.key),o)}}function _createClass(e,r,t){return r&&_defineProperties(e.prototype,r),t&&_defineProperties(e,t),Object.defineProperty(e,"prototype",{writable:!1}),e}function _callSuper(t,o,e){return o=_getPrototypeOf(o),_possibleConstructorReturn(t,_isNativeReflectConstruct()?Reflect.construct(o,e||[],_getPrototypeOf(t).constructor):o.apply(t,e))}function _possibleConstructorReturn(t,e){if(e&&("object"==_typeof(e)||"function"==typeof e))return e;if(void 0!==e)throw new TypeError("Derived constructors may only return object or undefined");return _assertThisInitialized(t)}function _assertThisInitialized(e){if(void 0===e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return e}function _isNativeReflectConstruct(){try{var t=!Boolean.prototype.valueOf.call(Reflect.construct(Boolean,[],function(){}))}catch(t){}return(_isNativeReflectConstruct=function _isNativeReflectConstruct(){return!!t})()}function _getPrototypeOf(t){return _getPrototypeOf=Object.setPrototypeOf?Object.getPrototypeOf.bind():function(t){return t.__proto__||Object.getPrototypeOf(t)},_getPrototypeOf(t)}function _inherits(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),Object.defineProperty(t,"prototype",{writable:!1}),e&&_setPrototypeOf(t,e)}function _setPrototypeOf(t,e){return _setPrototypeOf=Object.setPrototypeOf?Object.setPrototypeOf.bind():function(t,e){return t.__proto__=e,t},_setPrototypeOf(t,e)}function _defineProperty(e,r,t){return(r=_toPropertyKey(r))in e?Object.defineProperty(e,r,{value:t,enumerable:!0,configurable:!0,writable:!0}):e[r]=t,e}function _toPropertyKey(t){var i=_toPrimitive(t,"string");return"symbol"==_typeof(i)?i:i+""}function _toPrimitive(t,r){if("object"!=_typeof(t)||!t)return t;var e=t[Symbol.toPrimitive];if(void 0!==e){var i=e.call(t,r||"default");if("object"!=_typeof(i))return i;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===r?String:Number)(t)}/**
1
+ function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
2
+ function _construct(t, e, r) { if (_isNativeReflectConstruct()) return Reflect.construct.apply(null, arguments); var o = [null]; o.push.apply(o, e); var p = new (t.bind.apply(t, o))(); return r && _setPrototypeOf(p, r.prototype), p; }
3
+ function _toConsumableArray(r) { return _arrayWithoutHoles(r) || _iterableToArray(r) || _unsupportedIterableToArray(r) || _nonIterableSpread(); }
4
+ 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."); }
5
+ function _unsupportedIterableToArray(r, a) { if (r) { if ("string" == typeof r) return _arrayLikeToArray(r, a); var t = {}.toString.call(r).slice(8, -1); return "Object" === t && r.constructor && (t = r.constructor.name), "Map" === t || "Set" === t ? Array.from(r) : "Arguments" === t || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(t) ? _arrayLikeToArray(r, a) : void 0; } }
6
+ function _iterableToArray(r) { if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); }
7
+ function _arrayWithoutHoles(r) { if (Array.isArray(r)) return _arrayLikeToArray(r); }
8
+ function _arrayLikeToArray(r, a) { (null == a || a > r.length) && (a = r.length); for (var e = 0, n = Array(a); e < a; e++) n[e] = r[e]; return n; }
9
+ function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); }
10
+ function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } }
11
+ function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; }
12
+ function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); }
13
+ function _possibleConstructorReturn(t, e) { if (e && ("object" == _typeof(e) || "function" == typeof e)) return e; if (void 0 !== e) throw new TypeError("Derived constructors may only return object or undefined"); return _assertThisInitialized(t); }
14
+ function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; }
15
+ function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }
16
+ function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); }
17
+ function _inherits(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function"); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, writable: !0, configurable: !0 } }), Object.defineProperty(t, "prototype", { writable: !1 }), e && _setPrototypeOf(t, e); }
18
+ function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); }
19
+ function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
20
+ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
21
+ function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
22
+ /**
2
23
  * Copyright 2024 Sourcepole AG
3
24
  * All rights reserved.
4
25
  *
5
26
  * This source code is licensed under the BSD-style license found in the
6
27
  * LICENSE file in the root directory of this source tree.
7
- */import React from"react";import ReactDOM from"react-dom";import{connect}from"react-redux";import classNames from"classnames";import PropTypes from"prop-types";import{MOUSE,Vector3}from"three";import ConfigUtils from"../../utils/ConfigUtils";import{UrlParams}from"../../utils/PermaLinkUtils";import Icon from"../Icon";import{MapButtonPortalContext}from"../PluginsContainer";import FirstPersonControls3D from"./utils/FirstPersonControls3D";import OrbitControls3D from"./utils/OrbitControls3D";import"./style/MapControls3D.css";// FIXME: camera.fov is 30, but in reality seems to be 50 (as would be the threejs default)
8
- var CAMERA_FOV=50;var MapControls3D=/*#__PURE__*/function(_React$Component){function MapControls3D(props){var _buttonMap$_this$prop,_buttonMap$_this$prop2,_buttonMap$_this$prop3;var _this;_classCallCheck(this,MapControls3D);_this=_callSuper(this,MapControls3D,[props]);_defineProperty(_this,"state",{pickingFirstPerson:false,firstPerson:false});_defineProperty(_this,"unload",function(el){// componentWillUnmount is called too early, so do cleanup when the element is actually removed
9
- if(!el){_this.controls.removeEventListener("change",_this.updateControlsTarget);_this.fpcontrols.removeEventListener("change",_this.updateFpUrlParams);if(_this.state.firstPerson){_this.fpcontrols.disconnect()}else{_this.controls.disconnect()}_this.props.sceneContext.scene.domElement.removeEventListener("dblclick",_this.switchToFirstPersonView)}});_defineProperty(_this,"switchToFirstPersonView",function(ev){// Don't do anything if a task is set, may interfere
10
- if(!_this.props.currentTask&&!_this.state.firstPerson){_this.setupFirstPerson(ev)}});_defineProperty(_this,"toggleFirstPersonControls",function(){if(_this.state.firstPerson){_this.leaveFirstPerson()}else if(_this.state.pickingFirstPerson){_this.props.sceneContext.scene.domElement.removeEventListener("click",_this.setupFirstPerson);_this.props.sceneContext.scene.domElement.style.cursor="";_this.setState({pickingFirstPerson:false})}else{_this.props.sceneContext.scene.domElement.addEventListener("click",_this.setupFirstPerson,{once:true});var cursor=ConfigUtils.getAssetsPath()+"/img/person.svg";_this.props.sceneContext.scene.domElement.style.cursor="url(".concat(cursor,"), pointer");_this.setState({pickingFirstPerson:true})}});_defineProperty(_this,"setupFirstPerson",function(ev){_this.props.sceneContext.scene.domElement.style.cursor="";var rect=ev.target.getBoundingClientRect();var mouseX=(ev.clientX-rect.left)/rect.width*2-1;var mouseY=-((ev.clientY-rect.top)/rect.height)*2+1;var intersection=_this.props.sceneContext.getSceneIntersection(mouseX,mouseY,false);if(!intersection){return}var pos=intersection.point;_this.props.sceneContext.getTerrainHeightFromDTM([pos.x,pos.y]).then(function(z){var camerapos=new Vector3(pos.x,pos.y,z+_this.fpcontrols.personHeight);var targetpos=new Vector3(pos.x,pos.y+300,z+_this.fpcontrols.personHeight);_this.controls.animateTo(camerapos,targetpos,0,function(){_this.controls.disconnect();_this.fpcontrols.connect(_this.props.sceneContext);_this.fpcontrols.setView(camerapos,new Vector3(0,1,0));_this.setState({firstPerson:true,pickingFirstPerson:false})})})});_defineProperty(_this,"leaveFirstPerson",function(){if(_this.state.firstPerson){_this.setState({firstPerson:false},function(){// Need to ensure this.state.firstPerson is false to avoid endless loop
11
- var camerapos=_this.props.sceneContext.scene.view.camera.position;_this.fpcontrols.disconnect();_this.controls.connect(_this.props.sceneContext);_this.controls.setView(camerapos,new Vector3().addVectors(camerapos,_this.fpcontrols.lookAt));var bounds=[camerapos.x-750,camerapos.y-750,camerapos.x+750,camerapos.y+750];_this.setViewToExtent(bounds)})}});_defineProperty(_this,"home",function(){var extent=_this.props.sceneContext.map.extent;var bounds=[extent.west,extent.south,extent.east,extent.north];_this.setViewToExtent(bounds)});_defineProperty(_this,"setViewToExtent",function(bounds){var angle=arguments.length>1&&arguments[1]!==undefined?arguments[1]:0;_this.leaveFirstPerson();var fov=CAMERA_FOV/180*Math.PI;var cameraHeight=(bounds[2]-bounds[0])/(2*Math.tan(fov/2));var center={x:0.5*(bounds[0]+bounds[2]),y:0.5*(bounds[1]+bounds[3])};var camerapos=new Vector3(center.x,center.y,cameraHeight);var target=new Vector3(center.x,center.y,0);var h=_this.props.sceneContext.getTerrainHeightFromMap([center.x,center.y]);// Fall back to getTerrainHeightFromDTM if map is not yet loaded
12
- if(h===undefined){_this.props.sceneContext.getTerrainHeightFromDTM([center.x,center.y]).then(function(h2){camerapos.z+=h2;target.z+=h2;_this.controls.animateTo(camerapos,target,angle)})}else{camerapos.z+=h;target.z+=h;_this.controls.animateTo(camerapos,target,angle)}});_defineProperty(_this,"pan",function(ev,dx,dy){var panInterval=setInterval(function(){_this.props.sceneContext.scene.view.controls.panView(dx,dy)},50);ev.view.addEventListener("pointerup",function(){clearInterval(panInterval)},{once:true})});_defineProperty(_this,"tilt",function(ev,azimuth,polar){var tiltInterval=setInterval(function(){_this.props.sceneContext.scene.view.controls.tiltView(azimuth,polar)},50);ev.view.addEventListener("pointerup",function(){clearInterval(tiltInterval)},{once:true})});_defineProperty(_this,"resetTilt",function(){var camerapos=_this.props.sceneContext.scene.view.camera.position;if(_this.state.firstPerson){var newLookAt=_this.fpcontrols.lookAt.clone();newLookAt.z=0;_this.fpcontrols.setView(camerapos,newLookAt.normalize())}else{var target=_this.controls.target;var newcamerapos=new Vector3(target.x,target.y,target.distanceTo(camerapos));_this.controls.animateTo(newcamerapos,target,0)}});_defineProperty(_this,"zoom",function(ev,delta){var zoomInterval=setInterval(function(){var camerapos=_this.props.sceneContext.scene.view.camera.position;var target=_this.controls.target;var k=Math.min(150,Math.sqrt(target.distanceTo(camerapos)));_this.props.sceneContext.scene.view.controls.zoomView(delta*k)},50);ev.view.addEventListener("pointerup",function(){clearInterval(zoomInterval)},{once:true})});_defineProperty(_this,"updateUrlParams",function(){var cpos=_this.props.sceneContext.scene.view.camera.position;var tpos=_this.controls.target;UrlParams.updateParams({v3d:[cpos.x,cpos.y,cpos.z,tpos.x,tpos.y,tpos.z,0].map(function(v){return v.toFixed(1)}).join(",")});_this.props.onCameraChanged([tpos.x,tpos.y,tpos.z],[cpos.x,cpos.y,cpos.z],CAMERA_FOV)});_defineProperty(_this,"updateFpUrlParams",function(){var cpos=_this.fpcontrols.target;var lkat=_this.fpcontrols.lookAt;var h=_this.fpcontrols.personHeight;UrlParams.updateParams({v3d:[cpos.x,cpos.y,cpos.z,lkat.x,lkat.y,lkat.z,h].map(function(v){return v.toFixed(1)}).join(",")});_this.props.onCameraChanged([cpos.x,cpos.y,cpos.z],null)});_defineProperty(_this,"restoreView",function(viewState){if(viewState.camera&&viewState.target){var camera=_construct(Vector3,_toConsumableArray(viewState.camera));var target=_construct(Vector3,_toConsumableArray(viewState.target));if(viewState.personHeight>0){_this.controls.disconnect();_this.fpcontrols.connect(_this.props.sceneContext);_this.fpcontrols.setView(camera,target,viewState.personHeight);_this.setState({firstPerson:true})}else{_this.controls.setView(camera,target)}}});var sceneElement=props.sceneContext.scene.domElement;sceneElement.tabIndex=0;var buttonMap={pan:MOUSE.PAN,rotate:MOUSE.ROTATE,zoom:MOUSE.DOLLY};var mouseButtons={LEFT:(_buttonMap$_this$prop=buttonMap[_this.props.mouseButtons.left])!==null&&_buttonMap$_this$prop!==void 0?_buttonMap$_this$prop:null,MIDDLE:(_buttonMap$_this$prop2=buttonMap[_this.props.mouseButtons.middle])!==null&&_buttonMap$_this$prop2!==void 0?_buttonMap$_this$prop2:null,RIGHT:(_buttonMap$_this$prop3=buttonMap[_this.props.mouseButtons.right])!==null&&_buttonMap$_this$prop3!==void 0?_buttonMap$_this$prop3:null};_this.controls=new OrbitControls3D(props.sceneContext.scene.view.camera,mouseButtons);_this.fpcontrols=new FirstPersonControls3D(props.sceneContext.scene.view.camera,mouseButtons);_this.controls.connect(props.sceneContext);var targetPos=props.sceneContext.scene.view.camera.position.clone();targetPos.z=0;_this.controls.target=targetPos;_this.controls.addEventListener("change",_this.updateUrlParams);_this.fpcontrols.addEventListener("change",_this.updateFpUrlParams);sceneElement.addEventListener("dblclick",_this.switchToFirstPersonView);props.onControlsSet(_this);_this.updateUrlParams();return _this}_inherits(MapControls3D,_React$Component);return _createClass(MapControls3D,[{key:"render",value:function render(){var _this2=this;var firstPersonButtonClasses=classNames({"map3d-firstperson-button":true,"map3d-firstperson-button-active":this.state.firstPerson});return[this.props.children,/*#__PURE__*/ReactDOM.createPortal(/*#__PURE__*/React.createElement("div",{className:"map3d-nav-pan","data-slot":0,key:"MapControlsPan",style:{order:1000}},/*#__PURE__*/React.createElement("span",null),/*#__PURE__*/React.createElement(Icon,{icon:"chevron-up",onPointerDown:function onPointerDown(ev){return _this2.pan(ev,0,1)}}),/*#__PURE__*/React.createElement("span",null),/*#__PURE__*/React.createElement(Icon,{icon:"chevron-left",onPointerDown:function onPointerDown(ev){return _this2.pan(ev,-1,0)}}),/*#__PURE__*/React.createElement(Icon,{icon:"home",onClick:function onClick(){return _this2.home()}}),/*#__PURE__*/React.createElement(Icon,{icon:"chevron-right",onPointerDown:function onPointerDown(ev){return _this2.pan(ev,1,0)}}),/*#__PURE__*/React.createElement("span",null),/*#__PURE__*/React.createElement(Icon,{icon:"chevron-down",onPointerDown:function onPointerDown(ev){return _this2.pan(ev,0,-1)}}),/*#__PURE__*/React.createElement("span",null)),this.context),/*#__PURE__*/ReactDOM.createPortal(/*#__PURE__*/React.createElement("div",{className:"map3d-nav-rotate","data-slot":0,key:"MapControlsRotate",style:{order:999}},/*#__PURE__*/React.createElement("span",null),/*#__PURE__*/React.createElement(Icon,{icon:"tilt-up",onPointerDown:function onPointerDown(ev){return _this2.tilt(ev,0,0.1)}}),/*#__PURE__*/React.createElement("span",null),/*#__PURE__*/React.createElement(Icon,{icon:"tilt-left",onPointerDown:function onPointerDown(ev){return _this2.tilt(ev,0.1,0)}}),/*#__PURE__*/React.createElement(Icon,{icon:"point",onClick:function onClick(){return _this2.resetTilt()}}),/*#__PURE__*/React.createElement(Icon,{icon:"tilt-right",onPointerDown:function onPointerDown(ev){return _this2.tilt(ev,-0.1,0)}}),/*#__PURE__*/React.createElement("span",null),/*#__PURE__*/React.createElement(Icon,{icon:"tilt-down",onPointerDown:function onPointerDown(ev){return _this2.tilt(ev,0,-0.1)}}),/*#__PURE__*/React.createElement("span",null)),this.context),/*#__PURE__*/ReactDOM.createPortal(!this.state.firstPerson?/*#__PURE__*/React.createElement("div",{className:"map3d-nav-zoom","data-slot":0,key:"MapControlsSpacerZoom",style:{order:998}},/*#__PURE__*/React.createElement("div",{onPointerDown:function onPointerDown(ev){return _this2.zoom(ev,+1)}},/*#__PURE__*/React.createElement(Icon,{icon:"plus"})),/*#__PURE__*/React.createElement("div",{onPointerDown:function onPointerDown(ev){return _this2.zoom(ev,-1)}},/*#__PURE__*/React.createElement(Icon,{icon:"minus"}))):null,this.context),/*#__PURE__*/ReactDOM.createPortal(/*#__PURE__*/React.createElement("div",{className:firstPersonButtonClasses,"data-slot":0,key:"MapControlsFirstPerson",onClick:this.toggleFirstPersonControls,style:{order:997}},/*#__PURE__*/React.createElement(Icon,{icon:"person"})),this.context),this.props.controlsPosition!=="bottom"?/*#__PURE__*/ReactDOM.createPortal(/*#__PURE__*/React.createElement("div",{className:"map3d-nav-spacer",key:"MapControlsSpacer",style:{order:996}}),this.context):null]}}])}(React.Component);_defineProperty(MapControls3D,"contextType",MapButtonPortalContext);_defineProperty(MapControls3D,"propTypes",{children:PropTypes.oneOfType([PropTypes.node,PropTypes.func]),controlsPosition:PropTypes.string,currentTask:PropTypes.string,mouseButtons:PropTypes.object,onCameraChanged:PropTypes.func,onControlsSet:PropTypes.func,sceneContext:PropTypes.object});export default connect(function(state){return{currentTask:state.task.id}},{})(MapControls3D);
28
+ */
29
+
30
+ import React from 'react';
31
+ import ReactDOM from 'react-dom';
32
+ import { connect } from 'react-redux';
33
+ import classNames from 'classnames';
34
+ import PropTypes from 'prop-types';
35
+ import { MOUSE, Vector3 } from 'three';
36
+ import ConfigUtils from '../../utils/ConfigUtils';
37
+ import { UrlParams } from '../../utils/PermaLinkUtils';
38
+ import Icon from '../Icon';
39
+ import { MapButtonPortalContext } from '../PluginsContainer';
40
+ import FirstPersonControls3D from './utils/FirstPersonControls3D';
41
+ import OrbitControls3D from './utils/OrbitControls3D';
42
+ import './style/MapControls3D.css';
43
+
44
+ // FIXME: camera.fov is 30, but in reality seems to be 50 (as would be the threejs default)
45
+ var CAMERA_FOV = 50;
46
+ var MapControls3D = /*#__PURE__*/function (_React$Component) {
47
+ function MapControls3D(props) {
48
+ var _buttonMap$_this$prop, _buttonMap$_this$prop2, _buttonMap$_this$prop3;
49
+ var _this;
50
+ _classCallCheck(this, MapControls3D);
51
+ _this = _callSuper(this, MapControls3D, [props]);
52
+ _defineProperty(_this, "state", {
53
+ pickingFirstPerson: false,
54
+ firstPerson: false
55
+ });
56
+ _defineProperty(_this, "unload", function (el) {
57
+ // componentWillUnmount is called too early, so do cleanup when the element is actually removed
58
+ if (!el) {
59
+ _this.controls.removeEventListener('change', _this.updateControlsTarget);
60
+ _this.fpcontrols.removeEventListener('change', _this.updateFpUrlParams);
61
+ if (_this.state.firstPerson) {
62
+ _this.fpcontrols.disconnect();
63
+ } else {
64
+ _this.controls.disconnect();
65
+ }
66
+ _this.props.sceneContext.scene.domElement.removeEventListener('dblclick', _this.switchToFirstPersonView);
67
+ }
68
+ });
69
+ _defineProperty(_this, "switchToFirstPersonView", function (ev) {
70
+ // Don't do anything if a task is set, may interfere
71
+ if (!_this.props.currentTask && !_this.state.firstPerson) {
72
+ _this.setupFirstPerson(ev);
73
+ }
74
+ });
75
+ _defineProperty(_this, "toggleFirstPersonControls", function () {
76
+ if (_this.state.firstPerson) {
77
+ _this.leaveFirstPerson();
78
+ } else if (_this.state.pickingFirstPerson) {
79
+ _this.props.sceneContext.scene.domElement.removeEventListener('click', _this.setupFirstPerson);
80
+ _this.props.sceneContext.scene.domElement.style.cursor = '';
81
+ _this.setState({
82
+ pickingFirstPerson: false
83
+ });
84
+ } else {
85
+ _this.props.sceneContext.scene.domElement.addEventListener('click', _this.setupFirstPerson, {
86
+ once: true
87
+ });
88
+ var cursor = ConfigUtils.getAssetsPath() + "/img/person.svg";
89
+ _this.props.sceneContext.scene.domElement.style.cursor = "url(".concat(cursor, "), pointer");
90
+ _this.setState({
91
+ pickingFirstPerson: true
92
+ });
93
+ }
94
+ });
95
+ _defineProperty(_this, "setupFirstPerson", function (ev) {
96
+ _this.props.sceneContext.scene.domElement.style.cursor = '';
97
+ var rect = ev.target.getBoundingClientRect();
98
+ var mouseX = (ev.clientX - rect.left) / rect.width * 2 - 1;
99
+ var mouseY = -((ev.clientY - rect.top) / rect.height) * 2 + 1;
100
+ var intersection = _this.props.sceneContext.getSceneIntersection(mouseX, mouseY, false);
101
+ if (!intersection) {
102
+ return;
103
+ }
104
+ var pos = intersection.point;
105
+ _this.props.sceneContext.getTerrainHeightFromDTM([pos.x, pos.y]).then(function (z) {
106
+ var camerapos = new Vector3(pos.x, pos.y, z + _this.fpcontrols.personHeight);
107
+ var targetpos = new Vector3(pos.x, pos.y + 300, z + _this.fpcontrols.personHeight);
108
+ _this.controls.animateTo(camerapos, targetpos, 0, function () {
109
+ _this.controls.disconnect();
110
+ _this.fpcontrols.connect(_this.props.sceneContext);
111
+ _this.fpcontrols.setView(camerapos, new Vector3(0, 1, 0));
112
+ _this.setState({
113
+ firstPerson: true,
114
+ pickingFirstPerson: false
115
+ });
116
+ });
117
+ });
118
+ });
119
+ _defineProperty(_this, "leaveFirstPerson", function () {
120
+ if (_this.state.firstPerson) {
121
+ _this.setState({
122
+ firstPerson: false
123
+ }, function () {
124
+ // Need to ensure this.state.firstPerson is false to avoid endless loop
125
+ var camerapos = _this.props.sceneContext.scene.view.camera.position;
126
+ _this.fpcontrols.disconnect();
127
+ _this.controls.connect(_this.props.sceneContext);
128
+ _this.controls.setView(camerapos, new Vector3().addVectors(camerapos, _this.fpcontrols.lookAt));
129
+ var bounds = [camerapos.x - 750, camerapos.y - 750, camerapos.x + 750, camerapos.y + 750];
130
+ _this.setViewToExtent(bounds);
131
+ });
132
+ }
133
+ });
134
+ _defineProperty(_this, "home", function () {
135
+ var extent = _this.props.sceneContext.map.extent;
136
+ var bounds = [extent.west, extent.south, extent.east, extent.north];
137
+ _this.setViewToExtent(bounds);
138
+ });
139
+ _defineProperty(_this, "setViewToExtent", function (bounds) {
140
+ var angle = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 0;
141
+ _this.leaveFirstPerson();
142
+ var fov = CAMERA_FOV / 180 * Math.PI;
143
+ var cameraHeight = (bounds[2] - bounds[0]) / (2 * Math.tan(fov / 2));
144
+ var center = {
145
+ x: 0.5 * (bounds[0] + bounds[2]),
146
+ y: 0.5 * (bounds[1] + bounds[3])
147
+ };
148
+ var camerapos = new Vector3(center.x, center.y, cameraHeight);
149
+ var target = new Vector3(center.x, center.y, 0);
150
+ var h = _this.props.sceneContext.getTerrainHeightFromMap([center.x, center.y]);
151
+ // Fall back to getTerrainHeightFromDTM if map is not yet loaded
152
+ if (h === undefined) {
153
+ _this.props.sceneContext.getTerrainHeightFromDTM([center.x, center.y]).then(function (h2) {
154
+ camerapos.z += h2;
155
+ target.z += h2;
156
+ _this.controls.animateTo(camerapos, target, angle);
157
+ });
158
+ } else {
159
+ camerapos.z += h;
160
+ target.z += h;
161
+ _this.controls.animateTo(camerapos, target, angle);
162
+ }
163
+ });
164
+ _defineProperty(_this, "pan", function (ev, dx, dy) {
165
+ var panInterval = setInterval(function () {
166
+ _this.props.sceneContext.scene.view.controls.panView(dx, dy);
167
+ }, 50);
168
+ ev.view.addEventListener('pointerup', function () {
169
+ clearInterval(panInterval);
170
+ }, {
171
+ once: true
172
+ });
173
+ });
174
+ _defineProperty(_this, "tilt", function (ev, azimuth, polar) {
175
+ var tiltInterval = setInterval(function () {
176
+ _this.props.sceneContext.scene.view.controls.tiltView(azimuth, polar);
177
+ }, 50);
178
+ ev.view.addEventListener('pointerup', function () {
179
+ clearInterval(tiltInterval);
180
+ }, {
181
+ once: true
182
+ });
183
+ });
184
+ _defineProperty(_this, "resetTilt", function () {
185
+ var camerapos = _this.props.sceneContext.scene.view.camera.position;
186
+ if (_this.state.firstPerson) {
187
+ var newLookAt = _this.fpcontrols.lookAt.clone();
188
+ newLookAt.z = 0;
189
+ _this.fpcontrols.setView(camerapos, newLookAt.normalize());
190
+ } else {
191
+ var target = _this.controls.target;
192
+ var newcamerapos = new Vector3(target.x, target.y, target.distanceTo(camerapos));
193
+ _this.controls.animateTo(newcamerapos, target, 0);
194
+ }
195
+ });
196
+ _defineProperty(_this, "zoom", function (ev, delta) {
197
+ var zoomInterval = setInterval(function () {
198
+ var camerapos = _this.props.sceneContext.scene.view.camera.position;
199
+ var target = _this.controls.target;
200
+ var k = Math.min(150, Math.sqrt(target.distanceTo(camerapos)));
201
+ _this.props.sceneContext.scene.view.controls.zoomView(delta * k);
202
+ }, 50);
203
+ ev.view.addEventListener('pointerup', function () {
204
+ clearInterval(zoomInterval);
205
+ }, {
206
+ once: true
207
+ });
208
+ });
209
+ _defineProperty(_this, "updateUrlParams", function () {
210
+ var cpos = _this.props.sceneContext.scene.view.camera.position;
211
+ var tpos = _this.controls.target;
212
+ UrlParams.updateParams({
213
+ v3d: [cpos.x, cpos.y, cpos.z, tpos.x, tpos.y, tpos.z, 0].map(function (v) {
214
+ return v.toFixed(1);
215
+ }).join(",")
216
+ });
217
+ _this.props.onCameraChanged([tpos.x, tpos.y, tpos.z], [cpos.x, cpos.y, cpos.z], CAMERA_FOV);
218
+ });
219
+ _defineProperty(_this, "updateFpUrlParams", function () {
220
+ var cpos = _this.fpcontrols.target;
221
+ var lkat = _this.fpcontrols.lookAt;
222
+ var h = _this.fpcontrols.personHeight;
223
+ UrlParams.updateParams({
224
+ v3d: [cpos.x, cpos.y, cpos.z, lkat.x, lkat.y, lkat.z, h].map(function (v) {
225
+ return v.toFixed(1);
226
+ }).join(",")
227
+ });
228
+ _this.props.onCameraChanged([cpos.x, cpos.y, cpos.z], null);
229
+ });
230
+ _defineProperty(_this, "restoreView", function (viewState) {
231
+ if (viewState.camera && viewState.target) {
232
+ var camera = _construct(Vector3, _toConsumableArray(viewState.camera));
233
+ var target = _construct(Vector3, _toConsumableArray(viewState.target));
234
+ if (viewState.personHeight > 0) {
235
+ _this.controls.disconnect();
236
+ _this.fpcontrols.connect(_this.props.sceneContext);
237
+ _this.fpcontrols.setView(camera, target, viewState.personHeight);
238
+ _this.setState({
239
+ firstPerson: true
240
+ });
241
+ } else {
242
+ _this.controls.setView(camera, target);
243
+ }
244
+ }
245
+ });
246
+ var sceneElement = props.sceneContext.scene.domElement;
247
+ sceneElement.tabIndex = 0;
248
+ var buttonMap = {
249
+ pan: MOUSE.PAN,
250
+ rotate: MOUSE.ROTATE,
251
+ zoom: MOUSE.DOLLY
252
+ };
253
+ var mouseButtons = {
254
+ LEFT: (_buttonMap$_this$prop = buttonMap[_this.props.mouseButtons.left]) !== null && _buttonMap$_this$prop !== void 0 ? _buttonMap$_this$prop : null,
255
+ MIDDLE: (_buttonMap$_this$prop2 = buttonMap[_this.props.mouseButtons.middle]) !== null && _buttonMap$_this$prop2 !== void 0 ? _buttonMap$_this$prop2 : null,
256
+ RIGHT: (_buttonMap$_this$prop3 = buttonMap[_this.props.mouseButtons.right]) !== null && _buttonMap$_this$prop3 !== void 0 ? _buttonMap$_this$prop3 : null
257
+ };
258
+ _this.controls = new OrbitControls3D(props.sceneContext.scene.view.camera, mouseButtons);
259
+ _this.fpcontrols = new FirstPersonControls3D(props.sceneContext.scene.view.camera, mouseButtons);
260
+ _this.controls.connect(props.sceneContext);
261
+ var targetPos = props.sceneContext.scene.view.camera.position.clone();
262
+ targetPos.z = 0;
263
+ _this.controls.target = targetPos;
264
+ _this.controls.addEventListener('change', _this.updateUrlParams);
265
+ _this.fpcontrols.addEventListener('change', _this.updateFpUrlParams);
266
+ sceneElement.addEventListener('dblclick', _this.switchToFirstPersonView);
267
+ props.onControlsSet(_this);
268
+ _this.updateUrlParams();
269
+ return _this;
270
+ }
271
+ _inherits(MapControls3D, _React$Component);
272
+ return _createClass(MapControls3D, [{
273
+ key: "render",
274
+ value: function render() {
275
+ var _this2 = this;
276
+ var firstPersonButtonClasses = classNames({
277
+ "map3d-firstperson-button": true,
278
+ "map3d-firstperson-button-active": this.state.firstPerson
279
+ });
280
+ return [this.props.children, /*#__PURE__*/ReactDOM.createPortal(/*#__PURE__*/React.createElement("div", {
281
+ className: "map3d-nav-pan",
282
+ "data-slot": 0,
283
+ key: "MapControlsPan",
284
+ style: {
285
+ order: 1000
286
+ }
287
+ }, /*#__PURE__*/React.createElement("span", null), /*#__PURE__*/React.createElement(Icon, {
288
+ icon: "chevron-up",
289
+ onPointerDown: function onPointerDown(ev) {
290
+ return _this2.pan(ev, 0, 1);
291
+ }
292
+ }), /*#__PURE__*/React.createElement("span", null), /*#__PURE__*/React.createElement(Icon, {
293
+ icon: "chevron-left",
294
+ onPointerDown: function onPointerDown(ev) {
295
+ return _this2.pan(ev, -1, 0);
296
+ }
297
+ }), /*#__PURE__*/React.createElement(Icon, {
298
+ icon: "home",
299
+ onClick: function onClick() {
300
+ return _this2.home();
301
+ }
302
+ }), /*#__PURE__*/React.createElement(Icon, {
303
+ icon: "chevron-right",
304
+ onPointerDown: function onPointerDown(ev) {
305
+ return _this2.pan(ev, 1, 0);
306
+ }
307
+ }), /*#__PURE__*/React.createElement("span", null), /*#__PURE__*/React.createElement(Icon, {
308
+ icon: "chevron-down",
309
+ onPointerDown: function onPointerDown(ev) {
310
+ return _this2.pan(ev, 0, -1);
311
+ }
312
+ }), /*#__PURE__*/React.createElement("span", null)), this.context), /*#__PURE__*/ReactDOM.createPortal(/*#__PURE__*/React.createElement("div", {
313
+ className: "map3d-nav-rotate",
314
+ "data-slot": 0,
315
+ key: "MapControlsRotate",
316
+ style: {
317
+ order: 999
318
+ }
319
+ }, /*#__PURE__*/React.createElement("span", null), /*#__PURE__*/React.createElement(Icon, {
320
+ icon: "tilt-up",
321
+ onPointerDown: function onPointerDown(ev) {
322
+ return _this2.tilt(ev, 0, 0.1);
323
+ }
324
+ }), /*#__PURE__*/React.createElement("span", null), /*#__PURE__*/React.createElement(Icon, {
325
+ icon: "tilt-left",
326
+ onPointerDown: function onPointerDown(ev) {
327
+ return _this2.tilt(ev, 0.1, 0);
328
+ }
329
+ }), /*#__PURE__*/React.createElement(Icon, {
330
+ icon: "point",
331
+ onClick: function onClick() {
332
+ return _this2.resetTilt();
333
+ }
334
+ }), /*#__PURE__*/React.createElement(Icon, {
335
+ icon: "tilt-right",
336
+ onPointerDown: function onPointerDown(ev) {
337
+ return _this2.tilt(ev, -0.1, 0);
338
+ }
339
+ }), /*#__PURE__*/React.createElement("span", null), /*#__PURE__*/React.createElement(Icon, {
340
+ icon: "tilt-down",
341
+ onPointerDown: function onPointerDown(ev) {
342
+ return _this2.tilt(ev, 0, -0.1);
343
+ }
344
+ }), /*#__PURE__*/React.createElement("span", null)), this.context), /*#__PURE__*/ReactDOM.createPortal(!this.state.firstPerson ? /*#__PURE__*/React.createElement("div", {
345
+ className: "map3d-nav-zoom",
346
+ "data-slot": 0,
347
+ key: "MapControlsSpacerZoom",
348
+ style: {
349
+ order: 998
350
+ }
351
+ }, /*#__PURE__*/React.createElement("div", {
352
+ onPointerDown: function onPointerDown(ev) {
353
+ return _this2.zoom(ev, +1);
354
+ }
355
+ }, /*#__PURE__*/React.createElement(Icon, {
356
+ icon: "plus"
357
+ })), /*#__PURE__*/React.createElement("div", {
358
+ onPointerDown: function onPointerDown(ev) {
359
+ return _this2.zoom(ev, -1);
360
+ }
361
+ }, /*#__PURE__*/React.createElement(Icon, {
362
+ icon: "minus"
363
+ }))) : null, this.context), /*#__PURE__*/ReactDOM.createPortal(/*#__PURE__*/React.createElement("div", {
364
+ className: firstPersonButtonClasses,
365
+ "data-slot": 0,
366
+ key: "MapControlsFirstPerson",
367
+ onClick: this.toggleFirstPersonControls,
368
+ style: {
369
+ order: 997
370
+ }
371
+ }, /*#__PURE__*/React.createElement(Icon, {
372
+ icon: "person"
373
+ })), this.context), this.props.controlsPosition !== 'bottom' ? /*#__PURE__*/ReactDOM.createPortal(/*#__PURE__*/React.createElement("div", {
374
+ className: "map3d-nav-spacer",
375
+ key: "MapControlsSpacer",
376
+ style: {
377
+ order: 996
378
+ }
379
+ }), this.context) : null];
380
+ }
381
+ }]);
382
+ }(React.Component);
383
+ _defineProperty(MapControls3D, "contextType", MapButtonPortalContext);
384
+ _defineProperty(MapControls3D, "propTypes", {
385
+ children: PropTypes.oneOfType([PropTypes.node, PropTypes.func]),
386
+ controlsPosition: PropTypes.string,
387
+ currentTask: PropTypes.string,
388
+ mouseButtons: PropTypes.object,
389
+ onCameraChanged: PropTypes.func,
390
+ onControlsSet: PropTypes.func,
391
+ sceneContext: PropTypes.object
392
+ });
393
+ export default connect(function (state) {
394
+ return {
395
+ currentTask: state.task.id
396
+ };
397
+ }, {})(MapControls3D);