'use client' import {ChangeEvent, forwardRef, useContext, useEffect, useImperativeHandle, useState} from "react"; import System from "@/lib/models/System"; import {AlertContext} from "@/context/AlertContext"; import {SessionContext} from "@/context/SessionContext"; import TextInput from "@/components/form/TextInput"; import TexteAreaInput from "@/components/form/TexteAreaInput"; import InputField from "@/components/form/InputField"; import {useTranslations} from "next-intl"; import {LangContext, LangContextProps} from "@/context/LangContext"; import {SeriesContext, SeriesContextProps} from "@/context/SeriesContext"; import {SeriesDetailResponse, SeriesUpdateResponse} from "@/lib/models/Series"; import {FontAwesomeIcon} from "@fortawesome/react-fontawesome"; import {faSpinner} from "@fortawesome/free-solid-svg-icons"; import OfflineContext, {OfflineContextType} from "@/context/OfflineContext"; import {LocalSyncQueueContext, LocalSyncQueueContextProps} from "@/context/SyncQueueContext"; import {SeriesSyncContext, SeriesSyncContextProps} from "@/context/SeriesSyncContext"; import {SyncedSeries} from "@/lib/models/SyncedSeries"; function BasicSeriesInformation(props: object, ref: React.Ref<{ handleSave: () => Promise }>) { const t = useTranslations(); const {lang} = useContext(LangContext); const {session} = useContext(SessionContext); const {seriesId, localSeries} = useContext(SeriesContext); const userToken: string = session?.accessToken ? session?.accessToken : ''; const {errorMessage, successMessage} = useContext(AlertContext); const {isCurrentlyOffline} = useContext(OfflineContext); const {addToQueue} = useContext(LocalSyncQueueContext); const {localSyncedSeries} = useContext(SeriesSyncContext); const [isLoading, setIsLoading] = useState(true); const [name, setName] = useState(''); const [description, setDescription] = useState(''); useEffect(function () { if (seriesId) { loadSeriesData(); } }, [seriesId]); async function loadSeriesData(): Promise { setIsLoading(true); try { let response: SeriesDetailResponse; if (isCurrentlyOffline() || localSeries) { response = await window.electron.invoke('db:series:detail', {seriesId}); } else { response = await System.authGetQueryToServer( 'series/detail', userToken, lang, {seriesid: seriesId} ); } if (response) { setName(response.name); setDescription(response.description || ''); } } catch (e: unknown) { if (e instanceof Error) { errorMessage(e.message); } else { errorMessage(t('seriesBasicInformation.error.unknown')); } } finally { setIsLoading(false); } } useImperativeHandle(ref, function () { return { handleSave: handleSave }; }); async function handleSave(): Promise { if (!name) { errorMessage(t('seriesBasicInformation.error.nameRequired')); return; } try { const updateData = { seriesId: seriesId, name: name, description: description }; let success: boolean; if (isCurrentlyOffline() || localSeries) { success = await window.electron.invoke('db:series:update', updateData); } else { const response: SeriesUpdateResponse = await System.authPutToServer( 'series/update', updateData, userToken, lang ); success = response.success; if (localSyncedSeries.find((s: SyncedSeries): boolean => s.id === seriesId)) { addToQueue('db:series:update', updateData); } } if (!success) { errorMessage(t('seriesBasicInformation.error.update')); return; } successMessage(t('seriesBasicInformation.success.update')); } catch (e: unknown) { if (e instanceof Error) { errorMessage(e.message); } else { errorMessage(t('seriesBasicInformation.error.unknown')); } } } if (isLoading) { return (
); } return (
) => setName(e.target.value)} placeholder={t('seriesBasicInformation.fields.namePlaceholder')} />}/>
) => setDescription(e.target.value)} placeholder={t('seriesBasicInformation.fields.descriptionPlaceholder')} />}/>
); } export default forwardRef(BasicSeriesInformation);