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 / members / _editlist.html.erb @ 918:04114f36670d
History | View | Annotate | Download (3.9 KB)
| 1 | 500:d7326bb4f6f0 | chris | <%= error_messages_for 'member' %>
|
|---|---|---|---|
| 2 | |||
| 3 | <% roles = Role.find_all_givable
|
||
| 4 | members = @project.member_principals.find(:all, :include => [:roles, :principal]).sort %>
|
||
| 5 | |||
| 6 | <% if members.any? %>
|
||
| 7 | <table class="list members"> |
||
| 8 | <thead><tr> |
||
| 9 | <th><%= l(:label_user) %></th> |
||
| 10 | <th><%= l(:label_role_plural) %></th> |
||
| 11 | <th style="width:15%"></th> |
||
| 12 | </tr></thead> |
||
| 13 | <tbody>
|
||
| 14 | <% members.each do |member| %>
|
||
| 15 | <% next if member.new_record? %>
|
||
| 16 | <tr id="member-<%= member.id %>" class="<%= cycle 'odd', 'even' %> member"> |
||
| 17 | <td class="<%= member.principal.class.name.downcase %>"><%= link_to_user member.principal %></td> |
||
| 18 | <td class="roles"> |
||
| 19 | <span id="member-<%= member.id %>-roles"><%=h member.roles.sort.collect(&:to_s).join(', ') %></span> |
||
| 20 | <% remote_form_for(:member, member, :url => {:controller => 'members', :action => 'edit', :id => member},
|
||
| 21 | :method => :post, :html => { :id => "member-#{member.id}-roles-form", :class => 'hol' }) do |f| %>
|
||
| 22 | <p><% roles.each do |role| %> |
||
| 23 | <label><%= check_box_tag 'member[role_ids][]', role.id, member.roles.include?(role), :disabled => member.member_roles.detect {|mr| mr.role_id == role.id && !mr.inherited_from.nil?} %> <%=h role %></label><br /> |
||
| 24 | <% end %></p> |
||
| 25 | <%= hidden_field_tag 'member[role_ids][]', '' %>
|
||
| 26 | <p><%= submit_tag l(:button_change), :class => "small" %> |
||
| 27 | <%= link_to_function l(:button_cancel), "$('member-#{member.id}-roles').show(); $('member-#{member.id}-roles-form').hide(); return false;" %></p> |
||
| 28 | <% end %>
|
||
| 29 | </td>
|
||
| 30 | <td class="buttons"> |
||
| 31 | <%= link_to_function l(:button_edit), "$('member-#{member.id}-roles').hide(); $('member-#{member.id}-roles-form').show(); return false;", :class => 'icon icon-edit' %>
|
||
| 32 | <%= link_to_remote(l(:button_delete), { :url => {:controller => 'members', :action => 'destroy', :id => member},
|
||
| 33 | :method => :post,
|
||
| 34 | :confirm => (!User.current.admin? && member.include?(User.current) ? l(:text_own_membership_delete_confirmation) : nil)
|
||
| 35 | }, :title => l(:button_delete),
|
||
| 36 | :class => 'icon icon-del') if member.deletable? %>
|
||
| 37 | </td>
|
||
| 38 | </tr>
|
||
| 39 | <% end; reset_cycle %>
|
||
| 40 | </tbody>
|
||
| 41 | </table>
|
||
| 42 | <% else %>
|
||
| 43 | <p class="nodata"><%= l(:label_no_data) %></p> |
||
| 44 | <% end %>
|
||
| 45 | |||
| 46 | <% content_for :sidebar do %>
|
||
| 47 | <% principals = Principal.active.find(:all, :limit => 100, :order => 'type, login, lastname ASC') - @project.principals %>
|
||
| 48 | |||
| 49 | <% if roles.any? && principals.any? %>
|
||
| 50 | <% remote_form_for(:member, @member, :url => {:controller => 'members', :action => 'new', :id => @project}, :method => :post,
|
||
| 51 | :loading => '$(\'member-add-submit\').disable();',
|
||
| 52 | :complete => 'if($(\'member-add-submit\')) $(\'member-add-submit\').enable();') do |f| %>
|
||
| 53 | <h3><%=l(:label_member_new)%></h3> |
||
| 54 | |||
| 55 | <p><%= label_tag "principal_search", l(:label_principal_search) %><%= text_field_tag 'principal_search', nil %></p> |
||
| 56 | <%= observe_field(:principal_search,
|
||
| 57 | :frequency => 0.5,
|
||
| 58 | :update => :principals,
|
||
| 59 | :url => { :controller => 'members', :action => 'autocomplete_for_member', :id => @project },
|
||
| 60 | :with => 'q')
|
||
| 61 | %>
|
||
| 62 | |||
| 63 | <div id="principals"> |
||
| 64 | <% if params[:q] && params[:q].length > 1 %>
|
||
| 65 | <%= principals_check_box_tags 'member[user_ids][]', @principals %>
|
||
| 66 | <% end %>
|
||
| 67 | </div>
|
||
| 68 | |||
| 69 | <p><%= l(:label_set_role_plural) %>:</p> |
||
| 70 | <% roles.each do |role| %>
|
||
| 71 | <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> |
||
| 72 | <% end %>
|
||
| 73 | |||
| 74 | <p><%= submit_tag l(:button_add), :id => 'member-add-submit' %></p> |
||
| 75 | <% end %>
|
||
| 76 | <% end %>
|
||
| 77 | <% end %> |