- Foldable left panel (user profile) and right panel (task details) - Clicking a task in the list or graph node selects it and shows details - Both views (task list + graph) always mounted via absolute inset-0 for correct canvas dimensions; tabs toggle visibility with opacity - Graph node selection animation: other nodes repel outward (charge -600), then selected node smoothly slides to center (500ms cubic ease-out), then charge restores to -120 and graph stabilizes - Graph re-fits on tab switch and panel resize via ResizeObserver - Fix UUID string IDs throughout (backend returns UUIDs, not integers) - Add TaskDetailPanel, UserPanel components - Add CLAUDE.md project documentation Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
45 lines
891 B
TypeScript
45 lines
891 B
TypeScript
declare function arg<T extends arg.Spec>(
|
|
spec: T,
|
|
options?: arg.Options
|
|
): arg.Result<T>;
|
|
|
|
declare namespace arg {
|
|
export const flagSymbol: unique symbol;
|
|
|
|
export function flag<T>(fn: T): T & { [arg.flagSymbol]: true };
|
|
|
|
export const COUNT: Handler<number> & { [arg.flagSymbol]: true };
|
|
|
|
export type Handler<T = any> = (
|
|
value: string,
|
|
name: string,
|
|
previousValue?: T
|
|
) => T;
|
|
|
|
export class ArgError extends Error {
|
|
constructor(message: string, code: string);
|
|
|
|
code: string;
|
|
}
|
|
|
|
export interface Spec {
|
|
[key: string]: string | Handler | [Handler];
|
|
}
|
|
|
|
export type Result<T extends Spec> = { _: string[] } & {
|
|
[K in keyof T]?: T[K] extends Handler
|
|
? ReturnType<T[K]>
|
|
: T[K] extends [Handler]
|
|
? Array<ReturnType<T[K][0]>>
|
|
: never;
|
|
};
|
|
|
|
export interface Options {
|
|
argv?: string[];
|
|
permissive?: boolean;
|
|
stopAtPositional?: boolean;
|
|
}
|
|
}
|
|
|
|
export = arg;
|