elk/components/status/StatusDetails.vue

72 lines
2.2 KiB
Vue
Raw Normal View History

2022-11-14 14:54:30 +00:00
<script setup lang="ts">
2023-01-08 06:21:09 +00:00
import type { mastodon } from 'masto'
2022-11-14 14:54:30 +00:00
2022-12-26 07:37:42 +00:00
const props = withDefaults(defineProps<{
2023-01-08 06:21:09 +00:00
status: mastodon.v1.Status
2023-01-18 15:59:37 +00:00
newer?: mastodon.v1.Status
command?: boolean
2022-12-26 07:37:42 +00:00
actions?: boolean
}>(), {
actions: true,
})
2022-11-14 14:54:30 +00:00
2023-04-30 15:19:14 +00:00
defineEmits<{
(event: 'refetchStatus'): void
}>()
2022-11-14 14:54:30 +00:00
const status = $computed(() => {
if (props.status.reblog && props.status.reblog)
return props.status.reblog
return props.status
})
const createdAt = useFormattedDateTime(status.createdAt)
const { t } = useI18n()
useHydratedHead({
title: () => `${getDisplayName(status.account)} ${t('common.in')} ${t('app_name')}: "${removeHTMLTags(status.content) || ''}"`,
})
2022-11-14 14:54:30 +00:00
</script>
<template>
2023-03-07 19:32:21 +00:00
<div :id="`status-${status.id}`" flex flex-col gap-2 pt2 pb1 ps-3 pe-4 relative :lang="status.language ?? undefined" aria-roledescription="status-details">
2023-04-30 15:19:14 +00:00
<StatusActionsMore :status="status" absolute inset-ie-2 top-2 @after-edit="$emit('refetchStatus')" />
<NuxtLink :to="getAccountRoute(status.account)" rounded-full hover:bg-active transition-100 pe5 me-a>
2022-11-27 04:45:26 +00:00
<AccountHoverWrapper :account="status.account">
<AccountInfo :account="status.account" />
</AccountHoverWrapper>
</NuxtLink>
2023-01-18 15:59:37 +00:00
<StatusContent :status="status" :newer="newer" context="details" />
<div flex="~ gap-1" items-center text-secondary text-sm>
<div flex>
<div>{{ createdAt }}</div>
2022-11-26 05:05:44 +00:00
<StatusEditIndicator
:status="status"
:inline="false"
>
<span ms1 font-bold cursor-pointer>{{ $t('state.edited') }}</span>
2022-11-26 05:05:44 +00:00
</StatusEditIndicator>
</div>
<div aria-hidden="true">
&middot;
</div>
<StatusVisibilityIndicator :status="status" />
<div v-if="status.application?.name" aria-hidden="true">
2022-12-22 13:06:53 +00:00
&middot;
</div>
<div v-if="status.application?.website && status.application.name">
<NuxtLink :to="status.application.website">
{{ status.application.name }}
</NuxtLink>
</div>
<div v-else-if="status.application?.name">
2022-12-22 13:06:53 +00:00
{{ status.application?.name }}
</div>
2022-11-14 14:54:30 +00:00
</div>
<div border="t base" py-2>
<StatusActions v-if="actions" :status="status" details :command="command" />
2022-12-26 07:37:42 +00:00
</div>
2022-11-14 14:54:30 +00:00
</div>
</template>