我是歌谣 放弃很容易 但是坚持一定很酷 微信公众号关注前端小歌谣带你进入前端技术群 // in src/MyLayout.jsimport * as React from 'react';import { forwardRef } from 'react';import { AppBar, Layout, UserMenu,
我是歌谣 放弃很容易 但是坚持一定很酷 微信公众号关注前端小歌谣带你进入前端技术群
// in src/MyLayout.js
import * as React from 'react';
import { forwardRef } from 'react';
import { AppBar, Layout, UserMenu, useLogout } from 'react-admin';
import { MenuItem } from '@mui/material';
import ExitIcon from '@mui/icons-material/PowerSettingsNew';
// It's important to pass the ref to allow Material UI to manage the keyboard navigation
const MyLogoutButton = forwardRef((props, ref) => {
const logout = useLogout();
const handleClick = () => logout();
return (
<MenuItem
onClick={handleClick}
ref={ref}
// It's important to pass the props to allow Material UI to manage the keyboard navigation
{...props}
>
<ExitIcon /> Logout
</MenuItem>
);
});
const MyUserMenu = () => (
<UserMenu>
<MyLogoutButton />
</UserMenu>
);
const MyAppBar = () => <AppBar userMenu={<UserMenu />} />;
const MyLayout = (props) => (
<Layout {...props} appBar={MyAppBar} />
);
export default MyLayout;
import * as React from "react";
import { Admin } from 'react-admin';
import MyLayout from './MyLayout';
const App = () => (
<Admin layout={MyLayout} authProvider={authProvider}>
...
</Admin>
);
自定义用户菜单