_members.html.erb
77 lines
| 3.6 KiB
| text/plain
|
TextLexer
|
r505 | <%= error_messages_for 'member' %> | ||
|
r2549 | <% roles = Role.find_all_givable | ||
|
r2755 | members = @project.member_principals.find(:all, :include => [:roles, :principal]).sort %> | ||
|
r2546 | |||
<div class="splitcontentleft"> | ||||
|
r736 | <% if members.any? %> | ||
|
r2627 | <table class="list members"> | ||
|
r7145 | <thead><tr> | ||
<th><%= l(:label_user) %> / <%= l(:label_group) %></th> | ||||
<th><%= l(:label_role_plural) %></th> | ||||
<th style="width:15%"></th> | ||||
|
r1794 | <%= call_hook(:view_projects_settings_members_table_header, :project => @project) %> | ||
|
r7145 | </tr></thead> | ||
<tbody> | ||||
<% members.each do |member| %> | ||||
<% next if member.new_record? %> | ||||
<tr id="member-<%= member.id %>" class="<%= cycle 'odd', 'even' %> member"> | ||||
<td class="<%= member.principal.class.name.downcase %>"><%= link_to_user member.principal %></td> | ||||
|
r2627 | <td class="roles"> | ||
<span id="member-<%= member.id %>-roles"><%=h member.roles.sort.collect(&:to_s).join(', ') %></span> | ||||
|
r9388 | <%= form_for(member, {:as => :membership, :remote => true, :url => membership_path(member), | ||
|
r8669 | :method => :put, | ||
|
r9388 | :html => { :id => "member-#{member.id}-roles-form", :class => 'hol' }} | ||
) do |f| %> | ||||
|
r7145 | <p><% roles.each do |role| %> | ||
|
r8669 | <label><%= check_box_tag 'membership[role_ids][]', role.id, member.roles.include?(role), | ||
|
r7145 | :disabled => member.member_roles.detect {|mr| mr.role_id == role.id && !mr.inherited_from.nil?} %> <%=h role %></label><br /> | ||
|
r2627 | <% end %></p> | ||
|
r8669 | <%= hidden_field_tag 'membership[role_ids][]', '' %> | ||
|
r2627 | <p><%= submit_tag l(:button_change), :class => "small" %> | ||
|
r8482 | <%= link_to_function l(:button_cancel), | ||
|
r9885 | "$('#member-#{member.id}-roles').show(); $('#member-#{member.id}-roles-form').hide(); return false;" | ||
|
r8482 | %></p> | ||
|
r505 | <% end %> | ||
|
r2627 | </td> | ||
<td class="buttons"> | ||||
|
r8482 | <%= link_to_function l(:button_edit), | ||
|
r9885 | "$('#member-#{member.id}-roles').hide(); $('#member-#{member.id}-roles-form').show(); return false;", | ||
|
r8482 | :class => 'icon icon-edit' %> | ||
|
r9844 | <%= delete_link membership_path(member), | ||
:remote => true, | ||||
:data => (!User.current.admin? && member.include?(User.current) ? {:confirm => l(:text_own_membership_delete_confirmation)} : {}) if member.deletable? %> | ||||
|
r2627 | </td> | ||
<%= call_hook(:view_projects_settings_members_table_row, { :project => @project, :member => member}) %> | ||||
|
r7145 | </tr> | ||
|
r505 | <% end; reset_cycle %> | ||
|
r7145 | </tbody> | ||
|
r505 | </table> | ||
|
r736 | <% else %> | ||
<p class="nodata"><%= l(:label_no_data) %></p> | ||||
<% end %> | ||||
|
r2546 | </div> | ||
|
r505 | |||
|
r9008 | <% principals = Principal.active.not_member_of(@project).all(:limit => 100, :order => 'type, login, lastname ASC') %> | ||
|
r2549 | |||
|
r2546 | <div class="splitcontentright"> | ||
|
r2755 | <% if roles.any? && principals.any? %> | ||
|
r9885 | <%= form_for(@member, {:as => :membership, :url => project_memberships_path(@project), :remote => true, :method => :post}) do |f| %> | ||
|
r2546 | <fieldset><legend><%=l(:label_member_new)%></legend> | ||
|
r7099 | |||
|
r7145 | <p><%= label_tag "principal_search", l(:label_principal_search) %><%= text_field_tag 'principal_search', nil %></p> | ||
|
r9885 | <%= javascript_tag "observeSearchfield('principal_search', 'principals', '#{ escape_javascript autocomplete_project_memberships_path(@project) }')" %> | ||
|
r7108 | |||
|
r7145 | <div id="principals"> | ||
|
r8669 | <%= principals_check_box_tags 'membership[user_ids][]', principals %> | ||
|
r7145 | </div> | ||
|
r7108 | |||
|
r2627 | <p><%= l(:label_role_plural) %>: | ||
<% roles.each do |role| %> | ||||
|
r8669 | <label><%= check_box_tag 'membership[role_ids][]', role.id %> <%=h role %></label> | ||
|
r7145 | <% end %></p> | ||
|
r7108 | |||
|
r4257 | <p><%= submit_tag l(:button_add), :id => 'member-add-submit' %></p> | ||
|
r7145 | </fieldset> | ||
|
r505 | <% end %> | ||
<% end %> | ||||
|
r2546 | </div> | ||