Code cleanup.

git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@9363 e93f8b46-1217-0410-a6f0-8f06a7374b81
This commit is contained in:
Jean-Philippe Lang 2012-04-06 16:51:10 +00:00
parent eabbab6e2b
commit 18270ee587
4 changed files with 17 additions and 12 deletions

View File

@ -298,6 +298,19 @@ class ApplicationController < ActionController::Base
false false
end end
# Redirects to the request referer if present, redirects to args or call block otherwise.
def redirect_to_referer_or(*args, &block)
redirect_to :back
rescue ::ActionController::RedirectBackError
if args.any?
redirect_to *args
elsif block_given?
block.call
else
raise "#redirect_to_referer_or takes arguments or a block"
end
end
def render_403(options={}) def render_403(options={})
@project = nil @project = nil
render_error({:message => :notice_not_authorized, :status => 403}.merge(options)) render_error({:message => :notice_not_authorized, :status => 403}.merge(options))

View File

@ -88,9 +88,7 @@ class AttachmentsController < ApplicationController
end end
# Make sure association callbacks are called # Make sure association callbacks are called
@attachment.container.attachments.delete(@attachment) @attachment.container.attachments.delete(@attachment)
redirect_to :back redirect_back_or_default project_path(@project)
rescue ::ActionController::RedirectBackError
redirect_to :controller => 'projects', :action => 'show', :id => @project
end end
private private

View File

@ -154,7 +154,7 @@ class UsersController < ApplicationController
respond_to do |format| respond_to do |format|
format.html { format.html {
flash[:notice] = l(:notice_successful_update) flash[:notice] = l(:notice_successful_update)
redirect_to :back redirect_to_referer_or edit_user_path(@user)
} }
format.api { head :ok } format.api { head :ok }
end end
@ -169,8 +169,6 @@ class UsersController < ApplicationController
format.api { render_validation_errors(@user) } format.api { render_validation_errors(@user) }
end end
end end
rescue ::ActionController::RedirectBackError
redirect_to :controller => 'users', :action => 'edit', :id => @user
end end
def destroy def destroy

View File

@ -52,7 +52,7 @@ class WatchersController < ApplicationController
end end
end end
respond_to do |format| respond_to do |format|
format.html { redirect_to :back } format.html { redirect_to_referer_or {render :text => 'Watcher added.', :layout => true}}
format.js do format.js do
render :update do |page| render :update do |page|
page.replace_html 'ajax-modal', :partial => 'watchers/new', :locals => {:watched => @watched} page.replace_html 'ajax-modal', :partial => 'watchers/new', :locals => {:watched => @watched}
@ -60,8 +60,6 @@ class WatchersController < ApplicationController
end end
end end
end end
rescue ::ActionController::RedirectBackError
render :text => 'Watcher added.', :layout => true
end end
def append def append
@ -120,7 +118,7 @@ private
def set_watcher(user, watching) def set_watcher(user, watching)
@watched.set_watcher(user, watching) @watched.set_watcher(user, watching)
respond_to do |format| respond_to do |format|
format.html { redirect_to :back } format.html { redirect_to_referer_or {render :text => (watching ? 'Watcher added.' : 'Watcher removed.'), :layout => true}}
format.js do format.js do
render(:update) do |page| render(:update) do |page|
c = watcher_css(@watched) c = watcher_css(@watched)
@ -130,7 +128,5 @@ private
end end
end end
end end
rescue ::ActionController::RedirectBackError
render :text => (watching ? 'Watcher added.' : 'Watcher removed.'), :layout => true
end end
end end