Portal/rsconcept/frontend/src/hooks/useResolveText.ts

35 lines
1.1 KiB
TypeScript
Raw Normal View History

2024-06-07 20:17:03 +03:00
'use client';
import { useCallback, useState } from 'react';
import { DataCallback, postResolveText } from '@/app/backendAPI';
import { ErrorData } from '@/components/info/InfoError';
import { IResolutionData } from '@/models/language';
import { IRSForm } from '@/models/rsform';
function useResolveText({ schema }: { schema?: IRSForm }) {
const [processing, setProcessing] = useState(false);
2024-06-07 20:17:03 +03:00
const [error, setError] = useState<ErrorData>(undefined);
const [refsData, setRefsData] = useState<IResolutionData | undefined>(undefined);
const resetData = useCallback(() => setRefsData(undefined), []);
function resolveText(text: string, onSuccess?: DataCallback<IResolutionData>) {
setError(undefined);
postResolveText(String(schema!.id), {
data: { text: text },
showError: true,
setLoading: setProcessing,
2024-06-07 20:17:03 +03:00
onError: setError,
onSuccess: data => {
setRefsData(data);
if (onSuccess) onSuccess(data);
}
});
}
return { refsData, resolveText, resetData, error, setError, processing };
2024-06-07 20:17:03 +03:00
}
export default useResolveText;