import {
  Entity,
  PrimaryGeneratedColumn,
  Column,
  ManyToOne,
  OneToMany,
  JoinColumn,
} from "typeorm"
import { BaseEntity } from "../../common/entities/base.entity"
import { Auth } from "../../auth/entities/auth.entity"
import { Company } from "../../company/entities/company.entity"
import { RolePermission } from "../../role-permissions/entities/role-permission.entity"

@Entity("roles")
export class Role extends BaseEntity {
  @PrimaryGeneratedColumn()
  id: number

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

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

  @Column({ type: "smallint", default: 1 })
  status: number

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

  @OneToMany(() => Auth, (user) => user.role)
  users: Auth[]

  @OneToMany(() => RolePermission, (rolePermission) => rolePermission.role)
  rolePermissions: RolePermission[]

  @ManyToOne(() => Auth)
  @JoinColumn({ name: "created_by" })
  createdByUser: Auth

  @ManyToOne(() => Auth)
  @JoinColumn({ name: "updated_by" })
  updatedByUser: Auth

  @ManyToOne(() => Auth)
  @JoinColumn({ name: "deleted_by" })
  deletedByUser: Auth
}
