2022-11-13 17:05:32 +01:00
|
|
|
<script setup lang="ts">
|
|
|
|
const props = defineProps<{
|
|
|
|
modelValue?: boolean
|
|
|
|
}>()
|
|
|
|
|
|
|
|
const params = useRoute().params
|
2022-11-15 13:08:49 +01:00
|
|
|
const user = $computed(() => params.user as string)
|
2022-11-23 00:08:36 +01:00
|
|
|
|
2022-11-15 13:08:49 +01:00
|
|
|
const { data: account } = await useAsyncData(`${user}:info`, () => masto.accounts.lookup({ acct: user }))
|
2022-11-20 22:38:52 +01:00
|
|
|
|
|
|
|
const tabNames = ['Posts', 'Posts and replies'] as const
|
|
|
|
|
|
|
|
// Don't use local storage because it is better to default to Posts every time you visit a user's profile.
|
|
|
|
const tab = $ref('Posts')
|
|
|
|
|
|
|
|
const paginator = $computed(() => {
|
2022-11-21 09:07:20 +01:00
|
|
|
return masto.accounts.getStatusesIterable(account.value!.id!, { excludeReplies: tab === 'Posts' } as any)
|
2022-11-20 22:38:52 +01:00
|
|
|
})
|
2022-11-13 17:05:32 +01:00
|
|
|
</script>
|
|
|
|
|
|
|
|
<template>
|
2022-11-23 18:16:10 +01:00
|
|
|
<template v-if="account">
|
|
|
|
<div>
|
|
|
|
<AccountHeader :account="account" />
|
|
|
|
</div>
|
|
|
|
<CommonTabs v-model="tab" :options="tabNames" />
|
|
|
|
<TimelinePaginator :key="tab" :paginator="paginator" />
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<CommonNotFound v-else>
|
|
|
|
Account @{{ params.user }} not found
|
|
|
|
</CommonNotFound>
|
2022-11-13 17:05:32 +01:00
|
|
|
</template>
|