2023-08-23 22:57:25 +03:00
|
|
|
import { useCallback, useState } from 'react'
|
|
|
|
|
|
|
|
import { ErrorInfo } from '../components/BackendError';
|
2023-09-25 14:17:52 +03:00
|
|
|
import { IResolutionData } from '../models/language';
|
2023-09-11 20:31:54 +03:00
|
|
|
import { IRSForm } from '../models/rsform';
|
2023-08-23 22:57:25 +03:00
|
|
|
import { DataCallback, postResolveText } from '../utils/backendAPI';
|
|
|
|
|
|
|
|
function useResolveText({ schema }: { schema?: IRSForm }) {
|
|
|
|
const [loading, setLoading] = useState(false);
|
|
|
|
const [error, setError] = useState<ErrorInfo>(undefined);
|
2023-09-25 14:17:52 +03:00
|
|
|
const [refsData, setRefsData] = useState<IResolutionData | undefined>(undefined);
|
2023-08-23 22:57:25 +03:00
|
|
|
|
2023-08-27 16:35:17 +03:00
|
|
|
const resetData = useCallback(() => setRefsData(undefined), []);
|
2023-08-23 22:57:25 +03:00
|
|
|
|
2023-09-25 14:17:52 +03:00
|
|
|
function resolveText(text: string, onSuccess?: DataCallback<IResolutionData>) {
|
2023-08-23 22:57:25 +03:00
|
|
|
setError(undefined);
|
|
|
|
postResolveText(String(schema!.id), {
|
|
|
|
data: { text: text },
|
|
|
|
showError: true,
|
|
|
|
setLoading,
|
2023-08-27 16:35:17 +03:00
|
|
|
onError: error => setError(error),
|
2023-08-23 22:57:25 +03:00
|
|
|
onSuccess: data => {
|
|
|
|
setRefsData(data);
|
|
|
|
if (onSuccess) onSuccess(data);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
return { refsData, resolveText, resetData, error, setError, loading };
|
|
|
|
}
|
|
|
|
|
|
|
|
export default useResolveText;
|