CSV export: correct display time + remaining pieces
This commit is contained in:
		| @@ -114,7 +114,12 @@ class ContestantsController < ApplicationController | |||||||
|   def export |   def export | ||||||
|     authorize @contest |     authorize @contest | ||||||
|  |  | ||||||
|     @contestants = @contest.contestants.sort_by { |contestant| [ -contestant.completions.size, contestant.time_seconds ] } |     @contestants = @contest.contestants.sort_by { |contestant| [ | ||||||
|  |       -contestant.completions.where(remaining_pieces: nil).size, | ||||||
|  |       (contestant.completions.where(remaining_pieces: nil).size == @contest.puzzles.length ? 1 : 0) * contestant.time_seconds, | ||||||
|  |       contestant.completions.size > 0 && contestant.completions[-1].remaining_pieces ? contestant.completions[-1].remaining_pieces : 1000000, | ||||||
|  |       contestant.time_seconds | ||||||
|  |     ] } | ||||||
|  |  | ||||||
|     respond_to do |format| |     respond_to do |format| | ||||||
|       format.csv do |       format.csv do | ||||||
|   | |||||||
| @@ -1,4 +1,4 @@ | |||||||
| = CSV.generate_line [t("helpers.rank"), t("activerecord.attributes.contestant.name"), t("activerecord.attributes.contestant.display_time"), t("activerecord.attributes.contestant.completions")] | = CSV.generate_line [t("helpers.rank"), t("activerecord.attributes.contestant.name"), t("activerecord.attributes.contestant.display_time"), t("activerecord.attributes.contestant.completions")] | ||||||
|  |  | ||||||
| - @contestants.each_with_index do |contestant, index| | - @contestants.each_with_index do |contestant, index| | ||||||
|   = CSV.generate_line([index + 1, contestant.name, contestant.display_time, contestant.completions.length]) |   = CSV.generate_line([index + 1, contestant.name, contestant.completions.size > 0 && contestant.completions[-1].remaining_pieces ? "#{contestant.completions.map{|completion| completion.puzzle.pieces}.sum - contestant.completions[-1].remaining_pieces}p" : contestant.display_time, contestant.completions.where(remaining_pieces: nil).length]) | ||||||
		Reference in New Issue
	
	Block a user