@projectcor/people-microfront 1.0.1
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/App.js +64 -0
- package/lib/App.stories.js +104 -0
- package/lib/Providers.js +26 -0
- package/lib/components/Backdrop/Background.interface.js +2 -0
- package/lib/components/Backdrop/Background.js +12 -0
- package/lib/components/Backdrop/Background.style.js +9 -0
- package/lib/components/Backdrop/index.js +2 -0
- package/lib/components/DeletedUserIcon/DeletedUserIcon.js +20 -0
- package/lib/components/DeletedUserIcon/DeletedUserIcon.styles.js +7 -0
- package/lib/components/DeletedUserIcon/index.js +2 -0
- package/lib/components/DisabledUserIcon/DisabledUserIcon.js +24 -0
- package/lib/components/DisabledUserIcon/DisabledUserIcon.styles.js +7 -0
- package/lib/components/DisabledUserIcon/index.js +2 -0
- package/lib/components/EmptyUser/EmptyUser.js +59 -0
- package/lib/components/EmptyUser/index.js +3 -0
- package/lib/components/ErrorComponent/ErrorComponent.js +24 -0
- package/lib/components/ErrorComponent/ErrorComponent.spec.js +29 -0
- package/lib/components/ErrorComponent/ErrorComponent.styles.js +19 -0
- package/lib/components/ErrorComponent/index.js +2 -0
- package/lib/components/Filters/FilterChip/FilterChip.js +106 -0
- package/lib/components/Filters/FilterChip/index.js +2 -0
- package/lib/components/Filters/LabelFilter/LabelFilter.js +87 -0
- package/lib/components/Filters/LabelFilter/LabelFilter.styles.js +32 -0
- package/lib/components/Filters/SearchComponent/SearchComponent.js +26 -0
- package/lib/components/Filters/SearchComponent/SearchComponent.styles.js +16 -0
- package/lib/components/Filters/SearchComponent/index.js +2 -0
- package/lib/components/Filters/index.js +2 -0
- package/lib/components/Icons/UserBlockIcon.js +25 -0
- package/lib/components/Icons/UserIconLock.js +42 -0
- package/lib/components/Icons/UserIconWithCross.js +20 -0
- package/lib/components/Icons/index.js +4 -0
- package/lib/components/Illustration/EmptyUser.js +141 -0
- package/lib/components/Illustration/index.js +2 -0
- package/lib/components/Loading/LoadingComponent.js +11 -0
- package/lib/components/Loading/LoadingComponent.style.js +6 -0
- package/lib/components/Loading/index.js +2 -0
- package/lib/components/MenuOptions/MenuOptions.js +147 -0
- package/lib/components/MenuOptions/MenuOptions.styles.js +14 -0
- package/lib/components/MenuOptions/index.js +2 -0
- package/lib/components/Modal/ModalLayout.interface.js +2 -0
- package/lib/components/Modal/ModalLayout.js +25 -0
- package/lib/components/Modal/ModalLayout.style.js +26 -0
- package/lib/components/Modal/index.js +2 -0
- package/lib/components/ModalBloquedUser/ModalBloquedUser.js +67 -0
- package/lib/components/ModalBloquedUser/index.js +2 -0
- package/lib/components/ModalEditUserPosition/ModalEditUserPosition.js +171 -0
- package/lib/components/ModalEditUserPosition/UserEditPositionRow.js +327 -0
- package/lib/components/ModalEditUserPosition/UserEditPositionRow.styles.js +6 -0
- package/lib/components/ModalEditUserPosition/index.js +2 -0
- package/lib/components/ModalOptionsWithSearch/ConfirmButton.js +16 -0
- package/lib/components/ModalOptionsWithSearch/ModalOptionsWithSearch.js +76 -0
- package/lib/components/ModalOptionsWithSearch/ModalOptionsWithSearch.styles.js +21 -0
- package/lib/components/ModalOptionsWithSearch/SearchInput.js +14 -0
- package/lib/components/Search/InputSearch.js +22 -0
- package/lib/components/Search/Search.js +34 -0
- package/lib/components/Search/Search.styles.js +15 -0
- package/lib/components/Search/index.js +2 -0
- package/lib/components/Snackbar/Snackbar.interface.js +2 -0
- package/lib/components/Snackbar/Snackbar.js +35 -0
- package/lib/components/Snackbar/Snackbar.styles.js +18 -0
- package/lib/components/Snackbar/index.js +2 -0
- package/lib/components/Table/Content/ContentTable.js +7 -0
- package/lib/components/Table/Content/index.js +2 -0
- package/lib/components/Table/Header/HeaderTable.js +212 -0
- package/lib/components/Table/Header/index.js +2 -0
- package/lib/components/Table/Row/Row.js +66 -0
- package/lib/components/Table/Row/Row.styles.js +27 -0
- package/lib/components/Table/Row/index.js +2 -0
- package/lib/components/UserRow/UserRow.js +129 -0
- package/lib/components/UserRow/UserRow.stories.js +17 -0
- package/lib/components/UserRow/UserRow.styles.js +19 -0
- package/lib/constants/gqlClient.js +4 -0
- package/lib/container/Body/BodyContainer.js +109 -0
- package/lib/container/Filters/FiltersContainer.js +168 -0
- package/lib/container/MainView/MainUsersView.js +184 -0
- package/lib/container/MainView/MainView.js +117 -0
- package/lib/container/Pagination/PaginationContainer.js +145 -0
- package/lib/container/RouterComponent/RouterComponent.js +130 -0
- package/lib/container/RouterComponent/RouterComponent.stories.js +14 -0
- package/lib/container/RouterComponent/index.js +2 -0
- package/lib/container/TableContainer/TableContainer.js +41 -0
- package/lib/container/index.js +2 -0
- package/lib/context/UsersContext.js +145 -0
- package/lib/hooks/useAbortController.js +17 -0
- package/lib/hooks/useDebounce.js +18 -0
- package/lib/hooks/useGetTeams.js +30 -0
- package/lib/hooks/useGetUserPositionFilter.js +29 -0
- package/lib/hooks/useGetUsers.js +100 -0
- package/lib/hooks/useGetUsersForFilter.js +52 -0
- package/lib/hooks/useGraphAdapter.js +60 -0
- package/lib/hooks/useResize.js +29 -0
- package/lib/hooks/useSearchEvent.js +18 -0
- package/lib/hooks/useUnblockUser.js +131 -0
- package/lib/hooks/useUpdateUserPositions.js +58 -0
- package/lib/hooks/useUserPositionCategories.js +38 -0
- package/lib/index.css +28 -0
- package/lib/index.js +10 -0
- package/lib/lang/i18next.js +19 -0
- package/lib/lang/i18nextForWeb.js +22 -0
- package/lib/lang/resource.js +11 -0
- package/lib/lang/translation/br.json +69 -0
- package/lib/lang/translation/en.json +69 -0
- package/lib/lang/translation/es.json +69 -0
- package/lib/lang/translation/fr.json +69 -0
- package/lib/mocks/mockedUser.js +95 -0
- package/lib/query/getTeams.js +5 -0
- package/lib/query/getUserPositionCategory.js +5 -0
- package/lib/query/getUserPositionFilter.js +5 -0
- package/lib/query/getUsers.js +5 -0
- package/lib/query/updateUserPosition.js +5 -0
- package/lib/query/userUnblock.js +5 -0
- package/lib/types/global.d.js +2 -0
- package/lib/types/userType.d.js +2 -0
- package/lib/utils/ApolloMicroServiceClient.js +3 -0
- package/package.json +174 -0
- package/readme.md +87 -0
|
@@ -0,0 +1,184 @@
|
|
|
1
|
+
import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
|
|
2
|
+
import { memo, useState, useRef, useEffect, useCallback, useMemo } from 'react';
|
|
3
|
+
import { useTranslation } from 'react-i18next';
|
|
4
|
+
import { GroupByButton } from '@projectcor/group-by-button/lib/components/GroupByButton';
|
|
5
|
+
import { CUButton } from '@projectcor/button/lib/components/CUButton';
|
|
6
|
+
import { Tooltip } from '@projectcor/tooltipv2/lib/components/Tooltip';
|
|
7
|
+
import { FileUpload } from '@projectcor/icons/lib/components/FileUpload';
|
|
8
|
+
import { FiltersContainer } from '../Filters/FiltersContainer';
|
|
9
|
+
import { useGetUserPositionFilter } from '../../hooks/useGetUserPositionFilter';
|
|
10
|
+
import { useUsersQuery, useUsersEditPositions } from '../../context/UsersContext';
|
|
11
|
+
import { TableContainer } from '../TableContainer/TableContainer';
|
|
12
|
+
import { ModalEditUserPosition } from '../../components/ModalEditUserPosition';
|
|
13
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
14
|
+
export var MainUsersView = /*#__PURE__*/memo(function MainUsersView() {
|
|
15
|
+
var _useTranslation = useTranslation('people'),
|
|
16
|
+
t = _useTranslation.t;
|
|
17
|
+
var _useUsersQuery = useUsersQuery(),
|
|
18
|
+
handleGetUsers = _useUsersQuery.handleGetUsers,
|
|
19
|
+
loading = _useUsersQuery.loading,
|
|
20
|
+
error = _useUsersQuery.error,
|
|
21
|
+
users = _useUsersQuery.users,
|
|
22
|
+
handleSetPositions = _useUsersQuery.handleSetPositions,
|
|
23
|
+
positions = _useUsersQuery.positions;
|
|
24
|
+
var _useUsersEditPosition = useUsersEditPositions(),
|
|
25
|
+
handleSetHasEditPositions = _useUsersEditPosition.handleSetHasEditPositions,
|
|
26
|
+
hasEditPositions = _useUsersEditPosition.hasEditPositions,
|
|
27
|
+
usersToEditPositions = _useUsersEditPosition.usersToEditPositions;
|
|
28
|
+
var _useState = useState(false),
|
|
29
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
30
|
+
showModalEditUserPosition = _useState2[0],
|
|
31
|
+
setShowModalEditUserPosition = _useState2[1];
|
|
32
|
+
var _useGetUserPositionFi = useGetUserPositionFilter(),
|
|
33
|
+
handleGetUserPositionFilter = _useGetUserPositionFi.handleGetUserPositionFilter,
|
|
34
|
+
positionLoading = _useGetUserPositionFi.loading,
|
|
35
|
+
positionError = _useGetUserPositionFi.error,
|
|
36
|
+
positionData = _useGetUserPositionFi.data;
|
|
37
|
+
var hasFetchedPositions = useRef(false);
|
|
38
|
+
useEffect(function () {
|
|
39
|
+
if (!hasFetchedPositions.current && !(positions !== null && positions !== void 0 && positions.length)) {
|
|
40
|
+
hasFetchedPositions.current = true;
|
|
41
|
+
handleGetUserPositionFilter('');
|
|
42
|
+
}
|
|
43
|
+
}, [handleGetUserPositionFilter, positions]);
|
|
44
|
+
useEffect(function () {
|
|
45
|
+
if (positionData !== null && positionData !== void 0 && positionData.userPositionsFilter && !positionLoading && !positionError) {
|
|
46
|
+
var mappedPositions = positionData.userPositionsFilter.data.map(function (position) {
|
|
47
|
+
return {
|
|
48
|
+
id: position.id,
|
|
49
|
+
label: position.name,
|
|
50
|
+
categoryName: position.categoryName
|
|
51
|
+
};
|
|
52
|
+
});
|
|
53
|
+
handleSetPositions(mappedPositions);
|
|
54
|
+
}
|
|
55
|
+
}, [positionData, positionLoading, positionError, handleSetPositions]);
|
|
56
|
+
var handleChangePage = useCallback(function (page) {
|
|
57
|
+
handleGetUsers({
|
|
58
|
+
page: page
|
|
59
|
+
});
|
|
60
|
+
}, [handleGetUsers]);
|
|
61
|
+
var groupBySections = useMemo(function () {
|
|
62
|
+
return [{
|
|
63
|
+
id: 1,
|
|
64
|
+
title: t('users.view')
|
|
65
|
+
}, {
|
|
66
|
+
id: 2,
|
|
67
|
+
title: t('users.editPositionTitle')
|
|
68
|
+
}];
|
|
69
|
+
}, [t]);
|
|
70
|
+
var handleChangeSection = useCallback(function (prop) {
|
|
71
|
+
handleSetHasEditPositions(prop.id === 2);
|
|
72
|
+
}, [handleSetHasEditPositions]);
|
|
73
|
+
var handleShowModalEditUserPosition = useCallback(function () {
|
|
74
|
+
setShowModalEditUserPosition(true);
|
|
75
|
+
}, []);
|
|
76
|
+
var handleCloseModalEditUserPosition = useCallback(function () {
|
|
77
|
+
setShowModalEditUserPosition(false);
|
|
78
|
+
}, []);
|
|
79
|
+
var handleEditPositionsSuccess = useCallback(function () {
|
|
80
|
+
setShowModalEditUserPosition(false);
|
|
81
|
+
handleSetHasEditPositions(false);
|
|
82
|
+
}, [handleSetHasEditPositions]);
|
|
83
|
+
var handleGoToImport = useCallback(function () {
|
|
84
|
+
window.location.href = '/users/import';
|
|
85
|
+
}, []);
|
|
86
|
+
var handleGoToCreate = useCallback(function () {
|
|
87
|
+
window.location.href = '/users/create';
|
|
88
|
+
}, []);
|
|
89
|
+
return /*#__PURE__*/_jsxs(_Fragment, {
|
|
90
|
+
children: [/*#__PURE__*/_jsxs("div", {
|
|
91
|
+
style: {
|
|
92
|
+
display: 'flex',
|
|
93
|
+
flexDirection: 'column',
|
|
94
|
+
gap: '10px',
|
|
95
|
+
width: '100%',
|
|
96
|
+
height: '100%',
|
|
97
|
+
paddingTop: '20px'
|
|
98
|
+
},
|
|
99
|
+
children: [/*#__PURE__*/_jsxs("div", {
|
|
100
|
+
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: {
|
|
125
|
+
display: 'flex',
|
|
126
|
+
alignItems: 'center',
|
|
127
|
+
justifyContent: 'space-between',
|
|
128
|
+
position: 'sticky',
|
|
129
|
+
top: 40,
|
|
130
|
+
backgroundColor: 'white',
|
|
131
|
+
zIndex: 2,
|
|
132
|
+
padding: '10px'
|
|
133
|
+
},
|
|
134
|
+
children: [/*#__PURE__*/_jsx(FiltersContainer, {
|
|
135
|
+
handleGetUserPositionFilter: handleGetUserPositionFilter
|
|
136
|
+
}), /*#__PURE__*/_jsxs("div", {
|
|
137
|
+
style: {
|
|
138
|
+
display: 'flex',
|
|
139
|
+
alignItems: 'center',
|
|
140
|
+
gap: '10px',
|
|
141
|
+
justifyContent: 'center'
|
|
142
|
+
},
|
|
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"
|
|
162
|
+
})
|
|
163
|
+
})
|
|
164
|
+
})
|
|
165
|
+
}), /*#__PURE__*/_jsx(CUButton, {
|
|
166
|
+
variant: "contained",
|
|
167
|
+
size: "small",
|
|
168
|
+
onClick: handleGoToCreate,
|
|
169
|
+
children: t('users.createUser')
|
|
170
|
+
})]
|
|
171
|
+
})]
|
|
172
|
+
}), /*#__PURE__*/_jsx(TableContainer, {
|
|
173
|
+
handleChangePage: handleChangePage,
|
|
174
|
+
loading: loading,
|
|
175
|
+
error: error,
|
|
176
|
+
hasUsers: !!(users !== null && users !== void 0 && users.length)
|
|
177
|
+
})]
|
|
178
|
+
}), showModalEditUserPosition && /*#__PURE__*/_jsx(ModalEditUserPosition, {
|
|
179
|
+
handleCloseModal: handleCloseModalEditUserPosition,
|
|
180
|
+
onEditSuccess: handleEditPositionsSuccess
|
|
181
|
+
})]
|
|
182
|
+
});
|
|
183
|
+
});
|
|
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","backgroundColor","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":[]}
|
|
@@ -0,0 +1,117 @@
|
|
|
1
|
+
import _defineProperty from "@babel/runtime/helpers/defineProperty";
|
|
2
|
+
import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
|
|
3
|
+
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
4
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
5
|
+
/* eslint-disable react/require-default-props */
|
|
6
|
+
import { useEffect, memo, useState, Suspense, lazy, useCallback, useRef } from 'react';
|
|
7
|
+
import { useTranslation } from 'react-i18next';
|
|
8
|
+
import { LoaderComponent } from '../../components/Loading/LoadingComponent';
|
|
9
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
10
|
+
var LazySnackbarComponent = /*#__PURE__*/lazy(function () {
|
|
11
|
+
return import('../../components/Snackbar/Snackbar').then(function (module) {
|
|
12
|
+
return {
|
|
13
|
+
"default": module.SnackbarComponent
|
|
14
|
+
};
|
|
15
|
+
});
|
|
16
|
+
});
|
|
17
|
+
var LazyMainUsersView = /*#__PURE__*/lazy(function () {
|
|
18
|
+
return import('./MainUsersView').then(function (module) {
|
|
19
|
+
return {
|
|
20
|
+
"default": module.MainUsersView
|
|
21
|
+
};
|
|
22
|
+
});
|
|
23
|
+
});
|
|
24
|
+
var MainTeamsView = /*#__PURE__*/memo(function () {
|
|
25
|
+
return /*#__PURE__*/_jsx("div", {
|
|
26
|
+
children: "MainTeamsView"
|
|
27
|
+
});
|
|
28
|
+
});
|
|
29
|
+
export var MainPositionsView = /*#__PURE__*/memo(function () {
|
|
30
|
+
return /*#__PURE__*/_jsx("div", {
|
|
31
|
+
children: "MainPositionsView"
|
|
32
|
+
});
|
|
33
|
+
});
|
|
34
|
+
export var MainLeavesView = /*#__PURE__*/memo(function () {
|
|
35
|
+
return /*#__PURE__*/_jsx("div", {
|
|
36
|
+
children: "MainLeavesView"
|
|
37
|
+
});
|
|
38
|
+
});
|
|
39
|
+
|
|
40
|
+
// TODO: Convertir los componentes de las vistas (MainUsersView, MainTeamsView, MainPositionsView, MainLeavesView) a cargas lazy utilizando React.lazy y Suspense para mejorar el performance
|
|
41
|
+
var ViewByType = {
|
|
42
|
+
users: LazyMainUsersView,
|
|
43
|
+
teams: MainTeamsView,
|
|
44
|
+
positions: MainPositionsView,
|
|
45
|
+
leaves: MainLeavesView
|
|
46
|
+
};
|
|
47
|
+
export var MainView = /*#__PURE__*/memo(function (_ref) {
|
|
48
|
+
var _ref$view = _ref.view,
|
|
49
|
+
view = _ref$view === void 0 ? 'users' : _ref$view;
|
|
50
|
+
var _useTranslation = useTranslation('people'),
|
|
51
|
+
t = _useTranslation.t;
|
|
52
|
+
var View = ViewByType[view];
|
|
53
|
+
var _useState = useState({
|
|
54
|
+
severity: 'error',
|
|
55
|
+
show: false,
|
|
56
|
+
autoHideDuration: 3000,
|
|
57
|
+
message: '',
|
|
58
|
+
hideBackdrop: false
|
|
59
|
+
}),
|
|
60
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
61
|
+
snackbarProps = _useState2[0],
|
|
62
|
+
setSnabarProps = _useState2[1];
|
|
63
|
+
var messageByTypeRef = useRef({
|
|
64
|
+
updateUserPositions: '',
|
|
65
|
+
unblockUser: '',
|
|
66
|
+
deleteUser: '',
|
|
67
|
+
errorUpdateUserPositions: '',
|
|
68
|
+
errorUnblockUser: '',
|
|
69
|
+
errorDeleteUser: ''
|
|
70
|
+
});
|
|
71
|
+
messageByTypeRef.current = {
|
|
72
|
+
updateUserPositions: t('snackbar.updateUserPositions'),
|
|
73
|
+
unblockUser: t('snackbar.unblockUser'),
|
|
74
|
+
deleteUser: t('snackbar.deleteUser'),
|
|
75
|
+
errorUpdateUserPositions: t('snackbar.errorUpdateUserPositions'),
|
|
76
|
+
errorUnblockUser: t('snackbar.errorUnblockUser'),
|
|
77
|
+
errorDeleteUser: t('snackbar.errorDeleteUser')
|
|
78
|
+
};
|
|
79
|
+
var handleSetSnackbarProps = useCallback(function (event) {
|
|
80
|
+
var _messageByTypeRef$cur;
|
|
81
|
+
var _event$detail = event.detail,
|
|
82
|
+
typeMessage = _event$detail.typeMessage,
|
|
83
|
+
severity = _event$detail.severity,
|
|
84
|
+
show = _event$detail.show;
|
|
85
|
+
var message = (_messageByTypeRef$cur = messageByTypeRef.current[typeMessage]) !== null && _messageByTypeRef$cur !== void 0 ? _messageByTypeRef$cur : '';
|
|
86
|
+
setSnabarProps(function (prev) {
|
|
87
|
+
return _objectSpread(_objectSpread({}, prev), {}, {
|
|
88
|
+
message: message,
|
|
89
|
+
severity: severity,
|
|
90
|
+
show: show
|
|
91
|
+
});
|
|
92
|
+
});
|
|
93
|
+
}, []);
|
|
94
|
+
var handleCloseSnackbar = useCallback(function () {
|
|
95
|
+
setSnabarProps(function (prev) {
|
|
96
|
+
return _objectSpread(_objectSpread({}, prev), {}, {
|
|
97
|
+
show: false
|
|
98
|
+
});
|
|
99
|
+
});
|
|
100
|
+
}, []);
|
|
101
|
+
useEffect(function () {
|
|
102
|
+
var listener = function listener(e) {
|
|
103
|
+
return handleSetSnackbarProps(e);
|
|
104
|
+
};
|
|
105
|
+
window.addEventListener('snackbar', listener);
|
|
106
|
+
return function () {
|
|
107
|
+
return window.removeEventListener('snackbar', listener);
|
|
108
|
+
};
|
|
109
|
+
}, [handleSetSnackbarProps]);
|
|
110
|
+
return /*#__PURE__*/_jsxs(Suspense, {
|
|
111
|
+
fallback: /*#__PURE__*/_jsx(LoaderComponent, {}),
|
|
112
|
+
children: [/*#__PURE__*/_jsx(View, {}), snackbarProps.show && /*#__PURE__*/_jsx(LazySnackbarComponent, _objectSpread(_objectSpread({}, snackbarProps), {}, {
|
|
113
|
+
onClose: handleCloseSnackbar
|
|
114
|
+
}))]
|
|
115
|
+
});
|
|
116
|
+
});
|
|
117
|
+
//# 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","MainTeamsView","children","MainPositionsView","MainLeavesView","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","current","handleSetSnackbarProps","event","_messageByTypeRef$cur","_event$detail","detail","typeMessage","prev","_objectSpread","handleCloseSnackbar","listener","e","window","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 MainTeamsView = memo(() => {\n  return <div>MainTeamsView</div>\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":[]}
|
|
@@ -0,0 +1,145 @@
|
|
|
1
|
+
import { CUButton } from '@projectcor/button/lib/components/CUButton';
|
|
2
|
+
import { ChevronLeft } from '@projectcor/icons/lib/components/ChevronLeft';
|
|
3
|
+
import { ChevronDoubleLeft } from '@projectcor/icons/lib/components/ChevronDoubleLeft';
|
|
4
|
+
import { ChevronRight } from '@projectcor/icons/lib/components/ChevronRight';
|
|
5
|
+
import { useUsersQuery } from '../../context/UsersContext';
|
|
6
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
7
|
+
export var PaginationContainer = function PaginationContainer(_ref) {
|
|
8
|
+
var handleChangePage = _ref.handleChangePage;
|
|
9
|
+
var _useUsersQuery = useUsersQuery(),
|
|
10
|
+
currentPage = _useUsersQuery.currentPage,
|
|
11
|
+
totalPages = _useUsersQuery.totalPages;
|
|
12
|
+
var handleClickPrevious = function handleClickPrevious() {
|
|
13
|
+
if (totalPages === 1 || currentPage === 1) return;
|
|
14
|
+
handleChangePage(currentPage - 1);
|
|
15
|
+
};
|
|
16
|
+
var handleClickNext = function handleClickNext() {
|
|
17
|
+
if (currentPage >= totalPages) return;
|
|
18
|
+
handleChangePage(currentPage + 1);
|
|
19
|
+
};
|
|
20
|
+
var handleLastPage = function handleLastPage() {
|
|
21
|
+
handleChangePage(totalPages);
|
|
22
|
+
};
|
|
23
|
+
var handleFirstPage = function handleFirstPage() {
|
|
24
|
+
handleChangePage(1);
|
|
25
|
+
};
|
|
26
|
+
return /*#__PURE__*/_jsx("div", {
|
|
27
|
+
style: {
|
|
28
|
+
display: 'flex',
|
|
29
|
+
justifyContent: 'center',
|
|
30
|
+
alignItems: 'center',
|
|
31
|
+
padding: '10px'
|
|
32
|
+
},
|
|
33
|
+
children: /*#__PURE__*/_jsxs("div", {
|
|
34
|
+
style: {
|
|
35
|
+
display: 'flex',
|
|
36
|
+
alignItems: 'center',
|
|
37
|
+
justifyContent: 'center',
|
|
38
|
+
gap: '10px'
|
|
39
|
+
},
|
|
40
|
+
children: [/*#__PURE__*/_jsxs("div", {
|
|
41
|
+
style: {
|
|
42
|
+
display: 'flex',
|
|
43
|
+
alignItems: 'center',
|
|
44
|
+
justifyContent: 'center'
|
|
45
|
+
},
|
|
46
|
+
children: [/*#__PURE__*/_jsx("div", {
|
|
47
|
+
style: {
|
|
48
|
+
display: 'flex',
|
|
49
|
+
alignItems: 'center',
|
|
50
|
+
justifyContent: 'center'
|
|
51
|
+
},
|
|
52
|
+
children: /*#__PURE__*/_jsx(CUButton, {
|
|
53
|
+
variant: "text",
|
|
54
|
+
iconOnly: true,
|
|
55
|
+
size: "small",
|
|
56
|
+
onClick: handleFirstPage,
|
|
57
|
+
disabled: currentPage === 1,
|
|
58
|
+
children: /*#__PURE__*/_jsx(ChevronDoubleLeft, {
|
|
59
|
+
width: 20,
|
|
60
|
+
height: 20,
|
|
61
|
+
color: "inherit"
|
|
62
|
+
})
|
|
63
|
+
})
|
|
64
|
+
}), /*#__PURE__*/_jsx("div", {
|
|
65
|
+
style: {
|
|
66
|
+
display: 'flex',
|
|
67
|
+
alignItems: 'center',
|
|
68
|
+
justifyContent: 'center'
|
|
69
|
+
},
|
|
70
|
+
children: /*#__PURE__*/_jsx(CUButton, {
|
|
71
|
+
variant: "text",
|
|
72
|
+
iconOnly: true,
|
|
73
|
+
size: "small",
|
|
74
|
+
onClick: handleClickPrevious,
|
|
75
|
+
disabled: currentPage === 1,
|
|
76
|
+
children: /*#__PURE__*/_jsx(ChevronLeft, {
|
|
77
|
+
width: 20,
|
|
78
|
+
height: 20,
|
|
79
|
+
color: "inherit"
|
|
80
|
+
})
|
|
81
|
+
})
|
|
82
|
+
})]
|
|
83
|
+
}), /*#__PURE__*/_jsxs("div", {
|
|
84
|
+
style: {
|
|
85
|
+
display: 'flex',
|
|
86
|
+
alignItems: 'center',
|
|
87
|
+
justifyContent: 'center'
|
|
88
|
+
},
|
|
89
|
+
children: [currentPage, " de ", totalPages || currentPage]
|
|
90
|
+
}), /*#__PURE__*/_jsxs("div", {
|
|
91
|
+
style: {
|
|
92
|
+
display: 'flex',
|
|
93
|
+
alignItems: 'center',
|
|
94
|
+
justifyContent: 'center'
|
|
95
|
+
},
|
|
96
|
+
children: [/*#__PURE__*/_jsx("div", {
|
|
97
|
+
style: {
|
|
98
|
+
display: 'flex',
|
|
99
|
+
alignItems: 'center',
|
|
100
|
+
justifyContent: 'center'
|
|
101
|
+
},
|
|
102
|
+
children: /*#__PURE__*/_jsx(CUButton, {
|
|
103
|
+
variant: "text",
|
|
104
|
+
iconOnly: true,
|
|
105
|
+
size: "small",
|
|
106
|
+
onClick: handleClickNext,
|
|
107
|
+
disabled: currentPage >= totalPages,
|
|
108
|
+
children: /*#__PURE__*/_jsx(ChevronRight, {
|
|
109
|
+
width: 20,
|
|
110
|
+
height: 20,
|
|
111
|
+
color: "inherit"
|
|
112
|
+
})
|
|
113
|
+
})
|
|
114
|
+
}), /*#__PURE__*/_jsx("div", {
|
|
115
|
+
style: {
|
|
116
|
+
display: 'flex',
|
|
117
|
+
alignItems: 'center',
|
|
118
|
+
justifyContent: 'center'
|
|
119
|
+
},
|
|
120
|
+
children: /*#__PURE__*/_jsx(CUButton, {
|
|
121
|
+
variant: "text",
|
|
122
|
+
iconOnly: true,
|
|
123
|
+
size: "small",
|
|
124
|
+
onClick: handleLastPage,
|
|
125
|
+
disabled: currentPage >= totalPages,
|
|
126
|
+
children: /*#__PURE__*/_jsx("div", {
|
|
127
|
+
style: {
|
|
128
|
+
display: 'flex',
|
|
129
|
+
alignItems: 'center',
|
|
130
|
+
justifyContent: 'center',
|
|
131
|
+
rotate: '180deg'
|
|
132
|
+
},
|
|
133
|
+
children: /*#__PURE__*/_jsx(ChevronDoubleLeft, {
|
|
134
|
+
width: 20,
|
|
135
|
+
height: 20,
|
|
136
|
+
color: "inherit"
|
|
137
|
+
})
|
|
138
|
+
})
|
|
139
|
+
})
|
|
140
|
+
})]
|
|
141
|
+
})]
|
|
142
|
+
})
|
|
143
|
+
});
|
|
144
|
+
};
|
|
145
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["CUButton","ChevronLeft","ChevronDoubleLeft","ChevronRight","useUsersQuery","jsx","_jsx","jsxs","_jsxs","PaginationContainer","_ref","handleChangePage","_useUsersQuery","currentPage","totalPages","handleClickPrevious","handleClickNext","handleLastPage","handleFirstPage","style","display","justifyContent","alignItems","padding","children","gap","variant","iconOnly","size","onClick","disabled","width","height","color","rotate"],"sources":["../../../src/container/Pagination/PaginationContainer.tsx"],"sourcesContent":["import { CUButton } from '@projectcor/button/lib/components/CUButton'\nimport { ChevronLeft } from '@projectcor/icons/lib/components/ChevronLeft'\nimport { ChevronDoubleLeft } from '@projectcor/icons/lib/components/ChevronDoubleLeft'\nimport { ChevronRight } from '@projectcor/icons/lib/components/ChevronRight'\nimport { useUsersQuery } from '../../context/UsersContext'\n\nexport const PaginationContainer = ({ handleChangePage }: { handleChangePage: (page: number) => void }) => {\n  const { currentPage, totalPages } = useUsersQuery()\n\n  const handleClickPrevious = () => {\n    if (totalPages === 1 || currentPage === 1) return\n    handleChangePage(currentPage - 1)\n  }\n\n  const handleClickNext = () => {\n    if (currentPage >= totalPages) return\n    handleChangePage(currentPage + 1)\n  }\n\n  const handleLastPage = () => {\n    handleChangePage(totalPages)\n  }\n\n  const handleFirstPage = () => {\n    handleChangePage(1)\n  }\n\n  return (\n    <div style={{ display: 'flex', justifyContent: 'center', alignItems: 'center', padding: '10px' }}>\n      <div style={{ display: 'flex', alignItems: 'center', justifyContent: 'center', gap: '10px' }}>\n        <div style={{ display: 'flex', alignItems: 'center', justifyContent: 'center' }}>\n          <div style={{ display: 'flex', alignItems: 'center', justifyContent: 'center' }}>\n            <CUButton variant=\"text\" iconOnly size=\"small\" onClick={handleFirstPage} disabled={currentPage === 1}>\n              <ChevronDoubleLeft width={20} height={20} color=\"inherit\" />\n            </CUButton>\n          </div>\n          <div style={{ display: 'flex', alignItems: 'center', justifyContent: 'center' }}>\n            <CUButton variant=\"text\" iconOnly size=\"small\" onClick={handleClickPrevious} disabled={currentPage === 1}>\n              <ChevronLeft width={20} height={20} color=\"inherit\" />\n            </CUButton>\n          </div>\n        </div>\n        <div style={{ display: 'flex', alignItems: 'center', justifyContent: 'center' }}>\n          {currentPage} de {totalPages || currentPage}\n        </div>\n        <div style={{ display: 'flex', alignItems: 'center', justifyContent: 'center' }}>\n          <div style={{ display: 'flex', alignItems: 'center', justifyContent: 'center' }}>\n            <CUButton\n              variant=\"text\"\n              iconOnly\n              size=\"small\"\n              onClick={handleClickNext}\n              disabled={currentPage >= totalPages}\n            >\n              <ChevronRight width={20} height={20} color=\"inherit\" />\n            </CUButton>\n          </div>\n          <div style={{ display: 'flex', alignItems: 'center', justifyContent: 'center' }}>\n            <CUButton\n              variant=\"text\"\n              iconOnly\n              size=\"small\"\n              onClick={handleLastPage}\n              disabled={currentPage >= totalPages}\n            >\n              <div style={{ display: 'flex', alignItems: 'center', justifyContent: 'center', rotate: '180deg' }}>\n                <ChevronDoubleLeft width={20} height={20} color=\"inherit\" />\n              </div>\n            </CUButton>\n          </div>\n        </div>\n      </div>\n    </div>\n  )\n}\n"],"mappings":"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","ignoreList":[]}
|