ramimu's picture
Upload 586 files
1c72248 verified
'use client';
import { useEffect, useState, useRef } from 'react';
import { apiClient } from '@/utils/api';
interface FileObject {
path: string;
size: number;
}
const clean = (text: string): string => {
// remove \x1B[A\x1B[A
text = text.replace(/\x1B\[A/g, '');
return text;
};
export default function useJobLog(jobID: string, reloadInterval: null | number = null) {
const [log, setLog] = useState<string>('');
const didInitialLoadRef = useRef(false);
const [status, setStatus] = useState<'idle' | 'loading' | 'success' | 'error' | 'refreshing'>('idle');
const refresh = () => {
let loadStatus: 'loading' | 'refreshing' = 'loading';
if (didInitialLoadRef.current) {
loadStatus = 'refreshing';
}
setStatus(loadStatus);
apiClient
.get(`/api/jobs/${jobID}/log`)
.then(res => res.data)
.then(data => {
if (data.log) {
let cleanLog = clean(data.log);
setLog(cleanLog);
}
setStatus('success');
didInitialLoadRef.current = true;
})
.catch(error => {
console.error('Error fetching log:', error);
setStatus('error');
});
};
useEffect(() => {
refresh();
if (reloadInterval) {
const interval = setInterval(() => {
refresh();
}, reloadInterval);
return () => {
clearInterval(interval);
};
}
}, [jobID]);
return { log, setLog, status, refresh };
}