import { useState } from 'react'; import { ConditionallyRender } from 'component/common/ConditionallyRender/ConditionallyRender'; import { ADMIN } from 'component/providers/AccessProvider/permissions'; import { RolesTable } from './RolesTable/RolesTable'; import { PageContent } from 'component/common/PageContent/PageContent'; import { Tab, Tabs, styled, useMediaQuery } from '@mui/material'; import { Route, Routes, useLocation } from 'react-router-dom'; import { CenteredNavLink } from '../menu/CenteredNavLink'; import useUiConfig from 'hooks/api/getters/useUiConfig/useUiConfig'; import { PROJECT_ROLE_TYPE, ROOT_ROLE_TYPE } from '@server/util/constants'; import { useRoles } from 'hooks/api/getters/useRoles/useRoles'; import { Search } from 'component/common/Search/Search'; import theme from 'themes/theme'; import { PageHeader } from 'component/common/PageHeader/PageHeader'; import { Add } from '@mui/icons-material'; import ResponsiveButton from 'component/common/ResponsiveButton/ResponsiveButton'; import { IRole } from 'interfaces/role'; const StyledHeader = styled('div')(() => ({ display: 'flex', justifyContent: 'space-between', alignItems: 'center', })); const StyledTabsContainer = styled('div')({ flex: 1, }); const StyledActions = styled('div')({ display: 'flex', alignItems: 'center', }); export const RolesPage = () => { const { uiConfig } = useUiConfig(); const { pathname } = useLocation(); const { roles, projectRoles, loading } = useRoles(); const [searchValue, setSearchValue] = useState(''); const [modalOpen, setModalOpen] = useState(false); const [selectedRole, setSelectedRole] = useState(); const tabs = uiConfig.flags.customRootRoles ? [ { label: 'Root roles', path: '/admin/roles', total: roles.length, }, { label: 'Project roles', path: '/admin/roles/project-roles', total: projectRoles.length, }, ] : [ { label: 'Project roles', path: '/admin/roles', total: projectRoles.length, }, ]; const isSmallScreen = useMediaQuery(theme.breakpoints.down('md')); const type = !uiConfig.flags.customRootRoles || pathname.includes('project-roles') ? PROJECT_ROLE_TYPE : ROOT_ROLE_TYPE; return ( {tabs.map(({ label, path, total }) => ( {label} ({total}) } /> ))} } /> { setSelectedRole(undefined); setModalOpen(true); }} maxWidth={`${theme.breakpoints.values['sm']}px`} Icon={Add} permission={ADMIN} > New {type} role } /> } > } /> } /> ); };