1
0
mirror of https://github.com/elk-zone/elk synced 2024-11-28 23:08:13 +09:00
elk/components/account/AccountHeader.vue

109 lines
3.7 KiB
Vue
Raw Normal View History

2022-11-15 12:26:52 +09:00
<script setup lang="ts">
2022-11-23 07:40:20 +09:00
import type { Account } from 'masto'
2022-11-15 12:26:52 +09:00
const { account } = defineProps<{
account: Account
}>()
const createdAt = $(useFormattedDateTime(() => account.createdAt, {
month: 'long',
day: 'numeric',
year: 'numeric',
}))
2022-11-24 15:41:29 +09:00
const fields = $computed(() => {
return [
...account.fields || [],
{
name: 'Joined',
value: createdAt,
},
]
})
const fieldNameIcons: Record<string, string> = {
github: 'i-ri:github-fill',
twitter: 'i-ri:twitter-line',
mastodon: 'i-ri:mastodon-line',
youtube: 'i-ri:youtube-line',
twitch: 'i-ri:twitch-line',
instagram: 'i-ri:instagram-line',
website: 'i-ri:link',
site: 'i-ri:link',
blog: 'i-ri:newspaper-line',
home: 'i-ri:home-2-line',
sponsors: 'i-ri:heart-3-line',
location: 'i-ri:map-pin-2-line',
city: 'i-ri:map-pin-2-line',
joined: 'i-ri:user-add-line',
birth: 'i-ri:calendar-line',
}
function getFieldNameIcon(fieldName: string) {
const name = fieldName.trim().toLowerCase()
if (fieldNameIcons[name])
return fieldNameIcons[name]
}
function previewHeader() {
openImagePreviewDialog({ src: account.header, alt: `${account.username}'s profile header` })
}
function previewAvatar() {
openImagePreviewDialog({ src: account.avatar, alt: account.username })
}
2022-11-15 12:26:52 +09:00
</script>
<template>
<div flex flex-col>
<button border="b base" z-1>
<img h-50 w-full object-cover :src="account.header" @click="previewHeader">
</button>
2022-11-23 16:46:34 +09:00
<div p4 mt--17 flex flex-col gap-6>
2022-11-15 12:26:52 +09:00
<div flex justify-between>
<div flex="~ col gap-2 1">
<button w-30 h-30 rounded-full bg-black z-2 @click="previewAvatar">
<AccountAvatar :account="account" hover:opacity-90 transition-opacity />
</button>
2022-11-23 23:39:48 +09:00
<div flex flex-col>
<ContentRich font-bold text-2xl break-words :content="getDisplayName(account, { rich: true })" :emojis="account.emojis" />
<AccountHandle :account="account" />
2022-11-23 23:39:48 +09:00
</div>
2022-11-15 12:26:52 +09:00
</div>
2022-11-23 23:39:48 +09:00
<div flex gap-2 items-center>
2022-11-25 20:39:21 +09:00
<AccountMoreButton :account="account" />
2022-11-23 07:40:20 +09:00
<AccountFollowButton :account="account" />
2022-11-21 22:45:09 +09:00
<!-- <button flex gap-1 items-center w-full rounded op75 hover="op100 text-purple" group>
2022-11-15 12:26:52 +09:00
<div rounded p2 group-hover="bg-rose/10">
<div i-ri:bell-line />
</div>
2022-11-21 22:45:09 +09:00
</button> -->
2022-11-15 12:26:52 +09:00
</div>
</div>
2022-11-24 19:36:22 +09:00
<div v-if="account.note">
<ContentRich text-4 text-secondary :content="account.note" :emojis="account.emojis" />
2022-11-15 12:26:52 +09:00
</div>
2022-11-24 15:41:29 +09:00
<div flex flex-wrap gap-4>
<div v-for="field in fields" :key="field.name" flex="~ gap-1" items-center >
<div v-if="getFieldNameIcon(field.name)" text-secondary :class="getFieldNameIcon(field.name)" :title="field.name" />
<div v-else text-secondary uppercase text-xs font-bold>
2022-11-24 15:41:29 +09:00
{{ field.name }} |
</div>
<ContentRich text-sm filter-saturate-0 :content="field.value" />
2022-11-15 12:26:52 +09:00
</div>
</div>
<div flex gap-5>
<NuxtLink :to="getAccountPath(account)" exact-active-class="text-primary">
<span font-bold>{{ formattedNumber(account.statusesCount) }}</span> <span text-secondary>Posts</span>
</NuxtLink>
<NuxtLink :to="`${getAccountPath(account)}/following`" exact-active-class="text-primary">
<span font-bold>{{ humanReadableNumber(account.followingCount) }}</span> <span text-secondary>Following</span>
</NuxtLink>
<NuxtLink :to="`${getAccountPath(account)}/followers`" exact-active-class="text-primary">
<span font-bold>{{ humanReadableNumber(account.followersCount) }}</span> <span text-secondary>Followers</span>
</NuxtLink>
2022-11-15 12:26:52 +09:00
</div>
</div>
</div>
</template>