import React, { Component } from 'react';
import { inject, observer } from 'mobx-react';
import { Button, Col, Row } from 'antd';
import Avatar from './AvatarDropdown';
import styles from './index.less';
export class GlobalHeaderRight extends Component {
get isAdminPage() {
const { isAdminPage = false } = this.props;
return isAdminPage;
}
get isUserCenterPage() {
const { isUserCenterPage = false } = this.props;
return isUserCenterPage;
}
renderProject() {
if (this.isAdminPage || this.isUserCenterPage) {
return (
<Button
type="link"
href="/base/overview"
className={styles['single-link']}
>
{t('Project')}
</Button>
);
}
return null;
}
renderAdministrator() {
const { rootStore: { hasAdminPageRole = false } = {} } = this.props;
if (!hasAdminPageRole || this.isAdminPage) {
return null;
}
return (
<Button
type="link"
href="/base/overview-admin"
className={styles['single-link']}
>
{t('Administrator')}
</Button>
);
}
renderExtra() {
return null;
}
renderExtraLink() {
return null;
}
render() {
return (
<div className={styles.right}>
<Row justify="space-between" align="middle" gutter={10}>
<Col>
{this.renderExtraLink()}
{this.renderProject()}
{this.renderAdministrator()}
</Col>
{this.renderExtra()}
<Col>
<Avatar menu />
</Col>
</Row>
</div>
);
}
}
export default inject('rootStore')(observer(GlobalHeaderRight));