////////////////////////////////////////////////////////////////////////////////
//
// 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.managers
{
import flash.display.DisplayObject;
import flash.events.IEventDispatcher;
import flash.display.InteractiveObject;
import flash.display.Sprite;
import mx.core.IButton;
import mx.core.IUIComponent;
/**
* The IFocusManager interface defines the interface that components must implement
* to manage the focus on components in response to mouse activity or
* keyboard activity (Tab key), and to support a default button.
*
* @see mx.managers.FocusManager
*
* @langversion 3.0
* @playerversion Flash 9
* @playerversion AIR 1.1
* @productversion Flex 3
*/
public interface IFocusManager extends IEventDispatcher
{
//--------------------------------------------------------------------------
//
// Properties
//
//--------------------------------------------------------------------------
//----------------------------------
// defaultButton
//----------------------------------
/**
* A reference to the original default Button control.
* Pressing the Enter key while the focus is on any control
* activates the Button control by dispatching a click
event
* on the Button control, just as if it was clicked with the mouse.
* The actual default Button control changes if focus is given to another
* Button control, but switches back to the original if focus is not
* on a button.
*
*
This property is managed by Flex containers; do not set it directly * to specify the default button.
* *The defaultButton
must be of class
* mx.controls.Button
even though this property
* is of type IUIComponent
.
Enter
key
* set this property to false
to disable the Enter
* key from dispatching a click
event on the
* default button, if it exists.
*
* @langversion 3.0
* @playerversion Flash 9
* @playerversion AIR 1.1
* @productversion Flex 3
*/
function get defaultButtonEnabled():Boolean;
/**
* @private
*/
function set defaultButtonEnabled(value:Boolean):void;
//----------------------------------
// focusPane
//----------------------------------
/**
* A single Sprite that is moved from container to container
* as the focus moves to those containers.
* The Sprite is used as the parent of the visual indicator
* that a component has focus.
*
* @langversion 3.0
* @playerversion Flash 9
* @playerversion AIR 1.1
* @productversion Flex 3
*/
function get focusPane():Sprite;
/**
* @private
*/
function set focusPane(value:Sprite):void;
//----------------------------------
// nextTabIndex
//----------------------------------
/**
* The next unique tab index to use in this tab loop.
*
* @langversion 3.0
* @playerversion Flash 9
* @playerversion AIR 1.1
* @productversion Flex 3
*/
function get nextTabIndex():int;
//----------------------------------
// showFocusIndicator
//----------------------------------
/**
* A flag that indicates whether to display an indicator that
* a component has focus.
* If true
a component receiving focus
* draws a visible indicator that it has focus.
*
* By default, this is false
until the user uses
* the Tab key, then it is set to true
.
In general it is better to use
* the showFocus()
and hideFocus()
methods
* to change this property as those methods also update the
* visual indicator that a component has focus.
showFocusIndicator
to true
* and draws the visual focus indicator on the focused object, if any.
*
* @langversion 3.0
* @playerversion Flash 9
* @playerversion AIR 1.1
* @productversion Flex 3
*/
function showFocus():void;
/**
* Sets showFocusIndicator
to false
* and removes the visual focus indicator from the focused object, if any.
*
* @langversion 3.0
* @playerversion Flash 9
* @playerversion AIR 1.1
* @productversion Flex 3
*/
function hideFocus():void;
/**
* The SystemManager activates and deactivates a FocusManager
* if more than one IFocusManagerContainer is visible at the same time.
* If the mouse is clicked in an IFocusManagerContainer with a deactivated
* FocusManager, the SystemManager will call
* the activate()
method on that FocusManager.
* The FocusManager that was activated will have its deactivate()
method
* called prior to the activation of another FocusManager.
*
* @langversion 3.0
* @playerversion Flash 9
* @playerversion AIR 1.1
* @productversion Flex 3
*/
function activate():void;
/**
* The SystemManager activates and deactivates a FocusManager
* if more than one IFocusManagerContainer is visible at the same time.
* If the mouse is clicked in an IFocusManagerContainer with a deactivated
* FocusManager, the SystemManager will call
* the activate()
method on that FocusManager.
* The FocusManager that was activated will have its deactivate()
method
* called prior to the activation of another FocusManager.
*
* @langversion 3.0
* @playerversion Flash 9
* @playerversion AIR 1.1
* @productversion Flex 3
*/
function deactivate():void;
/**
* Returns the IFocusManagerComponent that contains the given object, if any.
* Because the player can set focus to a subcomponent of a Flex component
* this method determines which IFocusManagerComponent has focus from
* the component perspective.
*
* @param o An object that can have player-level focus.
*
* @return The IFOcusManagerComponent containing o
or
* null
*
* @langversion 3.0
* @playerversion Flash 9
* @playerversion AIR 1.1
* @productversion Flex 3
*/
function findFocusManagerComponent(o:InteractiveObject):IFocusManagerComponent;
/**
* Returns the IFocusManagerComponent that would receive focus
* if the user pressed the Tab key to navigate to another component.
* It will return the same component as the current focused component
* if there are no other valid components in the application.
*
* @param backward If true
, return the object
* as if the Shift-Tab keys were pressed.
*
* @return The component that would receive focus.
*
* @langversion 3.0
* @playerversion Flash 9
* @playerversion AIR 1.1
* @productversion Flex 3
*/
function getNextFocusManagerComponent(
backward:Boolean = false):IFocusManagerComponent;
}
}