import {
  Entity,
  PrimaryGeneratedColumn,
  Column,
  ManyToOne,
  JoinColumn,
} from "typeorm"
import { BaseEntity } from "../../common/entities/base.entity"
import { Company } from "../../company/entities/company.entity"
import { Project } from "../../projects/entities/project.entity"
import { PartyPayment } from "./party-payment.entity"

@Entity("party_payment_histories")
export class PartyPaymentHistory extends BaseEntity {
  @PrimaryGeneratedColumn()
  id: number

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

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

  @Column({ type: "varchar", length: 50, nullable: false })
  party_type: string

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

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

  @Column({ type: "decimal", precision: 15, scale: 2, nullable: false })
  amount: number

  @Column({ type: "date", nullable: false })
  billing_month: Date

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

  @ManyToOne(() => PartyPayment, { onDelete: "CASCADE" })
  @JoinColumn({ name: "party_payment_id" })
  partyPayment: PartyPayment

  @ManyToOne(() => Project, { onDelete: "CASCADE" })
  @JoinColumn({ name: "project_id" })
  project: Project

  @ManyToOne(() => Company, { onDelete: "CASCADE" })
  @JoinColumn({ name: "company_id" })
  company: Company
}
