// @flow import React from 'react'; import Button from 'component/button'; type Props = { removeSnack: any => void, snacks: { linkTarget: ?string, linkText: ?string, message: string, }, }; class SnackBar extends React.PureComponent { constructor(props: Props) { super(props); this.displayTime = 5; // in seconds this.hideTimeout = null; } render() { const { snacks, removeSnack } = this.props; if (!snacks.length) { this.hideTimeout = null; // should be unmounting anyway, but be safe? return null; } const snack = snacks[0]; const { message, linkText, linkTarget } = snack; if (this.hideTimeout === null) { this.hideTimeout = setTimeout(() => { this.hideTimeout = null; removeSnack(); }, this.displayTime * 1000); } return (
{message}
{linkText && linkTarget && (
); } } export default SnackBar;