style: added shadcn-ui
This commit is contained in:
@@ -28,7 +28,7 @@ export async function POST(request: Request) {
|
||||
});
|
||||
|
||||
const message: z.infer<typeof ResponseSchema> = {
|
||||
message: `Thank you for confirming the subscripion!`
|
||||
message: `Thank you for confirming the subscription, ${user.email}!`
|
||||
};
|
||||
|
||||
return ApiResponse(200, JSON.stringify(message));
|
||||
|
||||
@@ -1,9 +1,9 @@
|
||||
import { NextResponse } from 'next/server';
|
||||
import { z } from 'zod';
|
||||
import NewsletterEmail from '../../../components/emails/newsletter';
|
||||
import NewsletterTemplate from '../../../components/emails/newsletter';
|
||||
import prisma from '../../../prisma/prisma';
|
||||
import { sendEmail } from '../../../utils/sender';
|
||||
import { NewsSchema } from '../../../utils/types';
|
||||
import { NewsDatabaseSchema, NewsSchema } from '../../../utils/types';
|
||||
import { singleNews, topNews } from '../../../utils/urls';
|
||||
|
||||
export async function GET(request: Request) {
|
||||
@@ -18,28 +18,28 @@ export async function GET(request: Request) {
|
||||
const newsPromises = topstories
|
||||
.splice(0, Number(process.env.NEWS_LIMIT))
|
||||
.map(async id => {
|
||||
const sourceNews: z.infer<typeof NewsSchema> = await fetch(
|
||||
singleNews(id)
|
||||
).then(res => res.json());
|
||||
const sourceNews = await fetch(singleNews(id)).then(res => res.json());
|
||||
const validation = NewsDatabaseSchema.safeParse(sourceNews);
|
||||
|
||||
return await prisma.news.upsert({
|
||||
create: {
|
||||
...sourceNews,
|
||||
id
|
||||
},
|
||||
update: {
|
||||
...sourceNews
|
||||
},
|
||||
where: {
|
||||
id
|
||||
},
|
||||
select: {
|
||||
id: true
|
||||
}
|
||||
});
|
||||
if (validation.success) {
|
||||
const result = await prisma.news.upsert({
|
||||
create: {
|
||||
...validation.data,
|
||||
id
|
||||
},
|
||||
update: {
|
||||
...validation.data
|
||||
},
|
||||
where: {
|
||||
id
|
||||
}
|
||||
});
|
||||
|
||||
return result;
|
||||
}
|
||||
});
|
||||
|
||||
const newsIds = await Promise.all(newsPromises);
|
||||
const news = await Promise.all(newsPromises);
|
||||
|
||||
const users = await prisma.user.findMany({
|
||||
where: {
|
||||
@@ -58,10 +58,13 @@ export async function GET(request: Request) {
|
||||
});
|
||||
}
|
||||
|
||||
const validRankedNews = news
|
||||
.filter((item): item is z.infer<typeof NewsSchema> => item !== undefined)
|
||||
.sort((a, b) => b.score - a.score);
|
||||
|
||||
await sendEmail(
|
||||
users.map(user => user.email),
|
||||
`What's new from Hackernews?`,
|
||||
NewsletterEmail(newsIds.map(news => news.id))
|
||||
NewsletterTemplate(validRankedNews)
|
||||
);
|
||||
|
||||
return new NextResponse(`Newsletter sent to ${users.length} addresses.`, {
|
||||
|
||||
@@ -1,6 +1,6 @@
|
||||
import * as crypto from 'crypto';
|
||||
import { z } from 'zod';
|
||||
import SubscribeEmail from '../../../components/emails/subscribe';
|
||||
import SubscribeTemplate from '../../../components/emails/subscribe';
|
||||
import prisma from '../../../prisma/prisma';
|
||||
import { ApiResponse } from '../../../utils/apiResponse';
|
||||
import { sendEmail } from '../../../utils/sender';
|
||||
@@ -60,7 +60,7 @@ export async function POST(request: Request) {
|
||||
}
|
||||
});
|
||||
|
||||
await sendEmail([email], 'Welcome!', SubscribeEmail(code));
|
||||
await sendEmail([email], SubscribeTemplate(code));
|
||||
|
||||
const message: z.infer<typeof ResponseSchema> = {
|
||||
message: `Thank you! You will now receive an email to ${email} to confirm the subscription.`
|
||||
|
||||
@@ -1,5 +1,5 @@
|
||||
import { z } from 'zod';
|
||||
import UnsubscribeEmail from '../../../components/emails/unsubscribe';
|
||||
import UnsubscribeTemplate from '../../../components/emails/unsubscribe';
|
||||
import prisma from '../../../prisma/prisma';
|
||||
import { ApiResponse } from '../../../utils/apiResponse';
|
||||
import { sendEmail } from '../../../utils/sender';
|
||||
@@ -31,11 +31,11 @@ export async function POST(request: Request) {
|
||||
}
|
||||
});
|
||||
|
||||
sendEmail([email], 'Unsubscribe confirmation', UnsubscribeEmail());
|
||||
await sendEmail([email], UnsubscribeTemplate());
|
||||
}
|
||||
|
||||
const message: z.infer<typeof ResponseSchema> = {
|
||||
message: `${email} unsubscribed!`
|
||||
message: `${email} unsubscribed.`
|
||||
};
|
||||
|
||||
return ApiResponse(200, JSON.stringify(message));
|
||||
|
||||
Reference in New Issue
Block a user