forked from MapComplete/MapComplete
		
	Various bug fixes, add layer selection and background selection as parameter to the URL (fix #86, fix #84)
This commit is contained in:
		
							parent
							
								
									e35c85fc55
								
							
						
					
					
						commit
						97a69ff903
					
				
					 14 changed files with 111 additions and 25 deletions
				
			
		|  | @ -178,7 +178,6 @@ export class Widths extends LayerDefinition { | |||
| 
 | ||||
|         this.elementsToShow = [ | ||||
|             new TagRenderingOptions({ | ||||
|                 question: "Mogen auto's hier parkeren?", | ||||
|                 mappings: [ | ||||
|                     { | ||||
|                         k: this._bothSideParking, | ||||
|  |  | |||
|  | @ -40,6 +40,7 @@ export class Layout { | |||
|      * This number influences this | ||||
|      */ | ||||
|     public widenFactor: number = 0.07; | ||||
|     public defaultBackground: string = "osm"; | ||||
| 
 | ||||
|     /** | ||||
|      *  | ||||
|  |  | |||
|  | @ -91,6 +91,8 @@ export class StreetWidth extends Layout{ | |||
|         this.enableUserBadge = false; | ||||
|         this.enableAdd = false; | ||||
|         this.hideFromOverview = true; | ||||
|         this.enableMoreQuests = false; | ||||
|         this.enableShareScreen = false; | ||||
| 
 | ||||
|     } | ||||
| } | ||||
|  | @ -5,13 +5,13 @@ import {TagRenderingOptions} from "../../TagRenderingOptions"; | |||
| 
 | ||||
| export default class BikeStationStand extends TagRenderingOptions { | ||||
|     constructor() { | ||||
|         const to = Translations | ||||
|         const to = Translations.t.cyclofix.station.stand; | ||||
|         super({ | ||||
|             priority: 10, | ||||
|             question: "Does this bike station have a hook to suspend your bike with or a stand to elevate it?", | ||||
|             question: to.question, | ||||
|             mappings: [ | ||||
|                 {k: new Tag("service:bicycle:stand", "yes"), txt: "There is a hook or stand"}, | ||||
|                 {k: new Tag("service:bicycle:stand", "no"), txt: "There is no hook or stand"}, | ||||
|                 {k: new Tag("service:bicycle:stand", "yes"), txt: to.yes}, | ||||
|                 {k: new Tag("service:bicycle:stand", "no"), txt: to.no}, | ||||
|             ] | ||||
|         }); | ||||
|     } | ||||
|  |  | |||
|  | @ -26,6 +26,7 @@ import {CustomLayout} from "./Logic/CustomLayers"; | |||
| import {Preset} from "./Customizations/LayerDefinition"; | ||||
| import {VariableUiElement} from "./UI/Base/VariableUIElement"; | ||||
| import {LayerUpdater} from "./Logic/LayerUpdater"; | ||||
| import {QueryParameters} from "./Logic/QueryParameters"; | ||||
| 
 | ||||
| export class InitUiElements { | ||||
| 
 | ||||
|  | @ -136,7 +137,7 @@ export class InitUiElements { | |||
|     } | ||||
|      | ||||
|     static InitBaseMap(){ | ||||
|         State.state.bm = new Basemap("leafletDiv", State.state.locationControl, new VariableUiElement( | ||||
|         const bm = new Basemap("leafletDiv", State.state.locationControl, new VariableUiElement( | ||||
|             State.state.locationControl.map((location) => { | ||||
|                 const mapComplete = `<a href='https://github.com/pietervdvn/MapComplete' target='_blank'>Mapcomple ${State.vNumber}</a>  <a href='https://github.com/pietervdvn/MapComplete/issues' target='_blank'><img src='./assets/bug.svg' alt='Report bug'  class='small-userbadge-icon'></a>`; | ||||
|                 let editHere = ""; | ||||
|  | @ -150,7 +151,23 @@ export class InitUiElements { | |||
| 
 | ||||
|             }) | ||||
|         )); | ||||
|         State.state.bm = bm; | ||||
|         State.state.layerUpdater = new LayerUpdater(State.state); | ||||
|         const queryParam = QueryParameters.GetQueryParameter("background", State.state.layoutToUse.data.defaultBackground); | ||||
|         const queryParamMapped: UIEventSource<{ id: string, name: string, layer: any }> = | ||||
|             queryParam.map<{ id: string, name: string, layer: any }>((id) => { | ||||
|                 for (const layer of BaseLayers.baseLayers) { | ||||
|                     if (layer.id === id) { | ||||
|                         return layer; | ||||
|                     } | ||||
|                 } | ||||
|                 return undefined; | ||||
|             }, [], (layerInfo) => { | ||||
|                 return layerInfo.id | ||||
|             }); | ||||
| 
 | ||||
|         queryParamMapped.syncWith(bm.CurrentLayer); | ||||
| 
 | ||||
|     } | ||||
| 
 | ||||
| 
 | ||||
|  | @ -194,7 +211,12 @@ export class InitUiElements { | |||
| 
 | ||||
|             const flayer: FilteredLayer = FilteredLayer.fromDefinition(layer, generateInfo); | ||||
|             flayers.push(flayer); | ||||
|             flayer.isDisplayed.setData(true) | ||||
| 
 | ||||
|             QueryParameters.GetQueryParameter("layer-" + layer.id, "true") | ||||
|                 .map<boolean>((str) => str !== "false", [], (b) => b.toString()) | ||||
|                 .syncWith( | ||||
|                     flayer.isDisplayed | ||||
|                 ) | ||||
|         } | ||||
| 
 | ||||
|         State.state.filteredLayers.setData(flayers); | ||||
|  |  | |||
|  | @ -3,6 +3,7 @@ import {UIEventSource} from "../../UI/UIEventSource"; | |||
| import {UIElement} from "../../UI/UIElement"; | ||||
| import {State} from "../../State"; | ||||
| import {Utils} from "../../Utils"; | ||||
| import {Basemap} from "./Basemap"; | ||||
| 
 | ||||
| export class GeoLocationHandler extends UIElement { | ||||
| 
 | ||||
|  | @ -38,7 +39,8 @@ export class GeoLocationHandler extends UIElement { | |||
| 
 | ||||
|         } | ||||
| 
 | ||||
|         const map = State.state.bm.map; | ||||
|         const bm : Basemap = State.state.bm; | ||||
|         const map = bm.map; | ||||
|         map.on('accuratepositionprogress', onAccuratePositionProgress); | ||||
|         map.on('accuratepositionfound', onAccuratePositionFound); | ||||
|         map.on('accuratepositionerror', onAccuratePositionError); | ||||
|  | @ -53,7 +55,7 @@ export class GeoLocationHandler extends UIElement { | |||
| 
 | ||||
|         State.state.currentGPSLocation.addCallback((location) => { | ||||
|             const newMarker = L.marker(location.latlng, {icon: icon}); | ||||
|             newMarker.addTo(map.map); | ||||
|             newMarker.addTo(map); | ||||
| 
 | ||||
|             if (self._marker !== undefined) { | ||||
|                 map.removeLayer(self._marker); | ||||
|  |  | |||
							
								
								
									
										2
									
								
								State.ts
									
										
									
									
									
								
							
							
						
						
									
										2
									
								
								State.ts
									
										
									
									
									
								
							|  | @ -24,7 +24,7 @@ export class State { | |||
|     // The singleton of the global state
 | ||||
|     public static state: State; | ||||
|      | ||||
|     public static vNumber = "0.0.2"; | ||||
|     public static vNumber = "0.0.3"; | ||||
| 
 | ||||
|     public static runningFromConsole: boolean = false;  | ||||
| 
 | ||||
|  |  | |||
|  | @ -10,6 +10,9 @@ import {VerticalCombine} from "./Base/VerticalCombine"; | |||
| import {QueryParameters} from "../Logic/QueryParameters"; | ||||
| import {Img} from "./Img"; | ||||
| import {State} from "../State"; | ||||
| import {Basemap} from "../Logic/Leaflet/Basemap"; | ||||
| import {FilteredLayer} from "../Logic/FilteredLayer"; | ||||
| import {Utils} from "../Utils"; | ||||
| 
 | ||||
| export class ShareScreen extends UIElement { | ||||
| 
 | ||||
|  | @ -46,6 +49,50 @@ export class ShareScreen extends UIElement { | |||
|         }, [currentLocation])); | ||||
| 
 | ||||
| 
 | ||||
|         const currentLayer: UIEventSource<{ id: string, name: string, layer: any }> = (State.state.bm as Basemap).CurrentLayer; | ||||
|         const currentBackground = new VariableUiElement( | ||||
|             currentLayer.map( | ||||
|                 (layer) => `Include the current background choice <b>${layer.name}</b>` | ||||
|             ) | ||||
|         ); | ||||
|         const includeCurrentBackground = new CheckBox( | ||||
|             new Combine([Img.checkmark, currentBackground]), | ||||
|             new Combine([Img.no_checkmark, currentBackground]), | ||||
|             true | ||||
|         ) | ||||
|         optionCheckboxes.push(includeCurrentBackground); | ||||
|         optionParts.push(includeCurrentBackground.isEnabled.map((includeBG) => { | ||||
|             if (includeBG) { | ||||
|                 return "background=" + currentLayer.data.id | ||||
|             } else { | ||||
|                 return null | ||||
|             } | ||||
|         }, [currentLayer])); | ||||
| 
 | ||||
| 
 | ||||
|         const includeLayerChoices = new CheckBox( | ||||
|             new Combine([Img.checkmark, "Include the current layer choices"]), | ||||
|             new Combine([Img.no_checkmark, "Include the current layer choices"]), | ||||
|             true | ||||
|         ) | ||||
|         optionCheckboxes.push(includeLayerChoices); | ||||
| 
 | ||||
|         function fLayerToParam(flayer: FilteredLayer){ | ||||
|             if(flayer.isDisplayed.data){ | ||||
|                 return null; // Being displayed is the default
 | ||||
|             } | ||||
|             return "layer-"+flayer.layerDef.id+"="+flayer.isDisplayed.data | ||||
|         } | ||||
|          | ||||
|         optionParts.push(includeLayerChoices.isEnabled.map((includeLayerSelection) => { | ||||
|             if (includeLayerSelection) { | ||||
|                 return Utils.NoNull(State.state.filteredLayers.data.map(fLayerToParam)).join("&") | ||||
|             } else { | ||||
|                 return null | ||||
|             } | ||||
|         }, State.state.filteredLayers.data.map((flayer) => flayer.isDisplayed))); | ||||
| 
 | ||||
| 
 | ||||
|         const switches = [{urlName: "fs-userbadge", human: "Enable the login-button"}, | ||||
|             {urlName: "fs-search", human: "Enable search bar"}, | ||||
|             {urlName: "fs-welcome-message", human: "Enable the welcome message"}, | ||||
|  | @ -79,13 +126,7 @@ export class ShareScreen extends UIElement { | |||
| 
 | ||||
|             let literalText = "https://pietervdvn.github.io/MapComplete/" + layout.name + ".html" | ||||
| 
 | ||||
|             const parts = []; | ||||
|             for (const part of optionParts) { | ||||
|                 if (part.data === null) { | ||||
|                     continue; | ||||
|                 } | ||||
|                 parts.push(part.data); | ||||
|             } | ||||
|             const parts = Utils.NoNull(optionParts.map((eventSource) => eventSource.data)); | ||||
| 
 | ||||
|             if (parts.length === 0) { | ||||
|                 return literalText; | ||||
|  |  | |||
|  | @ -45,9 +45,14 @@ export class UIEventSource<T>{ | |||
|     } | ||||
|      | ||||
|     public map<J>(f: ((T) => J), | ||||
|                   extraSources: UIEventSource<any>[] = []): UIEventSource<J> { | ||||
|                   extraSources: UIEventSource<any>[] = [], | ||||
|                   g: ((J) => T) = undefined ): UIEventSource<J> { | ||||
|         const self = this; | ||||
|          | ||||
|         const newSource = new UIEventSource<J>( | ||||
|             f(this.data) | ||||
|         ); | ||||
|          | ||||
|         const update = function () { | ||||
|             newSource.setData(f(self.data)); | ||||
|             newSource.ping(); | ||||
|  | @ -57,9 +62,12 @@ export class UIEventSource<T>{ | |||
|         for (const extraSource of extraSources) { | ||||
|             extraSource.addCallback(update); | ||||
|         } | ||||
|         const newSource = new UIEventSource<J>( | ||||
|             f(this.data) | ||||
|         ); | ||||
|        | ||||
|         if(g !== undefined) { | ||||
|             newSource.addCallback((latest) => { | ||||
|                 self.setData((g(latest))); | ||||
|             }) | ||||
|         } | ||||
|          | ||||
| 
 | ||||
|         return newSource; | ||||
|  |  | |||
							
								
								
									
										13
									
								
								Utils.ts
									
										
									
									
									
								
							
							
						
						
									
										13
									
								
								Utils.ts
									
										
									
									
									
								
							|  | @ -25,7 +25,7 @@ export class Utils { | |||
|     } | ||||
| 
 | ||||
|     static DoEvery(millis: number, f: (() => void)) { | ||||
|         if(State.runningFromConsole){ | ||||
|         if (State.runningFromConsole) { | ||||
|             return; | ||||
|         } | ||||
|         window.setTimeout( | ||||
|  | @ -36,6 +36,17 @@ export class Utils { | |||
|             , millis) | ||||
|     } | ||||
| 
 | ||||
|     public static NoNull<T>(array: T[]): T[] { | ||||
|         const ls: T[] = []; | ||||
|         for (const t of array) { | ||||
|             if (t === undefined || t === null) { | ||||
|                 continue; | ||||
|             } | ||||
|             ls.push(t); | ||||
|         } | ||||
|         return ls; | ||||
|     } | ||||
| 
 | ||||
|     public static CreateLanguagePicker(label: string | UIElement = "") { | ||||
| 
 | ||||
|         return new DropDown(label, State.state.layoutToUse.data.supportedLanguages.map(lang => { | ||||
|  |  | |||
										
											Binary file not shown.
										
									
								
							| Before Width: | Height: | Size: 3.7 KiB | 
										
											Binary file not shown.
										
									
								
							| Before Width: | Height: | Size: 3.7 KiB | 
										
											Binary file not shown.
										
									
								
							| Before Width: | Height: | Size: 3.7 KiB | 
							
								
								
									
										2
									
								
								index.ts
									
										
									
									
									
								
							
							
						
						
									
										2
									
								
								index.ts
									
										
									
									
									
								
							|  | @ -40,7 +40,7 @@ if (location.hostname === "localhost" || location.hostname === "127.0.0.1") { | |||
| 
 | ||||
| // ----------------- SELECT THE RIGHT QUESTSET -----------------
 | ||||
| 
 | ||||
| let defaultLayout = "buurtnatuur" | ||||
| let defaultLayout = "bookcases" | ||||
| 
 | ||||
| const path = window.location.pathname.split("/").slice(-1)[0]; | ||||
| if (path !== "index.html") { | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue