2009-04-03 03:38:31 -04:00
|
|
|
package davmail.ui.tray;
|
2007-10-09 05:48:59 -04:00
|
|
|
|
2007-10-20 14:35:02 -04:00
|
|
|
import davmail.Settings;
|
2009-04-23 10:54:06 -04:00
|
|
|
import davmail.BundleMessage;
|
2009-05-17 18:24:43 -04:00
|
|
|
import davmail.DavGateway;
|
2008-11-03 05:56:57 -05:00
|
|
|
import davmail.ui.AboutFrame;
|
|
|
|
import davmail.ui.SettingsFrame;
|
2007-10-09 05:48:59 -04:00
|
|
|
import org.apache.log4j.Logger;
|
|
|
|
import org.apache.log4j.Priority;
|
|
|
|
import org.apache.log4j.lf5.LF5Appender;
|
|
|
|
import org.apache.log4j.lf5.LogLevel;
|
|
|
|
import org.apache.log4j.lf5.viewer.LogBrokerMonitor;
|
|
|
|
import org.eclipse.swt.SWT;
|
|
|
|
import org.eclipse.swt.graphics.Image;
|
2008-11-24 07:35:58 -05:00
|
|
|
import org.eclipse.swt.widgets.*;
|
|
|
|
|
2007-10-09 05:48:59 -04:00
|
|
|
import javax.swing.*;
|
|
|
|
import java.io.IOException;
|
|
|
|
import java.net.URL;
|
2007-10-09 08:01:58 -04:00
|
|
|
|
2007-10-09 05:48:59 -04:00
|
|
|
/**
|
|
|
|
* Tray icon handler based on SWT
|
|
|
|
*/
|
|
|
|
public class SwtGatewayTray implements DavGatewayTrayInterface {
|
|
|
|
protected SwtGatewayTray() {
|
|
|
|
}
|
|
|
|
|
2009-04-16 18:20:30 -04:00
|
|
|
private static TrayItem trayItem;
|
|
|
|
private static java.awt.Image awtImage;
|
|
|
|
private static Image image;
|
|
|
|
private static Image image2;
|
|
|
|
private static Image inactiveImage;
|
2007-10-09 05:48:59 -04:00
|
|
|
private static Display display;
|
|
|
|
private static Shell shell;
|
2009-05-17 18:24:43 -04:00
|
|
|
private static LogBrokerMonitor logBrokerMonitor;
|
2008-11-24 07:35:58 -05:00
|
|
|
private boolean isActive = true;
|
2009-04-16 18:20:30 -04:00
|
|
|
private boolean isReady;
|
2007-10-09 05:48:59 -04:00
|
|
|
|
2008-12-17 10:31:08 -05:00
|
|
|
private final Thread mainThread = Thread.currentThread();
|
|
|
|
|
2008-11-03 05:56:57 -05:00
|
|
|
public java.awt.Image getFrameIcon() {
|
|
|
|
return awtImage;
|
|
|
|
}
|
|
|
|
|
2007-10-09 05:48:59 -04:00
|
|
|
public void switchIcon() {
|
2008-11-24 07:35:58 -05:00
|
|
|
isActive = true;
|
|
|
|
display.syncExec(new Runnable() {
|
|
|
|
public void run() {
|
2009-05-07 04:45:45 -04:00
|
|
|
if (trayItem.getImage().equals(image)) {
|
2008-11-24 07:35:58 -05:00
|
|
|
trayItem.setImage(image2);
|
|
|
|
} else {
|
|
|
|
trayItem.setImage(image);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
2007-10-09 05:48:59 -04:00
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
public void resetIcon() {
|
2008-11-24 07:35:58 -05:00
|
|
|
display.syncExec(new Runnable() {
|
|
|
|
public void run() {
|
|
|
|
trayItem.setImage(image);
|
|
|
|
}
|
|
|
|
});
|
2007-10-09 05:48:59 -04:00
|
|
|
}
|
|
|
|
|
2008-11-24 07:35:58 -05:00
|
|
|
public void inactiveIcon() {
|
|
|
|
isActive = false;
|
|
|
|
display.syncExec(new Runnable() {
|
|
|
|
public void run() {
|
|
|
|
trayItem.setImage(inactiveImage);
|
2007-10-09 05:48:59 -04:00
|
|
|
}
|
2008-11-24 07:35:58 -05:00
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
public boolean isActive() {
|
|
|
|
return isActive;
|
|
|
|
}
|
|
|
|
|
|
|
|
public void displayMessage(final String message, final Priority priority) {
|
|
|
|
if (trayItem != null) {
|
|
|
|
display.asyncExec(new Runnable() {
|
|
|
|
public void run() {
|
|
|
|
int messageType = 0;
|
2009-05-07 04:45:45 -04:00
|
|
|
if (priority.equals(Priority.INFO)) {
|
2008-11-24 07:35:58 -05:00
|
|
|
messageType = SWT.ICON_INFORMATION;
|
2009-05-07 04:45:45 -04:00
|
|
|
} else if (priority.equals(Priority.WARN)) {
|
2008-11-24 07:35:58 -05:00
|
|
|
messageType = SWT.ICON_WARNING;
|
2009-05-07 04:45:45 -04:00
|
|
|
} else if (priority.equals(Priority.ERROR)) {
|
2008-11-24 07:35:58 -05:00
|
|
|
messageType = SWT.ICON_ERROR;
|
|
|
|
}
|
2008-12-17 10:31:08 -05:00
|
|
|
if (messageType != 0) {
|
2008-11-24 07:35:58 -05:00
|
|
|
final ToolTip toolTip = new ToolTip(shell, SWT.BALLOON | messageType);
|
2009-04-23 10:54:06 -04:00
|
|
|
toolTip.setText(BundleMessage.format("UI_DAVMAIL_GATEWAY"));
|
2008-11-24 07:35:58 -05:00
|
|
|
toolTip.setMessage(message);
|
|
|
|
trayItem.setToolTip(toolTip);
|
|
|
|
toolTip.setVisible(true);
|
|
|
|
}
|
2009-04-23 10:54:06 -04:00
|
|
|
trayItem.setToolTipText(BundleMessage.format("UI_DAVMAIL_GATEWAY") + '\n' + message);
|
2008-11-24 07:35:58 -05:00
|
|
|
}
|
|
|
|
});
|
2007-10-09 05:48:59 -04:00
|
|
|
}
|
2008-11-24 07:35:58 -05:00
|
|
|
}
|
2007-10-09 05:48:59 -04:00
|
|
|
|
2008-11-24 07:35:58 -05:00
|
|
|
/**
|
|
|
|
* Load image with current class loader.
|
|
|
|
*
|
|
|
|
* @param fileName image resource file name
|
|
|
|
* @return image
|
|
|
|
*/
|
|
|
|
public static Image loadSwtImage(String fileName) {
|
|
|
|
Image result = null;
|
|
|
|
try {
|
|
|
|
ClassLoader classloader = DavGatewayTray.class.getClassLoader();
|
|
|
|
URL imageUrl = classloader.getResource(fileName);
|
|
|
|
result = new Image(display, imageUrl.openStream());
|
|
|
|
} catch (IOException e) {
|
2009-04-23 10:54:06 -04:00
|
|
|
DavGatewayTray.warn(new BundleMessage("LOG_UNABLE_TO_LOAD_IMAGE"), e);
|
2008-11-24 07:35:58 -05:00
|
|
|
}
|
|
|
|
return result;
|
2007-10-09 05:48:59 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
public void init() {
|
|
|
|
// set native look and feel
|
|
|
|
try {
|
|
|
|
String lafClassName = UIManager.getSystemLookAndFeelClassName();
|
|
|
|
// workaround for bug when SWT and AWT both try to access Gtk
|
|
|
|
if (lafClassName.indexOf("gtk") > 0) {
|
|
|
|
lafClassName = UIManager.getCrossPlatformLookAndFeelClassName();
|
|
|
|
}
|
|
|
|
UIManager.setLookAndFeel(lafClassName);
|
|
|
|
} catch (Exception e) {
|
2009-04-23 10:54:06 -04:00
|
|
|
DavGatewayTray.warn(new BundleMessage("LOG_UNABLE_TO_SET_LOOK_AND_FEEL"));
|
2007-10-09 05:48:59 -04:00
|
|
|
}
|
|
|
|
|
2008-11-26 19:56:28 -05:00
|
|
|
new Thread("SWT") {
|
2009-04-16 17:52:17 -04:00
|
|
|
@Override
|
2007-10-09 05:48:59 -04:00
|
|
|
public void run() {
|
|
|
|
display = new Display();
|
|
|
|
shell = new Shell(display);
|
|
|
|
|
|
|
|
final Tray tray = display.getSystemTray();
|
|
|
|
if (tray != null) {
|
|
|
|
|
|
|
|
trayItem = new TrayItem(tray, SWT.NONE);
|
2009-04-23 10:54:06 -04:00
|
|
|
trayItem.setToolTipText(BundleMessage.format("UI_DAVMAIL_GATEWAY"));
|
2007-10-09 05:48:59 -04:00
|
|
|
|
2008-11-24 07:35:58 -05:00
|
|
|
awtImage = DavGatewayTray.loadImage("tray.png");
|
|
|
|
image = loadSwtImage("tray.png");
|
2009-04-07 08:39:09 -04:00
|
|
|
image2 = loadSwtImage(AwtGatewayTray.TRAY2_PNG);
|
|
|
|
inactiveImage = loadSwtImage(AwtGatewayTray.TRAYINACTIVE_PNG);
|
2007-10-09 05:48:59 -04:00
|
|
|
|
|
|
|
trayItem.setImage(image);
|
|
|
|
|
|
|
|
// create a popup menu
|
|
|
|
final Menu popup = new Menu(shell, SWT.POP_UP);
|
|
|
|
trayItem.addListener(SWT.MenuDetect, new Listener() {
|
|
|
|
public void handleEvent(Event event) {
|
2007-12-29 14:23:47 -05:00
|
|
|
display.asyncExec(
|
|
|
|
new Runnable() {
|
|
|
|
public void run() {
|
|
|
|
popup.setVisible(true);
|
|
|
|
}
|
|
|
|
});
|
2007-10-09 05:48:59 -04:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2008-10-19 17:00:22 -04:00
|
|
|
MenuItem aboutItem = new MenuItem(popup, SWT.PUSH);
|
2009-04-23 10:54:06 -04:00
|
|
|
aboutItem.setText(BundleMessage.format("UI_ABOUT"));
|
2008-10-19 17:00:22 -04:00
|
|
|
final AboutFrame aboutFrame = new AboutFrame();
|
|
|
|
aboutItem.addListener(SWT.Selection, new Listener() {
|
|
|
|
public void handleEvent(Event event) {
|
2009-02-11 08:28:09 -05:00
|
|
|
SwingUtilities.invokeLater(
|
2008-10-19 17:00:22 -04:00
|
|
|
new Runnable() {
|
|
|
|
public void run() {
|
2008-11-04 05:38:31 -05:00
|
|
|
aboutFrame.update();
|
2008-10-19 17:00:22 -04:00
|
|
|
aboutFrame.setVisible(true);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2007-10-09 05:48:59 -04:00
|
|
|
final SettingsFrame settingsFrame = new SettingsFrame();
|
|
|
|
trayItem.addListener(SWT.DefaultSelection, new Listener() {
|
|
|
|
public void handleEvent(Event event) {
|
2009-02-11 08:28:09 -05:00
|
|
|
SwingUtilities.invokeLater(
|
2007-10-09 05:48:59 -04:00
|
|
|
new Runnable() {
|
|
|
|
public void run() {
|
2008-10-31 13:12:30 -04:00
|
|
|
settingsFrame.reload();
|
2007-10-09 05:48:59 -04:00
|
|
|
settingsFrame.setVisible(true);
|
2008-11-07 13:26:49 -05:00
|
|
|
// workaround for focus on first open
|
|
|
|
settingsFrame.setVisible(true);
|
2007-10-09 05:48:59 -04:00
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
// create menu item for the default action
|
|
|
|
MenuItem defaultItem = new MenuItem(popup, SWT.PUSH);
|
2009-04-23 10:54:06 -04:00
|
|
|
defaultItem.setText(BundleMessage.format("UI_SETTINGS"));
|
2007-10-09 05:48:59 -04:00
|
|
|
defaultItem.addListener(SWT.Selection, new Listener() {
|
|
|
|
public void handleEvent(Event event) {
|
2009-02-11 08:28:09 -05:00
|
|
|
SwingUtilities.invokeLater(
|
2007-12-29 14:23:47 -05:00
|
|
|
new Runnable() {
|
|
|
|
public void run() {
|
2008-10-31 13:12:30 -04:00
|
|
|
settingsFrame.reload();
|
2008-01-31 18:40:26 -05:00
|
|
|
settingsFrame.setVisible(true);
|
2008-11-07 13:26:49 -05:00
|
|
|
// workaround for focus on first open
|
|
|
|
settingsFrame.setVisible(true);
|
2007-12-29 14:23:47 -05:00
|
|
|
}
|
|
|
|
});
|
2007-10-09 05:48:59 -04:00
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
MenuItem logItem = new MenuItem(popup, SWT.PUSH);
|
2009-04-23 10:54:06 -04:00
|
|
|
logItem.setText(BundleMessage.format("UI_SHOW_LOGS"));
|
2007-10-09 05:48:59 -04:00
|
|
|
logItem.addListener(SWT.Selection, new Listener() {
|
|
|
|
public void handleEvent(Event event) {
|
2009-02-11 08:28:09 -05:00
|
|
|
SwingUtilities.invokeLater(
|
2007-10-09 05:48:59 -04:00
|
|
|
new Runnable() {
|
|
|
|
public void run() {
|
|
|
|
|
|
|
|
Logger rootLogger = Logger.getRootLogger();
|
|
|
|
LF5Appender lf5Appender = (LF5Appender) rootLogger.getAppender("LF5Appender");
|
|
|
|
if (lf5Appender == null) {
|
2009-05-17 18:24:43 -04:00
|
|
|
logBrokerMonitor = new LogBrokerMonitor(LogLevel.getLog4JLevels()) {
|
2009-04-16 17:52:17 -04:00
|
|
|
@Override
|
2007-10-09 05:48:59 -04:00
|
|
|
protected void closeAfterConfirm() {
|
|
|
|
hide();
|
|
|
|
}
|
2009-05-17 18:24:43 -04:00
|
|
|
};
|
|
|
|
lf5Appender = new LF5Appender(logBrokerMonitor);
|
2007-10-09 05:48:59 -04:00
|
|
|
lf5Appender.setName("LF5Appender");
|
|
|
|
rootLogger.addAppender(lf5Appender);
|
|
|
|
}
|
|
|
|
lf5Appender.getLogBrokerMonitor().show();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
MenuItem exitItem = new MenuItem(popup, SWT.PUSH);
|
2009-04-23 10:54:06 -04:00
|
|
|
exitItem.setText(BundleMessage.format("UI_EXIT"));
|
2007-10-09 05:48:59 -04:00
|
|
|
exitItem.addListener(SWT.Selection, new Listener() {
|
|
|
|
public void handleEvent(Event event) {
|
2009-05-17 18:24:43 -04:00
|
|
|
DavGateway.stop();
|
2007-10-09 05:48:59 -04:00
|
|
|
shell.dispose();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
// display settings frame on first start
|
|
|
|
if (Settings.isFirstStart()) {
|
|
|
|
settingsFrame.setVisible(true);
|
|
|
|
}
|
2008-12-05 06:53:01 -05:00
|
|
|
synchronized (mainThread) {
|
2009-04-16 17:16:40 -04:00
|
|
|
// ready
|
|
|
|
isReady = true;
|
|
|
|
mainThread.notifyAll();
|
2008-12-05 06:53:01 -05:00
|
|
|
}
|
2007-10-09 05:48:59 -04:00
|
|
|
|
|
|
|
while (!shell.isDisposed()) {
|
2008-10-19 17:00:22 -04:00
|
|
|
if (!display.readAndDispatch()) {
|
2007-10-09 05:48:59 -04:00
|
|
|
display.sleep();
|
2008-10-19 17:00:22 -04:00
|
|
|
}
|
2007-10-09 05:48:59 -04:00
|
|
|
}
|
|
|
|
|
2009-05-17 18:24:43 -04:00
|
|
|
if (trayItem != null) {
|
|
|
|
trayItem.dispose();
|
2009-05-20 06:36:08 -04:00
|
|
|
trayItem = null;
|
2009-05-17 18:24:43 -04:00
|
|
|
}
|
|
|
|
|
2008-10-19 17:00:22 -04:00
|
|
|
if (image != null) {
|
2007-10-09 05:48:59 -04:00
|
|
|
image.dispose();
|
2008-10-19 17:00:22 -04:00
|
|
|
}
|
|
|
|
if (image2 != null) {
|
2007-10-09 05:48:59 -04:00
|
|
|
image2.dispose();
|
2008-10-19 17:00:22 -04:00
|
|
|
}
|
2007-10-09 05:48:59 -04:00
|
|
|
display.dispose();
|
2009-05-17 18:24:43 -04:00
|
|
|
// dispose AWT frames
|
|
|
|
settingsFrame.dispose();
|
|
|
|
aboutFrame.dispose();
|
|
|
|
if (logBrokerMonitor != null) {
|
|
|
|
logBrokerMonitor.dispose();
|
|
|
|
}
|
2009-05-20 06:36:08 -04:00
|
|
|
// make sure we do exit
|
|
|
|
System.exit(0);
|
2007-10-09 05:48:59 -04:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}.start();
|
2009-04-16 18:33:52 -04:00
|
|
|
while (true) {
|
2008-12-05 09:53:38 -05:00
|
|
|
// wait for SWT init
|
|
|
|
try {
|
|
|
|
synchronized (mainThread) {
|
2009-04-16 18:33:52 -04:00
|
|
|
if (isReady) {
|
|
|
|
break;
|
|
|
|
}
|
2008-12-05 09:53:38 -05:00
|
|
|
mainThread.wait(1000);
|
|
|
|
}
|
|
|
|
} catch (InterruptedException e) {
|
2009-04-23 10:54:06 -04:00
|
|
|
DavGatewayTray.error(new BundleMessage("LOG_ERROR_WAITING_FOR_SWT_INIT"), e);
|
2008-12-05 06:53:01 -05:00
|
|
|
}
|
|
|
|
}
|
2007-10-09 05:48:59 -04:00
|
|
|
}
|
2008-01-31 18:40:26 -05:00
|
|
|
|
2007-10-09 05:48:59 -04:00
|
|
|
}
|