aboutsummaryrefslogtreecommitdiffstats
path: root/sdc-workflow-designer-ui/src/app/components
diff options
context:
space:
mode:
authorLvbo163 <lv.bo163@zte.com.cn>2017-08-31 19:43:52 +0800
committerLvbo163 <lv.bo163@zte.com.cn>2017-08-31 19:43:52 +0800
commite0597dc5b0a3718aa3b5991a65096c609d23dba2 (patch)
treef7b258112dfae0be3a51e5e6ea08189ce28f63fd /sdc-workflow-designer-ui/src/app/components
parent626d74e4c51aa47da5d5d643b5b7a04188b5552a (diff)
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>
Diffstat (limited to 'sdc-workflow-designer-ui/src/app/components')
-rw-r--r--sdc-workflow-designer-ui/src/app/components/canvas/canvas.component.css2
-rw-r--r--sdc-workflow-designer-ui/src/app/components/menus/menu.component.css19
-rw-r--r--sdc-workflow-designer-ui/src/app/components/menus/menu.component.html20
-rw-r--r--sdc-workflow-designer-ui/src/app/components/menus/menu.component.spec.ts36
-rw-r--r--sdc-workflow-designer-ui/src/app/components/menus/menu.component.ts33
-rw-r--r--sdc-workflow-designer-ui/src/app/components/node/node.component.css54
-rw-r--r--sdc-workflow-designer-ui/src/app/components/node/node.component.html58
-rw-r--r--sdc-workflow-designer-ui/src/app/components/node/node.component.ts8
-rw-r--r--sdc-workflow-designer-ui/src/app/components/toolbar/toolbar.component.css95
-rw-r--r--sdc-workflow-designer-ui/src/app/components/toolbar/toolbar.component.html12
-rw-r--r--sdc-workflow-designer-ui/src/app/components/toolbar/toolbar.component.ts28
11 files changed, 300 insertions, 65 deletions
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 fec14a47..bc889652 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 00000000..2fa48afa
--- /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 00000000..edee3618
--- /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 00000000..52f2c772
--- /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 00000000..347f1a24
--- /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 08b7322d..0d01835f 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,31 +207,65 @@
border-top: 4px white solid;
}
+.node .name {
+ padding: 10px 15px;
+}
+
+.node:hover {
+ border: 1px dotted #000;
+}
-.node .startEvent {
+.node.focus {
+ border: 1px dotted red;
+}
+
+.startEvent {
border-radius: 30px;
- background-size: cover;
border: 1px solid rgb(0, 0, 0);
+ background-size: cover;
height: 30px;
width: 30px;
+ /*background-image: url("");*/
}
-.node .endEvent {
+.endEvent {
border-radius: 30px;
- background-size: cover;
border: 2px solid rgb(0, 0, 0);
+ background-size: cover;
height: 30px;
width: 30px;
+ /*background-image: url("");*/
}
-.node .name {
- padding: 10px 15px;
+.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>");
}
-.node:hover {
- border: 1px dotted #000;
+.restTask {
+ border-radius: 8px;
+ border: 2px solid rgb(0, 0, 0);
+ font-size: 10px;
}
-.node.focus {
- border: 1px dotted red;
+.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 090f324d..62cd6f51 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 676ba998..c6a95961 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 @@ export class NodeComponent implements AfterViewInit {
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 94559eff..942ac586 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 91b935e9..bb52644f 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 1e1de191..71bf02ab 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 @@ import { WorkflowService } from "../../services/workflow.service";
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());
+ }
}