@projectcor/people-microfront 1.0.2-2 → 1.0.2-21

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 (99) hide show
  1. package/lib/App.js +1 -43
  2. package/lib/App.stories.js +25 -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/EmptyStateTeams/EmptyStateTeams.js +2 -2
  9. package/lib/components/EmptyUser/EmptyUser.js +7 -48
  10. package/lib/components/EmptyUser/EmptyUser.styles.js +18 -0
  11. package/lib/components/Filters/FilterChip/FilterChip.js +12 -9
  12. package/lib/components/Filters/FilterChip/FilterChip.styles.js +6 -0
  13. package/lib/components/HeaderTeams/HeaderTeams.js +2 -2
  14. package/lib/components/Illustration/EmptyFilter.js +67 -0
  15. package/lib/components/Layout/Layout.js +23 -2
  16. package/lib/components/Layout/Layout.styles.js +16 -1
  17. package/lib/components/Layout/index.js +2 -3
  18. package/lib/components/MenuOptions/MenuOptions.js +4 -18
  19. package/lib/components/ModalBloquedUser/ModalBloquedUser.js +5 -28
  20. package/lib/components/ModalBloquedUser/ModalBloquedUser.styles.js +14 -0
  21. package/lib/components/ModalEditUserPosition/ModalEditUserPosition.js +17 -52
  22. package/lib/components/ModalEditUserPosition/ModalEditUserPosition.styles.js +36 -0
  23. package/lib/components/ModalEditUserPosition/UserEditPositionRow.js +28 -105
  24. package/lib/components/ModalEditUserPosition/UserEditPositionRow.styles.js +55 -1
  25. package/lib/components/ModalOptionsWithSearch/ModalOptionsWithSearch.js +11 -4
  26. package/lib/components/ModalOptionsWithSearch/ModalOptionsWithSearch.styles.js +5 -1
  27. package/lib/components/Pagination/Pagination.styles.js +5 -1
  28. package/lib/components/Pagination/PaginationView.js +80 -0
  29. package/lib/components/Search/Search.js +4 -4
  30. package/lib/components/Table/Header/HeaderTable.js +5 -21
  31. package/lib/components/Table/Header/HeaderTable.styles.js +14 -0
  32. package/lib/components/Table/Row/Row.js +61 -21
  33. package/lib/components/Table/Row/Row.styles.js +33 -9
  34. package/lib/components/Table/TeamRow/AddMemberModal/AddMemberModal.js +65 -0
  35. package/lib/components/Table/TeamRow/AddMemberModal/AddMemberModal.styles.js +38 -0
  36. package/lib/components/Table/TeamRow/AddMemberModal/index.js +2 -0
  37. package/lib/components/Table/TeamRow/AddUsers/AddUsers.js +185 -0
  38. package/lib/components/Table/TeamRow/AddUsers/AddUsers.styles.js +25 -0
  39. package/lib/components/Table/TeamRow/AddUsers/index.js +2 -0
  40. package/lib/components/Table/TeamRow/RemoveMemberModal/RemoveMemberModal.js +65 -0
  41. package/lib/components/Table/TeamRow/RemoveMemberModal/RemoveMemberModal.styles.js +38 -0
  42. package/lib/components/Table/TeamRow/RemoveMemberModal/index.js +2 -0
  43. package/lib/components/Table/TeamRow/TeamRow.js +76 -63
  44. package/lib/components/Table/TeamRow/TeamRow.styles.js +6 -0
  45. package/lib/components/Table/TeamRow/UsersRow/UsersRow.js +191 -0
  46. package/lib/components/Table/TeamRow/UsersRow/UsersRow.styles.js +40 -0
  47. package/lib/components/Table/TeamRow/UsersRow/index.js +2 -0
  48. package/lib/components/TeamDetailsModal/MembersSelect.js +104 -31
  49. package/lib/components/TeamDetailsModal/TeamDetailsModal.js +73 -77
  50. package/lib/components/TeamDetailsModal/TeamDetailsModal.styles.js +19 -11
  51. package/lib/components/TeamDetailsModal/TeamDetailsModal.types.js +1 -1
  52. package/lib/components/TeamDetailsModal/index.js +1 -1
  53. package/lib/components/UserRow/UserRow.js +17 -66
  54. package/lib/components/UserRow/UserRow.styles.js +30 -2
  55. package/lib/container/Body/BodyContainer.js +3 -8
  56. package/lib/container/Body/BodyContainerViewTeams.js +72 -98
  57. package/lib/container/Filters/FiltersContainer.js +44 -16
  58. package/lib/container/MainView/MainTeamsView.js +36 -0
  59. package/lib/container/MainView/MainUsersView.js +51 -81
  60. package/lib/container/MainView/MainUsersView.styles.js +32 -0
  61. package/lib/container/MainView/MainView.js +21 -41
  62. package/lib/container/Pagination/PaginationContainer.js +10 -123
  63. package/lib/container/Pagination/PaginationTeamsContainer.js +32 -0
  64. package/lib/container/RouterComponent/RouterComponent.js +20 -31
  65. package/lib/container/RouterComponent/RouterComponent.stories.js +1 -3
  66. package/lib/container/RouterComponent/RouterComponent.styles.js +26 -0
  67. package/lib/container/TableContainer/TableContainer.js +17 -9
  68. package/lib/context/TeamsContext.js +5 -2
  69. package/lib/context/UsersContext.js +77 -22
  70. package/lib/hooks/useAbortController.js +15 -11
  71. package/lib/hooks/useAssignUserToTeam.js +78 -0
  72. package/lib/hooks/useCreateTeams.js +67 -0
  73. package/lib/hooks/useDeleteTeam.js +67 -0
  74. package/lib/hooks/useGetTeams.js +8 -4
  75. package/lib/hooks/useGetTotalPositions.js +24 -0
  76. package/lib/hooks/useGetTotalTeams.js +24 -0
  77. package/lib/hooks/useGetUsers.js +25 -8
  78. package/lib/hooks/useGetUsersForFilter.js +1 -2
  79. package/lib/hooks/useGraphAdapter.js +19 -8
  80. package/lib/hooks/useResize.js +9 -4
  81. package/lib/hooks/useUnassignUserFromTeam.js +67 -0
  82. package/lib/hooks/useUpdateTeam.js +65 -0
  83. package/lib/lang/i18nextForWeb.js +2 -2
  84. package/lib/lang/translation/br.json +21 -4
  85. package/lib/lang/translation/en.json +58 -41
  86. package/lib/lang/translation/es.json +21 -4
  87. package/lib/lang/translation/fr.json +86 -69
  88. package/lib/mocks/mockedUser.js +7 -1
  89. package/lib/query/assignUserToTeam.js +5 -0
  90. package/lib/query/createTeam.js +5 -0
  91. package/lib/query/deleteTeam.js +5 -0
  92. package/lib/query/getTeams.js +2 -2
  93. package/lib/query/getTotalPositions.js +5 -0
  94. package/lib/query/getTotalTeams.js +5 -0
  95. package/lib/query/getUsers.js +2 -2
  96. package/lib/query/unassignUserFromTeam.js +5 -0
  97. package/lib/query/updateTeam.js +5 -0
  98. package/lib/types/global.d.js +1 -1
  99. package/package.json +2 -2
@@ -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, useMemo } from 'react';
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 memberName = "".concat(member.firstName, " ").concat(member.lastName);
23
- var currentMembers = value ? value.split(' - ') : [];
24
- if (currentMembers.includes(memberName)) {
25
- // Si ya está seleccionado, removerlo
26
- var updatedMembers = currentMembers.filter(function (m) {
27
- return m !== memberName;
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
- // Si no está seleccionado, agregarlo
32
- var _updatedMembers = [].concat(_toConsumableArray(currentMembers), [memberName]);
33
- onChange(_updatedMembers.join(' - '));
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
- var filteredMembers = useMemo(function () {
41
- if (!searchValue) return membersList;
42
- var searchLower = searchValue.toLowerCase();
43
- return membersList.filter(function (member) {
44
- return member.firstName.toLowerCase().includes(searchLower) || member.lastName.toLowerCase().includes(searchLower) || "".concat(member.firstName, " ").concat(member.lastName).toLowerCase().includes(searchLower);
45
- });
46
- }, [membersList, searchValue]);
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,33 +127,34 @@ 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: function 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
- }), filteredMembers.map(function (member) {
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.includes(memberName)) || false;
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();
80
155
  handleSelectMember(member);
81
156
  },
82
- style: {
83
- backgroundColor: isSelected ? '#edfaff' : 'transparent'
84
- },
157
+ isSelected: isSelected,
85
158
  children: /*#__PURE__*/_jsxs(SCMemberItemContent, {
86
159
  children: [/*#__PURE__*/_jsx("span", {
87
160
  children: memberName
@@ -100,4 +173,4 @@ export var MembersSelect = function MembersSelect(_ref) {
100
173
  })]
101
174
  });
102
175
  };
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":[]}
176
+ //# 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","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              isSelected={isSelected}\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":[]}