icns-frontend/components/connect-wallet-modal/modal.tsx

78 lines
1.8 KiB
TypeScript
Raw Permalink Normal View History

2022-12-12 06:51:25 +00:00
import { FunctionComponent } from "react";
2022-12-12 08:46:50 +00:00
import ReactModal from "react-modal";
2022-12-12 06:51:25 +00:00
import styled from "styled-components";
import color from "../../styles/color";
2022-12-12 08:46:50 +00:00
import { WalletList } from "../../constants/wallet";
import { WalletItem } from "./wallet-item";
2022-12-12 06:51:25 +00:00
interface Props {
isModalOpen: boolean;
onCloseModal: () => void;
}
export const ConnectWalletModal: FunctionComponent<Props> = (props) => {
const { isModalOpen, onCloseModal } = props;
return (
<ReactModal
isOpen={isModalOpen}
onRequestClose={onCloseModal}
2022-12-14 11:36:08 +00:00
ariaHideApp={false}
2022-12-12 06:51:25 +00:00
style={{
2022-12-16 06:55:31 +00:00
overlay: { background: "#121212cc" },
2022-12-12 06:51:25 +00:00
content: {
top: "50%",
left: "50%",
right: "auto",
bottom: "auto",
padding: 0,
marginRight: "-50%",
transform: "translate(-50%, -50%)",
background: color.grey["800"],
border: 0,
},
}}
>
<ModalContainer>
<ModalTitle>Connect Wallet</ModalTitle>
<ModalDescription>
Plz check which account is selected after you connect it
</ModalDescription>
2022-12-12 08:46:50 +00:00
{WalletList.map((walletItem) => {
return <WalletItem wallet={walletItem} key={walletItem.name} />;
})}
2022-12-12 06:51:25 +00:00
</ModalContainer>
</ReactModal>
);
};
const ModalContainer = styled.div`
display: flex;
flex-direction: column;
gap: 0.9rem;
padding: 2.2rem;
2022-12-16 06:55:31 +00:00
min-width: 28rem;
2022-12-12 06:51:25 +00:00
`;
const ModalTitle = styled.div`
font-family: "Inter", serif;
font-style: normal;
font-weight: 600;
font-size: 1.5rem;
line-height: 1.8rem;
color: ${color.white};
`;
const ModalDescription = styled.div`
font-family: "Inter", serif;
font-style: normal;
font-weight: 500;
font-size: 0.8rem;
line-height: 1.1rem;
color: ${color.grey["400"]};
`;