@projectcor/people-microfront 1.0.2-1 → 1.0.2-3
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/lib/components/Table/Row/Row.styles.js +16 -10
- package/lib/components/Table/TeamRow/AddMemberModal/AddMemberModal.js +65 -0
- package/lib/components/Table/TeamRow/AddMemberModal/AddMemberModal.styles.js +38 -0
- package/lib/components/Table/TeamRow/AddMemberModal/index.js +2 -0
- package/lib/components/Table/TeamRow/AddUsers/AddUsers.js +194 -0
- package/lib/components/Table/TeamRow/AddUsers/AddUsers.styles.js +21 -0
- package/lib/components/Table/TeamRow/AddUsers/index.js +2 -0
- package/lib/components/Table/TeamRow/RemoveMemberModal/RemoveMemberModal.js +65 -0
- package/lib/components/Table/TeamRow/RemoveMemberModal/RemoveMemberModal.styles.js +38 -0
- package/lib/components/Table/TeamRow/RemoveMemberModal/index.js +2 -0
- package/lib/components/Table/TeamRow/TeamRow.js +25 -47
- package/lib/components/Table/TeamRow/UsersRow/UsersRow.js +121 -0
- package/lib/components/Table/TeamRow/UsersRow/UsersRow.styles.js +18 -0
- package/lib/components/Table/TeamRow/UsersRow/index.js +2 -0
- package/lib/components/TeamDetailsModal/MembersSelect.js +103 -28
- package/lib/components/TeamDetailsModal/TeamDetailsModal.js +36 -32
- package/lib/components/TeamDetailsModal/TeamDetailsModal.styles.js +5 -5
- package/lib/components/TeamDetailsModal/TeamDetailsModal.types.js +1 -1
- package/lib/components/TeamDetailsModal/index.js +1 -1
- package/lib/components/UserRow/UserRow.js +8 -4
- package/lib/container/Body/BodyContainerViewTeams.js +52 -97
- package/lib/container/Filters/FiltersContainer.js +4 -4
- package/lib/container/MainView/MainTeamsView.js +40 -0
- package/lib/container/MainView/MainUsersView.js +9 -8
- package/lib/container/MainView/MainView.js +16 -38
- package/lib/container/RouterComponent/RouterComponent.js +20 -15
- package/lib/container/TableContainer/TableContainer.js +4 -2
- package/lib/context/TeamsContext.js +5 -2
- package/lib/context/UsersContext.js +35 -3
- package/lib/hooks/useAssignUserToTeam.js +65 -0
- package/lib/hooks/useCreateTeams.js +36 -0
- package/lib/hooks/useGetTeams.js +8 -4
- package/lib/hooks/useGetTotalPositions.js +24 -0
- package/lib/hooks/useGetTotalTeams.js +24 -0
- package/lib/hooks/useUnassignUserFromTeam.js +58 -0
- package/lib/hooks/useUnblockUser.js +14 -14
- package/lib/lang/translation/br.json +2 -2
- package/lib/lang/translation/en.json +41 -41
- package/lib/lang/translation/es.json +2 -2
- package/lib/lang/translation/fr.json +69 -69
- package/lib/query/assignUserToTeam.js +5 -0
- package/lib/query/createTeam.js +5 -0
- package/lib/query/getTotalPositions.js +5 -0
- package/lib/query/getTotalTeams.js +5 -0
- package/lib/query/unassignUserFromTeam.js +5 -0
- package/package.json +3 -3
|
@@ -1,30 +1,19 @@
|
|
|
1
|
-
import
|
|
1
|
+
import React from 'react';
|
|
2
2
|
import { Trash } from '@projectcor/icons/lib/components/Trash';
|
|
3
|
-
import {
|
|
4
|
-
import {
|
|
3
|
+
import { SCRWrapper, SCRWrapperDynamicRow, SCRWrapperWorkspace, SCRWrapperDeleteIcon, SCRWrapperName, SCRWrapperDescription } from '../Row/Row.styles';
|
|
4
|
+
import { UsersRow } from './UsersRow';
|
|
5
|
+
|
|
6
|
+
/* eslint-disable react/require-default-props */
|
|
5
7
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
6
|
-
var MAX_USERS_DISPLAYED = 6;
|
|
7
|
-
var MAX_NAMES_IN_TOOLTIP = 5;
|
|
8
|
-
var formatRemainingUsersTooltip = function formatRemainingUsersTooltip(remainingUsers) {
|
|
9
|
-
if (remainingUsers.length === 0) return '';
|
|
10
|
-
var namesToShow = remainingUsers.slice(0, MAX_NAMES_IN_TOOLTIP);
|
|
11
|
-
var namesText = namesToShow.map(function (user) {
|
|
12
|
-
return "".concat(user.firstName, " ").concat(user.lastName);
|
|
13
|
-
}).join(' - ');
|
|
14
|
-
if (remainingUsers.length > MAX_NAMES_IN_TOOLTIP) {
|
|
15
|
-
var remainingCount = remainingUsers.length - MAX_NAMES_IN_TOOLTIP;
|
|
16
|
-
return "".concat(namesText, " +").concat(remainingCount);
|
|
17
|
-
}
|
|
18
|
-
return namesText;
|
|
19
|
-
};
|
|
20
8
|
var TeamRowItem = function TeamRowItem(_ref) {
|
|
21
9
|
var _team$workspace;
|
|
22
10
|
var team = _ref.team,
|
|
23
11
|
handleShowTeamDetails = _ref.handleShowTeamDetails,
|
|
24
|
-
handleDeleteTeam = _ref.handleDeleteTeam
|
|
25
|
-
|
|
26
|
-
|
|
12
|
+
handleDeleteTeam = _ref.handleDeleteTeam,
|
|
13
|
+
handleRemoveUser = _ref.handleRemoveUser,
|
|
14
|
+
handleAddUser = _ref.handleAddUser;
|
|
27
15
|
return /*#__PURE__*/_jsxs(SCRWrapper, {
|
|
16
|
+
height: "48px",
|
|
28
17
|
children: [/*#__PURE__*/_jsx(SCRWrapperName, {
|
|
29
18
|
width: "300px",
|
|
30
19
|
onClick: function onClick() {
|
|
@@ -33,29 +22,12 @@ var TeamRowItem = function TeamRowItem(_ref) {
|
|
|
33
22
|
children: /*#__PURE__*/_jsx("span", {
|
|
34
23
|
children: team.name
|
|
35
24
|
})
|
|
36
|
-
}), /*#__PURE__*/
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
title: "".concat(user.firstName, " ").concat(user.lastName),
|
|
43
|
-
placement: "top",
|
|
44
|
-
children: /*#__PURE__*/_jsx(SCRWIconUser, {
|
|
45
|
-
children: /*#__PURE__*/_jsx(AvatarUser, {
|
|
46
|
-
firstName: user.firstName,
|
|
47
|
-
lastName: user.lastName,
|
|
48
|
-
picture: user.picture
|
|
49
|
-
})
|
|
50
|
-
}, user.id)
|
|
51
|
-
});
|
|
52
|
-
}), team.users.length > MAX_USERS_DISPLAYED && /*#__PURE__*/_jsx(Tooltip, {
|
|
53
|
-
title: tooltipText,
|
|
54
|
-
placement: "top",
|
|
55
|
-
children: /*#__PURE__*/_jsxs(SCRRemainingUsers, {
|
|
56
|
-
children: ["+", team.users.length - MAX_USERS_DISPLAYED]
|
|
57
|
-
})
|
|
58
|
-
})]
|
|
25
|
+
}), /*#__PURE__*/_jsx(SCRWrapperDynamicRow, {
|
|
26
|
+
children: /*#__PURE__*/_jsx(UsersRow, {
|
|
27
|
+
team: team,
|
|
28
|
+
onRemoveUser: handleRemoveUser,
|
|
29
|
+
onAddUser: handleAddUser
|
|
30
|
+
})
|
|
59
31
|
}), !window.hasWorkspacesFeature && /*#__PURE__*/_jsx(SCRWrapperDescription, {
|
|
60
32
|
width: "274px",
|
|
61
33
|
onClick: function onClick() {
|
|
@@ -64,7 +36,7 @@ var TeamRowItem = function TeamRowItem(_ref) {
|
|
|
64
36
|
children: /*#__PURE__*/_jsx("span", {
|
|
65
37
|
children: team.description
|
|
66
38
|
})
|
|
67
|
-
}), window.hasWorkspacesFeature && /*#__PURE__*/_jsx(
|
|
39
|
+
}), window.hasWorkspacesFeature && /*#__PURE__*/_jsx(SCRWrapperDynamicRow, {
|
|
68
40
|
onClick: function onClick() {
|
|
69
41
|
return handleShowTeamDetails(team.id);
|
|
70
42
|
},
|
|
@@ -88,10 +60,14 @@ var TeamRowItem = function TeamRowItem(_ref) {
|
|
|
88
60
|
})]
|
|
89
61
|
});
|
|
90
62
|
};
|
|
63
|
+
|
|
64
|
+
/* eslint-disable react/require-default-props */
|
|
91
65
|
export var TeamRow = function TeamRow(_ref2) {
|
|
92
66
|
var teams = _ref2.teams,
|
|
93
67
|
handleShowTeamDetails = _ref2.handleShowTeamDetails,
|
|
94
|
-
handleDeleteTeam = _ref2.handleDeleteTeam
|
|
68
|
+
handleDeleteTeam = _ref2.handleDeleteTeam,
|
|
69
|
+
handleRemoveUser = _ref2.handleRemoveUser,
|
|
70
|
+
handleAddUser = _ref2.handleAddUser;
|
|
95
71
|
return /*#__PURE__*/_jsx("div", {
|
|
96
72
|
style: {
|
|
97
73
|
display: 'flex',
|
|
@@ -102,9 +78,11 @@ export var TeamRow = function TeamRow(_ref2) {
|
|
|
102
78
|
return /*#__PURE__*/_jsx(TeamRowItem, {
|
|
103
79
|
team: team,
|
|
104
80
|
handleShowTeamDetails: handleShowTeamDetails,
|
|
105
|
-
handleDeleteTeam: handleDeleteTeam
|
|
81
|
+
handleDeleteTeam: handleDeleteTeam,
|
|
82
|
+
handleRemoveUser: handleRemoveUser,
|
|
83
|
+
handleAddUser: handleAddUser
|
|
106
84
|
}, team.id);
|
|
107
85
|
})
|
|
108
86
|
});
|
|
109
87
|
};
|
|
110
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["AvatarUser","Trash","Tooltip","SCRWrapper","SCRWrapperUser","SCRWrapperDynamicRow","SCRWIconUser","SCRWrapperWorkspace","SCRWrapperDeleteIcon","SCRWrapperName","SCRWrapperDescription","SCRRemainingUsers","jsx","_jsx","jsxs","_jsxs","MAX_USERS_DISPLAYED","MAX_NAMES_IN_TOOLTIP","formatRemainingUsersTooltip","remainingUsers","length","namesToShow","slice","namesText","map","user","concat","firstName","lastName","join","remainingCount","TeamRowItem","_ref","_team$workspace","team","handleShowTeamDetails","handleDeleteTeam","users","tooltipText","children","width","onClick","id","name","title","placement","picture","window","hasWorkspacesFeature","description","workspace","height","color","TeamRow","_ref2","teams","style","display","flexDirection","border"],"sources":["../../../../src/components/Table/TeamRow/TeamRow.tsx"],"sourcesContent":["import { AvatarUser } from '@projectcor/cor-commons/lib/components/avatar-user'\nimport { Trash } from '@projectcor/icons/lib/components/Trash'\nimport { Tooltip } from '@projectcor/tooltipv2/lib/components/Tooltip'\nimport {\n  SCRWrapper,\n  SCRWrapperUser,\n  SCRWrapperDynamicRow,\n  SCRWIconUser,\n  SCRWrapperWorkspace,\n  SCRWrapperDeleteIcon,\n  SCRWrapperName,\n  SCRWrapperDescription,\n  SCRRemainingUsers,\n} from '../Row/Row.styles'\nimport { Team } from '../../TeamDetailsModal/TeamDetailsModal.types'\n\nconst MAX_USERS_DISPLAYED = 6\nconst MAX_NAMES_IN_TOOLTIP = 5\n\nconst formatRemainingUsersTooltip = (remainingUsers: Team['users']): string => {\n  if (remainingUsers.length === 0) return ''\n\n  const namesToShow = remainingUsers.slice(0, MAX_NAMES_IN_TOOLTIP)\n  const namesText = namesToShow.map(user => `${user.firstName} ${user.lastName}`).join(' - ')\n\n  if (remainingUsers.length > MAX_NAMES_IN_TOOLTIP) {\n    const remainingCount = remainingUsers.length - MAX_NAMES_IN_TOOLTIP\n    return `${namesText} +${remainingCount}`\n  }\n\n  return namesText\n}\n\nconst TeamRowItem = ({\n  team,\n  handleShowTeamDetails,\n  handleDeleteTeam,\n}: {\n  team: Team\n  handleShowTeamDetails: (teamId: number) => void\n  handleDeleteTeam: (teamId: number) => void\n}) => {\n  const remainingUsers = team.users.slice(MAX_USERS_DISPLAYED)\n  const tooltipText = formatRemainingUsersTooltip(remainingUsers)\n\n  return (\n    <SCRWrapper>\n      <SCRWrapperName width=\"300px\" onClick={() => handleShowTeamDetails(team.id)}>\n        <span>{team.name}</span>\n      </SCRWrapperName>\n      <SCRWrapperUser onClick={() => handleShowTeamDetails(team.id)}>\n        {team.users.slice(0, MAX_USERS_DISPLAYED).map(user => {\n          return (\n            <Tooltip title={`${user.firstName} ${user.lastName}`} placement=\"top\">\n              <SCRWIconUser key={user.id}>\n                <AvatarUser firstName={user.firstName} lastName={user.lastName} picture={user.picture} />\n              </SCRWIconUser>\n            </Tooltip>\n          )\n        })}\n        {team.users.length > MAX_USERS_DISPLAYED && (\n          <Tooltip title={tooltipText} placement=\"top\">\n            <SCRRemainingUsers>+{team.users.length - MAX_USERS_DISPLAYED}</SCRRemainingUsers>\n          </Tooltip>\n        )}\n      </SCRWrapperUser>\n      {!window.hasWorkspacesFeature && (\n        <SCRWrapperDescription width=\"274px\" onClick={() => handleShowTeamDetails(team.id)}>\n          <span>{team.description}</span>\n        </SCRWrapperDescription>\n      )}\n      {window.hasWorkspacesFeature && (\n        <SCRWrapperUser onClick={() => handleShowTeamDetails(team.id)}>\n          {team.workspace?.name && (\n            <SCRWrapperWorkspace>\n              <span>{team.workspace.name}</span>\n            </SCRWrapperWorkspace>\n          )}\n        </SCRWrapperUser>\n      )}\n      <SCRWrapperDynamicRow width=\"40px\">\n        <SCRWrapperDeleteIcon onClick={() => handleDeleteTeam(team.id)}>\n          <Trash width=\"14px\" height=\"14px\" color=\"#C70505\" />\n        </SCRWrapperDeleteIcon>\n      </SCRWrapperDynamicRow>\n    </SCRWrapper>\n  )\n}\n\nexport const TeamRow = ({\n  teams,\n  handleShowTeamDetails,\n  handleDeleteTeam,\n}: {\n  teams: Team[]\n  handleShowTeamDetails: (teamId: number) => void\n  handleDeleteTeam: (teamId: number) => void\n}) => {\n  return (\n    <div style={{ display: 'flex', flexDirection: 'column', border: '1px solid #e7e7e7' }}>\n      {teams.map(team => (\n        <TeamRowItem\n          key={team.id}\n          team={team}\n          handleShowTeamDetails={handleShowTeamDetails}\n          handleDeleteTeam={handleDeleteTeam}\n        />\n      ))}\n    </div>\n  )\n}\n"],"mappings":"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","ignoreList":[]}
|
|
88
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","Trash","SCRWrapper","SCRWrapperDynamicRow","SCRWrapperWorkspace","SCRWrapperDeleteIcon","SCRWrapperName","SCRWrapperDescription","UsersRow","jsx","_jsx","jsxs","_jsxs","TeamRowItem","_ref","_team$workspace","team","handleShowTeamDetails","handleDeleteTeam","handleRemoveUser","handleAddUser","height","children","width","onClick","id","name","onRemoveUser","onAddUser","window","hasWorkspacesFeature","description","workspace","color","TeamRow","_ref2","teams","style","display","flexDirection","border","map"],"sources":["../../../../src/components/Table/TeamRow/TeamRow.tsx"],"sourcesContent":["import React from 'react'\nimport { Trash } from '@projectcor/icons/lib/components/Trash'\nimport {\n  SCRWrapper,\n  SCRWrapperDynamicRow,\n  SCRWrapperWorkspace,\n  SCRWrapperDeleteIcon,\n  SCRWrapperName,\n  SCRWrapperDescription,\n} from '../Row/Row.styles'\nimport { Team } from '../../TeamDetailsModal/TeamDetailsModal.types'\nimport { UsersRow } from './UsersRow'\n\n/* eslint-disable react/require-default-props */\nconst TeamRowItem = ({\n  team,\n  handleShowTeamDetails,\n  handleDeleteTeam,\n  handleRemoveUser,\n  handleAddUser,\n}: {\n  team: Team\n  handleShowTeamDetails: (teamId: number) => void\n  handleDeleteTeam: (teamId: number) => void\n  handleRemoveUser: (teamId: number, userId: number, deleteFromProjects: boolean) => void\n  handleAddUser: (teamId: number, userId: number, giveAccessToAllProjects: boolean) => void\n}) => {\n  return (\n    <SCRWrapper height=\"48px\">\n      <SCRWrapperName width=\"300px\" onClick={() => handleShowTeamDetails(team.id)}>\n        <span>{team.name}</span>\n      </SCRWrapperName>\n      <SCRWrapperDynamicRow>\n        <UsersRow team={team} onRemoveUser={handleRemoveUser} onAddUser={handleAddUser} />\n      </SCRWrapperDynamicRow>\n      {!window.hasWorkspacesFeature && (\n        <SCRWrapperDescription width=\"274px\" onClick={() => handleShowTeamDetails(team.id)}>\n          <span>{team.description}</span>\n        </SCRWrapperDescription>\n      )}\n      {window.hasWorkspacesFeature && (\n        <SCRWrapperDynamicRow onClick={() => handleShowTeamDetails(team.id)}>\n          {team.workspace?.name && (\n            <SCRWrapperWorkspace>\n              <span>{team.workspace.name}</span>\n            </SCRWrapperWorkspace>\n          )}\n        </SCRWrapperDynamicRow>\n      )}\n      <SCRWrapperDynamicRow width=\"40px\">\n        <SCRWrapperDeleteIcon onClick={() => handleDeleteTeam(team.id)}>\n          <Trash width=\"14px\" height=\"14px\" color=\"#C70505\" />\n        </SCRWrapperDeleteIcon>\n      </SCRWrapperDynamicRow>\n    </SCRWrapper>\n  )\n}\n\n/* eslint-disable react/require-default-props */\nexport const TeamRow = ({\n  teams,\n  handleShowTeamDetails,\n  handleDeleteTeam,\n  handleRemoveUser,\n  handleAddUser,\n}: {\n  teams: Team[]\n  handleShowTeamDetails: (teamId: number) => void\n  handleDeleteTeam: (teamId: number) => void\n  handleRemoveUser: (teamId: number, userId: number, deleteFromProjects: boolean) => void\n  handleAddUser: (teamId: number, userId: number, giveAccessToAllProjects: boolean) => void\n}) => {\n  return (\n    <div style={{ display: 'flex', flexDirection: 'column', border: '1px solid #e7e7e7' }}>\n      {teams.map(team => (\n        <TeamRowItem\n          key={team.id}\n          team={team}\n          handleShowTeamDetails={handleShowTeamDetails}\n          handleDeleteTeam={handleDeleteTeam}\n          handleRemoveUser={handleRemoveUser}\n          handleAddUser={handleAddUser}\n        />\n      ))}\n    </div>\n  )\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,121 @@
|
|
|
1
|
+
import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
|
|
2
|
+
import React, { useState } from 'react';
|
|
3
|
+
import { AvatarUser } from '@projectcor/cor-commons/lib/components/avatar-user';
|
|
4
|
+
import { Cross } from '@projectcor/icons/lib/components/Cross';
|
|
5
|
+
import { Tooltip } from '@projectcor/tooltipv2/lib/components/Tooltip';
|
|
6
|
+
import { AddUsers } from '../AddUsers';
|
|
7
|
+
import { AddMemberModal } from '../AddMemberModal';
|
|
8
|
+
import { RemoveMemberModal } from '../RemoveMemberModal';
|
|
9
|
+
import { SCURUserContainer, SCURUserAvatar, SCURRemoveIcon, SCURAddUsersWrapper } from './UsersRow.styles';
|
|
10
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
11
|
+
export var UsersRow = function UsersRow(_ref) {
|
|
12
|
+
var team = _ref.team,
|
|
13
|
+
onRemoveUser = _ref.onRemoveUser,
|
|
14
|
+
onAddUser = _ref.onAddUser;
|
|
15
|
+
var currentMembers = team.users.map(function (user) {
|
|
16
|
+
return {
|
|
17
|
+
id: user.id,
|
|
18
|
+
name: "".concat(user.firstName, " ").concat(user.lastName)
|
|
19
|
+
};
|
|
20
|
+
});
|
|
21
|
+
var _useState = useState(false),
|
|
22
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
23
|
+
isModalOpen = _useState2[0],
|
|
24
|
+
setIsModalOpen = _useState2[1];
|
|
25
|
+
var _useState3 = useState([]),
|
|
26
|
+
_useState4 = _slicedToArray(_useState3, 2),
|
|
27
|
+
pendingMembers = _useState4[0],
|
|
28
|
+
setPendingMembers = _useState4[1];
|
|
29
|
+
var _useState5 = useState(false),
|
|
30
|
+
_useState6 = _slicedToArray(_useState5, 2),
|
|
31
|
+
isRemoveModalOpen = _useState6[0],
|
|
32
|
+
setIsRemoveModalOpen = _useState6[1];
|
|
33
|
+
var _useState7 = useState(null),
|
|
34
|
+
_useState8 = _slicedToArray(_useState7, 2),
|
|
35
|
+
userToRemove = _useState8[0],
|
|
36
|
+
setUserToRemove = _useState8[1];
|
|
37
|
+
var handleAddMembers = function handleAddMembers(members) {
|
|
38
|
+
setPendingMembers(members);
|
|
39
|
+
setIsModalOpen(true);
|
|
40
|
+
};
|
|
41
|
+
var handleModalAccept = function handleModalAccept(giveAccessToAllProjects) {
|
|
42
|
+
// Agregar cada miembro seleccionado al equipo
|
|
43
|
+
pendingMembers.forEach(function (member) {
|
|
44
|
+
onAddUser(+team.id, member.id, giveAccessToAllProjects);
|
|
45
|
+
});
|
|
46
|
+
setIsModalOpen(false);
|
|
47
|
+
setPendingMembers([]);
|
|
48
|
+
};
|
|
49
|
+
var handleModalClose = function handleModalClose() {
|
|
50
|
+
setIsModalOpen(false);
|
|
51
|
+
setPendingMembers([]);
|
|
52
|
+
};
|
|
53
|
+
var handleRemoveUser = function handleRemoveUser(e, userId) {
|
|
54
|
+
e.stopPropagation();
|
|
55
|
+
setUserToRemove(userId);
|
|
56
|
+
setIsRemoveModalOpen(true);
|
|
57
|
+
};
|
|
58
|
+
var handleRemoveModalAccept = function handleRemoveModalAccept(deleteFromProjects) {
|
|
59
|
+
if (userToRemove !== null) {
|
|
60
|
+
onRemoveUser(+team.id, userToRemove, deleteFromProjects);
|
|
61
|
+
}
|
|
62
|
+
setIsRemoveModalOpen(false);
|
|
63
|
+
setUserToRemove(null);
|
|
64
|
+
};
|
|
65
|
+
var handleRemoveModalClose = function handleRemoveModalClose() {
|
|
66
|
+
setIsRemoveModalOpen(false);
|
|
67
|
+
setUserToRemove(null);
|
|
68
|
+
};
|
|
69
|
+
return /*#__PURE__*/_jsxs(_Fragment, {
|
|
70
|
+
children: [team.users.map(function (user) {
|
|
71
|
+
return /*#__PURE__*/_jsxs(SCURUserContainer, {
|
|
72
|
+
children: [/*#__PURE__*/_jsx(Tooltip, {
|
|
73
|
+
title: "".concat(user.firstName, " ").concat(user.lastName),
|
|
74
|
+
placement: "top",
|
|
75
|
+
children: /*#__PURE__*/_jsx(SCURUserAvatar, {
|
|
76
|
+
children: /*#__PURE__*/_jsx(AvatarUser, {
|
|
77
|
+
firstName: user.firstName,
|
|
78
|
+
lastName: user.lastName,
|
|
79
|
+
picture: user.picture
|
|
80
|
+
})
|
|
81
|
+
})
|
|
82
|
+
}), /*#__PURE__*/_jsx(SCURRemoveIcon, {
|
|
83
|
+
onClick: function onClick(e) {
|
|
84
|
+
return handleRemoveUser(e, user.id);
|
|
85
|
+
},
|
|
86
|
+
role: "button",
|
|
87
|
+
tabIndex: 0,
|
|
88
|
+
children: /*#__PURE__*/_jsx(Cross, {
|
|
89
|
+
width: "11px",
|
|
90
|
+
height: "11px",
|
|
91
|
+
color: "#8C8C8C"
|
|
92
|
+
})
|
|
93
|
+
})]
|
|
94
|
+
}, user.id);
|
|
95
|
+
}), /*#__PURE__*/_jsx(SCURAddUsersWrapper, {
|
|
96
|
+
onClick: function onClick(e) {
|
|
97
|
+
return e.stopPropagation();
|
|
98
|
+
},
|
|
99
|
+
onKeyDown: function onKeyDown(e) {
|
|
100
|
+
if (e.key === 'Enter' || e.key === ' ') {
|
|
101
|
+
e.stopPropagation();
|
|
102
|
+
}
|
|
103
|
+
},
|
|
104
|
+
role: "button",
|
|
105
|
+
tabIndex: 0,
|
|
106
|
+
children: /*#__PURE__*/_jsx(AddUsers, {
|
|
107
|
+
currentMembers: currentMembers,
|
|
108
|
+
onAddMembers: handleAddMembers
|
|
109
|
+
})
|
|
110
|
+
}), /*#__PURE__*/_jsx(AddMemberModal, {
|
|
111
|
+
isOpen: isModalOpen,
|
|
112
|
+
onClose: handleModalClose,
|
|
113
|
+
onAccept: handleModalAccept
|
|
114
|
+
}), /*#__PURE__*/_jsx(RemoveMemberModal, {
|
|
115
|
+
isOpen: isRemoveModalOpen,
|
|
116
|
+
onClose: handleRemoveModalClose,
|
|
117
|
+
onAccept: handleRemoveModalAccept
|
|
118
|
+
})]
|
|
119
|
+
});
|
|
120
|
+
};
|
|
121
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","useState","AvatarUser","Cross","Tooltip","AddUsers","AddMemberModal","RemoveMemberModal","SCURUserContainer","SCURUserAvatar","SCURRemoveIcon","SCURAddUsersWrapper","jsx","_jsx","jsxs","_jsxs","Fragment","_Fragment","UsersRow","_ref","team","onRemoveUser","onAddUser","currentMembers","users","map","user","id","name","concat","firstName","lastName","_useState","_useState2","_slicedToArray","isModalOpen","setIsModalOpen","_useState3","_useState4","pendingMembers","setPendingMembers","_useState5","_useState6","isRemoveModalOpen","setIsRemoveModalOpen","_useState7","_useState8","userToRemove","setUserToRemove","handleAddMembers","members","handleModalAccept","giveAccessToAllProjects","forEach","member","handleModalClose","handleRemoveUser","e","userId","stopPropagation","handleRemoveModalAccept","deleteFromProjects","handleRemoveModalClose","children","title","placement","picture","onClick","role","tabIndex","width","height","color","onKeyDown","key","onAddMembers","isOpen","onClose","onAccept"],"sources":["../../../../../src/components/Table/TeamRow/UsersRow/UsersRow.tsx"],"sourcesContent":["import React, { useState } from 'react'\nimport { AvatarUser } from '@projectcor/cor-commons/lib/components/avatar-user'\nimport { Cross } from '@projectcor/icons/lib/components/Cross'\nimport { Tooltip } from '@projectcor/tooltipv2/lib/components/Tooltip'\nimport { Team } from '../../../TeamDetailsModal/TeamDetailsModal.types'\nimport { AddUsers } from '../AddUsers'\nimport { MemberSelection } from '../../../TeamDetailsModal/MembersSelect'\nimport { AddMemberModal } from '../AddMemberModal'\nimport { RemoveMemberModal } from '../RemoveMemberModal'\nimport { SCURUserContainer, SCURUserAvatar, SCURRemoveIcon, SCURAddUsersWrapper } from './UsersRow.styles'\n\ninterface UsersRowProps {\n  team: Team\n  onRemoveUser: (teamId: number, userId: number, deleteFromProjects: boolean) => void\n  onAddUser: (teamId: number, userId: number, giveAccessToAllProjects: boolean) => void\n}\n\nexport const UsersRow = ({ team, onRemoveUser, onAddUser }: UsersRowProps) => {\n  const currentMembers: MemberSelection[] = team.users.map(user => ({\n    id: user.id,\n    name: `${user.firstName} ${user.lastName}`,\n  }))\n\n  const [isModalOpen, setIsModalOpen] = useState(false)\n  const [pendingMembers, setPendingMembers] = useState<MemberSelection[]>([])\n  const [isRemoveModalOpen, setIsRemoveModalOpen] = useState(false)\n  const [userToRemove, setUserToRemove] = useState<number | null>(null)\n\n  const handleAddMembers = (members: MemberSelection[]) => {\n    setPendingMembers(members)\n    setIsModalOpen(true)\n  }\n\n  const handleModalAccept = (giveAccessToAllProjects: boolean) => {\n    // Agregar cada miembro seleccionado al equipo\n    pendingMembers.forEach(member => {\n      onAddUser(+team.id, member.id, giveAccessToAllProjects)\n    })\n    setIsModalOpen(false)\n    setPendingMembers([])\n  }\n\n  const handleModalClose = () => {\n    setIsModalOpen(false)\n    setPendingMembers([])\n  }\n\n  const handleRemoveUser = (e: React.MouseEvent, userId: number) => {\n    e.stopPropagation()\n    setUserToRemove(userId)\n    setIsRemoveModalOpen(true)\n  }\n\n  const handleRemoveModalAccept = (deleteFromProjects: boolean) => {\n    if (userToRemove !== null) {\n      onRemoveUser(+team.id, userToRemove, deleteFromProjects)\n    }\n    setIsRemoveModalOpen(false)\n    setUserToRemove(null)\n  }\n\n  const handleRemoveModalClose = () => {\n    setIsRemoveModalOpen(false)\n    setUserToRemove(null)\n  }\n\n  return (\n    <>\n      {team.users.map(user => {\n        return (\n          <SCURUserContainer key={user.id}>\n            <Tooltip title={`${user.firstName} ${user.lastName}`} placement=\"top\">\n              <SCURUserAvatar>\n                <AvatarUser firstName={user.firstName} lastName={user.lastName} picture={user.picture} />\n              </SCURUserAvatar>\n            </Tooltip>\n            <SCURRemoveIcon onClick={e => handleRemoveUser(e, user.id)} role=\"button\" tabIndex={0}>\n              <Cross width=\"11px\" height=\"11px\" color=\"#8C8C8C\" />\n            </SCURRemoveIcon>\n          </SCURUserContainer>\n        )\n      })}\n      <SCURAddUsersWrapper\n        onClick={e => e.stopPropagation()}\n        onKeyDown={e => {\n          if (e.key === 'Enter' || e.key === ' ') {\n            e.stopPropagation()\n          }\n        }}\n        role=\"button\"\n        tabIndex={0}\n      >\n        <AddUsers currentMembers={currentMembers} onAddMembers={handleAddMembers} />\n      </SCURAddUsersWrapper>\n      <AddMemberModal isOpen={isModalOpen} onClose={handleModalClose} onAccept={handleModalAccept} />\n      <RemoveMemberModal\n        isOpen={isRemoveModalOpen}\n        onClose={handleRemoveModalClose}\n        onAccept={handleRemoveModalAccept}\n      />\n    </>\n  )\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import styled from 'styled-components';
|
|
2
|
+
export var SCURRemoveIcon = styled.div.withConfig({
|
|
3
|
+
displayName: "UsersRowstyles__SCURRemoveIcon",
|
|
4
|
+
componentId: "sc-1lkpduz-0"
|
|
5
|
+
})(["position:absolute;bottom:-4px;right:-4px;width:14px;height:14px;border:1px solid #8c8c8c;background-color:#ffffff;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;visibility:hidden;transition:opacity 0.2s ease-in-out,visibility 0.2s ease-in-out;z-index:10;"]);
|
|
6
|
+
export var SCURUserContainer = styled.div.withConfig({
|
|
7
|
+
displayName: "UsersRowstyles__SCURUserContainer",
|
|
8
|
+
componentId: "sc-1lkpduz-1"
|
|
9
|
+
})(["position:relative;display:inline-block;margin-right:-5px;&:hover ", "{opacity:1;visibility:visible;}"], SCURRemoveIcon);
|
|
10
|
+
export var SCURUserAvatar = styled.div.withConfig({
|
|
11
|
+
displayName: "UsersRowstyles__SCURUserAvatar",
|
|
12
|
+
componentId: "sc-1lkpduz-2"
|
|
13
|
+
})(["position:relative;display:flex;align-items:center;justify-content:center;"]);
|
|
14
|
+
export var SCURAddUsersWrapper = styled.div.withConfig({
|
|
15
|
+
displayName: "UsersRowstyles__SCURAddUsersWrapper",
|
|
16
|
+
componentId: "sc-1lkpduz-3"
|
|
17
|
+
})(["display:inline-block;"]);
|
|
18
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJzdHlsZWQiLCJTQ1VSUmVtb3ZlSWNvbiIsImRpdiIsIndpdGhDb25maWciLCJkaXNwbGF5TmFtZSIsImNvbXBvbmVudElkIiwiU0NVUlVzZXJDb250YWluZXIiLCJTQ1VSVXNlckF2YXRhciIsIlNDVVJBZGRVc2Vyc1dyYXBwZXIiXSwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9UYWJsZS9UZWFtUm93L1VzZXJzUm93L1VzZXJzUm93LnN0eWxlcy50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdzdHlsZWQtY29tcG9uZW50cydcblxuZXhwb3J0IGNvbnN0IFNDVVJSZW1vdmVJY29uID0gc3R5bGVkLmRpdmBcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICBib3R0b206IC00cHg7XG4gIHJpZ2h0OiAtNHB4O1xuICB3aWR0aDogMTRweDtcbiAgaGVpZ2h0OiAxNHB4O1xuICBib3JkZXI6IDFweCBzb2xpZCAjOGM4YzhjO1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAjZmZmZmZmO1xuICBib3JkZXItcmFkaXVzOiA1MCU7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuICBjdXJzb3I6IHBvaW50ZXI7XG4gIG9wYWNpdHk6IDA7XG4gIHZpc2liaWxpdHk6IGhpZGRlbjtcbiAgdHJhbnNpdGlvbjogb3BhY2l0eSAwLjJzIGVhc2UtaW4tb3V0LCB2aXNpYmlsaXR5IDAuMnMgZWFzZS1pbi1vdXQ7XG4gIHotaW5kZXg6IDEwO1xuYFxuXG5leHBvcnQgY29uc3QgU0NVUlVzZXJDb250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIGRpc3BsYXk6IGlubGluZS1ibG9jaztcbiAgbWFyZ2luLXJpZ2h0OiAtNXB4O1xuXG4gICY6aG92ZXIgJHtTQ1VSUmVtb3ZlSWNvbn0ge1xuICAgIG9wYWNpdHk6IDE7XG4gICAgdmlzaWJpbGl0eTogdmlzaWJsZTtcbiAgfVxuYFxuXG5leHBvcnQgY29uc3QgU0NVUlVzZXJBdmF0YXIgPSBzdHlsZWQuZGl2YFxuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuYFxuXG5leHBvcnQgY29uc3QgU0NVUkFkZFVzZXJzV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGlubGluZS1ibG9jaztcbmBcbiJdLCJtYXBwaW5ncyI6IkFBQUEsT0FBT0EsTUFBTSxNQUFNLG1CQUFtQjtBQUV0QyxPQUFPLElBQU1DLGNBQWMsR0FBR0QsTUFBTSxDQUFDRSxHQUFHLENBQUFDLFVBQUE7RUFBQUMsV0FBQTtFQUFBQyxXQUFBO0FBQUEseVRBaUJ2QztBQUVELE9BQU8sSUFBTUMsaUJBQWlCLEdBQUdOLE1BQU0sQ0FBQ0UsR0FBRyxDQUFBQyxVQUFBO0VBQUFDLFdBQUE7RUFBQUMsV0FBQTtBQUFBLDZHQUsvQkosY0FBYyxDQUl6QjtBQUVELE9BQU8sSUFBTU0sY0FBYyxHQUFHUCxNQUFNLENBQUNFLEdBQUcsQ0FBQUMsVUFBQTtFQUFBQyxXQUFBO0VBQUFDLFdBQUE7QUFBQSxpRkFLdkM7QUFFRCxPQUFPLElBQU1HLG1CQUFtQixHQUFHUixNQUFNLENBQUNFLEdBQUcsQ0FBQUMsVUFBQTtFQUFBQyxXQUFBO0VBQUFDLFdBQUE7QUFBQSw2QkFFNUMiLCJpZ25vcmVMaXN0IjpbXX0=
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export { UsersRow } from './UsersRow';
|
|
2
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJVc2Vyc1JvdyJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL1RhYmxlL1RlYW1Sb3cvVXNlcnNSb3cvaW5kZXgudHMiXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgVXNlcnNSb3cgfSBmcm9tICcuL1VzZXJzUm93J1xuIl0sIm1hcHBpbmdzIjoiQUFBQSxTQUFTQSxRQUFRLFFBQVEsWUFBWSIsImlnbm9yZUxpc3QiOltdfQ==
|
|
@@ -1,49 +1,121 @@
|
|
|
1
1
|
import _toConsumableArray from "@babel/runtime/helpers/toConsumableArray";
|
|
2
2
|
import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
|
|
3
|
-
import { useState,
|
|
3
|
+
import { useState, useEffect, useRef, useCallback } from 'react';
|
|
4
4
|
import { ChevronDown } from '@projectcor/icons/lib/components/ChevronDown';
|
|
5
5
|
import { CUSelect } from '@projectcor/selector/lib/components/CUSelect';
|
|
6
6
|
import { SearchComponent } from '../Filters/SearchComponent/SearchComponent';
|
|
7
|
+
import { useGetUsers } from '../../hooks/useGetUsers';
|
|
8
|
+
import { useDebounce } from '../../hooks/useDebounce';
|
|
7
9
|
import { SCBackdropInputSelect, SCCUItemsList, SCCUSelectItem, SCWrapperSelectIcon, SCMemberItemContent, SCMemberCheckbox, SCMemberSearchWrapper } from './TeamDetailsModal.styles';
|
|
8
10
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
9
11
|
export var MembersSelect = function MembersSelect(_ref) {
|
|
10
12
|
var value = _ref.value,
|
|
11
|
-
membersList = _ref.membersList,
|
|
12
13
|
onChange = _ref.onChange;
|
|
13
14
|
var _useState = useState(false),
|
|
14
15
|
_useState2 = _slicedToArray(_useState, 2),
|
|
15
16
|
showSelectMembers = _useState2[0],
|
|
16
17
|
setShowSelectMembers = _useState2[1];
|
|
18
|
+
var _useGetUsers = useGetUsers(),
|
|
19
|
+
handleGetUsers = _useGetUsers.handleGetUsers,
|
|
20
|
+
users = _useGetUsers.users,
|
|
21
|
+
currentPage = _useGetUsers.currentPage,
|
|
22
|
+
totalPages = _useGetUsers.totalPages,
|
|
23
|
+
loading = _useGetUsers.loading;
|
|
17
24
|
var _useState3 = useState(''),
|
|
18
25
|
_useState4 = _slicedToArray(_useState3, 2),
|
|
19
26
|
searchValue = _useState4[0],
|
|
20
27
|
setSearchValue = _useState4[1];
|
|
28
|
+
var debouncedSearchValue = useDebounce(searchValue, 300);
|
|
29
|
+
var _useState5 = useState([]),
|
|
30
|
+
_useState6 = _slicedToArray(_useState5, 2),
|
|
31
|
+
accumulatedUsers = _useState6[0],
|
|
32
|
+
setAccumulatedUsers = _useState6[1];
|
|
33
|
+
var scrollContainerRef = useRef(null);
|
|
34
|
+
var isLoadingMoreRef = useRef(false);
|
|
21
35
|
var handleSelectMember = function handleSelectMember(member) {
|
|
22
|
-
var
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
return m !==
|
|
28
|
-
});
|
|
29
|
-
onChange(updatedMembers.join(' - '));
|
|
36
|
+
var alredySelected = value.some(function (m) {
|
|
37
|
+
return m.id === member.id;
|
|
38
|
+
});
|
|
39
|
+
if (alredySelected) {
|
|
40
|
+
onChange('members', value.filter(function (m) {
|
|
41
|
+
return m.id !== member.id;
|
|
42
|
+
}));
|
|
30
43
|
} else {
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
44
|
+
onChange('members', [].concat(_toConsumableArray(value), [{
|
|
45
|
+
id: member.id,
|
|
46
|
+
name: "".concat(member.firstName, " ").concat(member.lastName)
|
|
47
|
+
}]));
|
|
34
48
|
}
|
|
35
|
-
// No cerrar el selector para permitir selección múltiple
|
|
36
49
|
};
|
|
37
50
|
var handleSearch = function handleSearch(e) {
|
|
38
51
|
setSearchValue(e.target.value);
|
|
39
52
|
};
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
53
|
+
|
|
54
|
+
// Resetear usuarios acumulados cuando cambia el search o se abre el selector
|
|
55
|
+
useEffect(function () {
|
|
56
|
+
if (showSelectMembers) {
|
|
57
|
+
setAccumulatedUsers([]);
|
|
58
|
+
isLoadingMoreRef.current = false;
|
|
59
|
+
handleGetUsers({
|
|
60
|
+
page: 1,
|
|
61
|
+
searchInput: debouncedSearchValue
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
}, [debouncedSearchValue, showSelectMembers, handleGetUsers]);
|
|
65
|
+
|
|
66
|
+
// Acumular usuarios cuando se reciben nuevos datos
|
|
67
|
+
useEffect(function () {
|
|
68
|
+
if (users.length > 0 && showSelectMembers) {
|
|
69
|
+
if (currentPage === 1) {
|
|
70
|
+
// Si es la primera página, reemplazar
|
|
71
|
+
setAccumulatedUsers(users);
|
|
72
|
+
} else {
|
|
73
|
+
// Si es una página posterior, agregar a los existentes
|
|
74
|
+
setAccumulatedUsers(function (prev) {
|
|
75
|
+
// Evitar duplicados
|
|
76
|
+
var existingIds = new Set(prev.map(function (u) {
|
|
77
|
+
return u.id;
|
|
78
|
+
}));
|
|
79
|
+
var newUsers = users.filter(function (u) {
|
|
80
|
+
return !existingIds.has(u.id);
|
|
81
|
+
});
|
|
82
|
+
return [].concat(_toConsumableArray(prev), _toConsumableArray(newUsers));
|
|
83
|
+
});
|
|
84
|
+
}
|
|
85
|
+
isLoadingMoreRef.current = false;
|
|
86
|
+
}
|
|
87
|
+
}, [users, currentPage, showSelectMembers]);
|
|
88
|
+
var handleScroll = useCallback(function () {
|
|
89
|
+
var container = scrollContainerRef.current;
|
|
90
|
+
if (!container || loading || isLoadingMoreRef.current) return;
|
|
91
|
+
var scrollTop = container.scrollTop,
|
|
92
|
+
scrollHeight = container.scrollHeight,
|
|
93
|
+
clientHeight = container.clientHeight;
|
|
94
|
+
var isNearBottom = scrollTop + clientHeight >= scrollHeight - 10; // 10px de margen
|
|
95
|
+
|
|
96
|
+
if (isNearBottom && currentPage < totalPages) {
|
|
97
|
+
isLoadingMoreRef.current = true;
|
|
98
|
+
handleGetUsers({
|
|
99
|
+
page: currentPage + 1,
|
|
100
|
+
searchInput: debouncedSearchValue
|
|
101
|
+
});
|
|
102
|
+
}
|
|
103
|
+
}, [currentPage, totalPages, loading, handleGetUsers, debouncedSearchValue]);
|
|
104
|
+
useEffect(function () {
|
|
105
|
+
var container = scrollContainerRef.current;
|
|
106
|
+
if (!container || !showSelectMembers) return undefined;
|
|
107
|
+
container.addEventListener('scroll', handleScroll);
|
|
108
|
+
return function () {
|
|
109
|
+
container.removeEventListener('scroll', handleScroll);
|
|
110
|
+
};
|
|
111
|
+
}, [handleScroll, showSelectMembers]);
|
|
112
|
+
var handleClickActionSelect = function handleClickActionSelect() {
|
|
113
|
+
setShowSelectMembers(!showSelectMembers);
|
|
114
|
+
if (!showSelectMembers) {
|
|
115
|
+
setSearchValue('');
|
|
116
|
+
setAccumulatedUsers([]);
|
|
117
|
+
}
|
|
118
|
+
};
|
|
47
119
|
return /*#__PURE__*/_jsxs(CUSelect, {
|
|
48
120
|
title: "Agregar miembros *",
|
|
49
121
|
placeholder: "Seleccionar miembros",
|
|
@@ -55,25 +127,28 @@ export var MembersSelect = function MembersSelect(_ref) {
|
|
|
55
127
|
color: "#20201F"
|
|
56
128
|
})
|
|
57
129
|
}),
|
|
58
|
-
value: value
|
|
130
|
+
value: value.map(function (member) {
|
|
131
|
+
return member.name;
|
|
132
|
+
}).join(' - '),
|
|
59
133
|
open: showSelectMembers,
|
|
60
|
-
handleClickAction:
|
|
61
|
-
return setShowSelectMembers(!showSelectMembers);
|
|
62
|
-
},
|
|
134
|
+
handleClickAction: handleClickActionSelect,
|
|
63
135
|
children: [/*#__PURE__*/_jsx(SCBackdropInputSelect, {
|
|
64
136
|
onClick: function onClick() {
|
|
65
137
|
return setShowSelectMembers(false);
|
|
66
138
|
}
|
|
67
139
|
}), /*#__PURE__*/_jsxs(SCCUItemsList, {
|
|
140
|
+
ref: scrollContainerRef,
|
|
68
141
|
children: [/*#__PURE__*/_jsx(SCMemberSearchWrapper, {
|
|
69
142
|
children: /*#__PURE__*/_jsx(SearchComponent, {
|
|
70
143
|
placeholder: "Buscar miembro",
|
|
71
144
|
onChange: handleSearch,
|
|
72
145
|
value: searchValue
|
|
73
146
|
})
|
|
74
|
-
}),
|
|
147
|
+
}), accumulatedUsers.map(function (member) {
|
|
75
148
|
var memberName = "".concat(member.firstName, " ").concat(member.lastName);
|
|
76
|
-
var isSelected = (value === null || value === void 0 ? void 0 : value.
|
|
149
|
+
var isSelected = (value === null || value === void 0 ? void 0 : value.some(function (m) {
|
|
150
|
+
return m.id === member.id;
|
|
151
|
+
})) || false;
|
|
77
152
|
return /*#__PURE__*/_jsx(SCCUSelectItem, {
|
|
78
153
|
onClick: function onClick(e) {
|
|
79
154
|
e.stopPropagation();
|
|
@@ -100,4 +175,4 @@ export var MembersSelect = function MembersSelect(_ref) {
|
|
|
100
175
|
})]
|
|
101
176
|
});
|
|
102
177
|
};
|
|
103
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["useState","useMemo","ChevronDown","CUSelect","SearchComponent","SCBackdropInputSelect","SCCUItemsList","SCCUSelectItem","SCWrapperSelectIcon","SCMemberItemContent","SCMemberCheckbox","SCMemberSearchWrapper","jsx","_jsx","jsxs","_jsxs","MembersSelect","_ref","value","membersList","onChange","_useState","_useState2","_slicedToArray","showSelectMembers","setShowSelectMembers","_useState3","_useState4","searchValue","setSearchValue","handleSelectMember","member","memberName","concat","firstName","lastName","currentMembers","split","includes","updatedMembers","filter","m","join","_toConsumableArray","handleSearch","e","target","filteredMembers","searchLower","toLowerCase","title","placeholder","endIcon","isOpen","children","width","height","color","open","handleClickAction","onClick","map","isSelected","stopPropagation","style","backgroundColor","type","checked","readOnly","id"],"sources":["../../../src/components/TeamDetailsModal/MembersSelect.tsx"],"sourcesContent":["import { useState, useMemo, ChangeEvent } from 'react'\nimport { ChevronDown } from '@projectcor/icons/lib/components/ChevronDown'\nimport { CUSelect } from '@projectcor/selector/lib/components/CUSelect'\nimport { SearchComponent } from '../Filters/SearchComponent/SearchComponent'\nimport {\n  SCBackdropInputSelect,\n  SCCUItemsList,\n  SCCUSelectItem,\n  SCWrapperSelectIcon,\n  SCMemberItemContent,\n  SCMemberCheckbox,\n  SCMemberSearchWrapper,\n} from './TeamDetailsModal.styles'\nimport { TeamUser } from './TeamDetailsModal.types'\n\ninterface MembersSelectProps {\n  value: string\n  membersList: TeamUser[]\n  onChange: (value: string) => void\n}\n\nexport const MembersSelect = ({ value, membersList, onChange }: MembersSelectProps) => {\n  const [showSelectMembers, setShowSelectMembers] = useState(false)\n  const [searchValue, setSearchValue] = useState('')\n\n  const handleSelectMember = (member: TeamUser) => {\n    const memberName = `${member.firstName} ${member.lastName}`\n    const currentMembers = value ? value.split(' - ') : []\n\n    if (currentMembers.includes(memberName)) {\n      // Si ya está seleccionado, removerlo\n      const updatedMembers = currentMembers.filter(m => m !== memberName)\n      onChange(updatedMembers.join(' - '))\n    } else {\n      // Si no está seleccionado, agregarlo\n      const updatedMembers = [...currentMembers, memberName]\n      onChange(updatedMembers.join(' - '))\n    }\n    // No cerrar el selector para permitir selección múltiple\n  }\n\n  const handleSearch = (e: ChangeEvent<HTMLInputElement>) => {\n    setSearchValue(e.target.value)\n  }\n\n  const filteredMembers = useMemo(() => {\n    if (!searchValue) return membersList\n    const searchLower = searchValue.toLowerCase()\n    return membersList.filter(\n      member =>\n        member.firstName.toLowerCase().includes(searchLower) ||\n        member.lastName.toLowerCase().includes(searchLower) ||\n        `${member.firstName} ${member.lastName}`.toLowerCase().includes(searchLower)\n    )\n  }, [membersList, searchValue])\n\n  return (\n    <CUSelect\n      title=\"Agregar miembros *\"\n      placeholder=\"Seleccionar miembros\"\n      endIcon={\n        <SCWrapperSelectIcon isOpen={showSelectMembers}>\n          <ChevronDown width=\"16px\" height=\"16px\" color=\"#20201F\" />\n        </SCWrapperSelectIcon>\n      }\n      value={value}\n      open={showSelectMembers}\n      handleClickAction={() => setShowSelectMembers(!showSelectMembers)}\n    >\n      <SCBackdropInputSelect onClick={() => setShowSelectMembers(false)} />\n      <SCCUItemsList>\n        <SCMemberSearchWrapper>\n          <SearchComponent placeholder=\"Buscar miembro\" onChange={handleSearch} value={searchValue} />\n        </SCMemberSearchWrapper>\n        {filteredMembers.map(member => {\n          const memberName = `${member.firstName} ${member.lastName}`\n          const isSelected = value?.includes(memberName) || false\n          return (\n            <SCCUSelectItem\n              key={member.id}\n              onClick={e => {\n                e.stopPropagation()\n                handleSelectMember(member)\n              }}\n              style={{ backgroundColor: isSelected ? '#edfaff' : 'transparent' }}\n            >\n              <SCMemberItemContent>\n                <span>{memberName}</span>\n                <SCMemberCheckbox\n                  type=\"checkbox\"\n                  checked={isSelected}\n                  readOnly\n                  onClick={e => {\n                    e.stopPropagation()\n                    handleSelectMember(member)\n                  }}\n                />\n              </SCMemberItemContent>\n            </SCCUSelectItem>\n          )\n        })}\n      </SCCUItemsList>\n    </CUSelect>\n  )\n}\n"],"mappings":"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","ignoreList":[]}
|
|
178
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["useState","useEffect","useRef","useCallback","ChevronDown","CUSelect","SearchComponent","useGetUsers","useDebounce","SCBackdropInputSelect","SCCUItemsList","SCCUSelectItem","SCWrapperSelectIcon","SCMemberItemContent","SCMemberCheckbox","SCMemberSearchWrapper","jsx","_jsx","jsxs","_jsxs","MembersSelect","_ref","value","onChange","_useState","_useState2","_slicedToArray","showSelectMembers","setShowSelectMembers","_useGetUsers","handleGetUsers","users","currentPage","totalPages","loading","_useState3","_useState4","searchValue","setSearchValue","debouncedSearchValue","_useState5","_useState6","accumulatedUsers","setAccumulatedUsers","scrollContainerRef","isLoadingMoreRef","handleSelectMember","member","alredySelected","some","m","id","filter","concat","_toConsumableArray","name","firstName","lastName","handleSearch","e","target","current","page","searchInput","length","prev","existingIds","Set","map","u","newUsers","has","handleScroll","container","scrollTop","scrollHeight","clientHeight","isNearBottom","undefined","addEventListener","removeEventListener","handleClickActionSelect","title","placeholder","endIcon","isOpen","children","width","height","color","join","open","handleClickAction","onClick","ref","memberName","isSelected","stopPropagation","style","backgroundColor","type","checked","readOnly"],"sources":["../../../src/components/TeamDetailsModal/MembersSelect.tsx"],"sourcesContent":["import { useState, ChangeEvent, useEffect, useRef, useCallback } from 'react'\nimport { ChevronDown } from '@projectcor/icons/lib/components/ChevronDown'\nimport { CUSelect } from '@projectcor/selector/lib/components/CUSelect'\nimport { SearchComponent } from '../Filters/SearchComponent/SearchComponent'\nimport { useGetUsers } from '../../hooks/useGetUsers'\nimport { useDebounce } from '../../hooks/useDebounce'\nimport {\n  SCBackdropInputSelect,\n  SCCUItemsList,\n  SCCUSelectItem,\n  SCWrapperSelectIcon,\n  SCMemberItemContent,\n  SCMemberCheckbox,\n  SCMemberSearchWrapper,\n} from './TeamDetailsModal.styles'\nimport { TeamUser } from './TeamDetailsModal.types'\nimport { User } from '../../types/userType'\n\nexport interface MemberSelection {\n  id: number\n  name: string\n}\n\ninterface MembersSelectProps {\n  value: MemberSelection[]\n  onChange: (input: string, value: MemberSelection[]) => void\n}\n\nexport const MembersSelect = ({ value, onChange }: MembersSelectProps) => {\n  const [showSelectMembers, setShowSelectMembers] = useState(false)\n  const { handleGetUsers, users, currentPage, totalPages, loading } = useGetUsers()\n  const [searchValue, setSearchValue] = useState('')\n  const debouncedSearchValue = useDebounce(searchValue, 300)\n  const [accumulatedUsers, setAccumulatedUsers] = useState<User[]>([])\n  const scrollContainerRef = useRef<HTMLDivElement>(null)\n  const isLoadingMoreRef = useRef(false)\n\n  const handleSelectMember = (member: User | TeamUser) => {\n    const alredySelected = value.some(m => m.id === member.id)\n    if (alredySelected) {\n      onChange(\n        'members',\n        value.filter(m => m.id !== member.id)\n      )\n    } else {\n      onChange('members', [...value, { id: member.id, name: `${member.firstName} ${member.lastName}` }])\n    }\n  }\n\n  const handleSearch = (e: ChangeEvent<HTMLInputElement>) => {\n    setSearchValue(e.target.value)\n  }\n\n  // Resetear usuarios acumulados cuando cambia el search o se abre el selector\n  useEffect(() => {\n    if (showSelectMembers) {\n      setAccumulatedUsers([])\n      isLoadingMoreRef.current = false\n      handleGetUsers({ page: 1, searchInput: debouncedSearchValue })\n    }\n  }, [debouncedSearchValue, showSelectMembers, handleGetUsers])\n\n  // Acumular usuarios cuando se reciben nuevos datos\n  useEffect(() => {\n    if (users.length > 0 && showSelectMembers) {\n      if (currentPage === 1) {\n        // Si es la primera página, reemplazar\n        setAccumulatedUsers(users)\n      } else {\n        // Si es una página posterior, agregar a los existentes\n        setAccumulatedUsers(prev => {\n          // Evitar duplicados\n          const existingIds = new Set(prev.map(u => u.id))\n          const newUsers = users.filter(u => !existingIds.has(u.id))\n          return [...prev, ...newUsers]\n        })\n      }\n      isLoadingMoreRef.current = false\n    }\n  }, [users, currentPage, showSelectMembers])\n\n  const handleScroll = useCallback(() => {\n    const container = scrollContainerRef.current\n    if (!container || loading || isLoadingMoreRef.current) return\n\n    const { scrollTop, scrollHeight, clientHeight } = container\n    const isNearBottom = scrollTop + clientHeight >= scrollHeight - 10 // 10px de margen\n\n    if (isNearBottom && currentPage < totalPages) {\n      isLoadingMoreRef.current = true\n      handleGetUsers({ page: currentPage + 1, searchInput: debouncedSearchValue })\n    }\n  }, [currentPage, totalPages, loading, handleGetUsers, debouncedSearchValue])\n\n  useEffect(() => {\n    const container = scrollContainerRef.current\n    if (!container || !showSelectMembers) return undefined\n\n    container.addEventListener('scroll', handleScroll)\n    return () => {\n      container.removeEventListener('scroll', handleScroll)\n    }\n  }, [handleScroll, showSelectMembers])\n\n  const handleClickActionSelect = () => {\n    setShowSelectMembers(!showSelectMembers)\n    if (!showSelectMembers) {\n      setSearchValue('')\n      setAccumulatedUsers([])\n    }\n  }\n\n  return (\n    <CUSelect\n      title=\"Agregar miembros *\"\n      placeholder=\"Seleccionar miembros\"\n      endIcon={\n        <SCWrapperSelectIcon isOpen={showSelectMembers}>\n          <ChevronDown width=\"16px\" height=\"16px\" color=\"#20201F\" />\n        </SCWrapperSelectIcon>\n      }\n      value={value.map(member => member.name).join(' - ')}\n      open={showSelectMembers}\n      handleClickAction={handleClickActionSelect}\n    >\n      <SCBackdropInputSelect onClick={() => setShowSelectMembers(false)} />\n      <SCCUItemsList ref={scrollContainerRef}>\n        <SCMemberSearchWrapper>\n          <SearchComponent placeholder=\"Buscar miembro\" onChange={handleSearch} value={searchValue} />\n        </SCMemberSearchWrapper>\n        {accumulatedUsers.map(member => {\n          const memberName = `${member.firstName} ${member.lastName}`\n          const isSelected = value?.some(m => m.id === member.id) || false\n          return (\n            <SCCUSelectItem\n              key={member.id}\n              onClick={e => {\n                e.stopPropagation()\n                handleSelectMember(member)\n              }}\n              style={{ backgroundColor: isSelected ? '#edfaff' : 'transparent' }}\n            >\n              <SCMemberItemContent>\n                <span>{memberName}</span>\n                <SCMemberCheckbox\n                  type=\"checkbox\"\n                  checked={isSelected}\n                  readOnly\n                  onClick={e => {\n                    e.stopPropagation()\n                    handleSelectMember(member)\n                  }}\n                />\n              </SCMemberItemContent>\n            </SCCUSelectItem>\n          )\n        })}\n      </SCCUItemsList>\n    </CUSelect>\n  )\n}\n"],"mappings":";;AAAA,SAASA,QAAQ,EAAeC,SAAS,EAAEC,MAAM,EAAEC,WAAW,QAAQ,OAAO;AAC7E,SAASC,WAAW,QAAQ,8CAA8C;AAC1E,SAASC,QAAQ,QAAQ,8CAA8C;AACvE,SAASC,eAAe,QAAQ,4CAA4C;AAC5E,SAASC,WAAW,QAAQ,yBAAyB;AACrD,SAASC,WAAW,QAAQ,yBAAyB;AACrD,SACEC,qBAAqB,EACrBC,aAAa,EACbC,cAAc,EACdC,mBAAmB,EACnBC,mBAAmB,EACnBC,gBAAgB,EAChBC,qBAAqB,QAChB,2BAA2B;AAAA,SAAAC,GAAA,IAAAC,IAAA,EAAAC,IAAA,IAAAC,KAAA;AAclC,OAAO,IAAMC,aAAa,GAAG,SAAhBA,aAAaA,CAAAC,IAAA,EAAgD;EAAA,IAA1CC,KAAK,GAAAD,IAAA,CAALC,KAAK;IAAEC,QAAQ,GAAAF,IAAA,CAARE,QAAQ;EAC7C,IAAAC,SAAA,GAAkDxB,QAAQ,CAAC,KAAK,CAAC;IAAAyB,UAAA,GAAAC,cAAA,CAAAF,SAAA;IAA1DG,iBAAiB,GAAAF,UAAA;IAAEG,oBAAoB,GAAAH,UAAA;EAC9C,IAAAI,YAAA,GAAoEtB,WAAW,CAAC,CAAC;IAAzEuB,cAAc,GAAAD,YAAA,CAAdC,cAAc;IAAEC,KAAK,GAAAF,YAAA,CAALE,KAAK;IAAEC,WAAW,GAAAH,YAAA,CAAXG,WAAW;IAAEC,UAAU,GAAAJ,YAAA,CAAVI,UAAU;IAAEC,OAAO,GAAAL,YAAA,CAAPK,OAAO;EAC/D,IAAAC,UAAA,GAAsCnC,QAAQ,CAAC,EAAE,CAAC;IAAAoC,UAAA,GAAAV,cAAA,CAAAS,UAAA;IAA3CE,WAAW,GAAAD,UAAA;IAAEE,cAAc,GAAAF,UAAA;EAClC,IAAMG,oBAAoB,GAAG/B,WAAW,CAAC6B,WAAW,EAAE,GAAG,CAAC;EAC1D,IAAAG,UAAA,GAAgDxC,QAAQ,CAAS,EAAE,CAAC;IAAAyC,UAAA,GAAAf,cAAA,CAAAc,UAAA;IAA7DE,gBAAgB,GAAAD,UAAA;IAAEE,mBAAmB,GAAAF,UAAA;EAC5C,IAAMG,kBAAkB,GAAG1C,MAAM,CAAiB,IAAI,CAAC;EACvD,IAAM2C,gBAAgB,GAAG3C,MAAM,CAAC,KAAK,CAAC;EAEtC,IAAM4C,kBAAkB,GAAG,SAArBA,kBAAkBA,CAAIC,MAAuB,EAAK;IACtD,IAAMC,cAAc,GAAG1B,KAAK,CAAC2B,IAAI,CAAC,UAAAC,CAAC;MAAA,OAAIA,CAAC,CAACC,EAAE,KAAKJ,MAAM,CAACI,EAAE;IAAA,EAAC;IAC1D,IAAIH,cAAc,EAAE;MAClBzB,QAAQ,CACN,SAAS,EACTD,KAAK,CAAC8B,MAAM,CAAC,UAAAF,CAAC;QAAA,OAAIA,CAAC,CAACC,EAAE,KAAKJ,MAAM,CAACI,EAAE;MAAA,EACtC,CAAC;IACH,CAAC,MAAM;MACL5B,QAAQ,CAAC,SAAS,KAAA8B,MAAA,CAAAC,kBAAA,CAAMhC,KAAK,IAAE;QAAE6B,EAAE,EAAEJ,MAAM,CAACI,EAAE;QAAEI,IAAI,KAAAF,MAAA,CAAKN,MAAM,CAACS,SAAS,OAAAH,MAAA,CAAIN,MAAM,CAACU,QAAQ;MAAG,CAAC,EAAC,CAAC;IACpG;EACF,CAAC;EAED,IAAMC,YAAY,GAAG,SAAfA,YAAYA,CAAIC,CAAgC,EAAK;IACzDrB,cAAc,CAACqB,CAAC,CAACC,MAAM,CAACtC,KAAK,CAAC;EAChC,CAAC;;EAED;EACArB,SAAS,CAAC,YAAM;IACd,IAAI0B,iBAAiB,EAAE;MACrBgB,mBAAmB,CAAC,EAAE,CAAC;MACvBE,gBAAgB,CAACgB,OAAO,GAAG,KAAK;MAChC/B,cAAc,CAAC;QAAEgC,IAAI,EAAE,CAAC;QAAEC,WAAW,EAAExB;MAAqB,CAAC,CAAC;IAChE;EACF,CAAC,EAAE,CAACA,oBAAoB,EAAEZ,iBAAiB,EAAEG,cAAc,CAAC,CAAC;;EAE7D;EACA7B,SAAS,CAAC,YAAM;IACd,IAAI8B,KAAK,CAACiC,MAAM,GAAG,CAAC,IAAIrC,iBAAiB,EAAE;MACzC,IAAIK,WAAW,KAAK,CAAC,EAAE;QACrB;QACAW,mBAAmB,CAACZ,KAAK,CAAC;MAC5B,CAAC,MAAM;QACL;QACAY,mBAAmB,CAAC,UAAAsB,IAAI,EAAI;UAC1B;UACA,IAAMC,WAAW,GAAG,IAAIC,GAAG,CAACF,IAAI,CAACG,GAAG,CAAC,UAAAC,CAAC;YAAA,OAAIA,CAAC,CAAClB,EAAE;UAAA,EAAC,CAAC;UAChD,IAAMmB,QAAQ,GAAGvC,KAAK,CAACqB,MAAM,CAAC,UAAAiB,CAAC;YAAA,OAAI,CAACH,WAAW,CAACK,GAAG,CAACF,CAAC,CAAClB,EAAE,CAAC;UAAA,EAAC;UAC1D,UAAAE,MAAA,CAAAC,kBAAA,CAAWW,IAAI,GAAAX,kBAAA,CAAKgB,QAAQ;QAC9B,CAAC,CAAC;MACJ;MACAzB,gBAAgB,CAACgB,OAAO,GAAG,KAAK;IAClC;EACF,CAAC,EAAE,CAAC9B,KAAK,EAAEC,WAAW,EAAEL,iBAAiB,CAAC,CAAC;EAE3C,IAAM6C,YAAY,GAAGrE,WAAW,CAAC,YAAM;IACrC,IAAMsE,SAAS,GAAG7B,kBAAkB,CAACiB,OAAO;IAC5C,IAAI,CAACY,SAAS,IAAIvC,OAAO,IAAIW,gBAAgB,CAACgB,OAAO,EAAE;IAEvD,IAAQa,SAAS,GAAiCD,SAAS,CAAnDC,SAAS;MAAEC,YAAY,GAAmBF,SAAS,CAAxCE,YAAY;MAAEC,YAAY,GAAKH,SAAS,CAA1BG,YAAY;IAC7C,IAAMC,YAAY,GAAGH,SAAS,GAAGE,YAAY,IAAID,YAAY,GAAG,EAAE,EAAC;;IAEnE,IAAIE,YAAY,IAAI7C,WAAW,GAAGC,UAAU,EAAE;MAC5CY,gBAAgB,CAACgB,OAAO,GAAG,IAAI;MAC/B/B,cAAc,CAAC;QAAEgC,IAAI,EAAE9B,WAAW,GAAG,CAAC;QAAE+B,WAAW,EAAExB;MAAqB,CAAC,CAAC;IAC9E;EACF,CAAC,EAAE,CAACP,WAAW,EAAEC,UAAU,EAAEC,OAAO,EAAEJ,cAAc,EAAES,oBAAoB,CAAC,CAAC;EAE5EtC,SAAS,CAAC,YAAM;IACd,IAAMwE,SAAS,GAAG7B,kBAAkB,CAACiB,OAAO;IAC5C,IAAI,CAACY,SAAS,IAAI,CAAC9C,iBAAiB,EAAE,OAAOmD,SAAS;IAEtDL,SAAS,CAACM,gBAAgB,CAAC,QAAQ,EAAEP,YAAY,CAAC;IAClD,OAAO,YAAM;MACXC,SAAS,CAACO,mBAAmB,CAAC,QAAQ,EAAER,YAAY,CAAC;IACvD,CAAC;EACH,CAAC,EAAE,CAACA,YAAY,EAAE7C,iBAAiB,CAAC,CAAC;EAErC,IAAMsD,uBAAuB,GAAG,SAA1BA,uBAAuBA,CAAA,EAAS;IACpCrD,oBAAoB,CAAC,CAACD,iBAAiB,CAAC;IACxC,IAAI,CAACA,iBAAiB,EAAE;MACtBW,cAAc,CAAC,EAAE,CAAC;MAClBK,mBAAmB,CAAC,EAAE,CAAC;IACzB;EACF,CAAC;EAED,oBACExB,KAAA,CAACd,QAAQ;IACP6E,KAAK,EAAC,oBAAoB;IAC1BC,WAAW,EAAC,sBAAsB;IAClCC,OAAO,eACLnE,IAAA,CAACL,mBAAmB;MAACyE,MAAM,EAAE1D,iBAAkB;MAAA2D,QAAA,eAC7CrE,IAAA,CAACb,WAAW;QAACmF,KAAK,EAAC,MAAM;QAACC,MAAM,EAAC,MAAM;QAACC,KAAK,EAAC;MAAS,CAAE;IAAC,CACvC,CACtB;IACDnE,KAAK,EAAEA,KAAK,CAAC8C,GAAG,CAAC,UAAArB,MAAM;MAAA,OAAIA,MAAM,CAACQ,IAAI;IAAA,EAAC,CAACmC,IAAI,CAAC,KAAK,CAAE;IACpDC,IAAI,EAAEhE,iBAAkB;IACxBiE,iBAAiB,EAAEX,uBAAwB;IAAAK,QAAA,gBAE3CrE,IAAA,CAACR,qBAAqB;MAACoF,OAAO,EAAE,SAATA,OAAOA,CAAA;QAAA,OAAQjE,oBAAoB,CAAC,KAAK,CAAC;MAAA;IAAC,CAAE,CAAC,eACrET,KAAA,CAACT,aAAa;MAACoF,GAAG,EAAElD,kBAAmB;MAAA0C,QAAA,gBACrCrE,IAAA,CAACF,qBAAqB;QAAAuE,QAAA,eACpBrE,IAAA,CAACX,eAAe;UAAC6E,WAAW,EAAC,gBAAgB;UAAC5D,QAAQ,EAAEmC,YAAa;UAACpC,KAAK,EAAEe;QAAY,CAAE;MAAC,CACvE,CAAC,EACvBK,gBAAgB,CAAC0B,GAAG,CAAC,UAAArB,MAAM,EAAI;QAC9B,IAAMgD,UAAU,MAAA1C,MAAA,CAAMN,MAAM,CAACS,SAAS,OAAAH,MAAA,CAAIN,MAAM,CAACU,QAAQ,CAAE;QAC3D,IAAMuC,UAAU,GAAG,CAAA1E,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAE2B,IAAI,CAAC,UAAAC,CAAC;UAAA,OAAIA,CAAC,CAACC,EAAE,KAAKJ,MAAM,CAACI,EAAE;QAAA,EAAC,KAAI,KAAK;QAChE,oBACElC,IAAA,CAACN,cAAc;UAEbkF,OAAO,EAAE,SAATA,OAAOA,CAAElC,CAAC,EAAI;YACZA,CAAC,CAACsC,eAAe,CAAC,CAAC;YACnBnD,kBAAkB,CAACC,MAAM,CAAC;UAC5B,CAAE;UACFmD,KAAK,EAAE;YAAEC,eAAe,EAAEH,UAAU,GAAG,SAAS,GAAG;UAAc,CAAE;UAAAV,QAAA,eAEnEnE,KAAA,CAACN,mBAAmB;YAAAyE,QAAA,gBAClBrE,IAAA;cAAAqE,QAAA,EAAOS;YAAU,CAAO,CAAC,eACzB9E,IAAA,CAACH,gBAAgB;cACfsF,IAAI,EAAC,UAAU;cACfC,OAAO,EAAEL,UAAW;cACpBM,QAAQ;cACRT,OAAO,EAAE,SAATA,OAAOA,CAAElC,CAAC,EAAI;gBACZA,CAAC,CAACsC,eAAe,CAAC,CAAC;gBACnBnD,kBAAkB,CAACC,MAAM,CAAC;cAC5B;YAAE,CACH,CAAC;UAAA,CACiB;QAAC,GAlBjBA,MAAM,CAACI,EAmBE,CAAC;MAErB,CAAC,CAAC;IAAA,CACW,CAAC;EAAA,CACR,CAAC;AAEf,CAAC","ignoreList":[]}
|