diff options
Diffstat (limited to 'framework/Web/Javascripts')
| -rw-r--r-- | framework/Web/Javascripts/js/ajax.js | 18 | ||||
| -rw-r--r-- | framework/Web/Javascripts/js/prado.js | 10 | ||||
| -rw-r--r-- | framework/Web/Javascripts/prado/ajax3.js | 49 | ||||
| -rw-r--r-- | framework/Web/Javascripts/prado/element.js | 12 | 
4 files changed, 61 insertions, 28 deletions
| diff --git a/framework/Web/Javascripts/js/ajax.js b/framework/Web/Javascripts/js/ajax.js index 6ae737bf..375d90e9 100644 --- a/framework/Web/Javascripts/js/ajax.js +++ b/framework/Web/Javascripts/js/ajax.js @@ -22,7 +22,8 @@ if(this.responseIsSuccess()){if(this.onComplete)  setTimeout(this.onComplete.bind(this),10);}}});Ajax.PeriodicalUpdater=Class.create();Ajax.PeriodicalUpdater.prototype=Object.extend(new Ajax.Base(),{initialize:function(container,url,options){this.setOptions(options);this.onComplete=this.options.onComplete;this.frequency=(this.options.frequency||2);this.decay=(this.options.decay||1);this.updater={};this.container=container;this.url=url;this.start();},start:function(){this.options.onComplete=this.updateComplete.bind(this);this.onTimerEvent();},stop:function(){this.updater.onComplete=undefined;clearTimeout(this.timer);(this.onComplete||Prototype.emptyFunction).apply(this,arguments);},updateComplete:function(request){if(this.options.decay){this.decay=(request.responseText==this.lastText?this.decay*this.options.decay:1);this.lastText=request.responseText;}  this.timer=setTimeout(this.onTimerEvent.bind(this),this.decay*this.frequency*1000);},onTimerEvent:function(){this.updater=new Ajax.Updater(this.container,this.url,this.options);}});Object.extend(Ajax.Request.prototype,{respondToReadyState:function(readyState)  {var event=Ajax.Request.Events[readyState];var transport=this.transport,json=this.getHeaderData(Prado.CallbackRequest.DATA_HEADER);if(event=='Complete') -{Ajax.Responders.dispatch('on'+transport.status,this,transport,json);Prado.CallbackRequest.dispatchActions(this.getHeaderData(Prado.CallbackRequest.ACTION_HEADER));try{(this.options['on'+this.transport.status]||this.options['on'+(this.responseIsSuccess()?'Success':'Failure')]||Prototype.emptyFunction)(transport,json);}catch(e){this.dispatchException(e);} +{try +{Ajax.Responders.dispatch('on'+transport.status,this,transport,json);Prado.CallbackRequest.dispatchActions(transport,this.getHeaderData(Prado.CallbackRequest.ACTION_HEADER));(this.options['on'+this.transport.status]||this.options['on'+(this.responseIsSuccess()?'Success':'Failure')]||Prototype.emptyFunction)(transport,json);}catch(e){this.dispatchException(e);}  if((this.header('Content-type')||'').match(/^text\/javascript/i))  this.evalResponse();}  try{(this.options['on'+event]||Prototype.emptyFunction)(transport,json);Ajax.Responders.dispatch('on'+event,this,transport,json);}catch(e){this.dispatchException(e);} @@ -33,12 +34,13 @@ this.transport.onreadystatechange=Prototype.emptyFunction;},getHeaderData:functi  catch(e)  {if(typeof(json)=="string")  {Logger.info("using json") -return Prado.CallbackRequest.decode(json);}}}});Prado.CallbackRequest=Class.create();Object.extend(Prado.CallbackRequest,{FIELD_CALLBACK_TARGET:'PRADO_CALLBACK_TARGET',FIELD_CALLBACK_PARAMETER:'PRADO_CALLBACK_PARAMETER',PostDataLoaders:['PRADO_PAGESTATE'],DATA_HEADER:'X-PRADO-DATA',ACTION_HEADER:'X-PRADO-ACTIONS',ERROR_HEADER:'X-PRADO-ERROR',dispatchActions:function(actions) -{actions.each(this.__run);},__run:function(command) +return Prado.CallbackRequest.decode(json);}}}});Prado.CallbackRequest=Class.create();Object.extend(Prado.CallbackRequest,{FIELD_CALLBACK_TARGET:'PRADO_CALLBACK_TARGET',FIELD_CALLBACK_PARAMETER:'PRADO_CALLBACK_PARAMETER',FIELD_CALLBACK_PAGESTATE:'PRADO_PAGESTATE',PostDataLoaders:[],DATA_HEADER:'X-PRADO-DATA',ACTION_HEADER:'X-PRADO-ACTIONS',ERROR_HEADER:'X-PRADO-ERROR',dispatchActions:function(transport,actions) +{if(actions&&actions.length>0) +actions.each(this.__run.bind(this,transport));},__run:function(transport,command)  {for(var method in command)  {if(command[method][0])  {var id=command[method][0];if($(id)||id.indexOf("[]")>-1) -method.toFunction().apply(this,command[method]);else if(typeof(Logger)!="undefined") +method.toFunction().apply(this,command[method].concat(transport));else if(typeof(Logger)!="undefined")  {Logger.error("Error in executing callback response:","Unable to find HTML element with ID '"+id+"' before executing "+method+"().");}}}},Exception:{"on505":function(request,transport,data)  {var e=request.getHeaderData(Prado.CallbackRequest.ERROR_HEADER);Logger.error("Callback Server Error "+e.code,this.formatException(e));},'on200':function(request,transport,data)  {if(transport.status<500) @@ -59,12 +61,14 @@ Object.extend(this.options||{},request);if(this.options.CausesValidation!=false&  {var form=this.options.Form||Prado.Validation.getForm();if(Prado.Validation.validate(form,this.options.ValidationGroup,this)==false)  return;}  this.request=new Ajax.Request(this.url,this.options);},_getPostData:function() -{var data={};Prado.CallbackRequest.PostDataLoaders.each(function(name) +{var data={};var callback=Prado.CallbackRequest;if(this.options.PostState!=false) +{callback.PostDataLoaders.each(function(name)  {$A(document.getElementsByName(name)).each(function(element)  {var value=$F(element);if(typeof(value)!="undefined") -data[name]=value;})}) +data[name]=value;})})}  if(typeof(this.options.params)!="undefined") -data[Prado.CallbackRequest.FIELD_CALLBACK_PARAMETER]=Prado.CallbackRequest.encode(this.options.params);data[Prado.CallbackRequest.FIELD_CALLBACK_TARGET]=this.id;return $H(data).toQueryString();}} +data[callback.FIELD_CALLBACK_PARAMETER]=callback.encode(this.options.params);var pageState=$F(callback.FIELD_CALLBACK_PAGESTATE);if(typeof(pageState)!="undefined") +data[callback.FIELD_CALLBACK_PAGESTATE]=pageState;data[callback.FIELD_CALLBACK_TARGET]=this.id;return $H(data).toQueryString();}}  Prado.Callback=function(UniqueID,parameter,onSuccess,options)  {var callback={'params':parameter||'','onSuccess':onSuccess||Prototype.emptyFunction,'CausesValidation':true};Object.extend(callback,options||{});new Prado.CallbackRequest(UniqueID,callback);return false;}  Array.prototype.______array='______array';Prado.JSON={org:'http://www.JSON.org',copyright:'(c)2005 JSON.org',license:'http://www.crockford.com/JSON/license.html',stringify:function(arg){var c,i,l,s='',v;switch(typeof arg){case'object':if(arg){if(arg.______array=='______array'){for(i=0;i<arg.length;++i){v=this.stringify(arg[i]);if(s){s+=',';} diff --git a/framework/Web/Javascripts/js/prado.js b/framework/Web/Javascripts/js/prado.js index d80f984d..f6c52983 100644 --- a/framework/Web/Javascripts/js/prado.js +++ b/framework/Web/Javascripts/js/prado.js @@ -256,7 +256,7 @@ selection[method](isList?element:el,value);},click:function(element)  {var el=$(element);if(!el)return;if(document.createEvent)  {var evt=document.createEvent('HTMLEvents');evt.initEvent('click',true,true);el.dispatchEvent(evt);}  else if(el.fireEvent) -{el.fireEvent('onclick');if(isFunction(el.onclick)) +{el.fireEvent('onclick');if(typeof(el.onclick)=="function")  el.onclick();}},setAttribute:function(element,attribute,value)  {var el=$(element);if(attribute=="disabled"&&value==false)  el.removeAttribute(attribute);else @@ -265,8 +265,12 @@ el.setAttribute(attribute,value);},setOptions:function(element,options)  {while(el.length>0)  el.remove(0);for(var i=0;i<options.length;i++)  el.options[el.options.length]=new Option(options[i][0],options[i][1]);}},focus:function(element) -{var obj=$(element);if(isObject(obj)&&isdef(obj.focus)) -setTimeout(function(){obj.focus();},100);return false;}} +{var obj=$(element);if(typeof(obj)!="undefined"&&typeof(obj.focus)!="undefined") +setTimeout(function(){obj.focus();},100);return false;},replaceContent:function(element,method,content,boundary,transport) +{if(boundary) +{var f=RegExp('(<!--'+boundary+'-->)([\\s\\S\\w\\W]*)(<!--//'+boundary+'-->)',"m");var result=transport.responseText.match(f);if(result&&result.length>=2) +content=result[2];} +method.toFunction().apply(this,[element,content]);}}  Prado.Element.Selection={inputValue:function(el,value)  {switch(el.type.toLowerCase())  {case'checkbox':case'radio':return el.checked=value;}},selectValue:function(el,value) diff --git a/framework/Web/Javascripts/prado/ajax3.js b/framework/Web/Javascripts/prado/ajax3.js index 1cffbd73..63add490 100644 --- a/framework/Web/Javascripts/prado/ajax3.js +++ b/framework/Web/Javascripts/prado/ajax3.js @@ -13,11 +13,13 @@ Object.extend(Ajax.Request.prototype,  	    var transport = this.transport, json = this.getHeaderData(Prado.CallbackRequest.DATA_HEADER);
  	    if (event == 'Complete') 
 -	    {
 +	    {	      
 +	      try 
 +	      {
  			Ajax.Responders.dispatch('on' + transport.status, this, transport, json);
 -			Prado.CallbackRequest.dispatchActions(this.getHeaderData(Prado.CallbackRequest.ACTION_HEADER));
 -	      
 -	      try {
 +			Prado.CallbackRequest.dispatchActions(transport,this.getHeaderData(Prado.CallbackRequest.ACTION_HEADER));
 +	      	
 +	      	
  	        (this.options['on' + this.transport.status]
  	         || this.options['on' + (this.responseIsSuccess() ? 'Success' : 'Failure')]
  	         || Prototype.emptyFunction)(transport, json);
 @@ -82,9 +84,13 @@ Object.extend(Prado.CallbackRequest,  	 */
  	FIELD_CALLBACK_PARAMETER : 'PRADO_CALLBACK_PARAMETER',
  	/**
 +	 * Callback request page state field name,
 +	 */
 +	FIELD_CALLBACK_PAGESTATE : 'PRADO_PAGESTATE',
 +	/**
  	 * List of form fields that will be collected during callback.
  	 */
 -	PostDataLoaders : ['PRADO_PAGESTATE'],
 +	PostDataLoaders : [],
  	/**
  	 * Response data header name.
  	 */
 @@ -101,15 +107,16 @@ Object.extend(Prado.CallbackRequest,  	/**
  	 * Dispatch callback response actions.
  	 */
 -	dispatchActions : function(actions)
 +	dispatchActions : function(transport,actions)
  	{
 -		actions.each(this.__run);
 +		if(actions && actions.length > 0)
 +			actions.each(this.__run.bind(this,transport));
  	},
  	/**
  	 * Prase and evaluate a Callback clien-side action
  	 */
 -	__run : function(command)
 +	__run : function(transport, command)
  	{
  		for(var method in command)
  		{
 @@ -117,7 +124,7 @@ Object.extend(Prado.CallbackRequest,  			{
  				var id = command[method][0];
  				if($(id) || id.indexOf("[]") > -1)
 -					method.toFunction().apply(this,command[method]);
 +					method.toFunction().apply(this,command[method].concat(transport));
  				else if(typeof(Logger) != "undefined")
  				{
  					Logger.error("Error in executing callback response:", 
 @@ -269,19 +276,25 @@ Prado.CallbackRequest.prototype =  	_getPostData : function()
  	{
  		var data = {};
 -		
 -		Prado.CallbackRequest.PostDataLoaders.each(function(name)
 +		var callback = Prado.CallbackRequest;
 +		if(this.options.PostState != false)
  		{
 -			$A(document.getElementsByName(name)).each(function(element)
 +			callback.PostDataLoaders.each(function(name)
  			{
 -				var value = $F(element);
 -				if(typeof(value) != "undefined")
 -					data[name] = value;
 +				$A(document.getElementsByName(name)).each(function(element)
 +				{
 +					var value = $F(element);
 +					if(typeof(value) != "undefined")
 +						data[name] = value;
 +				})
  			})
 -		})
 +		}
  		if(typeof(this.options.params) != "undefined")
 -			data[Prado.CallbackRequest.FIELD_CALLBACK_PARAMETER] = Prado.CallbackRequest.encode(this.options.params);
 -		data[Prado.CallbackRequest.FIELD_CALLBACK_TARGET] = this.id;
 +			data[callback.FIELD_CALLBACK_PARAMETER] = callback.encode(this.options.params);
 +		var pageState = $F(callback.FIELD_CALLBACK_PAGESTATE);
 +		if(typeof(pageState) != "undefined")
 +			data[callback.FIELD_CALLBACK_PAGESTATE] = pageState;
 +		data[callback.FIELD_CALLBACK_TARGET] = this.id;
  		return $H(data).toQueryString();
  	}
  }
 diff --git a/framework/Web/Javascripts/prado/element.js b/framework/Web/Javascripts/prado/element.js index 06937253..88fb9ec5 100644 --- a/framework/Web/Javascripts/prado/element.js +++ b/framework/Web/Javascripts/prado/element.js @@ -74,6 +74,18 @@ Prado.Element =  		if(typeof(obj) != "undefined" && typeof(obj.focus) != "undefined")
  			setTimeout(function(){ obj.focus(); }, 100);
  		return false;
 +	},
 +	
 +	replaceContent : function(element, method, content, boundary, transport)
 +	{
 +		if(boundary)
 +		{
 +			var f = RegExp('(<!--'+boundary+'-->)([\\s\\S\\w\\W]*)(<!--//'+boundary+'-->)',"m");
 +			var result = transport.responseText.match(f);
 +			if(result && result.length >= 2)
 +				content = result[2];
 +		}
 +		method.toFunction().apply(this,[element,content]);
  	}
  }
 | 
