import { HttpClient, HttpRequest, HttpResponse } from '@angular/common/http'; import { Component, OnInit, HostBinding } from '@angular/core'; // import { MyhttpService } from '../../myhttp.service'; import { onboardService } from '../../onboard.service'; import { slideToRight } from '../../animates'; import { NzMessageService, UploadFile, NzModalRef, NzModalService } from 'ng-zorro-antd'; import { filter } from 'rxjs/operators'; import { Title } from '@angular/platform-browser'; @Component({ selector: 'app-onboard-vnf-vm', templateUrl: './onboard-vnf-vm.component.html', styleUrls: ['./onboard-vnf-vm.component.less'], animations: [ slideToRight ] }) export class OnboardVnfVmComponent implements OnInit { @HostBinding('@routerAnimate') routerAnimateState; //url url = { // ns: 'http://ip:port/api/nsd/v1/ns_descriptors/{nsdInfoId}/nsd_content', // vnf: 'http://ip:port/api/vnfpkgm/v1/vnf_packages/{vnfPkgId}/package_content', // pnf: 'http://ip:port/api/nsd/v1/pnf_descriptors/{pnfdInfoId}/pnfd_content' ns: 'https://jsonplaceholder.typicode.com/posts/', vnf: 'https://jsonplaceholder.typicode.com/posts/', pnf: 'https://jsonplaceholder.typicode.com/posts/', }; // delete Modal confirmModal: NzModalRef; nsdInfoId = ''; vnfPkgId =''; pnfdInfoId = ''; tabTitle = "NS"; nsuploading = false; vnfuploading = false; pnfloading = false; fileListNS: UploadFile[] = []; fileListVNF: UploadFile[] = []; fileListPNF: UploadFile[] = []; // onboard initial value status = "Onboard Available"; constructor(private myhttp: onboardService, private http: HttpClient, private msg: NzMessageService,private titleService: Title,private modal: NzModalService, private modalService: NzModalService) { } //default 默认调用ns数据 ngOnInit() { this.getTableData(); } //表格数据 tableData:any; sdcData:any; vfcData:any; pageIndex = 1; pageSize = 10; total; nsloading = false; sortName = null; sortValue = null; tabs = ['NS', 'VNF', 'PNF']; isVisible = false; isOkLoading = false; showModal(): void { this.isVisible = true; } handleCancel(): void { this.isVisible = false; } // 处理tab切换 请求数据 handleTabChange(tab,nsdInfoId,url) { this.tabTitle = tab; console.log(tab); console.log(nsdInfoId); console.log(this.url); switch (tab) { case 'NS': // this.pageIndex = 1; // this.pageSize = 10; this.getTableData(); break case 'VNF': // this.pageIndex = 1; // this.pageSize = 10; this.getTableVnfData() break case 'PNF': // this.pageIndex = 1; // this.pageSize = 10; this.getTablePnfData() break } } //before put 创建--上传之前将文件拖拽到页面时 // requestBody = { // "userDefinedData": { // "additionalProp1": "string", // "additionalProp2": "string", // "additionalProp3": "string" // } // } // requestBody = {}; // ns beforeUpload beforeUploadNS = (file: UploadFile): boolean => { this.fileListNS.push(file); console.log('beforeUpload'); // this.myhttp.getCreatensData("createNetworkServiceData",requestBody)//线上 this.myhttp.getCreatensData("creatensDataNS") //本地 .subscribe((data) => { console.log("拖拽文件后返回的数据NS-->", data); this.nsdInfoId = data["id"]; console.log("拖拽文件后返回的数据的id-->",this.nsdInfoId); }, (err) => { console.log(err); }) return false; } //vnf beforeUpload beforeUploadVNF = (file: UploadFile): boolean => { this.fileListVNF.push(file); console.log('beforeUpload'); // this.myhttp.getCreatensData("createVnfData",requestBody)//线上 this.myhttp.getCreatensData("creatensDataVNF") //本地 .subscribe((data) => { console.log("拖拽文件后返回的数据VNF-->", data); this.vnfPkgId = data["id"]; console.log("拖拽文件后返回的数据的id-->",this.vnfPkgId); }, (err) => { console.log(err); }) return false; } // //pnf eforeUpload beforeUploadPNF = (file: UploadFile): boolean => { this.fileListPNF.push(file); console.log('beforeUpload'); // this.myhttp.getCreatensData("createPnfData",requestBody) //线上 this.myhttp.getCreatensData("creatensDataPNF") //本地 .subscribe((data) => { console.log("拖拽文件后返回的数据PNF-->", data); this.pnfdInfoId = data["id"]; console.log("拖拽文件后返回的数据的id-->",this.pnfdInfoId); }, (err) => { console.log(err); }) return false; } //拖拽后点击上传按钮 onClick (tab) { switch (tab) { case 'NS': console.log(this.nsdInfoId); // this.handleUpload('http://ip:port/api/nsd/v1/ns_descriptors/{nsdInfoId}/nsd_content'); this.handleUpload(this.url.ns, tab); this.getTableData(); break case 'VNF': console.log(this.vnfPkgId); // this.handleUpload('http://ip:port/api/vnfpkgm/v1/vnf_packages/{vnfPkgId}/package_content'); this.handleUpload(this.url.vnf, tab); this.getTableVnfData() break case 'PNF': console.log(this.pnfdInfoId); // this.handleUpload('http://ip:port/api/nsd/v1/pnf_descriptors/{pnfdInfoId}/pnfd_content'); this.handleUpload(this.url.pnf, tab); this.getTablePnfData(); break } } //put Upload 上传 handleUpload(url,tab): void { console.log('startUpload') const formData = new FormData(); // tslint:disable-next-line:no-any switch(tab) { case "NS": this.fileListNS.forEach((file: any) => { formData.append('files[]', file); }); this.nsuploading = true; break case "VNF": this.fileListVNF.forEach((file: any) => { formData.append('files[]', file); }); this.vnfuploading = true; break case "PNF": this.fileListPNF.forEach((file: any) => { formData.append('files[]', file); }); this.pnfloading = true; break } // this.nsuploading = true; // You can use any AJAX library you like const req = new HttpRequest('POST', url, formData, { reportProgress: true, withCredentials: true }); this.http .request(req) .pipe(filter(e => e instanceof HttpResponse)) .subscribe( (event: {}) => { this.changeUploadingSta(tab) console.log('upload successfully') this.msg.success('upload successfully.'); }, err => { this.changeUploadingSta(tab) console.log('upload failed') this.msg.error('upload failed.'); } ); } // 控制uploading的状态 changeUploadingSta(tab) { switch(tab) { case "NS": this.nsuploading = false; break case "VNF": this.vnfuploading = false; break case "PNF": this.pnfloading = false; } } //---------------------------------------------------------------------------------------------- // 获取NS列表 getTableData() { // 查询参数: 当前页码,每页条数,排序方式 let paramsObj = { pageIndex: this.pageIndex, pageSize: this.pageSize, nameSort: this.sortValue } //vfc this.myhttp.getOnboardTableData(paramsObj) .subscribe((data) => { console.log(data) this.total = data["body"].length; //body length console.log( this.total) // this.sdData = data.body.tableList; this.vfcData = data.body; console.log(typeof this.vfcData) console.log("NSlist-vfc-->",data.body) }, (err) => { console.log(err); }) // sdc this.myhttp.getSDC_NSTableData(paramsObj) .subscribe((data) => { console.log('NSlist-sdc-->',data) this.sdcData = data.body; this.tableData = this.MergeArray(this.vfcData, this.sdcData) // this.tableData = this.vfcData.concat(this.sdcData) }, (err) => { console.log(err); }) } // 获取vnf列表 getTableVnfData() { // 查询参数: 当前页码,每页条数,排序方式 let paramsObj = { pageIndex: this.pageIndex, pageSize: this.pageSize, // nameSort: this.sortValue } this.myhttp.getOnboardTableVnfData(paramsObj) .subscribe((data) => { console.log("vnfList-->", data); // this.total = data["body"]; //body length // console.log( this.total) this.vfcData = data.body; // this.tableData = data.body; console.log("vnfList-vfc-->",data.body) }, (err) => { console.log(err); }) // sdc this.myhttp.getSDC_VNFTableData() .subscribe((data) => { console.log('vnfList-sdc-->', data) this.sdcData = data; // this.tableData = this.vfcData.concat(this.sdcData) this.tableData = this.MergeArray(this.vfcData, this.sdcData) }, (err) => { console.log(err); }) } // 获取pnf列表 getTablePnfData() { // 查询参数: 当前页码,每页条数,排序方式 let paramsObj = { pageIndex: this.pageIndex, pageSize: this.pageSize, // nameSort: this.sortValue } this.myhttp.getOnboardTablePnfData(paramsObj) .subscribe((data) => { console.log("pnfList-->", data); this.total = data["body"]; //body length this.tableData = data.body; }, (err) => { console.log(err); }) } // sort(sort: { key: string, value: string }): void { // console.log(sort); // this.sortName = sort.key; // this.sortValue = sort.value; // this.getTableData(); // } //选择条数 // searchNsData(reset: boolean = false) { // console.log('dddd',reset) // this.getTableData(); // } /* onboard 上传按钮 */ // ns onboard success(): void { const modal = this.modalService.success({ nzTitle: 'This is an success message', nzContent: 'Package Onboard Completed.' }); window.setTimeout(() => modal.destroy(), 2000); } error(): void { this.modalService.error({ nzTitle: 'This is an error message', nzContent: 'Package Onboard Failed!' }); } updataNsService(id) { console.log(id); let requestBody = { "csarId": id } this.myhttp.getNsonboard(requestBody) .subscribe((data) => { console.log('onboard ns sdc', data); if(data["status"] == 200) { this.success(); } else { this.error(); } this.getTableData(); }, (err) => { console.log(err); }) } // searchVnfData(reset: boolean = false) { // console.log('vvvv',reset) // this.getTableVnfData(); // } // vnf onboard updataVnfService(id) { this.status = "Onboarding"; console.log(id) let requestBody = { "csarId": id } this.myhttp.getVnfonboard(requestBody) .subscribe((data) => { console.log('onboard vnf sdc', data); if(data["status"] == "200"){ this.success(); }else { this.error(); } }, (err) => { console.log(err); }) } // searchPnfData(reset: boolean = false) { // console.log('pppp',reset) // this.getTablePnfData(); // } // pnf onboard ? updataPnfService(id) { console.log('pnf',id); } //-------------------------------------------------------------------------------- /* delete 删除按钮 */ // ns showConfirm(index,pkgid,tab): void { this.confirmModal = this.modal.confirm({ nzTitle: 'Do you Want to delete these items?', nzContent: 'Do you Want to delete these items?', nzOkText : 'Yes', nzCancelText: 'No', nzOnOk: () => new Promise((resolve, reject) => { switch (tab) { case 'NS': this.deleteNsService(index,pkgid); setTimeout(Math.random() > 0.5 ? resolve : reject,1000); break case 'VNF': this.deleteVnfService(index,pkgid); setTimeout(Math.random() > 0.5 ? resolve : reject,1000); break case 'PNF': this.deletePnfService(index,pkgid); setTimeout(Math.random() > 0.5 ? resolve : reject,1000); break } }).catch(() => console.log('Oops errors!')) }); } /* delete 删除按钮 */ //delete nsItem deleteNsService(index,pkgid) { console.log(pkgid) console.log("deleteService!"); this.myhttp.deleteNsIdData(pkgid) .subscribe((data) => { console.log(44, data); }, (err) => { console.log(err); }) console.log(index) this.tableData.splice(index, 1) console.log('数组长度',this.tableData.length) this.getTableData() } //delete vnfItem deleteVnfService(index,pkgid) { console.log(pkgid) console.log("deleteVnfService!"); this.myhttp.deleteVnfIdData(pkgid) .subscribe((data) => { console.log(44, data); }, (err) => { console.log(err); }) console.log(index) this.tableData.splice(index, 1) console.log(this.tableData.length) this.getTableVnfData() } //delete PnfItem deletePnfService(index,pkgid) { console.log(pkgid) console.log("deletePnfService!"); this.myhttp.deletePnfIdData(pkgid) .subscribe((data) => { console.log(44, data); }, (err) => { console.log(err); }) console.log(index) this.tableData.splice(index, 1) console.log(this.tableData.length) this.getTablePnfData() } //下载download // downloadNsService(id) { // console.log('download') // console.log(id) // this.myhttp.downloadNsData(id) // .subscribe((data) => { // console.log(44, data); // }, (err) => { // console.log(err); // }) // } // downloadVnfService() { // console.log('downloadVnf') // this.myhttp.downloadVnfData() // .subscribe((data) => { // console.log('downloadVnf pack', data); // }, (err) => { // console.log(err); // }) // } // downloadPnfService(id) { // console.log('downloadPnf') // console.log(id) // this.myhttp.downloadNsData(id) // .subscribe((data) => { // console.log(44, data); // }, (err) => { // console.log(err); // }) // } //合并并去重 MergeArray(arr1, arr2) { var _arr = new Array(); for (var i = 0; i < arr1.length; i++) { if (arr1[i] != "") { _arr.push(arr1[i]); } } for (var i = 0; i < arr2.length; i++) { var flag = true; for (var j = 0; j < arr1.length; j++) { // 根据vfc列表arr1的id和sdc列表arr2的uuid去重 if (arr2[i].uuid == arr1[j].id) { flag = false; break; } } if (flag && arr2[i] != "") { _arr.push(arr2[i]); } } return _arr; } }