mirror of
https://github.com/immich-app/immich.git
synced 2025-05-24 01:12:58 -04:00
fix: map (#18399)
This commit is contained in:
parent
53420b7c02
commit
12b7a079c1
@ -1,7 +1,5 @@
|
|||||||
<script lang="ts">
|
<script lang="ts">
|
||||||
import { clickOutside } from '$lib/actions/click-outside';
|
|
||||||
import CircleIconButton from '$lib/components/elements/buttons/circle-icon-button.svelte';
|
import CircleIconButton from '$lib/components/elements/buttons/circle-icon-button.svelte';
|
||||||
import type Map from '$lib/components/shared-components/map/map.svelte';
|
|
||||||
import Portal from '$lib/components/shared-components/portal/portal.svelte';
|
import Portal from '$lib/components/shared-components/portal/portal.svelte';
|
||||||
import { timeToLoadTheMap } from '$lib/constants';
|
import { timeToLoadTheMap } from '$lib/constants';
|
||||||
import { albumMapViewManager } from '$lib/managers/album-view-map.manager.svelte';
|
import { albumMapViewManager } from '$lib/managers/album-view-map.manager.svelte';
|
||||||
@ -25,8 +23,6 @@
|
|||||||
let viewingAssets: string[] = $state([]);
|
let viewingAssets: string[] = $state([]);
|
||||||
let viewingAssetCursor = 0;
|
let viewingAssetCursor = 0;
|
||||||
|
|
||||||
let mapElement = $state<ReturnType<typeof Map>>();
|
|
||||||
|
|
||||||
let zoom = $derived(1);
|
let zoom = $derived(1);
|
||||||
let mapMarkers: MapMarkerResponseDto[] = $state([]);
|
let mapMarkers: MapMarkerResponseDto[] = $state([]);
|
||||||
|
|
||||||
@ -77,6 +73,7 @@
|
|||||||
async function onViewAssets(assetIds: string[]) {
|
async function onViewAssets(assetIds: string[]) {
|
||||||
viewingAssets = assetIds;
|
viewingAssets = assetIds;
|
||||||
viewingAssetCursor = 0;
|
viewingAssetCursor = 0;
|
||||||
|
closeMap();
|
||||||
|
|
||||||
await setAssetId(assetIds[0]);
|
await setAssetId(assetIds[0]);
|
||||||
}
|
}
|
||||||
@ -110,7 +107,6 @@
|
|||||||
<CircleIconButton title={$t('map')} onclick={openMap} icon={mdiMapOutline} />
|
<CircleIconButton title={$t('map')} onclick={openMap} icon={mdiMapOutline} />
|
||||||
|
|
||||||
{#if albumMapViewManager.isInMapView}
|
{#if albumMapViewManager.isInMapView}
|
||||||
<div use:clickOutside={{ onOutclick: closeMap }}>
|
|
||||||
<Modal title={$t('map')} size="medium" onClose={closeMap}>
|
<Modal title={$t('map')} size="medium" onClose={closeMap}>
|
||||||
<ModalBody>
|
<ModalBody>
|
||||||
<div class="flex flex-col w-full h-full gap-2 border border-gray-300 dark:border-light rounded-2xl">
|
<div class="flex flex-col w-full h-full gap-2 border border-gray-300 dark:border-light rounded-2xl">
|
||||||
@ -124,7 +120,6 @@
|
|||||||
{/await}
|
{/await}
|
||||||
{:then { default: Map }}
|
{:then { default: Map }}
|
||||||
<Map
|
<Map
|
||||||
bind:this={mapElement}
|
|
||||||
center={undefined}
|
center={undefined}
|
||||||
{zoom}
|
{zoom}
|
||||||
clickable={false}
|
clickable={false}
|
||||||
@ -138,7 +133,6 @@
|
|||||||
</div>
|
</div>
|
||||||
</ModalBody>
|
</ModalBody>
|
||||||
</Modal>
|
</Modal>
|
||||||
</div>
|
|
||||||
|
|
||||||
<Portal target="body">
|
<Portal target="body">
|
||||||
{#if $showAssetViewer}
|
{#if $showAssetViewer}
|
||||||
|
@ -57,7 +57,7 @@
|
|||||||
}
|
}
|
||||||
|
|
||||||
let {
|
let {
|
||||||
mapMarkers = $bindable([]),
|
mapMarkers = $bindable(),
|
||||||
showSettings = true,
|
showSettings = true,
|
||||||
zoom = undefined,
|
zoom = undefined,
|
||||||
center = $bindable(undefined),
|
center = $bindable(undefined),
|
||||||
@ -210,11 +210,13 @@
|
|||||||
};
|
};
|
||||||
|
|
||||||
onMount(async () => {
|
onMount(async () => {
|
||||||
|
if (!mapMarkers) {
|
||||||
mapMarkers = await loadMapMarkers();
|
mapMarkers = await loadMapMarkers();
|
||||||
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
onDestroy(() => {
|
onDestroy(() => {
|
||||||
abortController.abort();
|
abortController?.abort();
|
||||||
});
|
});
|
||||||
|
|
||||||
$effect(() => {
|
$effect(() => {
|
||||||
@ -296,7 +298,7 @@
|
|||||||
<GeoJSON
|
<GeoJSON
|
||||||
data={{
|
data={{
|
||||||
type: 'FeatureCollection',
|
type: 'FeatureCollection',
|
||||||
features: mapMarkers.map((marker) => asFeature(marker)),
|
features: mapMarkers?.map((marker) => asFeature(marker)) ?? [],
|
||||||
}}
|
}}
|
||||||
id="geojson"
|
id="geojson"
|
||||||
cluster={{ radius: 35, maxZoom: 17 }}
|
cluster={{ radius: 35, maxZoom: 17 }}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user