sse.ts 980 B

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. import { getToken } from '@/utils/auth';
  2. import { ElNotification } from 'element-plus';
  3. import useNoticeStore from '@/store/modules/notice';
  4. let message = '';
  5. // 初始化
  6. export const initSSE = (url: any) => {
  7. url = url + '?Authorization=Bearer ' + getToken() + '&clientid=' + import.meta.env.VITE_APP_CLIENT_ID
  8. const {
  9. data,
  10. error
  11. } = useEventSource(url, [], {
  12. autoReconnect: {
  13. retries: 10,
  14. delay: 3000,
  15. onFailed() {
  16. console.log('Failed to connect after 10 retries')
  17. },
  18. }
  19. });
  20. watch(error, () => {
  21. console.log('SSE connection error:', error.value)
  22. error.value = null;
  23. });
  24. watch(data, () => {
  25. if (!data.value) return;
  26. useNoticeStore().addNotice({
  27. message: data.value,
  28. read: false,
  29. time: new Date().toLocaleString()
  30. });
  31. ElNotification({
  32. title: '消息',
  33. message: data.value,
  34. type: 'success',
  35. duration: 3000
  36. });
  37. data.value = null;
  38. });
  39. };