[5d6f37a] | 1 | generator client {
|
---|
| 2 | provider = "prisma-client-js"
|
---|
| 3 | }
|
---|
| 4 |
|
---|
| 5 | datasource db {
|
---|
| 6 | provider = "postgresql"
|
---|
| 7 | url = env("DATABASE_URL")
|
---|
| 8 | }
|
---|
| 9 |
|
---|
[057453c] | 10 | model Client {
|
---|
[5d6f37a] | 11 | id String @id @default(uuid())
|
---|
| 12 | companyId String? // Optional company identifier
|
---|
| 13 | name String
|
---|
| 14 | email String @unique
|
---|
| 15 | address Json
|
---|
| 16 | logoUrl String?
|
---|
| 17 | phoneNumber String?
|
---|
| 18 | vatNumber String?
|
---|
| 19 | companyNumber String?
|
---|
| 20 | representative String
|
---|
| 21 | status CustomerStatus @default(active)
|
---|
| 22 |
|
---|
| 23 | invoicesReceived Invoice[] @relation("InvoiceTo")
|
---|
| 24 | }
|
---|
| 25 |
|
---|
| 26 | model Service {
|
---|
| 27 | id String @id @default(uuid())
|
---|
| 28 | name String
|
---|
[057453c] | 29 | sprint Float
|
---|
| 30 | hour Float
|
---|
| 31 | month Float
|
---|
| 32 | tenantId String
|
---|
| 33 | tenant Tenant @relation(fields: [tenantId], references: [id], onDelete: Cascade)
|
---|
[5d6f37a] | 34 |
|
---|
[057453c] | 35 | lineItems LineItem[]
|
---|
[5d6f37a] | 36 | }
|
---|
| 37 |
|
---|
| 38 | model Invoice {
|
---|
| 39 | id String @id @default(uuid())
|
---|
| 40 | sent Int? // Number of times sent
|
---|
| 41 | dueDate DateTime
|
---|
| 42 | status InvoiceStatus
|
---|
| 43 | currency Currency
|
---|
| 44 | quantityType QuantityType
|
---|
| 45 | subTotal Float
|
---|
| 46 | createDate DateTime
|
---|
| 47 | month Month
|
---|
| 48 | discount Float?
|
---|
| 49 | taxes Float?
|
---|
| 50 | totalAmount Float
|
---|
| 51 | invoiceNumber String @unique
|
---|
| 52 | pdfRef String?
|
---|
| 53 |
|
---|
| 54 | invoiceFromId String
|
---|
[057453c] | 55 | invoiceFrom Tenant @relation(fields: [invoiceFromId], references: [id], onDelete: Cascade)
|
---|
[5d6f37a] | 56 |
|
---|
| 57 | invoiceToId String
|
---|
[057453c] | 58 | invoiceTo Client @relation("InvoiceTo", fields: [invoiceToId], references: [id], onDelete: Cascade)
|
---|
[5d6f37a] | 59 |
|
---|
[057453c] | 60 | items LineItem[]
|
---|
[5d6f37a] | 61 | }
|
---|
| 62 |
|
---|
[057453c] | 63 | model LineItem {
|
---|
[5d6f37a] | 64 | id String @id @default(uuid())
|
---|
| 65 | title String
|
---|
| 66 | price Float
|
---|
| 67 | total Float
|
---|
| 68 | quantity Int
|
---|
| 69 | description String?
|
---|
| 70 | serviceId String
|
---|
| 71 | service Service @relation(fields: [serviceId], references: [id], onDelete: Cascade)
|
---|
| 72 | invoiceId String
|
---|
| 73 | invoice Invoice @relation(fields: [invoiceId], references: [id], onDelete: Cascade)
|
---|
| 74 | }
|
---|
| 75 |
|
---|
[057453c] | 76 | model Tenant {
|
---|
| 77 | id String @id @default(cuid())
|
---|
| 78 | name String
|
---|
| 79 | email String @unique
|
---|
| 80 | address Json // Holds {street: string, city?: string, country: string, state?: string, zip: string}
|
---|
| 81 | bankAccounts Json? // Holds {eur?: {accountNumber?, bicSwift?, iban?, routingNumber?}, usd?: {...}}
|
---|
| 82 | logoUrl String?
|
---|
| 83 | phoneNumber String?
|
---|
| 84 | vatNumber String?
|
---|
| 85 | companyNumber String?
|
---|
| 86 | representative String
|
---|
| 87 | lastInvoiceNumber String @default("0")
|
---|
| 88 | createdAt DateTime @default(now())
|
---|
| 89 | updatedAt DateTime @updatedAt
|
---|
| 90 | invoicesSent Invoice[]
|
---|
| 91 | services Service[]
|
---|
| 92 | employees Employee[]
|
---|
| 93 | }
|
---|
| 94 |
|
---|
| 95 | model Employee {
|
---|
| 96 | id String @id @default(uuid())
|
---|
| 97 | name String
|
---|
| 98 | email String @unique
|
---|
| 99 | status EmployeeStatus @default(active)
|
---|
| 100 | iban String?
|
---|
| 101 | cv String?
|
---|
| 102 | photo String?
|
---|
| 103 | project String?
|
---|
| 104 | tenantId String
|
---|
| 105 | tenant Tenant @relation(fields: [tenantId], references: [id], onDelete: Cascade)
|
---|
| 106 | }
|
---|
| 107 |
|
---|
[5d6f37a] | 108 | // Enums
|
---|
| 109 | enum CustomerStatus {
|
---|
| 110 | active
|
---|
| 111 | banned
|
---|
| 112 | inactive
|
---|
| 113 | }
|
---|
| 114 |
|
---|
| 115 | enum InvoiceStatus {
|
---|
[057453c] | 116 | draft
|
---|
| 117 | processing
|
---|
| 118 | pending
|
---|
| 119 | overdue
|
---|
| 120 | paid
|
---|
[5d6f37a] | 121 | }
|
---|
| 122 |
|
---|
| 123 | enum Currency {
|
---|
| 124 | EUR
|
---|
| 125 | USD
|
---|
| 126 | }
|
---|
| 127 |
|
---|
| 128 | enum QuantityType {
|
---|
[057453c] | 129 | Unit
|
---|
| 130 | Hour
|
---|
| 131 | Sprint
|
---|
| 132 | Month
|
---|
[5d6f37a] | 133 | }
|
---|
| 134 |
|
---|
| 135 | enum Month {
|
---|
[057453c] | 136 | January
|
---|
| 137 | February
|
---|
| 138 | March
|
---|
| 139 | April
|
---|
| 140 | May
|
---|
| 141 | June
|
---|
| 142 | July
|
---|
| 143 | August
|
---|
| 144 | September
|
---|
| 145 | October
|
---|
| 146 | November
|
---|
| 147 | December
|
---|
| 148 | }
|
---|
| 149 |
|
---|
| 150 | enum EmployeeStatus {
|
---|
| 151 | active
|
---|
| 152 | inactive
|
---|
[5d6f37a] | 153 | }
|
---|