mobility-toolbox-js 2.0.0-beta.8 → 2.0.1-beta.13

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 (304) hide show
  1. package/api/RoutingAPI.js +15 -0
  2. package/api/RoutingAPI.test.js +25 -0
  3. package/api/StopsAPI.js +12 -0
  4. package/api/StopsAPI.test.js +22 -0
  5. package/api/TralisAPI.js +359 -0
  6. package/api/TralisAPI.test.js +67 -0
  7. package/{src/api/tralis → api}/TralisAPIUtils.js +2 -32
  8. package/api/index.js +3 -0
  9. package/{index.html → api/typedefs.js} +0 -0
  10. package/common/Tracker.js +93 -0
  11. package/common/api/HttpAPI.js +30 -0
  12. package/common/api/HttpAPI.test.js +50 -0
  13. package/common/api/WebSocketAPI.js +175 -0
  14. package/{src/api/tralis/WebSocketConnector.test.js → common/api/WebSocketAPI.test.js} +100 -145
  15. package/common/controls/Control.js +81 -0
  16. package/{src/common → common}/controls/Control.test.js +32 -43
  17. package/common/index.js +4 -0
  18. package/common/layers/Layer.js +213 -0
  19. package/{src/common → common}/layers/Layer.test.js +185 -244
  20. package/common/mixins/CopyrightMixin.js +24 -0
  21. package/common/mixins/SearchMixin.js +110 -0
  22. package/common/mixins/TralisLayerMixin.js +479 -0
  23. package/common/styles/index.js +4 -0
  24. package/{src/common → common}/styles/trackerDefaultStyle.js +39 -175
  25. package/common/styles/trackerDelayStyle.js +8 -0
  26. package/{src/common → common}/styles/trackerSimpleStyle.js +4 -8
  27. package/{src/common → common}/trackerConfig.js +61 -99
  28. package/common/trackerConfig.test.js +23 -0
  29. package/{src/doc/examples/ol-mapbox-layer.md → common/typedefs.js} +0 -0
  30. package/common/utils/createTrackerFilters.js +56 -0
  31. package/common/utils/createTrackerFilters.test.js +79 -0
  32. package/{src/common → common}/utils/getMapboxMapCopyrights.js +3 -16
  33. package/common/utils/getMapboxMapCopyrights.test.js +40 -0
  34. package/{src/common → common}/utils/getMapboxStyleUrl.js +3 -13
  35. package/{src/common → common}/utils/getVehiclePosition.js +3 -33
  36. package/common/utils/index.js +5 -0
  37. package/common/utils/removeDuplicate.js +8 -0
  38. package/common/utils/removeDuplicate.test.js +19 -0
  39. package/{src/common → common}/utils/sortByDelay.js +2 -7
  40. package/common/utils/timeUtils.js +20 -0
  41. package/common/utils/timeUtils.test.js +10 -0
  42. package/index.js +8 -0
  43. package/mapbox/controls/CopyrightControl.js +29 -0
  44. package/mapbox/controls/index.js +1 -0
  45. package/mapbox/index.js +4 -0
  46. package/mapbox/layers/Layer.js +57 -0
  47. package/mapbox/layers/Layer.test.js +182 -0
  48. package/mapbox/layers/TralisLayer.js +182 -0
  49. package/{src/mapbox → mapbox}/layers/TralisLayer.test.js +12 -14
  50. package/mapbox/layers/index.js +2 -0
  51. package/{src/mapbox → mapbox}/utils.js +7 -21
  52. package/mbt.js +50444 -0
  53. package/mbt.js.map +7 -0
  54. package/mbt.min.js +1005 -0
  55. package/mbt.min.js.map +7 -0
  56. package/ol/controls/CopyrightControl.js +42 -0
  57. package/ol/controls/CopyrightControl.test.js +165 -0
  58. package/ol/controls/RoutingControl.js +387 -0
  59. package/ol/controls/RoutingControl.test.js +151 -0
  60. package/ol/controls/StopFinderControl.js +10 -0
  61. package/ol/controls/StopFinderControl.test.js +48 -0
  62. package/ol/controls/index.js +3 -0
  63. package/ol/index.js +5 -0
  64. package/ol/layers/Layer.js +88 -0
  65. package/ol/layers/Layer.test.js +174 -0
  66. package/ol/layers/MapboxLayer.js +203 -0
  67. package/{src/ol → ol}/layers/MapboxLayer.test.js +58 -84
  68. package/ol/layers/MapboxStyleLayer.js +187 -0
  69. package/{src/ol → ol}/layers/MapboxStyleLayer.test.js +97 -128
  70. package/ol/layers/MaplibreLayer.js +139 -0
  71. package/ol/layers/RoutingLayer.js +61 -0
  72. package/{src/ol → ol}/layers/RoutingLayer.test.js +15 -24
  73. package/ol/layers/TralisLayer.js +185 -0
  74. package/ol/layers/TralisLayer.test.js +79 -0
  75. package/ol/layers/VectorLayer.js +22 -0
  76. package/{src/ol → ol}/layers/VectorLayer.test.js +34 -45
  77. package/ol/layers/WMSLayer.js +38 -0
  78. package/ol/layers/WMSLayer.test.js +76 -0
  79. package/ol/layers/index.js +8 -0
  80. package/{src/ol → ol}/styles/fullTrajectoryDelayStyle.js +11 -15
  81. package/ol/styles/fullTrajectoryStyle.js +43 -0
  82. package/ol/styles/index.js +2 -0
  83. package/package.json +34 -74
  84. package/.babelrc +0 -6
  85. package/.esdoc.json +0 -17
  86. package/.eslintignore +0 -1
  87. package/.github/workflows/conventional-pr-title.yml +0 -21
  88. package/.github/workflows/cypress.yml +0 -29
  89. package/.github/workflows/nodejs.yml +0 -28
  90. package/.husky/commit-msg +0 -4
  91. package/.husky/post-checkout +0 -4
  92. package/.husky/post-merge +0 -4
  93. package/.husky/post-rebase +0 -4
  94. package/.husky/pre-commit +0 -4
  95. package/.neutrinorc.js +0 -176
  96. package/.nvmrc +0 -1
  97. package/CHANGELOG.md +0 -10
  98. package/LICENSE +0 -21
  99. package/__mocks__/mapbox-gl.js +0 -81
  100. package/__mocks__/maplibre-gl.js +0 -81
  101. package/commitlint.config.js +0 -1
  102. package/cypress/fixtures/example.json +0 -5
  103. package/cypress/integration/examples/api.spec.js +0 -7
  104. package/cypress/integration/examples/examples.spec.js +0 -7
  105. package/cypress/integration/examples/navigation.spec.js +0 -29
  106. package/cypress/plugins/index.js +0 -21
  107. package/cypress/support/commands.js +0 -25
  108. package/cypress/support/index.js +0 -20
  109. package/cypress.json +0 -4
  110. package/data/fetchRoute.json +0 -292
  111. package/data/fetchTrajectories.json +0 -18
  112. package/data/fetchTrajectoryById.json +0 -3
  113. package/data/fetchTrajectoryStations.json +0 -18
  114. package/data/stopsSearch.json +0 -15
  115. package/documentation.yml +0 -4
  116. package/esdoc/README.md +0 -27
  117. package/esdoc/plugins/MyPlugin.js +0 -69
  118. package/esdoc/plugins/dynamic-property-plugin/Plugin.js +0 -50
  119. package/esdoc/plugins/externals-plugin/Plugin.js +0 -45
  120. package/esdoc/plugins/externals-plugin/externals.js +0 -96
  121. package/global-setup.js +0 -3
  122. package/indexweb.html +0 -49
  123. package/jest.config.js +0 -5
  124. package/pull_request_template.md +0 -17
  125. package/renovate.json +0 -4
  126. package/scripts/read-pkg-json.js +0 -22
  127. package/src/api/index.js +0 -3
  128. package/src/api/routing/RoutingAPI.js +0 -44
  129. package/src/api/routing/RoutingAPI.test.js +0 -41
  130. package/src/api/stops/StopsAPI.js +0 -41
  131. package/src/api/stops/StopsAPI.test.js +0 -34
  132. package/src/api/tralis/TralisAPI.js +0 -731
  133. package/src/api/tralis/TralisAPI.test.js +0 -75
  134. package/src/api/tralis/WebSocketConnector.js +0 -338
  135. package/src/api/tralis/typedefs.js +0 -81
  136. package/src/assets/Lato-Black.ttf +0 -0
  137. package/src/assets/Lato-BlackItalic.ttf +0 -0
  138. package/src/assets/Lato-Bold.ttf +0 -0
  139. package/src/assets/Lato-BoldItalic.ttf +0 -0
  140. package/src/assets/Lato-Italic.ttf +0 -0
  141. package/src/assets/Lato-Light.ttf +0 -0
  142. package/src/assets/Lato-LightItalic.ttf +0 -0
  143. package/src/assets/Lato-Regular.ttf +0 -0
  144. package/src/assets/Lato-Thin.ttf +0 -0
  145. package/src/assets/Lato-ThinItalic.ttf +0 -0
  146. package/src/assets/OFL.txt +0 -93
  147. package/src/common/Tracker.js +0 -197
  148. package/src/common/api/api.js +0 -64
  149. package/src/common/api/api.test.js +0 -68
  150. package/src/common/controls/Control.js +0 -146
  151. package/src/common/index.js +0 -5
  152. package/src/common/layers/Layer.js +0 -404
  153. package/src/common/mixins/CopyrightMixin.js +0 -48
  154. package/src/common/mixins/SearchMixin.js +0 -176
  155. package/src/common/mixins/TralisLayerMixin.js +0 -930
  156. package/src/common/styles/index.js +0 -4
  157. package/src/common/styles/trackerDelayStyle.js +0 -17
  158. package/src/common/trackerConfig.test.js +0 -25
  159. package/src/common/typedefs.js +0 -23
  160. package/src/common/utils/createTrackerFilters.js +0 -87
  161. package/src/common/utils/createTrackerFilters.test.js +0 -95
  162. package/src/common/utils/getMapboxMapCopyrights.test.js +0 -47
  163. package/src/common/utils/index.js +0 -5
  164. package/src/common/utils/removeDuplicate.js +0 -22
  165. package/src/common/utils/removeDuplicate.test.js +0 -22
  166. package/src/common/utils/timeUtils.js +0 -44
  167. package/src/common/utils/timeUtils.test.js +0 -16
  168. package/src/doc/App.js +0 -116
  169. package/src/doc/App.scss +0 -51
  170. package/src/doc/_redirects +0 -2
  171. package/src/doc/components/CodeSandboxButton.js +0 -103
  172. package/src/doc/components/Documentation.js +0 -40
  173. package/src/doc/components/Esdoc/Anchor.js +0 -57
  174. package/src/doc/components/Esdoc/ClassDoc.js +0 -272
  175. package/src/doc/components/Esdoc/DeprecatedHTML.js +0 -16
  176. package/src/doc/components/Esdoc/DetailDocs.js +0 -281
  177. package/src/doc/components/Esdoc/DetailHTML.js +0 -33
  178. package/src/doc/components/Esdoc/DirectSubclassHTML.js +0 -30
  179. package/src/doc/components/Esdoc/DocBuilderUtils.js +0 -694
  180. package/src/doc/components/Esdoc/DocLinkHTML.js +0 -62
  181. package/src/doc/components/Esdoc/DocsLinkHTML.js +0 -38
  182. package/src/doc/components/Esdoc/Esdoc.js +0 -63
  183. package/src/doc/components/Esdoc/EsdocContent.js +0 -51
  184. package/src/doc/components/Esdoc/EsdocNavigation.js +0 -13
  185. package/src/doc/components/Esdoc/EsdocSearch.js +0 -81
  186. package/src/doc/components/Esdoc/ExperimentalHTML.js +0 -17
  187. package/src/doc/components/Esdoc/ExtendsChainHTML.js +0 -32
  188. package/src/doc/components/Esdoc/FileDocLinkHTML.js +0 -60
  189. package/src/doc/components/Esdoc/IdentifiersDoc.js +0 -113
  190. package/src/doc/components/Esdoc/IndirectSubclassHTML.js +0 -30
  191. package/src/doc/components/Esdoc/InheritedSummaryDoc.js +0 -70
  192. package/src/doc/components/Esdoc/InheritedSummaryHTML.js +0 -38
  193. package/src/doc/components/Esdoc/MixinClassesHTML.js +0 -29
  194. package/src/doc/components/Esdoc/NavDoc.js +0 -112
  195. package/src/doc/components/Esdoc/OverrideMethod.js +0 -44
  196. package/src/doc/components/Esdoc/OverrideMethodDescription.js +0 -35
  197. package/src/doc/components/Esdoc/Properties.js +0 -89
  198. package/src/doc/components/Esdoc/README.md +0 -45
  199. package/src/doc/components/Esdoc/SignatureHTML.js +0 -123
  200. package/src/doc/components/Esdoc/SingleDoc.js +0 -31
  201. package/src/doc/components/Esdoc/SummaryDoc.js +0 -160
  202. package/src/doc/components/Esdoc/SummaryHTML.js +0 -96
  203. package/src/doc/components/Esdoc/TypeDocLinkHTML.js +0 -249
  204. package/src/doc/components/Esdoc/css/identifiers.css +0 -38
  205. package/src/doc/components/Esdoc/css/search.css +0 -76
  206. package/src/doc/components/Esdoc/css/style.css +0 -603
  207. package/src/doc/components/Esdoc/index.js +0 -7
  208. package/src/doc/components/Example.js +0 -153
  209. package/src/doc/components/Examples.js +0 -183
  210. package/src/doc/components/Home.js +0 -106
  211. package/src/doc/components/TrackerExample.js +0 -38
  212. package/src/doc/examples/assets/tralis-live-map/index.js +0 -11
  213. package/src/doc/examples/assets/tralis-live-map/s1kreis.svg +0 -105
  214. package/src/doc/examples/assets/tralis-live-map/s20kreis.svg +0 -101
  215. package/src/doc/examples/assets/tralis-live-map/s2kreis.svg +0 -95
  216. package/src/doc/examples/assets/tralis-live-map/s3kreis.svg +0 -95
  217. package/src/doc/examples/assets/tralis-live-map/s4kreis.svg +0 -95
  218. package/src/doc/examples/assets/tralis-live-map/s6kreis.svg +0 -95
  219. package/src/doc/examples/assets/tralis-live-map/s7kreis.svg +0 -95
  220. package/src/doc/examples/assets/tralis-live-map/s8kreis.svg +0 -93
  221. package/src/doc/examples/assets/tralis-live-map/unknown.svg +0 -107
  222. package/src/doc/examples/mb-copyright.html +0 -26
  223. package/src/doc/examples/mb-copyright.js +0 -37
  224. package/src/doc/examples/mb-tracker.html +0 -1
  225. package/src/doc/examples/mb-tracker.js +0 -39
  226. package/src/doc/examples/mb-tracker.md +0 -1
  227. package/src/doc/examples/mb-tralis.html +0 -1
  228. package/src/doc/examples/mb-tralis.js +0 -34
  229. package/src/doc/examples/ol-copyright.html +0 -26
  230. package/src/doc/examples/ol-copyright.js +0 -43
  231. package/src/doc/examples/ol-mapbox-layer.html +0 -1
  232. package/src/doc/examples/ol-mapbox-layer.js +0 -28
  233. package/src/doc/examples/ol-mapbox-style-layer.html +0 -12
  234. package/src/doc/examples/ol-mapbox-style-layer.js +0 -44
  235. package/src/doc/examples/ol-query.html +0 -32
  236. package/src/doc/examples/ol-query.js +0 -83
  237. package/src/doc/examples/ol-routing.html +0 -26
  238. package/src/doc/examples/ol-routing.js +0 -59
  239. package/src/doc/examples/ol-routing.md +0 -1
  240. package/src/doc/examples/ol-stop-finder.html +0 -15
  241. package/src/doc/examples/ol-stop-finder.js +0 -31
  242. package/src/doc/examples/ol-stop-finder.md +0 -1
  243. package/src/doc/examples/ol-tracker.html +0 -1
  244. package/src/doc/examples/ol-tracker.js +0 -44
  245. package/src/doc/examples/ol-tracker.md +0 -1
  246. package/src/doc/examples/ol-tralis.html +0 -5
  247. package/src/doc/examples/ol-tralis.js +0 -57
  248. package/src/doc/examples/tralis-live-map.html +0 -1
  249. package/src/doc/examples/tralis-live-map.js +0 -51
  250. package/src/doc/examples/tralis-live-map.md +0 -3
  251. package/src/doc/examples.js +0 -107
  252. package/src/doc/img/examples/live_tracker_mb.jpg +0 -0
  253. package/src/doc/img/examples/live_tracker_munich.jpg +0 -0
  254. package/src/doc/img/examples/live_tracker_ol.jpg +0 -0
  255. package/src/doc/img/examples/mapbox.jpg +0 -0
  256. package/src/doc/img/examples/mapbox_style.jpg +0 -0
  257. package/src/doc/img/examples/ol-copyright.png +0 -0
  258. package/src/doc/img/examples/query_objects.jpg +0 -0
  259. package/src/doc/img/examples/routing.jpg +0 -0
  260. package/src/doc/img/examples/simple_map.jpg +0 -0
  261. package/src/doc/img/examples/stops.jpg +0 -0
  262. package/src/doc/img/favico.ico +0 -0
  263. package/src/doc/index.js +0 -21
  264. package/src/iife.js +0 -7
  265. package/src/index.js +0 -10
  266. package/src/mapbox/controls/CopyrightControl.js +0 -58
  267. package/src/mapbox/controls/index.js +0 -2
  268. package/src/mapbox/index.js +0 -4
  269. package/src/mapbox/layers/Layer.js +0 -118
  270. package/src/mapbox/layers/Layer.test.js +0 -202
  271. package/src/mapbox/layers/TralisLayer.js +0 -329
  272. package/src/mapbox/layers/index.js +0 -2
  273. package/src/ol/README.md +0 -0
  274. package/src/ol/controls/CopyrightControl.js +0 -80
  275. package/src/ol/controls/CopyrightControl.test.js +0 -211
  276. package/src/ol/controls/RoutingControl.js +0 -752
  277. package/src/ol/controls/RoutingControl.test.js +0 -216
  278. package/src/ol/controls/StopFinderControl.js +0 -38
  279. package/src/ol/controls/StopFinderControl.test.js +0 -59
  280. package/src/ol/controls/index.js +0 -3
  281. package/src/ol/controls/snapshots/RoutingControlRouteGen10.json +0 -58
  282. package/src/ol/controls/snapshots/RoutingControlRouteGen100.json +0 -292
  283. package/src/ol/controls/snapshots/RoutingControlRouteGen30.json +0 -69
  284. package/src/ol/controls/snapshots/RoutingControlRouteGen5.json +0 -58
  285. package/src/ol/controls/snapshots/RoutingControlRouteOSM.json +0 -759
  286. package/src/ol/controls/snapshots/RoutingControlStation1.json +0 -60
  287. package/src/ol/controls/snapshots/RoutingControlStation2.json +0 -49
  288. package/src/ol/index.js +0 -5
  289. package/src/ol/layers/Layer.js +0 -193
  290. package/src/ol/layers/Layer.test.js +0 -197
  291. package/src/ol/layers/MapboxLayer.js +0 -378
  292. package/src/ol/layers/MapboxStyleLayer.js +0 -417
  293. package/src/ol/layers/MaplibreLayer.js +0 -280
  294. package/src/ol/layers/RoutingLayer.js +0 -91
  295. package/src/ol/layers/TralisLayer.js +0 -359
  296. package/src/ol/layers/TralisLayer.test.js +0 -97
  297. package/src/ol/layers/VectorLayer.js +0 -43
  298. package/src/ol/layers/WMSLayer.js +0 -80
  299. package/src/ol/layers/WMSLayer.test.js +0 -84
  300. package/src/ol/layers/index.js +0 -8
  301. package/src/ol/styles/fullTrajectoryStyle.js +0 -51
  302. package/src/ol/styles/index.js +0 -2
  303. package/src/setupTests.js +0 -15
  304. package/webpack.config.js +0 -6
@@ -1,378 +0,0 @@
1
- /* eslint-disable no-underscore-dangle */
2
- import { toLonLat } from 'ol/proj';
3
- import { Map } from 'mapbox-gl';
4
- import Source from 'ol/source/Source';
5
- import OLLayer from 'ol/layer/Layer';
6
- import GeoJSON from 'ol/format/GeoJSON';
7
- import Layer from './Layer';
8
- import { getMapboxMapCopyrights, getMapboxStyleUrl } from '../../common/utils';
9
-
10
- /**
11
- * A class representing Mapboxlayer to display on BasicMap
12
- *
13
- * @example
14
- * import { MapboxLayer } from 'mobility-toolbox-js/ol';
15
- *
16
- * const layer = new MapboxLayer({
17
- * url: 'https://maps.geops.io/styles/travic_v2/style.json',
18
- * apikey: 'yourApiKey',
19
- * });
20
- *
21
- * @classproperty {ol/Map~Map} map - The map where the layer is displayed.
22
- * @extends {Layer}
23
- */
24
- export default class MapboxLayer extends Layer {
25
- /**
26
- * Constructor.
27
- *
28
- * @param {Object} options
29
- * @param {boolean} [options.preserveDrawingBuffer=false] If true able to export the canvas.
30
- * @param {number} [options.fadeDuration=300] Duration of the fade effect in ms.
31
- */
32
- constructor(options = {}) {
33
- const mbLayer = new OLLayer({
34
- source: new Source({}),
35
- render: (frameState) => {
36
- if (!this.mbMap) {
37
- // eslint-disable-next-line no-console
38
- console.warn("Mapbox map doesn't exist.");
39
- return null;
40
- }
41
- let changed = false;
42
- const canvas = this.mbMap.getCanvas();
43
- const { viewState } = frameState;
44
-
45
- const visible = this.olLayer.getVisible();
46
- if (this.renderState.visible !== visible) {
47
- canvas.style.display = visible ? 'block' : 'none';
48
- this.renderState.visible = visible;
49
- // Needed since mapbox-gl 1.9.0.
50
- // Without you don't see others ol layers on top.
51
- canvas.style.position = 'absolute';
52
- }
53
-
54
- const opacity = this.olLayer.getOpacity();
55
- if (this.renderState.opacity !== opacity) {
56
- canvas.style.opacity = opacity;
57
- this.renderState.opacity = opacity;
58
- }
59
-
60
- // adjust view parameters in mapbox
61
- const { rotation } = viewState;
62
- if (this.renderState.rotation !== rotation) {
63
- this.mbMap.rotateTo((-(rotation || 0) * 180) / Math.PI, {
64
- animate: false,
65
- });
66
- changed = true;
67
- this.renderState.rotation = rotation;
68
- }
69
-
70
- if (
71
- this.renderState.zoom !== viewState.zoom ||
72
- this.renderState.center[0] !== viewState.center[0] ||
73
- this.renderState.center[1] !== viewState.center[1]
74
- ) {
75
- this.mbMap.jumpTo({
76
- center: toLonLat(viewState.center),
77
- zoom: viewState.zoom - 1,
78
- animate: false,
79
- });
80
- changed = true;
81
- this.renderState.zoom = viewState.zoom;
82
- this.renderState.center = viewState.center;
83
- }
84
-
85
- const size = this.map.getSize();
86
- if (
87
- this.renderState.size[0] !== size[0] ||
88
- this.renderState.size[1] !== size[1]
89
- ) {
90
- changed = true;
91
- this.renderState.size = size;
92
- }
93
-
94
- // cancel the scheduled update & trigger synchronous redraw
95
- // see https://github.com/mapbox/mapbox-gl-js/issues/7893#issue-408992184
96
- // NOTE: THIS MIGHT BREAK WHEN UPDATING MAPBOX
97
- if (
98
- this.mbMap &&
99
- this.mbMap.style &&
100
- this.mbMap.isStyleLoaded() &&
101
- changed
102
- ) {
103
- try {
104
- if (this.mbMap._frame) {
105
- this.mbMap._frame.cancel();
106
- this.mbMap._frame = null;
107
- }
108
- this.mbMap._render();
109
- } catch (err) {
110
- // ignore render errors because it's probably related to
111
- // a render during an update of the style.
112
- // eslint-disable-next-line no-console
113
- console.warn(err);
114
- }
115
- }
116
-
117
- return this.mbMap.getContainer();
118
- },
119
- });
120
-
121
- super({
122
- ...options,
123
- olLayer: mbLayer,
124
- });
125
-
126
- /**
127
- * Url of the mapbox style.
128
- * @type {string}
129
- * @private
130
- */
131
- this.styleUrl = options.url;
132
-
133
- /**
134
- * Api key for the url of the mapbox style.
135
- * If set to false, the apiKey is not required.
136
- * @type {string}
137
- * @private
138
- */
139
- this.apiKey = options.apiKey;
140
-
141
- /**
142
- * Name of the apiKey to set in the url request.
143
- * Default is 'key'.
144
- * @type {string}
145
- * @private
146
- */
147
- this.apiKeyName = options.apiKeyName || 'key';
148
-
149
- /** @ignore */
150
- this.updateAttribution = this.updateAttribution.bind(this);
151
- }
152
-
153
- /**
154
- * Initialize the layer and listen to feature clicks.
155
- * @param {ol/Map~Map} map
156
- */
157
- init(map) {
158
- super.init(map);
159
-
160
- if (!this.map || this.mbMap) {
161
- return;
162
- }
163
-
164
- /**
165
- * The feature format.
166
- * @type {ol/format/GeoJSON}
167
- */
168
- this.format = new GeoJSON({
169
- featureProjection: this.map.getView().getProjection(),
170
- });
171
-
172
- this.loadMbMap();
173
-
174
- this.olListenersKeys.push(
175
- this.map.on('change:size', () => {
176
- try {
177
- if (this.mbMap) {
178
- this.mbMap.resize();
179
- }
180
- } catch (err) {
181
- // ignore render errors
182
- // eslint-disable-next-line no-console
183
- console.warn(err);
184
- }
185
- }),
186
- );
187
- }
188
-
189
- /**
190
- * Terminate what was initialized in init function. Remove layer, events...
191
- */
192
- terminate() {
193
- if (this.mbMap) {
194
- this.mbMap.off('idle', this.updateAttribution);
195
- // Some asynchrone repaints are triggered even if the mbMap has been removed,
196
- // to avoid display of errors we set an empty function.
197
- this.mbMap.triggerRepaint = () => {};
198
- this.mbMap.remove();
199
- this.mbMap = null;
200
- }
201
- this.loaded = false;
202
- super.terminate();
203
- }
204
-
205
- /**
206
- * Returns a style URL with apiKey & apiKeyName infos.
207
- * @private
208
- */
209
- createStyleUrl() {
210
- return getMapboxStyleUrl(this.apiKey, this.apiKeyName, this.styleUrl);
211
- }
212
-
213
- /**
214
- * Create the mapbox map.
215
- * @private
216
- */
217
- loadMbMap() {
218
- this.olListenersKeys.push(
219
- this.map.on('change:target', () => {
220
- this.loadMbMap();
221
- }),
222
- );
223
-
224
- if (!this.map.getTargetElement()) {
225
- return;
226
- }
227
-
228
- if (!this.visible) {
229
- // On next change of visibility we load the map
230
- this.olListenersKeys.push(
231
- this.once('change:visible', () => {
232
- this.loadMbMap();
233
- }),
234
- );
235
- return;
236
- }
237
-
238
- // If the map hasn't been resized, the center could be [NaN,NaN].
239
- // We set default good value for the mapbox map, to avoid the app crashes.
240
- let [x, y] = this.map.getView().getCenter();
241
- if (!x || !y) {
242
- x = 0;
243
- y = 0;
244
- }
245
-
246
- const container = document.createElement('div');
247
- container.style.position = 'absolute';
248
- container.style.width = '100%';
249
- container.style.height = '100%';
250
-
251
- /**
252
- * A mapbox map
253
- * @type {mapboxgl.Map}
254
- */
255
- this.mbMap = new Map({
256
- style: this.createStyleUrl(),
257
- container,
258
- interactive: false,
259
- trackResize: false,
260
- attributionControl: false,
261
- ...(this.options.mapOptions || {}),
262
- });
263
-
264
- // Options the last render run did happen. If something changes
265
- // we have to render again
266
- /** @ignore */
267
- this.renderState = {
268
- center: [x, y],
269
- zoom: null,
270
- rotation: null,
271
- visible: null,
272
- opacity: null,
273
- size: [0, 0],
274
- };
275
-
276
- this.mbMap.once('load', () => {
277
- this.mbMap.resize();
278
- /**
279
- * Is the map loaded.
280
- * @type {boolean}
281
- */
282
- this.loaded = true;
283
-
284
- /** @ignore */
285
- this.copyrights = getMapboxMapCopyrights(this.mbMap) || [];
286
-
287
- this.olLayer.getSource().setAttributions(this.copyrights);
288
-
289
- this.dispatchEvent({
290
- type: 'load',
291
- target: this,
292
- });
293
- });
294
-
295
- const mapboxCanvas = this.mbMap.getCanvas();
296
- if (mapboxCanvas) {
297
- if (this.options.tabIndex) {
298
- mapboxCanvas.setAttribute('tabindex', this.options.tabIndex);
299
- } else {
300
- // With a tabIndex='-1' the mouse events works but the map is not focused when we click on it
301
- // so we remove completely the tabIndex attribute.
302
- mapboxCanvas.removeAttribute('tabindex');
303
- }
304
- }
305
-
306
- this.mbMap.on('idle', this.updateAttribution);
307
- }
308
-
309
- /**
310
- * Update attributions of the source.
311
- * @private
312
- */
313
- updateAttribution(evt) {
314
- const newAttributions = getMapboxMapCopyrights(evt.target) || [];
315
- if (this.copyrights.toString() !== newAttributions.toString()) {
316
- this.copyrights = newAttributions;
317
- this.olLayer.getSource().setAttributions(newAttributions);
318
- }
319
- }
320
-
321
- /**
322
- * Request feature information for a given coordinate.
323
- * @param {ol/coordinate~Coordinate} coordinate Coordinate to request the information at.
324
- * @param {Object} options A [mapboxgl.Map#queryrenderedfeatures](https://docs.mapbox.com/mapbox-gl-js/api/map/#map#queryrenderedfeatures) options parameter.
325
- * @return {Promise<FeatureInfo>} Promise with features, layer and coordinate. The original Mapbox feature is available as a property named 'mapboxFeature'.
326
- */
327
- getFeatureInfoAtCoordinate(coordinate, options) {
328
- // Ignore the getFeatureInfo until the mapbox map is loaded
329
- if (
330
- !options ||
331
- !this.format ||
332
- !this.mbMap ||
333
- !this.mbMap.isStyleLoaded()
334
- ) {
335
- return Promise.resolve({ coordinate, features: [], layer: this });
336
- }
337
-
338
- let pixel = coordinate && this.mbMap.project(toLonLat(coordinate));
339
-
340
- if (this.hitTolerance) {
341
- const { x, y } = pixel;
342
- pixel = [
343
- { x: x - this.hitTolerance, y: y - this.hitTolerance },
344
- { x: x + this.hitTolerance, y: y + this.hitTolerance },
345
- ];
346
- }
347
-
348
- // At this point we get GeoJSON Mapbox feature, we transform it to an OpenLayers
349
- // feature to be consistent with other layers.
350
- const features = this.mbMap
351
- .queryRenderedFeatures(pixel, options)
352
- .map((feature) => {
353
- const olFeature = this.format.readFeature(feature);
354
- if (olFeature) {
355
- // We save the original mapbox feature to avoid losing informations
356
- // potentially needed for other functionnality like highlighting
357
- // (id, layer id, source, sourceLayer ...)
358
- olFeature.set('mapboxFeature', feature);
359
- }
360
- return olFeature;
361
- });
362
-
363
- return Promise.resolve({
364
- layer: this,
365
- features,
366
- coordinate,
367
- });
368
- }
369
-
370
- /**
371
- * Create a copy of the MapboxLayer.
372
- * @param {Object} newOptions Options to override
373
- * @return {MapboxLayer} A MapboxLayer
374
- */
375
- clone(newOptions) {
376
- return new MapboxLayer({ ...this.options, ...newOptions });
377
- }
378
- }