import { Button, ButtonGroup } from '@rocket.chat/fuselage';
import {
ContextualbarHeader,
ContextualbarClose,
ContextualbarTitle,
ContextualbarDialog,
Page,
PageHeader,
PageContent,
} from '@rocket.chat/ui-client';
import { useRoute, useRouteParameter, usePermission, useTranslation, useSetting } from '@rocket.chat/ui-contexts';
import type { ReactElement } from 'react';
import { useCallback, useRef, useEffect } from 'react';
import CustomUserActiveConnections from './CustomUserActiveConnections';
import CustomUserStatusFormWithData from './CustomUserStatusFormWithData';
import CustomUserStatusService from './CustomUserStatusService';
import CustomUserStatusTable from './CustomUserStatusTable';
import { useIsEnterprise } from '../../../hooks/useIsEnterprise';
import NotAuthorizedPage from '../../notAuthorized/NotAuthorizedPage';
const CustomUserStatusRoute = (): ReactElement => {
const t = useTranslation();
const route = useRoute('user-status');
const context = useRouteParameter('context');
const id = useRouteParameter('id');
const canManageUserStatus = usePermission('manage-user-status');
const { data: license } = useIsEnterprise();
const presenceDisabled = useSetting('Presence_broadcast_disabled', false);
useEffect(() => {
presenceDisabled && route.push({ context: 'presence-service' });
}, [presenceDisabled, route]);
const handleItemClick = (id: string): void => {
route.push({
context: 'edit',
id,
});
};
const handleNewButtonClick = useCallback(() => {
route.push({ context: 'new' });
}, [route]);
const handlePresenceServiceClick = useCallback(() => {
route.push({ context: 'presence-service' });
}, [route]);
const handleClose = useCallback(() => {
route.push({});
}, [route]);
const reload = useRef(() => null);
const handleReload = useCallback(() => {
reload.current();
}, [reload]);
if (!canManageUserStatus) {
return ;
}
return (
{!license?.isEnterprise && }
{context && (
{context === 'edit' && t('Custom_User_Status_Edit')}
{context === 'new' && t('Custom_User_Status_Add')}
{context === 'presence-service' && t('Presence_service_cap')}
{context === 'presence-service' && }
{(context === 'new' || context === 'edit') && (
)}
)}
);
};
export default CustomUserStatusRoute;