| 
									
										
										
										
											2020-07-29 15:48:21 +02:00
										 |  |  | import {UIElement} from "./UIElement"; | 
					
						
							|  |  |  | import {VerticalCombine} from "./Base/VerticalCombine"; | 
					
						
							|  |  |  | import Translations from "./i18n/Translations"; | 
					
						
							|  |  |  | import {AllKnownLayouts} from "../Customizations/AllKnownLayouts"; | 
					
						
							|  |  |  | import {FixedUiElement} from "./Base/FixedUiElement"; | 
					
						
							|  |  |  | import {Utils} from "../Utils"; | 
					
						
							|  |  |  | import {link} from "fs"; | 
					
						
							|  |  |  | import {UIEventSource} from "./UIEventSource"; | 
					
						
							|  |  |  | import {VariableUiElement} from "./Base/VariableUIElement"; | 
					
						
							| 
									
										
										
										
											2020-07-29 16:46:45 +02:00
										 |  |  | import Combine from "./Base/Combine"; | 
					
						
							|  |  |  | import {SubtleButton} from "./Base/SubtleButton"; | 
					
						
							| 
									
										
										
										
											2020-07-29 15:48:21 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export class MoreScreen extends UIElement { | 
					
						
							|  |  |  |     private currentLocation: UIEventSource<{ zoom: number, lat: number, lon: number }>; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     constructor(currentLocation: UIEventSource<{ zoom: number, lat: number, lon: number }>) { | 
					
						
							|  |  |  |         super(currentLocation); | 
					
						
							|  |  |  |         this.currentLocation = currentLocation; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     InnerRender(): string { | 
					
						
							|  |  |  |         const tr = Translations.t.general.morescreen; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         const els: UIElement[] = [] | 
					
						
							|  |  |  |         for (const k in AllKnownLayouts.allSets) { | 
					
						
							|  |  |  |             const layout = AllKnownLayouts.allSets[k] | 
					
						
							| 
									
										
										
										
											2020-07-29 16:46:45 +02:00
										 |  |  |             if (layout.hideFromOverview) { | 
					
						
							|  |  |  |                 continue | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2020-07-29 15:48:21 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |             const linkText = | 
					
						
							| 
									
										
										
										
											2020-07-29 16:46:45 +02:00
										 |  |  |                 `https://pietervdvn.github.io/MapComplete/${layout.name}.html?z=${this.currentLocation.data.zoom}&lat=${this.currentLocation.data.lat}&lon=${this.currentLocation.data.lon}` | 
					
						
							|  |  |  |             const link = | 
					
						
							|  |  |  |                 new SubtleButton(layout.icon, | 
					
						
							|  |  |  |                     new Combine([ | 
					
						
							|  |  |  |                         "<b>", | 
					
						
							|  |  |  |                         Translations.W(layout.title), | 
					
						
							|  |  |  |                         "</b>", | 
					
						
							|  |  |  |                         "<br/>", | 
					
						
							|  |  |  |                         Translations.W(layout.description), | 
					
						
							| 
									
										
										
										
											2020-07-29 19:02:36 +02:00
										 |  |  |                     ]), linkText); | 
					
						
							| 
									
										
										
										
											2020-07-29 15:48:21 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |             els.push(link) | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         return new VerticalCombine([ | 
					
						
							|  |  |  |             tr.intro, | 
					
						
							|  |  |  |             new VerticalCombine(els), | 
					
						
							|  |  |  |             tr.streetcomplete | 
					
						
							|  |  |  |         ]).Render(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } |