net.sourceforge.squirrel_sql.fw.gui.action.BaseAction Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of fw Show documentation
Show all versions of fw Show documentation
The framework library contains utility classes that are generic and useful for building applications
that introspect a database via JDBC. These are not intended to be SQuirreLSQL-specific and could be
used by other projects JDBC front-end applications. This project is guaranteed to have no code
dependencies on other SQuirreLSQL projects and could therefore be used when building a different
JDBC front-end application.
package net.sourceforge.squirrel_sql.fw.gui.action;
/*
* Copyright (C) 2001-2004 Colin Bell
* [email protected]
*
* 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
*/
import java.awt.Component;
import java.awt.Frame;
import java.awt.event.ActionEvent;
import javax.swing.AbstractAction;
import javax.swing.Icon;
import javax.swing.JPopupMenu;
/**
* This is the base class for all Action classes.
*
* @author Colin Bell
*/
public abstract class BaseAction extends AbstractAction
{
/** Names of properties stored in action. */
public interface IBaseActionPropertyNames
{
String DISABLED_ICON = "squirrelDisabledIcon";
String ROLLOVER_ICON = "squirrelRolloverIcon";
}
/**
* Default ctor.
*/
protected BaseAction()
{
super();
}
/**
* Ctor specifying the title.
*
* @param title Title for this action.
*/
protected BaseAction(String title)
{
super(title);
}
/**
* Ctor specifying the title and icon.
*
* @param title Title for this action.
* @param icon Icon for this action.
*/
protected BaseAction(String title, Icon icon)
{
super(title, icon);
}
/**
* Return the Frame object associated with the passed event.
*
* @param evt ActionEvent to find frame for.
*
* @return Frame or null if none found.
*/
protected Frame getParentFrame(ActionEvent evt)
{
Frame parent = null;
if (evt != null)
{
final Object src = evt.getSource();
if (src instanceof Component)
{
Component comp = (Component)src;
while (comp != null && parent == null)
{
if (comp instanceof Frame)
{
parent = (Frame)comp;
}
else if (comp instanceof JPopupMenu)
{
comp = ((JPopupMenu)comp).getInvoker();
}
else
{
comp = comp.getParent();
}
}
}
}
return parent;
}
}