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

57 lines
1.5 KiB
TypeScript
Raw Normal View History

import { useCallback, useState } from 'react';
2023-09-25 14:17:52 +03:00
import { ErrorInfo } from '../components/BackendError';
import { ILexemeData, ITextRequest, ITextResult, IWordFormPlain } from '../models/language';
import { DataCallback, postGenerateLexeme, postInflectText, postParseText } from '../utils/backendAPI';
function useConceptText() {
const [loading, setLoading] = useState(false);
const [error, setError] = useState<ErrorInfo>(undefined);
const inflect = useCallback(
(data: IWordFormPlain, onSuccess: DataCallback<ITextResult>) => {
setError(undefined);
postInflectText({
data: data,
showError: true,
setLoading,
onError: error => setError(error),
onSuccess: data => {
if (onSuccess) onSuccess(data);
}
});
}, []);
const parse = useCallback(
(data: ITextRequest, onSuccess: DataCallback<ITextResult>) => {
setError(undefined);
postParseText({
data: data,
showError: true,
setLoading,
onError: error => setError(error),
onSuccess: data => {
if (onSuccess) onSuccess(data);
}
});
}, []);
const generateLexeme = useCallback(
(data: ITextRequest, onSuccess: DataCallback<ILexemeData>) => {
setError(undefined);
postGenerateLexeme({
data: data,
showError: true,
setLoading,
onError: error => setError(error),
onSuccess: data => {
if (onSuccess) onSuccess(data);
}
});
}, []);
return { inflect, parse, generateLexeme, error, setError, loading };
}
export default useConceptText;