import {
  Entity,
  PrimaryGeneratedColumn,
  Column,
  CreateDateColumn,
  ManyToOne,
  JoinColumn,
} from "typeorm"
import { Trip } from "./trip.entity"
import { TeamMember } from "../../team-member/entities/team_member.entity"
import { Customer } from "src/modules/customers/entities/customer.entity"

@Entity("trip_timeline_history")
export class TripTimelineHistory {
  @PrimaryGeneratedColumn()
  id: number

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

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

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

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

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

  @CreateDateColumn({ type: "timestamp" })
  created_at: Date

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

  @ManyToOne(() => TeamMember, (teamMember) => teamMember.trip_status_changes, {
    nullable: true,
  })
  @JoinColumn({ name: "changed_by_id" })
  changed_by: TeamMember

  @ManyToOne(() => Customer, (customer) => customer.timeline, {
    nullable: true,
  })
  @JoinColumn({ name: "customer_id" })
  customer: Customer
}
