From 7f6c5a56548233b8b02b09a1ac28d7b509bd26f7 Mon Sep 17 00:00:00 2001 From: Jeremy Kemper Date: Fri, 3 Nov 2006 04:16:58 +0000 Subject: [PATCH] Set ActionView::Base.default_form_builder once rather than passing the :builder option to every form or overriding the form helper methods. git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@5422 5ecf4fe2-1ee6-0310-87b1-e25e094e27de --- actionpack/CHANGELOG | 2 ++ .../lib/action_view/helpers/form_helper.rb | 11 ++++++-- actionpack/test/template/form_helper_test.rb | 26 ++++++++++++++++++- 3 files changed, 36 insertions(+), 3 deletions(-) diff --git a/actionpack/CHANGELOG b/actionpack/CHANGELOG index a69ce44dc14a0..20172f4a28b00 100644 --- a/actionpack/CHANGELOG +++ b/actionpack/CHANGELOG @@ -1,5 +1,7 @@ *SVN* +* Set ActionView::Base.default_form_builder once rather than passing the :builder option to every form or overriding the form helper methods. [Jeremy Kemper] + * Deprecate expire_matched_fragments. Use expire_fragment instead. #6535 [Bob Silva] * Update to latest Prototype, which doesn't serialize disabled form elements, adds clone() to arrays, empty/non-string Element.update() and adds a fixes excessive error reporting in WebKit beta versions [Thomas Fuchs] diff --git a/actionpack/lib/action_view/helpers/form_helper.rb b/actionpack/lib/action_view/helpers/form_helper.rb index 4bc5a8d254546..8aa0b42fe10ef 100644 --- a/actionpack/lib/action_view/helpers/form_helper.rb +++ b/actionpack/lib/action_view/helpers/form_helper.rb @@ -142,11 +142,13 @@ def form_for(object_name, *args, &proc) # # Note: This also works for the methods in FormOptionHelper and DateHelper that are designed to work with an object as base. # Like collection_select and datetime_select. - def fields_for(object_name, *args, &proc) + def fields_for(object_name, *args, &block) raise ArgumentError, "Missing block" unless block_given? options = args.last.is_a?(Hash) ? args.pop : {} object = args.first - yield((options[:builder] || FormBuilder).new(object_name, object, self, options, proc)) + + builder = options[:builder] || ActionView::Base.default_form_builder + yield builder.new(object_name, object, self, options, block) end # Returns an input tag of the "text" type tailored for accessing a specified attribute (identified by +method+) on an object @@ -436,4 +438,9 @@ def radio_button(method, tag_value, options = {}) end end end + + class Base + cattr_accessor :default_form_builder + self.default_form_builder = ::ActionView::Helpers::FormBuilder + end end diff --git a/actionpack/test/template/form_helper_test.rb b/actionpack/test/template/form_helper_test.rb index c177a3db22be5..a7ceb6b30f791 100644 --- a/actionpack/test/template/form_helper_test.rb +++ b/actionpack/test/template/form_helper_test.rb @@ -396,7 +396,31 @@ def test_form_for_with_labelled_builder assert_dom_equal expected, _erbout end - + + def test_default_form_builder + old_default_form_builder, ActionView::Base.default_form_builder = + ActionView::Base.default_form_builder, LabelledFormBuilder + + _erbout = '' + form_for(:post, @post) do |f| + _erbout.concat f.text_field(:title) + _erbout.concat f.text_area(:body) + _erbout.concat f.check_box(:secret) + end + + expected = + "
" + + "
" + + "
" + + " " + + "
" + + "
" + + assert_dom_equal expected, _erbout + ensure + ActionView::Base.default_form_builder = old_default_form_builder + end + # Perhaps this test should be moved to prototype helper tests. def test_remote_form_for_with_labelled_builder self.extend ActionView::Helpers::PrototypeHelper