* Fix sign up form bug * Add run.sh to run setup and run web app * Output node version * Update readme with run.sh * Fix file upload form to handle ota_update service * Enable file upload form Enable error boundary to catch React errors (#7) Fix warning for link noreferrer Include authorization header with file upload * Remove default localhost settings (#8) * Remove default localhost settings Replace with deployment settings * Fix for upload data format * Fix test data for last commit * Fix json link format and remove localhost default settings (#10) * Remove default localhost settings Replace with deployment settings * Fix for upload data format * Fix test data for last commit * Fix link data format * Fix link json again (#12) Use id token instead of access token * nginx things * Web Worker Sign Out and Use Go API (#13) * Calculate checksum and send with file upload * Limit file upload and display rejected file error * Add sign in timeout * Check auth token structure before setting Clean up * Use web worker timer to sign out Remove checksum Point to Go ota update * Remove checksum dependency * Use compute auth service and fix static code analyzer warnings (#15) * Clean up formatting * Use new compute_auth service Implment SSO Implement token refresh Clean up unit tests * Fix unit tests * Fix auth test Fix warnings * Update default settings for compute_auth * Change main UI layout and add VINs to add and upload forms (#16) * Add new upload update package form Add new add vehicle form Add new side menu layout Add new toolbar layout Update and add unit tests * Enable add get and add vehicles * Integration issues with ota_update service * Update get vehicle JSON format * Fix related unit test Add release notes field * Add StatusContext to display error and status messages * Handle api error json (#18) * Handle api error json * Fix get vehicles error handling Update .env.template * Fix signout refresh (#20) * Merge to main (#17) * Fix sign up form bug * Add run.sh to run setup and run web app * Output node version * Update readme with run.sh * Fix file upload form to handle ota_update service * Enable file upload form Enable error boundary to catch React errors (#7) Fix warning for link noreferrer Include authorization header with file upload * Remove default localhost settings (#8) * Remove default localhost settings Replace with deployment settings * Fix for upload data format * Fix test data for last commit * Fix json link format and remove localhost default settings (#10) * Remove default localhost settings Replace with deployment settings * Fix for upload data format * Fix test data for last commit * Fix link data format * Fix link json again (#12) Use id token instead of access token * nginx things * Web Worker Sign Out and Use Go API (#13) * Calculate checksum and send with file upload * Limit file upload and display rejected file error * Add sign in timeout * Check auth token structure before setting Clean up * Use web worker timer to sign out Remove checksum Point to Go ota update * Remove checksum dependency * Use compute auth service and fix static code analyzer warnings (#15) * Clean up formatting * Use new compute_auth service Implment SSO Implement token refresh Clean up unit tests * Fix unit tests * Fix auth test Fix warnings * Update default settings for compute_auth * Change main UI layout and add VINs to add and upload forms (#16) * Add new upload update package form Add new add vehicle form Add new side menu layout Add new toolbar layout Update and add unit tests * Enable add get and add vehicles * Integration issues with ota_update service * Update get vehicle JSON format * Fix related unit test Add release notes field * Add StatusContext to display error and status messages * Handle api error json (#18) * Handle api error json * Fix get vehicles error handling Update .env.template Co-authored-by: Rafi Greenberg <rgreenberg@fiskerinc.com> * Fix sign out and refresh * Check for bad json Co-authored-by: Rafi Greenberg <rgreenberg@fiskerinc.com> * Add role checks (#21) * Add role checks * Remove moved Roles enum * Add package updates, car updates, and vehicle screens (#25) Co-authored-by: Rafi Greenberg <rgreenberg@fiskerinc.com>
157 lines
4.5 KiB
JavaScript
157 lines
4.5 KiB
JavaScript
import React, { useEffect, useState } from "react";
|
|
import { Link } from "react-router-dom";
|
|
import {
|
|
Table,
|
|
TableBody,
|
|
TableCell,
|
|
TableContainer,
|
|
TableFooter,
|
|
TableHead,
|
|
TablePagination,
|
|
TableRow,
|
|
Tooltip,
|
|
Typography,
|
|
} from "@material-ui/core";
|
|
import EditIcon from "@material-ui/icons/Edit";
|
|
import SendIcon from "@material-ui/icons/Send";
|
|
import VisibilityIcon from "@material-ui/icons/Visibility";
|
|
import useStyles from "../../useStyles";
|
|
import {
|
|
UpdatesProvider,
|
|
useUpdatesContext,
|
|
} from "../../Contexts/UpdatesContext";
|
|
import { useUserContext } from "../../Contexts/UserContext";
|
|
import { tsLocalDateTimeString } from "../../../utils/dates";
|
|
import { Roles, hasRole } from "../../../utils/roles";
|
|
|
|
const UpdatePackagesList = () => {
|
|
const classes = useStyles();
|
|
const [pageSize, setPageSize] = useState(5);
|
|
const [pageIndex, setPageIndex] = useState(0);
|
|
const { getPackages, packages, totalPackages } = useUpdatesContext();
|
|
const {
|
|
token: {
|
|
idToken: { jwtToken: token },
|
|
},
|
|
groups,
|
|
} = useUserContext();
|
|
|
|
useEffect(() => {
|
|
getPackages({ limit: pageSize, offset: pageSize * pageIndex }, token);
|
|
// eslint-disable-next-line
|
|
}, [pageIndex, pageSize, token]);
|
|
|
|
const handleChangePageIndex = (event, newIndex) => {
|
|
setPageIndex(newIndex);
|
|
};
|
|
|
|
const handleChangePageSize = (event) => {
|
|
setPageSize(parseInt(event.target.value, 10));
|
|
setPageIndex(0);
|
|
};
|
|
|
|
const Actions = (row) => {
|
|
let actions = [];
|
|
if (hasRole([Roles.CREATE, Roles.READ], groups)) {
|
|
actions.push({
|
|
tip: `Status "${row.package_name} ${row.version}"`,
|
|
link: `/carupdate-status/${row.id}`,
|
|
icon: (
|
|
<VisibilityIcon
|
|
aria-label={`Status ${row.package_name} ${row.version}`}
|
|
/>
|
|
),
|
|
});
|
|
}
|
|
if (hasRole([Roles.CREATE], groups)) {
|
|
actions = actions.concat([
|
|
{
|
|
tip: `Edit "${row.package_name} ${row.version}"`,
|
|
link: `/update/${row.id}`,
|
|
icon: (
|
|
<EditIcon aria-label={`Edit ${row.package_name} ${row.version}`} />
|
|
),
|
|
},
|
|
{
|
|
tip: `Deploy "${row.package_name} ${row.version}"`,
|
|
link: `/carupdate-deploy/${row.id}`,
|
|
icon: (
|
|
<SendIcon
|
|
aria-label={`Deploy ${row.package_name} ${row.version}`}
|
|
/>
|
|
),
|
|
},
|
|
]);
|
|
}
|
|
|
|
if (actions.length === 0) return "No actions";
|
|
|
|
return actions.map((action) => (
|
|
<Tooltip key={action.link} title={action.tip}>
|
|
<Link to={action.link} style={{ margin: 5 }}>
|
|
{action.icon}
|
|
</Link>
|
|
</Tooltip>
|
|
));
|
|
};
|
|
|
|
return (
|
|
<div className={classes.paper} style={{ height: 700, width: "100%" }}>
|
|
<Typography component="h1" variant="h5">
|
|
Updates
|
|
</Typography>
|
|
<TableContainer>
|
|
<Table>
|
|
<TableHead>
|
|
<TableRow>
|
|
<TableCell align="center">ID</TableCell>
|
|
<TableCell align="center">Name</TableCell>
|
|
<TableCell align="center">Version</TableCell>
|
|
<TableCell align="center">Created</TableCell>
|
|
<TableCell align="right">Actions</TableCell>
|
|
</TableRow>
|
|
</TableHead>
|
|
<TableBody>
|
|
{packages.map((row) => (
|
|
<TableRow key={row.id}>
|
|
<TableCell align="center">{row.id}</TableCell>
|
|
<TableCell align="center">{row.package_name}</TableCell>
|
|
<TableCell align="center">{row.version}</TableCell>
|
|
<TableCell align="center">
|
|
{tsLocalDateTimeString(row.timestamp)}
|
|
</TableCell>
|
|
<TableCell align="right">{Actions(row)}</TableCell>
|
|
</TableRow>
|
|
))}
|
|
</TableBody>
|
|
<TableFooter>
|
|
<TableRow>
|
|
<TablePagination
|
|
rowsPerPageOptions={[5, 10, 25]}
|
|
colSpan={5}
|
|
count={totalPackages}
|
|
rowsPerPage={pageSize}
|
|
page={pageIndex}
|
|
SelectProps={{
|
|
inputProps: { "aria-label": "rows per page" },
|
|
native: true,
|
|
}}
|
|
onChangePage={handleChangePageIndex}
|
|
onChangeRowsPerPage={handleChangePageSize}
|
|
/>
|
|
</TableRow>
|
|
</TableFooter>
|
|
</Table>
|
|
</TableContainer>
|
|
</div>
|
|
);
|
|
};
|
|
|
|
const UpdatePackagesForm = () => (
|
|
<UpdatesProvider>
|
|
<UpdatePackagesList />
|
|
</UpdatesProvider>
|
|
);
|
|
|
|
export default UpdatePackagesForm;
|