在哪里可以更改react-admin标头中的个人资料图片?

时间:2018-10-04 22:04:42

标签: reactjs admin-on-rest react-admin

我在react-admin(原为休息时使用admin)中使用社交登录,并且有他社交媒体中的用户图片,但是我没有找到如何更改用户个人资料图像的右上角屏幕:

Profile image

是否要设置诸如自定义登录或自定义退出按钮之类的道具?

谢谢。

1 个答案:

答案 0 :(得分:2)

当前,该过程涉及许多代码,因为您必须完全重写UserMenu。要使用它,您还必须使用自定义Layout来实现自定义AppBar。合并https://github.com/marmelab/react-admin/pull/2391时,将简化该过程。

// in src/MyUserMenu.js
import React, { Children, cloneElement } from 'react';
import PropTypes from 'prop-types';
import Tooltip from '@material-ui/core/Tooltip';
import IconButton from '@material-ui/core/IconButton';
import Menu from '@material-ui/core/Menu';
import AccountCircle from '@material-ui/icons/AccountCircle';
import { translate } from 'ra-core';

class UserMenu extends React.Component {
    static propTypes = {
        children: PropTypes.node,
        label: PropTypes.string.isRequired,
        logout: PropTypes.node,
        translate: PropTypes.func.isRequired,
    };

    static defaultProps = {
        label: 'ra.auth.user_menu',
    };

    state = {
        auth: true,
        anchorEl: null,
    };

    handleChange = (event, checked) => {
        this.setState({ auth: checked });
    };

    handleMenu = event => {
        this.setState({ anchorEl: event.currentTarget });
    };

    handleClose = () => {
        this.setState({ anchorEl: null });
    };

    render() {
        const { children, label, logout, translate } = this.props;
        if (!logout && !children) return null;
        const { anchorEl } = this.state;
        const open = Boolean(anchorEl);

        return (
            <div>
                <Tooltip title={label && translate(label, { _: label })}>
                    <IconButton
                        arial-label={label && translate(label, { _: label })}
                        aria-owns={open ? 'menu-appbar' : null}
                        aria-haspopup="true"
                        onClick={this.handleMenu}
                        color="inherit"
                    >
                        {/* Replace this icon with whatever you want, a user avatar or another icon */}
                        <AccountCircle />
                    </IconButton>
                </Tooltip>
                <Menu
                    id="menu-appbar"
                    anchorEl={anchorEl}
                    anchorOrigin={{
                        vertical: 'top',
                        horizontal: 'right',
                    }}
                    transformOrigin={{
                        vertical: 'top',
                        horizontal: 'right',
                    }}
                    open={open}
                    onClose={this.handleClose}
                >
                    {Children.map(children, menuItem =>
                        cloneElement(menuItem, { onClick: this.handleClose })
                    )}
                    {logout}
                </Menu>
            </div>
        );
    }
}

export default translate(UserMenu);

// in src/MyAppBar.js
import { AppBar } from 'react-admin';
import MyUserMenu from './MyUserMenu';

const MyAppBar = (props) => <AppBar {...props} userMenu={MyUserMenu} />;

// in src/MyLayout.js
import { Layout } from 'react-admin';
import MyAppBar from './MyAppBar';

const MyLayout = (props) => <Layout {...props} appBar={MyAppBar} />;

export default MyLayout;

文档:https://marmelab.com/react-admin/Theming.html#using-a-custom-appbar