forked from Mirrors/elk
62 lines
1.8 KiB
Vue
62 lines
1.8 KiB
Vue
<script lang="ts" setup>
|
|
import type { Account } from 'masto'
|
|
const { account, as = 'div' } = $defineProps<{
|
|
account: Account
|
|
as?: string
|
|
}>()
|
|
|
|
cacheAccount(account)
|
|
|
|
defineOptions({
|
|
inheritAttrs: false,
|
|
})
|
|
</script>
|
|
|
|
<template>
|
|
<component :is="as" block focus:outline-none focus-visible:ring="2 primary" v-bind="$attrs">
|
|
<!-- Banner -->
|
|
<div px2 pt2>
|
|
<div rounded of-hidden bg="gray-500/20" aspect="3.19">
|
|
<img h-full w-full object-cover :src="account.header" :alt="$t('account.profile_description', [account.username])">
|
|
</div>
|
|
</div>
|
|
<div px-4 pb-4 space-y-2>
|
|
<!-- User info -->
|
|
<div flex sm:flex-row flex-col flex-gap-2>
|
|
<div flex items-center justify-between>
|
|
<div w-17 h-17 rounded-full border-4 border-bg-base z-2 mt--2 ml--1>
|
|
<AccountAvatar :account="account" />
|
|
</div>
|
|
<a block sm:hidden href="javascript:;" @click.stop>
|
|
<AccountFollowButton :account="account" />
|
|
</a>
|
|
</div>
|
|
<div sm:mt-2>
|
|
<div>
|
|
<ContentRich
|
|
font-bold text-lg line-clamp-1 ws-pre-wrap break-all
|
|
:content="getDisplayName(account, { rich: true })"
|
|
:emojis="account.emojis"
|
|
/>
|
|
</div>
|
|
<AccountHandle text-sm :account="account" />
|
|
</div>
|
|
</div>
|
|
<!-- Note -->
|
|
<div v-if="account.note" max-h-100 overflow-y-auto>
|
|
<ContentRich
|
|
:content="account.note" :emojis="account.emojis"
|
|
line-clamp-2
|
|
/>
|
|
</div>
|
|
<!-- Follow info -->
|
|
<div flex justify-between items-center>
|
|
<AccountPostsFollowers text-sm :account="account" />
|
|
<a sm:block hidden href="javascript:;" @click.stop>
|
|
<AccountFollowButton :account="account" />
|
|
</a>
|
|
</div>
|
|
</div>
|
|
</component>
|
|
</template>
|