Mercurial > hg > release > thermostat-0.5
view client/swing/src/main/java/com/redhat/thermostat/client/swing/internal/Main.java @ 935:186115da601f
Make common-core not depend on storage-core.
Reviewed-by: vanaltj, omajid, ebaron
Review-thread: http://icedtea.classpath.org/pipermail/thermostat/2013-January/005042.html
author | Severin Gehwolf <sgehwolf@redhat.com> |
---|---|
date | Wed, 16 Jan 2013 18:58:59 +0100 |
parents | ccac9bcabaa0 |
children |
line wrap: on
line source
/* * Copyright 2012, 2013 Red Hat, Inc. * * This file is part of Thermostat. * * Thermostat is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published * by the Free Software Foundation; either version 2, or (at your * option) any later version. * * Thermostat 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 * General Public License for more details. * * You should have received a copy of the GNU General Public License * along with Thermostat; see the file COPYING. If not see * <http://www.gnu.org/licenses/>. * * Linking this code with other modules is making a combined work * based on this code. Thus, the terms and conditions of the GNU * General Public License cover the whole combination. * * As a special exception, the copyright holders of this code give * you permission to link this code with independent modules to * produce an executable, regardless of the license terms of these * independent modules, and to copy and distribute the resulting * executable under terms of your choice, provided that you also * meet, for each linked independent module, the terms and conditions * of the license of that module. An independent module is a module * which is not derived from or based on this code. If you modify * this code, you may extend this exception to your version of the * library, but you are not obligated to do so. If you do not wish * to do so, delete this exception statement from your version. */ package com.redhat.thermostat.client.swing.internal; import java.awt.EventQueue; import java.util.concurrent.ExecutorService; import java.util.logging.Level; import java.util.logging.Logger; import javax.swing.JOptionPane; import javax.swing.JPopupMenu; import javax.swing.SwingConstants; import javax.swing.SwingUtilities; import javax.swing.UIManager; import javax.swing.UnsupportedLookAndFeelException; import javax.swing.plaf.nimbus.NimbusLookAndFeel; import com.redhat.thermostat.client.core.views.ClientConfigurationView; import com.redhat.thermostat.client.locale.LocaleResources; import com.redhat.thermostat.client.swing.internal.config.ConnectionConfiguration; import com.redhat.thermostat.client.swing.internal.views.ClientConfigurationSwing; import com.redhat.thermostat.client.ui.ClientConfigReconnector; import com.redhat.thermostat.client.ui.ClientConfigurationController; import com.redhat.thermostat.client.ui.MainWindowController; import com.redhat.thermostat.client.ui.UiFacadeFactory; import com.redhat.thermostat.common.ApplicationService; import com.redhat.thermostat.common.Constants; import com.redhat.thermostat.common.config.ClientPreferences; import com.redhat.thermostat.common.locale.Translate; import com.redhat.thermostat.common.utils.LoggingUtils; import com.redhat.thermostat.common.utils.OSGIUtils; import com.redhat.thermostat.storage.config.StartupConfiguration; import com.redhat.thermostat.storage.core.Connection; import com.redhat.thermostat.storage.core.Connection.ConnectionListener; import com.redhat.thermostat.storage.core.Connection.ConnectionStatus; import com.redhat.thermostat.storage.core.Connection.ConnectionType; import com.redhat.thermostat.storage.core.StorageProvider; import com.redhat.thermostat.storage.core.StorageProviderUtil; import com.redhat.thermostat.storage.dao.DAOFactory; import com.redhat.thermostat.storage.dao.DAOFactoryImpl; import com.redhat.thermostat.utils.keyring.Keyring; public class Main { private static final Translate<LocaleResources> translator = LocaleResources.createLocalizer(); private static final Logger logger = LoggingUtils.getLogger(Main.class); private OSGIUtils serviceProvider; private UiFacadeFactory uiFacadeFactory; private DAOFactory daoFactory; public Main(Keyring keyring, UiFacadeFactory uiFacadeFactory, String[] args) { ClientPreferences prefs = new ClientPreferences(keyring); StartupConfiguration config = new ConnectionConfiguration(prefs); StorageProvider connProv = StorageProviderUtil.getStorageProvider(config); DAOFactory daoFactory = new DAOFactoryImpl(connProv); init(OSGIUtils.getInstance(), uiFacadeFactory, daoFactory); } Main(OSGIUtils serviceProvider, UiFacadeFactory uiFacadeFactory, DAOFactory daoFactory) { init(serviceProvider, uiFacadeFactory, daoFactory); } private void init(OSGIUtils serviceProvider, UiFacadeFactory uiFacadeFactory, DAOFactory daoFactory) { this.serviceProvider = serviceProvider; this.uiFacadeFactory = uiFacadeFactory; this.daoFactory = daoFactory; } private void setLAF() { boolean useDefault = false; // check if the user has other preferences... String laf = System.getProperty("swing.defaultlaf"); if (laf == null) { useDefault = true; } else if (laf.equalsIgnoreCase("dolphin")) { try { UIManager.setLookAndFeel("com.redhat.swing.laf.dolphin.DolphinLookAndFeel"); } catch (UnsupportedLookAndFeelException | ClassNotFoundException | InstantiationException | IllegalAccessException e) { useDefault = true; logger.log(Level.WARNING, "cannot set DolphinLookAndFeel"); } } else if (laf.equalsIgnoreCase("system")) { try { UIManager.setLookAndFeel(UIManager.getSystemLookAndFeelClassName()); } catch (UnsupportedLookAndFeelException | ClassNotFoundException | InstantiationException | IllegalAccessException e) { useDefault = true; logger.log(Level.WARNING, "cannot set System LookAndFeel"); } } if (useDefault) { try { UIManager.setLookAndFeel(new NimbusLookAndFeel()); } catch (UnsupportedLookAndFeelException e) { // well, whatever... logger.log(Level.WARNING, "cannot set NimbusLookAndFeel"); } } } public void run() { EventQueue.invokeLater(new Runnable() { @Override public void run() { setLAF(); // Thermostat JPopupMenu instances should all be // ThermostatPopupmenu, so this is redundant, but done in case // some client code doesn't use the internal popup JPopupMenu.setDefaultLightWeightPopupEnabled(false); // TODO: move them in an appropriate place UIManager.getDefaults().put("OptionPane.buttonOrientation", SwingConstants.RIGHT); UIManager.getDefaults().put("OptionPane.isYesLast", true); UIManager.getDefaults().put("OptionPane.sameSizeButtons", true); showGui(); } }); try { uiFacadeFactory.awaitShutdown(); } catch (InterruptedException e) { Thread.currentThread().interrupt(); } } private void showGui() { ApplicationService appSrv = serviceProvider.getService(ApplicationService.class); final ExecutorService service = appSrv.getApplicationExecutor(); service.execute(new ConnectorSetup(service)); } private class ConnectorSetup implements Runnable { private ExecutorService service; public ConnectorSetup(ExecutorService service) { this.service = service; } @Override public void run() { Connection connection = daoFactory.getConnection(); connection.setType(ConnectionType.LOCAL); ConnectionListener connectionListener = new ConnectionHandler(connection, service); connection.addListener(connectionListener); try { connection.connect(); } catch (Throwable t) { logger.log(Level.WARNING, "connection attempt failed: ", t); } } } private class Connector implements Runnable { private Connection connection; Connector(Connection connection) { this.connection = connection; } @Override public void run() { try { connection.connect(); } catch (Throwable t) { logger.log(Level.WARNING, "connection attempt failed: ", t); } } } private class ConnectionAttemp implements Runnable { private Connection connection; private ExecutorService service; public ConnectionAttemp(Connection connection, ExecutorService service) { this.connection = connection; this.service = service; } @Override public void run() { Object[] options = { translator.localize(LocaleResources.CONNECTION_WIZARD), translator.localize(LocaleResources.CONNECTION_QUIT), }; int n = JOptionPane .showOptionDialog( null, translator.localize(LocaleResources.CONNECTION_FAILED_TO_CONNECT_DESCRIPTION), translator.localize(LocaleResources.CONNECTION_FAILED_TO_CONNECT_TITLE), JOptionPane.OK_CANCEL_OPTION, JOptionPane.ERROR_MESSAGE, null, options, options[0]); switch (n) { case JOptionPane.CANCEL_OPTION: case JOptionPane.CLOSED_OPTION: case JOptionPane.NO_OPTION: uiFacadeFactory .shutdown(Constants.EXIT_UNABLE_TO_CONNECT_TO_DATABASE); break; case JOptionPane.YES_OPTION: default: createPreferencesDialog(connection, service); break; } } } private void connect(Connection connection, ExecutorService service) { service.execute(new Connector(connection)); } private class MainClientConfigReconnector implements ClientConfigReconnector { private Connection connection; private ExecutorService service; public MainClientConfigReconnector(Connection connection, ExecutorService service) { this.connection = connection; this.service = service; } @Override public void reconnect(ClientPreferences prefs) { connection.setUrl(prefs.getConnectionUrl()); connect(connection, service); } @Override public void abort() { uiFacadeFactory.shutdown(Constants.EXIT_UNABLE_TO_CONNECT_TO_DATABASE); } } private void createPreferencesDialog(final Connection connection, final ExecutorService service) { ClientPreferences prefs = new ClientPreferences(OSGIUtils.getInstance().getService(Keyring.class)); ClientConfigurationView configDialog = new ClientConfigurationSwing(); ClientConfigurationController controller = new ClientConfigurationController(prefs, configDialog, new MainClientConfigReconnector(connection, service)); controller.showDialog(); } private class ConnectionHandler implements ConnectionListener { private boolean retry; private Connection connection; private ExecutorService service; public ConnectionHandler(Connection connection, ExecutorService service) { this.connection = connection; this.retry = true; this.service = service; } private void showConnectionAttemptWarning() { SwingUtilities.invokeLater(new ConnectionAttemp(connection, service)); } @Override public void changed(ConnectionStatus newStatus) { if (newStatus == ConnectionStatus.CONNECTED) { // register the storage, so other services can request it daoFactory.registerDAOsAndStorageAsOSGiServices(); uiFacadeFactory.setHostInfoDao(daoFactory.getHostInfoDAO()); uiFacadeFactory.setVmInfoDao(daoFactory.getVmInfoDAO()); showMainWindow(); } else if (newStatus == ConnectionStatus.FAILED_TO_CONNECT) { if (retry) { retry = false; showConnectionAttemptWarning(); } else { JOptionPane.showMessageDialog( null, translator.localize(LocaleResources.CONNECTION_FAILED_TO_CONNECT_DESCRIPTION), translator.localize(LocaleResources.CONNECTION_FAILED_TO_CONNECT_TITLE), JOptionPane.ERROR_MESSAGE); uiFacadeFactory.shutdown(Constants.EXIT_UNABLE_TO_CONNECT_TO_DATABASE); } } } } private void showMainWindow() { SwingUtilities.invokeLater(new ShowMainWindow()); } private class ShowMainWindow implements Runnable { @Override public void run() { MainWindowController mainController = uiFacadeFactory.getMainWindow(); mainController.showMainMainWindow(); } } }