Files
PrivyDrop/frontend/hooks/useWebRTCConnection.ts
T
2025-08-17 15:44:59 +08:00

77 lines
2.7 KiB
TypeScript

import { useEffect, useMemo } from 'react';
import { webrtcService } from '@/lib/webrtcService';
import { useFileTransferStore } from '@/stores/fileTransferStore';
import type { Messages } from "@/types/messages";
// 保留类型定义以保持兼容性
export type PeerProgressDetails = { progress: number; speed: number };
export type FileProgressPeers = { [peerId: string]: PeerProgressDetails };
export type ProgressState = { [fileId: string]: FileProgressPeers };
interface UseWebRTCConnectionProps {
messages: Messages | null;
putMessageInMs: (message: string, isShareEnd?: boolean, displayTimeMs?: number) => void;
}
export function useWebRTCConnection({ messages, putMessageInMs }: UseWebRTCConnectionProps) {
// 从 store 获取状态
const {
sharePeerCount,
retrievePeerCount,
senderDisconnected,
sendProgress,
receiveProgress,
setIsAnyFileTransferring,
} = useFileTransferStore();
// 计算是否有文件正在传输
const isAnyFileTransferring = useMemo(() => {
const allProgress = [
...Object.values(sendProgress),
...Object.values(receiveProgress),
];
return allProgress.some((fileProgress: any) => {
return Object.values(fileProgress).some((progress: any) => {
return progress.progress > 0 && progress.progress < 1;
});
});
}, [sendProgress, receiveProgress]);
useEffect(() => {
setIsAnyFileTransferring(isAnyFileTransferring);
}, [isAnyFileTransferring, setIsAnyFileTransferring]);
// 确保服务在 React 生命周期内被初始化
useEffect(() => {
console.log('[useWebRTCConnection] WebRTC 服务已初始化');
return () => {
console.log('[useWebRTCConnection] Hook 清理');
};
}, []);
return {
// 状态从 store 获取
sharePeerCount,
retrievePeerCount,
senderDisconnected,
sendProgress,
receiveProgress,
// 方法直接从 service 暴露
broadcastDataToAllPeers: webrtcService.broadcastDataToAllPeers.bind(webrtcService),
requestFile: webrtcService.requestFile.bind(webrtcService),
requestFolder: webrtcService.requestFolder.bind(webrtcService),
setReceiverDirectoryHandle: webrtcService.setReceiverDirectoryHandle.bind(webrtcService),
getReceiverSaveType: webrtcService.getReceiverSaveType.bind(webrtcService),
manualSafeSave: webrtcService.manualSafeSave.bind(webrtcService),
// 重置连接方法
resetSenderConnection: () => webrtcService.leaveRoom(true),
resetReceiverConnection: () => webrtcService.leaveRoom(false),
// 为了兼容性,保留这些属性(但实际上不再需要)
sender: webrtcService.sender,
receiver: webrtcService.receiver,
};
}