mirror of
https://github.com/google-gemini/gemini-cli.git
synced 2026-03-11 22:51:00 -07:00
95 lines
2.9 KiB
TypeScript
95 lines
2.9 KiB
TypeScript
/**
|
|
* @license
|
|
* Copyright 2025 Google LLC
|
|
* SPDX-License-Identifier: Apache-2.0
|
|
*/
|
|
|
|
import { useState, useEffect } from 'react';
|
|
import type {
|
|
NetworkLog,
|
|
InspectorConsoleLog as ConsoleLog,
|
|
} from '../../src/types.js';
|
|
|
|
export type { NetworkLog };
|
|
export type { InspectorConsoleLog as ConsoleLog } from '../../src/types.js';
|
|
|
|
export function useDevToolsData() {
|
|
const [networkLogs, setNetworkLogs] = useState<NetworkLog[]>([]);
|
|
const [consoleLogs, setConsoleLogs] = useState<ConsoleLog[]>([]);
|
|
const [isConnected, setIsConnected] = useState(false);
|
|
const [connectedSessions, setConnectedSessions] = useState<string[]>([]);
|
|
|
|
useEffect(() => {
|
|
const evtSource = new EventSource('/events');
|
|
|
|
evtSource.onopen = () => setIsConnected(true);
|
|
evtSource.onerror = () => setIsConnected(false);
|
|
|
|
evtSource.addEventListener('snapshot', (e) => {
|
|
try {
|
|
const data = JSON.parse(e.data);
|
|
// Merge with existing data to preserve logs across server restarts
|
|
setNetworkLogs((prev) => {
|
|
if (data.networkLogs.length === 0) return prev;
|
|
const merged = new Map(prev.map((l: NetworkLog) => [l.id, l]));
|
|
for (const log of data.networkLogs) merged.set(log.id, log);
|
|
return Array.from(merged.values());
|
|
});
|
|
setConsoleLogs((prev) => {
|
|
if (data.consoleLogs.length === 0) return prev;
|
|
const existingIds = new Set(prev.map((l: ConsoleLog) => l.id));
|
|
const newLogs = data.consoleLogs.filter(
|
|
(l: ConsoleLog) => !existingIds.has(l.id),
|
|
);
|
|
const merged = [...prev, ...newLogs];
|
|
return merged.length > 5000 ? merged.slice(-5000) : merged;
|
|
});
|
|
setConnectedSessions(data.sessions);
|
|
} catch {
|
|
// Malformed snapshot — ignore
|
|
}
|
|
});
|
|
|
|
evtSource.addEventListener('network', (e) => {
|
|
try {
|
|
const log = JSON.parse(e.data) as NetworkLog;
|
|
setNetworkLogs((prev) => {
|
|
const idx = prev.findIndex((l) => l.id === log.id);
|
|
if (idx > -1) {
|
|
const next = [...prev];
|
|
next[idx] = log;
|
|
return next;
|
|
}
|
|
return [...prev, log];
|
|
});
|
|
} catch {
|
|
// Malformed network event — ignore
|
|
}
|
|
});
|
|
|
|
evtSource.addEventListener('console', (e) => {
|
|
try {
|
|
const log = JSON.parse(e.data) as ConsoleLog;
|
|
setConsoleLogs((prev) => {
|
|
const next = [...prev, log];
|
|
return next.length > 5000 ? next.slice(-5000) : next;
|
|
});
|
|
} catch {
|
|
// Malformed console event — ignore
|
|
}
|
|
});
|
|
|
|
evtSource.addEventListener('session', (e) => {
|
|
try {
|
|
setConnectedSessions(JSON.parse(e.data));
|
|
} catch {
|
|
// Malformed session event — ignore
|
|
}
|
|
});
|
|
|
|
return () => evtSource.close();
|
|
}, []);
|
|
|
|
return { networkLogs, consoleLogs, isConnected, connectedSessions };
|
|
}
|