X-Git-Url: https://git.pterodactylus.net/?a=blobdiff_plain;f=src%2Fnet%2Fpterodactylus%2Fjsite%2Fgui%2FMainWindow.java;h=e91a9dc178a9b7945d49e8247f9af90a7973e153;hb=f29d7d5e8028482735f51d4a93cfd0d937151051;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..e91a9dc 100644
--- a/src/net/pterodactylus/jsite/gui/MainWindow.java
+++ b/src/net/pterodactylus/jsite/gui/MainWindow.java
@@ -20,10 +20,17 @@
package net.pterodactylus.jsite.gui;
import java.awt.BorderLayout;
+import java.awt.Component;
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.beans.PropertyChangeEvent;
+import java.beans.PropertyChangeListener;
+import java.util.Timer;
+import java.util.TimerTask;
+import java.util.logging.Logger;
import javax.swing.Action;
import javax.swing.Box;
@@ -33,7 +40,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;
@@ -44,16 +53,21 @@ import net.pterodactylus.jsite.i18n.I18nable;
import net.pterodactylus.jsite.i18n.gui.I18nAction;
import net.pterodactylus.jsite.i18n.gui.I18nMenu;
import net.pterodactylus.jsite.main.Version;
+import net.pterodactylus.util.logging.Logging;
import net.pterodactylus.util.swing.StatusBar;
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, PropertyChangeListener {
+
+ /** Logger. */
+ @SuppressWarnings("unused")
+ private static final Logger logger = Logging.getLogger(MainWindow.class.getName());
/** The swing interface that receives all actions. */
private final SwingInterface swingInterface;
@@ -61,6 +75,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 +117,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 +135,7 @@ public class MainWindow extends JFrame implements I18nable {
pack();
SwingUtils.center(this);
I18n.registerI18nable(this);
- setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);
+ addWindowListener(this);
}
//
@@ -118,17 +144,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 +210,7 @@ public class MainWindow extends JFrame implements I18nable {
/**
* Returns the currently selected project.
- *
+ *
* @return The currently selected project
*/
public Project getSelectedProject() {
@@ -185,6 +245,20 @@ 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);
+ int newTabIndex = projectPane.getTabCount();
+ projectPane.add(project.getName(), projectPanel);
+ projectPane.setToolTipTextAt(newTabIndex, project.getDescription());
+ project.addPropertyChangeListener(this);
+ }
+
//
// PRIVATE METHODS
//
@@ -289,8 +363,11 @@ public class MainWindow extends JFrame implements I18nable {
projectOverviewPanel.add(addProjectButton);
projectOverviewPanel.add(Box.createVerticalGlue());
-// JPanel lowerPanel = new JPanel(new BorderLayout(12, 12));
-// getContentPane().add(lowerPanel, BorderLayout.CENTER);
+ 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 +406,87 @@ 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. */
+ }
+
+ //
+ // INTERFACE PropertyChangeListener
+ //
+
+ /**
+ * @see java.beans.PropertyChangeListener#propertyChange(java.beans.PropertyChangeEvent)
+ */
+ public void propertyChange(PropertyChangeEvent propertyChangeEvent) {
+ Object eventSource = propertyChangeEvent.getSource();
+ String propertyName = propertyChangeEvent.getPropertyName();
+ if (eventSource instanceof Project) {
+ /* if a project was changed, update the tab title and tooltip. */
+ if (Project.PROPERTY_NAME.equals(propertyName) || Project.PROPERTY_DESCRIPTION.equals(propertyName)) {
+ Project project = (Project) eventSource;
+ int tabCount = projectPane.getTabCount();
+ for (int tabIndex = 0; tabIndex < tabCount; tabIndex++) {
+ Component tabComponent = projectPane.getComponentAt(tabIndex);
+ if (tabComponent instanceof ProjectPanel) {
+ Project tabProject = ((ProjectPanel) tabComponent).getProject();
+ if (tabProject.equals(project)) {
+ projectPane.setTitleAt(tabIndex, project.getName());
+ projectPane.setToolTipTextAt(tabIndex, project.getDescription());
+ projectPane.repaint();
+ }
+ }
+ }
+ }
+ }
+ }
+
}