Files
gpx.studio/website/src/lib/components/street-view-control/StreetViewControl.svelte

63 lines
1.6 KiB
Svelte
Raw Normal View History

2024-06-24 19:41:44 +02:00
<script lang="ts">
import CustomControl from '$lib/components/custom-control/CustomControl.svelte';
import { Toggle } from '$lib/components/ui/toggle';
2024-07-16 16:16:53 +02:00
import { PersonStanding, X } from 'lucide-svelte';
2024-06-24 19:41:44 +02:00
import { MapillaryLayer } from './Mapillary';
import { GoogleRedirect } from './Google';
import { map, streetViewEnabled } from '$lib/stores';
import { settings } from '$lib/db';
const { streetViewSource } = settings;
let googleRedirect: GoogleRedirect;
let mapillaryLayer: MapillaryLayer;
2024-07-16 16:16:53 +02:00
let container: HTMLElement;
2024-06-24 19:41:44 +02:00
$: if ($map) {
googleRedirect = new GoogleRedirect($map);
2024-07-16 16:16:53 +02:00
mapillaryLayer = new MapillaryLayer($map, container);
2024-06-24 19:41:44 +02:00
}
$: if (mapillaryLayer) {
if ($streetViewSource === 'mapillary') {
googleRedirect.remove();
if ($streetViewEnabled) {
mapillaryLayer.add();
} else {
mapillaryLayer.remove();
}
} else {
mapillaryLayer.remove();
if ($streetViewEnabled) {
googleRedirect.add();
} else {
googleRedirect.remove();
}
}
}
</script>
2024-06-27 15:50:15 +02:00
<CustomControl class="w-[29px] h-[29px] shrink-0">
2024-06-24 19:41:44 +02:00
<Toggle bind:pressed={$streetViewEnabled} class="w-full h-full rounded p-0">
<PersonStanding size="22" />
</Toggle>
</CustomControl>
2024-07-16 16:16:53 +02:00
<div
bind:this={container}
class="hidden relative w-[50vw] h-[40vh] rounded-md border-background border-2"
>
<!-- svelte-ignore a11y-click-events-have-key-events -->
<!-- svelte-ignore a11y-no-static-element-interactions -->
<div
class="absolute top-0 right-0 z-10 bg-background p-1 rounded-bl-md cursor-pointer"
on:click={() => {
if (mapillaryLayer) {
mapillaryLayer.closePopup();
}
}}
>
<X size="16" />
</div>
</div>