@guardian/interactive-component-library 0.2.0-rc1 → 0.2.0-rc3

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 (276) hide show
  1. package/dist/components/index.d.ts +3 -0
  2. package/dist/components/molecules/canvas-map/Map.d.ts +17 -0
  3. package/dist/components/molecules/canvas-map/Map.js +89 -0
  4. package/dist/components/molecules/canvas-map/context/MapContext.d.ts +19 -0
  5. package/dist/components/molecules/canvas-map/context/MapContext.js +20 -0
  6. package/dist/components/molecules/canvas-map/controls/ZoomControl.d.ts +6 -0
  7. package/dist/components/molecules/canvas-map/controls/ZoomControl.js +40 -0
  8. package/dist/components/molecules/canvas-map/controls/icons/index.d.ts +3 -0
  9. package/dist/components/molecules/canvas-map/controls/icons/minus.d.ts +1 -0
  10. package/dist/components/molecules/canvas-map/controls/icons/minus.js +25 -0
  11. package/dist/components/molecules/canvas-map/controls/icons/plus.d.ts +1 -0
  12. package/dist/components/molecules/canvas-map/controls/icons/plus.js +25 -0
  13. package/dist/components/molecules/canvas-map/controls/icons/reset.d.ts +3 -0
  14. package/dist/components/molecules/canvas-map/controls/icons/reset.js +25 -0
  15. package/dist/components/molecules/canvas-map/controls/index.d.ts +1 -0
  16. package/dist/components/molecules/canvas-map/controls/style.module.css.js +11 -0
  17. package/dist/components/molecules/canvas-map/index.d.ts +12 -0
  18. package/dist/components/molecules/canvas-map/lib/Feature.d.ts +38 -0
  19. package/dist/components/molecules/canvas-map/lib/Feature.js +104 -0
  20. package/dist/components/molecules/canvas-map/lib/FeatureCollection.d.ts +20 -0
  21. package/dist/components/molecules/canvas-map/lib/FeatureCollection.js +23 -0
  22. package/dist/components/molecules/canvas-map/lib/Map.d.ts +69 -0
  23. package/dist/components/molecules/canvas-map/lib/Map.js +254 -0
  24. package/dist/components/molecules/canvas-map/lib/View.d.ts +136 -0
  25. package/dist/components/molecules/canvas-map/lib/View.js +179 -0
  26. package/dist/components/molecules/canvas-map/lib/events/Dispatcher.d.ts +8 -0
  27. package/dist/components/molecules/canvas-map/lib/events/Dispatcher.js +35 -0
  28. package/dist/components/molecules/canvas-map/lib/events/MapEvent.d.ts +6 -0
  29. package/dist/components/molecules/canvas-map/lib/events/MapEvent.js +9 -0
  30. package/dist/components/molecules/canvas-map/lib/events/index.d.ts +2 -0
  31. package/dist/components/molecules/canvas-map/lib/formats/GeoJSON.d.ts +10 -0
  32. package/dist/components/molecules/canvas-map/lib/formats/GeoJSON.js +96 -0
  33. package/dist/components/molecules/canvas-map/lib/geometry/Geometry.d.ts +32 -0
  34. package/dist/components/molecules/canvas-map/lib/geometry/Geometry.js +41 -0
  35. package/dist/components/molecules/canvas-map/lib/geometry/LineString.d.ts +12 -0
  36. package/dist/components/molecules/canvas-map/lib/geometry/LineString.js +19 -0
  37. package/dist/components/molecules/canvas-map/lib/geometry/Point.d.ts +11 -0
  38. package/dist/components/molecules/canvas-map/lib/geometry/Point.js +16 -0
  39. package/dist/components/molecules/canvas-map/lib/geometry/Polygon.d.ts +16 -0
  40. package/dist/components/molecules/canvas-map/lib/geometry/Polygon.js +46 -0
  41. package/dist/components/molecules/canvas-map/lib/geometry/index.d.ts +4 -0
  42. package/dist/components/molecules/canvas-map/lib/interpolators/index.d.ts +2 -0
  43. package/dist/components/molecules/canvas-map/lib/interpolators/interpolateFeatures.d.ts +5 -0
  44. package/dist/components/molecules/canvas-map/lib/interpolators/interpolateFeatures.js +95 -0
  45. package/dist/components/molecules/canvas-map/lib/interpolators/interpolateStyles.d.ts +4 -0
  46. package/dist/components/molecules/canvas-map/lib/interpolators/interpolateStyles.js +65 -0
  47. package/dist/components/molecules/canvas-map/lib/layers/TextLayer.d.ts +52 -0
  48. package/dist/components/molecules/canvas-map/lib/layers/TextLayer.js +111 -0
  49. package/dist/components/molecules/canvas-map/lib/layers/VectorLayer.d.ts +53 -0
  50. package/dist/components/molecules/canvas-map/lib/layers/VectorLayer.js +132 -0
  51. package/dist/components/molecules/canvas-map/lib/layers/index.d.ts +3 -0
  52. package/dist/components/molecules/canvas-map/lib/projection/index.d.ts +22 -0
  53. package/dist/components/molecules/canvas-map/lib/projection/index.js +12 -0
  54. package/dist/components/molecules/canvas-map/lib/renderers/FeatureRenderer.d.ts +6 -0
  55. package/dist/components/molecules/canvas-map/lib/renderers/FeatureRenderer.js +46 -0
  56. package/dist/components/molecules/canvas-map/lib/renderers/MapRenderer.d.ts +6 -0
  57. package/dist/components/molecules/canvas-map/lib/renderers/MapRenderer.js +53 -0
  58. package/dist/components/molecules/canvas-map/lib/renderers/TextLayerRenderer.d.ts +17 -0
  59. package/dist/components/molecules/canvas-map/lib/renderers/TextLayerRenderer.js +119 -0
  60. package/dist/components/molecules/canvas-map/lib/renderers/VectorLayerRenderer.d.ts +10 -0
  61. package/dist/components/molecules/canvas-map/lib/renderers/VectorLayerRenderer.js +78 -0
  62. package/dist/components/molecules/canvas-map/lib/sources/VectorSource.d.ts +15 -0
  63. package/dist/components/molecules/canvas-map/lib/sources/VectorSource.js +56 -0
  64. package/dist/components/molecules/canvas-map/lib/styles/Fill.d.ts +7 -0
  65. package/dist/components/molecules/canvas-map/lib/styles/Fill.js +15 -0
  66. package/dist/components/molecules/canvas-map/lib/styles/Stroke.d.ts +8 -0
  67. package/dist/components/molecules/canvas-map/lib/styles/Stroke.js +16 -0
  68. package/dist/components/molecules/canvas-map/lib/styles/Style.d.ts +24 -0
  69. package/dist/components/molecules/canvas-map/lib/styles/Style.js +17 -0
  70. package/dist/components/molecules/canvas-map/lib/styles/Text.d.ts +10 -0
  71. package/dist/components/molecules/canvas-map/lib/styles/Text.js +14 -0
  72. package/dist/components/molecules/canvas-map/lib/styles/index.d.ts +4 -0
  73. package/dist/components/molecules/canvas-map/lib/util/array.d.ts +6 -0
  74. package/dist/components/molecules/canvas-map/lib/util/array.js +15 -0
  75. package/dist/components/molecules/canvas-map/lib/util/bboxFeature.d.ts +8 -0
  76. package/dist/components/molecules/canvas-map/lib/util/bboxFeature.js +26 -0
  77. package/dist/components/molecules/canvas-map/lib/util/debug.d.ts +11 -0
  78. package/dist/components/molecules/canvas-map/lib/util/debug.js +27 -0
  79. package/dist/components/molecules/canvas-map/lib/util/deflate.d.ts +36 -0
  80. package/dist/components/molecules/canvas-map/lib/util/distance.d.ts +1 -0
  81. package/dist/components/molecules/canvas-map/lib/util/distance.js +12 -0
  82. package/dist/components/molecules/canvas-map/lib/util/dom.d.ts +9 -0
  83. package/dist/components/molecules/canvas-map/lib/util/dom.js +28 -0
  84. package/dist/components/molecules/canvas-map/lib/util/extent.d.ts +21 -0
  85. package/dist/components/molecules/canvas-map/lib/util/extent.js +38 -0
  86. package/dist/components/molecules/canvas-map/lib/util/memoise.d.ts +10 -0
  87. package/dist/components/molecules/canvas-map/lib/util/memoise.js +20 -0
  88. package/dist/components/molecules/canvas-map/lib/util/resolution.d.ts +9 -0
  89. package/dist/components/molecules/canvas-map/lib/util/resolution.js +11 -0
  90. package/dist/components/molecules/canvas-map/lib/util/simplify.d.ts +114 -0
  91. package/dist/components/molecules/canvas-map/lib/util/size.d.ts +32 -0
  92. package/dist/components/molecules/canvas-map/lib/util/size.js +53 -0
  93. package/dist/components/molecules/canvas-map/lib/util/toRgba.d.ts +1 -0
  94. package/dist/components/molecules/canvas-map/lib/util/toRgba.js +25 -0
  95. package/dist/components/molecules/canvas-map/lib/util/uid.d.ts +5 -0
  96. package/dist/components/molecules/canvas-map/lib/util/uid.js +7 -0
  97. package/dist/components/molecules/canvas-map/lib/util/zoomLevel.d.ts +2 -0
  98. package/dist/components/molecules/canvas-map/lib/util/zoomLevel.js +14 -0
  99. package/dist/components/molecules/canvas-map/style.module.scss.js +20 -0
  100. package/dist/components/molecules/column-chart/column-chart-example.d.ts +35 -0
  101. package/dist/components/molecules/column-chart/column-chart-util.d.ts +1 -0
  102. package/dist/components/molecules/column-chart/index.d.ts +11 -0
  103. package/dist/components/molecules/column-chart/index.js +63 -0
  104. package/dist/components/molecules/column-chart/style.module.css.js +14 -0
  105. package/dist/components/molecules/control-change/index.d.ts +6 -0
  106. package/dist/components/molecules/control-change/index.js +29 -0
  107. package/dist/components/molecules/control-change/style.module.css.js +11 -0
  108. package/dist/components/molecules/dropdown/index.d.ts +11 -0
  109. package/dist/components/molecules/dropdown/index.js +191 -0
  110. package/dist/components/molecules/dropdown/style.module.css.js +50 -0
  111. package/dist/components/molecules/first-past-the-post-waffle/index.d.ts +5 -0
  112. package/dist/components/molecules/first-past-the-post-waffle/index.js +14 -0
  113. package/dist/components/molecules/first-past-the-post-waffle/style.module.css.js +14 -0
  114. package/dist/components/molecules/index.d.ts +17 -0
  115. package/dist/components/molecules/modal/index.d.ts +8 -0
  116. package/dist/components/molecules/modal/index.js +59 -0
  117. package/dist/components/molecules/modal/style.module.css.js +26 -0
  118. package/dist/components/molecules/page-section/index.d.ts +8 -0
  119. package/dist/components/molecules/page-section/index.js +52 -0
  120. package/dist/components/molecules/page-section/style.module.scss.js +20 -0
  121. package/dist/components/molecules/party-profile/index.d.ts +10 -0
  122. package/dist/components/molecules/party-profile/index.js +29 -0
  123. package/dist/components/molecules/party-profile/style.module.css.js +26 -0
  124. package/dist/components/molecules/refresh-indicator/index.d.ts +4 -0
  125. package/dist/components/molecules/refresh-indicator/index.js +18 -0
  126. package/dist/components/molecules/refresh-indicator/style.module.scss.js +17 -0
  127. package/dist/components/molecules/responsive-grid/index.d.ts +10 -0
  128. package/dist/components/molecules/responsive-grid/index.js +19 -0
  129. package/dist/components/molecules/responsive-grid/style.module.scss.js +8 -0
  130. package/dist/components/molecules/result-summary/index.d.ts +8 -0
  131. package/dist/components/molecules/result-summary/index.js +38 -0
  132. package/dist/components/molecules/result-summary/style.module.css.js +11 -0
  133. package/dist/components/molecules/search-input/icons/search.d.ts +1 -0
  134. package/dist/components/molecules/search-input/icons/search.js +24 -0
  135. package/dist/components/molecules/search-input/icons/search.module.css.js +11 -0
  136. package/dist/components/molecules/search-input/index.d.ts +11 -0
  137. package/dist/components/molecules/search-input/index.js +164 -0
  138. package/dist/components/molecules/search-input/style.module.css.js +32 -0
  139. package/dist/components/molecules/slope-chart/index.d.ts +16 -0
  140. package/dist/components/molecules/slope-chart/index.js +139 -0
  141. package/dist/components/molecules/slope-chart/style.module.css.js +35 -0
  142. package/dist/components/molecules/svg-map/context/MapContext.d.ts +1 -0
  143. package/dist/components/molecules/svg-map/context/MapContext.js +5 -0
  144. package/dist/components/molecules/svg-map/context/SVGMapProvider.d.ts +10 -0
  145. package/dist/components/molecules/svg-map/context/SVGMapProvider.js +88 -0
  146. package/dist/components/molecules/svg-map/helpers/bboxFeature.d.ts +8 -0
  147. package/dist/components/molecules/svg-map/helpers/bboxFeature.js +26 -0
  148. package/dist/components/molecules/svg-map/helpers/dynamicPropValue.d.ts +1 -0
  149. package/dist/components/molecules/svg-map/helpers/dynamicPropValue.js +9 -0
  150. package/dist/components/molecules/svg-map/helpers/geoMath.d.ts +4 -0
  151. package/dist/components/molecules/svg-map/helpers/saveSVG.d.ts +1 -0
  152. package/dist/components/molecules/svg-map/hooks/useCamera.d.ts +0 -0
  153. package/dist/components/molecules/svg-map/hooks/useThrowIfNonLayerChildren.d.ts +4 -0
  154. package/dist/components/molecules/svg-map/hooks/useThrowIfNonLayerChildren.js +19 -0
  155. package/dist/components/molecules/svg-map/index.d.ts +38 -0
  156. package/dist/components/molecules/svg-map/index.js +121 -0
  157. package/dist/components/molecules/svg-map/layers/CompositionBorders.d.ts +3 -0
  158. package/dist/components/molecules/svg-map/layers/CompositionBorders.js +14 -0
  159. package/dist/components/molecules/svg-map/layers/Line.d.ts +7 -0
  160. package/dist/components/molecules/svg-map/layers/Line.js +48 -0
  161. package/dist/components/molecules/svg-map/layers/Point.d.ts +10 -0
  162. package/dist/components/molecules/svg-map/layers/Point.js +59 -0
  163. package/dist/components/molecules/svg-map/layers/Polygon.d.ts +9 -0
  164. package/dist/components/molecules/svg-map/layers/Polygon.js +75 -0
  165. package/dist/components/molecules/svg-map/layers/Prerendered.d.ts +3 -0
  166. package/dist/components/molecules/svg-map/layers/Prerendered.js +11 -0
  167. package/dist/components/molecules/svg-map/layers/compositionBorders.module.scss.js +8 -0
  168. package/dist/components/molecules/svg-map/layers/index.d.ts +5 -0
  169. package/dist/components/molecules/svg-map/layers/index.js +12 -0
  170. package/dist/components/molecules/svg-map/renderers/SVGRenderer.d.ts +3 -0
  171. package/dist/components/molecules/svg-map/renderers/SVGRenderer.js +32 -0
  172. package/dist/components/molecules/svg-map/style.module.css.js +11 -0
  173. package/dist/components/molecules/table/index.d.ts +7 -0
  174. package/dist/components/molecules/table/index.js +90 -0
  175. package/dist/components/molecules/table/style.module.scss.js +29 -0
  176. package/dist/components/molecules/table/useTable.d.ts +8 -0
  177. package/dist/components/molecules/table/useTable.js +128 -0
  178. package/dist/components/molecules/tooltip/index.d.ts +82 -0
  179. package/dist/components/molecules/tooltip/index.js +117 -0
  180. package/dist/components/molecules/tooltip/style.module.css.js +8 -0
  181. package/dist/components/molecules/topline-result/index.d.ts +3 -0
  182. package/dist/components/molecules/topline-result/index.js +61 -0
  183. package/dist/components/molecules/topline-result/style.module.scss.js +38 -0
  184. package/dist/components/organisms/coalitions-tracker/index.d.ts +16 -0
  185. package/dist/components/organisms/coalitions-tracker/index.js +151 -0
  186. package/dist/components/organisms/coalitions-tracker/style.module.scss.js +32 -0
  187. package/dist/components/organisms/index.d.ts +2 -0
  188. package/dist/components/organisms/ticker/gradient/index.d.ts +1 -0
  189. package/dist/components/organisms/ticker/gradient/index.js +35 -0
  190. package/dist/components/organisms/ticker/gradient/style.module.scss.js +14 -0
  191. package/dist/components/organisms/ticker/index.d.ts +5 -0
  192. package/dist/components/organisms/ticker/index.js +102 -0
  193. package/dist/components/organisms/ticker/style.module.scss.js +32 -0
  194. package/dist/components/particles/ad-slot/index.d.ts +40 -0
  195. package/dist/components/particles/ad-slot/index.js +34 -0
  196. package/dist/components/particles/ad-slot/style.module.css.js +11 -0
  197. package/dist/components/particles/arrow-button/index.d.ts +6 -0
  198. package/dist/components/particles/arrow-button/index.js +32 -0
  199. package/dist/components/particles/arrow-button/style.module.css.js +11 -0
  200. package/dist/components/particles/aspect-ratio-box/index.d.ts +4 -0
  201. package/dist/components/particles/aspect-ratio-box/index.js +15 -0
  202. package/dist/components/particles/aspect-ratio-box/style.module.css.js +6 -0
  203. package/dist/components/particles/button/index.d.ts +6 -0
  204. package/dist/components/particles/button/index.js +10 -0
  205. package/dist/components/particles/button/style.module.css.js +11 -0
  206. package/dist/components/particles/change-bar/index.d.ts +8 -0
  207. package/dist/components/particles/change-bar/index.js +27 -0
  208. package/dist/components/particles/change-bar/style.module.scss.js +14 -0
  209. package/dist/components/particles/chevron/index.d.ts +6 -0
  210. package/dist/components/particles/chevron/index.js +78 -0
  211. package/dist/components/particles/chevron/style.module.css.js +20 -0
  212. package/dist/components/particles/circle-icon/index.d.ts +6 -0
  213. package/dist/components/particles/circle-icon/index.js +32 -0
  214. package/dist/components/particles/circle-icon/style.module.css.js +14 -0
  215. package/dist/components/particles/close-button/index.d.ts +5 -0
  216. package/dist/components/particles/close-button/index.js +35 -0
  217. package/dist/components/particles/close-button/style.module.css.js +17 -0
  218. package/dist/components/particles/container/index.d.ts +5 -0
  219. package/dist/components/particles/container/index.js +13 -0
  220. package/dist/components/particles/container/style.module.scss.js +11 -0
  221. package/dist/components/particles/gradient-icon/index.d.ts +1 -0
  222. package/dist/components/particles/gradient-icon/index.js +46 -0
  223. package/dist/components/particles/gradient-icon/style.module.css.js +14 -0
  224. package/dist/components/particles/index.d.ts +18 -0
  225. package/dist/components/particles/info-button/index.d.ts +3 -0
  226. package/dist/components/particles/info-button/index.js +19 -0
  227. package/dist/components/particles/info-button/style.module.css.js +11 -0
  228. package/dist/components/particles/legend-item/index.d.ts +6 -0
  229. package/dist/components/particles/legend-item/index.js +26 -0
  230. package/dist/components/particles/legend-item/style.module.css.js +17 -0
  231. package/dist/components/particles/relative-time-sentence/index.d.ts +4 -0
  232. package/dist/components/particles/relative-time-sentence/index.js +14 -0
  233. package/dist/components/particles/relative-time-sentence/style.module.css.js +8 -0
  234. package/dist/components/particles/square-cut-corner-icon/index.d.ts +6 -0
  235. package/dist/components/particles/square-cut-corner-icon/index.js +56 -0
  236. package/dist/components/particles/square-cut-corner-icon/style.module.scss.js +17 -0
  237. package/dist/components/particles/square-icon/index.d.ts +5 -0
  238. package/dist/components/particles/square-icon/index.js +28 -0
  239. package/dist/components/particles/square-icon/style.module.scss.js +11 -0
  240. package/dist/components/particles/stacked-bar/index.d.ts +23 -0
  241. package/dist/components/particles/stacked-bar/index.js +140 -0
  242. package/dist/components/particles/stacked-bar/style.module.css.js +17 -0
  243. package/dist/components/particles/stacked-grid/index.d.ts +6 -0
  244. package/dist/components/particles/stacked-grid/index.js +35 -0
  245. package/dist/components/particles/stacked-grid/style.module.css.js +20 -0
  246. package/dist/components/particles/waffle/index.d.ts +14 -0
  247. package/dist/components/particles/waffle/index.js +76 -0
  248. package/dist/components/particles/waffle/style.module.css.js +11 -0
  249. package/dist/index.d.ts +2 -0
  250. package/dist/index.js +128 -0
  251. package/dist/shared/colors/index.d.ts +2 -0
  252. package/dist/shared/helpers/createStore.d.ts +1 -0
  253. package/dist/shared/helpers/geometry.d.ts +3 -0
  254. package/dist/shared/helpers/geometry.js +16 -0
  255. package/dist/shared/helpers/geometry.test.d.ts +1 -0
  256. package/dist/shared/helpers/labelsUtil.d.ts +54 -0
  257. package/dist/shared/helpers/labelsUtil.js +58 -0
  258. package/dist/shared/helpers/labelsUtils.test.d.ts +1 -0
  259. package/dist/shared/helpers/shouldUpdate.d.ts +7 -0
  260. package/dist/shared/hooks/index.d.ts +3 -0
  261. package/dist/shared/hooks/useContainerSize.d.ts +1 -0
  262. package/dist/shared/hooks/useContainerSize.js +24 -0
  263. package/dist/shared/hooks/useTouchOrHover.d.ts +6 -0
  264. package/dist/shared/hooks/useTouchOrHover.js +95 -0
  265. package/dist/shared/hooks/useWindowSize.d.ts +4 -0
  266. package/dist/shared/hooks/useWindowSize.js +27 -0
  267. package/dist/style.css +74 -74
  268. package/dist/styles/helpers/mergeStyles.d.ts +1 -0
  269. package/dist/styles/helpers/mergeStyles.js +22 -0
  270. package/dist/styles/helpers/mergeStyles.test.d.ts +1 -0
  271. package/dist/styles/theme.config.d.ts +124 -0
  272. package/package.json +6 -9
  273. package/dist/interactive-component-library.js +0 -7993
  274. package/dist/interactive-component-library.js.map +0 -1
  275. package/dist/interactive-component-library.umd.cjs +0 -7989
  276. package/dist/interactive-component-library.umd.cjs.map +0 -1
@@ -0,0 +1,254 @@
1
+ import { View } from "./View.js";
2
+ import { sizeForElement } from "./util/size.js";
3
+ import { arrayEquals } from "./util/array.js";
4
+ import { containsCoordinate } from "./util/extent.js";
5
+ import { MapRenderer } from "./renderers/MapRenderer.js";
6
+ import { zoomIdentity, zoom } from "d3-zoom";
7
+ import { select } from "d3-selection";
8
+ import { timer } from "d3-timer";
9
+ import { Dispatcher } from "./events/Dispatcher.js";
10
+ import { MapEvent } from "./events/MapEvent.js";
11
+ import "d3-transition";
12
+ class Map {
13
+ constructor(config) {
14
+ if (config.debug) {
15
+ console.log("Map config", config);
16
+ }
17
+ this.options = config;
18
+ this.view = new View(config.view, config.debug);
19
+ this.target = config.target;
20
+ this.layers = [];
21
+ this.dispatcher = new Dispatcher(this);
22
+ this._viewport = document.createElement("div");
23
+ this._viewport.className = "gv-map";
24
+ this._viewport.style.position = "relative";
25
+ this._viewport.style.overflow = "hidden";
26
+ this._viewport.style.width = "100%";
27
+ this._viewport.style.height = "100%";
28
+ this.target.appendChild(this._viewport);
29
+ this._renderer = new MapRenderer(this);
30
+ this._resizeObserver = new ResizeObserver(() => {
31
+ this._updateSize();
32
+ });
33
+ this._resizeObserver.observe(this.target);
34
+ this._viewport.addEventListener("touchmove", (event) => {
35
+ if (event.targetTouches.length < 2 && this._collaborativeGesturesEnabled) {
36
+ this._filterEventCallback(true);
37
+ }
38
+ });
39
+ }
40
+ destroy() {
41
+ this._resizeObserver.disconnect();
42
+ this._viewport.remove();
43
+ }
44
+ /** PUBLIC GETTERS */
45
+ get size() {
46
+ return this._size;
47
+ }
48
+ get viewPort() {
49
+ return this._viewport;
50
+ }
51
+ get zoomScale() {
52
+ return this.view.transform.k;
53
+ }
54
+ get isTransitioning() {
55
+ return this._isTransitioning;
56
+ }
57
+ /** PUBLIC METHODS */
58
+ collaborativeGesturesEnabled(enabled) {
59
+ if (enabled === void 0) return this._collaborativeGesturesEnabled;
60
+ this._collaborativeGesturesEnabled = enabled;
61
+ }
62
+ onFilterEvent(callback) {
63
+ this._filterEventCallback = callback;
64
+ }
65
+ fitObject(geoJSON) {
66
+ this.view.fitObject(geoJSON);
67
+ this._requestRender();
68
+ }
69
+ addLayer(layer) {
70
+ this.addLayers([layer]);
71
+ }
72
+ addLayers(layers) {
73
+ this.layers = this.layers.concat(layers);
74
+ layers.forEach((layer) => {
75
+ layer.on(MapEvent.CHANGE, () => {
76
+ this._requestRender();
77
+ });
78
+ });
79
+ this._requestRender();
80
+ }
81
+ setLayers(layers) {
82
+ if (layers === this.layers) {
83
+ return;
84
+ }
85
+ new Array(...this.layers).forEach((layer) => {
86
+ if (!layers.includes(layer)) {
87
+ this.removeLayer(layer);
88
+ }
89
+ });
90
+ this.layers = [];
91
+ this.addLayers(layers);
92
+ }
93
+ removeLayer(layer) {
94
+ layer.tearDown();
95
+ const layerIndex = this.layers.indexOf(layer);
96
+ if (layerIndex < 0) return;
97
+ this.layers.splice(layerIndex, 1);
98
+ }
99
+ async zoomIn(options) {
100
+ return this.zoomTo(this.zoomScale * 2, options);
101
+ }
102
+ async zoomOut(options) {
103
+ return this.zoomTo(this.zoomScale * 0.5, options);
104
+ }
105
+ async zoomTo(zoomScale, options = { duration: 500 }) {
106
+ return select(this._viewport).transition().duration(options.duration).call(this._zoomBehaviour.scaleTo, zoomScale).end();
107
+ }
108
+ zoomToFeature(feature, focalPoint, padding = { top: 40, right: 40, bottom: 40, left: 40 }) {
109
+ const extent = feature.getExtent();
110
+ const [[featureX, featureY], [featureWidth, featureHeight]] = this.view.boundsForExtent(extent);
111
+ const [viewPortWidth, viewPortHeight] = this.view.viewPortSize;
112
+ const paddedViewPortWidth = viewPortWidth - padding.left - padding.right;
113
+ const paddedViewPortHeight = viewPortHeight - padding.top - padding.bottom;
114
+ const featureScale = Math.min(
115
+ paddedViewPortWidth / featureWidth,
116
+ paddedViewPortHeight / featureHeight
117
+ );
118
+ const zoomScale = Math.min(this.view.scaleExtent[1], featureScale);
119
+ const scaledPadding = {
120
+ top: padding.top / zoomScale,
121
+ right: padding.right / zoomScale,
122
+ bottom: padding.bottom / zoomScale,
123
+ left: padding.left / zoomScale
124
+ };
125
+ const paddedFeatureBounds = {
126
+ x: featureX - scaledPadding.left,
127
+ y: featureY - scaledPadding.top,
128
+ width: featureWidth + scaledPadding.left + scaledPadding.right,
129
+ height: featureHeight + scaledPadding.top + scaledPadding.bottom
130
+ };
131
+ const newTransform = zoomIdentity.translate(viewPortWidth / 2, viewPortHeight / 2).scale(zoomScale).translate(
132
+ -(paddedFeatureBounds.x + paddedFeatureBounds.width / 2),
133
+ -(paddedFeatureBounds.y + paddedFeatureBounds.height / 2)
134
+ );
135
+ select(this._viewport).transition().duration(500).call(this._zoomBehaviour.transform, newTransform, focalPoint);
136
+ }
137
+ /** @param {import("./layers").Layer[]} layers */
138
+ hasLayers(layers) {
139
+ if (layers.length !== this.layers.length) {
140
+ return false;
141
+ }
142
+ for (let i = 0; i < layers.length; i++) {
143
+ if (layers[i] !== this.layers[i]) {
144
+ return false;
145
+ }
146
+ }
147
+ return true;
148
+ }
149
+ async resetZoom(options) {
150
+ return this.zoomTo(1, options);
151
+ }
152
+ findFeatures(point) {
153
+ const mapCoordinate = this.view.invert(point);
154
+ const matchingFeatures = [];
155
+ for (const layer of this.layers) {
156
+ const layerExtent = layer.getExtent();
157
+ if (layer.hitDetectionEnabled && containsCoordinate(layerExtent, mapCoordinate)) {
158
+ const features = layer.findFeatures(mapCoordinate);
159
+ if (features) {
160
+ matchingFeatures.push(...features);
161
+ }
162
+ }
163
+ }
164
+ return matchingFeatures;
165
+ }
166
+ changed() {
167
+ this._requestRender();
168
+ }
169
+ async transition(options = { duration: 500 }, callback) {
170
+ const ease = options.ease || ((t) => t);
171
+ return new Promise((resolve) => {
172
+ this._isTransitioning = true;
173
+ this.dispatcher.dispatch(MapEvent.TRANSITION_START);
174
+ const _timer = timer((elapsed) => {
175
+ const t = Math.min(elapsed / options.duration, 1);
176
+ callback(ease(t));
177
+ this._renderFrame();
178
+ if (elapsed >= options.duration) {
179
+ _timer.stop();
180
+ this._isTransitioning = false;
181
+ this.dispatcher.dispatch(MapEvent.TRANSITION_END);
182
+ resolve();
183
+ }
184
+ });
185
+ });
186
+ }
187
+ /** PRIVATE METHODS */
188
+ _updateSize() {
189
+ const targetElement = this.target;
190
+ let newSize = sizeForElement(targetElement);
191
+ const oldSize = this.size;
192
+ if (newSize && (!oldSize || !arrayEquals(newSize, oldSize))) {
193
+ this._size = newSize;
194
+ this._updateViewportSize(newSize);
195
+ }
196
+ }
197
+ _updateViewportSize(size) {
198
+ const view = this.view;
199
+ if (view) {
200
+ view.viewPortSize = size;
201
+ this._createZoomBehaviour(size);
202
+ }
203
+ this._requestRender();
204
+ }
205
+ _createZoomBehaviour(viewPortSize) {
206
+ if (this._zoomBehaviour) {
207
+ this._zoomBehaviour.on("zoom", null);
208
+ }
209
+ this._zoomBypassKey = navigator.userAgent.indexOf("Mac") !== -1 ? "metaKey" : "ctrlKey";
210
+ this._zoomBehaviour = zoom().extent([[0, 0], viewPortSize]).translateExtent([[0, 0], viewPortSize]).scaleExtent(this.view.scaleExtent).filter((event) => {
211
+ const filterEvent = (filter) => {
212
+ this._filterEventCallback(filter);
213
+ return !filter;
214
+ };
215
+ if (event.type === "wheel" && !event[this._zoomBypassKey]) {
216
+ return filterEvent(true);
217
+ }
218
+ if ("targetTouches" in event && this.collaborativeGesturesEnabled) {
219
+ if (event.targetTouches.length < 2) {
220
+ return false;
221
+ }
222
+ event.preventDefault();
223
+ return filterEvent(false);
224
+ }
225
+ return (!event.ctrlKey || event.type === "wheel") && !event.button;
226
+ }).on("zoom", (event) => {
227
+ this.view.transform = event.transform;
228
+ this._requestRender();
229
+ this.dispatcher.dispatch(MapEvent.ZOOM, {
230
+ zoomScale: event.transform.k
231
+ });
232
+ });
233
+ select(this._viewport).call(this._zoomBehaviour);
234
+ }
235
+ _requestRender() {
236
+ if (!this._renderer || !!this._animationFrameRequestID || this._isTransitioning)
237
+ return;
238
+ this._animationFrameRequestID = requestAnimationFrame(
239
+ this._renderFrame.bind(this)
240
+ );
241
+ }
242
+ _renderFrame() {
243
+ const frameState = {
244
+ size: this.size,
245
+ viewState: this.view.getState(),
246
+ debug: this.options.debug || false
247
+ };
248
+ this._renderer.renderFrame(frameState);
249
+ this._animationFrameRequestID = null;
250
+ }
251
+ }
252
+ export {
253
+ Map
254
+ };
@@ -0,0 +1,136 @@
1
+ import { ZoomTransform } from 'd3-zoom';
2
+ /**
3
+ * Represents how the map is viewed.
4
+ * @constructor
5
+ * @param {Object} options - The options for the view.
6
+ * @param {Projection} options.projection - The projection to use for the view.
7
+ * @param {Array} options.extent - The extent of the view in projection coordinates.
8
+ * @param {number} options.minZoom - The minimum zoom level for the view.
9
+ * @param {number} options.maxZoom - The maximum zoom level for the view.
10
+ * @param {Object} options.padding - The padding for the view in pixels.
11
+ * @param {boolean} debug - Whether to enable debug mode or not.
12
+ */
13
+ export class View {
14
+ constructor({ projection, extent, minZoom, maxZoom, padding, }: {
15
+ projection?: {
16
+ (p: any): number[];
17
+ invert(p: any): number[];
18
+ stream(stream: any): any;
19
+ postclip(_: any, ...args: any[]): any;
20
+ clipExtent(_: any, ...args: any[]): any[][] | any;
21
+ scale(_: any, ...args: any[]): number | any;
22
+ translate(_: any, ...args: any[]): number[] | any;
23
+ angle(_: any, ...args: any[]): number | any;
24
+ reflectX(_: any, ...args: any[]): boolean | any;
25
+ reflectY(_: any, ...args: any[]): boolean | any;
26
+ fitExtent(extent: any, object: any): any;
27
+ fitSize(size: any, object: any): any;
28
+ fitWidth(width: any, object: any): any;
29
+ fitHeight(height: any, object: any): any;
30
+ };
31
+ extent: any;
32
+ minZoom?: number;
33
+ maxZoom?: number;
34
+ padding?: {
35
+ top: number;
36
+ right: number;
37
+ bottom: number;
38
+ left: number;
39
+ };
40
+ }, debug?: boolean);
41
+ debug: boolean;
42
+ projection: {
43
+ (p: any): number[];
44
+ invert(p: any): number[];
45
+ stream(stream: any): any;
46
+ postclip(_: any, ...args: any[]): any;
47
+ clipExtent(_: any, ...args: any[]): any[][] | any;
48
+ scale(_: any, ...args: any[]): number | any;
49
+ translate(_: any, ...args: any[]): number[] | any;
50
+ angle(_: any, ...args: any[]): number | any;
51
+ reflectX(_: any, ...args: any[]): boolean | any;
52
+ reflectY(_: any, ...args: any[]): boolean | any;
53
+ fitExtent(extent: any, object: any): any;
54
+ fitSize(size: any, object: any): any;
55
+ fitWidth(width: any, object: any): any;
56
+ fitHeight(height: any, object: any): any;
57
+ };
58
+ extent: any;
59
+ minZoom: number;
60
+ maxZoom: number;
61
+ _transform: ZoomTransform;
62
+ _padding: {
63
+ top: number;
64
+ right: number;
65
+ bottom: number;
66
+ left: number;
67
+ };
68
+ _viewPortSize: number[];
69
+ pixelRatio: number;
70
+ set viewPortSize(size: number[]);
71
+ get viewPortSize(): number[];
72
+ set transform(transform: ZoomTransform);
73
+ get transform(): ZoomTransform;
74
+ get mapSize(): any;
75
+ get padding(): {
76
+ top: number;
77
+ right: number;
78
+ bottom: number;
79
+ left: number;
80
+ };
81
+ get scaledPadding(): {
82
+ top: number;
83
+ right: number;
84
+ bottom: number;
85
+ left: number;
86
+ };
87
+ get baseResolution(): number;
88
+ get scaleExtent(): number[];
89
+ setProjection(projection: any): void;
90
+ setRawProjection(projection: any): void;
91
+ fitExtent(extent: any): void;
92
+ fitObject(geoJSON: any): void;
93
+ boundsForExtent(extent: any): number[][];
94
+ invert(point: any): number[];
95
+ invertBounds(bounds: any): number[][];
96
+ getResolution(): number;
97
+ getZoomLevel(): number;
98
+ /**
99
+ * Function that returns the extent of the view in screen coordinates
100
+ * The extent is defined as [[minX, minY], [maxX, maxY]]
101
+ * @function getMapExtent
102
+ * @returns {[[number, number], [number, number]]}
103
+ */
104
+ getMapExtent(): [[number, number], [number, number]];
105
+ getVisibleExtent(transform: any, projection: any): any[];
106
+ getState(): {
107
+ transform: ZoomTransform;
108
+ projection: {
109
+ (p: any): number[];
110
+ invert(p: any): number[];
111
+ stream(stream: any): any;
112
+ postclip(_: any, ...args: any[]): any;
113
+ clipExtent(_: any, ...args: any[]): any[][] | any;
114
+ scale(_: any, ...args: any[]): number | any;
115
+ translate(_: any, ...args: any[]): number[] | any;
116
+ angle(_: any, ...args: any[]): number | any;
117
+ reflectX(_: any, ...args: any[]): boolean | any;
118
+ reflectY(_: any, ...args: any[]): boolean | any;
119
+ fitExtent(extent: any, object: any): any;
120
+ fitSize(size: any, object: any): any;
121
+ fitWidth(width: any, object: any): any;
122
+ fitHeight(height: any, object: any): any;
123
+ };
124
+ zoomLevel: any;
125
+ pixelRatio: number;
126
+ padding: {
127
+ top: number;
128
+ right: number;
129
+ bottom: number;
130
+ left: number;
131
+ };
132
+ viewPortSize: number[];
133
+ sizeInPixels: any;
134
+ visibleExtent: any[];
135
+ };
136
+ }
@@ -0,0 +1,179 @@
1
+ import { scaleSize, scalePadding, sizeMinusPadding } from "./util/size.js";
2
+ import { bboxFeature } from "./util/bboxFeature.js";
3
+ import { zoomIdentity, ZoomTransform } from "d3-zoom";
4
+ import { zoomLevelToZoomScale, zoomLevelForResolution } from "./util/zoomLevel.js";
5
+ import { resolutionForExtent } from "./util/resolution.js";
6
+ import { Projection } from "./projection/index.js";
7
+ import { generateDebugUrl } from "./util/debug.js";
8
+ class View {
9
+ constructor({
10
+ projection = Projection.geoIdentity,
11
+ extent,
12
+ minZoom = 1,
13
+ maxZoom = 10,
14
+ padding = { top: 0, right: 0, bottom: 0, left: 0 }
15
+ }, debug = false) {
16
+ this.debug = debug;
17
+ projection.revision = 0;
18
+ this.projection = projection;
19
+ this.extent = extent;
20
+ this.minZoom = minZoom;
21
+ this.maxZoom = maxZoom;
22
+ this._transform = zoomIdentity;
23
+ this._padding = padding;
24
+ this._viewPortSize = [0, 0];
25
+ this.pixelRatio = window.devicePixelRatio;
26
+ }
27
+ set viewPortSize(size) {
28
+ const previousSize = this._viewPortSize;
29
+ this._viewPortSize = size;
30
+ if (previousSize !== size) {
31
+ if (this.extent) {
32
+ this.fitExtent(this.extent);
33
+ }
34
+ }
35
+ }
36
+ get viewPortSize() {
37
+ return this._viewPortSize;
38
+ }
39
+ set transform(transform) {
40
+ this._transform = transform;
41
+ }
42
+ get transform() {
43
+ return new ZoomTransform(
44
+ this._transform.k,
45
+ this._transform.x * this.pixelRatio,
46
+ this._transform.y * this.pixelRatio
47
+ );
48
+ }
49
+ // map size in pixels (i.e. scaled by device pixel ratio)
50
+ get mapSize() {
51
+ return scaleSize(this.viewPortSize, this.pixelRatio);
52
+ }
53
+ get padding() {
54
+ return this._padding;
55
+ }
56
+ // padding in pixels (i.e. scaled by device pixel ratio)
57
+ get scaledPadding() {
58
+ const scaledPadding = { ...this._padding };
59
+ return scalePadding(scaledPadding, this.pixelRatio);
60
+ }
61
+ get baseResolution() {
62
+ const baseExtent = this.getVisibleExtent(zoomIdentity, this.projection);
63
+ const baseResolution = resolutionForExtent(baseExtent, this.viewPortSize);
64
+ return baseResolution;
65
+ }
66
+ // calculates the upper and lower zoom scales
67
+ get scaleExtent() {
68
+ const maxScale = zoomLevelToZoomScale(this.maxZoom, this.baseResolution);
69
+ return [1, maxScale];
70
+ }
71
+ setProjection(projection) {
72
+ this.projection = projection;
73
+ this.fitObject(bboxFeature(this.extent));
74
+ }
75
+ // only set the raw projection when it has already been configured with projection.fitExtent()
76
+ setRawProjection(projection) {
77
+ this.projection = projection;
78
+ }
79
+ fitExtent(extent) {
80
+ const extentFeature = bboxFeature(extent);
81
+ this.fitObject(extentFeature);
82
+ if (this.debug) {
83
+ console.log("Fit extent", extent, generateDebugUrl(extentFeature, false));
84
+ }
85
+ }
86
+ fitObject(geoJSON) {
87
+ this.projection.fitExtent(this.getMapExtent(), geoJSON);
88
+ ++this.projection.revision;
89
+ }
90
+ // returns bounds relative to the viewport
91
+ boundsForExtent(extent) {
92
+ const SW = this.projection([extent[0], extent[1]]);
93
+ const NE = this.projection([extent[2], extent[3]]);
94
+ const minX = SW[0] / this.pixelRatio;
95
+ const minY = NE[1] / this.pixelRatio;
96
+ const maxX = NE[0] / this.pixelRatio;
97
+ const maxY = SW[1] / this.pixelRatio;
98
+ const width = maxX - minX;
99
+ const height = maxY - minY;
100
+ return [
101
+ [minX, minY],
102
+ [width, height]
103
+ ];
104
+ }
105
+ invert(point) {
106
+ const { projection, pixelRatio, transform } = this.getState();
107
+ const scaledPoint = [point[0] * pixelRatio, point[1] * pixelRatio];
108
+ const untransformedPoint = transform.invert(scaledPoint);
109
+ const mapCoordinate = projection.invert(untransformedPoint);
110
+ return mapCoordinate;
111
+ }
112
+ // bounds is defined as [[minX, minY], [maxX, maxY]]
113
+ invertBounds(bounds) {
114
+ const topLeft = bounds[0];
115
+ const topRight = [bounds[1][0], bounds[0][1]];
116
+ const bottomRight = [bounds[1][0], bounds[1][1]];
117
+ const bottomLeft = [bounds[0][0], bounds[1][1]];
118
+ const points = [topLeft, topRight, bottomRight, bottomLeft, topLeft];
119
+ return points.map((d) => this.invert(d));
120
+ }
121
+ // map resolution (meters per pixel)
122
+ getResolution() {
123
+ return resolutionForExtent(
124
+ this.getVisibleExtent(this.transform, this.projection),
125
+ this.viewPortSize
126
+ );
127
+ }
128
+ // map zoom level (0 = the entire world)
129
+ getZoomLevel() {
130
+ return zoomLevelForResolution(this.getResolution());
131
+ }
132
+ //
133
+ /**
134
+ * Function that returns the extent of the view in screen coordinates
135
+ * The extent is defined as [[minX, minY], [maxX, maxY]]
136
+ * @function getMapExtent
137
+ * @returns {[[number, number], [number, number]]}
138
+ */
139
+ getMapExtent() {
140
+ const mapSizeInPixels = this.mapSize;
141
+ const paddingInPixels = this.scaledPadding;
142
+ return [
143
+ [paddingInPixels.left, paddingInPixels.top],
144
+ sizeMinusPadding(mapSizeInPixels, {
145
+ ...paddingInPixels,
146
+ left: 0,
147
+ top: 0
148
+ })
149
+ ];
150
+ }
151
+ // visible extent in map coordinates
152
+ getVisibleExtent(transform, projection) {
153
+ if (this.projection === Projection.geoIdentity) {
154
+ const [width2, height2] = this.mapSize;
155
+ return [0, 0, width2, height2];
156
+ }
157
+ const [width, height] = this.mapSize;
158
+ const southWest = projection.invert(transform.invert([0, height]));
159
+ const northEast = projection.invert(transform.invert([width, 0]));
160
+ return [southWest[0], southWest[1], northEast[0], northEast[1]];
161
+ }
162
+ getState() {
163
+ const transform = this.transform;
164
+ const projection = this.projection;
165
+ return {
166
+ transform,
167
+ projection,
168
+ zoomLevel: transform.k,
169
+ pixelRatio: this.pixelRatio,
170
+ padding: this.padding,
171
+ viewPortSize: this.viewPortSize,
172
+ sizeInPixels: scaleSize(this.viewPortSize, this.pixelRatio),
173
+ visibleExtent: this.getVisibleExtent(transform, projection)
174
+ };
175
+ }
176
+ }
177
+ export {
178
+ View
179
+ };
@@ -0,0 +1,8 @@
1
+ export class Dispatcher {
2
+ constructor(target: any);
3
+ _listenersByEvent: Map<any, any>;
4
+ target: any;
5
+ on(eventType: any, callback: any): string;
6
+ unsubscribe(eventType: any, listenerKey: any): void;
7
+ dispatch(eventType: any, payload: any): void;
8
+ }
@@ -0,0 +1,35 @@
1
+ import { createUid } from "../util/uid.js";
2
+ class Dispatcher {
3
+ constructor(target) {
4
+ this._listenersByEvent = /* @__PURE__ */ new Map();
5
+ this.target = target;
6
+ target.on = this.on.bind(this);
7
+ target.unsubscribe = this.unsubscribe.bind(this);
8
+ }
9
+ on(eventType, callback) {
10
+ let listenersForEvent = this._listenersByEvent.get(eventType);
11
+ if (!listenersForEvent) {
12
+ listenersForEvent = /* @__PURE__ */ new Map();
13
+ this._listenersByEvent.set(eventType, listenersForEvent);
14
+ }
15
+ const uid = createUid();
16
+ listenersForEvent.set(uid, callback);
17
+ return uid;
18
+ }
19
+ unsubscribe(eventType, listenerKey) {
20
+ const listenersForEvent = this._listenersByEvent.get(eventType);
21
+ if (!listenersForEvent) return;
22
+ if (!listenersForEvent.has(listenerKey)) return;
23
+ listenersForEvent.delete(listenerKey);
24
+ }
25
+ dispatch(eventType, payload) {
26
+ const listenersForEvent = this._listenersByEvent.get(eventType);
27
+ if (!listenersForEvent) return;
28
+ listenersForEvent.forEach((callback) => {
29
+ callback(this.target, payload);
30
+ });
31
+ }
32
+ }
33
+ export {
34
+ Dispatcher
35
+ };
@@ -0,0 +1,6 @@
1
+ export namespace MapEvent {
2
+ let CHANGE: string;
3
+ let ZOOM: string;
4
+ let TRANSITION_START: string;
5
+ let TRANSITION_END: string;
6
+ }
@@ -0,0 +1,9 @@
1
+ const MapEvent = {
2
+ CHANGE: "change",
3
+ ZOOM: "zoom",
4
+ TRANSITION_START: "transition_start",
5
+ TRANSITION_END: "transition_end"
6
+ };
7
+ export {
8
+ MapEvent
9
+ };
@@ -0,0 +1,2 @@
1
+ export * from './Dispatcher';
2
+ export * from './MapEvent';
@@ -0,0 +1,10 @@
1
+ import { Feature } from '../Feature';
2
+ import { LineString, Polygon, Point } from '../geometry';
3
+ export class GeoJSON {
4
+ readFeaturesFromObject(object: any): Feature[];
5
+ readFeatureFromObject(geoJSONObject: any): Feature;
6
+ readGeometriesFromObject(geometry: any): (LineString | Polygon | Point)[];
7
+ readPolygonForCoordinates(coordinates: any): Polygon;
8
+ readLineStringForCoordinates(coordinates: any): LineString;
9
+ readPointForCoordinates(coordinates: any): Point;
10
+ }