01: package net.sourceforge.squirrel_sql.client.mainframe.action;
02:
03: /*
04: * Copyright (C) 2001-2004 Colin Bell
05: * colbell@users.sourceforge.net
06: *
07: * This library is free software; you can redistribute it and/or
08: * modify it under the terms of the GNU Lesser General Public
09: * License as published by the Free Software Foundation; either
10: * version 2.1 of the License, or (at your option) any later version.
11: *
12: * This library is distributed in the hope that it will be useful,
13: * but WITHOUT ANY WARRANTY; without even the implied warranty of
14: * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15: * Lesser General Public License for more details.
16: *
17: * You should have received a copy of the GNU Lesser General Public
18: * License along with this library; if not, write to the Free Software
19: * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
20: */
21: import java.awt.event.ActionEvent;
22: import java.beans.PropertyVetoException;
23:
24: import net.sourceforge.squirrel_sql.fw.sql.ISQLAlias;
25: import net.sourceforge.squirrel_sql.fw.util.StringManager;
26: import net.sourceforge.squirrel_sql.fw.util.StringManagerFactory;
27: import net.sourceforge.squirrel_sql.fw.util.log.ILogger;
28: import net.sourceforge.squirrel_sql.fw.util.log.LoggerController;
29:
30: import net.sourceforge.squirrel_sql.client.IApplication;
31: import net.sourceforge.squirrel_sql.client.action.SquirrelAction;
32: import net.sourceforge.squirrel_sql.client.gui.db.AliasesListInternalFrame;
33: import net.sourceforge.squirrel_sql.client.gui.db.IAliasesList;
34: import net.sourceforge.squirrel_sql.client.gui.db.SQLAlias;
35:
36: /**
37: * This <CODE>Action</CODE> allows the user to connect to an alias.
38: *
39: * @author <A HREF="mailto:colbell@users.sourceforge.net">Colin Bell</A>
40: */
41: public class ConnectToAliasAction extends SquirrelAction {
42: /** Logger for this class. */
43: private static ILogger s_log = LoggerController
44: .createLogger(ConnectToAliasAction.class);
45:
46: /** Internationalized strings for this class. */
47: private static final StringManager s_stringMgr = StringManagerFactory
48: .getStringManager(ConnectToAliasAction.class);
49:
50: /**
51: * List of all the users aliases.
52: */
53: private final IAliasesList _aliases;
54:
55: /**
56: * Ctor specifying the list of aliases.
57: *
58: * @param app Application API.
59: * @param list List of <TT>ISQLAlias</TT> objects.
60: */
61: public ConnectToAliasAction(IApplication app, IAliasesList list) {
62: super (app);
63: _aliases = list;
64: }
65:
66: /**
67: * Perform this action. Retrieve the current alias from this list and
68: * connect to it.
69: *
70: * @param evt The current event.
71: */
72: public void actionPerformed(ActionEvent evt) {
73: final IApplication app = getApplication();
74: final AliasesListInternalFrame tw = app.getWindowManager()
75: .getAliasesListInternalFrame();
76: tw.moveToFront();
77: try {
78: tw.setSelected(true);
79: } catch (PropertyVetoException ex) {
80: // i18n[ConnectToAliasAction.error.selectingwindow=Error selecting window]
81: s_log
82: .error(
83: s_stringMgr
84: .getString("ConnectToAliasAction.error.selectingwindow"),
85: ex);
86: }
87: final SQLAlias alias = _aliases.getSelectedAlias();
88: if (alias != null) {
89: new ConnectToAliasCommand(app, alias).execute();
90: }
91: }
92: }
|