Description:
fix bug in score report
Commit status:
[Not Reviewed]
References:
Comments:
0 Commit comments 0 Inline Comments
Unresolved TODOs:
There are no unresolved TODOs
Add another comment

r614:20f955456e9b - - 1 file changed: 2 inserted, 2 deleted

@@ -7,98 +7,98
7 7 before_filter :admin_authorization, only: [:login_stat,:submission_stat, :stuck, :cheat_report, :cheat_scruntinize, :show_max_score]
8 8
9 9 before_filter(only: [:problem_hof]) { |c|
10 10 return false unless authenticate
11 11
12 12 if GraderConfiguration["right.user_view_submission"]
13 13 return true;
14 14 end
15 15
16 16 admin_authorization
17 17 }
18 18
19 19 def max_score
20 20 end
21 21
22 22 def current_score
23 23 @problems = Problem.find_available_problems
24 24 @users = User.includes(:contests).includes(:contest_stat).where(enabled: true)
25 25 @scorearray = calculate_max_score(@problems, @users,0,0,true)
26 26
27 27 #rencer accordingly
28 28 if params[:button] == 'download' then
29 29 csv = gen_csv_from_scorearray(@scorearray,@problems)
30 30 send_data csv, filename: 'max_score.csv'
31 31 else
32 32 #render template: 'user_admin/user_stat'
33 33 render 'current_score'
34 34 end
35 35 end
36 36
37 37 def show_max_score
38 38 #process parameters
39 39 #problems
40 40 @problems = []
41 41 params[:problem_id].each do |id|
42 42 next unless id.strip != ""
43 43 pid = Problem.find_by_id(id.to_i)
44 44 @problems << pid if pid
45 45 end
46 46
47 47 #users
48 48 @users = if params[:user] == "all" then
49 49 User.find(:all, :include => [:contests, :contest_stat])
50 50 else
51 51 User.includes(:contests).includes(:contest_stat).where(enabled: true)
52 52 end
53 53
54 54 #set up range from param
55 - since_id = params.fetch(:min_id, 0).to_i
56 - until_id = params.fetch(:max_id, 0).to_i
55 + since_id = params.fetch(:from_id, 0).to_i
56 + until_id = params.fetch(:to_id, 0).to_i
57 57
58 58 #calculate the routine
59 59 @scorearray = calculate_max_score(@problems, @users,since_id,until_id)
60 60
61 61 #rencer accordingly
62 62 if params[:button] == 'download' then
63 63 csv = gen_csv_from_scorearray(@scorearray,@problems)
64 64 send_data csv, filename: 'max_score.csv'
65 65 else
66 66 #render template: 'user_admin/user_stat'
67 67 render 'max_score'
68 68 end
69 69
70 70 end
71 71
72 72 def score
73 73 if params[:commit] == 'download csv'
74 74 @problems = Problem.all
75 75 else
76 76 @problems = Problem.find_available_problems
77 77 end
78 78 @users = User.includes(:contests, :contest_stat).where(enabled: true) #find(:all, :include => [:contests, :contest_stat]).where(enabled: true)
79 79 @scorearray = Array.new
80 80 @users.each do |u|
81 81 ustat = Array.new
82 82 ustat[0] = u
83 83 @problems.each do |p|
84 84 sub = Submission.find_last_by_user_and_problem(u.id,p.id)
85 85 if (sub!=nil) and (sub.points!=nil) and p and p.full_score
86 86 ustat << [(sub.points.to_f*100/p.full_score).round, (sub.points>=p.full_score)]
87 87 else
88 88 ustat << [0,false]
89 89 end
90 90 end
91 91 @scorearray << ustat
92 92 end
93 93 if params[:commit] == 'download csv' then
94 94 csv = gen_csv_from_scorearray(@scorearray,@problems)
95 95 send_data csv, filename: 'last_score.csv'
96 96 else
97 97 render template: 'user_admin/user_stat'
98 98 end
99 99
100 100 end
101 101
102 102 def login_stat
103 103 @logins = Array.new
104 104
You need to be logged in to leave comments. Login now