org.jdesktop.swingx.action.package-info Maven / Gradle / Ivy
/*
* Copyright 2009 Sun Microsystems, Inc., 4150 Network Circle,
* Santa Clara, California 95054, U.S.A. All rights reserved.
*
* This library is free software; you can redistribute it and/or
* modify it under the terms of the GNU Lesser General Public
* License as published by the Free Software Foundation; either
* version 2.1 of the License, or (at your option) any later version.
*
* This library is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
* Lesser General Public License for more details.
*
* You should have received a copy of the GNU Lesser General Public
* License along with this library; if not, write to the Free Software
* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
*/
/**
* Contains classes related to the JDNC actions architecture. The Actions
* architecture maintains the set of user initiated commands (referred to as
* user actions) in an application. These commands are represented as an
* {@link javax.swing.Action} and have properties like name and icon. The
* user actions
* are represented in the user interface by controls like menu items and
* toolbar buttons.
*
* The other type of actions used by the architecture are the internal
* swing Actions (refered to as behaviour actions) that are embedded
* within the {@link javax.swing.ActionMap} of a {@link javax.swing.JComponent}.
*
* These two types of actions are distinct from each other: user actions
* have a lot of properties but very little semantics by default
* (unless explicity bound). Behavior actions have no properties but have
* semantics. These two types of actions are linked by the action id
* which is the value of the Action.ACTION_COMMAND_KEY
*
* The {@link org.jdesktop.swingx.action.AbstractActionExt} class extends the Swing
* concept of the Action by adding support for toggle or two state actions.
* Toggle type actions may be grouped into a set of mutually exclusive actions.
* This binary actions are represented in the user interface as JToggleButtons,
* JCheckBoxMenuItems or JRadioButtonMenuItems.
*
* There are two types of user actions: A {@link org.jdesktop.swingx.action.BoundAction}
* is an action that will invoke a specific method. It may be bound to an explict
* component, a callback method on an object instance or one or more listeners.
* A {@link org.jdesktop.swingx.action.TargetableAction} is an action that doesn't have an
* explicit binding and the invocation will be sent to an arbitrator
* (the {@link org.jdesktop.swingx.action.TargetManager}) which dispatches the Action
* to the "current component" - represented by a Targetable instance.
* The current component may be explictly set by some programmatic
* policy (for example, changes in state).
*
* By defalt, the current component will be driven by the focus policy as dictated
* by the current FocusManager. If the current component cannot handle the action
* then the action will be dispatched up the containment hierarchy until the action
* is consumed. If the action is not consumed then it will be dispatched to the
* Application instance which manages an application global set of actions.
*
* These are the key classes or the actions architecture:
*
*
* - {@link org.jdesktop.swingx.action.ActionManager}
* - A repository of all shared actions in the application.
* There will be one instance per application which can be accessed
* via the Application object (was ClientApp)
*
*
* - {@link org.jdesktop.swingx.action.ActionContainerFactory}
* - Constructs JMenuBars, JMenus, JPopupMenus and
* JToolBars using lists of action ids. This functionality may
* be migrated into ActionManager.
*
*
* - {@link org.jdesktop.swingx.action.TargetableAction}
* - Represents an unbound Action. The invocation of this action
* will be dispatched to the TargetManager.
*
* - {@link org.jdesktop.swingx.action.BoundAction}
* - Represents an action which has an explicit binding.
*
* - {@link org.jdesktop.swingx.action.TargetManager}
* - Manages the targetable policy for actions which have no
* explicit binding. The policy can be set by changes in application
* state, event based criteria or whatever. If the policy has not been
* set then it will dispatch the action to the current focusable
* component.
*
*
* - {@link org.jdesktop.swingx.action.Targetable}
* - An interface that contains a few methods which expose actions to
* the TargetManager. Targetable objects don't have to be visual
* components they only have to be able to handle action invocations.
*
*
*
*
* Richard Bair
*/
package org.jdesktop.swingx.action;