Problems: auto-fix & problem panel (#541)
Test cases: - [x] create-ts-errors - [x] with auto-fix - [x] without auto-fix - [x] create-unfixable-ts-errors - [x] manually edit file & click recheck - [x] fix all - [x] delete and rename case THINGS - [x] error handling for checkProblems isn't working as expected - [x] make sure it works for both default templates (add tests) - [x] fix bad animation - [x] change file context (prompt/files) IF everything passes in Windows AND defensive try catch... then enable by default - [x] enable auto-fix by default
This commit is contained in:
30
src/hooks/useCheckProblems.ts
Normal file
30
src/hooks/useCheckProblems.ts
Normal file
@@ -0,0 +1,30 @@
|
||||
import { useQuery } from "@tanstack/react-query";
|
||||
import { IpcClient } from "@/ipc/ipc_client";
|
||||
import type { ProblemReport } from "@/ipc/ipc_types";
|
||||
|
||||
export function useCheckProblems(appId: number | null) {
|
||||
const {
|
||||
data: problemReport,
|
||||
isLoading: isChecking,
|
||||
error,
|
||||
refetch: checkProblems,
|
||||
} = useQuery<ProblemReport, Error>({
|
||||
queryKey: ["problems", appId],
|
||||
queryFn: async (): Promise<ProblemReport> => {
|
||||
if (!appId) {
|
||||
throw new Error("App ID is required");
|
||||
}
|
||||
const ipcClient = IpcClient.getInstance();
|
||||
return ipcClient.checkProblems({ appId });
|
||||
},
|
||||
enabled: !!appId,
|
||||
// DO NOT SHOW ERROR TOAST.
|
||||
});
|
||||
|
||||
return {
|
||||
problemReport,
|
||||
isChecking,
|
||||
error,
|
||||
checkProblems,
|
||||
};
|
||||
}
|
||||
Reference in New Issue
Block a user