change component structure

separate bpmn elements from toolbar component, and add rest task and gateway elements.

Issue-ID: SDC-266

Change-Id: I5aabe92b161a44bfc24290e93cd80b8d73dbe963
Signed-off-by: Lvbo163 <lv.bo163@zte.com.cn>
diff --git a/sdc-workflow-designer-ui/src/app/app.component.css b/sdc-workflow-designer-ui/src/app/app.component.css
index 762d14b..fdafa45 100644
--- a/sdc-workflow-designer-ui/src/app/app.component.css
+++ b/sdc-workflow-designer-ui/src/app/app.component.css
@@ -9,10 +9,36 @@
  * Contributors:

  *     ZTE - initial API and implementation and/or initial documentation

  */

+ .main-content-wrapper{

+    height: 100%;

+    background-image: url();

+    background-size: 11px;

+}

 

+.toolbar{

+    position: fixed;

+    top: 0px;

+    left: 0px;

+    width: 200px;

+    height: 100%;

+    background-color: white;

+}

 

- .container {

-     width: 100%;

-     height: 100%;

- }

+.design-area{

+    position: relative;

+    left: 200px;

+    width: calc(100% - 200px);

+    height: 100%;

+    padding: 20px;

+}

 

+.design-menu{

+    display: block;

+    height: 30px;

+    margin-bottom: 10px;

+}

+

+.design-container{

+    display: block;

+    height: calc(100% - 40px);

+}

diff --git a/sdc-workflow-designer-ui/src/app/app.component.html b/sdc-workflow-designer-ui/src/app/app.component.html
index 08b57b8..856e52b 100644
--- a/sdc-workflow-designer-ui/src/app/app.component.html
+++ b/sdc-workflow-designer-ui/src/app/app.component.html
@@ -12,10 +12,11 @@
  */
 -->
 
-
-<b4t-toolbar></b4t-toolbar>
-
-<b4t-canvas></b4t-canvas>
-
-<b4t-properties></b4t-properties>
-
+<div class="main-content-wrapper">
+    <b4t-toolbar class="toolbar"></b4t-toolbar>
+    <div class="design-area">
+        <b4t-menu class="design-menu"></b4t-menu>
+        <b4t-canvas></b4t-canvas>
+    </div>
+    <b4t-properties></b4t-properties>
+</div>
diff --git a/sdc-workflow-designer-ui/src/app/app.module.ts b/sdc-workflow-designer-ui/src/app/app.module.ts
index 5b05426..297cbce 100644
--- a/sdc-workflow-designer-ui/src/app/app.module.ts
+++ b/sdc-workflow-designer-ui/src/app/app.module.ts
@@ -30,11 +30,13 @@
 import { CanvasComponent } from "./components/canvas/canvas.component";
 import { StartEventParametersComponent } from "./components/property/start-event-parameters/start-event-parameters.component";
 import { ParameterComponent } from "./components/parameter/parameter.component";
+import { MenuComponent } from "./components/menus/menu.component";
 
 @NgModule({
     declarations: [
         AppComponent,
         CanvasComponent,
+        MenuComponent,
         NodeComponent,
         ParameterComponent,
         PropertiesComponent,
diff --git a/sdc-workflow-designer-ui/src/app/components/canvas/canvas.component.css b/sdc-workflow-designer-ui/src/app/components/canvas/canvas.component.css
index fec14a4..bc88965 100644
--- a/sdc-workflow-designer-ui/src/app/components/canvas/canvas.component.css
+++ b/sdc-workflow-designer-ui/src/app/components/canvas/canvas.component.css
@@ -22,5 +22,5 @@
     position: relative;
     overflow: scroll;
     z-index: 0;
-    background-color: #84acb3;
+    background-color: white;
 }
diff --git a/sdc-workflow-designer-ui/src/app/components/menus/menu.component.css b/sdc-workflow-designer-ui/src/app/components/menus/menu.component.css
new file mode 100644
index 0000000..2fa48af
--- /dev/null
+++ b/sdc-workflow-designer-ui/src/app/components/menus/menu.component.css
@@ -0,0 +1,19 @@
+/**
+ * Copyright (c) 2017 ZTE Corporation.
+ * All rights reserved. This program and the accompanying materials
+ * are made available under the terms of the Eclipse Public License v1.0
+ * and the Apache License 2.0 which both accompany this distribution,
+ * and are available at http://www.eclipse.org/legal/epl-v10.html
+ * and http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Contributors:
+ *     ZTE - initial API and implementation and/or initial documentation
+ */
+
+.btn-right{
+    float: right;
+}
+
+button i{
+    padding-right: 3px;
+}
diff --git a/sdc-workflow-designer-ui/src/app/components/menus/menu.component.html b/sdc-workflow-designer-ui/src/app/components/menus/menu.component.html
new file mode 100644
index 0000000..edee361
--- /dev/null
+++ b/sdc-workflow-designer-ui/src/app/components/menus/menu.component.html
@@ -0,0 +1,20 @@
+<!--
+/**
+ * Copyright (c) 2017 ZTE Corporation.
+ * All rights reserved. This program and the accompanying materials
+ * are made available under the terms of the Eclipse Public License v1.0
+ * and the Apache License 2.0 which both accompany this distribution,
+ * and are available at http://www.eclipse.org/legal/epl-v10.html
+ * and http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Contributors:
+ *     ZTE - initial API and implementation and/or initial documentation
+ */
+-->
+
+<div class="btn-right">
+  <button type="button" class="btn white" (click)="save()" [disabled]="!canSave">
+    <i class="fa fa-save"></i>Save
+  </button>
+  <!-- <button type="button" class="btn white" (click)="test()">test</button> -->
+</div>
diff --git a/sdc-workflow-designer-ui/src/app/components/menus/menu.component.spec.ts b/sdc-workflow-designer-ui/src/app/components/menus/menu.component.spec.ts
new file mode 100644
index 0000000..52f2c77
--- /dev/null
+++ b/sdc-workflow-designer-ui/src/app/components/menus/menu.component.spec.ts
@@ -0,0 +1,36 @@
+/**
+ * Copyright (c) 2017 ZTE Corporation.
+ * All rights reserved. This program and the accompanying materials
+ * are made available under the terms of the Eclipse Public License v1.0
+ * and the Apache License 2.0 which both accompany this distribution,
+ * and are available at http://www.eclipse.org/legal/epl-v10.html
+ * and http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Contributors:
+ *     ZTE - initial API and implementation and/or initial documentation
+ */
+import { async, ComponentFixture, TestBed } from '@angular/core/testing';
+
+import { MenuComponent } from './menu.component';
+
+describe('MenuComponent', () => {
+  let component: MenuComponent;
+  let fixture: ComponentFixture<MenuComponent>;
+
+  beforeEach(async(() => {
+    TestBed.configureTestingModule({
+      declarations: [ MenuComponent ]
+    })
+    .compileComponents();
+  }));
+
+  beforeEach(() => {
+    fixture = TestBed.createComponent(MenuComponent);
+    component = fixture.componentInstance;
+    fixture.detectChanges();
+  });
+
+  it('should be created', () => {
+    expect(component).toBeTruthy();
+  });
+});
diff --git a/sdc-workflow-designer-ui/src/app/components/menus/menu.component.ts b/sdc-workflow-designer-ui/src/app/components/menus/menu.component.ts
new file mode 100644
index 0000000..347f1a2
--- /dev/null
+++ b/sdc-workflow-designer-ui/src/app/components/menus/menu.component.ts
@@ -0,0 +1,33 @@
+/**
+ * Copyright (c) 2017 ZTE Corporation.
+ * All rights reserved. This program and the accompanying materials
+ * are made available under the terms of the Eclipse Public License v1.0
+ * and the Apache License 2.0 which both accompany this distribution,
+ * and are available at http://www.eclipse.org/legal/epl-v10.html
+ * and http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Contributors:
+ *     ZTE - initial API and implementation and/or initial documentation
+ */
+import { Component, OnInit, ViewChild } from '@angular/core';
+
+import { WorkflowService } from '../../services/workflow.service';
+
+@Component({
+  selector: 'b4t-menu',
+  templateUrl: './menu.component.html',
+  styleUrls: ['./menu.component.css']
+})
+export class MenuComponent {
+
+  public canSave = true;
+
+  constructor(private workflowService: WorkflowService) { }
+
+  public save(): void {
+    this.workflowService.save();
+  }
+
+  public test() {
+  }
+}
diff --git a/sdc-workflow-designer-ui/src/app/components/node/node.component.css b/sdc-workflow-designer-ui/src/app/components/node/node.component.css
index 08b7322..0d01835 100644
--- a/sdc-workflow-designer-ui/src/app/components/node/node.component.css
+++ b/sdc-workflow-designer-ui/src/app/components/node/node.component.css
@@ -207,23 +207,6 @@
     border-top: 4px white solid;

 }

 

-

-.node .startEvent {

-    border-radius: 30px;

-    background-size: cover;

-    border: 1px solid rgb(0, 0, 0);

-    height: 30px;

-    width: 30px;

-}

-

-.node .endEvent {

-    border-radius: 30px;

-    background-size: cover;

-    border: 2px solid rgb(0, 0, 0);

-    height: 30px;

-    width: 30px;

-}

-

 .node .name {

     padding: 10px 15px;

 }

@@ -235,3 +218,54 @@
 .node.focus {

     border: 1px dotted red;

 }

+

+.startEvent {

+    border-radius: 30px;

+    border: 1px solid rgb(0, 0, 0);

+    background-size: cover;

+    height: 30px;

+    width: 30px;

+    /*background-image: url("");*/

+}

+

+.endEvent {

+    border-radius: 30px;

+    border: 2px solid rgb(0, 0, 0);

+    background-size: cover;

+    height: 30px;

+    width: 30px;

+    /*background-image: url("");*/

+}

+

+.intermediateCatchEvent {

+    border-radius: 30px;

+    border: 1px solid rgb(0, 0, 0);

+    background-size: cover;

+    height: 30px;

+    width: 30px;

+    background-image: url("data:image/svg+xml;utf8,<?xml version='1.0' encoding='UTF-8' standalone='no'?><svg xmlns='http://www.w3.org/2000/svg' xmlns:oryx='http://www.b3mn.org/oryx' viewBox='1 1 30 30' width='28' height='28' style='fill:transparent' version='1.0'> <defs></defs> <oryx:magnets> <oryx:magnet oryx:cx='16' oryx:cy='16' oryx:default='yes' /> </oryx:magnets> <oryx:docker oryx:cx='16' oryx:cy='16' /> <g pointer-events='fill'> <defs> <radialGradient id='background' cx='10%' cy='10%' r='100%' fx='10%' fy='10%'> <stop offset='0%' stop-color='#ffffff' stop-opacity='1'/> <stop id='fill_el' offset='100%' stop-color='#ffffff' stop-opacity='1'/> </radialGradient> </defs> <circle id='bg_frame' cx='16' cy='16' r='15' stroke='black' stroke-width='1' style='stroke-dasharray: 5.5, 3' />  <circle id='frame2_non_interrupting' cx='16' cy='16' r='12' stroke='black' fill='none' stroke-width='1' style='stroke-dasharray: 4.5, 3' /><circle id='frame' cx='16' cy='16' r='15' stroke='black' fill='none' stroke-width='1'/><circle id='frame2' cx='16' cy='16' r='12' stroke='black' fill='none' stroke-width='1'/><circle id='circle' cx='16' cy='16' r='10' stroke='black' fill='none' stroke-width='1'/> <path id='path1' d='M 16 6 L 16 9 M 21 7 L 19.5 10 M 25 11 L 22 12.5 M 26 16 L 23 16 M 25 21 L 22 19.5 M 21 25 L 19.5 22 M 16 26 L 16 23 M 11 25 L 12.5 22 M 7 21 L 10 19.5 M 6 16 L 9 16 M 7 11 L 10 12.5 M 11 7 L 12.5 10 M 18 9 L 16 16 L 20 16' fill='none' stroke='black' /> <text font-size='11' id='text_name' x='16' y='33' oryx:align='top center' stroke='black'></text></g></svg>");

+}

+

+.restTask {

+    border-radius: 8px;

+    border: 2px solid rgb(0, 0, 0);

+    font-size: 10px;

+}

+

+.parallelGateway {

+    transform: rotate(45deg);

+    border: 2px solid rgb(0, 0, 0);

+    background-size: cover;

+    height: 30px;

+    width: 30px;

+    background-image: url("");

+}

+

+.exclusiveGateway {

+    transform: rotate(45deg);

+    border: 2px solid rgb(0, 0, 0);

+    background-size: cover;

+    height: 30px;

+    width: 30px;

+    background-image: url("");

+}

diff --git a/sdc-workflow-designer-ui/src/app/components/node/node.component.html b/sdc-workflow-designer-ui/src/app/components/node/node.component.html
index 090f324..62cd6f5 100644
--- a/sdc-workflow-designer-ui/src/app/components/node/node.component.html
+++ b/sdc-workflow-designer-ui/src/app/components/node/node.component.html
@@ -11,34 +11,34 @@
  *     ZTE - initial API and implementation and/or initial documentation

  */

 -->

+<div (dblclick)="showProperties($event)" class="node {{node.type}}" id="{{node.id}}" [style.top]="node.position.top + 'px'"

+    [style.left]="node.position.left + 'px'">

+    <div class="name">

+        {{getDisplayName()}}

+    </div>

 

-<div (dblclick)="showProperties()" class="node" id="{{node.id}}" [style.top]="node.position.top + 'px'"

-[style.left]="node.position.left + 'px'">

-<div [class]="node.type">

-

-</div>

-<div class="anchor anchors anchor-left">

-   <span class="left">

-       <i class="left-arrow1"></i>

-       <i class="left-arrow2"></i>

-   </span>

-</div>

-<div class="anchor anchors anchor-right">

-   <span class="right">

-       <i class="right-arrow1"></i>

-       <i class="right-arrow2"></i>

-   </span>

-</div>

-<div class="anchor anchors anchor-top">

-   <span class="top">

-       <i class="top-arrow1"></i>

-       <i class="top-arrow2"></i>

-   </span>

-</div>

-<div class="anchor anchors anchor-bottom">

-   <span class="bottom">

-       <i class="bottom-arrow1"></i>

-       <i class="bottom-arrow2"></i>

-   </span>

-</div>

+    <div class="anchor anchors anchor-left">

+        <span class="left">

+            <i class="left-arrow1"></i>

+            <i class="left-arrow2"></i>

+        </span>

+    </div>

+    <div class="anchor anchors anchor-right">

+        <span class="right">

+            <i class="right-arrow1"></i>

+            <i class="right-arrow2"></i>

+        </span>

+    </div>

+    <div class="anchor anchors anchor-top">

+        <span class="top">

+            <i class="top-arrow1"></i>

+            <i class="top-arrow2"></i>

+        </span>

+    </div>

+    <div class="anchor anchors anchor-bottom">

+        <span class="bottom">

+            <i class="bottom-arrow1"></i>

+            <i class="bottom-arrow2"></i>

+        </span>

+    </div>

 </div>

diff --git a/sdc-workflow-designer-ui/src/app/components/node/node.component.ts b/sdc-workflow-designer-ui/src/app/components/node/node.component.ts
index 676ba99..c6a9596 100644
--- a/sdc-workflow-designer-ui/src/app/components/node/node.component.ts
+++ b/sdc-workflow-designer-ui/src/app/components/node/node.component.ts
@@ -45,4 +45,12 @@
         this.broadcastService.broadcast(this.broadcastService.showProperty, true);

     }

 

+    public getDisplayName(): string {

+        if (this.node.type === 'restTask' || this.node.type === 'toscaTask') {

+            return this.node.name;

+        } else {

+            return '     ';

+        }

+    }

+

 }

diff --git a/sdc-workflow-designer-ui/src/app/components/toolbar/toolbar.component.css b/sdc-workflow-designer-ui/src/app/components/toolbar/toolbar.component.css
index 94559ef..942ac58 100644
--- a/sdc-workflow-designer-ui/src/app/components/toolbar/toolbar.component.css
+++ b/sdc-workflow-designer-ui/src/app/components/toolbar/toolbar.component.css
@@ -10,16 +10,97 @@
  *     ZTE - initial API and implementation and/or initial documentation

  */

 

-.toolbar {

-    padding: 10px 30px 0px 10px;

-    position: fixed;

-    top: 0px;

-    left: 0px;

-    width: 100%;

-    z-index: 4;

+ .toolbar{

+    padding: 20px 10px;

+}

+

+.row{

+    margin: 0;

 }

 

 button {

+    min-width: 40px;

+    width: 60px;

+    height: 60px;

     transition: all 0s;

+    margin: 10px;

+    padding: 0;

+}

+

+button div{

+    left: 0;

+    right: 0;

+    margin: auto;

+    width: 40px;

+    height: 40px;

+}

+

+button span{

+    padding: 0;

+    font-size: 10px;

+    letter-spacing: 0px;

+    color: black;

+}

+

+.subProcess {

+    border-radius: 8px;

+    border: 2px solid rgb(0, 0, 0);

+    font-size: 10px;

+}

+

+.parallelGateway {

+    transform: rotate(45deg);

+    border: 2px solid rgb(0, 0, 0);

+    background-size: cover;

+    height: 30px !important;

+    width: 30px !important;

+    background-image: url("");

+}

+

+.exclusiveGateway {

+    transform: rotate(45deg);

+    border: 2px solid rgb(0, 0, 0);

+    background-size: cover;

+    height: 30px !important;

+    width: 30px !important;

+    background-image: url("");

+}

+

+.startEvent {

+    border-radius: 30px;

+    border: 1px solid rgb(0, 0, 0);

+    background-size: cover;

     height: 30px;

+    width: 30px;

+    /*background-image: url("");*/

+}

+

+.endEvent {

+    border-radius: 30px;

+    border: 2px solid rgb(0, 0, 0);

+    background-size: cover;

+    height: 30px;

+    width: 30px;

+    /*background-image: url("");*/

+}

+

+.intermediateCatchEvent {

+    border-radius: 30px;

+    border: 1px solid rgb(0, 0, 0);

+    background-size: cover;

+    height: 30px;

+    width: 30px;

+    background-image: url("data:image/svg+xml;utf8,<?xml version='1.0' encoding='UTF-8' standalone='no'?><svg xmlns='http://www.w3.org/2000/svg' xmlns:oryx='http://www.b3mn.org/oryx' viewBox='1 1 30 30' width='28' height='28' style='fill:transparent' version='1.0'> <defs></defs> <oryx:magnets> <oryx:magnet oryx:cx='16' oryx:cy='16' oryx:default='yes' /> </oryx:magnets> <oryx:docker oryx:cx='16' oryx:cy='16' /> <g pointer-events='fill'> <defs> <radialGradient id='background' cx='10%' cy='10%' r='100%' fx='10%' fy='10%'> <stop offset='0%' stop-color='#ffffff' stop-opacity='1'/> <stop id='fill_el' offset='100%' stop-color='#ffffff' stop-opacity='1'/> </radialGradient> </defs> <circle id='bg_frame' cx='16' cy='16' r='15' stroke='black' stroke-width='1' style='stroke-dasharray: 5.5, 3' />  <circle id='frame2_non_interrupting' cx='16' cy='16' r='12' stroke='black' fill='none' stroke-width='1' style='stroke-dasharray: 4.5, 3' /><circle id='frame' cx='16' cy='16' r='15' stroke='black' fill='none' stroke-width='1'/><circle id='frame2' cx='16' cy='16' r='12' stroke='black' fill='none' stroke-width='1'/><circle id='circle' cx='16' cy='16' r='10' stroke='black' fill='none' stroke-width='1'/> <path id='path1' d='M 16 6 L 16 9 M 21 7 L 19.5 10 M 25 11 L 22 12.5 M 26 16 L 23 16 M 25 21 L 22 19.5 M 21 25 L 19.5 22 M 16 26 L 16 23 M 11 25 L 12.5 22 M 7 21 L 10 19.5 M 6 16 L 9 16 M 7 11 L 10 12.5 M 11 7 L 12.5 10 M 18 9 L 16 16 L 20 16' fill='none' stroke='black' /> <text font-size='11' id='text_name' x='16' y='33' oryx:align='top center' stroke='black'></text></g></svg>");

+}

+

+.toscaTask {

+    border-radius: 8px;

+    border: 2px solid rgb(0, 0, 0);

+    font-size: 10px;

+}

+

+.restTask {

+    border-radius: 8px;

+    border: 2px solid rgb(0, 0, 0);

+    font-size: 10px;

 }

diff --git a/sdc-workflow-designer-ui/src/app/components/toolbar/toolbar.component.html b/sdc-workflow-designer-ui/src/app/components/toolbar/toolbar.component.html
index 91b935e..bb52644 100644
--- a/sdc-workflow-designer-ui/src/app/components/toolbar/toolbar.component.html
+++ b/sdc-workflow-designer-ui/src/app/components/toolbar/toolbar.component.html
@@ -13,13 +13,11 @@
 -->

 <div class="toolbar">

     <div class="row">

-        <button type="button" class="btn btn-secondary item ui-draggable" [attr.nodeType]="'startEvent'">

-            <span>startEvent</span>

+        <button *ngFor="let nodeType of nodeTypes" type="button" [attr.nodeType]="nodeType"

+            class="btn btn-secondary item ui-draggable">

+            <div class="{{nodeType}}">

+            </div>

+            <span>{{getNameByType(nodeType)}}</span>

         </button>

-        <button type="button" class="btn btn-secondary item ui-draggable" [attr.nodeType]="'endEvent'">

-            <span>endEvent</span>

-        </button>

-

-        <button type="button" class="btn btn-success" (click)="save()">Save</button>

     </div>

 </div>

diff --git a/sdc-workflow-designer-ui/src/app/components/toolbar/toolbar.component.ts b/sdc-workflow-designer-ui/src/app/components/toolbar/toolbar.component.ts
index 1e1de19..71bf02a 100644
--- a/sdc-workflow-designer-ui/src/app/components/toolbar/toolbar.component.ts
+++ b/sdc-workflow-designer-ui/src/app/components/toolbar/toolbar.component.ts
@@ -10,10 +10,10 @@
  *     ZTE - initial API and implementation and/or initial documentation

  */

 

-import { AfterViewInit, Component } from '@angular/core';

+import { AfterViewInit, Component, OnInit } from '@angular/core';

 

 import { JsPlumbService } from '../../services/jsplumb.service';

-import { WorkflowService } from "../../services/workflow.service";

+import { NodeType } from "../../model/workflow/node-type.enum";

 

 /**

  * toolbar component contains some basic operations(save) and all of the supported workflow nodes.

@@ -24,23 +24,29 @@
     templateUrl: 'toolbar.component.html',

     styleUrls: ['./toolbar.component.css']

 })

-export class ToolbarComponent implements AfterViewInit {

+export class ToolbarComponent implements AfterViewInit, OnInit {

+    public nodeTypes = [];

 

-    constructor(private jsPlumbService: JsPlumbService, private workflowService: WorkflowService) {

+    constructor(private jsPlumbService: JsPlumbService) {

     }

 

     public ngAfterViewInit() {

         this.jsPlumbService.buttonDraggable();

     }

 

-    public save() {

-        this.workflowService.save().subscribe(success => {

-            if(success) {

-                console.log(`save workflow success`);

-            } else {

-                console.log(`save workflow failed`);

-            }

-        });

+    ngOnInit(): void {

+        this.getNodeTypes();

     }

 

+    private getNodeTypes() {

+        for(let key in NodeType) {

+            if (typeof NodeType[key] === 'number') {

+                this.nodeTypes.push(key);

+            }

+        }

+    }

+

+    public getNameByType(type:string):string{

+        return type.replace(type.charAt(0), type.charAt(0).toUpperCase());

+    }

 }

diff --git a/sdc-workflow-designer-ui/src/app/model/workflow/node-type.enum.ts b/sdc-workflow-designer-ui/src/app/model/workflow/node-type.enum.ts
index 994b3b6..c8d2fe2 100644
--- a/sdc-workflow-designer-ui/src/app/model/workflow/node-type.enum.ts
+++ b/sdc-workflow-designer-ui/src/app/model/workflow/node-type.enum.ts
@@ -13,10 +13,8 @@
 export enum NodeType {
     startEvent,
     endEvent,
-    toscaNodeManagementTask,
     restTask,
+    intermediateCatchEvent,
     exclusiveGateway,
     parallelGateway,
-    subProcess,
-    intermediateCatchEvent,
 }
diff --git a/sdc-workflow-designer-ui/src/app/model/workflow/position.ts b/sdc-workflow-designer-ui/src/app/model/workflow/position.ts
index b690f4d..7f3fe6f 100644
--- a/sdc-workflow-designer-ui/src/app/model/workflow/position.ts
+++ b/sdc-workflow-designer-ui/src/app/model/workflow/position.ts
@@ -17,5 +17,5 @@
  * Workflow node position

  */

 export class Position {

-    constructor(public top: number, public left: number, public width?: number, public height?: number) { }

+    constructor(public top: number, public left: number, public width: number = 200, public height: number = 100) { }

 }

diff --git a/sdc-workflow-designer-ui/src/app/services/jsplumb.service.ts b/sdc-workflow-designer-ui/src/app/services/jsplumb.service.ts
index 8d3d655..0863fb5 100644
--- a/sdc-workflow-designer-ui/src/app/services/jsplumb.service.ts
+++ b/sdc-workflow-designer-ui/src/app/services/jsplumb.service.ts
@@ -114,8 +114,9 @@
             drop: event => {

                 const el = this.jsplumbInstance.getSelector(event.drag.el);

                 const type = el.attributes.nodeType.value;

-                const left = event.e.clientX - event.drop.position[0];

-                const top = event.e.clientY - event.drop.position[1];

+                // Mouse position minus drop canvas start position and minus icon half size

+                const left = event.e.clientX - 220 - (event.e.offsetX / 2);

+                const top = event.e.clientY - 70 - (event.e.offsetY / 2);

 

                 this.workflowService.addNode(type, type, top, left);

             },

diff --git a/sdc-workflow-designer-ui/src/app/services/workflow.service.ts b/sdc-workflow-designer-ui/src/app/services/workflow.service.ts
index a36b51a..09e0e55 100644
--- a/sdc-workflow-designer-ui/src/app/services/workflow.service.ts
+++ b/sdc-workflow-designer-ui/src/app/services/workflow.service.ts
@@ -34,6 +34,7 @@
     }

 

     public save(): Observable<boolean> {

+        console.log(this.workflow);

         return this.dataAccessService.catalogService.saveWorkflow(this.workflow);

     }

 

diff --git a/sdc-workflow-designer-ui/src/styles.css b/sdc-workflow-designer-ui/src/styles.css
index 9438803..30d6d11 100644
--- a/sdc-workflow-designer-ui/src/styles.css
+++ b/sdc-workflow-designer-ui/src/styles.css
@@ -13,5 +13,4 @@
  body, html {
      height: 100%;
      margin: 0px;
-     background-color: cadetblue;
  }