UsersListPage.tsx 4.0 KB

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