* 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) * Car table update (#27) * Add Datadog RUM (#28) * fix run.sh * Add updates by car screen and modal popup (#29) * CEC-180 Cache Control (#30) * Set cache expire to 1 day Add snapshot tests for new screens * Fix table pagniation random ids for snapshot tests * Auto reload on chunk load error * OTA Admin Portal => Admin Portal * CEC-179 Car download progress (#32) * Display download progress * Change default * Fix * Fix * Update readme * Update readme and defaults Fix Dockerfile * CEC-179 Car update progress build fix (#33) * Display download progress * Change default * Fix * Fix * Update readme * Update readme and defaults Fix Dockerfile * Fix build * Undo Docker changes (#34) Co-authored-by: Rafi Greenberg <rgreenberg@fiskerinc.com> Co-authored-by: Roger Standridge <rstandridge@fiskerinc.com>
166 lines
4.4 KiB
JavaScript
166 lines
4.4 KiB
JavaScript
import React, { useRef, useState } from "react";
|
|
import { Button, TextField, Typography } from "@material-ui/core";
|
|
import { DropzoneArea } from "material-ui-dropzone";
|
|
import { useUserContext } from "../../Contexts/UserContext";
|
|
import { useStatusContext } from "../../Contexts/StatusContext";
|
|
import {
|
|
useFileUploadContext,
|
|
FileUploadProvider,
|
|
} from "../../Contexts/FileUploadContext";
|
|
import ModalProgressBar from "../../ModalProgressBar";
|
|
import useStyles from "../../useStyles";
|
|
import { Redirect } from "react-router";
|
|
|
|
const FileUploadZone = ({ classes, token }) => {
|
|
const { setFiles } = useFileUploadContext();
|
|
const { setMessage } = useStatusContext();
|
|
|
|
return (
|
|
<>
|
|
<DropzoneArea
|
|
id="dropzone"
|
|
showPreviews={true}
|
|
showPreviewsInDropzone={false}
|
|
useChipsForPreview
|
|
previewGridProps={{ container: { spacing: 1, direction: "row" } }}
|
|
previewChipProps={{ classes: { root: classes.previewChip } }}
|
|
previewText="Selected files"
|
|
maxFileSize={1e9}
|
|
filesLimit={1}
|
|
showAlerts={false}
|
|
onChange={(files) => setFiles(files)}
|
|
onDelete={(files) => setFiles(files)}
|
|
onDropRejected={(files) => {
|
|
setMessage(`Rejected ${files[0].name} too large`);
|
|
}}
|
|
/>
|
|
<ModalProgressBar />
|
|
</>
|
|
);
|
|
};
|
|
|
|
const MainForm = () => {
|
|
const { uploading, upload, files, cancel } = useFileUploadContext();
|
|
const { token } = useUserContext();
|
|
const { setMessage } = useStatusContext();
|
|
const [redirect, setRedirect] = useState(null);
|
|
const classes = useStyles();
|
|
const packagenameEl = useRef(null);
|
|
const versionEl = useRef(null);
|
|
const descEl = useRef(null);
|
|
const releasenotesEl = useRef(null);
|
|
const onSubmit = async (event) => {
|
|
try {
|
|
event.preventDefault();
|
|
const {
|
|
idToken: { jwtToken: authToken },
|
|
} = token;
|
|
const formData = {
|
|
packagename: packagenameEl.current.value,
|
|
version: versionEl.current.value,
|
|
description: descEl.current.value,
|
|
releasenotes: releasenotesEl.current.value,
|
|
};
|
|
const result = await upload(formData, authToken, files);
|
|
|
|
if (!result || result.error) return;
|
|
|
|
cancel();
|
|
setMessage(`Package uploaded`);
|
|
setRedirect(`/carupdate-deploy/${result.id}`);
|
|
} catch (e) {
|
|
setMessage(e.message);
|
|
}
|
|
};
|
|
|
|
if (redirect && redirect.length > 0) {
|
|
return <Redirect to={redirect} />;
|
|
}
|
|
|
|
return (
|
|
<div className={classes.paper}>
|
|
<Typography component="h1" variant="h5">
|
|
Create Update Package
|
|
</Typography>
|
|
<form className={classes.form} noValidate action="{onSubmit}">
|
|
<TextField
|
|
id="packagename"
|
|
name="packagename"
|
|
label="Package name"
|
|
variant="outlined"
|
|
margin="normal"
|
|
inputProps={{
|
|
maxLength: "255",
|
|
}}
|
|
required
|
|
fullWidth
|
|
inputRef={packagenameEl}
|
|
/>
|
|
<TextField
|
|
id="version"
|
|
name="version"
|
|
label="Version"
|
|
variant="outlined"
|
|
margin="normal"
|
|
inputProps={{
|
|
maxLength: "255",
|
|
}}
|
|
required
|
|
fullWidth
|
|
inputRef={versionEl}
|
|
/>
|
|
<TextField
|
|
id="description"
|
|
name="description"
|
|
label="Description"
|
|
variant="outlined"
|
|
margin="normal"
|
|
inputProps={{
|
|
maxLength: "5120",
|
|
}}
|
|
required
|
|
fullWidth
|
|
multiline
|
|
rows={4}
|
|
placeholder="Package description"
|
|
inputRef={descEl}
|
|
/>
|
|
<TextField
|
|
id="releasenotes"
|
|
name="releasenotes"
|
|
label="Release Notes URL"
|
|
variant="outlined"
|
|
margin="normal"
|
|
inputProps={{
|
|
maxLength: "1024",
|
|
}}
|
|
required
|
|
fullWidth
|
|
placeholder="Release Notes URL"
|
|
inputRef={releasenotesEl}
|
|
/>
|
|
<FileUploadZone classes={classes} />
|
|
<Button
|
|
type="submit"
|
|
disabled={uploading}
|
|
fullWidth
|
|
variant="contained"
|
|
color="primary"
|
|
className={classes.submit}
|
|
onClick={onSubmit}
|
|
>
|
|
{uploading ? "Uploading..." : "Submit"}
|
|
</Button>
|
|
</form>
|
|
</div>
|
|
);
|
|
};
|
|
|
|
export default function FileUploadForm() {
|
|
return (
|
|
<FileUploadProvider>
|
|
<MainForm />
|
|
</FileUploadProvider>
|
|
);
|
|
}
|