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" d="M12 6v6m0 0v6m0-6h6m-6 0H6"
/> />
</svg> </svg>
{:else} {:else if status === "Writing"}
<svg <svg
xmlns="http://www.w3.org/2000/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" fill="none"
viewBox="0 0 24 24" viewBox="0 0 24 24"
stroke="currentColor" stroke="currentColor"

View file

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

View file

@ -1,5 +1,5 @@
<script lang="ts"> <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 { Button } from "$lib/components/ui/button";
import PaperPlane from "svelte-radix/PaperPlane.svelte"; import PaperPlane from "svelte-radix/PaperPlane.svelte";
import Message from "$lib/components/Message.svelte"; import Message from "$lib/components/Message.svelte";
@ -7,8 +7,28 @@
export let data; export let data;
export let messages = data.messages; export let messages = data.messages;
export let users = data.users; // Liste des utilisateurs export let users = data.users;
let selectedUser = null; // Utilisateur actuellement sélectionné
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> </script>
<div class="h-full flex"> <div class="h-full flex">
@ -42,8 +62,8 @@
<!-- Input pour envoyer un message --> <!-- Input pour envoyer un message -->
<div class="px-10 py-5 w-full flex gap-2 border-t"> <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..." /> <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"> <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" /> <PaperPlane class="h-6 w-6" />
</Button> </Button>
</div> </div>