add: auto update launcher

This commit is contained in:
2025-07-08 02:30:35 +05:00
parent 5cd483209f
commit 31a26dc1ce
11 changed files with 132 additions and 20 deletions

View File

@ -11,6 +11,7 @@ import './App.css';
import TopBar from './components/TopBar';
import { Box } from '@mui/material';
import MinecraftBackround from './components/MinecraftBackround';
import { Notifier } from './components/Notifier';
// Переместите launchOptions сюда, вне компонентов
const launchOptions = {
@ -94,6 +95,7 @@ const App = () => {
>
<MinecraftBackround />
<TopBar onRegister={handleRegister} />
<Notifier />
<Routes>
<Route path="/login" element={<Login />} />
<Route

View File

@ -0,0 +1,63 @@
import { Alert, Box, Snackbar, Button } from '@mui/material';
import { useEffect, useState } from 'react';
export const Notifier = () => {
const [open, setOpen] = useState(false);
const [message, setMessage] = useState('');
const [severity, setSeverity] = useState<
'error' | 'warning' | 'info' | 'success'
>('info');
const [hasUpdateAvailable, setHasUpdateAvailable] = useState(false);
useEffect(() => {
// Слушаем событие о наличии обновления
window.electron.ipcRenderer.on('update-available', () => {
setMessage('Доступно новое обновление');
setSeverity('info');
setHasUpdateAvailable(true);
setOpen(true);
});
return () => {
// Отписываемся от события при размонтировании
window.electron.ipcRenderer.removeAllListeners('update-available');
};
}, []);
const handleClose = () => {
setOpen(false);
};
const handleUpdate = () => {
window.electron.ipcRenderer.invoke('install-update');
setOpen(false);
};
return (
<Box>
<Snackbar
open={open}
autoHideDuration={hasUpdateAvailable ? null : 6000}
onClose={handleClose}
>
<Alert
severity={severity}
action={
hasUpdateAvailable && (
<>
<Button color="primary" size="small" onClick={handleUpdate}>
Обновить сейчас
</Button>
<Button color="secondary" size="small" onClick={handleClose}>
Позже
</Button>
</>
)
}
>
{message}
</Alert>
</Snackbar>
</Box>
);
};

View File

@ -6,7 +6,7 @@
http-equiv="Content-Security-Policy"
content="script-src 'self' 'unsafe-inline'"
/>
<title>Hello Electron React!</title>
<title>popa-launcher</title>
</head>
<body>
<div id="root"></div>