2022-12-26 08:37:42 +01:00
|
|
|
<script setup lang="ts">
|
2023-01-08 07:21:09 +01:00
|
|
|
import type { mastodon } from 'masto'
|
2022-12-26 08:37:42 +01:00
|
|
|
|
|
|
|
const { status, context } = defineProps<{
|
2023-01-08 07:21:09 +01:00
|
|
|
status: mastodon.v1.Status
|
2023-01-18 16:59:37 +01:00
|
|
|
newer?: mastodon.v1.Status
|
2023-01-08 07:21:09 +01:00
|
|
|
context?: mastodon.v2.FilterContext | 'details'
|
2022-12-26 08:37:42 +01:00
|
|
|
}>()
|
|
|
|
|
|
|
|
const isDM = $computed(() => status.visibility === 'direct')
|
|
|
|
const isDetails = $computed(() => context === 'details')
|
|
|
|
|
|
|
|
// Content Filter logic
|
|
|
|
const filterResult = $computed(() => status.filtered?.length ? status.filtered[0] : null)
|
|
|
|
const filter = $computed(() => filterResult?.filter)
|
|
|
|
|
2023-01-10 07:10:20 +01:00
|
|
|
const filterPhrase = $computed(() => filter?.title)
|
2022-12-26 08:37:42 +01:00
|
|
|
const isFiltered = $computed(() => filterPhrase && (context && context !== 'details' ? filter?.context.includes(context) : false))
|
2023-01-29 00:39:03 +01:00
|
|
|
|
|
|
|
const cleanSharedLink = !status.poll
|
|
|
|
&& !status.mediaAttachments.length
|
|
|
|
&& status.card?.url
|
2022-12-26 08:37:42 +01:00
|
|
|
</script>
|
|
|
|
|
|
|
|
<template>
|
|
|
|
<div
|
|
|
|
space-y-3
|
|
|
|
:class="{
|
2023-01-10 06:58:07 +01:00
|
|
|
'pt2 pb0.5 px3.5 bg-dm rounded-4 me--1': isDM,
|
2023-01-03 17:25:43 +01:00
|
|
|
'ms--3.5 mt--1 ms--1': isDM && context !== 'details',
|
2022-12-26 08:37:42 +01:00
|
|
|
}"
|
|
|
|
>
|
2023-01-18 16:59:37 +01:00
|
|
|
<StatusBody v-if="!isFiltered && status.sensitive && !status.spoilerText" :status="status" :newer="newer" :with-action="!isDetails" :class="isDetails ? 'text-xl' : ''" />
|
2023-01-21 21:49:29 +01:00
|
|
|
<StatusSpoiler :enabled="status.sensitive || isFiltered" :filter="isFiltered" :is-d-m="isDM">
|
2022-12-29 17:31:04 +01:00
|
|
|
<template v-if="filterPhrase" #spoiler>
|
|
|
|
<p>{{ `${$t('status.filter_hidden_phrase')}: ${filterPhrase}` }}</p>
|
2022-12-26 08:37:42 +01:00
|
|
|
</template>
|
2022-12-29 17:31:04 +01:00
|
|
|
<template v-else-if="status.spoilerText" #spoiler>
|
|
|
|
<p>{{ status.spoilerText }}</p>
|
|
|
|
</template>
|
2023-01-29 00:39:03 +01:00
|
|
|
<StatusBody v-if="!status.sensitive || status.spoilerText" :clean-shared-link="cleanSharedLink" :status="status" :newer="newer" :with-action="!isDetails" :class="isDetails ? 'text-xl' : ''" />
|
2023-01-16 10:55:00 +01:00
|
|
|
<StatusTranslation :status="status" />
|
2022-12-28 12:49:47 +01:00
|
|
|
<StatusPoll v-if="status.poll" :status="status" />
|
2022-12-26 08:37:42 +01:00
|
|
|
<StatusMedia
|
|
|
|
v-if="status.mediaAttachments?.length"
|
|
|
|
:status="status"
|
|
|
|
/>
|
|
|
|
<StatusPreviewCard
|
|
|
|
v-if="status.card"
|
|
|
|
:card="status.card"
|
|
|
|
:small-picture-only="status.mediaAttachments?.length > 0"
|
2023-01-29 00:39:03 +01:00
|
|
|
:clean-shared-link="cleanSharedLink"
|
2022-12-26 08:37:42 +01:00
|
|
|
/>
|
|
|
|
<StatusCard
|
|
|
|
v-if="status.reblog"
|
|
|
|
:status="status.reblog" border="~ rounded"
|
|
|
|
:actions="false"
|
|
|
|
/>
|
2023-01-21 23:09:37 +01:00
|
|
|
<div v-if="isDM" />
|
2022-12-26 08:37:42 +01:00
|
|
|
</StatusSpoiler>
|
|
|
|
</div>
|
|
|
|
</template>
|