@opentui/core 0.1.33 → 0.1.35
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/3d.js +1 -1
- package/{index-xqg0a6ka.js → index-n8nbvvhk.js} +50 -7
- package/{index-xqg0a6ka.js.map → index-n8nbvvhk.js.map} +6 -6
- package/index.js +173 -42
- package/index.js.map +8 -8
- package/package.json +7 -7
- package/renderables/Code.d.ts +12 -0
- package/renderables/EditBufferRenderable.d.ts +9 -1
- package/renderables/Input.d.ts +9 -1
- package/renderables/ScrollBox.d.ts +8 -2
- package/renderables/Select.d.ts +4 -1
- package/renderer.d.ts +4 -0
- package/testing/mock-tree-sitter-client.d.ts +20 -0
- package/testing.d.ts +1 -0
- package/testing.js +35 -2
- package/testing.js.map +4 -3
- package/types.d.ts +4 -0
- package/zig.d.ts +2 -0
package/package.json
CHANGED
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
"main": "index.js",
|
|
5
5
|
"types": "index.d.ts",
|
|
6
6
|
"type": "module",
|
|
7
|
-
"version": "0.1.
|
|
7
|
+
"version": "0.1.35",
|
|
8
8
|
"description": "OpenTUI is a TypeScript library for building terminal user interfaces (TUIs)",
|
|
9
9
|
"license": "MIT",
|
|
10
10
|
"repository": {
|
|
@@ -55,11 +55,11 @@
|
|
|
55
55
|
"bun-webgpu": "0.1.3",
|
|
56
56
|
"planck": "^1.4.2",
|
|
57
57
|
"three": "0.177.0",
|
|
58
|
-
"@opentui/core-darwin-x64": "0.1.
|
|
59
|
-
"@opentui/core-darwin-arm64": "0.1.
|
|
60
|
-
"@opentui/core-linux-x64": "0.1.
|
|
61
|
-
"@opentui/core-linux-arm64": "0.1.
|
|
62
|
-
"@opentui/core-win32-x64": "0.1.
|
|
63
|
-
"@opentui/core-win32-arm64": "0.1.
|
|
58
|
+
"@opentui/core-darwin-x64": "0.1.35",
|
|
59
|
+
"@opentui/core-darwin-arm64": "0.1.35",
|
|
60
|
+
"@opentui/core-linux-x64": "0.1.35",
|
|
61
|
+
"@opentui/core-linux-arm64": "0.1.35",
|
|
62
|
+
"@opentui/core-win32-x64": "0.1.35",
|
|
63
|
+
"@opentui/core-win32-arm64": "0.1.35"
|
|
64
64
|
}
|
|
65
65
|
}
|
package/renderables/Code.d.ts
CHANGED
|
@@ -2,6 +2,7 @@ import { type RenderContext } from "../types";
|
|
|
2
2
|
import { SyntaxStyle } from "../syntax-style";
|
|
3
3
|
import { TreeSitterClient } from "../lib/tree-sitter";
|
|
4
4
|
import { TextBufferRenderable, type TextBufferOptions } from "./TextBufferRenderable";
|
|
5
|
+
import type { OptimizedBuffer } from "../buffer";
|
|
5
6
|
export interface CodeOptions extends TextBufferOptions {
|
|
6
7
|
content?: string;
|
|
7
8
|
filetype?: string;
|
|
@@ -9,6 +10,7 @@ export interface CodeOptions extends TextBufferOptions {
|
|
|
9
10
|
treeSitterClient?: TreeSitterClient;
|
|
10
11
|
conceal?: boolean;
|
|
11
12
|
drawUnstyledText?: boolean;
|
|
13
|
+
streaming?: boolean;
|
|
12
14
|
}
|
|
13
15
|
export declare class CodeRenderable extends TextBufferRenderable {
|
|
14
16
|
private _content;
|
|
@@ -21,10 +23,15 @@ export declare class CodeRenderable extends TextBufferRenderable {
|
|
|
21
23
|
private _currentHighlightId;
|
|
22
24
|
private _conceal;
|
|
23
25
|
private _drawUnstyledText;
|
|
26
|
+
private _shouldRenderTextBuffer;
|
|
27
|
+
private _streaming;
|
|
28
|
+
private _hadInitialContent;
|
|
29
|
+
private _lastHighlights;
|
|
24
30
|
protected _contentDefaultOptions: {
|
|
25
31
|
content: string;
|
|
26
32
|
conceal: true;
|
|
27
33
|
drawUnstyledText: true;
|
|
34
|
+
streaming: false;
|
|
28
35
|
};
|
|
29
36
|
constructor(ctx: RenderContext, options: CodeOptions);
|
|
30
37
|
get content(): string;
|
|
@@ -37,9 +44,14 @@ export declare class CodeRenderable extends TextBufferRenderable {
|
|
|
37
44
|
set conceal(value: boolean);
|
|
38
45
|
get drawUnstyledText(): boolean;
|
|
39
46
|
set drawUnstyledText(value: boolean);
|
|
47
|
+
get streaming(): boolean;
|
|
48
|
+
set streaming(value: boolean);
|
|
49
|
+
get treeSitterClient(): TreeSitterClient;
|
|
50
|
+
set treeSitterClient(value: TreeSitterClient);
|
|
40
51
|
private scheduleUpdate;
|
|
41
52
|
private updateContent;
|
|
42
53
|
private fallback;
|
|
43
54
|
private createFallbackStyledText;
|
|
44
55
|
getLineHighlights(lineIdx: number): import("..").Highlight[];
|
|
56
|
+
protected renderSelf(buffer: OptimizedBuffer): void;
|
|
45
57
|
}
|
|
@@ -3,7 +3,7 @@ import { Selection, type LocalSelectionBounds } from "../lib/selection";
|
|
|
3
3
|
import { EditBuffer, type LogicalCursor } from "../edit-buffer";
|
|
4
4
|
import { EditorView, type VisualCursor } from "../editor-view";
|
|
5
5
|
import { RGBA } from "../lib/RGBA";
|
|
6
|
-
import {
|
|
6
|
+
import type { RenderContext, Highlight, CursorStyleOptions } from "../types";
|
|
7
7
|
import type { OptimizedBuffer } from "../buffer";
|
|
8
8
|
import type { SyntaxStyle } from "../syntax-style";
|
|
9
9
|
export interface CursorChangeEvent {
|
|
@@ -23,6 +23,7 @@ export interface EditBufferOptions extends RenderableOptions<EditBufferRenderabl
|
|
|
23
23
|
scrollMargin?: number;
|
|
24
24
|
showCursor?: boolean;
|
|
25
25
|
cursorColor?: string | RGBA;
|
|
26
|
+
cursorStyle?: CursorStyleOptions;
|
|
26
27
|
syntaxStyle?: SyntaxStyle;
|
|
27
28
|
tabIndicator?: string | number;
|
|
28
29
|
tabIndicatorColor?: string | RGBA;
|
|
@@ -41,6 +42,7 @@ export declare abstract class EditBufferRenderable extends Renderable {
|
|
|
41
42
|
protected _scrollMargin: number;
|
|
42
43
|
protected _showCursor: boolean;
|
|
43
44
|
protected _cursorColor: RGBA;
|
|
45
|
+
protected _cursorStyle: CursorStyleOptions;
|
|
44
46
|
protected lastLocalSelection: LocalSelectionBounds | null;
|
|
45
47
|
protected _tabIndicator?: string | number;
|
|
46
48
|
protected _tabIndicatorColor?: RGBA;
|
|
@@ -59,6 +61,10 @@ export declare abstract class EditBufferRenderable extends Renderable {
|
|
|
59
61
|
scrollMargin: number;
|
|
60
62
|
showCursor: true;
|
|
61
63
|
cursorColor: RGBA;
|
|
64
|
+
cursorStyle: {
|
|
65
|
+
style: "block";
|
|
66
|
+
blinking: true;
|
|
67
|
+
};
|
|
62
68
|
tabIndicator: undefined;
|
|
63
69
|
tabIndicatorColor: undefined;
|
|
64
70
|
};
|
|
@@ -85,6 +91,8 @@ export declare abstract class EditBufferRenderable extends Renderable {
|
|
|
85
91
|
set showCursor(value: boolean);
|
|
86
92
|
get cursorColor(): RGBA;
|
|
87
93
|
set cursorColor(value: RGBA | string);
|
|
94
|
+
get cursorStyle(): CursorStyleOptions;
|
|
95
|
+
set cursorStyle(style: CursorStyleOptions);
|
|
88
96
|
get tabIndicator(): string | number | undefined;
|
|
89
97
|
set tabIndicator(value: string | number | undefined);
|
|
90
98
|
get tabIndicatorColor(): RGBA | undefined;
|
package/renderables/Input.d.ts
CHANGED
|
@@ -2,7 +2,7 @@ import { OptimizedBuffer } from "../buffer";
|
|
|
2
2
|
import type { KeyEvent } from "../lib/KeyHandler";
|
|
3
3
|
import { type ColorInput } from "../lib/RGBA";
|
|
4
4
|
import { Renderable, type RenderableOptions } from "../Renderable";
|
|
5
|
-
import type { RenderContext } from "../types";
|
|
5
|
+
import type { RenderContext, CursorStyleOptions } from "../types";
|
|
6
6
|
export interface InputRenderableOptions extends RenderableOptions<InputRenderable> {
|
|
7
7
|
backgroundColor?: ColorInput;
|
|
8
8
|
textColor?: ColorInput;
|
|
@@ -11,6 +11,7 @@ export interface InputRenderableOptions extends RenderableOptions<InputRenderabl
|
|
|
11
11
|
placeholder?: string;
|
|
12
12
|
placeholderColor?: ColorInput;
|
|
13
13
|
cursorColor?: ColorInput;
|
|
14
|
+
cursorStyle?: CursorStyleOptions;
|
|
14
15
|
maxLength?: number;
|
|
15
16
|
value?: string;
|
|
16
17
|
}
|
|
@@ -30,6 +31,7 @@ export declare class InputRenderable extends Renderable {
|
|
|
30
31
|
private _focusedTextColor;
|
|
31
32
|
private _placeholderColor;
|
|
32
33
|
private _cursorColor;
|
|
34
|
+
private _cursorStyle;
|
|
33
35
|
private _maxLength;
|
|
34
36
|
private _lastCommittedValue;
|
|
35
37
|
protected _defaultOptions: {
|
|
@@ -40,6 +42,10 @@ export declare class InputRenderable extends Renderable {
|
|
|
40
42
|
placeholder: string;
|
|
41
43
|
placeholderColor: string;
|
|
42
44
|
cursorColor: string;
|
|
45
|
+
cursorStyle: {
|
|
46
|
+
style: "block";
|
|
47
|
+
blinking: true;
|
|
48
|
+
};
|
|
43
49
|
maxLength: number;
|
|
44
50
|
value: string;
|
|
45
51
|
};
|
|
@@ -64,6 +70,8 @@ export declare class InputRenderable extends Renderable {
|
|
|
64
70
|
set focusedTextColor(value: ColorInput);
|
|
65
71
|
set placeholderColor(value: ColorInput);
|
|
66
72
|
set cursorColor(value: ColorInput);
|
|
73
|
+
get cursorStyle(): CursorStyleOptions;
|
|
74
|
+
set cursorStyle(style: CursorStyleOptions);
|
|
67
75
|
updateFromLayout(): void;
|
|
68
76
|
protected onResize(width: number, height: number): void;
|
|
69
77
|
protected onRemove(): void;
|
|
@@ -8,7 +8,10 @@ import type { VNode } from "./composition/vnode";
|
|
|
8
8
|
import { ScrollBarRenderable, type ScrollBarOptions, type ScrollUnit } from "./ScrollBar";
|
|
9
9
|
declare class ContentRenderable extends BoxRenderable {
|
|
10
10
|
private viewport;
|
|
11
|
-
|
|
11
|
+
private _viewportCulling;
|
|
12
|
+
constructor(ctx: RenderContext, viewport: BoxRenderable, viewportCulling: boolean, options: RenderableOptions<BoxRenderable>);
|
|
13
|
+
get viewportCulling(): boolean;
|
|
14
|
+
set viewportCulling(value: boolean);
|
|
12
15
|
protected _getChildren(): Renderable[];
|
|
13
16
|
}
|
|
14
17
|
export interface ScrollBoxOptions extends BoxOptions<ScrollBoxRenderable> {
|
|
@@ -24,6 +27,7 @@ export interface ScrollBoxOptions extends BoxOptions<ScrollBoxRenderable> {
|
|
|
24
27
|
scrollX?: boolean;
|
|
25
28
|
scrollY?: boolean;
|
|
26
29
|
scrollAcceleration?: ScrollAcceleration;
|
|
30
|
+
viewportCulling?: boolean;
|
|
27
31
|
}
|
|
28
32
|
export declare class ScrollBoxRenderable extends BoxRenderable {
|
|
29
33
|
static idCounter: number;
|
|
@@ -66,7 +70,7 @@ export declare class ScrollBoxRenderable extends BoxRenderable {
|
|
|
66
70
|
get scrollHeight(): number;
|
|
67
71
|
private updateStickyState;
|
|
68
72
|
private applyStickyStart;
|
|
69
|
-
constructor(ctx: RenderContext, { wrapperOptions, viewportOptions, contentOptions, rootOptions, scrollbarOptions, verticalScrollbarOptions, horizontalScrollbarOptions, stickyScroll, stickyStart, scrollX, scrollY, scrollAcceleration, ...options }: ScrollBoxOptions);
|
|
73
|
+
constructor(ctx: RenderContext, { wrapperOptions, viewportOptions, contentOptions, rootOptions, scrollbarOptions, verticalScrollbarOptions, horizontalScrollbarOptions, stickyScroll, stickyStart, scrollX, scrollY, scrollAcceleration, viewportCulling, ...options }: ScrollBoxOptions);
|
|
70
74
|
protected onUpdate(deltaTime: number): void;
|
|
71
75
|
scrollBy(delta: number | {
|
|
72
76
|
x: number;
|
|
@@ -100,6 +104,8 @@ export declare class ScrollBoxRenderable extends BoxRenderable {
|
|
|
100
104
|
set horizontalScrollbarOptions(options: ScrollBoxOptions["horizontalScrollbarOptions"]);
|
|
101
105
|
get scrollAcceleration(): ScrollAcceleration;
|
|
102
106
|
set scrollAcceleration(value: ScrollAcceleration);
|
|
107
|
+
get viewportCulling(): boolean;
|
|
108
|
+
set viewportCulling(value: boolean);
|
|
103
109
|
protected destroySelf(): void;
|
|
104
110
|
}
|
|
105
111
|
export {};
|
package/renderables/Select.d.ts
CHANGED
|
@@ -15,6 +15,7 @@ export interface SelectRenderableOptions extends RenderableOptions<SelectRendera
|
|
|
15
15
|
focusedBackgroundColor?: ColorInput;
|
|
16
16
|
focusedTextColor?: ColorInput;
|
|
17
17
|
options?: SelectOption[];
|
|
18
|
+
selectedIndex?: number;
|
|
18
19
|
selectedBackgroundColor?: ColorInput;
|
|
19
20
|
selectedTextColor?: ColorInput;
|
|
20
21
|
descriptionColor?: ColorInput;
|
|
@@ -33,7 +34,7 @@ export declare enum SelectRenderableEvents {
|
|
|
33
34
|
export declare class SelectRenderable extends Renderable {
|
|
34
35
|
protected _focusable: boolean;
|
|
35
36
|
private _options;
|
|
36
|
-
private
|
|
37
|
+
private _selectedIndex;
|
|
37
38
|
private scrollOffset;
|
|
38
39
|
private maxVisibleItems;
|
|
39
40
|
private _backgroundColor;
|
|
@@ -59,6 +60,7 @@ export declare class SelectRenderable extends Renderable {
|
|
|
59
60
|
focusedTextColor: string;
|
|
60
61
|
selectedBackgroundColor: string;
|
|
61
62
|
selectedTextColor: string;
|
|
63
|
+
selectedIndex: number;
|
|
62
64
|
descriptionColor: string;
|
|
63
65
|
selectedDescriptionColor: string;
|
|
64
66
|
showScrollIndicator: false;
|
|
@@ -99,4 +101,5 @@ export declare class SelectRenderable extends Renderable {
|
|
|
99
101
|
set font(font: keyof typeof fonts);
|
|
100
102
|
set itemSpacing(spacing: number);
|
|
101
103
|
set fastScrollStep(step: number);
|
|
104
|
+
set selectedIndex(value: number);
|
|
102
105
|
}
|
package/renderer.d.ts
CHANGED
|
@@ -28,6 +28,7 @@ export interface CliRendererConfig {
|
|
|
28
28
|
experimental_splitHeight?: number;
|
|
29
29
|
useKittyKeyboard?: boolean;
|
|
30
30
|
backgroundColor?: ColorInput;
|
|
31
|
+
openConsoleOnError?: boolean;
|
|
31
32
|
}
|
|
32
33
|
export type PixelResolution = {
|
|
33
34
|
width: number;
|
|
@@ -151,6 +152,7 @@ export declare class CliRenderer extends EventEmitter implements RenderContext {
|
|
|
151
152
|
private _latestPointer;
|
|
152
153
|
private _currentFocusedRenderable;
|
|
153
154
|
private lifecyclePasses;
|
|
155
|
+
private _openConsoleOnError;
|
|
154
156
|
private handleError;
|
|
155
157
|
private dumpOutputCache;
|
|
156
158
|
private exitHandler;
|
|
@@ -183,6 +185,8 @@ export declare class CliRenderer extends EventEmitter implements RenderContext {
|
|
|
183
185
|
get liveRequestCount(): number;
|
|
184
186
|
get currentControlState(): string;
|
|
185
187
|
get capabilities(): any | null;
|
|
188
|
+
get useKittyKeyboard(): boolean;
|
|
189
|
+
set useKittyKeyboard(use: boolean);
|
|
186
190
|
set experimental_splitHeight(splitHeight: number);
|
|
187
191
|
private interceptStdoutWrite;
|
|
188
192
|
disableStdoutInterception(): void;
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { TreeSitterClient } from "../lib/tree-sitter";
|
|
2
|
+
import type { SimpleHighlight } from "../lib/tree-sitter/types";
|
|
3
|
+
export declare class MockTreeSitterClient extends TreeSitterClient {
|
|
4
|
+
private _highlightPromises;
|
|
5
|
+
private _mockResult;
|
|
6
|
+
constructor();
|
|
7
|
+
highlightOnce(content: string, filetype: string): Promise<{
|
|
8
|
+
highlights?: SimpleHighlight[];
|
|
9
|
+
warning?: string;
|
|
10
|
+
error?: string;
|
|
11
|
+
}>;
|
|
12
|
+
setMockResult(result: {
|
|
13
|
+
highlights?: SimpleHighlight[];
|
|
14
|
+
warning?: string;
|
|
15
|
+
error?: string;
|
|
16
|
+
}): void;
|
|
17
|
+
resolveHighlightOnce(index?: number): void;
|
|
18
|
+
resolveAllHighlightOnce(): void;
|
|
19
|
+
isHighlighting(): boolean;
|
|
20
|
+
}
|
package/testing.d.ts
CHANGED
package/testing.js
CHANGED
|
@@ -2,8 +2,9 @@
|
|
|
2
2
|
import {
|
|
3
3
|
ANSI,
|
|
4
4
|
CliRenderer,
|
|
5
|
+
TreeSitterClient,
|
|
5
6
|
resolveRenderLib
|
|
6
|
-
} from "./index-
|
|
7
|
+
} from "./index-n8nbvvhk.js";
|
|
7
8
|
|
|
8
9
|
// src/testing/mock-keys.ts
|
|
9
10
|
var KeyCodes = {
|
|
@@ -345,6 +346,37 @@ async function setupTestRenderer(config) {
|
|
|
345
346
|
const renderer = new CliRenderer(ziglib, rendererPtr, stdin, stdout, width, height, config);
|
|
346
347
|
return renderer;
|
|
347
348
|
}
|
|
349
|
+
// src/testing/mock-tree-sitter-client.ts
|
|
350
|
+
class MockTreeSitterClient extends TreeSitterClient {
|
|
351
|
+
_highlightPromises = [];
|
|
352
|
+
_mockResult = { highlights: [] };
|
|
353
|
+
constructor() {
|
|
354
|
+
super({ dataPath: "/tmp/mock" });
|
|
355
|
+
}
|
|
356
|
+
async highlightOnce(content, filetype) {
|
|
357
|
+
const { promise, resolve } = Promise.withResolvers();
|
|
358
|
+
this._highlightPromises.push({ promise, resolve });
|
|
359
|
+
return promise;
|
|
360
|
+
}
|
|
361
|
+
setMockResult(result) {
|
|
362
|
+
this._mockResult = result;
|
|
363
|
+
}
|
|
364
|
+
resolveHighlightOnce(index = 0) {
|
|
365
|
+
if (index >= 0 && index < this._highlightPromises.length) {
|
|
366
|
+
this._highlightPromises[index].resolve(this._mockResult);
|
|
367
|
+
this._highlightPromises.splice(index, 1);
|
|
368
|
+
}
|
|
369
|
+
}
|
|
370
|
+
resolveAllHighlightOnce() {
|
|
371
|
+
for (const { resolve } of this._highlightPromises) {
|
|
372
|
+
resolve(this._mockResult);
|
|
373
|
+
}
|
|
374
|
+
this._highlightPromises = [];
|
|
375
|
+
}
|
|
376
|
+
isHighlighting() {
|
|
377
|
+
return this._highlightPromises.length > 0;
|
|
378
|
+
}
|
|
379
|
+
}
|
|
348
380
|
// src/testing/spy.ts
|
|
349
381
|
function createSpy() {
|
|
350
382
|
const calls = [];
|
|
@@ -365,8 +397,9 @@ export {
|
|
|
365
397
|
createMockMouse,
|
|
366
398
|
createMockKeys,
|
|
367
399
|
MouseButtons,
|
|
400
|
+
MockTreeSitterClient,
|
|
368
401
|
KeyCodes
|
|
369
402
|
};
|
|
370
403
|
|
|
371
|
-
//# debugId=
|
|
404
|
+
//# debugId=334F11C8682F8A0A64756E2164756E21
|
|
372
405
|
//# sourceMappingURL=testing.js.map
|
package/testing.js.map
CHANGED
|
@@ -1,13 +1,14 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
|
-
"sources": ["../src/testing/mock-keys.ts", "../src/testing/mock-mouse.ts", "../src/testing/test-renderer.ts", "../src/testing/spy.ts"],
|
|
3
|
+
"sources": ["../src/testing/mock-keys.ts", "../src/testing/mock-mouse.ts", "../src/testing/test-renderer.ts", "../src/testing/mock-tree-sitter-client.ts", "../src/testing/spy.ts"],
|
|
4
4
|
"sourcesContent": [
|
|
5
5
|
"import type { CliRenderer } from \"../renderer\"\nimport { ANSI } from \"../ansi\"\n\nexport const KeyCodes = {\n // Control keys\n RETURN: \"\\r\",\n LINEFEED: \"\\n\",\n TAB: \"\\t\",\n BACKSPACE: \"\\b\",\n // NOTE: This may depend on the platform and terminals\n DELETE: \"\\x1b[3~\",\n HOME: \"\\x1b[H\",\n END: \"\\x1b[F\",\n ESCAPE: \"\\x1b\",\n\n // Arrow keys\n ARROW_UP: \"\\x1b[A\",\n ARROW_DOWN: \"\\x1b[B\",\n ARROW_RIGHT: \"\\x1b[C\",\n ARROW_LEFT: \"\\x1b[D\",\n\n // Function keys\n F1: \"\\x1bOP\",\n F2: \"\\x1bOQ\",\n F3: \"\\x1bOR\",\n F4: \"\\x1bOS\",\n F5: \"\\x1b[15~\",\n F6: \"\\x1b[17~\",\n F7: \"\\x1b[18~\",\n F8: \"\\x1b[19~\",\n F9: \"\\x1b[20~\",\n F10: \"\\x1b[21~\",\n F11: \"\\x1b[23~\",\n F12: \"\\x1b[24~\",\n} as const\n\nexport type KeyInput = string | keyof typeof KeyCodes\n\nexport function createMockKeys(renderer: CliRenderer) {\n const pressKeys = async (keys: KeyInput[], delayMs: number = 0): Promise<void> => {\n for (const key of keys) {\n let keyCode: string\n if (typeof key === \"string\") {\n // If it's a string but also exists in KeyCodes, use the KeyCodes value\n if (key in KeyCodes) {\n keyCode = KeyCodes[key as keyof typeof KeyCodes]\n } else {\n keyCode = key\n }\n } else {\n // It's a KeyCode enum value\n keyCode = KeyCodes[key]\n if (!keyCode) {\n throw new Error(`Unknown key: ${key}`)\n }\n }\n\n renderer.stdin.emit(\"data\", Buffer.from(keyCode))\n\n if (delayMs > 0) {\n await new Promise((resolve) => setTimeout(resolve, delayMs))\n }\n }\n }\n\n const pressKey = (key: KeyInput, modifiers?: { shift?: boolean; ctrl?: boolean; meta?: boolean }): void => {\n let keyCode: string\n if (typeof key === \"string\") {\n // If it's a string but also exists in KeyCodes, use the KeyCodes value\n if (key in KeyCodes) {\n keyCode = KeyCodes[key as keyof typeof KeyCodes]\n } else {\n keyCode = key\n }\n } else {\n // This branch handles KeyCode enum values (though they're strings at runtime)\n keyCode = KeyCodes[key]\n if (!keyCode) {\n throw new Error(`Unknown key: ${key}`)\n }\n }\n\n // Apply modifiers if present\n if (modifiers) {\n // For arrow keys and special keys, modify the escape sequence\n if (keyCode.startsWith(\"\\x1b[\") && keyCode.length > 2) {\n // Arrow keys: \\x1b[A, \\x1b[B, \\x1b[C, \\x1b[D\n // With shift modifier: \\x1b[1;2A, \\x1b[1;2B, \\x1b[1;2C, \\x1b[1;2D\n const modifier = 1 + (modifiers.shift ? 1 : 0) + (modifiers.meta ? 2 : 0) + (modifiers.ctrl ? 4 : 0)\n if (modifier > 1) {\n // Insert modifier into sequence\n const ending = keyCode.slice(-1)\n keyCode = `\\x1b[1;${modifier}${ending}`\n }\n } else if (keyCode.length === 1) {\n // For regular characters and single-char control codes with modifiers\n let char = keyCode\n\n // Handle ctrl modifier for characters\n if (modifiers.ctrl) {\n // Ctrl+letter produces control codes (0x01-0x1a for a-z)\n if (char >= \"a\" && char <= \"z\") {\n keyCode = String.fromCharCode(char.charCodeAt(0) - 96)\n } else if (char >= \"A\" && char <= \"Z\") {\n keyCode = String.fromCharCode(char.charCodeAt(0) - 64)\n }\n // If meta is also pressed, prefix with escape\n if (modifiers.meta) {\n keyCode = `\\x1b${keyCode}`\n }\n } else {\n // Handle shift+meta or just meta\n if (modifiers.shift && char >= \"a\" && char <= \"z\") {\n char = char.toUpperCase()\n }\n if (modifiers.meta) {\n // For meta+character (including control codes), prefix with escape\n keyCode = `\\x1b${char}`\n } else {\n keyCode = char\n }\n }\n } else if (modifiers.meta && !keyCode.startsWith(\"\\x1b\")) {\n // For multi-char sequences that aren't escape sequences (like simple control codes)\n // just prefix with escape for meta\n keyCode = `\\x1b${keyCode}`\n }\n }\n\n renderer.stdin.emit(\"data\", Buffer.from(keyCode))\n }\n\n const typeText = async (text: string, delayMs: number = 0): Promise<void> => {\n const keys = text.split(\"\")\n await pressKeys(keys, delayMs)\n }\n\n const pressReturn = (modifiers?: { shift?: boolean; ctrl?: boolean; meta?: boolean }): void => {\n pressKey(KeyCodes.RETURN, modifiers)\n }\n\n const pressEscape = (modifiers?: { shift?: boolean; ctrl?: boolean; meta?: boolean }): void => {\n pressKey(KeyCodes.ESCAPE, modifiers)\n }\n\n const pressTab = (modifiers?: { shift?: boolean; ctrl?: boolean; meta?: boolean }): void => {\n pressKey(KeyCodes.TAB, modifiers)\n }\n\n const pressBackspace = (modifiers?: { shift?: boolean; ctrl?: boolean; meta?: boolean }): void => {\n pressKey(KeyCodes.BACKSPACE, modifiers)\n }\n\n const pressArrow = (\n direction: \"up\" | \"down\" | \"left\" | \"right\",\n modifiers?: { shift?: boolean; ctrl?: boolean; meta?: boolean },\n ): void => {\n const keyMap = {\n up: KeyCodes.ARROW_UP,\n down: KeyCodes.ARROW_DOWN,\n left: KeyCodes.ARROW_LEFT,\n right: KeyCodes.ARROW_RIGHT,\n }\n pressKey(keyMap[direction], modifiers)\n }\n\n const pressCtrlC = (): void => {\n pressKey(\"c\", { ctrl: true })\n }\n\n const pasteBracketedText = (text: string): Promise<void> => {\n return pressKeys([ANSI.bracketedPasteStart, text, ANSI.bracketedPasteEnd])\n }\n\n return {\n pressKeys,\n pressKey,\n typeText,\n pressEnter: pressReturn,\n pressEscape,\n pressTab,\n pressBackspace,\n pressArrow,\n pressCtrlC,\n pasteBracketedText,\n }\n}\n",
|
|
6
6
|
"import type { CliRenderer } from \"../renderer\"\n\nexport const MouseButtons = {\n LEFT: 0,\n MIDDLE: 1,\n RIGHT: 2,\n\n WHEEL_UP: 64, // 64 = scroll flag + 0\n WHEEL_DOWN: 65, // 64 + 1\n WHEEL_LEFT: 66, // 64 + 2\n WHEEL_RIGHT: 67, // 64 + 3\n} as const\n\nexport type MouseButton = (typeof MouseButtons)[keyof typeof MouseButtons]\n\nexport interface MousePosition {\n x: number\n y: number\n}\n\nexport interface MouseModifiers {\n shift?: boolean\n alt?: boolean\n ctrl?: boolean\n}\n\nexport type MouseEventType = \"down\" | \"up\" | \"move\" | \"drag\" | \"scroll\"\n\nexport interface MouseEventOptions {\n button?: MouseButton\n modifiers?: MouseModifiers\n delayMs?: number\n}\n\nexport function createMockMouse(renderer: CliRenderer) {\n let currentPosition: MousePosition = { x: 0, y: 0 }\n let buttonsPressed = new Set<MouseButton>()\n\n // Generate SGR mouse event sequence\n const generateMouseEvent = (\n type: MouseEventType,\n x: number,\n y: number,\n button: MouseButton = MouseButtons.LEFT,\n modifiers: MouseModifiers = {},\n ): string => {\n // SGR format: \\x1b[<b;x;yM or \\x1b[<b;x;ym\n // where b = button code + modifier flags + motion/scroll flags\n\n let buttonCode: number = button\n\n // Add modifier flags\n if (modifiers.shift) buttonCode |= 4\n if (modifiers.alt) buttonCode |= 8\n if (modifiers.ctrl) buttonCode |= 16\n\n switch (type) {\n case \"move\":\n buttonCode = 32 | 3 // motion flag (32) + button 3 for motion without button press\n if (modifiers.shift) buttonCode |= 4\n if (modifiers.alt) buttonCode |= 8\n if (modifiers.ctrl) buttonCode |= 16\n break\n case \"drag\":\n buttonCode = (buttonsPressed.size > 0 ? Array.from(buttonsPressed)[0] : button) | 32\n if (modifiers.shift) buttonCode |= 4\n if (modifiers.alt) buttonCode |= 8\n if (modifiers.ctrl) buttonCode |= 16\n break\n case \"scroll\":\n // Scroll events already have the scroll flag set in the button code\n break\n }\n\n // Convert to 1-based coordinates for ANSI\n const ansiX = x + 1\n const ansiY = y + 1\n\n let pressRelease = \"M\" // Default to press\n if (type === \"up\" || type === \"move\" || type === \"drag\") {\n pressRelease = \"m\"\n }\n\n return `\\x1b[<${buttonCode};${ansiX};${ansiY}${pressRelease}`\n }\n\n const emitMouseEvent = async (\n type: MouseEventType,\n x: number,\n y: number,\n button: MouseButton = MouseButtons.LEFT,\n options: Omit<MouseEventOptions, \"button\"> = {},\n ): Promise<void> => {\n const { modifiers = {}, delayMs = 0 } = options\n\n const eventSequence = generateMouseEvent(type, x, y, button, modifiers)\n renderer.stdin.emit(\"data\", Buffer.from(eventSequence))\n\n currentPosition = { x, y }\n\n if (type === \"down\" && button < 64) {\n buttonsPressed.add(button)\n } else if (type === \"up\") {\n buttonsPressed.delete(button)\n }\n\n if (delayMs > 0) {\n await new Promise((resolve) => setTimeout(resolve, delayMs))\n }\n }\n\n const moveTo = async (x: number, y: number, options: MouseEventOptions = {}): Promise<void> => {\n const { button = MouseButtons.LEFT, delayMs = 0, modifiers = {} } = options\n\n if (buttonsPressed.size > 0) {\n await emitMouseEvent(\"drag\", x, y, Array.from(buttonsPressed)[0], { modifiers, delayMs })\n } else {\n await emitMouseEvent(\"move\", x, y, button, { modifiers, delayMs })\n }\n\n currentPosition = { x, y }\n }\n\n const click = async (\n x: number,\n y: number,\n button: MouseButton = MouseButtons.LEFT,\n options: MouseEventOptions = {},\n ): Promise<void> => {\n const { delayMs = 10, modifiers = {} } = options\n\n await emitMouseEvent(\"down\", x, y, button, { modifiers, delayMs })\n await new Promise((resolve) => setTimeout(resolve, delayMs))\n await emitMouseEvent(\"up\", x, y, button, { modifiers, delayMs })\n }\n\n const doubleClick = async (\n x: number,\n y: number,\n button: MouseButton = MouseButtons.LEFT,\n options: MouseEventOptions = {},\n ): Promise<void> => {\n const { delayMs = 10, modifiers = {} } = options\n\n await click(x, y, button, { modifiers, delayMs })\n await new Promise((resolve) => setTimeout(resolve, delayMs))\n await click(x, y, button, { modifiers, delayMs })\n }\n\n const pressDown = async (\n x: number,\n y: number,\n button: MouseButton = MouseButtons.LEFT,\n options: MouseEventOptions = {},\n ): Promise<void> => {\n const { modifiers = {}, delayMs = 0 } = options\n await emitMouseEvent(\"down\", x, y, button, { modifiers, delayMs })\n }\n\n const release = async (\n x: number,\n y: number,\n button: MouseButton = MouseButtons.LEFT,\n options: MouseEventOptions = {},\n ): Promise<void> => {\n const { modifiers = {}, delayMs = 0 } = options\n await emitMouseEvent(\"up\", x, y, button, { modifiers, delayMs })\n }\n\n const drag = async (\n startX: number,\n startY: number,\n endX: number,\n endY: number,\n button: MouseButton = MouseButtons.LEFT,\n options: MouseEventOptions = {},\n ): Promise<void> => {\n const { delayMs = 10, modifiers = {} } = options\n\n await pressDown(startX, startY, button, { modifiers })\n\n const steps = 5\n const dx = (endX - startX) / steps\n const dy = (endY - startY) / steps\n\n for (let i = 1; i <= steps; i++) {\n const currentX = Math.round(startX + dx * i)\n const currentY = Math.round(startY + dy * i)\n await emitMouseEvent(\"drag\", currentX, currentY, button, { modifiers, delayMs })\n }\n\n await release(endX, endY, button, { modifiers })\n }\n\n const scroll = async (\n x: number,\n y: number,\n direction: \"up\" | \"down\" | \"left\" | \"right\",\n options: MouseEventOptions = {},\n ): Promise<void> => {\n const { modifiers = {}, delayMs = 0 } = options\n\n let button: MouseButton\n switch (direction) {\n case \"up\":\n button = MouseButtons.WHEEL_UP\n break\n case \"down\":\n button = MouseButtons.WHEEL_DOWN\n break\n case \"left\":\n button = MouseButtons.WHEEL_LEFT\n break\n case \"right\":\n button = MouseButtons.WHEEL_RIGHT\n break\n }\n\n await emitMouseEvent(\"scroll\", x, y, button, { modifiers, delayMs })\n }\n\n const getCurrentPosition = (): MousePosition => {\n return { ...currentPosition }\n }\n\n const getPressedButtons = (): MouseButton[] => {\n return Array.from(buttonsPressed)\n }\n\n return {\n // Core interaction methods\n moveTo,\n click,\n doubleClick,\n pressDown,\n release,\n drag,\n scroll,\n\n // State getters\n getCurrentPosition,\n getPressedButtons,\n\n // Low-level event emission (for advanced use cases)\n emitMouseEvent,\n }\n}\n",
|
|
7
7
|
"import { CliRenderer, type CliRendererConfig } from \"../renderer\"\nimport { resolveRenderLib } from \"../zig\"\nimport { createMockKeys } from \"./mock-keys\"\nimport { createMockMouse } from \"./mock-mouse\"\n\nexport interface TestRendererOptions extends CliRendererConfig {\n width?: number\n height?: number\n}\nexport interface TestRenderer extends CliRenderer {}\nexport type MockInput = ReturnType<typeof createMockKeys>\nexport type MockMouse = ReturnType<typeof createMockMouse>\n\nconst decoder = new TextDecoder()\n\nexport async function createTestRenderer(options: TestRendererOptions): Promise<{\n renderer: TestRenderer\n mockInput: MockInput\n mockMouse: MockMouse\n renderOnce: () => Promise<void>\n captureCharFrame: () => string\n resize: (width: number, height: number) => void\n}> {\n process.env.OTUI_USE_CONSOLE = \"false\"\n const renderer = await setupTestRenderer({\n ...options,\n useAlternateScreen: false,\n useConsole: false,\n })\n\n renderer.disableStdoutInterception()\n\n const mockInput = createMockKeys(renderer)\n const mockMouse = createMockMouse(renderer)\n\n const renderOnce = async () => {\n //@ts-expect-error - this is a test renderer\n await renderer.loop()\n }\n\n return {\n renderer,\n mockInput,\n mockMouse,\n renderOnce,\n captureCharFrame: () => {\n const currentBuffer = renderer.currentRenderBuffer\n const frameBytes = currentBuffer.getRealCharBytes(true)\n return decoder.decode(frameBytes)\n },\n resize: (width: number, height: number) => {\n //@ts-expect-error - this is a test renderer\n renderer.processResize(width, height)\n },\n }\n}\n\nasync function setupTestRenderer(config: TestRendererOptions) {\n const stdin = config.stdin || process.stdin\n const stdout = config.stdout || process.stdout\n\n const width = config.width || stdout.columns || 80\n const height = config.height || stdout.rows || 24\n const renderHeight =\n config.experimental_splitHeight && config.experimental_splitHeight > 0 ? config.experimental_splitHeight : height\n\n const ziglib = resolveRenderLib()\n const rendererPtr = ziglib.createRenderer(width, renderHeight, { testing: true })\n if (!rendererPtr) {\n throw new Error(\"Failed to create test renderer\")\n }\n if (config.useThread === undefined) {\n config.useThread = true\n }\n\n if (process.platform === \"linux\") {\n config.useThread = false\n }\n ziglib.setUseThread(rendererPtr, config.useThread)\n\n const renderer = new CliRenderer(ziglib, rendererPtr, stdin, stdout, width, height, config)\n\n // Do not setup the terminal for testing as we will not actualy output anything to the terminal\n // await renderer.setupTerminal()\n\n return renderer\n}\n",
|
|
8
|
+
"import { TreeSitterClient } from \"../lib/tree-sitter\"\nimport type { SimpleHighlight } from \"../lib/tree-sitter/types\"\n\nexport class MockTreeSitterClient extends TreeSitterClient {\n private _highlightPromises: Array<{\n promise: Promise<{ highlights?: SimpleHighlight[]; warning?: string; error?: string }>\n resolve: (result: { highlights?: SimpleHighlight[]; warning?: string; error?: string }) => void\n }> = []\n private _mockResult: { highlights?: SimpleHighlight[]; warning?: string; error?: string } = { highlights: [] }\n\n constructor() {\n super({ dataPath: \"/tmp/mock\" })\n }\n\n async highlightOnce(\n content: string,\n filetype: string,\n ): Promise<{ highlights?: SimpleHighlight[]; warning?: string; error?: string }> {\n const { promise, resolve } = Promise.withResolvers<{\n highlights?: SimpleHighlight[]\n warning?: string\n error?: string\n }>()\n\n this._highlightPromises.push({ promise, resolve })\n\n return promise\n }\n\n setMockResult(result: { highlights?: SimpleHighlight[]; warning?: string; error?: string }) {\n this._mockResult = result\n }\n\n resolveHighlightOnce(index: number = 0) {\n if (index >= 0 && index < this._highlightPromises.length) {\n this._highlightPromises[index].resolve(this._mockResult)\n this._highlightPromises.splice(index, 1)\n }\n }\n\n resolveAllHighlightOnce() {\n for (const { resolve } of this._highlightPromises) {\n resolve(this._mockResult)\n }\n this._highlightPromises = []\n }\n\n isHighlighting(): boolean {\n return this._highlightPromises.length > 0\n }\n}\n",
|
|
8
9
|
"export function createSpy() {\n const calls: any[][] = []\n const spy = (...args: any[]) => {\n calls.push(args)\n }\n spy.calls = calls\n spy.callCount = () => calls.length\n spy.calledWith = (...expected: any[]) => {\n return calls.some((call) => JSON.stringify(call) === JSON.stringify(expected))\n }\n spy.reset = () => (calls.length = 0)\n return spy\n}\n"
|
|
9
10
|
],
|
|
10
|
-
"mappings": "
|
|
11
|
-
"debugId": "
|
|
11
|
+
"mappings": "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",
|
|
12
|
+
"debugId": "334F11C8682F8A0A64756E2164756E21",
|
|
12
13
|
"names": []
|
|
13
14
|
}
|
package/types.d.ts
CHANGED
|
@@ -15,6 +15,10 @@ export declare const TextAttributes: {
|
|
|
15
15
|
STRIKETHROUGH: number;
|
|
16
16
|
};
|
|
17
17
|
export type CursorStyle = "block" | "line" | "underline";
|
|
18
|
+
export interface CursorStyleOptions {
|
|
19
|
+
style: CursorStyle;
|
|
20
|
+
blinking: boolean;
|
|
21
|
+
}
|
|
18
22
|
export declare enum DebugOverlayCorner {
|
|
19
23
|
topLeft = 0,
|
|
20
24
|
topRight = 1,
|
package/zig.d.ts
CHANGED
|
@@ -84,6 +84,8 @@ export interface RenderLib {
|
|
|
84
84
|
disableMouse: (renderer: Pointer) => void;
|
|
85
85
|
enableKittyKeyboard: (renderer: Pointer, flags: number) => void;
|
|
86
86
|
disableKittyKeyboard: (renderer: Pointer) => void;
|
|
87
|
+
setUseKittyKeyboard: (renderer: Pointer, use: boolean) => void;
|
|
88
|
+
getUseKittyKeyboard: (renderer: Pointer) => boolean;
|
|
87
89
|
setupTerminal: (renderer: Pointer, useAlternateScreen: boolean) => void;
|
|
88
90
|
queryPixelResolution: (renderer: Pointer) => void;
|
|
89
91
|
createTextBuffer: (widthMethod: WidthMethod) => TextBuffer;
|