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

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 (56) hide show
  1. package/lib/App.stories.js +3 -2
  2. package/lib/Providers.js +6 -2
  3. package/lib/components/DeleteTeamModal/DeleteTeamModal.js +54 -0
  4. package/lib/components/DeleteTeamModal/DeleteTeamModal.styles.js +42 -0
  5. package/lib/components/DeleteTeamModal/DeleteTeamModal.types.js +2 -0
  6. package/lib/components/DeleteTeamModal/index.js +2 -0
  7. package/lib/components/EmptyStateTeams/EmptyStateTeams.js +194 -0
  8. package/lib/components/EmptyStateTeams/EmptyStateTeams.styles.js +6 -0
  9. package/lib/components/EmptyStateTeams/index.js +2 -0
  10. package/lib/components/ErrorTeams/ErrorTeams.js +118 -0
  11. package/lib/components/ErrorTeams/ErrorTeams.styles.js +6 -0
  12. package/lib/components/ErrorTeams/index.js +2 -0
  13. package/lib/components/Filters/SearchComponent/SearchComponent.styles.js +2 -2
  14. package/lib/components/HeaderTeams/HeaderTeams.js +28 -0
  15. package/lib/components/HeaderTeams/HeaderTeams.style.js +14 -0
  16. package/lib/components/HeaderTeams/index.js +2 -0
  17. package/lib/components/Layout/Layout.js +16 -0
  18. package/lib/components/Layout/Layout.styles.js +10 -0
  19. package/lib/components/Layout/index.js +3 -0
  20. package/lib/components/Loader/Loader.js +11 -0
  21. package/lib/components/Loader/Loader.styles.js +6 -0
  22. package/lib/components/Loader/index.js +2 -0
  23. package/lib/components/Pagination/Pagination.js +78 -0
  24. package/lib/components/Pagination/Pagination.styles.js +22 -0
  25. package/lib/components/Pagination/index.js +2 -0
  26. package/lib/components/ShowMore/ShowMore.js +12 -0
  27. package/lib/components/ShowMore/ShowMore.style.js +10 -0
  28. package/lib/components/ShowMore/index.js +2 -0
  29. package/lib/components/Table/Header/HeaderTable.js +23 -19
  30. package/lib/components/Table/Row/Row.styles.js +48 -12
  31. package/lib/components/Table/TeamRow/TeamRow.js +111 -0
  32. package/lib/components/Table/TeamRow/index.js +2 -0
  33. package/lib/components/TeamDetailsModal/MembersSelect.js +103 -0
  34. package/lib/components/TeamDetailsModal/TeamDetailsModal.js +276 -0
  35. package/lib/components/TeamDetailsModal/TeamDetailsModal.styles.js +121 -0
  36. package/lib/components/TeamDetailsModal/TeamDetailsModal.types.js +2 -0
  37. package/lib/components/TeamDetailsModal/index.js +2 -0
  38. package/lib/container/Body/BodyContainer.js +2 -6
  39. package/lib/container/Body/BodyContainerViewTeams.js +217 -0
  40. package/lib/container/Filters/FiltersTeamsContainer.js +156 -0
  41. package/lib/container/Filters/FiltersTeamsContainer.styles.js +6 -0
  42. package/lib/container/MainView/MainView.js +45 -5
  43. package/lib/container/RouterComponent/RouterComponent.js +15 -22
  44. package/lib/container/TableContainer/TableContainer.js +5 -12
  45. package/lib/context/TeamsContext.js +40 -0
  46. package/lib/context/UsersContext.js +16 -11
  47. package/lib/hooks/useFiltersTeams.js +36 -0
  48. package/lib/hooks/useGetTeams.js +23 -20
  49. package/lib/lang/i18nextForWeb.js +14 -11
  50. package/lib/lang/translation/br.json +49 -1
  51. package/lib/lang/translation/en.json +49 -1
  52. package/lib/lang/translation/es.json +49 -1
  53. package/lib/lang/translation/fr.json +49 -1
  54. package/lib/query/getTeams.js +2 -2
  55. package/lib/types/global.d.js +1 -1
  56. package/package.json +5 -3
@@ -0,0 +1,156 @@
1
+ import _defineProperty from "@babel/runtime/helpers/defineProperty";
2
+ import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
3
+ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
4
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
5
+ /* eslint-disable no-undef */
6
+ /* eslint-disable @typescript-eslint/no-explicit-any */
7
+ import { memo, useEffect, useState, useContext } from 'react';
8
+ import { useTranslation } from 'react-i18next';
9
+ import { Filters } from '@projectcor/cor-commons/lib/components/filters/Filters';
10
+ import { UserContext } from '@projectcor/cor-commons/lib/providers/UserProvider';
11
+ import { useFiltersTeams } from '../../hooks/useFiltersTeams';
12
+ import { SCWrapper } from './FiltersTeamsContainer.styles';
13
+ import { jsx as _jsx } from "react/jsx-runtime";
14
+ var EVENT_TO_DISPATCH = 'locationChangeTeams';
15
+ var FILTERS_CONFIG = {
16
+ workspace: {
17
+ icon: 'tasks',
18
+ type: 'text',
19
+ isMultiple: false,
20
+ hasSearch: false
21
+ },
22
+ users: {
23
+ icon: 'user',
24
+ type: 'avatars',
25
+ isMultiple: true,
26
+ hasSearch: true
27
+ },
28
+ team: {
29
+ icon: 'team',
30
+ type: 'text',
31
+ isMultiple: false,
32
+ hasSearch: false
33
+ }
34
+ };
35
+ // Función para mapear los filtros al formato que espera el componente Filters
36
+ var getMappedFilters = function getMappedFilters(workspaceOptions, t) {
37
+ return {
38
+ workspace: {
39
+ id: 'workspace',
40
+ label: t('teams.filters.workspace'),
41
+ type: 'multiSelect',
42
+ options: workspaceOptions.map(function (option) {
43
+ return {
44
+ id: option.id,
45
+ label: option.label
46
+ };
47
+ })
48
+ }
49
+ };
50
+ };
51
+
52
+ // Función para formatear los chips aplicados
53
+ var formatChips = function formatChips(appliedFilters, filters) {
54
+ var chips = [];
55
+ Object.keys(appliedFilters).forEach(function (key) {
56
+ var _appliedFilters$key;
57
+ if ((_appliedFilters$key = appliedFilters[key]) !== null && _appliedFilters$key !== void 0 && _appliedFilters$key.length && filters[key]) {
58
+ var filter = filters[key];
59
+ appliedFilters[key].forEach(function (valueId) {
60
+ var _filter$options;
61
+ var option = (_filter$options = filter.options) === null || _filter$options === void 0 ? void 0 : _filter$options.find(function (opt) {
62
+ return opt.id === valueId;
63
+ });
64
+ if (option) {
65
+ chips.push({
66
+ id: "".concat(key, "-").concat(valueId),
67
+ filterId: key,
68
+ label: option.label,
69
+ value: valueId
70
+ });
71
+ }
72
+ });
73
+ }
74
+ });
75
+ return chips;
76
+ };
77
+ export var FiltersTeamsContainer = /*#__PURE__*/memo(function (_ref) {
78
+ var handleGetTeams = _ref.handleGetTeams;
79
+ var _useTranslation = useTranslation('teams'),
80
+ t = _useTranslation.t;
81
+ var _useState = useState({}),
82
+ _useState2 = _slicedToArray(_useState, 2),
83
+ filters = _useState2[0],
84
+ setFilters = _useState2[1];
85
+ var _useState3 = useState({}),
86
+ _useState4 = _slicedToArray(_useState3, 2),
87
+ appliedFilters = _useState4[0],
88
+ setAppliedFilters = _useState4[1];
89
+ var userContext = useContext(UserContext);
90
+ var lang = (userContext === null || userContext === void 0 ? void 0 : userContext.lang) || 'es';
91
+ var _useFiltersTeams = useFiltersTeams(),
92
+ workspaceOptions = _useFiltersTeams.workspaceOptions,
93
+ filtersLoading = _useFiltersTeams.loading;
94
+ useEffect(function () {
95
+ if (workspaceOptions.length > 0) {
96
+ var mappedFilters = getMappedFilters(workspaceOptions, t);
97
+ setFilters(mappedFilters);
98
+ }
99
+ }, [workspaceOptions, t]);
100
+ var trackEvent = function trackEvent() {
101
+ // TODO: Implementar tracking de Amplitude si es necesario
102
+ };
103
+ var deleteFilter = function deleteFilter(filterId, valueId) {
104
+ setAppliedFilters(function (prev) {
105
+ var newFilters = _objectSpread({}, prev);
106
+ if (valueId) {
107
+ if (newFilters[filterId]) {
108
+ newFilters[filterId] = newFilters[filterId].filter(function (id) {
109
+ return id !== valueId;
110
+ });
111
+ if (newFilters[filterId].length === 0) {
112
+ delete newFilters[filterId];
113
+ }
114
+ }
115
+ } else {
116
+ delete newFilters[filterId];
117
+ }
118
+ return newFilters;
119
+ });
120
+ // Actualizar la búsqueda cuando se elimina un filtro
121
+ handleGetTeams(1);
122
+ };
123
+ useEffect(function () {
124
+ var handleLocationChange = function handleLocationChange() {
125
+ // Recargar filtros cuando cambie la ubicación
126
+ // Similar al ejemplo que usa getChips()
127
+ };
128
+ window.addEventListener(EVENT_TO_DISPATCH, handleLocationChange);
129
+ return function () {
130
+ window.removeEventListener(EVENT_TO_DISPATCH, handleLocationChange);
131
+ };
132
+ }, []);
133
+ var handleFilterChange = function handleFilterChange(filterId, values) {
134
+ setAppliedFilters(function (prev) {
135
+ return _objectSpread(_objectSpread({}, prev), {}, _defineProperty({}, filterId, values));
136
+ });
137
+ // Aquí puedes agregar lógica adicional para filtrar por workspace cuando esté disponible en la API
138
+ handleGetTeams(1);
139
+ };
140
+ return /*#__PURE__*/_jsx(SCWrapper, {
141
+ children: /*#__PURE__*/_jsx(Filters, {
142
+ appliedFilters: formatChips(appliedFilters, filters),
143
+ filters: filters,
144
+ trackEvent: trackEvent,
145
+ deleteFilter: deleteFilter,
146
+ loading: filtersLoading,
147
+ lang: lang,
148
+ config: FILTERS_CONFIG,
149
+ eventToDispatch: EVENT_TO_DISPATCH,
150
+ addButtonId: "filters-add-button-teams",
151
+ notTypeable: false,
152
+ onFilterChange: handleFilterChange
153
+ })
154
+ });
155
+ });
156
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["memo","useEffect","useState","useContext","useTranslation","Filters","UserContext","useFiltersTeams","SCWrapper","jsx","_jsx","EVENT_TO_DISPATCH","FILTERS_CONFIG","workspace","icon","type","isMultiple","hasSearch","users","team","getMappedFilters","workspaceOptions","t","id","label","options","map","option","formatChips","appliedFilters","filters","chips","Object","keys","forEach","key","_appliedFilters$key","length","filter","valueId","_filter$options","find","opt","push","concat","filterId","value","FiltersTeamsContainer","_ref","handleGetTeams","_useTranslation","_useState","_useState2","_slicedToArray","setFilters","_useState3","_useState4","setAppliedFilters","userContext","lang","_useFiltersTeams","filtersLoading","loading","mappedFilters","trackEvent","deleteFilter","prev","newFilters","_objectSpread","handleLocationChange","window","addEventListener","removeEventListener","handleFilterChange","values","_defineProperty","children","config","eventToDispatch","addButtonId","notTypeable","onFilterChange"],"sources":["../../../src/container/Filters/FiltersTeamsContainer.tsx"],"sourcesContent":["/* eslint-disable no-undef */\n/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { memo, useEffect, useState, useContext } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { Filters } from '@projectcor/cor-commons/lib/components/filters/Filters'\nimport { UserContext } from '@projectcor/cor-commons/lib/providers/UserProvider'\nimport { useFiltersTeams } from '../../hooks/useFiltersTeams'\nimport { SCWrapper } from './FiltersTeamsContainer.styles'\n\ninterface FiltersTeamsContainerProps {\n  handleGetTeams: (page: number, filter?: { name: string }) => void\n}\n\nconst EVENT_TO_DISPATCH = 'locationChangeTeams'\n\nconst FILTERS_CONFIG = {\n  workspace: {\n    icon: 'tasks',\n    type: 'text',\n    isMultiple: false,\n    hasSearch: false,\n  },\n  users: {\n    icon: 'user',\n    type: 'avatars',\n    isMultiple: true,\n    hasSearch: true,\n  },\n  team: {\n    icon: 'team',\n    type: 'text',\n    isMultiple: false,\n    hasSearch: false,\n  },\n}\n\ninterface FilterOption {\n  id: number\n  label: string\n}\n\ninterface FilterConfig {\n  id: string\n  label: string\n  type: string\n  options: FilterOption[]\n}\n\ninterface AppliedChip {\n  id: string\n  filterId: string\n  label: string\n  value: number\n}\n\n// Función para mapear los filtros al formato que espera el componente Filters\nconst getMappedFilters = (\n  workspaceOptions: FilterOption[],\n  t: (key: string) => string\n): { [key: string]: FilterConfig } => {\n  return {\n    workspace: {\n      id: 'workspace',\n      label: t('teams.filters.workspace'),\n      type: 'multiSelect',\n      options: workspaceOptions.map(option => ({\n        id: option.id,\n        label: option.label,\n      })),\n    },\n  }\n}\n\n// Función para formatear los chips aplicados\nconst formatChips = (\n  appliedFilters: { [key: string]: number[] },\n  filters: { [key: string]: FilterConfig }\n): AppliedChip[] => {\n  const chips: AppliedChip[] = []\n  Object.keys(appliedFilters).forEach(key => {\n    if (appliedFilters[key]?.length && filters[key]) {\n      const filter = filters[key]\n      appliedFilters[key].forEach((valueId: number) => {\n        const option = filter.options?.find((opt: FilterOption) => opt.id === valueId)\n        if (option) {\n          chips.push({\n            id: `${key}-${valueId}`,\n            filterId: key,\n            label: option.label,\n            value: valueId,\n          })\n        }\n      })\n    }\n  })\n  return chips\n}\n\nexport const FiltersTeamsContainer = memo(({ handleGetTeams }: FiltersTeamsContainerProps) => {\n  const { t } = useTranslation('teams')\n  const [filters, setFilters] = useState<{ [key: string]: FilterConfig }>({})\n  const [appliedFilters, setAppliedFilters] = useState<{ [key: string]: number[] }>({})\n  const userContext = useContext(UserContext) as { lang?: string; company_id?: number } | undefined\n  const lang = userContext?.lang || 'es'\n  const { workspaceOptions, loading: filtersLoading } = useFiltersTeams()\n\n  useEffect(() => {\n    if (workspaceOptions.length > 0) {\n      const mappedFilters = getMappedFilters(workspaceOptions, t)\n      setFilters(mappedFilters)\n    }\n  }, [workspaceOptions, t])\n\n  const trackEvent = () => {\n    // TODO: Implementar tracking de Amplitude si es necesario\n  }\n\n  const deleteFilter = (filterId: string, valueId?: number) => {\n    setAppliedFilters(prev => {\n      const newFilters = { ...prev }\n      if (valueId) {\n        if (newFilters[filterId]) {\n          newFilters[filterId] = newFilters[filterId].filter((id: number) => id !== valueId)\n          if (newFilters[filterId].length === 0) {\n            delete newFilters[filterId]\n          }\n        }\n      } else {\n        delete newFilters[filterId]\n      }\n      return newFilters\n    })\n    // Actualizar la búsqueda cuando se elimina un filtro\n    handleGetTeams(1)\n  }\n\n  useEffect(() => {\n    const handleLocationChange = () => {\n      // Recargar filtros cuando cambie la ubicación\n      // Similar al ejemplo que usa getChips()\n    }\n\n    window.addEventListener(EVENT_TO_DISPATCH, handleLocationChange)\n    return () => {\n      window.removeEventListener(EVENT_TO_DISPATCH, handleLocationChange)\n    }\n  }, [])\n\n  const handleFilterChange = (filterId: string, values: number[]) => {\n    setAppliedFilters(prev => ({\n      ...prev,\n      [filterId]: values,\n    }))\n    // Aquí puedes agregar lógica adicional para filtrar por workspace cuando esté disponible en la API\n    handleGetTeams(1)\n  }\n\n  return (\n    <SCWrapper>\n      <Filters\n        appliedFilters={formatChips(appliedFilters, filters)}\n        filters={filters}\n        trackEvent={trackEvent}\n        deleteFilter={deleteFilter}\n        loading={filtersLoading}\n        lang={lang}\n        config={FILTERS_CONFIG}\n        eventToDispatch={EVENT_TO_DISPATCH}\n        addButtonId=\"filters-add-button-teams\"\n        notTypeable={false}\n        onFilterChange={handleFilterChange}\n      />\n    </SCWrapper>\n  )\n})\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,6 @@
1
+ import styled from 'styled-components';
2
+ export var SCWrapper = styled.div.withConfig({
3
+ displayName: "FiltersTeamsContainerstyles__SCWrapper",
4
+ componentId: "sc-1r4lpbo-0"
5
+ })(["display:flex;gap:10px;align-items:center;flex-wrap:wrap;"]);
6
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJzdHlsZWQiLCJTQ1dyYXBwZXIiLCJkaXYiLCJ3aXRoQ29uZmlnIiwiZGlzcGxheU5hbWUiLCJjb21wb25lbnRJZCJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb250YWluZXIvRmlsdGVycy9GaWx0ZXJzVGVhbXNDb250YWluZXIuc3R5bGVzLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ3N0eWxlZC1jb21wb25lbnRzJ1xuXG5leHBvcnQgY29uc3QgU0NXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgZGlzcGxheTogZmxleDtcbiAgZ2FwOiAxMHB4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBmbGV4LXdyYXA6IHdyYXA7XG5gXG4iXSwibWFwcGluZ3MiOiJBQUFBLE9BQU9BLE1BQU0sTUFBTSxtQkFBbUI7QUFFdEMsT0FBTyxJQUFNQyxTQUFTLEdBQUdELE1BQU0sQ0FBQ0UsR0FBRyxDQUFBQyxVQUFBO0VBQUFDLFdBQUE7RUFBQUMsV0FBQTtBQUFBLGdFQUtsQyIsImlnbm9yZUxpc3QiOltdfQ==
@@ -5,6 +5,14 @@ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t =
5
5
  /* eslint-disable react/require-default-props */
6
6
  import { useEffect, memo, useState, Suspense, lazy, useCallback, useRef } from 'react';
7
7
  import { useTranslation } from 'react-i18next';
8
+ import { TableContainer } from '../TableContainer/TableContainer';
9
+ import { useTeams } from '../../context/TeamsContext';
10
+ import { LayoutSection } from '../../components/Layout';
11
+ import { HeaderTeams } from '../../components/HeaderTeams';
12
+ import { EmptyStateTeams } from '../../components/EmptyStateTeams';
13
+ import { useGetTeams } from '../../hooks/useGetTeams';
14
+ import { ErrorTeams } from '../../components/ErrorTeams';
15
+ import { ShowMore } from '../../components/ShowMore';
8
16
  import { LoaderComponent } from '../../components/Loading/LoadingComponent';
9
17
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
10
18
  var LazySnackbarComponent = /*#__PURE__*/lazy(function () {
@@ -21,14 +29,46 @@ var LazyMainUsersView = /*#__PURE__*/lazy(function () {
21
29
  };
22
30
  });
23
31
  });
24
- var MainTeamsView = /*#__PURE__*/memo(function () {
25
- return /*#__PURE__*/_jsx("div", {
26
- children: "MainTeamsView"
32
+ export var MainTeamsView = /*#__PURE__*/memo(function () {
33
+ var _useTeams = useTeams(),
34
+ teams = _useTeams.teams,
35
+ totalTeams = _useTeams.totalTeams,
36
+ currentPage = _useTeams.currentPage,
37
+ setCurrentPage = _useTeams.setCurrentPage;
38
+ var _useGetTeams = useGetTeams(),
39
+ loading = _useGetTeams.loading,
40
+ error = _useGetTeams.error;
41
+ var handleCreateTeam = function handleCreateTeam() {
42
+ var event = new CustomEvent('createTeam');
43
+ window.dispatchEvent(event);
44
+ };
45
+ var handleClickShowMore = function handleClickShowMore() {
46
+ setCurrentPage(currentPage + 1);
47
+ };
48
+ return /*#__PURE__*/_jsxs(LayoutSection, {
49
+ children: [/*#__PURE__*/_jsx(HeaderTeams, {
50
+ showCreateButton: teams.length > 0,
51
+ clickCreateTeam: handleCreateTeam
52
+ }), error && /*#__PURE__*/_jsx(ErrorTeams, {}), teams.length > 0 ? /*#__PURE__*/_jsx(TableContainer, {
53
+ loading: loading
54
+ }) : /*#__PURE__*/_jsx(EmptyStateTeams, {
55
+ clickCreateTeam: handleCreateTeam
56
+ }), currentPage < totalTeams && /*#__PURE__*/_jsx(ShowMore, {
57
+ clickShowMore: handleClickShowMore
58
+ })]
27
59
  });
28
60
  });
29
61
  export var MainPositionsView = /*#__PURE__*/memo(function () {
62
+ useEffect(function () {
63
+ if (typeof window.showUserTypeAbm === 'function') {
64
+ window.showUserTypeAbm();
65
+ }
66
+ return function () {
67
+ if (typeof window.unMountUserTypeAbm === 'function') window.unMountUserTypeAbm();
68
+ };
69
+ }, []);
30
70
  return /*#__PURE__*/_jsx("div", {
31
- children: "MainPositionsView"
71
+ id: "container_project_team_select"
32
72
  });
33
73
  });
34
74
  export var MainLeavesView = /*#__PURE__*/memo(function () {
@@ -114,4 +154,4 @@ export var MainView = /*#__PURE__*/memo(function (_ref) {
114
154
  }))]
115
155
  });
116
156
  });
117
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["useEffect","memo","useState","Suspense","lazy","useCallback","useRef","useTranslation","LoaderComponent","jsx","_jsx","jsxs","_jsxs","LazySnackbarComponent","then","module","SnackbarComponent","LazyMainUsersView","MainUsersView","MainTeamsView","children","MainPositionsView","MainLeavesView","ViewByType","users","teams","positions","leaves","MainView","_ref","_ref$view","view","_useTranslation","t","View","_useState","severity","show","autoHideDuration","message","hideBackdrop","_useState2","_slicedToArray","snackbarProps","setSnabarProps","messageByTypeRef","updateUserPositions","unblockUser","deleteUser","errorUpdateUserPositions","errorUnblockUser","errorDeleteUser","current","handleSetSnackbarProps","event","_messageByTypeRef$cur","_event$detail","detail","typeMessage","prev","_objectSpread","handleCloseSnackbar","listener","e","window","addEventListener","removeEventListener","fallback","onClose"],"sources":["../../../src/container/MainView/MainView.tsx"],"sourcesContent":["/* eslint-disable react/require-default-props */\nimport { useEffect, memo, useState, Suspense, lazy, useCallback, useRef } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { ViewType } from '../../types/userType'\nimport { LoaderComponent } from '../../components/Loading/LoadingComponent'\n\nconst LazySnackbarComponent = lazy(() =>\n  import('../../components/Snackbar/Snackbar').then(module => ({ default: module.SnackbarComponent }))\n)\n\nconst LazyMainUsersView = lazy(() => import('./MainUsersView').then(module => ({ default: module.MainUsersView })))\n\nconst MainTeamsView = memo(() => {\n  return <div>MainTeamsView</div>\n})\n\nexport const MainPositionsView = memo(() => {\n  return <div>MainPositionsView</div>\n})\n\nexport const MainLeavesView = memo(() => {\n  return <div>MainLeavesView</div>\n})\n\n// TODO: Convertir los componentes de las vistas (MainUsersView, MainTeamsView, MainPositionsView, MainLeavesView) a cargas lazy utilizando React.lazy y Suspense para mejorar el performance\nconst ViewByType = {\n  users: LazyMainUsersView,\n  teams: MainTeamsView,\n  positions: MainPositionsView,\n  leaves: MainLeavesView,\n}\n\nexport const MainView = memo(({ view = 'users' }: { view?: ViewType }) => {\n  const { t } = useTranslation('people')\n  const View = ViewByType[view as ViewType]\n  const [snackbarProps, setSnabarProps] = useState({\n    severity: 'error',\n    show: false,\n    autoHideDuration: 3000,\n    message: '',\n    hideBackdrop: false,\n  })\n\n  const messageByTypeRef = useRef({\n    updateUserPositions: '',\n    unblockUser: '',\n    deleteUser: '',\n    errorUpdateUserPositions: '',\n    errorUnblockUser: '',\n    errorDeleteUser: '',\n  } as Record<string, string>)\n  messageByTypeRef.current = {\n    updateUserPositions: t('snackbar.updateUserPositions'),\n    unblockUser: t('snackbar.unblockUser'),\n    deleteUser: t('snackbar.deleteUser'),\n    errorUpdateUserPositions: t('snackbar.errorUpdateUserPositions'),\n    errorUnblockUser: t('snackbar.errorUnblockUser'),\n    errorDeleteUser: t('snackbar.errorDeleteUser'),\n  }\n\n  const handleSetSnackbarProps = useCallback(\n    (event: CustomEvent<{ typeMessage: string; severity: string; show: boolean }>) => {\n      const { typeMessage, severity, show } = event.detail\n      const message = messageByTypeRef.current[typeMessage] ?? ''\n      setSnabarProps(prev => ({\n        ...prev,\n        message,\n        severity,\n        show,\n      }))\n    },\n    []\n  )\n\n  const handleCloseSnackbar = useCallback(() => {\n    setSnabarProps(prev => ({ ...prev, show: false }))\n  }, [])\n\n  useEffect(() => {\n    const listener = (e: Event) =>\n      handleSetSnackbarProps(e as CustomEvent<{ typeMessage: string; severity: string; show: boolean }>)\n    window.addEventListener('snackbar', listener)\n    return () => window.removeEventListener('snackbar', listener)\n  }, [handleSetSnackbarProps])\n\n  return (\n    <Suspense fallback={<LoaderComponent />}>\n      <View />\n      {snackbarProps.show && <LazySnackbarComponent {...snackbarProps} onClose={handleCloseSnackbar} />}\n    </Suspense>\n  )\n})\n"],"mappings":"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","ignoreList":[]}
157
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["useEffect","memo","useState","Suspense","lazy","useCallback","useRef","useTranslation","TableContainer","useTeams","LayoutSection","HeaderTeams","EmptyStateTeams","useGetTeams","ErrorTeams","ShowMore","LoaderComponent","jsx","_jsx","jsxs","_jsxs","LazySnackbarComponent","then","module","SnackbarComponent","LazyMainUsersView","MainUsersView","MainTeamsView","_useTeams","teams","totalTeams","currentPage","setCurrentPage","_useGetTeams","loading","error","handleCreateTeam","event","CustomEvent","window","dispatchEvent","handleClickShowMore","children","showCreateButton","length","clickCreateTeam","clickShowMore","MainPositionsView","showUserTypeAbm","unMountUserTypeAbm","id","MainLeavesView","ViewByType","users","positions","leaves","MainView","_ref","_ref$view","view","_useTranslation","t","View","_useState","severity","show","autoHideDuration","message","hideBackdrop","_useState2","_slicedToArray","snackbarProps","setSnabarProps","messageByTypeRef","updateUserPositions","unblockUser","deleteUser","errorUpdateUserPositions","errorUnblockUser","errorDeleteUser","current","handleSetSnackbarProps","_messageByTypeRef$cur","_event$detail","detail","typeMessage","prev","_objectSpread","handleCloseSnackbar","listener","e","addEventListener","removeEventListener","fallback","onClose"],"sources":["../../../src/container/MainView/MainView.tsx"],"sourcesContent":["/* eslint-disable react/require-default-props */\nimport { useEffect, memo, useState, Suspense, lazy, useCallback, useRef } from 'react'\nimport { useTranslation } from 'react-i18next'\nimport { ViewType } from '../../types/userType'\nimport { FiltersContainer } from '../Filters/FiltersContainer'\nimport { TableContainer } from '../TableContainer/TableContainer'\nimport { useUsers } from '../../context/UsersContext'\nimport { useTeams } from '../../context/TeamsContext'\nimport { LayoutSection } from '../../components/Layout'\nimport { HeaderTeams } from '../../components/HeaderTeams'\nimport { EmptyStateTeams } from '../../components/EmptyStateTeams'\nimport { useGetTeams } from '../../hooks/useGetTeams'\nimport { LoaderTeams } from '../../components/Loader'\nimport { ErrorTeams } from '../../components/ErrorTeams'\nimport { ShowMore } from '../../components/ShowMore'\nimport { LoaderComponent } from '../../components/Loading/LoadingComponent'\n\nconst LazySnackbarComponent = lazy(() =>\n  import('../../components/Snackbar/Snackbar').then(module => ({ default: module.SnackbarComponent }))\n)\n\nconst LazyMainUsersView = lazy(() => import('./MainUsersView').then(module => ({ default: module.MainUsersView })))\n\nexport const MainTeamsView = memo(() => {\n  const { teams, totalTeams, currentPage, setCurrentPage } = useTeams()\n  const { loading, error } = useGetTeams()\n\n  const handleCreateTeam = () => {\n    const event = new CustomEvent('createTeam')\n    window.dispatchEvent(event)\n  }\n\n  const handleClickShowMore = () => {\n    setCurrentPage(currentPage + 1)\n  }\n\n  return (\n    <LayoutSection>\n      <HeaderTeams showCreateButton={teams.length > 0} clickCreateTeam={handleCreateTeam} />\n      {error && <ErrorTeams />}\n      {teams.length > 0 ? <TableContainer loading={loading} /> : <EmptyStateTeams clickCreateTeam={handleCreateTeam} />}\n      {currentPage < totalTeams && <ShowMore clickShowMore={handleClickShowMore} />}\n    </LayoutSection>\n  )\n})\n\nexport const MainPositionsView = memo(() => {\n  useEffect(() => {\n    if (typeof window.showUserTypeAbm === 'function') {\n      window.showUserTypeAbm()\n    }\n\n    return () => {\n      if (typeof window.unMountUserTypeAbm === 'function') window.unMountUserTypeAbm()\n    }\n  }, [])\n  return <div id=\"container_project_team_select\" />\n})\n\nexport const MainLeavesView = memo(() => {\n  return <div>MainLeavesView</div>\n})\n\n// TODO: Convertir los componentes de las vistas (MainUsersView, MainTeamsView, MainPositionsView, MainLeavesView) a cargas lazy utilizando React.lazy y Suspense para mejorar el performance\nconst ViewByType = {\n  users: LazyMainUsersView,\n  teams: MainTeamsView,\n  positions: MainPositionsView,\n  leaves: MainLeavesView,\n}\n\nexport const MainView = memo(({ view = 'users' }: { view?: ViewType }) => {\n  const { t } = useTranslation('people')\n  const View = ViewByType[view as ViewType]\n  const [snackbarProps, setSnabarProps] = useState({\n    severity: 'error',\n    show: false,\n    autoHideDuration: 3000,\n    message: '',\n    hideBackdrop: false,\n  })\n\n  const messageByTypeRef = useRef({\n    updateUserPositions: '',\n    unblockUser: '',\n    deleteUser: '',\n    errorUpdateUserPositions: '',\n    errorUnblockUser: '',\n    errorDeleteUser: '',\n  } as Record<string, string>)\n  messageByTypeRef.current = {\n    updateUserPositions: t('snackbar.updateUserPositions'),\n    unblockUser: t('snackbar.unblockUser'),\n    deleteUser: t('snackbar.deleteUser'),\n    errorUpdateUserPositions: t('snackbar.errorUpdateUserPositions'),\n    errorUnblockUser: t('snackbar.errorUnblockUser'),\n    errorDeleteUser: t('snackbar.errorDeleteUser'),\n  }\n\n  const handleSetSnackbarProps = useCallback(\n    (event: CustomEvent<{ typeMessage: string; severity: string; show: boolean }>) => {\n      const { typeMessage, severity, show } = event.detail\n      const message = messageByTypeRef.current[typeMessage] ?? ''\n      setSnabarProps(prev => ({\n        ...prev,\n        message,\n        severity,\n        show,\n      }))\n    },\n    []\n  )\n\n  const handleCloseSnackbar = useCallback(() => {\n    setSnabarProps(prev => ({ ...prev, show: false }))\n  }, [])\n\n  useEffect(() => {\n    const listener = (e: Event) =>\n      handleSetSnackbarProps(e as CustomEvent<{ typeMessage: string; severity: string; show: boolean }>)\n    window.addEventListener('snackbar', listener)\n    return () => window.removeEventListener('snackbar', listener)\n  }, [handleSetSnackbarProps])\n\n  return (\n    <Suspense fallback={<LoaderComponent />}>\n      <View />\n      {snackbarProps.show && <LazySnackbarComponent {...snackbarProps} onClose={handleCloseSnackbar} />}\n    </Suspense>\n  )\n})\n"],"mappings":"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","ignoreList":[]}
@@ -1,4 +1,3 @@
1
- import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
2
1
  import _defineProperty from "@babel/runtime/helpers/defineProperty";
3
2
  function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
4
3
  function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
@@ -6,13 +5,12 @@ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t =
6
5
  /* eslint-disable jsx-a11y/click-events-have-key-events */
7
6
  /* eslint-disable jsx-a11y/no-static-element-interactions */
8
7
  /* eslint-disable react/button-has-type */
9
- import { useState } from 'react';
8
+
10
9
  import { UserCircle } from '@projectcor/icons/lib/components/UserCircle';
11
10
  import { UserTeam } from '@projectcor/icons/lib/components/UserTeam';
12
11
  import { Wired } from '@projectcor/icons/lib/components/Wired';
13
- import { UserClock } from '@projectcor/icons/lib/components/UserClock';
14
12
  import { MainView } from '../MainView/MainView';
15
- import { useUsers, useUsersCount } from '../../context/UsersContext';
13
+ import { useUsers, useUsersCount, useUsersView } from '../../context/UsersContext';
16
14
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
17
15
  var VIEW_ITEMS = [{
18
16
  type: 'users',
@@ -41,16 +39,14 @@ var VIEW_ITEMS = [{
41
39
  }),
42
40
  title: 'Posiciones',
43
41
  count: 10
44
- }, {
45
- type: 'leaves',
46
- icon: /*#__PURE__*/_jsx(UserClock, {
47
- width: "20px",
48
- height: "20px",
49
- color: "inherit"
50
- }),
51
- title: 'Availability',
52
- count: 10
53
- }];
42
+ }
43
+ // {
44
+ // type: 'leaves',
45
+ // icon: <UserClock width="20px" height="20px" color="inherit" />,
46
+ // title: 'Availability',
47
+ // count: 10,
48
+ // },
49
+ ];
54
50
  var ViewItem = function ViewItem(_ref) {
55
51
  var icon = _ref.icon,
56
52
  title = _ref.title,
@@ -110,13 +106,10 @@ var ViewItems = function ViewItems(_ref2) {
110
106
  })
111
107
  });
112
108
  };
113
- export var RouterComponent = function RouterComponent(_ref3) {
114
- var _ref3$peopleView = _ref3.peopleView,
115
- peopleView = _ref3$peopleView === void 0 ? 'users' : _ref3$peopleView;
116
- var _useState = useState(peopleView),
117
- _useState2 = _slicedToArray(_useState, 2),
118
- view = _useState2[0],
119
- setView = _useState2[1];
109
+ export var RouterComponent = function RouterComponent() {
110
+ var _useUsersView = useUsersView(),
111
+ view = _useUsersView.view,
112
+ setView = _useUsersView.setView;
120
113
  var handleViewChange = function handleViewChange(type) {
121
114
  if (view === type) return;
122
115
  setView(type);
@@ -130,4 +123,4 @@ export var RouterComponent = function RouterComponent(_ref3) {
130
123
  })]
131
124
  });
132
125
  };
133
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["useState","UserCircle","UserTeam","Wired","UserClock","MainView","useUsers","useUsersCount","jsx","_jsx","jsxs","_jsxs","VIEW_ITEMS","type","icon","width","height","color","title","count","ViewItem","_ref","isSelected","handleViewChange","style","display","alignItems","gap","justifyContent","cursor","padding","borderBottom","onClick","children","ViewItems","_ref2","viewSelected","_useUsersCount","totalUsers","_useUsers","userInfoContext","userInfo","totalItemsByView","users","teams","positions","leaves","map","item","_userInfoContext$plan","includes","role_id","plan","features","_objectSpread","RouterComponent","_ref3","_ref3$peopleView","peopleView","_useState","_useState2","_slicedToArray","view","setView"],"sources":["../../../src/container/RouterComponent/RouterComponent.tsx"],"sourcesContent":["/* eslint-disable react/require-default-props */\n/* eslint-disable jsx-a11y/click-events-have-key-events */\n/* eslint-disable jsx-a11y/no-static-element-interactions */\n/* eslint-disable react/button-has-type */\nimport { ReactElement, useState } from 'react'\nimport { UserCircle } from '@projectcor/icons/lib/components/UserCircle'\nimport { UserTeam } from '@projectcor/icons/lib/components/UserTeam'\nimport { Wired } from '@projectcor/icons/lib/components/Wired'\nimport { UserClock } from '@projectcor/icons/lib/components/UserClock'\nimport { ViewType } from '../../types/userType'\nimport { MainView } from '../MainView/MainView'\nimport { useUsers, useUsersCount } from '../../context/UsersContext'\n\nconst VIEW_ITEMS: { type: ViewType; icon: ReactElement; title: string; count: number }[] = [\n  {\n    type: 'users',\n    icon: <UserCircle width=\"20px\" height=\"20px\" color=\"inherit\" />,\n    title: 'Usuarios',\n    count: 151,\n  },\n  {\n    type: 'teams',\n    icon: <UserTeam width=\"20px\" height=\"20px\" color=\"inherit\" />,\n    title: 'Equipos',\n    count: 10,\n  },\n  {\n    type: 'positions',\n    icon: <Wired width=\"20px\" height=\"20px\" color=\"inherit\" />,\n    title: 'Posiciones',\n    count: 10,\n  },\n  {\n    type: 'leaves',\n    icon: <UserClock width=\"20px\" height=\"20px\" color=\"inherit\" />,\n    title: 'Availability',\n    count: 10,\n  },\n]\n\nconst ViewItem = ({\n  icon,\n  title,\n  count,\n  isSelected,\n  handleViewChange,\n  type,\n}: {\n  icon: ReactElement\n  title: string\n  count: number\n  isSelected: boolean\n  handleViewChange: (view: ViewType) => void\n  type: ViewType\n}) => {\n  return (\n    <div\n      style={{\n        display: 'flex',\n        alignItems: 'center',\n        gap: '8px',\n        justifyContent: 'center',\n        cursor: isSelected ? 'default' : 'pointer',\n        padding: '8px',\n        borderBottom: isSelected ? '2px solid rgba(0, 136, 204, 1)' : 'none',\n        color: isSelected ? 'rgba(0, 0, 0, 1)' : 'rgba(153, 153, 153, 1)',\n      }}\n      onClick={() => handleViewChange(type)}\n    >\n      {icon}\n      {title} ({count})\n    </div>\n  )\n}\n\nconst ViewItems = ({\n  handleViewChange,\n  viewSelected,\n}: {\n  handleViewChange: (view: ViewType) => void\n  viewSelected: ViewType\n}) => {\n  const { totalUsers } = useUsersCount()\n  const { userInfo: userInfoContext } = useUsers()\n\n  const totalItemsByView = {\n    users: totalUsers,\n    teams: 0,\n    positions: 0,\n    leaves: 0,\n  }\n\n  return (\n    <div\n      style={{ display: 'flex', gap: '8px', alignItems: 'center', borderBottom: '1px solid rgba(224, 224, 224, 1)' }}\n    >\n      {VIEW_ITEMS.map(item => {\n        if (\n          // eslint-disable-next-line prettier/prettier\n          item.type === 'positions' &&\n          ![1, 2].includes(userInfoContext?.role_id) &&\n          !userInfoContext?.plan?.features?.includes('USERS_POSITIONS')\n        ) {\n          return null\n        }\n        return (\n          <ViewItem\n            key={item.type}\n            {...item}\n            isSelected={viewSelected === item.type}\n            handleViewChange={handleViewChange}\n            count={totalItemsByView[item.type]}\n          />\n        )\n      })}\n    </div>\n  )\n}\n\nexport const RouterComponent = ({ peopleView = 'users' }: { peopleView?: ViewType }) => {\n  const [view, setView] = useState<ViewType>(peopleView)\n\n  const handleViewChange = (type: ViewType) => {\n    if (view === type) return\n    setView(type)\n  }\n\n  return (\n    <div>\n      <ViewItems handleViewChange={handleViewChange} viewSelected={view} />\n      <MainView view={view} />\n    </div>\n  )\n}\n"],"mappings":"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","ignoreList":[]}
126
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["UserCircle","UserTeam","Wired","MainView","useUsers","useUsersCount","useUsersView","jsx","_jsx","jsxs","_jsxs","VIEW_ITEMS","type","icon","width","height","color","title","count","ViewItem","_ref","isSelected","handleViewChange","style","display","alignItems","gap","justifyContent","cursor","padding","borderBottom","onClick","children","ViewItems","_ref2","viewSelected","_useUsersCount","totalUsers","_useUsers","userInfoContext","userInfo","totalItemsByView","users","teams","positions","leaves","map","item","_userInfoContext$plan","includes","role_id","plan","features","_objectSpread","RouterComponent","_useUsersView","view","setView"],"sources":["../../../src/container/RouterComponent/RouterComponent.tsx"],"sourcesContent":["/* eslint-disable react/require-default-props */\n/* eslint-disable jsx-a11y/click-events-have-key-events */\n/* eslint-disable jsx-a11y/no-static-element-interactions */\n/* eslint-disable react/button-has-type */\nimport { ReactElement } from 'react'\nimport { UserCircle } from '@projectcor/icons/lib/components/UserCircle'\nimport { UserTeam } from '@projectcor/icons/lib/components/UserTeam'\nimport { Wired } from '@projectcor/icons/lib/components/Wired'\nimport { UserClock } from '@projectcor/icons/lib/components/UserClock'\nimport { ViewType } from '../../types/userType'\nimport { MainView } from '../MainView/MainView'\nimport { useUsers, useUsersCount, useUsersView } from '../../context/UsersContext'\n\nconst VIEW_ITEMS: { type: ViewType; icon: ReactElement; title: string; count: number }[] = [\n  {\n    type: 'users',\n    icon: <UserCircle width=\"20px\" height=\"20px\" color=\"inherit\" />,\n    title: 'Usuarios',\n    count: 151,\n  },\n  {\n    type: 'teams',\n    icon: <UserTeam width=\"20px\" height=\"20px\" color=\"inherit\" />,\n    title: 'Equipos',\n    count: 10,\n  },\n  {\n    type: 'positions',\n    icon: <Wired width=\"20px\" height=\"20px\" color=\"inherit\" />,\n    title: 'Posiciones',\n    count: 10,\n  },\n  // {\n  //   type: 'leaves',\n  //   icon: <UserClock width=\"20px\" height=\"20px\" color=\"inherit\" />,\n  //   title: 'Availability',\n  //   count: 10,\n  // },\n]\n\nconst ViewItem = ({\n  icon,\n  title,\n  count,\n  isSelected,\n  handleViewChange,\n  type,\n}: {\n  icon: ReactElement\n  title: string\n  count: number\n  isSelected: boolean\n  handleViewChange: (view: ViewType) => void\n  type: ViewType\n}) => {\n  return (\n    <div\n      style={{\n        display: 'flex',\n        alignItems: 'center',\n        gap: '8px',\n        justifyContent: 'center',\n        cursor: isSelected ? 'default' : 'pointer',\n        padding: '8px',\n        borderBottom: isSelected ? '2px solid rgba(0, 136, 204, 1)' : 'none',\n        color: isSelected ? 'rgba(0, 0, 0, 1)' : 'rgba(153, 153, 153, 1)',\n      }}\n      onClick={() => handleViewChange(type)}\n    >\n      {icon}\n      {title} ({count})\n    </div>\n  )\n}\n\nconst ViewItems = ({\n  handleViewChange,\n  viewSelected,\n}: {\n  handleViewChange: (view: ViewType) => void\n  viewSelected: ViewType\n}) => {\n  const { totalUsers } = useUsersCount()\n  const { userInfo: userInfoContext } = useUsers()\n\n  const totalItemsByView = {\n    users: totalUsers,\n    teams: 0,\n    positions: 0,\n    leaves: 0,\n  }\n\n  return (\n    <div\n      style={{ display: 'flex', gap: '8px', alignItems: 'center', borderBottom: '1px solid rgba(224, 224, 224, 1)' }}\n    >\n      {VIEW_ITEMS.map(item => {\n        if (\n          // eslint-disable-next-line prettier/prettier\n          item.type === 'positions' &&\n          ![1, 2].includes(userInfoContext?.role_id) &&\n          !userInfoContext?.plan?.features?.includes('USERS_POSITIONS')\n        ) {\n          return null\n        }\n        return (\n          <ViewItem\n            key={item.type}\n            {...item}\n            isSelected={viewSelected === item.type}\n            handleViewChange={handleViewChange}\n            count={totalItemsByView[item.type]}\n          />\n        )\n      })}\n    </div>\n  )\n}\n\nexport const RouterComponent = () => {\n  const { view, setView } = useUsersView()\n\n  const handleViewChange = (type: ViewType) => {\n    if (view === type) return\n    setView(type)\n  }\n\n  return (\n    <div>\n      <ViewItems handleViewChange={handleViewChange} viewSelected={view} />\n      <MainView view={view} />\n    </div>\n  )\n}\n"],"mappings":"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","ignoreList":[]}
@@ -5,11 +5,13 @@ import { useTranslation } from 'react-i18next';
5
5
  import { HeaderTable } from '../../components/Table/Header/HeaderTable';
6
6
  import { BodyContainer } from '../Body/BodyContainer';
7
7
  import { PaginationContainer } from '../Pagination/PaginationContainer';
8
+ import { LayoutTable } from '../../components/Layout';
8
9
  import { ErrorComponent } from '../../components/ErrorComponent';
9
10
  import { LoaderComponent } from '../../components/Loading/LoadingComponent';
10
11
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
11
12
  export var TableContainer = /*#__PURE__*/memo(function (_ref) {
12
- var handleChangePage = _ref.handleChangePage,
13
+ var _ref$handleChangePage = _ref.handleChangePage,
14
+ handleChangePage = _ref$handleChangePage === void 0 ? function () {} : _ref$handleChangePage,
13
15
  _ref$loading = _ref.loading,
14
16
  loading = _ref$loading === void 0 ? false : _ref$loading,
15
17
  _ref$error = _ref.error,
@@ -19,16 +21,7 @@ export var TableContainer = /*#__PURE__*/memo(function (_ref) {
19
21
  var _useTranslation = useTranslation('people'),
20
22
  t = _useTranslation.t;
21
23
  return /*#__PURE__*/_jsxs("div", {
22
- style: {
23
- width: '100%',
24
- height: '100%'
25
- },
26
- children: [/*#__PURE__*/_jsxs("div", {
27
- style: {
28
- width: '100%',
29
- height: '100%',
30
- borderRadius: '4px'
31
- },
24
+ children: [/*#__PURE__*/_jsxs(LayoutTable, {
32
25
  children: [/*#__PURE__*/_jsx(HeaderTable, {}), loading ? /*#__PURE__*/_jsx(LoaderComponent, {}) : error ? /*#__PURE__*/_jsx(ErrorComponent, {
33
26
  title: t('error.errorMessageTitle'),
34
27
  subtitle: t('error.errorMessageBody')
@@ -38,4 +31,4 @@ export var TableContainer = /*#__PURE__*/memo(function (_ref) {
38
31
  })]
39
32
  });
40
33
  });
41
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJtZW1vIiwidXNlVHJhbnNsYXRpb24iLCJIZWFkZXJUYWJsZSIsIkJvZHlDb250YWluZXIiLCJQYWdpbmF0aW9uQ29udGFpbmVyIiwiRXJyb3JDb21wb25lbnQiLCJMb2FkZXJDb21wb25lbnQiLCJqc3giLCJfanN4IiwianN4cyIsIl9qc3hzIiwiVGFibGVDb250YWluZXIiLCJfcmVmIiwiaGFuZGxlQ2hhbmdlUGFnZSIsIl9yZWYkbG9hZGluZyIsImxvYWRpbmciLCJfcmVmJGVycm9yIiwiZXJyb3IiLCJfcmVmJGhhc1VzZXJzIiwiaGFzVXNlcnMiLCJfdXNlVHJhbnNsYXRpb24iLCJ0Iiwic3R5bGUiLCJ3aWR0aCIsImhlaWdodCIsImNoaWxkcmVuIiwiYm9yZGVyUmFkaXVzIiwidGl0bGUiLCJzdWJ0aXRsZSJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb250YWluZXIvVGFibGVDb250YWluZXIvVGFibGVDb250YWluZXIudHN4Il0sInNvdXJjZXNDb250ZW50IjpbIi8qIGVzbGludC1kaXNhYmxlIHJlYWN0L3JlcXVpcmUtZGVmYXVsdC1wcm9wcyAqL1xuLyogZXNsaW50LWRpc2FibGUgbm8tbmVzdGVkLXRlcm5hcnkgKi9cbmltcG9ydCB7IG1lbW8gfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IHVzZVRyYW5zbGF0aW9uIH0gZnJvbSAncmVhY3QtaTE4bmV4dCdcbmltcG9ydCB7IEhlYWRlclRhYmxlIH0gZnJvbSAnLi4vLi4vY29tcG9uZW50cy9UYWJsZS9IZWFkZXIvSGVhZGVyVGFibGUnXG5pbXBvcnQgeyBCb2R5Q29udGFpbmVyIH0gZnJvbSAnLi4vQm9keS9Cb2R5Q29udGFpbmVyJ1xuaW1wb3J0IHsgUGFnaW5hdGlvbkNvbnRhaW5lciB9IGZyb20gJy4uL1BhZ2luYXRpb24vUGFnaW5hdGlvbkNvbnRhaW5lcidcbmltcG9ydCB7IEVycm9yQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vY29tcG9uZW50cy9FcnJvckNvbXBvbmVudCdcbmltcG9ydCB7IExvYWRlckNvbXBvbmVudCB9IGZyb20gJy4uLy4uL2NvbXBvbmVudHMvTG9hZGluZy9Mb2FkaW5nQ29tcG9uZW50J1xuXG5leHBvcnQgY29uc3QgVGFibGVDb250YWluZXIgPSBtZW1vKFxuICAoe1xuICAgIGhhbmRsZUNoYW5nZVBhZ2UsXG4gICAgbG9hZGluZyA9IGZhbHNlLFxuICAgIGVycm9yID0gZmFsc2UsXG4gICAgaGFzVXNlcnMgPSBmYWxzZSxcbiAgfToge1xuICAgIGhhbmRsZUNoYW5nZVBhZ2U6IChwYWdlOiBudW1iZXIpID0+IHZvaWRcbiAgICBsb2FkaW5nPzogYm9vbGVhblxuICAgIGVycm9yPzogYm9vbGVhblxuICAgIGhhc1VzZXJzPzogYm9vbGVhblxuICB9KSA9PiB7XG4gICAgY29uc3QgeyB0IH0gPSB1c2VUcmFuc2xhdGlvbigncGVvcGxlJylcbiAgICByZXR1cm4gKFxuICAgICAgPGRpdiBzdHlsZT17eyB3aWR0aDogJzEwMCUnLCBoZWlnaHQ6ICcxMDAlJyB9fT5cbiAgICAgICAgPGRpdiBzdHlsZT17eyB3aWR0aDogJzEwMCUnLCBoZWlnaHQ6ICcxMDAlJywgYm9yZGVyUmFkaXVzOiAnNHB4JyB9fT5cbiAgICAgICAgICA8SGVhZGVyVGFibGUgLz5cbiAgICAgICAgICB7bG9hZGluZyA/IChcbiAgICAgICAgICAgIDxMb2FkZXJDb21wb25lbnQgLz5cbiAgICAgICAgICApIDogZXJyb3IgPyAoXG4gICAgICAgICAgICA8RXJyb3JDb21wb25lbnQgdGl0bGU9e3QoJ2Vycm9yLmVycm9yTWVzc2FnZVRpdGxlJyl9IHN1YnRpdGxlPXt0KCdlcnJvci5lcnJvck1lc3NhZ2VCb2R5Jyl9IC8+XG4gICAgICAgICAgKSA6IChcbiAgICAgICAgICAgIDxCb2R5Q29udGFpbmVyIC8+XG4gICAgICAgICAgKX1cbiAgICAgICAgPC9kaXY+XG4gICAgICAgIHtoYXNVc2VycyAmJiAhbG9hZGluZyAmJiAhZXJyb3IgJiYgPFBhZ2luYXRpb25Db250YWluZXIgaGFuZGxlQ2hhbmdlUGFnZT17aGFuZGxlQ2hhbmdlUGFnZX0gLz59XG4gICAgICA8L2Rpdj5cbiAgICApXG4gIH1cbilcbiJdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQTtBQUNBLFNBQVNBLElBQUksUUFBUSxPQUFPO0FBQzVCLFNBQVNDLGNBQWMsUUFBUSxlQUFlO0FBQzlDLFNBQVNDLFdBQVcsUUFBUSwyQ0FBMkM7QUFDdkUsU0FBU0MsYUFBYSxRQUFRLHVCQUF1QjtBQUNyRCxTQUFTQyxtQkFBbUIsUUFBUSxtQ0FBbUM7QUFDdkUsU0FBU0MsY0FBYyxRQUFRLGlDQUFpQztBQUNoRSxTQUFTQyxlQUFlLFFBQVEsMkNBQTJDO0FBQUEsU0FBQUMsR0FBQSxJQUFBQyxJQUFBLEVBQUFDLElBQUEsSUFBQUMsS0FBQTtBQUUzRSxPQUFPLElBQU1DLGNBQWMsZ0JBQUdYLElBQUksQ0FDaEMsVUFBQVksSUFBQSxFQVVNO0VBQUEsSUFUSkMsZ0JBQWdCLEdBQUFELElBQUEsQ0FBaEJDLGdCQUFnQjtJQUFBQyxZQUFBLEdBQUFGLElBQUEsQ0FDaEJHLE9BQU87SUFBUEEsT0FBTyxHQUFBRCxZQUFBLGNBQUcsS0FBSyxHQUFBQSxZQUFBO0lBQUFFLFVBQUEsR0FBQUosSUFBQSxDQUNmSyxLQUFLO0lBQUxBLEtBQUssR0FBQUQsVUFBQSxjQUFHLEtBQUssR0FBQUEsVUFBQTtJQUFBRSxhQUFBLEdBQUFOLElBQUEsQ0FDYk8sUUFBUTtJQUFSQSxRQUFRLEdBQUFELGFBQUEsY0FBRyxLQUFLLEdBQUFBLGFBQUE7RUFPaEIsSUFBQUUsZUFBQSxHQUFjbkIsY0FBYyxDQUFDLFFBQVEsQ0FBQztJQUE5Qm9CLENBQUMsR0FBQUQsZUFBQSxDQUFEQyxDQUFDO0VBQ1Qsb0JBQ0VYLEtBQUE7SUFBS1ksS0FBSyxFQUFFO01BQUVDLEtBQUssRUFBRSxNQUFNO01BQUVDLE1BQU0sRUFBRTtJQUFPLENBQUU7SUFBQUMsUUFBQSxnQkFDNUNmLEtBQUE7TUFBS1ksS0FBSyxFQUFFO1FBQUVDLEtBQUssRUFBRSxNQUFNO1FBQUVDLE1BQU0sRUFBRSxNQUFNO1FBQUVFLFlBQVksRUFBRTtNQUFNLENBQUU7TUFBQUQsUUFBQSxnQkFDakVqQixJQUFBLENBQUNOLFdBQVcsSUFBRSxDQUFDLEVBQ2RhLE9BQU8sZ0JBQ05QLElBQUEsQ0FBQ0YsZUFBZSxJQUFFLENBQUMsR0FDakJXLEtBQUssZ0JBQ1BULElBQUEsQ0FBQ0gsY0FBYztRQUFDc0IsS0FBSyxFQUFFTixDQUFDLENBQUMseUJBQXlCLENBQUU7UUFBQ08sUUFBUSxFQUFFUCxDQUFDLENBQUMsd0JBQXdCO01BQUUsQ0FBRSxDQUFDLGdCQUU5RmIsSUFBQSxDQUFDTCxhQUFhLElBQUUsQ0FDakI7SUFBQSxDQUNFLENBQUMsRUFDTGdCLFFBQVEsSUFBSSxDQUFDSixPQUFPLElBQUksQ0FBQ0UsS0FBSyxpQkFBSVQsSUFBQSxDQUFDSixtQkFBbUI7TUFBQ1MsZ0JBQWdCLEVBQUVBO0lBQWlCLENBQUUsQ0FBQztFQUFBLENBQzNGLENBQUM7QUFFVixDQUNGLENBQUMiLCJpZ25vcmVMaXN0IjpbXX0=
34
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJtZW1vIiwidXNlVHJhbnNsYXRpb24iLCJIZWFkZXJUYWJsZSIsIkJvZHlDb250YWluZXIiLCJQYWdpbmF0aW9uQ29udGFpbmVyIiwiTGF5b3V0VGFibGUiLCJFcnJvckNvbXBvbmVudCIsIkxvYWRlckNvbXBvbmVudCIsImpzeCIsIl9qc3giLCJqc3hzIiwiX2pzeHMiLCJUYWJsZUNvbnRhaW5lciIsIl9yZWYiLCJfcmVmJGhhbmRsZUNoYW5nZVBhZ2UiLCJoYW5kbGVDaGFuZ2VQYWdlIiwiX3JlZiRsb2FkaW5nIiwibG9hZGluZyIsIl9yZWYkZXJyb3IiLCJlcnJvciIsIl9yZWYkaGFzVXNlcnMiLCJoYXNVc2VycyIsIl91c2VUcmFuc2xhdGlvbiIsInQiLCJjaGlsZHJlbiIsInRpdGxlIiwic3VidGl0bGUiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29udGFpbmVyL1RhYmxlQ29udGFpbmVyL1RhYmxlQ29udGFpbmVyLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSByZWFjdC9yZXF1aXJlLWRlZmF1bHQtcHJvcHMgKi9cbi8qIGVzbGludC1kaXNhYmxlIG5vLW5lc3RlZC10ZXJuYXJ5ICovXG5pbXBvcnQgeyBtZW1vIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyB1c2VUcmFuc2xhdGlvbiB9IGZyb20gJ3JlYWN0LWkxOG5leHQnXG5pbXBvcnQgeyBIZWFkZXJUYWJsZSB9IGZyb20gJy4uLy4uL2NvbXBvbmVudHMvVGFibGUvSGVhZGVyL0hlYWRlclRhYmxlJ1xuaW1wb3J0IHsgQm9keUNvbnRhaW5lciB9IGZyb20gJy4uL0JvZHkvQm9keUNvbnRhaW5lcidcbmltcG9ydCB7IFBhZ2luYXRpb25Db250YWluZXIgfSBmcm9tICcuLi9QYWdpbmF0aW9uL1BhZ2luYXRpb25Db250YWluZXInXG5pbXBvcnQgeyBMYXlvdXRUYWJsZSB9IGZyb20gJy4uLy4uL2NvbXBvbmVudHMvTGF5b3V0J1xuaW1wb3J0IHsgRXJyb3JDb21wb25lbnQgfSBmcm9tICcuLi8uLi9jb21wb25lbnRzL0Vycm9yQ29tcG9uZW50J1xuaW1wb3J0IHsgTG9hZGVyQ29tcG9uZW50IH0gZnJvbSAnLi4vLi4vY29tcG9uZW50cy9Mb2FkaW5nL0xvYWRpbmdDb21wb25lbnQnXG5cbmV4cG9ydCBjb25zdCBUYWJsZUNvbnRhaW5lciA9IG1lbW8oXG4gICh7XG4gICAgaGFuZGxlQ2hhbmdlUGFnZSA9ICgpID0+IHt9LFxuICAgIGxvYWRpbmcgPSBmYWxzZSxcbiAgICBlcnJvciA9IGZhbHNlLFxuICAgIGhhc1VzZXJzID0gZmFsc2UsXG4gIH06IHtcbiAgICBoYW5kbGVDaGFuZ2VQYWdlPzogKHBhZ2U6IG51bWJlcikgPT4gdm9pZFxuICAgIGxvYWRpbmc/OiBib29sZWFuXG4gICAgZXJyb3I/OiBib29sZWFuXG4gICAgaGFzVXNlcnM/OiBib29sZWFuXG4gIH0pID0+IHtcbiAgICBjb25zdCB7IHQgfSA9IHVzZVRyYW5zbGF0aW9uKCdwZW9wbGUnKVxuICAgIHJldHVybiAoXG4gICAgICA8ZGl2PlxuICAgICAgICA8TGF5b3V0VGFibGU+XG4gICAgICAgICAgPEhlYWRlclRhYmxlIC8+XG4gICAgICAgICAge2xvYWRpbmcgPyAoXG4gICAgICAgICAgICA8TG9hZGVyQ29tcG9uZW50IC8+XG4gICAgICAgICAgKSA6IGVycm9yID8gKFxuICAgICAgICAgICAgPEVycm9yQ29tcG9uZW50IHRpdGxlPXt0KCdlcnJvci5lcnJvck1lc3NhZ2VUaXRsZScpfSBzdWJ0aXRsZT17dCgnZXJyb3IuZXJyb3JNZXNzYWdlQm9keScpfSAvPlxuICAgICAgICAgICkgOiAoXG4gICAgICAgICAgICA8Qm9keUNvbnRhaW5lciAvPlxuICAgICAgICAgICl9XG4gICAgICAgIDwvTGF5b3V0VGFibGU+XG4gICAgICAgIHtoYXNVc2VycyAmJiAhbG9hZGluZyAmJiAhZXJyb3IgJiYgPFBhZ2luYXRpb25Db250YWluZXIgaGFuZGxlQ2hhbmdlUGFnZT17aGFuZGxlQ2hhbmdlUGFnZX0gLz59XG4gICAgICA8L2Rpdj5cbiAgICApXG4gIH1cbilcbiJdLCJtYXBwaW5ncyI6IkFBQUE7QUFDQTtBQUNBLFNBQVNBLElBQUksUUFBUSxPQUFPO0FBQzVCLFNBQVNDLGNBQWMsUUFBUSxlQUFlO0FBQzlDLFNBQVNDLFdBQVcsUUFBUSwyQ0FBMkM7QUFDdkUsU0FBU0MsYUFBYSxRQUFRLHVCQUF1QjtBQUNyRCxTQUFTQyxtQkFBbUIsUUFBUSxtQ0FBbUM7QUFDdkUsU0FBU0MsV0FBVyxRQUFRLHlCQUF5QjtBQUNyRCxTQUFTQyxjQUFjLFFBQVEsaUNBQWlDO0FBQ2hFLFNBQVNDLGVBQWUsUUFBUSwyQ0FBMkM7QUFBQSxTQUFBQyxHQUFBLElBQUFDLElBQUEsRUFBQUMsSUFBQSxJQUFBQyxLQUFBO0FBRTNFLE9BQU8sSUFBTUMsY0FBYyxnQkFBR1osSUFBSSxDQUNoQyxVQUFBYSxJQUFBLEVBVU07RUFBQSxJQUFBQyxxQkFBQSxHQUFBRCxJQUFBLENBVEpFLGdCQUFnQjtJQUFoQkEsZ0JBQWdCLEdBQUFELHFCQUFBLGNBQUcsWUFBTSxDQUFDLENBQUMsR0FBQUEscUJBQUE7SUFBQUUsWUFBQSxHQUFBSCxJQUFBLENBQzNCSSxPQUFPO0lBQVBBLE9BQU8sR0FBQUQsWUFBQSxjQUFHLEtBQUssR0FBQUEsWUFBQTtJQUFBRSxVQUFBLEdBQUFMLElBQUEsQ0FDZk0sS0FBSztJQUFMQSxLQUFLLEdBQUFELFVBQUEsY0FBRyxLQUFLLEdBQUFBLFVBQUE7SUFBQUUsYUFBQSxHQUFBUCxJQUFBLENBQ2JRLFFBQVE7SUFBUkEsUUFBUSxHQUFBRCxhQUFBLGNBQUcsS0FBSyxHQUFBQSxhQUFBO0VBT2hCLElBQUFFLGVBQUEsR0FBY3JCLGNBQWMsQ0FBQyxRQUFRLENBQUM7SUFBOUJzQixDQUFDLEdBQUFELGVBQUEsQ0FBREMsQ0FBQztFQUNULG9CQUNFWixLQUFBO0lBQUFhLFFBQUEsZ0JBQ0ViLEtBQUEsQ0FBQ04sV0FBVztNQUFBbUIsUUFBQSxnQkFDVmYsSUFBQSxDQUFDUCxXQUFXLElBQUUsQ0FBQyxFQUNkZSxPQUFPLGdCQUNOUixJQUFBLENBQUNGLGVBQWUsSUFBRSxDQUFDLEdBQ2pCWSxLQUFLLGdCQUNQVixJQUFBLENBQUNILGNBQWM7UUFBQ21CLEtBQUssRUFBRUYsQ0FBQyxDQUFDLHlCQUF5QixDQUFFO1FBQUNHLFFBQVEsRUFBRUgsQ0FBQyxDQUFDLHdCQUF3QjtNQUFFLENBQUUsQ0FBQyxnQkFFOUZkLElBQUEsQ0FBQ04sYUFBYSxJQUFFLENBQ2pCO0lBQUEsQ0FDVSxDQUFDLEVBQ2JrQixRQUFRLElBQUksQ0FBQ0osT0FBTyxJQUFJLENBQUNFLEtBQUssaUJBQUlWLElBQUEsQ0FBQ0wsbUJBQW1CO01BQUNXLGdCQUFnQixFQUFFQTtJQUFpQixDQUFFLENBQUM7RUFBQSxDQUMzRixDQUFDO0FBRVYsQ0FDRixDQUFDIiwiaWdub3JlTGlzdCI6W119
@@ -0,0 +1,40 @@
1
+ import _slicedToArray from "@babel/runtime/helpers/slicedToArray";
2
+ import { createContext, useContext, useState } from 'react';
3
+ import { jsx as _jsx } from "react/jsx-runtime";
4
+ var TeamsContext = /*#__PURE__*/createContext(undefined);
5
+ export var TeamsProvider = function TeamsProvider(_ref) {
6
+ var children = _ref.children,
7
+ view = _ref.view;
8
+ var _useState = useState([]),
9
+ _useState2 = _slicedToArray(_useState, 2),
10
+ teams = _useState2[0],
11
+ setTeams = _useState2[1];
12
+ var _useState3 = useState(0),
13
+ _useState4 = _slicedToArray(_useState3, 2),
14
+ totalTeams = _useState4[0],
15
+ setTotalTeams = _useState4[1];
16
+ var _useState5 = useState(1),
17
+ _useState6 = _slicedToArray(_useState5, 2),
18
+ currentPage = _useState6[0],
19
+ setCurrentPage = _useState6[1];
20
+ return /*#__PURE__*/_jsx(TeamsContext.Provider, {
21
+ value: {
22
+ teams: teams,
23
+ totalTeams: totalTeams,
24
+ currentPage: currentPage,
25
+ setTeams: setTeams,
26
+ setTotalTeams: setTotalTeams,
27
+ setCurrentPage: setCurrentPage,
28
+ view: view
29
+ },
30
+ children: children
31
+ });
32
+ };
33
+ export var useTeams = function useTeams() {
34
+ var context = useContext(TeamsContext);
35
+ if (context === undefined) {
36
+ throw new Error('useTeams must be used within a TeamsProvider');
37
+ }
38
+ return context;
39
+ };
40
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJjcmVhdGVDb250ZXh0IiwidXNlQ29udGV4dCIsInVzZVN0YXRlIiwianN4IiwiX2pzeCIsIlRlYW1zQ29udGV4dCIsInVuZGVmaW5lZCIsIlRlYW1zUHJvdmlkZXIiLCJfcmVmIiwiY2hpbGRyZW4iLCJ2aWV3IiwiX3VzZVN0YXRlIiwiX3VzZVN0YXRlMiIsIl9zbGljZWRUb0FycmF5IiwidGVhbXMiLCJzZXRUZWFtcyIsIl91c2VTdGF0ZTMiLCJfdXNlU3RhdGU0IiwidG90YWxUZWFtcyIsInNldFRvdGFsVGVhbXMiLCJfdXNlU3RhdGU1IiwiX3VzZVN0YXRlNiIsImN1cnJlbnRQYWdlIiwic2V0Q3VycmVudFBhZ2UiLCJQcm92aWRlciIsInZhbHVlIiwidXNlVGVhbXMiLCJjb250ZXh0IiwiRXJyb3IiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvY29udGV4dC9UZWFtc0NvbnRleHQudHN4Il0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNyZWF0ZUNvbnRleHQsIHVzZUNvbnRleHQsIFJlYWN0Tm9kZSwgdXNlU3RhdGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IFZpZXdUeXBlIH0gZnJvbSAnLi4vdHlwZXMvdXNlclR5cGUnXG5cbmludGVyZmFjZSBUZWFtc0NvbnRleHRUeXBlIHtcbiAgdGVhbXM6IGFueVtdXG4gIHRvdGFsVGVhbXM6IG51bWJlclxuICBjdXJyZW50UGFnZTogbnVtYmVyXG4gIHNldFRlYW1zOiAodGVhbXM6IGFueVtdKSA9PiB2b2lkXG4gIHNldFRvdGFsVGVhbXM6ICh0b3RhbDogbnVtYmVyKSA9PiB2b2lkXG4gIHNldEN1cnJlbnRQYWdlOiAocGFnZTogbnVtYmVyKSA9PiB2b2lkXG4gIHZpZXc6IFZpZXdUeXBlXG59XG5cbmNvbnN0IFRlYW1zQ29udGV4dCA9IGNyZWF0ZUNvbnRleHQ8VGVhbXNDb250ZXh0VHlwZSB8IHVuZGVmaW5lZD4odW5kZWZpbmVkKVxuXG5leHBvcnQgY29uc3QgVGVhbXNQcm92aWRlciA9ICh7IGNoaWxkcmVuLCB2aWV3IH06IHsgY2hpbGRyZW46IFJlYWN0Tm9kZTsgdmlldzogVmlld1R5cGUgfSkgPT4ge1xuICBjb25zdCBbdGVhbXMsIHNldFRlYW1zXSA9IHVzZVN0YXRlPGFueVtdPihbXSlcbiAgY29uc3QgW3RvdGFsVGVhbXMsIHNldFRvdGFsVGVhbXNdID0gdXNlU3RhdGU8bnVtYmVyPigwKVxuICBjb25zdCBbY3VycmVudFBhZ2UsIHNldEN1cnJlbnRQYWdlXSA9IHVzZVN0YXRlPG51bWJlcj4oMSlcblxuICByZXR1cm4gKFxuICAgIDxUZWFtc0NvbnRleHQuUHJvdmlkZXJcbiAgICAgIHZhbHVlPXt7XG4gICAgICAgIHRlYW1zLFxuICAgICAgICB0b3RhbFRlYW1zLFxuICAgICAgICBjdXJyZW50UGFnZSxcbiAgICAgICAgc2V0VGVhbXMsXG4gICAgICAgIHNldFRvdGFsVGVhbXMsXG4gICAgICAgIHNldEN1cnJlbnRQYWdlLFxuICAgICAgICB2aWV3LFxuICAgICAgfX1cbiAgICA+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9UZWFtc0NvbnRleHQuUHJvdmlkZXI+XG4gIClcbn1cblxuZXhwb3J0IGNvbnN0IHVzZVRlYW1zID0gKCkgPT4ge1xuICBjb25zdCBjb250ZXh0ID0gdXNlQ29udGV4dChUZWFtc0NvbnRleHQpXG4gIGlmIChjb250ZXh0ID09PSB1bmRlZmluZWQpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ3VzZVRlYW1zIG11c3QgYmUgdXNlZCB3aXRoaW4gYSBUZWFtc1Byb3ZpZGVyJylcbiAgfVxuICByZXR1cm4gY29udGV4dFxufVxuIl0sIm1hcHBpbmdzIjoiO0FBQUEsU0FBU0EsYUFBYSxFQUFFQyxVQUFVLEVBQWFDLFFBQVEsUUFBUSxPQUFPO0FBQUEsU0FBQUMsR0FBQSxJQUFBQyxJQUFBO0FBYXRFLElBQU1DLFlBQVksZ0JBQUdMLGFBQWEsQ0FBK0JNLFNBQVMsQ0FBQztBQUUzRSxPQUFPLElBQU1DLGFBQWEsR0FBRyxTQUFoQkEsYUFBYUEsQ0FBQUMsSUFBQSxFQUFvRTtFQUFBLElBQTlEQyxRQUFRLEdBQUFELElBQUEsQ0FBUkMsUUFBUTtJQUFFQyxJQUFJLEdBQUFGLElBQUEsQ0FBSkUsSUFBSTtFQUM1QyxJQUFBQyxTQUFBLEdBQTBCVCxRQUFRLENBQVEsRUFBRSxDQUFDO0lBQUFVLFVBQUEsR0FBQUMsY0FBQSxDQUFBRixTQUFBO0lBQXRDRyxLQUFLLEdBQUFGLFVBQUE7SUFBRUcsUUFBUSxHQUFBSCxVQUFBO0VBQ3RCLElBQUFJLFVBQUEsR0FBb0NkLFFBQVEsQ0FBUyxDQUFDLENBQUM7SUFBQWUsVUFBQSxHQUFBSixjQUFBLENBQUFHLFVBQUE7SUFBaERFLFVBQVUsR0FBQUQsVUFBQTtJQUFFRSxhQUFhLEdBQUFGLFVBQUE7RUFDaEMsSUFBQUcsVUFBQSxHQUFzQ2xCLFFBQVEsQ0FBUyxDQUFDLENBQUM7SUFBQW1CLFVBQUEsR0FBQVIsY0FBQSxDQUFBTyxVQUFBO0lBQWxERSxXQUFXLEdBQUFELFVBQUE7SUFBRUUsY0FBYyxHQUFBRixVQUFBO0VBRWxDLG9CQUNFakIsSUFBQSxDQUFDQyxZQUFZLENBQUNtQixRQUFRO0lBQ3BCQyxLQUFLLEVBQUU7TUFDTFgsS0FBSyxFQUFMQSxLQUFLO01BQ0xJLFVBQVUsRUFBVkEsVUFBVTtNQUNWSSxXQUFXLEVBQVhBLFdBQVc7TUFDWFAsUUFBUSxFQUFSQSxRQUFRO01BQ1JJLGFBQWEsRUFBYkEsYUFBYTtNQUNiSSxjQUFjLEVBQWRBLGNBQWM7TUFDZGIsSUFBSSxFQUFKQTtJQUNGLENBQUU7SUFBQUQsUUFBQSxFQUVEQTtFQUFRLENBQ1ksQ0FBQztBQUU1QixDQUFDO0FBRUQsT0FBTyxJQUFNaUIsUUFBUSxHQUFHLFNBQVhBLFFBQVFBLENBQUEsRUFBUztFQUM1QixJQUFNQyxPQUFPLEdBQUcxQixVQUFVLENBQUNJLFlBQVksQ0FBQztFQUN4QyxJQUFJc0IsT0FBTyxLQUFLckIsU0FBUyxFQUFFO0lBQ3pCLE1BQU0sSUFBSXNCLEtBQUssQ0FBQyw4Q0FBOEMsQ0FBQztFQUNqRTtFQUNBLE9BQU9ELE9BQU87QUFDaEIsQ0FBQyIsImlnbm9yZUxpc3QiOltdfQ==