@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
|
@@ -1,172 +0,0 @@
|
|
|
1
|
-
// @flow
|
|
2
|
-
|
|
3
|
-
import {warnOnce, parseCacheControl} from './util';
|
|
4
|
-
import window from './window';
|
|
5
|
-
|
|
6
|
-
import type Dispatcher from './dispatcher';
|
|
7
|
-
|
|
8
|
-
const CACHE_NAME = 'mapbox-tiles';
|
|
9
|
-
let cacheLimit = 500; // 50MB / (100KB/tile) ~= 500 tiles
|
|
10
|
-
let cacheCheckThreshold = 50;
|
|
11
|
-
|
|
12
|
-
const MIN_TIME_UNTIL_EXPIRY = 1000 * 60 * 7; // 7 minutes. Skip caching tiles with a short enough max age.
|
|
13
|
-
|
|
14
|
-
export type ResponseOptions = {
|
|
15
|
-
status: number,
|
|
16
|
-
statusText: string,
|
|
17
|
-
headers: window.Headers
|
|
18
|
-
};
|
|
19
|
-
|
|
20
|
-
// We're using a global shared cache object. Normally, requesting ad-hoc Cache objects is fine, but
|
|
21
|
-
// Safari has a memory leak in which it fails to release memory when requesting keys() from a Cache
|
|
22
|
-
// object. See https://bugs.webkit.org/show_bug.cgi?id=203991 for more information.
|
|
23
|
-
let sharedCache: ?Promise<Cache>;
|
|
24
|
-
|
|
25
|
-
function cacheOpen() {
|
|
26
|
-
if (window.caches && !sharedCache) {
|
|
27
|
-
sharedCache = window.caches.open(CACHE_NAME);
|
|
28
|
-
}
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
// We're never closing the cache, but our unit tests rely on changing out the global window.caches
|
|
32
|
-
// object, so we have a function specifically for unit tests that allows resetting the shared cache.
|
|
33
|
-
export function cacheClose() {
|
|
34
|
-
sharedCache = undefined;
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
let responseConstructorSupportsReadableStream;
|
|
38
|
-
function prepareBody(response: Response, callback) {
|
|
39
|
-
if (responseConstructorSupportsReadableStream === undefined) {
|
|
40
|
-
try {
|
|
41
|
-
new Response(new ReadableStream()); // eslint-disable-line no-undef
|
|
42
|
-
responseConstructorSupportsReadableStream = true;
|
|
43
|
-
} catch (e) {
|
|
44
|
-
// Edge
|
|
45
|
-
responseConstructorSupportsReadableStream = false;
|
|
46
|
-
}
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
if (responseConstructorSupportsReadableStream) {
|
|
50
|
-
callback(response.body);
|
|
51
|
-
} else {
|
|
52
|
-
response.blob().then(callback);
|
|
53
|
-
}
|
|
54
|
-
}
|
|
55
|
-
|
|
56
|
-
export function cachePut(request: Request, response: Response, requestTime: number) {
|
|
57
|
-
cacheOpen();
|
|
58
|
-
if (!sharedCache) return;
|
|
59
|
-
|
|
60
|
-
const options: ResponseOptions = {
|
|
61
|
-
status: response.status,
|
|
62
|
-
statusText: response.statusText,
|
|
63
|
-
headers: new window.Headers()
|
|
64
|
-
};
|
|
65
|
-
response.headers.forEach((v, k) => options.headers.set(k, v));
|
|
66
|
-
|
|
67
|
-
const cacheControl = parseCacheControl(response.headers.get('Cache-Control') || '');
|
|
68
|
-
if (cacheControl['no-store']) {
|
|
69
|
-
return;
|
|
70
|
-
}
|
|
71
|
-
if (cacheControl['max-age']) {
|
|
72
|
-
options.headers.set('Expires', new Date(requestTime + cacheControl['max-age'] * 1000).toUTCString());
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
const timeUntilExpiry = new Date(options.headers.get('Expires')).getTime() - requestTime;
|
|
76
|
-
if (timeUntilExpiry < MIN_TIME_UNTIL_EXPIRY) return;
|
|
77
|
-
|
|
78
|
-
prepareBody(response, body => {
|
|
79
|
-
const clonedResponse = new window.Response(body, options);
|
|
80
|
-
|
|
81
|
-
cacheOpen();
|
|
82
|
-
if (!sharedCache) return;
|
|
83
|
-
sharedCache
|
|
84
|
-
.then(cache => cache.put(stripQueryParameters(request.url), clonedResponse))
|
|
85
|
-
.catch(e => warnOnce(e.message));
|
|
86
|
-
});
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
function stripQueryParameters(url: string) {
|
|
90
|
-
const start = url.indexOf('?');
|
|
91
|
-
return start < 0 ? url : url.slice(0, start);
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
export function cacheGet(request: Request, callback: (error: ?any, response: ?Response, fresh: ?boolean) => void) {
|
|
95
|
-
cacheOpen();
|
|
96
|
-
if (!sharedCache) return callback(null);
|
|
97
|
-
|
|
98
|
-
const strippedURL = stripQueryParameters(request.url);
|
|
99
|
-
|
|
100
|
-
sharedCache
|
|
101
|
-
.then(cache => {
|
|
102
|
-
// manually strip URL instead of `ignoreSearch: true` because of a known
|
|
103
|
-
// performance issue in Chrome https://github.com/mapbox/mapbox-gl-js/issues/8431
|
|
104
|
-
cache.match(strippedURL)
|
|
105
|
-
.then(response => {
|
|
106
|
-
const fresh = isFresh(response);
|
|
107
|
-
|
|
108
|
-
// Reinsert into cache so that order of keys in the cache is the order of access.
|
|
109
|
-
// This line makes the cache a LRU instead of a FIFO cache.
|
|
110
|
-
cache.delete(strippedURL);
|
|
111
|
-
if (fresh) {
|
|
112
|
-
cache.put(strippedURL, response.clone());
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
callback(null, response, fresh);
|
|
116
|
-
})
|
|
117
|
-
.catch(callback);
|
|
118
|
-
})
|
|
119
|
-
.catch(callback);
|
|
120
|
-
|
|
121
|
-
}
|
|
122
|
-
|
|
123
|
-
function isFresh(response) {
|
|
124
|
-
if (!response) return false;
|
|
125
|
-
const expires = new Date(response.headers.get('Expires') || 0);
|
|
126
|
-
const cacheControl = parseCacheControl(response.headers.get('Cache-Control') || '');
|
|
127
|
-
return expires > Date.now() && !cacheControl['no-cache'];
|
|
128
|
-
}
|
|
129
|
-
|
|
130
|
-
// `Infinity` triggers a cache check after the first tile is loaded
|
|
131
|
-
// so that a check is run at least once on each page load.
|
|
132
|
-
let globalEntryCounter = Infinity;
|
|
133
|
-
|
|
134
|
-
// The cache check gets run on a worker. The reason for this is that
|
|
135
|
-
// profiling sometimes shows this as taking up significant time on the
|
|
136
|
-
// thread it gets called from. And sometimes it doesn't. It *may* be
|
|
137
|
-
// fine to run this on the main thread but out of caution this is being
|
|
138
|
-
// dispatched on a worker. This can be investigated further in the future.
|
|
139
|
-
export function cacheEntryPossiblyAdded(dispatcher: Dispatcher) {
|
|
140
|
-
globalEntryCounter++;
|
|
141
|
-
if (globalEntryCounter > cacheCheckThreshold) {
|
|
142
|
-
dispatcher.getActor().send('enforceCacheSizeLimit', cacheLimit);
|
|
143
|
-
globalEntryCounter = 0;
|
|
144
|
-
}
|
|
145
|
-
}
|
|
146
|
-
|
|
147
|
-
// runs on worker, see above comment
|
|
148
|
-
export function enforceCacheSizeLimit(limit: number) {
|
|
149
|
-
cacheOpen();
|
|
150
|
-
if (!sharedCache) return;
|
|
151
|
-
|
|
152
|
-
sharedCache
|
|
153
|
-
.then(cache => {
|
|
154
|
-
cache.keys().then(keys => {
|
|
155
|
-
for (let i = 0; i < keys.length - limit; i++) {
|
|
156
|
-
cache.delete(keys[i]);
|
|
157
|
-
}
|
|
158
|
-
});
|
|
159
|
-
});
|
|
160
|
-
}
|
|
161
|
-
|
|
162
|
-
export function clearTileCache(callback?: (err: ?Error) => void) {
|
|
163
|
-
const promise = window.caches.delete(CACHE_NAME);
|
|
164
|
-
if (callback) {
|
|
165
|
-
promise.catch(callback).then(() => callback());
|
|
166
|
-
}
|
|
167
|
-
}
|
|
168
|
-
|
|
169
|
-
export function setCacheLimits(limit: number, checkThreshold: number) {
|
|
170
|
-
cacheLimit = limit;
|
|
171
|
-
cacheCheckThreshold = checkThreshold;
|
|
172
|
-
}
|
package/src/util/util.js
DELETED
|
@@ -1,504 +0,0 @@
|
|
|
1
|
-
// @flow
|
|
2
|
-
|
|
3
|
-
import UnitBezier from '@mapbox/unitbezier';
|
|
4
|
-
|
|
5
|
-
import Point from '@mapbox/point-geometry';
|
|
6
|
-
import window from './window';
|
|
7
|
-
|
|
8
|
-
import type {Callback} from '../types/callback';
|
|
9
|
-
|
|
10
|
-
/**
|
|
11
|
-
* @module util
|
|
12
|
-
* @private
|
|
13
|
-
*/
|
|
14
|
-
|
|
15
|
-
/**
|
|
16
|
-
* Given a value `t` that varies between 0 and 1, return
|
|
17
|
-
* an interpolation function that eases between 0 and 1 in a pleasing
|
|
18
|
-
* cubic in-out fashion.
|
|
19
|
-
*
|
|
20
|
-
* @private
|
|
21
|
-
*/
|
|
22
|
-
export function easeCubicInOut(t: number): number {
|
|
23
|
-
if (t <= 0) return 0;
|
|
24
|
-
if (t >= 1) return 1;
|
|
25
|
-
const t2 = t * t,
|
|
26
|
-
t3 = t2 * t;
|
|
27
|
-
return 4 * (t < 0.5 ? t3 : 3 * (t - t2) + t3 - 0.75);
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
/**
|
|
31
|
-
* Given given (x, y), (x1, y1) control points for a bezier curve,
|
|
32
|
-
* return a function that interpolates along that curve.
|
|
33
|
-
*
|
|
34
|
-
* @param p1x control point 1 x coordinate
|
|
35
|
-
* @param p1y control point 1 y coordinate
|
|
36
|
-
* @param p2x control point 2 x coordinate
|
|
37
|
-
* @param p2y control point 2 y coordinate
|
|
38
|
-
* @private
|
|
39
|
-
*/
|
|
40
|
-
export function bezier(p1x: number, p1y: number, p2x: number, p2y: number): (t: number) => number {
|
|
41
|
-
const bezier = new UnitBezier(p1x, p1y, p2x, p2y);
|
|
42
|
-
return function(t: number) {
|
|
43
|
-
return bezier.solve(t);
|
|
44
|
-
};
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
/**
|
|
48
|
-
* A default bezier-curve powered easing function with
|
|
49
|
-
* control points (0.25, 0.1) and (0.25, 1)
|
|
50
|
-
*
|
|
51
|
-
* @private
|
|
52
|
-
*/
|
|
53
|
-
export const ease = bezier(0.25, 0.1, 0.25, 1);
|
|
54
|
-
|
|
55
|
-
/**
|
|
56
|
-
* constrain n to the given range via min + max
|
|
57
|
-
*
|
|
58
|
-
* @param n value
|
|
59
|
-
* @param min the minimum value to be returned
|
|
60
|
-
* @param max the maximum value to be returned
|
|
61
|
-
* @returns the clamped value
|
|
62
|
-
* @private
|
|
63
|
-
*/
|
|
64
|
-
export function clamp(n: number, min: number, max: number): number {
|
|
65
|
-
return Math.min(max, Math.max(min, n));
|
|
66
|
-
}
|
|
67
|
-
|
|
68
|
-
/**
|
|
69
|
-
* constrain n to the given range, excluding the minimum, via modular arithmetic
|
|
70
|
-
*
|
|
71
|
-
* @param n value
|
|
72
|
-
* @param min the minimum value to be returned, exclusive
|
|
73
|
-
* @param max the maximum value to be returned, inclusive
|
|
74
|
-
* @returns constrained number
|
|
75
|
-
* @private
|
|
76
|
-
*/
|
|
77
|
-
export function wrap(n: number, min: number, max: number): number {
|
|
78
|
-
const d = max - min;
|
|
79
|
-
const w = ((n - min) % d + d) % d + min;
|
|
80
|
-
return (w === min) ? max : w;
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
/*
|
|
84
|
-
* Call an asynchronous function on an array of arguments,
|
|
85
|
-
* calling `callback` with the completed results of all calls.
|
|
86
|
-
*
|
|
87
|
-
* @param array input to each call of the async function.
|
|
88
|
-
* @param fn an async function with signature (data, callback)
|
|
89
|
-
* @param callback a callback run after all async work is done.
|
|
90
|
-
* called with an array, containing the results of each async call.
|
|
91
|
-
* @private
|
|
92
|
-
*/
|
|
93
|
-
export function asyncAll<Item, Result>(
|
|
94
|
-
array: Array<Item>,
|
|
95
|
-
fn: (item: Item, fnCallback: Callback<Result>) => void,
|
|
96
|
-
callback: Callback<Array<Result>>
|
|
97
|
-
) {
|
|
98
|
-
if (!array.length) { return callback(null, []); }
|
|
99
|
-
let remaining = array.length;
|
|
100
|
-
const results = new Array(array.length);
|
|
101
|
-
let error = null;
|
|
102
|
-
array.forEach((item, i) => {
|
|
103
|
-
fn(item, (err, result) => {
|
|
104
|
-
if (err) error = err;
|
|
105
|
-
results[i] = ((result: any): Result); // https://github.com/facebook/flow/issues/2123
|
|
106
|
-
if (--remaining === 0) callback(error, results);
|
|
107
|
-
});
|
|
108
|
-
});
|
|
109
|
-
}
|
|
110
|
-
|
|
111
|
-
/*
|
|
112
|
-
* Polyfill for Object.values. Not fully spec compliant, but we don't
|
|
113
|
-
* need it to be.
|
|
114
|
-
*
|
|
115
|
-
* @private
|
|
116
|
-
*/
|
|
117
|
-
export function values<T>(obj: {[key: string]: T}): Array<T> {
|
|
118
|
-
const result = [];
|
|
119
|
-
for (const k in obj) {
|
|
120
|
-
result.push(obj[k]);
|
|
121
|
-
}
|
|
122
|
-
return result;
|
|
123
|
-
}
|
|
124
|
-
|
|
125
|
-
/*
|
|
126
|
-
* Compute the difference between the keys in one object and the keys
|
|
127
|
-
* in another object.
|
|
128
|
-
*
|
|
129
|
-
* @returns keys difference
|
|
130
|
-
* @private
|
|
131
|
-
*/
|
|
132
|
-
export function keysDifference<S, T>(obj: {[key: string]: S}, other: {[key: string]: T}): Array<string> {
|
|
133
|
-
const difference = [];
|
|
134
|
-
for (const i in obj) {
|
|
135
|
-
if (!(i in other)) {
|
|
136
|
-
difference.push(i);
|
|
137
|
-
}
|
|
138
|
-
}
|
|
139
|
-
return difference;
|
|
140
|
-
}
|
|
141
|
-
|
|
142
|
-
/**
|
|
143
|
-
* Given a destination object and optionally many source objects,
|
|
144
|
-
* copy all properties from the source objects into the destination.
|
|
145
|
-
* The last source object given overrides properties from previous
|
|
146
|
-
* source objects.
|
|
147
|
-
*
|
|
148
|
-
* @param dest destination object
|
|
149
|
-
* @param sources sources from which properties are pulled
|
|
150
|
-
* @private
|
|
151
|
-
*/
|
|
152
|
-
export function extend(dest: Object, ...sources: Array<?Object>): Object {
|
|
153
|
-
for (const src of sources) {
|
|
154
|
-
for (const k in src) {
|
|
155
|
-
dest[k] = src[k];
|
|
156
|
-
}
|
|
157
|
-
}
|
|
158
|
-
return dest;
|
|
159
|
-
}
|
|
160
|
-
|
|
161
|
-
/**
|
|
162
|
-
* Given an object and a number of properties as strings, return version
|
|
163
|
-
* of that object with only those properties.
|
|
164
|
-
*
|
|
165
|
-
* @param src the object
|
|
166
|
-
* @param properties an array of property names chosen
|
|
167
|
-
* to appear on the resulting object.
|
|
168
|
-
* @returns object with limited properties.
|
|
169
|
-
* @example
|
|
170
|
-
* var foo = { name: 'Charlie', age: 10 };
|
|
171
|
-
* var justName = pick(foo, ['name']);
|
|
172
|
-
* // justName = { name: 'Charlie' }
|
|
173
|
-
* @private
|
|
174
|
-
*/
|
|
175
|
-
export function pick(src: Object, properties: Array<string>): Object {
|
|
176
|
-
const result = {};
|
|
177
|
-
for (let i = 0; i < properties.length; i++) {
|
|
178
|
-
const k = properties[i];
|
|
179
|
-
if (k in src) {
|
|
180
|
-
result[k] = src[k];
|
|
181
|
-
}
|
|
182
|
-
}
|
|
183
|
-
return result;
|
|
184
|
-
}
|
|
185
|
-
|
|
186
|
-
let id = 1;
|
|
187
|
-
|
|
188
|
-
/**
|
|
189
|
-
* Return a unique numeric id, starting at 1 and incrementing with
|
|
190
|
-
* each call.
|
|
191
|
-
*
|
|
192
|
-
* @returns unique numeric id.
|
|
193
|
-
* @private
|
|
194
|
-
*/
|
|
195
|
-
export function uniqueId(): number {
|
|
196
|
-
return id++;
|
|
197
|
-
}
|
|
198
|
-
|
|
199
|
-
/**
|
|
200
|
-
* Return a random UUID (v4). Taken from: https://gist.github.com/jed/982883
|
|
201
|
-
* @private
|
|
202
|
-
*/
|
|
203
|
-
export function uuid(): string {
|
|
204
|
-
function b(a) {
|
|
205
|
-
return a ? (a ^ Math.random() * 16 >> a / 4).toString(16) :
|
|
206
|
-
//$FlowFixMe: Flow doesn't like the implied array literal conversion here
|
|
207
|
-
([1e7] + -[1e3] + -4e3 + -8e3 + -1e11).replace(/[018]/g, b);
|
|
208
|
-
}
|
|
209
|
-
return b();
|
|
210
|
-
}
|
|
211
|
-
|
|
212
|
-
/**
|
|
213
|
-
* Validate a string to match UUID(v4) of the
|
|
214
|
-
* form: xxxxxxxx-xxxx-4xxx-[89ab]xxx-xxxxxxxxxxxx
|
|
215
|
-
* @param str string to validate.
|
|
216
|
-
* @private
|
|
217
|
-
*/
|
|
218
|
-
export function validateUuid(str: ?string): boolean {
|
|
219
|
-
return str ? /^[0-9a-f]{8}-[0-9a-f]{4}-[4][0-9a-f]{3}-[89ab][0-9a-f]{3}-[0-9a-f]{12}$/i.test(str) : false;
|
|
220
|
-
}
|
|
221
|
-
|
|
222
|
-
/**
|
|
223
|
-
* Given an array of member function names as strings, replace all of them
|
|
224
|
-
* with bound versions that will always refer to `context` as `this`. This
|
|
225
|
-
* is useful for classes where otherwise event bindings would reassign
|
|
226
|
-
* `this` to the evented object or some other value: this lets you ensure
|
|
227
|
-
* the `this` value always.
|
|
228
|
-
*
|
|
229
|
-
* @param fns list of member function names
|
|
230
|
-
* @param context the context value
|
|
231
|
-
* @example
|
|
232
|
-
* function MyClass() {
|
|
233
|
-
* bindAll(['ontimer'], this);
|
|
234
|
-
* this.name = 'Tom';
|
|
235
|
-
* }
|
|
236
|
-
* MyClass.prototype.ontimer = function() {
|
|
237
|
-
* alert(this.name);
|
|
238
|
-
* };
|
|
239
|
-
* var myClass = new MyClass();
|
|
240
|
-
* setTimeout(myClass.ontimer, 100);
|
|
241
|
-
* @private
|
|
242
|
-
*/
|
|
243
|
-
export function bindAll(fns: Array<string>, context: Object): void {
|
|
244
|
-
fns.forEach((fn) => {
|
|
245
|
-
if (!context[fn]) { return; }
|
|
246
|
-
context[fn] = context[fn].bind(context);
|
|
247
|
-
});
|
|
248
|
-
}
|
|
249
|
-
|
|
250
|
-
/**
|
|
251
|
-
* Determine if a string ends with a particular substring
|
|
252
|
-
*
|
|
253
|
-
* @private
|
|
254
|
-
*/
|
|
255
|
-
export function endsWith(string: string, suffix: string): boolean {
|
|
256
|
-
return string.indexOf(suffix, string.length - suffix.length) !== -1;
|
|
257
|
-
}
|
|
258
|
-
|
|
259
|
-
/**
|
|
260
|
-
* Create an object by mapping all the values of an existing object while
|
|
261
|
-
* preserving their keys.
|
|
262
|
-
*
|
|
263
|
-
* @private
|
|
264
|
-
*/
|
|
265
|
-
export function mapObject(input: Object, iterator: Function, context?: Object): Object {
|
|
266
|
-
const output = {};
|
|
267
|
-
for (const key in input) {
|
|
268
|
-
output[key] = iterator.call(context || this, input[key], key, input);
|
|
269
|
-
}
|
|
270
|
-
return output;
|
|
271
|
-
}
|
|
272
|
-
|
|
273
|
-
/**
|
|
274
|
-
* Create an object by filtering out values of an existing object.
|
|
275
|
-
*
|
|
276
|
-
* @private
|
|
277
|
-
*/
|
|
278
|
-
export function filterObject(input: Object, iterator: Function, context?: Object): Object {
|
|
279
|
-
const output = {};
|
|
280
|
-
for (const key in input) {
|
|
281
|
-
if (iterator.call(context || this, input[key], key, input)) {
|
|
282
|
-
output[key] = input[key];
|
|
283
|
-
}
|
|
284
|
-
}
|
|
285
|
-
return output;
|
|
286
|
-
}
|
|
287
|
-
|
|
288
|
-
import deepEqual from '../style-spec/util/deep_equal';
|
|
289
|
-
export {deepEqual};
|
|
290
|
-
|
|
291
|
-
/**
|
|
292
|
-
* Deeply clones two objects.
|
|
293
|
-
*
|
|
294
|
-
* @private
|
|
295
|
-
*/
|
|
296
|
-
export function clone<T>(input: T): T {
|
|
297
|
-
if (Array.isArray(input)) {
|
|
298
|
-
return input.map(clone);
|
|
299
|
-
} else if (typeof input === 'object' && input) {
|
|
300
|
-
return ((mapObject(input, clone): any): T);
|
|
301
|
-
} else {
|
|
302
|
-
return input;
|
|
303
|
-
}
|
|
304
|
-
}
|
|
305
|
-
|
|
306
|
-
/**
|
|
307
|
-
* Check if two arrays have at least one common element.
|
|
308
|
-
*
|
|
309
|
-
* @private
|
|
310
|
-
*/
|
|
311
|
-
export function arraysIntersect<T>(a: Array<T>, b: Array<T>): boolean {
|
|
312
|
-
for (let l = 0; l < a.length; l++) {
|
|
313
|
-
if (b.indexOf(a[l]) >= 0) return true;
|
|
314
|
-
}
|
|
315
|
-
return false;
|
|
316
|
-
}
|
|
317
|
-
|
|
318
|
-
/**
|
|
319
|
-
* Print a warning message to the console and ensure duplicate warning messages
|
|
320
|
-
* are not printed.
|
|
321
|
-
*
|
|
322
|
-
* @private
|
|
323
|
-
*/
|
|
324
|
-
const warnOnceHistory: {[key: string]: boolean} = {};
|
|
325
|
-
|
|
326
|
-
export function warnOnce(message: string): void {
|
|
327
|
-
if (!warnOnceHistory[message]) {
|
|
328
|
-
// console isn't defined in some WebWorkers, see #2558
|
|
329
|
-
if (typeof console !== "undefined") console.warn(message);
|
|
330
|
-
warnOnceHistory[message] = true;
|
|
331
|
-
}
|
|
332
|
-
}
|
|
333
|
-
|
|
334
|
-
/**
|
|
335
|
-
* Indicates if the provided Points are in a counter clockwise (true) or clockwise (false) order
|
|
336
|
-
*
|
|
337
|
-
* @private
|
|
338
|
-
* @returns true for a counter clockwise set of points
|
|
339
|
-
*/
|
|
340
|
-
// http://bryceboe.com/2006/10/23/line-segment-intersection-algorithm/
|
|
341
|
-
export function isCounterClockwise(a: Point, b: Point, c: Point): boolean {
|
|
342
|
-
return (c.y - a.y) * (b.x - a.x) > (b.y - a.y) * (c.x - a.x);
|
|
343
|
-
}
|
|
344
|
-
|
|
345
|
-
/**
|
|
346
|
-
* Returns the signed area for the polygon ring. Postive areas are exterior rings and
|
|
347
|
-
* have a clockwise winding. Negative areas are interior rings and have a counter clockwise
|
|
348
|
-
* ordering.
|
|
349
|
-
*
|
|
350
|
-
* @private
|
|
351
|
-
* @param ring Exterior or interior ring
|
|
352
|
-
*/
|
|
353
|
-
export function calculateSignedArea(ring: Array<Point>): number {
|
|
354
|
-
let sum = 0;
|
|
355
|
-
for (let i = 0, len = ring.length, j = len - 1, p1, p2; i < len; j = i++) {
|
|
356
|
-
p1 = ring[i];
|
|
357
|
-
p2 = ring[j];
|
|
358
|
-
sum += (p2.x - p1.x) * (p1.y + p2.y);
|
|
359
|
-
}
|
|
360
|
-
return sum;
|
|
361
|
-
}
|
|
362
|
-
|
|
363
|
-
/**
|
|
364
|
-
* Detects closed polygons, first + last point are equal
|
|
365
|
-
*
|
|
366
|
-
* @private
|
|
367
|
-
* @param points array of points
|
|
368
|
-
* @return true if the points are a closed polygon
|
|
369
|
-
*/
|
|
370
|
-
export function isClosedPolygon(points: Array<Point>): boolean {
|
|
371
|
-
// If it is 2 points that are the same then it is a point
|
|
372
|
-
// If it is 3 points with start and end the same then it is a line
|
|
373
|
-
if (points.length < 4)
|
|
374
|
-
return false;
|
|
375
|
-
|
|
376
|
-
const p1 = points[0];
|
|
377
|
-
const p2 = points[points.length - 1];
|
|
378
|
-
|
|
379
|
-
if (Math.abs(p1.x - p2.x) > 0 ||
|
|
380
|
-
Math.abs(p1.y - p2.y) > 0) {
|
|
381
|
-
return false;
|
|
382
|
-
}
|
|
383
|
-
|
|
384
|
-
// polygon simplification can produce polygons with zero area and more than 3 points
|
|
385
|
-
return Math.abs(calculateSignedArea(points)) > 0.01;
|
|
386
|
-
}
|
|
387
|
-
|
|
388
|
-
/**
|
|
389
|
-
* Converts spherical coordinates to cartesian coordinates.
|
|
390
|
-
*
|
|
391
|
-
* @private
|
|
392
|
-
* @param spherical Spherical coordinates, in [radial, azimuthal, polar]
|
|
393
|
-
* @return cartesian coordinates in [x, y, z]
|
|
394
|
-
*/
|
|
395
|
-
|
|
396
|
-
export function sphericalToCartesian([r, azimuthal, polar]: [number, number, number]): {x: number, y: number, z: number} {
|
|
397
|
-
// We abstract "north"/"up" (compass-wise) to be 0° when really this is 90° (π/2):
|
|
398
|
-
// correct for that here
|
|
399
|
-
azimuthal += 90;
|
|
400
|
-
|
|
401
|
-
// Convert azimuthal and polar angles to radians
|
|
402
|
-
azimuthal *= Math.PI / 180;
|
|
403
|
-
polar *= Math.PI / 180;
|
|
404
|
-
|
|
405
|
-
return {
|
|
406
|
-
x: r * Math.cos(azimuthal) * Math.sin(polar),
|
|
407
|
-
y: r * Math.sin(azimuthal) * Math.sin(polar),
|
|
408
|
-
z: r * Math.cos(polar)
|
|
409
|
-
};
|
|
410
|
-
}
|
|
411
|
-
|
|
412
|
-
/* global self, WorkerGlobalScope */
|
|
413
|
-
/**
|
|
414
|
-
* Retuns true if the when run in the web-worker context.
|
|
415
|
-
*
|
|
416
|
-
* @private
|
|
417
|
-
* @returns {boolean}
|
|
418
|
-
*/
|
|
419
|
-
export function isWorker(): boolean {
|
|
420
|
-
return typeof WorkerGlobalScope !== 'undefined' && typeof self !== 'undefined' &&
|
|
421
|
-
self instanceof WorkerGlobalScope;
|
|
422
|
-
}
|
|
423
|
-
|
|
424
|
-
/**
|
|
425
|
-
* Parses data from 'Cache-Control' headers.
|
|
426
|
-
*
|
|
427
|
-
* @private
|
|
428
|
-
* @param cacheControl Value of 'Cache-Control' header
|
|
429
|
-
* @return object containing parsed header info.
|
|
430
|
-
*/
|
|
431
|
-
|
|
432
|
-
export function parseCacheControl(cacheControl: string): Object {
|
|
433
|
-
// Taken from [Wreck](https://github.com/hapijs/wreck)
|
|
434
|
-
const re = /(?:^|(?:\s*\,\s*))([^\x00-\x20\(\)<>@\,;\:\\"\/\[\]\?\=\{\}\x7F]+)(?:\=(?:([^\x00-\x20\(\)<>@\,;\:\\"\/\[\]\?\=\{\}\x7F]+)|(?:\"((?:[^"\\]|\\.)*)\")))?/g;
|
|
435
|
-
|
|
436
|
-
const header = {};
|
|
437
|
-
cacheControl.replace(re, ($0, $1, $2, $3) => {
|
|
438
|
-
const value = $2 || $3;
|
|
439
|
-
header[$1] = value ? value.toLowerCase() : true;
|
|
440
|
-
return '';
|
|
441
|
-
});
|
|
442
|
-
|
|
443
|
-
if (header['max-age']) {
|
|
444
|
-
const maxAge = parseInt(header['max-age'], 10);
|
|
445
|
-
if (isNaN(maxAge)) delete header['max-age'];
|
|
446
|
-
else header['max-age'] = maxAge;
|
|
447
|
-
}
|
|
448
|
-
|
|
449
|
-
return header;
|
|
450
|
-
}
|
|
451
|
-
|
|
452
|
-
let _isSafari = null;
|
|
453
|
-
|
|
454
|
-
/**
|
|
455
|
-
* Returns true when run in WebKit derived browsers.
|
|
456
|
-
* This is used as a workaround for a memory leak in Safari caused by using Transferable objects to
|
|
457
|
-
* transfer data between WebWorkers and the main thread.
|
|
458
|
-
* https://github.com/mapbox/mapbox-gl-js/issues/8771
|
|
459
|
-
*
|
|
460
|
-
* This should be removed once the underlying Safari issue is fixed.
|
|
461
|
-
*
|
|
462
|
-
* @private
|
|
463
|
-
* @param scope {WindowOrWorkerGlobalScope} Since this function is used both on the main thread and WebWorker context,
|
|
464
|
-
* let the calling scope pass in the global scope object.
|
|
465
|
-
* @returns {boolean}
|
|
466
|
-
*/
|
|
467
|
-
export function isSafari(scope: any): boolean {
|
|
468
|
-
if (_isSafari == null) {
|
|
469
|
-
const userAgent = scope.navigator ? scope.navigator.userAgent : null;
|
|
470
|
-
_isSafari = !!scope.safari ||
|
|
471
|
-
!!(userAgent && (/\b(iPad|iPhone|iPod)\b/.test(userAgent) || (!!userAgent.match('Safari') && !userAgent.match('Chrome'))));
|
|
472
|
-
}
|
|
473
|
-
return _isSafari;
|
|
474
|
-
}
|
|
475
|
-
|
|
476
|
-
export function storageAvailable(type: string): boolean {
|
|
477
|
-
try {
|
|
478
|
-
const storage = window[type];
|
|
479
|
-
storage.setItem('_mapbox_test_', 1);
|
|
480
|
-
storage.removeItem('_mapbox_test_');
|
|
481
|
-
return true;
|
|
482
|
-
} catch (e) {
|
|
483
|
-
return false;
|
|
484
|
-
}
|
|
485
|
-
}
|
|
486
|
-
|
|
487
|
-
// The following methods are from https://developer.mozilla.org/en-US/docs/Web/API/WindowBase64/Base64_encoding_and_decoding#The_Unicode_Problem
|
|
488
|
-
//Unicode compliant base64 encoder for strings
|
|
489
|
-
export function b64EncodeUnicode(str: string) {
|
|
490
|
-
return window.btoa(
|
|
491
|
-
encodeURIComponent(str).replace(/%([0-9A-F]{2})/g,
|
|
492
|
-
(match, p1) => {
|
|
493
|
-
return String.fromCharCode(Number('0x' + p1)); //eslint-disable-line
|
|
494
|
-
}
|
|
495
|
-
)
|
|
496
|
-
);
|
|
497
|
-
}
|
|
498
|
-
|
|
499
|
-
// Unicode compliant decoder for base64-encoded strings
|
|
500
|
-
export function b64DecodeUnicode(str: string) {
|
|
501
|
-
return decodeURIComponent(window.atob(str).split('').map((c) => {
|
|
502
|
-
return '%' + ('00' + c.charCodeAt(0).toString(16)).slice(-2); //eslint-disable-line
|
|
503
|
-
}).join(''));
|
|
504
|
-
}
|