@mapgis/mapbox-gl 16.0.1 → 16.2.0

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 (434) hide show
  1. package/dist/mapbox-gl.js +3 -3
  2. package/dist/mapbox-gl.js.map +1 -1
  3. package/package.json +1 -1
  4. package/.flowconfig +0 -61
  5. package/LICENSE.txt +0 -84
  6. package/README.md +0 -34
  7. package/build/banner.js +0 -4
  8. package/build/check-bundle-size.js +0 -140
  9. package/build/generate-access-token-script.js +0 -11
  10. package/build/generate-flow-typed-style-spec.js +0 -188
  11. package/build/generate-release-list.js +0 -21
  12. package/build/generate-struct-arrays.js +0 -237
  13. package/build/generate-style-code.js +0 -159
  14. package/build/mapbox-gl.js.flow +0 -3
  15. package/build/print-release-url.js +0 -6
  16. package/build/rollup_plugin_minify_style_spec.js +0 -20
  17. package/build/rollup_plugins.js +0 -80
  18. package/build/run-node +0 -3
  19. package/build/run-tap +0 -8
  20. package/build/test/build-tape.js +0 -19
  21. package/flow-typed/gl.js +0 -5
  22. package/flow-typed/jsdom.js +0 -18
  23. package/flow-typed/mapbox-gl-supported.js +0 -9
  24. package/flow-typed/mapbox-unitbezier.js +0 -14
  25. package/flow-typed/offscreen-canvas.js +0 -9
  26. package/flow-typed/pbf.js +0 -25
  27. package/flow-typed/point-geometry.js +0 -44
  28. package/flow-typed/potpack.js +0 -12
  29. package/flow-typed/sinon.js +0 -28
  30. package/flow-typed/vector-tile.js +0 -41
  31. package/src/css/mapbox-gl.css +0 -798
  32. package/src/css/svg/mapboxgl-ctrl-attrib.svg +0 -3
  33. package/src/css/svg/mapboxgl-ctrl-compass.svg +0 -4
  34. package/src/css/svg/mapboxgl-ctrl-fullscreen.svg +0 -3
  35. package/src/css/svg/mapboxgl-ctrl-geolocate.svg +0 -5
  36. package/src/css/svg/mapboxgl-ctrl-logo.svg +0 -20
  37. package/src/css/svg/mapboxgl-ctrl-shrink.svg +0 -3
  38. package/src/css/svg/mapboxgl-ctrl-zoom-in.svg +0 -3
  39. package/src/css/svg/mapboxgl-ctrl-zoom-out.svg +0 -3
  40. package/src/data/array_types.js +0 -1095
  41. package/src/data/bucket/circle_attributes.js +0 -9
  42. package/src/data/bucket/circle_bucket.js +0 -204
  43. package/src/data/bucket/fill_attributes.js +0 -9
  44. package/src/data/bucket/fill_bucket.js +0 -233
  45. package/src/data/bucket/fill_extrusion_attributes.js +0 -10
  46. package/src/data/bucket/fill_extrusion_bucket.js +0 -289
  47. package/src/data/bucket/heatmap_bucket.js +0 -17
  48. package/src/data/bucket/line_attributes.js +0 -10
  49. package/src/data/bucket/line_bucket.js +0 -556
  50. package/src/data/bucket/pattern_attributes.js +0 -10
  51. package/src/data/bucket/pattern_bucket_features.js +0 -60
  52. package/src/data/bucket/symbol_attributes.js +0 -117
  53. package/src/data/bucket/symbol_bucket.js +0 -972
  54. package/src/data/bucket.js +0 -123
  55. package/src/data/dem_data.js +0 -125
  56. package/src/data/extent.js +0 -18
  57. package/src/data/feature_index.js +0 -321
  58. package/src/data/feature_position_map.js +0 -125
  59. package/src/data/index_array_type.js +0 -16
  60. package/src/data/load_geometry.js +0 -48
  61. package/src/data/pos_attributes.js +0 -6
  62. package/src/data/program_configuration.js +0 -687
  63. package/src/data/raster_bounds_attributes.js +0 -7
  64. package/src/data/segment.js +0 -76
  65. package/src/geo/edge_insets.js +0 -102
  66. package/src/geo/lng_lat.js +0 -165
  67. package/src/geo/lng_lat_bounds.js +0 -267
  68. package/src/geo/mercator_coordinate.js +0 -153
  69. package/src/geo/transform.js +0 -864
  70. package/src/gl/color_mode.js +0 -34
  71. package/src/gl/context.js +0 -298
  72. package/src/gl/cull_face_mode.js +0 -26
  73. package/src/gl/depth_mode.js +0 -29
  74. package/src/gl/framebuffer.js +0 -44
  75. package/src/gl/index_buffer.js +0 -55
  76. package/src/gl/stencil_mode.js +0 -30
  77. package/src/gl/types.js +0 -84
  78. package/src/gl/value.js +0 -520
  79. package/src/gl/vertex_buffer.js +0 -119
  80. package/src/index.js +0 -201
  81. package/src/render/draw_background.js +0 -57
  82. package/src/render/draw_circle.js +0 -113
  83. package/src/render/draw_collision_debug.js +0 -49
  84. package/src/render/draw_custom.js +0 -49
  85. package/src/render/draw_debug.js +0 -127
  86. package/src/render/draw_fill.js +0 -126
  87. package/src/render/draw_fill_extrusion.js +0 -96
  88. package/src/render/draw_heatmap.js +0 -140
  89. package/src/render/draw_hillshade.js +0 -108
  90. package/src/render/draw_line.js +0 -98
  91. package/src/render/draw_raster.js +0 -125
  92. package/src/render/draw_symbol.js +0 -394
  93. package/src/render/glyph_atlas.js +0 -71
  94. package/src/render/glyph_manager.js +0 -182
  95. package/src/render/image_atlas.js +0 -149
  96. package/src/render/image_manager.js +0 -306
  97. package/src/render/line_atlas.js +0 -210
  98. package/src/render/painter.js +0 -653
  99. package/src/render/program/background_program.js +0 -103
  100. package/src/render/program/circle_program.js +0 -69
  101. package/src/render/program/clipping_mask_program.js +0 -20
  102. package/src/render/program/collision_program.js +0 -49
  103. package/src/render/program/debug_program.js +0 -35
  104. package/src/render/program/fill_extrusion_program.js +0 -122
  105. package/src/render/program/fill_program.js +0 -126
  106. package/src/render/program/heatmap_program.js +0 -83
  107. package/src/render/program/hillshade_program.js +0 -122
  108. package/src/render/program/line_program.js +0 -207
  109. package/src/render/program/pattern.js +0 -102
  110. package/src/render/program/program_uniforms.js +0 -42
  111. package/src/render/program/raster_program.js +0 -92
  112. package/src/render/program/symbol_program.js +0 -224
  113. package/src/render/program.js +0 -168
  114. package/src/render/texture.js +0 -122
  115. package/src/render/uniform_binding.js +0 -147
  116. package/src/render/vertex_array_object.js +0 -163
  117. package/src/shaders/README.md +0 -42
  118. package/src/shaders/_prelude.fragment.glsl +0 -17
  119. package/src/shaders/_prelude.vertex.glsl +0 -73
  120. package/src/shaders/background.fragment.glsl +0 -10
  121. package/src/shaders/background.vertex.glsl +0 -7
  122. package/src/shaders/background_pattern.fragment.glsl +0 -28
  123. package/src/shaders/background_pattern.vertex.glsl +0 -20
  124. package/src/shaders/circle.fragment.glsl +0 -39
  125. package/src/shaders/circle.vertex.glsl +0 -64
  126. package/src/shaders/clipping_mask.fragment.glsl +0 -3
  127. package/src/shaders/clipping_mask.vertex.glsl +0 -7
  128. package/src/shaders/collision_box.fragment.glsl +0 -21
  129. package/src/shaders/collision_box.vertex.glsl +0 -27
  130. package/src/shaders/collision_circle.fragment.glsl +0 -34
  131. package/src/shaders/collision_circle.vertex.glsl +0 -36
  132. package/src/shaders/debug.fragment.glsl +0 -9
  133. package/src/shaders/debug.vertex.glsl +0 -12
  134. package/src/shaders/encode_attribute.js +0 -17
  135. package/src/shaders/fill.fragment.glsl +0 -13
  136. package/src/shaders/fill.vertex.glsl +0 -13
  137. package/src/shaders/fill_extrusion.fragment.glsl +0 -9
  138. package/src/shaders/fill_extrusion.vertex.glsl +0 -66
  139. package/src/shaders/fill_extrusion_pattern.fragment.glsl +0 -45
  140. package/src/shaders/fill_extrusion_pattern.vertex.glsl +0 -79
  141. package/src/shaders/fill_outline.fragment.glsl +0 -17
  142. package/src/shaders/fill_outline.vertex.glsl +0 -17
  143. package/src/shaders/fill_outline_pattern.fragment.glsl +0 -43
  144. package/src/shaders/fill_outline_pattern.vertex.glsl +0 -44
  145. package/src/shaders/fill_pattern.fragment.glsl +0 -36
  146. package/src/shaders/fill_pattern.vertex.glsl +0 -39
  147. package/src/shaders/heatmap.fragment.glsl +0 -22
  148. package/src/shaders/heatmap.vertex.glsl +0 -54
  149. package/src/shaders/heatmap_texture.fragment.glsl +0 -14
  150. package/src/shaders/heatmap_texture.vertex.glsl +0 -11
  151. package/src/shaders/hillshade.fragment.glsl +0 -52
  152. package/src/shaders/hillshade.vertex.glsl +0 -11
  153. package/src/shaders/hillshade_prepare.fragment.glsl +0 -74
  154. package/src/shaders/hillshade_prepare.vertex.glsl +0 -15
  155. package/src/shaders/index.js +0 -20
  156. package/src/shaders/line.fragment.glsl +0 -30
  157. package/src/shaders/line.vertex.glsl +0 -85
  158. package/src/shaders/line_gradient.fragment.glsl +0 -34
  159. package/src/shaders/line_gradient.vertex.glsl +0 -87
  160. package/src/shaders/line_pattern.fragment.glsl +0 -74
  161. package/src/shaders/line_pattern.vertex.glsl +0 -99
  162. package/src/shaders/line_sdf.fragment.glsl +0 -45
  163. package/src/shaders/line_sdf.vertex.glsl +0 -98
  164. package/src/shaders/raster.fragment.glsl +0 -52
  165. package/src/shaders/raster.vertex.glsl +0 -21
  166. package/src/shaders/shaders.js +0 -180
  167. package/src/shaders/symbol_icon.fragment.glsl +0 -17
  168. package/src/shaders/symbol_icon.vertex.glsl +0 -94
  169. package/src/shaders/symbol_sdf.fragment.glsl +0 -52
  170. package/src/shaders/symbol_sdf.vertex.glsl +0 -115
  171. package/src/shaders/symbol_text_and_icon.fragment.glsl +0 -68
  172. package/src/shaders/symbol_text_and_icon.vertex.glsl +0 -116
  173. package/src/source/canvas_source.js +0 -238
  174. package/src/source/geojson_helper.js +0 -92
  175. package/src/source/geojson_source.js +0 -374
  176. package/src/source/geojson_worker_source.js +0 -357
  177. package/src/source/geojson_wrapper.js +0 -94
  178. package/src/source/image_source.js +0 -307
  179. package/src/source/load_tilejson.js +0 -39
  180. package/src/source/mbtiles_source.js +0 -115
  181. package/src/source/offline_database.js +0 -61
  182. package/src/source/offline_database_root.js +0 -62
  183. package/src/source/pixels_to_tile_units.js +0 -21
  184. package/src/source/query_features.js +0 -208
  185. package/src/source/raster_dem_tile_source.js +0 -138
  186. package/src/source/raster_dem_tile_worker_source.js +0 -62
  187. package/src/source/raster_tile_offline_source.js +0 -136
  188. package/src/source/raster_tile_source.js +0 -177
  189. package/src/source/rtl_text_plugin.js +0 -138
  190. package/src/source/source.js +0 -137
  191. package/src/source/source_cache.js +0 -957
  192. package/src/source/source_state.js +0 -159
  193. package/src/source/tile.js +0 -465
  194. package/src/source/tile_bounds.js +0 -38
  195. package/src/source/tile_cache.js +0 -212
  196. package/src/source/tile_id.js +0 -402
  197. package/src/source/vector_tile_source.js +0 -192
  198. package/src/source/vector_tile_worker_source.js +0 -216
  199. package/src/source/video_source.js +0 -203
  200. package/src/source/worker.js +0 -237
  201. package/src/source/worker_source.js +0 -106
  202. package/src/source/worker_tile.js +0 -224
  203. package/src/style/create_style_layer.js +0 -36
  204. package/src/style/evaluation_parameters.js +0 -62
  205. package/src/style/light.js +0 -130
  206. package/src/style/load_glyph_range.js +0 -38
  207. package/src/style/load_sprite.js +0 -67
  208. package/src/style/parse_glyph_pbf.js +0 -44
  209. package/src/style/pauseable_placement.js +0 -132
  210. package/src/style/properties.js +0 -753
  211. package/src/style/query_utils.js +0 -43
  212. package/src/style/style.js +0 -1361
  213. package/src/style/style_glyph.js +0 -17
  214. package/src/style/style_image.js +0 -137
  215. package/src/style/style_layer/background_style_layer.js +0 -21
  216. package/src/style/style_layer/background_style_layer_properties.js +0 -40
  217. package/src/style/style_layer/circle_style_layer.js +0 -98
  218. package/src/style/style_layer/circle_style_layer_properties.js +0 -63
  219. package/src/style/style_layer/custom_style_layer.js +0 -223
  220. package/src/style/style_layer/fill_extrusion_style_layer.js +0 -224
  221. package/src/style/style_layer/fill_extrusion_style_layer_properties.js +0 -50
  222. package/src/style/style_layer/fill_style_layer.js +0 -67
  223. package/src/style/style_layer/fill_style_layer_properties.js +0 -55
  224. package/src/style/style_layer/heatmap_style_layer.js +0 -69
  225. package/src/style/style_layer/heatmap_style_layer_properties.js +0 -44
  226. package/src/style/style_layer/hillshade_style_layer.js +0 -25
  227. package/src/style/style_layer/hillshade_style_layer_properties.js +0 -46
  228. package/src/style/style_layer/layer_properties.js.ejs +0 -69
  229. package/src/style/style_layer/line_style_layer.js +0 -151
  230. package/src/style/style_layer/line_style_layer_properties.js +0 -71
  231. package/src/style/style_layer/raster_style_layer.js +0 -21
  232. package/src/style/style_layer/raster_style_layer_properties.js +0 -50
  233. package/src/style/style_layer/symbol_style_layer.js +0 -190
  234. package/src/style/style_layer/symbol_style_layer_properties.js +0 -153
  235. package/src/style/style_layer/typed_style_layer.js +0 -17
  236. package/src/style/style_layer.js +0 -281
  237. package/src/style/style_layer_index.js +0 -80
  238. package/src/style/validate_style.js +0 -42
  239. package/src/style/zoom_history.js +0 -44
  240. package/src/style-spec/.eslintrc +0 -5
  241. package/src/style-spec/CHANGELOG.md +0 -438
  242. package/src/style-spec/README.md +0 -59
  243. package/src/style-spec/bin/gl-style-composite +0 -9
  244. package/src/style-spec/bin/gl-style-format +0 -22
  245. package/src/style-spec/bin/gl-style-migrate +0 -9
  246. package/src/style-spec/bin/gl-style-validate +0 -50
  247. package/src/style-spec/composite.js +0 -50
  248. package/src/style-spec/declass.js +0 -42
  249. package/src/style-spec/deref.js +0 -52
  250. package/src/style-spec/diff.js +0 -393
  251. package/src/style-spec/dist/.gitkeep +0 -0
  252. package/src/style-spec/empty.js +0 -29
  253. package/src/style-spec/error/parsing_error.js +0 -16
  254. package/src/style-spec/error/validation_error.js +0 -18
  255. package/src/style-spec/expression/compound_expression.js +0 -162
  256. package/src/style-spec/expression/definitions/assertion.js +0 -130
  257. package/src/style-spec/expression/definitions/at.js +0 -70
  258. package/src/style-spec/expression/definitions/case.js +0 -85
  259. package/src/style-spec/expression/definitions/coalesce.js +0 -93
  260. package/src/style-spec/expression/definitions/coercion.js +0 -133
  261. package/src/style-spec/expression/definitions/collator.js +0 -78
  262. package/src/style-spec/expression/definitions/comparison.js +0 -184
  263. package/src/style-spec/expression/definitions/format.js +0 -144
  264. package/src/style-spec/expression/definitions/format_section_override.js +0 -54
  265. package/src/style-spec/expression/definitions/image.js +0 -52
  266. package/src/style-spec/expression/definitions/in.js +0 -92
  267. package/src/style-spec/expression/definitions/index.js +0 -561
  268. package/src/style-spec/expression/definitions/interpolate.js +0 -267
  269. package/src/style-spec/expression/definitions/length.js +0 -61
  270. package/src/style-spec/expression/definitions/let.js +0 -72
  271. package/src/style-spec/expression/definitions/literal.js +0 -77
  272. package/src/style-spec/expression/definitions/match.js +0 -158
  273. package/src/style-spec/expression/definitions/number_format.js +0 -142
  274. package/src/style-spec/expression/definitions/step.js +0 -120
  275. package/src/style-spec/expression/definitions/var.js +0 -46
  276. package/src/style-spec/expression/definitions/within.js +0 -333
  277. package/src/style-spec/expression/evaluation_context.js +0 -59
  278. package/src/style-spec/expression/expression.js +0 -27
  279. package/src/style-spec/expression/index.js +0 -392
  280. package/src/style-spec/expression/is_constant.js +0 -59
  281. package/src/style-spec/expression/parsing_context.js +0 -233
  282. package/src/style-spec/expression/parsing_error.js +0 -13
  283. package/src/style-spec/expression/runtime_error.js +0 -17
  284. package/src/style-spec/expression/scope.js +0 -36
  285. package/src/style-spec/expression/stops.js +0 -39
  286. package/src/style-spec/expression/types/collator.js +0 -61
  287. package/src/style-spec/expression/types/formatted.js +0 -73
  288. package/src/style-spec/expression/types/resolved_image.js +0 -29
  289. package/src/style-spec/expression/types.js +0 -106
  290. package/src/style-spec/expression/values.js +0 -123
  291. package/src/style-spec/feature_filter/README.md +0 -55
  292. package/src/style-spec/feature_filter/convert.js +0 -208
  293. package/src/style-spec/feature_filter/index.js +0 -165
  294. package/src/style-spec/format.js +0 -51
  295. package/src/style-spec/function/convert.js +0 -254
  296. package/src/style-spec/function/index.js +0 -262
  297. package/src/style-spec/group_by_layout.js +0 -75
  298. package/src/style-spec/migrate/expressions.js +0 -39
  299. package/src/style-spec/migrate/v8.js +0 -203
  300. package/src/style-spec/migrate/v9.js +0 -26
  301. package/src/style-spec/migrate.js +0 -36
  302. package/src/style-spec/package.json +0 -41
  303. package/src/style-spec/read_style.js +0 -14
  304. package/src/style-spec/reference/latest.js +0 -3
  305. package/src/style-spec/reference/v8.json +0 -5808
  306. package/src/style-spec/rollup.config.js +0 -45
  307. package/src/style-spec/style-spec.js +0 -122
  308. package/src/style-spec/types.js +0 -438
  309. package/src/style-spec/util/color.js +0 -95
  310. package/src/style-spec/util/color_spaces.js +0 -139
  311. package/src/style-spec/util/deep_equal.js +0 -28
  312. package/src/style-spec/util/extend.js +0 -10
  313. package/src/style-spec/util/get_type.js +0 -17
  314. package/src/style-spec/util/interpolate.js +0 -22
  315. package/src/style-spec/util/properties.js +0 -15
  316. package/src/style-spec/util/ref_properties.js +0 -2
  317. package/src/style-spec/util/result.js +0 -19
  318. package/src/style-spec/util/unbundle_jsonlint.js +0 -24
  319. package/src/style-spec/validate/latest.js +0 -11
  320. package/src/style-spec/validate/validate.js +0 -75
  321. package/src/style-spec/validate/validate_array.js +0 -52
  322. package/src/style-spec/validate/validate_boolean.js +0 -15
  323. package/src/style-spec/validate/validate_color.js +0 -20
  324. package/src/style-spec/validate/validate_constants.js +0 -13
  325. package/src/style-spec/validate/validate_enum.js +0 -21
  326. package/src/style-spec/validate/validate_expression.js +0 -43
  327. package/src/style-spec/validate/validate_filter.js +0 -111
  328. package/src/style-spec/validate/validate_formatted.js +0 -11
  329. package/src/style-spec/validate/validate_function.js +0 -207
  330. package/src/style-spec/validate/validate_glyphs_url.js +0 -21
  331. package/src/style-spec/validate/validate_image.js +0 -11
  332. package/src/style-spec/validate/validate_layer.js +0 -134
  333. package/src/style-spec/validate/validate_layout_property.js +0 -6
  334. package/src/style-spec/validate/validate_light.js +0 -47
  335. package/src/style-spec/validate/validate_number.js +0 -29
  336. package/src/style-spec/validate/validate_object.js +0 -61
  337. package/src/style-spec/validate/validate_paint_property.js +0 -6
  338. package/src/style-spec/validate/validate_property.js +0 -64
  339. package/src/style-spec/validate/validate_source.js +0 -111
  340. package/src/style-spec/validate/validate_string.js +0 -15
  341. package/src/style-spec/validate_mapbox_api_supported.js +0 -171
  342. package/src/style-spec/validate_style.js +0 -39
  343. package/src/style-spec/validate_style.min.js +0 -78
  344. package/src/style-spec/visit.js +0 -77
  345. package/src/symbol/anchor.js +0 -26
  346. package/src/symbol/check_max_angle.js +0 -81
  347. package/src/symbol/clip_line.js +0 -71
  348. package/src/symbol/collision_feature.js +0 -217
  349. package/src/symbol/collision_index.js +0 -372
  350. package/src/symbol/cross_tile_symbol_index.js +0 -301
  351. package/src/symbol/get_anchors.js +0 -167
  352. package/src/symbol/grid_index.js +0 -335
  353. package/src/symbol/mergelines.js +0 -82
  354. package/src/symbol/one_em.js +0 -4
  355. package/src/symbol/opacity_state.js +0 -27
  356. package/src/symbol/placement.js +0 -1062
  357. package/src/symbol/projection.js +0 -450
  358. package/src/symbol/quads.js +0 -334
  359. package/src/symbol/shaping.js +0 -816
  360. package/src/symbol/symbol_layout.js +0 -772
  361. package/src/symbol/symbol_size.js +0 -113
  362. package/src/symbol/transform_text.js +0 -29
  363. package/src/types/callback.js +0 -17
  364. package/src/types/cancelable.js +0 -3
  365. package/src/types/tilejson.js +0 -17
  366. package/src/types/transferable.js +0 -3
  367. package/src/types/window.js +0 -172
  368. package/src/ui/anchor.js +0 -32
  369. package/src/ui/bind_handlers.js +0 -202
  370. package/src/ui/camera.js +0 -1152
  371. package/src/ui/control/attribution_control.js +0 -189
  372. package/src/ui/control/fps_control.js +0 -185
  373. package/src/ui/control/fullscreen_control.js +0 -147
  374. package/src/ui/control/geolocate_control.js +0 -594
  375. package/src/ui/control/logo_control.js +0 -92
  376. package/src/ui/control/navigation_control.js +0 -148
  377. package/src/ui/control/scale_control.js +0 -142
  378. package/src/ui/crs.js +0 -64
  379. package/src/ui/default_locale.js +0 -20
  380. package/src/ui/events.js +0 -806
  381. package/src/ui/handler/box_zoom.js +0 -175
  382. package/src/ui/handler/dblclick_zoom.js +0 -139
  383. package/src/ui/handler/drag_pan.js +0 -416
  384. package/src/ui/handler/drag_rotate.js +0 -378
  385. package/src/ui/handler/keyboard.js +0 -161
  386. package/src/ui/handler/scroll_zoom.js +0 -333
  387. package/src/ui/handler/touch_zoom_rotate.js +0 -293
  388. package/src/ui/hash.js +0 -147
  389. package/src/ui/map.js +0 -2883
  390. package/src/ui/marker.js +0 -607
  391. package/src/ui/offline_map.js +0 -91
  392. package/src/ui/popup.js +0 -530
  393. package/src/util/actor.js +0 -212
  394. package/src/util/ajax.js +0 -371
  395. package/src/util/browser/web_worker.js +0 -10
  396. package/src/util/browser/window.js +0 -5
  397. package/src/util/browser.js +0 -70
  398. package/src/util/classify_rings.js +0 -52
  399. package/src/util/color_ramp.js +0 -28
  400. package/src/util/config.js +0 -30
  401. package/src/util/debug.js +0 -12
  402. package/src/util/dictionary_coder.js +0 -30
  403. package/src/util/dispatcher.js +0 -70
  404. package/src/util/dom.js +0 -144
  405. package/src/util/evented.js +0 -174
  406. package/src/util/find_pole_of_inaccessibility.js +0 -129
  407. package/src/util/global_worker_pool.js +0 -17
  408. package/src/util/image.js +0 -142
  409. package/src/util/intersection_tests.js +0 -208
  410. package/src/util/is_char_in_unicode_block.js +0 -311
  411. package/src/util/mapbox.js +0 -486
  412. package/src/util/offscreen_canvas_supported.js +0 -14
  413. package/src/util/performance.js +0 -112
  414. package/src/util/primitives.js +0 -145
  415. package/src/util/resolve_tokens.js +0 -16
  416. package/src/util/script_detection.js +0 -328
  417. package/src/util/sku_token.js +0 -42
  418. package/src/util/smart_wrap.js +0 -55
  419. package/src/util/struct_array.js +0 -243
  420. package/src/util/struct_array.js.ejs +0 -112
  421. package/src/util/struct_array_layout.js.ejs +0 -98
  422. package/src/util/task_queue.js +0 -68
  423. package/src/util/throttle.js +0 -28
  424. package/src/util/throttled_invoker.js +0 -46
  425. package/src/util/tile_cover.js +0 -101
  426. package/src/util/tile_request_cache.js +0 -172
  427. package/src/util/util.js +0 -504
  428. package/src/util/vectortile_to_geojson.js +0 -54
  429. package/src/util/verticalize_punctuation.js +0 -114
  430. package/src/util/web_worker.js +0 -91
  431. package/src/util/web_worker_transfer.js +0 -266
  432. package/src/util/webp_supported.js +0 -69
  433. package/src/util/window.js +0 -102
  434. package/src/util/worker_pool.js +0 -47
@@ -1,753 +0,0 @@
1
- // @flow
2
-
3
- import assert from 'assert';
4
- import {clone, extend, easeCubicInOut} from '../util/util';
5
- import * as interpolate from '../style-spec/util/interpolate';
6
- import {normalizePropertyExpression} from '../style-spec/expression';
7
- import Color from '../style-spec/util/color';
8
- import {register} from '../util/web_worker_transfer';
9
- import EvaluationParameters from './evaluation_parameters';
10
-
11
- import type {CanonicalTileID} from '../source/tile_id';
12
- import type {StylePropertySpecification} from '../style-spec/style-spec';
13
- import type {
14
- TransitionSpecification,
15
- PropertyValueSpecification
16
- } from '../style-spec/types';
17
-
18
- import type {
19
- Feature,
20
- FeatureState,
21
- StylePropertyExpression,
22
- SourceExpression,
23
- CompositeExpression
24
- } from '../style-spec/expression';
25
-
26
- type TimePoint = number;
27
-
28
- export type CrossFaded<T> = {
29
- to: T,
30
- from: T
31
- };
32
-
33
- /**
34
- * Implements a number of classes that define state and behavior for paint and layout properties, most
35
- * importantly their respective evaluation chains:
36
- *
37
- * Transitionable paint property value
38
- * → Transitioning paint property value
39
- * → Possibly evaluated paint property value
40
- * → Fully evaluated paint property value
41
- *
42
- * Layout property value
43
- * → Possibly evaluated layout property value
44
- * → Fully evaluated layout property value
45
- *
46
- * @module
47
- * @private
48
- */
49
-
50
- /**
51
- * Implementations of the `Property` interface:
52
- *
53
- * * Hold metadata about a property that's independent of any specific value: stuff like the type of the value,
54
- * the default value, etc. This comes from the style specification JSON.
55
- * * Define behavior that needs to be polymorphic across different properties: "possibly evaluating"
56
- * an input value (see below), and interpolating between two possibly-evaluted values.
57
- *
58
- * The type `T` is the fully-evaluated value type (e.g. `number`, `string`, `Color`).
59
- * The type `R` is the intermediate "possibly evaluated" value type. See below.
60
- *
61
- * There are two main implementations of the interface -- one for properties that allow data-driven values,
62
- * and one for properties that don't. There are a few "special case" implementations as well: one for properties
63
- * which cross-fade between two values rather than interpolating, one for `heatmap-color` and `line-gradient`,
64
- * and one for `light-position`.
65
- *
66
- * @private
67
- */
68
- export interface Property<T, R> {
69
- specification: StylePropertySpecification;
70
- possiblyEvaluate(value: PropertyValue<T, R>, parameters: EvaluationParameters, canonical?: CanonicalTileID, availableImages?: Array<string>): R;
71
- interpolate(a: R, b: R, t: number): R;
72
- }
73
-
74
- /**
75
- * `PropertyValue` represents the value part of a property key-value unit. It's used to represent both
76
- * paint and layout property values, and regardless of whether or not their property supports data-driven
77
- * expressions.
78
- *
79
- * `PropertyValue` stores the raw input value as seen in a style or a runtime styling API call, i.e. one of the
80
- * following:
81
- *
82
- * * A constant value of the type appropriate for the property
83
- * * A function which produces a value of that type (but functions are quasi-deprecated in favor of expressions)
84
- * * An expression which produces a value of that type
85
- * * "undefined"/"not present", in which case the property is assumed to take on its default value.
86
- *
87
- * In addition to storing the original input value, `PropertyValue` also stores a normalized representation,
88
- * effectively treating functions as if they are expressions, and constant or default values as if they are
89
- * (constant) expressions.
90
- *
91
- * @private
92
- */
93
- export class PropertyValue<T, R> {
94
- property: Property<T, R>;
95
- value: PropertyValueSpecification<T> | void;
96
- expression: StylePropertyExpression;
97
-
98
- constructor(property: Property<T, R>, value: PropertyValueSpecification<T> | void) {
99
- this.property = property;
100
- this.value = value;
101
- this.expression = normalizePropertyExpression(value === undefined ? property.specification.default : value, property.specification);
102
- }
103
-
104
- isDataDriven(): boolean {
105
- return this.expression.kind === 'source' || this.expression.kind === 'composite';
106
- }
107
-
108
- possiblyEvaluate(parameters: EvaluationParameters, canonical?: CanonicalTileID, availableImages?: Array<string>): R {
109
- return this.property.possiblyEvaluate(this, parameters, canonical, availableImages);
110
- }
111
- }
112
-
113
- // ------- Transitionable -------
114
-
115
- export type TransitionParameters = {
116
- now: TimePoint,
117
- transition: TransitionSpecification
118
- };
119
-
120
- /**
121
- * Paint properties are _transitionable_: they can change in a fluid manner, interpolating or cross-fading between
122
- * old and new value. The duration of the transition, and the delay before it begins, is configurable.
123
- *
124
- * `TransitionablePropertyValue` is a compositional class that stores both the property value and that transition
125
- * configuration.
126
- *
127
- * A `TransitionablePropertyValue` can calculate the next step in the evaluation chain for paint property values:
128
- * `TransitioningPropertyValue`.
129
- *
130
- * @private
131
- */
132
- class TransitionablePropertyValue<T, R> {
133
- property: Property<T, R>;
134
- value: PropertyValue<T, R>;
135
- transition: TransitionSpecification | void;
136
-
137
- constructor(property: Property<T, R>) {
138
- this.property = property;
139
- this.value = new PropertyValue(property, undefined);
140
- }
141
-
142
- transitioned(parameters: TransitionParameters,
143
- prior: TransitioningPropertyValue<T, R>): TransitioningPropertyValue<T, R> {
144
- return new TransitioningPropertyValue(this.property, this.value, prior, // eslint-disable-line no-use-before-define
145
- extend({}, parameters.transition, this.transition), parameters.now);
146
- }
147
-
148
- untransitioned(): TransitioningPropertyValue<T, R> {
149
- return new TransitioningPropertyValue(this.property, this.value, null, {}, 0); // eslint-disable-line no-use-before-define
150
- }
151
- }
152
-
153
- /**
154
- * A helper type: given an object type `Properties` whose values are each of type `Property<T, R>`, it calculates
155
- * an object type with the same keys and values of type `TransitionablePropertyValue<T, R>`.
156
- *
157
- * @private
158
- */
159
- type TransitionablePropertyValues<Props: Object>
160
- = $Exact<$ObjMap<Props, <T, R>(p: Property<T, R>) => TransitionablePropertyValue<T, R>>>
161
-
162
- /**
163
- * `Transitionable` stores a map of all (property name, `TransitionablePropertyValue`) pairs for paint properties of a
164
- * given layer type. It can calculate the `TransitioningPropertyValue`s for all of them at once, producing a
165
- * `Transitioning` instance for the same set of properties.
166
- *
167
- * @private
168
- */
169
- export class Transitionable<Props: Object> {
170
- _properties: Properties<Props>;
171
- _values: TransitionablePropertyValues<Props>;
172
-
173
- constructor(properties: Properties<Props>) {
174
- this._properties = properties;
175
- this._values = (Object.create(properties.defaultTransitionablePropertyValues): any);
176
- }
177
-
178
- getValue<S: string, T>(name: S): PropertyValueSpecification<T> | void {
179
- return clone(this._values[name].value.value);
180
- }
181
-
182
- setValue<S: string, T>(name: S, value: PropertyValueSpecification<T> | void) {
183
- if (!this._values.hasOwnProperty(name)) {
184
- this._values[name] = new TransitionablePropertyValue(this._values[name].property);
185
- }
186
- // Note that we do not _remove_ an own property in the case where a value is being reset
187
- // to the default: the transition might still be non-default.
188
- this._values[name].value = new PropertyValue(this._values[name].property, value === null ? undefined : clone(value));
189
- }
190
-
191
- getTransition<S: string>(name: S): TransitionSpecification | void {
192
- return clone(this._values[name].transition);
193
- }
194
-
195
- setTransition<S: string>(name: S, value: TransitionSpecification | void) {
196
- if (!this._values.hasOwnProperty(name)) {
197
- this._values[name] = new TransitionablePropertyValue(this._values[name].property);
198
- }
199
- this._values[name].transition = clone(value) || undefined;
200
- }
201
-
202
- serialize() {
203
- const result: any = {};
204
- for (const property of Object.keys(this._values)) {
205
- const value = this.getValue(property);
206
- if (value !== undefined) {
207
- result[property] = value;
208
- }
209
-
210
- const transition = this.getTransition(property);
211
- if (transition !== undefined) {
212
- result[`${property}-transition`] = transition;
213
- }
214
- }
215
- return result;
216
- }
217
-
218
- transitioned(parameters: TransitionParameters, prior: Transitioning<Props>): Transitioning<Props> {
219
- const result = new Transitioning(this._properties); // eslint-disable-line no-use-before-define
220
- for (const property of Object.keys(this._values)) {
221
- result._values[property] = this._values[property].transitioned(parameters, prior._values[property]);
222
- }
223
- return result;
224
- }
225
-
226
- untransitioned(): Transitioning<Props> {
227
- const result = new Transitioning(this._properties); // eslint-disable-line no-use-before-define
228
- for (const property of Object.keys(this._values)) {
229
- result._values[property] = this._values[property].untransitioned();
230
- }
231
- return result;
232
- }
233
- }
234
-
235
- // ------- Transitioning -------
236
-
237
- /**
238
- * `TransitioningPropertyValue` implements the first of two intermediate steps in the evaluation chain of a paint
239
- * property value. In this step, transitions between old and new values are handled: as long as the transition is in
240
- * progress, `TransitioningPropertyValue` maintains a reference to the prior value, and interpolates between it and
241
- * the new value based on the current time and the configured transition duration and delay. The product is the next
242
- * step in the evaluation chain: the "possibly evaluated" result type `R`. See below for more on this concept.
243
- *
244
- * @private
245
- */
246
- class TransitioningPropertyValue<T, R> {
247
- property: Property<T, R>;
248
- value: PropertyValue<T, R>;
249
- prior: ?TransitioningPropertyValue<T, R>;
250
- begin: TimePoint;
251
- end: TimePoint;
252
-
253
- constructor(property: Property<T, R>,
254
- value: PropertyValue<T, R>,
255
- prior: ?TransitioningPropertyValue<T, R>,
256
- transition: TransitionSpecification,
257
- now: TimePoint) {
258
- this.property = property;
259
- this.value = value;
260
- this.begin = now + transition.delay || 0;
261
- this.end = this.begin + transition.duration || 0;
262
- if (property.specification.transition && (transition.delay || transition.duration)) {
263
- this.prior = prior;
264
- }
265
- }
266
-
267
- possiblyEvaluate(parameters: EvaluationParameters, canonical: CanonicalTileID, availableImages: Array<string>): R {
268
- const now = parameters.now || 0;
269
- const finalValue = this.value.possiblyEvaluate(parameters, canonical, availableImages);
270
- const prior = this.prior;
271
- if (!prior) {
272
- // No prior value.
273
- return finalValue;
274
- } else if (now > this.end) {
275
- // Transition from prior value is now complete.
276
- this.prior = null;
277
- return finalValue;
278
- } else if (this.value.isDataDriven()) {
279
- // Transitions to data-driven properties are not supported.
280
- // We snap immediately to the data-driven value so that, when we perform layout,
281
- // we see the data-driven function and can use it to populate vertex buffers.
282
- this.prior = null;
283
- return finalValue;
284
- } else if (now < this.begin) {
285
- // Transition hasn't started yet.
286
- return prior.possiblyEvaluate(parameters, canonical, availableImages);
287
- } else {
288
- // Interpolate between recursively-calculated prior value and final.
289
- const t = (now - this.begin) / (this.end - this.begin);
290
- return this.property.interpolate(prior.possiblyEvaluate(parameters, canonical, availableImages), finalValue, easeCubicInOut(t));
291
- }
292
- }
293
- }
294
-
295
- /**
296
- * A helper type: given an object type `Properties` whose values are each of type `Property<T, R>`, it calculates
297
- * an object type with the same keys and values of type `TransitioningPropertyValue<T, R>`.
298
- *
299
- * @private
300
- */
301
- type TransitioningPropertyValues<Props: Object>
302
- = $Exact<$ObjMap<Props, <T, R>(p: Property<T, R>) => TransitioningPropertyValue<T, R>>>
303
-
304
- /**
305
- * `Transitioning` stores a map of all (property name, `TransitioningPropertyValue`) pairs for paint properties of a
306
- * given layer type. It can calculate the possibly-evaluated values for all of them at once, producing a
307
- * `PossiblyEvaluated` instance for the same set of properties.
308
- *
309
- * @private
310
- */
311
- export class Transitioning<Props: Object> {
312
- _properties: Properties<Props>;
313
- _values: TransitioningPropertyValues<Props>;
314
-
315
- constructor(properties: Properties<Props>) {
316
- this._properties = properties;
317
- this._values = (Object.create(properties.defaultTransitioningPropertyValues): any);
318
- }
319
-
320
- possiblyEvaluate(parameters: EvaluationParameters, availableImages?: Array<string>): PossiblyEvaluated<Props> {
321
- const result = new PossiblyEvaluated(this._properties); // eslint-disable-line no-use-before-define
322
- for (const property of Object.keys(this._values)) {
323
- result._values[property] = this._values[property].possiblyEvaluate(parameters, availableImages);
324
- }
325
- return result;
326
- }
327
-
328
- hasTransition() {
329
- for (const property of Object.keys(this._values)) {
330
- if (this._values[property].prior) {
331
- return true;
332
- }
333
- }
334
- return false;
335
- }
336
- }
337
-
338
- // ------- Layout -------
339
-
340
- /**
341
- * A helper type: given an object type `Properties` whose values are each of type `Property<T, R>`, it calculates
342
- * an object type with the same keys and values of type `PropertyValue<T, R>`.
343
- *
344
- * @private
345
- */
346
- type PropertyValues<Props: Object>
347
- = $Exact<$ObjMap<Props, <T, R>(p: Property<T, R>) => PropertyValue<T, R>>>
348
-
349
- /**
350
- * Because layout properties are not transitionable, they have a simpler representation and evaluation chain than
351
- * paint properties: `PropertyValue`s are possibly evaluated, producing possibly evaluated values, which are then
352
- * fully evaluated.
353
- *
354
- * `Layout` stores a map of all (property name, `PropertyValue`) pairs for layout properties of a
355
- * given layer type. It can calculate the possibly-evaluated values for all of them at once, producing a
356
- * `PossiblyEvaluated` instance for the same set of properties.
357
- *
358
- * @private
359
- */
360
- export class Layout<Props: Object> {
361
- _properties: Properties<Props>;
362
- _values: PropertyValues<Props>;
363
-
364
- constructor(properties: Properties<Props>) {
365
- this._properties = properties;
366
- this._values = (Object.create(properties.defaultPropertyValues): any);
367
- }
368
-
369
- getValue<S: string>(name: S) {
370
- return clone(this._values[name].value);
371
- }
372
-
373
- setValue<S: string>(name: S, value: *) {
374
- this._values[name] = new PropertyValue(this._values[name].property, value === null ? undefined : clone(value));
375
- }
376
-
377
- serialize() {
378
- const result: any = {};
379
- for (const property of Object.keys(this._values)) {
380
- const value = this.getValue(property);
381
- if (value !== undefined) {
382
- result[property] = value;
383
- }
384
- }
385
- return result;
386
- }
387
-
388
- possiblyEvaluate(parameters: EvaluationParameters, availableImages?: Array<string>): PossiblyEvaluated<Props> {
389
- const result = new PossiblyEvaluated(this._properties); // eslint-disable-line no-use-before-define
390
- for (const property of Object.keys(this._values)) {
391
- result._values[property] = this._values[property].possiblyEvaluate(parameters, availableImages);
392
- }
393
- return result;
394
- }
395
- }
396
-
397
- // ------- PossiblyEvaluated -------
398
-
399
- /**
400
- * "Possibly evaluated value" is an intermediate stage in the evaluation chain for both paint and layout property
401
- * values. The purpose of this stage is to optimize away unnecessary recalculations for data-driven properties. Code
402
- * which uses data-driven property values must assume that the value is dependent on feature data, and request that it
403
- * be evaluated for each feature. But when that property value is in fact a constant or camera function, the calculation
404
- * will not actually depend on the feature, and we can benefit from returning the prior result of having done the
405
- * evaluation once, ahead of time, in an intermediate step whose inputs are just the value and "global" parameters
406
- * such as current zoom level.
407
- *
408
- * `PossiblyEvaluatedValue` represents the three possible outcomes of this step: if the input value was a constant or
409
- * camera expression, then the "possibly evaluated" result is a constant value. Otherwise, the input value was either
410
- * a source or composite expression, and we must defer final evaluation until supplied a feature. We separate
411
- * the source and composite cases because they are handled differently when generating GL attributes, buffers, and
412
- * uniforms.
413
- *
414
- * Note that `PossiblyEvaluatedValue` (and `PossiblyEvaluatedPropertyValue`, below) are _not_ used for properties that
415
- * do not allow data-driven values. For such properties, we know that the "possibly evaluated" result is always a constant
416
- * scalar value. See below.
417
- *
418
- * @private
419
- */
420
- type PossiblyEvaluatedValue<T> =
421
- | {kind: 'constant', value: T}
422
- | SourceExpression
423
- | CompositeExpression;
424
-
425
- /**
426
- * `PossiblyEvaluatedPropertyValue` is used for data-driven paint and layout property values. It holds a
427
- * `PossiblyEvaluatedValue` and the `GlobalProperties` that were used to generate it. You're not allowed to supply
428
- * a different set of `GlobalProperties` when performing the final evaluation because they would be ignored in the
429
- * case where the input value was a constant or camera function.
430
- *
431
- * @private
432
- */
433
- export class PossiblyEvaluatedPropertyValue<T> {
434
- property: DataDrivenProperty<T>;
435
- value: PossiblyEvaluatedValue<T>;
436
- parameters: EvaluationParameters;
437
-
438
- constructor(property: DataDrivenProperty<T>, value: PossiblyEvaluatedValue<T>, parameters: EvaluationParameters) {
439
- this.property = property;
440
- this.value = value;
441
- this.parameters = parameters;
442
- }
443
-
444
- isConstant(): boolean {
445
- return this.value.kind === 'constant';
446
- }
447
-
448
- constantOr(value: T): T {
449
- if (this.value.kind === 'constant') {
450
- return this.value.value;
451
- } else {
452
- return value;
453
- }
454
- }
455
-
456
- evaluate(feature: Feature, featureState: FeatureState, canonical?: CanonicalTileID, availableImages?: Array<string>): T {
457
- return this.property.evaluate(this.value, this.parameters, feature, featureState, canonical, availableImages);
458
- }
459
- }
460
-
461
- /**
462
- * A helper type: given an object type `Properties` whose values are each of type `Property<T, R>`, it calculates
463
- * an object type with the same keys, and values of type `R`.
464
- *
465
- * For properties that don't allow data-driven values, `R` is a scalar type such as `number`, `string`, or `Color`.
466
- * For data-driven properties, it is `PossiblyEvaluatedPropertyValue`. Critically, the type definitions are set up
467
- * in a way that allows flow to know which of these two cases applies for any given property name, and if you attempt
468
- * to use a `PossiblyEvaluatedPropertyValue` as if it was a scalar, or vice versa, you will get a type error. (However,
469
- * there's at least one case in which flow fails to produce a type error that you should be aware of: in a context such
470
- * as `layer.paint.get('foo-opacity') === 0`, if `foo-opacity` is data-driven, than the left-hand side is of type
471
- * `PossiblyEvaluatedPropertyValue<number>`, but flow will not complain about comparing this to a number using `===`.
472
- * See https://github.com/facebook/flow/issues/2359.)
473
- *
474
- * There's also a third, special case possiblity for `R`: for cross-faded properties, it's `?CrossFaded<T>`.
475
- *
476
- * @private
477
- */
478
- type PossiblyEvaluatedPropertyValues<Props: Object>
479
- = $Exact<$ObjMap<Props, <T, R>(p: Property<T, R>) => R>>
480
-
481
- /**
482
- * `PossiblyEvaluated` stores a map of all (property name, `R`) pairs for paint or layout properties of a
483
- * given layer type.
484
- * @private
485
- */
486
- export class PossiblyEvaluated<Props: Object> {
487
- _properties: Properties<Props>;
488
- _values: PossiblyEvaluatedPropertyValues<Props>;
489
-
490
- constructor(properties: Properties<Props>) {
491
- this._properties = properties;
492
- this._values = (Object.create(properties.defaultPossiblyEvaluatedValues): any);
493
- }
494
-
495
- get<S: string>(name: S): $ElementType<PossiblyEvaluatedPropertyValues<Props>, S> {
496
- return this._values[name];
497
- }
498
- }
499
-
500
- /**
501
- * An implementation of `Property` for properties that do not permit data-driven (source or composite) expressions.
502
- * This restriction allows us to declare statically that the result of possibly evaluating this kind of property
503
- * is in fact always the scalar type `T`, and can be used without further evaluating the value on a per-feature basis.
504
- *
505
- * @private
506
- */
507
- export class DataConstantProperty<T> implements Property<T, T> {
508
- specification: StylePropertySpecification;
509
-
510
- constructor(specification: StylePropertySpecification) {
511
- this.specification = specification;
512
- }
513
-
514
- possiblyEvaluate(value: PropertyValue<T, T>, parameters: EvaluationParameters): T {
515
- assert(!value.isDataDriven());
516
- return value.expression.evaluate(parameters);
517
- }
518
-
519
- interpolate(a: T, b: T, t: number): T {
520
- const interp: ?(a: T, b: T, t: number) => T = (interpolate: any)[this.specification.type];
521
- if (interp) {
522
- return interp(a, b, t);
523
- } else {
524
- return a;
525
- }
526
- }
527
- }
528
-
529
- /**
530
- * An implementation of `Property` for properties that permit data-driven (source or composite) expressions.
531
- * The result of possibly evaluating this kind of property is `PossiblyEvaluatedPropertyValue<T>`; obtaining
532
- * a scalar value `T` requires further evaluation on a per-feature basis.
533
- *
534
- * @private
535
- */
536
- export class DataDrivenProperty<T> implements Property<T, PossiblyEvaluatedPropertyValue<T>> {
537
- specification: StylePropertySpecification;
538
- overrides: ?Object;
539
-
540
- constructor(specification: StylePropertySpecification, overrides?: Object) {
541
- this.specification = specification;
542
- this.overrides = overrides;
543
- }
544
-
545
- possiblyEvaluate(value: PropertyValue<T, PossiblyEvaluatedPropertyValue<T>>, parameters: EvaluationParameters, canonical?: CanonicalTileID, availableImages?: Array<string>): PossiblyEvaluatedPropertyValue<T> {
546
- if (value.expression.kind === 'constant' || value.expression.kind === 'camera') {
547
- return new PossiblyEvaluatedPropertyValue(this, {kind: 'constant', value: value.expression.evaluate(parameters, (null: any), {}, canonical, availableImages)}, parameters);
548
- } else {
549
- return new PossiblyEvaluatedPropertyValue(this, value.expression, parameters);
550
- }
551
- }
552
-
553
- interpolate(a: PossiblyEvaluatedPropertyValue<T>,
554
- b: PossiblyEvaluatedPropertyValue<T>,
555
- t: number): PossiblyEvaluatedPropertyValue<T> {
556
- // If either possibly-evaluated value is non-constant, give up: we aren't able to interpolate data-driven values.
557
- if (a.value.kind !== 'constant' || b.value.kind !== 'constant') {
558
- return a;
559
- }
560
-
561
- // Special case hack solely for fill-outline-color. The undefined value is subsequently handled in
562
- // FillStyleLayer#recalculate, which sets fill-outline-color to the fill-color value if the former
563
- // is a PossiblyEvaluatedPropertyValue containing a constant undefined value. In addition to the
564
- // return value here, the other source of a PossiblyEvaluatedPropertyValue containing a constant
565
- // undefined value is the "default value" for fill-outline-color held in
566
- // `Properties#defaultPossiblyEvaluatedValues`, which serves as the prototype of
567
- // `PossiblyEvaluated#_values`.
568
- if (a.value.value === undefined || b.value.value === undefined) {
569
- return new PossiblyEvaluatedPropertyValue(this, {kind: 'constant', value: (undefined: any)}, a.parameters);
570
- }
571
-
572
- const interp: ?(a: T, b: T, t: number) => T = (interpolate: any)[this.specification.type];
573
- if (interp) {
574
- return new PossiblyEvaluatedPropertyValue(this, {kind: 'constant', value: interp(a.value.value, b.value.value, t)}, a.parameters);
575
- } else {
576
- return a;
577
- }
578
- }
579
-
580
- evaluate(value: PossiblyEvaluatedValue<T>, parameters: EvaluationParameters, feature: Feature, featureState: FeatureState, canonical?: CanonicalTileID, availableImages?: Array<string>): T {
581
- if (value.kind === 'constant') {
582
- return value.value;
583
- } else {
584
- return value.evaluate(parameters, feature, featureState, canonical, availableImages);
585
- }
586
- }
587
- }
588
-
589
- /**
590
- * An implementation of `Property` for data driven `line-pattern` which are transitioned by cross-fading
591
- * rather than interpolation.
592
- *
593
- * @private
594
- */
595
-
596
- export class CrossFadedDataDrivenProperty<T> extends DataDrivenProperty<?CrossFaded<T>> {
597
-
598
- possiblyEvaluate(value: PropertyValue<?CrossFaded<T>, PossiblyEvaluatedPropertyValue<?CrossFaded<T>>>, parameters: EvaluationParameters, canonical?: CanonicalTileID, availableImages?: Array<string>): PossiblyEvaluatedPropertyValue<?CrossFaded<T>> {
599
- if (value.value === undefined) {
600
- return new PossiblyEvaluatedPropertyValue(this, {kind: 'constant', value: undefined}, parameters);
601
- } else if (value.expression.kind === 'constant') {
602
- const evaluatedValue = value.expression.evaluate(parameters, (null: any), {}, canonical, availableImages);
603
- const isImageExpression = value.property.specification.type === 'resolvedImage';
604
- const constantValue = isImageExpression && typeof evaluatedValue !== 'string' ? evaluatedValue.name : evaluatedValue;
605
- const constant = this._calculate(constantValue, constantValue, constantValue, parameters);
606
- return new PossiblyEvaluatedPropertyValue(this, {kind: 'constant', value: constant}, parameters);
607
- } else if (value.expression.kind === 'camera') {
608
- const cameraVal = this._calculate(
609
- value.expression.evaluate({zoom: parameters.zoom - 1.0}),
610
- value.expression.evaluate({zoom: parameters.zoom}),
611
- value.expression.evaluate({zoom: parameters.zoom + 1.0}),
612
- parameters);
613
- return new PossiblyEvaluatedPropertyValue(this, {kind: 'constant', value: cameraVal}, parameters);
614
- } else {
615
- // source or composite expression
616
- return new PossiblyEvaluatedPropertyValue(this, value.expression, parameters);
617
- }
618
- }
619
-
620
- evaluate(value: PossiblyEvaluatedValue<?CrossFaded<T>>, globals: EvaluationParameters, feature: Feature, featureState: FeatureState, canonical?: CanonicalTileID, availableImages?: Array<string>): ?CrossFaded<T> {
621
- if (value.kind === 'source') {
622
- const constant = value.evaluate(globals, feature, featureState, canonical, availableImages);
623
- return this._calculate(constant, constant, constant, globals);
624
- } else if (value.kind === 'composite') {
625
- return this._calculate(
626
- value.evaluate({zoom: Math.floor(globals.zoom) - 1.0}, feature, featureState),
627
- value.evaluate({zoom: Math.floor(globals.zoom)}, feature, featureState),
628
- value.evaluate({zoom: Math.floor(globals.zoom) + 1.0}, feature, featureState),
629
- globals);
630
- } else {
631
- return value.value;
632
- }
633
- }
634
-
635
- _calculate(min: T, mid: T, max: T, parameters: EvaluationParameters): CrossFaded<T> {
636
- const z = parameters.zoom;
637
- return z > parameters.zoomHistory.lastIntegerZoom ? {from: min, to: mid} : {from: max, to: mid};
638
- }
639
-
640
- interpolate(a: PossiblyEvaluatedPropertyValue<?CrossFaded<T>>): PossiblyEvaluatedPropertyValue<?CrossFaded<T>> {
641
- return a;
642
- }
643
- }
644
- /**
645
- * An implementation of `Property` for `*-pattern` and `line-dasharray`, which are transitioned by cross-fading
646
- * rather than interpolation.
647
- *
648
- * @private
649
- */
650
- export class CrossFadedProperty<T> implements Property<T, ?CrossFaded<T>> {
651
- specification: StylePropertySpecification;
652
-
653
- constructor(specification: StylePropertySpecification) {
654
- this.specification = specification;
655
- }
656
-
657
- possiblyEvaluate(value: PropertyValue<T, ?CrossFaded<T>>, parameters: EvaluationParameters, canonical?: CanonicalTileID, availableImages?: Array<string>): ?CrossFaded<T> {
658
- if (value.value === undefined) {
659
- return undefined;
660
- } else if (value.expression.kind === 'constant') {
661
- const constant = value.expression.evaluate(parameters, (null: any), {}, canonical, availableImages);
662
- return this._calculate(constant, constant, constant, parameters);
663
- } else {
664
- assert(!value.isDataDriven());
665
- return this._calculate(
666
- value.expression.evaluate(new EvaluationParameters(Math.floor(parameters.zoom - 1.0), parameters)),
667
- value.expression.evaluate(new EvaluationParameters(Math.floor(parameters.zoom), parameters)),
668
- value.expression.evaluate(new EvaluationParameters(Math.floor(parameters.zoom + 1.0), parameters)),
669
- parameters);
670
- }
671
- }
672
-
673
- _calculate(min: T, mid: T, max: T, parameters: EvaluationParameters): ?CrossFaded<T> {
674
- const z = parameters.zoom;
675
- return z > parameters.zoomHistory.lastIntegerZoom ? {from: min, to: mid} : {from: max, to: mid};
676
- }
677
-
678
- interpolate(a: ?CrossFaded<T>): ?CrossFaded<T> {
679
- return a;
680
- }
681
- }
682
-
683
- /**
684
- * An implementation of `Property` for `heatmap-color` and `line-gradient`. Interpolation is a no-op, and
685
- * evaluation returns a boolean value in order to indicate its presence, but the real
686
- * evaluation happens in StyleLayer classes.
687
- *
688
- * @private
689
- */
690
-
691
- export class ColorRampProperty implements Property<Color, boolean> {
692
- specification: StylePropertySpecification;
693
-
694
- constructor(specification: StylePropertySpecification) {
695
- this.specification = specification;
696
- }
697
-
698
- possiblyEvaluate(value: PropertyValue<Color, boolean>, parameters: EvaluationParameters, canonical?: CanonicalTileID, availableImages?: Array<string>): boolean {
699
- return !!value.expression.evaluate(parameters, (null: any), {}, canonical, availableImages);
700
- }
701
-
702
- interpolate(): boolean { return false; }
703
- }
704
-
705
- /**
706
- * `Properties` holds objects containing default values for the layout or paint property set of a given
707
- * layer type. These objects are immutable, and they are used as the prototypes for the `_values` members of
708
- * `Transitionable`, `Transitioning`, `Layout`, and `PossiblyEvaluated`. This allows these classes to avoid
709
- * doing work in the common case where a property has no explicit value set and should be considered to take
710
- * on the default value: using `for (const property of Object.keys(this._values))`, they can iterate over
711
- * only the _own_ properties of `_values`, skipping repeated calculation of transitions and possible/final
712
- * evaluations for defaults, the result of which will always be the same.
713
- *
714
- * @private
715
- */
716
- export class Properties<Props: Object> {
717
- properties: Props;
718
- defaultPropertyValues: PropertyValues<Props>;
719
- defaultTransitionablePropertyValues: TransitionablePropertyValues<Props>;
720
- defaultTransitioningPropertyValues: TransitioningPropertyValues<Props>;
721
- defaultPossiblyEvaluatedValues: PossiblyEvaluatedPropertyValues<Props>;
722
- overridableProperties: Array<string>;
723
-
724
- constructor(properties: Props) {
725
- this.properties = properties;
726
- this.defaultPropertyValues = ({}: any);
727
- this.defaultTransitionablePropertyValues = ({}: any);
728
- this.defaultTransitioningPropertyValues = ({}: any);
729
- this.defaultPossiblyEvaluatedValues = ({}: any);
730
- this.overridableProperties = ([]: any);
731
-
732
- for (const property in properties) {
733
- const prop = properties[property];
734
- if (prop.specification.overridable) {
735
- this.overridableProperties.push(property);
736
- }
737
- const defaultPropertyValue = this.defaultPropertyValues[property] =
738
- new PropertyValue(prop, undefined);
739
- const defaultTransitionablePropertyValue = this.defaultTransitionablePropertyValues[property] =
740
- new TransitionablePropertyValue(prop);
741
- this.defaultTransitioningPropertyValues[property] =
742
- defaultTransitionablePropertyValue.untransitioned();
743
- this.defaultPossiblyEvaluatedValues[property] =
744
- defaultPropertyValue.possiblyEvaluate(({}: any));
745
- }
746
- }
747
- }
748
-
749
- register('DataDrivenProperty', DataDrivenProperty);
750
- register('DataConstantProperty', DataConstantProperty);
751
- register('CrossFadedDataDrivenProperty', CrossFadedDataDrivenProperty);
752
- register('CrossFadedProperty', CrossFadedProperty);
753
- register('ColorRampProperty', ColorRampProperty);