2022-01-04 00:57:17 -06:00
|
|
|
import React from 'react';
|
2024-06-06 06:43:12 -05:00
|
|
|
import { styled } from '@mui/material/styles';
|
2022-01-04 00:57:17 -06:00
|
|
|
import CheckboxTree from 'react-checkbox-tree';
|
2024-04-08 21:51:14 -05:00
|
|
|
import CheckBoxIcon from '@mui/icons-material/CheckBox';
|
|
|
|
import CheckBoxOutlineBlankIcon from '@mui/icons-material/CheckBoxOutlineBlank';
|
|
|
|
import IndeterminateCheckBoxIcon from '@mui/icons-material/IndeterminateCheckBox';
|
|
|
|
import ExpandMoreIcon from '@mui/icons-material/ExpandMore';
|
|
|
|
import ChevronRightIcon from '@mui/icons-material/ChevronRight';
|
2022-01-04 00:57:17 -06:00
|
|
|
import PropTypes from 'prop-types';
|
|
|
|
|
2024-06-06 06:43:12 -05:00
|
|
|
|
|
|
|
const StyledDiv = styled('div')(({theme}) => ({
|
|
|
|
height: '100%',
|
|
|
|
'& .rct-collapse, .rct-checkbox': {
|
|
|
|
padding: 0
|
|
|
|
},
|
|
|
|
'& .rct-node-leaf':{
|
|
|
|
padding: '0 0 0 10px'
|
|
|
|
},
|
|
|
|
'& .react-checkbox-tree': {
|
|
|
|
height: '97%',
|
|
|
|
fontSize: '0.815rem',
|
|
|
|
overflow: 'auto',
|
|
|
|
...theme.mixins.panelBorder
|
|
|
|
},
|
|
|
|
'& .CheckBoxTree-unchecked': {
|
|
|
|
fill: theme.otherVars.borderColor
|
|
|
|
},
|
|
|
|
'& .CheckBoxTree-checked': {
|
|
|
|
fill: theme.palette.primary.main
|
|
|
|
}
|
|
|
|
}));
|
|
|
|
|
2022-01-04 00:57:17 -06:00
|
|
|
export default function CheckBoxTree({treeData, ...props}) {
|
|
|
|
const [checked, setChecked] = React.useState([]);
|
|
|
|
const [expanded, setExpanded] = React.useState([]);
|
|
|
|
|
|
|
|
React.useEffect(() => {
|
|
|
|
if (props.getSelectedServers) {
|
|
|
|
props.getSelectedServers(checked);
|
|
|
|
}
|
|
|
|
}, [checked]);
|
|
|
|
|
|
|
|
return (
|
2024-06-06 06:43:12 -05:00
|
|
|
<StyledDiv>
|
2022-01-04 00:57:17 -06:00
|
|
|
<CheckboxTree
|
|
|
|
nodes={treeData}
|
|
|
|
checked={checked}
|
|
|
|
expanded={expanded}
|
2022-01-21 07:23:48 -06:00
|
|
|
onCheck={checkedVal => setChecked(checkedVal)}
|
|
|
|
onExpand={expandedVal => setExpanded(expandedVal)}
|
2022-01-04 00:57:17 -06:00
|
|
|
showNodeIcon={false}
|
|
|
|
icons={{
|
2024-06-06 06:43:12 -05:00
|
|
|
check: <CheckBoxIcon className='CheckBoxTree-checked'/>,
|
|
|
|
uncheck: <CheckBoxOutlineBlankIcon className='CheckBoxTree-unchecked'/>,
|
|
|
|
halfCheck: <IndeterminateCheckBoxIcon className='CheckBoxTree-checked'/>,
|
2022-01-04 00:57:17 -06:00
|
|
|
expandClose: <ChevronRightIcon />,
|
|
|
|
expandOpen: <ExpandMoreIcon />,
|
|
|
|
leaf: <ChevronRightIcon />
|
|
|
|
}}
|
|
|
|
/>
|
2024-06-06 06:43:12 -05:00
|
|
|
</StyledDiv>
|
2022-01-04 00:57:17 -06:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
CheckBoxTree.propTypes = {
|
|
|
|
treeData: PropTypes.array,
|
|
|
|
getSelectedServers: PropTypes.func
|
|
|
|
};
|