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