| 
									
										
										
										
											2023-05-18 15:44:54 +02:00
										 |  |  | <script lang="ts"> | 
					
						
							| 
									
										
										
										
											2023-06-14 20:39:36 +02:00
										 |  |  |   /** | 
					
						
							|  |  |  |    * The RasterLayerOverview shows the available 4 categories of maps with a RasterLayerPicker | 
					
						
							|  |  |  |    */ | 
					
						
							|  |  |  |   import { Store, UIEventSource } from "../../Logic/UIEventSource" | 
					
						
							|  |  |  |   import type { RasterLayerPolygon } from "../../Models/RasterLayers" | 
					
						
							|  |  |  |   import RasterLayerPicker from "./RasterLayerPicker.svelte" | 
					
						
							|  |  |  |   import type { EliCategory } from "../../Models/RasterLayerProperties" | 
					
						
							|  |  |  |   import Translations from "../i18n/Translations" | 
					
						
							|  |  |  |   import Tr from "../Base/Tr.svelte" | 
					
						
							| 
									
										
										
										
											2024-08-11 16:27:00 +02:00
										 |  |  |   import Loading from "../Base/Loading.svelte" | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  |   import Page from "../Base/Page.svelte" | 
					
						
							|  |  |  |   import ThemeViewState from "../../Models/ThemeViewState" | 
					
						
							| 
									
										
										
										
											2024-08-29 03:53:54 +02:00
										 |  |  |   import { Square3Stack3dIcon } from "@babeard/svelte-heroicons/solid" | 
					
						
							| 
									
										
										
										
											2023-05-18 15:44:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  |   export let state: ThemeViewState | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   let map = state.map | 
					
						
							|  |  |  |   let mapproperties = state.mapProperties | 
					
						
							|  |  |  |   let userstate = state.userRelatedState | 
					
						
							|  |  |  |   let shown = state.guistate.pageStates.background | 
					
						
							|  |  |  |   let availableLayers: { store: Store<RasterLayerPolygon[]> } = state.availableLayers | 
					
						
							| 
									
										
										
										
											2024-08-11 16:27:00 +02:00
										 |  |  |   let _availableLayers = availableLayers.store | 
					
						
							| 
									
										
										
										
											2023-05-18 15:44:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-14 20:39:36 +02:00
										 |  |  |   type CategoryType = "photo" | "map" | "other" | "osmbasedmap" | 
					
						
							|  |  |  |   const categories: Record<CategoryType, EliCategory[]> = { | 
					
						
							|  |  |  |     photo: ["photo", "historicphoto"], | 
					
						
							|  |  |  |     map: ["map", "historicmap"], | 
					
						
							|  |  |  |     other: ["other", "elevation"], | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  |     osmbasedmap: ["osmbasedmap"] | 
					
						
							| 
									
										
										
										
											2023-06-14 20:39:36 +02:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2023-05-18 15:44:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-14 20:39:36 +02:00
										 |  |  |   function availableForCategory(type: CategoryType): Store<RasterLayerPolygon[]> { | 
					
						
							|  |  |  |     const keywords = categories[type] | 
					
						
							| 
									
										
										
										
											2024-08-11 16:27:00 +02:00
										 |  |  |     return _availableLayers.mapD((available) => | 
					
						
							| 
									
										
										
										
											2024-08-14 13:53:56 +02:00
										 |  |  |       available.filter((layer) => keywords.indexOf(<EliCategory>layer.properties.category) >= 0) | 
					
						
							| 
									
										
										
										
											2023-06-14 20:39:36 +02:00
										 |  |  |     ) | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2023-05-18 15:44:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-14 20:39:36 +02:00
										 |  |  |   const mapLayers = availableForCategory("map") | 
					
						
							|  |  |  |   const osmbasedmapLayers = availableForCategory("osmbasedmap") | 
					
						
							|  |  |  |   const photoLayers = availableForCategory("photo") | 
					
						
							|  |  |  |   const otherLayers = availableForCategory("other") | 
					
						
							| 
									
										
										
										
											2023-05-18 15:44:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-14 20:39:36 +02:00
										 |  |  |   function onApply() { | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  |     shown.setData(false) | 
					
						
							| 
									
										
										
										
											2023-06-14 20:39:36 +02:00
										 |  |  |   } | 
					
						
							| 
									
										
										
										
											2023-05-18 15:44:54 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-06-14 20:39:36 +02:00
										 |  |  |   function getPref(type: CategoryType): undefined | UIEventSource<string> { | 
					
						
							|  |  |  |     return userstate?.osmConnection?.GetPreference("preferred-layer-" + type) | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |   export let onlyLink: boolean | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-05-18 15:44:54 +02:00
										 |  |  | </script> | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  | <Page {onlyLink} shown={shown} fullscreen={true}> | 
					
						
							| 
									
										
										
										
											2024-08-29 03:53:54 +02:00
										 |  |  |   <div slot="header" class="flex" > | 
					
						
							|  |  |  |     <Square3Stack3dIcon class="h-6 w-6" /> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   <Tr t={Translations.t.general.backgroundMap} /> | 
					
						
							|  |  |  |   </div> | 
					
						
							| 
									
										
										
										
											2024-08-11 16:27:00 +02:00
										 |  |  |   {#if $_availableLayers?.length < 1} | 
					
						
							|  |  |  |     <Loading /> | 
					
						
							| 
									
										
										
										
											2024-08-14 13:53:56 +02:00
										 |  |  |   {:else} | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     <div class="flex gap-x-2 flex-col sm:flex-row gap-y-2" style="height: calc( 100% - 5rem)"> | 
					
						
							| 
									
										
										
										
											2024-08-11 16:27:00 +02:00
										 |  |  |       <RasterLayerPicker | 
					
						
							|  |  |  |         availableLayers={$photoLayers} | 
					
						
							|  |  |  |         favourite={getPref("photo")} | 
					
						
							|  |  |  |         {map} | 
					
						
							|  |  |  |         {mapproperties} | 
					
						
							|  |  |  |         on:appliedLayer={onApply} | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  |         {shown} | 
					
						
							| 
									
										
										
										
											2024-08-11 16:27:00 +02:00
										 |  |  |       /> | 
					
						
							|  |  |  |       <RasterLayerPicker | 
					
						
							|  |  |  |         availableLayers={$mapLayers} | 
					
						
							|  |  |  |         favourite={getPref("map")} | 
					
						
							|  |  |  |         {map} | 
					
						
							|  |  |  |         {mapproperties} | 
					
						
							|  |  |  |         on:appliedLayer={onApply} | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  |         {shown} | 
					
						
							| 
									
										
										
										
											2024-08-11 16:27:00 +02:00
										 |  |  |       /> | 
					
						
							|  |  |  |       <RasterLayerPicker | 
					
						
							|  |  |  |         availableLayers={$osmbasedmapLayers} | 
					
						
							|  |  |  |         favourite={getPref("osmbasedmap")} | 
					
						
							|  |  |  |         {map} | 
					
						
							|  |  |  |         {mapproperties} | 
					
						
							|  |  |  |         on:appliedLayer={onApply} | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  |         {shown} | 
					
						
							| 
									
										
										
										
											2024-08-11 16:27:00 +02:00
										 |  |  |       /> | 
					
						
							|  |  |  |       <RasterLayerPicker | 
					
						
							|  |  |  |         availableLayers={$otherLayers} | 
					
						
							|  |  |  |         favourite={getPref("other")} | 
					
						
							|  |  |  |         {map} | 
					
						
							|  |  |  |         {mapproperties} | 
					
						
							|  |  |  |         on:appliedLayer={onApply} | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  |         {shown} | 
					
						
							| 
									
										
										
										
											2024-08-11 16:27:00 +02:00
										 |  |  |       /> | 
					
						
							|  |  |  |     </div> | 
					
						
							|  |  |  |   {/if} | 
					
						
							| 
									
										
										
										
											2024-08-29 02:46:51 +02:00
										 |  |  | </Page> |