import moment from "https://esm.sh/moment";
import { createClient } from "npm:@supabase/supabase-js";
class ForbetEventService {
_supabase;
constructor() {
this._supabase = createClient(
Deno.env.get("SUPABASE_URL"),
Deno.env.get("SUPABASE_ANON_KEY"),
);
}
async getEvents() {
const { data, error } = await this._supabase
.from("forbetEvents")
.select("*")
.order("eventId", { ascending: false });
return data;
}
async getEventById(id) {
const { data, error } = await this._supabase
.from("forbetEvents")
.select("*")
.eq("eventId", id);
if (!data) return;
const [entry] = data;
return entry;
}
async createEvent(event) {
const { data, error } = await this._supabase.from("forbetEvents").insert([
{
eventId: event.id,
date: moment(event.date, "DD/MM/YYYY HH:mm"),
data: event,
status: event.status,
result: event.result,
},
]);
console.log({ error });
if (!data) return;
const [entry] = data;
return entry;
}
async updateEvent(event) {
const { data, error } = await this._supabase
.from("forbetEvents")
.update({
eventId: event.id,
data: event,
...(event.date ? { date: moment(event.date, "DD/MM/YYYY HH:mm") } : {}),
...(event.status ? { status: event.status } : {}),
...(event.result ? { result: event.result } : {}),
})
.eq("eventId", event.id);
console.log({ error });
if (!data) return;
const [entry] = data;
return entry;
}
async deleteEvent(id) {
const { data, error } = await this._supabase
.from("forbetEvents")
.delete()
.eq("eventId", id);
return data;
}
async getEventsByDate(fromDate, toDate) {
const { data, error } = await this._supabase
.from("forbetEvents")
.select("*")
.gte("date", fromDate)
.lte("date", toDate)
.range(0, 1000);
if (!data) return [];
return data;
}
async getAllCompletedEvents() {
const from = 0;
const to = 1000;