mirror of https://github.com/elk-zone/elk.git
45 lines
1.1 KiB
Vue
45 lines
1.1 KiB
Vue
|
<script setup lang="ts">
|
||
|
import type { mastodon } from 'masto'
|
||
|
|
||
|
const { account, list } = defineProps<{
|
||
|
account: mastodon.v1.Account
|
||
|
hoverCard?: boolean
|
||
|
list: string
|
||
|
}>()
|
||
|
|
||
|
cacheAccount(account)
|
||
|
|
||
|
const client = useMastoClient()
|
||
|
|
||
|
const isRemoved = ref(false)
|
||
|
|
||
|
async function edit() {
|
||
|
try {
|
||
|
isRemoved.value
|
||
|
? await client.v1.lists.addAccount(list, { accountIds: [account.id] })
|
||
|
: await client.v1.lists.removeAccount(list, { accountIds: [account.id] })
|
||
|
isRemoved.value = !isRemoved.value
|
||
|
}
|
||
|
catch (err) {
|
||
|
console.error(err)
|
||
|
}
|
||
|
}
|
||
|
</script>
|
||
|
|
||
|
<template>
|
||
|
<div flex justify-between hover:bg-active transition-100 items-center>
|
||
|
<AccountInfo
|
||
|
:account="account" hover p1 as="router-link"
|
||
|
:hover-card="hoverCard"
|
||
|
shrink
|
||
|
overflow-hidden
|
||
|
:to="getAccountRoute(account)"
|
||
|
/>
|
||
|
<div>
|
||
|
<CommonTooltip :content="isRemoved ? $t('list.add_account') : $t('list.remove_account')" :hover="isRemoved ? 'text-green' : 'text-red'">
|
||
|
<button :class="isRemoved ? 'i-ri:user-add-line' : 'i-ri:user-unfollow-line'" text-xl @click="edit" />
|
||
|
</CommonTooltip>
|
||
|
</div>
|
||
|
</div>
|
||
|
</template>
|