annotate app/views/members/_editlist.html.erb @ 1519:afce8026aaeb redmine-2.4-integration

Merge from branch "live"
author Chris Cannam
date Tue, 09 Sep 2014 09:34:53 +0100
parents b2f7f52a164d
children 82fac3dcf466
rev   line source
chris@500 1 <%= error_messages_for 'member' %>
chris@500 2
chris@500 3 <% roles = Role.find_all_givable
chris@500 4 members = @project.member_principals.find(:all, :include => [:roles, :principal]).sort %>
chris@500 5
chris@500 6 <% if members.any? %>
chris@500 7 <table class="list members">
chris@500 8 <thead><tr>
chris@500 9 <th><%= l(:label_user) %></th>
chris@500 10 <th><%= l(:label_role_plural) %></th>
chris@500 11 <th style="width:15%"></th>
chris@500 12 </tr></thead>
chris@500 13 <tbody>
chris@500 14 <% members.each do |member| %>
chris@500 15 <% next if member.new_record? %>
chris@500 16 <tr id="member-<%= member.id %>" class="<%= cycle 'odd', 'even' %> member">
chris@500 17 <td class="<%= member.principal.class.name.downcase %>"><%= link_to_user member.principal %></td>
chris@500 18 <td class="roles">
chris@500 19 <span id="member-<%= member.id %>-roles"><%=h member.roles.sort.collect(&:to_s).join(', ') %></span>
chris@1270 20 <%= form_for(member, {:as => :membership, :remote => true, :url => membership_path(member),
chris@1270 21 :method => :put,
chris@1270 22 :html => { :id => "member-#{member.id}-roles-form", :class => 'hol' }}
chris@1270 23 ) do |f| %>
chris@500 24 <p><% roles.each do |role| %>
chris@1270 25 <label><%= check_box_tag 'membership[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 />
chris@500 26 <% end %></p>
chris@1270 27 <%= hidden_field_tag 'membership[role_ids][]', '' %>
chris@500 28 <p><%= submit_tag l(:button_change), :class => "small" %>
chris@1270 29 <%= link_to_function l(:button_cancel),
chris@1270 30 "$('#member-#{member.id}-roles').show(); $('#member-#{member.id}-roles-form').hide(); return false;"
chris@1270 31 %></p>
chris@500 32 <% end %>
chris@500 33 </td>
chris@500 34 <td class="buttons">
chris@1270 35 <%= link_to_function l(:button_edit),
chris@1270 36 "$('#member-#{member.id}-roles').hide(); $('#member-#{member.id}-roles-form').show(); return false;",
chris@1270 37 :class => 'icon icon-edit' %>
chris@1270 38 <%= delete_link membership_path(member),
chris@1270 39 :data => (!User.current.admin? && member.include?(User.current) ? {:confirm => l(:text_own_membership_delete_confirmation)} : {}) if member.deletable? %>
chris@500 40 </td>
chris@500 41 </tr>
chris@500 42 <% end; reset_cycle %>
chris@500 43 </tbody>
chris@500 44 </table>
chris@500 45 <% else %>
chris@500 46 <p class="nodata"><%= l(:label_no_data) %></p>
chris@500 47 <% end %>
chris@500 48
chris@500 49 <% content_for :sidebar do %>
chris@500 50 <% principals = Principal.active.find(:all, :limit => 100, :order => 'type, login, lastname ASC') - @project.principals %>
chris@500 51
chris@500 52 <% if roles.any? && principals.any? %>
chris@1270 53 <%= form_for(@member, {:as => :membership, :url => project_memberships_path(@project), :method => :post}) do |f| %>
chris@500 54 <h3><%=l(:label_member_new)%></h3>
chris@500 55
chris@500 56 <p><%= label_tag "principal_search", l(:label_principal_search) %><%= text_field_tag 'principal_search', nil %></p>
chris@1270 57 <%= javascript_tag "observeSearchfield('principal_search', 'principals', '#{ escape_javascript autocomplete_project_memberships_path(@project) }')" %>
chris@500 58
chris@500 59 <div id="principals">
chris@500 60 <% if params[:q] && params[:q].length > 1 %>
chris@1270 61 <%= principals_check_box_tags 'membership[user_ids][]', @principals %>
chris@500 62 <% end %>
chris@500 63 </div>
chris@500 64
chris@500 65 <p><%= l(:label_set_role_plural) %>:</p>
chris@500 66 <% roles.each do |role| %>
chris@1270 67 <label><%= check_box_tag 'membership[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>
chris@500 68 <% end %>
chris@500 69
chris@500 70 <p><%= submit_tag l(:button_add), :id => 'member-add-submit' %></p>
chris@500 71 <% end %>
chris@500 72 <% end %>
chris@500 73 <% end %>