ff-admin-server/src/entity/unit/inspection/inspectionPlan.ts

51 lines
1.4 KiB
TypeScript
Raw Normal View History

2025-05-24 13:51:38 +02:00
import { Column, CreateDateColumn, Entity, ManyToOne, OneToMany, PrimaryGeneratedColumn } from "typeorm";
2025-05-28 18:30:00 +02:00
import { PlanTimeDefinition } from "../../../viewmodel/admin/unit/inspection/inspectionPlan.models";
2025-05-24 13:51:38 +02:00
import { inspectionVersionedPlan } from "./inspectionVersionedPlan";
import { equipmentType } from "../equipment/equipmentType";
import { vehicleType } from "../vehicle/vehicleType";
2025-05-24 13:51:38 +02:00
@Entity()
export class inspectionPlan {
@PrimaryGeneratedColumn("uuid")
id: string;
@Column({ type: "varchar", length: 255 })
title: string;
@Column({ type: "varchar", length: 255 })
inspectionInterval: PlanTimeDefinition;
@Column({ type: "varchar", length: 255 })
remindTime: PlanTimeDefinition;
@CreateDateColumn()
2025-05-26 14:53:25 +02:00
createdAt: Date;
2025-05-24 13:51:38 +02:00
2025-06-08 07:55:40 +02:00
@Column({ nullable: true, default: null })
equipmentTypeId?: string;
2025-05-24 13:51:38 +02:00
2025-06-08 07:55:40 +02:00
@Column({ nullable: true, default: null })
vehicleTypeId?: string;
2025-05-24 13:51:38 +02:00
@ManyToOne(() => equipmentType, {
2025-05-28 18:30:00 +02:00
nullable: true,
onDelete: "CASCADE",
onUpdate: "RESTRICT",
})
equipmentType?: equipmentType;
2025-05-24 13:51:38 +02:00
@ManyToOne(() => vehicleType, {
2025-05-28 18:30:00 +02:00
nullable: true,
onDelete: "CASCADE",
onUpdate: "RESTRICT",
})
vehicleType?: vehicleType;
2025-05-24 13:51:38 +02:00
@OneToMany(() => inspectionVersionedPlan, (ivp) => ivp.inspectionPlan, {
cascade: ["insert"],
})
versionedPlans: inspectionVersionedPlan[];
latestVersionedPlan?: inspectionVersionedPlan;
}