@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,130 @@
1
+ import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
2
+ import _defineProperty from "@babel/runtime/helpers/defineProperty";
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 jsx-a11y/click-events-have-key-events */
6
+ /* eslint-disable jsx-a11y/no-static-element-interactions */
7
+ /* eslint-disable react/button-has-type */
8
+ import { useState } from 'react';
9
+ import { UserCircle } from '@projectcor/icons/lib/components/UserCircle';
10
+ import { UserTeam } from '@projectcor/icons/lib/components/UserTeam';
11
+ import { Wired } from '@projectcor/icons/lib/components/Wired';
12
+ import { UserClock } from '@projectcor/icons/lib/components/UserClock';
13
+ import { MainView } from '../MainView/MainView';
14
+ import { useUsers, useUsersCount } from '../../context/UsersContext';
15
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
16
+ var VIEW_ITEMS = [{
17
+ type: 'users',
18
+ icon: /*#__PURE__*/_jsx(UserCircle, {
19
+ width: "20px",
20
+ height: "20px",
21
+ color: "inherit"
22
+ }),
23
+ title: 'Usuarios',
24
+ count: 151
25
+ }, {
26
+ type: 'teams',
27
+ icon: /*#__PURE__*/_jsx(UserTeam, {
28
+ width: "20px",
29
+ height: "20px",
30
+ color: "inherit"
31
+ }),
32
+ title: 'Equipos',
33
+ count: 10
34
+ }, {
35
+ type: 'positions',
36
+ icon: /*#__PURE__*/_jsx(Wired, {
37
+ width: "20px",
38
+ height: "20px",
39
+ color: "inherit"
40
+ }),
41
+ title: 'Posiciones',
42
+ count: 10
43
+ }, {
44
+ type: 'leaves',
45
+ icon: /*#__PURE__*/_jsx(UserClock, {
46
+ width: "20px",
47
+ height: "20px",
48
+ color: "inherit"
49
+ }),
50
+ title: 'Availability',
51
+ count: 10
52
+ }];
53
+ var ViewItem = function ViewItem(_ref) {
54
+ var icon = _ref.icon,
55
+ title = _ref.title,
56
+ count = _ref.count,
57
+ isSelected = _ref.isSelected,
58
+ handleViewChange = _ref.handleViewChange,
59
+ type = _ref.type;
60
+ return /*#__PURE__*/_jsxs("div", {
61
+ style: {
62
+ display: 'flex',
63
+ alignItems: 'center',
64
+ gap: '8px',
65
+ justifyContent: 'center',
66
+ cursor: isSelected ? 'default' : 'pointer',
67
+ padding: '8px',
68
+ borderBottom: isSelected ? '2px solid rgba(0, 136, 204, 1)' : 'none',
69
+ color: isSelected ? 'rgba(0, 0, 0, 1)' : 'rgba(153, 153, 153, 1)'
70
+ },
71
+ onClick: function onClick() {
72
+ return handleViewChange(type);
73
+ },
74
+ children: [icon, title, " (", count, ")"]
75
+ });
76
+ };
77
+ var ViewItems = function ViewItems(_ref2) {
78
+ var handleViewChange = _ref2.handleViewChange,
79
+ viewSelected = _ref2.viewSelected;
80
+ var _useUsersCount = useUsersCount(),
81
+ totalUsers = _useUsersCount.totalUsers;
82
+ var _useUsers = useUsers(),
83
+ userInfoContext = _useUsers.userInfo;
84
+ var totalItemsByView = {
85
+ users: totalUsers,
86
+ teams: 0,
87
+ positions: 0,
88
+ leaves: 0
89
+ };
90
+ return /*#__PURE__*/_jsx("div", {
91
+ style: {
92
+ display: 'flex',
93
+ gap: '8px',
94
+ alignItems: 'center',
95
+ borderBottom: '1px solid rgba(224, 224, 224, 1)'
96
+ },
97
+ children: VIEW_ITEMS.map(function (item) {
98
+ var _userInfoContext$plan;
99
+ if (
100
+ // eslint-disable-next-line prettier/prettier
101
+ item.type === 'positions' && ![1, 2].includes(userInfoContext === null || userInfoContext === void 0 ? void 0 : userInfoContext.role_id) && !(userInfoContext !== null && userInfoContext !== void 0 && (_userInfoContext$plan = userInfoContext.plan) !== null && _userInfoContext$plan !== void 0 && (_userInfoContext$plan = _userInfoContext$plan.features) !== null && _userInfoContext$plan !== void 0 && _userInfoContext$plan.includes('USERS_POSITIONS'))) {
102
+ return null;
103
+ }
104
+ return /*#__PURE__*/_jsx(ViewItem, _objectSpread(_objectSpread({}, item), {}, {
105
+ isSelected: viewSelected === item.type,
106
+ handleViewChange: handleViewChange,
107
+ count: totalItemsByView[item.type]
108
+ }), item.type);
109
+ })
110
+ });
111
+ };
112
+ export var RouterComponent = function RouterComponent() {
113
+ var _useState = useState('users'),
114
+ _useState2 = _slicedToArray(_useState, 2),
115
+ view = _useState2[0],
116
+ setView = _useState2[1];
117
+ var handleViewChange = function handleViewChange(type) {
118
+ if (view === type) return;
119
+ setView(type);
120
+ };
121
+ return /*#__PURE__*/_jsxs("div", {
122
+ children: [/*#__PURE__*/_jsx(ViewItems, {
123
+ handleViewChange: handleViewChange,
124
+ viewSelected: view
125
+ }), /*#__PURE__*/_jsx(MainView, {
126
+ view: view
127
+ })]
128
+ });
129
+ };
130
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["useState","UserCircle","UserTeam","Wired","UserClock","MainView","useUsers","useUsersCount","jsx","_jsx","jsxs","_jsxs","VIEW_ITEMS","type","icon","width","height","color","title","count","ViewItem","_ref","isSelected","handleViewChange","style","display","alignItems","gap","justifyContent","cursor","padding","borderBottom","onClick","children","ViewItems","_ref2","viewSelected","_useUsersCount","totalUsers","_useUsers","userInfoContext","userInfo","totalItemsByView","users","teams","positions","leaves","map","item","_userInfoContext$plan","includes","role_id","plan","features","_objectSpread","RouterComponent","_useState","_useState2","_slicedToArray","view","setView"],"sources":["../../../src/container/RouterComponent/RouterComponent.tsx"],"sourcesContent":["/* eslint-disable jsx-a11y/click-events-have-key-events */\n/* eslint-disable jsx-a11y/no-static-element-interactions */\n/* eslint-disable react/button-has-type */\nimport { ReactElement, useState } from 'react'\nimport { UserCircle } from '@projectcor/icons/lib/components/UserCircle'\nimport { UserTeam } from '@projectcor/icons/lib/components/UserTeam'\nimport { Wired } from '@projectcor/icons/lib/components/Wired'\nimport { UserClock } from '@projectcor/icons/lib/components/UserClock'\nimport { ViewType } from '../../types/userType'\nimport { MainView } from '../MainView/MainView'\nimport { useUsers, useUsersCount } from '../../context/UsersContext'\n\nconst VIEW_ITEMS: { type: ViewType; icon: ReactElement; title: string; count: number }[] = [\n  {\n    type: 'users',\n    icon: <UserCircle width=\"20px\" height=\"20px\" color=\"inherit\" />,\n    title: 'Usuarios',\n    count: 151,\n  },\n  {\n    type: 'teams',\n    icon: <UserTeam width=\"20px\" height=\"20px\" color=\"inherit\" />,\n    title: 'Equipos',\n    count: 10,\n  },\n  {\n    type: 'positions',\n    icon: <Wired width=\"20px\" height=\"20px\" color=\"inherit\" />,\n    title: 'Posiciones',\n    count: 10,\n  },\n  {\n    type: 'leaves',\n    icon: <UserClock width=\"20px\" height=\"20px\" color=\"inherit\" />,\n    title: 'Availability',\n    count: 10,\n  },\n]\n\nconst ViewItem = ({\n  icon,\n  title,\n  count,\n  isSelected,\n  handleViewChange,\n  type,\n}: {\n  icon: ReactElement\n  title: string\n  count: number\n  isSelected: boolean\n  handleViewChange: (view: ViewType) => void\n  type: ViewType\n}) => {\n  return (\n    <div\n      style={{\n        display: 'flex',\n        alignItems: 'center',\n        gap: '8px',\n        justifyContent: 'center',\n        cursor: isSelected ? 'default' : 'pointer',\n        padding: '8px',\n        borderBottom: isSelected ? '2px solid rgba(0, 136, 204, 1)' : 'none',\n        color: isSelected ? 'rgba(0, 0, 0, 1)' : 'rgba(153, 153, 153, 1)',\n      }}\n      onClick={() => handleViewChange(type)}\n    >\n      {icon}\n      {title} ({count})\n    </div>\n  )\n}\n\nconst ViewItems = ({\n  handleViewChange,\n  viewSelected,\n}: {\n  handleViewChange: (view: ViewType) => void\n  viewSelected: ViewType\n}) => {\n  const { totalUsers } = useUsersCount()\n  const { userInfo: userInfoContext } = useUsers()\n\n  const totalItemsByView = {\n    users: totalUsers,\n    teams: 0,\n    positions: 0,\n    leaves: 0,\n  }\n\n  return (\n    <div\n      style={{ display: 'flex', gap: '8px', alignItems: 'center', borderBottom: '1px solid rgba(224, 224, 224, 1)' }}\n    >\n      {VIEW_ITEMS.map(item => {\n        if (\n          // eslint-disable-next-line prettier/prettier\n          item.type === 'positions' &&\n          ![1, 2].includes(userInfoContext?.role_id) &&\n          !userInfoContext?.plan?.features?.includes('USERS_POSITIONS')\n        ) {\n          return null\n        }\n        return (\n          <ViewItem\n            key={item.type}\n            {...item}\n            isSelected={viewSelected === item.type}\n            handleViewChange={handleViewChange}\n            count={totalItemsByView[item.type]}\n          />\n        )\n      })}\n    </div>\n  )\n}\n\nexport const RouterComponent = () => {\n  const [view, setView] = useState<ViewType>('users')\n\n  const handleViewChange = (type: ViewType) => {\n    if (view === type) return\n    setView(type)\n  }\n\n  return (\n    <div>\n      <ViewItems handleViewChange={handleViewChange} viewSelected={view} />\n      <MainView view={view} />\n    </div>\n  )\n}\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,14 @@
1
+ // Ayudame a armar las historias de storybook para el RouterComponent
2
+
3
+ import { RouterComponent } from './RouterComponent';
4
+ import { jsx as _jsx } from "react/jsx-runtime";
5
+ export default {
6
+ component: RouterComponent,
7
+ title: 'Components/RouterComponent'
8
+ };
9
+ export var Default = {
10
+ render: function render() {
11
+ return /*#__PURE__*/_jsx(RouterComponent, {});
12
+ }
13
+ };
14
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJSb3V0ZXJDb21wb25lbnQiLCJqc3giLCJfanN4IiwiY29tcG9uZW50IiwidGl0bGUiLCJEZWZhdWx0IiwicmVuZGVyIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NvbnRhaW5lci9Sb3V0ZXJDb21wb25lbnQvUm91dGVyQ29tcG9uZW50LnN0b3JpZXMudHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8vIEF5dWRhbWUgYSBhcm1hciBsYXMgaGlzdG9yaWFzIGRlIHN0b3J5Ym9vayBwYXJhIGVsIFJvdXRlckNvbXBvbmVudFxuXG5pbXBvcnQgeyBDb21wb25lbnRNZXRhLCBTdG9yeU9iaiB9IGZyb20gJ0BzdG9yeWJvb2svcmVhY3QnXG5pbXBvcnQgeyBSb3V0ZXJDb21wb25lbnQgfSBmcm9tICcuL1JvdXRlckNvbXBvbmVudCdcblxuZXhwb3J0IGRlZmF1bHQge1xuICBjb21wb25lbnQ6IFJvdXRlckNvbXBvbmVudCxcbiAgdGl0bGU6ICdDb21wb25lbnRzL1JvdXRlckNvbXBvbmVudCcsXG59IGFzIENvbXBvbmVudE1ldGE8dHlwZW9mIFJvdXRlckNvbXBvbmVudD5cblxuZXhwb3J0IGNvbnN0IERlZmF1bHQ6IFN0b3J5T2JqPHR5cGVvZiBSb3V0ZXJDb21wb25lbnQ+ID0ge1xuICByZW5kZXI6ICgpID0+IDxSb3V0ZXJDb21wb25lbnQgLz4sXG59XG4iXSwibWFwcGluZ3MiOiJBQUFBOztBQUdBLFNBQVNBLGVBQWUsUUFBUSxtQkFBbUI7QUFBQSxTQUFBQyxHQUFBLElBQUFDLElBQUE7QUFFbkQsZUFBZTtFQUNiQyxTQUFTLEVBQUVILGVBQWU7RUFDMUJJLEtBQUssRUFBRTtBQUNULENBQUM7QUFFRCxPQUFPLElBQU1DLE9BQXlDLEdBQUc7RUFDdkRDLE1BQU0sRUFBRSxTQUFSQSxNQUFNQSxDQUFBO0lBQUEsb0JBQVFKLElBQUEsQ0FBQ0YsZUFBZSxJQUFFLENBQUM7RUFBQTtBQUNuQyxDQUFDIiwiaWdub3JlTGlzdCI6W119
@@ -0,0 +1,2 @@
1
+
2
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6W10sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2NvbnRhaW5lci9Sb3V0ZXJDb21wb25lbnQvaW5kZXgudHMiXSwic291cmNlc0NvbnRlbnQiOlsiIl0sIm1hcHBpbmdzIjoiIiwiaWdub3JlTGlzdCI6W119
@@ -0,0 +1,41 @@
1
+ /* eslint-disable react/require-default-props */
2
+ /* eslint-disable no-nested-ternary */
3
+ import { memo } from 'react';
4
+ import { useTranslation } from 'react-i18next';
5
+ import { HeaderTable } from '../../components/Table/Header/HeaderTable';
6
+ import { BodyContainer } from '../Body/BodyContainer';
7
+ import { PaginationContainer } from '../Pagination/PaginationContainer';
8
+ import { ErrorComponent } from '../../components/ErrorComponent';
9
+ import { LoaderComponent } from '../../components/Loading/LoadingComponent';
10
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
11
+ export var TableContainer = /*#__PURE__*/memo(function (_ref) {
12
+ var handleChangePage = _ref.handleChangePage,
13
+ _ref$loading = _ref.loading,
14
+ loading = _ref$loading === void 0 ? false : _ref$loading,
15
+ _ref$error = _ref.error,
16
+ error = _ref$error === void 0 ? false : _ref$error,
17
+ _ref$hasUsers = _ref.hasUsers,
18
+ hasUsers = _ref$hasUsers === void 0 ? false : _ref$hasUsers;
19
+ var _useTranslation = useTranslation('people'),
20
+ t = _useTranslation.t;
21
+ return /*#__PURE__*/_jsxs("div", {
22
+ style: {
23
+ width: '100%',
24
+ height: '100%'
25
+ },
26
+ children: [/*#__PURE__*/_jsxs("div", {
27
+ style: {
28
+ width: '100%',
29
+ height: '100%',
30
+ borderRadius: '4px'
31
+ },
32
+ children: [/*#__PURE__*/_jsx(HeaderTable, {}), loading ? /*#__PURE__*/_jsx(LoaderComponent, {}) : error ? /*#__PURE__*/_jsx(ErrorComponent, {
33
+ title: t('error.errorMessageTitle'),
34
+ subtitle: t('error.errorMessageBody')
35
+ }) : /*#__PURE__*/_jsx(BodyContainer, {})]
36
+ }), hasUsers && !loading && !error && /*#__PURE__*/_jsx(PaginationContainer, {
37
+ handleChangePage: handleChangePage
38
+ })]
39
+ });
40
+ });
41
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJtZW1vIiwidXNlVHJhbnNsYXRpb24iLCJIZWFkZXJUYWJsZSIsIkJvZHlDb250YWluZXIiLCJQYWdpbmF0aW9uQ29udGFpbmVyIiwiRXJyb3JDb21wb25lbnQiLCJMb2FkZXJDb21wb25lbnQiLCJqc3giLCJfanN4IiwianN4cyIsIl9qc3hzIiwiVGFibGVDb250YWluZXIiLCJfcmVmIiwiaGFuZGxlQ2hhbmdlUGFnZSIsIl9yZWYkbG9hZGluZyIsImxvYWRpbmciLCJfcmVmJGVycm9yIiwiZXJyb3IiLCJfcmVmJGhhc1VzZXJzIiwiaGFzVXNlcnMiLCJfdXNlVHJhbnNsYXRpb24iLCJ0Iiwic3R5bGUiLCJ3aWR0aCIsImhlaWdodCIsImNoaWxkcmVuIiwiYm9yZGVyUmFkaXVzIiwidGl0bGUiLCJzdWJ0aXRsZSJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb250YWluZXIvVGFibGVDb250YWluZXIvVGFibGVDb250YWluZXIudHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L3JlcXVpcmUtZGVmYXVsdC1wcm9wcyAqL1xuLyogZXNsaW50LWRpc2FibGUgbm8tbmVzdGVkLXRlcm5hcnkgKi9cbmltcG9ydCB7IG1lbW8gfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCdcbmltcG9ydCB7IEhlYWRlclRhYmxlIH0gZnJvbSAnLi4vLi4vY29tcG9uZW50cy9UYWJsZS9IZWFkZXIvSGVhZGVyVGFibGUnXG5pbXBvcnQgeyBCb2R5Q29udGFpbmVyIH0gZnJvbSAnLi4vQm9keS9Cb2R5Q29udGFpbmVyJ1xuaW1wb3J0IHsgUGFnaW5hdGlvbkNvbnRhaW5lciB9IGZyb20gJy4uL1BhZ2luYXRpb24vUGFnaW5hdGlvbkNvbnRhaW5lcidcbmltcG9ydCB7IEVycm9yQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vY29tcG9uZW50cy9FcnJvckNvbXBvbmVudCdcbmltcG9ydCB7IExvYWRlckNvbXBvbmVudCB9IGZyb20gJy4uLy4uL2NvbXBvbmVudHMvTG9hZGluZy9Mb2FkaW5nQ29tcG9uZW50J1xuXG5leHBvcnQgY29uc3QgVGFibGVDb250YWluZXIgPSBtZW1vKFxuICAoe1xuICAgIGhhbmRsZUNoYW5nZVBhZ2UsXG4gICAgbG9hZGluZyA9IGZhbHNlLFxuICAgIGVycm9yID0gZmFsc2UsXG4gICAgaGFzVXNlcnMgPSBmYWxzZSxcbiAgfToge1xuICAgIGhhbmRsZUNoYW5nZVBhZ2U6IChwYWdlOiBudW1iZXIpID0+IHZvaWRcbiAgICBsb2FkaW5nPzogYm9vbGVhblxuICAgIGVycm9yPzogYm9vbGVhblxuICAgIGhhc1VzZXJzPzogYm9vbGVhblxuICB9KSA9PiB7XG4gICAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigncGVvcGxlJylcbiAgICByZXR1cm4gKFxuICAgICAgPGRpdiBzdHlsZT17eyB3aWR0aDogJzEwMCUnLCBoZWlnaHQ6ICcxMDAlJyB9fT5cbiAgICAgICAgPGRpdiBzdHlsZT17eyB3aWR0aDogJzEwMCUnLCBoZWlnaHQ6ICcxMDAlJywgYm9yZGVyUmFkaXVzOiAnNHB4JyB9fT5cbiAgICAgICAgICA8SGVhZGVyVGFibGUgLz5cbiAgICAgICAgICB7bG9hZGluZyA/IChcbiAgICAgICAgICAgIDxMb2FkZXJDb21wb25lbnQgLz5cbiAgICAgICAgICApIDogZXJyb3IgPyAoXG4gICAgICAgICAgICA8RXJyb3JDb21wb25lbnQgdGl0bGU9e3QoJ2Vycm9yLmVycm9yTWVzc2FnZVRpdGxlJyl9IHN1YnRpdGxlPXt0KCdlcnJvci5lcnJvck1lc3NhZ2VCb2R5Jyl9IC8+XG4gICAgICAgICAgKSA6IChcbiAgICAgICAgICAgIDxCb2R5Q29udGFpbmVyIC8+XG4gICAgICAgICAgKX1cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIHtoYXNVc2VycyAmJiAhbG9hZGluZyAmJiAhZXJyb3IgJiYgPFBhZ2luYXRpb25Db250YWluZXIgaGFuZGxlQ2hhbmdlUGFnZT17aGFuZGxlQ2hhbmdlUGFnZX0gLz59XG4gICAgICA8L2Rpdj5cbiAgICApXG4gIH1cbilcbiJdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQTtBQUNBLFNBQVNBLElBQUksUUFBUSxPQUFPO0FBQzVCLFNBQVNDLGNBQWMsUUFBUSxlQUFlO0FBQzlDLFNBQVNDLFdBQVcsUUFBUSwyQ0FBMkM7QUFDdkUsU0FBU0MsYUFBYSxRQUFRLHVCQUF1QjtBQUNyRCxTQUFTQyxtQkFBbUIsUUFBUSxtQ0FBbUM7QUFDdkUsU0FBU0MsY0FBYyxRQUFRLGlDQUFpQztBQUNoRSxTQUFTQyxlQUFlLFFBQVEsMkNBQTJDO0FBQUEsU0FBQUMsR0FBQSxJQUFBQyxJQUFBLEVBQUFDLElBQUEsSUFBQUMsS0FBQTtBQUUzRSxPQUFPLElBQU1DLGNBQWMsZ0JBQUdYLElBQUksQ0FDaEMsVUFBQVksSUFBQSxFQVVNO0VBQUEsSUFUSkMsZ0JBQWdCLEdBQUFELElBQUEsQ0FBaEJDLGdCQUFnQjtJQUFBQyxZQUFBLEdBQUFGLElBQUEsQ0FDaEJHLE9BQU87SUFBUEEsT0FBTyxHQUFBRCxZQUFBLGNBQUcsS0FBSyxHQUFBQSxZQUFBO0lBQUFFLFVBQUEsR0FBQUosSUFBQSxDQUNmSyxLQUFLO0lBQUxBLEtBQUssR0FBQUQsVUFBQSxjQUFHLEtBQUssR0FBQUEsVUFBQTtJQUFBRSxhQUFBLEdBQUFOLElBQUEsQ0FDYk8sUUFBUTtJQUFSQSxRQUFRLEdBQUFELGFBQUEsY0FBRyxLQUFLLEdBQUFBLGFBQUE7RUFPaEIsSUFBQUUsZUFBQSxHQUFjbkIsY0FBYyxDQUFDLFFBQVEsQ0FBQztJQUE5Qm9CLENBQUMsR0FBQUQsZUFBQSxDQUFEQyxDQUFDO0VBQ1Qsb0JBQ0VYLEtBQUE7SUFBS1ksS0FBSyxFQUFFO01BQUVDLEtBQUssRUFBRSxNQUFNO01BQUVDLE1BQU0sRUFBRTtJQUFPLENBQUU7SUFBQUMsUUFBQSxnQkFDNUNmLEtBQUE7TUFBS1ksS0FBSyxFQUFFO1FBQUVDLEtBQUssRUFBRSxNQUFNO1FBQUVDLE1BQU0sRUFBRSxNQUFNO1FBQUVFLFlBQVksRUFBRTtNQUFNLENBQUU7TUFBQUQsUUFBQSxnQkFDakVqQixJQUFBLENBQUNOLFdBQVcsSUFBRSxDQUFDLEVBQ2RhLE9BQU8sZ0JBQ05QLElBQUEsQ0FBQ0YsZUFBZSxJQUFFLENBQUMsR0FDakJXLEtBQUssZ0JBQ1BULElBQUEsQ0FBQ0gsY0FBYztRQUFDc0IsS0FBSyxFQUFFTixDQUFDLENBQUMseUJBQXlCLENBQUU7UUFBQ08sUUFBUSxFQUFFUCxDQUFDLENBQUMsd0JBQXdCO01BQUUsQ0FBRSxDQUFDLGdCQUU5RmIsSUFBQSxDQUFDTCxhQUFhLElBQUUsQ0FDakI7SUFBQSxDQUNFLENBQUMsRUFDTGdCLFFBQVEsSUFBSSxDQUFDSixPQUFPLElBQUksQ0FBQ0UsS0FBSyxpQkFBSVQsSUFBQSxDQUFDSixtQkFBbUI7TUFBQ1MsZ0JBQWdCLEVBQUVBO0lBQWlCLENBQUUsQ0FBQztFQUFBLENBQzNGLENBQUM7QUFFVixDQUNGLENBQUMiLCJpZ25vcmVMaXN0IjpbXX0=
@@ -0,0 +1,2 @@
1
+ export { MainView } from './MainView/MainView';
2
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJNYWluVmlldyJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb250YWluZXIvaW5kZXgudHMiXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgTWFpblZpZXcgfSBmcm9tICcuL01haW5WaWV3L01haW5WaWV3J1xuIl0sIm1hcHBpbmdzIjoiQUFBQSxTQUFTQSxRQUFRLFFBQVEscUJBQXFCIiwiaWdub3JlTGlzdCI6W119
@@ -0,0 +1,145 @@
1
+ import _defineProperty from "@babel/runtime/helpers/defineProperty";
2
+ import _toConsumableArray from "@babel/runtime/helpers/toConsumableArray";
3
+ import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
4
+ 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; }
5
+ 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; }
6
+ /* eslint-disable @typescript-eslint/no-shadow */
7
+ /* eslint-disable @typescript-eslint/no-explicit-any */
8
+ import { createContext, useCallback, useContext, useMemo, useState, useEffect } from 'react';
9
+ import { UserContext } from '@projectcor/cor-commons/lib/providers/UserProvider';
10
+ import { useGetUsers } from '../hooks/useGetUsers';
11
+ import { jsx as _jsx } from "react/jsx-runtime";
12
+ var UsersQueryContext = /*#__PURE__*/createContext(undefined);
13
+ var UsersViewContext = /*#__PURE__*/createContext(undefined);
14
+ var UsersEditPositionsContext = /*#__PURE__*/createContext(undefined);
15
+ var UsersCountContext = /*#__PURE__*/createContext(undefined);
16
+ export var UsersProvider = function UsersProvider(_ref) {
17
+ var children = _ref.children,
18
+ view = _ref.view;
19
+ var _useState = useState(false),
20
+ _useState2 = _slicedToArray(_useState, 2),
21
+ hasEditPositions = _useState2[0],
22
+ setHasEditPositions = _useState2[1];
23
+ var _useState3 = useState([]),
24
+ _useState4 = _slicedToArray(_useState3, 2),
25
+ usersToEditPositions = _useState4[0],
26
+ setUsersToEditPositions = _useState4[1];
27
+ var _useState5 = useState([]),
28
+ _useState6 = _slicedToArray(_useState5, 2),
29
+ positions = _useState6[0],
30
+ setPositions = _useState6[1];
31
+ var _useGetUsers = useGetUsers(),
32
+ handleGetUsers = _useGetUsers.handleGetUsers,
33
+ loading = _useGetUsers.loading,
34
+ error = _useGetUsers.error,
35
+ users = _useGetUsers.users,
36
+ totalUsers = _useGetUsers.totalUsers,
37
+ currentPage = _useGetUsers.currentPage,
38
+ totalPages = _useGetUsers.totalPages;
39
+ var handleSetHasEditPositions = useCallback(function (value) {
40
+ if (!value) setUsersToEditPositions([]);
41
+ setHasEditPositions(value);
42
+ }, []);
43
+ var handleSetUsersToEditPositions = useCallback(function (value) {
44
+ setUsersToEditPositions(function (prev) {
45
+ var exists = prev.some(function (user) {
46
+ return (user === null || user === void 0 ? void 0 : user.id) === value.id;
47
+ });
48
+ if (exists) return prev.filter(function (user) {
49
+ return (user === null || user === void 0 ? void 0 : user.id) !== value.id;
50
+ });
51
+ return [].concat(_toConsumableArray(prev), [value]);
52
+ });
53
+ }, []);
54
+ var handleSetPositions = useCallback(function (newPositions) {
55
+ setPositions(newPositions);
56
+ }, []);
57
+ useEffect(function () {
58
+ if (view === 'users') {
59
+ handleGetUsers({
60
+ page: 1
61
+ });
62
+ }
63
+ }, [view, handleGetUsers]);
64
+ var queryValue = useMemo(function () {
65
+ return {
66
+ users: users,
67
+ totalUsers: totalUsers,
68
+ currentPage: currentPage,
69
+ totalPages: totalPages,
70
+ loading: loading,
71
+ error: error,
72
+ positions: positions,
73
+ handleGetUsers: handleGetUsers,
74
+ handleSetPositions: handleSetPositions
75
+ };
76
+ }, [users, totalUsers, currentPage, loading, error, positions, handleGetUsers, handleSetPositions]);
77
+ var editPositionsValue = useMemo(function () {
78
+ return {
79
+ hasEditPositions: hasEditPositions,
80
+ handleSetHasEditPositions: handleSetHasEditPositions,
81
+ usersToEditPositions: usersToEditPositions,
82
+ handleSetUsersToEditPositions: handleSetUsersToEditPositions
83
+ };
84
+ }, [hasEditPositions, handleSetHasEditPositions, usersToEditPositions, handleSetUsersToEditPositions]);
85
+ var viewValue = useMemo(function () {
86
+ return {
87
+ view: view
88
+ };
89
+ }, [view]);
90
+ var countValue = useMemo(function () {
91
+ return {
92
+ totalUsers: totalUsers
93
+ };
94
+ }, [totalUsers]);
95
+ return /*#__PURE__*/_jsx(UsersViewContext.Provider, {
96
+ value: viewValue,
97
+ children: /*#__PURE__*/_jsx(UsersCountContext.Provider, {
98
+ value: countValue,
99
+ children: /*#__PURE__*/_jsx(UsersQueryContext.Provider, {
100
+ value: queryValue,
101
+ children: /*#__PURE__*/_jsx(UsersEditPositionsContext.Provider, {
102
+ value: editPositionsValue,
103
+ children: children
104
+ })
105
+ })
106
+ })
107
+ });
108
+ };
109
+ export var useUsersQuery = function useUsersQuery() {
110
+ var context = useContext(UsersQueryContext);
111
+ if (context === undefined) throw new Error('useUsersQuery must be used within a UsersProvider');
112
+ return context;
113
+ };
114
+ export var useUsersView = function useUsersView() {
115
+ var context = useContext(UsersViewContext);
116
+ if (context === undefined) throw new Error('useUsersView must be used within a UsersProvider');
117
+ return context;
118
+ };
119
+ export var useUsersEditPositions = function useUsersEditPositions() {
120
+ var context = useContext(UsersEditPositionsContext);
121
+ if (context === undefined) throw new Error('useUsersEditPositions must be used within a UsersProvider');
122
+ return context;
123
+ };
124
+ export var useUserInfo = function useUserInfo() {
125
+ var context = useContext(UserContext);
126
+ if (context === undefined) throw new Error('useUserInfo must be used within a UsersProvider');
127
+ return context;
128
+ };
129
+ export var useUsersCount = function useUsersCount() {
130
+ var context = useContext(UsersCountContext);
131
+ if (context === undefined) throw new Error('useUsersCount must be used within a UsersProvider');
132
+ return context;
133
+ };
134
+
135
+ // Backward-compatible hook. Prefer the specific hooks above.
136
+ export var useUsers = function useUsers() {
137
+ var query = useUsersQuery();
138
+ var viewCtx = useUsersView();
139
+ var edit = useUsersEditPositions();
140
+ var userInfo = useUserInfo();
141
+ return _objectSpread(_objectSpread(_objectSpread(_objectSpread({}, query), viewCtx), edit), {}, {
142
+ userInfo: userInfo
143
+ });
144
+ };
145
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["createContext","useCallback","useContext","useMemo","useState","useEffect","UserContext","useGetUsers","jsx","_jsx","UsersQueryContext","undefined","UsersViewContext","UsersEditPositionsContext","UsersCountContext","UsersProvider","_ref","children","view","_useState","_useState2","_slicedToArray","hasEditPositions","setHasEditPositions","_useState3","_useState4","usersToEditPositions","setUsersToEditPositions","_useState5","_useState6","positions","setPositions","_useGetUsers","handleGetUsers","loading","error","users","totalUsers","currentPage","totalPages","handleSetHasEditPositions","value","handleSetUsersToEditPositions","prev","exists","some","user","id","filter","concat","_toConsumableArray","handleSetPositions","newPositions","page","queryValue","editPositionsValue","viewValue","countValue","Provider","useUsersQuery","context","Error","useUsersView","useUsersEditPositions","useUserInfo","useUsersCount","useUsers","query","viewCtx","edit","userInfo","_objectSpread"],"sources":["../../src/context/UsersContext.tsx"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-shadow */\n/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { createContext, useCallback, useContext, useMemo, ReactNode, useState, useEffect } from 'react'\nimport { UserContext } from '@projectcor/cor-commons/lib/providers/UserProvider'\nimport { useGetUsers } from '../hooks/useGetUsers'\nimport { User, ViewType } from '../types/userType'\n\ninterface UsersQueryContextType {\n  users: User[]\n  totalUsers: number\n  currentPage: number\n  totalPages: number\n  loading: boolean\n  error: any\n  positions: { id: number; label: string; categoryName?: string }[]\n  handleGetUsers: ({\n    searchInput,\n    page,\n    valuesToFilter,\n  }: {\n    searchInput?: string\n    page?: number\n    valuesToFilter?: any[]\n  }) => void\n  handleSetPositions: (positions: { id: number; label: string; categoryName?: string }[]) => void\n}\n\ninterface UsersViewContextType {\n  view: ViewType\n}\n\nexport type InfoUser = {\n  id: number\n  firstName: string\n  lastName: string\n  lang: string\n  company_id: number\n  company: string\n  remainingHours?: number\n  dailyHours: number\n  authorized_by?: { id: number }\n  role_id: number\n  picture: string\n}\n\ninterface UsersEditPositionsContextType {\n  hasEditPositions: boolean\n  handleSetHasEditPositions: (value: boolean) => void\n  usersToEditPositions: User[]\n  handleSetUsersToEditPositions: (value: User) => void\n}\n\nexport interface UserTypes extends InfoUser {\n  permissions: Partial<Permissions>\n  settings?: {\n    block_task_without_project?: boolean\n  }\n}\n\nconst UsersQueryContext = createContext<UsersQueryContextType | undefined>(undefined)\nconst UsersViewContext = createContext<UsersViewContextType | undefined>(undefined)\nconst UsersEditPositionsContext = createContext<UsersEditPositionsContextType | undefined>(undefined)\nconst UsersCountContext = createContext<{ totalUsers: number } | undefined>(undefined)\n\nexport const UsersProvider = ({ children, view }: { children: ReactNode; view: ViewType }) => {\n  const [hasEditPositions, setHasEditPositions] = useState(false)\n  const [usersToEditPositions, setUsersToEditPositions] = useState<User[]>([])\n  const [positions, setPositions] = useState<{ id: number; label: string; categoryName?: string }[]>([])\n  const { handleGetUsers, loading, error, users, totalUsers, currentPage, totalPages } = useGetUsers()\n\n  const handleSetHasEditPositions = useCallback((value: boolean) => {\n    if (!value) setUsersToEditPositions([])\n    setHasEditPositions(value)\n  }, [])\n\n  const handleSetUsersToEditPositions = useCallback((value: User) => {\n    setUsersToEditPositions(prev => {\n      const exists = prev.some(user => user?.id === value.id)\n      if (exists) return prev.filter(user => user?.id !== value.id)\n      return [...prev, value]\n    })\n  }, [])\n\n  const handleSetPositions = useCallback((newPositions: { id: number; label: string; categoryName?: string }[]) => {\n    setPositions(newPositions)\n  }, [])\n\n  useEffect(() => {\n    if (view === 'users') {\n      handleGetUsers({ page: 1 })\n    }\n  }, [view, handleGetUsers])\n\n  const queryValue = useMemo(\n    () => ({\n      users,\n      totalUsers,\n      currentPage,\n      totalPages,\n      loading,\n      error,\n      positions,\n      handleGetUsers,\n      handleSetPositions,\n    }),\n    [users, totalUsers, currentPage, loading, error, positions, handleGetUsers, handleSetPositions]\n  )\n\n  const editPositionsValue = useMemo(\n    () => ({\n      hasEditPositions,\n      handleSetHasEditPositions,\n      usersToEditPositions,\n      handleSetUsersToEditPositions,\n    }),\n    [hasEditPositions, handleSetHasEditPositions, usersToEditPositions, handleSetUsersToEditPositions]\n  )\n\n  const viewValue = useMemo(() => ({ view }), [view])\n  const countValue = useMemo(() => ({ totalUsers }), [totalUsers])\n\n  return (\n    <UsersViewContext.Provider value={viewValue}>\n      <UsersCountContext.Provider value={countValue}>\n        <UsersQueryContext.Provider value={queryValue}>\n          <UsersEditPositionsContext.Provider value={editPositionsValue}>{children}</UsersEditPositionsContext.Provider>\n        </UsersQueryContext.Provider>\n      </UsersCountContext.Provider>\n    </UsersViewContext.Provider>\n  )\n}\n\nexport const useUsersQuery = () => {\n  const context = useContext(UsersQueryContext)\n  if (context === undefined) throw new Error('useUsersQuery must be used within a UsersProvider')\n  return context\n}\n\nexport const useUsersView = () => {\n  const context = useContext(UsersViewContext)\n  if (context === undefined) throw new Error('useUsersView must be used within a UsersProvider')\n  return context\n}\n\nexport const useUsersEditPositions = () => {\n  const context = useContext(UsersEditPositionsContext)\n  if (context === undefined) throw new Error('useUsersEditPositions must be used within a UsersProvider')\n  return context\n}\n\nexport const useUserInfo = () => {\n  const context = useContext<UserTypes>(UserContext)\n  if (context === undefined) throw new Error('useUserInfo must be used within a UsersProvider')\n  return context\n}\n\nexport const useUsersCount = () => {\n  const context = useContext(UsersCountContext)\n  if (context === undefined) throw new Error('useUsersCount must be used within a UsersProvider')\n  return context\n}\n\n// Backward-compatible hook. Prefer the specific hooks above.\nexport const useUsers = () => {\n  const query = useUsersQuery()\n  const viewCtx = useUsersView()\n  const edit = useUsersEditPositions()\n  const userInfo = useUserInfo()\n  return { ...query, ...viewCtx, ...edit, userInfo }\n}\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,17 @@
1
+ import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
2
+ import { useEffect, useState } from 'react';
3
+ export var useAbortController = function useAbortController() {
4
+ var _useState = useState(new AbortController()),
5
+ _useState2 = _slicedToArray(_useState, 2),
6
+ controller = _useState2[0],
7
+ setController = _useState2[1];
8
+ useEffect(function () {
9
+ var newController = new AbortController();
10
+ setController(newController);
11
+ return function () {
12
+ return newController.abort();
13
+ };
14
+ }, []);
15
+ return controller;
16
+ };
17
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJ1c2VFZmZlY3QiLCJ1c2VTdGF0ZSIsInVzZUFib3J0Q29udHJvbGxlciIsIl91c2VTdGF0ZSIsIkFib3J0Q29udHJvbGxlciIsIl91c2VTdGF0ZTIiLCJfc2xpY2VkVG9BcnJheSIsImNvbnRyb2xsZXIiLCJzZXRDb250cm9sbGVyIiwibmV3Q29udHJvbGxlciIsImFib3J0Il0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL2hvb2tzL3VzZUFib3J0Q29udHJvbGxlci50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB1c2VFZmZlY3QsIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnXG5cbmV4cG9ydCBjb25zdCB1c2VBYm9ydENvbnRyb2xsZXIgPSAoKSA9PiB7XG4gIGNvbnN0IFtjb250cm9sbGVyLCBzZXRDb250cm9sbGVyXSA9IHVzZVN0YXRlKG5ldyBBYm9ydENvbnRyb2xsZXIoKSlcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGNvbnN0IG5ld0NvbnRyb2xsZXIgPSBuZXcgQWJvcnRDb250cm9sbGVyKClcbiAgICBzZXRDb250cm9sbGVyKG5ld0NvbnRyb2xsZXIpXG4gICAgcmV0dXJuICgpID0+IG5ld0NvbnRyb2xsZXIuYWJvcnQoKVxuICB9LCBbXSlcblxuICByZXR1cm4gY29udHJvbGxlclxufVxuIl0sIm1hcHBpbmdzIjoiO0FBQUEsU0FBU0EsU0FBUyxFQUFFQyxRQUFRLFFBQVEsT0FBTztBQUUzQyxPQUFPLElBQU1DLGtCQUFrQixHQUFHLFNBQXJCQSxrQkFBa0JBLENBQUEsRUFBUztFQUN0QyxJQUFBQyxTQUFBLEdBQW9DRixRQUFRLENBQUMsSUFBSUcsZUFBZSxDQUFDLENBQUMsQ0FBQztJQUFBQyxVQUFBLEdBQUFDLGNBQUEsQ0FBQUgsU0FBQTtJQUE1REksVUFBVSxHQUFBRixVQUFBO0lBQUVHLGFBQWEsR0FBQUgsVUFBQTtFQUVoQ0wsU0FBUyxDQUFDLFlBQU07SUFDZCxJQUFNUyxhQUFhLEdBQUcsSUFBSUwsZUFBZSxDQUFDLENBQUM7SUFDM0NJLGFBQWEsQ0FBQ0MsYUFBYSxDQUFDO0lBQzVCLE9BQU87TUFBQSxPQUFNQSxhQUFhLENBQUNDLEtBQUssQ0FBQyxDQUFDO0lBQUE7RUFDcEMsQ0FBQyxFQUFFLEVBQUUsQ0FBQztFQUVOLE9BQU9ILFVBQVU7QUFDbkIsQ0FBQyIsImlnbm9yZUxpc3QiOltdfQ==
@@ -0,0 +1,18 @@
1
+ import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
2
+ import { useState, useEffect } from 'react';
3
+ export function useDebounce(value, delay) {
4
+ var _useState = useState(value),
5
+ _useState2 = _slicedToArray(_useState, 2),
6
+ debouncedValue = _useState2[0],
7
+ setDebouncedValue = _useState2[1];
8
+ useEffect(function () {
9
+ var timer = setTimeout(function () {
10
+ setDebouncedValue(value);
11
+ }, delay);
12
+ return function () {
13
+ clearTimeout(timer);
14
+ };
15
+ }, [value, delay]);
16
+ return debouncedValue;
17
+ }
18
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJ1c2VTdGF0ZSIsInVzZUVmZmVjdCIsInVzZURlYm91bmNlIiwidmFsdWUiLCJkZWxheSIsIl91c2VTdGF0ZSIsIl91c2VTdGF0ZTIiLCJfc2xpY2VkVG9BcnJheSIsImRlYm91bmNlZFZhbHVlIiwic2V0RGVib3VuY2VkVmFsdWUiLCJ0aW1lciIsInNldFRpbWVvdXQiLCJjbGVhclRpbWVvdXQiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvaG9va3MvdXNlRGVib3VuY2UudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdXNlU3RhdGUsIHVzZUVmZmVjdCB9IGZyb20gJ3JlYWN0J1xuXG5leHBvcnQgZnVuY3Rpb24gdXNlRGVib3VuY2U8VD4odmFsdWU6IFQsIGRlbGF5OiBudW1iZXIpOiBUIHtcbiAgY29uc3QgW2RlYm91bmNlZFZhbHVlLCBzZXREZWJvdW5jZWRWYWx1ZV0gPSB1c2VTdGF0ZTxUPih2YWx1ZSlcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGNvbnN0IHRpbWVyID0gc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICBzZXREZWJvdW5jZWRWYWx1ZSh2YWx1ZSlcbiAgICB9LCBkZWxheSlcblxuICAgIHJldHVybiAoKSA9PiB7XG4gICAgICBjbGVhclRpbWVvdXQodGltZXIpXG4gICAgfVxuICB9LCBbdmFsdWUsIGRlbGF5XSlcblxuICByZXR1cm4gZGVib3VuY2VkVmFsdWVcbn1cbiJdLCJtYXBwaW5ncyI6IjtBQUFBLFNBQVNBLFFBQVEsRUFBRUMsU0FBUyxRQUFRLE9BQU87QUFFM0MsT0FBTyxTQUFTQyxXQUFXQSxDQUFJQyxLQUFRLEVBQUVDLEtBQWEsRUFBSztFQUN6RCxJQUFBQyxTQUFBLEdBQTRDTCxRQUFRLENBQUlHLEtBQUssQ0FBQztJQUFBRyxVQUFBLEdBQUFDLGNBQUEsQ0FBQUYsU0FBQTtJQUF2REcsY0FBYyxHQUFBRixVQUFBO0lBQUVHLGlCQUFpQixHQUFBSCxVQUFBO0VBRXhDTCxTQUFTLENBQUMsWUFBTTtJQUNkLElBQU1TLEtBQUssR0FBR0MsVUFBVSxDQUFDLFlBQU07TUFDN0JGLGlCQUFpQixDQUFDTixLQUFLLENBQUM7SUFDMUIsQ0FBQyxFQUFFQyxLQUFLLENBQUM7SUFFVCxPQUFPLFlBQU07TUFDWFEsWUFBWSxDQUFDRixLQUFLLENBQUM7SUFDckIsQ0FBQztFQUNILENBQUMsRUFBRSxDQUFDUCxLQUFLLEVBQUVDLEtBQUssQ0FBQyxDQUFDO0VBRWxCLE9BQU9JLGNBQWM7QUFDdkIiLCJpZ25vcmVMaXN0IjpbXX0=
@@ -0,0 +1,30 @@
1
+ import { GET_TEAMS } from '../query/getTeams';
2
+ import { apolloReasourceAllocationServiceClient } from '../utils/ApolloMicroServiceClient';
3
+ import { useLazyQueryAdapter } from './useGraphAdapter';
4
+ export var useGetTeams = function useGetTeams() {
5
+ var _useLazyQueryAdapter = useLazyQueryAdapter({
6
+ query: GET_TEAMS,
7
+ client: apolloReasourceAllocationServiceClient
8
+ }),
9
+ fetchGetTeams = _useLazyQueryAdapter.handleFetchLazyQuery,
10
+ data = _useLazyQueryAdapter.data,
11
+ loading = _useLazyQueryAdapter.loading,
12
+ error = _useLazyQueryAdapter.error;
13
+ var handleGetTeams = function handleGetTeams(page, filter) {
14
+ fetchGetTeams({
15
+ variables: {
16
+ page: page,
17
+ filter: {
18
+ name: filter || ''
19
+ }
20
+ }
21
+ });
22
+ };
23
+ return {
24
+ handleGetTeams: handleGetTeams,
25
+ loading: loading,
26
+ error: error,
27
+ data: data
28
+ };
29
+ };
30
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJHRVRfVEVBTVMiLCJhcG9sbG9SZWFzb3VyY2VBbGxvY2F0aW9uU2VydmljZUNsaWVudCIsInVzZUxhenlRdWVyeUFkYXB0ZXIiLCJ1c2VHZXRUZWFtcyIsIl91c2VMYXp5UXVlcnlBZGFwdGVyIiwicXVlcnkiLCJjbGllbnQiLCJmZXRjaEdldFRlYW1zIiwiaGFuZGxlRmV0Y2hMYXp5UXVlcnkiLCJkYXRhIiwibG9hZGluZyIsImVycm9yIiwiaGFuZGxlR2V0VGVhbXMiLCJwYWdlIiwiZmlsdGVyIiwidmFyaWFibGVzIiwibmFtZSJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9ob29rcy91c2VHZXRUZWFtcy50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBHRVRfVEVBTVMgfSBmcm9tICcuLi9xdWVyeS9nZXRUZWFtcydcbmltcG9ydCB7IGFwb2xsb1JlYXNvdXJjZUFsbG9jYXRpb25TZXJ2aWNlQ2xpZW50IH0gZnJvbSAnLi4vdXRpbHMvQXBvbGxvTWljcm9TZXJ2aWNlQ2xpZW50J1xuaW1wb3J0IHsgdXNlTGF6eVF1ZXJ5QWRhcHRlciB9IGZyb20gJy4vdXNlR3JhcGhBZGFwdGVyJ1xuXG5leHBvcnQgY29uc3QgdXNlR2V0VGVhbXMgPSAoKSA9PiB7XG4gIGNvbnN0IHtcbiAgICBoYW5kbGVGZXRjaExhenlRdWVyeTogZmV0Y2hHZXRUZWFtcyxcbiAgICBkYXRhLFxuICAgIGxvYWRpbmcsXG4gICAgZXJyb3IsXG4gIH0gPSB1c2VMYXp5UXVlcnlBZGFwdGVyPHtcbiAgICB0ZWFtczoge1xuICAgICAgcGFnZTogbnVtYmVyXG4gICAgICBsYXN0UGFnZTogbnVtYmVyXG4gICAgICBkYXRhOiBhbnlbXVxuICAgIH1cbiAgfT4oe1xuICAgIHF1ZXJ5OiBHRVRfVEVBTVMsXG4gICAgY2xpZW50OiBhcG9sbG9SZWFzb3VyY2VBbGxvY2F0aW9uU2VydmljZUNsaWVudCxcbiAgfSlcblxuICBjb25zdCBoYW5kbGVHZXRUZWFtcyA9IChwYWdlOiBudW1iZXIsIGZpbHRlcj86IHsgbmFtZTogc3RyaW5nIH0pID0+IHtcbiAgICBmZXRjaEdldFRlYW1zKHtcbiAgICAgIHZhcmlhYmxlczoge1xuICAgICAgICBwYWdlLFxuICAgICAgICBmaWx0ZXI6IHtcbiAgICAgICAgICBuYW1lOiBmaWx0ZXIgfHwgJycsXG4gICAgICAgIH0sXG4gICAgICB9LFxuICAgIH0pXG4gIH1cblxuICByZXR1cm4geyBoYW5kbGVHZXRUZWFtcywgbG9hZGluZywgZXJyb3IsIGRhdGEgfVxufVxuIl0sIm1hcHBpbmdzIjoiQUFBQSxTQUFTQSxTQUFTLFFBQVEsbUJBQW1CO0FBQzdDLFNBQVNDLHNDQUFzQyxRQUFRLG1DQUFtQztBQUMxRixTQUFTQyxtQkFBbUIsUUFBUSxtQkFBbUI7QUFFdkQsT0FBTyxJQUFNQyxXQUFXLEdBQUcsU0FBZEEsV0FBV0EsQ0FBQSxFQUFTO0VBQy9CLElBQUFDLG9CQUFBLEdBS0lGLG1CQUFtQixDQU1wQjtNQUNERyxLQUFLLEVBQUVMLFNBQVM7TUFDaEJNLE1BQU0sRUFBRUw7SUFDVixDQUFDLENBQUM7SUFic0JNLGFBQWEsR0FBQUgsb0JBQUEsQ0FBbkNJLG9CQUFvQjtJQUNwQkMsSUFBSSxHQUFBTCxvQkFBQSxDQUFKSyxJQUFJO0lBQ0pDLE9BQU8sR0FBQU4sb0JBQUEsQ0FBUE0sT0FBTztJQUNQQyxLQUFLLEdBQUFQLG9CQUFBLENBQUxPLEtBQUs7RUFZUCxJQUFNQyxjQUFjLEdBQUcsU0FBakJBLGNBQWNBLENBQUlDLElBQVksRUFBRUMsTUFBeUIsRUFBSztJQUNsRVAsYUFBYSxDQUFDO01BQ1pRLFNBQVMsRUFBRTtRQUNURixJQUFJLEVBQUpBLElBQUk7UUFDSkMsTUFBTSxFQUFFO1VBQ05FLElBQUksRUFBRUYsTUFBTSxJQUFJO1FBQ2xCO01BQ0Y7SUFDRixDQUFDLENBQUM7RUFDSixDQUFDO0VBRUQsT0FBTztJQUFFRixjQUFjLEVBQWRBLGNBQWM7SUFBRUYsT0FBTyxFQUFQQSxPQUFPO0lBQUVDLEtBQUssRUFBTEEsS0FBSztJQUFFRixJQUFJLEVBQUpBO0VBQUssQ0FBQztBQUNqRCxDQUFDIiwiaWdub3JlTGlzdCI6W119
@@ -0,0 +1,29 @@
1
+ import { GET_USER_POSITION_FILTER } from '../query/getUserPositionFilter';
2
+ import { apolloReasourceAllocationServiceClient } from '../utils/ApolloMicroServiceClient';
3
+ import { useLazyQueryAdapter } from './useGraphAdapter';
4
+ export var useGetUserPositionFilter = function useGetUserPositionFilter() {
5
+ var _useLazyQueryAdapter = useLazyQueryAdapter({
6
+ query: GET_USER_POSITION_FILTER,
7
+ client: apolloReasourceAllocationServiceClient
8
+ }),
9
+ fetchGetTeams = _useLazyQueryAdapter.handleFetchLazyQuery,
10
+ data = _useLazyQueryAdapter.data,
11
+ loading = _useLazyQueryAdapter.loading,
12
+ error = _useLazyQueryAdapter.error;
13
+ var handleGetUserPositionFilter = function handleGetUserPositionFilter(name) {
14
+ var page = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 1;
15
+ fetchGetTeams({
16
+ variables: {
17
+ name: name,
18
+ page: page
19
+ }
20
+ });
21
+ };
22
+ return {
23
+ handleGetUserPositionFilter: handleGetUserPositionFilter,
24
+ loading: loading,
25
+ error: error,
26
+ data: data
27
+ };
28
+ };
29
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJHRVRfVVNFUl9QT1NJVElPTl9GSUxURVIiLCJhcG9sbG9SZWFzb3VyY2VBbGxvY2F0aW9uU2VydmljZUNsaWVudCIsInVzZUxhenlRdWVyeUFkYXB0ZXIiLCJ1c2VHZXRVc2VyUG9zaXRpb25GaWx0ZXIiLCJfdXNlTGF6eVF1ZXJ5QWRhcHRlciIsInF1ZXJ5IiwiY2xpZW50IiwiZmV0Y2hHZXRUZWFtcyIsImhhbmRsZUZldGNoTGF6eVF1ZXJ5IiwiZGF0YSIsImxvYWRpbmciLCJlcnJvciIsImhhbmRsZUdldFVzZXJQb3NpdGlvbkZpbHRlciIsIm5hbWUiLCJwYWdlIiwiYXJndW1lbnRzIiwibGVuZ3RoIiwidW5kZWZpbmVkIiwidmFyaWFibGVzIl0sInNvdXJjZXMiOlsiLi4vLi4vc3JjL2hvb2tzL3VzZUdldFVzZXJQb3NpdGlvbkZpbHRlci50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBHRVRfVVNFUl9QT1NJVElPTl9GSUxURVIgfSBmcm9tICcuLi9xdWVyeS9nZXRVc2VyUG9zaXRpb25GaWx0ZXInXG5pbXBvcnQgeyBhcG9sbG9SZWFzb3VyY2VBbGxvY2F0aW9uU2VydmljZUNsaWVudCB9IGZyb20gJy4uL3V0aWxzL0Fwb2xsb01pY3JvU2VydmljZUNsaWVudCdcbmltcG9ydCB7IHVzZUxhenlRdWVyeUFkYXB0ZXIgfSBmcm9tICcuL3VzZUdyYXBoQWRhcHRlcidcblxuZXhwb3J0IGNvbnN0IHVzZUdldFVzZXJQb3NpdGlvbkZpbHRlciA9ICgpID0+IHtcbiAgY29uc3Qge1xuICAgIGhhbmRsZUZldGNoTGF6eVF1ZXJ5OiBmZXRjaEdldFRlYW1zLFxuICAgIGRhdGEsXG4gICAgbG9hZGluZyxcbiAgICBlcnJvcixcbiAgfSA9IHVzZUxhenlRdWVyeUFkYXB0ZXI8e1xuICAgIHVzZXJQb3NpdGlvbnNGaWx0ZXI6IHtcbiAgICAgIGRhdGE6IHtcbiAgICAgICAgaWQ6IG51bWJlclxuICAgICAgICBuYW1lOiBzdHJpbmdcbiAgICAgICAgY2F0ZWdvcnlOYW1lOiBzdHJpbmdcbiAgICAgIH1bXVxuICAgIH1cbiAgfT4oe1xuICAgIHF1ZXJ5OiBHRVRfVVNFUl9QT1NJVElPTl9GSUxURVIsXG4gICAgY2xpZW50OiBhcG9sbG9SZWFzb3VyY2VBbGxvY2F0aW9uU2VydmljZUNsaWVudCxcbiAgfSlcblxuICBjb25zdCBoYW5kbGVHZXRVc2VyUG9zaXRpb25GaWx0ZXIgPSAobmFtZTogc3RyaW5nLCBwYWdlID0gMSkgPT4ge1xuICAgIGZldGNoR2V0VGVhbXMoe1xuICAgICAgdmFyaWFibGVzOiB7XG4gICAgICAgIG5hbWUsXG4gICAgICAgIHBhZ2UsXG4gICAgICB9LFxuICAgIH0pXG4gIH1cblxuICByZXR1cm4geyBoYW5kbGVHZXRVc2VyUG9zaXRpb25GaWx0ZXIsIGxvYWRpbmcsIGVycm9yLCBkYXRhIH1cbn1cbiJdLCJtYXBwaW5ncyI6IkFBQUEsU0FBU0Esd0JBQXdCLFFBQVEsZ0NBQWdDO0FBQ3pFLFNBQVNDLHNDQUFzQyxRQUFRLG1DQUFtQztBQUMxRixTQUFTQyxtQkFBbUIsUUFBUSxtQkFBbUI7QUFFdkQsT0FBTyxJQUFNQyx3QkFBd0IsR0FBRyxTQUEzQkEsd0JBQXdCQSxDQUFBLEVBQVM7RUFDNUMsSUFBQUMsb0JBQUEsR0FLSUYsbUJBQW1CLENBUXBCO01BQ0RHLEtBQUssRUFBRUwsd0JBQXdCO01BQy9CTSxNQUFNLEVBQUVMO0lBQ1YsQ0FBQyxDQUFDO0lBZnNCTSxhQUFhLEdBQUFILG9CQUFBLENBQW5DSSxvQkFBb0I7SUFDcEJDLElBQUksR0FBQUwsb0JBQUEsQ0FBSkssSUFBSTtJQUNKQyxPQUFPLEdBQUFOLG9CQUFBLENBQVBNLE9BQU87SUFDUEMsS0FBSyxHQUFBUCxvQkFBQSxDQUFMTyxLQUFLO0VBY1AsSUFBTUMsMkJBQTJCLEdBQUcsU0FBOUJBLDJCQUEyQkEsQ0FBSUMsSUFBWSxFQUFlO0lBQUEsSUFBYkMsSUFBSSxHQUFBQyxTQUFBLENBQUFDLE1BQUEsUUFBQUQsU0FBQSxRQUFBRSxTQUFBLEdBQUFGLFNBQUEsTUFBRyxDQUFDO0lBQ3pEUixhQUFhLENBQUM7TUFDWlcsU0FBUyxFQUFFO1FBQ1RMLElBQUksRUFBSkEsSUFBSTtRQUNKQyxJQUFJLEVBQUpBO01BQ0Y7SUFDRixDQUFDLENBQUM7RUFDSixDQUFDO0VBRUQsT0FBTztJQUFFRiwyQkFBMkIsRUFBM0JBLDJCQUEyQjtJQUFFRixPQUFPLEVBQVBBLE9BQU87SUFBRUMsS0FBSyxFQUFMQSxLQUFLO0lBQUVGLElBQUksRUFBSkE7RUFBSyxDQUFDO0FBQzlELENBQUMiLCJpZ25vcmVMaXN0IjpbXX0=
@@ -0,0 +1,100 @@
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
+ import { useCallback, useEffect, useState } from 'react';
6
+ import { useLazyQueryAdapter } from './useGraphAdapter';
7
+ import { GET_USERS } from '../query/getUsers';
8
+ import { apolloReasourceAllocationServiceClient } from '../utils/ApolloMicroServiceClient';
9
+ var roleByRoleId = {
10
+ 1: 'Admin',
11
+ 2: 'User',
12
+ 3: 'Manager',
13
+ 4: 'Supervisor',
14
+ 5: 'Director'
15
+ };
16
+ export var useGetUsers = function useGetUsers() {
17
+ var _useState = useState([]),
18
+ _useState2 = _slicedToArray(_useState, 2),
19
+ users = _useState2[0],
20
+ setUsers = _useState2[1];
21
+ var _useState3 = useState(0),
22
+ _useState4 = _slicedToArray(_useState3, 2),
23
+ totalUsers = _useState4[0],
24
+ setTotalUsers = _useState4[1];
25
+ var _useState5 = useState(1),
26
+ _useState6 = _slicedToArray(_useState5, 2),
27
+ currentPage = _useState6[0],
28
+ setCurrentPage = _useState6[1];
29
+ var _useState7 = useState(0),
30
+ _useState8 = _slicedToArray(_useState7, 2),
31
+ totalPages = _useState8[0],
32
+ setTotalPages = _useState8[1];
33
+ var _useLazyQueryAdapter = useLazyQueryAdapter({
34
+ query: GET_USERS,
35
+ client: apolloReasourceAllocationServiceClient
36
+ }),
37
+ fetchGetUsers = _useLazyQueryAdapter.handleFetchLazyQuery,
38
+ data = _useLazyQueryAdapter.data,
39
+ loading = _useLazyQueryAdapter.loading,
40
+ error = _useLazyQueryAdapter.error;
41
+ var handleGetUsers = useCallback(function (_ref) {
42
+ var searchInput = _ref.searchInput,
43
+ _ref$page = _ref.page,
44
+ page = _ref$page === void 0 ? 1 : _ref$page,
45
+ valuesToFilter = _ref.valuesToFilter;
46
+ var variables = {
47
+ filters: JSON.stringify(_objectSpread(_objectSpread({
48
+ withPosition: true,
49
+ withHiddenUsers: true,
50
+ isGroupedByLabels: false
51
+ }, searchInput && {
52
+ searchInput: searchInput
53
+ }), valuesToFilter && _objectSpread({}, valuesToFilter))),
54
+ page: page
55
+ };
56
+ fetchGetUsers({
57
+ variables: variables
58
+ });
59
+ }, [fetchGetUsers]);
60
+ useEffect(function () {
61
+ if (data !== null && data !== void 0 && data.userFilter && !loading && !error) {
62
+ var parsedUsers = data.userFilter.data.map(function (user, index) {
63
+ return {
64
+ id: user.id,
65
+ fullName: "".concat(user.firstName, " ").concat(user.lastName),
66
+ position: user.positionName || 'Sin posición',
67
+ email: user.email,
68
+ team: user.team || 'Sin equipo',
69
+ firstName: user.firstName,
70
+ lastName: user.lastName,
71
+ picture: user.picture,
72
+ userPositionId: user.userPositionId,
73
+ hours: user.hours || index + 1,
74
+ costHour: user.costHour || user.id,
75
+ role: roleByRoleId[user.roleId],
76
+ remainingHours: user.remainingHours,
77
+ leaves: user.leaves,
78
+ isBlocked: user.isBlocked,
79
+ isDeleted: user.isDeleted || false,
80
+ hidden: user.hidden,
81
+ isActive: user.isActive
82
+ };
83
+ });
84
+ setUsers(parsedUsers);
85
+ setTotalUsers(data.userFilter.total);
86
+ setCurrentPage(+data.userFilter.page);
87
+ setTotalPages(+data.userFilter.lastPage);
88
+ }
89
+ }, [data, loading, error]);
90
+ return {
91
+ handleGetUsers: handleGetUsers,
92
+ loading: loading,
93
+ error: error,
94
+ users: users,
95
+ totalUsers: totalUsers,
96
+ currentPage: currentPage,
97
+ totalPages: totalPages
98
+ };
99
+ };
100
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["useCallback","useEffect","useState","useLazyQueryAdapter","GET_USERS","apolloReasourceAllocationServiceClient","roleByRoleId","useGetUsers","_useState","_useState2","_slicedToArray","users","setUsers","_useState3","_useState4","totalUsers","setTotalUsers","_useState5","_useState6","currentPage","setCurrentPage","_useState7","_useState8","totalPages","setTotalPages","_useLazyQueryAdapter","query","client","fetchGetUsers","handleFetchLazyQuery","data","loading","error","handleGetUsers","_ref","searchInput","_ref$page","page","valuesToFilter","variables","filters","JSON","stringify","_objectSpread","withPosition","withHiddenUsers","isGroupedByLabels","userFilter","parsedUsers","map","user","index","id","fullName","concat","firstName","lastName","position","positionName","email","team","picture","userPositionId","hours","costHour","role","roleId","remainingHours","leaves","isBlocked","isDeleted","hidden","isActive","total","lastPage"],"sources":["../../src/hooks/useGetUsers.ts"],"sourcesContent":["import { useCallback, useEffect, useState } from 'react'\nimport { useLazyQueryAdapter } from './useGraphAdapter'\nimport { GET_USERS } from '../query/getUsers'\nimport { apolloReasourceAllocationServiceClient } from '../utils/ApolloMicroServiceClient'\nimport { User, UsersResponse } from '../types/userType'\n\nconst roleByRoleId = {\n  1: 'Admin',\n  2: 'User',\n  3: 'Manager',\n  4: 'Supervisor',\n  5: 'Director',\n}\n\nexport const useGetUsers = () => {\n  const [users, setUsers] = useState<User[]>([])\n  const [totalUsers, setTotalUsers] = useState<number>(0)\n  const [currentPage, setCurrentPage] = useState<number>(1)\n  const [totalPages, setTotalPages] = useState<number>(0)\n  const {\n    handleFetchLazyQuery: fetchGetUsers,\n    data,\n    loading,\n    error,\n  } = useLazyQueryAdapter<UsersResponse>({\n    query: GET_USERS,\n    client: apolloReasourceAllocationServiceClient,\n  })\n\n  const handleGetUsers = useCallback(\n    ({ searchInput, page = 1, valuesToFilter }: { searchInput?: string; page?: number; valuesToFilter?: any }) => {\n      const variables = {\n        filters: JSON.stringify({\n          withPosition: true,\n          withHiddenUsers: true,\n          isGroupedByLabels: false,\n          ...(searchInput && { searchInput }),\n          ...(valuesToFilter && { ...valuesToFilter }),\n        }),\n        page,\n      }\n      fetchGetUsers({\n        variables,\n      })\n    },\n    [fetchGetUsers]\n  )\n\n  useEffect(() => {\n    if (data?.userFilter && !loading && !error) {\n      const parsedUsers = data.userFilter.data.map((user: any, index: number) => ({\n        id: user.id,\n        fullName: `${user.firstName} ${user.lastName}`,\n        position: user.positionName || 'Sin posición',\n        email: user.email,\n        team: user.team || 'Sin equipo',\n        firstName: user.firstName,\n        lastName: user.lastName,\n        picture: user.picture,\n        userPositionId: user.userPositionId,\n        hours: user.hours || index + 1,\n        costHour: user.costHour || user.id,\n        role: roleByRoleId[user.roleId],\n        remainingHours: user.remainingHours,\n        leaves: user.leaves,\n        isBlocked: user.isBlocked,\n        isDeleted: user.isDeleted || false,\n        hidden: user.hidden,\n        isActive: user.isActive,\n      }))\n      setUsers(parsedUsers)\n      setTotalUsers(data.userFilter.total)\n      setCurrentPage(+data.userFilter.page)\n      setTotalPages(+data.userFilter.lastPage)\n    }\n  }, [data, loading, error])\n\n  return {\n    handleGetUsers,\n    loading,\n    error,\n    users,\n    totalUsers,\n    currentPage,\n    totalPages,\n  }\n}\n"],"mappings":"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","ignoreList":[]}