annotate app/views/projects/settings/_members.rhtml @ 855:7294e8db2515 bug_162

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