pleroma/app/soapbox/features/admin/components/admin-tabs.tsx
2022-04-28 15:29:38 -05:00

42 lines
1.2 KiB
TypeScript

import React from 'react';
import { useIntl, defineMessages } from 'react-intl';
import { Tabs } from 'soapbox/components/ui';
import { useAppSelector } from 'soapbox/hooks';
const messages = defineMessages({
dashboard: { id: 'admin_nav.dashboard', defaultMessage: 'Dashboard' },
reports: { id: 'admin_nav.reports', defaultMessage: 'Reports' },
waitlist: { id: 'admin_nav.awaiting_approval', defaultMessage: 'Waitlist' },
});
interface IAdminTabs {
activeItem: 'dashboard' | 'reports' | 'approval',
}
const AdminTabs: React.FC<IAdminTabs> = ({ activeItem }) => {
const intl = useIntl();
const approvalCount = useAppSelector(state => state.admin.awaitingApproval.count());
const reportsCount = useAppSelector(state => state.admin.openReports.count());
const tabs = [{
name: 'dashboard',
text: intl.formatMessage(messages.dashboard),
to: '/admin',
}, {
name: 'reports',
text: intl.formatMessage(messages.reports),
to: '/admin/reports',
count: reportsCount,
}, {
name: 'approval',
text: intl.formatMessage(messages.waitlist),
to: '/admin/approval',
count: approvalCount,
}];
return <Tabs items={tabs} activeItem={activeItem} />;
};
export default AdminTabs;