Improved styling for contests and referee admin pages

Fixes deleting maps form contests
This commit is contained in:
Luke Barratt 2014-04-25 23:15:15 +01:00
parent 66c0ce27e7
commit ac0b47eca9
13 changed files with 341 additions and 193 deletions

View file

@ -3,6 +3,7 @@
*/ */
form { form {
.inline { .inline {
float: left; float: left;
display: inline-block; display: inline-block;
@ -48,6 +49,7 @@ form {
display: inline-block; display: inline-block;
margin-right: em(10); margin-right: em(10);
float: left; float: left;
max-width: 100%;
select { select {
@include appearance(none); @include appearance(none);
@ -65,6 +67,7 @@ form {
margin: 0; margin: 0;
padding: $select-padding em(50) $select-padding $input-padding; padding: $select-padding em(50) $select-padding $input-padding;
font-size: $input-font-size; font-size: $input-font-size;
max-width: 100%;
option { option {
font-size: $input-font-size; font-size: $input-font-size;
@ -143,7 +146,6 @@ form {
} }
> label.checkbox { > label.checkbox {
display: none;
position: relative; position: relative;
width: em(40); width: em(40);
height: em(40); height: em(40);

View file

@ -12,13 +12,13 @@ table {
th { th {
border-bottom: 1px solid darken($base-border-color, 15%); border-bottom: 1px solid darken($base-border-color, 15%);
font-weight: bold; font-weight: bold;
padding: ($base-line-height / 2) 0; padding: 0.5em 0;
text-align: left; text-align: left;
} }
td { td {
border-bottom: 1px solid $base-border-color; border-bottom: 1px solid $base-border-color;
padding: ($base-line-height / 2) 0; padding: 0.5em 0;
} }
tr, td, th { tr, td, th {
@ -41,4 +41,4 @@ table.striped > tbody {
> tr:nth-child(2n) td { > tr:nth-child(2n) td {
background-color: transparentize($light-blue, 0.9); background-color: transparentize($light-blue, 0.9);
} }
} }

View file

@ -27,7 +27,7 @@ ul.navigation {
> li { > li {
float: left; float: left;
width: (100%/7); width: (100%/7);
border-right: em(1) solid transparent; border-right: 0.1em solid transparent;
.count { .count {
float: right; float: right;

View file

@ -144,3 +144,50 @@ table.brackets {
width: em(150); width: em(150);
} }
} }
/*
Contest Page
*/
#contest {
table.weeks {
.week {
width: 50%;
}
.date {
width: 30%;
}
.score {
width: 10%;
text-align: right;
}
}
table.matches {
.team {
width: 50%;
}
.date {
width: 50%;
text-align: right;
}
}
table.predictions {
.user {
width: 50%;
}
.result {
width: 50%;
text-align: right;
}
}
}

View file

@ -141,10 +141,47 @@ div#match {
@include span-columns(12); @include span-columns(12);
margin: em(20) 0 em(40); margin: em(20) 0 em(40);
h3 {
text-align: center;
margin-bottom: 1em;
}
i { i {
color: $gold; color: $gold;
} }
.team-1,
.team-2 {
position: relative;
.player {
@include span-columns(12);
line-height: em(40);
margin-bottom: em(10);
}
.players {
position: relative;
}
.controls {
top: 0;
position: absolute;
z-index: 100;
input {
margin: 0;
}
}
form {
label.checkbox {
padding: 0;
}
}
}
.team-1 { .team-1 {
@include span-columns(6); @include span-columns(6);
text-align: right; text-align: right;
@ -152,16 +189,64 @@ div#match {
.flag { .flag {
margin: 0 0 0 em(10); margin: 0 0 0 em(10);
} }
.controls {
left: 0;
}
form {
label.checkbox {
float: right;
margin-left: 1em;
}
}
} }
.team-2 { .team-2 {
@include span-columns(6); @include span-columns(6);
@include omega; @include omega;
.controls {
right: 0;
}
form {
label.checkbox {
float: left;
margin-right: 1em;
}
}
} }
&.shift .team-2 { &.shift .team-2 {
@include shift(6); @include shift(6);
} }
.mercenaries {
@include span-columns(12);
input {
margin: 0;
}
}
}
.scoring {
@include span-columns(12);
border-top: em(3) solid $light-gray;
h3 {
margin-bottom: 1em;
}
.scores input {
width: auto;
margin-left: 0;
text-align: center;
width: em(40);
}
} }
.predictions { .predictions {
@ -209,6 +294,16 @@ div#match {
margin: em(20) 0; margin: em(20) 0;
padding-top: em(20); padding-top: em(20);
border-top: em(3) solid $light-gray; border-top: em(3) solid $light-gray;
textarea {
margin: em(20) 0;
width: 100%;
height: em(600);
}
.mceLayout {
margin: em(20) 0;
}
} }
} }

View file

@ -51,15 +51,15 @@
</h3> </h3>
<% if @contest.weeks.count > 0 %> <% if @contest.weeks.count > 0 %>
<table class="data"> <table class="striped weeks">
<% @contest.weeks.ordered.each do |week| %> <% @contest.weeks.ordered.each do |week| %>
<% next if week.matches.realfinished.size == 0 %> <% next if week.matches.realfinished.size == 0 %>
<tr> <tr>
<th><%= week.name %></th> <th class="week"><%= week.name %></th>
<th>Date</th> <th class="date">Date</th>
<th>Score</th> <th class="score">Score</th>
<% if @contest.contest_type == Contest::TYPE_LADDER %> <% if @contest.contest_type == Contest::TYPE_LADDER %>
<th>Points</th> <th class="points">Points</th>
<% end %> <% end %>
</tr> </tr>
<% week.matches.realfinished.ordered.reverse_each do |match| %> <% week.matches.realfinished.ordered.reverse_each do |match| %>
@ -72,14 +72,14 @@
<td> <td>
<%= shorttime match.match_time %> <%= shorttime match.match_time %>
</td> </td>
<td> <td class="score">
<%= link_to match, :class => "bold #{match.score_color}" do %> <%= link_to match, :class => "bold #{match.score_color}" do %>
<b><%= h match.score1 %> - <%= h match.score2 %></b> <b><%= h match.score1 %> - <%= h match.score2 %></b>
<% end %> <% end %>
</td> </td>
<% if @contest.contest_type == Contest::TYPE_LADDER %> <% if @contest.contest_type == Contest::TYPE_LADDER %>
<td> <td class="points">
<%= match.points1 %> / <%= match.points2 %> <%= match.points1 %> / <%= match.points2 %>
</td> </td>
<% end %> <% end %>
@ -88,13 +88,13 @@
<% end %> <% end %>
</table> </table>
<% else %> <% else %>
<table class="data"> <table class="striped teams">
<tr> <tr>
<th>Teams</th> <th class="team">Teams</th>
<th>Date</th> <th class="date">Date</th>
<th>Score</th> <th class="score">Score</th>
<% if @contest.contest_type == Contest::TYPE_LADDER %> <% if @contest.contest_type == Contest::TYPE_LADDER %>
<th>Points</th> <th class="points">Points</th>
<% end %> <% end %>
</tr> </tr>
@ -129,10 +129,10 @@
Matches to be played Matches to be played
</h3> </h3>
<table class="data"> <table class="striped matches">
<tr> <tr>
<th>Teams</th> <th class="team">Teams</th>
<th>Date</th> <th class="date">Date</th>
</tr> </tr>
<% @contest.matches.unfinished.ordered.reverse_each do |match| %> <% @contest.matches.unfinished.ordered.reverse_each do |match| %>
@ -142,7 +142,7 @@
vs vs
<%= namelink match.contester2.team if match.contester2 %> <%= namelink match.contester2.team if match.contester2 %>
</td> </td>
<td> <td class="date">
<%= link_to shorttime(match.match_time), match %> <%= link_to shorttime(match.match_time), match %>
</td> </td>
</tr> </tr>
@ -152,22 +152,22 @@
</div> </div>
<div class="tab" id="predictions"> <div class="tab" id="predictions">
<table class="data"> <table class="striped predictions">
<tr> <tr>
<th>User</th> <th class="user">User</th>
<th>Result</th> <th class="result">Result</th>
</tr> </tr>
<% @contest.preds_with_score.each do |prediction| %> <% @contest.preds_with_score.each do |prediction| %>
<tr> <tr>
<td><%= namelink prediction.user %></td> <td><%= namelink prediction.user %></td>
<td><%= prediction.correct %> / <%= prediction.total %> correct (<%= prediction.score.to_f.round(2) %>%)</td> <td class="result"><%= prediction.correct %> / <%= prediction.total %> correct (<%= prediction.score.to_f.round(2) %>%)</td>
</tr> </tr>
<% end %> <% end %>
</table> </table>
</div> </div>
<div class="tab" id="maps"> <div class="tab" id="maps">
<ul> <ul class="disc">
<% @contest.maps.each do |map| %> <% @contest.maps.each do |map| %>
<li><%= map %></li> <li><%= map %></li>
<% end %> <% end %>

View file

@ -1,4 +1,4 @@
<h1><%= cuser ? "New Issue" : "Contact" %></h1> <h1 class="title"><%= cuser ? "New Issue" : "Contact" %></h1>
<p>Please do not forget to include contact details, such as an email address or a Steam account in the case that you do not have an ENSL account.</p> <p>Please do not forget to include contact details, such as an email address or a Steam account in the case that you do not have an ENSL account.</p>

View file

@ -1,38 +1,38 @@
<div class="wide box"> <div class="wide box">
<%= form_for @match do |f| %> <%= form_for @match, html: { class: 'square' } do |f| %>
<%= f.error_messages %> <%= f.error_messages %>
<%= f.hidden_field :contest_id %> <%= f.hidden_field :contest_id %>
<p> <div class="fields horizontal">
<%= f.label :contester1_id, "Team #1" %><br /> <%= f.label :contester1_id, "Team #1" %>
<%= f.select :contester1_id, @match.contest.contesters.active.collect{|c| ["#{c.team.name}", c.id]} %> <%= f.select :contester1_id, @match.contest.contesters.active.collect{|c| ["#{c.team.name}", c.id]} %>
</p> </div>
<p> <div class="fields horizontal">
<%= f.label :contester2_id, "Team #2" %><br /> <%= f.label :contester2_id, "Team #2" %>
<%= f.select :contester2_id, @match.contest.contesters.active.collect{|c| ["#{c.team.name}", c.id]} %> <%= f.select :contester2_id, @match.contest.contesters.active.collect{|c| ["#{c.team.name}", c.id]} %>
</p> </div>
<p> <div class="fields horizontal">
<%= f.label :map1_id, "Team 1's map" %><br /> <%= f.label :map1_id, "Map #1" %>
<%= f.select :map1_id, @match.contest.maps.basic.collect{|m| [m.name, m.id]} %> <%= f.select :map1_id, @match.contest.maps.basic.collect{|m| [m.name, m.id]} %>
</p> </div>
<p> <div class="fields horizontal">
<%= f.label :map2_id, "Team 2's map" %><br /> <%= f.label :map2_id, "Map #2" %>
<%= f.select :map2_id, @match.contest.maps.basic.collect{|m| [m.name, m.id]} %> <%= f.select :map2_id, @match.contest.maps.basic.collect{|m| [m.name, m.id]} %>
</p> </div>
<p> <div class="fields horizontal">
<%= f.label :match_time %><br /> <%= f.label :match_time %>
<%= f.datetime_select :match_time %> <%= f.datetime_select :match_time, datetime_separator: '', time_separator: '' %>
</p> </div>
<p> <div class="fields horizontal">
<%= f.label :referee_id %><br /> <%= f.label :referee_id %>
<%= f.select :referee_id, Group.find(Group::REFEREES).users.collect{|u| [u, u.id]}, {:include_blank => true} %> <%= f.select :referee_id, Group.find(Group::REFEREES).users.collect{|u| [u, u.id]}, {:include_blank => true} %>
</p> </div>
<p> <div class="fields horizontal">
<%= f.label :week_id %><br /> <%= f.label :week_id %>
<%= f.select :week_id, @match.contest.weeks.ordered.collect{|w| [w, w.id]}, {:include_blank => true} %> <%= f.select :week_id, @match.contest.weeks.ordered.collect{|w| [w, w.id]}, {:include_blank => true} %>
</p> </div>
<p> <div class="controls">
<%= f.submit 'Save' %> <%= f.submit 'Save Match' %>
</p> </div>
<% end %> <% end %>
</div> </div>

View file

@ -1,46 +1,49 @@
<h4> <div class="players">
<%= namelink contester.team %> <% contester.lineup.each do |teamer| %>
</h4> <div class="player fields">
<% if matcher = @match.matchers.first(conditions: { user_id: teamer.user_id }) %>
<%= hidden_field_tag "match[matchers_attributes][#{@n}][id]", matcher.id %>
<% end %>
<div class="left"><h5>Team members</h5> <%= hidden_field_tag "match[matchers_attributes][#{@n}][user_id]", teamer.user_id %>
<% contester.lineup.each do |teamer| %> <%= hidden_field_tag "match[matchers_attributes][#{@n}][contester_id]", contester.id %>
<p> <%= hidden_field_tag "match[matchers_attributes][#{@n}][match_id]", @match.id %>
<% if matcher = @match.matchers.first(:conditions => {:user_id => teamer.user_id}) %> <%= hidden_field_tag "match[matchers_attributes][#{@n}][merc]", false %>
<%= hidden_field_tag "match[matchers_attributes][#{@n}][id]", matcher.id %> <%= check_box_tag "match[matchers_attributes][#{@n}][_destroy]", "keep", @match.users.exists?(teamer.user), { id: "player_#{@n}" } %>
<% end %>
<%= hidden_field_tag "match[matchers_attributes][#{@n}][user_id]", teamer.user_id %> <%= label_tag "player_#{@n}", '', class: 'checkbox' %>
<%= hidden_field_tag "match[matchers_attributes][#{@n}][contester_id]", contester.id %>
<%= hidden_field_tag "match[matchers_attributes][#{@n}][match_id]", @match.id %> <span><%= teamer.user %></span>
<%= hidden_field_tag "match[matchers_attributes][#{@n}][merc]", false %> </div>
<%= check_box_tag "match[matchers_attributes][#{@n}][_destroy]", "keep", @match.users.exists?(teamer.user) %>
<%= teamer.user %> <% @n = @n + 1 %>
</p>
<% @n = @n + 1; end %>
</div>
<div class ="center">
<% if contester.team.logo %>
<%= image_tag contester.team.logo.url%>
<% end %> <% end %>
</div> </div>
<div class="right"><h5>Mercenaries</h5>
<div class="mercenaries">
<% @match.matchers.mercs.of_contester(contester).each do |matcher| %> <% @match.matchers.mercs.of_contester(contester).each do |matcher| %>
<p> <div class="player fields">
<%= hidden_field_tag "match[matchers_attributes][#{@n}][id]", matcher.id %> <%= hidden_field_tag "match[matchers_attributes][#{@n}][id]", matcher.id %>
<%= hidden_field_tag "match[matchers_attributes][#{@n}][user_id]", matcher.user_id %> <%= hidden_field_tag "match[matchers_attributes][#{@n}][user_id]", matcher.user_id %>
<%= hidden_field_tag "match[matchers_attributes][#{@n}][contester_id]", contester.id %> <%= hidden_field_tag "match[matchers_attributes][#{@n}][contester_id]", contester.id %>
<%= hidden_field_tag "match[matchers_attributes][#{@n}][match_id]", @match.id %> <%= hidden_field_tag "match[matchers_attributes][#{@n}][match_id]", @match.id %>
<%= hidden_field_tag "match[matchers_attributes][#{@n}][merc]", true %> <%= hidden_field_tag "match[matchers_attributes][#{@n}][merc]", true %>
<%= check_box_tag "match[matchers_attributes][#{@n}][_destroy]", "keep", true %> <%= check_box_tag "match[matchers_attributes][#{@n}][_destroy]", "keep", true, { id: "player_#{@n}" } %>
<%= matcher.user %>
</p>
<% @n = @n + 1; end %>
<p> <%= label_tag "player_#{@n}", '', class: 'checkbox' %>
<%= hidden_field_tag "match[matchers_attributes][#{@n}][contester_id]", contester.id %>
<%= hidden_field_tag "match[matchers_attributes][#{@n}][match_id]", @match.id %> <span><%= matcher.user %></span>
<%= hidden_field_tag "match[matchers_attributes][#{@n}][merc]", true %> </div>
<%= hidden_field_tag "match[matchers_attributes][#{@n}][_destroy]", "keep" %>
<%= link_to_function 'Merc', "findUser('match[matchers_attributes][#{@n}][merc][user_id]')" %>: <% @n = @n + 1 %>
<%= text_field_tag "match[matchers_attributes][#{@n}][user_id]", '', :size => 5 %> <% end %>
</p>
<div class="fields">
<%= hidden_field_tag "match[matchers_attributes][#{@n}][contester_id]", contester.id %>
<%= hidden_field_tag "match[matchers_attributes][#{@n}][match_id]", @match.id %>
<%= hidden_field_tag "match[matchers_attributes][#{@n}][merc]", true %>
<%= hidden_field_tag "match[matchers_attributes][#{@n}][_destroy]", "keep" %>
<%= text_field_tag "match[matchers_attributes][#{@n}][user_id]", '', placeholder: 'Mercenary' %>
</div> </div>
</div>

View file

@ -1,6 +1,3 @@
<h1>Editing match</h1> <h1>Editing Match</h1>
<%= render :partial => "form" %> <%= render partial: 'form' %>
<%= link_to 'Show', @match %> |
<%= link_to 'Back', edit_contest_path(@match.contest) %>

View file

@ -1,5 +1,3 @@
<h1>New match</h1> <h1>New Match</h1>
<%= render :partial => "form" %> <%= render partial: 'form' %>
<%= link_to 'Back', matches_path %>

View file

@ -1,98 +1,104 @@
<h2> <div id="match">
<%= namelink @match.contester1.team %> vs <%= namelink @match.contester2.team %> <h1 class="fancy title">
</h2> <span>Referee Admin</span>
</h1>
<%= render :partial => "javascripts/mce_full" %> <div class="contesters">
<h1 class="team-1"><%= namelink @match.contester1.team if @match.contester1 %></h1>
<div class="versus">
<span class="vs">VS</span>
</div>
<h1 class="team-2"><%= namelink @match.contester2.team if @match.contester2 %></h1>
</div>
<div class="wide box"> <%= render partial: 'javascripts/mce_full' %>
<h2>
Lineup
</h2>
<div class="box center"> <div class="lineups">
<h3>Lineups</h3>
<div class="team-1">
<%= form_for @match do |f| %>
<%= f.error_messages %>
<div class="controls">
<%= f.submit 'Save Lineup' %>
</div>
<% [@match.contester1].each do |contester| %>
<%= render partial: "lineup", locals: { contester: contester } %>
<% end %>
<% end %>
</div>
<div class="team-2">
<%= form_for @match do |f| %>
<%= f.error_messages %>
<div class="controls">
<%= f.submit 'Save Lineup' %>
</div>
<% [@match.contester2].each do |contester| %>
<%= render partial: "lineup", locals: { contester: contester } %>
<% end %>
<% end %>
</div>
</div>
<div class="scoring">
<%= form_for @match, html: { class: 'square' } do |f| %>
<%= f.error_messages %>
<h3>Scoring</h3>
<div class="fields horizontal">
<%= f.label :server_id %>
<%= f.select :server_id, Server.active.collect { |d| ["#{d.name}", d.id] }, { include_blank: true } %>
</div>
<div class="fields horizontal">
<%= f.label :forfeit %>
<%= f.check_box :forfeit %>
<%= f.label :forfeit, class: 'checkbox' %>
</div>
<div class="fields horizontal">
<%= f.label "Scores" %>
<div class="inputs scores">
<%= f.text_field :score1, size: 1 %>
<%= f.text_field :score2, size: 2 %>
</div>
</div>
<div class="fields horizontal">
<%= f.label :demo %>
<div class="inputs">
<%= f.select :demo_id, DataFile.ordered.collect { |d| ["#{d.name}", d.id] }, { include_blank: true } %>
</div>
</div>
<div class="fields horizontal">
<%= f.label 'Player of the match' %>
<%= f.text_field :motm_name, { value: User.get(@match.motm_id) } %>
</div>
<div class="controls">
<%= f.submit 'Save Scores' %>
</div>
<% end %>
</div>
<div class="report">
<%= form_for @match do |f| %> <%= form_for @match do |f| %>
<%= f.error_messages %> <%= f.error_messages %>
<% [@match.contester1].each do |contester| %> <h3>Match Report</h3>
<%= render :partial => "lineup", :locals => {:contester => contester} %>
<%= f.text_area :report %>
<div class="controls">
<%= f.submit 'Save Report' %>
</div>
<% end %> <% end %>
<p class="clear"> </div>
<%= f.submit "Save" %> </div>
</p>
<% end %>
</div>
<div class="box center">
<%= form_for @match do |f| %>
<%= f.error_messages %>
<% [@match.contester2].each do |contester| %>
<%= render :partial => "lineup", :locals => {:contester => contester} %>
<% end %>
<p class="clear">
<%= f.submit "Save" %>
</p>
<% end %>
</div>
<p class="clear"></p>
</div>
<div class="wide box">
<%= form_for @match do |f| %>
<%= f.error_messages %>
<h3>
Scoring and options
</h3>
<p>
<%= f.label :server_id %>
<%= f.select :server_id, Server.hlds.active.collect{|d| ["#{d.name}", d.id]}, {:include_blank => true} %>
</p>
<p>
<%= f.label :forfeit %>
<%= f.check_box :forfeit %>
</p>
<p>
Score:
<%= f.text_field :score1, :size => 1 %>
<%= f.text_field :score2, :size => 2 %>
</p>
<p>
<%= f.label :demo %>:
<%= f.select :demo_id, DataFile.ordered.collect{|d| ["#{d.name}", d.id]}, {:include_blank => true} %>
</p>
<p>
<%= link_to_function 'Man of the match', "findUser('motm')" %>:
<%= f.text_field :motm_name, {:value => User.get(@match.motm_id)} %>
</p>
<p>
<%= f.submit "Save" %>
</p>
<% end %>
</div>
<div class="wide box">
<%= form_for @match do |f| %>
<%= f.error_messages %>
<h3>
Report
</h3>
<p>
<%= f.text_area :report, :rows => 20, :cols => 60 %>
</p>
<p>
<%= f.submit "Save" %>
</p>
<% end %>
</div>
<%= link_to "Back", @match %>

View file

@ -5,6 +5,10 @@ Ensl::Application.routes.draw do
resources :versions resources :versions
end end
match 'contests/del_map'
match 'contests/scores'
match 'contests/historical', to: "contests#historical"
resources :contests do resources :contests do
get 'current', on: :collection get 'current', on: :collection
end end
@ -71,16 +75,12 @@ Ensl::Application.routes.draw do
match 'news/admin', to: "articles#admin" match 'news/admin', to: "articles#admin"
match 'articles/cleanup' match 'articles/cleanup'
match 'contests/historical', to: "contests#historical"
match 'data_files/admin' match 'data_files/admin'
match 'data_files/addFile' match 'data_files/addFile'
match 'data_files/delFile' match 'data_files/delFile'
match 'data_files/trash' match 'data_files/trash'
match 'contesters/recalc' match 'contesters/recalc'
match 'contests/scores'
match 'contests/del_map'
match 'directories', to: "directories#show", id: 1 match 'directories', to: "directories#show", id: 1