2022-11-14 23:54:30 +09:00
|
|
|
<script setup lang="ts">
|
|
|
|
import type { Status } from 'masto'
|
|
|
|
|
|
|
|
const props = defineProps<{
|
|
|
|
status: Status
|
2022-11-29 17:15:05 +09:00
|
|
|
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
|
|
|
|
})
|
|
|
|
|
2022-11-26 12:36:18 +09:00
|
|
|
const createdAt = useFormattedDateTime(status.createdAt)
|
2022-11-26 12:02:26 +09:00
|
|
|
|
|
|
|
const visibility = $computed(() => STATUS_VISIBILITIES.find(v => v.value === status.visibility)!)
|
2022-11-14 23:54:30 +09:00
|
|
|
</script>
|
|
|
|
|
|
|
|
<template>
|
2022-11-27 13:45:26 +09:00
|
|
|
<div :id="`status-${status.id}`" flex flex-col gap-2 py3 px-4>
|
|
|
|
<NuxtLink :to="getAccountPath(status.account)" rounded-full hover:bg-active transition-100 pr5 mr-a>
|
|
|
|
<AccountHoverWrapper :account="status.account">
|
|
|
|
<AccountInfo :account="status.account" />
|
|
|
|
</AccountHoverWrapper>
|
|
|
|
</NuxtLink>
|
2022-11-24 14:47:14 +09:00
|
|
|
<StatusReplyingTo v-if="status.inReplyToAccountId" :status="status" />
|
2022-11-25 21:57:02 +09:00
|
|
|
<StatusSpoiler :enabled="status.sensitive">
|
|
|
|
<template #spoiler>
|
2022-11-30 11:07:13 +09:00
|
|
|
<p text-2xl>
|
|
|
|
{{ status.spoilerText }}
|
|
|
|
</p>
|
2022-11-25 21:57:02 +09:00
|
|
|
</template>
|
2022-11-26 09:04:31 +09:00
|
|
|
<StatusBody :status="status" :with-action="false" text-2xl />
|
2022-11-30 05:29:02 +09:00
|
|
|
<StatusPoll v-if="status.poll" :poll="status.poll" />
|
2022-11-25 21:57:02 +09:00
|
|
|
<StatusMedia
|
|
|
|
v-if="status.mediaAttachments?.length"
|
|
|
|
:status="status"
|
|
|
|
/>
|
|
|
|
</StatusSpoiler>
|
2022-11-27 05:41:18 +09:00
|
|
|
<div flex="~ gap-1" items-center text-secondary text-sm>
|
2022-11-26 12:36:18 +09:00
|
|
|
<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>
|
2022-11-26 12:36:18 +09:00
|
|
|
</div>
|
2022-11-26 12:02:26 +09:00
|
|
|
<div>·</div>
|
2022-11-30 08:25:29 +09:00
|
|
|
<CommonTooltip :content="$t(`visibility.${visibility.value}`)" placement="bottom">
|
2022-11-26 12:02:26 +09:00
|
|
|
<div :class="visibility.icon" />
|
|
|
|
</CommonTooltip>
|
|
|
|
<div v-if="status.application?.name">
|
|
|
|
· {{ status.application?.name }}
|
|
|
|
</div>
|
2022-11-14 23:54:30 +09:00
|
|
|
</div>
|
2022-11-29 17:15:05 +09:00
|
|
|
<StatusActions :status="status" details :command="command" border="t base" pt-2 />
|
2022-11-14 23:54:30 +09:00
|
|
|
</div>
|
|
|
|
</template>
|