Resourcified project memberships.
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@8789 e93f8b46-1217-0410-a6f0-8f06a7374b81
This commit is contained in:
parent
229b2f8d2a
commit
78bd24c6f7
@ -17,15 +17,15 @@
|
|||||||
|
|
||||||
class MembersController < ApplicationController
|
class MembersController < ApplicationController
|
||||||
model_object Member
|
model_object Member
|
||||||
before_filter :find_model_object, :except => [:new, :autocomplete_for_member]
|
before_filter :find_model_object, :except => [:create, :autocomplete]
|
||||||
before_filter :find_project_from_association, :except => [:new, :autocomplete_for_member]
|
before_filter :find_project_from_association, :except => [:create, :autocomplete]
|
||||||
before_filter :find_project, :only => [:new, :autocomplete_for_member]
|
before_filter :find_project_by_project_id, :only => [:create, :autocomplete]
|
||||||
before_filter :authorize
|
before_filter :authorize
|
||||||
|
|
||||||
def new
|
def create
|
||||||
members = []
|
members = []
|
||||||
if params[:member] && request.post?
|
if params[:membership] && request.post?
|
||||||
attrs = params[:member].dup
|
attrs = params[:membership].dup
|
||||||
if (user_ids = attrs.delete(:user_ids))
|
if (user_ids = attrs.delete(:user_ids))
|
||||||
user_ids.each do |user_id|
|
user_ids.each do |user_id|
|
||||||
members << Member.new(attrs.merge(:user_id => user_id))
|
members << Member.new(attrs.merge(:user_id => user_id))
|
||||||
@ -63,8 +63,11 @@ class MembersController < ApplicationController
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def edit
|
def update
|
||||||
if request.post? and @member.update_attributes(params[:member])
|
if params[:membership]
|
||||||
|
@member.role_ids = params[:membership][:role_ids]
|
||||||
|
end
|
||||||
|
if request.put? && @member.save
|
||||||
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 {
|
format.js {
|
||||||
@ -79,7 +82,7 @@ class MembersController < ApplicationController
|
|||||||
end
|
end
|
||||||
|
|
||||||
def destroy
|
def destroy
|
||||||
if request.post? && @member.deletable?
|
if request.delete? && @member.deletable?
|
||||||
@member.destroy
|
@member.destroy
|
||||||
end
|
end
|
||||||
respond_to do |format|
|
respond_to do |format|
|
||||||
@ -92,7 +95,7 @@ class MembersController < ApplicationController
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def autocomplete_for_member
|
def autocomplete
|
||||||
@principals = Principal.active.like(params[:q]).find(:all, :limit => 100) - @project.principals
|
@principals = Principal.active.like(params[:q]).find(:all, :limit => 100) - @project.principals
|
||||||
render :layout => false
|
render :layout => false
|
||||||
end
|
end
|
||||||
|
1
app/views/members/autocomplete.html.erb
Normal file
1
app/views/members/autocomplete.html.erb
Normal file
@ -0,0 +1 @@
|
|||||||
|
<%= principals_check_box_tags 'membership[user_ids][]', @principals %>
|
@ -1 +0,0 @@
|
|||||||
<%= principals_check_box_tags 'member[user_ids][]', @principals %>
|
|
@ -18,21 +18,19 @@
|
|||||||
<td class="<%= member.principal.class.name.downcase %>"><%= link_to_user member.principal %></td>
|
<td class="<%= member.principal.class.name.downcase %>"><%= link_to_user member.principal %></td>
|
||||||
<td class="roles">
|
<td class="roles">
|
||||||
<span id="member-<%= member.id %>-roles"><%=h member.roles.sort.collect(&:to_s).join(', ') %></span>
|
<span id="member-<%= member.id %>-roles"><%=h member.roles.sort.collect(&:to_s).join(', ') %></span>
|
||||||
<% if authorize_for('members', 'edit') %>
|
<% remote_form_for(:membership, member, :url => membership_path(member),
|
||||||
<% remote_form_for(:member, member, :url => {:controller => 'members', :action => 'edit', :id => member},
|
:method => :put,
|
||||||
:method => :post,
|
|
||||||
:html => { :id => "member-#{member.id}-roles-form", :class => 'hol' }) do |f| %>
|
:html => { :id => "member-#{member.id}-roles-form", :class => 'hol' }) do |f| %>
|
||||||
<p><% roles.each do |role| %>
|
<p><% roles.each do |role| %>
|
||||||
<label><%= check_box_tag 'member[role_ids][]', role.id, member.roles.include?(role),
|
<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 />
|
:disabled => member.member_roles.detect {|mr| mr.role_id == role.id && !mr.inherited_from.nil?} %> <%=h role %></label><br />
|
||||||
<% end %></p>
|
<% end %></p>
|
||||||
<%= hidden_field_tag 'member[role_ids][]', '' %>
|
<%= hidden_field_tag 'membership[role_ids][]', '' %>
|
||||||
<p><%= submit_tag l(:button_change), :class => "small" %>
|
<p><%= submit_tag l(:button_change), :class => "small" %>
|
||||||
<%= link_to_function l(:button_cancel),
|
<%= link_to_function l(:button_cancel),
|
||||||
"$('member-#{member.id}-roles').show(); $('member-#{member.id}-roles-form').hide(); return false;"
|
"$('member-#{member.id}-roles').show(); $('member-#{member.id}-roles-form').hide(); return false;"
|
||||||
%></p>
|
%></p>
|
||||||
<% end %>
|
<% end %>
|
||||||
<% end %>
|
|
||||||
</td>
|
</td>
|
||||||
<td class="buttons">
|
<td class="buttons">
|
||||||
<%= link_to_function l(:button_edit),
|
<%= link_to_function l(:button_edit),
|
||||||
@ -40,8 +38,8 @@
|
|||||||
:class => 'icon icon-edit' %>
|
:class => 'icon icon-edit' %>
|
||||||
<%= link_to_remote(
|
<%= link_to_remote(
|
||||||
l(:button_delete),
|
l(:button_delete),
|
||||||
{ :url => {:controller => 'members', :action => 'destroy', :id => member},
|
{ :url => membership_path(member),
|
||||||
:method => :post,
|
:method => :delete,
|
||||||
:confirm => (!User.current.admin? && member.include?(User.current) ? l(:text_own_membership_delete_confirmation) : nil) },
|
:confirm => (!User.current.admin? && member.include?(User.current) ? l(:text_own_membership_delete_confirmation) : nil) },
|
||||||
:title => l(:button_delete),
|
:title => l(:button_delete),
|
||||||
:class => 'icon icon-del'
|
:class => 'icon icon-del'
|
||||||
@ -61,7 +59,7 @@
|
|||||||
|
|
||||||
<div class="splitcontentright">
|
<div class="splitcontentright">
|
||||||
<% if roles.any? && principals.any? %>
|
<% if roles.any? && principals.any? %>
|
||||||
<% remote_form_for(:member, @member, :url => {:controller => 'members', :action => 'new', :id => @project}, :method => :post,
|
<% remote_form_for(:membership, @member, :url => project_memberships_path(@project), :method => :post,
|
||||||
:loading => '$(\'member-add-submit\').disable();',
|
:loading => '$(\'member-add-submit\').disable();',
|
||||||
:complete => 'if($(\'member-add-submit\')) $(\'member-add-submit\').enable();') do |f| %>
|
:complete => 'if($(\'member-add-submit\')) $(\'member-add-submit\').enable();') do |f| %>
|
||||||
<fieldset><legend><%=l(:label_member_new)%></legend>
|
<fieldset><legend><%=l(:label_member_new)%></legend>
|
||||||
@ -70,17 +68,18 @@
|
|||||||
<%= observe_field(:principal_search,
|
<%= observe_field(:principal_search,
|
||||||
:frequency => 0.5,
|
:frequency => 0.5,
|
||||||
:update => :principals,
|
:update => :principals,
|
||||||
:url => { :controller => 'members', :action => 'autocomplete_for_member', :id => @project },
|
:url => autocomplete_project_memberships_path(@project),
|
||||||
|
:method => :get,
|
||||||
:with => 'q')
|
:with => 'q')
|
||||||
%>
|
%>
|
||||||
|
|
||||||
<div id="principals">
|
<div id="principals">
|
||||||
<%= principals_check_box_tags 'member[user_ids][]', principals %>
|
<%= principals_check_box_tags 'membership[user_ids][]', principals %>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<p><%= l(:label_role_plural) %>:
|
<p><%= l(:label_role_plural) %>:
|
||||||
<% roles.each do |role| %>
|
<% roles.each do |role| %>
|
||||||
<label><%= check_box_tag 'member[role_ids][]', role.id %> <%=h role %></label>
|
<label><%= check_box_tag 'membership[role_ids][]', role.id %> <%=h role %></label>
|
||||||
<% end %></p>
|
<% end %></p>
|
||||||
|
|
||||||
<p><%= submit_tag l(:button_add), :id => 'member-add-submit' %></p>
|
<p><%= submit_tag l(:button_add), :id => 'member-add-submit' %></p>
|
||||||
|
@ -96,15 +96,6 @@ ActionController::Routing::Routes.draw do |map|
|
|||||||
map.connect 'my/order_blocks', :controller => 'my', :action => 'order_blocks',
|
map.connect 'my/order_blocks', :controller => 'my', :action => 'order_blocks',
|
||||||
:conditions => {:method => :post}
|
:conditions => {:method => :post}
|
||||||
|
|
||||||
map.connect 'projects/:id/members/new', :controller => 'members',
|
|
||||||
:action => 'new', :conditions => { :method => :post }
|
|
||||||
map.connect 'members/edit/:id', :controller => 'members',
|
|
||||||
:action => 'edit', :id => /\d+/, :conditions => { :method => :post }
|
|
||||||
map.connect 'members/destroy/:id', :controller => 'members',
|
|
||||||
:action => 'destroy', :id => /\d+/, :conditions => { :method => :post }
|
|
||||||
map.connect 'members/autocomplete_for_member/:id', :controller => 'members',
|
|
||||||
:action => 'autocomplete_for_member', :conditions => { :method => :post }
|
|
||||||
|
|
||||||
map.with_options :controller => 'users' do |users|
|
map.with_options :controller => 'users' do |users|
|
||||||
users.user_membership 'users/:id/memberships/:membership_id',
|
users.user_membership 'users/:id/memberships/:membership_id',
|
||||||
:action => 'edit_membership',
|
:action => 'edit_membership',
|
||||||
@ -178,6 +169,9 @@ ActionController::Routing::Routes.draw do |map|
|
|||||||
project.resources :boards
|
project.resources :boards
|
||||||
project.resources :repositories, :shallow => true, :except => [:index, :show],
|
project.resources :repositories, :shallow => true, :except => [:index, :show],
|
||||||
:member => {:committers => [:get, :post]}
|
:member => {:committers => [:get, :post]}
|
||||||
|
project.resources :memberships, :shallow => true, :controller => 'members',
|
||||||
|
:only => [:create, :update, :destroy],
|
||||||
|
:collection => {:autocomplete => :get}
|
||||||
|
|
||||||
project.wiki_start_page 'wiki', :controller => 'wiki', :action => 'show', :conditions => {:method => :get}
|
project.wiki_start_page 'wiki', :controller => 'wiki', :action => 'show', :conditions => {:method => :get}
|
||||||
project.wiki_index 'wiki/index', :controller => 'wiki', :action => 'index', :conditions => {:method => :get}
|
project.wiki_index 'wiki/index', :controller => 'wiki', :action => 'index', :conditions => {:method => :get}
|
||||||
|
@ -52,7 +52,7 @@ Redmine::AccessControl.map do |map|
|
|||||||
map.permission :add_project, {:projects => [:new, :create]}, :require => :loggedin
|
map.permission :add_project, {:projects => [:new, :create]}, :require => :loggedin
|
||||||
map.permission :edit_project, {:projects => [:settings, :edit, :update]}, :require => :member
|
map.permission :edit_project, {:projects => [:settings, :edit, :update]}, :require => :member
|
||||||
map.permission :select_project_modules, {:projects => :modules}, :require => :member
|
map.permission :select_project_modules, {:projects => :modules}, :require => :member
|
||||||
map.permission :manage_members, {:projects => :settings, :members => [:new, :edit, :destroy, :autocomplete_for_member]}, :require => :member
|
map.permission :manage_members, {:projects => :settings, :members => [:create, :update, :destroy, :autocomplete]}, :require => :member
|
||||||
map.permission :manage_versions, {:projects => :settings, :versions => [:new, :create, :edit, :update, :close_completed, :destroy]}, :require => :member
|
map.permission :manage_versions, {:projects => :settings, :versions => [:new, :create, :edit, :update, :close_completed, :destroy]}, :require => :member
|
||||||
map.permission :add_subprojects, {:projects => [:new, :create]}, :require => :member
|
map.permission :add_subprojects, {:projects => [:new, :create]}, :require => :member
|
||||||
|
|
||||||
|
@ -35,7 +35,7 @@ class MembersControllerTest < ActionController::TestCase
|
|||||||
|
|
||||||
def test_create
|
def test_create
|
||||||
assert_difference 'Member.count' do
|
assert_difference 'Member.count' do
|
||||||
post :new, :id => 1, :member => {:role_ids => [1], :user_id => 7}
|
post :create, :project_id => 1, :membership => {:role_ids => [1], :user_id => 7}
|
||||||
end
|
end
|
||||||
assert_redirected_to '/projects/ecookbook/settings/members'
|
assert_redirected_to '/projects/ecookbook/settings/members'
|
||||||
assert User.find(7).member_of?(Project.find(1))
|
assert User.find(7).member_of?(Project.find(1))
|
||||||
@ -43,7 +43,7 @@ class MembersControllerTest < ActionController::TestCase
|
|||||||
|
|
||||||
def test_create_multiple
|
def test_create_multiple
|
||||||
assert_difference 'Member.count', 3 do
|
assert_difference 'Member.count', 3 do
|
||||||
post :new, :id => 1, :member => {:role_ids => [1], :user_ids => [7, 8, 9]}
|
post :create, :project_id => 1, :membership => {:role_ids => [1], :user_ids => [7, 8, 9]}
|
||||||
end
|
end
|
||||||
assert_redirected_to '/projects/ecookbook/settings/members'
|
assert_redirected_to '/projects/ecookbook/settings/members'
|
||||||
assert User.find(7).member_of?(Project.find(1))
|
assert User.find(7).member_of?(Project.find(1))
|
||||||
@ -51,7 +51,7 @@ class MembersControllerTest < ActionController::TestCase
|
|||||||
|
|
||||||
def test_xhr_create
|
def test_xhr_create
|
||||||
assert_difference 'Member.count', 3 do
|
assert_difference 'Member.count', 3 do
|
||||||
post :new, :format => "js", :id => 1, :member => {:role_ids => [1], :user_ids => [7, 8, 9]}
|
post :create, :project_id => 1, :membership => {:role_ids => [1], :user_ids => [7, 8, 9]}, :format => "js"
|
||||||
end
|
end
|
||||||
assert_select_rjs :replace_html, 'tab-content-members'
|
assert_select_rjs :replace_html, 'tab-content-members'
|
||||||
assert User.find(7).member_of?(Project.find(1))
|
assert User.find(7).member_of?(Project.find(1))
|
||||||
@ -61,7 +61,7 @@ class MembersControllerTest < ActionController::TestCase
|
|||||||
|
|
||||||
def test_xhr_create_with_failure
|
def test_xhr_create_with_failure
|
||||||
assert_no_difference 'Member.count' do
|
assert_no_difference 'Member.count' do
|
||||||
post :new, :format => "js", :id => 1, :member => {:role_ids => [], :user_ids => [7, 8, 9]}
|
post :create, :project_id => 1, :membership => {:role_ids => [], :user_ids => [7, 8, 9]}, :format => "js"
|
||||||
end
|
end
|
||||||
assert_select '#tab-content-members', 0
|
assert_select '#tab-content-members', 0
|
||||||
assert @response.body.match(/alert/i), "Alert message not sent"
|
assert @response.body.match(/alert/i), "Alert message not sent"
|
||||||
@ -69,14 +69,14 @@ class MembersControllerTest < ActionController::TestCase
|
|||||||
|
|
||||||
def test_edit
|
def test_edit
|
||||||
assert_no_difference 'Member.count' do
|
assert_no_difference 'Member.count' do
|
||||||
post :edit, :id => 2, :member => {:role_ids => [1], :user_id => 3}
|
put :update, :id => 2, :membership => {:role_ids => [1], :user_id => 3}
|
||||||
end
|
end
|
||||||
assert_redirected_to '/projects/ecookbook/settings/members'
|
assert_redirected_to '/projects/ecookbook/settings/members'
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_xhr_edit
|
def test_xhr_edit
|
||||||
assert_no_difference 'Member.count' do
|
assert_no_difference 'Member.count' do
|
||||||
xhr :post, :edit, :id => 2, :member => {:role_ids => [1], :user_id => 3}
|
xhr :put, :update, :id => 2, :membership => {:role_ids => [1], :user_id => 3}
|
||||||
end
|
end
|
||||||
assert_select_rjs :replace_html, 'tab-content-members'
|
assert_select_rjs :replace_html, 'tab-content-members'
|
||||||
member = Member.find(2)
|
member = Member.find(2)
|
||||||
@ -86,7 +86,7 @@ class MembersControllerTest < ActionController::TestCase
|
|||||||
|
|
||||||
def test_destroy
|
def test_destroy
|
||||||
assert_difference 'Member.count', -1 do
|
assert_difference 'Member.count', -1 do
|
||||||
post :destroy, :id => 2
|
delete :destroy, :id => 2
|
||||||
end
|
end
|
||||||
assert_redirected_to '/projects/ecookbook/settings/members'
|
assert_redirected_to '/projects/ecookbook/settings/members'
|
||||||
assert !User.find(3).member_of?(Project.find(1))
|
assert !User.find(3).member_of?(Project.find(1))
|
||||||
@ -94,17 +94,17 @@ class MembersControllerTest < ActionController::TestCase
|
|||||||
|
|
||||||
def test_xhr_destroy
|
def test_xhr_destroy
|
||||||
assert_difference 'Member.count', -1 do
|
assert_difference 'Member.count', -1 do
|
||||||
xhr :post, :destroy, :id => 2
|
xhr :delete, :destroy, :id => 2
|
||||||
end
|
end
|
||||||
assert_select_rjs :replace_html, 'tab-content-members'
|
assert_select_rjs :replace_html, 'tab-content-members'
|
||||||
end
|
end
|
||||||
|
|
||||||
def test_autocomplete_for_member
|
def test_autocomplete
|
||||||
get :autocomplete_for_member, :id => 1, :q => 'mis'
|
get :autocomplete, :project_id => 1, :q => 'mis'
|
||||||
assert_response :success
|
assert_response :success
|
||||||
assert_template 'autocomplete_for_member'
|
assert_template 'autocomplete'
|
||||||
|
|
||||||
assert_tag :label, :content => /User Misc/,
|
assert_tag :label, :content => /User Misc/,
|
||||||
:child => { :tag => 'input', :attributes => { :name => 'member[user_ids][]', :value => '8' } }
|
:child => { :tag => 'input', :attributes => { :name => 'membership[user_ids][]', :value => '8' } }
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -20,20 +20,20 @@ require File.expand_path('../../../test_helper', __FILE__)
|
|||||||
class RoutingMembersTest < ActionController::IntegrationTest
|
class RoutingMembersTest < ActionController::IntegrationTest
|
||||||
def test_members
|
def test_members
|
||||||
assert_routing(
|
assert_routing(
|
||||||
{ :method => 'post', :path => "/projects/5234/members/new" },
|
{ :method => 'post', :path => "/projects/5234/memberships" },
|
||||||
{ :controller => 'members', :action => 'new', :id => '5234' }
|
{ :controller => 'members', :action => 'create', :project_id => '5234' }
|
||||||
)
|
)
|
||||||
assert_routing(
|
assert_routing(
|
||||||
{ :method => 'post', :path => "/members/edit/5234" },
|
{ :method => 'put', :path => "/memberships/5234" },
|
||||||
{ :controller => 'members', :action => 'edit', :id => '5234' }
|
{ :controller => 'members', :action => 'update', :id => '5234' }
|
||||||
)
|
)
|
||||||
assert_routing(
|
assert_routing(
|
||||||
{ :method => 'post', :path => "/members/destroy/5234" },
|
{ :method => 'delete', :path => "/memberships/5234" },
|
||||||
{ :controller => 'members', :action => 'destroy', :id => '5234' }
|
{ :controller => 'members', :action => 'destroy', :id => '5234' }
|
||||||
)
|
)
|
||||||
assert_routing(
|
assert_routing(
|
||||||
{ :method => 'post', :path => "/members/autocomplete_for_member/5234" },
|
{ :method => 'get', :path => "/projects/5234/memberships/autocomplete" },
|
||||||
{ :controller => 'members', :action => 'autocomplete_for_member', :id => '5234' }
|
{ :controller => 'members', :action => 'autocomplete', :project_id => '5234' }
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
Loading…
x
Reference in New Issue
Block a user