@projectcor/people-microfront 1.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/App.js +64 -0
- package/lib/App.stories.js +104 -0
- package/lib/Providers.js +26 -0
- package/lib/components/Backdrop/Background.interface.js +2 -0
- package/lib/components/Backdrop/Background.js +12 -0
- package/lib/components/Backdrop/Background.style.js +9 -0
- package/lib/components/Backdrop/index.js +2 -0
- package/lib/components/DeletedUserIcon/DeletedUserIcon.js +20 -0
- package/lib/components/DeletedUserIcon/DeletedUserIcon.styles.js +7 -0
- package/lib/components/DeletedUserIcon/index.js +2 -0
- package/lib/components/DisabledUserIcon/DisabledUserIcon.js +24 -0
- package/lib/components/DisabledUserIcon/DisabledUserIcon.styles.js +7 -0
- package/lib/components/DisabledUserIcon/index.js +2 -0
- package/lib/components/EmptyUser/EmptyUser.js +59 -0
- package/lib/components/EmptyUser/index.js +3 -0
- package/lib/components/ErrorComponent/ErrorComponent.js +24 -0
- package/lib/components/ErrorComponent/ErrorComponent.spec.js +29 -0
- package/lib/components/ErrorComponent/ErrorComponent.styles.js +19 -0
- package/lib/components/ErrorComponent/index.js +2 -0
- package/lib/components/Filters/FilterChip/FilterChip.js +106 -0
- package/lib/components/Filters/FilterChip/index.js +2 -0
- package/lib/components/Filters/LabelFilter/LabelFilter.js +87 -0
- package/lib/components/Filters/LabelFilter/LabelFilter.styles.js +32 -0
- package/lib/components/Filters/SearchComponent/SearchComponent.js +26 -0
- package/lib/components/Filters/SearchComponent/SearchComponent.styles.js +16 -0
- package/lib/components/Filters/SearchComponent/index.js +2 -0
- package/lib/components/Filters/index.js +2 -0
- package/lib/components/Icons/UserBlockIcon.js +25 -0
- package/lib/components/Icons/UserIconLock.js +42 -0
- package/lib/components/Icons/UserIconWithCross.js +20 -0
- package/lib/components/Icons/index.js +4 -0
- package/lib/components/Illustration/EmptyUser.js +141 -0
- package/lib/components/Illustration/index.js +2 -0
- package/lib/components/Loading/LoadingComponent.js +11 -0
- package/lib/components/Loading/LoadingComponent.style.js +6 -0
- package/lib/components/Loading/index.js +2 -0
- package/lib/components/MenuOptions/MenuOptions.js +147 -0
- package/lib/components/MenuOptions/MenuOptions.styles.js +14 -0
- package/lib/components/MenuOptions/index.js +2 -0
- package/lib/components/Modal/ModalLayout.interface.js +2 -0
- package/lib/components/Modal/ModalLayout.js +25 -0
- package/lib/components/Modal/ModalLayout.style.js +26 -0
- package/lib/components/Modal/index.js +2 -0
- package/lib/components/ModalBloquedUser/ModalBloquedUser.js +67 -0
- package/lib/components/ModalBloquedUser/index.js +2 -0
- package/lib/components/ModalEditUserPosition/ModalEditUserPosition.js +171 -0
- package/lib/components/ModalEditUserPosition/UserEditPositionRow.js +327 -0
- package/lib/components/ModalEditUserPosition/UserEditPositionRow.styles.js +6 -0
- package/lib/components/ModalEditUserPosition/index.js +2 -0
- package/lib/components/ModalOptionsWithSearch/ConfirmButton.js +16 -0
- package/lib/components/ModalOptionsWithSearch/ModalOptionsWithSearch.js +76 -0
- package/lib/components/ModalOptionsWithSearch/ModalOptionsWithSearch.styles.js +21 -0
- package/lib/components/ModalOptionsWithSearch/SearchInput.js +14 -0
- package/lib/components/Search/InputSearch.js +22 -0
- package/lib/components/Search/Search.js +34 -0
- package/lib/components/Search/Search.styles.js +15 -0
- package/lib/components/Search/index.js +2 -0
- package/lib/components/Snackbar/Snackbar.interface.js +2 -0
- package/lib/components/Snackbar/Snackbar.js +35 -0
- package/lib/components/Snackbar/Snackbar.styles.js +18 -0
- package/lib/components/Snackbar/index.js +2 -0
- package/lib/components/Table/Content/ContentTable.js +7 -0
- package/lib/components/Table/Content/index.js +2 -0
- package/lib/components/Table/Header/HeaderTable.js +212 -0
- package/lib/components/Table/Header/index.js +2 -0
- package/lib/components/Table/Row/Row.js +66 -0
- package/lib/components/Table/Row/Row.styles.js +27 -0
- package/lib/components/Table/Row/index.js +2 -0
- package/lib/components/UserRow/UserRow.js +129 -0
- package/lib/components/UserRow/UserRow.stories.js +17 -0
- package/lib/components/UserRow/UserRow.styles.js +19 -0
- package/lib/constants/gqlClient.js +4 -0
- package/lib/container/Body/BodyContainer.js +109 -0
- package/lib/container/Filters/FiltersContainer.js +168 -0
- package/lib/container/MainView/MainUsersView.js +184 -0
- package/lib/container/MainView/MainView.js +117 -0
- package/lib/container/Pagination/PaginationContainer.js +145 -0
- package/lib/container/RouterComponent/RouterComponent.js +130 -0
- package/lib/container/RouterComponent/RouterComponent.stories.js +14 -0
- package/lib/container/RouterComponent/index.js +2 -0
- package/lib/container/TableContainer/TableContainer.js +41 -0
- package/lib/container/index.js +2 -0
- package/lib/context/UsersContext.js +145 -0
- package/lib/hooks/useAbortController.js +17 -0
- package/lib/hooks/useDebounce.js +18 -0
- package/lib/hooks/useGetTeams.js +30 -0
- package/lib/hooks/useGetUserPositionFilter.js +29 -0
- package/lib/hooks/useGetUsers.js +100 -0
- package/lib/hooks/useGetUsersForFilter.js +52 -0
- package/lib/hooks/useGraphAdapter.js +60 -0
- package/lib/hooks/useResize.js +29 -0
- package/lib/hooks/useSearchEvent.js +18 -0
- package/lib/hooks/useUnblockUser.js +131 -0
- package/lib/hooks/useUpdateUserPositions.js +58 -0
- package/lib/hooks/useUserPositionCategories.js +38 -0
- package/lib/index.css +28 -0
- package/lib/index.js +10 -0
- package/lib/lang/i18next.js +19 -0
- package/lib/lang/i18nextForWeb.js +22 -0
- package/lib/lang/resource.js +11 -0
- package/lib/lang/translation/br.json +69 -0
- package/lib/lang/translation/en.json +69 -0
- package/lib/lang/translation/es.json +69 -0
- package/lib/lang/translation/fr.json +69 -0
- package/lib/mocks/mockedUser.js +95 -0
- package/lib/query/getTeams.js +5 -0
- package/lib/query/getUserPositionCategory.js +5 -0
- package/lib/query/getUserPositionFilter.js +5 -0
- package/lib/query/getUsers.js +5 -0
- package/lib/query/updateUserPosition.js +5 -0
- package/lib/query/userUnblock.js +5 -0
- package/lib/types/global.d.js +2 -0
- package/lib/types/userType.d.js +2 -0
- package/lib/utils/ApolloMicroServiceClient.js +3 -0
- package/package.json +174 -0
- package/readme.md +87 -0
|
@@ -0,0 +1,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":[]}
|