mirror of
https://github.com/gpxstudio/gpx.studio.git
synced 2025-10-15 20:08:19 +00:00
44 lines
1.6 KiB
Svelte
44 lines
1.6 KiB
Svelte
<script lang="ts">
|
|
import type { TrackPoint } from 'gpx';
|
|
import type { PopupItem } from '$lib/components/MapPopup';
|
|
import CopyCoordinates from '$lib/components/gpx-layer/CopyCoordinates.svelte';
|
|
import * as Card from '$lib/components/ui/card';
|
|
import WithUnits from '$lib/components/WithUnits.svelte';
|
|
import { Compass, Mountain, Timer } from 'lucide-svelte';
|
|
import { df } from '$lib/utils';
|
|
import { _ } from 'svelte-i18n';
|
|
|
|
export let trackpoint: PopupItem<TrackPoint>;
|
|
</script>
|
|
|
|
<Card.Root class="border-none shadow-md text-base p-2">
|
|
<Card.Header class="p-0">
|
|
<Card.Title class="text-md"></Card.Title>
|
|
</Card.Header>
|
|
<Card.Content class="flex flex-col p-0 text-xs gap-1">
|
|
<div class="flex flex-row items-center gap-1">
|
|
<Compass size="14" />
|
|
{trackpoint.item.getLatitude().toFixed(6)}° {trackpoint.item
|
|
.getLongitude()
|
|
.toFixed(6)}°
|
|
</div>
|
|
{#if trackpoint.item.ele !== undefined}
|
|
<div class="flex flex-row items-center gap-1">
|
|
<Mountain size="14" />
|
|
<WithUnits value={trackpoint.item.ele} type="elevation" />
|
|
</div>
|
|
{/if}
|
|
{#if trackpoint.item.time}
|
|
<div class="flex flex-row items-center gap-1">
|
|
<Timer size="14" />
|
|
{df.format(trackpoint.item.time)}
|
|
</div>
|
|
{/if}
|
|
<CopyCoordinates
|
|
coordinates={trackpoint.item.attributes}
|
|
onCopy={() => trackpoint.hide?.()}
|
|
class="mt-0.5"
|
|
/>
|
|
</Card.Content>
|
|
</Card.Root>
|