import { Country } from "src/modules/country/entities/country.entity"
import {
  Entity,
  PrimaryGeneratedColumn,
  Column,
  CreateDateColumn,
  UpdateDateColumn,
  DeleteDateColumn,
  ManyToOne,
  JoinColumn,
} from "typeorm"

@Entity("currencies")
export class Currency {
  @PrimaryGeneratedColumn()
  id: number

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

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

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

  @Column({ type: "int" })
  country_id: number

  @DeleteDateColumn()
  deleted_at: Date

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

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

  @ManyToOne(() => Country, (country) => country.currencies)
  @JoinColumn({ name: "country_id" })
  country: Country
}
