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