aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDavid Heinemeier Hansson <david@loudthinking.com>2006-02-14 04:39:44 +0000
committerDavid Heinemeier Hansson <david@loudthinking.com>2006-02-14 04:39:44 +0000
commitc7f5a848f107bf294302b7eca606930168cc9e98 (patch)
treef322e9641f0e8e1576cbe3c083c1e2acda0612aa
parent35b74de7703515cf93da2d3e850702f58a2a6f48 (diff)
downloadrails-c7f5a848f107bf294302b7eca606930168cc9e98.tar.gz
rails-c7f5a848f107bf294302b7eca606930168cc9e98.tar.bz2
rails-c7f5a848f107bf294302b7eca606930168cc9e98.zip
Refactor the Javascript proxy into a hierarchy for element/collection [DHH]
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@3592 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
-rw-r--r--actionpack/lib/action_view/helpers/prototype_helper.rb42
1 files changed, 31 insertions, 11 deletions
diff --git a/actionpack/lib/action_view/helpers/prototype_helper.rb b/actionpack/lib/action_view/helpers/prototype_helper.rb
index 9a65fee855..8a4498ae89 100644
--- a/actionpack/lib/action_view/helpers/prototype_helper.rb
+++ b/actionpack/lib/action_view/helpers/prototype_helper.rb
@@ -424,7 +424,7 @@ module ActionView
# page['blank_slate'].show # => $('blank_slate').show();
# page['blank_slate'].show('first').up # => $('blank_slate').show('first').up();
def [](id)
- JavaScriptElementProxy.new(self, "$('#{id}')")
+ JavaScriptElementProxy.new(self, id)
end
# Returns a collection reference by finding it through a CSS +pattern+ in the DOM. This collection can then be
@@ -434,7 +434,7 @@ module ActionView
# page.select('p.welcome b').first # => $$('p.welcome b').first();
# page.select('p.welcome b').first.hide # => $$('p.welcome b').first().hide();
def select(pattern)
- JavaScriptElementProxy.new(self, "$$('#{pattern}')")
+ JavaScriptCollectionProxy.new(self, pattern)
end
# Inserts HTML at the specified +position+ relative to the DOM element
@@ -666,20 +666,12 @@ module ActionView
end
# Converts chained method calls on DOM proxy elements into JavaScript chains
- class JavaScriptElementProxy < Builder::BlankSlate #:nodoc:
+ class JavaScriptProxy < Builder::BlankSlate #:nodoc:
def initialize(generator, root)
@generator = generator
@generator << root
end
- def replace_html(*options_for_render)
- call 'update', @generator.render(*options_for_render)
- end
-
- def replace(*options_for_render)
- call 'replace', @generator.render(*options_for_render)
- end
-
private
def method_missing(method, *arguments)
if method.to_s =~ /(.*)=$/
@@ -707,5 +699,33 @@ module ActionView
function_chain[-1] += ".#{call};"
end
end
+
+ class JavaScriptElementProxy < JavaScriptProxy #:nodoc:
+ def initialize(generator, id)
+ @id = id
+ super(generator, "$('#{id}')")
+ end
+
+ def replace_html(*options_for_render)
+ call 'update', @generator.send(:render, *options_for_render)
+ end
+
+ def replace(*options_for_render)
+ call 'replace', @generator.send(:render, *options_for_render)
+ end
+
+ def reload
+ replace :partial => @id.to_s
+ end
+ end
+
+ class JavaScriptCollectionProxy < JavaScriptProxy #:nodoc:
+ def initialize(generator, pattern)
+ @pattern = pattern
+ super(generator, "$$('#{pattern}')")
+ end
+
+ # TODO: Implement funky stuff like .each
+ end
end
end