UserGroupPage.jsx 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152
  1. import React, { Fragment } from 'react';
  2. import PropTypes from 'prop-types';
  3. import UserGroupTable from './UserGroupTable';
  4. import UserGroupCreateForm from './UserGroupCreateForm';
  5. import UserGroupDeleteModal from './UserGroupDeleteModal';
  6. import { withUnstatedContainers } from '../../UnstatedUtils';
  7. import AppContainer from '~/client/services/AppContainer';
  8. import { toastSuccess, toastError } from '~/client/util/apiNotification';
  9. class UserGroupPage extends React.Component {
  10. constructor(props) {
  11. super(props);
  12. this.state = {
  13. userGroups: [],
  14. userGroupRelations: [],
  15. selectedUserGroup: undefined, // not null but undefined (to use defaultProps in UserGroupDeleteModal)
  16. isDeleteModalShow: false,
  17. };
  18. this.xss = window.xss;
  19. this.showDeleteModal = this.showDeleteModal.bind(this);
  20. this.hideDeleteModal = this.hideDeleteModal.bind(this);
  21. this.addUserGroup = this.addUserGroup.bind(this);
  22. this.deleteUserGroupById = this.deleteUserGroupById.bind(this);
  23. }
  24. async componentDidMount() {
  25. await this.syncUserGroupAndRelations();
  26. }
  27. async showDeleteModal(group) {
  28. try {
  29. await this.syncUserGroupAndRelations();
  30. this.setState({
  31. selectedUserGroup: group,
  32. isDeleteModalShow: true,
  33. });
  34. }
  35. catch (err) {
  36. toastError(err);
  37. }
  38. }
  39. hideDeleteModal() {
  40. this.setState({
  41. selectedUserGroup: undefined,
  42. isDeleteModalShow: false,
  43. });
  44. }
  45. addUserGroup(userGroup, users) {
  46. this.setState((prevState) => {
  47. const userGroupRelations = Object.assign(prevState.userGroupRelations, {
  48. [userGroup._id]: users,
  49. });
  50. return {
  51. userGroups: [...prevState.userGroups, userGroup],
  52. userGroupRelations,
  53. };
  54. });
  55. }
  56. async deleteUserGroupById({ deleteGroupId, actionName, transferToUserGroupId }) {
  57. try {
  58. const res = await this.props.appContainer.apiv3.delete(`/user-groups/${deleteGroupId}`, {
  59. actionName,
  60. transferToUserGroupId,
  61. });
  62. this.setState((prevState) => {
  63. const userGroups = prevState.userGroups.filter((userGroup) => {
  64. return userGroup._id !== deleteGroupId;
  65. });
  66. delete prevState.userGroupRelations[deleteGroupId];
  67. return {
  68. userGroups,
  69. userGroupRelations: prevState.userGroupRelations,
  70. selectedUserGroup: undefined,
  71. isDeleteModalShow: false,
  72. };
  73. });
  74. toastSuccess(`Deleted a group "${this.xss.process(res.data.userGroup.name)}"`);
  75. }
  76. catch (err) {
  77. toastError(new Error('Unable to delete the group'));
  78. }
  79. }
  80. async syncUserGroupAndRelations() {
  81. try {
  82. const userGroupsRes = await this.props.appContainer.apiv3.get('/user-groups', { pagination: false });
  83. const userGroupRelationsRes = await this.props.appContainer.apiv3.get('/user-group-relations');
  84. this.setState({
  85. userGroups: userGroupsRes.data.userGroups,
  86. userGroupRelations: userGroupRelationsRes.data.userGroupRelations,
  87. });
  88. }
  89. catch (err) {
  90. toastError(err);
  91. }
  92. }
  93. render() {
  94. const { isAclEnabled } = this.props.appContainer.config;
  95. return (
  96. <Fragment>
  97. <UserGroupCreateForm
  98. isAclEnabled={isAclEnabled}
  99. onCreate={this.addUserGroup}
  100. />
  101. <UserGroupTable
  102. userGroups={this.state.userGroups}
  103. isAclEnabled={isAclEnabled}
  104. onDelete={this.showDeleteModal}
  105. userGroupRelations={this.state.userGroupRelations}
  106. />
  107. <UserGroupDeleteModal
  108. userGroups={this.state.userGroups}
  109. deleteUserGroup={this.state.selectedUserGroup}
  110. onDelete={this.deleteUserGroupById}
  111. isShow={this.state.isDeleteModalShow}
  112. onShow={this.showDeleteModal}
  113. onHide={this.hideDeleteModal}
  114. />
  115. </Fragment>
  116. );
  117. }
  118. }
  119. /**
  120. * Wrapper component for using unstated
  121. */
  122. const UserGroupPageWrapper = withUnstatedContainers(UserGroupPage, [AppContainer]);
  123. UserGroupPage.propTypes = {
  124. appContainer: PropTypes.instanceOf(AppContainer).isRequired,
  125. };
  126. export default UserGroupPageWrapper;