X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/c57c9f8553e59144b4adeafc90ce2fa2ac946962..31a15158b7598ecfa0f8311d4d7ddce1c6287fcc:/src/views-components/snackbar/snackbar.tsx diff --git a/src/views-components/snackbar/snackbar.tsx b/src/views-components/snackbar/snackbar.tsx index c5d0f483..2d077cf7 100644 --- a/src/views-components/snackbar/snackbar.tsx +++ b/src/views-components/snackbar/snackbar.tsx @@ -2,34 +2,32 @@ // // 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 { snackbarActions, SnackbarKind } from "~/store/snackbar/snackbar-actions"; -import { navigateTo } from '~/store/navigation/navigation-action'; +import { snackbarActions, SnackbarKind, SnackbarMessage } 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 { 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; autoHideDuration?: number; open: boolean; - message?: React.ReactElement; - kind: SnackbarKind; - link?: string; + messages: SnackbarMessage[]; } interface SnackbarEventProps { - onClose?: (event: React.SyntheticEvent, reason: string) => void; + onClose?: (event: React.SyntheticEvent, reason: string, message?: string) => void; onExited: () => void; onClick: (uuid: string) => void; } @@ -39,17 +37,15 @@ const mapStateToProps = (state: RootState): SnackbarDataProps => { return { anchorOrigin: { vertical: "bottom", horizontal: "right" }, 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, - link: messages.length > 0 ? messages[0].link : '' + messages, + autoHideDuration: messages.length > 0 ? messages[0].hideDuration : 0 }; }; const mapDispatchToProps = (dispatch: Dispatch): SnackbarEventProps => ({ - onClose: (event: any, reason: string) => { + onClose: (event: any, reason: string, id: undefined) => { if (reason !== "clickaway") { - dispatch(snackbarActions.CLOSE_SNACKBAR()); + dispatch(snackbarActions.CLOSE_SNACKBAR(id)); } }, onExited: () => { @@ -60,7 +56,7 @@ const mapDispatchToProps = (dispatch: Dispatch): SnackbarEventProps => ({ } }); -type CssRules = "success" | "error" | "info" | "warning" | "icon" | "iconVariant" | "message" | "linkButton"; +type CssRules = "success" | "error" | "info" | "warning" | "icon" | "iconVariant" | "message" | "linkButton" | "snackbarContent"; const styles: StyleRulesCallback = (theme: ArvadosTheme) => ({ success: { @@ -88,6 +84,9 @@ const styles: StyleRulesCallback = (theme: ArvadosTheme) => ({ }, linkButton: { fontWeight: 'bolder' + }, + snackbarContent: { + marginBottom: '1rem' } }); @@ -104,54 +103,57 @@ export const Snackbar = withStyles(styles)(connect(mapStateToProps, mapDispatchT [SnackbarKind.ERROR]: [ErrorIcon, classes.error] }; - const [Icon, cssClass] = variants[props.kind]; - - - return ( - - - {props.message} - +
+ { + props.messages.map((message, index) => { + const [Icon, cssClass] = variants[message.kind]; + + return + + {message.message} + + } + action={actions(message, props.onClick, props.onClose, classes, index, props.autoHideDuration)} + /> + }) } - action={actions(props)} - /> +
); } )); -const actions = (props: SnackbarProps) => { - const { link, onClose, onClick, classes } = props; +const actions = (props: SnackbarMessage, onClick, onClose, classes, index, autoHideDuration) => { const actions = [ onClose && onClose(e, '')}> + onClick={e => onClose && onClose(e, '', index)}> ]; - if (link) { + if (props.link) { actions.splice(0, 0, ); }