727d05915f
* fix: rtl arrows on settings page * fix: border on settings page for RTL languages * fix: RTL fixes for logo, search box and logout icon * fix: RTL layout bugs in conversations * chore: remove rtl setting icon * improve arabic locale * add new entries to arabic locale * chore: include number format * fix: RTL layout on several pages * fix: RTL layout of account header and sign in modal * fix: always display account handle in LTR * fix: move character counter in publish widget to left side for RTL * fix: remove border-ss-none unocss rule * fix: many RTL fixes * fix: RTL fixes for many pages * fix: use viewer's direction in all content * chore: use new arabic plural rules * chore: flip arrow on main content header * chore: fix StatusPoll and show_new_items for zh-TW * chore: StatusPoll tooltip on bottom * chore: add `en` variants to i18n conf * chore: update entry to use new plural rule * fix: automatic content direction for status * fix: direction for account handle * fix: direction of polls Co-authored-by: userquin <userquin@gmail.com> Co-authored-by: Jean-Paul Khawam <jeanpaulkhawam@protonmail.com> Co-authored-by: Daniel Roe <daniel@roe.dev>
66 lines
2 KiB
Vue
66 lines
2 KiB
Vue
<script setup lang="ts">
|
|
import type { Status } from 'masto'
|
|
|
|
const props = withDefaults(defineProps<{
|
|
status: Status
|
|
command?: boolean
|
|
actions?: boolean
|
|
}>(), {
|
|
actions: true,
|
|
})
|
|
|
|
const status = $computed(() => {
|
|
if (props.status.reblog && props.status.reblog)
|
|
return props.status.reblog
|
|
return props.status
|
|
})
|
|
|
|
const createdAt = useFormattedDateTime(status.createdAt)
|
|
|
|
const visibility = $computed(() => STATUS_VISIBILITIES.find(v => v.value === status.visibility)!)
|
|
|
|
const { t } = useI18n()
|
|
|
|
useHeadFixed({
|
|
title: () => `${status.account.displayName || status.account.acct} ${t('common.in')} ${t('app_name')}: "${removeHTMLTags(status.content) || ''}"`,
|
|
})
|
|
|
|
const isDM = $computed(() => status.visibility === 'direct')
|
|
</script>
|
|
|
|
<template>
|
|
<div :id="`status-${status.id}`" flex flex-col gap-2 pt2 pb1 px-4 relative :lang="status.language ?? undefined">
|
|
<StatusActionsMore :status="status" absolute inset-ie-2 top-2 />
|
|
<NuxtLink :to="getAccountRoute(status.account)" rounded-full hover:bg-active transition-100 pe5 me-a>
|
|
<AccountHoverWrapper :account="status.account">
|
|
<AccountInfo :account="status.account" />
|
|
</AccountHoverWrapper>
|
|
</NuxtLink>
|
|
<StatusContent :status="status" context="details" />
|
|
<div flex="~ gap-1" items-center text-secondary text-sm>
|
|
<div flex>
|
|
<div>{{ createdAt }}</div>
|
|
<StatusEditIndicator
|
|
:status="status"
|
|
:inline="false"
|
|
>
|
|
<span ms1 font-bold cursor-pointer>{{ $t('state.edited') }}</span>
|
|
</StatusEditIndicator>
|
|
</div>
|
|
<div>·</div>
|
|
<CommonTooltip :content="$t(`visibility.${visibility.value}`)" placement="bottom">
|
|
<div :class="visibility.icon" />
|
|
</CommonTooltip>
|
|
<div v-if="status.application?.name">
|
|
·
|
|
</div>
|
|
<div v-if="status.application?.name">
|
|
{{ status.application?.name }}
|
|
</div>
|
|
</div>
|
|
<div border="t base" pt-2>
|
|
<StatusActions v-if="actions" :status="status" details :command="command" />
|
|
</div>
|
|
</div>
|
|
</template>
|