import * as React from "react"; import { useState, useEffect } from "react"; import { useNavigate, useParams } from "react-router-dom"; import { AccordionDetails, AccordionSummary, Accordion, Skeleton, Radio, Box, Typography, TextField, Button, Table, TableHead, TableBody, TableCell, TableRow, } from "@mui/material"; import { GridSelectionModel } from "@mui/x-data-grid"; import ExpandMoreIcon from "@mui/icons-material/ExpandMore"; import ClearIcon from "@mui/icons-material/Clear"; import ConditionalRender from "@root/pages/Setting/ConditionalRender"; import ModalUser from "@root/pages/dashboard/ModalUser"; import ServiceUsersDG from "./ServiceUsersDG"; import { getRegisteredUsers, getManagersList } from "@root/api/user"; import { getRoles } from "@root/api/privilegies"; import { getRoles_mock, TMockData } from "../../../api/roles"; import theme from "../../../theme"; import type { UserType } from "../../../api/roles"; const Users: React.FC = () => { const radioboxes = ["admin", "manager", "user"]; const [selectedValue, setSelectedValue] = React.useState("admin"); const handleChange = (event: React.ChangeEvent) => { setSelectedValue(event.target.value); if (selectedValue === "manager") { } }; const navigate = useNavigate(); const [data, setData] = React.useState([]); const handleChangeData = () => { getRoles_mock().then((mockdata) => { setData(mockdata); }); }; const [accordionHeader, setAccordionHeader] = React.useState("none"); const [accordionState, setAccordionState] = React.useState(true); const [accordionText, setAccordionText] = React.useState(""); const handleChangeAccordion = (text: string) => { if (text == "") { setAccordionState(true); setAccordionHeader("none"); } else { handleToggleAccordion(); setAccordionHeader("flex"); } accordionState ? setAccordionText(text) : setAccordionText(""); }; const handleToggleAccordion = () => { setAccordionState(!accordionState); }; handleChangeData(); const [roles, setRoles] = React.useState([]); const [users, setUsers] = React.useState([]); const [manager, setManager] = React.useState([]); const [openUserModal, setOpenUserModal] = useState(false); const [activeUserId, setActiveUserId] = useState(""); const { userId } = useParams(); useEffect(() => { if (userId) { setActiveUserId(userId); setOpenUserModal(true); return; } setActiveUserId(""); setOpenUserModal(false); }, [userId]); useEffect(() => { getManagersList().then(([managersListResponse]) => { if (managersListResponse) { setManager(managersListResponse.users); } }); getRegisteredUsers().then(([registeredUsersResponse]) => { if (registeredUsersResponse) { setUsers(registeredUsersResponse.users); } }); getRoles().then(([rolesResponse]) => { if (rolesResponse) { setRoles(rolesResponse); } }); }, [selectedValue]); const [selectedTariffs, setSelectedTariffs] = useState( [] ); return ( handleToggleAccordion()} /> } aria-controls="panel1a-content" id="panel1a-header" > {accordionText} handleChangeAccordion("")} /> Имя Описание Отобразить {data.length ? ( data.map(function (item, index) { return ( handleChangeAccordion(item.desc)} > {item.name} {item.desc} ); }) ) : ( )}
} childrenUser={ } />
); }; export default Users;