forked from MapComplete/MapComplete
		
	Small refactoring of search
This commit is contained in:
		
							parent
							
								
									fc3a043795
								
							
						
					
					
						commit
						14956e229c
					
				
					 2 changed files with 33 additions and 35 deletions
				
			
		|  | @ -1,23 +1,22 @@ | |||
| import State from "../../State"; | ||||
| import {Utils} from "../../Utils"; | ||||
| import {BBox} from "../BBox"; | ||||
| 
 | ||||
| export interface GeoCodeResult { | ||||
|     display_name: string, | ||||
|     lat: number, lon: number, boundingbox: number[], | ||||
|     osm_type: string, osm_id: string | ||||
| } | ||||
| 
 | ||||
| export class Geocoding { | ||||
| 
 | ||||
|     private static readonly host = "https://nominatim.openstreetmap.org/search?"; | ||||
| 
 | ||||
|     static Search(query: string, | ||||
|                   handleResult: ((places: { | ||||
|                       display_name: string, lat: number, lon: number, boundingbox: number[], | ||||
|                       osm_type: string, osm_id: string | ||||
|                   }[]) => void), | ||||
|                   onFail: (() => void)) { | ||||
|         const b = State.state.currentBounds.data; | ||||
|     static async Search(query: string): Promise<GeoCodeResult[]> { | ||||
|         const b = State?.state?.currentBounds?.data ?? BBox.global; | ||||
|         const url = Geocoding.host + "format=json&limit=1&viewbox=" + | ||||
|             `${b.getEast()},${b.getNorth()},${b.getWest()},${b.getSouth()}` + | ||||
|             "&accept-language=nl&q=" + query; | ||||
|         Utils.downloadJson( | ||||
|             url) | ||||
|             .then(handleResult) | ||||
|             .catch(onFail); | ||||
|        return Utils.downloadJson(url) | ||||
|     } | ||||
| } | ||||
|  |  | |||
|  | @ -44,38 +44,37 @@ export default class SearchAndGo extends Combine { | |||
|         ); | ||||
| 
 | ||||
|         // Triggered by 'enter' or onclick
 | ||||
|         function runSearch() { | ||||
|         async function runSearch() { | ||||
|             const searchString = searchField.GetValue().data; | ||||
|             if (searchString === undefined || searchString === "") { | ||||
|                 return; | ||||
|             } | ||||
|             searchField.GetValue().setData(""); | ||||
|             placeholder.setData(Translations.t.general.search.searching); | ||||
|             Geocoding.Search( | ||||
|                 searchString, | ||||
|                 (result) => { | ||||
|                     console.log("Search result", result); | ||||
|                     if (result.length == 0) { | ||||
|                         placeholder.setData(Translations.t.general.search.nothing); | ||||
|                         return; | ||||
|                     } | ||||
|             try { | ||||
| 
 | ||||
|                     const poi = result[0]; | ||||
|                     const bb = poi.boundingbox; | ||||
|                     const bounds: [[number, number], [number, number]] = [ | ||||
|                         [bb[0], bb[2]], | ||||
|                         [bb[1], bb[3]], | ||||
|                     ]; | ||||
|                     state.selectedElement.setData(undefined); | ||||
|                     Hash.hash.setData(poi.osm_type + "/" + poi.osm_id); | ||||
|                     state.leafletMap.data.fitBounds(bounds); | ||||
|                     placeholder.setData(Translations.t.general.search.search); | ||||
|                 }, | ||||
|                 () => { | ||||
|                     searchField.GetValue().setData(""); | ||||
|                     placeholder.setData(Translations.t.general.search.error); | ||||
|                 const result = await Geocoding.Search(searchString); | ||||
| 
 | ||||
|                 console.log("Search result", result); | ||||
|                 if (result.length == 0) { | ||||
|                     placeholder.setData(Translations.t.general.search.nothing); | ||||
|                     return; | ||||
|                 } | ||||
|             ); | ||||
| 
 | ||||
|                 const poi = result[0]; | ||||
|                 const bb = poi.boundingbox; | ||||
|                 const bounds: [[number, number], [number, number]] = [ | ||||
|                     [bb[0], bb[2]], | ||||
|                     [bb[1], bb[3]], | ||||
|                 ]; | ||||
|                 state.selectedElement.setData(undefined); | ||||
|                 Hash.hash.setData(poi.osm_type + "/" + poi.osm_id); | ||||
|                 state.leafletMap.data.fitBounds(bounds); | ||||
|                 placeholder.setData(Translations.t.general.search.search) | ||||
|             }catch(e){ | ||||
|                 searchField.GetValue().setData(""); | ||||
|                 placeholder.setData(Translations.t.general.search.error); | ||||
|             } | ||||
|         } | ||||
| 
 | ||||
|         searchField.enterPressed.addCallback(runSearch); | ||||
|  |  | |||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue