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

56 lines
1.5 KiB
TypeScript
Raw Normal View History

2024-06-07 20:17:03 +03:00
'use client';
import { useCallback, useState } from 'react';
import { DataCallback, postGenerateLexeme, postInflectText, postParseText } from '@/app/backendAPI';
import { ErrorData } from '@/components/info/InfoError';
import { ILexemeData, ITextRequest, ITextResult, IWordFormPlain } from '@/models/language';
function useConceptText() {
const [processing, setProcessing] = useState(false);
2024-06-07 20:17:03 +03:00
const [error, setError] = useState<ErrorData>(undefined);
const inflect = useCallback((data: IWordFormPlain, onSuccess: DataCallback<ITextResult>) => {
setError(undefined);
postInflectText({
data: data,
showError: true,
setLoading: setProcessing,
2024-06-07 20:17:03 +03:00
onError: setError,
onSuccess: data => {
if (onSuccess) onSuccess(data);
}
});
}, []);
const parse = useCallback((data: ITextRequest, onSuccess: DataCallback<ITextResult>) => {
setError(undefined);
postParseText({
data: data,
showError: true,
setLoading: setProcessing,
2024-06-07 20:17:03 +03:00
onError: setError,
onSuccess: data => {
if (onSuccess) onSuccess(data);
}
});
}, []);
const generateLexeme = useCallback((data: ITextRequest, onSuccess: DataCallback<ILexemeData>) => {
setError(undefined);
postGenerateLexeme({
data: data,
showError: true,
setLoading: setProcessing,
2024-06-07 20:17:03 +03:00
onError: setError,
onSuccess: data => {
if (onSuccess) onSuccess(data);
}
});
}, []);
return { inflect, parse, generateLexeme, error, setError, processing };
2024-06-07 20:17:03 +03:00
}
export default useConceptText;