From bbf2b917ea500145e70519a4754d8b65df014483 Mon Sep 17 00:00:00 2001 From: Jon Grim Date: Thu, 29 Feb 2024 11:29:57 +0100 Subject: [PATCH] fix loading notifications on app init (#264) --- src/App.vue | 17 ++++++++--------- 1 file changed, 8 insertions(+), 9 deletions(-) diff --git a/src/App.vue b/src/App.vue index 8159e5c..50f8c04 100644 --- a/src/App.vue +++ b/src/App.vue @@ -58,6 +58,9 @@ async function setupUserProfile(id: string) { store.userSettings = profile?.user_settings; loadInProgress.value = false; store.authState = "signedin"; + if (!notificationSubscription.value) { + loadNotificationsAndSubscribe(profile.id); + } } function handleUserInit(session: Session) { @@ -66,9 +69,6 @@ function handleUserInit(session: Session) { setupUserProfile(session.user.id); triggerUserAccessLoad(session.user.id); getFlags(session.user.id); - if (!notificationSubscription.value) { - loadNotificationsAndSubscribe(); - } if (route.query.redirect && typeof route.query.redirect === "string") { log({ @@ -129,13 +129,12 @@ onUnmounted(() => { supabaseSubscription.value?.unsubscribe(); }); -async function loadNotificationsAndSubscribe() { - if (!store.user?.id) return; +async function loadNotificationsAndSubscribe(id: string) { const { data, error } = await supabase .from("notifications") .select("*") .eq("read", false) - .eq("user_id", store.user.id); + .eq("user_id", id); if (error) { log({ error }); } @@ -143,14 +142,14 @@ async function loadNotificationsAndSubscribe() { store.notifications = data; } const subscription = supabase - .channel(`public:notifications:user_id=eq.${store.user.id}`) + .channel(`public:notifications:user_id=eq.${id}`) .on( "postgres_changes", { event: "INSERT", schema: "public", table: "notifications", - filter: `user_id=eq.${store.user.id}`, + filter: `user_id=eq.${id}`, }, (payload) => { store.notifications = store.notifications.concat( @@ -164,7 +163,7 @@ async function loadNotificationsAndSubscribe() { event: "UPDATE", schema: "public", table: "notifications", - filter: `user_id=eq.${store.user.id}`, + filter: `user_id=eq.${id}`, }, (payload) => { store.notifications = store.notifications.map((notification) => {