mirror of
https://github.com/jcwimer/wrestlingApp
synced 2026-03-25 01:14:43 +00:00
Fixed bug in pooladvance and refactored
This commit is contained in:
@@ -5,7 +5,7 @@ class Match < ActiveRecord::Base
|
||||
has_many :wrestlers, :through => :weight
|
||||
|
||||
after_save do
|
||||
if self.finished == 1
|
||||
if self.finished == 1 && self.winner_id != nil
|
||||
advance_wrestlers
|
||||
calcSchoolPoints
|
||||
end
|
||||
@@ -14,7 +14,7 @@ class Match < ActiveRecord::Base
|
||||
WIN_TYPES = ["Decision", "Major", "Tech Fall", "Pin", "Forfeit", "Injury Default", "Default", "DQ"]
|
||||
|
||||
def calcSchoolPoints
|
||||
if self.w1? && self.w2?
|
||||
if self.w1 && self.w2
|
||||
wrestler1.school.calcScore
|
||||
wrestler2.school.calcScore
|
||||
end
|
||||
@@ -29,7 +29,7 @@ class Match < ActiveRecord::Base
|
||||
end
|
||||
|
||||
def advance_wrestlers
|
||||
if self.w1? && self.w2?
|
||||
if self.w1 && self.w2
|
||||
@w1 = wrestler1
|
||||
@w2 = wrestler2
|
||||
@w1.advanceInBracket
|
||||
@@ -56,7 +56,7 @@ class Match < ActiveRecord::Base
|
||||
end
|
||||
|
||||
def w1_name
|
||||
if self.w1
|
||||
if self.w1 != nil
|
||||
wrestler1.name
|
||||
else
|
||||
self.loser1_name
|
||||
@@ -64,7 +64,7 @@ class Match < ActiveRecord::Base
|
||||
end
|
||||
|
||||
def w2_name
|
||||
if self.w2
|
||||
if self.w2 != nil
|
||||
wrestler2.name
|
||||
else
|
||||
self.loser2_name
|
||||
|
||||
@@ -1,22 +1,24 @@
|
||||
class Pooladvance
|
||||
|
||||
attr_accessor :wrestler
|
||||
def initialize(wrestler)
|
||||
@wrestler = wrestler
|
||||
end
|
||||
|
||||
def advanceWrestler
|
||||
if self.wrestler.weight.allPoolMatchesFinished(self.wrestler.generatePoolNumber) && self.wrestler.finishedBracketMatches.size == 0
|
||||
if @wrestler.weight.allPoolMatchesFinished(@wrestler.generatePoolNumber) && @wrestler.finishedBracketMatches.size == 0
|
||||
poolToBracketAdvancment
|
||||
end
|
||||
if self.wrestler.finishedBracketMatches.size != 0
|
||||
bracketAdvancment
|
||||
if @wrestler.finishedBracketMatches.size > 0
|
||||
bracketAdvancment
|
||||
end
|
||||
end
|
||||
|
||||
def poolToBracketAdvancment
|
||||
pool = self.wrestler.generatePoolNumber
|
||||
if self.wrestler.weight.wrestlers.size > 6
|
||||
poolOrder = self.wrestler.weight.poolOrder(pool)
|
||||
pool = @wrestler.generatePoolNumber
|
||||
if @wrestler.weight.wrestlers.size > 6
|
||||
poolOrder = @wrestler.weight.poolOrder(pool)
|
||||
#Take pool order and move winner and runner up to correct match based on w1_name and w2_name
|
||||
matches = self.wrestler.weight.matches
|
||||
matches = @wrestler.weight.matches
|
||||
winnerMatch = matches.select{|m| m.loser1_name == "Winner Pool #{pool}" || m.loser2_name == "Winner Pool #{pool}"}.first
|
||||
runnerUpMatch = matches.select{|m| m.loser1_name == "Runner Up Pool #{pool}" || m.loser2_name == "Runner Up Pool #{pool}"}.first
|
||||
winner = poolOrder.first
|
||||
@@ -27,49 +29,46 @@ class Pooladvance
|
||||
end
|
||||
|
||||
def bracketAdvancment
|
||||
#Move to next correct spot in bracket
|
||||
matches = self.wrestler.finishedMatches.sort_by{|m| m.round}.reverse
|
||||
last_match = matches.first
|
||||
if last_match.winner_id == self.wrestler.id
|
||||
winnerAdvance(last_match)
|
||||
if @wrestler.winnerOfLastMatch?
|
||||
winnerAdvance
|
||||
end
|
||||
if last_match.winner_id != self.wrestler.id
|
||||
loserAdvance(last_match)
|
||||
if !@wrestler.winnerOfLastMatch?
|
||||
loserAdvance
|
||||
end
|
||||
end
|
||||
|
||||
def winnerAdvance(last_match)
|
||||
#Quarter to Semis
|
||||
#Semis to 1/2
|
||||
#Conso Semis to 5/6
|
||||
pos = last_match.bracket_position_number
|
||||
new_pos = (pos/2.0)
|
||||
if last_match.bracket_position == "Quarter"
|
||||
new_match = Match.where("bracket_position = ? AND bracket_position_number = ?","Semis",new_pos.ceil).first
|
||||
def winnerAdvance
|
||||
if @wrestler.lastMatch.bracket_position == "Quarter"
|
||||
new_match = Match.where("bracket_position = ? AND bracket_position_number = ? AND weight_id = ?","Semis",@wrestler.nextMatchPositionNumber.ceil,@wrestler.weight_id).first
|
||||
updateNewMatch(new_match)
|
||||
end
|
||||
if last_match.bracket_position == "Semis"
|
||||
new_match = Match.where("bracket_position = ? AND bracket_position_number = ?","1/2",new_pos.ceil).first
|
||||
if @wrestler.lastMatch.bracket_position == "Semis"
|
||||
new_match = Match.where("bracket_position = ? AND bracket_position_number = ? AND weight_id = ?","1/2",@wrestler.nextMatchPositionNumber.ceil,@wrestler.weight_id).first
|
||||
updateNewMatch(new_match)
|
||||
end
|
||||
if last_match.bracket_position == "Conso Semis"
|
||||
new_match = Match.where("bracket_position = ? AND bracket_position_number = ?","5/6",new_pos.ceil).first
|
||||
if @wrestler.lastMatch.bracket_position == "Conso Semis"
|
||||
new_match = Match.where("bracket_position = ? AND bracket_position_number = ? AND weight_id = ?","5/6",@wrestler.nextMatchPositionNumber.ceil,@wrestler.weight_id).first
|
||||
updateNewMatch(new_match)
|
||||
end
|
||||
if new_match
|
||||
if new_pos == new_pos.ceil
|
||||
new_match.w2 = self.wrestler.id
|
||||
new_match.save
|
||||
|
||||
end
|
||||
|
||||
def updateNewMatch(match)
|
||||
if @wrestler.nextMatchPositionNumber == @wrestler.nextMatchPositionNumber.ceil
|
||||
match.w2 = @wrestler.id
|
||||
match.update
|
||||
end
|
||||
if new_pos != new_pos.ceil
|
||||
new_match.w1 = self.wrestler.id
|
||||
new_match.save
|
||||
if @wrestler.nextMatchPositionNumber != @wrestler.nextMatchPositionNumber.ceil
|
||||
match.w1 = @wrestler.id
|
||||
match.update
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
def loserAdvance(last_match)
|
||||
bout = last_match.bout_number
|
||||
next_match = Match.where("loser1_name = ? or loser2_name = ?","Loser of #{bout}","Loser of #{bout}")
|
||||
def loserAdvance
|
||||
bout = @wrestler.lastMatch.bout_number
|
||||
next_match = Match.where("loser1_name = ? OR loser2_name = ? AND weight_id = ?","Loser of #{bout}","Loser of #{bout}",@wrestler.weight_id)
|
||||
if next_match.size > 0
|
||||
next_match.first.replaceLoserNameWithWrestler(self.wrestler,"Loser of #{bout}")
|
||||
next_match.first.replaceLoserNameWithWrestler(@wrestler,"Loser of #{bout}")
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
@@ -39,6 +39,23 @@ class Wrestler < ActiveRecord::Base
|
||||
unfinishedMatches.first
|
||||
end
|
||||
|
||||
def nextMatchPositionNumber
|
||||
pos = lastMatch.bracket_position_number
|
||||
return (pos/2.0)
|
||||
end
|
||||
|
||||
def lastMatch
|
||||
finishedMatches.sort_by{|m| m.round}.reverse.first
|
||||
end
|
||||
|
||||
def winnerOfLastMatch?
|
||||
if lastMatch.winner_id == self.id
|
||||
return true
|
||||
else
|
||||
return false
|
||||
end
|
||||
end
|
||||
|
||||
def nextMatchBoutNumber
|
||||
if nextMatch
|
||||
nextMatch.bout_number
|
||||
@@ -155,8 +172,6 @@ class Wrestler < ActiveRecord::Base
|
||||
end
|
||||
|
||||
def advanceInBracket
|
||||
@advance = Pooladvance.new
|
||||
@advance.wrestler = self
|
||||
@advance.advanceWrestler
|
||||
Pooladvance.new(self).advanceWrestler
|
||||
end
|
||||
end
|
||||
|
||||
Reference in New Issue
Block a user