π File detail
context/stats.tsx
π― Use case
This file lives under βcontext/β, which covers assembling model context, attachments, and conversation state. On the API surface it exposes StatsStore, createStatsStore, StatsContext, StatsProvider, and useStats (and more) β mainly functions, hooks, or classes. Dependencies touch React UI. It composes internal code from utils (relative imports).
Generated from folder role, exports, dependency roots, and inline comments β not hand-reviewed for every path.
π§ Inline summary
import { c as _c } from "react/compiler-runtime"; import React, { createContext, useCallback, useContext, useEffect, useMemo } from 'react'; import { saveCurrentProjectConfig } from '../utils/config.js'; export type StatsStore = { increment(name: string, value?: number): void;
π€ Exports (heuristic)
StatsStorecreateStatsStoreStatsContextStatsProvideruseStatsuseCounteruseGaugeuseTimeruseSet
π External import roots
Package roots from from "β¦" (relative paths omitted).
react
π₯οΈ Source preview
import { c as _c } from "react/compiler-runtime";
import React, { createContext, useCallback, useContext, useEffect, useMemo } from 'react';
import { saveCurrentProjectConfig } from '../utils/config.js';
export type StatsStore = {
increment(name: string, value?: number): void;
set(name: string, value: number): void;
observe(name: string, value: number): void;
add(name: string, value: string): void;
getAll(): Record<string, number>;
};
function percentile(sorted: number[], p: number): number {
const index = p / 100 * (sorted.length - 1);
const lower = Math.floor(index);
const upper = Math.ceil(index);
if (lower === upper) {
return sorted[lower]!;
}
return sorted[lower]! + (sorted[upper]! - sorted[lower]!) * (index - lower);
}
const RESERVOIR_SIZE = 1024;
type Histogram = {
reservoir: number[];
count: number;
sum: number;
min: number;
max: number;
};
export function createStatsStore(): StatsStore {
const metrics = new Map<string, number>();
const histograms = new Map<string, Histogram>();
const sets = new Map<string, Set<string>>();
return {
increment(name: string, value = 1) {
metrics.set(name, (metrics.get(name) ?? 0) + value);
},
set(name: string, value: number) {
metrics.set(name, value);
},
observe(name: string, value: number) {
let h = histograms.get(name);
if (!h) {
h = {
reservoir: [],
count: 0,
sum: 0,
min: value,
max: value
};
histograms.set(name, h);
}
h.count++;
h.sum += value;
if (value < h.min) {
h.min = value;
}
if (value > h.max) {
h.max = value;
}
// Reservoir sampling (Algorithm R)
if (h.reservoir.length < RESERVOIR_SIZE) {
h.reservoir.push(value);
} else {
const j = Math.floor(Math.random() * h.count);
if (j < RESERVOIR_SIZE) {
h.reservoir[j] = value;
}
}
},
add(name: string, value: string) {
let s = sets.get(name);
if (!s) {
s = new Set();
sets.set(name, s);
}
s.add(value);
},
getAll() {
const result: Record<string, number> = Object.fromEntries(metrics);
for (const [name, h] of histograms) {
if (h.count === 0) {
continue;
}
result[`${name}_count`] = h.count;
result[`${name}_min`] = h.min;
result[`${name}_max`] = h.max;
result[`${name}_avg`] = h.sum / h.count;
const sorted = [...h.reservoir].sort((a, b) => a - b);
result[`${name}_p50`] = percentile(sorted, 50);
result[`${name}_p95`] = percentile(sorted, 95);
result[`${name}_p99`] = percentile(sorted, 99);
}
for (const [name, s] of sets) {
result[name] = s.size;
}
return result;
}
};
}
export const StatsContext = createContext<StatsStore | null>(null);
type Props = {
store?: StatsStore;
children: React.ReactNode;
};
export function StatsProvider(t0) {
const $ = _c(7);
const {
store: externalStore,
children
} = t0;
let t1;
if ($[0] === Symbol.for("react.memo_cache_sentinel")) {
t1 = createStatsStore();
$[0] = t1;
} else {
t1 = $[0];
}
const internalStore = t1;
const store = externalStore ?? internalStore;
let t2;
let t3;
if ($[1] !== store) {
t2 = () => {
const flush = () => {
const metrics = store.getAll();
if (Object.keys(metrics).length > 0) {
saveCurrentProjectConfig(current => ({
...current,
lastSessionMetrics: metrics
}));
}
};
process.on("exit", flush);
return () => {
process.off("exit", flush);
};
};
t3 = [store];
$[1] = store;
$[2] = t2;
$[3] = t3;
} else {
t2 = $[2];
t3 = $[3];
}
useEffect(t2, t3);
let t4;
if ($[4] !== children || $[5] !== store) {
t4 = <StatsContext.Provider value={store}>{children}</StatsContext.Provider>;
$[4] = children;
$[5] = store;
$[6] = t4;
} else {
t4 = $[6];
}
return t4;
}
export function useStats() {
const store = useContext(StatsContext);
if (!store) {
throw new Error("useStats must be used within a StatsProvider");
}
return store;
}
export function useCounter(name) {
const $ = _c(3);
const store = useStats();
let t0;
if ($[0] !== name || $[1] !== store) {
t0 = value => store.increment(name, value);
$[0] = name;
$[1] = store;
$[2] = t0;
} else {
t0 = $[2];
}
return t0;
}
export function useGauge(name) {
const $ = _c(3);
const store = useStats();
let t0;
if ($[0] !== name || $[1] !== store) {
t0 = value => store.set(name, value);
$[0] = name;
$[1] = store;
$[2] = t0;
} else {
t0 = $[2];
}
return t0;
}
export function useTimer(name) {
const $ = _c(3);
const store = useStats();
let t0;
if ($[0] !== name || $[1] !== store) {
t0 = value => store.observe(name, value);
$[0] = name;
$[1] = store;
$[2] = t0;
} else {
t0 = $[2];
}
return t0;
}
export function useSet(name) {
const $ = _c(3);
const store = useStats();
let t0;
if ($[0] !== name || $[1] !== store) {
t0 = value => store.add(name, value);
$[0] = name;
$[1] = store;
$[2] = t0;
} else {
t0 = $[2];
}
return t0;
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["React","createContext","useCallback","useContext","useEffect","useMemo","saveCurrentProjectConfig","StatsStore","increment","name","value","set","observe","add","getAll","Record","percentile","sorted","p","index","length","lower","Math","floor","upper","ceil","RESERVOIR_SIZE","Histogram","reservoir","count","sum","min","max","createStatsStore","metrics","Map","histograms","sets","Set","get","h","push","j","random","s","result","Object","fromEntries","sort","a","b","size","StatsContext","Props","store","children","ReactNode","StatsProvider","t0","$","_c","externalStore","t1","Symbol","for","internalStore","t2","t3","flush","keys","current","lastSessionMetrics","process","on","off","t4","useStats","Error","useCounter","useGauge","useTimer","useSet"],"sources":["stats.tsx"],"sourcesContent":["import React, {\n  createContext,\n  useCallback,\n  useContext,\n  useEffect,\n  useMemo,\n} from 'react'\nimport { saveCurrentProjectConfig } from '../utils/config.js'\n\nexport type StatsStore = {\n  increment(name: string, value?: number): void\n  set(name: string, value: number): void\n  observe(name: string, value: number): void\n  add(name: string, value: string): void\n  getAll(): Record<string, number>\n}\n\nfunction percentile(sorted: number[], p: number): number {\n  const index = (p / 100) * (sorted.length - 1)\n  const lower = Math.floor(index)\n  const upper = Math.ceil(index)\n  if (lower === upper) {\n    return sorted[lower]!\n  }\n  return sorted[lower]! + (sorted[upper]! - sorted[lower]!) * (index - lower)\n}\n\nconst RESERVOIR_SIZE = 1024\n\ntype Histogram = {\n  reservoir: number[]\n  count: number\n  sum: number\n  min: number\n  max: number\n}\n\nexport function createStatsStore(): StatsStore {\n  const metrics = new Map<string, number>()\n  const histograms = new Map<string, Histogram>()\n  const sets = new Map<string, Set<string>>()\n\n  return {\n    increment(name: string, value = 1) {\n      metrics.set(name, (metrics.get(name) ?? 0) + value)\n    },\n    set(name: string, value: number) {\n      metrics.set(name, value)\n    },\n    observe(name: string, value: number) {\n      let h = histograms.get(name)\n      if (!h) {\n        h = { reservoir: [], count: 0, sum: 0, min: value, max: value }\n        histograms.set(name, h)\n      }\n      h.count++\n      h.sum += value\n      if (value < h.min) {\n        h.min = value\n      }\n      if (value > h.max) {\n        h.max = value\n      }\n      // Reservoir sampling (Algorithm R)\n      if (h.reservoir.length < RESERVOIR_SIZE) {\n        h.reservoir.push(value)\n      } else {\n        const j = Math.floor(Math.random() * h.count)\n        if (j < RESERVOIR_SIZE) {\n          h.reservoir[j] = value\n        }\n      }\n    },\n    add(name: string, value: string) {\n      let s = sets.get(name)\n      if (!s) {\n        s = new Set()\n        sets.set(name, s)\n      }\n      s.add(value)\n    },\n    getAll() {\n      const result: Record<string, number> = Object.fromEntries(metrics)\n\n      for (const [name, h] of histograms) {\n        if (h.count === 0) {\n          continue\n        }\n        result[`${name}_count`] = h.count\n        result[`${name}_min`] = h.min\n        result[`${name}_max`] = h.max\n        result[`${name}_avg`] = h.sum / h.count\n        const sorted = [...h.reservoir].sort((a, b) => a - b)\n        result[`${name}_p50`] = percentile(sorted, 50)\n        result[`${name}_p95`] = percentile(sorted, 95)\n        result[`${name}_p99`] = percentile(sorted, 99)\n      }\n\n      for (const [name, s] of sets) {\n        result[name] = s.size\n      }\n\n      return result\n    },\n  }\n}\n\nexport const StatsContext = createContext<StatsStore | null>(null)\n\ntype Props = {\n  store?: StatsStore\n  children: React.ReactNode\n}\n\nexport function StatsProvider({\n  store: externalStore,\n  children,\n}: Props): React.ReactNode {\n  const internalStore = useMemo(() => createStatsStore(), [])\n  const store = externalStore ?? internalStore\n\n  useEffect(() => {\n    const flush = () => {\n      const metrics = store.getAll()\n      if (Object.keys(metrics).length > 0) {\n        saveCurrentProjectConfig(current => ({\n          ...current,\n          lastSessionMetrics: metrics,\n        }))\n      }\n    }\n    process.on('exit', flush)\n    return () => {\n      process.off('exit', flush)\n    }\n  }, [store])\n\n  return <StatsContext.Provider value={store}>{children}</StatsContext.Provider>\n}\n\nexport function useStats(): StatsStore {\n  const store = useContext(StatsContext)\n  if (!store) {\n    throw new Error('useStats must be used within a StatsProvider')\n  }\n  return store\n}\n\nexport function useCounter(name: string): (value?: number) => void {\n  const store = useStats()\n  return useCallback(\n    (value?: number) => store.increment(name, value),\n    [store, name],\n  )\n}\n\nexport function useGauge(name: string): (value: number) => void {\n  const store = useStats()\n  return useCallback((value: number) => store.set(name, value), [store, name])\n}\n\nexport function useTimer(name: string): (value: number) => void {\n  const store = useStats()\n  return useCallback(\n    (value: number) => store.observe(name, value),\n    [store, name],\n  )\n}\n\nexport function useSet(name: string): (value: string) => void {\n  const store = useStats()\n  return useCallback((value: string) => store.add(name, value), [store, name])\n}\n"],"mappings":"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","ignoreList":[]}