@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.
- package/lib/App.stories.js +3 -2
- package/lib/Providers.js +6 -2
- package/lib/components/DeleteTeamModal/DeleteTeamModal.js +54 -0
- package/lib/components/DeleteTeamModal/DeleteTeamModal.styles.js +42 -0
- package/lib/components/DeleteTeamModal/DeleteTeamModal.types.js +2 -0
- package/lib/components/DeleteTeamModal/index.js +2 -0
- package/lib/components/EmptyStateTeams/EmptyStateTeams.js +194 -0
- package/lib/components/EmptyStateTeams/EmptyStateTeams.styles.js +6 -0
- package/lib/components/EmptyStateTeams/index.js +2 -0
- package/lib/components/ErrorTeams/ErrorTeams.js +118 -0
- package/lib/components/ErrorTeams/ErrorTeams.styles.js +6 -0
- package/lib/components/ErrorTeams/index.js +2 -0
- package/lib/components/Filters/SearchComponent/SearchComponent.styles.js +2 -2
- package/lib/components/HeaderTeams/HeaderTeams.js +28 -0
- package/lib/components/HeaderTeams/HeaderTeams.style.js +14 -0
- package/lib/components/HeaderTeams/index.js +2 -0
- package/lib/components/Layout/Layout.js +16 -0
- package/lib/components/Layout/Layout.styles.js +10 -0
- package/lib/components/Layout/index.js +3 -0
- package/lib/components/Loader/Loader.js +11 -0
- package/lib/components/Loader/Loader.styles.js +6 -0
- package/lib/components/Loader/index.js +2 -0
- package/lib/components/Pagination/Pagination.js +78 -0
- package/lib/components/Pagination/Pagination.styles.js +22 -0
- package/lib/components/Pagination/index.js +2 -0
- package/lib/components/ShowMore/ShowMore.js +12 -0
- package/lib/components/ShowMore/ShowMore.style.js +10 -0
- package/lib/components/ShowMore/index.js +2 -0
- package/lib/components/Table/Header/HeaderTable.js +23 -19
- package/lib/components/Table/Row/Row.styles.js +48 -12
- package/lib/components/Table/TeamRow/TeamRow.js +111 -0
- package/lib/components/Table/TeamRow/index.js +2 -0
- package/lib/components/TeamDetailsModal/MembersSelect.js +103 -0
- package/lib/components/TeamDetailsModal/TeamDetailsModal.js +276 -0
- package/lib/components/TeamDetailsModal/TeamDetailsModal.styles.js +121 -0
- package/lib/components/TeamDetailsModal/TeamDetailsModal.types.js +2 -0
- package/lib/components/TeamDetailsModal/index.js +2 -0
- package/lib/container/Body/BodyContainer.js +2 -6
- package/lib/container/Body/BodyContainerViewTeams.js +217 -0
- package/lib/container/Filters/FiltersTeamsContainer.js +156 -0
- package/lib/container/Filters/FiltersTeamsContainer.styles.js +6 -0
- package/lib/container/MainView/MainView.js +45 -5
- package/lib/container/RouterComponent/RouterComponent.js +15 -22
- package/lib/container/TableContainer/TableContainer.js +5 -12
- package/lib/context/TeamsContext.js +40 -0
- package/lib/context/UsersContext.js +16 -11
- package/lib/hooks/useFiltersTeams.js +36 -0
- package/lib/hooks/useGetTeams.js +23 -20
- package/lib/lang/i18nextForWeb.js +14 -11
- package/lib/lang/translation/br.json +49 -1
- package/lib/lang/translation/en.json +49 -1
- package/lib/lang/translation/es.json +49 -1
- package/lib/lang/translation/fr.json +49 -1
- package/lib/query/getTeams.js +2 -2
- package/lib/types/global.d.js +1 -1
- 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
|
-
|
|
26
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
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(
|
|
114
|
-
var
|
|
115
|
-
|
|
116
|
-
|
|
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
|
-
|
|
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,
|
|
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==
|