hyper/lib/components/notification.js

116 lines
3 KiB
JavaScript
Raw Normal View History

2016-07-13 12:44:24 -08:00
import React from 'react';
export default class Notification extends React.PureComponent {
constructor() {
2016-07-13 12:44:24 -08:00
super();
this.state = {
dismissing: false
};
this.handleDismiss = this.handleDismiss.bind(this);
2016-07-13 12:44:24 -08:00
this.onElement = this.onElement.bind(this);
}
componentDidMount() {
2016-07-13 12:44:24 -08:00
if (this.props.dismissAfter) {
this.setDismissTimer();
}
}
componentWillReceiveProps(next) {
2016-07-13 12:44:24 -08:00
// if we have a timer going and the notification text
2016-07-17 13:05:37 -08:00
// changed we reset the timer
2016-07-13 12:44:24 -08:00
if (next.text !== this.props.text) {
if (this.props.dismissAfter) {
this.resetDismissTimer();
}
if (this.state.dismissing) {
this.setState({dismissing: false});
2016-07-13 12:44:24 -08:00
}
}
}
handleDismiss() {
this.setState({dismissing: true});
2016-07-13 12:44:24 -08:00
}
onElement(el) {
2016-07-13 12:44:24 -08:00
if (el) {
el.addEventListener('webkitTransitionEnd', () => {
if (this.state.dismissing) {
this.props.onDismiss();
}
});
const {backgroundColor} = this.props;
2016-07-13 12:44:24 -08:00
if (backgroundColor) {
el.style.setProperty('background-color', backgroundColor, 'important');
2016-07-13 12:44:24 -08:00
}
}
}
setDismissTimer() {
2016-07-13 12:44:24 -08:00
this.dismissTimer = setTimeout(() => {
this.handleDismiss();
2016-07-13 12:44:24 -08:00
}, this.props.dismissAfter);
}
resetDismissTimer() {
2016-07-13 12:44:24 -08:00
clearTimeout(this.dismissTimer);
this.setDismissTimer();
}
componentWillUnmount() {
2016-07-13 12:44:24 -08:00
clearTimeout(this.dismissTimer);
}
render() {
const {backgroundColor, color} = this.props;
2016-07-13 12:44:24 -08:00
const opacity = this.state.dismissing ? 0 : 1;
return (
<div ref={this.onElement} style={{opacity, backgroundColor, color}} className="notification_indicator">
{this.props.customChildrenBefore}
{this.props.children || this.props.text}
{this.props.userDismissable ? (
<a
className="notification_dismissLink"
onClick={this.handleDismiss}
style={{color: this.props.userDismissColor}}
>
[x]
</a>
) : null}
{this.props.customChildren}
2016-07-13 12:44:24 -08:00
<style jsx>{`
.notification_indicator {
display: inline-block;
cursor: default;
-webkit-user-select: none;
background: rgba(255, 255, 255, 0.2);
padding: 8px 14px 9px;
margin-left: 10px;
transition: 150ms opacity ease;
color: #fff;
font-size: 12px;
font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto', 'Oxygen', 'Ubuntu', 'Cantarell',
'Fira Sans', 'Droid Sans', 'Helvetica Neue', sans-serif;
}
2016-07-13 12:44:24 -08:00
.notification_dismissLink {
position: relative;
left: 4px;
cursor: pointer;
opacity: 0.5;
color: currentColor;
transition: opacity 0.1s ease-in-out;
}
.notification_dismissLink:hover,
.notification_dismissLink:focus {
opacity: 1;
}
`}</style>
</div>
);
2016-07-13 12:44:24 -08:00
}
}