{"remainingRequest":"D:\\jenkins\\workspace\\jd_cgpt_fvue\\node_modules\\vue-loader\\lib\\index.js??vue-loader-options!D:\\jenkins\\workspace\\jd_cgpt_fvue\\src\\components\\layout\\Layout.vue?vue&type=script&lang=js&","dependencies":[{"path":"D:\\jenkins\\workspace\\jd_cgpt_fvue\\src\\components\\layout\\Layout.vue","mtime":1720471236277},{"path":"D:\\jenkins\\workspace\\jd_cgpt_fvue\\node_modules\\babel-loader\\lib\\index.js","mtime":315532800000},{"path":"D:\\jenkins\\workspace\\jd_cgpt_fvue\\node_modules\\cache-loader\\dist\\cjs.js","mtime":499162500000},{"path":"D:\\jenkins\\workspace\\jd_cgpt_fvue\\node_modules\\vue-loader\\lib\\index.js","mtime":499162500000}],"contextDependencies":[],"result":["//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n//\n\r\nimport Navigator from './Navigator.vue'\r\nimport SideMenu from './SideMenu.vue'\r\nimport Main from './Main.vue'\r\nexport default {\r\n components: {\r\n Navigator,\r\n SideMenu,\r\n Main\r\n },\r\n data() {\r\n return {\r\n menuShow: true, // 侧边菜单收折flag\r\n transitionName: 'fold-right', // 页面切换动画名称\r\n navMode: 'sideMenu', // sideMenu 侧边菜单 | topMenu 顶部菜单 | topSideMenu-UD 顶部侧边联动菜单上下布局 | topSideMenu-LR 顶部侧边联动菜单左右布局\r\n aliasPath: [], // 当前路由菜单别名全路径\r\n bizMenuIndex: 0, //业务菜单一级属于前台菜单层级中的第几级\r\n bizMenuAlias: 'normal', // 业务菜单根别名\r\n showHeader: true,\r\n heartCheck: {},\r\n isCurrentWindow: true\r\n }\r\n },\r\n created() {\r\n // 在外框架中获取所有前台菜单,组件中不再请求,直接读取vuex中数据\r\n this.getMenus()\r\n this.heartCheckFun()\r\n this.initWebSocket()\r\n },\r\n mounted() {\r\n window.onresize = () => {\r\n this.$root.$emit('resize')\r\n }\r\n this.$bus.$on('login', () => {\r\n this.heartCheckFun()\r\n })\r\n },\r\n beforeDestroy() {\r\n this.isCurrentWindow = false\r\n },\r\n watch: {\r\n $route: 'activeAlias'\r\n },\r\n methods: {\r\n getMenus() {\r\n this.menuAll = []\r\n this.$store.dispatch('menu/actionFrontMenus').then(data => {\r\n this.menuAll = data\r\n this.menuReady = true\r\n this.activeAlias()\r\n })\r\n },\r\n activeAlias() {\r\n // 如果是顶部侧边联动部菜单则页面刷新时需要根据当前路由别名找到对应的父级节点\r\n if (\r\n this.navMode == 'topSideMenu-LR' ||\r\n this.navMode == 'topSideMenu-UD'\r\n ) {\r\n // 根据路由别名刷新找到对应的父级菜单全路径\r\n let fullPath = this.$route.path\r\n let path = fullPath.split('/')\r\n let urlAnchor = path[path.indexOf('platLayout') + 1]\r\n let aliasPath = []\r\n this.filterRootParant(this.menuAll, urlAnchor, aliasPath)\r\n this.aliasPath = aliasPath\r\n }\r\n this.$bus.$emit('menuPathReady', this.aliasPath)\r\n },\r\n // 找到对应的根父级菜单\r\n filterRootParant(data, urlAnchor, result) {\r\n for (let item of data) {\r\n if (item.alias === urlAnchor) {\r\n // 如何找到了则说明这里是最后一级可以返回了,将查找到的目标数据加入结果数组中\r\n // 可根据需求unshift(item.id)或unshift(item)\r\n result.unshift(item.alias)\r\n return true\r\n } else if (item.children && item.children.length > 0) {\r\n // 否则继续在子节点中查找\r\n let isFind = this.filterRootParant(item.children, urlAnchor, result)\r\n // 如果在当前节点的子字节点中找到了则将当前节点加入到结果数组中\r\n if (isFind) {\r\n result.unshift(item.alias)\r\n return true\r\n }\r\n }\r\n }\r\n // 没找到目标\r\n return false\r\n },\r\n initWebSocket() {\r\n // WebSocket与普通的请求所用协议有所不同,ws等同于http,wss等同于https\r\n const token = this.$store.state.login.currentUser.token\r\n const url =\r\n window.context.WebSocket.replace('https://', 'wss://').replace(\r\n 'http://',\r\n 'ws://'\r\n ) + '/websocket'\r\n // ?token=' +\r\n // token\r\n console.log(url, 'url')\r\n this.websock = new WebSocket(url)\r\n this.websock.onopen = this.websocketOnopen\r\n this.websock.onerror = this.websocketOnerror\r\n this.websock.onmessage = this.websocketOnmessage\r\n this.websock.onclose = this.websocketOnclose\r\n },\r\n websocketOnopen() {\r\n console.log('WebSocket连接成功')\r\n this.heartCheck.start()\r\n },\r\n websocketOnerror(e) {\r\n console.log(e, 'WebSocket连接发生错误')\r\n this.reconnect()\r\n },\r\n websocketOnmessage(e) {\r\n let data = JSON.parse(e.data) //解析对象 eval('(' + e.data + ')');\r\n // 竞拍报价\r\n if (data.offerId !== undefined) {\r\n if (this.isCurrentWindow) {\r\n console.log('-----接收消息-------', data.offerId)\r\n this.$bus.$emit('JPBJMsg', data.offerId)\r\n }\r\n }\r\n this.heartCheck.reset()\r\n },\r\n websocketOnclose(e) {\r\n console.log('connection closed (' + e.code + ')')\r\n this.reconnect()\r\n },\r\n websocketSend(text) {\r\n // 数据发送\r\n try {\r\n this.websock.send(text)\r\n } catch (err) {\r\n console.log('send failed (' + err.code + ')')\r\n }\r\n },\r\n reconnect() {\r\n if (this.lockReconnect) return\r\n this.lockReconnect = true\r\n //没连接上会一直重连,设置延迟避免请求过多\r\n setTimeout(() => {\r\n console.info('尝试重连...')\r\n this.initWebSocket()\r\n this.lockReconnect = false\r\n }, 5000)\r\n },\r\n heartCheckFun() {\r\n var that = this\r\n //心跳检测,每10分钟心跳一次\r\n this.heartCheck = {\r\n timeout: 1000 * 60 * 10,\r\n timeoutObj: null,\r\n serverTimeoutObj: null,\r\n reset: function() {\r\n clearTimeout(this.timeoutObj)\r\n this.start()\r\n return this\r\n },\r\n start: function() {\r\n var self = this\r\n this.timeoutObj = setTimeout(function() {\r\n //这里发送一个心跳,后端收到后,返回一个心跳消息,\r\n //onmessage拿到返回的心跳就说明连接正常\r\n const account = JSON.parse(sessionStorage.getItem('currentUser'))\r\n .account\r\n that.websocketSend(\"{'messageType':'ping','message':'web'}\")\r\n console.info('客户端发送心跳')\r\n //self.serverTimeoutObj = setTimeout(function(){//如果超过一定时间还没重置,说明后端主动断开了\r\n // that.websock.close();//如果onclose会执行reconnect,我们执行ws.close()就行了.如果直接执行reconnect 会触发onclose导致重连两次\r\n //}, self.timeout)\r\n }, this.timeout)\r\n }\r\n }\r\n }\r\n }\r\n}\r\n",null]}