@projectcor/people-microfront 1.0.2-2 → 1.0.2-20

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (81) hide show
  1. package/lib/App.js +1 -43
  2. package/lib/App.stories.js +25 -2
  3. package/lib/components/DeleteTeamModal/DeleteTeamModal.js +36 -24
  4. package/lib/components/DeleteTeamModal/DeleteTeamModal.styles.js +18 -6
  5. package/lib/components/DeleteTeamModal/DeleteTeamModal.types.js +1 -1
  6. package/lib/components/DeletedUserIcon/DeletedUserIcon.styles.js +2 -2
  7. package/lib/components/DisabledUserIcon/DisabledUserIcon.styles.js +2 -2
  8. package/lib/components/EmptyStateTeams/EmptyStateTeams.js +2 -2
  9. package/lib/components/EmptyUser/EmptyUser.js +3 -18
  10. package/lib/components/Filters/FilterChip/FilterChip.js +10 -5
  11. package/lib/components/HeaderTeams/HeaderTeams.js +2 -2
  12. package/lib/components/Illustration/EmptyFilter.js +67 -0
  13. package/lib/components/MenuOptions/MenuOptions.js +4 -18
  14. package/lib/components/ModalEditUserPosition/ModalEditUserPosition.js +17 -52
  15. package/lib/components/ModalEditUserPosition/ModalEditUserPosition.styles.js +36 -0
  16. package/lib/components/ModalEditUserPosition/UserEditPositionRow.js +13 -4
  17. package/lib/components/ModalOptionsWithSearch/ModalOptionsWithSearch.js +16 -3
  18. package/lib/components/Pagination/PaginationView.js +132 -0
  19. package/lib/components/Search/Search.js +4 -4
  20. package/lib/components/Table/Row/Row.js +65 -14
  21. package/lib/components/Table/Row/Row.styles.js +25 -9
  22. package/lib/components/Table/TeamRow/AddMemberModal/AddMemberModal.js +65 -0
  23. package/lib/components/Table/TeamRow/AddMemberModal/AddMemberModal.styles.js +38 -0
  24. package/lib/components/Table/TeamRow/AddMemberModal/index.js +2 -0
  25. package/lib/components/Table/TeamRow/AddUsers/AddUsers.js +182 -0
  26. package/lib/components/Table/TeamRow/AddUsers/AddUsers.styles.js +21 -0
  27. package/lib/components/Table/TeamRow/AddUsers/index.js +2 -0
  28. package/lib/components/Table/TeamRow/RemoveMemberModal/RemoveMemberModal.js +65 -0
  29. package/lib/components/Table/TeamRow/RemoveMemberModal/RemoveMemberModal.styles.js +38 -0
  30. package/lib/components/Table/TeamRow/RemoveMemberModal/index.js +2 -0
  31. package/lib/components/Table/TeamRow/TeamRow.js +74 -57
  32. package/lib/components/Table/TeamRow/UsersRow/UsersRow.js +191 -0
  33. package/lib/components/Table/TeamRow/UsersRow/UsersRow.styles.js +40 -0
  34. package/lib/components/Table/TeamRow/UsersRow/index.js +2 -0
  35. package/lib/components/TeamDetailsModal/MembersSelect.js +103 -28
  36. package/lib/components/TeamDetailsModal/TeamDetailsModal.js +73 -74
  37. package/lib/components/TeamDetailsModal/TeamDetailsModal.styles.js +14 -10
  38. package/lib/components/TeamDetailsModal/TeamDetailsModal.types.js +1 -1
  39. package/lib/components/TeamDetailsModal/index.js +1 -1
  40. package/lib/components/UserRow/UserRow.js +17 -8
  41. package/lib/components/UserRow/UserRow.styles.js +2 -2
  42. package/lib/container/Body/BodyContainerViewTeams.js +72 -98
  43. package/lib/container/Filters/FiltersContainer.js +42 -10
  44. package/lib/container/MainView/MainTeamsView.js +33 -0
  45. package/lib/container/MainView/MainUsersView.js +89 -69
  46. package/lib/container/MainView/MainView.js +21 -39
  47. package/lib/container/Pagination/PaginationContainer.js +10 -123
  48. package/lib/container/Pagination/PaginationTeamsContainer.js +32 -0
  49. package/lib/container/RouterComponent/RouterComponent.js +20 -31
  50. package/lib/container/RouterComponent/RouterComponent.styles.js +26 -0
  51. package/lib/container/TableContainer/TableContainer.js +18 -8
  52. package/lib/context/TeamsContext.js +5 -2
  53. package/lib/context/UsersContext.js +71 -22
  54. package/lib/hooks/useAssignUserToTeam.js +78 -0
  55. package/lib/hooks/useCreateTeams.js +67 -0
  56. package/lib/hooks/useDeleteTeam.js +67 -0
  57. package/lib/hooks/useGetTeams.js +8 -4
  58. package/lib/hooks/useGetTotalPositions.js +24 -0
  59. package/lib/hooks/useGetTotalTeams.js +24 -0
  60. package/lib/hooks/useGetUsers.js +23 -8
  61. package/lib/hooks/useGetUsersForFilter.js +1 -2
  62. package/lib/hooks/useResize.js +9 -4
  63. package/lib/hooks/useUnassignUserFromTeam.js +67 -0
  64. package/lib/hooks/useUpdateTeam.js +65 -0
  65. package/lib/lang/i18nextForWeb.js +2 -2
  66. package/lib/lang/translation/br.json +21 -4
  67. package/lib/lang/translation/en.json +58 -41
  68. package/lib/lang/translation/es.json +21 -4
  69. package/lib/lang/translation/fr.json +86 -69
  70. package/lib/mocks/mockedUser.js +7 -1
  71. package/lib/query/assignUserToTeam.js +5 -0
  72. package/lib/query/createTeam.js +5 -0
  73. package/lib/query/deleteTeam.js +5 -0
  74. package/lib/query/getTeams.js +2 -2
  75. package/lib/query/getTotalPositions.js +5 -0
  76. package/lib/query/getTotalTeams.js +5 -0
  77. package/lib/query/getUsers.js +2 -2
  78. package/lib/query/unassignUserFromTeam.js +5 -0
  79. package/lib/query/updateTeam.js +5 -0
  80. package/lib/types/global.d.js +1 -1
  81. package/package.json +2 -2
@@ -1,29 +1,53 @@
1
- import { AvatarUser } from '@projectcor/cor-commons/lib/components/avatar-user';
2
- import { Trash } from '@projectcor/icons/lib/components/Trash';
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 { SCRWrapper, SCRWrapperDynamicRow, SCRWIconUser, SCRWrapperWorkspace, SCRWrapperDeleteIcon, SCRWrapperName, SCRWrapperDescription, SCRRemainingUsers } from '../Row/Row.styles';
4
+ import { MenuOptions } from '../../MenuOptions/MenuOptions';
5
+ import { SCRWrapper, SCRWrapperDynamicRow, SCRWrapperWorkspace, SCRWrapperName, SCRWrapperDescription } from '../Row/Row.styles';
6
+ import { UsersRow } from './UsersRow';
7
+
8
+ /* eslint-disable react/require-default-props */
5
9
  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
10
  var TeamRowItem = function TeamRowItem(_ref) {
21
11
  var _team$workspace;
22
12
  var team = _ref.team,
23
13
  handleShowTeamDetails = _ref.handleShowTeamDetails,
24
- handleDeleteTeam = _ref.handleDeleteTeam;
25
- var remainingUsers = team.users.slice(MAX_USERS_DISPLAYED);
26
- var tooltipText = formatRemainingUsersTooltip(remainingUsers);
14
+ handleDeleteTeam = _ref.handleDeleteTeam,
15
+ handleEditTeam = _ref.handleEditTeam,
16
+ handleRemoveUser = _ref.handleRemoveUser,
17
+ handleAddUser = _ref.handleAddUser;
18
+ var nameRef = useRef(null);
19
+ var _useState = useState(false),
20
+ _useState2 = _slicedToArray(_useState, 2),
21
+ isTruncated = _useState2[0],
22
+ setIsTruncated = _useState2[1];
23
+ useEffect(function () {
24
+ var checkTruncation = function checkTruncation() {
25
+ if (nameRef.current) {
26
+ var _nameRef$current = nameRef.current,
27
+ scrollWidth = _nameRef$current.scrollWidth,
28
+ clientWidth = _nameRef$current.clientWidth;
29
+ setIsTruncated(scrollWidth > clientWidth);
30
+ }
31
+ };
32
+ checkTruncation();
33
+ window.addEventListener('resize', checkTruncation);
34
+ return function () {
35
+ return window.removeEventListener('resize', checkTruncation);
36
+ };
37
+ }, [team.name]);
38
+ var handleMenuSelectOption = function handleMenuSelectOption(option) {
39
+ if (option.id === 2) {
40
+ // Editar
41
+ handleEditTeam(team.id);
42
+ } else if (option.id === 3) {
43
+ // Eliminar
44
+ handleDeleteTeam(team.id);
45
+ }
46
+ };
47
+ var nameElement = /*#__PURE__*/_jsx("span", {
48
+ ref: nameRef,
49
+ children: team.name
50
+ });
27
51
  return /*#__PURE__*/_jsxs(SCRWrapper, {
28
52
  height: "48px",
29
53
  children: [/*#__PURE__*/_jsx(SCRWrapperName, {
@@ -31,32 +55,16 @@ var TeamRowItem = function TeamRowItem(_ref) {
31
55
  onClick: function onClick() {
32
56
  return handleShowTeamDetails(team.id);
33
57
  },
34
- children: /*#__PURE__*/_jsx("span", {
35
- children: team.name
58
+ children: isTruncated ? /*#__PURE__*/_jsx(Tooltip, {
59
+ title: team.name,
60
+ children: nameElement
61
+ }) : nameElement
62
+ }), /*#__PURE__*/_jsx(SCRWrapperDynamicRow, {
63
+ children: /*#__PURE__*/_jsx(UsersRow, {
64
+ team: team,
65
+ onRemoveUser: handleRemoveUser,
66
+ onAddUser: handleAddUser
36
67
  })
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
68
  }), !window.hasWorkspacesFeature && /*#__PURE__*/_jsx(SCRWrapperDescription, {
61
69
  width: "274px",
62
70
  onClick: function onClick() {
@@ -76,23 +84,29 @@ var TeamRowItem = function TeamRowItem(_ref) {
76
84
  })
77
85
  }), /*#__PURE__*/_jsx(SCRWrapperDynamicRow, {
78
86
  width: "40px",
79
- children: /*#__PURE__*/_jsx(SCRWrapperDeleteIcon, {
80
- onClick: function onClick() {
81
- return handleDeleteTeam(team.id);
82
- },
83
- children: /*#__PURE__*/_jsx(Trash, {
84
- width: "14px",
85
- height: "14px",
86
- color: "#C70505"
87
- })
87
+ children: !window.hasWorkspacesFeature && /*#__PURE__*/_jsx(MenuOptions, {
88
+ id: "team-menu-".concat(team.id),
89
+ handleSelectOption: handleMenuSelectOption,
90
+ options: [{
91
+ id: 2,
92
+ label: 'Editar'
93
+ }, {
94
+ id: 3,
95
+ label: 'Eliminar'
96
+ }]
88
97
  })
89
98
  })]
90
99
  });
91
100
  };
101
+
102
+ /* eslint-disable react/require-default-props */
92
103
  export var TeamRow = function TeamRow(_ref2) {
93
104
  var teams = _ref2.teams,
94
105
  handleShowTeamDetails = _ref2.handleShowTeamDetails,
95
- handleDeleteTeam = _ref2.handleDeleteTeam;
106
+ handleDeleteTeam = _ref2.handleDeleteTeam,
107
+ handleEditTeam = _ref2.handleEditTeam,
108
+ handleRemoveUser = _ref2.handleRemoveUser,
109
+ handleAddUser = _ref2.handleAddUser;
96
110
  return /*#__PURE__*/_jsx("div", {
97
111
  style: {
98
112
  display: 'flex',
@@ -103,9 +117,12 @@ export var TeamRow = function TeamRow(_ref2) {
103
117
  return /*#__PURE__*/_jsx(TeamRowItem, {
104
118
  team: team,
105
119
  handleShowTeamDetails: handleShowTeamDetails,
106
- handleDeleteTeam: handleDeleteTeam
120
+ handleDeleteTeam: handleDeleteTeam,
121
+ handleEditTeam: handleEditTeam,
122
+ handleRemoveUser: handleRemoveUser,
123
+ handleAddUser: handleAddUser
107
124
  }, team.id);
108
125
  })
109
126
  });
110
127
  };
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":[]}
128
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","useRef","useEffect","useState","Tooltip","MenuOptions","SCRWrapper","SCRWrapperDynamicRow","SCRWrapperWorkspace","SCRWrapperName","SCRWrapperDescription","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","style","display","flexDirection","border","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 { 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    <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          handleEditTeam={handleEditTeam}\n          handleRemoveUser={handleRemoveUser}\n          handleAddUser={handleAddUser}\n        />\n      ))}\n    </div>\n  )\n}\n"],"mappings":"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","ignoreList":[]}
@@ -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==