reads local claude and codex auth files server-side, calls provider quota apis (anthropic oauth usage, chatgpt wham/usage), and surfaces live usedPercent per window in ProviderQuotaCard with threshold fill colors
34 lines
1.4 KiB
TypeScript
34 lines
1.4 KiB
TypeScript
import type { CostSummary, CostByAgent, CostByProviderModel, CostWindowSpendRow, ProviderQuotaResult } from "@paperclipai/shared";
|
|
import { api } from "./client";
|
|
|
|
export interface CostByProject {
|
|
projectId: string | null;
|
|
projectName: string | null;
|
|
costCents: number;
|
|
inputTokens: number;
|
|
outputTokens: number;
|
|
}
|
|
|
|
function dateParams(from?: string, to?: string): string {
|
|
const params = new URLSearchParams();
|
|
if (from) params.set("from", from);
|
|
if (to) params.set("to", to);
|
|
const qs = params.toString();
|
|
return qs ? `?${qs}` : "";
|
|
}
|
|
|
|
export const costsApi = {
|
|
summary: (companyId: string, from?: string, to?: string) =>
|
|
api.get<CostSummary>(`/companies/${companyId}/costs/summary${dateParams(from, to)}`),
|
|
byAgent: (companyId: string, from?: string, to?: string) =>
|
|
api.get<CostByAgent[]>(`/companies/${companyId}/costs/by-agent${dateParams(from, to)}`),
|
|
byProject: (companyId: string, from?: string, to?: string) =>
|
|
api.get<CostByProject[]>(`/companies/${companyId}/costs/by-project${dateParams(from, to)}`),
|
|
byProvider: (companyId: string, from?: string, to?: string) =>
|
|
api.get<CostByProviderModel[]>(`/companies/${companyId}/costs/by-provider${dateParams(from, to)}`),
|
|
windowSpend: (companyId: string) =>
|
|
api.get<CostWindowSpendRow[]>(`/companies/${companyId}/costs/window-spend`),
|
|
quotaWindows: (companyId: string) =>
|
|
api.get<ProviderQuotaResult[]>(`/companies/${companyId}/costs/quota-windows`),
|
|
};
|