|
@ -1,7 +1,7 @@ |
|
|
<script lang="ts" context="module"> |
|
|
<script lang="ts" context="module"> |
|
|
export interface chatMessagesType { |
|
|
export interface chatMessagesType { |
|
|
id: number; |
|
|
id: number; |
|
|
author: string; |
|
|
author: User; |
|
|
text: string; |
|
|
text: string; |
|
|
} |
|
|
} |
|
|
import { createEventDispatcher, onDestroy, onMount } from "svelte"; |
|
|
import { createEventDispatcher, onDestroy, onMount } from "svelte"; |
|
@ -18,38 +18,35 @@ |
|
|
export let channel: ChannelsType; |
|
|
export let channel: ChannelsType; |
|
|
let newText = ""; |
|
|
let newText = ""; |
|
|
onMount(async () => { |
|
|
onMount(async () => { |
|
|
let res = await fetch(API_URL + "/users/block/" + $store.ftId, { |
|
|
let res = await fetch(API_URL + "/users/blocked/", { |
|
|
credentials: "include", |
|
|
credentials: "include", |
|
|
mode: "cors", |
|
|
mode: "cors", |
|
|
}); |
|
|
}); |
|
|
if (res.ok) blockedUsers = await res.json(); |
|
|
if (res.ok) blockedUsers = await res.json(); |
|
|
|
|
|
|
|
|
|
|
|
}); |
|
|
socket.on("messages", (msgs: Array<chatMessagesType>) => { |
|
|
socket.on("messages", (msgs: Array<chatMessagesType>) => { |
|
|
chatMessages = msgs; |
|
|
chatMessages = msgs; |
|
|
}); |
|
|
}); |
|
|
|
|
|
|
|
|
socket.on("newMessage", (msg: chatMessagesType) => { |
|
|
socket.on("newMessage", (msg: chatMessagesType) => { |
|
|
chatMessages = [...chatMessages.slice(-5 + 1), msg]; |
|
|
chatMessages = [...chatMessages, msg]; |
|
|
}); |
|
|
}); |
|
|
|
|
|
|
|
|
onDestroy(() => { |
|
|
onDestroy(() => { |
|
|
socket.emit("leaveChannel", channel.id, $store.ftId); |
|
|
socket.emit("leaveChannel"); |
|
|
}); |
|
|
}) |
|
|
}); |
|
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------/ |
|
|
//--------------------------------------------------------------------------------/ |
|
|
|
|
|
|
|
|
const sendMessage = () => { |
|
|
const sendMessage = () => { |
|
|
if (newText !== "") { |
|
|
if (newText !== "") { |
|
|
/* |
|
|
|
|
|
const newMessage = { |
|
|
|
|
|
id: chatMessages.length + 1, |
|
|
|
|
|
author: $store.username, |
|
|
|
|
|
text: newText, |
|
|
|
|
|
}; |
|
|
|
|
|
*/ |
|
|
|
|
|
chatMessages = [...chatMessages.slice(-5 + 1)]; |
|
|
chatMessages = [...chatMessages.slice(-5 + 1)]; |
|
|
socket.emit("addMessage", channel.id, $store.ftId, newText); |
|
|
socket.emit("addMessage", { |
|
|
|
|
|
text: newText, |
|
|
|
|
|
UserId: $store.ftId, |
|
|
|
|
|
ChannelId: channel.id, |
|
|
|
|
|
}) |
|
|
newText = ""; |
|
|
newText = ""; |
|
|
const messagesDiv = document.querySelector(".messages"); |
|
|
const messagesDiv = document.querySelector(".messages"); |
|
|
if (messagesDiv) { |
|
|
if (messagesDiv) { |
|
@ -275,8 +272,8 @@ |
|
|
{#if !blockedUsers.filter((user) => user.username == message.author).length} |
|
|
{#if !blockedUsers.filter((user) => user.username == message.author).length} |
|
|
<span |
|
|
<span |
|
|
class="message-name" |
|
|
class="message-name" |
|
|
on:click={() => openProfile(message.author)} |
|
|
on:click={() => openProfile(message.author.username)} |
|
|
on:keydown={() => openProfile(message.author)} |
|
|
on:keydown={() => openProfile(message.author.username)} |
|
|
style="cursor: pointer;" |
|
|
style="cursor: pointer;" |
|
|
> |
|
|
> |
|
|
{message.author} |
|
|
{message.author} |
|
|