feat(dashboard): add key roles
This commit is contained in:
parent
b52df95b65
commit
65d286389d
4 changed files with 170 additions and 4 deletions
|
|
@ -77,7 +77,9 @@ export type FullGuild = {
|
|||
icon_url: string;
|
||||
categories: GuildCategory[];
|
||||
channels_without_category: GuildChannel[];
|
||||
roles: GuildRole[];
|
||||
config: GuildConfig;
|
||||
key_roles: string[];
|
||||
};
|
||||
|
||||
export type GuildCategory = {
|
||||
|
|
@ -93,6 +95,13 @@ export type GuildChannel = {
|
|||
can_redirect_from: boolean;
|
||||
};
|
||||
|
||||
export type GuildRole = {
|
||||
id: string;
|
||||
name: string;
|
||||
position: string;
|
||||
colour: string;
|
||||
};
|
||||
|
||||
export type CurrentUser = {
|
||||
user: User;
|
||||
guilds: PartialGuild[];
|
||||
|
|
|
|||
|
|
@ -1,7 +1,108 @@
|
|||
<script lang="ts">
|
||||
// TODO
|
||||
import {
|
||||
Button,
|
||||
Label,
|
||||
ListGroup,
|
||||
ListGroupItem,
|
||||
} from "@sveltestrap/sveltestrap";
|
||||
import type { PageData } from "./$types";
|
||||
import Svelecte from "svelecte";
|
||||
import { addToast } from "$lib/toast";
|
||||
import { fastFetch, type ApiError } from "$lib/api";
|
||||
|
||||
export let data: PageData;
|
||||
|
||||
$: keyRoles = data.guild.roles.filter((r) =>
|
||||
data.guild.key_roles.some((id) => r.id === id),
|
||||
);
|
||||
|
||||
$: options = data.guild.roles
|
||||
.filter((r) => !keyRoles.some((kr) => kr.id === r.id))
|
||||
.map((r) => ({ label: r.name, value: r.id }));
|
||||
|
||||
let toAdd: string | null;
|
||||
|
||||
const addRole = async () => {
|
||||
if (!toAdd) return;
|
||||
|
||||
try {
|
||||
await fastFetch("PUT", `/api/guilds/${data.guild.id}/key-roles/${toAdd}`);
|
||||
const role = data.guild.roles.find((r) => r.id === toAdd);
|
||||
data.guild.key_roles.push(toAdd);
|
||||
data.guild = data.guild;
|
||||
addToast({
|
||||
header: "Added key role",
|
||||
body: `Added ${role?.name || `unknown role ${toAdd}`} to the list of key roles.`,
|
||||
});
|
||||
toAdd = null;
|
||||
} catch (e) {
|
||||
addToast({
|
||||
header: "Error adding key role",
|
||||
body:
|
||||
(e as ApiError).message || "Unknown error. Please try again later.",
|
||||
});
|
||||
}
|
||||
};
|
||||
|
||||
const removeRole = async (id: string) => {
|
||||
try {
|
||||
await fastFetch("DELETE", `/api/guilds/${data.guild.id}/key-roles/${id}`);
|
||||
const role = data.guild.roles.find((r) => r.id === id);
|
||||
const idx = data.guild.key_roles.indexOf(id);
|
||||
if (idx > -1) data.guild.key_roles.splice(idx, 1);
|
||||
data.guild = data.guild;
|
||||
addToast({
|
||||
header: "Removed key role",
|
||||
body: `Removed ${role?.name || `unknown role ${toAdd}`} from the list of key roles.`,
|
||||
});
|
||||
} catch (e) {
|
||||
addToast({
|
||||
header: "Error removing key role",
|
||||
body:
|
||||
(e as ApiError).message || "Unknown error. Please try again later.",
|
||||
});
|
||||
}
|
||||
};
|
||||
|
||||
const colour = (c: string) => (c === "#000000" ? "current-color" : c);
|
||||
</script>
|
||||
|
||||
<h3>Key roles</h3>
|
||||
|
||||
<p>This page is still under construction!</p>
|
||||
<p>
|
||||
Key roles are logged separately from other roles, and also log <em>who</em> added
|
||||
or removed the role. Useful for moderator roles.
|
||||
</p>
|
||||
|
||||
<div>
|
||||
<Label><strong>Add a new key role</strong></Label>
|
||||
<Svelecte
|
||||
bind:value={toAdd}
|
||||
{options}
|
||||
labelField="label"
|
||||
valueField="value"
|
||||
searchable={true}
|
||||
/>
|
||||
</div>
|
||||
|
||||
<div class="my-2 d-grid d-md-block">
|
||||
<Button color="primary" on:click={() => addRole()} disabled={!toAdd}>
|
||||
Add key role
|
||||
</Button>
|
||||
</div>
|
||||
|
||||
<div>
|
||||
<h4>Current key roles</h4>
|
||||
|
||||
<ListGroup>
|
||||
{#each keyRoles as r (r.id)}
|
||||
<ListGroupItem class="d-flex justify-content-between align-items-center">
|
||||
<span>
|
||||
<span style="color: {colour(r.colour)};">●</span>
|
||||
{r.name}
|
||||
</span>
|
||||
<Button color="link" on:click={() => removeRole(r.id)}>Remove</Button>
|
||||
</ListGroupItem>
|
||||
{/each}
|
||||
</ListGroup>
|
||||
</div>
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue