-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathpartner.ts
More file actions
78 lines (68 loc) · 2.18 KB
/
partner.ts
File metadata and controls
78 lines (68 loc) · 2.18 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
import type { PartnerAgreementDraft, PartnerDraft, PartnerLegalEntityDraft } from '../types'
import { eq } from 'drizzle-orm'
import { useDatabase } from '../database'
import { partnerAgreements, partnerLegalEntities, partners } from '../tables'
export class Partner {
static async find(id: string) {
return useDatabase().query.partners.findFirst({
where: (partners, { eq }) => eq(partners.id, id),
with: {
kitchens: true,
},
})
}
static async findAgreement(id: string) {
return useDatabase().query.partnerAgreements.findFirst({
where: (agreements, { eq }) => eq(agreements.id, id),
})
}
static async list() {
return useDatabase().query.partners.findMany({
where: (partners, { eq }) => eq(partners.isActive, true),
})
}
static async listWithData() {
return useDatabase().query.partners.findMany({
where: (partners, { eq }) => eq(partners.isActive, true),
with: {
kitchens: true,
legalEntity: {
with: {
agreements: true,
},
},
},
})
}
static async create(data: PartnerDraft) {
const [partner] = await useDatabase().insert(partners).values(data).returning()
return partner
}
static async createLegalEntity(data: PartnerLegalEntityDraft) {
const [legalEntity] = await useDatabase().insert(partnerLegalEntities).values(data).returning()
return legalEntity
}
static async createAgreement(data: PartnerAgreementDraft) {
const [agreement] = await useDatabase().insert(partnerAgreements).values(data).returning()
return agreement
}
static async update(id: string, data: Partial<PartnerDraft>) {
const [partner] = await useDatabase()
.update(partners)
.set(data)
.where(eq(partners.id, id))
.returning()
return partner
}
static async updateAgreement(id: string, data: Partial<PartnerAgreementDraft>) {
const [agreement] = await useDatabase()
.update(partnerAgreements)
.set(data)
.where(eq(partnerAgreements.id, id))
.returning()
return agreement
}
static async delete(id: string) {
return useDatabase().delete(partners).where(eq(partners.id, id))
}
}