forked from MapComplete/MapComplete
		
	Fixes, surveillance cams v0.1
This commit is contained in:
		
							parent
							
								
									b329bbbdb3
								
							
						
					
					
						commit
						ba44024dd9
					
				
					 10 changed files with 137 additions and 65 deletions
				
			
		|  | @ -15,10 +15,11 @@ import * as benches from "../assets/themes/benches/benches.json"; | ||||||
| import * as charging_stations from "../assets/themes/charging_stations/charging_stations.json" | import * as charging_stations from "../assets/themes/charging_stations/charging_stations.json" | ||||||
| import * as widths from "../assets/themes/widths/width.json" | import * as widths from "../assets/themes/widths/width.json" | ||||||
| import * as drinking_water from "../assets/themes/drinking_water/drinking_water.json" | import * as drinking_water from "../assets/themes/drinking_water/drinking_water.json" | ||||||
| import LayerConfig from "./JSON/LayerConfig"; | import * as surveillance_cameras from "../assets/themes/surveillance_cameras/surveillance_cameras.json" | ||||||
| import SharedLayers from "./SharedLayers"; |  | ||||||
| import * as personal from "../assets/themes/personalLayout/personalLayout.json" | import * as personal from "../assets/themes/personalLayout/personalLayout.json" | ||||||
|  | import LayerConfig from "./JSON/LayerConfig"; | ||||||
| import LayoutConfig from "./JSON/LayoutConfig"; | import LayoutConfig from "./JSON/LayoutConfig"; | ||||||
|  | import SharedLayers from "./SharedLayers"; | ||||||
| 
 | 
 | ||||||
| export class AllKnownLayouts { | export class AllKnownLayouts { | ||||||
| 
 | 
 | ||||||
|  | @ -60,6 +61,7 @@ export class AllKnownLayouts { | ||||||
|         new LayoutConfig(widths), |         new LayoutConfig(widths), | ||||||
|         new LayoutConfig(buurtnatuur), |         new LayoutConfig(buurtnatuur), | ||||||
|         new LayoutConfig(bike_monitoring_stations), |         new LayoutConfig(bike_monitoring_stations), | ||||||
|  |         new LayoutConfig(surveillance_cameras) | ||||||
|     ]; |     ]; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -442,7 +442,7 @@ export class InitUiElements { | ||||||
|         State.state.layerUpdater = new UpdateFromOverpass(State.state); |         State.state.layerUpdater = new UpdateFromOverpass(State.state); | ||||||
| 
 | 
 | ||||||
|         State.state.availableBackgroundLayers = new AvailableBaseLayers(State.state).availableEditorLayers; |         State.state.availableBackgroundLayers = new AvailableBaseLayers(State.state).availableEditorLayers; | ||||||
|         const queryParam = QueryParameters.GetQueryParameter("background", State.state.layoutToUse.data.defaultBackgroundId); |         const queryParam = QueryParameters.GetQueryParameter("background", State.state.layoutToUse.data.defaultBackgroundId, "The id of the background layer to start with"); | ||||||
| 
 | 
 | ||||||
|         queryParam.addCallbackAndRun((selectedId: string) => { |         queryParam.addCallbackAndRun((selectedId: string) => { | ||||||
|             const available = State.state.availableBackgroundLayers.data; |             const available = State.state.availableBackgroundLayers.data; | ||||||
|  | @ -483,7 +483,7 @@ export class InitUiElements { | ||||||
|             const flayer: FilteredLayer = FilteredLayer.fromDefinition(layer, generateInfo); |             const flayer: FilteredLayer = FilteredLayer.fromDefinition(layer, generateInfo); | ||||||
|             flayers.push(flayer); |             flayers.push(flayer); | ||||||
| 
 | 
 | ||||||
|             QueryParameters.GetQueryParameter("layer-" + layer.id, "true") |             QueryParameters.GetQueryParameter("layer-" + layer.id, "true", "Wehter or not layer "+layer.id+" is shown") | ||||||
|                 .map<boolean>((str) => str !== "false", [], (b) => b.toString()) |                 .map<boolean>((str) => str !== "false", [], (b) => b.toString()) | ||||||
|                 .syncWith( |                 .syncWith( | ||||||
|                     flayer.isDisplayed |                     flayer.isDisplayed | ||||||
|  |  | ||||||
|  | @ -10,6 +10,8 @@ export class QueryParameters { | ||||||
|     private static initialized = false; |     private static initialized = false; | ||||||
|     private static defaults = {} |     private static defaults = {} | ||||||
| 
 | 
 | ||||||
|  |     private static documentation = {} | ||||||
|  | 
 | ||||||
|     private static addOrder(key) { |     private static addOrder(key) { | ||||||
|         if (this.order.indexOf(key) < 0) { |         if (this.order.indexOf(key) < 0) { | ||||||
|             this.order.push(key) |             this.order.push(key) | ||||||
|  | @ -63,6 +65,7 @@ export class QueryParameters { | ||||||
|         if(!this.initialized){ |         if(!this.initialized){ | ||||||
|             this.init(); |             this.init(); | ||||||
|         } |         } | ||||||
|  |         QueryParameters.documentation[key] = documentation; | ||||||
|         if (deflt !== undefined) { |         if (deflt !== undefined) { | ||||||
|             QueryParameters.defaults[key] = deflt; |             QueryParameters.defaults[key] = deflt; | ||||||
|         } |         } | ||||||
|  | @ -76,4 +79,12 @@ export class QueryParameters { | ||||||
|         return source; |         return source; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|  |     public static GenerateQueryParameterDocs(): string { | ||||||
|  |         const docs = []; | ||||||
|  |         for (const key in QueryParameters.documentation) { | ||||||
|  |             docs.push("**" + key + "**: " + QueryParameters.documentation[key] + " (default value: _" + QueryParameters.defaults[key] + "_)") | ||||||
|  |         } | ||||||
|  |         return docs.join("\n\n"); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
| } | } | ||||||
							
								
								
									
										46
									
								
								README.md
									
										
									
									
									
								
							
							
						
						
									
										46
									
								
								README.md
									
										
									
									
									
								
							|  | @ -103,7 +103,7 @@ A theme has translations into the preset.json (`assets/themes/themename/themenam | ||||||
| 
 | 
 | ||||||
| 1. Modify `"language"` to contain the new language, e.g. `"language": "nl"` becomes `"language": ["nl", "en"]` | 1. Modify `"language"` to contain the new language, e.g. `"language": "nl"` becomes `"language": ["nl", "en"]` | ||||||
| 2. Add extra strings to the texts. If it used to be a single-language theme, one can replace the strings, e.g.: `"description": "Welcome to Open Bookcase Map"` to `"description": {"en": "Welcome to Open Bookcase Map", "nl": "Welkom bij de OpenBoekenruilkastenKaart", "fr": "Bienvenue sûr la carte des petites bibliotheques"}`. If the correct language is not found, it'll fallback to another supported language. | 2. Add extra strings to the texts. If it used to be a single-language theme, one can replace the strings, e.g.: `"description": "Welcome to Open Bookcase Map"` to `"description": {"en": "Welcome to Open Bookcase Map", "nl": "Welkom bij de OpenBoekenruilkastenKaart", "fr": "Bienvenue sûr la carte des petites bibliotheques"}`. If the correct language is not found, it'll fallback to another supported language. | ||||||
| 3. If you notice missing translations in the core of MapComplete, fork this project, open [the file containing all translations](https://github.com/pietervdvn/MapComplete/blob/master/UI/i18n/Translations.ts), add add a language string there | 3. If you notice missing translations in the core of MapComplete, fork this project, open [the file containing all translations](https://github.com/pietervdvn/MapComplete/blob/master/assets/translations.json), add add a language string there | ||||||
| 4. Send a pull request to update the languages, I'll gladly add it! It doesn't have to be a complete translation from the start ;) | 4. Send a pull request to update the languages, I'll gladly add it! It doesn't have to be a complete translation from the start ;) | ||||||
| 
 | 
 | ||||||
| ### Adding your theme to the repository | ### Adding your theme to the repository | ||||||
|  | @ -165,6 +165,50 @@ Whenever a change is made -even adding a single tag- the change is uploaded into | ||||||
| 
 | 
 | ||||||
| Note that changesets are closed automatically after one hour of inactivity, so we don't have to worry about closing them.  | Note that changesets are closed automatically after one hour of inactivity, so we don't have to worry about closing them.  | ||||||
| 
 | 
 | ||||||
|  | ### Query parameters | ||||||
|  | 
 | ||||||
|  | By adding extra query parameters, more options are available to influence: | ||||||
|  | 
 | ||||||
|  | **test**: 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 (default value: _false_) | ||||||
|  | 
 | ||||||
|  | **layout**: The layout to load into MapComplete (default value: _bookcases_) | ||||||
|  | 
 | ||||||
|  | **userlayout**: undefined (default value: _false_) | ||||||
|  | 
 | ||||||
|  | **layer-control-toggle**: Wether or not the layer control is shown (default value: _false_) | ||||||
|  | 
 | ||||||
|  | **tab**: The tab that is shown in the welcome-message. 0 = the explanation of the theme,1 = OSM-credits, 2 = sharescreen, 3 = more themes, 4 = about mapcomplete (user must be logged in and have >200 changesets) (default value: _0_) | ||||||
|  | 
 | ||||||
|  | **z**: The initial/current zoom level (default value: _1_) | ||||||
|  | 
 | ||||||
|  | **lat**: The initial/current latitude (default value: _0_) | ||||||
|  | 
 | ||||||
|  | **lon**: The initial/current longitude of the app (default value: _0_) | ||||||
|  | 
 | ||||||
|  | **fs-userbadge**: Disables/Enables the userbadge (and thus disables login capabilities) (default value: _true_) | ||||||
|  | 
 | ||||||
|  | **fs-search**: Disables/Enables the search bar (default value: _true_) | ||||||
|  | 
 | ||||||
|  | **fs-layers**: Disables/Enables the layer control (default value: _true_) | ||||||
|  | 
 | ||||||
|  | **fs-add-new**: Disables/Enables the 'add new feature'-popup. (A theme without presets might not have it in the first place) (default value: _true_) | ||||||
|  | 
 | ||||||
|  | **fs-welcome-message**: undefined (default value: _true_) | ||||||
|  | 
 | ||||||
|  | **fs-iframe**: Disables/Enables the iframe-popup (default value: _false_) | ||||||
|  | 
 | ||||||
|  | **fs-more-quests**: Disables/Enables the 'More Quests'-tab in the welcome message (default value: _true_) | ||||||
|  | 
 | ||||||
|  | **fs-share-screen**: Disables/Enables the 'Share-screen'-tab in the welcome message (default value: _true_) | ||||||
|  | 
 | ||||||
|  | **fs-geolocation**: Disables/Enables the geolocation button (default value: _true_) | ||||||
|  | 
 | ||||||
|  | **oauth_token**: Used to complete the login (default value: _undefined_) | ||||||
|  | 
 | ||||||
|  | **background**: The id of the background layer to start with (default value: _undefined_) | ||||||
|  | 
 | ||||||
|  | **layer-bookcases**: Wehter or not layer bookcases is shown (default value: _true_) index.ts:104:8 | ||||||
|  | 
 | ||||||
| # Privacy | # Privacy | ||||||
| 
 | 
 | ||||||
| Privacy is important, we try to leak as little information as possible. | Privacy is important, we try to leak as little information as possible. | ||||||
|  |  | ||||||
							
								
								
									
										46
									
								
								State.ts
									
										
									
									
									
								
							
							
						
						
									
										46
									
								
								State.ts
									
										
									
									
									
								
							|  | @ -115,10 +115,10 @@ export default class State { | ||||||
|     public layoutDefinition: string; |     public layoutDefinition: string; | ||||||
|     public installedThemes: UIEventSource<{ layout: LayoutConfig; definition: string }[]>; |     public installedThemes: UIEventSource<{ layout: LayoutConfig; definition: string }[]>; | ||||||
| 
 | 
 | ||||||
|     public layerControlIsOpened: UIEventSource<boolean> = QueryParameters.GetQueryParameter("layer-control-toggle", "false") |     public layerControlIsOpened: UIEventSource<boolean> = QueryParameters.GetQueryParameter("layer-control-toggle", "false", "Wether or not the layer control is shown") | ||||||
|         .map<boolean>((str) => str !== "false", [], b => "" + b) |         .map<boolean>((str) => str !== "false", [], b => "" + b) | ||||||
| 
 | 
 | ||||||
|     public welcomeMessageOpenedTab = QueryParameters.GetQueryParameter("tab", "0").map<number>( |     public welcomeMessageOpenedTab = QueryParameters.GetQueryParameter("tab", "0", `The tab that is shown in the welcome-message. 0 = the explanation of the theme,1 = OSM-credits, 2 = sharescreen, 3 = more themes, 4 = about mapcomplete (user must be logged in and have >${State.userJourney.mapCompleteHelpUnlock} changesets)`).map<number>( | ||||||
|         str => isNaN(Number(str)) ? 0 : Number(str), [], n => "" + n |         str => isNaN(Number(str)) ? 0 : Number(str), [], n => "" + n | ||||||
|     ); |     ); | ||||||
| 
 | 
 | ||||||
|  | @ -138,11 +138,11 @@ export default class State { | ||||||
|             }) |             }) | ||||||
|         } |         } | ||||||
|         this.zoom = asFloat( |         this.zoom = asFloat( | ||||||
|             QueryParameters.GetQueryParameter("z", "" + layoutToUse.startZoom) |             QueryParameters.GetQueryParameter("z", "" + layoutToUse.startZoom, "The initial/current zoom level") | ||||||
|             .syncWith(LocalStorageSource.Get("zoom"))); |             .syncWith(LocalStorageSource.Get("zoom"))); | ||||||
|         this.lat = asFloat(QueryParameters.GetQueryParameter("lat", "" + layoutToUse.startLat) |         this.lat = asFloat(QueryParameters.GetQueryParameter("lat", "" + layoutToUse.startLat, "The initial/current latitude") | ||||||
|             .syncWith(LocalStorageSource.Get("lat"))); |             .syncWith(LocalStorageSource.Get("lat"))); | ||||||
|         this.lon = asFloat(QueryParameters.GetQueryParameter("lon", "" + layoutToUse.startLon) |         this.lon = asFloat(QueryParameters.GetQueryParameter("lon", "" + layoutToUse.startLon, "The initial/current longitude of the app") | ||||||
|             .syncWith(LocalStorageSource.Get("lon"))); |             .syncWith(LocalStorageSource.Get("lon"))); | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | @ -165,8 +165,8 @@ export default class State { | ||||||
|         }); |         }); | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|         function featSw(key: string, deflt: (layout: LayoutConfig) => boolean, documentation?: string): UIEventSource<boolean> { |         function featSw(key: string, deflt: (layout: LayoutConfig) => boolean, documentation: string): UIEventSource<boolean> { | ||||||
|             const queryParameterSource = QueryParameters.GetQueryParameter(key, undefined); |             const queryParameterSource = QueryParameters.GetQueryParameter(key, undefined, documentation); | ||||||
|             // I'm so sorry about someone trying to decipher this
 |             // I'm so sorry about someone trying to decipher this
 | ||||||
| 
 | 
 | ||||||
|             // It takes the current layout, extracts the default value for this query paramter. A query parameter event source is then retreived and flattened
 |             // It takes the current layout, extracts the default value for this query paramter. A query parameter event source is then retreived and flattened
 | ||||||
|  | @ -180,20 +180,30 @@ export default class State { | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|         this.featureSwitchUserbadge = featSw("fs-userbadge", (layoutToUse) => layoutToUse?.enableUserBadge ?? true, |         this.featureSwitchUserbadge = featSw("fs-userbadge", (layoutToUse) => layoutToUse?.enableUserBadge ?? true, | ||||||
|             "Disables the userbadge (and thus disables login capabilities)"); |             "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."); | ||||||
|         this.featureSwitchSearch = featSw("fs-search", (layoutToUse) => layoutToUse?.enableSearch ?? true); |         this.featureSwitchSearch = featSw("fs-search", (layoutToUse) => layoutToUse?.enableSearch ?? true, | ||||||
|         this.featureSwitchLayers = featSw("fs-layers", (layoutToUse) => layoutToUse?.enableLayers ?? true); |             "Disables/Enables the search bar"); | ||||||
|         this.featureSwitchAddNew = featSw("fs-add-new", (layoutToUse) => layoutToUse?.enableAddNewPoints ?? true); |         this.featureSwitchLayers = featSw("fs-layers", (layoutToUse) => layoutToUse?.enableLayers ?? true, | ||||||
|         this.featureSwitchWelcomeMessage = featSw("fs-welcome-message", () => true); |             "Disables/Enables the layer control"); | ||||||
|         this.featureSwitchIframe = featSw("fs-iframe", () => false); |         this.featureSwitchAddNew = featSw("fs-add-new", (layoutToUse) => layoutToUse?.enableAddNewPoints ?? true, | ||||||
|         this.featureSwitchMoreQuests = featSw("fs-more-quests", (layoutToUse) => layoutToUse?.enableMoreQuests ?? true); |             "Disables/Enables the 'add new feature'-popup. (A theme without presets might not have it in the first place)"); | ||||||
|         this.featureSwitchShareScreen = featSw("fs-share-screen", (layoutToUse) => layoutToUse?.enableShareScreen ?? true); |         this.featureSwitchWelcomeMessage = featSw("fs-welcome-message", () => true,  | ||||||
|         this.featureSwitchGeolocation = featSw("fs-geolocation", (layoutToUse) => layoutToUse?.enableGeolocation ?? true); |             "Disables/enables the help menu or welcome message"); | ||||||
|  |         this.featureSwitchIframe = featSw("fs-iframe", () => false, | ||||||
|  |             "Disables/Enables the iframe-popup"); | ||||||
|  |         this.featureSwitchMoreQuests = featSw("fs-more-quests", (layoutToUse) => layoutToUse?.enableMoreQuests ?? true, | ||||||
|  |             "Disables/Enables the 'More Quests'-tab in the welcome message"); | ||||||
|  |         this.featureSwitchShareScreen = featSw("fs-share-screen", (layoutToUse) => layoutToUse?.enableShareScreen ?? true, | ||||||
|  |             "Disables/Enables the 'Share-screen'-tab in the welcome message"); | ||||||
|  |         this.featureSwitchGeolocation = featSw("fs-geolocation", (layoutToUse) => layoutToUse?.enableGeolocation ?? true, | ||||||
|  |             "Disables/Enables the geolocation button"); | ||||||
| 
 | 
 | ||||||
|         const testParam = QueryParameters.GetQueryParameter("test", "false").data; |         const testParam = QueryParameters.GetQueryParameter("test", "false", | ||||||
|  |             "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").data; | ||||||
|         this.osmConnection = new OsmConnection( |         this.osmConnection = new OsmConnection( | ||||||
|             testParam === "true", |             testParam === "true", | ||||||
|             QueryParameters.GetQueryParameter("oauth_token", undefined), |             QueryParameters.GetQueryParameter("oauth_token", undefined, | ||||||
|  |                 "Used to complete the login"), | ||||||
|             layoutToUse.id, |             layoutToUse.id, | ||||||
|             true |             true | ||||||
|         ); |         ); | ||||||
|  |  | ||||||
|  | @ -42,6 +42,9 @@ export default class DeleteImage extends UIElement { | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     InnerRender(): string { |     InnerRender(): string { | ||||||
|  |         if(!State.state.featureSwitchUserbadge.data){ | ||||||
|  |             return ""; | ||||||
|  |         } | ||||||
| 
 | 
 | ||||||
|         const value = this.tags.data[this.key]; |         const value = this.tags.data[this.key]; | ||||||
|         if (value === undefined || value === "") { |         if (value === undefined || value === "") { | ||||||
|  |  | ||||||
|  | @ -52,6 +52,10 @@ export class ImageUploadFlow extends UIElement { | ||||||
| 
 | 
 | ||||||
|     InnerRender(): string { |     InnerRender(): string { | ||||||
|          |          | ||||||
|  |         if(!State.state.featureSwitchUserbadge.data){ | ||||||
|  |             return ""; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|         const t = Translations.t.image; |         const t = Translations.t.image; | ||||||
|         if (State.state.osmConnection.userDetails === undefined) { |         if (State.state.osmConnection.userDetails === undefined) { | ||||||
|             return ""; // No user details -> logging in is probably disabled or smthing
 |             return ""; // No user details -> logging in is probably disabled or smthing
 | ||||||
|  |  | ||||||
|  | @ -9,25 +9,11 @@ import {SubstitutedTranslation} from "../SpecialVisualizations"; | ||||||
| export default class TagRenderingAnswer extends UIElement { | export default class TagRenderingAnswer extends UIElement { | ||||||
|     private _tags: UIEventSource<any>; |     private _tags: UIEventSource<any>; | ||||||
|     private _configuration: TagRenderingConfig; |     private _configuration: TagRenderingConfig; | ||||||
|     private _content: UIElement; |  | ||||||
| 
 | 
 | ||||||
|     constructor(tags: UIEventSource<any>, configuration: TagRenderingConfig) { |     constructor(tags: UIEventSource<any>, configuration: TagRenderingConfig) { | ||||||
|         super(tags); |         super(tags); | ||||||
|         this._tags = tags; |         this._tags = tags; | ||||||
|         this._configuration = configuration; |         this._configuration = configuration; | ||||||
|         const self = this; |  | ||||||
|         tags.addCallbackAndRun(tags => { |  | ||||||
|             if (tags === undefined) { |  | ||||||
|                 self._content = undefined |  | ||||||
|                 return; |  | ||||||
|             } |  | ||||||
|             const tr = this._configuration.GetRenderValue(tags); |  | ||||||
|             if (tr === undefined) { |  | ||||||
|                 self._content = undefined |  | ||||||
|                 return |  | ||||||
|             } |  | ||||||
|             self._content = new SubstitutedTranslation(tr, self._tags) |  | ||||||
|         }) |  | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     InnerRender(): string { |     InnerRender(): string { | ||||||
|  | @ -36,10 +22,16 @@ export default class TagRenderingAnswer extends UIElement { | ||||||
|                 return ""; |                 return ""; | ||||||
|             } |             } | ||||||
|         } |         } | ||||||
|         if(this._content === undefined){ | 
 | ||||||
|  |         const tags = this._tags.data; | ||||||
|  |         if (tags === undefined) { | ||||||
|             return ""; |             return ""; | ||||||
|         } |         } | ||||||
|         return this._content.Render(); |         const tr = this._configuration.GetRenderValue(tags); | ||||||
|  |         if (tr === undefined) { | ||||||
|  |             return ""; | ||||||
|  |         } | ||||||
|  |         return new SubstitutedTranslation(tr, this._tags).Render(); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
| } | } | ||||||
|  | @ -156,8 +156,8 @@ | ||||||
|             "key": "surveillance:type" |             "key": "surveillance:type" | ||||||
|           }, |           }, | ||||||
|           "render": { |           "render": { | ||||||
|             "en": " Surveills a {surveillance:type}", |             "en": " Surveills a {surveillance:zone}", | ||||||
|             "nl": "Bewaakt een {surveillance:type}" |             "nl": "Bewaakt een {surveillance:zone}" | ||||||
|           }, |           }, | ||||||
|           "mappings": [ |           "mappings": [ | ||||||
|             { |             { | ||||||
|  | @ -193,6 +193,28 @@ | ||||||
|                 "nl": "Bewaakt een ingang" |                 "nl": "Bewaakt een ingang" | ||||||
|               } |               } | ||||||
|             }, |             }, | ||||||
|  |             { | ||||||
|  |               "if": { | ||||||
|  |                 "and": [ | ||||||
|  |                   "surveillance:zone=corridor" | ||||||
|  |                 ] | ||||||
|  |               }, | ||||||
|  |               "then": { | ||||||
|  |                 "en": "Surveills a corridor", | ||||||
|  |                 "nl": "Bewaakt een gang" | ||||||
|  |               } | ||||||
|  |             }, | ||||||
|  |             { | ||||||
|  |               "if": { | ||||||
|  |                 "and": [ | ||||||
|  |                   "surveillance:zone=public_transport_platform" | ||||||
|  |                 ] | ||||||
|  |               }, | ||||||
|  |               "then": { | ||||||
|  |                 "en": "Surveills a public tranport platform", | ||||||
|  |                 "nl": "Bewaakt een perron of bushalte" | ||||||
|  |               } | ||||||
|  |             }, | ||||||
|             { |             { | ||||||
|               "if": { |               "if": { | ||||||
|                 "and": [ |                 "and": [ | ||||||
							
								
								
									
										20
									
								
								index.ts
									
										
									
									
									
								
							
							
						
						
									
										20
									
								
								index.ts
									
										
									
									
									
								
							|  | @ -4,7 +4,6 @@ import {InitUiElements} from "./InitUiElements"; | ||||||
| import {QueryParameters} from "./Logic/Web/QueryParameters"; | import {QueryParameters} from "./Logic/Web/QueryParameters"; | ||||||
| import {UIEventSource} from "./Logic/UIEventSource"; | import {UIEventSource} from "./Logic/UIEventSource"; | ||||||
| import * as $ from "jquery"; | import * as $ from "jquery"; | ||||||
| import SharedLayers from "./Customizations/SharedLayers"; |  | ||||||
| import LayoutConfig from "./Customizations/JSON/LayoutConfig"; | import LayoutConfig from "./Customizations/JSON/LayoutConfig"; | ||||||
| 
 | 
 | ||||||
| let defaultLayout = "bookcases" | let defaultLayout = "bookcases" | ||||||
|  | @ -54,23 +53,7 @@ if (path !== "index.html" && path !== "") { | ||||||
|     defaultLayout = path.substr(0, path.length - 5); |     defaultLayout = path.substr(0, path.length - 5); | ||||||
|     console.log("Using layout", defaultLayout); |     console.log("Using layout", defaultLayout); | ||||||
| } | } | ||||||
| 
 | defaultLayout = QueryParameters.GetQueryParameter("layout", defaultLayout,"The layout to load into MapComplete").data; | ||||||
| // Run over all questsets. If a part of the URL matches a searched-for part in the layout, it'll take that as the default
 |  | ||||||
| for (const k in AllKnownLayouts.allSets) { |  | ||||||
|     const layout : LayoutConfig= AllKnownLayouts.allSets[k]; |  | ||||||
|     const possibleParts = (layout.locationContains ?? []); |  | ||||||
|     for (const locationMatch of possibleParts) { |  | ||||||
|         if (locationMatch === "") { |  | ||||||
|             continue |  | ||||||
|         } |  | ||||||
|         if (window.location.href.toLowerCase().indexOf(locationMatch.toLowerCase()) >= 0) { |  | ||||||
|             defaultLayout = layout.name; |  | ||||||
|         } |  | ||||||
|     } |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| defaultLayout = QueryParameters.GetQueryParameter("layout", defaultLayout).data; |  | ||||||
| 
 |  | ||||||
| let layoutToUse: LayoutConfig = AllKnownLayouts.allSets[defaultLayout.toLowerCase()] ?? AllKnownLayouts["all"]; | let layoutToUse: LayoutConfig = AllKnownLayouts.allSets[defaultLayout.toLowerCase()] ?? AllKnownLayouts["all"]; | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
|  | @ -118,3 +101,4 @@ if (layoutFromBase64.startsWith("wiki:")) { | ||||||
|     InitUiElements.InitAll(layoutToUse, layoutFromBase64, testing, defaultLayout); |     InitUiElements.InitAll(layoutToUse, layoutFromBase64, testing, defaultLayout); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | // console.log(QueryParameters.GenerateQueryParameterDocs())
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue