feat(05): add blog/[...slug].vue — render @nuxt/content articles via queryCollection

This commit is contained in:
2026-04-21 16:45:34 +02:00
parent 2ea6af0fff
commit f2e29e6c2f
2 changed files with 90 additions and 0 deletions
+31
View File
@@ -0,0 +1,31 @@
<script setup lang="ts">
const { locale } = useI18n()
const route = useRoute()
const slug = Array.isArray(route.params.slug) ? route.params.slug.join('/') : route.params.slug
const path = `/blog/${slug}`
const { data: page } = await useAsyncData(`blog-${locale.value}-${slug}`, () => {
const collection = locale.value === 'fr' ? 'blog_fr' : 'blog_en'
return queryCollection(collection).path(path).first()
})
if (!page.value) {
throw createError({ statusCode: 404, statusMessage: 'Article introuvable' })
}
useSeoMeta({
title: page.value.title,
description: page.value.description,
ogTitle: page.value.title,
ogDescription: page.value.description,
})
</script>
<template>
<div class="mx-auto max-w-3xl px-4 py-12">
<article class="prose dark:prose-invert max-w-none">
<ContentRenderer v-if="page" :value="page" />
</article>
</div>
</template>