staff_data/apps/server/src/queue/models/post/utils.ts

99 lines
2.1 KiB
TypeScript
Raw Normal View History

2025-02-25 08:25:54 +08:00
import {
AppConfigSlug,
BaseSetting,
db,
PostType,
TaxonomySlug,
VisitType,
} from '@nice/common';
export async function updateTotalCourseViewCount(type: VisitType) {
const courses = await db.post.findMany({
where: { type: PostType.COURSE },
select: { id: true },
});
const courseIds = courses.map((course) => course.id);
const totalViews = await db.visit.aggregate({
_sum: {
views: true,
},
where: {
postId: { in: courseIds },
type: type,
},
});
const appConfig = await db.appConfig.findFirst({
where: {
slug: AppConfigSlug.BASE_SETTING,
},
select: {
id: true,
meta: true,
},
});
const baseSeting = appConfig.meta as BaseSetting;
await db.appConfig.update({
where: {
slug: AppConfigSlug.BASE_SETTING,
},
data: {
meta: {
...baseSeting,
2025-02-25 09:11:15 +08:00
reads: totalViews._sum.views,
2025-02-25 08:25:54 +08:00
},
},
});
}
2025-02-24 08:51:44 +08:00
export async function updatePostViewCount(id: string, type: VisitType) {
2025-02-24 10:16:33 +08:00
const post = await db.post.findFirst({
where: { id },
select: { id: true, meta: true },
});
2025-02-24 08:51:44 +08:00
const totalViews = await db.visit.aggregate({
_sum: {
views: true,
},
where: {
postId: id,
type: type,
},
});
if (type === VisitType.READED) {
await db.post.update({
where: {
id: id,
},
data: {
meta: {
2025-02-24 10:16:33 +08:00
...((post?.meta as any) || {}),
2025-02-24 08:51:44 +08:00
views: totalViews._sum.views || 0,
}, // Use 0 if no visits exist
},
});
2025-02-24 09:32:55 +08:00
console.log('readed');
2025-02-24 08:51:44 +08:00
} else if (type === VisitType.LIKE) {
await db.post.update({
where: {
id: id,
},
data: {
meta: {
2025-02-24 10:16:33 +08:00
...((post?.meta as any) || {}),
2025-02-24 08:51:44 +08:00
likes: totalViews._sum.views || 0, // Use 0 if no visits exist
},
},
});
} else if (type === VisitType.HATE) {
await db.post.update({
where: {
id: id,
},
data: {
meta: {
2025-02-24 10:16:33 +08:00
...((post?.meta as any) || {}),
2025-02-24 08:51:44 +08:00
hates: totalViews._sum.views || 0, // Use 0 if no visits exist
},
},
});
}
}