Merge branch 'development' into main

This commit is contained in:
jwu-fisker
2021-05-18 12:58:05 -07:00
9 changed files with 811 additions and 190 deletions

View File

@@ -299,17 +299,17 @@ exports[`App Route /carupdate-deploy authenticated 1`] = `
data-testid="mocked-userprovider"
>
<div
class="makeStyles-root-551"
class="makeStyles-root-559"
>
<header
class="MuiPaper-root MuiAppBar-root MuiAppBar-positionFixed MuiAppBar-colorPrimary makeStyles-appBar-552 makeStyles-appBarShift-553 mui-00000fixed MuiPaper-elevation4"
class="MuiPaper-root MuiAppBar-root MuiAppBar-positionFixed MuiAppBar-colorPrimary makeStyles-appBar-560 makeStyles-appBarShift-561 mui-00000fixed MuiPaper-elevation4"
>
<div
class="MuiToolbar-root MuiToolbar-regular MuiToolbar-gutters"
>
<button
aria-label="open drawer"
class="MuiButtonBase-root MuiIconButton-root makeStyles-menuButton-554 MuiIconButton-colorInherit MuiIconButton-edgeStart"
class="MuiButtonBase-root MuiIconButton-root makeStyles-menuButton-562 MuiIconButton-colorInherit MuiIconButton-edgeStart"
tabindex="0"
type="button"
>
@@ -337,7 +337,7 @@ exports[`App Route /carupdate-deploy authenticated 1`] = `
Fisker OTA Portal
</h6>
<button
class="MuiButtonBase-root MuiButton-root MuiButton-text makeStyles-rightToolbar-561 MuiButton-colorInherit"
class="MuiButtonBase-root MuiButton-root MuiButton-text makeStyles-rightToolbar-569 MuiButton-colorInherit"
tabindex="0"
type="button"
>
@@ -353,13 +353,13 @@ exports[`App Route /carupdate-deploy authenticated 1`] = `
</div>
</header>
<div
class="MuiDrawer-root MuiDrawer-docked makeStyles-drawer-556"
class="MuiDrawer-root MuiDrawer-docked makeStyles-drawer-564"
>
<div
class="MuiPaper-root MuiDrawer-paper makeStyles-drawerPaper-557 MuiDrawer-paperAnchorLeft MuiDrawer-paperAnchorDockedLeft MuiPaper-elevation0"
class="MuiPaper-root MuiDrawer-paper makeStyles-drawerPaper-565 MuiDrawer-paperAnchorLeft MuiDrawer-paperAnchorDockedLeft MuiPaper-elevation0"
>
<div
class="makeStyles-drawerHeader-558"
class="makeStyles-drawerHeader-566"
>
<button
class="MuiButtonBase-root MuiIconButton-root"
@@ -505,10 +505,10 @@ exports[`App Route /carupdate-deploy authenticated 1`] = `
</div>
</div>
<main
class="makeStyles-content-559 makeStyles-contentShift-560"
class="makeStyles-content-567 makeStyles-contentShift-568"
>
<div
class="makeStyles-drawerHeader-558"
class="makeStyles-drawerHeader-566"
/>
<main
class="MuiContainer-root MuiContainer-maxWidthLg"
@@ -517,7 +517,7 @@ exports[`App Route /carupdate-deploy authenticated 1`] = `
data-testid="mocked-updatesprovider"
>
<div
class="makeStyles-paper-540"
class="makeStyles-paper-548"
>
<h1
class="MuiTypography-root MuiTypography-h5"
@@ -527,7 +527,7 @@ exports[`App Route /carupdate-deploy authenticated 1`] = `
</h1>
<form
action="{onSubmit}"
class="makeStyles-form-542"
class="makeStyles-form-550"
novalidate=""
>
<div
@@ -631,10 +631,10 @@ exports[`App Route /carupdate-deploy authenticated 1`] = `
data-testid="mocked-vehicleprovider"
>
<div
class="makeStyles-form-542"
class="makeStyles-form-550"
>
<div
class="MuiFormControl-root makeStyles-formControlInline-545"
class="MuiFormControl-root makeStyles-formControlInline-553"
>
<label
class="MuiFormLabel-root MuiInputLabel-root MuiInputLabel-formControl MuiInputLabel-animated MuiInputLabel-shrink MuiInputLabel-outlined MuiFormLabel-filled"
@@ -676,11 +676,11 @@ exports[`App Route /carupdate-deploy authenticated 1`] = `
</svg>
<fieldset
aria-hidden="true"
class="PrivateNotchedOutline-root-563 MuiOutlinedInput-notchedOutline"
class="PrivateNotchedOutline-root-571 MuiOutlinedInput-notchedOutline"
style="padding-left: 8px;"
>
<legend
class="PrivateNotchedOutline-legend-564"
class="PrivateNotchedOutline-legend-572"
style="width: 0.01px;"
>
<span>
@@ -691,7 +691,7 @@ exports[`App Route /carupdate-deploy authenticated 1`] = `
</div>
</div>
<div
class="MuiFormControl-root makeStyles-formControlInline-545"
class="MuiFormControl-root makeStyles-formControlInline-553"
>
<label
class="MuiFormLabel-root MuiInputLabel-root MuiInputLabel-formControl MuiInputLabel-animated MuiInputLabel-shrink MuiInputLabel-outlined MuiFormLabel-filled"
@@ -733,11 +733,11 @@ exports[`App Route /carupdate-deploy authenticated 1`] = `
</svg>
<fieldset
aria-hidden="true"
class="PrivateNotchedOutline-root-563 MuiOutlinedInput-notchedOutline"
class="PrivateNotchedOutline-root-571 MuiOutlinedInput-notchedOutline"
style="padding-left: 8px;"
>
<legend
class="PrivateNotchedOutline-legend-564"
class="PrivateNotchedOutline-legend-572"
style="width: 0.01px;"
>
<span>
@@ -748,14 +748,14 @@ exports[`App Route /carupdate-deploy authenticated 1`] = `
</div>
</div>
<div
class="makeStyles-labelInline-546"
class="makeStyles-labelInline-554"
>
No Cars Selected
</div>
</div>
</div>
<button
class="MuiButtonBase-root MuiButton-root MuiButton-contained makeStyles-submit-543 MuiButton-containedPrimary MuiButton-fullWidth"
class="MuiButtonBase-root MuiButton-root MuiButton-contained makeStyles-submit-551 MuiButton-containedPrimary MuiButton-fullWidth"
tabindex="0"
type="submit"
>
@@ -2132,17 +2132,17 @@ exports[`App Route /page-not-found authenticated 1`] = `
data-testid="mocked-userprovider"
>
<div
class="makeStyles-root-526"
class="makeStyles-root-534"
>
<header
class="MuiPaper-root MuiAppBar-root MuiAppBar-positionFixed MuiAppBar-colorPrimary makeStyles-appBar-527 makeStyles-appBarShift-528 mui-00000fixed MuiPaper-elevation4"
class="MuiPaper-root MuiAppBar-root MuiAppBar-positionFixed MuiAppBar-colorPrimary makeStyles-appBar-535 makeStyles-appBarShift-536 mui-00000fixed MuiPaper-elevation4"
>
<div
class="MuiToolbar-root MuiToolbar-regular MuiToolbar-gutters"
>
<button
aria-label="open drawer"
class="MuiButtonBase-root MuiIconButton-root makeStyles-menuButton-529 MuiIconButton-colorInherit MuiIconButton-edgeStart"
class="MuiButtonBase-root MuiIconButton-root makeStyles-menuButton-537 MuiIconButton-colorInherit MuiIconButton-edgeStart"
tabindex="0"
type="button"
>
@@ -2170,7 +2170,7 @@ exports[`App Route /page-not-found authenticated 1`] = `
Fisker OTA Portal
</h6>
<button
class="MuiButtonBase-root MuiButton-root MuiButton-text makeStyles-rightToolbar-536 MuiButton-colorInherit"
class="MuiButtonBase-root MuiButton-root MuiButton-text makeStyles-rightToolbar-544 MuiButton-colorInherit"
tabindex="0"
type="button"
>
@@ -2186,13 +2186,13 @@ exports[`App Route /page-not-found authenticated 1`] = `
</div>
</header>
<div
class="MuiDrawer-root MuiDrawer-docked makeStyles-drawer-531"
class="MuiDrawer-root MuiDrawer-docked makeStyles-drawer-539"
>
<div
class="MuiPaper-root MuiDrawer-paper makeStyles-drawerPaper-532 MuiDrawer-paperAnchorLeft MuiDrawer-paperAnchorDockedLeft MuiPaper-elevation0"
class="MuiPaper-root MuiDrawer-paper makeStyles-drawerPaper-540 MuiDrawer-paperAnchorLeft MuiDrawer-paperAnchorDockedLeft MuiPaper-elevation0"
>
<div
class="makeStyles-drawerHeader-533"
class="makeStyles-drawerHeader-541"
>
<button
class="MuiButtonBase-root MuiIconButton-root"
@@ -2338,16 +2338,16 @@ exports[`App Route /page-not-found authenticated 1`] = `
</div>
</div>
<main
class="makeStyles-content-534 makeStyles-contentShift-535"
class="makeStyles-content-542 makeStyles-contentShift-543"
>
<div
class="makeStyles-drawerHeader-533"
class="makeStyles-drawerHeader-541"
/>
<main
class="MuiContainer-root MuiContainer-maxWidthLg"
>
<div
class="makeStyles-paper-515"
class="makeStyles-paper-523"
>
<h1
class="MuiTypography-root MuiTypography-h2"
@@ -2368,10 +2368,10 @@ exports[`App Route /page-not-found unauthenticated 1`] = `
data-testid="mocked-userprovider"
>
<div
class="makeStyles-root-501"
class="makeStyles-root-509"
>
<header
class="MuiPaper-root MuiAppBar-root MuiAppBar-positionFixed MuiAppBar-colorPrimary makeStyles-appBar-502 mui-00000fixed MuiPaper-elevation4"
class="MuiPaper-root MuiAppBar-root MuiAppBar-positionFixed MuiAppBar-colorPrimary makeStyles-appBar-510 mui-00000fixed MuiPaper-elevation4"
>
<div
class="MuiToolbar-root MuiToolbar-regular MuiToolbar-gutters"
@@ -2384,16 +2384,16 @@ exports[`App Route /page-not-found unauthenticated 1`] = `
</div>
</header>
<main
class="makeStyles-content-509"
class="makeStyles-content-517"
>
<div
class="makeStyles-drawerHeader-508"
class="makeStyles-drawerHeader-516"
/>
<main
class="MuiContainer-root MuiContainer-maxWidthLg"
>
<div
class="makeStyles-paper-490"
class="makeStyles-paper-498"
>
<h1
class="MuiTypography-root MuiTypography-h2"
@@ -4104,185 +4104,486 @@ exports[`App Route /vehicle-status authenticated 1`] = `
class="MuiContainer-root MuiContainer-maxWidthLg"
>
<div
data-testid="mocked-updatesprovider"
data-testid="mocked-vehicleprovider"
>
<div
class="makeStyles-paper-465"
style="height: 700px; width: 100%;"
data-testid="mocked-updatesprovider"
>
<h1
class="MuiTypography-root MuiTypography-h5"
>
FISKER123
Updates
</h1>
<div
class="MuiTableContainer-root"
class="makeStyles-paper-465"
style="height: 700px; width: 100%;"
>
<table
class="MuiTable-root"
<h1
class="MuiTypography-root MuiTypography-h5"
>
<thead
class="MuiTableHead-root"
FISKER123
Updates
</h1>
<div
class="MuiTableContainer-root"
>
<table
class="MuiTable-root"
>
<tr
class="MuiTableRow-root MuiTableRow-head"
<thead
class="MuiTableHead-root"
>
<th
class="MuiTableCell-root MuiTableCell-head MuiTableCell-alignCenter"
scope="col"
<tr
class="MuiTableRow-root MuiTableRow-head"
>
ID
</th>
<th
class="MuiTableCell-root MuiTableCell-head MuiTableCell-alignCenter"
scope="col"
>
Update
</th>
<th
class="MuiTableCell-root MuiTableCell-head MuiTableCell-alignCenter"
scope="col"
>
Status
</th>
<th
class="MuiTableCell-root MuiTableCell-head MuiTableCell-alignCenter"
scope="col"
>
Created
</th>
<th
class="MuiTableCell-root MuiTableCell-head MuiTableCell-alignCenter"
scope="col"
>
Updated
</th>
</tr>
</thead>
<tbody
class="MuiTableBody-root"
/>
<tfoot
class="MuiTableFooter-root"
>
<tr
class="MuiTableRow-root MuiTableRow-footer"
<th
class="MuiTableCell-root MuiTableCell-head MuiTableCell-alignCenter"
scope="col"
>
ID
</th>
<th
class="MuiTableCell-root MuiTableCell-head MuiTableCell-alignCenter"
scope="col"
>
Update
</th>
<th
class="MuiTableCell-root MuiTableCell-head MuiTableCell-alignCenter"
scope="col"
>
Status
</th>
<th
class="MuiTableCell-root MuiTableCell-head MuiTableCell-alignCenter"
scope="col"
>
Created
</th>
<th
class="MuiTableCell-root MuiTableCell-head MuiTableCell-alignCenter"
scope="col"
>
Updated
</th>
</tr>
</thead>
<tbody
class="MuiTableBody-root"
/>
<tfoot
class="MuiTableFooter-root"
>
<td
class="MuiTableCell-root MuiTableCell-footer MuiTablePagination-root"
colspan="5"
<tr
class="MuiTableRow-root MuiTableRow-footer"
>
<div
class="MuiToolbar-root MuiToolbar-regular MuiTablePagination-toolbar MuiToolbar-gutters"
<td
class="MuiTableCell-root MuiTableCell-footer MuiTablePagination-root"
colspan="5"
>
<div
class="MuiTablePagination-spacer"
/>
<p
class="MuiTypography-root MuiTablePagination-caption MuiTypography-body2 MuiTypography-colorInherit"
id="mui-00000"
class="MuiToolbar-root MuiToolbar-regular MuiTablePagination-toolbar MuiToolbar-gutters"
>
Rows per page:
</p>
<div
class="MuiInputBase-root MuiTablePagination-input MuiTablePagination-selectRoot"
>
<select
aria-label="rows per page"
class="MuiSelect-root MuiSelect-select MuiTablePagination-select MuiInputBase-input"
<div
class="MuiTablePagination-spacer"
/>
<p
class="MuiTypography-root MuiTablePagination-caption MuiTypography-body2 MuiTypography-colorInherit"
id="mui-00000"
>
<option
class="MuiTablePagination-menuItem"
value="5"
Rows per page:
</p>
<div
class="MuiInputBase-root MuiTablePagination-input MuiTablePagination-selectRoot"
>
<select
aria-label="rows per page"
class="MuiSelect-root MuiSelect-select MuiTablePagination-select MuiInputBase-input"
id="mui-00000"
>
5
</option>
<option
class="MuiTablePagination-menuItem"
value="10"
<option
class="MuiTablePagination-menuItem"
value="5"
>
5
</option>
<option
class="MuiTablePagination-menuItem"
value="10"
>
10
</option>
<option
class="MuiTablePagination-menuItem"
value="25"
>
25
</option>
</select>
<svg
aria-hidden="true"
class="MuiSvgIcon-root MuiSelect-icon MuiTablePagination-selectIcon"
focusable="false"
viewBox="0 0 24 24"
>
10
</option>
<option
class="MuiTablePagination-menuItem"
value="25"
<path
d="M7 10l5 5 5-5z"
/>
</svg>
</div>
<p
class="MuiTypography-root MuiTablePagination-caption MuiTypography-body2 MuiTypography-colorInherit"
>
0-0 of 0
</p>
<div
class="MuiTablePagination-actions"
>
<button
aria-label="Previous page"
class="MuiButtonBase-root MuiIconButton-root MuiIconButton-colorInherit Mui-disabled Mui-disabled"
disabled=""
tabindex="-1"
title="Previous page"
type="button"
>
25
</option>
</select>
<span
class="MuiIconButton-label"
>
<svg
aria-hidden="true"
class="MuiSvgIcon-root"
focusable="false"
viewBox="0 0 24 24"
>
<path
d="M15.41 16.09l-4.58-4.59 4.58-4.59L14 5.5l-6 6 6 6z"
/>
</svg>
</span>
</button>
<button
aria-label="Next page"
class="MuiButtonBase-root MuiIconButton-root MuiIconButton-colorInherit Mui-disabled Mui-disabled"
disabled=""
tabindex="-1"
title="Next page"
type="button"
>
<span
class="MuiIconButton-label"
>
<svg
aria-hidden="true"
class="MuiSvgIcon-root"
focusable="false"
viewBox="0 0 24 24"
>
<path
d="M8.59 16.34l4.58-4.59-4.58-4.59L10 5.75l6 6-6 6z"
/>
</svg>
</span>
</button>
</div>
</div>
</td>
</tr>
</tfoot>
</table>
</div>
<div
class="MuiGrid-root makeStyles-root-476 MuiGrid-container MuiGrid-spacing-xs-2"
>
<div
class="MuiGrid-root MuiGrid-item MuiGrid-grid-md-12 MuiGrid-grid-lg-6"
>
<div
class="makeStyles-form-467"
>
<div
class="MuiFormControl-root makeStyles-formControlInline-470"
>
<label
class="MuiFormLabel-root MuiInputLabel-root MuiInputLabel-formControl MuiInputLabel-animated MuiInputLabel-shrink MuiInputLabel-outlined MuiFormLabel-filled"
data-shrink="true"
for="send-command"
style="background-color: White;"
>
Command
</label>
<div
class="MuiInputBase-root MuiOutlinedInput-root MuiInputBase-formControl"
>
<select
aria-invalid="false"
class="MuiSelect-root MuiSelect-select MuiSelect-outlined MuiInputBase-input MuiOutlinedInput-input"
id="send-command"
name="send-command"
>
<option
value="LFRD"
>
Lock front right door
</option>
<option
value="UFRD"
>
Unlock front right door
</option>
<option
value="LFLD"
>
Lock front left door
</option>
<option
value="UFLD"
>
Unlock front left door
</option>
<option
value="LRRD"
>
Lock rear right door
</option>
<option
value="URRD"
>
Unlock rear right door
</option>
<option
value="LRLD"
>
Lock rear left door
</option>
<option
value="URLD"
>
Unlock rear left door
</option>
<option
value="LTRK"
>
Lock trunk
</option>
<option
value="UTRK"
>
Unlock trunk
</option>
<option
value="OWIN"
>
Open Windows
</option>
<option
value="CWIN"
>
Close Windows
</option>
<option
value="FLASH"
>
Flash headlights
</option>
</select>
<svg
aria-hidden="true"
class="MuiSvgIcon-root MuiSelect-icon MuiSelect-iconOutlined"
focusable="false"
viewBox="0 0 24 24"
>
<path
d="M7 10l5 5 5-5z"
/>
</svg>
<fieldset
aria-hidden="true"
class="PrivateNotchedOutline-root-488 MuiOutlinedInput-notchedOutline"
style="padding-left: 8px;"
>
<legend
class="PrivateNotchedOutline-legend-489"
style="width: 0.01px;"
>
<span>
</span>
</legend>
</fieldset>
</div>
</div>
<span
aria-disabled="false"
aria-label="send command"
class="MuiButtonBase-root MuiIconButton-root MuiIconButton-colorPrimary"
role="button"
tabindex="0"
>
<span
class="MuiIconButton-label"
>
<svg
aria-hidden="true"
class="MuiSvgIcon-root MuiSvgIcon-fontSizeLarge"
focusable="false"
viewBox="0 0 24 24"
>
<path
d="M2.01 21L23 12 2.01 3 2 10l15 2-15 2z"
/>
</svg>
</span>
<span
class="MuiTouchRipple-root"
/>
</span>
</div>
</div>
<div
class="MuiGrid-root MuiGrid-item MuiGrid-grid-md-12 MuiGrid-grid-lg-6"
style="text-align: right;"
>
<div
class="MuiGrid-root MuiGrid-container MuiGrid-spacing-xs-2 MuiGrid-align-items-xs-center"
>
<div
class="MuiGrid-root MuiGrid-item"
>
<label
class="MuiFormControlLabel-root MuiFormControlLabel-labelPlacementTop"
>
<span
class="MuiSwitch-root"
>
<span
aria-disabled="false"
class="MuiButtonBase-root MuiIconButton-root PrivateSwitchBase-root-492 MuiSwitch-switchBase MuiSwitch-colorPrimary PrivateSwitchBase-checked-493 Mui-checked"
>
<span
class="MuiIconButton-label"
>
<input
checked=""
class="PrivateSwitchBase-input-495 MuiSwitch-input"
name="logStart"
type="checkbox"
value=""
/>
<span
class="MuiSwitch-thumb"
/>
</span>
<span
class="MuiTouchRipple-root"
/>
</span>
<span
class="MuiSwitch-track"
/>
</span>
<span
class="MuiTypography-root MuiFormControlLabel-label MuiTypography-body1"
>
Logging
</span>
</label>
</div>
<div
class="MuiGrid-root MuiGrid-item"
>
<div
class="MuiFormControl-root MuiTextField-root MuiFormControl-marginNormal"
>
<label
class="MuiFormLabel-root MuiInputLabel-root MuiInputLabel-formControl MuiInputLabel-animated MuiInputLabel-outlined"
data-shrink="false"
for="log-filter"
id="log-filter-label"
>
Filter
</label>
<div
class="MuiInputBase-root MuiOutlinedInput-root MuiInputBase-formControl"
>
<input
aria-invalid="false"
class="MuiInputBase-input MuiOutlinedInput-input"
id="log-filter"
maxlength="17"
name="log-filter"
type="text"
value=""
/>
<fieldset
aria-hidden="true"
class="PrivateNotchedOutline-root-488 MuiOutlinedInput-notchedOutline"
>
<legend
class="PrivateNotchedOutline-legendLabelled-490"
>
<span>
Filter
</span>
</legend>
</fieldset>
</div>
</div>
</div>
<div
class="MuiGrid-root MuiGrid-item"
>
<div
class="MuiFormControl-root MuiTextField-root"
>
<label
class="MuiFormLabel-root MuiInputLabel-root MuiInputLabel-formControl MuiInputLabel-animated MuiInputLabel-shrink MuiFormLabel-filled"
data-shrink="true"
for="log-frequency"
id="log-frequency-label"
>
Frequency
</label>
<div
class="MuiInputBase-root MuiInput-root MuiInput-underline MuiInputBase-formControl MuiInput-formControl"
>
<input
aria-invalid="false"
class="MuiInputBase-input MuiInput-input"
id="log-frequency"
type="number"
value="0"
/>
</div>
</div>
</div>
<div
class="MuiGrid-root MuiGrid-item"
>
<span
aria-disabled="false"
aria-label="send log command"
class="MuiButtonBase-root MuiIconButton-root MuiIconButton-colorPrimary"
role="button"
tabindex="0"
>
<span
class="MuiIconButton-label"
>
<svg
aria-hidden="true"
class="MuiSvgIcon-root MuiSelect-icon MuiTablePagination-selectIcon"
class="MuiSvgIcon-root MuiSvgIcon-fontSizeLarge"
focusable="false"
viewBox="0 0 24 24"
>
<path
d="M7 10l5 5 5-5z"
d="M2.01 21L23 12 2.01 3 2 10l15 2-15 2z"
/>
</svg>
</div>
<p
class="MuiTypography-root MuiTablePagination-caption MuiTypography-body2 MuiTypography-colorInherit"
>
0-0 of 0
</p>
<div
class="MuiTablePagination-actions"
>
<button
aria-label="Previous page"
class="MuiButtonBase-root MuiIconButton-root MuiIconButton-colorInherit Mui-disabled Mui-disabled"
disabled=""
tabindex="-1"
title="Previous page"
type="button"
>
<span
class="MuiIconButton-label"
>
<svg
aria-hidden="true"
class="MuiSvgIcon-root"
focusable="false"
viewBox="0 0 24 24"
>
<path
d="M15.41 16.09l-4.58-4.59 4.58-4.59L14 5.5l-6 6 6 6z"
/>
</svg>
</span>
</button>
<button
aria-label="Next page"
class="MuiButtonBase-root MuiIconButton-root MuiIconButton-colorInherit Mui-disabled Mui-disabled"
disabled=""
tabindex="-1"
title="Next page"
type="button"
>
<span
class="MuiIconButton-label"
>
<svg
aria-hidden="true"
class="MuiSvgIcon-root"
focusable="false"
viewBox="0 0 24 24"
>
<path
d="M8.59 16.34l4.58-4.59-4.58-4.59L10 5.75l6 6-6 6z"
/>
</svg>
</span>
</button>
</div>
</div>
</td>
</tr>
</tfoot>
</table>
</span>
<span
class="MuiTouchRipple-root"
/>
</span>
</div>
</div>
</div>
</div>
</div>
</div>
</div>