From bb871963aef2b2d1c22a3ae705c6f253ac48d5fe Mon Sep 17 00:00:00 2001 From: Chinchuluun1029 Date: Wed, 29 Sep 2021 15:21:47 -0500 Subject: [PATCH 1/5] Handling success and error on Manage Sponsors *gracefully* (N-60) --- src/client/routes/manage/CreateSponsor.tsx | 160 +++++++++++---------- 1 file changed, 82 insertions(+), 78 deletions(-) diff --git a/src/client/routes/manage/CreateSponsor.tsx b/src/client/routes/manage/CreateSponsor.tsx index c91e876b0..f10d85be8 100644 --- a/src/client/routes/manage/CreateSponsor.tsx +++ b/src/client/routes/manage/CreateSponsor.tsx @@ -1,10 +1,10 @@ -import React, { useState } from 'react'; +import React, { useRef, useState } from 'react'; import styled from 'styled-components'; import * as EmailValidator from 'email-validator'; +import { toast } from 'react-toastify'; import { Button } from '../../components/Buttons/Button'; import { SearchBox } from '../../components/Input/SearchBox'; import FloatingPopup from '../../components/Containers/FloatingPopup'; -import { SmallCenteredText } from '../../components/Text/SmallCenteredText'; import { FlexRow } from '../../components/Containers/FlexContainers'; import { useCreateSponsorMutation, @@ -16,7 +16,6 @@ import { TiersDocument, } from '../../generated/graphql'; import { Spinner } from '../../components/Loading/Spinner'; -import STRINGS from '../../assets/strings.json'; const StyledSelect = styled.select` margin: 0.25rem 1rem 0.25rem 0rem; @@ -40,10 +39,64 @@ const StyledOption = styled.option` min-width: 10rem; `; +const showToast = (message: string, isError: boolean = false) => { + toast.dismiss(); + (isError ? toast.error : toast.success)(

{message}

, { + position: 'bottom-right', + }) +} + +const CreateTier: React.FC = () => { + const [tierName, setTierName] = useState(''); + const [permissions, setPermissions] = useState(['']); + + const [createTier] = useCreateTierMutation({ + variables: { input: { name: tierName, permissions } }, + refetchQueries: [{ query: TiersDocument }], + awaitRefetchQueries: true, + }); + + const onCreateTier = async (): Promise => { + try { + createTier() + .then(() => showToast(`Tier ${tierName} created successfully!`)) + .catch(res => showToast(`Sorry. ${res.graphQLErrors[0].message} Please try again :)`, true)) + .finally(() => { + setTierName(""); + setPermissions([""]); + }); + } catch (err) { + console.error(err); + } + }; + + return ( + <> + + setTierName(e.target.value)} + minWidth="15em" + /> + setPermissions(e.target.value.split(','))} + minWidth="15em" + /> + + + + ); +}; + const CreateCompany: React.FunctionComponent = (): JSX.Element => { const [companyName, setCompanyName] = useState(''); const [tierId, setTierId] = useState(''); - const [createCompanyMsg, setCreateCompanyMsg] = useState(''); + const selectTierRef = useRef(null); const [createCompany] = useCreateCompanyMutation({ variables: { input: { name: companyName, tierId } }, @@ -56,12 +109,17 @@ const CreateCompany: React.FunctionComponent = (): JSX.Element => { const onCreateCompany = async (): Promise => { try { - createCompany().catch(res => { - setCreateCompanyMsg(`Sorry. ${res.graphQLErrors[0].message} Please try again :-)`); - }); + createCompany() + .then(() => showToast(`Company ${companyName} created successfully!`)) + .catch(res => showToast(`Sorry. ${res.graphQLErrors[0].message} Please try again :)`, true)) + .finally(() => { + setCompanyName(""); + if (selectTierRef && selectTierRef.current) { + selectTierRef.current.value = ""; + } + }) } catch (err) { console.error(err); - setCreateCompanyMsg(STRINGS.GRAPHQL_ORGANIZER_ERROR_MESSAGE); } }; @@ -78,7 +136,7 @@ const CreateCompany: React.FunctionComponent = (): JSX.Element => { {loading || !data ? ( ) : ( - setTierId(e.target.value)}> + setTierId(e.target.value)} ref={selectTierRef}> Select Tier @@ -89,59 +147,8 @@ const CreateCompany: React.FunctionComponent = (): JSX.Element => { ))} )} - + - - {createCompanyMsg} - - - ); -}; - -const CreateTier: React.FC = () => { - const [tierName, setTierName] = useState(''); - const [permissions, setPermissions] = useState(['']); - const [createTierMsg, setCreateTierMsg] = useState(''); - - const [createTier] = useCreateTierMutation({ - variables: { input: { name: tierName, permissions } }, - refetchQueries: [{ query: TiersDocument }], - awaitRefetchQueries: true, - }); - - const onCreateTier = async (): Promise => { - try { - createTier().catch(res => { - setCreateTierMsg(`Sorry. ${res.graphQLErrors[0].message} Please try again :-)`); - }); - } catch (err) { - console.error(err); - setCreateTierMsg(STRINGS.GRAPHQL_ORGANIZER_ERROR_MESSAGE); - } - }; - - return ( - <> - - setTierName(e.target.value)} - minWidth="15em" - /> - setPermissions(e.target.value.split(','))} - minWidth="15em" - /> - - - - {createTierMsg} - ); }; @@ -150,31 +157,31 @@ const CreateSponsor: React.FunctionComponent = (): JSX.Element => { const [sponsorEmail, setSponsorEmail] = useState(''); const [sponsorName, setSponsorName] = useState(''); const [companyId, setCompanyId] = useState(''); - const [createSponsorMsg, setCreateSponsorMsg] = useState(''); const { loading, data } = useCompaniesQuery(); + const selectCompanyRef = useRef(null); const [createSponsor] = useCreateSponsorMutation({ variables: { input: { companyId, email: sponsorEmail, name: sponsorName } }, }); const onCreateSponsorEmail = async (): Promise => { - // validate the email entered - if (EmailValidator.validate(sponsorEmail)) { try { - console.log(sponsorEmail); - console.log(sponsorName); - createSponsor().catch(res => { - setCreateSponsorMsg(`Sorry. ${res.graphQLErrors[0].message} Please try again :-)`); - }); - // create sponsor in the database - // already created or not + createSponsor() + .then(() => showToast(`Email ${sponsorEmail} for sponsor ${sponsorName} created successfully!`)) + .catch(res => showToast(`Sorry. ${res.graphQLErrors[0].message} Please try again :)`, true)) + .finally(() => { + setSponsorEmail(""); + setSponsorName(""); + if (selectCompanyRef && selectCompanyRef.current) { + selectCompanyRef.current.value = ""; + } + }) } catch (err) { console.error(err); - setCreateSponsorMsg(STRINGS.GRAPHQL_ORGANIZER_ERROR_MESSAGE); } } else { - setCreateSponsorMsg(`Email '${sponsorEmail}' is not valid when creating sponsor`); + showToast(`Email ${sponsorEmail} is not valid for creating a sponsor`, true); } }; @@ -198,7 +205,7 @@ const CreateSponsor: React.FunctionComponent = (): JSX.Element => { {loading || !data ? ( ) : ( - setCompanyId(e.target.value)}> + setCompanyId(e.target.value)} ref={selectCompanyRef}> Select Company @@ -209,11 +216,8 @@ const CreateSponsor: React.FunctionComponent = (): JSX.Element => { ))} )} - + - - {createSponsorMsg} - ); }; From b002e2eaa4eda3d8ff48617eedd4869ccac2823d Mon Sep 17 00:00:00 2001 From: Chinchuluun1029 Date: Wed, 29 Sep 2021 15:23:47 -0500 Subject: [PATCH 2/5] Remove duplicate word --- src/client/routes/manage/CreateSponsor.tsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/client/routes/manage/CreateSponsor.tsx b/src/client/routes/manage/CreateSponsor.tsx index f10d85be8..37c5ec876 100644 --- a/src/client/routes/manage/CreateSponsor.tsx +++ b/src/client/routes/manage/CreateSponsor.tsx @@ -59,7 +59,7 @@ const CreateTier: React.FC = () => { const onCreateTier = async (): Promise => { try { createTier() - .then(() => showToast(`Tier ${tierName} created successfully!`)) + .then(() => showToast(`${tierName} created successfully!`)) .catch(res => showToast(`Sorry. ${res.graphQLErrors[0].message} Please try again :)`, true)) .finally(() => { setTierName(""); From 006862b1c008ab0706f18b4e57a53847ad693a77 Mon Sep 17 00:00:00 2001 From: Chinchuluun1029 Date: Wed, 29 Sep 2021 15:24:38 -0500 Subject: [PATCH 3/5] Rollback --- src/client/routes/manage/CreateSponsor.tsx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/client/routes/manage/CreateSponsor.tsx b/src/client/routes/manage/CreateSponsor.tsx index 37c5ec876..f10d85be8 100644 --- a/src/client/routes/manage/CreateSponsor.tsx +++ b/src/client/routes/manage/CreateSponsor.tsx @@ -59,7 +59,7 @@ const CreateTier: React.FC = () => { const onCreateTier = async (): Promise => { try { createTier() - .then(() => showToast(`${tierName} created successfully!`)) + .then(() => showToast(`Tier ${tierName} created successfully!`)) .catch(res => showToast(`Sorry. ${res.graphQLErrors[0].message} Please try again :)`, true)) .finally(() => { setTierName(""); From bd2d1cdbd4dcff3d40cfdd2b7ce4a5834b319c61 Mon Sep 17 00:00:00 2001 From: Chinchuluun1029 Date: Tue, 5 Oct 2021 09:17:52 -0500 Subject: [PATCH 4/5] Resolving lint error --- src/client/routes/manage/CreateSponsor.tsx | 43 +++++++++++++--------- 1 file changed, 26 insertions(+), 17 deletions(-) diff --git a/src/client/routes/manage/CreateSponsor.tsx b/src/client/routes/manage/CreateSponsor.tsx index f10d85be8..e58981e44 100644 --- a/src/client/routes/manage/CreateSponsor.tsx +++ b/src/client/routes/manage/CreateSponsor.tsx @@ -1,4 +1,4 @@ -import React, { useRef, useState } from 'react'; +import React, { ReactText, useRef, useState } from 'react'; import styled from 'styled-components'; import * as EmailValidator from 'email-validator'; import { toast } from 'react-toastify'; @@ -39,12 +39,17 @@ const StyledOption = styled.option` min-width: 10rem; `; -const showToast = (message: string, isError: boolean = false) => { +const showToast = (message: string, isError = false): ReactText => { toast.dismiss(); - (isError ? toast.error : toast.success)(

{message}

, { - position: 'bottom-right', - }) -} + (isError ? toast.error : toast.success)( +

+ {message} +

, + { + position: 'bottom-right', + } + ); +}; const CreateTier: React.FC = () => { const [tierName, setTierName] = useState(''); @@ -62,8 +67,8 @@ const CreateTier: React.FC = () => { .then(() => showToast(`Tier ${tierName} created successfully!`)) .catch(res => showToast(`Sorry. ${res.graphQLErrors[0].message} Please try again :)`, true)) .finally(() => { - setTierName(""); - setPermissions([""]); + setTierName(''); + setPermissions(['']); }); } catch (err) { console.error(err); @@ -113,11 +118,11 @@ const CreateCompany: React.FunctionComponent = (): JSX.Element => { .then(() => showToast(`Company ${companyName} created successfully!`)) .catch(res => showToast(`Sorry. ${res.graphQLErrors[0].message} Please try again :)`, true)) .finally(() => { - setCompanyName(""); + setCompanyName(''); if (selectTierRef && selectTierRef.current) { - selectTierRef.current.value = ""; + selectTierRef.current.value = ''; } - }) + }); } catch (err) { console.error(err); } @@ -168,15 +173,19 @@ const CreateSponsor: React.FunctionComponent = (): JSX.Element => { if (EmailValidator.validate(sponsorEmail)) { try { createSponsor() - .then(() => showToast(`Email ${sponsorEmail} for sponsor ${sponsorName} created successfully!`)) - .catch(res => showToast(`Sorry. ${res.graphQLErrors[0].message} Please try again :)`, true)) + .then(() => + showToast(`Email ${sponsorEmail} for sponsor ${sponsorName} created successfully!`) + ) + .catch(res => + showToast(`Sorry. ${res.graphQLErrors[0].message} Please try again :)`, true) + ) .finally(() => { - setSponsorEmail(""); - setSponsorName(""); + setSponsorEmail(''); + setSponsorName(''); if (selectCompanyRef && selectCompanyRef.current) { - selectCompanyRef.current.value = ""; + selectCompanyRef.current.value = ''; } - }) + }); } catch (err) { console.error(err); } From ee0f255ad224904a92d57a6832361d4558bf8523 Mon Sep 17 00:00:00 2001 From: Chinchuluun1029 Date: Tue, 5 Oct 2021 09:19:47 -0500 Subject: [PATCH 5/5] Changing return type bc im dummy --- src/client/routes/manage/CreateSponsor.tsx | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/src/client/routes/manage/CreateSponsor.tsx b/src/client/routes/manage/CreateSponsor.tsx index e58981e44..c6cfae6bf 100644 --- a/src/client/routes/manage/CreateSponsor.tsx +++ b/src/client/routes/manage/CreateSponsor.tsx @@ -1,4 +1,4 @@ -import React, { ReactText, useRef, useState } from 'react'; +import React, { useRef, useState } from 'react'; import styled from 'styled-components'; import * as EmailValidator from 'email-validator'; import { toast } from 'react-toastify'; @@ -39,7 +39,7 @@ const StyledOption = styled.option` min-width: 10rem; `; -const showToast = (message: string, isError = false): ReactText => { +const showToast = (message: string, isError = false): void => { toast.dismiss(); (isError ? toast.error : toast.success)(