ff-admin-server/src/entity/unit/maintenance.ts

55 lines
1.4 KiB
TypeScript
Raw Normal View History

2025-07-19 11:02:07 +02:00
import { Column, ColumnType, CreateDateColumn, Entity, ManyToOne, OneToMany, PrimaryGeneratedColumn } from "typeorm";
import { equipment } from "./equipment/equipment";
import { wearable } from "./wearable/wearable";
import { vehicle } from "./vehicle/vehicle";
import { damageReport } from "./damageReport";
2025-07-19 11:02:07 +02:00
import { getTypeByORM } from "../../migrations/ormHelper";
@Entity()
export class maintenance {
@PrimaryGeneratedColumn("uuid")
id: string;
@CreateDateColumn()
createdAt: Date;
2025-07-19 11:02:07 +02:00
@Column({ type: getTypeByORM("datetime").type as ColumnType, nullable: true, default: null })
finishedAt?: Date;
@Column({ type: "varchar", length: 255 })
status: string;
@Column({ type: "text" })
description: string;
@Column({ nullable: true, default: null })
equipmentId?: string;
@Column({ nullable: true, default: null })
vehicleId?: string;
@Column({ nullable: true, default: null })
wearableId?: string;
2025-07-14 15:28:57 +02:00
@ManyToOne(() => equipment, (e) => e.maintenances, {
nullable: true,
onDelete: "CASCADE",
onUpdate: "RESTRICT",
})
equipment?: equipment;
2025-07-14 15:28:57 +02:00
@ManyToOne(() => vehicle, (v) => v.maintenances, {
nullable: true,
onDelete: "CASCADE",
onUpdate: "RESTRICT",
})
vehicle?: vehicle;
2025-07-14 15:28:57 +02:00
@ManyToOne(() => wearable, (w) => w.maintenances, {
nullable: true,
onDelete: "CASCADE",
onUpdate: "RESTRICT",
})
wearable?: wearable;
}