forked from Mirrors/elk
36 lines
891 B
Vue
36 lines
891 B
Vue
<script setup lang="ts">
|
|
import type { mastodon } from 'masto'
|
|
|
|
defineProps<{
|
|
card: mastodon.v1.PreviewCard
|
|
/** When it is root card in the list, not appear as a child card */
|
|
root?: boolean
|
|
/** For the preview image, only the small image mode is displayed */
|
|
provider?: string
|
|
}>()
|
|
</script>
|
|
|
|
<template>
|
|
<div
|
|
max-h-2xl
|
|
flex flex-col
|
|
my-auto
|
|
:class="[
|
|
root ? 'flex-gap-1' : 'justify-center sm:justify-start',
|
|
]"
|
|
>
|
|
<p text-secondary ws-pre-wrap break-all line-clamp-1>
|
|
{{ provider }}
|
|
</p>
|
|
<strong
|
|
v-if="card.title" font-normal sm:font-medium line-clamp-1
|
|
break-all ws-pre-wrap
|
|
>{{ card.title }}</strong>
|
|
<p
|
|
v-if="card.description"
|
|
line-clamp-1 break-all sm:break-words text-secondary ws-pre-wrap :class="[root ? 'sm:line-clamp-2' : '']"
|
|
>
|
|
{{ card.description }}
|
|
</p>
|
|
</div>
|
|
</template>
|