forked from mirrors/Vencord
Updater: Inform about more recent commits
This commit is contained in:
parent
443978929b
commit
25fcc528ea
2 changed files with 82 additions and 50 deletions
|
@ -1,13 +1,12 @@
|
||||||
import gitHash from "git-hash";
|
import gitHash from "git-hash";
|
||||||
import { changes, checkForUpdates, getRepo, rebuild, update, UpdateLogger, updateError } from '../utils/updater';
|
import { changes, checkForUpdates, getRepo, rebuild, update, UpdateLogger, updateError, isOutdated, isNewer } from '../utils/updater';
|
||||||
import { React, Forms, Button, Margins, Alerts, Card, Parser, Toasts } from '../webpack/common';
|
import { React, Forms, Button, Margins, Alerts, Card, Parser, Toasts } from '../webpack/common';
|
||||||
import { Flex } from "./Flex";
|
import { Flex } from "./Flex";
|
||||||
import { useAwaiter } from '../utils/misc';
|
import { classes, useAwaiter } from '../utils/misc';
|
||||||
import { Link } from "./Link";
|
import { Link } from "./Link";
|
||||||
import ErrorBoundary from "./ErrorBoundary";
|
import ErrorBoundary from "./ErrorBoundary";
|
||||||
import { ErrorCard } from "./ErrorCard";
|
import { ErrorCard } from "./ErrorCard";
|
||||||
|
|
||||||
|
|
||||||
function withDispatcher(dispatcher: React.Dispatch<React.SetStateAction<boolean>>, action: () => any) {
|
function withDispatcher(dispatcher: React.Dispatch<React.SetStateAction<boolean>>, action: () => any) {
|
||||||
return async () => {
|
return async () => {
|
||||||
dispatcher(true);
|
dispatcher(true);
|
||||||
|
@ -45,49 +44,13 @@ function withDispatcher(dispatcher: React.Dispatch<React.SetStateAction<boolean>
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
export default ErrorBoundary.wrap(function Updater() {
|
interface CommonProps {
|
||||||
const [repo, err, repoPending] = useAwaiter(getRepo, "Loading...");
|
repo: string;
|
||||||
const [isChecking, setIsChecking] = React.useState(false);
|
repoPending: boolean;
|
||||||
const [isUpdating, setIsUpdating] = React.useState(false);
|
|
||||||
const [updates, setUpdates] = React.useState(changes);
|
|
||||||
|
|
||||||
React.useEffect(() => {
|
|
||||||
if (err)
|
|
||||||
UpdateLogger.error("Failed to retrieve repo", err);
|
|
||||||
}, [err]);
|
|
||||||
|
|
||||||
const isOutdated = updates?.length > 0;
|
|
||||||
|
|
||||||
return (
|
|
||||||
<Forms.FormSection tag="h1" title="Vencord Updater">
|
|
||||||
<Forms.FormTitle tag="h5">Repo</Forms.FormTitle>
|
|
||||||
|
|
||||||
<Forms.FormText>{repoPending ? repo : err ? "Failed to retrieve - check console" : (
|
|
||||||
<Link href={repo}>
|
|
||||||
{repo.split("/").slice(-2).join("/")}
|
|
||||||
</Link>
|
|
||||||
)} ({gitHash})</Forms.FormText>
|
|
||||||
|
|
||||||
<Forms.FormDivider />
|
|
||||||
|
|
||||||
<Forms.FormTitle tag="h5">Updates</Forms.FormTitle>
|
|
||||||
|
|
||||||
{!updates && updateError ? (
|
|
||||||
<>
|
|
||||||
<Forms.FormText>Failed to check updates. Check the console for more info</Forms.FormText>
|
|
||||||
<ErrorCard style={{ padding: "1em" }}>
|
|
||||||
<p>{updateError.stderr || updateError.stdout || "An unknown error occurred"}</p>
|
|
||||||
</ErrorCard>
|
|
||||||
</>
|
|
||||||
) :
|
|
||||||
(
|
|
||||||
<Forms.FormText className={Margins.marginBottom8}>
|
|
||||||
{isOutdated ? `There are ${updates.length} Updates` : "Up to Date!"}
|
|
||||||
</Forms.FormText>
|
|
||||||
)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
{isOutdated && (
|
function Changes({ updates, repo, repoPending }: CommonProps & { updates: typeof changes; }) {
|
||||||
|
return (
|
||||||
<Card style={{ padding: ".5em" }}>
|
<Card style={{ padding: ".5em" }}>
|
||||||
{updates.map(({ hash, author, message }) => (
|
{updates.map(({ hash, author, message }) => (
|
||||||
<div>
|
<div>
|
||||||
|
@ -101,9 +64,34 @@ export default ErrorBoundary.wrap(function Updater() {
|
||||||
</div>
|
</div>
|
||||||
))}
|
))}
|
||||||
</Card>
|
</Card>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
function Updatable(props: CommonProps) {
|
||||||
|
const [updates, setUpdates] = React.useState(changes);
|
||||||
|
const [isChecking, setIsChecking] = React.useState(false);
|
||||||
|
const [isUpdating, setIsUpdating] = React.useState(false);
|
||||||
|
|
||||||
|
const isOutdated = updates.length > 0;
|
||||||
|
|
||||||
|
return (
|
||||||
|
<>
|
||||||
|
{!updates && updateError ? (
|
||||||
|
<>
|
||||||
|
<Forms.FormText>Failed to check updates. Check the console for more info</Forms.FormText>
|
||||||
|
<ErrorCard style={{ padding: "1em" }}>
|
||||||
|
<p>{updateError.stderr || updateError.stdout || "An unknown error occurred"}</p>
|
||||||
|
</ErrorCard>
|
||||||
|
</>
|
||||||
|
) : (
|
||||||
|
<Forms.FormText className={Margins.marginBottom8}>
|
||||||
|
{isOutdated ? `There are ${updates.length} Updates` : "Up to Date!"}
|
||||||
|
</Forms.FormText>
|
||||||
)}
|
)}
|
||||||
|
|
||||||
<Flex className={`${Margins.marginBottom8} ${Margins.marginTop8}`}>
|
{isOutdated && <Changes updates={updates} {...props} />}
|
||||||
|
|
||||||
|
<Flex className={classes(Margins.marginBottom8, Margins.marginTop8)}>
|
||||||
{isOutdated && <Button
|
{isOutdated && <Button
|
||||||
size={Button.Sizes.SMALL}
|
size={Button.Sizes.SMALL}
|
||||||
disabled={isUpdating || isChecking}
|
disabled={isUpdating || isChecking}
|
||||||
|
@ -155,6 +143,49 @@ export default ErrorBoundary.wrap(function Updater() {
|
||||||
Check for Updates
|
Check for Updates
|
||||||
</Button>
|
</Button>
|
||||||
</Flex>
|
</Flex>
|
||||||
|
</>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
function Newer(props: CommonProps) {
|
||||||
|
return (
|
||||||
|
<>
|
||||||
|
<Forms.FormText className={Margins.marginBottom8}>
|
||||||
|
Your local copy has more recent commits. Please stash or reset them.
|
||||||
|
</Forms.FormText>
|
||||||
|
<Changes {...props} updates={changes} />
|
||||||
|
</>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
export default ErrorBoundary.wrap(function Updater() {
|
||||||
|
const [repo, err, repoPending] = useAwaiter(getRepo, "Loading...");
|
||||||
|
|
||||||
|
React.useEffect(() => {
|
||||||
|
if (err)
|
||||||
|
UpdateLogger.error("Failed to retrieve repo", err);
|
||||||
|
}, [err]);
|
||||||
|
|
||||||
|
const commonProps: CommonProps = {
|
||||||
|
repo,
|
||||||
|
repoPending
|
||||||
|
};
|
||||||
|
|
||||||
|
return (
|
||||||
|
<Forms.FormSection tag="h1" title="Vencord Updater">
|
||||||
|
<Forms.FormTitle tag="h5">Repo</Forms.FormTitle>
|
||||||
|
|
||||||
|
<Forms.FormText>{repoPending ? repo : err ? "Failed to retrieve - check console" : (
|
||||||
|
<Link href={repo}>
|
||||||
|
{repo.split("/").slice(-2).join("/")}
|
||||||
|
</Link>
|
||||||
|
)} ({gitHash})</Forms.FormText>
|
||||||
|
|
||||||
|
<Forms.FormDivider />
|
||||||
|
|
||||||
|
<Forms.FormTitle tag="h5">Updates</Forms.FormTitle>
|
||||||
|
|
||||||
|
{isNewer ? <Newer {...commonProps} /> : <Updatable {...commonProps} />}
|
||||||
</Forms.FormSection >
|
</Forms.FormSection >
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
|
@ -5,6 +5,7 @@ import gitHash from 'git-hash';
|
||||||
|
|
||||||
export const UpdateLogger = new Logger("Updater", "white");
|
export const UpdateLogger = new Logger("Updater", "white");
|
||||||
export let isOutdated = false;
|
export let isOutdated = false;
|
||||||
|
export let isNewer = false;
|
||||||
export let updateError: any;
|
export let updateError: any;
|
||||||
export let changes: Record<"hash" | "author" | "message", string>[];
|
export let changes: Record<"hash" | "author" | "message", string>[];
|
||||||
|
|
||||||
|
@ -20,8 +21,8 @@ async function Unwrap<T>(p: Promise<IpcRes<T>>) {
|
||||||
export async function checkForUpdates() {
|
export async function checkForUpdates() {
|
||||||
changes = await Unwrap(VencordNative.ipc.invoke<IpcRes<typeof changes>>(IpcEvents.GET_UPDATES));
|
changes = await Unwrap(VencordNative.ipc.invoke<IpcRes<typeof changes>>(IpcEvents.GET_UPDATES));
|
||||||
if (changes.some(c => c.hash === gitHash)) {
|
if (changes.some(c => c.hash === gitHash)) {
|
||||||
// git log NEWER...OLDER works as well. This means it will return the more recent local commits if the
|
isNewer = true;
|
||||||
changes = [];
|
return (isOutdated = false);
|
||||||
}
|
}
|
||||||
return (isOutdated = changes.length > 0);
|
return (isOutdated = changes.length > 0);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue