Merge "YANG Model update for A1 Adapter"
[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 class ConnectionStatusLogComponent extends React.Component<ConnectionStatusLogComponentProps> {
39   render(): JSX.Element {
40     return (
41       <ConnectionStatusTable tableId="connection-status-table" columns={[
42         { property: "timestamp", title: "Time", type: ColumnType.text },
43         { property: "nodeId", title: "Node Name", type: ColumnType.text },
44         { property: "status", title: "Connection status", type: ColumnType.text },
45       ]} idProperty="id" {...this.props.connectionStatusLogActions} {...this.props.connectionStatusLogProperties} >
46       </ConnectionStatusTable>
47     );
48   };
49 }
50
51 export const ConnectionStatusLog = connect(mapProps, mapDispatch)(ConnectionStatusLogComponent);
52 export default ConnectionStatusLog;