1
0
mirror of https://github.com/elk-zone/elk synced 2024-12-24 11:37:59 +09:00
elk/components/account/AccountPostsFollowers.vue

67 lines
3.1 KiB
Vue
Raw Normal View History

2022-11-28 18:51:15 +09:00
<script setup lang="ts">
import type { Account } from 'masto'
2022-12-02 11:18:36 +09:00
const props = defineProps<{
2022-11-28 18:51:15 +09:00
account: Account
}>()
2022-12-02 11:18:36 +09:00
const { formatHumanReadableNumber, formatNumber, forSR } = useHumanReadableNumber()
const statusesCount = $computed(() => formatHumanReadableNumber(props.account.statusesCount))
const statusesCountSR = $computed(() => forSR(props.account.statusesCount))
2022-12-02 11:18:36 +09:00
const followingCount = $computed(() => formatHumanReadableNumber(props.account.followingCount))
const followingCountSR = $computed(() => forSR(props.account.followingCount))
const followersCount = $computed(() => formatHumanReadableNumber(props.account.followersCount))
const followersCountSR = $computed(() => forSR(props.account.followersCount))
2022-11-28 18:51:15 +09:00
</script>
<template>
<div flex gap-5>
<NuxtLink
:to="getAccountRoute(account)"
text-secondary
exact-active-class="text-primary"
:class="statusesCountSR ? 'flex gap-x-1' : null"
>
2022-11-28 19:14:58 +09:00
<template #default="{ isExactActive }">
2022-12-02 11:18:36 +09:00
<i18n-t keypath="account.posts_count" :plural="account.statusesCount">
<CommonTooltip v-if="statusesCountSR" :content="formatNumber(account.statusesCount)" placement="bottom">
<span aria-hidden="true" font-bold :class="isExactActive ? 'text-primary' : 'text-base'">{{ statusesCount }}</span>
<span sr-only font-bold>{{ account.statusesCount }}</span>
</CommonTooltip>
<span v-else font-bold :class="isExactActive ? 'text-primary' : 'text-base'">{{ statusesCount }}</span>
2022-11-28 19:14:58 +09:00
</i18n-t>
</template>
2022-11-28 18:51:15 +09:00
</NuxtLink>
<NuxtLink
:to="getAccountFollowingRoute(account)"
text-secondary exact-active-class="text-primary"
:class="followingCountSR ? 'flex gap-x-1' : null"
>
2022-11-28 19:14:58 +09:00
<template #default="{ isExactActive }">
<i18n-t keypath="account.following_count" :plural="account.followingCount">
<CommonTooltip v-if="followingCountSR" :content="formatNumber(account.followingCount)" placement="bottom">
2022-12-02 11:18:36 +09:00
<span aria-hidden="true" font-bold :class="isExactActive ? 'text-primary' : 'text-base'">{{ followingCount }}</span>
<span sr-only font-bold>{{ account.followingCount }}</span>
</CommonTooltip>
2022-12-02 11:18:36 +09:00
<span v-else font-bold :class="isExactActive ? 'text-primary' : 'text-base'">{{ followingCount }}</span>
2022-11-28 19:14:58 +09:00
</i18n-t>
</template>
2022-11-28 18:51:15 +09:00
</NuxtLink>
<NuxtLink
:to="getAccountFollowersRoute(account)"
text-secondary exact-active-class="text-primary"
:class="followersCountSR ? 'flex gap-x-1' : null"
>
2022-11-28 19:14:58 +09:00
<template #default="{ isExactActive }">
2022-12-02 11:18:36 +09:00
<i18n-t keypath="account.followers_count" :plural="account.followersCount">
<CommonTooltip v-if="followersCountSR" :content="formatNumber(account.followersCount)" placement="bottom">
2022-12-02 11:18:36 +09:00
<span aria-hidden="true" font-bold :class="isExactActive ? 'text-primary' : 'text-base'">{{ followersCount }}</span>
<span sr-only font-bold>{{ account.followersCount }}</span>
</CommonTooltip>
2022-12-02 11:18:36 +09:00
<span v-else font-bold :class="isExactActive ? 'text-primary' : 'text-base'">{{ followersCount }}</span>
2022-11-28 19:14:58 +09:00
</i18n-t>
</template>
2022-11-28 18:51:15 +09:00
</NuxtLink>
</div>
</template>