({
files,
formData,
typeDef,
projectId,
className,
onStatusChange,
autoStart,
}: TaskControlsProps)
| 22 | type TaskCompletePayload = { projectId?: string; status?: string } | string; |
| 23 | |
| 24 | const TaskControls = ({ |
| 25 | files, |
| 26 | formData, |
| 27 | typeDef, |
| 28 | projectId, |
| 29 | className, |
| 30 | onStatusChange, |
| 31 | autoStart, |
| 32 | }: TaskControlsProps) => { |
| 33 | const [taskStatus, setTaskStatusState] = useState('idle'); |
| 34 | // 首次状态同步是否已完成:autostart 必须等它,否则迟到的 'idle' 会覆盖乐观 'running' |
| 35 | const [statusSynced, setStatusSynced] = useState(false); |
| 36 | const { t } = useTranslation(['home', 'common']); |
| 37 | |
| 38 | const setTaskStatus = (status: string) => { |
| 39 | setTaskStatusState(status); |
| 40 | onStatusChange?.(status); |
| 41 | }; |
| 42 | |
| 43 | useEffect(() => { |
| 44 | setStatusSynced(false); |
| 45 | if (!projectId) return; |
| 46 | let disposed = false; |
| 47 | // 获取当前工程的任务状态 |
| 48 | const getCurrentTaskStatus = async () => { |
| 49 | const status = await window?.ipc?.invoke('getTaskStatus', projectId); |
| 50 | if (!disposed && status) setTaskStatus(status); |
| 51 | if (!disposed) setStatusSynced(true); |
| 52 | }; |
| 53 | getCurrentTaskStatus(); |
| 54 | |
| 55 | // 监听本工程的任务完成事件 |
| 56 | const cleanup = window?.ipc?.on( |
| 57 | 'taskComplete', |
| 58 | (payload: TaskCompletePayload) => { |
| 59 | const status = typeof payload === 'string' ? payload : payload?.status; |
| 60 | const pid = |
| 61 | typeof payload === 'string' ? undefined : payload?.projectId; |
| 62 | if (pid && pid !== projectId) return; |
| 63 | if (status) setTaskStatus(status); |
| 64 | }, |
| 65 | ); |
| 66 | |
| 67 | return () => { |
| 68 | disposed = true; |
| 69 | cleanup?.(); |
| 70 | }; |
| 71 | }, [projectId]); |
| 72 | |
| 73 | const handleTask = async () => { |
| 74 | if (!files?.length) { |
| 75 | toast(t('common:notification'), { |
| 76 | description: t('home:noTask'), |
| 77 | }); |
| 78 | return; |
| 79 | } |
| 80 | // 带翻译的任务必须有有效翻译服务商('-1' 为历史「不翻译」残留值) |
| 81 | if (typeDef.hasTranslate) { |
nothing calls this directly
no test coverage detected