mapbox-gl 1.13.2

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 (460) hide show
  1. package/.flowconfig +61 -0
  2. package/CHANGELOG.md +2485 -0
  3. package/LICENSE.txt +84 -0
  4. package/README.md +34 -0
  5. package/build/banner.js +4 -0
  6. package/build/check-bundle-size.js +140 -0
  7. package/build/diff-tarball.js +18 -0
  8. package/build/generate-access-token-script.js +11 -0
  9. package/build/generate-flow-typed-style-spec.js +188 -0
  10. package/build/generate-release-list.js +21 -0
  11. package/build/generate-struct-arrays.js +243 -0
  12. package/build/generate-style-code.js +159 -0
  13. package/build/mapbox-gl.js.flow +3 -0
  14. package/build/print-release-url.js +6 -0
  15. package/build/rollup_plugin_minify_style_spec.js +24 -0
  16. package/build/rollup_plugins.js +80 -0
  17. package/build/run-node +3 -0
  18. package/build/run-tap +8 -0
  19. package/build/test/build-tape.js +19 -0
  20. package/dist/mapbox-gl-csp-worker.js +2 -0
  21. package/dist/mapbox-gl-csp-worker.js.map +1 -0
  22. package/dist/mapbox-gl-csp.js +2 -0
  23. package/dist/mapbox-gl-csp.js.map +1 -0
  24. package/dist/mapbox-gl-dev.js +65889 -0
  25. package/dist/mapbox-gl-dev.js.flow +3 -0
  26. package/dist/mapbox-gl-unminified.js +42889 -0
  27. package/dist/mapbox-gl-unminified.js.map +1 -0
  28. package/dist/mapbox-gl.css +1 -0
  29. package/dist/mapbox-gl.js +42 -0
  30. package/dist/mapbox-gl.js.flow +3 -0
  31. package/dist/mapbox-gl.js.map +1 -0
  32. package/dist/style-spec/index.es.js +15032 -0
  33. package/dist/style-spec/index.es.js.map +1 -0
  34. package/dist/style-spec/index.js +15058 -0
  35. package/dist/style-spec/index.js.map +1 -0
  36. package/flow-typed/gl.js +5 -0
  37. package/flow-typed/jsdom.js +18 -0
  38. package/flow-typed/mapbox-gl-supported.js +9 -0
  39. package/flow-typed/mapbox-unitbezier.js +14 -0
  40. package/flow-typed/offscreen-canvas.js +9 -0
  41. package/flow-typed/pbf.js +25 -0
  42. package/flow-typed/point-geometry.js +44 -0
  43. package/flow-typed/potpack.js +12 -0
  44. package/flow-typed/sinon.js +28 -0
  45. package/flow-typed/vector-tile.js +41 -0
  46. package/package.json +173 -0
  47. package/src/css/mapbox-gl.css +812 -0
  48. package/src/css/svg/mapboxgl-ctrl-attrib.svg +3 -0
  49. package/src/css/svg/mapboxgl-ctrl-compass.svg +4 -0
  50. package/src/css/svg/mapboxgl-ctrl-fullscreen.svg +3 -0
  51. package/src/css/svg/mapboxgl-ctrl-geolocate.svg +5 -0
  52. package/src/css/svg/mapboxgl-ctrl-logo.svg +20 -0
  53. package/src/css/svg/mapboxgl-ctrl-shrink.svg +3 -0
  54. package/src/css/svg/mapboxgl-ctrl-zoom-in.svg +3 -0
  55. package/src/css/svg/mapboxgl-ctrl-zoom-out.svg +3 -0
  56. package/src/data/array_types.js +1135 -0
  57. package/src/data/bucket/circle_attributes.js +9 -0
  58. package/src/data/bucket/circle_bucket.js +201 -0
  59. package/src/data/bucket/fill_attributes.js +9 -0
  60. package/src/data/bucket/fill_bucket.js +229 -0
  61. package/src/data/bucket/fill_extrusion_attributes.js +10 -0
  62. package/src/data/bucket/fill_extrusion_bucket.js +283 -0
  63. package/src/data/bucket/heatmap_bucket.js +17 -0
  64. package/src/data/bucket/line_attributes.js +10 -0
  65. package/src/data/bucket/line_attributes_ext.js +10 -0
  66. package/src/data/bucket/line_bucket.js +594 -0
  67. package/src/data/bucket/pattern_attributes.js +12 -0
  68. package/src/data/bucket/pattern_bucket_features.js +60 -0
  69. package/src/data/bucket/symbol_attributes.js +117 -0
  70. package/src/data/bucket/symbol_bucket.js +937 -0
  71. package/src/data/bucket.js +123 -0
  72. package/src/data/dem_data.js +125 -0
  73. package/src/data/evaluation_feature.js +25 -0
  74. package/src/data/extent.js +18 -0
  75. package/src/data/feature_index.js +322 -0
  76. package/src/data/feature_position_map.js +131 -0
  77. package/src/data/index_array_type.js +16 -0
  78. package/src/data/load_geometry.js +46 -0
  79. package/src/data/pos_attributes.js +6 -0
  80. package/src/data/program_configuration.js +708 -0
  81. package/src/data/raster_bounds_attributes.js +7 -0
  82. package/src/data/segment.js +76 -0
  83. package/src/geo/edge_insets.js +102 -0
  84. package/src/geo/lng_lat.js +168 -0
  85. package/src/geo/lng_lat_bounds.js +276 -0
  86. package/src/geo/mercator_coordinate.js +150 -0
  87. package/src/geo/transform.js +834 -0
  88. package/src/gl/color_mode.js +34 -0
  89. package/src/gl/context.js +302 -0
  90. package/src/gl/cull_face_mode.js +26 -0
  91. package/src/gl/depth_mode.js +29 -0
  92. package/src/gl/framebuffer.js +44 -0
  93. package/src/gl/index_buffer.js +55 -0
  94. package/src/gl/stencil_mode.js +30 -0
  95. package/src/gl/types.js +84 -0
  96. package/src/gl/value.js +520 -0
  97. package/src/gl/vertex_buffer.js +119 -0
  98. package/src/index.js +230 -0
  99. package/src/render/draw_background.js +57 -0
  100. package/src/render/draw_circle.js +113 -0
  101. package/src/render/draw_collision_debug.js +172 -0
  102. package/src/render/draw_custom.js +49 -0
  103. package/src/render/draw_debug.js +127 -0
  104. package/src/render/draw_fill.js +124 -0
  105. package/src/render/draw_fill_extrusion.js +95 -0
  106. package/src/render/draw_heatmap.js +133 -0
  107. package/src/render/draw_hillshade.js +107 -0
  108. package/src/render/draw_line.js +125 -0
  109. package/src/render/draw_raster.js +125 -0
  110. package/src/render/draw_symbol.js +392 -0
  111. package/src/render/glyph_atlas.js +71 -0
  112. package/src/render/glyph_manager.js +182 -0
  113. package/src/render/image_atlas.js +149 -0
  114. package/src/render/image_manager.js +306 -0
  115. package/src/render/line_atlas.js +210 -0
  116. package/src/render/painter.js +654 -0
  117. package/src/render/program/background_program.js +103 -0
  118. package/src/render/program/circle_program.js +69 -0
  119. package/src/render/program/clipping_mask_program.js +20 -0
  120. package/src/render/program/collision_program.js +76 -0
  121. package/src/render/program/debug_program.js +35 -0
  122. package/src/render/program/fill_extrusion_program.js +122 -0
  123. package/src/render/program/fill_program.js +126 -0
  124. package/src/render/program/heatmap_program.js +83 -0
  125. package/src/render/program/hillshade_program.js +119 -0
  126. package/src/render/program/line_program.js +211 -0
  127. package/src/render/program/pattern.js +102 -0
  128. package/src/render/program/program_uniforms.js +42 -0
  129. package/src/render/program/raster_program.js +92 -0
  130. package/src/render/program/symbol_program.js +224 -0
  131. package/src/render/program.js +188 -0
  132. package/src/render/texture.js +122 -0
  133. package/src/render/uniform_binding.js +147 -0
  134. package/src/render/vertex_array_object.js +163 -0
  135. package/src/shaders/README.md +42 -0
  136. package/src/shaders/_prelude.fragment.glsl +17 -0
  137. package/src/shaders/_prelude.vertex.glsl +73 -0
  138. package/src/shaders/background.fragment.glsl +10 -0
  139. package/src/shaders/background.vertex.glsl +7 -0
  140. package/src/shaders/background_pattern.fragment.glsl +28 -0
  141. package/src/shaders/background_pattern.vertex.glsl +20 -0
  142. package/src/shaders/circle.fragment.glsl +39 -0
  143. package/src/shaders/circle.vertex.glsl +64 -0
  144. package/src/shaders/clipping_mask.fragment.glsl +3 -0
  145. package/src/shaders/clipping_mask.vertex.glsl +7 -0
  146. package/src/shaders/collision_box.fragment.glsl +21 -0
  147. package/src/shaders/collision_box.vertex.glsl +27 -0
  148. package/src/shaders/collision_circle.fragment.glsl +17 -0
  149. package/src/shaders/collision_circle.vertex.glsl +59 -0
  150. package/src/shaders/debug.fragment.glsl +9 -0
  151. package/src/shaders/debug.vertex.glsl +12 -0
  152. package/src/shaders/encode_attribute.js +17 -0
  153. package/src/shaders/fill.fragment.glsl +13 -0
  154. package/src/shaders/fill.vertex.glsl +13 -0
  155. package/src/shaders/fill_extrusion.fragment.glsl +9 -0
  156. package/src/shaders/fill_extrusion.vertex.glsl +66 -0
  157. package/src/shaders/fill_extrusion_pattern.fragment.glsl +45 -0
  158. package/src/shaders/fill_extrusion_pattern.vertex.glsl +79 -0
  159. package/src/shaders/fill_outline.fragment.glsl +17 -0
  160. package/src/shaders/fill_outline.vertex.glsl +17 -0
  161. package/src/shaders/fill_outline_pattern.fragment.glsl +43 -0
  162. package/src/shaders/fill_outline_pattern.vertex.glsl +44 -0
  163. package/src/shaders/fill_pattern.fragment.glsl +36 -0
  164. package/src/shaders/fill_pattern.vertex.glsl +39 -0
  165. package/src/shaders/heatmap.fragment.glsl +22 -0
  166. package/src/shaders/heatmap.vertex.glsl +54 -0
  167. package/src/shaders/heatmap_texture.fragment.glsl +14 -0
  168. package/src/shaders/heatmap_texture.vertex.glsl +11 -0
  169. package/src/shaders/hillshade.fragment.glsl +52 -0
  170. package/src/shaders/hillshade.vertex.glsl +11 -0
  171. package/src/shaders/hillshade_prepare.fragment.glsl +75 -0
  172. package/src/shaders/hillshade_prepare.vertex.glsl +15 -0
  173. package/src/shaders/index.js +20 -0
  174. package/src/shaders/line.fragment.glsl +30 -0
  175. package/src/shaders/line.vertex.glsl +85 -0
  176. package/src/shaders/line_gradient.fragment.glsl +34 -0
  177. package/src/shaders/line_gradient.vertex.glsl +88 -0
  178. package/src/shaders/line_pattern.fragment.glsl +74 -0
  179. package/src/shaders/line_pattern.vertex.glsl +99 -0
  180. package/src/shaders/line_sdf.fragment.glsl +45 -0
  181. package/src/shaders/line_sdf.vertex.glsl +98 -0
  182. package/src/shaders/raster.fragment.glsl +52 -0
  183. package/src/shaders/raster.vertex.glsl +21 -0
  184. package/src/shaders/shaders.js +185 -0
  185. package/src/shaders/symbol_icon.fragment.glsl +17 -0
  186. package/src/shaders/symbol_icon.vertex.glsl +94 -0
  187. package/src/shaders/symbol_sdf.fragment.glsl +52 -0
  188. package/src/shaders/symbol_sdf.vertex.glsl +115 -0
  189. package/src/shaders/symbol_text_and_icon.fragment.glsl +68 -0
  190. package/src/shaders/symbol_text_and_icon.vertex.glsl +116 -0
  191. package/src/source/canvas_source.js +238 -0
  192. package/src/source/geojson_source.js +370 -0
  193. package/src/source/geojson_worker_source.js +366 -0
  194. package/src/source/geojson_wrapper.js +94 -0
  195. package/src/source/image_source.js +307 -0
  196. package/src/source/load_tilejson.js +39 -0
  197. package/src/source/pixels_to_tile_units.js +21 -0
  198. package/src/source/query_features.js +208 -0
  199. package/src/source/raster_dem_tile_source.js +138 -0
  200. package/src/source/raster_dem_tile_worker_source.js +62 -0
  201. package/src/source/raster_tile_source.js +169 -0
  202. package/src/source/rtl_text_plugin.js +143 -0
  203. package/src/source/source.js +137 -0
  204. package/src/source/source_cache.js +953 -0
  205. package/src/source/source_state.js +159 -0
  206. package/src/source/tile.js +458 -0
  207. package/src/source/tile_bounds.js +38 -0
  208. package/src/source/tile_cache.js +212 -0
  209. package/src/source/tile_id.js +199 -0
  210. package/src/source/vector_tile_source.js +259 -0
  211. package/src/source/vector_tile_worker_source.js +216 -0
  212. package/src/source/video_source.js +203 -0
  213. package/src/source/worker.js +240 -0
  214. package/src/source/worker_source.js +107 -0
  215. package/src/source/worker_tile.js +224 -0
  216. package/src/style/create_style_layer.js +36 -0
  217. package/src/style/evaluation_parameters.js +62 -0
  218. package/src/style/format_section_override.js +56 -0
  219. package/src/style/light.js +130 -0
  220. package/src/style/load_glyph_range.js +38 -0
  221. package/src/style/load_sprite.js +67 -0
  222. package/src/style/parse_glyph_pbf.js +44 -0
  223. package/src/style/pauseable_placement.js +132 -0
  224. package/src/style/properties.js +753 -0
  225. package/src/style/query_utils.js +43 -0
  226. package/src/style/style.js +1374 -0
  227. package/src/style/style_glyph.js +17 -0
  228. package/src/style/style_image.js +137 -0
  229. package/src/style/style_layer/background_style_layer.js +21 -0
  230. package/src/style/style_layer/background_style_layer_properties.js +40 -0
  231. package/src/style/style_layer/circle_style_layer.js +98 -0
  232. package/src/style/style_layer/circle_style_layer_properties.js +63 -0
  233. package/src/style/style_layer/custom_style_layer.js +223 -0
  234. package/src/style/style_layer/fill_extrusion_style_layer.js +224 -0
  235. package/src/style/style_layer/fill_extrusion_style_layer_properties.js +50 -0
  236. package/src/style/style_layer/fill_style_layer.js +67 -0
  237. package/src/style/style_layer/fill_style_layer_properties.js +55 -0
  238. package/src/style/style_layer/heatmap_style_layer.js +73 -0
  239. package/src/style/style_layer/heatmap_style_layer_properties.js +44 -0
  240. package/src/style/style_layer/hillshade_style_layer.js +25 -0
  241. package/src/style/style_layer/hillshade_style_layer_properties.js +46 -0
  242. package/src/style/style_layer/layer_properties.js.ejs +69 -0
  243. package/src/style/style_layer/line_style_layer.js +150 -0
  244. package/src/style/style_layer/line_style_layer_properties.js +71 -0
  245. package/src/style/style_layer/raster_style_layer.js +21 -0
  246. package/src/style/style_layer/raster_style_layer_properties.js +50 -0
  247. package/src/style/style_layer/symbol_style_layer.js +190 -0
  248. package/src/style/style_layer/symbol_style_layer_properties.js +153 -0
  249. package/src/style/style_layer/typed_style_layer.js +17 -0
  250. package/src/style/style_layer.js +283 -0
  251. package/src/style/style_layer_index.js +80 -0
  252. package/src/style/validate_style.js +42 -0
  253. package/src/style/zoom_history.js +44 -0
  254. package/src/style-spec/.eslintrc +5 -0
  255. package/src/style-spec/CHANGELOG.md +468 -0
  256. package/src/style-spec/README.md +59 -0
  257. package/src/style-spec/bin/gl-style-composite +9 -0
  258. package/src/style-spec/bin/gl-style-format +22 -0
  259. package/src/style-spec/bin/gl-style-migrate +9 -0
  260. package/src/style-spec/bin/gl-style-validate +50 -0
  261. package/src/style-spec/composite.js +50 -0
  262. package/src/style-spec/declass.js +42 -0
  263. package/src/style-spec/deref.js +52 -0
  264. package/src/style-spec/diff.js +393 -0
  265. package/src/style-spec/dist/.gitkeep +0 -0
  266. package/src/style-spec/dist/index.es.js +15032 -0
  267. package/src/style-spec/dist/index.es.js.map +1 -0
  268. package/src/style-spec/dist/index.js +15058 -0
  269. package/src/style-spec/dist/index.js.map +1 -0
  270. package/src/style-spec/empty.js +29 -0
  271. package/src/style-spec/error/parsing_error.js +16 -0
  272. package/src/style-spec/error/validation_error.js +18 -0
  273. package/src/style-spec/expression/compound_expression.js +162 -0
  274. package/src/style-spec/expression/definitions/assertion.js +130 -0
  275. package/src/style-spec/expression/definitions/at.js +70 -0
  276. package/src/style-spec/expression/definitions/case.js +85 -0
  277. package/src/style-spec/expression/definitions/coalesce.js +93 -0
  278. package/src/style-spec/expression/definitions/coercion.js +133 -0
  279. package/src/style-spec/expression/definitions/collator.js +78 -0
  280. package/src/style-spec/expression/definitions/comparison.js +184 -0
  281. package/src/style-spec/expression/definitions/format.js +144 -0
  282. package/src/style-spec/expression/definitions/image.js +52 -0
  283. package/src/style-spec/expression/definitions/in.js +72 -0
  284. package/src/style-spec/expression/definitions/index.js +565 -0
  285. package/src/style-spec/expression/definitions/index_of.js +89 -0
  286. package/src/style-spec/expression/definitions/interpolate.js +267 -0
  287. package/src/style-spec/expression/definitions/length.js +61 -0
  288. package/src/style-spec/expression/definitions/let.js +72 -0
  289. package/src/style-spec/expression/definitions/literal.js +77 -0
  290. package/src/style-spec/expression/definitions/match.js +158 -0
  291. package/src/style-spec/expression/definitions/number_format.js +142 -0
  292. package/src/style-spec/expression/definitions/slice.js +86 -0
  293. package/src/style-spec/expression/definitions/step.js +120 -0
  294. package/src/style-spec/expression/definitions/var.js +46 -0
  295. package/src/style-spec/expression/definitions/within.js +342 -0
  296. package/src/style-spec/expression/evaluation_context.js +59 -0
  297. package/src/style-spec/expression/expression.js +27 -0
  298. package/src/style-spec/expression/index.js +392 -0
  299. package/src/style-spec/expression/is_constant.js +59 -0
  300. package/src/style-spec/expression/parsing_context.js +233 -0
  301. package/src/style-spec/expression/parsing_error.js +13 -0
  302. package/src/style-spec/expression/runtime_error.js +17 -0
  303. package/src/style-spec/expression/scope.js +36 -0
  304. package/src/style-spec/expression/stops.js +39 -0
  305. package/src/style-spec/expression/types/collator.js +61 -0
  306. package/src/style-spec/expression/types/formatted.js +73 -0
  307. package/src/style-spec/expression/types/resolved_image.js +29 -0
  308. package/src/style-spec/expression/types.js +126 -0
  309. package/src/style-spec/expression/values.js +123 -0
  310. package/src/style-spec/feature_filter/README.md +55 -0
  311. package/src/style-spec/feature_filter/convert.js +208 -0
  312. package/src/style-spec/feature_filter/index.js +175 -0
  313. package/src/style-spec/format.js +51 -0
  314. package/src/style-spec/function/convert.js +270 -0
  315. package/src/style-spec/function/index.js +262 -0
  316. package/src/style-spec/group_by_layout.js +75 -0
  317. package/src/style-spec/migrate/expressions.js +39 -0
  318. package/src/style-spec/migrate/v8.js +203 -0
  319. package/src/style-spec/migrate/v9.js +26 -0
  320. package/src/style-spec/migrate.js +36 -0
  321. package/src/style-spec/package.json +41 -0
  322. package/src/style-spec/read_style.js +14 -0
  323. package/src/style-spec/reference/latest.js +3 -0
  324. package/src/style-spec/reference/v8.json +5914 -0
  325. package/src/style-spec/rollup.config.js +65 -0
  326. package/src/style-spec/style-spec.js +124 -0
  327. package/src/style-spec/types.js +432 -0
  328. package/src/style-spec/util/color.js +95 -0
  329. package/src/style-spec/util/color_spaces.js +139 -0
  330. package/src/style-spec/util/deep_equal.js +28 -0
  331. package/src/style-spec/util/extend.js +10 -0
  332. package/src/style-spec/util/get_type.js +17 -0
  333. package/src/style-spec/util/interpolate.js +22 -0
  334. package/src/style-spec/util/properties.js +15 -0
  335. package/src/style-spec/util/ref_properties.js +2 -0
  336. package/src/style-spec/util/result.js +19 -0
  337. package/src/style-spec/util/unbundle_jsonlint.js +24 -0
  338. package/src/style-spec/validate/latest.js +11 -0
  339. package/src/style-spec/validate/validate.js +75 -0
  340. package/src/style-spec/validate/validate_array.js +52 -0
  341. package/src/style-spec/validate/validate_boolean.js +15 -0
  342. package/src/style-spec/validate/validate_color.js +20 -0
  343. package/src/style-spec/validate/validate_constants.js +13 -0
  344. package/src/style-spec/validate/validate_enum.js +21 -0
  345. package/src/style-spec/validate/validate_expression.js +43 -0
  346. package/src/style-spec/validate/validate_filter.js +117 -0
  347. package/src/style-spec/validate/validate_formatted.js +11 -0
  348. package/src/style-spec/validate/validate_function.js +207 -0
  349. package/src/style-spec/validate/validate_glyphs_url.js +21 -0
  350. package/src/style-spec/validate/validate_image.js +11 -0
  351. package/src/style-spec/validate/validate_layer.js +134 -0
  352. package/src/style-spec/validate/validate_layout_property.js +6 -0
  353. package/src/style-spec/validate/validate_light.js +47 -0
  354. package/src/style-spec/validate/validate_number.js +29 -0
  355. package/src/style-spec/validate/validate_object.js +61 -0
  356. package/src/style-spec/validate/validate_paint_property.js +6 -0
  357. package/src/style-spec/validate/validate_property.js +64 -0
  358. package/src/style-spec/validate/validate_source.js +111 -0
  359. package/src/style-spec/validate/validate_string.js +15 -0
  360. package/src/style-spec/validate_mapbox_api_supported.js +171 -0
  361. package/src/style-spec/validate_style.js +39 -0
  362. package/src/style-spec/validate_style.min.js +78 -0
  363. package/src/style-spec/visit.js +77 -0
  364. package/src/symbol/anchor.js +26 -0
  365. package/src/symbol/check_max_angle.js +81 -0
  366. package/src/symbol/clip_line.js +71 -0
  367. package/src/symbol/collision_feature.js +109 -0
  368. package/src/symbol/collision_index.js +373 -0
  369. package/src/symbol/cross_tile_symbol_index.js +301 -0
  370. package/src/symbol/get_anchors.js +167 -0
  371. package/src/symbol/grid_index.js +335 -0
  372. package/src/symbol/mergelines.js +82 -0
  373. package/src/symbol/one_em.js +4 -0
  374. package/src/symbol/opacity_state.js +27 -0
  375. package/src/symbol/path_interpolator.js +61 -0
  376. package/src/symbol/placement.js +1124 -0
  377. package/src/symbol/projection.js +451 -0
  378. package/src/symbol/quads.js +334 -0
  379. package/src/symbol/shaping.js +816 -0
  380. package/src/symbol/symbol_layout.js +796 -0
  381. package/src/symbol/symbol_size.js +113 -0
  382. package/src/symbol/transform_text.js +29 -0
  383. package/src/types/callback.js +17 -0
  384. package/src/types/cancelable.js +3 -0
  385. package/src/types/tilejson.js +17 -0
  386. package/src/types/transferable.js +3 -0
  387. package/src/types/window.js +172 -0
  388. package/src/ui/anchor.js +32 -0
  389. package/src/ui/camera.js +1277 -0
  390. package/src/ui/control/attribution_control.js +212 -0
  391. package/src/ui/control/fullscreen_control.js +147 -0
  392. package/src/ui/control/geolocate_control.js +707 -0
  393. package/src/ui/control/logo_control.js +92 -0
  394. package/src/ui/control/navigation_control.js +257 -0
  395. package/src/ui/control/scale_control.js +142 -0
  396. package/src/ui/default_locale.js +22 -0
  397. package/src/ui/events.js +1301 -0
  398. package/src/ui/handler/box_zoom.js +170 -0
  399. package/src/ui/handler/click_zoom.js +52 -0
  400. package/src/ui/handler/handler_util.js +12 -0
  401. package/src/ui/handler/keyboard.js +208 -0
  402. package/src/ui/handler/map_event.js +156 -0
  403. package/src/ui/handler/mouse.js +171 -0
  404. package/src/ui/handler/scroll_zoom.js +350 -0
  405. package/src/ui/handler/shim/dblclick_zoom.js +62 -0
  406. package/src/ui/handler/shim/drag_pan.js +88 -0
  407. package/src/ui/handler/shim/drag_rotate.js +67 -0
  408. package/src/ui/handler/shim/touch_zoom_rotate.js +108 -0
  409. package/src/ui/handler/tap_drag_zoom.js +103 -0
  410. package/src/ui/handler/tap_recognizer.js +133 -0
  411. package/src/ui/handler/tap_zoom.js +93 -0
  412. package/src/ui/handler/touch_pan.js +101 -0
  413. package/src/ui/handler/touch_zoom_rotate.js +305 -0
  414. package/src/ui/handler_inertia.js +158 -0
  415. package/src/ui/handler_manager.js +531 -0
  416. package/src/ui/hash.js +148 -0
  417. package/src/ui/map.js +2874 -0
  418. package/src/ui/marker.js +672 -0
  419. package/src/ui/popup.js +640 -0
  420. package/src/util/actor.js +212 -0
  421. package/src/util/ajax.js +388 -0
  422. package/src/util/browser/web_worker.js +10 -0
  423. package/src/util/browser/window.js +6 -0
  424. package/src/util/browser.js +70 -0
  425. package/src/util/classify_rings.js +52 -0
  426. package/src/util/color_ramp.js +61 -0
  427. package/src/util/config.js +30 -0
  428. package/src/util/debug.js +28 -0
  429. package/src/util/dictionary_coder.js +30 -0
  430. package/src/util/dispatcher.js +70 -0
  431. package/src/util/dom.js +142 -0
  432. package/src/util/evented.js +174 -0
  433. package/src/util/find_pole_of_inaccessibility.js +129 -0
  434. package/src/util/global_worker_pool.js +35 -0
  435. package/src/util/image.js +142 -0
  436. package/src/util/intersection_tests.js +208 -0
  437. package/src/util/is_char_in_unicode_block.js +311 -0
  438. package/src/util/mapbox.js +491 -0
  439. package/src/util/offscreen_canvas_supported.js +14 -0
  440. package/src/util/performance.js +112 -0
  441. package/src/util/primitives.js +145 -0
  442. package/src/util/resolve_tokens.js +16 -0
  443. package/src/util/script_detection.js +328 -0
  444. package/src/util/sku_token.js +42 -0
  445. package/src/util/smart_wrap.js +55 -0
  446. package/src/util/struct_array.js +243 -0
  447. package/src/util/struct_array.js.ejs +112 -0
  448. package/src/util/struct_array_layout.js.ejs +98 -0
  449. package/src/util/task_queue.js +68 -0
  450. package/src/util/throttle.js +27 -0
  451. package/src/util/throttled_invoker.js +46 -0
  452. package/src/util/tile_request_cache.js +172 -0
  453. package/src/util/util.js +524 -0
  454. package/src/util/vectortile_to_geojson.js +50 -0
  455. package/src/util/verticalize_punctuation.js +114 -0
  456. package/src/util/web_worker.js +91 -0
  457. package/src/util/web_worker_transfer.js +266 -0
  458. package/src/util/webp_supported.js +69 -0
  459. package/src/util/window.js +102 -0
  460. package/src/util/worker_pool.js +57 -0
@@ -0,0 +1,212 @@
1
+ // @flow
2
+
3
+ import {bindAll, isWorker, isSafari} from './util';
4
+ import window from './window';
5
+ import {serialize, deserialize} from './web_worker_transfer';
6
+ import ThrottledInvoker from './throttled_invoker';
7
+
8
+ import type {Transferable} from '../types/transferable';
9
+ import type {Cancelable} from '../types/cancelable';
10
+
11
+ /**
12
+ * An implementation of the [Actor design pattern](http://en.wikipedia.org/wiki/Actor_model)
13
+ * that maintains the relationship between asynchronous tasks and the objects
14
+ * that spin them off - in this case, tasks like parsing parts of styles,
15
+ * owned by the styles
16
+ *
17
+ * @param {WebWorker} target
18
+ * @param {WebWorker} parent
19
+ * @param {string|number} mapId A unique identifier for the Map instance using this Actor.
20
+ * @private
21
+ */
22
+ class Actor {
23
+ target: any;
24
+ parent: any;
25
+ mapId: ?number;
26
+ callbacks: { number: any };
27
+ name: string;
28
+ tasks: { number: any };
29
+ taskQueue: Array<number>;
30
+ cancelCallbacks: { number: Cancelable };
31
+ invoker: ThrottledInvoker;
32
+ globalScope: any;
33
+
34
+ constructor(target: any, parent: any, mapId: ?number) {
35
+ this.target = target;
36
+ this.parent = parent;
37
+ this.mapId = mapId;
38
+ this.callbacks = {};
39
+ this.tasks = {};
40
+ this.taskQueue = [];
41
+ this.cancelCallbacks = {};
42
+ bindAll(['receive', 'process'], this);
43
+ this.invoker = new ThrottledInvoker(this.process);
44
+ this.target.addEventListener('message', this.receive, false);
45
+ this.globalScope = isWorker() ? target : window;
46
+ }
47
+
48
+ /**
49
+ * Sends a message from a main-thread map to a Worker or from a Worker back to
50
+ * a main-thread map instance.
51
+ *
52
+ * @param type The name of the target method to invoke or '[source-type].[source-name].name' for a method on a WorkerSource.
53
+ * @param targetMapId A particular mapId to which to send this message.
54
+ * @private
55
+ */
56
+ send(type: string, data: mixed, callback: ?Function, targetMapId: ?string, mustQueue: boolean = false): ?Cancelable {
57
+ // We're using a string ID instead of numbers because they are being used as object keys
58
+ // anyway, and thus stringified implicitly. We use random IDs because an actor may receive
59
+ // message from multiple other actors which could run in different execution context. A
60
+ // linearly increasing ID could produce collisions.
61
+ const id = Math.round((Math.random() * 1e18)).toString(36).substring(0, 10);
62
+ if (callback) {
63
+ this.callbacks[id] = callback;
64
+ }
65
+ const buffers: ?Array<Transferable> = isSafari(this.globalScope) ? undefined : [];
66
+ this.target.postMessage({
67
+ id,
68
+ type,
69
+ hasCallback: !!callback,
70
+ targetMapId,
71
+ mustQueue,
72
+ sourceMapId: this.mapId,
73
+ data: serialize(data, buffers)
74
+ }, buffers);
75
+ return {
76
+ cancel: () => {
77
+ if (callback) {
78
+ // Set the callback to null so that it never fires after the request is aborted.
79
+ delete this.callbacks[id];
80
+ }
81
+ this.target.postMessage({
82
+ id,
83
+ type: '<cancel>',
84
+ targetMapId,
85
+ sourceMapId: this.mapId
86
+ });
87
+ }
88
+ };
89
+ }
90
+
91
+ receive(message: Object) {
92
+ const data = message.data,
93
+ id = data.id;
94
+
95
+ if (!id) {
96
+ return;
97
+ }
98
+
99
+ if (data.targetMapId && this.mapId !== data.targetMapId) {
100
+ return;
101
+ }
102
+
103
+ if (data.type === '<cancel>') {
104
+ // Remove the original request from the queue. This is only possible if it
105
+ // hasn't been kicked off yet. The id will remain in the queue, but because
106
+ // there is no associated task, it will be dropped once it's time to execute it.
107
+ delete this.tasks[id];
108
+ const cancel = this.cancelCallbacks[id];
109
+ delete this.cancelCallbacks[id];
110
+ if (cancel) {
111
+ cancel();
112
+ }
113
+ } else {
114
+ if (isWorker() || data.mustQueue) {
115
+ // In workers, store the tasks that we need to process before actually processing them. This
116
+ // is necessary because we want to keep receiving messages, and in particular,
117
+ // <cancel> messages. Some tasks may take a while in the worker thread, so before
118
+ // executing the next task in our queue, postMessage preempts this and <cancel>
119
+ // messages can be processed. We're using a MessageChannel object to get throttle the
120
+ // process() flow to one at a time.
121
+ this.tasks[id] = data;
122
+ this.taskQueue.push(id);
123
+ this.invoker.trigger();
124
+ } else {
125
+ // In the main thread, process messages immediately so that other work does not slip in
126
+ // between getting partial data back from workers.
127
+ this.processTask(id, data);
128
+ }
129
+ }
130
+ }
131
+
132
+ process() {
133
+ if (!this.taskQueue.length) {
134
+ return;
135
+ }
136
+ const id = this.taskQueue.shift();
137
+ const task = this.tasks[id];
138
+ delete this.tasks[id];
139
+ // Schedule another process call if we know there's more to process _before_ invoking the
140
+ // current task. This is necessary so that processing continues even if the current task
141
+ // doesn't execute successfully.
142
+ if (this.taskQueue.length) {
143
+ this.invoker.trigger();
144
+ }
145
+ if (!task) {
146
+ // If the task ID doesn't have associated task data anymore, it was canceled.
147
+ return;
148
+ }
149
+
150
+ this.processTask(id, task);
151
+ }
152
+
153
+ processTask(id: number, task: any) {
154
+ if (task.type === '<response>') {
155
+ // The done() function in the counterpart has been called, and we are now
156
+ // firing the callback in the originating actor, if there is one.
157
+ const callback = this.callbacks[id];
158
+ delete this.callbacks[id];
159
+ if (callback) {
160
+ // If we get a response, but don't have a callback, the request was canceled.
161
+ if (task.error) {
162
+ callback(deserialize(task.error));
163
+ } else {
164
+ callback(null, deserialize(task.data));
165
+ }
166
+ }
167
+ } else {
168
+ let completed = false;
169
+ const buffers: ?Array<Transferable> = isSafari(this.globalScope) ? undefined : [];
170
+ const done = task.hasCallback ? (err, data) => {
171
+ completed = true;
172
+ delete this.cancelCallbacks[id];
173
+ this.target.postMessage({
174
+ id,
175
+ type: '<response>',
176
+ sourceMapId: this.mapId,
177
+ error: err ? serialize(err) : null,
178
+ data: serialize(data, buffers)
179
+ }, buffers);
180
+ } : (_) => {
181
+ completed = true;
182
+ };
183
+
184
+ let callback = null;
185
+ const params = (deserialize(task.data): any);
186
+ if (this.parent[task.type]) {
187
+ // task.type == 'loadTile', 'removeTile', etc.
188
+ callback = this.parent[task.type](task.sourceMapId, params, done);
189
+ } else if (this.parent.getWorkerSource) {
190
+ // task.type == sourcetype.method
191
+ const keys = task.type.split('.');
192
+ const scope = (this.parent: any).getWorkerSource(task.sourceMapId, keys[0], params.source);
193
+ callback = scope[keys[1]](params, done);
194
+ } else {
195
+ // No function was found.
196
+ done(new Error(`Could not find function ${task.type}`));
197
+ }
198
+
199
+ if (!completed && callback && callback.cancel) {
200
+ // Allows canceling the task as long as it hasn't been completed yet.
201
+ this.cancelCallbacks[id] = callback.cancel;
202
+ }
203
+ }
204
+ }
205
+
206
+ remove() {
207
+ this.invoker.remove();
208
+ this.target.removeEventListener('message', this.receive, false);
209
+ }
210
+ }
211
+
212
+ export default Actor;
@@ -0,0 +1,388 @@
1
+ // @flow
2
+
3
+ import window from './window';
4
+ import {extend, warnOnce, isWorker} from './util';
5
+ import {isMapboxHTTPURL, hasCacheDefeatingSku} from './mapbox';
6
+ import config from './config';
7
+ import assert from 'assert';
8
+ import {cacheGet, cachePut} from './tile_request_cache';
9
+ import webpSupported from './webp_supported';
10
+ import offscreenCanvasSupported from './offscreen_canvas_supported';
11
+
12
+ import type {Callback} from '../types/callback';
13
+ import type {Cancelable} from '../types/cancelable';
14
+
15
+ /**
16
+ * The type of a resource.
17
+ * @private
18
+ * @readonly
19
+ * @enum {string}
20
+ */
21
+ const ResourceType = {
22
+ Unknown: 'Unknown',
23
+ Style: 'Style',
24
+ Source: 'Source',
25
+ Tile: 'Tile',
26
+ Glyphs: 'Glyphs',
27
+ SpriteImage: 'SpriteImage',
28
+ SpriteJSON: 'SpriteJSON',
29
+ Image: 'Image'
30
+ };
31
+ export {ResourceType};
32
+
33
+ if (typeof Object.freeze == 'function') {
34
+ Object.freeze(ResourceType);
35
+ }
36
+
37
+ /**
38
+ * A `RequestParameters` object to be returned from Map.options.transformRequest callbacks.
39
+ * @typedef {Object} RequestParameters
40
+ * @property {string} url The URL to be requested.
41
+ * @property {Object} headers The headers to be sent with the request.
42
+ * @property {string} method Request method `'GET' | 'POST' | 'PUT'`.
43
+ * @property {string} body Request body.
44
+ * @property {string} type Response body type to be returned `'string' | 'json' | 'arrayBuffer'`.
45
+ * @property {string} credentials `'same-origin'|'include'` Use 'include' to send cookies with cross-origin requests.
46
+ * @property {boolean} collectResourceTiming If true, Resource Timing API information will be collected for these transformed requests and returned in a resourceTiming property of relevant data events.
47
+ * @example
48
+ * // use transformRequest to modify requests that begin with `http://myHost`
49
+ * transformRequest: function(url, resourceType) {
50
+ * if (resourceType === 'Source' && url.indexOf('http://myHost') > -1) {
51
+ * return {
52
+ * url: url.replace('http', 'https'),
53
+ * headers: { 'my-custom-header': true },
54
+ * credentials: 'include' // Include cookies for cross-origin requests
55
+ * }
56
+ * }
57
+ * }
58
+ *
59
+ */
60
+ export type RequestParameters = {
61
+ url: string,
62
+ headers?: Object,
63
+ method?: 'GET' | 'POST' | 'PUT',
64
+ body?: string,
65
+ type?: 'string' | 'json' | 'arrayBuffer',
66
+ credentials?: 'same-origin' | 'include',
67
+ collectResourceTiming?: boolean
68
+ };
69
+
70
+ export type ResponseCallback<T> = (error: ?Error, data: ?T, cacheControl: ?string, expires: ?string) => void;
71
+
72
+ class AJAXError extends Error {
73
+ status: number;
74
+ url: string;
75
+ constructor(message: string, status: number, url: string) {
76
+ if (status === 401 && isMapboxHTTPURL(url)) {
77
+ message += ': you may have provided an invalid Mapbox access token. See https://www.mapbox.com/api-documentation/#access-tokens-and-token-scopes';
78
+ }
79
+ super(message);
80
+ this.status = status;
81
+ this.url = url;
82
+
83
+ // work around for https://github.com/Rich-Harris/buble/issues/40
84
+ this.name = this.constructor.name;
85
+ this.message = message;
86
+ }
87
+
88
+ toString() {
89
+ return `${this.name}: ${this.message} (${this.status}): ${this.url}`;
90
+ }
91
+ }
92
+
93
+ // Ensure that we're sending the correct referrer from blob URL worker bundles.
94
+ // For files loaded from the local file system, `location.origin` will be set
95
+ // to the string(!) "null" (Firefox), or "file://" (Chrome, Safari, Edge, IE),
96
+ // and we will set an empty referrer. Otherwise, we're using the document's URL.
97
+ /* global self */
98
+ export const getReferrer = isWorker() ?
99
+ () => self.worker && self.worker.referrer :
100
+ () => (window.location.protocol === 'blob:' ? window.parent : window).location.href;
101
+
102
+ // Determines whether a URL is a file:// URL. This is obviously the case if it begins
103
+ // with file://. Relative URLs are also file:// URLs iff the original document was loaded
104
+ // via a file:// URL.
105
+ const isFileURL = url => /^file:/.test(url) || (/^file:/.test(getReferrer()) && !/^\w+:/.test(url));
106
+
107
+ function makeFetchRequest(requestParameters: RequestParameters, callback: ResponseCallback<any>): Cancelable {
108
+ const controller = new window.AbortController();
109
+ const request = new window.Request(requestParameters.url, {
110
+ method: requestParameters.method || 'GET',
111
+ body: requestParameters.body,
112
+ credentials: requestParameters.credentials,
113
+ headers: requestParameters.headers,
114
+ referrer: getReferrer(),
115
+ signal: controller.signal
116
+ });
117
+ let complete = false;
118
+ let aborted = false;
119
+
120
+ const cacheIgnoringSearch = hasCacheDefeatingSku(request.url);
121
+
122
+ if (requestParameters.type === 'json') {
123
+ request.headers.set('Accept', 'application/json');
124
+ }
125
+
126
+ const validateOrFetch = (err, cachedResponse, responseIsFresh) => {
127
+ if (aborted) return;
128
+
129
+ if (err) {
130
+ // Do fetch in case of cache error.
131
+ // HTTP pages in Edge trigger a security error that can be ignored.
132
+ if (err.message !== 'SecurityError') {
133
+ warnOnce(err);
134
+ }
135
+ }
136
+
137
+ if (cachedResponse && responseIsFresh) {
138
+ return finishRequest(cachedResponse);
139
+ }
140
+
141
+ if (cachedResponse) {
142
+ // We can't do revalidation with 'If-None-Match' because then the
143
+ // request doesn't have simple cors headers.
144
+ }
145
+
146
+ const requestTime = Date.now();
147
+
148
+ window.fetch(request).then(response => {
149
+ if (response.ok) {
150
+ const cacheableResponse = cacheIgnoringSearch ? response.clone() : null;
151
+ return finishRequest(response, cacheableResponse, requestTime);
152
+
153
+ } else {
154
+ return callback(new AJAXError(response.statusText, response.status, requestParameters.url));
155
+ }
156
+ }).catch(error => {
157
+ if (error.code === 20) {
158
+ // silence expected AbortError
159
+ return;
160
+ }
161
+ callback(new Error(error.message));
162
+ });
163
+ };
164
+
165
+ const finishRequest = (response, cacheableResponse, requestTime) => {
166
+ (
167
+ requestParameters.type === 'arrayBuffer' ? response.arrayBuffer() :
168
+ requestParameters.type === 'json' ? response.json() :
169
+ response.text()
170
+ ).then(result => {
171
+ if (aborted) return;
172
+ if (cacheableResponse && requestTime) {
173
+ // The response needs to be inserted into the cache after it has completely loaded.
174
+ // Until it is fully loaded there is a chance it will be aborted. Aborting while
175
+ // reading the body can cause the cache insertion to error. We could catch this error
176
+ // in most browsers but in Firefox it seems to sometimes crash the tab. Adding
177
+ // it to the cache here avoids that error.
178
+ cachePut(request, cacheableResponse, requestTime);
179
+ }
180
+ complete = true;
181
+ callback(null, result, response.headers.get('Cache-Control'), response.headers.get('Expires'));
182
+ }).catch(err => {
183
+ if (!aborted) callback(new Error(err.message));
184
+ });
185
+ };
186
+
187
+ if (cacheIgnoringSearch) {
188
+ cacheGet(request, validateOrFetch);
189
+ } else {
190
+ validateOrFetch(null, null);
191
+ }
192
+
193
+ return {cancel: () => {
194
+ aborted = true;
195
+ if (!complete) controller.abort();
196
+ }};
197
+ }
198
+
199
+ function makeXMLHttpRequest(requestParameters: RequestParameters, callback: ResponseCallback<any>): Cancelable {
200
+ const xhr: XMLHttpRequest = new window.XMLHttpRequest();
201
+
202
+ xhr.open(requestParameters.method || 'GET', requestParameters.url, true);
203
+ if (requestParameters.type === 'arrayBuffer') {
204
+ xhr.responseType = 'arraybuffer';
205
+ }
206
+ for (const k in requestParameters.headers) {
207
+ xhr.setRequestHeader(k, requestParameters.headers[k]);
208
+ }
209
+ if (requestParameters.type === 'json') {
210
+ xhr.responseType = 'text';
211
+ xhr.setRequestHeader('Accept', 'application/json');
212
+ }
213
+ xhr.withCredentials = requestParameters.credentials === 'include';
214
+ xhr.onerror = () => {
215
+ callback(new Error(xhr.statusText));
216
+ };
217
+ xhr.onload = () => {
218
+ if (((xhr.status >= 200 && xhr.status < 300) || xhr.status === 0) && xhr.response !== null) {
219
+ let data: mixed = xhr.response;
220
+ if (requestParameters.type === 'json') {
221
+ // We're manually parsing JSON here to get better error messages.
222
+ try {
223
+ data = JSON.parse(xhr.response);
224
+ } catch (err) {
225
+ return callback(err);
226
+ }
227
+ }
228
+ callback(null, data, xhr.getResponseHeader('Cache-Control'), xhr.getResponseHeader('Expires'));
229
+ } else {
230
+ callback(new AJAXError(xhr.statusText, xhr.status, requestParameters.url));
231
+ }
232
+ };
233
+ xhr.send(requestParameters.body);
234
+ return {cancel: () => xhr.abort()};
235
+ }
236
+
237
+ export const makeRequest = function(requestParameters: RequestParameters, callback: ResponseCallback<any>): Cancelable {
238
+ // We're trying to use the Fetch API if possible. However, in some situations we can't use it:
239
+ // - IE11 doesn't support it at all. In this case, we dispatch the request to the main thread so
240
+ // that we can get an accruate referrer header.
241
+ // - Safari exposes window.AbortController, but it doesn't work actually abort any requests in
242
+ // some versions (see https://bugs.webkit.org/show_bug.cgi?id=174980#c2)
243
+ // - Requests for resources with the file:// URI scheme don't work with the Fetch API either. In
244
+ // this case we unconditionally use XHR on the current thread since referrers don't matter.
245
+ if (!isFileURL(requestParameters.url)) {
246
+ if (window.fetch && window.Request && window.AbortController && window.Request.prototype.hasOwnProperty('signal')) {
247
+ return makeFetchRequest(requestParameters, callback);
248
+ }
249
+ if (isWorker() && self.worker && self.worker.actor) {
250
+ const queueOnMainThread = true;
251
+ return self.worker.actor.send('getResource', requestParameters, callback, undefined, queueOnMainThread);
252
+ }
253
+ }
254
+ return makeXMLHttpRequest(requestParameters, callback);
255
+ };
256
+
257
+ export const getJSON = function(requestParameters: RequestParameters, callback: ResponseCallback<Object>): Cancelable {
258
+ return makeRequest(extend(requestParameters, {type: 'json'}), callback);
259
+ };
260
+
261
+ export const getArrayBuffer = function(requestParameters: RequestParameters, callback: ResponseCallback<ArrayBuffer>): Cancelable {
262
+ return makeRequest(extend(requestParameters, {type: 'arrayBuffer'}), callback);
263
+ };
264
+
265
+ export const postData = function(requestParameters: RequestParameters, callback: ResponseCallback<string>): Cancelable {
266
+ return makeRequest(extend(requestParameters, {method: 'POST'}), callback);
267
+ };
268
+
269
+ function sameOrigin(url) {
270
+ const a: HTMLAnchorElement = window.document.createElement('a');
271
+ a.href = url;
272
+ return a.protocol === window.document.location.protocol && a.host === window.document.location.host;
273
+ }
274
+
275
+ const transparentPngUrl = 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAC0lEQVQYV2NgAAIAAAUAAarVyFEAAAAASUVORK5CYII=';
276
+
277
+ function arrayBufferToImage(data: ArrayBuffer, callback: (err: ?Error, image: ?HTMLImageElement) => void, cacheControl: ?string, expires: ?string) {
278
+ const img: HTMLImageElement = new window.Image();
279
+ const URL = window.URL;
280
+ img.onload = () => {
281
+ callback(null, img);
282
+ URL.revokeObjectURL(img.src);
283
+ // prevent image dataURI memory leak in Safari;
284
+ // but don't free the image immediately because it might be uploaded in the next frame
285
+ // https://github.com/mapbox/mapbox-gl-js/issues/10226
286
+ img.onload = null;
287
+ window.requestAnimationFrame(() => { img.src = transparentPngUrl; });
288
+ };
289
+ img.onerror = () => callback(new Error('Could not load image. Please make sure to use a supported image type such as PNG or JPEG. Note that SVGs are not supported.'));
290
+ const blob: Blob = new window.Blob([new Uint8Array(data)], {type: 'image/png'});
291
+ (img: any).cacheControl = cacheControl;
292
+ (img: any).expires = expires;
293
+ img.src = data.byteLength ? URL.createObjectURL(blob) : transparentPngUrl;
294
+ }
295
+
296
+ function arrayBufferToImageBitmap(data: ArrayBuffer, callback: (err: ?Error, image: ?ImageBitmap) => void) {
297
+ const blob: Blob = new window.Blob([new Uint8Array(data)], {type: 'image/png'});
298
+ window.createImageBitmap(blob).then((imgBitmap) => {
299
+ callback(null, imgBitmap);
300
+ }).catch((e) => {
301
+ callback(new Error(`Could not load image because of ${e.message}. Please make sure to use a supported image type such as PNG or JPEG. Note that SVGs are not supported.`));
302
+ });
303
+ }
304
+
305
+ let imageQueue, numImageRequests;
306
+ export const resetImageRequestQueue = () => {
307
+ imageQueue = [];
308
+ numImageRequests = 0;
309
+ };
310
+ resetImageRequestQueue();
311
+
312
+ export const getImage = function(requestParameters: RequestParameters, callback: Callback<HTMLImageElement | ImageBitmap>): Cancelable {
313
+ if (webpSupported.supported) {
314
+ if (!requestParameters.headers) {
315
+ requestParameters.headers = {};
316
+ }
317
+ requestParameters.headers.accept = 'image/webp,*/*';
318
+ }
319
+
320
+ // limit concurrent image loads to help with raster sources performance on big screens
321
+ if (numImageRequests >= config.MAX_PARALLEL_IMAGE_REQUESTS) {
322
+ const queued = {
323
+ requestParameters,
324
+ callback,
325
+ cancelled: false,
326
+ cancel() { this.cancelled = true; }
327
+ };
328
+ imageQueue.push(queued);
329
+ return queued;
330
+ }
331
+ numImageRequests++;
332
+
333
+ let advanced = false;
334
+ const advanceImageRequestQueue = () => {
335
+ if (advanced) return;
336
+ advanced = true;
337
+ numImageRequests--;
338
+ assert(numImageRequests >= 0);
339
+ while (imageQueue.length && numImageRequests < config.MAX_PARALLEL_IMAGE_REQUESTS) { // eslint-disable-line
340
+ const request = imageQueue.shift();
341
+ const {requestParameters, callback, cancelled} = request;
342
+ if (!cancelled) {
343
+ request.cancel = getImage(requestParameters, callback).cancel;
344
+ }
345
+ }
346
+ };
347
+
348
+ // request the image with XHR to work around caching issues
349
+ // see https://github.com/mapbox/mapbox-gl-js/issues/1470
350
+ const request = getArrayBuffer(requestParameters, (err: ?Error, data: ?ArrayBuffer, cacheControl: ?string, expires: ?string) => {
351
+
352
+ advanceImageRequestQueue();
353
+
354
+ if (err) {
355
+ callback(err);
356
+ } else if (data) {
357
+ if (offscreenCanvasSupported()) {
358
+ arrayBufferToImageBitmap(data, callback);
359
+ } else {
360
+ arrayBufferToImage(data, callback, cacheControl, expires);
361
+ }
362
+ }
363
+ });
364
+
365
+ return {
366
+ cancel: () => {
367
+ request.cancel();
368
+ advanceImageRequestQueue();
369
+ }
370
+ };
371
+ };
372
+
373
+ export const getVideo = function(urls: Array<string>, callback: Callback<HTMLVideoElement>): Cancelable {
374
+ const video: HTMLVideoElement = window.document.createElement('video');
375
+ video.muted = true;
376
+ video.onloadstart = function() {
377
+ callback(null, video);
378
+ };
379
+ for (let i = 0; i < urls.length; i++) {
380
+ const s: HTMLSourceElement = window.document.createElement('source');
381
+ if (!sameOrigin(urls[i])) {
382
+ video.crossOrigin = 'Anonymous';
383
+ }
384
+ s.src = urls[i];
385
+ video.appendChild(s);
386
+ }
387
+ return {cancel: () => {}};
388
+ };
@@ -0,0 +1,10 @@
1
+ // @flow
2
+
3
+ import window from '../window';
4
+ import mapboxgl from '../../';
5
+
6
+ import type {WorkerInterface} from '../web_worker';
7
+
8
+ export default function (): WorkerInterface {
9
+ return (new window.Worker(mapboxgl.workerUrl): any);
10
+ }
@@ -0,0 +1,6 @@
1
+ // @flow
2
+ /* eslint-env browser */
3
+ import type {Window} from '../../types/window';
4
+
5
+ // shim window for the case of requiring the browser bundle in Node
6
+ export default typeof self !== 'undefined' ? (self: Window) : (({}: any): Window);
@@ -0,0 +1,70 @@
1
+ // @flow strict
2
+
3
+ import window from './window';
4
+ import type {Cancelable} from '../types/cancelable';
5
+
6
+ const now = window.performance && window.performance.now ?
7
+ window.performance.now.bind(window.performance) :
8
+ Date.now.bind(Date);
9
+
10
+ const raf = window.requestAnimationFrame ||
11
+ window.mozRequestAnimationFrame ||
12
+ window.webkitRequestAnimationFrame ||
13
+ window.msRequestAnimationFrame;
14
+
15
+ const cancel = window.cancelAnimationFrame ||
16
+ window.mozCancelAnimationFrame ||
17
+ window.webkitCancelAnimationFrame ||
18
+ window.msCancelAnimationFrame;
19
+
20
+ let linkEl;
21
+
22
+ let reducedMotionQuery: MediaQueryList;
23
+
24
+ /**
25
+ * @private
26
+ */
27
+ const exported = {
28
+ /**
29
+ * Provides a function that outputs milliseconds: either performance.now()
30
+ * or a fallback to Date.now()
31
+ */
32
+ now,
33
+
34
+ frame(fn: (paintStartTimestamp: number) => void): Cancelable {
35
+ const frame = raf(fn);
36
+ return {cancel: () => cancel(frame)};
37
+ },
38
+
39
+ getImageData(img: CanvasImageSource, padding?: number = 0): ImageData {
40
+ const canvas = window.document.createElement('canvas');
41
+ const context = canvas.getContext('2d');
42
+ if (!context) {
43
+ throw new Error('failed to create canvas 2d context');
44
+ }
45
+ canvas.width = img.width;
46
+ canvas.height = img.height;
47
+ context.drawImage(img, 0, 0, img.width, img.height);
48
+ return context.getImageData(-padding, -padding, img.width + 2 * padding, img.height + 2 * padding);
49
+ },
50
+
51
+ resolveURL(path: string) {
52
+ if (!linkEl) linkEl = window.document.createElement('a');
53
+ linkEl.href = path;
54
+ return linkEl.href;
55
+ },
56
+
57
+ hardwareConcurrency: window.navigator && window.navigator.hardwareConcurrency || 4,
58
+
59
+ get devicePixelRatio() { return window.devicePixelRatio; },
60
+ get prefersReducedMotion(): boolean {
61
+ if (!window.matchMedia) return false;
62
+ //Lazily initialize media query
63
+ if (reducedMotionQuery == null) {
64
+ reducedMotionQuery = window.matchMedia('(prefers-reduced-motion: reduce)');
65
+ }
66
+ return reducedMotionQuery.matches;
67
+ },
68
+ };
69
+
70
+ export default exported;