You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
71 lines
3.4 KiB
71 lines
3.4 KiB
14 years ago
|
/*
|
||
|
Copyright (c) 2004-2011, The Dojo Foundation All Rights Reserved.
|
||
|
Available via Academic Free License >= 2.1 OR the modified BSD license.
|
||
|
see: http://dojotoolkit.org/license for details
|
||
|
*/
|
||
|
|
||
|
|
||
|
if(!dojo._hasResource["dijit.layout.TabController"]){
|
||
|
dojo._hasResource["dijit.layout.TabController"]=true;
|
||
|
dojo.provide("dijit.layout.TabController");
|
||
|
dojo.require("dijit.layout.StackController");
|
||
|
dojo.require("dijit.Menu");
|
||
|
dojo.require("dijit.MenuItem");
|
||
|
dojo.requireLocalization("dijit","common",null,"ROOT,ar,ca,cs,da,de,el,es,fi,fr,he,hu,it,ja,kk,ko,nb,nl,pl,pt,pt-pt,ro,ru,sk,sl,sv,th,tr,zh,zh-tw");
|
||
|
dojo.declare("dijit.layout.TabController",dijit.layout.StackController,{templateString:"<div role='tablist' dojoAttachEvent='onkeypress:onkeypress'></div>",tabPosition:"top",buttonWidget:"dijit.layout._TabButton",_rectifyRtlTabList:function(){
|
||
|
if(0>=this.tabPosition.indexOf("-h")){
|
||
|
return;
|
||
|
}
|
||
|
if(!this.pane2button){
|
||
|
return;
|
||
|
}
|
||
|
var _1=0;
|
||
|
for(var _2 in this.pane2button){
|
||
|
var ow=this.pane2button[_2].innerDiv.scrollWidth;
|
||
|
_1=Math.max(_1,ow);
|
||
|
}
|
||
|
for(_2 in this.pane2button){
|
||
|
this.pane2button[_2].innerDiv.style.width=_1+"px";
|
||
|
}
|
||
|
}});
|
||
|
dojo.declare("dijit.layout._TabButton",dijit.layout._StackButton,{baseClass:"dijitTab",cssStateNodes:{closeNode:"dijitTabCloseButton"},templateString:dojo.cache("dijit.layout","templates/_TabButton.html","<div role=\"presentation\" dojoAttachPoint=\"titleNode\" dojoAttachEvent='onclick:onClick'>\n <div role=\"presentation\" class='dijitTabInnerDiv' dojoAttachPoint='innerDiv'>\n <div role=\"presentation\" class='dijitTabContent' dojoAttachPoint='tabContent'>\n \t<div role=\"presentation\" dojoAttachPoint='focusNode'>\n\t\t <img src=\"${_blankGif}\" alt=\"\" class=\"dijitIcon dijitTabButtonIcon\" dojoAttachPoint='iconNode' />\n\t\t <span dojoAttachPoint='containerNode' class='tabLabel'></span>\n\t\t <span class=\"dijitInline dijitTabCloseButton dijitTabCloseIcon\" dojoAttachPoint='closeNode'\n\t\t \t\tdojoAttachEvent='onclick: onClickCloseButton' role=\"presentation\">\n\t\t <span dojoAttachPoint='closeText' class='dijitTabCloseText'>[x]</span\n\t\t ></span>\n\t\t\t</div>\n </div>\n </div>\n</div>\n"),scrollOnFocus:false,buildRendering:function(){
|
||
|
this.inherited(arguments);
|
||
|
dojo.setSelectable(this.containerNode,false);
|
||
|
},startup:function(){
|
||
|
this.inherited(arguments);
|
||
|
var n=this.domNode;
|
||
|
setTimeout(function(){
|
||
|
n.className=n.className;
|
||
|
},1);
|
||
|
},_setCloseButtonAttr:function(_3){
|
||
|
this._set("closeButton",_3);
|
||
|
dojo.toggleClass(this.innerDiv,"dijitClosable",_3);
|
||
|
this.closeNode.style.display=_3?"":"none";
|
||
|
if(_3){
|
||
|
var _4=dojo.i18n.getLocalization("dijit","common");
|
||
|
if(this.closeNode){
|
||
|
dojo.attr(this.closeNode,"title",_4.itemClose);
|
||
|
}
|
||
|
var _4=dojo.i18n.getLocalization("dijit","common");
|
||
|
this._closeMenu=new dijit.Menu({id:this.id+"_Menu",dir:this.dir,lang:this.lang,targetNodeIds:[this.domNode]});
|
||
|
this._closeMenu.addChild(new dijit.MenuItem({label:_4.itemClose,dir:this.dir,lang:this.lang,onClick:dojo.hitch(this,"onClickCloseButton")}));
|
||
|
}else{
|
||
|
if(this._closeMenu){
|
||
|
this._closeMenu.destroyRecursive();
|
||
|
delete this._closeMenu;
|
||
|
}
|
||
|
}
|
||
|
},_setLabelAttr:function(_5){
|
||
|
this.inherited(arguments);
|
||
|
if(this.showLabel==false&&!this.params.title){
|
||
|
this.iconNode.alt=dojo.trim(this.containerNode.innerText||this.containerNode.textContent||"");
|
||
|
}
|
||
|
},destroy:function(){
|
||
|
if(this._closeMenu){
|
||
|
this._closeMenu.destroyRecursive();
|
||
|
delete this._closeMenu;
|
||
|
}
|
||
|
this.inherited(arguments);
|
||
|
}});
|
||
|
}
|