1
0
mirror of https://github.com/elk-zone/elk synced 2024-12-22 18:48:00 +09:00
elk/components/status/StatusDetails.vue

78 lines
2.5 KiB
Vue
Raw Normal View History

2022-11-14 23:54:30 +09:00
<script setup lang="ts">
import type { Status } from 'masto'
const props = defineProps<{
status: Status
command?: boolean
2022-11-14 23:54:30 +09:00
}>()
const status = $computed(() => {
if (props.status.reblog && props.status.reblog)
return props.status.reblog
return props.status
})
const createdAt = useFormattedDateTime(status.createdAt)
const visibility = $computed(() => STATUS_VISIBILITIES.find(v => v.value === status.visibility)!)
2022-11-14 23:54:30 +09:00
</script>
<template>
2022-12-01 15:46:26 +09:00
<div :id="`status-${status.id}`" flex flex-col gap-2 py3 px-4 relative>
<StatusActionsMore :status="status" absolute right-2 top-2 />
<NuxtLink :to="getAccountRoute(status.account)" rounded-full hover:bg-active transition-100 pr5 mr-a>
2022-11-27 13:45:26 +09:00
<AccountHoverWrapper :account="status.account">
<AccountInfo :account="status.account" />
</AccountHoverWrapper>
</NuxtLink>
2022-12-01 16:32:07 +09:00
<div
2022-12-13 08:10:04 +09:00
:class="status.visibility === 'direct' ? 'my2 p1 px4 br2 bg-fade border-primary-light border-1 rounded-3 rounded-tl-none' : ''"
2022-12-01 16:32:07 +09:00
>
<StatusSpoiler :enabled="status.sensitive">
<template #spoiler>
<p text-2xl>
{{ status.spoilerText }}
</p>
</template>
<StatusBody :status="status" :with-action="false" text-2xl />
2022-12-14 04:26:53 +09:00
<StatusPoll
v-if="status.poll"
:poll="status.poll"
/>
2022-12-01 16:32:07 +09:00
<StatusMedia
v-if="status.mediaAttachments?.length"
:status="status"
2022-12-13 08:10:04 +09:00
:class="status.visibility === 'direct' ? 'pb4' : ''"
2022-12-14 04:26:53 +09:00
full-size
/>
<StatusPreviewCard
v-if="status.card"
:card="status.card"
:class="status.visibility === 'direct' ? 'pb4' : ''"
:small-picture-only="status.mediaAttachments?.length > 0"
mt-2
2022-12-01 16:32:07 +09:00
/>
</StatusSpoiler>
</div>
<div flex="~ gap-1" items-center text-secondary text-sm>
<div flex>
<div>{{ createdAt }}</div>
2022-11-26 14:05:44 +09:00
<StatusEditIndicator
:status="status"
:inline="false"
>
2022-11-30 08:25:29 +09:00
<span ml1 font-bold cursor-pointer>{{ $t('state.edited') }}</span>
2022-11-26 14:05:44 +09:00
</StatusEditIndicator>
</div>
2022-12-05 03:59:33 +09:00
<div>&middot;</div>
2022-11-30 08:25:29 +09:00
<CommonTooltip :content="$t(`visibility.${visibility.value}`)" placement="bottom">
<div :class="visibility.icon" />
</CommonTooltip>
<div v-if="status.application?.name">
2022-12-05 03:59:33 +09:00
&middot; {{ status.application?.name }}
</div>
2022-11-14 23:54:30 +09:00
</div>
<StatusActions :status="status" details :command="command" border="t base" pt-2 />
2022-11-14 23:54:30 +09:00
</div>
</template>