import { FunctionComponent } from "react"; import ArrowRightIcon from "../../public/images/svg/arrow-right.svg"; import color from "../../styles/color"; import { Flex1 } from "../../styles/flex-1"; import styled from "styled-components"; import Image from "next/image"; import { SELECTED_WALLET_KEY, WALLET_INSTALL_URL, WalletType, } from "../../constants/wallet"; import { getKeplrFromWindow, KeplrWallet } from "../../wallets"; import { loginWithTwitter } from "../../repository"; interface Props { wallet: WalletType; } export const WalletItem: FunctionComponent = (props: Props) => { const { wallet } = props; const onClickWalletItem = async () => { try { if (wallet.name === "Keplr") { await connectKeplr(); localStorage.setItem(SELECTED_WALLET_KEY, wallet.name); } await loginWithTwitter(); } catch (e) { console.log(e); } }; const connectKeplr = async () => { const keplr = await getKeplrFromWindow(); if (keplr === undefined) { window.location.href = WALLET_INSTALL_URL; } if (keplr) { const wallet = new KeplrWallet(keplr); const chainIds = (await wallet.getChainInfosWithoutEndpoints()).map( (c) => c.chainId, ); await wallet.init(chainIds); } }; return ( wallet Icon {wallet.name} {wallet.isReady ? null : ( Comming soon )} arrow right icon ); }; const WalletContainer = styled.div<{ isReady: boolean }>` display: flex; flex-direction: row; align-items: center; height: 5.8rem; padding: 1rem; background-color: ${color.grey["600"]}; opacity: ${(props) => (props.isReady ? 1 : 0.3)}; cursor: ${(props) => (props.isReady ? "pointer" : "default")}; `; const WalletIcon = styled.div` position: relative; width: 3.75rem; height: 3.75rem; `; const WalletContentContainer = styled.div` display: flex; flex-direction: column; align-items: flex-start; padding-left: 1rem; `; const WalletName = styled.div` font-family: "Inter", serif; font-style: normal; font-weight: 600; font-size: 1.3rem; line-height: 1.5rem; text-align: center; color: ${color.white}; `; const WalletDescription = styled.div` font-family: "Inter", serif; font-style: normal; font-weight: 600; font-size: 0.8rem; line-height: 1.1rem; color: ${color.grey["300"]}; `;