diff options
| author | wei <> | 2006-06-09 07:41:18 +0000 | 
|---|---|---|
| committer | wei <> | 2006-06-09 07:41:18 +0000 | 
| commit | c3404ca887eb20dbf7e3b8d4118d87f4cf39f31e (patch) | |
| tree | 7aad322f619578b09445509760acb43cf5a70bab | |
| parent | e95d096064de94c948e4398f5183afaccf522ffa (diff) | |
Update datepicker and link button.
| -rw-r--r-- | framework/Web/Javascripts/datepicker/datepicker.js | 28 | ||||
| -rw-r--r-- | framework/Web/Javascripts/js/datepicker.js | 7 | ||||
| -rw-r--r-- | framework/Web/Javascripts/prado/controls.js | 1 | ||||
| -rw-r--r-- | framework/Web/UI/WebControls/TLinkButton.php | 3 | 
4 files changed, 18 insertions, 21 deletions
| diff --git a/framework/Web/Javascripts/datepicker/datepicker.js b/framework/Web/Javascripts/datepicker/datepicker.js index e704e950..11bee07e 100644 --- a/framework/Web/Javascripts/datepicker/datepicker.js +++ b/framework/Web/Javascripts/datepicker/datepicker.js @@ -239,13 +239,6 @@ Prado.WebUI.TDatePicker.prototype =  		var buttonText = today.SimpleFormat(this.Format,this);
  		todayButton.value = buttonText;
  		div.appendChild(todayButton);
 -		
 -		/*var clearButton = document.createElement("button");
 -		clearButton.className = "clearButton";
 -		buttonText = "Clear";
 -		clearButton.appendChild(document.createTextNode(buttonText));
 -		div.appendChild(clearButton);
 -		*/
  		if(Prado.Browser().ie)
  		{
 @@ -283,10 +276,9 @@ Prado.WebUI.TDatePicker.prototype =  		Event.observe(calendarBody, "click", this.selectDate.bindEvent(this));
 -		Event.observe(this.control, "blur", this.hide.bind(this));
  		Prado.Element.focus(this.control);
 -	},A
 +	},
  	ieHack : function(cleanup) 
  	{
 @@ -308,7 +300,7 @@ Prado.WebUI.TDatePicker.prototype =  		if (!ev) ev = document.parentWindow.event;
  		var kc = ev.keyCode != null ? ev.keyCode : ev.charCode;
 -		if(kc == Event.KEY_RETURN || kc == Event.KEY_SPACEBAR)
 +		if(kc == Event.KEY_RETURN || kc == Event.KEY_SPACEBAR || kc == Event.KEY_TAB)
  		{
  			this.setSelectedDate(this.selectedDate);
  			Event.stop(ev);
 @@ -318,8 +310,7 @@ Prado.WebUI.TDatePicker.prototype =  		{
  			Event.stop(ev); this.hide();
  		}
 -		
 -		
 +				
  		var getDaysPerMonth = function (nMonth, nYear) 
  		{
  			nMonth = (nMonth + 12) % 12;
 @@ -600,6 +591,7 @@ Prado.WebUI.TDatePicker.prototype =  		if(!within) this.hide();
  	},
 +
  	hide : function()
  	{
  		if(this.showing)
 @@ -667,11 +659,13 @@ Prado.WebUI.TDatePicker.prototype =  	hover : function(ev)
  	{
 -		//conditionally add the hover class to the event target element.
 -		if(ev.type == "mouseover")
 -			Event.element(ev).addClassName("hover");
 -		else
 -			Event.element(ev).removeClassName("hover");
 +		if(Event.element(ev).tagName)
 +		{
 +			if(ev.type == "mouseover")
 +				Event.element(ev).addClassName("hover");
 +				else
 +				Event.element(ev).removeClassName("hover");
 +		}
  	},
  	updateHeader : function () {
 diff --git a/framework/Web/Javascripts/js/datepicker.js b/framework/Web/Javascripts/js/datepicker.js index e0bba502..090f3cbd 100644 --- a/framework/Web/Javascripts/js/datepicker.js +++ b/framework/Web/Javascripts/js/datepicker.js @@ -23,10 +23,10 @@ div=document.createElement("div");div.className="calendarFooter";this._calDiv.ap  this.iePopUp.scrolling="no"  this.iePopUp.frameBorder="0"  document.body.appendChild(this.iePopUp);} -document.body.appendChild(this._calDiv);this.update();this.updateHeader();this.ieHack(true);previousMonth.hideFocus=true;nextMonth.hideFocus=true;todayButton.hideFocus=true;Event.observe(previousMonth,"click",this.prevMonth.bindEvent(this));Event.observe(nextMonth,"click",this.nextMonth.bindEvent(this));Event.observe(todayButton,"click",this.selectToday.bindEvent(this));Event.observe(this._monthSelect,"change",this.monthSelect.bindEvent(this));Event.observe(this._yearSelect,"change",this.yearSelect.bindEvent(this));Event.observe(this._calDiv,"mousewheel",this.mouseWheelChange.bindEvent(this));Event.observe(calendarBody,"click",this.selectDate.bindEvent(this));Event.observe(this.control,"blur",this.hide.bind(this));Prado.Element.focus(this.control);},ieHack:function(cleanup) +document.body.appendChild(this._calDiv);this.update();this.updateHeader();this.ieHack(true);previousMonth.hideFocus=true;nextMonth.hideFocus=true;todayButton.hideFocus=true;Event.observe(previousMonth,"click",this.prevMonth.bindEvent(this));Event.observe(nextMonth,"click",this.nextMonth.bindEvent(this));Event.observe(todayButton,"click",this.selectToday.bindEvent(this));Event.observe(this._monthSelect,"change",this.monthSelect.bindEvent(this));Event.observe(this._yearSelect,"change",this.yearSelect.bindEvent(this));Event.observe(this._calDiv,"mousewheel",this.mouseWheelChange.bindEvent(this));Event.observe(calendarBody,"click",this.selectDate.bindEvent(this));Prado.Element.focus(this.control);},ieHack:function(cleanup)  {if(this.iePopUp)  {this.iePopUp.style.display="block";this.iePopUp.style.top=(this._calDiv.offsetTop-1)+"px";this.iePopUp.style.left=(this._calDiv.offsetLeft-1)+"px";this.iePopUp.style.width=Math.abs(this._calDiv.offsetWidth-2)+"px";this.iePopUp.style.height=(this._calDiv.offsetHeight+1)+"px";if(cleanup)this.iePopUp.style.display="none";}},keyPressed:function(ev) -{if(!this.showing)return;if(!ev)ev=document.parentWindow.event;var kc=ev.keyCode!=null?ev.keyCode:ev.charCode;if(kc==Event.KEY_RETURN||kc==Event.KEY_SPACEBAR) +{if(!this.showing)return;if(!ev)ev=document.parentWindow.event;var kc=ev.keyCode!=null?ev.keyCode:ev.charCode;if(kc==Event.KEY_RETURN||kc==Event.KEY_SPACEBAR||kc==Event.KEY_TAB)  {this.setSelectedDate(this.selectedDate);Event.stop(ev);this.hide();}  if(kc==Event.KEY_ESC)  {Event.stop(ev);this.hide();} @@ -110,7 +110,8 @@ for(i=1;i<=monthLength;i++,index++){var slot=this.dateSlot[index];var slotNode=s  if(d1.toISODate()==selected){slotNode.className+=" selected";}  d1=new Date(d1.getFullYear(),d1.getMonth(),d1.getDate()+1);}  var lastDateIndex=index;while(index<42){this.dateSlot[index].value=-1;this.dateSlot[index].data.data=String.fromCharCode(160);this.dateSlot[index].data.parentNode.className="empty";++index;}},hover:function(ev) +{if(Event.element(ev).tagName)  {if(ev.type=="mouseover")  Event.element(ev).addClassName("hover");else -Event.element(ev).removeClassName("hover");},updateHeader:function(){var options=this._monthSelect.options;var m=this.selectedDate.getMonth();for(var i=0;i<options.length;++i){options[i].selected=false;if(options[i].value==m){options[i].selected=true;}} +Event.element(ev).removeClassName("hover");}},updateHeader:function(){var options=this._monthSelect.options;var m=this.selectedDate.getMonth();for(var i=0;i<options.length;++i){options[i].selected=false;if(options[i].value==m){options[i].selected=true;}}  options=this._yearSelect.options;var year=this.selectedDate.getFullYear();for(var i=0;i<options.length;++i){options[i].selected=false;if(options[i].value==year){options[i].selected=true;}}}};
\ No newline at end of file diff --git a/framework/Web/Javascripts/prado/controls.js b/framework/Web/Javascripts/prado/controls.js index de409e94..2497c586 100644 --- a/framework/Web/Javascripts/prado/controls.js +++ b/framework/Web/Javascripts/prado/controls.js @@ -61,6 +61,7 @@ Prado.WebUI.PostBackControl.prototype =  		var src = Event.element(event);
  		var doPostBack = true;
  		var onclicked = null;
 +
  		if(this._elementOnClick)
  		{
  			var onclicked = this._elementOnClick(event);
 diff --git a/framework/Web/UI/WebControls/TLinkButton.php b/framework/Web/UI/WebControls/TLinkButton.php index bca4a8f6..b25f602b 100644 --- a/framework/Web/UI/WebControls/TLinkButton.php +++ b/framework/Web/UI/WebControls/TLinkButton.php @@ -83,7 +83,8 @@ class TLinkButton extends TWebControl implements IPostBackEventHandler, IButtonC  		if($this->getEnabled(true))
  		{
  			//create unique no-op url references
 -			$nop = "#".$this->getClientID();
 +			//$nop = "#".$this->getClientID();
 +			$nop = "javascript:;//".$this->getClientID();
  			$writer->addAttribute('href', $nop);
  			$this->getPage()->getClientScript()->registerPostBackControl('Prado.WebUI.TLinkButton',$this->getPostBackOptions());
  		}
 | 
