Add tabbed panel for key stores.
[jkeytool.git] / src / net / pterodactylus / jkeytool / gui / swing / SwingInterface.java
index 4d287d9..6a6597e 100644 (file)
 
 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<KeyStore, KeyStorePanel> keyStores = new HashMap<KeyStore, KeyStorePanel>();
+
+       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);
        }
 
        /**