UsersListPage.tsx 3.7 KB

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