mirror of
https://github.com/pheralb/svgl.git
synced 2025-12-29 08:01:36 +08:00
✨ Add ViewTransitions component to layout for improve navigation
This commit is contained in:
@@ -0,0 +1,12 @@
|
|||||||
|
<script lang="ts">
|
||||||
|
import { onNavigate } from "$app/navigation";
|
||||||
|
onNavigate((navigation) => {
|
||||||
|
if (!document.startViewTransition) return;
|
||||||
|
return new Promise((resolve) => {
|
||||||
|
document.startViewTransition(async () => {
|
||||||
|
resolve();
|
||||||
|
await navigation.complete;
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
||||||
|
</script>
|
||||||
@@ -10,12 +10,14 @@
|
|||||||
// Providers:
|
// Providers:
|
||||||
import { ModeWatcher } from "mode-watcher";
|
import { ModeWatcher } from "mode-watcher";
|
||||||
import Sidebar from "@/components/layout/sidebar.svelte";
|
import Sidebar from "@/components/layout/sidebar.svelte";
|
||||||
|
import ViewTransitions from "@/components/viewTransitions.svelte";
|
||||||
|
|
||||||
// SSR Data:
|
// SSR Data:
|
||||||
let { data, children }: LayoutProps = $props();
|
let { data, children }: LayoutProps = $props();
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<ModeWatcher />
|
<ModeWatcher />
|
||||||
|
<ViewTransitions />
|
||||||
<Header githubStars={data?.stars} />
|
<Header githubStars={data?.stars} />
|
||||||
<Sidebar>
|
<Sidebar>
|
||||||
{@render children?.()}
|
{@render children?.()}
|
||||||
|
|||||||
Reference in New Issue
Block a user