2023-08-10 09:28:10 +02:00
|
|
|
import { PageContent } from 'component/common/PageContent/PageContent';
|
|
|
|
import { PageHeader } from 'component/common/PageHeader/PageHeader';
|
|
|
|
import { VFC } from 'react';
|
|
|
|
import { adminGroups } from './adminRoutes';
|
|
|
|
import { INavigationMenuItem } from 'interfaces/route';
|
|
|
|
import { Box, Link, Typography } from '@mui/material';
|
|
|
|
import { Link as RouterLink } from 'react-router-dom';
|
|
|
|
import { useAdminRoutes } from './useAdminRoutes';
|
|
|
|
|
|
|
|
export const AdminIndex: VFC = () => {
|
|
|
|
const adminRoutes = useAdminRoutes();
|
|
|
|
|
2023-10-02 14:25:46 +02:00
|
|
|
const routeGroups = adminRoutes.reduce(
|
|
|
|
(acc, route) => {
|
|
|
|
const group = route.group || 'other';
|
2023-08-10 09:28:10 +02:00
|
|
|
|
2023-10-02 14:25:46 +02:00
|
|
|
const index = acc.findIndex((item) => item.name === group);
|
|
|
|
if (index === -1) {
|
|
|
|
acc.push({
|
|
|
|
name: group,
|
|
|
|
description: adminGroups[group] || 'Other',
|
|
|
|
items: [route],
|
|
|
|
});
|
2023-08-10 09:28:10 +02:00
|
|
|
|
2023-10-02 14:25:46 +02:00
|
|
|
return acc;
|
|
|
|
}
|
2023-08-10 09:28:10 +02:00
|
|
|
|
2023-10-02 14:25:46 +02:00
|
|
|
acc[index].items.push(route);
|
2023-08-10 09:28:10 +02:00
|
|
|
|
2023-10-02 14:25:46 +02:00
|
|
|
return acc;
|
|
|
|
},
|
|
|
|
[] as Array<{
|
|
|
|
name: string;
|
|
|
|
description: string;
|
|
|
|
items: INavigationMenuItem[];
|
|
|
|
}>,
|
|
|
|
);
|
2023-08-10 09:28:10 +02:00
|
|
|
|
|
|
|
return (
|
2023-10-02 14:25:46 +02:00
|
|
|
<PageContent header={<PageHeader title='Manage Unleash' />}>
|
|
|
|
{routeGroups.map((group) => (
|
2023-08-10 09:28:10 +02:00
|
|
|
<Box
|
|
|
|
key={group.name}
|
2023-10-02 14:25:46 +02:00
|
|
|
sx={(theme) => ({ marginBottom: theme.spacing(2) })}
|
2023-08-10 09:28:10 +02:00
|
|
|
>
|
2023-10-02 14:25:46 +02:00
|
|
|
<Typography variant='h2'>{group.description}</Typography>
|
2023-08-10 09:28:10 +02:00
|
|
|
<ul>
|
2023-10-02 14:25:46 +02:00
|
|
|
{group.items.map((route) => (
|
2023-08-10 09:28:10 +02:00
|
|
|
<li key={route.path}>
|
|
|
|
<Link component={RouterLink} to={route.path}>
|
|
|
|
{route.title}
|
|
|
|
</Link>
|
|
|
|
</li>
|
|
|
|
))}
|
|
|
|
</ul>
|
|
|
|
</Box>
|
|
|
|
))}
|
|
|
|
</PageContent>
|
|
|
|
);
|
|
|
|
};
|