forked from p15670423/monkey
UI: Refactor Telemetry page
This commit is contained in:
parent
c3fb5ae441
commit
99c0288886
|
@ -1,58 +1,24 @@
|
||||||
import React from 'react';
|
import React from 'react';
|
||||||
import {Button, Col} from 'react-bootstrap';
|
import {Button, Col} from 'react-bootstrap';
|
||||||
import JSONTree from 'react-json-tree';
|
import AuthService from '../../services/AuthService';
|
||||||
import MUIDataTable from 'mui-datatables';
|
|
||||||
import AuthComponent from '../AuthComponent';
|
|
||||||
import download from 'downloadjs';
|
import download from 'downloadjs';
|
||||||
|
import TelemetryLogTable from '../ui-components/TelemetryLogTable'
|
||||||
import {FontAwesomeIcon} from '@fortawesome/react-fontawesome';
|
import {FontAwesomeIcon} from '@fortawesome/react-fontawesome';
|
||||||
|
|
||||||
import '../../styles/pages/TelemetryPage.scss';
|
import '../../styles/pages/TelemetryPage.scss';
|
||||||
import {faDownload} from '@fortawesome/free-solid-svg-icons/faDownload';
|
import {faDownload} from '@fortawesome/free-solid-svg-icons/faDownload';
|
||||||
|
|
||||||
const renderJson = (val) => <JSONTree data={val} level={1} theme="eighties" invertTheme={true}/>;
|
|
||||||
const renderTime = (val) => val.split('.')[0];
|
|
||||||
|
|
||||||
const columns = [
|
class TelemetryPageComponent extends React.Component {
|
||||||
{label: 'Time', name: 'timestamp'},
|
|
||||||
{label: 'Monkey', name: 'monkey'},
|
|
||||||
{label: 'Type', name: 'telem_category'},
|
|
||||||
{label: 'Details', name: 'data', options: { setCellProps: () => ({ style: { width: '40%' }})}}
|
|
||||||
];
|
|
||||||
|
|
||||||
const table_options = {
|
|
||||||
filterType: 'textField',
|
|
||||||
sortOrder: {
|
|
||||||
name: 'timestamp',
|
|
||||||
direction: 'desc'
|
|
||||||
},
|
|
||||||
print: false,
|
|
||||||
download: false,
|
|
||||||
rowHover: false,
|
|
||||||
rowsPerPage: 20,
|
|
||||||
rowsPerPageOptions: [20, 50, 100],
|
|
||||||
selectableRows: 'none'
|
|
||||||
};
|
|
||||||
|
|
||||||
class TelemetryPageComponent extends AuthComponent {
|
|
||||||
constructor(props) {
|
constructor(props) {
|
||||||
super(props);
|
super(props);
|
||||||
|
this.auth = new AuthService();
|
||||||
|
this.authFetch = this.auth.authFetch;
|
||||||
this.state = {
|
this.state = {
|
||||||
data: [],
|
data: []
|
||||||
isFetching: false
|
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
componentDidMount = () => {
|
|
||||||
this.authFetch('/api/telemetry')
|
|
||||||
.then(res => res.json())
|
|
||||||
.then(res => {this.setState({data: res.objects})
|
|
||||||
})
|
|
||||||
.catch(e => {
|
|
||||||
console.log(e);
|
|
||||||
this.setState({...this.state});
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
downloadIslandLog = () => {
|
downloadIslandLog = () => {
|
||||||
this.authFetch('/api/log/island/download')
|
this.authFetch('/api/log/island/download')
|
||||||
.then(res => res.json())
|
.then(res => res.json())
|
||||||
|
@ -70,21 +36,7 @@ class TelemetryPageComponent extends AuthComponent {
|
||||||
className={'main'}>
|
className={'main'}>
|
||||||
<div>
|
<div>
|
||||||
<h1 className="page-title">Logs</h1>
|
<h1 className="page-title">Logs</h1>
|
||||||
<div className="data-table-container">
|
<TelemetryLogTable/>
|
||||||
<MUIDataTable
|
|
||||||
columns={columns}
|
|
||||||
data={this.state.data.map(item => {
|
|
||||||
return [
|
|
||||||
renderTime(item.timestamp),
|
|
||||||
item.monkey,
|
|
||||||
item.telem_category,
|
|
||||||
renderJson(item.data)
|
|
||||||
]
|
|
||||||
})
|
|
||||||
}
|
|
||||||
options={table_options}
|
|
||||||
/>
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
<div>
|
<div>
|
||||||
<h1 className="page-title"> Monkey Island Logs </h1>
|
<h1 className="page-title"> Monkey Island Logs </h1>
|
||||||
|
|
|
@ -0,0 +1,75 @@
|
||||||
|
import React from 'react';
|
||||||
|
import JSONTree from 'react-json-tree';
|
||||||
|
import MUIDataTable from 'mui-datatables';
|
||||||
|
import AuthService from '../../services/AuthService';
|
||||||
|
import '../../styles/pages/TelemetryPage.scss';
|
||||||
|
|
||||||
|
const renderJson = (val) => <JSONTree data={val} level={1} theme="eighties" invertTheme={true}/>;
|
||||||
|
const renderTime = (val) => val.split('.')[0];
|
||||||
|
|
||||||
|
const columns = [
|
||||||
|
{label: 'Time', name: 'timestamp'},
|
||||||
|
{label: 'Monkey', name: 'monkey'},
|
||||||
|
{label: 'Type', name: 'telem_category'},
|
||||||
|
{label: 'Details',
|
||||||
|
name: 'data',
|
||||||
|
options: {
|
||||||
|
setCellProps: () => ({ style: { width: '40%' }}),
|
||||||
|
filter:false,
|
||||||
|
sort:false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
];
|
||||||
|
|
||||||
|
const table_options = {
|
||||||
|
filterType: 'textField',
|
||||||
|
sortOrder: {
|
||||||
|
name: 'timestamp',
|
||||||
|
direction: 'desc'
|
||||||
|
},
|
||||||
|
print: false,
|
||||||
|
download: false,
|
||||||
|
rowHover: false,
|
||||||
|
rowsPerPageOptions: [10, 20, 50, 100],
|
||||||
|
selectableRows: 'none'
|
||||||
|
};
|
||||||
|
|
||||||
|
class TelemetryLogTable extends React.Component {
|
||||||
|
constructor(props) {
|
||||||
|
super(props);
|
||||||
|
this.auth = new AuthService();
|
||||||
|
this.authFetch = this.auth.authFetch;
|
||||||
|
this.state = {
|
||||||
|
data: []
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
componentDidMount = () => {
|
||||||
|
this.authFetch('/api/telemetry')
|
||||||
|
.then(res => res.json())
|
||||||
|
.then(res => {this.setState({data: res.objects})
|
||||||
|
})
|
||||||
|
};
|
||||||
|
|
||||||
|
render() {
|
||||||
|
return (
|
||||||
|
<>
|
||||||
|
<div className="data-table-container">
|
||||||
|
<MUIDataTable
|
||||||
|
columns={columns}
|
||||||
|
data={this.state.data.map(item => {
|
||||||
|
return [
|
||||||
|
renderTime(item.timestamp),
|
||||||
|
item.monkey,
|
||||||
|
item.telem_category,
|
||||||
|
renderJson(item.data)
|
||||||
|
]})}
|
||||||
|
options={table_options}
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
|
</>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export default TelemetryLogTable;
|
Loading…
Reference in New Issue