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.
- package/dist/core/renderer.d.ts +33 -3
- package/dist/core/renderer.d.ts.map +1 -1
- package/dist/core/renderer.js +48 -7
- package/dist/core/renderer.js.map +1 -1
- package/dist/data/stdin-provider.d.ts +44 -0
- package/dist/data/stdin-provider.d.ts.map +1 -0
- package/dist/data/stdin-provider.js +83 -0
- package/dist/data/stdin-provider.js.map +1 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +56 -64
- package/dist/index.js.map +1 -1
- package/dist/providers/git-provider.d.ts +53 -46
- package/dist/providers/git-provider.d.ts.map +1 -1
- package/dist/providers/git-provider.js +53 -107
- package/dist/providers/git-provider.js.map +1 -1
- package/dist/providers/stdin-provider.d.ts +16 -15
- package/dist/providers/stdin-provider.d.ts.map +1 -1
- package/dist/providers/stdin-provider.js +35 -66
- package/dist/providers/stdin-provider.js.map +1 -1
- package/dist/schemas/stdin-schema.d.ts +123 -0
- package/dist/schemas/stdin-schema.d.ts.map +1 -0
- package/dist/schemas/stdin-schema.js +81 -0
- package/dist/schemas/stdin-schema.js.map +1 -0
- package/dist/types.d.ts +6 -63
- package/dist/types.d.ts.map +1 -1
- package/dist/types.js +3 -0
- package/dist/types.js.map +1 -1
- package/dist/ui/utils/colors.d.ts +52 -0
- package/dist/ui/utils/colors.d.ts.map +1 -0
- package/dist/ui/utils/colors.js +54 -0
- package/dist/ui/utils/colors.js.map +1 -0
- package/dist/ui/utils/formatters.d.ts +56 -0
- package/dist/ui/utils/formatters.d.ts.map +1 -0
- package/dist/ui/utils/formatters.js +114 -0
- package/dist/ui/utils/formatters.js.map +1 -0
- package/dist/widgets/context-widget.d.ts +3 -3
- package/dist/widgets/context-widget.d.ts.map +1 -1
- package/dist/widgets/context-widget.js +9 -5
- package/dist/widgets/context-widget.js.map +1 -1
- package/dist/widgets/core/stdin-data-widget.d.ts +93 -0
- package/dist/widgets/core/stdin-data-widget.d.ts.map +1 -0
- package/dist/widgets/core/stdin-data-widget.js +84 -0
- package/dist/widgets/core/stdin-data-widget.js.map +1 -0
- package/dist/widgets/cost-widget.d.ts +4 -4
- package/dist/widgets/cost-widget.d.ts.map +1 -1
- package/dist/widgets/cost-widget.js +6 -5
- package/dist/widgets/cost-widget.js.map +1 -1
- package/dist/widgets/duration-widget.d.ts +3 -3
- package/dist/widgets/duration-widget.d.ts.map +1 -1
- package/dist/widgets/duration-widget.js +5 -4
- package/dist/widgets/duration-widget.js.map +1 -1
- package/dist/widgets/git/git-changes-widget.d.ts +38 -0
- package/dist/widgets/git/git-changes-widget.d.ts.map +1 -0
- package/dist/widgets/git/git-changes-widget.js +91 -0
- package/dist/widgets/git/git-changes-widget.js.map +1 -0
- package/dist/widgets/git/git-widget.d.ts +37 -0
- package/dist/widgets/git/git-widget.d.ts.map +1 -0
- package/dist/widgets/git/git-widget.js +67 -0
- package/dist/widgets/git/git-widget.js.map +1 -0
- package/dist/widgets/model-widget.d.ts +3 -3
- package/dist/widgets/model-widget.d.ts.map +1 -1
- package/dist/widgets/model-widget.js +2 -3
- package/dist/widgets/model-widget.js.map +1 -1
- 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
|
-
|
|
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
|
*/
|
package/dist/types.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA
|
|
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
package/dist/types.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.js","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA
|
|
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 '
|
|
7
|
-
import type { RenderContext } from '../
|
|
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
|
-
|
|
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,
|
|
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 '
|
|
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
|
-
|
|
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.
|
|
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,
|
|
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
|
|
4
|
+
* Displays total session cost
|
|
5
5
|
*/
|
|
6
|
-
import { StdinDataWidget } from '
|
|
7
|
-
import type { RenderContext } from '../
|
|
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
|
-
|
|
11
|
+
protected renderWithData(data: StdinData, context: RenderContext): string | null;
|
|
12
12
|
}
|
|
13
13
|
//# sourceMappingURL=cost-widget.d.ts.map
|