2021-07-24 17:01:50 +01:00
|
|
|
import { XCircle } from "@styled-icons/boxicons-regular";
|
2021-07-29 19:01:40 +01:00
|
|
|
import { observer } from "mobx-react-lite";
|
2021-07-24 18:46:33 +01:00
|
|
|
import { Route } from "revolt.js/dist/api/routes";
|
2021-07-30 20:24:53 +01:00
|
|
|
import { Server } from "revolt.js/dist/maps/Servers";
|
2021-07-05 11:23:23 +01:00
|
|
|
|
2021-07-24 17:01:50 +01:00
|
|
|
import styles from "./Panes.module.scss";
|
|
|
|
import { Text } from "preact-i18n";
|
2021-08-05 14:47:00 +01:00
|
|
|
import { useEffect, useState } from "preact/hooks";
|
2021-06-19 22:37:12 +01:00
|
|
|
|
2021-07-24 17:01:50 +01:00
|
|
|
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-29 19:01:40 +01:00
|
|
|
server: Server;
|
2021-06-19 22:37:12 +01:00
|
|
|
}
|
|
|
|
|
2021-07-29 19:01:40 +01:00
|
|
|
export const Bans = observer(({ server }: Props) => {
|
2021-07-24 17:01:50 +01:00
|
|
|
const [deleting, setDelete] = useState<string[]>([]);
|
|
|
|
const [data, setData] = useState<
|
2021-07-24 18:46:33 +01:00
|
|
|
Route<"GET", "/servers/id/bans">["response"] | undefined
|
2021-07-24 17:01:50 +01:00
|
|
|
>(undefined);
|
2021-06-19 22:37:12 +01:00
|
|
|
|
2021-07-05 11:25:20 +01:00
|
|
|
useEffect(() => {
|
2021-08-05 14:47:00 +01:00
|
|
|
server.fetchBans().then(setData);
|
|
|
|
}, [server, setData]);
|
2021-06-19 22:37:12 +01:00
|
|
|
|
2021-07-05 11:25:20 +01:00
|
|
|
return (
|
2021-07-24 17:01:50 +01:00
|
|
|
<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) => {
|
2021-08-05 14:47:00 +01:00
|
|
|
const user = data.users.find((y) => y._id === x._id.user);
|
2021-07-24 17:01:50 +01:00
|
|
|
|
|
|
|
return (
|
|
|
|
<div
|
2021-08-05 14:47:00 +01:00
|
|
|
key={x._id.user}
|
2021-07-24 17:01:50 +01:00
|
|
|
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]);
|
|
|
|
|
2021-07-30 20:24:53 +01:00
|
|
|
await server.unbanUser(x._id.user);
|
2021-07-24 17:01:50 +01:00
|
|
|
|
|
|
|
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-07-29 19:01:40 +01:00
|
|
|
});
|