Skip to content

Commit

Permalink
refactor(member): send correct email+uid when making payment from mem…
Browse files Browse the repository at this point in the history
…bers-only area
  • Loading branch information
m2mathew committed Aug 2, 2023
1 parent 9dc80bb commit f79c7c5
Show file tree
Hide file tree
Showing 3 changed files with 18 additions and 7 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -27,9 +27,11 @@ import MemberInfoCard from '../../../shared/MemberInfoCard';
import PaypalButtonWrapper from '../../../register/paypal/paypal-button-wrapper';
import PrintInvoiceUI from '../../../../pages/members/PrintInvoiceUI';
import { appNameShort } from '../../../../utils/app-constants';
import { TfaaAuthUser } from '../../../layout';

// Local Typings
interface Props {
currentAuthUser: TfaaAuthUser | null;
currentMemberData: TfaaMemberData | null;
}

Expand Down Expand Up @@ -103,7 +105,10 @@ const StyledStrong = styled.strong(({ theme }) => ({
}));

// Component Definition
const MemberStatus: React.FC<Props> = ({ currentMemberData }) => {
const MemberStatus: React.FC<Props> = ({
currentAuthUser,
currentMemberData,
}) => {
const isRegisteredForCurrentYear = Boolean(currentMemberData);

// If the member paid by check, the TFAA Executive Secretary will manually
Expand All @@ -128,7 +133,7 @@ const MemberStatus: React.FC<Props> = ({ currentMemberData }) => {
receiptId: currentMemberData?.receiptId ?? 0,
};

const userId = `${currentMemberData?.Email}-${currentMemberData?.userId}`;
const userId = `${currentAuthUser?.email}-${currentAuthUser?.uid}`;

// Update the member's payment data in the Firestore database
// This shape should be the same as register-membmer-payment
Expand Down
8 changes: 7 additions & 1 deletion src/components/members/MemberContent/MemberInfo/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -14,10 +14,12 @@ import MemberContactInfo from './MemberContactInfo';
import MemberRegistrationTasks from './MemberRegistrationTasks';
import MemberStatus from './MemberStatus';
import AdminActions from './AdminActions';
import { TfaaAuthUser } from '../../../layout';

// Local Typings
interface Props {
authUserEmail: string | undefined;
currentAuthUser: TfaaAuthUser | null;
currentMemberData: TfaaMemberData | null;
isAdmin: boolean;
onUpdateShouldRefetchUserList: ((shouldRefetchUserList: boolean) => void) | null;
Expand Down Expand Up @@ -60,6 +62,7 @@ const StyledRoot = styled.div(({ theme }) => ({
// Component Definition
const MemberInfo: React.FC<Props> = ({
authUserEmail,
currentAuthUser,
currentMemberData,
onUpdateShouldRefetchUserList,
}) => {
Expand All @@ -71,7 +74,10 @@ const MemberInfo: React.FC<Props> = ({
<StyledRoot>
<Motifs small />

<MemberStatus currentMemberData={currentMemberData} />
<MemberStatus
currentAuthUser={currentAuthUser}
currentMemberData={currentMemberData}
/>

{currentMemberData && (
<MemberContactInfo
Expand Down
8 changes: 4 additions & 4 deletions src/components/members/MemberContent/index.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -36,11 +36,10 @@ const MemberContent: React.FC<Props> = ({ currentAuthUser }) => {
useEffect(() => {
if (currentAuthUser && allMembersData && allMembersData.length > 0 && !currentMemberData) {
const currentMember = allMembersData.find(
// We used to use authUser.uid as the unique key in the Firestore
// Now we use authUser.email
// We have to search for both for backwards compatibility
// We use a combination of email and uid to uniquely identify a user.
// The email part makes it easier to find a user in the database.
(user) => {
return user.userId === currentAuthUser.uid || user.userId === currentAuthUser.email;
return user.userId === `${currentAuthUser.email}-${currentAuthUser.uid}`;
});

setCurrentMemberData(currentMember ?? null);
Expand All @@ -65,6 +64,7 @@ const MemberContent: React.FC<Props> = ({ currentAuthUser }) => {

<MemberInfo
authUserEmail={currentAuthUser?.email || currentMemberData?.Email}
currentAuthUser={currentAuthUser}
currentMemberData={currentMemberData}
isAdmin={isAdmin}
onUpdateShouldRefetchUserList={handleUpdateShouldRefetchUserList}
Expand Down

0 comments on commit f79c7c5

Please sign in to comment.