|  |  |  | 
|---|
|  |  |  | <template> | 
|---|
|  |  |  | <div id="UiHeader"> | 
|---|
|  |  |  | <el-menu router :default-active="this.$route.path" background-color="#545c64" text-color="#fff" active-text-color="#ffd04b" mode="horizontal"> | 
|---|
|  |  |  | <el-menu router :default-active="activeIndex" menu-trigger="click" background-color="#545c64" text-color="#fff" active-text-color="#ffd04b" mode="horizontal"> | 
|---|
|  |  |  | <el-menu-item index="/">控制台</el-menu-item> | 
|---|
|  |  |  | <el-menu-item index="/videoList">设备列表</el-menu-item> | 
|---|
|  |  |  | <!-- <el-menu-item index="/videoReplay">录像回看</el-menu-item> --> | 
|---|
|  |  |  | <!-- <el-menu-item index="4">级联设置</el-menu-item> --> | 
|---|
|  |  |  | <el-menu-item style="float: right;" @click="loginout">退出</el-menu-item> | 
|---|
|  |  |  | <el-menu-item index="/deviceList">设备列表</el-menu-item> | 
|---|
|  |  |  | <el-menu-item index="/pushVideoList">推流列表</el-menu-item> | 
|---|
|  |  |  | <el-menu-item index="/streamProxyList">拉流代理</el-menu-item> | 
|---|
|  |  |  | <el-menu-item index="/cloudRecord">云端录像</el-menu-item> | 
|---|
|  |  |  | <el-menu-item index="/mediaServerManger">节点管理</el-menu-item> | 
|---|
|  |  |  | <el-menu-item index="/parentPlatformList/15/1">国标级联</el-menu-item> | 
|---|
|  |  |  | <el-menu-item @click="openDoc">在线文档</el-menu-item> | 
|---|
|  |  |  | <!--            <el-submenu index="/setting">--> | 
|---|
|  |  |  | <!--              <template slot="title">系统设置</template>--> | 
|---|
|  |  |  | <!--              <el-menu-item index="/setting/web">WEB服务</el-menu-item>--> | 
|---|
|  |  |  | <!--              <el-menu-item index="/setting/sip">国标服务</el-menu-item>--> | 
|---|
|  |  |  | <!--              <el-menu-item index="/setting/media">媒体服务</el-menu-item>--> | 
|---|
|  |  |  | <!--            </el-submenu>--> | 
|---|
|  |  |  | <el-switch v-model="alarmNotify"  active-text="报警信息推送" style="display: block float: right" @change="alarmNotifyChannge"></el-switch> | 
|---|
|  |  |  | <!--            <el-menu-item style="float: right;" @click="loginout">退出</el-menu-item>--> | 
|---|
|  |  |  | <el-submenu index="" style="float: right;" > | 
|---|
|  |  |  | <template slot="title">欢迎,{{this.$cookies.get("session").username}}</template> | 
|---|
|  |  |  | <el-menu-item @click="changePassword">修改密码</el-menu-item> | 
|---|
|  |  |  | <el-menu-item @click="loginout">注销</el-menu-item> | 
|---|
|  |  |  | </el-submenu> | 
|---|
|  |  |  | </el-menu> | 
|---|
|  |  |  | <changePasswordDialog ref="changePasswordDialog"></changePasswordDialog> | 
|---|
|  |  |  | </div> | 
|---|
|  |  |  | </template> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | <script> | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import changePasswordDialog from './dialog/changePassword.vue' | 
|---|
|  |  |  | export default { | 
|---|
|  |  |  | name: "UiHeader", | 
|---|
|  |  |  | methods:{ | 
|---|
|  |  |  | components: { Notification, changePasswordDialog }, | 
|---|
|  |  |  | data() { | 
|---|
|  |  |  | return { | 
|---|
|  |  |  | alarmNotify: false, | 
|---|
|  |  |  | sseSource: null, | 
|---|
|  |  |  | activeIndex: this.$route.path, | 
|---|
|  |  |  | }; | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | created(){ | 
|---|
|  |  |  | if (this.$route.path.startsWith("/channelList")){ | 
|---|
|  |  |  | this.activeIndex = "/deviceList" | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | mounted() { | 
|---|
|  |  |  | window.addEventListener('beforeunload', e => this.beforeunloadHandler(e)) | 
|---|
|  |  |  | // window.addEventListener('unload', e => this.unloadHandler(e)) | 
|---|
|  |  |  | this.alarmNotify = this.getAlarmSwitchStatus() === "true"; | 
|---|
|  |  |  | this.sseControl(); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | methods:{ | 
|---|
|  |  |  | loginout(){ | 
|---|
|  |  |  | this.$axios({ | 
|---|
|  |  |  | method: 'get', | 
|---|
|  |  |  | url:"/api/user/logout" | 
|---|
|  |  |  | }).then((res)=> { | 
|---|
|  |  |  | // 删除cookie,回到登录页面 | 
|---|
|  |  |  | this.$cookies.remove("session"); | 
|---|
|  |  |  | this.$router.push('/login'); | 
|---|
|  |  |  | this.sseSource.close(); | 
|---|
|  |  |  | }).catch((error)=> { | 
|---|
|  |  |  | console.error("登出失败") | 
|---|
|  |  |  | console.error(error) | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | changePassword(){ | 
|---|
|  |  |  | this.$refs.changePasswordDialog.openDialog() | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | openDoc(){ | 
|---|
|  |  |  | console.log(process.env.BASE_API) | 
|---|
|  |  |  | window.open( !!process.env.BASE_API? process.env.BASE_API + "/doc.html": "/doc.html") | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | beforeunloadHandler() { | 
|---|
|  |  |  | this.sseSource.close(); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | alarmNotifyChannge(){ | 
|---|
|  |  |  | this.setAlarmSwitchStatus() | 
|---|
|  |  |  | this.sseControl() | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | sseControl() { | 
|---|
|  |  |  | let that = this; | 
|---|
|  |  |  | if (this.alarmNotify) { | 
|---|
|  |  |  | console.log("申请SSE推送API调用,浏览器ID: " + this.$browserId); | 
|---|
|  |  |  | this.sseSource = new EventSource('/api/emit?browserId=' + this.$browserId); | 
|---|
|  |  |  | this.sseSource.addEventListener('message', function(evt) { | 
|---|
|  |  |  | that.$notify({ | 
|---|
|  |  |  | title: '收到报警信息', | 
|---|
|  |  |  | dangerouslyUseHTMLString: true, | 
|---|
|  |  |  | message: evt.data, | 
|---|
|  |  |  | type: 'warning' | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | console.log("收到信息:" + evt.data); | 
|---|
|  |  |  | }); | 
|---|
|  |  |  | this.sseSource.addEventListener('open', function(e) { | 
|---|
|  |  |  | console.log("SSE连接打开."); | 
|---|
|  |  |  | }, false); | 
|---|
|  |  |  | this.sseSource.addEventListener('error', function(e) { | 
|---|
|  |  |  | if (e.target.readyState == EventSource.CLOSED) { | 
|---|
|  |  |  | console.log("SSE连接关闭"); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | console.log(e.target.readyState); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }, false); | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  | if (this.sseSource != null) { | 
|---|
|  |  |  | this.sseSource.removeEventListener('open', null); | 
|---|
|  |  |  | this.sseSource.removeEventListener('message', null); | 
|---|
|  |  |  | this.sseSource.removeEventListener('error', null); | 
|---|
|  |  |  | this.sseSource.close(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | getAlarmSwitchStatus(){ | 
|---|
|  |  |  | if (localStorage.getItem("alarmSwitchStatus") == null) { | 
|---|
|  |  |  | localStorage.setItem("alarmSwitchStatus", false); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | return localStorage.getItem("alarmSwitchStatus"); | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | setAlarmSwitchStatus(){ | 
|---|
|  |  |  | localStorage.setItem("alarmSwitchStatus", this.alarmNotify); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  | destroyed() { | 
|---|
|  |  |  | window.removeEventListener('beforeunload', e => this.beforeunloadHandler(e)) | 
|---|
|  |  |  | if (this.sseSource != null) { | 
|---|
|  |  |  | this.sseSource.removeEventListener('open', null); | 
|---|
|  |  |  | this.sseSource.removeEventListener('message', null); | 
|---|
|  |  |  | this.sseSource.removeEventListener('error', null); | 
|---|
|  |  |  | this.sseSource.close(); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | }, | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | </script> | 
|---|