adding import package basic functionalities
[ccsdk/cds.git] / cds-ui / designer-client / src / app / modules / feature-modules / packages / package-creation / package-creation.component.ts
1 /*
2 ============LICENSE_START==========================================
3 ===================================================================
4 Copyright (C) 2019 Orange. All rights reserved.
5 ===================================================================
6
7 Unless otherwise specified, all software contained herein is licensed
8 under the Apache License, Version 2.0 (the License);
9 you may not use this software except in compliance with the License.
10 You may obtain a copy of the License at
11
12     http://www.apache.org/licenses/LICENSE-2.0
13
14 Unless required by applicable law or agreed to in writing, software
15 distributed under the License is distributed on an "AS IS" BASIS,
16 WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17 See the License for the specific language governing permissions and
18 limitations under the License.
19 ============LICENSE_END============================================
20 */
21
22 import {Component, ElementRef, OnInit, ViewChild} from '@angular/core';
23 import {FilesContent, FolderNodeElement, MetaDataTabModel} from './mapping-models/metadata/MetaDataTab.model';
24
25 import * as JSZip from 'jszip';
26 import {PackageCreationStore} from './package-creation.store';
27 import {Definition} from './mapping-models/CBAPacakge.model';
28 import {PackageCreationModes} from './creationModes/PackageCreationModes';
29 import {PackageCreationBuilder} from './creationModes/PackageCreationBuilder';
30 import {PackageCreationUtils} from './package-creation.utils';
31 import {MetadataTabComponent} from './metadata-tab/metadata-tab.component';
32 import {Router} from '@angular/router';
33 import {ToastrService} from 'ngx-toastr';
34 import {TourService} from 'ngx-tour-md-menu';
35 import {PackageCreationService} from './package-creation.service';
36 import {ComponentCanDeactivate} from '../../../../common/core/canDactivate/ComponentCanDeactivate';
37 import {DesignerStore} from '../designer/designer.store';
38
39
40 @Component({
41     selector: 'app-package-creation',
42     templateUrl: './package-creation.component.html',
43     styleUrls: ['./package-creation.component.css']
44 })
45 export class PackageCreationComponent extends ComponentCanDeactivate implements OnInit {
46
47
48     // adding initial referencing to designer mode
49
50
51     constructor(
52         private packageCreationStore: PackageCreationStore,
53         private packageCreationService: PackageCreationService,
54         private packageCreationUtils: PackageCreationUtils,
55         private router: Router,
56         private tourService: TourService,
57         private toastService: ToastrService,
58         private designerStore: DesignerStore) {
59
60         super();
61     }
62
63     counter = 0;
64     modes: object[] = [
65         {name: 'Designer Mode', style: 'mode-icon icon-designer-mode'},
66         {name: 'Scripting Mode', style: 'mode-icon icon-scripting-mode'}];
67     metaDataTab: MetaDataTabModel = new MetaDataTabModel();
68     folder: FolderNodeElement = new FolderNodeElement();
69     zipFile: JSZip = new JSZip();
70     filesData: any = [];
71     definition: Definition = new Definition();
72     isSaveEnabled = false;
73
74     @ViewChild(MetadataTabComponent, {static: false})
75     metadataTabComponent: MetadataTabComponent;
76
77     @ViewChild('nameit', {static: true})
78     elementRef: ElementRef;
79     versionPattern = '^(\\d+\\.)?(\\d+\\.)?(\\*|\\d+)$';
80     metadataClasses = 'nav-item nav-link active complete';
81
82     ngOnInit() {
83         this.elementRef.nativeElement.focus();
84         const regexp = RegExp(this.versionPattern);
85         this.packageCreationStore.state$.subscribe(cbaPackage => {
86             if (cbaPackage && cbaPackage.metaData && cbaPackage.metaData.description
87                 && cbaPackage.metaData.name && cbaPackage.metaData.version &&
88                 regexp.test(cbaPackage.metaData.version)) {
89                 this.isSaveEnabled = true;
90                 if (!this.metadataClasses.includes('complete')) {
91                     console.log('added');
92                     this.metadataClasses += 'complete';
93                 }
94                 console.log('perhaps it is been added');
95             } else {
96                 this.isSaveEnabled = false;
97                 this.metadataClasses = this.metadataClasses.replace('complete', '');
98             }
99         });
100     }
101
102     openTourGuide(step: string) {
103         // this.tourService.goto(step);
104     }
105
106     saveBluePrint() {
107         this.packageCreationStore.state$.subscribe(
108             cbaPackage => {
109                 console.log(cbaPackage);
110                 FilesContent.clear();
111                 let packageCreationModes: PackageCreationModes;
112                 cbaPackage = PackageCreationModes.mapModeType(cbaPackage);
113                 cbaPackage.metaData = PackageCreationModes.setEntryPoint(cbaPackage.metaData);
114                 packageCreationModes = PackageCreationBuilder.getCreationMode(cbaPackage);
115                 cbaPackage.templateTopology.content = this.designerStore.state.sourceContent;
116                 packageCreationModes.execute(cbaPackage, this.packageCreationUtils);
117                 this.filesData.push(this.folder.TREE_DATA);
118                 this.saveBluePrintToDataBase();
119             });
120
121
122     }
123
124
125     saveBluePrintToDataBase() {
126         this.create();
127         this.zipFile.generateAsync({type: 'blob'})
128             .then(blob => {
129                 this.packageCreationService.savePackage(blob).subscribe(
130                     bluePrintDetailModels => {
131                         if (bluePrintDetailModels) {
132                             const id = bluePrintDetailModels.toString().split('id')[1].split(':')[1].split('"')[1];
133                             this.toastService.info('package updated successfully ');
134                             this.isSaveEnabled = false;
135                             this.router.navigate(['/packages/package/' + id]);
136                         }
137                     }, error => {
138                         // this.toastService.error('error happened when editing ' + error.message);
139                         console.log('Error -' + error.message);
140                     });
141             });
142     }
143
144
145     create() {
146         FilesContent.getMapOfFilesNamesAndContent().forEach((value, key) => {
147             this.zipFile.folder(key.split('/')[0]);
148             this.zipFile.file(key, value);
149         });
150
151     }
152
153
154     goBackToDashBorad() {
155         this.router.navigate(['/packages']);
156     }
157
158     saveMetaData() {
159         console.log('executed change');
160         this.metadataTabComponent.saveMetaDataToStore();
161
162     }
163
164     canDeactivate(): boolean {
165         return this.isSaveEnabled;
166     }
167 }