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

58 lines
1.5 KiB
TypeScript
Raw Normal View History

'use client';
import { useCallback, useState } from 'react';
2023-09-25 14:17:52 +03:00
import { ErrorData } from '@/components/InfoError';
import { ILexemeData, ITextRequest, ITextResult, IWordFormPlain } from '@/models/language';
import { DataCallback, postGenerateLexeme, postInflectText, postParseText } from '@/utils/backendAPI';
2023-09-25 14:17:52 +03:00
function useConceptText() {
const [loading, setLoading] = useState(false);
const [error, setError] = useState<ErrorData>(undefined);
2023-09-25 14:17:52 +03:00
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;