mirror of
https://github.com/mattermost/mattermost.git
synced 2025-02-25 18:55:24 -06:00
123 lines
3.4 KiB
JavaScript
123 lines
3.4 KiB
JavaScript
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
|
// See License.txt for license information.
|
|
|
|
import AdminStore from 'stores/admin_store.jsx';
|
|
import LoadingScreen from '../loading_screen.jsx';
|
|
import * as AsyncClient from 'utils/async_client.jsx';
|
|
|
|
import {FormattedMessage} from 'react-intl';
|
|
|
|
import React from 'react';
|
|
|
|
export default class Logs extends React.Component {
|
|
constructor(props) {
|
|
super(props);
|
|
|
|
this.onLogListenerChange = this.onLogListenerChange.bind(this);
|
|
this.reload = this.reload.bind(this);
|
|
|
|
this.state = {
|
|
logs: AdminStore.getLogs()
|
|
};
|
|
}
|
|
|
|
componentDidMount() {
|
|
AdminStore.addLogChangeListener(this.onLogListenerChange);
|
|
AsyncClient.getLogs();
|
|
this.refs.logPanel.focus();
|
|
}
|
|
|
|
componentDidUpdate() {
|
|
// Scroll Down to get the latest logs
|
|
var node = this.refs.logPanel;
|
|
node.scrollTop = node.scrollHeight;
|
|
node.focus();
|
|
}
|
|
|
|
componentWillUnmount() {
|
|
AdminStore.removeLogChangeListener(this.onLogListenerChange);
|
|
}
|
|
|
|
onLogListenerChange() {
|
|
this.setState({
|
|
logs: AdminStore.getLogs()
|
|
});
|
|
}
|
|
|
|
reload() {
|
|
AdminStore.saveLogs(null);
|
|
this.setState({
|
|
logs: null
|
|
});
|
|
|
|
AsyncClient.getLogs();
|
|
}
|
|
|
|
render() {
|
|
var content = null;
|
|
|
|
if (this.state.logs === null) {
|
|
content = <LoadingScreen/>;
|
|
} else {
|
|
content = [];
|
|
|
|
for (var i = 0; i < this.state.logs.length; i++) {
|
|
var style = {
|
|
whiteSpace: 'nowrap',
|
|
fontFamily: 'monospace'
|
|
};
|
|
|
|
if (this.state.logs[i].indexOf('[EROR]') > 0) {
|
|
style.color = 'red';
|
|
}
|
|
|
|
content.push(<br key={'br_' + i}/>);
|
|
content.push(
|
|
<span
|
|
key={'log_' + i}
|
|
style={style}
|
|
>
|
|
{this.state.logs[i]}
|
|
</span>
|
|
);
|
|
}
|
|
}
|
|
|
|
return (
|
|
<div className='panel'>
|
|
<h3 className='admin-console-header'>
|
|
<FormattedMessage
|
|
id='admin.logs.title'
|
|
defaultMessage='Server Logs'
|
|
/>
|
|
</h3>
|
|
<div className='banner'>
|
|
<div className='banner__content'>
|
|
<FormattedMessage
|
|
id='admin.logs.bannerDesc'
|
|
defaultMessage='To look up users by User ID, go to Reporting > Users and paste the ID into the search filter.'
|
|
/>
|
|
</div>
|
|
</div>
|
|
<button
|
|
type='submit'
|
|
className='btn btn-primary'
|
|
onClick={this.reload}
|
|
>
|
|
<FormattedMessage
|
|
id='admin.logs.reload'
|
|
defaultMessage='Reload'
|
|
/>
|
|
</button>
|
|
<div
|
|
tabIndex='-1'
|
|
ref='logPanel'
|
|
className='log__panel'
|
|
>
|
|
{content}
|
|
</div>
|
|
</div>
|
|
);
|
|
}
|
|
}
|