import { Dispatch, FunctionComponent, SetStateAction, useEffect } from "react"; import { ChainItemType } from "../../types"; import color from "../../styles/color"; import styled from "styled-components"; import { ChainItem } from "./chain-item"; interface Props { allChecked: boolean; setAllChecked: Dispatch>; chainList: ChainItemType[]; disabledChainList: ChainItemType[]; checkedItems: Set; setCheckedItems: Dispatch>>; } export const ChainList: FunctionComponent = (props) => { const { allChecked, setAllChecked, chainList, disabledChainList, checkedItems, setCheckedItems, } = props; const checkedItemHandler = (chainItem: ChainItemType, isChecked: boolean) => { const tempSet = new Set(checkedItems); if (isChecked) { tempSet.add(chainItem); } else if (!isChecked && checkedItems.has(chainItem)) { tempSet.delete(chainItem); } setCheckedItems(tempSet); }; useEffect(() => { if (allChecked) { setCheckedItems(new Set(chainList)); } else if (chainList.length === checkedItems.size) { setCheckedItems(new Set()); } }, [allChecked]); useEffect(() => { if (chainList.length === checkedItems.size && checkedItems.size !== 0) { setAllChecked(true); } else { setAllChecked(false); } }, [checkedItems]); return ( {chainList.map((chainItem) => ( ))} {disabledChainList.map((chainItem) => ( ))} ); }; export const ChainContainer = styled.div` display: flex; flex-direction: column; width: 100%; max-height: 33rem; overflow: scroll; background-color: ${(props) => props.color}; `;