polardbxengine/storage/ndb/mcc/frontend/dojo/dojox/mobile/TabBar.js.uncompressed.js

186 lines
5.7 KiB
JavaScript

define("dojox/mobile/TabBar", [
"dojo/_base/array",
"dojo/_base/declare",
"dojo/_base/window",
"dojo/dom-class",
"dojo/dom-construct",
"dojo/dom-geometry",
"dojo/dom-style",
"dijit/_Contained",
"dijit/_Container",
"dijit/_WidgetBase",
"./TabBarButton" // to load TabBarButton for you (no direct references)
], function(array, declare, win, domClass, domConstruct, domGeometry, domStyle, Contained, Container, WidgetBase, TabBarButton){
// module:
// dojox/mobile/TabBar
return declare("dojox.mobile.TabBar", [WidgetBase, Container, Contained],{
// summary:
// A bar widget that has buttons to control visibility of views.
// description:
// TabBar is a container widget that has typically multiple
// TabBarButtons which controls visibility of views. It can be used
// as a tab container.
// iconBase: String
// The default icon path for child items.
iconBase: "",
// iconPos: String
// The default icon position for child items.
iconPos: "",
// barType: String
// "tabBar", "segmentedControl", "standardTab", "slimTab", "flatTab",
// or "tallTab"
barType: "tabBar",
// closable: Boolean
// If true, user can close (destroy) a child tab by clicking the X on the tab.
// This property is NOT effective for "tabBar" and "tallBar".
closable: false,
// center: Boolean
// If true, place the tabs in the center of the bar.
// This property is NOT effective for "tabBar".
center: true,
// syncWithViews: Boolean
// If true, this widget listens to view transition events to be
// synchronized with view's visibility.
syncWithViews: false,
// tag: String
// A name of html tag to create as domNode.
tag: "ul",
/* internal properties */
// selectOne: [private] Boolean
// Specifies that only one item can be selected.
selectOne: true,
baseClass: "mblTabBar",
_fixedButtonWidth: 76,
_fixedButtonMargin: 17,
_largeScreenWidth: 500,
buildRendering: function(){
this.domNode = this.srcNodeRef || domConstruct.create(this.tag);
this.reset();
this.inherited(arguments);
},
postCreate: function(){
if(this.syncWithViews){ // see also RoundRect#postCreate
var f = function(view, moveTo, dir, transition, context, method){
var child = array.filter(this.getChildren(), function(w){
return w.moveTo === "#" + view.id || w.moveTo === view.id; })[0];
if(child){ child.set("selected", true); }
};
this.subscribe("/dojox/mobile/afterTransitionIn", f);
this.subscribe("/dojox/mobile/startView", f);
}
},
startup: function(){
if(this._started){ return; }
this.inherited(arguments);
this.resize();
},
reset: function(){
// summary:
// Resets the widget to its initial state.
var prev = this._barType;
if(typeof this.barType === "object"){
this._barType = this.barType["*"];
for(var c in this.barType){
if(domClass.contains(win.doc.documentElement, c)){
this._barType = this.barType[c];
break;
}
}
}else{
this._barType = this.barType;
}
var cap = function(s){
return s.charAt(0).toUpperCase() + s.substring(1);
};
if(prev){
domClass.remove(this.domNode, this.baseClass + cap(prev));
}
domClass.add(this.domNode, this.baseClass + cap(this._barType));
},
resize: function(size){
var i, w;
if(size && size.w){
domGeometry.setMarginBox(this.domNode, size);
w = size.w;
}else{
// Calculation of the bar width varies according to its "position" value.
// When the widget is used as a fixed bar, its position would be "absolute".
w = domStyle.get(this.domNode, "position") === "absolute" ?
domGeometry.getContentBox(this.domNode).w : domGeometry.getMarginBox(this.domNode).w;
}
var bw = this._fixedButtonWidth;
var bm = this._fixedButtonMargin;
var arr = array.map(this.getChildren(), function(w){ return w.domNode; });
domClass.toggle(this.domNode, "mblTabBarNoIcons",
!array.some(this.getChildren(), function(w){ return w.iconNode1; }));
domClass.toggle(this.domNode, "mblTabBarNoText",
!array.some(this.getChildren(), function(w){ return w.label; }));
var margin = 0;
if (this._barType == "tabBar"){
this.containerNode.style.paddingLeft = "";
margin = Math.floor((w - (bw + bm * 2) * arr.length) / 2);
if(w < this._largeScreenWidth || margin < 0){
// If # of buttons is 4, for example, assign "25%" to each button.
// More precisely, 1%(left margin) + 98%(bar width) + 1%(right margin)
for(i = 0; i < arr.length; i++){
arr[i].style.width = Math.round(98/arr.length) + "%";
arr[i].style.margin = "0";
}
}else{
// Fixed width buttons. Mainly for larger screen such as iPad.
for(i = 0; i < arr.length; i++){
arr[i].style.width = bw + "px";
arr[i].style.margin = "0 " + bm + "px";
}
if(arr.length > 0){
arr[0].style.marginLeft = margin + bm + "px";
}
this.containerNode.style.padding = "0px";
}
}else{
for(i = 0; i < arr.length; i++){
arr[i].style.width = arr[i].style.margin = "";
}
var parent = this.getParent();
if(this.center && (!parent || !domClass.contains(parent.domNode, "mblHeading"))){
margin = w;
for(i = 0; i < arr.length; i++){
margin -= domGeometry.getMarginBox(arr[i]).w;
}
margin = Math.floor(margin/2);
}
this.containerNode.style.paddingLeft = margin ? margin + "px" : "";
}
},
getSelectedTab: function(){
// summary:
// Returns the first selected child.
return array.filter(this.getChildren(), function(w){ return w.selected; })[0];
},
onCloseButtonClick: function(/*TabBarButton*/tab){
// summary:
// Called whenever the close button [X] of a child tab is clicked.
return true;
}
});
});