revite/src/pages/settings/server/Bans.tsx

88 lines
3.2 KiB
TypeScript
Raw Normal View History

import { XCircle } from "@styled-icons/boxicons-regular";
import { Servers, Users } from "revolt.js/dist/api/objects";
2021-07-05 11:23:23 +01:00
import styles from "./Panes.module.scss";
import { Text } from "preact-i18n";
2021-06-19 22:37:12 +01:00
import { useContext, useEffect, useState } from "preact/hooks";
2021-07-05 11:23:23 +01:00
2021-06-19 22:37:12 +01:00
import { AppContext } from "../../../context/revoltjs/RevoltClient";
import UserIcon from "../../../components/common/user/UserIcon";
import IconButton from "../../../components/ui/IconButton";
import Preloader from "../../../components/ui/Preloader";
2021-07-05 11:23:23 +01:00
2021-06-19 22:37:12 +01:00
interface Props {
2021-07-05 11:25:20 +01:00
server: Servers.Server;
2021-06-19 22:37:12 +01:00
}
export function Bans({ server }: Props) {
2021-07-05 11:25:20 +01:00
const client = useContext(AppContext);
const [deleting, setDelete] = useState<string[]>([]);
const [data, setData] = useState<
| {
users: Pick<Users.User, "_id" | "username" | "avatar">[];
bans: Servers.Ban[];
}
| undefined
>(undefined);
2021-06-19 22:37:12 +01:00
2021-07-05 11:25:20 +01:00
useEffect(() => {
client.servers.fetchBans(server._id).then(setData as any);
2021-07-05 11:25:20 +01:00
}, []);
2021-06-19 22:37:12 +01:00
2021-07-05 11:25:20 +01:00
return (
<div className={styles.userList}>
<div className={styles.subtitle}>
<span>
<Text id="app.settings.server_pages.bans.user" />
</span>
<span class={styles.reason}>
<Text id="app.settings.server_pages.bans.reason" />
</span>
<span>
<Text id="app.settings.server_pages.bans.revoke" />
</span>
</div>
{typeof data === "undefined" && <Preloader type="ring" />}
{data?.bans.map((x) => {
let user = data.users.find((y) => y._id === x._id.user);
return (
<div
className={styles.ban}
data-deleting={deleting.indexOf(x._id.user) > -1}>
<span>
<UserIcon attachment={user?.avatar} size={24} />
{user?.username}
</span>
<div className={styles.reason}>
{x.reason ?? (
<Text id="app.settings.server_pages.bans.no_reason" />
)}
</div>
<IconButton
onClick={async () => {
setDelete([...deleting, x._id.user]);
await client.servers.unbanUser(
server._id,
x._id.user,
);
setData({
...data,
bans: data.bans.filter(
(y) => y._id.user !== x._id.user,
),
});
}}
disabled={deleting.indexOf(x._id.user) > -1}>
<XCircle size={24} />
</IconButton>
</div>
);
})}
2021-07-05 11:25:20 +01:00
</div>
);
2021-06-19 22:37:12 +01:00
}