-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathkitchen.ts
More file actions
94 lines (83 loc) · 2.73 KB
/
kitchen.ts
File metadata and controls
94 lines (83 loc) · 2.73 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
import type { KitchenDraft, KitchenRevenueDraft } from '../types'
import { eq, sql } from 'drizzle-orm'
import { useDatabase } from '../database'
import { kitchenRevenues, kitchens } from '../tables'
export class Kitchen {
static async find(id: string) {
return useDatabase().query.kitchens.findFirst({
where: (kitchens, { eq }) => eq(kitchens.id, id),
})
}
static async findRevenue(id: string) {
return useDatabase().query.kitchenRevenues.findFirst({
where: (revenues, { eq }) => eq(revenues.id, id),
})
}
static async findRevenueByKitchenAndDate(kitchenId: string, date: Date) {
return useDatabase().query.kitchenRevenues.findFirst({
where: (revenues, { eq, and }) => and(
eq(revenues.kitchenId, kitchenId),
sql`date(${revenues.date}) = date(${date})`, // Same date
),
})
}
static async list() {
return useDatabase().query.kitchens.findMany({
orderBy: (kitchens, { asc }) => asc(kitchens.name),
with: {
feedbackPoints: true,
},
})
}
static async listRevenuesByKitchen(kitchenId: string) {
return useDatabase().query.kitchenRevenues.findMany({
where: (revenues, { eq }) => eq(revenues.kitchenId, kitchenId),
orderBy: (revenues, { desc }) => desc(revenues.date),
limit: 1000,
})
}
static async listRevenuesByKitchenForPeriod(kitchenId: string, start: Date, end: Date) {
return useDatabase().query.kitchenRevenues.findMany({
where: (revenues, { eq, and }) => and(
eq(revenues.kitchenId, kitchenId),
sql`date(${revenues.date}) >= date(${start})`,
sql`date(${revenues.date}) <= date(${end})`,
),
orderBy: (revenues, { desc }) => desc(revenues.date),
limit: 1000,
})
}
static async create(data: KitchenDraft) {
const [kitchen] = await useDatabase().insert(kitchens).values(data).returning()
return kitchen
}
static async createRevenue(data: KitchenRevenueDraft) {
const [revenue] = await useDatabase().insert(kitchenRevenues).values(data).returning()
return revenue
}
static async update(id: string, data: Partial<KitchenDraft>) {
const [kitchen] = await useDatabase()
.update(kitchens)
.set({
...data,
updatedAt: sql`now()`,
})
.where(eq(kitchens.id, id))
.returning()
return kitchen
}
static async updateRevenue(id: string, data: Partial<KitchenRevenueDraft>) {
const [revenue] = await useDatabase()
.update(kitchenRevenues)
.set({
...data,
updatedAt: sql`now()`,
})
.where(eq(kitchenRevenues.id, id))
.returning()
return revenue
}
static async delete(id: string) {
return useDatabase().delete(kitchens).where(eq(kitchens.id, id))
}
}