forked from LaconicNetwork/icns-frontend
66 lines
1.6 KiB
TypeScript
66 lines
1.6 KiB
TypeScript
|
import { ChainItemType } from "../../types";
|
||
|
import {
|
||
|
ChangeEvent,
|
||
|
Dispatch,
|
||
|
FunctionComponent,
|
||
|
SetStateAction,
|
||
|
useEffect,
|
||
|
useState,
|
||
|
} from "react";
|
||
|
import {
|
||
|
ChainImageContainer,
|
||
|
ChainInfoContainer,
|
||
|
ChainItemContainer,
|
||
|
} from "./chain-list";
|
||
|
import { ChainImage } from "./chain-image";
|
||
|
import { Flex1 } from "../../styles/flex-1";
|
||
|
import { ChainCheckBox, ChainName, WalletAddress } from "./chain-item";
|
||
|
import color from "../../styles/color";
|
||
|
import styled from "styled-components";
|
||
|
|
||
|
interface Props {
|
||
|
allChecked: boolean;
|
||
|
setAllChecked: Dispatch<SetStateAction<boolean>>;
|
||
|
chainItem: ChainItemType;
|
||
|
}
|
||
|
|
||
|
export const AllChainsItem: FunctionComponent<Props> = (props) => {
|
||
|
const { allChecked, setAllChecked, chainItem } = props;
|
||
|
|
||
|
const checkHandler = () => {
|
||
|
setAllChecked(!allChecked);
|
||
|
};
|
||
|
|
||
|
return (
|
||
|
<AllChainsContainer>
|
||
|
<ChainItemContainer
|
||
|
key={chainItem.prefix}
|
||
|
isLoading={false}
|
||
|
onClick={checkHandler}
|
||
|
>
|
||
|
<ChainImageContainer width="3rem" height="3rem">
|
||
|
<ChainImage
|
||
|
src={chainItem.chainImageUrl}
|
||
|
fill={true}
|
||
|
alt={`${chainItem.prefix} chain image`}
|
||
|
/>
|
||
|
</ChainImageContainer>
|
||
|
<ChainInfoContainer>
|
||
|
<ChainName>{`.${chainItem.prefix}`}</ChainName>
|
||
|
<WalletAddress>{chainItem.address}</WalletAddress>
|
||
|
</ChainInfoContainer>
|
||
|
|
||
|
<Flex1 />
|
||
|
|
||
|
<ChainCheckBox checked={allChecked} />
|
||
|
</ChainItemContainer>
|
||
|
</AllChainsContainer>
|
||
|
);
|
||
|
};
|
||
|
|
||
|
const AllChainsContainer = styled.div`
|
||
|
width: 100%;
|
||
|
|
||
|
background-color: ${color.grey["800"]};
|
||
|
`;
|