2018-10-28 23:28:22 +01:00
|
|
|
<div class="push-notifications">
|
|
|
|
{#if pushNotificationsSupport === false}
|
|
|
|
<p>Your browser doesn't support push notifications.</p>
|
|
|
|
{:elseif $notificationPermission === "denied"}
|
|
|
|
<p role="alert">You have denied permission to show notifications.</p>
|
|
|
|
{/if}
|
|
|
|
<form id="push-notification-settings" disabled="{!pushNotificationsSupport}" ref:pushNotificationsForm aria-label="Push notification settings">
|
|
|
|
<input type="checkbox" id="push-notifications-follow" name="follow" disabled="{!pushNotificationsSupport}" on:change="onPushSettingsChange(event)">
|
|
|
|
<label for="push-notifications-follow">New followers</label>
|
|
|
|
<br>
|
|
|
|
<input type="checkbox" id="push-notifications-favourite" name="favourite" disabled="{!pushNotificationsSupport}" on:change="onPushSettingsChange(event)">
|
2019-05-25 22:21:17 +02:00
|
|
|
<label for="push-notifications-favourite">Favorites</label>
|
2018-10-28 23:28:22 +01:00
|
|
|
<br>
|
|
|
|
<input type="checkbox" id="push-notifications-reblog" name="reblog" disabled="{!pushNotificationsSupport}" on:change="onPushSettingsChange(event)">
|
|
|
|
<label for="push-notifications-reblog">Boosts</label>
|
|
|
|
<br>
|
|
|
|
<input type="checkbox" id="push-notifications-mention" name="mention" disabled="{!pushNotificationsSupport}" on:change="onPushSettingsChange(event)">
|
|
|
|
<label for="push-notifications-mention">Mentions</label>
|
|
|
|
</form>
|
|
|
|
</div>
|
|
|
|
<style>
|
|
|
|
.push-notifications {
|
|
|
|
background: var(--form-bg);
|
|
|
|
border: 1px solid var(--main-border);
|
|
|
|
border-radius: 4px;
|
|
|
|
display: block;
|
|
|
|
padding: 20px;
|
|
|
|
line-height: 2em;
|
|
|
|
}
|
|
|
|
.push-notifications form[disabled="true"] {
|
|
|
|
opacity: 0.5;
|
|
|
|
}
|
|
|
|
.push-notifications p {
|
|
|
|
margin: 0;
|
|
|
|
}
|
|
|
|
</style>
|
|
|
|
<script>
|
|
|
|
import { store } from '../../../_store/store'
|
2019-02-19 00:43:41 +01:00
|
|
|
import { importShowTextConfirmationDialog } from '../../dialog/asyncDialogs'
|
2018-10-28 23:28:22 +01:00
|
|
|
import { logOutOfInstance } from '../../../_actions/instances'
|
|
|
|
import { updatePushSubscriptionForInstance, updateAlerts } from '../../../_actions/pushSubscription'
|
2018-12-23 00:37:51 +01:00
|
|
|
import { toast } from '../../toast/toast'
|
2019-05-25 22:21:17 +02:00
|
|
|
import { get } from '../../../_utils/lodash-lite'
|
2018-10-28 23:28:22 +01:00
|
|
|
|
|
|
|
export default {
|
|
|
|
async oncreate () {
|
|
|
|
let { instanceName } = this.get()
|
|
|
|
await updatePushSubscriptionForInstance(instanceName)
|
|
|
|
|
|
|
|
const form = this.refs.pushNotificationsForm
|
|
|
|
const { pushSubscription } = this.store.get()
|
|
|
|
|
2019-05-25 22:21:17 +02:00
|
|
|
form.elements.follow.checked = get(pushSubscription, ['alerts', 'follow'])
|
|
|
|
form.elements.favourite.checked = get(pushSubscription, ['alerts', 'favourite'])
|
|
|
|
form.elements.reblog.checked = get(pushSubscription, ['alerts', 'reblog'])
|
|
|
|
form.elements.mention.checked = get(pushSubscription, ['alerts', 'mention'])
|
2018-10-28 23:28:22 +01:00
|
|
|
},
|
|
|
|
store: () => store,
|
|
|
|
computed: {
|
|
|
|
pushNotificationsSupport: ({ $pushNotificationsSupport }) => $pushNotificationsSupport
|
|
|
|
},
|
|
|
|
methods: {
|
|
|
|
async onPushSettingsChange (e) {
|
|
|
|
const { instanceName } = this.get()
|
|
|
|
const form = this.refs.pushNotificationsForm
|
|
|
|
const alerts = {
|
|
|
|
follow: form.elements.follow.checked,
|
|
|
|
favourite: form.elements.favourite.checked,
|
|
|
|
reblog: form.elements.reblog.checked,
|
|
|
|
mention: form.elements.mention.checked
|
|
|
|
}
|
|
|
|
|
|
|
|
try {
|
|
|
|
await updateAlerts(instanceName, alerts)
|
|
|
|
} catch (err) {
|
|
|
|
e.target.checked = !e.target.checked
|
|
|
|
|
|
|
|
// TODO: Better way to detect missing authorization scope
|
|
|
|
if (err.message.startsWith('403:')) {
|
2019-02-19 00:43:41 +01:00
|
|
|
let showTextConfirmationDialog = await importShowTextConfirmationDialog()
|
|
|
|
showTextConfirmationDialog({
|
|
|
|
text: `You need to reauthenticate in order to enable push notification. Log out of ${instanceName}?`
|
|
|
|
}).on('positive', () => {
|
|
|
|
/* no await */ logOutOfInstance(instanceName)
|
2018-10-28 23:28:22 +01:00
|
|
|
})
|
|
|
|
} else {
|
|
|
|
toast.say(`Failed to update push notification settings: ${err.message}`)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2018-12-23 00:37:51 +01:00
|
|
|
</script>
|