diff options
-rw-r--r-- | actionpack/lib/action_view/helpers/javascript_helper.rb | 5 | ||||
-rw-r--r-- | actionpack/lib/action_view/helpers/javascripts/prototype.js | 67 | ||||
-rw-r--r-- | railties/html/javascripts/prototype.js | 141 |
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 |