The communications platform that puts data protection first.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
Rocket.Chat/apps/meteor/client/views/admin/users/UsersPage.tsx

100 lines
3.2 KiB

import { Button, ButtonGroup, Icon } from '@rocket.chat/fuselage';
import { usePermission, useRoute, useRouteParameter, useTranslation } from '@rocket.chat/ui-contexts';
import type { ReactElement } from 'react';
import React, { useEffect, useRef } from 'react';
import UserPageHeaderContentWithSeatsCap from '../../../../ee/client/views/admin/users/UserPageHeaderContentWithSeatsCap';
import { useSeatsCap } from '../../../../ee/client/views/admin/users/useSeatsCap';
import { Contextualbar, ContextualbarHeader, ContextualbarTitle, ContextualbarClose } from '../../../components/Contextualbar';
import Page from '../../../components/Page';
import AddUser from './AddUser';
import AdminUserInfoWithData from './AdminUserInfoWithData';
import EditUserWithData from './EditUserWithData';
import InviteUsers from './InviteUsers';
import UsersTable from './UsersTable';
const UsersPage = (): ReactElement => {
const t = useTranslation();
const context = useRouteParameter('context');
const id = useRouteParameter('id');
const seatsCap = useSeatsCap();
const reload = useRef(() => null);
const usersRoute = useRoute('admin-users');
const canCreateUser = usePermission('create-user');
const canBulkCreateUser = usePermission('bulk-register-user');
useEffect(() => {
if (!context || !seatsCap) {
return;
}
if (seatsCap.activeUsers >= seatsCap.maxActiveUsers && !['edit', 'info'].includes(context)) {
usersRoute.push({});
}
}, [context, seatsCap, usersRoute]);
const handleCloseContextualbar = (): void => {
usersRoute.push({});
};
const handleNewUser = (): void => {
usersRoute.push({ context: 'new' });
};
const handleInviteUser = (): void => {
usersRoute.push({ context: 'invite' });
};
const handleReload = (): void => {
seatsCap?.reload();
reload.current();
};
return (
<Page flexDirection='row'>
<Page>
<Page.Header title={t('Users')}>
{seatsCap && seatsCap.maxActiveUsers < Number.POSITIVE_INFINITY ? (
<UserPageHeaderContentWithSeatsCap {...seatsCap} />
) : (
<ButtonGroup>
{canCreateUser && (
<Button onClick={handleNewUser}>
<Icon size='x20' name='user-plus' /> {t('New')}
</Button>
)}
{canBulkCreateUser && (
<Button onClick={handleInviteUser}>
<Icon size='x20' name='mail' /> {t('Invite')}
</Button>
)}
</ButtonGroup>
)}
</Page.Header>
<Page.Content>
<UsersTable reload={reload} />
</Page.Content>
</Page>
{context && (
<Contextualbar>
<ContextualbarHeader>
<ContextualbarTitle>
{context === 'info' && t('User_Info')}
{context === 'edit' && t('Edit_User')}
{context === 'new' && t('Add_User')}
{context === 'invite' && t('Invite_Users')}
</ContextualbarTitle>
<ContextualbarClose onClick={handleCloseContextualbar} />
</ContextualbarHeader>
{context === 'info' && id && <AdminUserInfoWithData uid={id} onReload={handleReload} />}
{context === 'edit' && id && <EditUserWithData uid={id} onReload={handleReload} />}
{context === 'new' && <AddUser onReload={handleReload} />}
{context === 'invite' && <InviteUsers />}
</Contextualbar>
)}
</Page>
);
};
export default UsersPage;