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

74 lines
2.4 KiB
Svelte
Raw Normal View History

2024-04-14 15:36:41 +02:00
<script lang="ts">
import LayerTree from './LayerTree.svelte';
import { Button } from '$lib/components/ui/button';
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-04-14 15:36:41 +02:00
2024-04-15 10:33:47 +02:00
import { Settings } from 'lucide-svelte';
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-05-04 23:50:27 +02:00
const { selectedBasemapTree, selectedOverlayTree } = settings;
2024-04-14 15:36:41 +02:00
</script>
<Sheet.Root>
<Sheet.Trigger class="w-full">
2024-04-15 10:33:47 +02:00
<Button variant="ghost" class="w-full px-1 py-1.5">
<Settings size="18" class="mr-2" />
2024-04-24 17:39:56 +02:00
{$_('layers.manage')}
2024-04-14 15:36:41 +02:00
</Button>
</Sheet.Trigger>
<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-04-24 17:39:56 +02:00
<Accordion.Trigger>{$_('layers.custom_layers')}</Accordion.Trigger>
2024-04-14 16:42:38 +02:00
<Accordion.Content>
2024-04-15 10:33:47 +02:00
<ScrollArea>TODO custom layer list + new custom layer form</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-04-14 16:42:38 +02:00
<Accordion.Content></Accordion.Content>
</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>