2017-05-20 11:25:26 +00:00
# Notification
> Create OS desktop notifications
Process: [Main ](../glossary.md#main-process )
## Using in the renderer process
2017-05-30 09:06:51 +00:00
If you want to show Notifications from a renderer process you should use the [HTML5 Notification API ](../tutorial/notifications.md )
2017-05-20 11:25:26 +00:00
## Class: Notification
> Create OS desktop notifications
Process: [Main ](../glossary.md#main-process )
2019-07-22 15:20:43 +00:00
`Notification` is an [EventEmitter][event-emitter].
2017-05-20 11:25:26 +00:00
It creates a new `Notification` with native properties as set by the `options` .
2017-05-30 10:27:24 +00:00
### Static Methods
The `Notification` class has the following static methods:
2017-06-23 10:50:50 +00:00
#### `Notification.isSupported()`
2017-05-30 10:27:24 +00:00
2021-11-16 04:13:18 +00:00
Returns `boolean` - Whether or not desktop notifications are supported on the current system
2017-05-20 11:25:26 +00:00
2020-04-02 16:32:18 +00:00
### `new Notification([options])`
2017-05-20 11:25:26 +00:00
2019-06-04 21:03:24 +00:00
* `options` Object (optional)
2021-11-16 04:13:18 +00:00
* `title` string (optional) - A title for the notification, which will be shown at the top of the notification window when it is shown.
* `subtitle` string (optional) _macOS_ - A subtitle for the notification, which will be displayed below the title.
* `body` string (optional) - The body text of the notification, which will be displayed below the title or subtitle.
* `silent` boolean (optional) - Whether or not to emit an OS notification noise when showing the notification.
* `icon` (string | [NativeImage ](native-image.md )) (optional) - An icon to use in the notification.
* `hasReply` boolean (optional) _macOS_ - Whether or not to add an inline reply option to the notification.
* `timeoutType` string (optional) _Linux_ _Windows_ - The timeout duration of the notification. Can be 'default' or 'never'.
* `replyPlaceholder` string (optional) _macOS_ - The placeholder to write in the inline reply input field.
* `sound` string (optional) _macOS_ - The name of the sound file to play when the notification is shown.
* `urgency` string (optional) _Linux_ - The urgency level of the notification. Can be 'normal', 'critical', or 'low'.
2017-11-29 10:58:24 +00:00
* `actions` [NotificationAction[]](structures/notification-action.md) (optional) _macOS_ - Actions to add to the notification. Please read the available actions and limitations in the `NotificationAction` documentation.
2021-11-16 04:13:18 +00:00
* `closeButtonText` string (optional) _macOS_ - A custom title for the close button of an alert. An empty string will cause the default localized text to be used.
* `toastXml` string (optional) _Windows_ - A custom description of the Notification on Windows superseding all properties above. Provides full customization of design and behavior of the notification.
2017-05-20 11:25:26 +00:00
### Instance Events
Objects created with `new Notification` emit the following events:
**Note:** Some events are only available on specific operating systems and are
labeled as such.
2017-05-29 11:33:43 +00:00
#### Event: 'show'
2017-05-20 11:25:26 +00:00
Returns:
* `event` Event
2017-05-29 11:33:43 +00:00
Emitted when the notification is shown to the user, note this could be fired
multiple times as a notification can be shown multiple times through the
`show()` method.
2017-05-20 11:25:26 +00:00
2017-05-29 11:33:43 +00:00
#### Event: 'click'
2017-05-20 11:25:26 +00:00
Returns:
* `event` Event
2017-05-29 11:33:43 +00:00
Emitted when the notification is clicked by the user.
2017-05-20 11:25:26 +00:00
2017-05-29 11:33:43 +00:00
#### Event: 'close'
2017-05-20 11:25:26 +00:00
Returns:
* `event` Event
2017-05-29 11:33:43 +00:00
Emitted when the notification is closed by manual intervention from the user.
2017-10-24 05:37:03 +00:00
This event is not guaranteed to be emitted in all cases where the notification
2017-05-29 11:33:43 +00:00
is closed.
2017-05-20 11:25:26 +00:00
#### Event: 'reply' _macOS_
Returns:
* `event` Event
2021-11-16 04:13:18 +00:00
* `reply` string - The string the user entered into the inline reply field.
2017-05-20 11:25:26 +00:00
Emitted when the user clicks the "Reply" button on a notification with `hasReply: true` .
2017-06-23 10:39:42 +00:00
#### Event: 'action' _macOS_
Returns:
* `event` Event
2021-11-16 04:13:18 +00:00
* `index` number - The index of the action that was activated.
2017-06-23 10:39:42 +00:00
2020-09-29 19:20:10 +00:00
#### Event: 'failed' _Windows_
Returns:
* `event` Event
2021-11-16 04:13:18 +00:00
* `error` string - The error encountered during execution of the `show()` method.
2020-09-29 19:20:10 +00:00
Emitted when an error is encountered while creating and showing the native notification.
2017-05-20 11:25:26 +00:00
### Instance Methods
Objects created with `new Notification` have the following instance methods:
#### `notification.show()`
Immediately shows the notification to the user, please note this means unlike the
2018-05-08 05:16:09 +00:00
HTML5 Notification implementation, instantiating a `new Notification` does
2017-05-20 11:25:26 +00:00
not immediately show it to the user, you need to call this method before the OS
will display it.
2017-08-21 20:53:50 +00:00
2017-10-27 19:17:30 +00:00
If the notification has been shown before, this method will dismiss the previously
shown notification and create a new one with identical properties.
2017-10-27 03:22:21 +00:00
#### `notification.close()`
2017-10-27 19:17:30 +00:00
Dismisses the notification.
2017-10-27 03:22:21 +00:00
2019-07-25 00:18:11 +00:00
### Instance Properties
#### `notification.title`
2021-11-16 04:13:18 +00:00
A `string` property representing the title of the notification.
2019-07-25 00:18:11 +00:00
#### `notification.subtitle`
2021-11-16 04:13:18 +00:00
A `string` property representing the subtitle of the notification.
2019-07-25 00:18:11 +00:00
#### `notification.body`
2021-11-16 04:13:18 +00:00
A `string` property representing the body of the notification.
2019-07-25 00:18:11 +00:00
#### `notification.replyPlaceholder`
2021-11-16 04:13:18 +00:00
A `string` property representing the reply placeholder of the notification.
2019-07-25 00:18:11 +00:00
#### `notification.sound`
2021-11-16 04:13:18 +00:00
A `string` property representing the sound of the notification.
2019-07-25 00:18:11 +00:00
#### `notification.closeButtonText`
2021-11-16 04:13:18 +00:00
A `string` property representing the close button text of the notification.
2019-07-25 00:18:11 +00:00
#### `notification.silent`
2021-11-16 04:13:18 +00:00
A `boolean` property representing whether the notification is silent.
2019-07-25 00:18:11 +00:00
#### `notification.hasReply`
2021-11-16 04:13:18 +00:00
A `boolean` property representing whether the notification has a reply action.
2019-07-25 00:18:11 +00:00
2019-09-19 05:35:20 +00:00
#### `notification.urgency` _Linux_
2021-11-16 04:13:18 +00:00
A `string` property representing the urgency level of the notification. Can be 'normal', 'critical', or 'low'.
2019-09-19 05:35:20 +00:00
2023-03-20 14:25:54 +00:00
Default is 'low' - see [NotifyUrgency ](https://developer-old.gnome.org/notification-spec/#urgency-levels ) for more information.
2019-09-19 05:35:20 +00:00
2019-10-09 15:22:21 +00:00
#### `notification.timeoutType` _Linux_ _Windows_
2021-11-16 04:13:18 +00:00
A `string` property representing the type of timeout duration for the notification. Can be 'default' or 'never'.
2019-10-09 15:22:21 +00:00
If `timeoutType` is set to 'never', the notification never expires. It stays open until closed by the calling API or the user.
2019-07-25 00:18:11 +00:00
#### `notification.actions`
A [`NotificationAction[]`](structures/notification-action.md) property representing the actions of the notification.
2020-09-29 19:20:10 +00:00
#### `notification.toastXml` _Windows_
2021-11-16 04:13:18 +00:00
A `string` property representing the custom Toast XML of the notification.
2020-09-29 19:20:10 +00:00
2017-08-21 20:56:10 +00:00
### Playing Sounds
2017-08-21 20:53:50 +00:00
On macOS, you can specify the name of the sound you'd like to play when the
notification is shown. Any of the default sounds (under System Preferences >
Sound) can be used, in addition to custom sound files. Be sure that the sound
2017-08-21 20:56:10 +00:00
file is copied under the app bundle (e.g., `YourApp.app/Contents/Resources` ),
or one of the following locations:
2017-08-21 20:53:50 +00:00
* `~/Library/Sounds`
* `/Library/Sounds`
* `/Network/Library/Sounds`
* `/System/Library/Sounds`
See the [`NSSound` ](https://developer.apple.com/documentation/appkit/nssound ) docs for more information.
2019-07-22 15:20:43 +00:00
[event-emitter]: https://nodejs.org/api/events.html#events_class_eventemitter