Move some events team stuff to prisma
This commit is contained in:
@@ -42,20 +42,16 @@ export async function loader({ context }: { context: RequestContext }) {
|
||||
status: 403,
|
||||
});
|
||||
|
||||
const etData = await context.env.D1.prepare(
|
||||
"SELECT id, name, points, roblox_id FROM et_members;",
|
||||
).all();
|
||||
|
||||
if (etData.error)
|
||||
throw new Response(null, {
|
||||
status: 500,
|
||||
const etData = await context.data.prisma.etMember.findMany({
|
||||
select: {
|
||||
id: true,
|
||||
name: true,
|
||||
points: true,
|
||||
roblox_id: true,
|
||||
},
|
||||
});
|
||||
|
||||
const members = etData.results as { [k: string]: any }[];
|
||||
|
||||
return { members } as {
|
||||
members: { [k: string]: any }[];
|
||||
};
|
||||
return { members: etData };
|
||||
}
|
||||
|
||||
export default function () {
|
||||
|
||||
@@ -45,15 +45,15 @@ export async function loader({
|
||||
status: 403,
|
||||
});
|
||||
|
||||
const strikeData = await context.env.D1.prepare(
|
||||
"SELECT * FROM et_strikes WHERE user = ?;",
|
||||
)
|
||||
.bind(params.uid)
|
||||
.all();
|
||||
const strikes = await context.data.prisma.etStrike.findMany({
|
||||
where: {
|
||||
user: params.uid,
|
||||
},
|
||||
});
|
||||
|
||||
return {
|
||||
can_manage: Boolean([1 << 4, 1 << 12].find((p) => user.permissions & p)),
|
||||
strikes: strikeData.results,
|
||||
strikes,
|
||||
user: params.uid,
|
||||
};
|
||||
}
|
||||
|
||||
@@ -30,6 +30,7 @@ import { useLoaderData } from "@remix-run/react";
|
||||
import { useState } from "react";
|
||||
import calendarStyles from "react-big-calendar/lib/css/react-big-calendar.css";
|
||||
import { type LinksFunction } from "@remix-run/cloudflare";
|
||||
import { EtMember } from "../../generated/prisma/client.js";
|
||||
|
||||
export const links: LinksFunction = () => {
|
||||
return [{ href: calendarStyles, rel: "stylesheet" }];
|
||||
@@ -51,34 +52,41 @@ export async function loader({ context }: { context: RequestContext }) {
|
||||
});
|
||||
|
||||
const now = new Date();
|
||||
const monthEventList = await context.env.D1.prepare(
|
||||
"SELECT answer, approved, created_by, day, details, id, month, pending, performed_at, reached_minimum_player_count, type, year FROM events WHERE month = ? AND year = ? ORDER BY day ASC;",
|
||||
)
|
||||
.bind(now.getUTCMonth() + 1, now.getUTCFullYear())
|
||||
.all();
|
||||
|
||||
if (monthEventList.error)
|
||||
throw new Response(null, {
|
||||
status: 500,
|
||||
const { prisma } = context.data;
|
||||
const monthEventList = await prisma.event.findMany({
|
||||
orderBy: {
|
||||
day: "asc",
|
||||
},
|
||||
select: {
|
||||
answer: true,
|
||||
approved: true,
|
||||
created_by: true,
|
||||
day: true,
|
||||
details: true,
|
||||
id: true,
|
||||
month: true,
|
||||
pending: true,
|
||||
performed_at: true,
|
||||
reached_minimum_player_count: true,
|
||||
type: true,
|
||||
year: true,
|
||||
},
|
||||
where: {
|
||||
month: now.getUTCMonth() + 1,
|
||||
year: now.getUTCFullYear(),
|
||||
},
|
||||
});
|
||||
|
||||
const membersList = await context.env.D1.prepare(
|
||||
"SELECT id, name FROM et_members WHERE id IN (SELECT created_by FROM events WHERE month = ? AND year = ?);",
|
||||
)
|
||||
.bind(now.getUTCMonth() + 1, now.getUTCFullYear())
|
||||
.all();
|
||||
|
||||
if (membersList.error)
|
||||
throw new Response(null, {
|
||||
status: 500,
|
||||
});
|
||||
const membersList = await prisma.$queryRaw<
|
||||
EtMember[]
|
||||
>`SELECT id, name FROM et_members WHERE id IN (SELECT created_by FROM events WHERE month = ${now.getUTCMonth() + 1} AND year = ${now.getUTCFullYear()});`;
|
||||
|
||||
return {
|
||||
can_approve: Boolean(
|
||||
[1 << 4, 1 << 12].find((p) => context.data.current_user.permissions & p),
|
||||
),
|
||||
events: monthEventList.results,
|
||||
members: membersList.results as { id: string; name: string }[],
|
||||
events: monthEventList,
|
||||
members: membersList,
|
||||
user_id: context.data.current_user.id as string,
|
||||
};
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user