Create wt-odlux directory
[ccsdk/features.git] / sdnr / wt-odlux / odlux / framework / src / views / home.tsx
1 /**
2  * ============LICENSE_START========================================================================
3  * ONAP : ccsdk feature sdnr wt odlux
4  * =================================================================================================
5  * Copyright (C) 2021 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
19 import React, {FC, useState} from 'react';
20 import applicationService from '../services/applicationManager';
21
22
23 type DashboardElement = { name: string, element: JSX.Element };
24
25 const DashboardView: FC = (props) => {
26
27   const registrations = applicationService.applications;
28
29   const [selectedIndex] = useState(0);
30
31   let dashboardArray: DashboardElement[] = [];
32
33   let dashboardElements: (DashboardElement)[] = Object.keys(registrations).map(p => {
34     const application = registrations[p];
35
36     if (application.dashbaordElement) {
37       const value: DashboardElement = { name: application.menuEntry?.toString()!, element: <application.dashbaordElement /> };
38       return value;
39
40     } else {
41       return null;
42     }
43   }).filter((x): x is DashboardElement => x !== null);
44
45   dashboardArray.push(...dashboardElements);
46
47   return <div>
48     <div>
49       <div>
50         {
51           dashboardArray[selectedIndex]?.element
52         }
53       </div>
54     </div>
55   </div>
56 }
57
58
59 export default DashboardView;