Add ApprovalDetail page with comment thread, revision request/resubmit flow, and ApprovalPayload component for structured payload display. Extend AgentDetail with permissions management, config revision history, and duplicate action. Add agent hire dialog with permission-gated access. Rework Costs page with per-agent breakdown table and period filtering. Add sidebar badge counts for pending approvals and inbox items. Enhance Dashboard with live metrics and sparkline trends. Extend Agents list with pending_approval status and bulk actions. Update IssueDetail with approval linking. Various component improvements to MetricCard, InlineEditor, CommentThread, and StatusBadge. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
28 lines
987 B
TypeScript
28 lines
987 B
TypeScript
import type { CostSummary, CostByAgent } from "@paperclip/shared";
|
|
import { api } from "./client";
|
|
|
|
export interface CostByEntity {
|
|
agentId?: string | null;
|
|
projectId?: 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<CostByEntity[]>(`/companies/${companyId}/costs/by-project${dateParams(from, to)}`),
|
|
};
|