X-Git-Url: https://git.pterodactylus.net/?p=jkeytool.git;a=blobdiff_plain;f=src%2Fnet%2Fpterodactylus%2Fjkeytool%2Fgui%2Fswing%2FSwingInterface.java;h=165a6d6ab791620aa2e1c679a0830d75ee10376d;hp=107dc8d1938ad15b39bff7eb3044cf9a6d29d228;hb=caae8a8c82efbd16ae5a45ee352a761e445d5de5;hpb=7255bdf4430ded3abfbc342f15ccd9091b9617b7 diff --git a/src/net/pterodactylus/jkeytool/gui/swing/SwingInterface.java b/src/net/pterodactylus/jkeytool/gui/swing/SwingInterface.java index 107dc8d..165a6d6 100644 --- a/src/net/pterodactylus/jkeytool/gui/swing/SwingInterface.java +++ b/src/net/pterodactylus/jkeytool/gui/swing/SwingInterface.java @@ -30,13 +30,18 @@ import javax.swing.Action; import javax.swing.BorderFactory; import javax.swing.JComponent; import javax.swing.JFrame; +import javax.swing.JMenu; +import javax.swing.JMenuBar; import javax.swing.JPanel; import javax.swing.JTabbedPane; +import javax.swing.JToolBar; import net.pterodactylus.jkeytool.core.Core; import net.pterodactylus.jkeytool.gui.Interface; import net.pterodactylus.jkeytool.main.Main; +import net.pterodactylus.util.i18n.I18n; import net.pterodactylus.util.i18n.gui.I18nAction; +import net.pterodactylus.util.i18n.gui.I18nMenu; import net.pterodactylus.util.swing.StatusBar; /** @@ -49,6 +54,9 @@ public class SwingInterface implements Interface { /** The core to control. */ private Core core; + /** The I18n container. */ + private I18n i18n = new I18n("jkeytool", SwingInterface.class); + /** The main frame. */ private JFrame mainFrame = new JFrame("jkeytool " + Main.getVersion()); @@ -67,6 +75,9 @@ public class SwingInterface implements Interface { /** Loaded key stores and their panels. */ private final Map keyStores = new HashMap(); + /** + * Creates a new Swing interface. + */ public SwingInterface() { createActions(); createFrame(); @@ -76,9 +87,16 @@ public class SwingInterface implements Interface { // ACTIONS // + /** + * Creates a new key store. + */ private void createKeyStore() { + /* TODO */ } + /** + * Exits the application. + */ private void quit() { System.exit(0); } @@ -87,15 +105,18 @@ public class SwingInterface implements Interface { // PRIVATE METHODS // + /** + * Creates all used actions. + */ private void createActions() { - createKeyStoreAction = new I18nAction("jkeytool.action.createKeyStore") { + createKeyStoreAction = new I18nAction(i18n, "jkeytool.action.createKeyStore") { @SuppressWarnings("synthetic-access") public void actionPerformed(ActionEvent actionEvent) { createKeyStore(); } }; - quitAction = new I18nAction("jkeytool.action.quit") { + quitAction = new I18nAction(i18n, "jkeytool.action.quit") { /** * @see java.awt.event.ActionListener#actionPerformed(java.awt.event.ActionEvent) @@ -107,12 +128,22 @@ public class SwingInterface implements Interface { }; } + /** + * Creates the application main frame. + */ private void createFrame() { + mainFrame.setJMenuBar(createMenubar()); + mainFrame.getContentPane().add(createToolbar(), BorderLayout.PAGE_START); mainFrame.getContentPane().add(createCenterPanel(), BorderLayout.CENTER); mainFrame.getContentPane().add(statusBar, BorderLayout.PAGE_END); mainFrame.pack(); } + /** + * Creates the central panel of the frame. + * + * @return The central panel of the frame + */ private JComponent createCenterPanel() { JPanel centerPanel = new JPanel(new BorderLayout()); centerPanel.setBorder(BorderFactory.createEmptyBorder(6, 6, 6, 6)); @@ -122,6 +153,37 @@ public class SwingInterface implements Interface { return centerPanel; } + /** + * Creates the menu bar of the frame. + * + * @return The menu bar of the frame + */ + private JMenuBar createMenubar() { + JMenuBar menubar = new JMenuBar(); + + JMenu fileMenu = new I18nMenu(i18n, "jkeytool.menu.file"); + menubar.add(fileMenu); + fileMenu.add(createKeyStoreAction); + fileMenu.addSeparator(); + fileMenu.add(quitAction); + + return menubar; + } + + /** + * Creates the tool bar of the frame. + * + * @return The tool bar of the frame + */ + private JToolBar createToolbar() { + JToolBar toolbar = new JToolBar(); + + toolbar.add(createKeyStoreAction); + toolbar.add(quitAction); + + return toolbar; + } + // // INTERFACE Interface // @@ -167,7 +229,7 @@ public class SwingInterface implements Interface { * {@inheritDoc} */ public void keyStoreLoaded(File keyStoreFile, KeyStore keyStore) { - KeyStorePanel keyStorePanel = new KeyStorePanel(keyStore); + KeyStorePanel keyStorePanel = new KeyStorePanel(i18n, keyStore); keyStores.put(keyStore, keyStorePanel); tabPane.addTab(keyStoreFile.getName(), keyStorePanel); }