Enhance event model and management: Add new fields for room, time, and maxPlaces to the Event model in Prisma schema. Update API routes and UI components to support these fields, improving event details and user interaction in event management and registration processes.

This commit is contained in:
Julien Froidefond
2025-12-10 05:27:35 +01:00
parent fb5c8c1466
commit fdd860c456
13 changed files with 564 additions and 22 deletions

View File

@@ -16,7 +16,7 @@ export async function PUT(
const { id } = await params; const { id } = await params;
const body = await request.json(); const body = await request.json();
const { date, name, description, type, status } = body; const { date, name, description, type, status, room, time, maxPlaces } = body;
// Vérifier que l'événement existe // Vérifier que l'événement existe
const existingEvent = await prisma.event.findUnique({ const existingEvent = await prisma.event.findUnique({
@@ -36,6 +36,9 @@ export async function PUT(
description?: string; description?: string;
type?: EventType; type?: EventType;
status?: EventStatus; status?: EventStatus;
room?: string | null;
time?: string | null;
maxPlaces?: number | null;
} = {}; } = {};
if (date !== undefined) updateData.date = date; if (date !== undefined) updateData.date = date;
@@ -59,6 +62,9 @@ export async function PUT(
} }
updateData.status = status as EventStatus; updateData.status = status as EventStatus;
} }
if (room !== undefined) updateData.room = room || null;
if (time !== undefined) updateData.time = time || null;
if (maxPlaces !== undefined) updateData.maxPlaces = maxPlaces ? parseInt(maxPlaces) : null;
const event = await prisma.event.update({ const event = await prisma.event.update({
where: { id }, where: { id },

View File

@@ -22,6 +22,9 @@ export async function GET() {
description: true, description: true,
type: true, type: true,
status: true, status: true,
room: true,
time: true,
maxPlaces: true,
createdAt: true, createdAt: true,
updatedAt: true, updatedAt: true,
_count: { _count: {
@@ -40,6 +43,9 @@ export async function GET() {
description: event.description, description: event.description,
type: event.type, type: event.type,
status: event.status, status: event.status,
room: event.room,
time: event.time,
maxPlaces: event.maxPlaces,
createdAt: event.createdAt.toISOString(), createdAt: event.createdAt.toISOString(),
updatedAt: event.updatedAt.toISOString(), updatedAt: event.updatedAt.toISOString(),
registrationsCount: event._count.registrations, registrationsCount: event._count.registrations,
@@ -64,7 +70,7 @@ export async function POST(request: Request) {
} }
const body = await request.json(); const body = await request.json();
const { date, name, description, type, status } = body; const { date, name, description, type, status, room, time, maxPlaces } = body;
if (!date || !name || !description || !type || !status) { if (!date || !name || !description || !type || !status) {
return NextResponse.json( return NextResponse.json(
@@ -95,6 +101,9 @@ export async function POST(request: Request) {
description, description,
type: type as EventType, type: type as EventType,
status: status as EventStatus, status: status as EventStatus,
room: room || null,
time: time || null,
maxPlaces: maxPlaces ? parseInt(maxPlaces) : null,
}, },
}); });

View File

@@ -7,8 +7,11 @@ interface Event {
date: string; date: string;
name: string; name: string;
description: string; description: string;
type: "SUMMIT" | "LAUNCH" | "FESTIVAL" | "COMPETITION"; type: "SUMMIT" | "LAUNCH" | "FESTIVAL" | "COMPETITION" | "CODE_KATA";
status: "UPCOMING" | "LIVE" | "PAST"; status: "UPCOMING" | "LIVE" | "PAST";
room?: string | null;
time?: string | null;
maxPlaces?: number | null;
createdAt: string; createdAt: string;
updatedAt: string; updatedAt: string;
registrationsCount?: number; registrationsCount?: number;
@@ -18,8 +21,11 @@ interface EventFormData {
date: string; date: string;
name: string; name: string;
description: string; description: string;
type: "SUMMIT" | "LAUNCH" | "FESTIVAL" | "COMPETITION"; type: "SUMMIT" | "LAUNCH" | "FESTIVAL" | "COMPETITION" | "CODE_KATA";
status: "UPCOMING" | "LIVE" | "PAST"; status: "UPCOMING" | "LIVE" | "PAST";
room?: string;
time?: string;
maxPlaces?: number;
} }
const eventTypes: Event["type"][] = [ const eventTypes: Event["type"][] = [
@@ -27,6 +33,7 @@ const eventTypes: Event["type"][] = [
"LAUNCH", "LAUNCH",
"FESTIVAL", "FESTIVAL",
"COMPETITION", "COMPETITION",
"CODE_KATA",
]; ];
const eventStatuses: Event["status"][] = ["UPCOMING", "LIVE", "PAST"]; const eventStatuses: Event["status"][] = ["UPCOMING", "LIVE", "PAST"];
@@ -40,6 +47,8 @@ const getEventTypeLabel = (type: Event["type"]) => {
return "Festival"; return "Festival";
case "COMPETITION": case "COMPETITION":
return "Compétition"; return "Compétition";
case "CODE_KATA":
return "Code Kata";
default: default:
return type; return type;
} }
@@ -70,6 +79,9 @@ export default function EventManagement() {
description: "", description: "",
type: "SUMMIT", type: "SUMMIT",
status: "UPCOMING", status: "UPCOMING",
room: "",
time: "",
maxPlaces: undefined,
}); });
useEffect(() => { useEffect(() => {
@@ -99,6 +111,9 @@ export default function EventManagement() {
description: "", description: "",
type: "SUMMIT", type: "SUMMIT",
status: "UPCOMING", status: "UPCOMING",
room: "",
time: "",
maxPlaces: undefined,
}); });
}; };
@@ -111,6 +126,9 @@ export default function EventManagement() {
description: event.description, description: event.description,
type: event.type, type: event.type,
status: event.status, status: event.status,
room: event.room || "",
time: event.time || "",
maxPlaces: event.maxPlaces || undefined,
}); });
}; };
@@ -146,6 +164,9 @@ export default function EventManagement() {
description: "", description: "",
type: "SUMMIT", type: "SUMMIT",
status: "UPCOMING", status: "UPCOMING",
room: "",
time: "",
maxPlaces: undefined,
}); });
} else { } else {
const error = await response?.json(); const error = await response?.json();
@@ -190,6 +211,9 @@ export default function EventManagement() {
description: "", description: "",
type: "SUMMIT", type: "SUMMIT",
status: "UPCOMING", status: "UPCOMING",
room: "",
time: "",
maxPlaces: undefined,
}); });
}; };
@@ -298,6 +322,55 @@ export default function EventManagement() {
</select> </select>
</div> </div>
</div> </div>
<div className="grid grid-cols-3 gap-4">
<div>
<label className="block text-sm text-gray-300 mb-1">
Salle
</label>
<input
type="text"
value={formData.room || ""}
onChange={(e) =>
setFormData({ ...formData, room: e.target.value })
}
placeholder="Ex: Nautilus"
className="w-full px-3 py-2 bg-black/60 border border-pixel-gold/30 rounded text-white text-sm"
/>
</div>
<div>
<label className="block text-sm text-gray-300 mb-1">
Heure
</label>
<input
type="text"
value={formData.time || ""}
onChange={(e) =>
setFormData({ ...formData, time: e.target.value })
}
placeholder="Ex: 11h-12h"
className="w-full px-3 py-2 bg-black/60 border border-pixel-gold/30 rounded text-white text-sm"
/>
</div>
<div>
<label className="block text-sm text-gray-300 mb-1">
Places max
</label>
<input
type="number"
value={formData.maxPlaces || ""}
onChange={(e) =>
setFormData({
...formData,
maxPlaces: e.target.value
? parseInt(e.target.value)
: undefined,
})
}
placeholder="Ex: 25"
className="w-full px-3 py-2 bg-black/60 border border-pixel-gold/30 rounded text-white text-sm"
/>
</div>
</div>
<div className="flex gap-2"> <div className="flex gap-2">
<button <button
onClick={handleSave} onClick={handleSave}
@@ -352,10 +425,25 @@ export default function EventManagement() {
<p className="text-gray-400 text-sm mb-2"> <p className="text-gray-400 text-sm mb-2">
{event.description} {event.description}
</p> </p>
<div className="flex items-center gap-4 mt-2"> <div className="flex flex-wrap items-center gap-4 mt-2">
<p className="text-gray-500 text-xs"> <p className="text-gray-500 text-xs">
Date: {new Date(event.date).toLocaleDateString("fr-FR")} Date: {new Date(event.date).toLocaleDateString("fr-FR")}
</p> </p>
{event.room && (
<p className="text-gray-500 text-xs">
📍 Salle: {event.room}
</p>
)}
{event.time && (
<p className="text-gray-500 text-xs">
🕐 Heure: {event.time}
</p>
)}
{event.maxPlaces && (
<p className="text-gray-500 text-xs">
👥 Places: {event.maxPlaces}
</p>
)}
<span className="px-2 py-1 bg-blue-900/30 border border-blue-500/50 text-blue-400 text-xs rounded"> <span className="px-2 py-1 bg-blue-900/30 border border-blue-500/50 text-blue-400 text-xs rounded">
{event.registrationsCount || 0} inscrit {event.registrationsCount || 0} inscrit
{event.registrationsCount !== 1 ? "s" : ""} {event.registrationsCount !== 1 ? "s" : ""}

View File

@@ -9,8 +9,11 @@ interface Event {
date: string; date: string;
name: string; name: string;
description: string; description: string;
type: "SUMMIT" | "LAUNCH" | "FESTIVAL" | "COMPETITION"; type: "SUMMIT" | "LAUNCH" | "FESTIVAL" | "COMPETITION" | "CODE_KATA";
status: "UPCOMING" | "LIVE" | "PAST"; status: "UPCOMING" | "LIVE" | "PAST";
room?: string | null;
time?: string | null;
maxPlaces?: number | null;
} }
interface EventsPageSectionProps { interface EventsPageSectionProps {
@@ -29,6 +32,8 @@ const getEventTypeColor = (type: Event["type"]) => {
return "from-pixel-gold to-orange-500"; return "from-pixel-gold to-orange-500";
case "COMPETITION": case "COMPETITION":
return "from-red-600 to-orange-500"; return "from-red-600 to-orange-500";
case "CODE_KATA":
return "from-green-600 to-emerald-500";
default: default:
return "from-gray-600 to-gray-500"; return "from-gray-600 to-gray-500";
} }
@@ -44,6 +49,8 @@ const getEventTypeLabel = (type: Event["type"]) => {
return "Festival"; return "Festival";
case "COMPETITION": case "COMPETITION":
return "Compétition"; return "Compétition";
case "CODE_KATA":
return "Code Kata";
default: default:
return type; return type;
} }
@@ -84,6 +91,7 @@ export default function EventsPageSection({
const [loading, setLoading] = useState<Record<string, boolean>>({}); const [loading, setLoading] = useState<Record<string, boolean>>({});
const [error, setError] = useState<string>(""); const [error, setError] = useState<string>("");
const [currentMonth, setCurrentMonth] = useState(new Date()); const [currentMonth, setCurrentMonth] = useState(new Date());
const [selectedEvent, setSelectedEvent] = useState<Event | null>(null);
// Déterminer si on a des données initiales valides // Déterminer si on a des données initiales valides
const hasInitialData = useMemo( const hasInitialData = useMemo(
@@ -338,10 +346,16 @@ export default function EventsPageSection({
); );
}; };
const truncateDescription = (text: string, maxLength: number = 150) => {
if (text.length <= maxLength) return text;
return text.substring(0, maxLength).trim() + "...";
};
const renderEventCard = (event: Event) => ( const renderEventCard = (event: Event) => (
<div <div
key={event.id} key={event.id}
className="bg-black/60 border border-pixel-gold/30 rounded-lg overflow-hidden backdrop-blur-sm hover:border-pixel-gold/50 transition group" onClick={() => setSelectedEvent(event)}
className="bg-black/60 border border-pixel-gold/30 rounded-lg overflow-hidden backdrop-blur-sm hover:border-pixel-gold/50 transition group cursor-pointer"
> >
{/* Event Header */} {/* Event Header */}
<div <div
@@ -368,17 +382,52 @@ export default function EventsPageSection({
{event.name} {event.name}
</h3> </h3>
{/* Description */} {/* Event Details */}
{(event.room || event.time || event.maxPlaces) && (
<div className="flex flex-wrap gap-3 mb-4 text-sm">
{event.room && (
<div className="flex items-center gap-1.5 text-gray-300">
<span className="text-pixel-gold">📍</span>
<span className="font-semibold">Salle:</span>
<span>{event.room}</span>
</div>
)}
{event.time && (
<div className="flex items-center gap-1.5 text-gray-300">
<span className="text-pixel-gold">🕐</span>
<span className="font-semibold">Heure:</span>
<span>{event.time}</span>
</div>
)}
{event.maxPlaces && (
<div className="flex items-center gap-1.5 text-gray-300">
<span className="text-pixel-gold">👥</span>
<span className="font-semibold">Places:</span>
<span>{event.maxPlaces}</span>
</div>
)}
</div>
)}
{/* Description (truncated) */}
<p className="text-gray-400 text-sm leading-relaxed mb-4"> <p className="text-gray-400 text-sm leading-relaxed mb-4">
{event.description} {truncateDescription(event.description)}
</p> </p>
{event.description.length > 150 && (
<p className="text-pixel-gold text-xs mb-4 italic">
Cliquez pour voir plus...
</p>
)}
{/* Action Button */} {/* Action Button */}
{event.status === "UPCOMING" && ( {event.status === "UPCOMING" && (
<> <>
{registrations[event.id] ? ( {registrations[event.id] ? (
<button <button
onClick={() => handleUnregister(event.id)} onClick={(e) => {
e.stopPropagation();
handleUnregister(event.id);
}}
disabled={loading[event.id]} disabled={loading[event.id]}
className="w-full px-4 py-2 border border-green-500/50 bg-green-900/20 text-green-400 uppercase text-xs tracking-widest rounded hover:bg-green-900/30 transition disabled:opacity-50 disabled:cursor-not-allowed" className="w-full px-4 py-2 border border-green-500/50 bg-green-900/20 text-green-400 uppercase text-xs tracking-widest rounded hover:bg-green-900/30 transition disabled:opacity-50 disabled:cursor-not-allowed"
> >
@@ -386,7 +435,10 @@ export default function EventsPageSection({
</button> </button>
) : ( ) : (
<button <button
onClick={() => handleRegister(event.id)} onClick={(e) => {
e.stopPropagation();
handleRegister(event.id);
}}
disabled={loading[event.id]} disabled={loading[event.id]}
className="w-full px-4 py-2 border border-pixel-gold/50 bg-black/40 text-white uppercase text-xs tracking-widest rounded hover:bg-pixel-gold/10 hover:border-pixel-gold transition disabled:opacity-50 disabled:cursor-not-allowed" className="w-full px-4 py-2 border border-pixel-gold/50 bg-black/40 text-white uppercase text-xs tracking-widest rounded hover:bg-pixel-gold/10 hover:border-pixel-gold transition disabled:opacity-50 disabled:cursor-not-allowed"
> >
@@ -557,6 +609,160 @@ export default function EventsPageSection({
</p> </p>
</div> </div>
</div> </div>
{/* Event Modal */}
{selectedEvent && (
<div
className="fixed inset-0 z-[200] flex items-center justify-center p-4 bg-black/80 backdrop-blur-sm"
onClick={() => setSelectedEvent(null)}
>
<div
className="bg-black border-2 border-pixel-gold/70 rounded-lg max-w-3xl w-full max-h-[90vh] overflow-y-auto shadow-2xl"
onClick={(e) => e.stopPropagation()}
>
<div className="p-8">
{/* Header */}
<div className="flex items-center justify-between mb-6">
<div className="flex-1">
<div className="flex items-center gap-3 mb-2">
{getStatusBadge(selectedEvent.status)}
<span className="px-3 py-1 bg-pixel-gold/20 border border-pixel-gold/50 text-pixel-gold text-xs uppercase rounded">
{getEventTypeLabel(selectedEvent.type)}
</span>
</div>
<h2 className="text-3xl font-bold text-white uppercase tracking-wide">
{selectedEvent.name}
</h2>
</div>
<button
onClick={() => setSelectedEvent(null)}
className="text-gray-400 hover:text-pixel-gold text-3xl font-bold transition ml-4"
>
×
</button>
</div>
{/* Event Header Color Bar */}
<div
className={`h-1 bg-gradient-to-r ${getEventTypeColor(
selectedEvent.type
)} mb-6 rounded`}
></div>
{/* Date */}
<div className="text-white text-lg font-bold uppercase tracking-widest mb-4">
{selectedEvent.date}
</div>
{/* Event Details */}
{(selectedEvent.room ||
selectedEvent.time ||
selectedEvent.maxPlaces) && (
<div className="grid grid-cols-1 md:grid-cols-3 gap-4 mb-6">
{selectedEvent.room && (
<div className="flex items-center gap-2 text-gray-300 bg-black/40 p-3 rounded border border-pixel-gold/20">
<span className="text-pixel-gold text-xl">📍</span>
<div>
<div className="text-xs text-gray-400 uppercase tracking-wider">
Salle
</div>
<div className="font-semibold">
{selectedEvent.room}
</div>
</div>
</div>
)}
{selectedEvent.time && (
<div className="flex items-center gap-2 text-gray-300 bg-black/40 p-3 rounded border border-pixel-gold/20">
<span className="text-pixel-gold text-xl">🕐</span>
<div>
<div className="text-xs text-gray-400 uppercase tracking-wider">
Heure
</div>
<div className="font-semibold">
{selectedEvent.time}
</div>
</div>
</div>
)}
{selectedEvent.maxPlaces && (
<div className="flex items-center gap-2 text-gray-300 bg-black/40 p-3 rounded border border-pixel-gold/20">
<span className="text-pixel-gold text-xl">👥</span>
<div>
<div className="text-xs text-gray-400 uppercase tracking-wider">
Places
</div>
<div className="font-semibold">
{selectedEvent.maxPlaces}
</div>
</div>
</div>
)}
</div>
)}
{/* Full Description */}
<div className="mb-6">
<h3 className="text-pixel-gold text-sm uppercase tracking-widest mb-3">
Description
</h3>
<p className="text-gray-300 text-sm leading-relaxed whitespace-pre-line">
{selectedEvent.description}
</p>
</div>
{/* Action Button */}
{selectedEvent.status === "UPCOMING" && (
<div className="pt-4 border-t border-pixel-gold/20">
{registrations[selectedEvent.id] ? (
<button
onClick={(e) => {
e.stopPropagation();
handleUnregister(selectedEvent.id);
setSelectedEvent(null);
}}
disabled={loading[selectedEvent.id]}
className="w-full px-4 py-3 border border-green-500/50 bg-green-900/20 text-green-400 uppercase text-sm tracking-widest rounded hover:bg-green-900/30 transition disabled:opacity-50 disabled:cursor-not-allowed"
>
{loading[selectedEvent.id]
? "Annulation..."
: "Se désinscrire"}
</button>
) : (
<button
onClick={(e) => {
e.stopPropagation();
handleRegister(selectedEvent.id);
setSelectedEvent(null);
}}
disabled={loading[selectedEvent.id]}
className="w-full px-4 py-3 border border-pixel-gold/50 bg-pixel-gold/10 text-white uppercase text-sm tracking-widest rounded hover:bg-pixel-gold/20 hover:border-pixel-gold transition disabled:opacity-50 disabled:cursor-not-allowed"
>
{loading[selectedEvent.id]
? "Inscription..."
: "S'inscrire maintenant"}
</button>
)}
</div>
)}
{selectedEvent.status === "LIVE" && (
<div className="pt-4 border-t border-pixel-gold/20">
<button className="w-full px-4 py-3 border border-red-500/50 bg-red-900/20 text-red-400 uppercase text-sm tracking-widest rounded hover:bg-red-900/30 transition animate-pulse">
Rejoindre en direct
</button>
</div>
)}
{selectedEvent.status === "PAST" && (
<div className="pt-4 border-t border-pixel-gold/20">
<button className="w-full px-4 py-3 border border-gray-600/50 bg-gray-900/20 text-gray-500 uppercase text-sm tracking-widest rounded cursor-not-allowed">
Événement terminé
</button>
</div>
)}
</div>
</div>
</div>
)}
</section> </section>
); );
} }

View File

@@ -181,6 +181,17 @@ export type EnumEventStatusFilter<$PrismaModel = never> = {
not?: Prisma.NestedEnumEventStatusFilter<$PrismaModel> | $Enums.EventStatus not?: Prisma.NestedEnumEventStatusFilter<$PrismaModel> | $Enums.EventStatus
} }
export type IntNullableFilter<$PrismaModel = never> = {
equals?: number | Prisma.IntFieldRefInput<$PrismaModel> | null
in?: number[] | null
notIn?: number[] | null
lt?: number | Prisma.IntFieldRefInput<$PrismaModel>
lte?: number | Prisma.IntFieldRefInput<$PrismaModel>
gt?: number | Prisma.IntFieldRefInput<$PrismaModel>
gte?: number | Prisma.IntFieldRefInput<$PrismaModel>
not?: Prisma.NestedIntNullableFilter<$PrismaModel> | number | null
}
export type EnumEventTypeWithAggregatesFilter<$PrismaModel = never> = { export type EnumEventTypeWithAggregatesFilter<$PrismaModel = never> = {
equals?: $Enums.EventType | Prisma.EnumEventTypeFieldRefInput<$PrismaModel> equals?: $Enums.EventType | Prisma.EnumEventTypeFieldRefInput<$PrismaModel>
in?: $Enums.EventType[] in?: $Enums.EventType[]
@@ -201,6 +212,22 @@ export type EnumEventStatusWithAggregatesFilter<$PrismaModel = never> = {
_max?: Prisma.NestedEnumEventStatusFilter<$PrismaModel> _max?: Prisma.NestedEnumEventStatusFilter<$PrismaModel>
} }
export type IntNullableWithAggregatesFilter<$PrismaModel = never> = {
equals?: number | Prisma.IntFieldRefInput<$PrismaModel> | null
in?: number[] | null
notIn?: number[] | null
lt?: number | Prisma.IntFieldRefInput<$PrismaModel>
lte?: number | Prisma.IntFieldRefInput<$PrismaModel>
gt?: number | Prisma.IntFieldRefInput<$PrismaModel>
gte?: number | Prisma.IntFieldRefInput<$PrismaModel>
not?: Prisma.NestedIntNullableWithAggregatesFilter<$PrismaModel> | number | null
_count?: Prisma.NestedIntNullableFilter<$PrismaModel>
_avg?: Prisma.NestedFloatNullableFilter<$PrismaModel>
_sum?: Prisma.NestedIntNullableFilter<$PrismaModel>
_min?: Prisma.NestedIntNullableFilter<$PrismaModel>
_max?: Prisma.NestedIntNullableFilter<$PrismaModel>
}
export type NestedStringFilter<$PrismaModel = never> = { export type NestedStringFilter<$PrismaModel = never> = {
equals?: string | Prisma.StringFieldRefInput<$PrismaModel> equals?: string | Prisma.StringFieldRefInput<$PrismaModel>
in?: string[] in?: string[]
@@ -405,4 +432,31 @@ export type NestedEnumEventStatusWithAggregatesFilter<$PrismaModel = never> = {
_max?: Prisma.NestedEnumEventStatusFilter<$PrismaModel> _max?: Prisma.NestedEnumEventStatusFilter<$PrismaModel>
} }
export type NestedIntNullableWithAggregatesFilter<$PrismaModel = never> = {
equals?: number | Prisma.IntFieldRefInput<$PrismaModel> | null
in?: number[] | null
notIn?: number[] | null
lt?: number | Prisma.IntFieldRefInput<$PrismaModel>
lte?: number | Prisma.IntFieldRefInput<$PrismaModel>
gt?: number | Prisma.IntFieldRefInput<$PrismaModel>
gte?: number | Prisma.IntFieldRefInput<$PrismaModel>
not?: Prisma.NestedIntNullableWithAggregatesFilter<$PrismaModel> | number | null
_count?: Prisma.NestedIntNullableFilter<$PrismaModel>
_avg?: Prisma.NestedFloatNullableFilter<$PrismaModel>
_sum?: Prisma.NestedIntNullableFilter<$PrismaModel>
_min?: Prisma.NestedIntNullableFilter<$PrismaModel>
_max?: Prisma.NestedIntNullableFilter<$PrismaModel>
}
export type NestedFloatNullableFilter<$PrismaModel = never> = {
equals?: number | Prisma.FloatFieldRefInput<$PrismaModel> | null
in?: number[] | null
notIn?: number[] | null
lt?: number | Prisma.FloatFieldRefInput<$PrismaModel>
lte?: number | Prisma.FloatFieldRefInput<$PrismaModel>
gt?: number | Prisma.FloatFieldRefInput<$PrismaModel>
gte?: number | Prisma.FloatFieldRefInput<$PrismaModel>
not?: Prisma.NestedFloatNullableFilter<$PrismaModel> | number | null
}

View File

@@ -21,7 +21,8 @@ export const EventType = {
SUMMIT: 'SUMMIT', SUMMIT: 'SUMMIT',
LAUNCH: 'LAUNCH', LAUNCH: 'LAUNCH',
FESTIVAL: 'FESTIVAL', FESTIVAL: 'FESTIVAL',
COMPETITION: 'COMPETITION' COMPETITION: 'COMPETITION',
CODE_KATA: 'CODE_KATA'
} as const } as const
export type EventType = (typeof EventType)[keyof typeof EventType] export type EventType = (typeof EventType)[keyof typeof EventType]

View File

@@ -20,7 +20,7 @@ const config: runtime.GetPrismaClientConfig = {
"clientVersion": "7.1.0", "clientVersion": "7.1.0",
"engineVersion": "ab635e6b9d606fa5c8fb8b1a7f909c3c3c1c98ba", "engineVersion": "ab635e6b9d606fa5c8fb8b1a7f909c3c3c1c98ba",
"activeProvider": "sqlite", "activeProvider": "sqlite",
"inlineSchema": "// This is your Prisma schema file,\n// learn more about it in the docs: https://pris.ly/d/prisma-schema\n\ngenerator client {\n provider = \"prisma-client\"\n output = \"./generated/prisma\"\n}\n\ndatasource db {\n provider = \"sqlite\"\n}\n\nenum Role {\n USER\n ADMIN\n}\n\nenum EventType {\n SUMMIT\n LAUNCH\n FESTIVAL\n COMPETITION\n}\n\nenum EventStatus {\n UPCOMING\n LIVE\n PAST\n}\n\nenum CharacterClass {\n WARRIOR\n MAGE\n ROGUE\n RANGER\n PALADIN\n ENGINEER\n MERCHANT\n SCHOLAR\n BERSERKER\n NECROMANCER\n}\n\nmodel User {\n id String @id @default(cuid())\n email String @unique\n password String\n username String @unique\n role Role @default(USER)\n score Int @default(0)\n level Int @default(1)\n hp Int @default(1000)\n maxHp Int @default(1000)\n xp Int @default(0)\n maxXp Int @default(5000)\n avatar String?\n bio String?\n characterClass CharacterClass?\n createdAt DateTime @default(now())\n updatedAt DateTime @updatedAt\n preferences UserPreferences?\n eventRegistrations EventRegistration[]\n\n @@index([score])\n @@index([email])\n}\n\nmodel UserPreferences {\n id String @id @default(cuid())\n userId String @unique\n user User @relation(fields: [userId], references: [id], onDelete: Cascade)\n\n // Background images for each page\n homeBackground String?\n eventsBackground String?\n leaderboardBackground String?\n\n // Other UI preferences can be added here\n theme String? @default(\"default\")\n\n createdAt DateTime @default(now())\n updatedAt DateTime @updatedAt\n}\n\nmodel Event {\n id String @id @default(cuid())\n date String\n name String\n description String\n type EventType\n status EventStatus\n createdAt DateTime @default(now())\n updatedAt DateTime @updatedAt\n registrations EventRegistration[]\n\n @@index([status])\n @@index([date])\n}\n\nmodel EventRegistration {\n id String @id @default(cuid())\n userId String\n eventId String\n user User @relation(fields: [userId], references: [id], onDelete: Cascade)\n event Event @relation(fields: [eventId], references: [id], onDelete: Cascade)\n createdAt DateTime @default(now())\n\n @@unique([userId, eventId])\n @@index([userId])\n @@index([eventId])\n}\n\nmodel SitePreferences {\n id String @id @default(\"global\")\n homeBackground String?\n eventsBackground String?\n leaderboardBackground String?\n createdAt DateTime @default(now())\n updatedAt DateTime @updatedAt\n}\n", "inlineSchema": "// This is your Prisma schema file,\n// learn more about it in the docs: https://pris.ly/d/prisma-schema\n\ngenerator client {\n provider = \"prisma-client\"\n output = \"./generated/prisma\"\n}\n\ndatasource db {\n provider = \"sqlite\"\n}\n\nenum Role {\n USER\n ADMIN\n}\n\nenum EventType {\n SUMMIT\n LAUNCH\n FESTIVAL\n COMPETITION\n CODE_KATA\n}\n\nenum EventStatus {\n UPCOMING\n LIVE\n PAST\n}\n\nenum CharacterClass {\n WARRIOR\n MAGE\n ROGUE\n RANGER\n PALADIN\n ENGINEER\n MERCHANT\n SCHOLAR\n BERSERKER\n NECROMANCER\n}\n\nmodel User {\n id String @id @default(cuid())\n email String @unique\n password String\n username String @unique\n role Role @default(USER)\n score Int @default(0)\n level Int @default(1)\n hp Int @default(1000)\n maxHp Int @default(1000)\n xp Int @default(0)\n maxXp Int @default(5000)\n avatar String?\n bio String?\n characterClass CharacterClass?\n createdAt DateTime @default(now())\n updatedAt DateTime @updatedAt\n preferences UserPreferences?\n eventRegistrations EventRegistration[]\n\n @@index([score])\n @@index([email])\n}\n\nmodel UserPreferences {\n id String @id @default(cuid())\n userId String @unique\n user User @relation(fields: [userId], references: [id], onDelete: Cascade)\n\n // Background images for each page\n homeBackground String?\n eventsBackground String?\n leaderboardBackground String?\n\n // Other UI preferences can be added here\n theme String? @default(\"default\")\n\n createdAt DateTime @default(now())\n updatedAt DateTime @updatedAt\n}\n\nmodel Event {\n id String @id @default(cuid())\n date String\n name String\n description String\n type EventType\n status EventStatus\n room String?\n time String?\n maxPlaces Int?\n createdAt DateTime @default(now())\n updatedAt DateTime @updatedAt\n registrations EventRegistration[]\n\n @@index([status])\n @@index([date])\n}\n\nmodel EventRegistration {\n id String @id @default(cuid())\n userId String\n eventId String\n user User @relation(fields: [userId], references: [id], onDelete: Cascade)\n event Event @relation(fields: [eventId], references: [id], onDelete: Cascade)\n createdAt DateTime @default(now())\n\n @@unique([userId, eventId])\n @@index([userId])\n @@index([eventId])\n}\n\nmodel SitePreferences {\n id String @id @default(\"global\")\n homeBackground String?\n eventsBackground String?\n leaderboardBackground String?\n createdAt DateTime @default(now())\n updatedAt DateTime @updatedAt\n}\n",
"runtimeDataModel": { "runtimeDataModel": {
"models": {}, "models": {},
"enums": {}, "enums": {},
@@ -28,7 +28,7 @@ const config: runtime.GetPrismaClientConfig = {
} }
} }
config.runtimeDataModel = JSON.parse("{\"models\":{\"User\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"email\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"password\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"username\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"role\",\"kind\":\"enum\",\"type\":\"Role\"},{\"name\":\"score\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"level\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"hp\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"maxHp\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"xp\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"maxXp\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"avatar\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"bio\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"characterClass\",\"kind\":\"enum\",\"type\":\"CharacterClass\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"updatedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"preferences\",\"kind\":\"object\",\"type\":\"UserPreferences\",\"relationName\":\"UserToUserPreferences\"},{\"name\":\"eventRegistrations\",\"kind\":\"object\",\"type\":\"EventRegistration\",\"relationName\":\"EventRegistrationToUser\"}],\"dbName\":null},\"UserPreferences\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"userId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"user\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"UserToUserPreferences\"},{\"name\":\"homeBackground\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"eventsBackground\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"leaderboardBackground\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"theme\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"updatedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"}],\"dbName\":null},\"Event\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"date\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"name\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"description\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"type\",\"kind\":\"enum\",\"type\":\"EventType\"},{\"name\":\"status\",\"kind\":\"enum\",\"type\":\"EventStatus\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"updatedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"registrations\",\"kind\":\"object\",\"type\":\"EventRegistration\",\"relationName\":\"EventToEventRegistration\"}],\"dbName\":null},\"EventRegistration\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"userId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"eventId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"user\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"EventRegistrationToUser\"},{\"name\":\"event\",\"kind\":\"object\",\"type\":\"Event\",\"relationName\":\"EventToEventRegistration\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"}],\"dbName\":null},\"SitePreferences\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"homeBackground\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"eventsBackground\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"leaderboardBackground\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"updatedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"}],\"dbName\":null}},\"enums\":{},\"types\":{}}") config.runtimeDataModel = JSON.parse("{\"models\":{\"User\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"email\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"password\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"username\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"role\",\"kind\":\"enum\",\"type\":\"Role\"},{\"name\":\"score\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"level\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"hp\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"maxHp\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"xp\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"maxXp\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"avatar\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"bio\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"characterClass\",\"kind\":\"enum\",\"type\":\"CharacterClass\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"updatedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"preferences\",\"kind\":\"object\",\"type\":\"UserPreferences\",\"relationName\":\"UserToUserPreferences\"},{\"name\":\"eventRegistrations\",\"kind\":\"object\",\"type\":\"EventRegistration\",\"relationName\":\"EventRegistrationToUser\"}],\"dbName\":null},\"UserPreferences\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"userId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"user\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"UserToUserPreferences\"},{\"name\":\"homeBackground\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"eventsBackground\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"leaderboardBackground\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"theme\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"updatedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"}],\"dbName\":null},\"Event\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"date\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"name\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"description\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"type\",\"kind\":\"enum\",\"type\":\"EventType\"},{\"name\":\"status\",\"kind\":\"enum\",\"type\":\"EventStatus\"},{\"name\":\"room\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"time\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"maxPlaces\",\"kind\":\"scalar\",\"type\":\"Int\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"updatedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"registrations\",\"kind\":\"object\",\"type\":\"EventRegistration\",\"relationName\":\"EventToEventRegistration\"}],\"dbName\":null},\"EventRegistration\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"userId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"eventId\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"user\",\"kind\":\"object\",\"type\":\"User\",\"relationName\":\"EventRegistrationToUser\"},{\"name\":\"event\",\"kind\":\"object\",\"type\":\"Event\",\"relationName\":\"EventToEventRegistration\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"}],\"dbName\":null},\"SitePreferences\":{\"fields\":[{\"name\":\"id\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"homeBackground\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"eventsBackground\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"leaderboardBackground\",\"kind\":\"scalar\",\"type\":\"String\"},{\"name\":\"createdAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"},{\"name\":\"updatedAt\",\"kind\":\"scalar\",\"type\":\"DateTime\"}],\"dbName\":null}},\"enums\":{},\"types\":{}}")
async function decodeBase64AsWasm(wasmBase64: string): Promise<WebAssembly.Module> { async function decodeBase64AsWasm(wasmBase64: string): Promise<WebAssembly.Module> {
const { Buffer } = await import('node:buffer') const { Buffer } = await import('node:buffer')

View File

@@ -857,6 +857,9 @@ export const EventScalarFieldEnum = {
description: 'description', description: 'description',
type: 'type', type: 'type',
status: 'status', status: 'status',
room: 'room',
time: 'time',
maxPlaces: 'maxPlaces',
createdAt: 'createdAt', createdAt: 'createdAt',
updatedAt: 'updatedAt' updatedAt: 'updatedAt'
} as const } as const

View File

@@ -114,6 +114,9 @@ export const EventScalarFieldEnum = {
description: 'description', description: 'description',
type: 'type', type: 'type',
status: 'status', status: 'status',
room: 'room',
time: 'time',
maxPlaces: 'maxPlaces',
createdAt: 'createdAt', createdAt: 'createdAt',
updatedAt: 'updatedAt' updatedAt: 'updatedAt'
} as const } as const

View File

@@ -20,10 +20,20 @@ export type EventModel = runtime.Types.Result.DefaultSelection<Prisma.$EventPayl
export type AggregateEvent = { export type AggregateEvent = {
_count: EventCountAggregateOutputType | null _count: EventCountAggregateOutputType | null
_avg: EventAvgAggregateOutputType | null
_sum: EventSumAggregateOutputType | null
_min: EventMinAggregateOutputType | null _min: EventMinAggregateOutputType | null
_max: EventMaxAggregateOutputType | null _max: EventMaxAggregateOutputType | null
} }
export type EventAvgAggregateOutputType = {
maxPlaces: number | null
}
export type EventSumAggregateOutputType = {
maxPlaces: number | null
}
export type EventMinAggregateOutputType = { export type EventMinAggregateOutputType = {
id: string | null id: string | null
date: string | null date: string | null
@@ -31,6 +41,9 @@ export type EventMinAggregateOutputType = {
description: string | null description: string | null
type: $Enums.EventType | null type: $Enums.EventType | null
status: $Enums.EventStatus | null status: $Enums.EventStatus | null
room: string | null
time: string | null
maxPlaces: number | null
createdAt: Date | null createdAt: Date | null
updatedAt: Date | null updatedAt: Date | null
} }
@@ -42,6 +55,9 @@ export type EventMaxAggregateOutputType = {
description: string | null description: string | null
type: $Enums.EventType | null type: $Enums.EventType | null
status: $Enums.EventStatus | null status: $Enums.EventStatus | null
room: string | null
time: string | null
maxPlaces: number | null
createdAt: Date | null createdAt: Date | null
updatedAt: Date | null updatedAt: Date | null
} }
@@ -53,12 +69,23 @@ export type EventCountAggregateOutputType = {
description: number description: number
type: number type: number
status: number status: number
room: number
time: number
maxPlaces: number
createdAt: number createdAt: number
updatedAt: number updatedAt: number
_all: number _all: number
} }
export type EventAvgAggregateInputType = {
maxPlaces?: true
}
export type EventSumAggregateInputType = {
maxPlaces?: true
}
export type EventMinAggregateInputType = { export type EventMinAggregateInputType = {
id?: true id?: true
date?: true date?: true
@@ -66,6 +93,9 @@ export type EventMinAggregateInputType = {
description?: true description?: true
type?: true type?: true
status?: true status?: true
room?: true
time?: true
maxPlaces?: true
createdAt?: true createdAt?: true
updatedAt?: true updatedAt?: true
} }
@@ -77,6 +107,9 @@ export type EventMaxAggregateInputType = {
description?: true description?: true
type?: true type?: true
status?: true status?: true
room?: true
time?: true
maxPlaces?: true
createdAt?: true createdAt?: true
updatedAt?: true updatedAt?: true
} }
@@ -88,6 +121,9 @@ export type EventCountAggregateInputType = {
description?: true description?: true
type?: true type?: true
status?: true status?: true
room?: true
time?: true
maxPlaces?: true
createdAt?: true createdAt?: true
updatedAt?: true updatedAt?: true
_all?: true _all?: true
@@ -128,6 +164,18 @@ export type EventAggregateArgs<ExtArgs extends runtime.Types.Extensions.Internal
* Count returned Events * Count returned Events
**/ **/
_count?: true | EventCountAggregateInputType _count?: true | EventCountAggregateInputType
/**
* {@link https://www.prisma.io/docs/concepts/components/prisma-client/aggregations Aggregation Docs}
*
* Select which fields to average
**/
_avg?: EventAvgAggregateInputType
/**
* {@link https://www.prisma.io/docs/concepts/components/prisma-client/aggregations Aggregation Docs}
*
* Select which fields to sum
**/
_sum?: EventSumAggregateInputType
/** /**
* {@link https://www.prisma.io/docs/concepts/components/prisma-client/aggregations Aggregation Docs} * {@link https://www.prisma.io/docs/concepts/components/prisma-client/aggregations Aggregation Docs}
* *
@@ -161,6 +209,8 @@ export type EventGroupByArgs<ExtArgs extends runtime.Types.Extensions.InternalAr
take?: number take?: number
skip?: number skip?: number
_count?: EventCountAggregateInputType | true _count?: EventCountAggregateInputType | true
_avg?: EventAvgAggregateInputType
_sum?: EventSumAggregateInputType
_min?: EventMinAggregateInputType _min?: EventMinAggregateInputType
_max?: EventMaxAggregateInputType _max?: EventMaxAggregateInputType
} }
@@ -172,9 +222,14 @@ export type EventGroupByOutputType = {
description: string description: string
type: $Enums.EventType type: $Enums.EventType
status: $Enums.EventStatus status: $Enums.EventStatus
room: string | null
time: string | null
maxPlaces: number | null
createdAt: Date createdAt: Date
updatedAt: Date updatedAt: Date
_count: EventCountAggregateOutputType | null _count: EventCountAggregateOutputType | null
_avg: EventAvgAggregateOutputType | null
_sum: EventSumAggregateOutputType | null
_min: EventMinAggregateOutputType | null _min: EventMinAggregateOutputType | null
_max: EventMaxAggregateOutputType | null _max: EventMaxAggregateOutputType | null
} }
@@ -204,6 +259,9 @@ export type EventWhereInput = {
description?: Prisma.StringFilter<"Event"> | string description?: Prisma.StringFilter<"Event"> | string
type?: Prisma.EnumEventTypeFilter<"Event"> | $Enums.EventType type?: Prisma.EnumEventTypeFilter<"Event"> | $Enums.EventType
status?: Prisma.EnumEventStatusFilter<"Event"> | $Enums.EventStatus status?: Prisma.EnumEventStatusFilter<"Event"> | $Enums.EventStatus
room?: Prisma.StringNullableFilter<"Event"> | string | null
time?: Prisma.StringNullableFilter<"Event"> | string | null
maxPlaces?: Prisma.IntNullableFilter<"Event"> | number | null
createdAt?: Prisma.DateTimeFilter<"Event"> | Date | string createdAt?: Prisma.DateTimeFilter<"Event"> | Date | string
updatedAt?: Prisma.DateTimeFilter<"Event"> | Date | string updatedAt?: Prisma.DateTimeFilter<"Event"> | Date | string
registrations?: Prisma.EventRegistrationListRelationFilter registrations?: Prisma.EventRegistrationListRelationFilter
@@ -216,6 +274,9 @@ export type EventOrderByWithRelationInput = {
description?: Prisma.SortOrder description?: Prisma.SortOrder
type?: Prisma.SortOrder type?: Prisma.SortOrder
status?: Prisma.SortOrder status?: Prisma.SortOrder
room?: Prisma.SortOrderInput | Prisma.SortOrder
time?: Prisma.SortOrderInput | Prisma.SortOrder
maxPlaces?: Prisma.SortOrderInput | Prisma.SortOrder
createdAt?: Prisma.SortOrder createdAt?: Prisma.SortOrder
updatedAt?: Prisma.SortOrder updatedAt?: Prisma.SortOrder
registrations?: Prisma.EventRegistrationOrderByRelationAggregateInput registrations?: Prisma.EventRegistrationOrderByRelationAggregateInput
@@ -231,6 +292,9 @@ export type EventWhereUniqueInput = Prisma.AtLeast<{
description?: Prisma.StringFilter<"Event"> | string description?: Prisma.StringFilter<"Event"> | string
type?: Prisma.EnumEventTypeFilter<"Event"> | $Enums.EventType type?: Prisma.EnumEventTypeFilter<"Event"> | $Enums.EventType
status?: Prisma.EnumEventStatusFilter<"Event"> | $Enums.EventStatus status?: Prisma.EnumEventStatusFilter<"Event"> | $Enums.EventStatus
room?: Prisma.StringNullableFilter<"Event"> | string | null
time?: Prisma.StringNullableFilter<"Event"> | string | null
maxPlaces?: Prisma.IntNullableFilter<"Event"> | number | null
createdAt?: Prisma.DateTimeFilter<"Event"> | Date | string createdAt?: Prisma.DateTimeFilter<"Event"> | Date | string
updatedAt?: Prisma.DateTimeFilter<"Event"> | Date | string updatedAt?: Prisma.DateTimeFilter<"Event"> | Date | string
registrations?: Prisma.EventRegistrationListRelationFilter registrations?: Prisma.EventRegistrationListRelationFilter
@@ -243,11 +307,16 @@ export type EventOrderByWithAggregationInput = {
description?: Prisma.SortOrder description?: Prisma.SortOrder
type?: Prisma.SortOrder type?: Prisma.SortOrder
status?: Prisma.SortOrder status?: Prisma.SortOrder
room?: Prisma.SortOrderInput | Prisma.SortOrder
time?: Prisma.SortOrderInput | Prisma.SortOrder
maxPlaces?: Prisma.SortOrderInput | Prisma.SortOrder
createdAt?: Prisma.SortOrder createdAt?: Prisma.SortOrder
updatedAt?: Prisma.SortOrder updatedAt?: Prisma.SortOrder
_count?: Prisma.EventCountOrderByAggregateInput _count?: Prisma.EventCountOrderByAggregateInput
_avg?: Prisma.EventAvgOrderByAggregateInput
_max?: Prisma.EventMaxOrderByAggregateInput _max?: Prisma.EventMaxOrderByAggregateInput
_min?: Prisma.EventMinOrderByAggregateInput _min?: Prisma.EventMinOrderByAggregateInput
_sum?: Prisma.EventSumOrderByAggregateInput
} }
export type EventScalarWhereWithAggregatesInput = { export type EventScalarWhereWithAggregatesInput = {
@@ -260,6 +329,9 @@ export type EventScalarWhereWithAggregatesInput = {
description?: Prisma.StringWithAggregatesFilter<"Event"> | string description?: Prisma.StringWithAggregatesFilter<"Event"> | string
type?: Prisma.EnumEventTypeWithAggregatesFilter<"Event"> | $Enums.EventType type?: Prisma.EnumEventTypeWithAggregatesFilter<"Event"> | $Enums.EventType
status?: Prisma.EnumEventStatusWithAggregatesFilter<"Event"> | $Enums.EventStatus status?: Prisma.EnumEventStatusWithAggregatesFilter<"Event"> | $Enums.EventStatus
room?: Prisma.StringNullableWithAggregatesFilter<"Event"> | string | null
time?: Prisma.StringNullableWithAggregatesFilter<"Event"> | string | null
maxPlaces?: Prisma.IntNullableWithAggregatesFilter<"Event"> | number | null
createdAt?: Prisma.DateTimeWithAggregatesFilter<"Event"> | Date | string createdAt?: Prisma.DateTimeWithAggregatesFilter<"Event"> | Date | string
updatedAt?: Prisma.DateTimeWithAggregatesFilter<"Event"> | Date | string updatedAt?: Prisma.DateTimeWithAggregatesFilter<"Event"> | Date | string
} }
@@ -271,6 +343,9 @@ export type EventCreateInput = {
description: string description: string
type: $Enums.EventType type: $Enums.EventType
status: $Enums.EventStatus status: $Enums.EventStatus
room?: string | null
time?: string | null
maxPlaces?: number | null
createdAt?: Date | string createdAt?: Date | string
updatedAt?: Date | string updatedAt?: Date | string
registrations?: Prisma.EventRegistrationCreateNestedManyWithoutEventInput registrations?: Prisma.EventRegistrationCreateNestedManyWithoutEventInput
@@ -283,6 +358,9 @@ export type EventUncheckedCreateInput = {
description: string description: string
type: $Enums.EventType type: $Enums.EventType
status: $Enums.EventStatus status: $Enums.EventStatus
room?: string | null
time?: string | null
maxPlaces?: number | null
createdAt?: Date | string createdAt?: Date | string
updatedAt?: Date | string updatedAt?: Date | string
registrations?: Prisma.EventRegistrationUncheckedCreateNestedManyWithoutEventInput registrations?: Prisma.EventRegistrationUncheckedCreateNestedManyWithoutEventInput
@@ -295,6 +373,9 @@ export type EventUpdateInput = {
description?: Prisma.StringFieldUpdateOperationsInput | string description?: Prisma.StringFieldUpdateOperationsInput | string
type?: Prisma.EnumEventTypeFieldUpdateOperationsInput | $Enums.EventType type?: Prisma.EnumEventTypeFieldUpdateOperationsInput | $Enums.EventType
status?: Prisma.EnumEventStatusFieldUpdateOperationsInput | $Enums.EventStatus status?: Prisma.EnumEventStatusFieldUpdateOperationsInput | $Enums.EventStatus
room?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
time?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
maxPlaces?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
createdAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string createdAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
updatedAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string updatedAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
registrations?: Prisma.EventRegistrationUpdateManyWithoutEventNestedInput registrations?: Prisma.EventRegistrationUpdateManyWithoutEventNestedInput
@@ -307,6 +388,9 @@ export type EventUncheckedUpdateInput = {
description?: Prisma.StringFieldUpdateOperationsInput | string description?: Prisma.StringFieldUpdateOperationsInput | string
type?: Prisma.EnumEventTypeFieldUpdateOperationsInput | $Enums.EventType type?: Prisma.EnumEventTypeFieldUpdateOperationsInput | $Enums.EventType
status?: Prisma.EnumEventStatusFieldUpdateOperationsInput | $Enums.EventStatus status?: Prisma.EnumEventStatusFieldUpdateOperationsInput | $Enums.EventStatus
room?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
time?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
maxPlaces?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
createdAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string createdAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
updatedAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string updatedAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
registrations?: Prisma.EventRegistrationUncheckedUpdateManyWithoutEventNestedInput registrations?: Prisma.EventRegistrationUncheckedUpdateManyWithoutEventNestedInput
@@ -319,6 +403,9 @@ export type EventCreateManyInput = {
description: string description: string
type: $Enums.EventType type: $Enums.EventType
status: $Enums.EventStatus status: $Enums.EventStatus
room?: string | null
time?: string | null
maxPlaces?: number | null
createdAt?: Date | string createdAt?: Date | string
updatedAt?: Date | string updatedAt?: Date | string
} }
@@ -330,6 +417,9 @@ export type EventUpdateManyMutationInput = {
description?: Prisma.StringFieldUpdateOperationsInput | string description?: Prisma.StringFieldUpdateOperationsInput | string
type?: Prisma.EnumEventTypeFieldUpdateOperationsInput | $Enums.EventType type?: Prisma.EnumEventTypeFieldUpdateOperationsInput | $Enums.EventType
status?: Prisma.EnumEventStatusFieldUpdateOperationsInput | $Enums.EventStatus status?: Prisma.EnumEventStatusFieldUpdateOperationsInput | $Enums.EventStatus
room?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
time?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
maxPlaces?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
createdAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string createdAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
updatedAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string updatedAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
} }
@@ -341,6 +431,9 @@ export type EventUncheckedUpdateManyInput = {
description?: Prisma.StringFieldUpdateOperationsInput | string description?: Prisma.StringFieldUpdateOperationsInput | string
type?: Prisma.EnumEventTypeFieldUpdateOperationsInput | $Enums.EventType type?: Prisma.EnumEventTypeFieldUpdateOperationsInput | $Enums.EventType
status?: Prisma.EnumEventStatusFieldUpdateOperationsInput | $Enums.EventStatus status?: Prisma.EnumEventStatusFieldUpdateOperationsInput | $Enums.EventStatus
room?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
time?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
maxPlaces?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
createdAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string createdAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
updatedAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string updatedAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
} }
@@ -352,10 +445,17 @@ export type EventCountOrderByAggregateInput = {
description?: Prisma.SortOrder description?: Prisma.SortOrder
type?: Prisma.SortOrder type?: Prisma.SortOrder
status?: Prisma.SortOrder status?: Prisma.SortOrder
room?: Prisma.SortOrder
time?: Prisma.SortOrder
maxPlaces?: Prisma.SortOrder
createdAt?: Prisma.SortOrder createdAt?: Prisma.SortOrder
updatedAt?: Prisma.SortOrder updatedAt?: Prisma.SortOrder
} }
export type EventAvgOrderByAggregateInput = {
maxPlaces?: Prisma.SortOrder
}
export type EventMaxOrderByAggregateInput = { export type EventMaxOrderByAggregateInput = {
id?: Prisma.SortOrder id?: Prisma.SortOrder
date?: Prisma.SortOrder date?: Prisma.SortOrder
@@ -363,6 +463,9 @@ export type EventMaxOrderByAggregateInput = {
description?: Prisma.SortOrder description?: Prisma.SortOrder
type?: Prisma.SortOrder type?: Prisma.SortOrder
status?: Prisma.SortOrder status?: Prisma.SortOrder
room?: Prisma.SortOrder
time?: Prisma.SortOrder
maxPlaces?: Prisma.SortOrder
createdAt?: Prisma.SortOrder createdAt?: Prisma.SortOrder
updatedAt?: Prisma.SortOrder updatedAt?: Prisma.SortOrder
} }
@@ -374,10 +477,17 @@ export type EventMinOrderByAggregateInput = {
description?: Prisma.SortOrder description?: Prisma.SortOrder
type?: Prisma.SortOrder type?: Prisma.SortOrder
status?: Prisma.SortOrder status?: Prisma.SortOrder
room?: Prisma.SortOrder
time?: Prisma.SortOrder
maxPlaces?: Prisma.SortOrder
createdAt?: Prisma.SortOrder createdAt?: Prisma.SortOrder
updatedAt?: Prisma.SortOrder updatedAt?: Prisma.SortOrder
} }
export type EventSumOrderByAggregateInput = {
maxPlaces?: Prisma.SortOrder
}
export type EventScalarRelationFilter = { export type EventScalarRelationFilter = {
is?: Prisma.EventWhereInput is?: Prisma.EventWhereInput
isNot?: Prisma.EventWhereInput isNot?: Prisma.EventWhereInput
@@ -391,6 +501,14 @@ export type EnumEventStatusFieldUpdateOperationsInput = {
set?: $Enums.EventStatus set?: $Enums.EventStatus
} }
export type NullableIntFieldUpdateOperationsInput = {
set?: number | null
increment?: number
decrement?: number
multiply?: number
divide?: number
}
export type EventCreateNestedOneWithoutRegistrationsInput = { export type EventCreateNestedOneWithoutRegistrationsInput = {
create?: Prisma.XOR<Prisma.EventCreateWithoutRegistrationsInput, Prisma.EventUncheckedCreateWithoutRegistrationsInput> create?: Prisma.XOR<Prisma.EventCreateWithoutRegistrationsInput, Prisma.EventUncheckedCreateWithoutRegistrationsInput>
connectOrCreate?: Prisma.EventCreateOrConnectWithoutRegistrationsInput connectOrCreate?: Prisma.EventCreateOrConnectWithoutRegistrationsInput
@@ -412,6 +530,9 @@ export type EventCreateWithoutRegistrationsInput = {
description: string description: string
type: $Enums.EventType type: $Enums.EventType
status: $Enums.EventStatus status: $Enums.EventStatus
room?: string | null
time?: string | null
maxPlaces?: number | null
createdAt?: Date | string createdAt?: Date | string
updatedAt?: Date | string updatedAt?: Date | string
} }
@@ -423,6 +544,9 @@ export type EventUncheckedCreateWithoutRegistrationsInput = {
description: string description: string
type: $Enums.EventType type: $Enums.EventType
status: $Enums.EventStatus status: $Enums.EventStatus
room?: string | null
time?: string | null
maxPlaces?: number | null
createdAt?: Date | string createdAt?: Date | string
updatedAt?: Date | string updatedAt?: Date | string
} }
@@ -450,6 +574,9 @@ export type EventUpdateWithoutRegistrationsInput = {
description?: Prisma.StringFieldUpdateOperationsInput | string description?: Prisma.StringFieldUpdateOperationsInput | string
type?: Prisma.EnumEventTypeFieldUpdateOperationsInput | $Enums.EventType type?: Prisma.EnumEventTypeFieldUpdateOperationsInput | $Enums.EventType
status?: Prisma.EnumEventStatusFieldUpdateOperationsInput | $Enums.EventStatus status?: Prisma.EnumEventStatusFieldUpdateOperationsInput | $Enums.EventStatus
room?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
time?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
maxPlaces?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
createdAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string createdAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
updatedAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string updatedAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
} }
@@ -461,6 +588,9 @@ export type EventUncheckedUpdateWithoutRegistrationsInput = {
description?: Prisma.StringFieldUpdateOperationsInput | string description?: Prisma.StringFieldUpdateOperationsInput | string
type?: Prisma.EnumEventTypeFieldUpdateOperationsInput | $Enums.EventType type?: Prisma.EnumEventTypeFieldUpdateOperationsInput | $Enums.EventType
status?: Prisma.EnumEventStatusFieldUpdateOperationsInput | $Enums.EventStatus status?: Prisma.EnumEventStatusFieldUpdateOperationsInput | $Enums.EventStatus
room?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
time?: Prisma.NullableStringFieldUpdateOperationsInput | string | null
maxPlaces?: Prisma.NullableIntFieldUpdateOperationsInput | number | null
createdAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string createdAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
updatedAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string updatedAt?: Prisma.DateTimeFieldUpdateOperationsInput | Date | string
} }
@@ -503,6 +633,9 @@ export type EventSelect<ExtArgs extends runtime.Types.Extensions.InternalArgs =
description?: boolean description?: boolean
type?: boolean type?: boolean
status?: boolean status?: boolean
room?: boolean
time?: boolean
maxPlaces?: boolean
createdAt?: boolean createdAt?: boolean
updatedAt?: boolean updatedAt?: boolean
registrations?: boolean | Prisma.Event$registrationsArgs<ExtArgs> registrations?: boolean | Prisma.Event$registrationsArgs<ExtArgs>
@@ -516,6 +649,9 @@ export type EventSelectCreateManyAndReturn<ExtArgs extends runtime.Types.Extensi
description?: boolean description?: boolean
type?: boolean type?: boolean
status?: boolean status?: boolean
room?: boolean
time?: boolean
maxPlaces?: boolean
createdAt?: boolean createdAt?: boolean
updatedAt?: boolean updatedAt?: boolean
}, ExtArgs["result"]["event"]> }, ExtArgs["result"]["event"]>
@@ -527,6 +663,9 @@ export type EventSelectUpdateManyAndReturn<ExtArgs extends runtime.Types.Extensi
description?: boolean description?: boolean
type?: boolean type?: boolean
status?: boolean status?: boolean
room?: boolean
time?: boolean
maxPlaces?: boolean
createdAt?: boolean createdAt?: boolean
updatedAt?: boolean updatedAt?: boolean
}, ExtArgs["result"]["event"]> }, ExtArgs["result"]["event"]>
@@ -538,11 +677,14 @@ export type EventSelectScalar = {
description?: boolean description?: boolean
type?: boolean type?: boolean
status?: boolean status?: boolean
room?: boolean
time?: boolean
maxPlaces?: boolean
createdAt?: boolean createdAt?: boolean
updatedAt?: boolean updatedAt?: boolean
} }
export type EventOmit<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = runtime.Types.Extensions.GetOmit<"id" | "date" | "name" | "description" | "type" | "status" | "createdAt" | "updatedAt", ExtArgs["result"]["event"]> export type EventOmit<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = runtime.Types.Extensions.GetOmit<"id" | "date" | "name" | "description" | "type" | "status" | "room" | "time" | "maxPlaces" | "createdAt" | "updatedAt", ExtArgs["result"]["event"]>
export type EventInclude<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = { export type EventInclude<ExtArgs extends runtime.Types.Extensions.InternalArgs = runtime.Types.Extensions.DefaultArgs> = {
registrations?: boolean | Prisma.Event$registrationsArgs<ExtArgs> registrations?: boolean | Prisma.Event$registrationsArgs<ExtArgs>
_count?: boolean | Prisma.EventCountOutputTypeDefaultArgs<ExtArgs> _count?: boolean | Prisma.EventCountOutputTypeDefaultArgs<ExtArgs>
@@ -562,6 +704,9 @@ export type $EventPayload<ExtArgs extends runtime.Types.Extensions.InternalArgs
description: string description: string
type: $Enums.EventType type: $Enums.EventType
status: $Enums.EventStatus status: $Enums.EventStatus
room: string | null
time: string | null
maxPlaces: number | null
createdAt: Date createdAt: Date
updatedAt: Date updatedAt: Date
}, ExtArgs["result"]["event"]> }, ExtArgs["result"]["event"]>
@@ -994,6 +1139,9 @@ export interface EventFieldRefs {
readonly description: Prisma.FieldRef<"Event", 'String'> readonly description: Prisma.FieldRef<"Event", 'String'>
readonly type: Prisma.FieldRef<"Event", 'EventType'> readonly type: Prisma.FieldRef<"Event", 'EventType'>
readonly status: Prisma.FieldRef<"Event", 'EventStatus'> readonly status: Prisma.FieldRef<"Event", 'EventStatus'>
readonly room: Prisma.FieldRef<"Event", 'String'>
readonly time: Prisma.FieldRef<"Event", 'String'>
readonly maxPlaces: Prisma.FieldRef<"Event", 'Int'>
readonly createdAt: Prisma.FieldRef<"Event", 'DateTime'> readonly createdAt: Prisma.FieldRef<"Event", 'DateTime'>
readonly updatedAt: Prisma.FieldRef<"Event", 'DateTime'> readonly updatedAt: Prisma.FieldRef<"Event", 'DateTime'>
} }

View File

@@ -0,0 +1,4 @@
-- AlterTable
ALTER TABLE "Event" ADD COLUMN "maxPlaces" INTEGER;
ALTER TABLE "Event" ADD COLUMN "room" TEXT;
ALTER TABLE "Event" ADD COLUMN "time" TEXT;

View File

@@ -20,6 +20,7 @@ enum EventType {
LAUNCH LAUNCH
FESTIVAL FESTIVAL
COMPETITION COMPETITION
CODE_KATA
} }
enum EventStatus { enum EventStatus {
@@ -89,6 +90,9 @@ model Event {
description String description String
type EventType type EventType
status EventStatus status EventStatus
room String?
time String?
maxPlaces Int?
createdAt DateTime @default(now()) createdAt DateTime @default(now())
updatedAt DateTime @updatedAt updatedAt DateTime @updatedAt
registrations EventRegistration[] registrations EventRegistration[]

View File

@@ -148,7 +148,7 @@ async function main() {
// Créer des événements (vérifier s'ils existent déjà) // Créer des événements (vérifier s'ils existent déjà)
const eventData = [ const eventData = [
{ {
date: "18 NOVEMBRE 2023", date: "2023-11-18",
name: "Sommet de l'Innovation Tech", name: "Sommet de l'Innovation Tech",
description: description:
"Rejoignez les leaders de l'industrie et les innovateurs pour une journée de discussions sur les technologies de pointe, les percées de l'IA et des opportunités de networking.", "Rejoignez les leaders de l'industrie et les innovateurs pour une journée de discussions sur les technologies de pointe, les percées de l'IA et des opportunités de networking.",
@@ -156,7 +156,7 @@ async function main() {
status: EventStatus.PAST, status: EventStatus.PAST,
}, },
{ {
date: "3 DÉCEMBRE 2023", date: "2023-12-03",
name: "Lancement de la Révolution IA", name: "Lancement de la Révolution IA",
description: description:
"Assistez au lancement de systèmes d'IA révolutionnaires qui vont remodeler le paysage du gaming. Aperçus exclusifs et opportunités d'accès anticipé.", "Assistez au lancement de systèmes d'IA révolutionnaires qui vont remodeler le paysage du gaming. Aperçus exclusifs et opportunités d'accès anticipé.",
@@ -164,7 +164,7 @@ async function main() {
status: EventStatus.PAST, status: EventStatus.PAST,
}, },
{ {
date: "22 DÉCEMBRE 2023", date: "2023-12-22",
name: "Festival du Code d'Hiver", name: "Festival du Code d'Hiver",
description: description:
"Une célébration de l'excellence en programmation avec des hackathons, des défis de codage et des prix. Montrez vos compétences et rivalisez avec les meilleurs développeurs.", "Une célébration de l'excellence en programmation avec des hackathons, des défis de codage et des prix. Montrez vos compétences et rivalisez avec les meilleurs développeurs.",
@@ -172,7 +172,7 @@ async function main() {
status: EventStatus.PAST, status: EventStatus.PAST,
}, },
{ {
date: "15 JANVIER 2024", date: "2024-01-15",
name: "Expo Informatique Quantique", name: "Expo Informatique Quantique",
description: description:
"Explorez l'avenir de l'informatique quantique dans le gaming. Démonstrations interactives, conférences d'experts et ateliers pratiques pour tous les niveaux.", "Explorez l'avenir de l'informatique quantique dans le gaming. Démonstrations interactives, conférences d'experts et ateliers pratiques pour tous les niveaux.",
@@ -180,7 +180,7 @@ async function main() {
status: EventStatus.UPCOMING, status: EventStatus.UPCOMING,
}, },
{ {
date: "8 FÉVRIER 2024", date: "2024-02-08",
name: "Championnat Cyber Arena", name: "Championnat Cyber Arena",
description: description:
"L'événement de gaming compétitif ultime. Compétissez pour la gloire, des récompenses exclusives et le titre de Champion Cyber Arena. Inscriptions ouvertes.", "L'événement de gaming compétitif ultime. Compétissez pour la gloire, des récompenses exclusives et le titre de Champion Cyber Arena. Inscriptions ouvertes.",
@@ -188,13 +188,24 @@ async function main() {
status: EventStatus.UPCOMING, status: EventStatus.UPCOMING,
}, },
{ {
date: "12 MARS 2024", date: "2024-03-12",
name: "Gala Tech du Printemps", name: "Gala Tech du Printemps",
description: description:
"Une soirée élégante célébrant les réalisations technologiques. Cérémonie de remise de prix, networking et annonces exclusives des plus grandes entreprises tech.", "Une soirée élégante célébrant les réalisations technologiques. Cérémonie de remise de prix, networking et annonces exclusives des plus grandes entreprises tech.",
type: EventType.FESTIVAL, type: EventType.FESTIVAL,
status: EventStatus.UPCOMING, status: EventStatus.UPCOMING,
}, },
{
date: "2024-12-15",
name: "Builder pattern : construction et refactoring",
description:
"Lors de cet atelier, nous utiliserons le design pattern Builder pour structurer pas à pas la création d'objets complexes… sans transformer notre code en film digne de Red Is Dead.\n\nVous découvrirez comment ce pattern permet de découpler proprement la logique de construction, d'améliorer la lisibilité et de faciliter l'évolution du code — notamment lors de phases de refactoring où les responsabilités se mélangent plus vite que la foule au Palais des Festivals.\n\nL'objectif : poser les fondations pour introduire un vrai modèle, sans rien casser du comportement existant.\n\nQue vous souhaitiez renforcer vos compétences en conception, préparer votre prochain refactoring, ou simplement coder avec plus de style que Serge Karamazov dansant la carioca, venez construire avec nous.",
type: EventType.CODE_KATA,
status: EventStatus.UPCOMING,
room: "Nautilus",
time: "11h-12h",
maxPlaces: 25,
},
]; ];
const events = await Promise.all( const events = await Promise.all(
@@ -202,7 +213,12 @@ async function main() {
const existing = await prisma.event.findFirst({ const existing = await prisma.event.findFirst({
where: { name: data.name }, where: { name: data.name },
}); });
if (existing) return existing; if (existing) {
return prisma.event.update({
where: { id: existing.id },
data,
});
}
return prisma.event.create({ data }); return prisma.event.create({ data });
}) })
); );