
* chore(vite): use vite * fix(vite): alias lib directory * chore(vite): set type: module * chore: update vite and MUI * fix(vite): make MUI components load * fix: use node path resolution * chore(vite): add svg support * fix(vite): polyfill global * fix(vite): use import.meta * fix(vite): use correct svg module resolution * chore(vite): migrate to vitest * fix(vite): remove PUBLIC_URL * fix(tests): mock audio service * chore(deps): upgrade to react test library 14 * refactor(tests): simplify room test setup * refactor(tests): make Date.now() mockable * refactor(vite): remove bootstrap shim * chore(deps): drop react-scripts * chore(deps): remove source-map-explorer Source maps do not currently work with MUI and Vite: https://github.com/vitejs/vite/issues/15012 Because of this, source map utilities are currently removed. * refactor(vite): use TypeScript for Vite config * chore(actions): update actions config for new paths * fix(service-worker): use VITE_HOMEPAGE for service worker resolution * fix(vercel): use quotes for build command * fix(vite): use import.meta.env.MODE * fix(service-worker): use correct definition for publicUrl * feat(vite): use vite-plugin-pwa * fix(pwa): make update prompt work * fix(types): use vite/client types * docs(readme): update building instructions * refactor(vite): simplify theme loading workaround * refactor(vite): use manifest object * docs(readme): update tool references * chore(deps): run `npm audit fix` * fix(vite): make syntax highlighter work consistently See: https://github.com/react-syntax-highlighter/react-syntax-highlighter/issues/513 * fix(pwa): remove manifest.json references * refactor(deps): remove jest references * refactor(types): remove react-scripts reference * chore(deps): use TypeScript 5 * refactor(tests): improve persisted storage mocking
55 lines
1.7 KiB
TypeScript
55 lines
1.7 KiB
TypeScript
import Box from '@mui/material/Box'
|
|
import Button from '@mui/material/Button'
|
|
import Dialog from '@mui/material/Dialog'
|
|
import DialogActions from '@mui/material/DialogActions'
|
|
import DialogContent from '@mui/material/DialogContent'
|
|
import DialogContentText from '@mui/material/DialogContentText'
|
|
import DialogTitle from '@mui/material/DialogTitle'
|
|
import WarningIcon from '@mui/icons-material/Warning'
|
|
import { useRegisterSW } from 'virtual:pwa-register/react'
|
|
|
|
interface UpgradeDialogProps {
|
|
appNeedsUpdate: boolean
|
|
}
|
|
|
|
export const UpgradeDialog = ({ appNeedsUpdate }: UpgradeDialogProps) => {
|
|
const { updateServiceWorker } = useRegisterSW()
|
|
|
|
const handleRestartClick = () => {
|
|
updateServiceWorker(true)
|
|
}
|
|
|
|
return (
|
|
<Dialog
|
|
open={appNeedsUpdate}
|
|
aria-labelledby="alert-dialog-title"
|
|
aria-describedby="alert-dialog-description"
|
|
>
|
|
<DialogTitle id="alert-dialog-title">
|
|
<Box sx={{ display: 'flex', alignItems: 'center' }}>
|
|
<WarningIcon
|
|
fontSize="medium"
|
|
sx={theme => ({
|
|
color: theme.palette.warning.main,
|
|
mr: theme.spacing(1),
|
|
})}
|
|
/>
|
|
Update needed
|
|
</Box>
|
|
</DialogTitle>
|
|
<DialogContent>
|
|
<DialogContentText id="alert-dialog-description">
|
|
In order to function properly, Chitchatter needs to be updated. The
|
|
update has already been installed in the background. All you need to
|
|
do is reload the page or click "Refresh" below.
|
|
</DialogContentText>
|
|
</DialogContent>
|
|
<DialogActions>
|
|
<Button onClick={handleRestartClick} autoFocus>
|
|
Refresh
|
|
</Button>
|
|
</DialogActions>
|
|
</Dialog>
|
|
)
|
|
}
|