mirror of
https://github.com/clash-verge-rev/clash-verge-rev
synced 2025-05-05 05:13:44 +08:00
feat: Add Download Progress for Updater (#34)
This commit is contained in:
parent
0775560ad2
commit
2d453a1a6c
@ -2,17 +2,19 @@ import useSWR from "swr";
|
|||||||
import snarkdown from "snarkdown";
|
import snarkdown from "snarkdown";
|
||||||
import { forwardRef, useImperativeHandle, useState, useMemo } from "react";
|
import { forwardRef, useImperativeHandle, useState, useMemo } from "react";
|
||||||
import { useLockFn } from "ahooks";
|
import { useLockFn } from "ahooks";
|
||||||
import { Box, styled } from "@mui/material";
|
import { Box, LinearProgress, styled } from "@mui/material";
|
||||||
import { useRecoilState } from "recoil";
|
import { useRecoilState } from "recoil";
|
||||||
import { useTranslation } from "react-i18next";
|
import { useTranslation } from "react-i18next";
|
||||||
import { relaunch } from "@tauri-apps/api/process";
|
import { relaunch } from "@tauri-apps/api/process";
|
||||||
import { checkUpdate, installUpdate } from "@tauri-apps/api/updater";
|
import { checkUpdate, installUpdate } from "@tauri-apps/api/updater";
|
||||||
import { BaseDialog, DialogRef, Notice } from "@/components/base";
|
import { BaseDialog, DialogRef, Notice } from "@/components/base";
|
||||||
import { atomUpdateState } from "@/services/states";
|
import { atomUpdateState } from "@/services/states";
|
||||||
|
import { listen, Event, UnlistenFn } from "@tauri-apps/api/event";
|
||||||
|
|
||||||
const UpdateLog = styled(Box)(() => ({
|
const UpdateLog = styled(Box)(() => ({
|
||||||
"h1,h2,h3,ul,ol,p": { margin: "0.5em 0", color: "inherit" },
|
"h1,h2,h3,ul,ol,p": { margin: "0.5em 0", color: "inherit" },
|
||||||
}));
|
}));
|
||||||
|
let eventListener: UnlistenFn | null = null;
|
||||||
|
|
||||||
export const UpdateViewer = forwardRef<DialogRef>((props, ref) => {
|
export const UpdateViewer = forwardRef<DialogRef>((props, ref) => {
|
||||||
const { t } = useTranslation();
|
const { t } = useTranslation();
|
||||||
@ -26,6 +28,10 @@ export const UpdateViewer = forwardRef<DialogRef>((props, ref) => {
|
|||||||
focusThrottleInterval: 36e5, // 1 hour
|
focusThrottleInterval: 36e5, // 1 hour
|
||||||
});
|
});
|
||||||
|
|
||||||
|
const [downloaded, setDownloaded] = useState(0);
|
||||||
|
const [buffer, setBuffer] = useState(0);
|
||||||
|
const [total, setTotal] = useState(0);
|
||||||
|
|
||||||
useImperativeHandle(ref, () => ({
|
useImperativeHandle(ref, () => ({
|
||||||
open: () => setOpen(true),
|
open: () => setOpen(true),
|
||||||
close: () => setOpen(false),
|
close: () => setOpen(false),
|
||||||
@ -42,7 +48,19 @@ export const UpdateViewer = forwardRef<DialogRef>((props, ref) => {
|
|||||||
const onUpdate = useLockFn(async () => {
|
const onUpdate = useLockFn(async () => {
|
||||||
if (updateState) return;
|
if (updateState) return;
|
||||||
setUpdateState(true);
|
setUpdateState(true);
|
||||||
|
if (eventListener !== null) {
|
||||||
|
eventListener();
|
||||||
|
}
|
||||||
|
eventListener = await listen(
|
||||||
|
"tauri://update-download-progress",
|
||||||
|
(e: Event<any>) => {
|
||||||
|
setTotal(e.payload.contentLength);
|
||||||
|
setBuffer(e.payload.chunkLength);
|
||||||
|
setDownloaded((a) => {
|
||||||
|
return a + e.payload.chunkLength;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
);
|
||||||
try {
|
try {
|
||||||
await installUpdate();
|
await installUpdate();
|
||||||
await relaunch();
|
await relaunch();
|
||||||
@ -65,6 +83,14 @@ export const UpdateViewer = forwardRef<DialogRef>((props, ref) => {
|
|||||||
onOk={onUpdate}
|
onOk={onUpdate}
|
||||||
>
|
>
|
||||||
<UpdateLog dangerouslySetInnerHTML={{ __html: parseContent }} />
|
<UpdateLog dangerouslySetInnerHTML={{ __html: parseContent }} />
|
||||||
|
{updateState && (
|
||||||
|
<LinearProgress
|
||||||
|
variant="buffer"
|
||||||
|
value={(downloaded / total) * 100}
|
||||||
|
valueBuffer={buffer}
|
||||||
|
sx={{ marginTop: "5px" }}
|
||||||
|
/>
|
||||||
|
)}
|
||||||
</BaseDialog>
|
</BaseDialog>
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
Loading…
x
Reference in New Issue
Block a user