-
Notifications
You must be signed in to change notification settings - Fork 3.9k
Tray
Tray API requires node-webkit >= v0.3.0
Tray
is an abstraction of different controls on different platforms, usually it's a small icon shown on the OS's notification area. On Mac it's called Status Item
, on GTK it's Status Icon
, and on Windows it's System Tray Icon
.
// Load native UI library
var gui = require('nw.gui');
// Create a tray icon
var tray = new gui.Tray({ title: 'Tray', icon: 'img/icon.png' });
// Give it a menu
var menu = new gui.Menu();
menu.append({ label: 'Item' });
tray.menu = menu;
// Remove the tray
tray.remove();
tray = null;
Create a new Tray
, option
is an object contains initial settings for the Tray
. option
can have following fields: title
, tooltip
, icon
and menu
.
Every field has its own property in the Tray
, see documentation of each property for details.
Get or Set the title
of Tray
.
On Mac title
will be showed on status bar along with its icon
, but it doesn't have effects on GTK and Windows, since the latter two platforms only support tray to be showed as icons.
Get or Set the tooltip
of Tray
. tooltip
shows when you hover the Tray
with mouse.
tooltip
is showed on all three platforms.
Get or Set the icon
of Tray
, icon
must a path to your icon file. It can be a relative path which points to an icon in your app, or an absolute path pointing to a file in user's system.
Get or Set the menu
of Tray
, menu
will be showed when you click on the Tray
icon.
On Mac the menu will be showed when you click on the tray (which is the only action available for tray icons on Mac). On Windows and Linux, the menu will be showed when you single click on the tray with right mouse button, clicking with left mouse button sends the click
event and does not show a menu.
In order to reduce differences from different platforms, setting menu
property is the only way to bind a menu to tray, there's no way to popup a menu with left mouse button click on Linux and Windows.
Remove the tray.
Once removed, you will not be able to show it again and you should set your tray variable to null
. There is no way temporarily hide a tray icon.
Following events can be listened by using Tray.on()
function, for more information on how to receive events, you can visit EventEmitter.
Emitted when user clicks the menu item with left mouse button. You can only catch this event on Windows
and Linux
, since there is no way to catch it on Mac. So you should never make user interactive rely on the click
event.
And you cannot catch click with right mouse button, because it is used to show menu. Even if you're not binding a menu to a tray, you still can not listen to it. Double click events are also ignored.