aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorcyuamber <xuranyjy@chinamobile.com>2019-12-24 17:30:00 +0800
committercyuamber <xuranyjy@chinamobile.com>2019-12-24 17:30:07 +0800
commit1be0c93494c5b5c6479048330c48e51b80ae1f1c (patch)
treeea29e730be67e0eebe0b5f608c30b415e6e88b82
parent759713eb1eda7136c8e312267a11d0c8ee54922c (diff)
feat:Optimize progress interface polling and progress bar display
Change-Id: I8b3e84f248393796c7c5fa9c2c6d684bbb28abf9 Issue-ID: USECASEUI-369 Signed-off-by: cyuamber <xuranyjy@chinamobile.com>
-rw-r--r--usecaseui-portal/package-lock.json8
-rw-r--r--usecaseui-portal/src/app/views/services/slicing-management/slicing-resource-management/slicing-business-management/slicing-business-table/slicing-business-table.component.html4
-rw-r--r--usecaseui-portal/src/app/views/services/slicing-management/slicing-resource-management/slicing-business-management/slicing-business-table/slicing-business-table.component.ts104
3 files changed, 51 insertions, 65 deletions
diff --git a/usecaseui-portal/package-lock.json b/usecaseui-portal/package-lock.json
index 00333f75..b311f2be 100644
--- a/usecaseui-portal/package-lock.json
+++ b/usecaseui-portal/package-lock.json
@@ -3950,8 +3950,7 @@
"code-point-at": {
"version": "1.1.0",
"bundled": true,
- "dev": true,
- "optional": true
+ "dev": true
},
"concat-map": {
"version": "0.0.1",
@@ -4079,8 +4078,7 @@
"inherits": {
"version": "2.0.3",
"bundled": true,
- "dev": true,
- "optional": true
+ "dev": true
},
"ini": {
"version": "1.3.5",
@@ -4092,7 +4090,6 @@
"version": "1.0.0",
"bundled": true,
"dev": true,
- "optional": true,
"requires": {
"number-is-nan": "^1.0.0"
}
@@ -4380,7 +4377,6 @@
"version": "3.0.1",
"bundled": true,
"dev": true,
- "optional": true,
"requires": {
"ansi-regex": "^2.0.0"
}
diff --git a/usecaseui-portal/src/app/views/services/slicing-management/slicing-resource-management/slicing-business-management/slicing-business-table/slicing-business-table.component.html b/usecaseui-portal/src/app/views/services/slicing-management/slicing-resource-management/slicing-business-management/slicing-business-table/slicing-business-table.component.html
index 006a6d73..535ee012 100644
--- a/usecaseui-portal/src/app/views/services/slicing-management/slicing-resource-management/slicing-business-management/slicing-business-table/slicing-business-table.component.html
+++ b/usecaseui-portal/src/app/views/services/slicing-management/slicing-resource-management/slicing-business-management/slicing-business-table/slicing-business-table.component.html
@@ -57,12 +57,12 @@
[nzDisabled]="data.last_operation_progress !== 100"
(ngModelChange)="switchChange(data,i)"
></nz-switch>
- <nz-progress *ngIf="data.last_operation_progress !== 100 && data.orchestration_status !== 'delete'"
+ <nz-progress *ngIf="data.last_operation_progress !== 100 && data.last_operation_type !== 'delete'"
[nzPercent]="data.last_operation_progress"
[nzShowInfo]="false" nzStatus="active"></nz-progress>
</div>
<div class="action-icon">
- <i [ngClass]="{'cannotclick':data.last_operation_progress !== 100 || data.orchestration_status==='activated'}"
+ <i [ngClass]="{'cannotclick':(data.last_operation_progress !== 100 && data.last_operation_type !== 'delete') || data.orchestration_status==='activated'}"
nz-icon
nzType="poweroff"
nzTheme="outline"
diff --git a/usecaseui-portal/src/app/views/services/slicing-management/slicing-resource-management/slicing-business-management/slicing-business-table/slicing-business-table.component.ts b/usecaseui-portal/src/app/views/services/slicing-management/slicing-resource-management/slicing-business-management/slicing-business-table/slicing-business-table.component.ts
index b4f2edbd..2dd1f0c8 100644
--- a/usecaseui-portal/src/app/views/services/slicing-management/slicing-resource-management/slicing-business-management/slicing-business-table/slicing-business-table.component.ts
+++ b/usecaseui-portal/src/app/views/services/slicing-management/slicing-resource-management/slicing-business-management/slicing-business-table/slicing-business-table.component.ts
@@ -1,7 +1,7 @@
import {Component, OnInit, ViewChild} from '@angular/core';
import {SlicingTaskServices} from '.././../../../../../core/services/slicingTaskServices';
import {BUSINESS_STATUS} from '../../../../../../../constants/constants';
-import { NzModalService } from 'ng-zorro-antd';
+import { NzModalService,NzMessageService } from 'ng-zorro-antd';
import { SlicingBusinessModelComponent } from '../slicing-business-model/slicing-business-model.component';
@Component({
selector: 'app-slicing-business-table',
@@ -12,7 +12,8 @@ export class SlicingBusinessTableComponent implements OnInit {
constructor(
private myhttp: SlicingTaskServices,
- private modalService: NzModalService
+ private modalService: NzModalService,
+ private message: NzMessageService
) {
}
@@ -53,15 +54,16 @@ export class SlicingBusinessTableComponent implements OnInit {
if (+result_code === 200) {
this.total = record_number;
this.loading = false;
- this.listOfData = slicing_business_list.map((item)=>{
- if(item.last_operation_progress < 100){
+ this.listOfData = slicing_business_list.map((item,index)=>{
+ if(item.last_operation_progress!==null && item.last_operation_progress < 100 && item.last_operation_type!==null){
let updata = (prodata) => {
item.last_operation_progress = prodata.operation_progress || item.last_operation_progress;
};
let obj = {
serviceId: item.service_instance_id
};
- this.queryProgress(obj, updata).then((res) => {
+ if(item.last_operation_type === 'delete')this.terminateStart = true;
+ this.queryProgress(obj,item.orchestration_status,index, updata).then((res) => {
item.last_operation_progress = 100;
})
}
@@ -113,35 +115,22 @@ export class SlicingBusinessTableComponent implements OnInit {
this.myhttp.changeActivateSlicingService(paramsObj,isActivate).subscribe (res => {
const { result_header: { result_code, result_message }, result_body: { operation_id } } = res;
if (+result_code === 200) {
- slicing.last_operation_progress = 0;
- slicing.orchestration_status = activateValue;
- console.log(operation_id,"operation_id");
- let obj = {
- serviceId: slicing.service_instance_id
- };
- let updata = (prodata) => {
- slicing.last_operation_progress = prodata.progress || 0;
- slicing.orchestration_status = prodata.operation_type || activateValue;
- };
- this.queryProgress(obj, updata).then(() => {
- slicing.last_operation_progress = 100;
- slicing.orchestration_status = finished;
- this.notification1.notificationSuccess('slicing business', finished, slicing.service_instance_id);
- this.getBusinessList();
- })
+ this.notification1.notificationSuccess('slicing business', finished, slicing.service_instance_id);
+ this.getBusinessList();
}else {
let singleSlicing = Object.assign({},this.listOfData[index]);
this.listOfData[index] = singleSlicing;
this.listOfData = [...this.listOfData];
this.notification1.notificationFailed('slicing business', finished, slicing.service_instance_id);
- console.error(result_message);
+ this.getBusinessList();
}
- },(err) => {
+ this.getBusinessList();
+ },() => {
let singleSlicing = Object.assign({},this.listOfData[index]);
this.listOfData[index] = singleSlicing;
this.listOfData = [...this.listOfData];
this.notification1.notificationFailed('slicing business', finished, slicing.service_instance_id);
- console.error(err);
+ this.getBusinessList();
})
}
terminate(slicing){
@@ -157,32 +146,14 @@ export class SlicingBusinessTableComponent implements OnInit {
this.myhttp.terminateSlicingService(paramsObj).subscribe (res => {
const { result_header: { result_code, result_message }, result_body: { operation_id } } = res;
if (+result_code === 200) {
- slicing.last_operation_progress = 0;
- slicing.orchestration_status = 'delete';
- console.log(operation_id,"operation_id");
- let obj = {
- serviceId: slicing.service_instance_id
- };
- let updata = (prodata) => {
- slicing.last_operation_progress = prodata.progress || 0;
- slicing.orchestration_status = prodata.operation_type || "delete";
- };
- this.queryProgress(obj, updata).then(() => {
- slicing.last_operation_progress = 100;
- slicing.orchestration_status = "delete";
- this.notification1.notificationSuccess('slicing business', 'terminate', slicing.service_instance_id);
- this.terminateStart = false;
- this.getBusinessList();
- })
+ this.getBusinessList();
}else {
this.notification1.notificationFailed('slicing business', 'terminate', slicing.service_instance_id);
this.terminateStart = false;
- console.error(result_message)
}
- },(err) => {
+ },() => {
this.notification1.notificationFailed('slicing business', 'terminate', slicing.service_instance_id);
this.terminateStart = false;
- console.error(err)
})
},
nzCancelText: 'No',
@@ -203,28 +174,47 @@ export class SlicingBusinessTableComponent implements OnInit {
}
})
}
- queryProgress(obj, callback) {
+ queryProgress(obj,action,index,callback) {
return new Promise( res => {
let requery = () => {
this.myhttp.getSlicingBusinessProgress(obj)
.subscribe((data) => {
- if (data.result_body.operation_progress < 100) {
- callback(data.result_body);
- let progressSetTimeOut = setTimeout(() => {
- requery();
- },5000);
- this.progressingTimer.push({
- id:obj.serviceId,
- timer:progressSetTimeOut
- })
- } else {
+ const { result_header: { result_code, result_message }, result_body: { operation_id } } = data;
+ if (+result_code === 200) {
+ if (data.result_body.operation_progress < 100) {
+ callback(data.result_body);
+ let progressSetTimeOut = setTimeout(() => {
+ requery();
+ }, 5000);
+ this.progressingTimer.push({
+ id: obj.serviceId,
+ timer: progressSetTimeOut
+ })
+ } else {
+ this.progressingTimer.forEach((item) => {
+ if (item.serviceId === obj.serviceId) {
+ clearInterval(item.timer);
+ }
+ });
+ res(data.result_body);
+ }
+ }else {
this.progressingTimer.forEach((item) => {
- if(item.serviceId === obj.serviceId){
+ if (item.serviceId === obj.serviceId) {
clearInterval(item.timer);
}
});
- res(data.result_body);
+ this.getBusinessList();
+ this.message.error(result_message);
}
+ },(err) => {
+ this.progressingTimer.forEach((item) => {
+ if (item.serviceId === obj.serviceId) {
+ clearInterval(item.timer);
+ }
+ });
+ this.getBusinessList();
+ this.message.error(err);
})
};
requery();