feat: Add Model gestion for piece and component
This commit is contained in:
@@ -51,38 +51,6 @@ model TypeMachine {
|
||||
@@map("type_machines")
|
||||
}
|
||||
|
||||
model TypeComposant {
|
||||
id String @id @default(cuid())
|
||||
name String @unique
|
||||
description String?
|
||||
createdAt DateTime @default(now())
|
||||
updatedAt DateTime @updatedAt
|
||||
|
||||
// Relations
|
||||
composants Composant[]
|
||||
customFields CustomField[] @relation("TypeComposantCustomFields")
|
||||
models ComposantModel[]
|
||||
componentRequirements TypeMachineComponentRequirement[]
|
||||
|
||||
@@map("type_composants")
|
||||
}
|
||||
|
||||
model TypePiece {
|
||||
id String @id @default(cuid())
|
||||
name String @unique
|
||||
description String?
|
||||
createdAt DateTime @default(now())
|
||||
updatedAt DateTime @updatedAt
|
||||
|
||||
// Relations
|
||||
pieces Piece[]
|
||||
customFields CustomField[] @relation("TypePieceCustomFields")
|
||||
models PieceModel[]
|
||||
pieceRequirements TypeMachinePieceRequirement[]
|
||||
|
||||
@@map("type_pieces")
|
||||
}
|
||||
|
||||
model Machine {
|
||||
id String @id @default(cuid())
|
||||
name String
|
||||
@@ -128,7 +96,7 @@ model Composant {
|
||||
sousComposants Composant[] @relation("ComposantHierarchy")
|
||||
|
||||
typeComposantId String?
|
||||
typeComposant TypeComposant? @relation(fields: [typeComposantId], references: [id])
|
||||
typeComposant ModelType? @relation("ModelTypeComponentAssignments", fields: [typeComposantId], references: [id])
|
||||
|
||||
composantModelId String?
|
||||
composantModel ComposantModel? @relation(fields: [composantModelId], references: [id], onDelete: SetNull)
|
||||
@@ -163,7 +131,7 @@ model Piece {
|
||||
composant Composant? @relation(fields: [composantId], references: [id], onDelete: Cascade)
|
||||
|
||||
typePieceId String?
|
||||
typePiece TypePiece? @relation(fields: [typePieceId], references: [id])
|
||||
typePiece ModelType? @relation("ModelTypePieceAssignments", fields: [typePieceId], references: [id])
|
||||
|
||||
pieceModelId String?
|
||||
pieceModel PieceModel? @relation(fields: [pieceModelId], references: [id], onDelete: SetNull)
|
||||
@@ -180,6 +148,33 @@ model Piece {
|
||||
@@map("pieces")
|
||||
}
|
||||
|
||||
enum ModelCategory {
|
||||
COMPONENT
|
||||
PIECE
|
||||
}
|
||||
|
||||
model ModelType {
|
||||
id String @id @default(cuid())
|
||||
name String @db.VarChar(120)
|
||||
code String @unique @db.VarChar(60)
|
||||
category ModelCategory
|
||||
notes String? @db.Text
|
||||
description String? @db.Text
|
||||
createdAt DateTime @default(now())
|
||||
updatedAt DateTime @updatedAt
|
||||
|
||||
@@index([category, name])
|
||||
|
||||
composants Composant[] @relation("ModelTypeComponentAssignments")
|
||||
models ComposantModel[] @relation("ModelTypeComponentModels")
|
||||
componentRequirements TypeMachineComponentRequirement[] @relation("ModelTypeComponentRequirements")
|
||||
customFields CustomField[] @relation("ModelTypeCustomFields")
|
||||
pieceModels PieceModel[] @relation("ModelTypePieceModels")
|
||||
pieceRequirements TypeMachinePieceRequirement[] @relation("ModelTypePieceRequirements")
|
||||
pieces Piece[] @relation("ModelTypePieceAssignments")
|
||||
pieceCustomFields CustomField[] @relation("ModelTypePieceCustomFields")
|
||||
}
|
||||
|
||||
model Constructeur {
|
||||
id String @id @default(cuid())
|
||||
name String @unique
|
||||
@@ -247,10 +242,10 @@ model CustomField {
|
||||
typeMachine TypeMachine? @relation("TypeMachineCustomFields", fields: [typeMachineId], references: [id], onDelete: Cascade)
|
||||
|
||||
typeComposantId String?
|
||||
typeComposant TypeComposant? @relation("TypeComposantCustomFields", fields: [typeComposantId], references: [id], onDelete: Cascade)
|
||||
typeComposant ModelType? @relation("ModelTypeCustomFields", fields: [typeComposantId], references: [id], onDelete: Cascade)
|
||||
|
||||
typePieceId String?
|
||||
typePiece TypePiece? @relation("TypePieceCustomFields", fields: [typePieceId], references: [id], onDelete: Cascade)
|
||||
typePiece ModelType? @relation("ModelTypePieceCustomFields", fields: [typePieceId], references: [id], onDelete: Cascade)
|
||||
|
||||
// Relations avec les valeurs
|
||||
customFieldValues CustomFieldValue[]
|
||||
@@ -289,7 +284,7 @@ model ComposantModel {
|
||||
updatedAt DateTime @updatedAt
|
||||
|
||||
typeComposantId String
|
||||
typeComposant TypeComposant @relation(fields: [typeComposantId], references: [id], onDelete: Cascade)
|
||||
typeComposant ModelType @relation("ModelTypeComponentModels", fields: [typeComposantId], references: [id], onDelete: Cascade)
|
||||
|
||||
composants Composant[]
|
||||
|
||||
@@ -305,7 +300,7 @@ model PieceModel {
|
||||
updatedAt DateTime @updatedAt
|
||||
|
||||
typePieceId String
|
||||
typePiece TypePiece @relation(fields: [typePieceId], references: [id], onDelete: Cascade)
|
||||
typePiece ModelType @relation("ModelTypePieceModels", fields: [typePieceId], references: [id], onDelete: Cascade)
|
||||
|
||||
pieces Piece[]
|
||||
|
||||
@@ -326,7 +321,7 @@ model TypeMachineComponentRequirement {
|
||||
typeMachine TypeMachine @relation(fields: [typeMachineId], references: [id], onDelete: Cascade)
|
||||
|
||||
typeComposantId String
|
||||
typeComposant TypeComposant @relation(fields: [typeComposantId], references: [id])
|
||||
typeComposant ModelType @relation("ModelTypeComponentRequirements", fields: [typeComposantId], references: [id])
|
||||
|
||||
composants Composant[]
|
||||
|
||||
@@ -347,7 +342,7 @@ model TypeMachinePieceRequirement {
|
||||
typeMachine TypeMachine @relation(fields: [typeMachineId], references: [id], onDelete: Cascade)
|
||||
|
||||
typePieceId String
|
||||
typePiece TypePiece @relation(fields: [typePieceId], references: [id])
|
||||
typePiece ModelType @relation("ModelTypePieceRequirements", fields: [typePieceId], references: [id])
|
||||
|
||||
pieces Piece[]
|
||||
|
||||
|
||||
Reference in New Issue
Block a user