diff --git a/src/components/User/UserDashBoard.tsx b/src/components/User/UserDashBoard.tsx index 7aa739e55..970d872e0 100644 --- a/src/components/User/UserDashBoard.tsx +++ b/src/components/User/UserDashBoard.tsx @@ -1,24 +1,25 @@ -import { useEffect, useState } from 'react'; -import { AlertComponent } from '../AlertComponent'; -import type { AxiosResponse } from 'axios'; -import CustomAvatar from '../Avatar/index'; -import type { Organisation } from '../organization/interfaces'; -import type { UserActivity } from './interfaces'; +import { Button, Tooltip } from 'flowbite-react'; +import { getAllCredDef, getAllSchemasByOrgId } from '../../api/Schema'; +import { getFromLocalStorage, setToLocalStorage } from '../../api/Auth'; import { apiStatusCodes, itemPerPage, storageKeys } from '../../config/CommonConstant'; import { getOrganizationById, getOrganizations } from '../../api/organization'; -import { getUserActivity } from '../../api/users'; import { getUserEcosystemInvitations, getUserInvitations, } from '../../api/invitations'; -import { pathRoutes } from '../../config/pathRoutes'; -import { getFromLocalStorage, setToLocalStorage } from '../../api/Auth'; -import { dateConversion } from '../../utils/DateConversion'; +import { useEffect, useState } from 'react'; + +import { AlertComponent } from '../AlertComponent'; +import type { AxiosResponse } from 'axios'; +import CustomAvatar from '../Avatar/index'; import DateTooltip from '../Tooltip'; -import { Roles } from '../../utils/enums/roles'; -import { Button, Tooltip } from 'flowbite-react'; -import { getAllCredDef, getAllSchemasByOrgId } from '../../api/Schema'; import type { GetAllSchemaListParameter } from '../Resources/Schema/interfaces'; +import type { Organisation } from '../organization/interfaces'; +import { Roles } from '../../utils/enums/roles'; +import type { UserActivity } from './interfaces'; +import { dateConversion } from '../../utils/DateConversion'; +import { getUserActivity } from '../../api/users'; +import { pathRoutes } from '../../config/pathRoutes'; import React from 'react'; import { OrganizationRoles, @@ -50,10 +51,10 @@ interface ICredDef { } const UserDashBoard = () => { - const [message, setMessage] = useState(null); - const [ecoMessage, setEcoMessage] = useState(null); + const [message, setMessage] = useState(''); + const [ecoMessage, setEcoMessage] = useState(''); const [viewButton, setViewButton] = useState(false); - const [error, setError] = useState(null); + const [error, setError] = useState(''); const [currentPage, setCurrentPage] = useState(initialPageState); const [organizationsList, setOrganizationList] = useState | null>(null); @@ -85,6 +86,7 @@ const UserDashBoard = () => { const getAllInvitations = async () => { setLoading(true); + try { const response = await getUserInvitations( currentPage.pageNumber, currentPage.pageSize, @@ -106,9 +108,11 @@ const UserDashBoard = () => { } else { setError(response as string); } + } catch(err) { + setError('An unexpected error occurred'); + } setLoading(false); }; - //Fetch the user organization list const getAllOrganizations = async () => { setOrgLoading(true); const response = await getOrganizations( @@ -128,9 +132,10 @@ const UserDashBoard = () => { } setOrgLoading(false); }; - + const getAllEcosystemInvitations = async () => { setLoading(true); + try { const response = await getUserEcosystemInvitations( currentPage.pageNumber, currentPage.pageSize, @@ -156,6 +161,10 @@ const UserDashBoard = () => { } else { setError(response as string); } + } + catch(err){ + setError('An unexpected error occurred.'); + } setLoading(false); }; @@ -437,31 +446,39 @@ const UserDashBoard = () => { }; return ( + <>
- 0 && + + { - setMessage(null); - setError(null); + setMessage(''); + setError(''); }} - /> + /> + } + +
- { - setEcoMessage(null); - setError(null); - }} - /> + {ecoMessage && ecoMessage.length > 0 && + { + setEcoMessage(''); + setError(''); + }} + /> +} +
{walletData && walletData.length > 0 ? ( <> @@ -572,7 +589,7 @@ const UserDashBoard = () => { ); org.roles = roles; return ( - @@ -603,12 +620,12 @@ const UserDashBoard = () => { )} - {org?.name} + {org?.name} {org.roles.includes( OrganizationRoles.organizationOwner, ) ? ( - + { OrganizationRoles.organizationIssuer, ) ? ( {
- + ); })} {organizationsList && organizationsList?.length > 0 && ( @@ -941,10 +955,10 @@ const UserDashBoard = () => { className="flex items-center space-x-2 py-2 hover:bg-gray-100 dark:hover:bg-gray-600 dark:hover:text-white rounded-md" > - {schema?.name} + {schema?.name || ''} - {schema?.version} + {schema?.version || ''} @@ -1040,10 +1054,10 @@ const UserDashBoard = () => { className="flex items-center space-x-2 py-2 hover:bg-gray-100 dark:hover:bg-gray-600 dark:hover:text-white rounded-md" > - {cred?.tag} + {cred?.tag || ''} - {cred?.credentialDefinitionId} + {cred?.credentialDefinitionId || ''} @@ -1111,6 +1125,7 @@ const UserDashBoard = () => { + ); }; export default UserDashBoard;