icns-frontend/pages/complete/index.tsx

218 lines
4.4 KiB
TypeScript
Raw Normal View History

2022-12-12 08:16:16 +00:00
import Image from "next/image";
import styled from "styled-components";
2022-12-12 08:40:36 +00:00
import Typed from "react-typed";
2022-12-12 08:16:16 +00:00
import { Logo } from "../../components/logo";
import color from "../../styles/color";
import AlertCircleOutlineIcon from "../../public/images/svg/alert-circle-outline.svg";
import TwitterIcon from "../../public/images/svg/twitter-icon.svg";
2022-12-14 07:52:05 +00:00
import { useRouter } from "next/router";
import { useEffect } from "react";
import { TendermintTxTracer } from "@keplr-wallet/cosmos";
2022-12-12 08:16:16 +00:00
export default function CompletePage() {
2022-12-14 07:52:05 +00:00
const router = useRouter();
useEffect(() => {
const { txHash } = router.query;
if (txHash) {
traceTX(txHash as string);
}
}, []);
const traceTX = async (txHash: string) => {
const txTracer = new TendermintTxTracer(
"https://rpc.testnet.osmosis.zone",
"/websocket",
);
const result = await txTracer.traceTx(Buffer.from(txHash, "hex"));
console.log(result);
2022-12-15 10:06:44 +00:00
// Todo rsult => 확인 후에 확인
2022-12-14 07:52:05 +00:00
};
2022-12-12 08:16:16 +00:00
return (
<Container>
<Logo />
<MainContainer>
<MainTitle>Your Name is Active Now!</MainTitle>
<ContentContainer>
<RecipentContainer>
<RecipentTitle>Recipent</RecipentTitle>
2022-12-12 08:40:36 +00:00
<AddressContainer>
kingstarcookies.
<Typed
strings={["osmo", "cosmos"]}
typeSpeed={150}
backSpeed={150}
backDelay={1000}
loop
smartBackspace
/>
</AddressContainer>
2022-12-12 08:16:16 +00:00
<AvailableAddressText>available address</AvailableAddressText>
</RecipentContainer>
</ContentContainer>
<DescriptionContainer>
<AlertIcon>
<Image src={AlertCircleOutlineIcon} fill={true} alt="alert icon" />
</AlertIcon>
<DescriptionText>
If you want to make that name address with same twitter account,
just go to home and start again.
</DescriptionText>
</DescriptionContainer>
<ShareButtonContainer>
<ShareButtonText>SHARE MY NAME</ShareButtonText>
<Image src={TwitterIcon} alt="twitter icon" />
</ShareButtonContainer>
</MainContainer>
</Container>
);
}
const Container = styled.div`
width: 100vw;
height: 100vh;
`;
const MainContainer = styled.div`
display: flex;
flex-direction: column;
align-items: center;
padding-top: 10.1rem;
color: white;
`;
const MainTitle = styled.div`
font-family: "Inter", serif;
font-style: normal;
font-weight: 700;
font-size: 2rem;
line-height: 2rem;
padding: 1rem;
`;
const ContentContainer = styled.div`
width: 30rem;
margin-top: 1rem;
padding: 2rem 2rem;
background-color: ${color.grey["900"]};
`;
const RecipentContainer = styled.div`
display: flex;
flex-direction: column;
gap: 0.5rem;
padding: 2rem;
`;
const RecipentTitle = styled.div`
font-family: "Inter", serif;
font-style: normal;
font-weight: 500;
font-size: 1rem;
line-height: 1rem;
color: ${color.grey["400"]};
`;
const AddressContainer = styled.div`
font-family: "Inter", serif;
font-style: normal;
font-weight: 600;
font-size: 0.9rem;
line-height: 0.9rem;
color: ${color.white};
padding: 1rem;
background-color: ${color.grey["600"]};
`;
const AvailableAddressText = styled.div`
font-family: "Inter", serif;
font-style: normal;
font-weight: 400;
font-size: 0.75rem;
line-height: 0.75rem;
color: ${color.blue};
`;
const DescriptionContainer = styled.div`
display: flex;
flex-direction: row;
gap: 1rem;
width: 30rem;
margin-top: 1.5rem;
padding: 1.5rem 2rem;
background-color: ${color.grey["900"]};
`;
const AlertIcon = styled.div`
position: relative;
width: 1.5rem;
height: 1.5rem;
`;
const DescriptionText = styled.div`
width: 100%;
font-family: "Inter", serif;
font-style: normal;
font-weight: 400;
font-size: 0.8rem;
line-height: 0.8rem;
color: ${color.grey["400"]};
`;
const ShareButtonContainer = styled.div`
display: flex;
flex-direction: row;
justify-content: center;
align-items: center;
gap: 0.625rem;
width: 20rem;
height: 5rem;
margin-top: 2.5rem;
cursor: pointer;
user-select: none;
background-color: ${color.grey["700"]};
`;
const ShareButtonText = styled.div`
font-family: "Inter", serif;
font-style: normal;
font-weight: 700;
font-size: 1.25rem;
line-height: 1.25rem;
color: ${color.grey["100"]};
`;