react-spatial 1.5.2 → 1.5.3

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 (295) hide show
  1. package/.github/workflows/conventional-pr-title.yml +21 -0
  2. package/.github/workflows/main.yml +28 -0
  3. package/.husky/commit-msg +4 -0
  4. package/.husky/post-checkout +4 -0
  5. package/.husky/post-merge +4 -0
  6. package/.husky/post-rebase +4 -0
  7. package/.husky/pre-commit +4 -0
  8. package/.nvmrc +1 -0
  9. package/.whitesource +8 -0
  10. package/CHANGELOG.md +65 -0
  11. package/DEVELOP.md +113 -0
  12. package/__mocks__/mapbox-gl.js +11 -0
  13. package/__mocks__/resize-observer-polyfill.js +9 -0
  14. package/babel.config.js +3 -0
  15. package/commitlint.config.js +1 -0
  16. package/data/topic1.js +119 -0
  17. package/data/topic2.js +28 -0
  18. package/doc/README.md +21 -0
  19. package/doc/doc-config.json +4 -0
  20. package/package.json +4 -3
  21. package/pull_request_template.md +16 -0
  22. package/renovate.json +4 -0
  23. package/scripts/read-pkg-json.js +17 -0
  24. package/src/components/BaseLayerSwitcher/BaseLayerSwitcher.js +322 -0
  25. package/src/components/BaseLayerSwitcher/BaseLayerSwitcher.test.js +69 -0
  26. package/src/components/BaseLayerSwitcher/README.md +61 -0
  27. package/src/components/BaseLayerSwitcher/__snapshots__/BaseLayerSwitcher.test.js.snap +88 -0
  28. package/src/components/BaseLayerSwitcher/index.js +1 -0
  29. package/src/components/BasicMap/BasicMap.js +413 -0
  30. package/src/components/BasicMap/BasicMap.test.js +281 -0
  31. package/src/components/BasicMap/README.md +18 -0
  32. package/src/components/BasicMap/index.js +1 -0
  33. package/{components → src/components}/CanvasSaveButton/CanvasSaveButton.js +320 -93
  34. package/src/components/CanvasSaveButton/CanvasSaveButton.test.js +148 -0
  35. package/src/components/CanvasSaveButton/README.md +76 -0
  36. package/src/components/CanvasSaveButton/__snapshots__/CanvasSaveButton.test.js.snap +76 -0
  37. package/src/components/CanvasSaveButton/index.js +1 -0
  38. package/src/components/Copyright/Copyright.js +89 -0
  39. package/src/components/Copyright/Copyright.test.js +134 -0
  40. package/src/components/Copyright/README.md +36 -0
  41. package/src/components/Copyright/index.js +1 -0
  42. package/src/components/FeatureExportButton/FeatureExportButton.js +118 -0
  43. package/src/components/FeatureExportButton/FeatureExportButton.test.js +417 -0
  44. package/src/components/FeatureExportButton/README.md +76 -0
  45. package/src/components/FeatureExportButton/__snapshots__/FeatureExportButton.test.js.snap +67 -0
  46. package/src/components/FeatureExportButton/index.js +1 -0
  47. package/src/components/FitExtent/FitExtent.js +62 -0
  48. package/src/components/FitExtent/FitExtent.test.js +48 -0
  49. package/src/components/FitExtent/README.md +34 -0
  50. package/src/components/FitExtent/__snapshots__/FitExtent.test.js.snap +13 -0
  51. package/src/components/FitExtent/index.js +1 -0
  52. package/{components → src/components}/Geolocation/Geolocation.js +144 -61
  53. package/src/components/Geolocation/Geolocation.test.js +267 -0
  54. package/src/components/Geolocation/README.md +25 -0
  55. package/src/components/Geolocation/__snapshots__/Geolocation.test.js.snap +92 -0
  56. package/src/components/Geolocation/index.js +1 -0
  57. package/src/components/LayerTree/LayerTree.js +487 -0
  58. package/src/components/LayerTree/LayerTree.test.js +337 -0
  59. package/src/components/LayerTree/README.md +92 -0
  60. package/src/components/LayerTree/__snapshots__/LayerTree.test.js.snap +1746 -0
  61. package/src/components/LayerTree/index.js +1 -0
  62. package/src/components/MousePosition/MousePosition.js +175 -0
  63. package/src/components/MousePosition/MousePosition.test.js +132 -0
  64. package/src/components/MousePosition/README.md +50 -0
  65. package/src/components/MousePosition/__snapshots__/MousePosition.test.js.snap +76 -0
  66. package/src/components/MousePosition/index.js +1 -0
  67. package/src/components/NorthArrow/NorthArrow.js +75 -0
  68. package/src/components/NorthArrow/NorthArrow.test.js +104 -0
  69. package/src/components/NorthArrow/README.md +59 -0
  70. package/src/components/NorthArrow/__snapshots__/NorthArrow.test.js.snap +117 -0
  71. package/src/components/NorthArrow/index.js +1 -0
  72. package/src/components/Overlay/Overlay.js +176 -0
  73. package/src/components/Overlay/Overlay.test.js +149 -0
  74. package/src/components/Overlay/README.md +59 -0
  75. package/src/components/Overlay/__snapshots__/Overlay.test.js.snap +9 -0
  76. package/src/components/Overlay/index.js +1 -0
  77. package/src/components/Permalink/Permalink.js +326 -0
  78. package/src/components/Permalink/Permalink.test.js +285 -0
  79. package/src/components/Permalink/README.md +105 -0
  80. package/src/components/Permalink/index.js +1 -0
  81. package/{components → src/components}/Popup/Popup.js +165 -55
  82. package/src/components/Popup/Popup.test.js +307 -0
  83. package/src/components/Popup/README.md +93 -0
  84. package/src/components/Popup/__snapshots__/Popup.test.js.snap +180 -0
  85. package/src/components/Popup/index.js +1 -0
  86. package/src/components/README.md +41 -0
  87. package/{components → src/components}/ResizeHandler/ResizeHandler.js +50 -15
  88. package/src/components/ResizeHandler/ResizeHandler.test.js +344 -0
  89. package/src/components/ResizeHandler/index.js +1 -0
  90. package/src/components/RouteSchedule/README.md +118 -0
  91. package/src/components/RouteSchedule/RouteSchedule.js +370 -0
  92. package/src/components/RouteSchedule/RouteSchedule.test.js +113 -0
  93. package/src/components/RouteSchedule/__snapshots__/RouteSchedule.test.js.snap +248 -0
  94. package/src/components/RouteSchedule/index.js +1 -0
  95. package/src/components/ScaleLine/README.md +29 -0
  96. package/src/components/ScaleLine/ScaleLine.js +50 -0
  97. package/src/components/ScaleLine/ScaleLine.test.js +30 -0
  98. package/src/components/ScaleLine/__snapshots__/ScaleLine.test.js.snap +7 -0
  99. package/src/components/ScaleLine/index.js +1 -0
  100. package/src/components/StopsFinder/README.md +50 -0
  101. package/src/components/StopsFinder/StopsFinder.js +284 -0
  102. package/src/components/StopsFinder/StopsFinder.test.js +17 -0
  103. package/src/components/StopsFinder/StopsFinderOption.js +61 -0
  104. package/src/components/StopsFinder/__snapshots__/StopsFinder.test.js.snap +133 -0
  105. package/src/components/StopsFinder/index.js +1 -0
  106. package/src/components/Zoom/README.md +25 -0
  107. package/src/components/Zoom/Zoom.js +180 -0
  108. package/src/components/Zoom/Zoom.test.js +141 -0
  109. package/src/components/Zoom/__snapshots__/Zoom.test.js.snap +201 -0
  110. package/src/components/Zoom/index.js +1 -0
  111. package/{propTypes.js → src/propTypes.js} +16 -12
  112. package/{setupTests.js → src/setupTests.js} +1 -1
  113. package/src/styleguidist/ComponentsList.js +52 -0
  114. package/src/styleguidist/StyleGuide.js +277 -0
  115. package/src/styleguidist/styleguidist.css +38 -0
  116. package/src/utils/GlobalsForOle.js +99 -0
  117. package/src/utils/KML.js +594 -0
  118. package/src/utils/KML.test.js +337 -0
  119. package/src/utils/KMLFormat.js +100 -0
  120. package/src/utils/KMLFormat.test.js +50 -0
  121. package/{utils → src/utils}/Styles.js +20 -14
  122. package/src/utils/__snapshots__/KML.test.js.snap.KML-readFeatures()-and-writeFeatures()-should-read-and-write-lineDash-and-fillPattern-style-for-polygon.canvas-image.png +0 -0
  123. package/src/utils/__snapshots__/getPolygonPattern.test.js.snap.getPolygonPattern()-render-pattern-2-(cross)-color-and-(light-blue)-opacity.canvas-image.png +0 -0
  124. package/src/utils/__snapshots__/getPolygonPattern.test.js.snap.getPolygonPattern()-render-pattern-3-(diagonal-line-from-bottom-left-tot-top-right)-with-color-(light-blue)-and-opacity.canvas-image.png +0 -0
  125. package/src/utils/__snapshots__/getPolygonPattern.test.js.snap.getPolygonPattern()-render-pattern-4-(diagonal-line-from-top-left-to-bottom-right)-with-color-(light-blue)-and-opacity.canvas-image.png +0 -0
  126. package/{utils → src/utils}/getPolygonPattern.js +34 -6
  127. package/src/utils/getPolygonPattern.test.js +61 -0
  128. package/src/utils/timeUtils.js +52 -0
  129. package/src/utils/timeUtils.test.js +30 -0
  130. package/styleguide.config.js +251 -0
  131. package/components/BaseLayerSwitcher/BaseLayerSwitcher.js +0 -231
  132. package/components/BaseLayerSwitcher/BaseLayerSwitcher.js.map +0 -7
  133. package/components/BaseLayerSwitcher/index.js +0 -1
  134. package/components/BaseLayerSwitcher/index.js.map +0 -7
  135. package/components/BasicMap/BasicMap.js +0 -278
  136. package/components/BasicMap/BasicMap.js.map +0 -7
  137. package/components/BasicMap/index.js +0 -1
  138. package/components/BasicMap/index.js.map +0 -7
  139. package/components/CanvasSaveButton/CanvasSaveButton.js.map +0 -7
  140. package/components/CanvasSaveButton/index.js +0 -1
  141. package/components/CanvasSaveButton/index.js.map +0 -7
  142. package/components/Copyright/Copyright.js +0 -55
  143. package/components/Copyright/Copyright.js.map +0 -7
  144. package/components/Copyright/index.js +0 -1
  145. package/components/Copyright/index.js.map +0 -7
  146. package/components/FeatureExportButton/FeatureExportButton.js +0 -62
  147. package/components/FeatureExportButton/FeatureExportButton.js.map +0 -7
  148. package/components/FeatureExportButton/index.js +0 -1
  149. package/components/FeatureExportButton/index.js.map +0 -7
  150. package/components/FitExtent/FitExtent.js +0 -32
  151. package/components/FitExtent/FitExtent.js.map +0 -7
  152. package/components/FitExtent/index.js +0 -1
  153. package/components/FitExtent/index.js.map +0 -7
  154. package/components/Geolocation/Geolocation.js.map +0 -7
  155. package/components/Geolocation/index.js +0 -1
  156. package/components/Geolocation/index.js.map +0 -7
  157. package/components/LayerTree/LayerTree.js +0 -278
  158. package/components/LayerTree/LayerTree.js.map +0 -7
  159. package/components/LayerTree/index.js +0 -1
  160. package/components/LayerTree/index.js.map +0 -7
  161. package/components/MousePosition/MousePosition.js +0 -110
  162. package/components/MousePosition/MousePosition.js.map +0 -7
  163. package/components/MousePosition/index.js +0 -1
  164. package/components/MousePosition/index.js.map +0 -7
  165. package/components/NorthArrow/NorthArrow.js +0 -43
  166. package/components/NorthArrow/NorthArrow.js.map +0 -7
  167. package/components/NorthArrow/index.js +0 -1
  168. package/components/NorthArrow/index.js.map +0 -7
  169. package/components/Overlay/Overlay.js +0 -122
  170. package/components/Overlay/Overlay.js.map +0 -7
  171. package/components/Overlay/index.js +0 -1
  172. package/components/Overlay/index.js.map +0 -7
  173. package/components/Permalink/Permalink.js +0 -206
  174. package/components/Permalink/Permalink.js.map +0 -7
  175. package/components/Permalink/index.js +0 -1
  176. package/components/Permalink/index.js.map +0 -7
  177. package/components/Popup/Popup.js.map +0 -7
  178. package/components/Popup/index.js +0 -1
  179. package/components/Popup/index.js.map +0 -7
  180. package/components/ResizeHandler/ResizeHandler.js.map +0 -7
  181. package/components/ResizeHandler/index.js +0 -1
  182. package/components/ResizeHandler/index.js.map +0 -7
  183. package/components/RouteSchedule/RouteSchedule.js +0 -220
  184. package/components/RouteSchedule/RouteSchedule.js.map +0 -7
  185. package/components/RouteSchedule/index.js +0 -1
  186. package/components/RouteSchedule/index.js.map +0 -7
  187. package/components/ScaleLine/ScaleLine.js +0 -32
  188. package/components/ScaleLine/ScaleLine.js.map +0 -7
  189. package/components/ScaleLine/index.js +0 -1
  190. package/components/ScaleLine/index.js.map +0 -7
  191. package/components/StopsFinder/StopsFinder.js +0 -210
  192. package/components/StopsFinder/StopsFinder.js.map +0 -7
  193. package/components/StopsFinder/StopsFinderOption.js +0 -51
  194. package/components/StopsFinder/StopsFinderOption.js.map +0 -7
  195. package/components/StopsFinder/index.js +0 -1
  196. package/components/StopsFinder/index.js.map +0 -7
  197. package/components/Zoom/Zoom.js +0 -130
  198. package/components/Zoom/Zoom.js.map +0 -7
  199. package/components/Zoom/index.js +0 -1
  200. package/components/Zoom/index.js.map +0 -7
  201. package/propTypes.js.map +0 -7
  202. package/setupTests.js.map +0 -7
  203. package/utils/GlobalsForOle.js +0 -94
  204. package/utils/GlobalsForOle.js.map +0 -7
  205. package/utils/KML.js +0 -412
  206. package/utils/KML.js.map +0 -7
  207. package/utils/KMLFormat.js +0 -69
  208. package/utils/KMLFormat.js.map +0 -7
  209. package/utils/Styles.js.map +0 -7
  210. package/utils/getPolygonPattern.js.map +0 -7
  211. package/utils/timeUtils.js +0 -31
  212. package/utils/timeUtils.js.map +0 -7
  213. /package/{components → src/components}/BaseLayerSwitcher/BaseLayerSwitcher.md.scss +0 -0
  214. /package/{components → src/components}/BaseLayerSwitcher/BaseLayerSwitcher.scss +0 -0
  215. /package/{components → src/components}/BasicMap/BasicMap.md.scss +0 -0
  216. /package/{components → src/components}/CanvasSaveButton/CanvasSaveButton.md.scss +0 -0
  217. /package/{components → src/components}/Copyright/Copyright.md.scss +0 -0
  218. /package/{components → src/components}/FeatureExportButton/FeatureExportButton.md.scss +0 -0
  219. /package/{components → src/components}/FitExtent/FitExtent.md.scss +0 -0
  220. /package/{components → src/components}/Geolocation/Geolocation.md.scss +0 -0
  221. /package/{components → src/components}/Geolocation/Geolocation.scss +0 -0
  222. /package/{components → src/components}/LayerTree/LayerTree.md.scss +0 -0
  223. /package/{components → src/components}/LayerTree/LayerTree.scss +0 -0
  224. /package/{components → src/components}/MousePosition/MousePosition.md.scss +0 -0
  225. /package/{components → src/components}/NorthArrow/NorthArrow.scss +0 -0
  226. /package/{components → src/components}/Overlay/Overlay.md.scss +0 -0
  227. /package/{components → src/components}/Overlay/Overlay.scss +0 -0
  228. /package/{components → src/components}/Permalink/Permalink.md.scss +0 -0
  229. /package/{components → src/components}/Popup/Popup.md.scss +0 -0
  230. /package/{components → src/components}/Popup/Popup.scss +0 -0
  231. /package/{components → src/components}/RouteSchedule/RouteSchedule.md.scss +0 -0
  232. /package/{components → src/components}/RouteSchedule/RouteSchedule.scss +0 -0
  233. /package/{components → src/components}/ScaleLine/ScaleLine.scss +0 -0
  234. /package/{components → src/components}/Zoom/Zoom.md.scss +0 -0
  235. /package/{components → src/components}/Zoom/Zoom.scss +0 -0
  236. /package/{images → src/images}/RouteSchedule/firstStation.png +0 -0
  237. /package/{images → src/images}/RouteSchedule/lastStation.png +0 -0
  238. /package/{images → src/images}/RouteSchedule/line.png +0 -0
  239. /package/{images → src/images}/RouteSchedule/station.png +0 -0
  240. /package/{images → src/images}/baselayer/baselayer.basebright.png +0 -0
  241. /package/{images → src/images}/baselayer/baselayer.osm.png +0 -0
  242. /package/{images → src/images}/baselayer/baselayer.travic.png +0 -0
  243. /package/{images → src/images}/baselayer/open.topo.map.png +0 -0
  244. /package/{images → src/images}/baselayer/osm.baselayer.hot.png +0 -0
  245. /package/{images → src/images}/baselayer/osm.baselayer.png +0 -0
  246. /package/{images → src/images}/favicon.png +0 -0
  247. /package/{images → src/images}/geops_logo.png +0 -0
  248. /package/{images → src/images}/geops_logo.svg +0 -0
  249. /package/{images → src/images}/geops_qr.png +0 -0
  250. /package/{images → src/images}/mots/bus_poi-blue-01.svg +0 -0
  251. /package/{images → src/images}/mots/bus_poi-grey-01.svg +0 -0
  252. /package/{images → src/images}/mots/bus_round-blue-01.svg +0 -0
  253. /package/{images → src/images}/mots/bus_round-grey-01.svg +0 -0
  254. /package/{images → src/images}/mots/bus_square-blue-01.svg +0 -0
  255. /package/{images → src/images}/mots/bus_square-grey-01.svg +0 -0
  256. /package/{images → src/images}/mots/cable_car_poi-blue-01.svg +0 -0
  257. /package/{images → src/images}/mots/cable_car_poi-grey-01.svg +0 -0
  258. /package/{images → src/images}/mots/cable_car_round-blue-01.svg +0 -0
  259. /package/{images → src/images}/mots/cable_car_round-grey-01.svg +0 -0
  260. /package/{images → src/images}/mots/cable_car_square-blue-01.svg +0 -0
  261. /package/{images → src/images}/mots/cable_car_square-grey-01.svg +0 -0
  262. /package/{images → src/images}/mots/ferry_poi-blue-01.svg +0 -0
  263. /package/{images → src/images}/mots/ferry_poi-grey-01.svg +0 -0
  264. /package/{images → src/images}/mots/ferry_round-blue-01.svg +0 -0
  265. /package/{images → src/images}/mots/ferry_round-grey-01.svg +0 -0
  266. /package/{images → src/images}/mots/ferry_square-blue-01.svg +0 -0
  267. /package/{images → src/images}/mots/ferry_square-grey-01.svg +0 -0
  268. /package/{images → src/images}/mots/funicular_round-blue-01.svg +0 -0
  269. /package/{images → src/images}/mots/funicular_round-grey-01.svg +0 -0
  270. /package/{images → src/images}/mots/funicular_square-blue-01.svg +0 -0
  271. /package/{images → src/images}/mots/gondola_round-blue-01.svg +0 -0
  272. /package/{images → src/images}/mots/rail_poi-blue-01.svg +0 -0
  273. /package/{images → src/images}/mots/rail_poi-grey-01.svg +0 -0
  274. /package/{images → src/images}/mots/rail_round-blue-01.svg +0 -0
  275. /package/{images → src/images}/mots/rail_round-grey-01.svg +0 -0
  276. /package/{images → src/images}/mots/rail_square-blue-01.svg +0 -0
  277. /package/{images → src/images}/mots/rail_square-grey-01.svg +0 -0
  278. /package/{images → src/images}/mots/subway_round blue-01.svg +0 -0
  279. /package/{images → src/images}/mots/subway_round-blue-01.svg +0 -0
  280. /package/{images → src/images}/mots/tram_poi-blue-01.svg +0 -0
  281. /package/{images → src/images}/mots/tram_poi-grey-01.svg +0 -0
  282. /package/{images → src/images}/mots/tram_round-blue-01.svg +0 -0
  283. /package/{images → src/images}/mots/tram_round-grey-01.svg +0 -0
  284. /package/{images → src/images}/mots/tram_square-blue-01.svg +0 -0
  285. /package/{images → src/images}/mots/tram_square-grey-01.svg +0 -0
  286. /package/{images → src/images}/northArrow.svg +0 -0
  287. /package/{images → src/images}/northArrow.url.svg +0 -0
  288. /package/{images → src/images}/northArrowCircle.svg +0 -0
  289. /package/{images → src/images}/northArrowCircle.url.svg +0 -0
  290. /package/{themes → src/themes}/README.md +0 -0
  291. /package/{themes → src/themes}/default/components.scss +0 -0
  292. /package/{themes → src/themes}/default/examples.scss +0 -0
  293. /package/{themes → src/themes}/default/index.scss +0 -0
  294. /package/{themes → src/themes}/default/mixins.scss +0 -0
  295. /package/{themes → src/themes}/default/variables.scss +0 -0
@@ -0,0 +1,117 @@
1
+ // Jest Snapshot v1, https://goo.gl/fbAQLP
2
+
3
+ exports[`NorthArrow should match snapshot rotated. 1`] = `
4
+ <div
5
+ className="rs-north-arrow"
6
+ style={
7
+ {
8
+ "transform": "rotate(45deg)",
9
+ }
10
+ }
11
+ >
12
+ <svg
13
+ data-file-name="SvgNorthArrow"
14
+ />
15
+ </div>
16
+ `;
17
+
18
+ exports[`NorthArrow should match snapshot with children. 1`] = `
19
+ <div
20
+ className="rs-north-arrow"
21
+ style={
22
+ {
23
+ "transform": "rotate(0deg)",
24
+ }
25
+ }
26
+ >
27
+ <svg
28
+ baseProfile="tiny"
29
+ fill="currentColor"
30
+ height="1em"
31
+ stroke="currentColor"
32
+ strokeWidth="0"
33
+ style={
34
+ {
35
+ "color": undefined,
36
+ }
37
+ }
38
+ version="1.2"
39
+ viewBox="0 0 24 24"
40
+ width="1em"
41
+ xmlns="http://www.w3.org/2000/svg"
42
+ >
43
+ <circle
44
+ cx="8.5"
45
+ cy="8.5"
46
+ r="2.5"
47
+ />
48
+ <path
49
+ d="M16 10c-2 0-3 3-4.5 3s-1.499-1-3.5-1c-2 0-3.001 4-3.001 4h14.001s-1-6-3-6zM20 3h-16c-1.103 0-2 .897-2 2v12c0 1.103.897 2 2 2h16c1.103 0 2-.897 2-2v-12c0-1.103-.897-2-2-2zm0 14h-16v-12h16v12z"
50
+ />
51
+ </svg>
52
+ </div>
53
+ `;
54
+
55
+ exports[`NorthArrow should match snapshot with circle. 1`] = `
56
+ <div
57
+ className="rs-north-arrow"
58
+ style={
59
+ {
60
+ "transform": "rotate(0deg)",
61
+ }
62
+ }
63
+ >
64
+ <svg
65
+ data-file-name="SvgNorthArrowCircle"
66
+ />
67
+ </div>
68
+ `;
69
+
70
+ exports[`NorthArrow should match snapshot with custom attributes. 1`] = `
71
+ <div
72
+ className="test-class"
73
+ style={
74
+ {
75
+ "transform": "rotate(0deg)",
76
+ }
77
+ }
78
+ tabIndex={0}
79
+ >
80
+ <svg
81
+ data-file-name="SvgNorthArrow"
82
+ />
83
+ </div>
84
+ `;
85
+
86
+ exports[`NorthArrow should match snapshot with default value. 1`] = `
87
+ <div
88
+ className="rs-north-arrow"
89
+ style={
90
+ {
91
+ "transform": "rotate(0deg)",
92
+ }
93
+ }
94
+ >
95
+ <svg
96
+ data-file-name="SvgNorthArrow"
97
+ />
98
+ </div>
99
+ `;
100
+
101
+ exports[`NorthArrow should react on view rotation (transform: \`rotate(20deg)\`) 1`] = `
102
+ <div class="rs-north-arrow"
103
+ style="transform: rotate(20deg);"
104
+ >
105
+ <svg data-file-name="SvgNorthArrow">
106
+ </svg>
107
+ </div>
108
+ `;
109
+
110
+ exports[`NorthArrow should react on view rotation with offset (transform: \`rotate(10deg)\`) 1`] = `
111
+ <div class="rs-north-arrow"
112
+ style="transform: rotate(10deg);"
113
+ >
114
+ <svg data-file-name="SvgNorthArrow">
115
+ </svg>
116
+ </div>
117
+ `;
@@ -0,0 +1 @@
1
+ export { default } from './NorthArrow';
@@ -0,0 +1,176 @@
1
+ import React, { Component, useState } from 'react';
2
+ import PropTypes from 'prop-types';
3
+ import { Resizable } from 're-resizable';
4
+ import ResizeHandler from '../ResizeHandler';
5
+
6
+ const propTypes = {
7
+ /**
8
+ * CSS class added to container.
9
+ */
10
+ className: PropTypes.string,
11
+
12
+ /**
13
+ * Children content of the overlay.
14
+ */
15
+ children: PropTypes.node,
16
+
17
+ /**
18
+ * Observed element to define screen size.
19
+ */
20
+ observe: PropTypes.oneOfType([
21
+ PropTypes.string,
22
+ PropTypes.node,
23
+ PropTypes.instanceOf(Component),
24
+ PropTypes.shape({ current: PropTypes.node }),
25
+ PropTypes.shape({ current: PropTypes.instanceOf(Component) }),
26
+ ]),
27
+
28
+ /**
29
+ * Deactivate the ability to resize the overlay on mobile.
30
+ * /!\ This prop is only used if isMobile (observer width < 768px).
31
+ */
32
+ isMobileResizable: PropTypes.bool,
33
+
34
+ /**
35
+ * Size parameters to the Resizable component on mobile.
36
+ * Pass following prop to re-resizable component: 'size', 'defaultSize', 'minHeight' & 'maxHeight'
37
+ * (https://github.com/bokuweb/re-resizable)
38
+ * /!\ This prop is only used if isMobile (observer width < 768px).
39
+ */
40
+ mobileSize: PropTypes.shape({
41
+ minimalHeight: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),
42
+ maximalHeight: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),
43
+ defaultSize: PropTypes.shape({
44
+ height: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),
45
+ width: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),
46
+ }),
47
+ size: PropTypes.shape({
48
+ height: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),
49
+ width: PropTypes.oneOfType([PropTypes.number, PropTypes.string]),
50
+ }),
51
+ }),
52
+
53
+ /**
54
+ * Minimal width to consider the observed as mobile.
55
+ * Default is 768px.
56
+ */
57
+ thresholdWidthForMobile: PropTypes.number,
58
+
59
+ /**
60
+ * Callback when stop resizing
61
+ * Pass following prop to re-resizable component
62
+ * (https://github.com/bokuweb/re-resizable)
63
+ */
64
+ onResizeStop: PropTypes.func,
65
+
66
+ /**
67
+ * Callback when start resizing
68
+ * Pass following prop to re-resizable component
69
+ * (https://github.com/bokuweb/re-resizable)
70
+ */
71
+ onResizeStart: PropTypes.func,
72
+ };
73
+
74
+ const defaultMobileSize = {
75
+ defaultSize: {
76
+ width: '100%',
77
+ height: '25%',
78
+ },
79
+ size: undefined,
80
+ maximalHeight: '100%',
81
+ minimalHeight: '25%',
82
+ };
83
+
84
+ const defaultProps = {
85
+ className: null,
86
+ children: null,
87
+ observe: null,
88
+ isMobileResizable: true,
89
+ mobileSize: defaultMobileSize,
90
+ thresholdWidthForMobile: 768,
91
+ onResizeStop: () => {},
92
+ onResizeStart: () => {},
93
+ };
94
+
95
+ /**
96
+ * The Overlay component creates a resizable, swipable overlay <div\>
97
+ */
98
+ const Overlay = ({
99
+ observe,
100
+ className,
101
+ children,
102
+ isMobileResizable,
103
+ mobileSize,
104
+ onResizeStop,
105
+ onResizeStart,
106
+ thresholdWidthForMobile,
107
+ }) => {
108
+ const [isMobile, setIsMobile] = useState();
109
+
110
+ const onResize = (entries) => {
111
+ for (let i = 0; i < entries.length; i += 1) {
112
+ const { width } = entries[i].contentRect;
113
+ setIsMobile(width <= thresholdWidthForMobile);
114
+ }
115
+ };
116
+
117
+ let resizableMobileSize;
118
+ if (mobileSize) {
119
+ resizableMobileSize = { ...defaultMobileSize, ...mobileSize };
120
+ }
121
+
122
+ return (
123
+ <>
124
+ {observe ? <ResizeHandler observe={observe} onResize={onResize} /> : null}
125
+ {isMobile ? (
126
+ <Resizable
127
+ style={{
128
+ position: 'absolute',
129
+ }}
130
+ enable={{
131
+ top: isMobileResizable,
132
+ right: false,
133
+ bottom: false,
134
+ left: false,
135
+ topRight: false,
136
+ bottomRight: false,
137
+ bottomLeft: false,
138
+ topLeft: false,
139
+ }}
140
+ maxHeight={mobileSize && resizableMobileSize.maximalHeight}
141
+ minHeight={mobileSize && resizableMobileSize.minimalHeight}
142
+ handleComponent={{
143
+ top: <div className="tm-overlay-handler">&mdash;</div>,
144
+ }}
145
+ onResizeStart={onResizeStart}
146
+ onResizeStop={onResizeStop}
147
+ handleStyles={{
148
+ top: {
149
+ top: '-20px',
150
+ height: '20px',
151
+ padding: '20px 0',
152
+ width: '100%',
153
+ display: 'flex',
154
+ alignItems: 'center',
155
+ justifyContent: 'center',
156
+ },
157
+ }}
158
+ size={resizableMobileSize.size}
159
+ defaultSize={mobileSize && resizableMobileSize.defaultSize}
160
+ className={`tm-overlay-mobile${className ? ` ${className}` : ''}`}
161
+ >
162
+ <div className="tm-overlay-mobile-content">{children}</div>
163
+ </Resizable>
164
+ ) : (
165
+ <div className={`tm-overlay${className ? ` ${className}` : ''}`}>
166
+ {children}
167
+ </div>
168
+ )}
169
+ </>
170
+ );
171
+ };
172
+
173
+ Overlay.propTypes = propTypes;
174
+ Overlay.defaultProps = defaultProps;
175
+
176
+ export default Overlay;
@@ -0,0 +1,149 @@
1
+ import React, { useState } from 'react';
2
+ import PropTypes from 'prop-types';
3
+ import { act } from 'react-dom/test-utils';
4
+ import { configure, mount } from 'enzyme';
5
+ import renderer from 'react-test-renderer';
6
+ import Adapter from '@cfaester/enzyme-adapter-react-18';
7
+ import ResizeObserver from 'resize-observer-polyfill';
8
+ import { Resizable } from 're-resizable';
9
+ import Overlay from './Overlay';
10
+
11
+ jest.mock('resize-observer-polyfill');
12
+
13
+ configure({ adapter: new Adapter() });
14
+
15
+ const propTypes = {
16
+ isMobileResizable: PropTypes.bool,
17
+ thresholdWidthForMobile: PropTypes.number,
18
+ };
19
+
20
+ const defaultProps = {
21
+ isMobileResizable: undefined,
22
+ thresholdWidthForMobile: undefined,
23
+ };
24
+
25
+ const BasicComponent = ({ thresholdWidthForMobile, isMobileResizable }) => {
26
+ const [ref, setRef] = useState(null);
27
+
28
+ return (
29
+ <>
30
+ <div
31
+ ref={(node) => {
32
+ if (node !== ref) {
33
+ setRef(node);
34
+ }
35
+ }}
36
+ className="observer"
37
+ />
38
+ <Overlay
39
+ observe={ref}
40
+ thresholdWidthForMobile={thresholdWidthForMobile}
41
+ isMobileResizable={isMobileResizable}
42
+ >
43
+ Test content
44
+ </Overlay>
45
+ </>
46
+ );
47
+ };
48
+ BasicComponent.propTypes = propTypes;
49
+ BasicComponent.defaultProps = defaultProps;
50
+
51
+ describe('Overlay', () => {
52
+ test('should match snapshot.', () => {
53
+ const component = renderer.create(<Overlay>Test content</Overlay>);
54
+ const tree = component.toJSON();
55
+ expect(tree).toMatchSnapshot();
56
+ });
57
+
58
+ test('should react on observe resize.', () => {
59
+ const wrapper = mount(<BasicComponent />);
60
+ const target = wrapper.find('.observer').getDOMNode();
61
+
62
+ act(() => {
63
+ // The mock class set the onResize property, we just have to run it to
64
+ // simulate a resize
65
+ ResizeObserver.onResize([
66
+ {
67
+ target,
68
+ contentRect: {
69
+ width: 200,
70
+ height: 200,
71
+ },
72
+ },
73
+ ]);
74
+ });
75
+ wrapper.update();
76
+
77
+ expect(wrapper.find('.tm-overlay').length > 0).toBe(false);
78
+ expect(wrapper.find('.tm-overlay-mobile').length > 0).toBe(true);
79
+ });
80
+
81
+ test('should force mobile overlay display on big screen.', () => {
82
+ const wrapper = mount(
83
+ <BasicComponent thresholdWidthForMobile={Infinity} />,
84
+ );
85
+ const target = wrapper.find('.observer').getDOMNode();
86
+
87
+ act(() => {
88
+ ResizeObserver.onResize([
89
+ {
90
+ target,
91
+ contentRect: {
92
+ width: 1200,
93
+ height: 200,
94
+ },
95
+ },
96
+ ]);
97
+ });
98
+ wrapper.update();
99
+
100
+ expect(wrapper.find('.tm-overlay').length > 0).toBe(false);
101
+ expect(wrapper.find('.tm-overlay-mobile').length > 0).toBe(true);
102
+ });
103
+
104
+ test('should allow resizing with top handler on mobile.', () => {
105
+ const wrapper = mount(<BasicComponent />);
106
+ const target = wrapper.find('.observer').getDOMNode();
107
+
108
+ // Force resize to make it mobile.
109
+ act(() => {
110
+ ResizeObserver.onResize([
111
+ {
112
+ target,
113
+ contentRect: {
114
+ width: 200,
115
+ height: 200,
116
+ },
117
+ },
118
+ ]);
119
+ });
120
+ wrapper.update();
121
+
122
+ const resizableProps = wrapper.find(Resizable).props();
123
+
124
+ expect(resizableProps.enable.top).toBe(true);
125
+ });
126
+
127
+ test('should not allow resizing with top handler on mobile.', () => {
128
+ const wrapper = mount(<BasicComponent isMobileResizable={false} />);
129
+ const target = wrapper.find('.observer').getDOMNode();
130
+
131
+ // Force resize to make it mobile.
132
+ act(() => {
133
+ ResizeObserver.onResize([
134
+ {
135
+ target,
136
+ contentRect: {
137
+ width: 200,
138
+ height: 200,
139
+ },
140
+ },
141
+ ]);
142
+ });
143
+ wrapper.update();
144
+
145
+ const resizableProps = wrapper.find(Resizable).props();
146
+
147
+ expect(resizableProps.enable.top).toBe(false);
148
+ });
149
+ });
@@ -0,0 +1,59 @@
1
+
2
+ The following example demonstrates the use of Overlay.
3
+
4
+ ```jsx
5
+ import React, { useState, useEffect, useRef } from 'react';
6
+ import Overlay from 'react-spatial/components/Overlay';
7
+
8
+ function OverlayExample() {
9
+ const [open, setOpen] = useState(true);
10
+ const [ref, setRef] = useState(null);
11
+ const refDiv = useRef(null);
12
+
13
+ useEffect(() => {
14
+ setRef(refDiv);
15
+ }, [refDiv]);
16
+
17
+ return (
18
+ <div
19
+ className="tm-overlay-example"
20
+ ref={refDiv}
21
+ >
22
+ <div
23
+ role="button"
24
+ className="tm-clickable-feature"
25
+ onClick={() => {
26
+ setOpen(!open);
27
+ }}
28
+ >
29
+ Toggle Overlay
30
+ </div>
31
+ {open && ref ? (
32
+ <Overlay
33
+ observe={ref.current}
34
+ className="tm-overlay-container"
35
+ mobileSize={{
36
+ minimalHeight: '25%',
37
+ maximalHeight: '80%',
38
+ defaultSize: {
39
+ height: '40%',
40
+ width: '100%',
41
+ },
42
+ }}
43
+ >
44
+ <div
45
+ role="button"
46
+ onClick={() => {
47
+ setOpen(false);
48
+ }}
49
+ >
50
+ Close Overlay
51
+ </div>
52
+ </Overlay>
53
+ ) : null}
54
+ </div>
55
+ );
56
+ }
57
+
58
+ <OverlayExample />;
59
+ ```
@@ -0,0 +1,9 @@
1
+ // Jest Snapshot v1, https://goo.gl/fbAQLP
2
+
3
+ exports[`Overlay should match snapshot. 1`] = `
4
+ <div
5
+ className="tm-overlay"
6
+ >
7
+ Test content
8
+ </div>
9
+ `;
@@ -0,0 +1 @@
1
+ export { default } from './Overlay';