1
0
Fork 0
mirror of https://github.com/rails/rails.git synced 2022-11-09 12:12:34 -05:00

Update Prototype; hopefully the last change before 0.13

git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@1651 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
This commit is contained in:
Sam Stephenson 2005-07-04 05:23:28 +00:00
parent bf3a0c5391
commit 5bbc24a508

View file

@ -136,7 +136,7 @@ if (!Function.prototype.apply) {
if (!parameters) parameters = new Array();
for (var i = 0; i < parameters.length; i++)
parameterStrings[i] = 'x[' + i + ']';
parameterStrings[i] = 'parameters[' + i + ']';
object.__apply__ = this;
var result = eval('object.__apply__(' +
@ -184,6 +184,16 @@ Ajax.Base.prototype = {
asynchronous: true,
parameters: ''
}.extend(options || {});
},
responseIsSuccess: function() {
return this.transport.status == undefined
|| this.transport.status == 0
|| (this.transport.status >= 200 && this.transport.status < 300);
},
responseIsFailure: function() {
return !this.responseIsSuccess();
}
}
@ -195,7 +205,10 @@ Ajax.Request.prototype = (new Ajax.Base()).extend({
initialize: function(url, options) {
this.transport = Ajax.getTransport();
this.setOptions(options);
this.request(url);
},
request: function(url) {
var parameters = this.options.parameters || '';
if (parameters.length > 0) parameters += '&_=';
@ -221,16 +234,20 @@ Ajax.Request.prototype = (new Ajax.Base()).extend({
},
setRequestHeaders: function() {
var requestHeaders = [
'X-Requested-With', 'XMLHttpRequest',
'X-Prototype-Version', Prototype.Version];
var requestHeaders =
['X-Requested-With', 'XMLHttpRequest',
'X-Prototype-Version', Prototype.Version];
if (this.options.method == 'post') {
requestHeaders.push(
'Content-type', 'application/x-www-form-urlencoded');
if(navigator.userAgent.indexOf('Gecko')>0)
requestHeaders.push(
'Connection', 'close');
requestHeaders.push('Content-type',
'application/x-www-form-urlencoded');
/* Force "Connection: close" for Mozilla browsers to work around
* a bug where XMLHttpReqeuest sends an incorrect Content-length
* header. See Mozilla Bugzilla #246651.
*/
if (this.transport.overrideMimeType)
requestHeaders.push('Connection', 'close');
}
if (this.options.requestHeaders)
@ -249,7 +266,7 @@ Ajax.Request.prototype = (new Ajax.Base()).extend({
respondToReadyState: function(readyState) {
var event = Ajax.Request.Events[readyState];
if (event == 'Complete' && this.transport.status != 200)
if (event == 'Complete' && this.responseIsFailure())
(this.options['on' + this.transport.status]
|| this.options.onFailure
|| Prototype.emptyFunction)(this.transport);
@ -259,39 +276,35 @@ Ajax.Request.prototype = (new Ajax.Base()).extend({
});
Ajax.Updater = Class.create();
Ajax.Updater.ScriptFragmentMatch = /<script.*?>((?:\n|.)*?)<\/script>/img;
Ajax.Updater.ScriptFragment = '(?:<script.*?>)((\n|.)*?)(?:<\/script>)';
Ajax.Updater.prototype = (new Ajax.Base()).extend({
Ajax.Updater.prototype.extend(Ajax.Request.prototype).extend({
initialize: function(container, url, options) {
this.containers = {
success: container.success ? $(container.success) : $(container),
failure: container.failure ? $(container.failure) :
(container.success ? null : $(container))
failure: container.failure ?
(container.success ? null : $(container)) : null
}
this.transport = Ajax.getTransport();
this.setOptions(options);
if (this.options.asynchronous) {
this.onComplete = this.options.onComplete;
this.options.onComplete = this.updateContent.bind(this);
}
this.request = new Ajax.Request(url, this.options);
if (!this.options.asynchronous)
var onComplete = this.options.onComplete || Prototype.emptyFunction;
this.options.onComplete = (function() {
onComplete(this.transport);
this.updateContent();
}).bind(this);
this.request(url);
},
updateContent: function() {
var receiver =
(this.request.transport.status == 200) ?
var receiver = this.responseIsSuccess() ?
this.containers.success : this.containers.failure;
var response = this.request.transport.responseText.
replace(Ajax.Updater.ScriptFragmentMatch, '');
var scripts = this.request.transport.responseText.
match(Ajax.Updater.ScriptFragmentMatch);
var match = new RegExp(Ajax.Updater.ScriptFragment, 'img');
var response = this.transport.responseText.replace(match, '');
var scripts = this.transport.responseText.match(match);
if (receiver) {
if (this.options.insertion) {
@ -301,17 +314,19 @@ Ajax.Updater.prototype = (new Ajax.Base()).extend({
}
}
if (this.request.transport.status == 200)
if (this.responseIsSuccess()) {
if (this.onComplete)
setTimeout((function() {this.onComplete(
this.request.transport)}).bind(this), 10);
if (this.options.evalScripts && scripts)
setTimeout( (function() {
for(var i=0;i<scripts.length;i++)
eval(scripts[i].replace(/^<script.*?>/,'').replace(/<\/script>$/,''));
} ).bind(this), 10);
this.transport)}).bind(this), 10);
}
if (this.options.evalScripts && scripts) {
match = new RegExp(Ajax.Updater.ScriptFragment, 'im');
setTimeout((function() {
for (var i = 0; i < scripts.length; i++)
eval(scripts[i].match(match)[1]);
}).bind(this), 10);
}
}
});