X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/a2bf1ed3a15cf55e426c51ad8e6febd7ff2e3020..afa04ca15bcaa890770a30ddb099b62f5cbe2926:/src/views-components/snackbar/snackbar.tsx diff --git a/src/views-components/snackbar/snackbar.tsx b/src/views-components/snackbar/snackbar.tsx index 7449e1e2..59dddcaf 100644 --- a/src/views-components/snackbar/snackbar.tsx +++ b/src/views-components/snackbar/snackbar.tsx @@ -5,7 +5,7 @@ import * as React from "react"; import { connect } from "react-redux"; import { RootState } from "~/store/store"; -import MaterialSnackbar, { SnackbarProps } from "@material-ui/core/Snackbar"; +import MaterialSnackbar, { SnackbarOrigin } from "@material-ui/core/Snackbar"; import { Dispatch } from "redux"; import { snackbarActions, SnackbarKind } from "~/store/snackbar/snackbar-actions"; import IconButton from '@material-ui/core/IconButton'; @@ -20,7 +20,20 @@ import { ArvadosTheme } from "~/common/custom-theme"; import { amber, green } from "@material-ui/core/colors"; import * as classNames from 'classnames'; -const mapStateToProps = (state: RootState): SnackbarProps & ArvadosSnackbarProps => { +interface SnackbarDataProps { + anchorOrigin?: SnackbarOrigin; + autoHideDuration?: number; + open: boolean; + message?: React.ReactElement; + kind: SnackbarKind; +} + +interface SnackbarEventProps { + onClose?: (event: React.SyntheticEvent, reason: string) => void; + onExited: () => void; +} + +const mapStateToProps = (state: RootState): SnackbarDataProps => { const messages = state.snackbar.messages; return { anchorOrigin: { vertical: "bottom", horizontal: "right" }, @@ -31,7 +44,7 @@ const mapStateToProps = (state: RootState): SnackbarProps & ArvadosSnackbarProps }; }; -const mapDispatchToProps = (dispatch: Dispatch) => ({ +const mapDispatchToProps = (dispatch: Dispatch): SnackbarEventProps => ({ onClose: (event: any, reason: string) => { if (reason !== "clickaway") { dispatch(snackbarActions.CLOSE_SNACKBAR()); @@ -42,10 +55,6 @@ const mapDispatchToProps = (dispatch: Dispatch) => ({ } }); -const ArvadosSnackbar = (props: any) => - -; - type CssRules = "success" | "error" | "info" | "warning" | "icon" | "iconVariant" | "message"; const styles: StyleRulesCallback = (theme: ArvadosTheme) => ({ @@ -74,62 +83,46 @@ const styles: StyleRulesCallback = (theme: ArvadosTheme) => ({ }, }); -interface ArvadosSnackbarProps { - kind: SnackbarKind; -} - -const ArvadosSnackbarContent = (props: SnackbarProps & ArvadosSnackbarProps & WithStyles) => { - const { classes, className, message, onClose, kind } = props; +const ArvadosSnackbar = (props: SnackbarDataProps & SnackbarEventProps & WithStyles) => { + const { classes } = props; - let Icon = InfoIcon; - let cssClass = classes.info; + const variants = { + [SnackbarKind.INFO]: [InfoIcon, classes.info], + [SnackbarKind.WARNING]: [WarningIcon, classes.warning], + [SnackbarKind.SUCCESS]: [CheckCircleIcon, classes.success], + [SnackbarKind.ERROR]: [ErrorIcon, classes.error] + }; - switch (kind) { - case SnackbarKind.INFO: - Icon = InfoIcon; - cssClass = classes.info; - break; - case SnackbarKind.WARNING: - Icon = WarningIcon; - cssClass = classes.warning; - break; - case SnackbarKind.SUCCESS: - Icon = CheckCircleIcon; - cssClass = classes.success; - break; - case SnackbarKind.ERROR: - Icon = ErrorIcon; - cssClass = classes.error; - break; - } + const [Icon, cssClass] = variants[props.kind]; return ( - - - {message} - - } - action={ - { - if (onClose) { - onClose(e, ''); - } - }}> - - - } - /> + + + + {props.message} + + } + action={ + props.onClose && props.onClose(e, '')}> + + + } + /> + ); }; -export const Snackbar = connect(mapStateToProps, mapDispatchToProps)( - withStyles(styles)(ArvadosSnackbar) -); +export const Snackbar = withStyles(styles)(connect(mapStateToProps, mapDispatchToProps)(ArvadosSnackbar));