class CourseAttendance < ApplicationRecord
  # status: 0: 未开启,1:已开启,2:已截止
  # mode: 0 两种签到,1 二维码签到,2 数字签到
  enum mode: { ALL: 0, QRCODE: 1, NUMBER: 2 }

  belongs_to :course
  belongs_to :user

  has_many :course_attendance_groups, dependent: :destroy
  has_many :course_member_attendances, dependent: :destroy

  validates :name, presence: true
  validates :mode, presence: true
  validates :attendance_date, presence: true
  validates :start_time, presence: true
  validates :end_time, presence: true

  after_create :generate_attendance_code

  # 正常签到人数
  def normal_count
    course_member_attendances.select{|member_attendance| member_attendance.attendance_status == "NORMAL"}.size
  end

  # 请假人数
  def leave_count
    course_member_attendances.select{|member_attendance| member_attendance.attendance_status == "LEAVE"}.size
  end

  # 旷课人数
  def absence_count
    course_member_attendances.select{|member_attendance| member_attendance.attendance_status == "ABSENCE"}.size
  end

  def current_attendance?
    a_start_time = "#{attendance_date} #{start_time}".to_time
    a_end_time = "#{attendance_date} #{end_time}".to_time
    a_start_time < Time.current && Time.current < a_end_time
  end

  # 延迟生成邀请码
  def attendance_code
    return generate_attendance_code
  end

  # 生成邀请码
  CODES = %W(2 3 4 5 6 7 8 9 A B C D E F G H J K L N M O P Q R S T U V W X Y Z)
  def generate_attendance_code
    code = read_attribute(:attendance_code)
    if !code || code.size < 4
      code = CODES.sample(4).join
      return generate_attendance_code if CourseAttendance.where(attendance_code: code).present?
      update_attribute(:attendance_code, code)
    end
    code
  end
end