UsersListPage.tsx 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. import React, { PureComponent } from 'react';
  2. import { hot } from 'react-hot-loader';
  3. import { connect } from 'react-redux';
  4. import PageHeader from 'app/core/components/PageHeader/PageHeader';
  5. import UsersActionBar from './UsersActionBar';
  6. import UsersTable from 'app/features/users/UsersTable';
  7. import InviteesTable from './InviteesTable';
  8. import { Invitee, NavModel, OrgUser } from 'app/types';
  9. import appEvents from 'app/core/app_events';
  10. import { loadUsers, loadInvitees, revokeInvite, setUsersSearchQuery, updateUser, removeUser } from './state/actions';
  11. import { getNavModel } from '../../core/selectors/navModel';
  12. import { getInvitees, getUsers, getUsersSearchQuery } from './state/selectors';
  13. export interface Props {
  14. navModel: NavModel;
  15. invitees: Invitee[];
  16. users: OrgUser[];
  17. searchQuery: string;
  18. externalUserMngInfo: string;
  19. loadUsers: typeof loadUsers;
  20. loadInvitees: typeof loadInvitees;
  21. setUsersSearchQuery: typeof setUsersSearchQuery;
  22. updateUser: typeof updateUser;
  23. removeUser: typeof removeUser;
  24. revokeInvite: typeof revokeInvite;
  25. }
  26. export interface State {
  27. showInvites: boolean;
  28. }
  29. export class UsersListPage extends PureComponent<Props, State> {
  30. state = {
  31. showInvites: false,
  32. };
  33. componentDidMount() {
  34. this.fetchUsers();
  35. this.fetchInvitees();
  36. }
  37. async fetchUsers() {
  38. return await this.props.loadUsers();
  39. }
  40. async fetchInvitees() {
  41. return await this.props.loadInvitees();
  42. }
  43. onRoleChange = (role, user) => {
  44. const updatedUser = { ...user, role: role };
  45. this.props.updateUser(updatedUser);
  46. };
  47. onRemoveUser = user => {
  48. appEvents.emit('confirm-modal', {
  49. title: 'Delete',
  50. text: 'Are you sure you want to delete user ' + user.login + '?',
  51. yesText: 'Delete',
  52. icon: 'fa-warning',
  53. onConfirm: () => {
  54. this.props.removeUser(user.userId);
  55. },
  56. });
  57. };
  58. onRevokeInvite = code => {
  59. this.props.revokeInvite(code);
  60. };
  61. showInvites = () => {
  62. this.setState(prevState => ({
  63. showInvites: !prevState.showInvites,
  64. }));
  65. };
  66. render() {
  67. const { externalUserMngInfo, invitees, navModel, users } = this.props;
  68. return (
  69. <div>
  70. <PageHeader model={navModel} />
  71. <div className="page-container page-body">
  72. <UsersActionBar showInvites={this.showInvites} />
  73. {externalUserMngInfo && (
  74. <div className="grafana-info-box">
  75. <span>{externalUserMngInfo}</span>
  76. </div>
  77. )}
  78. {this.state.showInvites ? (
  79. <InviteesTable invitees={invitees} revokeInvite={code => this.onRevokeInvite(code)} />
  80. ) : (
  81. <UsersTable
  82. users={users}
  83. onRoleChange={(role, user) => this.onRoleChange(role, user)}
  84. onRemoveUser={user => this.onRemoveUser(user)}
  85. />
  86. )}
  87. </div>
  88. </div>
  89. );
  90. }
  91. }
  92. function mapStateToProps(state) {
  93. return {
  94. navModel: getNavModel(state.navIndex, 'users'),
  95. users: getUsers(state.users),
  96. searchQuery: getUsersSearchQuery(state.users),
  97. invitees: getInvitees(state.users),
  98. externalUserMngInfo: state.users.externalUserMngInfo,
  99. };
  100. }
  101. const mapDispatchToProps = {
  102. loadUsers,
  103. loadInvitees,
  104. setUsersSearchQuery,
  105. updateUser,
  106. removeUser,
  107. revokeInvite,
  108. };
  109. export default hot(module)(connect(mapStateToProps, mapDispatchToProps)(UsersListPage));