claude-scope 0.1.3 → 0.1.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (64) hide show
  1. package/dist/core/renderer.d.ts +33 -3
  2. package/dist/core/renderer.d.ts.map +1 -1
  3. package/dist/core/renderer.js +48 -7
  4. package/dist/core/renderer.js.map +1 -1
  5. package/dist/data/stdin-provider.d.ts +44 -0
  6. package/dist/data/stdin-provider.d.ts.map +1 -0
  7. package/dist/data/stdin-provider.js +83 -0
  8. package/dist/data/stdin-provider.js.map +1 -0
  9. package/dist/index.d.ts.map +1 -1
  10. package/dist/index.js +56 -64
  11. package/dist/index.js.map +1 -1
  12. package/dist/providers/git-provider.d.ts +53 -46
  13. package/dist/providers/git-provider.d.ts.map +1 -1
  14. package/dist/providers/git-provider.js +53 -107
  15. package/dist/providers/git-provider.js.map +1 -1
  16. package/dist/providers/stdin-provider.d.ts +16 -15
  17. package/dist/providers/stdin-provider.d.ts.map +1 -1
  18. package/dist/providers/stdin-provider.js +35 -66
  19. package/dist/providers/stdin-provider.js.map +1 -1
  20. package/dist/schemas/stdin-schema.d.ts +123 -0
  21. package/dist/schemas/stdin-schema.d.ts.map +1 -0
  22. package/dist/schemas/stdin-schema.js +81 -0
  23. package/dist/schemas/stdin-schema.js.map +1 -0
  24. package/dist/types.d.ts +6 -63
  25. package/dist/types.d.ts.map +1 -1
  26. package/dist/types.js +3 -0
  27. package/dist/types.js.map +1 -1
  28. package/dist/ui/utils/colors.d.ts +52 -0
  29. package/dist/ui/utils/colors.d.ts.map +1 -0
  30. package/dist/ui/utils/colors.js +54 -0
  31. package/dist/ui/utils/colors.js.map +1 -0
  32. package/dist/ui/utils/formatters.d.ts +56 -0
  33. package/dist/ui/utils/formatters.d.ts.map +1 -0
  34. package/dist/ui/utils/formatters.js +114 -0
  35. package/dist/ui/utils/formatters.js.map +1 -0
  36. package/dist/widgets/context-widget.d.ts +3 -3
  37. package/dist/widgets/context-widget.d.ts.map +1 -1
  38. package/dist/widgets/context-widget.js +9 -5
  39. package/dist/widgets/context-widget.js.map +1 -1
  40. package/dist/widgets/core/stdin-data-widget.d.ts +93 -0
  41. package/dist/widgets/core/stdin-data-widget.d.ts.map +1 -0
  42. package/dist/widgets/core/stdin-data-widget.js +84 -0
  43. package/dist/widgets/core/stdin-data-widget.js.map +1 -0
  44. package/dist/widgets/cost-widget.d.ts +4 -4
  45. package/dist/widgets/cost-widget.d.ts.map +1 -1
  46. package/dist/widgets/cost-widget.js +6 -5
  47. package/dist/widgets/cost-widget.js.map +1 -1
  48. package/dist/widgets/duration-widget.d.ts +3 -3
  49. package/dist/widgets/duration-widget.d.ts.map +1 -1
  50. package/dist/widgets/duration-widget.js +5 -4
  51. package/dist/widgets/duration-widget.js.map +1 -1
  52. package/dist/widgets/git/git-changes-widget.d.ts +38 -0
  53. package/dist/widgets/git/git-changes-widget.d.ts.map +1 -0
  54. package/dist/widgets/git/git-changes-widget.js +91 -0
  55. package/dist/widgets/git/git-changes-widget.js.map +1 -0
  56. package/dist/widgets/git/git-widget.d.ts +37 -0
  57. package/dist/widgets/git/git-widget.d.ts.map +1 -0
  58. package/dist/widgets/git/git-widget.js +67 -0
  59. package/dist/widgets/git/git-widget.js.map +1 -0
  60. package/dist/widgets/model-widget.d.ts +3 -3
  61. package/dist/widgets/model-widget.d.ts.map +1 -1
  62. package/dist/widgets/model-widget.js +2 -3
  63. package/dist/widgets/model-widget.js.map +1 -1
  64. package/package.json +8 -6
package/dist/types.d.ts CHANGED
@@ -1,69 +1,12 @@
1
1
  /**
2
2
  * Shared types used across the application
3
+ *
4
+ * This file re-exports types from the Zod schema (single source of truth)
5
+ * and defines additional types not related to stdin data validation.
3
6
  */
4
- /**
5
- * Model information from Claude Code
6
- */
7
- export interface ModelInfo {
8
- id: string;
9
- display_name: string;
10
- }
11
- /**
12
- * Output style configuration
13
- */
14
- export interface OutputStyle {
15
- name: string;
16
- }
17
- /**
18
- * Workspace information
19
- */
20
- export interface WorkspaceInfo {
21
- current_dir: string;
22
- project_dir: string;
23
- }
24
- /**
25
- * Cost and activity information
26
- */
27
- export interface CostInfo {
28
- total_cost_usd: number;
29
- total_duration_ms: number;
30
- total_api_duration_ms: number;
31
- total_lines_added: number;
32
- total_lines_removed: number;
33
- }
34
- /**
35
- * Current context window usage
36
- */
37
- export interface ContextUsage {
38
- input_tokens: number;
39
- output_tokens: number;
40
- cache_creation_input_tokens: number;
41
- cache_read_input_tokens: number;
42
- }
43
- /**
44
- * Context window information
45
- */
46
- export interface ContextWindow {
47
- total_input_tokens: number;
48
- total_output_tokens: number;
49
- context_window_size: number;
50
- current_usage: ContextUsage | null;
51
- }
52
- /**
53
- * Data received from Claude Code via stdin
54
- */
55
- export interface StdinData {
56
- hook_event_name: "Status";
57
- session_id: string;
58
- transcript_path: string;
59
- cwd: string;
60
- model: ModelInfo;
61
- workspace: WorkspaceInfo;
62
- version: string;
63
- output_style: OutputStyle;
64
- cost: CostInfo;
65
- context_window: ContextWindow;
66
- }
7
+ import type { StdinData, ModelInfo, Workspace, OutputStyle, CostInfo, ContextWindow, ContextUsage } from './schemas/stdin-schema.js';
8
+ export type { StdinData, ModelInfo, Workspace, OutputStyle, CostInfo, ContextWindow, ContextUsage };
9
+ export type WorkspaceInfo = Workspace;
67
10
  /**
68
11
  * Git repository information
69
12
  */
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH;;GAEG;AACH,MAAM,WAAW,SAAS;IACxB,EAAE,EAAE,MAAM,CAAC;IACX,YAAY,EAAE,MAAM,CAAC;CACtB;AAED;;GAEG;AACH,MAAM,WAAW,WAAW;IAC1B,IAAI,EAAE,MAAM,CAAC;CACd;AAED;;GAEG;AACH,MAAM,WAAW,aAAa;IAC5B,WAAW,EAAE,MAAM,CAAC;IACpB,WAAW,EAAE,MAAM,CAAC;CACrB;AAED;;GAEG;AACH,MAAM,WAAW,QAAQ;IACvB,cAAc,EAAE,MAAM,CAAC;IACvB,iBAAiB,EAAE,MAAM,CAAC;IAC1B,qBAAqB,EAAE,MAAM,CAAC;IAC9B,iBAAiB,EAAE,MAAM,CAAC;IAC1B,mBAAmB,EAAE,MAAM,CAAC;CAC7B;AAED;;GAEG;AACH,MAAM,WAAW,YAAY;IAC3B,YAAY,EAAE,MAAM,CAAC;IACrB,aAAa,EAAE,MAAM,CAAC;IACtB,2BAA2B,EAAE,MAAM,CAAC;IACpC,uBAAuB,EAAE,MAAM,CAAC;CACjC;AAED;;GAEG;AACH,MAAM,WAAW,aAAa;IAC5B,kBAAkB,EAAE,MAAM,CAAC;IAC3B,mBAAmB,EAAE,MAAM,CAAC;IAC5B,mBAAmB,EAAE,MAAM,CAAC;IAC5B,aAAa,EAAE,YAAY,GAAG,IAAI,CAAC;CACpC;AAED;;GAEG;AACH,MAAM,WAAW,SAAS;IACxB,eAAe,EAAE,QAAQ,CAAC;IAC1B,UAAU,EAAE,MAAM,CAAC;IACnB,eAAe,EAAE,MAAM,CAAC;IACxB,GAAG,EAAE,MAAM,CAAC;IACZ,KAAK,EAAE,SAAS,CAAC;IACjB,SAAS,EAAE,aAAa,CAAC;IACzB,OAAO,EAAE,MAAM,CAAC;IAChB,YAAY,EAAE,WAAW,CAAC;IAC1B,IAAI,EAAE,QAAQ,CAAC;IACf,cAAc,EAAE,aAAa,CAAC;CAC/B;AAED;;GAEG;AACH,MAAM,WAAW,OAAO;IACtB,MAAM,EAAE,MAAM,GAAG,IAAI,CAAC;IACtB,MAAM,EAAE,OAAO,CAAC;CACjB;AAED;;GAEG;AACH,MAAM,WAAW,UAAU;IACzB,UAAU,EAAE,MAAM,CAAC;IACnB,SAAS,EAAE,MAAM,CAAC;CACnB;AAED;;GAEG;AACH,MAAM,WAAW,aAAa;IAC5B,KAAK,EAAE,MAAM,CAAC;IACd,SAAS,EAAE,MAAM,CAAC;CACnB"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAGH,OAAO,KAAK,EACV,SAAS,EACT,SAAS,EACT,SAAS,EACT,WAAW,EACX,QAAQ,EACR,aAAa,EACb,YAAY,EACb,MAAM,2BAA2B,CAAC;AAGnC,YAAY,EACV,SAAS,EACT,SAAS,EACT,SAAS,EACT,WAAW,EACX,QAAQ,EACR,aAAa,EACb,YAAY,EACb,CAAC;AAGF,MAAM,MAAM,aAAa,GAAG,SAAS,CAAC;AAEtC;;GAEG;AACH,MAAM,WAAW,OAAO;IACtB,MAAM,EAAE,MAAM,GAAG,IAAI,CAAC;IACtB,MAAM,EAAE,OAAO,CAAC;CACjB;AAED;;GAEG;AACH,MAAM,WAAW,UAAU;IACzB,UAAU,EAAE,MAAM,CAAC;IACnB,SAAS,EAAE,MAAM,CAAC;CACnB;AAED;;GAEG;AACH,MAAM,WAAW,aAAa;IAC5B,KAAK,EAAE,MAAM,CAAC;IACd,SAAS,EAAE,MAAM,CAAC;CACnB"}
package/dist/types.js CHANGED
@@ -1,5 +1,8 @@
1
1
  /**
2
2
  * Shared types used across the application
3
+ *
4
+ * This file re-exports types from the Zod schema (single source of truth)
5
+ * and defines additional types not related to stdin data validation.
3
6
  */
4
7
  export {};
5
8
  //# sourceMappingURL=types.js.map
package/dist/types.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA;;GAEG"}
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA;;;;;GAKG"}
@@ -0,0 +1,52 @@
1
+ /**
2
+ * ANSI color utilities for terminal output
3
+ *
4
+ * Provides ANSI escape codes for colors and text styling in terminal output.
5
+ * These codes work in most modern terminal emulators.
6
+ */
7
+ /**
8
+ * Reset all styles and colors
9
+ */
10
+ export declare const reset = "\u001B[0m";
11
+ /**
12
+ * Foreground colors (30-37, 90 for bright/bold variants)
13
+ */
14
+ export declare const red = "\u001B[31m";
15
+ export declare const green = "\u001B[32m";
16
+ export declare const yellow = "\u001B[33m";
17
+ export declare const blue = "\u001B[34m";
18
+ export declare const magenta = "\u001B[35m";
19
+ export declare const cyan = "\u001B[36m";
20
+ export declare const white = "\u001B[37m";
21
+ export declare const gray = "\u001B[90m";
22
+ /**
23
+ * Background colors (40-47)
24
+ */
25
+ export declare const bgRed = "\u001B[41m";
26
+ export declare const bgGreen = "\u001B[42m";
27
+ export declare const bgYellow = "\u001B[43m";
28
+ export declare const bgBlue = "\u001B[44m";
29
+ /**
30
+ * Text styles
31
+ */
32
+ export declare const bold = "\u001B[1m";
33
+ export declare const dim = "\u001B[2m";
34
+ export declare const italic = "\u001B[3m";
35
+ export declare const underline = "\u001B[4m";
36
+ /**
37
+ * Context usage colors
38
+ * Used for context progress bar based on usage percentage
39
+ */
40
+ export declare const contextColors: {
41
+ readonly low: "\u001B[32m";
42
+ readonly medium: "\u001B[33m";
43
+ readonly high: "\u001B[31m";
44
+ };
45
+ /**
46
+ * Wrap text in ANSI color
47
+ * @param text - Text to colorize
48
+ * @param color - ANSI color code
49
+ * @returns Colorized text with reset code
50
+ */
51
+ export declare function colorize(text: string, color: string): string;
52
+ //# sourceMappingURL=colors.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"colors.d.ts","sourceRoot":"","sources":["../../../src/ui/utils/colors.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH;;GAEG;AACH,eAAO,MAAM,KAAK,cAAY,CAAC;AAE/B;;GAEG;AACH,eAAO,MAAM,GAAG,eAAa,CAAC;AAC9B,eAAO,MAAM,KAAK,eAAa,CAAC;AAChC,eAAO,MAAM,MAAM,eAAa,CAAC;AACjC,eAAO,MAAM,IAAI,eAAa,CAAC;AAC/B,eAAO,MAAM,OAAO,eAAa,CAAC;AAClC,eAAO,MAAM,IAAI,eAAa,CAAC;AAC/B,eAAO,MAAM,KAAK,eAAa,CAAC;AAChC,eAAO,MAAM,IAAI,eAAa,CAAC;AAE/B;;GAEG;AACH,eAAO,MAAM,KAAK,eAAa,CAAC;AAChC,eAAO,MAAM,OAAO,eAAa,CAAC;AAClC,eAAO,MAAM,QAAQ,eAAa,CAAC;AACnC,eAAO,MAAM,MAAM,eAAa,CAAC;AAEjC;;GAEG;AACH,eAAO,MAAM,IAAI,cAAY,CAAC;AAC9B,eAAO,MAAM,GAAG,cAAY,CAAC;AAC7B,eAAO,MAAM,MAAM,cAAY,CAAC;AAChC,eAAO,MAAM,SAAS,cAAY,CAAC;AAEnC;;;GAGG;AACH,eAAO,MAAM,aAAa;;;;CAIhB,CAAC;AAEX;;;;;GAKG;AACH,wBAAgB,QAAQ,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,MAAM,CAE5D"}
@@ -0,0 +1,54 @@
1
+ /**
2
+ * ANSI color utilities for terminal output
3
+ *
4
+ * Provides ANSI escape codes for colors and text styling in terminal output.
5
+ * These codes work in most modern terminal emulators.
6
+ */
7
+ /**
8
+ * Reset all styles and colors
9
+ */
10
+ export const reset = '\x1b[0m';
11
+ /**
12
+ * Foreground colors (30-37, 90 for bright/bold variants)
13
+ */
14
+ export const red = '\x1b[31m';
15
+ export const green = '\x1b[32m';
16
+ export const yellow = '\x1b[33m';
17
+ export const blue = '\x1b[34m';
18
+ export const magenta = '\x1b[35m';
19
+ export const cyan = '\x1b[36m';
20
+ export const white = '\x1b[37m';
21
+ export const gray = '\x1b[90m';
22
+ /**
23
+ * Background colors (40-47)
24
+ */
25
+ export const bgRed = '\x1b[41m';
26
+ export const bgGreen = '\x1b[42m';
27
+ export const bgYellow = '\x1b[43m';
28
+ export const bgBlue = '\x1b[44m';
29
+ /**
30
+ * Text styles
31
+ */
32
+ export const bold = '\x1b[1m';
33
+ export const dim = '\x1b[2m';
34
+ export const italic = '\x1b[3m';
35
+ export const underline = '\x1b[4m';
36
+ /**
37
+ * Context usage colors
38
+ * Used for context progress bar based on usage percentage
39
+ */
40
+ export const contextColors = {
41
+ low: green, // <50% usage
42
+ medium: yellow, // 50-79% usage
43
+ high: red // >=80% usage
44
+ };
45
+ /**
46
+ * Wrap text in ANSI color
47
+ * @param text - Text to colorize
48
+ * @param color - ANSI color code
49
+ * @returns Colorized text with reset code
50
+ */
51
+ export function colorize(text, color) {
52
+ return `${color}${text}${reset}`;
53
+ }
54
+ //# sourceMappingURL=colors.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"colors.js","sourceRoot":"","sources":["../../../src/ui/utils/colors.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH;;GAEG;AACH,MAAM,CAAC,MAAM,KAAK,GAAG,SAAS,CAAC;AAE/B;;GAEG;AACH,MAAM,CAAC,MAAM,GAAG,GAAG,UAAU,CAAC;AAC9B,MAAM,CAAC,MAAM,KAAK,GAAG,UAAU,CAAC;AAChC,MAAM,CAAC,MAAM,MAAM,GAAG,UAAU,CAAC;AACjC,MAAM,CAAC,MAAM,IAAI,GAAG,UAAU,CAAC;AAC/B,MAAM,CAAC,MAAM,OAAO,GAAG,UAAU,CAAC;AAClC,MAAM,CAAC,MAAM,IAAI,GAAG,UAAU,CAAC;AAC/B,MAAM,CAAC,MAAM,KAAK,GAAG,UAAU,CAAC;AAChC,MAAM,CAAC,MAAM,IAAI,GAAG,UAAU,CAAC;AAE/B;;GAEG;AACH,MAAM,CAAC,MAAM,KAAK,GAAG,UAAU,CAAC;AAChC,MAAM,CAAC,MAAM,OAAO,GAAG,UAAU,CAAC;AAClC,MAAM,CAAC,MAAM,QAAQ,GAAG,UAAU,CAAC;AACnC,MAAM,CAAC,MAAM,MAAM,GAAG,UAAU,CAAC;AAEjC;;GAEG;AACH,MAAM,CAAC,MAAM,IAAI,GAAG,SAAS,CAAC;AAC9B,MAAM,CAAC,MAAM,GAAG,GAAG,SAAS,CAAC;AAC7B,MAAM,CAAC,MAAM,MAAM,GAAG,SAAS,CAAC;AAChC,MAAM,CAAC,MAAM,SAAS,GAAG,SAAS,CAAC;AAEnC;;;GAGG;AACH,MAAM,CAAC,MAAM,aAAa,GAAG;IAC3B,GAAG,EAAE,KAAK,EAAM,aAAa;IAC7B,MAAM,EAAE,MAAM,EAAE,eAAe;IAC/B,IAAI,EAAE,GAAG,CAAO,cAAc;CACtB,CAAC;AAEX;;;;;GAKG;AACH,MAAM,UAAU,QAAQ,CAAC,IAAY,EAAE,KAAa;IAClD,OAAO,GAAG,KAAK,GAAG,IAAI,GAAG,KAAK,EAAE,CAAC;AACnC,CAAC"}
@@ -0,0 +1,56 @@
1
+ /**
2
+ * Formatter utilities for displaying data in human-readable formats
3
+ */
4
+ /**
5
+ * Format milliseconds to human-readable duration
6
+ *
7
+ * Examples:
8
+ * - 45000 -> "45s"
9
+ * - 60000 -> "1m 0s"
10
+ * - 3600000 -> "1h 0m 0s"
11
+ * - 3665000 -> "1h 1m 5s"
12
+ *
13
+ * @param ms - Duration in milliseconds
14
+ * @returns Human-readable duration string
15
+ */
16
+ export declare function formatDuration(ms: number): string;
17
+ /**
18
+ * Format cost in USD with appropriate precision
19
+ *
20
+ * - Values < $0.01 (positive): 4 decimal places ($0.0012)
21
+ * - Values >= $0.01: 2 decimal places ($1.23)
22
+ * - Values >= $100: 0 decimal places ($123)
23
+ * - Negative values: 2 decimal places ($-1.23)
24
+ *
25
+ * @param usd - Cost in USD
26
+ * @returns Formatted cost string with $ prefix
27
+ */
28
+ export declare function formatCostUSD(usd: number): string;
29
+ /**
30
+ * Create a visual progress bar
31
+ *
32
+ * @param percent - Percentage (0-100)
33
+ * @param width - Bar width in characters (default: DEFAULTS.PROGRESS_BAR_WIDTH)
34
+ * @returns Progress bar string like "████████░░░░░░░░░░░░"
35
+ */
36
+ export declare function progressBar(percent: number, width?: number): string;
37
+ /**
38
+ * Get color code for context percentage
39
+ *
40
+ * - <50%: green (low usage)
41
+ * - 50-79%: yellow (medium usage)
42
+ * - >=80%: red (high usage)
43
+ *
44
+ * @param percent - Context usage percentage (0-100)
45
+ * @returns ANSI color code
46
+ */
47
+ export declare function getContextColor(percent: number): string;
48
+ /**
49
+ * Colorize text with ANSI color code
50
+ *
51
+ * @param text - Text to colorize
52
+ * @param color - ANSI color code
53
+ * @returns Colorized text with reset code
54
+ */
55
+ export declare function colorize(text: string, color: string): string;
56
+ //# sourceMappingURL=formatters.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"formatters.d.ts","sourceRoot":"","sources":["../../../src/ui/utils/formatters.ts"],"names":[],"mappings":"AAAA;;GAEG;AAIH;;;;;;;;;;;GAWG;AACH,wBAAgB,cAAc,CAAC,EAAE,EAAE,MAAM,GAAG,MAAM,CAsBjD;AAED;;;;;;;;;;GAUG;AACH,wBAAgB,aAAa,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAgBjD;AAED;;;;;;GAMG;AACH,wBAAgB,WAAW,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,GAAE,MAAoC,GAAG,MAAM,CAKhG;AAED;;;;;;;;;GASG;AACH,wBAAgB,eAAe,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,CAUvD;AAED;;;;;;GAMG;AACH,wBAAgB,QAAQ,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,MAAM,CAE5D"}
@@ -0,0 +1,114 @@
1
+ /**
2
+ * Formatter utilities for displaying data in human-readable formats
3
+ */
4
+ import { TIME, COST_THRESHOLDS, CONTEXT_THRESHOLDS, ANSI_COLORS, DEFAULTS } from '../../constants.js';
5
+ /**
6
+ * Format milliseconds to human-readable duration
7
+ *
8
+ * Examples:
9
+ * - 45000 -> "45s"
10
+ * - 60000 -> "1m 0s"
11
+ * - 3600000 -> "1h 0m 0s"
12
+ * - 3665000 -> "1h 1m 5s"
13
+ *
14
+ * @param ms - Duration in milliseconds
15
+ * @returns Human-readable duration string
16
+ */
17
+ export function formatDuration(ms) {
18
+ if (ms <= 0)
19
+ return '0s';
20
+ const seconds = Math.floor(ms / TIME.MS_PER_SECOND);
21
+ const hours = Math.floor(seconds / TIME.SECONDS_PER_HOUR);
22
+ const minutes = Math.floor((seconds % TIME.SECONDS_PER_HOUR) / TIME.SECONDS_PER_MINUTE);
23
+ const secs = seconds % TIME.SECONDS_PER_MINUTE;
24
+ const parts = [];
25
+ if (hours > 0) {
26
+ parts.push(`${hours}h`);
27
+ parts.push(`${minutes}m`);
28
+ parts.push(`${secs}s`);
29
+ }
30
+ else if (minutes > 0) {
31
+ parts.push(`${minutes}m`);
32
+ parts.push(`${secs}s`);
33
+ }
34
+ else {
35
+ parts.push(`${secs}s`);
36
+ }
37
+ return parts.join(' ');
38
+ }
39
+ /**
40
+ * Format cost in USD with appropriate precision
41
+ *
42
+ * - Values < $0.01 (positive): 4 decimal places ($0.0012)
43
+ * - Values >= $0.01: 2 decimal places ($1.23)
44
+ * - Values >= $100: 0 decimal places ($123)
45
+ * - Negative values: 2 decimal places ($-1.23)
46
+ *
47
+ * @param usd - Cost in USD
48
+ * @returns Formatted cost string with $ prefix
49
+ */
50
+ export function formatCostUSD(usd) {
51
+ const absUsd = Math.abs(usd);
52
+ if (usd < 0) {
53
+ // Negative values: 2 decimal places
54
+ return `$${usd.toFixed(2)}`;
55
+ }
56
+ else if (absUsd < COST_THRESHOLDS.SMALL) {
57
+ // 4 decimal places for very small positive values
58
+ return `$${usd.toFixed(4)}`;
59
+ }
60
+ else if (absUsd < COST_THRESHOLDS.LARGE) {
61
+ // 2 decimal places for normal values
62
+ return `$${usd.toFixed(2)}`;
63
+ }
64
+ else {
65
+ // 0 decimal places for large values
66
+ return `$${Math.floor(usd).toFixed(0)}`;
67
+ }
68
+ }
69
+ /**
70
+ * Create a visual progress bar
71
+ *
72
+ * @param percent - Percentage (0-100)
73
+ * @param width - Bar width in characters (default: DEFAULTS.PROGRESS_BAR_WIDTH)
74
+ * @returns Progress bar string like "████████░░░░░░░░░░░░"
75
+ */
76
+ export function progressBar(percent, width = DEFAULTS.PROGRESS_BAR_WIDTH) {
77
+ const clampedPercent = Math.max(0, Math.min(100, percent));
78
+ const filled = Math.round((clampedPercent / 100) * width);
79
+ const empty = width - filled;
80
+ return '█'.repeat(filled) + '░'.repeat(empty);
81
+ }
82
+ /**
83
+ * Get color code for context percentage
84
+ *
85
+ * - <50%: green (low usage)
86
+ * - 50-79%: yellow (medium usage)
87
+ * - >=80%: red (high usage)
88
+ *
89
+ * @param percent - Context usage percentage (0-100)
90
+ * @returns ANSI color code
91
+ */
92
+ export function getContextColor(percent) {
93
+ const clampedPercent = Math.max(0, Math.min(100, percent));
94
+ if (clampedPercent < CONTEXT_THRESHOLDS.LOW_MEDIUM) {
95
+ return ANSI_COLORS.GREEN;
96
+ }
97
+ else if (clampedPercent < CONTEXT_THRESHOLDS.MEDIUM_HIGH) {
98
+ return ANSI_COLORS.YELLOW;
99
+ }
100
+ else {
101
+ return ANSI_COLORS.RED;
102
+ }
103
+ }
104
+ /**
105
+ * Colorize text with ANSI color code
106
+ *
107
+ * @param text - Text to colorize
108
+ * @param color - ANSI color code
109
+ * @returns Colorized text with reset code
110
+ */
111
+ export function colorize(text, color) {
112
+ return `${color}${text}${ANSI_COLORS.RESET}`;
113
+ }
114
+ //# sourceMappingURL=formatters.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"formatters.js","sourceRoot":"","sources":["../../../src/ui/utils/formatters.ts"],"names":[],"mappings":"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"}
@@ -3,11 +3,11 @@
3
3
  *
4
4
  * Displays context window usage with progress bar
5
5
  */
6
- import { StdinDataWidget } from '../core/stdin-data-widget.js';
7
- import type { RenderContext } from '../core/types.js';
6
+ import { StdinDataWidget } from './core/stdin-data-widget.js';
7
+ import type { RenderContext, StdinData } from '../types.js';
8
8
  export declare class ContextWidget extends StdinDataWidget {
9
9
  readonly id = "context";
10
10
  readonly metadata: import("../core/types.js").IWidgetMetadata;
11
- render(context: RenderContext): Promise<string | null>;
11
+ protected renderWithData(data: StdinData, context: RenderContext): string | null;
12
12
  }
13
13
  //# sourceMappingURL=context-widget.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"context-widget.d.ts","sourceRoot":"","sources":["../../src/widgets/context-widget.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAI/D,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,kBAAkB,CAAC;AAEtD,qBAAa,aAAc,SAAQ,eAAe;IAChD,QAAQ,CAAC,EAAE,aAAa;IACxB,QAAQ,CAAC,QAAQ,6CAGf;IAEI,MAAM,CAAC,OAAO,EAAE,aAAa,GAAG,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC;CAiB7D"}
1
+ {"version":3,"file":"context-widget.d.ts","sourceRoot":"","sources":["../../src/widgets/context-widget.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,eAAe,EAAE,MAAM,6BAA6B,CAAC;AAI9D,OAAO,KAAK,EAAE,aAAa,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAE5D,qBAAa,aAAc,SAAQ,eAAe;IAChD,QAAQ,CAAC,EAAE,aAAa;IACxB,QAAQ,CAAC,QAAQ,6CAGf;IAEF,SAAS,CAAC,cAAc,CAAC,IAAI,EAAE,SAAS,EAAE,OAAO,EAAE,aAAa,GAAG,MAAM,GAAG,IAAI;CAqBjF"}
@@ -3,21 +3,25 @@
3
3
  *
4
4
  * Displays context window usage with progress bar
5
5
  */
6
- import { StdinDataWidget } from '../core/stdin-data-widget.js';
6
+ import { StdinDataWidget } from './core/stdin-data-widget.js';
7
7
  import { createWidgetMetadata } from '../core/widget-types.js';
8
- import { progressBar, getContextColor, colorize } from '../utils/formatters.js';
8
+ import { progressBar, getContextColor, colorize } from '../ui/utils/formatters.js';
9
9
  import { DEFAULTS } from '../constants.js';
10
10
  export class ContextWidget extends StdinDataWidget {
11
11
  id = 'context';
12
12
  metadata = createWidgetMetadata('Context', 'Displays context window usage with progress bar');
13
- async render(context) {
14
- const data = this.getData();
13
+ renderWithData(data, context) {
15
14
  const { current_usage, context_window_size } = data.context_window;
16
15
  if (!current_usage)
17
16
  return null;
17
+ // Calculate actual context usage:
18
+ // - input_tokens: new tokens added to context
19
+ // - cache_creation_input_tokens: tokens spent creating cache (also in context)
20
+ // - cache_read_input_tokens: NOT counted (reading from cache doesn't use context space)
21
+ // - output_tokens: tokens in the response (also part of context)
18
22
  const used = current_usage.input_tokens +
19
23
  current_usage.cache_creation_input_tokens +
20
- current_usage.cache_read_input_tokens;
24
+ current_usage.output_tokens;
21
25
  const percent = Math.round((used / context_window_size) * 100);
22
26
  const bar = progressBar(percent, DEFAULTS.PROGRESS_BAR_WIDTH);
23
27
  const color = getContextColor(percent);
@@ -1 +1 @@
1
- {"version":3,"file":"context-widget.js","sourceRoot":"","sources":["../../src/widgets/context-widget.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,eAAe,EAAE,MAAM,8BAA8B,CAAC;AAC/D,OAAO,EAAE,oBAAoB,EAAE,MAAM,yBAAyB,CAAC;AAC/D,OAAO,EAAE,WAAW,EAAE,eAAe,EAAE,QAAQ,EAAE,MAAM,wBAAwB,CAAC;AAChF,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAG3C,MAAM,OAAO,aAAc,SAAQ,eAAe;IACvC,EAAE,GAAG,SAAS,CAAC;IACf,QAAQ,GAAG,oBAAoB,CACtC,SAAS,EACT,iDAAiD,CAClD,CAAC;IAEF,KAAK,CAAC,MAAM,CAAC,OAAsB;QACjC,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;QAC5B,MAAM,EAAE,aAAa,EAAE,mBAAmB,EAAE,GAAG,IAAI,CAAC,cAAc,CAAC;QAEnE,IAAI,CAAC,aAAa;YAAE,OAAO,IAAI,CAAC;QAEhC,MAAM,IAAI,GAAG,aAAa,CAAC,YAAY;YAC1B,aAAa,CAAC,2BAA2B;YACzC,aAAa,CAAC,uBAAuB,CAAC;QAEnD,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,IAAI,GAAG,mBAAmB,CAAC,GAAG,GAAG,CAAC,CAAC;QAE/D,MAAM,GAAG,GAAG,WAAW,CAAC,OAAO,EAAE,QAAQ,CAAC,kBAAkB,CAAC,CAAC;QAC9D,MAAM,KAAK,GAAG,eAAe,CAAC,OAAO,CAAC,CAAC;QAEvC,OAAO,QAAQ,CAAC,IAAI,GAAG,KAAK,OAAO,GAAG,EAAE,KAAK,CAAC,CAAC;IACjD,CAAC;CACF"}
1
+ {"version":3,"file":"context-widget.js","sourceRoot":"","sources":["../../src/widgets/context-widget.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,eAAe,EAAE,MAAM,6BAA6B,CAAC;AAC9D,OAAO,EAAE,oBAAoB,EAAE,MAAM,yBAAyB,CAAC;AAC/D,OAAO,EAAE,WAAW,EAAE,eAAe,EAAE,QAAQ,EAAE,MAAM,2BAA2B,CAAC;AACnF,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAG3C,MAAM,OAAO,aAAc,SAAQ,eAAe;IACvC,EAAE,GAAG,SAAS,CAAC;IACf,QAAQ,GAAG,oBAAoB,CACtC,SAAS,EACT,iDAAiD,CAClD,CAAC;IAEQ,cAAc,CAAC,IAAe,EAAE,OAAsB;QAC9D,MAAM,EAAE,aAAa,EAAE,mBAAmB,EAAE,GAAG,IAAI,CAAC,cAAc,CAAC;QAEnE,IAAI,CAAC,aAAa;YAAE,OAAO,IAAI,CAAC;QAEhC,kCAAkC;QAClC,8CAA8C;QAC9C,+EAA+E;QAC/E,wFAAwF;QACxF,iEAAiE;QACjE,MAAM,IAAI,GAAG,aAAa,CAAC,YAAY;YAC1B,aAAa,CAAC,2BAA2B;YACzC,aAAa,CAAC,aAAa,CAAC;QAEzC,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,IAAI,GAAG,mBAAmB,CAAC,GAAG,GAAG,CAAC,CAAC;QAE/D,MAAM,GAAG,GAAG,WAAW,CAAC,OAAO,EAAE,QAAQ,CAAC,kBAAkB,CAAC,CAAC;QAC9D,MAAM,KAAK,GAAG,eAAe,CAAC,OAAO,CAAC,CAAC;QAEvC,OAAO,QAAQ,CAAC,IAAI,GAAG,KAAK,OAAO,GAAG,EAAE,KAAK,CAAC,CAAC;IACjD,CAAC;CACF"}
@@ -0,0 +1,93 @@
1
+ /**
2
+ * Base class for widgets that receive StdinData
3
+ *
4
+ * Uses Template Method Pattern for state management.
5
+ *
6
+ * Extending widgets only need to implement renderWithData() method.
7
+ * The base class handles data storage, update logic, and enables checking.
8
+ */
9
+ import type { IWidget, IWidgetMetadata, WidgetContext, RenderContext } from '../../core/types.js';
10
+ import type { StdinData } from '../../types.js';
11
+ /**
12
+ * Abstract base class for widgets working with StdinData
13
+ *
14
+ * Uses Template Method Pattern:
15
+ * - render() is final template method that handles null checks
16
+ * - Subclasses implement renderWithData() hook with data as parameter
17
+ *
18
+ * @example
19
+ * ```typescript
20
+ * export class ModelWidget extends StdinDataWidget {
21
+ * readonly id = 'model';
22
+ * readonly metadata = createWidgetMetadata('Model', 'Displays Claude model');
23
+ *
24
+ * protected renderWithData(data: StdinData, context: RenderContext): string | null {
25
+ * return data.model.display_name;
26
+ * }
27
+ * }
28
+ * ```
29
+ */
30
+ export declare abstract class StdinDataWidget implements IWidget {
31
+ /**
32
+ * Stored stdin data from last update
33
+ */
34
+ protected data: StdinData | null;
35
+ /**
36
+ * Widget enabled state
37
+ */
38
+ protected enabled: boolean;
39
+ /**
40
+ * Unique widget identifier
41
+ */
42
+ abstract readonly id: string;
43
+ /**
44
+ * Widget metadata
45
+ */
46
+ abstract readonly metadata: IWidgetMetadata;
47
+ /**
48
+ * Initialize widget with context
49
+ * @param context - Widget initialization context
50
+ */
51
+ initialize(context: WidgetContext): Promise<void>;
52
+ /**
53
+ * Update widget with new stdin data
54
+ * @param data - Stdin data from Claude Code
55
+ */
56
+ update(data: StdinData): Promise<void>;
57
+ /**
58
+ * Get stored stdin data
59
+ * @returns Stored stdin data
60
+ * @throws Error if data has not been initialized (update not called)
61
+ */
62
+ getData(): StdinData;
63
+ /**
64
+ * Check if widget is enabled
65
+ * @returns true if widget should render
66
+ */
67
+ isEnabled(): boolean;
68
+ /**
69
+ * Template method - final, subclasses implement renderWithData()
70
+ *
71
+ * Handles null data checks and calls renderWithData() hook.
72
+ *
73
+ * @param context - Render context
74
+ * @returns Rendered string, or null if widget should not display
75
+ */
76
+ render(context: RenderContext): Promise<string | null>;
77
+ /**
78
+ * Hook method for subclasses to implement rendering logic
79
+ *
80
+ * Called by render() template method with guaranteed non-null data.
81
+ *
82
+ * @param data - Stdin data (guaranteed to be non-null)
83
+ * @param context - Render context
84
+ * @returns Rendered string, or null if widget should not display
85
+ */
86
+ protected abstract renderWithData(data: StdinData, context: RenderContext): string | null;
87
+ /**
88
+ * Optional cleanup method
89
+ * Override if widget has resources to clean up
90
+ */
91
+ cleanup?(): Promise<void>;
92
+ }
93
+ //# sourceMappingURL=stdin-data-widget.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stdin-data-widget.d.ts","sourceRoot":"","sources":["../../../src/widgets/core/stdin-data-widget.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,KAAK,EAAE,OAAO,EAAE,eAAe,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAClG,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAEhD;;;;;;;;;;;;;;;;;;GAkBG;AACH,8BAAsB,eAAgB,YAAW,OAAO;IACtD;;OAEG;IACH,SAAS,CAAC,IAAI,EAAE,SAAS,GAAG,IAAI,CAAQ;IAExC;;OAEG;IACH,SAAS,CAAC,OAAO,UAAQ;IAEzB;;OAEG;IACH,QAAQ,CAAC,QAAQ,CAAC,EAAE,EAAE,MAAM,CAAC;IAE7B;;OAEG;IACH,QAAQ,CAAC,QAAQ,CAAC,QAAQ,EAAE,eAAe,CAAC;IAE5C;;;OAGG;IACG,UAAU,CAAC,OAAO,EAAE,aAAa,GAAG,OAAO,CAAC,IAAI,CAAC;IAIvD;;;OAGG;IACG,MAAM,CAAC,IAAI,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;IAI5C;;;;OAIG;IACH,OAAO,IAAI,SAAS;IAOpB;;;OAGG;IACH,SAAS,IAAI,OAAO;IAIpB;;;;;;;OAOG;IACG,MAAM,CAAC,OAAO,EAAE,aAAa,GAAG,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC;IAO5D;;;;;;;;OAQG;IACH,SAAS,CAAC,QAAQ,CAAC,cAAc,CAC/B,IAAI,EAAE,SAAS,EACf,OAAO,EAAE,aAAa,GACrB,MAAM,GAAG,IAAI;IAEhB;;;OAGG;IACG,OAAO,CAAC,IAAI,OAAO,CAAC,IAAI,CAAC;CAChC"}
@@ -0,0 +1,84 @@
1
+ /**
2
+ * Base class for widgets that receive StdinData
3
+ *
4
+ * Uses Template Method Pattern for state management.
5
+ *
6
+ * Extending widgets only need to implement renderWithData() method.
7
+ * The base class handles data storage, update logic, and enables checking.
8
+ */
9
+ /**
10
+ * Abstract base class for widgets working with StdinData
11
+ *
12
+ * Uses Template Method Pattern:
13
+ * - render() is final template method that handles null checks
14
+ * - Subclasses implement renderWithData() hook with data as parameter
15
+ *
16
+ * @example
17
+ * ```typescript
18
+ * export class ModelWidget extends StdinDataWidget {
19
+ * readonly id = 'model';
20
+ * readonly metadata = createWidgetMetadata('Model', 'Displays Claude model');
21
+ *
22
+ * protected renderWithData(data: StdinData, context: RenderContext): string | null {
23
+ * return data.model.display_name;
24
+ * }
25
+ * }
26
+ * ```
27
+ */
28
+ export class StdinDataWidget {
29
+ /**
30
+ * Stored stdin data from last update
31
+ */
32
+ data = null;
33
+ /**
34
+ * Widget enabled state
35
+ */
36
+ enabled = true;
37
+ /**
38
+ * Initialize widget with context
39
+ * @param context - Widget initialization context
40
+ */
41
+ async initialize(context) {
42
+ this.enabled = context.config?.enabled !== false;
43
+ }
44
+ /**
45
+ * Update widget with new stdin data
46
+ * @param data - Stdin data from Claude Code
47
+ */
48
+ async update(data) {
49
+ this.data = data;
50
+ }
51
+ /**
52
+ * Get stored stdin data
53
+ * @returns Stored stdin data
54
+ * @throws Error if data has not been initialized (update not called)
55
+ */
56
+ getData() {
57
+ if (!this.data) {
58
+ throw new Error(`Widget ${this.id} data not initialized. Call update() first.`);
59
+ }
60
+ return this.data;
61
+ }
62
+ /**
63
+ * Check if widget is enabled
64
+ * @returns true if widget should render
65
+ */
66
+ isEnabled() {
67
+ return this.enabled;
68
+ }
69
+ /**
70
+ * Template method - final, subclasses implement renderWithData()
71
+ *
72
+ * Handles null data checks and calls renderWithData() hook.
73
+ *
74
+ * @param context - Render context
75
+ * @returns Rendered string, or null if widget should not display
76
+ */
77
+ async render(context) {
78
+ if (!this.data || !this.enabled) {
79
+ return null;
80
+ }
81
+ return this.renderWithData(this.data, context);
82
+ }
83
+ }
84
+ //# sourceMappingURL=stdin-data-widget.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"stdin-data-widget.js","sourceRoot":"","sources":["../../../src/widgets/core/stdin-data-widget.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAKH;;;;;;;;;;;;;;;;;;GAkBG;AACH,MAAM,OAAgB,eAAe;IACnC;;OAEG;IACO,IAAI,GAAqB,IAAI,CAAC;IAExC;;OAEG;IACO,OAAO,GAAG,IAAI,CAAC;IAYzB;;;OAGG;IACH,KAAK,CAAC,UAAU,CAAC,OAAsB;QACrC,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC,MAAM,EAAE,OAAO,KAAK,KAAK,CAAC;IACnD,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,MAAM,CAAC,IAAe;QAC1B,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;IACnB,CAAC;IAED;;;;OAIG;IACH,OAAO;QACL,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC;YACf,MAAM,IAAI,KAAK,CAAC,UAAU,IAAI,CAAC,EAAE,6CAA6C,CAAC,CAAC;QAClF,CAAC;QACD,OAAO,IAAI,CAAC,IAAI,CAAC;IACnB,CAAC;IAED;;;OAGG;IACH,SAAS;QACP,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAED;;;;;;;OAOG;IACH,KAAK,CAAC,MAAM,CAAC,OAAsB;QACjC,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YAChC,OAAO,IAAI,CAAC;QACd,CAAC;QACD,OAAO,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;IACjD,CAAC;CAqBF"}
@@ -1,13 +1,13 @@
1
1
  /**
2
2
  * Cost Widget
3
3
  *
4
- * Displays session cost in USD
4
+ * Displays total session cost
5
5
  */
6
- import { StdinDataWidget } from '../core/stdin-data-widget.js';
7
- import type { RenderContext } from '../core/types.js';
6
+ import { StdinDataWidget } from './core/stdin-data-widget.js';
7
+ import type { RenderContext, StdinData } from '../types.js';
8
8
  export declare class CostWidget extends StdinDataWidget {
9
9
  readonly id = "cost";
10
10
  readonly metadata: import("../core/types.js").IWidgetMetadata;
11
- render(context: RenderContext): Promise<string | null>;
11
+ protected renderWithData(data: StdinData, context: RenderContext): string | null;
12
12
  }
13
13
  //# sourceMappingURL=cost-widget.d.ts.map