_members.rhtml
82 lines
| 3.8 KiB
| text/html+ruby
|
RhtmlLexer
|
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"> | ||
|
r3620 | <thead><tr> | ||
|
r2755 | <th><%= l(:label_user) %> / <%= l(:label_group) %></th> | ||
|
r2627 | <th><%= l(:label_role_plural) %></th> | ||
|
r506 | <th style="width:15%"></th> | ||
|
r1794 | <%= call_hook(:view_projects_settings_members_table_header, :project => @project) %> | ||
|
r3620 | </tr></thead> | ||
|
r505 | <tbody> | ||
|
r736 | <% members.each do |member| %> | ||
|
r505 | <% next if member.new_record? %> | ||
|
r2627 | <tr id="member-<%= member.id %>" class="<%= cycle 'odd', 'even' %> member"> | ||
|
r2755 | <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> | ||||
|
r505 | <% if authorize_for('members', 'edit') %> | ||
|
r2627 | <% remote_form_for(:member, member, :url => {:controller => 'members', :action => 'edit', :id => member}, | ||
:method => :post, | ||||
|
r3369 | :html => { :id => "member-#{member.id}-roles-form", :class => 'hol' }) do |f| %> | ||
|
r2627 | <p><% roles.each do |role| %> | ||
|
r2755 | <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 /> | ||||
|
r2627 | <% end %></p> | ||
|
r2755 | <%= hidden_field_tag 'member[role_ids][]', '' %> | ||
|
r2627 | <p><%= submit_tag l(:button_change), :class => "small" %> | ||
<%= link_to_function l(:button_cancel), "$('member-#{member.id}-roles').show(); $('member-#{member.id}-roles-form').hide(); return false;" %></p> | ||||
|
r505 | <% end %> | ||
<% end %> | ||||
|
r2627 | </td> | ||
<td class="buttons"> | ||||
<%= link_to_function l(:button_edit), "$('member-#{member.id}-roles').hide(); $('member-#{member.id}-roles-form').show(); return false;", :class => 'icon icon-edit' %> | ||||
|
r2755 | <%= link_to_remote(l(:button_delete), { :url => {:controller => 'members', :action => 'destroy', :id => member}, | ||
|
r3135 | :method => :post, | ||
:confirm => (!User.current.admin? && member.include?(User.current) ? l(:text_own_membership_delete_confirmation) : nil) | ||||
|
r505 | }, :title => l(:button_delete), | ||
|
r2755 | :class => 'icon icon-del') if member.deletable? %> | ||
|
r2627 | </td> | ||
<%= call_hook(:view_projects_settings_members_table_row, { :project => @project, :member => member}) %> | ||||
|
r505 | </tr> | ||
<% end; reset_cycle %> | ||||
|
r3634 | </tbody> | ||
|
r505 | </table> | ||
|
r736 | <% else %> | ||
<p class="nodata"><%= l(:label_no_data) %></p> | ||||
<% end %> | ||||
|
r2546 | </div> | ||
|
r505 | |||
|
r2549 | |||
|
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? %> | ||
|
r714 | <% remote_form_for(:member, @member, :url => {:controller => 'members', :action => 'new', :id => @project}, :method => :post) do |f| %> | ||
|
r2546 | <fieldset><legend><%=l(:label_member_new)%></legend> | ||
|
r2755 | |||
|
r3568 | <p><%= text_field_tag 'principal_search', nil %></p> | ||
|
r2755 | <%= observe_field(:principal_search, | ||
:frequency => 0.5, | ||||
:update => :principals, | ||||
:url => { :controller => 'members', :action => 'autocomplete_for_member', :id => @project }, | ||||
:with => 'q') | ||||
%> | ||||
<div id="principals"> | ||||
<%= principals_check_box_tags 'member[user_ids][]', principals %> | ||||
</div> | ||||
|
r2627 | <p><%= l(:label_role_plural) %>: | ||
<% roles.each do |role| %> | ||||
<label><%= check_box_tag 'member[role_ids][]', role.id %> <%=h role %></label> | ||||
<% end %></p> | ||||
|
r2755 | |||
|
r2627 | <p><%= submit_tag l(:button_add) %></p> | ||
|
r2546 | </fieldset> | ||
|
r505 | <% end %> | ||
<% end %> | ||||
|
r2546 | </div> | ||