Newer
Older
urbanLifeline_YanAn / src / utils / ws / useSocket.js
@zhangzhihui zhangzhihui 15 days ago 1 KB WS + 模型
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,
  };
}