
Loading is a flag for data loading on context create Processing is a flag for waiting for response after function call
35 lines
1.1 KiB
TypeScript
35 lines
1.1 KiB
TypeScript
'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);
|
|
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,
|
|
onError: setError,
|
|
onSuccess: data => {
|
|
setRefsData(data);
|
|
if (onSuccess) onSuccess(data);
|
|
}
|
|
});
|
|
}
|
|
|
|
return { refsData, resolveText, resetData, error, setError, processing };
|
|
}
|
|
|
|
export default useResolveText;
|