aboutsummaryrefslogtreecommitdiff
path: root/src/components/ModalScreen/ModalScreen.tsx
diff options
context:
space:
mode:
authoreug-vs <eug-vs@keemail.me>2020-10-08 20:21:35 +0300
committereug-vs <eug-vs@keemail.me>2020-10-08 20:21:35 +0300
commitfd7e4817cd0e0160e85ad98ad81f406c66a94800 (patch)
tree4acabe508c38ff7f56c48fd70543fdebb3ffa976 /src/components/ModalScreen/ModalScreen.tsx
parent40cc9f63feb15e1bb14c5360b4437d3379df96e2 (diff)
downloadwhich-ui-fd7e4817cd0e0160e85ad98ad81f406c66a94800.tar.gz
feat: correctly wire modal logic
Diffstat (limited to 'src/components/ModalScreen/ModalScreen.tsx')
-rw-r--r--src/components/ModalScreen/ModalScreen.tsx19
1 files changed, 12 insertions, 7 deletions
diff --git a/src/components/ModalScreen/ModalScreen.tsx b/src/components/ModalScreen/ModalScreen.tsx
index 7090980..6c514cd 100644
--- a/src/components/ModalScreen/ModalScreen.tsx
+++ b/src/components/ModalScreen/ModalScreen.tsx
@@ -17,7 +17,9 @@ import CloseIcon from '@material-ui/icons/Close';
interface PropTypes {
title: string;
- rightIcon?: JSX.Element;
+ actionIcon?: JSX.Element;
+ handleAction?: () => void;
+ isActionDisabled?: boolean;
}
const useStyles = makeStyles(theme => ({
@@ -38,7 +40,7 @@ const Transition = React.forwardRef((
ref: React.Ref<unknown>
) => <Slide direction="left" ref={ref} {...props} />);
-const ModalScreen: React.FC<PropTypes> = ({ title, rightIcon, children }) => {
+const ModalScreen: React.FC<PropTypes> = ({ title, actionIcon, handleAction, isActionDisabled, children }) => {
const [isOpen, setIsOpen] = useState<boolean>(true);
const classes = useStyles();
const theme = useTheme();
@@ -48,6 +50,11 @@ const ModalScreen: React.FC<PropTypes> = ({ title, rightIcon, children }) => {
const handleClose = useCallback(() => setIsOpen(false), [setIsOpen]);
const onExited = useCallback(() => history.goBack(), [history]);
+ const handleClickAction = useCallback(async () => {
+ if (handleAction) await handleAction();
+ return handleClose();
+ }, [handleAction, handleClose]);
+
return (
<Dialog
open={isOpen}
@@ -66,11 +73,9 @@ const ModalScreen: React.FC<PropTypes> = ({ title, rightIcon, children }) => {
<Typography variant="h6">
{ title }
</Typography>
- { rightIcon || (
- <IconButton style={{ visibility: 'hidden' }}>
- <CloseIcon />
- </IconButton>
- )}
+ <IconButton onClick={handleClickAction} disabled={isActionDisabled}>
+ { actionIcon }
+ </IconButton>
</Toolbar>
</AppBar>
<Divider />