You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
197 lines
6.7 KiB
197 lines
6.7 KiB
import { HttpClient } from "@angular/common/http"; |
|
import { Component, OnInit } from "@angular/core"; |
|
import { ActivatedRoute, Router } from "@angular/router"; |
|
import { CacheTokenService } from "../http-interceptors/cache-token.service"; |
|
import { Viewer } from "photo-sphere-viewer"; |
|
import { DomSanitizer } from "@angular/platform-browser"; |
|
|
|
@Component({ |
|
selector: "app-external-links-plan", |
|
templateUrl: "./external-links-plan.component.html", |
|
styleUrls: ["./external-links-plan.component.scss"], |
|
}) |
|
export class ExternalLinksPlanComponent implements OnInit { |
|
constructor( |
|
private http: HttpClient, |
|
private token: CacheTokenService, |
|
public route: ActivatedRoute, |
|
private sanitizer: DomSanitizer, |
|
private router: Router |
|
) {} |
|
|
|
planId: any; //预案id |
|
viewer; //全景图对象 |
|
fetchUrl; //预案文件地址 |
|
showType; //预案类型 1:全景图 |
|
planData; //预案信息 |
|
|
|
unitId; |
|
async ngOnInit(): Promise<void> { |
|
await this.login(); //登录存储token |
|
this.route.queryParams.subscribe((paramsData) => { |
|
if (paramsData.planId) { |
|
this.planId = paramsData.planId; |
|
this.http |
|
.get(`/api/PlanComponents/${this.planId}`) |
|
.subscribe((data: any) => { |
|
console.log("单个预案详细信息", data); |
|
sessionStorage.setItem("planId", data.id); |
|
sessionStorage.setItem("companyId", data.companyId); |
|
sessionStorage.setItem( |
|
"buildingTypeId", |
|
data.company.buildingTypes[0].id |
|
); |
|
sessionStorage.setItem("editable", "0"); |
|
sessionStorage.setItem("planName", data.name); |
|
let queryParams = {}; |
|
if (data.webTextData && data.planType === 16) { |
|
queryParams = { |
|
id: data.companyId, |
|
planId: data.id, |
|
orName: data.company.organizationName, |
|
orId: data.company.organizationId, |
|
companyId: data.companyId, |
|
planName: data.name, |
|
unitName: data.companyName, |
|
planCategory: data.planCategory, |
|
unitTypeId: data.company.buildingTypes[0].id, |
|
pattern: "false", |
|
}; |
|
} else { |
|
queryParams = { |
|
id: data.companyId, |
|
planId: data.id, |
|
orName: data.company.organizationName, |
|
orId: data.company.organizationId, |
|
}; |
|
} |
|
this.router.navigate([`/linksPlan`], { |
|
queryParams: queryParams, |
|
}); |
|
this.planData = data; |
|
|
|
//如果是查看文件类型 |
|
|
|
console.log("data.planType", data.planType); |
|
if (data.planType != 1 && data.planType != 2) { |
|
this.fetchUrl = data.attachmentUrls ? data.attachmentUrls[0] : ""; |
|
var index = this.fetchUrl.indexOf("/"); |
|
|
|
// 在线编制预案 |
|
if (data.webTextData && data.planType === 16) { |
|
this.showType = 2; |
|
return; |
|
} |
|
|
|
//全景图图片 |
|
if (this.fetchUrl.substr(0, index) == "psw") { |
|
this.showType = 1; |
|
var obj = document.getElementById("viewer"); |
|
if (obj != null) { |
|
obj.innerHTML = ""; |
|
} |
|
window.setTimeout(() => { |
|
this.viewer = new Viewer({ |
|
container: document.querySelector("#viewer"), |
|
panorama: "/api/Objects/PlanPlatform/" + this.fetchUrl, |
|
}); |
|
}); |
|
} else { |
|
//word文档 |
|
this.lookWord(); |
|
} |
|
} else { |
|
// 如果是二三维预案 |
|
this.handleData(); |
|
} |
|
}); |
|
} else if (paramsData.unitId) { |
|
this.http |
|
.get(`/api/Companies/${paramsData.unitId}`) |
|
.subscribe((data: any) => { |
|
console.log("单位信息", data); |
|
sessionStorage.setItem("editable", "0"); |
|
sessionStorage.setItem("companyName", data.name); |
|
sessionStorage.setItem("companyId", data.id); |
|
sessionStorage.setItem( |
|
data.id, |
|
JSON.stringify(data.companyIntegrityScore) |
|
); |
|
let queryParams = { |
|
id: data.id, |
|
usci: data.usci, |
|
}; |
|
this.unitId = paramsData.unitId; |
|
this.router.navigate([`/linksPlan`], { |
|
queryParams: queryParams, |
|
}); |
|
}); |
|
} |
|
}); |
|
} |
|
|
|
async login() { |
|
await new Promise((resolve, reject) => { |
|
let { appKey, signature, timestamp } = this.route.snapshot.queryParams; |
|
if (!appKey || !signature || !timestamp) { |
|
alert("url参数不完整"); |
|
return; |
|
} |
|
this.http |
|
.get("/api/Account/VerifyAppInfo", { |
|
params: { |
|
appKey: appKey, |
|
signature: signature, |
|
timestamp: timestamp, |
|
}, |
|
}) |
|
.subscribe((data: any) => { |
|
sessionStorage.setItem("level", data.level); |
|
sessionStorage.setItem("token", data.token); |
|
sessionStorage.setItem("refreshToken", data.refreshToken); |
|
console.log("登录成功", data); |
|
resolve(data); |
|
this.token.startUp(); |
|
}); |
|
}); |
|
} |
|
iframeSrc; //word服务器链接 |
|
lookWord() { |
|
this.showType = 0; |
|
let src; |
|
let suffix = this.fetchUrl |
|
.split(".") |
|
[this.fetchUrl.split(".").length - 1].toLowerCase(); |
|
if (suffix == "docx" || suffix == "doc") { |
|
let arr = this.fetchUrl.split("."); |
|
arr[arr.length - 1] = "pdf"; |
|
src = `/api/Objects/PlanPlatform/` + arr.join("."); |
|
} else if (suffix == "pdf") { |
|
src = `/api/Objects/PlanPlatform/` + this.fetchUrl; |
|
} |
|
this.iframeSrc = this.sanitizer.bypassSecurityTrustResourceUrl(src); |
|
} |
|
|
|
companyData; //当前公司信息 |
|
thirdPartyURL; |
|
threedUrl: any; |
|
handleData() { |
|
let data = this.planData; |
|
if (this.planData.planMode == 1 || this.planData.planMode == 2) { |
|
//预案planMode=2时, 跳查看页面组件 |
|
this.showType = 3; |
|
} else if (this.planData.planMode == 3) { |
|
//网页地址 |
|
let localhostPath = window.document.location.href.substring( |
|
0, |
|
window.document.location.href.indexOf(window.document.location.pathname) |
|
); |
|
let url = data.url; |
|
if (url.indexOf(localhostPath) != -1) { |
|
window.location.href = `${url}?unitId=${data.company.id}&unitName=${data.company.name}&editMode=false`; |
|
} else { |
|
window.location.href = `${url}?unitId=${data.company.id}&unitName=${data.company.name}&editMode=false`; |
|
} |
|
} |
|
} |
|
}
|
|
|