elk/components/account/AccountInfo.vue

36 lines
1.5 KiB
Vue
Raw Normal View History

2022-11-13 08:34:43 +03:00
<script setup lang="ts">
2023-01-08 09:21:09 +03:00
import type { mastodon } from 'masto'
2022-11-13 08:34:43 +03:00
defineOptions({
inheritAttrs: false,
})
const { account, as = 'div' } = defineProps<{
2023-01-08 09:21:09 +03:00
account: mastodon.v1.Account
as?: string
2022-11-28 20:24:39 +03:00
hoverCard?: boolean
square?: boolean
2022-11-13 08:34:43 +03:00
}>()
</script>
<!-- TODO: Make this work for both buttons and links -->
<!-- This is sometimes (like in the sidebar) used directly as a button, and sometimes, like in follow notifications, as a link. I think this component may need a second refactor that either lets an implementation pass in a link or an action and adapt to what's passed in, or the implementations need to be updated to wrap in the action they want to take and this be just the layout for these items -->
2022-11-13 08:34:43 +03:00
<template>
<component :is="as" flex items-center gap-3 v-bind="$attrs">
<AccountHoverWrapper :disabled="!hoverCard" :account="account">
<AccountBigAvatar :account="account" shrink-0 :square="square" />
2022-11-28 20:24:39 +03:00
</AccountHoverWrapper>
<div flex="~ col" shrink h-full overflow-hidden justify-center leading-none select-none p-1>
2022-12-11 18:43:23 +03:00
<div flex="~" gap-2>
<AccountDisplayName :account="account" font-bold line-clamp-1 ws-pre-wrap break-all text-lg />
<AccountLockIndicator v-if="account.locked" text-xs />
<AccountBotIndicator v-if="account.bot" text-xs />
2022-12-11 18:43:23 +03:00
</div>
<AccountHandle :account="account" text-secondary-light />
<div self-start mt-1>
<AccountRolesIndicator v-if="account.roles?.length" :account="account" :limit="1" />
</div>
</div>
</component>
2022-11-13 08:34:43 +03:00
</template>