From f6fcf6aa451d2df9b703d52e75c6c70ca0a03e65 Mon Sep 17 00:00:00 2001 From: Aleksandar Petkov Date: Sat, 6 Jan 2024 09:31:38 +0200 Subject: [PATCH] client/notifications: Fix crash when selecting profile's email (#1700) Removed some unused imports as well --- .../TeamMembersSection/TeamMembersSection.tsx | 5 ++--- .../notifications/CampaignSubscribeModal.tsx | 8 +++----- .../client/notifications/GeneralSubscribeModal.tsx | 5 +++-- .../client/notifications/SubscriptionPage.tsx | 14 +++++++++----- 4 files changed, 17 insertions(+), 15 deletions(-) diff --git a/src/components/client/index/sections/TeamMembersSection/TeamMembersSection.tsx b/src/components/client/index/sections/TeamMembersSection/TeamMembersSection.tsx index 5ca93f554..420bebbc6 100644 --- a/src/components/client/index/sections/TeamMembersSection/TeamMembersSection.tsx +++ b/src/components/client/index/sections/TeamMembersSection/TeamMembersSection.tsx @@ -1,13 +1,12 @@ -import React, { useState } from 'react' +import React from 'react' import Image from 'next/image' import { useTranslation } from 'next-i18next' import ChevronRightIcon from '@mui/icons-material/ChevronRight' -import { Box, Grid } from '@mui/material' +import { Box } from '@mui/material' import { routes } from 'common/routes' import { Heading, InfoText, OutlinedButton } from '../../IndexPage.styled' import { Root } from './TeamMembersSection.styled' -import { SectionGridWrapper } from '../PlatformStatisticsSection/PlatformStatisticsSection.styled' export default function TeamMembersSection() { const { t } = useTranslation('index') diff --git a/src/components/client/notifications/CampaignSubscribeModal.tsx b/src/components/client/notifications/CampaignSubscribeModal.tsx index 88a626a6e..35ea56b4a 100644 --- a/src/components/client/notifications/CampaignSubscribeModal.tsx +++ b/src/components/client/notifications/CampaignSubscribeModal.tsx @@ -55,7 +55,7 @@ const validationSchema: yup.SchemaOf = yup export default function RenderCampaignSubscribeModal({ campaign, setOpen }: ModalProps) { const { t } = useTranslation() - const { status } = useSession() + const { status, data } = useSession() const [loading, setLoading] = useState(false) const [isSuccess, setIsSuccess] = useState(false) const [isGuest, setIsGuest] = useState(false) @@ -75,13 +75,10 @@ export default function RenderCampaignSubscribeModal({ campaign, setOpen }: Moda >({ mutationFn: useSubscribeToCampaign(campaign.id), onError: (error) => { - console.log(error.message) - handleError(error) }, onSuccess: () => { AlertStore.show(t('common:alerts.message-sent'), 'success') - setIsSuccess(true) }, }) @@ -137,10 +134,11 @@ export default function RenderCampaignSubscribeModal({ campaign, setOpen }: Moda } const sendOnProfileEmail = (status: string) => { + const userData = data?.user if (status !== 'authenticated') { router.push(routes.login) } else { - onSubmit({ email: email || '', consent: consent || true }) + onSubmit({ email: userData?.email || '', consent: consent || true }) handleClose() } } diff --git a/src/components/client/notifications/GeneralSubscribeModal.tsx b/src/components/client/notifications/GeneralSubscribeModal.tsx index 40f0a7a91..9f5409f60 100644 --- a/src/components/client/notifications/GeneralSubscribeModal.tsx +++ b/src/components/client/notifications/GeneralSubscribeModal.tsx @@ -62,7 +62,7 @@ const validationSchema: yup.SchemaOf = yup export default function RenderSubscribeModal({ setOpen }: ModalProps) { const { t } = useTranslation() - const { status } = useSession() + const { status, data } = useSession() const [loading, setLoading] = useState(false) const [isSuccess, setIsSuccess] = useState(false) @@ -139,10 +139,11 @@ export default function RenderSubscribeModal({ setOpen }: ModalProps) { } const sendOnProfileEmail = (status: string) => { + const userData = data?.user if (status !== 'authenticated') { router.push(routes.login) } else { - onSubmit({ email: email || '' }) + onSubmit({ email: userData?.email || '' }) handleClose() } } diff --git a/src/components/client/notifications/SubscriptionPage.tsx b/src/components/client/notifications/SubscriptionPage.tsx index aa73c8dce..bad56f453 100644 --- a/src/components/client/notifications/SubscriptionPage.tsx +++ b/src/components/client/notifications/SubscriptionPage.tsx @@ -97,10 +97,18 @@ export default function SubscriptionPage(data: Props) { }, []) const handleError = (e: AxiosError) => { + const error = e.response?.data?.message + AlertStore.show(error ? error : t('common:alerts.error'), 'error') setLoading(false) setIsSuccess(false) } + const handleSuccess = () => { + AlertStore.show(t('common:alerts.message-sent'), 'success') + setIsSuccess(true) + setLoading(false) + } + const mutation = useMutation< AxiosResponse, AxiosError, @@ -108,11 +116,7 @@ export default function SubscriptionPage(data: Props) { >({ mutationFn: useSubscribePublicEmail(), onError: (error) => handleError(error), - onSuccess: () => { - AlertStore.show(t('common:alerts.message-sent'), 'success') - setIsSuccess(true) - setLoading(false) - }, + onSuccess: () => handleSuccess, }) async function callSubscribeApiRoute(values: {