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