MapComplete/src/UI/Map/RasterLayerPicker.svelte

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

100 lines
2.8 KiB
Svelte
Raw Normal View History

<script lang="ts">
import type { RasterLayerPolygon } from "../../Models/RasterLayers"
import OverlayMap from "./OverlayMap.svelte"
import type { MapProperties } from "../../Models/MapProperties"
import { Store, UIEventSource } from "../../Logic/UIEventSource"
import { Map as MlMap } from "maplibre-gl"
import { createEventDispatcher, onDestroy } from "svelte"
/***
* Chooses a background-layer out of available options
*/
export let availableLayers: Store<RasterLayerPolygon[]>
export let mapproperties: MapProperties
export let map: Store<MlMap>
2023-05-18 15:44:54 +02:00
export let visible: Store<boolean> = undefined
2023-05-18 15:44:54 +02:00
let dispatch = createEventDispatcher<{ appliedLayer }>()
export let favourite: UIEventSource<string> | undefined = undefined
let rasterLayer = new UIEventSource<RasterLayerPolygon>(availableLayers.data?.[0])
let hasLayers = true
onDestroy(
availableLayers.addCallbackAndRun((layers) => {
if (layers === undefined || layers.length === 0) {
hasLayers = false
return
}
hasLayers = true
rasterLayer.setData(layers[0])
})
)
if (favourite) {
onDestroy(
favourite.addCallbackAndRunD((favourite) => {
const fav = availableLayers.data?.find((l) => l.properties.id === favourite)
if (!fav) {
return
2023-05-18 15:44:54 +02:00
}
rasterLayer.setData(fav)
})
)
2023-05-18 15:44:54 +02:00
onDestroy(
rasterLayer.addCallbackAndRunD((selected) => {
favourite?.setData(selected.properties.id)
})
)
}
let rasterLayerOnMap = UIEventSource.feedFrom(rasterLayer)
if (visible) {
onDestroy(
visible?.addCallbackAndRunD((visible) => {
if (visible) {
rasterLayerOnMap.setData(rasterLayer.data ?? availableLayers.data[0])
} else {
rasterLayerOnMap.setData(undefined)
}
})
)
}
function apply() {
mapproperties.rasterLayer.setData(rasterLayer.data)
dispatch("appliedLayer")
}
2024-02-20 13:33:38 +01:00
function handleKeyPress(e: KeyboardEvent) {
if (e.key === "Enter") {
apply()
}
}
</script>
2023-05-18 15:44:54 +02:00
{#if hasLayers}
<form class="flex h-full w-full flex-col" on:submit|preventDefault={() => {}}>
2024-02-20 13:33:38 +01:00
<button tabindex="-1" on:click={() => apply()} class="m-0 h-full w-full cursor-pointer p-1">
2024-04-13 02:40:21 +02:00
<span class="pointer-events-none relative h-full w-full">
2024-02-20 13:33:38 +01:00
<OverlayMap
interactive={false}
rasterLayer={rasterLayerOnMap}
placedOverMap={map}
placedOverMapProperties={mapproperties}
{visible}
/>
2024-02-21 17:33:29 +01:00
</span>
</button>
<select bind:value={$rasterLayer} class="w-full" on:keydown={handleKeyPress}>
{#each $availableLayers as availableLayer}
<option value={availableLayer}>
{availableLayer.properties.name}
</option>
{/each}
</select>
</form>
2023-05-18 15:44:54 +02:00
{/if}