Completed restyling:

- Bans
- Articles
- Forums
- Users

Further styling improvements to form elements
This commit is contained in:
Luke Barratt 2014-04-20 02:29:52 +01:00
parent 6f56bf81fd
commit 5cd2d098a0
33 changed files with 575 additions and 475 deletions

View file

@ -53,3 +53,5 @@
@import "pages/teams"; @import "pages/teams";
@import "pages/users"; @import "pages/users";
@import "pages/matches"; @import "pages/matches";
@import "pages/files";
@import "pages/bans";

View file

@ -57,6 +57,9 @@ form {
display: block; display: block;
width: auto; width: auto;
position: relative; position: relative;
line-height: em(22);
vertical-align: middle;
max-height: em(36);
margin-left: 0; margin-left: 0;
border: 0; border: 0;
margin: 0; margin: 0;
@ -139,42 +142,46 @@ form {
font-family: $open-sans; font-family: $open-sans;
} }
input[type=checkbox] { > label.checkbox {
@include appearance(none); display: none;
position: relative;
width: em(40);
height: em(40);
overflow: hidden;
&:before {
@include box-sizing(border-box);
content: "";
display: block;
border-radius: $input-border-radius; border-radius: $input-border-radius;
width: em(40); width: em(40);
height: em(40); height: em(40);
font-size: $input-font-size;
padding: $input-padding; padding: $input-padding;
background-color: $input-primary; background-color: $input-primary;
border: $input-border-colour solid $input-border-width; border: $input-border-colour solid $input-border-width;
position: relative;
margin: 0; margin: 0;
float: left;
&:focus {
outline: none;
} }
&:hover { &:hover {
&:before {
border: $input-border-width solid lighten($input-secondary, 20%); border: $input-border-width solid lighten($input-secondary, 20%);
cursor: pointer; }
}
} }
&:checked { input[type=checkbox] {
border-color: $button-secondary; display: none;
&:after { &:checked {
& + label.checkbox:before {
content: $fa-var-check; content: $fa-var-check;
pointer-events: none; pointer-events: none;
font-family: $fontawesome; font-family: $fontawesome;
font-weight: normal; font-weight: normal;
font-style: normal; font-style: normal;
position: absolute; color: $light-blue;
font-size: em(22);
top: em(4);
left: em(5);
color: $button-secondary;
} }
} }
} }
@ -258,6 +265,11 @@ form.square {
@include span-columns(3); @include span-columns(3);
padding: em(11) 0; padding: em(11) 0;
line-height: em(16); line-height: em(16);
&.checkbox {
width: em(40);
padding: 0;
}
} }
input[type=text], input[type=text],
@ -277,7 +289,6 @@ form.square {
} }
} }
&.wide { &.wide {
> .field_with_errors { > .field_with_errors {

View file

@ -26,13 +26,17 @@ tr, td, th {
} }
table.striped > tbody { table.striped > tbody {
> tr > td:first-child { > tr {
td:first-child,
th:first-child {
padding-left: ($base-line-height / 2); padding-left: ($base-line-height / 2);
} }
> tr > td:last-child { td:last-child,
th:last-child {
padding-right: ($base-line-height / 2); padding-right: ($base-line-height / 2);
} }
}
> 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

@ -21,7 +21,6 @@ ul.navigation {
float: left; float: left;
width: 100%; width: 100%;
background: transparent; background: transparent;
overflow: hidden;
max-width: $max-width; max-width: $max-width;
max-height: em(60); max-height: em(60);

View file

@ -0,0 +1,23 @@
/*
Bans List
*/
#bans {
h1 {
margin-bottom: 1em;
}
table.bans {
.type,
.expiry {
width: 20%;
}
.actions {
width: 10%;
text-align: right;
}
}
}

View file

@ -0,0 +1,12 @@
/*
File Page
*/
#file {
.actions,
.files-list {
@include span-columns(12);
margin: em(20) 0;
}
}

View file

@ -176,3 +176,22 @@ div#categories {
} }
} }
} }
/*
Forms
*/
#forums .add-acl {
h4 {
margin: 1em 0;
}
.permissions,
.controls {
display: inline;
width: auto;
float: none;
}
}

View file

@ -88,3 +88,19 @@ form.article {
margin-bottom: em(20); margin-bottom: em(20);
} }
} }
.files {
.files-list {
margin: em(20) 0 em(40);
}
form {
@include span-columns(12);
margin: em(20) 0;
.fields {
margin-bottom: em(20);
}
}
}

View file

@ -96,6 +96,17 @@
} }
} }
#profile-edit {
h1 {
margin-bottom: 1em;
}
form {
margin-top: 0;
}
}
/* /*
Agenda Agenda
*/ */
@ -172,3 +183,23 @@
margin-top: em(20); margin-top: em(20);
} }
} }
/*
Staff List
*/
table.staff {
table-layout: auto;
.country {
width: 6%;
}
.username {
width: 20%;
}
.age {
width: 5%;
}
}

View file

@ -1,6 +1,7 @@
class PostsController < ApplicationController class PostsController < ApplicationController
before_filter :get_post, except: [:new, :create] before_filter :get_post, except: [:new, :create]
respond_to :html, :js respond_to :html, :js
layout 'forums'
def quote def quote
raise AccessError unless @post.can_show? cuser raise AccessError unless @post.can_show? cuser
@ -10,7 +11,6 @@ class PostsController < ApplicationController
@post = Post.new @post = Post.new
@post.topic = Topic.find(params[:id]) @post.topic = Topic.find(params[:id])
raise AccessError unless @post.can_create? cuser raise AccessError unless @post.can_create? cuser
render layout: 'forums'
end end
def edit def edit
@ -28,8 +28,7 @@ class PostsController < ApplicationController
flash[:notice] = t(:posts_create) flash[:notice] = t(:posts_create)
format.js { render } format.js { render }
else else
flash[:error] = t(:posts_invalid) + @post.errors.full_messages.to_s format.html { render :new }
format.html { return_to }
end end
end end
end end

View file

@ -1,5 +1,6 @@
class TopicsController < ApplicationController class TopicsController < ApplicationController
before_filter :get_topic, only: [:show, :reply, :edit, :update, :destroy] before_filter :get_topic, only: [:show, :reply, :edit, :update, :destroy]
layout 'forums'
def index def index
render partial: true, locals: {page: params[:p].to_i} render partial: true, locals: {page: params[:p].to_i}
@ -18,7 +19,6 @@ class TopicsController < ApplicationController
@newpost.topic = @topic @newpost.topic = @topic
@newpost.user = cuser @newpost.user = cuser
@lock = (@topic.lock ? @topic.lock : Lock.new(:lockable => @topic)) @lock = (@topic.lock ? @topic.lock : Lock.new(:lockable => @topic))
render layout: 'forums'
end end
def reply def reply
@ -27,7 +27,7 @@ class TopicsController < ApplicationController
if request.xhr? if request.xhr?
render 'quickreply', layout: false render 'quickreply', layout: false
else else
render layout: 'forums' render
end end
end end
@ -35,12 +35,10 @@ class TopicsController < ApplicationController
@topic = Topic.new @topic = Topic.new
@topic.forum = Forum.find(params[:id]) @topic.forum = Forum.find(params[:id])
raise AccessError unless @topic.can_create? cuser raise AccessError unless @topic.can_create? cuser
render layout: 'forums'
end end
def edit def edit
raise AccessError unless @topic.can_update? cuser raise AccessError unless @topic.can_update? cuser
render layout: 'forums'
end end
def create def create

View file

@ -27,7 +27,7 @@
<div class="tabbed-contents"> <div class="tabbed-contents">
<div class="tab" id="admins"> <div class="tab" id="admins">
<h3>Admins</h3> <h3>Admins</h3>
<table class="data"> <table class="striped staff">
<tr> <tr>
<th></th> <th></th>
<th>Username</th> <th>Username</th>
@ -36,9 +36,9 @@
<th>Age</th> <th>Age</th>
</tr> </tr>
<% Group.admins.each do |grouper| %> <% Group.admins.each do |grouper| %>
<tr class="<%= cycle('even', 'odd') %>"> <tr>
<td><%= flag grouper.user.country %></td> <td class="country"><%= flag grouper.user.country %></td>
<td><%= namelink grouper.user %></td> <td class="username"><%= namelink grouper.user %></td>
<td><%= h grouper.user.email_s %></td> <td><%= h grouper.user.email_s %></td>
<td> <td>
<% if grouper.task %> <% if grouper.task %>
@ -47,14 +47,14 @@
<%= h grouper.group.name.singularize %> <%= h grouper.group.name.singularize %>
<% end %> <% end %>
</td> </td>
<td><%= h grouper.user.age %></td> <td class="age"><%= h grouper.user.age %></td>
</tr> </tr>
<% end %> <% end %>
</table> </table>
</div> </div>
<div class="tab" id="referees"> <div class="tab" id="referees">
<h3>Referees</h3> <h3>Referees</h3>
<table class="data"> <table class="striped staff">
<tr> <tr>
<th></th> <th></th>
<th>Username</th> <th>Username</th>
@ -63,9 +63,9 @@
<th>Age</th> <th>Age</th>
</tr> </tr>
<% Group.referees.each do |grouper| %> <% Group.referees.each do |grouper| %>
<tr class="<%= cycle('even', 'odd') %>"> <tr>
<td><%= flag grouper.user.country %></td> <td class="country"><%= flag grouper.user.country %></td>
<td><%= namelink grouper.user %></td> <td class="username"><%= namelink grouper.user %></td>
<td><%= h grouper.user.email_s %></td> <td><%= h grouper.user.email_s %></td>
<td> <td>
<% if grouper.task %> <% if grouper.task %>
@ -74,14 +74,14 @@
<%= h grouper.group.name.singularize %> <%= h grouper.group.name.singularize %>
<% end %> <% end %>
</td> </td>
<td><%= h grouper.user.age %></td> <td class="age"><%= h grouper.user.age %></td>
</tr> </tr>
<% end %> <% end %>
</table> </table>
</div> </div>
<div class="tab" id="casters"> <div class="tab" id="casters">
<h3>Shoutcasters</h3> <h3>Shoutcasters</h3>
<table class="data"> <table class="striped staff">
<tr> <tr>
<th></th> <th></th>
<th>Username</th> <th>Username</th>
@ -90,9 +90,9 @@
<th>Age</th> <th>Age</th>
</tr> </tr>
<% Group.shoutcasters.each do |grouper| %> <% Group.shoutcasters.each do |grouper| %>
<tr class="<%= cycle('even', 'odd') %>"> <tr>
<td><%= flag grouper.user.country %></td> <td class="country"><%= flag grouper.user.country %></td>
<td><%= namelink grouper.user %></td> <td class="username"><%= namelink grouper.user %></td>
<td><%= h grouper.user.email_s %></td> <td><%= h grouper.user.email_s %></td>
<td> <td>
<% if grouper.task %> <% if grouper.task %>
@ -101,14 +101,14 @@
<%= h grouper.group.name.singularize %> <%= h grouper.group.name.singularize %>
<% end %> <% end %>
</td> </td>
<td><%= h grouper.user.age %></td> <td class="age"><%= h grouper.user.age %></td>
</tr> </tr>
<% end %> <% end %>
</table> </table>
</div> </div>
<div class="tab" id="extras"> <div class="tab" id="extras">
<h3>Extras</h3> <h3>Extras</h3>
<table class="data"> <table class="striped staff">
<tr> <tr>
<th></th> <th></th>
<th>Username</th> <th>Username</th>
@ -118,8 +118,8 @@
</tr> </tr>
<% Group.extras.each do |grouper| %> <% Group.extras.each do |grouper| %>
<tr> <tr>
<td><%= flag grouper.user.country %></td> <td class="country"><%= flag grouper.user.country %></td>
<td><%= namelink grouper.user %></td> <td class="username"><%= namelink grouper.user %></td>
<td><%= h grouper.user.email_s %></td> <td><%= h grouper.user.email_s %></td>
<td> <td>
<% if grouper.task %> <% if grouper.task %>
@ -128,7 +128,7 @@
<%= h grouper.group.name.singularize %> <%= h grouper.group.name.singularize %>
<% end %> <% end %>
</td> </td>
<td><%= h grouper.user.age %></td> <td class="age"><%= h grouper.user.age %></td>
</tr> </tr>
<% end %> <% end %>
</table> </table>
@ -141,7 +141,8 @@
</div> </div>
</div> </div>
</div> </div>
<script type="text/javascript"> <script type="text/javascript">
new Yetii({id: 'staff'}); new Yetii({
</script> id: 'staff'
});
</script>

View file

@ -35,12 +35,13 @@
<% end %> <% end %>
<% unless @article.new_record? %> <% unless @article.new_record? %>
<h2>Files</h2> <div class="files">
<h4>Files</h4>
<%= render partial: "data_files/list", locals: { files: @article.files } %> <%= render partial: "data_files/list", locals: { files: @article.files } %>
<% if @file && @file.can_create?(cuser) %> <% if @file && @file.can_create?(cuser) %>
<h4>New file</h4> <h4>New File</h4>
<%= form_for @file, html: { multipart: true } do |f| %> <%= form_for @file, html: { multipart: true } do |f| %>
<%= render 'shared/errors', messages: @file.errors.full_messages %> <%= render 'shared/errors', messages: @file.errors.full_messages %>
@ -48,10 +49,13 @@
<%= f.hidden_field :directory_id %> <%= f.hidden_field :directory_id %>
<%= f.hidden_field :article_id %> <%= f.hidden_field :article_id %>
<p> <div class="fields">
<%= f.file_field :name %> <%= f.file_field :name %>
</div>
<div class="controls">
<%= f.submit 'Create' %> <%= f.submit 'Create' %>
</p> </div>
<% end %> <% end %>
<% end %> <% end %>
</div>
<% end %> <% end %>

View file

@ -1,3 +1 @@
<%= render partial: "form" %> <%= render partial: "form" %>
<%= link_to 'Show', @article, class: 'button' %>

View file

@ -1,7 +1,6 @@
<div class="box wide"> <h1>Articles</h1>
<h2>Articles</h2>
<% @categories.each do |category| %> <% @categories.each do |category| %>
<h3> <h3>
<%= category.name %> <%= category.name %>
</h3> </h3>
@ -20,12 +19,8 @@
<br class="clear" /> <br class="clear" />
</div> </div>
<% end %> <% end %>
<% end %> <% end %>
<br />
</div>
<% if Article.new.can_create? cuser %> <% if Article.new.can_create? cuser %>
<p> <%= link_to 'New Article', new_article_path, class: 'button' %>
<%= link_to 'New article', new_article_path %>
</p>
<% end %> <% end %>

View file

@ -1,3 +1 @@
<%= render :partial => "form" %> <%= render :partial => "form" %>
<%= link_to 'Back', articles_path %>

View file

@ -1,35 +1,29 @@
<div class="wide box"> <%= form_for @ban, html: { class: 'square' } do |f| %>
<%= form_for(@ban) do |f| %> <%= render 'shared/errors', messages: @ban.errors.full_messages %>
<div id="error_explanation">
<ul>
<% @ban.errors.full_messages.each do |msg| %>
<li><%= msg %></li>
<% end %>
</ul>
</div>
<p> <div class="fields horizontal">
<%= link_to_function 'User', "findUser('ban[user_name]')" %><br /> <%= f.label :user_name %>
<%= f.text_field :user_name, {:value => @ban.user.to_s} %> <%= f.text_field :user_name, { value: @ban.user.to_s } %>
</p> </div>
<p> <div class="fields horizontal">
<%= f.label :ban_type %><br /> <%= f.label :ban_type %>
<%= f.select :ban_type, @ban.types.invert %> <%= f.select :ban_type, @ban.types.invert %>
</p> </div>
<p> <div class="fields horizontal">
<%= f.label :steamid %><br /> <%= f.label :steamid %>
<%= f.text_field :steamid %> <%= f.text_field :steamid %>
</p> </div>
<p> <div class="fields horizontal">
<%= f.label :expiry %><br /> <%= f.label :expiry %>
<%= f.datetime_select :expiry %> <%= f.datetime_select :expiry, datetime_separator: '', time_separator: '' %>
</p> </div>
<p> <div class="fields horizontal">
<%= f.label :reason %> <%= bbcode %><br /> <%= f.label :reason do %>
<%= f.text_area :reason %> Reason (<em>BB Code</em>)
</p>
<p>
<%= f.submit 'Create' %>
</p>
<% end %> <% end %>
</div> <%= f.text_area :reason %>
</div>
<div class="controls">
<%= f.submit 'Create' %>
</div>
<% end %>

View file

@ -1,11 +1,11 @@
<table class="data"> <table class="bans striped">
<tr> <tr>
<th>User</th> <th class="user">User</th>
<th>Type</th> <th class="type">Type</th>
<th>Expiry</th> <th class="expiry">Expiry</th>
<th>Reason</th> <th class="reason">Reason</th>
<% if cuser and cuser.admin? %> <% if cuser and cuser.admin? %>
<th>Actions</th> <th class="actions"></th>
<% end %> <% end %>
</tr> </tr>
@ -20,13 +20,14 @@
</td> </td>
<td><%= ban.types[ban.ban_type] %></td> <td><%= ban.types[ban.ban_type] %></td>
<td><%= shorttime ban.expiry %></td> <td><%= shorttime ban.expiry %></td>
<td><%= shorten ban.reason, 30 %> </td> <td><%= shorten ban.reason, 30 %></td>
<% if cuser and cuser.admin? %> <% if cuser and cuser.admin? %>
<td> <td class="actions">
<% if ban.can_update? cuser %> <% if ban.can_update? cuser %>
<%= link_to 'E', edit_ban_path(ban) %> <%= link_to icon('pencil'), edit_ban_path(ban) %>
<% end; if ban.can_destroy? cuser %> <% end %>
<%= link_to 'D', ban, :confirm => 'Are you sure?', :method => :delete %> <% if ban.can_destroy? cuser %>
<%= link_to icon('times'), ban, confirm: 'Are you sure?', method: :delete %>
<% end %> <% end %>
</td> </td>
<% end %> <% end %>

View file

@ -1,6 +1,3 @@
<h1>Editing ban</h1> <h1>Editing Ban</h1>
<%= render :partial => "form" %> <%= render partial: "form" %>
<%= link_to 'Show', @ban %> |
<%= link_to 'Back', bans_path %>

View file

@ -1,11 +1,14 @@
<h1>Active bans</h1> <div id="bans">
<h1>Active bans</h1>
<%= render :partial => "list", :locals => {:bans => @bans.effective} %> <%= link_to 'New ban', new_ban_path, class: 'button' %>
<br /> <%= render partial: "list", locals: { bans: @bans.effective } %>
<h1>Ban history</h1> <h1>Ban history</h1>
<%= render :partial => "list", :locals => {:bans => @bans.ineffective} %> <%= render partial: "list", locals: { bans: @bans.ineffective } %>
<%= link_to 'New ban', new_ban_path, class: 'button' %>
</div>
<%= link_to 'New ban', new_ban_path %>

View file

@ -1,5 +1,3 @@
<h1>New ban</h1> <h1>New Ban</h1>
<%= render :partial => "form" %> <%= render partial: "form" %>
<%= link_to 'Back', bans_path %>

View file

@ -1,4 +1,4 @@
<table class="data"> <table class="striped files-list">
<tr> <tr>
<th>Name</th> <th>Name</th>
<th>Path</th> <th>Path</th>
@ -7,7 +7,7 @@
</tr> </tr>
<% files.each do |file| %> <% files.each do |file| %>
<tr class="<%= cycle('even', 'odd') %>"> <tr>
<td><%= namelink file %></td> <td><%= namelink file %></td>
<td><%= h file.url %></td> <td><%= h file.url %></td>
<td><%= file.size_s %></td> <td><%= file.size_s %></td>
@ -15,7 +15,7 @@
<% if file.can_update? cuser %> <% if file.can_update? cuser %>
<%= link_to icon('pencil'), edit_data_file_path(file) %> <%= link_to icon('pencil'), edit_data_file_path(file) %>
<% end; if file.can_destroy? cuser %> <% end; if file.can_destroy? cuser %>
<%= link_to icon('times'), file, :confirm => 'Are you sure?', :method => :delete %> <%= link_to icon('times'), file, confirm: 'Are you sure?', method: :delete %>
<% end %> <% end %>
</td> </td>
</tr> </tr>

View file

@ -1,35 +1,24 @@
<div class="box wide"> <div id="file">
<h1> <h1><%=h @file %></h1>
<%= h @file %>
</h1>
<%= cascade @file, [["Filename", "name.filename".to_sym], "size_s", "directory", "md5_s", ["Modified", "created_at"]] %> <%= cascade @file, [["Filename", "name.filename".to_sym], "size_s", "directory", "md5_s", ["Modified", "created_at"]] %>
<% if cuser and cuser.admin? %> <% if cuser and cuser.admin? %>
<p> <div class="actions">
[
<% if @file.can_update? cuser %> <% if @file.can_update? cuser %>
<%= link_to 'Edit', edit_data_file_path(@file) %> <%= link_to 'Edit', edit_data_file_path(@file), class: 'button tiny' %>
<% end; if @file.can_destroy? cuser %> <% end; if @file.can_destroy? cuser %>
<%= link_to 'Destroy', @file, :confirm => 'Are you sure?', :method => :delete %> <%= link_to 'Destroy', @file, confirm: 'Are you sure?', method: :delete, class: 'button tiny' %>
<% end %> <% end %>
] </div>
</p>
<% end %> <% end %>
<br /> <%= link_to "Download", @file.url, class: 'button' %>
<h2 class="center"> <div class="files-list">
<%= link_to "Download", @file.url %> <h4>Related Files</h4>
</h2>
</div>
<div class="wide box"> <table class="striped">
<h3>
Related Files
</h3>
<table class="data">
<tr> <tr>
<th>Name</th> <th>Name</th>
<th>Size</th> <th>Size</th>
@ -53,6 +42,7 @@
</tr> </tr>
<% end %> <% end %>
</table> </table>
</div>
</div> </div>
<%= add_comments @file %> <%= add_comments @file %>

View file

@ -1,71 +1,74 @@
<div class="wide box"> <div id="forums">
<%= form_for(@forum) do |f| %> <%= form_for(@forum, html: { class: 'square' }) do |f| %>
<div id="error_explanation"> <%= render 'shared/errors', messages: @forum.errors.full_messages %>
<ul>
<% @forum.errors.full_messages.each do |msg| %>
<li><%= msg %></li>
<% end %>
</ul>
</div>
<p> <div class="fields horizontal">
<%= f.label :title %><br /> <%= f.label :title %>
<%= f.text_field :title %> <%= f.text_field :title %>
</p> </div>
<p> <div class="fields horizontal">
<%= f.label :description %><br /> <%= f.label :description %>
<%= f.text_field :description %> <%= f.text_field :description %>
</p> </div>
<p> <div class="fields horizontal">
<%= f.label :category %><br /> <%= f.label :category %>
<%= f.select :category_id, Category.domain(Category::DOMAIN_FORUMS).ordered.collect{|c| [c, c.id]} %> <%= f.select :category_id, Category.domain(Category::DOMAIN_FORUMS).ordered.collect{|c| [c, c.id]} %>
</p> </div>
<p> <div class="controls">
<%= f.submit 'Save' %> <%= f.submit 'Save' %>
</p> </div>
<% end %> <% end %>
</div>
<% unless @forum.new_record? %> <% unless @forum.new_record? %>
<div class="wide box"> <h2>Access Rights</h2>
<h2> <p>If no groups are specified, everyone is allowed for the specific access type.</p>
Access Rights
</h2>
If no groups are specified, everyone is allowed for the specific access type. <table id="acl" class="striped">
<table class="data">
<tr> <tr>
<th>Group</th> <th class="group">Group</th>
<th>Access Level</th> <th class="level">Access Level</th>
<th>Options</th> <th class="options">Options</th>
</tr> </tr>
<% @forum.forumers.each do |forumer| %> <% @forum.forumers.each do |forumer| %>
<tr class="<%= cycle('even', 'odd') %>"> <tr>
<%= form_for forumer do |g| %>
<td><%= namelink forumer.group %></td> <td><%= namelink forumer.group %></td>
<td> <td>
<%= g.select :access, forumer.accesses.invert, :size => 20 %> <%= form_for forumer do |g| %>
<div class="fields">
<%= g.select :access, forumer.accesses.invert, size: 20 %>
</div>
<% end %>
</td> </td>
<td> <td>
<%= link_to_function "Update", "$('edit_forumer_#{forumer.id}').submit()" %> <%= content_tag :a, { class: 'button tiny', data: { forumer: forumer.id } } do %>
<%= link_to "Remove", forumer, :method => :delete %> Update
</td>
<% end %> <% end %>
<%= link_to "Remove", forumer, method: :delete, class: 'button tiny' %>
</td>
</tr> </tr>
<% end %> <% end %>
</table> </table>
<%= form_for @forum.forumers.build do |f| %> <%= form_for @forum.forumers.build, html: { class: 'add-acl' } do |f| %>
<%= f.error_messages %> <%= render 'shared/errors', messages: @forum.errors.full_messages %>
<%= f.hidden_field :forum_id %> <%= f.hidden_field :forum_id %>
<p>
<%= f.label :group_id %><br /> <div class="fields permissions">
<h4>Grant Access</h4>
<%= f.select :group_id, Group.all.collect{|g| [g, g.id]} %> <%= f.select :group_id, Group.all.collect{|g| [g, g.id]} %>
<%= f.select :access, f.object.accesses.invert, :size => 20 %> <%= f.select :access, f.object.accesses.invert, :size => 20 %>
<%= f.submit "Add" %>
</p>
<% end %>
</div> </div>
<% end %> <div class="controls">
<%= f.submit "Add" %>
</div>
<% end %>
<% end %>
<script>
$('a[data-forumer]').click(function() {
$('#edit_forumer_' + $(this).data('forumer')).submit();
});
</script>
</div>

View file

@ -1,6 +1,3 @@
<h1>Editing forum</h1> <h1>Editing forum</h1>
<%= render :partial => "form" %> <%= render :partial => "form" %>
<%= link_to 'Show', @forum %> |
<%= link_to 'Back', forums_path %>

View file

@ -1,5 +1,3 @@
<h1>New Forum</h1> <h1>New Forum</h1>
<%= render partial: "form" %> <%= render partial: "form" %>
<%= link_to 'Back', forums_path, class: 'button' %>

View file

@ -20,7 +20,7 @@
</div> </div>
<div class="fields horizontal"> <div class="fields horizontal">
<%= f.label :text %> <%= f.label :text %>
<%= f.text_area :text %> <%= f.text_area :text, rows: 15 %>
</div> </div>
<div class="controls"> <div class="controls">
<%= f.submit 'Send Message' %> <%= f.submit 'Send Message' %>

View file

@ -1,13 +1,18 @@
<%= form_for(@post) do |f| %> <%= form_for(@post, html: { class: 'square' }) do |f| %>
<%= f.error_messages %> <%= render 'shared/errors', messages: @post.errors.full_messages %>
<%= f.hidden_field :topic_id %> <%= f.hidden_field :topic_id %>
<p> <div class="square horizontal">
Topic: <%= namelink @post.topic %> <%= f.label :topic %>
</p> <div class="inputs">
<p> <%= namelink @post.topic %>
<%= f.text_area :text, :rows => 15, :cols => 108 %> </div>
</p> </div>
<p> <div class="square horizontal">
<%= f.submit 'Save' %> <%= f.label :text %>
</p> <%= f.text_area :text, rows: 20 %>
</div>
<div class="controls">
<%= f.submit 'Save Post' %>
</div>
<% end %> <% end %>

View file

@ -2,4 +2,4 @@
<%= render :partial => "form" %> <%= render :partial => "form" %>
<%= link_to 'Back to topic', @post.topic %> <%= link_to 'Back to topic', @post.topic, class: 'button tiny' %>

View file

@ -1,5 +1,3 @@
<h1>New post</h1> <h1>New Post</h1>
<%= render :partial => "form" %> <%= render partial: "form" %>
<%= link_to 'Back', posts_path %>

View file

@ -1,25 +1,21 @@
<h1>Editing topic</h1> <h1>Editing Topic</h1>
<div class="wide box"> <%= form_for(@topic, html: { class: 'square' }) do |f| %>
<%= form_for(@topic) do |f| %> <%= render 'shared/errors', messages: @topic.errors.full_messages %>
<%= f.error_messages %>
<p> <div class="fields horizontal">
<%= f.label :title %><br /> <%= f.label :title %>
<%= f.text_field :title %> <%= f.text_field :title %>
</p> </div>
<p> <div class="fields horizontal">
<%= f.label :forum_id %><br /> <%= f.label :forum_id %>
<%= f.select :forum_id, Forum.all.collect{|forum| [forum, forum.id]} %> <%= f.select :forum_id, Forum.all.collect{|forum| [forum, forum.id]} %>
</p> </div>
<p> <div class="fields horizontal">
<%= f.label :state %><br /> <%= f.label :state %>
<%= f.select :state, f.object.states.invert %> <%= f.select :state, f.object.states.invert %>
</p> </div>
<p> <div class="controls">
<%= f.submit 'Update' %> <%= f.submit 'Update Topic' %>
</p> </div>
<% end %> <% end %>
</div>
<%= link_to 'Back', @topic %>

View file

@ -1,21 +1,28 @@
<h1>New topic</h1> <h1>New Topic</h1>
<%= form_for @topic, html: { multipart: true, class: 'square' } do |f| %>
<%= render 'shared/errors', messages: @topic.errors.full_messages %>
<%= form_for @topic, :html => { :multipart => true } do |f| %>
<%= f.error_messages %>
<%= f.hidden_field :forum_id %> <%= f.hidden_field :forum_id %>
<p> <div class="fields horizontal">
<%= f.label :title %><br /> <%= f.label :forum %>
<%= f.text_field :title, :size => 50 %> <div class="inputs">
</p> <%= @topic.forum %>
</div>
</div>
<p> <div class="fields horizontal">
<%= f.text_area :first_post, :rows => 15, :cols => 108 %> <%= f.label :title %>
</p> <%= f.text_field :title, size: 50 %>
</div>
<p> <div class="fields horizontal">
<%= f.submit 'Create the topic' %> <%= f.label :post %>
</p> <%= f.text_area :first_post, rows: 15 %>
</div>
<div class="controls">
<%= f.submit 'Create Topic' %>
</div>
<% end %> <% end %>
<%= link_to 'Back', @topic.forum %>

View file

@ -1,6 +1,9 @@
<h1>Account: <%= h @user.username %></h1> <div id="profile-edit">
<h1>Account: <%= h @user.username %></h1>
<%= form_for @user, html: { multipart: true, id: 'profile', class: 'square' } do |f| %> <%= render 'shared/errors', messages: @user.errors.full_messages %>
<%= form_for @user, html: { multipart: true, id: 'profile', class: 'square' } do |f| %>
<% f.fields_for :profile do |p| %> <% f.fields_for :profile do |p| %>
<div id="user" class="tabbed"> <div id="user" class="tabbed">
<ul id="user-nav" class="tabs"> <ul id="user-nav" class="tabs">
@ -12,16 +15,6 @@
<div class="tabbed-contents"> <div class="tabbed-contents">
<div class="tab" id="account"> <div class="tab" id="account">
<% if @user.errors.any? %>
<div id="errors">
<strong><%= pluralize(@user.errors.count, t(:error)) %></strong>
<ul class="errors">
<% @user.errors.full_messages.each do |msg| %>
<li><%= msg %></li>
<% end %>
</ul>
</div>
<% end %>
<div class="fields horizontal"> <div class="fields horizontal">
<%= f.label :username, 'Username', class: 'required' %> <%= f.label :username, 'Username', class: 'required' %>
<%= f.text_field :username %> <%= f.text_field :username %>
@ -40,6 +33,7 @@
<div class="fields horizontal"> <div class="fields horizontal">
<%= f.label :public_email %> <%= f.label :public_email %>
<%= f.check_box :public_email %> <%= f.check_box :public_email %>
<%= f.label :public_email, class: 'checkbox' %>
</div> </div>
<div class="fields horizontal"> <div class="fields horizontal">
<%= f.label :steamid %> <%= f.label :steamid %>
@ -118,41 +112,49 @@
<div class="fields horizontal"> <div class="fields horizontal">
<%= p.label :notify_news, "News item are posted" %> <%= p.label :notify_news, "News item are posted" %>
<%= p.check_box :notify_news %> <%= p.check_box :notify_news %>
<%= p.label :notify_news, class: 'checkbox' %>
</div> </div>
<div class="fields horizontal"> <div class="fields horizontal">
<%= p.label :notify_articles, "New articles" %> <%= p.label :notify_articles, "New articles" %>
<%= p.check_box :notify_articles %> <%= p.check_box :notify_articles %>
<%= p.label :notify_articles, class: 'checkbox' %>
</div> </div>
<div class="fields horizontal"> <div class="fields horizontal">
<%= p.label :notify_movies, "New movies" %> <%= p.label :notify_movies, "New movies" %>
<%= p.check_box :notify_movies %> <%= p.check_box :notify_movies %>
<%= p.label :notify_movies, class: 'checkbox' %>
</div> </div>
<div class="fields horizontal"> <div class="fields horizontal">
<%= p.label :notify_gather, "Gather has 6 players" %> <%= p.label :notify_gather, "Gather has 6 players" %>
<%= p.check_box :notify_gather %> <%= p.check_box :notify_gather %>
<%= p.label :notify_gather, class: 'checkbox' %>
</div> </div>
<div class="fields horizontal"> <div class="fields horizontal">
<%= p.label :notify_own_match, "My team's matches" %> <%= p.label :notify_own_match, "My team's matches" %>
<%= p.check_box :notify_own_match %> <%= p.check_box :notify_own_match %>
<%= p.label :notify_own_match, class: 'checkbox' %>
</div> </div>
<div class="fields horizontal"> <div class="fields horizontal">
<%= p.label :notify_any_match, "New matches" %> <%= p.label :notify_any_match, "New matches" %>
<%= p.check_box :notify_any_match %> <%= p.check_box :notify_any_match %>
<%= p.label :notify_any_match, class: 'checkbox' %>
</div> </div>
<div class="fields horizontal"> <div class="fields horizontal">
<%= p.label :notify_challenge, "New challenges" %> <%= p.label :notify_challenge, "New challenges" %>
<%= p.check_box :notify_challenge %> <%= p.check_box :notify_challenge %>
<%= p.label :notify_challenge, class: 'checkbox' %>
</div> </div>
<div class="fields horizontal"> <div class="fields horizontal">
<%= p.label :notify_pms, "Private messages" %> <%= p.label :notify_pms, "Private messages" %>
<%= p.check_box :notify_pms %> <%= p.check_box :notify_pms %>
<%= p.label :notify_pms, class: 'checkbox' %>
</div> </div>
</div> </div>
</div> </div>
@ -162,10 +164,11 @@
</div> </div>
</div> </div>
<% end %> <% end %>
<% end %> <% end %>
<script type="text/javascript"> <script type="text/javascript">
new Yetii({ new Yetii({
id: 'user' id: 'user'
}); });
</script> </script>
</div>