Browse Source

chat

master
WalidMoovin 2 years ago
parent
commit
b4c8a49dab
  1. 13
      front/volume/src/App.svelte
  2. 9
      front/volume/src/components/Channels.svelte
  3. 178
      front/volume/src/components/Chat.svelte

13
front/volume/src/App.svelte

@ -86,17 +86,7 @@
function clickChannels() { function clickChannels() {
setAppState(APPSTATE.CHANNELS); setAppState(APPSTATE.CHANNELS);
} }
let channels: Array<ChannelsType> = [ let channels: Array<ChannelsType> = [];
{ id: "1", name: "General", messages: [], privacy: "public", password: "" },
{
id: "2",
name: "Lobby",
messages: [],
privacy: "private",
password: "test",
},
{ id: "3", name: "Game", messages: [], privacy: "private", password: "" },
];
let selectedChannel: ChannelsType; let selectedChannel: ChannelsType;
const handleSelectChannel = (channel: ChannelsType) => { const handleSelectChannel = (channel: ChannelsType) => {
selectedChannel = channel; selectedChannel = channel;
@ -151,7 +141,6 @@
on:keydown={() => setAppState(APPSTATE.CHANNELS)} on:keydown={() => setAppState(APPSTATE.CHANNELS)}
> >
<Chat <Chat
chatMessages={selectedChannel.messages}
on:view-profile={openIdProfile} on:view-profile={openIdProfile}
on:add-friend={addFriend} on:add-friend={addFriend}
on:invite-to-game={pong.inviteToGame} on:invite-to-game={pong.inviteToGame}

9
front/volume/src/components/Channels.svelte

@ -5,11 +5,11 @@
name: string; name: string;
privacy: string; privacy: string;
password: string; password: string;
messages: Array<chatMessagesType>; owner: string;
} }
import { onMount } from "svelte"; import { onMount } from "svelte";
import { API_URL, store } from "../Auth"; import { API_URL, store } from "../Auth";
import { dataset_dev } from "svelte/internal"; import { dataset_dev } from "svelte/internal";
</script> </script>
<script lang="ts"> <script lang="ts">
@ -58,9 +58,9 @@
const newChannel: ChannelsType = { const newChannel: ChannelsType = {
id: Math.random().toString(), id: Math.random().toString(),
name, name,
privacy, owner: $store.username,
password, password,
messages: [], privacy,
}; };
// const response = await fetch(API_URL + "/channels" + $store.ftId , { // const response = await fetch(API_URL + "/channels" + $store.ftId , {
// method: "POST", // method: "POST",
@ -73,6 +73,7 @@
// } else { // } else {
// alert("Error creating channel"); // alert("Error creating channel");
// } // }
channels = [newChannel, ...channels];
} }
} }
}; };

178
front/volume/src/components/Chat.svelte

@ -45,6 +45,8 @@
function openProfile(username: string) { function openProfile(username: string) {
showProfileMenu = true; showProfileMenu = true;
selectedUser = username; selectedUser = username;
showChatMembers = false;
showChannelSettings = false;
} }
function closeProfileMenu() { function closeProfileMenu() {
showProfileMenu = false; showProfileMenu = false;
@ -57,6 +59,7 @@
let showChatMembers = false; let showChatMembers = false;
function toggleChatMembers() { function toggleChatMembers() {
showChatMembers = !showChatMembers; showChatMembers = !showChatMembers;
showChannelSettings = false;
} }
let chatMembers: Array<User> = [ let chatMembers: Array<User> = [
{ username: "user1" }, { username: "user1" },
@ -80,18 +83,122 @@
//--------------------------------------------------------------------------------/ //--------------------------------------------------------------------------------/
const blockUser = async () => { let showChannelSettings = false;
const res = await fetch(API_URL + "/chat/block", { function toggleChannelSettings() {
method: "POST", showChannelSettings = !showChannelSettings;
mode: "cors", showChatMembers = false;
}); }
const data = await res.json();
if (data.success) { //--------------------------------------------------------------------------------/
alert("User blocked");
} else { const blockUser = async (username : string) => {
alert("Failed to block user"); };
}
}; //--------------------------------------------------------------------------------/
const banUser = async (username : string) => {
// const prompt = window.prompt("Enter ban duration in seconds");
// const res1 = await fetch(API_URL + "/user/" + username, {
// mode: "cors",
// });
// const data1 = await res1.json();
// const res2 = await fetch(API_URL + "/chat/channels/" + data1.ftId + "/ban", {
// method: "POST",
// mode: "cors",
// });
// const data2 = await res2.json();
// if (res2.ok) {
// alert("User banned");
// } else {
// alert("Failed to ban user");
// }
};
//--------------------------------------------------------------------------------/
const kickUser = async (username : string) => {
// set-up channel joining and kicking
// const res1 = await fetch(API_URL + "/user/" + username, {
// mode: "cors",
// });
// const data1 = await res1.json();
// const res2 = await fetch(API_URL + "/chat/channels/" + data1.ftId + "/kick", {
// method: "POST",
// mode: "cors",
// });
// const data2 = await res2.json();
// if (res2.ok) {
// alert("User kicked");
// } else {
// alert("Failed to kick user");
// }
};
//--------------------------------------------------------------------------------/
const muteUser = async (username : string) => {
// use minutes prompt to determine mute duration
// const prompt = window.prompt("Enter mute duration in seconds");
// const res1 = await fetch(API_URL + "/user/" + username, {
// mode: "cors",
// });
// const data1 = await res1.json();
// const res2 = await fetch(API_URL + "/chat/channels/" + data1.ftId + "/mute", {
// method: "POST",
// mode: "cors",
// });
// const data2 = await res2.json();
// if (res2.ok) {
// alert("User muted");
// } else {
// alert("Failed to mute user");
// }
};
//--------------------------------------------------------------------------------/
const adminUser = async (username : string) => {
// const res1 = await fetch(API_URL + "/user/" + username, {
// mode: "cors",
// });
// const data1 = await res1.json();
// const res2 = await fetch(API_URL + "/chat/channels/" + data1.ftId + "/admin", {
// method: "POST",
// mode: "cors",
// });
// const data2 = await res2.json();
// if (res2.ok) {
// alert("User admined");
// } else {
// alert("Failed to admin user");
// }
};
//--------------------------------------------------------------------------------/
const removeAdminUser = async (username : string) => {
// const res1 = await fetch(API_URL + "/user/" + username, {
// mode: "cors",
// });
// const data1 = await res1.json();
// const res2 = await fetch(API_URL + "/chat/channels/" + data1.ftId + "/admin", {
// method: "DELETE",
// mode: "cors",
// });
// const data2 = await res2.json();
// if (res2.ok) {
// alert("User admin removed");
// } else {
// alert("Failed to remove admin user");
// }
};
//--------------------------------------------------------------------------------/
</script> </script>
<div class="overlay"> <div class="overlay">
@ -138,7 +245,8 @@
> >
</li> </li>
<li> <li>
<button on:click={() => dispatch("block-user", selectedUser)} <!-- block only if not blocked -->
<button on:click={() => blockUser(selectedUser)}
>Block User</button >Block User</button
> >
</li> </li>
@ -168,17 +276,35 @@
<li> <li>
<p> <p>
{member.username} {member.username}
<button>ban</button> <button on:click={() => banUser(member.username)}>ban</button>
<button>kick</button> <button on:click={() => kickUser(member.username)}>kick</button>
<button>mute</button> <button on:click={() => muteUser(member.username)}>mute</button>
<button>admin</button> <button on:click={() => adminUser(member.username)}>promote</button>
</p> <button on:click={() => removeAdminUser(member.username)}>demote</button>
<p> ----------------------------------------------------------------------------------- </p>
</li> </li>
{/each} {/each}
</ul> </ul>
</div> </div>
</div> </div>
{/if} {/if}
<button
on:click|stopPropagation={toggleChannelSettings}
on:keydown|stopPropagation>Channel Settings</button
>
{#if showChannelSettings}
<div
class="channelSettings"
on:click|stopPropagation
on:keydown|stopPropagation
>
<div>
<button>Change Password</button>
<button>Set Password</button>
<button>Remove Password</button>
</div>
</div>
{/if}
</div> </div>
</div> </div>
@ -225,6 +351,20 @@
} }
.chatMembers button { .chatMembers button {
width: 3.5rem; width: 6rem;
}
.channelSettings {
position: absolute;
background-color: #fff;
border: 1px solid #ccc;
border-radius: 5px;
padding: 1rem;
max-height: 100px;
overflow-y: scroll;
}
.channelSettings button {
width: 5rem;
} }
</style> </style>

Loading…
Cancel
Save