@bigbinary/neeto-team-members-frontend 2.10.5 → 2.10.7
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +114 -30
- package/dist/index.cjs.js +57 -22
- package/dist/index.cjs.js.map +1 -1
- package/dist/index.js +57 -22
- package/dist/index.js.map +1 -1
- package/package.json +3 -3
package/README.md
CHANGED
|
@@ -2,22 +2,27 @@
|
|
|
2
2
|
|
|
3
3
|
The `neeto-team-members-nano` facilitates the administration of team members within neeto applications. The nano exports the `@bigbinary/neeto-team-members-frontend` NPM package and `neeto-team-members-engine` Rails engine for development.
|
|
4
4
|
|
|
5
|
-
|
|
5
|
+
## Contents
|
|
6
|
+
|
|
6
7
|
1. [Development with Host Application](#development-with-host-application)
|
|
7
8
|
- [Engine](#engine)
|
|
8
|
-
|
|
9
|
-
|
|
9
|
+
- [Installation](#installation)
|
|
10
|
+
- [Usage](#usage)
|
|
10
11
|
- [Frontend package](#frontend-package)
|
|
11
|
-
|
|
12
|
-
|
|
12
|
+
- [Installation](#installation-1)
|
|
13
|
+
- [Components](#components)
|
|
13
14
|
2. [Instructions for Publishing](#instructions-for-publishing)
|
|
14
15
|
|
|
15
|
-
|
|
16
|
-
|
|
16
|
+
## Development with Host Application
|
|
17
|
+
|
|
18
|
+
### Engine
|
|
19
|
+
|
|
17
20
|
The engine is used to seed the roles and permissions for the organization. It also provides concerns to handle common logic related to `User` model.
|
|
18
21
|
|
|
19
|
-
|
|
22
|
+
#### Installation
|
|
23
|
+
|
|
20
24
|
1. Add this line to your application's Gemfile:
|
|
25
|
+
|
|
21
26
|
```ruby
|
|
22
27
|
source "NEETO_GEM_SERVER_URL" do
|
|
23
28
|
# ..existing gems
|
|
@@ -25,51 +30,75 @@ The engine is used to seed the roles and permissions for the organization. It al
|
|
|
25
30
|
gem 'neeto-team-members-engine'
|
|
26
31
|
end
|
|
27
32
|
```
|
|
33
|
+
|
|
28
34
|
2. And then execute:
|
|
35
|
+
|
|
29
36
|
```shell
|
|
30
37
|
bundle install
|
|
31
38
|
```
|
|
39
|
+
|
|
32
40
|
3. Add this line to your application's `config/routes.rb` file:
|
|
41
|
+
|
|
33
42
|
```ruby
|
|
34
43
|
mount NeetoTeamMembersEngine::Engine => "/neeto_team_members_engine"
|
|
35
44
|
```
|
|
45
|
+
|
|
36
46
|
4. Run the command to bring in all migrations required from the engine to the host application:
|
|
47
|
+
|
|
37
48
|
```shell
|
|
38
49
|
bundle exec rails neeto_team_members_engine:install:migrations
|
|
39
50
|
```
|
|
51
|
+
|
|
40
52
|
5. Add the migrations to the database:
|
|
53
|
+
|
|
41
54
|
```shell
|
|
42
55
|
bundle exec rails db:migrate
|
|
43
56
|
```
|
|
57
|
+
|
|
44
58
|
6. Now, run the generator which will copy the required files.
|
|
59
|
+
|
|
45
60
|
```shell
|
|
46
61
|
bundle exec rails g neeto_team_members_engine:install
|
|
47
62
|
```
|
|
63
|
+
|
|
48
64
|
This command will try to inject the engine's route as well as create a `config/permissions.yml` file to add the permissions required.
|
|
49
65
|
|
|
50
|
-
|
|
66
|
+
#### Usage
|
|
67
|
+
|
|
51
68
|
You can learn more about the setup and usage here:
|
|
69
|
+
|
|
52
70
|
1. [Permissions](./docs/engine/permissions.md)
|
|
53
71
|
2. [Roles](./docs/engine/roles.md)
|
|
54
72
|
3. [Concerns](./docs/engine/concerns.md)
|
|
55
73
|
|
|
56
|
-
|
|
74
|
+
### Frontend package
|
|
75
|
+
|
|
57
76
|
The package exports the four components: `Roles`, `TeamMembers`, `Permissions`, and `ManageRole`.
|
|
58
77
|
|
|
59
|
-
|
|
60
|
-
|
|
78
|
+
#### Installation
|
|
79
|
+
|
|
80
|
+
Install the latest `NeetoTeamMembersNano` package using the below command:
|
|
61
81
|
|
|
62
82
|
```shell
|
|
63
83
|
yarn add @bigbinary/neeto-team-members-frontend
|
|
64
84
|
```
|
|
65
|
-
|
|
66
|
-
####
|
|
85
|
+
|
|
86
|
+
#### Components
|
|
87
|
+
|
|
88
|
+
##### `Roles`
|
|
89
|
+
|
|
67
90
|
This component manages team roles. It includes functionalities such as adding roles and allowing updates to roles with associated permissions.
|
|
68
|
-
|
|
91
|
+
|
|
92
|
+
###### Props
|
|
93
|
+
|
|
69
94
|
- `config`: Configuration object that includes mandatory specifications for header breadcrumbs and role permissions. It also allows optional configurations for help articles and permission hierarchy.
|
|
70
|
-
|
|
95
|
+
|
|
96
|
+
###### Configuration
|
|
97
|
+
|
|
71
98
|
Refer to the [Roles](./docs/frontend/roles.md) section for detailed information on the available configurations for the `Roles` component.
|
|
72
|
-
|
|
99
|
+
|
|
100
|
+
###### Usage
|
|
101
|
+
|
|
73
102
|
```jsx
|
|
74
103
|
import React from "react";
|
|
75
104
|
|
|
@@ -95,13 +124,21 @@ const App = () => (
|
|
|
95
124
|
|
|
96
125
|
export default App;
|
|
97
126
|
```
|
|
98
|
-
|
|
127
|
+
|
|
128
|
+
##### `TeamMembers`
|
|
129
|
+
|
|
99
130
|
The component offers functionalities for adding, updating and viewing team members and their roles in a tabular format. Additionally, it provides filtering options based on email, name, and role.
|
|
100
|
-
|
|
131
|
+
|
|
132
|
+
###### Props
|
|
133
|
+
|
|
101
134
|
- `config`: Configuration object that allows customization of role management, member operation permissions, UI elements like buttons and headers, callback functions, table structure, dropdown actions, and various display aspects.
|
|
102
|
-
|
|
135
|
+
|
|
136
|
+
###### Configuration
|
|
137
|
+
|
|
103
138
|
Refer to the [TeamMembers](./docs/frontend/team_members.md) section for detailed information on the available configurations for the `TeamMembers` component.
|
|
104
|
-
|
|
139
|
+
|
|
140
|
+
###### Usage
|
|
141
|
+
|
|
105
142
|
```jsx
|
|
106
143
|
import React from "react";
|
|
107
144
|
|
|
@@ -128,15 +165,22 @@ const App = () => (
|
|
|
128
165
|
export default App;
|
|
129
166
|
```
|
|
130
167
|
|
|
131
|
-
|
|
168
|
+
##### `Permissions`
|
|
169
|
+
|
|
132
170
|
The component handles the rendering and management of permissions for team members. It organizes permissions into categories, provides checkboxes for selection, and supports hierarchical structures with parent-child relationships.
|
|
133
|
-
|
|
171
|
+
|
|
172
|
+
###### Props
|
|
173
|
+
|
|
134
174
|
- `permissions`: An array of permissions.
|
|
135
175
|
- `isDisabled`: A boolean indicating whether the component is disabled. By default, it is false.
|
|
136
176
|
- `permissionRelationConfig`: Configuration for managing parent-child relationships and unchecking permissions on select.
|
|
137
|
-
|
|
177
|
+
|
|
178
|
+
###### Configuration
|
|
179
|
+
|
|
138
180
|
Refer to the [Permissions](./docs/frontend/permissions.md) section for detailed information on the available configurations for the `TeamMembers` component.
|
|
139
|
-
|
|
181
|
+
|
|
182
|
+
###### Usage
|
|
183
|
+
|
|
140
184
|
```jsx
|
|
141
185
|
import React from "react";
|
|
142
186
|
|
|
@@ -166,18 +210,24 @@ const App = () => (
|
|
|
166
210
|
export default App;
|
|
167
211
|
```
|
|
168
212
|
|
|
169
|
-
|
|
213
|
+
##### `ManageMembers`
|
|
214
|
+
|
|
170
215
|
The component is a form-based interface for adding or editing team members.
|
|
171
|
-
|
|
216
|
+
|
|
217
|
+
###### Props
|
|
218
|
+
|
|
172
219
|
- `config`: Configuration object with various options for customizing the behavior of the component.
|
|
173
220
|
- `onComplete`: Callback function to be executed when the component is closed or the form is submitted.
|
|
174
221
|
- `roles`: An array of roles available for team members.
|
|
175
222
|
- `selectedMember`: The team member object being edited, if applicable.
|
|
176
223
|
- `componentConfig`: Configuration specific to the component, including the type of pane, initial focus reference, etc.
|
|
177
224
|
|
|
178
|
-
|
|
225
|
+
###### Configuration
|
|
226
|
+
|
|
179
227
|
Refer to the [ManageMembers](./docs/frontend/manage_members.md) section for detailed information on the available configurations for the `ManageMembers` component.
|
|
180
|
-
|
|
228
|
+
|
|
229
|
+
###### Usage
|
|
230
|
+
|
|
181
231
|
```jsx
|
|
182
232
|
import React from "react";
|
|
183
233
|
|
|
@@ -207,6 +257,40 @@ const App = () => (
|
|
|
207
257
|
|
|
208
258
|
export default App;
|
|
209
259
|
```
|
|
210
|
-
|
|
260
|
+
|
|
261
|
+
## Instructions for Publishing
|
|
211
262
|
|
|
212
263
|
Consult the [building and releasing packages](https://neeto-engineering.neetokb.com/articles/building-and-releasing-packages) guide for details on how to publish.
|
|
264
|
+
|
|
265
|
+
## Integrations
|
|
266
|
+
|
|
267
|
+
| Projects | TeamMembers | Roles | Permissions |
|
|
268
|
+
|----------------| :----------------: | :----------------: | :----------------: |
|
|
269
|
+
| neetoAuth | :white_check_mark: | :white_check_mark: | - |
|
|
270
|
+
| neetoCal | :white_check_mark: | :white_check_mark: | - |
|
|
271
|
+
| neetoChangelog | :white_check_mark: | :white_check_mark: | - |
|
|
272
|
+
| neetoChat | :white_check_mark: | :white_check_mark: | - |
|
|
273
|
+
| neetoChatify | :white_check_mark: | :white_check_mark: | - |
|
|
274
|
+
| neetoCI | :white_check_mark: | :white_check_mark: | - |
|
|
275
|
+
| neetoCourse | :white_check_mark: | :white_check_mark: | - |
|
|
276
|
+
| neetoCRM | :white_check_mark: | :white_check_mark: | - |
|
|
277
|
+
| neetoDeploy | :white_check_mark: | :white_check_mark: | :white_check_mark: |
|
|
278
|
+
| neetoDesk | :white_check_mark: | :white_check_mark: | - |
|
|
279
|
+
| neetoForm | :white_check_mark: | :white_check_mark: | - |
|
|
280
|
+
| neetoGit | :white_check_mark: | :white_check_mark: | - |
|
|
281
|
+
| neetoInvisible | :white_check_mark: | :white_check_mark: | - |
|
|
282
|
+
| neetoInvoice | :white_check_mark: | :white_check_mark: | - |
|
|
283
|
+
| neetoKB | :white_check_mark: | :white_check_mark: | - |
|
|
284
|
+
| neetoMonitor | :white_check_mark: | :white_check_mark: | - |
|
|
285
|
+
| neetoPlanner | :white_check_mark: | :white_check_mark: | - |
|
|
286
|
+
| neetoQuiz | :white_check_mark: | :white_check_mark: | - |
|
|
287
|
+
| neetoRecord | :white_check_mark: | :white_check_mark: | - |
|
|
288
|
+
| neetoReplay | :white_check_mark: | :white_check_mark: | - |
|
|
289
|
+
| neetoRunner | :white_check_mark: | :white_check_mark: | - |
|
|
290
|
+
| neetoSign | :white_check_mark: | :white_check_mark: | - |
|
|
291
|
+
| neetoSite | :white_check_mark: | :white_check_mark: | - |
|
|
292
|
+
| neetoTestify | :white_check_mark: | :white_check_mark: | - |
|
|
293
|
+
| neetoTower | :white_check_mark: | :white_check_mark: | - |
|
|
294
|
+
| neetoTrail | :white_check_mark: | :white_check_mark: | - |
|
|
295
|
+
| neetoWheel | :white_check_mark: | :white_check_mark: | - |
|
|
296
|
+
| neetoWireframe | :white_check_mark: | :white_check_mark: | - |
|
package/dist/index.cjs.js
CHANGED
|
@@ -2792,7 +2792,7 @@ var Roles = function Roles(_ref) {
|
|
|
2792
2792
|
roles = _useFetchRoles.data,
|
|
2793
2793
|
isRolesLoading = _useFetchRoles.isLoading;
|
|
2794
2794
|
var _useQueryParams = reactUtils.useQueryParams(),
|
|
2795
|
-
_useQueryParams$searc = _useQueryParams.
|
|
2795
|
+
_useQueryParams$searc = _useQueryParams.searchTerm,
|
|
2796
2796
|
searchTerm = _useQueryParams$searc === void 0 ? "" : _useQueryParams$searc;
|
|
2797
2797
|
var _useFetchPermissions = useFetchPermissions({
|
|
2798
2798
|
enabled: isViewPermissionGranted
|
|
@@ -5388,7 +5388,7 @@ var useFilters = function useFilters(_ref) {
|
|
|
5388
5388
|
var _useTranslation = reactI18next.useTranslation(),
|
|
5389
5389
|
t = _useTranslation.t;
|
|
5390
5390
|
var _useQueryParams = reactUtils.useQueryParams(),
|
|
5391
|
-
_useQueryParams$searc = _useQueryParams.
|
|
5391
|
+
_useQueryParams$searc = _useQueryParams.searchTerm,
|
|
5392
5392
|
searchTerm = _useQueryParams$searc === void 0 ? "" : _useQueryParams$searc;
|
|
5393
5393
|
var _useState = React.useState(""),
|
|
5394
5394
|
_useState2 = _slicedToArray(_useState, 2),
|
|
@@ -5466,8 +5466,10 @@ var useTeams = function useTeams(_ref) {
|
|
|
5466
5466
|
selectedRows = _useState6[0],
|
|
5467
5467
|
setSelectedRows = _useState6[1];
|
|
5468
5468
|
var handleUpdateMember = function handleUpdateMember() {
|
|
5469
|
+
var _globalProps$user;
|
|
5469
5470
|
var id = selectedMember.id,
|
|
5470
|
-
active = selectedMember.active
|
|
5471
|
+
active = selectedMember.active,
|
|
5472
|
+
email = selectedMember.email;
|
|
5471
5473
|
var payload = {
|
|
5472
5474
|
active: !active
|
|
5473
5475
|
};
|
|
@@ -5475,6 +5477,9 @@ var useTeams = function useTeams(_ref) {
|
|
|
5475
5477
|
id: id,
|
|
5476
5478
|
payload: payload
|
|
5477
5479
|
});
|
|
5480
|
+
if (((_globalProps$user = initializers.globalProps.user) === null || _globalProps$user === void 0 ? void 0 : _globalProps$user.email) === email) {
|
|
5481
|
+
window.location.pathname = "/";
|
|
5482
|
+
}
|
|
5478
5483
|
};
|
|
5479
5484
|
var handleUpdateStatus = function handleUpdateStatus(user) {
|
|
5480
5485
|
setSelectedMember(user);
|
|
@@ -5488,8 +5493,13 @@ var useTeams = function useTeams(_ref) {
|
|
|
5488
5493
|
setIsOpen(ramda.assoc("alert", false));
|
|
5489
5494
|
setSelectedMember(null);
|
|
5490
5495
|
};
|
|
5491
|
-
var
|
|
5496
|
+
var handlePaneClose = function handlePaneClose(_ref2) {
|
|
5497
|
+
var _globalProps$user2;
|
|
5498
|
+
var submitted = _ref2.submitted;
|
|
5492
5499
|
setIsOpen(ramda.assoc("manageMember", false));
|
|
5500
|
+
if (submitted && ((_globalProps$user2 = initializers.globalProps.user) === null || _globalProps$user2 === void 0 ? void 0 : _globalProps$user2.email) === (selectedMember === null || selectedMember === void 0 ? void 0 : selectedMember.email)) {
|
|
5501
|
+
window.location.pathname = "/";
|
|
5502
|
+
}
|
|
5493
5503
|
setSelectedMember(null);
|
|
5494
5504
|
};
|
|
5495
5505
|
var resetSelectedRows = function resetSelectedRows() {
|
|
@@ -5524,7 +5534,7 @@ var useTeams = function useTeams(_ref) {
|
|
|
5524
5534
|
return {
|
|
5525
5535
|
handleAlertClose: handleAlertClose,
|
|
5526
5536
|
handleMemberFilterChange: handleMemberFilterChange,
|
|
5527
|
-
|
|
5537
|
+
handlePaneClose: handlePaneClose,
|
|
5528
5538
|
handleRowSelect: handleRowSelect,
|
|
5529
5539
|
handleTableChange: handleTableChange,
|
|
5530
5540
|
handleUpdateMember: handleUpdateMember,
|
|
@@ -5733,12 +5743,16 @@ var Left = function Left(_ref) {
|
|
|
5733
5743
|
}),
|
|
5734
5744
|
bulkUpdateMember = _useBulkUpdateMembers.mutate;
|
|
5735
5745
|
var handleDeactivateMembers = function handleDeactivateMembers() {
|
|
5736
|
-
|
|
5746
|
+
var _selectedRows$emails, _globalProps$user;
|
|
5747
|
+
bulkUpdateMember({
|
|
5737
5748
|
users: {
|
|
5738
5749
|
active: false,
|
|
5739
5750
|
emails: selectedRows === null || selectedRows === void 0 ? void 0 : selectedRows.emails
|
|
5740
5751
|
}
|
|
5741
5752
|
});
|
|
5753
|
+
if (selectedRows !== null && selectedRows !== void 0 && (_selectedRows$emails = selectedRows.emails) !== null && _selectedRows$emails !== void 0 && _selectedRows$emails.includes((_globalProps$user = initializers.globalProps.user) === null || _globalProps$user === void 0 ? void 0 : _globalProps$user.email)) {
|
|
5754
|
+
window.location.pathname = "/";
|
|
5755
|
+
}
|
|
5742
5756
|
};
|
|
5743
5757
|
var handleActivateMembers = function handleActivateMembers() {
|
|
5744
5758
|
return bulkUpdateMember({
|
|
@@ -5749,6 +5763,7 @@ var Left = function Left(_ref) {
|
|
|
5749
5763
|
});
|
|
5750
5764
|
};
|
|
5751
5765
|
var handleRoleChange = function handleRoleChange(role) {
|
|
5766
|
+
var _selectedRows$emails2, _globalProps$user2;
|
|
5752
5767
|
bulkUpdateMember({
|
|
5753
5768
|
users: {
|
|
5754
5769
|
active: true,
|
|
@@ -5756,6 +5771,9 @@ var Left = function Left(_ref) {
|
|
|
5756
5771
|
organization_role: role
|
|
5757
5772
|
}
|
|
5758
5773
|
});
|
|
5774
|
+
if (selectedRows !== null && selectedRows !== void 0 && (_selectedRows$emails2 = selectedRows.emails) !== null && _selectedRows$emails2 !== void 0 && _selectedRows$emails2.includes((_globalProps$user2 = initializers.globalProps.user) === null || _globalProps$user2 === void 0 ? void 0 : _globalProps$user2.email)) {
|
|
5775
|
+
window.location.pathname = "/";
|
|
5776
|
+
}
|
|
5759
5777
|
};
|
|
5760
5778
|
var alertTypes = [{
|
|
5761
5779
|
message: "neetoTeamMembers.alerts.messages.deactivateMember",
|
|
@@ -5826,11 +5844,11 @@ var Left = function Left(_ref) {
|
|
|
5826
5844
|
return setAlertType("activate");
|
|
5827
5845
|
}
|
|
5828
5846
|
}, t("neetoTeamMembers.common.activate")), !(config !== null && config !== void 0 && (_config$hiddenBulkAct = config.hiddenBulkActions) !== null && _config$hiddenBulkAct !== void 0 && _config$hiddenBulkAct.includes("role")) && /*#__PURE__*/React__default["default"].createElement(RolesDropdown, {
|
|
5829
|
-
disabled: hasDeactivateMembers,
|
|
5830
|
-
hasUpdatePermission: isUpdatePermissionGranted,
|
|
5831
5847
|
roles: roles,
|
|
5832
5848
|
setAlertType: setAlertType,
|
|
5833
|
-
setBulkUpdateRole: setBulkUpdateRole
|
|
5849
|
+
setBulkUpdateRole: setBulkUpdateRole,
|
|
5850
|
+
disabled: hasDeactivateMembers,
|
|
5851
|
+
hasUpdatePermission: isUpdatePermissionGranted
|
|
5834
5852
|
}), config === null || config === void 0 || (_config$otherBulkActi = config.otherBulkActions) === null || _config$otherBulkActi === void 0 ? void 0 : _config$otherBulkActi.call(config))))), /*#__PURE__*/React__default["default"].createElement(neetoui.Alert, {
|
|
5835
5853
|
isOpen: selectedAlert,
|
|
5836
5854
|
submitButtonLabel: getButtonLabel(selectedAlert === null || selectedAlert === void 0 ? void 0 : selectedAlert.type),
|
|
@@ -6422,6 +6440,7 @@ var ManageMember = function ManageMember(_ref) {
|
|
|
6422
6440
|
isAppListEnabled: true
|
|
6423
6441
|
});
|
|
6424
6442
|
var shouldSkipAppListPage = React.useRef(false);
|
|
6443
|
+
var formikValues = React.useRef(null);
|
|
6425
6444
|
var manageMemberComponentConfig = _objectSpread$1(_objectSpread$1({}, DEFAULT_COMPONENT_CONFIG), {}, {
|
|
6426
6445
|
initialFocusRef: inputReference
|
|
6427
6446
|
}, componentConfig);
|
|
@@ -6461,14 +6480,25 @@ var ManageMember = function ManageMember(_ref) {
|
|
|
6461
6480
|
var _useUpdateMember = useUpdateMember({
|
|
6462
6481
|
onSuccess: function onSuccess() {
|
|
6463
6482
|
var _config$updateMember;
|
|
6464
|
-
handleClose();
|
|
6483
|
+
handleClose(true);
|
|
6465
6484
|
config === null || config === void 0 || (_config$updateMember = config.updateMember) === null || _config$updateMember === void 0 || (_config$updateMember = _config$updateMember.onSuccess) === null || _config$updateMember === void 0 ? void 0 : _config$updateMember.callback();
|
|
6466
6485
|
}
|
|
6467
6486
|
}),
|
|
6468
6487
|
updateMember = _useUpdateMember.mutate,
|
|
6469
6488
|
isUpdatingMember = _useUpdateMember.isLoading;
|
|
6489
|
+
var hasRoleChanged = function hasRoleChanged(_ref2) {
|
|
6490
|
+
var submitted = _ref2.submitted,
|
|
6491
|
+
values = _ref2.values;
|
|
6492
|
+
return submitted && (values === null || values === void 0 ? void 0 : values.role) !== (selectedMember === null || selectedMember === void 0 ? void 0 : selectedMember.role);
|
|
6493
|
+
};
|
|
6470
6494
|
var handleClose = function handleClose() {
|
|
6471
|
-
|
|
6495
|
+
var submitted = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : false;
|
|
6496
|
+
onComplete({
|
|
6497
|
+
submitted: hasRoleChanged({
|
|
6498
|
+
submitted: submitted,
|
|
6499
|
+
values: formikValues.current
|
|
6500
|
+
})
|
|
6501
|
+
});
|
|
6472
6502
|
setCurrentPage(FORM_PAGES.MAIN);
|
|
6473
6503
|
appListSavedStateReference.current = {
|
|
6474
6504
|
isAppListEnabled: true
|
|
@@ -6539,7 +6569,9 @@ var ManageMember = function ManageMember(_ref) {
|
|
|
6539
6569
|
"data-cy": "ntm-manage-members-pane-wrapper",
|
|
6540
6570
|
initialFocusRef: manageMemberComponentConfig.initialFocusRef,
|
|
6541
6571
|
isOpen: manageMemberComponentConfig.isOpen,
|
|
6542
|
-
onClose:
|
|
6572
|
+
onClose: function onClose() {
|
|
6573
|
+
return handleClose(false);
|
|
6574
|
+
}
|
|
6543
6575
|
}, /*#__PURE__*/React__default["default"].createElement(Component.Header, _extends({}, manageMemberComponentConfig.headerProps, {
|
|
6544
6576
|
className: classnames__default["default"]([{
|
|
6545
6577
|
"ntm-manage-members__header": currentPage !== FORM_PAGES.MAIN
|
|
@@ -6565,12 +6597,13 @@ var ManageMember = function ManageMember(_ref) {
|
|
|
6565
6597
|
initialValues: renderInitialValues(selectedMember, filteredRoles, globalRoles),
|
|
6566
6598
|
onSubmit: handleOnSubmit
|
|
6567
6599
|
})
|
|
6568
|
-
}, function (
|
|
6600
|
+
}, function (_ref3) {
|
|
6569
6601
|
var _manageMemberComponen2, _manageMemberComponen3;
|
|
6570
|
-
var values =
|
|
6571
|
-
dirty =
|
|
6602
|
+
var values = _ref3.values,
|
|
6603
|
+
dirty = _ref3.dirty;
|
|
6572
6604
|
var emails = values.emails,
|
|
6573
6605
|
role = values.role;
|
|
6606
|
+
formikValues.current = values;
|
|
6574
6607
|
return /*#__PURE__*/React__default["default"].createElement(React__default["default"].Fragment, null, /*#__PURE__*/React__default["default"].createElement(ScrollToErrorField, {
|
|
6575
6608
|
formRef: formReference
|
|
6576
6609
|
}), /*#__PURE__*/React__default["default"].createElement(Component.Body, _extends({}, manageMemberComponentConfig.bodyProps, {
|
|
@@ -6588,7 +6621,9 @@ var ManageMember = function ManageMember(_ref) {
|
|
|
6588
6621
|
"data-cy": "ntm-manage-member-cancel-button",
|
|
6589
6622
|
label: t("neetoTeamMembers.buttons.cancel"),
|
|
6590
6623
|
style: "text",
|
|
6591
|
-
onClick:
|
|
6624
|
+
onClick: function onClick() {
|
|
6625
|
+
return handleClose(false);
|
|
6626
|
+
}
|
|
6592
6627
|
})));
|
|
6593
6628
|
}));
|
|
6594
6629
|
};
|
|
@@ -6684,7 +6719,7 @@ var TeamMembers = function TeamMembers(_ref) {
|
|
|
6684
6719
|
}),
|
|
6685
6720
|
handleAlertClose = _useTeams.handleAlertClose,
|
|
6686
6721
|
handleMemberFilterChange = _useTeams.handleMemberFilterChange,
|
|
6687
|
-
|
|
6722
|
+
handlePaneClose = _useTeams.handlePaneClose,
|
|
6688
6723
|
handleRowSelect = _useTeams.handleRowSelect,
|
|
6689
6724
|
handleTableChange = _useTeams.handleTableChange,
|
|
6690
6725
|
handleUpdateMember = _useTeams.handleUpdateMember,
|
|
@@ -6754,8 +6789,8 @@ var TeamMembers = function TeamMembers(_ref) {
|
|
|
6754
6789
|
}, /*#__PURE__*/React__default["default"].createElement("div", {
|
|
6755
6790
|
className: "ntm-members-wrapper"
|
|
6756
6791
|
}, /*#__PURE__*/React__default["default"].createElement(Menu, {
|
|
6757
|
-
filterCounts: team === null || team === void 0 ? void 0 : team.perCategoryCount,
|
|
6758
6792
|
handleMemberFilterChange: handleMemberFilterChange,
|
|
6793
|
+
filterCounts: team === null || team === void 0 ? void 0 : team.perCategoryCount,
|
|
6759
6794
|
isMenuOpen: isOpen.menuBar,
|
|
6760
6795
|
memberFilter: filters.category
|
|
6761
6796
|
}), /*#__PURE__*/React__default["default"].createElement(Container__default["default"], null, /*#__PURE__*/React__default["default"].createElement(Header$1, {
|
|
@@ -6765,10 +6800,10 @@ var TeamMembers = function TeamMembers(_ref) {
|
|
|
6765
6800
|
filterCategory: filters.category
|
|
6766
6801
|
}), /*#__PURE__*/React__default["default"].createElement(SubHeaderMolecule__default["default"], {
|
|
6767
6802
|
leftActionBlock: /*#__PURE__*/React__default["default"].createElement(SubHeader.Left, {
|
|
6768
|
-
filteredCount: team === null || team === void 0 ? void 0 : team.membersCount,
|
|
6769
6803
|
config: config,
|
|
6770
6804
|
selectedRows: selectedRows,
|
|
6771
6805
|
setSelectedRows: setSelectedRows,
|
|
6806
|
+
filteredCount: team === null || team === void 0 ? void 0 : team.membersCount,
|
|
6772
6807
|
roles: filteredRoles
|
|
6773
6808
|
}),
|
|
6774
6809
|
rightActionBlock: /*#__PURE__*/React__default["default"].createElement(SubHeader.Right, {
|
|
@@ -6806,13 +6841,13 @@ var TeamMembers = function TeamMembers(_ref) {
|
|
|
6806
6841
|
primaryButtonProps: noDataButtonProps,
|
|
6807
6842
|
title: noDataTitle
|
|
6808
6843
|
})))), /*#__PURE__*/React__default["default"].createElement(ManageMember, {
|
|
6844
|
+
config: config,
|
|
6845
|
+
selectedMember: selectedMember,
|
|
6809
6846
|
componentConfig: {
|
|
6810
6847
|
isOpen: isOpen.manageMember
|
|
6811
6848
|
},
|
|
6812
|
-
config: config,
|
|
6813
|
-
selectedMember: selectedMember,
|
|
6814
6849
|
roles: filteredRoles,
|
|
6815
|
-
onComplete:
|
|
6850
|
+
onComplete: handlePaneClose
|
|
6816
6851
|
}), /*#__PURE__*/React__default["default"].createElement(neetoui.Alert, {
|
|
6817
6852
|
cancelButtonLabel: t("neetoTeamMembers.buttons.cancel"),
|
|
6818
6853
|
isOpen: isOpen.alert,
|