/** * ============LICENSE_START======================================================================== * ONAP : ccsdk feature sdnr wt odlux * ================================================================================================= * Copyright (C) 2019 highstreet technologies GmbH Intellectual Property. All rights reserved. * ================================================================================================= * Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except * in compliance with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software distributed under the License * is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express * or implied. See the License for the specific language governing permissions and limitations under * the License. * ============LICENSE_END========================================================================== */ import * as React from 'react'; import connect, { IDispatcher, Connect } from '../../../../framework/src/flux/connect'; import { Panel } from '../../../../framework/src/components/material-ui'; import { requiredNetworkElementsReloadAction, createRequiredNetworkElementsActions } from '../handlers/requiredNetworkElementsHandler'; import { loadAllMountedNetworkElementsAsync } from '../actions/mountedNetworkElementsActions'; import { connectionStatusLogReloadAction, createConnectionStatusLogActions } from '../handlers/connectionStatusLogHandler'; import { RequiredNetworkElementsList } from '../components/requiredNetworkElements'; import { ConnectionStatusLog } from '../components/connectionStatusLog'; import { UnknownNetworkElementsList } from '../components/unknownNetworkElements'; const mapDispatcher = (dispatcher: IDispatcher) => ({ requiredNetworkElementsActions: createRequiredNetworkElementsActions(dispatcher.dispatch), connectionStatusLogActions: createConnectionStatusLogActions(dispatcher.dispatch), onLoadUnknownNetworkElements: () => { dispatcher.dispatch(loadAllMountedNetworkElementsAsync); }, onLoadRequiredNetworkElements: () => { dispatcher.dispatch(requiredNetworkElementsReloadAction); }, onLoadConnectionStatusLog: () => { dispatcher.dispatch(connectionStatusLogReloadAction); } }); type PanelId = null | "RequiredNetworkElements" | "UnknownNetworkElements" | "ConnectionStatusLog"; type ConnectApplicationComponentProps = Connect ; type ConnectApplicationComponentState = { activePanel: PanelId; }; class ConnectApplicationComponent extends React.Component{ /** * Initialises this instance */ constructor(props: ConnectApplicationComponentProps) { super(props); this.state = { activePanel: null }; } private onTogglePanel = (panelId: PanelId) => { const nextActivePanel = panelId === this.state.activePanel ? null : panelId; this.setState({ activePanel: nextActivePanel }, () => { switch (nextActivePanel) { case 'RequiredNetworkElements': this.props.onLoadRequiredNetworkElements(); break; case 'UnknownNetworkElements': // todo: should we update the application state ? break; case 'ConnectionStatusLog': this.props.onLoadConnectionStatusLog(); break; case null: // do nothing if all panels are closed break; default: console.warn("Unknown nextActivePanel [" + nextActivePanel + "] in connectView"); break; } }); }; render(): JSX.Element { const { activePanel } = this.state; return ( <> ); }; public componentDidMount() { this.onTogglePanel("RequiredNetworkElements"); this.props.onLoadUnknownNetworkElements(); this.props.requiredNetworkElementsActions.onToggleFilter(); this.props.connectionStatusLogActions.onToggleFilter(); } } export const ConnectApplication = (connect(undefined, mapDispatcher)(ConnectApplicationComponent)); export default ConnectApplication;