All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.jdesktop.swingx.action.ActionFactory Maven / Gradle / Ivy

The newest version!
/*
 * Copyright 2004 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
 */
package org.jdesktop.swingx.action;

import javax.swing.AbstractAction;
import javax.swing.Action;
import javax.swing.Icon;
import javax.swing.KeyStroke;

/**
 * A collection of static methods to make it easier to construct
 * Actions. Not sure how usefull they are in reality but it saves a
 * lot of typing.
 *
 * @author Mark Davidson
 */
public class ActionFactory {

    /*
     * Factory Methods for creating BoundActions
     */
	
	/**
     * constructs a BoundAction
	 * 
	 * @param id String
	 * @param name String
	 * @param mnemonic String
	 * @return BoundAction
	 */
    public static BoundAction createBoundAction(String id, String name, String mnemonic) {
        return createBoundAction(id, name, mnemonic, false);
    }

    /**
     * constructs a BoundAction
     * 
     * @param id String
     * @param name String
     * @param mnemonic String
     * @param toggle boolean
     * @return BoundAction
     */
    public static BoundAction createBoundAction(String id, String name, String mnemonic, boolean toggle) {
        return createBoundAction(id, name, mnemonic, toggle, null);
    }

    /**
     * constructs a BoundAction
     * 
     * @param id String
     * @param name String
     * @param mnemonic String
     * @param toggle boolean
     * @param group String
     * @return BoundAction
     */
    public static BoundAction createBoundAction(String id, String name,
                                                String mnemonic, boolean toggle,
                                                String group) {
        return (BoundAction)configureAction(new BoundAction(name, id),
                                            mnemonic, toggle, group);
    }

    /*
     * Factory Methods for creating CompositeAction
     * @see CompositeAction
     */
    
    /**
     * constructs a CompositeAction
     * 
     * @param id String
     * @param name String
     * @param mnemonic String
     * @return CompositeAction
     */
    public static CompositeAction createCompositeAction(String id, String name, String mnemonic) {
        return createCompositeAction(id, name, mnemonic, false);
    }

    /**
     * constructs a CompositeAction
     * 
     * @param id String
     * @param name String
     * @param mnemonic String
     * @param toggle boolean
     * @return CompositeAction
     */
    public static CompositeAction createCompositeAction(String id, String name, String mnemonic, boolean toggle) {
        return createCompositeAction(id, name, mnemonic, toggle, null);
    }

    /**
     * constructs a CompositeAction
     * 
     * @param id String
     * @param name String
     * @param mnemonic String
     * @param toggle boolean
     * @param group String
     * @return CompositeAction
     */
    public static CompositeAction createCompositeAction(String id, String name,
                                                        String mnemonic, boolean toggle,
                                                        String group) {
        return (CompositeAction)configureAction(new CompositeAction(name, id),
                                                mnemonic, toggle, group);
    }

    /**
     * constructs a ServerAction
     * 
     * @param id String
     * @param name String
     * @param mnemonic String
     * @return ServerAction
     */
    public static ServerAction createServerAction(String id, String name, String mnemonic) {
        ServerAction action = new ServerAction(name, id);
        if (mnemonic != null && !mnemonic.equals("")) {
            action.putValue(Action.MNEMONIC_KEY, (int) mnemonic.charAt(0));
        }
        return action;
    }


    /*
     * These methods are usefull for creating targetable actions
     */
    
    /**
     * constructs a TargetableAction
     * 
     * @param id String
     * @param name String
     * @return TargetableAction
     */
    public static TargetableAction createTargetableAction(String id, String name) {
        return createTargetableAction(id, name, null);
    }

    /**
     * constructs a TargetableAction
     * 
     * @param id String
     * @param name String
     * @param mnemonic String
     * @return TargetableAction
     */
    public static TargetableAction createTargetableAction(String id, String name, String mnemonic) {
        return createTargetableAction(id, name, mnemonic, false);
    }

    /**
     * constructs a TargetableAction
     * 
     * @param id String
     * @param name String
     * @param mnemonic String
     * @param toggle boolean
     * @return TargetableAction
     */
    public static TargetableAction createTargetableAction(String id, String name,
                                                          String mnemonic, boolean toggle) {
        return createTargetableAction(id, name, mnemonic, toggle, null);
    }

    /**
     * constructs a TargetableAction
     * 
     * @param id String
     * @param name String
     * @param mnemonic String
     * @param toggle boolean
     * @param group String
     * @return TargetableAction
     */
    public static TargetableAction createTargetableAction(String id, String name,
                                                          String mnemonic, boolean toggle,
                                                          String group) {
        return (TargetableAction)configureAction(new TargetableAction(name, id), mnemonic, toggle, group);
    }

    private static Action configureAction(AbstractActionExt action,
                                          String mnemonic, boolean toggle,
                                          String group) {
        action.setMnemonic(mnemonic);
        String description = action.getName() + " action with comand " + action.getActionCommand();
        action.setShortDescription(description);
        action.setLongDescription(description);

        if (toggle) {
            action.setStateAction();
        }
        if (group != null) {
            action.setGroup(group);
        }
        return action;
    }

    /**
     * Add additional attributes to the action. If any of these attributes
     * are null then they will still be set on the action. Many of these
     * attributes map to the set methods on AbstractActionExt
     * 
     * @param action the action which will all the attributes will be applied
     * @param shortDesc String
     * @param longDesc String
     * @param smallIcon Icon
     * @param largeIcon Icon
     * @param accel KeyStroke
     */
    public static void decorateAction(AbstractAction action,
                                      String shortDesc, String longDesc,
                                      Icon smallIcon, Icon largeIcon,
                                      KeyStroke accel) {
        if (action instanceof AbstractActionExt) {
            AbstractActionExt a = (AbstractActionExt)action;
            a.setShortDescription(shortDesc);
            a.setLongDescription(longDesc);
            a.setSmallIcon(smallIcon);
            a.setLargeIcon(largeIcon);
            a.setAccelerator(accel);
        }
        else {
            action.putValue(Action.SHORT_DESCRIPTION, shortDesc);
            action.putValue(Action.LONG_DESCRIPTION, longDesc);
            action.putValue(Action.SMALL_ICON, smallIcon);
            action.putValue(AbstractActionExt.LARGE_ICON, largeIcon);
            action.putValue(Action.ACCELERATOR_KEY, accel);
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy