You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

AllHoldersList.tsx 4.3KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131
  1. /*
  2. * SonarQube
  3. * Copyright (C) 2009-2022 SonarSource SA
  4. * mailto:info AT sonarsource DOT com
  5. *
  6. * This program is free software; you can redistribute it and/or
  7. * modify it under the terms of the GNU Lesser General Public
  8. * License as published by the Free Software Foundation; either
  9. * version 3 of the License, or (at your option) any later version.
  10. *
  11. * This program is distributed in the hope that it will be useful,
  12. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  14. * Lesser General Public License for more details.
  15. *
  16. * You should have received a copy of the GNU Lesser General Public License
  17. * along with this program; if not, write to the Free Software Foundation,
  18. * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
  19. */
  20. import * as React from 'react';
  21. import withAppStateContext from '../../../../app/components/app-state/withAppStateContext';
  22. import ListFooter from '../../../../components/controls/ListFooter';
  23. import { AppState } from '../../../../types/appstate';
  24. import { ComponentQualifier } from '../../../../types/component';
  25. import { Paging, PermissionGroup, PermissionUser } from '../../../../types/types';
  26. import HoldersList from '../../shared/components/HoldersList';
  27. import SearchForm from '../../shared/components/SearchForm';
  28. import {
  29. convertToPermissionDefinitions,
  30. filterPermissions,
  31. PERMISSIONS_ORDER_GLOBAL
  32. } from '../../utils';
  33. interface StateProps {
  34. appState: AppState;
  35. }
  36. interface OwnProps {
  37. filter: string;
  38. grantPermissionToGroup: (groupName: string, permission: string) => Promise<void>;
  39. grantPermissionToUser: (login: string, permission: string) => Promise<void>;
  40. groups: PermissionGroup[];
  41. groupsPaging?: Paging;
  42. loadHolders: () => void;
  43. loading?: boolean;
  44. onLoadMore: () => void;
  45. onFilter: (filter: string) => void;
  46. onSearch: (query: string) => void;
  47. query: string;
  48. revokePermissionFromGroup: (groupName: string, permission: string) => Promise<void>;
  49. revokePermissionFromUser: (login: string, permission: string) => Promise<void>;
  50. users: PermissionUser[];
  51. usersPaging?: Paging;
  52. }
  53. type Props = StateProps & OwnProps;
  54. export class AllHoldersList extends React.PureComponent<Props> {
  55. handleToggleUser = (user: PermissionUser, permission: string) => {
  56. const hasPermission = user.permissions.includes(permission);
  57. if (hasPermission) {
  58. return this.props.revokePermissionFromUser(user.login, permission);
  59. }
  60. return this.props.grantPermissionToUser(user.login, permission);
  61. };
  62. handleToggleGroup = (group: PermissionGroup, permission: string) => {
  63. const hasPermission = group.permissions.includes(permission);
  64. if (hasPermission) {
  65. return this.props.revokePermissionFromGroup(group.name, permission);
  66. }
  67. return this.props.grantPermissionToGroup(group.name, permission);
  68. };
  69. render() {
  70. const {
  71. appState,
  72. filter,
  73. groups,
  74. groupsPaging,
  75. users,
  76. usersPaging,
  77. loading,
  78. query
  79. } = this.props;
  80. const l10nPrefix = 'global_permissions';
  81. const hasPortfoliosEnabled = appState.qualifiers.includes(ComponentQualifier.Portfolio);
  82. const hasApplicationsEnabled = appState.qualifiers.includes(ComponentQualifier.Application);
  83. const permissions = convertToPermissionDefinitions(
  84. filterPermissions(PERMISSIONS_ORDER_GLOBAL, hasApplicationsEnabled, hasPortfoliosEnabled),
  85. l10nPrefix
  86. );
  87. let count = 0;
  88. let total = 0;
  89. if (filter !== 'users') {
  90. count += groups.length;
  91. total += groupsPaging ? groupsPaging.total : groups.length;
  92. }
  93. if (filter !== 'groups') {
  94. count += users.length;
  95. total += usersPaging ? usersPaging.total : users.length;
  96. }
  97. return (
  98. <>
  99. <HoldersList
  100. filter={filter}
  101. groups={groups}
  102. loading={loading}
  103. onToggleGroup={this.handleToggleGroup}
  104. onToggleUser={this.handleToggleUser}
  105. permissions={permissions}
  106. query={query}
  107. users={users}>
  108. <SearchForm
  109. filter={filter}
  110. onFilter={this.props.onFilter}
  111. onSearch={this.props.onSearch}
  112. query={query}
  113. />
  114. </HoldersList>
  115. <ListFooter count={count} loadMore={this.props.onLoadMore} total={total} />
  116. </>
  117. );
  118. }
  119. }
  120. export default withAppStateContext(AllHoldersList);