diff options
| author | shpuld <shp@cock.li> | 2018-12-28 21:44:09 +0200 |
|---|---|---|
| committer | shpuld <shp@cock.li> | 2018-12-28 21:44:09 +0200 |
| commit | 650655709dd617a558709ffbf8911f05f7c17267 (patch) | |
| tree | 5d87472d287b93bc845e442c91006070ef88f85d /src/lib/push_notifications_plugin.js | |
| parent | 85c058e95c04245dacf3ffb6b45a6eceb3253e7b (diff) | |
| parent | a86b80b0544ca93a1b59ff521fd9b1e8bbc3f8c9 (diff) | |
fix conflict in user card content
Diffstat (limited to 'src/lib/push_notifications_plugin.js')
| -rw-r--r-- | src/lib/push_notifications_plugin.js | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/src/lib/push_notifications_plugin.js b/src/lib/push_notifications_plugin.js new file mode 100644 index 00000000..f75bb823 --- /dev/null +++ b/src/lib/push_notifications_plugin.js @@ -0,0 +1,22 @@ +export default (store) => { + store.subscribe((mutation, state) => { + const vapidPublicKey = state.instance.vapidPublicKey + const webPushNotification = state.config.webPushNotifications + const permission = state.interface.notificationPermission === 'granted' + const user = state.users.currentUser + + const isUserMutation = mutation.type === 'setCurrentUser' + const isVapidMutation = mutation.type === 'setInstanceOption' && mutation.payload.name === 'vapidPublicKey' + const isPermMutation = mutation.type === 'setNotificationPermission' && mutation.payload === 'granted' + const isUserConfigMutation = mutation.type === 'setOption' && mutation.payload.name === 'webPushNotifications' + const isVisibilityMutation = mutation.type === 'setOption' && mutation.payload.name === 'notificationVisibility' + + if (isUserMutation || isVapidMutation || isPermMutation || isUserConfigMutation || isVisibilityMutation) { + if (user && vapidPublicKey && permission && webPushNotification) { + return store.dispatch('registerPushNotifications') + } else if (isUserConfigMutation && !webPushNotification) { + return store.dispatch('unregisterPushNotifications') + } + } + }) +} |
