@projectcor/people-microfront 1.0.2-2 → 1.0.2-21
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 +1 -43
- package/lib/App.stories.js +25 -2
- package/lib/components/DeleteTeamModal/DeleteTeamModal.js +36 -24
- package/lib/components/DeleteTeamModal/DeleteTeamModal.styles.js +18 -6
- package/lib/components/DeleteTeamModal/DeleteTeamModal.types.js +1 -1
- package/lib/components/DeletedUserIcon/DeletedUserIcon.styles.js +2 -2
- package/lib/components/DisabledUserIcon/DisabledUserIcon.styles.js +2 -2
- package/lib/components/EmptyStateTeams/EmptyStateTeams.js +2 -2
- package/lib/components/EmptyUser/EmptyUser.js +7 -48
- package/lib/components/EmptyUser/EmptyUser.styles.js +18 -0
- package/lib/components/Filters/FilterChip/FilterChip.js +12 -9
- package/lib/components/Filters/FilterChip/FilterChip.styles.js +6 -0
- package/lib/components/HeaderTeams/HeaderTeams.js +2 -2
- package/lib/components/Illustration/EmptyFilter.js +67 -0
- package/lib/components/Layout/Layout.js +23 -2
- package/lib/components/Layout/Layout.styles.js +16 -1
- package/lib/components/Layout/index.js +2 -3
- package/lib/components/MenuOptions/MenuOptions.js +4 -18
- package/lib/components/ModalBloquedUser/ModalBloquedUser.js +5 -28
- package/lib/components/ModalBloquedUser/ModalBloquedUser.styles.js +14 -0
- package/lib/components/ModalEditUserPosition/ModalEditUserPosition.js +17 -52
- package/lib/components/ModalEditUserPosition/ModalEditUserPosition.styles.js +36 -0
- package/lib/components/ModalEditUserPosition/UserEditPositionRow.js +28 -105
- package/lib/components/ModalEditUserPosition/UserEditPositionRow.styles.js +55 -1
- package/lib/components/ModalOptionsWithSearch/ModalOptionsWithSearch.js +11 -4
- package/lib/components/ModalOptionsWithSearch/ModalOptionsWithSearch.styles.js +5 -1
- package/lib/components/Pagination/Pagination.styles.js +5 -1
- package/lib/components/Pagination/PaginationView.js +80 -0
- package/lib/components/Search/Search.js +4 -4
- package/lib/components/Table/Header/HeaderTable.js +5 -21
- package/lib/components/Table/Header/HeaderTable.styles.js +14 -0
- package/lib/components/Table/Row/Row.js +61 -21
- package/lib/components/Table/Row/Row.styles.js +33 -9
- package/lib/components/Table/TeamRow/AddMemberModal/AddMemberModal.js +65 -0
- package/lib/components/Table/TeamRow/AddMemberModal/AddMemberModal.styles.js +38 -0
- package/lib/components/Table/TeamRow/AddMemberModal/index.js +2 -0
- package/lib/components/Table/TeamRow/AddUsers/AddUsers.js +185 -0
- package/lib/components/Table/TeamRow/AddUsers/AddUsers.styles.js +25 -0
- package/lib/components/Table/TeamRow/AddUsers/index.js +2 -0
- package/lib/components/Table/TeamRow/RemoveMemberModal/RemoveMemberModal.js +65 -0
- package/lib/components/Table/TeamRow/RemoveMemberModal/RemoveMemberModal.styles.js +38 -0
- package/lib/components/Table/TeamRow/RemoveMemberModal/index.js +2 -0
- package/lib/components/Table/TeamRow/TeamRow.js +76 -63
- package/lib/components/Table/TeamRow/TeamRow.styles.js +6 -0
- package/lib/components/Table/TeamRow/UsersRow/UsersRow.js +191 -0
- package/lib/components/Table/TeamRow/UsersRow/UsersRow.styles.js +40 -0
- package/lib/components/Table/TeamRow/UsersRow/index.js +2 -0
- package/lib/components/TeamDetailsModal/MembersSelect.js +104 -31
- package/lib/components/TeamDetailsModal/TeamDetailsModal.js +73 -77
- package/lib/components/TeamDetailsModal/TeamDetailsModal.styles.js +19 -11
- package/lib/components/TeamDetailsModal/TeamDetailsModal.types.js +1 -1
- package/lib/components/TeamDetailsModal/index.js +1 -1
- package/lib/components/UserRow/UserRow.js +17 -66
- package/lib/components/UserRow/UserRow.styles.js +30 -2
- package/lib/container/Body/BodyContainer.js +3 -8
- package/lib/container/Body/BodyContainerViewTeams.js +72 -98
- package/lib/container/Filters/FiltersContainer.js +44 -16
- package/lib/container/MainView/MainTeamsView.js +36 -0
- package/lib/container/MainView/MainUsersView.js +51 -81
- package/lib/container/MainView/MainUsersView.styles.js +32 -0
- package/lib/container/MainView/MainView.js +21 -41
- package/lib/container/Pagination/PaginationContainer.js +10 -123
- package/lib/container/Pagination/PaginationTeamsContainer.js +32 -0
- package/lib/container/RouterComponent/RouterComponent.js +20 -31
- package/lib/container/RouterComponent/RouterComponent.stories.js +1 -3
- package/lib/container/RouterComponent/RouterComponent.styles.js +26 -0
- package/lib/container/TableContainer/TableContainer.js +17 -9
- package/lib/context/TeamsContext.js +5 -2
- package/lib/context/UsersContext.js +77 -22
- package/lib/hooks/useAbortController.js +15 -11
- package/lib/hooks/useAssignUserToTeam.js +78 -0
- package/lib/hooks/useCreateTeams.js +67 -0
- package/lib/hooks/useDeleteTeam.js +67 -0
- package/lib/hooks/useGetTeams.js +8 -4
- package/lib/hooks/useGetTotalPositions.js +24 -0
- package/lib/hooks/useGetTotalTeams.js +24 -0
- package/lib/hooks/useGetUsers.js +25 -8
- package/lib/hooks/useGetUsersForFilter.js +1 -2
- package/lib/hooks/useGraphAdapter.js +19 -8
- package/lib/hooks/useResize.js +9 -4
- package/lib/hooks/useUnassignUserFromTeam.js +67 -0
- package/lib/hooks/useUpdateTeam.js +65 -0
- package/lib/lang/i18nextForWeb.js +2 -2
- package/lib/lang/translation/br.json +21 -4
- package/lib/lang/translation/en.json +58 -41
- package/lib/lang/translation/es.json +21 -4
- package/lib/lang/translation/fr.json +86 -69
- package/lib/mocks/mockedUser.js +7 -1
- package/lib/query/assignUserToTeam.js +5 -0
- package/lib/query/createTeam.js +5 -0
- package/lib/query/deleteTeam.js +5 -0
- package/lib/query/getTeams.js +2 -2
- package/lib/query/getTotalPositions.js +5 -0
- package/lib/query/getTotalTeams.js +5 -0
- package/lib/query/getUsers.js +2 -2
- package/lib/query/unassignUserFromTeam.js +5 -0
- package/lib/query/updateTeam.js +5 -0
- package/lib/types/global.d.js +1 -1
- package/package.json +2 -2
|
@@ -1,29 +1,54 @@
|
|
|
1
|
-
import
|
|
2
|
-
import {
|
|
1
|
+
import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
|
|
2
|
+
import React, { useRef, useEffect, useState } from 'react';
|
|
3
3
|
import { Tooltip } from '@projectcor/tooltipv2/lib/components/Tooltip';
|
|
4
|
-
import {
|
|
4
|
+
import { MenuOptions } from '../../MenuOptions/MenuOptions';
|
|
5
|
+
import { SCRWrapper, SCRWrapperDynamicRow, SCRWrapperWorkspace, SCRWrapperName, SCRWrapperDescription } from '../Row/Row.styles';
|
|
6
|
+
import { SCTeamRowList } from './TeamRow.styles';
|
|
7
|
+
import { UsersRow } from './UsersRow';
|
|
8
|
+
|
|
9
|
+
/* eslint-disable react/require-default-props */
|
|
5
10
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
6
|
-
var MAX_USERS_DISPLAYED = 6;
|
|
7
|
-
var MAX_NAMES_IN_TOOLTIP = 5;
|
|
8
|
-
var formatRemainingUsersTooltip = function formatRemainingUsersTooltip(remainingUsers) {
|
|
9
|
-
if (remainingUsers.length === 0) return '';
|
|
10
|
-
var namesToShow = remainingUsers.slice(0, MAX_NAMES_IN_TOOLTIP);
|
|
11
|
-
var namesText = namesToShow.map(function (user) {
|
|
12
|
-
return "".concat(user.firstName, " ").concat(user.lastName);
|
|
13
|
-
}).join(' - ');
|
|
14
|
-
if (remainingUsers.length > MAX_NAMES_IN_TOOLTIP) {
|
|
15
|
-
var remainingCount = remainingUsers.length - MAX_NAMES_IN_TOOLTIP;
|
|
16
|
-
return "".concat(namesText, " +").concat(remainingCount);
|
|
17
|
-
}
|
|
18
|
-
return namesText;
|
|
19
|
-
};
|
|
20
11
|
var TeamRowItem = function TeamRowItem(_ref) {
|
|
21
12
|
var _team$workspace;
|
|
22
13
|
var team = _ref.team,
|
|
23
14
|
handleShowTeamDetails = _ref.handleShowTeamDetails,
|
|
24
|
-
handleDeleteTeam = _ref.handleDeleteTeam
|
|
25
|
-
|
|
26
|
-
|
|
15
|
+
handleDeleteTeam = _ref.handleDeleteTeam,
|
|
16
|
+
handleEditTeam = _ref.handleEditTeam,
|
|
17
|
+
handleRemoveUser = _ref.handleRemoveUser,
|
|
18
|
+
handleAddUser = _ref.handleAddUser;
|
|
19
|
+
var nameRef = useRef(null);
|
|
20
|
+
var _useState = useState(false),
|
|
21
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
22
|
+
isTruncated = _useState2[0],
|
|
23
|
+
setIsTruncated = _useState2[1];
|
|
24
|
+
useEffect(function () {
|
|
25
|
+
var checkTruncation = function checkTruncation() {
|
|
26
|
+
if (nameRef.current) {
|
|
27
|
+
var _nameRef$current = nameRef.current,
|
|
28
|
+
scrollWidth = _nameRef$current.scrollWidth,
|
|
29
|
+
clientWidth = _nameRef$current.clientWidth;
|
|
30
|
+
setIsTruncated(scrollWidth > clientWidth);
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
checkTruncation();
|
|
34
|
+
window.addEventListener('resize', checkTruncation);
|
|
35
|
+
return function () {
|
|
36
|
+
return window.removeEventListener('resize', checkTruncation);
|
|
37
|
+
};
|
|
38
|
+
}, [team.name]);
|
|
39
|
+
var handleMenuSelectOption = function handleMenuSelectOption(option) {
|
|
40
|
+
if (option.id === 2) {
|
|
41
|
+
// Editar
|
|
42
|
+
handleEditTeam(team.id);
|
|
43
|
+
} else if (option.id === 3) {
|
|
44
|
+
// Eliminar
|
|
45
|
+
handleDeleteTeam(team.id);
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
var nameElement = /*#__PURE__*/_jsx("span", {
|
|
49
|
+
ref: nameRef,
|
|
50
|
+
children: team.name
|
|
51
|
+
});
|
|
27
52
|
return /*#__PURE__*/_jsxs(SCRWrapper, {
|
|
28
53
|
height: "48px",
|
|
29
54
|
children: [/*#__PURE__*/_jsx(SCRWrapperName, {
|
|
@@ -31,32 +56,16 @@ var TeamRowItem = function TeamRowItem(_ref) {
|
|
|
31
56
|
onClick: function onClick() {
|
|
32
57
|
return handleShowTeamDetails(team.id);
|
|
33
58
|
},
|
|
34
|
-
children: /*#__PURE__*/_jsx(
|
|
35
|
-
|
|
59
|
+
children: isTruncated ? /*#__PURE__*/_jsx(Tooltip, {
|
|
60
|
+
title: team.name,
|
|
61
|
+
children: nameElement
|
|
62
|
+
}) : nameElement
|
|
63
|
+
}), /*#__PURE__*/_jsx(SCRWrapperDynamicRow, {
|
|
64
|
+
children: /*#__PURE__*/_jsx(UsersRow, {
|
|
65
|
+
team: team,
|
|
66
|
+
onRemoveUser: handleRemoveUser,
|
|
67
|
+
onAddUser: handleAddUser
|
|
36
68
|
})
|
|
37
|
-
}), /*#__PURE__*/_jsxs(SCRWrapperDynamicRow, {
|
|
38
|
-
onClick: function onClick() {
|
|
39
|
-
return handleShowTeamDetails(team.id);
|
|
40
|
-
},
|
|
41
|
-
children: [team.users.slice(0, MAX_USERS_DISPLAYED).map(function (user) {
|
|
42
|
-
return /*#__PURE__*/_jsx(Tooltip, {
|
|
43
|
-
title: "".concat(user.firstName, " ").concat(user.lastName),
|
|
44
|
-
placement: "top",
|
|
45
|
-
children: /*#__PURE__*/_jsx(SCRWIconUser, {
|
|
46
|
-
children: /*#__PURE__*/_jsx(AvatarUser, {
|
|
47
|
-
firstName: user.firstName,
|
|
48
|
-
lastName: user.lastName,
|
|
49
|
-
picture: user.picture
|
|
50
|
-
})
|
|
51
|
-
}, user.id)
|
|
52
|
-
});
|
|
53
|
-
}), team.users.length > MAX_USERS_DISPLAYED && /*#__PURE__*/_jsx(Tooltip, {
|
|
54
|
-
title: tooltipText,
|
|
55
|
-
placement: "top",
|
|
56
|
-
children: /*#__PURE__*/_jsxs(SCRRemainingUsers, {
|
|
57
|
-
children: ["+", team.users.length - MAX_USERS_DISPLAYED]
|
|
58
|
-
})
|
|
59
|
-
})]
|
|
60
69
|
}), !window.hasWorkspacesFeature && /*#__PURE__*/_jsx(SCRWrapperDescription, {
|
|
61
70
|
width: "274px",
|
|
62
71
|
onClick: function onClick() {
|
|
@@ -76,36 +85,40 @@ var TeamRowItem = function TeamRowItem(_ref) {
|
|
|
76
85
|
})
|
|
77
86
|
}), /*#__PURE__*/_jsx(SCRWrapperDynamicRow, {
|
|
78
87
|
width: "40px",
|
|
79
|
-
children: /*#__PURE__*/_jsx(
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
+
children: !window.hasWorkspacesFeature && /*#__PURE__*/_jsx(MenuOptions, {
|
|
89
|
+
id: "team-menu-".concat(team.id),
|
|
90
|
+
handleSelectOption: handleMenuSelectOption,
|
|
91
|
+
options: [{
|
|
92
|
+
id: 2,
|
|
93
|
+
label: 'Editar'
|
|
94
|
+
}, {
|
|
95
|
+
id: 3,
|
|
96
|
+
label: 'Eliminar'
|
|
97
|
+
}]
|
|
88
98
|
})
|
|
89
99
|
})]
|
|
90
100
|
});
|
|
91
101
|
};
|
|
102
|
+
|
|
103
|
+
/* eslint-disable react/require-default-props */
|
|
92
104
|
export var TeamRow = function TeamRow(_ref2) {
|
|
93
105
|
var teams = _ref2.teams,
|
|
94
106
|
handleShowTeamDetails = _ref2.handleShowTeamDetails,
|
|
95
|
-
handleDeleteTeam = _ref2.handleDeleteTeam
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
border: '1px solid #e7e7e7'
|
|
101
|
-
},
|
|
107
|
+
handleDeleteTeam = _ref2.handleDeleteTeam,
|
|
108
|
+
handleEditTeam = _ref2.handleEditTeam,
|
|
109
|
+
handleRemoveUser = _ref2.handleRemoveUser,
|
|
110
|
+
handleAddUser = _ref2.handleAddUser;
|
|
111
|
+
return /*#__PURE__*/_jsx(SCTeamRowList, {
|
|
102
112
|
children: teams.map(function (team) {
|
|
103
113
|
return /*#__PURE__*/_jsx(TeamRowItem, {
|
|
104
114
|
team: team,
|
|
105
115
|
handleShowTeamDetails: handleShowTeamDetails,
|
|
106
|
-
handleDeleteTeam: handleDeleteTeam
|
|
116
|
+
handleDeleteTeam: handleDeleteTeam,
|
|
117
|
+
handleEditTeam: handleEditTeam,
|
|
118
|
+
handleRemoveUser: handleRemoveUser,
|
|
119
|
+
handleAddUser: handleAddUser
|
|
107
120
|
}, team.id);
|
|
108
121
|
})
|
|
109
122
|
});
|
|
110
123
|
};
|
|
111
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["AvatarUser","Trash","Tooltip","SCRWrapper","SCRWrapperDynamicRow","SCRWIconUser","SCRWrapperWorkspace","SCRWrapperDeleteIcon","SCRWrapperName","SCRWrapperDescription","SCRRemainingUsers","jsx","_jsx","jsxs","_jsxs","MAX_USERS_DISPLAYED","MAX_NAMES_IN_TOOLTIP","formatRemainingUsersTooltip","remainingUsers","length","namesToShow","slice","namesText","map","user","concat","firstName","lastName","join","remainingCount","TeamRowItem","_ref","_team$workspace","team","handleShowTeamDetails","handleDeleteTeam","users","tooltipText","height","children","width","onClick","id","name","title","placement","picture","window","hasWorkspacesFeature","description","workspace","color","TeamRow","_ref2","teams","style","display","flexDirection","border"],"sources":["../../../../src/components/Table/TeamRow/TeamRow.tsx"],"sourcesContent":["import { AvatarUser } from '@projectcor/cor-commons/lib/components/avatar-user'\nimport { Trash } from '@projectcor/icons/lib/components/Trash'\nimport { Tooltip } from '@projectcor/tooltipv2/lib/components/Tooltip'\nimport {\n  SCRWrapper,\n  SCRWrapperDynamicRow,\n  SCRWIconUser,\n  SCRWrapperWorkspace,\n  SCRWrapperDeleteIcon,\n  SCRWrapperName,\n  SCRWrapperDescription,\n  SCRRemainingUsers,\n} from '../Row/Row.styles'\nimport { Team } from '../../TeamDetailsModal/TeamDetailsModal.types'\n\nconst MAX_USERS_DISPLAYED = 6\nconst MAX_NAMES_IN_TOOLTIP = 5\n\nconst formatRemainingUsersTooltip = (remainingUsers: Team['users']): string => {\n  if (remainingUsers.length === 0) return ''\n\n  const namesToShow = remainingUsers.slice(0, MAX_NAMES_IN_TOOLTIP)\n  const namesText = namesToShow.map(user => `${user.firstName} ${user.lastName}`).join(' - ')\n\n  if (remainingUsers.length > MAX_NAMES_IN_TOOLTIP) {\n    const remainingCount = remainingUsers.length - MAX_NAMES_IN_TOOLTIP\n    return `${namesText} +${remainingCount}`\n  }\n\n  return namesText\n}\n\nconst TeamRowItem = ({\n  team,\n  handleShowTeamDetails,\n  handleDeleteTeam,\n}: {\n  team: Team\n  handleShowTeamDetails: (teamId: number) => void\n  handleDeleteTeam: (teamId: number) => void\n}) => {\n  const remainingUsers = team.users.slice(MAX_USERS_DISPLAYED)\n  const tooltipText = formatRemainingUsersTooltip(remainingUsers)\n\n  return (\n    <SCRWrapper height=\"48px\">\n      <SCRWrapperName width=\"300px\" onClick={() => handleShowTeamDetails(team.id)}>\n        <span>{team.name}</span>\n      </SCRWrapperName>\n      <SCRWrapperDynamicRow onClick={() => handleShowTeamDetails(team.id)}>\n        {team.users.slice(0, MAX_USERS_DISPLAYED).map(user => {\n          return (\n            <Tooltip title={`${user.firstName} ${user.lastName}`} placement=\"top\">\n              <SCRWIconUser key={user.id}>\n                <AvatarUser firstName={user.firstName} lastName={user.lastName} picture={user.picture} />\n              </SCRWIconUser>\n            </Tooltip>\n          )\n        })}\n        {team.users.length > MAX_USERS_DISPLAYED && (\n          <Tooltip title={tooltipText} placement=\"top\">\n            <SCRRemainingUsers>+{team.users.length - MAX_USERS_DISPLAYED}</SCRRemainingUsers>\n          </Tooltip>\n        )}\n      </SCRWrapperDynamicRow>\n      {!window.hasWorkspacesFeature && (\n        <SCRWrapperDescription width=\"274px\" onClick={() => handleShowTeamDetails(team.id)}>\n          <span>{team.description}</span>\n        </SCRWrapperDescription>\n      )}\n      {window.hasWorkspacesFeature && (\n        <SCRWrapperDynamicRow onClick={() => handleShowTeamDetails(team.id)}>\n          {team.workspace?.name && (\n            <SCRWrapperWorkspace>\n              <span>{team.workspace.name}</span>\n            </SCRWrapperWorkspace>\n          )}\n        </SCRWrapperDynamicRow>\n      )}\n      <SCRWrapperDynamicRow width=\"40px\">\n        <SCRWrapperDeleteIcon onClick={() => handleDeleteTeam(team.id)}>\n          <Trash width=\"14px\" height=\"14px\" color=\"#C70505\" />\n        </SCRWrapperDeleteIcon>\n      </SCRWrapperDynamicRow>\n    </SCRWrapper>\n  )\n}\n\nexport const TeamRow = ({\n  teams,\n  handleShowTeamDetails,\n  handleDeleteTeam,\n}: {\n  teams: Team[]\n  handleShowTeamDetails: (teamId: number) => void\n  handleDeleteTeam: (teamId: number) => void\n}) => {\n  return (\n    <div style={{ display: 'flex', flexDirection: 'column', border: '1px solid #e7e7e7' }}>\n      {teams.map(team => (\n        <TeamRowItem\n          key={team.id}\n          team={team}\n          handleShowTeamDetails={handleShowTeamDetails}\n          handleDeleteTeam={handleDeleteTeam}\n        />\n      ))}\n    </div>\n  )\n}\n"],"mappings":"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","ignoreList":[]}
|
|
124
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","useRef","useEffect","useState","Tooltip","MenuOptions","SCRWrapper","SCRWrapperDynamicRow","SCRWrapperWorkspace","SCRWrapperName","SCRWrapperDescription","SCTeamRowList","UsersRow","jsx","_jsx","jsxs","_jsxs","TeamRowItem","_ref","_team$workspace","team","handleShowTeamDetails","handleDeleteTeam","handleEditTeam","handleRemoveUser","handleAddUser","nameRef","_useState","_useState2","_slicedToArray","isTruncated","setIsTruncated","checkTruncation","current","_nameRef$current","scrollWidth","clientWidth","window","addEventListener","removeEventListener","name","handleMenuSelectOption","option","id","nameElement","ref","children","height","width","onClick","title","onRemoveUser","onAddUser","hasWorkspacesFeature","description","workspace","concat","handleSelectOption","options","label","TeamRow","_ref2","teams","map"],"sources":["../../../../src/components/Table/TeamRow/TeamRow.tsx"],"sourcesContent":["import React, { useRef, useEffect, useState } from 'react'\nimport { Tooltip } from '@projectcor/tooltipv2/lib/components/Tooltip'\nimport { MenuOptions } from '../../MenuOptions/MenuOptions'\nimport {\n  SCRWrapper,\n  SCRWrapperDynamicRow,\n  SCRWrapperWorkspace,\n  SCRWrapperName,\n  SCRWrapperDescription,\n} from '../Row/Row.styles'\nimport { SCTeamRowList } from './TeamRow.styles'\nimport { Team } from '../../TeamDetailsModal/TeamDetailsModal.types'\nimport { UsersRow } from './UsersRow'\n\n/* eslint-disable react/require-default-props */\nconst TeamRowItem = ({\n  team,\n  handleShowTeamDetails,\n  handleDeleteTeam,\n  handleEditTeam,\n  handleRemoveUser,\n  handleAddUser,\n}: {\n  team: Team\n  handleShowTeamDetails: (teamId: number) => void\n  handleDeleteTeam: (teamId: number) => void\n  handleEditTeam: (teamId: number) => void\n  handleRemoveUser: (teamId: number, userId: number, deleteFromProjects: boolean) => void\n  handleAddUser: (teamId: number, userId: number, giveAccessToAllProjects: boolean) => void\n}) => {\n  const nameRef = useRef<HTMLSpanElement>(null)\n  const [isTruncated, setIsTruncated] = useState(false)\n\n  useEffect(() => {\n    const checkTruncation = () => {\n      if (nameRef.current) {\n        const { scrollWidth, clientWidth } = nameRef.current\n        setIsTruncated(scrollWidth > clientWidth)\n      }\n    }\n\n    checkTruncation()\n    window.addEventListener('resize', checkTruncation)\n    return () => window.removeEventListener('resize', checkTruncation)\n  }, [team.name])\n\n  const handleMenuSelectOption = (option: { id: number; label: string }) => {\n    if (option.id === 2) {\n      // Editar\n      handleEditTeam(team.id)\n    } else if (option.id === 3) {\n      // Eliminar\n      handleDeleteTeam(team.id)\n    }\n  }\n\n  const nameElement = <span ref={nameRef}>{team.name}</span>\n\n  return (\n    <SCRWrapper height=\"48px\">\n      <SCRWrapperName width=\"300px\" onClick={() => handleShowTeamDetails(team.id)}>\n        {isTruncated ? <Tooltip title={team.name}>{nameElement}</Tooltip> : nameElement}\n      </SCRWrapperName>\n      <SCRWrapperDynamicRow>\n        <UsersRow team={team} onRemoveUser={handleRemoveUser} onAddUser={handleAddUser} />\n      </SCRWrapperDynamicRow>\n      {!window.hasWorkspacesFeature && (\n        <SCRWrapperDescription width=\"274px\" onClick={() => handleShowTeamDetails(team.id)}>\n          <span>{team.description}</span>\n        </SCRWrapperDescription>\n      )}\n      {window.hasWorkspacesFeature && (\n        <SCRWrapperDynamicRow onClick={() => handleShowTeamDetails(team.id)}>\n          {team.workspace?.name && (\n            <SCRWrapperWorkspace>\n              <span>{team.workspace.name}</span>\n            </SCRWrapperWorkspace>\n          )}\n        </SCRWrapperDynamicRow>\n      )}\n      <SCRWrapperDynamicRow width=\"40px\">\n        {!window.hasWorkspacesFeature && (\n          <MenuOptions\n            id={`team-menu-${team.id}`}\n            handleSelectOption={handleMenuSelectOption}\n            options={[\n              { id: 2, label: 'Editar' },\n              { id: 3, label: 'Eliminar' },\n            ]}\n          />\n        )}\n      </SCRWrapperDynamicRow>\n    </SCRWrapper>\n  )\n}\n\n/* eslint-disable react/require-default-props */\nexport const TeamRow = ({\n  teams,\n  handleShowTeamDetails,\n  handleDeleteTeam,\n  handleEditTeam,\n  handleRemoveUser,\n  handleAddUser,\n}: {\n  teams: Team[]\n  handleShowTeamDetails: (teamId: number) => void\n  handleDeleteTeam: (teamId: number) => void\n  handleEditTeam: (teamId: number) => void\n  handleRemoveUser: (teamId: number, userId: number, deleteFromProjects: boolean) => void\n  handleAddUser: (teamId: number, userId: number, giveAccessToAllProjects: boolean) => void\n}) => {\n  return (\n    <SCTeamRowList>\n      {teams.map(team => (\n        <TeamRowItem\n          key={team.id}\n          team={team}\n          handleShowTeamDetails={handleShowTeamDetails}\n          handleDeleteTeam={handleDeleteTeam}\n          handleEditTeam={handleEditTeam}\n          handleRemoveUser={handleRemoveUser}\n          handleAddUser={handleAddUser}\n        />\n      ))}\n    </SCTeamRowList>\n  )\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import styled from 'styled-components';
|
|
2
|
+
export var SCTeamRowList = styled.div.withConfig({
|
|
3
|
+
displayName: "TeamRowstyles__SCTeamRowList",
|
|
4
|
+
componentId: "sc-1e41ddl-0"
|
|
5
|
+
})(["display:flex;flex-direction:column;border:1px solid #e7e7e7;"]);
|
|
6
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJzdHlsZWQiLCJTQ1RlYW1Sb3dMaXN0IiwiZGl2Iiwid2l0aENvbmZpZyIsImRpc3BsYXlOYW1lIiwiY29tcG9uZW50SWQiXSwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9UYWJsZS9UZWFtUm93L1RlYW1Sb3cuc3R5bGVzLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ3N0eWxlZC1jb21wb25lbnRzJ1xuXG5leHBvcnQgY29uc3QgU0NUZWFtUm93TGlzdCA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIGJvcmRlcjogMXB4IHNvbGlkICNlN2U3ZTc7XG5gXG4iXSwibWFwcGluZ3MiOiJBQUFBLE9BQU9BLE1BQU0sTUFBTSxtQkFBbUI7QUFFdEMsT0FBTyxJQUFNQyxhQUFhLEdBQUdELE1BQU0sQ0FBQ0UsR0FBRyxDQUFBQyxVQUFBO0VBQUFDLFdBQUE7RUFBQUMsV0FBQTtBQUFBLG9FQUl0QyIsImlnbm9yZUxpc3QiOltdfQ==
|
|
@@ -0,0 +1,191 @@
|
|
|
1
|
+
import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
|
|
2
|
+
import React, { useState, useRef, useEffect } from 'react';
|
|
3
|
+
import { AvatarUser } from '@projectcor/cor-commons/lib/components/avatar-user';
|
|
4
|
+
import { Cross } from '@projectcor/icons/lib/components/Cross';
|
|
5
|
+
import { ChevronLeft } from '@projectcor/icons/lib/components/ChevronLeft';
|
|
6
|
+
import { ChevronRight } from '@projectcor/icons/lib/components/ChevronRight';
|
|
7
|
+
import { Tooltip } from '@projectcor/tooltipv2/lib/components/Tooltip';
|
|
8
|
+
import { AddUsers } from '../AddUsers';
|
|
9
|
+
import { AddMemberModal } from '../AddMemberModal';
|
|
10
|
+
import { RemoveMemberModal } from '../RemoveMemberModal';
|
|
11
|
+
import { SCURUserContainer, SCURUserAvatar, SCURRemoveIcon, SCURAddUsersWrapper, SCURSliderWrapper, SCURSliderContainer, SCURSliderContent, SCURNavButton } from './UsersRow.styles';
|
|
12
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
13
|
+
export var UsersRow = function UsersRow(_ref) {
|
|
14
|
+
var team = _ref.team,
|
|
15
|
+
onRemoveUser = _ref.onRemoveUser,
|
|
16
|
+
onAddUser = _ref.onAddUser;
|
|
17
|
+
var currentMembers = team.users.map(function (user) {
|
|
18
|
+
return {
|
|
19
|
+
id: user.id,
|
|
20
|
+
name: "".concat(user.firstName, " ").concat(user.lastName)
|
|
21
|
+
};
|
|
22
|
+
});
|
|
23
|
+
var _useState = useState(false),
|
|
24
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
25
|
+
isModalOpen = _useState2[0],
|
|
26
|
+
setIsModalOpen = _useState2[1];
|
|
27
|
+
var _useState3 = useState(null),
|
|
28
|
+
_useState4 = _slicedToArray(_useState3, 2),
|
|
29
|
+
pendingMembers = _useState4[0],
|
|
30
|
+
setPendingMembers = _useState4[1];
|
|
31
|
+
var _useState5 = useState(false),
|
|
32
|
+
_useState6 = _slicedToArray(_useState5, 2),
|
|
33
|
+
isRemoveModalOpen = _useState6[0],
|
|
34
|
+
setIsRemoveModalOpen = _useState6[1];
|
|
35
|
+
var _useState7 = useState(null),
|
|
36
|
+
_useState8 = _slicedToArray(_useState7, 2),
|
|
37
|
+
userToRemove = _useState8[0],
|
|
38
|
+
setUserToRemove = _useState8[1];
|
|
39
|
+
var _useState9 = useState(false),
|
|
40
|
+
_useState0 = _slicedToArray(_useState9, 2),
|
|
41
|
+
showLeftButton = _useState0[0],
|
|
42
|
+
setShowLeftButton = _useState0[1];
|
|
43
|
+
var _useState1 = useState(true),
|
|
44
|
+
_useState10 = _slicedToArray(_useState1, 2),
|
|
45
|
+
showRightButton = _useState10[0],
|
|
46
|
+
setShowRightButton = _useState10[1];
|
|
47
|
+
var sliderRef = useRef(null);
|
|
48
|
+
var handleAddMembers = function handleAddMembers(member) {
|
|
49
|
+
setPendingMembers(member);
|
|
50
|
+
setIsModalOpen(true);
|
|
51
|
+
};
|
|
52
|
+
var handleModalAccept = function handleModalAccept(giveAccessToAllProjects) {
|
|
53
|
+
if (pendingMembers) {
|
|
54
|
+
onAddUser(+team.id, pendingMembers.id, giveAccessToAllProjects);
|
|
55
|
+
setIsModalOpen(false);
|
|
56
|
+
setPendingMembers(null);
|
|
57
|
+
}
|
|
58
|
+
};
|
|
59
|
+
var handleModalClose = function handleModalClose() {
|
|
60
|
+
setIsModalOpen(false);
|
|
61
|
+
setPendingMembers(null);
|
|
62
|
+
};
|
|
63
|
+
var handleRemoveUser = function handleRemoveUser(e, userId) {
|
|
64
|
+
e.stopPropagation();
|
|
65
|
+
setUserToRemove(userId);
|
|
66
|
+
setIsRemoveModalOpen(true);
|
|
67
|
+
};
|
|
68
|
+
var handleRemoveModalAccept = function handleRemoveModalAccept(deleteFromProjects) {
|
|
69
|
+
if (userToRemove !== null) {
|
|
70
|
+
onRemoveUser(+team.id, userToRemove, deleteFromProjects);
|
|
71
|
+
}
|
|
72
|
+
setIsRemoveModalOpen(false);
|
|
73
|
+
setUserToRemove(null);
|
|
74
|
+
};
|
|
75
|
+
var handleRemoveModalClose = function handleRemoveModalClose() {
|
|
76
|
+
setIsRemoveModalOpen(false);
|
|
77
|
+
setUserToRemove(null);
|
|
78
|
+
};
|
|
79
|
+
var checkScrollButtons = function checkScrollButtons() {
|
|
80
|
+
if (sliderRef.current) {
|
|
81
|
+
var _sliderRef$current = sliderRef.current,
|
|
82
|
+
_scrollLeft = _sliderRef$current.scrollLeft,
|
|
83
|
+
scrollWidth = _sliderRef$current.scrollWidth,
|
|
84
|
+
clientWidth = _sliderRef$current.clientWidth;
|
|
85
|
+
setShowLeftButton(_scrollLeft > 0);
|
|
86
|
+
setShowRightButton(_scrollLeft < scrollWidth - (clientWidth + 20) - 1);
|
|
87
|
+
}
|
|
88
|
+
};
|
|
89
|
+
useEffect(function () {
|
|
90
|
+
// Esperar un momento para que el DOM se actualice
|
|
91
|
+
var timer = setTimeout(function () {
|
|
92
|
+
checkScrollButtons();
|
|
93
|
+
}, 0);
|
|
94
|
+
var slider = sliderRef.current;
|
|
95
|
+
if (slider) {
|
|
96
|
+
slider.addEventListener('scroll', checkScrollButtons);
|
|
97
|
+
return function () {
|
|
98
|
+
clearTimeout(timer);
|
|
99
|
+
slider.removeEventListener('scroll', checkScrollButtons);
|
|
100
|
+
};
|
|
101
|
+
}
|
|
102
|
+
return function () {
|
|
103
|
+
return clearTimeout(timer);
|
|
104
|
+
};
|
|
105
|
+
}, [team.users]);
|
|
106
|
+
var scrollLeft = function scrollLeft() {
|
|
107
|
+
if (sliderRef.current) {
|
|
108
|
+
var scrollAmount = 200;
|
|
109
|
+
sliderRef.current.scrollBy({
|
|
110
|
+
left: -scrollAmount,
|
|
111
|
+
behavior: 'smooth'
|
|
112
|
+
});
|
|
113
|
+
}
|
|
114
|
+
};
|
|
115
|
+
var scrollRight = function scrollRight() {
|
|
116
|
+
if (sliderRef.current) {
|
|
117
|
+
var scrollAmount = 200;
|
|
118
|
+
sliderRef.current.scrollBy({
|
|
119
|
+
left: scrollAmount,
|
|
120
|
+
behavior: 'smooth'
|
|
121
|
+
});
|
|
122
|
+
}
|
|
123
|
+
};
|
|
124
|
+
return /*#__PURE__*/_jsxs(_Fragment, {
|
|
125
|
+
children: [/*#__PURE__*/_jsxs(SCURSliderWrapper, {
|
|
126
|
+
children: [showLeftButton && /*#__PURE__*/_jsx(SCURNavButton, {
|
|
127
|
+
onClick: scrollLeft,
|
|
128
|
+
"aria-label": "Desplazar izquierda",
|
|
129
|
+
left: "-4px",
|
|
130
|
+
children: /*#__PURE__*/_jsx(ChevronLeft, {
|
|
131
|
+
width: "16px",
|
|
132
|
+
height: "16px",
|
|
133
|
+
color: "#8C8C8C"
|
|
134
|
+
})
|
|
135
|
+
}), /*#__PURE__*/_jsx(SCURSliderContainer, {
|
|
136
|
+
ref: sliderRef,
|
|
137
|
+
children: /*#__PURE__*/_jsx(SCURSliderContent, {
|
|
138
|
+
children: team.users.map(function (user) {
|
|
139
|
+
return /*#__PURE__*/_jsxs(SCURUserContainer, {
|
|
140
|
+
children: [/*#__PURE__*/_jsx(Tooltip, {
|
|
141
|
+
title: "".concat(user.firstName, " ").concat(user.lastName),
|
|
142
|
+
placement: "top",
|
|
143
|
+
children: /*#__PURE__*/_jsx(SCURUserAvatar, {
|
|
144
|
+
children: /*#__PURE__*/_jsx(AvatarUser, {
|
|
145
|
+
firstName: user.firstName,
|
|
146
|
+
lastName: user.lastName,
|
|
147
|
+
picture: user.picture
|
|
148
|
+
})
|
|
149
|
+
})
|
|
150
|
+
}), !window.hasWorkspacesFeature && /*#__PURE__*/_jsx(SCURRemoveIcon, {
|
|
151
|
+
onClick: function onClick(e) {
|
|
152
|
+
return handleRemoveUser(e, user.id);
|
|
153
|
+
},
|
|
154
|
+
role: "button",
|
|
155
|
+
tabIndex: 0,
|
|
156
|
+
children: /*#__PURE__*/_jsx(Cross, {
|
|
157
|
+
width: "11px",
|
|
158
|
+
height: "11px",
|
|
159
|
+
color: "#8C8C8C"
|
|
160
|
+
})
|
|
161
|
+
})]
|
|
162
|
+
}, user.id);
|
|
163
|
+
})
|
|
164
|
+
})
|
|
165
|
+
}), showRightButton && /*#__PURE__*/_jsx(SCURNavButton, {
|
|
166
|
+
onClick: scrollRight,
|
|
167
|
+
"aria-label": "Desplazar derecha",
|
|
168
|
+
right: "-4px",
|
|
169
|
+
children: /*#__PURE__*/_jsx(ChevronRight, {
|
|
170
|
+
width: "16px",
|
|
171
|
+
height: "16px",
|
|
172
|
+
color: "#8C8C8C"
|
|
173
|
+
})
|
|
174
|
+
})]
|
|
175
|
+
}), !window.hasWorkspacesFeature && /*#__PURE__*/_jsx(SCURAddUsersWrapper, {
|
|
176
|
+
children: /*#__PURE__*/_jsx(AddUsers, {
|
|
177
|
+
currentMembers: currentMembers,
|
|
178
|
+
onAddMembers: handleAddMembers
|
|
179
|
+
})
|
|
180
|
+
}), /*#__PURE__*/_jsx(AddMemberModal, {
|
|
181
|
+
isOpen: isModalOpen,
|
|
182
|
+
onClose: handleModalClose,
|
|
183
|
+
onAccept: handleModalAccept
|
|
184
|
+
}), /*#__PURE__*/_jsx(RemoveMemberModal, {
|
|
185
|
+
isOpen: isRemoveModalOpen,
|
|
186
|
+
onClose: handleRemoveModalClose,
|
|
187
|
+
onAccept: handleRemoveModalAccept
|
|
188
|
+
})]
|
|
189
|
+
});
|
|
190
|
+
};
|
|
191
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","useState","useRef","useEffect","AvatarUser","Cross","ChevronLeft","ChevronRight","Tooltip","AddUsers","AddMemberModal","RemoveMemberModal","SCURUserContainer","SCURUserAvatar","SCURRemoveIcon","SCURAddUsersWrapper","SCURSliderWrapper","SCURSliderContainer","SCURSliderContent","SCURNavButton","jsx","_jsx","jsxs","_jsxs","Fragment","_Fragment","UsersRow","_ref","team","onRemoveUser","onAddUser","currentMembers","users","map","user","id","name","concat","firstName","lastName","_useState","_useState2","_slicedToArray","isModalOpen","setIsModalOpen","_useState3","_useState4","pendingMembers","setPendingMembers","_useState5","_useState6","isRemoveModalOpen","setIsRemoveModalOpen","_useState7","_useState8","userToRemove","setUserToRemove","_useState9","_useState0","showLeftButton","setShowLeftButton","_useState1","_useState10","showRightButton","setShowRightButton","sliderRef","handleAddMembers","member","handleModalAccept","giveAccessToAllProjects","handleModalClose","handleRemoveUser","e","userId","stopPropagation","handleRemoveModalAccept","deleteFromProjects","handleRemoveModalClose","checkScrollButtons","current","_sliderRef$current","scrollLeft","scrollWidth","clientWidth","timer","setTimeout","slider","addEventListener","clearTimeout","removeEventListener","scrollAmount","scrollBy","left","behavior","scrollRight","children","onClick","width","height","color","ref","title","placement","picture","window","hasWorkspacesFeature","role","tabIndex","right","onAddMembers","isOpen","onClose","onAccept"],"sources":["../../../../../src/components/Table/TeamRow/UsersRow/UsersRow.tsx"],"sourcesContent":["import React, { useState, useRef, useEffect } from 'react'\nimport { AvatarUser } from '@projectcor/cor-commons/lib/components/avatar-user'\nimport { Cross } from '@projectcor/icons/lib/components/Cross'\nimport { ChevronLeft } from '@projectcor/icons/lib/components/ChevronLeft'\nimport { ChevronRight } from '@projectcor/icons/lib/components/ChevronRight'\nimport { Tooltip } from '@projectcor/tooltipv2/lib/components/Tooltip'\nimport { Team } from '../../../TeamDetailsModal/TeamDetailsModal.types'\nimport { AddUsers } from '../AddUsers'\nimport { MemberSelection } from '../../../TeamDetailsModal/MembersSelect'\nimport { AddMemberModal } from '../AddMemberModal'\nimport { RemoveMemberModal } from '../RemoveMemberModal'\nimport { User } from '../../../../types/userType'\nimport {\n  SCURUserContainer,\n  SCURUserAvatar,\n  SCURRemoveIcon,\n  SCURAddUsersWrapper,\n  SCURSliderWrapper,\n  SCURSliderContainer,\n  SCURSliderContent,\n  SCURNavButton,\n} from './UsersRow.styles'\n\ninterface UsersRowProps {\n  team: Team\n  onRemoveUser: (teamId: number, userId: number, deleteFromProjects: boolean) => void\n  onAddUser: (teamId: number, userId: number, giveAccessToAllProjects: boolean) => void\n}\n\nexport const UsersRow = ({ team, onRemoveUser, onAddUser }: UsersRowProps) => {\n  const currentMembers: MemberSelection[] = team.users.map(user => ({\n    id: user.id,\n    name: `${user.firstName} ${user.lastName}`,\n  }))\n\n  const [isModalOpen, setIsModalOpen] = useState(false)\n  const [pendingMembers, setPendingMembers] = useState<User | null>(null)\n  const [isRemoveModalOpen, setIsRemoveModalOpen] = useState(false)\n  const [userToRemove, setUserToRemove] = useState<number | null>(null)\n  const [showLeftButton, setShowLeftButton] = useState(false)\n  const [showRightButton, setShowRightButton] = useState(true)\n  const sliderRef = useRef<HTMLDivElement>(null)\n\n  const handleAddMembers = (member: User) => {\n    setPendingMembers(member)\n    setIsModalOpen(true)\n  }\n\n  const handleModalAccept = (giveAccessToAllProjects: boolean) => {\n    if (pendingMembers) {\n      onAddUser(+team.id, pendingMembers.id, giveAccessToAllProjects)\n      setIsModalOpen(false)\n      setPendingMembers(null)\n    }\n  }\n\n  const handleModalClose = () => {\n    setIsModalOpen(false)\n    setPendingMembers(null)\n  }\n\n  const handleRemoveUser = (e: React.MouseEvent, userId: number) => {\n    e.stopPropagation()\n    setUserToRemove(userId)\n    setIsRemoveModalOpen(true)\n  }\n\n  const handleRemoveModalAccept = (deleteFromProjects: boolean) => {\n    if (userToRemove !== null) {\n      onRemoveUser(+team.id, userToRemove, deleteFromProjects)\n    }\n    setIsRemoveModalOpen(false)\n    setUserToRemove(null)\n  }\n\n  const handleRemoveModalClose = () => {\n    setIsRemoveModalOpen(false)\n    setUserToRemove(null)\n  }\n\n  const checkScrollButtons = () => {\n    if (sliderRef.current) {\n      const { scrollLeft, scrollWidth, clientWidth } = sliderRef.current\n      setShowLeftButton(scrollLeft > 0)\n      setShowRightButton(scrollLeft < scrollWidth - (clientWidth + 20) - 1)\n    }\n  }\n\n  useEffect(() => {\n    // Esperar un momento para que el DOM se actualice\n    const timer = setTimeout(() => {\n      checkScrollButtons()\n    }, 0)\n\n    const slider = sliderRef.current\n    if (slider) {\n      slider.addEventListener('scroll', checkScrollButtons)\n      return () => {\n        clearTimeout(timer)\n        slider.removeEventListener('scroll', checkScrollButtons)\n      }\n    }\n    return () => clearTimeout(timer)\n  }, [team.users])\n\n  const scrollLeft = () => {\n    if (sliderRef.current) {\n      const scrollAmount = 200\n      sliderRef.current.scrollBy({ left: -scrollAmount, behavior: 'smooth' })\n    }\n  }\n\n  const scrollRight = () => {\n    if (sliderRef.current) {\n      const scrollAmount = 200\n      sliderRef.current.scrollBy({ left: scrollAmount, behavior: 'smooth' })\n    }\n  }\n\n  return (\n    <>\n      <SCURSliderWrapper>\n        {showLeftButton && (\n          <SCURNavButton onClick={scrollLeft} aria-label=\"Desplazar izquierda\" left=\"-4px\">\n            <ChevronLeft width=\"16px\" height=\"16px\" color=\"#8C8C8C\" />\n          </SCURNavButton>\n        )}\n        <SCURSliderContainer ref={sliderRef}>\n          <SCURSliderContent>\n            {team.users.map(user => {\n              return (\n                <SCURUserContainer key={user.id}>\n                  <Tooltip title={`${user.firstName} ${user.lastName}`} placement=\"top\">\n                    <SCURUserAvatar>\n                      <AvatarUser firstName={user.firstName} lastName={user.lastName} picture={user.picture} />\n                    </SCURUserAvatar>\n                  </Tooltip>\n                  {!window.hasWorkspacesFeature && (\n                    <SCURRemoveIcon onClick={e => handleRemoveUser(e, user.id)} role=\"button\" tabIndex={0}>\n                      <Cross width=\"11px\" height=\"11px\" color=\"#8C8C8C\" />\n                    </SCURRemoveIcon>\n                  )}\n                </SCURUserContainer>\n              )\n            })}\n          </SCURSliderContent>\n        </SCURSliderContainer>\n\n        {showRightButton && (\n          <SCURNavButton onClick={scrollRight} aria-label=\"Desplazar derecha\" right=\"-4px\">\n            <ChevronRight width=\"16px\" height=\"16px\" color=\"#8C8C8C\" />\n          </SCURNavButton>\n        )}\n      </SCURSliderWrapper>\n      {!window.hasWorkspacesFeature && (\n        <SCURAddUsersWrapper>\n          <AddUsers currentMembers={currentMembers} onAddMembers={handleAddMembers} />\n        </SCURAddUsersWrapper>\n      )}\n      <AddMemberModal isOpen={isModalOpen} onClose={handleModalClose} onAccept={handleModalAccept} />\n      <RemoveMemberModal\n        isOpen={isRemoveModalOpen}\n        onClose={handleRemoveModalClose}\n        onAccept={handleRemoveModalAccept}\n      />\n    </>\n  )\n}\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import styled from 'styled-components';
|
|
2
|
+
export var SCURRemoveIcon = styled.div.withConfig({
|
|
3
|
+
displayName: "UsersRowstyles__SCURRemoveIcon",
|
|
4
|
+
componentId: "sc-1lkpduz-0"
|
|
5
|
+
})(["position:absolute;bottom:-4px;right:-4px;width:14px;height:14px;border:1px solid #8c8c8c;background-color:#ffffff;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;visibility:hidden;transition:opacity 0.2s ease-in-out,visibility 0.2s ease-in-out;z-index:10;"]);
|
|
6
|
+
export var SCURUserContainer = styled.div.withConfig({
|
|
7
|
+
displayName: "UsersRowstyles__SCURUserContainer",
|
|
8
|
+
componentId: "sc-1lkpduz-1"
|
|
9
|
+
})(["position:relative;display:inline-block;margin-right:1px;&:hover ", "{opacity:1;visibility:visible;}"], SCURRemoveIcon);
|
|
10
|
+
export var SCURUserAvatar = styled.div.withConfig({
|
|
11
|
+
displayName: "UsersRowstyles__SCURUserAvatar",
|
|
12
|
+
componentId: "sc-1lkpduz-2"
|
|
13
|
+
})(["position:relative;display:flex;align-items:center;justify-content:center;"]);
|
|
14
|
+
export var SCURAddUsersWrapper = styled.div.withConfig({
|
|
15
|
+
displayName: "UsersRowstyles__SCURAddUsersWrapper",
|
|
16
|
+
componentId: "sc-1lkpduz-3"
|
|
17
|
+
})(["display:inline-block;flex-shrink:0;margin-left:4px;"]);
|
|
18
|
+
export var SCURSliderWrapper = styled.div.withConfig({
|
|
19
|
+
displayName: "UsersRowstyles__SCURSliderWrapper",
|
|
20
|
+
componentId: "sc-1lkpduz-4"
|
|
21
|
+
})(["display:flex;align-items:center;position:relative;width:fit-content;min-width:0;max-width:100%;"]);
|
|
22
|
+
export var SCURSliderContainer = styled.div.withConfig({
|
|
23
|
+
displayName: "UsersRowstyles__SCURSliderContainer",
|
|
24
|
+
componentId: "sc-1lkpduz-5"
|
|
25
|
+
})(["overflow-x:auto;overflow-y:hidden;scroll-behavior:smooth;flex:1 1 0;display:flex;align-items:center;min-width:0;max-width:100%;scrollbar-width:none;-ms-overflow-style:none;&::-webkit-scrollbar{display:none;}"]);
|
|
26
|
+
export var SCURSliderContent = styled.div.withConfig({
|
|
27
|
+
displayName: "UsersRowstyles__SCURSliderContent",
|
|
28
|
+
componentId: "sc-1lkpduz-6"
|
|
29
|
+
})(["display:flex;align-items:center;gap:0;min-width:fit-content;max-width:100%;height:48px;"]);
|
|
30
|
+
export var SCURNavButton = styled.button.withConfig({
|
|
31
|
+
displayName: "UsersRowstyles__SCURNavButton",
|
|
32
|
+
componentId: "sc-1lkpduz-7"
|
|
33
|
+
})(["display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;border:none;box-shadow:0px 4px 16px 0px #1212123d;background-color:#ffffff;cursor:pointer;flex-shrink:0;transition:background-color 0.2s ease-in-out;z-index:1;position:absolute;", " ", " &:hover{background-color:#f5f5f5;}&:active{background-color:#e8e8e8;}"], function (_ref) {
|
|
34
|
+
var right = _ref.right;
|
|
35
|
+
return right && "right: ".concat(right, ";");
|
|
36
|
+
}, function (_ref2) {
|
|
37
|
+
var left = _ref2.left;
|
|
38
|
+
return left && "left: ".concat(left, ";");
|
|
39
|
+
});
|
|
40
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJzdHlsZWQiLCJTQ1VSUmVtb3ZlSWNvbiIsImRpdiIsIndpdGhDb25maWciLCJkaXNwbGF5TmFtZSIsImNvbXBvbmVudElkIiwiU0NVUlVzZXJDb250YWluZXIiLCJTQ1VSVXNlckF2YXRhciIsIlNDVVJBZGRVc2Vyc1dyYXBwZXIiLCJTQ1VSU2xpZGVyV3JhcHBlciIsIlNDVVJTbGlkZXJDb250YWluZXIiLCJTQ1VSU2xpZGVyQ29udGVudCIsIlNDVVJOYXZCdXR0b24iLCJidXR0b24iLCJfcmVmIiwicmlnaHQiLCJjb25jYXQiLCJfcmVmMiIsImxlZnQiXSwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvY29tcG9uZW50cy9UYWJsZS9UZWFtUm93L1VzZXJzUm93L1VzZXJzUm93LnN0eWxlcy50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdzdHlsZWQtY29tcG9uZW50cydcblxuZXhwb3J0IGNvbnN0IFNDVVJSZW1vdmVJY29uID0gc3R5bGVkLmRpdmBcbiAgcG9zaXRpb246IGFic29sdXRlO1xuICBib3R0b206IC00cHg7XG4gIHJpZ2h0OiAtNHB4O1xuICB3aWR0aDogMTRweDtcbiAgaGVpZ2h0OiAxNHB4O1xuICBib3JkZXI6IDFweCBzb2xpZCAjOGM4YzhjO1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAjZmZmZmZmO1xuICBib3JkZXItcmFkaXVzOiA1MCU7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuICBjdXJzb3I6IHBvaW50ZXI7XG4gIG9wYWNpdHk6IDA7XG4gIHZpc2liaWxpdHk6IGhpZGRlbjtcbiAgdHJhbnNpdGlvbjogb3BhY2l0eSAwLjJzIGVhc2UtaW4tb3V0LCB2aXNpYmlsaXR5IDAuMnMgZWFzZS1pbi1vdXQ7XG4gIHotaW5kZXg6IDEwO1xuYFxuXG5leHBvcnQgY29uc3QgU0NVUlVzZXJDb250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIGRpc3BsYXk6IGlubGluZS1ibG9jaztcbiAgbWFyZ2luLXJpZ2h0OiAxcHg7XG5cbiAgJjpob3ZlciAke1NDVVJSZW1vdmVJY29ufSB7XG4gICAgb3BhY2l0eTogMTtcbiAgICB2aXNpYmlsaXR5OiB2aXNpYmxlO1xuICB9XG5gXG5cbmV4cG9ydCBjb25zdCBTQ1VSVXNlckF2YXRhciA9IHN0eWxlZC5kaXZgXG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG5gXG5cbmV4cG9ydCBjb25zdCBTQ1VSQWRkVXNlcnNXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogaW5saW5lLWJsb2NrO1xuICBmbGV4LXNocmluazogMDtcbiAgbWFyZ2luLWxlZnQ6IDRweDtcbmBcblxuZXhwb3J0IGNvbnN0IFNDVVJTbGlkZXJXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICB3aWR0aDogZml0LWNvbnRlbnQ7XG4gIG1pbi13aWR0aDogMDtcbiAgbWF4LXdpZHRoOiAxMDAlO1xuICAvKiBvdmVyZmxvdzogaGlkZGVuOyAqL1xuICAvKiBnYXA6IDRweDsgKi9cbmBcblxuZXhwb3J0IGNvbnN0IFNDVVJTbGlkZXJDb250YWluZXIgPSBzdHlsZWQuZGl2YFxuICBvdmVyZmxvdy14OiBhdXRvO1xuICBvdmVyZmxvdy15OiBoaWRkZW47XG4gIHNjcm9sbC1iZWhhdmlvcjogc21vb3RoO1xuICBmbGV4OiAxIDEgMDtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgbWluLXdpZHRoOiAwO1xuICBtYXgtd2lkdGg6IDEwMCU7XG4gIHNjcm9sbGJhci13aWR0aDogbm9uZTsgLyogRmlyZWZveCAqL1xuICAtbXMtb3ZlcmZsb3ctc3R5bGU6IG5vbmU7IC8qIElFIGFuZCBFZGdlICovXG5cbiAgJjo6LXdlYmtpdC1zY3JvbGxiYXIge1xuICAgIGRpc3BsYXk6IG5vbmU7IC8qIENocm9tZSwgU2FmYXJpLCBPcGVyYSAqL1xuICB9XG5gXG5cbmV4cG9ydCBjb25zdCBTQ1VSU2xpZGVyQ29udGVudCA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGdhcDogMDtcbiAgbWluLXdpZHRoOiBmaXQtY29udGVudDtcbiAgbWF4LXdpZHRoOiAxMDAlO1xuICBoZWlnaHQ6IDQ4cHg7XG5gXG5cbmV4cG9ydCBjb25zdCBTQ1VSTmF2QnV0dG9uID0gc3R5bGVkLmJ1dHRvbjx7IHJpZ2h0Pzogc3RyaW5nOyBsZWZ0Pzogc3RyaW5nIH0+YFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcbiAgd2lkdGg6IDI0cHg7XG4gIGhlaWdodDogMjRweDtcbiAgYm9yZGVyLXJhZGl1czogNTAlO1xuICBib3JkZXI6IG5vbmU7XG4gIGJveC1zaGFkb3c6IDBweCA0cHggMTZweCAwcHggIzEyMTIxMjNkO1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAjZmZmZmZmO1xuICBjdXJzb3I6IHBvaW50ZXI7XG4gIGZsZXgtc2hyaW5rOiAwO1xuICB0cmFuc2l0aW9uOiBiYWNrZ3JvdW5kLWNvbG9yIDAuMnMgZWFzZS1pbi1vdXQ7XG4gIHotaW5kZXg6IDE7XG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgJHsoeyByaWdodCB9KSA9PiByaWdodCAmJiBgcmlnaHQ6ICR7cmlnaHR9O2B9XG4gICR7KHsgbGVmdCB9KSA9PiBsZWZ0ICYmIGBsZWZ0OiAke2xlZnR9O2B9XG5cbiAgJjpob3ZlciB7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogI2Y1ZjVmNTtcbiAgfVxuXG4gICY6YWN0aXZlIHtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAjZThlOGU4O1xuICB9XG5gXG4iXSwibWFwcGluZ3MiOiJBQUFBLE9BQU9BLE1BQU0sTUFBTSxtQkFBbUI7QUFFdEMsT0FBTyxJQUFNQyxjQUFjLEdBQUdELE1BQU0sQ0FBQ0UsR0FBRyxDQUFBQyxVQUFBO0VBQUFDLFdBQUE7RUFBQUMsV0FBQTtBQUFBLHlUQWlCdkM7QUFFRCxPQUFPLElBQU1DLGlCQUFpQixHQUFHTixNQUFNLENBQUNFLEdBQUcsQ0FBQUMsVUFBQTtFQUFBQyxXQUFBO0VBQUFDLFdBQUE7QUFBQSw0R0FLL0JKLGNBQWMsQ0FJekI7QUFFRCxPQUFPLElBQU1NLGNBQWMsR0FBR1AsTUFBTSxDQUFDRSxHQUFHLENBQUFDLFVBQUE7RUFBQUMsV0FBQTtFQUFBQyxXQUFBO0FBQUEsaUZBS3ZDO0FBRUQsT0FBTyxJQUFNRyxtQkFBbUIsR0FBR1IsTUFBTSxDQUFDRSxHQUFHLENBQUFDLFVBQUE7RUFBQUMsV0FBQTtFQUFBQyxXQUFBO0FBQUEsMkRBSTVDO0FBRUQsT0FBTyxJQUFNSSxpQkFBaUIsR0FBR1QsTUFBTSxDQUFDRSxHQUFHLENBQUFDLFVBQUE7RUFBQUMsV0FBQTtFQUFBQyxXQUFBO0FBQUEsdUdBUzFDO0FBRUQsT0FBTyxJQUFNSyxtQkFBbUIsR0FBR1YsTUFBTSxDQUFDRSxHQUFHLENBQUFDLFVBQUE7RUFBQUMsV0FBQTtFQUFBQyxXQUFBO0FBQUEsdU5BZTVDO0FBRUQsT0FBTyxJQUFNTSxpQkFBaUIsR0FBR1gsTUFBTSxDQUFDRSxHQUFHLENBQUFDLFVBQUE7RUFBQUMsV0FBQTtFQUFBQyxXQUFBO0FBQUEsK0ZBTzFDO0FBRUQsT0FBTyxJQUFNTyxhQUFhLEdBQUdaLE1BQU0sQ0FBQ2EsTUFBTSxDQUFBVixVQUFBO0VBQUFDLFdBQUE7RUFBQUMsV0FBQTtBQUFBLHlXQWV0QyxVQUFBUyxJQUFBO0VBQUEsSUFBR0MsS0FBSyxHQUFBRCxJQUFBLENBQUxDLEtBQUs7RUFBQSxPQUFPQSxLQUFLLGNBQUFDLE1BQUEsQ0FBY0QsS0FBSyxNQUFHO0FBQUEsR0FDMUMsVUFBQUUsS0FBQTtFQUFBLElBQUdDLElBQUksR0FBQUQsS0FBQSxDQUFKQyxJQUFJO0VBQUEsT0FBT0EsSUFBSSxhQUFBRixNQUFBLENBQWFFLElBQUksTUFBRztBQUFBLEVBU3pDIiwiaWdub3JlTGlzdCI6W119
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export { UsersRow } from './UsersRow';
|
|
2
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJVc2Vyc1JvdyJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL1RhYmxlL1RlYW1Sb3cvVXNlcnNSb3cvaW5kZXgudHMiXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgVXNlcnNSb3cgfSBmcm9tICcuL1VzZXJzUm93J1xuIl0sIm1hcHBpbmdzIjoiQUFBQSxTQUFTQSxRQUFRLFFBQVEsWUFBWSIsImlnbm9yZUxpc3QiOltdfQ==
|