@mapgis/mapbox-gl 16.0.0 → 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 (441) hide show
  1. package/dist/mapbox-gl.js +4 -4
  2. package/dist/mapbox-gl.js.map +1 -1
  3. package/package.json +4 -5
  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/dist/mapbox-gl-csp-worker.js +0 -2
  22. package/dist/mapbox-gl-csp-worker.js.map +0 -1
  23. package/dist/mapbox-gl-csp.js +0 -2
  24. package/dist/mapbox-gl-csp.js.map +0 -1
  25. package/dist/mapbox-gl-dev.js +0 -68798
  26. package/dist/mapbox-gl-unminified.js +0 -45076
  27. package/dist/mapbox-gl-unminified.js.map +0 -1
  28. package/flow-typed/gl.js +0 -5
  29. package/flow-typed/jsdom.js +0 -18
  30. package/flow-typed/mapbox-gl-supported.js +0 -9
  31. package/flow-typed/mapbox-unitbezier.js +0 -14
  32. package/flow-typed/offscreen-canvas.js +0 -9
  33. package/flow-typed/pbf.js +0 -25
  34. package/flow-typed/point-geometry.js +0 -44
  35. package/flow-typed/potpack.js +0 -12
  36. package/flow-typed/sinon.js +0 -28
  37. package/flow-typed/vector-tile.js +0 -41
  38. package/src/css/mapbox-gl.css +0 -798
  39. package/src/css/svg/mapboxgl-ctrl-attrib.svg +0 -3
  40. package/src/css/svg/mapboxgl-ctrl-compass.svg +0 -4
  41. package/src/css/svg/mapboxgl-ctrl-fullscreen.svg +0 -3
  42. package/src/css/svg/mapboxgl-ctrl-geolocate.svg +0 -5
  43. package/src/css/svg/mapboxgl-ctrl-logo.svg +0 -20
  44. package/src/css/svg/mapboxgl-ctrl-shrink.svg +0 -3
  45. package/src/css/svg/mapboxgl-ctrl-zoom-in.svg +0 -3
  46. package/src/css/svg/mapboxgl-ctrl-zoom-out.svg +0 -3
  47. package/src/data/array_types.js +0 -1095
  48. package/src/data/bucket/circle_attributes.js +0 -9
  49. package/src/data/bucket/circle_bucket.js +0 -204
  50. package/src/data/bucket/fill_attributes.js +0 -9
  51. package/src/data/bucket/fill_bucket.js +0 -233
  52. package/src/data/bucket/fill_extrusion_attributes.js +0 -10
  53. package/src/data/bucket/fill_extrusion_bucket.js +0 -289
  54. package/src/data/bucket/heatmap_bucket.js +0 -17
  55. package/src/data/bucket/line_attributes.js +0 -10
  56. package/src/data/bucket/line_bucket.js +0 -556
  57. package/src/data/bucket/pattern_attributes.js +0 -10
  58. package/src/data/bucket/pattern_bucket_features.js +0 -60
  59. package/src/data/bucket/symbol_attributes.js +0 -117
  60. package/src/data/bucket/symbol_bucket.js +0 -972
  61. package/src/data/bucket.js +0 -123
  62. package/src/data/dem_data.js +0 -125
  63. package/src/data/extent.js +0 -18
  64. package/src/data/feature_index.js +0 -321
  65. package/src/data/feature_position_map.js +0 -125
  66. package/src/data/index_array_type.js +0 -16
  67. package/src/data/load_geometry.js +0 -48
  68. package/src/data/pos_attributes.js +0 -6
  69. package/src/data/program_configuration.js +0 -687
  70. package/src/data/raster_bounds_attributes.js +0 -7
  71. package/src/data/segment.js +0 -76
  72. package/src/geo/edge_insets.js +0 -102
  73. package/src/geo/lng_lat.js +0 -165
  74. package/src/geo/lng_lat_bounds.js +0 -267
  75. package/src/geo/mercator_coordinate.js +0 -153
  76. package/src/geo/transform.js +0 -864
  77. package/src/gl/color_mode.js +0 -34
  78. package/src/gl/context.js +0 -298
  79. package/src/gl/cull_face_mode.js +0 -26
  80. package/src/gl/depth_mode.js +0 -29
  81. package/src/gl/framebuffer.js +0 -44
  82. package/src/gl/index_buffer.js +0 -55
  83. package/src/gl/stencil_mode.js +0 -30
  84. package/src/gl/types.js +0 -84
  85. package/src/gl/value.js +0 -520
  86. package/src/gl/vertex_buffer.js +0 -119
  87. package/src/index.js +0 -201
  88. package/src/render/draw_background.js +0 -57
  89. package/src/render/draw_circle.js +0 -113
  90. package/src/render/draw_collision_debug.js +0 -49
  91. package/src/render/draw_custom.js +0 -49
  92. package/src/render/draw_debug.js +0 -127
  93. package/src/render/draw_fill.js +0 -126
  94. package/src/render/draw_fill_extrusion.js +0 -96
  95. package/src/render/draw_heatmap.js +0 -140
  96. package/src/render/draw_hillshade.js +0 -108
  97. package/src/render/draw_line.js +0 -98
  98. package/src/render/draw_raster.js +0 -125
  99. package/src/render/draw_symbol.js +0 -394
  100. package/src/render/glyph_atlas.js +0 -71
  101. package/src/render/glyph_manager.js +0 -182
  102. package/src/render/image_atlas.js +0 -149
  103. package/src/render/image_manager.js +0 -306
  104. package/src/render/line_atlas.js +0 -210
  105. package/src/render/painter.js +0 -653
  106. package/src/render/program/background_program.js +0 -103
  107. package/src/render/program/circle_program.js +0 -69
  108. package/src/render/program/clipping_mask_program.js +0 -20
  109. package/src/render/program/collision_program.js +0 -49
  110. package/src/render/program/debug_program.js +0 -35
  111. package/src/render/program/fill_extrusion_program.js +0 -122
  112. package/src/render/program/fill_program.js +0 -126
  113. package/src/render/program/heatmap_program.js +0 -83
  114. package/src/render/program/hillshade_program.js +0 -122
  115. package/src/render/program/line_program.js +0 -207
  116. package/src/render/program/pattern.js +0 -102
  117. package/src/render/program/program_uniforms.js +0 -42
  118. package/src/render/program/raster_program.js +0 -92
  119. package/src/render/program/symbol_program.js +0 -224
  120. package/src/render/program.js +0 -168
  121. package/src/render/texture.js +0 -122
  122. package/src/render/uniform_binding.js +0 -147
  123. package/src/render/vertex_array_object.js +0 -163
  124. package/src/shaders/README.md +0 -42
  125. package/src/shaders/_prelude.fragment.glsl +0 -17
  126. package/src/shaders/_prelude.vertex.glsl +0 -73
  127. package/src/shaders/background.fragment.glsl +0 -10
  128. package/src/shaders/background.vertex.glsl +0 -7
  129. package/src/shaders/background_pattern.fragment.glsl +0 -28
  130. package/src/shaders/background_pattern.vertex.glsl +0 -20
  131. package/src/shaders/circle.fragment.glsl +0 -39
  132. package/src/shaders/circle.vertex.glsl +0 -64
  133. package/src/shaders/clipping_mask.fragment.glsl +0 -3
  134. package/src/shaders/clipping_mask.vertex.glsl +0 -7
  135. package/src/shaders/collision_box.fragment.glsl +0 -21
  136. package/src/shaders/collision_box.vertex.glsl +0 -27
  137. package/src/shaders/collision_circle.fragment.glsl +0 -34
  138. package/src/shaders/collision_circle.vertex.glsl +0 -36
  139. package/src/shaders/debug.fragment.glsl +0 -9
  140. package/src/shaders/debug.vertex.glsl +0 -12
  141. package/src/shaders/encode_attribute.js +0 -17
  142. package/src/shaders/fill.fragment.glsl +0 -13
  143. package/src/shaders/fill.vertex.glsl +0 -13
  144. package/src/shaders/fill_extrusion.fragment.glsl +0 -9
  145. package/src/shaders/fill_extrusion.vertex.glsl +0 -66
  146. package/src/shaders/fill_extrusion_pattern.fragment.glsl +0 -45
  147. package/src/shaders/fill_extrusion_pattern.vertex.glsl +0 -79
  148. package/src/shaders/fill_outline.fragment.glsl +0 -17
  149. package/src/shaders/fill_outline.vertex.glsl +0 -17
  150. package/src/shaders/fill_outline_pattern.fragment.glsl +0 -43
  151. package/src/shaders/fill_outline_pattern.vertex.glsl +0 -44
  152. package/src/shaders/fill_pattern.fragment.glsl +0 -36
  153. package/src/shaders/fill_pattern.vertex.glsl +0 -39
  154. package/src/shaders/heatmap.fragment.glsl +0 -22
  155. package/src/shaders/heatmap.vertex.glsl +0 -54
  156. package/src/shaders/heatmap_texture.fragment.glsl +0 -14
  157. package/src/shaders/heatmap_texture.vertex.glsl +0 -11
  158. package/src/shaders/hillshade.fragment.glsl +0 -52
  159. package/src/shaders/hillshade.vertex.glsl +0 -11
  160. package/src/shaders/hillshade_prepare.fragment.glsl +0 -74
  161. package/src/shaders/hillshade_prepare.vertex.glsl +0 -15
  162. package/src/shaders/index.js +0 -20
  163. package/src/shaders/line.fragment.glsl +0 -30
  164. package/src/shaders/line.vertex.glsl +0 -85
  165. package/src/shaders/line_gradient.fragment.glsl +0 -34
  166. package/src/shaders/line_gradient.vertex.glsl +0 -87
  167. package/src/shaders/line_pattern.fragment.glsl +0 -74
  168. package/src/shaders/line_pattern.vertex.glsl +0 -99
  169. package/src/shaders/line_sdf.fragment.glsl +0 -45
  170. package/src/shaders/line_sdf.vertex.glsl +0 -98
  171. package/src/shaders/raster.fragment.glsl +0 -52
  172. package/src/shaders/raster.vertex.glsl +0 -21
  173. package/src/shaders/shaders.js +0 -180
  174. package/src/shaders/symbol_icon.fragment.glsl +0 -17
  175. package/src/shaders/symbol_icon.vertex.glsl +0 -94
  176. package/src/shaders/symbol_sdf.fragment.glsl +0 -52
  177. package/src/shaders/symbol_sdf.vertex.glsl +0 -115
  178. package/src/shaders/symbol_text_and_icon.fragment.glsl +0 -68
  179. package/src/shaders/symbol_text_and_icon.vertex.glsl +0 -116
  180. package/src/source/canvas_source.js +0 -238
  181. package/src/source/geojson_helper.js +0 -92
  182. package/src/source/geojson_source.js +0 -374
  183. package/src/source/geojson_worker_source.js +0 -357
  184. package/src/source/geojson_wrapper.js +0 -94
  185. package/src/source/image_source.js +0 -307
  186. package/src/source/load_tilejson.js +0 -39
  187. package/src/source/mbtiles_source.js +0 -115
  188. package/src/source/offline_database.js +0 -61
  189. package/src/source/offline_database_root.js +0 -62
  190. package/src/source/pixels_to_tile_units.js +0 -21
  191. package/src/source/query_features.js +0 -208
  192. package/src/source/raster_dem_tile_source.js +0 -138
  193. package/src/source/raster_dem_tile_worker_source.js +0 -62
  194. package/src/source/raster_tile_offline_source.js +0 -136
  195. package/src/source/raster_tile_source.js +0 -177
  196. package/src/source/rtl_text_plugin.js +0 -138
  197. package/src/source/source.js +0 -137
  198. package/src/source/source_cache.js +0 -957
  199. package/src/source/source_state.js +0 -159
  200. package/src/source/tile.js +0 -465
  201. package/src/source/tile_bounds.js +0 -38
  202. package/src/source/tile_cache.js +0 -212
  203. package/src/source/tile_id.js +0 -402
  204. package/src/source/vector_tile_source.js +0 -192
  205. package/src/source/vector_tile_worker_source.js +0 -216
  206. package/src/source/video_source.js +0 -203
  207. package/src/source/worker.js +0 -237
  208. package/src/source/worker_source.js +0 -106
  209. package/src/source/worker_tile.js +0 -224
  210. package/src/style/create_style_layer.js +0 -36
  211. package/src/style/evaluation_parameters.js +0 -62
  212. package/src/style/light.js +0 -130
  213. package/src/style/load_glyph_range.js +0 -38
  214. package/src/style/load_sprite.js +0 -67
  215. package/src/style/parse_glyph_pbf.js +0 -44
  216. package/src/style/pauseable_placement.js +0 -132
  217. package/src/style/properties.js +0 -753
  218. package/src/style/query_utils.js +0 -43
  219. package/src/style/style.js +0 -1361
  220. package/src/style/style_glyph.js +0 -17
  221. package/src/style/style_image.js +0 -137
  222. package/src/style/style_layer/background_style_layer.js +0 -21
  223. package/src/style/style_layer/background_style_layer_properties.js +0 -40
  224. package/src/style/style_layer/circle_style_layer.js +0 -98
  225. package/src/style/style_layer/circle_style_layer_properties.js +0 -63
  226. package/src/style/style_layer/custom_style_layer.js +0 -223
  227. package/src/style/style_layer/fill_extrusion_style_layer.js +0 -224
  228. package/src/style/style_layer/fill_extrusion_style_layer_properties.js +0 -50
  229. package/src/style/style_layer/fill_style_layer.js +0 -67
  230. package/src/style/style_layer/fill_style_layer_properties.js +0 -55
  231. package/src/style/style_layer/heatmap_style_layer.js +0 -69
  232. package/src/style/style_layer/heatmap_style_layer_properties.js +0 -44
  233. package/src/style/style_layer/hillshade_style_layer.js +0 -25
  234. package/src/style/style_layer/hillshade_style_layer_properties.js +0 -46
  235. package/src/style/style_layer/layer_properties.js.ejs +0 -69
  236. package/src/style/style_layer/line_style_layer.js +0 -151
  237. package/src/style/style_layer/line_style_layer_properties.js +0 -71
  238. package/src/style/style_layer/raster_style_layer.js +0 -21
  239. package/src/style/style_layer/raster_style_layer_properties.js +0 -50
  240. package/src/style/style_layer/symbol_style_layer.js +0 -190
  241. package/src/style/style_layer/symbol_style_layer_properties.js +0 -153
  242. package/src/style/style_layer/typed_style_layer.js +0 -17
  243. package/src/style/style_layer.js +0 -281
  244. package/src/style/style_layer_index.js +0 -80
  245. package/src/style/validate_style.js +0 -42
  246. package/src/style/zoom_history.js +0 -44
  247. package/src/style-spec/.eslintrc +0 -5
  248. package/src/style-spec/CHANGELOG.md +0 -438
  249. package/src/style-spec/README.md +0 -59
  250. package/src/style-spec/bin/gl-style-composite +0 -9
  251. package/src/style-spec/bin/gl-style-format +0 -22
  252. package/src/style-spec/bin/gl-style-migrate +0 -9
  253. package/src/style-spec/bin/gl-style-validate +0 -50
  254. package/src/style-spec/composite.js +0 -50
  255. package/src/style-spec/declass.js +0 -42
  256. package/src/style-spec/deref.js +0 -52
  257. package/src/style-spec/diff.js +0 -393
  258. package/src/style-spec/dist/.gitkeep +0 -0
  259. package/src/style-spec/empty.js +0 -29
  260. package/src/style-spec/error/parsing_error.js +0 -16
  261. package/src/style-spec/error/validation_error.js +0 -18
  262. package/src/style-spec/expression/compound_expression.js +0 -162
  263. package/src/style-spec/expression/definitions/assertion.js +0 -130
  264. package/src/style-spec/expression/definitions/at.js +0 -70
  265. package/src/style-spec/expression/definitions/case.js +0 -85
  266. package/src/style-spec/expression/definitions/coalesce.js +0 -93
  267. package/src/style-spec/expression/definitions/coercion.js +0 -133
  268. package/src/style-spec/expression/definitions/collator.js +0 -78
  269. package/src/style-spec/expression/definitions/comparison.js +0 -184
  270. package/src/style-spec/expression/definitions/format.js +0 -144
  271. package/src/style-spec/expression/definitions/format_section_override.js +0 -54
  272. package/src/style-spec/expression/definitions/image.js +0 -52
  273. package/src/style-spec/expression/definitions/in.js +0 -92
  274. package/src/style-spec/expression/definitions/index.js +0 -561
  275. package/src/style-spec/expression/definitions/interpolate.js +0 -267
  276. package/src/style-spec/expression/definitions/length.js +0 -61
  277. package/src/style-spec/expression/definitions/let.js +0 -72
  278. package/src/style-spec/expression/definitions/literal.js +0 -77
  279. package/src/style-spec/expression/definitions/match.js +0 -158
  280. package/src/style-spec/expression/definitions/number_format.js +0 -142
  281. package/src/style-spec/expression/definitions/step.js +0 -120
  282. package/src/style-spec/expression/definitions/var.js +0 -46
  283. package/src/style-spec/expression/definitions/within.js +0 -333
  284. package/src/style-spec/expression/evaluation_context.js +0 -59
  285. package/src/style-spec/expression/expression.js +0 -27
  286. package/src/style-spec/expression/index.js +0 -392
  287. package/src/style-spec/expression/is_constant.js +0 -59
  288. package/src/style-spec/expression/parsing_context.js +0 -233
  289. package/src/style-spec/expression/parsing_error.js +0 -13
  290. package/src/style-spec/expression/runtime_error.js +0 -17
  291. package/src/style-spec/expression/scope.js +0 -36
  292. package/src/style-spec/expression/stops.js +0 -39
  293. package/src/style-spec/expression/types/collator.js +0 -61
  294. package/src/style-spec/expression/types/formatted.js +0 -73
  295. package/src/style-spec/expression/types/resolved_image.js +0 -29
  296. package/src/style-spec/expression/types.js +0 -106
  297. package/src/style-spec/expression/values.js +0 -123
  298. package/src/style-spec/feature_filter/README.md +0 -55
  299. package/src/style-spec/feature_filter/convert.js +0 -208
  300. package/src/style-spec/feature_filter/index.js +0 -165
  301. package/src/style-spec/format.js +0 -51
  302. package/src/style-spec/function/convert.js +0 -254
  303. package/src/style-spec/function/index.js +0 -262
  304. package/src/style-spec/group_by_layout.js +0 -75
  305. package/src/style-spec/migrate/expressions.js +0 -39
  306. package/src/style-spec/migrate/v8.js +0 -203
  307. package/src/style-spec/migrate/v9.js +0 -26
  308. package/src/style-spec/migrate.js +0 -36
  309. package/src/style-spec/package.json +0 -41
  310. package/src/style-spec/read_style.js +0 -14
  311. package/src/style-spec/reference/latest.js +0 -3
  312. package/src/style-spec/reference/v8.json +0 -5808
  313. package/src/style-spec/rollup.config.js +0 -45
  314. package/src/style-spec/style-spec.js +0 -122
  315. package/src/style-spec/types.js +0 -438
  316. package/src/style-spec/util/color.js +0 -95
  317. package/src/style-spec/util/color_spaces.js +0 -139
  318. package/src/style-spec/util/deep_equal.js +0 -28
  319. package/src/style-spec/util/extend.js +0 -10
  320. package/src/style-spec/util/get_type.js +0 -17
  321. package/src/style-spec/util/interpolate.js +0 -22
  322. package/src/style-spec/util/properties.js +0 -15
  323. package/src/style-spec/util/ref_properties.js +0 -2
  324. package/src/style-spec/util/result.js +0 -19
  325. package/src/style-spec/util/unbundle_jsonlint.js +0 -24
  326. package/src/style-spec/validate/latest.js +0 -11
  327. package/src/style-spec/validate/validate.js +0 -75
  328. package/src/style-spec/validate/validate_array.js +0 -52
  329. package/src/style-spec/validate/validate_boolean.js +0 -15
  330. package/src/style-spec/validate/validate_color.js +0 -20
  331. package/src/style-spec/validate/validate_constants.js +0 -13
  332. package/src/style-spec/validate/validate_enum.js +0 -21
  333. package/src/style-spec/validate/validate_expression.js +0 -43
  334. package/src/style-spec/validate/validate_filter.js +0 -111
  335. package/src/style-spec/validate/validate_formatted.js +0 -11
  336. package/src/style-spec/validate/validate_function.js +0 -207
  337. package/src/style-spec/validate/validate_glyphs_url.js +0 -21
  338. package/src/style-spec/validate/validate_image.js +0 -11
  339. package/src/style-spec/validate/validate_layer.js +0 -134
  340. package/src/style-spec/validate/validate_layout_property.js +0 -6
  341. package/src/style-spec/validate/validate_light.js +0 -47
  342. package/src/style-spec/validate/validate_number.js +0 -29
  343. package/src/style-spec/validate/validate_object.js +0 -61
  344. package/src/style-spec/validate/validate_paint_property.js +0 -6
  345. package/src/style-spec/validate/validate_property.js +0 -64
  346. package/src/style-spec/validate/validate_source.js +0 -111
  347. package/src/style-spec/validate/validate_string.js +0 -15
  348. package/src/style-spec/validate_mapbox_api_supported.js +0 -171
  349. package/src/style-spec/validate_style.js +0 -39
  350. package/src/style-spec/validate_style.min.js +0 -78
  351. package/src/style-spec/visit.js +0 -77
  352. package/src/symbol/anchor.js +0 -26
  353. package/src/symbol/check_max_angle.js +0 -81
  354. package/src/symbol/clip_line.js +0 -71
  355. package/src/symbol/collision_feature.js +0 -217
  356. package/src/symbol/collision_index.js +0 -372
  357. package/src/symbol/cross_tile_symbol_index.js +0 -301
  358. package/src/symbol/get_anchors.js +0 -167
  359. package/src/symbol/grid_index.js +0 -335
  360. package/src/symbol/mergelines.js +0 -82
  361. package/src/symbol/one_em.js +0 -4
  362. package/src/symbol/opacity_state.js +0 -27
  363. package/src/symbol/placement.js +0 -1062
  364. package/src/symbol/projection.js +0 -450
  365. package/src/symbol/quads.js +0 -334
  366. package/src/symbol/shaping.js +0 -816
  367. package/src/symbol/symbol_layout.js +0 -772
  368. package/src/symbol/symbol_size.js +0 -113
  369. package/src/symbol/transform_text.js +0 -29
  370. package/src/types/callback.js +0 -17
  371. package/src/types/cancelable.js +0 -3
  372. package/src/types/tilejson.js +0 -17
  373. package/src/types/transferable.js +0 -3
  374. package/src/types/window.js +0 -172
  375. package/src/ui/anchor.js +0 -32
  376. package/src/ui/bind_handlers.js +0 -202
  377. package/src/ui/camera.js +0 -1152
  378. package/src/ui/control/attribution_control.js +0 -189
  379. package/src/ui/control/fps_control.js +0 -185
  380. package/src/ui/control/fullscreen_control.js +0 -147
  381. package/src/ui/control/geolocate_control.js +0 -594
  382. package/src/ui/control/logo_control.js +0 -92
  383. package/src/ui/control/navigation_control.js +0 -148
  384. package/src/ui/control/scale_control.js +0 -142
  385. package/src/ui/crs.js +0 -64
  386. package/src/ui/default_locale.js +0 -20
  387. package/src/ui/events.js +0 -806
  388. package/src/ui/handler/box_zoom.js +0 -175
  389. package/src/ui/handler/dblclick_zoom.js +0 -139
  390. package/src/ui/handler/drag_pan.js +0 -416
  391. package/src/ui/handler/drag_rotate.js +0 -378
  392. package/src/ui/handler/keyboard.js +0 -161
  393. package/src/ui/handler/scroll_zoom.js +0 -333
  394. package/src/ui/handler/touch_zoom_rotate.js +0 -293
  395. package/src/ui/hash.js +0 -147
  396. package/src/ui/map.js +0 -2883
  397. package/src/ui/marker.js +0 -607
  398. package/src/ui/offline_map.js +0 -91
  399. package/src/ui/popup.js +0 -530
  400. package/src/util/actor.js +0 -212
  401. package/src/util/ajax.js +0 -371
  402. package/src/util/browser/web_worker.js +0 -10
  403. package/src/util/browser/window.js +0 -5
  404. package/src/util/browser.js +0 -70
  405. package/src/util/classify_rings.js +0 -52
  406. package/src/util/color_ramp.js +0 -28
  407. package/src/util/config.js +0 -30
  408. package/src/util/debug.js +0 -12
  409. package/src/util/dictionary_coder.js +0 -30
  410. package/src/util/dispatcher.js +0 -70
  411. package/src/util/dom.js +0 -144
  412. package/src/util/evented.js +0 -174
  413. package/src/util/find_pole_of_inaccessibility.js +0 -129
  414. package/src/util/global_worker_pool.js +0 -17
  415. package/src/util/image.js +0 -142
  416. package/src/util/intersection_tests.js +0 -208
  417. package/src/util/is_char_in_unicode_block.js +0 -311
  418. package/src/util/mapbox.js +0 -486
  419. package/src/util/offscreen_canvas_supported.js +0 -14
  420. package/src/util/performance.js +0 -112
  421. package/src/util/primitives.js +0 -145
  422. package/src/util/resolve_tokens.js +0 -16
  423. package/src/util/script_detection.js +0 -328
  424. package/src/util/sku_token.js +0 -42
  425. package/src/util/smart_wrap.js +0 -55
  426. package/src/util/struct_array.js +0 -243
  427. package/src/util/struct_array.js.ejs +0 -112
  428. package/src/util/struct_array_layout.js.ejs +0 -98
  429. package/src/util/task_queue.js +0 -68
  430. package/src/util/throttle.js +0 -28
  431. package/src/util/throttled_invoker.js +0 -46
  432. package/src/util/tile_cover.js +0 -101
  433. package/src/util/tile_request_cache.js +0 -172
  434. package/src/util/util.js +0 -504
  435. package/src/util/vectortile_to_geojson.js +0 -54
  436. package/src/util/verticalize_punctuation.js +0 -114
  437. package/src/util/web_worker.js +0 -91
  438. package/src/util/web_worker_transfer.js +0 -266
  439. package/src/util/webp_supported.js +0 -69
  440. package/src/util/window.js +0 -102
  441. 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);