@mapcomponents/react-maplibre 0.1.62 → 0.1.64

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 (340) hide show
  1. package/.babelrc +21 -2
  2. package/.editorconfig +1 -1
  3. package/.eslintrc.js +11 -1
  4. package/.github/workflows/check-catalogue-metadata-schema.yml +19 -0
  5. package/.storybook/main.js +0 -1
  6. package/.storybook/preview.js +0 -2
  7. package/CHANGELOG.md +43 -0
  8. package/coverage/clover.xml +864 -1037
  9. package/coverage/coverage-final.json +32 -21
  10. package/coverage/lcov-report/favicon.png +0 -0
  11. package/coverage/lcov-report/index.html +170 -95
  12. package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  13. package/coverage/lcov-report/src/components/MapLibreMap/MapLibreMap.tsx.html +24 -24
  14. package/coverage/lcov-report/src/components/MapLibreMap/index.html +1 -1
  15. package/coverage/lcov-report/src/components/MlCenterPosition/MlCenterPosition.tsx.html +5 -5
  16. package/coverage/lcov-report/src/components/MlCenterPosition/index.html +1 -1
  17. package/coverage/lcov-report/src/components/MlCreatePdfButton/MlCreatePdfButton.tsx.html +2 -2
  18. package/coverage/lcov-report/src/components/MlCreatePdfButton/index.html +1 -1
  19. package/coverage/lcov-report/src/components/MlCreatePdfForm/MlCreatePdfForm.cy.tsx.html +148 -0
  20. package/coverage/lcov-report/src/components/MlCreatePdfForm/MlCreatePdfForm.tsx.html +1 -1
  21. package/coverage/lcov-report/src/components/MlCreatePdfForm/index.html +22 -7
  22. package/coverage/lcov-report/src/components/MlFeatureEditor/MlFeatureEditor.tsx.html +72 -42
  23. package/coverage/lcov-report/src/components/MlFeatureEditor/index.html +15 -15
  24. package/coverage/lcov-report/src/components/MlFillExtrusionLayer/MlFillExtrusionLayer.tsx.html +1 -1
  25. package/coverage/lcov-report/src/components/MlFillExtrusionLayer/index.html +1 -1
  26. package/coverage/lcov-report/src/components/MlFollowGps/MlFollowGps.tsx.html +1 -1
  27. package/coverage/lcov-report/src/components/MlFollowGps/index.html +1 -1
  28. package/coverage/lcov-report/src/components/MlGeoJsonLayer/MlGeoJsonLayer.tsx.html +86 -35
  29. package/coverage/lcov-report/src/components/MlGeoJsonLayer/index.html +1 -1
  30. package/coverage/lcov-report/src/components/{MlSpatialElevationProfile/MlSpatialElevationProfile.js.html → MlGeoJsonLayer/story_utils/MlGeoJsonLayer.lineStyler.js.html} +215 -320
  31. package/coverage/lcov-report/src/components/MlGeoJsonLayer/story_utils/MlGeoJsonLayer.polygonStyler.js.html +649 -0
  32. package/coverage/lcov-report/src/components/MlGeoJsonLayer/story_utils/MlGeojsonLayerCircleStyler.tsx.html +112 -0
  33. package/coverage/lcov-report/src/components/MlGeoJsonLayer/story_utils/MlGeojsonLayerHeatMapStyler.tsx.html +115 -0
  34. package/coverage/lcov-report/src/components/MlGeoJsonLayer/story_utils/index.html +161 -0
  35. package/coverage/lcov-report/src/components/MlGeojsonLayerWithSource/MlGeojsonLayerWithSource.tsx.html +1 -1
  36. package/coverage/lcov-report/src/components/MlGeojsonLayerWithSource/index.html +1 -1
  37. package/coverage/lcov-report/src/components/MlGpxViewer/MlGpxViewer.tsx.html +394 -0
  38. package/coverage/lcov-report/src/components/MlGpxViewer/index.html +116 -0
  39. package/coverage/lcov-report/src/components/MlImageMarkerLayer/MlImageMarkerLayer.tsx.html +63 -285
  40. package/coverage/lcov-report/src/components/MlImageMarkerLayer/index.html +21 -21
  41. package/coverage/lcov-report/src/components/MlLayer/MlLayer.tsx.html +1 -1
  42. package/coverage/lcov-report/src/components/MlLayer/index.html +1 -1
  43. package/coverage/lcov-report/src/components/MlLayerMagnify/MlLayerMagnify.tsx.html +58 -76
  44. package/coverage/lcov-report/src/components/MlLayerMagnify/index.html +1 -1
  45. package/coverage/lcov-report/src/components/MlLayerSwipe/MlLayerSwipe.tsx.html +58 -61
  46. package/coverage/lcov-report/src/components/MlLayerSwipe/index.html +11 -11
  47. package/coverage/lcov-report/src/components/MlLayerSwitcher/MlLayerSwitcher.js.html +1 -1
  48. package/coverage/lcov-report/src/components/MlLayerSwitcher/components/LayerBox.js.html +30 -21
  49. package/coverage/lcov-report/src/components/MlLayerSwitcher/components/index.html +1 -1
  50. package/coverage/lcov-report/src/components/MlLayerSwitcher/index.html +1 -1
  51. package/coverage/lcov-report/src/components/MlMarker/MlMarker.tsx.html +1 -1
  52. package/coverage/lcov-report/src/components/MlMarker/index.html +1 -1
  53. package/coverage/lcov-report/src/components/MlMeasureTool/MlMeasureTool.tsx.html +1 -1
  54. package/coverage/lcov-report/src/components/MlMeasureTool/index.html +1 -1
  55. package/coverage/lcov-report/src/components/MlNavigationCompass/MlNavigationCompass.tsx.html +1 -1
  56. package/coverage/lcov-report/src/components/MlNavigationCompass/index.html +1 -1
  57. package/coverage/lcov-report/src/components/MlNavigationTools/MlNavigationTools.tsx.html +1 -1
  58. package/coverage/lcov-report/src/components/MlNavigationTools/index.html +1 -1
  59. package/coverage/lcov-report/src/components/MlOsmLayer/MlOsmLayer.js.html +1 -1
  60. package/coverage/lcov-report/src/components/MlOsmLayer/MlOsmLayer.stories_.js.html +1 -1
  61. package/coverage/lcov-report/src/components/MlOsmLayer/index.html +1 -1
  62. package/coverage/lcov-report/src/components/MlScaleReference/MlScaleReference.js.html +1 -1
  63. package/coverage/lcov-report/src/components/MlScaleReference/index.html +1 -1
  64. package/coverage/lcov-report/src/components/MlShareMapState/MlShareMapState.js.html +1 -1
  65. package/coverage/lcov-report/src/components/MlShareMapState/index.html +1 -1
  66. package/coverage/lcov-report/src/components/MlSketchTool/LayerList/ColorPicker.tsx.html +214 -0
  67. package/coverage/lcov-report/src/components/MlSketchTool/LayerList/LayerList.tsx.html +121 -0
  68. package/coverage/lcov-report/src/components/MlSketchTool/LayerList/LayerListItem.tsx.html +412 -0
  69. package/coverage/lcov-report/src/components/MlSketchTool/LayerList/LayerPropertyForm.tsx.html +463 -0
  70. package/coverage/lcov-report/src/components/MlSketchTool/LayerList/index.html +161 -0
  71. package/coverage/lcov-report/src/components/{MlGPXViewer/MlGPXViewer.tsx.html → MlSketchTool/MlSketchTool.tsx.html} +271 -589
  72. package/coverage/lcov-report/src/components/{MlGPXViewer → MlSketchTool}/index.html +22 -37
  73. package/coverage/lcov-report/src/components/MlSpatialElevationProfile/MlSpatialElevationProfile.tsx.html +514 -0
  74. package/coverage/lcov-report/src/components/MlSpatialElevationProfile/index.html +21 -21
  75. package/coverage/lcov-report/src/components/MlThreeJsLayer/MlThreeJsLayer.js.html +1 -1
  76. package/coverage/lcov-report/src/components/MlThreeJsLayer/index.html +1 -1
  77. package/coverage/lcov-report/src/components/MlTransitionGeoJsonLayer/MlTransitionGeoJsonLayer.tsx.html +20 -206
  78. package/coverage/lcov-report/src/components/MlTransitionGeoJsonLayer/index.html +1 -1
  79. package/coverage/lcov-report/src/components/MlUseMapDebugger/MlUseMapDebugger.js.html +1 -1
  80. package/coverage/lcov-report/src/components/MlUseMapDebugger/index.html +1 -1
  81. package/coverage/lcov-report/src/components/MlVectorTileLayer/MlVectorTileLayer.tsx.html +10 -7
  82. package/coverage/lcov-report/src/components/MlVectorTileLayer/index.html +5 -5
  83. package/coverage/lcov-report/src/components/MlWmsFeatureInfoPopup/MlWmsFeatureInfoPopup.js.html +1 -1
  84. package/coverage/lcov-report/src/components/MlWmsFeatureInfoPopup/index.html +1 -1
  85. package/coverage/lcov-report/src/components/MlWmsLayer/MlWmsLayer.tsx.html +111 -57
  86. package/coverage/lcov-report/src/components/MlWmsLayer/index.html +19 -19
  87. package/coverage/lcov-report/src/components/MlWmsLoader/MlWmsLoader.tsx.html +201 -144
  88. package/coverage/lcov-report/src/components/MlWmsLoader/index.html +9 -9
  89. package/coverage/lcov-report/src/contexts/MapContext.tsx.html +23 -23
  90. package/coverage/lcov-report/src/contexts/SimpleDataContext.js.html +1 -1
  91. package/coverage/lcov-report/src/contexts/SimpleDataProvider.js.html +1 -1
  92. package/coverage/lcov-report/src/contexts/index.html +1 -1
  93. package/coverage/lcov-report/src/hooks/index.html +50 -50
  94. package/coverage/lcov-report/src/hooks/useCameraFollowPath/index.html +1 -1
  95. package/coverage/lcov-report/src/hooks/useCameraFollowPath/useCameraFollowPath.tsx.html +1 -1
  96. package/coverage/lcov-report/src/hooks/useExportMap/index.html +1 -1
  97. package/coverage/lcov-report/src/hooks/useExportMap/index.ts.html +1 -1
  98. package/coverage/lcov-report/src/hooks/useExportMap/lib.ts.html +1 -1
  99. package/coverage/lcov-report/src/hooks/useGpx/index.html +116 -0
  100. package/coverage/lcov-report/src/hooks/useGpx/useGpx.tsx.html +295 -0
  101. package/coverage/lcov-report/src/hooks/useLayer.ts.html +132 -66
  102. package/coverage/lcov-report/src/hooks/useLayerEvent.js.html +1 -1
  103. package/coverage/lcov-report/src/hooks/useLayerHoverPopup/index.html +116 -0
  104. package/coverage/lcov-report/src/hooks/useLayerHoverPopup/useLayerHoverPopup.tsx.html +331 -0
  105. package/coverage/lcov-report/src/hooks/useMap.ts.html +47 -47
  106. package/coverage/lcov-report/src/hooks/useMapState.ts.html +54 -54
  107. package/coverage/lcov-report/src/hooks/useSource.ts.html +57 -57
  108. package/coverage/lcov-report/src/hooks/{useWms.js.html → useWms.ts.html} +54 -15
  109. package/coverage/lcov-report/src/index.html +1 -1
  110. package/coverage/lcov-report/src/index.ts.html +6 -6
  111. package/coverage/lcov.info +1724 -1974
  112. package/cypress/support/commands.ts +37 -0
  113. package/cypress/support/component-index.html +12 -0
  114. package/cypress/support/component.ts +46 -0
  115. package/cypress.config.ts +101 -0
  116. package/dist/components/MapLibreMap/MapLibreMap.d.ts +1 -1
  117. package/dist/components/MapLibreMap/lib/MapLibreGlWrapper.d.ts +53 -27
  118. package/dist/components/MlCenterPosition/MlCenterPosition.d.ts +3 -2
  119. package/dist/components/MlCenterPosition/MlCenterPosition.stories.d.ts +35 -16
  120. package/dist/components/MlComponentTemplate/MlComponentTemplate.d.ts +1 -1
  121. package/dist/components/MlComponentTemplate/MlComponentTemplate.stories.d.ts +12 -9
  122. package/dist/components/MlCreatePdfButton/MlCreatePdfButton.d.ts +1 -1
  123. package/dist/components/MlCreatePdfButton/MlCreatePdfButton.stories.d.ts +12 -9
  124. package/dist/components/MlCreatePdfForm/MlCreatePdfForm.cy.d.ts +1 -0
  125. package/dist/components/MlCreatePdfForm/lib/PdfPreview.d.ts +1 -1
  126. package/dist/components/MlFeatureEditor/MlFeatureEditor.d.ts +10 -4
  127. package/dist/components/MlFeatureEditor/lib/double_click_zoom.d.ts +0 -2
  128. package/dist/components/MlFeatureEditor/lib/theme.d.ts +1 -1
  129. package/dist/components/MlGeoJsonLayer/MlGeoJsonLayer.d.ts +23 -12
  130. package/dist/components/MlGeoJsonLayer/MlGeoJsonLayer.stories.d.ts +12 -11
  131. package/dist/components/MlGeoJsonLayer/story_utils/MlGeoJsonLayer.lineStyler.d.ts +2 -0
  132. package/dist/components/MlGeoJsonLayer/story_utils/MlGeoJsonLayer.polygonStyler.d.ts +2 -0
  133. package/dist/components/MlGeoJsonLayer/story_utils/MlGeojsonLayerCircleStyler.d.ts +3 -0
  134. package/dist/components/MlGeoJsonLayer/story_utils/MlGeojsonLayerHeatMapStyler.d.ts +3 -0
  135. package/dist/components/MlGpxViewer/MlGpxViewer.d.ts +30 -0
  136. package/dist/components/MlGpxViewer/MlGpxViewer.stories.d.ts +17 -0
  137. package/dist/components/MlGpxViewer/MlGpxViewer.test.d.ts +1 -0
  138. package/dist/components/MlGpxViewer/util/GeoJsonContext.d.ts +10 -0
  139. package/dist/components/MlGpxViewer/util/GeoJsonProvider.d.ts +4 -0
  140. package/dist/components/MlGpxViewer/util/MetadataDrawer.d.ts +7 -0
  141. package/dist/components/MlGpxViewer/util/MlGpxDemoLoader.d.ts +10 -0
  142. package/dist/components/MlGpxViewer/util/MlGpxViewerInstructions.d.ts +3 -0
  143. package/dist/components/MlImageMarkerLayer/MlImageMarkerLayer.d.ts +11 -2
  144. package/dist/components/MlImageMarkerLayer/MlImageMarkerLayer.stories.d.ts +7 -9
  145. package/dist/components/MlLayerMagnify/MlLayerMagnify.d.ts +8 -2
  146. package/dist/components/MlLayerMagnify/MlLayerMagnify.stories.d.ts +13 -9
  147. package/dist/components/MlLayerSwipe/MlLayerSwipe.d.ts +13 -3
  148. package/dist/components/MlLayerSwipe/MlLayerSwipe.stories.d.ts +12 -10
  149. package/dist/components/MlSketchTool/LayerList/ColorPicker.d.ts +9 -0
  150. package/dist/components/MlSketchTool/LayerList/LayerList.d.ts +5 -0
  151. package/dist/components/MlSketchTool/LayerList/LayerListItem.d.ts +11 -0
  152. package/dist/components/MlSketchTool/LayerList/LayerPropertyForm.d.ts +9 -0
  153. package/dist/components/MlSketchTool/MlSketchTool.d.ts +29 -0
  154. package/dist/components/MlSketchTool/MlSketchTool.stories.d.ts +10 -0
  155. package/dist/components/MlSpatialElevationProfile/MlSpatialElevationProfile.d.ts +33 -14
  156. package/dist/components/MlSpatialElevationProfile/MlSpatialElevationProfile.stories.d.ts +18 -15
  157. package/dist/components/MlSpatialElevationProfile/util/getElevationData.d.ts +14 -0
  158. package/dist/components/MlTransitionGeoJsonLayer/MlTransitionGeoJsonLayer.d.ts +3 -67
  159. package/dist/components/MlWmsLayer/MlWmsLayer.d.ts +7 -4
  160. package/dist/components/MlWmsLoader/MlWmsLoader.d.ts +17 -10
  161. package/dist/components/MlWmsLoader/MlWmsLoader.stories.d.ts +23 -12
  162. package/dist/components/MlWmsLoader/utils/MlWmsLoaderInstructions.d.ts +3 -0
  163. package/dist/components/MlWmsLoader/utils/WMSLinks.d.ts +6 -0
  164. package/dist/contexts/SimpleDataProvider.d.ts +1 -1
  165. package/dist/custom.d.d.ts +1 -1
  166. package/dist/decorators/ThemeWrapper.d.ts +3 -1
  167. package/dist/hooks/useGpx/lib/gpxConverter.d.ts +11 -0
  168. package/dist/hooks/useGpx/useGpx.d.ts +26 -0
  169. package/dist/hooks/useGpx/useGpx.stories.d.ts +10 -0
  170. package/dist/hooks/useLayer.d.ts +14 -8
  171. package/dist/hooks/useLayerHoverPopup/useLayerHoverPopup.d.ts +23 -0
  172. package/dist/hooks/useLayerHoverPopup/useLayerHoverPopup.stories.d.ts +10 -0
  173. package/dist/hooks/useMap.d.ts +2 -2
  174. package/dist/hooks/useMap.test.d.ts +1 -0
  175. package/dist/hooks/useMapState.d.ts +3 -3
  176. package/dist/hooks/useSource.d.ts +3 -3
  177. package/dist/hooks/useWms.d.ts +24 -16
  178. package/dist/index.d.ts +5 -5
  179. package/dist/index.esm.css +1 -1
  180. package/dist/index.esm.js +9327 -14844
  181. package/dist/index.esm.js.map +1 -1
  182. package/dist/setupTests.d.ts +6 -5
  183. package/dist/ui_components/Dropzone.d.ts +5 -0
  184. package/dist/ui_components/ImageLoader.d.ts +8 -1
  185. package/dist/ui_components/LoadingOverlayContext.d.ts +11 -11
  186. package/dist/ui_components/Sidebar.d.ts +10 -1
  187. package/dist/ui_components/Tooltip.d.ts +1 -1
  188. package/dist/ui_components/TopToolbar.d.ts +7 -1
  189. package/dist/ui_components/UploadButton.d.ts +6 -0
  190. package/dist/util/BubbleForInstructions.d.ts +2 -0
  191. package/dist/util/Instructions.d.ts +13 -0
  192. package/package.json +195 -185
  193. package/public/assets/sample1.gpx +3003 -0
  194. package/public/assets/sample2.gpx +1264 -0
  195. package/public/assets/sample3.gpx +912 -0
  196. package/{src/components/MlImageMarkerLayer → public}/assets/wg-marker.png +0 -0
  197. package/public/index.html +0 -4
  198. package/public/thumbnails/MlSketchTool.png +0 -0
  199. package/public/thumbnails/useCameraFollowPath.png +0 -0
  200. package/scripts/build-catalogue-meta.js +35 -11
  201. package/src/components/MapLibreMap/lib/MapLibreGlWrapper.ts +230 -188
  202. package/src/components/MlCenterPosition/MlCenterPosition.meta_.json +1 -2
  203. package/src/components/MlCenterPosition/MlCenterPosition.stories.tsx +20 -0
  204. package/src/components/MlCenterPosition/MlCenterPosition.tsx +4 -4
  205. package/src/components/MlComponentTemplate/MlComponentTemplate.meta_.json +1 -2
  206. package/src/components/MlComponentTemplate/{MlComponentTemplate.stories.js → MlComponentTemplate.stories.tsx} +2 -2
  207. package/src/components/MlComponentTemplate/MlComponentTemplate.tsx +1 -1
  208. package/src/components/MlCreatePdfButton/MlCreatePdfButton.meta_.json +1 -2
  209. package/src/components/MlCreatePdfButton/{MlCreatePdfButton.stories.js → MlCreatePdfButton.stories.tsx} +1 -1
  210. package/src/components/MlCreatePdfButton/MlCreatePdfButton.tsx +1 -1
  211. package/src/components/MlCreatePdfForm/MlCreatePdfForm.cy.tsx +21 -0
  212. package/src/components/MlCreatePdfForm/MlCreatePdfForm.meta.json +1 -2
  213. package/src/components/MlCreatePdfForm/MlCreatePdfForm.stories.tsx +1 -3
  214. package/src/components/MlCreatePdfForm/lib/PdfForm.tsx +25 -2
  215. package/src/components/MlFeatureEditor/MlFeatureEditor.meta.json +2 -3
  216. package/src/components/MlFeatureEditor/MlFeatureEditor.tsx +39 -29
  217. package/src/components/MlFillExtrusionLayer/MlFillExtrusionLayer.meta.json +1 -2
  218. package/src/components/MlFollowGps/MlFollowGps.meta.json +1 -2
  219. package/src/components/MlGeoJsonLayer/MlGeoJsonLayer.meta.json +1 -2
  220. package/src/components/MlGeoJsonLayer/MlGeoJsonLayer.stories.tsx +191 -0
  221. package/src/components/MlGeoJsonLayer/MlGeoJsonLayer.tsx +47 -30
  222. package/src/components/MlGeoJsonLayer/assets/earthquake.json +109937 -0
  223. package/src/components/MlGeoJsonLayer/assets/sample_1.json +138 -24
  224. package/src/components/MlGeoJsonLayer/assets/sample_2.json +140 -20
  225. package/src/components/MlGeoJsonLayer/assets/wg_locations.json +65 -0
  226. package/src/components/MlGeoJsonLayer/story_utils/MlGeoJsonLayer.lineStyler.js +189 -0
  227. package/src/components/MlGeoJsonLayer/story_utils/MlGeoJsonLayer.polygonStyler.js +188 -0
  228. package/src/components/MlGeoJsonLayer/story_utils/MlGeojsonLayerCircleStyler.tsx +9 -0
  229. package/src/components/MlGeoJsonLayer/story_utils/MlGeojsonLayerHeatMapStyler.tsx +10 -0
  230. package/src/components/MlGeojsonLayerWithSource/MlGeojsonLayerWithSource.meta_.json +1 -2
  231. package/src/components/{MlGPXViewer/MlGPXViewer.doc.de.md → MlGpxViewer/MlGpxViewer.doc.de.md} +0 -0
  232. package/src/components/{MlGPXViewer/MlGPXViewer.doc.en.md → MlGpxViewer/MlGpxViewer.doc.en.md} +0 -0
  233. package/src/components/{MlGPXViewer/MlGPXViewer.meta.json → MlGpxViewer/MlGpxViewer.meta.json} +2 -3
  234. package/src/components/MlGpxViewer/MlGpxViewer.stories.tsx +109 -0
  235. package/src/components/MlGpxViewer/MlGpxViewer.test.js +53 -0
  236. package/src/components/MlGpxViewer/MlGpxViewer.tsx +103 -0
  237. package/src/components/{MlGPXViewer → MlGpxViewer}/util/GeoJsonContext.ts +0 -0
  238. package/src/components/{MlGPXViewer → MlGpxViewer}/util/GeoJsonProvider.tsx +0 -0
  239. package/src/components/MlGpxViewer/util/MetadataDrawer.tsx +38 -0
  240. package/src/components/MlGpxViewer/util/MlGpxDemoLoader.tsx +128 -0
  241. package/src/components/MlGpxViewer/util/MlGpxViewerInstructions.tsx +68 -0
  242. package/src/components/MlImageMarkerLayer/MlImageMarkerLayer.meta_.json +1 -2
  243. package/src/components/MlImageMarkerLayer/MlImageMarkerLayer.stories.tsx +41 -0
  244. package/src/components/MlImageMarkerLayer/MlImageMarkerLayer.test.js +27 -8
  245. package/src/components/MlImageMarkerLayer/MlImageMarkerLayer.tsx +41 -115
  246. package/src/components/MlLayer/MlLayer.meta_.json +1 -2
  247. package/src/components/MlLayerMagnify/MlLayerMagnify.meta.json +1 -2
  248. package/src/components/MlLayerMagnify/MlLayerMagnify.stories.tsx +44 -0
  249. package/src/components/MlLayerMagnify/{MlLayerMagnify.test.js → MlLayerMagnify.test.tsx} +15 -18
  250. package/src/components/MlLayerMagnify/MlLayerMagnify.tsx +55 -61
  251. package/src/components/MlLayerSwipe/MlLayerSwipe.meta.json +1 -2
  252. package/src/components/MlLayerSwipe/{MlLayerSwipe.stories.js → MlLayerSwipe.stories.tsx} +9 -11
  253. package/src/components/MlLayerSwipe/MlLayerSwipe.tsx +47 -48
  254. package/src/components/MlLayerSwitcher/MlLayerSwitcher.meta_.json +1 -2
  255. package/src/components/MlLayerSwitcher/components/LayerBox.js +22 -19
  256. package/src/components/MlMarker/MlMarker.meta_.json +1 -2
  257. package/src/components/MlMeasureTool/MlMeasureTool.meta.json +1 -2
  258. package/src/components/MlNavigationCompass/MlNavigationCompass.meta.json +1 -2
  259. package/src/components/MlNavigationTools/MlNavigationTools.meta.json +1 -2
  260. package/src/components/MlScaleReference/MlScaleReference.meta.json +1 -2
  261. package/src/components/MlShareMapState/MlShareMapState.meta_.json +1 -2
  262. package/src/components/MlSketchTool/LayerList/ColorPicker.tsx +43 -0
  263. package/src/components/MlSketchTool/LayerList/LayerList.tsx +12 -0
  264. package/src/components/MlSketchTool/LayerList/LayerListItem.tsx +109 -0
  265. package/src/components/MlSketchTool/LayerList/LayerPropertyForm.tsx +126 -0
  266. package/src/components/MlSketchTool/MlSketchTool.doc.de.md +3 -0
  267. package/src/components/MlSketchTool/MlSketchTool.meta.json +14 -0
  268. package/src/components/MlSketchTool/MlSketchTool.stories.js +26 -0
  269. package/src/components/MlSketchTool/MlSketchTool.tsx +271 -0
  270. package/src/components/MlSpatialElevationProfile/MlSpatialElevationProfile.meta.json +1 -2
  271. package/src/components/MlSpatialElevationProfile/MlSpatialElevationProfile.stories.tsx +121 -0
  272. package/src/components/MlSpatialElevationProfile/MlSpatialElevationProfile.test.js +30 -1
  273. package/src/components/MlSpatialElevationProfile/MlSpatialElevationProfile.tsx +143 -0
  274. package/src/components/MlSpatialElevationProfile/util/getElevationData.tsx +103 -0
  275. package/src/components/MlThreeJsLayer/MlThreeJsLayer.meta.json +1 -2
  276. package/src/components/MlTransitionGeoJsonLayer/MlTransitionGeoJsonLayer.meta.json +3 -4
  277. package/src/components/MlTransitionGeoJsonLayer/MlTransitionGeoJsonLayer.stories.js +2 -3
  278. package/src/components/MlTransitionGeoJsonLayer/MlTransitionGeoJsonLayer.tsx +17 -79
  279. package/src/components/MlUseMapDebugger/MlUseMapDebugger.meta_.json +1 -2
  280. package/src/components/MlVectorTileLayer/MlVectorTileLayer.meta.json +1 -2
  281. package/src/components/MlVectorTileLayer/MlVectorTileLayer.tsx +3 -2
  282. package/src/components/MlWmsFeatureInfoPopup/MlWmsFeatureInfoPopup.meta_.json +1 -2
  283. package/src/components/MlWmsLayer/MlWmsLayer.tsx +59 -41
  284. package/src/components/MlWmsLoader/MlWmsLoader.meta.json +1 -2
  285. package/src/components/MlWmsLoader/MlWmsLoader.stories.tsx +89 -0
  286. package/src/components/MlWmsLoader/MlWmsLoader.tsx +141 -122
  287. package/src/components/MlWmsLoader/utils/MlWmsLoaderInstructions.tsx +50 -0
  288. package/src/components/MlWmsLoader/utils/WMSLinks.tsx +128 -0
  289. package/src/decorators/MapContextDecorator.js +1 -1
  290. package/src/decorators/MapContextDecoratorHooks.js +1 -1
  291. package/src/decorators/ThemeWrapper.tsx +9 -0
  292. package/src/hooks/useCameraFollowPath/useCameraFollowPath.meta.json +1 -2
  293. package/src/{components/MlGPXViewer → hooks/useGpx/lib}/gpxConverter.js +1 -0
  294. package/src/hooks/useGpx/useGpx.doc.de.md +3 -0
  295. package/src/hooks/useGpx/useGpx.meta_.json +15 -0
  296. package/src/{components/MlCenterPosition/MlCenterPosition.stories.js → hooks/useGpx/useGpx.stories.js} +4 -5
  297. package/src/hooks/useGpx/useGpx.tsx +70 -0
  298. package/src/hooks/useLayer.ts +32 -10
  299. package/src/hooks/useLayerHoverPopup/useLayerHoverPopup.doc.de.md +3 -0
  300. package/src/hooks/useLayerHoverPopup/useLayerHoverPopup.meta_.json +15 -0
  301. package/src/hooks/useLayerHoverPopup/useLayerHoverPopup.stories.js +20 -0
  302. package/src/hooks/useLayerHoverPopup/useLayerHoverPopup.tsx +82 -0
  303. package/src/hooks/useMap.test.tsx +48 -0
  304. package/src/hooks/useMap.ts +8 -8
  305. package/src/hooks/useSource.ts +4 -4
  306. package/src/hooks/{useWms.js → useWms.ts} +24 -11
  307. package/src/index.ts +5 -5
  308. package/src/setupTests.js +18 -15
  309. package/src/ui_components/Dropzone.tsx +104 -0
  310. package/src/ui_components/{ImageLoader.js → ImageLoader.tsx} +30 -25
  311. package/src/ui_components/{LoadingOverlayContext.js → LoadingOverlayContext.tsx} +12 -15
  312. package/src/ui_components/Sidebar.tsx +82 -0
  313. package/src/ui_components/Tooltip.tsx +17 -0
  314. package/src/ui_components/TopToolbar.tsx +26 -0
  315. package/src/ui_components/UploadButton.tsx +57 -0
  316. package/src/util/BubbleForInstructions.js +46 -0
  317. package/src/util/Instructions.tsx +60 -0
  318. package/tsconfig.json +39 -58
  319. package/config/getHttpsConfig.js +0 -66
  320. package/config/modules.js +0 -134
  321. package/config/pnpTs.js +0 -35
  322. package/config/webpack.config.js +0 -757
  323. package/config/webpackDevServer.config.js +0 -130
  324. package/coverage/lcov-report/src/components/MlGPXViewer/gpxConverter.js.html +0 -1645
  325. package/scripts/start.js +0 -166
  326. package/src/components/MlGPXViewer/MlGPXViewer.stories.js +0 -31
  327. package/src/components/MlGPXViewer/MlGPXViewer.test.js +0 -28
  328. package/src/components/MlGPXViewer/MlGPXViewer.tsx +0 -377
  329. package/src/components/MlGeoJsonLayer/MlGeoJsonLayer.stories.js +0 -66
  330. package/src/components/MlImageMarkerLayer/MlImageMarkerLayer.stories.js +0 -45
  331. package/src/components/MlLayerMagnify/MlLayerMagnify.stories.js +0 -41
  332. package/src/components/MlSpatialElevationProfile/MlSpatialElevationProfile.js +0 -224
  333. package/src/components/MlSpatialElevationProfile/MlSpatialElevationProfile.stories.js +0 -57
  334. package/src/components/MlWmsLoader/MlWmsLoader.stories.js +0 -47
  335. package/src/decorators/ThemeWrapper.jsx +0 -9
  336. package/src/ui_components/Legend.js +0 -44
  337. package/src/ui_components/LoadingOverlay.js +0 -41
  338. package/src/ui_components/Sidebar.js +0 -100
  339. package/src/ui_components/Tooltip.js +0 -21
  340. package/src/ui_components/TopToolbar.js +0 -29
@@ -0,0 +1,68 @@
1
+ import React from 'react';
2
+ import Instructions from '../../../util/Instructions';
3
+
4
+ const bubbleBottomRightStyle = {
5
+ bubbleRight: '-120px',
6
+ bubbleBottom: '-120px',
7
+ textMarginTop: '70px',
8
+ textMarginLeft: '120px',
9
+ iconTransform: 'rotate(180deg)',
10
+ iconMarginLeft: '200px',
11
+ zIndex: 200
12
+ };
13
+
14
+ const steps = [
15
+ {
16
+ duration: 3000,
17
+ props: {
18
+ ...bubbleBottomRightStyle,
19
+ iconMarginTop: '43px',
20
+ },
21
+ content: (
22
+ <>
23
+ You can load your <br />
24
+ own GPX file <br /> here
25
+ </>
26
+ ),
27
+ },
28
+ {
29
+ duration: 3000,
30
+ props: {
31
+ ...bubbleBottomRightStyle,
32
+ iconMarginTop: '68px',
33
+ },
34
+ content: (
35
+ <>
36
+ You can see more <br /> information about <br />
37
+ the track <br />
38
+ here
39
+ </>
40
+ ),
41
+ },
42
+ {
43
+ duration: 3000,
44
+ props: {
45
+ bubbleLeft: '-40px',
46
+ bubbleTop: '-150px',
47
+ textMarginTop: '230px',
48
+ textMarginLeft: '75px',
49
+ iconTransform: 'rotate(90deg)',
50
+ iconMarginTop: '-135px',
51
+ iconMarginLeft: '280px',
52
+ zIndex: 400
53
+ },
54
+ content: (
55
+ <>
56
+ In demo mode we <br /> provide you some <br /> GPX tracks <br /> to load.
57
+ </>
58
+ ),
59
+ },
60
+ ];
61
+ export default function MlGpxViewerInstructions(props: { open: boolean}) {
62
+
63
+ return (
64
+ <>
65
+ <Instructions steps={steps} open={props.open} />
66
+ </>
67
+ );
68
+ }
@@ -10,6 +10,5 @@
10
10
  },
11
11
  "tags": [],
12
12
  "category": "",
13
- "type": "component",
14
- "price": 0
13
+ "type": "component"
15
14
  }
@@ -0,0 +1,41 @@
1
+ import React from 'react';
2
+
3
+ import MlImageMarkerLayer from './MlImageMarkerLayer';
4
+
5
+ import mapContextDecorator from '../../decorators/MapContextDecorator';
6
+
7
+ const storyoptions = {
8
+ title: 'MapComponents/MlImageMarkerLayer',
9
+ component: MlImageMarkerLayer,
10
+ argTypes: {},
11
+ decorators: mapContextDecorator,
12
+ };
13
+ export default storyoptions;
14
+
15
+ const Template = () => (
16
+ <MlImageMarkerLayer
17
+ options={{
18
+ source: {
19
+ type: 'geojson',
20
+ data: {
21
+ type: 'Feature',
22
+ geometry: {
23
+ type: 'Point',
24
+ coordinates: [7.0847929969609424, 50.73855193187643],
25
+ },
26
+ properties: { id: 'test' },
27
+ },
28
+ },
29
+ layout: {
30
+ 'icon-allow-overlap': true,
31
+ 'icon-size': 0.14,
32
+ 'icon-offset': [0, -180],
33
+ },
34
+ }}
35
+ imgSrc={'/assets/wg-marker.png'}
36
+ />
37
+ );
38
+
39
+ export const ExampleConfig = Template.bind({});
40
+ ExampleConfig.parameters = {};
41
+ ExampleConfig.args = {};
@@ -1,19 +1,38 @@
1
- import { layerRemovalTest, sourceRemovalTest } from "../../util";
2
- import { uuid_regex } from "../../setupTests";
1
+ import { layerRemovalTest, sourceRemovalTest } from '../../util';
2
+ import { uuid_regex } from '../../setupTests';
3
3
 
4
- import MlImageMarkerLayer from "./MlImageMarkerLayer";
4
+ import MlImageMarkerLayer from './MlImageMarkerLayer';
5
5
 
6
- const testComponent = <MlImageMarkerLayer options={{ source: {} }} />;
6
+ const testComponent = (
7
+ // eslint-disable-next-line react/react-in-jsx-scope
8
+ <MlImageMarkerLayer
9
+ options={{
10
+ source: {
11
+ type: 'geojson',
12
+ data: {
13
+ type: 'Feature',
14
+ properties: {
15
+ id: 'test',
16
+ },
17
+ geometry: {
18
+ type: 'Point',
19
+ coordinates: [7.0847929969609424, 50.73855193187643],
20
+ },
21
+ },
22
+ },
23
+ }}
24
+ />
25
+ );
7
26
 
8
27
  layerRemovalTest(
9
- "<MlImageMarkerLayer />",
28
+ '<MlImageMarkerLayer />',
10
29
  testComponent,
11
30
  new RegExp('^.*"MlImageMarkerLayer-' + uuid_regex + '".*$'),
12
- "MlImageMarkerLayer-{uuid}"
31
+ 'MlImageMarkerLayer-{uuid}'
13
32
  );
14
33
  sourceRemovalTest(
15
- "<MlImageMarkerLayer />",
34
+ '<MlImageMarkerLayer />',
16
35
  testComponent,
17
36
  new RegExp('^.*"MlImageMarkerLayer-' + uuid_regex + '".*$'),
18
- "MlImageMarkerLayer-{uuid}"
37
+ 'MlImageMarkerLayer-{uuid}'
19
38
  );
@@ -1,9 +1,13 @@
1
- import React, { useRef, useCallback, useEffect } from "react";
1
+ import React, { useRef, useEffect, useState } from 'react';
2
2
 
3
- import { GeoJSONSource } from "maplibre-gl";
4
- import useMap, { useMapType } from "../../hooks/useMap";
3
+ import { v4 as uuidv4 } from 'uuid';
5
4
 
6
- interface MlImageMarkerLayerProps {
5
+ import useLayer from '../../hooks/useLayer';
6
+ import useMap from '../../hooks/useMap';
7
+ import { SymbolLayerSpecification } from 'maplibre-gl';
8
+ import { Feature, FeatureCollection } from '@turf/turf';
9
+
10
+ export interface MlImageMarkerLayerProps {
7
11
  /**
8
12
  * Id of the target MapLibre instance in mapContext
9
13
  */
@@ -28,7 +32,11 @@ interface MlImageMarkerLayerProps {
28
32
  /**
29
33
  * Javascript object that is passed the addLayer command as first parameter.
30
34
  */
31
- options?: any;
35
+ options?: {
36
+ source?: { type?: string | undefined; data: Feature | FeatureCollection | undefined };
37
+ layout?: SymbolLayerSpecification['layout'];
38
+ paint?: SymbolLayerSpecification['paint'];
39
+ };
32
40
  }
33
41
 
34
42
  const MlImageMarkerLayer = (props: MlImageMarkerLayerProps) => {
@@ -37,38 +45,27 @@ const MlImageMarkerLayer = (props: MlImageMarkerLayerProps) => {
37
45
  waitForLayer: props.insertBeforeLayer,
38
46
  });
39
47
 
40
- const initializedRef = useRef(false);
41
- const recreationInProgress = useRef(false);
42
- const imageIdRef = useRef(props.imageId || "img_" + new Date().getTime());
43
- const layerId = useRef(props.layerId || "MlImageMarkerLayer-" + mapHook.componentId);
44
-
45
- // effect to sync Layer paint & layout properties
46
- useEffect(() => {
47
- if (
48
- !mapHook.map ||
49
- (mapHook.map && !mapHook.map.map.getLayer(layerId.current)) ||
50
- !props.options
51
- )
52
- return;
53
-
54
- var key;
55
-
56
- if (props.options.layout) {
57
- for (key in props.options.layout) {
58
- mapHook.map.map.setLayoutProperty(layerId.current, key, props.options.layout[key]);
59
- }
60
- }
61
- if (props.options.paint) {
62
- for (key in props.options.paint) {
63
- mapHook.map.map.setPaintProperty(layerId.current, key, props.options.paint[key]);
64
- }
65
- }
66
- }, [props.options, layerId.current, props.mapId]);
48
+ const [imageId, setImageId] = useState<string>();
49
+ const imageIdRef = useRef(props.imageId || 'img_' + uuidv4());
50
+ const layerId = useRef(props.layerId || 'MlImageMarkerLayer-' + mapHook.componentId);
51
+
52
+ useLayer({
53
+ geojson: props.options?.source?.data,
54
+ layerId: layerId.current,
55
+ options: {
56
+ type: 'symbol',
57
+ layout: {
58
+ ...props.options?.layout,
59
+ 'icon-image': imageId || imageIdRef.current,
60
+ },
61
+ paint: {
62
+ ...props.options?.paint,
63
+ },
64
+ },
65
+ });
67
66
 
68
- const createImage = (mapHook: useMapType, props: MlImageMarkerLayerProps, callback: Function) => {
67
+ const createImage = (mapHook: ReturnType<typeof useMap>, props: MlImageMarkerLayerProps) => {
69
68
  if (!mapHook.map) {
70
- initializedRef.current = false;
71
-
72
69
  return;
73
70
  }
74
71
 
@@ -78,96 +75,25 @@ const MlImageMarkerLayer = (props: MlImageMarkerLayerProps) => {
78
75
 
79
76
  if (!mapHook.map || mapHook.map.map.hasImage(imageIdRef.current)) return;
80
77
 
81
- mapHook.map.addImage(imageIdRef.current, image, mapHook.componentId);
78
+ mapHook.map.addImage(
79
+ imageIdRef.current,
80
+ image as unknown as ImageData,
81
+ mapHook.componentId
82
+ );
82
83
 
83
- if (typeof callback === "function") {
84
- callback();
85
- }
84
+ setImageId(imageIdRef.current);
86
85
  });
87
- } else {
88
- if (typeof callback === "function") {
89
- callback();
90
- }
91
- }
92
- };
93
-
94
- const createLayer = (
95
- mapHook: useMapType,
96
- props: MlImageMarkerLayerProps,
97
- createMapLibreElements: Function
98
- ) => {
99
- if (!props.options || !mapHook.map || mapHook.map?.map.getLayer(layerId.current)) return;
100
-
101
- let tmpOptions = {
102
- id: layerId.current,
103
- layout: {},
104
- ...props.options,
105
- };
106
- tmpOptions.layout["icon-image"] = imageIdRef.current;
107
- mapHook.map.addLayer(tmpOptions, props.insertBeforeLayer, mapHook.componentId);
108
-
109
- // recreate layer if map style.json has changed
110
- mapHook.map.on(
111
- "styledata",
112
- () => {
113
- if (
114
- initializedRef.current &&
115
- !mapHook.map?.map.getLayer(layerId.current) &&
116
- !recreationInProgress.current
117
- ) {
118
- initializedRef.current = false;
119
- recreationInProgress.current = true;
120
- console.log("Recreate Layer " + layerId.current);
121
- createMapLibreElements();
122
- }
123
- },
124
- mapHook.componentId
125
- );
126
-
127
- if (recreationInProgress.current) {
128
- recreationInProgress.current = false;
129
86
  }
130
87
  };
131
88
 
132
- const createMapLibreElements = useCallback(() => {
133
- if (!mapHook.map || initializedRef.current || mapHook.map?.map.getLayer(layerId.current))
134
- return;
135
-
136
- initializedRef.current = true;
137
-
138
- if (recreationInProgress.current) {
139
- mapHook.cleanup();
140
- }
89
+ useEffect(() => {
90
+ if (!mapHook.map) return;
141
91
 
142
92
  if (props.imgSrc) {
143
- createImage(mapHook, props, () => {
144
- createLayer(mapHook, props, createMapLibreElements);
145
- });
146
- } else {
147
- createLayer(mapHook, props, createMapLibreElements);
93
+ createImage(mapHook, props);
148
94
  }
149
95
  }, [props, mapHook]);
150
96
 
151
- useEffect(() => {
152
- if (initializedRef.current) return;
153
-
154
- createMapLibreElements();
155
- }, [createMapLibreElements]);
156
-
157
- useEffect(() => {
158
- if (
159
- !mapHook.map ||
160
- (mapHook.map && !mapHook.map.map.getLayer(layerId.current)) ||
161
- !props.options
162
- ) {
163
- return;
164
- }
165
-
166
- (mapHook.map.map.getSource(layerId.current) as GeoJSONSource).setData(
167
- props.options.source.data
168
- );
169
- }, [props.options.source.data, props]);
170
-
171
97
  return <></>;
172
98
  };
173
99
 
@@ -10,6 +10,5 @@
10
10
  },
11
11
  "tags": [],
12
12
  "category": "",
13
- "type": "component",
14
- "price": 0
13
+ "type": "component"
15
14
  }
@@ -10,6 +10,5 @@
10
10
  },
11
11
  "tags": ["Map add-on"],
12
12
  "category": "add-ons",
13
- "type": "component",
14
- "price": 5000
13
+ "type": "component"
15
14
  }
@@ -0,0 +1,44 @@
1
+ import React from 'react';
2
+
3
+ import MlLayerMagnify from './MlLayerMagnify';
4
+ import MlWmsLayer from '../MlWmsLayer/MlWmsLayer';
5
+
6
+ import multiMapContextDecorator from '../../decorators/MultiMapContextDecorator';
7
+
8
+ const storyoptions = {
9
+ title: 'MapComponents/MlLayerMagnify',
10
+ component: MlLayerMagnify,
11
+ argTypes: {},
12
+ decorators: multiMapContextDecorator,
13
+ };
14
+ export default storyoptions;
15
+
16
+ interface TemplateProps {
17
+ wmsLayerMapId: string;
18
+ magnifierRadius: number;
19
+ }
20
+
21
+ const Template = (args: TemplateProps) => (
22
+ <>
23
+ <MlWmsLayer
24
+ url="https://www.wms.nrw.de/geobasis/wms_nw_uraufnahme"
25
+ urlParameters={{
26
+ layers: 'nw_uraufnahme_rw',
27
+ }}
28
+ sourceOptions={{
29
+ minzoom: 13,
30
+ maxzoom: 20,
31
+ }}
32
+ mapId={args.wmsLayerMapId}
33
+
34
+ />
35
+ <MlLayerMagnify map1Id="map_1" map2Id="map_2" magnifierStyle={{border:'2px solid grey'}} magnifierRadius={args.magnifierRadius} />
36
+ </>
37
+ );
38
+
39
+ export const ExampleConfig = Template.bind({});
40
+ ExampleConfig.parameters = {};
41
+ ExampleConfig.args = {
42
+ wmsLayerMapId: 'map_2',
43
+ magnifierRadius: 200,
44
+ };
@@ -1,17 +1,18 @@
1
- import MlLayerMagnify from "./MlLayerMagnify";
1
+ import MlLayerMagnify from './MlLayerMagnify';
2
2
 
3
- import React, { useContext, useState } from "react";
4
- import { mount } from "enzyme";
5
- import MapContext, { MapComponentsProvider } from "../../contexts/MapContext";
6
- import MapLibreMap from "./../MapLibreMap/MapLibreMap";
7
- import syncMove from "@mapbox/mapbox-gl-sync-move";
3
+ import React, { useContext, useState } from 'react';
4
+ import { mount } from 'enzyme';
5
+ import MapContext, { MapComponentsProvider } from '../../contexts/MapContext';
6
+ import MapLibreMap from './../MapLibreMap/MapLibreMap';
7
+ // we need to import this explicitly, because otherwise it gets mixed up with cypress expect
8
+ import { expect } from '@jest/globals';
8
9
  // Mapbox sync-move mockup
9
- var mockSyncMoveMethods = {
10
+ const mockSyncMoveMethods = {
10
11
  cleanup: jest.fn(),
11
12
  };
12
13
 
13
- jest.mock("@mapbox/mapbox-gl-sync-move", () => {
14
- const originalModule = jest.requireActual("@mapbox/mapbox-gl-sync-move");
14
+ jest.mock('@mapbox/mapbox-gl-sync-move', () => {
15
+ const originalModule = jest.requireActual('@mapbox/mapbox-gl-sync-move');
15
16
  return {
16
17
  __esModule: true,
17
18
  ...originalModule,
@@ -19,11 +20,7 @@ jest.mock("@mapbox/mapbox-gl-sync-move", () => {
19
20
  };
20
21
  });
21
22
 
22
- const syncMoveObj = {
23
- syncMove: syncMove,
24
- };
25
-
26
- const TestComponent = (props) => {
23
+ const TestComponent = () => {
27
24
  const [layerVisible, setLayerVisible] = useState(true);
28
25
  const [refreshTrigger, setRefreshTrigger] = useState(0);
29
26
  const mapContext = useContext(MapContext);
@@ -65,7 +62,7 @@ const createWrapper = () =>
65
62
  </MapComponentsProvider>
66
63
  );
67
64
 
68
- describe("<MlLayerMagnify/>", () => {
65
+ describe('<MlLayerMagnify/>', () => {
69
66
  //it("should add a MlLayerMagnify Component to that calls syncMaps with both available MapLibre instances once", async () => {
70
67
  // const spy = jest.spyOn(syncMoveObj, "syncMove");
71
68
  // const wrapper = createWrapper(TestComponent);
@@ -73,12 +70,12 @@ describe("<MlLayerMagnify/>", () => {
73
70
  // expect(spy).toHaveBeenCalledTimes(1);
74
71
  //});
75
72
 
76
- it("should call the syncMaps cleanup function once when it is removed from reactDOM", async () => {
77
- const wrapper = createWrapper(TestComponent);
73
+ it('should call the syncMaps cleanup function once when it is removed from reactDOM', async () => {
74
+ const wrapper = createWrapper();
78
75
 
79
76
  //expect(syncMove).toHaveBeenCalledTimes(1);
80
77
 
81
- wrapper.find(".toggle_layer_visible").simulate("click");
78
+ wrapper.find('.toggle_layer_visible').simulate('click');
82
79
 
83
80
  //TODO: Fix cleanup test
84
81
  expect(mockSyncMoveMethods.cleanup).toHaveBeenCalledTimes(1);