Vulcan/packages/example-forum/lib/components/users/UsersMenu.jsx
2017-09-04 18:37:21 +09:00

41 lines
1.7 KiB
JavaScript

import { Components, registerComponent, withCurrentUser } from 'meteor/vulcan:core';
import React from 'react';
import PropTypes from 'prop-types';
import { FormattedMessage } from 'meteor/vulcan:i18n';
import { Meteor } from 'meteor/meteor';
import Dropdown from 'react-bootstrap/lib/Dropdown';
import MenuItem from 'react-bootstrap/lib/MenuItem';
import { LinkContainer } from 'react-router-bootstrap';
import Users from 'meteor/vulcan:users';
import { withApollo } from 'react-apollo';
const UsersMenu = ({currentUser, client}) =>
<div className="users-menu">
<Dropdown id="user-dropdown">
<Dropdown.Toggle>
<Components.UsersAvatar size="small" user={currentUser} addLink={false} />
<div className="users-menu-name">{Users.getDisplayName(currentUser)}</div>
</Dropdown.Toggle>
<Dropdown.Menu>
<LinkContainer to={`/users/${currentUser.slug}`}>
<MenuItem className="dropdown-item" eventKey="1"><FormattedMessage id="users.profile"/></MenuItem>
</LinkContainer>
<LinkContainer to={`/account`}>
<MenuItem className="dropdown-item" eventKey="2"><FormattedMessage id="users.edit_account"/></MenuItem>
</LinkContainer>
<LinkContainer to={`/admin`}>
<MenuItem className="dropdown-item" eventKey="2">Admin</MenuItem>
</LinkContainer>
<MenuItem className="dropdown-item" eventKey="4" onClick={() => Meteor.logout(() => client.resetStore())}><FormattedMessage id="users.log_out"/></MenuItem>
</Dropdown.Menu>
</Dropdown>
</div>
UsersMenu.propsTypes = {
currentUser: PropTypes.object,
client: PropTypes.object,
};
registerComponent('UsersMenu', UsersMenu, withCurrentUser, withApollo);