aboutsummaryrefslogtreecommitdiff
path: root/src/background/presenters/NotifyPresenter.js
diff options
context:
space:
mode:
authorShin'ya Ueoka <ueokande@i-beam.org>2019-02-25 22:01:37 +0900
committerGitHub <noreply@github.com>2019-02-25 22:01:37 +0900
commitcebd64a69f705482957a5e6a3f23054ca7985aa4 (patch)
tree9e8ffd8209972f839367302d3a4b68051f5c2823 /src/background/presenters/NotifyPresenter.js
parentdfeb7e75498384af5e24255ee0fe7f8af37ac489 (diff)
parent8614c7a516b475803b0ad30a0fe8e6d0c98e7b48 (diff)
Merge pull request #539 from ueokande/webext-on-install-event
Use browser.runtime.onInstalled event
Diffstat (limited to 'src/background/presenters/NotifyPresenter.js')
-rw-r--r--src/background/presenters/NotifyPresenter.js23
1 files changed, 23 insertions, 0 deletions
diff --git a/src/background/presenters/NotifyPresenter.js b/src/background/presenters/NotifyPresenter.js
new file mode 100644
index 0000000..a81f227
--- /dev/null
+++ b/src/background/presenters/NotifyPresenter.js
@@ -0,0 +1,23 @@
+const NOTIFICATION_ID = 'vimvixen-update';
+
+export default class NotifyPresenter {
+ notify(title, message, onclick) {
+ const listener = (id) => {
+ if (id !== NOTIFICATION_ID) {
+ return;
+ }
+
+ onclick();
+
+ browser.notifications.onClicked.removeListener(listener);
+ };
+ browser.notifications.onClicked.addListener(listener);
+
+ return browser.notifications.create(NOTIFICATION_ID, {
+ 'type': 'basic',
+ 'iconUrl': browser.extension.getURL('resources/icon_48x48.png'),
+ title,
+ message,
+ });
+ }
+}