ConceptPortal-public/rsconcept/frontend/src/hooks/useResolveText.ts

32 lines
1.0 KiB
TypeScript
Raw Normal View History

2023-08-23 22:57:25 +03:00
import { useCallback, useState } from 'react'
import { ErrorInfo } from '../components/BackendError';
import { DataCallback, postResolveText } from '../utils/backendAPI';
import { IReferenceData,IRSForm } from '../utils/models';
function useResolveText({ schema }: { schema?: IRSForm }) {
const [loading, setLoading] = useState(false);
const [error, setError] = useState<ErrorInfo>(undefined);
const [refsData, setRefsData] = useState<IReferenceData | undefined>(undefined);
2023-08-27 16:35:17 +03:00
const resetData = useCallback(() => setRefsData(undefined), []);
2023-08-23 22:57:25 +03:00
function resolveText(text: string, onSuccess?: DataCallback<IReferenceData>) {
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;