To check out this repository please hg clone the following URL, or open the URL using EasyMercurial or your preferred Mercurial client.

Statistics Download as Zip
| Branch: | Tag: | Revision:

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>