summaryrefslogtreecommitdiffstats
path: root/sdc-workflow-designer-ui/src/app/components/menu/microservice/microservice-list
diff options
context:
space:
mode:
Diffstat (limited to 'sdc-workflow-designer-ui/src/app/components/menu/microservice/microservice-list')
-rw-r--r--sdc-workflow-designer-ui/src/app/components/menu/microservice/microservice-list/microservice-list.component.css15
-rw-r--r--sdc-workflow-designer-ui/src/app/components/menu/microservice/microservice-list/microservice-list.component.html32
-rw-r--r--sdc-workflow-designer-ui/src/app/components/menu/microservice/microservice-list/microservice-list.component.ts64
3 files changed, 111 insertions, 0 deletions
diff --git a/sdc-workflow-designer-ui/src/app/components/menu/microservice/microservice-list/microservice-list.component.css b/sdc-workflow-designer-ui/src/app/components/menu/microservice/microservice-list/microservice-list.component.css
new file mode 100644
index 00000000..f403890e
--- /dev/null
+++ b/sdc-workflow-designer-ui/src/app/components/menu/microservice/microservice-list/microservice-list.component.css
@@ -0,0 +1,15 @@
+/**
+ * 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
+ */
+
+ .swagger-list{
+ overflow: auto;
+ } \ No newline at end of file
diff --git a/sdc-workflow-designer-ui/src/app/components/menu/microservice/microservice-list/microservice-list.component.html b/sdc-workflow-designer-ui/src/app/components/menu/microservice/microservice-list/microservice-list.component.html
new file mode 100644
index 00000000..ce4730f7
--- /dev/null
+++ b/sdc-workflow-designer-ui/src/app/components/menu/microservice/microservice-list/microservice-list.component.html
@@ -0,0 +1,32 @@
+<!--
+/**
+ * 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="scroll" style="overflow:hidden; max-height: 300px; height: 300px;">
+ <div class="card">
+ <div class="card-header d-flex justify-content-between align-items-center">
+ <span>Config List</span>
+ <span class="badge badge-success badge-pill" (click)="addMicroservice()"><i class="fa fa-plus"></i></span>
+ </div>
+
+ <ul class="list-group">
+ <li class="list-group-item d-flex justify-content-between align-items-center"
+ *ngFor="let microservice of microservices; index as i">
+ <div (click)="onMicroserviceSelected(microservice)">{{microservice.name}}</div>
+ <div class="badge badge-danger badge-pill" (click)="deleteMicroservice(i, microservice)">
+ <i class="fa fa-minus"></i>
+ </div>
+ </li>
+ </ul>
+ </div>
+</div>
+
diff --git a/sdc-workflow-designer-ui/src/app/components/menu/microservice/microservice-list/microservice-list.component.ts b/sdc-workflow-designer-ui/src/app/components/menu/microservice/microservice-list/microservice-list.component.ts
new file mode 100644
index 00000000..2e22699d
--- /dev/null
+++ b/sdc-workflow-designer-ui/src/app/components/menu/microservice/microservice-list/microservice-list.component.ts
@@ -0,0 +1,64 @@
+/**
+ * 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, EventEmitter, Input, Output, ViewChild } from '@angular/core';
+import { ModalDirective } from 'ngx-bootstrap/modal';
+
+import { Microservice } from '../../../../model/workflow/microservice';
+
+/**
+ * toolbar component contains some basic operations(save) and all of the supported workflow nodes.
+ * The supported nodes can be dragged to container component. which will add a new node to the workflow.
+ */
+@Component({
+ selector: 'b4t-microservice-list',
+ templateUrl: 'microservice-list.component.html',
+})
+export class MicroserviceListComponent {
+ @Input() microservices: Microservice[];
+ @Output() microserviceSelected = new EventEmitter<Microservice>();
+
+ public onMicroserviceSelected(microservice: Microservice) {
+ this.microserviceSelected.emit(microservice);
+ }
+
+ public addMicroservice() {
+ const microservice = new Microservice('new microservice', '', {});
+ this.microservices.push(microservice);
+
+ this.onMicroserviceSelected(microservice);
+ }
+
+ public deleteMicroservice(index: number, microservice: Microservice) {
+ this.deleteMicroService(microservice.name, microservice.version);
+
+ // set the next microservice selected
+ let selectedMicroservice;
+ if (this.microservices.length > 0) {
+ if (this.microservices[index]) {
+ selectedMicroservice = this.microservices[index];
+ } else {
+ selectedMicroservice = this.microservices[index - 1];
+ }
+ }
+ this.onMicroserviceSelected(selectedMicroservice);
+ }
+
+ private deleteMicroService(name: string, version: string) {
+ const index = this.microservices.findIndex(service => (service.name === name && service.version === version));
+ if(index !== -1) {
+ return this.microservices.splice(index, 1)[0];
+ }
+
+ return undefined;
+ }
+}