Revision 915:2a68662d5adf app/views/members
| app/views/members/_editlist.erb | ||
|---|---|---|
| 1 |
<%= error_messages_for 'member' %> |
|
| 2 |
|
|
| 3 |
<% roles = Role.find_all_givable |
|
| 4 |
members = @project.member_principals.find(:all, :include => [:roles, :principal]).sort %> |
|
| 5 |
|
|
| 6 |
<% if members.any? %> |
|
| 7 |
<table class="list members"> |
|
| 8 |
<thead><tr> |
|
| 9 |
<th><%= l(:label_user) %></th> |
|
| 10 |
<th><%= l(:label_role_plural) %></th> |
|
| 11 |
<th style="width:15%"></th> |
|
| 12 |
</tr></thead> |
|
| 13 |
<tbody> |
|
| 14 |
<% members.each do |member| %> |
|
| 15 |
<% next if member.new_record? %> |
|
| 16 |
<tr id="member-<%= member.id %>" class="<%= cycle 'odd', 'even' %> member"> |
|
| 17 |
<td class="<%= member.principal.class.name.downcase %>"><%= link_to_user member.principal %></td> |
|
| 18 |
<td class="roles"> |
|
| 19 |
<span id="member-<%= member.id %>-roles"><%=h member.roles.sort.collect(&:to_s).join(', ') %></span>
|
|
| 20 |
<% remote_form_for(:member, member, :url => {:controller => 'members', :action => 'edit', :id => member},
|
|
| 21 |
:method => :post, :html => { :id => "member-#{member.id}-roles-form", :class => 'hol' }) do |f| %>
|
|
| 22 |
<p><% roles.each do |role| %> |
|
| 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 />
|
|
| 24 |
<% end %></p> |
|
| 25 |
<%= hidden_field_tag 'member[role_ids][]', '' %> |
|
| 26 |
<p><%= submit_tag l(:button_change), :class => "small" %> |
|
| 27 |
<%= link_to_function l(:button_cancel), "$('member-#{member.id}-roles').show(); $('member-#{member.id}-roles-form').hide(); return false;" %></p>
|
|
| 28 |
<% end %> |
|
| 29 |
</td> |
|
| 30 |
<td class="buttons"> |
|
| 31 |
<%= link_to_function l(:button_edit), "$('member-#{member.id}-roles').hide(); $('member-#{member.id}-roles-form').show(); return false;", :class => 'icon icon-edit' %>
|
|
| 32 |
<%= link_to_remote(l(:button_delete), { :url => {:controller => 'members', :action => 'destroy', :id => member},
|
|
| 33 |
:method => :post, |
|
| 34 |
:confirm => (!User.current.admin? && member.include?(User.current) ? l(:text_own_membership_delete_confirmation) : nil) |
|
| 35 |
}, :title => l(:button_delete), |
|
| 36 |
:class => 'icon icon-del') if member.deletable? %> |
|
| 37 |
</td> |
|
| 38 |
</tr> |
|
| 39 |
<% end; reset_cycle %> |
|
| 40 |
</tbody> |
|
| 41 |
</table> |
|
| 42 |
<% else %> |
|
| 43 |
<p class="nodata"><%= l(:label_no_data) %></p> |
|
| 44 |
<% end %> |
|
| 45 |
|
|
| 46 |
<% content_for :sidebar do %> |
|
| 47 |
<% principals = Principal.active.find(:all, :limit => 100, :order => 'type, login, lastname ASC') - @project.principals %> |
|
| 48 |
|
|
| 49 |
<% if roles.any? && principals.any? %> |
|
| 50 |
<% remote_form_for(:member, @member, :url => {:controller => 'members', :action => 'new', :id => @project}, :method => :post,
|
|
| 51 |
:loading => '$(\'member-add-submit\').disable();', |
|
| 52 |
:complete => 'if($(\'member-add-submit\')) $(\'member-add-submit\').enable();') do |f| %> |
|
| 53 |
<h3><%=l(:label_member_new)%></h3> |
|
| 54 |
|
|
| 55 |
<p><%= label_tag "principal_search", l(:label_principal_search) %><%= text_field_tag 'principal_search', nil %></p> |
|
| 56 |
<%= observe_field(:principal_search, |
|
| 57 |
:frequency => 0.5, |
|
| 58 |
:update => :principals, |
|
| 59 |
:url => { :controller => 'members', :action => 'autocomplete_for_member', :id => @project },
|
|
| 60 |
:with => 'q') |
|
| 61 |
%> |
|
| 62 |
|
|
| 63 |
<div id="principals"> |
|
| 64 |
<% if params[:q] && params[:q].length > 1 %> |
|
| 65 |
<%= principals_check_box_tags 'member[user_ids][]', @principals %> |
|
| 66 |
<% end %> |
|
| 67 |
</div> |
|
| 68 |
|
|
| 69 |
<p><%= l(:label_set_role_plural) %>:</p> |
|
| 70 |
<% roles.each do |role| %> |
|
| 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> |
|
| 72 |
<% end %> |
|
| 73 |
|
|
| 74 |
<p><%= submit_tag l(:button_add), :id => 'member-add-submit' %></p> |
|
| 75 |
<% end %> |
|
| 76 |
<% end %> |
|
| 77 |
<% end %> |
|
| app/views/members/_editlist.rhtml | ||
|---|---|---|
| 1 |
<%= error_messages_for 'member' %> |
|
| 2 |
|
|
| 3 |
<% roles = Role.find_all_givable |
|
| 4 |
members = @project.member_principals.find(:all, :include => [:roles, :principal]).sort %> |
|
| 5 |
|
|
| 6 |
<% if members.any? %> |
|
| 7 |
<table class="list members"> |
|
| 8 |
<thead><tr> |
|
| 9 |
<th><%= l(:label_user) %></th> |
|
| 10 |
<th><%= l(:label_role_plural) %></th> |
|
| 11 |
<th style="width:15%"></th> |
|
| 12 |
</tr></thead> |
|
| 13 |
<tbody> |
|
| 14 |
<% members.each do |member| %> |
|
| 15 |
<% next if member.new_record? %> |
|
| 16 |
<tr id="member-<%= member.id %>" class="<%= cycle 'odd', 'even' %> member"> |
|
| 17 |
<td class="<%= member.principal.class.name.downcase %>"><%= link_to_user member.principal %></td> |
|
| 18 |
<td class="roles"> |
|
| 19 |
<span id="member-<%= member.id %>-roles"><%=h member.roles.sort.collect(&:to_s).join(', ') %></span>
|
|
| 20 |
<% remote_form_for(:member, member, :url => {:controller => 'members', :action => 'edit', :id => member},
|
|
| 21 |
:method => :post, :html => { :id => "member-#{member.id}-roles-form", :class => 'hol' }) do |f| %>
|
|
| 22 |
<p><% roles.each do |role| %> |
|
| 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 />
|
|
| 24 |
<% end %></p> |
|
| 25 |
<%= hidden_field_tag 'member[role_ids][]', '' %> |
|
| 26 |
<p><%= submit_tag l(:button_change), :class => "small" %> |
|
| 27 |
<%= link_to_function l(:button_cancel), "$('member-#{member.id}-roles').show(); $('member-#{member.id}-roles-form').hide(); return false;" %></p>
|
|
| 28 |
<% end %> |
|
| 29 |
</td> |
|
| 30 |
<td class="buttons"> |
|
| 31 |
<%= link_to_function l(:button_edit), "$('member-#{member.id}-roles').hide(); $('member-#{member.id}-roles-form').show(); return false;", :class => 'icon icon-edit' %>
|
|
| 32 |
<%= link_to_remote(l(:button_delete), { :url => {:controller => 'members', :action => 'destroy', :id => member},
|
|
| 33 |
:method => :post, |
|
| 34 |
:confirm => (!User.current.admin? && member.include?(User.current) ? l(:text_own_membership_delete_confirmation) : nil) |
|
| 35 |
}, :title => l(:button_delete), |
|
| 36 |
:class => 'icon icon-del') if member.deletable? %> |
|
| 37 |
</td> |
|
| 38 |
</tr> |
|
| 39 |
<% end; reset_cycle %> |
|
| 40 |
</tbody> |
|
| 41 |
</table> |
|
| 42 |
<% else %> |
|
| 43 |
<p class="nodata"><%= l(:label_no_data) %></p> |
|
| 44 |
<% end %> |
|
| 45 |
|
|
| 46 |
<% content_for :sidebar do %> |
|
| 47 |
<% principals = Principal.active.find(:all, :limit => 100, :order => 'type, login, lastname ASC') - @project.principals %> |
|
| 48 |
|
|
| 49 |
<% if roles.any? && principals.any? %> |
|
| 50 |
<% remote_form_for(:member, @member, :url => {:controller => 'members', :action => 'new', :id => @project}, :method => :post,
|
|
| 51 |
:loading => '$(\'member-add-submit\').disable();', |
|
| 52 |
:complete => 'if($(\'member-add-submit\')) $(\'member-add-submit\').enable();') do |f| %> |
|
| 53 |
<h3><%=l(:label_member_new)%></h3> |
|
| 54 |
|
|
| 55 |
<p><%= label_tag "principal_search", l(:label_principal_search) %><%= text_field_tag 'principal_search', nil %></p> |
|
| 56 |
<%= observe_field(:principal_search, |
|
| 57 |
:frequency => 0.5, |
|
| 58 |
:update => :principals, |
|
| 59 |
:url => { :controller => 'members', :action => 'autocomplete_for_member', :id => @project },
|
|
| 60 |
:with => 'q') |
|
| 61 |
%> |
|
| 62 |
|
|
| 63 |
<div id="principals"> |
|
| 64 |
<% if params[:q] && params[:q].length > 1 %> |
|
| 65 |
<%= principals_check_box_tags 'member[user_ids][]', @principals %> |
|
| 66 |
<% end %> |
|
| 67 |
</div> |
|
| 68 |
|
|
| 69 |
<p><%= l(:label_set_role_plural) %>:</p> |
|
| 70 |
<% roles.each do |role| %> |
|
| 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> |
|
| 72 |
<% end %> |
|
| 73 |
|
|
| 74 |
<p><%= submit_tag l(:button_add), :id => 'member-add-submit' %></p> |
|
| 75 |
<% end %> |
|
| 76 |
<% end %> |
|
| 77 |
<% end %> |
|
| app/views/members/_list.erb | ||
|---|---|---|
| 1 |
|
|
| 2 |
<% roles = Role.find_all_givable |
|
| 3 |
members = @project.member_principals.find(:all, :include => [:roles, :principal]).sort %> |
|
| 4 |
|
|
| 5 |
<% if members.any? %> |
|
| 6 |
|
|
| 7 |
<div id="members"> |
|
| 8 |
<dl> |
|
| 9 |
<% members.each do |member| %> |
|
| 10 |
<dt id="member-<%= member.id %>" class="member <%= member.principal.class.name.downcase %> <%= User.current.logged? && User.current == member.user ? 'me' : nil %>"> |
|
| 11 |
<%= avatar(member.user, :size => "24") %> |
|
| 12 |
<span class="user"><%= link_to_user member.principal %></span> |
|
| 13 |
<span class="email"><%= member.user.mail if !member.user.pref.hide_mail %></span> |
|
| 14 |
<dd id="member-<%= member.id %>" class="roles <%= member.principal.class.name.downcase %> <%= User.current.logged? && User.current == member.user ? 'me' : nil %>"> |
|
| 15 |
<span class="roles" id="member-<%= member.id %>-roles"><%=h member.roles.sort.collect(&:to_s).join(', ') %></span>
|
|
| 16 |
</dd> |
|
| 17 |
<% end %> |
|
| 18 |
</dl> |
|
| 19 |
<% else %> |
|
| 20 |
<p class="nodata"><%= l(:label_no_data) %></p> |
|
| 21 |
<% end %> |
|
| 22 |
</div> |
|
| 23 |
|
|
| 24 |
<% content_for :sidebar do %> |
|
| 25 |
<% end %> |
|
| 26 |
|
|
| app/views/members/_list.rhtml | ||
|---|---|---|
| 1 |
|
|
| 2 |
<% roles = Role.find_all_givable |
|
| 3 |
members = @project.member_principals.find(:all, :include => [:roles, :principal]).sort %> |
|
| 4 |
|
|
| 5 |
<% if members.any? %> |
|
| 6 |
|
|
| 7 |
<div id="members"> |
|
| 8 |
<dl> |
|
| 9 |
<% members.each do |member| %> |
|
| 10 |
<dt id="member-<%= member.id %>" class="member <%= member.principal.class.name.downcase %> <%= User.current.logged? && User.current == member.user ? 'me' : nil %>"> |
|
| 11 |
<%= avatar(member.user, :size => "24") %> |
|
| 12 |
<span class="user"><%= link_to_user member.principal %></span> |
|
| 13 |
<span class="email"><%= member.user.mail if !member.user.pref.hide_mail %></span> |
|
| 14 |
<dd id="member-<%= member.id %>" class="roles <%= member.principal.class.name.downcase %> <%= User.current.logged? && User.current == member.user ? 'me' : nil %>"> |
|
| 15 |
<span class="roles" id="member-<%= member.id %>-roles"><%=h member.roles.sort.collect(&:to_s).join(', ') %></span>
|
|
| 16 |
</dd> |
|
| 17 |
<% end %> |
|
| 18 |
</dl> |
|
| 19 |
<% else %> |
|
| 20 |
<p class="nodata"><%= l(:label_no_data) %></p> |
|
| 21 |
<% end %> |
|
| 22 |
</div> |
|
| 23 |
|
|
| 24 |
<% content_for :sidebar do %> |
|
| 25 |
<% end %> |
|
| 26 |
|
|
| app/views/members/index.erb | ||
|---|---|---|
| 1 |
|
|
| 2 |
<h2><%=l(:label_member_plural)%></h2> |
|
| 3 |
|
|
| 4 |
<% editable = authorize_for('members', 'edit') %>
|
|
| 5 |
|
|
| 6 |
<div id="memberlist"> |
|
| 7 |
<% if editable %> |
|
| 8 |
<%= render :partial => 'editlist' %> |
|
| 9 |
<% else %> |
|
| 10 |
<%= render :partial => 'list' %> |
|
| 11 |
<% end %> |
|
| 12 |
</div> |
|
| 13 |
|
|
| app/views/members/index.rhtml | ||
|---|---|---|
| 1 |
|
|
| 2 |
<h2><%=l(:label_member_plural)%></h2> |
|
| 3 |
|
|
| 4 |
<% editable = authorize_for('members', 'edit') %>
|
|
| 5 |
|
|
| 6 |
<div id="memberlist"> |
|
| 7 |
<% if editable %> |
|
| 8 |
<%= render :partial => 'editlist' %> |
|
| 9 |
<% else %> |
|
| 10 |
<%= render :partial => 'list' %> |
|
| 11 |
<% end %> |
|
| 12 |
</div> |
|
| 13 |
|
|
Also available in: Unified diff