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

99 lines
3.6 KiB
TypeScript
Raw Normal View History

2021-06-27 12:17:59 +02:00
import { XCircle } from "@styled-icons/boxicons-regular";
2021-07-29 15:11:21 +01:00
import { observer } from "mobx-react-lite";
2021-07-05 11:23:23 +01:00
import { Invites as InvitesNS, Servers } from "revolt.js/dist/api/objects";
import styles from "./Panes.module.scss";
import { Text } from "preact-i18n";
2021-06-19 22:37:12 +01:00
import { useEffect, useState } from "preact/hooks";
2021-07-05 11:23:23 +01:00
2021-07-29 15:11:21 +01:00
import { useData } from "../../../mobx/State";
import { useClient } from "../../../context/revoltjs/RevoltClient";
2021-06-19 22:37:12 +01:00
import { getChannelName } from "../../../context/revoltjs/util";
2021-07-05 11:23:23 +01:00
import UserIcon from "../../../components/common/user/UserIcon";
import IconButton from "../../../components/ui/IconButton";
import Preloader from "../../../components/ui/Preloader";
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
}
2021-07-29 15:11:21 +01:00
export const Invites = observer(({ server }: Props) => {
const [deleting, setDelete] = useState<string[]>([]);
2021-07-05 11:25:20 +01:00
const [invites, setInvites] = useState<
InvitesNS.ServerInvite[] | undefined
>(undefined);
2021-07-05 11:23:23 +01:00
2021-07-29 15:11:21 +01:00
const store = useData();
2021-07-29 18:41:01 +01:00
const client = useClient();
2021-07-29 15:11:21 +01:00
const users = invites?.map((invite) => store.users.get(invite.creator));
2021-07-29 18:41:01 +01:00
const channels = invites?.map((invite) =>
store.channels.get(invite.channel),
);
2021-07-29 15:11:21 +01:00
2021-07-05 11:25:20 +01:00
useEffect(() => {
2021-07-29 18:41:01 +01:00
client.servers
2021-07-05 11:25:20 +01:00
.fetchInvites(server._id)
.then((invites) => setInvites(invites));
}, []);
2021-06-19 22:37:12 +01:00
2021-07-05 11:25:20 +01:00
return (
<div className={styles.userList}>
2021-07-05 11:25:20 +01:00
<div className={styles.subtitle}>
<span>
<Text id="app.settings.server_pages.invites.code" />
</span>
<span>
<Text id="app.settings.server_pages.invites.invitor" />
</span>
<span>
<Text id="app.settings.server_pages.invites.channel" />
</span>
<span>
<Text id="app.settings.server_pages.invites.revoke" />
</span>
2021-07-05 11:25:20 +01:00
</div>
{typeof invites === "undefined" && <Preloader type="ring" />}
2021-07-29 15:11:21 +01:00
{invites?.map((invite, index) => {
const creator = users![index];
2021-07-29 18:41:01 +01:00
const channel = channels![index];
2021-06-19 22:37:12 +01:00
2021-07-05 11:25:20 +01:00
return (
<div
className={styles.invite}
data-deleting={deleting.indexOf(invite._id) > -1}>
<code>{invite._id}</code>
<span>
<UserIcon target={creator} size={24} />{" "}
{creator?.username ?? (
<Text id="app.main.channel.unknown_user" />
)}
2021-07-05 11:25:20 +01:00
</span>
<span>
{channel && creator
2021-07-29 18:41:01 +01:00
? getChannelName(client, channel, true)
: "#??"}
2021-07-05 11:25:20 +01:00
</span>
<IconButton
onClick={async () => {
setDelete([...deleting, invite._id]);
2021-06-19 22:37:12 +01:00
2021-07-29 18:41:01 +01:00
await client.deleteInvite(invite._id);
2021-06-19 22:37:12 +01:00
2021-07-05 11:25:20 +01:00
setInvites(
invites?.filter(
(x) => x._id !== invite._id,
),
);
}}
disabled={deleting.indexOf(invite._id) > -1}>
<XCircle size={24} />
</IconButton>
</div>
);
})}
</div>
);
2021-07-29 15:11:21 +01:00
});