| 
									
										
										
										
											2021-01-27 01:14:16 +01:00
										 |  |  | import {UIEventSource} from "../UIEventSource"; | 
					
						
							|  |  |  | import FeatureSource from "../FeatureSource/FeatureSource"; | 
					
						
							| 
									
										
										
										
											2021-07-28 00:09:17 +02:00
										 |  |  | import {OsmObject} from "../Osm/OsmObject"; | 
					
						
							| 
									
										
										
										
											2021-05-06 01:33:09 +02:00
										 |  |  | import Loc from "../../Models/Loc"; | 
					
						
							|  |  |  | import FeaturePipeline from "../FeatureSource/FeaturePipeline"; | 
					
						
							|  |  |  | import OsmApiFeatureSource from "../FeatureSource/OsmApiFeatureSource"; | 
					
						
							| 
									
										
										
										
											2021-01-27 01:14:16 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  | /** | 
					
						
							| 
									
										
										
										
											2021-05-06 01:33:09 +02:00
										 |  |  |  * Makes sure the hash shows the selected element and vice-versa. | 
					
						
							| 
									
										
										
										
											2021-01-27 01:14:16 +01:00
										 |  |  |  */ | 
					
						
							|  |  |  | export default class SelectedFeatureHandler { | 
					
						
							|  |  |  |     private readonly _featureSource: FeatureSource; | 
					
						
							|  |  |  |     private readonly _hash: UIEventSource<string>; | 
					
						
							|  |  |  |     private readonly _selectedFeature: UIEventSource<any>; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-07-28 00:09:17 +02:00
										 |  |  |     private static readonly _no_trigger_on = ["welcome", "copyright", "layers", "new"] | 
					
						
							| 
									
										
										
										
											2021-05-06 01:33:09 +02:00
										 |  |  |     private readonly _osmApiSource: OsmApiFeatureSource; | 
					
						
							| 
									
										
										
										
											2021-07-28 00:09:17 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     constructor(hash: UIEventSource<string>, | 
					
						
							| 
									
										
										
										
											2021-01-27 01:14:16 +01:00
										 |  |  |                 selectedFeature: UIEventSource<any>, | 
					
						
							| 
									
										
										
										
											2021-05-06 01:33:09 +02:00
										 |  |  |                 featureSource: FeaturePipeline, | 
					
						
							|  |  |  |                 osmApiSource: OsmApiFeatureSource) { | 
					
						
							| 
									
										
										
										
											2021-01-27 01:14:16 +01:00
										 |  |  |         this._hash = hash; | 
					
						
							|  |  |  |         this._selectedFeature = selectedFeature; | 
					
						
							|  |  |  |         this._featureSource = featureSource; | 
					
						
							| 
									
										
										
										
											2021-05-06 01:33:09 +02:00
										 |  |  |         this._osmApiSource = osmApiSource; | 
					
						
							| 
									
										
										
										
											2021-01-27 01:14:16 +01:00
										 |  |  |         const self = this; | 
					
						
							|  |  |  |         hash.addCallback(h => { | 
					
						
							|  |  |  |             if (h === undefined || h === "") { | 
					
						
							|  |  |  |                 selectedFeature.setData(undefined); | 
					
						
							| 
									
										
										
										
											2021-07-28 00:09:17 +02:00
										 |  |  |             } else { | 
					
						
							| 
									
										
										
										
											2021-01-27 01:14:16 +01:00
										 |  |  |                 self.selectFeature(); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         }) | 
					
						
							| 
									
										
										
										
											2021-07-28 00:09:17 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         hash.addCallbackAndRunD(h => { | 
					
						
							|  |  |  |             try { | 
					
						
							|  |  |  |                 self.downloadFeature(h) | 
					
						
							|  |  |  |             } catch (e) { | 
					
						
							|  |  |  |                 console.error("Could not download feature, probably a weird hash") | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         }) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-27 01:14:16 +01:00
										 |  |  |         featureSource.features.addCallback(_ => self.selectFeature()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         selectedFeature.addCallback(feature => { | 
					
						
							| 
									
										
										
										
											2021-07-28 00:09:17 +02:00
										 |  |  |             if (feature === undefined) { | 
					
						
							|  |  |  |                 if (SelectedFeatureHandler._no_trigger_on.indexOf(hash.data) < 0) { | 
					
						
							| 
									
										
										
										
											2021-04-23 18:16:44 +02:00
										 |  |  |                     hash.setData("") | 
					
						
							|  |  |  |                 } | 
					
						
							| 
									
										
										
										
											2021-04-06 19:41:41 +02:00
										 |  |  |             } | 
					
						
							| 
									
										
										
										
											2021-07-28 00:09:17 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-03-13 17:25:44 +01:00
										 |  |  |             const h = feature?.properties?.id; | 
					
						
							| 
									
										
										
										
											2021-07-28 00:09:17 +02:00
										 |  |  |             if (h !== undefined) { | 
					
						
							| 
									
										
										
										
											2021-03-13 17:25:44 +01:00
										 |  |  |                 hash.setData(h) | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2021-01-27 01:14:16 +01:00
										 |  |  |         }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         this.selectFeature(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-07-28 00:09:17 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-05-06 01:33:09 +02:00
										 |  |  |     // If a feature is selected via the hash, zoom there
 | 
					
						
							| 
									
										
										
										
											2021-07-28 00:09:17 +02:00
										 |  |  |     public zoomToSelectedFeature(location: UIEventSource<Loc>) { | 
					
						
							| 
									
										
										
										
											2021-05-06 01:33:09 +02:00
										 |  |  |         const hash = this._hash.data; | 
					
						
							| 
									
										
										
										
											2021-07-28 00:09:17 +02:00
										 |  |  |         if (hash === undefined || SelectedFeatureHandler._no_trigger_on.indexOf(hash) >= 0) { | 
					
						
							| 
									
										
										
										
											2021-05-06 01:33:09 +02:00
										 |  |  |             return; // No valid feature selected
 | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2021-07-18 14:52:09 +02:00
										 |  |  |         // We should have a valid osm-ID and zoom to it... But we wrap it in try-catch to be sure
 | 
					
						
							| 
									
										
										
										
											2021-07-28 00:09:17 +02:00
										 |  |  |         try { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             OsmObject.DownloadObject(hash).addCallbackAndRunD(element => { | 
					
						
							|  |  |  |                 const centerpoint = element.centerpoint(); | 
					
						
							|  |  |  |                 console.log("Zooming to location for select point: ", centerpoint) | 
					
						
							|  |  |  |                 location.data.lat = centerpoint[0] | 
					
						
							|  |  |  |                 location.data.lon = centerpoint[1] | 
					
						
							|  |  |  |                 location.ping(); | 
					
						
							|  |  |  |             }) | 
					
						
							|  |  |  |         } catch (e) { | 
					
						
							| 
									
										
										
										
											2021-07-18 14:52:09 +02:00
										 |  |  |             console.error("Could not download OSM-object with id", hash, " - probably a weird hash") | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2021-05-06 01:33:09 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-07-28 00:09:17 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     private downloadFeature(hash: string) { | 
					
						
							|  |  |  |         if (hash === undefined || hash === "") { | 
					
						
							| 
									
										
										
										
											2021-05-06 01:33:09 +02:00
										 |  |  |             return; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2021-07-28 00:09:17 +02:00
										 |  |  |         if (SelectedFeatureHandler._no_trigger_on.indexOf(hash) >= 0) { | 
					
						
							| 
									
										
										
										
											2021-05-06 01:33:09 +02:00
										 |  |  |             return; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2021-07-28 00:09:17 +02:00
										 |  |  |         try { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             this._osmApiSource.load(hash) | 
					
						
							|  |  |  |         } catch (e) { | 
					
						
							|  |  |  |             console.log("Could not download feature, probably a weird hash:", hash) | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2021-05-06 01:33:09 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2021-07-28 00:09:17 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     private selectFeature() { | 
					
						
							| 
									
										
										
										
											2021-01-27 01:14:16 +01:00
										 |  |  |         const features = this._featureSource?.features?.data; | 
					
						
							| 
									
										
										
										
											2021-07-28 00:09:17 +02:00
										 |  |  |         if (features === undefined) { | 
					
						
							| 
									
										
										
										
											2021-01-27 01:14:16 +01:00
										 |  |  |             return; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2021-07-28 00:09:17 +02:00
										 |  |  |         if (this._selectedFeature.data?.properties?.id === this._hash.data) { | 
					
						
							| 
									
										
										
										
											2021-02-05 18:58:06 +01:00
										 |  |  |             // Feature already selected
 | 
					
						
							|  |  |  |             return; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2021-07-28 00:09:17 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-02-20 01:45:51 +01:00
										 |  |  |         const hash = this._hash.data; | 
					
						
							| 
									
										
										
										
											2021-07-28 00:09:17 +02:00
										 |  |  |         if (hash === undefined || hash === "" || hash === "#") { | 
					
						
							| 
									
										
										
										
											2021-02-20 01:45:51 +01:00
										 |  |  |             return; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2021-01-27 01:14:16 +01:00
										 |  |  |         for (const feature of features) { | 
					
						
							|  |  |  |             const id = feature.feature?.properties?.id; | 
					
						
							| 
									
										
										
										
											2021-07-28 00:09:17 +02:00
										 |  |  |             if (id === hash) { | 
					
						
							| 
									
										
										
										
											2021-01-27 01:14:16 +01:00
										 |  |  |                 this._selectedFeature.setData(feature.feature); | 
					
						
							| 
									
										
										
										
											2021-02-14 19:45:02 +01:00
										 |  |  |                 break; | 
					
						
							| 
									
										
										
										
											2021-01-27 01:14:16 +01:00
										 |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } |