module ActionView
module Helpers
module FormHelper
# Returns an input tag of the "text" type tailored for accessing a specified attribute (identified by +method+) and
# that is populated with jQuery's autocomplete plugin.
#
# ==== Examples
# autocomplete_field(:post, :title, author_autocomplete_path, :size => 20)
# # =>
#
def autocomplete_field(object_name, method, source, options ={})
options["data-autocomplete"] = source
text_field(object_name, method, rewrite_autocomplete_option(options))
end
end
module FormTagHelper
# Creates a standard text field that can be populated with jQuery's autocomplete plugin
#
# ==== Examples
# autocomplete_field_tag 'address', '', address_autocomplete_path, :size => 75
# # =>
#
def autocomplete_field_tag(name, value, source, options ={})
options["data-autocomplete"] = source
text_field_tag(name, value, rewrite_autocomplete_option(options))
end
end
#
# Method used to rename the autocomplete key to a more standard
# data-autocomplete key
#
private
def rewrite_autocomplete_option(options)
options["data-autocomplete-fields"] = JSON.generate(options.delete :fields) if options[:fields]
options["data-update-elements"] = JSON.generate(options.delete :update_elements) if options[:update_elements]
options["data-id-element"] = options.delete :id_element if options[:id_element]
options["data-append-to"] = options.delete :append_to if options[:append_to]
options
end
end
end
class ActionView::Helpers::FormBuilder #:nodoc:
def autocomplete_field(method, source, options = {})
@template.autocomplete_field(@object_name, method, source, objectify_options(options))
end
end