1 import * as React from 'react';
3 import { withRouter, RouteComponentProps } from 'react-router-dom';
5 import { MaterialTable, ColumnType, ColumnModel, MaterialTableCtorType } from '../../../../framework/src/components/material-table';
6 import { IApplicationStoreState } from '../../../../framework/src/store/applicationStore';
7 import connect, { Connect, IDispatcher } from '../../../../framework/src/flux/connect';
8 import { PerformanceDataType } from '../models/performanceDataType';
9 import { IDataSet, IDataSetsObject } from '../models/chartTypes';
10 import { createPerformanceData15minProperties, createPerformanceData15minActions } from '../handlers/performanceData15minHandler';
11 import { createPerformanceData24hoursProperties, createPerformanceData24hoursActions } from '../handlers/performanceData24hoursHandler';
12 import { lineChart, sortDataByTimeStamp } from '../utils/chartUtils';
13 import { addColumnLabels } from '../utils/tableUtils';
15 const mapProps = (state: IApplicationStoreState) => ({
16 performanceData15minProperties: createPerformanceData15minProperties(state),
17 performanceData24hoursProperties: createPerformanceData24hoursProperties(state)
20 const mapDisp = (dispatcher: IDispatcher) => ({
21 performanceData15minActions: createPerformanceData15minActions(dispatcher.dispatch),
22 performanceData24hoursActions: createPerformanceData24hoursActions(dispatcher.dispatch)
25 type PerformanceDataComponentProps = RouteComponentProps & Connect<typeof mapProps, typeof mapDisp> & {
26 selectedTimePeriod: string
29 const PerformanceDataTable = MaterialTable as MaterialTableCtorType<PerformanceDataType>;
32 * The Component which gets the performance data from the database based on the selected time period.
34 class PerformanceDataComponent extends React.Component<PerformanceDataComponentProps>{
35 render(): JSX.Element {
36 const properties = this.props.selectedTimePeriod === "15min"
37 ? this.props.performanceData15minProperties
38 : this.props.performanceData24hoursProperties;
39 const actions = this.props.selectedTimePeriod === "15min"
40 ? this.props.performanceData15minActions
41 : this.props.performanceData24hoursActions;
43 const chartPagedData = this.getChartDataValues(properties.rows);
44 const performanceColumns: ColumnModel<PerformanceDataType>[] = [
45 { property: "radio-signal-id", title: "Radio signal", type: ColumnType.text },
46 { property: "scanner-id", title: "Scanner ID", type: ColumnType.text },
47 { property: "time-stamp", title: "End Time", type: ColumnType.text, disableFilter: true },
49 property: "suspect-interval-flag", title: "Suspect Interval", type: ColumnType.custom, customControl: ({ rowData }) => {
50 const suspectIntervalFlag = rowData["suspect-interval-flag"].toString();
51 return <div >{suspectIntervalFlag} </div>
56 chartPagedData.datasets.forEach(ds => {
57 performanceColumns.push(addColumnLabels<PerformanceDataType>(ds.name, ds.columnLabel));
61 {lineChart(chartPagedData)}
62 <PerformanceDataTable idProperty={"_id"} columns={performanceColumns} {...properties} {...actions} />
68 * This function gets the performance values for PerformanceData according on the chartjs dataset structure
69 * which is to be sent to the chart.
71 private getChartDataValues = (rows: PerformanceDataType[]): IDataSetsObject => {
72 const _rows = [...rows];
73 sortDataByTimeStamp(_rows);
75 const datasets: IDataSet[] = [{
78 borderColor: '#0e17f3de',
87 borderColor: '#08edb6de',
94 name: "unavailability",
95 label: "unavailability",
96 borderColor: '#b308edde',
101 columnLabel: "Unavailability"
104 _rows.forEach(row => {
105 datasets.forEach(ds => {
107 x: row["time-stamp"],
108 y: row[ds.name as keyof PerformanceDataType] as string
118 const PerformanceData = withRouter(connect(mapProps, mapDisp)(PerformanceDataComponent));
119 export default PerformanceData;