2023-09-25 03:13:17 +02:00
import * as packagefile from "../../package.json"
import * as extraconfig from "../../config.json"
2023-09-02 00:55:07 +02:00
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 ]
2023-04-19 03:20:49 +02:00
2021-01-02 16:04:16 +01:00
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
*
* Currently there is no user - friendly way to get the user ' s API key .
* 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-07-13 10:03:09 +02:00
public static readonly MaprouletteApiKey = ""
2023-03-25 02:48:24 +01:00
public static readonly added_by_default = [
2022-12-09 13:58:41 +01:00
"selected_element" ,
2021-12-21 18:35:31 +01:00
"gps_location" ,
"gps_location_history" ,
"home_location" ,
"gps_track" ,
2023-03-25 02:48:24 +01:00
"range" ,
2023-04-02 02:59:20 +02:00
"last_click" ,
2023-11-22 19:39:19 +01:00
"favourite" ,
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-01-26 21:40:38 +01:00
"conflation" ,
"split_point" ,
2023-04-20 01:52:23 +02:00
"split_road" ,
2022-01-26 21:40:38 +01:00
"current_view" ,
2023-03-29 18:54:00 +02:00
"import_candidate" ,
"usersettings" ,
2024-01-16 04:09:58 +01:00
"icons" ,
"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-06-13 03:13:42 +02:00
. . . Constants . added_by_default ,
. . . Constants . no_include ,
2023-03-25 02:48:24 +01:00
] as const
2021-01-02 16:04:16 +01:00
// 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 ,
2021-07-01 02:26:45 +02:00
deletePointsOfOthersUnlock : 20 ,
2021-03-17 14:35:06 +01:00
tagsVisibleAt : 25 ,
2021-03-16 19:35:19 +01:00
tagsVisibleAndWikiLinked : 30 ,
2021-09-09 00:05:51 +02:00
2021-06-28 18:06:54 +02:00
mapCompleteHelpUnlock : 50 ,
2021-03-24 01:25:57 +01:00
themeGeneratorReadOnlyUnlock : 50 ,
2021-01-02 16:04:16 +01:00
themeGeneratorFullUnlock : 500 ,
addNewPointWithUnreadMessagesUnlock : 500 ,
2021-09-09 00:05:51 +02:00
2022-01-18 21:26:07 +01:00
importHelperUnlock : 5000 ,
2021-01-02 16:04:16 +01:00
}
2023-10-09 01:26:12 +02:00
static readonly minZoomLevelToAddNewPoint = Constants . isRetina ( ) ? 17 : 18
2021-02-20 22:18:42 +01:00
/ * *
* 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
2021-11-09 01:49:07 +01:00
/ * *
* 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-01-26 21:40:38 +01:00
static nearbyVisitTime : number = 30 * 60
2021-11-09 01:49:07 +01:00
/ * *
* 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-02-22 16:11:00 +01:00
static themeOrder = [
"personal" ,
"cyclofix" ,
"waste" ,
"etymology" ,
"food" ,
"cafes_and_pubs" ,
2023-09-02 00:07:47 +02:00
"shops" ,
2022-02-22 16:11:00 +01:00
"playgrounds" ,
"hailhydrant" ,
"toilets" ,
"aed" ,
"bookcases" ,
2022-09-08 21:40:48 +02:00
]
2022-04-09 19:29:51 +02:00
/ * *
* Upon initialization , the GPS will search the location .
* If the location is found within the given timout , it ' ll automatically fly to it .
*
* In seconds
* /
2023-02-09 03:12:21 +01:00
static zoomToLocationTimeout = 15
2023-12-24 05:01:10 +01:00
public static readonly viewportCenterCloseToGpsCutoff : number = 20
2023-09-25 03:13:17 +02:00
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
2023-09-29 11:13:30 +02:00
public static nominatimEndpoint : string = Constants . config . nominatimEndpoint
2023-05-08 01:58:33 +02:00
/ * *
* These are the values that are allowed to use as 'backdrop' icon for a map pin
* /
2023-06-14 20:39:36 +02:00
private static readonly _defaultPinIcons = [
2024-01-12 23:19:31 +01:00
"pin" ,
2023-06-14 20:39:36 +02:00
"square" ,
"circle" ,
2024-01-12 23:19:31 +01:00
"checkmark" ,
"clock" ,
"close" ,
"crosshair" ,
"help" ,
"home" ,
"invalid" ,
"location" ,
"location_empty" ,
"location_locked" ,
"note" ,
"resolved" ,
2023-06-14 20:39:36 +02:00
"ring" ,
2024-01-12 23:19:31 +01:00
"scissors" ,
2023-06-14 20:39:36 +02:00
"teardrop" ,
2024-01-12 23:19:31 +01:00
"teardrop_with_hole_green" ,
2023-06-14 20:39:36 +02:00
"triangle" ,
2023-11-19 05:05:15 +01:00
"brick_wall_square" ,
"brick_wall_round" ,
"gps_arrow" ,
"checkmark" ,
"help" ,
"close" ,
2024-01-12 23:19:31 +01:00
"invalid" ,
2023-11-22 19:39:19 +01:00
"heart" ,
"heart_outline" ,
2024-01-12 23:19:31 +01:00
"confirm" ,
"direction" ,
"not_found" ,
"mastodon" ,
"party" ,
"addSmall" ,
2023-06-14 20:39:36 +02:00
] as const
2023-05-08 01:58:33 +02:00
public static readonly defaultPinIcons : string [ ] = < any > Constants . _defaultPinIcons
2021-01-06 02:21:50 +01:00
private static isRetina ( ) : boolean {
2022-06-02 03:02:35 +02:00
if ( Utils . runningFromConsole ) {
return false
}
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
return (
( window . matchMedia &&
( window . matchMedia (
2023-06-14 20:39:36 +02:00
"only screen and (min-resolution: 192dpi), only screen and (min-resolution: 2dppx), only screen and (min-resolution: 75.6dpcm)"
) . matches ||
2021-01-06 02:21:50 +01: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 )
2022-09-08 21:40:48 +02:00
)
2021-01-06 02:21:50 +01:00
}
2021-03-31 11:39:56 +02:00
}