aboutsummaryrefslogtreecommitdiffstats
path: root/app
diff options
context:
space:
mode:
authorLouise Crow <louise.crow@gmail.com>2015-06-11 10:05:28 +0100
committerLouise Crow <louise.crow@gmail.com>2015-06-12 10:11:38 +0100
commit1524f83baa3b93a506dbefe7def0c4c304f93745 (patch)
tree0cb741772e90a77fa7d79f9d0cf743f78b5e95a9 /app
parent3efe2f333a9b143e88556c0aeedb534090eb41d3 (diff)
Move updating of derived attributes to a concern.
Add spec to demonstrate that admin-added bodies aren't getting derived attributes. Add a spec to demonstrate the problem setting the first letter for translations. Demonstrate failure to update derived attributes in translations.
Diffstat (limited to 'app')
-rw-r--r--app/models/concerns/public_body_derived_fields.rb47
-rw-r--r--app/models/public_body.rb40
2 files changed, 55 insertions, 32 deletions
diff --git a/app/models/concerns/public_body_derived_fields.rb b/app/models/concerns/public_body_derived_fields.rb
new file mode 100644
index 000000000..f389e3cbf
--- /dev/null
+++ b/app/models/concerns/public_body_derived_fields.rb
@@ -0,0 +1,47 @@
+module PublicBodyDerivedFields
+
+ extend ActiveSupport::Concern
+
+ included do
+ before_save :set_first_letter
+
+ # When name or short name is changed, also change the url name
+ def short_name=(short_name)
+ super
+ update_url_name
+ end
+
+ def name=(name)
+ super
+ update_url_name
+ end
+
+ end
+
+ # Return the short name if present, or else long name
+ def short_or_long_name
+ if self.short_name.nil? || self.short_name.empty?
+ self.name.nil? ? "" : self.name
+ else
+ self.short_name
+ end
+ end
+
+ # Set the first letter, which is used for faster queries
+ def set_first_letter
+ unless name.blank?
+ # we use a regex to ensure it works with utf-8/multi-byte
+ first_letter = Unicode.upcase name.scan(/^./mu)[0]
+ if first_letter != self.first_letter
+ self.first_letter = first_letter
+ end
+ end
+ end
+
+ def update_url_name
+ if changed.include?('name') || changed.include?('short_name')
+ self.url_name = MySociety::Format.simplify_url_part(self.short_or_long_name, 'body')
+ end
+ end
+
+end
diff --git a/app/models/public_body.rb b/app/models/public_body.rb
index 5053523a3..5d6e51534 100644
--- a/app/models/public_body.rb
+++ b/app/models/public_body.rb
@@ -55,11 +55,11 @@ class PublicBody < ActiveRecord::Base
has_tag_string
before_save :set_api_key,
- :set_default_publication_scheme,
- :set_first_letter
+ :set_default_publication_scheme
after_save :purge_in_cache
after_update :reindex_requested_from
+
# Every public body except for the internal admin one is visible
scope :visible, lambda {
{
@@ -69,6 +69,11 @@ class PublicBody < ActiveRecord::Base
translates :name, :short_name, :request_email, :url_name, :notes, :first_letter, :publication_scheme
+ include PublicBodyDerivedFields
+ class Translation
+ include PublicBodyDerivedFields
+ end
+
# Default fields available for importing from CSV, in the format
# [field_name, 'short description of field (basic html allowed)']
cattr_accessor :csv_import_fields do
@@ -183,10 +188,7 @@ class PublicBody < ActiveRecord::Base
PublicBody.find(old.first)
end
- # Set the first letter, which is used for faster queries
- def set_first_letter
- PublicBody.set_first_letter(self)
- end
+
# If tagged "not_apply", then FOI/EIR no longer applies to authority at all
def not_apply?
@@ -281,32 +283,6 @@ class PublicBody < ActiveRecord::Base
end
end
- # When name or short name is changed, also change the url name
- def short_name=(short_name)
- globalize.write(Globalize.locale, :short_name, short_name)
- self[:short_name] = short_name
- self.update_url_name
- end
-
- def name=(name)
- globalize.write(Globalize.locale, :name, name)
- self[:name] = name
- self.update_url_name
- end
-
- def update_url_name
- self.url_name = MySociety::Format.simplify_url_part(self.short_or_long_name, 'body')
- end
-
- # Return the short name if present, or else long name
- def short_or_long_name
- if self.short_name.nil? || self.short_name.empty? # 'nil' can happen during construction
- self.name.nil? ? "" : self.name
- else
- self.short_name
- end
- end
-
# Guess home page from the request email, or use explicit override, or nil
# if not known.
def calculated_home_page