| 
									
										
										
										
											2020-06-27 03:06:51 +02:00
										 |  |  | /** | 
					
						
							|  |  |  |  * Keeps 'messagebox' and 'messageboxmobile' in sync, shows a 'close' button on the latter one | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | import {UIEventSource} from "./UIEventSource"; | 
					
						
							|  |  |  | import {UIElement} from "./UIElement"; | 
					
						
							| 
									
										
										
										
											2020-06-29 03:12:44 +02:00
										 |  |  | import {VariableUiElement} from "./Base/VariableUIElement"; | 
					
						
							| 
									
										
										
										
											2020-06-27 03:06:51 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | export class MessageBoxHandler { | 
					
						
							|  |  |  |     private _uielement: UIEventSource<() => UIElement>; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     constructor(uielement: UIEventSource<() => UIElement>, | 
					
						
							|  |  |  |                 onClear: (() => void)) { | 
					
						
							|  |  |  |         this._uielement = uielement; | 
					
						
							|  |  |  |         this.listenTo(uielement); | 
					
						
							|  |  |  |         this.update(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-29 03:12:44 +02:00
										 |  |  |         window.onhashchange = function () { | 
					
						
							|  |  |  |             if (location.hash === "") { | 
					
						
							|  |  |  |                 // No more element: back to the map!
 | 
					
						
							|  |  |  |                 uielement.setData(undefined); | 
					
						
							|  |  |  |                 onClear(); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-28 00:06:23 +02:00
										 |  |  |         new VariableUiElement(new UIEventSource<string>("<h2>Naar de kaart</h2>"), | 
					
						
							| 
									
										
										
										
											2020-06-29 03:12:44 +02:00
										 |  |  |             () => { | 
					
						
							| 
									
										
										
										
											2020-06-28 00:06:23 +02:00
										 |  |  |                 document.getElementById("to-the-map").onclick = function () { | 
					
						
							| 
									
										
										
										
											2020-06-27 03:06:51 +02:00
										 |  |  |                     uielement.setData(undefined); | 
					
						
							|  |  |  |                     onClear(); | 
					
						
							|  |  |  |                 } | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         ).AttachTo("to-the-map"); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-29 03:12:44 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-27 03:06:51 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     listenTo(uiEventSource: UIEventSource<any>) { | 
					
						
							|  |  |  |         const self = this; | 
					
						
							|  |  |  |         uiEventSource.addCallback(function () { | 
					
						
							|  |  |  |             self.update(); | 
					
						
							|  |  |  |         }) | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-29 03:12:44 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-27 03:06:51 +02:00
										 |  |  |     update() { | 
					
						
							|  |  |  |         const wrapper = document.getElementById("messagesboxmobilewrapper"); | 
					
						
							|  |  |  |         const gen = this._uielement.data; | 
					
						
							|  |  |  |         console.log("Generator: ", gen); | 
					
						
							|  |  |  |         if (gen === undefined) { | 
					
						
							| 
									
										
										
										
											2020-06-29 03:12:44 +02:00
										 |  |  |             wrapper.classList.add("hidden") | 
					
						
							|  |  |  |             if (location.hash !== "") { | 
					
						
							|  |  |  |                 location.hash = "" | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2020-06-27 03:06:51 +02:00
										 |  |  |             return; | 
					
						
							|  |  |  |         } | 
					
						
							| 
									
										
										
										
											2020-06-29 03:12:44 +02:00
										 |  |  |         location.hash = "#element" | 
					
						
							| 
									
										
										
										
											2020-06-27 03:06:51 +02:00
										 |  |  |         wrapper.classList.remove("hidden"); | 
					
						
							| 
									
										
										
										
											2020-06-29 16:21:36 +02:00
										 |  |  |       /*  gen() | 
					
						
							| 
									
										
										
										
											2020-06-27 03:06:51 +02:00
										 |  |  |             ?.HideOnEmpty(true) | 
					
						
							|  |  |  |             ?.AttachTo("messagesbox") | 
					
						
							| 
									
										
										
										
											2020-06-29 16:21:36 +02:00
										 |  |  |             ?.Activate();*/ | 
					
						
							| 
									
										
										
										
											2020-06-27 03:06:51 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         gen() | 
					
						
							|  |  |  |             ?.HideOnEmpty(true) | 
					
						
							|  |  |  |             ?.AttachTo("messagesboxmobile") | 
					
						
							|  |  |  |             ?.Activate(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } |