Show token bar at bottom of chat input (#33)
This commit is contained in:
43
src/hooks/useCountTokens.ts
Normal file
43
src/hooks/useCountTokens.ts
Normal file
@@ -0,0 +1,43 @@
|
||||
import { useCallback } from "react";
|
||||
import { atom, useAtom } from "jotai";
|
||||
import { IpcClient } from "@/ipc/ipc_client";
|
||||
import type { TokenCountResult } from "@/ipc/ipc_types";
|
||||
|
||||
// Create atoms to store the token count state
|
||||
export const tokenCountResultAtom = atom<TokenCountResult | null>(null);
|
||||
export const tokenCountLoadingAtom = atom<boolean>(false);
|
||||
export const tokenCountErrorAtom = atom<Error | null>(null);
|
||||
|
||||
export function useCountTokens() {
|
||||
const [result, setResult] = useAtom(tokenCountResultAtom);
|
||||
const [loading, setLoading] = useAtom(tokenCountLoadingAtom);
|
||||
const [error, setError] = useAtom(tokenCountErrorAtom);
|
||||
|
||||
const countTokens = useCallback(
|
||||
async (chatId: number, input: string) => {
|
||||
setLoading(true);
|
||||
setError(null);
|
||||
|
||||
try {
|
||||
const ipcClient = IpcClient.getInstance();
|
||||
const tokenResult = await ipcClient.countTokens({ chatId, input });
|
||||
setResult(tokenResult);
|
||||
return tokenResult;
|
||||
} catch (error) {
|
||||
console.error("Error counting tokens:", error);
|
||||
setError(error instanceof Error ? error : new Error(String(error)));
|
||||
throw error;
|
||||
} finally {
|
||||
setLoading(false);
|
||||
}
|
||||
},
|
||||
[setLoading, setError, setResult]
|
||||
);
|
||||
|
||||
return {
|
||||
countTokens,
|
||||
result,
|
||||
loading,
|
||||
error,
|
||||
};
|
||||
}
|
||||
Reference in New Issue
Block a user