2 Copyright 2020 TATA ELXSI
4 Licensed under the Apache License, Version 2.0 (the 'License');
5 you may not use this file except in compliance with the License.
6 You may obtain a copy of the License at
8 http://www.apache.org/licenses/LICENSE-2.0
10 Unless required by applicable law or agreed to in writing, software
11 distributed under the License is distributed on an "AS IS" BASIS,
12 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 See the License for the specific language governing permissions and
14 limitations under the License.
16 Author: KUMARAN M (kumaran.m@tataelxsi.co.in), RAJESH S (rajesh.s@tataelxsi.co.in), BARATH KUMAR R (barath.r@tataelxsi.co.in)
19 * @file Instance module
21 import { CommonModule } from '@angular/common';
22 import { CUSTOM_ELEMENTS_SCHEMA, NgModule } from '@angular/core';
23 import { FlexLayoutModule } from '@angular/flex-layout';
24 import { FormsModule } from '@angular/forms';
25 import { ReactiveFormsModule } from '@angular/forms';
26 import { RouterModule, Routes } from '@angular/router';
27 import { CodemirrorModule } from '@ctrl/ngx-codemirror';
28 import { NgbModule } from '@ng-bootstrap/ng-bootstrap';
29 import { NgSelectModule } from '@ng-select/ng-select';
30 import { TranslateModule } from '@ngx-translate/core';
31 import { AddPDUInstancesComponent } from 'AddPDUInstancesComponent';
32 import { DataService } from 'DataService';
33 import { HistoryOperationsComponent } from 'HistoryOperationsComponent';
34 import { InstancesComponent } from 'InstancesComponent';
35 import { LoaderModule } from 'LoaderModule';
36 import { NetsliceInstancesComponent } from 'NetsliceInstancesComponent';
37 import { SidebarModule } from 'ng-sidebar';
38 import { Ng2SmartTableModule } from 'ng2-smart-table';
39 import { NSInstancesComponent } from 'NSInstancesComponent';
40 import { NSPrimitiveComponent } from 'NSPrimitiveComponent';
41 import { NSTopologyComponent } from 'NSTopologyComponent';
42 import { OperationalViewAppActionsComponent } from 'OperationalAppActionsComponent';
43 import { OperationalViewAppConfigsComponent } from 'OperationalAppConfigsComponent';
44 import { OperationalViewAppExecutedActionsComponent } from 'OperationalAppExecutedActionsComponent';
45 import { OperationalViewComponent } from 'OperationalViewComponent';
46 import { PagePerRowModule } from 'PagePerRowModule';
47 import { PageReloadModule } from 'PageReloadModule';
48 import { PDUInstancesComponent } from 'PDUInstancesComponent';
49 import { VNFInstancesComponent } from 'VNFInstancesComponent';
51 /** To halndle project information */
52 const projectInfo: {} = { title: '{project}', url: '/' };
54 /** Exporting a function using Routes @exports routes */
55 const routes: Routes = [
58 component: InstancesComponent,
63 breadcrumb: [{ title: 'PAGE.DASHBOARD.DASHBOARD', url: '/' }, { title: 'PAGE.DASHBOARD.PROJECTS', url: '/projects' },
64 projectInfo, { title: 'NSINSTANCES', url: null }]
66 component: NSInstancesComponent
71 breadcrumb: [{ title: 'PAGE.DASHBOARD.DASHBOARD', url: '/' }, { title: 'PAGE.DASHBOARD.PROJECTS', url: '/projects' },
72 projectInfo, { title: 'VNFINSTANCES', url: null }]
74 component: VNFInstancesComponent
79 breadcrumb: [{ title: 'PAGE.DASHBOARD.DASHBOARD', url: '/' }, { title: 'PAGE.DASHBOARD.PROJECTS', url: '/projects' },
80 projectInfo, { title: 'PDUINSTANCES', url: null }]
82 component: PDUInstancesComponent
87 breadcrumb: [{ title: 'PAGE.DASHBOARD.DASHBOARD', url: '/' }, { title: 'PAGE.DASHBOARD.PROJECTS', url: '/projects' },
88 projectInfo, { title: 'PAGE.DASHBOARD.NETSLICEINSTANCE', url: null }]
90 component: NetsliceInstancesComponent
93 path: ':type/history-operations/:id',
95 breadcrumb: [{ title: 'PAGE.DASHBOARD.DASHBOARD', url: '/' }, { title: 'PAGE.DASHBOARD.PROJECTS', url: '/projects' },
96 projectInfo, { title: '{type}', url: '/instances/{type}' }, { title: '{id}', url: null }]
98 component: HistoryOperationsComponent
103 breadcrumb: [{ title: 'PAGE.DASHBOARD.DASHBOARD', url: '/' }, { title: 'PAGE.DASHBOARD.PROJECTS', url: '/projects' },
104 projectInfo, { title: 'NSINSTANCES', url: '/instances/ns' }, { title: '{id}', url: null }]
106 component: NSTopologyComponent
109 path: 'operational-view',
111 breadcrumb: [{ title: 'PAGE.DASHBOARD.DASHBOARD', url: '/' }, { title: 'PAGE.DASHBOARD.PROJECTS', url: '/projects' },
112 projectInfo, { title: 'PAGE.OPERATIONALDASHBOARD.TITLE', url: null }]
114 component: OperationalViewComponent
117 path: 'operational-view/:id',
119 breadcrumb: [{ title: 'PAGE.DASHBOARD.DASHBOARD', url: '/' }, { title: 'PAGE.DASHBOARD.PROJECTS', url: '/projects' },
120 projectInfo, { title: 'PAGE.OPERATIONALDASHBOARD.TITLE', url: '/instances/operational-view' },
121 { title: '{id}', url: null }]
123 component: OperationalViewComponent
130 * An NgModule is a class adorned with the @NgModule decorator function.
131 * @NgModule takes a metadata object that tells Angular how to compile and run module code.
134 imports: [ReactiveFormsModule.withConfig({ warnOnNgModelWithFormControl: 'never' }), FormsModule, TranslateModule,
135 CodemirrorModule, CommonModule, Ng2SmartTableModule, FlexLayoutModule, RouterModule.forChild(routes), NgbModule,
136 NgSelectModule, PagePerRowModule, LoaderModule, SidebarModule.forRoot(), PageReloadModule],
137 declarations: [InstancesComponent, NSInstancesComponent, VNFInstancesComponent, PDUInstancesComponent, AddPDUInstancesComponent,
138 NetsliceInstancesComponent, HistoryOperationsComponent, NSTopologyComponent, NSPrimitiveComponent, OperationalViewComponent,
139 OperationalViewAppConfigsComponent, OperationalViewAppActionsComponent, OperationalViewAppExecutedActionsComponent],
140 schemas: [CUSTOM_ELEMENTS_SCHEMA],
141 providers: [DataService]
143 /** Exporting a class @exports InstancesModule */
144 export class InstancesModule {
146 * Lifecyle Hooks the trigger before component is instantiate