| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172 | require({cache:{'url:dijit/layout/templates/_TabButton.html':"<div role=\"presentation\" data-dojo-attach-point=\"titleNode\" data-dojo-attach-event='onclick:onClick'>\n    <div role=\"presentation\" class='dijitTabInnerDiv' data-dojo-attach-point='innerDiv'>\n        <div role=\"presentation\" class='dijitTabContent' data-dojo-attach-point='tabContent'>\n        \t<div role=\"presentation\" data-dojo-attach-point='focusNode'>\n\t\t        <img src=\"${_blankGif}\" alt=\"\" class=\"dijitIcon dijitTabButtonIcon\" data-dojo-attach-point='iconNode' />\n\t\t        <span data-dojo-attach-point='containerNode' class='tabLabel'></span>\n\t\t        <span class=\"dijitInline dijitTabCloseButton dijitTabCloseIcon\" data-dojo-attach-point='closeNode'\n\t\t        \t\tdata-dojo-attach-event='onclick: onClickCloseButton' role=\"presentation\">\n\t\t            <span data-dojo-attach-point='closeText' class='dijitTabCloseText'>[x]</span\n\t\t        ></span>\n\t\t\t</div>\n        </div>\n    </div>\n</div>\n"}});define("dijit/layout/TabController", [	"dojo/_base/declare", // declare	"dojo/dom", // dom.setSelectable	"dojo/dom-attr", // domAttr.attr	"dojo/dom-class", // domClass.toggle	"dojo/i18n", // i18n.getLocalization	"dojo/_base/lang", // lang.hitch lang.trim	"./StackController",	"../Menu",	"../MenuItem",	"dojo/text!./templates/_TabButton.html",	"dojo/i18n!../nls/common"], function(declare, dom, domAttr, domClass, i18n, lang, StackController, Menu, MenuItem, template){/*=====	var StackController = dijit.layout.StackController;	var Menu = dijit.Menu;	var MenuItem = dijit.MenuItem;=====*/	// module:	//		dijit/layout/TabController	// summary:	// 		Set of tabs (the things with titles and a close button, that you click to show a tab panel).	//		Used internally by `dijit.layout.TabContainer`.	var TabButton = declare("dijit.layout._TabButton", StackController.StackButton, {		// summary:		//		A tab (the thing you click to select a pane).		// description:		//		Contains the title of the pane, and optionally a close-button to destroy the pane.		//		This is an internal widget and should not be instantiated directly.		// tags:		//		private		// baseClass: String		//		The CSS class applied to the domNode.		baseClass: "dijitTab",		// Apply dijitTabCloseButtonHover when close button is hovered		cssStateNodes: {			closeNode: "dijitTabCloseButton"		},		templateString: template,		// Override _FormWidget.scrollOnFocus.		// Don't scroll the whole tab container into view when the button is focused.		scrollOnFocus: false,		buildRendering: function(){			this.inherited(arguments);			dom.setSelectable(this.containerNode, false);		},		startup: function(){			this.inherited(arguments);			var n = this.domNode;			// Required to give IE6 a kick, as it initially hides the			// tabs until they are focused on.			setTimeout(function(){				n.className = n.className;			}, 1);		},		_setCloseButtonAttr: function(/*Boolean*/ disp){			// summary:			//		Hide/show close button			this._set("closeButton", disp);			domClass.toggle(this.innerDiv, "dijitClosable", disp);			this.closeNode.style.display = disp ? "" : "none";			if(disp){				var _nlsResources = i18n.getLocalization("dijit", "common");				if(this.closeNode){					domAttr.set(this.closeNode,"title", _nlsResources.itemClose);				}				// add context menu onto title button				this._closeMenu = new Menu({					id: this.id+"_Menu",					dir: this.dir,					lang: this.lang,					textDir: this.textDir,					targetNodeIds: [this.domNode]				});				this._closeMenu.addChild(new MenuItem({					label: _nlsResources.itemClose,					dir: this.dir,					lang: this.lang,					textDir: this.textDir,					onClick: lang.hitch(this, "onClickCloseButton")				}));			}else{				if(this._closeMenu){					this._closeMenu.destroyRecursive();					delete this._closeMenu;				}			}		},		_setLabelAttr: function(/*String*/ content){			// summary:			//		Hook for set('label', ...) to work.			// description:			//		takes an HTML string.			//		Inherited ToggleButton implementation will Set the label (text) of the button;			//		Need to set the alt attribute of icon on tab buttons if no label displayed			this.inherited(arguments);			if(!this.showLabel && !this.params.title){				this.iconNode.alt = lang.trim(this.containerNode.innerText || this.containerNode.textContent || '');			}		},		destroy: function(){			if(this._closeMenu){				this._closeMenu.destroyRecursive();				delete this._closeMenu;			}			this.inherited(arguments);		}	});	var TabController = declare("dijit.layout.TabController", StackController, {		// summary:		// 		Set of tabs (the things with titles and a close button, that you click to show a tab panel).		//		Used internally by `dijit.layout.TabContainer`.		// description:		//		Lets the user select the currently shown pane in a TabContainer or StackContainer.		//		TabController also monitors the TabContainer, and whenever a pane is		//		added or deleted updates itself accordingly.		// tags:		//		private		baseClass: "dijitTabController",		templateString: "<div role='tablist' data-dojo-attach-event='onkeypress:onkeypress'></div>",		// tabPosition: String		//		Defines where tabs go relative to the content.		//		"top", "bottom", "left-h", "right-h"		tabPosition: "top",		// buttonWidget: Constructor		//		The tab widget to create to correspond to each page		buttonWidget: TabButton,		_rectifyRtlTabList: function(){			// summary:			//		For left/right TabContainer when page is RTL mode, rectify the width of all tabs to be equal, otherwise the tab widths are different in IE			if(0 >= this.tabPosition.indexOf('-h')){ return; }			if(!this.pane2button){ return; }			var maxWidth = 0;			for(var pane in this.pane2button){				var ow = this.pane2button[pane].innerDiv.scrollWidth;				maxWidth = Math.max(maxWidth, ow);			}			//unify the length of all the tabs			for(pane in this.pane2button){				this.pane2button[pane].innerDiv.style.width = maxWidth + 'px';			}		}	});	TabController.TabButton = TabButton;	// for monkey patching	return TabController;});
 |