diff --git a/lightrag_webui/src/App.tsx b/lightrag_webui/src/App.tsx
index c0b6ac3d..487ca2e8 100644
--- a/lightrag_webui/src/App.tsx
+++ b/lightrag_webui/src/App.tsx
@@ -1,9 +1,8 @@
import { useState, useCallback, useEffect, useRef } from 'react'
import ThemeProvider from '@/components/ThemeProvider'
import TabVisibilityProvider from '@/contexts/TabVisibilityProvider'
-import MessageAlert from '@/components/MessageAlert'
import ApiKeyAlert from '@/components/ApiKeyAlert'
-import StatusIndicator from '@/components/graph/StatusIndicator'
+import StatusIndicator from '@/components/status/StatusIndicator'
import { healthCheckInterval } from '@/lib/constants'
import { useBackendState, useAuthStore } from '@/stores/state'
import { useSettingsStore } from '@/stores/settings'
@@ -22,26 +21,30 @@ function App() {
const message = useBackendState.use.message()
const enableHealthCheck = useSettingsStore.use.enableHealthCheck()
const currentTab = useSettingsStore.use.currentTab()
- const [apiKeyInvalid, setApiKeyInvalid] = useState(false)
+ const [apiKeyAlertOpen, setApiKeyAlertOpen] = useState(false)
const versionCheckRef = useRef(false); // Prevent duplicate calls in Vite dev mode
+ const handleApiKeyAlertOpenChange = useCallback((open: boolean) => {
+ setApiKeyAlertOpen(open)
+ if (!open) {
+ useBackendState.getState().clear()
+ }
+ }, [])
+
// Health check - can be disabled
useEffect(() => {
- // Only execute if health check is enabled
- if (!enableHealthCheck) return;
+ // Only execute if health check is enabled and ApiKeyAlert is closed
+ if (!enableHealthCheck || apiKeyAlertOpen) return;
// Health check function
const performHealthCheck = async () => {
await useBackendState.getState().check();
};
- // Execute immediately
- performHealthCheck();
-
// Set interval for periodic execution
const interval = setInterval(performHealthCheck, healthCheckInterval * 1000);
return () => clearInterval(interval);
- }, [enableHealthCheck]);
+ }, [enableHealthCheck, apiKeyAlertOpen]);
// Version check - independent and executed only once
useEffect(() => {
@@ -90,12 +93,10 @@ function App() {
useEffect(() => {
if (message) {
if (message.includes(InvalidApiKeyError) || message.includes(RequireApiKeError)) {
- setApiKeyInvalid(true)
- return
+ setApiKeyAlertOpen(true)
}
}
- setApiKeyInvalid(false)
- }, [message, setApiKeyInvalid])
+ }, [message])
return (
@@ -123,8 +124,7 @@ function App() {
{enableHealthCheck && }
- {message !== null && !apiKeyInvalid && }
- {apiKeyInvalid && }
+
diff --git a/lightrag_webui/src/components/ApiKeyAlert.tsx b/lightrag_webui/src/components/ApiKeyAlert.tsx
index 86c8e13f..99a1098b 100644
--- a/lightrag_webui/src/components/ApiKeyAlert.tsx
+++ b/lightrag_webui/src/components/ApiKeyAlert.tsx
@@ -12,10 +12,12 @@ import { useSettingsStore } from '@/stores/settings'
import { useBackendState } from '@/stores/state'
import { InvalidApiKeyError, RequireApiKeError } from '@/api/lightrag'
-import { toast } from 'sonner'
+interface ApiKeyAlertProps {
+ open: boolean;
+ onOpenChange: (open: boolean) => void;
+}
-const ApiKeyAlert = () => {
- const [opened, setOpened] = useState(true)
+const ApiKeyAlert = ({ open: opened, onOpenChange: setOpened }: ApiKeyAlertProps) => {
const apiKey = useSettingsStore.use.apiKey()
const [tempApiKey, setTempApiKey] = useState('')
const message = useBackendState.use.message()
@@ -32,14 +34,10 @@ const ApiKeyAlert = () => {
}
}, [message, setOpened])
- const setApiKey = useCallback(async () => {
+ const setApiKey = useCallback(() => {
useSettingsStore.setState({ apiKey: tempApiKey || null })
- if (await useBackendState.getState().check()) {
- setOpened(false)
- return
- }
- toast.error('API Key is invalid')
- }, [tempApiKey])
+ setOpened(false)
+ }, [tempApiKey, setOpened])
const handleTempApiKeyChange = useCallback(
(e: React.ChangeEvent) => {
@@ -53,22 +51,31 @@ const ApiKeyAlert = () => {
API Key is required
- Please enter your API key
+
+ Please enter your API key to access the service
+
-
)
diff --git a/lightrag_webui/src/components/MessageAlert.tsx b/lightrag_webui/src/components/MessageAlert.tsx
deleted file mode 100644
index cd23bbd9..00000000
--- a/lightrag_webui/src/components/MessageAlert.tsx
+++ /dev/null
@@ -1,56 +0,0 @@
-import { Alert, AlertDescription, AlertTitle } from '@/components/ui/Alert'
-import { useBackendState } from '@/stores/state'
-import { useEffect, useState } from 'react'
-import { cn } from '@/lib/utils'
-
-// import Button from '@/components/ui/Button'
-// import { controlButtonVariant } from '@/lib/constants'
-
-import { AlertCircle } from 'lucide-react'
-
-const MessageAlert = () => {
- const health = useBackendState.use.health()
- const message = useBackendState.use.message()
- const messageTitle = useBackendState.use.messageTitle()
- const [isMounted, setIsMounted] = useState(false)
-
- useEffect(() => {
- setTimeout(() => {
- setIsMounted(true)
- }, 50)
- }, [])
-
- return (
-
- {!health && (
-
- )}
-
-
{messageTitle}
-
{message}
-
- {/*
-
-
-
*/}
-
- )
-}
-
-export default MessageAlert
diff --git a/lightrag_webui/src/components/graph/StatusCard.tsx b/lightrag_webui/src/components/status/StatusCard.tsx
similarity index 100%
rename from lightrag_webui/src/components/graph/StatusCard.tsx
rename to lightrag_webui/src/components/status/StatusCard.tsx
diff --git a/lightrag_webui/src/components/graph/StatusIndicator.tsx b/lightrag_webui/src/components/status/StatusIndicator.tsx
similarity index 97%
rename from lightrag_webui/src/components/graph/StatusIndicator.tsx
rename to lightrag_webui/src/components/status/StatusIndicator.tsx
index d7a1831f..263bb99e 100644
--- a/lightrag_webui/src/components/graph/StatusIndicator.tsx
+++ b/lightrag_webui/src/components/status/StatusIndicator.tsx
@@ -2,7 +2,7 @@ import { cn } from '@/lib/utils'
import { useBackendState } from '@/stores/state'
import { useEffect, useState } from 'react'
import { Popover, PopoverContent, PopoverTrigger } from '@/components/ui/Popover'
-import StatusCard from '@/components/graph/StatusCard'
+import StatusCard from '@/components/status/StatusCard'
import { useTranslation } from 'react-i18next'
const StatusIndicator = () => {