import { Text } from "preact-i18n"; import { useState } from "preact/hooks"; import styles from "./UserPicker.module.scss"; import { useUsers } from "../../revoltjs/hooks"; import Modal from "../../../components/ui/Modal"; import { User, Users } from "revolt.js/dist/api/objects"; import UserCheckbox from "../../../components/common/UserCheckbox"; interface Props { omit?: string[]; onClose: () => void; callback: (users: string[]) => Promise; } export function UserPicker(props: Props) { const [selected, setSelected] = useState([]); const omit = [...(props.omit || []), "00000000000000000000000000"]; const users = useUsers(); return ( } onClose={props.onClose} actions={[ { text: , onClick: () => props.callback(selected).then(props.onClose) } ]} >
{(users.filter( x => x && x.relationship === Users.Relationship.Friend && !omit.includes(x._id) ) as User[]) .map(x => { return { ...x, selected: selected.includes(x._id) }; }) .map(x => ( { if (v) { setSelected([...selected, x._id]); } else { setSelected( selected.filter(y => y !== x._id) ); } }} /> ))}
); }