This repository has been archived on 2022-08-14. You can view files and clone it, but cannot push or open issues or pull requests.
outline/app/scenes/Settings/components/UserMenu.js

94 lines
2.3 KiB
JavaScript
Raw Normal View History

2018-03-04 23:39:17 +00:00
// @flow
import React, { Component } from 'react';
import { inject, observer } from 'mobx-react';
2018-05-03 04:51:39 +00:00
import { MoreIcon } from 'outline-icons';
2018-03-04 23:39:17 +00:00
2018-03-05 06:34:06 +00:00
import UsersStore from 'stores/UsersStore';
2018-03-04 23:39:17 +00:00
import { DropdownMenu, DropdownMenuItem } from 'components/DropdownMenu';
import type { User } from 'types';
type Props = {
user: User,
2018-03-05 06:34:06 +00:00
users: UsersStore,
2018-03-04 23:39:17 +00:00
};
@observer
2018-03-05 06:34:06 +00:00
class UserMenu extends Component {
2018-03-04 23:39:17 +00:00
props: Props;
handlePromote = (ev: SyntheticEvent) => {
ev.preventDefault();
2018-03-05 06:34:06 +00:00
const { user, users } = this.props;
2018-03-05 00:53:57 +00:00
if (
!window.confirm(
`Are you want to make ${
user.name
} an admin? Admins can modify team and billing information.`
)
) {
return;
}
2018-03-05 06:34:06 +00:00
users.promote(user);
2018-03-04 23:39:17 +00:00
};
handleDemote = (ev: SyntheticEvent) => {
ev.preventDefault();
2018-03-05 06:34:06 +00:00
const { user, users } = this.props;
2018-03-05 00:53:57 +00:00
if (!window.confirm(`Are you want to make ${user.name} a member?`)) {
return;
}
2018-03-05 06:34:06 +00:00
users.demote(user);
2018-03-04 23:39:17 +00:00
};
handleSuspend = (ev: SyntheticEvent) => {
ev.preventDefault();
2018-03-05 06:34:06 +00:00
const { user, users } = this.props;
2018-03-05 00:53:57 +00:00
if (
!window.confirm(
"Are you want to suspend this account? Suspended users won't be able to access Outline."
)
) {
return;
}
2018-03-05 06:34:06 +00:00
users.suspend(user);
2018-03-04 23:39:17 +00:00
};
handleActivate = (ev: SyntheticEvent) => {
ev.preventDefault();
2018-03-05 06:34:06 +00:00
const { user, users } = this.props;
users.activate(user);
2018-03-04 23:39:17 +00:00
};
render() {
const { user } = this.props;
return (
<span>
<DropdownMenu label={<MoreIcon />}>
{!user.isSuspended &&
(user.isAdmin ? (
<DropdownMenuItem onClick={this.handleDemote}>
Make {user.name} a member
</DropdownMenuItem>
) : (
<DropdownMenuItem onClick={this.handlePromote}>
Make {user.name} an admin
</DropdownMenuItem>
))}
{user.isSuspended ? (
<DropdownMenuItem onClick={this.handleActivate}>
2018-03-05 00:53:57 +00:00
Activate account
2018-03-04 23:39:17 +00:00
</DropdownMenuItem>
) : (
<DropdownMenuItem onClick={this.handleSuspend}>
Suspend account
</DropdownMenuItem>
)}
</DropdownMenu>
</span>
);
}
}
2018-03-05 06:34:06 +00:00
export default inject('users')(UserMenu);