import {FontAwesomeIcon} from "@fortawesome/react-fontawesome"; import {faTrash} from "@fortawesome/free-solid-svg-icons"; import {useContext, useState} from "react"; import System from "@/lib/models/System"; import {SessionContext} from "@/context/SessionContext"; import {LangContext, LangContextProps} from "@/context/LangContext"; import {AlertContext, AlertContextProps} from "@/context/AlertContext"; import AlertBox from "@/components/AlertBox"; import OfflineContext, {OfflineContextType} from "@/context/OfflineContext"; import {BooksSyncContext, BooksSyncContextProps} from "@/context/BooksSyncContext"; import {SyncedBook} from "@/lib/models/SyncedBook"; interface DeleteBookProps { bookId: string; } export default function DeleteBook({bookId}: DeleteBookProps) { const {session} = useContext(SessionContext); const {lang} = useContext(LangContext) const {isCurrentlyOffline} = useContext(OfflineContext); const [showConfirmBox, setShowConfirmBox] = useState(false); const {errorMessage} = useContext(AlertContext) const {serverOnlyBooks,setServerOnlyBooks,localOnlyBooks,setLocalOnlyBooks} = useContext(BooksSyncContext); function handleConfirmation(): void { setShowConfirmBox(true); } async function handleDeleteBook(): Promise { try { let response: boolean; const deleteData = { id: bookId }; const ifLocalBook: SyncedBook | undefined = localOnlyBooks.find((book: SyncedBook): boolean => book.id === bookId); if (isCurrentlyOffline() || ifLocalBook) { response = await window.electron.invoke('db:book:delete', deleteData); } else { response = await System.authDeleteToServer( `book/delete`, deleteData, session.accessToken, lang ); } if (response) { setShowConfirmBox(false); if (ifLocalBook) { setLocalOnlyBooks(localOnlyBooks.filter((b: SyncedBook): boolean => b.id !== bookId)); } else { setServerOnlyBooks(serverOnlyBooks.filter((b: SyncedBook): boolean => b.id !== bookId)); } } } catch (e: unknown) { if (e instanceof Error) { errorMessage(e.message) } else { errorMessage("Une erreur inconnue est survenue lors de la suppression du livre."); } } } return ( <> { showConfirmBox && ( setShowConfirmBox(false)} confirmText={'Supprimer'} cancelText={'Annuler'}/> ) } ) }