forked from MapComplete/MapComplete
		
	
		
			
				
	
	
		
			213 lines
		
	
	
	
		
			6.2 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			213 lines
		
	
	
	
		
			6.2 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import { Feature, FeatureCollection } from "geojson"
 | |
| 
 | |
| export interface Eli extends FeatureCollection {
 | |
|     features: EliEntry[]
 | |
| }
 | |
| 
 | |
| export interface EliEntry extends Feature {
 | |
|     properties: {
 | |
|         /**
 | |
|          * The name of the imagery source
 | |
|          */
 | |
|         name: string
 | |
| 
 | |
|         /**
 | |
|          * Whether the imagery name should be translated
 | |
|          */
 | |
|         i18n?: boolean
 | |
| 
 | |
|         /**
 | |
|          * Type of layer
 | |
|          */
 | |
|         type: "tms" | "wms" | "bing" | "scanex" | "wms_endpoint" | "wmts"
 | |
| 
 | |
|         /**
 | |
|          * A rough categorisation of different types of layers.
 | |
|          * @see https://github.com/osmlab/editor-layer-index/blob/gh-pages/CONTRIBUTING.md#categories
 | |
|          */
 | |
|         category?:
 | |
|             | "photo"
 | |
|             | "map"
 | |
|             | "historicmap"
 | |
|             | "osmbasedmap"
 | |
|             | "historicphoto"
 | |
|             | "qa"
 | |
|             | "elevation"
 | |
|             | "other"
 | |
| 
 | |
|         /**
 | |
|          * A URL template for imagery tiles
 | |
|          */
 | |
|         url: string
 | |
| 
 | |
|         /**
 | |
|          * The minimum zoom level
 | |
|          */
 | |
|         min_zoom?: number
 | |
| 
 | |
|         /**
 | |
|          * The maximum zoom level
 | |
|          */
 | |
|         max_zoom?: number
 | |
| 
 | |
|         /**
 | |
|          * explicit/implicit permission by the owner for use in OSM
 | |
|          */
 | |
|         permission_osm?: "explicit" | "implicit" | "no"
 | |
| 
 | |
|         /**
 | |
|          * A URL for the license or permissions for the imagery
 | |
|          */
 | |
|         license_url?: string
 | |
| 
 | |
|         /**
 | |
|          * A URL for the privacy policy of the operator or false if there is no existing privacy policy for tis imagery.
 | |
|          */
 | |
|         privacy_policy_url?: string | boolean
 | |
| 
 | |
|         /**
 | |
|          * A unique identifier for the source; used in imagery_used changeset tag
 | |
|          */
 | |
|         id: string
 | |
| 
 | |
|         /**
 | |
|          * A short English-language description of the source
 | |
|          */
 | |
|         description?: string
 | |
| 
 | |
|         /**
 | |
|          * The ISO 3166-1 alpha-2 two letter country code in upper case. Use ZZ for unknown or multiple.
 | |
|          */
 | |
|         country_code?: string
 | |
| 
 | |
|         /**
 | |
|          * Whether this imagery should be shown in the default world-wide menu
 | |
|          */
 | |
|         default?: boolean
 | |
| 
 | |
|         /**
 | |
|          * Whether this imagery is the best source for the region
 | |
|          */
 | |
|         best?: boolean
 | |
| 
 | |
|         /**
 | |
|          * The age of the oldest imagery or data in the source, as an RFC3339 date or leading portion of one
 | |
|          */
 | |
|         start_date?: string
 | |
| 
 | |
|         /**
 | |
|          * The age of the newest imagery or data in the source, as an RFC3339 date or leading portion of one
 | |
|          */
 | |
|         end_date?: string
 | |
| 
 | |
|         /**
 | |
|          * HTTP header to check for information if the tile is invalid
 | |
|          */
 | |
|         no_tile_header?: { [header: string]: string[] } | null
 | |
| 
 | |
|         /**
 | |
|          * 'true' if tiles are transparent and can be overlaid on another source
 | |
|          */
 | |
|         overlay?: boolean
 | |
| 
 | |
|         /**
 | |
|          * Available projections
 | |
|          */
 | |
|         available_projections?: string[]
 | |
| 
 | |
|         /**
 | |
|          * Attribution
 | |
|          */
 | |
|         attribution?: {
 | |
|             /**
 | |
|              * URL
 | |
|              */
 | |
|             url?: string
 | |
| 
 | |
|             /**
 | |
|              * Text
 | |
|              */
 | |
|             text?: string
 | |
| 
 | |
|             /**
 | |
|              * HTML formatted attribution
 | |
|              */
 | |
|             html?: string
 | |
| 
 | |
|             /**
 | |
|              * Whether attribution is required
 | |
|              */
 | |
|             required?: boolean
 | |
|         }
 | |
| 
 | |
|         /**
 | |
|          * A URL for an image, that can be displayed in the list of imagery layers next to the name
 | |
|          */
 | |
|         icon?: string
 | |
| 
 | |
|         /**
 | |
|          * A link to an EULA text that has to be accepted by the user, before the imagery source is added. Can contain {lang} to be replaced by a current user language wiki code (like FR:) or an empty string for the default English text.
 | |
|          */
 | |
|         eula?: string
 | |
| 
 | |
|         /**
 | |
|          * A URL for an image, that is displayed in the mapview for attribution
 | |
|          */
 | |
|         "logo-image"?: string
 | |
| 
 | |
|         /**
 | |
|          * Customized text for the terms of use link (default is "Background Terms of Use")
 | |
|          */
 | |
|         "terms-of-use-text"?: string
 | |
| 
 | |
|         /**
 | |
|          * Specify a checksum for tiles, which aren't real tiles. `type` is the digest type and can be MD5, SHA-1, SHA-256, SHA-384 and SHA-512, value is the hex encoded checksum in lower case. To create a checksum save the tile as file and upload it to e.g. https://defuse.ca/checksums.htm.
 | |
|          */
 | |
|         "no-tile-checksum"?: string
 | |
| 
 | |
|         /**
 | |
|          * header-name attribute specifies a header returned by tile server, that will be shown as `metadata-key` attribute in Show Tile Info dialog
 | |
|          */
 | |
|         "metadata-header"?: string
 | |
| 
 | |
|         /**
 | |
|          * Set to `true` if imagery source is properly aligned and does not need imagery offset adjustments. This is used for OSM based sources too.
 | |
|          */
 | |
|         "valid-georeference"?: boolean
 | |
| 
 | |
|         /**
 | |
|          * Size of individual tiles delivered by a TMS service
 | |
|          */
 | |
|         "tile-size"?: number
 | |
| 
 | |
|         /**
 | |
|          * Whether tiles status can be accessed by appending /status to the tile URL and can be submitted for re-rendering by appending /dirty.
 | |
|          */
 | |
|         "mod-tile-features"?: string
 | |
| 
 | |
|         /**
 | |
|          * HTTP headers to be sent to server. It has two attributes header-name and header-value. May be specified multiple times.
 | |
|          */
 | |
|         "custom-http-headers"?: { "header-name": string; "header-value": string }[]
 | |
| 
 | |
|         /**
 | |
|          * Default layer to open (when using WMS_ENDPOINT type). Contains list of layer tag with two attributes - name and style, e.g. `\"default-layers\": [\"layer\": { name=\"Basisdata_NP_Basiskart_JanMayen_WMTS_25829\" \"style\":\"default\" } ]` (not allowed in `mirror` attribute)
 | |
|          */
 | |
|         "default-layers"?: { layer: { "layer-name": string; "layer-style": string } }[]
 | |
| 
 | |
|         /**
 | |
|          * format to use when connecting tile server (when using WMS_ENDPOINT type)
 | |
|          */
 | |
|         format?: string
 | |
| 
 | |
|         /**
 | |
|          * If `true` transparent tiles will be requested from WMS server
 | |
|          */
 | |
|         transparent?: boolean
 | |
| 
 | |
|         /**
 | |
|          * minimum expiry time for tiles in seconds. The larger the value, the longer entry in cache will be considered valid
 | |
|          */
 | |
|         "minimum-tile-expire"?: number
 | |
|     }
 | |
| }
 |