2024-11-17 11:45:08 +08:00
|
|
|
<script lang="ts" setup>
|
2025-01-13 21:51:37 +08:00
|
|
|
import { computed, onMounted, ref } from 'vue'
|
2024-11-17 11:45:08 +08:00
|
|
|
|
2025-01-13 23:12:06 +08:00
|
|
|
interface errObj {
|
2025-01-13 21:51:37 +08:00
|
|
|
blog?: object
|
2025-01-13 01:03:16 +08:00
|
|
|
git?: object
|
|
|
|
}
|
|
|
|
|
2025-01-13 21:51:37 +08:00
|
|
|
const { $mitt } = useNuxtApp(),
|
|
|
|
recentPosts = ref<IPost[] | null>(null),
|
|
|
|
recentActivities = ref<IActivity[] | null>(null),
|
|
|
|
isLoading = ref({
|
|
|
|
blog: true,
|
|
|
|
git: true,
|
|
|
|
}),
|
|
|
|
isError = ref({
|
|
|
|
blog: false,
|
|
|
|
git: false,
|
|
|
|
}),
|
|
|
|
errMsg = ref<errObj>({
|
|
|
|
blog: undefined,
|
|
|
|
git: undefined,
|
|
|
|
}),
|
2024-11-17 11:45:08 +08:00
|
|
|
|
2025-01-13 23:12:06 +08:00
|
|
|
getBlogRecentPost = get<IBlogResponse<IPostsData>, unknown>('/blog/index.php/api/posts', {
|
2025-01-13 21:51:37 +08:00
|
|
|
params: {
|
|
|
|
showDigest: 'excerpt',
|
|
|
|
limit: 100,
|
|
|
|
},
|
|
|
|
}),
|
2025-01-13 23:12:06 +08:00
|
|
|
getActivity = get<IActivity[], unknown>('/git/api/v1/users/cantyonion/activities/feeds', {
|
2025-01-13 21:51:37 +08:00
|
|
|
params: {
|
2025-01-14 03:00:07 +08:00
|
|
|
'limit': 10,
|
|
|
|
'only-performed-by': true,
|
2025-01-13 21:51:37 +08:00
|
|
|
},
|
|
|
|
}),
|
2024-12-01 13:09:44 +08:00
|
|
|
|
2025-01-13 21:51:37 +08:00
|
|
|
hasPosts = computed(() => (recentPosts.value ?? []).length > 0),
|
|
|
|
hasActivities = computed(() => (recentActivities.value ?? []).length > 0),
|
|
|
|
postsData = computed(() => {
|
2025-01-13 23:12:06 +08:00
|
|
|
if (!recentPosts.value) {
|
|
|
|
return []
|
|
|
|
}
|
|
|
|
if (recentPosts.value.length > 4) {
|
|
|
|
return recentPosts.value.slice(0, 4)
|
|
|
|
}
|
2025-01-13 21:51:37 +08:00
|
|
|
return recentPosts.value
|
|
|
|
}),
|
2025-01-14 03:00:07 +08:00
|
|
|
activitiesData = computed((): IStrictActivity[] => {
|
2025-01-13 23:12:06 +08:00
|
|
|
if (!Array.isArray(recentActivities.value)) {
|
|
|
|
return []
|
|
|
|
}
|
2025-01-13 21:51:37 +08:00
|
|
|
return recentActivities.value.map((item) => {
|
2025-01-14 03:00:07 +08:00
|
|
|
return {
|
|
|
|
...item,
|
|
|
|
content: typeof item.content === 'string' && item.content ? JSON.parse(item.content) : null,
|
2025-01-13 21:51:37 +08:00
|
|
|
}
|
2025-01-14 03:00:07 +08:00
|
|
|
})
|
2025-01-13 21:51:37 +08:00
|
|
|
}),
|
2024-11-17 11:45:08 +08:00
|
|
|
|
2025-01-13 21:51:37 +08:00
|
|
|
reloadPosts = async () => {
|
|
|
|
try {
|
|
|
|
isLoading.value.blog = true
|
|
|
|
isError.value.blog = false
|
|
|
|
const postData = await getBlogRecentPost()
|
2025-01-13 23:12:06 +08:00
|
|
|
if (postData !== null) {
|
|
|
|
recentPosts.value = postData.data.dataSet
|
|
|
|
}
|
2025-01-13 21:51:37 +08:00
|
|
|
}
|
|
|
|
catch (e) {
|
|
|
|
isError.value.blog = true
|
|
|
|
errMsg.value.blog = e as object
|
|
|
|
}
|
|
|
|
finally {
|
|
|
|
isLoading.value.blog = false
|
|
|
|
}
|
|
|
|
},
|
2024-11-17 11:45:08 +08:00
|
|
|
|
2025-01-13 21:51:37 +08:00
|
|
|
reloadActivities = async () => {
|
|
|
|
try {
|
|
|
|
isLoading.value.git = true
|
|
|
|
isError.value.git = false
|
|
|
|
recentActivities.value = await getActivity()
|
|
|
|
}
|
|
|
|
catch (e) {
|
|
|
|
isError.value.git = true
|
|
|
|
errMsg.value.git = e as object
|
|
|
|
}
|
|
|
|
finally {
|
|
|
|
isLoading.value.git = false
|
|
|
|
}
|
2024-11-17 11:45:08 +08:00
|
|
|
}
|
|
|
|
|
2025-01-13 01:03:16 +08:00
|
|
|
await Promise.allSettled([reloadPosts(), reloadActivities()])
|
2024-11-17 11:45:08 +08:00
|
|
|
|
2024-12-01 13:09:44 +08:00
|
|
|
onMounted(() => {
|
2024-12-18 08:42:00 +08:00
|
|
|
$mitt.emit('startLoading', false)
|
2024-11-17 11:45:08 +08:00
|
|
|
})
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<template>
|
2025-01-13 23:12:06 +08:00
|
|
|
<div class="main">
|
|
|
|
<!-- 个人介绍 -->
|
|
|
|
<card-full-screen-intro-card />
|
2024-11-17 11:45:08 +08:00
|
|
|
|
2025-01-13 23:12:06 +08:00
|
|
|
<div class="container mx-auto xl:max-w-screen-xl">
|
|
|
|
<!-- 博客部分 -->
|
|
|
|
<section class="w-full px-4 sm:px-0">
|
|
|
|
<!-- 标题部分 -->
|
|
|
|
<card-title
|
|
|
|
:icon="['fas', 'blog']"
|
|
|
|
title="最近文章"
|
|
|
|
/>
|
2024-11-17 11:45:08 +08:00
|
|
|
|
2025-01-13 23:12:06 +08:00
|
|
|
<card-section-card
|
|
|
|
:empty="!hasPosts"
|
|
|
|
:error="isError.blog"
|
|
|
|
:loading="isLoading.blog"
|
|
|
|
:err-msg="errMsg.blog"
|
|
|
|
@reload="reloadPosts"
|
|
|
|
>
|
|
|
|
<template #default>
|
|
|
|
<div class="grid w-full grid-cols-1 gap-8 sm:grid-cols-2 lg:grid-cols-3">
|
|
|
|
<card-article-card
|
|
|
|
v-for="item in postsData"
|
|
|
|
:key="item.cid"
|
|
|
|
:post="item"
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
</card-section-card>
|
|
|
|
</section>
|
2024-11-17 11:45:08 +08:00
|
|
|
|
2025-01-13 23:12:06 +08:00
|
|
|
<!-- Git部分 -->
|
|
|
|
<section class="my-4 w-full px-4 sm:px-0">
|
|
|
|
<card-title
|
|
|
|
:icon="['fas', 'code']"
|
|
|
|
title="最近活动"
|
|
|
|
/>
|
2024-11-17 11:45:08 +08:00
|
|
|
|
2025-01-13 23:12:06 +08:00
|
|
|
<card-section-card
|
|
|
|
:empty="!hasActivities"
|
|
|
|
:error="isError.git"
|
|
|
|
:loading="isLoading.git"
|
|
|
|
:err-msg="errMsg.git"
|
|
|
|
@reload="reloadActivities"
|
|
|
|
>
|
|
|
|
<template #default>
|
2025-01-14 03:00:07 +08:00
|
|
|
<div class="w-full rounded-xl bg-white divide-y divide-dashed">
|
2025-01-13 23:12:06 +08:00
|
|
|
<card-git-card
|
|
|
|
v-for="item in activitiesData"
|
|
|
|
:key="item.id"
|
|
|
|
:commit="item"
|
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
</card-section-card>
|
|
|
|
</section>
|
|
|
|
</div>
|
2024-11-17 11:45:08 +08:00
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<style scoped>
|
|
|
|
|
2025-01-13 21:51:37 +08:00
|
|
|
</style>
|