|
@ -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 { |
|
|
|
|
|
alert("Failed to block user"); |
|
|
|
|
|
} |
|
|
} |
|
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------/ |
|
|
|
|
|
|
|
|
|
|
|
const blockUser = async (username : string) => { |
|
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
|
|
//--------------------------------------------------------------------------------/ |
|
|
|
|
|
|
|
|
|
|
|
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> |
|
|