300 lines
8.5 KiB
Markdown
300 lines
8.5 KiB
Markdown
## Class: Tray
|
|
|
|
> Add icons and context menus to the system's notification area.
|
|
|
|
Process: [Main](../glossary.md#main-process)
|
|
|
|
`Tray` is an [EventEmitter][event-emitter].
|
|
|
|
```javascript
|
|
const { app, Menu, Tray } = require('electron')
|
|
|
|
let tray = null
|
|
app.on('ready', () => {
|
|
tray = new Tray('/path/to/my/icon')
|
|
const contextMenu = Menu.buildFromTemplate([
|
|
{ label: 'Item1', type: 'radio' },
|
|
{ label: 'Item2', type: 'radio' },
|
|
{ label: 'Item3', type: 'radio', checked: true },
|
|
{ label: 'Item4', type: 'radio' }
|
|
])
|
|
tray.setToolTip('This is my application.')
|
|
tray.setContextMenu(contextMenu)
|
|
})
|
|
```
|
|
|
|
__Platform limitations:__
|
|
|
|
* On Linux the app indicator will be used if it is supported, otherwise
|
|
`GtkStatusIcon` will be used instead.
|
|
* On Linux distributions that only have app indicator support, you have to
|
|
install `libappindicator1` to make the tray icon work.
|
|
* App indicator will only be shown when it has a context menu.
|
|
* When app indicator is used on Linux, the `click` event is ignored.
|
|
* On Linux in order for changes made to individual `MenuItem`s to take effect,
|
|
you have to call `setContextMenu` again. For example:
|
|
|
|
```javascript
|
|
const { app, Menu, Tray } = require('electron')
|
|
|
|
let appIcon = null
|
|
app.on('ready', () => {
|
|
appIcon = new Tray('/path/to/my/icon')
|
|
const contextMenu = Menu.buildFromTemplate([
|
|
{ label: 'Item1', type: 'radio' },
|
|
{ label: 'Item2', type: 'radio' }
|
|
])
|
|
|
|
// Make a change to the context menu
|
|
contextMenu.items[1].checked = false
|
|
|
|
// Call this again for Linux because we modified the context menu
|
|
appIcon.setContextMenu(contextMenu)
|
|
})
|
|
```
|
|
* On Windows it is recommended to use `ICO` icons to get best visual effects.
|
|
|
|
If you want to keep exact same behaviors on all platforms, you should not
|
|
rely on the `click` event and always attach a context menu to the tray icon.
|
|
|
|
|
|
### `new Tray(image)`
|
|
|
|
* `image` ([NativeImage](native-image.md) | String)
|
|
|
|
Creates a new tray icon associated with the `image`.
|
|
|
|
### Instance Events
|
|
|
|
The `Tray` module emits the following events:
|
|
|
|
#### Event: 'click'
|
|
|
|
Returns:
|
|
|
|
* `event` [KeyboardEvent](structures/keyboard-event.md)
|
|
* `bounds` [Rectangle](structures/rectangle.md) - The bounds of tray icon.
|
|
* `position` [Point](structures/point.md) - The position of the event.
|
|
|
|
Emitted when the tray icon is clicked.
|
|
|
|
#### Event: 'right-click' _macOS_ _Windows_
|
|
|
|
Returns:
|
|
|
|
* `event` [KeyboardEvent](structures/keyboard-event.md)
|
|
* `bounds` [Rectangle](structures/rectangle.md) - The bounds of tray icon.
|
|
|
|
Emitted when the tray icon is right clicked.
|
|
|
|
#### Event: 'double-click' _macOS_ _Windows_
|
|
|
|
Returns:
|
|
|
|
* `event` [KeyboardEvent](structures/keyboard-event.md)
|
|
* `bounds` [Rectangle](structures/rectangle.md) - The bounds of tray icon.
|
|
|
|
Emitted when the tray icon is double clicked.
|
|
|
|
#### Event: 'balloon-show' _Windows_
|
|
|
|
Emitted when the tray balloon shows.
|
|
|
|
#### Event: 'balloon-click' _Windows_
|
|
|
|
Emitted when the tray balloon is clicked.
|
|
|
|
#### Event: 'balloon-closed' _Windows_
|
|
|
|
Emitted when the tray balloon is closed because of timeout or user manually
|
|
closes it.
|
|
|
|
#### Event: 'drop' _macOS_
|
|
|
|
Emitted when any dragged items are dropped on the tray icon.
|
|
|
|
#### Event: 'drop-files' _macOS_
|
|
|
|
Returns:
|
|
|
|
* `event` Event
|
|
* `files` String[] - The paths of the dropped files.
|
|
|
|
Emitted when dragged files are dropped in the tray icon.
|
|
|
|
#### Event: 'drop-text' _macOS_
|
|
|
|
Returns:
|
|
|
|
* `event` Event
|
|
* `text` String - the dropped text string.
|
|
|
|
Emitted when dragged text is dropped in the tray icon.
|
|
|
|
#### Event: 'drag-enter' _macOS_
|
|
|
|
Emitted when a drag operation enters the tray icon.
|
|
|
|
#### Event: 'drag-leave' _macOS_
|
|
|
|
Emitted when a drag operation exits the tray icon.
|
|
|
|
#### Event: 'drag-end' _macOS_
|
|
|
|
Emitted when a drag operation ends on the tray or ends at another location.
|
|
|
|
#### Event: 'mouse-up' _macOS_
|
|
|
|
Returns:
|
|
|
|
* `event` [KeyboardEvent](structures/keyboard-event.md)
|
|
* `position` [Point](structures/point.md) - The position of the event.
|
|
|
|
Emitted when the mouse is released from clicking the tray icon.
|
|
|
|
Note: This will not be emitted if you have set a context menu for your Tray using `tray.setContextMenu`, as a result of macOS-level constraints.
|
|
|
|
#### Event: 'mouse-down' _macOS_
|
|
|
|
Returns:
|
|
|
|
* `event` [KeyboardEvent](structures/keyboard-event.md)
|
|
* `position` [Point](structures/point.md) - The position of the event.
|
|
|
|
Emitted when the mouse clicks the tray icon.
|
|
|
|
#### Event: 'mouse-enter' _macOS_
|
|
|
|
Returns:
|
|
|
|
* `event` [KeyboardEvent](structures/keyboard-event.md)
|
|
* `position` [Point](structures/point.md) - The position of the event.
|
|
|
|
Emitted when the mouse enters the tray icon.
|
|
|
|
#### Event: 'mouse-leave' _macOS_
|
|
|
|
Returns:
|
|
|
|
* `event` [KeyboardEvent](structures/keyboard-event.md)
|
|
* `position` [Point](structures/point.md) - The position of the event.
|
|
|
|
Emitted when the mouse exits the tray icon.
|
|
|
|
#### Event: 'mouse-move' _macOS_ _Windows_
|
|
|
|
Returns:
|
|
|
|
* `event` [KeyboardEvent](structures/keyboard-event.md)
|
|
* `position` [Point](structures/point.md) - The position of the event.
|
|
|
|
Emitted when the mouse moves in the tray icon.
|
|
|
|
### Instance Methods
|
|
|
|
The `Tray` class has the following methods:
|
|
|
|
#### `tray.destroy()`
|
|
|
|
Destroys the tray icon immediately.
|
|
|
|
#### `tray.setImage(image)`
|
|
|
|
* `image` ([NativeImage](native-image.md) | String)
|
|
|
|
Sets the `image` associated with this tray icon.
|
|
|
|
#### `tray.setPressedImage(image)` _macOS_
|
|
|
|
* `image` ([NativeImage](native-image.md) | String)
|
|
|
|
Sets the `image` associated with this tray icon when pressed on macOS.
|
|
|
|
#### `tray.setToolTip(toolTip)`
|
|
|
|
* `toolTip` String
|
|
|
|
Sets the hover text for this tray icon.
|
|
|
|
#### `tray.setTitle(title)` _macOS_
|
|
|
|
* `title` String
|
|
|
|
Sets the title displayed next to the tray icon in the status bar (Support ANSI colors).
|
|
|
|
#### `tray.getTitle()` _macOS_
|
|
|
|
Returns `String` - the title displayed next to the tray icon in the status bar
|
|
|
|
#### `tray.setIgnoreDoubleClickEvents(ignore)` _macOS_
|
|
|
|
* `ignore` Boolean
|
|
|
|
Sets the option to ignore double click events. Ignoring these events allows you
|
|
to detect every individual click of the tray icon.
|
|
|
|
This value is set to false by default.
|
|
|
|
#### `tray.getIgnoreDoubleClickEvents()` _macOS_
|
|
|
|
Returns `Boolean` - Whether double click events will be ignored.
|
|
|
|
#### `tray.displayBalloon(options)` _Windows_
|
|
|
|
* `options` Object
|
|
* `icon` ([NativeImage](native-image.md) | String) (optional) - Icon to use when `iconType` is `custom`.
|
|
* `iconType` String (optional) - Can be `none`, `info`, `warning`, `error` or `custom`. Default is `custom`.
|
|
* `title` String
|
|
* `content` String
|
|
* `largeIcon` Boolean (optional) - The large version of the icon should be used. Default is `true`. Maps to [`NIIF_LARGE_ICON`][NIIF_LARGE_ICON].
|
|
* `noSound` Boolean (optional) - Do not play the associated sound. Default is `false`. Maps to [`NIIF_NOSOUND`][NIIF_NOSOUND].
|
|
* `respectQuietTime` Boolean (optional) - Do not display the balloon notification if the current user is in "quiet time". Default is `false`. Maps to [`NIIF_RESPECT_QUIET_TIME`][NIIF_RESPECT_QUIET_TIME].
|
|
|
|
Displays a tray balloon.
|
|
|
|
[NIIF_NOSOUND]: https://docs.microsoft.com/en-us/windows/win32/api/shellapi/ns-shellapi-notifyicondataa#niif_nosound-0x00000010
|
|
[NIIF_LARGE_ICON]: https://docs.microsoft.com/en-us/windows/win32/api/shellapi/ns-shellapi-notifyicondataa#niif_large_icon-0x00000020
|
|
[NIIF_RESPECT_QUIET_TIME]: https://docs.microsoft.com/en-us/windows/win32/api/shellapi/ns-shellapi-notifyicondataa#niif_respect_quiet_time-0x00000080
|
|
|
|
#### `tray.removeBalloon()` _Windows_
|
|
|
|
Removes a tray balloon.
|
|
|
|
#### `tray.focus()` _Windows_
|
|
|
|
Returns focus to the taskbar notification area.
|
|
Notification area icons should use this message when they have completed their UI operation.
|
|
For example, if the icon displays a shortcut menu, but the user presses ESC to cancel it,
|
|
use `tray.focus()` to return focus to the notification area.
|
|
|
|
#### `tray.popUpContextMenu([menu, position])` _macOS_ _Windows_
|
|
|
|
* `menu` Menu (optional)
|
|
* `position` [Point](structures/point.md) (optional) - The pop up position.
|
|
|
|
Pops up the context menu of the tray icon. When `menu` is passed, the `menu` will
|
|
be shown instead of the tray icon's context menu.
|
|
|
|
The `position` is only available on Windows, and it is (0, 0) by default.
|
|
|
|
#### `tray.closeContextMenu()` _macOS_ _Windows_
|
|
|
|
Closes an open context menu, as set by `tray.setContextMenu()`.
|
|
|
|
#### `tray.setContextMenu(menu)`
|
|
|
|
* `menu` Menu | null
|
|
|
|
Sets the context menu for this icon.
|
|
|
|
#### `tray.getBounds()` _macOS_ _Windows_
|
|
|
|
Returns [`Rectangle`](structures/rectangle.md)
|
|
|
|
The `bounds` of this tray icon as `Object`.
|
|
|
|
#### `tray.isDestroyed()`
|
|
|
|
Returns `Boolean` - Whether the tray icon is destroyed.
|
|
|
|
[event-emitter]: https://nodejs.org/api/events.html#events_class_eventemitter
|