import {
  Entity,
  PrimaryGeneratedColumn,
  Column,
  ManyToOne,
  CreateDateColumn,
  UpdateDateColumn,
  JoinColumn,
  DeleteDateColumn,
  OneToMany,
} from "typeorm"
import { TeamMember } from "src/modules/team-member/entities/team_member.entity"
import { FleetManagement } from "src/modules/fleet-management/entities/fleet-management.entity"
import { InspectionFleetAnswer } from "./inspection-report-answers.entity"

@Entity("inspection_fleet_reports")
export class InspectionFleetReport {
  @PrimaryGeneratedColumn()
  id: number

  @Column({ type: "int", nullable: true })
  fleet_id: number

  @Column({ type: "int", nullable: true })
  driver_id: number

  //   @Column({ type: "int", nullable: true })
  //   dispatcher_id: number

  @Column({ type: "varchar", nullable: true })
  front_side_photo: string

  @Column({ type: "varchar", nullable: true })
  right_side_photo: string

  @Column({ type: "varchar", nullable: true })
  back_side_photo: string

  @Column({ type: "varchar", nullable: true })
  left_side_photo: string

  @CreateDateColumn({ type: "timestamp", default: () => "NOW()" })
  created_at: Date

  @UpdateDateColumn({ type: "timestamp", default: () => "NOW()" })
  updated_at: Date

  @DeleteDateColumn()
  deleted_at: Date

  @ManyToOne(() => TeamMember, (member) => member.driver_inspection_reports, {
    onDelete: "CASCADE",
  })
  @JoinColumn({ name: "driver_id" })
  driver: TeamMember

  //   @ManyToOne(
  //     () => TeamMember,
  //     (member) => member.dispatcher_inspection_reports,
  //     {
  //       onDelete: "CASCADE",
  //     },
  //   )
  //   @JoinColumn({ name: "dispatcher_id" })
  //   dispatcher: TeamMember

  @ManyToOne(() => FleetManagement, (fleet) => fleet.inspection_reports, {
    onDelete: "CASCADE",
  })
  @JoinColumn({ name: "fleet_id" })
  fleet: FleetManagement

  @OneToMany(
    () => InspectionFleetAnswer,
    (answer) => answer.inspection_fleet_report,
  )
  inspection_answers: InspectionFleetAnswer[]
}
