1 import { Component, OnInit, OnDestroy } from '@angular/core';
2 import { DesignerStore } from '../designer.store';
3 import { PackageCreationUtils } from '../../package-creation/package-creation.utils';
4 import { RouterLink, Router, ActivatedRoute } from '@angular/router';
5 import { Subject } from 'rxjs';
6 import { BluePrintDetailModel } from '../../model/BluePrint.detail.model';
7 import { viewClassName } from '@angular/compiler';
8 import { SourceViewService } from './source-view.service';
11 selector: 'app-designer-source-view',
12 templateUrl: './source-view.component.html',
13 // styleUrls: ['./source-view.component.css']
14 styleUrls: ['../designer.component.css']
16 export class DesignerSourceViewComponent implements OnInit, OnDestroy {
20 controllerSideBar: boolean;
21 ngUnsubscribe = new Subject();
22 viewedPackage: BluePrintDetailModel = new BluePrintDetailModel();
23 public customActionName = '';
27 private store: DesignerStore,
28 private packageCreationUtils: PackageCreationUtils,
29 private router: Router,
30 private route: ActivatedRoute,
31 private sourceViewService: SourceViewService) {
32 this.controllerSideBar = true;
34 private _toggleSidebar1() {
35 this.controllerSideBar = !this.controllerSideBar;
36 if (this.controllerSideBar === false) {
39 if (this.controllerSideBar === true) {
45 this.store.state$.subscribe(
48 this.content = this.packageCreationUtils.transformToJson(state.template);
51 const id = this.route.snapshot.paramMap.get('id');
52 this.sourceViewService.getPagedPackages(id).subscribe(
53 (bluePrintDetailModels) => {
54 if (bluePrintDetailModels) {
55 this.viewedPackage = bluePrintDetailModels[0];
60 convertAndOpenInDesingerView(id) {
61 // TODO validate json against scheme
62 console.log('convertAndOpenInDesingerView ...', this.content);
63 this.store.saveSourceContent(this.content);
64 this.router.navigate(['/packages/designer', id, { actionName: this.customActionName }]);
68 this.ngUnsubscribe.next();
69 this.ngUnsubscribe.complete();