1
0
elk/components/status/StatusDetails.vue

35 lines
931 B
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
}>()
const status = $computed(() => {
if (props.status.reblog && props.status.reblog)
return props.status.reblog
return props.status
})
const formatter = Intl.DateTimeFormat(undefined, { dateStyle: 'long' })
const date = computed(() => formatter.format(new Date(status.createdAt)))
</script>
<template>
2022-11-24 14:47:14 +09:00
<div flex flex-col gap-2 py3 px-4>
2022-11-14 23:54:30 +09:00
<AccountInfo :account="status.account" />
2022-11-24 14:47:14 +09:00
<StatusReplyingTo v-if="status.inReplyToAccountId" :status="status" />
2022-11-23 09:00:52 +09:00
<StatusBody :status="status" text-2xl />
2022-11-14 23:54:30 +09:00
<StatusMedia
v-if="status.mediaAttachments?.length"
:status="status"
/>
<div>
<span op50 text-sm>
{{ date }} · {{ status.application?.name || 'Unknown client' }}
</span>
</div>
2022-11-23 11:16:31 +09:00
<StatusActions :status="status" border="t base" pt-2 />
2022-11-14 23:54:30 +09:00
</div>
</template>