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,3 +1,219 @@
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 _createForOfIteratorHelper(r,e){var t="undefined"!=typeof Symbol&&r[Symbol.iterator]||r["@@iterator"];if(!t){if(Array.isArray(r)||(t=_unsupportedIterableToArray(r))||e&&r&&"number"==typeof r.length){t&&(r=t);var _n=0,F=function F(){};return{s:F,n:function n(){return _n>=r.length?{done:!0}:{done:!1,value:r[_n++]}},e:function e(r){throw r},f:F}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}var o,a=!0,u=!1;return{s:function s(){t=t.call(r)},n:function n(){var r=t.next();return a=r.done,r},e:function e(r){u=!0,o=r},f:function f(){try{a||null==t["return"]||t["return"]()}finally{if(u)throw 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 _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)}import React from"react";import{remove as removeDiacritics}from"diacritics";import isEmpty from"lodash.isempty";import PropTypes from"prop-types";import LayerUtils from"../../utils/LayerUtils";import LocaleUtils from"../../utils/LocaleUtils";import ServiceLayerUtils from"../../utils/ServiceLayerUtils";import Icon from"../Icon";import InputContainer from"./InputContainer";import"./style/LayerCatalogWidget.css";var LayerCatalogWidget=/*#__PURE__*/function(_React$PureComponent){function LayerCatalogWidget(props){var _this;_classCallCheck(this,LayerCatalogWidget);_this=_callSuper(this,LayerCatalogWidget,[props]);_defineProperty(_this,"state",{catalog:[],filter:""});_defineProperty(_this,"toggleLayerListEntry",function(path){_this.setState(function(state){var newCatalog=_toConsumableArray(state.catalog);newCatalog[path[0]]=_objectSpread({},newCatalog[path[0]]);var cur=newCatalog[path[0]];var _iterator=_createForOfIteratorHelper(path.slice(1)),_step;try{for(_iterator.s();!(_step=_iterator.n()).done;){var idx=_step.value;cur.sublayers[idx]=_objectSpread({},cur.sublayers[idx]);cur=cur.sublayers[idx]}}catch(err){_iterator.e(err)}finally{_iterator.f()}cur.expanded=!cur.expanded;return{catalog:newCatalog}})});_defineProperty(_this,"addServiceLayer",function(entry){var asGroup=arguments.length>1&&arguments[1]!==undefined?arguments[1]:false;if(entry.resource){var _entry$title;var params=LayerUtils.splitLayerUrlParam(entry.resource);// Create placeholder layer
2
- _this.props.addLayer({id:params.id,type:"placeholder",name:params.name,title:(_entry$title=entry.title)!==null&&_entry$title!==void 0?_entry$title:params.name,role:params.USERLAYER,loading:true});ServiceLayerUtils.findLayers(params.type,params.url,[params],_this.props.mapCrs,function(id,layer){if(layer){if(entry.sublayers===false||!asGroup){layer.sublayers=null}LayerUtils.propagateLayerProperty(layer,"opacity",params.opacity);_this.props.replacePlaceholderLayer(params.id,layer)}else{// eslint-disable-next-line
3
- alert(LocaleUtils.tr("importlayer.addfailed"));_this.props.removeLayer(params.id)}})}else if(entry.type==="wms"||entry.type==="wfs"||entry.type==="wmts"){if(asGroup){_this.props.addLayer(entry)}else{_this.props.addLayer(_objectSpread(_objectSpread({},entry),{},{sublayers:null}))}}});_this.state.catalog=props.catalog||[];return _this}_inherits(LayerCatalogWidget,_React$PureComponent);return _createClass(LayerCatalogWidget,[{key:"componentDidUpdate",value:function componentDidUpdate(prevProps){if(this.props.catalog!==prevProps.catalog){this.setState({catalog:this.props.catalog||[]})}}},{key:"renderCatalogEntry",value:function renderCatalogEntry(entry,filter,path){var _this2=this;var level=arguments.length>3&&arguments[3]!==undefined?arguments[3]:0;var idx=arguments.length>4?arguments[4]:undefined;var hasSublayers=!isEmpty(entry.sublayers);var sublayers=hasSublayers?entry.sublayers.map(function(sublayer,i){return _this2.renderCatalogEntry(sublayer,filter,[].concat(_toConsumableArray(path),[i]),level+1,i)}):[];if(sublayers.filter(function(item){return item}).length===0&&filter&&!removeDiacritics(entry.title).match(filter)){return null}var type=entry.resource?entry.resource.slice(0,entry.resource.indexOf(":")):entry.type;var key=(entry.resource||entry.type+":"+entry.name)+":"+idx;var indentSize=!this.props.levelBasedIndentSize&&level>0?1.5:level;return/*#__PURE__*/React.createElement("div",{key:key,style:{paddingLeft:indentSize+"em"}},/*#__PURE__*/React.createElement("div",{className:"layer-catalog-widget-entry"},hasSublayers?/*#__PURE__*/React.createElement(Icon,{icon:entry.expanded?"tree_minus":"tree_plus",onClick:function onClick(){return _this2.toggleLayerListEntry(path)}}):/*#__PURE__*/React.createElement("span",{className:"layer-catalog-widget-entry-iconspacer"}),/*#__PURE__*/React.createElement("span",{className:"layer-catalog-widget-entry-contents",onClick:function onClick(){return type?_this2.addServiceLayer(entry,!hasSublayers):_this2.toggleLayerListEntry(path)}},type?/*#__PURE__*/React.createElement("span",{className:"layer-catalog-widget-entry-service"},type):null,entry.title),hasSublayers&&type==="wms"?/*#__PURE__*/React.createElement(Icon,{icon:"group",onClick:function onClick(){return _this2.addServiceLayer(entry,true)},title:LocaleUtils.tr("importlayer.asgroup")}):null),entry.expanded?sublayers:null)}},{key:"render",value:function render(){var _this3=this;var filter=new RegExp(removeDiacritics(this.state.filter).replace(/[-[\]/{}()*+?.\\^$|]/g,"\\$&"),"i");var emptyEntry=null;if(isEmpty(this.state.catalog)&&this.props.pendingRequests===0){emptyEntry=/*#__PURE__*/React.createElement("div",{className:"layer-catalog-placeholder"},LocaleUtils.tr("importlayer.noresults"))}else if(isEmpty(this.state.catalog)){emptyEntry=/*#__PURE__*/React.createElement("div",{className:"layer-catalog-placeholder"},LocaleUtils.tr("importlayer.loading"))}var filterplaceholder=LocaleUtils.tr("importlayer.filter");return/*#__PURE__*/React.createElement("div",{className:"layer-catalog-widget"},/*#__PURE__*/React.createElement(InputContainer,{className:"layer-catalog-widget-filter"},/*#__PURE__*/React.createElement("input",{onChange:function onChange(ev){return _this3.setState({filter:ev.target.value})},placeholder:filterplaceholder,role:"input",type:"text",value:this.state.filter}),/*#__PURE__*/React.createElement(Icon,{icon:"clear",onClick:function onClick(){return _this3.setState({filter:""})},role:"suffix"})),/*#__PURE__*/React.createElement("div",{className:"layer-catalog-widget-body"},this.state.catalog.map(function(entry,idx){return _this3.renderCatalogEntry(entry,filter,[idx],0,idx)}),emptyEntry))}}])}(React.PureComponent);_defineProperty(LayerCatalogWidget,"propTypes",{addLayer:PropTypes.func,catalog:PropTypes.array,levelBasedIndentSize:PropTypes.bool,mapCrs:PropTypes.string,pendingRequests:PropTypes.number,removeLayer:PropTypes.func,replacePlaceholderLayer:PropTypes.func});export{LayerCatalogWidget as default};
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 _createForOfIteratorHelper(r, e) { var t = "undefined" != typeof Symbol && r[Symbol.iterator] || r["@@iterator"]; if (!t) { if (Array.isArray(r) || (t = _unsupportedIterableToArray(r)) || e && r && "number" == typeof r.length) { t && (r = t); var _n = 0, F = function F() {}; return { s: F, n: function n() { return _n >= r.length ? { done: !0 } : { done: !1, value: r[_n++] }; }, e: function e(r) { throw r; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var o, a = !0, u = !1; return { s: function s() { t = t.call(r); }, n: function n() { var r = t.next(); return a = r.done, r; }, e: function e(r) { u = !0, o = r; }, f: function f() { try { a || null == t["return"] || t["return"](); } finally { if (u) throw o; } } }; }
3
+ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
4
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
5
+ function _toConsumableArray(r) { return _arrayWithoutHoles(r) || _iterableToArray(r) || _unsupportedIterableToArray(r) || _nonIterableSpread(); }
6
+ 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."); }
7
+ 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; } }
8
+ function _iterableToArray(r) { if ("undefined" != typeof Symbol && null != r[Symbol.iterator] || null != r["@@iterator"]) return Array.from(r); }
9
+ function _arrayWithoutHoles(r) { if (Array.isArray(r)) return _arrayLikeToArray(r); }
10
+ 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; }
11
+ function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); }
12
+ 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); } }
13
+ function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; }
14
+ function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); }
15
+ 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); }
16
+ function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; }
17
+ function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }
18
+ function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); }
19
+ 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); }
20
+ function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); }
21
+ 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; }
22
+ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
23
+ 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); }
24
+ import React from 'react';
25
+ import { remove as removeDiacritics } from 'diacritics';
26
+ import isEmpty from 'lodash.isempty';
27
+ import PropTypes from 'prop-types';
28
+ import LayerUtils from '../../utils/LayerUtils';
29
+ import LocaleUtils from '../../utils/LocaleUtils';
30
+ import ServiceLayerUtils from '../../utils/ServiceLayerUtils';
31
+ import Icon from '../Icon';
32
+ import InputContainer from './InputContainer';
33
+ import './style/LayerCatalogWidget.css';
34
+ var LayerCatalogWidget = /*#__PURE__*/function (_React$PureComponent) {
35
+ function LayerCatalogWidget(props) {
36
+ var _this;
37
+ _classCallCheck(this, LayerCatalogWidget);
38
+ _this = _callSuper(this, LayerCatalogWidget, [props]);
39
+ _defineProperty(_this, "state", {
40
+ catalog: [],
41
+ filter: ""
42
+ });
43
+ _defineProperty(_this, "toggleLayerListEntry", function (path) {
44
+ _this.setState(function (state) {
45
+ var newCatalog = _toConsumableArray(state.catalog);
46
+ newCatalog[path[0]] = _objectSpread({}, newCatalog[path[0]]);
47
+ var cur = newCatalog[path[0]];
48
+ var _iterator = _createForOfIteratorHelper(path.slice(1)),
49
+ _step;
50
+ try {
51
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
52
+ var idx = _step.value;
53
+ cur.sublayers[idx] = _objectSpread({}, cur.sublayers[idx]);
54
+ cur = cur.sublayers[idx];
55
+ }
56
+ } catch (err) {
57
+ _iterator.e(err);
58
+ } finally {
59
+ _iterator.f();
60
+ }
61
+ cur.expanded = !cur.expanded;
62
+ return {
63
+ catalog: newCatalog
64
+ };
65
+ });
66
+ });
67
+ _defineProperty(_this, "addServiceLayer", function (entry) {
68
+ var asGroup = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : false;
69
+ if (entry.resource) {
70
+ var _entry$title;
71
+ var params = LayerUtils.splitLayerUrlParam(entry.resource);
72
+ // Create placeholder layer
73
+ _this.props.addLayer({
74
+ id: params.id,
75
+ type: "placeholder",
76
+ name: params.name,
77
+ title: (_entry$title = entry.title) !== null && _entry$title !== void 0 ? _entry$title : params.name,
78
+ role: params.USERLAYER,
79
+ loading: true
80
+ });
81
+ ServiceLayerUtils.findLayers(params.type, params.url, [params], _this.props.mapCrs, function (id, layer) {
82
+ if (layer) {
83
+ if (entry.sublayers === false || !asGroup) {
84
+ layer.sublayers = null;
85
+ }
86
+ LayerUtils.propagateLayerProperty(layer, "opacity", params.opacity);
87
+ _this.props.replacePlaceholderLayer(params.id, layer);
88
+ } else {
89
+ // eslint-disable-next-line
90
+ alert(LocaleUtils.tr("importlayer.addfailed"));
91
+ _this.props.removeLayer(params.id);
92
+ }
93
+ });
94
+ } else if (entry.type === "wms" || entry.type === "wfs" || entry.type === "wmts") {
95
+ if (asGroup) {
96
+ _this.props.addLayer(entry);
97
+ } else {
98
+ _this.props.addLayer(_objectSpread(_objectSpread({}, entry), {}, {
99
+ sublayers: null
100
+ }));
101
+ }
102
+ }
103
+ });
104
+ _this.state.catalog = props.catalog || [];
105
+ return _this;
106
+ }
107
+ _inherits(LayerCatalogWidget, _React$PureComponent);
108
+ return _createClass(LayerCatalogWidget, [{
109
+ key: "componentDidUpdate",
110
+ value: function componentDidUpdate(prevProps) {
111
+ if (this.props.catalog !== prevProps.catalog) {
112
+ this.setState({
113
+ catalog: this.props.catalog || []
114
+ });
115
+ }
116
+ }
117
+ }, {
118
+ key: "renderCatalogEntry",
119
+ value: function renderCatalogEntry(entry, filter, path) {
120
+ var _this2 = this;
121
+ var level = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : 0;
122
+ var idx = arguments.length > 4 ? arguments[4] : undefined;
123
+ var hasSublayers = !isEmpty(entry.sublayers);
124
+ var sublayers = hasSublayers ? entry.sublayers.map(function (sublayer, i) {
125
+ return _this2.renderCatalogEntry(sublayer, filter, [].concat(_toConsumableArray(path), [i]), level + 1, i);
126
+ }) : [];
127
+ if (sublayers.filter(function (item) {
128
+ return item;
129
+ }).length === 0 && filter && !removeDiacritics(entry.title).match(filter)) {
130
+ return null;
131
+ }
132
+ var type = entry.resource ? entry.resource.slice(0, entry.resource.indexOf(":")) : entry.type;
133
+ var key = (entry.resource || entry.type + ":" + entry.name) + ":" + idx;
134
+ var indentSize = !this.props.levelBasedIndentSize && level > 0 ? 1.5 : level;
135
+ return /*#__PURE__*/React.createElement("div", {
136
+ key: key,
137
+ style: {
138
+ paddingLeft: indentSize + 'em'
139
+ }
140
+ }, /*#__PURE__*/React.createElement("div", {
141
+ className: "layer-catalog-widget-entry"
142
+ }, hasSublayers ? /*#__PURE__*/React.createElement(Icon, {
143
+ icon: entry.expanded ? 'tree_minus' : 'tree_plus',
144
+ onClick: function onClick() {
145
+ return _this2.toggleLayerListEntry(path);
146
+ }
147
+ }) : /*#__PURE__*/React.createElement("span", {
148
+ className: "layer-catalog-widget-entry-iconspacer"
149
+ }), /*#__PURE__*/React.createElement("span", {
150
+ className: "layer-catalog-widget-entry-contents",
151
+ onClick: function onClick() {
152
+ return type ? _this2.addServiceLayer(entry, !hasSublayers) : _this2.toggleLayerListEntry(path);
153
+ }
154
+ }, type ? /*#__PURE__*/React.createElement("span", {
155
+ className: "layer-catalog-widget-entry-service"
156
+ }, type) : null, entry.title), hasSublayers && type === "wms" ? /*#__PURE__*/React.createElement(Icon, {
157
+ icon: "group",
158
+ onClick: function onClick() {
159
+ return _this2.addServiceLayer(entry, true);
160
+ },
161
+ title: LocaleUtils.tr("importlayer.asgroup")
162
+ }) : null), entry.expanded ? sublayers : null);
163
+ }
164
+ }, {
165
+ key: "render",
166
+ value: function render() {
167
+ var _this3 = this;
168
+ var filter = new RegExp(removeDiacritics(this.state.filter).replace(/[-[\]/{}()*+?.\\^$|]/g, "\\$&"), "i");
169
+ var emptyEntry = null;
170
+ if (isEmpty(this.state.catalog) && this.props.pendingRequests === 0) {
171
+ emptyEntry = /*#__PURE__*/React.createElement("div", {
172
+ className: "layer-catalog-placeholder"
173
+ }, LocaleUtils.tr("importlayer.noresults"));
174
+ } else if (isEmpty(this.state.catalog)) {
175
+ emptyEntry = /*#__PURE__*/React.createElement("div", {
176
+ className: "layer-catalog-placeholder"
177
+ }, LocaleUtils.tr("importlayer.loading"));
178
+ }
179
+ var filterplaceholder = LocaleUtils.tr("importlayer.filter");
180
+ return /*#__PURE__*/React.createElement("div", {
181
+ className: "layer-catalog-widget"
182
+ }, /*#__PURE__*/React.createElement(InputContainer, {
183
+ className: "layer-catalog-widget-filter"
184
+ }, /*#__PURE__*/React.createElement("input", {
185
+ onChange: function onChange(ev) {
186
+ return _this3.setState({
187
+ filter: ev.target.value
188
+ });
189
+ },
190
+ placeholder: filterplaceholder,
191
+ role: "input",
192
+ type: "text",
193
+ value: this.state.filter
194
+ }), /*#__PURE__*/React.createElement(Icon, {
195
+ icon: "clear",
196
+ onClick: function onClick() {
197
+ return _this3.setState({
198
+ filter: ""
199
+ });
200
+ },
201
+ role: "suffix"
202
+ })), /*#__PURE__*/React.createElement("div", {
203
+ className: "layer-catalog-widget-body"
204
+ }, this.state.catalog.map(function (entry, idx) {
205
+ return _this3.renderCatalogEntry(entry, filter, [idx], 0, idx);
206
+ }), emptyEntry));
207
+ }
208
+ }]);
209
+ }(React.PureComponent);
210
+ _defineProperty(LayerCatalogWidget, "propTypes", {
211
+ addLayer: PropTypes.func,
212
+ catalog: PropTypes.array,
213
+ levelBasedIndentSize: PropTypes.bool,
214
+ mapCrs: PropTypes.string,
215
+ pendingRequests: PropTypes.number,
216
+ removeLayer: PropTypes.func,
217
+ replacePlaceholderLayer: PropTypes.func
218
+ });
219
+ export { LayerCatalogWidget as default };
@@ -1 +1,157 @@
1
- function _typeof(o){"@babel/helpers - typeof";return _typeof="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(o){return typeof o}:function(o){return o&&"function"==typeof Symbol&&o.constructor===Symbol&&o!==Symbol.prototype?"symbol":typeof o},_typeof(o)}function _classCallCheck(a,n){if(!(a instanceof n))throw new TypeError("Cannot call a class as a function")}function _defineProperties(e,r){for(var t=0;t<r.length;t++){var o=r[t];o.enumerable=o.enumerable||!1,o.configurable=!0,"value"in o&&(o.writable=!0),Object.defineProperty(e,_toPropertyKey(o.key),o)}}function _createClass(e,r,t){return r&&_defineProperties(e.prototype,r),t&&_defineProperties(e,t),Object.defineProperty(e,"prototype",{writable:!1}),e}function _callSuper(t,o,e){return o=_getPrototypeOf(o),_possibleConstructorReturn(t,_isNativeReflectConstruct()?Reflect.construct(o,e||[],_getPrototypeOf(t).constructor):o.apply(t,e))}function _possibleConstructorReturn(t,e){if(e&&("object"==_typeof(e)||"function"==typeof e))return e;if(void 0!==e)throw new TypeError("Derived constructors may only return object or undefined");return _assertThisInitialized(t)}function _assertThisInitialized(e){if(void 0===e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return e}function _isNativeReflectConstruct(){try{var t=!Boolean.prototype.valueOf.call(Reflect.construct(Boolean,[],function(){}))}catch(t){}return(_isNativeReflectConstruct=function _isNativeReflectConstruct(){return!!t})()}function _getPrototypeOf(t){return _getPrototypeOf=Object.setPrototypeOf?Object.getPrototypeOf.bind():function(t){return t.__proto__||Object.getPrototypeOf(t)},_getPrototypeOf(t)}function _inherits(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),Object.defineProperty(t,"prototype",{writable:!1}),e&&_setPrototypeOf(t,e)}function _setPrototypeOf(t,e){return _setPrototypeOf=Object.setPrototypeOf?Object.setPrototypeOf.bind():function(t,e){return t.__proto__=e,t},_setPrototypeOf(t,e)}function _defineProperty(e,r,t){return(r=_toPropertyKey(r))in e?Object.defineProperty(e,r,{value:t,enumerable:!0,configurable:!0,writable:!0}):e[r]=t,e}function _toPropertyKey(t){var i=_toPrimitive(t,"string");return"symbol"==_typeof(i)?i:i+""}function _toPrimitive(t,r){if("object"!=_typeof(t)||!t)return t;var e=t[Symbol.toPrimitive];if(void 0!==e){var i=e.call(t,r||"default");if("object"!=_typeof(i))return i;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===r?String:Number)(t)}import React from"react";import classnames from"classnames";import PropTypes from"prop-types";import Icon from"../Icon";import PopupMenu from"./PopupMenu";import"./style/MenuButton.css";var MenuButton=/*#__PURE__*/function(_React$Component){function MenuButton(props){var _this;_classCallCheck(this,MenuButton);_this=_callSuper(this,MenuButton,[props]);_defineProperty(_this,"state",{popup:false,selected:null});_defineProperty(_this,"onMenuClicked",function(){if(!_this.props.disabled){_this.setState({popup:true})}});_defineProperty(_this,"onButtonClicked",function(ev){ev.stopPropagation();if(_this.state.selected){_this.props.onActivate(_this.state.selected)}else{_this.onMenuClicked()}});_defineProperty(_this,"onChildClicked",function(child){if(!child.props.disabled){if(_this.state.selected){_this.setState({selected:child.props.value})}_this.props.onActivate(child.props.value)}});_this.el=null;if(!props.menuIcon&&!props.menuLabel){var _this$props$active;_this.state.selected=((_this$props$active=_this.props.active)!==null&&_this$props$active!==void 0?_this$props$active:props.children.length>0)?props.children[0].props.value:null}return _this}_inherits(MenuButton,_React$Component);return _createClass(MenuButton,[{key:"componentDidUpdate",value:function componentDidUpdate(prevProps){if(this.props.active!==prevProps.active&&this.props.active&&this.props.active!==this.state.selected){this.setState({selected:this.props.active})}}},{key:"render",value:function render(){var _this2=this;var children=React.Children.toArray(this.props.children);var rect=this.el?this.el.getBoundingClientRect():null;var buttonContents=null;if(this.props.menuIcon||this.props.menuLabel){buttonContents=[this.props.menuIcon?/*#__PURE__*/React.createElement(Icon,{icon:this.props.menuIcon,key:"icon"}):null,this.props.menuLabel?/*#__PURE__*/React.createElement("span",null,this.props.menuLabel):null]}else{buttonContents=children.filter(function(child){return child.props.value===_this2.state.selected})}var classes=classnames(_defineProperty({"menubutton":true,"menubutton-disabled":this.props.disabled},this.props.className,!!this.props.className));var buttonClassnames=classnames({"menubutton-button":true,"menubutton-togglebutton":!this.props.menuIcon&&!this.props.menuLabel,"menubutton-menubutton":this.props.menuIcon||this.props.menuLabel,"menubutton-button-active":!!this.props.active,"menubutton-button-hover":this.state.popup});return/*#__PURE__*/React.createElement("div",{className:classes,ref:function ref(el){_this2.el=el}},/*#__PURE__*/React.createElement("div",{className:buttonClassnames,onClick:this.onMenuClicked},/*#__PURE__*/React.createElement("span",{className:"menubutton-button-content",onClick:this.onButtonClicked},buttonContents),/*#__PURE__*/React.createElement("span",{className:"menubotton-button-arrow"},/*#__PURE__*/React.createElement(Icon,{icon:"chevron-down"})),this.props.tooltip?/*#__PURE__*/React.createElement("span",{className:"menubutton-tooltip "+("menubutton-tooltip-"+this.props.tooltipPos)},this.props.tooltip):null),this.el&&this.state.popup?/*#__PURE__*/React.createElement(PopupMenu,{className:"menubutton-menu"+(this.props.menuClassName?" "+this.props.menuClassName:""),onClose:function onClose(){return _this2.setState({popup:false})},width:rect.width,x:rect.left,y:rect.bottom},children.map(function(child){var classNames=classnames(_defineProperty({"menubutton-menu-active":child.props.value===_this2.state.selected&&!child.props.disabled,"menubutton-menu-disabled":child.props.disabled},child.props.className,!!child.props.className));return/*#__PURE__*/React.cloneElement(child,{className:classNames,onClickCapture:function onClickCapture(){return _this2.onChildClicked(child)}})})):null)}}])}(React.Component);_defineProperty(MenuButton,"propTypes",{active:PropTypes.string,children:PropTypes.array,className:PropTypes.string,disabled:PropTypes.bool,menuClassName:PropTypes.string,menuIcon:PropTypes.string,menuLabel:PropTypes.string,onActivate:PropTypes.func,tooltip:PropTypes.string,tooltipPos:PropTypes.string});_defineProperty(MenuButton,"defaultProps",{tooltipPos:"bottom"});export{MenuButton as default};
1
+ function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
2
+ function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); }
3
+ function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } }
4
+ function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; }
5
+ function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); }
6
+ function _possibleConstructorReturn(t, e) { if (e && ("object" == _typeof(e) || "function" == typeof e)) return e; if (void 0 !== e) throw new TypeError("Derived constructors may only return object or undefined"); return _assertThisInitialized(t); }
7
+ function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; }
8
+ function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }
9
+ function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); }
10
+ function _inherits(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function"); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, writable: !0, configurable: !0 } }), Object.defineProperty(t, "prototype", { writable: !1 }), e && _setPrototypeOf(t, e); }
11
+ function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); }
12
+ function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
13
+ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
14
+ function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
15
+ import React from 'react';
16
+ import classnames from 'classnames';
17
+ import PropTypes from 'prop-types';
18
+ import Icon from '../Icon';
19
+ import PopupMenu from './PopupMenu';
20
+ import './style/MenuButton.css';
21
+ var MenuButton = /*#__PURE__*/function (_React$Component) {
22
+ function MenuButton(props) {
23
+ var _this;
24
+ _classCallCheck(this, MenuButton);
25
+ _this = _callSuper(this, MenuButton, [props]);
26
+ _defineProperty(_this, "state", {
27
+ popup: false,
28
+ selected: null
29
+ });
30
+ _defineProperty(_this, "onMenuClicked", function () {
31
+ if (!_this.props.disabled) {
32
+ _this.setState({
33
+ popup: true
34
+ });
35
+ }
36
+ });
37
+ _defineProperty(_this, "onButtonClicked", function (ev) {
38
+ ev.stopPropagation();
39
+ if (_this.state.selected) {
40
+ _this.props.onActivate(_this.state.selected);
41
+ } else {
42
+ _this.onMenuClicked();
43
+ }
44
+ });
45
+ _defineProperty(_this, "onChildClicked", function (child) {
46
+ if (!child.props.disabled) {
47
+ if (_this.state.selected) {
48
+ _this.setState({
49
+ selected: child.props.value
50
+ });
51
+ }
52
+ _this.props.onActivate(child.props.value);
53
+ }
54
+ });
55
+ _this.el = null;
56
+ if (!props.menuIcon && !props.menuLabel) {
57
+ var _this$props$active;
58
+ _this.state.selected = ((_this$props$active = _this.props.active) !== null && _this$props$active !== void 0 ? _this$props$active : props.children.length > 0) ? props.children[0].props.value : null;
59
+ }
60
+ return _this;
61
+ }
62
+ _inherits(MenuButton, _React$Component);
63
+ return _createClass(MenuButton, [{
64
+ key: "componentDidUpdate",
65
+ value: function componentDidUpdate(prevProps) {
66
+ if (this.props.active !== prevProps.active && this.props.active && this.props.active !== this.state.selected) {
67
+ this.setState({
68
+ selected: this.props.active
69
+ });
70
+ }
71
+ }
72
+ }, {
73
+ key: "render",
74
+ value: function render() {
75
+ var _this2 = this;
76
+ var children = React.Children.toArray(this.props.children);
77
+ var rect = this.el ? this.el.getBoundingClientRect() : null;
78
+ var buttonContents = null;
79
+ if (this.props.menuIcon || this.props.menuLabel) {
80
+ buttonContents = [this.props.menuIcon ? /*#__PURE__*/React.createElement(Icon, {
81
+ icon: this.props.menuIcon,
82
+ key: "icon"
83
+ }) : null, this.props.menuLabel ? /*#__PURE__*/React.createElement("span", null, this.props.menuLabel) : null];
84
+ } else {
85
+ buttonContents = children.filter(function (child) {
86
+ return child.props.value === _this2.state.selected;
87
+ });
88
+ }
89
+ var classes = classnames(_defineProperty({
90
+ "menubutton": true,
91
+ "menubutton-disabled": this.props.disabled
92
+ }, this.props.className, !!this.props.className));
93
+ var buttonClassnames = classnames({
94
+ "menubutton-button": true,
95
+ "menubutton-togglebutton": !this.props.menuIcon && !this.props.menuLabel,
96
+ "menubutton-menubutton": this.props.menuIcon || this.props.menuLabel,
97
+ "menubutton-button-active": !!this.props.active,
98
+ "menubutton-button-hover": this.state.popup
99
+ });
100
+ return /*#__PURE__*/React.createElement("div", {
101
+ className: classes,
102
+ ref: function ref(el) {
103
+ _this2.el = el;
104
+ }
105
+ }, /*#__PURE__*/React.createElement("div", {
106
+ className: buttonClassnames,
107
+ onClick: this.onMenuClicked
108
+ }, /*#__PURE__*/React.createElement("span", {
109
+ className: "menubutton-button-content",
110
+ onClick: this.onButtonClicked
111
+ }, buttonContents), /*#__PURE__*/React.createElement("span", {
112
+ className: "menubotton-button-arrow"
113
+ }, /*#__PURE__*/React.createElement(Icon, {
114
+ icon: "chevron-down"
115
+ })), this.props.tooltip ? /*#__PURE__*/React.createElement("span", {
116
+ className: "menubutton-tooltip " + ("menubutton-tooltip-" + this.props.tooltipPos)
117
+ }, this.props.tooltip) : null), this.el && this.state.popup ? /*#__PURE__*/React.createElement(PopupMenu, {
118
+ className: "menubutton-menu" + (this.props.menuClassName ? " " + this.props.menuClassName : ""),
119
+ onClose: function onClose() {
120
+ return _this2.setState({
121
+ popup: false
122
+ });
123
+ },
124
+ width: rect.width,
125
+ x: rect.left,
126
+ y: rect.bottom
127
+ }, children.map(function (child) {
128
+ var classNames = classnames(_defineProperty({
129
+ "menubutton-menu-active": child.props.value === _this2.state.selected && !child.props.disabled,
130
+ "menubutton-menu-disabled": child.props.disabled
131
+ }, child.props.className, !!child.props.className));
132
+ return /*#__PURE__*/React.cloneElement(child, {
133
+ className: classNames,
134
+ onClickCapture: function onClickCapture() {
135
+ return _this2.onChildClicked(child);
136
+ }
137
+ });
138
+ })) : null);
139
+ }
140
+ }]);
141
+ }(React.Component);
142
+ _defineProperty(MenuButton, "propTypes", {
143
+ active: PropTypes.string,
144
+ children: PropTypes.array,
145
+ className: PropTypes.string,
146
+ disabled: PropTypes.bool,
147
+ menuClassName: PropTypes.string,
148
+ menuIcon: PropTypes.string,
149
+ menuLabel: PropTypes.string,
150
+ onActivate: PropTypes.func,
151
+ tooltip: PropTypes.string,
152
+ tooltipPos: PropTypes.string
153
+ });
154
+ _defineProperty(MenuButton, "defaultProps", {
155
+ tooltipPos: 'bottom'
156
+ });
157
+ export { MenuButton as default };
@@ -1,7 +1,69 @@
1
- function _typeof(o){"@babel/helpers - typeof";return _typeof="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(o){return typeof o}:function(o){return o&&"function"==typeof Symbol&&o.constructor===Symbol&&o!==Symbol.prototype?"symbol":typeof o},_typeof(o)}function _classCallCheck(a,n){if(!(a instanceof n))throw new TypeError("Cannot call a class as a function")}function _defineProperties(e,r){for(var t=0;t<r.length;t++){var o=r[t];o.enumerable=o.enumerable||!1,o.configurable=!0,"value"in o&&(o.writable=!0),Object.defineProperty(e,_toPropertyKey(o.key),o)}}function _createClass(e,r,t){return r&&_defineProperties(e.prototype,r),t&&_defineProperties(e,t),Object.defineProperty(e,"prototype",{writable:!1}),e}function _callSuper(t,o,e){return o=_getPrototypeOf(o),_possibleConstructorReturn(t,_isNativeReflectConstruct()?Reflect.construct(o,e||[],_getPrototypeOf(t).constructor):o.apply(t,e))}function _possibleConstructorReturn(t,e){if(e&&("object"==_typeof(e)||"function"==typeof e))return e;if(void 0!==e)throw new TypeError("Derived constructors may only return object or undefined");return _assertThisInitialized(t)}function _assertThisInitialized(e){if(void 0===e)throw new ReferenceError("this hasn't been initialised - super() hasn't been called");return e}function _isNativeReflectConstruct(){try{var t=!Boolean.prototype.valueOf.call(Reflect.construct(Boolean,[],function(){}))}catch(t){}return(_isNativeReflectConstruct=function _isNativeReflectConstruct(){return!!t})()}function _getPrototypeOf(t){return _getPrototypeOf=Object.setPrototypeOf?Object.getPrototypeOf.bind():function(t){return t.__proto__||Object.getPrototypeOf(t)},_getPrototypeOf(t)}function _inherits(t,e){if("function"!=typeof e&&null!==e)throw new TypeError("Super expression must either be null or a function");t.prototype=Object.create(e&&e.prototype,{constructor:{value:t,writable:!0,configurable:!0}}),Object.defineProperty(t,"prototype",{writable:!1}),e&&_setPrototypeOf(t,e)}function _setPrototypeOf(t,e){return _setPrototypeOf=Object.setPrototypeOf?Object.setPrototypeOf.bind():function(t,e){return t.__proto__=e,t},_setPrototypeOf(t,e)}function _defineProperty(e,r,t){return(r=_toPropertyKey(r))in e?Object.defineProperty(e,r,{value:t,enumerable:!0,configurable:!0,writable:!0}):e[r]=t,e}function _toPropertyKey(t){var i=_toPrimitive(t,"string");return"symbol"==_typeof(i)?i:i+""}function _toPrimitive(t,r){if("object"!=_typeof(t)||!t)return t;var e=t[Symbol.toPrimitive];if(void 0!==e){var i=e.call(t,r||"default");if("object"!=_typeof(i))return i;throw new TypeError("@@toPrimitive must return a primitive value.")}return("string"===r?String:Number)(t)}/**
1
+ function _typeof(o) { "@babel/helpers - typeof"; return _typeof = "function" == typeof Symbol && "symbol" == typeof Symbol.iterator ? function (o) { return typeof o; } : function (o) { return o && "function" == typeof Symbol && o.constructor === Symbol && o !== Symbol.prototype ? "symbol" : typeof o; }, _typeof(o); }
2
+ function _classCallCheck(a, n) { if (!(a instanceof n)) throw new TypeError("Cannot call a class as a function"); }
3
+ function _defineProperties(e, r) { for (var t = 0; t < r.length; t++) { var o = r[t]; o.enumerable = o.enumerable || !1, o.configurable = !0, "value" in o && (o.writable = !0), Object.defineProperty(e, _toPropertyKey(o.key), o); } }
4
+ function _createClass(e, r, t) { return r && _defineProperties(e.prototype, r), t && _defineProperties(e, t), Object.defineProperty(e, "prototype", { writable: !1 }), e; }
5
+ function _callSuper(t, o, e) { return o = _getPrototypeOf(o), _possibleConstructorReturn(t, _isNativeReflectConstruct() ? Reflect.construct(o, e || [], _getPrototypeOf(t).constructor) : o.apply(t, e)); }
6
+ function _possibleConstructorReturn(t, e) { if (e && ("object" == _typeof(e) || "function" == typeof e)) return e; if (void 0 !== e) throw new TypeError("Derived constructors may only return object or undefined"); return _assertThisInitialized(t); }
7
+ function _assertThisInitialized(e) { if (void 0 === e) throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); return e; }
8
+ function _isNativeReflectConstruct() { try { var t = !Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); } catch (t) {} return (_isNativeReflectConstruct = function _isNativeReflectConstruct() { return !!t; })(); }
9
+ function _getPrototypeOf(t) { return _getPrototypeOf = Object.setPrototypeOf ? Object.getPrototypeOf.bind() : function (t) { return t.__proto__ || Object.getPrototypeOf(t); }, _getPrototypeOf(t); }
10
+ function _inherits(t, e) { if ("function" != typeof e && null !== e) throw new TypeError("Super expression must either be null or a function"); t.prototype = Object.create(e && e.prototype, { constructor: { value: t, writable: !0, configurable: !0 } }), Object.defineProperty(t, "prototype", { writable: !1 }), e && _setPrototypeOf(t, e); }
11
+ function _setPrototypeOf(t, e) { return _setPrototypeOf = Object.setPrototypeOf ? Object.setPrototypeOf.bind() : function (t, e) { return t.__proto__ = e, t; }, _setPrototypeOf(t, e); }
12
+ function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
13
+ function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == _typeof(i) ? i : i + ""; }
14
+ function _toPrimitive(t, r) { if ("object" != _typeof(t) || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != _typeof(i)) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
15
+ /**
2
16
  * Copyright 2024 Sourcepole AG
3
17
  * All rights reserved.
4
18
  *
5
19
  * This source code is licensed under the BSD-style license found in the
6
20
  * LICENSE file in the root directory of this source tree.
7
- */import React from"react";import ReactDOM from"react-dom";import PropTypes from"prop-types";import Icon from"../Icon";import"./style/ModalDialog.css";var ModalDialog=/*#__PURE__*/function(_React$Component){function ModalDialog(props){var _this;_classCallCheck(this,ModalDialog);_this=_callSuper(this,ModalDialog,[props]);_defineProperty(_this,"componentDidMount",function(){document.body.appendChild(_this.el)});_defineProperty(_this,"componentWillUnmount",function(){document.body.removeChild(_this.el)});_this.el=document.createElement("div");_this.el.className="modal-dialog-container";return _this}_inherits(ModalDialog,_React$Component);return _createClass(ModalDialog,[{key:"render",value:function render(){var contents=/*#__PURE__*/React.createElement("div",{className:"modal-dialog"},/*#__PURE__*/React.createElement("div",{className:"modal-dialog-title"},/*#__PURE__*/React.createElement(Icon,{icon:this.props.icon}),/*#__PURE__*/React.createElement("span",null,this.props.title),/*#__PURE__*/React.createElement(Icon,{icon:"remove",onClick:this.props.onClose})),/*#__PURE__*/React.createElement("div",{className:"modal-dialog-body"},this.props.children));return/*#__PURE__*/ReactDOM.createPortal(contents,this.el)}}])}(React.Component);_defineProperty(ModalDialog,"propTypes",{children:PropTypes.oneOfType([PropTypes.node,PropTypes.func]),icon:PropTypes.string,onClose:PropTypes.func,title:PropTypes.string});export{ModalDialog as default};
21
+ */
22
+
23
+ import React from 'react';
24
+ import ReactDOM from 'react-dom';
25
+ import PropTypes from 'prop-types';
26
+ import Icon from '../Icon';
27
+ import './style/ModalDialog.css';
28
+ var ModalDialog = /*#__PURE__*/function (_React$Component) {
29
+ function ModalDialog(props) {
30
+ var _this;
31
+ _classCallCheck(this, ModalDialog);
32
+ _this = _callSuper(this, ModalDialog, [props]);
33
+ _defineProperty(_this, "componentDidMount", function () {
34
+ document.body.appendChild(_this.el);
35
+ });
36
+ _defineProperty(_this, "componentWillUnmount", function () {
37
+ document.body.removeChild(_this.el);
38
+ });
39
+ _this.el = document.createElement("div");
40
+ _this.el.className = "modal-dialog-container";
41
+ return _this;
42
+ }
43
+ _inherits(ModalDialog, _React$Component);
44
+ return _createClass(ModalDialog, [{
45
+ key: "render",
46
+ value: function render() {
47
+ var contents = /*#__PURE__*/React.createElement("div", {
48
+ className: "modal-dialog"
49
+ }, /*#__PURE__*/React.createElement("div", {
50
+ className: "modal-dialog-title"
51
+ }, /*#__PURE__*/React.createElement(Icon, {
52
+ icon: this.props.icon
53
+ }), /*#__PURE__*/React.createElement("span", null, this.props.title), /*#__PURE__*/React.createElement(Icon, {
54
+ icon: "remove",
55
+ onClick: this.props.onClose
56
+ })), /*#__PURE__*/React.createElement("div", {
57
+ className: "modal-dialog-body"
58
+ }, this.props.children));
59
+ return /*#__PURE__*/ReactDOM.createPortal(contents, this.el);
60
+ }
61
+ }]);
62
+ }(React.Component);
63
+ _defineProperty(ModalDialog, "propTypes", {
64
+ children: PropTypes.oneOfType([PropTypes.node, PropTypes.func]),
65
+ icon: PropTypes.string,
66
+ onClose: PropTypes.func,
67
+ title: PropTypes.string
68
+ });
69
+ export { ModalDialog as default };