Add aria-labels
[ccsdk/features.git] / sdnr / wt / odlux / apps / connectApp / src / components / connectionStatusLog.tsx
1 /**
2  * ============LICENSE_START========================================================================
3  * ONAP : ccsdk feature sdnr wt odlux
4  * =================================================================================================
5  * Copyright (C) 2019 highstreet technologies GmbH Intellectual Property. All rights reserved.
6  * =================================================================================================
7  * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except
8  * in compliance with the License. You may obtain a copy of the License at
9  *
10  * http://www.apache.org/licenses/LICENSE-2.0
11  *
12  * Unless required by applicable law or agreed to in writing, software distributed under the License
13  * is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express
14  * or implied. See the License for the specific language governing permissions and limitations under
15  * the License.
16  * ============LICENSE_END==========================================================================
17  */
18 import * as React from 'react';
19 import connect, { IDispatcher, Connect } from '../../../../framework/src/flux/connect';
20 import { IApplicationStoreState } from '../../../../framework/src/store/applicationStore';
21 import { MaterialTable, ColumnType, MaterialTableCtorType } from '../../../../framework/src/components/material-table';
22
23 import { createConnectionStatusLogActions, createConnectionStatusLogProperties } from '../handlers/connectionStatusLogHandler';
24 import { NetworkElementConnectionLog } from '../models/networkElementConnectionLog';
25
26 const mapProps = (state: IApplicationStoreState) => ({
27   connectionStatusLogProperties: createConnectionStatusLogProperties(state),
28 });
29
30 const mapDispatch = (dispatcher: IDispatcher) => ({
31   connectionStatusLogActions: createConnectionStatusLogActions(dispatcher.dispatch),
32 });
33
34 const ConnectionStatusTable = MaterialTable as MaterialTableCtorType<NetworkElementConnectionLog>;
35
36 type ConnectionStatusLogComponentProps = Connect<typeof mapProps, typeof mapDispatch>;
37
38 let initialSorted = false;
39
40
41 class ConnectionStatusLogComponent extends React.Component<ConnectionStatusLogComponentProps> {
42   render(): JSX.Element {
43     return (
44       <ConnectionStatusTable stickyHeader tableId="connection-status-table" columns={[
45         { property: "timestamp", title: "Timestamp", type: ColumnType.text },
46         { property: "nodeId", title: "Node Name", type: ColumnType.text },
47         { property: "status", title: "Connection Status", type: ColumnType.text },
48       ]} idProperty="id" {...this.props.connectionStatusLogActions} {...this.props.connectionStatusLogProperties} >
49       </ConnectionStatusTable>
50     );
51   };
52
53   componentDidMount() {
54     if (!initialSorted) {
55       initialSorted = true;
56       this.props.connectionStatusLogActions.onHandleExplicitRequestSort("timestamp", "desc");
57     } else {
58       this.props.connectionStatusLogActions.onRefresh();
59     }
60   }
61 }
62
63 export const ConnectionStatusLog = connect(mapProps, mapDispatch)(ConnectionStatusLogComponent);
64 export default ConnectionStatusLog;