mirror of
https://github.com/moparisthebest/davmail
synced 2025-01-12 22:18:11 -05:00
Improve Mac OSX Java6 support
git-svn-id: http://svn.code.sf.net/p/davmail/code/trunk@498 3d1905a2-6b24-0410-a738-b14d5a86fcbd
This commit is contained in:
parent
94d3deb6b4
commit
c0a7f59384
@ -21,6 +21,9 @@ public class AwtGatewayTray implements DavGatewayTrayInterface {
|
||||
protected AwtGatewayTray() {
|
||||
}
|
||||
|
||||
protected static AboutFrame aboutFrame;
|
||||
protected static SettingsFrame settingsFrame;
|
||||
|
||||
private static TrayIcon trayIcon = null;
|
||||
private static Image image = null;
|
||||
private static Image image2 = null;
|
||||
@ -86,6 +89,24 @@ public class AwtGatewayTray implements DavGatewayTrayInterface {
|
||||
});
|
||||
}
|
||||
|
||||
public void about() {
|
||||
SwingUtilities.invokeLater(new Runnable() {
|
||||
public void run() {
|
||||
aboutFrame.update();
|
||||
aboutFrame.setVisible(true);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
public void preferences() {
|
||||
SwingUtilities.invokeLater(new Runnable() {
|
||||
public void run() {
|
||||
settingsFrame.reload();
|
||||
settingsFrame.setVisible(true);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
public void init() {
|
||||
SwingUtilities.invokeLater(new Runnable() {
|
||||
public void run() {
|
||||
@ -95,7 +116,6 @@ public class AwtGatewayTray implements DavGatewayTrayInterface {
|
||||
}
|
||||
|
||||
|
||||
|
||||
protected void createAndShowGUI() {
|
||||
// set native look and feel
|
||||
try {
|
||||
@ -113,12 +133,11 @@ public class AwtGatewayTray implements DavGatewayTrayInterface {
|
||||
// create a popup menu
|
||||
PopupMenu popup = new PopupMenu();
|
||||
|
||||
final AboutFrame aboutFrame = new AboutFrame();
|
||||
aboutFrame = new AboutFrame();
|
||||
// create an action settingsListener to listen for settings action executed on the tray icon
|
||||
ActionListener aboutListener = new ActionListener() {
|
||||
public void actionPerformed(ActionEvent e) {
|
||||
aboutFrame.update();
|
||||
aboutFrame.setVisible(true);
|
||||
about();
|
||||
}
|
||||
};
|
||||
// create menu item for the default action
|
||||
@ -126,12 +145,11 @@ public class AwtGatewayTray implements DavGatewayTrayInterface {
|
||||
aboutItem.addActionListener(aboutListener);
|
||||
popup.add(aboutItem);
|
||||
|
||||
final SettingsFrame settingsFrame = new SettingsFrame();
|
||||
settingsFrame = new SettingsFrame();
|
||||
// create an action settingsListener to listen for settings action executed on the tray icon
|
||||
ActionListener settingsListener = new ActionListener() {
|
||||
public void actionPerformed(ActionEvent e) {
|
||||
settingsFrame.reload();
|
||||
settingsFrame.setVisible(true);
|
||||
preferences();
|
||||
}
|
||||
};
|
||||
// create menu item for the default action
|
||||
|
@ -127,7 +127,11 @@ public class DavGatewayTray {
|
||||
if (davGatewayTray == null) {
|
||||
try {
|
||||
if (SystemTray.isSupported()) {
|
||||
if (isOSX()) {
|
||||
davGatewayTray = new OSXAwtGatewayTray();
|
||||
} else {
|
||||
davGatewayTray = new AwtGatewayTray();
|
||||
}
|
||||
davGatewayTray.init();
|
||||
}
|
||||
} catch (NoClassDefFoundError e) {
|
||||
@ -135,7 +139,7 @@ public class DavGatewayTray {
|
||||
}
|
||||
}
|
||||
if (davGatewayTray == null) {
|
||||
if (System.getProperty("os.name").toLowerCase().startsWith("mac os x")) {
|
||||
if (isOSX()) {
|
||||
// MacOS
|
||||
davGatewayTray = new OSXFrameGatewayTray();
|
||||
} else {
|
||||
@ -146,6 +150,15 @@ public class DavGatewayTray {
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Test if running on OSX
|
||||
*
|
||||
* @return true on Mac OS X
|
||||
*/
|
||||
protected static boolean isOSX() {
|
||||
return System.getProperty("os.name").toLowerCase().startsWith("mac os x");
|
||||
}
|
||||
|
||||
/**
|
||||
* Load image with current class loader.
|
||||
*
|
||||
|
26
src/java/davmail/tray/OSXAwtGatewayTray.java
Normal file
26
src/java/davmail/tray/OSXAwtGatewayTray.java
Normal file
@ -0,0 +1,26 @@
|
||||
package davmail.tray;
|
||||
|
||||
import davmail.ui.OSXAdapter;
|
||||
|
||||
/**
|
||||
* Extended Awt tray with OSX extensions.
|
||||
*/
|
||||
public class OSXAwtGatewayTray extends AwtGatewayTray {
|
||||
@SuppressWarnings({"SameReturnValue"})
|
||||
public boolean quit() {
|
||||
return true;
|
||||
}
|
||||
|
||||
@Override
|
||||
protected void createAndShowGUI() {
|
||||
System.setProperty("apple.laf.useScreenMenuBar", "true");
|
||||
super.createAndShowGUI();
|
||||
try {
|
||||
OSXAdapter.setAboutHandler(this, AwtGatewayTray.class.getDeclaredMethod("about", (Class[]) null));
|
||||
OSXAdapter.setPreferencesHandler(this, AwtGatewayTray.class.getDeclaredMethod("preferences", (Class[]) null));
|
||||
OSXAdapter.setQuitHandler(this, OSXAwtGatewayTray.class.getDeclaredMethod("quit", (Class[]) null));
|
||||
} catch (Exception e) {
|
||||
DavGatewayTray.error("Error while loading the OSXAdapter", e);
|
||||
}
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user