Basic GitHub integration flow

This commit is contained in:
Will Chen
2025-04-14 18:12:43 -07:00
parent 3ceb3e23c6
commit 7ad83a2bdc
9 changed files with 633 additions and 26 deletions

View File

@@ -1,4 +1,4 @@
import { useState, useEffect } from "react";
import { useState, useEffect, useCallback } from "react";
import { useAtom } from "jotai";
import { userSettingsAtom, envVarsAtom } from "@/atoms/appAtoms";
import { IpcClient } from "@/ipc/ipc_client";
@@ -18,31 +18,30 @@ export function useSettings() {
const [envVars, setEnvVarsAtom] = useAtom(envVarsAtom);
const [loading, setLoading] = useState(true);
const [error, setError] = useState<Error | null>(null);
const loadInitialData = useCallback(async () => {
setLoading(true);
try {
const ipcClient = IpcClient.getInstance();
// Fetch settings and env vars concurrently
const [userSettings, fetchedEnvVars] = await Promise.all([
ipcClient.getUserSettings(),
ipcClient.getEnvVars(),
]);
setSettingsAtom(userSettings);
setEnvVarsAtom(fetchedEnvVars);
setError(null);
} catch (error) {
console.error("Error loading initial data:", error);
setError(error instanceof Error ? error : new Error(String(error)));
} finally {
setLoading(false);
}
}, [setSettingsAtom, setEnvVarsAtom]);
useEffect(() => {
const loadInitialData = async () => {
setLoading(true);
try {
const ipcClient = IpcClient.getInstance();
// Fetch settings and env vars concurrently
const [userSettings, fetchedEnvVars] = await Promise.all([
ipcClient.getUserSettings(),
ipcClient.getEnvVars(),
]);
setSettingsAtom(userSettings);
setEnvVarsAtom(fetchedEnvVars);
setError(null);
} catch (error) {
console.error("Error loading initial data:", error);
setError(error instanceof Error ? error : new Error(String(error)));
} finally {
setLoading(false);
}
};
loadInitialData();
// Only run once on mount, dependencies are stable getters/setters
}, [setSettingsAtom, setEnvVarsAtom]);
loadInitialData();
}, [loadInitialData]);
const updateSettings = async (newSettings: Partial<UserSettings>) => {
setLoading(true);
@@ -84,5 +83,8 @@ export function useSettings() {
isProviderSetup(provider)
);
},
refreshSettings: () => {
loadInitialData();
},
};
}