mirror of
https://github.com/Drop-OSS/drop.git
synced 2025-11-09 20:12:10 +10:00
35 lines
922 B
Vue
35 lines
922 B
Vue
<template>
|
|
<div v-if="!noWrapper" class="flex flex-col w-full min-h-screen bg-zinc-900">
|
|
<LazyUserHeader class="z-50" hydrate-on-idle />
|
|
<div class="grow flex">
|
|
<NuxtPage />
|
|
</div>
|
|
<LazyUserFooter class="z-50" hydrate-on-interaction />
|
|
</div>
|
|
<div v-else class="flex w-full min-h-screen bg-zinc-900">
|
|
<NuxtPage />
|
|
</div>
|
|
</template>
|
|
|
|
<script setup lang="ts">
|
|
const route = useRoute();
|
|
const i18nHead = useLocaleHead();
|
|
const noWrapper = !!route.query.noWrapper;
|
|
|
|
const { t } = useI18n();
|
|
|
|
useHead({
|
|
htmlAttrs: {
|
|
lang: i18nHead.value.htmlAttrs.lang,
|
|
// @ts-expect-error head.value.htmlAttrs.dir is not typed as strictly as it should be
|
|
dir: i18nHead.value.htmlAttrs.dir,
|
|
},
|
|
// // seo headers
|
|
// link: [...i18nHead.value.link],
|
|
// meta: [...i18nHead.value.meta],
|
|
titleTemplate(title) {
|
|
return title ? t("titleTemplate", [title]) : t("title");
|
|
},
|
|
});
|
|
</script>
|