# frozen_string_literal: true require "cgi" class Object # Alias of to_s. def to_param to_s end # Converts an object into a string suitable for use as a URL query string, # using the given key as the param name. def to_query(key) "#{CGI.escape(key.to_param)}=#{CGI.escape(to_param.to_s)}" end end class NilClass # Returns +self+. def to_param self end end class TrueClass # Returns +self+. def to_param self end end class FalseClass # Returns +self+. def to_param self end end class Array # Converts an array into a string suitable for use as a URL query string, # using the given +key+ as the param name. # # ["Rails", "coding"].to_query("hobbies") # # => "hobbies%5B%5D=Rails&hobbies%5B%5D=coding" def to_query(key) prefix = "#{key}[]" if empty? nil.to_query(prefix) else collect {|value| value.to_query(prefix) }.join "&" end end end class Hash # Returns a string representation of the receiver suitable for use as a URL # query string: # # {name: 'David', nationality: 'Danish'}.to_query # # => "name=David&nationality=Danish" # # An optional namespace can be passed to enclose key names: # # {name: 'David', nationality: 'Danish'}.to_query('user') # # => "user%5Bname%5D=David&user%5Bnationality%5D=Danish" # # The string pairs "key=value" that conform the query string # are sorted lexicographically in ascending order. # # This method is also aliased as +to_param+. def to_query(namespace = nil) filter_map do |key, value| unless (value.is_a?(Hash) || value.is_a?(Array)) && value.empty? value.to_query(namespace ? "#{namespace}[#{key}]" : key) end end.sort! * "&" end alias to_param to_query end