Files
mattermost/webapp/components/error_bar.jsx
Christopher Speller 4b260b761a Updating client dependancies and ESLint (#2954)
* Updating client dependancies

* Fixing eslint errors with updates

* Updating eslint
2016-05-12 07:50:53 -04:00

92 lines
2.2 KiB
JavaScript
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

// Copyright (c) 2015 Mattermost, Inc. All Rights Reserved.
// See License.txt for license information.
import ErrorStore from 'stores/error_store.jsx';
import * as Utils from 'utils/utils.jsx';
import React from 'react';
export default class ErrorBar extends React.Component {
constructor() {
super();
this.onErrorChange = this.onErrorChange.bind(this);
this.handleClose = this.handleClose.bind(this);
this.state = ErrorStore.getLastError();
}
isValidError(s) {
if (!s) {
return false;
}
if (!s.message) {
return false;
}
return true;
}
componentWillMount() {
if (!ErrorStore.getIgnoreEmailPreview() && global.window.mm_config.SendEmailNotifications === 'false') {
ErrorStore.storeLastError({email_preview: true, message: Utils.localizeMessage('error_bar.preview_mode', 'Preview Mode: Email notifications have not been configured')});
this.onErrorChange();
}
}
componentDidMount() {
ErrorStore.addChangeListener(this.onErrorChange);
}
componentWillUnmount() {
ErrorStore.removeChangeListener(this.onErrorChange);
}
onErrorChange() {
var newState = ErrorStore.getLastError();
if (newState) {
this.setState(newState);
} else {
this.setState({message: null});
}
}
handleClose(e) {
if (e) {
e.preventDefault();
}
ErrorStore.clearLastError();
this.setState({message: null});
}
render() {
if (!this.isValidError(this.state)) {
return <div/>;
}
var errClass = 'error-bar';
if (this.state.type && this.state.type === 'developer') {
errClass = 'error-bar-developer';
}
return (
<div className={errClass}>
<span>{this.state.message}</span>
<a
href='#'
className='error-bar__close'
onClick={this.handleClose}
>
{'×'}
</a>
</div>
);
}
}
export default ErrorBar;