pollo/app/routes/api.room.set.$roomId.tsx

88 lines
2.2 KiB
TypeScript
Raw Permalink Normal View History

2023-04-20 04:20:00 -06:00
import { getAuth } from "@clerk/remix/ssr.server";
2023-12-13 14:52:56 -07:00
import { type ActionFunctionArgs, json } from "@remix-run/node";
2023-04-20 04:20:00 -06:00
import { createId } from "@paralleldrive/cuid2";
import { db } from "~/services/db.server";
import { emitter } from "~/services/emitter.server";
2023-12-11 22:58:49 -07:00
import { logs, rooms, votes } from "~/services/schema.server";
2023-04-20 04:20:00 -06:00
import { eq } from "drizzle-orm";
export async function action({ request, params, context }: ActionFunctionArgs) {
const { userId } = await getAuth({ context, params, request });
if (!userId) {
return json("Not Signed In!", {
status: 403,
statusText: "UNAUTHORIZED!",
});
}
const data = await request.json();
const roomId = params.roomId;
if (data.log) {
const oldRoom = await db.query.rooms.findFirst({
where: eq(rooms.id, params.roomId || ""),
with: {
votes: true,
logs: true,
},
});
oldRoom &&
(await db.insert(logs).values({
id: `log_${createId()}`,
created_at: Date.now().toString(),
userId: userId || "",
roomId: roomId || "",
scale: oldRoom.scale,
votes: JSON.stringify(
oldRoom.votes.map((vote) => {
return {
name: vote.userId,
value: vote.value,
};
})
),
roomName: oldRoom.roomName,
2024-04-09 11:09:51 -06:00
topicName: oldRoom.topicName,
2023-04-20 04:20:00 -06:00
}));
}
if (data.reset) {
await db.delete(votes).where(eq(votes.roomId, params.roomId || ""));
}
const newRoom = data.reset
? await db
2024-04-09 11:09:51 -06:00
.update(rooms)
.set({
topicName: data.name,
visible: data.visible,
scale: [...new Set(data.scale.split(","))]
.filter((item) => item !== "")
.toString(),
})
.where(eq(rooms.id, params.roomId || ""))
.returning()
2023-04-20 04:20:00 -06:00
: await db
2024-04-09 11:09:51 -06:00
.update(rooms)
.set({
visible: data.visible,
})
.where(eq(rooms.id, params.roomId || ""))
.returning();
2023-04-20 04:20:00 -06:00
const success = newRoom.length > 0;
if (success) {
console.log(success);
2023-12-01 14:57:31 -07:00
emitter.emit("nodes", "room");
emitter.emit("nodes", "votes");
2023-04-20 04:20:00 -06:00
return json(newRoom, {
status: 200,
statusText: "SUCCESS",
});
}
}