aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--actionpack/lib/action_view/helpers/javascript_helper.rb5
-rw-r--r--actionpack/lib/action_view/helpers/javascripts/prototype.js67
-rw-r--r--railties/html/javascripts/prototype.js141
3 files changed, 194 insertions, 19 deletions
diff --git a/actionpack/lib/action_view/helpers/javascript_helper.rb b/actionpack/lib/action_view/helpers/javascript_helper.rb
index 513074cddd..1d70073069 100644
--- a/actionpack/lib/action_view/helpers/javascript_helper.rb
+++ b/actionpack/lib/action_view/helpers/javascript_helper.rb
@@ -158,8 +158,9 @@ module ActionView
js_options = build_callbacks(options)
js_options['asynchronous'] = options[:type] != :synchronous
- js_options['method'] = options[:method] if options[:method]
- js_options['effect'] = ("\'"+options[:effect].to_s+"\'") if options[:effect]
+ js_options['method'] = options[:method] if options[:method]
+ js_options['position'] = options[:position] ? "'#{options[:position].to_s}'" : "'replace'"
+ js_options['effect'] = ("\'"+options[:effect].to_s+"\'") if options[:effect]
if options[:form]
js_options['parameters'] = 'Form.serialize(this)'
diff --git a/actionpack/lib/action_view/helpers/javascripts/prototype.js b/actionpack/lib/action_view/helpers/javascripts/prototype.js
index d634c5c6b5..60dbd5d419 100644
--- a/actionpack/lib/action_view/helpers/javascripts/prototype.js
+++ b/actionpack/lib/action_view/helpers/javascripts/prototype.js
@@ -135,7 +135,8 @@ Ajax.Base.prototype = {
this.options = {
method: 'post',
asynchronous: true,
- parameters: ''
+ parameters: '',
+ position: 'replace'
}.extend(options || {});
}
}
@@ -204,9 +205,17 @@ Ajax.Updater.prototype = (new Ajax.Base()).extend({
updateContent: function() {
this.container.innerHTML = this.request.transport.responseText;
+
+ if (this.options.position.toLowerCase() == 'replace') {
+ this.container.innerHTML = this.request.transport.responseText;
+ } else {
+ Insert[this.options.position.toLowerCase()]( this.container, this.request.transport.responseText );
+ }
+
switch(this.options.effect) {
case 'highlight': new YellowFader(this.container); break;
}
+
if (this.onComplete) this.onComplete(this.request);
}
});
@@ -382,4 +391,58 @@ YellowFader.prototype = {
highlight: function(element, current) {
element.style.backgroundColor = "#ffff" + current.toColorPart();
}
-} \ No newline at end of file
+}
+
+/*--------------------------------------------------------------------------*/
+
+Insert = {
+ before_begin: function(dom, html) {
+ dom = $(dom);
+ if (dom.insertAdjacentHTML) {
+ dom.insertAdjacentHTML('BeforeBegin', html);
+ } else {
+ var r = dom.ownerDocument.createRange();
+ r.setStartBefore(dom);
+ var df = r.createContextualFragment(html);
+ dom.parentNode.insertBefore(df, dom);
+ }
+ },
+
+ after_begin: function(dom, html) {
+ dom = $(dom);
+ if (dom.insertAdjacentHTML) {
+ dom.insertAdjacentHTML('AfterBegin', html);
+ } else {
+ var r = dom.ownerDocument.createRange();
+ r.selectNodeContents(dom);
+ r.collapse(true);
+ var df = r.createContextualFragment( html );
+ dom.insertBefore(df, dom.firstChild );
+ }
+ },
+
+ before_end: function(dom, html) {
+ dom = $(dom);
+ if (dom.insertAdjacentHTML) {
+ dom.insertAdjacentHTML('BeforeEnd', html);
+ } else {
+ var r = dom.ownerDocument.createRange();
+ r.selectNodeContents(dom);
+ r.collapse(dom);
+ var df = r.createContextualFragment(html);
+ dom.appendChild(df);
+ }
+ },
+
+ after_end: function(dom, html) {
+ dom = $(dom);
+ if (dom.insertAdjacentHTML) {
+ dom.insertAdjacentHTML('BeforeBegin', html);
+ } else {
+ var r = dom.ownerDocument.createRange();
+ r.setStartAfter(dom);
+ var df = r.createContextualFragment( html );
+ dom.parentNode.insertBefore(df, dom.nextSibling);
+ }
+ }
+}; \ No newline at end of file
diff --git a/railties/html/javascripts/prototype.js b/railties/html/javascripts/prototype.js
index 46100c31a6..60dbd5d419 100644
--- a/railties/html/javascripts/prototype.js
+++ b/railties/html/javascripts/prototype.js
@@ -58,8 +58,8 @@ Try = {
Toggle = {
display: function() {
- for (var i = 0; i < elements.length; i++) {
- var element = $(elements[i]);
+ for (var i = 0; i < arguments.length; i++) {
+ var element = $(arguments[i]);
element.style.display =
(element.style.display == 'none' ? '' : 'none');
}
@@ -86,23 +86,35 @@ function $() {
}
function getElementsByClassName(className, element) {
- var children = (element || document).getElementsByTagName('*');
+ var all = document.all ? document.all : document.getElementsByTagName(element);
var elements = new Array();
-
- for (var i = 0; i < children.length; i++) {
- var child = children[i];
- var classNames = child.className.split(' ');
- for (var j = 0; j < classNames.length; j++) {
- if (classNames[j] == className) {
- elements.push(child);
- break;
- }
- }
+
+ for (var e = 0; e < all.length; e++) {
+ if (all[e].className == className)
+ elements[elements.length] = all[e];
}
-
+
return elements;
}
+// function getElementsByClassName(className, element) {
+// var children = (element || document).getElementsByTagName('*');
+// var elements = new Array();
+//
+// for (var i = 0; i < children.length; i++) {
+// var child = children[i];
+// var classNames = child.className.split(' ');
+// for (var j = 0; j < classNames.length; j++) {
+// if (classNames[j] == className) {
+// elements.push(child);
+// break;
+// }
+// }
+// }
+//
+// return elements;
+// }
+
/*--------------------------------------------------------------------------*/
Ajax = {
@@ -123,7 +135,8 @@ Ajax.Base.prototype = {
this.options = {
method: 'post',
asynchronous: true,
- parameters: ''
+ parameters: '',
+ position: 'replace'
}.extend(options || {});
}
}
@@ -192,6 +205,17 @@ Ajax.Updater.prototype = (new Ajax.Base()).extend({
updateContent: function() {
this.container.innerHTML = this.request.transport.responseText;
+
+ if (this.options.position.toLowerCase() == 'replace') {
+ this.container.innerHTML = this.request.transport.responseText;
+ } else {
+ Insert[this.options.position.toLowerCase()]( this.container, this.request.transport.responseText );
+ }
+
+ switch(this.options.effect) {
+ case 'highlight': new YellowFader(this.container); break;
+ }
+
if (this.onComplete) this.onComplete(this.request);
}
});
@@ -335,3 +359,90 @@ Form.Observer.prototype = (new Abstract.TimedObserver()).extend({
}
});
+/*--------------------------------------------------------------------------*/
+
+Number.prototype.toColorPart = function() {
+ var digits = this.toString(16);
+ if (this < 16) return '0' + digits;
+ return digits;
+}
+
+var YellowFader = Class.create();
+YellowFader.prototype = {
+ initialize: function(element) {
+ if (typeof element == 'string') element = $(element);
+ if (!element) return;
+ this.element = element;
+ this.start = 153;
+ this.finish = 255;
+ this.current = this.start;
+ this.fade();
+ },
+ fade: function() {
+ if (this.isFinished()) return;
+ if (this.timer) clearTimeout(this.timer); // prevent flicker
+ this.highlight(this.element, this.current);
+ this.current += 17;
+ this.timer = setTimeout(this.fade.bind(this), 250);
+ },
+ isFinished: function() {
+ return this.current > this.finish;
+ },
+ highlight: function(element, current) {
+ element.style.backgroundColor = "#ffff" + current.toColorPart();
+ }
+}
+
+/*--------------------------------------------------------------------------*/
+
+Insert = {
+ before_begin: function(dom, html) {
+ dom = $(dom);
+ if (dom.insertAdjacentHTML) {
+ dom.insertAdjacentHTML('BeforeBegin', html);
+ } else {
+ var r = dom.ownerDocument.createRange();
+ r.setStartBefore(dom);
+ var df = r.createContextualFragment(html);
+ dom.parentNode.insertBefore(df, dom);
+ }
+ },
+
+ after_begin: function(dom, html) {
+ dom = $(dom);
+ if (dom.insertAdjacentHTML) {
+ dom.insertAdjacentHTML('AfterBegin', html);
+ } else {
+ var r = dom.ownerDocument.createRange();
+ r.selectNodeContents(dom);
+ r.collapse(true);
+ var df = r.createContextualFragment( html );
+ dom.insertBefore(df, dom.firstChild );
+ }
+ },
+
+ before_end: function(dom, html) {
+ dom = $(dom);
+ if (dom.insertAdjacentHTML) {
+ dom.insertAdjacentHTML('BeforeEnd', html);
+ } else {
+ var r = dom.ownerDocument.createRange();
+ r.selectNodeContents(dom);
+ r.collapse(dom);
+ var df = r.createContextualFragment(html);
+ dom.appendChild(df);
+ }
+ },
+
+ after_end: function(dom, html) {
+ dom = $(dom);
+ if (dom.insertAdjacentHTML) {
+ dom.insertAdjacentHTML('BeforeBegin', html);
+ } else {
+ var r = dom.ownerDocument.createRange();
+ r.setStartAfter(dom);
+ var df = r.createContextualFragment( html );
+ dom.parentNode.insertBefore(df, dom.nextSibling);
+ }
+ }
+}; \ No newline at end of file