From e0597dc5b0a3718aa3b5991a65096c609d23dba2 Mon Sep 17 00:00:00 2001 From: Lvbo163 Date: Thu, 31 Aug 2017 19:43:52 +0800 Subject: 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 --- .../src/app/components/canvas/canvas.component.css | 2 +- .../src/app/components/menus/menu.component.css | 19 +++++ .../src/app/components/menus/menu.component.html | 20 +++++ .../app/components/menus/menu.component.spec.ts | 36 ++++++++ .../src/app/components/menus/menu.component.ts | 33 ++++++++ .../src/app/components/node/node.component.css | 54 +++++++++--- .../src/app/components/node/node.component.html | 58 ++++++------- .../src/app/components/node/node.component.ts | 8 ++ .../app/components/toolbar/toolbar.component.css | 95 ++++++++++++++++++++-- .../app/components/toolbar/toolbar.component.html | 12 ++- .../app/components/toolbar/toolbar.component.ts | 28 ++++--- 11 files changed, 300 insertions(+), 65 deletions(-) create mode 100644 sdc-workflow-designer-ui/src/app/components/menus/menu.component.css create mode 100644 sdc-workflow-designer-ui/src/app/components/menus/menu.component.html create mode 100644 sdc-workflow-designer-ui/src/app/components/menus/menu.component.spec.ts create mode 100644 sdc-workflow-designer-ui/src/app/components/menus/menu.component.ts (limited to 'sdc-workflow-designer-ui/src/app/components') 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 @@ + + +
+ + +
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; + + 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, "); } -.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 */ --> +
+
+ {{getDisplayName()}} +
-
-
- -
-
- - - - -
-
- - - - -
-
- - - - -
-
- - - - -
+
+ + + + +
+
+ + + + +
+
+ + + + +
+
+ + + + +
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, "); +} + +.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 @@ -->
- - - -
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()); + } } -- cgit 1.2.3-korg