2022-11-26 00:49:56 +01:00
|
|
|
<script setup lang="ts">
|
2022-11-30 17:15:18 +00:00
|
|
|
import type { Account } from 'masto'
|
2022-12-13 22:01:25 +01:00
|
|
|
import AccountTabs from '~/components/account/AccountTabs.vue'
|
2022-11-30 17:15:18 +00:00
|
|
|
|
2022-11-26 00:49:56 +01:00
|
|
|
const params = useRoute().params
|
2022-11-30 15:08:10 +08:00
|
|
|
const handle = $(computedEager(() => params.account as string))
|
2022-11-26 00:49:56 +01:00
|
|
|
|
2022-11-30 17:15:18 +00:00
|
|
|
definePageMeta({ name: 'account-index' })
|
|
|
|
|
2022-12-13 22:01:25 +01:00
|
|
|
const { t } = useI18n()
|
|
|
|
|
2022-11-30 17:15:18 +00:00
|
|
|
const { data: account } = await useAsyncData(`account:${handle}`, async () => (
|
|
|
|
window.history.state?.account as Account | undefined)
|
2022-12-13 22:01:25 +01:00
|
|
|
?? await fetchAccountByHandle(handle),
|
2022-11-30 17:15:18 +00:00
|
|
|
)
|
2022-11-26 00:49:56 +01:00
|
|
|
|
2022-12-13 22:01:25 +01:00
|
|
|
const paginator = useMasto().accounts.iterateStatuses(account.value!.id, { excludeReplies: true })
|
2022-11-26 12:36:23 -05:00
|
|
|
|
2022-12-13 22:01:25 +01:00
|
|
|
if (account) {
|
|
|
|
useHeadFixed({
|
|
|
|
title: () => `${t('account.posts')} | ${getDisplayName(account.value!)} (@${account.value!.acct})`,
|
|
|
|
})
|
|
|
|
}
|
2022-11-26 00:49:56 +01:00
|
|
|
</script>
|
|
|
|
|
|
|
|
<template>
|
2022-12-03 13:42:00 +08:00
|
|
|
<div>
|
2022-12-13 22:01:25 +01:00
|
|
|
<AccountTabs />
|
|
|
|
<TimelinePaginator :paginator="paginator" context="account" />
|
2022-11-26 00:49:56 +01:00
|
|
|
</div>
|
|
|
|
</template>
|