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