2022-11-15 04:26:52 +01:00
|
|
|
<script setup lang="ts">
|
2023-01-08 07:21:09 +01:00
|
|
|
import type { mastodon } from 'masto'
|
2022-11-15 04:26:52 +01:00
|
|
|
|
|
|
|
const { account } = defineProps<{
|
2023-01-08 07:21:09 +01:00
|
|
|
account: mastodon.v1.Account
|
2022-11-29 09:15:05 +01:00
|
|
|
command?: boolean
|
2022-11-15 04:26:52 +01:00
|
|
|
}>()
|
|
|
|
|
2023-01-15 09:38:02 +01:00
|
|
|
const { client } = $(useMasto())
|
2023-01-13 15:53:40 +01:00
|
|
|
|
2022-12-02 03:18:36 +01:00
|
|
|
const { t } = useI18n()
|
|
|
|
|
2022-11-26 09:34:24 +01:00
|
|
|
const createdAt = $(useFormattedDateTime(() => account.createdAt, {
|
|
|
|
month: 'long',
|
|
|
|
day: 'numeric',
|
|
|
|
year: 'numeric',
|
|
|
|
}))
|
2022-11-24 07:41:29 +01:00
|
|
|
|
2023-01-13 15:53:40 +01:00
|
|
|
const relationship = $(useRelationship(account))
|
|
|
|
|
2023-01-08 07:21:09 +01:00
|
|
|
const namedFields = ref<mastodon.v1.AccountField[]>([])
|
|
|
|
const iconFields = ref<mastodon.v1.AccountField[]>([])
|
2023-01-19 11:26:40 +01:00
|
|
|
const hasHeader = $computed(() => !account.header.endsWith('/original/missing.png'))
|
2022-11-24 07:41:29 +01:00
|
|
|
|
2022-12-02 03:18:36 +01:00
|
|
|
function getFieldIconTitle(fieldName: string) {
|
|
|
|
return fieldName === 'Joined' ? t('account.joined') : fieldName
|
|
|
|
}
|
2022-11-25 19:13:44 +01:00
|
|
|
|
2023-01-17 13:57:24 +01:00
|
|
|
function getNotificationIconTitle() {
|
|
|
|
return relationship?.notifying ? t('account.notifications_on_post_disable', { username: `@${account.username}` }) : t('account.notifications_on_post_enable', { username: `@${account.username}` })
|
|
|
|
}
|
|
|
|
|
2022-11-25 19:13:44 +01:00
|
|
|
function previewHeader() {
|
2022-11-30 04:27:19 +01:00
|
|
|
openMediaPreview([{
|
|
|
|
id: `${account.acct}:header`,
|
|
|
|
type: 'image',
|
|
|
|
previewUrl: account.header,
|
2022-12-02 03:18:36 +01:00
|
|
|
description: t('account.profile_description', [account.username]),
|
2022-11-30 04:27:19 +01:00
|
|
|
}])
|
2022-11-25 19:13:44 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
function previewAvatar() {
|
2022-11-30 04:27:19 +01:00
|
|
|
openMediaPreview([{
|
|
|
|
id: `${account.acct}:avatar`,
|
|
|
|
type: 'image',
|
|
|
|
previewUrl: account.avatar,
|
2022-12-02 03:18:36 +01:00
|
|
|
description: t('account.avatar_description', [account.username]),
|
2022-11-30 04:27:19 +01:00
|
|
|
}])
|
2022-11-25 19:13:44 +01:00
|
|
|
}
|
2022-11-27 08:44:47 +01:00
|
|
|
|
2023-01-15 11:00:39 +01:00
|
|
|
async function toggleNotifications() {
|
|
|
|
relationship!.notifying = !relationship?.notifying
|
2023-01-13 15:53:40 +01:00
|
|
|
try {
|
2023-01-15 11:00:39 +01:00
|
|
|
const newRel = await client.v1.accounts.follow(account.id, { notify: relationship?.notifying })
|
2023-01-13 15:53:40 +01:00
|
|
|
Object.assign(relationship!, newRel)
|
|
|
|
}
|
|
|
|
catch {
|
|
|
|
// TODO error handling
|
2023-01-15 11:00:39 +01:00
|
|
|
relationship!.notifying = !relationship?.notifying
|
2023-01-13 15:53:40 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2022-11-27 08:44:47 +01:00
|
|
|
watchEffect(() => {
|
2023-01-08 07:21:09 +01:00
|
|
|
const named: mastodon.v1.AccountField[] = []
|
|
|
|
const icons: mastodon.v1.AccountField[] = []
|
2022-11-27 08:44:47 +01:00
|
|
|
|
|
|
|
account.fields?.forEach((field) => {
|
2023-01-02 16:00:11 +01:00
|
|
|
const icon = getAccountFieldIcon(field.name)
|
2022-11-27 08:44:47 +01:00
|
|
|
if (icon)
|
|
|
|
icons.push(field)
|
|
|
|
else
|
|
|
|
named.push(field)
|
|
|
|
})
|
|
|
|
icons.push({
|
|
|
|
name: 'Joined',
|
|
|
|
value: createdAt,
|
|
|
|
})
|
|
|
|
|
|
|
|
namedFields.value = named
|
|
|
|
iconFields.value = icons
|
|
|
|
})
|
2022-12-26 09:50:11 +01:00
|
|
|
|
2023-01-14 14:04:44 +01:00
|
|
|
const isSelf = $(useSelfAccount(() => account))
|
2023-01-15 11:00:39 +01:00
|
|
|
const isNotifiedOnPost = $computed(() => !!relationship?.notifying)
|
2022-11-15 04:26:52 +01:00
|
|
|
</script>
|
|
|
|
|
|
|
|
<template>
|
|
|
|
<div flex flex-col>
|
2023-01-19 11:26:40 +01:00
|
|
|
<component :is="hasHeader ? 'button' : 'div'" border="b base" z-1 @click="hasHeader ? previewHeader() : undefined">
|
|
|
|
<img h-50 height="200" w-full object-cover :src="account.header" :alt="t('account.profile_description', [account.username])">
|
|
|
|
</component>
|
2022-11-29 21:04:23 +01:00
|
|
|
<div p4 mt--18 flex flex-col gap-4>
|
2022-11-27 13:20:03 +01:00
|
|
|
<div relative>
|
2022-11-25 19:13:44 +01:00
|
|
|
<div flex="~ col gap-2 1">
|
2023-01-11 09:39:49 +01:00
|
|
|
<button :class="{ 'rounded-full': !isSelf, 'squircle': isSelf }" w-30 h-30 p1 bg-base border-bg-base z-2 @click="previewAvatar">
|
|
|
|
<AccountAvatar :square="isSelf" :account="account" hover:opacity-90 transition-opacity />
|
2022-11-25 19:13:44 +01:00
|
|
|
</button>
|
2023-01-06 20:12:00 +01:00
|
|
|
<div flex="~ col gap1">
|
2022-12-11 16:43:23 +01:00
|
|
|
<div flex justify-between>
|
2023-01-06 20:12:00 +01:00
|
|
|
<AccountDisplayName :account="account" font-bold sm:text-2xl text-xl />
|
2023-01-07 14:53:09 +01:00
|
|
|
<AccountBotIndicator v-if="account.bot" show-label />
|
2022-12-11 16:43:23 +01:00
|
|
|
</div>
|
2022-11-26 21:41:18 +01:00
|
|
|
<AccountHandle :account="account" />
|
2022-11-23 15:39:48 +01:00
|
|
|
</div>
|
2022-11-15 04:26:52 +01:00
|
|
|
</div>
|
2023-01-01 15:29:11 +01:00
|
|
|
<div absolute top-18 inset-ie-0 flex gap-2 items-center>
|
2022-11-29 09:15:05 +01:00
|
|
|
<AccountMoreButton :account="account" :command="command" />
|
2023-01-17 13:57:24 +01:00
|
|
|
<CommonTooltip v-if="!isSelf && relationship?.following" :content="getNotificationIconTitle()">
|
|
|
|
<button
|
|
|
|
:aria-pressed="isNotifiedOnPost"
|
|
|
|
:aria-label="t('account.notifications_on_post_enable', { username: `@${account.username}` })"
|
2023-01-23 12:05:46 +01:00
|
|
|
rounded-full text-sm p2 border-1 transition-colors
|
2023-01-17 13:57:24 +01:00
|
|
|
:class="isNotifiedOnPost ? 'text-primary border-primary hover:bg-red/20 hover:text-red hover:border-red' : 'border-base hover:text-primary'"
|
|
|
|
@click="toggleNotifications"
|
|
|
|
>
|
|
|
|
<span v-if="isNotifiedOnPost" i-ri:notification-4-fill block text-current />
|
|
|
|
<span v-else i-ri-notification-4-line block text-current />
|
|
|
|
</button>
|
|
|
|
</CommonTooltip>
|
2022-11-29 09:15:05 +01:00
|
|
|
<AccountFollowButton :account="account" :command="command" />
|
2022-12-26 09:50:11 +01:00
|
|
|
<!-- Edit profile -->
|
|
|
|
<NuxtLink
|
|
|
|
v-if="isSelf"
|
|
|
|
to="/settings/profile/appearance"
|
2023-01-08 20:35:48 +01:00
|
|
|
gap-1 items-center border="1" rounded-full flex="~ gap2 center" font-500 min-w-30 h-fit px3 py1
|
2022-12-26 09:50:11 +01:00
|
|
|
hover="border-primary text-primary bg-active"
|
|
|
|
>
|
|
|
|
{{ $t('settings.profile.appearance.title') }}
|
|
|
|
</NuxtLink>
|
2022-11-15 04:26:52 +01:00
|
|
|
</div>
|
|
|
|
</div>
|
2022-12-30 21:54:23 +01:00
|
|
|
<div v-if="account.note" max-h-100 overflow-y-auto>
|
2022-12-25 13:44:45 +01:00
|
|
|
<ContentRich text-4 text-base :content="account.note" :emojis="account.emojis" />
|
2022-11-15 04:26:52 +01:00
|
|
|
</div>
|
2022-11-27 08:44:47 +01:00
|
|
|
<div v-if="namedFields.length" flex="~ col wrap gap1">
|
|
|
|
<div v-for="field in namedFields" :key="field.name" flex="~ gap-1" items-center>
|
|
|
|
<div text-secondary uppercase text-xs font-bold>
|
2022-11-24 07:41:29 +01:00
|
|
|
{{ field.name }} |
|
|
|
|
</div>
|
2022-11-28 14:58:58 +01:00
|
|
|
<ContentRich :content="field.value" :emojis="account.emojis" />
|
2022-11-27 08:44:47 +01:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div v-if="iconFields.length" flex="~ wrap gap-4">
|
|
|
|
<div v-for="field in iconFields" :key="field.name" flex="~ gap-1" items-center>
|
2023-01-03 12:41:26 +01:00
|
|
|
<CommonTooltip :content="getFieldIconTitle(field.name)">
|
|
|
|
<div text-secondary :class="getAccountFieldIcon(field.name)" :title="getFieldIconTitle(field.name)" />
|
|
|
|
</CommonTooltip>
|
2022-11-28 14:58:58 +01:00
|
|
|
<ContentRich text-sm filter-saturate-0 :content="field.value" :emojis="account.emojis" />
|
2022-11-15 04:26:52 +01:00
|
|
|
</div>
|
|
|
|
</div>
|
2022-11-28 10:51:15 +01:00
|
|
|
<AccountPostsFollowers :account="account" />
|
2022-11-15 04:26:52 +01:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</template>
|