Fix import statements and add missing code comments
parent
e085e36934
commit
77c0264963
|
@ -13,6 +13,7 @@
|
|||
"@flare/js-utils": "^1.1.0",
|
||||
"@flare/tuitio-client-react": "^1.2.6",
|
||||
"@mui/icons-material": "^5.14.16",
|
||||
"@mui/lab": "^5.0.0-alpha.169",
|
||||
"@mui/material": "^5.14.16",
|
||||
"axios": "^1.6.0",
|
||||
"i18next": "^22.4.15",
|
||||
|
@ -3484,6 +3485,46 @@
|
|||
}
|
||||
}
|
||||
},
|
||||
"node_modules/@mui/lab": {
|
||||
"version": "5.0.0-alpha.169",
|
||||
"resolved": "https://registry.npmjs.org/@mui/lab/-/lab-5.0.0-alpha.169.tgz",
|
||||
"integrity": "sha512-h6xe1K6ISKUbyxTDgdvql4qoDP6+q8ad5fg9nXQxGLUrIeT2jVrBuT/jRECSTufbnhzP+V5kulvYxaMfM8rEdA==",
|
||||
"dependencies": {
|
||||
"@babel/runtime": "^7.23.9",
|
||||
"@mui/base": "5.0.0-beta.40",
|
||||
"@mui/system": "^5.15.14",
|
||||
"@mui/types": "^7.2.14",
|
||||
"@mui/utils": "^5.15.14",
|
||||
"clsx": "^2.1.0",
|
||||
"prop-types": "^15.8.1"
|
||||
},
|
||||
"engines": {
|
||||
"node": ">=12.0.0"
|
||||
},
|
||||
"funding": {
|
||||
"type": "opencollective",
|
||||
"url": "https://opencollective.com/mui-org"
|
||||
},
|
||||
"peerDependencies": {
|
||||
"@emotion/react": "^11.5.0",
|
||||
"@emotion/styled": "^11.3.0",
|
||||
"@mui/material": ">=5.15.0",
|
||||
"@types/react": "^17.0.0 || ^18.0.0",
|
||||
"react": "^17.0.0 || ^18.0.0",
|
||||
"react-dom": "^17.0.0 || ^18.0.0"
|
||||
},
|
||||
"peerDependenciesMeta": {
|
||||
"@emotion/react": {
|
||||
"optional": true
|
||||
},
|
||||
"@emotion/styled": {
|
||||
"optional": true
|
||||
},
|
||||
"@types/react": {
|
||||
"optional": true
|
||||
}
|
||||
}
|
||||
},
|
||||
"node_modules/@mui/material": {
|
||||
"version": "5.15.14",
|
||||
"resolved": "https://registry.npmjs.org/@mui/material/-/material-5.15.14.tgz",
|
||||
|
@ -21308,6 +21349,20 @@
|
|||
"@babel/runtime": "^7.23.9"
|
||||
}
|
||||
},
|
||||
"@mui/lab": {
|
||||
"version": "5.0.0-alpha.169",
|
||||
"resolved": "https://registry.npmjs.org/@mui/lab/-/lab-5.0.0-alpha.169.tgz",
|
||||
"integrity": "sha512-h6xe1K6ISKUbyxTDgdvql4qoDP6+q8ad5fg9nXQxGLUrIeT2jVrBuT/jRECSTufbnhzP+V5kulvYxaMfM8rEdA==",
|
||||
"requires": {
|
||||
"@babel/runtime": "^7.23.9",
|
||||
"@mui/base": "5.0.0-beta.40",
|
||||
"@mui/system": "^5.15.14",
|
||||
"@mui/types": "^7.2.14",
|
||||
"@mui/utils": "^5.15.14",
|
||||
"clsx": "^2.1.0",
|
||||
"prop-types": "^15.8.1"
|
||||
}
|
||||
},
|
||||
"@mui/material": {
|
||||
"version": "5.15.14",
|
||||
"resolved": "https://registry.npmjs.org/@mui/material/-/material-5.15.14.tgz",
|
||||
|
|
|
@ -13,11 +13,12 @@
|
|||
},
|
||||
"private": true,
|
||||
"dependencies": {
|
||||
"@flare/js-utils": "^1.1.0",
|
||||
"@flare/tuitio-client-react": "^1.2.6",
|
||||
"@emotion/react": "^11.11.1",
|
||||
"@emotion/styled": "^11.11.0",
|
||||
"@flare/js-utils": "^1.1.0",
|
||||
"@flare/tuitio-client-react": "^1.2.6",
|
||||
"@mui/icons-material": "^5.14.16",
|
||||
"@mui/lab": "^5.0.0-alpha.169",
|
||||
"@mui/material": "^5.14.16",
|
||||
"axios": "^1.6.0",
|
||||
"i18next": "^22.4.15",
|
||||
|
@ -26,12 +27,12 @@
|
|||
"moment": "^2.29.4",
|
||||
"react": "^18.2.0",
|
||||
"react-dom": "^18.2.0",
|
||||
"react-world-flags": "^1.5.1",
|
||||
"react-i18next": "^12.2.2",
|
||||
"react-lazylog": "^4.5.3",
|
||||
"react-router-dom": "^6.10.0",
|
||||
"react-scripts": "5.0.1",
|
||||
"react-toastify": "^9.1.3"
|
||||
"react-toastify": "^9.1.3",
|
||||
"react-world-flags": "^1.5.1"
|
||||
},
|
||||
"devDependencies": {
|
||||
"@babel/plugin-proposal-private-property-in-object": "^7.21.11",
|
||||
|
|
|
@ -1,7 +1,6 @@
|
|||
import React, { useState } from "react";
|
||||
import PropTypes from "prop-types";
|
||||
import ToggleButton from "@material-ui/lab/ToggleButton";
|
||||
import ToggleButtonGroup from "@material-ui/lab/ToggleButtonGroup";
|
||||
import { ToggleButtonGroup, ToggleButton } from "@mui/material";
|
||||
import { Tooltip } from "@mui/material";
|
||||
|
||||
const NavigationButtons = ({ tabs, onTabChange }) => {
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
import React from "react";
|
||||
import { makeStyles } from "@mui/material/styles";
|
||||
import { Alert, AlertTitle } from "@material-ui/lab";
|
||||
import { Alert, AlertTitle } from "@mui/material";
|
||||
import { useTranslation } from "react-i18next";
|
||||
|
||||
const useStyles = makeStyles(theme => ({
|
||||
|
|
|
@ -4,8 +4,7 @@ import ReleaseNotesList from "./ReleaseNotesList";
|
|||
import TimelineComponent from "../timeline/TimelineComponent";
|
||||
import { routes, get } from "../../../utils/api";
|
||||
|
||||
const sort = releases =>
|
||||
releases.sort((a, b) => new Date(b.date) - new Date(a.date));
|
||||
const sort = releases => releases.sort((a, b) => new Date(b.date) - new Date(a.date));
|
||||
|
||||
const ReleaseNotesContainer = ({ view }) => {
|
||||
const [state, setState] = useState({ data: [], loaded: false });
|
||||
|
|
|
@ -1,20 +1,20 @@
|
|||
import React from "react";
|
||||
import PropTypes from "prop-types";
|
||||
import { makeStyles } from "@mui/material/styles";
|
||||
import Timeline from "@material-ui/lab/Timeline";
|
||||
import TimelineItem from "@material-ui/lab/TimelineItem";
|
||||
import TimelineSeparator from "@material-ui/lab/TimelineSeparator";
|
||||
import TimelineConnector from "@material-ui/lab/TimelineConnector";
|
||||
import TimelineContent from "@material-ui/lab/TimelineContent";
|
||||
import TimelineOppositeContent from "@material-ui/lab/TimelineOppositeContent";
|
||||
import TimelineDot from "@material-ui/lab/TimelineDot";
|
||||
import Timeline from "@mui/lab/Timeline";
|
||||
import TimelineItem from "@mui/lab/TimelineItem";
|
||||
import TimelineSeparator from "@mui/lab/TimelineSeparator";
|
||||
import TimelineConnector from "@mui/lab/TimelineConnector";
|
||||
import TimelineContent from "@mui/lab/TimelineContent";
|
||||
import TimelineOppositeContent from "@mui/lab/TimelineOppositeContent";
|
||||
import TimelineDot from "@mui/lab/TimelineDot";
|
||||
import Paper from "@mui/material/Paper";
|
||||
import Typography from "@mui/material/Typography";
|
||||
import { useTranslation } from "react-i18next";
|
||||
import { getRandomElement } from "../../../utils";
|
||||
import {
|
||||
Announcement,
|
||||
AmpStories,
|
||||
Book,
|
||||
Apps,
|
||||
BugReport,
|
||||
DeviceHub,
|
||||
|
@ -33,7 +33,7 @@ import {
|
|||
|
||||
const timelineIcons = [
|
||||
Announcement,
|
||||
AmpStories,
|
||||
Book,
|
||||
Apps,
|
||||
BugReport,
|
||||
DeviceHub,
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
import React from "react";
|
||||
import { makeStyles } from "@mui/material/styles";
|
||||
import { Alert, AlertTitle } from "@material-ui/lab";
|
||||
import { Alert, AlertTitle } from "@mui/material";
|
||||
import styles from "../styles";
|
||||
import { useTranslation } from "react-i18next";
|
||||
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
import React from "react";
|
||||
import { makeStyles } from "@mui/material/styles";
|
||||
import { Alert, AlertTitle } from "@material-ui/lab";
|
||||
import { Alert, AlertTitle } from "@mui/material";
|
||||
import styles from "../styles";
|
||||
import { useTranslation } from "react-i18next";
|
||||
import { useTuitioUser } from "@flare/tuitio-client-react";
|
||||
|
|
|
@ -26,13 +26,7 @@ const LoginContainer = () => {
|
|||
return login(userName, password);
|
||||
};
|
||||
|
||||
return (
|
||||
<LoginCard
|
||||
credentials={credentials}
|
||||
onChange={handleChange}
|
||||
onLogin={handleLogin}
|
||||
/>
|
||||
);
|
||||
return <LoginCard credentials={credentials} onChange={handleChange} onLogin={handleLogin} />;
|
||||
};
|
||||
|
||||
export default LoginContainer;
|
||||
|
|
|
@ -96,7 +96,9 @@ const MachineContainer = ({ machine, viewMode }) => {
|
|||
},
|
||||
{
|
||||
code: "advanced",
|
||||
effect: () => {},
|
||||
effect: () => {
|
||||
// to do: implement
|
||||
},
|
||||
icon: Launch,
|
||||
tooltip: t("Machine.Actions.Advanced"),
|
||||
main: false
|
||||
|
|
|
@ -1,8 +1,5 @@
|
|||
import React, { useContext, useEffect, useCallback, useState } from "react";
|
||||
import {
|
||||
NetworkStateContext,
|
||||
NetworkDispatchContext
|
||||
} from "../../network/state/contexts";
|
||||
import { NetworkStateContext, NetworkDispatchContext } from "../../network/state/contexts";
|
||||
import MachinesListComponent from "./MachinesListComponent";
|
||||
import PageTitle from "../../../components/common/PageTitle";
|
||||
import { useTranslation } from "react-i18next";
|
||||
|
@ -35,19 +32,9 @@ const MachinesContainer = () => {
|
|||
<>
|
||||
<PageTitle
|
||||
text={t("Menu.Machines")}
|
||||
toolBar={
|
||||
<ViewModeSelection
|
||||
callback={setViewMode}
|
||||
initialMode={ViewModes.TABLE}
|
||||
toolBar={<ViewModeSelection callback={setViewMode} initialMode={ViewModes.TABLE} />}
|
||||
/>
|
||||
}
|
||||
/>
|
||||
{viewMode && (
|
||||
<MachinesListComponent
|
||||
machines={state.network.machines}
|
||||
viewMode={viewMode}
|
||||
/>
|
||||
)}
|
||||
{viewMode && <MachinesListComponent machines={state.network.machines} viewMode={viewMode} />}
|
||||
</>
|
||||
);
|
||||
};
|
||||
|
|
|
@ -2,8 +2,7 @@ import React, { useState, useEffect, useCallback } from "react";
|
|||
import PropTypes from "prop-types";
|
||||
import TableChartIcon from "@mui/icons-material/TableChart";
|
||||
import ViewListIcon from "@mui/icons-material/ViewList";
|
||||
import ToggleButton from "@material-ui/lab/ToggleButton";
|
||||
import ToggleButtonGroup from "@material-ui/lab/ToggleButtonGroup";
|
||||
import { ToggleButtonGroup, ToggleButton } from "@mui/material";
|
||||
import { Tooltip } from "@mui/material";
|
||||
import { useTranslation } from "react-i18next";
|
||||
|
||||
|
|
|
@ -41,4 +41,6 @@ ActionButton.propTypes = {
|
|||
disabled: PropTypes.bool
|
||||
};
|
||||
|
||||
ActionButton.displayName = "ActionButton";
|
||||
|
||||
export default ActionButton;
|
||||
|
|
|
@ -71,7 +71,9 @@ const WakeComponent = ({ machine, addLog, disabled }) => {
|
|||
}, pingInterval);
|
||||
}
|
||||
},
|
||||
onError: () => {}
|
||||
onError: () => {
|
||||
// to do: handle error
|
||||
}
|
||||
}
|
||||
);
|
||||
}, [machine, log, pingInterval, disabled]);
|
||||
|
|
|
@ -6,16 +6,11 @@ import { initialState } from "./initialState";
|
|||
|
||||
const NetworkStateProvider = ({ children }) => {
|
||||
const [state, dispatch] = useReducer(reducer, initialState);
|
||||
const dispatchActions = useMemo(
|
||||
() => reducerDispatchActions(dispatch),
|
||||
[dispatch]
|
||||
);
|
||||
const dispatchActions = useMemo(() => reducerDispatchActions(dispatch), [dispatch]);
|
||||
|
||||
return (
|
||||
<NetworkStateContext.Provider value={state}>
|
||||
<NetworkDispatchContext.Provider value={dispatchActions}>
|
||||
{children}
|
||||
</NetworkDispatchContext.Provider>
|
||||
<NetworkDispatchContext.Provider value={dispatchActions}>{children}</NetworkDispatchContext.Provider>
|
||||
</NetworkStateContext.Provider>
|
||||
);
|
||||
};
|
||||
|
|
|
@ -17,6 +17,5 @@ export function reducer(state, action) {
|
|||
}
|
||||
|
||||
export const dispatchActions = dispatch => ({
|
||||
onNetworkChange: (prop, value) =>
|
||||
dispatch({ type: "onNetworkChange", payload: { prop, value } })
|
||||
onNetworkChange: (prop, value) => dispatch({ type: "onNetworkChange", payload: { prop, value } })
|
||||
});
|
||||
|
|
|
@ -1,6 +1,6 @@
|
|||
import React from "react";
|
||||
import PropTypes from "prop-types";
|
||||
import Flag from "react-flags";
|
||||
import Flag from "react-world-flags";
|
||||
import { IconButton, Menu, MenuItem } from "@mui/material";
|
||||
import { useTranslation } from "react-i18next";
|
||||
|
||||
|
|
|
@ -2,9 +2,7 @@ import React, { useState, useEffect } from "react";
|
|||
import { useTranslation } from "react-i18next";
|
||||
import LanguageComponent from "./LanguageComponent";
|
||||
|
||||
const flagsPath = process.env.PUBLIC_URL
|
||||
? `${process.env.PUBLIC_URL}/flags`
|
||||
: "flags";
|
||||
const flagsPath = process.env.PUBLIC_URL ? `${process.env.PUBLIC_URL}/flags` : "flags";
|
||||
|
||||
const LanguageContainer = () => {
|
||||
const [anchorEl, setAnchorEl] = useState(null);
|
||||
|
|
|
@ -3,9 +3,8 @@ import React from "react";
|
|||
const NotificationsContainer = () => {
|
||||
return (
|
||||
<div>
|
||||
Enable/Disable email notifications (for each one separately - when
|
||||
starting the machine, when stopping) You can go even further and have an
|
||||
advanced site where you can configure each individual machine.
|
||||
Enable/Disable email notifications (for each one separately - when starting the machine, when stopping) You can go
|
||||
even further and have an advanced site where you can configure each individual machine.
|
||||
</div>
|
||||
);
|
||||
};
|
||||
|
|
|
@ -23,8 +23,7 @@ const reducer = (state = initialState, action) => {
|
|||
};
|
||||
|
||||
const dispatchActions = dispatch => ({
|
||||
onSensitiveInfoEnabled: enabled =>
|
||||
dispatch({ type: "onSensitiveInfoEnabled", payload: { enabled } })
|
||||
onSensitiveInfoEnabled: enabled => dispatch({ type: "onSensitiveInfoEnabled", payload: { enabled } })
|
||||
});
|
||||
|
||||
const useSensitiveInfo = () => {
|
||||
|
|
|
@ -3,9 +3,4 @@ import ToastProvider from "./ToastProvider";
|
|||
import SensitiveInfoProvider from "./SensitiveInfoProvider";
|
||||
import UserPermissionsProvider from "./UserPermissionsProvider";
|
||||
|
||||
export {
|
||||
ThemeProvider,
|
||||
ToastProvider,
|
||||
SensitiveInfoProvider,
|
||||
UserPermissionsProvider
|
||||
};
|
||||
export { ThemeProvider, ToastProvider, SensitiveInfoProvider, UserPermissionsProvider };
|
||||
|
|
|
@ -49,16 +49,12 @@ i18n
|
|||
let startDate = moment(value.start);
|
||||
let endDate = moment(value.end);
|
||||
let span = moment.duration(endDate - startDate);
|
||||
return `${parseInt(span.asHours(), 10)}h ${parseInt(
|
||||
span.asMinutes() % 60,
|
||||
10
|
||||
)}m`;
|
||||
return `${parseInt(span.asHours(), 10)}h ${parseInt(span.asMinutes() % 60, 10)}m`;
|
||||
}
|
||||
return "";
|
||||
}
|
||||
|
||||
if (format === "intlNumber")
|
||||
return new Intl.NumberFormat(lng).format(value);
|
||||
if (format === "intlNumber") return new Intl.NumberFormat(lng).format(value);
|
||||
if (format === "intlDecimal")
|
||||
return new Intl.NumberFormat(lng, {
|
||||
minimumFractionDigits: 2
|
||||
|
|
|
@ -1,9 +1,7 @@
|
|||
const obfuscateForChars = (text, placeholder = "*") => {
|
||||
const firstChar = text.substring(0, 1);
|
||||
const lastChar = text.substring(text.length - 1);
|
||||
const middleChars = text
|
||||
.substring(1, text.length - 1)
|
||||
.replace(/[a-zA-Z0-9]/g, placeholder);
|
||||
const middleChars = text.substring(1, text.length - 1).replace(/[a-zA-Z0-9]/g, placeholder);
|
||||
return firstChar + middleChars + lastChar;
|
||||
};
|
||||
|
||||
|
@ -15,9 +13,7 @@ const obfuscate = (text, placeholder = "*") => {
|
|||
|
||||
const firstTwoChars = text.substring(0, 2);
|
||||
const lastChar = text.substring(text.length - 1);
|
||||
const middleChars = text
|
||||
.substring(2, text.length - 1)
|
||||
.replace(/[a-zA-Z0-9]/g, placeholder);
|
||||
const middleChars = text.substring(2, text.length - 1).replace(/[a-zA-Z0-9]/g, placeholder);
|
||||
return firstTwoChars + middleChars + lastChar;
|
||||
};
|
||||
|
||||
|
|
Loading…
Reference in New Issue