|
|
|
class Challenge < ApplicationRecord
|
|
|
|
# difficulty: 关卡难度: 1.简单 2.中等 3.困难
|
|
|
|
# show_type: 效果展示:-1.无效果 1.图片 2.apk/exe 3.txt 4.html 5.mp3 6.mp4
|
|
|
|
|
|
|
|
belongs_to :shixun, :touch => true, counter_cache: true
|
|
|
|
belongs_to :user
|
|
|
|
has_many :challenge_samples, :dependent => :destroy
|
|
|
|
has_many :test_sets, :dependent => :destroy
|
|
|
|
has_many :challenge_tags, :dependent => :destroy
|
|
|
|
has_many :games, :dependent => :destroy
|
|
|
|
has_many :challenge_chooses, :dependent => :destroy
|
|
|
|
has_many :homework_challenge_settings, :dependent => :destroy
|
|
|
|
has_many :praise_treads, as: :praise_tread_object, dependent: :destroy
|
|
|
|
has_one :praise_tread_cache, as: :object, dependent: :destroy
|
|
|
|
has_many :tidings
|
|
|
|
# 参考答案
|
|
|
|
has_many :challenge_answers, :dependent => :destroy
|
|
|
|
has_many :exercise_bank_shixun_challenges, :dependent => :destroy
|
|
|
|
# 回复
|
|
|
|
has_many :discusses, :dependent => :destroy
|
|
|
|
|
|
|
|
# acts_as_attachable
|
|
|
|
|
|
|
|
scope :base_attrs, -> { select([:id, :subject, :position, :shixun_id, :st, :score, :path, :task_pass, :modify_time,
|
|
|
|
:web_route, :answer, :exec_time, :praises_count]) }
|
|
|
|
scope :choose_type, -> { where(st: 1) }
|
|
|
|
scope :practice_type, -> { where(st: 0) }
|
|
|
|
|
|
|
|
scope :fields_for_list, -> { select([:id, :subject, :st, :score, :position, :shixun_id]) }
|
|
|
|
|
|
|
|
validates :task_pass, length: { maximum: 35000, too_long: "不能超过35000个字符" }
|
|
|
|
|
|
|
|
|
|
|
|
after_commit :create_diff_record
|
|
|
|
|
|
|
|
def next_challenge
|
|
|
|
position = self.position + 1
|
|
|
|
Challenge.where(:position => position, :shixun_id => self.shixun).first
|
|
|
|
end
|
|
|
|
|
|
|
|
# 用户关卡是否通关
|
|
|
|
def has_passed?(user_id)
|
|
|
|
self.games.present? && self.games.select{|game| game.user_id == user_id && game.status == 2}.length > 0
|
|
|
|
end
|
|
|
|
|
|
|
|
## 选择题总分
|
|
|
|
def choose_score
|
|
|
|
self.score
|
|
|
|
#self.challenge_chooses.pluck(:score).sum
|
|
|
|
end
|
|
|
|
|
|
|
|
def challenge_difficulty
|
|
|
|
case difficulty
|
|
|
|
when 1 then "简单"
|
|
|
|
when 2 then "中等"
|
|
|
|
when 3 then "困难"
|
|
|
|
else ''
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# 关卡总分
|
|
|
|
def all_score
|
|
|
|
self.score
|
|
|
|
# if self.st == 1
|
|
|
|
# self.choose_score
|
|
|
|
# else
|
|
|
|
# self.score
|
|
|
|
# end
|
|
|
|
end
|
|
|
|
|
|
|
|
# 开启挑战
|
|
|
|
def open_game shixun
|
|
|
|
# 这里的identifier,status是关联了games取了games的identifier,status
|
|
|
|
identifier = self.identifier
|
|
|
|
if identifier.present?
|
|
|
|
shixun.task_pass || self.status != 3 ? "/tasks/#{identifier}" : ""
|
|
|
|
else
|
|
|
|
self.position == 1 ? "/api/shixuns/#{shixun.identifier}/shixun_exec" : ""
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# def open_game shixun, user_id
|
|
|
|
# game = self.games.map{|g| g.user_id == user_id}.first
|
|
|
|
# if game.present?
|
|
|
|
# shixun.task_pass || game.status != 3 ? "/tasks/#{game.identifier}" : ""
|
|
|
|
# else
|
|
|
|
# self.position == 1 ? "/api/shixuns/#{shixun.identifier}/shixun_exec" : ""
|
|
|
|
# end
|
|
|
|
# end
|
|
|
|
|
|
|
|
## 用户关卡状态 0: 不能开启实训; 1:直接开启; 2表示已完成
|
|
|
|
# def user_tpi_status shixun, user_id
|
|
|
|
# # todo: 以前没加索引导致相同关卡,同一用户有多个games
|
|
|
|
# # 允许跳关则直接开启
|
|
|
|
# game = games.where(user_id: user_id).take
|
|
|
|
# if game.blank?
|
|
|
|
# position == 1 ? 1 : 0
|
|
|
|
# else
|
|
|
|
# if game.status == 3
|
|
|
|
# shixun.task_pass ? 1 : 0
|
|
|
|
# elsif game.status == 2
|
|
|
|
# 2
|
|
|
|
# else
|
|
|
|
# 1
|
|
|
|
# end
|
|
|
|
# end
|
|
|
|
# end
|
|
|
|
|
|
|
|
# ## 用户关卡状态 0: 不能开启实训; 1:直接开启; 2表示已完成
|
|
|
|
def user_tpi_status shixun
|
|
|
|
# todo: 以前没加索引导致相同关卡,同一用户有多个games
|
|
|
|
# 允许跳关则直接开启
|
|
|
|
identifier = self.identifier
|
|
|
|
if identifier.blank?
|
|
|
|
self.position == 1 ? 1 : 0
|
|
|
|
else
|
|
|
|
if status == 3
|
|
|
|
shixun.task_pass ? 1 : 0
|
|
|
|
elsif status == 2
|
|
|
|
2
|
|
|
|
else
|
|
|
|
1
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def tags_show
|
|
|
|
if self.challenge_tags.nil?
|
|
|
|
"--"
|
|
|
|
else
|
|
|
|
self.try(:challenge_tags).map(&:name).join(";")
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
## 选择题答案
|
|
|
|
def choose_answer
|
|
|
|
result = []
|
|
|
|
self.challenge_chooses.each do |choose|
|
|
|
|
result << {:position => choose.position, :answer => (choose.answer.blank? ? choose.standard_answer : choose.answer)}
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
# 关卡用户通关数
|
|
|
|
def user_passed_count
|
|
|
|
#games.map{|g| g.status == 2}.count
|
|
|
|
self.games.where(status: 1).count
|
|
|
|
end
|
|
|
|
|
|
|
|
# 关卡用户正在挑战的人数
|
|
|
|
def playing_count
|
|
|
|
#games.map{|g| g.status == 0 || g.status == 1}.count
|
|
|
|
self.games.where(status: [0,1]).count
|
|
|
|
end
|
|
|
|
|
|
|
|
def last_challenge
|
|
|
|
Challenge.find_by(position: position - 1, shixun_id: shixun_id)
|
|
|
|
end
|
|
|
|
|
|
|
|
# 关卡评测文件
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def create_diff_record
|
|
|
|
return unless task_pass_previously_changed?
|
|
|
|
CreateDiffRecordJob.perform_later(User.current.id, id, 'Challenge', 'task_pass', task_pass_before_last_save, task_pass)
|
|
|
|
end
|
|
|
|
end
|