Files
gpx.studio/website/src/lib/components/layer-control/LayerControlSettings.svelte

148 lines
4.7 KiB
Svelte
Raw Normal View History

2024-04-14 15:36:41 +02:00
<script lang="ts">
import LayerTree from './LayerTree.svelte';
import { Separator } from '$lib/components/ui/separator';
import { ScrollArea } from '$lib/components/ui/scroll-area/index.js';
import * as Sheet from '$lib/components/ui/sheet';
2024-04-14 16:42:38 +02:00
import * as Accordion from '$lib/components/ui/accordion';
2024-06-06 18:11:03 +02:00
import { Label } from '$lib/components/ui/label';
import * as Select from '$lib/components/ui/select';
2024-04-14 15:36:41 +02:00
2024-05-05 18:59:09 +02:00
import { basemapTree, overlayTree } from '$lib/assets/layers';
2024-05-04 23:50:27 +02:00
import { settings } from '$lib/db';
2024-04-24 17:39:56 +02:00
import { _ } from 'svelte-i18n';
2024-06-06 18:11:03 +02:00
import { writable, get } from 'svelte/store';
import { map, setStravaHeatmapURLs } from '$lib/stores';
2024-06-06 18:40:08 +02:00
import { browser } from '$app/environment';
2024-06-26 17:19:41 +02:00
import CustomLayers from './CustomLayers.svelte';
2024-05-04 23:50:27 +02:00
2024-06-06 18:11:03 +02:00
const { selectedBasemapTree, selectedOverlayTree, stravaHeatmapColor, currentOverlays } =
settings;
2024-05-23 11:21:57 +02:00
export let open: boolean;
2024-06-06 18:11:03 +02:00
const heatmapColors = [
{ value: '', label: '' },
{ value: 'blue', label: $_('layers.color.blue') },
{ value: 'bluered', label: $_('layers.color.bluered') },
{ value: 'gray', label: $_('layers.color.gray') },
{ value: 'hot', label: $_('layers.color.hot') },
{ value: 'orange', label: $_('layers.color.orange') },
{ value: 'purple', label: $_('layers.color.purple') }
];
let selectedHeatmapColor = writable(heatmapColors[0]);
$: if ($selectedHeatmapColor !== heatmapColors[0]) {
stravaHeatmapColor.set($selectedHeatmapColor.value);
// remove and add the heatmap layers
let m = get(map);
if (m) {
let currentStravaLayers = [];
2024-06-18 14:23:59 +02:00
if (overlayTree.overlays.world.strava) {
for (let layer of Object.keys(overlayTree.overlays.world.strava)) {
if (m.getLayer(layer)) {
m.removeLayer(layer);
currentStravaLayers.push(layer);
}
if (m.getSource(layer)) {
m.removeSource(layer);
}
2024-06-06 18:11:03 +02:00
}
}
if (currentStravaLayers.length > 0) {
currentOverlays.update(($currentOverlays) => {
for (let layer of currentStravaLayers) {
$currentOverlays.overlays.world.strava[layer] = false;
}
return $currentOverlays;
});
currentOverlays.update(($currentOverlays) => {
for (let layer of currentStravaLayers) {
$currentOverlays.overlays.world.strava[layer] = true;
}
return $currentOverlays;
});
}
}
}
2024-06-06 18:40:08 +02:00
$: if ($stravaHeatmapColor && browser) {
2024-06-06 18:11:03 +02:00
setStravaHeatmapURLs();
if ($stravaHeatmapColor !== get(selectedHeatmapColor).value) {
let toSelect = heatmapColors.find(({ value }) => value === $stravaHeatmapColor);
if (toSelect) {
selectedHeatmapColor.set(toSelect);
}
}
}
2024-04-14 15:36:41 +02:00
</script>
2024-05-23 11:21:57 +02:00
<Sheet.Root bind:open>
<Sheet.Trigger class="hidden" />
2024-04-14 15:36:41 +02:00
<Sheet.Content>
2024-04-14 15:49:21 +02:00
<Sheet.Header class="h-full">
2024-04-24 17:39:56 +02:00
<Sheet.Title>{$_('layers.settings')}</Sheet.Title>
2024-04-14 15:36:41 +02:00
<Sheet.Description>
2024-04-24 17:39:56 +02:00
{$_('layers.settings_help')}
2024-04-14 15:36:41 +02:00
</Sheet.Description>
2024-04-14 16:42:38 +02:00
<Accordion.Root class="flex flex-col overflow-hidden">
<Accordion.Item value="item-1" class="flex flex-col overflow-hidden">
2024-04-24 17:39:56 +02:00
<Accordion.Trigger>{$_('layers.selection')}</Accordion.Trigger>
2024-04-15 10:33:47 +02:00
<Accordion.Content class="grow flex flex-col border rounded">
<ScrollArea class="py-2 pr-2">
2024-04-14 16:42:38 +02:00
<LayerTree
layerTree={basemapTree}
name="basemapSettings"
multiple={true}
2024-05-05 18:59:09 +02:00
bind:checked={$selectedBasemapTree}
2024-04-14 16:42:38 +02:00
/>
</ScrollArea>
2024-04-15 10:33:47 +02:00
<Separator />
<ScrollArea class="py-2 pr-2">
2024-04-14 16:42:38 +02:00
<LayerTree
layerTree={overlayTree}
name="overlaySettings"
multiple={true}
2024-05-05 18:59:09 +02:00
bind:checked={$selectedOverlayTree}
2024-04-14 16:42:38 +02:00
/>
</ScrollArea>
</Accordion.Content>
</Accordion.Item>
<Accordion.Item value="item-2">
2024-06-26 17:19:41 +02:00
<Accordion.Trigger>{$_('layers.custom_layers.title')}</Accordion.Trigger>
2024-04-14 16:42:38 +02:00
<Accordion.Content>
2024-06-26 17:19:41 +02:00
<ScrollArea>
<CustomLayers />
</ScrollArea>
2024-04-14 16:42:38 +02:00
</Accordion.Content>
</Accordion.Item>
<Accordion.Item value="item-3">
2024-04-24 17:39:56 +02:00
<Accordion.Trigger>{$_('layers.heatmap')}</Accordion.Trigger>
2024-06-10 17:55:48 +02:00
<Accordion.Content class="overflow-visible">
<Label class="flex flex-row items-center justify-between gap-4"
2024-06-19 16:15:21 +02:00
>{$_('menu.style.color')}
2024-06-10 17:55:48 +02:00
<Select.Root bind:selected={$selectedHeatmapColor}>
<Select.Trigger class="h-8 mr-1">
2024-06-06 18:11:03 +02:00
<Select.Value placeholder="Theme" />
</Select.Trigger>
<Select.Content>
{#each heatmapColors as { value, label }}
<Select.Item {value}>{label}</Select.Item>
{/each}
</Select.Content>
</Select.Root>
2024-06-10 17:55:48 +02:00
</Label>
2024-06-06 18:11:03 +02:00
</Accordion.Content>
2024-04-14 16:42:38 +02:00
</Accordion.Item>
<Accordion.Item value="item-4">
2024-04-24 17:39:56 +02:00
<Accordion.Trigger>{$_('layers.pois')}</Accordion.Trigger>
2024-04-14 16:42:38 +02:00
<Accordion.Content></Accordion.Content>
</Accordion.Item>
</Accordion.Root>
2024-04-14 15:36:41 +02:00
</Sheet.Header>
</Sheet.Content>
</Sheet.Root>