@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,111 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
import ValidationError from '../error/validation_error';
|
|
3
|
-
import validateExpression from './validate_expression';
|
|
4
|
-
import validateEnum from './validate_enum';
|
|
5
|
-
import getType from '../util/get_type';
|
|
6
|
-
import {unbundle, deepUnbundle} from '../util/unbundle_jsonlint';
|
|
7
|
-
import extend from '../util/extend';
|
|
8
|
-
import {isExpressionFilter} from '../feature_filter';
|
|
9
|
-
|
|
10
|
-
export default function validateFilter(options) {
|
|
11
|
-
if (isExpressionFilter(deepUnbundle(options.value))) {
|
|
12
|
-
return validateExpression(extend({}, options, {
|
|
13
|
-
expressionContext: 'filter',
|
|
14
|
-
valueSpec: {value: 'boolean'}
|
|
15
|
-
}));
|
|
16
|
-
} else {
|
|
17
|
-
return validateNonExpressionFilter(options);
|
|
18
|
-
}
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
function validateNonExpressionFilter(options) {
|
|
22
|
-
const value = options.value;
|
|
23
|
-
const key = options.key;
|
|
24
|
-
|
|
25
|
-
if (getType(value) !== 'array') {
|
|
26
|
-
return [new ValidationError(key, value, `array expected, ${getType(value)} found`)];
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
const styleSpec = options.styleSpec;
|
|
30
|
-
let type;
|
|
31
|
-
|
|
32
|
-
let errors = [];
|
|
33
|
-
|
|
34
|
-
if (value.length < 1) {
|
|
35
|
-
return [new ValidationError(key, value, 'filter array must have at least 1 element')];
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
errors = errors.concat(validateEnum({
|
|
39
|
-
key: `${key}[0]`,
|
|
40
|
-
value: value[0],
|
|
41
|
-
valueSpec: styleSpec.filter_operator,
|
|
42
|
-
style: options.style,
|
|
43
|
-
styleSpec: options.styleSpec
|
|
44
|
-
}));
|
|
45
|
-
|
|
46
|
-
switch (unbundle(value[0])) {
|
|
47
|
-
case '<':
|
|
48
|
-
case '<=':
|
|
49
|
-
case '>':
|
|
50
|
-
case '>=':
|
|
51
|
-
if (value.length >= 2 && unbundle(value[1]) === '$type') {
|
|
52
|
-
errors.push(new ValidationError(key, value, `"$type" cannot be use with operator "${value[0]}"`));
|
|
53
|
-
}
|
|
54
|
-
/* falls through */
|
|
55
|
-
case '==':
|
|
56
|
-
case '!=':
|
|
57
|
-
if (value.length !== 3) {
|
|
58
|
-
errors.push(new ValidationError(key, value, `filter array for operator "${value[0]}" must have 3 elements`));
|
|
59
|
-
}
|
|
60
|
-
/* falls through */
|
|
61
|
-
case 'in':
|
|
62
|
-
case '!in':
|
|
63
|
-
if (value.length >= 2) {
|
|
64
|
-
type = getType(value[1]);
|
|
65
|
-
if (type !== 'string') {
|
|
66
|
-
errors.push(new ValidationError(`${key}[1]`, value[1], `string expected, ${type} found`));
|
|
67
|
-
}
|
|
68
|
-
}
|
|
69
|
-
for (let i = 2; i < value.length; i++) {
|
|
70
|
-
type = getType(value[i]);
|
|
71
|
-
if (unbundle(value[1]) === '$type') {
|
|
72
|
-
errors = errors.concat(validateEnum({
|
|
73
|
-
key: `${key}[${i}]`,
|
|
74
|
-
value: value[i],
|
|
75
|
-
valueSpec: styleSpec.geometry_type,
|
|
76
|
-
style: options.style,
|
|
77
|
-
styleSpec: options.styleSpec
|
|
78
|
-
}));
|
|
79
|
-
} else if (type !== 'string' && type !== 'number' && type !== 'boolean') {
|
|
80
|
-
errors.push(new ValidationError(`${key}[${i}]`, value[i], `string, number, or boolean expected, ${type} found`));
|
|
81
|
-
}
|
|
82
|
-
}
|
|
83
|
-
break;
|
|
84
|
-
|
|
85
|
-
case 'any':
|
|
86
|
-
case 'all':
|
|
87
|
-
case 'none':
|
|
88
|
-
for (let i = 1; i < value.length; i++) {
|
|
89
|
-
errors = errors.concat(validateNonExpressionFilter({
|
|
90
|
-
key: `${key}[${i}]`,
|
|
91
|
-
value: value[i],
|
|
92
|
-
style: options.style,
|
|
93
|
-
styleSpec: options.styleSpec
|
|
94
|
-
}));
|
|
95
|
-
}
|
|
96
|
-
break;
|
|
97
|
-
|
|
98
|
-
case 'has':
|
|
99
|
-
case '!has':
|
|
100
|
-
type = getType(value[1]);
|
|
101
|
-
if (value.length !== 2) {
|
|
102
|
-
errors.push(new ValidationError(key, value, `filter array for "${value[0]}" operator must have 2 elements`));
|
|
103
|
-
} else if (type !== 'string') {
|
|
104
|
-
errors.push(new ValidationError(`${key}[1]`, value[1], `string expected, ${type} found`));
|
|
105
|
-
}
|
|
106
|
-
break;
|
|
107
|
-
|
|
108
|
-
}
|
|
109
|
-
|
|
110
|
-
return errors;
|
|
111
|
-
}
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
// @flow
|
|
2
|
-
import validateExpression from './validate_expression';
|
|
3
|
-
import validateString from './validate_string';
|
|
4
|
-
|
|
5
|
-
export default function validateFormatted(options: any) {
|
|
6
|
-
if (validateString(options).length === 0) {
|
|
7
|
-
return [];
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
return validateExpression(options);
|
|
11
|
-
}
|
|
@@ -1,207 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
import ValidationError from '../error/validation_error';
|
|
3
|
-
import getType from '../util/get_type';
|
|
4
|
-
import validate from './validate';
|
|
5
|
-
import validateObject from './validate_object';
|
|
6
|
-
import validateArray from './validate_array';
|
|
7
|
-
import validateNumber from './validate_number';
|
|
8
|
-
import {isExpression} from '../expression';
|
|
9
|
-
import {unbundle, deepUnbundle} from '../util/unbundle_jsonlint';
|
|
10
|
-
import {
|
|
11
|
-
supportsPropertyExpression,
|
|
12
|
-
supportsZoomExpression,
|
|
13
|
-
supportsInterpolation
|
|
14
|
-
} from '../util/properties';
|
|
15
|
-
|
|
16
|
-
export default function validateFunction(options) {
|
|
17
|
-
const functionValueSpec = options.valueSpec;
|
|
18
|
-
const functionType = unbundle(options.value.type);
|
|
19
|
-
let stopKeyType;
|
|
20
|
-
let stopDomainValues = {};
|
|
21
|
-
let previousStopDomainValue;
|
|
22
|
-
let previousStopDomainZoom;
|
|
23
|
-
|
|
24
|
-
const isZoomFunction = functionType !== 'categorical' && options.value.property === undefined;
|
|
25
|
-
const isPropertyFunction = !isZoomFunction;
|
|
26
|
-
const isZoomAndPropertyFunction =
|
|
27
|
-
getType(options.value.stops) === 'array' &&
|
|
28
|
-
getType(options.value.stops[0]) === 'array' &&
|
|
29
|
-
getType(options.value.stops[0][0]) === 'object';
|
|
30
|
-
|
|
31
|
-
const errors = validateObject({
|
|
32
|
-
key: options.key,
|
|
33
|
-
value: options.value,
|
|
34
|
-
valueSpec: options.styleSpec.function,
|
|
35
|
-
style: options.style,
|
|
36
|
-
styleSpec: options.styleSpec,
|
|
37
|
-
objectElementValidators: {
|
|
38
|
-
stops: validateFunctionStops,
|
|
39
|
-
default: validateFunctionDefault
|
|
40
|
-
}
|
|
41
|
-
});
|
|
42
|
-
|
|
43
|
-
if (functionType === 'identity' && isZoomFunction) {
|
|
44
|
-
errors.push(new ValidationError(options.key, options.value, 'missing required property "property"'));
|
|
45
|
-
}
|
|
46
|
-
|
|
47
|
-
if (functionType !== 'identity' && !options.value.stops) {
|
|
48
|
-
errors.push(new ValidationError(options.key, options.value, 'missing required property "stops"'));
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
if (functionType === 'exponential' && options.valueSpec.expression && !supportsInterpolation(options.valueSpec)) {
|
|
52
|
-
errors.push(new ValidationError(options.key, options.value, 'exponential functions not supported'));
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
if (options.styleSpec.$version >= 8) {
|
|
56
|
-
if (isPropertyFunction && !supportsPropertyExpression(options.valueSpec)) {
|
|
57
|
-
errors.push(new ValidationError(options.key, options.value, 'property functions not supported'));
|
|
58
|
-
} else if (isZoomFunction && !supportsZoomExpression(options.valueSpec)) {
|
|
59
|
-
errors.push(new ValidationError(options.key, options.value, 'zoom functions not supported'));
|
|
60
|
-
}
|
|
61
|
-
}
|
|
62
|
-
|
|
63
|
-
if ((functionType === 'categorical' || isZoomAndPropertyFunction) && options.value.property === undefined) {
|
|
64
|
-
errors.push(new ValidationError(options.key, options.value, '"property" property is required'));
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
return errors;
|
|
68
|
-
|
|
69
|
-
function validateFunctionStops(options) {
|
|
70
|
-
if (functionType === 'identity') {
|
|
71
|
-
return [new ValidationError(options.key, options.value, 'identity function may not have a "stops" property')];
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
let errors = [];
|
|
75
|
-
const value = options.value;
|
|
76
|
-
|
|
77
|
-
errors = errors.concat(validateArray({
|
|
78
|
-
key: options.key,
|
|
79
|
-
value,
|
|
80
|
-
valueSpec: options.valueSpec,
|
|
81
|
-
style: options.style,
|
|
82
|
-
styleSpec: options.styleSpec,
|
|
83
|
-
arrayElementValidator: validateFunctionStop
|
|
84
|
-
}));
|
|
85
|
-
|
|
86
|
-
if (getType(value) === 'array' && value.length === 0) {
|
|
87
|
-
errors.push(new ValidationError(options.key, value, 'array must have at least one stop'));
|
|
88
|
-
}
|
|
89
|
-
|
|
90
|
-
return errors;
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
function validateFunctionStop(options) {
|
|
94
|
-
let errors = [];
|
|
95
|
-
const value = options.value;
|
|
96
|
-
const key = options.key;
|
|
97
|
-
|
|
98
|
-
if (getType(value) !== 'array') {
|
|
99
|
-
return [new ValidationError(key, value, `array expected, ${getType(value)} found`)];
|
|
100
|
-
}
|
|
101
|
-
|
|
102
|
-
if (value.length !== 2) {
|
|
103
|
-
return [new ValidationError(key, value, `array length 2 expected, length ${value.length} found`)];
|
|
104
|
-
}
|
|
105
|
-
|
|
106
|
-
if (isZoomAndPropertyFunction) {
|
|
107
|
-
if (getType(value[0]) !== 'object') {
|
|
108
|
-
return [new ValidationError(key, value, `object expected, ${getType(value[0])} found`)];
|
|
109
|
-
}
|
|
110
|
-
if (value[0].zoom === undefined) {
|
|
111
|
-
return [new ValidationError(key, value, 'object stop key must have zoom')];
|
|
112
|
-
}
|
|
113
|
-
if (value[0].value === undefined) {
|
|
114
|
-
return [new ValidationError(key, value, 'object stop key must have value')];
|
|
115
|
-
}
|
|
116
|
-
if (previousStopDomainZoom && previousStopDomainZoom > unbundle(value[0].zoom)) {
|
|
117
|
-
return [new ValidationError(key, value[0].zoom, 'stop zoom values must appear in ascending order')];
|
|
118
|
-
}
|
|
119
|
-
if (unbundle(value[0].zoom) !== previousStopDomainZoom) {
|
|
120
|
-
previousStopDomainZoom = unbundle(value[0].zoom);
|
|
121
|
-
previousStopDomainValue = undefined;
|
|
122
|
-
stopDomainValues = {};
|
|
123
|
-
}
|
|
124
|
-
errors = errors.concat(validateObject({
|
|
125
|
-
key: `${key}[0]`,
|
|
126
|
-
value: value[0],
|
|
127
|
-
valueSpec: {zoom: {}},
|
|
128
|
-
style: options.style,
|
|
129
|
-
styleSpec: options.styleSpec,
|
|
130
|
-
objectElementValidators: {zoom: validateNumber, value: validateStopDomainValue}
|
|
131
|
-
}));
|
|
132
|
-
} else {
|
|
133
|
-
errors = errors.concat(validateStopDomainValue({
|
|
134
|
-
key: `${key}[0]`,
|
|
135
|
-
value: value[0],
|
|
136
|
-
valueSpec: {},
|
|
137
|
-
style: options.style,
|
|
138
|
-
styleSpec: options.styleSpec
|
|
139
|
-
}, value));
|
|
140
|
-
}
|
|
141
|
-
|
|
142
|
-
if (isExpression(deepUnbundle(value[1]))) {
|
|
143
|
-
return errors.concat([new ValidationError(`${key}[1]`, value[1], 'expressions are not allowed in function stops.')]);
|
|
144
|
-
}
|
|
145
|
-
|
|
146
|
-
return errors.concat(validate({
|
|
147
|
-
key: `${key}[1]`,
|
|
148
|
-
value: value[1],
|
|
149
|
-
valueSpec: functionValueSpec,
|
|
150
|
-
style: options.style,
|
|
151
|
-
styleSpec: options.styleSpec
|
|
152
|
-
}));
|
|
153
|
-
}
|
|
154
|
-
|
|
155
|
-
function validateStopDomainValue(options, stop) {
|
|
156
|
-
const type = getType(options.value);
|
|
157
|
-
const value = unbundle(options.value);
|
|
158
|
-
|
|
159
|
-
const reportValue = options.value !== null ? options.value : stop;
|
|
160
|
-
|
|
161
|
-
if (!stopKeyType) {
|
|
162
|
-
stopKeyType = type;
|
|
163
|
-
} else if (type !== stopKeyType) {
|
|
164
|
-
return [new ValidationError(options.key, reportValue, `${type} stop domain type must match previous stop domain type ${stopKeyType}`)];
|
|
165
|
-
}
|
|
166
|
-
|
|
167
|
-
if (type !== 'number' && type !== 'string' && type !== 'boolean') {
|
|
168
|
-
return [new ValidationError(options.key, reportValue, 'stop domain value must be a number, string, or boolean')];
|
|
169
|
-
}
|
|
170
|
-
|
|
171
|
-
if (type !== 'number' && functionType !== 'categorical') {
|
|
172
|
-
let message = `number expected, ${type} found`;
|
|
173
|
-
if (supportsPropertyExpression(functionValueSpec) && functionType === undefined) {
|
|
174
|
-
message += '\nIf you intended to use a categorical function, specify `"type": "categorical"`.';
|
|
175
|
-
}
|
|
176
|
-
return [new ValidationError(options.key, reportValue, message)];
|
|
177
|
-
}
|
|
178
|
-
|
|
179
|
-
if (functionType === 'categorical' && type === 'number' && (!isFinite(value) || Math.floor(value) !== value)) {
|
|
180
|
-
return [new ValidationError(options.key, reportValue, `integer expected, found ${value}`)];
|
|
181
|
-
}
|
|
182
|
-
|
|
183
|
-
if (functionType !== 'categorical' && type === 'number' && previousStopDomainValue !== undefined && value < previousStopDomainValue) {
|
|
184
|
-
return [new ValidationError(options.key, reportValue, 'stop domain values must appear in ascending order')];
|
|
185
|
-
} else {
|
|
186
|
-
previousStopDomainValue = value;
|
|
187
|
-
}
|
|
188
|
-
|
|
189
|
-
if (functionType === 'categorical' && value in stopDomainValues) {
|
|
190
|
-
return [new ValidationError(options.key, reportValue, 'stop domain values must be unique')];
|
|
191
|
-
} else {
|
|
192
|
-
stopDomainValues[value] = true;
|
|
193
|
-
}
|
|
194
|
-
|
|
195
|
-
return [];
|
|
196
|
-
}
|
|
197
|
-
|
|
198
|
-
function validateFunctionDefault(options) {
|
|
199
|
-
return validate({
|
|
200
|
-
key: options.key,
|
|
201
|
-
value: options.value,
|
|
202
|
-
valueSpec: functionValueSpec,
|
|
203
|
-
style: options.style,
|
|
204
|
-
styleSpec: options.styleSpec
|
|
205
|
-
});
|
|
206
|
-
}
|
|
207
|
-
}
|
|
@@ -1,21 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
import ValidationError from '../error/validation_error';
|
|
3
|
-
import validateString from './validate_string';
|
|
4
|
-
|
|
5
|
-
export default function(options) {
|
|
6
|
-
const value = options.value;
|
|
7
|
-
const key = options.key;
|
|
8
|
-
|
|
9
|
-
const errors = validateString(options);
|
|
10
|
-
if (errors.length) return errors;
|
|
11
|
-
|
|
12
|
-
if (value.indexOf('{fontstack}') === -1) {
|
|
13
|
-
errors.push(new ValidationError(key, value, '"glyphs" url must include a "{fontstack}" token'));
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
if (value.indexOf('{range}') === -1) {
|
|
17
|
-
errors.push(new ValidationError(key, value, '"glyphs" url must include a "{range}" token'));
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
return errors;
|
|
21
|
-
}
|
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
// @flow
|
|
2
|
-
import validateExpression from './validate_expression';
|
|
3
|
-
import validateString from './validate_string';
|
|
4
|
-
|
|
5
|
-
export default function validateImage(options: any) {
|
|
6
|
-
if (validateString(options).length === 0) {
|
|
7
|
-
return [];
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
return validateExpression(options);
|
|
11
|
-
}
|
|
@@ -1,134 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
import ValidationError from '../error/validation_error';
|
|
3
|
-
import {unbundle} from '../util/unbundle_jsonlint';
|
|
4
|
-
import validateObject from './validate_object';
|
|
5
|
-
import validateFilter from './validate_filter';
|
|
6
|
-
import validatePaintProperty from './validate_paint_property';
|
|
7
|
-
import validateLayoutProperty from './validate_layout_property';
|
|
8
|
-
import validateSpec from './validate';
|
|
9
|
-
import extend from '../util/extend';
|
|
10
|
-
|
|
11
|
-
export default function validateLayer(options) {
|
|
12
|
-
let errors = [];
|
|
13
|
-
|
|
14
|
-
const layer = options.value;
|
|
15
|
-
const key = options.key;
|
|
16
|
-
const style = options.style;
|
|
17
|
-
const styleSpec = options.styleSpec;
|
|
18
|
-
|
|
19
|
-
if (!layer.type && !layer.ref) {
|
|
20
|
-
errors.push(new ValidationError(key, layer, 'either "type" or "ref" is required'));
|
|
21
|
-
}
|
|
22
|
-
let type = unbundle(layer.type);
|
|
23
|
-
const ref = unbundle(layer.ref);
|
|
24
|
-
|
|
25
|
-
if (layer.id) {
|
|
26
|
-
const layerId = unbundle(layer.id);
|
|
27
|
-
for (let i = 0; i < options.arrayIndex; i++) {
|
|
28
|
-
const otherLayer = style.layers[i];
|
|
29
|
-
if (unbundle(otherLayer.id) === layerId) {
|
|
30
|
-
errors.push(new ValidationError(key, layer.id, `duplicate layer id "${layer.id}", previously used at line ${otherLayer.id.__line__}`));
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
|
|
35
|
-
if ('ref' in layer) {
|
|
36
|
-
['type', 'source', 'source-layer', 'filter', 'layout'].forEach((p) => {
|
|
37
|
-
if (p in layer) {
|
|
38
|
-
errors.push(new ValidationError(key, layer[p], `"${p}" is prohibited for ref layers`));
|
|
39
|
-
}
|
|
40
|
-
});
|
|
41
|
-
|
|
42
|
-
let parent;
|
|
43
|
-
|
|
44
|
-
style.layers.forEach((layer) => {
|
|
45
|
-
if (unbundle(layer.id) === ref) parent = layer;
|
|
46
|
-
});
|
|
47
|
-
|
|
48
|
-
if (!parent) {
|
|
49
|
-
errors.push(new ValidationError(key, layer.ref, `ref layer "${ref}" not found`));
|
|
50
|
-
} else if (parent.ref) {
|
|
51
|
-
errors.push(new ValidationError(key, layer.ref, 'ref cannot reference another ref layer'));
|
|
52
|
-
} else {
|
|
53
|
-
type = unbundle(parent.type);
|
|
54
|
-
}
|
|
55
|
-
} else if (type !== 'background') {
|
|
56
|
-
if (!layer.source) {
|
|
57
|
-
errors.push(new ValidationError(key, layer, 'missing required property "source"'));
|
|
58
|
-
} else {
|
|
59
|
-
const source = style.sources && style.sources[layer.source];
|
|
60
|
-
const sourceType = source && unbundle(source.type);
|
|
61
|
-
if (!source) {
|
|
62
|
-
errors.push(new ValidationError(key, layer.source, `source "${layer.source}" not found`));
|
|
63
|
-
} else if (sourceType === 'vector' && type === 'raster') {
|
|
64
|
-
errors.push(new ValidationError(key, layer.source, `layer "${layer.id}" requires a raster source`));
|
|
65
|
-
} else if (sourceType === 'raster' && type !== 'raster') {
|
|
66
|
-
errors.push(new ValidationError(key, layer.source, `layer "${layer.id}" requires a vector source`));
|
|
67
|
-
} else if (sourceType === 'vector' && !layer['source-layer']) {
|
|
68
|
-
errors.push(new ValidationError(key, layer, `layer "${layer.id}" must specify a "source-layer"`));
|
|
69
|
-
} else if (sourceType === 'raster-dem' && type !== 'hillshade') {
|
|
70
|
-
errors.push(new ValidationError(key, layer.source, 'raster-dem source can only be used with layer type \'hillshade\'.'));
|
|
71
|
-
} else if (type === 'line' && layer.paint && layer.paint['line-gradient'] &&
|
|
72
|
-
(sourceType !== 'geojson' || !source.lineMetrics)) {
|
|
73
|
-
errors.push(new ValidationError(key, layer, `layer "${layer.id}" specifies a line-gradient, which requires a GeoJSON source with \`lineMetrics\` enabled.`));
|
|
74
|
-
}
|
|
75
|
-
}
|
|
76
|
-
}
|
|
77
|
-
|
|
78
|
-
errors = errors.concat(validateObject({
|
|
79
|
-
key,
|
|
80
|
-
value: layer,
|
|
81
|
-
valueSpec: styleSpec.layer,
|
|
82
|
-
style: options.style,
|
|
83
|
-
styleSpec: options.styleSpec,
|
|
84
|
-
objectElementValidators: {
|
|
85
|
-
'*'() {
|
|
86
|
-
return [];
|
|
87
|
-
},
|
|
88
|
-
// We don't want to enforce the spec's `"requires": true` for backward compatibility with refs;
|
|
89
|
-
// the actual requirement is validated above. See https://github.com/mapbox/mapbox-gl-js/issues/5772.
|
|
90
|
-
type() {
|
|
91
|
-
return validateSpec({
|
|
92
|
-
key: `${key}.type`,
|
|
93
|
-
value: layer.type,
|
|
94
|
-
valueSpec: styleSpec.layer.type,
|
|
95
|
-
style: options.style,
|
|
96
|
-
styleSpec: options.styleSpec,
|
|
97
|
-
object: layer,
|
|
98
|
-
objectKey: 'type'
|
|
99
|
-
});
|
|
100
|
-
},
|
|
101
|
-
filter: validateFilter,
|
|
102
|
-
layout(options) {
|
|
103
|
-
return validateObject({
|
|
104
|
-
layer,
|
|
105
|
-
key: options.key,
|
|
106
|
-
value: options.value,
|
|
107
|
-
style: options.style,
|
|
108
|
-
styleSpec: options.styleSpec,
|
|
109
|
-
objectElementValidators: {
|
|
110
|
-
'*'(options) {
|
|
111
|
-
return validateLayoutProperty(extend({layerType: type}, options));
|
|
112
|
-
}
|
|
113
|
-
}
|
|
114
|
-
});
|
|
115
|
-
},
|
|
116
|
-
paint(options) {
|
|
117
|
-
return validateObject({
|
|
118
|
-
layer,
|
|
119
|
-
key: options.key,
|
|
120
|
-
value: options.value,
|
|
121
|
-
style: options.style,
|
|
122
|
-
styleSpec: options.styleSpec,
|
|
123
|
-
objectElementValidators: {
|
|
124
|
-
'*'(options) {
|
|
125
|
-
return validatePaintProperty(extend({layerType: type}, options));
|
|
126
|
-
}
|
|
127
|
-
}
|
|
128
|
-
});
|
|
129
|
-
}
|
|
130
|
-
}
|
|
131
|
-
}));
|
|
132
|
-
|
|
133
|
-
return errors;
|
|
134
|
-
}
|
|
@@ -1,47 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
import ValidationError from '../error/validation_error';
|
|
3
|
-
import getType from '../util/get_type';
|
|
4
|
-
import validate from './validate';
|
|
5
|
-
|
|
6
|
-
export default function validateLight(options) {
|
|
7
|
-
const light = options.value;
|
|
8
|
-
const styleSpec = options.styleSpec;
|
|
9
|
-
const lightSpec = styleSpec.light;
|
|
10
|
-
const style = options.style;
|
|
11
|
-
|
|
12
|
-
let errors = [];
|
|
13
|
-
|
|
14
|
-
const rootType = getType(light);
|
|
15
|
-
if (light === undefined) {
|
|
16
|
-
return errors;
|
|
17
|
-
} else if (rootType !== 'object') {
|
|
18
|
-
errors = errors.concat([new ValidationError('light', light, `object expected, ${rootType} found`)]);
|
|
19
|
-
return errors;
|
|
20
|
-
}
|
|
21
|
-
|
|
22
|
-
for (const key in light) {
|
|
23
|
-
const transitionMatch = key.match(/^(.*)-transition$/);
|
|
24
|
-
|
|
25
|
-
if (transitionMatch && lightSpec[transitionMatch[1]] && lightSpec[transitionMatch[1]].transition) {
|
|
26
|
-
errors = errors.concat(validate({
|
|
27
|
-
key,
|
|
28
|
-
value: light[key],
|
|
29
|
-
valueSpec: styleSpec.transition,
|
|
30
|
-
style,
|
|
31
|
-
styleSpec
|
|
32
|
-
}));
|
|
33
|
-
} else if (lightSpec[key]) {
|
|
34
|
-
errors = errors.concat(validate({
|
|
35
|
-
key,
|
|
36
|
-
value: light[key],
|
|
37
|
-
valueSpec: lightSpec[key],
|
|
38
|
-
style,
|
|
39
|
-
styleSpec
|
|
40
|
-
}));
|
|
41
|
-
} else {
|
|
42
|
-
errors = errors.concat([new ValidationError(key, light[key], `unknown property "${key}"`)]);
|
|
43
|
-
}
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
return errors;
|
|
47
|
-
}
|
|
@@ -1,29 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
import getType from '../util/get_type';
|
|
3
|
-
import ValidationError from '../error/validation_error';
|
|
4
|
-
|
|
5
|
-
export default function validateNumber(options) {
|
|
6
|
-
const key = options.key;
|
|
7
|
-
const value = options.value;
|
|
8
|
-
const valueSpec = options.valueSpec;
|
|
9
|
-
let type = getType(value);
|
|
10
|
-
|
|
11
|
-
// eslint-disable-next-line no-self-compare
|
|
12
|
-
if (type === 'number' && value !== value) {
|
|
13
|
-
type = 'NaN';
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
if (type !== 'number') {
|
|
17
|
-
return [new ValidationError(key, value, `number expected, ${type} found`)];
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
if ('minimum' in valueSpec && value < valueSpec.minimum) {
|
|
21
|
-
return [new ValidationError(key, value, `${value} is less than the minimum value ${valueSpec.minimum}`)];
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
if ('maximum' in valueSpec && value > valueSpec.maximum) {
|
|
25
|
-
return [new ValidationError(key, value, `${value} is greater than the maximum value ${valueSpec.maximum}`)];
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
return [];
|
|
29
|
-
}
|
|
@@ -1,61 +0,0 @@
|
|
|
1
|
-
|
|
2
|
-
import ValidationError from '../error/validation_error';
|
|
3
|
-
import getType from '../util/get_type';
|
|
4
|
-
import validateSpec from './validate';
|
|
5
|
-
|
|
6
|
-
export default function validateObject(options) {
|
|
7
|
-
const key = options.key;
|
|
8
|
-
const object = options.value;
|
|
9
|
-
const elementSpecs = options.valueSpec || {};
|
|
10
|
-
const elementValidators = options.objectElementValidators || {};
|
|
11
|
-
const style = options.style;
|
|
12
|
-
const styleSpec = options.styleSpec;
|
|
13
|
-
let errors = [];
|
|
14
|
-
|
|
15
|
-
const type = getType(object);
|
|
16
|
-
if (type !== 'object') {
|
|
17
|
-
return [new ValidationError(key, object, `object expected, ${type} found`)];
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
for (const objectKey in object) {
|
|
21
|
-
const elementSpecKey = objectKey.split('.')[0]; // treat 'paint.*' as 'paint'
|
|
22
|
-
const elementSpec = elementSpecs[elementSpecKey] || elementSpecs['*'];
|
|
23
|
-
|
|
24
|
-
let validateElement;
|
|
25
|
-
if (elementValidators[elementSpecKey]) {
|
|
26
|
-
validateElement = elementValidators[elementSpecKey];
|
|
27
|
-
} else if (elementSpecs[elementSpecKey]) {
|
|
28
|
-
validateElement = validateSpec;
|
|
29
|
-
} else if (elementValidators['*']) {
|
|
30
|
-
validateElement = elementValidators['*'];
|
|
31
|
-
} else if (elementSpecs['*']) {
|
|
32
|
-
validateElement = validateSpec;
|
|
33
|
-
} else {
|
|
34
|
-
errors.push(new ValidationError(key, object[objectKey], `unknown property "${objectKey}"`));
|
|
35
|
-
continue;
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
errors = errors.concat(validateElement({
|
|
39
|
-
key: (key ? `${key}.` : key) + objectKey,
|
|
40
|
-
value: object[objectKey],
|
|
41
|
-
valueSpec: elementSpec,
|
|
42
|
-
style,
|
|
43
|
-
styleSpec,
|
|
44
|
-
object,
|
|
45
|
-
objectKey
|
|
46
|
-
}, object));
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
for (const elementSpecKey in elementSpecs) {
|
|
50
|
-
// Don't check `required` when there's a custom validator for that property.
|
|
51
|
-
if (elementValidators[elementSpecKey]) {
|
|
52
|
-
continue;
|
|
53
|
-
}
|
|
54
|
-
|
|
55
|
-
if (elementSpecs[elementSpecKey].required && elementSpecs[elementSpecKey]['default'] === undefined && object[elementSpecKey] === undefined) {
|
|
56
|
-
errors.push(new ValidationError(key, object, `missing required property "${elementSpecKey}"`));
|
|
57
|
-
}
|
|
58
|
-
}
|
|
59
|
-
|
|
60
|
-
return errors;
|
|
61
|
-
}
|