import { Achievement } from 'src/achievements/entities/achievement.entity';
import { AppUser } from 'src/app_users/entities/app_user.entity';
import {
  Entity,
  PrimaryGeneratedColumn,
  Column,
  ManyToOne,
  JoinColumn,
} from 'typeorm';

@Entity('user_achievements')
export class UserAchievement {
  @PrimaryGeneratedColumn('uuid')
  id: string;

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

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

  @Column({ type: 'varchar' })
  achievement_goal: string;

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

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

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

  @Column({ type: 'timestamp', nullable: true })
  deleted_at: Date | null;

  @ManyToOne(() => AppUser, (user) => user.user_achievements, {
    onDelete: 'CASCADE',
  })
  @JoinColumn({ name: 'user_id' })
  user: AppUser;

  @ManyToOne(
    () => Achievement,
    (achievement) => achievement.user_achievements,
    {
      onDelete: 'CASCADE',
    },
  )
  @JoinColumn({ name: 'achievement_id' })
  achievement: Achievement;
}
