1 import { Component, EventEmitter, Input, OnInit, Output } from "@angular/core";
2 import { COMMUNICATION_FORM_ITEMS,MASKTEXT } from "./constants";
3 import { Util } from "../../../../../shared/utils/utils";
4 import { SlicingTaskServices } from "../../../../../core/services/slicingTaskServices";
5 import { NzMessageService } from "ng-zorro-antd";
8 selector: "app-business-order",
9 templateUrl: "./business-order.component.html",
10 styleUrls: ["./business-order.component.less"],
12 export class BusinessOrderComponent implements OnInit {
14 private myhttp: SlicingTaskServices,
15 private message: NzMessageService,
22 let areaList = ["Beijing;Beijing;Haidian District;Wanshoulu Street"];
23 if (this.modelParams && this.showModel) {
24 this.slicing_order_info = {...this.modelParams};
25 if (this.slicing_order_info.coverageArea) {
27 areaList.push(this.slicing_order_info.coverageArea.split(" ").join(";"));
30 this.AreaFormatting(areaList);
33 COMMUNICATION_FORM_ITEMS.forEach((item, index) => {
34 if(item.key=='coverageAreaNumber'){
35 item["coverflag"] = flag == true ? false:true
40 @Input() showModel: boolean;
41 @Input() modelParams: any;
42 @Output() cancel = new EventEmitter<boolean>();
43 comunicationFormItems = COMMUNICATION_FORM_ITEMS;
44 slicing_order_info = {
50 resourceSharingLevel: "shared",
51 uEMobilityLevel: "stationary",
53 coverageAreaNumber: null,
56 validateRulesShow: any[] = [];
57 rulesText: any[] = [];
58 areaLevel: number = 4;
59 masktext: string = MASKTEXT ;
60 AreaFormatting(areaList): void {
61 this.areaList = areaList.map((item: any) => {
62 let arr = item.split(";");
63 item = arr.map((it, index) => {
67 } else if (index === 1) {
69 } else if (index === 2) {
77 obj.options = [{ name: it, id: it }];
84 handleCancel(): void {
85 this.showModel = false;
86 this.cancel.emit(this.showModel);
87 this.slicing_order_info = {
93 resourceSharingLevel: "shared",
94 uEMobilityLevel: "stationary",
96 coverageAreaNumber: null,
98 this.validateRulesShow = [];
102 const coverage_list: string[] = [];
104 COMMUNICATION_FORM_ITEMS.forEach((item, index) => {
105 if (item.required && item.type === "input" ) {
109 this.slicing_order_info[item.key],
112 this.validateRulesShow
116 if (this.validateRulesShow.indexOf(true) > -1) {
119 for(const key in this.areaList){
120 const value = this.areaList[key]
122 for(const val of value){
124 str += area.selected + ";";
126 this.message.error("Please complete the form");
130 coverage_list.push(str.substring(0, str.length - 1));
132 if (coverage_list.length > 1) {
133 coverageAreas = coverage_list.join("|");
135 coverageAreas = coverage_list.toString();
137 const coverageAreaNumber = this.slicing_order_info[
140 if (coverageAreaNumber) {
141 this.slicing_order_info.coverageArea = `${coverageAreas}-${coverageAreaNumber}`;
143 this.slicing_order_info.coverageArea = `${coverageAreas}`;
145 delete this.slicing_order_info.coverageAreaNumber;
148 slicing_order_info: this.slicing_order_info,
150 const csmfSlicingPurchaseFailedCallback = () => {
155 .csmfSlicingPurchase(paramsObj, csmfSlicingPurchaseFailedCallback)
157 const result = res.result_header;
160 result.result_code &&
161 +result.result_code === 200
165 this.message.create("error", "Network error");