# frozen_string_literal: true

class InvalidTrustLevel < StandardError
end

class TrustLevel
  def self.[](level)
    raise InvalidTrustLevel if !valid?(level)

    level
  end

  def self.levels
    @levels ||= Enum.new(:newuser, :basic, :member, :regular, :leader, start: 0)
  end

  def self.valid?(level)
    valid_range === level
  end

  def self.valid_range
    (0..4)
  end

  def self.compare(current_level, level)
    (current_level || 0) >= level
  end

  def self.name(level)
    I18n.t("js.trust_levels.names.#{levels[level]}")
  end

  def self.calculate(user, use_previous_trust_level: false)
    # First, use the manual locked level
    return user.manual_locked_trust_level if user.manual_locked_trust_level.present?

    # Then consider the group locked level (or the previous trust level)
    granted_trust_level = user.group_granted_trust_level || 0
    previous_trust_level = use_previous_trust_level ? find_previous_trust_level(user) : 0

    [granted_trust_level, previous_trust_level, SiteSetting.default_trust_level].max
  end

  private

  def self.find_previous_trust_level(user)
    UserHistory
      .where(action: UserHistory.actions[:change_trust_level])
      .where(target_user_id: user.id)
      .order(created_at: :desc)
      .pick(:new_value)
      .to_i
  end
end