| 
									
										
										
										
											2021-01-04 04:06:21 +01:00
										 |  |  | import {UIEventSource} from "../../Logic/UIEventSource"; | 
					
						
							|  |  |  | import {UIElement} from "../UIElement"; | 
					
						
							|  |  |  | import LayoutConfig from "../../Customizations/JSON/LayoutConfig"; | 
					
						
							|  |  |  | import {AllKnownLayouts} from "../../Customizations/AllKnownLayouts"; | 
					
						
							|  |  |  | import Svg from "../../Svg"; | 
					
						
							|  |  |  | import State from "../../State"; | 
					
						
							|  |  |  | import Combine from "../Base/Combine"; | 
					
						
							| 
									
										
										
										
											2021-06-10 01:36:20 +02:00
										 |  |  | import Toggle from "../Input/Toggle"; | 
					
						
							| 
									
										
										
										
											2021-01-04 04:06:21 +01:00
										 |  |  | import {SubtleButton} from "../Base/SubtleButton"; | 
					
						
							|  |  |  | import Translations from "../i18n/Translations"; | 
					
						
							|  |  |  | import * as personal from "../../assets/themes/personalLayout/personalLayout.json" | 
					
						
							| 
									
										
										
										
											2021-01-05 01:30:59 +01:00
										 |  |  | import Locale from "../i18n/Locale"; | 
					
						
							| 
									
										
										
										
											2021-06-12 02:58:32 +02:00
										 |  |  | import BaseUIElement from "../BaseUIElement"; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-01-04 04:06:21 +01:00
										 |  |  | export default class PersonalLayersPanel extends UIElement { | 
					
						
							| 
									
										
										
										
											2021-06-12 02:58:32 +02:00
										 |  |  |     private checkboxes: BaseUIElement[] = []; | 
					
						
							| 
									
										
										
										
											2020-08-26 15:36:04 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-31 04:58:58 +02:00
										 |  |  |     constructor() { | 
					
						
							| 
									
										
										
										
											2020-08-26 15:36:04 +02:00
										 |  |  |         super(State.state.favouriteLayers); | 
					
						
							| 
									
										
										
										
											2020-07-31 04:58:58 +02:00
										 |  |  |         this.ListenTo(State.state.osmConnection.userDetails); | 
					
						
							| 
									
										
										
										
											2021-01-05 01:30:59 +01:00
										 |  |  |         this.ListenTo(Locale.language); | 
					
						
							| 
									
										
										
										
											2020-08-26 20:11:43 +02:00
										 |  |  |         this.UpdateView([]); | 
					
						
							|  |  |  |         const self = this; | 
					
						
							|  |  |  |         State.state.installedThemes.addCallback(extraThemes => { | 
					
						
							| 
									
										
										
										
											2021-01-02 23:28:14 +01:00
										 |  |  |             self.UpdateView(extraThemes.map(layout => layout.layout)); | 
					
						
							| 
									
										
										
										
											2020-08-26 20:11:43 +02:00
										 |  |  |             self.Update(); | 
					
						
							|  |  |  |         }) | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-07-31 04:58:58 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-11-11 16:23:49 +01:00
										 |  |  |     private UpdateView(extraThemes: LayoutConfig[]) { | 
					
						
							| 
									
										
										
										
											2020-08-26 20:11:43 +02:00
										 |  |  |         this.checkboxes = []; | 
					
						
							|  |  |  |         const favs = State.state.favouriteLayers.data ?? []; | 
					
						
							| 
									
										
										
										
											2020-07-31 04:58:58 +02:00
										 |  |  |         const controls = new Map<string, UIEventSource<boolean>>(); | 
					
						
							| 
									
										
										
										
											2020-08-26 20:11:43 +02:00
										 |  |  |         const allLayouts = AllKnownLayouts.layoutsList.concat(extraThemes); | 
					
						
							|  |  |  |         for (const layout of allLayouts) { | 
					
						
							| 
									
										
										
										
											2020-11-11 16:23:49 +01:00
										 |  |  |             if (layout.id === personal.id) { | 
					
						
							| 
									
										
										
										
											2020-07-31 16:17:16 +02:00
										 |  |  |                 continue; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2021-01-05 01:30:59 +01:00
										 |  |  |              | 
					
						
							|  |  |  |             if(layout.hideFromOverview){ | 
					
						
							|  |  |  |                 continue; | 
					
						
							|  |  |  |             } | 
					
						
							| 
									
										
										
										
											2020-08-26 20:11:43 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-31 04:58:58 +02:00
										 |  |  |             const header = | 
					
						
							|  |  |  |                 new Combine([ | 
					
						
							| 
									
										
										
										
											2020-09-15 02:29:31 +02:00
										 |  |  |                     `<img style="max-width: 3em;max-height: 3em; float: left; padding: 0.1em; margin-right: 0.3em;" src='${layout.icon}'>`, | 
					
						
							|  |  |  |                     "<b>", | 
					
						
							| 
									
										
										
										
											2020-07-31 04:58:58 +02:00
										 |  |  |                     layout.title, | 
					
						
							|  |  |  |                     "</b><br/>", | 
					
						
							| 
									
										
										
										
											2020-11-11 16:23:49 +01:00
										 |  |  |                     layout.shortDescription ?? "" | 
					
						
							| 
									
										
										
										
											2021-01-27 02:58:11 +01:00
										 |  |  |                 ]).SetClass("block p1 overflow-auto rounded") | 
					
						
							|  |  |  |                     .SetStyle("background: #eee;") | 
					
						
							| 
									
										
										
										
											2020-07-31 04:58:58 +02:00
										 |  |  |             this.checkboxes.push(header); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             for (const layer of layout.layers) { | 
					
						
							| 
									
										
										
										
											2020-11-11 16:23:49 +01:00
										 |  |  |                 if(layer === undefined){ | 
					
						
							|  |  |  |                     console.warn("Undefined layer for ",layout.id) | 
					
						
							|  |  |  |                     continue; | 
					
						
							|  |  |  |                 } | 
					
						
							| 
									
										
										
										
											2020-09-15 02:29:31 +02:00
										 |  |  |                 if (typeof layer === "string") { | 
					
						
							| 
									
										
										
										
											2020-09-10 19:33:06 +02:00
										 |  |  |                     continue; | 
					
						
							|  |  |  |                 } | 
					
						
							| 
									
										
										
										
											2021-06-12 02:58:32 +02:00
										 |  |  |                 let icon :BaseUIElement = layer.GenerateLeafletStyle(new UIEventSource<any>({id:"node/-1"}), false).icon.html | 
					
						
							| 
									
										
										
										
											2021-01-02 23:28:14 +01:00
										 |  |  |                     ?? Svg.checkmark_svg(); | 
					
						
							| 
									
										
										
										
											2021-06-12 02:58:32 +02:00
										 |  |  |                 let iconUnset =new Combine([icon]); | 
					
						
							| 
									
										
										
										
											2021-01-02 23:28:14 +01:00
										 |  |  |                 icon.SetClass("single-layer-selection-toggle") | 
					
						
							|  |  |  |                 iconUnset.SetClass("single-layer-selection-toggle") | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-31 16:17:16 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-26 20:11:43 +02:00
										 |  |  |                 let name = layer.name ?? layer.id; | 
					
						
							|  |  |  |                 if (name === undefined) { | 
					
						
							|  |  |  |                     continue; | 
					
						
							|  |  |  |                 } | 
					
						
							| 
									
										
										
										
											2020-07-31 16:17:16 +02:00
										 |  |  |                 const content = new Combine([ | 
					
						
							| 
									
										
										
										
											2020-09-15 02:29:31 +02:00
										 |  |  |                     "<b>",  | 
					
						
							|  |  |  |                     name,  | 
					
						
							|  |  |  |                     "</b> ", | 
					
						
							| 
									
										
										
										
											2020-07-31 16:17:16 +02:00
										 |  |  |                     layer.description !== undefined ? new Combine(["<br/>", layer.description]) : "", | 
					
						
							| 
									
										
										
										
											2020-09-15 02:29:31 +02:00
										 |  |  |                 ]) | 
					
						
							| 
									
										
										
										
											2020-09-18 22:23:49 +02:00
										 |  |  |                  | 
					
						
							|  |  |  |                  | 
					
						
							| 
									
										
										
										
											2021-06-10 01:36:20 +02:00
										 |  |  |                 const cb = new Toggle( | 
					
						
							| 
									
										
										
										
											2020-09-15 02:29:31 +02:00
										 |  |  |                     new SubtleButton( | 
					
						
							| 
									
										
										
										
											2021-01-02 23:28:14 +01:00
										 |  |  |                         icon,  | 
					
						
							| 
									
										
										
										
											2020-09-18 22:23:49 +02:00
										 |  |  |                         content), | 
					
						
							|  |  |  |                     new SubtleButton( | 
					
						
							| 
									
										
										
										
											2021-01-02 23:28:14 +01:00
										 |  |  |                         iconUnset.SetStyle("opacity:0.1"), | 
					
						
							| 
									
										
										
										
											2020-09-15 02:29:31 +02:00
										 |  |  |                         new Combine(["<del>", | 
					
						
							|  |  |  |                             content, | 
					
						
							|  |  |  |                             "</del>" | 
					
						
							|  |  |  |                         ])), | 
					
						
							| 
									
										
										
										
											2020-07-31 04:58:58 +02:00
										 |  |  |                     controls[layer.id] ?? (favs.indexOf(layer.id) >= 0) | 
					
						
							|  |  |  |                 ); | 
					
						
							| 
									
										
										
										
											2020-08-28 03:16:21 +02:00
										 |  |  |                 cb.SetClass("custom-layer-checkbox"); | 
					
						
							| 
									
										
										
										
											2020-07-31 04:58:58 +02:00
										 |  |  |                 controls[layer.id] = cb.isEnabled; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 cb.isEnabled.addCallback((isEnabled) => { | 
					
						
							| 
									
										
										
										
											2020-08-26 15:36:04 +02:00
										 |  |  |                     const favs = State.state.favouriteLayers; | 
					
						
							| 
									
										
										
										
											2020-07-31 04:58:58 +02:00
										 |  |  |                     if (isEnabled) { | 
					
						
							| 
									
										
										
										
											2020-09-15 02:29:31 +02:00
										 |  |  |                         if(favs.data.indexOf(layer.id)>= 0){ | 
					
						
							|  |  |  |                             return; // Already added
 | 
					
						
							|  |  |  |                         } | 
					
						
							| 
									
										
										
										
											2020-08-26 15:36:04 +02:00
										 |  |  |                         favs.data.push(layer.id); | 
					
						
							| 
									
										
										
										
											2020-07-31 04:58:58 +02:00
										 |  |  |                     } else { | 
					
						
							| 
									
										
										
										
											2020-08-26 15:36:04 +02:00
										 |  |  |                         favs.data.splice(favs.data.indexOf(layer.id), 1); | 
					
						
							| 
									
										
										
										
											2020-07-31 04:58:58 +02:00
										 |  |  |                     } | 
					
						
							| 
									
										
										
										
											2020-08-26 15:36:04 +02:00
										 |  |  |                     favs.ping(); | 
					
						
							| 
									
										
										
										
											2020-07-31 04:58:58 +02:00
										 |  |  |                 }) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 this.checkboxes.push(cb); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-31 16:17:16 +02:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2020-09-15 02:29:31 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         State.state.favouriteLayers.addCallback((layers) => { | 
					
						
							|  |  |  |             for (const layerId of layers) { | 
					
						
							|  |  |  |                 controls[layerId]?.setData(true); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-31 04:58:58 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-06-12 02:58:32 +02:00
										 |  |  |     InnerRender(): BaseUIElement { | 
					
						
							| 
									
										
										
										
											2020-07-31 04:58:58 +02:00
										 |  |  |         const t = Translations.t.favourite; | 
					
						
							| 
									
										
										
										
											2021-06-12 02:58:32 +02:00
										 |  |  |         return new Toggle( | 
					
						
							|  |  |  |             new Combine([ | 
					
						
							|  |  |  |                 t.panelIntro, | 
					
						
							|  |  |  |                 ...this.checkboxes | 
					
						
							|  |  |  |             ]), | 
					
						
							|  |  |  |             t.loginNeeded, | 
					
						
							|  |  |  |             State.state.osmConnection.isLoggedIn | 
					
						
							|  |  |  |              | 
					
						
							|  |  |  |         ) | 
					
						
							| 
									
										
										
										
											2020-07-31 04:58:58 +02:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } |