import { MeetAndGreetPricing } from "src/modules/meet-greet-pricing/entities/meet-greet-pricing.entity"
import { TripType } from "src/modules/trips/entities/trip-type.entity"
import { Trip } from "src/modules/trips/entities/trip.entity"
import { VehicleType } from "src/modules/vehicle-type/entities/vehicle-type.entity"
import {
  Column,
  CreateDateColumn,
  DeleteDateColumn,
  Entity,
  JoinColumn,
  ManyToOne,
  PrimaryGeneratedColumn,
  UpdateDateColumn,
} from "typeorm"

@Entity("trip_base_pricing")
export class TripBasePricing {
  @PrimaryGeneratedColumn()
  id: number

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

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

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

  @Column({ type: "varchar", nullable: true })
  vehicle_type_price: number

  @Column({ type: "varchar", nullable: true })
  vehicle_total_price: number

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

  @Column({ type: "varchar", nullable: true })
  meet_greet_price: number

  @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(() => Trip, (trip) => trip.base_pricing)
  @JoinColumn({ name: "trip_id" })
  trip: Trip

  @ManyToOne(() => VehicleType, (vehicle_type) => vehicle_type.base_pricing, {
    nullable: true,
  })
  @JoinColumn({ name: "vehicle_type_id" })
  vehicle_type: VehicleType

  @ManyToOne(() => TripType, (trip_type) => trip_type.base_pricing, {
    nullable: true,
  })
  @JoinColumn({ name: "trip_type_id" })
  trip_type: TripType

  @ManyToOne(
    () => MeetAndGreetPricing,
    (meet_greet_pricing) => meet_greet_pricing.base_pricing,
  )
  @JoinColumn({ name: "meet_greet_id" })
  meet_greet_pricing: MeetAndGreetPricing
}
