Files
WearPartTracker/prisma/schema.prisma
Denis Urs Rudolph d37676f3c0 Feature: Kilometerstand-Feld für Fahrräder und verbesserte Warnungen
- currentMileage Feld zu Bike-Modell hinzugefügt
- calculateServiceStatus verwendet jetzt aktuellen Kilometerstand des Fahrrads
- Warnungen für überfällige Wartungen (OVERDUE Status)
- Rote Warnung bei überfälligen Teilen
- Kilometerstand wird in BikeDetail und BikeCard angezeigt
- AlertBadge unterstützt jetzt critical Variante
- Verbesserte Statusanzeige mit Überfällig-Hinweis
2025-12-05 22:37:10 +01:00

57 lines
1.8 KiB
Plaintext

// This is your Prisma schema file,
// learn more about it in the docs: https://pris.ly/d/prisma-schema
generator client {
provider = "prisma-client-js"
}
datasource db {
provider = "sqlite"
url = "file:./dev.db"
}
model Bike {
id String @id @default(cuid())
name String
brand String?
model String?
purchaseDate DateTime?
currentMileage Int @default(0)
notes String?
wearParts WearPart[]
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
}
model WearPart {
id String @id @default(cuid())
bikeId String
bike Bike @relation(fields: [bikeId], references: [id], onDelete: Cascade)
type String // CHAIN, BRAKE_PADS, TIRE, CASSETTE, CHAINRING, DERAILLEUR, etc.
brand String?
model String?
installDate DateTime
installMileage Int @default(0)
serviceInterval Int // in km
status String @default("ACTIVE") // ACTIVE, NEEDS_SERVICE, REPLACED, INACTIVE
cost Float?
notes String?
maintenanceHistory MaintenanceHistory[]
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
}
model MaintenanceHistory {
id String @id @default(cuid())
wearPartId String
wearPart WearPart @relation(fields: [wearPartId], references: [id], onDelete: Cascade)
date DateTime
mileage Int
action String // INSTALL, REPLACE, SERVICE, CHECK, ADJUST
notes String?
cost Float?
createdAt DateTime @default(now())
updatedAt DateTime @updatedAt
}