X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/afa04ca15bcaa890770a30ddb099b62f5cbe2926..17dfef9d2440ddbac9cd8eac0ec8be721b42cc09:/src/views-components/snackbar/snackbar.tsx diff --git a/src/views-components/snackbar/snackbar.tsx b/src/views-components/snackbar/snackbar.tsx index 59dddcaf..2a63a31a 100644 --- a/src/views-components/snackbar/snackbar.tsx +++ b/src/views-components/snackbar/snackbar.tsx @@ -2,23 +2,22 @@ // // SPDX-License-Identifier: AGPL-3.0 -import * as React from "react"; +import React from "react"; +import { Dispatch } from "redux"; import { connect } from "react-redux"; -import { RootState } from "~/store/store"; +import { RootState } from "store/store"; +import { Button, IconButton, StyleRulesCallback, WithStyles, withStyles, SnackbarContent } from '@material-ui/core'; 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'; -import SnackbarContent from '@material-ui/core/SnackbarContent'; +import { snackbarActions, SnackbarKind } from "store/snackbar/snackbar-actions"; +import { navigateTo } from 'store/navigation/navigation-action'; import WarningIcon from '@material-ui/icons/Warning'; import CheckCircleIcon from '@material-ui/icons/CheckCircle'; import ErrorIcon from '@material-ui/icons/Error'; import InfoIcon from '@material-ui/icons/Info'; import CloseIcon from '@material-ui/icons/Close'; -import { StyleRulesCallback, WithStyles, withStyles } from '@material-ui/core/styles'; -import { ArvadosTheme } from "~/common/custom-theme"; +import { ArvadosTheme } from "common/custom-theme"; import { amber, green } from "@material-ui/core/colors"; -import * as classNames from 'classnames'; +import classNames from 'classnames'; interface SnackbarDataProps { anchorOrigin?: SnackbarOrigin; @@ -26,11 +25,13 @@ interface SnackbarDataProps { open: boolean; message?: React.ReactElement; kind: SnackbarKind; + link?: string; } interface SnackbarEventProps { onClose?: (event: React.SyntheticEvent, reason: string) => void; onExited: () => void; + onClick: (uuid: string) => void; } const mapStateToProps = (state: RootState): SnackbarDataProps => { @@ -40,7 +41,8 @@ const mapStateToProps = (state: RootState): SnackbarDataProps => { open: state.snackbar.open, message: {messages.length > 0 ? messages[0].message : ""}, autoHideDuration: messages.length > 0 ? messages[0].hideDuration : 0, - kind: messages.length > 0 ? messages[0].kind : SnackbarKind.INFO + kind: messages.length > 0 ? messages[0].kind : SnackbarKind.INFO, + link: messages.length > 0 ? messages[0].link : '' }; }; @@ -52,10 +54,13 @@ const mapDispatchToProps = (dispatch: Dispatch): SnackbarEventProps => ({ }, onExited: () => { dispatch(snackbarActions.SHIFT_MESSAGES()); + }, + onClick: (uuid: string) => { + dispatch(navigateTo(uuid)); } }); -type CssRules = "success" | "error" | "info" | "warning" | "icon" | "iconVariant" | "message"; +type CssRules = "success" | "error" | "info" | "warning" | "icon" | "iconVariant" | "message" | "linkButton"; const styles: StyleRulesCallback = (theme: ArvadosTheme) => ({ success: { @@ -65,7 +70,7 @@ const styles: StyleRulesCallback = (theme: ArvadosTheme) => ({ backgroundColor: theme.palette.error.dark }, info: { - backgroundColor: theme.palette.primary.dark + backgroundColor: theme.palette.primary.main }, warning: { backgroundColor: amber[700] @@ -81,48 +86,74 @@ const styles: StyleRulesCallback = (theme: ArvadosTheme) => ({ display: 'flex', alignItems: 'center' }, + linkButton: { + fontWeight: 'bolder' + } }); -const ArvadosSnackbar = (props: SnackbarDataProps & SnackbarEventProps & WithStyles) => { - const { classes } = props; +type SnackbarProps = SnackbarDataProps & SnackbarEventProps & WithStyles; - const variants = { - [SnackbarKind.INFO]: [InfoIcon, classes.info], - [SnackbarKind.WARNING]: [WarningIcon, classes.warning], - [SnackbarKind.SUCCESS]: [CheckCircleIcon, classes.success], - [SnackbarKind.ERROR]: [ErrorIcon, classes.error] - }; +export const Snackbar = withStyles(styles)(connect(mapStateToProps, mapDispatchToProps)( + (props: SnackbarProps) => { + const { classes } = props; - const [Icon, cssClass] = variants[props.kind]; + const variants = { + [SnackbarKind.INFO]: [InfoIcon, classes.info], + [SnackbarKind.WARNING]: [WarningIcon, classes.warning], + [SnackbarKind.SUCCESS]: [CheckCircleIcon, classes.success], + [SnackbarKind.ERROR]: [ErrorIcon, classes.error] + }; - return ( - - - - {props.message} - - } - action={ - props.onClose && props.onClose(e, '')}> - - - } - /> - - ); -}; + const [Icon, cssClass] = variants[props.kind]; -export const Snackbar = withStyles(styles)(connect(mapStateToProps, mapDispatchToProps)(ArvadosSnackbar)); + + + return ( + + + + {props.message} + + } + action={actions(props)} + /> + + ); + } +)); + +const actions = (props: SnackbarProps) => { + const { link, onClose, onClick, classes } = props; + const actions = [ + onClose && onClose(e, '')}> + + + ]; + if (link) { + actions.splice(0, 0, + + ); + } + return actions; +};