@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.
Files changed (116) hide show
  1. package/lib/App.js +64 -0
  2. package/lib/App.stories.js +104 -0
  3. package/lib/Providers.js +26 -0
  4. package/lib/components/Backdrop/Background.interface.js +2 -0
  5. package/lib/components/Backdrop/Background.js +12 -0
  6. package/lib/components/Backdrop/Background.style.js +9 -0
  7. package/lib/components/Backdrop/index.js +2 -0
  8. package/lib/components/DeletedUserIcon/DeletedUserIcon.js +20 -0
  9. package/lib/components/DeletedUserIcon/DeletedUserIcon.styles.js +7 -0
  10. package/lib/components/DeletedUserIcon/index.js +2 -0
  11. package/lib/components/DisabledUserIcon/DisabledUserIcon.js +24 -0
  12. package/lib/components/DisabledUserIcon/DisabledUserIcon.styles.js +7 -0
  13. package/lib/components/DisabledUserIcon/index.js +2 -0
  14. package/lib/components/EmptyUser/EmptyUser.js +59 -0
  15. package/lib/components/EmptyUser/index.js +3 -0
  16. package/lib/components/ErrorComponent/ErrorComponent.js +24 -0
  17. package/lib/components/ErrorComponent/ErrorComponent.spec.js +29 -0
  18. package/lib/components/ErrorComponent/ErrorComponent.styles.js +19 -0
  19. package/lib/components/ErrorComponent/index.js +2 -0
  20. package/lib/components/Filters/FilterChip/FilterChip.js +106 -0
  21. package/lib/components/Filters/FilterChip/index.js +2 -0
  22. package/lib/components/Filters/LabelFilter/LabelFilter.js +87 -0
  23. package/lib/components/Filters/LabelFilter/LabelFilter.styles.js +32 -0
  24. package/lib/components/Filters/SearchComponent/SearchComponent.js +26 -0
  25. package/lib/components/Filters/SearchComponent/SearchComponent.styles.js +16 -0
  26. package/lib/components/Filters/SearchComponent/index.js +2 -0
  27. package/lib/components/Filters/index.js +2 -0
  28. package/lib/components/Icons/UserBlockIcon.js +25 -0
  29. package/lib/components/Icons/UserIconLock.js +42 -0
  30. package/lib/components/Icons/UserIconWithCross.js +20 -0
  31. package/lib/components/Icons/index.js +4 -0
  32. package/lib/components/Illustration/EmptyUser.js +141 -0
  33. package/lib/components/Illustration/index.js +2 -0
  34. package/lib/components/Loading/LoadingComponent.js +11 -0
  35. package/lib/components/Loading/LoadingComponent.style.js +6 -0
  36. package/lib/components/Loading/index.js +2 -0
  37. package/lib/components/MenuOptions/MenuOptions.js +147 -0
  38. package/lib/components/MenuOptions/MenuOptions.styles.js +14 -0
  39. package/lib/components/MenuOptions/index.js +2 -0
  40. package/lib/components/Modal/ModalLayout.interface.js +2 -0
  41. package/lib/components/Modal/ModalLayout.js +25 -0
  42. package/lib/components/Modal/ModalLayout.style.js +26 -0
  43. package/lib/components/Modal/index.js +2 -0
  44. package/lib/components/ModalBloquedUser/ModalBloquedUser.js +67 -0
  45. package/lib/components/ModalBloquedUser/index.js +2 -0
  46. package/lib/components/ModalEditUserPosition/ModalEditUserPosition.js +171 -0
  47. package/lib/components/ModalEditUserPosition/UserEditPositionRow.js +327 -0
  48. package/lib/components/ModalEditUserPosition/UserEditPositionRow.styles.js +6 -0
  49. package/lib/components/ModalEditUserPosition/index.js +2 -0
  50. package/lib/components/ModalOptionsWithSearch/ConfirmButton.js +16 -0
  51. package/lib/components/ModalOptionsWithSearch/ModalOptionsWithSearch.js +76 -0
  52. package/lib/components/ModalOptionsWithSearch/ModalOptionsWithSearch.styles.js +21 -0
  53. package/lib/components/ModalOptionsWithSearch/SearchInput.js +14 -0
  54. package/lib/components/Search/InputSearch.js +22 -0
  55. package/lib/components/Search/Search.js +34 -0
  56. package/lib/components/Search/Search.styles.js +15 -0
  57. package/lib/components/Search/index.js +2 -0
  58. package/lib/components/Snackbar/Snackbar.interface.js +2 -0
  59. package/lib/components/Snackbar/Snackbar.js +35 -0
  60. package/lib/components/Snackbar/Snackbar.styles.js +18 -0
  61. package/lib/components/Snackbar/index.js +2 -0
  62. package/lib/components/Table/Content/ContentTable.js +7 -0
  63. package/lib/components/Table/Content/index.js +2 -0
  64. package/lib/components/Table/Header/HeaderTable.js +212 -0
  65. package/lib/components/Table/Header/index.js +2 -0
  66. package/lib/components/Table/Row/Row.js +66 -0
  67. package/lib/components/Table/Row/Row.styles.js +27 -0
  68. package/lib/components/Table/Row/index.js +2 -0
  69. package/lib/components/UserRow/UserRow.js +129 -0
  70. package/lib/components/UserRow/UserRow.stories.js +17 -0
  71. package/lib/components/UserRow/UserRow.styles.js +19 -0
  72. package/lib/constants/gqlClient.js +4 -0
  73. package/lib/container/Body/BodyContainer.js +109 -0
  74. package/lib/container/Filters/FiltersContainer.js +168 -0
  75. package/lib/container/MainView/MainUsersView.js +184 -0
  76. package/lib/container/MainView/MainView.js +117 -0
  77. package/lib/container/Pagination/PaginationContainer.js +145 -0
  78. package/lib/container/RouterComponent/RouterComponent.js +130 -0
  79. package/lib/container/RouterComponent/RouterComponent.stories.js +14 -0
  80. package/lib/container/RouterComponent/index.js +2 -0
  81. package/lib/container/TableContainer/TableContainer.js +41 -0
  82. package/lib/container/index.js +2 -0
  83. package/lib/context/UsersContext.js +145 -0
  84. package/lib/hooks/useAbortController.js +17 -0
  85. package/lib/hooks/useDebounce.js +18 -0
  86. package/lib/hooks/useGetTeams.js +30 -0
  87. package/lib/hooks/useGetUserPositionFilter.js +29 -0
  88. package/lib/hooks/useGetUsers.js +100 -0
  89. package/lib/hooks/useGetUsersForFilter.js +52 -0
  90. package/lib/hooks/useGraphAdapter.js +60 -0
  91. package/lib/hooks/useResize.js +29 -0
  92. package/lib/hooks/useSearchEvent.js +18 -0
  93. package/lib/hooks/useUnblockUser.js +131 -0
  94. package/lib/hooks/useUpdateUserPositions.js +58 -0
  95. package/lib/hooks/useUserPositionCategories.js +38 -0
  96. package/lib/index.css +28 -0
  97. package/lib/index.js +10 -0
  98. package/lib/lang/i18next.js +19 -0
  99. package/lib/lang/i18nextForWeb.js +22 -0
  100. package/lib/lang/resource.js +11 -0
  101. package/lib/lang/translation/br.json +69 -0
  102. package/lib/lang/translation/en.json +69 -0
  103. package/lib/lang/translation/es.json +69 -0
  104. package/lib/lang/translation/fr.json +69 -0
  105. package/lib/mocks/mockedUser.js +95 -0
  106. package/lib/query/getTeams.js +5 -0
  107. package/lib/query/getUserPositionCategory.js +5 -0
  108. package/lib/query/getUserPositionFilter.js +5 -0
  109. package/lib/query/getUsers.js +5 -0
  110. package/lib/query/updateUserPosition.js +5 -0
  111. package/lib/query/userUnblock.js +5 -0
  112. package/lib/types/global.d.js +2 -0
  113. package/lib/types/userType.d.js +2 -0
  114. package/lib/utils/ApolloMicroServiceClient.js +3 -0
  115. package/package.json +174 -0
  116. 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":[]}