dev #4
@@ -4,6 +4,15 @@ import { styles } from "../styles/styles";
|
|||||||
import { stylesTokens } from "../styles/theme";
|
import { stylesTokens } from "../styles/theme";
|
||||||
import { createPortal } from "react-dom";
|
import { createPortal } from "react-dom";
|
||||||
|
|
||||||
|
export default function AdminPanel() {
|
||||||
|
const [users, setUsers] = useState([]);
|
||||||
|
|
||||||
|
const [open, setOpen] = useState(false);
|
||||||
|
const [displayName, setDisplayName] = useState("");
|
||||||
|
const [email, setEmail] = useState("");
|
||||||
|
const [password, setPassword] = useState("");
|
||||||
|
const [role, setRole] = useState("user");
|
||||||
|
const [msg, setMsg] = useState("");
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
if (!open) return;
|
if (!open) return;
|
||||||
@@ -15,15 +24,6 @@ useEffect(() => {
|
|||||||
document.body.style.overflow = prev;
|
document.body.style.overflow = prev;
|
||||||
};
|
};
|
||||||
}, [open]);
|
}, [open]);
|
||||||
export default function AdminPanel() {
|
|
||||||
const [users, setUsers] = useState([]);
|
|
||||||
|
|
||||||
const [open, setOpen] = useState(false);
|
|
||||||
const [displayName, setDisplayName] = useState("");
|
|
||||||
const [email, setEmail] = useState("");
|
|
||||||
const [password, setPassword] = useState("");
|
|
||||||
const [role, setRole] = useState("user");
|
|
||||||
const [msg, setMsg] = useState("");
|
|
||||||
|
|
||||||
const loadUsers = async () => {
|
const loadUsers = async () => {
|
||||||
const u = await api("/admin/users");
|
const u = await api("/admin/users");
|
||||||
|
|||||||
Reference in New Issue
Block a user