Merge pull request #6 from NabilOuldHamou/features/sendMessage
Ajout de la fonction sendMessage dans la page chat coter client
This commit is contained in:
commit
98c70f062a
3 changed files with 31 additions and 9 deletions
|
@ -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"
|
||||||
|
|
|
@ -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,
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
}
|
}
|
|
@ -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>
|
||||||
|
|
Loading…
Add table
Reference in a new issue