package list from viandwi24
This commit is contained in:
11
pages/post/[slug].vue
Normal file
11
pages/post/[slug].vue
Normal file
@@ -0,0 +1,11 @@
|
||||
<script lang="ts" setup>
|
||||
definePageMeta({
|
||||
layout: 'page',
|
||||
})
|
||||
</script>
|
||||
|
||||
<template>
|
||||
<PageWrapper class="flex flex-col">
|
||||
<PageContentDoc empty-tip="Post im empty" />
|
||||
</PageWrapper>
|
||||
</template>
|
||||
67
pages/post/index.vue
Normal file
67
pages/post/index.vue
Normal file
@@ -0,0 +1,67 @@
|
||||
<script lang="ts" setup>
|
||||
import { capitalize } from '~/utils/str'
|
||||
|
||||
// composable
|
||||
const { t } = useLang()
|
||||
|
||||
// compiler macro
|
||||
definePageMeta({
|
||||
layout: 'page',
|
||||
})
|
||||
useHead(() => ({
|
||||
title: capitalize(t('pages.post.title')),
|
||||
meta: [
|
||||
{
|
||||
name: 'description',
|
||||
content: t('pages.post.description'),
|
||||
},
|
||||
],
|
||||
}))
|
||||
</script>
|
||||
|
||||
<template>
|
||||
<PageWrapper>
|
||||
<PageHeader>
|
||||
<PageTitle :text="$t('pages.post.title')" class="capitalize" />
|
||||
</PageHeader>
|
||||
<PageBody>
|
||||
<ContentList v-slot="{ list }" path="/post">
|
||||
<PageSection v-for="article in list" :key="article._path">
|
||||
<div
|
||||
class="block hover:no-underline p-6 flex space-x-6 rounded border border-gray-900/10 dark:border-gray-50/[0.2]"
|
||||
>
|
||||
<div class="mt-1 text-slate-600 dark:text-gray-400 text-right">
|
||||
<div>{{ article.date }}</div>
|
||||
<Anchor
|
||||
class="text-sm flex items-center justify-end space-x-1"
|
||||
:href="`https://www.github.com/${article.author}`"
|
||||
>
|
||||
<icon-mdi:github-face class="text-xs" />
|
||||
<span>{{ article.author }}</span>
|
||||
</Anchor>
|
||||
</div>
|
||||
<div class="flex flex-col">
|
||||
<div
|
||||
class="text-xl font-semibold text-slate-800 dark:text-gray-50"
|
||||
>
|
||||
{{ article.title }}
|
||||
</div>
|
||||
<div class="text-slate-700 dark:text-gray-300 mb-1">
|
||||
{{ article.description }}
|
||||
</div>
|
||||
<div class="flex">
|
||||
<Anchor
|
||||
class="text-sm flex space-x-1 items-center text-primary-500"
|
||||
:to="article._path"
|
||||
>
|
||||
<span>{{ $t('others.learn_more') }}</span>
|
||||
<icon:ic:baseline-arrow-right-alt class="text-sm" />
|
||||
</Anchor>
|
||||
</div>
|
||||
</div>
|
||||
</div>
|
||||
</PageSection>
|
||||
</ContentList>
|
||||
</PageBody>
|
||||
</PageWrapper>
|
||||
</template>
|
||||
Reference in New Issue
Block a user