2022-11-14 10:20:07 +08:00
|
|
|
<script setup lang="ts">
|
2023-01-08 14:21:09 +08:00
|
|
|
import type { mastodon } from 'masto'
|
2022-11-14 10:20:07 +08:00
|
|
|
|
2023-01-07 10:31:48 +01:00
|
|
|
const {
|
|
|
|
status,
|
2023-01-18 16:59:37 +01:00
|
|
|
newer,
|
2023-01-07 10:31:48 +01:00
|
|
|
withAction = true,
|
|
|
|
} = defineProps<{
|
2023-01-08 14:21:09 +08:00
|
|
|
status: mastodon.v1.Status | mastodon.v1.StatusEdit
|
2023-01-18 16:59:37 +01:00
|
|
|
newer?: mastodon.v1.Status
|
2022-11-26 01:04:31 +01:00
|
|
|
withAction?: boolean
|
2022-11-14 10:20:07 +08:00
|
|
|
}>()
|
2023-01-06 00:48:20 +08:00
|
|
|
|
2023-01-18 05:41:26 +08:00
|
|
|
const { translation } = useTranslation(status, getLanguageCode())
|
2023-01-07 10:31:48 +01:00
|
|
|
|
|
|
|
const emojisObject = useEmojisFallback(() => status.emojis)
|
2024-02-21 16:20:08 +01:00
|
|
|
const vnode = computed(() => {
|
2023-01-07 10:31:48 +01:00
|
|
|
if (!status.content)
|
|
|
|
return null
|
2023-11-07 10:57:44 +01:00
|
|
|
return contentToVNode(status.content, {
|
2023-01-07 10:31:48 +01:00
|
|
|
emojis: emojisObject.value,
|
2023-01-11 17:18:06 +00:00
|
|
|
mentions: 'mentions' in status ? status.mentions : undefined,
|
2023-01-07 10:31:48 +01:00
|
|
|
markdown: true,
|
2023-01-13 01:08:56 +01:00
|
|
|
collapseMentionLink: !!('inReplyToId' in status && status.inReplyToId),
|
2023-01-18 16:59:37 +01:00
|
|
|
status: 'id' in status ? status : undefined,
|
|
|
|
inReplyToStatus: newer,
|
2023-01-07 10:31:48 +01:00
|
|
|
})
|
|
|
|
})
|
2024-10-29 19:25:32 +09:00
|
|
|
|
|
|
|
const userSettings = useUserSettings()
|
|
|
|
const lineHeight = userSettings.value.lineHeight
|
2022-11-14 10:20:07 +08:00
|
|
|
</script>
|
|
|
|
|
|
|
|
<template>
|
2023-01-18 16:59:37 +01:00
|
|
|
<div class="status-body" whitespace-pre-wrap break-words :class="{ 'with-action': withAction }" relative>
|
2023-01-07 10:31:48 +01:00
|
|
|
<span
|
2022-11-27 17:54:11 +01:00
|
|
|
v-if="status.content"
|
2024-10-29 19:25:32 +09:00
|
|
|
class="content-rich" :class="[`line-height-${lineHeight}`]"
|
|
|
|
dir="auto"
|
2023-01-07 10:31:48 +01:00
|
|
|
:lang="('language' in status && status.language) || undefined"
|
|
|
|
>
|
2023-05-29 02:16:34 -05:00
|
|
|
<component :is="vnode" v-if="vnode" />
|
2023-01-07 10:31:48 +01:00
|
|
|
</span>
|
2022-12-23 22:53:21 +01:00
|
|
|
<div v-else />
|
2022-11-27 17:54:11 +01:00
|
|
|
<template v-if="translation.visible">
|
|
|
|
<div my2 h-px border="b base" bg-base />
|
2024-10-29 19:25:32 +09:00
|
|
|
<ContentRich v-if="translation.success" class="content-rich" :class="[`line-height-${lineHeight}`]" :content="translation.text" :emojis="status.emojis" />
|
2023-01-16 17:55:00 +08:00
|
|
|
<div v-else text-red-4>
|
|
|
|
Error: {{ translation.error }}
|
|
|
|
</div>
|
2022-11-27 17:54:11 +01:00
|
|
|
</template>
|
2022-11-21 05:21:53 +08:00
|
|
|
</div>
|
2022-11-14 10:20:07 +08:00
|
|
|
</template>
|
2022-11-26 01:04:31 +01:00
|
|
|
|
|
|
|
<style>
|
|
|
|
.status-body.with-action p {
|
|
|
|
cursor: pointer;
|
|
|
|
}
|
|
|
|
</style>
|