style: added shadcn-ui

This commit is contained in:
Riccardo
2023-12-05 20:13:29 +01:00
parent 1b0919a460
commit 78de374cba
45 changed files with 1463 additions and 1340 deletions

View File

@@ -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));

View File

@@ -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.`, {

View File

@@ -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.`

View File

@@ -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));