| 
									
										
										
										
											2020-06-24 00:35:19 +02:00
										 |  |  | import {UIElement} from "./UIElement"; | 
					
						
							|  |  |  | import {UIEventSource} from "./UIEventSource"; | 
					
						
							|  |  |  | import {OsmConnection} from "../Logic/OsmConnection"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export class CenterMessageBox extends UIElement { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     private readonly _location: UIEventSource<{ zoom: number }>; | 
					
						
							|  |  |  |     private readonly _zoomInMore = new UIEventSource<boolean>(true); | 
					
						
							|  |  |  |     private readonly _centermessage: UIEventSource<string>; | 
					
						
							|  |  |  |     private readonly _osmConnection: OsmConnection; | 
					
						
							|  |  |  |     private readonly _queryRunning: UIEventSource<boolean>; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     constructor( | 
					
						
							|  |  |  |         startZoom: number, | 
					
						
							|  |  |  |         centermessage: UIEventSource<string>, | 
					
						
							|  |  |  |         osmConnection: OsmConnection, | 
					
						
							|  |  |  |         location: UIEventSource<{ zoom: number }>, | 
					
						
							|  |  |  |         queryRunning: UIEventSource<boolean> | 
					
						
							|  |  |  |     ) { | 
					
						
							|  |  |  |         super(centermessage); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         this._centermessage = centermessage; | 
					
						
							|  |  |  |         this._location = location; | 
					
						
							|  |  |  |         this._osmConnection = osmConnection; | 
					
						
							|  |  |  |         this._queryRunning = queryRunning; | 
					
						
							|  |  |  |         this.ListenTo(queryRunning); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         const self = this; | 
					
						
							|  |  |  |         location.addCallback(function () { | 
					
						
							|  |  |  |             self._zoomInMore.setData(location.data.zoom < startZoom); | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |         this.ListenTo(this._zoomInMore); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     protected InnerRender(): string { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (this._centermessage.data != "") { | 
					
						
							|  |  |  |             return this._centermessage.data; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (this._zoomInMore.data) { | 
					
						
							|  |  |  |             return "Zoom in om de data te zien en te bewerken"; | 
					
						
							|  |  |  |         } else if (this._queryRunning.data) { | 
					
						
							|  |  |  |             return "Data wordt geladen..."; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return "Klaar!"; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     private ShouldShowSomething() : boolean{ | 
					
						
							|  |  |  |         if (this._queryRunning.data) { | 
					
						
							|  |  |  |             return true; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         return this._zoomInMore.data; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     InnerUpdate(htmlElement: HTMLElement) { | 
					
						
							|  |  |  |         const pstyle = htmlElement.parentElement.style; | 
					
						
							|  |  |  |         if (this._centermessage.data != "") { | 
					
						
							|  |  |  |             pstyle.opacity = "1"; | 
					
						
							|  |  |  |             pstyle.pointerEvents = "all"; | 
					
						
							| 
									
										
										
										
											2020-06-27 03:06:51 +02:00
										 |  |  |             this._osmConnection.registerActivateOsmAUthenticationClass(); | 
					
						
							| 
									
										
										
										
											2020-06-24 00:35:19 +02:00
										 |  |  |             return; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         pstyle.pointerEvents = "none"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (this.ShouldShowSomething()) { | 
					
						
							|  |  |  |             pstyle.opacity = "0.5"; | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |             pstyle.opacity = "0"; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 |