X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;ds=inline;f=src%2Fnet%2Fpterodactylus%2Fjsite%2Fgui%2FMainWindow.java;h=6708f5e90467bdfb9cf12032c9f0210a5ac56a32;hb=f42a2065246b7cef6d307478e146cb59d563504c;hp=fc9986a45b32b9d84a5158e2dcc7a8689c86463d;hpb=3147745190bab479d89840ff706d3e346692fd49;p=jSite2.git
diff --git a/src/net/pterodactylus/jsite/gui/MainWindow.java b/src/net/pterodactylus/jsite/gui/MainWindow.java
index fc9986a..6708f5e 100644
--- a/src/net/pterodactylus/jsite/gui/MainWindow.java
+++ b/src/net/pterodactylus/jsite/gui/MainWindow.java
@@ -24,6 +24,9 @@ import java.awt.Container;
import java.awt.Dimension;
import java.awt.event.WindowAdapter;
import java.awt.event.WindowEvent;
+import java.awt.event.WindowListener;
+import java.util.Timer;
+import java.util.TimerTask;
import javax.swing.Action;
import javax.swing.Box;
@@ -33,7 +36,9 @@ import javax.swing.JFrame;
import javax.swing.JMenuBar;
import javax.swing.JMenuItem;
import javax.swing.JPanel;
+import javax.swing.JScrollPane;
import javax.swing.JTabbedPane;
+import javax.swing.JTable;
import javax.swing.JToolBar;
import javax.swing.SwingConstants;
import javax.swing.border.EmptyBorder;
@@ -49,11 +54,11 @@ import net.pterodactylus.util.swing.SwingUtils;
/**
* Defines the main window of the application.
- *
+ *
* @author David âBombeâ Roden <bombe@freenetproject.org>
* @version $Id$
*/
-public class MainWindow extends JFrame implements I18nable {
+public class MainWindow extends JFrame implements WindowListener, I18nable {
/** The swing interface that receives all actions. */
private final SwingInterface swingInterface;
@@ -61,6 +66,15 @@ public class MainWindow extends JFrame implements I18nable {
/** The status bar. */
private StatusBar statusBar = new StatusBar();
+ /** Timer for clearing the status bar. */
+ private Timer statusBarClearTimer = new Timer("StatusBar Cleaner", true);
+
+ /** Object for status bar clearing ticker event. */
+ private TimerTask statusBarClearTimerTask;
+
+ /** Delay (in seconds) after which to clear status bar. */
+ private int statusBarClearDelay = 5000;
+
/** The content pane. */
private JPanel contentPane = new JPanel(new BorderLayout(12, 12));
@@ -94,10 +108,13 @@ public class MainWindow extends JFrame implements I18nable {
/** The project overview panel. */
private Box projectOverviewPanel;
+ /** The request table. */
+ private JTable requestTable;
+
/**
* Creates a new main window that redirects all actions to the given swing
* interface.
- *
+ *
* @param swingInterface
* The swing interface to receive all actions
*/
@@ -109,7 +126,7 @@ public class MainWindow extends JFrame implements I18nable {
pack();
SwingUtils.center(this);
I18n.registerI18nable(this);
- setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
+ addWindowListener(this);
}
//
@@ -118,17 +135,51 @@ public class MainWindow extends JFrame implements I18nable {
/**
* Sets the text of the status bar.
- *
+ *
* @param text
* The text of the status bar
*/
public void setStatusBarText(String text) {
statusBar.setText(text);
+ synchronized (statusBar) {
+ if (statusBarClearTimerTask != null) {
+ statusBarClearTimerTask.cancel();
+ }
+ statusBarClearTimerTask = new TimerTask() {
+
+ @SuppressWarnings("synthetic-access")
+ @Override
+ public void run() {
+ statusBar.setText("\u00a0");
+ }
+
+ };
+ statusBarClearTimer.schedule(statusBarClearTimerTask, statusBarClearDelay);
+ }
+ }
+
+ /**
+ * Returns the status bar clear delay (in milliseconds).
+ *
+ * @return The status bar clear delay
+ */
+ public int getStatusBarClearDelay() {
+ return statusBarClearDelay;
+ }
+
+ /**
+ * Sets the status bar clear delay (in milliseconds).
+ *
+ * @param statusBarClearDelay
+ * The status bar clear delay
+ */
+ public void setStatusBarClearDelay(int statusBarClearDelay) {
+ this.statusBarClearDelay = statusBarClearDelay;
}
/**
* Sets whether the advanced mode is activated.
- *
+ *
* @param advancedMode
* true
if the advanced mode is activated,
* false
if the simple mode is activated
@@ -150,7 +201,7 @@ public class MainWindow extends JFrame implements I18nable {
/**
* Returns the currently selected project.
- *
+ *
* @return The currently selected project
*/
public Project getSelectedProject() {
@@ -185,6 +236,17 @@ public class MainWindow extends JFrame implements I18nable {
}
}
+ /**
+ * Adds a project to the project pane.
+ *
+ * @param project
+ * The project to add
+ */
+ void addProject(Project project) {
+ ProjectPanel projectPanel = new ProjectPanel(swingInterface, project);
+ projectPane.add(project.getName(), projectPanel);
+ }
+
//
// PRIVATE METHODS
//
@@ -289,6 +351,9 @@ public class MainWindow extends JFrame implements I18nable {
projectOverviewPanel.add(addProjectButton);
projectOverviewPanel.add(Box.createVerticalGlue());
+ requestTable = new JTable(swingInterface.getRequestTableModel());
+ getContentPane().add(new JScrollPane(requestTable), BorderLayout.CENTER);
+
// JPanel lowerPanel = new JPanel(new BorderLayout(12, 12));
// getContentPane().add(lowerPanel, BorderLayout.CENTER);
}
@@ -329,4 +394,57 @@ public class MainWindow extends JFrame implements I18nable {
SwingUtils.repackCentered(this);
}
+ //
+ // INTERFACE WindowListener
+ //
+
+ /**
+ * {@inheritDoc}
+ */
+ public void windowActivated(WindowEvent e) {
+ /* do nothing. */
+ }
+
+ /**
+ * {@inheritDoc}
+ */
+ public void windowClosed(WindowEvent e) {
+ /* do nothing. */
+ }
+
+ /**
+ * {@inheritDoc}
+ */
+ public void windowClosing(WindowEvent e) {
+ swingInterface.getQuitAction().actionPerformed(null);
+ }
+
+ /**
+ * {@inheritDoc}
+ */
+ public void windowDeactivated(WindowEvent e) {
+ /* do nothing. */
+ }
+
+ /**
+ * {@inheritDoc}
+ */
+ public void windowDeiconified(WindowEvent e) {
+ /* do nothing. */
+ }
+
+ /**
+ * {@inheritDoc}
+ */
+ public void windowIconified(WindowEvent e) {
+ /* do nothing. */
+ }
+
+ /**
+ * {@inheritDoc}
+ */
+ public void windowOpened(WindowEvent e) {
+ /* do nothing. */
+ }
+
}