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, 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 {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';
39 selector: 'app-package-creation',
40 templateUrl: './package-creation.component.html',
41 styleUrls: ['./package-creation.component.css']
43 export class PackageCreationComponent implements OnInit {
45 // adding initial referencing to designer mode
49 private packageCreationStore: PackageCreationStore,
50 private packageCreationService: PackageCreationService,
51 private packageCreationUtils: PackageCreationUtils,
52 private router: Router,
53 private tourService: TourService,
54 private toastService: ToastrService) {
59 {name: 'Designer Mode', style: 'mode-icon icon-designer-mode'},
60 {name: 'Scripting Mode', style: 'mode-icon icon-scripting-mode'}];
61 metaDataTab: MetaDataTabModel = new MetaDataTabModel();
62 folder: FolderNodeElement = new FolderNodeElement();
63 zipFile: JSZip = new JSZip();
65 definition: Definition = new Definition();
66 isSaveEnabled = false;
68 @ViewChild(MetadataTabComponent, {static: false})
69 metadataTabComponent: MetadataTabComponent;
71 @ViewChild('nameit', {static: true})
72 elementRef: ElementRef;
73 versionPattern = '^(\\d+\\.)?(\\d+\\.)?(\\*|\\d+)$';
74 metadataClasses = 'nav-item nav-link active complete';
77 this.elementRef.nativeElement.focus();
78 const regexp = RegExp(this.versionPattern);
79 this.packageCreationStore.state$.subscribe(cbaPackage => {
80 if (cbaPackage && cbaPackage.metaData && cbaPackage.metaData.description
81 && cbaPackage.metaData.name && cbaPackage.metaData.version &&
82 regexp.test(cbaPackage.metaData.version)) {
83 this.isSaveEnabled = true;
84 if (!this.metadataClasses.includes('complete')) {
86 this.metadataClasses += 'complete';
88 console.log('perhaps it is been added');
90 this.isSaveEnabled = false;
91 this.metadataClasses = this.metadataClasses.replace('complete', '');
96 openTourGuide(step: string) {
97 // this.tourService.goto(step);
101 this.packageCreationStore.state$.subscribe(
103 console.log(cbaPackage);
104 FilesContent.clear();
105 let packageCreationModes: PackageCreationModes;
106 cbaPackage = PackageCreationModes.mapModeType(cbaPackage);
107 cbaPackage.metaData = PackageCreationModes.setEntryPoint(cbaPackage.metaData);
108 packageCreationModes = PackageCreationBuilder.getCreationMode(cbaPackage);
109 packageCreationModes.execute(cbaPackage, this.packageCreationUtils);
110 this.filesData.push(this.folder.TREE_DATA);
111 this.saveBluePrintToDataBase();
118 saveBluePrintToDataBase() {
120 this.zipFile.generateAsync({type: 'blob'})
122 this.packageCreationService.savePackage(blob).subscribe(
123 bluePrintDetailModels => {
124 if (bluePrintDetailModels) {
125 const id = bluePrintDetailModels.toString().split('id')[1].split(':')[1].split('"')[1];
126 this.toastService.info('package updated successfully ');
127 this.router.navigate(['/packages/package/' + id]);
130 // this.toastService.error('error happened when editing ' + error.message);
131 console.log('Error -' + error.message);
138 FilesContent.getMapOfFilesNamesAndContent().forEach((value, key) => {
139 this.zipFile.folder(key.split('/')[0]);
140 this.zipFile.file(key, value);
146 goBackToDashBorad() {
147 this.router.navigate(['/packages']);
151 console.log('executed change');
152 this.metadataTabComponent.saveMetaDataToStore();