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,10 +1,444 @@
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 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 _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 _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 _slicedToArray(r,e){return _arrayWithHoles(r)||_iterableToArrayLimit(r,e)||_unsupportedIterableToArray(r,e)||_nonIterableRest()}function _nonIterableRest(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}function _unsupportedIterableToArray(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 _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 _iterableToArrayLimit(r,l){var t=null==r?null:"undefined"!=typeof Symbol&&r[Symbol.iterator]||r["@@iterator"];if(null!=t){var e,n,i,u,a=[],f=!0,o=!1;try{if(i=(t=t.call(r)).next,0===l){if(Object(t)!==t)return;f=!1}else for(;!(f=(e=i.call(t)).done)&&(a.push(e.value),a.length!==l);f=!0);}catch(r){o=!0,n=r}finally{try{if(!f&&null!=t["return"]&&(u=t["return"](),Object(u)!==u))return}finally{if(o)throw n}}return a}}function _arrayWithHoles(r){if(Array.isArray(r))return r}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 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; }
3
+ 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; }
4
+ function _toConsumableArray(r) { return _arrayWithoutHoles(r) || _iterableToArray(r) || _unsupportedIterableToArray(r) || _nonIterableSpread(); }
5
+ 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."); }
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 _slicedToArray(r, e) { return _arrayWithHoles(r) || _iterableToArrayLimit(r, e) || _unsupportedIterableToArray(r, e) || _nonIterableRest(); }
9
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
10
+ 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; } }
11
+ 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; }
12
+ function _iterableToArrayLimit(r, l) { var t = null == r ? null : "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (null != t) { var e, n, i, u, a = [], f = !0, o = !1; try { if (i = (t = t.call(r)).next, 0 === l) { if (Object(t) !== t) return; f = !1; } else for (; !(f = (e = i.call(t)).done) && (a.push(e.value), a.length !== l); f = !0); } catch (r) { o = !0, n = r; } finally { try { if (!f && null != t["return"] && (u = t["return"](), Object(u) !== u)) return; } finally { if (o) throw n; } } return a; } }
13
+ function _arrayWithHoles(r) { if (Array.isArray(r)) return r; }
14
+ function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); }
15
+ 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); } }
16
+ function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; }
17
+ function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); }
18
+ 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); }
19
+ function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; }
20
+ function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }
21
+ function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); }
22
+ 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); }
23
+ function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); }
24
+ 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; }
25
+ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
26
+ 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); }
27
+ /**
2
28
  * Copyright 2024 Sourcepole AG
3
29
  * All rights reserved.
4
30
  *
5
31
  * This source code is licensed under the BSD-style license found in the
6
32
  * LICENSE file in the root directory of this source tree.
7
- */import React from"react";import{connect}from"react-redux";import dayjs from"dayjs";import PropTypes from"prop-types";import randomcolor from"randomcolor";import{addLayerFeatures,removeLayer,LayerRole}from"../../actions/layers";import LocaleUtils from"../../utils/LocaleUtils";import MiscUtils from"../../utils/MiscUtils";import Input from"../widgets/Input";import Spinner from"../widgets/Spinner";import"./style/TimelineFeaturesSlider.css";var TimelineFeaturesSlider=/*#__PURE__*/function(_React$Component){function TimelineFeaturesSlider(){var _this;_classCallCheck(this,TimelineFeaturesSlider);for(var _len=arguments.length,args=new Array(_len),_key=0;_key<_len;_key++){args[_key]=arguments[_key]}_this=_callSuper(this,TimelineFeaturesSlider,[].concat(args));_defineProperty(_this,"state",{currentTimestampDrag:null,highlightFeatures:null,layerClassifications:{},layerAttrGroups:{}});_defineProperty(_this,"renderCursor",function(timestamp){if(_this.props.timeEnabled){var cursorPos=_this.state.currentTimestampDrag?_this.state.currentTimestampDrag.pos:_this.props.computePixelFromTime(timestamp);var cursorStyle={left:cursorPos-2+"px"};return/*#__PURE__*/React.createElement("div",{className:"timeline-slider-cursor",style:cursorStyle},/*#__PURE__*/React.createElement("div",{className:"timeline-slider-cursor-label"},_this.props.cursorFormat.includes("date")?/*#__PURE__*/React.createElement("div",null,/*#__PURE__*/React.createElement(Input,{onChange:_this.setCursorDate,required:true,type:"date",value:dayjs(timestamp).format("YYYY-MM-DD")})):null,_this.props.cursorFormat.includes("time")?/*#__PURE__*/React.createElement("div",null,/*#__PURE__*/React.createElement(Input,{onChange:_this.setCursorTime,required:true,type:"time",value:dayjs(timestamp).format("HH:mm:ss")})):null))}return null});_defineProperty(_this,"setCursorDate",function(date){if(date){var newdate=dayjs(date,"YYYY-MM-DD");_this.props.timestampChanged(+dayjs(_this.props.currentTimestamp).year(newdate.year()).month(newdate.month()).date(newdate.date()))}});_defineProperty(_this,"setCursorTime",function(time){if(time){var parts=time.split(":").map(function(x){return parseInt(x,10)});_this.props.timestampChanged(+dayjs(_this.props.currentTimestamp).hour(parts[0]).minute(parts[1]).second(parts[2]))}});_defineProperty(_this,"pickCurrentTimestamp",function(event){if(["INPUT","SELECT","OPTION"].includes(event.target.nodeName)){return}clearTimeout(_this.timestampChangeTimeout);var target=event.currentTarget;var rect=target.getBoundingClientRect();var computeTimestamp=function computeTimestamp(ev){if(!_this.props.timeEnabled){return}var pos=Math.max(0,Math.min(ev.clientX-rect.left,rect.right-rect.left));var newTimestamp=dayjs(_this.props.computeTimeFromPixel(pos));// Snap to configured step interval
8
- var add=null;if(_this.props.stepSizeUnit.endsWith("m")){add=newTimestamp.second()>30;newTimestamp=newTimestamp.second(0)}else if(_this.props.stepSizeUnit.endsWith("h")){add=newTimestamp.minute()>30;newTimestamp=newTimestamp.second(0).minute(0)}else if(_this.props.stepSizeUnit.endsWith("d")){add=newTimestamp.hour()>12;newTimestamp=newTimestamp.second(0).minute(0).hour(0)}else if(_this.props.stepSizeUnit.endsWith("M")){add=newTimestamp.date()>15;newTimestamp=newTimestamp.second(0).minute(0).hour(0).date(1)}else if(_this.props.stepSizeUnit.endsWith("y")){add=newTimestamp.month()>5;newTimestamp=newTimestamp.second(0).minute(0).hour(0).date(1).month(0)}if(add){var num=parseInt(_this.props.stepSizeUnit.slice(0,-1),10)||1;newTimestamp=newTimestamp.add(num,_this.props.stepSizeUnit.slice(-1))}_this.setState({currentTimestampDrag:{pos:pos,time:newTimestamp}})};document.addEventListener("pointermove",computeTimestamp);document.addEventListener("pointerup",function(){if(_this.state.currentTimestampDrag){_this.props.timestampChanged(+_this.state.currentTimestampDrag.time);_this.setState({currentTimestampDrag:null})}document.removeEventListener("pointermove",computeTimestamp)},{once:true,capture:true});computeTimestamp(event)});_defineProperty(_this,"renderTimeFeatures",function(sliderGeom){return Object.entries(_this.props.timeFeatures.features).map(function(_ref){var _ref2=_slicedToArray(_ref,2),layer=_ref2[0],features=_ref2[1];var layerTitleStyle={top:sliderGeom.top+"px",left:0,right:0};sliderGeom.top+=30;var classattr=(_this.state.layerClassifications[layer]||{}).attr||"";var groupattr=(_this.state.layerAttrGroups[layer]||{}).attr||"";var sliderFeatures=null;if(_this.state.layerAttrGroups[layer]){var layerAttrGroups=_this.state.layerAttrGroups[layer];sliderFeatures=Object.values(layerAttrGroups.groups).map(function(groupData){return _this.renderTimeFeature(sliderGeom,groupData.start,groupData.end,groupData.features,"",groupattr,groupData)})}else{var layerAttrClasses=_this.state.layerClassifications[layer];sliderFeatures=features.map(function(feature){var attrData=layerAttrClasses?layerAttrClasses.classes[feature.properties[layerAttrClasses.attr]]:null;var tstart=feature.properties.__startdate;var tend=feature.properties.__enddate;var label=feature.properties[feature.displayfield];return _this.renderTimeFeature(sliderGeom,tstart,tend,[feature],label,classattr,attrData)})}return[/*#__PURE__*/React.createElement("div",{className:"timeline-slider-layertitle",key:layer,style:layerTitleStyle},/*#__PURE__*/React.createElement("span",null,layer),/*#__PURE__*/React.createElement("span",null,LocaleUtils.tr("timemanager.group"),":\xA0"),/*#__PURE__*/React.createElement("select",{onChange:function onChange(ev){return _this.setGroupAttr(layer,ev.target.value)},value:groupattr},/*#__PURE__*/React.createElement("option",{value:""},LocaleUtils.tr("timemanager.groupnone")),_this.props.timeFeatures.attributes[layer].map(function(attr){return/*#__PURE__*/React.createElement("option",{key:attr,value:attr},attr)})),/*#__PURE__*/React.createElement("span",null,LocaleUtils.tr("timemanager.classify"),":\xA0"),/*#__PURE__*/React.createElement("select",{onChange:function onChange(ev){return _this.setClassification(layer,ev.target.value)},value:classattr},/*#__PURE__*/React.createElement("option",{value:""},LocaleUtils.tr("timemanager.classifynone")),_this.props.timeFeatures.attributes[layer].map(function(attr){return/*#__PURE__*/React.createElement("option",{key:attr,value:attr},attr)}))),sliderFeatures]})});_defineProperty(_this,"renderTimeLayers",function(sliderGeom){return Object.entries(_this.props.timeFeatures.features).reduce(function(res,_ref3){var _ref4=_slicedToArray(_ref3,2),layer=_ref4[0],features=_ref4[1];if(features.length>0){var tstart=features[0].properties.__startdate;var tend=features[0].properties.__enddate;for(var i=1;i<features.length;++i){if(features[i].properties.__startdate<tstart){tstart=features[i].properties.__startdate}if(features[i].properties.__enddate>tend){tend=features[i].properties.__enddate}}return[].concat(_toConsumableArray(res),[_this.renderTimeFeature(sliderGeom,tstart,tend,features,layer)])}return res},[])});_defineProperty(_this,"renderTimeFeature",function(sliderGeom,tstart,tend,features,label,attr,featClass){var left=tstart.isValid()?_this.props.computePixelFromTime(tstart):0;var right=tend.isValid()?_this.props.computePixelFromTime(tend):0;var style={top:sliderGeom.top+"px",left:left+"px"};if(tend.isValid()){style.width=right-left+"px"}else{style.right=0}var tooltip=LocaleUtils.tr("timemanager.starttime")+": "+(tstart.isValid()?tstart.format(_this.props.dateFormat):"-")+"\n"+LocaleUtils.tr("timemanager.endtime")+": "+(tend.isValid()?tend.format(_this.props.dateFormat):"-");if(featClass){style.backgroundColor=featClass.bg;style.color=featClass.fg;label+=(label?": ":"")+featClass.val;tooltip+="\n"+attr+": "+featClass.val}sliderGeom.top+=26;return/*#__PURE__*/React.createElement("div",{className:"timeline-slider-feature",key:features[0].id,onMouseEnter:function onMouseEnter(){return _this.setState({highlightFeatures:features})},onMouseLeave:function onMouseLeave(){return _this.setState({highlightFeatures:null})},style:style,title:tooltip},/*#__PURE__*/React.createElement("span",null,label))});_defineProperty(_this,"renderGradient",function(sliderGeom){if(!_this.props.markersEnabled){return null}var left=_this.props.computePixelFromTime(_this.props.startTime);var right=_this.props.computePixelFromTime(_this.props.endTime);var style={left:left+"px",width:right-left+"px",height:sliderGeom.top+"px",background:"linear-gradient(90deg, "+_this.props.markerConfiguration.gradient.join(", ")+")"};return/*#__PURE__*/React.createElement("div",{className:"timeline-slider-gradient",style:style})});_defineProperty(_this,"setClassification",function(layer,attr){_this.setState(function(state){var newLayerClassifications=_objectSpread({},state.layerClassifications);if(attr){var classes={};_this.props.timeFeatures.features[layer].forEach(function(feature){if(!classes[feature.properties[attr]]){var color=randomcolor();classes[feature.properties[attr]]={bg:color,fg:MiscUtils.isBrightColor(color)?"#000":"#FFF",val:feature.properties[attr]}}});newLayerClassifications[layer]={attr:attr,classes:classes}}else{delete newLayerClassifications[layer]}// Attr classification and grouping cannot be enabled at the same time
9
- var newLayerAttrGroups=_objectSpread({},state.layerAttrGroups);delete newLayerAttrGroups[layer];return{layerClassifications:newLayerClassifications,layerAttrGroups:newLayerAttrGroups}})});_defineProperty(_this,"setGroupAttr",function(layer,attr){_this.setState(function(state){var newLayerAttrGroups=_objectSpread({},state.layerAttrGroups);if(attr){var groups={};_this.props.timeFeatures.features[layer].forEach(function(feature){if(!groups[feature.properties[attr]]){var color=randomcolor();groups[feature.properties[attr]]={bg:color,fg:MiscUtils.isBrightColor(color)?"#000":"#FFF",val:feature.properties[attr],features:[feature],start:feature.properties.__startdate,end:feature.properties.__enddate}}else{if(feature.properties.__startdate<groups[feature.properties[attr]].start){groups[feature.properties[attr]].start=feature.properties.__startdate}if(feature.properties.__enddate>groups[feature.properties[attr]].end){groups[feature.properties[attr]].end=feature.properties.__enddate}groups[feature.properties[attr]].features.push(feature)}});newLayerAttrGroups[layer]={attr:attr,groups:groups}}else{delete newLayerAttrGroups[layer]}// Attr classification and grouping cannot be enabled at the same time
10
- var newLayerClassifications=_objectSpread({},state.layerClassifications);delete newLayerClassifications[layer];return{layerClassifications:newLayerClassifications,layerAttrGroups:newLayerAttrGroups}})});return _this}_inherits(TimelineFeaturesSlider,_React$Component);return _createClass(TimelineFeaturesSlider,[{key:"componentDidUpdate",value:function componentDidUpdate(prevProps,prevState){var _this2=this;if(this.state.highlightFeatures!==prevState.highlightFeatures){if(!this.state.highlightFeatures){this.props.removeLayer("timelinefeathighlight")}else{var layer={id:"timelinefeathighlight",role:LayerRole.MARKER,rev:+new Date};this.props.addLayerFeatures(layer,this.state.highlightFeatures,true)}}if(this.props.timeFeatures!==prevProps.timeFeatures){var newLayerClassifications=_objectSpread({},this.state.layerClassifications);Object.keys(this.state.layerClassifications).forEach(function(layername){if(!_this2.props.timeFeatures.attributes[layername]||_this2.props.timeFeatures.attributes[layername]!==prevProps.timeFeatures.attributes[layername]){delete newLayerClassifications.layername}});this.setState(function(state){var newLayerAttrGroups=_objectSpread({},state.layerAttrGroups);Object.keys(state.layerAttrGroups).forEach(function(layername){if(!_this2.props.timeFeatures.attributes[layername]||_this2.props.timeFeatures.attributes[layername]!==prevProps.timeFeatures.attributes[layername]){delete newLayerAttrGroups.layername}});return{layerAttrGroups:newLayerAttrGroups}})}}},{key:"render",value:function render(){var timestamp=this.state.currentTimestampDrag?this.state.currentTimestampDrag.time:this.props.currentTimestamp;var sliderGeom={top:5};return/*#__PURE__*/React.createElement("div",{className:"timeline-slider-container"},/*#__PURE__*/React.createElement("div",{className:"timeline-slider",onPointerDown:this.pickCurrentTimestamp},this.props.displayMode==="features"?this.renderTimeFeatures(sliderGeom):null,this.props.displayMode==="layers"?this.renderTimeLayers(sliderGeom):null,this.renderGradient(sliderGeom)),this.renderCursor(timestamp),this.props.timeFeatures.pendingRequests>0?/*#__PURE__*/React.createElement("div",{className:"timeline-slider-loading"},/*#__PURE__*/React.createElement(Spinner,null),/*#__PURE__*/React.createElement("span",null,LocaleUtils.tr("timemanager.loading"))):null)}}])}(React.Component);_defineProperty(TimelineFeaturesSlider,"propTypes",{addLayerFeatures:PropTypes.func,computePixelFromTime:PropTypes.func,computeTimeFromPixel:PropTypes.func,currentTimestamp:PropTypes.number,cursorFormat:PropTypes.string,dateFormat:PropTypes.string,displayMode:PropTypes.string,endTime:PropTypes.object,markerConfiguration:PropTypes.object,markersEnabled:PropTypes.bool,removeLayer:PropTypes.func,startTime:PropTypes.object,stepSizeUnit:PropTypes.string,timeEnabled:PropTypes.bool,timeFeatures:PropTypes.object,timestampChanged:PropTypes.func});export default connect(function(){return{}},{addLayerFeatures:addLayerFeatures,removeLayer:removeLayer})(TimelineFeaturesSlider);
33
+ */
34
+
35
+ import React from 'react';
36
+ import { connect } from 'react-redux';
37
+ import dayjs from 'dayjs';
38
+ import PropTypes from 'prop-types';
39
+ import randomcolor from 'randomcolor';
40
+ import { addLayerFeatures, removeLayer, LayerRole } from '../../actions/layers';
41
+ import LocaleUtils from '../../utils/LocaleUtils';
42
+ import MiscUtils from '../../utils/MiscUtils';
43
+ import Input from '../widgets/Input';
44
+ import Spinner from '../widgets/Spinner';
45
+ import './style/TimelineFeaturesSlider.css';
46
+ var TimelineFeaturesSlider = /*#__PURE__*/function (_React$Component) {
47
+ function TimelineFeaturesSlider() {
48
+ var _this;
49
+ _classCallCheck(this, TimelineFeaturesSlider);
50
+ for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
51
+ args[_key] = arguments[_key];
52
+ }
53
+ _this = _callSuper(this, TimelineFeaturesSlider, [].concat(args));
54
+ _defineProperty(_this, "state", {
55
+ currentTimestampDrag: null,
56
+ highlightFeatures: null,
57
+ layerClassifications: {},
58
+ layerAttrGroups: {}
59
+ });
60
+ _defineProperty(_this, "renderCursor", function (timestamp) {
61
+ if (_this.props.timeEnabled) {
62
+ var cursorPos = _this.state.currentTimestampDrag ? _this.state.currentTimestampDrag.pos : _this.props.computePixelFromTime(timestamp);
63
+ var cursorStyle = {
64
+ left: cursorPos - 2 + "px"
65
+ };
66
+ return /*#__PURE__*/React.createElement("div", {
67
+ className: "timeline-slider-cursor",
68
+ style: cursorStyle
69
+ }, /*#__PURE__*/React.createElement("div", {
70
+ className: "timeline-slider-cursor-label"
71
+ }, _this.props.cursorFormat.includes("date") ? /*#__PURE__*/React.createElement("div", null, /*#__PURE__*/React.createElement(Input, {
72
+ onChange: _this.setCursorDate,
73
+ required: true,
74
+ type: "date",
75
+ value: dayjs(timestamp).format('YYYY-MM-DD')
76
+ })) : null, _this.props.cursorFormat.includes("time") ? /*#__PURE__*/React.createElement("div", null, /*#__PURE__*/React.createElement(Input, {
77
+ onChange: _this.setCursorTime,
78
+ required: true,
79
+ type: "time",
80
+ value: dayjs(timestamp).format("HH:mm:ss")
81
+ })) : null));
82
+ }
83
+ return null;
84
+ });
85
+ _defineProperty(_this, "setCursorDate", function (date) {
86
+ if (date) {
87
+ var newdate = dayjs(date, "YYYY-MM-DD");
88
+ _this.props.timestampChanged(+dayjs(_this.props.currentTimestamp).year(newdate.year()).month(newdate.month()).date(newdate.date()));
89
+ }
90
+ });
91
+ _defineProperty(_this, "setCursorTime", function (time) {
92
+ if (time) {
93
+ var parts = time.split(":").map(function (x) {
94
+ return parseInt(x, 10);
95
+ });
96
+ _this.props.timestampChanged(+dayjs(_this.props.currentTimestamp).hour(parts[0]).minute(parts[1]).second(parts[2]));
97
+ }
98
+ });
99
+ _defineProperty(_this, "pickCurrentTimestamp", function (event) {
100
+ if (["INPUT", "SELECT", "OPTION"].includes(event.target.nodeName)) {
101
+ return;
102
+ }
103
+ clearTimeout(_this.timestampChangeTimeout);
104
+ var target = event.currentTarget;
105
+ var rect = target.getBoundingClientRect();
106
+ var computeTimestamp = function computeTimestamp(ev) {
107
+ if (!_this.props.timeEnabled) {
108
+ return;
109
+ }
110
+ var pos = Math.max(0, Math.min(ev.clientX - rect.left, rect.right - rect.left));
111
+ var newTimestamp = dayjs(_this.props.computeTimeFromPixel(pos));
112
+ // Snap to configured step interval
113
+ var add = null;
114
+ if (_this.props.stepSizeUnit.endsWith("m")) {
115
+ add = newTimestamp.second() > 30;
116
+ newTimestamp = newTimestamp.second(0);
117
+ } else if (_this.props.stepSizeUnit.endsWith("h")) {
118
+ add = newTimestamp.minute() > 30;
119
+ newTimestamp = newTimestamp.second(0).minute(0);
120
+ } else if (_this.props.stepSizeUnit.endsWith("d")) {
121
+ add = newTimestamp.hour() > 12;
122
+ newTimestamp = newTimestamp.second(0).minute(0).hour(0);
123
+ } else if (_this.props.stepSizeUnit.endsWith("M")) {
124
+ add = newTimestamp.date() > 15;
125
+ newTimestamp = newTimestamp.second(0).minute(0).hour(0).date(1);
126
+ } else if (_this.props.stepSizeUnit.endsWith("y")) {
127
+ add = newTimestamp.month() > 5;
128
+ newTimestamp = newTimestamp.second(0).minute(0).hour(0).date(1).month(0);
129
+ }
130
+ if (add) {
131
+ var num = parseInt(_this.props.stepSizeUnit.slice(0, -1), 10) || 1;
132
+ newTimestamp = newTimestamp.add(num, _this.props.stepSizeUnit.slice(-1));
133
+ }
134
+ _this.setState({
135
+ currentTimestampDrag: {
136
+ pos: pos,
137
+ time: newTimestamp
138
+ }
139
+ });
140
+ };
141
+ document.addEventListener("pointermove", computeTimestamp);
142
+ document.addEventListener("pointerup", function () {
143
+ if (_this.state.currentTimestampDrag) {
144
+ _this.props.timestampChanged(+_this.state.currentTimestampDrag.time);
145
+ _this.setState({
146
+ currentTimestampDrag: null
147
+ });
148
+ }
149
+ document.removeEventListener("pointermove", computeTimestamp);
150
+ }, {
151
+ once: true,
152
+ capture: true
153
+ });
154
+ computeTimestamp(event);
155
+ });
156
+ _defineProperty(_this, "renderTimeFeatures", function (sliderGeom) {
157
+ return Object.entries(_this.props.timeFeatures.features).map(function (_ref) {
158
+ var _ref2 = _slicedToArray(_ref, 2),
159
+ layer = _ref2[0],
160
+ features = _ref2[1];
161
+ var layerTitleStyle = {
162
+ top: sliderGeom.top + "px",
163
+ left: 0,
164
+ right: 0
165
+ };
166
+ sliderGeom.top += 30;
167
+ var classattr = (_this.state.layerClassifications[layer] || {}).attr || "";
168
+ var groupattr = (_this.state.layerAttrGroups[layer] || {}).attr || "";
169
+ var sliderFeatures = null;
170
+ if (_this.state.layerAttrGroups[layer]) {
171
+ var layerAttrGroups = _this.state.layerAttrGroups[layer];
172
+ sliderFeatures = Object.values(layerAttrGroups.groups).map(function (groupData) {
173
+ return _this.renderTimeFeature(sliderGeom, groupData.start, groupData.end, groupData.features, "", groupattr, groupData);
174
+ });
175
+ } else {
176
+ var layerAttrClasses = _this.state.layerClassifications[layer];
177
+ sliderFeatures = features.map(function (feature) {
178
+ var attrData = layerAttrClasses ? layerAttrClasses.classes[feature.properties[layerAttrClasses.attr]] : null;
179
+ var tstart = feature.properties.__startdate;
180
+ var tend = feature.properties.__enddate;
181
+ var label = feature.properties[feature.displayfield];
182
+ return _this.renderTimeFeature(sliderGeom, tstart, tend, [feature], label, classattr, attrData);
183
+ });
184
+ }
185
+ return [/*#__PURE__*/React.createElement("div", {
186
+ className: "timeline-slider-layertitle",
187
+ key: layer,
188
+ style: layerTitleStyle
189
+ }, /*#__PURE__*/React.createElement("span", null, layer), /*#__PURE__*/React.createElement("span", null, LocaleUtils.tr("timemanager.group"), ":\xA0"), /*#__PURE__*/React.createElement("select", {
190
+ onChange: function onChange(ev) {
191
+ return _this.setGroupAttr(layer, ev.target.value);
192
+ },
193
+ value: groupattr
194
+ }, /*#__PURE__*/React.createElement("option", {
195
+ value: ""
196
+ }, LocaleUtils.tr("timemanager.groupnone")), _this.props.timeFeatures.attributes[layer].map(function (attr) {
197
+ return /*#__PURE__*/React.createElement("option", {
198
+ key: attr,
199
+ value: attr
200
+ }, attr);
201
+ })), /*#__PURE__*/React.createElement("span", null, LocaleUtils.tr("timemanager.classify"), ":\xA0"), /*#__PURE__*/React.createElement("select", {
202
+ onChange: function onChange(ev) {
203
+ return _this.setClassification(layer, ev.target.value);
204
+ },
205
+ value: classattr
206
+ }, /*#__PURE__*/React.createElement("option", {
207
+ value: ""
208
+ }, LocaleUtils.tr("timemanager.classifynone")), _this.props.timeFeatures.attributes[layer].map(function (attr) {
209
+ return /*#__PURE__*/React.createElement("option", {
210
+ key: attr,
211
+ value: attr
212
+ }, attr);
213
+ }))), sliderFeatures];
214
+ });
215
+ });
216
+ _defineProperty(_this, "renderTimeLayers", function (sliderGeom) {
217
+ return Object.entries(_this.props.timeFeatures.features).reduce(function (res, _ref3) {
218
+ var _ref4 = _slicedToArray(_ref3, 2),
219
+ layer = _ref4[0],
220
+ features = _ref4[1];
221
+ if (features.length > 0) {
222
+ var tstart = features[0].properties.__startdate;
223
+ var tend = features[0].properties.__enddate;
224
+ for (var i = 1; i < features.length; ++i) {
225
+ if (features[i].properties.__startdate < tstart) {
226
+ tstart = features[i].properties.__startdate;
227
+ }
228
+ if (features[i].properties.__enddate > tend) {
229
+ tend = features[i].properties.__enddate;
230
+ }
231
+ }
232
+ return [].concat(_toConsumableArray(res), [_this.renderTimeFeature(sliderGeom, tstart, tend, features, layer)]);
233
+ }
234
+ return res;
235
+ }, []);
236
+ });
237
+ _defineProperty(_this, "renderTimeFeature", function (sliderGeom, tstart, tend, features, label, attr, featClass) {
238
+ var left = tstart.isValid() ? _this.props.computePixelFromTime(tstart) : 0;
239
+ var right = tend.isValid() ? _this.props.computePixelFromTime(tend) : 0;
240
+ var style = {
241
+ top: sliderGeom.top + "px",
242
+ left: left + "px"
243
+ };
244
+ if (tend.isValid()) {
245
+ style.width = right - left + "px";
246
+ } else {
247
+ style.right = 0;
248
+ }
249
+ var tooltip = LocaleUtils.tr("timemanager.starttime") + ": " + (tstart.isValid() ? tstart.format(_this.props.dateFormat) : "-") + "\n" + LocaleUtils.tr("timemanager.endtime") + ": " + (tend.isValid() ? tend.format(_this.props.dateFormat) : "-");
250
+ if (featClass) {
251
+ style.backgroundColor = featClass.bg;
252
+ style.color = featClass.fg;
253
+ label += (label ? ": " : "") + featClass.val;
254
+ tooltip += "\n" + attr + ": " + featClass.val;
255
+ }
256
+ sliderGeom.top += 26;
257
+ return /*#__PURE__*/React.createElement("div", {
258
+ className: "timeline-slider-feature",
259
+ key: features[0].id,
260
+ onMouseEnter: function onMouseEnter() {
261
+ return _this.setState({
262
+ highlightFeatures: features
263
+ });
264
+ },
265
+ onMouseLeave: function onMouseLeave() {
266
+ return _this.setState({
267
+ highlightFeatures: null
268
+ });
269
+ },
270
+ style: style,
271
+ title: tooltip
272
+ }, /*#__PURE__*/React.createElement("span", null, label));
273
+ });
274
+ _defineProperty(_this, "renderGradient", function (sliderGeom) {
275
+ if (!_this.props.markersEnabled) {
276
+ return null;
277
+ }
278
+ var left = _this.props.computePixelFromTime(_this.props.startTime);
279
+ var right = _this.props.computePixelFromTime(_this.props.endTime);
280
+ var style = {
281
+ left: left + "px",
282
+ width: right - left + "px",
283
+ height: sliderGeom.top + "px",
284
+ background: 'linear-gradient(90deg, ' + _this.props.markerConfiguration.gradient.join(", ") + ')'
285
+ };
286
+ return /*#__PURE__*/React.createElement("div", {
287
+ className: "timeline-slider-gradient",
288
+ style: style
289
+ });
290
+ });
291
+ _defineProperty(_this, "setClassification", function (layer, attr) {
292
+ _this.setState(function (state) {
293
+ var newLayerClassifications = _objectSpread({}, state.layerClassifications);
294
+ if (attr) {
295
+ var classes = {};
296
+ _this.props.timeFeatures.features[layer].forEach(function (feature) {
297
+ if (!classes[feature.properties[attr]]) {
298
+ var color = randomcolor();
299
+ classes[feature.properties[attr]] = {
300
+ bg: color,
301
+ fg: MiscUtils.isBrightColor(color) ? "#000" : "#FFF",
302
+ val: feature.properties[attr]
303
+ };
304
+ }
305
+ });
306
+ newLayerClassifications[layer] = {
307
+ attr: attr,
308
+ classes: classes
309
+ };
310
+ } else {
311
+ delete newLayerClassifications[layer];
312
+ }
313
+ // Attr classification and grouping cannot be enabled at the same time
314
+ var newLayerAttrGroups = _objectSpread({}, state.layerAttrGroups);
315
+ delete newLayerAttrGroups[layer];
316
+ return {
317
+ layerClassifications: newLayerClassifications,
318
+ layerAttrGroups: newLayerAttrGroups
319
+ };
320
+ });
321
+ });
322
+ _defineProperty(_this, "setGroupAttr", function (layer, attr) {
323
+ _this.setState(function (state) {
324
+ var newLayerAttrGroups = _objectSpread({}, state.layerAttrGroups);
325
+ if (attr) {
326
+ var groups = {};
327
+ _this.props.timeFeatures.features[layer].forEach(function (feature) {
328
+ if (!groups[feature.properties[attr]]) {
329
+ var color = randomcolor();
330
+ groups[feature.properties[attr]] = {
331
+ bg: color,
332
+ fg: MiscUtils.isBrightColor(color) ? "#000" : "#FFF",
333
+ val: feature.properties[attr],
334
+ features: [feature],
335
+ start: feature.properties.__startdate,
336
+ end: feature.properties.__enddate
337
+ };
338
+ } else {
339
+ if (feature.properties.__startdate < groups[feature.properties[attr]].start) {
340
+ groups[feature.properties[attr]].start = feature.properties.__startdate;
341
+ }
342
+ if (feature.properties.__enddate > groups[feature.properties[attr]].end) {
343
+ groups[feature.properties[attr]].end = feature.properties.__enddate;
344
+ }
345
+ groups[feature.properties[attr]].features.push(feature);
346
+ }
347
+ });
348
+ newLayerAttrGroups[layer] = {
349
+ attr: attr,
350
+ groups: groups
351
+ };
352
+ } else {
353
+ delete newLayerAttrGroups[layer];
354
+ }
355
+ // Attr classification and grouping cannot be enabled at the same time
356
+ var newLayerClassifications = _objectSpread({}, state.layerClassifications);
357
+ delete newLayerClassifications[layer];
358
+ return {
359
+ layerClassifications: newLayerClassifications,
360
+ layerAttrGroups: newLayerAttrGroups
361
+ };
362
+ });
363
+ });
364
+ return _this;
365
+ }
366
+ _inherits(TimelineFeaturesSlider, _React$Component);
367
+ return _createClass(TimelineFeaturesSlider, [{
368
+ key: "componentDidUpdate",
369
+ value: function componentDidUpdate(prevProps, prevState) {
370
+ var _this2 = this;
371
+ if (this.state.highlightFeatures !== prevState.highlightFeatures) {
372
+ if (!this.state.highlightFeatures) {
373
+ this.props.removeLayer("timelinefeathighlight");
374
+ } else {
375
+ var layer = {
376
+ id: "timelinefeathighlight",
377
+ role: LayerRole.MARKER,
378
+ rev: +new Date()
379
+ };
380
+ this.props.addLayerFeatures(layer, this.state.highlightFeatures, true);
381
+ }
382
+ }
383
+ if (this.props.timeFeatures !== prevProps.timeFeatures) {
384
+ var newLayerClassifications = _objectSpread({}, this.state.layerClassifications);
385
+ Object.keys(this.state.layerClassifications).forEach(function (layername) {
386
+ if (!_this2.props.timeFeatures.attributes[layername] || _this2.props.timeFeatures.attributes[layername] !== prevProps.timeFeatures.attributes[layername]) {
387
+ delete newLayerClassifications.layername;
388
+ }
389
+ });
390
+ this.setState(function (state) {
391
+ var newLayerAttrGroups = _objectSpread({}, state.layerAttrGroups);
392
+ Object.keys(state.layerAttrGroups).forEach(function (layername) {
393
+ if (!_this2.props.timeFeatures.attributes[layername] || _this2.props.timeFeatures.attributes[layername] !== prevProps.timeFeatures.attributes[layername]) {
394
+ delete newLayerAttrGroups.layername;
395
+ }
396
+ });
397
+ return {
398
+ layerAttrGroups: newLayerAttrGroups
399
+ };
400
+ });
401
+ }
402
+ }
403
+ }, {
404
+ key: "render",
405
+ value: function render() {
406
+ var timestamp = this.state.currentTimestampDrag ? this.state.currentTimestampDrag.time : this.props.currentTimestamp;
407
+ var sliderGeom = {
408
+ top: 5
409
+ };
410
+ return /*#__PURE__*/React.createElement("div", {
411
+ className: "timeline-slider-container"
412
+ }, /*#__PURE__*/React.createElement("div", {
413
+ className: "timeline-slider",
414
+ onPointerDown: this.pickCurrentTimestamp
415
+ }, this.props.displayMode === "features" ? this.renderTimeFeatures(sliderGeom) : null, this.props.displayMode === "layers" ? this.renderTimeLayers(sliderGeom) : null, this.renderGradient(sliderGeom)), this.renderCursor(timestamp), this.props.timeFeatures.pendingRequests > 0 ? /*#__PURE__*/React.createElement("div", {
416
+ className: "timeline-slider-loading"
417
+ }, /*#__PURE__*/React.createElement(Spinner, null), /*#__PURE__*/React.createElement("span", null, LocaleUtils.tr("timemanager.loading"))) : null);
418
+ }
419
+ }]);
420
+ }(React.Component);
421
+ _defineProperty(TimelineFeaturesSlider, "propTypes", {
422
+ addLayerFeatures: PropTypes.func,
423
+ computePixelFromTime: PropTypes.func,
424
+ computeTimeFromPixel: PropTypes.func,
425
+ currentTimestamp: PropTypes.number,
426
+ cursorFormat: PropTypes.string,
427
+ dateFormat: PropTypes.string,
428
+ displayMode: PropTypes.string,
429
+ endTime: PropTypes.object,
430
+ markerConfiguration: PropTypes.object,
431
+ markersEnabled: PropTypes.bool,
432
+ removeLayer: PropTypes.func,
433
+ startTime: PropTypes.object,
434
+ stepSizeUnit: PropTypes.string,
435
+ timeEnabled: PropTypes.bool,
436
+ timeFeatures: PropTypes.object,
437
+ timestampChanged: PropTypes.func
438
+ });
439
+ export default connect(function () {
440
+ return {};
441
+ }, {
442
+ addLayerFeatures: addLayerFeatures,
443
+ removeLayer: removeLayer
444
+ })(TimelineFeaturesSlider);
@@ -1,7 +1,101 @@
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 _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 _toConsumableArray(r) { return _arrayWithoutHoles(r) || _iterableToArray(r) || _unsupportedIterableToArray(r) || _nonIterableSpread(); }
3
+ 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."); }
4
+ 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; } }
5
+ function _iterableToArray(r) { if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); }
6
+ function _arrayWithoutHoles(r) { if (Array.isArray(r)) return _arrayLikeToArray(r); }
7
+ 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; }
8
+ function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); }
9
+ 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); } }
10
+ function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; }
11
+ function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); }
12
+ 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); }
13
+ function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; }
14
+ function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }
15
+ function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); }
16
+ 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); }
17
+ function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); }
18
+ 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; }
19
+ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
20
+ 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); }
21
+ /**
2
22
  * Copyright 2019-2024 Sourcepole AG
3
23
  * All rights reserved.
4
24
  *
5
25
  * This source code is licensed under the BSD-style license found in the
6
26
  * LICENSE file in the root directory of this source tree.
7
- */import React from"react";import PropTypes from"prop-types";import Icon from"../Icon";import"./style/AccordeonWidget.css";var AccordeonWidget=/*#__PURE__*/function(_React$Component){function AccordeonWidget(){var _this;_classCallCheck(this,AccordeonWidget);for(var _len=arguments.length,args=new Array(_len),_key=0;_key<_len;_key++){args[_key]=arguments[_key]}_this=_callSuper(this,AccordeonWidget,[].concat(args));_defineProperty(_this,"state",{currentSections:[]});_defineProperty(_this,"renderSection",function(section){return/*#__PURE__*/React.createElement("div",{className:"accordeon-section",key:section.key},/*#__PURE__*/React.createElement("div",{className:"accordeon-section-header",onClick:function onClick(){return _this.toggleSection(section.key)}},section.title,/*#__PURE__*/React.createElement(Icon,{icon:_this.state.currentSections.includes(section.key)?"collapse":"expand"})),_this.state.currentSections.includes(section.key)?/*#__PURE__*/React.createElement("div",{className:"accordeon-section-body"},/*#__PURE__*/React.createElement(section.widget,section.params||{})):null)});_defineProperty(_this,"toggleSection",function(key){var currentSections=[];if(_this.props.allowMultiple){if(_this.state.currentSections.includes(key)){currentSections=_this.state.currentSections.filter(function(entry){return entry!==key})}else{currentSections=[].concat(_toConsumableArray(_this.state.currentSections),[key])}}else{currentSections=_this.state.currentSections.includes(key)?[]:[key]}_this.setState({currentSections:currentSections})});return _this}_inherits(AccordeonWidget,_React$Component);return _createClass(AccordeonWidget,[{key:"render",value:function render(){var _this2=this;return/*#__PURE__*/React.createElement("div",{className:this.props.className,role:"body"},this.props.sections.map(function(section){return _this2.renderSection(section)}))}}])}(React.Component);_defineProperty(AccordeonWidget,"propTypes",{allowMultiple:PropTypes.bool,className:PropTypes.string,sections:PropTypes.arrayOf(PropTypes.shape({key:PropTypes.string,widget:PropTypes.object,title:PropTypes.string}))});export{AccordeonWidget as default};
27
+ */
28
+
29
+ import React from 'react';
30
+ import PropTypes from 'prop-types';
31
+ import Icon from '../Icon';
32
+ import './style/AccordeonWidget.css';
33
+ var AccordeonWidget = /*#__PURE__*/function (_React$Component) {
34
+ function AccordeonWidget() {
35
+ var _this;
36
+ _classCallCheck(this, AccordeonWidget);
37
+ for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
38
+ args[_key] = arguments[_key];
39
+ }
40
+ _this = _callSuper(this, AccordeonWidget, [].concat(args));
41
+ _defineProperty(_this, "state", {
42
+ currentSections: []
43
+ });
44
+ _defineProperty(_this, "renderSection", function (section) {
45
+ return /*#__PURE__*/React.createElement("div", {
46
+ className: "accordeon-section",
47
+ key: section.key
48
+ }, /*#__PURE__*/React.createElement("div", {
49
+ className: "accordeon-section-header",
50
+ onClick: function onClick() {
51
+ return _this.toggleSection(section.key);
52
+ }
53
+ }, section.title, /*#__PURE__*/React.createElement(Icon, {
54
+ icon: _this.state.currentSections.includes(section.key) ? 'collapse' : 'expand'
55
+ })), _this.state.currentSections.includes(section.key) ? /*#__PURE__*/React.createElement("div", {
56
+ className: "accordeon-section-body"
57
+ }, /*#__PURE__*/React.createElement(section.widget, section.params || {})) : null);
58
+ });
59
+ _defineProperty(_this, "toggleSection", function (key) {
60
+ var currentSections = [];
61
+ if (_this.props.allowMultiple) {
62
+ if (_this.state.currentSections.includes(key)) {
63
+ currentSections = _this.state.currentSections.filter(function (entry) {
64
+ return entry !== key;
65
+ });
66
+ } else {
67
+ currentSections = [].concat(_toConsumableArray(_this.state.currentSections), [key]);
68
+ }
69
+ } else {
70
+ currentSections = _this.state.currentSections.includes(key) ? [] : [key];
71
+ }
72
+ _this.setState({
73
+ currentSections: currentSections
74
+ });
75
+ });
76
+ return _this;
77
+ }
78
+ _inherits(AccordeonWidget, _React$Component);
79
+ return _createClass(AccordeonWidget, [{
80
+ key: "render",
81
+ value: function render() {
82
+ var _this2 = this;
83
+ return /*#__PURE__*/React.createElement("div", {
84
+ className: this.props.className,
85
+ role: "body"
86
+ }, this.props.sections.map(function (section) {
87
+ return _this2.renderSection(section);
88
+ }));
89
+ }
90
+ }]);
91
+ }(React.Component);
92
+ _defineProperty(AccordeonWidget, "propTypes", {
93
+ allowMultiple: PropTypes.bool,
94
+ className: PropTypes.string,
95
+ sections: PropTypes.arrayOf(PropTypes.shape({
96
+ key: PropTypes.string,
97
+ widget: PropTypes.object,
98
+ title: PropTypes.string
99
+ }))
100
+ });
101
+ export { AccordeonWidget as default };