elk/components/status/StatusBody.vue

48 lines
1.1 KiB
Vue
Raw Normal View History

2022-11-14 02:20:07 +00:00
<script setup lang="ts">
2023-01-08 06:21:09 +00:00
import type { mastodon } from 'masto'
2022-11-14 02:20:07 +00:00
2023-01-07 09:31:48 +00:00
const {
status,
withAction = true,
} = defineProps<{
2023-01-08 06:21:09 +00:00
status: mastodon.v1.Status | mastodon.v1.StatusEdit
withAction?: boolean
2022-11-14 02:20:07 +00:00
}>()
2023-01-05 16:48:20 +00:00
const { translation } = useTranslation(status)
2023-01-07 09:31:48 +00:00
const emojisObject = useEmojisFallback(() => status.emojis)
const vnode = $computed(() => {
if (!status.content)
return null
const vnode = contentToVNode(status.content, {
emojis: emojisObject.value,
markdown: true,
})
return vnode
})
2022-11-14 02:20:07 +00:00
</script>
<template>
<div class="status-body" whitespace-pre-wrap break-words :class="{ 'with-action': withAction }">
2023-01-07 09:31:48 +00:00
<span
v-if="status.content"
2023-01-07 09:31:48 +00:00
class="content-rich line-compact" dir="auto"
:lang="('language' in status && status.language) || undefined"
>
<component :is="vnode" />
</span>
2022-12-23 21:53:21 +00:00
<div v-else />
<template v-if="translation.visible">
<div my2 h-px border="b base" bg-base />
<ContentRich class="line-compact" :content="translation.text" :emojis="status.emojis" />
</template>
2022-11-20 21:21:53 +00:00
</div>
2022-11-14 02:20:07 +00:00
</template>
<style>
.status-body.with-action p {
cursor: pointer;
}
</style>