Module: ActiveSupport::CoreExtensions::Array::Conversions
- Included in:
- Array
- Defined in:
- lib/active_support/core_ext/array/conversions.rb
Class Method Summary collapse
-
.included(base) ⇒ Object
:nodoc:.
Instance Method Summary collapse
- #to_formatted_s(format = :default) ⇒ Object
-
#to_param ⇒ Object
Calls to_param on all its elements and joins the result with slashes.
-
#to_query(key) ⇒ Object
Converts an array into a string suitable for use as a URL query string, using the given
key
as the param name. -
#to_sentence(options = {}) ⇒ Object
Converts the array to a comma-separated sentence where the last element is joined by the connector word.
- #to_xml(options = {}) ⇒ Object
Class Method Details
.included(base) ⇒ Object
:nodoc:
41 42 43 44 45 46 |
# File 'lib/active_support/core_ext/array/conversions.rb', line 41 def self.included(base) #:nodoc: base.class_eval do alias_method :to_default_s, :to_s alias_method :to_s, :to_formatted_s end end |
Instance Method Details
#to_formatted_s(format = :default) ⇒ Object
48 49 50 51 52 53 54 55 56 57 58 59 |
# File 'lib/active_support/core_ext/array/conversions.rb', line 48 def to_formatted_s(format = :default) case format when :db if respond_to?(:empty?) && self.empty? "null" else collect { |element| element.id }.join(",") end else to_default_s end end |
#to_param ⇒ Object
Calls to_param on all its elements and joins the result with slashes. This is used by url_for in Action Pack.
28 29 30 |
# File 'lib/active_support/core_ext/array/conversions.rb', line 28 def to_param map(&:to_param).join '/' end |
#to_query(key) ⇒ Object
Converts an array into a string suitable for use as a URL query string, using the given key
as the param name.
Example:
['Rails', 'coding'].to_query('hobbies') => "hobbies%5B%5D=Rails&hobbies%5B%5D=coding"
37 38 39 |
# File 'lib/active_support/core_ext/array/conversions.rb', line 37 def to_query(key) collect { |value| value.to_query("#{key}[]") } * '&' end |
#to_sentence(options = {}) ⇒ Object
Converts the array to a comma-separated sentence where the last element is joined by the connector word. Options:
-
:connector
- The word used to join the last element in arrays with two or more elements (default: “and”) -
:skip_last_comma
- Set to true to return “a, b and c” instead of “a, b, and c”.
10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 |
# File 'lib/active_support/core_ext/array/conversions.rb', line 10 def to_sentence( = {}) .assert_valid_keys(:connector, :skip_last_comma) .reverse_merge! :connector => 'and', :skip_last_comma => false [:connector] = "#{[:connector]} " unless [:connector].nil? || [:connector].strip == '' case length when 0 "" when 1 self[0].to_s when 2 "#{self[0]} #{[:connector]}#{self[1]}" else "#{self[0...-1].join(', ')}#{[:skip_last_comma] ? '' : ','} #{[:connector]}#{self[-1]}" end end |
#to_xml(options = {}) ⇒ Object
61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 |
# File 'lib/active_support/core_ext/array/conversions.rb', line 61 def to_xml( = {}) raise "Not all elements respond to to_xml" unless all? { |e| e.respond_to? :to_xml } [:root] ||= all? { |e| e.is_a?(first.class) && first.class.to_s != "Hash" } ? first.class.to_s.underscore.pluralize : "records" [:children] ||= [:root].singularize [:indent] ||= 2 [:builder] ||= Builder::XmlMarkup.new(:indent => [:indent]) root = .delete(:root).to_s children = .delete(:children) if !.has_key?(:dasherize) || [:dasherize] root = root.dasherize end [:builder].instruct! unless .delete(:skip_instruct) opts = .merge({ :root => children }) xml = [:builder] if empty? xml.tag!(root, [:skip_types] ? {} : {:type => "array"}) else xml.tag!(root, [:skip_types] ? {} : {:type => "array"}) { yield xml if block_given? each { |e| e.to_xml(opts.merge!({ :skip_instruct => true })) } } end end |