mirror of
https://github.com/github/rails.git
synced 2026-04-26 03:00:59 -04:00
Fix label form helper to use I18n and html options, without the need of 'nil' text param:
Before: f.label :title, nil, :class => 'title' After : f.label :title, :class => 'title' [#5267 state:committed] Signed-off-by: Santiago Pastorino <santiago@wyeworks.com>
This commit is contained in:
committed by
Santiago Pastorino
parent
fb0bd8c109
commit
11614bddc0
@@ -215,7 +215,7 @@ module ActionView
|
||||
# ...
|
||||
# <% end %>
|
||||
#
|
||||
# If your resource has associations defined, for example, you want to add comments
|
||||
# If your resource has associations defined, for example, you want to add comments
|
||||
# to the post given that the routes are set correctly:
|
||||
#
|
||||
# <%= form_for([@document, @comment]) do |f| %>
|
||||
@@ -583,8 +583,9 @@ module ActionView
|
||||
# 'Accept <a href="/terms">Terms</a>.'
|
||||
# end
|
||||
def label(object_name, method, content_or_options = nil, options = nil, &block)
|
||||
if block_given?
|
||||
options = content_or_options if content_or_options.is_a?(Hash)
|
||||
content_is_options = content_or_options.is_a?(Hash)
|
||||
if content_is_options || block_given?
|
||||
options = content_or_options if content_is_options
|
||||
text = nil
|
||||
else
|
||||
text = content_or_options
|
||||
|
||||
@@ -120,6 +120,13 @@ class FormHelperTest < ActionView::TestCase
|
||||
I18n.locale = old_locale
|
||||
end
|
||||
|
||||
def test_label_with_locales_and_options
|
||||
old_locale, I18n.locale = I18n.locale, :label
|
||||
assert_dom_equal('<label for="post_body" class="post_body">Write entire text here</label>', label(:post, :body, :class => 'post_body'))
|
||||
ensure
|
||||
I18n.locale = old_locale
|
||||
end
|
||||
|
||||
def test_label_with_for_attribute_as_symbol
|
||||
assert_dom_equal('<label for="my_for">Title</label>', label(:post, :title, nil, :for => "my_for"))
|
||||
end
|
||||
@@ -620,7 +627,7 @@ class FormHelperTest < ActionView::TestCase
|
||||
|
||||
def test_form_for_with_symbol_object_name
|
||||
form_for(@post, :as => "other_name", :html => { :id => 'create-post' }) do |f|
|
||||
concat f.label(:title)
|
||||
concat f.label(:title, :class => 'post_title')
|
||||
concat f.text_field(:title)
|
||||
concat f.text_area(:body)
|
||||
concat f.check_box(:secret)
|
||||
@@ -628,7 +635,7 @@ class FormHelperTest < ActionView::TestCase
|
||||
end
|
||||
|
||||
expected = whole_form("/posts/123", "create-post", "other_name_edit", :method => "put") do
|
||||
"<label for='other_name_title'>Title</label>" +
|
||||
"<label for='other_name_title' class='post_title'>Title</label>" +
|
||||
"<input name='other_name[title]' size='30' id='other_name_title' value='Hello World' type='text' />" +
|
||||
"<textarea name='other_name[body]' id='other_name_body' rows='20' cols='40'>Back to the hill and over it again!</textarea>" +
|
||||
"<input name='other_name[secret]' value='0' type='hidden' />" +
|
||||
|
||||
Reference in New Issue
Block a user