From 125fb9b3811f9f580997545f92c93e0a01271abe Mon Sep 17 00:00:00 2001 From: liuwh7 Date: Fri, 4 Mar 2022 14:13:19 +0800 Subject: feat:intentBasedService predict Signed-off-by: liuwh7 Change-Id: I08e0d7a5141325f830bf522b42894b399ea6e7af Issue-ID: REQ-1075 --- .../cloud-leased-line-modal.component.html | 6 +- .../intent-based-predict.component.html | 42 +++++++++++++ .../intent-based-predict.component.less | 22 +++++++ .../intent-based-predict.component.spec.ts | 25 ++++++++ .../intent-based-predict.component.ts | 73 ++++++++++++++++++++++ .../intent-based-services.component.html | 7 ++- .../smart-cloud-leased-modal.component.ts | 11 +++- .../business-order/business-order.component.ts | 10 ++- .../input-business-order.component.ts | 12 +++- 9 files changed, 194 insertions(+), 14 deletions(-) create mode 100644 usecaseui-portal/src/app/views/services/intent-based-services/intent-based-predict/intent-based-predict.component.html create mode 100644 usecaseui-portal/src/app/views/services/intent-based-services/intent-based-predict/intent-based-predict.component.less create mode 100644 usecaseui-portal/src/app/views/services/intent-based-services/intent-based-predict/intent-based-predict.component.spec.ts create mode 100644 usecaseui-portal/src/app/views/services/intent-based-services/intent-based-predict/intent-based-predict.component.ts (limited to 'usecaseui-portal/src/app/views') diff --git a/usecaseui-portal/src/app/views/services/intent-based-services/cloud-leased-line-modal/cloud-leased-line-modal.component.html b/usecaseui-portal/src/app/views/services/intent-based-services/cloud-leased-line-modal/cloud-leased-line-modal.component.html index 2fe58cfc..b436bf32 100644 --- a/usecaseui-portal/src/app/views/services/intent-based-services/cloud-leased-line-modal/cloud-leased-line-modal.component.html +++ b/usecaseui-portal/src/app/views/services/intent-based-services/cloud-leased-line-modal/cloud-leased-line-modal.component.html @@ -50,8 +50,8 @@ @@ -59,7 +59,7 @@
{{item.nodeName}}: +
+
+ + + + + +
+
+
+ +
+ + +
diff --git a/usecaseui-portal/src/app/views/services/intent-based-services/intent-based-predict/intent-based-predict.component.less b/usecaseui-portal/src/app/views/services/intent-based-services/intent-based-predict/intent-based-predict.component.less new file mode 100644 index 00000000..e71b27cc --- /dev/null +++ b/usecaseui-portal/src/app/views/services/intent-based-services/intent-based-predict/intent-based-predict.component.less @@ -0,0 +1,22 @@ +.subnet_params_container { + // padding-left: 3%; + // padding-right: 3%; + .form_class { + padding: 0 100px; + } + .submit { + text-align: center; + margin-top: 30px; + } +} +.ant-form-item { + margin-top: 20px; + margin-bottom: -5px; +} + +.validateRules{ + color: red; +} +.error-input-border{ + border-color: red!important; +} \ No newline at end of file diff --git a/usecaseui-portal/src/app/views/services/intent-based-services/intent-based-predict/intent-based-predict.component.spec.ts b/usecaseui-portal/src/app/views/services/intent-based-services/intent-based-predict/intent-based-predict.component.spec.ts new file mode 100644 index 00000000..ffdd130f --- /dev/null +++ b/usecaseui-portal/src/app/views/services/intent-based-services/intent-based-predict/intent-based-predict.component.spec.ts @@ -0,0 +1,25 @@ +import { async, ComponentFixture, TestBed } from '@angular/core/testing'; + +import { InputBusinessOrderComponent } from './input-business-order.component'; + +describe('InputBusinessOrderComponent', () => { + let component: InputBusinessOrderComponent; + let fixture: ComponentFixture; + + beforeEach(async(() => { + TestBed.configureTestingModule({ + declarations: [ InputBusinessOrderComponent ] + }) + .compileComponents(); + })); + + beforeEach(() => { + fixture = TestBed.createComponent(InputBusinessOrderComponent); + component = fixture.componentInstance; + fixture.detectChanges(); + }); + + it('should create', () => { + expect(component).toBeTruthy(); + }); +}); diff --git a/usecaseui-portal/src/app/views/services/intent-based-services/intent-based-predict/intent-based-predict.component.ts b/usecaseui-portal/src/app/views/services/intent-based-services/intent-based-predict/intent-based-predict.component.ts new file mode 100644 index 00000000..d88afa9c --- /dev/null +++ b/usecaseui-portal/src/app/views/services/intent-based-services/intent-based-predict/intent-based-predict.component.ts @@ -0,0 +1,73 @@ +import { Component, OnInit } from '@angular/core'; +import { NzMessageService } from 'ng-zorro-antd'; +import { intentBaseService } from '../../../../core/services/intentBase.service'; + +@Component({ + selector: 'app-intent-based-predict', + templateUrl: './intent-based-predict.component.html', + styleUrls: ['./intent-based-predict.component.less'] +}) +export class IntentBasedPredictComponent implements OnInit { + + constructor( + private myhttp: intentBaseService, + private msg: NzMessageService + ) {} + + // textarea input predict param + communicationMessage: String = ""; + // button loading + isConfirmCreating: boolean = false; + // modal param + modalParam: Object = {}; + // cloud modal show flag + cloudModalShowFlag: boolean = false; + // business modal show flag + businessModalShowFlag: boolean = false; + + ngOnInit() { + this.communicationMessage = ''; + } + + ngOnChange() {} + + submitFormMessage(): void { + this.isConfirmCreating = true; + this.myhttp.intentBasedUnifyPredict({ + "text": this.communicationMessage + }).subscribe( + (response) => { + this.isConfirmCreating = false; + const { code, message, data: { type, formData } } = response; + if (code !== 200) { + this.msg.error(message); + return; + } + + this.modalParam = { + ...formData, + intentContent: this.communicationMessage + }; + + if (type === 'ccvpn') { + this.cloudModalShowFlag = true; + } + + if (type === '5gs') { + this.businessModalShowFlag = true; + } + }, + (err) => { + this.isConfirmCreating = false; + console.log(err); + } + ) + } + + modalClose() { + this.cloudModalShowFlag = false; + this.businessModalShowFlag = false; + this.modalParam = {}; + this.communicationMessage = ''; + } +} diff --git a/usecaseui-portal/src/app/views/services/intent-based-services/intent-based-services.component.html b/usecaseui-portal/src/app/views/services/intent-based-services/intent-based-services.component.html index cd7e0fa7..e4262859 100644 --- a/usecaseui-portal/src/app/views/services/intent-based-services/intent-based-services.component.html +++ b/usecaseui-portal/src/app/views/services/intent-based-services/intent-based-services.component.html @@ -1,7 +1,12 @@ + + + \ No newline at end of file diff --git a/usecaseui-portal/src/app/views/services/intent-based-services/smart-cloud-leased-modal/smart-cloud-leased-modal.component.ts b/usecaseui-portal/src/app/views/services/intent-based-services/smart-cloud-leased-modal/smart-cloud-leased-modal.component.ts index e91c57e7..8f9fd47c 100644 --- a/usecaseui-portal/src/app/views/services/intent-based-services/smart-cloud-leased-modal/smart-cloud-leased-modal.component.ts +++ b/usecaseui-portal/src/app/views/services/intent-based-services/smart-cloud-leased-modal/smart-cloud-leased-modal.component.ts @@ -63,7 +63,16 @@ export class SmartCloudLeasedModalComponent implements OnInit { }; this.myhttp.intentInstancePredict(params).subscribe( (response) => { - this.handleCancel(false, response); + const { code, message, data } = response; + if (code !== 200) { + this.msg.error(message); + return; + } + let orderForm = { + ...data, + intentContent: this.communicationMessage + }; + this.handleCancel(false, orderForm); }, (err) => { console.log(err); diff --git a/usecaseui-portal/src/app/views/services/slicing-management/csmf-slicing-business-management/business-order/business-order.component.ts b/usecaseui-portal/src/app/views/services/slicing-management/csmf-slicing-business-management/business-order/business-order.component.ts index 9c3fe319..aa5a5db1 100644 --- a/usecaseui-portal/src/app/views/services/slicing-management/csmf-slicing-business-management/business-order/business-order.component.ts +++ b/usecaseui-portal/src/app/views/services/slicing-management/csmf-slicing-business-management/business-order/business-order.component.ts @@ -1,8 +1,8 @@ import { Component, EventEmitter, Input, OnInit, Output } from "@angular/core"; -import { COMMUNICATION_FORM_ITEMS, MASKTEXT } from "./constants"; -import { Util } from "../../../../../shared/utils/utils"; -import { SlicingTaskServices } from "../../../../../core/services/slicingTaskServices"; import { NzMessageService } from "ng-zorro-antd"; +import { SlicingTaskServices } from "../../../../../core/services/slicingTaskServices"; +import { Util } from "../../../../../shared/utils/utils"; +import { COMMUNICATION_FORM_ITEMS, MASKTEXT } from "./constants"; @Component({ selector: "app-business-order", @@ -24,9 +24,7 @@ export class BusinessOrderComponent implements OnInit { this.slicing_order_info = { ...this.modelParams }; if (this.slicing_order_info.coverageArea) { areaList = []; - areaList.push( - this.slicing_order_info.coverageArea.split(" ").join(";") - ); + areaList.push(this.slicing_order_info.coverageArea); } } this.AreaFormatting(areaList); diff --git a/usecaseui-portal/src/app/views/services/slicing-management/csmf-slicing-business-management/input-business-order/input-business-order.component.ts b/usecaseui-portal/src/app/views/services/slicing-management/csmf-slicing-business-management/input-business-order/input-business-order.component.ts index e64f687f..7b4d9d1b 100644 --- a/usecaseui-portal/src/app/views/services/slicing-management/csmf-slicing-business-management/input-business-order/input-business-order.component.ts +++ b/usecaseui-portal/src/app/views/services/slicing-management/csmf-slicing-business-management/input-business-order/input-business-order.component.ts @@ -79,12 +79,18 @@ export class InputBusinessOrderComponent implements OnInit {     "text": this.communicationMessage }; this.myhttp["analysisInputText"](params) - .subscribe((data) => { + .subscribe((response) => { this.clickRepeat = false; - if (data === 0) { + const { code, message, data } = response; + if (code !== 200) { + this.msg.error(message); return; } - let orderForm = { ...data }; + + let orderForm = { + ...data, + intentContent: this.communicationMessage + }; this.communicationMessage = ""; this.showModel = false; this.modalOpreation.emit({ "cancel": false, "param": orderForm }); -- cgit 1.2.3-korg