@projectcor/people-microfront 1.0.2-1 → 1.0.2-11

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.
Files changed (68) hide show
  1. package/lib/App.js +1 -43
  2. package/lib/App.stories.js +10 -2
  3. package/lib/components/DeleteTeamModal/DeleteTeamModal.js +36 -24
  4. package/lib/components/DeleteTeamModal/DeleteTeamModal.styles.js +18 -6
  5. package/lib/components/DeleteTeamModal/DeleteTeamModal.types.js +1 -1
  6. package/lib/components/DeletedUserIcon/DeletedUserIcon.styles.js +2 -2
  7. package/lib/components/DisabledUserIcon/DisabledUserIcon.styles.js +2 -2
  8. package/lib/components/MenuOptions/MenuOptions.js +4 -18
  9. package/lib/components/ModalEditUserPosition/ModalEditUserPosition.js +17 -52
  10. package/lib/components/ModalEditUserPosition/ModalEditUserPosition.styles.js +36 -0
  11. package/lib/components/ModalEditUserPosition/UserEditPositionRow.js +3 -3
  12. package/lib/components/Pagination/PaginationView.js +132 -0
  13. package/lib/components/Table/Row/Row.js +17 -3
  14. package/lib/components/Table/Row/Row.styles.js +23 -11
  15. package/lib/components/Table/TeamRow/AddMemberModal/AddMemberModal.js +65 -0
  16. package/lib/components/Table/TeamRow/AddMemberModal/AddMemberModal.styles.js +38 -0
  17. package/lib/components/Table/TeamRow/AddMemberModal/index.js +2 -0
  18. package/lib/components/Table/TeamRow/AddUsers/AddUsers.js +182 -0
  19. package/lib/components/Table/TeamRow/AddUsers/AddUsers.styles.js +21 -0
  20. package/lib/components/Table/TeamRow/AddUsers/index.js +2 -0
  21. package/lib/components/Table/TeamRow/RemoveMemberModal/RemoveMemberModal.js +65 -0
  22. package/lib/components/Table/TeamRow/RemoveMemberModal/RemoveMemberModal.styles.js +38 -0
  23. package/lib/components/Table/TeamRow/RemoveMemberModal/index.js +2 -0
  24. package/lib/components/Table/TeamRow/TeamRow.js +76 -58
  25. package/lib/components/Table/TeamRow/UsersRow/UsersRow.js +191 -0
  26. package/lib/components/Table/TeamRow/UsersRow/UsersRow.styles.js +40 -0
  27. package/lib/components/Table/TeamRow/UsersRow/index.js +2 -0
  28. package/lib/components/TeamDetailsModal/MembersSelect.js +103 -28
  29. package/lib/components/TeamDetailsModal/TeamDetailsModal.js +68 -69
  30. package/lib/components/TeamDetailsModal/TeamDetailsModal.styles.js +10 -6
  31. package/lib/components/TeamDetailsModal/TeamDetailsModal.types.js +1 -1
  32. package/lib/components/TeamDetailsModal/index.js +1 -1
  33. package/lib/components/UserRow/UserRow.js +9 -5
  34. package/lib/container/Body/BodyContainerViewTeams.js +75 -101
  35. package/lib/container/Filters/FiltersContainer.js +4 -4
  36. package/lib/container/MainView/MainTeamsView.js +33 -0
  37. package/lib/container/MainView/MainUsersView.js +77 -65
  38. package/lib/container/MainView/MainView.js +30 -40
  39. package/lib/container/Pagination/PaginationContainer.js +10 -123
  40. package/lib/container/Pagination/PaginationTeamsContainer.js +32 -0
  41. package/lib/container/RouterComponent/RouterComponent.js +20 -15
  42. package/lib/container/TableContainer/TableContainer.js +9 -4
  43. package/lib/context/TeamsContext.js +5 -2
  44. package/lib/context/UsersContext.js +59 -22
  45. package/lib/hooks/useAssignUserToTeam.js +78 -0
  46. package/lib/hooks/useCreateTeams.js +63 -0
  47. package/lib/hooks/useDeleteTeam.js +63 -0
  48. package/lib/hooks/useGetTeams.js +8 -4
  49. package/lib/hooks/useGetTotalPositions.js +24 -0
  50. package/lib/hooks/useGetTotalTeams.js +24 -0
  51. package/lib/hooks/useUnassignUserFromTeam.js +67 -0
  52. package/lib/hooks/useUnblockUser.js +14 -14
  53. package/lib/hooks/useUpdateTeam.js +65 -0
  54. package/lib/lang/translation/br.json +17 -4
  55. package/lib/lang/translation/en.json +54 -41
  56. package/lib/lang/translation/es.json +17 -4
  57. package/lib/lang/translation/fr.json +82 -69
  58. package/lib/mocks/mockedUser.js +7 -1
  59. package/lib/query/assignUserToTeam.js +5 -0
  60. package/lib/query/createTeam.js +5 -0
  61. package/lib/query/deleteTeam.js +5 -0
  62. package/lib/query/getTeams.js +2 -2
  63. package/lib/query/getTotalPositions.js +5 -0
  64. package/lib/query/getTotalTeams.js +5 -0
  65. package/lib/query/unassignUserFromTeam.js +5 -0
  66. package/lib/query/updateTeam.js +5 -0
  67. package/lib/types/global.d.js +1 -1
  68. package/package.json +4 -4
@@ -0,0 +1,33 @@
1
+ import { memo } from 'react';
2
+ import { useTeams } from '../../context/TeamsContext';
3
+ import { LayoutSection } from '../../components/Layout';
4
+ import { HeaderTeams } from '../../components/HeaderTeams';
5
+ import { EmptyStateTeams } from '../../components/EmptyStateTeams';
6
+ import { useGetTeams } from '../../hooks/useGetTeams';
7
+ import { ErrorTeams } from '../../components/ErrorTeams';
8
+ import { TableContainer } from '../TableContainer/TableContainer';
9
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
10
+ export var MainTeamsView = /*#__PURE__*/memo(function () {
11
+ var _useTeams = useTeams(),
12
+ teams = _useTeams.teams;
13
+ var _useGetTeams = useGetTeams(),
14
+ loading = _useGetTeams.loading,
15
+ error = _useGetTeams.error;
16
+ var handleCreateTeam = function handleCreateTeam() {
17
+ var event = new CustomEvent('createTeam');
18
+ window.dispatchEvent(event);
19
+ };
20
+ return /*#__PURE__*/_jsxs(LayoutSection, {
21
+ children: [/*#__PURE__*/_jsx(HeaderTeams, {
22
+ showCreateButton: teams.length > 0,
23
+ clickCreateTeam: handleCreateTeam
24
+ }), error && /*#__PURE__*/_jsx(ErrorTeams, {}), teams.length > 0 ? /*#__PURE__*/_jsx(TableContainer, {
25
+ loading: loading,
26
+ error: !!error,
27
+ hasTeams: teams.length > 0
28
+ }) : !error && !loading && /*#__PURE__*/_jsx(EmptyStateTeams, {
29
+ clickCreateTeam: handleCreateTeam
30
+ })]
31
+ });
32
+ });
33
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJtZW1vIiwidXNlVGVhbXMiLCJMYXlvdXRTZWN0aW9uIiwiSGVhZGVyVGVhbXMiLCJFbXB0eVN0YXRlVGVhbXMiLCJ1c2VHZXRUZWFtcyIsIkVycm9yVGVhbXMiLCJUYWJsZUNvbnRhaW5lciIsImpzeCIsIl9qc3giLCJqc3hzIiwiX2pzeHMiLCJNYWluVGVhbXNWaWV3IiwiX3VzZVRlYW1zIiwidGVhbXMiLCJfdXNlR2V0VGVhbXMiLCJsb2FkaW5nIiwiZXJyb3IiLCJoYW5kbGVDcmVhdGVUZWFtIiwiZXZlbnQiLCJDdXN0b21FdmVudCIsIndpbmRvdyIsImRpc3BhdGNoRXZlbnQiLCJjaGlsZHJlbiIsInNob3dDcmVhdGVCdXR0b24iLCJsZW5ndGgiLCJjbGlja0NyZWF0ZVRlYW0iLCJoYXNUZWFtcyJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb250YWluZXIvTWFpblZpZXcvTWFpblRlYW1zVmlldy50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgbWVtbyB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgdXNlVGVhbXMgfSBmcm9tICcuLi8uLi9jb250ZXh0L1RlYW1zQ29udGV4dCdcbmltcG9ydCB7IExheW91dFNlY3Rpb24gfSBmcm9tICcuLi8uLi9jb21wb25lbnRzL0xheW91dCdcbmltcG9ydCB7IEhlYWRlclRlYW1zIH0gZnJvbSAnLi4vLi4vY29tcG9uZW50cy9IZWFkZXJUZWFtcydcbmltcG9ydCB7IEVtcHR5U3RhdGVUZWFtcyB9IGZyb20gJy4uLy4uL2NvbXBvbmVudHMvRW1wdHlTdGF0ZVRlYW1zJ1xuaW1wb3J0IHsgdXNlR2V0VGVhbXMgfSBmcm9tICcuLi8uLi9ob29rcy91c2VHZXRUZWFtcydcbmltcG9ydCB7IEVycm9yVGVhbXMgfSBmcm9tICcuLi8uLi9jb21wb25lbnRzL0Vycm9yVGVhbXMnXG5pbXBvcnQgeyBUYWJsZUNvbnRhaW5lciB9IGZyb20gJy4uL1RhYmxlQ29udGFpbmVyL1RhYmxlQ29udGFpbmVyJ1xuXG5leHBvcnQgY29uc3QgTWFpblRlYW1zVmlldyA9IG1lbW8oKCkgPT4ge1xuICBjb25zdCB7IHRlYW1zIH0gPSB1c2VUZWFtcygpXG4gIGNvbnN0IHsgbG9hZGluZywgZXJyb3IgfSA9IHVzZUdldFRlYW1zKClcblxuICBjb25zdCBoYW5kbGVDcmVhdGVUZWFtID0gKCkgPT4ge1xuICAgIGNvbnN0IGV2ZW50ID0gbmV3IEN1c3RvbUV2ZW50KCdjcmVhdGVUZWFtJylcbiAgICB3aW5kb3cuZGlzcGF0Y2hFdmVudChldmVudClcbiAgfVxuXG4gIHJldHVybiAoXG4gICAgPExheW91dFNlY3Rpb24+XG4gICAgICA8SGVhZGVyVGVhbXMgc2hvd0NyZWF0ZUJ1dHRvbj17dGVhbXMubGVuZ3RoID4gMH0gY2xpY2tDcmVhdGVUZWFtPXtoYW5kbGVDcmVhdGVUZWFtfSAvPlxuICAgICAge2Vycm9yICYmIDxFcnJvclRlYW1zIC8+fVxuICAgICAge3RlYW1zLmxlbmd0aCA+IDAgPyAoXG4gICAgICAgIDxUYWJsZUNvbnRhaW5lciBsb2FkaW5nPXtsb2FkaW5nfSBlcnJvcj17ISFlcnJvcn0gaGFzVGVhbXM9e3RlYW1zLmxlbmd0aCA+IDB9IC8+XG4gICAgICApIDogKFxuICAgICAgICAhZXJyb3IgJiYgIWxvYWRpbmcgJiYgPEVtcHR5U3RhdGVUZWFtcyBjbGlja0NyZWF0ZVRlYW09e2hhbmRsZUNyZWF0ZVRlYW19IC8+XG4gICAgICApfVxuICAgICAgey8qIHtjdXJyZW50UGFnZSA8IHRvdGFsVGVhbXMgJiYgPFNob3dNb3JlIGNsaWNrU2hvd01vcmU9e2hhbmRsZUNsaWNrU2hvd01vcmV9IC8+fSAqL31cbiAgICA8L0xheW91dFNlY3Rpb24+XG4gIClcbn0pXG4iXSwibWFwcGluZ3MiOiJBQUFBLFNBQVNBLElBQUksUUFBUSxPQUFPO0FBQzVCLFNBQVNDLFFBQVEsUUFBUSw0QkFBNEI7QUFDckQsU0FBU0MsYUFBYSxRQUFRLHlCQUF5QjtBQUN2RCxTQUFTQyxXQUFXLFFBQVEsOEJBQThCO0FBQzFELFNBQVNDLGVBQWUsUUFBUSxrQ0FBa0M7QUFDbEUsU0FBU0MsV0FBVyxRQUFRLHlCQUF5QjtBQUNyRCxTQUFTQyxVQUFVLFFBQVEsNkJBQTZCO0FBQ3hELFNBQVNDLGNBQWMsUUFBUSxrQ0FBa0M7QUFBQSxTQUFBQyxHQUFBLElBQUFDLElBQUEsRUFBQUMsSUFBQSxJQUFBQyxLQUFBO0FBRWpFLE9BQU8sSUFBTUMsYUFBYSxnQkFBR1osSUFBSSxDQUFDLFlBQU07RUFDdEMsSUFBQWEsU0FBQSxHQUFrQlosUUFBUSxDQUFDLENBQUM7SUFBcEJhLEtBQUssR0FBQUQsU0FBQSxDQUFMQyxLQUFLO0VBQ2IsSUFBQUMsWUFBQSxHQUEyQlYsV0FBVyxDQUFDLENBQUM7SUFBaENXLE9BQU8sR0FBQUQsWUFBQSxDQUFQQyxPQUFPO0lBQUVDLEtBQUssR0FBQUYsWUFBQSxDQUFMRSxLQUFLO0VBRXRCLElBQU1DLGdCQUFnQixHQUFHLFNBQW5CQSxnQkFBZ0JBLENBQUEsRUFBUztJQUM3QixJQUFNQyxLQUFLLEdBQUcsSUFBSUMsV0FBVyxDQUFDLFlBQVksQ0FBQztJQUMzQ0MsTUFBTSxDQUFDQyxhQUFhLENBQUNILEtBQUssQ0FBQztFQUM3QixDQUFDO0VBRUQsb0JBQ0VSLEtBQUEsQ0FBQ1QsYUFBYTtJQUFBcUIsUUFBQSxnQkFDWmQsSUFBQSxDQUFDTixXQUFXO01BQUNxQixnQkFBZ0IsRUFBRVYsS0FBSyxDQUFDVyxNQUFNLEdBQUcsQ0FBRTtNQUFDQyxlQUFlLEVBQUVSO0lBQWlCLENBQUUsQ0FBQyxFQUNyRkQsS0FBSyxpQkFBSVIsSUFBQSxDQUFDSCxVQUFVLElBQUUsQ0FBQyxFQUN2QlEsS0FBSyxDQUFDVyxNQUFNLEdBQUcsQ0FBQyxnQkFDZmhCLElBQUEsQ0FBQ0YsY0FBYztNQUFDUyxPQUFPLEVBQUVBLE9BQVE7TUFBQ0MsS0FBSyxFQUFFLENBQUMsQ0FBQ0EsS0FBTTtNQUFDVSxRQUFRLEVBQUViLEtBQUssQ0FBQ1csTUFBTSxHQUFHO0lBQUUsQ0FBRSxDQUFDLEdBRWhGLENBQUNSLEtBQUssSUFBSSxDQUFDRCxPQUFPLGlCQUFJUCxJQUFBLENBQUNMLGVBQWU7TUFBQ3NCLGVBQWUsRUFBRVI7SUFBaUIsQ0FBRSxDQUM1RTtFQUFBLENBRVksQ0FBQztBQUVwQixDQUFDLENBQUMiLCJpZ25vcmVMaXN0IjpbXX0=
@@ -7,11 +7,12 @@ import { Tooltip } from '@projectcor/tooltipv2/lib/components/Tooltip';
7
7
  import { FileUpload } from '@projectcor/icons/lib/components/FileUpload';
8
8
  import { FiltersContainer } from '../Filters/FiltersContainer';
9
9
  import { useGetUserPositionFilter } from '../../hooks/useGetUserPositionFilter';
10
- import { useUsersQuery, useUsersEditPositions } from '../../context/UsersContext';
10
+ import { useUsersQuery, useUsersEditPositions, useUsers } from '../../context/UsersContext';
11
11
  import { TableContainer } from '../TableContainer/TableContainer';
12
12
  import { ModalEditUserPosition } from '../../components/ModalEditUserPosition';
13
13
  import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
14
14
  export var MainUsersView = /*#__PURE__*/memo(function MainUsersView() {
15
+ var _userInfo$permissions, _userInfo$permissions2;
15
16
  var _useTranslation = useTranslation('people'),
16
17
  t = _useTranslation.t;
17
18
  var _useUsersQuery = useUsersQuery(),
@@ -21,6 +22,8 @@ export var MainUsersView = /*#__PURE__*/memo(function MainUsersView() {
21
22
  users = _useUsersQuery.users,
22
23
  handleSetPositions = _useUsersQuery.handleSetPositions,
23
24
  positions = _useUsersQuery.positions;
25
+ var _useUsers = useUsers(),
26
+ userInfo = _useUsers.userInfo;
24
27
  var _useUsersEditPosition = useUsersEditPositions(),
25
28
  handleSetHasEditPositions = _useUsersEditPosition.handleSetHasEditPositions,
26
29
  hasEditPositions = _useUsersEditPosition.hasEditPositions,
@@ -81,7 +84,7 @@ export var MainUsersView = /*#__PURE__*/memo(function MainUsersView() {
81
84
  handleSetHasEditPositions(false);
82
85
  }, [handleSetHasEditPositions]);
83
86
  var handleGoToImport = useCallback(function () {
84
- window.location.href = '/users/import';
87
+ window.location.pathname = '/import/users';
85
88
  }, []);
86
89
  var handleGoToCreate = useCallback(function () {
87
90
  window.location.href = '/users/create';
@@ -91,82 +94,91 @@ export var MainUsersView = /*#__PURE__*/memo(function MainUsersView() {
91
94
  style: {
92
95
  display: 'flex',
93
96
  flexDirection: 'column',
94
- gap: '10px',
97
+ gap: '20px',
95
98
  width: '100%',
96
99
  height: '100%',
97
- paddingTop: '20px'
100
+ backgroundColor: 'white',
101
+ borderRadius: '6px',
102
+ padding: '12px'
98
103
  },
99
104
  children: [/*#__PURE__*/_jsxs("div", {
100
105
  style: {
101
- display: users !== null && users !== void 0 && users.length ? 'flex' : 'none',
102
- alignItems: 'center',
103
- justifyContent: 'space-between',
104
- position: 'sticky',
105
- top: 0,
106
- // backgroundColor: 'white',
107
- zIndex: 2,
108
- padding: '10px'
109
- },
110
- children: [/*#__PURE__*/_jsx(GroupByButton, {
111
- sections: groupBySections,
112
- sectionSelectedId: hasEditPositions ? 2 : 1,
113
- handleChangeSection: handleChangeSection,
114
- groupByTitle: "Vista",
115
- withTitle: true,
116
- withMinHeight: true
117
- }), hasEditPositions && (usersToEditPositions === null || usersToEditPositions === void 0 ? void 0 : usersToEditPositions.length) > 0 && /*#__PURE__*/_jsxs(CUButton, {
118
- variant: "outlined",
119
- size: "small",
120
- onClick: handleShowModalEditUserPosition,
121
- children: [t('users.editPositionTitle'), " (", usersToEditPositions.length, ")"]
122
- })]
123
- }), /*#__PURE__*/_jsxs("div", {
124
- style: {
106
+ backgroundColor: 'white',
125
107
  display: 'flex',
126
- alignItems: 'center',
127
- justifyContent: 'space-between',
128
- position: 'sticky',
129
- top: 40,
130
- // backgroundColor: 'white',
131
- zIndex: 2,
132
- padding: '10px'
108
+ flexDirection: 'column',
109
+ gap: '20px'
133
110
  },
134
- children: [/*#__PURE__*/_jsx(FiltersContainer, {
135
- handleGetUserPositionFilter: handleGetUserPositionFilter
111
+ children: [!!((_userInfo$permissions = userInfo.permissions.users) !== null && _userInfo$permissions !== void 0 && _userInfo$permissions.edit) && !window.hasCapacityPlanningFeatureAccess && !window.hasProjectManagementFeatureAccess && /*#__PURE__*/_jsxs("div", {
112
+ style: {
113
+ display: users !== null && users !== void 0 && users.length ? 'flex' : 'none',
114
+ alignItems: 'center',
115
+ justifyContent: 'space-between',
116
+ position: 'sticky',
117
+ top: 0,
118
+ zIndex: 2
119
+ // padding: '10px',
120
+ },
121
+ children: [/*#__PURE__*/_jsx(GroupByButton, {
122
+ sections: groupBySections,
123
+ sectionSelectedId: hasEditPositions ? 2 : 1,
124
+ handleChangeSection: handleChangeSection,
125
+ groupByTitle: "Vista",
126
+ withTitle: true,
127
+ withMinHeight: true
128
+ }), hasEditPositions && (usersToEditPositions === null || usersToEditPositions === void 0 ? void 0 : usersToEditPositions.length) > 0 && /*#__PURE__*/_jsxs(CUButton, {
129
+ variant: "outlined",
130
+ size: "small",
131
+ onClick: handleShowModalEditUserPosition,
132
+ children: [t('users.editPositionTitle'), " (", usersToEditPositions.length, ")"]
133
+ })]
136
134
  }), /*#__PURE__*/_jsxs("div", {
137
135
  style: {
138
136
  display: 'flex',
139
137
  alignItems: 'center',
140
- gap: '10px',
141
- justifyContent: 'center'
138
+ justifyContent: 'space-between',
139
+ position: 'sticky',
140
+ top: 40,
141
+ // backgroundColor: 'white',
142
+ zIndex: 2
143
+ // padding: '10px',
142
144
  },
143
- children: [/*#__PURE__*/_jsx(Tooltip, {
144
- title: t('users.exportUsers'),
145
- placement: "top",
146
- zIndex: "2002",
147
- children: /*#__PURE__*/_jsx("div", {
148
- style: {
149
- display: 'flex',
150
- alignItems: 'center',
151
- justifyContent: 'center'
152
- },
153
- children: /*#__PURE__*/_jsx(CUButton, {
154
- variant: "text",
155
- iconOnly: true,
156
- size: "small",
157
- onClick: handleGoToImport,
158
- children: /*#__PURE__*/_jsx(FileUpload, {
159
- width: 20,
160
- height: 20,
161
- color: "inherit"
145
+ children: [/*#__PURE__*/_jsx(FiltersContainer, {
146
+ handleGetUserPositionFilter: handleGetUserPositionFilter
147
+ }), /*#__PURE__*/_jsxs("div", {
148
+ style: {
149
+ display: 'flex',
150
+ alignItems: 'center',
151
+ gap: '10px',
152
+ justifyContent: 'center'
153
+ },
154
+ children: [!!window.hasUserImportFeatureAccess && /*#__PURE__*/_jsx(Tooltip, {
155
+ title: t('users.importUsers'),
156
+ placement: "top",
157
+ zIndex: "2002",
158
+ children: /*#__PURE__*/_jsx("div", {
159
+ style: {
160
+ display: 'flex',
161
+ alignItems: 'center',
162
+ justifyContent: 'center'
163
+ },
164
+ children: /*#__PURE__*/_jsx(CUButton, {
165
+ variant: "text",
166
+ iconOnly: true,
167
+ size: "small",
168
+ onClick: handleGoToImport,
169
+ children: /*#__PURE__*/_jsx(FileUpload, {
170
+ width: 20,
171
+ height: 20,
172
+ color: "inherit"
173
+ })
162
174
  })
163
175
  })
164
- })
165
- }), /*#__PURE__*/_jsx(CUButton, {
166
- variant: "contained",
167
- size: "small",
168
- onClick: handleGoToCreate,
169
- children: t('users.createUser')
176
+ }), !!((_userInfo$permissions2 = userInfo.permissions.users) !== null && _userInfo$permissions2 !== void 0 && _userInfo$permissions2.create) && /*#__PURE__*/_jsx(CUButton, {
177
+ variant: "contained",
178
+ size: "small",
179
+ onClick: handleGoToCreate,
180
+ children: t('users.createUser')
181
+ })]
170
182
  })]
171
183
  })]
172
184
  }), /*#__PURE__*/_jsx(TableContainer, {
@@ -181,4 +193,4 @@ export var MainUsersView = /*#__PURE__*/memo(function MainUsersView() {
181
193
  })]
182
194
  });
183
195
  });
184
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["memo","useState","useRef","useEffect","useCallback","useMemo","useTranslation","GroupByButton","CUButton","Tooltip","FileUpload","FiltersContainer","useGetUserPositionFilter","useUsersQuery","useUsersEditPositions","TableContainer","ModalEditUserPosition","jsx","_jsx","jsxs","_jsxs","Fragment","_Fragment","MainUsersView","_useTranslation","t","_useUsersQuery","handleGetUsers","loading","error","users","handleSetPositions","positions","_useUsersEditPosition","handleSetHasEditPositions","hasEditPositions","usersToEditPositions","_useState","_useState2","_slicedToArray","showModalEditUserPosition","setShowModalEditUserPosition","_useGetUserPositionFi","handleGetUserPositionFilter","positionLoading","positionError","positionData","data","hasFetchedPositions","current","length","userPositionsFilter","mappedPositions","map","position","id","label","name","categoryName","handleChangePage","page","groupBySections","title","handleChangeSection","prop","handleShowModalEditUserPosition","handleCloseModalEditUserPosition","handleEditPositionsSuccess","handleGoToImport","window","location","href","handleGoToCreate","children","style","display","flexDirection","gap","width","height","paddingTop","alignItems","justifyContent","top","zIndex","padding","sections","sectionSelectedId","groupByTitle","withTitle","withMinHeight","variant","size","onClick","placement","iconOnly","color","hasUsers","handleCloseModal","onEditSuccess"],"sources":["../../../src/container/MainView/MainUsersView.tsx"],"sourcesContent":["import { memo, useState, useRef, useEffect, useCallback, useMemo } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { GroupByButton } from '@projectcor/group-by-button/lib/components/GroupByButton'\nimport { CUButton } from '@projectcor/button/lib/components/CUButton'\nimport { Tooltip } from '@projectcor/tooltipv2/lib/components/Tooltip'\nimport { FileUpload } from '@projectcor/icons/lib/components/FileUpload'\nimport { FiltersContainer } from '../Filters/FiltersContainer'\nimport { useGetUserPositionFilter } from '../../hooks/useGetUserPositionFilter'\nimport { useUsersQuery, useUsersEditPositions } from '../../context/UsersContext'\nimport { TableContainer } from '../TableContainer/TableContainer'\nimport { ModalEditUserPosition } from '../../components/ModalEditUserPosition'\n\nexport const MainUsersView = memo(function MainUsersView() {\n  const { t } = useTranslation('people')\n  const { handleGetUsers, loading, error, users, handleSetPositions, positions } = useUsersQuery()\n  const { handleSetHasEditPositions, hasEditPositions, usersToEditPositions } = useUsersEditPositions()\n  const [showModalEditUserPosition, setShowModalEditUserPosition] = useState(false)\n  const {\n    handleGetUserPositionFilter,\n    loading: positionLoading,\n    error: positionError,\n    data: positionData,\n  } = useGetUserPositionFilter()\n  const hasFetchedPositions = useRef(false)\n\n  useEffect(() => {\n    if (!hasFetchedPositions.current && !positions?.length) {\n      hasFetchedPositions.current = true\n      handleGetUserPositionFilter('')\n    }\n  }, [handleGetUserPositionFilter, positions])\n\n  useEffect(() => {\n    if (positionData?.userPositionsFilter && !positionLoading && !positionError) {\n      const mappedPositions = positionData.userPositionsFilter.data.map(position => ({\n        id: position.id,\n        label: position.name,\n        categoryName: position.categoryName,\n      }))\n      handleSetPositions(mappedPositions)\n    }\n  }, [positionData, positionLoading, positionError, handleSetPositions])\n\n  const handleChangePage = useCallback(\n    (page: number) => {\n      handleGetUsers({ page })\n    },\n    [handleGetUsers]\n  )\n\n  const groupBySections = useMemo(\n    () => [\n      { id: 1, title: t('users.view') },\n      { id: 2, title: t('users.editPositionTitle') },\n    ],\n    [t]\n  )\n\n  const handleChangeSection = useCallback(\n    (prop: any) => {\n      handleSetHasEditPositions(prop.id === 2)\n    },\n    [handleSetHasEditPositions]\n  )\n\n  const handleShowModalEditUserPosition = useCallback(() => {\n    setShowModalEditUserPosition(true)\n  }, [])\n\n  const handleCloseModalEditUserPosition = useCallback(() => {\n    setShowModalEditUserPosition(false)\n  }, [])\n\n  const handleEditPositionsSuccess = useCallback(() => {\n    setShowModalEditUserPosition(false)\n    handleSetHasEditPositions(false)\n  }, [handleSetHasEditPositions])\n\n  const handleGoToImport = useCallback(() => {\n    window.location.href = '/users/import'\n  }, [])\n\n  const handleGoToCreate = useCallback(() => {\n    window.location.href = '/users/create'\n  }, [])\n\n  return (\n    <>\n      <div\n        style={{\n          display: 'flex',\n          flexDirection: 'column',\n          gap: '10px',\n          width: '100%',\n          height: '100%',\n          paddingTop: '20px',\n        }}\n      >\n        <div\n          style={{\n            display: users?.length ? 'flex' : 'none',\n            alignItems: 'center',\n            justifyContent: 'space-between',\n            position: 'sticky',\n            top: 0,\n            // backgroundColor: 'white',\n            zIndex: 2,\n            padding: '10px',\n          }}\n        >\n          <GroupByButton\n            sections={groupBySections}\n            sectionSelectedId={hasEditPositions ? 2 : 1}\n            handleChangeSection={handleChangeSection}\n            groupByTitle=\"Vista\"\n            withTitle\n            withMinHeight\n          />\n          {hasEditPositions && usersToEditPositions?.length > 0 && (\n            <CUButton variant=\"outlined\" size=\"small\" onClick={handleShowModalEditUserPosition}>\n              {t('users.editPositionTitle')} ({usersToEditPositions.length})\n            </CUButton>\n          )}\n        </div>\n        <div\n          style={{\n            display: 'flex',\n            alignItems: 'center',\n            justifyContent: 'space-between',\n            position: 'sticky',\n            top: 40,\n            // backgroundColor: 'white',\n            zIndex: 2,\n            padding: '10px',\n          }}\n        >\n          <FiltersContainer handleGetUserPositionFilter={handleGetUserPositionFilter} />\n          <div style={{ display: 'flex', alignItems: 'center', gap: '10px', justifyContent: 'center' }}>\n            <Tooltip title={t('users.exportUsers')} placement=\"top\" zIndex=\"2002\">\n              <div style={{ display: 'flex', alignItems: 'center', justifyContent: 'center' }}>\n                <CUButton variant=\"text\" iconOnly size=\"small\" onClick={handleGoToImport}>\n                  <FileUpload width={20} height={20} color=\"inherit\" />\n                </CUButton>\n              </div>\n            </Tooltip>\n            <CUButton variant=\"contained\" size=\"small\" onClick={handleGoToCreate}>\n              {t('users.createUser')}\n            </CUButton>\n          </div>\n        </div>\n        <TableContainer\n          handleChangePage={handleChangePage}\n          loading={loading}\n          error={error}\n          hasUsers={!!users?.length}\n        />\n      </div>\n      {showModalEditUserPosition && (\n        <ModalEditUserPosition\n          handleCloseModal={handleCloseModalEditUserPosition}\n          onEditSuccess={handleEditPositionsSuccess}\n        />\n      )}\n    </>\n  )\n})\n"],"mappings":"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","ignoreList":[]}
196
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["memo","useState","useRef","useEffect","useCallback","useMemo","useTranslation","GroupByButton","CUButton","Tooltip","FileUpload","FiltersContainer","useGetUserPositionFilter","useUsersQuery","useUsersEditPositions","useUsers","TableContainer","ModalEditUserPosition","jsx","_jsx","jsxs","_jsxs","Fragment","_Fragment","MainUsersView","_userInfo$permissions","_userInfo$permissions2","_useTranslation","t","_useUsersQuery","handleGetUsers","loading","error","users","handleSetPositions","positions","_useUsers","userInfo","_useUsersEditPosition","handleSetHasEditPositions","hasEditPositions","usersToEditPositions","_useState","_useState2","_slicedToArray","showModalEditUserPosition","setShowModalEditUserPosition","_useGetUserPositionFi","handleGetUserPositionFilter","positionLoading","positionError","positionData","data","hasFetchedPositions","current","length","userPositionsFilter","mappedPositions","map","position","id","label","name","categoryName","handleChangePage","page","groupBySections","title","handleChangeSection","prop","handleShowModalEditUserPosition","handleCloseModalEditUserPosition","handleEditPositionsSuccess","handleGoToImport","window","location","pathname","handleGoToCreate","href","children","style","display","flexDirection","gap","width","height","backgroundColor","borderRadius","padding","permissions","edit","hasCapacityPlanningFeatureAccess","hasProjectManagementFeatureAccess","alignItems","justifyContent","top","zIndex","sections","sectionSelectedId","groupByTitle","withTitle","withMinHeight","variant","size","onClick","hasUserImportFeatureAccess","placement","iconOnly","color","create","hasUsers","handleCloseModal","onEditSuccess"],"sources":["../../../src/container/MainView/MainUsersView.tsx"],"sourcesContent":["import { memo, useState, useRef, useEffect, useCallback, useMemo } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { GroupByButton } from '@projectcor/group-by-button/lib/components/GroupByButton'\nimport { CUButton } from '@projectcor/button/lib/components/CUButton'\nimport { Tooltip } from '@projectcor/tooltipv2/lib/components/Tooltip'\nimport { FileUpload } from '@projectcor/icons/lib/components/FileUpload'\nimport { FiltersContainer } from '../Filters/FiltersContainer'\nimport { useGetUserPositionFilter } from '../../hooks/useGetUserPositionFilter'\nimport { useUsersQuery, useUsersEditPositions, useUsers } from '../../context/UsersContext'\nimport { TableContainer } from '../TableContainer/TableContainer'\nimport { ModalEditUserPosition } from '../../components/ModalEditUserPosition'\n\nexport const MainUsersView = memo(function MainUsersView() {\n  const { t } = useTranslation('people')\n  const { handleGetUsers, loading, error, users, handleSetPositions, positions } = useUsersQuery()\n  const { userInfo } = useUsers()\n  const { handleSetHasEditPositions, hasEditPositions, usersToEditPositions } = useUsersEditPositions()\n  const [showModalEditUserPosition, setShowModalEditUserPosition] = useState(false)\n  const {\n    handleGetUserPositionFilter,\n    loading: positionLoading,\n    error: positionError,\n    data: positionData,\n  } = useGetUserPositionFilter()\n  const hasFetchedPositions = useRef(false)\n\n  useEffect(() => {\n    if (!hasFetchedPositions.current && !positions?.length) {\n      hasFetchedPositions.current = true\n      handleGetUserPositionFilter('')\n    }\n  }, [handleGetUserPositionFilter, positions])\n\n  useEffect(() => {\n    if (positionData?.userPositionsFilter && !positionLoading && !positionError) {\n      const mappedPositions = positionData.userPositionsFilter.data.map(position => ({\n        id: position.id,\n        label: position.name,\n        categoryName: position.categoryName,\n      }))\n      handleSetPositions(mappedPositions)\n    }\n  }, [positionData, positionLoading, positionError, handleSetPositions])\n\n  const handleChangePage = useCallback(\n    (page: number) => {\n      handleGetUsers({ page })\n    },\n    [handleGetUsers]\n  )\n\n  const groupBySections = useMemo(\n    () => [\n      { id: 1, title: t('users.view') },\n      { id: 2, title: t('users.editPositionTitle') },\n    ],\n    [t]\n  )\n\n  const handleChangeSection = useCallback(\n    (prop: any) => {\n      handleSetHasEditPositions(prop.id === 2)\n    },\n    [handleSetHasEditPositions]\n  )\n\n  const handleShowModalEditUserPosition = useCallback(() => {\n    setShowModalEditUserPosition(true)\n  }, [])\n\n  const handleCloseModalEditUserPosition = useCallback(() => {\n    setShowModalEditUserPosition(false)\n  }, [])\n\n  const handleEditPositionsSuccess = useCallback(() => {\n    setShowModalEditUserPosition(false)\n    handleSetHasEditPositions(false)\n  }, [handleSetHasEditPositions])\n\n  const handleGoToImport = useCallback(() => {\n    window.location.pathname = '/import/users'\n  }, [])\n\n  const handleGoToCreate = useCallback(() => {\n    window.location.href = '/users/create'\n  }, [])\n\n  return (\n    <>\n      <div\n        style={{\n          display: 'flex',\n          flexDirection: 'column',\n          gap: '20px',\n          width: '100%',\n          height: '100%',\n          backgroundColor: 'white',\n          borderRadius: '6px',\n          padding: '12px',\n        }}\n      >\n        <div style={{ backgroundColor: 'white', display: 'flex', flexDirection: 'column', gap: '20px' }}>\n          {!!userInfo.permissions.users?.edit &&\n            !window.hasCapacityPlanningFeatureAccess &&\n            !window.hasProjectManagementFeatureAccess && (\n              <div\n                style={{\n                  display: users?.length ? 'flex' : 'none',\n                  alignItems: 'center',\n                  justifyContent: 'space-between',\n                  position: 'sticky',\n                  top: 0,\n                  zIndex: 2,\n                  // padding: '10px',\n                }}\n              >\n                <GroupByButton\n                  sections={groupBySections}\n                  sectionSelectedId={hasEditPositions ? 2 : 1}\n                  handleChangeSection={handleChangeSection}\n                  groupByTitle=\"Vista\"\n                  withTitle\n                  withMinHeight\n                />\n                {hasEditPositions && usersToEditPositions?.length > 0 && (\n                  <CUButton variant=\"outlined\" size=\"small\" onClick={handleShowModalEditUserPosition}>\n                    {t('users.editPositionTitle')} ({usersToEditPositions.length})\n                  </CUButton>\n                )}\n              </div>\n            )}\n          <div\n            style={{\n              display: 'flex',\n              alignItems: 'center',\n              justifyContent: 'space-between',\n              position: 'sticky',\n              top: 40,\n              // backgroundColor: 'white',\n              zIndex: 2,\n              // padding: '10px',\n            }}\n          >\n            <FiltersContainer handleGetUserPositionFilter={handleGetUserPositionFilter} />\n            <div style={{ display: 'flex', alignItems: 'center', gap: '10px', justifyContent: 'center' }}>\n              {!!window.hasUserImportFeatureAccess && (\n                <Tooltip title={t('users.importUsers')} placement=\"top\" zIndex=\"2002\">\n                  <div style={{ display: 'flex', alignItems: 'center', justifyContent: 'center' }}>\n                    <CUButton variant=\"text\" iconOnly size=\"small\" onClick={handleGoToImport}>\n                      <FileUpload width={20} height={20} color=\"inherit\" />\n                    </CUButton>\n                  </div>\n                </Tooltip>\n              )}\n              {!!userInfo.permissions.users?.create && (\n                <CUButton variant=\"contained\" size=\"small\" onClick={handleGoToCreate}>\n                  {t('users.createUser')}\n                </CUButton>\n              )}\n            </div>\n          </div>\n        </div>\n        <TableContainer\n          handleChangePage={handleChangePage}\n          loading={loading}\n          error={error}\n          hasUsers={!!users?.length}\n        />\n      </div>\n      {showModalEditUserPosition && (\n        <ModalEditUserPosition\n          handleCloseModal={handleCloseModalEditUserPosition}\n          onEditSuccess={handleEditPositionsSuccess}\n        />\n      )}\n    </>\n  )\n})\n"],"mappings":"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","ignoreList":[]}
@@ -5,14 +5,6 @@ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t =
5
5
  /* eslint-disable react/require-default-props */
6
6
  import { useEffect, memo, useState, Suspense, lazy, useCallback, useRef } from 'react';
7
7
  import { useTranslation } from 'react-i18next';
8
- import { TableContainer } from '../TableContainer/TableContainer';
9
- import { useTeams } from '../../context/TeamsContext';
10
- import { LayoutSection } from '../../components/Layout';
11
- import { HeaderTeams } from '../../components/HeaderTeams';
12
- import { EmptyStateTeams } from '../../components/EmptyStateTeams';
13
- import { useGetTeams } from '../../hooks/useGetTeams';
14
- import { ErrorTeams } from '../../components/ErrorTeams';
15
- import { ShowMore } from '../../components/ShowMore';
16
8
  import { LoaderComponent } from '../../components/Loading/LoadingComponent';
17
9
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
18
10
  var LazySnackbarComponent = /*#__PURE__*/lazy(function () {
@@ -29,38 +21,24 @@ var LazyMainUsersView = /*#__PURE__*/lazy(function () {
29
21
  };
30
22
  });
31
23
  });
32
- export var MainTeamsView = /*#__PURE__*/memo(function () {
33
- var _useTeams = useTeams(),
34
- teams = _useTeams.teams,
35
- totalTeams = _useTeams.totalTeams,
36
- currentPage = _useTeams.currentPage,
37
- setCurrentPage = _useTeams.setCurrentPage;
38
- var _useGetTeams = useGetTeams(),
39
- loading = _useGetTeams.loading,
40
- error = _useGetTeams.error;
41
- var handleCreateTeam = function handleCreateTeam() {
42
- var event = new CustomEvent('createTeam');
43
- window.dispatchEvent(event);
44
- };
45
- var handleClickShowMore = function handleClickShowMore() {
46
- setCurrentPage(currentPage + 1);
47
- };
48
- return /*#__PURE__*/_jsxs(LayoutSection, {
49
- children: [/*#__PURE__*/_jsx(HeaderTeams, {
50
- showCreateButton: teams.length > 0,
51
- clickCreateTeam: handleCreateTeam
52
- }), error && /*#__PURE__*/_jsx(ErrorTeams, {}), teams.length > 0 ? /*#__PURE__*/_jsx(TableContainer, {
53
- loading: loading
54
- }) : /*#__PURE__*/_jsx(EmptyStateTeams, {
55
- clickCreateTeam: handleCreateTeam
56
- }), currentPage < totalTeams && /*#__PURE__*/_jsx(ShowMore, {
57
- clickShowMore: handleClickShowMore
58
- })]
24
+ var LazyMainTeamsView = /*#__PURE__*/lazy(function () {
25
+ return import('./MainTeamsView').then(function (module) {
26
+ return {
27
+ "default": module.MainTeamsView
28
+ };
59
29
  });
60
30
  });
61
31
  export var MainPositionsView = /*#__PURE__*/memo(function () {
32
+ useEffect(function () {
33
+ if (typeof window.showUserTypeAbm === 'function') {
34
+ window.showUserTypeAbm();
35
+ }
36
+ return function () {
37
+ if (typeof window.unMountUserTypeAbm === 'function') window.unMountUserTypeAbm();
38
+ };
39
+ }, []);
62
40
  return /*#__PURE__*/_jsx("div", {
63
- children: "MainPositionsView"
41
+ id: "container_project_team_select"
64
42
  });
65
43
  });
66
44
  export var MainLeavesView = /*#__PURE__*/memo(function () {
@@ -72,7 +50,7 @@ export var MainLeavesView = /*#__PURE__*/memo(function () {
72
50
  // TODO: Convertir los componentes de las vistas (MainUsersView, MainTeamsView, MainPositionsView, MainLeavesView) a cargas lazy utilizando React.lazy y Suspense para mejorar el performance
73
51
  var ViewByType = {
74
52
  users: LazyMainUsersView,
75
- teams: MainTeamsView,
53
+ teams: LazyMainTeamsView,
76
54
  positions: MainPositionsView,
77
55
  leaves: MainLeavesView
78
56
  };
@@ -98,7 +76,13 @@ export var MainView = /*#__PURE__*/memo(function (_ref) {
98
76
  deleteUser: '',
99
77
  errorUpdateUserPositions: '',
100
78
  errorUnblockUser: '',
101
- errorDeleteUser: ''
79
+ errorDeleteUser: '',
80
+ unassignUserFromTeam: '',
81
+ errorMessage: '',
82
+ assignUserToTeam: '',
83
+ updateTeam: '',
84
+ deleteTeam: '',
85
+ createTeam: ''
102
86
  });
103
87
  messageByTypeRef.current = {
104
88
  updateUserPositions: t('snackbar.updateUserPositions'),
@@ -106,7 +90,13 @@ export var MainView = /*#__PURE__*/memo(function (_ref) {
106
90
  deleteUser: t('snackbar.deleteUser'),
107
91
  errorUpdateUserPositions: t('snackbar.errorUpdateUserPositions'),
108
92
  errorUnblockUser: t('snackbar.errorUnblockUser'),
109
- errorDeleteUser: t('snackbar.errorDeleteUser')
93
+ errorDeleteUser: t('snackbar.errorDeleteUser'),
94
+ unassignUserFromTeam: t('snackbar.unassignUserFromTeam'),
95
+ errorMessage: t('error.errorMessage'),
96
+ assignUserToTeam: t('snackbar.assignUserToTeam'),
97
+ updateTeam: t('snackbar.updateTeam'),
98
+ deleteTeam: t('snackbar.deleteTeam'),
99
+ createTeam: t('snackbar.createTeam')
110
100
  };
111
101
  var handleSetSnackbarProps = useCallback(function (event) {
112
102
  var _messageByTypeRef$cur;
@@ -146,4 +136,4 @@ export var MainView = /*#__PURE__*/memo(function (_ref) {
146
136
  }))]
147
137
  });
148
138
  });
149
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["useEffect","memo","useState","Suspense","lazy","useCallback","useRef","useTranslation","TableContainer","useTeams","LayoutSection","HeaderTeams","EmptyStateTeams","useGetTeams","ErrorTeams","ShowMore","LoaderComponent","jsx","_jsx","jsxs","_jsxs","LazySnackbarComponent","then","module","SnackbarComponent","LazyMainUsersView","MainUsersView","MainTeamsView","_useTeams","teams","totalTeams","currentPage","setCurrentPage","_useGetTeams","loading","error","handleCreateTeam","event","CustomEvent","window","dispatchEvent","handleClickShowMore","children","showCreateButton","length","clickCreateTeam","clickShowMore","MainPositionsView","MainLeavesView","ViewByType","users","positions","leaves","MainView","_ref","_ref$view","view","_useTranslation","t","View","_useState","severity","show","autoHideDuration","message","hideBackdrop","_useState2","_slicedToArray","snackbarProps","setSnabarProps","messageByTypeRef","updateUserPositions","unblockUser","deleteUser","errorUpdateUserPositions","errorUnblockUser","errorDeleteUser","current","handleSetSnackbarProps","_messageByTypeRef$cur","_event$detail","detail","typeMessage","prev","_objectSpread","handleCloseSnackbar","listener","e","addEventListener","removeEventListener","fallback","onClose"],"sources":["../../../src/container/MainView/MainView.tsx"],"sourcesContent":["/* eslint-disable react/require-default-props */\nimport { useEffect, memo, useState, Suspense, lazy, useCallback, useRef } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { ViewType } from '../../types/userType'\nimport { FiltersContainer } from '../Filters/FiltersContainer'\nimport { TableContainer } from '../TableContainer/TableContainer'\nimport { useUsers } from '../../context/UsersContext'\nimport { useTeams } from '../../context/TeamsContext'\nimport { LayoutSection } from '../../components/Layout'\nimport { HeaderTeams } from '../../components/HeaderTeams'\nimport { EmptyStateTeams } from '../../components/EmptyStateTeams'\nimport { useGetTeams } from '../../hooks/useGetTeams'\nimport { LoaderTeams } from '../../components/Loader'\nimport { ErrorTeams } from '../../components/ErrorTeams'\nimport { ShowMore } from '../../components/ShowMore'\nimport { LoaderComponent } from '../../components/Loading/LoadingComponent'\n\nconst LazySnackbarComponent = lazy(() =>\n  import('../../components/Snackbar/Snackbar').then(module => ({ default: module.SnackbarComponent }))\n)\n\nconst LazyMainUsersView = lazy(() => import('./MainUsersView').then(module => ({ default: module.MainUsersView })))\n\nexport const MainTeamsView = memo(() => {\n  const { teams, totalTeams, currentPage, setCurrentPage } = useTeams()\n  const { loading, error } = useGetTeams()\n\n  const handleCreateTeam = () => {\n    const event = new CustomEvent('createTeam')\n    window.dispatchEvent(event)\n  }\n\n  const handleClickShowMore = () => {\n    setCurrentPage(currentPage + 1)\n  }\n\n  return (\n    <LayoutSection>\n      <HeaderTeams showCreateButton={teams.length > 0} clickCreateTeam={handleCreateTeam} />\n      {error && <ErrorTeams />}\n      {teams.length > 0 ? <TableContainer loading={loading} /> : <EmptyStateTeams clickCreateTeam={handleCreateTeam} />}\n      {currentPage < totalTeams && <ShowMore clickShowMore={handleClickShowMore} />}\n    </LayoutSection>\n  )\n})\n\nexport const MainPositionsView = memo(() => {\n  return <div>MainPositionsView</div>\n})\n\nexport const MainLeavesView = memo(() => {\n  return <div>MainLeavesView</div>\n})\n\n// TODO: Convertir los componentes de las vistas (MainUsersView, MainTeamsView, MainPositionsView, MainLeavesView) a cargas lazy utilizando React.lazy y Suspense para mejorar el performance\nconst ViewByType = {\n  users: LazyMainUsersView,\n  teams: MainTeamsView,\n  positions: MainPositionsView,\n  leaves: MainLeavesView,\n}\n\nexport const MainView = memo(({ view = 'users' }: { view?: ViewType }) => {\n  const { t } = useTranslation('people')\n  const View = ViewByType[view as ViewType]\n  const [snackbarProps, setSnabarProps] = useState({\n    severity: 'error',\n    show: false,\n    autoHideDuration: 3000,\n    message: '',\n    hideBackdrop: false,\n  })\n\n  const messageByTypeRef = useRef({\n    updateUserPositions: '',\n    unblockUser: '',\n    deleteUser: '',\n    errorUpdateUserPositions: '',\n    errorUnblockUser: '',\n    errorDeleteUser: '',\n  } as Record<string, string>)\n  messageByTypeRef.current = {\n    updateUserPositions: t('snackbar.updateUserPositions'),\n    unblockUser: t('snackbar.unblockUser'),\n    deleteUser: t('snackbar.deleteUser'),\n    errorUpdateUserPositions: t('snackbar.errorUpdateUserPositions'),\n    errorUnblockUser: t('snackbar.errorUnblockUser'),\n    errorDeleteUser: t('snackbar.errorDeleteUser'),\n  }\n\n  const handleSetSnackbarProps = useCallback(\n    (event: CustomEvent<{ typeMessage: string; severity: string; show: boolean }>) => {\n      const { typeMessage, severity, show } = event.detail\n      const message = messageByTypeRef.current[typeMessage] ?? ''\n      setSnabarProps(prev => ({\n        ...prev,\n        message,\n        severity,\n        show,\n      }))\n    },\n    []\n  )\n\n  const handleCloseSnackbar = useCallback(() => {\n    setSnabarProps(prev => ({ ...prev, show: false }))\n  }, [])\n\n  useEffect(() => {\n    const listener = (e: Event) =>\n      handleSetSnackbarProps(e as CustomEvent<{ typeMessage: string; severity: string; show: boolean }>)\n    window.addEventListener('snackbar', listener)\n    return () => window.removeEventListener('snackbar', listener)\n  }, [handleSetSnackbarProps])\n\n  return (\n    <Suspense fallback={<LoaderComponent />}>\n      <View />\n      {snackbarProps.show && <LazySnackbarComponent {...snackbarProps} onClose={handleCloseSnackbar} />}\n    </Suspense>\n  )\n})\n"],"mappings":"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","ignoreList":[]}
139
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["useEffect","memo","useState","Suspense","lazy","useCallback","useRef","useTranslation","LoaderComponent","jsx","_jsx","jsxs","_jsxs","LazySnackbarComponent","then","module","SnackbarComponent","LazyMainUsersView","MainUsersView","LazyMainTeamsView","MainTeamsView","MainPositionsView","window","showUserTypeAbm","unMountUserTypeAbm","id","MainLeavesView","children","ViewByType","users","teams","positions","leaves","MainView","_ref","_ref$view","view","_useTranslation","t","View","_useState","severity","show","autoHideDuration","message","hideBackdrop","_useState2","_slicedToArray","snackbarProps","setSnabarProps","messageByTypeRef","updateUserPositions","unblockUser","deleteUser","errorUpdateUserPositions","errorUnblockUser","errorDeleteUser","unassignUserFromTeam","errorMessage","assignUserToTeam","updateTeam","deleteTeam","createTeam","current","handleSetSnackbarProps","event","_messageByTypeRef$cur","_event$detail","detail","typeMessage","prev","_objectSpread","handleCloseSnackbar","listener","e","addEventListener","removeEventListener","fallback","onClose"],"sources":["../../../src/container/MainView/MainView.tsx"],"sourcesContent":["/* eslint-disable react/require-default-props */\nimport { useEffect, memo, useState, Suspense, lazy, useCallback, useRef } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { ViewType } from '../../types/userType'\nimport { LoaderComponent } from '../../components/Loading/LoadingComponent'\n\nconst LazySnackbarComponent = lazy(() =>\n  import('../../components/Snackbar/Snackbar').then(module => ({ default: module.SnackbarComponent }))\n)\n\nconst LazyMainUsersView = lazy(() => import('./MainUsersView').then(module => ({ default: module.MainUsersView })))\n\nconst LazyMainTeamsView = lazy(() => import('./MainTeamsView').then(module => ({ default: module.MainTeamsView })))\n\nexport const MainPositionsView = memo(() => {\n  useEffect(() => {\n    if (typeof window.showUserTypeAbm === 'function') {\n      window.showUserTypeAbm()\n    }\n\n    return () => {\n      if (typeof window.unMountUserTypeAbm === 'function') window.unMountUserTypeAbm()\n    }\n  }, [])\n  return <div id=\"container_project_team_select\" />\n})\n\nexport const MainLeavesView = memo(() => {\n  return <div>MainLeavesView</div>\n})\n\n// TODO: Convertir los componentes de las vistas (MainUsersView, MainTeamsView, MainPositionsView, MainLeavesView) a cargas lazy utilizando React.lazy y Suspense para mejorar el performance\nconst ViewByType = {\n  users: LazyMainUsersView,\n  teams: LazyMainTeamsView,\n  positions: MainPositionsView,\n  leaves: MainLeavesView,\n}\n\nexport const MainView = memo(({ view = 'users' }: { view?: ViewType }) => {\n  const { t } = useTranslation('people')\n  const View = ViewByType[view as ViewType]\n  const [snackbarProps, setSnabarProps] = useState({\n    severity: 'error',\n    show: false,\n    autoHideDuration: 3000,\n    message: '',\n    hideBackdrop: false,\n  })\n\n  const messageByTypeRef = useRef({\n    updateUserPositions: '',\n    unblockUser: '',\n    deleteUser: '',\n    errorUpdateUserPositions: '',\n    errorUnblockUser: '',\n    errorDeleteUser: '',\n    unassignUserFromTeam: '',\n    errorMessage: '',\n    assignUserToTeam: '',\n    updateTeam: '',\n    deleteTeam: '',\n    createTeam: '',\n  } as Record<string, string>)\n  messageByTypeRef.current = {\n    updateUserPositions: t('snackbar.updateUserPositions'),\n    unblockUser: t('snackbar.unblockUser'),\n    deleteUser: t('snackbar.deleteUser'),\n    errorUpdateUserPositions: t('snackbar.errorUpdateUserPositions'),\n    errorUnblockUser: t('snackbar.errorUnblockUser'),\n    errorDeleteUser: t('snackbar.errorDeleteUser'),\n    unassignUserFromTeam: t('snackbar.unassignUserFromTeam'),\n    errorMessage: t('error.errorMessage'),\n    assignUserToTeam: t('snackbar.assignUserToTeam'),\n    updateTeam: t('snackbar.updateTeam'),\n    deleteTeam: t('snackbar.deleteTeam'),\n    createTeam: t('snackbar.createTeam'),\n  }\n\n  const handleSetSnackbarProps = useCallback(\n    (event: CustomEvent<{ typeMessage: string; severity: string; show: boolean }>) => {\n      const { typeMessage, severity, show } = event.detail\n      const message = messageByTypeRef.current[typeMessage] ?? ''\n      setSnabarProps(prev => ({\n        ...prev,\n        message,\n        severity,\n        show,\n      }))\n    },\n    []\n  )\n\n  const handleCloseSnackbar = useCallback(() => {\n    setSnabarProps(prev => ({ ...prev, show: false }))\n  }, [])\n\n  useEffect(() => {\n    const listener = (e: Event) =>\n      handleSetSnackbarProps(e as CustomEvent<{ typeMessage: string; severity: string; show: boolean }>)\n    window.addEventListener('snackbar', listener)\n    return () => window.removeEventListener('snackbar', listener)\n  }, [handleSetSnackbarProps])\n\n  return (\n    <Suspense fallback={<LoaderComponent />}>\n      <View />\n      {snackbarProps.show && <LazySnackbarComponent {...snackbarProps} onClose={handleCloseSnackbar} />}\n    </Suspense>\n  )\n})\n"],"mappings":"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","ignoreList":[]}