diff options
Diffstat (limited to 'src/lib/Database/Supabase/events.ts')
| -rw-r--r-- | src/lib/Database/Supabase/events.ts | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/src/lib/Database/Supabase/events.ts b/src/lib/Database/Supabase/events.ts new file mode 100644 index 00000000..e87fe011 --- /dev/null +++ b/src/lib/Database/Supabase/events.ts @@ -0,0 +1,46 @@ +import type Group from '$lib/Events/Group.svelte'; +import supabase from '../supabase'; + +export interface Event { + id: number; + created_at: string; + updated_at: string; + title: string; + description: string; + group: Group; + banner: string; + anilist_url: string; +} + +interface NewEvent { + updated_at?: string; + title: string; + description: string; +} + +export const getEvents = async () => { + const { data, error } = await supabase.from('events').select('*, group:groups(*)'); + + if (error) return []; + + return data as Event[]; +}; + +export const getGroupEvents = async (group: string) => { + const { data, error } = await supabase.from('events').select('*').eq('group', group); + + if (error) return []; + + return data as Event[]; +}; + +export const createEvent = async (event: NewEvent) => await supabase.from('events').insert(event); + +export const deleteEvent = async (id: number) => + await supabase.from('events').delete().eq('id', id); + +export const updateEvent = async (id: number, event: NewEvent) => { + if (!event.updated_at) event.updated_at = new Date().toISOString(); + + return await supabase.from('events').update(event).eq('id', id); +}; |