Merge branch 'notifications' into 'master'
Notification issues See merge request framasoft/mobilizon!961
This commit is contained in:
commit
4a7f77b685
@ -158,7 +158,7 @@ export const PRIVACY = gql`
|
|||||||
`;
|
`;
|
||||||
|
|
||||||
export const TIMEZONES = gql`
|
export const TIMEZONES = gql`
|
||||||
query {
|
query Timezones {
|
||||||
config {
|
config {
|
||||||
timezones
|
timezones
|
||||||
}
|
}
|
||||||
@ -166,7 +166,7 @@ export const TIMEZONES = gql`
|
|||||||
`;
|
`;
|
||||||
|
|
||||||
export const WEB_PUSH = gql`
|
export const WEB_PUSH = gql`
|
||||||
query {
|
query WebPush {
|
||||||
config {
|
config {
|
||||||
webPush {
|
webPush {
|
||||||
enabled
|
enabled
|
||||||
|
@ -1055,5 +1055,10 @@
|
|||||||
"Send notification e-mails": "Send notification e-mails",
|
"Send notification e-mails": "Send notification e-mails",
|
||||||
"Announcements and mentions notifications are always sent straight away.": "Announcements and mentions notifications are always sent straight away.",
|
"Announcements and mentions notifications are always sent straight away.": "Announcements and mentions notifications are always sent straight away.",
|
||||||
"Weekly email summary": "Weekly email summary",
|
"Weekly email summary": "Weekly email summary",
|
||||||
"Receive one email for each activity": "Receive one email for each activity"
|
"Receive one email for each activity": "Receive one email for each activity",
|
||||||
|
"Error while updating participation status inside this browser": "Error while updating participation status inside this browser",
|
||||||
|
"We couldn't save your participation inside this browser. Not to worry, you have successfully confirmed your participation, we just couldn't save it's status in this browser because of a technical issue.": "We couldn't save your participation inside this browser. Not to worry, you have successfully confirmed your participation, we just couldn't save it's status in this browser because of a technical issue.",
|
||||||
|
"This instance hasn't got push notifications enabled.": "This instance hasn't got push notifications enabled.",
|
||||||
|
"enable the feature": "enable the feature",
|
||||||
|
"Ask your instance admin to {enable_feature}.": "Ask your instance admin to {enable_feature}."
|
||||||
}
|
}
|
||||||
|
@ -1146,5 +1146,10 @@
|
|||||||
"Send notification e-mails": "Envoyer des e-mails de notification",
|
"Send notification e-mails": "Envoyer des e-mails de notification",
|
||||||
"Announcements and mentions notifications are always sent straight away.": "Les notifications d'annonces et de mentions sont toujours envoyées directement.",
|
"Announcements and mentions notifications are always sent straight away.": "Les notifications d'annonces et de mentions sont toujours envoyées directement.",
|
||||||
"Weekly email summary": "Résumé hebdomadaire par e-mail",
|
"Weekly email summary": "Résumé hebdomadaire par e-mail",
|
||||||
"Receive one email for each activity": "Recevoir un e-mail à chaque activité"
|
"Receive one email for each activity": "Recevoir un e-mail à chaque activité",
|
||||||
|
"Error while updating participation status inside this browser": "Erreur lors de la mise à jour du statut de votre participation dans ce navigateur",
|
||||||
|
"We couldn't save your participation inside this browser. Not to worry, you have successfully confirmed your participation, we just couldn't save it's status in this browser because of a technical issue.": "Nous n'avons pas pu sauvegarder votre participation dans ce navigateur. Aucune inquiétude, vous avez bien confirmé votre participation, nous n'avons juste pas pu enregistrer son statut dans ce navigateur à cause d'un souci technique.",
|
||||||
|
"This instance hasn't got push notifications enabled.": "Cette instance n'a pas activé la fonctionnalité de notification push.",
|
||||||
|
"enable the feature": "activer la fonctionnalité",
|
||||||
|
"Ask your instance admin to {enable_feature}.": "Demandez à l'administrateur⋅ice de votre instance d'{enable_feature}."
|
||||||
}
|
}
|
||||||
|
@ -22,8 +22,8 @@ export async function subscribeUserToPush(): Promise<PushSubscription | null> {
|
|||||||
apolloProvider.defaultClient as ApolloClient<NormalizedCacheObject>;
|
apolloProvider.defaultClient as ApolloClient<NormalizedCacheObject>;
|
||||||
|
|
||||||
const registration = await navigator.serviceWorker.ready;
|
const registration = await navigator.serviceWorker.ready;
|
||||||
const { data } = await client.mutate<{ config: IConfig }>({
|
const { data } = await client.query<{ config: IConfig }>({
|
||||||
mutation: WEB_PUSH,
|
query: WEB_PUSH,
|
||||||
});
|
});
|
||||||
|
|
||||||
if (data?.config?.webPush?.enabled && data?.config?.webPush?.publicKey) {
|
if (data?.config?.webPush?.enabled && data?.config?.webPush?.publicKey) {
|
||||||
|
@ -24,12 +24,24 @@
|
|||||||
<b-button
|
<b-button
|
||||||
icon-left="rss"
|
icon-left="rss"
|
||||||
@click="subscribeToWebPush"
|
@click="subscribeToWebPush"
|
||||||
v-else-if="canShowWebPush"
|
v-else-if="canShowWebPush && webPushEnabled"
|
||||||
>{{ $t("Activate browser push notifications") }}</b-button
|
>{{ $t("Activate browser push notifications") }}</b-button
|
||||||
>
|
>
|
||||||
<span v-else>{{
|
<b-message type="is-warning" v-else-if="!webPushEnabled">
|
||||||
|
{{ $t("This instance hasn't got push notifications enabled.") }}
|
||||||
|
<i18n path="Ask your instance admin to {enable_feature}.">
|
||||||
|
<a
|
||||||
|
slot="enable_feature"
|
||||||
|
href="https://docs.joinmobilizon.org/administration/configure/push/"
|
||||||
|
target="_blank"
|
||||||
|
rel="noopener noreferer"
|
||||||
|
>{{ $t("enable the feature") }}</a
|
||||||
|
>
|
||||||
|
</i18n>
|
||||||
|
</b-message>
|
||||||
|
<b-message type="is-danger" v-else>{{
|
||||||
$t("You can't use push notifications in this browser.")
|
$t("You can't use push notifications in this browser.")
|
||||||
}}</span>
|
}}</b-message>
|
||||||
</section>
|
</section>
|
||||||
<section>
|
<section>
|
||||||
<div class="setting-title">
|
<div class="setting-title">
|
||||||
@ -292,6 +304,7 @@ import {
|
|||||||
UNREGISTER_PUSH_MUTATION,
|
UNREGISTER_PUSH_MUTATION,
|
||||||
} from "@/graphql/webPush";
|
} from "@/graphql/webPush";
|
||||||
import { merge } from "lodash";
|
import { merge } from "lodash";
|
||||||
|
import { WEB_PUSH } from "@/graphql/config";
|
||||||
|
|
||||||
type NotificationSubType = { label: string; id: string };
|
type NotificationSubType = { label: string; id: string };
|
||||||
type NotificationType = { label: string; subtypes: NotificationSubType[] };
|
type NotificationType = { label: string; subtypes: NotificationSubType[] };
|
||||||
@ -306,6 +319,10 @@ type NotificationType = { label: string; subtypes: NotificationSubType[] };
|
|||||||
(token: IFeedToken) => token.actor === null
|
(token: IFeedToken) => token.actor === null
|
||||||
),
|
),
|
||||||
},
|
},
|
||||||
|
webPushEnabled: {
|
||||||
|
query: WEB_PUSH,
|
||||||
|
update: (data) => data.config.webPush.enabled,
|
||||||
|
},
|
||||||
},
|
},
|
||||||
metaInfo() {
|
metaInfo() {
|
||||||
return {
|
return {
|
||||||
@ -341,6 +358,8 @@ export default class Notifications extends Vue {
|
|||||||
|
|
||||||
canShowWebPush = false;
|
canShowWebPush = false;
|
||||||
|
|
||||||
|
webPushEnabled = false;
|
||||||
|
|
||||||
notificationMethods = {
|
notificationMethods = {
|
||||||
email: this.$t("Email") as string,
|
email: this.$t("Email") as string,
|
||||||
push: this.$t("Push") as string,
|
push: this.$t("Push") as string,
|
||||||
@ -626,8 +645,7 @@ export default class Notifications extends Vue {
|
|||||||
const subscription = await subscribeUserToPush();
|
const subscription = await subscribeUserToPush();
|
||||||
if (subscription) {
|
if (subscription) {
|
||||||
const subscriptionJSON = subscription?.toJSON();
|
const subscriptionJSON = subscription?.toJSON();
|
||||||
console.log("subscription", subscriptionJSON);
|
await this.$apollo.mutate({
|
||||||
const { data } = await this.$apollo.mutate({
|
|
||||||
mutation: REGISTER_PUSH_MUTATION,
|
mutation: REGISTER_PUSH_MUTATION,
|
||||||
variables: {
|
variables: {
|
||||||
endpoint: subscriptionJSON.endpoint,
|
endpoint: subscriptionJSON.endpoint,
|
||||||
@ -636,14 +654,13 @@ export default class Notifications extends Vue {
|
|||||||
},
|
},
|
||||||
});
|
});
|
||||||
this.subscribed = true;
|
this.subscribed = true;
|
||||||
console.log(data);
|
|
||||||
} else {
|
} else {
|
||||||
this.$notifier.error(
|
this.$notifier.error(
|
||||||
this.$t("Error while subscribing to push notifications") as string
|
this.$t("Error while subscribing to push notifications") as string
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
console.log("can't do webpush");
|
console.error("can't do webpush");
|
||||||
}
|
}
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
console.error(e);
|
console.error(e);
|
||||||
@ -672,7 +689,6 @@ export default class Notifications extends Vue {
|
|||||||
if (!window.isSecureContext && !("serviceWorker" in navigator))
|
if (!window.isSecureContext && !("serviceWorker" in navigator))
|
||||||
return Promise.resolve(false);
|
return Promise.resolve(false);
|
||||||
const registration = await navigator.serviceWorker.getRegistration();
|
const registration = await navigator.serviceWorker.getRegistration();
|
||||||
console.log("registration", registration);
|
|
||||||
return registration !== undefined;
|
return registration !== undefined;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user