annotate app/views/members/index.rhtml @ 493:7a2bb9c5fb34 feature_142

Some experiments toward adding a Members entry to the project menu (for feature #142)
author Chris Cannam <chris.cannam@soundsoftware.ac.uk>
date Wed, 13 Jul 2011 11:03:57 +0100
parents
children d7326bb4f6f0
rev   line source
chris@493 1 <%= error_messages_for 'member' %>
chris@493 2 <% roles = Role.find_all_givable
chris@493 3 members = @project.member_principals.find(:all, :include => [:roles, :principal]).sort %>
chris@493 4
chris@493 5
chris@493 6 <div class="splitcontentleft">
chris@493 7 <% if members.any? %>
chris@493 8 <table class="list members">
chris@493 9 <thead><tr>
chris@493 10 <th><%= l(:label_user) %> / <%= l(:label_group) %></th>
chris@493 11 <th><%= l(:label_role_plural) %></th>
chris@493 12 <th style="width:15%"></th>
chris@493 13 <%= call_hook(:view_projects_settings_members_table_header, :project => @project) %>
chris@493 14 </tr></thead>
chris@493 15 <tbody>
chris@493 16 <% members.each do |member| %>
chris@493 17 <% next if member.new_record? %>
chris@493 18 <tr id="member-<%= member.id %>" class="<%= cycle 'odd', 'even' %> member">
chris@493 19 <td class="<%= member.principal.class.name.downcase %>"><%= link_to_user member.principal %></td>
chris@493 20 <td class="roles">
chris@493 21 <span id="member-<%= member.id %>-roles"><%=h member.roles.sort.collect(&:to_s).join(', ') %></span>
chris@493 22 <% if authorize_for('members', 'edit') %>
chris@493 23 <% remote_form_for(:member, member, :url => {:controller => 'members', :action => 'edit', :id => member},
chris@493 24 :method => :post, :html => { :id => "member-#{member.id}-roles-form", :class => 'hol' }) do |f| %>
chris@493 25 <p><% roles.each do |role| %>
chris@493 26 <label><%= check_box_tag 'member[role_ids][]', role.id, member.roles.include?(role),
chris@493 27 :disabled => member.member_roles.detect {|mr| mr.role_id == role.id && !mr.inherited_from.nil?} %> <%=h role %></label><br />
chris@493 28 <% end %></p>
chris@493 29 <%= hidden_field_tag 'member[role_ids][]', '' %>
chris@493 30 <p><%= submit_tag l(:button_change), :class => "small" %>
chris@493 31 <%= link_to_function l(:button_cancel), "$('member-#{member.id}-roles').show(); $('member-#{member.id}-roles-form').hide(); return false;" %></p>
chris@493 32 <% end %>
chris@493 33 <% end %>
chris@493 34 </td>
chris@493 35 <td class="buttons">
chris@493 36 <%= link_to_function l(:button_edit), "$('member-#{member.id}-roles').hide(); $('member-#{member.id}-roles-form').show(); return false;", :class => 'icon icon-edit' %>
chris@493 37 <%= link_to_remote(l(:button_delete), { :url => {:controller => 'members', :action => 'destroy', :id => member},
chris@493 38 :method => :post,
chris@493 39 :confirm => (!User.current.admin? && member.include?(User.current) ? l(:text_own_membership_delete_confirmation) : nil)
chris@493 40 }, :title => l(:button_delete),
chris@493 41 :class => 'icon icon-del') if member.deletable? %>
chris@493 42 </td>
chris@493 43 <%= call_hook(:view_projects_settings_members_table_row, { :project => @project, :member => member}) %>
chris@493 44 </tr>
chris@493 45 <% end; reset_cycle %>
chris@493 46 </tbody>
chris@493 47 </table>
chris@493 48 <% else %>
chris@493 49 <p class="nodata"><%= l(:label_no_data) %></p>
chris@493 50 <% end %>
chris@493 51 </div>
chris@493 52
chris@493 53
chris@493 54 <% principals = Principal.active.find(:all, :limit => 100, :order => 'type, login, lastname ASC') - @project.principals %>
chris@493 55
chris@493 56 <div class="splitcontentright">
chris@493 57 <% if roles.any? && principals.any? %>
chris@493 58 <% remote_form_for(:member, @member, :url => {:controller => 'members', :action => 'new', :id => @project}, :method => :post,
chris@493 59 :loading => '$(\'member-add-submit\').disable();',
chris@493 60 :complete => 'if($(\'member-add-submit\')) $(\'member-add-submit\').enable();') do |f| %>
chris@493 61 <fieldset><legend><%=l(:label_member_new)%></legend>
chris@493 62
chris@493 63 <p><%= label_tag "principal_search", l(:label_principal_search) %><%= text_field_tag 'principal_search', nil %></p>
chris@493 64 <%= observe_field(:principal_search,
chris@493 65 :frequency => 0.5,
chris@493 66 :update => :principals,
chris@493 67 :url => { :controller => 'members', :action => 'autocomplete_for_member', :id => @project },
chris@493 68 :with => 'q')
chris@493 69 %>
chris@493 70
chris@493 71 <div id="principals">
chris@493 72 <% if params[:q] && params[:q].length > 1 %>
chris@493 73 <%= principals_check_box_tags 'member[user_ids][]', @principals %>
chris@493 74 <% end %>
chris@493 75 </div>
chris@493 76
chris@493 77 <p><%= l(:label_set_role_plural) %>:</p>
chris@493 78 <% roles.each do |role| %>
chris@493 79 <label><%= check_box_tag 'member[role_ids][]', role.id %> <%=h role %> </label><div style="margin-left: 2em; margin-bottom: 0.5em"><i><%=l( 'label_' + role.name.downcase + "_description").to_sym %></i></div>
chris@493 80 <% end %>
chris@493 81
chris@493 82 <p><%= submit_tag l(:button_add), :id => 'member-add-submit' %></p>
chris@493 83 </fieldset>
chris@493 84 <% end %>
chris@493 85 <% end %>
chris@493 86 </div>