| 
									
										
										
										
											2024-08-21 14:06:42 +02:00
										 |  |  | import { Store, UIEventSource } from "../UIEventSource" | 
					
						
							|  |  |  | import { Feature } from "geojson" | 
					
						
							|  |  |  | import { OsmConnection } from "../Osm/OsmConnection" | 
					
						
							|  |  |  | import { GeoCodeResult } from "./GeocodingProvider" | 
					
						
							|  |  |  | import { GeoOperations } from "../GeoOperations" | 
					
						
							|  |  |  | import LayoutConfig from "../../Models/ThemeConfig/LayoutConfig" | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export class RecentSearch { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-22 02:54:46 +02:00
										 |  |  |     private readonly _seenThisSession: UIEventSource<GeoCodeResult[]> | 
					
						
							|  |  |  |     public readonly seenThisSession: Store<GeoCodeResult[]> | 
					
						
							| 
									
										
										
										
											2024-08-21 14:06:42 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     constructor(state: { layout: LayoutConfig, osmConnection: OsmConnection, selectedElement: Store<Feature> }) { | 
					
						
							| 
									
										
										
										
											2024-08-23 02:16:24 +02:00
										 |  |  |         const prefs = state.osmConnection.preferencesHandler.GetLongPreference("previous-searches") | 
					
						
							|  |  |  |         prefs.addCallbackAndRunD(prev => console.trace("Previous searches are:", prev)) | 
					
						
							|  |  |  |         prefs.set(null) | 
					
						
							| 
									
										
										
										
											2024-08-22 02:54:46 +02:00
										 |  |  |         this._seenThisSession =  new UIEventSource<GeoCodeResult[]>([])//UIEventSource.asObject<GeoCodeResult[]>(prefs, [])
 | 
					
						
							|  |  |  |         this.seenThisSession = this._seenThisSession | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-23 02:16:24 +02:00
										 |  |  |         prefs.addCallbackAndRunD(prefs => { | 
					
						
							|  |  |  |             if(prefs === ""){ | 
					
						
							|  |  |  |                 return | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             const simpleArr = <GeoCodeResult[]> JSON.parse(prefs) | 
					
						
							|  |  |  |             if(simpleArr.length > 0){ | 
					
						
							|  |  |  |                 this._seenThisSession.set(simpleArr) | 
					
						
							|  |  |  |                 return true | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         this.seenThisSession.stabilized(2500).addCallbackAndRunD(seen => { | 
					
						
							|  |  |  |             const results=  [] | 
					
						
							|  |  |  |             for (let i = 0; i < Math.min(3, seen.length); i++) { | 
					
						
							|  |  |  |                 const gc = seen[i] | 
					
						
							|  |  |  |                 const simple = { | 
					
						
							|  |  |  |                     category: gc.category, | 
					
						
							|  |  |  |                     description: gc.description, | 
					
						
							|  |  |  |                     display_name: gc.display_name, | 
					
						
							|  |  |  |                     lat: gc.lat, lon: gc.lon, | 
					
						
							|  |  |  |                     osm_id: gc.osm_id, | 
					
						
							|  |  |  |                     osm_type: gc.osm_type | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |                 results.push(simple) | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             console.log("Setting", results) | 
					
						
							|  |  |  |             prefs.setData(JSON.stringify(results)) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         }) | 
					
						
							| 
									
										
										
										
											2024-08-21 14:06:42 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         state.selectedElement.addCallbackAndRunD(selected => { | 
					
						
							| 
									
										
										
										
											2024-08-22 22:50:37 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-21 14:06:42 +02:00
										 |  |  |             const [osm_type, osm_id] = selected.properties.id.split("/") | 
					
						
							| 
									
										
										
										
											2024-08-22 22:50:37 +02:00
										 |  |  |             if(!osm_id){ | 
					
						
							|  |  |  |                 return | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2024-08-23 02:16:24 +02:00
										 |  |  |             console.log("Selected element is", selected) | 
					
						
							|  |  |  |             if(["node","way","relation"].indexOf(osm_type) < 0){ | 
					
						
							|  |  |  |                 return | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2024-08-21 14:06:42 +02:00
										 |  |  |             const [lon, lat] = GeoOperations.centerpointCoordinates(selected) | 
					
						
							| 
									
										
										
										
											2024-08-22 02:54:46 +02:00
										 |  |  |             const entry = <GeoCodeResult>{ | 
					
						
							| 
									
										
										
										
											2024-08-21 14:06:42 +02:00
										 |  |  |                 feature: selected, | 
					
						
							|  |  |  |                 osm_id, osm_type, | 
					
						
							|  |  |  |                 lon, lat | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             this.addSelected(entry) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         }) | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     addSelected(entry: GeoCodeResult) { | 
					
						
							| 
									
										
										
										
											2024-08-22 02:54:46 +02:00
										 |  |  |         const arr = [...(this.seenThisSession.data ?? []).slice(0, 20), entry] | 
					
						
							| 
									
										
										
										
											2024-08-21 14:06:42 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         const seenIds = new Set<string>() | 
					
						
							|  |  |  |         for (let i = arr.length - 1; i >= 0; i--) { | 
					
						
							|  |  |  |             const id = arr[i].osm_type + arr[i].osm_id | 
					
						
							|  |  |  |             if (seenIds.has(id)) { | 
					
						
							|  |  |  |                 arr.splice(i, 1) | 
					
						
							|  |  |  |             } else { | 
					
						
							|  |  |  |                 seenIds.add(id) | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2024-08-23 02:16:24 +02:00
										 |  |  |         console.log(">>>",arr) | 
					
						
							| 
									
										
										
										
											2024-08-21 14:06:42 +02:00
										 |  |  |         this._seenThisSession.set(arr) | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } |