From 7bfca7e717aca77ab8dcc629c55abe71f2e5e4bd Mon Sep 17 00:00:00 2001 From: David Heinemeier Hansson Date: Sat, 18 Mar 2006 16:08:09 +0000 Subject: [PATCH] Added :function option to PrototypeHelper#observe_field/observe_form that allows you to call a function instead of submitting an ajax call as the trigger (closes #4268) [jonathan@daikini.com] git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@3926 5ecf4fe2-1ee6-0310-87b1-e25e094e27de --- actionpack/CHANGELOG | 2 ++ actionpack/lib/action_view/helpers/prototype_helper.rb | 6 ++++-- actionpack/test/template/prototype_helper_test.rb | 10 ++++++++++ 3 files changed, 16 insertions(+), 2 deletions(-) diff --git a/actionpack/CHANGELOG b/actionpack/CHANGELOG index 4024be84c1..5d9c228007 100644 --- a/actionpack/CHANGELOG +++ b/actionpack/CHANGELOG @@ -1,5 +1,7 @@ *SVN* +* Added :function option to PrototypeHelper#observe_field/observe_form that allows you to call a function instead of submitting an ajax call as the trigger #4268 [jonathan@daikini.com] + * Make Mime::Type.parse consider q values (if any) [Jamis Buck] * XML-formatted requests are typecast according to "type" attributes for :xml_simple [Jamis Buck] diff --git a/actionpack/lib/action_view/helpers/prototype_helper.rb b/actionpack/lib/action_view/helpers/prototype_helper.rb index d49bc94517..35a671c081 100644 --- a/actionpack/lib/action_view/helpers/prototype_helper.rb +++ b/actionpack/lib/action_view/helpers/prototype_helper.rb @@ -315,9 +315,11 @@ def remote_function(options) # Observes the field with the DOM ID specified by +field_id+ and makes # an Ajax call when its contents have changed. # - # Required +options+ are: + # Required +options+ are either of: # :url:: +url_for+-style options for the action to call # when the field has changed. + # :function:: Instead of making a remote call to a URL, you + # can specify a function to be called instead. # # Additional options are: # :frequency:: The frequency (in seconds) at which changes to @@ -702,7 +704,7 @@ def build_observer(klass, name, options = {}) options[:with] ||= 'value' if options[:update] end - callback = remote_function(options) + callback = options[:function] || remote_function(options) javascript = "new #{klass}('#{name}', " javascript << "#{options[:frequency]}, " if options[:frequency] javascript << "function(element, value) {" diff --git a/actionpack/test/template/prototype_helper_test.rb b/actionpack/test/template/prototype_helper_test.rb index e0746f62e6..eb8de1ff40 100644 --- a/actionpack/test/template/prototype_helper_test.rb +++ b/actionpack/test/template/prototype_helper_test.rb @@ -108,10 +108,20 @@ def test_observe_field observe_field("glass", :frequency => 5.minutes, :url => { :action => "reorder_if_empty" }) end + def test_observe_field_using_function_for_callback + assert_dom_equal %(), + observe_field("glass", :frequency => 5.minutes, :function => "alert('Element changed')") + end + def test_observe_form assert_dom_equal %(), observe_form("cart", :frequency => 2, :url => { :action => "cart_changed" }) end + + def test_observe_form_using_function_for_callback + assert_dom_equal %(), + observe_form("cart", :frequency => 2, :function => "alert('Form changed')") + end def test_update_element_function assert_equal %($('myelement').innerHTML = 'blub';\n), -- GitLab