index and update screen

This commit is contained in:
Novattz
2025-11-12 15:04:17 +01:00
parent 686a5219eb
commit 38f536bc1c
4 changed files with 106 additions and 8 deletions

View File

@@ -1,3 +1,4 @@
export { default as LoadingIndicator } from './LoadingIndicator'
export { default as ProgressBar } from './ProgressBar'
export type { LoadingSize, LoadingType } from './LoadingIndicator'

View File

@@ -0,0 +1,94 @@
import { useState, useEffect, useCallback } from 'react'
import { check } from '@tauri-apps/plugin-updater'
import { relaunch } from '@tauri-apps/plugin-process'
import { ProgressBar } from '@/components/common'
interface UpdateScreenProps {
onComplete: () => void
}
/**
* Update screen displayed before the initial loading screen
* Checks for updates and installs them automatically
*/
const UpdateScreen = ({ onComplete }: UpdateScreenProps) => {
const [checking, setChecking] = useState(true)
const [downloading, setDownloading] = useState(false)
const [progress, setProgress] = useState(0)
const [version, setVersion] = useState('')
const checkForUpdates = useCallback(async () => {
try {
setChecking(true)
const update = await check()
// Check if update exists (null means no update available)
if (update) {
setChecking(false)
setDownloading(true)
setVersion(update.version)
// Download and install the update
await update.downloadAndInstall((event) => {
switch (event.event) {
case 'Started': {
const contentLength = event.data.contentLength
console.log(`Started downloading ${contentLength} bytes`)
break
}
case 'Progress': {
const { chunkLength } = event.data
// Calculate cumulative progress
setProgress((prev) => {
const newProgress = prev + chunkLength
return Math.min(newProgress, 100)
})
break
}
case 'Finished':
console.log('Download finished, installing...')
setProgress(100)
break
}
})
// Relaunch the app
await relaunch()
} else {
// No update available (update is null), proceed to normal loading
setChecking(false)
onComplete()
}
} catch (error) {
console.error('Update check failed:', error)
// On error, just continue to the app
setChecking(false)
onComplete()
}
}, [onComplete])
useEffect(() => {
checkForUpdates()
}, [checkForUpdates])
return (
<div className="initial-loading-screen">
<div className="loading-content">
<h1>CreamLinux</h1>
<div className="loading-animation">
{checking && <div className="loading-spinner"></div>}
</div>
<p className="loading-message">
{checking && 'Checking for updates...'}
{downloading && `Downloading update v${version}...`}
</p>
{downloading && <ProgressBar progress={progress} />}
</div>
</div>
)
}
export default UpdateScreen

View File

@@ -4,3 +4,4 @@ export { default as Sidebar } from './Sidebar'
export { default as AnimatedBackground } from './AnimatedBackground'
export { default as InitialLoadingScreen } from './InitialLoadingScreen'
export { default as ErrorBoundary } from './ErrorBoundary'
export { default as UpdateScreen } from './UpdateScreen'