import { AppUser } from 'src/app_users/entities/app_user.entity';
import {
  Column,
  CreateDateColumn,
  Entity,
  JoinColumn,
  ManyToOne,
  PrimaryGeneratedColumn,
} from 'typeorm';
import { Streak } from './streak.entity';

@Entity('user_streaks')
export class UserStreak {
  @PrimaryGeneratedColumn('uuid')
  id: string;

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

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

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

  @Column({ type: '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, (app_user) => app_user.user_streaks)
  @JoinColumn({ name: 'app_user_id' })
  app_user: AppUser;

  @ManyToOne(() => Streak, (streak) => streak.user_streaks, {
    onDelete: 'CASCADE',
  })
  @JoinColumn({ name: 'streak_id' })
  streak: Streak;
}
