feat: add configuration loading and error handling to AiProvidersPage

This commit is contained in:
LTbinglingfeng
2026-01-31 01:26:49 +08:00
parent 291f67e2b9
commit e4c5f80b02

View File

@@ -1,4 +1,4 @@
import { useCallback, useEffect, useState } from 'react'; import { useCallback, useEffect, useRef, useState } from 'react';
import { useTranslation } from 'react-i18next'; import { useTranslation } from 'react-i18next';
import { useNavigate } from 'react-router-dom'; import { useNavigate } from 'react-router-dom';
import { import {
@@ -31,15 +31,27 @@ export function AiProvidersPage() {
const fetchConfig = useConfigStore((state) => state.fetchConfig); const fetchConfig = useConfigStore((state) => state.fetchConfig);
const updateConfigValue = useConfigStore((state) => state.updateConfigValue); const updateConfigValue = useConfigStore((state) => state.updateConfigValue);
const clearCache = useConfigStore((state) => state.clearCache); const clearCache = useConfigStore((state) => state.clearCache);
const isCacheValid = useConfigStore((state) => state.isCacheValid);
const [loading, setLoading] = useState(true); const hasMounted = useRef(false);
const [loading, setLoading] = useState(() => !isCacheValid());
const [error, setError] = useState(''); const [error, setError] = useState('');
const [geminiKeys, setGeminiKeys] = useState<GeminiKeyConfig[]>([]); const [geminiKeys, setGeminiKeys] = useState<GeminiKeyConfig[]>(
const [codexConfigs, setCodexConfigs] = useState<ProviderKeyConfig[]>([]); () => config?.geminiApiKeys || []
const [claudeConfigs, setClaudeConfigs] = useState<ProviderKeyConfig[]>([]); );
const [vertexConfigs, setVertexConfigs] = useState<ProviderKeyConfig[]>([]); const [codexConfigs, setCodexConfigs] = useState<ProviderKeyConfig[]>(
const [openaiProviders, setOpenaiProviders] = useState<OpenAIProviderConfig[]>([]); () => config?.codexApiKeys || []
);
const [claudeConfigs, setClaudeConfigs] = useState<ProviderKeyConfig[]>(
() => config?.claudeApiKeys || []
);
const [vertexConfigs, setVertexConfigs] = useState<ProviderKeyConfig[]>(
() => config?.vertexApiKeys || []
);
const [openaiProviders, setOpenaiProviders] = useState<OpenAIProviderConfig[]>(
() => config?.openaiCompatibility || []
);
const [configSwitchingKey, setConfigSwitchingKey] = useState<string | null>(null); const [configSwitchingKey, setConfigSwitchingKey] = useState<string | null>(null);
@@ -55,7 +67,10 @@ export function AiProvidersPage() {
}; };
const loadConfigs = useCallback(async () => { const loadConfigs = useCallback(async () => {
setLoading(true); const hasValidCache = isCacheValid();
if (!hasValidCache) {
setLoading(true);
}
setError(''); setError('');
try { try {
const [configResult, vertexResult, ampcodeResult] = await Promise.allSettled([ const [configResult, vertexResult, ampcodeResult] = await Promise.allSettled([
@@ -91,9 +106,11 @@ export function AiProvidersPage() {
} finally { } finally {
setLoading(false); setLoading(false);
} }
}, [clearCache, fetchConfig, t, updateConfigValue]); }, [clearCache, fetchConfig, isCacheValid, t, updateConfigValue]);
useEffect(() => { useEffect(() => {
if (hasMounted.current) return;
hasMounted.current = true;
loadConfigs(); loadConfigs();
loadKeyStats(); loadKeyStats();
}, [loadConfigs, loadKeyStats]); }, [loadConfigs, loadKeyStats]);