2021-06-27 12:17:59 +02:00
|
|
|
import { XCircle } from "@styled-icons/boxicons-regular";
|
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
|
|
|
|
|
|
|
import {
|
2021-07-05 11:25:20 +01:00
|
|
|
useChannels,
|
|
|
|
useForceUpdate,
|
|
|
|
useUsers,
|
2021-07-05 11:23:23 +01:00
|
|
|
} from "../../../context/revoltjs/hooks";
|
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
|
|
|
}
|
|
|
|
|
|
|
|
export function Invites({ server }: Props) {
|
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-05 11:25:20 +01:00
|
|
|
const ctx = useForceUpdate();
|
|
|
|
const [deleting, setDelete] = useState<string[]>([]);
|
|
|
|
const users = useUsers(invites?.map((x) => x.creator) ?? [], ctx);
|
|
|
|
const channels = useChannels(invites?.map((x) => x.channel) ?? [], ctx);
|
2021-06-19 22:37:12 +01:00
|
|
|
|
2021-07-05 11:25:20 +01:00
|
|
|
useEffect(() => {
|
|
|
|
ctx.client.servers
|
|
|
|
.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.invites}>
|
|
|
|
<div className={styles.subtitle}>
|
|
|
|
<span>Invite Code</span>
|
|
|
|
<span>Invitor</span>
|
|
|
|
<span>Channel</span>
|
|
|
|
<span>Revoke</span>
|
|
|
|
</div>
|
|
|
|
{typeof invites === "undefined" && <Preloader type="ring" />}
|
|
|
|
{invites?.map((invite) => {
|
2021-07-10 15:57:29 +01:00
|
|
|
const creator = users.find((x) => x?._id === invite.creator);
|
|
|
|
const channel = channels.find((x) => x?._id === invite.channel);
|
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 ?? "unknown"}
|
|
|
|
</span>
|
|
|
|
<span>
|
|
|
|
{channel && creator
|
|
|
|
? getChannelName(ctx.client, channel, true)
|
|
|
|
: "#unknown"}
|
|
|
|
</span>
|
|
|
|
<IconButton
|
|
|
|
onClick={async () => {
|
|
|
|
setDelete([...deleting, invite._id]);
|
2021-06-19 22:37:12 +01:00
|
|
|
|
2021-07-05 11:25:20 +01:00
|
|
|
await ctx.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-06-19 22:37:12 +01:00
|
|
|
}
|