Module: ActionView::Helpers::ActiveRecordHelper
- Defined in:
- lib/action_view/helpers/active_record_helper.rb
Overview
The Active Record Helper makes it easier to create forms for records kept in instance variables. The most far-reaching is the form method that creates a complete form for all the basic content types of the record (not associations or aggregations, though). This is a great of making the record quickly available for editing, but likely to prove lacklusters for a complicated real-world form. In that case, it’s better to use the input method and the specialized form methods in classes/ActionView/Helpers/FormHelper.html
Instance Method Summary collapse
-
#error_message_on(object, method, prepend_text = "", append_text = "", css_class = "formError") ⇒ Object
Returns a string containing the error message attached to the
method
on theobject
, if one exists. -
#error_messages_for(object_name, options = {}) ⇒ Object
Returns a string with a div containing all the error messages for the object located as an instance variable by the name of
object_name
. -
#form(record_name, options = {}) ⇒ Object
Returns an entire form with input tags and everything for a specified Active Record object.
-
#input(record_name, method) ⇒ Object
Returns a default input tag for the type of object returned by the method.
Instance Method Details
#error_message_on(object, method, prepend_text = "", append_text = "", css_class = "formError") ⇒ Object
Returns a string containing the error message attached to the method
on the object
, if one exists. This error message is wrapped in a DIV tag, which can be specialized to include both a prepend_text
and append_text
to properly introduce the error and a css_class
to style it accordingly. Examples (post has an error message “can’t be empty” on the title attribute):
<%= error_message_on "post", "title" %> =>
<div class="formError">can't be empty</div>
<%= error_message_on "post", "title", "Title simply ", " (or it won't work)", "inputError" %> =>
<div class="inputError">Title simply can't be empty (or it won't work)</div>
77 78 79 80 81 |
# File 'lib/action_view/helpers/active_record_helper.rb', line 77 def (object, method, prepend_text = "", append_text = "", css_class = "formError") if errors = instance_eval("@#{object}").errors.on(method) "<div class=\"#{css_class}\">#{prepend_text + (errors.is_a?(Array) ? errors.first : errors) + append_text}</div>" end end |
#error_messages_for(object_name, options = {}) ⇒ Object
Returns a string with a div containing all the error messages for the object located as an instance variable by the name of object_name
. This div can be tailored by the following options:
-
header_tag
- Used for the header of the error div (default: h2) -
id
- The id of the error div (default: errorExplanation) -
class
- The class of the error div (default: errorExplanation)
89 90 91 92 93 94 95 96 97 98 99 100 101 102 |
# File 'lib/action_view/helpers/active_record_helper.rb', line 89 def (object_name, ={}) object = instance_eval "@#{object_name}" unless object.errors.empty? content_tag("div", content_tag( [:header_tag] || "h2", "#{pluralize(object.errors.count, "error")} prohibited this #{object_name.gsub("_", " ")} from being saved" ) + content_tag("p", "There were problems with the following fields:") + content_tag("ul", object.errors..collect { |msg| content_tag("li", msg) }), "id" => [:id] || "errorExplanation", "class" => [:class] || "errorExplanation" ) end end |
#form(record_name, options = {}) ⇒ Object
Returns an entire form with input tags and everything for a specified Active Record object. Example (post is a new record that has a title using VARCHAR and a body using TEXT):
form("post") =>
<form action='/post/create' method='post'>
<p>
<label for="post_title">Title</label><br />
<input id="post_title" name="post[title]" size="30" type="text" value="Hello World" />
</p>
<p>
<label for="post_body">Body</label><br />
<textarea cols="40" id="post_body" name="post[body]" rows="20" wrap="virtual">
Back to the hill and over it again!
</textarea>
</p>
<input type='submit' value='Create' />
</form>
It’s possible to specialize the form builder by using a different action name and by supplying another block renderer. Example (entry is a new record that has a message attribute using VARCHAR):
form("entry", :action => "sign", :input_block =>
Proc.new { |record, column| "#{column.human_name}: #{input(record, column.name)}<br />" }) =>
<form action='/post/sign' method='post'>
Message:
<input id="post_title" name="post[title]" size="30" type="text" value="Hello World" /><br />
<input type='submit' value='Sign' />
</form>
52 53 54 55 56 57 58 59 60 61 62 63 64 65 |
# File 'lib/action_view/helpers/active_record_helper.rb', line 52 def form(record_name, = {}) record = instance_eval("@#{record_name}") [:action] ||= record.new_record? ? "create" : "update" action = url_for(:action => [:action]) submit_value = [:submit_value] || [:action].gsub(/[^\w]/, '').capitalize id_field = record.new_record? ? "" : InstanceTag.new(record_name, "id", self).to_input_field_tag("hidden") %(<form action="#{action}" method="post">#{id_field}) + (record, record_name, ) + %(<input type="submit" value="#{submit_value}" /></form>) end |
#input(record_name, method) ⇒ Object
Returns a default input tag for the type of object returned by the method. Example (title is a VARCHAR column and holds “Hello World”):
input("post", "title") =>
<input id="post_title" name="post[title]" size="30" type="text" value="Hello World" />
20 21 22 |
# File 'lib/action_view/helpers/active_record_helper.rb', line 20 def input(record_name, method) InstanceTag.new(record_name, method, self).to_tag end |