173 lines
6.0 KiB
JavaScript
173 lines
6.0 KiB
JavaScript
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;
|
|
});
|