import {
  Column,
  CreateDateColumn,
  DeleteDateColumn,
  Entity,
  JoinColumn,
  ManyToOne,
  OneToMany,
  PrimaryGeneratedColumn,
  UpdateDateColumn,
} from "typeorm"
import { CustomerEpisode } from "./customer_episode.entity"
import { Hospital } from "src/modules/hospitals/entities/hospital.entity"
import { TripLog } from "src/modules/trips/entities/trip-logs.entity"

@Entity("episode_logs")
export class EpisodeLog {
  @PrimaryGeneratedColumn()
  id: number

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

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

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

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

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

  @Column({ type: "timestamp", nullable: true })
  log_date: Date

  @Column({ type: "timestamp", nullable: true })
  log_expiration: Date

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

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

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

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

  @DeleteDateColumn({ type: "timestamp", nullable: true })
  deleted_at: Date

  @ManyToOne(() => CustomerEpisode, (episode) => episode.logs)
  @JoinColumn({ name: "episode_id" })
  episode: CustomerEpisode

  @ManyToOne(() => Hospital, (hospital) => hospital.logs)
  @JoinColumn({ name: "hospital_id" })
  hospital: Hospital

  @OneToMany(() => TripLog, (trip_logs) => trip_logs.episode_log)
  trip_logs: TripLog[]
}
