@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,27 @@
1
+ import styled, { css } from 'styled-components';
2
+ export var SCRWrapper = styled.div.withConfig({
3
+ displayName: "Rowstyles__SCRWrapper",
4
+ componentId: "sc-17nzsxw-0"
5
+ })(["display:flex;height:75px;align-items:center;position:relative;", ""], function (_ref) {
6
+ var isBlocked = _ref.isBlocked;
7
+ return isBlocked && css(["& > *{color:#999999 !important;}"]);
8
+ });
9
+ export var SCRWrapperDay = styled.div.withConfig({
10
+ displayName: "Rowstyles__SCRWrapperDay",
11
+ componentId: "sc-17nzsxw-1"
12
+ })(["width:100px;line-height:130%;color:rgba(32,32,31,1);height:100%;padding:0 10px;font-size:12px;display:flex;align-items:center;"]);
13
+ export var SCRWrapperUser = styled.div.withConfig({
14
+ displayName: "Rowstyles__SCRWrapperUser",
15
+ componentId: "sc-17nzsxw-2"
16
+ })(["display:flex;align-items:center;flex:1;max-width:365px;height:100%;padding:0 10px;min-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-wrap:nowrap;"]);
17
+ export var SCRWrapperRow = styled.div.withConfig({
18
+ displayName: "Rowstyles__SCRWrapperRow",
19
+ componentId: "sc-17nzsxw-3"
20
+ })(["display:flex;align-items:center;flex:1;", " height:100%;padding:0 10px;font-size:12px;color:", ";"], function (_ref2) {
21
+ var width = _ref2.width;
22
+ return width && css(["justify-content:center;max-width:", ";"], width || '120px');
23
+ }, function (_ref3) {
24
+ var color = _ref3.color;
25
+ return color || 'rgba(102, 102, 102, 1)';
26
+ });
27
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJzdHlsZWQiLCJjc3MiLCJTQ1JXcmFwcGVyIiwiZGl2Iiwid2l0aENvbmZpZyIsImRpc3BsYXlOYW1lIiwiY29tcG9uZW50SWQiLCJfcmVmIiwiaXNCbG9ja2VkIiwiU0NSV3JhcHBlckRheSIsIlNDUldyYXBwZXJVc2VyIiwiU0NSV3JhcHBlclJvdyIsIl9yZWYyIiwid2lkdGgiLCJfcmVmMyIsImNvbG9yIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvVGFibGUvUm93L1Jvdy5zdHlsZXMudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQsIHsgY3NzIH0gZnJvbSAnc3R5bGVkLWNvbXBvbmVudHMnXG5cbmV4cG9ydCBjb25zdCBTQ1JXcmFwcGVyID0gc3R5bGVkLmRpdjx7IGlzQmxvY2tlZD86IGJvb2xlYW4gfT5gXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGhlaWdodDogNzVweDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgLyogYm9yZGVyLWJvdHRvbTogMXB4IHNvbGlkICNlN2U3ZTc7ICovXG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgJHsoeyBpc0Jsb2NrZWQgfSkgPT5cbiAgICBpc0Jsb2NrZWQgJiZcbiAgICBjc3NgXG4gICAgICAmID4gKiB7XG4gICAgICAgIGNvbG9yOiAjOTk5OTk5ICFpbXBvcnRhbnQ7XG4gICAgICB9XG4gICAgYH1cbmBcblxuZXhwb3J0IGNvbnN0IFNDUldyYXBwZXJEYXkgPSBzdHlsZWQuZGl2YFxuICB3aWR0aDogMTAwcHg7XG4gIGxpbmUtaGVpZ2h0OiAxMzAlO1xuICBjb2xvcjogcmdiYSgzMiwgMzIsIDMxLCAxKTtcbiAgaGVpZ2h0OiAxMDAlO1xuICBwYWRkaW5nOiAwIDEwcHg7XG4gIGZvbnQtc2l6ZTogMTJweDtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbmBcblxuZXhwb3J0IGNvbnN0IFNDUldyYXBwZXJVc2VyID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgZmxleDogMTtcbiAgbWF4LXdpZHRoOiAzNjVweDtcbiAgaGVpZ2h0OiAxMDAlO1xuICAvKiBib3JkZXItcmlnaHQ6IDFweCBzb2xpZCAjZTdlN2U3OyAqL1xuICBwYWRkaW5nOiAwIDEwcHg7XG4gIG1pbi13aWR0aDogMjAwcHg7XG4gIG92ZXJmbG93OiBoaWRkZW47XG4gIHRleHQtb3ZlcmZsb3c6IGVsbGlwc2lzO1xuICB3aGl0ZS1zcGFjZTogbm93cmFwO1xuICB0ZXh0LXdyYXA6IG5vd3JhcDtcbmBcblxuZXhwb3J0IGNvbnN0IFNDUldyYXBwZXJSb3cgPSBzdHlsZWQuZGl2PHsgd2lkdGg/OiBzdHJpbmc7IGNvbG9yPzogc3RyaW5nIH0+YFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBmbGV4OiAxO1xuICAkeyh7IHdpZHRoIH0pID0+XG4gICAgd2lkdGggJiZcbiAgICBjc3NgXG4gICAgICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcbiAgICAgIG1heC13aWR0aDogJHt3aWR0aCB8fCAnMTIwcHgnfTtcbiAgICBgfVxuICBoZWlnaHQ6IDEwMCU7XG4gIHBhZGRpbmc6IDAgMTBweDtcbiAgZm9udC1zaXplOiAxMnB4O1xuICBjb2xvcjogJHsoeyBjb2xvciB9KSA9PiBjb2xvciB8fCAncmdiYSgxMDIsIDEwMiwgMTAyLCAxKSd9O1xuYFxuIl0sIm1hcHBpbmdzIjoiQUFBQSxPQUFPQSxNQUFNLElBQUlDLEdBQUcsUUFBUSxtQkFBbUI7QUFFL0MsT0FBTyxJQUFNQyxVQUFVLEdBQUdGLE1BQU0sQ0FBQ0csR0FBRyxDQUFBQyxVQUFBO0VBQUFDLFdBQUE7RUFBQUMsV0FBQTtBQUFBLDJFQU1oQyxVQUFBQyxJQUFBO0VBQUEsSUFBR0MsU0FBUyxHQUFBRCxJQUFBLENBQVRDLFNBQVM7RUFBQSxPQUNaQSxTQUFTLElBQ1RQLEdBQUcsc0NBSUY7QUFBQSxFQUNKO0FBRUQsT0FBTyxJQUFNUSxhQUFhLEdBQUdULE1BQU0sQ0FBQ0csR0FBRyxDQUFBQyxVQUFBO0VBQUFDLFdBQUE7RUFBQUMsV0FBQTtBQUFBLHNJQVN0QztBQUVELE9BQU8sSUFBTUksY0FBYyxHQUFHVixNQUFNLENBQUNHLEdBQUcsQ0FBQUMsVUFBQTtFQUFBQyxXQUFBO0VBQUFDLFdBQUE7QUFBQSxxTEFhdkM7QUFFRCxPQUFPLElBQU1LLGFBQWEsR0FBR1gsTUFBTSxDQUFDRyxHQUFHLENBQUFDLFVBQUE7RUFBQUMsV0FBQTtFQUFBQyxXQUFBO0FBQUEsMEdBSW5DLFVBQUFNLEtBQUE7RUFBQSxJQUFHQyxLQUFLLEdBQUFELEtBQUEsQ0FBTEMsS0FBSztFQUFBLE9BQ1JBLEtBQUssSUFDTFosR0FBRyw2Q0FFWVksS0FBSyxJQUFJLE9BQU8sQ0FDOUI7QUFBQSxHQUlNLFVBQUFDLEtBQUE7RUFBQSxJQUFHQyxLQUFLLEdBQUFELEtBQUEsQ0FBTEMsS0FBSztFQUFBLE9BQU9BLEtBQUssSUFBSSx3QkFBd0I7QUFBQSxFQUMxRCIsImlnbm9yZUxpc3QiOltdfQ==
@@ -0,0 +1,2 @@
1
+ export { RowComponent } from './Row';
2
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJSb3dDb21wb25lbnQiXSwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9UYWJsZS9Sb3cvaW5kZXgudHMiXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgUm93Q29tcG9uZW50IH0gZnJvbSAnLi9Sb3cnXG4iXSwibWFwcGluZ3MiOiJBQUFBLFNBQVNBLFlBQVksUUFBUSxPQUFPIiwiaWdub3JlTGlzdCI6W119
@@ -0,0 +1,129 @@
1
+ /* eslint-disable no-nested-ternary */
2
+ /* eslint-disable no-undef */
3
+ /* eslint-disable react/require-default-props */
4
+ import { useRef } from 'react';
5
+ import { AvatarUser } from '@projectcor/cor-commons/lib/components/avatar-user';
6
+ import { Tooltip } from '@projectcor/tooltipv2/lib/components/Tooltip';
7
+ import { useTranslation } from 'react-i18next';
8
+ import { DeletedUserIcon } from '../DeletedUserIcon/DeletedUserIcon';
9
+ import { DisabledUserIcon } from '../DisabledUserIcon/DisabledUserIcon';
10
+ import { SCUIWrapper, SCUIWrapperLabel } from './UserRow.styles';
11
+ import { useResizeListener } from '../../hooks/useResize';
12
+ import { UserIconLock } from '../Icons';
13
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
14
+ export var UserRow = function UserRow(_ref) {
15
+ var firstName = _ref.firstName,
16
+ lastName = _ref.lastName,
17
+ picture = _ref.picture,
18
+ position = _ref.position,
19
+ email = _ref.email,
20
+ isDeleted = _ref.isDeleted,
21
+ hidden = _ref.hidden,
22
+ isBlocked = _ref.isBlocked;
23
+ var _useTranslation = useTranslation('people'),
24
+ t = _useTranslation.t;
25
+ var positionColumnRef = useRef(null);
26
+ var userNameColumnRef = useRef(null);
27
+ var emailColumnRef = useRef(null);
28
+ var _useResizeListener = useResizeListener(userNameColumnRef, [firstName, lastName]),
29
+ showTooltip = _useResizeListener.showTooltip;
30
+ var _useResizeListener2 = useResizeListener(positionColumnRef, [position]),
31
+ showPositionTooltip = _useResizeListener2.showTooltip;
32
+ var _useResizeListener3 = useResizeListener(emailColumnRef, [email]),
33
+ showEmailTooltip = _useResizeListener3.showTooltip;
34
+ return /*#__PURE__*/_jsx(SCUIWrapper, {
35
+ withBorder: true,
36
+ isBlocked: isBlocked,
37
+ children: /*#__PURE__*/_jsxs("div", {
38
+ style: {
39
+ display: 'flex',
40
+ gap: '8px'
41
+ },
42
+ children: [/*#__PURE__*/_jsxs("div", {
43
+ style: {
44
+ borderRadius: '50%',
45
+ backgroundColor: 'lightblue',
46
+ height: '32px',
47
+ width: '32px',
48
+ display: 'flex',
49
+ justifyContent: 'center',
50
+ alignItems: 'center',
51
+ position: 'relative'
52
+ },
53
+ children: [/*#__PURE__*/_jsx(AvatarUser, {
54
+ firstName: firstName,
55
+ lastName: lastName,
56
+ picture: picture
57
+ }), isBlocked ? /*#__PURE__*/_jsx(Tooltip, {
58
+ title: t('users.table.bloquedUserTooltip'),
59
+ children: /*#__PURE__*/_jsx("div", {
60
+ style: {
61
+ position: 'absolute',
62
+ left: '2px',
63
+ backgroundColor: 'white',
64
+ borderRadius: '50%',
65
+ padding: '2px',
66
+ display: 'flex',
67
+ justifyContent: 'center',
68
+ alignItems: 'center'
69
+ },
70
+ children: /*#__PURE__*/_jsx(UserIconLock, {})
71
+ })
72
+ }) : isDeleted ? /*#__PURE__*/_jsx(DeletedUserIcon, {}) : hidden && /*#__PURE__*/_jsx(DisabledUserIcon, {})]
73
+ }), /*#__PURE__*/_jsxs(SCUIWrapperLabel, {
74
+ children: [/*#__PURE__*/_jsxs("div", {
75
+ style: {
76
+ display: 'flex',
77
+ gap: 8,
78
+ fontSize: '12px'
79
+ },
80
+ children: [/*#__PURE__*/_jsx(Tooltip, {
81
+ title: showTooltip ? "".concat(firstName, " ").concat(lastName) : '',
82
+ children: /*#__PURE__*/_jsx("span", {
83
+ style: {
84
+ borderRight: '1px solid #E0E0E0',
85
+ paddingRight: '8px',
86
+ color: '#20201F',
87
+ textWrap: 'nowrap',
88
+ textTransform: 'capitalize',
89
+ textOverflow: 'ellipsis',
90
+ maxWidth: 'fit-content',
91
+ overflow: 'hidden'
92
+ },
93
+ ref: userNameColumnRef,
94
+ children: "".concat(firstName, " ").concat(lastName)
95
+ })
96
+ }), /*#__PURE__*/_jsx(Tooltip, {
97
+ title: showPositionTooltip ? position : '',
98
+ children: /*#__PURE__*/_jsx("span", {
99
+ style: {
100
+ color: '#666666',
101
+ textWrap: 'nowrap',
102
+ textTransform: 'capitalize',
103
+ maxWidth: 'fit-content',
104
+ overflow: 'hidden',
105
+ textOverflow: 'ellipsis'
106
+ },
107
+ ref: positionColumnRef,
108
+ children: !position || position === 'no_position' ? t('users.table.noPosition') : position
109
+ })
110
+ })]
111
+ }), /*#__PURE__*/_jsx(Tooltip, {
112
+ title: showEmailTooltip ? email || t('users.table.noEmail') : '',
113
+ children: /*#__PURE__*/_jsx("span", {
114
+ style: {
115
+ color: '#999999',
116
+ fontSize: '10px',
117
+ textWrap: 'nowrap',
118
+ overflow: 'hidden',
119
+ textOverflow: 'ellipsis'
120
+ },
121
+ ref: emailColumnRef,
122
+ children: email || t('users.table.noEmail')
123
+ })
124
+ })]
125
+ })]
126
+ })
127
+ });
128
+ };
129
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["useRef","AvatarUser","Tooltip","useTranslation","DeletedUserIcon","DisabledUserIcon","SCUIWrapper","SCUIWrapperLabel","useResizeListener","UserIconLock","jsx","_jsx","jsxs","_jsxs","UserRow","_ref","firstName","lastName","picture","position","email","isDeleted","hidden","isBlocked","_useTranslation","t","positionColumnRef","userNameColumnRef","emailColumnRef","_useResizeListener","showTooltip","_useResizeListener2","showPositionTooltip","_useResizeListener3","showEmailTooltip","withBorder","children","style","display","gap","borderRadius","backgroundColor","height","width","justifyContent","alignItems","title","left","padding","fontSize","concat","borderRight","paddingRight","color","textWrap","textTransform","textOverflow","maxWidth","overflow","ref"],"sources":["../../../src/components/UserRow/UserRow.tsx"],"sourcesContent":["/* eslint-disable no-nested-ternary */\n/* eslint-disable no-undef */\n/* eslint-disable react/require-default-props */\nimport { useRef } from 'react'\nimport { AvatarUser } from '@projectcor/cor-commons/lib/components/avatar-user'\nimport { Tooltip } from '@projectcor/tooltipv2/lib/components/Tooltip'\nimport { useTranslation } from 'react-i18next'\nimport { DeletedUserIcon } from '../DeletedUserIcon/DeletedUserIcon'\nimport { DisabledUserIcon } from '../DisabledUserIcon/DisabledUserIcon'\nimport { SCUIWrapper, SCUIWrapperLabel } from './UserRow.styles'\nimport { useResizeListener } from '../../hooks/useResize'\nimport { UserIconLock } from '../Icons'\n\nexport const UserRow = ({\n  firstName,\n  lastName,\n  picture,\n  position,\n  email,\n  isDeleted,\n  hidden,\n  isBlocked,\n}: {\n  firstName: string\n  lastName: string\n  picture: string\n  position?: string\n  email?: string\n  isDeleted: boolean\n  hidden: boolean\n  isBlocked: boolean\n}) => {\n  const { t } = useTranslation('people')\n  const positionColumnRef = useRef<HTMLDivElement>(null)\n  const userNameColumnRef = useRef<HTMLDivElement>(null)\n  const emailColumnRef = useRef<HTMLDivElement>(null)\n  const { showTooltip } = useResizeListener(userNameColumnRef, [firstName, lastName])\n  const { showTooltip: showPositionTooltip } = useResizeListener(positionColumnRef, [position])\n  const { showTooltip: showEmailTooltip } = useResizeListener(emailColumnRef, [email])\n  return (\n    <SCUIWrapper withBorder isBlocked={isBlocked}>\n      <div style={{ display: 'flex', gap: '8px' }}>\n        <div\n          style={{\n            borderRadius: '50%',\n            backgroundColor: 'lightblue',\n            height: '32px',\n            width: '32px',\n            display: 'flex',\n            justifyContent: 'center',\n            alignItems: 'center',\n            position: 'relative',\n          }}\n        >\n          <AvatarUser firstName={firstName} lastName={lastName} picture={picture} />\n          {isBlocked ? (\n            <Tooltip title={t('users.table.bloquedUserTooltip')}>\n              <div\n                style={{\n                  position: 'absolute',\n                  left: '2px',\n                  backgroundColor: 'white',\n                  borderRadius: '50%',\n                  padding: '2px',\n                  display: 'flex',\n                  justifyContent: 'center',\n                  alignItems: 'center',\n                }}\n              >\n                <UserIconLock />\n              </div>\n            </Tooltip>\n          ) : isDeleted ? (\n            <DeletedUserIcon />\n          ) : (\n            hidden && <DisabledUserIcon />\n          )}\n        </div>\n        <SCUIWrapperLabel>\n          <div style={{ display: 'flex', gap: 8, fontSize: '12px' }}>\n            <Tooltip title={showTooltip ? `${firstName} ${lastName}` : ''}>\n              <span\n                style={{\n                  borderRight: '1px solid #E0E0E0',\n                  paddingRight: '8px',\n                  color: '#20201F',\n                  textWrap: 'nowrap',\n                  textTransform: 'capitalize',\n                  textOverflow: 'ellipsis',\n                  maxWidth: 'fit-content',\n                  overflow: 'hidden',\n                }}\n                ref={userNameColumnRef}\n              >\n                {`${firstName} ${lastName}`}\n              </span>\n            </Tooltip>\n            <Tooltip title={showPositionTooltip ? position : ''}>\n              <span\n                style={{\n                  color: '#666666',\n                  textWrap: 'nowrap',\n                  textTransform: 'capitalize',\n                  maxWidth: 'fit-content',\n                  overflow: 'hidden',\n                  textOverflow: 'ellipsis',\n                }}\n                ref={positionColumnRef}\n              >\n                {!position || position === 'no_position' ? t('users.table.noPosition') : position}\n              </span>\n            </Tooltip>\n          </div>\n          <Tooltip title={showEmailTooltip ? email || t('users.table.noEmail') : ''}>\n            <span\n              style={{\n                color: '#999999',\n                fontSize: '10px',\n                textWrap: 'nowrap',\n                overflow: 'hidden',\n                textOverflow: 'ellipsis',\n              }}\n              ref={emailColumnRef}\n            >\n              {email || t('users.table.noEmail')}\n            </span>\n          </Tooltip>\n        </SCUIWrapperLabel>\n      </div>\n    </SCUIWrapper>\n  )\n}\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,17 @@
1
+ import { UserRow } from './UserRow';
2
+ import { jsx as _jsx } from "react/jsx-runtime";
3
+ export default {
4
+ title: 'Components/UserRow',
5
+ component: UserRow
6
+ };
7
+ export var Default = function Default() {
8
+ return /*#__PURE__*/_jsx(UserRow, {
9
+ firstName: "John",
10
+ lastName: "Doe",
11
+ picture: "https://via.placeholder.com/150",
12
+ isDeleted: false,
13
+ hidden: false,
14
+ isBlocked: false
15
+ });
16
+ };
17
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJVc2VyUm93IiwianN4IiwiX2pzeCIsInRpdGxlIiwiY29tcG9uZW50IiwiRGVmYXVsdCIsImZpcnN0TmFtZSIsImxhc3ROYW1lIiwicGljdHVyZSIsImlzRGVsZXRlZCIsImhpZGRlbiIsImlzQmxvY2tlZCJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL1VzZXJSb3cvVXNlclJvdy5zdG9yaWVzLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnRNZXRhIH0gZnJvbSAnQHN0b3J5Ym9vay9yZWFjdCdcbmltcG9ydCB7IFVzZXJSb3cgfSBmcm9tICcuL1VzZXJSb3cnXG5cbmV4cG9ydCBkZWZhdWx0IHtcbiAgdGl0bGU6ICdDb21wb25lbnRzL1VzZXJSb3cnLFxuICBjb21wb25lbnQ6IFVzZXJSb3csXG59IGFzIENvbXBvbmVudE1ldGE8dHlwZW9mIFVzZXJSb3c+XG5cbmV4cG9ydCBjb25zdCBEZWZhdWx0ID0gKCkgPT4gKFxuICA8VXNlclJvd1xuICAgIGZpcnN0TmFtZT1cIkpvaG5cIlxuICAgIGxhc3ROYW1lPVwiRG9lXCJcbiAgICBwaWN0dXJlPVwiaHR0cHM6Ly92aWEucGxhY2Vob2xkZXIuY29tLzE1MFwiXG4gICAgaXNEZWxldGVkPXtmYWxzZX1cbiAgICBoaWRkZW49e2ZhbHNlfVxuICAgIGlzQmxvY2tlZD17ZmFsc2V9XG4gIC8+XG4pXG4iXSwibWFwcGluZ3MiOiJBQUNBLFNBQVNBLE9BQU8sUUFBUSxXQUFXO0FBQUEsU0FBQUMsR0FBQSxJQUFBQyxJQUFBO0FBRW5DLGVBQWU7RUFDYkMsS0FBSyxFQUFFLG9CQUFvQjtFQUMzQkMsU0FBUyxFQUFFSjtBQUNiLENBQUM7QUFFRCxPQUFPLElBQU1LLE9BQU8sR0FBRyxTQUFWQSxPQUFPQSxDQUFBO0VBQUEsb0JBQ2xCSCxJQUFBLENBQUNGLE9BQU87SUFDTk0sU0FBUyxFQUFDLE1BQU07SUFDaEJDLFFBQVEsRUFBQyxLQUFLO0lBQ2RDLE9BQU8sRUFBQyxpQ0FBaUM7SUFDekNDLFNBQVMsRUFBRSxLQUFNO0lBQ2pCQyxNQUFNLEVBQUUsS0FBTTtJQUNkQyxTQUFTLEVBQUU7RUFBTSxDQUNsQixDQUFDO0FBQUEsQ0FDSCIsImlnbm9yZUxpc3QiOltdfQ==
@@ -0,0 +1,19 @@
1
+ import styled, { css } from 'styled-components';
2
+ export var SCUIWrapper = styled.div.withConfig({
3
+ displayName: "UserRowstyles__SCUIWrapper",
4
+ componentId: "sc-a3cw-0"
5
+ })(["", " & > *{cursor:default !important;}& [class*='SCAvatarFallback']{cursor:default !important;}max-width:", ";", ""], function (_ref) {
6
+ var isBlocked = _ref.isBlocked;
7
+ return isBlocked && css(["*{color:#999999 !important;}"]);
8
+ }, function (_ref2) {
9
+ var withBorder = _ref2.withBorder;
10
+ return withBorder ? '100%' : 'calc(100% - 40px)';
11
+ }, function (_ref3) {
12
+ var withBorder = _ref3.withBorder;
13
+ return withBorder && css(["padding:8px 24px 8px 8px;border:1px solid #e0e0e0;border-radius:34px;"]);
14
+ });
15
+ export var SCUIWrapperLabel = styled.div.withConfig({
16
+ displayName: "UserRowstyles__SCUIWrapperLabel",
17
+ componentId: "sc-a3cw-1"
18
+ })(["display:flex;flex-direction:column;gap:4px;max-width:calc(100% - 32px);"]);
19
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJzdHlsZWQiLCJjc3MiLCJTQ1VJV3JhcHBlciIsImRpdiIsIndpdGhDb25maWciLCJkaXNwbGF5TmFtZSIsImNvbXBvbmVudElkIiwiX3JlZiIsImlzQmxvY2tlZCIsIl9yZWYyIiwid2l0aEJvcmRlciIsIl9yZWYzIiwiU0NVSVdyYXBwZXJMYWJlbCJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL1VzZXJSb3cvVXNlclJvdy5zdHlsZXMudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQsIHsgY3NzIH0gZnJvbSAnc3R5bGVkLWNvbXBvbmVudHMnXG5cbmV4cG9ydCBjb25zdCBTQ1VJV3JhcHBlciA9IHN0eWxlZC5kaXY8eyB3aXRoQm9yZGVyPzogYm9vbGVhbjsgaXNCbG9ja2VkPzogYm9vbGVhbiB9PmBcbiAgJHsoeyBpc0Jsb2NrZWQgfSkgPT5cbiAgICBpc0Jsb2NrZWQgJiZcbiAgICBjc3NgXG4gICAgICAqIHtcbiAgICAgICAgY29sb3I6ICM5OTk5OTkgIWltcG9ydGFudDtcbiAgICAgIH1cbiAgICBgfVxuICAmID4gKiB7XG4gICAgY3Vyc29yOiBkZWZhdWx0ICFpbXBvcnRhbnQ7XG4gIH1cbiAgJiBbY2xhc3MqPSdTQ0F2YXRhckZhbGxiYWNrJ10ge1xuICAgIGN1cnNvcjogZGVmYXVsdCAhaW1wb3J0YW50O1xuICB9XG4gIG1heC13aWR0aDogJHsoeyB3aXRoQm9yZGVyIH0pID0+ICh3aXRoQm9yZGVyID8gJzEwMCUnIDogJ2NhbGMoMTAwJSAtIDQwcHgpJyl9O1xuICAkeyh7IHdpdGhCb3JkZXIgfSkgPT5cbiAgICB3aXRoQm9yZGVyICYmXG4gICAgY3NzYFxuICAgICAgcGFkZGluZzogOHB4IDI0cHggOHB4IDhweDtcbiAgICAgIGJvcmRlcjogMXB4IHNvbGlkICNlMGUwZTA7XG4gICAgICBib3JkZXItcmFkaXVzOiAzNHB4O1xuICAgIGB9XG5gXG5cbmV4cG9ydCBjb25zdCBTQ1VJV3JhcHBlckxhYmVsID0gc3R5bGVkLmRpdjx7IGlzQmxvY2tlZD86IGJvb2xlYW4gfT5gXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIGdhcDogNHB4O1xuICBtYXgtd2lkdGg6IGNhbGMoMTAwJSAtIDMycHgpO1xuYFxuIl0sIm1hcHBpbmdzIjoiQUFBQSxPQUFPQSxNQUFNLElBQUlDLEdBQUcsUUFBUSxtQkFBbUI7QUFFL0MsT0FBTyxJQUFNQyxXQUFXLEdBQUdGLE1BQU0sQ0FBQ0csR0FBRyxDQUFBQyxVQUFBO0VBQUFDLFdBQUE7RUFBQUMsV0FBQTtBQUFBLDJIQUNqQyxVQUFBQyxJQUFBO0VBQUEsSUFBR0MsU0FBUyxHQUFBRCxJQUFBLENBQVRDLFNBQVM7RUFBQSxPQUNaQSxTQUFTLElBQ1RQLEdBQUcsa0NBSUY7QUFBQSxHQU9VLFVBQUFRLEtBQUE7RUFBQSxJQUFHQyxVQUFVLEdBQUFELEtBQUEsQ0FBVkMsVUFBVTtFQUFBLE9BQVFBLFVBQVUsR0FBRyxNQUFNLEdBQUcsbUJBQW1CO0FBQUEsQ0FBQyxFQUMxRSxVQUFBQyxLQUFBO0VBQUEsSUFBR0QsVUFBVSxHQUFBQyxLQUFBLENBQVZELFVBQVU7RUFBQSxPQUNiQSxVQUFVLElBQ1ZULEdBQUcsMkVBSUY7QUFBQSxFQUNKO0FBRUQsT0FBTyxJQUFNVyxnQkFBZ0IsR0FBR1osTUFBTSxDQUFDRyxHQUFHLENBQUFDLFVBQUE7RUFBQUMsV0FBQTtFQUFBQyxXQUFBO0FBQUEsK0VBS3pDIiwiaWdub3JlTGlzdCI6W119
@@ -0,0 +1,4 @@
1
+ import { getApolloClient } from '@projectcor/cor-apollo-provider';
2
+ var MAIN_GQL = process.env.GRAPHQL_URL;
3
+ export default getApolloClient(MAIN_GQL);
4
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJnZXRBcG9sbG9DbGllbnQiLCJNQUlOX0dRTCIsInByb2Nlc3MiLCJlbnYiLCJHUkFQSFFMX1VSTCJdLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb25zdGFudHMvZ3FsQ2xpZW50LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGdldEFwb2xsb0NsaWVudCB9IGZyb20gJ0Bwcm9qZWN0Y29yL2Nvci1hcG9sbG8tcHJvdmlkZXInXG5cbmNvbnN0IE1BSU5fR1FMID0gcHJvY2Vzcy5lbnYuR1JBUEhRTF9VUkxcblxuZXhwb3J0IGRlZmF1bHQgZ2V0QXBvbGxvQ2xpZW50KE1BSU5fR1FMKVxuIl0sIm1hcHBpbmdzIjoiQUFBQSxTQUFTQSxlQUFlLFFBQVEsaUNBQWlDO0FBRWpFLElBQU1DLFFBQVEsR0FBR0MsT0FBTyxDQUFDQyxHQUFHLENBQUNDLFdBQVc7QUFFeEMsZUFBZUosZUFBZSxDQUFDQyxRQUFRLENBQUMiLCJpZ25vcmVMaXN0IjpbXX0=
@@ -0,0 +1,109 @@
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 @typescript-eslint/no-unused-vars */
6
+ /* eslint-disable no-unused-vars */
7
+ /* eslint-disable @typescript-eslint/no-explicit-any */
8
+ import { useCallback, memo, useState } from 'react';
9
+ import { RowComponent } from '../../components/Table/Row';
10
+ import { ModalBloquedUser } from '../../components/ModalBloquedUser';
11
+ import { useUsersEditPositions, useUsersQuery, useUsersView } from '../../context/UsersContext';
12
+ import { EmptyUserComponent } from '../../components/EmptyUser/EmptyUser';
13
+ import { useUnblockUser } from '../../hooks/useUnblockUser';
14
+ import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
15
+ var BodyContainerViewUsers = function BodyContainerViewUsers() {
16
+ var _useUsersQuery = useUsersQuery(),
17
+ users = _useUsersQuery.users;
18
+ var _useUsersEditPosition = useUsersEditPositions(),
19
+ hasEditPositions = _useUsersEditPosition.hasEditPositions,
20
+ handleSetUsersToEditPositions = _useUsersEditPosition.handleSetUsersToEditPositions;
21
+ var _useUnblockUser = useUnblockUser(),
22
+ handleUnblockUser = _useUnblockUser.handleUnblockUser;
23
+ var _useState = useState(false),
24
+ _useState2 = _slicedToArray(_useState, 2),
25
+ showModalBloquedUser = _useState2[0],
26
+ setShowModalBloquedUser = _useState2[1];
27
+ var _useState3 = useState(null),
28
+ _useState4 = _slicedToArray(_useState3, 2),
29
+ userBloqued = _useState4[0],
30
+ setUserBloqued = _useState4[1];
31
+ var handleSelectOption = useCallback(function (option, user, userIndexPositionToEdit) {
32
+ if (option.id === 1) {
33
+ setUserBloqued(_objectSpread(_objectSpread({}, user), {}, {
34
+ userIndexPositionToEdit: userIndexPositionToEdit
35
+ }));
36
+ setShowModalBloquedUser(true);
37
+ return;
38
+ }
39
+ if (option.id === 2) {
40
+ window.location.href = "/users/".concat(user.id, "/edit");
41
+ return;
42
+ }
43
+ if (option.id === 3) {
44
+ window.location.href = "/users/".concat(user.id, "/delete");
45
+ }
46
+ }, []);
47
+ var handleAction = function handleAction(action, userInfoToSend) {
48
+ if (action === 'cancel') {
49
+ setShowModalBloquedUser(false);
50
+ setUserBloqued(null);
51
+ return;
52
+ }
53
+ if (action === 'unlock') {
54
+ handleUnblockUser(userInfoToSend);
55
+ }
56
+ setShowModalBloquedUser(false);
57
+ };
58
+ return /*#__PURE__*/_jsxs(_Fragment, {
59
+ children: [showModalBloquedUser && /*#__PURE__*/_jsx(ModalBloquedUser, {
60
+ user: userBloqued,
61
+ handleAction: handleAction
62
+ }), /*#__PURE__*/_jsx("div", {
63
+ style: {
64
+ display: 'flex',
65
+ flexDirection: 'column',
66
+ border: '1px solid #e7e7e7',
67
+ borderRadius: '0 0 4px 4px'
68
+ },
69
+ children: users !== null && users !== void 0 && users.length ? users.map(function (user, index) {
70
+ return /*#__PURE__*/_jsx(RowComponent, {
71
+ id: user.id.toString(),
72
+ handleSelectOption: handleSelectOption,
73
+ user: user,
74
+ hasEditPositions: hasEditPositions,
75
+ handleSetUsersToEditPositions: handleSetUsersToEditPositions,
76
+ userIndexPositionToEdit: index
77
+ }, user.id);
78
+ }) : /*#__PURE__*/_jsx(EmptyUserComponent, {})
79
+ })]
80
+ });
81
+ };
82
+ var BodyContainerViewTeams = function BodyContainerViewTeams() {
83
+ return /*#__PURE__*/_jsx("div", {
84
+ children: "BodyContainerViewTeams"
85
+ });
86
+ };
87
+ var BodyContainerViewPositions = function BodyContainerViewPositions() {
88
+ return /*#__PURE__*/_jsx("div", {
89
+ children: "BodyContainerViewPositions"
90
+ });
91
+ };
92
+ var BodyContainerViewLeaves = function BodyContainerViewLeaves() {
93
+ return /*#__PURE__*/_jsx("div", {
94
+ children: "BodyContainerViewLeaves"
95
+ });
96
+ };
97
+ var BodyContainerByView = {
98
+ users: BodyContainerViewUsers,
99
+ teams: BodyContainerViewTeams,
100
+ positions: BodyContainerViewPositions,
101
+ leaves: BodyContainerViewLeaves
102
+ };
103
+ export var BodyContainer = /*#__PURE__*/memo(function () {
104
+ var _useUsersView = useUsersView(),
105
+ view = _useUsersView.view;
106
+ var BodyContainerView = BodyContainerByView[view];
107
+ return /*#__PURE__*/_jsx(BodyContainerView, {});
108
+ });
109
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["useCallback","memo","useState","RowComponent","ModalBloquedUser","useUsersEditPositions","useUsersQuery","useUsersView","EmptyUserComponent","useUnblockUser","jsx","_jsx","Fragment","_Fragment","jsxs","_jsxs","BodyContainerViewUsers","_useUsersQuery","users","_useUsersEditPosition","hasEditPositions","handleSetUsersToEditPositions","_useUnblockUser","handleUnblockUser","_useState","_useState2","_slicedToArray","showModalBloquedUser","setShowModalBloquedUser","_useState3","_useState4","userBloqued","setUserBloqued","handleSelectOption","option","user","userIndexPositionToEdit","id","_objectSpread","window","location","href","concat","handleAction","action","userInfoToSend","children","style","display","flexDirection","border","borderRadius","length","map","index","toString","BodyContainerViewTeams","BodyContainerViewPositions","BodyContainerViewLeaves","BodyContainerByView","teams","positions","leaves","BodyContainer","_useUsersView","view","BodyContainerView"],"sources":["../../../src/container/Body/BodyContainer.tsx"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-unused-vars */\n/* eslint-disable no-unused-vars */\n/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { useCallback, memo, useState } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { RowComponent } from '../../components/Table/Row'\nimport { ModalBloquedUser } from '../../components/ModalBloquedUser'\nimport { useUsersEditPositions, useUsersQuery, useUsersView } from '../../context/UsersContext'\nimport { EmptyUserComponent } from '../../components/EmptyUser/EmptyUser'\nimport { useUnblockUser } from '../../hooks/useUnblockUser'\n\nconst BodyContainerViewUsers = () => {\n  const { users } = useUsersQuery()\n  const { hasEditPositions, handleSetUsersToEditPositions } = useUsersEditPositions()\n  const { handleUnblockUser } = useUnblockUser()\n  const [showModalBloquedUser, setShowModalBloquedUser] = useState(false)\n  const [userBloqued, setUserBloqued] = useState<any>(null)\n  const handleSelectOption = useCallback(\n    (option: { id: number; label: string }, user: any, userIndexPositionToEdit: number) => {\n      if (option.id === 1) {\n        setUserBloqued({ ...user, userIndexPositionToEdit })\n        setShowModalBloquedUser(true)\n        return\n      }\n      if (option.id === 2) {\n        window.location.href = `/users/${user.id}/edit`\n        return\n      }\n      if (option.id === 3) {\n        window.location.href = `/users/${user.id}/delete`\n      }\n    },\n    []\n  )\n\n  const handleAction = (action: string, userInfoToSend: any) => {\n    if (action === 'cancel') {\n      setShowModalBloquedUser(false)\n      setUserBloqued(null)\n      return\n    }\n    if (action === 'unlock') {\n      handleUnblockUser(userInfoToSend)\n    }\n    setShowModalBloquedUser(false)\n  }\n\n  return (\n    <>\n      {showModalBloquedUser && <ModalBloquedUser user={userBloqued} handleAction={handleAction} />}\n      <div\n        style={{ display: 'flex', flexDirection: 'column', border: '1px solid #e7e7e7', borderRadius: '0 0 4px 4px' }}\n      >\n        {users?.length ? (\n          users.map((user, index) => (\n            <RowComponent\n              key={user.id}\n              id={user.id.toString()}\n              handleSelectOption={handleSelectOption}\n              user={user}\n              hasEditPositions={hasEditPositions}\n              handleSetUsersToEditPositions={handleSetUsersToEditPositions}\n              userIndexPositionToEdit={index}\n            />\n          ))\n        ) : (\n          <EmptyUserComponent />\n        )}\n      </div>\n    </>\n  )\n}\n\nconst BodyContainerViewTeams = () => {\n  return <div>BodyContainerViewTeams</div>\n}\n\nconst BodyContainerViewPositions = () => {\n  return <div>BodyContainerViewPositions</div>\n}\n\nconst BodyContainerViewLeaves = () => {\n  return <div>BodyContainerViewLeaves</div>\n}\n\nconst BodyContainerByView = {\n  users: BodyContainerViewUsers,\n  teams: BodyContainerViewTeams,\n  positions: BodyContainerViewPositions,\n  leaves: BodyContainerViewLeaves,\n}\n\nexport const BodyContainer = memo(() => {\n  const { view } = useUsersView()\n  const BodyContainerView = BodyContainerByView[view]\n  return <BodyContainerView />\n})\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,168 @@
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 @typescript-eslint/indent */
6
+ /* eslint-disable no-nested-ternary */
7
+ /* eslint-disable @typescript-eslint/no-empty-function */
8
+ /* eslint-disable react/require-default-props */
9
+ /* eslint-disable no-undef */
10
+ import { memo, useEffect, useState, useRef } from 'react';
11
+ import { useTranslation } from 'react-i18next';
12
+ import { useUsersQuery } from '../../context/UsersContext';
13
+ import { FilterChip } from '../../components/Filters/FilterChip';
14
+ import { useGetTeams } from '../../hooks/useGetTeams';
15
+ import { SEARCH_EVENT } from '../../hooks/useSearchEvent';
16
+ import { Search } from '../../components/Search/Search';
17
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
18
+ export var FiltersContainer = /*#__PURE__*/memo(function (_ref) {
19
+ var handleGetUserPositionFilterProp = _ref.handleGetUserPositionFilter;
20
+ var _useTranslation = useTranslation('people'),
21
+ t = _useTranslation.t;
22
+ var _useUsersQuery = useUsersQuery(),
23
+ handleGetUsers = _useUsersQuery.handleGetUsers,
24
+ positions = _useUsersQuery.positions;
25
+ var _useGetTeams = useGetTeams(),
26
+ handleGetTeams = _useGetTeams.handleGetTeams,
27
+ loading = _useGetTeams.loading,
28
+ error = _useGetTeams.error,
29
+ data = _useGetTeams.data;
30
+ var handleGetUserPositionFilter = handleGetUserPositionFilterProp !== null && handleGetUserPositionFilterProp !== void 0 ? handleGetUserPositionFilterProp : function () {};
31
+ var _useState = useState(''),
32
+ _useState2 = _slicedToArray(_useState, 2),
33
+ searchTermValue = _useState2[0],
34
+ setSearchTermValue = _useState2[1];
35
+ var _useState3 = useState([]),
36
+ _useState4 = _slicedToArray(_useState3, 2),
37
+ teamOptions = _useState4[0],
38
+ setTeamOptions = _useState4[1];
39
+ var _useState5 = useState(positions || []),
40
+ _useState6 = _slicedToArray(_useState5, 2),
41
+ positionOptions = _useState6[0],
42
+ setPositionOptions = _useState6[1];
43
+ var defaultPositionsRef = useRef(positions || []);
44
+ var _useState7 = useState([]),
45
+ _useState8 = _slicedToArray(_useState7, 2),
46
+ selectedTeams = _useState8[0],
47
+ setSelectedTeams = _useState8[1];
48
+ var _useState9 = useState([]),
49
+ _useState10 = _slicedToArray(_useState9, 2),
50
+ selectedPositions = _useState10[0],
51
+ setSelectedPositions = _useState10[1];
52
+ var buildAndSendUserRequest = function buildAndSendUserRequest() {
53
+ var _ref2 = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {},
54
+ searchInputOverride = _ref2.searchInputOverride,
55
+ teamsOverride = _ref2.teamsOverride,
56
+ positionsOverride = _ref2.positionsOverride;
57
+ var positionsFilter = positionsOverride !== undefined ? positionsOverride.length ? {
58
+ positions: positionsOverride
59
+ } : {} : selectedPositions.length ? {
60
+ positions: selectedPositions
61
+ } : {};
62
+ var teamsFilter = teamsOverride !== undefined ? teamsOverride.length ? {
63
+ teams: teamsOverride
64
+ } : {} : selectedTeams.length ? {
65
+ teams: selectedTeams
66
+ } : {};
67
+ var valuesToFilter = _objectSpread(_objectSpread({}, positionsFilter), teamsFilter);
68
+ handleGetUsers({
69
+ searchInput: searchInputOverride !== undefined ? searchInputOverride : searchTermValue,
70
+ page: 1,
71
+ valuesToFilter: valuesToFilter
72
+ });
73
+ };
74
+ useEffect(function () {
75
+ var handleSearch = function handleSearch(event) {
76
+ var _event$detail = event.detail,
77
+ searchTerm = _event$detail.searchTerm,
78
+ type = _event$detail.type,
79
+ valuesToFilter = _event$detail.valuesToFilter;
80
+ if (type === 'filter1') {
81
+ setSearchTermValue(searchTerm);
82
+ buildAndSendUserRequest({
83
+ searchInputOverride: searchTerm
84
+ });
85
+ return;
86
+ }
87
+ if (type === 'teamFilter') {
88
+ if (Array.isArray(valuesToFilter)) {
89
+ if (valuesToFilter.length) {
90
+ var areTeamsEqual = valuesToFilter.every(function (value, index) {
91
+ return value === selectedTeams[index];
92
+ });
93
+ if (areTeamsEqual) return;
94
+ setSelectedTeams(valuesToFilter);
95
+ buildAndSendUserRequest({
96
+ teamsOverride: valuesToFilter
97
+ });
98
+ } else {
99
+ setSelectedTeams([]);
100
+ buildAndSendUserRequest({
101
+ teamsOverride: []
102
+ });
103
+ }
104
+ } else {
105
+ handleGetTeams(1, searchTerm);
106
+ }
107
+ }
108
+ if (type === 'positionFilter') {
109
+ if (Array.isArray(valuesToFilter)) {
110
+ if (!valuesToFilter.length) {
111
+ setSelectedPositions([]);
112
+ buildAndSendUserRequest({
113
+ positionsOverride: []
114
+ });
115
+ } else {
116
+ var arePositionsEqual = valuesToFilter.every(function (value, index) {
117
+ return value === selectedPositions[index];
118
+ });
119
+ if (arePositionsEqual) return;
120
+ setSelectedPositions(valuesToFilter);
121
+ buildAndSendUserRequest({
122
+ positionsOverride: valuesToFilter
123
+ });
124
+ }
125
+ } else if (searchTerm) {
126
+ handleGetUserPositionFilter(searchTerm);
127
+ }
128
+ }
129
+ };
130
+ window.addEventListener(SEARCH_EVENT, handleSearch);
131
+ return function () {
132
+ window.removeEventListener(SEARCH_EVENT, handleSearch);
133
+ };
134
+ }, [handleGetTeams, handleGetUserPositionFilter, handleGetUsers, searchTermValue]);
135
+ useEffect(function () {
136
+ if (data !== null && data !== void 0 && data.teams && !loading && !error) {
137
+ setTeamOptions(data.teams.data.map(function (team) {
138
+ return {
139
+ id: team.id,
140
+ label: team.name
141
+ };
142
+ }));
143
+ }
144
+ }, [data, loading, error]);
145
+ useEffect(function () {
146
+ if (positions !== null && positions !== void 0 && positions.length) {
147
+ setPositionOptions(positions);
148
+ defaultPositionsRef.current = positions;
149
+ }
150
+ }, [positions]);
151
+ return /*#__PURE__*/_jsxs("div", {
152
+ style: {
153
+ display: 'flex',
154
+ gap: '10px',
155
+ alignItems: 'center'
156
+ },
157
+ children: [/*#__PURE__*/_jsx(Search, {}), /*#__PURE__*/_jsx(FilterChip, {
158
+ id: "teamFilter",
159
+ label: t('filters.team'),
160
+ options: teamOptions
161
+ }), /*#__PURE__*/_jsx(FilterChip, {
162
+ id: "positionFilter",
163
+ label: t('filters.position'),
164
+ options: positionOptions
165
+ })]
166
+ });
167
+ });
168
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["memo","useEffect","useState","useRef","useTranslation","useUsersQuery","FilterChip","useGetTeams","SEARCH_EVENT","Search","jsx","_jsx","jsxs","_jsxs","FiltersContainer","_ref","handleGetUserPositionFilterProp","handleGetUserPositionFilter","_useTranslation","t","_useUsersQuery","handleGetUsers","positions","_useGetTeams","handleGetTeams","loading","error","data","_useState","_useState2","_slicedToArray","searchTermValue","setSearchTermValue","_useState3","_useState4","teamOptions","setTeamOptions","_useState5","_useState6","positionOptions","setPositionOptions","defaultPositionsRef","_useState7","_useState8","selectedTeams","setSelectedTeams","_useState9","_useState10","selectedPositions","setSelectedPositions","buildAndSendUserRequest","_ref2","arguments","length","undefined","searchInputOverride","teamsOverride","positionsOverride","positionsFilter","teamsFilter","teams","valuesToFilter","_objectSpread","searchInput","page","handleSearch","event","_event$detail","detail","searchTerm","type","Array","isArray","areTeamsEqual","every","value","index","arePositionsEqual","window","addEventListener","removeEventListener","map","team","id","label","name","current","style","display","gap","alignItems","children","options"],"sources":["../../../src/container/Filters/FiltersContainer.tsx"],"sourcesContent":["/* eslint-disable @typescript-eslint/indent */\n/* eslint-disable no-nested-ternary */\n/* eslint-disable @typescript-eslint/no-empty-function */\n/* eslint-disable react/require-default-props */\n/* eslint-disable no-undef */\nimport { memo, useEffect, useState, useRef } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { useUsersQuery } from '../../context/UsersContext'\nimport { FilterChip } from '../../components/Filters/FilterChip'\nimport { useGetTeams } from '../../hooks/useGetTeams'\nimport { SEARCH_EVENT } from '../../hooks/useSearchEvent'\nimport { Search } from '../../components/Search/Search'\n\ntype FiltersContainerProps = {\n  handleGetUserPositionFilter?: (name: string, page?: number) => void\n}\n\nexport const FiltersContainer = memo(\n  ({ handleGetUserPositionFilter: handleGetUserPositionFilterProp }: FiltersContainerProps) => {\n    const { t } = useTranslation('people')\n    const { handleGetUsers, positions } = useUsersQuery()\n    const { handleGetTeams, loading, error, data } = useGetTeams()\n    const handleGetUserPositionFilter = handleGetUserPositionFilterProp ?? (() => {})\n\n    const [searchTermValue, setSearchTermValue] = useState('')\n    const [teamOptions, setTeamOptions] = useState<{ id: number; label: string }[]>([])\n    const [positionOptions, setPositionOptions] = useState<{ id: number; label: string }[]>(positions || [])\n    const defaultPositionsRef = useRef<{ id: number; label: string; categoryName?: string }[]>(positions || [])\n\n    const [selectedTeams, setSelectedTeams] = useState<number[]>([])\n    const [selectedPositions, setSelectedPositions] = useState<number[]>([])\n\n    const buildAndSendUserRequest = ({\n      searchInputOverride,\n      teamsOverride,\n      positionsOverride,\n    }: {\n      searchInputOverride?: string\n      teamsOverride?: number[]\n      positionsOverride?: number[]\n    } = {}) => {\n      const positionsFilter =\n        positionsOverride !== undefined\n          ? positionsOverride.length\n            ? { positions: positionsOverride }\n            : {}\n          : selectedPositions.length\n          ? { positions: selectedPositions }\n          : {}\n      const teamsFilter =\n        teamsOverride !== undefined\n          ? teamsOverride.length\n            ? { teams: teamsOverride }\n            : {}\n          : selectedTeams.length\n          ? { teams: selectedTeams }\n          : {}\n      const valuesToFilter = { ...positionsFilter, ...teamsFilter }\n\n      handleGetUsers({\n        searchInput: searchInputOverride !== undefined ? searchInputOverride : searchTermValue,\n        page: 1,\n        valuesToFilter: valuesToFilter as any,\n      })\n    }\n\n    useEffect(() => {\n      const handleSearch = (event: CustomEvent) => {\n        const { searchTerm, type, valuesToFilter } = event.detail\n        if (type === 'filter1') {\n          setSearchTermValue(searchTerm)\n          buildAndSendUserRequest({ searchInputOverride: searchTerm })\n          return\n        }\n\n        if (type === 'teamFilter') {\n          if (Array.isArray(valuesToFilter)) {\n            if (valuesToFilter.length) {\n              const areTeamsEqual = valuesToFilter.every((value, index) => value === selectedTeams[index])\n              if (areTeamsEqual) return\n              setSelectedTeams(valuesToFilter)\n              buildAndSendUserRequest({\n                teamsOverride: valuesToFilter,\n              })\n            } else {\n              setSelectedTeams([])\n              buildAndSendUserRequest({ teamsOverride: [] })\n            }\n          } else {\n            handleGetTeams(1, searchTerm)\n          }\n        }\n\n        if (type === 'positionFilter') {\n          if (Array.isArray(valuesToFilter)) {\n            if (!valuesToFilter.length) {\n              setSelectedPositions([])\n              buildAndSendUserRequest({ positionsOverride: [] })\n            } else {\n              const arePositionsEqual = valuesToFilter.every((value, index) => value === selectedPositions[index])\n              if (arePositionsEqual) return\n              setSelectedPositions(valuesToFilter)\n              buildAndSendUserRequest({\n                positionsOverride: valuesToFilter,\n              })\n            }\n          } else if (searchTerm) {\n            handleGetUserPositionFilter(searchTerm)\n          }\n        }\n      }\n\n      window.addEventListener(SEARCH_EVENT, handleSearch as unknown as EventListener)\n      return () => {\n        window.removeEventListener(SEARCH_EVENT, handleSearch as unknown as EventListener)\n      }\n    }, [handleGetTeams, handleGetUserPositionFilter, handleGetUsers, searchTermValue])\n\n    useEffect(() => {\n      if (data?.teams && !loading && !error) {\n        setTeamOptions(data.teams.data.map(team => ({ id: team.id, label: team.name })))\n      }\n    }, [data, loading, error])\n\n    useEffect(() => {\n      if (positions?.length) {\n        setPositionOptions(positions)\n        defaultPositionsRef.current = positions\n      }\n    }, [positions])\n\n    return (\n      <div\n        style={{\n          display: 'flex',\n          gap: '10px',\n          alignItems: 'center',\n        }}\n      >\n        <Search />\n        <FilterChip id=\"teamFilter\" label={t('filters.team')} options={teamOptions} />\n        <FilterChip id=\"positionFilter\" label={t('filters.position')} options={positionOptions} />\n      </div>\n    )\n  }\n)\n"],"mappings":"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","ignoreList":[]}