blob: 7b3975f465a9f69337d8ee142418fe38297c4cdc [file] [log] [blame]
////////////////////////////////////////////////////////////////////////////////
//
// Licensed to the Apache Software Foundation (ASF) under one or more
// contributor license agreements. See the NOTICE file distributed with
// this work for additional information regarding copyright ownership.
// The ASF licenses this file to You under the Apache License, Version 2.0
// (the "License"); you may not use this file except in compliance with
// the License. You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//
////////////////////////////////////////////////////////////////////////////////
package mx.controls
{
import flash.display.DisplayObject;
import flash.events.MouseEvent;
import mx.controls.tabBarClasses.Tab;
import mx.core.ClassFactory;
import mx.core.IFlexDisplayObject;
import mx.core.mx_internal;
import mx.events.ItemClickEvent;
use namespace mx_internal;
//--------------------------------------
// Events
//--------------------------------------
/**
* Dispatched when a tab navigation item is selected.
* This event is sent only if the data provider is not a ViewStack container.
*
* @eventType mx.events.ItemClickEvent.ITEM_CLICK
*
* @langversion 3.0
* @playerversion Flash 9
* @playerversion AIR 1.1
* @productversion Flex 3
*/
[Event(name="itemClick", type="mx.events.ItemClickEvent")]
//--------------------------------------
// Styles
//--------------------------------------
/**
* Name of CSS style declaration that specifies the styles to use for the
* first tab navigation item.
*
* @default "tabStyleName"
*
* @langversion 3.0
* @playerversion Flash 9
* @playerversion AIR 1.1
* @productversion Flex 3
*/
[Style(name="firstTabStyleName", type="String", inherit="no")]
/**
* Horizontal alignment of all tabs within the TabBar. Since individual
* tabs stretch to fill the entire TabBar, this style is only useful if you
* use the tabWidth style and the combined widths of the tabs are less than
* than the width of the TabBar.
* Possible values are <code>"left"</code>, <code>"center"</code>,
* and <code>"right"</code>.
*
* @default "center"
*
* @langversion 3.0
* @playerversion Flash 9
* @playerversion AIR 1.1
* @productversion Flex 3
*/[Style(name="horizontalAlign", type="String", enumeration="left,center,right", inherit="no")]
/**
* Number of pixels between tab navigation items in the horizontal direction.
*
* @default -1
*
* @langversion 3.0
* @playerversion Flash 9
* @playerversion AIR 1.1
* @productversion Flex 3
*/
[Style(name="horizontalGap", type="Number", format="Length", inherit="no")]
/**
* Name of CSS style declaration that specifies the styles to use for the
* last tab navigation item.
*
* @default "tabStyleName"
*
* @langversion 3.0
* @playerversion Flash 9
* @playerversion AIR 1.1
* @productversion Flex 3
*/
[Style(name="lastTabStyleName", type="String", inherit="no")]
/**
* Name of CSS style declaration that specifies the styles to use for the text
* of the selected tab navigation item.
*
* @default "activeTabStyle"
*
* @langversion 3.0
* @playerversion Flash 9
* @playerversion AIR 1.1
* @productversion Flex 3
*/
[Style(name="selectedTabTextStyleName", type="String", inherit="no")]
/**
* Name of CSS style declaration that specifies the styles to use for the tab
* navigation items.
*
* @default undefined
*
* @langversion 3.0
* @playerversion Flash 9
* @playerversion AIR 1.1
* @productversion Flex 3
*/
[Style(name="tabStyleName", type="String", inherit="no")]
/**
* Height of each tab navigation item, in pixels.
* When this property is <code>undefined</code>, the height of each tab
* is determined by the font styles applied to the container.
* If you set this property, the specified value overrides this calculation.
*
* @default undefined
*
* @langversion 3.0
* @playerversion Flash 9
* @playerversion AIR 1.1
* @productversion Flex 3
*/
[Style(name="tabHeight", type="Number", format="Length", inherit="no")]
/**
* Width of the tab navigation item, in pixels.
* If undefined, the default tab widths are calculated from the label text.
*
* @default undefined
*
* @langversion 3.0
* @playerversion Flash 9
* @playerversion AIR 1.1
* @productversion Flex 3
*/
[Style(name="tabWidth", type="Number", format="Length", inherit="no")]
/**
* Vertical alignment of all tabs within the TabBar. Since individual
* tabs stretch to fill the entire TabBar, this style is only useful if you
* use the tabHeight style and the combined heights of the tabs are less than
* than the height of the TabBar.
* Possible values are <code>"top"</code>, <code>"middle"</code>,
* and <code>"bottom"</code>.
*
* @default "middle"
*
* @langversion 3.0
* @playerversion Flash 9
* @playerversion AIR 1.1
* @productversion Flex 3
*/[Style(name="verticalAlign", type="String", enumeration="top,middle,bottom", inherit="no")]
/**
* Number of pixels between tab navigation items in the vertical direction.
*
* @default -1
*
* @langversion 3.0
* @playerversion Flash 9
* @playerversion AIR 1.1
* @productversion Flex 3
*/
[Style(name="verticalGap", type="Number", format="Length", inherit="no")]
//--------------------------------------
// Excluded APIs
//--------------------------------------
[Exclude(name="horizontalLineScrollSize", kind="property")]
[Exclude(name="horizontalPageScrollSize", kind="property")]
[Exclude(name="horizontalScrollBar", kind="property")]
[Exclude(name="horizontalScrollPolicy", kind="property")]
[Exclude(name="horizontalScrollPosition", kind="property")]
[Exclude(name="maxHorizontalScrollPosition", kind="property")]
[Exclude(name="maxVerticalScrollPosition", kind="property")]
[Exclude(name="verticalLineScrollSize", kind="property")]
[Exclude(name="verticalPageScrollSize", kind="property")]
[Exclude(name="verticalScrollBar", kind="property")]
[Exclude(name="verticalScrollPolicy", kind="property")]
[Exclude(name="verticalScrollPosition", kind="property")]
[Exclude(name="scroll", kind="event")]
[Exclude(name="backgroundAlpha", kind="style")]
[Exclude(name="backgroundAttachment", kind="style")]
[Exclude(name="backgroundColor", kind="style")]
[Exclude(name="backgroundImage", kind="style")]
[Exclude(name="backgroundSize", kind="style")]
[Exclude(name="borderAlpha", kind="style")]
[Exclude(name="borderColor", kind="style")]
[Exclude(name="borderSides", kind="style")]
[Exclude(name="borderSkin", kind="style")]
[Exclude(name="borderStyle", kind="style")]
[Exclude(name="borderThickness", kind="style")]
[Exclude(name="borderVisible", kind="style")]
[Exclude(name="cornerRadius", kind="style")]
[Exclude(name="dropShadowColor", kind="style")]
[Exclude(name="dropShadowEnabled", kind="style")]
[Exclude(name="firstButtonStyleName", kind="style")]
[Exclude(name="horizontalScrollBarStyleName", kind="style")]
[Exclude(name="lastButtonStyleName", kind="style")]
[Exclude(name="shadowCapColor", kind="style")]
[Exclude(name="shadowColor", kind="style")]
[Exclude(name="shadowDirection", kind="style")]
[Exclude(name="shadowDistance", kind="style")]
[Exclude(name="verticalScrollBarStyleName", kind="style")]
//--------------------------------------
// Other metadata
//--------------------------------------
[AccessibilityClass(implementation="mx.accessibility.TabBarAccImpl")]
[DefaultProperty("dataProvider")]
[DefaultTriggerEvent("itemClick")]
[IconFile("TabBar.png")]
[MaxChildren(0)]
/**
* The TabBar control lets you create a horizontal or vertical group of tab navigation
* items by defining the labels and data associated with each tab. Use the
* TabBar control instead of the TabNavigator container to create tabs that, by default, are not
* associated with multiple views.
*
* <p>Using the TabBar control lets the tabs be directly determined by the
* data so that you can change the view or views in any way.</p>
*
* <p>A TabBar control has the following default characteristics:</p>
* <table class="innertable">
* <tr>
* <th>Characteristic</th>
* <th>Description</th>
* </tr>
* <tr>
* <td>Preferred size</td>
* <td>A width wide enough to contain all label text, plus any padding, and a height tall enough for the label text. The default tab height is determined by the font, style, and skin applied to the control. If you set an explicit height using the tabHeight property, that value overrides the default value.</td>
* </tr>
* <tr>
* <td>Control resizing rules</td>
* <td>TabBar controls do not resize by default. Specify percentage sizes if you want your TabBar to resize based on the size of its parent container.</td>
* </tr>
* <tr>
* <td>Padding</td>
* <td>0 pixels for the left and right properties.</td>
* </tr>
* </table>
*
* @mxml
*
* <p>The <code>&lt;mx:TabBar&gt;</code> tag inherits all of the tag attributes
* of its superclass, and adds the following tag attributes:</p>
*
* <pre>
* &lt;mx:TabBar
* <b>Styles</b>
* firstTabStyleName="<i>Value of the</i> <code>tabStyleName</code> <i>property</i>"
* horizontalAlign="left|center|right"
* horizontalGap="-1"
* lastTabStyleName="<i>Value of the</i> <code>tabStyleName</code> <i>property</i>"
* selectedTabTextStyleName="activeTabStyle"
* tabHeight="undefined"
* tabStyleName="Tab"
* tabWidth="undefined"
* verticalAlign="top|middle|bottom"
* verticalGap="-1"
*
* <b>Events</b>
* itemClick="<i>No default</i>"
* &gt;
* ...
* <i>child tags</i>
* ...
* &lt;/mx:TabBar&gt;
* </pre>
*
* @includeExample examples/TabBarExample.mxml
*
* @langversion 3.0
* @playerversion Flash 9
* @playerversion AIR 1.1
* @productversion Flex 3
*/
public class TabBar extends ToggleButtonBar
{
include "../core/Version.as";
//--------------------------------------------------------------------------
//
// Class mixins
//
//--------------------------------------------------------------------------
/**
* @private
* Placeholder for mixin by TabBarAccImpl.
*/
mx_internal static var createAccessibilityImplementation:Function;
//--------------------------------------------------------------------------
//
// Constructor
//
//--------------------------------------------------------------------------
/**
* Constructor.
*
* @langversion 3.0
* @playerversion Flash 9
* @playerversion AIR 1.1
* @productversion Flex 3
*/
public function TabBar()
{
super();
buttonHeightProp = "tabHeight";
buttonStyleNameProp = "tabStyleName";
firstButtonStyleNameProp = "firstTabStyleName";
lastButtonStyleNameProp = "lastTabStyleName";
buttonWidthProp = "tabWidth";
navItemFactory = new ClassFactory(Tab);
selectedButtonTextStyleNameProp = "selectedTabTextStyleName";
}
//--------------------------------------------------------------------------
//
// Overridden methods: UIComponent
//
//--------------------------------------------------------------------------
/**
* @private
*/
override protected function initializeAccessibility():void
{
if (TabBar.createAccessibilityImplementation != null)
TabBar.createAccessibilityImplementation(this);
}
//--------------------------------------------------------------------------
//
// Overridden methods: NavBar
//
//--------------------------------------------------------------------------
/**
* @private
*/
override protected function createNavItem(
label:String,
icon:Class = null):IFlexDisplayObject
{
var navItem:IFlexDisplayObject = super.createNavItem(label, icon);
DisplayObject(navItem).addEventListener(
MouseEvent.MOUSE_DOWN, tab_mouseDownHandler);
DisplayObject(navItem).addEventListener(
MouseEvent.DOUBLE_CLICK, tab_doubleClickHandler);
return navItem;
}
//--------------------------------------------------------------------------
//
// Overridden event handlers: NavBar
//
//--------------------------------------------------------------------------
/**
* @private
*/
override protected function clickHandler(event:MouseEvent):void
{
// Since we select on mouse down instead of click, make
// sure the click is only handled when the selection
// actually changes (selectButton sends a "faked"
// click event which we do need to handle).
if (getChildIndex(DisplayObject(event.currentTarget)) == selectedIndex)
{
Button(event.currentTarget).selected = true;
event.stopImmediatePropagation();
return;
}
super.clickHandler(event);
}
//--------------------------------------------------------------------------
//
// Event handlers
//
//--------------------------------------------------------------------------
/**
* @private
* TabBars select the tab on mouse down instead of click.
*/
private function tab_mouseDownHandler(event:MouseEvent):void
{
selectButton(event.currentTarget.parent.getChildIndex(
event.currentTarget), true, event);
}
/**
* @private
*/
private function tab_doubleClickHandler(event:MouseEvent):void
{
// Make sure the tab remains selected when double-clicked.
Button(event.currentTarget).selected = true;
}
}
}