X-Git-Url: https://git.pterodactylus.net/?p=jkeytool.git;a=blobdiff_plain;f=src%2Fnet%2Fpterodactylus%2Fjkeytool%2Fgui%2Fswing%2FSwingInterface.java;h=6a6597e30e867cd471cb2c4a5f10635f9d9f42fd;hp=4d287d9e7893dae60f071a27ca89970a2eaa0278;hb=0024383ab6e99742fdf45ff5390ef144c3bfc4b1;hpb=93811f6061a8da43bd50cf04cffcc150d465f845 diff --git a/src/net/pterodactylus/jkeytool/gui/swing/SwingInterface.java b/src/net/pterodactylus/jkeytool/gui/swing/SwingInterface.java index 4d287d9..6a6597e 100644 --- a/src/net/pterodactylus/jkeytool/gui/swing/SwingInterface.java +++ b/src/net/pterodactylus/jkeytool/gui/swing/SwingInterface.java @@ -19,11 +19,22 @@ package net.pterodactylus.jkeytool.gui.swing; +import java.awt.BorderLayout; import java.io.File; import java.security.KeyStore; +import java.util.HashMap; +import java.util.Map; + +import javax.swing.BorderFactory; +import javax.swing.JComponent; +import javax.swing.JFrame; +import javax.swing.JPanel; +import javax.swing.JTabbedPane; import net.pterodactylus.jkeytool.core.Core; import net.pterodactylus.jkeytool.gui.Interface; +import net.pterodactylus.jkeytool.main.Main; +import net.pterodactylus.util.swing.StatusBar; /** * TODO @@ -35,6 +46,41 @@ public class SwingInterface implements Interface { /** The core to control. */ private Core core; + /** The main frame. */ + private JFrame mainFrame = new JFrame("jkeytool " + Main.getVersion()); + + /** The tab pane. */ + private JTabbedPane tabPane = new JTabbedPane(); + + /** The status bar. */ + private StatusBar statusBar = new StatusBar(); + + /** Loaded key stores and their panels. */ + private final Map keyStores = new HashMap(); + + public SwingInterface() { + createFrame(); + } + + // + // PRIVATE METHODS + // + + private void createFrame() { + mainFrame.getContentPane().add(createCenterPanel(), BorderLayout.CENTER); + mainFrame.getContentPane().add(statusBar, BorderLayout.PAGE_END); + mainFrame.pack(); + } + + private JComponent createCenterPanel() { + JPanel centerPanel = new JPanel(new BorderLayout()); + centerPanel.setBorder(BorderFactory.createEmptyBorder(6, 6, 6, 6)); + + centerPanel.add(tabPane, BorderLayout.CENTER); + + return centerPanel; + } + // // INTERFACE Interface // @@ -53,6 +99,15 @@ public class SwingInterface implements Interface { * {@inheritDoc} */ public void start() { + mainFrame.setVisible(true); + statusBar.setText("jkeytool startup complete."); + core.loadKeyStore(new File("client.p12")); + } + + /** + * {@inheritDoc} + */ + public void stop() { /* TODO */ } @@ -71,7 +126,9 @@ public class SwingInterface implements Interface { * {@inheritDoc} */ public void keyStoreLoaded(File keyStoreFile, KeyStore keyStore) { - /* TODO */ + KeyStorePanel keyStorePanel = new KeyStorePanel(keyStore); + keyStores.put(keyStore, keyStorePanel); + tabPane.addTab(keyStoreFile.getName(), keyStorePanel); } /**