feat: login

This commit is contained in:
mozzie 2023-08-28 11:17:33 +08:00
parent 60c1d9165d
commit 2822f338dc
6 changed files with 100 additions and 66 deletions

View File

@ -1,10 +1,28 @@
import { MenuItem, roleMenusMapping } from "./roleMenu.config";
import { UserService } from "@@/domain/User/UserService";
import { useEffect, useState } from "react"; import { useEffect, useState } from "react";
import { observer } from "mobx-react-lite";
import { useNavigate } from "react-router"; import { useNavigate } from "react-router";
import { Menu, Spin } from "antd"; import { Menu, MenuProps } from "antd";
import { ROLE_NAME } from "@/constant";
export type MenuItem = Required<MenuProps>["items"][number];
type RoleMenusType = {
menuItems: MenuItem[];
};
export const getItem = (
label: React.ReactNode,
key: React.Key,
icon?: React.ReactNode,
children?: MenuItem[],
type?: "group"
): MenuItem => {
return {
key,
icon,
children,
label,
type,
} as MenuItem;
};
export const useMenu = () => { export const useMenu = () => {
const navigate = useNavigate(); const navigate = useNavigate();
@ -12,17 +30,9 @@ export const useMenu = () => {
useEffect(() => setSelectedKeys([location.pathname]), []); useEffect(() => setSelectedKeys([location.pathname]), []);
const RoleMenu: React.FC<{ domainService: UserService }> = observer( const LeftMenu = (props: RoleMenusType) => {
({ domainService }) => { const { menuItems } = props;
const { user } = domainService; return menuItems.length > 0 ? (
console.log(user);
const roleNames = user.getRolesName();
if (roleNames) {
let menuItems: MenuItem[] = [];
for (const key in roleMenusMapping)
if (roleNames.includes(key))
menuItems = roleMenusMapping[key as ROLE_NAME];
return (
<Menu <Menu
onClick={(e) => navigate(e.key)} onClick={(e) => navigate(e.key)}
style={{ width: "100%", height: "100%" }} style={{ width: "100%", height: "100%" }}
@ -31,16 +41,10 @@ export const useMenu = () => {
mode="inline" mode="inline"
items={menuItems} items={menuItems}
/> />
) : (
<span></span>
); );
} else { };
return (
<div style={{ textAlign: "center" }}>
<Spin />
</div>
);
}
}
);
return { RoleMenu }; return { LeftMenu };
}; };

View File

@ -33,7 +33,7 @@ const adminMenuItems: MenuItem[] = [
const annotatorMenuItems: MenuItem[] = [ const annotatorMenuItems: MenuItem[] = [
getItem("影像", "dicom", <DatabaseOutlined />, [ getItem("影像", "dicom", <DatabaseOutlined />, [
getItem("标注", "/annotator/list", <CloudUploadOutlined />), getItem("标注", "/list", <CloudUploadOutlined />),
]), ]),
]; ];

View File

@ -1,23 +1,20 @@
import { Outlet, useLocation } from "react-router"; import { Outlet, useLocation } from "react-router";
import { useDomain } from "@/hook/useDomain"; import { ReactNode } from "react";
import { useMenu } from "./Menu";
import "./index.less"; import "./index.less";
interface LayoutProps { interface LayoutProps {
children?: JSX.Element; children?: JSX.Element;
leftMenus?: ReactNode;
} }
export const Layout = (props: LayoutProps) => { export const Layout = (props: LayoutProps) => {
const location = useLocation(); const location = useLocation();
const { userDomainService } = useDomain();
const { RoleMenu } = useMenu();
return ( return (
<div className="layout-container"> <div className="layout-container">
<header> {location.pathname}</header> <header> {location.pathname}</header>
<div> <div>
<aside> <aside>{props.leftMenus}</aside>
<RoleMenu domainService={userDomainService} />
</aside>
<main> <main>
<Outlet /> <Outlet />
</main> </main>

View File

@ -1,14 +1,31 @@
import { getItem, useMenu } from "@/components/Layout/Menu";
import { Layout } from "@/components/Layout";
import {
CloudUploadOutlined,
DatabaseOutlined,
UnorderedListOutlined,
} from "@ant-design/icons";
import { Outlet } from "react-router"; import { Outlet } from "react-router";
import { MenuProps } from "antd";
interface AdminDashboardProps { interface AdminDashboardProps {
children?: JSX.Element; children?: JSX.Element;
} }
export type MenuItem = Required<MenuProps>["items"][number];
const adminMenuItems: MenuItem[] = [
getItem("影像", "dicom", <DatabaseOutlined />, [
getItem("上传", "/upload", <CloudUploadOutlined />),
getItem("列表", "/list", <UnorderedListOutlined />),
]),
];
export const AdminDashboard = (props: AdminDashboardProps) => { export const AdminDashboard = (props: AdminDashboardProps) => {
const { LeftMenu } = useMenu();
return ( return (
<div> <Layout leftMenus={<LeftMenu menuItems={adminMenuItems} />}>
<p>AdminDashboard</p>
<Outlet /> <Outlet />
</div> </Layout>
); );
}; };

View File

@ -1,14 +1,23 @@
import { CloudUploadOutlined, DatabaseOutlined } from "@ant-design/icons";
import { MenuItem, getItem, useMenu } from "@/components/Layout/Menu";
import { Layout } from "@/components/Layout";
import { Outlet } from "react-router"; import { Outlet } from "react-router";
interface AnnotatorDashBoardProps { interface AnnotatorDashBoardProps {
children?: JSX.Element; children?: JSX.Element;
} }
const annotatorMenuItems: MenuItem[] = [
getItem("影像", "dicom", <DatabaseOutlined />, [
getItem("标注", "/list", <CloudUploadOutlined />),
]),
];
export const AnnotatorDashBoard = (props: AnnotatorDashBoardProps) => { export const AnnotatorDashBoard = (props: AnnotatorDashBoardProps) => {
const { LeftMenu } = useMenu();
return ( return (
<div> <Layout leftMenus={<LeftMenu menuItems={annotatorMenuItems} />}>
<p>AnnotatorDashBoard</p>
<Outlet /> <Outlet />
</div> </Layout>
); );
}; };

View File

@ -16,7 +16,6 @@ export const roleRoutes: Record<ROLE_NAME, (RouteObject & ExpandRouteProps)[]> =
{ {
path: "/", path: "/",
element: <AdminDashboard />, element: <AdminDashboard />,
title: "管理员",
children: [ children: [
{ {
path: "/", path: "/",
@ -26,33 +25,41 @@ export const roleRoutes: Record<ROLE_NAME, (RouteObject & ExpandRouteProps)[]> =
path: "/list", path: "/list",
element: <DicomList />, element: <DicomList />,
}, },
],
},
{
path: "/list",
element: <DicomList />,
title: "管理员",
},
{ {
path: "/upload", path: "/upload",
element: <DicomUpload />, element: <DicomUpload />,
title: "管理员",
}, },
], ],
},
// {
// path: "/list",
// element: <DicomList />,
// title: "管理员",
// },
// {
// path: "/upload",
// element: <DicomUpload />,
// title: "管理员",
// },
],
/** /**
* *
*/ */
[ROLE_NAME.ANNOTATOR]: [ [ROLE_NAME.ANNOTATOR]: [
{ {
path: "/", path: "/",
// element: <Navigate to="/annotator/list" replace />,
element: <AnnotatorDashBoard />, element: <AnnotatorDashBoard />,
title: "标注", title: "标注",
children: [
{
path: "/",
element: <Navigate to="/list" replace />,
}, },
{ {
path: "/annotator/list", path: "/list",
element: <AnnotatorList />, element: <AnnotatorList />,
title: "标注", },
],
}, },
], ],
}; };