1
0
mirror of https://github.com/elk-zone/elk synced 2025-01-18 21:32:55 +09:00
elk/pages/@[user]/index.vue

34 lines
955 B
Vue
Raw Normal View History

2022-11-14 01:05:32 +09:00
<script setup lang="ts">
const props = defineProps<{
modelValue?: boolean
}>()
const params = useRoute().params
2022-11-15 21:08:49 +09:00
const user = $computed(() => params.user as string)
2022-11-23 08:08:36 +09:00
2022-11-15 21:08:49 +09:00
const { data: account } = await useAsyncData(`${user}:info`, () => masto.accounts.lookup({ acct: user }))
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(() => {
return masto.accounts.getStatusesIterable(account.value!.id!, { excludeReplies: tab === 'Posts' } as any)
})
2022-11-14 01:05:32 +09:00
</script>
<template>
2022-11-24 02:16:10 +09: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-14 01:05:32 +09:00
</template>