Display KYC status on success page

This commit is contained in:
Adw8 2024-07-30 14:44:21 +05:30
parent 2a24985930
commit a4cc95d9b8
3 changed files with 59 additions and 18 deletions

View File

@ -4,6 +4,10 @@ import { useLocation } from "react-router-dom";
import { Box, Typography } from "@mui/material"; import { Box, Typography } from "@mui/material";
import { Registry } from "@cerc-io/registry-sdk"; import { Registry } from "@cerc-io/registry-sdk";
import SumsubWebSdk from "@sumsub/websdk-react";
import { MessageHandler } from "@sumsub/websdk";
import { accessTokenExpirationHandler, config, fetchAccessToken, options } from "../utils/sumsub";
interface Participant { interface Participant {
cosmosAddress: string; cosmosAddress: string;
@ -23,6 +27,17 @@ const OnboardingSuccess = () => {
} }
const [participant, setParticipant] = useState<Participant>(); const [participant, setParticipant] = useState<Participant>();
const [token, setToken] = useState<string>('');
const [loading, setLoading] = useState<boolean>(true);
const messageHandler: MessageHandler = (event, payload) => {
console.log('sumsubEvent:', event);
if (payload) {
console.log("Event payload is: ", payload);
}
};
useEffect(() => { useEffect(() => {
const fetchParticipants = async () => { const fetchParticipants = async () => {
@ -46,6 +61,23 @@ const OnboardingSuccess = () => {
fetchParticipants(); fetchParticipants();
}, [cosmosAddress]); }, [cosmosAddress]);
useEffect(() => {
const getToken = async (userId: string) => {
const newToken = await fetchAccessToken(userId);
setToken(newToken);
setLoading(false);
};
if (cosmosAddress) {
console.log("Cosmos addy: ", cosmosAddress);
getToken(cosmosAddress).catch(error => {
console.error(error);
alert("Failed to fetch token");
});
}
}, [cosmosAddress]);
return ( return (
<Box <Box
sx={{ sx={{
@ -78,6 +110,15 @@ const OnboardingSuccess = () => {
)} )}
</pre> </pre>
</Box> </Box>
{!loading && token && (
<SumsubWebSdk
accessToken={token}
expirationHandler={accessTokenExpirationHandler}
config={config}
options={options}
onMessage={messageHandler}
/>
)}
<SnackbarProvider /> <SnackbarProvider />
</Box> </Box>
); );

View File

@ -6,17 +6,7 @@ import SumsubWebSdk from '@sumsub/websdk-react';
import { MessageHandler } from '@sumsub/websdk'; import { MessageHandler } from '@sumsub/websdk';
import { EventPayload } from '@sumsub/websdk/types/types'; import { EventPayload } from '@sumsub/websdk/types/types';
import { fetchAccessToken } from '../utils/sumsub'; import { accessTokenExpirationHandler, config, fetchAccessToken, options } from '../utils/sumsub';
const config = {
lang: "en", // language of WebSDK texts and comments (ISO 639-1 format)
theme: "light",
};
const options = {
addViewportTag: false,
adaptIframeHeight: true,
};
const UserVerification = () => { const UserVerification = () => {
const [kycId, setKycId] = useState<string>('unknown'); const [kycId, setKycId] = useState<string>('unknown');
@ -39,11 +29,11 @@ const UserVerification = () => {
const getToken = async (userId: string) => { const getToken = async (userId: string) => {
console.log(userId); console.log(userId);
const newToken = await fetchAccessToken(userId); const newToken = await fetchAccessToken(userId);
setToken(newToken); setToken(newToken);
setLoading(false); setLoading(false);
}; };
if (userId) { if (userId) {
getToken(userId).catch(error => { getToken(userId).catch(error => {
console.error(error); console.error(error);
@ -64,11 +54,6 @@ const UserVerification = () => {
} }
}, [applicationSubmitted, kycId, navigate, cosmosAddress, message, receivedEthSig]); }, [applicationSubmitted, kycId, navigate, cosmosAddress, message, receivedEthSig]);
const accessTokenExpirationHandler = async () => {
alert("Please renew token");
return "Token expired";
};
const messageHandler: MessageHandler = (event, payload) => { const messageHandler: MessageHandler = (event, payload) => {
console.log('sumsubEvent:', event); console.log('sumsubEvent:', event);

View File

@ -14,3 +14,18 @@ export const fetchAccessToken = async (userId: string): Promise<string> => {
const data = await response.json(); const data = await response.json();
return data.token; return data.token;
}; };
export const config = {
lang: "en", // language of WebSDK texts and comments (ISO 639-1 format)
theme: "light",
};
export const options = {
addViewportTag: false,
adaptIframeHeight: true,
};
export const accessTokenExpirationHandler = async () => {
alert("Please renew token");
return "Token expired";
};