import {
  Entity,
  PrimaryGeneratedColumn,
  Column,
  CreateDateColumn,
  UpdateDateColumn,
  DeleteDateColumn,
  ManyToOne,
  JoinColumn,
} from 'typeorm';
import { Tip } from './tip.entity';

@Entity('tips_medias')
export class TipsMedias {
  @PrimaryGeneratedColumn('uuid')
  id: string;

  @Column({ type: 'uuid' })
  tips_id: string;

  @Column({ type: 'varchar', nullable: true })
  media: string;

  @Column({ type: 'varchar', nullable: true })
  media_type: string;

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

  @CreateDateColumn({ type: 'timestamp', default: () => 'CURRENT_TIMESTAMP' })
  created_at: Date;

  @UpdateDateColumn({ type: 'timestamp', default: () => 'CURRENT_TIMESTAMP' })
  updated_at: Date;

  @DeleteDateColumn({ type: 'timestamp', nullable: true })
  deleted_at: Date;

  @ManyToOne(() => Tip, (tip) => tip.tips_medias, { onDelete: 'CASCADE' })
  @JoinColumn({ name: 'tips_id' })
  tip: Tip;
}
