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) {
28 this.slicing_order_info.coverageArea.split(" ").join(";")
32 this.AreaFormatting(areaList);
35 COMMUNICATION_FORM_ITEMS.forEach((item, index) => {
36 if (item.key == "coverageAreaNumber") {
37 item["coverflag"] = flag == true ? false : true;
42 @Input() showModel: boolean;
43 @Input() modelParams: any;
44 @Output() cancel = new EventEmitter<boolean>();
45 comunicationFormItems = COMMUNICATION_FORM_ITEMS;
46 slicing_order_info = {
52 resourceSharingLevel: "shared",
53 uEMobilityLevel: "stationary",
55 coverageAreaNumber: null,
58 validateRulesShow: any[] = [];
59 rulesText: any[] = [];
60 areaLevel: number = 4;
61 masktext: string = MASKTEXT;
62 loading: boolean = false;
63 AreaFormatting(areaList): void {
64 this.areaList = areaList.map((item: any) => {
65 let arr = item.split(";");
66 item = arr.map((it, index) => {
70 } else if (index === 1) {
72 } else if (index === 2) {
80 obj.options = [{ name: it, id: it }];
87 handleCancel(): void {
88 this.showModel = false;
89 this.cancel.emit(this.showModel);
90 this.slicing_order_info = {
96 resourceSharingLevel: "shared",
97 uEMobilityLevel: "stationary",
99 coverageAreaNumber: null,
101 this.validateRulesShow = [];
105 const coverage_list: string[] = [];
107 COMMUNICATION_FORM_ITEMS.forEach((item, index) => {
108 if (item.required && item.type === "input") {
112 this.slicing_order_info[item.key],
115 this.validateRulesShow
119 if (this.validateRulesShow.indexOf(true) > -1) {
122 for (const key in this.areaList) {
123 const value = this.areaList[key];
125 for (const val of value) {
127 str += area.selected + ";";
128 if (!area.selected) {
129 this.message.error("Please complete the form");
133 coverage_list.push(str.substring(0, str.length - 1));
135 if (coverage_list.length > 1) {
136 coverageAreas = coverage_list.join("|");
138 coverageAreas = coverage_list.toString();
140 const coverageAreaNumber = this.slicing_order_info[
143 if (coverageAreaNumber) {
144 this.slicing_order_info.coverageArea = `${coverageAreas}-${coverageAreaNumber}`;
146 this.slicing_order_info.coverageArea = `${coverageAreas}`;
148 delete this.slicing_order_info.coverageAreaNumber;
151 slicing_order_info: this.slicing_order_info,
153 const csmfSlicingPurchaseFailedCallback = () => {
158 .csmfSlicingPurchase(paramsObj, csmfSlicingPurchaseFailedCallback)
160 const result = res.result_header;
163 result.result_code &&
164 +result.result_code === 200
168 this.message.create("error", "Network error");
170 this.loading = false;