diff options
Diffstat (limited to 'src/lib/Home/HeadTitle.svelte')
| -rw-r--r-- | src/lib/Home/HeadTitle.svelte | 21 |
1 files changed, 18 insertions, 3 deletions
diff --git a/src/lib/Home/HeadTitle.svelte b/src/lib/Home/HeadTitle.svelte index 0759943f..73cf3e3d 100644 --- a/src/lib/Home/HeadTitle.svelte +++ b/src/lib/Home/HeadTitle.svelte @@ -1,9 +1,24 @@ <script lang="ts"> import { siteUrl } from "$lib/Utility/appOrigin"; +import locale from "$stores/locale"; +import type { Locale } from "$lib/Locale/layout"; -let { route = undefined, path = "/" }: { route?: string; path?: string } = - $props(); -const title = $derived((route ? `${route} • ` : "") + "due.moe"); +type HeadTitleKey = keyof NonNullable<Locale["headTitle"]>; + +let { + route = undefined, + routeKey = undefined, + path = "/", +}: { + route?: string; + routeKey?: HeadTitleKey; + path?: string; +} = $props(); + +const resolved = $derived( + routeKey ? ($locale().headTitle?.[routeKey] ?? routeKey) : route, +); +const title = $derived((resolved ? `${resolved} • ` : "") + "due.moe"); </script> <svelte:head> |