Feature 11009 Ns Config Template as first class citizens in OSM
[osm/NG-UI.git] / src / app / packages / PackagesModule.ts
1 /*
2  Copyright 2020 TATA ELXSI
3
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
7
8     http://www.apache.org/licenses/LICENSE-2.0
9
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.
15
16  Author: KUMARAN M (kumaran.m@tataelxsi.co.in), RAJESH S (rajesh.s@tataelxsi.co.in), BARATH KUMAR R (barath.r@tataelxsi.co.in)
17 */
18 /**
19  * @file Packages Module.
20  */
21 import { CommonModule } from '@angular/common';
22 import { CUSTOM_ELEMENTS_SCHEMA, NgModule } from '@angular/core';
23 import { ReactiveFormsModule } from '@angular/forms';
24 import { FormsModule } from '@angular/forms';
25 import { RouterModule, Routes } from '@angular/router';
26 import { CodemirrorModule } from '@ctrl/ngx-codemirror';
27 import { NgbModule } from '@ng-bootstrap/ng-bootstrap';
28 import { NgSelectModule } from '@ng-select/ng-select';
29 import { TranslateModule } from '@ngx-translate/core';
30 import { ClonePackageComponent } from 'ClonePackage';
31 import { DataService } from 'DataService';
32 import { DragDirective } from 'DragDirective';
33 import { EditPackagesComponent } from 'EditPackagesComponent';
34 import { LoaderModule } from 'LoaderModule';
35 import { NetsliceTemplateComponent } from 'NetsliceTemplate';
36 import { SidebarModule } from 'ng-sidebar';
37 import { Ng2SmartTableModule } from 'ng2-smart-table';
38 import { NSComposerComponent } from 'NSComposer';
39 import { NSConfigTemplateComponent } from 'NSCONFIGTEMPLATE';
40 import { NSPackagesComponent } from 'NSPackages';
41 import { PackagesComponent } from 'Packages';
42 import { PagePerRowModule } from 'PagePerRowModule';
43 import { PageReloadModule } from 'PageReloadModule';
44 import { ShowContentComponent } from 'ShowContent';
45 import { VNFComposerComponent } from 'VNFComposer';
46 import { VNFPackagesComponent } from 'VNFPackages';
47
48 /** To halndle project information */
49 const projectInfo: {} = { title: '{project}', url: '/' };
50
51 /**
52  * configures  routers
53  */
54 const routes: Routes = [
55     {
56         path: '',
57         component: PackagesComponent,
58         children: [
59             {
60                 path: 'ns',
61                 data: {
62                     breadcrumb: [{ title: 'PAGE.DASHBOARD.DASHBOARD', url: '/' }, { title: 'PAGE.DASHBOARD.PROJECTS', url: '/projects' },
63                         projectInfo, { title: 'NSPACKAGES', url: null }]
64                 },
65                 component: NSPackagesComponent
66             },
67             {
68                 path: 'vnf',
69                 data: {
70                     breadcrumb: [{ title: 'PAGE.DASHBOARD.DASHBOARD', url: '/' }, { title: 'PAGE.DASHBOARD.PROJECTS', url: '/projects' },
71                         projectInfo, { title: 'VNFPACKAGES', url: null }]
72                 },
73                 component: VNFPackagesComponent
74             },
75             {
76                 path: 'netslice',
77                 data: {
78                     breadcrumb: [{ title: 'PAGE.DASHBOARD.DASHBOARD', url: '/' }, { title: 'PAGE.DASHBOARD.PROJECTS', url: '/projects' }
79                         , projectInfo, { title: 'PAGE.DASHBOARD.NETSLICETEMPLATE', url: null }]
80                 },
81                 component: NetsliceTemplateComponent
82             },
83             {
84                 path: ':type/edit/:id',
85                 data: {
86                     breadcrumb: [{ title: 'PAGE.DASHBOARD.DASHBOARD', url: '/' }, { title: 'PAGE.DASHBOARD.PROJECTS', url: '/projects' }
87                         , projectInfo, { title: '{type}', url: '/packages/{type}' }, { title: '{id}', url: null }]
88                 },
89                 component: EditPackagesComponent
90             },
91             {
92                 path: 'ns/compose/:id',
93                 data: {
94                     breadcrumb: [{ title: 'PAGE.DASHBOARD.DASHBOARD', url: '/' }, { title: 'PAGE.DASHBOARD.PROJECTS', url: '/projects' }
95                         , projectInfo, { title: 'NSPACKAGES', url: '/packages/ns' }, { title: '{id}', url: null }]
96                 },
97                 component: NSComposerComponent
98             },
99             {
100                 path: 'vnf/compose/:id',
101                 data: {
102                     breadcrumb: [{ title: 'PAGE.DASHBOARD.DASHBOARD', url: '/' }, { title: 'PAGE.DASHBOARD.PROJECTS', url: '/projects' },
103                         projectInfo, { title: 'VNFPACKAGES', url: '/packages/vnf' }, { title: '{id}', url: null }]
104                 },
105                 component: VNFComposerComponent
106             },
107             {
108                 path: 'nsconfigtemplate',
109                 data: {
110                     breadcrumb: [{ title: 'PAGE.DASHBOARD.DASHBOARD', url: '/' }, { title: 'PAGE.DASHBOARD.PROJECTS', url: '/projects' },
111                         projectInfo, { title: 'PAGE.DASHBOARD.NSCONFIGTEMPLATE', url: null }]
112                 },
113                 component: NSConfigTemplateComponent
114             }
115         ]
116     }
117 ];
118
119 /**
120  * Creating @NgModule component for Modules
121  */
122 @NgModule({
123     imports: [ReactiveFormsModule.withConfig({ warnOnNgModelWithFormControl: 'never' }), FormsModule, CommonModule, Ng2SmartTableModule,
124         CodemirrorModule, TranslateModule, RouterModule.forChild(routes), NgbModule, NgSelectModule,
125         PagePerRowModule, SidebarModule.forRoot(), LoaderModule, PageReloadModule],
126     declarations: [PackagesComponent, NSPackagesComponent, VNFPackagesComponent, NetsliceTemplateComponent,
127         DragDirective, ShowContentComponent, NSComposerComponent, VNFComposerComponent, EditPackagesComponent, ClonePackageComponent, NSConfigTemplateComponent],
128     providers: [DataService],
129     schemas: [CUSTOM_ELEMENTS_SCHEMA]
130 })
131 /** Exporting a class @exports PackagesModule */
132 export class PackagesModule {
133     /** Variables declared to avoid state-less class */
134     private packagesModule: string;
135 }