summaryrefslogtreecommitdiff
path: root/app/controllers/matches_controller.rb
diff options
context:
space:
mode:
authorguntasgrewal <guntasgrewal@gmail.com>2014-04-07 03:48:51 -0400
committerguntasgrewal <guntasgrewal@gmail.com>2014-04-07 03:48:51 -0400
commitf20dc8df17187027c1881803dbc72b1d3802ff1a (patch)
tree32c71a2fa178d439f9b0720a59287832f3945a6b /app/controllers/matches_controller.rb
parent0da3155cc44e257fdcaae81c9dd7f2a38d5389df (diff)
Tournament advancement stuff. IT'S 4 AM
Diffstat (limited to 'app/controllers/matches_controller.rb')
-rw-r--r--app/controllers/matches_controller.rb31
1 files changed, 12 insertions, 19 deletions
diff --git a/app/controllers/matches_controller.rb b/app/controllers/matches_controller.rb
index 8e7cc9e..7d6bf43 100644
--- a/app/controllers/matches_controller.rb
+++ b/app/controllers/matches_controller.rb
@@ -144,9 +144,6 @@ class MatchesController < ApplicationController
handle_asynchronously :is_match_over
def show
- if (@match.status == 1)
- @scores = @match.scores
- end
file_blue = "blue.yaml"
file_purple = "purple.yaml"
@blue2 = YAML.load_file(file_blue)
@@ -167,12 +164,16 @@ class MatchesController < ApplicationController
format.json { render json: "Permission denied", status: :forbidden }
end
end
- when "score"
+ when "finish"
+ @match.status = 2
+
+ # Individual scores
scores = params["scores"]
scores.each do |user_name, score|
Score.create(user: User.find_by_user_name(user_name), match: @match, value: score.to_i)
end
+ # Team scores
team_scores = {}
@match.teams.each do |team|
team_scores[team] = 0
@@ -180,10 +181,15 @@ class MatchesController < ApplicationController
team_scores[team] += scores[user.user_name].to_i
end
end
-
teams = team_scores.invert
@match.winner = teams[teams.keys.sort.last]
+ # Schedule next match
+ cur_match_num = @tournament.matches_ordered.invert[@match]
+ unless cur_match_num == 1
+ @match.winner.matches.push(@tournament.matches_ordered[cur_match_num/2])
+ end
+
respond_to do |format|
if @match.save
format.html { redirect_to tournament_match_path(@tournament, @match), notice: 'Peer evaluation started.' }
@@ -194,7 +200,7 @@ class MatchesController < ApplicationController
end
end
when "peer"
- @match.status = 2;
+ @match.status = 3;
respond_to do |format|
if @match.save
format.html { redirect_to tournament_match_path(@tournament, @match), notice: 'Scores Submitted' }
@@ -204,17 +210,6 @@ class MatchesController < ApplicationController
format.json { render json: "Permission denied", status: :forbidden }
end
end
- when "finish"
- @match.status = 3
- respond_to do |format|
- if @match.save
- format.html { redirect_to tournament_match_path(@tournament, @match), notice: 'Peer Review Submitted' }
- format.json { head :no_content }
- else
- format.html { redirect_to @tournament, notice: "You don't have permission to start this match." }
- format.json { render json: "Permission denied", status: :forbidden }
- end
- end
when "reset"
@match.status = 0
respond_to do |format|
@@ -226,7 +221,6 @@ class MatchesController < ApplicationController
format.json { render json: "Permission denied", status: :forbidden }
end
end
-
else
respond_to do |format|
format.html { redirect_to @tournament, notice: "Invalid action", status: :unprocessable_entity }
@@ -241,7 +235,6 @@ class MatchesController < ApplicationController
def set_match
set_tournament
@match = @tournament.matches.find(params[:id])
- @first = @match.teams.first.users.first.user_name.downcase
end
def set_tournament
@tournament = Tournament.find(params[:tournament_id])