qwc2 2025.10.9 → 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,7 +1,112 @@
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 _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 _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); }
3
+ 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); } }
4
+ function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; }
5
+ function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); }
6
+ 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); }
7
+ function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; }
8
+ function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }
9
+ function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); }
10
+ 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); }
11
+ function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); }
12
+ 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; }
13
+ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
14
+ 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); }
15
+ /**
2
16
  * Copyright 2020-2024 Sourcepole AG
3
17
  * All rights reserved.
4
18
  *
5
19
  * This source code is licensed under the BSD-style license found in the
6
20
  * LICENSE file in the root directory of this source tree.
7
- */import React from"react";import{connect}from"react-redux";import DOMPurify from"dompurify";import PropTypes from"prop-types";import{setActiveServiceInfo}from"../actions/serviceinfo";import ResizeableWindow from"../components/ResizeableWindow";import LocaleUtils from"../utils/LocaleUtils";import MiscUtils from"../utils/MiscUtils";import"./style/ServiceInfoWindow.css";var ServiceInfoWindow=/*#__PURE__*/function(_React$Component){function ServiceInfoWindow(){var _this;_classCallCheck(this,ServiceInfoWindow);for(var _len=arguments.length,args=new Array(_len),_key=0;_key<_len;_key++){args[_key]=arguments[_key]}_this=_callSuper(this,ServiceInfoWindow,[].concat(args));_defineProperty(_this,"renderRow",function(title,content){var html=arguments.length>2&&arguments[2]!==undefined?arguments[2]:false;if(content){return/*#__PURE__*/React.createElement("tr",null,/*#__PURE__*/React.createElement("td",null,title,":"),html?/*#__PURE__*/React.createElement("td",{dangerouslySetInnerHTML:{__html:MiscUtils.addLinkAnchors(DOMPurify.sanitize(content))}}):/*#__PURE__*/React.createElement("td",null,content))}return null});_defineProperty(_this,"onClose",function(){_this.props.setActiveServiceInfo(null)});return _this}_inherits(ServiceInfoWindow,_React$Component);return _createClass(ServiceInfoWindow,[{key:"renderLink",value:function renderLink(text,url){if(url){return/*#__PURE__*/React.createElement("a",{href:url,rel:"noreferrer",target:"_blank"},text)}else if(text){return text}return null}},{key:"render",value:function render(){var _this$props$service$c,_this$props$service$c2,_this$props$service$c3,_this$props$service$c4,_this$props$service$c5;if(!this.props.service){return null}return/*#__PURE__*/React.createElement(ResizeableWindow,{icon:"info-sign",initialHeight:this.props.layerInfoGeometry.initialHeight,initialWidth:this.props.layerInfoGeometry.initialWidth,initialX:this.props.layerInfoGeometry.initialX,initialY:this.props.layerInfoGeometry.initialY,initiallyDocked:this.props.layerInfoGeometry.initiallyDocked,onClose:this.onClose,title:LocaleUtils.tr("serviceinfo.title")},/*#__PURE__*/React.createElement("div",{className:"service-info-window-body",role:"body"},/*#__PURE__*/React.createElement("h4",{className:"service-info-window-title"},this.props.service.title),/*#__PURE__*/React.createElement("div",{className:"service-info-window-frame"},/*#__PURE__*/React.createElement("table",{className:"service-info-window-table"},/*#__PURE__*/React.createElement("tbody",null,this.renderRow(LocaleUtils.tr("serviceinfo.abstract"),this.props.service["abstract"],true),this.renderRow(LocaleUtils.tr("serviceinfo.keywords"),this.props.service.keywords),this.renderRow(LocaleUtils.tr("serviceinfo.onlineResource"),this.renderLink(this.props.service.onlineResource,this.props.service.onlineResource)),this.renderRow(LocaleUtils.tr("serviceinfo.contactPerson"),(_this$props$service$c=this.props.service.contact)===null||_this$props$service$c===void 0?void 0:_this$props$service$c.person),this.renderRow(LocaleUtils.tr("serviceinfo.contactOrganization"),(_this$props$service$c2=this.props.service.contact)===null||_this$props$service$c2===void 0?void 0:_this$props$service$c2.organization),this.renderRow(LocaleUtils.tr("serviceinfo.contactPosition"),(_this$props$service$c3=this.props.service.contact)===null||_this$props$service$c3===void 0?void 0:_this$props$service$c3.position),this.renderRow(LocaleUtils.tr("serviceinfo.contactPhone"),(_this$props$service$c4=this.props.service.contact)===null||_this$props$service$c4===void 0?void 0:_this$props$service$c4.phone),this.renderRow(LocaleUtils.tr("serviceinfo.contactEmail"),(_this$props$service$c5=this.props.service.contact)===null||_this$props$service$c5===void 0?void 0:_this$props$service$c5.email))))))}}])}(React.Component);_defineProperty(ServiceInfoWindow,"propTypes",{layerInfoGeometry:PropTypes.object,service:PropTypes.object,setActiveServiceInfo:PropTypes.func});var selector=function selector(state){return{service:state.serviceinfo.service}};export default connect(selector,{setActiveServiceInfo:setActiveServiceInfo})(ServiceInfoWindow);
21
+ */
22
+
23
+ import React from 'react';
24
+ import { connect } from 'react-redux';
25
+ import DOMPurify from 'dompurify';
26
+ import PropTypes from 'prop-types';
27
+ import { setActiveServiceInfo } from '../actions/serviceinfo';
28
+ import ResizeableWindow from '../components/ResizeableWindow';
29
+ import LocaleUtils from '../utils/LocaleUtils';
30
+ import MiscUtils from '../utils/MiscUtils';
31
+ import './style/ServiceInfoWindow.css';
32
+ var ServiceInfoWindow = /*#__PURE__*/function (_React$Component) {
33
+ function ServiceInfoWindow() {
34
+ var _this;
35
+ _classCallCheck(this, ServiceInfoWindow);
36
+ for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
37
+ args[_key] = arguments[_key];
38
+ }
39
+ _this = _callSuper(this, ServiceInfoWindow, [].concat(args));
40
+ _defineProperty(_this, "renderRow", function (title, content) {
41
+ var html = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : false;
42
+ if (content) {
43
+ return /*#__PURE__*/React.createElement("tr", null, /*#__PURE__*/React.createElement("td", null, title, ":"), html ? /*#__PURE__*/React.createElement("td", {
44
+ dangerouslySetInnerHTML: {
45
+ __html: MiscUtils.addLinkAnchors(DOMPurify.sanitize(content))
46
+ }
47
+ }) : /*#__PURE__*/React.createElement("td", null, content));
48
+ }
49
+ return null;
50
+ });
51
+ _defineProperty(_this, "onClose", function () {
52
+ _this.props.setActiveServiceInfo(null);
53
+ });
54
+ return _this;
55
+ }
56
+ _inherits(ServiceInfoWindow, _React$Component);
57
+ return _createClass(ServiceInfoWindow, [{
58
+ key: "renderLink",
59
+ value: function renderLink(text, url) {
60
+ if (url) {
61
+ return /*#__PURE__*/React.createElement("a", {
62
+ href: url,
63
+ rel: "noreferrer",
64
+ target: "_blank"
65
+ }, text);
66
+ } else if (text) {
67
+ return text;
68
+ }
69
+ return null;
70
+ }
71
+ }, {
72
+ key: "render",
73
+ value: function render() {
74
+ var _this$props$service$c, _this$props$service$c2, _this$props$service$c3, _this$props$service$c4, _this$props$service$c5;
75
+ if (!this.props.service) {
76
+ return null;
77
+ }
78
+ return /*#__PURE__*/React.createElement(ResizeableWindow, {
79
+ icon: "info-sign",
80
+ initialHeight: this.props.layerInfoGeometry.initialHeight,
81
+ initialWidth: this.props.layerInfoGeometry.initialWidth,
82
+ initialX: this.props.layerInfoGeometry.initialX,
83
+ initialY: this.props.layerInfoGeometry.initialY,
84
+ initiallyDocked: this.props.layerInfoGeometry.initiallyDocked,
85
+ onClose: this.onClose,
86
+ title: LocaleUtils.tr("serviceinfo.title")
87
+ }, /*#__PURE__*/React.createElement("div", {
88
+ className: "service-info-window-body",
89
+ role: "body"
90
+ }, /*#__PURE__*/React.createElement("h4", {
91
+ className: "service-info-window-title"
92
+ }, this.props.service.title), /*#__PURE__*/React.createElement("div", {
93
+ className: "service-info-window-frame"
94
+ }, /*#__PURE__*/React.createElement("table", {
95
+ className: "service-info-window-table"
96
+ }, /*#__PURE__*/React.createElement("tbody", null, this.renderRow(LocaleUtils.tr("serviceinfo.abstract"), this.props.service["abstract"], true), this.renderRow(LocaleUtils.tr("serviceinfo.keywords"), this.props.service.keywords), this.renderRow(LocaleUtils.tr("serviceinfo.onlineResource"), this.renderLink(this.props.service.onlineResource, this.props.service.onlineResource)), this.renderRow(LocaleUtils.tr("serviceinfo.contactPerson"), (_this$props$service$c = this.props.service.contact) === null || _this$props$service$c === void 0 ? void 0 : _this$props$service$c.person), this.renderRow(LocaleUtils.tr("serviceinfo.contactOrganization"), (_this$props$service$c2 = this.props.service.contact) === null || _this$props$service$c2 === void 0 ? void 0 : _this$props$service$c2.organization), this.renderRow(LocaleUtils.tr("serviceinfo.contactPosition"), (_this$props$service$c3 = this.props.service.contact) === null || _this$props$service$c3 === void 0 ? void 0 : _this$props$service$c3.position), this.renderRow(LocaleUtils.tr("serviceinfo.contactPhone"), (_this$props$service$c4 = this.props.service.contact) === null || _this$props$service$c4 === void 0 ? void 0 : _this$props$service$c4.phone), this.renderRow(LocaleUtils.tr("serviceinfo.contactEmail"), (_this$props$service$c5 = this.props.service.contact) === null || _this$props$service$c5 === void 0 ? void 0 : _this$props$service$c5.email))))));
97
+ }
98
+ }]);
99
+ }(React.Component);
100
+ _defineProperty(ServiceInfoWindow, "propTypes", {
101
+ layerInfoGeometry: PropTypes.object,
102
+ service: PropTypes.object,
103
+ setActiveServiceInfo: PropTypes.func
104
+ });
105
+ var selector = function selector(state) {
106
+ return {
107
+ service: state.serviceinfo.service
108
+ };
109
+ };
110
+ export default connect(selector, {
111
+ setActiveServiceInfo: setActiveServiceInfo
112
+ })(ServiceInfoWindow);
@@ -1,9 +1,209 @@
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 _readOnlyError(r){throw new TypeError("\""+r+"\" is read-only")}function ownKeys(e,r){var t=Object.keys(e);if(Object.getOwnPropertySymbols){var o=Object.getOwnPropertySymbols(e);r&&(o=o.filter(function(r){return Object.getOwnPropertyDescriptor(e,r).enumerable})),t.push.apply(t,o)}return t}function _objectSpread(e){for(var r=1;r<arguments.length;r++){var t=null!=arguments[r]?arguments[r]:{};r%2?ownKeys(Object(t),!0).forEach(function(r){_defineProperty(e,r,t[r])}):Object.getOwnPropertyDescriptors?Object.defineProperties(e,Object.getOwnPropertyDescriptors(t)):ownKeys(Object(t)).forEach(function(r){Object.defineProperty(e,r,Object.getOwnPropertyDescriptor(t,r))})}return e}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 _readOnlyError(r) { throw new TypeError('"' + r + '" is read-only'); }
3
+ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
4
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
5
+ function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); }
6
+ 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); } }
7
+ function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; }
8
+ function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); }
9
+ 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); }
10
+ function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; }
11
+ function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }
12
+ function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); }
13
+ 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); }
14
+ function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); }
15
+ 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; }
16
+ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
17
+ 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); }
18
+ /**
2
19
  * Copyright 2016-2024 Sourcepole AG
3
20
  * All rights reserved.
4
21
  *
5
22
  * This source code is licensed under the BSD-style license found in the
6
23
  * 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{setCurrentTask}from"../actions/task";import Icon from"./Icon";import{MapContainerPortalContext}from"./PluginsContainer";import{Swipeable}from"./Swipeable";import"./style/SideBar.css";var SideBar=/*#__PURE__*/function(_React$Component){function SideBar(props){var _this;_classCallCheck(this,SideBar);_this=_callSuper(this,SideBar,[props]);_defineProperty(_this,"state",{render:false});_defineProperty(_this,"closeClicked",function(){if(_this.props.currentTask.id===_this.props.id){_this.props.setCurrentTask(null)}});_defineProperty(_this,"renderRole",function(role){var children=typeof _this.props.children==="function"?_this.props.children():React.Children.toArray(_this.props.children).reduce(function(res,child){return _objectSpread(_objectSpread({},res),{},_defineProperty({},child.props.role,child))},{});return children[role]});_defineProperty(_this,"setRef",function(el){_this.sidebar=el});_defineProperty(_this,"startSidebarResize",function(ev){var startWidth=_this.sidebar.offsetWidth;var startMouseX=ev.clientX;var sign=_this.props.side==="left"?-1:1;var resizeSidebar=function resizeSidebar(event){_this.sidebar.style.width=startWidth+sign*(startMouseX-event.clientX)+"px"};ev.view.document.body.style.userSelect="none";ev.view.addEventListener("pointermove",resizeSidebar);ev.view.addEventListener("pointerup",function(){ev.view.document.body.style.userSelect="";ev.view.removeEventListener("pointermove",resizeSidebar)},{once:true})});_defineProperty(_this,"startSidebarBottomResize",function(ev){var startHeight=_this.sidebar.offsetHeight;var startMouseY=ev.clientY;var resizeSidebar=function resizeSidebar(event){_this.sidebar.style.height=Math.max(64,startHeight+(event.clientY-startMouseY))+"px"};ev.view.document.body.style.userSelect="none";ev.view.addEventListener("pointermove",resizeSidebar);ev.view.addEventListener("pointerup",function(){ev.view.document.body.style.userSelect="";ev.view.removeEventListener("pointermove",resizeSidebar)},{once:true})});_this.state.render=props.currentTask&&props.currentTask.id===props.id;_this.sidebar=null;return _this}_inherits(SideBar,_React$Component);return _createClass(SideBar,[{key:"componentDidUpdate",value:function componentDidUpdate(prevProps){var _this2=this;var newVisible=this.props.currentTask&&this.props.currentTask.id===this.props.id;var oldVisible=prevProps.currentTask&&prevProps.currentTask.id===prevProps.id;if(newVisible&&(!oldVisible||this.props.currentTask.mode!==prevProps.currentTask.mode)){this.setState({render:true});this.props.onShow(this.props.currentTask.mode)}else if(!newVisible&&oldVisible){this.props.onHide();// Hide the element after the transition period (see SideBar.css)
8
- setTimeout(function(){_this2.setState({render:false})},300)}if(!this.props.heightResizeable&&prevProps.heightResizeable){this.sidebar.style.height=""}}},{key:"render",value:function render(){var visible=this.props.currentTask.id===this.props.id;var render=visible||this.state.render;var style={width:this.props.width,minWidth:this.props.minWidth,zIndex:visible?5:4};var isLeftSide=this.props.side==="left";var classes=classnames({"sidebar":true,"sidebar-open":visible,"sidebar-left":isLeftSide,"sidebar-right":!isLeftSide});var closeIcon=isLeftSide?"chevron-left":"chevron-right";var body=null;var extra=null;if(render){body=this.renderRole("body");extra=this.renderRole("extra")}return/*#__PURE__*/ReactDOM.createPortal(/*#__PURE__*/React.createElement("div",null,/*#__PURE__*/React.createElement(Swipeable,{delta:30,onSwipedRight:this.closeClicked},/*#__PURE__*/React.createElement("div",{className:"".concat(classes," ").concat(this.props.extraClasses),id:this.props.id,ref:this.setRef,style:style},/*#__PURE__*/React.createElement("div",{className:"sidebar-resize-handle sidebar-resize-handle-"+this.props.side,onPointerDown:this.startSidebarResize}),/*#__PURE__*/React.createElement("div",{className:"sidebar-titlebar"},this.state.render?this.props.extraBeforeContent:null,/*#__PURE__*/React.createElement(Icon,{className:"sidebar-titlebar-icon",icon:this.props.icon,size:"large"}),/*#__PURE__*/React.createElement("span",{className:"sidebar-titlebar-title"},this.props.title),this.state.render?this.props.extraTitlebarContent:null,/*#__PURE__*/React.createElement("span",{className:"sidebar-titlebar-spacer"}),/*#__PURE__*/React.createElement(Icon,{className:"sidebar-titlebar-closeicon",icon:closeIcon,onClick:this.closeClicked})),/*#__PURE__*/React.createElement("div",{className:"sidebar-body"},body),this.props.heightResizeable?/*#__PURE__*/React.createElement("div",{className:"sidebar-resize-handle-bottom",onPointerDown:this.startSidebarBottomResize}):null)),extra),this.context)}}])}(React.Component);_defineProperty(SideBar,"contextType",MapContainerPortalContext);_defineProperty(SideBar,"propTypes",{children:PropTypes.oneOfType([PropTypes.node,PropTypes.func]),currentTask:PropTypes.object,extraBeforeContent:PropTypes.object,extraClasses:PropTypes.string,extraTitlebarContent:PropTypes.object,heightResizeable:PropTypes.bool,icon:PropTypes.string,id:PropTypes.string.isRequired,minWidth:PropTypes.string,onHide:PropTypes.func,onShow:PropTypes.func,setCurrentTask:PropTypes.func,side:PropTypes.string,title:PropTypes.string,width:PropTypes.string});_defineProperty(SideBar,"defaultProps",{extraClasses:"",onShow:function onShow(){},onHide:function onHide(){},width:"15em",minWidth:"15em",// allowed values are 'left' and 'right'
9
- side:"right"});export default connect(function(state){return{currentTask:state.task}},{setCurrentTask:setCurrentTask})(SideBar);
24
+ */
25
+
26
+ import React from 'react';
27
+ import ReactDOM from 'react-dom';
28
+ import { connect } from 'react-redux';
29
+ import classnames from 'classnames';
30
+ import PropTypes from 'prop-types';
31
+ import { setCurrentTask } from '../actions/task';
32
+ import Icon from './Icon';
33
+ import { MapContainerPortalContext } from './PluginsContainer';
34
+ import { Swipeable } from './Swipeable';
35
+ import './style/SideBar.css';
36
+ var SideBar = /*#__PURE__*/function (_React$Component) {
37
+ function SideBar(props) {
38
+ var _this;
39
+ _classCallCheck(this, SideBar);
40
+ _this = _callSuper(this, SideBar, [props]);
41
+ _defineProperty(_this, "state", {
42
+ render: false
43
+ });
44
+ _defineProperty(_this, "closeClicked", function () {
45
+ if (_this.props.currentTask.id === _this.props.id) {
46
+ _this.props.setCurrentTask(null);
47
+ }
48
+ });
49
+ _defineProperty(_this, "renderRole", function (role) {
50
+ var children = typeof _this.props.children === "function" ? _this.props.children() : React.Children.toArray(_this.props.children).reduce(function (res, child) {
51
+ return _objectSpread(_objectSpread({}, res), {}, _defineProperty({}, child.props.role, child));
52
+ }, {});
53
+ return children[role];
54
+ });
55
+ _defineProperty(_this, "setRef", function (el) {
56
+ _this.sidebar = el;
57
+ });
58
+ _defineProperty(_this, "startSidebarResize", function (ev) {
59
+ var startWidth = _this.sidebar.offsetWidth;
60
+ var startMouseX = ev.clientX;
61
+ var sign = _this.props.side === 'left' ? -1 : 1;
62
+ var resizeSidebar = function resizeSidebar(event) {
63
+ _this.sidebar.style.width = startWidth + sign * (startMouseX - event.clientX) + 'px';
64
+ };
65
+ ev.view.document.body.style.userSelect = 'none';
66
+ ev.view.addEventListener("pointermove", resizeSidebar);
67
+ ev.view.addEventListener("pointerup", function () {
68
+ ev.view.document.body.style.userSelect = '';
69
+ ev.view.removeEventListener("pointermove", resizeSidebar);
70
+ }, {
71
+ once: true
72
+ });
73
+ });
74
+ _defineProperty(_this, "startSidebarBottomResize", function (ev) {
75
+ var startHeight = _this.sidebar.offsetHeight;
76
+ var startMouseY = ev.clientY;
77
+ var resizeSidebar = function resizeSidebar(event) {
78
+ _this.sidebar.style.height = Math.max(64, startHeight + (event.clientY - startMouseY)) + 'px';
79
+ };
80
+ ev.view.document.body.style.userSelect = 'none';
81
+ ev.view.addEventListener("pointermove", resizeSidebar);
82
+ ev.view.addEventListener("pointerup", function () {
83
+ ev.view.document.body.style.userSelect = '';
84
+ ev.view.removeEventListener("pointermove", resizeSidebar);
85
+ }, {
86
+ once: true
87
+ });
88
+ });
89
+ _this.state.render = props.currentTask && props.currentTask.id === props.id;
90
+ _this.sidebar = null;
91
+ return _this;
92
+ }
93
+ _inherits(SideBar, _React$Component);
94
+ return _createClass(SideBar, [{
95
+ key: "componentDidUpdate",
96
+ value: function componentDidUpdate(prevProps) {
97
+ var _this2 = this;
98
+ var newVisible = this.props.currentTask && this.props.currentTask.id === this.props.id;
99
+ var oldVisible = prevProps.currentTask && prevProps.currentTask.id === prevProps.id;
100
+ if (newVisible && (!oldVisible || this.props.currentTask.mode !== prevProps.currentTask.mode)) {
101
+ this.setState({
102
+ render: true
103
+ });
104
+ this.props.onShow(this.props.currentTask.mode);
105
+ } else if (!newVisible && oldVisible) {
106
+ this.props.onHide();
107
+ // Hide the element after the transition period (see SideBar.css)
108
+ setTimeout(function () {
109
+ _this2.setState({
110
+ render: false
111
+ });
112
+ }, 300);
113
+ }
114
+ if (!this.props.heightResizeable && prevProps.heightResizeable) {
115
+ this.sidebar.style.height = '';
116
+ }
117
+ }
118
+ }, {
119
+ key: "render",
120
+ value: function render() {
121
+ var visible = this.props.currentTask.id === this.props.id;
122
+ var render = visible || this.state.render;
123
+ var style = {
124
+ width: this.props.width,
125
+ minWidth: this.props.minWidth,
126
+ zIndex: visible ? 5 : 4
127
+ };
128
+ var isLeftSide = this.props.side === "left";
129
+ var classes = classnames({
130
+ "sidebar": true,
131
+ "sidebar-open": visible,
132
+ "sidebar-left": isLeftSide,
133
+ "sidebar-right": !isLeftSide
134
+ });
135
+ var closeIcon = isLeftSide ? "chevron-left" : "chevron-right";
136
+ var body = null;
137
+ var extra = null;
138
+ if (render) {
139
+ body = this.renderRole("body");
140
+ extra = this.renderRole("extra");
141
+ }
142
+ return /*#__PURE__*/ReactDOM.createPortal(/*#__PURE__*/React.createElement("div", null, /*#__PURE__*/React.createElement(Swipeable, {
143
+ delta: 30,
144
+ onSwipedRight: this.closeClicked
145
+ }, /*#__PURE__*/React.createElement("div", {
146
+ className: "".concat(classes, " ").concat(this.props.extraClasses),
147
+ id: this.props.id,
148
+ ref: this.setRef,
149
+ style: style
150
+ }, /*#__PURE__*/React.createElement("div", {
151
+ className: "sidebar-resize-handle sidebar-resize-handle-" + this.props.side,
152
+ onPointerDown: this.startSidebarResize
153
+ }), /*#__PURE__*/React.createElement("div", {
154
+ className: "sidebar-titlebar"
155
+ }, this.state.render ? this.props.extraBeforeContent : null, /*#__PURE__*/React.createElement(Icon, {
156
+ className: "sidebar-titlebar-icon",
157
+ icon: this.props.icon,
158
+ size: "large"
159
+ }), /*#__PURE__*/React.createElement("span", {
160
+ className: "sidebar-titlebar-title"
161
+ }, this.props.title), this.state.render ? this.props.extraTitlebarContent : null, /*#__PURE__*/React.createElement("span", {
162
+ className: "sidebar-titlebar-spacer"
163
+ }), /*#__PURE__*/React.createElement(Icon, {
164
+ className: "sidebar-titlebar-closeicon",
165
+ icon: closeIcon,
166
+ onClick: this.closeClicked
167
+ })), /*#__PURE__*/React.createElement("div", {
168
+ className: "sidebar-body"
169
+ }, body), this.props.heightResizeable ? /*#__PURE__*/React.createElement("div", {
170
+ className: "sidebar-resize-handle-bottom",
171
+ onPointerDown: this.startSidebarBottomResize
172
+ }) : null)), extra), this.context);
173
+ }
174
+ }]);
175
+ }(React.Component);
176
+ _defineProperty(SideBar, "contextType", MapContainerPortalContext);
177
+ _defineProperty(SideBar, "propTypes", {
178
+ children: PropTypes.oneOfType([PropTypes.node, PropTypes.func]),
179
+ currentTask: PropTypes.object,
180
+ extraBeforeContent: PropTypes.object,
181
+ extraClasses: PropTypes.string,
182
+ extraTitlebarContent: PropTypes.object,
183
+ heightResizeable: PropTypes.bool,
184
+ icon: PropTypes.string,
185
+ id: PropTypes.string.isRequired,
186
+ minWidth: PropTypes.string,
187
+ onHide: PropTypes.func,
188
+ onShow: PropTypes.func,
189
+ setCurrentTask: PropTypes.func,
190
+ side: PropTypes.string,
191
+ title: PropTypes.string,
192
+ width: PropTypes.string
193
+ });
194
+ _defineProperty(SideBar, "defaultProps", {
195
+ extraClasses: '',
196
+ onShow: function onShow() {},
197
+ onHide: function onHide() {},
198
+ width: '15em',
199
+ minWidth: '15em',
200
+ // allowed values are 'left' and 'right'
201
+ side: 'right'
202
+ });
203
+ export default connect(function (state) {
204
+ return {
205
+ currentTask: state.task
206
+ };
207
+ }, {
208
+ setCurrentTask: setCurrentTask
209
+ })(SideBar);