MapComplete/src/Models/Constants.ts

222 lines
7.7 KiB
TypeScript
Raw Normal View History

import * as packagefile from "../../package.json"
import * as extraconfig from "../../config.json"
import { Utils } from "../Utils"
2023-09-27 22:21:35 +02:00
import { AuthConfig } from "../Logic/Osm/AuthConfig"
2023-05-08 01:58:33 +02:00
2023-06-14 20:44:01 +02:00
export type PriviligedLayerType = (typeof Constants.priviliged_layers)[number]
2024-08-21 14:06:42 +02:00
export type DefaultPinIcon = (typeof Constants._defaultPinIcons)[number]
export default class Constants {
2023-10-16 14:27:05 +02:00
public static vNumber: string = packagefile.version
2022-07-13 16:12:25 +02:00
/**
* API key for Maproulette
2022-09-08 21:40:48 +02:00
*
2024-06-27 02:29:53 +02:00
* There is no user-friendly way to get the user's API key currently.
2022-07-13 16:12:25 +02:00
* See https://github.com/maproulette/maproulette2/issues/476 for more information.
* Using an empty string however does work for most actions, but will attribute all actions to the Superuser.
*/
2022-09-08 21:40:48 +02:00
public static readonly MaprouletteApiKey = ""
2023-03-25 02:48:24 +01:00
public static readonly added_by_default = [
"selected_element",
2022-09-08 21:40:48 +02:00
"gps_location",
"gps_location_history",
"home_location",
"gps_track",
2023-03-25 02:48:24 +01:00
"range",
"last_click",
2023-11-22 19:39:19 +01:00
"favourite",
2024-02-15 17:39:59 +01:00
"summary",
2024-08-23 02:16:24 +02:00
"search"
2023-03-25 02:48:24 +01:00
] as const
/**
* Special layers which are not included in a theme by default
*/
public static readonly no_include = [
2022-09-08 21:40:48 +02:00
"conflation",
"split_point",
"split_road",
2022-09-08 21:40:48 +02:00
"current_view",
"import_candidate",
"usersettings",
2024-01-16 04:09:58 +01:00
"icons",
2024-08-23 02:16:24 +02:00
"filters"
2023-03-25 02:48:24 +01:00
] as const
2021-12-21 18:35:31 +01:00
/**
* Layer IDs of layers which have special properties through built-in hooks
*/
2023-03-25 02:48:24 +01:00
public static readonly priviliged_layers = [
2022-09-08 21:40:48 +02:00
...Constants.added_by_default,
...Constants.no_include,
2023-03-25 02:48:24 +01:00
] as const
// The user journey states thresholds when a new feature gets unlocked
public static userJourney = {
2021-03-16 19:35:19 +01:00
moreScreenUnlock: 1,
2021-06-28 18:06:54 +02:00
personalLayoutUnlock: 5,
historyLinkVisible: 10,
deletePointsOfOthersUnlock: 20,
2021-03-17 14:35:06 +01:00
tagsVisibleAt: 25,
2021-03-16 19:35:19 +01:00
tagsVisibleAndWikiLinked: 30,
2021-06-28 18:06:54 +02:00
mapCompleteHelpUnlock: 50,
themeGeneratorReadOnlyUnlock: 50,
themeGeneratorFullUnlock: 500,
addNewPointWithUnreadMessagesUnlock: 500,
2022-09-08 21:40:48 +02:00
importHelperUnlock: 5000,
}
static readonly minZoomLevelToAddNewPoint = Constants.isRetina() ? 17 : 18
/**
* Used by 'PendingChangesUploader', which waits this amount of seconds to upload changes.
* (Note that pendingChanges might upload sooner if the popup is closed or similar)
*/
2023-10-16 13:38:11 +02:00
static updateTimeoutSec: number = 15
/**
* If the contributor has their GPS location enabled and makes a change,
* the points visited less then `nearbyVisitTime`-seconds ago will be inspected.
* The point closest to the changed feature will be considered and this distance will be tracked.
* ALl these distances are used to calculate a nearby-score
*/
2022-09-08 21:40:48 +02:00
static nearbyVisitTime: number = 30 * 60
/**
* If a user makes a change, the distance to the changed object is calculated.
* If a user makes multiple changes, all these distances are put into multiple bins, depending on this distance.
* For every bin, the totals are uploaded as metadata
*/
2022-01-26 21:40:38 +01:00
static distanceToChangeObjectBins = [25, 50, 100, 500, 1000, 5000, Number.MAX_VALUE]
2022-09-08 21:40:48 +02:00
static themeOrder = [
"personal",
"cyclofix",
"waste",
"etymology",
"food",
"cafes_and_pubs",
"shops",
2022-09-08 21:40:48 +02:00
"playgrounds",
"hailhydrant",
"toilets",
"aed",
"bookcases",
]
/**
* Upon initialization, the GPS will search the location.
* If the location is found within the given timout, it'll automatically fly to it.
2022-09-08 21:40:48 +02:00
*
* In seconds
*/
2023-02-09 03:12:21 +01:00
static zoomToLocationTimeout = 15
public static readonly viewportCenterCloseToGpsCutoff: number = 20
private static readonly config = (() => {
const defaultConfig = packagefile.config
return { ...defaultConfig, ...extraconfig }
})()
public static ImgurApiKey = Constants.config.api_keys.imgur
public static readonly mapillary_client_token_v4 = Constants.config.api_keys.mapillary_v4
public static defaultOverpassUrls = Constants.config.default_overpass_urls
2023-09-27 22:21:35 +02:00
public static countryCoderEndpoint: string = Constants.config.country_coder_host
public static osmAuthConfig: AuthConfig = Constants.config.oauth_credentials
public static nominatimEndpoint: string = Constants.config.nominatimEndpoint
2024-08-21 14:06:42 +02:00
public static photonEndpoint: string = Constants.config.photonEndpoint
public static linkedDataProxy: string = Constants.config["jsonld-proxy"]
2023-05-08 01:58:33 +02:00
/**
* These are the values that are allowed to use as 'backdrop' icon for a map pin
*/
2024-08-21 14:06:42 +02:00
public static readonly _defaultPinIcons = [
2024-07-29 23:34:41 +02:00
"addSmall",
2024-08-21 14:06:42 +02:00
"airport",
2024-07-29 23:34:41 +02:00
"brick_wall_round",
"brick_wall_square",
2024-08-21 14:06:42 +02:00
"building_office_2",
2024-08-23 02:16:24 +02:00
"building_storefront",
"bug",
"checkmark",
2024-07-29 23:34:41 +02:00
"checkmark",
"circle",
"clock",
"close",
2024-07-29 23:34:41 +02:00
"close",
"confirm",
"computer",
"cross_bottom_right",
"crosshair",
2024-07-29 23:34:41 +02:00
"desktop",
"direction",
"gear",
2024-08-21 14:06:42 +02:00
"globe_alt",
2024-07-29 23:34:41 +02:00
"gps_arrow",
"heart",
"heart_outline",
"help",
"help",
"home",
2024-08-21 14:06:42 +02:00
"house",
"key",
"invalid",
2024-07-29 23:34:41 +02:00
"invalid",
"link",
"location",
"location_empty",
"location_locked",
"lock",
2024-07-29 23:34:41 +02:00
"mastodon",
"not_found",
"note",
2024-07-29 23:34:41 +02:00
"party",
"pencil",
2024-07-29 23:34:41 +02:00
"pin",
"resolved",
"ring",
"scissors",
2024-07-29 23:34:41 +02:00
"square",
"square_rounded",
"teardrop",
"teardrop_with_hole_green",
2024-08-21 14:06:42 +02:00
"train",
"triangle",
2024-08-21 14:06:42 +02:00
"user_circle",
2024-08-09 16:55:08 +02:00
"wifi",
] as const
2023-05-08 01:58:33 +02:00
public static readonly defaultPinIcons: string[] = <any>Constants._defaultPinIcons
/**
* The location that the MVT-layer is hosted.
* This is a MapLibre/MapBox vector tile server which hosts vector tiles for every (official) layer
*/
public static VectorTileServer: string | undefined = Constants.config.mvt_layer_server
2024-06-17 19:27:21 +02:00
public static GeoIpServer: string | undefined = Constants.config.geoip_server
public static ErrorReportServer: string | undefined = Constants.config.error_server
2024-06-17 19:27:21 +02:00
public static readonly maptilerApiKey = "GvoVAJgu46I5rZapJuAy"
2024-06-12 15:03:10 +02:00
public static readonly SummaryServer: string = Constants.config.summary_server
2021-01-06 02:21:50 +01:00
2024-07-09 13:42:08 +02:00
public static allServers: string[] = [
Constants.SummaryServer,
Constants.VectorTileServer,
Constants.GeoIpServer,
Constants.ErrorReportServer,
Constants.countryCoderEndpoint,
Constants.osmAuthConfig.url,
Constants.nominatimEndpoint,
2024-08-21 14:06:42 +02:00
Constants.photonEndpoint,
2024-07-09 13:42:08 +02:00
Constants.linkedDataProxy,
...Constants.defaultOverpassUrls,
]
2024-06-27 03:44:52 +02:00
2021-01-06 02:21:50 +01:00
private static isRetina(): boolean {
2022-09-08 21:40:48 +02:00
if (Utils.runningFromConsole) {
return false
2022-06-02 03:02:35 +02:00
}
2021-01-06 02:21:50 +01:00
// The cause for this line of code: https://github.com/pietervdvn/MapComplete/issues/115
// See https://stackoverflow.com/questions/19689715/what-is-the-best-way-to-detect-retina-support-on-a-device-using-javascript
2022-09-08 21:40:48 +02:00
return (
(window.matchMedia &&
(window.matchMedia(
"only screen and (min-resolution: 192dpi), only screen and (min-resolution: 2dppx), only screen and (min-resolution: 75.6dpcm)"
).matches ||
2022-09-08 21:40:48 +02:00
window.matchMedia(
"only screen and (-webkit-min-device-pixel-ratio: 2), only screen and (-o-min-device-pixel-ratio: 2/1), only screen and (min--moz-device-pixel-ratio: 2), only screen and (min-device-pixel-ratio: 2)"
).matches)) ||
(window.devicePixelRatio && window.devicePixelRatio >= 2)
)
2021-01-06 02:21:50 +01:00
}
2021-03-31 11:39:56 +02:00
}