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
10 * http://www.apache.org/licenses/LICENSE-2.0
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
16 * ============LICENSE_END==========================================================================
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';
23 import { createConnectionStatusLogActions, createConnectionStatusLogProperties } from '../handlers/connectionStatusLogHandler';
24 import { NetworkElementConnectionLog } from '../models/networkElementConnectionLog';
26 const mapProps = (state: IApplicationStoreState) => ({
27 connectionStatusLogProperties: createConnectionStatusLogProperties(state),
30 const mapDispatch = (dispatcher: IDispatcher) => ({
31 connectionStatusLogActions: createConnectionStatusLogActions(dispatcher.dispatch),
34 const ConnectionStatusTable = MaterialTable as MaterialTableCtorType<NetworkElementConnectionLog>;
36 type ConnectionStatusLogComponentProps = Connect<typeof mapProps, typeof mapDispatch>;
38 let initialSorted = false;
41 class ConnectionStatusLogComponent extends React.Component<ConnectionStatusLogComponentProps> {
42 render(): JSX.Element {
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>
56 this.props.connectionStatusLogActions.onHandleExplicitRequestSort("timestamp", "desc");
58 this.props.connectionStatusLogActions.onRefresh();
63 export const ConnectionStatusLog = connect(mapProps, mapDispatch)(ConnectionStatusLogComponent);
64 export default ConnectionStatusLog;