0
Fork 0
mirror of https://github.com/immich-app/immich.git synced 2025-01-21 00:52:43 -05:00

fix(web): nested layout navigation issue (#1936)

* fix(web): nested layout navigation issue

* move guarding to html template

* fix test
This commit is contained in:
Alex 2023-03-04 16:09:55 -06:00 committed by GitHub
parent bdf35b6688
commit 1918625be9
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 1066 additions and 721 deletions

1736
web/package-lock.json generated

File diff suppressed because it is too large Load diff

View file

@ -1,16 +1,17 @@
<script lang="ts">
import { fade } from 'svelte/transition';
import ImmichLogo from './immich-logo.svelte';
export let dropHandler: (event: DragEvent) => void;
let dragStartTarget: EventTarget | null = null;
const handleDragEnter = (e: DragEvent) => {
dragStartTarget = e.target;
};
</script>
<svelte:body
on:dragenter|stopPropagation|preventDefault={(e) => {
dragStartTarget = e.target;
}}
on:dragenter|stopPropagation|preventDefault={handleDragEnter}
on:dragleave|stopPropagation|preventDefault={(e) => {
if (dragStartTarget === e.target) {
dragStartTarget = null;

View file

@ -1,22 +0,0 @@
<script lang="ts">
import { page } from '$app/stores';
import { fileUploadHandler } from '$lib/utils/file-uploader';
import UploadCover from '$lib/components/shared-components/drag-and-drop-upload-overlay.svelte';
const dropHandler = async ({ dataTransfer }: DragEvent) => {
const files = dataTransfer?.files;
if (!files) {
return;
}
const filesArray: File[] = Array.from<File>(files);
const albumId =
($page.route.id === '/(user)/albums/[albumId]' || undefined) && $page.params.albumId;
await fileUploadHandler(filesArray, albumId);
};
</script>
<slot />
<UploadCover {dropHandler} />

View file

@ -10,8 +10,11 @@
import VersionAnnouncementBox from '$lib/components/shared-components/version-announcement-box.svelte';
import faviconUrl from '$lib/assets/favicon.png';
import type { LayoutData } from './$types';
import { fileUploadHandler } from '$lib/utils/file-uploader';
import UploadCover from '$lib/components/shared-components/drag-and-drop-upload-overlay.svelte';
let showNavigationLoadingBar = false;
export let data: LayoutData;
beforeNavigate(() => {
showNavigationLoadingBar = true;
@ -21,7 +24,18 @@
showNavigationLoadingBar = false;
});
export let data: LayoutData;
const dropHandler = async ({ dataTransfer }: DragEvent) => {
const files = dataTransfer?.files;
if (!files) {
return;
}
const filesArray: File[] = Array.from<File>(files);
const albumId =
($page.route.id === '/(user)/albums/[albumId]' || undefined) && $page.params.albumId;
await fileUploadHandler(filesArray, albumId);
};
</script>
<svelte:head>
@ -58,3 +72,7 @@
{#if data.user?.isAdmin}
<VersionAnnouncementBox serverVersion={data.serverVersion} />
{/if}
{#if $page.route.id?.includes('(user)')}
<UploadCover {dropHandler} />
{/if}