import { Component, OnInit, ViewChild, TemplateRef, ViewContainerRef, } from "@angular/core"; import { Router, NavigationEnd } from "@angular/router"; import { filter } from "rxjs/operators"; import { NavChangeService } from "../../service/navChange.service"; import { CacheTokenService } from "../../service/cache-token.service"; //引入服务 import { NzMessageService } from "ng-zorro-antd/message"; import { SignalRAspNetCoreHelper } from "../../../shared/helpers/SignalRAspNetCoreHelper"; import { NzNotificationService } from "ng-zorro-antd/notification"; import { GetOutOfLineDetailsComponent } from "../today-warning/get-out-of-line-details/get-out-of-line-details.component"; import { NzModalService } from "ng-zorro-antd/modal"; import { HttpClient } from "@angular/common/http"; import { ChangePasswordComponent, MyValidators, } from "../change-password/change-password.component"; import { listRefreshService } from "../../service/listRefresh.service"; declare var abp: any; import * as moment from "moment"; import { FormBuilder, FormGroup, Validators } from "@angular/forms"; import { DisposeequipmentComponent } from "../records/warning-statistics-list/disposeequipment/disposeequipment.component"; import { SelectedMenu } from "src/app/service/selectedMenu.service"; import { Location } from "@angular/common"; import { SystemModelComponent } from "./system-model/system-model.component"; import { PatternService } from "src/app/service/pattern.service"; @Component({ selector: "app-home", templateUrl: "./home.component.html", styleUrls: ["./home.component.scss"], }) export class HomeComponent implements OnInit { @ViewChild("warning", { static: false }) template?: TemplateRef<{}>; passwordValidateForm!: FormGroup; constructor( private listRefreshService: listRefreshService, private http: HttpClient, private router: Router, private navChangeService: NavChangeService, public token: CacheTokenService, private message: NzMessageService, private notificationService: NzNotificationService, private modal: NzModalService, private viewContainerRef: ViewContainerRef, private fb: FormBuilder, private selectedMenu: SelectedMenu, private location: Location, private patternService: PatternService ) { const { password } = MyValidators; this.passwordValidateForm = this.fb.group({ oldpassword: [null, [Validators.required]], newpassword: [null, [Validators.required, password]], affirmpassword: [null, [Validators.required, password]], }); } isGasStationNav: boolean; isGasStation: boolean; isGasStationBack: boolean; num; surname: string; userName: string; //菜单 menu1 = [ { name: "首页", url: "/homepage" }, { name: "数字油站", url: "/plan" }, { name: "今日预警", url: "/todaywarning" }, { name: "预警记录", url: "/records_nav" }, { name: "证照管理", url: "/audit" }, ]; menu2 = [ { name: "数字油站", url: "/plan/petrolStation" }, { name: "今日预警", url: "/todaywarning/petrolStation" }, { name: "预警记录", url: "/records_nav/petrolStation" }, { name: "证照管理", url: "/license/petrolStation" }, ]; menu3 = [ { name: "组织机构管理", url: "/system/organization" }, { name: "用户管理", url: "/system/user" }, { name: "角色管理", url: "/system/role" }, { name: "分析主机管理", url: "/system/host" }, { name: "推送管理", url: "/system/push" }, { name: "经营类证照管理", url: "/system/updateOfLicense" }, { name: "资产类证照管理", url: "/system/fileOfLicense" }, { name: "菜单管理", url: "/system/menu" }, ]; xitongguanli = false; userMenu = []; tap = []; menuList1 = []; menuList2 = []; selectedItem; routerChange(item) { if (JSON.parse(sessionStorage.getItem("isGasStation"))) { let a = JSON.parse(sessionStorage.getItem("3dSceneData")); if (!a.hasBuildingInfo && item.url == "/plan/petrolStation") { this.message.info("当前油站未开通!"); return; } } if (item.name == this.selectedItem) { return; } sessionStorage.setItem("selectedMenu", item.name); this.selectedItem = item.name; this.router.navigate([item.url]); } isProd: boolean; ngOnInit(): void { this.isProd = this.patternService.isProd; this.initSelectedItem(this.router); let a = sessionStorage.getItem("userdata"); this.userMenu = JSON.parse(a).menus; for (let index = 0; index < this.userMenu.length; index++) { let a = this.userMenu[index].name; this.tap.push(a); } if (sessionStorage.getItem("selectedMenu")) { this.selectedItem = sessionStorage.getItem("selectedMenu"); } this.isGasStation = JSON.parse(sessionStorage.getItem("isGasStation")); //初始化登陆 如果是油站用户 if (this.isGasStation) { this.isGasStationNav = true; for (let index = 0; index < this.menu2.length; index++) { for (let k = 0; k < this.tap.length; k++) { if (this.tap[k] == this.menu2[index].name) { this.menuList1.push(this.menu2[index]); } } } } else { //初始化登陆 如果是管理者用户 this.isGasStationNav = false; this.isGasStationBack = false; for (let index = 0; index < this.menu1.length; index++) { for (let k = 0; k < this.tap.length; k++) { if (this.tap[k] == this.menu1[index].name) { this.menuList1.push(this.menu1[index]); } } } for (let index = 0; index < this.tap.length; index++) { if (this.tap[index] == "系统管理") { this.xitongguanli = true; } } } this.router.events .pipe(filter((event) => event instanceof NavigationEnd)) .subscribe((event: any) => { console.log('走这里Elma44',event) //管理者进入油站页面 if (event.url.indexOf("petrolStation") != -1 && !this.isGasStation) { //控制返回按钮显示 this.isGasStationNav = true; this.isGasStationBack = true; } //管理者进入非油站页面 if (event.url.indexOf("petrolStation") == -1 && !this.isGasStation) { //控制返回按钮显示 this.isGasStationNav = false; this.isGasStationBack = false; } //油站人员进入管理页面 if (event.url.indexOf("petrolStation") == -1 && this.isGasStation) { //控制返回按钮显示 this.isGasStationNav = false; this.isGasStationBack = false; } //油站人员进入油站 if (event.url.indexOf("petrolStation") != -1 && this.isGasStation) { //控制返回按钮显示 this.isGasStationNav = true; this.isGasStationBack = false; } }); setInterval(() => { this.getTime(); }, 1000); if (this.isGasStation) { this.surname = JSON.parse( sessionStorage.getItem("userdataOfgasstation") ).name; this.userName = JSON.parse( sessionStorage.getItem("userdataOfgasstation") ).userName; } else { this.surname = JSON.parse(sessionStorage.getItem("userdata")).name; this.userName = JSON.parse(sessionStorage.getItem("userdata")).userName; } // if ( // (sessionStorage.getItem("isDefaultPassword") == "true" || // sessionStorage.getItem("isPasswordExpired") == "true") && // JSON.parse(sessionStorage.getItem("userdata")).userName != "admin" // ) { // this.changePasswordPopup(); // } this.getWarningSwitch(); } initSelectedItem(event) { // console.log(666, event); if (event.url.indexOf("/homepage") !== -1) { sessionStorage.setItem("selectedMenu", "首页"); this.selectedItem = "首页"; } else if (event.url.indexOf("/todaywarning") !== -1) { sessionStorage.setItem("selectedMenu", "今日预警"); this.selectedItem = "今日预警"; } else if (event.url.indexOf("/records_nav") != -1) { this.selectedItem = "预警记录"; } } isWarningVoice = true; //预警声音 isWarningWindow = true; //预警弹窗 /** * 预警开关 */ getWarningSwitch() { this.http .get("/api/services/app/Session/GetCurrentLoginInformations") .subscribe((data: any) => { let popupConfig = data.result.user.popupConfig; if (!popupConfig) { this.isWarningVoice = true; this.isWarningWindow = true; return; } this.isWarningVoice = JSON.parse(popupConfig).isWarningVoice; this.isWarningWindow = JSON.parse(popupConfig).isWarningWindow; }); } warningSwitch(type) { let body = { isWarningVoice: type === "voice" ? !this.isWarningVoice : this.isWarningVoice, isWarningWindow: type === "window" ? !this.isWarningWindow : this.isWarningWindow, }; this.http .post("/api/services/app/User/SetPopupConfig", body, { params: { userId: JSON.parse(sessionStorage.getItem("userdata")).id, }, }) .subscribe( (data) => { if (type === "voice") { this.isWarningVoice = !this.isWarningVoice; this.isWarningVoice ? this.message.success("预警声音已开启") : this.message.success("预警声音已关闭"); } else if (type === "window") { this.isWarningWindow = !this.isWarningWindow; this.isWarningWindow ? this.message.success("预警弹窗已开启") : this.message.success("预警弹窗已关闭"); } }, (err) => { this.message.error("修改失败"); } ); } ngAfterViewInit() { SignalRAspNetCoreHelper.initSignalR(); abp.event.on("abp.notifications.received", this.reloadPage); } reloadPage = (userNotification) => { console.log("abp.notifications.received收到通知", userNotification); if ( this.router.url.indexOf("todaywarning") != -1 || this.router.url.indexOf("homepage") != -1 ) { let obj = { type: "add", data: userNotification, }; this.listRefreshService.sendMessage(obj); //发布一条消息 } this.receiptOfNotification(userNotification); }; //右下角消息弹窗 messageId = []; receiptOfNotification(userNotification) { if (this.isWarningVoice) { // if (!window.speechSynthesis) { // this.message.create("warning", `该游览器不支持语音播报`); // } else { // let speakMsg = new SpeechSynthesisUtterance( // "请注意,收到一条新的预警信息,请及时处理!" // ); // speakMsg.lang = "zh-CN"; // speakMsg.rate = 1; // speakMsg.pitch = 1.5; // window.speechSynthesis.speak(speakMsg); // } this.Sound(); } if (this.isWarningWindow) { let obj = { id: userNotification.notification.entityId, messageId: this.notificationService.template(this.template!, { nzPlacement: "bottomRight", nzClass: "receiptOfNotification", nzDuration: 0, nzData: userNotification, }).messageId, }; this.messageId.push(obj); } } Sound() { var mp3Url = "../../../assets/sound/warning.mp3"; var player = new Audio(mp3Url); player.play(); //播放 mp3这个音频对象 } modalData; look(item) { console.log("推送信息", item); let params = { id: item.notification.entityId, }; this.http .get("/api/services/app/ViolateRecord/Get", { params: params, }) .subscribe((data: any) => { console.log("推送信息后获取信息", data); setTimeout(() => { let copydata = data.result; if (copydata.violation.violationType == "设备监测") { copydata.violatedItemSnapshotObj = JSON.parse( copydata.violatedItemSnapshot ); const modal = this.modal.create({ nzContent: DisposeequipmentComponent, nzViewContainerRef: this.viewContainerRef, nzWidth: 380, nzBodyStyle: { border: "1px solid #91CCFF", "border-radius": "0px", padding: "7px", "box-shadow": "0 0 8px 0 #fff", "background-image": "linear-gradient(#003665, #000f25)", }, nzComponentParams: { data: copydata, }, nzFooter: null, nzClosable: false, nzOnOk: async () => { if (instance.isScrap) { await new Promise((resolve) => { let body = { id: copydata.violatedItemSnapshotObj.id, isScrapped: true, organizationUnitId: copydata.violatedItemSnapshotObj.organizationUnitId, name: instance.copydata2.violatedItemSnapshotObj.name, storageLocation: instance.copydata2.violatedItemSnapshotObj .storageLocation, productionDate: moment( instance.copydata2.violatedItemSnapshotObj .productionDate ).format("yyyy-MM-DD"), maintenanceDate: moment( instance.copydata2.violatedItemSnapshotObj .maintenanceDate ).format("yyyy-MM-DD"), validityEndTime: moment( instance.copydata2.violatedItemSnapshotObj .validityEndTime ).format("yyyy-MM-DD"), }; this.http .put("/api/services/app/FireEquipment/Update", body) .subscribe((data: any) => { let body = { id: copydata.id, handleRecord: "报废成功!", }; this.http .post( "/api/services/app/ViolateRecord/HandleViolateRecord", body ) .subscribe((data) => { resolve(data); this.message.create("success", "报废成功!"); copydata.handleTime = new Date(); if (this.router.url.indexOf("todaywarning") != -1) { let obj = { type: "updatehandleTime", data: copydata.id, }; this.listRefreshService.sendMessage(obj); //发布一条消息 } return true; }); }); }); } else { if (instance.validateForm.valid) { await new Promise((resolve) => { let body = { id: copydata.violatedItemSnapshotObj.id, name: instance.validateForm.value.name, storageLocation: instance.validateForm.value.storageLocation, productionDate: moment( instance.validateForm.value.productionDate ).format("yyyy-MM-DD"), maintenanceDate: moment( instance.validateForm.value.maintenanceDate ).format("yyyy-MM-DD"), validityEndTime: moment( instance.validateForm.value.validityEndTime ).format("yyyy-MM-DD"), organizationUnitId: copydata.violatedItemSnapshotObj.organizationUnitId, }; this.http .put("/api/services/app/FireEquipment/Update", body) .subscribe((data: any) => { let body = { id: copydata.id, handleRecord: "维保成功!", }; this.http .post( "/api/services/app/ViolateRecord/HandleViolateRecord", body ) .subscribe((data) => { resolve(data); this.message.create("success", "维保成功!"); copydata.handleTime = new Date(); if ( this.router.url.indexOf("todaywarning") != -1 ) { let obj = { type: "updatehandleTime", data: copydata.id, }; this.listRefreshService.sendMessage(obj); //发布一条消息 } return true; }); }); }); } else { this.message.create("warning", "请填写完整!"); return false; } } }, }); const instance = modal.getContentComponent(); } else { const modal = this.modal.create({ nzContent: GetOutOfLineDetailsComponent, nzWrapClassName: "vertical-center-modal", nzViewContainerRef: this.viewContainerRef, nzWidth: document.documentElement.clientHeight < 650 || document.documentElement.clientWidth < 1400 ? 1000 : 1200, nzClosable: false, nzClassName: "modelnobg", nzBodyStyle: { "border-radius": "0px", padding: "0px", }, nzComponentParams: { data: copydata, }, nzFooter: null, }); const instance = modal.getContentComponent(); } }, 0); this.messageId.forEach((element) => { if (element.id == item.notification.entityId) { this.notificationService.remove(element.messageId); } }); this.readMess(item.notification.id); }); } //标记为已读 readMess(id) { let body = { id: id, }; this.http .post("/api/services/app/Notification/Read", body) .subscribe((data: any) => { console.log("标记已读成功"); }); } close(item) { this.messageId.forEach((element) => { if (element.id == item.notification.entityId) { this.notificationService.remove(element.messageId); } }); } //处置 updateState(item, type) { let body = { id: item.notification.entityId, operation: type, }; this.http .put( "/api/services/app/StationValidityLicenseNotificationRecord/UpdateState", body ) .subscribe( (data) => { this.messageId.forEach((element) => { if (element.id == item.notification.entityId) { this.notificationService.remove(element.messageId); } }); this.message.create("success", "操作成功"); }, (err) => { this.message.create("error", "操作失败"); } ); } ngOnDestroy() { console.log("退出"); abp.event.off("abp.notifications.received", this.reloadPage); abp.signalr.disconnect(); this.notificationService.remove(); } //获得时间 time: string; getTime() { let myDate = new Date(); let y = myDate.getFullYear(); let M = myDate.getMonth() + 1; //获取当前月份(0-11,0代表1月) let d = myDate.getDate(); //获取当前日(1-31) let h = myDate.getHours(); //获取当前小时数(0-23) let m = myDate.getMinutes(); //获取当前分钟数(0-59) let s = myDate.getSeconds(); //获取当前秒数(0-59) //检查是否小于10 M = check(M); d = check(d); h = check(h); m = check(m); s = check(s); let timestr = y + "-" + M + "-" + d + " " + h + ":" + m + ":" + s; this.time = timestr; //时间数字小于10,则在之前加个“0”补位。 function check(i) { let num = i < 10 ? "0" + i : i; return num; } } //退出系统 signOut() { this.message.create("success", `退出成功`); this.token.delete(); sessionStorage.clear(); localStorage.removeItem("isautologin"); this.router.navigate(["/login"]); } navChange(router) { if (router == "/oliStationInfo") { this.router.navigate([router], { queryParams: { id: JSON.parse(sessionStorage.getItem("userdata")).organization.id, }, }); } else { this.router.navigate([router]); } } navChange2() { for (let index = 0; index < this.menu3.length; index++) { for (let k = 0; k < this.tap.length; k++) { if (this.tap[k] == this.menu3[index].name) { this.menuList2.push(this.menu3[index]); } } } if (this.menuList2.length == 0) { this.message.create("warning", "未分配系统管理菜单"); return; } else { window.open(this.menuList2[0].url); } } goback() { this.router.navigate(["/plan"]); this.isGasStationNav = false; } //全屏 isfullscreen: boolean = false; fullscreenToggle() { const docElmWithBrowsersFullScreenFunctions = document.documentElement as HTMLElement & { mozRequestFullScreen(): Promise; webkitRequestFullscreen(): Promise; msRequestFullscreen(): Promise; }; if (docElmWithBrowsersFullScreenFunctions.requestFullscreen) { docElmWithBrowsersFullScreenFunctions.requestFullscreen(); } else if (docElmWithBrowsersFullScreenFunctions.mozRequestFullScreen) { /* Firefox */ docElmWithBrowsersFullScreenFunctions.mozRequestFullScreen(); } else if (docElmWithBrowsersFullScreenFunctions.webkitRequestFullscreen) { /* Chrome, Safari and Opera */ docElmWithBrowsersFullScreenFunctions.webkitRequestFullscreen(); } else if (docElmWithBrowsersFullScreenFunctions.msRequestFullscreen) { /* IE/Edge */ docElmWithBrowsersFullScreenFunctions.msRequestFullscreen(); } this.isfullscreen = true; } closefullscreen() { const docWithBrowsersExitFunctions = document as Document & { mozCancelFullScreen(): Promise; webkitExitFullscreen(): Promise; msExitFullscreen(): Promise; }; if (docWithBrowsersExitFunctions.exitFullscreen) { docWithBrowsersExitFunctions.exitFullscreen(); } else if (docWithBrowsersExitFunctions.mozCancelFullScreen) { /* Firefox */ docWithBrowsersExitFunctions.mozCancelFullScreen(); } else if (docWithBrowsersExitFunctions.webkitExitFullscreen) { /* Chrome, Safari and Opera */ docWithBrowsersExitFunctions.webkitExitFullscreen(); } else if (docWithBrowsersExitFunctions.msExitFullscreen) { /* IE/Edge */ docWithBrowsersExitFunctions.msExitFullscreen(); } this.isfullscreen = false; } //修改密码 changePassword() { const modal: any = this.modal.create({ nzTitle: "修改密码", nzContent: ChangePasswordComponent, nzViewContainerRef: this.viewContainerRef, nzWidth: 288, nzComponentParams: {}, nzOnOk: async () => { if (instance.validateForm.valid) { let word = JSON.parse( JSON.stringify(instance.validateForm.value.newpassword) ).toLowerCase(); if ( instance.validateForm.value.newpassword != instance.validateForm.value.affirmpassword ) { this.message.create("warning", "两次密码输入不一致!"); return false; } if (word.indexOf("sino") != -1 || word.indexOf("zhonghua") != -1) { this.message.create( "warning", "口令禁止包含 sinochem、sino、zhonghua (含大小写变体) 等中国中化相关字符" ); return false; } else { await new Promise((resolve, reject) => { let body = { currentPassword: instance.validateForm.value.oldpassword, newPassword: instance.validateForm.value.newpassword, }; this.http .post("/api/services/app/User/ChangePassword", body) .subscribe( (data) => { resolve(data); this.message.create("success", "修改成功!"); return true; }, (err) => { this.message.create("warning", err.error.error.message); modal.config.nzOkLoading = false; return false; } ); }); } } else { this.message.create("warning", "请填写完整!"); return false; } }, }); const instance = modal.getContentComponent(); } }