X-Git-Url: https://git.arvados.org/arvados-workbench2.git/blobdiff_plain/d7c9755621d7d6f6c57810fc9fe04c8dc65b640e..48adcab305593e4e869c2f622b00a1f794d55c50:/src/views-components/snackbar/snackbar.tsx diff --git a/src/views-components/snackbar/snackbar.tsx b/src/views-components/snackbar/snackbar.tsx index 037f564a..1887f0bd 100644 --- a/src/views-components/snackbar/snackbar.tsx +++ b/src/views-components/snackbar/snackbar.tsx @@ -27,7 +27,7 @@ interface SnackbarDataProps { } interface SnackbarEventProps { - onClose?: (event: React.SyntheticEvent, reason: string) => void; + onClose?: (event: React.SyntheticEvent, reason: string, message?: string) => void; onExited: () => void; onClick: (uuid: string) => void; } @@ -43,9 +43,9 @@ const mapStateToProps = (state: RootState): SnackbarDataProps => { }; 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: () => { @@ -112,10 +112,11 @@ export const Snackbar = withStyles(styles)(connect(mapStateToProps, mapDispatchT autoHideDuration={props.autoHideDuration}>
{ - props.messages.map(message => { + props.messages.map((message, index) => { const [Icon, cssClass] = variants[message.kind]; return } - action={actions(message, props.onClick, props.onClose, classes)} + action={actions(message, props.onClick, props.onClose, classes, index, props.autoHideDuration)} /> }) } @@ -134,13 +135,17 @@ export const Snackbar = withStyles(styles)(connect(mapStateToProps, mapDispatchT } )); -const actions = (props: SnackbarMessage, onClick, onClose, classes) => { +const actions = (props: SnackbarMessage, onClick, onClose, classes, index, autoHideDuration) => { + if (onClose && autoHideDuration) { + setTimeout(onClose, autoHideDuration); + } + const actions = [ onClose && onClose(e, '')}> + onClick={e => onClose && onClose(e, '', index)}> ];