105 lines
2.5 KiB
TypeScript
105 lines
2.5 KiB
TypeScript
import { GetServerSidePropsContext } from "next";
|
|
|
|
import { PaymentData } from "@ee/lib/stripe/server";
|
|
|
|
import { asStringOrThrow } from "@lib/asStringOrNull";
|
|
import prisma from "@lib/prisma";
|
|
import { inferSSRProps } from "@lib/types/inferSSRProps";
|
|
|
|
export type PaymentPageProps = inferSSRProps<typeof getServerSideProps>;
|
|
|
|
export const getServerSideProps = async (context: GetServerSidePropsContext) => {
|
|
const rawPayment = await prisma.payment.findFirst({
|
|
where: {
|
|
uid: asStringOrThrow(context.query.uid),
|
|
},
|
|
select: {
|
|
data: true,
|
|
success: true,
|
|
uid: true,
|
|
refunded: true,
|
|
bookingId: true,
|
|
booking: {
|
|
select: {
|
|
description: true,
|
|
title: true,
|
|
startTime: true,
|
|
attendees: {
|
|
select: {
|
|
email: true,
|
|
name: true,
|
|
},
|
|
},
|
|
eventTypeId: true,
|
|
location: true,
|
|
eventType: {
|
|
select: {
|
|
id: true,
|
|
title: true,
|
|
description: true,
|
|
length: true,
|
|
eventName: true,
|
|
requiresConfirmation: true,
|
|
userId: true,
|
|
users: {
|
|
select: {
|
|
name: true,
|
|
username: true,
|
|
hideBranding: true,
|
|
plan: true,
|
|
theme: true,
|
|
},
|
|
},
|
|
team: {
|
|
select: {
|
|
name: true,
|
|
hideBranding: true,
|
|
},
|
|
},
|
|
price: true,
|
|
currency: true,
|
|
},
|
|
},
|
|
},
|
|
},
|
|
},
|
|
});
|
|
|
|
if (!rawPayment) throw Error("Payment not found");
|
|
|
|
const { data, booking: _booking, ...restPayment } = rawPayment;
|
|
const payment = {
|
|
...restPayment,
|
|
data: data as unknown as PaymentData,
|
|
};
|
|
|
|
if (!_booking) throw Error("Booking not found");
|
|
|
|
const { startTime, eventType, ...restBooking } = _booking;
|
|
const booking = {
|
|
...restBooking,
|
|
startTime: startTime.toString(),
|
|
};
|
|
|
|
if (!eventType) throw Error("Event not found");
|
|
|
|
const [user] = eventType.users;
|
|
if (!user) return { notFound: true };
|
|
|
|
const profile = {
|
|
name: eventType.team?.name || user?.name || null,
|
|
theme: (!eventType.team?.name && user?.theme) || null,
|
|
hideBranding: eventType.team?.hideBranding || user?.hideBranding || null,
|
|
};
|
|
|
|
return {
|
|
props: {
|
|
user,
|
|
eventType,
|
|
booking,
|
|
payment,
|
|
profile,
|
|
},
|
|
};
|
|
};
|