/** * ============LICENSE_START======================================================================== * ONAP : ccsdk feature sdnr wt odlux * ================================================================================================= * Copyright (C) 2021 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 { IApplicationStoreState } from "../store/applicationStore"; import connect, { Connect, IDispatcher } from "../flux/connect"; import applicationService from '../services/applicationManager'; type props = Connect; type SettingsEntry = { name: string, element: JSX.Element } const mapProps = (state: IApplicationStoreState) => ({ }); const mapDispatch = (dispatcher: IDispatcher) => ({ }); const DashboardView: React.FunctionComponent = (props) => { const registrations = applicationService.applications; const [selectedIndex] = React.useState(0); let settingsArray: SettingsEntry[] = []; let settingsElements: (SettingsEntry)[] = Object.keys(registrations).map(p => { const application = registrations[p]; if (application.dashbaordElement) { const value: SettingsEntry = { name: application.menuEntry?.toString()!, element: }; return value; } else { return null; } }).filter((x): x is SettingsEntry => x !== null); settingsArray.push(...settingsElements); return
{ settingsArray[selectedIndex]?.element }
} export default connect(mapProps, mapDispatch)(DashboardView);