Commit d3bae4732e29d4e29257349674a6c30887afe6f3
Committed by
Antonio Terceiro
1 parent
e6c801d6
Exists in
master
and in
28 other branches
ActionItem1021: "Page not exists" when exit from community on another environment
* move leave logic to profile_controller * use lightbox to leave confirmation, like join * store location to remember to where redirect
Showing
14 changed files
with
189 additions
and
71 deletions
Show diff stats
app/controllers/my_profile/memberships_controller.rb
... | ... | @@ -6,19 +6,6 @@ class MembershipsController < MyProfileController |
6 | 6 | @memberships = profile.memberships |
7 | 7 | end |
8 | 8 | |
9 | - def leave | |
10 | - @to_leave = Profile.find(params[:id]) | |
11 | - @wizard = params[:wizard] | |
12 | - if request.post? && params[:confirmation] | |
13 | - @to_leave.remove_member(profile) | |
14 | - if @wizard | |
15 | - redirect_to :controller => 'search', :action => 'assets', :asset => 'communities', :wizard => true | |
16 | - else | |
17 | - redirect_to :action => 'index' | |
18 | - end | |
19 | - end | |
20 | - end | |
21 | - | |
22 | 9 | def new_community |
23 | 10 | @community = Community.new(params[:community]) |
24 | 11 | @wizard = params[:wizard].blank? ? false : params[:wizard] | ... | ... |
app/controllers/public/profile_controller.rb
... | ... | @@ -2,7 +2,7 @@ class ProfileController < PublicController |
2 | 2 | |
3 | 3 | needs_profile |
4 | 4 | before_filter :check_access_to_profile |
5 | - before_filter :login_required, :only => [:join, :refuse_join] | |
5 | + before_filter :login_required, :only => [:join, :refuse_join, :leave] | |
6 | 6 | |
7 | 7 | helper TagsHelper |
8 | 8 | |
... | ... | @@ -55,9 +55,27 @@ class ProfileController < PublicController |
55 | 55 | if @wizard |
56 | 56 | redirect_to :controller => 'search', :action => 'assets', :asset => 'communities', :wizard => true |
57 | 57 | else |
58 | - redirect_to profile.url | |
58 | + redirect_back_or_default profile.url | |
59 | 59 | end |
60 | 60 | else |
61 | + store_location(request.referer) | |
62 | + if request.xhr? | |
63 | + render :layout => false | |
64 | + end | |
65 | + end | |
66 | + end | |
67 | + | |
68 | + def leave | |
69 | + @wizard = params[:wizard] | |
70 | + if request.post? && params[:confirmation] | |
71 | + profile.remove_member(current_user.person) | |
72 | + if @wizard | |
73 | + redirect_to :controller => 'search', :action => 'assets', :asset => 'communities', :wizard => true | |
74 | + else | |
75 | + redirect_back_or_default profile.url | |
76 | + end | |
77 | + else | |
78 | + store_location(request.referer) | |
61 | 79 | if request.xhr? |
62 | 80 | render :layout => false |
63 | 81 | end | ... | ... |
app/models/profile.rb
... | ... | @@ -350,6 +350,14 @@ class Profile < ActiveRecord::Base |
350 | 350 | { :profile => identifier, :controller => 'profile_editor', :action => 'index' } |
351 | 351 | end |
352 | 352 | |
353 | + def leave_url | |
354 | + { :profile => identifier, :controller => 'profile', :action => 'leave' } | |
355 | + end | |
356 | + | |
357 | + def join_url | |
358 | + { :profile => identifier, :controller => 'profile', :action => 'join' } | |
359 | + end | |
360 | + | |
353 | 361 | def public_profile_url |
354 | 362 | generate_url(:profile => identifier, :controller => 'profile', :action => 'index') |
355 | 363 | end | ... | ... |
app/views/account/_profile_details.rhtml
... | ... | @@ -7,11 +7,11 @@ |
7 | 7 | <%= _('Members: %s') % @profile.members.size.to_s %> <br/> |
8 | 8 | <%= _('Created at: %s') % show_date(@profile.created_at) %> <br/> |
9 | 9 | |
10 | -<% form_tag({ :profile => @profile.identifier, :controller => 'profile', :action => 'join'}) do %> | |
10 | +<% form_tag(@profile.join_url) do %> | |
11 | 11 | <%= hidden_field_tag(:confirmation, 1) %> |
12 | 12 | <%= hidden_field_tag(:wizard, true) %> |
13 | 13 | <% if @profile.members.include?(user) %> |
14 | - <%= link_to( _('Leave'), { :profile => user.identifier, :controller => 'memberships', :action => 'leave', :id => @profile.id, :confirmation => 1, :wizard => true }, :method => 'post') %> | |
14 | + <%= link_to( _('Leave'), @profile.leave_url.merge(:confirmation => 1, :wizard => true }, :method => 'post') %> | |
15 | 15 | <% else %> |
16 | 16 | <%= submit_button(:ok, _("Join now")) %> |
17 | 17 | <% end %> | ... | ... |
app/views/blocks/profile_info_actions/community.rhtml
... | ... | @@ -3,11 +3,11 @@ |
3 | 3 | |
4 | 4 | <% if profile.members.include?(user) %> |
5 | 5 | <li> |
6 | - <%= link_to content_tag('span', _('Leave')), { :profile => user.identifier, :controller => 'memberships', :action => 'leave', :id => profile.id }, :class => 'button with-text icon-delete', :title => _('Leave this community') %> | |
6 | + <%= lightbox_link_to content_tag('span', _('Leave')), profile.leave_url, :class => 'button with-text icon-delete', :title => _('Leave this community') %> | |
7 | 7 | </li> |
8 | 8 | <% else %> |
9 | 9 | <li> |
10 | - <%= lightbox_link_to content_tag('span', _('Join')), { :profile => profile.identifier, :controller => 'profile', :action => 'join' }, :class => 'button with-text icon-add', :title => _('Join this community') %> | |
10 | + <%= lightbox_link_to content_tag('span', _('Join')), profile.join_url, :class => 'button with-text icon-add', :title => _('Join this community') %> | |
11 | 11 | </li> |
12 | 12 | <% end %> |
13 | 13 | ... | ... |
app/views/memberships/index.rhtml
... | ... | @@ -21,7 +21,7 @@ |
21 | 21 | <%= _('Members: %s') % membership.members.size.to_s %> <br/> |
22 | 22 | <%= _('Created at: %s') % show_date(membership.created_at) unless membership.enterprise? %> <br/> |
23 | 23 | <%= [ link_to(_('Manage'), membership.admin_url), |
24 | - link_to(_('Leave'), { :profile => profile.identifier, :controller => 'memberships', :action => 'leave', :id => membership }), | |
24 | + lightbox_link_to(_('Leave'), membership.leave_url), | |
25 | 25 | (membership.community? && user.has_permission?(:destroy_profile, membership) ? link_to(_('Remove'), { :action => 'destroy_community', :id => membership }) : nil) |
26 | 26 | ].compact.join(', ') |
27 | 27 | %> | ... | ... |
app/views/memberships/leave.rhtml
... | ... | @@ -1,11 +0,0 @@ |
1 | -<h1><%= _('Leaving %s') % @to_leave.name %></h1> | |
2 | - | |
3 | -<p> | |
4 | -<%= _('Are you sure you want to leave %s?') % @to_leave.name %> | |
5 | -</p> | |
6 | - | |
7 | -<% form_tag do %> | |
8 | - <%= hidden_field_tag(:confirmation, 1) %> | |
9 | - <%= submit_button(:ok, _("Yes, I want to leave.") % @to_leave.name) %> | |
10 | - <%= button(:cancel, _("No, I don't want."), :action => 'index') %> | |
11 | -<% end %> |
... | ... | @@ -0,0 +1,15 @@ |
1 | +<h1><%= _('Leaving %s') % profile.name %></h1> | |
2 | + | |
3 | +<p> | |
4 | +<%= _('Are you sure you want to leave %s?') % profile.name %> | |
5 | +</p> | |
6 | + | |
7 | +<% form_tag do %> | |
8 | + <%= hidden_field_tag(:confirmation, 1) %> | |
9 | + <%= submit_button(:ok, _("Yes, I want to leave.") % profile.name) %> | |
10 | + <% if logged_in? && request.xhr? %> | |
11 | + <%= lightbox_close_button(_("No, I don't want")) %> | |
12 | + <% else %> | |
13 | + <%= button(:cancel, _("No, I don't want."), profile.url) %> | |
14 | + <% end %> | |
15 | +<% end %> | ... | ... |
app/views/shared/join_community_popup.rhtml
... | ... | @@ -3,9 +3,9 @@ |
3 | 3 | |
4 | 4 | <% button_bar do %> |
5 | 5 | <% if logged_in? %> |
6 | - <%= button(:ok, _('Yes'), { :controller => 'profile', :action => 'join', :profile => profile.identifier, :confirmation => '1'}, :method => :post) %> | |
6 | + <%= button(:ok, _('Yes'), profile.join_url.merge(:confirmation => '1'), :method => :post) %> | |
7 | 7 | <% else %> |
8 | - <%= button(:ok, _('Yes'), :controller => 'profile', :action => 'join', :profile => profile.identifier) %> | |
8 | + <%= button(:ok, _('Yes'), profile.join_url) %> | |
9 | 9 | <% end %> |
10 | 10 | <%= button_to_remote(:cancel, _('Not now'), :url => profile.url.merge({:controller => 'profile', :action => 'refuse_for_now', :profile => profile.identifier}), :loaded => '$("join-community-popup").hide()') %> |
11 | 11 | <%= button(:cancel, _('No and don\'t ask again'), :controller => 'profile', :action => 'refuse_join', :profile => profile.identifier) if logged_in? %> | ... | ... |
lib/authenticated_system.rb
... | ... | @@ -79,8 +79,8 @@ module AuthenticatedSystem |
79 | 79 | # Store the URI of the current request in the session. |
80 | 80 | # |
81 | 81 | # We can return to this location by calling #redirect_back_or_default. |
82 | - def store_location | |
83 | - session[:return_to] = request.request_uri | |
82 | + def store_location(location = request.request_uri) | |
83 | + session[:return_to] = location | |
84 | 84 | end |
85 | 85 | |
86 | 86 | # Redirect to the URI stored by the most recent store_location call or | ... | ... |
test/functional/cms_controller_test.rb
... | ... | @@ -1121,4 +1121,5 @@ class CmsControllerTest < Test::Unit::TestCase |
1121 | 1121 | get :view, :profile => profile.identifier, :id => profile.blog.id |
1122 | 1122 | assert_no_tag :tag => 'a', :attributes => { :href => "/myprofile/#{profile.identifier}/cms/upload_files?parent_id=#{profile.blog.id}"} |
1123 | 1123 | end |
1124 | + | |
1124 | 1125 | end | ... | ... |
test/functional/memberships_controller_test.rb
... | ... | @@ -109,41 +109,7 @@ class MembershipsControllerTest < Test::Unit::TestCase |
109 | 109 | community = Community.create!(:name => 'my test community', :description => 'description test') |
110 | 110 | community.add_member(profile) |
111 | 111 | get :index, :profile => profile.identifier |
112 | - assert_tag :tag => 'a', :attributes => { :href => "/myprofile/#{profile.identifier}/memberships/leave/#{community.id}" }, :content => 'Leave' | |
113 | - end | |
114 | - | |
115 | - should 'present confirmation before leaving a profile' do | |
116 | - community = Community.create!(:name => 'my test community') | |
117 | - community.add_member(profile) | |
118 | - get :leave, :profile => profile.identifier, :id => community.id | |
119 | - | |
120 | - assert_response :success | |
121 | - assert_template 'leave' | |
122 | - end | |
123 | - | |
124 | - should 'actually leave profile' do | |
125 | - community = Community.create!(:name => 'my test community') | |
126 | - community.add_member(profile) | |
127 | - assert_includes profile.memberships, community | |
128 | - post :leave, :profile => profile.identifier, :id => community.id, :confirmation => '1' | |
129 | - | |
130 | - assert_response :redirect | |
131 | - assert_redirected_to :action => 'index' | |
132 | - | |
133 | - profile = Profile.find(@profile.id) | |
134 | - assert_not_includes profile.memberships, community | |
135 | - end | |
136 | - | |
137 | - should 'leave profile when on wizard' do | |
138 | - community = Community.create!(:name => 'my test community') | |
139 | - community.add_member(profile) | |
140 | - post :leave, :profile => profile.identifier, :id => community.id, :confirmation => '1', :wizard => true | |
141 | - | |
142 | - assert_response :redirect | |
143 | - assert_redirected_to :controller => 'search', :action => 'assets', :asset => 'communities', :wizard => true | |
144 | - | |
145 | - profile = Profile.find(@profile.id) | |
146 | - assert_not_includes profile.memberships, community | |
112 | + assert_tag :tag => 'a', :attributes => { :href => "/profile/#{community.identifier}/leave" }, :content => 'Leave' | |
147 | 113 | end |
148 | 114 | |
149 | 115 | should 'current user is added as admin after create new community' do | ... | ... |
test/functional/profile_controller_test.rb
... | ... | @@ -12,6 +12,7 @@ class ProfileControllerTest < Test::Unit::TestCase |
12 | 12 | |
13 | 13 | @profile = create_user('testuser').person |
14 | 14 | end |
15 | + attr_reader :profile | |
15 | 16 | |
16 | 17 | def test_local_files_reference |
17 | 18 | assert_local_files_reference |
... | ... | @@ -224,7 +225,8 @@ class ProfileControllerTest < Test::Unit::TestCase |
224 | 225 | community = Community.create!(:name => 'my test community') |
225 | 226 | community.add_member(@profile) |
226 | 227 | get :index, :profile => community.identifier |
227 | - assert_tag :tag => 'a', :attributes => { :href => "/myprofile/#{@profile.identifier}/memberships/leave/#{community.id}" } | |
228 | + assert_tag :tag => 'a', | |
229 | + :attributes => { :href => "/profile/#{community.identifier}/leave" } | |
228 | 230 | end |
229 | 231 | |
230 | 232 | should 'not show Leave This Community button for non-registered users' do |
... | ... | @@ -510,4 +512,126 @@ class ProfileControllerTest < Test::Unit::TestCase |
510 | 512 | assert_equal ((2..10).to_a + [community.id]), @request.session[:no_asking] |
511 | 513 | end |
512 | 514 | |
515 | + should 'present confirmation before leaving a profile' do | |
516 | + community = Community.create!(:name => 'my test community') | |
517 | + community.add_member(profile) | |
518 | + | |
519 | + login_as(profile.identifier) | |
520 | + get :leave, :profile => community.identifier | |
521 | + | |
522 | + assert_template 'leave' | |
523 | + assert_tag :tag => 'input', :attributes => {:value => 'Yes, I want to leave.', :type => 'submit'} | |
524 | + end | |
525 | + | |
526 | + should 'actually leave profile' do | |
527 | + community = Community.create!(:name => 'my test community') | |
528 | + community.add_member(profile) | |
529 | + assert_includes profile.memberships, community | |
530 | + | |
531 | + login_as(profile.identifier) | |
532 | + post :leave, :profile => community.identifier, :confirmation => '1' | |
533 | + | |
534 | + profile = Profile.find(@profile.id) | |
535 | + assert_not_includes profile.memberships, community | |
536 | + end | |
537 | + | |
538 | + should 'leave profile when on wizard' do | |
539 | + community = Community.create!(:name => 'my test community') | |
540 | + community.add_member(profile) | |
541 | + | |
542 | + login_as(profile.identifier) | |
543 | + post :leave, :profile => community.identifier, :confirmation => '1', :wizard => true | |
544 | + | |
545 | + assert_response :redirect | |
546 | + assert_redirected_to :controller => 'search', :action => 'assets', :asset => 'communities', :wizard => true | |
547 | + | |
548 | + profile = Profile.find(@profile.id) | |
549 | + assert_not_includes profile.memberships, community | |
550 | + end | |
551 | + | |
552 | + should "offer button to close 'leave community' lightbox" do | |
553 | + community = Community.create!(:name => 'my test community') | |
554 | + community.add_member(profile) | |
555 | + | |
556 | + login_as(profile.identifier) | |
557 | + get :index, :profile => community.identifier | |
558 | + | |
559 | + assert_tag :tag => 'a', :content => 'Leave', :attributes => { :href => "/profile/#{community.identifier}/leave", :class => /^lbOn/ } | |
560 | + end | |
561 | + | |
562 | + should 'offer button to cancel leaving community' do | |
563 | + community = Community.create!(:name => 'my test community') | |
564 | + community.add_member(profile) | |
565 | + | |
566 | + login_as(profile.identifier) | |
567 | + get :leave, :profile => community.identifier | |
568 | + | |
569 | + assert_tag :tag => 'a', :content => "No, I don't want." | |
570 | + end | |
571 | + | |
572 | + should 'render without layout when use lightbox to leave community' do | |
573 | + community = Community.create!(:name => 'my test community') | |
574 | + community.add_member(profile) | |
575 | + | |
576 | + @request.stubs(:xhr?).returns(true) | |
577 | + login_as(profile.identifier) | |
578 | + get :leave, :profile => community.identifier | |
579 | + | |
580 | + assert_no_tag :tag => 'body' # e.g. no layout | |
581 | + end | |
582 | + | |
583 | + should 'require login to leave community' do | |
584 | + community = Community.create!(:name => 'my test community') | |
585 | + get :leave, :profile => community.identifier | |
586 | + | |
587 | + assert_redirected_to :controller => 'account', :action => 'login' | |
588 | + end | |
589 | + | |
590 | + should 'redirect to stored location after leave community' do | |
591 | + community = Community.create!(:name => 'my test community') | |
592 | + community.add_member(profile) | |
593 | + | |
594 | + @request.session[:return_to] = "/profile/#{community.identifier}/to_go" | |
595 | + login_as(profile.identifier) | |
596 | + | |
597 | + post :leave, :profile => community.identifier, :confirmation => '1' | |
598 | + | |
599 | + assert_redirected_to "/profile/#{community.identifier}/to_go" | |
600 | + end | |
601 | + | |
602 | + should 'store referer location when request leave via get' do | |
603 | + community = Community.create!(:name => 'my test community') | |
604 | + login_as(profile.identifier) | |
605 | + | |
606 | + assert_nil @request.session[:return_to] | |
607 | + @request.expects(:referer).returns("/profile/redirect_to") | |
608 | + | |
609 | + get :leave, :profile => community.identifier | |
610 | + | |
611 | + assert_equal '/profile/redirect_to', @request.session[:return_to] | |
612 | + end | |
613 | + | |
614 | + should 'store referer location when request join via get' do | |
615 | + community = Community.create!(:name => 'my test community') | |
616 | + login_as(profile.identifier) | |
617 | + | |
618 | + assert_nil @request.session[:return_to] | |
619 | + @request.expects(:referer).returns("/profile/redirect_to") | |
620 | + | |
621 | + get :join, :profile => community.identifier | |
622 | + | |
623 | + assert_equal '/profile/redirect_to', @request.session[:return_to] | |
624 | + end | |
625 | + | |
626 | + should 'redirect to stored location after join community' do | |
627 | + community = Community.create!(:name => 'my test community') | |
628 | + | |
629 | + @request.session[:return_to] = "/profile/#{community.identifier}/to_go" | |
630 | + login_as(profile.identifier) | |
631 | + | |
632 | + post :join, :profile => community.identifier, :confirmation => '1' | |
633 | + | |
634 | + assert_redirected_to "/profile/#{community.identifier}/to_go" | |
635 | + end | |
636 | + | |
513 | 637 | end | ... | ... |
test/unit/profile_test.rb
... | ... | @@ -1370,6 +1370,16 @@ class ProfileTest < Test::Unit::TestCase |
1370 | 1370 | assert_equal "header customized", person.custom_header |
1371 | 1371 | end |
1372 | 1372 | |
1373 | + should 'provide URL to leave' do | |
1374 | + profile = Profile.create!(:name => "Test Profile", :identifier => 'testprofile', :environment_id => create_environment('mycolivre.net').id) | |
1375 | + assert_equal({ :profile => 'testprofile', :controller => 'profile', :action => 'leave'}, profile.leave_url) | |
1376 | + end | |
1377 | + | |
1378 | + should 'provide URL to join' do | |
1379 | + profile = Profile.create!(:name => "Test Profile", :identifier => 'testprofile', :environment_id => create_environment('mycolivre.net').id) | |
1380 | + assert_equal({ :profile => 'testprofile', :controller => 'profile', :action => 'join'}, profile.join_url) | |
1381 | + end | |
1382 | + | |
1373 | 1383 | private |
1374 | 1384 | |
1375 | 1385 | def assert_invalid_identifier(id) | ... | ... |