import { TeamMember } from "src/modules/team-member/entities/team_member.entity"
import { Trip } from "src/modules/trips/entities/trip.entity"
import {
  Entity,
  PrimaryGeneratedColumn,
  Column,
  CreateDateColumn,
  UpdateDateColumn,
  DeleteDateColumn,
  ManyToOne,
  JoinColumn,
  OneToMany,
} from "typeorm"
import { IncidentType } from "./incident-type.entity"
import { FleetManagement } from "src/modules/fleet-management/entities/fleet-management.entity"
import { IncidentImage } from "./incident-images.entity"

@Entity("incident_reportings")
export class IncidentReporting {
  @PrimaryGeneratedColumn()
  id: number

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

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

  @Column({ type: "int", nullable: false })
  issue_type_id: number

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

  @Column({ type: "varchar", nullable: false })
  issue_title: string

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

  @Column({ type: "varchar" })
  created_date: string

  @Column({ type: "varchar" })
  created_time: string

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

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

  @DeleteDateColumn()
  deleted_at: Date

  @ManyToOne(() => TeamMember, (team_member) => team_member.incident_reporting)
  @JoinColumn({ name: "driver_id" })
  team_member: TeamMember

  @ManyToOne(
    () => FleetManagement,
    (fleet_management) => fleet_management.incident_reporting,
  )
  @JoinColumn({ name: "fleet_id" })
  fleet_management: FleetManagement

  @ManyToOne(() => Trip, (trip) => trip.incident_reporting)
  @JoinColumn({ name: "trip_id" })
  trip: Trip

  @ManyToOne(() => IncidentType, (incident_type) => incident_type.incident)
  @JoinColumn({ name: "issue_type_id" })
  incident_type: IncidentType

  @OneToMany(() => IncidentImage, (image) => image.incident, { cascade: true })
  images: IncidentImage[]
}
