diff options
author | Rafael França <rafaelmfranca@gmail.com> | 2016-04-20 01:19:51 -0300 |
---|---|---|
committer | Rafael França <rafaelmfranca@gmail.com> | 2016-04-20 01:19:51 -0300 |
commit | 2201eef7f6cd2a3430bce9d9b0b56cc14373f68c (patch) | |
tree | b019b248cca5c02678decb2dd91761958a950421 /actionview/lib | |
parent | 9918118a97c91742d94a0e677603f2e3301eebdc (diff) | |
parent | 9baedc8a963e5efc92911f32a84bc8b74a15a2e9 (diff) | |
download | rails-2201eef7f6cd2a3430bce9d9b0b56cc14373f68c.tar.gz rails-2201eef7f6cd2a3430bce9d9b0b56cc14373f68c.tar.bz2 rails-2201eef7f6cd2a3430bce9d9b0b56cc14373f68c.zip |
Merge pull request #23869 from oreoshake/to-sentence-html-safety
Add html_safe support to ActionView Array#OutputSafetyHelper
Diffstat (limited to 'actionview/lib')
-rw-r--r-- | actionview/lib/action_view/helpers/output_safety_helper.rb | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/actionview/lib/action_view/helpers/output_safety_helper.rb b/actionview/lib/action_view/helpers/output_safety_helper.rb index c0fc3b820f..d4b55423a8 100644 --- a/actionview/lib/action_view/helpers/output_safety_helper.rb +++ b/actionview/lib/action_view/helpers/output_safety_helper.rb @@ -33,6 +33,36 @@ module ActionView #:nodoc: array.flatten.map! { |i| ERB::Util.unwrapped_html_escape(i) }.join(sep).html_safe end + + # Converts the array to a comma-separated sentence where the last element is + # joined by the connector word. This is the html_safe-aware version of + # ActiveSupport's {Array#to_sentence}[http://api.rubyonrails.org/classes/Array.html#method-i-to_sentence]. + # + def to_sentence(array, options = {}) + options.assert_valid_keys(:words_connector, :two_words_connector, :last_word_connector, :locale) + + default_connectors = { + :words_connector => ', ', + :two_words_connector => ' and ', + :last_word_connector => ', and ' + } + if defined?(I18n) + i18n_connectors = I18n.translate(:'support.array', locale: options[:locale], default: {}) + default_connectors.merge!(i18n_connectors) + end + options = default_connectors.merge!(options) + + case array.length + when 0 + ''.html_safe + when 1 + ERB::Util.html_escape(array[0]) + when 2 + safe_join([array[0], array[1]], options[:two_words_connector]) + else + safe_join([safe_join(array[0...-1], options[:words_connector]), options[:last_word_connector], array[-1]]) + end + end end end end |