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,8 +1,440 @@
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 2016-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{connect}from"react-redux";import classnames from"classnames";import{remove as removeDiacritics}from"diacritics";import isEmpty from"lodash.isempty";import isEqual from"lodash.isequal";import mousetrap from"mousetrap";import PropTypes from"prop-types";import{setCurrentTask}from"../actions/task";import{setMenuMargin}from"../actions/windows";import InputContainer from"../components/widgets/InputContainer";import ConfigUtils from"../utils/ConfigUtils";import LocaleUtils from"../utils/LocaleUtils";import MiscUtils from"../utils/MiscUtils";import Icon from"./Icon";import"./style/AppMenu.css";var AppMenu=/*#__PURE__*/function(_React$Component){function AppMenu(props){var _this;_classCallCheck(this,AppMenu);_this=_callSuper(this,AppMenu,[props]);_defineProperty(_this,"state",{menuVisible:false,filter:"",submenusVisible:[],curEntry:null,keyNav:false});_defineProperty(_this,"addKeyBindings",function(items){items.forEach(function(item){if(item.subitems){_this.addKeyBindings(item.subitems)}else if(item.shortcut){mousetrap.bind(item.shortcut,function(){_this.onMenuitemClicked(item);return false});_this.boundShortcuts.push(item.shortcut)}})});_defineProperty(_this,"onKeyPress",function(ev){if(ev.key==="Enter"||ev.key==="ArrowLeft"||ev.key==="ArrowUp"||ev.key==="ArrowRight"||ev.key==="ArrowDown"){if(!_this.state.curEntry){if(ev.key==="ArrowUp"||ev.key==="ArrowDown"){_this.setState({curEntry:[ev.key==="ArrowUp"?_this.props.menuItems.length-1:0]})}}else{var curEntry=_toConsumableArray(_this.state.curEntry);var stack=[_this.props.menuItems];_this.state.curEntry.forEach(function(entry){stack.push(stack[stack.length-1][entry].subitems)});stack.pop();var leaf=curEntry.pop();var level=stack.length-1;if(ev.key==="Enter"){if(!isEmpty(stack[stack.length-1][leaf].subitems)){_this.onSubmenuClicked(stack[stack.length-1][leaf].key,level)}else{_this.onMenuitemClicked(stack[stack.length-1][leaf])}}else if(ev.key==="ArrowLeft"){if(!isEmpty(stack[stack.length-1][leaf].subitems)&&_this.state.submenusVisible[level]===stack[stack.length-1][leaf].key){_this.onSubmenuClicked(stack[stack.length-1][leaf].key,level)}}else if(ev.key==="ArrowUp"){leaf-=1;if(leaf>=0&&!isEmpty(stack[stack.length-1][leaf].subitems)&&_this.state.submenusVisible[level]===stack[stack.length-1][leaf].key){curEntry.push(leaf);leaf=stack[stack.length-1][leaf].subitems.length-1}else{while(leaf<0&&curEntry.length>0){leaf=curEntry.pop()}if(leaf<0){leaf=_this.props.menuItems.length-1}}}else if(ev.key==="ArrowRight"){if(!isEmpty(stack[stack.length-1][leaf].subitems)&&!_this.state.submenusVisible[level]){_this.onSubmenuClicked(stack[stack.length-1][leaf].key,level)}}else if(ev.key==="ArrowDown"){if(!isEmpty(stack[stack.length-1][leaf].subitems)&&_this.state.submenusVisible[level]===stack[stack.length-1][leaf].key){curEntry.push(leaf);leaf=0}else{leaf+=1;while(leaf>stack[stack.length-1].length-1&&curEntry.length>0){leaf=curEntry.pop()+1;stack.pop()}if(leaf>_this.props.menuItems.length-1){leaf=0}}}_this.setState({curEntry:[].concat(_toConsumableArray(curEntry),[leaf]),keyNav:true})}MiscUtils.killEvent(ev)}else if(ev.key==="Escape"){_this.toggleMenu();MiscUtils.killEvent(ev)}});_defineProperty(_this,"onMouseMove",function(ev){if(_this.state.keyNav){_this.setState({keyNav:false})}MiscUtils.killEvent(ev)});_defineProperty(_this,"toggleMenu",function(){if(!_this.state.menuVisible&&_this.props.currentTaskBlocked){return}if(!_this.state.menuVisible&&_this.props.appMenuClearsTask){_this.props.setCurrentTask(null)}if(!_this.props.keepMenuOpen){if(!_this.state.menuVisible){document.addEventListener("click",_this.checkCloseMenu);document.addEventListener("keydown",_this.onKeyPress,true);document.addEventListener("mousemove",_this.onMouseMove,true)}else{document.removeEventListener("click",_this.checkCloseMenu);document.removeEventListener("keydown",_this.onKeyPress,true);document.removeEventListener("mousemove",_this.onMouseMove,true)}}_this.props.onMenuToggled(!_this.state.menuVisible);if(_this.props.menuCompact){_this.props.setMenuMargin(!_this.state.menuVisible?MiscUtils.convertEmToPx(3.75):0,0)}_this.setState(function(state){return{menuVisible:!state.menuVisible,submenusVisible:[],filter:""}})});_defineProperty(_this,"checkCloseMenu",function(ev){if(_this.menuEl&&!_this.menuEl.contains(ev.target)&&!_this.props.keepMenuOpen){_this.toggleMenu()}MiscUtils.killEvent(ev)});_defineProperty(_this,"onSubmenuClicked",function(key,level){var a=_this.state.submenusVisible[level]===key?[]:[key];_this.setState(function(state){return{submenusVisible:state.submenusVisible.slice(0,level).concat(a)}})});_defineProperty(_this,"onMenuitemClicked",function(item){if(!_this.props.keepMenuOpen&&_this.state.menuVisible){_this.toggleMenu()}if(item.url){var label=item.title?LocaleUtils.tr(item.title):LocaleUtils.tr("appmenu.items."+item.key+(item.mode||""));_this.props.openExternalUrl(item.url,item.target,label,item.icon)}else{_this.props.setCurrentTask(item.task||item.key,item.mode,item.mapClickAction||(item.identifyEnabled?"identify":null))}});_defineProperty(_this,"renderMenuItems",function(items,level,filter,path){if(items){return items.map(function(item,idx){var active=isEqual(_this.state.curEntry,[].concat(_toConsumableArray(path),[idx]));if(item.subitems){var _item$key;var subitems=_this.renderMenuItems(item.subitems,level+1,filter,[].concat(_toConsumableArray(path),[idx]));if(filter&&isEmpty(subitems)){return null}var visible=filter&&!isEmpty(subitems)||_this.state.submenusVisible[level]===item.key;var className=classnames({"appmenu-submenu":true,"appmenu-submenu-active":active,"appmenu-submenu-expanded":visible});return/*#__PURE__*/React.createElement("li",{className:className,key:(_item$key=item.key)!==null&&_item$key!==void 0?_item$key:item.title,onClick:function onClick(){return _this.onSubmenuClicked(item.key,level)},onMouseEnter:function onMouseEnter(){if(!_this.state.keyNav){_this.setState({curEntry:[].concat(_toConsumableArray(path),[idx])})}},onMouseLeave:function onMouseLeave(){if(!_this.state.keyNav){_this.setState({curEntry:null})}},ref:function ref(el){if(active&&el&&_this.state.keyNav){el.scrollIntoView(false)}}},/*#__PURE__*/React.createElement(Icon,{icon:item.icon,size:"xlarge"}),item.title?LocaleUtils.tr(item.title):LocaleUtils.tr("appmenu.items."+item.key),/*#__PURE__*/React.createElement("ul",null,subitems))}else{var trargs=item.trargs||[];var label=item.title?LocaleUtils.tr.apply(LocaleUtils,[item.title].concat(_toConsumableArray(trargs))):LocaleUtils.tr.apply(LocaleUtils,["appmenu.items."+item.key+(item.mode||"")].concat(_toConsumableArray(trargs)));var comment=item.comment?LocaleUtils.tr.apply(LocaleUtils,["appmenu.items."+item.key+(item.mode||"")+"_comment"].concat(_toConsumableArray(trargs))):"";if(!filter||removeDiacritics(label.toLowerCase()).match(filter)||comment&&removeDiacritics(comment.toLowerCase()).match(filter)){var _className=classnames({"appmenu-leaf":true,"appmenu-leaf-active":active});return/*#__PURE__*/React.createElement("li",{className:_className,key:item.key?item.key+(item.mode||""):item.title,onClick:function onClick(){return _this.onMenuitemClicked(item)},onMouseEnter:function onMouseEnter(){if(!_this.state.keyNav){_this.setState({curEntry:[].concat(_toConsumableArray(path),[idx])})}},onMouseLeave:function onMouseLeave(){if(!_this.state.keyNav){_this.setState({curEntry:null})}},ref:function ref(el){if(active&&el&&_this.state.keyNav){el.scrollIntoView(false)}}},/*#__PURE__*/React.createElement(Icon,{icon:item.icon,size:"xlarge"}),/*#__PURE__*/React.createElement("span",{className:"appmenu-leaf-label"},label,comment?/*#__PURE__*/React.createElement("div",{className:"appmenu-leaf-comment"},comment):null))}return null}}).filter(function(x){return x})}else{return null}});_defineProperty(_this,"setFilterField",function(el){_this.filterfield=el;if(_this.props.appMenuShortcut){mousetrap(el).bind(_this.props.appMenuShortcut,_this.toggleMenu)}});_this.menuEl=null;_this.filterfield=null;_this.boundShortcuts=[];return _this}_inherits(AppMenu,_React$Component);return _createClass(AppMenu,[{key:"componentDidMount",value:function componentDidMount(){if(this.props.showOnStartup){this.toggleMenu()}this.addKeyBindings(this.props.menuItems);if(this.props.appMenuShortcut){mousetrap.bind(this.props.appMenuShortcut,this.toggleMenu)}}},{key:"componentDidUpdate",value:function componentDidUpdate(prevProps,prevState){var _this2=this;if(this.state.menuVisible&&!prevState.menuVisible&&this.filterfield&&!this.props.menuCompact){// Need to wait until slide in transition is over
8
- setTimeout(function(){_this2.filterfield.focus()},400)}}},{key:"componentWillUnmount",value:function componentWillUnmount(){this.boundShortcuts.forEach(function(shortcut){return mousetrap.unbind(shortcut)});if(this.props.appMenuShortcut){mousetrap.unbind(this.props.appMenuShortcut,this.toggleMenu)}if(this.state.menuVisible){document.removeEventListener("click",this.checkCloseMenu);document.removeEventListener("keydown",this.onKeyPress,true);document.removeEventListener("mousemove",this.onMouseMove,true)}}},{key:"render",value:function render(){var _this3=this;var isMobile=ConfigUtils.isMobile();var visible=!this.props.currentTaskBlocked&&this.state.menuVisible;var showLabel=!this.props.menuCompact&&!isMobile;var className=classnames({"AppMenu":true,"appmenu-blocked":this.props.currentTaskBlocked,"appmenu-visible":visible,"appmenu-compact":this.props.menuCompact,"appmenu-nolabel":!showLabel});var filter=this.state.filter?new RegExp(removeDiacritics(this.state.filter).replace(/[-[\]/{}()*+?.\\^$|]/g,"\\$&"),"i"):null;return/*#__PURE__*/React.createElement("div",{className:className,ref:function ref(el){_this3.menuEl=el;MiscUtils.setupKillTouchEvents(el)}},/*#__PURE__*/React.createElement("div",{className:"appmenu-button",onMouseDown:this.toggleMenu,title:this.props.buttonLabel},showLabel?/*#__PURE__*/React.createElement("span",{className:"appmenu-label"},this.props.buttonLabel):null,/*#__PURE__*/React.createElement("span",{className:"appmenu-icon"},/*#__PURE__*/React.createElement(Icon,{icon:"menu-hamburger"}))),/*#__PURE__*/React.createElement("div",{className:"appmenu-menu-container"},/*#__PURE__*/React.createElement("ul",{className:"appmenu-menu"},this.props.showFilterField?/*#__PURE__*/React.createElement("li",{className:"appmenu-leaf"},/*#__PURE__*/React.createElement(Icon,{icon:"search",size:"xlarge"}),/*#__PURE__*/React.createElement(InputContainer,{className:"appmenu-filter"},/*#__PURE__*/React.createElement("input",{onChange:function onChange(ev){return _this3.setState({filter:ev.target.value,curEntry:null})},placeholder:LocaleUtils.tr("appmenu.filter"),ref:this.setFilterField,role:"input",type:"text",value:this.state.filter}),/*#__PURE__*/React.createElement(Icon,{icon:"clear",onClick:function onClick(){return _this3.setState({filter:""})},role:"suffix"}))):null,this.renderMenuItems(this.props.menuItems,0,filter,[]))))}}])}(React.Component);_defineProperty(AppMenu,"propTypes",{appMenuClearsTask:PropTypes.bool,appMenuShortcut:PropTypes.string,buttonLabel:PropTypes.string,currentTaskBlocked:PropTypes.bool,keepMenuOpen:PropTypes.bool,menuCompact:PropTypes.bool,menuItems:PropTypes.array,onMenuToggled:PropTypes.func,openExternalUrl:PropTypes.func,setCurrentTask:PropTypes.func,setMenuMargin:PropTypes.func,showFilterField:PropTypes.bool,showOnStartup:PropTypes.bool});_defineProperty(AppMenu,"defaultProps",{onMenuToggled:function onMenuToggled(){}});export default connect(function(state){return{currentTaskBlocked:state.task.blocked}},{setCurrentTask:setCurrentTask,setMenuMargin:setMenuMargin})(AppMenu);
27
+ */
28
+
29
+ import React from 'react';
30
+ import { connect } from 'react-redux';
31
+ import classnames from 'classnames';
32
+ import { remove as removeDiacritics } from 'diacritics';
33
+ import isEmpty from 'lodash.isempty';
34
+ import isEqual from 'lodash.isequal';
35
+ import mousetrap from 'mousetrap';
36
+ import PropTypes from 'prop-types';
37
+ import { setCurrentTask } from '../actions/task';
38
+ import { setMenuMargin } from '../actions/windows';
39
+ import InputContainer from '../components/widgets/InputContainer';
40
+ import ConfigUtils from '../utils/ConfigUtils';
41
+ import LocaleUtils from '../utils/LocaleUtils';
42
+ import MiscUtils from '../utils/MiscUtils';
43
+ import Icon from './Icon';
44
+ import './style/AppMenu.css';
45
+ var AppMenu = /*#__PURE__*/function (_React$Component) {
46
+ function AppMenu(props) {
47
+ var _this;
48
+ _classCallCheck(this, AppMenu);
49
+ _this = _callSuper(this, AppMenu, [props]);
50
+ _defineProperty(_this, "state", {
51
+ menuVisible: false,
52
+ filter: "",
53
+ submenusVisible: [],
54
+ curEntry: null,
55
+ keyNav: false
56
+ });
57
+ _defineProperty(_this, "addKeyBindings", function (items) {
58
+ items.forEach(function (item) {
59
+ if (item.subitems) {
60
+ _this.addKeyBindings(item.subitems);
61
+ } else if (item.shortcut) {
62
+ mousetrap.bind(item.shortcut, function () {
63
+ _this.onMenuitemClicked(item);
64
+ return false;
65
+ });
66
+ _this.boundShortcuts.push(item.shortcut);
67
+ }
68
+ });
69
+ });
70
+ _defineProperty(_this, "onKeyPress", function (ev) {
71
+ if (ev.key === 'Enter' || ev.key === 'ArrowLeft' || ev.key === 'ArrowUp' || ev.key === 'ArrowRight' || ev.key === 'ArrowDown') {
72
+ if (!_this.state.curEntry) {
73
+ if (ev.key === 'ArrowUp' || ev.key === 'ArrowDown') {
74
+ _this.setState({
75
+ curEntry: [ev.key === 'ArrowUp' ? _this.props.menuItems.length - 1 : 0]
76
+ });
77
+ }
78
+ } else {
79
+ var curEntry = _toConsumableArray(_this.state.curEntry);
80
+ var stack = [_this.props.menuItems];
81
+ _this.state.curEntry.forEach(function (entry) {
82
+ stack.push(stack[stack.length - 1][entry].subitems);
83
+ });
84
+ stack.pop();
85
+ var leaf = curEntry.pop();
86
+ var level = stack.length - 1;
87
+ if (ev.key === 'Enter') {
88
+ if (!isEmpty(stack[stack.length - 1][leaf].subitems)) {
89
+ _this.onSubmenuClicked(stack[stack.length - 1][leaf].key, level);
90
+ } else {
91
+ _this.onMenuitemClicked(stack[stack.length - 1][leaf]);
92
+ }
93
+ } else if (ev.key === 'ArrowLeft') {
94
+ if (!isEmpty(stack[stack.length - 1][leaf].subitems) && _this.state.submenusVisible[level] === stack[stack.length - 1][leaf].key) {
95
+ _this.onSubmenuClicked(stack[stack.length - 1][leaf].key, level);
96
+ }
97
+ } else if (ev.key === 'ArrowUp') {
98
+ leaf -= 1;
99
+ if (leaf >= 0 && !isEmpty(stack[stack.length - 1][leaf].subitems) && _this.state.submenusVisible[level] === stack[stack.length - 1][leaf].key) {
100
+ curEntry.push(leaf);
101
+ leaf = stack[stack.length - 1][leaf].subitems.length - 1;
102
+ } else {
103
+ while (leaf < 0 && curEntry.length > 0) {
104
+ leaf = curEntry.pop();
105
+ }
106
+ if (leaf < 0) {
107
+ leaf = _this.props.menuItems.length - 1;
108
+ }
109
+ }
110
+ } else if (ev.key === 'ArrowRight') {
111
+ if (!isEmpty(stack[stack.length - 1][leaf].subitems) && !_this.state.submenusVisible[level]) {
112
+ _this.onSubmenuClicked(stack[stack.length - 1][leaf].key, level);
113
+ }
114
+ } else if (ev.key === 'ArrowDown') {
115
+ if (!isEmpty(stack[stack.length - 1][leaf].subitems) && _this.state.submenusVisible[level] === stack[stack.length - 1][leaf].key) {
116
+ curEntry.push(leaf);
117
+ leaf = 0;
118
+ } else {
119
+ leaf += 1;
120
+ while (leaf > stack[stack.length - 1].length - 1 && curEntry.length > 0) {
121
+ leaf = curEntry.pop() + 1;
122
+ stack.pop();
123
+ }
124
+ if (leaf > _this.props.menuItems.length - 1) {
125
+ leaf = 0;
126
+ }
127
+ }
128
+ }
129
+ _this.setState({
130
+ curEntry: [].concat(_toConsumableArray(curEntry), [leaf]),
131
+ keyNav: true
132
+ });
133
+ }
134
+ MiscUtils.killEvent(ev);
135
+ } else if (ev.key === 'Escape') {
136
+ _this.toggleMenu();
137
+ MiscUtils.killEvent(ev);
138
+ }
139
+ });
140
+ _defineProperty(_this, "onMouseMove", function (ev) {
141
+ if (_this.state.keyNav) {
142
+ _this.setState({
143
+ keyNav: false
144
+ });
145
+ }
146
+ MiscUtils.killEvent(ev);
147
+ });
148
+ _defineProperty(_this, "toggleMenu", function () {
149
+ if (!_this.state.menuVisible && _this.props.currentTaskBlocked) {
150
+ return;
151
+ }
152
+ if (!_this.state.menuVisible && _this.props.appMenuClearsTask) {
153
+ _this.props.setCurrentTask(null);
154
+ }
155
+ if (!_this.props.keepMenuOpen) {
156
+ if (!_this.state.menuVisible) {
157
+ document.addEventListener('click', _this.checkCloseMenu);
158
+ document.addEventListener('keydown', _this.onKeyPress, true);
159
+ document.addEventListener('mousemove', _this.onMouseMove, true);
160
+ } else {
161
+ document.removeEventListener('click', _this.checkCloseMenu);
162
+ document.removeEventListener('keydown', _this.onKeyPress, true);
163
+ document.removeEventListener('mousemove', _this.onMouseMove, true);
164
+ }
165
+ }
166
+ _this.props.onMenuToggled(!_this.state.menuVisible);
167
+ if (_this.props.menuCompact) {
168
+ _this.props.setMenuMargin(!_this.state.menuVisible ? MiscUtils.convertEmToPx(3.75) : 0, 0);
169
+ }
170
+ _this.setState(function (state) {
171
+ return {
172
+ menuVisible: !state.menuVisible,
173
+ submenusVisible: [],
174
+ filter: ""
175
+ };
176
+ });
177
+ });
178
+ _defineProperty(_this, "checkCloseMenu", function (ev) {
179
+ if (_this.menuEl && !_this.menuEl.contains(ev.target) && !_this.props.keepMenuOpen) {
180
+ _this.toggleMenu();
181
+ }
182
+ MiscUtils.killEvent(ev);
183
+ });
184
+ _defineProperty(_this, "onSubmenuClicked", function (key, level) {
185
+ var a = _this.state.submenusVisible[level] === key ? [] : [key];
186
+ _this.setState(function (state) {
187
+ return {
188
+ submenusVisible: state.submenusVisible.slice(0, level).concat(a)
189
+ };
190
+ });
191
+ });
192
+ _defineProperty(_this, "onMenuitemClicked", function (item) {
193
+ if (!_this.props.keepMenuOpen && _this.state.menuVisible) {
194
+ _this.toggleMenu();
195
+ }
196
+ if (item.url) {
197
+ var label = item.title ? LocaleUtils.tr(item.title) : LocaleUtils.tr("appmenu.items." + item.key + (item.mode || ""));
198
+ _this.props.openExternalUrl(item.url, item.target, label, item.icon);
199
+ } else {
200
+ _this.props.setCurrentTask(item.task || item.key, item.mode, item.mapClickAction || (item.identifyEnabled ? "identify" : null));
201
+ }
202
+ });
203
+ _defineProperty(_this, "renderMenuItems", function (items, level, filter, path) {
204
+ if (items) {
205
+ return items.map(function (item, idx) {
206
+ var active = isEqual(_this.state.curEntry, [].concat(_toConsumableArray(path), [idx]));
207
+ if (item.subitems) {
208
+ var _item$key;
209
+ var subitems = _this.renderMenuItems(item.subitems, level + 1, filter, [].concat(_toConsumableArray(path), [idx]));
210
+ if (filter && isEmpty(subitems)) {
211
+ return null;
212
+ }
213
+ var visible = filter && !isEmpty(subitems) || _this.state.submenusVisible[level] === item.key;
214
+ var className = classnames({
215
+ "appmenu-submenu": true,
216
+ "appmenu-submenu-active": active,
217
+ "appmenu-submenu-expanded": visible
218
+ });
219
+ return /*#__PURE__*/React.createElement("li", {
220
+ className: className,
221
+ key: (_item$key = item.key) !== null && _item$key !== void 0 ? _item$key : item.title,
222
+ onClick: function onClick() {
223
+ return _this.onSubmenuClicked(item.key, level);
224
+ },
225
+ onMouseEnter: function onMouseEnter() {
226
+ if (!_this.state.keyNav) {
227
+ _this.setState({
228
+ curEntry: [].concat(_toConsumableArray(path), [idx])
229
+ });
230
+ }
231
+ },
232
+ onMouseLeave: function onMouseLeave() {
233
+ if (!_this.state.keyNav) {
234
+ _this.setState({
235
+ curEntry: null
236
+ });
237
+ }
238
+ },
239
+ ref: function ref(el) {
240
+ if (active && el && _this.state.keyNav) {
241
+ el.scrollIntoView(false);
242
+ }
243
+ }
244
+ }, /*#__PURE__*/React.createElement(Icon, {
245
+ icon: item.icon,
246
+ size: "xlarge"
247
+ }), item.title ? LocaleUtils.tr(item.title) : LocaleUtils.tr("appmenu.items." + item.key), /*#__PURE__*/React.createElement("ul", null, subitems));
248
+ } else {
249
+ var trargs = item.trargs || [];
250
+ var label = item.title ? LocaleUtils.tr.apply(LocaleUtils, [item.title].concat(_toConsumableArray(trargs))) : LocaleUtils.tr.apply(LocaleUtils, ["appmenu.items." + item.key + (item.mode || "")].concat(_toConsumableArray(trargs)));
251
+ var comment = item.comment ? LocaleUtils.tr.apply(LocaleUtils, ["appmenu.items." + item.key + (item.mode || "") + "_comment"].concat(_toConsumableArray(trargs))) : "";
252
+ if (!filter || removeDiacritics(label.toLowerCase()).match(filter) || comment && removeDiacritics(comment.toLowerCase()).match(filter)) {
253
+ var _className = classnames({
254
+ "appmenu-leaf": true,
255
+ "appmenu-leaf-active": active
256
+ });
257
+ return /*#__PURE__*/React.createElement("li", {
258
+ className: _className,
259
+ key: item.key ? item.key + (item.mode || "") : item.title,
260
+ onClick: function onClick() {
261
+ return _this.onMenuitemClicked(item);
262
+ },
263
+ onMouseEnter: function onMouseEnter() {
264
+ if (!_this.state.keyNav) {
265
+ _this.setState({
266
+ curEntry: [].concat(_toConsumableArray(path), [idx])
267
+ });
268
+ }
269
+ },
270
+ onMouseLeave: function onMouseLeave() {
271
+ if (!_this.state.keyNav) {
272
+ _this.setState({
273
+ curEntry: null
274
+ });
275
+ }
276
+ },
277
+ ref: function ref(el) {
278
+ if (active && el && _this.state.keyNav) {
279
+ el.scrollIntoView(false);
280
+ }
281
+ }
282
+ }, /*#__PURE__*/React.createElement(Icon, {
283
+ icon: item.icon,
284
+ size: "xlarge"
285
+ }), /*#__PURE__*/React.createElement("span", {
286
+ className: "appmenu-leaf-label"
287
+ }, label, comment ? /*#__PURE__*/React.createElement("div", {
288
+ className: "appmenu-leaf-comment"
289
+ }, comment) : null));
290
+ }
291
+ return null;
292
+ }
293
+ }).filter(function (x) {
294
+ return x;
295
+ });
296
+ } else {
297
+ return null;
298
+ }
299
+ });
300
+ _defineProperty(_this, "setFilterField", function (el) {
301
+ _this.filterfield = el;
302
+ if (_this.props.appMenuShortcut) {
303
+ mousetrap(el).bind(_this.props.appMenuShortcut, _this.toggleMenu);
304
+ }
305
+ });
306
+ _this.menuEl = null;
307
+ _this.filterfield = null;
308
+ _this.boundShortcuts = [];
309
+ return _this;
310
+ }
311
+ _inherits(AppMenu, _React$Component);
312
+ return _createClass(AppMenu, [{
313
+ key: "componentDidMount",
314
+ value: function componentDidMount() {
315
+ if (this.props.showOnStartup) {
316
+ this.toggleMenu();
317
+ }
318
+ this.addKeyBindings(this.props.menuItems);
319
+ if (this.props.appMenuShortcut) {
320
+ mousetrap.bind(this.props.appMenuShortcut, this.toggleMenu);
321
+ }
322
+ }
323
+ }, {
324
+ key: "componentDidUpdate",
325
+ value: function componentDidUpdate(prevProps, prevState) {
326
+ var _this2 = this;
327
+ if (this.state.menuVisible && !prevState.menuVisible && this.filterfield && !this.props.menuCompact) {
328
+ // Need to wait until slide in transition is over
329
+ setTimeout(function () {
330
+ _this2.filterfield.focus();
331
+ }, 400);
332
+ }
333
+ }
334
+ }, {
335
+ key: "componentWillUnmount",
336
+ value: function componentWillUnmount() {
337
+ this.boundShortcuts.forEach(function (shortcut) {
338
+ return mousetrap.unbind(shortcut);
339
+ });
340
+ if (this.props.appMenuShortcut) {
341
+ mousetrap.unbind(this.props.appMenuShortcut, this.toggleMenu);
342
+ }
343
+ if (this.state.menuVisible) {
344
+ document.removeEventListener('click', this.checkCloseMenu);
345
+ document.removeEventListener('keydown', this.onKeyPress, true);
346
+ document.removeEventListener('mousemove', this.onMouseMove, true);
347
+ }
348
+ }
349
+ }, {
350
+ key: "render",
351
+ value: function render() {
352
+ var _this3 = this;
353
+ var isMobile = ConfigUtils.isMobile();
354
+ var visible = !this.props.currentTaskBlocked && this.state.menuVisible;
355
+ var showLabel = !this.props.menuCompact && !isMobile;
356
+ var className = classnames({
357
+ "AppMenu": true,
358
+ "appmenu-blocked": this.props.currentTaskBlocked,
359
+ "appmenu-visible": visible,
360
+ "appmenu-compact": this.props.menuCompact,
361
+ "appmenu-nolabel": !showLabel
362
+ });
363
+ var filter = this.state.filter ? new RegExp(removeDiacritics(this.state.filter).replace(/[-[\]/{}()*+?.\\^$|]/g, "\\$&"), "i") : null;
364
+ return /*#__PURE__*/React.createElement("div", {
365
+ className: className,
366
+ ref: function ref(el) {
367
+ _this3.menuEl = el;
368
+ MiscUtils.setupKillTouchEvents(el);
369
+ }
370
+ }, /*#__PURE__*/React.createElement("div", {
371
+ className: "appmenu-button",
372
+ onMouseDown: this.toggleMenu,
373
+ title: this.props.buttonLabel
374
+ }, showLabel ? /*#__PURE__*/React.createElement("span", {
375
+ className: "appmenu-label"
376
+ }, this.props.buttonLabel) : null, /*#__PURE__*/React.createElement("span", {
377
+ className: "appmenu-icon"
378
+ }, /*#__PURE__*/React.createElement(Icon, {
379
+ icon: "menu-hamburger"
380
+ }))), /*#__PURE__*/React.createElement("div", {
381
+ className: "appmenu-menu-container"
382
+ }, /*#__PURE__*/React.createElement("ul", {
383
+ className: "appmenu-menu"
384
+ }, this.props.showFilterField ? /*#__PURE__*/React.createElement("li", {
385
+ className: "appmenu-leaf"
386
+ }, /*#__PURE__*/React.createElement(Icon, {
387
+ icon: "search",
388
+ size: "xlarge"
389
+ }), /*#__PURE__*/React.createElement(InputContainer, {
390
+ className: "appmenu-filter"
391
+ }, /*#__PURE__*/React.createElement("input", {
392
+ onChange: function onChange(ev) {
393
+ return _this3.setState({
394
+ filter: ev.target.value,
395
+ curEntry: null
396
+ });
397
+ },
398
+ placeholder: LocaleUtils.tr("appmenu.filter"),
399
+ ref: this.setFilterField,
400
+ role: "input",
401
+ type: "text",
402
+ value: this.state.filter
403
+ }), /*#__PURE__*/React.createElement(Icon, {
404
+ icon: "clear",
405
+ onClick: function onClick() {
406
+ return _this3.setState({
407
+ filter: ""
408
+ });
409
+ },
410
+ role: "suffix"
411
+ }))) : null, this.renderMenuItems(this.props.menuItems, 0, filter, []))));
412
+ }
413
+ }]);
414
+ }(React.Component);
415
+ _defineProperty(AppMenu, "propTypes", {
416
+ appMenuClearsTask: PropTypes.bool,
417
+ appMenuShortcut: PropTypes.string,
418
+ buttonLabel: PropTypes.string,
419
+ currentTaskBlocked: PropTypes.bool,
420
+ keepMenuOpen: PropTypes.bool,
421
+ menuCompact: PropTypes.bool,
422
+ menuItems: PropTypes.array,
423
+ onMenuToggled: PropTypes.func,
424
+ openExternalUrl: PropTypes.func,
425
+ setCurrentTask: PropTypes.func,
426
+ setMenuMargin: PropTypes.func,
427
+ showFilterField: PropTypes.bool,
428
+ showOnStartup: PropTypes.bool
429
+ });
430
+ _defineProperty(AppMenu, "defaultProps", {
431
+ onMenuToggled: function onMenuToggled() {}
432
+ });
433
+ export default connect(function (state) {
434
+ return {
435
+ currentTaskBlocked: state.task.blocked
436
+ };
437
+ }, {
438
+ setCurrentTask: setCurrentTask,
439
+ setMenuMargin: setMenuMargin
440
+ })(AppMenu);