提交 495daef0 编写于 作者: R Rafael Mendonça França

Merge pull request #12112 from adamniedzielski/fix-form-for-namespace-and-as

form_for - fix :namespace and :as options clash

Conflicts:
	actionview/CHANGELOG.md
* Fix `form_for` when both `namespace` and `as` options are present
`as` option no longer overwrites `namespace` option when generating
html id attribute of the form element
*Adam Niedzielski*
* Fix `excerpt` when `:separator` is `nil`.
*Paul Nikitochkin*
......
......@@ -442,10 +442,11 @@ def apply_form_for_options!(record, object, options) #:nodoc:
object = convert_to_model(object)
as = options[:as]
namespace = options[:namespace]
action, method = object.respond_to?(:persisted?) && object.persisted? ? [:edit, :patch] : [:new, :post]
options[:html].reverse_merge!(
class: as ? "#{action}_#{as}" : dom_class(object, action),
id: as ? "#{action}_#{as}" : [options[:namespace], dom_id(object, action)].compact.join("_").presence,
id: (as ? [namespace, action, as] : [namespace, dom_id(object, action)]).compact.join("_").presence,
method: method
)
......
......@@ -1681,6 +1681,18 @@ def test_form_for_with_namespace_with_label
assert_dom_equal expected, output_buffer
end
def test_form_for_with_namespace_and_as_option
form_for(@post, namespace: 'namespace', as: 'custom_name') do |f|
concat f.text_field(:title)
end
expected = whole_form('/posts/123', 'namespace_edit_custom_name', 'edit_custom_name', method: 'patch') do
"<input id='namespace_custom_name_title' name='custom_name[title]' type='text' value='Hello World' />"
end
assert_dom_equal expected, output_buffer
end
def test_two_form_for_with_namespace
form_for(@post, namespace: 'namespace_1') do |f|
concat f.label(:title)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册