aboutsummaryrefslogtreecommitdiffstats
path: root/app/controllers
diff options
context:
space:
mode:
Diffstat (limited to 'app/controllers')
-rw-r--r--app/controllers/application.rb15
-rw-r--r--app/controllers/body_controller.rb3
-rw-r--r--app/controllers/help_controller.rb33
-rw-r--r--app/controllers/request_controller.rb15
4 files changed, 53 insertions, 13 deletions
diff --git a/app/controllers/application.rb b/app/controllers/application.rb
index ae2c8dd6f..c6f346907 100644
--- a/app/controllers/application.rb
+++ b/app/controllers/application.rb
@@ -6,7 +6,7 @@
# Copyright (c) 2007 UK Citizens Online Democracy. All rights reserved.
# Email: francis@mysociety.org; WWW: http://www.mysociety.org/
#
-# $Id: application.rb,v 1.50 2008-09-12 08:26:04 francis Exp $
+# $Id: application.rb,v 1.51 2008-10-07 22:05:06 francis Exp $
class ApplicationController < ActionController::Base
@@ -213,12 +213,19 @@ class ApplicationController < ActionController::Base
return InfoRequest.full_search(models, @query, order, ascending, collapse, @per_page, @page)
end
+ # Store last visited pages, for contact form
+ def set_last_request(info_request)
+ session[:last_request_id] = info_request.id
+ session[:last_body_id] = nil
+ end
+ def set_last_body(public_body)
+ session[:last_request_id] = nil
+ session[:last_body_id] = public_body.id
+ end
+
# URL generating functions are needed by all controllers (for redirects),
# views (for links) and mailers (for use in emails), so include them into
# all of all.
include LinkToHelper
end
-
-
-
diff --git a/app/controllers/body_controller.rb b/app/controllers/body_controller.rb
index b2addd045..1b113252f 100644
--- a/app/controllers/body_controller.rb
+++ b/app/controllers/body_controller.rb
@@ -4,7 +4,7 @@
# Copyright (c) 2007 UK Citizens Online Democracy. All rights reserved.
# Email: francis@mysociety.org; WWW: http://www.mysociety.org/
#
-# $Id: body_controller.rb,v 1.17 2008-09-13 15:35:37 francis Exp $
+# $Id: body_controller.rb,v 1.18 2008-10-07 22:05:06 francis Exp $
class BodyController < ApplicationController
# XXX tidy this up with better error messages, and a more standard infrastructure for the redirect to canonical URL
@@ -32,6 +32,7 @@ class BodyController < ApplicationController
redirect_to show_public_body_url(:url_name => @public_bodies[0].url_name)
end
@public_body = @public_bodies[0]
+ set_last_body(@public_body)
@track_thing = TrackThing.create_track_for_public_body(@public_body)
@feed_autodetect = [ { :url => do_track_url(@track_thing, 'feed'), :title => @track_thing.params[:title_in_rss] } ]
diff --git a/app/controllers/help_controller.rb b/app/controllers/help_controller.rb
index 0ba7da12d..5fc039b3e 100644
--- a/app/controllers/help_controller.rb
+++ b/app/controllers/help_controller.rb
@@ -4,7 +4,7 @@
# Copyright (c) 2008 UK Citizens Online Democracy. All rights reserved.
# Email: francis@mysociety.org; WWW: http://www.mysociety.org/
#
-# $Id: help_controller.rb,v 1.8 2008-10-03 17:48:37 francis Exp $
+# $Id: help_controller.rb,v 1.9 2008-10-07 22:05:06 francis Exp $
class HelpController < ApplicationController
@@ -15,24 +15,51 @@ class HelpController < ApplicationController
@contact_email = MySociety::Config.get("CONTACT_EMAIL", 'contact@localhost')
@contact_email = @contact_email.gsub(/@/, "&#64;")
+ # if they clicked remove for link to request/body, remove it
+ if params[:remove]
+ @last_request = nil
+ session[:last_request_id] = nil
+ session[:last_body_id] = nil
+ end
+
+ # look up link to request/body
+ @last_request_id = session[:last_request_id].to_i
+ if @last_request_id > 0
+ @last_request = InfoRequest.find(@last_request_id)
+ else
+ @last_request = nil
+ end
+ @last_body_id = session[:last_body_id].to_i
+ if @last_body_id > 0
+ @last_body = PublicBody.find(@last_body_id)
+ else
+ @last_body = nil
+ end
+
+ # submit form
if params[:submitted_contact_form]
if @user
params[:contact][:email] = @user.email
params[:contact][:name] = @user.name
end
@contact = ContactValidator.new(params[:contact])
- if @contact.valid?
+ if @contact.valid? && !params[:remove]
ContactMailer.deliver_message(
params[:contact][:name],
params[:contact][:email],
params[:contact][:subject],
params[:contact][:message],
- @user
+ @user,
+ @last_request, @last_body
)
flash[:notice] = "Your message has been sent. Thank you for getting in touch! We'll get back to you soon."
redirect_to frontpage_url
return
end
+
+ if params[:remove]
+ @contact.errors.clear
+ end
end
end
diff --git a/app/controllers/request_controller.rb b/app/controllers/request_controller.rb
index bb3bd8b85..2b6ff0400 100644
--- a/app/controllers/request_controller.rb
+++ b/app/controllers/request_controller.rb
@@ -4,7 +4,7 @@
# Copyright (c) 2007 UK Citizens Online Democracy. All rights reserved.
# Email: francis@mysociety.org; WWW: http://www.mysociety.org/
#
-# $Id: request_controller.rb,v 1.117 2008-10-03 17:09:05 francis Exp $
+# $Id: request_controller.rb,v 1.118 2008-10-07 22:05:06 francis Exp $
class RequestController < ApplicationController
@@ -15,9 +15,10 @@ class RequestController < ApplicationController
redirect_to request_url(@info_request)
return
end
-
+
# Look up by new style text names
@info_request = InfoRequest.find_by_url_title(params[:url_title])
+ set_last_request(@info_request)
# Other parameters
@info_request_events = @info_request.info_request_events
@@ -195,7 +196,8 @@ class RequestController < ApplicationController
# Describing state of messages post here
def describe_state
- @info_request = InfoRequest.find(params[:id])
+ @info_request = InfoRequest.find(params[:id].to_i)
+ set_last_request(@info_request)
# special case that an admin user can edit requires_admin requests
@requires_admin_describe = (@info_request.described_state == 'requires_admin') && !authenticated_user.nil? && authenticated_user.requires_admin_power?
@@ -270,8 +272,8 @@ class RequestController < ApplicationController
elsif @info_request.calculate_status == 'gone_postal'
redirect_to respond_to_last_url(@info_request) + "?gone_postal=1"
elsif @info_request.calculate_status == 'requires_admin'
- flash[:notice] = "Thanks! The WhatDoTheyKnow team have been notified. <a href=\"/help/contact\">Contact us</a> if you have more to say about how we should handle this."
- redirect_to request_url(@info_request)
+ flash[:notice] = "Please use the form below to tell us details about what is unusual about the response."
+ redirect_to help_general_url(:action => 'contact')
else
raise "unknown calculate_status " + @info_request.calculate_status
end
@@ -303,7 +305,10 @@ class RequestController < ApplicationController
else
@incoming_message = IncomingMessage.find(params[:incoming_message_id])
end
+
@info_request = InfoRequest.find(params[:id].to_i)
+ set_last_request(@info_request)
+
@collapse_quotes = params[:unfold] ? false : true
@is_owning_user = !authenticated_user.nil? && (authenticated_user.id == @info_request.user_id || authenticated_user.owns_every_request?)
@gone_postal = params[:gone_postal] ? true : false