@yeshwanthyk/open-tui 0.1.0 → 0.1.1
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/app.d.ts +18 -0
- package/dist/app.d.ts.map +1 -0
- package/dist/app.jsx +28 -0
- package/dist/app.jsx.map +1 -0
- package/dist/autocomplete/autocomplete.d.ts +48 -0
- package/dist/autocomplete/autocomplete.d.ts.map +1 -0
- package/dist/autocomplete/autocomplete.js +391 -0
- package/dist/autocomplete/autocomplete.js.map +1 -0
- package/dist/autocomplete/file-index.d.ts +36 -0
- package/dist/autocomplete/file-index.d.ts.map +1 -0
- package/dist/autocomplete/file-index.js +143 -0
- package/dist/autocomplete/file-index.js.map +1 -0
- package/dist/autocomplete/index.d.ts +3 -0
- package/dist/autocomplete/index.d.ts.map +1 -0
- package/dist/autocomplete/index.js +3 -0
- package/dist/autocomplete/index.js.map +1 -0
- package/dist/components/badge.d.ts +11 -0
- package/dist/components/badge.d.ts.map +1 -0
- package/dist/components/badge.jsx +31 -0
- package/dist/components/badge.jsx.map +1 -0
- package/dist/components/code-block.d.ts +12 -0
- package/dist/components/code-block.d.ts.map +1 -0
- package/dist/components/code-block.jsx +34 -0
- package/dist/components/code-block.jsx.map +1 -0
- package/dist/components/dialog.d.ts +12 -0
- package/dist/components/dialog.d.ts.map +1 -0
- package/dist/components/dialog.jsx +29 -0
- package/dist/components/dialog.jsx.map +1 -0
- package/dist/components/diff.d.ts +11 -0
- package/dist/components/diff.d.ts.map +1 -0
- package/dist/components/diff.jsx +17 -0
- package/dist/components/diff.jsx.map +1 -0
- package/dist/components/divider.d.ts +9 -0
- package/dist/components/divider.d.ts.map +1 -0
- package/dist/components/divider.jsx +13 -0
- package/dist/components/divider.jsx.map +1 -0
- package/dist/components/editor.d.ts +87 -0
- package/dist/components/editor.d.ts.map +1 -0
- package/dist/components/editor.jsx +146 -0
- package/dist/components/editor.jsx.map +1 -0
- package/dist/components/image.d.ts +65 -0
- package/dist/components/image.d.ts.map +1 -0
- package/dist/components/image.jsx +319 -0
- package/dist/components/image.jsx.map +1 -0
- package/dist/components/loader.d.ts +25 -0
- package/dist/components/loader.d.ts.map +1 -0
- package/dist/components/loader.jsx +31 -0
- package/dist/components/loader.jsx.map +1 -0
- package/dist/components/markdown.d.ts +28 -0
- package/dist/components/markdown.d.ts.map +1 -0
- package/dist/components/markdown.jsx +30 -0
- package/dist/components/markdown.jsx.map +1 -0
- package/dist/components/panel.d.ts +12 -0
- package/dist/components/panel.d.ts.map +1 -0
- package/dist/components/panel.jsx +51 -0
- package/dist/components/panel.jsx.map +1 -0
- package/dist/components/select-list.d.ts +55 -0
- package/dist/components/select-list.d.ts.map +1 -0
- package/dist/components/select-list.jsx +135 -0
- package/dist/components/select-list.jsx.map +1 -0
- package/dist/components/spacer.d.ts +25 -0
- package/dist/components/spacer.d.ts.map +1 -0
- package/dist/components/spacer.jsx +27 -0
- package/dist/components/spacer.jsx.map +1 -0
- package/dist/components/toast.d.ts +19 -0
- package/dist/components/toast.d.ts.map +1 -0
- package/dist/components/toast.jsx +52 -0
- package/dist/components/toast.jsx.map +1 -0
- package/dist/context/terminal.d.ts +7 -0
- package/dist/context/terminal.d.ts.map +1 -0
- package/dist/context/terminal.jsx +6 -0
- package/dist/context/terminal.jsx.map +1 -0
- package/dist/context/theme.d.ts +117 -0
- package/dist/context/theme.d.ts.map +1 -0
- package/dist/context/theme.jsx +650 -0
- package/dist/context/theme.jsx.map +1 -0
- package/dist/hooks/use-keyboard.d.ts +7 -0
- package/dist/hooks/use-keyboard.d.ts.map +1 -0
- package/dist/hooks/use-keyboard.js +6 -0
- package/dist/hooks/use-keyboard.js.map +1 -0
- package/dist/index.d.ts +31 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +45 -0
- package/dist/index.js.map +1 -0
- package/dist/opentui-augmentations.d.ts +9 -0
- package/dist/opentui-augmentations.d.ts.map +1 -0
- package/dist/opentui-augmentations.js +1 -0
- package/dist/opentui-augmentations.js.map +1 -0
- package/dist/parsers-config.d.ts +16 -0
- package/dist/parsers-config.d.ts.map +1 -0
- package/dist/parsers-config.js +119 -0
- package/dist/parsers-config.js.map +1 -0
- package/dist/themes/aura.json +69 -0
- package/dist/themes/ayu.json +80 -0
- package/dist/themes/catppuccin-macchiato.json +233 -0
- package/dist/themes/catppuccin.json +112 -0
- package/dist/themes/cobalt2.json +228 -0
- package/dist/themes/dracula.json +219 -0
- package/dist/themes/everforest.json +241 -0
- package/dist/themes/flexoki.json +237 -0
- package/dist/themes/github.json +233 -0
- package/dist/themes/gruvbox.json +95 -0
- package/dist/themes/kanagawa.json +77 -0
- package/dist/themes/lucent-orng.json +227 -0
- package/dist/themes/marvin.json +97 -0
- package/dist/themes/material.json +235 -0
- package/dist/themes/matrix.json +77 -0
- package/dist/themes/mercury.json +245 -0
- package/dist/themes/monokai.json +221 -0
- package/dist/themes/nightowl.json +221 -0
- package/dist/themes/nord.json +223 -0
- package/dist/themes/one-dark.json +84 -0
- package/dist/themes/opencode.json +245 -0
- package/dist/themes/orng.json +245 -0
- package/dist/themes/palenight.json +222 -0
- package/dist/themes/rosepine.json +234 -0
- package/dist/themes/solarized.json +223 -0
- package/dist/themes/synthwave84.json +226 -0
- package/dist/themes/tokyonight.json +243 -0
- package/dist/themes/vercel.json +245 -0
- package/dist/themes/vesper.json +218 -0
- package/dist/themes/zenburn.json +223 -0
- package/dist/utils/clipboard.d.ts +12 -0
- package/dist/utils/clipboard.d.ts.map +1 -0
- package/dist/utils/clipboard.js +52 -0
- package/dist/utils/clipboard.js.map +1 -0
- package/dist/utils/text-width.d.ts +26 -0
- package/dist/utils/text-width.d.ts.map +1 -0
- package/dist/utils/text-width.js +101 -0
- package/dist/utils/text-width.js.map +1 -0
- package/package.json +13 -4
- package/src/index.ts +0 -121
|
@@ -0,0 +1,143 @@
|
|
|
1
|
+
import { spawn } from "child_process";
|
|
2
|
+
import fuzzysort from "fuzzysort";
|
|
3
|
+
import { dirname } from "path";
|
|
4
|
+
/**
|
|
5
|
+
* Fast file index using ripgrep for listing and fuzzysort for matching.
|
|
6
|
+
* Respects .gitignore by default.
|
|
7
|
+
*/
|
|
8
|
+
export class FileIndex {
|
|
9
|
+
cwd;
|
|
10
|
+
files = [];
|
|
11
|
+
indexing = false;
|
|
12
|
+
indexed = false;
|
|
13
|
+
pendingCallbacks = [];
|
|
14
|
+
searchItemsFilesOnly = [];
|
|
15
|
+
searchItemsWithDirs = [];
|
|
16
|
+
lastRefreshTime = 0;
|
|
17
|
+
staleTime;
|
|
18
|
+
constructor(options) {
|
|
19
|
+
this.cwd = options.cwd;
|
|
20
|
+
this.staleTime = options.staleTime ?? 5_000; // Default 5s - short for quick file visibility
|
|
21
|
+
if (!options.lazy) {
|
|
22
|
+
this.refresh().catch(() => { });
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
async refresh() {
|
|
26
|
+
if (this.indexing) {
|
|
27
|
+
return new Promise((resolve) => {
|
|
28
|
+
this.pendingCallbacks.push(resolve);
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
this.indexing = true;
|
|
32
|
+
const files = [];
|
|
33
|
+
const dirs = new Set();
|
|
34
|
+
try {
|
|
35
|
+
await new Promise((resolve) => {
|
|
36
|
+
const proc = spawn("rg", ["--files", "--follow", "--hidden", "--glob=!.git/*"], {
|
|
37
|
+
cwd: this.cwd,
|
|
38
|
+
stdio: ["ignore", "pipe", "ignore"],
|
|
39
|
+
});
|
|
40
|
+
let buffer = "";
|
|
41
|
+
proc.stdout.on("data", (chunk) => {
|
|
42
|
+
buffer += chunk.toString();
|
|
43
|
+
const lines = buffer.split("\n");
|
|
44
|
+
buffer = lines.pop() || "";
|
|
45
|
+
for (const line of lines) {
|
|
46
|
+
if (line) {
|
|
47
|
+
files.push(line);
|
|
48
|
+
let current = line;
|
|
49
|
+
while (true) {
|
|
50
|
+
const dir = dirname(current);
|
|
51
|
+
if (dir === "." || dir === current)
|
|
52
|
+
break;
|
|
53
|
+
current = dir;
|
|
54
|
+
if (dirs.has(dir))
|
|
55
|
+
break;
|
|
56
|
+
dirs.add(dir);
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
});
|
|
61
|
+
proc.on("close", () => {
|
|
62
|
+
if (buffer) {
|
|
63
|
+
files.push(buffer);
|
|
64
|
+
let current = buffer;
|
|
65
|
+
while (true) {
|
|
66
|
+
const dir = dirname(current);
|
|
67
|
+
if (dir === "." || dir === current)
|
|
68
|
+
break;
|
|
69
|
+
current = dir;
|
|
70
|
+
if (dirs.has(dir))
|
|
71
|
+
break;
|
|
72
|
+
dirs.add(dir);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
resolve();
|
|
76
|
+
});
|
|
77
|
+
proc.on("error", () => {
|
|
78
|
+
resolve();
|
|
79
|
+
});
|
|
80
|
+
});
|
|
81
|
+
this.files = files;
|
|
82
|
+
this.searchItemsFilesOnly = files.map((f) => ({ path: f, isDirectory: false }));
|
|
83
|
+
this.searchItemsWithDirs = [
|
|
84
|
+
...this.searchItemsFilesOnly,
|
|
85
|
+
...Array.from(dirs, (dir) => ({ path: dir + "/", isDirectory: true })),
|
|
86
|
+
];
|
|
87
|
+
this.indexed = true;
|
|
88
|
+
this.lastRefreshTime = Date.now();
|
|
89
|
+
}
|
|
90
|
+
finally {
|
|
91
|
+
this.indexing = false;
|
|
92
|
+
for (const cb of this.pendingCallbacks) {
|
|
93
|
+
cb();
|
|
94
|
+
}
|
|
95
|
+
this.pendingCallbacks = [];
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
search(query, options) {
|
|
99
|
+
const limit = options?.limit ?? 20;
|
|
100
|
+
const includeDirs = options?.includeDirs ?? true;
|
|
101
|
+
if (!this.indexed && !this.indexing) {
|
|
102
|
+
this.refresh().catch(() => { });
|
|
103
|
+
return [];
|
|
104
|
+
}
|
|
105
|
+
// Trigger background refresh if stale (doesn't block current search)
|
|
106
|
+
if (this.indexed && !this.indexing && Date.now() - this.lastRefreshTime > this.staleTime) {
|
|
107
|
+
this.refresh().catch(() => { });
|
|
108
|
+
}
|
|
109
|
+
if (!this.indexed) {
|
|
110
|
+
return [];
|
|
111
|
+
}
|
|
112
|
+
const items = includeDirs ? this.searchItemsWithDirs : this.searchItemsFilesOnly;
|
|
113
|
+
if (!query) {
|
|
114
|
+
return items.slice(0, limit).map((item) => ({
|
|
115
|
+
path: item.path,
|
|
116
|
+
isDirectory: item.isDirectory,
|
|
117
|
+
score: 0,
|
|
118
|
+
}));
|
|
119
|
+
}
|
|
120
|
+
const results = fuzzysort.go(query, items, {
|
|
121
|
+
key: "path",
|
|
122
|
+
limit,
|
|
123
|
+
threshold: 0.2,
|
|
124
|
+
});
|
|
125
|
+
return results
|
|
126
|
+
.filter((r) => r.obj?.path != null)
|
|
127
|
+
.map((r) => ({
|
|
128
|
+
path: r.obj.path,
|
|
129
|
+
isDirectory: r.obj.isDirectory,
|
|
130
|
+
score: r.score,
|
|
131
|
+
}));
|
|
132
|
+
}
|
|
133
|
+
get fileCount() {
|
|
134
|
+
return this.files.length;
|
|
135
|
+
}
|
|
136
|
+
get isIndexing() {
|
|
137
|
+
return this.indexing;
|
|
138
|
+
}
|
|
139
|
+
get isReady() {
|
|
140
|
+
return this.indexed;
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
//# sourceMappingURL=file-index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"file-index.js","sourceRoot":"","sources":["../../src/autocomplete/file-index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/autocomplete/index.ts"],"names":[],"mappings":"AAAA,OAAO,EACN,KAAK,gBAAgB,EACrB,KAAK,oBAAoB,EACzB,4BAA4B,EAC5B,KAAK,YAAY,GACjB,MAAM,mBAAmB,CAAC;AAC3B,OAAO,EAAE,SAAS,EAAE,KAAK,gBAAgB,EAAE,KAAK,gBAAgB,EAAE,MAAM,iBAAiB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/autocomplete/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAGN,4BAA4B,GAE5B,MAAM,mBAAmB,CAAC;AAC3B,OAAO,EAAE,SAAS,EAAgD,MAAM,iBAAiB,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { JSX } from "@opentui/solid";
|
|
2
|
+
import { type RGBA } from "../context/theme.js";
|
|
3
|
+
export type BadgeVariant = "neutral" | "info" | "success" | "warning" | "error";
|
|
4
|
+
export type BadgeProps = Omit<JSX.IntrinsicElements["box"], "children"> & {
|
|
5
|
+
label: string;
|
|
6
|
+
variant?: BadgeVariant;
|
|
7
|
+
fg?: RGBA;
|
|
8
|
+
bg?: RGBA;
|
|
9
|
+
};
|
|
10
|
+
export declare function Badge(props: BadgeProps): JSX.Element;
|
|
11
|
+
//# sourceMappingURL=badge.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"badge.d.ts","sourceRoot":"","sources":["../../src/components/badge.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAA;AAGzC,OAAO,EAAY,KAAK,IAAI,EAAE,MAAM,qBAAqB,CAAA;AAEzD,MAAM,MAAM,YAAY,GAAG,SAAS,GAAG,MAAM,GAAG,SAAS,GAAG,SAAS,GAAG,OAAO,CAAA;AAE/E,MAAM,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,CAAC,iBAAiB,CAAC,KAAK,CAAC,EAAE,UAAU,CAAC,GAAG;IACzE,KAAK,EAAE,MAAM,CAAA;IACb,OAAO,CAAC,EAAE,YAAY,CAAA;IACtB,EAAE,CAAC,EAAE,IAAI,CAAA;IACT,EAAE,CAAC,EAAE,IAAI,CAAA;CACT,CAAA;AAED,wBAAgB,KAAK,CAAC,KAAK,EAAE,UAAU,GAAG,GAAG,CAAC,OAAO,CAwCpD"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { splitProps } from "solid-js";
|
|
2
|
+
import { TextAttributes } from "@opentui/core";
|
|
3
|
+
import { useTheme } from "../context/theme.js";
|
|
4
|
+
export function Badge(props) {
|
|
5
|
+
const { theme } = useTheme();
|
|
6
|
+
const [local, rest] = splitProps(props, ["label", "variant", "fg", "bg"]);
|
|
7
|
+
const resolvedFg = () => {
|
|
8
|
+
if (local.fg)
|
|
9
|
+
return local.fg;
|
|
10
|
+
switch (local.variant ?? "neutral") {
|
|
11
|
+
case "info":
|
|
12
|
+
return theme.info;
|
|
13
|
+
case "success":
|
|
14
|
+
return theme.success;
|
|
15
|
+
case "warning":
|
|
16
|
+
return theme.warning;
|
|
17
|
+
case "error":
|
|
18
|
+
return theme.error;
|
|
19
|
+
case "neutral":
|
|
20
|
+
default:
|
|
21
|
+
return theme.textMuted;
|
|
22
|
+
}
|
|
23
|
+
};
|
|
24
|
+
const resolvedBg = () => local.bg ?? theme.backgroundElement;
|
|
25
|
+
return (<box backgroundColor={resolvedBg()} border borderColor={theme.borderSubtle} paddingLeft={1} paddingRight={1} paddingTop={0} paddingBottom={0} flexShrink={0} {...rest}>
|
|
26
|
+
<text fg={resolvedFg()} attributes={TextAttributes.BOLD}>
|
|
27
|
+
{local.label}
|
|
28
|
+
</text>
|
|
29
|
+
</box>);
|
|
30
|
+
}
|
|
31
|
+
//# sourceMappingURL=badge.jsx.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"badge.jsx","sourceRoot":"","sources":["../../src/components/badge.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAA;AACrC,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAA;AAC9C,OAAO,EAAE,QAAQ,EAAa,MAAM,qBAAqB,CAAA;AAWzD,MAAM,UAAU,KAAK,CAAC,KAAiB;IACtC,MAAM,EAAE,KAAK,EAAE,GAAG,QAAQ,EAAE,CAAA;IAC5B,MAAM,CAAC,KAAK,EAAE,IAAI,CAAC,GAAG,UAAU,CAAC,KAAK,EAAE,CAAC,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC,CAAA;IAEzE,MAAM,UAAU,GAAG,GAAS,EAAE;QAC7B,IAAI,KAAK,CAAC,EAAE;YAAE,OAAO,KAAK,CAAC,EAAE,CAAA;QAC7B,QAAQ,KAAK,CAAC,OAAO,IAAI,SAAS,EAAE,CAAC;YACpC,KAAK,MAAM;gBACV,OAAO,KAAK,CAAC,IAAI,CAAA;YAClB,KAAK,SAAS;gBACb,OAAO,KAAK,CAAC,OAAO,CAAA;YACrB,KAAK,SAAS;gBACb,OAAO,KAAK,CAAC,OAAO,CAAA;YACrB,KAAK,OAAO;gBACX,OAAO,KAAK,CAAC,KAAK,CAAA;YACnB,KAAK,SAAS,CAAC;YACf;gBACC,OAAO,KAAK,CAAC,SAAS,CAAA;QACxB,CAAC;IACF,CAAC,CAAA;IAED,MAAM,UAAU,GAAG,GAAS,EAAE,CAAC,KAAK,CAAC,EAAE,IAAI,KAAK,CAAC,iBAAiB,CAAA;IAElE,OAAO,CACN,CAAC,GAAG,CACH,eAAe,CAAC,CAAC,UAAU,EAAE,CAAC,CAC9B,MAAM,CACN,WAAW,CAAC,CAAC,KAAK,CAAC,YAAY,CAAC,CAChC,WAAW,CAAC,CAAC,CAAC,CAAC,CACf,YAAY,CAAC,CAAC,CAAC,CAAC,CAChB,UAAU,CAAC,CAAC,CAAC,CAAC,CACd,aAAa,CAAC,CAAC,CAAC,CAAC,CACjB,UAAU,CAAC,CAAC,CAAC,CAAC,CACd,IAAI,IAAI,CAAC,CAET;GAAA,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,UAAU,EAAE,CAAC,CAAC,UAAU,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,CACvD;IAAA,CAAC,KAAK,CAAC,KAAK,CACb;GAAA,EAAE,IAAI,CACP;EAAA,EAAE,GAAG,CAAC,CACN,CAAA;AACF,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { JSX } from "@opentui/solid";
|
|
2
|
+
export type CodeBlockProps = Omit<JSX.IntrinsicElements["box"], "children"> & {
|
|
3
|
+
content: string;
|
|
4
|
+
filetype?: string;
|
|
5
|
+
title?: string;
|
|
6
|
+
showLineNumbers?: boolean;
|
|
7
|
+
wrapMode?: "word" | "char" | "none";
|
|
8
|
+
streaming?: boolean;
|
|
9
|
+
conceal?: boolean;
|
|
10
|
+
};
|
|
11
|
+
export declare function CodeBlock(props: CodeBlockProps): JSX.Element;
|
|
12
|
+
//# sourceMappingURL=code-block.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"code-block.d.ts","sourceRoot":"","sources":["../../src/components/code-block.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAA;AAIzC,MAAM,MAAM,cAAc,GAAG,IAAI,CAAC,GAAG,CAAC,iBAAiB,CAAC,KAAK,CAAC,EAAE,UAAU,CAAC,GAAG;IAC7E,OAAO,EAAE,MAAM,CAAA;IACf,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,eAAe,CAAC,EAAE,OAAO,CAAA;IACzB,QAAQ,CAAC,EAAE,MAAM,GAAG,MAAM,GAAG,MAAM,CAAA;IACnC,SAAS,CAAC,EAAE,OAAO,CAAA;IACnB,OAAO,CAAC,EAAE,OAAO,CAAA;CACjB,CAAA;AAED,wBAAgB,SAAS,CAAC,KAAK,EAAE,cAAc,GAAG,GAAG,CAAC,OAAO,CA8D5D"}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { getTreeSitterClient } from "@opentui/core";
|
|
2
|
+
import { Show, createSignal, splitProps } from "solid-js";
|
|
3
|
+
import { useTheme } from "../context/theme.js";
|
|
4
|
+
export function CodeBlock(props) {
|
|
5
|
+
const { theme, syntaxStyle } = useTheme();
|
|
6
|
+
const [local, rest] = splitProps(props, [
|
|
7
|
+
"content",
|
|
8
|
+
"filetype",
|
|
9
|
+
"title",
|
|
10
|
+
"showLineNumbers",
|
|
11
|
+
"wrapMode",
|
|
12
|
+
"streaming",
|
|
13
|
+
"conceal",
|
|
14
|
+
]);
|
|
15
|
+
const [codeRef, setCodeRef] = createSignal(undefined);
|
|
16
|
+
const showLineNumbers = () => local.showLineNumbers ?? true;
|
|
17
|
+
// Minimal: no border, subtle bg tint
|
|
18
|
+
return (<box flexDirection="column" backgroundColor={theme.backgroundElement} paddingLeft={1} paddingRight={1} {...rest}>
|
|
19
|
+
<Show when={local.title}>
|
|
20
|
+
<box flexDirection="row" alignItems="center" gap={1} paddingBottom={1}>
|
|
21
|
+
<text fg={theme.textMuted}>
|
|
22
|
+
{local.title}
|
|
23
|
+
</text>
|
|
24
|
+
</box>
|
|
25
|
+
</Show>
|
|
26
|
+
<box flexDirection="row">
|
|
27
|
+
<Show when={showLineNumbers() && codeRef()}>
|
|
28
|
+
{(ref) => (<line_number target={ref()} fg={theme.diffLineNumberFg} bg={theme.diffLineNumberBg} paddingRight={1} flexShrink={0}/>)}
|
|
29
|
+
</Show>
|
|
30
|
+
<code ref={setCodeRef} content={local.content} filetype={local.filetype ?? "text"} syntaxStyle={syntaxStyle} treeSitterClient={getTreeSitterClient()} wrapMode={local.wrapMode ?? "word"} streaming={local.streaming ?? false} conceal={local.conceal ?? false} drawUnstyledText selectionBg={theme.selectionBg} selectionFg={theme.selectionFg} width="100%" height="100%"/>
|
|
31
|
+
</box>
|
|
32
|
+
</box>);
|
|
33
|
+
}
|
|
34
|
+
//# sourceMappingURL=code-block.jsx.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"code-block.jsx","sourceRoot":"","sources":["../../src/components/code-block.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,mBAAmB,EAAE,MAAM,eAAe,CAAA;AAEnD,OAAO,EAAE,IAAI,EAAE,YAAY,EAAE,UAAU,EAAiB,MAAM,UAAU,CAAA;AACxE,OAAO,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAA;AAY9C,MAAM,UAAU,SAAS,CAAC,KAAqB;IAC9C,MAAM,EAAE,KAAK,EAAE,WAAW,EAAE,GAAG,QAAQ,EAAE,CAAA;IACzC,MAAM,CAAC,KAAK,EAAE,IAAI,CAAC,GAAG,UAAU,CAAC,KAAK,EAAE;QACvC,SAAS;QACT,UAAU;QACV,OAAO;QACP,iBAAiB;QACjB,UAAU;QACV,WAAW;QACX,SAAS;KACT,CAAC,CAAA;IAEF,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,YAAY,CAA6B,SAAS,CAAC,CAAA;IAEjF,MAAM,eAAe,GAAG,GAAG,EAAE,CAAC,KAAK,CAAC,eAAe,IAAI,IAAI,CAAA;IAE3D,qCAAqC;IACrC,OAAO,CACN,CAAC,GAAG,CACH,aAAa,CAAC,QAAQ,CACtB,eAAe,CAAC,CAAC,KAAK,CAAC,iBAAiB,CAAC,CACzC,WAAW,CAAC,CAAC,CAAC,CAAC,CACf,YAAY,CAAC,CAAC,CAAC,CAAC,CAChB,IAAI,IAAI,CAAC,CAET;GAAA,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CACvB;IAAA,CAAC,GAAG,CAAC,aAAa,CAAC,KAAK,CAAC,UAAU,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CACrE;KAAA,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,SAAS,CAAC,CACzB;MAAA,CAAC,KAAK,CAAC,KAAK,CACb;KAAA,EAAE,IAAI,CACP;IAAA,EAAE,GAAG,CACN;GAAA,EAAE,IAAI,CACN;GAAA,CAAC,GAAG,CAAC,aAAa,CAAC,KAAK,CACvB;IAAA,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,eAAe,EAAE,IAAI,OAAO,EAAE,CAAC,CAC1C;KAAA,CAAC,CAAC,GAA6B,EAAE,EAAE,CAAC,CACnC,CAAC,WAAW,CACX,MAAM,CAAC,CAAC,GAAG,EAAE,CAAC,CACd,EAAE,CAAC,CAAC,KAAK,CAAC,gBAAgB,CAAC,CAC3B,EAAE,CAAC,CAAC,KAAK,CAAC,gBAAgB,CAAC,CAC3B,YAAY,CAAC,CAAC,CAAC,CAAC,CAChB,UAAU,CAAC,CAAC,CAAC,CAAC,EACb,CACF,CACF;IAAA,EAAE,IAAI,CACN;IAAA,CAAC,IAAI,CACJ,GAAG,CAAC,CAAC,UAAU,CAAC,CAChB,OAAO,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CACvB,QAAQ,CAAC,CAAC,KAAK,CAAC,QAAQ,IAAI,MAAM,CAAC,CACnC,WAAW,CAAC,CAAC,WAAW,CAAC,CACzB,gBAAgB,CAAC,CAAC,mBAAmB,EAAE,CAAC,CACxC,QAAQ,CAAC,CAAC,KAAK,CAAC,QAAQ,IAAI,MAAM,CAAC,CACnC,SAAS,CAAC,CAAC,KAAK,CAAC,SAAS,IAAI,KAAK,CAAC,CACpC,OAAO,CAAC,CAAC,KAAK,CAAC,OAAO,IAAI,KAAK,CAAC,CAChC,gBAAgB,CAChB,WAAW,CAAC,CAAC,KAAK,CAAC,WAAW,CAAC,CAC/B,WAAW,CAAC,CAAC,KAAK,CAAC,WAAW,CAAC,CAC/B,KAAK,CAAC,MAAM,CACZ,MAAM,CAAC,MAAM,EAEf;GAAA,EAAE,GAAG,CACN;EAAA,EAAE,GAAG,CAAC,CACN,CAAA;AACF,CAAC"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type { JSX } from "@opentui/solid";
|
|
2
|
+
import { type RGBA } from "../context/theme.js";
|
|
3
|
+
export type DialogProps = Omit<JSX.IntrinsicElements["box"], "children"> & {
|
|
4
|
+
open: boolean;
|
|
5
|
+
title?: string;
|
|
6
|
+
borderColor?: RGBA;
|
|
7
|
+
closeOnOverlayClick?: boolean;
|
|
8
|
+
onClose?: () => void;
|
|
9
|
+
children?: JSX.Element;
|
|
10
|
+
};
|
|
11
|
+
export declare function Dialog(props: DialogProps): JSX.Element;
|
|
12
|
+
//# sourceMappingURL=dialog.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dialog.d.ts","sourceRoot":"","sources":["../../src/components/dialog.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAA;AAGzC,OAAO,EAAY,KAAK,IAAI,EAAE,MAAM,qBAAqB,CAAA;AAGzD,MAAM,MAAM,WAAW,GAAG,IAAI,CAAC,GAAG,CAAC,iBAAiB,CAAC,KAAK,CAAC,EAAE,UAAU,CAAC,GAAG;IAC1E,IAAI,EAAE,OAAO,CAAA;IACb,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,WAAW,CAAC,EAAE,IAAI,CAAA;IAClB,mBAAmB,CAAC,EAAE,OAAO,CAAA;IAC7B,OAAO,CAAC,EAAE,MAAM,IAAI,CAAA;IACpB,QAAQ,CAAC,EAAE,GAAG,CAAC,OAAO,CAAA;CACtB,CAAA;AAED,wBAAgB,MAAM,CAAC,KAAK,EAAE,WAAW,GAAG,GAAG,CAAC,OAAO,CA0CtD"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { Show, splitProps } from "solid-js";
|
|
2
|
+
import { TextAttributes } from "@opentui/core";
|
|
3
|
+
import { useTheme } from "../context/theme.js";
|
|
4
|
+
import { Panel } from "./panel.js";
|
|
5
|
+
export function Dialog(props) {
|
|
6
|
+
const { theme } = useTheme();
|
|
7
|
+
const [local, rest] = splitProps(props, ["open", "title", "borderColor", "closeOnOverlayClick", "onClose", "children"]);
|
|
8
|
+
return (<Show when={local.open}>
|
|
9
|
+
<box position="absolute" top={0} left={0} width="100%" height="100%" zIndex={900}>
|
|
10
|
+
<box position="absolute" top={0} left={0} width="100%" height="100%" backgroundColor={theme.background} opacity={0.8} onMouseUp={() => {
|
|
11
|
+
if (local.closeOnOverlayClick === false)
|
|
12
|
+
return;
|
|
13
|
+
local.onClose?.();
|
|
14
|
+
}}/>
|
|
15
|
+
<box position="absolute" top="15%" left="15%" width="70%" maxHeight="70%" zIndex={901} {...rest}>
|
|
16
|
+
<Panel variant="panel" borderColor={local.borderColor ?? theme.borderActive} paddingX={2} paddingY={1}>
|
|
17
|
+
<Show when={local.title}>
|
|
18
|
+
<text fg={theme.text} attributes={TextAttributes.BOLD}>
|
|
19
|
+
{local.title}
|
|
20
|
+
</text>
|
|
21
|
+
<box height={1}/>
|
|
22
|
+
</Show>
|
|
23
|
+
{local.children}
|
|
24
|
+
</Panel>
|
|
25
|
+
</box>
|
|
26
|
+
</box>
|
|
27
|
+
</Show>);
|
|
28
|
+
}
|
|
29
|
+
//# sourceMappingURL=dialog.jsx.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dialog.jsx","sourceRoot":"","sources":["../../src/components/dialog.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,IAAI,EAAE,UAAU,EAAE,MAAM,UAAU,CAAA;AAC3C,OAAO,EAAE,cAAc,EAAE,MAAM,eAAe,CAAA;AAC9C,OAAO,EAAE,QAAQ,EAAa,MAAM,qBAAqB,CAAA;AACzD,OAAO,EAAE,KAAK,EAAE,MAAM,YAAY,CAAA;AAWlC,MAAM,UAAU,MAAM,CAAC,KAAkB;IACxC,MAAM,EAAE,KAAK,EAAE,GAAG,QAAQ,EAAE,CAAA;IAC5B,MAAM,CAAC,KAAK,EAAE,IAAI,CAAC,GAAG,UAAU,CAAC,KAAK,EAAE,CAAC,MAAM,EAAE,OAAO,EAAE,aAAa,EAAE,qBAAqB,EAAE,SAAS,EAAE,UAAU,CAAC,CAAC,CAAA;IAEvH,OAAO,CACN,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CACtB;GAAA,CAAC,GAAG,CAAC,QAAQ,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,CAChF;IAAA,CAAC,GAAG,CACH,QAAQ,CAAC,UAAU,CACnB,GAAG,CAAC,CAAC,CAAC,CAAC,CACP,IAAI,CAAC,CAAC,CAAC,CAAC,CACR,KAAK,CAAC,MAAM,CACZ,MAAM,CAAC,MAAM,CACb,eAAe,CAAC,CAAC,KAAK,CAAC,UAAU,CAAC,CAClC,OAAO,CAAC,CAAC,GAAG,CAAC,CACb,SAAS,CAAC,CAAC,GAAG,EAAE;YACf,IAAI,KAAK,CAAC,mBAAmB,KAAK,KAAK;gBAAE,OAAM;YAC/C,KAAK,CAAC,OAAO,EAAE,EAAE,CAAA;QAClB,CAAC,CAAC,EAEH;IAAA,CAAC,GAAG,CACH,QAAQ,CAAC,UAAU,CACnB,GAAG,CAAC,KAAK,CACT,IAAI,CAAC,KAAK,CACV,KAAK,CAAC,KAAK,CACX,SAAS,CAAC,KAAK,CACf,MAAM,CAAC,CAAC,GAAG,CAAC,CACZ,IAAI,IAAI,CAAC,CAET;KAAA,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,KAAK,CAAC,WAAW,IAAI,KAAK,CAAC,YAAY,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CACrG;MAAA,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CACvB;OAAA,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,UAAU,CAAC,CAAC,cAAc,CAAC,IAAI,CAAC,CACrD;QAAA,CAAC,KAAK,CAAC,KAAK,CACb;OAAA,EAAE,IAAI,CACN;OAAA,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAChB;MAAA,EAAE,IAAI,CACN;MAAA,CAAC,KAAK,CAAC,QAAQ,CAChB;KAAA,EAAE,KAAK,CACR;IAAA,EAAE,GAAG,CACN;GAAA,EAAE,GAAG,CACN;EAAA,EAAE,IAAI,CAAC,CACP,CAAA;AACF,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { JSX } from "@opentui/solid";
|
|
2
|
+
export type DiffView = "auto" | "unified" | "split";
|
|
3
|
+
export type DiffWrapMode = "word" | "char" | "none";
|
|
4
|
+
export type DiffProps = Omit<JSX.IntrinsicElements["diff"], "diff" | "view" | "filetype" | "syntaxStyle" | "treeSitterClient"> & {
|
|
5
|
+
diffText: string;
|
|
6
|
+
filetype?: string;
|
|
7
|
+
view?: DiffView;
|
|
8
|
+
wrapMode?: DiffWrapMode;
|
|
9
|
+
};
|
|
10
|
+
export declare function Diff(props: DiffProps): JSX.Element;
|
|
11
|
+
//# sourceMappingURL=diff.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"diff.d.ts","sourceRoot":"","sources":["../../src/components/diff.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAA;AAMzC,MAAM,MAAM,QAAQ,GAAG,MAAM,GAAG,SAAS,GAAG,OAAO,CAAA;AAEnD,MAAM,MAAM,YAAY,GAAG,MAAM,GAAG,MAAM,GAAG,MAAM,CAAA;AAEnD,MAAM,MAAM,SAAS,GAAG,IAAI,CAAC,GAAG,CAAC,iBAAiB,CAAC,MAAM,CAAC,EAAE,MAAM,GAAG,MAAM,GAAG,UAAU,GAAG,aAAa,GAAG,kBAAkB,CAAC,GAAG;IAChI,QAAQ,EAAE,MAAM,CAAA;IAChB,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,IAAI,CAAC,EAAE,QAAQ,CAAA;IACf,QAAQ,CAAC,EAAE,YAAY,CAAA;CACvB,CAAA;AAED,wBAAgB,IAAI,CAAC,KAAK,EAAE,SAAS,GAAG,GAAG,CAAC,OAAO,CAqClD"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { splitProps } from "solid-js";
|
|
2
|
+
import { getTreeSitterClient } from "@opentui/core";
|
|
3
|
+
import { useTerminalDimensions } from "../context/terminal.js";
|
|
4
|
+
import { useTheme } from "../context/theme.js";
|
|
5
|
+
export function Diff(props) {
|
|
6
|
+
const dimensions = useTerminalDimensions();
|
|
7
|
+
const { theme, syntaxStyle } = useTheme();
|
|
8
|
+
const [local, rest] = splitProps(props, ["diffText", "filetype", "view", "wrapMode"]);
|
|
9
|
+
const computedView = () => {
|
|
10
|
+
const requested = local.view ?? "auto";
|
|
11
|
+
if (requested === "unified" || requested === "split")
|
|
12
|
+
return requested;
|
|
13
|
+
return dimensions().width > 120 ? "split" : "unified";
|
|
14
|
+
};
|
|
15
|
+
return (<diff diff={local.diffText} view={computedView()} filetype={local.filetype ?? "text"} wrapMode={local.wrapMode ?? "word"} syntaxStyle={syntaxStyle} treeSitterClient={getTreeSitterClient()} showLineNumbers lineNumberFg={theme.diffLineNumberFg} lineNumberBg={theme.diffLineNumberBg} addedBg={theme.diffAddedBg} removedBg={theme.diffRemovedBg} contextBg={theme.diffContextBg} addedContentBg={theme.diffHighlightAddedBg} removedContentBg={theme.diffHighlightRemovedBg} addedSignColor={theme.diffAddedSign} removedSignColor={theme.diffRemovedSign} addedLineNumberBg={theme.diffAddedLineNumberBg} removedLineNumberBg={theme.diffRemovedLineNumberBg} selectionBg={theme.selectionBg} selectionFg={theme.selectionFg} {...rest}/>);
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=diff.jsx.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"diff.jsx","sourceRoot":"","sources":["../../src/components/diff.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAA;AACrC,OAAO,EAAE,mBAAmB,EAAE,MAAM,eAAe,CAAA;AACnD,OAAO,EAAE,qBAAqB,EAAE,MAAM,wBAAwB,CAAA;AAC9D,OAAO,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAA;AAa9C,MAAM,UAAU,IAAI,CAAC,KAAgB;IACpC,MAAM,UAAU,GAAG,qBAAqB,EAAE,CAAA;IAC1C,MAAM,EAAE,KAAK,EAAE,WAAW,EAAE,GAAG,QAAQ,EAAE,CAAA;IAEzC,MAAM,CAAC,KAAK,EAAE,IAAI,CAAC,GAAG,UAAU,CAAC,KAAK,EAAE,CAAC,UAAU,EAAE,UAAU,EAAE,MAAM,EAAE,UAAU,CAAC,CAAC,CAAA;IAErF,MAAM,YAAY,GAAG,GAAwB,EAAE;QAC9C,MAAM,SAAS,GAAG,KAAK,CAAC,IAAI,IAAI,MAAM,CAAA;QACtC,IAAI,SAAS,KAAK,SAAS,IAAI,SAAS,KAAK,OAAO;YAAE,OAAO,SAAS,CAAA;QACtE,OAAO,UAAU,EAAE,CAAC,KAAK,GAAG,GAAG,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS,CAAA;IACtD,CAAC,CAAA;IAED,OAAO,CACN,CAAC,IAAI,CACJ,IAAI,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC,CACrB,IAAI,CAAC,CAAC,YAAY,EAAE,CAAC,CACrB,QAAQ,CAAC,CAAC,KAAK,CAAC,QAAQ,IAAI,MAAM,CAAC,CACnC,QAAQ,CAAC,CAAC,KAAK,CAAC,QAAQ,IAAI,MAAM,CAAC,CACnC,WAAW,CAAC,CAAC,WAAW,CAAC,CACzB,gBAAgB,CAAC,CAAC,mBAAmB,EAAE,CAAC,CACxC,eAAe,CACf,YAAY,CAAC,CAAC,KAAK,CAAC,gBAAgB,CAAC,CACrC,YAAY,CAAC,CAAC,KAAK,CAAC,gBAAgB,CAAC,CACrC,OAAO,CAAC,CAAC,KAAK,CAAC,WAAW,CAAC,CAC3B,SAAS,CAAC,CAAC,KAAK,CAAC,aAAa,CAAC,CAC/B,SAAS,CAAC,CAAC,KAAK,CAAC,aAAa,CAAC,CAC/B,cAAc,CAAC,CAAC,KAAK,CAAC,oBAAoB,CAAC,CAC3C,gBAAgB,CAAC,CAAC,KAAK,CAAC,sBAAsB,CAAC,CAC/C,cAAc,CAAC,CAAC,KAAK,CAAC,aAAa,CAAC,CACpC,gBAAgB,CAAC,CAAC,KAAK,CAAC,eAAe,CAAC,CACxC,iBAAiB,CAAC,CAAC,KAAK,CAAC,qBAAqB,CAAC,CAC/C,mBAAmB,CAAC,CAAC,KAAK,CAAC,uBAAuB,CAAC,CACnD,WAAW,CAAC,CAAC,KAAK,CAAC,WAAW,CAAC,CAC/B,WAAW,CAAC,CAAC,KAAK,CAAC,WAAW,CAAC,CAC/B,IAAI,IAAI,CAAC,EACR,CACF,CAAA;AACF,CAAC"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { JSX } from "@opentui/solid";
|
|
2
|
+
import { type RGBA } from "../context/theme.js";
|
|
3
|
+
export type DividerOrientation = "horizontal" | "vertical";
|
|
4
|
+
export type DividerProps = Omit<JSX.IntrinsicElements["box"], "children"> & {
|
|
5
|
+
orientation?: DividerOrientation;
|
|
6
|
+
color?: RGBA;
|
|
7
|
+
};
|
|
8
|
+
export declare function Divider(props: DividerProps): JSX.Element;
|
|
9
|
+
//# sourceMappingURL=divider.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"divider.d.ts","sourceRoot":"","sources":["../../src/components/divider.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAA;AAEzC,OAAO,EAAY,KAAK,IAAI,EAAE,MAAM,qBAAqB,CAAA;AAEzD,MAAM,MAAM,kBAAkB,GAAG,YAAY,GAAG,UAAU,CAAA;AAE1D,MAAM,MAAM,YAAY,GAAG,IAAI,CAAC,GAAG,CAAC,iBAAiB,CAAC,KAAK,CAAC,EAAE,UAAU,CAAC,GAAG;IAC3E,WAAW,CAAC,EAAE,kBAAkB,CAAA;IAChC,KAAK,CAAC,EAAE,IAAI,CAAA;CACZ,CAAA;AAED,wBAAgB,OAAO,CAAC,KAAK,EAAE,YAAY,GAAG,GAAG,CAAC,OAAO,CAYxD"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { splitProps } from "solid-js";
|
|
2
|
+
import { useTheme } from "../context/theme.js";
|
|
3
|
+
export function Divider(props) {
|
|
4
|
+
const { theme } = useTheme();
|
|
5
|
+
const [local, rest] = splitProps(props, ["orientation", "color"]);
|
|
6
|
+
const color = () => local.color ?? theme.borderSubtle;
|
|
7
|
+
const orientation = () => local.orientation ?? "horizontal";
|
|
8
|
+
if (orientation() === "vertical") {
|
|
9
|
+
return <box border={["left"]} borderColor={color()} width={1} height={rest.height ?? "100%"} flexShrink={0} {...rest}/>;
|
|
10
|
+
}
|
|
11
|
+
return <box border={["top"]} borderColor={color()} height={1} width={rest.width ?? "100%"} flexShrink={0} {...rest}/>;
|
|
12
|
+
}
|
|
13
|
+
//# sourceMappingURL=divider.jsx.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"divider.jsx","sourceRoot":"","sources":["../../src/components/divider.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAA;AACrC,OAAO,EAAE,QAAQ,EAAa,MAAM,qBAAqB,CAAA;AASzD,MAAM,UAAU,OAAO,CAAC,KAAmB;IAC1C,MAAM,EAAE,KAAK,EAAE,GAAG,QAAQ,EAAE,CAAA;IAC5B,MAAM,CAAC,KAAK,EAAE,IAAI,CAAC,GAAG,UAAU,CAAC,KAAK,EAAE,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC,CAAA;IAEjE,MAAM,KAAK,GAAG,GAAG,EAAE,CAAC,KAAK,CAAC,KAAK,IAAI,KAAK,CAAC,YAAY,CAAA;IACrD,MAAM,WAAW,GAAG,GAAG,EAAE,CAAC,KAAK,CAAC,WAAW,IAAI,YAAY,CAAA;IAE3D,IAAI,WAAW,EAAE,KAAK,UAAU,EAAE,CAAC;QAClC,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,MAAM,IAAI,MAAM,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,EAAG,CAAA;IACzH,CAAC;IAED,OAAO,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,KAAK,IAAI,MAAM,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,EAAG,CAAA;AACvH,CAAC"}
|
|
@@ -0,0 +1,87 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Editor component - wrapper around OpenTUI's TextareaRenderable
|
|
3
|
+
*
|
|
4
|
+
* Provides a multi-line text input with keyboard navigation, history,
|
|
5
|
+
* and autocomplete support.
|
|
6
|
+
*/
|
|
7
|
+
import { TextareaRenderable } from "@opentui/core";
|
|
8
|
+
import { type RGBA } from "../context/theme.js";
|
|
9
|
+
export interface EditorTheme {
|
|
10
|
+
border: RGBA;
|
|
11
|
+
borderActive: RGBA;
|
|
12
|
+
text: RGBA;
|
|
13
|
+
cursor: RGBA;
|
|
14
|
+
placeholder: RGBA;
|
|
15
|
+
background: RGBA;
|
|
16
|
+
}
|
|
17
|
+
export interface EditorProps {
|
|
18
|
+
/** Initial text content */
|
|
19
|
+
initialValue?: string;
|
|
20
|
+
/** Placeholder text when empty */
|
|
21
|
+
placeholder?: string;
|
|
22
|
+
/** Whether the editor is focused */
|
|
23
|
+
focused?: boolean;
|
|
24
|
+
/** Whether input is disabled */
|
|
25
|
+
disabled?: boolean;
|
|
26
|
+
/** Minimum height in lines */
|
|
27
|
+
minHeight?: number;
|
|
28
|
+
/** Maximum height in lines */
|
|
29
|
+
maxHeight?: number;
|
|
30
|
+
/** Optional width constraint */
|
|
31
|
+
width?: number | "auto" | `${number}%`;
|
|
32
|
+
/** Optional max width constraint */
|
|
33
|
+
maxWidth?: number | "auto" | `${number}%`;
|
|
34
|
+
/** Theme overrides */
|
|
35
|
+
theme?: Partial<EditorTheme>;
|
|
36
|
+
/** Called when content changes */
|
|
37
|
+
onChange?: (text: string) => void;
|
|
38
|
+
/** Called when Enter is pressed (submit) */
|
|
39
|
+
onSubmit?: (text: string) => void;
|
|
40
|
+
/** Called when Escape is pressed */
|
|
41
|
+
onEscape?: () => void;
|
|
42
|
+
/** Ref callback to get the textarea renderable */
|
|
43
|
+
ref?: (ref: EditorRef) => void;
|
|
44
|
+
}
|
|
45
|
+
export interface EditorRef {
|
|
46
|
+
/** Get current text content */
|
|
47
|
+
getText: () => string;
|
|
48
|
+
/** Set text content */
|
|
49
|
+
setText: (text: string) => void;
|
|
50
|
+
/** Clear the editor */
|
|
51
|
+
clear: () => void;
|
|
52
|
+
/** Focus the editor */
|
|
53
|
+
focus: () => void;
|
|
54
|
+
/** Blur the editor */
|
|
55
|
+
blur: () => void;
|
|
56
|
+
/** Get the underlying TextareaRenderable */
|
|
57
|
+
getTextarea: () => TextareaRenderable | undefined;
|
|
58
|
+
}
|
|
59
|
+
/**
|
|
60
|
+
* Editor component for multi-line text input
|
|
61
|
+
*/
|
|
62
|
+
export declare function Editor(props: EditorProps): any;
|
|
63
|
+
/**
|
|
64
|
+
* Simple single-line input component
|
|
65
|
+
*/
|
|
66
|
+
export interface InputProps {
|
|
67
|
+
/** Current value */
|
|
68
|
+
value?: string;
|
|
69
|
+
/** Placeholder text */
|
|
70
|
+
placeholder?: string;
|
|
71
|
+
/** Whether the input is focused */
|
|
72
|
+
focused?: boolean;
|
|
73
|
+
/** Called when value changes */
|
|
74
|
+
onChange?: (value: string) => void;
|
|
75
|
+
/** Called when Enter is pressed */
|
|
76
|
+
onSubmit?: (value: string) => void;
|
|
77
|
+
/** Called when Escape is pressed */
|
|
78
|
+
onEscape?: () => void;
|
|
79
|
+
/** Theme overrides */
|
|
80
|
+
theme?: Partial<EditorTheme>;
|
|
81
|
+
/** Optional width constraint */
|
|
82
|
+
width?: EditorProps["width"];
|
|
83
|
+
/** Optional max width constraint */
|
|
84
|
+
maxWidth?: EditorProps["maxWidth"];
|
|
85
|
+
}
|
|
86
|
+
export declare function Input(props: InputProps): any;
|
|
87
|
+
//# sourceMappingURL=editor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"editor.d.ts","sourceRoot":"","sources":["../../src/components/editor.tsx"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,OAAO,EAAE,kBAAkB,EAAiB,MAAM,eAAe,CAAA;AAEjE,OAAO,EAAE,KAAK,IAAI,EAAY,MAAM,qBAAqB,CAAA;AAEzD,MAAM,WAAW,WAAW;IAC3B,MAAM,EAAE,IAAI,CAAA;IACZ,YAAY,EAAE,IAAI,CAAA;IAClB,IAAI,EAAE,IAAI,CAAA;IACV,MAAM,EAAE,IAAI,CAAA;IACZ,WAAW,EAAE,IAAI,CAAA;IACjB,UAAU,EAAE,IAAI,CAAA;CAChB;AAED,MAAM,WAAW,WAAW;IAC3B,2BAA2B;IAC3B,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,kCAAkC;IAClC,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,oCAAoC;IACpC,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,gCAAgC;IAChC,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,8BAA8B;IAC9B,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,8BAA8B;IAC9B,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,gCAAgC;IAChC,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,GAAG,GAAG,MAAM,GAAG,CAAA;IACtC,oCAAoC;IACpC,QAAQ,CAAC,EAAE,MAAM,GAAG,MAAM,GAAG,GAAG,MAAM,GAAG,CAAA;IACzC,sBAAsB;IACtB,KAAK,CAAC,EAAE,OAAO,CAAC,WAAW,CAAC,CAAA;IAC5B,kCAAkC;IAClC,QAAQ,CAAC,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAA;IACjC,4CAA4C;IAC5C,QAAQ,CAAC,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAA;IACjC,oCAAoC;IACpC,QAAQ,CAAC,EAAE,MAAM,IAAI,CAAA;IACrB,kDAAkD;IAClD,GAAG,CAAC,EAAE,CAAC,GAAG,EAAE,SAAS,KAAK,IAAI,CAAA;CAC9B;AAED,MAAM,WAAW,SAAS;IACzB,+BAA+B;IAC/B,OAAO,EAAE,MAAM,MAAM,CAAA;IACrB,uBAAuB;IACvB,OAAO,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAA;IAC/B,uBAAuB;IACvB,KAAK,EAAE,MAAM,IAAI,CAAA;IACjB,uBAAuB;IACvB,KAAK,EAAE,MAAM,IAAI,CAAA;IACjB,sBAAsB;IACtB,IAAI,EAAE,MAAM,IAAI,CAAA;IAChB,4CAA4C;IAC5C,WAAW,EAAE,MAAM,kBAAkB,GAAG,SAAS,CAAA;CACjD;AAyBD;;GAEG;AACH,wBAAgB,MAAM,CAAC,KAAK,EAAE,WAAW,OAgGxC;AAED;;GAEG;AACH,MAAM,WAAW,UAAU;IAC1B,oBAAoB;IACpB,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,uBAAuB;IACvB,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,mCAAmC;IACnC,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,gCAAgC;IAChC,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAA;IAClC,mCAAmC;IACnC,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAA;IAClC,oCAAoC;IACpC,QAAQ,CAAC,EAAE,MAAM,IAAI,CAAA;IACrB,sBAAsB;IACtB,KAAK,CAAC,EAAE,OAAO,CAAC,WAAW,CAAC,CAAA;IAC5B,gCAAgC;IAChC,KAAK,CAAC,EAAE,WAAW,CAAC,OAAO,CAAC,CAAA;IAC5B,oCAAoC;IACpC,QAAQ,CAAC,EAAE,WAAW,CAAC,UAAU,CAAC,CAAA;CAClC;AAED,wBAAgB,KAAK,CAAC,KAAK,EAAE,UAAU,OAgBtC"}
|