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,171 @@
1
+ // @flow
2
+
3
+ import DOM from '../../util/dom';
4
+ import type Point from '@mapbox/point-geometry';
5
+
6
+ const LEFT_BUTTON = 0;
7
+ const RIGHT_BUTTON = 2;
8
+
9
+ // the values for each button in MouseEvent.buttons
10
+ const BUTTONS_FLAGS = {
11
+ [LEFT_BUTTON]: 1,
12
+ [RIGHT_BUTTON]: 2
13
+ };
14
+
15
+ function buttonStillPressed(e: MouseEvent, button: number) {
16
+ const flag = BUTTONS_FLAGS[button];
17
+ return e.buttons === undefined || (e.buttons & flag) !== flag;
18
+ }
19
+
20
+ class MouseHandler {
21
+
22
+ _enabled: boolean;
23
+ _active: boolean;
24
+ _lastPoint: Point;
25
+ _eventButton: number;
26
+ _moved: boolean;
27
+ _clickTolerance: number;
28
+
29
+ constructor(options: { clickTolerance: number }) {
30
+ this.reset();
31
+ this._clickTolerance = options.clickTolerance || 1;
32
+ }
33
+
34
+ blur() {
35
+ this.reset();
36
+ }
37
+
38
+ reset() {
39
+ this._active = false;
40
+ this._moved = false;
41
+ delete this._lastPoint;
42
+ delete this._eventButton;
43
+ }
44
+
45
+ _correctButton(e: MouseEvent, button: number) { //eslint-disable-line
46
+ return false; // implemented by child
47
+ }
48
+
49
+ _move(lastPoint: Point, point: Point) { //eslint-disable-line
50
+ return {}; // implemented by child
51
+ }
52
+
53
+ mousedown(e: MouseEvent, point: Point) {
54
+ if (this._lastPoint) return;
55
+
56
+ const eventButton = DOM.mouseButton(e);
57
+ if (!this._correctButton(e, eventButton)) return;
58
+
59
+ this._lastPoint = point;
60
+ this._eventButton = eventButton;
61
+ }
62
+
63
+ mousemoveWindow(e: MouseEvent, point: Point) {
64
+ const lastPoint = this._lastPoint;
65
+ if (!lastPoint) return;
66
+ e.preventDefault();
67
+
68
+ if (buttonStillPressed(e, this._eventButton)) {
69
+ // Some browsers don't fire a `mouseup` when the mouseup occurs outside
70
+ // the window or iframe:
71
+ // https://github.com/mapbox/mapbox-gl-js/issues/4622
72
+ //
73
+ // If the button is no longer pressed during this `mousemove` it may have
74
+ // been released outside of the window or iframe.
75
+ this.reset();
76
+ return;
77
+ }
78
+
79
+ if (!this._moved && point.dist(lastPoint) < this._clickTolerance) return;
80
+ this._moved = true;
81
+ this._lastPoint = point;
82
+
83
+ // implemented by child class
84
+ return this._move(lastPoint, point);
85
+ }
86
+
87
+ mouseupWindow(e: MouseEvent) {
88
+ if (!this._lastPoint) return;
89
+ const eventButton = DOM.mouseButton(e);
90
+ if (eventButton !== this._eventButton) return;
91
+ if (this._moved) DOM.suppressClick();
92
+ this.reset();
93
+ }
94
+
95
+ enable() {
96
+ this._enabled = true;
97
+ }
98
+
99
+ disable() {
100
+ this._enabled = false;
101
+ this.reset();
102
+ }
103
+
104
+ isEnabled() {
105
+ return this._enabled;
106
+ }
107
+
108
+ isActive() {
109
+ return this._active;
110
+ }
111
+ }
112
+
113
+ export class MousePanHandler extends MouseHandler {
114
+
115
+ mousedown(e: MouseEvent, point: Point) {
116
+ super.mousedown(e, point);
117
+ if (this._lastPoint) this._active = true;
118
+ }
119
+ _correctButton(e: MouseEvent, button: number) {
120
+ return button === LEFT_BUTTON && !e.ctrlKey;
121
+ }
122
+
123
+ _move(lastPoint: Point, point: Point) {
124
+ return {
125
+ around: point,
126
+ panDelta: point.sub(lastPoint)
127
+ };
128
+ }
129
+ }
130
+
131
+ export class MouseRotateHandler extends MouseHandler {
132
+ _correctButton(e: MouseEvent, button: number) {
133
+ return (button === LEFT_BUTTON && e.ctrlKey) || (button === RIGHT_BUTTON);
134
+ }
135
+
136
+ _move(lastPoint: Point, point: Point) {
137
+ const degreesPerPixelMoved = 0.8;
138
+ const bearingDelta = (point.x - lastPoint.x) * degreesPerPixelMoved;
139
+ if (bearingDelta) {
140
+ this._active = true;
141
+ return {bearingDelta};
142
+ }
143
+ }
144
+
145
+ contextmenu(e: MouseEvent) {
146
+ // prevent browser context menu when necessary; we don't allow it with rotation
147
+ // because we can't discern rotation gesture start from contextmenu on Mac
148
+ e.preventDefault();
149
+ }
150
+ }
151
+
152
+ export class MousePitchHandler extends MouseHandler {
153
+ _correctButton(e: MouseEvent, button: number) {
154
+ return (button === LEFT_BUTTON && e.ctrlKey) || (button === RIGHT_BUTTON);
155
+ }
156
+
157
+ _move(lastPoint: Point, point: Point) {
158
+ const degreesPerPixelMoved = -0.5;
159
+ const pitchDelta = (point.y - lastPoint.y) * degreesPerPixelMoved;
160
+ if (pitchDelta) {
161
+ this._active = true;
162
+ return {pitchDelta};
163
+ }
164
+ }
165
+
166
+ contextmenu(e: MouseEvent) {
167
+ // prevent browser context menu when necessary; we don't allow it with rotation
168
+ // because we can't discern rotation gesture start from contextmenu on Mac
169
+ e.preventDefault();
170
+ }
171
+ }
@@ -0,0 +1,350 @@
1
+ // @flow
2
+
3
+ import assert from 'assert';
4
+ import DOM from '../../util/dom';
5
+
6
+ import {ease as _ease, bindAll, bezier} from '../../util/util';
7
+ import browser from '../../util/browser';
8
+ import window from '../../util/window';
9
+ import {number as interpolate} from '../../style-spec/util/interpolate';
10
+ import LngLat from '../../geo/lng_lat';
11
+
12
+ import type Map from '../map';
13
+ import type HandlerManager from '../handler_manager';
14
+ import type Point from '@mapbox/point-geometry';
15
+
16
+ // deltaY value for mouse scroll wheel identification
17
+ const wheelZoomDelta = 4.000244140625;
18
+
19
+ // These magic numbers control the rate of zoom. Trackpad events fire at a greater
20
+ // frequency than mouse scroll wheel, so reduce the zoom rate per wheel tick
21
+ const defaultZoomRate = 1 / 100;
22
+ const wheelZoomRate = 1 / 450;
23
+
24
+ // upper bound on how much we scale the map in any single render frame; this
25
+ // is used to limit zoom rate in the case of very fast scrolling
26
+ const maxScalePerFrame = 2;
27
+
28
+ /**
29
+ * The `ScrollZoomHandler` allows the user to zoom the map by scrolling.
30
+ */
31
+ class ScrollZoomHandler {
32
+ _map: Map;
33
+ _el: HTMLElement;
34
+ _enabled: boolean;
35
+ _active: boolean;
36
+ _zooming: boolean;
37
+ _aroundCenter: boolean;
38
+ _around: Point;
39
+ _aroundPoint: Point;
40
+ _type: 'wheel' | 'trackpad' | null;
41
+ _lastValue: number;
42
+ _timeout: ?TimeoutID; // used for delayed-handling of a single wheel movement
43
+ _finishTimeout: ?TimeoutID; // used to delay final '{move,zoom}end' events
44
+
45
+ _lastWheelEvent: any;
46
+ _lastWheelEventTime: number;
47
+
48
+ _startZoom: ?number;
49
+ _targetZoom: ?number;
50
+ _delta: number;
51
+ _easing: ?((number) => number);
52
+ _prevEase: ?{start: number, duration: number, easing: (_: number) => number};
53
+
54
+ _frameId: ?boolean;
55
+ _handler: HandlerManager;
56
+
57
+ _defaultZoomRate: number;
58
+ _wheelZoomRate: number;
59
+
60
+ /**
61
+ * @private
62
+ */
63
+ constructor(map: Map, handler: HandlerManager) {
64
+ this._map = map;
65
+ this._el = map.getCanvasContainer();
66
+ this._handler = handler;
67
+
68
+ this._delta = 0;
69
+
70
+ this._defaultZoomRate = defaultZoomRate;
71
+ this._wheelZoomRate = wheelZoomRate;
72
+
73
+ bindAll(['_onTimeout'], this);
74
+ }
75
+
76
+ /**
77
+ * Set the zoom rate of a trackpad
78
+ * @param {number} [zoomRate=1/100] The rate used to scale trackpad movement to a zoom value.
79
+ * @example
80
+ * // Speed up trackpad zoom
81
+ * map.scrollZoom.setZoomRate(1/25);
82
+ */
83
+ setZoomRate(zoomRate: number) {
84
+ this._defaultZoomRate = zoomRate;
85
+ }
86
+
87
+ /**
88
+ * Set the zoom rate of a mouse wheel
89
+ * @param {number} [wheelZoomRate=1/450] The rate used to scale mouse wheel movement to a zoom value.
90
+ * @example
91
+ * // Slow down zoom of mouse wheel
92
+ * map.scrollZoom.setWheelZoomRate(1/600);
93
+ */
94
+ setWheelZoomRate(wheelZoomRate: number) {
95
+ this._wheelZoomRate = wheelZoomRate;
96
+ }
97
+
98
+ /**
99
+ * Returns a Boolean indicating whether the "scroll to zoom" interaction is enabled.
100
+ *
101
+ * @returns {boolean} `true` if the "scroll to zoom" interaction is enabled.
102
+ */
103
+ isEnabled() {
104
+ return !!this._enabled;
105
+ }
106
+
107
+ /*
108
+ * Active state is turned on and off with every scroll wheel event and is set back to false before the map
109
+ * render is called, so _active is not a good candidate for determining if a scroll zoom animation is in
110
+ * progress.
111
+ */
112
+ isActive() {
113
+ return !!this._active || this._finishTimeout !== undefined;
114
+ }
115
+
116
+ isZooming() {
117
+ return !!this._zooming;
118
+ }
119
+
120
+ /**
121
+ * Enables the "scroll to zoom" interaction.
122
+ *
123
+ * @param {Object} [options] Options object.
124
+ * @param {string} [options.around] If "center" is passed, map will zoom around center of map
125
+ *
126
+ * @example
127
+ * map.scrollZoom.enable();
128
+ * @example
129
+ * map.scrollZoom.enable({ around: 'center' })
130
+ */
131
+ enable(options: any) {
132
+ if (this.isEnabled()) return;
133
+ this._enabled = true;
134
+ this._aroundCenter = options && options.around === 'center';
135
+ }
136
+
137
+ /**
138
+ * Disables the "scroll to zoom" interaction.
139
+ *
140
+ * @example
141
+ * map.scrollZoom.disable();
142
+ */
143
+ disable() {
144
+ if (!this.isEnabled()) return;
145
+ this._enabled = false;
146
+ }
147
+
148
+ wheel(e: WheelEvent) {
149
+ if (!this.isEnabled()) return;
150
+
151
+ // Remove `any` cast when https://github.com/facebook/flow/issues/4879 is fixed.
152
+ let value = e.deltaMode === (window.WheelEvent: any).DOM_DELTA_LINE ? e.deltaY * 40 : e.deltaY;
153
+ const now = browser.now(),
154
+ timeDelta = now - (this._lastWheelEventTime || 0);
155
+
156
+ this._lastWheelEventTime = now;
157
+
158
+ if (value !== 0 && (value % wheelZoomDelta) === 0) {
159
+ // This one is definitely a mouse wheel event.
160
+ this._type = 'wheel';
161
+
162
+ } else if (value !== 0 && Math.abs(value) < 4) {
163
+ // This one is definitely a trackpad event because it is so small.
164
+ this._type = 'trackpad';
165
+
166
+ } else if (timeDelta > 400) {
167
+ // This is likely a new scroll action.
168
+ this._type = null;
169
+ this._lastValue = value;
170
+
171
+ // Start a timeout in case this was a singular event, and dely it by up to 40ms.
172
+ this._timeout = setTimeout(this._onTimeout, 40, e);
173
+
174
+ } else if (!this._type) {
175
+ // This is a repeating event, but we don't know the type of event just yet.
176
+ // If the delta per time is small, we assume it's a fast trackpad; otherwise we switch into wheel mode.
177
+ this._type = (Math.abs(timeDelta * value) < 200) ? 'trackpad' : 'wheel';
178
+
179
+ // Make sure our delayed event isn't fired again, because we accumulate
180
+ // the previous event (which was less than 40ms ago) into this event.
181
+ if (this._timeout) {
182
+ clearTimeout(this._timeout);
183
+ this._timeout = null;
184
+ value += this._lastValue;
185
+ }
186
+ }
187
+
188
+ // Slow down zoom if shift key is held for more precise zooming
189
+ if (e.shiftKey && value) value = value / 4;
190
+
191
+ // Only fire the callback if we actually know what type of scrolling device the user uses.
192
+ if (this._type) {
193
+ this._lastWheelEvent = e;
194
+ this._delta -= value;
195
+ if (!this._active) {
196
+ this._start(e);
197
+ }
198
+ }
199
+
200
+ e.preventDefault();
201
+ }
202
+
203
+ _onTimeout(initialEvent: any) {
204
+ this._type = 'wheel';
205
+ this._delta -= this._lastValue;
206
+ if (!this._active) {
207
+ this._start(initialEvent);
208
+ }
209
+ }
210
+
211
+ _start(e: any) {
212
+ if (!this._delta) return;
213
+
214
+ if (this._frameId) {
215
+ this._frameId = null;
216
+ }
217
+
218
+ this._active = true;
219
+ if (!this.isZooming()) {
220
+ this._zooming = true;
221
+ }
222
+
223
+ if (this._finishTimeout) {
224
+ clearTimeout(this._finishTimeout);
225
+ delete this._finishTimeout;
226
+ }
227
+
228
+ const pos = DOM.mousePos(this._el, e);
229
+
230
+ this._around = LngLat.convert(this._aroundCenter ? this._map.getCenter() : this._map.unproject(pos));
231
+ this._aroundPoint = this._map.transform.locationPoint(this._around);
232
+ if (!this._frameId) {
233
+ this._frameId = true;
234
+ this._handler._triggerRenderFrame();
235
+ }
236
+ }
237
+
238
+ renderFrame() {
239
+ if (!this._frameId) return;
240
+ this._frameId = null;
241
+
242
+ if (!this.isActive()) return;
243
+ const tr = this._map.transform;
244
+
245
+ // if we've had scroll events since the last render frame, consume the
246
+ // accumulated delta, and update the target zoom level accordingly
247
+ if (this._delta !== 0) {
248
+ // For trackpad events and single mouse wheel ticks, use the default zoom rate
249
+ const zoomRate = (this._type === 'wheel' && Math.abs(this._delta) > wheelZoomDelta) ? this._wheelZoomRate : this._defaultZoomRate;
250
+ // Scale by sigmoid of scroll wheel delta.
251
+ let scale = maxScalePerFrame / (1 + Math.exp(-Math.abs(this._delta * zoomRate)));
252
+
253
+ if (this._delta < 0 && scale !== 0) {
254
+ scale = 1 / scale;
255
+ }
256
+
257
+ const fromScale = typeof this._targetZoom === 'number' ? tr.zoomScale(this._targetZoom) : tr.scale;
258
+ this._targetZoom = Math.min(tr.maxZoom, Math.max(tr.minZoom, tr.scaleZoom(fromScale * scale)));
259
+
260
+ // if this is a mouse wheel, refresh the starting zoom and easing
261
+ // function we're using to smooth out the zooming between wheel
262
+ // events
263
+ if (this._type === 'wheel') {
264
+ this._startZoom = tr.zoom;
265
+ this._easing = this._smoothOutEasing(200);
266
+ }
267
+
268
+ this._delta = 0;
269
+ }
270
+
271
+ const targetZoom = typeof this._targetZoom === 'number' ?
272
+ this._targetZoom : tr.zoom;
273
+ const startZoom = this._startZoom;
274
+ const easing = this._easing;
275
+
276
+ let finished = false;
277
+ let zoom;
278
+ if (this._type === 'wheel' && startZoom && easing) {
279
+ assert(easing && typeof startZoom === 'number');
280
+
281
+ const t = Math.min((browser.now() - this._lastWheelEventTime) / 200, 1);
282
+ const k = easing(t);
283
+ zoom = interpolate(startZoom, targetZoom, k);
284
+ if (t < 1) {
285
+ if (!this._frameId) {
286
+ this._frameId = true;
287
+ }
288
+ } else {
289
+ finished = true;
290
+ }
291
+ } else {
292
+ zoom = targetZoom;
293
+ finished = true;
294
+ }
295
+
296
+ this._active = true;
297
+
298
+ if (finished) {
299
+ this._active = false;
300
+ this._finishTimeout = setTimeout(() => {
301
+ this._zooming = false;
302
+ this._handler._triggerRenderFrame();
303
+ delete this._targetZoom;
304
+ delete this._finishTimeout;
305
+ }, 200);
306
+ }
307
+
308
+ return {
309
+ noInertia: true,
310
+ needsRenderFrame: !finished,
311
+ zoomDelta: zoom - tr.zoom,
312
+ around: this._aroundPoint,
313
+ originalEvent: this._lastWheelEvent
314
+ };
315
+ }
316
+
317
+ _smoothOutEasing(duration: number) {
318
+ let easing = _ease;
319
+
320
+ if (this._prevEase) {
321
+ const ease = this._prevEase,
322
+ t = (browser.now() - ease.start) / ease.duration,
323
+ speed = ease.easing(t + 0.01) - ease.easing(t),
324
+
325
+ // Quick hack to make new bezier that is continuous with last
326
+ x = 0.27 / Math.sqrt(speed * speed + 0.0001) * 0.01,
327
+ y = Math.sqrt(0.27 * 0.27 - x * x);
328
+
329
+ easing = bezier(x, y, 0.25, 1);
330
+ }
331
+
332
+ this._prevEase = {
333
+ start: browser.now(),
334
+ duration,
335
+ easing
336
+ };
337
+
338
+ return easing;
339
+ }
340
+
341
+ blur() {
342
+ this.reset();
343
+ }
344
+
345
+ reset() {
346
+ this._active = false;
347
+ }
348
+ }
349
+
350
+ export default ScrollZoomHandler;
@@ -0,0 +1,62 @@
1
+ // @flow
2
+
3
+ import type ClickZoomHandler from '../click_zoom';
4
+ import type TapZoomHandler from './../tap_zoom';
5
+
6
+ /**
7
+ * The `DoubleClickZoomHandler` allows the user to zoom the map at a point by
8
+ * double clicking or double tapping.
9
+ */
10
+ export default class DoubleClickZoomHandler {
11
+
12
+ _clickZoom: ClickZoomHandler;
13
+ _tapZoom: TapZoomHandler;
14
+
15
+ /**
16
+ * @private
17
+ */
18
+ constructor(clickZoom: ClickZoomHandler, TapZoom: TapZoomHandler) {
19
+ this._clickZoom = clickZoom;
20
+ this._tapZoom = TapZoom;
21
+ }
22
+
23
+ /**
24
+ * Enables the "double click to zoom" interaction.
25
+ *
26
+ * @example
27
+ * map.doubleClickZoom.enable();
28
+ */
29
+ enable() {
30
+ this._clickZoom.enable();
31
+ this._tapZoom.enable();
32
+ }
33
+
34
+ /**
35
+ * Disables the "double click to zoom" interaction.
36
+ *
37
+ * @example
38
+ * map.doubleClickZoom.disable();
39
+ */
40
+ disable() {
41
+ this._clickZoom.disable();
42
+ this._tapZoom.disable();
43
+ }
44
+
45
+ /**
46
+ * Returns a Boolean indicating whether the "double click to zoom" interaction is enabled.
47
+ *
48
+ * @returns {boolean} `true` if the "double click to zoom" interaction is enabled.
49
+ */
50
+ isEnabled() {
51
+ return this._clickZoom.isEnabled() && this._tapZoom.isEnabled();
52
+ }
53
+
54
+ /**
55
+ * Returns a Boolean indicating whether the "double click to zoom" interaction is active, i.e. currently being used.
56
+ *
57
+ * @returns {boolean} `true` if the "double click to zoom" interaction is active.
58
+ */
59
+ isActive() {
60
+ return this._clickZoom.isActive() || this._tapZoom.isActive();
61
+ }
62
+ }
@@ -0,0 +1,88 @@
1
+ // @flow
2
+
3
+ import type {MousePanHandler} from '../mouse';
4
+ import type TouchPanHandler from './../touch_pan';
5
+
6
+ export type DragPanOptions = {
7
+ linearity?: number;
8
+ easing?: (t: number) => number;
9
+ deceleration?: number;
10
+ maxSpeed?: number;
11
+ };
12
+
13
+ /**
14
+ * The `DragPanHandler` allows the user to pan the map by clicking and dragging
15
+ * the cursor.
16
+ */
17
+ export default class DragPanHandler {
18
+
19
+ _el: HTMLElement;
20
+ _mousePan: MousePanHandler;
21
+ _touchPan: TouchPanHandler;
22
+ _inertiaOptions: DragPanOptions
23
+
24
+ /**
25
+ * @private
26
+ */
27
+ constructor(el: HTMLElement, mousePan: MousePanHandler, touchPan: TouchPanHandler) {
28
+ this._el = el;
29
+ this._mousePan = mousePan;
30
+ this._touchPan = touchPan;
31
+ }
32
+
33
+ /**
34
+ * Enables the "drag to pan" interaction.
35
+ *
36
+ * @param {Object} [options] Options object
37
+ * @param {number} [options.linearity=0] factor used to scale the drag velocity
38
+ * @param {Function} [options.easing=bezier(0, 0, 0.3, 1)] easing function applled to `map.panTo` when applying the drag.
39
+ * @param {number} [options.maxSpeed=1400] the maximum value of the drag velocity.
40
+ * @param {number} [options.deceleration=2500] the rate at which the speed reduces after the pan ends.
41
+ *
42
+ * @example
43
+ * map.dragPan.enable();
44
+ * @example
45
+ * map.dragPan.enable({
46
+ * linearity: 0.3,
47
+ * easing: bezier(0, 0, 0.3, 1),
48
+ * maxSpeed: 1400,
49
+ * deceleration: 2500,
50
+ * });
51
+ */
52
+ enable(options?: DragPanOptions) {
53
+ this._inertiaOptions = options || {};
54
+ this._mousePan.enable();
55
+ this._touchPan.enable();
56
+ this._el.classList.add('mapboxgl-touch-drag-pan');
57
+ }
58
+
59
+ /**
60
+ * Disables the "drag to pan" interaction.
61
+ *
62
+ * @example
63
+ * map.dragPan.disable();
64
+ */
65
+ disable() {
66
+ this._mousePan.disable();
67
+ this._touchPan.disable();
68
+ this._el.classList.remove('mapboxgl-touch-drag-pan');
69
+ }
70
+
71
+ /**
72
+ * Returns a Boolean indicating whether the "drag to pan" interaction is enabled.
73
+ *
74
+ * @returns {boolean} `true` if the "drag to pan" interaction is enabled.
75
+ */
76
+ isEnabled() {
77
+ return this._mousePan.isEnabled() && this._touchPan.isEnabled();
78
+ }
79
+
80
+ /**
81
+ * Returns a Boolean indicating whether the "drag to pan" interaction is active, i.e. currently being used.
82
+ *
83
+ * @returns {boolean} `true` if the "drag to pan" interaction is active.
84
+ */
85
+ isActive() {
86
+ return this._mousePan.isActive() || this._touchPan.isActive();
87
+ }
88
+ }