Ability to add multiple project members in a single action (#1556).
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@2635 e93f8b46-1217-0410-a6f0-8f06a7374b81
This commit is contained in:
parent
c77806738a
commit
90810c0741
|
@ -21,10 +21,26 @@ class MembersController < ApplicationController
|
||||||
before_filter :authorize
|
before_filter :authorize
|
||||||
|
|
||||||
def new
|
def new
|
||||||
@project.members << Member.new(params[:member]) if request.post?
|
members = []
|
||||||
|
if params[:member] && request.post?
|
||||||
|
attrs = params[:member].dup
|
||||||
|
if (user_ids = attrs.delete(:user_ids))
|
||||||
|
user_ids.each do |user_id|
|
||||||
|
members << Member.new(attrs.merge(:user_id => user_id))
|
||||||
|
end
|
||||||
|
else
|
||||||
|
members << Member.new(attrs)
|
||||||
|
end
|
||||||
|
@project.members << members
|
||||||
|
end
|
||||||
respond_to do |format|
|
respond_to do |format|
|
||||||
format.html { redirect_to :controller => 'projects', :action => 'settings', :tab => 'members', :id => @project }
|
format.html { redirect_to :controller => 'projects', :action => 'settings', :tab => 'members', :id => @project }
|
||||||
format.js { render(:update) {|page| page.replace_html "tab-content-members", :partial => 'projects/settings/members'} }
|
format.js {
|
||||||
|
render(:update) {|page|
|
||||||
|
page.replace_html "tab-content-members", :partial => 'projects/settings/members'
|
||||||
|
members.each {|member| page.visual_effect(:highlight, "member-#{member.id}") }
|
||||||
|
}
|
||||||
|
}
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
|
@ -4,6 +4,7 @@
|
||||||
<% # members sorted by role position
|
<% # members sorted by role position
|
||||||
members = @project.members.find(:all, :include => [:role, :user]).sort %>
|
members = @project.members.find(:all, :include => [:role, :user]).sort %>
|
||||||
|
|
||||||
|
<div class="splitcontentleft">
|
||||||
<% if members.any? %>
|
<% if members.any? %>
|
||||||
<table class="list">
|
<table class="list">
|
||||||
<thead>
|
<thead>
|
||||||
|
@ -15,7 +16,7 @@
|
||||||
<tbody>
|
<tbody>
|
||||||
<% members.each do |member| %>
|
<% members.each do |member| %>
|
||||||
<% next if member.new_record? %>
|
<% next if member.new_record? %>
|
||||||
<tr class="<%= cycle 'odd', 'even' %>">
|
<tr id="member-<%= member.id %>" class="<%= cycle 'odd', 'even' %>">
|
||||||
<td><%= member.name %></td>
|
<td><%= member.name %></td>
|
||||||
<td align="center">
|
<td align="center">
|
||||||
<% if authorize_for('members', 'edit') %>
|
<% if authorize_for('members', 'edit') %>
|
||||||
|
@ -39,12 +40,20 @@
|
||||||
<% else %>
|
<% else %>
|
||||||
<p class="nodata"><%= l(:label_no_data) %></p>
|
<p class="nodata"><%= l(:label_no_data) %></p>
|
||||||
<% end %>
|
<% end %>
|
||||||
|
</div>
|
||||||
|
|
||||||
<% if authorize_for('members', 'new') && !users.empty? %>
|
<div class="splitcontentright">
|
||||||
|
<% if !users.empty? %>
|
||||||
<% remote_form_for(:member, @member, :url => {:controller => 'members', :action => 'new', :id => @project}, :method => :post) do |f| %>
|
<% remote_form_for(:member, @member, :url => {:controller => 'members', :action => 'new', :id => @project}, :method => :post) do |f| %>
|
||||||
<p><label for="member_user_id"><%=l(:label_member_new)%></label><br />
|
<fieldset><legend><%=l(:label_member_new)%></legend>
|
||||||
<%= f.select :user_id, users.collect{|user| [user.name, user.id]} %>
|
<div>
|
||||||
<%= l(:label_role) %>: <%= f.select :role_id, roles.collect{|role| [role.name, role.id]}, :selected => nil %>
|
<% users.each do |user| -%>
|
||||||
|
<label><%= check_box_tag 'member[user_ids][]', user.id, false %> <%= user %></label>
|
||||||
|
<% end -%>
|
||||||
|
</div>
|
||||||
|
<p><%= l(:label_role) %>: <%= f.select :role_id, roles.collect{|role| [role.name, role.id]}, :selected => nil %>
|
||||||
<%= submit_tag l(:button_add) %></p>
|
<%= submit_tag l(:button_add) %></p>
|
||||||
|
</fieldset>
|
||||||
<% end %>
|
<% end %>
|
||||||
<% end %>
|
<% end %>
|
||||||
|
</div>
|
||||||
|
|
|
@ -324,6 +324,16 @@ p.other-formats { text-align: right; font-size:0.9em; color: #666; }
|
||||||
|
|
||||||
a.atom { background: url(../images/feed.png) no-repeat 1px 50%; padding: 2px 0px 3px 16px; }
|
a.atom { background: url(../images/feed.png) no-repeat 1px 50%; padding: 2px 0px 3px 16px; }
|
||||||
|
|
||||||
|
/* Project members tab */
|
||||||
|
div#tab-content-members .splitcontentleft { width: 64% }
|
||||||
|
div#tab-content-members .splitcontentright { width: 34% }
|
||||||
|
div#tab-content-members fieldset { margin-top: -8px; padding-top:0.6em; margin-bottom: 1em; }
|
||||||
|
div#tab-content-members fieldset legend { font-weight: bold; }
|
||||||
|
div#tab-content-members fieldset label { display: block; }
|
||||||
|
div#tab-content-members fieldset div { max-height: 400px; overflow:auto; }
|
||||||
|
|
||||||
|
* html div#tab-content-members fieldset div { height: 450px; }
|
||||||
|
|
||||||
/***** Flash & error messages ****/
|
/***** Flash & error messages ****/
|
||||||
#errorExplanation, div.flash, .nodata, .warning {
|
#errorExplanation, div.flash, .nodata, .warning {
|
||||||
padding: 4px 4px 4px 30px;
|
padding: 4px 4px 4px 30px;
|
||||||
|
|
|
@ -112,5 +112,37 @@ users_007:
|
||||||
mail_notification: false
|
mail_notification: false
|
||||||
login: someone
|
login: someone
|
||||||
type: User
|
type: User
|
||||||
|
users_008:
|
||||||
|
id: 8
|
||||||
|
created_on: 2006-07-19 19:33:19 +02:00
|
||||||
|
status: 1
|
||||||
|
last_login_on:
|
||||||
|
language: 'it'
|
||||||
|
hashed_password: 1
|
||||||
|
updated_on: 2006-07-19 19:33:19 +02:00
|
||||||
|
admin: false
|
||||||
|
mail: miscuser8@foo.bar
|
||||||
|
lastname: Misc
|
||||||
|
firstname: User
|
||||||
|
auth_source_id:
|
||||||
|
mail_notification: false
|
||||||
|
login: miscuser8
|
||||||
|
type: User
|
||||||
|
users_009:
|
||||||
|
id: 9
|
||||||
|
created_on: 2006-07-19 19:33:19 +02:00
|
||||||
|
status: 1
|
||||||
|
last_login_on:
|
||||||
|
language: 'it'
|
||||||
|
hashed_password: 1
|
||||||
|
updated_on: 2006-07-19 19:33:19 +02:00
|
||||||
|
admin: false
|
||||||
|
mail: miscuser9@foo.bar
|
||||||
|
lastname: Misc
|
||||||
|
firstname: User
|
||||||
|
auth_source_id:
|
||||||
|
mail_notification: false
|
||||||
|
login: miscuser9
|
||||||
|
type: User
|
||||||
|
|
||||||
|
|
|
@ -40,7 +40,7 @@ class MembersControllerTest < Test::Unit::TestCase
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_new
|
def test_create
|
||||||
assert_difference 'Member.count' do
|
assert_difference 'Member.count' do
|
||||||
post :new, :id => 1, :member => {:role_id => 1, :user_id => 7}
|
post :new, :id => 1, :member => {:role_id => 1, :user_id => 7}
|
||||||
end
|
end
|
||||||
|
@ -48,6 +48,14 @@ class MembersControllerTest < Test::Unit::TestCase
|
||||||
assert User.find(7).member_of?(Project.find(1))
|
assert User.find(7).member_of?(Project.find(1))
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def test_create_multiple
|
||||||
|
assert_difference 'Member.count', 3 do
|
||||||
|
post :new, :id => 1, :member => {:role_id => 1, :user_ids => [7, 8, 9]}
|
||||||
|
end
|
||||||
|
assert_redirected_to '/projects/ecookbook/settings/members'
|
||||||
|
assert User.find(7).member_of?(Project.find(1))
|
||||||
|
end
|
||||||
|
|
||||||
def test_edit
|
def test_edit
|
||||||
assert_no_difference 'Member.count' do
|
assert_no_difference 'Member.count' do
|
||||||
post :edit, :id => 2, :member => {:role_id => 1, :user_id => 3}
|
post :edit, :id => 2, :member => {:role_id => 1, :user_id => 3}
|
||||||
|
|
Loading…
Reference in New Issue