_members.html.erb
91 lines
| 4.1 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> | ||||
|
r8669 | <% remote_form_for(:membership, member, :url => membership_path(member), | ||
:method => :put, | ||||
|
r7145 | :html => { :id => "member-#{member.id}-roles-form", :class => 'hol' }) do |f| %> | ||
<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), | ||
"$('member-#{member.id}-roles').show(); $('member-#{member.id}-roles-form').hide(); return false;" | ||||
%></p> | ||||
|
r505 | <% end %> | ||
|
r2627 | </td> | ||
<td class="buttons"> | ||||
|
r8482 | <%= link_to_function l(:button_edit), | ||
"$('member-#{member.id}-roles').hide(); $('member-#{member.id}-roles-form').show(); return false;", | ||||
:class => 'icon icon-edit' %> | ||||
<%= link_to_remote( | ||||
l(:button_delete), | ||||
|
r8669 | { :url => membership_path(member), | ||
:method => :delete, | ||||
|
r8482 | :confirm => (!User.current.admin? && member.include?(User.current) ? l(:text_own_membership_delete_confirmation) : nil) }, | ||
:title => l(:button_delete), | ||||
:class => 'icon icon-del' | ||||
) 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 | |||
|
r2755 | <% principals = Principal.active.find(:all, :limit => 100, :order => 'type, login, lastname ASC') - @project.principals %> | ||
|
r2549 | |||
|
r2546 | <div class="splitcontentright"> | ||
|
r2755 | <% if roles.any? && principals.any? %> | ||
|
r8669 | <% remote_form_for(:membership, @member, :url => project_memberships_path(@project), :method => :post, | ||
|
r7145 | :loading => '$(\'member-add-submit\').disable();', | ||
:complete => 'if($(\'member-add-submit\')) $(\'member-add-submit\').enable();') 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> | ||
<%= observe_field(:principal_search, | ||||
|
r2755 | :frequency => 0.5, | ||
:update => :principals, | ||||
|
r8669 | :url => autocomplete_project_memberships_path(@project), | ||
:method => :get, | ||||
|
r8754 | :before => '$("principal_search").addClassName("ajax-loading")', | ||
:complete => '$("principal_search").removeClassName("ajax-loading")', | ||||
|
r2755 | :with => 'q') | ||
%> | ||||
|
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> | ||