| 
									
										
										
										
											2021-07-28 16:48:59 +02:00
										 |  |  | import Combine from "../Base/Combine"; | 
					
						
							|  |  |  | import ScrollableFullScreen from "../Base/ScrollableFullScreen"; | 
					
						
							|  |  |  | import Translations from "../i18n/Translations"; | 
					
						
							|  |  |  | import Toggle from "../Input/Toggle"; | 
					
						
							|  |  |  | import MapControlButton from "../MapControlButton"; | 
					
						
							|  |  |  | import Svg from "../../Svg"; | 
					
						
							|  |  |  | import AllDownloads from "./AllDownloads"; | 
					
						
							|  |  |  | import FilterView from "./FilterView"; | 
					
						
							| 
									
										
										
										
											2021-09-21 02:10:42 +02:00
										 |  |  | import {UIEventSource} from "../../Logic/UIEventSource"; | 
					
						
							| 
									
										
										
										
											2021-11-21 02:44:35 +01:00
										 |  |  | import BackgroundMapSwitch from "./BackgroundMapSwitch"; | 
					
						
							| 
									
										
										
										
											2021-12-10 17:30:50 +01:00
										 |  |  | import Lazy from "../Base/Lazy"; | 
					
						
							|  |  |  | import {VariableUiElement} from "../Base/VariableUIElement"; | 
					
						
							|  |  |  | import FeatureInfoBox from "../Popup/FeatureInfoBox"; | 
					
						
							| 
									
										
										
										
											2021-12-14 03:12:10 +01:00
										 |  |  | import CopyrightPanel from "./CopyrightPanel"; | 
					
						
							| 
									
										
										
										
											2022-01-19 20:34:04 +01:00
										 |  |  | import FeaturePipelineState from "../../Logic/State/FeaturePipelineState"; | 
					
						
							| 
									
										
										
										
											2021-07-28 16:48:59 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | export default class LeftControls extends Combine { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-01-19 20:34:04 +01:00
										 |  |  |     constructor(state: FeaturePipelineState, | 
					
						
							| 
									
										
										
										
											2021-10-15 05:20:02 +02:00
										 |  |  |                 guiState: { | 
					
						
							| 
									
										
										
										
											2021-12-10 17:30:50 +01:00
										 |  |  |                     currentViewControlIsOpened: UIEventSource<boolean>; | 
					
						
							| 
									
										
										
										
											2021-10-15 05:20:02 +02:00
										 |  |  |                     downloadControlIsOpened: UIEventSource<boolean>, | 
					
						
							|  |  |  |                     filterViewIsOpened: UIEventSource<boolean>, | 
					
						
							| 
									
										
										
										
											2021-10-23 02:46:37 +02:00
										 |  |  |                     copyrightViewIsOpened: UIEventSource<boolean> | 
					
						
							| 
									
										
										
										
											2021-10-15 05:20:02 +02:00
										 |  |  |                 }) { | 
					
						
							| 
									
										
										
										
											2021-07-28 16:48:59 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-10 17:30:50 +01:00
										 |  |  |         const currentViewFL = state.currentView?.layer | 
					
						
							|  |  |  |         const currentViewAction = new Toggle( | 
					
						
							|  |  |  |             new Lazy(() => { | 
					
						
							| 
									
										
										
										
											2021-12-14 03:12:10 +01:00
										 |  |  |                 const feature: UIEventSource<any> = state.currentView.features.map(ffs => ffs[0]?.feature) | 
					
						
							| 
									
										
										
										
											2021-12-10 17:30:50 +01:00
										 |  |  |                 const icon = new VariableUiElement(feature.map(feature => { | 
					
						
							|  |  |  |                     const defaultIcon = Svg.checkbox_empty_svg() | 
					
						
							|  |  |  |                     if (feature === undefined) { | 
					
						
							|  |  |  |                         return defaultIcon; | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                     const tags = {...feature.properties, button: "yes"} | 
					
						
							| 
									
										
										
										
											2021-12-11 02:19:28 +01:00
										 |  |  |                     const elem = currentViewFL.layerDef.mapRendering[0]?.GenerateLeafletStyle(new UIEventSource(tags), false, { | 
					
						
							| 
									
										
										
										
											2021-12-10 17:30:50 +01:00
										 |  |  |                         noSize: true | 
					
						
							|  |  |  |                     })?.html | 
					
						
							| 
									
										
										
										
											2021-12-14 03:12:10 +01:00
										 |  |  |                     if (elem === undefined) { | 
					
						
							| 
									
										
										
										
											2021-12-10 17:30:50 +01:00
										 |  |  |                         return defaultIcon | 
					
						
							|  |  |  |                     } | 
					
						
							|  |  |  |                     return elem | 
					
						
							| 
									
										
										
										
											2021-12-11 02:19:28 +01:00
										 |  |  |                 })).SetClass("inline-block w-full h-full") | 
					
						
							| 
									
										
										
										
											2021-12-14 03:12:10 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-10 17:30:50 +01:00
										 |  |  |                 const featureBox = new VariableUiElement(feature.map(feature => { | 
					
						
							| 
									
										
										
										
											2021-12-14 03:12:10 +01:00
										 |  |  |                     if (feature === undefined) { | 
					
						
							|  |  |  |                         return undefined | 
					
						
							|  |  |  |                     } | 
					
						
							| 
									
										
										
										
											2021-12-10 17:30:50 +01:00
										 |  |  |                     return new Lazy(() => { | 
					
						
							| 
									
										
										
										
											2021-12-14 03:12:10 +01:00
										 |  |  |                         const tagsSource = state.allElements.getEventSourceById(feature.properties.id) | 
					
						
							| 
									
										
										
										
											2022-01-19 20:34:04 +01:00
										 |  |  |                         return new FeatureInfoBox(tagsSource, currentViewFL.layerDef,state, "currentview", guiState.currentViewControlIsOpened) | 
					
						
							| 
									
										
										
										
											2021-12-12 02:59:24 +01:00
										 |  |  |                             .SetClass("md:floating-element-width") | 
					
						
							| 
									
										
										
										
											2021-12-10 17:30:50 +01:00
										 |  |  |                     }) | 
					
						
							|  |  |  |                 })) | 
					
						
							| 
									
										
										
										
											2021-12-14 03:12:10 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-10 17:30:50 +01:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 return new Toggle( | 
					
						
							|  |  |  |                     featureBox, | 
					
						
							|  |  |  |                     new MapControlButton(icon), | 
					
						
							|  |  |  |                     guiState.currentViewControlIsOpened | 
					
						
							|  |  |  |                 ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-11 02:19:28 +01:00
										 |  |  |             }).onClick(() => { | 
					
						
							| 
									
										
										
										
											2021-12-10 17:30:50 +01:00
										 |  |  |                 guiState.currentViewControlIsOpened.setData(true) | 
					
						
							|  |  |  |             }), | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             undefined, | 
					
						
							|  |  |  |             new UIEventSource<boolean>(currentViewFL !== undefined && currentViewFL?.layerDef?.tagRenderings !== null) | 
					
						
							|  |  |  |         ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-07-28 16:48:59 +02:00
										 |  |  |         const toggledDownload = new Toggle( | 
					
						
							|  |  |  |             new AllDownloads( | 
					
						
							| 
									
										
										
										
											2021-10-15 05:20:02 +02:00
										 |  |  |                 guiState.downloadControlIsOpened | 
					
						
							| 
									
										
										
										
											2021-12-12 02:59:24 +01:00
										 |  |  |             ).SetClass("block p-1 rounded-full md:floating-element-width"), | 
					
						
							| 
									
										
										
										
											2021-07-28 18:20:59 +02:00
										 |  |  |             new MapControlButton(Svg.download_svg()) | 
					
						
							| 
									
										
										
										
											2021-10-15 05:20:02 +02:00
										 |  |  |                 .onClick(() => guiState.downloadControlIsOpened.setData(true)), | 
					
						
							|  |  |  |             guiState.downloadControlIsOpened | 
					
						
							| 
									
										
										
										
											2021-07-28 18:20:59 +02:00
										 |  |  |         ) | 
					
						
							| 
									
										
										
										
											2021-07-28 16:48:59 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         const downloadButtonn = new Toggle( | 
					
						
							|  |  |  |             toggledDownload, | 
					
						
							|  |  |  |             undefined, | 
					
						
							| 
									
										
										
										
											2021-10-15 05:20:02 +02:00
										 |  |  |             state.featureSwitchEnableExport.map(downloadEnabled => downloadEnabled || state.featureSwitchExportAsPdf.data, | 
					
						
							|  |  |  |                 [state.featureSwitchExportAsPdf]) | 
					
						
							| 
									
										
										
										
											2021-07-28 16:48:59 +02:00
										 |  |  |         ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         const toggledFilter = new Toggle( | 
					
						
							|  |  |  |             new ScrollableFullScreen( | 
					
						
							|  |  |  |                 () => Translations.t.general.layerSelection.title.Clone(), | 
					
						
							|  |  |  |                 () => | 
					
						
							| 
									
										
										
										
											2021-10-15 05:20:02 +02:00
										 |  |  |                     new FilterView(state.filteredLayers, state.overlayToggles).SetClass( | 
					
						
							| 
									
										
										
										
											2021-10-23 02:46:37 +02:00
										 |  |  |                         "block p-1" | 
					
						
							| 
									
										
										
										
											2021-07-28 16:48:59 +02:00
										 |  |  |                     ), | 
					
						
							| 
									
										
										
										
											2021-10-25 20:50:59 +02:00
										 |  |  |                 "filters", | 
					
						
							| 
									
										
										
										
											2021-10-15 05:20:02 +02:00
										 |  |  |                 guiState.filterViewIsOpened | 
					
						
							| 
									
										
										
										
											2021-12-12 02:59:24 +01:00
										 |  |  |             ).SetClass("rounded-lg md:floating-element-width"), | 
					
						
							| 
									
										
										
										
											2022-01-06 18:51:52 +01:00
										 |  |  |             new MapControlButton(Svg.layers_svg()) | 
					
						
							| 
									
										
										
										
											2021-10-15 05:20:02 +02:00
										 |  |  |                 .onClick(() => guiState.filterViewIsOpened.setData(true)), | 
					
						
							|  |  |  |             guiState.filterViewIsOpened | 
					
						
							| 
									
										
										
										
											2021-07-28 18:20:59 +02:00
										 |  |  |         ) | 
					
						
							| 
									
										
										
										
											2021-07-28 16:48:59 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         const filterButton = new Toggle( | 
					
						
							|  |  |  |             toggledFilter, | 
					
						
							|  |  |  |             undefined, | 
					
						
							| 
									
										
										
										
											2021-10-15 05:20:02 +02:00
										 |  |  |             state.featureSwitchFilter | 
					
						
							| 
									
										
										
										
											2021-07-28 16:48:59 +02:00
										 |  |  |         ); | 
					
						
							| 
									
										
										
										
											2021-12-10 17:30:50 +01:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-04 12:20:24 +01:00
										 |  |  |         const mapSwitch = new Toggle( | 
					
						
							|  |  |  |             new BackgroundMapSwitch(state, state.backgroundLayer), | 
					
						
							|  |  |  |             undefined, | 
					
						
							|  |  |  |             state.featureSwitchBackgroundSelection | 
					
						
							|  |  |  |         ) | 
					
						
							| 
									
										
										
										
											2021-07-28 16:48:59 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-14 03:12:10 +01:00
										 |  |  |         // If the welcomeMessage is disabled, the copyright is hidden (as that is where the copyright is located
 | 
					
						
							|  |  |  |         const copyright = new Toggle( | 
					
						
							|  |  |  |             undefined, | 
					
						
							|  |  |  |             new Lazy(() => | 
					
						
							|  |  |  |                 new Toggle( | 
					
						
							|  |  |  |                     new ScrollableFullScreen( | 
					
						
							|  |  |  |                         () => Translations.t.general.attribution.attributionTitle, | 
					
						
							|  |  |  |                         () => new CopyrightPanel(state), | 
					
						
							|  |  |  |                         "copyright", | 
					
						
							|  |  |  |                         guiState.copyrightViewIsOpened | 
					
						
							|  |  |  |                     ), | 
					
						
							|  |  |  |                     new MapControlButton(Svg.copyright_svg()).onClick(() => guiState.copyrightViewIsOpened.setData(true)), | 
					
						
							|  |  |  |                     guiState.copyrightViewIsOpened | 
					
						
							|  |  |  |                 ) | 
					
						
							|  |  |  |             ), | 
					
						
							|  |  |  |             state.featureSwitchWelcomeMessage | 
					
						
							|  |  |  |         ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-12-10 17:30:50 +01:00
										 |  |  |         super([ | 
					
						
							|  |  |  |             currentViewAction, | 
					
						
							|  |  |  |             filterButton, | 
					
						
							| 
									
										
										
										
											2021-07-28 16:48:59 +02:00
										 |  |  |             downloadButtonn, | 
					
						
							| 
									
										
										
										
											2021-12-14 03:12:10 +01:00
										 |  |  |             copyright, | 
					
						
							| 
									
										
										
										
											2021-12-10 17:30:50 +01:00
										 |  |  |             mapSwitch | 
					
						
							| 
									
										
										
										
											2021-11-21 02:44:35 +01:00
										 |  |  |         ]) | 
					
						
							| 
									
										
										
										
											2021-09-09 00:05:51 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-07-28 16:48:59 +02:00
										 |  |  |         this.SetClass("flex flex-col") | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } |