2 ============LICENSE_START==========================================
3 ===================================================================
4 Copyright (C) 2019 Orange. All rights reserved.
5 ===================================================================
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
12 http://www.apache.org/licenses/LICENSE-2.0
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============================================
22 import {Component, ElementRef, OnDestroy, OnInit, ViewChild} from '@angular/core';
23 import {FilesContent, FolderNodeElement, MetaDataTabModel} from './mapping-models/metadata/MetaDataTab.model';
25 import * as JSZip from 'jszip';
26 import {PackageCreationStore} from './package-creation.store';
27 import {CBAPackage, 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';
41 selector: 'app-package-creation',
42 templateUrl: './package-creation.component.html',
43 styleUrls: ['./package-creation.component.css']
45 export class PackageCreationComponent extends ComponentCanDeactivate implements OnInit, OnDestroy {
48 // adding initial referencing to designer mode
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) {
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();
71 definition: Definition = new Definition();
72 isSaveEnabled = false;
74 @ViewChild(MetadataTabComponent, {static: false})
75 metadataTabComponent: MetadataTabComponent;
77 @ViewChild('nameit', {static: true})
78 elementRef: ElementRef;
79 versionPattern = '^(\\d+\\.)?(\\d+\\.)?(\\*|\\d+)$';
80 metadataClasses = 'nav-item nav-link active complete';
81 private cbaPackage: CBAPackage;
84 this.elementRef.nativeElement.focus();
85 const regexp = RegExp(this.versionPattern);
86 this.packageCreationStore.state$.subscribe(cbaPackage => {
87 console.log(cbaPackage);
88 console.log('abbaaaas' + cbaPackage.metaData.name);
89 this.cbaPackage = cbaPackage;
90 if (cbaPackage && cbaPackage.metaData && cbaPackage.metaData.description
91 && cbaPackage.metaData.name && cbaPackage.metaData.version &&
92 regexp.test(cbaPackage.metaData.version)) {
93 this.isSaveEnabled = true;
94 if (!this.metadataClasses.includes('complete')) {
96 this.metadataClasses += 'complete';
98 console.log('perhaps it is been added');
100 this.isSaveEnabled = false;
101 this.metadataClasses = this.metadataClasses.replace('complete', '');
106 openTourGuide(step: string) {
107 // this.tourService.goto(step);
111 console.log(this.cbaPackage);
112 FilesContent.clear();
113 let packageCreationModes: PackageCreationModes;
114 this.cbaPackage = PackageCreationModes.mapModeType(this.cbaPackage);
115 this.cbaPackage.metaData = PackageCreationModes.setEntryPoint(this.cbaPackage.metaData);
116 packageCreationModes = PackageCreationBuilder.getCreationMode(this.cbaPackage);
118 // this.cbaPackage.templateTopology.content = this.designerStore.state.sourceContent;
119 packageCreationModes.execute(this.cbaPackage, this.packageCreationUtils);
120 this.filesData.push(this.folder.TREE_DATA);
121 this.saveBluePrintToDataBase();
127 saveBluePrintToDataBase() {
129 this.zipFile.generateAsync({type: 'blob'})
131 this.packageCreationService.savePackage(blob).subscribe(
132 bluePrintDetailModels => {
133 if (bluePrintDetailModels) {
134 const id = bluePrintDetailModels.toString().split('id')[1].split(':')[1].split('"')[1];
135 this.toastService.info('package updated successfully ');
136 this.isSaveEnabled = false;
137 this.router.navigate(['/packages/package/' + id]);
140 // this.toastService.error('error happened when editing ' + error.message);
141 console.log('Error -' + error.message);
148 FilesContent.getMapOfFilesNamesAndContent().forEach((value, key) => {
149 this.zipFile.folder(key.split('/')[0]);
150 this.zipFile.file(key, value);
156 goBackToDashBorad() {
157 this.router.navigate(['/packages']);
161 console.log('executed change');
162 this.metadataTabComponent.saveMetaDataToStore();
166 canDeactivate(): boolean {
167 return this.isSaveEnabled;
170 ngOnDestroy(): void {