diff --git a/app/controllers/users_controller.rb b/app/controllers/users_controller.rb index f67d1ae5..ceb70ab9 100644 --- a/app/controllers/users_controller.rb +++ b/app/controllers/users_controller.rb @@ -33,8 +33,8 @@ class UsersController < ApplicationController sort_init 'login', 'asc' sort_update - @status = params[:status] ? params[:status].to_i : 1 - conditions = nil + @status = params[:status] ? params[:status].to_i : 1 + conditions = "status <> 0" conditions = ["status=?", @status] unless @status == 0 @user_count = User.count(:conditions => conditions) diff --git a/app/helpers/users_helper.rb b/app/helpers/users_helper.rb index 9dc87c5c..7bd13716 100644 --- a/app/helpers/users_helper.rb +++ b/app/helpers/users_helper.rb @@ -17,7 +17,7 @@ module UsersHelper def status_options_for_select(selected) - options_for_select([[l(:label_all), "*"], + options_for_select([[l(:label_all), ''], [l(:status_active), 1], [l(:status_registered), 2], [l(:status_locked), 3]], selected) diff --git a/app/views/users/list.rhtml b/app/views/users/list.rhtml index 50054c98..7415af30 100644 --- a/app/views/users/list.rhtml +++ b/app/views/users/list.rhtml @@ -4,11 +4,10 @@

<%=l(:label_user_plural)%>

-<% form_tag() do %> +<% form_tag({}, :method => :get) do %>
<%= l(:label_filter_plural) %> <%= select_tag 'status', status_options_for_select(@status), :class => "small", :onchange => "this.form.submit(); return false;" %> -<%= submit_tag l(:button_apply), :class => "small" %>
<% end %>   @@ -20,38 +19,33 @@ <%= sort_header_tag('lastname', :caption => l(:field_lastname)) %> <%=l(:field_mail)%> <%= sort_header_tag('admin', :caption => l(:field_admin)) %> - <%= sort_header_tag('status', :caption => l(:field_status)) %> <%= sort_header_tag('created_on', :caption => l(:field_created_on)) %> <%= sort_header_tag('last_login_on', :caption => l(:field_last_login_on)) %> -<% for user in @users %> - "> - <%= link_to user.login, :action => 'edit', :id => user %> - <%= user.firstname %> - <%= user.lastname %> - <%= user.mail %> - <%= image_tag 'true.png' if user.admin? %> - <%= image_tag 'locked.png' if user.locked? %><%= image_tag 'user_new.png' if user.registered? %> - <%= format_time(user.created_on) %> - <%= format_time(user.last_login_on) unless user.last_login_on.nil? %> - - <% form_tag({:action => 'edit', :id => user}) do %> - <% if user.locked? %> - <%= hidden_field_tag 'user[status]', User::STATUS_ACTIVE %> - <%= submit_tag l(:button_unlock), :class => "button-small" %> - <% elsif user.registered? %> - <%= hidden_field_tag 'user[status]', User::STATUS_ACTIVE %> - <%= submit_tag l(:button_activate), :class => "button-small" %> - <% else %> - <%= hidden_field_tag 'user[status]', User::STATUS_LOCKED %> - <%= submit_tag l(:button_lock), :class => "button-small" %> - <% end %> - <% end %> - +<% for user in @users -%> + <%= %w(anon active registered locked)[user.status] %>"> + <%= link_to user.login, :action => 'edit', :id => user %> + <%= user.firstname %> + <%= user.lastname %> + <%= user.mail %> + <%= image_tag('true.png') if user.admin? %> + <%= format_time(user.created_on) %> + <%= format_time(user.last_login_on) unless user.last_login_on.nil? %> + + + <% if user.locked? -%> + <%= link_to l(:button_unlock), {:action => 'edit', :id => user, :user => {:status => User::STATUS_ACTIVE}}, :method => :post, :class => 'icon icon-unlock' %> + <% elsif user.registered? -%> + <%= link_to l(:button_activate), {:action => 'edit', :id => user, :user => {:status => User::STATUS_ACTIVE}}, :method => :post, :class => 'icon icon-unlock' %> + <% else -%> + <%= link_to l(:button_lock), {:action => 'edit', :id => user, :user => {:status => User::STATUS_LOCKED}}, :method => :post, :class => 'icon icon-lock' %> + <% end -%> + + -<% end %> +<% end -%> diff --git a/public/stylesheets/application.css b/public/stylesheets/application.css index 1090d8c8..1abd1f6f 100644 --- a/public/stylesheets/application.css +++ b/public/stylesheets/application.css @@ -94,6 +94,12 @@ tr.message td.last_message { font-size: 80%; } tr.message.locked td.subject a { background-image: url(../images/locked.png); } tr.message.sticky td.subject a { background-image: url(../images/sticky.png); font-weight: bold; } +tr.user td { width:13%; } +tr.user td.email { width:18%; } +tr.user td { white-space: nowrap; } +tr.user.locked, tr.user.registered { color: #aaa; } +tr.user.locked a, tr.user.registered a { color: #aaa; } + table.list tbody tr:hover { background-color:#ffffdd; } table td {padding:2px;} table p {margin:0;}