forked from MapComplete/MapComplete
		
	Search: close dialog when appropriate, move special layer logic to themeViewState
This commit is contained in:
		
							parent
							
								
									902a479e3b
								
							
						
					
					
						commit
						05e5a63a12
					
				
					 11 changed files with 165 additions and 81 deletions
				
			
		|  | @ -26,6 +26,7 @@ export default class Constants { | |||
|         "last_click", | ||||
|         "favourite", | ||||
|         "summary", | ||||
|         "search" | ||||
|     ] as const | ||||
|     /** | ||||
|      * Special layers which are not included in a theme by default | ||||
|  | @ -39,7 +40,6 @@ export default class Constants { | |||
|         "usersettings", | ||||
|         "icons", | ||||
|         "filters", | ||||
|         "search" | ||||
|     ] as const | ||||
|     /** | ||||
|      * Layer IDs of layers which have special properties through built-in hooks | ||||
|  |  | |||
|  | @ -58,7 +58,7 @@ import { GeolocationControlState } from "../UI/BigComponents/GeolocationControl" | |||
| import Zoomcontrol from "../UI/Zoomcontrol" | ||||
| import { | ||||
|     SummaryTileSource, | ||||
|     SummaryTileSourceRewriter, | ||||
|     SummaryTileSourceRewriter | ||||
| } from "../Logic/FeatureSource/TiledFeatureSource/SummaryTileSource" | ||||
| import summaryLayer from "../assets/generated/layers/summary.json" | ||||
| import last_click_layerconfig from "../assets/generated/layers/last_click.json" | ||||
|  | @ -69,6 +69,7 @@ import { GeoOperations } from "../Logic/GeoOperations" | |||
| import { CombinedFetcher } from "../Logic/Web/NearbyImagesSearch" | ||||
| import { GeocodeResult, GeocodingUtils } from "../Logic/Search/GeocodingProvider" | ||||
| import SearchState from "../Logic/State/SearchState" | ||||
| import { ShowDataLayerOptions } from "../UI/Map/ShowDataLayerOptions" | ||||
| 
 | ||||
| /** | ||||
|  * | ||||
|  | @ -175,7 +176,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|                 "oauth_token", | ||||
|                 undefined, | ||||
|                 "Used to complete the login" | ||||
|             ), | ||||
|             ) | ||||
|         }) | ||||
|         this.userRelatedState = new UserRelatedState( | ||||
|             this.osmConnection, | ||||
|  | @ -254,8 +255,8 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|                         bbox.asGeoJson({ | ||||
|                             zoom: this.mapProperties.zoom.data, | ||||
|                             ...this.mapProperties.location.data, | ||||
|                             id: "current_view_" + currentViewIndex, | ||||
|                         }), | ||||
|                             id: "current_view_" + currentViewIndex | ||||
|                         }) | ||||
|                     ] | ||||
|                 }) | ||||
|             ) | ||||
|  | @ -272,7 +273,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|                     featurePropertiesStore: this.featureProperties, | ||||
|                     osmConnection: this.osmConnection, | ||||
|                     historicalUserLocations: this.geolocation.historicalUserLocations, | ||||
|                     featureSwitches: this.featureSwitches, | ||||
|                     featureSwitches: this.featureSwitches | ||||
|                 }, | ||||
|                 layout?.isLeftRightSensitive() ?? false, | ||||
|                 (e, extraMsg) => this.reportError(e, extraMsg) | ||||
|  | @ -300,7 +301,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|                             "leftover features, such as", | ||||
|                             features[0].properties | ||||
|                         ) | ||||
|                     }, | ||||
|                     } | ||||
|                 } | ||||
|             ) | ||||
|             this.perLayer = perLayer.perLayer | ||||
|  | @ -356,7 +357,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|             { | ||||
|                 currentZoom: this.mapProperties.zoom, | ||||
|                 layerState: this.layerState, | ||||
|                 bounds: this.visualFeedbackViewportBounds, | ||||
|                 bounds: this.visualFeedbackViewportBounds | ||||
|             } | ||||
|         ) | ||||
|         this.hasDataInView = new NoElementsInViewDetector(this).hasFeatureInView | ||||
|  | @ -453,7 +454,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|                 doShowLayer, | ||||
|                 metaTags: this.userRelatedState.preferencesAsTags, | ||||
|                 selectedElement: this.selectedElement, | ||||
|                 fetchStore: (id) => this.featureProperties.getStore(id), | ||||
|                 fetchStore: (id) => this.featureProperties.getStore(id) | ||||
|             }) | ||||
|         }) | ||||
|         return filteringFeatureSource | ||||
|  | @ -480,7 +481,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|             doShowLayer: flayerGps.isDisplayed, | ||||
|             layer: flayerGps.layerDef, | ||||
|             metaTags: this.userRelatedState.preferencesAsTags, | ||||
|             selectedElement: this.selectedElement, | ||||
|             selectedElement: this.selectedElement | ||||
|         }) | ||||
|     } | ||||
| 
 | ||||
|  | @ -554,16 +555,16 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|                 this.previewedImage.setData(undefined) | ||||
|                 return | ||||
|             } | ||||
|             if(this.selectedElement.data){ | ||||
|             if (this.selectedElement.data) { | ||||
|                 this.selectedElement.setData(undefined) | ||||
|                 return | ||||
|             } | ||||
|             if (this.searchState.showSearchDrawer.data){ | ||||
|             if (this.searchState.showSearchDrawer.data) { | ||||
|                 this.searchState.showSearchDrawer.set(false) | ||||
|                 return | ||||
|             } | ||||
|             if (this.guistate.closeAll()){ | ||||
|                return | ||||
|             if (this.guistate.closeAll()) { | ||||
|                 return | ||||
|             } | ||||
|             Zoomcontrol.resetzoom() | ||||
|             this.focusOnMap() | ||||
|  | @ -573,10 +574,11 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|             this.guistate.pageStates.favourites.set(true) | ||||
|         }) | ||||
| 
 | ||||
| 
 | ||||
|         Hotkeys.RegisterHotkey( | ||||
|             { | ||||
|                 nomod: " ", | ||||
|                 onUp: true, | ||||
|                 onUp: true | ||||
|             }, | ||||
|             docs.selectItem, | ||||
|             () => { | ||||
|  | @ -586,7 +588,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|                 if (this.guistate.isSomethingOpen() || this.previewedImage.data !== undefined) { | ||||
|                     return | ||||
|                 } | ||||
|                 if(document.activeElement.tagName === "button" || document.activeElement.tagName === "input"){ | ||||
|                 if (document.activeElement.tagName === "button" || document.activeElement.tagName === "input") { | ||||
|                     return | ||||
|                 } | ||||
|                 this.selectClosestAtCenter(0) | ||||
|  | @ -605,7 +607,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|             Hotkeys.RegisterHotkey( | ||||
|                 { | ||||
|                     nomod: "" + i, | ||||
|                     onUp: true, | ||||
|                     onUp: true | ||||
|                 }, | ||||
|                 doc, | ||||
|                 () => this.selectClosestAtCenter(i - 1) | ||||
|  | @ -624,7 +626,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|             } | ||||
|             Hotkeys.RegisterHotkey( | ||||
|                 { | ||||
|                     nomod: "b", | ||||
|                     nomod: "b" | ||||
|                 }, | ||||
|                 docs.openLayersPanel, | ||||
|                 () => { | ||||
|  | @ -635,7 +637,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|             ) | ||||
|             Hotkeys.RegisterHotkey( | ||||
|                 { | ||||
|                     nomod: "s", | ||||
|                     nomod: "s" | ||||
|                 }, | ||||
|                 Translations.t.hotkeyDocumentation.openFilterPanel, | ||||
|                 () => { | ||||
|  | @ -713,7 +715,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
| 
 | ||||
|         Hotkeys.RegisterHotkey( | ||||
|             { | ||||
|                 shift: "T", | ||||
|                 shift: "T" | ||||
|             }, | ||||
|             Translations.t.hotkeyDocumentation.translationMode, | ||||
|             () => { | ||||
|  | @ -750,7 +752,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|             this.mapProperties.zoom.map((z) => Math.max(Math.floor(z), 0)), | ||||
|             this.mapProperties, | ||||
|             { | ||||
|                 isActive: this.mapProperties.zoom.map((z) => z < maxzoom), | ||||
|                 isActive: this.mapProperties.zoom.map((z) => z < maxzoom) | ||||
|             } | ||||
|         ) | ||||
| 
 | ||||
|  | @ -783,6 +785,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|             favourite: this.favourites, | ||||
|             summary: this.featureSummary, | ||||
|             last_click: this.lastClickObject, | ||||
|             search: this.searchState.locationResults | ||||
|         } | ||||
| 
 | ||||
|         this.closestFeatures.registerSource(specialLayers.favourite, "favourite") | ||||
|  | @ -832,20 +835,28 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|             } | ||||
| 
 | ||||
|             this.featureProperties.trackFeatureSource(features) | ||||
|             new ShowDataLayer(this.map, { | ||||
|             const options: ShowDataLayerOptions & { layer: LayerConfig } = { | ||||
|                 features, | ||||
|                 doShowLayer: flayer.isDisplayed, | ||||
|                 layer: flayer.layerDef, | ||||
|                 metaTags: this.userRelatedState.preferencesAsTags, | ||||
|                 selectedElement: this.selectedElement, | ||||
|             }) | ||||
|                 selectedElement: this.selectedElement | ||||
| 
 | ||||
|             } | ||||
|             if (flayer.layerDef.id === "search") { | ||||
|                 options.onClick = (feature) => { | ||||
|                     this.searchState.clickedOnMap(feature) | ||||
|                 } | ||||
|                 delete options.selectedElement | ||||
|             } | ||||
|             new ShowDataLayer(this.map, options) | ||||
|         }) | ||||
|         const summaryLayerConfig = new LayerConfig(<LayerConfigJson>summaryLayer, "summaryLayer") | ||||
|         new ShowDataLayer(this.map, { | ||||
|             features: specialLayers.summary, | ||||
|             layer: summaryLayerConfig, | ||||
|             // doShowLayer: this.mapProperties.zoom.map((z) => z < maxzoom),
 | ||||
|             selectedElement: this.selectedElement, | ||||
|             selectedElement: this.selectedElement | ||||
|         }) | ||||
| 
 | ||||
|         const lastClickLayerConfig = new LayerConfig( | ||||
|  | @ -856,14 +867,14 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|             lastClickLayerConfig.isShown === undefined | ||||
|                 ? specialLayers.last_click | ||||
|                 : specialLayers.last_click.features.mapD((fs) => | ||||
|                       fs.filter((f) => { | ||||
|                           const matches = lastClickLayerConfig.isShown.matchesProperties( | ||||
|                               f.properties | ||||
|                           ) | ||||
|                           console.debug("LastClick ", f, "matches", matches) | ||||
|                           return matches | ||||
|                       }) | ||||
|                   ) | ||||
|                     fs.filter((f) => { | ||||
|                         const matches = lastClickLayerConfig.isShown.matchesProperties( | ||||
|                             f.properties | ||||
|                         ) | ||||
|                         console.debug("LastClick ", f, "matches", matches) | ||||
|                         return matches | ||||
|                     }) | ||||
|                 ) | ||||
|         new ShowDataLayer(this.map, { | ||||
|             features: new StaticFeatureSource(lastClickFiltered), | ||||
|             layer: lastClickLayerConfig, | ||||
|  | @ -874,9 +885,9 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|                 } | ||||
|                 this.map.data.flyTo({ | ||||
|                     zoom: Constants.minZoomLevelToAddNewPoint, | ||||
|                     center: GeoOperations.centerpointCoordinates(feature), | ||||
|                     center: GeoOperations.centerpointCoordinates(feature) | ||||
|                 }) | ||||
|             }, | ||||
|             } | ||||
|         }) | ||||
|     } | ||||
| 
 | ||||
|  | @ -901,15 +912,24 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|             }) | ||||
|         }) | ||||
| 
 | ||||
|         // Add the selected element to the recently visited history
 | ||||
|         this.selectedElement.addCallbackD(selected => { | ||||
|             const [osm_type, osm_id] = selected.properties.id.split("/") | ||||
|             const [lon, lat]  = GeoOperations.centerpointCoordinates(selected) | ||||
|             const [lon, lat] = GeoOperations.centerpointCoordinates(selected) | ||||
|             const layer = this.layout.getMatchingLayer(selected.properties) | ||||
|             const r = <GeocodeResult> { | ||||
| 
 | ||||
|             const nameOptions = [ | ||||
|                 selected?.properties?.name, | ||||
|                 selected?.properties?.alt_name, selected?.properties?.local_name, | ||||
|                 layer?.title.GetRenderValue(selected?.properties ?? {}).txt, | ||||
|                 selected.properties.display_name, | ||||
|                 selected.properties.id | ||||
|             ] | ||||
|             const r = <GeocodeResult>{ | ||||
|                 feature: selected, | ||||
|                 display_name: selected.properties.name ?? selected.properties.alt_name ?? selected.properties.local_name ?? layer.title.GetRenderValue(selected.properties ?? {}).txt , | ||||
|                 display_name: nameOptions.find(opt => opt !== undefined), | ||||
|                 osm_id, osm_type, | ||||
|                 lon, lat, | ||||
|                 lon, lat | ||||
|             } | ||||
|             this.userRelatedState.recentlyVisitedSearch.add(r) | ||||
|         }) | ||||
|  | @ -937,7 +957,7 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|     /** | ||||
|      * Searches the appropriate layer - will first try if a special layer matches; if not, a normal layer will be used by delegating to the layout | ||||
|      */ | ||||
|     public getMatchingLayer(properties: Record<string, string>){ | ||||
|     public getMatchingLayer(properties: Record<string, string>) { | ||||
| 
 | ||||
|         const id = properties.id | ||||
| 
 | ||||
|  | @ -961,8 +981,8 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|         return this.layout.getMatchingLayer(properties) | ||||
|     } | ||||
| 
 | ||||
|     public async reportError(message: string | Error | XMLHttpRequest, extramessage:string = "") { | ||||
|         if(Utils.runningFromConsole){ | ||||
|     public async reportError(message: string | Error | XMLHttpRequest, extramessage: string = "") { | ||||
|         if (Utils.runningFromConsole) { | ||||
|             console.error("Got (in themeViewSTate.reportError):", message, extramessage) | ||||
|             return | ||||
|         } | ||||
|  | @ -1014,8 +1034,8 @@ export default class ThemeViewState implements SpecialVisualizationState { | |||
|                     userid: this.osmConnection.userDetails.data?.uid, | ||||
|                     pendingChanges: this.changes.pendingChanges.data, | ||||
|                     previousChanges: this.changes.allChanges.data, | ||||
|                     changeRewrites: Utils.MapToObj(this.changes._changesetHandler._remappings), | ||||
|                 }), | ||||
|                     changeRewrites: Utils.MapToObj(this.changes._changesetHandler._remappings) | ||||
|                 }) | ||||
|             }) | ||||
|         } catch (e) { | ||||
|             console.error("Could not upload an error report") | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue