<template>
  <v-card :to="url" class="mx-[2.5ch] mb-3">
    <v-card-text>
      <div class="mb-3 flex flex-row gap-4">
        <nuxt-link :to="`/users/${post.publisher?.name}`">
          <v-avatar :image="getAttachmentUrl(post.publisher?.avatar)" icon="mdi-account-circle" />
        </nuxt-link>
        <div class="flex flex-col">
          <span
            >{{ post.publisher?.nick }} <span class="text-xs">@{{ post.publisher?.name }}</span></span
          >
          <span v-if="post.body?.title" class="text-md">{{ post.body?.title }}</span>
          <span v-if="post.body?.description" class="text-sm">{{ post.body?.description }}</span>
          <span v-if="!post.body?.title && !post.body?.description" class="text-sm">
            {{ post.publisher?.description }}
          </span>

          <div v-if="post.type != 'story'" class="mt-1">
            <v-btn size="x-small" variant="flat" append-icon="mdi-arrow-right" :text="t('continueReading')" />
          </div>
        </div>
      </div>

      <div v-if="post.body?.thumbnail" class="mb-5">
        <v-img
          :src="`${config.public.solarNetworkApi}/cgi/uc/attachments/${post.body?.thumbnail}`"
          :aspect-ratio="16 / 9"
          alt="Post thumbnail"
          class="rounded-md"
          cover
        />
      </div>

      <article v-if="(post.type == 'story' || props.forceShowContent) && post.body?.content" class="text-base prose max-w-none">
        <m-d-c :value="post.body?.content"></m-d-c>
      </article>

      <v-card v-if="post.body?.attachments?.length > 0" class="mb-5">
        <attachment-carousel
          :no-clickable-attachment="props.noClickableAttachment"
          :attachments="post.body?.attachments"
        />
      </v-card>

      <div class="text-sm flex flex-col">
        <span class="flex flex-row gap-1">
          <span> {{ post.metric.reply_count }} {{ post.metric.reply_count > 1 ? "replies" : "reply" }}, </span>
          <span>
            {{ post.metric.reaction_count }} {{ post.metric.reaction_count > 1 ? "reactions" : "reaction" }}
          </span>
        </span>
        <span>
          {{ post.type.startsWith("a") ? "An" : "A" }} {{ post.type }} posted on
          {{ new Date(post.published_at).toLocaleString() }}
        </span>
      </div>

      <div v-if="post.tags?.length > 0" class="text-xs text-grey flex flex-row gap-1 mt-3">
        <nuxt-link
          v-for="tag in post.tags"
          :to="`/posts/tags/${tag.alias}`"
          class="hover:underline hover:underline-dotted"
          @click.stop
        >
          #{{ tag.alias }}
        </nuxt-link>
      </div>
    </v-card-text>
  </v-card>
</template>

<script setup lang="ts">
const props = defineProps<{ post: any; forceShowContent?: boolean; noClickableAttachment?: boolean }>()
const config = useRuntimeConfig()

const { t } = useI18n()

const url = computed(() =>
  props.post?.alias ? `/posts/${props.post?.alias_prefix}/${props.post?.alias}` : `/posts/${props.post?.id}`,
)
</script>