@dexteel/mesf-core 4.20.5 → 4.21.0

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 (36) hide show
  1. package/.release-please-manifest.json +1 -1
  2. package/CHANGELOG.md +20 -0
  3. package/dist/components/modals/modal.mesf.d.ts +3 -2
  4. package/dist/configuration/pages/asset/theme.d.ts +1 -1
  5. package/dist/configuration/pages/log/styles/tableStyles.d.ts +1 -1
  6. package/dist/configuration/pages/settings/SettingsPage.d.ts +2 -0
  7. package/dist/configuration/pages/settings/components/TableSettings.d.ts +9 -0
  8. package/dist/configuration/pages/settings/components/customHooks/useSettingsOptionsFunctions.d.ts +12 -0
  9. package/dist/configuration/pages/settings/components/customHooks/useTableSettings.d.ts +11 -0
  10. package/dist/configuration/pages/settings/components/upsertDelete/CreateSetting.d.ts +7 -0
  11. package/dist/configuration/pages/settings/components/upsertDelete/DeleteSetting.d.ts +7 -0
  12. package/dist/configuration/pages/settings/components/upsertDelete/EditSetting.d.ts +7 -0
  13. package/dist/configuration/pages/settings/context/SettingsContext.d.ts +26 -0
  14. package/dist/configuration/pages/settings/index.d.ts +3 -0
  15. package/dist/configuration/pages/settings/models/FormInitialValues.d.ts +2 -0
  16. package/dist/configuration/pages/settings/models/Setting.d.ts +6 -0
  17. package/dist/configuration/pages/settings/reducers/SettingReducer.d.ts +20 -0
  18. package/dist/configuration/pages/settings/repositories/settingRepository.d.ts +3 -0
  19. package/dist/configuration/pages/settings/styles/useStyles.d.ts +1 -0
  20. package/dist/context/axiosInstance.d.ts +2 -1
  21. package/dist/controls/contextMenu/styles/ContextMenuStyles.d.ts +1 -1
  22. package/dist/controls/index.d.ts +1 -0
  23. package/dist/controls/panels.d.ts +1 -1
  24. package/dist/controls/shift-navigator/repositories/ShiftsRepository.d.ts +1 -4
  25. package/dist/controls/shift-navigator-v2/component/shift-period-navigator.control.d.ts +8 -0
  26. package/dist/controls/shift-navigator-v2/index.d.ts +4 -0
  27. package/dist/controls/shift-navigator-v2/models/SearchShiftsParameters.d.ts +4 -0
  28. package/dist/controls/shift-navigator-v2/models/shift-data.d.ts +22 -0
  29. package/dist/controls/shift-navigator-v2/repositories/ShiftsRepository.d.ts +14 -0
  30. package/dist/index.esm.js +1500 -418
  31. package/dist/index.esm.js.map +1 -1
  32. package/dist/pages/trendings/components/chart/styles/TagColorsStyles.d.ts +1 -1
  33. package/dist/pages/trendings/components/chart/styles/TagsTableStyles.d.ts +1 -1
  34. package/dist/pages/trendings/components/chart/styles/TasgTreeModalStyles.d.ts +1 -1
  35. package/dist/pages/trendings/components/chart/styles/TrendingStyles.d.ts +1 -1
  36. package/package.json +1 -1
package/dist/index.esm.js CHANGED
@@ -1,5 +1,5 @@
1
1
  export { LicenseManager } from 'ag-grid-enterprise';
2
- import { DialogTitle as DialogTitle$1, DialogContent as DialogContent$1, DialogActions as DialogActions$1, Grid, Button, withStyles as withStyles$1, alpha, makeStyles, Dialog as Dialog$1, SvgIcon, Collapse, Typography as Typography$1, Checkbox, TextField, InputAdornment, IconButton as IconButton$1, MenuItem, Select, Card, CardContent, CardActions, Snackbar, CircularProgress, Paper, InputLabel, FormHelperText, DialogContentText, FormControlLabel, Badge, useTheme, FormControl, Input, Chip, Tooltip, ListItemIcon, MenuList, Divider, Box, debounce, createStyles as createStyles$1, List, ListItem, ListItemText } from '@material-ui/core';
2
+ import { withStyles, DialogTitle as DialogTitle$1, DialogContent as DialogContent$1, DialogActions as DialogActions$1, createStyles, Grid, Button, alpha, makeStyles, Dialog as Dialog$1, SvgIcon, Collapse, Typography as Typography$1, Checkbox, TextField, InputAdornment, IconButton as IconButton$1, MenuItem, Select, Card, CardContent, CardActions, Snackbar, CircularProgress, Paper, InputLabel, FormHelperText, DialogContentText, FormControlLabel, Badge, useTheme, FormControl, Input, Chip, Tooltip, ListItemIcon, MenuList, Divider, Box, debounce, List, ListItem, ListItemText } from '@material-ui/core';
3
3
  import { get as get$1, isNil as isNil$1, isEmpty, values, round, isNaN, isNumber } from 'lodash-es';
4
4
  import * as React from 'react';
5
5
  import React__default, { useState, useRef, useEffect, useMemo, Component, createContext, useContext, useCallback, lazy, Suspense } from 'react';
@@ -9,6 +9,7 @@ import { Outlet, useParams, useNavigate, useSearchParams, Link, Navigate, Routes
9
9
  import { Alert as Alert$1, Modal as Modal$1, Navbar, Container, Nav, NavDropdown } from 'react-bootstrap';
10
10
  import { LogLevel, PublicClientApplication } from '@azure/msal-browser';
11
11
  import { useMsal, MsalProvider } from '@azure/msal-react';
12
+ import SettingsIcon from '@material-ui/icons/Settings';
12
13
  import ShowChartIcon from '@material-ui/icons/ShowChart';
13
14
  import { useComplexState } from 'use-complex-state';
14
15
  import { createSlice } from '@reduxjs/toolkit';
@@ -17,10 +18,13 @@ import { HTML5Backend } from 'react-dnd-html5-backend';
17
18
  import { AgGridReact } from 'ag-grid-react';
18
19
  import MomentUtils from '@date-io/moment';
19
20
  import { MuiPickersUtilsProvider, KeyboardDatePicker, KeyboardTimePicker } from '@material-ui/pickers';
20
- import moment$2 from 'moment';
21
+ import moment$4 from 'moment';
21
22
  import EditIcon from '@material-ui/icons/Edit';
22
23
  import PlaylistAddIcon from '@material-ui/icons/PlaylistAdd';
23
24
  import { isNil, get } from 'lodash';
25
+ import DeleteIcon from '@material-ui/icons/Delete';
26
+ import FormatListBulletedSharpIcon from '@material-ui/icons/FormatListBulletedSharp';
27
+ import { useForm, Controller } from 'react-hook-form';
24
28
  import axios from 'axios';
25
29
  import { _adapters, Chart, CategoryScale, LinearScale, PointElement, LineElement, Title, Tooltip as Tooltip$1, Legend, TimeScale } from 'chart.js';
26
30
  import zoomPlugin from 'chartjs-plugin-zoom';
@@ -30,21 +34,19 @@ import { Alert as Alert$3, Autocomplete } from '@material-ui/lab';
30
34
  import Button$1 from '@material-ui/core/Button';
31
35
  import Popover from '@material-ui/core/Popover';
32
36
  import CreateIcon from '@material-ui/icons/Create';
33
- import DeleteIcon from '@material-ui/icons/Delete';
34
37
  import { isAncestor, Tree, DndProvider as DndProvider$1 } from '@minoru/react-dnd-treeview';
35
38
  import FolderIcon from '@material-ui/icons/Folder';
36
39
  import InsertChartIcon from '@material-ui/icons/InsertChart';
37
40
  import ArrowDropDownIcon from '@material-ui/icons/ArrowDropDown';
38
41
  import SkipNextIcon from '@material-ui/icons/SkipNext';
39
42
  import { Line } from 'react-chartjs-2';
40
- import { ClearIcon, LocalizationProvider } from '@mui/x-date-pickers';
43
+ import { ClearIcon, DatePicker as DatePicker$1, CalendarIcon, LocalizationProvider } from '@mui/x-date-pickers';
41
44
  import { AdapterMoment } from '@mui/x-date-pickers/AdapterMoment';
42
- import moment$3 from 'moment-timezone';
45
+ import moment$5 from 'moment-timezone';
43
46
  import PersonPinCircleIcon from '@material-ui/icons/PersonPinCircle';
44
47
  import Dialog from '@material-ui/core/Dialog';
45
48
  import IconButton from '@material-ui/core/IconButton';
46
49
  import Typography from '@material-ui/core/Typography';
47
- import { withStyles, createStyles } from '@material-ui/core/styles';
48
50
  import CloseIcon from '@material-ui/icons/Close';
49
51
  import { ResponsiveBar } from '@nivo/bar';
50
52
  import PropTypes from 'prop-types';
@@ -61,8 +63,6 @@ import RefreshIcon from '@material-ui/icons/Refresh';
61
63
  import ReplayIcon from '@material-ui/icons/Replay';
62
64
  import ToggleOfIcon from '@material-ui/icons/ToggleOff';
63
65
  import ToggleOnIcon from '@material-ui/icons/ToggleOn';
64
- import FormatListBulletedSharpIcon from '@material-ui/icons/FormatListBulletedSharp';
65
- import { useForm, Controller } from 'react-hook-form';
66
66
  import 'ag-grid-enterprise/styles/ag-grid.css';
67
67
  import 'ag-grid-enterprise/styles/ag-theme-balham.min.css';
68
68
  import 'ag-grid-community/styles/ag-grid.css';
@@ -330,7 +330,7 @@ BarChartControl.propTypes = {
330
330
 
331
331
  var e=[],t=[];function n(n,r){if(n&&"undefined"!=typeof document){var a,s=!0===r.prepend?"prepend":"append",d=!0===r.singleTag,i="string"==typeof r.container?document.querySelector(r.container):document.getElementsByTagName("head")[0];if(d){var u=e.indexOf(i);-1===u&&(u=e.push(i)-1,t[u]={}),a=t[u]&&t[u][s]?t[u][s]:t[u][s]=c();}else a=c();65279===n.charCodeAt(0)&&(n=n.substring(1)),a.styleSheet?a.styleSheet.cssText+=n:a.appendChild(document.createTextNode(n));}function c(){var e=document.createElement("style");if(e.setAttribute("type","text/css"),r.attributes)for(var t=Object.keys(r.attributes),n=0;n<t.length;n++)e.setAttribute(t[n],r.attributes[t[n]]);var a="prepend"===s?"afterbegin":"beforeend";return i.insertAdjacentElement(a,e),e}}
332
332
 
333
- var css$2 = ".lds-ring {\n display: inline-block;\n position: relative;\n width: 80px;\n height: 80px;\n}\n.lds-ring div {\n box-sizing: border-box;\n display: block;\n position: absolute;\n width: 64px;\n height: 64px;\n margin: 8px;\n border: 5px solid rgb(63,81,181);\n border-radius: 50%;\n animation: lds-ring 1.2s cubic-bezier(0.5, 0, 0.5, 1) infinite;\n border-color: rgb(63,81,181) transparent transparent transparent;\n}\n.lds-ring div:nth-child(1) {\n animation-delay: -0.45s;\n}\n.lds-ring div:nth-child(2) {\n animation-delay: -0.3s;\n}\n.lds-ring div:nth-child(3) {\n animation-delay: -0.15s;\n}\n@keyframes lds-ring {\n 0% {\n transform: rotate(0deg);\n }\n 100% {\n transform: rotate(360deg);\n }\n}\n";
333
+ var css$2 = ".lds-ring {\n\tdisplay: inline-block;\n\tposition: relative;\n\twidth: 80px;\n\theight: 80px;\n}\n.lds-ring div {\n\tbox-sizing: border-box;\n\tdisplay: block;\n\tposition: absolute;\n\twidth: 64px;\n\theight: 64px;\n\tmargin: 8px;\n\tborder: 5px solid rgb(63, 81, 181);\n\tborder-radius: 50%;\n\tanimation: lds-ring 1.2s cubic-bezier(0.5, 0, 0.5, 1) infinite;\n\tborder-color: rgb(63, 81, 181) transparent transparent transparent;\n}\n.lds-ring div:nth-child(1) {\n\tanimation-delay: -0.45s;\n}\n.lds-ring div:nth-child(2) {\n\tanimation-delay: -0.3s;\n}\n.lds-ring div:nth-child(3) {\n\tanimation-delay: -0.15s;\n}\n@keyframes lds-ring {\n\t0% {\n\t\ttransform: rotate(0deg);\n\t}\n\t100% {\n\t\ttransform: rotate(360deg);\n\t}\n}\n";
334
334
  n(css$2,{});
335
335
 
336
336
  var LazyLoading = function () {
@@ -364,7 +364,7 @@ function TransitionComponent(props) {
364
364
  TransitionComponent.propTypes = {
365
365
  "in": PropTypes.bool
366
366
  };
367
- var StyledTreeItem = withStyles$1(function (theme) { return ({
367
+ var StyledTreeItem = withStyles(function (theme) { return ({
368
368
  iconContainer: {
369
369
  "& .close": {
370
370
  opacity: 0.3
@@ -573,7 +573,7 @@ var ModalTreeFilterControl = function (props) {
573
573
  React__default.createElement(Button, { onClick: handleOk, color: "primary" }, "OK"))));
574
574
  };
575
575
 
576
- var useStyles$v = makeStyles(function (theme) { return ({
576
+ var useStyles$z = makeStyles(function (theme) { return ({
577
577
  root: {
578
578
  width: "100%",
579
579
  backgroundColor: theme.palette.background.paper,
@@ -589,7 +589,7 @@ var useStyles$v = makeStyles(function (theme) { return ({
589
589
  }
590
590
  }); });
591
591
  var TreePickerControl = function (props) {
592
- var classes = useStyles$v();
592
+ var classes = useStyles$z();
593
593
  var onSelect = props.onSelect, value = props.value; props.styleLabel; var dataSource = props.dataSource, _a = props.inputTitle, inputTitle = _a === void 0 ? "Asset" : _a; props.showPath; var _c = props.multipleSelectNodes, multipleSelectNodes = _c === void 0 ? false : _c, _d = props.showClearButton, showClearButton = _d === void 0 ? false : _d, showAssetTree = props.showAssetTree, onHide = props.onHide, _e = props.listAssetDrawings, listAssetDrawings = _e === void 0 ? [] : _e, onSuccess = props.onSuccess, isLoading = props.isLoading, other = __rest(props, ["onSelect", "value", "styleLabel", "dataSource", "inputTitle", "showPath", "multipleSelectNodes", "showClearButton", "showAssetTree", "onHide", "listAssetDrawings", "onSuccess", "isLoading"]);
594
594
  var _f = useState(showAssetTree || false), open = _f[0], setOpen = _f[1];
595
595
  var handleClickListItem = function (e) {
@@ -673,7 +673,7 @@ var TreePickerControl = function (props) {
673
673
  }, onHide: onHide, id: "modal-treeview-filter", title: props.title, keepMounted: true, open: open, onClose: handleClose, isLoading: isLoading, value: value, data: dataSource, onBackdropClick: function () { return setOpen(false); }, multipleSelectNodes: multipleSelectNodes, listAssetDrawings: listAssetDrawings, setListAssetDrawings: listAssetDrawings, onSuccess: onSuccess }, other)))));
674
674
  };
675
675
 
676
- var useStyles$u = makeStyles(function (theme) { return ({
676
+ var useStyles$y = makeStyles(function (theme) { return ({
677
677
  root: {
678
678
  width: "100%",
679
679
  backgroundColor: theme.palette.background.paper
@@ -699,7 +699,7 @@ function findNameById(node, id) {
699
699
  return null;
700
700
  }
701
701
  var TreePickerControlV2 = function (props) {
702
- var classes = useStyles$u();
702
+ var classes = useStyles$y();
703
703
  var value = props.value, onSelect = props.onSelect; props.styleLabel; var dataSource = props.dataSource; props.getOptionName; var _a = props.inputTitle, inputTitle = _a === void 0 ? "Asset" : _a; props.showPath; var _c = props.multipleSelectNodes, multipleSelectNodes = _c === void 0 ? false : _c, _d = props.showClearButton, showClearButton = _d === void 0 ? false : _d, showAssetTree = props.showAssetTree, onHide = props.onHide, _e = props.listAssetDrawings, listAssetDrawings = _e === void 0 ? [] : _e, onSuccess = props.onSuccess, isLoading = props.isLoading, _f = props.disabled, disabled = _f === void 0 ? false : _f, other = __rest(props, ["value", "onSelect", "styleLabel", "dataSource", "getOptionName", "inputTitle", "showPath", "multipleSelectNodes", "showClearButton", "showAssetTree", "onHide", "listAssetDrawings", "onSuccess", "isLoading", "disabled"]);
704
704
  var _g = useState(false), open = _g[0], setOpen = _g[1];
705
705
  var handleClickListItem = function (event) {
@@ -1352,7 +1352,7 @@ var useJobsOptionsFunctions = function (_a) {
1352
1352
  };
1353
1353
  };
1354
1354
 
1355
- var useStyles$t = makeStyles(function (theme) { return ({
1355
+ var useStyles$x = makeStyles(function (theme) { return ({
1356
1356
  buttons: {
1357
1357
  opacity: 0,
1358
1358
  transition: "opacity 0.1s ease-in-out",
@@ -1370,7 +1370,7 @@ var useStyles$t = makeStyles(function (theme) { return ({
1370
1370
  var useJobsTableData = function (_a) {
1371
1371
  var setRowSelected = _a.setRowSelected, showContextMenu = _a.showContextMenu;
1372
1372
  var _b = useJobsContext().state, jobsData = _b.jobsData, blockButtons = _b.blockButtons;
1373
- var classes = useStyles$t();
1373
+ var classes = useStyles$x();
1374
1374
  var rows = jobsData.map(function (_a) {
1375
1375
  var JobId = _a.JobId, sProcedure = _a.sProcedure, Running = _a.Running, LastStarted = _a.LastStarted, LastCounter = _a.LastCounter, Enabled = _a.Enabled, RestartAfterFailure = _a.RestartAfterFailure, PeriodTime = _a.PeriodTime, StartTime = _a.StartTime, NextExecutionTime = _a.NextExecutionTime;
1376
1376
  return ({
@@ -1497,7 +1497,7 @@ var useJobsTableData = function (_a) {
1497
1497
  headerName: "Start Time",
1498
1498
  valueFormatter: function (_a) {
1499
1499
  var value = _a.value;
1500
- return value === null ? "NULL" : moment$2(value).format("DD/MM/YYYY HH:mm");
1500
+ return value === null ? "NULL" : moment$4(value).format("DD/MM/YYYY HH:mm");
1501
1501
  },
1502
1502
  flex: 1,
1503
1503
  cellStyle: {
@@ -1513,7 +1513,7 @@ var useJobsTableData = function (_a) {
1513
1513
  headerName: "Next Execution",
1514
1514
  valueFormatter: function (_a) {
1515
1515
  var value = _a.value;
1516
- return value === null ? "NULL" : moment$2(value).format("DD/MM/YYYY HH:mm");
1516
+ return value === null ? "NULL" : moment$4(value).format("DD/MM/YYYY HH:mm");
1517
1517
  },
1518
1518
  flex: 1,
1519
1519
  cellStyle: {
@@ -1529,7 +1529,7 @@ var useJobsTableData = function (_a) {
1529
1529
  headerName: "Started",
1530
1530
  valueFormatter: function (_a) {
1531
1531
  var value = _a.value;
1532
- return value === null ? "NULL" : moment$2(value).format("DD/MM/YYYY HH:mm");
1532
+ return value === null ? "NULL" : moment$4(value).format("DD/MM/YYYY HH:mm");
1533
1533
  },
1534
1534
  flex: 1,
1535
1535
  cellStyle: {
@@ -1545,7 +1545,7 @@ var useJobsTableData = function (_a) {
1545
1545
  headerName: "Last Seen",
1546
1546
  valueFormatter: function (_a) {
1547
1547
  var value = _a.value;
1548
- return value === null ? "NULL" : moment$2(value).format("DD/MM/YYYY HH:mm");
1548
+ return value === null ? "NULL" : moment$4(value).format("DD/MM/YYYY HH:mm");
1549
1549
  },
1550
1550
  flex: 2,
1551
1551
  cellStyle: {
@@ -1655,7 +1655,7 @@ var useJobsTableData = function (_a) {
1655
1655
  return { rows: rows, columnDefs: columnDefs };
1656
1656
  };
1657
1657
 
1658
- var useStyles$s = makeStyles(function (theme) { return ({
1658
+ var useStyles$w = makeStyles(function (theme) { return ({
1659
1659
  root: {
1660
1660
  "& .MuiDataGrid-row": {
1661
1661
  cursor: "pointer"
@@ -1718,7 +1718,7 @@ var useStyles$s = makeStyles(function (theme) { return ({
1718
1718
  }); });
1719
1719
  var TableJobs = function (_a) {
1720
1720
  var getJobsFromAPI = _a.getJobsFromAPI, isLoading = _a.isLoading;
1721
- var classes = useStyles$s();
1721
+ var classes = useStyles$w();
1722
1722
  var _b = useState(null), rowSelected = _b[0], setRowSelected = _b[1];
1723
1723
  var _c = useState(false), snackbarLoading = _c[0], setSnackbarLoading = _c[1];
1724
1724
  var _d = useState(false), snackbarSuccessfulMessage = _d[0], setSnackbarSuccessfulMessage = _d[1];
@@ -1875,8 +1875,8 @@ var JobsPage = function (props) {
1875
1875
  var LogsInitialState = {
1876
1876
  logs: [],
1877
1877
  searchData: {
1878
- Start: moment$2().add(-5, "days").hour(0).minute(0).second(0).toDate(),
1879
- End: moment$2().hour(23).minute(59).second(59).toDate(),
1878
+ Start: moment$4().add(-5, "days").hour(0).minute(0).second(0).toDate(),
1879
+ End: moment$4().hour(23).minute(59).second(59).toDate(),
1880
1880
  Search: "",
1881
1881
  LogTypeCode: "A"
1882
1882
  }
@@ -1912,8 +1912,8 @@ var LogsReducer = createSlice({
1912
1912
  resetFilters: function (state, _a) {
1913
1913
  _a.payload;
1914
1914
  state.searchData = {
1915
- Start: moment$2().add(-5, "days").hour(0).minute(0).second(0).toDate(),
1916
- End: moment$2().hour(23).minute(59).second(59).toDate(),
1915
+ Start: moment$4().add(-5, "days").hour(0).minute(0).second(0).toDate(),
1916
+ End: moment$4().hour(23).minute(59).second(59).toDate(),
1917
1917
  Search: "",
1918
1918
  LogTypeCode: "A"
1919
1919
  };
@@ -1982,7 +1982,7 @@ var SearchFilter = function (_a) {
1982
1982
  React__default.createElement(FormHelperText, { style: { marginBottom: 10, marginTop: -15 } }, "Search by Source, Message or User")));
1983
1983
  };
1984
1984
 
1985
- var useStyles$r = makeStyles(function (theme) { return ({
1985
+ var useStyles$v = makeStyles(function (theme) { return ({
1986
1986
  title: {
1987
1987
  fontSize: 15
1988
1988
  },
@@ -1999,7 +1999,7 @@ var formatTime = function (nowTime) {
1999
1999
  };
2000
2000
  var ModalLogSelected = function (_a) {
2001
2001
  var show = _a.show, onHide = _a.onHide, selectedLog = _a.selectedLog;
2002
- var classes = useStyles$r();
2002
+ var classes = useStyles$v();
2003
2003
  return (React__default.createElement(Grid, { container: true, justifyContent: "center", alignItems: "center" },
2004
2004
  React__default.createElement(MesfModal, { title: "LOG DETAILS", open: show, handleClose: function () { return onHide(false); }, maxWidth: "md", id: "log-details-modal" },
2005
2005
  React__default.createElement(MesfModal.Content, { style: { padding: "15px 30px" } },
@@ -2055,7 +2055,7 @@ var ModalLogSelected = function (_a) {
2055
2055
  React__default.createElement(Button, { fullWidth: true, variant: "contained", color: "default", onClick: function () { return onHide(true); } }, "Close")))))));
2056
2056
  };
2057
2057
 
2058
- var useStyles$q = makeStyles(function (theme) { return ({
2058
+ var useStyles$u = makeStyles(function (theme) { return ({
2059
2059
  buttons: {
2060
2060
  opacity: 0,
2061
2061
  transition: "opacity 0.1s ease-in-out",
@@ -2073,7 +2073,7 @@ var useStyles$q = makeStyles(function (theme) { return ({
2073
2073
  var useLogTableData = function () {
2074
2074
  var _a;
2075
2075
  var state = useLogsContext().state;
2076
- var classes = useStyles$q();
2076
+ var classes = useStyles$u();
2077
2077
  var formatTime = function (nowTime) {
2078
2078
  return (nowTime.toLocaleDateString("en-US") + " " + nowTime.toLocaleTimeString());
2079
2079
  };
@@ -2194,7 +2194,7 @@ var ButtonWithLoading = function (_a) {
2194
2194
  children));
2195
2195
  };
2196
2196
 
2197
- var useStyles$p = makeStyles(function (theme) { return ({
2197
+ var useStyles$t = makeStyles(function (theme) { return ({
2198
2198
  root: {
2199
2199
  "& .MuiDataGrid-row": {
2200
2200
  cursor: "pointer"
@@ -2288,7 +2288,7 @@ var useLogsOptionsFunctions = function (_a) {
2288
2288
  var TableLogs = function (_a) {
2289
2289
  var isLoading = _a.isLoading; _a.rowData; var refreshData = _a.refreshData;
2290
2290
  var _b = useLogsContext(), _c = _b.state.searchData, Start = _c.Start, End = _c.End, Search = _c.Search, LogTypeCode = _c.LogTypeCode, _d = _b.actions, setLogTypeCodeFilter = _d.setLogTypeCodeFilter, setEndFilter = _d.setEndFilter, setStartFilter = _d.setStartFilter, setSearchFilter = _d.setSearchFilter;
2291
- var classes = useStyles$p();
2291
+ var classes = useStyles$t();
2292
2292
  var gridStyle = useMemo(function () { return ({ height: "100%", width: "100%" }); }, []);
2293
2293
  var _e = useState(null); _e[0]; var setGridAPI = _e[1];
2294
2294
  var _f = useState(false), showLogModal = _f[0], setShowLogModal = _f[1];
@@ -2314,8 +2314,8 @@ var TableLogs = function (_a) {
2314
2314
  var handleResetButtonClick = function () {
2315
2315
  resetFilter();
2316
2316
  refreshData({
2317
- Start: moment$2().add(-5, "days").hour(0).minute(0).second(0).toDate(),
2318
- End: moment$2().hour(23).minute(59).second(59).toDate(),
2317
+ Start: moment$4().add(-5, "days").hour(0).minute(0).second(0).toDate(),
2318
+ End: moment$4().hour(23).minute(59).second(59).toDate(),
2319
2319
  Search: "",
2320
2320
  LogTypeCode: "A"
2321
2321
  });
@@ -2477,7 +2477,7 @@ var LogsPage = function (props) {
2477
2477
  React.createElement(Logs, null)));
2478
2478
  };
2479
2479
 
2480
- var INITIAL_VALUES$2 = {
2480
+ var INITIAL_VALUES$3 = {
2481
2481
  ProfileId: null,
2482
2482
  ProfileName: ""
2483
2483
  };
@@ -2578,7 +2578,7 @@ var deleteProfile = function (profileId) { return __awaiter(void 0, void 0, void
2578
2578
  });
2579
2579
  }); };
2580
2580
 
2581
- var useStyles$o = makeStyles(function (theme) { return ({
2581
+ var useStyles$s = makeStyles(function (theme) { return ({
2582
2582
  title: {
2583
2583
  fontSize: 15
2584
2584
  },
@@ -2601,8 +2601,8 @@ var CreateProfile = function (_a) {
2601
2601
  var _d = useState(""), message = _d[0], setMessage = _d[1];
2602
2602
  var _e = useState(false), isSubmitLoading = _e[0], setIsSubmitLoading = _e[1];
2603
2603
  var _f = useState(""), error = _f[0], setError = _f[1];
2604
- var classes = useStyles$o();
2605
- var _g = useForm({ defaultValues: INITIAL_VALUES$2 }), register = _g.register, handleSubmit = _g.handleSubmit, reset = _g.reset, errors = _g.formState.errors;
2604
+ var classes = useStyles$s();
2605
+ var _g = useForm({ defaultValues: INITIAL_VALUES$3 }), register = _g.register, handleSubmit = _g.handleSubmit, reset = _g.reset, errors = _g.formState.errors;
2606
2606
  var onSubmit = function (data) { return __awaiter(void 0, void 0, void 0, function () {
2607
2607
  var res;
2608
2608
  return __generator(this, function (_a) {
@@ -2836,7 +2836,7 @@ var DataTable = function (_a) {
2836
2836
  React__default.createElement(ErrorModal, { error: error, onHide: function () { return setError(""); } })));
2837
2837
  };
2838
2838
 
2839
- var useStyles$n = makeStyles(function (theme) { return ({
2839
+ var useStyles$r = makeStyles(function (theme) { return ({
2840
2840
  root: {
2841
2841
  "& .MuiFormLabel-asterisk": {
2842
2842
  display: "none"
@@ -2845,7 +2845,7 @@ var useStyles$n = makeStyles(function (theme) { return ({
2845
2845
  }); });
2846
2846
  var ActionsOfProfile = function (_a) {
2847
2847
  var profileForEdit = _a.profileForEdit, show = _a.show, onHide = _a.onHide;
2848
- var classes = useStyles$n();
2848
+ var classes = useStyles$r();
2849
2849
  var _b = useState(null), actionsOfProfile = _b[0], setActionsOfProfile = _b[1];
2850
2850
  var _c = useState(false), open = _c[0], setOpen = _c[1];
2851
2851
  var _d = useState(true), isLoading = _d[0], setIsLoading = _d[1];
@@ -2855,7 +2855,7 @@ var ActionsOfProfile = function (_a) {
2855
2855
  var _h = useState(""), profileName = _h[0], setProfileName = _h[1];
2856
2856
  var _j = useState(""), nameError = _j[0], setNameError = _j[1];
2857
2857
  var _k = useState(false); _k[0]; var setShowEditInput = _k[1];
2858
- var handleSubmit = useForm({ defaultValues: INITIAL_VALUES$2 }).handleSubmit;
2858
+ var handleSubmit = useForm({ defaultValues: INITIAL_VALUES$3 }).handleSubmit;
2859
2859
  var handleClose = function (event, reason) {
2860
2860
  if (reason === "clickaway") {
2861
2861
  return;
@@ -3033,7 +3033,7 @@ var ProfilesProvider = function (_a) {
3033
3033
  return (React__default.createElement(ProfilesContext.Provider, { value: { state: state, actions: actions } }, children));
3034
3034
  };
3035
3035
 
3036
- var useStyles$m = makeStyles(function (theme) { return ({
3036
+ var useStyles$q = makeStyles(function (theme) { return ({
3037
3037
  buttons: {
3038
3038
  opacity: 0,
3039
3039
  transition: "opacity 0.1s ease-in-out",
@@ -3048,10 +3048,10 @@ var useStyles$m = makeStyles(function (theme) { return ({
3048
3048
  }
3049
3049
  }
3050
3050
  }); });
3051
- var useTableData$2 = function (_a) {
3051
+ var useTableData$3 = function (_a) {
3052
3052
  var setProfileId = _a.setProfileId, setModalProceduresProfile = _a.setModalProceduresProfile, setModalDeleteProfile = _a.setModalDeleteProfile, showContextMenu = _a.showContextMenu;
3053
3053
  var state = useProfilesContext().state;
3054
- var classes = useStyles$m();
3054
+ var classes = useStyles$q();
3055
3055
  var rows = state.profiles.map(function (_a) {
3056
3056
  var ProfileId = _a.ProfileId, ProfileName = _a.ProfileName;
3057
3057
  return ({
@@ -3123,7 +3123,7 @@ var useTableData$2 = function (_a) {
3123
3123
  return { rows: rows, columnDefs: columnDefs };
3124
3124
  };
3125
3125
 
3126
- var useStyles$l = makeStyles(function (theme) { return ({
3126
+ var useStyles$p = makeStyles(function (theme) { return ({
3127
3127
  root: {
3128
3128
  "& .ag-icon-menu": {
3129
3129
  display: "none"
@@ -3195,7 +3195,7 @@ var TableProfiles = function (_a) {
3195
3195
  var _e = useState(null), profile = _e[0], setProfile = _e[1];
3196
3196
  var gridStyle = useMemo(function () { return ({ height: "100%", width: "100%" }); }, []);
3197
3197
  var _f = useState(null), gridApi = _f[0], setGridApi = _f[1];
3198
- var classes = useStyles$l();
3198
+ var classes = useStyles$p();
3199
3199
  var loadingOverlayComponent = useMemo(function () {
3200
3200
  return LazyLoading;
3201
3201
  }, []);
@@ -3214,7 +3214,7 @@ var TableProfiles = function (_a) {
3214
3214
  setModalProceduresProfile: setModalProceduresProfile
3215
3215
  }).getMenuOptions;
3216
3216
  var _g = useContextMenuMESF(), showContextMenu = _g.showContextMenu, registerConfig = _g.registerConfig;
3217
- var _h = useTableData$2({
3217
+ var _h = useTableData$3({
3218
3218
  setModalDeleteProfile: setModalDeleteProfile,
3219
3219
  setModalProceduresProfile: setModalProceduresProfile,
3220
3220
  setProfileId: setProfile,
@@ -3335,7 +3335,7 @@ var ProfilesPage = function (props) {
3335
3335
  React.createElement(Profiles, null)));
3336
3336
  };
3337
3337
 
3338
- var INITIAL_VALUES$1 = {
3338
+ var INITIAL_VALUES$2 = {
3339
3339
  PatternStart: new Date(),
3340
3340
  ShiftCodes: "",
3341
3341
  Crews: "",
@@ -3350,7 +3350,7 @@ var INITIAL_VALUES$1 = {
3350
3350
 
3351
3351
  var ShiftsCrewsInitialState = {
3352
3352
  shifts: [],
3353
- shiftTableData: INITIAL_VALUES$1
3353
+ shiftTableData: INITIAL_VALUES$2
3354
3354
  };
3355
3355
  var ShiftsCrewsReducer = createSlice({
3356
3356
  name: "__",
@@ -3434,7 +3434,7 @@ var DeleteShiftParameters = function (PatternStart) { return __awaiter(void 0, v
3434
3434
  });
3435
3435
  }); };
3436
3436
 
3437
- var useStyles$k = makeStyles(function (theme) { return ({
3437
+ var useStyles$o = makeStyles(function (theme) { return ({
3438
3438
  title: {
3439
3439
  fontSize: 15
3440
3440
  },
@@ -3460,10 +3460,10 @@ var CreateShift = function (_a) {
3460
3460
  var _d = useState(false), open = _d[0], setOpen = _d[1];
3461
3461
  var _e = useState(false), isSubmitLoading = _e[0], setIsSubmitLoading = _e[1];
3462
3462
  var _f = useState(""), error = _f[0], setError = _f[1];
3463
- var classes = useStyles$k();
3463
+ var classes = useStyles$o();
3464
3464
  var shiftTableData = useShiftsCrewsContext().state.shiftTableData;
3465
3465
  var _g = useForm({
3466
- defaultValues: shiftTableData ? shiftTableData : INITIAL_VALUES$1
3466
+ defaultValues: shiftTableData ? shiftTableData : INITIAL_VALUES$2
3467
3467
  }), control = _g.control, handleSubmit = _g.handleSubmit, reset = _g.reset, watch = _g.watch, setValue = _g.setValue, errors = _g.formState.errors;
3468
3468
  // Progress bar
3469
3469
  var calculatePercentage = function () {
@@ -3662,7 +3662,7 @@ var CreateShift = function (_a) {
3662
3662
  React.createElement(Alert, { severity: "success", onClose: handleClose }, "The shift was created successfully"))));
3663
3663
  };
3664
3664
 
3665
- var useStyles$j = makeStyles(function (theme) { return ({
3665
+ var useStyles$n = makeStyles(function (theme) { return ({
3666
3666
  title: {
3667
3667
  fontSize: 15
3668
3668
  },
@@ -3688,10 +3688,10 @@ var DeleteShift = function (_a) {
3688
3688
  var _c = useState(false), open = _c[0], setOpen = _c[1];
3689
3689
  var _d = useState(false), isSubmitLoading = _d[0], setIsSubmitLoading = _d[1];
3690
3690
  var _e = useState(false), deleteAlert = _e[0], setDeleteAlert = _e[1];
3691
- var classes = useStyles$j();
3691
+ var classes = useStyles$n();
3692
3692
  var shiftTableData = useShiftsCrewsContext().state.shiftTableData;
3693
3693
  var _f = useState(""), error = _f[0], setError = _f[1];
3694
- var _g = useForm({ defaultValues: INITIAL_VALUES$1 }), control = _g.control, setValue = _g.setValue, reset = _g.reset, watch = _g.watch, errors = _g.formState.errors;
3694
+ var _g = useForm({ defaultValues: INITIAL_VALUES$2 }), control = _g.control, setValue = _g.setValue, reset = _g.reset, watch = _g.watch, errors = _g.formState.errors;
3695
3695
  var onDelete = function (data) { return __awaiter(void 0, void 0, void 0, function () {
3696
3696
  var shiftParameters;
3697
3697
  return __generator(this, function (_a) {
@@ -3827,7 +3827,7 @@ var DeleteShift = function (_a) {
3827
3827
  React.createElement(Alert, { severity: "warning", onClose: handleClose }, "The shift was deleted successfully"))));
3828
3828
  };
3829
3829
 
3830
- var useStyles$i = makeStyles(function (theme) { return ({
3830
+ var useStyles$m = makeStyles(function (theme) { return ({
3831
3831
  title: {
3832
3832
  fontSize: 15
3833
3833
  },
@@ -3854,9 +3854,9 @@ var EditShift = function (_a) {
3854
3854
  var _d = useState(""), error = _d[0], setError = _d[1];
3855
3855
  var _e = useState(false), isSubmitLoading = _e[0], setIsSubmitLoading = _e[1];
3856
3856
  var _f = useState(false), initialShiftPerDayAndCrewsNumber = _f[0], setInitialShiftPerDayAndCrewsNumber = _f[1];
3857
- var classes = useStyles$i();
3857
+ var classes = useStyles$m();
3858
3858
  var shiftTableData = useShiftsCrewsContext().state.shiftTableData;
3859
- var _g = useForm({ defaultValues: INITIAL_VALUES$1 }), control = _g.control, setValue = _g.setValue, handleSubmit = _g.handleSubmit, reset = _g.reset, watch = _g.watch, errors = _g.formState.errors;
3859
+ var _g = useForm({ defaultValues: INITIAL_VALUES$2 }), control = _g.control, setValue = _g.setValue, handleSubmit = _g.handleSubmit, reset = _g.reset, watch = _g.watch, errors = _g.formState.errors;
3860
3860
  // Progress bar
3861
3861
  var calculatePercentage = function () {
3862
3862
  return ((crewRotation === null || crewRotation === void 0 ? void 0 : crewRotation.length) / maxCrewRotationLength) * 100;
@@ -4122,7 +4122,7 @@ var useShiftsOptionsFunctions = function (_a) {
4122
4122
  };
4123
4123
  };
4124
4124
 
4125
- var useStyles$h = makeStyles(function (theme) { return ({
4125
+ var useStyles$l = makeStyles(function (theme) { return ({
4126
4126
  root: {
4127
4127
  opacity: 0,
4128
4128
  transition: "opacity 0.1s ease-in-out",
@@ -4137,11 +4137,11 @@ var useStyles$h = makeStyles(function (theme) { return ({
4137
4137
  }
4138
4138
  }
4139
4139
  }); });
4140
- var useTableData$1 = function (_a) {
4140
+ var useTableData$2 = function (_a) {
4141
4141
  var _b;
4142
4142
  var setOpenModalEditShift = _a.setOpenModalEditShift, setOpenModalDeleteShift = _a.setOpenModalDeleteShift, showContextMenu = _a.showContextMenu;
4143
4143
  var _c = useShiftsCrewsContext(), state = _c.state, actions = _c.actions;
4144
- var classes = useStyles$h();
4144
+ var classes = useStyles$l();
4145
4145
  var rows = (_b = state.shifts) === null || _b === void 0 ? void 0 : _b.map(function (_a) {
4146
4146
  var PatternStart = _a.PatternStart, ShiftCodes = _a.ShiftCodes, Crews = _a.Crews, PatternDays = _a.PatternDays, CrewRotation = _a.CrewRotation, Comments = _a.Comments, CanEdit = _a.CanEdit;
4147
4147
  return ({
@@ -4161,7 +4161,7 @@ var useTableData$1 = function (_a) {
4161
4161
  headerName: "Pattern Start",
4162
4162
  valueFormatter: function (_a) {
4163
4163
  var value = _a.value;
4164
- return "".concat(moment$2(value).format("L"), ", ").concat(moment$2(value).format("LTS"));
4164
+ return "".concat(moment$4(value).format("L"), ", ").concat(moment$4(value).format("LTS"));
4165
4165
  },
4166
4166
  minWidth: 180,
4167
4167
  flex: 4,
@@ -4252,7 +4252,7 @@ var useTableData$1 = function (_a) {
4252
4252
  return { rows: rows, columnDefs: columnDefs };
4253
4253
  };
4254
4254
 
4255
- var useStyles$g = makeStyles(function (theme) { return ({
4255
+ var useStyles$k = makeStyles(function (theme) { return ({
4256
4256
  root: {
4257
4257
  "& .ag-icon-menu": {
4258
4258
  display: "none"
@@ -4302,7 +4302,7 @@ var useStyles$g = makeStyles(function (theme) { return ({
4302
4302
  }); });
4303
4303
  var TableShiftsCrews = function (_a) {
4304
4304
  _a.isLoading; var getShiftsCrewsFromAPI = _a.getShiftsCrewsFromAPI;
4305
- var classes = useStyles$g();
4305
+ var classes = useStyles$k();
4306
4306
  var _b = useState(false), openModalNew = _b[0], setOpenModalNew = _b[1];
4307
4307
  var _c = useState(false), openModalEditShift = _c[0], setOpenModalEditShift = _c[1];
4308
4308
  var _d = useState(false), openModalDeleteShift = _d[0], setOpenModalDeleteShift = _d[1];
@@ -4325,7 +4325,7 @@ var TableShiftsCrews = function (_a) {
4325
4325
  setShowEditModal: setOpenModalEditShift
4326
4326
  }).getMenuOptions;
4327
4327
  var _f = useContextMenuMESF(), showContextMenu = _f.showContextMenu, registerConfig = _f.registerConfig;
4328
- var _g = useTableData$1({
4328
+ var _g = useTableData$2({
4329
4329
  setOpenModalEditShift: setOpenModalEditShift,
4330
4330
  setOpenModalDeleteShift: setOpenModalDeleteShift,
4331
4331
  showContextMenu: showContextMenu
@@ -4806,7 +4806,7 @@ var useAssetCodes = function () {
4806
4806
  return { loadFilterAssets: loadFilterAssets };
4807
4807
  };
4808
4808
 
4809
- var useStyles$f = makeStyles(function (theme) { return ({
4809
+ var useStyles$j = makeStyles(function (theme) { return ({
4810
4810
  root: {
4811
4811
  "& .input-group-text": {
4812
4812
  display: "none"
@@ -4849,7 +4849,7 @@ var useStyles$f = makeStyles(function (theme) { return ({
4849
4849
  }); });
4850
4850
  var CreateNewAssetDialog = function (_a) {
4851
4851
  var show = _a.show, onHide = _a.onHide;
4852
- var classes = useStyles$f();
4852
+ var classes = useStyles$j();
4853
4853
  var _b = useState(true), fullWidth = _b[0]; _b[1];
4854
4854
  var _c = useState("sm"), maxWidth = _c[0]; _c[1];
4855
4855
  var _d = useState(false), assetCreatedSuccess = _d[0], setAssetCreatedSuccess = _d[1];
@@ -4968,7 +4968,7 @@ var CreateNewAssetDialog = function (_a) {
4968
4968
  React__default.createElement(Alert$2, { severity: "info", onClose: handleClose }, "Document created succesfully"))));
4969
4969
  };
4970
4970
 
4971
- var useStyles$e = makeStyles(function (theme) { return ({
4971
+ var useStyles$i = makeStyles(function (theme) { return ({
4972
4972
  root: {
4973
4973
  "& .input-group-text": {
4974
4974
  display: "none"
@@ -5016,7 +5016,7 @@ var useStyles$e = makeStyles(function (theme) { return ({
5016
5016
  }); });
5017
5017
  var EditAssetDialog = function (_a) {
5018
5018
  var show = _a.show, onHide = _a.onHide;
5019
- var classes = useStyles$e();
5019
+ var classes = useStyles$i();
5020
5020
  var _b = useState(true), fullWidth = _b[0]; _b[1];
5021
5021
  var _c = useState("sm"), maxWidth = _c[0]; _c[1];
5022
5022
  var _d = useState(false), assetEditedSuccess = _d[0], setAssetEditedSuccess = _d[1];
@@ -5136,7 +5136,7 @@ var EditAssetDialog = function (_a) {
5136
5136
  React__default.createElement(Alert$3, { severity: "info", onClose: handleClose }, "Document created succesfully")))))))));
5137
5137
  };
5138
5138
 
5139
- var useStyles$d = makeStyles(function (theme) { return ({
5139
+ var useStyles$h = makeStyles(function (theme) { return ({
5140
5140
  root: {
5141
5141
  "& .input-group-text": {
5142
5142
  display: "none"
@@ -5180,7 +5180,7 @@ var useStyles$d = makeStyles(function (theme) { return ({
5180
5180
  }); });
5181
5181
  var RemoveAssetDialog = function (_a) {
5182
5182
  var show = _a.show, onHide = _a.onHide;
5183
- var classes = useStyles$d();
5183
+ var classes = useStyles$h();
5184
5184
  var _b = useState(true), fullWidth = _b[0]; _b[1];
5185
5185
  var _c = useState("sm"), maxWidth = _c[0]; _c[1];
5186
5186
  var _d = useState(false), assetRemovedSuccess = _d[0], setAssetRemovedSuccess = _d[1];
@@ -5239,7 +5239,7 @@ var RemoveAssetDialog = function (_a) {
5239
5239
  React__default.createElement(Alert$2, { severity: "info", onClose: handleClose }, "Asset removed succesfully"))));
5240
5240
  };
5241
5241
 
5242
- var useStyles$c = makeStyles(function (theme) { return ({
5242
+ var useStyles$g = makeStyles(function (theme) { return ({
5243
5243
  root: {
5244
5244
  "& .input-group-text": {
5245
5245
  display: "none"
@@ -5290,7 +5290,7 @@ var useStyles$c = makeStyles(function (theme) { return ({
5290
5290
  }); });
5291
5291
  var ViewerAssetDialog = function (_a) {
5292
5292
  var show = _a.show, onHide = _a.onHide;
5293
- var classes = useStyles$c();
5293
+ var classes = useStyles$g();
5294
5294
  var _b = useState(true), fullWidth = _b[0]; _b[1];
5295
5295
  var _c = useState("sm"), maxWidth = _c[0]; _c[1];
5296
5296
  var _d = useConfigurationAssetContext().state, dataToCreateAsset = _d.dataToCreateAsset, assetNodeSelectedInTree = _d.assetNodeSelectedInTree;
@@ -5463,7 +5463,7 @@ var TypeIcon = function (props) {
5463
5463
  }
5464
5464
  };
5465
5465
 
5466
- var useStyles$b = makeStyles(function (theme) { return ({
5466
+ var useStyles$f = makeStyles(function (theme) { return ({
5467
5467
  root: {
5468
5468
  alignItems: "center",
5469
5469
  backgroundColor: "#1967d2",
@@ -5488,7 +5488,7 @@ var useStyles$b = makeStyles(function (theme) { return ({
5488
5488
  }); });
5489
5489
  var CustomDragPreview$1 = function (props) {
5490
5490
  var _a;
5491
- var classes = useStyles$b();
5491
+ var classes = useStyles$f();
5492
5492
  var item = props.monitorProps.item;
5493
5493
  return (React__default.createElement("div", { className: classes.root },
5494
5494
  React__default.createElement("div", { className: classes.icon },
@@ -5496,7 +5496,7 @@ var CustomDragPreview$1 = function (props) {
5496
5496
  React__default.createElement("div", { className: classes.label }, item.text)));
5497
5497
  };
5498
5498
 
5499
- var useStyles$a = makeStyles(function (theme) { return ({
5499
+ var useStyles$e = makeStyles(function (theme) { return ({
5500
5500
  root: {
5501
5501
  alignItems: "center",
5502
5502
  display: "flex",
@@ -5543,7 +5543,7 @@ var CustomNode = function (_a) {
5543
5543
  var _c = useConfigurationAssetContext(), openAssets = _c.state.openAssets, setOpenAssets = _c.actions.setOpenAssets;
5544
5544
  var _d = props.node, id = _d.id, droppable = _d.droppable, data = _d.data;
5545
5545
  var indent = props.depth * 24;
5546
- var classes = useStyles$a();
5546
+ var classes = useStyles$e();
5547
5547
  var nodeClasses = "".concat(classes.customNodeRoot, " ").concat(classes.root, " ").concat(isSelected ? classes.selected : "");
5548
5548
  var handleClick = function (e) {
5549
5549
  props.onClick(e, props.node);
@@ -5598,7 +5598,7 @@ var CustomNode = function (_a) {
5598
5598
  React__default.createElement(Typography$1, { variant: "body2" }, props.node.text))));
5599
5599
  };
5600
5600
 
5601
- var useStyles$9 = makeStyles(function (theme) { return ({
5601
+ var useStyles$d = makeStyles(function (theme) { return ({
5602
5602
  root: {
5603
5603
  alignItems: "flex-start",
5604
5604
  backgroundColor: "#1967d2",
@@ -5630,7 +5630,7 @@ var useStyles$9 = makeStyles(function (theme) { return ({
5630
5630
  }
5631
5631
  }); });
5632
5632
  var MultipleDragPreview = function (props) {
5633
- var classes = useStyles$9();
5633
+ var classes = useStyles$d();
5634
5634
  return (React__default.createElement(Badge, { classes: { badge: classes.badge }, color: "error", badgeContent: props.dragSources.length, anchorOrigin: { vertical: "top", horizontal: "right" } },
5635
5635
  React__default.createElement("div", { className: classes.root, "data-testid": "custom-drag-preview" }, props.dragSources.map(function (node) {
5636
5636
  var _a;
@@ -5641,7 +5641,7 @@ var MultipleDragPreview = function (props) {
5641
5641
  }))));
5642
5642
  };
5643
5643
 
5644
- var useStyles$8 = makeStyles(function (theme) { return ({
5644
+ var useStyles$c = makeStyles(function (theme) { return ({
5645
5645
  root: {},
5646
5646
  contextMenu: {
5647
5647
  backgroundColor: "#F8F8F8",
@@ -5687,7 +5687,7 @@ var useStyles$8 = makeStyles(function (theme) { return ({
5687
5687
  }); });
5688
5688
  var AssetViewComponent = function () {
5689
5689
  var _a = useState([]), selectedNodes = _a[0], setSelectedNodes = _a[1];
5690
- var classes = useStyles$8();
5690
+ var classes = useStyles$c();
5691
5691
  var _b = useState(false), isDragging = _b[0], setIsDragging = _b[1];
5692
5692
  var _c = useState(false), isCtrlPressing = _c[0], setIsCtrlPressing = _c[1];
5693
5693
  var _d = useState(false), isDoubleClick = _d[0], setIsDoubleClick = _d[1];
@@ -6088,7 +6088,7 @@ var ChangePassword$1 = function (_a) {
6088
6088
  }
6089
6089
  };
6090
6090
 
6091
- var INITIAL_VALUES = {
6091
+ var INITIAL_VALUES$1 = {
6092
6092
  UserId: null,
6093
6093
  UserName: "",
6094
6094
  FirstName: "",
@@ -6100,7 +6100,7 @@ var INITIAL_VALUES = {
6100
6100
  Profiles: []
6101
6101
  };
6102
6102
 
6103
- var useStyles$7 = makeStyles(function (theme) { return ({
6103
+ var useStyles$b = makeStyles(function (theme) { return ({
6104
6104
  root: {
6105
6105
  "& .MuiSelect-select": {
6106
6106
  minHeight: "40px"
@@ -6133,7 +6133,7 @@ var MenuProps$1 = {
6133
6133
  };
6134
6134
  var AuthTypeSelector = function (_a) {
6135
6135
  var value = _a.value, onChange = _a.onChange, disabled = _a.disabled;
6136
- var classes = useStyles$7();
6136
+ var classes = useStyles$b();
6137
6137
  var _b = useState([]), authTypes = _b[0], setAuthTypes = _b[1];
6138
6138
  var _c = useState(true), isLoading = _c[0], setIsLoading = _c[1];
6139
6139
  var theme = useTheme();
@@ -6169,7 +6169,7 @@ var AuthTypeSelector = function (_a) {
6169
6169
  React.createElement(Chip, { key: "selected-authType-".concat(selected), label: selectedAuthTypeName, className: classes.chip }))); }, MenuProps: MenuProps$1 }, authTypes.map(function (authType) { return (React.createElement(MenuItem, { key: "auth-".concat(authType.AuthTypeId), value: authType.AuthTypeId, style: getStyles(authType.AuthTypeId, authTypes, theme) }, authType.Name)); })))) : (React.createElement(React.Fragment, null))));
6170
6170
  };
6171
6171
 
6172
- var useStyles$6 = makeStyles(function (theme) { return ({
6172
+ var useStyles$a = makeStyles(function (theme) { return ({
6173
6173
  root: {
6174
6174
  "& .MuiSelect-select": {
6175
6175
  height: "auto",
@@ -6210,7 +6210,7 @@ var MenuProps = {
6210
6210
  };
6211
6211
  var ProfilesPicker = function (_a) {
6212
6212
  var value = _a.value, onChange = _a.onChange; _a.userIdForDelete; var setprofileError = _a.setprofileError, disabled = _a.disabled;
6213
- var classes = useStyles$6();
6213
+ var classes = useStyles$a();
6214
6214
  var theme = useTheme();
6215
6215
  var _b = useState(true), isLoading = _b[0], setIsLoading = _b[1];
6216
6216
  var _c = useState([]), profiles = _c[0], setProfiles = _c[1];
@@ -6250,7 +6250,7 @@ var ProfilesPicker = function (_a) {
6250
6250
  React__default.createElement(Select, { autoWidth: true, labelId: "demo-mutiple-chip-label", id: "demo-mutiple-chip", multiple: true, value: value, onChange: onChange, input: React__default.createElement(Input, { id: "select-multiple-chip" }), renderValue: function (selected) { return (React__default.createElement("div", { className: classes.chips }, selected.map(function (profileId) { return (React__default.createElement(Chip, { key: "selected-profile-".concat(profileId), label: getProfileNameById(profileId), className: classes.chip })); }))); }, MenuProps: MenuProps }, profiles.map(function (profile) { return (React__default.createElement(MenuItem, { key: "profile-".concat(profile.ProfileId), value: profile.ProfileId, style: getStyles(profile.ProfileId, profiles, theme) }, profile.ProfileName.replaceAll("Profile", ""))); })))) : (React__default.createElement(React__default.Fragment, null))));
6251
6251
  };
6252
6252
 
6253
- var useStyles$5 = makeStyles(function (theme) { return ({
6253
+ var useStyles$9 = makeStyles(function (theme) { return ({
6254
6254
  checkbox: {
6255
6255
  userSelect: "none"
6256
6256
  },
@@ -6272,8 +6272,8 @@ var CreateUser = function (_a) {
6272
6272
  var _f = useState(false), isSubmitLoading = _f[0], setIsSubmitLoading = _f[1];
6273
6273
  var _g = useState(""), error = _g[0], setError = _g[1];
6274
6274
  var _h = useState(""), profileError = _h[0], setprofileError = _h[1];
6275
- var classes = useStyles$5();
6276
- var _j = useForm({ defaultValues: INITIAL_VALUES }), register = _j.register, control = _j.control, handleSubmit = _j.handleSubmit, reset = _j.reset, watch = _j.watch, errors = _j.formState.errors;
6275
+ var classes = useStyles$9();
6276
+ var _j = useForm({ defaultValues: INITIAL_VALUES$1 }), register = _j.register, control = _j.control, handleSubmit = _j.handleSubmit, reset = _j.reset, watch = _j.watch, errors = _j.formState.errors;
6277
6277
  var handleClose = function (event, reason) {
6278
6278
  if (reason === "clickaway") {
6279
6279
  return;
@@ -6371,7 +6371,7 @@ var DeleteUser = function (_a) {
6371
6371
  var _f = useState(""), error = _f[0], setError = _f[1];
6372
6372
  var _g = useState(""), profileError = _g[0], setprofileError = _g[1];
6373
6373
  var _h = useForm({
6374
- defaultValues: INITIAL_VALUES
6374
+ defaultValues: INITIAL_VALUES$1
6375
6375
  }), register = _h.register, control = _h.control, setValue = _h.setValue;
6376
6376
  var handleClose = function (event, reason) {
6377
6377
  if (reason === "clickaway") {
@@ -6487,7 +6487,7 @@ var DeleteUser = function (_a) {
6487
6487
  React__default.createElement(ErrorModal, { error: profileError, onHide: function () { return setprofileError(""); }, title: "Error Choosing Profile" })));
6488
6488
  };
6489
6489
 
6490
- var useStyles$4 = makeStyles(function (theme) { return ({
6490
+ var useStyles$8 = makeStyles(function (theme) { return ({
6491
6491
  checkbox: {
6492
6492
  userSelect: "none"
6493
6493
  },
@@ -6506,13 +6506,13 @@ var useStyles$4 = makeStyles(function (theme) { return ({
6506
6506
  var EditUser = function (_a) {
6507
6507
  var _b, _c, _d;
6508
6508
  var userId = _a.userId, show = _a.show, onHide = _a.onHide;
6509
- var classes = useStyles$4();
6509
+ var classes = useStyles$8();
6510
6510
  var _e = useState(false), open = _e[0], setOpen = _e[1];
6511
6511
  var _f = useState(false), isLoading = _f[0], setIsLoading = _f[1];
6512
6512
  var _g = useState(false), isSubmitLoading = _g[0], setIsSubmitLoading = _g[1];
6513
6513
  var _h = useState(""), error = _h[0], setError = _h[1];
6514
6514
  var _j = useState(""), profileError = _j[0], setprofileError = _j[1];
6515
- var _k = useForm({ defaultValues: INITIAL_VALUES }), register = _k.register, control = _k.control, setValue = _k.setValue, handleSubmit = _k.handleSubmit, errors = _k.formState.errors;
6515
+ var _k = useForm({ defaultValues: INITIAL_VALUES$1 }), register = _k.register, control = _k.control, setValue = _k.setValue, handleSubmit = _k.handleSubmit, errors = _k.formState.errors;
6516
6516
  var handleClose = function (event, reason) {
6517
6517
  if (reason === "clickaway") {
6518
6518
  return;
@@ -6657,7 +6657,7 @@ var UsersProvider = function (_a) {
6657
6657
  return (React__default.createElement(UsersContext.Provider, { value: { state: state, actions: actions } }, children));
6658
6658
  };
6659
6659
 
6660
- var useStyles$3 = makeStyles(function (theme) { return ({
6660
+ var useStyles$7 = makeStyles(function (theme) { return ({
6661
6661
  buttons: {
6662
6662
  opacity: 0,
6663
6663
  transition: "opacity 0.1s ease-in-out",
@@ -6673,7 +6673,7 @@ var useStyles$3 = makeStyles(function (theme) { return ({
6673
6673
  }
6674
6674
  }); });
6675
6675
  var buttonsCellRenderer = function (params) {
6676
- var classes = useStyles$3();
6676
+ var classes = useStyles$7();
6677
6677
  var setUserId = params.setUserId, setOpenModalEditDataUser = params.setOpenModalEditDataUser, setOpenModalDeleteUser = params.setOpenModalDeleteUser, setOpenModalChangePasswordd = params.setOpenModalChangePasswordd, showContextMenu = params.showContextMenu;
6678
6678
  return (React__default.createElement(Grid, { container: true, style: {
6679
6679
  height: "100%",
@@ -6722,7 +6722,7 @@ var buttonsCellRenderer = function (params) {
6722
6722
  React__default.createElement(FormatListBulletedSharpIcon, { style: { height: "auto" }, color: "action" })))));
6723
6723
  };
6724
6724
 
6725
- var useTableData = function (_a) {
6725
+ var useTableData$1 = function (_a) {
6726
6726
  var setUserId = _a.setUserId, setOpenModalEditDataUser = _a.setOpenModalEditDataUser, setOpenModalDeleteUser = _a.setOpenModalDeleteUser, setOpenModalChangePasswordd = _a.setOpenModalChangePasswordd, showContextMenu = _a.showContextMenu;
6727
6727
  var state = useUsersContext().state;
6728
6728
  var columnDefs = [
@@ -6872,7 +6872,7 @@ var useUsersOptionsFunctions = function (_a) {
6872
6872
  };
6873
6873
  };
6874
6874
 
6875
- var useStyles$2 = makeStyles(function (theme) { return ({
6875
+ var useStyles$6 = makeStyles(function (theme) { return ({
6876
6876
  root: {
6877
6877
  "& .ag-icon-menu": {
6878
6878
  display: "none"
@@ -6943,7 +6943,7 @@ var TableUsers = function (_a) {
6943
6943
  var _c = useState(false), openModalEditDataUser = _c[0], setOpenModalEditDataUser = _c[1];
6944
6944
  var _d = useState(false), openModalDeleteUser = _d[0], setOpenModalDeleteUser = _d[1];
6945
6945
  var _e = useState(false), openModalChangePassword = _e[0], setOpenModalChangePasswordd = _e[1];
6946
- var classes = useStyles$2();
6946
+ var classes = useStyles$6();
6947
6947
  var _f = useState(null), userId = _f[0], setUserId = _f[1];
6948
6948
  var _g = useState(null), gridApi = _g[0], setGridApi = _g[1];
6949
6949
  var loadingOverlayComponent = useMemo(function () {
@@ -6957,7 +6957,7 @@ var TableUsers = function (_a) {
6957
6957
  setShowChangePasswordModal: setOpenModalChangePasswordd
6958
6958
  }).getMenuOptions;
6959
6959
  var _h = useContextMenuMESF(), showContextMenu = _h.showContextMenu, registerConfig = _h.registerConfig;
6960
- var _j = useTableData({
6960
+ var _j = useTableData$1({
6961
6961
  setUserId: setUserId,
6962
6962
  setOpenModalEditDataUser: setOpenModalEditDataUser,
6963
6963
  setOpenModalDeleteUser: setOpenModalDeleteUser,
@@ -7412,7 +7412,7 @@ var MESApiService = /** @class */ (function () {
7412
7412
  data.dataBaseName = database;
7413
7413
  data.parameters = formattedParameters;
7414
7414
  Date.prototype.toJSON = function () {
7415
- return moment$2(this).format("YYYY-MM-DDTHH:mm:ss");
7415
+ return moment$4(this).format("YYYY-MM-DDTHH:mm:ss");
7416
7416
  }; // eslint-disable-line
7417
7417
  isError = { ok: true };
7418
7418
  return [2 /*return*/, fetch(this.config.API_PROCEDURE_URL + "/Execute", {
@@ -7471,7 +7471,7 @@ var MESApiService = /** @class */ (function () {
7471
7471
  data.dataBaseName = database;
7472
7472
  data.parameters = formattedParameters;
7473
7473
  Date.prototype.toJSON = function () {
7474
- return moment$2(this).format("YYYY-MM-DDTHH:mm:ss");
7474
+ return moment$4(this).format("YYYY-MM-DDTHH:mm:ss");
7475
7475
  }; // eslint-disable-line
7476
7476
  _a.label = 1;
7477
7477
  case 1:
@@ -7532,7 +7532,7 @@ var MESApiService = /** @class */ (function () {
7532
7532
  data.dataBaseName = database;
7533
7533
  data.parameters = formattedParameters;
7534
7534
  Date.prototype.toJSON = function () {
7535
- return moment$2(this).format("YYYY-MM-DDTHH:mm:ss");
7535
+ return moment$4(this).format("YYYY-MM-DDTHH:mm:ss");
7536
7536
  }; // eslint-disable-line
7537
7537
  isError = { ok: true };
7538
7538
  return [2 /*return*/, fetch(this.config.API_PROCEDURE_URL + "/ExecuteJSON", {
@@ -7587,7 +7587,7 @@ var MESApiService = /** @class */ (function () {
7587
7587
  formattedParameters.push(formattedParameter);
7588
7588
  });
7589
7589
  Date.prototype.toJSON = function () {
7590
- return moment$2(this).format("YYYY-MM-DDTHH:mm:ss");
7590
+ return moment$4(this).format("YYYY-MM-DDTHH:mm:ss");
7591
7591
  }; // eslint-disable-line
7592
7592
  isError = { ok: true };
7593
7593
  files.forEach(function (element) {
@@ -7652,7 +7652,7 @@ var MESApiService = /** @class */ (function () {
7652
7652
  data.parameters = formattedParameters;
7653
7653
  data.fileName = fileName || "Default.xlsx";
7654
7654
  Date.prototype.toJSON = function () {
7655
- return moment$2(this).format("YYYY-MM-DDTHH:mm:ss");
7655
+ return moment$4(this).format("YYYY-MM-DDTHH:mm:ss");
7656
7656
  }; // eslint-disable-line
7657
7657
  isError = { ok: true };
7658
7658
  return [2 /*return*/, fetch(this.config.API_PROCEDURE_URL + "/Export", {
@@ -7728,7 +7728,7 @@ var MESApiService = /** @class */ (function () {
7728
7728
  data.parameters = formattedParameters;
7729
7729
  data.fileName = fileName || "Default.xlsx";
7730
7730
  Date.prototype.toJSON = function () {
7731
- return moment$2(this).format("YYYY-MM-DDTHH:mm:ss");
7731
+ return moment$4(this).format("YYYY-MM-DDTHH:mm:ss");
7732
7732
  }; // eslint-disable-line
7733
7733
  isError = { ok: true };
7734
7734
  return [2 /*return*/, fetch(this.config.API_PROCEDURE_URL + "/ExportExcel", {
@@ -7815,7 +7815,7 @@ var TimeService = /** @class */ (function () {
7815
7815
  else {
7816
7816
  this.timeZone = timeZone;
7817
7817
  }
7818
- moment$3.tz.setDefault(this.timeZone);
7818
+ moment$5.tz.setDefault(this.timeZone);
7819
7819
  };
7820
7820
  TimeService.prototype.toUTC = function (datetime, format$1) {
7821
7821
  try {
@@ -7854,7 +7854,7 @@ var TimeService = /** @class */ (function () {
7854
7854
  };
7855
7855
  return TimeService;
7856
7856
  }());
7857
- var getMomentTz = function () { return moment$3; };
7857
+ var getMomentTz = function () { return moment$5; };
7858
7858
  var dxtServerTimeZone = function () {
7859
7859
  return TimeService.getInstance().getServerTimeZone;
7860
7860
  };
@@ -7904,7 +7904,7 @@ var getShiftByParameters = function (parameters) { return __awaiter(void 0, void
7904
7904
  });
7905
7905
  }); };
7906
7906
 
7907
- var moment$1 = getMomentTz();
7907
+ var moment$3 = getMomentTz();
7908
7908
  var useShiftNavigatorManager = function () {
7909
7909
  var _a = useState(null), shiftInfo = _a[0], setShiftInfo = _a[1];
7910
7910
  var _b = useState(false); _b[0]; var setIsShiftInfoLoading = _b[1];
@@ -7936,11 +7936,11 @@ var useShiftNavigatorManager = function () {
7936
7936
  case 1:
7937
7937
  resp = _a.sent();
7938
7938
  if (resp.ok) {
7939
- shift = __assign(__assign({}, resp.data), { CurrentProductionDate: moment$1
7939
+ shift = __assign(__assign({}, resp.data), { CurrentProductionDate: moment$3
7940
7940
  .utc(resp.data.CurrentProductionDate)
7941
- .toDate(), CurrentStart: moment$1.utc(resp.data.CurrentStart).toDate(), CurrentEnd: moment$1.utc(resp.data.CurrentEnd).toDate(), PreviousProductionDate: moment$1
7941
+ .toDate(), CurrentStart: moment$3.utc(resp.data.CurrentStart).toDate(), CurrentEnd: moment$3.utc(resp.data.CurrentEnd).toDate(), PreviousProductionDate: moment$3
7942
7942
  .utc(resp.data.PreviousProductionDate)
7943
- .toDate(), PreviousStart: moment$1.utc(resp.data.PreviousStart).toDate(), PreviousEnd: moment$1.utc(resp.data.PreviousEnd).toDate(), LastProductionDate: moment$1.utc(resp.data.LastProductionDate).toDate(), LastStart: moment$1.utc(resp.data.LastStart).toDate(), LastEnd: moment$1.utc(resp.data.LastEnd).toDate() });
7943
+ .toDate(), PreviousStart: moment$3.utc(resp.data.PreviousStart).toDate(), PreviousEnd: moment$3.utc(resp.data.PreviousEnd).toDate(), LastProductionDate: moment$3.utc(resp.data.LastProductionDate).toDate(), LastStart: moment$3.utc(resp.data.LastStart).toDate(), LastEnd: moment$3.utc(resp.data.LastEnd).toDate() });
7944
7944
  setShiftInfo(shift);
7945
7945
  return [2 /*return*/, shift];
7946
7946
  }
@@ -7965,11 +7965,11 @@ var useShiftNavigatorManager = function () {
7965
7965
  case 2:
7966
7966
  resp = _a.sent();
7967
7967
  if (resp.ok) {
7968
- shift = __assign(__assign({}, resp.data), { CurrentProductionDate: moment$1
7968
+ shift = __assign(__assign({}, resp.data), { CurrentProductionDate: moment$3
7969
7969
  .utc(resp.data.CurrentProductionDate)
7970
- .toDate(), CurrentStart: moment$1.utc(resp.data.CurrentStart).toDate(), CurrentEnd: moment$1.utc(resp.data.CurrentEnd).toDate(), PreviousProductionDate: moment$1
7970
+ .toDate(), CurrentStart: moment$3.utc(resp.data.CurrentStart).toDate(), CurrentEnd: moment$3.utc(resp.data.CurrentEnd).toDate(), PreviousProductionDate: moment$3
7971
7971
  .utc(resp.data.PreviousProductionDate)
7972
- .toDate(), PreviousStart: moment$1.utc(resp.data.PreviousStart).toDate(), PreviousEnd: moment$1.utc(resp.data.PreviousEnd).toDate(), LastProductionDate: moment$1.utc(resp.data.LastProductionDate).toDate(), LastStart: moment$1.utc(resp.data.LastStart).toDate(), LastEnd: moment$1.utc(resp.data.LastEnd).toDate() });
7972
+ .toDate(), PreviousStart: moment$3.utc(resp.data.PreviousStart).toDate(), PreviousEnd: moment$3.utc(resp.data.PreviousEnd).toDate(), LastProductionDate: moment$3.utc(resp.data.LastProductionDate).toDate(), LastStart: moment$3.utc(resp.data.LastStart).toDate(), LastEnd: moment$3.utc(resp.data.LastEnd).toDate() });
7973
7973
  setShiftInfo(shift);
7974
7974
  return [2 /*return*/, shift];
7975
7975
  }
@@ -7995,11 +7995,11 @@ var useShiftNavigatorManager = function () {
7995
7995
  case 1:
7996
7996
  resp = _a.sent();
7997
7997
  if (resp.ok) {
7998
- shift = __assign(__assign({}, resp.data), { CurrentProductionDate: moment$1
7998
+ shift = __assign(__assign({}, resp.data), { CurrentProductionDate: moment$3
7999
7999
  .utc(resp.data.CurrentProductionDate)
8000
- .toDate(), CurrentStart: moment$1.utc(resp.data.CurrentStart).toDate(), CurrentEnd: moment$1.utc(resp.data.CurrentEnd).toDate(), PreviousProductionDate: moment$1
8000
+ .toDate(), CurrentStart: moment$3.utc(resp.data.CurrentStart).toDate(), CurrentEnd: moment$3.utc(resp.data.CurrentEnd).toDate(), PreviousProductionDate: moment$3
8001
8001
  .utc(resp.data.PreviousProductionDate)
8002
- .toDate(), PreviousStart: moment$1.utc(resp.data.PreviousStart).toDate(), PreviousEnd: moment$1.utc(resp.data.PreviousEnd).toDate(), LastProductionDate: moment$1.utc(resp.data.LastProductionDate).toDate(), LastStart: moment$1.utc(resp.data.LastStart).toDate(), LastEnd: moment$1.utc(resp.data.LastEnd).toDate() });
8002
+ .toDate(), PreviousStart: moment$3.utc(resp.data.PreviousStart).toDate(), PreviousEnd: moment$3.utc(resp.data.PreviousEnd).toDate(), LastProductionDate: moment$3.utc(resp.data.LastProductionDate).toDate(), LastStart: moment$3.utc(resp.data.LastStart).toDate(), LastEnd: moment$3.utc(resp.data.LastEnd).toDate() });
8003
8003
  setShiftInfo(shift);
8004
8004
  return [2 /*return*/, shift];
8005
8005
  }
@@ -8063,7 +8063,7 @@ var ShiftNavigatorProvider = function (_a) {
8063
8063
  return (React__default.createElement(ShiftNavigatorContext.Provider, { value: shiftNavigatorManager }, children));
8064
8064
  };
8065
8065
 
8066
- var moment = getMomentTz();
8066
+ var moment$2 = getMomentTz();
8067
8067
  var ShiftDayNavigatorControl = function (props) {
8068
8068
  var _a;
8069
8069
  var _b = useShiftNavigator(), shiftInfo = _b.shiftInfo, initShiftNavigator = _b.initShiftNavigator, moveShift = _b.moveShift, getShiftDataFromAPI = _b.getShiftDataFromAPI;
@@ -8105,7 +8105,7 @@ var ShiftDayNavigatorControl = function (props) {
8105
8105
  }, size: "small" },
8106
8106
  React__default.createElement(ArrowBackRounded, null)))),
8107
8107
  React__default.createElement(Grid, { item: true },
8108
- React__default.createElement(DatePicker, { label: "Current Date", timezone: "UTC", format: "MM/DD/YYYY", maxDate: moment(), closeOnSelect: true, formatDensity: "dense", value: moment(shiftInfo === null || shiftInfo === void 0 ? void 0 : shiftInfo.CurrentProductionDate), onChange: function (date) {
8108
+ React__default.createElement(DatePicker, { label: "Current Date", timezone: "UTC", format: "MM/DD/YYYY", maxDate: moment$2(), closeOnSelect: true, formatDensity: "dense", value: moment$2(shiftInfo === null || shiftInfo === void 0 ? void 0 : shiftInfo.CurrentProductionDate), onChange: function (date) {
8109
8109
  if (date) {
8110
8110
  getShiftDataFromAPI(date.toDate(), 0).then(function () { });
8111
8111
  }
@@ -8138,51 +8138,389 @@ var ShiftDayNavigatorControl = function (props) {
8138
8138
  React__default.createElement(SkipNext, null)))))));
8139
8139
  };
8140
8140
 
8141
- var useStyles$1 = makeStyles(function (theme) { return ({
8142
- contextMenu: {
8143
- backgroundColor: "#fff",
8144
- borderRadius: "2px",
8145
- padding: "5px 0",
8146
- width: "180px",
8147
- height: "auto",
8148
- margin: "0",
8149
- position: "fixed",
8150
- zIndex: 1,
8151
- listStyle: "none",
8152
- boxShadow: "0 0 20px 0 #ccc",
8153
- "& .MuiMenuItem-root": {
8154
- fontSize: "14px"
8155
- },
8156
- "& .MuiListItemIcon-root": {
8157
- minWidth: "25px",
8158
- padding: "0"
8159
- },
8160
- "& .MuiSvgIcon-root": {
8161
- fontSize: "16px"
8162
- }
8163
- }
8164
- }); });
8141
+ var moment$1 = getMomentTz();
8142
+ var getShiftsRangeByParameters = function (period, Start, End, StartShiftId, EndShiftId, action) {
8143
+ if (Start === void 0) { Start = null; }
8144
+ if (End === void 0) { End = null; }
8145
+ if (StartShiftId === void 0) { StartShiftId = null; }
8146
+ if (EndShiftId === void 0) { EndShiftId = null; }
8147
+ if (action === void 0) { action = null; }
8148
+ return __awaiter(void 0, void 0, void 0, function () {
8149
+ var apiService, resp, data;
8150
+ return __generator(this, function (_a) {
8151
+ switch (_a.label) {
8152
+ case 0:
8153
+ apiService = new MESApiService();
8154
+ return [4 /*yield*/, apiService.callV2("[MES].[GetShiftsRangeByParameters]", [
8155
+ {
8156
+ name: "Period",
8157
+ value: period
8158
+ },
8159
+ {
8160
+ name: "Start",
8161
+ value: Start === null || Start === void 0 ? void 0 : Start.toISOString()
8162
+ },
8163
+ {
8164
+ name: "End",
8165
+ value: End === null || End === void 0 ? void 0 : End.toISOString()
8166
+ },
8167
+ {
8168
+ name: "StartShiftId",
8169
+ value: StartShiftId
8170
+ },
8171
+ {
8172
+ name: "EndShiftId",
8173
+ value: EndShiftId
8174
+ },
8175
+ {
8176
+ name: "Action",
8177
+ value: action
8178
+ },
8179
+ ])];
8180
+ case 1:
8181
+ resp = _a.sent();
8182
+ if (resp.ok) {
8183
+ data = resp.data;
8184
+ data.tables[0].rows.map(function (shift) {
8185
+ shift.Start = moment$1.utc(shift["Start"]).toDate();
8186
+ shift.End = moment$1.utc(shift["End"]).toDate();
8187
+ });
8188
+ return [2 /*return*/, {
8189
+ ok: true,
8190
+ data: data
8191
+ }];
8192
+ }
8193
+ else {
8194
+ return [2 /*return*/, {
8195
+ ok: false,
8196
+ message: resp.message
8197
+ }];
8198
+ }
8199
+ }
8200
+ });
8201
+ });
8202
+ };
8165
8203
 
8166
- var ContextMenuMESFContext = createContext({
8167
- show: false,
8168
- position: { x: 0, y: 0 },
8169
- options: [],
8170
- showContextMenu: function () { },
8171
- registerConfig: function () { },
8172
- onClickOutside: function () { }
8204
+ var useStyles$5 = makeStyles(function (theme) {
8205
+ var _a, _b, _c;
8206
+ return ({
8207
+ container: {
8208
+ display: "flex",
8209
+ alignItems: "center",
8210
+ width: "100%",
8211
+ margin: 0,
8212
+ padding: "8px 0",
8213
+ gap: "8px",
8214
+ flexWrap: "wrap"
8215
+ },
8216
+ gridItem: (_a = {
8217
+ display: "flex",
8218
+ alignItems: "center"
8219
+ },
8220
+ _a[theme.breakpoints.down("sm")] = {
8221
+ width: "100%"
8222
+ },
8223
+ _a),
8224
+ datePickerWrapper: (_b = {
8225
+ flex: 1,
8226
+ minWidth: "280px"
8227
+ },
8228
+ _b[theme.breakpoints.down("sm")] = {
8229
+ minWidth: "100%"
8230
+ },
8231
+ _b),
8232
+ selectWrapper: (_c = {
8233
+ width: "120px"
8234
+ },
8235
+ _c[theme.breakpoints.down("sm")] = {
8236
+ width: "100%"
8237
+ },
8238
+ _c)
8239
+ });
8173
8240
  });
8174
- var ContextMenuMESFProvider = function (_a) {
8175
- var children = _a.children;
8176
- var _b = useState(false), show = _b[0], setShow = _b[1];
8177
- var _c = useState({ x: 0, y: 0 }), position = _c[0], setPosition = _c[1];
8178
- var _d = useState([]), options = _d[0], setOptions = _d[1];
8179
- var _e = useState({}), configs = _e[0], setConfigs = _e[1];
8180
- var currentDataRef = useRef(null);
8181
- var currentConfigIdRef = useRef(null);
8182
- var registerConfig = function (config) {
8183
- setConfigs(function (prev) {
8184
- var _a;
8185
- return (__assign(__assign({}, prev), (_a = {}, _a[config.id] = config, _a)));
8241
+ var moment = getMomentTz();
8242
+ var ShiftPeriodNavigatorControl = function (_a) {
8243
+ var value = _a.value, onChange = _a.onChange;
8244
+ var classes = useStyles$5();
8245
+ var _b = useState("Shift"), period = _b[0], setPeriod = _b[1];
8246
+ var _c = useState(false), loadingShiftPeriodList = _c[0], setLoadingShiftPeriodList = _c[1];
8247
+ var _d = useState(""); _d[0]; var setError = _d[1];
8248
+ var _e = useState([]), shiftPeriodList = _e[0], setShiftPeriodList = _e[1];
8249
+ var _f = useState(false), isActionInProgress = _f[0], setIsActionInProgress = _f[1];
8250
+ var handleArrowNavigation = function (direction) { return __awaiter(void 0, void 0, void 0, function () {
8251
+ var error_1;
8252
+ return __generator(this, function (_a) {
8253
+ switch (_a.label) {
8254
+ case 0:
8255
+ if (!(startShift === null || startShift === void 0 ? void 0 : startShift.Start) && !(endShift === null || endShift === void 0 ? void 0 : endShift.End))
8256
+ return [2 /*return*/];
8257
+ _a.label = 1;
8258
+ case 1:
8259
+ _a.trys.push([1, 6, , 7]);
8260
+ if (!(direction === "prev" && (startShift === null || startShift === void 0 ? void 0 : startShift.Start))) return [3 /*break*/, 3];
8261
+ return [4 /*yield*/, searchShiftsRangeByParameters(period, moment(startShift.Start).toDate(), null, false, "prev")];
8262
+ case 2:
8263
+ _a.sent();
8264
+ return [3 /*break*/, 5];
8265
+ case 3:
8266
+ if (!(direction === "next" && (endShift === null || endShift === void 0 ? void 0 : endShift.End))) return [3 /*break*/, 5];
8267
+ return [4 /*yield*/, searchShiftsRangeByParameters(period, null, moment(endShift.End).toDate(), false, "next")];
8268
+ case 4:
8269
+ _a.sent();
8270
+ _a.label = 5;
8271
+ case 5: return [3 /*break*/, 7];
8272
+ case 6:
8273
+ error_1 = _a.sent();
8274
+ setError(error_1);
8275
+ return [3 /*break*/, 7];
8276
+ case 7: return [2 /*return*/];
8277
+ }
8278
+ });
8279
+ }); };
8280
+ var handleLastShift = function () { return __awaiter(void 0, void 0, void 0, function () {
8281
+ var error_2;
8282
+ return __generator(this, function (_a) {
8283
+ switch (_a.label) {
8284
+ case 0:
8285
+ _a.trys.push([0, 2, , 3]);
8286
+ return [4 /*yield*/, searchShiftsRangeByParameters(period, null, null, false, "last")];
8287
+ case 1:
8288
+ _a.sent();
8289
+ return [3 /*break*/, 3];
8290
+ case 2:
8291
+ error_2 = _a.sent();
8292
+ setError(error_2);
8293
+ return [3 /*break*/, 3];
8294
+ case 3: return [2 /*return*/];
8295
+ }
8296
+ });
8297
+ }); };
8298
+ var searchShiftsRangeByParameters = function (newPeriod, newStartDate, newEndDate, useShiftIds, action) {
8299
+ if (useShiftIds === void 0) { useShiftIds = true; }
8300
+ if (action === void 0) { action = null; }
8301
+ return __awaiter(void 0, void 0, void 0, function () {
8302
+ var res, rowsSource, error_3;
8303
+ var _a, _b;
8304
+ return __generator(this, function (_c) {
8305
+ switch (_c.label) {
8306
+ case 0:
8307
+ if (isActionInProgress)
8308
+ return [2 /*return*/];
8309
+ setIsActionInProgress(true);
8310
+ setLoadingShiftPeriodList(true);
8311
+ _c.label = 1;
8312
+ case 1:
8313
+ _c.trys.push([1, 3, 4, 5]);
8314
+ return [4 /*yield*/, getShiftsRangeByParameters(newPeriod, newStartDate, newEndDate, useShiftIds ? ((_a = value === null || value === void 0 ? void 0 : value.StartShiftId) !== null && _a !== void 0 ? _a : null) : null, useShiftIds ? ((_b = value === null || value === void 0 ? void 0 : value.EndShiftId) !== null && _b !== void 0 ? _b : null) : null, action)];
8315
+ case 2:
8316
+ res = _c.sent();
8317
+ if (res.ok) {
8318
+ rowsSource = get$1(res, "data.tables[0].rows", []);
8319
+ setShiftPeriodList(rowsSource);
8320
+ if (rowsSource.length >= 2) {
8321
+ onChange({
8322
+ StartShiftId: rowsSource[0].ShiftId,
8323
+ EndShiftId: rowsSource[1].ShiftId
8324
+ });
8325
+ }
8326
+ }
8327
+ else {
8328
+ setError(res.message);
8329
+ }
8330
+ return [3 /*break*/, 5];
8331
+ case 3:
8332
+ error_3 = _c.sent();
8333
+ setError(error_3);
8334
+ return [3 /*break*/, 5];
8335
+ case 4:
8336
+ setLoadingShiftPeriodList(false);
8337
+ setIsActionInProgress(false);
8338
+ return [7 /*endfinally*/];
8339
+ case 5: return [2 /*return*/];
8340
+ }
8341
+ });
8342
+ });
8343
+ };
8344
+ var handleDateChange = function (value, key) { return __awaiter(void 0, void 0, void 0, function () {
8345
+ var newDate, error_4;
8346
+ return __generator(this, function (_a) {
8347
+ switch (_a.label) {
8348
+ case 0:
8349
+ if (!value || !value.isValid())
8350
+ return [2 /*return*/];
8351
+ _a.label = 1;
8352
+ case 1:
8353
+ _a.trys.push([1, 6, , 7]);
8354
+ newDate = value.toDate();
8355
+ if (!(key === "start")) return [3 /*break*/, 3];
8356
+ return [4 /*yield*/, searchShiftsRangeByParameters(period, newDate, null, false)];
8357
+ case 2:
8358
+ _a.sent();
8359
+ return [3 /*break*/, 5];
8360
+ case 3: return [4 /*yield*/, searchShiftsRangeByParameters(period, null, newDate, false)];
8361
+ case 4:
8362
+ _a.sent();
8363
+ _a.label = 5;
8364
+ case 5: return [3 /*break*/, 7];
8365
+ case 6:
8366
+ error_4 = _a.sent();
8367
+ setError(error_4);
8368
+ return [3 /*break*/, 7];
8369
+ case 7: return [2 /*return*/];
8370
+ }
8371
+ });
8372
+ }); };
8373
+ var handleChangeScope = function (e) { return __awaiter(void 0, void 0, void 0, function () {
8374
+ var newPeriod;
8375
+ return __generator(this, function (_a) {
8376
+ switch (_a.label) {
8377
+ case 0:
8378
+ newPeriod = e.target.value;
8379
+ setPeriod(newPeriod);
8380
+ return [4 /*yield*/, searchShiftsRangeByParameters(newPeriod, null, (endShift === null || endShift === void 0 ? void 0 : endShift.End) ? moment(endShift.End).toDate() : null, false)];
8381
+ case 1:
8382
+ _a.sent();
8383
+ return [2 /*return*/];
8384
+ }
8385
+ });
8386
+ }); };
8387
+ useEffect(function () {
8388
+ if ((value === null || value === void 0 ? void 0 : value.StartShiftId) || (value === null || value === void 0 ? void 0 : value.EndShiftId)) {
8389
+ searchShiftsRangeByParameters(period, null, null, true);
8390
+ }
8391
+ }, [value === null || value === void 0 ? void 0 : value.StartShiftId, value === null || value === void 0 ? void 0 : value.EndShiftId]);
8392
+ useEffect(function () {
8393
+ searchShiftsRangeByParameters(period, null, null, true);
8394
+ }, []);
8395
+ var startShift = shiftPeriodList[0];
8396
+ var endShift = shiftPeriodList[1];
8397
+ return (React__default.createElement("div", { className: classes.container },
8398
+ React__default.createElement("div", { className: classes.gridItem },
8399
+ React__default.createElement(IconButton$1, { size: "small", color: "primary", disabled: loadingShiftPeriodList, onClick: function () { return handleArrowNavigation("prev"); } },
8400
+ React__default.createElement(ChevronLeft, null))),
8401
+ React__default.createElement("div", { className: "".concat(classes.gridItem, " ").concat(classes.datePickerWrapper) },
8402
+ React__default.createElement(DatePicker$1, { label: "Start", format: "MM/DD/YYYY HH:mm a", value: moment((startShift === null || startShift === void 0 ? void 0 : startShift.Start) || moment().subtract(1, "day")), onChange: function (value) {
8403
+ return handleDateChange(value ? moment(value) : null, "start");
8404
+ }, disabled: loadingShiftPeriodList, slots: {
8405
+ textField: function (props) { return (React__default.createElement(TextField, __assign({}, props, { size: "small", variant: "outlined", fullWidth: true, style: {
8406
+ width: "100%"
8407
+ }, InputProps: __assign(__assign({}, props.InputProps), { style: {
8408
+ height: "50px",
8409
+ paddingTop: "2px"
8410
+ } }) }))); },
8411
+ openPickerIcon: function () { return (React__default.createElement("div", { style: {
8412
+ display: "flex",
8413
+ alignItems: "center",
8414
+ width: "100%"
8415
+ } },
8416
+ React__default.createElement("span", { style: {
8417
+ paddingRight: 5,
8418
+ whiteSpace: "nowrap",
8419
+ overflow: "hidden",
8420
+ textOverflow: "ellipsis",
8421
+ fontSize: 15,
8422
+ fontWeight: "bold"
8423
+ } }, startShift === null || startShift === void 0 ? void 0 :
8424
+ startShift.Shift,
8425
+ " - ", startShift === null || startShift === void 0 ? void 0 :
8426
+ startShift.Crew),
8427
+ React__default.createElement(IconButton$1, { style: { padding: "0px", flexShrink: 0 } },
8428
+ React__default.createElement(CalendarIcon, null)))); }
8429
+ } })),
8430
+ React__default.createElement("div", { className: "".concat(classes.gridItem, " ").concat(classes.selectWrapper) },
8431
+ React__default.createElement(FormControl, { variant: "outlined", size: "small", fullWidth: true },
8432
+ React__default.createElement(Select, { value: period, onChange: handleChangeScope, disabled: loadingShiftPeriodList, style: {
8433
+ height: "50px",
8434
+ width: "100%",
8435
+ paddingTop: 10
8436
+ } },
8437
+ React__default.createElement(MenuItem, { value: "Shift" }, "Shift"),
8438
+ React__default.createElement(MenuItem, { value: "Day" }, "Day"),
8439
+ React__default.createElement(MenuItem, { value: "4Days" }, "4 Days"),
8440
+ React__default.createElement(MenuItem, { value: "Week" }, "Week"),
8441
+ React__default.createElement(MenuItem, { value: "Month" }, "Month")))),
8442
+ React__default.createElement("div", { className: "".concat(classes.gridItem, " ").concat(classes.datePickerWrapper) },
8443
+ React__default.createElement(DatePicker$1, { label: "End", format: "MM/DD/YYYY HH:mm a", value: moment((endShift === null || endShift === void 0 ? void 0 : endShift.Start) || moment().subtract(1, "day")), onChange: function (value) {
8444
+ return handleDateChange(value ? moment(value) : null, "end");
8445
+ }, disabled: loadingShiftPeriodList, slots: {
8446
+ textField: function (props) { return (React__default.createElement(TextField, __assign({}, props, { size: "small", variant: "outlined", fullWidth: true, style: {
8447
+ width: "100%"
8448
+ }, InputProps: __assign(__assign({}, props.InputProps), { style: {
8449
+ height: "50px",
8450
+ paddingTop: "2px"
8451
+ } }) }))); },
8452
+ openPickerIcon: function () { return (React__default.createElement("div", { style: {
8453
+ display: "flex",
8454
+ alignItems: "center",
8455
+ width: "100%"
8456
+ } },
8457
+ React__default.createElement("span", { style: {
8458
+ paddingRight: 5,
8459
+ whiteSpace: "nowrap",
8460
+ overflow: "hidden",
8461
+ textOverflow: "ellipsis",
8462
+ fontSize: 15,
8463
+ fontWeight: "bold"
8464
+ } }, endShift === null || endShift === void 0 ? void 0 :
8465
+ endShift.Shift,
8466
+ " - ", endShift === null || endShift === void 0 ? void 0 :
8467
+ endShift.Crew),
8468
+ React__default.createElement(IconButton$1, { style: { padding: "4px", flexShrink: 0 } },
8469
+ React__default.createElement(CalendarIcon, null)))); }
8470
+ } })),
8471
+ React__default.createElement("div", { className: classes.gridItem },
8472
+ React__default.createElement(IconButton$1, { size: "small", disabled: loadingShiftPeriodList, onClick: function () { return handleArrowNavigation("next"); } },
8473
+ React__default.createElement(ChevronRight, null))),
8474
+ React__default.createElement("div", { className: classes.gridItem },
8475
+ React__default.createElement(IconButton$1, { size: "small", disabled: loadingShiftPeriodList, onClick: handleLastShift },
8476
+ React__default.createElement(SkipNextIcon, null)))));
8477
+ };
8478
+
8479
+ var useStyles$4 = makeStyles(function (theme) { return ({
8480
+ contextMenu: {
8481
+ backgroundColor: "#fff",
8482
+ borderRadius: "2px",
8483
+ padding: "5px 0",
8484
+ width: "180px",
8485
+ height: "auto",
8486
+ margin: "0",
8487
+ position: "fixed",
8488
+ zIndex: 1,
8489
+ listStyle: "none",
8490
+ boxShadow: "0 0 20px 0 #ccc",
8491
+ "& .MuiMenuItem-root": {
8492
+ fontSize: "14px"
8493
+ },
8494
+ "& .MuiListItemIcon-root": {
8495
+ minWidth: "25px",
8496
+ padding: "0"
8497
+ },
8498
+ "& .MuiSvgIcon-root": {
8499
+ fontSize: "16px"
8500
+ }
8501
+ }
8502
+ }); });
8503
+
8504
+ var ContextMenuMESFContext = createContext({
8505
+ show: false,
8506
+ position: { x: 0, y: 0 },
8507
+ options: [],
8508
+ showContextMenu: function () { },
8509
+ registerConfig: function () { },
8510
+ onClickOutside: function () { }
8511
+ });
8512
+ var ContextMenuMESFProvider = function (_a) {
8513
+ var children = _a.children;
8514
+ var _b = useState(false), show = _b[0], setShow = _b[1];
8515
+ var _c = useState({ x: 0, y: 0 }), position = _c[0], setPosition = _c[1];
8516
+ var _d = useState([]), options = _d[0], setOptions = _d[1];
8517
+ var _e = useState({}), configs = _e[0], setConfigs = _e[1];
8518
+ var currentDataRef = useRef(null);
8519
+ var currentConfigIdRef = useRef(null);
8520
+ var registerConfig = function (config) {
8521
+ setConfigs(function (prev) {
8522
+ var _a;
8523
+ return (__assign(__assign({}, prev), (_a = {}, _a[config.id] = config, _a)));
8186
8524
  });
8187
8525
  };
8188
8526
  var showContextMenu = function (e, data, configId) {
@@ -8230,7 +8568,7 @@ var useContextMenuMESF = function () { return useContext(ContextMenuMESFContext)
8230
8568
 
8231
8569
  var ContextMenu$1 = function () {
8232
8570
  var _a = useContextMenuMESF(), show = _a.show, position = _a.position, options = _a.options;
8233
- var classes = useStyles$1();
8571
+ var classes = useStyles$4();
8234
8572
  var menuRef = useRef(null);
8235
8573
  var _b = useState("0"), x = _b[0], setX = _b[1];
8236
8574
  var _c = useState("0"), y = _c[0], setY = _c[1];
@@ -8959,241 +9297,978 @@ var LoginWithAzureAD = function (_a) {
8959
9297
  React__default.createElement(LoginWithAzureADForm, null))));
8960
9298
  };
8961
9299
 
8962
- function Login(_a) {
8963
- var authConfig = _a.authConfig;
8964
- var params = useRef(new URL(document.location).searchParams);
8965
- var _b = useState(false), open = _b[0], setOpen = _b[1];
8966
- var _c = useState(""), message = _c[0], setMessage = _c[1];
8967
- var useEmailAndPassword = get$1(authConfig, "useEmailAndPassword", true);
8968
- var useAzureAD = get$1(authConfig, "useAzureAD", false);
8969
- var useWindowsAuth = get$1(authConfig, "useWindowsAuth", false);
8970
- var guestIsEnabled = get$1(authConfig, "guestIsEnabled", false);
8971
- var handleClose = function () {
8972
- setOpen(false);
8973
- params.current["delete"]("message");
8974
- var newUrl = window.location.origin + "?" + params.current.toString();
8975
- window.history.replaceState({ path: newUrl }, "", newUrl);
8976
- };
8977
- useEffect(function () {
8978
- if (params.current.has("message")) {
8979
- setMessage(params.current.get("message"));
8980
- setOpen(true);
8981
- }
8982
- }, [params.toString()]);
8983
- return (React__default.createElement(React__default.Fragment, null,
8984
- React__default.createElement("header", null,
8985
- React__default.createElement(Navbar, { variant: "dark", expand: "lg", className: "mes-primary-color mes-menu-top" },
8986
- React__default.createElement(Navbar.Brand, { href: "/" }, "MESF"))),
8987
- React__default.createElement("div", { className: "container-fluid" },
8988
- React__default.createElement("div", { className: "row" },
8989
- React__default.createElement("div", { className: "col-10 col-md-6 mx-auto my-5" },
8990
- React__default.createElement(Paper, { elevation: 2 },
8991
- React__default.createElement("div", { className: "card-header text-center" },
8992
- React__default.createElement("b", null, "LOGIN")),
8993
- React__default.createElement(Grid, { container: true, justifyContent: "space-between", alignItems: "center" }, !useAzureAD && !guestIsEnabled && !useWindowsAuth ? (React__default.createElement(Grid, { item: true, xs: 12 },
8994
- React__default.createElement(Paper, { elevation: 2, style: { padding: 40, margin: "40px 40px 40px 40px" } }, useEmailAndPassword && React__default.createElement(LoginWithEmailAndPassword, null)))) : (React__default.createElement(React__default.Fragment, null,
8995
- React__default.createElement(Grid, { item: true, md: 5, xs: 5 },
8996
- React__default.createElement(Paper, { elevation: 2, style: { padding: 40, margin: "40px -40px 40px 40px" } }, useEmailAndPassword && React__default.createElement(LoginWithEmailAndPassword, null))),
8997
- React__default.createElement(Grid, { item: true, md: 1, xs: 1, style: { maxWidth: "20px" } },
8998
- React__default.createElement("span", { className: "text-muted font-weight-bold" }, "OR")),
8999
- React__default.createElement(Grid, { item: true, md: 5, xs: 5, style: { marginBottom: "auto" } },
9000
- React__default.createElement(Paper, { elevation: 2, style: {
9001
- padding: 40,
9002
- margin: "40px 40px 40px -40px",
9003
- minHeight: 248,
9004
- display: "flex",
9005
- flexDirection: "column",
9006
- justifyContent: "space-evenly"
9007
- } },
9008
- React__default.createElement(React__default.Fragment, null,
9009
- React__default.createElement(LoginWithWindowsAuthentication, null),
9010
- useAzureAD && (React__default.createElement(LoginWithAzureAD, { config: authConfig.AzureConfig })),
9011
- guestIsEnabled && React__default.createElement(LoginAsGuest, null))))))))))),
9012
- React__default.createElement(Snackbar, { open: open, autoHideDuration: 6000, onClose: handleClose, message: message })));
9013
- }
9014
-
9015
- function Logout() {
9016
- var clearUserData = useContext(AuthContext).clearUserData;
9017
- var navigate = useNavigate();
9018
- var _a = useSearchParams(), params = _a[0]; _a[1];
9019
- var logout = function () {
9020
- clearUserData();
9021
- navigate("/?".concat(params.toString()));
9300
+ function Login(_a) {
9301
+ var authConfig = _a.authConfig;
9302
+ var params = useRef(new URL(document.location).searchParams);
9303
+ var _b = useState(false), open = _b[0], setOpen = _b[1];
9304
+ var _c = useState(""), message = _c[0], setMessage = _c[1];
9305
+ var useEmailAndPassword = get$1(authConfig, "useEmailAndPassword", true);
9306
+ var useAzureAD = get$1(authConfig, "useAzureAD", false);
9307
+ var useWindowsAuth = get$1(authConfig, "useWindowsAuth", false);
9308
+ var guestIsEnabled = get$1(authConfig, "guestIsEnabled", false);
9309
+ var handleClose = function () {
9310
+ setOpen(false);
9311
+ params.current["delete"]("message");
9312
+ var newUrl = window.location.origin + "?" + params.current.toString();
9313
+ window.history.replaceState({ path: newUrl }, "", newUrl);
9314
+ };
9315
+ useEffect(function () {
9316
+ if (params.current.has("message")) {
9317
+ setMessage(params.current.get("message"));
9318
+ setOpen(true);
9319
+ }
9320
+ }, [params.toString()]);
9321
+ return (React__default.createElement(React__default.Fragment, null,
9322
+ React__default.createElement("header", null,
9323
+ React__default.createElement(Navbar, { variant: "dark", expand: "lg", className: "mes-primary-color mes-menu-top" },
9324
+ React__default.createElement(Navbar.Brand, { href: "/" }, "MESF"))),
9325
+ React__default.createElement("div", { className: "container-fluid" },
9326
+ React__default.createElement("div", { className: "row" },
9327
+ React__default.createElement("div", { className: "col-10 col-md-6 mx-auto my-5" },
9328
+ React__default.createElement(Paper, { elevation: 2 },
9329
+ React__default.createElement("div", { className: "card-header text-center" },
9330
+ React__default.createElement("b", null, "LOGIN")),
9331
+ React__default.createElement(Grid, { container: true, justifyContent: "space-between", alignItems: "center" }, !useAzureAD && !guestIsEnabled && !useWindowsAuth ? (React__default.createElement(Grid, { item: true, xs: 12 },
9332
+ React__default.createElement(Paper, { elevation: 2, style: { padding: 40, margin: "40px 40px 40px 40px" } }, useEmailAndPassword && React__default.createElement(LoginWithEmailAndPassword, null)))) : (React__default.createElement(React__default.Fragment, null,
9333
+ React__default.createElement(Grid, { item: true, md: 5, xs: 5 },
9334
+ React__default.createElement(Paper, { elevation: 2, style: { padding: 40, margin: "40px -40px 40px 40px" } }, useEmailAndPassword && React__default.createElement(LoginWithEmailAndPassword, null))),
9335
+ React__default.createElement(Grid, { item: true, md: 1, xs: 1, style: { maxWidth: "20px" } },
9336
+ React__default.createElement("span", { className: "text-muted font-weight-bold" }, "OR")),
9337
+ React__default.createElement(Grid, { item: true, md: 5, xs: 5, style: { marginBottom: "auto" } },
9338
+ React__default.createElement(Paper, { elevation: 2, style: {
9339
+ padding: 40,
9340
+ margin: "40px 40px 40px -40px",
9341
+ minHeight: 248,
9342
+ display: "flex",
9343
+ flexDirection: "column",
9344
+ justifyContent: "space-evenly"
9345
+ } },
9346
+ React__default.createElement(React__default.Fragment, null,
9347
+ React__default.createElement(LoginWithWindowsAuthentication, null),
9348
+ useAzureAD && (React__default.createElement(LoginWithAzureAD, { config: authConfig.AzureConfig })),
9349
+ guestIsEnabled && React__default.createElement(LoginAsGuest, null))))))))))),
9350
+ React__default.createElement(Snackbar, { open: open, autoHideDuration: 6000, onClose: handleClose, message: message })));
9351
+ }
9352
+
9353
+ function Logout() {
9354
+ var clearUserData = useContext(AuthContext).clearUserData;
9355
+ var navigate = useNavigate();
9356
+ var _a = useSearchParams(), params = _a[0]; _a[1];
9357
+ var logout = function () {
9358
+ clearUserData();
9359
+ navigate("/?".concat(params.toString()));
9360
+ };
9361
+ useEffect(function () {
9362
+ logout();
9363
+ }, []);
9364
+ return (React__default.createElement(React__default.Fragment, null,
9365
+ React__default.createElement("div", null, "logging out!!!")));
9366
+ }
9367
+
9368
+ var RouterContext = createContext(function () { return React__default.createElement(React__default.Fragment, null); });
9369
+ var ConfigurationContext = createContext([
9370
+ [],
9371
+ function () { return React__default.createElement(React__default.Fragment, null); },
9372
+ ]);
9373
+ var NavbarContext = createContext(function () { return React__default.createElement(React__default.Fragment, null); });
9374
+
9375
+ var useSearchAssets = function (setError) {
9376
+ var _a = useAssetContext().actions, setAllAssets = _a.setAllAssets, setAreasList = _a.setAreasList;
9377
+ var searchAssets = function () {
9378
+ getAssets().then(function (res) { return __awaiter(void 0, void 0, void 0, function () {
9379
+ var rows, areas;
9380
+ return __generator(this, function (_a) {
9381
+ switch (_a.label) {
9382
+ case 0:
9383
+ if (!res.ok) return [3 /*break*/, 2];
9384
+ rows = get$1(res, "data.tables[0].rows", []);
9385
+ return [4 /*yield*/, rows.filter(function (asset) { return asset.CanBeDefaultAsset; })];
9386
+ case 1:
9387
+ areas = _a.sent();
9388
+ setAllAssets(rows);
9389
+ setAreasList(areas);
9390
+ return [3 /*break*/, 3];
9391
+ case 2:
9392
+ setError(res.message);
9393
+ _a.label = 3;
9394
+ case 3: return [2 /*return*/];
9395
+ }
9396
+ });
9397
+ }); });
9398
+ };
9399
+ return { searchAssets: searchAssets };
9400
+ };
9401
+
9402
+ var UTLSettingsInitialState = {
9403
+ serverTimeZone: Intl.DateTimeFormat().resolvedOptions().timeZone,
9404
+ settings: {}
9405
+ };
9406
+ var UTLSettingsReducer = createSlice({
9407
+ name: "__",
9408
+ initialState: UTLSettingsInitialState,
9409
+ reducers: {
9410
+ setServerTimeZone: function (state, _a) {
9411
+ var payload = _a.payload;
9412
+ state.serverTimeZone = payload;
9413
+ },
9414
+ setSetting: function (state, _a) {
9415
+ var payload = _a.payload;
9416
+ state.settings[payload.key] = payload.value;
9417
+ },
9418
+ initSettings: function (state, _a) {
9419
+ var payload = _a.payload;
9420
+ state.settings = payload.reduce(function (acc, cur) {
9421
+ if (cur.SettingName.trim() === "TimeZone") {
9422
+ var timeService = TimeService.getInstance();
9423
+ timeService.setTimeZone(cur.Value);
9424
+ }
9425
+ acc[cur.SettingName.trim()] = cur.Value;
9426
+ return acc;
9427
+ }, {});
9428
+ }
9429
+ }
9430
+ });
9431
+
9432
+ var UTLSettingsContext = createContext({
9433
+ state: UTLSettingsReducer.getInitialState(),
9434
+ actions: UTLSettingsReducer.actions
9435
+ });
9436
+ var useUTLSettingsContext = function () { return useContext(UTLSettingsContext); };
9437
+ var UTLSettingsProvider = function (_a) {
9438
+ var children = _a.children;
9439
+ var _b = useComplexState({
9440
+ initialState: UTLSettingsReducer.getInitialState(),
9441
+ reducers: UTLSettingsReducer.caseReducers
9442
+ }), state = _b[0], actions = _b[1];
9443
+ return (React__default.createElement(UTLSettingsContext.Provider, { value: { state: state, actions: actions } }, children));
9444
+ };
9445
+
9446
+ var useSearchUTLSettings = function (_a) {
9447
+ var onError = _a.onError;
9448
+ var initSettings = useUTLSettingsContext().actions.initSettings;
9449
+ var searchUTLSettings = function () { return __awaiter(void 0, void 0, void 0, function () {
9450
+ var res, settings;
9451
+ return __generator(this, function (_a) {
9452
+ switch (_a.label) {
9453
+ case 0: return [4 /*yield*/, getUTLSettings()];
9454
+ case 1:
9455
+ res = _a.sent();
9456
+ if (res.ok) {
9457
+ settings = get$1(res, "data.tables[0].rows", []);
9458
+ initSettings(settings);
9459
+ }
9460
+ else {
9461
+ onError(res.message);
9462
+ }
9463
+ return [2 /*return*/];
9464
+ }
9465
+ });
9466
+ }); };
9467
+ return { searchUTLSettings: searchUTLSettings };
9468
+ };
9469
+
9470
+ var AreaSelector$1 = lazy(function () {
9471
+ return Promise.resolve().then(function () { return areaSelector; }).then(function (mod) { return ({
9472
+ "default": mod.AreaSelector
9473
+ }); });
9474
+ });
9475
+ function Header$1(_a) {
9476
+ var _b = _a.showAreaSelector, showAreaSelector = _b === void 0 ? false : _b, _c = _a.showTrendingsIcon, showTrendingsIcon = _c === void 0 ? true : _c, _d = _a.navbarTitle, navbarTitle = _d === void 0 ? "MESF" : _d;
9477
+ var getUserName = useToken().getUserName;
9478
+ var _e = useState(""), error = _e[0], setError = _e[1];
9479
+ var _f = useState(new Date()), date = _f[0], setDate = _f[1];
9480
+ var CustomNavbar = useContext(NavbarContext);
9481
+ var userName = useState(getUserName())[0];
9482
+ var searchAssets = useSearchAssets(setError).searchAssets;
9483
+ var _g = useState(false), settingsIsReady = _g[0], setSettingsIsReady = _g[1];
9484
+ var searchUTLSettings = useSearchUTLSettings({
9485
+ onError: setError
9486
+ }).searchUTLSettings;
9487
+ var userLogged = useUserContext().state.userLogged;
9488
+ var tick = function () {
9489
+ setDate(new Date());
9490
+ };
9491
+ useEffect(function () {
9492
+ var timerID = setTimeout(function () {
9493
+ tick();
9494
+ }, 1000);
9495
+ return function () {
9496
+ clearTimeout(timerID);
9497
+ };
9498
+ });
9499
+ useEffect(function () {
9500
+ searchUTLSettings().then(function () {
9501
+ setSettingsIsReady(true);
9502
+ });
9503
+ }, []);
9504
+ useEffect(function () {
9505
+ if (showAreaSelector && userLogged && settingsIsReady) {
9506
+ searchAssets();
9507
+ }
9508
+ }, [userLogged, settingsIsReady]);
9509
+ return (React__default.createElement(Navbar, { variant: "dark", expand: "lg", className: "mes-primary-color mes-menu-top" },
9510
+ React__default.createElement(Container, { fluid: true },
9511
+ React__default.createElement(Navbar.Brand, { as: Link, to: "/home" }, navbarTitle),
9512
+ React__default.createElement(Navbar.Toggle, { "aria-controls": "basic-navbar-nav" }),
9513
+ React__default.createElement(Navbar.Collapse, { id: "basic-navbar-nav" },
9514
+ React__default.createElement(Nav, { className: "me-auto" },
9515
+ React__default.createElement(CustomNavbar, null)),
9516
+ React__default.createElement(Nav, { className: "ml-auto", style: { alignItems: "baseline" } },
9517
+ showTrendingsIcon ? (React__default.createElement(Nav, { className: "mx-2" },
9518
+ React__default.createElement(Nav.Link, { as: Link, to: "/trendings" },
9519
+ React__default.createElement(Tooltip, { title: "Trendings", placement: "top", arrow: true, interactive: true, enterDelay: 1500 },
9520
+ React__default.createElement(ShowChartIcon, null))))) : null,
9521
+ React__default.createElement(Nav, null,
9522
+ React__default.createElement("span", { className: "navbar-text" }, dxtToLocalServerTime(date, "HH:mm:ss z"))),
9523
+ React__default.createElement(Nav, { className: "mx-2" },
9524
+ React__default.createElement(Nav.Link, { as: Link, to: "/configuration" },
9525
+ React__default.createElement(SettingsIcon, null))),
9526
+ showAreaSelector ? (React__default.createElement(Suspense, { fallback: "..." },
9527
+ React__default.createElement(AreaSelector$1, null))) : null,
9528
+ React__default.createElement(NavDropdown, { id: "user-menu", title: React__default.createElement(React__default.Fragment, null,
9529
+ React__default.createElement("i", { className: "fas fa-user", style: { marginRight: 6 } }),
9530
+ userName), className: "mx-2" },
9531
+ React__default.createElement(NavDropdown.Item, { href: "account" }, "Account"),
9532
+ React__default.createElement(NavDropdown.Item, { href: "logout" }, "Logout"))))),
9533
+ React__default.createElement(ErrorModal, { error: error, onHide: function () { return setError(""); } })));
9534
+ }
9535
+
9536
+ var SettingsInitialState = {
9537
+ settings: [],
9538
+ settingSelected: null
9539
+ };
9540
+ var SettingsReducer = createSlice({
9541
+ name: "__",
9542
+ initialState: SettingsInitialState,
9543
+ reducers: {
9544
+ setSettings: function (state, _a) {
9545
+ var payload = _a.payload;
9546
+ state.settings = payload;
9547
+ },
9548
+ setSettingSelected: function (state, _a) {
9549
+ var payload = _a.payload;
9550
+ state.settingSelected = payload;
9551
+ }
9552
+ }
9553
+ });
9554
+
9555
+ var SettingsContext = createContext({
9556
+ state: SettingsReducer.getInitialState(),
9557
+ actions: SettingsReducer.actions
9558
+ });
9559
+ var useSettingsContext = function () { return useContext(SettingsContext); };
9560
+ var SettingsProvider = function (_a) {
9561
+ var children = _a.children;
9562
+ var _b = useComplexState({
9563
+ initialState: SettingsReducer.getInitialState(),
9564
+ reducers: SettingsReducer.caseReducers
9565
+ }), state = _b[0], actions = _b[1];
9566
+ return (React__default.createElement(SettingsContext.Provider, { value: { state: state, actions: actions } }, children));
9567
+ };
9568
+
9569
+ var useStyles$3 = makeStyles(function (theme) { return ({
9570
+ root: {
9571
+ "& .ag-icon-menu": {
9572
+ display: "none"
9573
+ },
9574
+ "& .ag-header-cell-label": {
9575
+ display: "flex",
9576
+ alignItems: "center",
9577
+ justifyContent: "center",
9578
+ fontSize: "2vh"
9579
+ },
9580
+ "& .ag-header-cell-text": {
9581
+ textAlign: "center !important"
9582
+ },
9583
+ "& .ag-checkbox-input-wrapper": {
9584
+ margin: "0 10px"
9585
+ },
9586
+ "& .ag-cell": {
9587
+ alignItems: "center",
9588
+ padding: "0 !important",
9589
+ border: "unset !important"
9590
+ },
9591
+ "& .ag-header-cell": {
9592
+ padding: "0px !important",
9593
+ textAlign: "center !important",
9594
+ fontSize: 10,
9595
+ display: "flex",
9596
+ alignItems: "center",
9597
+ justifyContent: "center"
9598
+ },
9599
+ "& .ag-cell-wrapper": {
9600
+ textAlign: "center"
9601
+ },
9602
+ "& .ag-menu-option": {
9603
+ cursor: "pointer"
9604
+ }
9605
+ },
9606
+ relative: {
9607
+ position: "relative"
9608
+ },
9609
+ textfield: {
9610
+ margin: theme.spacing(2)
9611
+ },
9612
+ btnModal: {
9613
+ display: "flex",
9614
+ justifyContent: "flex-end"
9615
+ }
9616
+ }); });
9617
+
9618
+ var useSettingsOptionsFunctions = function (_a) {
9619
+ var setSettingId = _a.setSettingId, setShowDeleteModal = _a.setShowDeleteModal, setShowCreateModal = _a.setShowCreateModal, setShowEditModal = _a.setShowEditModal;
9620
+ var getMenuOptions = function (data) {
9621
+ var options = [];
9622
+ if (!data) {
9623
+ options = options.concat([
9624
+ {
9625
+ name: "New Setting",
9626
+ key: "new_setting",
9627
+ onClick: function () {
9628
+ setShowCreateModal(true);
9629
+ },
9630
+ icon: React__default.createElement(PlaylistAddIcon, null)
9631
+ },
9632
+ ]);
9633
+ }
9634
+ else {
9635
+ options = options.concat([
9636
+ {
9637
+ name: "New Setting",
9638
+ key: "new_setting",
9639
+ onClick: function () {
9640
+ setShowCreateModal(true);
9641
+ },
9642
+ icon: React__default.createElement(PlaylistAddIcon, null)
9643
+ },
9644
+ {
9645
+ name: "Edit Setting",
9646
+ key: "edit_setting",
9647
+ onClick: function () {
9648
+ setSettingId(data);
9649
+ setShowEditModal(true);
9650
+ },
9651
+ icon: React__default.createElement(EditIcon, null)
9652
+ },
9653
+ {
9654
+ name: "Delete Setting",
9655
+ key: "delete_setting",
9656
+ onClick: function () {
9657
+ setSettingId(data);
9658
+ setShowDeleteModal(true);
9659
+ },
9660
+ icon: React__default.createElement(DeleteIcon, null)
9661
+ },
9662
+ ]);
9663
+ }
9664
+ return options;
9665
+ };
9666
+ return {
9667
+ getMenuOptions: getMenuOptions
9668
+ };
9669
+ };
9670
+
9671
+ var useStyles$2 = makeStyles(function (theme) { return ({
9672
+ root: {
9673
+ opacity: 0,
9674
+ transition: "opacity 0.1s ease-in-out",
9675
+ ".ag-row-hover &": {
9676
+ opacity: 1
9677
+ },
9678
+ ".ag-row-focus &": {
9679
+ opacity: 1
9680
+ },
9681
+ ".ag-row-selected &": {
9682
+ opacity: 1
9683
+ }
9684
+ }
9685
+ }); });
9686
+ var useTableData = function (_a) {
9687
+ var setOpenModalEditSetting = _a.setOpenModalEditSetting, setOpenModalDeleteSetting = _a.setOpenModalDeleteSetting, showContextMenu = _a.showContextMenu;
9688
+ var _b = useSettingsContext(); _b.state; var actions = _b.actions;
9689
+ var classes = useStyles$2();
9690
+ var columnDefs = [
9691
+ {
9692
+ field: "SettingName",
9693
+ headerName: "Name",
9694
+ minWidth: 180,
9695
+ flex: 4,
9696
+ cellStyle: {
9697
+ display: "flex",
9698
+ alignItems: "center",
9699
+ justifyContent: "center"
9700
+ }
9701
+ },
9702
+ {
9703
+ field: "Value",
9704
+ headerName: "Value",
9705
+ minWidth: 180,
9706
+ flex: 2,
9707
+ cellStyle: {
9708
+ display: "flex",
9709
+ alignItems: "center",
9710
+ justifyContent: "center"
9711
+ }
9712
+ },
9713
+ {
9714
+ field: "Description",
9715
+ headerName: "Description",
9716
+ minWidth: 150,
9717
+ flex: 4,
9718
+ cellStyle: {
9719
+ display: "flex",
9720
+ alignItems: "center",
9721
+ justifyContent: "center"
9722
+ }
9723
+ },
9724
+ {
9725
+ cellRenderer: function (params) {
9726
+ return (React__default.createElement(Grid, { container: true, style: {
9727
+ height: "100%",
9728
+ display: "flex",
9729
+ justifyContent: "center",
9730
+ alignItems: "center"
9731
+ }, className: classes.root },
9732
+ React__default.createElement(Grid, { item: true, xs: 12, md: 12, style: {
9733
+ display: "flex",
9734
+ justifyContent: "center",
9735
+ alignItems: "center"
9736
+ } },
9737
+ React__default.createElement(Button, { style: {}, onClick: function () {
9738
+ (function () { return __awaiter(void 0, void 0, void 0, function () {
9739
+ return __generator(this, function (_a) {
9740
+ actions.setSettingSelected(params === null || params === void 0 ? void 0 : params.data);
9741
+ setOpenModalEditSetting(true);
9742
+ return [2 /*return*/];
9743
+ });
9744
+ }); })();
9745
+ } },
9746
+ React__default.createElement(EditIcon, { color: "primary" })),
9747
+ React__default.createElement(Button, { style: {}, onClick: function () {
9748
+ (function () { return __awaiter(void 0, void 0, void 0, function () {
9749
+ return __generator(this, function (_a) {
9750
+ actions.setSettingSelected(params === null || params === void 0 ? void 0 : params.data);
9751
+ setOpenModalDeleteSetting(true);
9752
+ return [2 /*return*/];
9753
+ });
9754
+ }); })();
9755
+ } },
9756
+ React__default.createElement(DeleteIcon, { color: "secondary" })),
9757
+ React__default.createElement(Button, { style: {}, onClick: function (e) {
9758
+ return showContextMenu(e, params.data, "TableSettings");
9759
+ } },
9760
+ React__default.createElement(FormatListBulletedSharpIcon, { color: "action" })))));
9761
+ },
9762
+ field: "",
9763
+ flex: 1,
9764
+ minWidth: 240,
9765
+ editable: false,
9766
+ autoHeight: false,
9767
+ suppressNavigable: true
9768
+ },
9769
+ ];
9770
+ var defaultColDef = useMemo(function () {
9771
+ return {
9772
+ sortable: true,
9773
+ wrapText: true,
9774
+ autoHeight: true,
9775
+ wrapHeaderText: true
9776
+ };
9777
+ }, []);
9778
+ return { columnDefs: columnDefs, defaultColDef: defaultColDef };
9779
+ };
9780
+
9781
+ var INITIAL_VALUES = {
9782
+ SettingId: null,
9783
+ SettingName: "",
9784
+ Value: "",
9785
+ Description: ""
9786
+ };
9787
+
9788
+ var upsertSettings = function (_a) {
9789
+ var SettingId = _a.SettingId, Description = _a.Description, SettingName = _a.SettingName, Value = _a.Value;
9790
+ return __awaiter(void 0, void 0, void 0, function () {
9791
+ var apiService, parameters, resp;
9792
+ return __generator(this, function (_b) {
9793
+ switch (_b.label) {
9794
+ case 0:
9795
+ apiService = new MESApiService();
9796
+ parameters = [];
9797
+ parameters.push({ name: "SettingId", value: SettingId });
9798
+ parameters.push({ name: "SettingName", value: SettingName });
9799
+ parameters.push({ name: "Description", value: Description });
9800
+ parameters.push({ name: "Value", value: Value });
9801
+ return [4 /*yield*/, apiService.callV2("[UTL].[SetSetting]", parameters)];
9802
+ case 1:
9803
+ resp = _b.sent();
9804
+ return [2 /*return*/, resp];
9805
+ }
9806
+ });
9807
+ });
9808
+ };
9809
+ var deleteSetting = function (SettingId) { return __awaiter(void 0, void 0, void 0, function () {
9810
+ var apiService, parameters, resp;
9811
+ return __generator(this, function (_a) {
9812
+ switch (_a.label) {
9813
+ case 0:
9814
+ apiService = new MESApiService();
9815
+ parameters = [];
9816
+ parameters.push({ name: "SettingId", value: SettingId });
9817
+ return [4 /*yield*/, apiService.callV2("[UTL].[DeleteSetting]", parameters)];
9818
+ case 1:
9819
+ resp = _a.sent();
9820
+ return [2 /*return*/, resp];
9821
+ }
9822
+ });
9823
+ }); };
9824
+
9825
+ var useStyles$1 = makeStyles(function (theme) { return ({
9826
+ title: {
9827
+ fontSize: 15
9828
+ },
9829
+ modalTitle: {
9830
+ fontSize: 15,
9831
+ marginTop: theme.spacing(1)
9832
+ },
9833
+ chip: {
9834
+ margin: 2
9835
+ },
9836
+ errorLabel: {
9837
+ fontSize: 12,
9838
+ color: "#F44336"
9839
+ },
9840
+ infoLabel: {
9841
+ fontSize: 12,
9842
+ color: "#757575"
9843
+ }
9844
+ }); });
9845
+ var CreateSetting = function (_a) {
9846
+ var show = _a.show, onHide = _a.onHide;
9847
+ var _b = useState(false), open = _b[0], setOpen = _b[1];
9848
+ var _c = useState(false), isSubmitLoading = _c[0], setIsSubmitLoading = _c[1];
9849
+ var _d = useState(""), error = _d[0], setError = _d[1];
9850
+ useStyles$1();
9851
+ var settingSelected = useSettingsContext().state.settingSelected;
9852
+ var _e = useForm({
9853
+ defaultValues: settingSelected ? settingSelected : INITIAL_VALUES
9854
+ }), control = _e.control, handleSubmit = _e.handleSubmit, reset = _e.reset; _e.watch; _e.setValue; _e.formState.errors;
9855
+ // Progress bar
9856
+ var onSubmit = function (data) { return __awaiter(void 0, void 0, void 0, function () {
9857
+ var settingsResp;
9858
+ return __generator(this, function (_a) {
9859
+ switch (_a.label) {
9860
+ case 0:
9861
+ setIsSubmitLoading(true);
9862
+ return [4 /*yield*/, upsertSettings(data)];
9863
+ case 1:
9864
+ settingsResp = _a.sent();
9865
+ if (settingsResp.ok) {
9866
+ setIsSubmitLoading(false);
9867
+ setOpen(true);
9868
+ onHide(true);
9869
+ }
9870
+ else {
9871
+ setIsSubmitLoading(false);
9872
+ setError(settingsResp.message);
9873
+ }
9874
+ return [2 /*return*/];
9875
+ }
9876
+ });
9877
+ }); };
9878
+ var handleClose = function (event, reason) {
9879
+ if (reason === "clickaway") {
9880
+ return;
9881
+ }
9882
+ setOpen(false);
9883
+ };
9884
+ useEffect(function () {
9885
+ if (show) {
9886
+ reset();
9887
+ }
9888
+ }, [show]);
9889
+ return (React.createElement(React.Fragment, null,
9890
+ React.createElement(Grid, { container: true },
9891
+ React.createElement(Grid, { item: true },
9892
+ React.createElement(MesfModal, { title: "NEW SETTING/CREW", open: show, handleClose: function () { return onHide(false); }, id: "create-setting-modal", maxWidth: "md" },
9893
+ React.createElement("form", { onSubmit: handleSubmit(onSubmit) },
9894
+ React.createElement(MesfModal.Content, { style: { padding: "15px 30px 0" } },
9895
+ React.createElement(Grid, { container: true, spacing: 2 },
9896
+ React.createElement(Grid, { item: true, xs: 12, md: 6 },
9897
+ React.createElement(Controller, { name: "SettingName", control: control, rules: { required: "Name is required" }, render: function (_a) {
9898
+ var field = _a.field, error = _a.fieldState.error;
9899
+ return (React.createElement(TextField, __assign({}, field, { label: "Name", variant: "outlined", error: !!error, helperText: error ? error.message : null, fullWidth: true, margin: "dense", autoComplete: "off" })));
9900
+ } })),
9901
+ React.createElement(Grid, { item: true, xs: 12, md: 6 },
9902
+ React.createElement(Controller, { name: "Value", control: control, rules: {
9903
+ required: "Value is required",
9904
+ pattern: {
9905
+ value: /^[A-Za-z0-9]+$/,
9906
+ message: "Only letters and numbers are allowed"
9907
+ }
9908
+ }, render: function (_a) {
9909
+ var field = _a.field, error = _a.fieldState.error;
9910
+ return (React.createElement(TextField, __assign({}, field, { label: "Value", variant: "outlined", error: !!error, helperText: error ? error.message : null, fullWidth: true, margin: "dense", autoComplete: "off" })));
9911
+ } })),
9912
+ React.createElement(Grid, { item: true, md: 12, xs: 12, style: { margin: "12px 0 20px", padding: "0 8px" } },
9913
+ React.createElement(Controller, { name: "Description", control: control, render: function (_a) {
9914
+ var _b = _a.field, value = _b.value, onChange = _b.onChange;
9915
+ return (React.createElement(TextField, { style: { margin: "8px 0" }, size: "medium", maxRows: 5, label: "Description", multiline: true, variant: "outlined", fullWidth: true, autoComplete: "off", value: value, onChange: function (evt) {
9916
+ if (evt.target.value.length <= 200)
9917
+ onChange(evt);
9918
+ } }));
9919
+ } })))),
9920
+ React.createElement(MesfModal.Actions, { style: { padding: "20px 30px 30px" } },
9921
+ React.createElement(Grid, { container: true, spacing: 2, justifyContent: "flex-end" },
9922
+ React.createElement(Grid, { item: true, md: 3, xs: 12, style: { margin: 0 } },
9923
+ React.createElement(Button, { fullWidth: true, variant: "contained", color: "default", onClick: function () { return onHide(false); } }, "Cancel")),
9924
+ React.createElement(Grid, { item: true, md: 3, xs: 12, style: { margin: 0 } },
9925
+ React.createElement(Button, { fullWidth: true, startIcon: isSubmitLoading && React.createElement(CircularProgress, { size: "1rem" }), disabled: isSubmitLoading, variant: "contained", color: "primary", type: "submit" }, "Save")))))))),
9926
+ React.createElement(ErrorModal, { error: error, onHide: function () { return setError(""); }, title: "Error Creating Setting" }),
9927
+ React.createElement(Snackbar, { open: open, autoHideDuration: 2500, onClose: handleClose },
9928
+ React.createElement(Alert, { severity: "success", onClose: handleClose }, "The setting was created successfully"))));
9929
+ };
9930
+
9931
+ makeStyles(function (theme) { return ({
9932
+ title: {
9933
+ fontSize: 15
9934
+ },
9935
+ modalTitle: {
9936
+ fontSize: 15,
9937
+ marginTop: theme.spacing(1)
9938
+ },
9939
+ chip: {
9940
+ margin: 2
9941
+ },
9942
+ errorLabel: {
9943
+ fontSize: 12,
9944
+ color: "#F44336"
9945
+ },
9946
+ infoLabel: {
9947
+ fontSize: 12,
9948
+ color: "#757575"
9949
+ }
9950
+ }); });
9951
+ var DeleteSetting = function (_a) {
9952
+ var show = _a.show, onHide = _a.onHide;
9953
+ var _b = useState(false), open = _b[0], setOpen = _b[1];
9954
+ var _c = useState(false), isSubmitLoading = _c[0], setIsSubmitLoading = _c[1];
9955
+ var _d = useState(""), error = _d[0], setError = _d[1];
9956
+ var settingSelected = useSettingsContext().state.settingSelected;
9957
+ var _e = useForm({
9958
+ defaultValues: settingSelected ? settingSelected : INITIAL_VALUES
9959
+ }), control = _e.control, handleSubmit = _e.handleSubmit, reset = _e.reset, setValue = _e.setValue;
9960
+ var onSubmit = function (data) { return __awaiter(void 0, void 0, void 0, function () {
9961
+ var settingsResp;
9962
+ return __generator(this, function (_a) {
9963
+ switch (_a.label) {
9964
+ case 0:
9965
+ setIsSubmitLoading(true);
9966
+ return [4 /*yield*/, deleteSetting(data.SettingId)];
9967
+ case 1:
9968
+ settingsResp = _a.sent();
9969
+ if (settingsResp.ok) {
9970
+ setIsSubmitLoading(false);
9971
+ setOpen(true);
9972
+ onHide(true);
9973
+ }
9974
+ else {
9975
+ setIsSubmitLoading(false);
9976
+ setError(settingsResp.message);
9977
+ }
9978
+ return [2 /*return*/];
9979
+ }
9980
+ });
9981
+ }); };
9982
+ var handleClose = function (event, reason) {
9983
+ if (reason === "clickaway") {
9984
+ return;
9985
+ }
9986
+ setOpen(false);
9987
+ };
9988
+ useEffect(function () {
9989
+ if (show) {
9990
+ reset();
9991
+ if (settingSelected) {
9992
+ setValue("SettingId", settingSelected.SettingId);
9993
+ setValue("SettingName", settingSelected.SettingName);
9994
+ setValue("Value", settingSelected.Value);
9995
+ setValue("Description", settingSelected.Description);
9996
+ }
9997
+ }
9998
+ }, [show]);
9999
+ return (React.createElement(React.Fragment, null,
10000
+ React.createElement(Grid, { container: true },
10001
+ React.createElement(Grid, { item: true },
10002
+ React.createElement(MesfModal, { title: "DELETE SETTING/CREW", open: show, handleClose: function () { return onHide(false); }, id: "delete-setting-modal", maxWidth: "md" },
10003
+ React.createElement("form", { onSubmit: handleSubmit(onSubmit) },
10004
+ React.createElement(MesfModal.Content, { style: { padding: "15px 30px 0" } },
10005
+ React.createElement(Grid, { container: true, spacing: 2 },
10006
+ React.createElement(Grid, { item: true, xs: 12, md: 6 },
10007
+ React.createElement(Controller, { name: "SettingName", control: control, rules: { required: "Name is required" }, render: function (_a) {
10008
+ var field = _a.field, error = _a.fieldState.error;
10009
+ return (React.createElement(TextField, __assign({ disabled: true }, field, { label: "Name", variant: "outlined", error: !!error, helperText: error ? error.message : null, fullWidth: true, margin: "dense", autoComplete: "off" })));
10010
+ } })),
10011
+ React.createElement(Grid, { item: true, xs: 12, md: 6 },
10012
+ React.createElement(Controller, { name: "Value", control: control, rules: { required: "Value is required" }, render: function (_a) {
10013
+ var field = _a.field, error = _a.fieldState.error;
10014
+ return (React.createElement(TextField, __assign({ disabled: true }, field, { label: "Value", variant: "outlined", error: !!error, helperText: error ? error.message : null, fullWidth: true, margin: "dense", autoComplete: "off" })));
10015
+ } })),
10016
+ React.createElement(Grid, { item: true, md: 12, xs: 12, style: { margin: "12px 0 20px", padding: "0 8px" } },
10017
+ React.createElement(Controller, { name: "Description", control: control, render: function (_a) {
10018
+ var _b = _a.field, value = _b.value, onChange = _b.onChange;
10019
+ return (React.createElement(TextField, { disabled: true, style: { margin: "8px 0" }, size: "medium", maxRows: 5, label: "Description", multiline: true, variant: "outlined", fullWidth: true, autoComplete: "off", value: value, onChange: function (evt) {
10020
+ if (evt.target.value.length <= 200)
10021
+ onChange(evt);
10022
+ } }));
10023
+ } })))),
10024
+ React.createElement(MesfModal.Actions, { style: { padding: "20px 30px 30px" } },
10025
+ React.createElement(Grid, { container: true, spacing: 2, justifyContent: "flex-end" },
10026
+ React.createElement(Grid, { item: true, md: 3, xs: 12, style: { margin: 0 } },
10027
+ React.createElement(Button, { fullWidth: true, variant: "contained", color: "default", onClick: function () { return onHide(false); } }, "Cancel")),
10028
+ React.createElement(Grid, { item: true, md: 3, xs: 12, style: { margin: 0 } },
10029
+ React.createElement(Button, { fullWidth: true, startIcon: isSubmitLoading && React.createElement(CircularProgress, { size: "1rem" }), disabled: isSubmitLoading, variant: "contained", color: "secondary", type: "submit" }, "Delete")))))))),
10030
+ React.createElement(ErrorModal, { error: error, onHide: function () { return setError(""); }, title: "Error deleting Setting" }),
10031
+ React.createElement(Snackbar, { open: open, autoHideDuration: 2500, onClose: handleClose },
10032
+ React.createElement(Alert, { severity: "success", onClose: handleClose }, "The setting was deleted successfully"))));
10033
+ };
10034
+
10035
+ makeStyles(function (theme) { return ({
10036
+ title: {
10037
+ fontSize: 15
10038
+ },
10039
+ modalTitle: {
10040
+ fontSize: 15,
10041
+ marginTop: theme.spacing(1)
10042
+ },
10043
+ chip: {
10044
+ margin: 2
10045
+ },
10046
+ errorLabel: {
10047
+ fontSize: 12,
10048
+ color: "#F44336"
10049
+ },
10050
+ infoLabel: {
10051
+ fontSize: 12,
10052
+ color: "#757575"
10053
+ }
10054
+ }); });
10055
+ var EditSetting = function (_a) {
10056
+ var show = _a.show, onHide = _a.onHide;
10057
+ var _b = useState(false), open = _b[0], setOpen = _b[1];
10058
+ var _c = useState(false), isSubmitLoading = _c[0], setIsSubmitLoading = _c[1];
10059
+ var _d = useState(""), error = _d[0], setError = _d[1];
10060
+ var settingSelected = useSettingsContext().state.settingSelected;
10061
+ var _e = useForm({
10062
+ defaultValues: settingSelected ? settingSelected : INITIAL_VALUES
10063
+ }), control = _e.control, handleSubmit = _e.handleSubmit, reset = _e.reset, setValue = _e.setValue;
10064
+ var onSubmit = function (data) { return __awaiter(void 0, void 0, void 0, function () {
10065
+ var settingsResp;
10066
+ return __generator(this, function (_a) {
10067
+ switch (_a.label) {
10068
+ case 0:
10069
+ setIsSubmitLoading(true);
10070
+ return [4 /*yield*/, upsertSettings(data)];
10071
+ case 1:
10072
+ settingsResp = _a.sent();
10073
+ if (settingsResp.ok) {
10074
+ setIsSubmitLoading(false);
10075
+ setOpen(true);
10076
+ onHide(true);
10077
+ }
10078
+ else {
10079
+ setIsSubmitLoading(false);
10080
+ setError(settingsResp.message);
10081
+ }
10082
+ return [2 /*return*/];
10083
+ }
10084
+ });
10085
+ }); };
10086
+ var handleClose = function (event, reason) {
10087
+ if (reason === "clickaway") {
10088
+ return;
10089
+ }
10090
+ setOpen(false);
10091
+ };
10092
+ useEffect(function () {
10093
+ if (show) {
10094
+ reset();
10095
+ if (settingSelected) {
10096
+ setValue("SettingId", settingSelected.SettingId);
10097
+ setValue("SettingName", settingSelected.SettingName);
10098
+ setValue("Value", settingSelected.Value);
10099
+ setValue("Description", settingSelected.Description);
10100
+ }
10101
+ }
10102
+ }, [show]);
10103
+ return (React.createElement(React.Fragment, null,
10104
+ React.createElement(Grid, { container: true },
10105
+ React.createElement(Grid, { item: true },
10106
+ React.createElement(MesfModal, { title: "EDIT SETTING/CREW", open: show, handleClose: function () { return onHide(false); }, id: "edit-setting-modal", maxWidth: "md" },
10107
+ React.createElement("form", { onSubmit: handleSubmit(onSubmit) },
10108
+ React.createElement(MesfModal.Content, { style: { padding: "15px 30px 0" } },
10109
+ React.createElement(Grid, { container: true, spacing: 2 },
10110
+ React.createElement(Grid, { item: true, xs: 12, md: 6 },
10111
+ React.createElement(Controller, { name: "SettingName", control: control, rules: { required: "Name is required" }, render: function (_a) {
10112
+ var field = _a.field, error = _a.fieldState.error;
10113
+ return (React.createElement(TextField, __assign({}, field, { label: "Name", variant: "outlined", error: !!error, helperText: error ? error.message : null, fullWidth: true, margin: "dense", autoComplete: "off" })));
10114
+ } })),
10115
+ React.createElement(Grid, { item: true, xs: 12, md: 6 },
10116
+ React.createElement(Controller, { name: "Value", control: control, rules: {
10117
+ required: "Value is required",
10118
+ pattern: {
10119
+ value: /^[A-Za-z0-9]+$/,
10120
+ message: "Only letters and numbers are allowed"
10121
+ }
10122
+ }, render: function (_a) {
10123
+ var field = _a.field, error = _a.fieldState.error;
10124
+ return (React.createElement(TextField, __assign({}, field, { label: "Value", variant: "outlined", error: !!error, helperText: error ? error.message : null, fullWidth: true, margin: "dense", autoComplete: "off" })));
10125
+ } })),
10126
+ React.createElement(Grid, { item: true, md: 12, xs: 12, style: { margin: "12px 0 20px", padding: "0 8px" } },
10127
+ React.createElement(Controller, { name: "Description", control: control, render: function (_a) {
10128
+ var _b = _a.field, value = _b.value, onChange = _b.onChange;
10129
+ return (React.createElement(TextField, { style: { margin: "8px 0" }, size: "medium", maxRows: 5, label: "Description", multiline: true, variant: "outlined", fullWidth: true, autoComplete: "off", value: value, onChange: function (evt) {
10130
+ if (evt.target.value.length <= 200)
10131
+ onChange(evt);
10132
+ } }));
10133
+ } })))),
10134
+ React.createElement(MesfModal.Actions, { style: { padding: "20px 30px 30px" } },
10135
+ React.createElement(Grid, { container: true, spacing: 2, justifyContent: "flex-end" },
10136
+ React.createElement(Grid, { item: true, md: 3, xs: 12, style: { margin: 0 } },
10137
+ React.createElement(Button, { fullWidth: true, variant: "contained", color: "default", onClick: function () { return onHide(false); } }, "Cancel")),
10138
+ React.createElement(Grid, { item: true, md: 3, xs: 12, style: { margin: 0 } },
10139
+ React.createElement(Button, { fullWidth: true, startIcon: isSubmitLoading && React.createElement(CircularProgress, { size: "1rem" }), disabled: isSubmitLoading, variant: "contained", color: "primary", type: "submit" }, "Save")))))))),
10140
+ React.createElement(ErrorModal, { error: error, onHide: function () { return setError(""); }, title: "Error updating Setting" }),
10141
+ React.createElement(Snackbar, { open: open, autoHideDuration: 2500, onClose: handleClose },
10142
+ React.createElement(Alert, { severity: "success", onClose: handleClose }, "The setting was edited successfully"))));
10143
+ };
10144
+
10145
+ var TableSettings = function (_a) {
10146
+ var getSettingsFromAPI = _a.getSettingsFromAPI; _a.isLoading; var rows = _a.rows;
10147
+ var _b = useContextMenuMESF(), showContextMenu = _b.showContextMenu, registerConfig = _b.registerConfig;
10148
+ var _c = useSettingsContext(); _c.state; var actions = _c.actions;
10149
+ var classes = useStyles$3();
10150
+ var _d = useState(false), openModalNew = _d[0], setOpenModalNew = _d[1];
10151
+ var _e = useState(false), openModalEditSetting = _e[0], setOpenModalEditSetting = _e[1];
10152
+ var _f = useState(false), openModalDeleteSetting = _f[0], setOpenModalDeleteSetting = _f[1];
10153
+ var getMenuOptions = useSettingsOptionsFunctions({
10154
+ setSettingId: actions.setSettingSelected,
10155
+ setShowDeleteModal: setOpenModalDeleteSetting,
10156
+ setShowCreateModal: setOpenModalNew,
10157
+ setShowEditModal: setOpenModalEditSetting
10158
+ }).getMenuOptions;
10159
+ var _g = useTableData({
10160
+ setOpenModalEditSetting: setOpenModalEditSetting,
10161
+ setOpenModalDeleteSetting: setOpenModalDeleteSetting,
10162
+ showContextMenu: showContextMenu
10163
+ }), columnDefs = _g.columnDefs, defaultColDef = _g.defaultColDef;
10164
+ var loadingOverlayComponent = useMemo(function () {
10165
+ return (React__default.createElement("div", { style: {
10166
+ width: "100%",
10167
+ height: "100%",
10168
+ display: "flex",
10169
+ justifyContent: "center",
10170
+ alignItems: "center"
10171
+ } },
10172
+ React__default.createElement(LazyLoading, null)));
10173
+ }, []);
10174
+ var getContextMenuItems = function (params) {
10175
+ var _a, _b;
10176
+ var data = (_a = params.node) === null || _a === void 0 ? void 0 : _a.data;
10177
+ params.api.deselectAll();
10178
+ (_b = params.node) === null || _b === void 0 ? void 0 : _b.setSelected(true);
10179
+ showContextMenu(event, data, "TableSettings");
10180
+ return [];
9022
10181
  };
9023
10182
  useEffect(function () {
9024
- logout();
10183
+ registerConfig({
10184
+ id: "TableSettings",
10185
+ getOptions: getMenuOptions
10186
+ });
9025
10187
  }, []);
9026
10188
  return (React__default.createElement(React__default.Fragment, null,
9027
- React__default.createElement("div", null, "logging out!!!")));
9028
- }
9029
-
9030
- var RouterContext = createContext(function () { return React__default.createElement(React__default.Fragment, null); });
9031
- var ConfigurationContext = createContext([
9032
- [],
9033
- function () { return React__default.createElement(React__default.Fragment, null); },
9034
- ]);
9035
- var NavbarContext = createContext(function () { return React__default.createElement(React__default.Fragment, null); });
9036
-
9037
- var useSearchAssets = function (setError) {
9038
- var _a = useAssetContext().actions, setAllAssets = _a.setAllAssets, setAreasList = _a.setAreasList;
9039
- var searchAssets = function () {
9040
- getAssets().then(function (res) { return __awaiter(void 0, void 0, void 0, function () {
9041
- var rows, areas;
9042
- return __generator(this, function (_a) {
9043
- switch (_a.label) {
9044
- case 0:
9045
- if (!res.ok) return [3 /*break*/, 2];
9046
- rows = get$1(res, "data.tables[0].rows", []);
9047
- return [4 /*yield*/, rows.filter(function (asset) { return asset.CanBeDefaultAsset; })];
9048
- case 1:
9049
- areas = _a.sent();
9050
- setAllAssets(rows);
9051
- setAreasList(areas);
9052
- return [3 /*break*/, 3];
9053
- case 2:
9054
- setError(res.message);
9055
- _a.label = 3;
9056
- case 3: return [2 /*return*/];
9057
- }
9058
- });
9059
- }); });
9060
- };
9061
- return { searchAssets: searchAssets };
9062
- };
9063
-
9064
- var UTLSettingsInitialState = {
9065
- serverTimeZone: Intl.DateTimeFormat().resolvedOptions().timeZone,
9066
- settings: {}
9067
- };
9068
- var UTLSettingsReducer = createSlice({
9069
- name: "__",
9070
- initialState: UTLSettingsInitialState,
9071
- reducers: {
9072
- setServerTimeZone: function (state, _a) {
9073
- var payload = _a.payload;
9074
- state.serverTimeZone = payload;
9075
- },
9076
- setSetting: function (state, _a) {
9077
- var payload = _a.payload;
9078
- state.settings[payload.key] = payload.value;
9079
- },
9080
- initSettings: function (state, _a) {
9081
- var payload = _a.payload;
9082
- state.settings = payload.reduce(function (acc, cur) {
9083
- if (cur.SettingName.trim() === "TimeZone") {
9084
- var timeService = TimeService.getInstance();
9085
- timeService.setTimeZone(cur.Value);
9086
- }
9087
- acc[cur.SettingName.trim()] = cur.Value;
9088
- return acc;
9089
- }, {});
9090
- }
9091
- }
9092
- });
9093
-
9094
- var UTLSettingsContext = createContext({
9095
- state: UTLSettingsReducer.getInitialState(),
9096
- actions: UTLSettingsReducer.actions
9097
- });
9098
- var useUTLSettingsContext = function () { return useContext(UTLSettingsContext); };
9099
- var UTLSettingsProvider = function (_a) {
9100
- var children = _a.children;
9101
- var _b = useComplexState({
9102
- initialState: UTLSettingsReducer.getInitialState(),
9103
- reducers: UTLSettingsReducer.caseReducers
9104
- }), state = _b[0], actions = _b[1];
9105
- return (React__default.createElement(UTLSettingsContext.Provider, { value: { state: state, actions: actions } }, children));
10189
+ React__default.createElement(Grid, { container: true, justifyContent: "center", alignItems: "center", className: classes.root },
10190
+ React__default.createElement(Grid, { item: true, md: 12, xs: 12, style: { padding: "0 15px" } },
10191
+ React__default.createElement(Typography$1, { variant: "h5", style: { margin: "20px 0 20px", fontWeight: 600 } }, "Settings")),
10192
+ React__default.createElement(Grid, { container: true, justifyContent: "center", alignItems: "center", className: classes.root },
10193
+ React__default.createElement(Grid, { item: true, md: 12, xs: 12, style: { padding: "0 15px" }, className: classes.relative },
10194
+ React__default.createElement(CreateSetting, { show: openModalNew, onHide: function (shouldUpdate) {
10195
+ setOpenModalNew(false);
10196
+ if (shouldUpdate)
10197
+ getSettingsFromAPI();
10198
+ } }),
10199
+ React__default.createElement(EditSetting, { show: openModalEditSetting, onHide: function (shouldUpdate) {
10200
+ setOpenModalEditSetting(false);
10201
+ if (shouldUpdate)
10202
+ getSettingsFromAPI();
10203
+ } }),
10204
+ React__default.createElement(DeleteSetting, { show: openModalDeleteSetting, onHide: function (shouldUpdate) {
10205
+ setOpenModalDeleteSetting(false);
10206
+ if (shouldUpdate)
10207
+ getSettingsFromAPI();
10208
+ } }),
10209
+ React__default.createElement(Grid, { item: true, md: 12, xs: 12, style: {
10210
+ height: "62vh",
10211
+ border: "4px solid #ccc",
10212
+ borderRadius: 10,
10213
+ padding: 10,
10214
+ margin: "20px 0 10px"
10215
+ } },
10216
+ React__default.createElement("div", { style: { height: "100%", width: "100%" }, className: "ag-theme-alpine" },
10217
+ React__default.createElement(AgGridReact, { rowData: rows, columnDefs: columnDefs, defaultColDef: defaultColDef, rowHeight: 34, headerHeight: 34, animateRows: true, loadingOverlayComponent: loadingOverlayComponent, getContextMenuItems: function (e) { return getContextMenuItems(e); }, pagination: true, rowSelection: "single", onRowDoubleClicked: function (event) {
10218
+ actions.setSettingSelected(event.data);
10219
+ setOpenModalEditSetting(true);
10220
+ } }))),
10221
+ React__default.createElement(Grid, { container: true, justifyContent: "flex-end" },
10222
+ React__default.createElement(Grid, { item: true, md: 2, xs: 12, style: {
10223
+ display: "flex",
10224
+ justifyContent: "flex-end"
10225
+ } },
10226
+ React__default.createElement(Button, { variant: "contained", color: "primary", onClick: function () { return setOpenModalNew(!openModalNew); }, fullWidth: true, style: { marginTop: 10 } }, "NEW SETTING"))))))));
9106
10227
  };
9107
10228
 
9108
- var useSearchUTLSettings = function (_a) {
9109
- var onError = _a.onError;
9110
- var initSettings = useUTLSettingsContext().actions.initSettings;
9111
- var searchUTLSettings = function () { return __awaiter(void 0, void 0, void 0, function () {
10229
+ var SettingsPage = function () {
10230
+ var _a = useSettingsContext(), state = _a.state, actions = _a.actions;
10231
+ var _b = useState(""), error = _b[0], setError = _b[1];
10232
+ var _c = useState(false), isLoading = _c[0], setIsLoading = _c[1];
10233
+ var getSettingsFromAPI = function () { return __awaiter(void 0, void 0, void 0, function () {
9112
10234
  var res, settings;
9113
10235
  return __generator(this, function (_a) {
9114
10236
  switch (_a.label) {
9115
- case 0: return [4 /*yield*/, getUTLSettings()];
10237
+ case 0:
10238
+ setIsLoading(true);
10239
+ return [4 /*yield*/, getUTLSettings()];
9116
10240
  case 1:
9117
10241
  res = _a.sent();
9118
10242
  if (res.ok) {
9119
10243
  settings = get$1(res, "data.tables[0].rows", []);
9120
- initSettings(settings);
10244
+ actions.setSettings(settings);
9121
10245
  }
9122
10246
  else {
9123
- onError(res.message);
10247
+ setError(res.message);
9124
10248
  }
10249
+ setIsLoading(false);
9125
10250
  return [2 /*return*/];
9126
10251
  }
9127
10252
  });
9128
10253
  }); };
9129
- return { searchUTLSettings: searchUTLSettings };
9130
- };
9131
-
9132
- var AreaSelector$1 = lazy(function () {
9133
- return Promise.resolve().then(function () { return areaSelector; }).then(function (mod) { return ({
9134
- "default": mod.AreaSelector
9135
- }); });
9136
- });
9137
- function Header$1(_a) {
9138
- var _b = _a.showAreaSelector, showAreaSelector = _b === void 0 ? false : _b, _c = _a.showTrendingsIcon, showTrendingsIcon = _c === void 0 ? true : _c, _d = _a.navbarTitle, navbarTitle = _d === void 0 ? "MESF" : _d;
9139
- var getUserName = useToken().getUserName;
9140
- var _e = useState(""), error = _e[0], setError = _e[1];
9141
- var _f = useState(new Date()), date = _f[0], setDate = _f[1];
9142
- var CustomNavbar = useContext(NavbarContext);
9143
- var userName = useState(getUserName())[0];
9144
- var searchAssets = useSearchAssets(setError).searchAssets;
9145
- var _g = useState(false), settingsIsReady = _g[0], setSettingsIsReady = _g[1];
9146
- var searchUTLSettings = useSearchUTLSettings({
9147
- onError: setError
9148
- }).searchUTLSettings;
9149
- var userLogged = useUserContext().state.userLogged;
9150
- var tick = function () {
9151
- setDate(new Date());
9152
- };
9153
- useEffect(function () {
9154
- var timerID = setTimeout(function () {
9155
- tick();
9156
- }, 1000);
9157
- return function () {
9158
- clearTimeout(timerID);
9159
- };
9160
- });
9161
10254
  useEffect(function () {
9162
- searchUTLSettings().then(function () {
9163
- setSettingsIsReady(true);
9164
- });
10255
+ getSettingsFromAPI();
9165
10256
  }, []);
9166
- useEffect(function () {
9167
- if (showAreaSelector && userLogged && settingsIsReady) {
9168
- searchAssets();
9169
- }
9170
- }, [userLogged, settingsIsReady]);
9171
- return (React__default.createElement(Navbar, { variant: "dark", expand: "lg", className: "mes-primary-color mes-menu-top" },
9172
- React__default.createElement(Container, { fluid: true },
9173
- React__default.createElement(Navbar.Brand, { as: Link, to: "/home" }, navbarTitle),
9174
- React__default.createElement(Navbar.Toggle, { "aria-controls": "basic-navbar-nav" }),
9175
- React__default.createElement(Navbar.Collapse, { id: "basic-navbar-nav" },
9176
- React__default.createElement(Nav, { className: "me-auto" },
9177
- React__default.createElement(CustomNavbar, null)),
9178
- React__default.createElement(Nav, { className: "ml-auto", style: { alignItems: "baseline" } },
9179
- showTrendingsIcon ? (React__default.createElement(Nav, { className: "mx-2" },
9180
- React__default.createElement(Nav.Link, { as: Link, to: "/trendings" },
9181
- React__default.createElement(Tooltip, { title: "Trendings", placement: "top", arrow: true, interactive: true, enterDelay: 1500 },
9182
- React__default.createElement(ShowChartIcon, null))))) : null,
9183
- React__default.createElement(Nav, null,
9184
- React__default.createElement("span", { className: "navbar-text" }, dxtToLocalServerTime(date, "HH:mm:ss z"))),
9185
- React__default.createElement(Nav, { className: "mx-2" },
9186
- React__default.createElement(Nav.Link, { as: Link, to: "/configuration" },
9187
- React__default.createElement("i", { className: "fas fa-cog" }))),
9188
- showAreaSelector ? (React__default.createElement(Suspense, { fallback: "..." },
9189
- React__default.createElement(AreaSelector$1, null))) : null,
9190
- React__default.createElement(NavDropdown, { id: "user-menu", title: React__default.createElement(React__default.Fragment, null,
9191
- React__default.createElement("i", { className: "fas fa-user", style: { marginRight: 6 } }),
9192
- userName), className: "mx-2" },
9193
- React__default.createElement(NavDropdown.Item, { href: "account" }, "Account"),
9194
- React__default.createElement(NavDropdown.Item, { href: "logout" }, "Logout"))))),
10257
+ return (React__default.createElement(React__default.Fragment, null,
10258
+ React__default.createElement(Grid, { container: true, justifyContent: "center", alignItems: "center" },
10259
+ React__default.createElement(Paper, { elevation: 1, style: {
10260
+ width: "100%",
10261
+ padding: "10px 0 20px",
10262
+ borderRadius: "0.75rem"
10263
+ } },
10264
+ React__default.createElement(TableSettings, { rows: state.settings, isLoading: isLoading, getSettingsFromAPI: getSettingsFromAPI }))),
9195
10265
  React__default.createElement(ErrorModal, { error: error, onHide: function () { return setError(""); } })));
9196
- }
10266
+ };
10267
+
10268
+ var Settings = function () {
10269
+ return (React__default.createElement(SettingsProvider, null,
10270
+ React__default.createElement(SettingsPage, null)));
10271
+ };
9197
10272
 
9198
10273
  function Configuration() {
9199
10274
  var option = useParams().option;
@@ -9233,6 +10308,11 @@ function Configuration() {
9233
10308
  path: "jobs",
9234
10309
  sidebar: function () { return React__default.createElement("div", null, "Jobs"); },
9235
10310
  main: function () { return React__default.createElement(JobsPage, null); }
10311
+ },
10312
+ {
10313
+ path: "settings",
10314
+ sidebar: function () { return React__default.createElement("div", null, "Settings"); },
10315
+ main: function () { return React__default.createElement(Settings, null); }
9236
10316
  }
9237
10317
  ], customConfiguration, true);
9238
10318
  return (React__default.createElement(GenericPanel, { title: "Configuration", description: "" },
@@ -9256,7 +10336,9 @@ function Configuration() {
9256
10336
  React__default.createElement(MenuItem, { selected: option === "logs", className: "p-0" },
9257
10337
  React__default.createElement(Link, { to: "/configuration/logs", className: "nav-link" }, "Logs")),
9258
10338
  React__default.createElement(MenuItem, { selected: option === "jobs", className: "p-0" },
9259
- React__default.createElement(Link, { to: "/configuration/jobs", className: "nav-link" }, "Jobs")))),
10339
+ React__default.createElement(Link, { to: "/configuration/jobs", className: "nav-link" }, "Jobs")),
10340
+ React__default.createElement(MenuItem, { selected: option === "settings", className: "p-0" },
10341
+ React__default.createElement(Link, { to: "/configuration/settings", className: "nav-link" }, "Settings")))),
9260
10342
  React__default.createElement("div", { className: "col-md-10", style: { flex: "80%" } },
9261
10343
  React__default.createElement(Routes, null, routes.map(function (route, index) { return (React__default.createElement(Route, { key: "".concat(route.path), path: route.path, element: React__default.createElement(route.main, null) })); }))))));
9262
10344
  }
@@ -9292,7 +10374,7 @@ const FORMATS = {
9292
10374
  year: 'YYYY'
9293
10375
  };
9294
10376
 
9295
- _adapters._date.override(typeof moment$2 === 'function' ? {
10377
+ _adapters._date.override(typeof moment$4 === 'function' ? {
9296
10378
  _id: 'moment', // DEBUG ONLY
9297
10379
 
9298
10380
  formats: function() {
@@ -9301,27 +10383,27 @@ _adapters._date.override(typeof moment$2 === 'function' ? {
9301
10383
 
9302
10384
  parse: function(value, format) {
9303
10385
  if (typeof value === 'string' && typeof format === 'string') {
9304
- value = moment$2(value, format);
9305
- } else if (!(value instanceof moment$2)) {
9306
- value = moment$2(value);
10386
+ value = moment$4(value, format);
10387
+ } else if (!(value instanceof moment$4)) {
10388
+ value = moment$4(value);
9307
10389
  }
9308
10390
  return value.isValid() ? value.valueOf() : null;
9309
10391
  },
9310
10392
 
9311
10393
  format: function(time, format) {
9312
- return moment$2(time).format(format);
10394
+ return moment$4(time).format(format);
9313
10395
  },
9314
10396
 
9315
10397
  add: function(time, amount, unit) {
9316
- return moment$2(time).add(amount, unit).valueOf();
10398
+ return moment$4(time).add(amount, unit).valueOf();
9317
10399
  },
9318
10400
 
9319
10401
  diff: function(max, min, unit) {
9320
- return moment$2(max).diff(moment$2(min), unit);
10402
+ return moment$4(max).diff(moment$4(min), unit);
9321
10403
  },
9322
10404
 
9323
10405
  startOf: function(time, unit, weekday) {
9324
- time = moment$2(time);
10406
+ time = moment$4(time);
9325
10407
  if (unit === 'isoWeek') {
9326
10408
  weekday = Math.trunc(Math.min(Math.max(0, weekday), 6));
9327
10409
  return time.isoWeekday(weekday).startOf('day').valueOf();
@@ -9330,11 +10412,11 @@ _adapters._date.override(typeof moment$2 === 'function' ? {
9330
10412
  },
9331
10413
 
9332
10414
  endOf: function(time, unit) {
9333
- return moment$2(time).endOf(unit).valueOf();
10415
+ return moment$4(time).endOf(unit).valueOf();
9334
10416
  }
9335
10417
  } : {});
9336
10418
 
9337
- var css$1 = "/* ContextMenu.css */\n.context-menu {\n position: absolute;\n z-index: 1000;\n background-color: #fff;\n border: 1px solid #ddd;\n box-shadow: 0px 0px 10px rgba(0, 0, 0, 0.1);\n border-radius: 4px;\n overflow: hidden;\n}\n\n .context-menu ul {\n list-style: none;\n margin: 0;\n padding: 0;\n }\n\n .context-menu li {\n padding: 8px 15px;\n cursor: pointer;\n border-bottom: 1px solid #eee;\n background-color: #fff;\n color: #333;\n font-size: 14px;\n }\n\n .context-menu li:hover {\n background-color: #f5f5f5;\n }\n\n\n";
10419
+ var css$1 = "/* ContextMenu.css */ .context-menu {\n\tposition: absolute;\n\tz-index: 1000;\n\tbackground-color: #fff;\n\tborder: 1px solid #ddd;\n\tbox-shadow: 0px 0px 10px rgba(0, 0, 0, 0.1);\n\tborder-radius: 4px;\n\toverflow: hidden;\n}\n\n.context-menu ul {\n\tlist-style: none;\n\tmargin: 0;\n\tpadding: 0;\n}\n\n.context-menu li {\n\tpadding: 8px 15px;\n\tcursor: pointer;\n\tborder-bottom: 1px solid #eee;\n\tbackground-color: #fff;\n\tcolor: #333;\n\tfont-size: 14px;\n}\n\n.context-menu li:hover {\n\tbackground-color: #f5f5f5;\n}\n";
9338
10420
  n(css$1,{});
9339
10421
 
9340
10422
  var useTagColorsStyles = makeStyles({
@@ -9424,7 +10506,7 @@ var ColorPicker = function (_a) {
9424
10506
  };
9425
10507
 
9426
10508
  var TrendingsInitialState = {
9427
- timeScopeStart: moment$2(new Date()).subtract(1, "days").toDate(),
10509
+ timeScopeStart: moment$4(new Date()).subtract(1, "days").toDate(),
9428
10510
  timeScopeEnd: new Date(),
9429
10511
  scope: "1 day",
9430
10512
  graphPan: false,
@@ -9464,32 +10546,32 @@ var TrendingsReducer = createSlice({
9464
10546
  if (payload.scope !== "custom") {
9465
10547
  switch (payload.scope) {
9466
10548
  case "10 min":
9467
- state.timeScopeStart = moment$2(state.timeScopeEnd)
10549
+ state.timeScopeStart = moment$4(state.timeScopeEnd)
9468
10550
  .subtract(10, "minutes")
9469
10551
  .toDate();
9470
10552
  break;
9471
10553
  case "1 hour":
9472
- state.timeScopeStart = moment$2(state.timeScopeEnd)
10554
+ state.timeScopeStart = moment$4(state.timeScopeEnd)
9473
10555
  .subtract(1, "hours")
9474
10556
  .toDate();
9475
10557
  break;
9476
10558
  case "4 hours":
9477
- state.timeScopeStart = moment$2(state.timeScopeEnd)
10559
+ state.timeScopeStart = moment$4(state.timeScopeEnd)
9478
10560
  .subtract(4, "hours")
9479
10561
  .toDate();
9480
10562
  break;
9481
10563
  case "12 hours":
9482
- state.timeScopeStart = moment$2(state.timeScopeEnd)
10564
+ state.timeScopeStart = moment$4(state.timeScopeEnd)
9483
10565
  .subtract(12, "hours")
9484
10566
  .toDate();
9485
10567
  break;
9486
10568
  case "1 day":
9487
- state.timeScopeStart = moment$2(state.timeScopeEnd)
10569
+ state.timeScopeStart = moment$4(state.timeScopeEnd)
9488
10570
  .subtract(1, "days")
9489
10571
  .toDate();
9490
10572
  break;
9491
10573
  case "10 days":
9492
- state.timeScopeStart = moment$2(state.timeScopeEnd)
10574
+ state.timeScopeStart = moment$4(state.timeScopeEnd)
9493
10575
  .subtract(10, "days")
9494
10576
  .toDate();
9495
10577
  break;
@@ -9520,32 +10602,32 @@ var TrendingsReducer = createSlice({
9520
10602
  if (state.scope !== "custom") {
9521
10603
  switch (state.scope) {
9522
10604
  case "10 min":
9523
- state.timeScopeEnd = moment$2(payload.start)
10605
+ state.timeScopeEnd = moment$4(payload.start)
9524
10606
  .add(10, "minutes")
9525
10607
  .toDate();
9526
10608
  break;
9527
10609
  case "1 hour":
9528
- state.timeScopeEnd = moment$2(payload.start)
10610
+ state.timeScopeEnd = moment$4(payload.start)
9529
10611
  .add(1, "hours")
9530
10612
  .toDate();
9531
10613
  break;
9532
10614
  case "4 hours":
9533
- state.timeScopeEnd = moment$2(payload.start)
10615
+ state.timeScopeEnd = moment$4(payload.start)
9534
10616
  .add(4, "hours")
9535
10617
  .toDate();
9536
10618
  break;
9537
10619
  case "12 hours":
9538
- state.timeScopeEnd = moment$2(payload.start)
10620
+ state.timeScopeEnd = moment$4(payload.start)
9539
10621
  .add(12, "hours")
9540
10622
  .toDate();
9541
10623
  break;
9542
10624
  case "1 day":
9543
- state.timeScopeEnd = moment$2(payload.start)
10625
+ state.timeScopeEnd = moment$4(payload.start)
9544
10626
  .add(1, "days")
9545
10627
  .toDate();
9546
10628
  break;
9547
10629
  case "10 days":
9548
- state.timeScopeEnd = moment$2(payload.start)
10630
+ state.timeScopeEnd = moment$4(payload.start)
9549
10631
  .add(10, "days")
9550
10632
  .toDate();
9551
10633
  break;
@@ -9558,32 +10640,32 @@ var TrendingsReducer = createSlice({
9558
10640
  if (state.scope !== "custom") {
9559
10641
  switch (state.scope) {
9560
10642
  case "10 min":
9561
- state.timeScopeStart = moment$2(payload.end)
10643
+ state.timeScopeStart = moment$4(payload.end)
9562
10644
  .subtract(10, "minutes")
9563
10645
  .toDate();
9564
10646
  break;
9565
10647
  case "1 hour":
9566
- state.timeScopeStart = moment$2(payload.end)
10648
+ state.timeScopeStart = moment$4(payload.end)
9567
10649
  .subtract(1, "hours")
9568
10650
  .toDate();
9569
10651
  break;
9570
10652
  case "4 hours":
9571
- state.timeScopeStart = moment$2(payload.end)
10653
+ state.timeScopeStart = moment$4(payload.end)
9572
10654
  .subtract(4, "hours")
9573
10655
  .toDate();
9574
10656
  break;
9575
10657
  case "12 hours":
9576
- state.timeScopeStart = moment$2(payload.end)
10658
+ state.timeScopeStart = moment$4(payload.end)
9577
10659
  .subtract(12, "hours")
9578
10660
  .toDate();
9579
10661
  break;
9580
10662
  case "1 day":
9581
- state.timeScopeStart = moment$2(payload.end)
10663
+ state.timeScopeStart = moment$4(payload.end)
9582
10664
  .subtract(1, "days")
9583
10665
  .toDate();
9584
10666
  break;
9585
10667
  case "10 days":
9586
- state.timeScopeStart = moment$2(payload.end)
10668
+ state.timeScopeStart = moment$4(payload.end)
9587
10669
  .subtract(10, "days")
9588
10670
  .toDate();
9589
10671
  break;
@@ -11542,21 +12624,21 @@ var dateNavigator = function (startDate, endDate, scope, operator, current) {
11542
12624
  }
11543
12625
  else {
11544
12626
  var _a = scope.split(" "), quantity = _a[0], duration = _a[1];
11545
- newStartDate = moment$2(newEndDate)
12627
+ newStartDate = moment$4(newEndDate)
11546
12628
  .subtract(quantity, duration[0])
11547
12629
  .toDate();
11548
12630
  }
11549
12631
  }
11550
12632
  else {
11551
12633
  if (scope === "custom") {
11552
- var durationInMs = moment$2(endDate).diff(moment$2(startDate));
11553
- newStartDate = moment$2(startDate)[operator](durationInMs).toDate();
12634
+ var durationInMs = moment$4(endDate).diff(moment$4(startDate));
12635
+ newStartDate = moment$4(startDate)[operator](durationInMs).toDate();
11554
12636
  }
11555
12637
  else {
11556
12638
  var _b = scope.split(" "), quantity = _b[0], duration = _b[1];
11557
- newStartDate = moment$2(startDate)[operator](quantity, duration[0])
12639
+ newStartDate = moment$4(startDate)[operator](quantity, duration[0])
11558
12640
  .toDate();
11559
- newEndDate = moment$2(endDate)[operator](quantity, duration[0])
12641
+ newEndDate = moment$4(endDate)[operator](quantity, duration[0])
11560
12642
  .toDate();
11561
12643
  }
11562
12644
  }
@@ -11585,7 +12667,7 @@ var Header = function (_a) {
11585
12667
  var handleDateChange = function (newValue, key) {
11586
12668
  var _a;
11587
12669
  //@ts-ignore
11588
- actions.setTotalScope((_a = {}, _a[key] = moment$2(newValue).toDate(), _a));
12670
+ actions.setTotalScope((_a = {}, _a[key] = moment$4(newValue).toDate(), _a));
11589
12671
  };
11590
12672
  var handleChangeScope = function (e) {
11591
12673
  var newScope = e.target.value;
@@ -11621,7 +12703,7 @@ var Header = function (_a) {
11621
12703
  React__default.createElement(IconButton$1, { color: "primary", onClick: function () { return handleDateNavigator("subtract"); }, className: classes.navigatorButton },
11622
12704
  React__default.createElement(ChevronLeft, { fontSize: "large" }))),
11623
12705
  React__default.createElement(Grid, { item: true },
11624
- React__default.createElement(TextField, { type: "datetime-local", className: classes.datetimePicker, label: "Start", variant: "outlined", value: moment$2(state.timeScopeStart).format("YYYY-MM-DDTHH:mm:ss"), onChange: function (e) { return handleDateChange(e.target.value, "start"); }, InputLabelProps: {
12706
+ React__default.createElement(TextField, { type: "datetime-local", className: classes.datetimePicker, label: "Start", variant: "outlined", value: moment$4(state.timeScopeStart).format("YYYY-MM-DDTHH:mm:ss"), onChange: function (e) { return handleDateChange(e.target.value, "start"); }, InputLabelProps: {
11625
12707
  shrink: true,
11626
12708
  style: { marginLeft: "10px" }
11627
12709
  }, InputProps: {
@@ -11638,7 +12720,7 @@ var Header = function (_a) {
11638
12720
  React__default.createElement(MenuItem, { value: "10 days" }, "10 days"),
11639
12721
  React__default.createElement(MenuItem, { value: "custom" }, "Custom")))),
11640
12722
  React__default.createElement(Grid, { item: true },
11641
- React__default.createElement(TextField, { label: "End", variant: "outlined", className: classes.datetimePicker, type: "datetime-local", value: moment$2(state.timeScopeEnd).format("YYYY-MM-DDTHH:mm:ss"), onChange: function (e) { return handleDateChange(e.target.value, "end"); }, InputLabelProps: {
12723
+ React__default.createElement(TextField, { label: "End", variant: "outlined", className: classes.datetimePicker, type: "datetime-local", value: moment$4(state.timeScopeEnd).format("YYYY-MM-DDTHH:mm:ss"), onChange: function (e) { return handleDateChange(e.target.value, "end"); }, InputLabelProps: {
11642
12724
  shrink: true,
11643
12725
  style: { marginLeft: "10px" }
11644
12726
  } })),
@@ -12235,16 +13317,16 @@ var Navigation = function (_a) {
12235
13317
  React__default.createElement(MESFMainContainer, null)));
12236
13318
  };
12237
13319
 
12238
- var css = "body {\n margin: 0;\n font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto', 'Oxygen',\n 'Ubuntu', 'Cantarell', 'Fira Sans', 'Droid Sans', 'Helvetica Neue',\n sans-serif;\n -webkit-font-smoothing: antialiased;\n -moz-osx-font-smoothing: grayscale;\n background-color: #fafbfc !important;\n}\n.container-fluid-main{\n padding-right: 0px !important; \n padding-left: 0px !important;\n}\n\ncode {\n font-family: source-code-pro, Menlo, Monaco, Consolas, 'Courier New',\n monospace;\n}\n\n.mes-primary-color {\n background-color: #479dc4 !important;\n}\n.mes-button-primary{\n background-color: #479dc4 !important;\n border-color: #479dc4 !important;\n}\n\n.mes-selectable-datagrid .MuiDataGrid-row{\n cursor: pointer;\n}\n\n.mes-menu-top .navbar-brand{\n color: #FFFF !important;\n}\n.mes-menu-top .nav-link {\n color: #FFFF !important;\n}\n.mes-menu-top .navbar-toggler {\n color: #FFFF !important;\n}\n.mes-menu-top .navbar-text {\n color: #FFFF !important;\n}\n.mes-footer-login{\n position: absolute;\n bottom: 0;\n width: 100%;\n height: 10em;\n line-height: 60px;\n text-align:center;\n}\n.mes-filter-datepicker{\n padding: unset !important;\n border-top-left-radius: 0 !important;\n border-bottom-left-radius: 0 !important;\n padding-top: 0.375rem !important;\n padding-bottom: 0.375rem !important;\n padding-left: 0.75rem !important;\n cursor: pointer !important;\n max-width: 120px;\n}\n.mes-filter-datetimepicker{\n max-width: 97px;\n}\n.mes-not-rounded{\n border-radius: unset !important;\n}\n\n.mes-numeric{\n text-align: right;\n}\n.mes-drag-over{\n border: 3px dotted #666;\n background-color: #479dc4 !important;\n}\n.mes-drag-start{\n border: 3px solid #666;\n}\n\n.mes-selectable{\n cursor: pointer !important;\n}\n\n.mes-custom-select{\n width: auto !important;\n padding: 0.375rem 0 0.375rem 0 !important;\n background: unset !important;\n font-family: inherit !important;\n}\n.mes-custom-select .MuiSelect-select{\n padding-left: 14px;\n}\n\n.mes-custom-select::before{\n border-bottom: unset !important;\n}\n.mes-custom-select::after{\n border-bottom: unset !important;\n}\n.mes-no-border{\n border: unset;\n}\n.mes-no-border:focus-visible {\n outline: unset;\n}\n.mes-div-submenu{\n border-right: 1px solid #cfdbe2;\n overflow-y: scroll;\n max-height: 80vh;\n}\n.mes-submenu a{\n width: 100% !important;\n /* color: rgba(0, 0, 0, 0.87); */\n color: #479dc4\n}\n.mes-submenu .Mui-selected{\n border-right: 3px solid #479dc4; \n}\n.mes-menu-group{\n font-size: 20px;\n line-height: 1.1;\n color: #929292; \n font-weight: normal; \n}\n\n/********************MUI DATAGRID*****************************/\n.Mui-selected{\n font-weight: bolder !important;\n opacity: 1 !important;\n}\n\n.mes-upload-control{\n\n}\n.mes-upload-control .file-box{\n /* border : 1px solid black; */\n height : 100px;\n position: relative; \n}\n.mes-upload-control .file-detail{\n position: absolute;\n left: 0px;\n top: 0px; \n z-index: 1;\n height: 100%;\n width: 100%;\n}\n\n.mes-upload-control input[type=file]{\n left: 0px;\n top: 0px;\n opacity: 0;\n z-index: 10000;\n height: 100%;\n cursor: pointer;\n}\n.mes-upload-control table{\n width: 100%;\n}\n.mes-upload-control td{\n font-size: 0.8rem !important;\n max-width:0;overflow: hidden;text-overflow: ellipsis;white-space: nowrap;\n}\n\n\n.input-group-text{\n background-color: #ced2cc !important;\n /* border: 1px solid #ced4da !important; */\n /* color: #000000 !important; */\n}\n\n\n\n\n.content-wrapper {\n padding: 15px;\n width: 100%;\n border-top: 1px solid rgba(0, 0, 0, 0.15);\n margin-top: -1px;\n}\n.content-wrapper > .unwrap {\n margin: -15px;\n}\n@media only screen and (min-width: 768px) {\n .content-wrapper > .unwrap {\n margin: -20px;\n }\n}\n.content-wrapper > h3,\n.content-wrapper > .content-heading {\n font-size: 24px;\n line-height: 1.1;\n color: #929292;\n margin: -15px;\n margin-bottom: 20px;\n padding: 15px;\n font-weight: normal;\n background-color: #fafbfc;\n border-bottom: 1px solid #cfdbe2;\n}\n.content-wrapper > h3 > small,\n.content-wrapper > .content-heading > small {\n display: block;\n font-size: 12px;\n color: #909fa7;\n}\n.content-wrapper > button,\n.content-wrapper > .btn {\n margin: 10px 10px 0 0;\n}\n.content-wrapper .container,\n.content-wrapper .container-fluid {\n padding-left: 0;\n padding-right: 0;\n}\n@media only screen and (min-width: 768px) {\n .content-wrapper {\n padding: 20px;\n }\n .content-wrapper > h3,\n .content-wrapper > .content-heading {\n margin: -20px;\n margin-bottom: 5px;\n padding: 15px;\n }\n .content-wrapper > button,\n .content-wrapper > .btn {\n margin: 0;\n }\n}\n\n @media print {\n .sidebar,\n .topnavbar,\n .offsidebar,\n .btn {\n display: none !important;\n width: 0 !important;\n height: 0 !important;\n }\n .wrapper,\n .wrapper > section,\n .content-wrapper {\n margin: 0 !important;\n /* remove margin used for sidebar and expand the content */\n padding: 0 !important;\n width: 100% !important;\n }\n .content-wrapper {\n overflow: hidden !important;\n }\n }\n ";
13320
+ var css = "body {\n\tmargin: 0;\n\tfont-family: -apple-system, BlinkMacSystemFont, \"Segoe UI\", \"Roboto\", \"Oxygen\",\n\t\t\"Ubuntu\", \"Cantarell\", \"Fira Sans\", \"Droid Sans\", \"Helvetica Neue\",\n\t\tsans-serif;\n\t-webkit-font-smoothing: antialiased;\n\t-moz-osx-font-smoothing: grayscale;\n\tbackground-color: #fafbfc !important;\n}\n.container-fluid-main {\n\tpadding-right: 0px !important;\n\tpadding-left: 0px !important;\n}\n\ncode {\n\tfont-family: source-code-pro, Menlo, Monaco, Consolas, \"Courier New\",\n\t\tmonospace;\n}\n\n.mes-primary-color {\n\tbackground-color: #479dc4 !important;\n}\n.mes-button-primary {\n\tbackground-color: #479dc4 !important;\n\tborder-color: #479dc4 !important;\n}\n\n.mes-selectable-datagrid .MuiDataGrid-row {\n\tcursor: pointer;\n}\n\n.mes-menu-top .navbar-brand {\n\tcolor: #ffff !important;\n}\n.mes-menu-top .nav-link {\n\tcolor: #ffff !important;\n}\n.mes-menu-top .navbar-toggler {\n\tcolor: #ffff !important;\n}\n.mes-menu-top .navbar-text {\n\tcolor: #ffff !important;\n}\n.mes-footer-login {\n\tposition: absolute;\n\tbottom: 0;\n\twidth: 100%;\n\theight: 10em;\n\tline-height: 60px;\n\ttext-align: center;\n}\n.mes-filter-datepicker {\n\tpadding: unset !important;\n\tborder-top-left-radius: 0 !important;\n\tborder-bottom-left-radius: 0 !important;\n\tpadding-top: 0.375rem !important;\n\tpadding-bottom: 0.375rem !important;\n\tpadding-left: 0.75rem !important;\n\tcursor: pointer !important;\n\tmax-width: 120px;\n}\n.mes-filter-datetimepicker {\n\tmax-width: 97px;\n}\n.mes-not-rounded {\n\tborder-radius: unset !important;\n}\n\n.mes-numeric {\n\ttext-align: right;\n}\n.mes-drag-over {\n\tborder: 3px dotted #666;\n\tbackground-color: #479dc4 !important;\n}\n.mes-drag-start {\n\tborder: 3px solid #666;\n}\n\n.mes-selectable {\n\tcursor: pointer !important;\n}\n\n.mes-custom-select {\n\twidth: auto !important;\n\tpadding: 0.375rem 0 0.375rem 0 !important;\n\tbackground: unset !important;\n\tfont-family: inherit !important;\n}\n.mes-custom-select .MuiSelect-select {\n\tpadding-left: 14px;\n}\n\n.mes-custom-select::before {\n\tborder-bottom: unset !important;\n}\n.mes-custom-select::after {\n\tborder-bottom: unset !important;\n}\n.mes-no-border {\n\tborder: unset;\n}\n.mes-no-border:focus-visible {\n\toutline: unset;\n}\n.mes-div-submenu {\n\tborder-right: 1px solid #cfdbe2;\n\toverflow-y: scroll;\n\tmax-height: 80vh;\n}\n.mes-submenu a {\n\twidth: 100% !important;\n\t/* color: rgba(0, 0, 0, 0.87); */\n\tcolor: #479dc4;\n}\n.mes-submenu .Mui-selected {\n\tborder-right: 3px solid #479dc4;\n}\n.mes-menu-group {\n\tfont-size: 20px;\n\tline-height: 1.1;\n\tcolor: #929292;\n\tfont-weight: normal;\n}\n\n/********************MUI DATAGRID*****************************/\n.Mui-selected {\n\tfont-weight: bolder !important;\n\topacity: 1 !important;\n}\n\n.mes-upload-control {\n}\n.mes-upload-control .file-box {\n\t/* border : 1px solid black; */\n\theight: 100px;\n\tposition: relative;\n}\n.mes-upload-control .file-detail {\n\tposition: absolute;\n\tleft: 0px;\n\ttop: 0px;\n\tz-index: 1;\n\theight: 100%;\n\twidth: 100%;\n}\n\n.mes-upload-control input[type=\"file\"] {\n\tleft: 0px;\n\ttop: 0px;\n\topacity: 0;\n\tz-index: 10000;\n\theight: 100%;\n\tcursor: pointer;\n}\n.mes-upload-control table {\n\twidth: 100%;\n}\n.mes-upload-control td {\n\tfont-size: 0.8rem !important;\n\tmax-width: 0;\n\toverflow: hidden;\n\ttext-overflow: ellipsis;\n\twhite-space: nowrap;\n}\n\n.input-group-text {\n\tbackground-color: #ced2cc !important;\n\t/* border: 1px solid #ced4da !important; */\n\t/* color: #000000 !important; */\n}\n\n.content-wrapper {\n\tpadding: 15px;\n\twidth: 100%;\n\tborder-top: 1px solid rgba(0, 0, 0, 0.15);\n\tmargin-top: -1px;\n}\n.content-wrapper > .unwrap {\n\tmargin: -15px;\n}\n@media only screen and (min-width: 768px) {\n\t.content-wrapper > .unwrap {\n\t\tmargin: -20px;\n\t}\n}\n.content-wrapper > h3,\n.content-wrapper > .content-heading {\n\tfont-size: 24px;\n\tline-height: 1.1;\n\tcolor: #929292;\n\tmargin: -15px;\n\tmargin-bottom: 20px;\n\tpadding: 15px;\n\tfont-weight: normal;\n\tbackground-color: #fafbfc;\n\tborder-bottom: 1px solid #cfdbe2;\n}\n.content-wrapper > h3 > small,\n.content-wrapper > .content-heading > small {\n\tdisplay: block;\n\tfont-size: 12px;\n\tcolor: #909fa7;\n}\n.content-wrapper > button,\n.content-wrapper > .btn {\n\tmargin: 10px 10px 0 0;\n}\n.content-wrapper .container,\n.content-wrapper .container-fluid {\n\tpadding-left: 0;\n\tpadding-right: 0;\n}\n@media only screen and (min-width: 768px) {\n\t.content-wrapper {\n\t\tpadding: 20px;\n\t}\n\t.content-wrapper > h3,\n\t.content-wrapper > .content-heading {\n\t\tmargin: -20px;\n\t\tmargin-bottom: 5px;\n\t\tpadding: 15px;\n\t}\n\t.content-wrapper > button,\n\t.content-wrapper > .btn {\n\t\tmargin: 0;\n\t}\n}\n\n@media print {\n\t.sidebar,\n\t.topnavbar,\n\t.offsidebar,\n\t.btn {\n\t\tdisplay: none !important;\n\t\twidth: 0 !important;\n\t\theight: 0 !important;\n\t}\n\t.wrapper,\n\t.wrapper > section,\n\t.content-wrapper {\n\t\tmargin: 0 !important;\n\t\t/* remove margin used for sidebar and expand the content */\n\t\tpadding: 0 !important;\n\t\twidth: 100% !important;\n\t}\n\t.content-wrapper {\n\t\toverflow: hidden !important;\n\t}\n}\n";
12239
13321
  n(css,{});
12240
13322
 
12241
13323
  var timezone = TimeService.getInstance().getServerTimeZone();
12242
- moment$3.tz.setDefault(timezone);
13324
+ moment$5.tz.setDefault(timezone);
12243
13325
  var base = document.getElementsByTagName("base")[0].getAttribute("href") || "/";
12244
13326
  function MESFMain(_a) {
12245
13327
  var authentication = _a.authentication, routes = _a.routes, navbar = _a.navbar, _b = _a.navbarTitle, navbarTitle = _b === void 0 ? "MESF" : _b, configurations = _a.configurations, _c = _a.showAreaSelector, showAreaSelector = _c === void 0 ? false : _c, _d = _a.showTrendingsIcon, showTrendingsIcon = _d === void 0 ? true : _d;
12246
13328
  return (React__default.createElement(AuthProvider, { authConfig: authentication },
12247
- React__default.createElement(LocalizationProvider, { dateAdapter: AdapterMoment, dateLibInstance: moment$3 },
13329
+ React__default.createElement(LocalizationProvider, { dateAdapter: AdapterMoment, dateLibInstance: moment$5 },
12248
13330
  React__default.createElement(UserProvider, null,
12249
13331
  React__default.createElement(AssetProvider, null,
12250
13332
  React__default.createElement(UTLSettingsProvider, null,
@@ -12279,7 +13361,7 @@ var useDefaultAreaId = function (setError) {
12279
13361
  };
12280
13362
 
12281
13363
  var useStyles = makeStyles(function (theme) {
12282
- return createStyles$1({
13364
+ return createStyles({
12283
13365
  root: {
12284
13366
  "& .MuiInputBase-input": {
12285
13367
  color: "#000 !important"
@@ -12398,5 +13480,5 @@ var areaSelector = /*#__PURE__*/Object.freeze({
12398
13480
  AreaSelector: AreaSelector
12399
13481
  });
12400
13482
 
12401
- export { Account, AssetProvider, AuthContext, AuthProvider, BarChartControl, ButtonWithLoading, ChangePassword, CheckBoxControl, Configuration$1 as Configuration, ContextMenu$1 as ContextMenu, ContextMenuMESFProvider, CurrencyFormatter, DataGridControl, DateFormatter, DateTimeFormatter, ErrorModal, FetchError, FilterPanel, GenericPanel, GenericTable, GetCrewColor, GetShiftColor, HorizontalTextControl, IntegerFormatter, Login, Logout, LongFilterPanel, MESApiService, MESFMain, MESSAGE_API, MESSAGE_ERRORS, MasterDetailPanel, MesfModal, ModalTreeFilterControl, MultipleSelectorControl, NumberFormatter, NumericTextControl, ShiftDayNavigatorControl, ShiftNavigatorProvider, SimplePasswordControl, SimpleSelectorControl, SimpleTextAreaControl, SimpleTextControl, TimeFormatter, TimeService, TreePickerControl, TreePickerControlV2, TrendingsPage, USER_LABELS, UTLSettingsProvider, UploadFileControl, UserProvider, axiosInstance, deleteUser, dxtServerTimeZone, dxtToLocalServerTime, dxtToUTC, formatNumber, getAuthTypes, getCrewStyle, getDataUser, getError, getMomentTz, getProfiles, getShiftByParameters, getShiftStyle, getTokenFromLS, getUsers, renewToken, setPassword, setProfilesToUser, upsertUser, useAssetContext, useContextMenuMESF, useShiftNavigator, useShiftNavigatorManager, useStyles$1 as useStyles, useToken, useUTLSettingsContext, useUserContext };
13483
+ export { Account, AssetProvider, AuthContext, AuthProvider, BarChartControl, ButtonWithLoading, ChangePassword, CheckBoxControl, Configuration$1 as Configuration, ContextMenu$1 as ContextMenu, ContextMenuMESFProvider, CurrencyFormatter, DataGridControl, DateFormatter, DateTimeFormatter, ErrorModal, FetchError, FilterPanel, GenericPanel, GenericTable, GetCrewColor, GetShiftColor, HorizontalTextControl, IntegerFormatter, Login, Logout, LongFilterPanel, MESApiService, MESFMain, MESSAGE_API, MESSAGE_ERRORS, MasterDetailPanel, MesfModal, ModalTreeFilterControl, MultipleSelectorControl, NumberFormatter, NumericTextControl, ShiftDayNavigatorControl, ShiftNavigatorProvider, ShiftPeriodNavigatorControl, SimplePasswordControl, SimpleSelectorControl, SimpleTextAreaControl, SimpleTextControl, TimeFormatter, TimeService, TreePickerControl, TreePickerControlV2, TrendingsPage, USER_LABELS, UTLSettingsProvider, UploadFileControl, UserProvider, axiosInstance, deleteUser, dxtServerTimeZone, dxtToLocalServerTime, dxtToUTC, formatNumber, getAuthTypes, getCrewStyle, getDataUser, getError, getMomentTz, getProfiles, getShiftByParameters, getShiftStyle, getShiftsRangeByParameters, getTokenFromLS, getUsers, renewToken, setPassword, setProfilesToUser, upsertUser, useAssetContext, useContextMenuMESF, useShiftNavigator, useShiftNavigatorManager, useStyles$4 as useStyles, useToken, useUTLSettingsContext, useUserContext };
12402
13484
  //# sourceMappingURL=index.esm.js.map