feat: refactored the member status mapping

This commit is contained in:
SagarRajput-7
2026-03-18 23:42:53 +05:30
parent 34dcd79243
commit b9bcd2d4e1
2 changed files with 29 additions and 22 deletions

View File

@@ -13,7 +13,7 @@ import MembersTable, { MemberRow } from 'components/MembersTable/MembersTable';
import useUrlQuery from 'hooks/useUrlQuery';
import { useAppContext } from 'providers/App/App';
import { FilterMode, MemberStatus } from './utils';
import { FilterMode, MemberStatus, toMemberStatus } from './utils';
import './MembersSettings.styles.scss';
@@ -40,27 +40,15 @@ function MembersSettings(): JSX.Element {
const allMembers = useMemo(
(): MemberRow[] =>
(usersData?.data ?? []).map((user) => {
let status: MemberStatus;
if (user.status === 'pending_invite') {
status = MemberStatus.Invited;
} else if (user.status === 'deleted') {
status = MemberStatus.Deleted;
} else if (user.status === 'active') {
status = MemberStatus.Active;
} else {
status = MemberStatus.Anonymous;
}
return {
id: user.id,
name: user.displayName,
email: user.email,
role: user.role,
status,
joinedOn: user.createdAt ? String(user.createdAt) : null,
updatedAt: user.updatedAt ? String(user.updatedAt) : null,
};
}),
(usersData?.data ?? []).map((user) => ({
id: user.id,
name: user.displayName,
email: user.email,
role: user.role,
status: toMemberStatus(user.status ?? ''),
joinedOn: user.createdAt ? String(user.createdAt) : null,
updatedAt: user.updatedAt ? String(user.updatedAt) : null,
})),
[usersData],
);

View File

@@ -9,3 +9,22 @@ export enum MemberStatus {
Deleted = 'Deleted',
Anonymous = 'Anonymous',
}
export enum UserApiStatus {
Active = 'active',
PendingInvite = 'pending_invite',
Deleted = 'deleted',
}
export function toMemberStatus(apiStatus: string): MemberStatus {
switch (apiStatus) {
case UserApiStatus.PendingInvite:
return MemberStatus.Invited;
case UserApiStatus.Deleted:
return MemberStatus.Deleted;
case UserApiStatus.Active:
return MemberStatus.Active;
default:
return MemberStatus.Anonymous;
}
}