Display KYC status in success page #8
@ -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>
|
||||||
);
|
);
|
||||||
|
@ -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);
|
||||||
|
|
||||||
|
@ -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";
|
||||||
|
};
|
||||||
|
Loading…
Reference in New Issue
Block a user