import { ref, watchEffect, watch } from 'vue'; import useWebSocket, { SocketStatus } from './useWebSocket'; // 用户的store,用于检测登录 // import { useAdminStore } from '@stores/adminStore'; import useUserStore from '@/store/modules/user'; import { getToken } from '@/utils/auth'; export default function useSocket(path) { // window.location.host // '58.51.132.86:8102' let url = import.meta.env.VITE_APP_ENV == 'development' ? 'ws://192.168.16.254:13002/' + '/mess_notice' : 'ws://' + window.location.host + '/' + path; const { status, message, error, connect, disconnect } = useWebSocket({ url, heartBeatData: 'ping', token: getToken(), }); const { userInfo } = storeToRefs(useUserStore()); const chatMessage = ref(null); const socketStatusText = ref(''); window.addEventListener('offline', function () { console.log('网络连接已断开'); }); window.addEventListener('online', function () { console.log('网络连接已恢复'); // 在网络连接恢复后执行的操作 retryConnect(); }); watch( () => status.value, newVal => { if (newVal != SocketStatus.Connected) { socketStatusText.value = newVal; } } ); watch( () => message.value, newVal => { if (newVal) { chatMessage.value = newVal; } } ); watchEffect(() => { // 检测登录后就发起连接,退出后断开连接 if (userInfo.value.userId) { connect(); } else { disconnect(); } }); const retryConnect = () => { if (status.value !== SocketStatus.Connected) { connect(); } }; return { socketStatusText, chatMessage, retryConnect, }; }