1 import { Component, EventEmitter, Input, OnInit, Output } from "@angular/core";
2 import { NzMessageService } from "ng-zorro-antd";
3 import { SlicingTaskServices } from "../../../../../core/services/slicingTaskServices";
4 import { Util } from "../../../../../shared/utils/utils";
5 import { COMMUNICATION_FORM_ITEMS, MASKTEXT } from "./constants";
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);
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 loading: boolean = false;
61 AreaFormatting(areaList): void {
62 this.areaList = areaList.map((item: any) => {
63 let arr = item.split(";");
64 item = arr.map((it, index) => {
68 } else if (index === 1) {
70 } else if (index === 2) {
78 obj.options = [{ name: it, id: it }];
85 handleCancel(): void {
86 this.showModel = false;
87 this.cancel.emit(this.showModel);
88 this.slicing_order_info = {
94 resourceSharingLevel: "shared",
95 uEMobilityLevel: "stationary",
97 coverageAreaNumber: null,
99 this.validateRulesShow = [];
103 const coverage_list: string[] = [];
105 COMMUNICATION_FORM_ITEMS.forEach((item, index) => {
106 if (item.required && item.type === "input") {
110 this.slicing_order_info[item.key],
113 this.validateRulesShow
117 if (this.validateRulesShow.indexOf(true) > -1) {
120 for (const key in this.areaList) {
121 const value = this.areaList[key];
123 for (const val of value) {
125 str += area.selected + ";";
126 if (!area.selected) {
127 this.message.error("Please complete the form");
131 coverage_list.push(str.substring(0, str.length - 1));
133 if (coverage_list.length > 1) {
134 coverageAreas = coverage_list.join("|");
136 coverageAreas = coverage_list.toString();
138 const coverageAreaNumber = this.slicing_order_info[
141 if (coverageAreaNumber) {
142 this.slicing_order_info.coverageArea = `${coverageAreas}-${coverageAreaNumber}`;
144 this.slicing_order_info.coverageArea = `${coverageAreas}`;
146 delete this.slicing_order_info.coverageAreaNumber;
149 slicing_order_info: this.slicing_order_info,
151 const csmfSlicingPurchaseFailedCallback = () => {
156 .csmfSlicingPurchase(paramsObj, csmfSlicingPurchaseFailedCallback)
158 const result = res.result_header;
161 result.result_code &&
162 +result.result_code === 200
166 this.message.create("error", "Network error");
168 this.loading = false;