48 lines
1.3 KiB
JavaScript
48 lines
1.3 KiB
JavaScript
import React from 'react';
|
|
import ClassNames from 'classnames';
|
|
import Button from '../button';
|
|
import FontIcon from '../font_icon';
|
|
import Overlay from '../overlay';
|
|
import style from './style';
|
|
|
|
class Snackbar extends React.Component {
|
|
static propTypes = {
|
|
action: React.PropTypes.string,
|
|
active: React.PropTypes.bool,
|
|
className: React.PropTypes.string,
|
|
icon: React.PropTypes.string,
|
|
label: React.PropTypes.string.isRequired,
|
|
onClick: React.PropTypes.func,
|
|
onTimeout: React.PropTypes.func,
|
|
timeout: React.PropTypes.number,
|
|
type: React.PropTypes.string
|
|
};
|
|
|
|
componentDidUpdate () {
|
|
if (this.props.active && this.props.timeout) {
|
|
setTimeout(() => {
|
|
this.props.onTimeout();
|
|
}, this.props.timeout);
|
|
}
|
|
}
|
|
|
|
render () {
|
|
const {action, active, icon, label, onClick, type } = this.props;
|
|
const className = ClassNames([style.root, style[type]], {
|
|
[style.active]: active
|
|
}, this.props.className);
|
|
|
|
return (
|
|
<Overlay invisible>
|
|
<div data-react-toolbox='snackbar' className={className}>
|
|
{icon ? <FontIcon value={icon} className={style.icon} /> : null}
|
|
<span className={style.label}>{label}</span>
|
|
{action ? <Button className={style.button} label={action} onClick={onClick}/> : null}
|
|
</div>
|
|
</Overlay>
|
|
);
|
|
}
|
|
}
|
|
|
|
export default Snackbar;
|