annotate app/views/members/_editlist.rhtml @ 849:7018aa84e3a8 feature_36

Close obsolete branch feature_36
author Chris Cannam
date Sat, 24 Sep 2011 18:15:01 +0100
parents d7326bb4f6f0
children
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@500 20 <% remote_form_for(:member, member, :url => {:controller => 'members', :action => 'edit', :id => member},
chris@500 21 :method => :post, :html => { :id => "member-#{member.id}-roles-form", :class => 'hol' }) do |f| %>
chris@500 22 <p><% roles.each do |role| %>
chris@500 23 <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 />
chris@500 24 <% end %></p>
chris@500 25 <%= hidden_field_tag 'member[role_ids][]', '' %>
chris@500 26 <p><%= submit_tag l(:button_change), :class => "small" %>
chris@500 27 <%= link_to_function l(:button_cancel), "$('member-#{member.id}-roles').show(); $('member-#{member.id}-roles-form').hide(); return false;" %></p>
chris@500 28 <% end %>
chris@500 29 </td>
chris@500 30 <td class="buttons">
chris@500 31 <%= link_to_function l(:button_edit), "$('member-#{member.id}-roles').hide(); $('member-#{member.id}-roles-form').show(); return false;", :class => 'icon icon-edit' %>
chris@500 32 <%= link_to_remote(l(:button_delete), { :url => {:controller => 'members', :action => 'destroy', :id => member},
chris@500 33 :method => :post,
chris@500 34 :confirm => (!User.current.admin? && member.include?(User.current) ? l(:text_own_membership_delete_confirmation) : nil)
chris@500 35 }, :title => l(:button_delete),
chris@500 36 :class => 'icon icon-del') if member.deletable? %>
chris@500 37 </td>
chris@500 38 </tr>
chris@500 39 <% end; reset_cycle %>
chris@500 40 </tbody>
chris@500 41 </table>
chris@500 42 <% else %>
chris@500 43 <p class="nodata"><%= l(:label_no_data) %></p>
chris@500 44 <% end %>
chris@500 45
chris@500 46 <% content_for :sidebar do %>
chris@500 47 <% principals = Principal.active.find(:all, :limit => 100, :order => 'type, login, lastname ASC') - @project.principals %>
chris@500 48
chris@500 49 <% if roles.any? && principals.any? %>
chris@500 50 <% remote_form_for(:member, @member, :url => {:controller => 'members', :action => 'new', :id => @project}, :method => :post,
chris@500 51 :loading => '$(\'member-add-submit\').disable();',
chris@500 52 :complete => 'if($(\'member-add-submit\')) $(\'member-add-submit\').enable();') do |f| %>
chris@500 53 <h3><%=l(:label_member_new)%></h3>
chris@500 54
chris@500 55 <p><%= label_tag "principal_search", l(:label_principal_search) %><%= text_field_tag 'principal_search', nil %></p>
chris@500 56 <%= observe_field(:principal_search,
chris@500 57 :frequency => 0.5,
chris@500 58 :update => :principals,
chris@500 59 :url => { :controller => 'members', :action => 'autocomplete_for_member', :id => @project },
chris@500 60 :with => 'q')
chris@500 61 %>
chris@500 62
chris@500 63 <div id="principals">
chris@500 64 <% if params[:q] && params[:q].length > 1 %>
chris@500 65 <%= principals_check_box_tags 'member[user_ids][]', @principals %>
chris@500 66 <% end %>
chris@500 67 </div>
chris@500 68
chris@500 69 <p><%= l(:label_set_role_plural) %>:</p>
chris@500 70 <% roles.each do |role| %>
chris@500 71 <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>
chris@500 72 <% end %>
chris@500 73
chris@500 74 <p><%= submit_tag l(:button_add), :id => 'member-add-submit' %></p>
chris@500 75 <% end %>
chris@500 76 <% end %>
chris@500 77 <% end %>