From 9e9ef42cf54e1df8ce9849f9ce56d01f47290a5e Mon Sep 17 00:00:00 2001 From: Jaton David Date: Tue, 17 Dec 2024 15:00:47 +0100 Subject: [PATCH] Delete media --- resources/views/dashboard.blade.php | 99 ++++++++++++++--------------- 1 file changed, 48 insertions(+), 51 deletions(-) diff --git a/resources/views/dashboard.blade.php b/resources/views/dashboard.blade.php index acf54d8..8c2f222 100644 --- a/resources/views/dashboard.blade.php +++ b/resources/views/dashboard.blade.php @@ -190,6 +190,16 @@ class="ml-2 text-red-500 hover:text-red-700 focus:outline-none"

${prettyDate} `; + if (isCurrentUser){ + mediaElement += ` + `; + } messageElement.innerHTML = mediaElement; } @@ -352,44 +362,32 @@ function leaveChat() { * @param {number} discussionId The ID of the discussion * @returns {void} or response of the fetch */ - function deleteMessage(messageId, discussionId) { - if (!messageId || !discussionId) { - alert("Informations de message ou discussion manquantes."); - return; + async function deleteMessage(messageId, discussionId) { + if (!messageId || !discussionId) { + alert("Informations de message ou discussion manquantes."); + return; + } + + const response = await fetch(`/chat/${discussionId}/${messageId}/delete`, { + method: 'DELETE', + headers: { + 'X-Requested-With': 'XMLHttpRequest', + 'X-CSRF-TOKEN': '{{ csrf_token() }}' } + }); - // Send the request to delete the message - fetch(`/chat/${discussionId}/${messageId}/delete`, { - method: 'DELETE', - headers: { - 'X-Requested-With': 'XMLHttpRequest', - 'X-CSRF-TOKEN': '{{ csrf_token() }}' - } - }) - .then(response => { - if (!response.ok) { - console.error("Erreur de suppression, statut:", response.status); - throw new Error("Impossible de supprimer le message."); - } - return response.json(); - }) - .then(data => { - currentChatId = null; + if (!response.ok) { + console.error("Erreur de suppression, statut:", response.status); + throw new Error("Impossible de supprimer le message."); + } + + const messageElement = document.getElementById(`message-div-${messageId}`); + if (messageElement) { + messageElement.remove(); + } +} - document.getElementById('chat-area').style.display = 'none'; - document.getElementById('chat-placeholder').style.display = 'flex'; - location.reload(); - const messageElement = document.getElementById(`message-div-${messageId}`); - if (messageElement) { - messageElement.remove(); - } - }) - .catch(error => { - console.error("Erreur lors de la suppression :", error); - alert("Une erreur s'est produite lors de la suppression du message."); - }); -} function leaveChatWithLoad() { const loader = document.getElementById('leave-chat-loader'); @@ -409,24 +407,23 @@ function leaveChatWithLoad() }); } -function deleteMessageWithLoader(messageId, chatId) { +async function deleteMessageWithLoader(messageId, chatId) { const loader = document.getElementById(`loader-${messageId}`); - const button = event.target; - button.style.display = 'none'; - loader.style.display = 'inline'; - - - deleteMessage(messageId, chatId) - .then(() => { - loader.style.display = 'none'; - button.style.display = 'inline'; - }) - .catch((error) => { - console.error(error); - loader.style.display = 'none'; - button.style.display = 'inline'; - }); -} + const button = event.target; + + button.style.display = 'none'; + loader.style.display = 'inline'; + + try { + await deleteMessage(messageId, chatId); + } catch (error) { + console.error(error); + } finally { + loader.style.display = 'none'; + button.style.display = 'inline'; + } +} + /** * Function to update the file name in the form