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,64 @@
1
+
2
+ import validate from './validate';
3
+ import ValidationError from '../error/validation_error';
4
+ import getType from '../util/get_type';
5
+ import {isFunction} from '../function';
6
+ import {unbundle, deepUnbundle} from '../util/unbundle_jsonlint';
7
+ import {supportsPropertyExpression} from '../util/properties';
8
+
9
+ export default function validateProperty(options, propertyType) {
10
+ const key = options.key;
11
+ const style = options.style;
12
+ const styleSpec = options.styleSpec;
13
+ const value = options.value;
14
+ const propertyKey = options.objectKey;
15
+ const layerSpec = styleSpec[`${propertyType}_${options.layerType}`];
16
+
17
+ if (!layerSpec) return [];
18
+
19
+ const transitionMatch = propertyKey.match(/^(.*)-transition$/);
20
+ if (propertyType === 'paint' && transitionMatch && layerSpec[transitionMatch[1]] && layerSpec[transitionMatch[1]].transition) {
21
+ return validate({
22
+ key,
23
+ value,
24
+ valueSpec: styleSpec.transition,
25
+ style,
26
+ styleSpec
27
+ });
28
+ }
29
+
30
+ const valueSpec = options.valueSpec || layerSpec[propertyKey];
31
+ if (!valueSpec) {
32
+ return [new ValidationError(key, value, `unknown property "${propertyKey}"`)];
33
+ }
34
+
35
+ let tokenMatch;
36
+ if (getType(value) === 'string' && supportsPropertyExpression(valueSpec) && !valueSpec.tokens && (tokenMatch = /^{([^}]+)}$/.exec(value))) {
37
+ return [new ValidationError(
38
+ key, value,
39
+ `"${propertyKey}" does not support interpolation syntax\n` +
40
+ `Use an identity property function instead: \`{ "type": "identity", "property": ${JSON.stringify(tokenMatch[1])} }\`.`)];
41
+ }
42
+
43
+ const errors = [];
44
+
45
+ if (options.layerType === 'symbol') {
46
+ if (propertyKey === 'text-field' && style && !style.glyphs) {
47
+ errors.push(new ValidationError(key, value, 'use of "text-field" requires a style "glyphs" property'));
48
+ }
49
+ if (propertyKey === 'text-font' && isFunction(deepUnbundle(value)) && unbundle(value.type) === 'identity') {
50
+ errors.push(new ValidationError(key, value, '"text-font" does not support identity functions'));
51
+ }
52
+ }
53
+
54
+ return errors.concat(validate({
55
+ key: options.key,
56
+ value,
57
+ valueSpec,
58
+ style,
59
+ styleSpec,
60
+ expressionContext: 'property',
61
+ propertyType,
62
+ propertyKey
63
+ }));
64
+ }
@@ -0,0 +1,111 @@
1
+
2
+ import ValidationError from '../error/validation_error';
3
+ import {unbundle} from '../util/unbundle_jsonlint';
4
+ import validateObject from './validate_object';
5
+ import validateEnum from './validate_enum';
6
+ import validateExpression from './validate_expression';
7
+ import validateString from './validate_string';
8
+ import getType from '../util/get_type';
9
+
10
+ const objectElementValidators = {
11
+ promoteId: validatePromoteId
12
+ };
13
+
14
+ export default function validateSource(options) {
15
+ const value = options.value;
16
+ const key = options.key;
17
+ const styleSpec = options.styleSpec;
18
+ const style = options.style;
19
+
20
+ if (!value.type) {
21
+ return [new ValidationError(key, value, '"type" is required')];
22
+ }
23
+
24
+ const type = unbundle(value.type);
25
+ let errors;
26
+
27
+ switch (type) {
28
+ case 'vector':
29
+ case 'raster':
30
+ case 'raster-dem':
31
+ errors = validateObject({
32
+ key,
33
+ value,
34
+ valueSpec: styleSpec[`source_${type.replace('-', '_')}`],
35
+ style: options.style,
36
+ styleSpec,
37
+ objectElementValidators
38
+ });
39
+ return errors;
40
+
41
+ case 'geojson':
42
+ errors = validateObject({
43
+ key,
44
+ value,
45
+ valueSpec: styleSpec.source_geojson,
46
+ style,
47
+ styleSpec,
48
+ objectElementValidators
49
+ });
50
+ if (value.cluster) {
51
+ for (const prop in value.clusterProperties) {
52
+ const [operator, mapExpr] = value.clusterProperties[prop];
53
+ const reduceExpr = typeof operator === 'string' ? [operator, ['accumulated'], ['get', prop]] : operator;
54
+
55
+ errors.push(...validateExpression({
56
+ key: `${key}.${prop}.map`,
57
+ value: mapExpr,
58
+ expressionContext: 'cluster-map'
59
+ }));
60
+ errors.push(...validateExpression({
61
+ key: `${key}.${prop}.reduce`,
62
+ value: reduceExpr,
63
+ expressionContext: 'cluster-reduce'
64
+ }));
65
+ }
66
+ }
67
+ return errors;
68
+
69
+ case 'video':
70
+ return validateObject({
71
+ key,
72
+ value,
73
+ valueSpec: styleSpec.source_video,
74
+ style,
75
+ styleSpec
76
+ });
77
+
78
+ case 'image':
79
+ return validateObject({
80
+ key,
81
+ value,
82
+ valueSpec: styleSpec.source_image,
83
+ style,
84
+ styleSpec
85
+ });
86
+
87
+ case 'canvas':
88
+ return [new ValidationError(key, null, `Please use runtime APIs to add canvas sources, rather than including them in stylesheets.`, 'source.canvas')];
89
+
90
+ default:
91
+ return validateEnum({
92
+ key: `${key}.type`,
93
+ value: value.type,
94
+ valueSpec: {values: ['vector', 'raster', 'raster-dem', 'geojson', 'video', 'image']},
95
+ style,
96
+ styleSpec
97
+ });
98
+ }
99
+ }
100
+
101
+ function validatePromoteId({key, value}) {
102
+ if (getType(value) === 'string') {
103
+ return validateString({key, value});
104
+ } else {
105
+ const errors = [];
106
+ for (const prop in value) {
107
+ errors.push(...validateString({key: `${key}.${prop}`, value: value[prop]}));
108
+ }
109
+ return errors;
110
+ }
111
+ }
@@ -0,0 +1,15 @@
1
+
2
+ import getType from '../util/get_type';
3
+ import ValidationError from '../error/validation_error';
4
+
5
+ export default function validateString(options) {
6
+ const value = options.value;
7
+ const key = options.key;
8
+ const type = getType(value);
9
+
10
+ if (type !== 'string') {
11
+ return [new ValidationError(key, value, `string expected, ${type} found`)];
12
+ }
13
+
14
+ return [];
15
+ }
@@ -0,0 +1,171 @@
1
+ // @flow
2
+
3
+ import validateStyle from './validate_style.min';
4
+ import {v8} from './style-spec';
5
+ import readStyle from './read_style';
6
+ import ValidationError from './error/validation_error';
7
+ import getType from './util/get_type';
8
+
9
+ const SUPPORTED_SPEC_VERSION = 8;
10
+ const MAX_SOURCES_IN_STYLE = 15;
11
+
12
+ function isValid(value: ?string, regex: RegExp): boolean {
13
+ if (!value || getType(value) !== 'string') return true;
14
+ return !!value.match(regex);
15
+ }
16
+
17
+ function getSourceCount(source: Object): number {
18
+ if (source.url) {
19
+ return source.url.split(',').length;
20
+ } else {
21
+ return 0;
22
+ }
23
+ }
24
+
25
+ function getAllowedKeyErrors(obj: Object, keys: Array<*>, path: ?string): Array<?ValidationError> {
26
+ const allowed = new Set(keys);
27
+ const errors = [];
28
+ Object.keys(obj).forEach(k => {
29
+ if (!allowed.has(k)) {
30
+ const prop = path ? `${path}.${k}` : null;
31
+ errors.push(new ValidationError(prop, obj[k], `Unsupported property "${k}"`));
32
+ }
33
+ });
34
+ return errors;
35
+ }
36
+
37
+ function getSourceErrors(source: Object, i: number): Array<?ValidationError> {
38
+ const errors = [];
39
+
40
+ /*
41
+ * Inlined sources are not supported by the Mapbox Styles API, so only
42
+ * "type", "url", and "tileSize" properties are valid
43
+ */
44
+ const sourceKeys = ['type', 'url', 'tileSize'];
45
+ errors.push(...getAllowedKeyErrors(source, sourceKeys, 'source'));
46
+
47
+ /*
48
+ * "source" is required. Valid examples:
49
+ * mapbox://mapbox.abcd1234
50
+ * mapbox://penny.abcd1234
51
+ * mapbox://mapbox.abcd1234,penny.abcd1234
52
+ */
53
+ const sourceUrlPattern = /^mapbox:\/\/([^/]*)$/;
54
+ if (!isValid(source.url, sourceUrlPattern)) {
55
+ errors.push(new ValidationError(`sources[${i}]`, source.url, 'Source url must be a valid Mapbox tileset url'));
56
+ }
57
+
58
+ return errors;
59
+ }
60
+
61
+ function getSourcesErrors(sources: Object): Array<?ValidationError> {
62
+ const errors = [];
63
+ let count = 0;
64
+
65
+ Object.keys(sources).forEach((s: string, i: number) => {
66
+ const sourceErrors = getSourceErrors(sources[s], i);
67
+
68
+ // If source has errors, skip counting
69
+ if (!sourceErrors.length) {
70
+ count = count + getSourceCount(sources[s]);
71
+ }
72
+
73
+ errors.push(...sourceErrors);
74
+ });
75
+
76
+ if (count > MAX_SOURCES_IN_STYLE) {
77
+ errors.push(new ValidationError('sources', null, `Styles must contain ${MAX_SOURCES_IN_STYLE} or fewer sources`));
78
+ }
79
+
80
+ return errors;
81
+ }
82
+
83
+ function getRootErrors(style: Object, specKeys: Array<any>): Array<?ValidationError> {
84
+ const errors = [];
85
+
86
+ /*
87
+ * The following keys are optional but fully managed by the Mapbox Styles
88
+ * API. Values on stylesheet on POST or PATCH will be ignored: "owner",
89
+ * "id", "cacheControl", "draft", "created", "modified"
90
+ *
91
+ * The following keys are optional. The Mapbox Styles API respects value on
92
+ * stylesheet on PATCH, but ignores the value on POST: "visibility"
93
+ */
94
+ const optionalRootProperties = [
95
+ 'owner',
96
+ 'id',
97
+ 'cacheControl',
98
+ 'draft',
99
+ 'created',
100
+ 'modified',
101
+ 'visibility'
102
+ ];
103
+
104
+ const allowedKeyErrors = getAllowedKeyErrors(style, [...specKeys, ...optionalRootProperties]);
105
+ errors.push(...allowedKeyErrors);
106
+
107
+ if (style.version > SUPPORTED_SPEC_VERSION || style.version < SUPPORTED_SPEC_VERSION) {
108
+ errors.push(new ValidationError('version', style.version, `Style version must be ${SUPPORTED_SPEC_VERSION}`));
109
+ }
110
+
111
+ /*
112
+ * "glyphs" is optional. If present, valid examples:
113
+ * mapbox://fonts/penny/{fontstack}/{range}.pbf
114
+ * mapbox://fonts/mapbox/{fontstack}/{range}.pbf
115
+ */
116
+ const glyphUrlPattern = /^mapbox:\/\/fonts\/([^/]*)\/{fontstack}\/{range}.pbf$/;
117
+ if (!isValid(style.glyphs, glyphUrlPattern)) {
118
+ errors.push(new ValidationError('glyphs', style.glyphs, 'Styles must reference glyphs hosted by Mapbox'));
119
+ }
120
+
121
+ /*
122
+ * "sprite" is optional. If present, valid examples:
123
+ * mapbox://sprites/penny/abcd1234
124
+ * mapbox://sprites/mapbox/abcd1234/draft
125
+ * mapbox://sprites/cyrus/abcd1234/abcd1234
126
+ */
127
+ const spriteUrlPattern = /^mapbox:\/\/sprites\/([^/]*)\/([^/]*)\/?([^/]*)?$/;
128
+ if (!isValid(style.sprite, spriteUrlPattern)) {
129
+ errors.push(new ValidationError('sprite', style.sprite, 'Styles must reference sprites hosted by Mapbox'));
130
+ }
131
+
132
+ /*
133
+ * "visibility" is optional. If present, valid examples:
134
+ * "private"
135
+ * "public"
136
+ */
137
+ const visibilityPattern = /^(public|private)$/;
138
+ if (!isValid(style.visibility, visibilityPattern)) {
139
+ errors.push(new ValidationError('visibility', style.visibility, 'Style visibility must be public or private'));
140
+ }
141
+
142
+ return errors;
143
+ }
144
+
145
+ /**
146
+ * Validate a Mapbox GL style against the style specification and check for
147
+ * compatibility with the Mapbox Styles API.
148
+ *
149
+ * @param {Object} style The style to be validated.
150
+ * @returns {Array<ValidationError>}
151
+ * @example
152
+ * var validateMapboxApiSupported = require('mapbox-gl-style-spec/lib/validate_style_mapbox_api_supported.js');
153
+ * var errors = validateMapboxApiSupported(style);
154
+ */
155
+ export default function validateMapboxApiSupported(style: Object): Array<?ValidationError> {
156
+ let s = style;
157
+ try {
158
+ s = readStyle(s);
159
+ } catch (e) {
160
+ return [e];
161
+ }
162
+
163
+ let errors = validateStyle(s, v8)
164
+ .concat(getRootErrors(s, Object.keys(v8.$root)));
165
+
166
+ if (s.sources) {
167
+ errors = errors.concat(getSourcesErrors(s.sources));
168
+ }
169
+
170
+ return errors;
171
+ }
@@ -0,0 +1,39 @@
1
+
2
+ import validateStyleMin from './validate_style.min';
3
+ import {v8} from './style-spec';
4
+ import readStyle from './read_style';
5
+
6
+ /**
7
+ * Validate a Mapbox GL style against the style specification.
8
+ *
9
+ * @private
10
+ * @alias validate
11
+ * @param {Object|String|Buffer} style The style to be validated. If a `String`
12
+ * or `Buffer` is provided, the returned errors will contain line numbers.
13
+ * @param {Object} [styleSpec] The style specification to validate against.
14
+ * If omitted, the spec version is inferred from the stylesheet.
15
+ * @returns {Array<ValidationError|ParsingError>}
16
+ * @example
17
+ * var validate = require('mapbox-gl-style-spec').validate;
18
+ * var style = fs.readFileSync('./style.json', 'utf8');
19
+ * var errors = validate(style);
20
+ */
21
+
22
+ export default function validateStyle(style, styleSpec = v8) {
23
+ let s = style;
24
+
25
+ try {
26
+ s = readStyle(s);
27
+ } catch (e) {
28
+ return [e];
29
+ }
30
+
31
+ return validateStyleMin(s, styleSpec);
32
+ }
33
+
34
+ export const source = validateStyleMin.source;
35
+ export const light = validateStyleMin.light;
36
+ export const layer = validateStyleMin.layer;
37
+ export const filter = validateStyleMin.filter;
38
+ export const paintProperty = validateStyleMin.paintProperty;
39
+ export const layoutProperty = validateStyleMin.layoutProperty;
@@ -0,0 +1,78 @@
1
+
2
+ import validateConstants from './validate/validate_constants';
3
+ import validate from './validate/validate';
4
+ import latestStyleSpec from './reference/latest';
5
+ import validateGlyphsURL from './validate/validate_glyphs_url';
6
+
7
+ import validateSource from './validate/validate_source';
8
+ import validateLight from './validate/validate_light';
9
+ import validateLayer from './validate/validate_layer';
10
+ import validateFilter from './validate/validate_filter';
11
+ import validatePaintProperty from './validate/validate_paint_property';
12
+ import validateLayoutProperty from './validate/validate_layout_property';
13
+
14
+ /**
15
+ * Validate a Mapbox GL style against the style specification. This entrypoint,
16
+ * `mapbox-gl-style-spec/lib/validate_style.min`, is designed to produce as
17
+ * small a browserify bundle as possible by omitting unnecessary functionality
18
+ * and legacy style specifications.
19
+ *
20
+ * @private
21
+ * @param {Object} style The style to be validated.
22
+ * @param {Object} [styleSpec] The style specification to validate against.
23
+ * If omitted, the latest style spec is used.
24
+ * @returns {Array<ValidationError>}
25
+ * @example
26
+ * var validate = require('mapbox-gl-style-spec/lib/validate_style.min');
27
+ * var errors = validate(style);
28
+ */
29
+ function validateStyleMin(style, styleSpec = latestStyleSpec) {
30
+
31
+ let errors = [];
32
+
33
+ errors = errors.concat(validate({
34
+ key: '',
35
+ value: style,
36
+ valueSpec: styleSpec.$root,
37
+ styleSpec,
38
+ style,
39
+ objectElementValidators: {
40
+ glyphs: validateGlyphsURL,
41
+ '*'() {
42
+ return [];
43
+ }
44
+ }
45
+ }));
46
+
47
+ if (style.constants) {
48
+ errors = errors.concat(validateConstants({
49
+ key: 'constants',
50
+ value: style.constants,
51
+ style,
52
+ styleSpec
53
+ }));
54
+ }
55
+
56
+ return sortErrors(errors);
57
+ }
58
+
59
+ validateStyleMin.source = wrapCleanErrors(validateSource);
60
+ validateStyleMin.light = wrapCleanErrors(validateLight);
61
+ validateStyleMin.layer = wrapCleanErrors(validateLayer);
62
+ validateStyleMin.filter = wrapCleanErrors(validateFilter);
63
+ validateStyleMin.paintProperty = wrapCleanErrors(validatePaintProperty);
64
+ validateStyleMin.layoutProperty = wrapCleanErrors(validateLayoutProperty);
65
+
66
+ function sortErrors(errors) {
67
+ return [].concat(errors).sort((a, b) => {
68
+ return a.line - b.line;
69
+ });
70
+ }
71
+
72
+ function wrapCleanErrors(inner) {
73
+ return function(...args) {
74
+ return sortErrors(inner.apply(this, args));
75
+ };
76
+ }
77
+
78
+ export default validateStyleMin;
@@ -0,0 +1,77 @@
1
+ // @flow
2
+
3
+ import Reference from './reference/v8.json';
4
+ import type {StylePropertySpecification} from './style-spec';
5
+ import type {
6
+ StyleSpecification,
7
+ SourceSpecification,
8
+ LayerSpecification,
9
+ PropertyValueSpecification,
10
+ DataDrivenPropertyValueSpecification
11
+ } from './types';
12
+
13
+ function getPropertyReference(propertyName): StylePropertySpecification {
14
+ for (let i = 0; i < Reference.layout.length; i++) {
15
+ for (const key in Reference[Reference.layout[i]]) {
16
+ if (key === propertyName) return (Reference[Reference.layout[i]][key]: any);
17
+ }
18
+ }
19
+ for (let i = 0; i < Reference.paint.length; i++) {
20
+ for (const key in Reference[Reference.paint[i]]) {
21
+ if (key === propertyName) return (Reference[Reference.paint[i]][key]: any);
22
+ }
23
+ }
24
+
25
+ return (null: any);
26
+ }
27
+
28
+ export function eachSource(style: StyleSpecification, callback: (_: SourceSpecification) => void) {
29
+ for (const k in style.sources) {
30
+ callback(style.sources[k]);
31
+ }
32
+ }
33
+
34
+ export function eachLayer(style: StyleSpecification, callback: (_: LayerSpecification) => void) {
35
+ for (const layer of style.layers) {
36
+ callback(layer);
37
+ }
38
+ }
39
+
40
+ type PropertyCallback = ({
41
+ path: [string, 'paint' | 'layout', string], // [layerid, paint/layout, property key]
42
+ key: string,
43
+ value: PropertyValueSpecification<mixed> | DataDrivenPropertyValueSpecification<mixed>,
44
+ reference: StylePropertySpecification,
45
+ set: (PropertyValueSpecification<mixed> | DataDrivenPropertyValueSpecification<mixed>) => void
46
+ }) => void;
47
+
48
+ export function eachProperty(
49
+ style: StyleSpecification,
50
+ options: {paint?: boolean, layout?: boolean},
51
+ callback: PropertyCallback
52
+ ) {
53
+ function inner(layer, propertyType: 'paint' | 'layout') {
54
+ const properties = (layer[propertyType]: any);
55
+ if (!properties) return;
56
+ Object.keys(properties).forEach((key) => {
57
+ callback({
58
+ path: [layer.id, propertyType, key],
59
+ key,
60
+ value: properties[key],
61
+ reference: getPropertyReference(key),
62
+ set(x) {
63
+ properties[key] = x;
64
+ }
65
+ });
66
+ });
67
+ }
68
+
69
+ eachLayer(style, (layer) => {
70
+ if (options.paint) {
71
+ inner(layer, 'paint');
72
+ }
73
+ if (options.layout) {
74
+ inner(layer, 'layout');
75
+ }
76
+ });
77
+ }
@@ -0,0 +1,26 @@
1
+ // @flow
2
+
3
+ import Point from '@mapbox/point-geometry';
4
+
5
+ import {register} from '../util/web_worker_transfer';
6
+
7
+ class Anchor extends Point {
8
+ angle: any;
9
+ segment: number | void;
10
+
11
+ constructor(x: number, y: number, angle: number, segment?: number) {
12
+ super(x, y);
13
+ this.angle = angle;
14
+ if (segment !== undefined) {
15
+ this.segment = segment;
16
+ }
17
+ }
18
+
19
+ clone() {
20
+ return new Anchor(this.x, this.y, this.angle, this.segment);
21
+ }
22
+ }
23
+
24
+ register('Anchor', Anchor);
25
+
26
+ export default Anchor;
@@ -0,0 +1,81 @@
1
+ // @flow
2
+
3
+ export default checkMaxAngle;
4
+
5
+ import type Point from '@mapbox/point-geometry';
6
+ import type Anchor from './anchor';
7
+
8
+ /**
9
+ * Labels placed around really sharp angles aren't readable. Check if any
10
+ * part of the potential label has a combined angle that is too big.
11
+ *
12
+ * @param line
13
+ * @param anchor The point on the line around which the label is anchored.
14
+ * @param labelLength The length of the label in geometry units.
15
+ * @param windowSize The check fails if the combined angles within a part of the line that is `windowSize` long is too big.
16
+ * @param maxAngle The maximum combined angle that any window along the label is allowed to have.
17
+ *
18
+ * @returns {boolean} whether the label should be placed
19
+ * @private
20
+ */
21
+ function checkMaxAngle(line: Array<Point>, anchor: Anchor, labelLength: number, windowSize: number, maxAngle: number) {
22
+
23
+ // horizontal labels always pass
24
+ if (anchor.segment === undefined) return true;
25
+
26
+ let p = anchor;
27
+ let index = anchor.segment + 1;
28
+ let anchorDistance = 0;
29
+
30
+ // move backwards along the line to the first segment the label appears on
31
+ while (anchorDistance > -labelLength / 2) {
32
+ index--;
33
+
34
+ // there isn't enough room for the label after the beginning of the line
35
+ if (index < 0) return false;
36
+
37
+ anchorDistance -= line[index].dist(p);
38
+ p = line[index];
39
+ }
40
+
41
+ anchorDistance += line[index].dist(line[index + 1]);
42
+ index++;
43
+
44
+ // store recent corners and their total angle difference
45
+ const recentCorners = [];
46
+ let recentAngleDelta = 0;
47
+
48
+ // move forwards by the length of the label and check angles along the way
49
+ while (anchorDistance < labelLength / 2) {
50
+ const prev = line[index - 1];
51
+ const current = line[index];
52
+ const next = line[index + 1];
53
+
54
+ // there isn't enough room for the label before the end of the line
55
+ if (!next) return false;
56
+
57
+ let angleDelta = prev.angleTo(current) - current.angleTo(next);
58
+ // restrict angle to -pi..pi range
59
+ angleDelta = Math.abs(((angleDelta + 3 * Math.PI) % (Math.PI * 2)) - Math.PI);
60
+
61
+ recentCorners.push({
62
+ distance: anchorDistance,
63
+ angleDelta
64
+ });
65
+ recentAngleDelta += angleDelta;
66
+
67
+ // remove corners that are far enough away from the list of recent anchors
68
+ while (anchorDistance - recentCorners[0].distance > windowSize) {
69
+ recentAngleDelta -= recentCorners.shift().angleDelta;
70
+ }
71
+
72
+ // the sum of angles within the window area exceeds the maximum allowed value. check fails.
73
+ if (recentAngleDelta > maxAngle) return false;
74
+
75
+ index++;
76
+ anchorDistance += current.dist(next);
77
+ }
78
+
79
+ // no part of the line had an angle greater than the maximum allowed. check passes.
80
+ return true;
81
+ }