mapcomplete/Logic/State/FeatureSwitchState.ts

226 lines
9 KiB
TypeScript
Raw Normal View History

/**
* The part of the global state which initializes the feature switches, based on default values and on the layoutToUse
*/
2022-09-08 21:40:48 +02:00
import LayoutConfig from "../../Models/ThemeConfig/LayoutConfig"
2023-05-25 20:09:42 +02:00
import {UIEventSource} from "../UIEventSource"
import {QueryParameters} from "../Web/QueryParameters"
2022-09-08 21:40:48 +02:00
import Constants from "../../Models/Constants"
2023-05-25 20:09:42 +02:00
import {Utils} from "../../Utils"
2023-05-25 20:09:42 +02:00
class FeatureSwitchUtils {
static initSwitch(
key: string,
deflt:boolean,
documentation: string
): UIEventSource<boolean> {
const defaultValue = deflt
const queryParam = QueryParameters.GetQueryParameter(
key,
"" + defaultValue,
documentation
)
// It takes the current layout, extracts the default value for this query parameter. A query parameter event source is then retrieved and flattened
return queryParam.sync(
(str) => (str === undefined ? defaultValue : str !== "false"),
[],
(b) => (b == defaultValue ? undefined : "" + b)
)
}
}
export class OsmConnectionFeatureSwitches {
public readonly featureSwitchFakeUser: UIEventSource<boolean>
public readonly featureSwitchApiURL: UIEventSource<string>
constructor() {
this.featureSwitchApiURL = QueryParameters.GetQueryParameter(
"backend",
"osm",
"The OSM backend to use - can be used to redirect mapcomplete to the testing backend when using 'osm-test'"
)
this.featureSwitchFakeUser = QueryParameters.GetBooleanQueryParameter(
"fake-user",
false,
"If true, 'dryrun' mode is activated and a fake user account is loaded"
)
}
}
export default class FeatureSwitchState extends OsmConnectionFeatureSwitches{
/**
* The layout that is being used in this run
*/
2022-09-08 21:40:48 +02:00
public readonly layoutToUse: LayoutConfig
public readonly featureSwitchUserbadge: UIEventSource<boolean>
public readonly featureSwitchSearch: UIEventSource<boolean>
public readonly featureSwitchBackgroundSelection: UIEventSource<boolean>
public readonly featureSwitchAddNew: UIEventSource<boolean>
public readonly featureSwitchWelcomeMessage: UIEventSource<boolean>
public readonly featureSwitchCommunityIndex: UIEventSource<boolean>
2022-09-08 21:40:48 +02:00
public readonly featureSwitchExtraLinkEnabled: UIEventSource<boolean>
public readonly featureSwitchMoreQuests: UIEventSource<boolean>
public readonly featureSwitchShareScreen: UIEventSource<boolean>
public readonly featureSwitchGeolocation: UIEventSource<boolean>
public readonly featureSwitchIsTesting: UIEventSource<boolean>
public readonly featureSwitchIsDebugging: UIEventSource<boolean>
public readonly featureSwitchShowAllQuestions: UIEventSource<boolean>
public readonly featureSwitchFilter: UIEventSource<boolean>
public readonly featureSwitchEnableExport: UIEventSource<boolean>
public readonly overpassUrl: UIEventSource<string[]>
public readonly overpassTimeout: UIEventSource<number>
public readonly overpassMaxZoom: UIEventSource<number>
public readonly osmApiTileSize: UIEventSource<number>
public readonly backgroundLayerId: UIEventSource<string>
2023-05-25 20:09:42 +02:00
public constructor(layoutToUse?: LayoutConfig) {
super()
2022-09-08 21:40:48 +02:00
this.layoutToUse = layoutToUse
// Helper function to initialize feature switches
2023-05-25 20:09:42 +02:00
this.featureSwitchUserbadge = FeatureSwitchUtils.initSwitch(
"fs-userbadge",
2023-05-25 20:09:42 +02:00
layoutToUse?.enableUserBadge ?? true,
"Disables/Enables the user information pill (userbadge) at the top left. Disabling this disables logging in and thus disables editing all together, effectively putting MapComplete into read-only mode."
2022-09-08 21:40:48 +02:00
)
2023-05-25 20:09:42 +02:00
this.featureSwitchSearch = FeatureSwitchUtils.initSwitch(
"fs-search",
2023-05-25 20:09:42 +02:00
layoutToUse?.enableSearch ?? true,
"Disables/Enables the search bar"
2022-09-08 21:40:48 +02:00
)
2023-05-25 20:09:42 +02:00
this.featureSwitchBackgroundSelection = FeatureSwitchUtils.initSwitch(
"fs-background",
2023-05-25 20:09:42 +02:00
layoutToUse?.enableBackgroundLayerSelection ?? true,
"Disables/Enables the background layer control"
2022-09-08 21:40:48 +02:00
)
2023-05-25 20:09:42 +02:00
this.featureSwitchFilter = FeatureSwitchUtils.initSwitch(
"fs-filter",
2023-05-25 20:09:42 +02:00
layoutToUse?.enableLayers ?? true,
"Disables/Enables the filter view"
2022-09-08 21:40:48 +02:00
)
2023-05-25 20:09:42 +02:00
this.featureSwitchAddNew = FeatureSwitchUtils.initSwitch(
"fs-add-new",
2023-05-25 20:09:42 +02:00
layoutToUse?.enableAddNewPoints ?? true,
"Disables/Enables the 'add new feature'-popup. (A theme without presets might not have it in the first place)"
2022-09-08 21:40:48 +02:00
)
2023-05-25 20:09:42 +02:00
this.featureSwitchWelcomeMessage = FeatureSwitchUtils.initSwitch(
"fs-welcome-message",
2023-05-25 20:09:42 +02:00
true,
"Disables/enables the help menu or welcome message"
2022-09-08 21:40:48 +02:00
)
2023-05-25 20:09:42 +02:00
this.featureSwitchCommunityIndex = FeatureSwitchUtils.initSwitch(
"fs-community-index",
2023-05-25 20:09:42 +02:00
true,
"Disables/enables the button to get in touch with the community"
)
2023-05-25 20:09:42 +02:00
this.featureSwitchExtraLinkEnabled = FeatureSwitchUtils.initSwitch(
"fs-iframe-popout",
2023-05-25 20:09:42 +02:00
true,
"Disables/Enables the extraLink button. By default, if in iframe mode and the welcome message is hidden, a popout button to the full mapcomplete instance is shown instead (unless disabled with this switch or another extraLink button is enabled)"
2022-09-08 21:40:48 +02:00
)
2023-05-25 20:09:42 +02:00
this.featureSwitchMoreQuests = FeatureSwitchUtils.initSwitch(
"fs-more-quests",
2023-05-25 20:09:42 +02:00
layoutToUse?.enableMoreQuests ?? true,
"Disables/Enables the 'More Quests'-tab in the welcome message"
2022-09-08 21:40:48 +02:00
)
2023-05-25 20:09:42 +02:00
this.featureSwitchShareScreen = FeatureSwitchUtils.initSwitch(
"fs-share-screen",
2023-05-25 20:09:42 +02:00
layoutToUse?.enableShareScreen ?? true,
"Disables/Enables the 'Share-screen'-tab in the welcome message"
2022-09-08 21:40:48 +02:00
)
2023-05-25 20:09:42 +02:00
this.featureSwitchGeolocation = FeatureSwitchUtils.initSwitch(
"fs-geolocation",
2023-05-25 20:09:42 +02:00
layoutToUse?.enableGeolocation ?? true,
"Disables/Enables the geolocation button"
2022-09-08 21:40:48 +02:00
)
2023-05-25 20:09:42 +02:00
this.featureSwitchShowAllQuestions = FeatureSwitchUtils.initSwitch(
"fs-all-questions",
2023-05-25 20:09:42 +02:00
layoutToUse?.enableShowAllQuestions ?? false,
"Always show all questions"
2022-09-08 21:40:48 +02:00
)
2023-05-25 20:09:42 +02:00
this.featureSwitchEnableExport = FeatureSwitchUtils.initSwitch(
"fs-export",
2023-05-25 20:09:42 +02:00
layoutToUse?.enableExportButton ?? true,
"Enable the export as GeoJSON and CSV button"
2022-09-08 21:40:48 +02:00
)
2022-09-08 21:40:48 +02:00
let testingDefaultValue = false
if (
this.featureSwitchApiURL.data !== "osm-test" &&
!Utils.runningFromConsole &&
(location.hostname === "localhost" || location.hostname === "127.0.0.1")
) {
testingDefaultValue = true
}
this.featureSwitchIsTesting = QueryParameters.GetBooleanQueryParameter(
"test",
testingDefaultValue,
"If true, 'dryrun' mode is activated. The app will behave as normal, except that changes to OSM will be printed onto the console instead of actually uploaded to osm.org"
)
this.featureSwitchIsDebugging = QueryParameters.GetBooleanQueryParameter(
"debug",
false,
"If true, shows some extra debugging help such as all the available tags on every object"
)
2022-09-08 21:40:48 +02:00
this.overpassUrl = QueryParameters.GetQueryParameter(
"overpassUrl",
(layoutToUse?.overpassUrl ?? Constants.defaultOverpassUrls).join(","),
"Point mapcomplete to a different overpass-instance. Example: https://overpass-api.de/api/interpreter"
2022-09-08 21:40:48 +02:00
).sync(
2022-09-18 12:45:02 +02:00
(param) => param?.split(","),
2022-09-08 21:40:48 +02:00
[],
2022-09-18 12:45:02 +02:00
(urls) => urls?.join(",")
2022-09-08 21:40:48 +02:00
)
2022-09-08 21:40:48 +02:00
this.overpassTimeout = UIEventSource.asFloat(
QueryParameters.GetQueryParameter(
"overpassTimeout",
"" + layoutToUse?.overpassTimeout,
"Set a different timeout (in seconds) for queries in overpass"
)
)
2022-09-08 21:40:48 +02:00
this.overpassMaxZoom = UIEventSource.asFloat(
QueryParameters.GetQueryParameter(
"overpassMaxZoom",
"" + layoutToUse?.overpassMaxZoom,
2022-09-08 21:40:48 +02:00
" point to switch between OSM-api and overpass"
)
)
2022-09-08 21:40:48 +02:00
this.osmApiTileSize = UIEventSource.asFloat(
QueryParameters.GetQueryParameter(
"osmApiTileSize",
"" + layoutToUse?.osmApiTileSize,
2022-09-08 21:40:48 +02:00
"Tilesize when the OSM-API is used to fetch data within a BBOX"
)
)
2022-09-08 21:40:48 +02:00
this.featureSwitchUserbadge.addCallbackAndRun((userbadge) => {
if (!userbadge) {
this.featureSwitchAddNew.setData(false)
}
})
this.backgroundLayerId = QueryParameters.GetQueryParameter(
"background",
layoutToUse?.defaultBackgroundId ?? "osm",
"The id of the background layer to start with"
2022-09-08 21:40:48 +02:00
)
}
2022-09-08 21:40:48 +02:00
}