indusagi-coding-agent 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (240) hide show
  1. package/CHANGELOG.md +2249 -0
  2. package/README.md +546 -0
  3. package/dist/cli/args.js +282 -0
  4. package/dist/cli/config-selector.js +30 -0
  5. package/dist/cli/file-processor.js +78 -0
  6. package/dist/cli/list-models.js +91 -0
  7. package/dist/cli/session-picker.js +31 -0
  8. package/dist/cli.js +10 -0
  9. package/dist/config.js +158 -0
  10. package/dist/core/agent-session.js +2097 -0
  11. package/dist/core/auth-storage.js +278 -0
  12. package/dist/core/bash-executor.js +211 -0
  13. package/dist/core/compaction/branch-summarization.js +241 -0
  14. package/dist/core/compaction/compaction.js +606 -0
  15. package/dist/core/compaction/index.js +6 -0
  16. package/dist/core/compaction/utils.js +137 -0
  17. package/dist/core/diagnostics.js +1 -0
  18. package/dist/core/event-bus.js +24 -0
  19. package/dist/core/exec.js +70 -0
  20. package/dist/core/export-html/ansi-to-html.js +248 -0
  21. package/dist/core/export-html/index.js +221 -0
  22. package/dist/core/export-html/template.css +905 -0
  23. package/dist/core/export-html/template.html +54 -0
  24. package/dist/core/export-html/template.js +1549 -0
  25. package/dist/core/export-html/tool-renderer.js +56 -0
  26. package/dist/core/export-html/vendor/highlight.min.js +1213 -0
  27. package/dist/core/export-html/vendor/marked.min.js +6 -0
  28. package/dist/core/extensions/index.js +8 -0
  29. package/dist/core/extensions/loader.js +395 -0
  30. package/dist/core/extensions/runner.js +499 -0
  31. package/dist/core/extensions/types.js +31 -0
  32. package/dist/core/extensions/wrapper.js +101 -0
  33. package/dist/core/footer-data-provider.js +133 -0
  34. package/dist/core/index.js +8 -0
  35. package/dist/core/keybindings.js +140 -0
  36. package/dist/core/messages.js +122 -0
  37. package/dist/core/model-registry.js +454 -0
  38. package/dist/core/model-resolver.js +309 -0
  39. package/dist/core/package-manager.js +1142 -0
  40. package/dist/core/prompt-templates.js +250 -0
  41. package/dist/core/resource-loader.js +569 -0
  42. package/dist/core/sdk.js +225 -0
  43. package/dist/core/session-manager.js +1078 -0
  44. package/dist/core/settings-manager.js +430 -0
  45. package/dist/core/skills.js +339 -0
  46. package/dist/core/system-prompt.js +136 -0
  47. package/dist/core/timings.js +24 -0
  48. package/dist/core/tools/bash.js +226 -0
  49. package/dist/core/tools/edit-diff.js +242 -0
  50. package/dist/core/tools/edit.js +145 -0
  51. package/dist/core/tools/find.js +205 -0
  52. package/dist/core/tools/grep.js +238 -0
  53. package/dist/core/tools/index.js +60 -0
  54. package/dist/core/tools/ls.js +117 -0
  55. package/dist/core/tools/path-utils.js +52 -0
  56. package/dist/core/tools/read.js +165 -0
  57. package/dist/core/tools/truncate.js +204 -0
  58. package/dist/core/tools/write.js +77 -0
  59. package/dist/index.js +41 -0
  60. package/dist/main.js +565 -0
  61. package/dist/migrations.js +260 -0
  62. package/dist/modes/index.js +7 -0
  63. package/dist/modes/interactive/components/armin.js +328 -0
  64. package/dist/modes/interactive/components/assistant-message.js +86 -0
  65. package/dist/modes/interactive/components/bash-execution.js +155 -0
  66. package/dist/modes/interactive/components/bordered-loader.js +47 -0
  67. package/dist/modes/interactive/components/branch-summary-message.js +41 -0
  68. package/dist/modes/interactive/components/compaction-summary-message.js +42 -0
  69. package/dist/modes/interactive/components/config-selector.js +458 -0
  70. package/dist/modes/interactive/components/countdown-timer.js +27 -0
  71. package/dist/modes/interactive/components/custom-editor.js +61 -0
  72. package/dist/modes/interactive/components/custom-message.js +80 -0
  73. package/dist/modes/interactive/components/diff.js +132 -0
  74. package/dist/modes/interactive/components/dynamic-border.js +19 -0
  75. package/dist/modes/interactive/components/extension-editor.js +96 -0
  76. package/dist/modes/interactive/components/extension-input.js +54 -0
  77. package/dist/modes/interactive/components/extension-selector.js +70 -0
  78. package/dist/modes/interactive/components/footer.js +213 -0
  79. package/dist/modes/interactive/components/index.js +31 -0
  80. package/dist/modes/interactive/components/keybinding-hints.js +60 -0
  81. package/dist/modes/interactive/components/login-dialog.js +138 -0
  82. package/dist/modes/interactive/components/model-selector.js +253 -0
  83. package/dist/modes/interactive/components/oauth-selector.js +91 -0
  84. package/dist/modes/interactive/components/scoped-models-selector.js +262 -0
  85. package/dist/modes/interactive/components/session-selector-search.js +145 -0
  86. package/dist/modes/interactive/components/session-selector.js +698 -0
  87. package/dist/modes/interactive/components/settings-selector.js +250 -0
  88. package/dist/modes/interactive/components/show-images-selector.js +33 -0
  89. package/dist/modes/interactive/components/skill-invocation-message.js +44 -0
  90. package/dist/modes/interactive/components/theme-selector.js +43 -0
  91. package/dist/modes/interactive/components/thinking-selector.js +45 -0
  92. package/dist/modes/interactive/components/tool-execution.js +608 -0
  93. package/dist/modes/interactive/components/tree-selector.js +892 -0
  94. package/dist/modes/interactive/components/user-message-selector.js +109 -0
  95. package/dist/modes/interactive/components/user-message.js +15 -0
  96. package/dist/modes/interactive/components/visual-truncate.js +32 -0
  97. package/dist/modes/interactive/interactive-mode.js +3576 -0
  98. package/dist/modes/interactive/theme/dark.json +85 -0
  99. package/dist/modes/interactive/theme/light.json +84 -0
  100. package/dist/modes/interactive/theme/theme-schema.json +335 -0
  101. package/dist/modes/interactive/theme/theme.js +938 -0
  102. package/dist/modes/print-mode.js +96 -0
  103. package/dist/modes/rpc/rpc-client.js +390 -0
  104. package/dist/modes/rpc/rpc-mode.js +448 -0
  105. package/dist/modes/rpc/rpc-types.js +7 -0
  106. package/dist/utils/changelog.js +86 -0
  107. package/dist/utils/clipboard-image.js +116 -0
  108. package/dist/utils/clipboard.js +58 -0
  109. package/dist/utils/frontmatter.js +25 -0
  110. package/dist/utils/git.js +5 -0
  111. package/dist/utils/image-convert.js +34 -0
  112. package/dist/utils/image-resize.js +180 -0
  113. package/dist/utils/mime.js +25 -0
  114. package/dist/utils/photon.js +120 -0
  115. package/dist/utils/shell.js +164 -0
  116. package/dist/utils/sleep.js +16 -0
  117. package/dist/utils/tools-manager.js +186 -0
  118. package/docs/compaction.md +390 -0
  119. package/docs/custom-provider.md +538 -0
  120. package/docs/development.md +69 -0
  121. package/docs/extensions.md +1733 -0
  122. package/docs/images/doom-extension.png +0 -0
  123. package/docs/images/interactive-mode.png +0 -0
  124. package/docs/images/tree-view.png +0 -0
  125. package/docs/json.md +79 -0
  126. package/docs/keybindings.md +162 -0
  127. package/docs/models.md +193 -0
  128. package/docs/packages.md +163 -0
  129. package/docs/prompt-templates.md +67 -0
  130. package/docs/providers.md +147 -0
  131. package/docs/rpc.md +1048 -0
  132. package/docs/sdk.md +957 -0
  133. package/docs/session.md +412 -0
  134. package/docs/settings.md +216 -0
  135. package/docs/shell-aliases.md +13 -0
  136. package/docs/skills.md +226 -0
  137. package/docs/terminal-setup.md +65 -0
  138. package/docs/themes.md +295 -0
  139. package/docs/tree.md +219 -0
  140. package/docs/tui.md +887 -0
  141. package/docs/windows.md +17 -0
  142. package/examples/README.md +25 -0
  143. package/examples/extensions/README.md +192 -0
  144. package/examples/extensions/antigravity-image-gen.ts +414 -0
  145. package/examples/extensions/auto-commit-on-exit.ts +49 -0
  146. package/examples/extensions/bookmark.ts +50 -0
  147. package/examples/extensions/claude-rules.ts +86 -0
  148. package/examples/extensions/confirm-destructive.ts +59 -0
  149. package/examples/extensions/custom-compaction.ts +115 -0
  150. package/examples/extensions/custom-footer.ts +65 -0
  151. package/examples/extensions/custom-header.ts +73 -0
  152. package/examples/extensions/custom-provider-anthropic/index.ts +605 -0
  153. package/examples/extensions/custom-provider-anthropic/package-lock.json +24 -0
  154. package/examples/extensions/custom-provider-anthropic/package.json +19 -0
  155. package/examples/extensions/custom-provider-gitlab-duo/index.ts +350 -0
  156. package/examples/extensions/custom-provider-gitlab-duo/package.json +16 -0
  157. package/examples/extensions/custom-provider-gitlab-duo/test.ts +83 -0
  158. package/examples/extensions/dirty-repo-guard.ts +56 -0
  159. package/examples/extensions/doom-overlay/README.md +46 -0
  160. package/examples/extensions/doom-overlay/doom/build/doom.js +21 -0
  161. package/examples/extensions/doom-overlay/doom/build/doom.wasm +0 -0
  162. package/examples/extensions/doom-overlay/doom/build.sh +152 -0
  163. package/examples/extensions/doom-overlay/doom/doomgeneric_pi.c +72 -0
  164. package/examples/extensions/doom-overlay/doom-component.ts +133 -0
  165. package/examples/extensions/doom-overlay/doom-engine.ts +173 -0
  166. package/examples/extensions/doom-overlay/doom-keys.ts +105 -0
  167. package/examples/extensions/doom-overlay/index.ts +74 -0
  168. package/examples/extensions/doom-overlay/wad-finder.ts +51 -0
  169. package/examples/extensions/event-bus.ts +43 -0
  170. package/examples/extensions/file-trigger.ts +41 -0
  171. package/examples/extensions/git-checkpoint.ts +53 -0
  172. package/examples/extensions/handoff.ts +151 -0
  173. package/examples/extensions/hello.ts +25 -0
  174. package/examples/extensions/inline-bash.ts +94 -0
  175. package/examples/extensions/input-transform.ts +43 -0
  176. package/examples/extensions/interactive-shell.ts +196 -0
  177. package/examples/extensions/mac-system-theme.ts +47 -0
  178. package/examples/extensions/message-renderer.ts +60 -0
  179. package/examples/extensions/modal-editor.ts +86 -0
  180. package/examples/extensions/model-status.ts +31 -0
  181. package/examples/extensions/notify.ts +25 -0
  182. package/examples/extensions/overlay-qa-tests.ts +882 -0
  183. package/examples/extensions/overlay-test.ts +151 -0
  184. package/examples/extensions/permission-gate.ts +34 -0
  185. package/examples/extensions/pirate.ts +47 -0
  186. package/examples/extensions/plan-mode/README.md +65 -0
  187. package/examples/extensions/plan-mode/index.ts +341 -0
  188. package/examples/extensions/plan-mode/utils.ts +168 -0
  189. package/examples/extensions/preset.ts +399 -0
  190. package/examples/extensions/protected-paths.ts +30 -0
  191. package/examples/extensions/qna.ts +120 -0
  192. package/examples/extensions/question.ts +265 -0
  193. package/examples/extensions/questionnaire.ts +428 -0
  194. package/examples/extensions/rainbow-editor.ts +88 -0
  195. package/examples/extensions/sandbox/index.ts +318 -0
  196. package/examples/extensions/sandbox/package-lock.json +92 -0
  197. package/examples/extensions/sandbox/package.json +19 -0
  198. package/examples/extensions/send-user-message.ts +97 -0
  199. package/examples/extensions/session-name.ts +27 -0
  200. package/examples/extensions/shutdown-command.ts +63 -0
  201. package/examples/extensions/snake.ts +344 -0
  202. package/examples/extensions/space-invaders.ts +561 -0
  203. package/examples/extensions/ssh.ts +220 -0
  204. package/examples/extensions/status-line.ts +40 -0
  205. package/examples/extensions/subagent/README.md +172 -0
  206. package/examples/extensions/subagent/agents/planner.md +37 -0
  207. package/examples/extensions/subagent/agents/reviewer.md +35 -0
  208. package/examples/extensions/subagent/agents/scout.md +50 -0
  209. package/examples/extensions/subagent/agents/worker.md +24 -0
  210. package/examples/extensions/subagent/agents.ts +127 -0
  211. package/examples/extensions/subagent/index.ts +964 -0
  212. package/examples/extensions/subagent/prompts/implement-and-review.md +10 -0
  213. package/examples/extensions/subagent/prompts/implement.md +10 -0
  214. package/examples/extensions/subagent/prompts/scout-and-plan.md +9 -0
  215. package/examples/extensions/summarize.ts +196 -0
  216. package/examples/extensions/timed-confirm.ts +70 -0
  217. package/examples/extensions/todo.ts +300 -0
  218. package/examples/extensions/tool-override.ts +144 -0
  219. package/examples/extensions/tools.ts +147 -0
  220. package/examples/extensions/trigger-compact.ts +40 -0
  221. package/examples/extensions/truncated-tool.ts +193 -0
  222. package/examples/extensions/widget-placement.ts +17 -0
  223. package/examples/extensions/with-deps/index.ts +36 -0
  224. package/examples/extensions/with-deps/package-lock.json +31 -0
  225. package/examples/extensions/with-deps/package.json +22 -0
  226. package/examples/sdk/01-minimal.ts +22 -0
  227. package/examples/sdk/02-custom-model.ts +50 -0
  228. package/examples/sdk/03-custom-prompt.ts +55 -0
  229. package/examples/sdk/04-skills.ts +46 -0
  230. package/examples/sdk/05-tools.ts +56 -0
  231. package/examples/sdk/06-extensions.ts +88 -0
  232. package/examples/sdk/07-context-files.ts +40 -0
  233. package/examples/sdk/08-prompt-templates.ts +47 -0
  234. package/examples/sdk/09-api-keys-and-oauth.ts +48 -0
  235. package/examples/sdk/10-settings.ts +38 -0
  236. package/examples/sdk/11-sessions.ts +48 -0
  237. package/examples/sdk/12-full-control.ts +82 -0
  238. package/examples/sdk/13-codex-oauth.ts +37 -0
  239. package/examples/sdk/README.md +144 -0
  240. package/package.json +85 -0
package/docs/skills.md ADDED
@@ -0,0 +1,226 @@
1
+ > indusagi can create skills. Ask it to build one for your use case.
2
+
3
+ # Skills
4
+
5
+ Skills are self-contained capability packages that the agent loads on-demand. A skill provides specialized workflows, setup instructions, helper scripts, and reference documentation for specific tasks.
6
+
7
+ Indusagi implements the [Agent Skills standard](https://agentskills.io/specification), warning about violations but remaining lenient.
8
+
9
+ ## Table of Contents
10
+
11
+ - [Locations](#locations)
12
+ - [How Skills Work](#how-skills-work)
13
+ - [Skill Commands](#skill-commands)
14
+ - [Skill Structure](#skill-structure)
15
+ - [Frontmatter](#frontmatter)
16
+ - [Validation](#validation)
17
+ - [Example](#example)
18
+ - [Skill Repositories](#skill-repositories)
19
+
20
+ ## Locations
21
+
22
+ > **Security:** Skills can instruct the model to perform any action and may include executable code the model invokes. Review skill content before use.
23
+
24
+ Indusagi loads skills from:
25
+
26
+ - Global: `~/.indusagi/agent/skills/`
27
+ - Project: `.indusagi/skills/`
28
+ - Packages: `skills/` directories or `indusagi.skills` entries in `package.json`
29
+ - Settings: `skills` array with files or directories
30
+ - CLI: `--skill <path>` (repeatable, additive even with `--no-skills`)
31
+
32
+ Discovery rules:
33
+ - Direct `.md` files in the skills directory root
34
+ - Recursive `SKILL.md` files under subdirectories
35
+
36
+ Disable discovery with `--no-skills` (explicit `--skill` paths still load).
37
+
38
+ ### Using Skills from Other Harnesses
39
+
40
+ To use skills from Claude Code or OpenAI Codex, add their directories to settings:
41
+
42
+ ```json
43
+ {
44
+ "skills": [
45
+ "~/.claude/skills",
46
+ "~/.codex/skills"
47
+ ]
48
+ }
49
+ ```
50
+
51
+ For project-level Claude Code skills, add to `.indusagi/settings.json`:
52
+
53
+ ```json
54
+ {
55
+ "skills": ["../.claude/skills"]
56
+ }
57
+ ```
58
+
59
+ ## How Skills Work
60
+
61
+ 1. At startup, indusagi scans skill locations and extracts names and descriptions
62
+ 2. The system prompt includes available skills in XML format per the [specification](https://agentskills.io/integrate-skills)
63
+ 3. When a task matches, the agent uses `read` to load the full SKILL.md (models don't always do this; use prompting or `/skill:name` to force it)
64
+ 4. The agent follows the instructions, using relative paths to reference scripts and assets
65
+
66
+ This is progressive disclosure: only descriptions are always in context, full instructions load on-demand.
67
+
68
+ ## Skill Commands
69
+
70
+ Skills register as `/skill:name` commands:
71
+
72
+ ```bash
73
+ /skill:brave-search # Load and execute the skill
74
+ /skill:pdf-tools extract # Load skill with arguments
75
+ ```
76
+
77
+ Arguments after the command are appended to the skill content as `User: <args>`.
78
+
79
+ Toggle skill commands via `/settings` in interactive mode or in `settings.json`:
80
+
81
+ ```json
82
+ {
83
+ "enableSkillCommands": true
84
+ }
85
+ ```
86
+
87
+ ## Skill Structure
88
+
89
+ A skill is a directory with a `SKILL.md` file. Everything else is freeform.
90
+
91
+ ```
92
+ my-skill/
93
+ ├── SKILL.md # Required: frontmatter + instructions
94
+ ├── scripts/ # Helper scripts
95
+ │ └── process.sh
96
+ ├── references/ # Detailed docs loaded on-demand
97
+ │ └── api-reference.md
98
+ └── assets/
99
+ └── template.json
100
+ ```
101
+
102
+ ### SKILL.md Format
103
+
104
+ ```markdown
105
+ ---
106
+ name: my-skill
107
+ description: What this skill does and when to use it. Be specific.
108
+ ---
109
+
110
+ # My Skill
111
+
112
+ ## Setup
113
+
114
+ Run once before first use:
115
+ \`\`\`bash
116
+ cd /path/to/skill && npm install
117
+ \`\`\`
118
+
119
+ ## Usage
120
+
121
+ \`\`\`bash
122
+ ./scripts/process.sh <input>
123
+ \`\`\`
124
+ ```
125
+
126
+ Use relative paths from the skill directory:
127
+
128
+ ```markdown
129
+ See [the reference guide](references/REFERENCE.md) for details.
130
+ ```
131
+
132
+ ## Frontmatter
133
+
134
+ Per the [Agent Skills specification](https://agentskills.io/specification#frontmatter-required):
135
+
136
+ | Field | Required | Description |
137
+ |-------|----------|-------------|
138
+ | `name` | Yes | Max 64 chars. Lowercase a-z, 0-9, hyphens. Must match parent directory. |
139
+ | `description` | Yes | Max 1024 chars. What the skill does and when to use it. |
140
+ | `license` | No | License name or reference to bundled file. |
141
+ | `compatibility` | No | Max 500 chars. Environment requirements. |
142
+ | `metadata` | No | Arbitrary key-value mapping. |
143
+ | `allowed-tools` | No | Space-delimited list of pre-approved tools (experimental). |
144
+ | `disable-model-invocation` | No | When `true`, skill is hidden from system prompt. Users must use `/skill:name`. |
145
+
146
+ ### Name Rules
147
+
148
+ - 1-64 characters
149
+ - Lowercase letters, numbers, hyphens only
150
+ - No leading/trailing hyphens
151
+ - No consecutive hyphens
152
+ - Must match parent directory name
153
+
154
+ Valid: `pdf-processing`, `data-analysis`, `code-review`
155
+ Invalid: `PDF-Processing`, `-pdf`, `pdf--processing`
156
+
157
+ ### Description Best Practices
158
+
159
+ The description determines when the agent loads the skill. Be specific.
160
+
161
+ Good:
162
+ ```yaml
163
+ description: Extracts text and tables from PDF files, fills PDF forms, and merges multiple PDFs. Use when working with PDF documents.
164
+ ```
165
+
166
+ Poor:
167
+ ```yaml
168
+ description: Helps with PDFs.
169
+ ```
170
+
171
+ ## Validation
172
+
173
+ Indusagi validates skills against the Agent Skills standard. Most issues produce warnings but still load the skill:
174
+
175
+ - Name doesn't match parent directory
176
+ - Name exceeds 64 characters or contains invalid characters
177
+ - Name starts/ends with hyphen or has consecutive hyphens
178
+ - Description exceeds 1024 characters
179
+ - Unknown frontmatter fields
180
+
181
+ **Exception:** Skills with missing description are not loaded.
182
+
183
+ Name collisions (same name from different locations) warn and keep the first skill found.
184
+
185
+ ## Example
186
+
187
+ ```
188
+ brave-search/
189
+ ├── SKILL.md
190
+ ├── search.js
191
+ └── content.js
192
+ ```
193
+
194
+ **SKILL.md:**
195
+ ```markdown
196
+ ---
197
+ name: brave-search
198
+ description: Web search and content extraction via Brave Search API. Use for searching documentation, facts, or any web content.
199
+ ---
200
+
201
+ # Brave Search
202
+
203
+ ## Setup
204
+
205
+ \`\`\`bash
206
+ cd /path/to/brave-search && npm install
207
+ \`\`\`
208
+
209
+ ## Search
210
+
211
+ \`\`\`bash
212
+ ./search.js "query" # Basic search
213
+ ./search.js "query" --content # Include page content
214
+ \`\`\`
215
+
216
+ ## Extract Page Content
217
+
218
+ \`\`\`bash
219
+ ./content.js https://example.com
220
+ \`\`\`
221
+ ```
222
+
223
+ ## Skill Repositories
224
+
225
+ - [Anthropic Skills](https://github.com/anthropics/skills) - Document processing (docx, pdf, pptx, xlsx), web development
226
+ - [Indusagi Skills](https://github.com/badlogic/indusagi-skills) - Web search, browser automation, Google APIs, transcription
@@ -0,0 +1,65 @@
1
+ # Terminal Setup
2
+
3
+ Indusagi uses the [Kitty keyboard protocol](https://sw.kovidgoyal.net/kitty/keyboard-protocol/) for reliable modifier key detection. Most modern terminals support this protocol, but some require configuration.
4
+
5
+ ## Kitty, iTerm2
6
+
7
+ Work out of the box.
8
+
9
+ ## Ghostty
10
+
11
+ Add to your Ghostty config (`~/.config/ghostty/config`):
12
+
13
+ ```
14
+ keybind = alt+backspace=text:\x1b\x7f
15
+ keybind = shift+enter=text:\n
16
+ ```
17
+
18
+ ## WezTerm
19
+
20
+ Create `~/.wezterm.lua`:
21
+
22
+ ```lua
23
+ local wezterm = require 'wezterm'
24
+ local config = wezterm.config_builder()
25
+ config.enable_kitty_keyboard = true
26
+ return config
27
+ ```
28
+
29
+ ## VS Code (Integrated Terminal)
30
+
31
+ Add to `keybindings.json` to enable `Shift+Enter` for multi-line input:
32
+
33
+ ```json
34
+ {
35
+ "key": "shift+enter",
36
+ "command": "workbench.action.terminal.sendSequence",
37
+ "args": { "text": "\u001b[13;2u" },
38
+ "when": "terminalFocus"
39
+ }
40
+ ```
41
+
42
+ ## Windows Terminal
43
+
44
+ Add to `settings.json` (Ctrl+Shift+, or Settings → Open JSON file):
45
+
46
+ ```json
47
+ {
48
+ "actions": [
49
+ {
50
+ "command": { "action": "sendInput", "input": "\u001b[13;2u" },
51
+ "keys": "shift+enter"
52
+ }
53
+ ]
54
+ }
55
+ ```
56
+
57
+ If you already have an `actions` array, add the object to it.
58
+
59
+ ## IntelliJ IDEA (Integrated Terminal)
60
+
61
+ The built-in terminal has limited escape sequence support. Shift+Enter cannot be distinguished from Enter in IntelliJ's terminal.
62
+
63
+ If you want the hardware cursor visible, set `INDUSAGI_HARDWARE_CURSOR=1` before running indusagi (disabled by default for compatibility).
64
+
65
+ Consider using a dedicated terminal emulator for the best experience.
package/docs/themes.md ADDED
@@ -0,0 +1,295 @@
1
+ > indusagi can create themes. Ask it to build one for your setup.
2
+
3
+ # Themes
4
+
5
+ Themes are JSON files that define colors for the TUI.
6
+
7
+ ## Table of Contents
8
+
9
+ - [Locations](#locations)
10
+ - [Selecting a Theme](#selecting-a-theme)
11
+ - [Creating a Custom Theme](#creating-a-custom-theme)
12
+ - [Theme Format](#theme-format)
13
+ - [Color Tokens](#color-tokens)
14
+ - [Color Values](#color-values)
15
+ - [Tips](#tips)
16
+
17
+ ## Locations
18
+
19
+ Indusagi loads themes from:
20
+
21
+ - Built-in: `dark`, `light`
22
+ - Global: `~/.indusagi/agent/themes/*.json`
23
+ - Project: `.indusagi/themes/*.json`
24
+ - Packages: `themes/` directories or `indusagi.themes` entries in `package.json`
25
+ - Settings: `themes` array with files or directories
26
+ - CLI: `--theme <path>` (repeatable)
27
+
28
+ Disable discovery with `--no-themes`.
29
+
30
+ ## Selecting a Theme
31
+
32
+ Select a theme via `/settings` or in `settings.json`:
33
+
34
+ ```json
35
+ {
36
+ "theme": "my-theme"
37
+ }
38
+ ```
39
+
40
+ On first run, indusagi detects your terminal background and defaults to `dark` or `light`.
41
+
42
+ ## Creating a Custom Theme
43
+
44
+ 1. Create a theme file:
45
+
46
+ ```bash
47
+ mkdir -p ~/.indusagi/agent/themes
48
+ vim ~/.indusagi/agent/themes/my-theme.json
49
+ ```
50
+
51
+ 2. Define the theme with all required colors (see [Color Tokens](#color-tokens)):
52
+
53
+ ```json
54
+ {
55
+ "$schema": "https://raw.githubusercontent.com/badlogic/indusagi-mono/main/packages/coding-agent/src/modes/interactive/theme/theme-schema.json",
56
+ "name": "my-theme",
57
+ "vars": {
58
+ "primary": "#00aaff",
59
+ "secondary": 242
60
+ },
61
+ "colors": {
62
+ "accent": "primary",
63
+ "border": "primary",
64
+ "borderAccent": "#00ffff",
65
+ "borderMuted": "secondary",
66
+ "success": "#00ff00",
67
+ "error": "#ff0000",
68
+ "warning": "#ffff00",
69
+ "muted": "secondary",
70
+ "dim": 240,
71
+ "text": "",
72
+ "thinkingText": "secondary",
73
+ "selectedBg": "#2d2d30",
74
+ "userMessageBg": "#2d2d30",
75
+ "userMessageText": "",
76
+ "customMessageBg": "#2d2d30",
77
+ "customMessageText": "",
78
+ "customMessageLabel": "primary",
79
+ "toolPendingBg": "#1e1e2e",
80
+ "toolSuccessBg": "#1e2e1e",
81
+ "toolErrorBg": "#2e1e1e",
82
+ "toolTitle": "primary",
83
+ "toolOutput": "",
84
+ "mdHeading": "#ffaa00",
85
+ "mdLink": "primary",
86
+ "mdLinkUrl": "secondary",
87
+ "mdCode": "#00ffff",
88
+ "mdCodeBlock": "",
89
+ "mdCodeBlockBorder": "secondary",
90
+ "mdQuote": "secondary",
91
+ "mdQuoteBorder": "secondary",
92
+ "mdHr": "secondary",
93
+ "mdListBullet": "#00ffff",
94
+ "toolDiffAdded": "#00ff00",
95
+ "toolDiffRemoved": "#ff0000",
96
+ "toolDiffContext": "secondary",
97
+ "syntaxComment": "secondary",
98
+ "syntaxKeyword": "primary",
99
+ "syntaxFunction": "#00aaff",
100
+ "syntaxVariable": "#ffaa00",
101
+ "syntaxString": "#00ff00",
102
+ "syntaxNumber": "#ff00ff",
103
+ "syntaxType": "#00aaff",
104
+ "syntaxOperator": "primary",
105
+ "syntaxPunctuation": "secondary",
106
+ "thinkingOff": "secondary",
107
+ "thinkingMinimal": "primary",
108
+ "thinkingLow": "#00aaff",
109
+ "thinkingMedium": "#00ffff",
110
+ "thinkingHigh": "#ff00ff",
111
+ "thinkingXhigh": "#ff0000",
112
+ "bashMode": "#ffaa00"
113
+ }
114
+ }
115
+ ```
116
+
117
+ 3. Select the theme via `/settings`.
118
+
119
+ **Hot reload:** When you edit the currently active custom theme file, indusagi reloads it automatically for immediate visual feedback.
120
+
121
+ ## Theme Format
122
+
123
+ ```json
124
+ {
125
+ "$schema": "https://raw.githubusercontent.com/badlogic/indusagi-mono/main/packages/coding-agent/src/modes/interactive/theme/theme-schema.json",
126
+ "name": "my-theme",
127
+ "vars": {
128
+ "blue": "#0066cc",
129
+ "gray": 242
130
+ },
131
+ "colors": {
132
+ "accent": "blue",
133
+ "muted": "gray",
134
+ "text": "",
135
+ ...
136
+ }
137
+ }
138
+ ```
139
+
140
+ - `name` is required and must be unique.
141
+ - `vars` is optional. Define reusable colors here, then reference them in `colors`.
142
+ - `colors` must define all 51 required tokens.
143
+
144
+ The `$schema` field enables editor auto-completion and validation.
145
+
146
+ ## Color Tokens
147
+
148
+ Every theme must define all 51 color tokens. There are no optional colors.
149
+
150
+ ### Core UI (11 colors)
151
+
152
+ | Token | Purpose |
153
+ |-------|---------|
154
+ | `accent` | Primary accent (logo, selected items, cursor) |
155
+ | `border` | Normal borders |
156
+ | `borderAccent` | Highlighted borders |
157
+ | `borderMuted` | Subtle borders (editor) |
158
+ | `success` | Success states |
159
+ | `error` | Error states |
160
+ | `warning` | Warning states |
161
+ | `muted` | Secondary text |
162
+ | `dim` | Tertiary text |
163
+ | `text` | Default text (usually `""`) |
164
+ | `thinkingText` | Thinking block text |
165
+
166
+ ### Backgrounds & Content (11 colors)
167
+
168
+ | Token | Purpose |
169
+ |-------|---------|
170
+ | `selectedBg` | Selected line background |
171
+ | `userMessageBg` | User message background |
172
+ | `userMessageText` | User message text |
173
+ | `customMessageBg` | Extension message background |
174
+ | `customMessageText` | Extension message text |
175
+ | `customMessageLabel` | Extension message label |
176
+ | `toolPendingBg` | Tool box (pending) |
177
+ | `toolSuccessBg` | Tool box (success) |
178
+ | `toolErrorBg` | Tool box (error) |
179
+ | `toolTitle` | Tool title |
180
+ | `toolOutput` | Tool output text |
181
+
182
+ ### Markdown (10 colors)
183
+
184
+ | Token | Purpose |
185
+ |-------|---------|
186
+ | `mdHeading` | Headings |
187
+ | `mdLink` | Link text |
188
+ | `mdLinkUrl` | Link URL |
189
+ | `mdCode` | Inline code |
190
+ | `mdCodeBlock` | Code block content |
191
+ | `mdCodeBlockBorder` | Code block fences |
192
+ | `mdQuote` | Blockquote text |
193
+ | `mdQuoteBorder` | Blockquote border |
194
+ | `mdHr` | Horizontal rule |
195
+ | `mdListBullet` | List bullets |
196
+
197
+ ### Tool Diffs (3 colors)
198
+
199
+ | Token | Purpose |
200
+ |-------|---------|
201
+ | `toolDiffAdded` | Added lines |
202
+ | `toolDiffRemoved` | Removed lines |
203
+ | `toolDiffContext` | Context lines |
204
+
205
+ ### Syntax Highlighting (9 colors)
206
+
207
+ | Token | Purpose |
208
+ |-------|---------|
209
+ | `syntaxComment` | Comments |
210
+ | `syntaxKeyword` | Keywords |
211
+ | `syntaxFunction` | Function names |
212
+ | `syntaxVariable` | Variables |
213
+ | `syntaxString` | Strings |
214
+ | `syntaxNumber` | Numbers |
215
+ | `syntaxType` | Types |
216
+ | `syntaxOperator` | Operators |
217
+ | `syntaxPunctuation` | Punctuation |
218
+
219
+ ### Thinking Level Borders (6 colors)
220
+
221
+ Editor border colors indicating thinking level (visual hierarchy from subtle to prominent):
222
+
223
+ | Token | Purpose |
224
+ |-------|---------|
225
+ | `thinkingOff` | Thinking off |
226
+ | `thinkingMinimal` | Minimal thinking |
227
+ | `thinkingLow` | Low thinking |
228
+ | `thinkingMedium` | Medium thinking |
229
+ | `thinkingHigh` | High thinking |
230
+ | `thinkingXhigh` | Extra high thinking |
231
+
232
+ ### Bash Mode (1 color)
233
+
234
+ | Token | Purpose |
235
+ |-------|---------|
236
+ | `bashMode` | Editor border in bash mode (`!` prefix) |
237
+
238
+ ### HTML Export (optional)
239
+
240
+ The `export` section controls colors for `/export` HTML output. If omitted, colors are derived from `userMessageBg`.
241
+
242
+ ```json
243
+ {
244
+ "export": {
245
+ "pageBg": "#18181e",
246
+ "cardBg": "#1e1e24",
247
+ "infoBg": "#3c3728"
248
+ }
249
+ }
250
+ ```
251
+
252
+ ## Color Values
253
+
254
+ Four formats are supported:
255
+
256
+ | Format | Example | Description |
257
+ |--------|---------|-------------|
258
+ | Hex | `"#ff0000"` | 6-digit hex RGB |
259
+ | 256-color | `39` | xterm 256-color palette index (0-255) |
260
+ | Variable | `"primary"` | Reference to a `vars` entry |
261
+ | Default | `""` | Terminal's default color |
262
+
263
+ ### 256-Color Palette
264
+
265
+ - `0-15`: Basic ANSI colors (terminal-dependent)
266
+ - `16-231`: 6×6×6 RGB cube (`16 + 36×R + 6×G + B` where R,G,B are 0-5)
267
+ - `232-255`: Grayscale ramp
268
+
269
+ ### Terminal Compatibility
270
+
271
+ Indusagi uses 24-bit RGB colors. Most modern terminals support this (iTerm2, Kitty, WezTerm, Windows Terminal, VS Code). For older terminals with only 256-color support, indusagi falls back to the nearest approximation.
272
+
273
+ Check truecolor support:
274
+
275
+ ```bash
276
+ echo $COLORTERM # Should output "truecolor" or "24bit"
277
+ ```
278
+
279
+ ## Tips
280
+
281
+ **Dark terminals:** Use bright, saturated colors with higher contrast.
282
+
283
+ **Light terminals:** Use darker, muted colors with lower contrast.
284
+
285
+ **Color harmony:** Start with a base palette (Nord, Gruvbox, Tokyo Night), define it in `vars`, and reference consistently.
286
+
287
+ **Testing:** Check your theme with different message types, tool states, markdown content, and long wrapped text.
288
+
289
+ **VS Code:** Set `terminal.integrated.minimumContrastRatio` to `1` for accurate colors.
290
+
291
+ ## Examples
292
+
293
+ See the built-in themes:
294
+ - [dark.json](../src/modes/interactive/theme/dark.json)
295
+ - [light.json](../src/modes/interactive/theme/light.json)