Merge pull request #6 from NabilOuldHamou/features/sendMessage

Ajout de la fonction sendMessage dans la page chat coter client
This commit is contained in:
Bilal Dieumegard 2024-12-03 19:22:32 +01:00 committed by GitHub
commit 98c70f062a
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
3 changed files with 31 additions and 9 deletions

View file

@ -29,10 +29,10 @@
d="M12 6v6m0 0v6m0-6h6m-6 0H6"
/>
</svg>
{:else}
{:else if status === "Writing"}
<svg
xmlns="http://www.w3.org/2000/svg"
class="h-3 w-3 text-gray-500"
class="h-3 w-3 text-blue-500"
fill="none"
viewBox="0 0 24 24"
stroke="currentColor"

View file

@ -8,12 +8,14 @@ export async function load({ fetch, params }) {
});
const messages = await res.json();
return {
messages
messages,
channelId: params.id,
}
}catch (error) {
console.error('Erreur lors du chargement des messages:', error);
return {
messages: []
messages: [],
channelId: params.id,
};
}
}

View file

@ -1,5 +1,5 @@
<script lang="ts">
import Textarea from "../../../lib/components/ui/textarea/textarea.svelte";
import Textarea from "$lib/components/ui/textarea/textarea.svelte";
import { Button } from "$lib/components/ui/button";
import PaperPlane from "svelte-radix/PaperPlane.svelte";
import Message from "$lib/components/Message.svelte";
@ -7,8 +7,28 @@
export let data;
export let messages = data.messages;
export let users = data.users; // Liste des utilisateurs
let selectedUser = null; // Utilisateur actuellement sélectionné
export let users = data.users;
let messageText = '';
async function sendMessage() {
// Appel API pour envoyer le message
const response = await fetch(`/api/channels/${data.channelId}/messages`, {
method: 'POST',
headers: {
'Content-Type': 'application/json',
},
body: JSON.stringify({ user: data.userId, text: messageText }),
});
if (response.ok) {
messageText = '';
console.log('Message envoyé avec succès');
}else{
console.log('Erreur lors de l\'envoi du message');
}
}
</script>
<div class="h-full flex">
@ -42,8 +62,8 @@
<!-- Input pour envoyer un message -->
<div class="px-10 py-5 w-full flex gap-2 border-t">
<Textarea class="h-16 resize-none flex-grow" placeholder="Écrivez un message..." />
<Button size="icon" class="h-16 w-16 bg-blue-500 hover:bg-blue-600 h-full">
<Textarea class="h-16 resize-none flex-grow" placeholder="Écrivez un message..." value={messageText}/>
<Button size="icon" class="h-16 w-16 bg-blue-500 hover:bg-blue-600 h-full" on:click={sendMessage}>
<PaperPlane class="h-6 w-6" />
</Button>
</div>