|
|
@@ -5,7 +5,8 @@ import OrgActionBar from 'app/core/components/OrgActionBar/OrgActionBar';
|
|
|
import PageHeader from 'app/core/components/PageHeader/PageHeader';
|
|
|
import UsersTable from 'app/features/users/UsersTable';
|
|
|
import { NavModel, User } from 'app/types';
|
|
|
-import { loadUsers, setUsersSearchQuery } from './state/actions';
|
|
|
+import appEvents from 'app/core/app_events';
|
|
|
+import { loadUsers, setUsersSearchQuery, updateUser, removeUser } from './state/actions';
|
|
|
import { getNavModel } from '../../core/selectors/navModel';
|
|
|
import { getUsers, getUsersSearchQuery } from './state/selectors';
|
|
|
|
|
|
@@ -15,6 +16,8 @@ export interface Props {
|
|
|
searchQuery: string;
|
|
|
loadUsers: typeof loadUsers;
|
|
|
setUsersSearchQuery: typeof setUsersSearchQuery;
|
|
|
+ updateUser: typeof updateUser;
|
|
|
+ removeUser: typeof removeUser;
|
|
|
}
|
|
|
|
|
|
export class UsersListPage extends PureComponent<Props> {
|
|
|
@@ -25,6 +28,25 @@ export class UsersListPage extends PureComponent<Props> {
|
|
|
async fetchUsers() {
|
|
|
return await this.props.loadUsers();
|
|
|
}
|
|
|
+
|
|
|
+ onRoleChange = (role, user) => {
|
|
|
+ const updatedUser = { ...user, role: role };
|
|
|
+
|
|
|
+ this.props.updateUser(updatedUser);
|
|
|
+ };
|
|
|
+
|
|
|
+ onRemoveUser = user => {
|
|
|
+ appEvents.emit('confirm-modal', {
|
|
|
+ title: 'Delete',
|
|
|
+ text: 'Are you sure you want to delete user ' + user.login + '?',
|
|
|
+ yesText: 'Delete',
|
|
|
+ icon: 'fa-warning',
|
|
|
+ onConfirm: () => {
|
|
|
+ this.props.removeUser(user.userId);
|
|
|
+ },
|
|
|
+ });
|
|
|
+ };
|
|
|
+
|
|
|
render() {
|
|
|
const { navModel, searchQuery, setUsersSearchQuery, users } = this.props;
|
|
|
|
|
|
@@ -43,7 +65,11 @@ export class UsersListPage extends PureComponent<Props> {
|
|
|
setSearchQuery={setUsersSearchQuery}
|
|
|
linkButton={linkButton}
|
|
|
/>
|
|
|
- <UsersTable users={users} />
|
|
|
+ <UsersTable
|
|
|
+ users={users}
|
|
|
+ onRoleChange={(role, user) => this.onRoleChange(role, user)}
|
|
|
+ onRemoveUser={user => this.onRemoveUser(user)}
|
|
|
+ />
|
|
|
</div>
|
|
|
</div>
|
|
|
);
|
|
|
@@ -61,6 +87,8 @@ function mapStateToProps(state) {
|
|
|
const mapDispatchToProps = {
|
|
|
loadUsers,
|
|
|
setUsersSearchQuery,
|
|
|
+ updateUser,
|
|
|
+ removeUser,
|
|
|
};
|
|
|
|
|
|
export default hot(module)(connect(mapStateToProps, mapDispatchToProps)(UsersListPage));
|