Initial Commit - NG UI
[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 { NSPackagesComponent } from 'NSPackages';
40 import { PackagesComponent } from 'Packages';
41 import { PagePerRowModule } from 'PagePerRowModule';
42 import { PageReloadModule } from 'PageReloadModule';
43 import { ShowContentComponent } from 'ShowContent';
44 import { VNFComposerComponent } from 'VNFComposer';
45 import { VNFPackagesComponent } from 'VNFPackages';
46
47 /** To halndle project information */
48 const projectInfo: {} = { title: '{project}', url: '/' };
49
50 /**
51  * configures  routers
52  */
53 const routes: Routes = [
54     {
55         path: '',
56         component: PackagesComponent,
57         children: [
58             {
59                 path: 'ns',
60                 data: {
61                     breadcrumb: [{ title: 'PAGE.DASHBOARD.DASHBOARD', url: '/' }, { title: 'PAGE.DASHBOARD.PROJECTS', url: '/projects' },
62                         projectInfo, { title: 'NSPACKAGES', url: null }]
63                 },
64                 component: NSPackagesComponent
65             },
66             {
67                 path: 'vnf',
68                 data: {
69                     breadcrumb: [{ title: 'PAGE.DASHBOARD.DASHBOARD', url: '/' }, { title: 'PAGE.DASHBOARD.PROJECTS', url: '/projects' },
70                         projectInfo, { title: 'VNFPACKAGES', url: null }]
71                 },
72                 component: VNFPackagesComponent
73             },
74             {
75                 path: 'netslice',
76                 data: {
77                     breadcrumb: [{ title: 'PAGE.DASHBOARD.DASHBOARD', url: '/' }, { title: 'PAGE.DASHBOARD.PROJECTS', url: '/projects' }
78                         , projectInfo, { title: 'PAGE.DASHBOARD.NETSLICETEMPLATE', url: null }]
79                 },
80                 component: NetsliceTemplateComponent
81             },
82             {
83                 path: ':type/edit/:id',
84                 data: {
85                     breadcrumb: [{ title: 'PAGE.DASHBOARD.DASHBOARD', url: '/' }, { title: 'PAGE.DASHBOARD.PROJECTS', url: '/projects' }
86                         , projectInfo, { title: '{type}', url: '/packages/{type}' }, { title: '{id}', url: null }]
87                 },
88                 component: EditPackagesComponent
89             },
90             {
91                 path: 'ns/compose/:id',
92                 data: {
93                     breadcrumb: [{ title: 'PAGE.DASHBOARD.DASHBOARD', url: '/' }, { title: 'PAGE.DASHBOARD.PROJECTS', url: '/projects' }
94                         , projectInfo, { title: 'NSPACKAGES', url: '/packages/ns' }, { title: '{id}', url: null }]
95                 },
96                 component: NSComposerComponent
97             },
98             {
99                 path: 'vnf/compose/:id',
100                 data: {
101                     breadcrumb: [{ title: 'PAGE.DASHBOARD.DASHBOARD', url: '/' }, { title: 'PAGE.DASHBOARD.PROJECTS', url: '/projects' },
102                         projectInfo, { title: 'VNFPACKAGES', url: '/packages/vnf' }, { title: '{id}', url: null }]
103                 },
104                 component: VNFComposerComponent
105             }
106         ]
107     }
108 ];
109
110 /**
111  * Creating @NgModule component for Modules
112  */
113 @NgModule({
114     imports: [ReactiveFormsModule.withConfig({ warnOnNgModelWithFormControl: 'never' }), FormsModule, CommonModule, Ng2SmartTableModule,
115         CodemirrorModule, TranslateModule, RouterModule.forChild(routes), NgbModule, NgSelectModule,
116         PagePerRowModule, SidebarModule.forRoot(), LoaderModule, PageReloadModule],
117     declarations: [PackagesComponent, NSPackagesComponent, VNFPackagesComponent, NetsliceTemplateComponent,
118         DragDirective, ShowContentComponent, NSComposerComponent, VNFComposerComponent, EditPackagesComponent, ClonePackageComponent],
119     providers: [DataService],
120     schemas: [CUSTOM_ELEMENTS_SCHEMA],
121     entryComponents: [ShowContentComponent, ClonePackageComponent]
122 })
123 /** Exporting a class @exports PackagesModule */
124 export class PackagesModule {
125     /** Variables declared to avoid state-less class */
126     private packagesModule: string;
127 }