1
0
elk/pages/home.vue

38 lines
940 B
Vue
Raw Normal View History

<script setup lang="ts">
2022-11-28 19:14:58 +09:00
import { useI18n } from 'vue-i18n'
definePageMeta({
middleware: 'auth',
alias: ['/signin/callback'],
})
if (useRoute().path === '/signin/callback') {
// This only cleans up the URL; page content should stay the same
useRouter().push('/home')
}
2022-12-03 14:36:10 +09:00
const paginator = useMasto().timelines.iterateHome()
const stream = await useMasto().stream.streamUser()
onBeforeUnmount(() => stream.disconnect())
2022-11-28 19:14:58 +09:00
const { t } = useI18n()
useHeadFixed({
2022-11-28 19:14:58 +09:00
title: () => t('nav_side.home'),
})
</script>
<template>
<MainContent>
<template #title>
2022-11-30 05:15:53 +09:00
<NuxtLink to="/home" text-lg font-bold flex items-center gap-2 @click="$scrollToTop">
<div i-ri:home-5-line />
<span>{{ $t('nav_side.home') }}</span>
</NuxtLink>
</template>
<slot>
2022-11-24 16:53:27 +09:00
<PublishWidget draft-key="home" border="b base" />
<TimelinePaginator v-bind="{ paginator, stream }" />
</slot>
</MainContent>
</template>