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
@@ -0,0 +1,905 @@
1
+ :root {
2
+ {{THEME_VARS}}
3
+ --body-bg: {{BODY_BG}};
4
+ --container-bg: {{CONTAINER_BG}};
5
+ --info-bg: {{INFO_BG}};
6
+ }
7
+
8
+ * { margin: 0; padding: 0; box-sizing: border-box; }
9
+
10
+ :root {
11
+ --line-height: 18px; /* 12px font * 1.5 */
12
+ }
13
+
14
+ body {
15
+ font-family: ui-monospace, 'Cascadia Code', 'Source Code Pro', Menlo, Consolas, 'DejaVu Sans Mono', monospace;
16
+ font-size: 12px;
17
+ line-height: var(--line-height);
18
+ color: var(--text);
19
+ background: var(--body-bg);
20
+ }
21
+
22
+ #app {
23
+ display: flex;
24
+ min-height: 100vh;
25
+ }
26
+
27
+ /* Sidebar */
28
+ #sidebar {
29
+ width: 400px;
30
+ background: var(--container-bg);
31
+ flex-shrink: 0;
32
+ display: flex;
33
+ flex-direction: column;
34
+ position: sticky;
35
+ top: 0;
36
+ height: 100vh;
37
+ border-right: 1px solid var(--dim);
38
+ }
39
+
40
+ .sidebar-header {
41
+ padding: 8px 12px;
42
+ flex-shrink: 0;
43
+ }
44
+
45
+ .sidebar-controls {
46
+ padding: 8px 8px 4px 8px;
47
+ }
48
+
49
+ .sidebar-search {
50
+ width: 100%;
51
+ box-sizing: border-box;
52
+ padding: 4px 8px;
53
+ font-size: 11px;
54
+ font-family: inherit;
55
+ background: var(--body-bg);
56
+ color: var(--text);
57
+ border: 1px solid var(--dim);
58
+ border-radius: 3px;
59
+ }
60
+
61
+ .sidebar-filters {
62
+ display: flex;
63
+ padding: 4px 8px 8px 8px;
64
+ gap: 4px;
65
+ align-items: center;
66
+ flex-wrap: wrap;
67
+ }
68
+
69
+ .sidebar-search:focus {
70
+ outline: none;
71
+ border-color: var(--accent);
72
+ }
73
+
74
+ .sidebar-search::placeholder {
75
+ color: var(--muted);
76
+ }
77
+
78
+ .filter-btn {
79
+ padding: 3px 8px;
80
+ font-size: 10px;
81
+ font-family: inherit;
82
+ background: transparent;
83
+ color: var(--muted);
84
+ border: 1px solid var(--dim);
85
+ border-radius: 3px;
86
+ cursor: pointer;
87
+ }
88
+
89
+ .filter-btn:hover {
90
+ color: var(--text);
91
+ border-color: var(--text);
92
+ }
93
+
94
+ .filter-btn.active {
95
+ background: var(--accent);
96
+ color: var(--body-bg);
97
+ border-color: var(--accent);
98
+ }
99
+
100
+ .sidebar-close {
101
+ display: none;
102
+ padding: 3px 8px;
103
+ font-size: 12px;
104
+ font-family: inherit;
105
+ background: transparent;
106
+ color: var(--muted);
107
+ border: 1px solid var(--dim);
108
+ border-radius: 3px;
109
+ cursor: pointer;
110
+ margin-left: auto;
111
+ }
112
+
113
+ .sidebar-close:hover {
114
+ color: var(--text);
115
+ border-color: var(--text);
116
+ }
117
+
118
+ .tree-container {
119
+ flex: 1;
120
+ overflow: auto;
121
+ padding: 4px 0;
122
+ }
123
+
124
+ .tree-node {
125
+ padding: 0 8px;
126
+ cursor: pointer;
127
+ display: flex;
128
+ align-items: baseline;
129
+ font-size: 11px;
130
+ line-height: 13px;
131
+ white-space: nowrap;
132
+ }
133
+
134
+ .tree-node:hover {
135
+ background: var(--selectedBg);
136
+ }
137
+
138
+ .tree-node.active {
139
+ background: var(--selectedBg);
140
+ }
141
+
142
+ .tree-node.active .tree-content {
143
+ font-weight: bold;
144
+ }
145
+
146
+ .tree-node.in-path {
147
+ background: color-mix(in srgb, var(--accent) 10%, transparent);
148
+ }
149
+
150
+ .tree-node:not(.in-path) {
151
+ opacity: 0.5;
152
+ }
153
+
154
+ .tree-node:not(.in-path):hover {
155
+ opacity: 1;
156
+ }
157
+
158
+ .tree-prefix {
159
+ color: var(--muted);
160
+ flex-shrink: 0;
161
+ font-family: monospace;
162
+ white-space: pre;
163
+ }
164
+
165
+ .tree-marker {
166
+ color: var(--accent);
167
+ flex-shrink: 0;
168
+ }
169
+
170
+ .tree-content {
171
+ color: var(--text);
172
+ }
173
+
174
+ .tree-role-user {
175
+ color: var(--accent);
176
+ }
177
+
178
+ .tree-role-assistant {
179
+ color: var(--success);
180
+ }
181
+
182
+ .tree-role-tool {
183
+ color: var(--muted);
184
+ }
185
+
186
+ .tree-muted {
187
+ color: var(--muted);
188
+ }
189
+
190
+ .tree-error {
191
+ color: var(--error);
192
+ }
193
+
194
+ .tree-compaction {
195
+ color: var(--borderAccent);
196
+ }
197
+
198
+ .tree-branch-summary {
199
+ color: var(--warning);
200
+ }
201
+
202
+ .tree-custom-message {
203
+ color: var(--customMessageLabel);
204
+ }
205
+
206
+ .tree-status {
207
+ padding: 4px 12px;
208
+ font-size: 10px;
209
+ color: var(--muted);
210
+ flex-shrink: 0;
211
+ }
212
+
213
+ /* Main content */
214
+ #content {
215
+ flex: 1;
216
+ overflow-y: auto;
217
+ padding: var(--line-height) calc(var(--line-height) * 2);
218
+ display: flex;
219
+ flex-direction: column;
220
+ align-items: center;
221
+ }
222
+
223
+ #content > * {
224
+ width: 100%;
225
+ max-width: 800px;
226
+ }
227
+
228
+ /* Help bar */
229
+ .help-bar {
230
+ font-size: 11px;
231
+ color: var(--warning);
232
+ margin-bottom: var(--line-height);
233
+ display: flex;
234
+ align-items: center;
235
+ gap: 12px;
236
+ }
237
+
238
+ .download-json-btn {
239
+ font-size: 10px;
240
+ padding: 2px 8px;
241
+ background: var(--container-bg);
242
+ border: 1px solid var(--border);
243
+ border-radius: 3px;
244
+ color: var(--text);
245
+ cursor: pointer;
246
+ font-family: inherit;
247
+ }
248
+
249
+ .download-json-btn:hover {
250
+ background: var(--hover);
251
+ border-color: var(--borderAccent);
252
+ }
253
+
254
+ /* Header */
255
+ .header {
256
+ background: var(--container-bg);
257
+ border-radius: 4px;
258
+ padding: var(--line-height);
259
+ margin-bottom: var(--line-height);
260
+ }
261
+
262
+ .header h1 {
263
+ font-size: 12px;
264
+ font-weight: bold;
265
+ color: var(--borderAccent);
266
+ margin-bottom: var(--line-height);
267
+ }
268
+
269
+ .header-info {
270
+ display: flex;
271
+ flex-direction: column;
272
+ gap: 0;
273
+ font-size: 11px;
274
+ }
275
+
276
+ .info-item {
277
+ color: var(--dim);
278
+ display: flex;
279
+ align-items: baseline;
280
+ }
281
+
282
+ .info-label {
283
+ font-weight: 600;
284
+ margin-right: 8px;
285
+ min-width: 100px;
286
+ }
287
+
288
+ .info-value {
289
+ color: var(--text);
290
+ flex: 1;
291
+ }
292
+
293
+ /* Messages */
294
+ #messages {
295
+ display: flex;
296
+ flex-direction: column;
297
+ gap: var(--line-height);
298
+ }
299
+
300
+ .message-timestamp {
301
+ font-size: 10px;
302
+ color: var(--dim);
303
+ opacity: 0.8;
304
+ }
305
+
306
+ .user-message {
307
+ background: var(--userMessageBg);
308
+ color: var(--userMessageText);
309
+ padding: var(--line-height);
310
+ border-radius: 4px;
311
+ position: relative;
312
+ }
313
+
314
+ .assistant-message {
315
+ padding: 0;
316
+ position: relative;
317
+ }
318
+
319
+ /* Copy link button - appears on hover */
320
+ .copy-link-btn {
321
+ position: absolute;
322
+ top: 8px;
323
+ right: 8px;
324
+ width: 28px;
325
+ height: 28px;
326
+ padding: 6px;
327
+ background: var(--container-bg);
328
+ border: 1px solid var(--dim);
329
+ border-radius: 4px;
330
+ color: var(--muted);
331
+ cursor: pointer;
332
+ opacity: 0;
333
+ transition: opacity 0.15s, background 0.15s, color 0.15s;
334
+ display: flex;
335
+ align-items: center;
336
+ justify-content: center;
337
+ z-index: 10;
338
+ }
339
+
340
+ .user-message:hover .copy-link-btn,
341
+ .assistant-message:hover .copy-link-btn {
342
+ opacity: 1;
343
+ }
344
+
345
+ .copy-link-btn:hover {
346
+ background: var(--accent);
347
+ color: var(--body-bg);
348
+ border-color: var(--accent);
349
+ }
350
+
351
+ .copy-link-btn.copied {
352
+ background: var(--success, #22c55e);
353
+ color: white;
354
+ border-color: var(--success, #22c55e);
355
+ }
356
+
357
+ /* Highlight effect for deep-linked messages */
358
+ .user-message.highlight,
359
+ .assistant-message.highlight {
360
+ animation: highlight-pulse 2s ease-out;
361
+ }
362
+
363
+ @keyframes highlight-pulse {
364
+ 0% {
365
+ box-shadow: 0 0 0 3px var(--accent);
366
+ }
367
+ 100% {
368
+ box-shadow: 0 0 0 0 transparent;
369
+ }
370
+ }
371
+
372
+ .assistant-message > .message-timestamp {
373
+ padding-left: var(--line-height);
374
+ }
375
+
376
+ .assistant-text {
377
+ padding: var(--line-height);
378
+ padding-bottom: 0;
379
+ }
380
+
381
+ .message-timestamp + .assistant-text,
382
+ .message-timestamp + .thinking-block {
383
+ padding-top: 0;
384
+ }
385
+
386
+ .thinking-block + .assistant-text {
387
+ padding-top: 0;
388
+ }
389
+
390
+ .thinking-text {
391
+ padding: var(--line-height);
392
+ color: var(--thinkingText);
393
+ font-style: italic;
394
+ white-space: pre-wrap;
395
+ }
396
+
397
+ .message-timestamp + .thinking-block .thinking-text,
398
+ .message-timestamp + .thinking-block .thinking-collapsed {
399
+ padding-top: 0;
400
+ }
401
+
402
+ .thinking-collapsed {
403
+ display: none;
404
+ padding: var(--line-height);
405
+ color: var(--thinkingText);
406
+ font-style: italic;
407
+ }
408
+
409
+ /* Tool execution */
410
+ .tool-execution {
411
+ padding: var(--line-height);
412
+ border-radius: 4px;
413
+ }
414
+
415
+ .tool-execution + .tool-execution {
416
+ margin-top: var(--line-height);
417
+ }
418
+
419
+ .assistant-text + .tool-execution {
420
+ margin-top: var(--line-height);
421
+ }
422
+
423
+ .tool-execution.pending { background: var(--toolPendingBg); }
424
+ .tool-execution.success { background: var(--toolSuccessBg); }
425
+ .tool-execution.error { background: var(--toolErrorBg); }
426
+
427
+ .tool-header, .tool-name {
428
+ font-weight: bold;
429
+ }
430
+
431
+ .tool-path {
432
+ color: var(--accent);
433
+ word-break: break-all;
434
+ }
435
+
436
+ .line-numbers {
437
+ color: var(--warning);
438
+ }
439
+
440
+ .line-count {
441
+ color: var(--dim);
442
+ }
443
+
444
+ .tool-command {
445
+ font-weight: bold;
446
+ white-space: pre-wrap;
447
+ word-wrap: break-word;
448
+ overflow-wrap: break-word;
449
+ word-break: break-word;
450
+ }
451
+
452
+ .tool-output {
453
+ margin-top: var(--line-height);
454
+ color: var(--toolOutput);
455
+ word-wrap: break-word;
456
+ overflow-wrap: break-word;
457
+ word-break: break-word;
458
+ font-family: inherit;
459
+ overflow-x: auto;
460
+ }
461
+
462
+ .tool-output > div,
463
+ .output-preview,
464
+ .output-full {
465
+ margin: 0;
466
+ padding: 0;
467
+ line-height: var(--line-height);
468
+ }
469
+
470
+ .tool-output pre {
471
+ margin: 0;
472
+ padding: 0;
473
+ font-family: inherit;
474
+ color: inherit;
475
+ white-space: pre-wrap;
476
+ word-wrap: break-word;
477
+ overflow-wrap: break-word;
478
+ }
479
+
480
+ .tool-output code {
481
+ padding: 0;
482
+ background: none;
483
+ color: var(--text);
484
+ }
485
+
486
+ .tool-output.expandable {
487
+ cursor: pointer;
488
+ }
489
+
490
+ .tool-output.expandable:hover {
491
+ opacity: 0.9;
492
+ }
493
+
494
+ .tool-output.expandable .output-full {
495
+ display: none;
496
+ }
497
+
498
+ .tool-output.expandable.expanded .output-preview {
499
+ display: none;
500
+ }
501
+
502
+ .tool-output.expandable.expanded .output-full {
503
+ display: block;
504
+ }
505
+
506
+ .tool-images {
507
+ }
508
+
509
+ .tool-image {
510
+ max-width: 100%;
511
+ max-height: 500px;
512
+ border-radius: 4px;
513
+ margin: var(--line-height) 0;
514
+ }
515
+
516
+ .expand-hint {
517
+ color: var(--toolOutput);
518
+ }
519
+
520
+ /* Diff */
521
+ .tool-diff {
522
+ font-size: 11px;
523
+ overflow-x: auto;
524
+ white-space: pre;
525
+ }
526
+
527
+ .diff-added { color: var(--toolDiffAdded); }
528
+ .diff-removed { color: var(--toolDiffRemoved); }
529
+ .diff-context { color: var(--toolDiffContext); }
530
+
531
+ /* Model change */
532
+ .model-change {
533
+ padding: 0 var(--line-height);
534
+ color: var(--dim);
535
+ font-size: 11px;
536
+ }
537
+
538
+ .model-name {
539
+ color: var(--borderAccent);
540
+ font-weight: bold;
541
+ }
542
+
543
+ /* Compaction / Branch Summary - matches customMessage colors from TUI */
544
+ .compaction {
545
+ background: var(--customMessageBg);
546
+ border-radius: 4px;
547
+ padding: var(--line-height);
548
+ cursor: pointer;
549
+ }
550
+
551
+ .compaction-label {
552
+ color: var(--customMessageLabel);
553
+ font-weight: bold;
554
+ }
555
+
556
+ .compaction-collapsed {
557
+ color: var(--customMessageText);
558
+ }
559
+
560
+ .compaction-content {
561
+ display: none;
562
+ color: var(--customMessageText);
563
+ white-space: pre-wrap;
564
+ margin-top: var(--line-height);
565
+ }
566
+
567
+ .compaction.expanded .compaction-collapsed {
568
+ display: none;
569
+ }
570
+
571
+ .compaction.expanded .compaction-content {
572
+ display: block;
573
+ }
574
+
575
+ /* System prompt */
576
+ .system-prompt {
577
+ background: var(--customMessageBg);
578
+ padding: var(--line-height);
579
+ border-radius: 4px;
580
+ margin-bottom: var(--line-height);
581
+ }
582
+
583
+ .system-prompt.expandable {
584
+ cursor: pointer;
585
+ }
586
+
587
+ .system-prompt-header {
588
+ font-weight: bold;
589
+ color: var(--customMessageLabel);
590
+ }
591
+
592
+ .system-prompt-preview {
593
+ color: var(--customMessageText);
594
+ white-space: pre-wrap;
595
+ word-wrap: break-word;
596
+ font-size: 11px;
597
+ margin-top: var(--line-height);
598
+ }
599
+
600
+ .system-prompt-expand-hint {
601
+ color: var(--muted);
602
+ font-style: italic;
603
+ margin-top: 4px;
604
+ }
605
+
606
+ .system-prompt-full {
607
+ display: none;
608
+ color: var(--customMessageText);
609
+ white-space: pre-wrap;
610
+ word-wrap: break-word;
611
+ font-size: 11px;
612
+ margin-top: var(--line-height);
613
+ }
614
+
615
+ .system-prompt.expanded .system-prompt-preview,
616
+ .system-prompt.expanded .system-prompt-expand-hint {
617
+ display: none;
618
+ }
619
+
620
+ .system-prompt.expanded .system-prompt-full {
621
+ display: block;
622
+ }
623
+
624
+ .system-prompt.provider-prompt {
625
+ border-left: 3px solid var(--warning);
626
+ }
627
+
628
+ .system-prompt-note {
629
+ font-size: 10px;
630
+ font-style: italic;
631
+ color: var(--muted);
632
+ margin-top: 4px;
633
+ }
634
+
635
+ /* Tools list */
636
+ .tools-list {
637
+ background: var(--customMessageBg);
638
+ padding: var(--line-height);
639
+ border-radius: 4px;
640
+ margin-bottom: var(--line-height);
641
+ }
642
+
643
+ .tools-header {
644
+ font-weight: bold;
645
+ color: var(--customMessageLabel);
646
+ margin-bottom: var(--line-height);
647
+ }
648
+
649
+ .tool-item {
650
+ font-size: 11px;
651
+ }
652
+
653
+ .tool-item-name {
654
+ font-weight: bold;
655
+ color: var(--text);
656
+ }
657
+
658
+ .tool-item-desc {
659
+ color: var(--dim);
660
+ }
661
+
662
+ /* Hook/custom messages */
663
+ .hook-message {
664
+ background: var(--customMessageBg);
665
+ color: var(--customMessageText);
666
+ padding: var(--line-height);
667
+ border-radius: 4px;
668
+ }
669
+
670
+ .hook-type {
671
+ color: var(--customMessageLabel);
672
+ font-weight: bold;
673
+ }
674
+
675
+ /* Branch summary */
676
+ .branch-summary {
677
+ background: var(--customMessageBg);
678
+ padding: var(--line-height);
679
+ border-radius: 4px;
680
+ }
681
+
682
+ .branch-summary-header {
683
+ font-weight: bold;
684
+ color: var(--borderAccent);
685
+ }
686
+
687
+ /* Error */
688
+ .error-text {
689
+ color: var(--error);
690
+ padding: 0 var(--line-height);
691
+ }
692
+
693
+ /* Images */
694
+ .message-images {
695
+ margin-bottom: 12px;
696
+ }
697
+
698
+ .message-image {
699
+ max-width: 100%;
700
+ max-height: 400px;
701
+ border-radius: 4px;
702
+ margin: var(--line-height) 0;
703
+ }
704
+
705
+ /* Markdown content */
706
+ .markdown-content h1,
707
+ .markdown-content h2,
708
+ .markdown-content h3,
709
+ .markdown-content h4,
710
+ .markdown-content h5,
711
+ .markdown-content h6 {
712
+ color: var(--mdHeading);
713
+ margin: var(--line-height) 0 0 0;
714
+ font-weight: bold;
715
+ }
716
+
717
+ .markdown-content h1 { font-size: 1em; }
718
+ .markdown-content h2 { font-size: 1em; }
719
+ .markdown-content h3 { font-size: 1em; }
720
+ .markdown-content h4 { font-size: 1em; }
721
+ .markdown-content h5 { font-size: 1em; }
722
+ .markdown-content h6 { font-size: 1em; }
723
+ .markdown-content p { margin: 0; }
724
+ .markdown-content p + p { margin-top: var(--line-height); }
725
+
726
+ .markdown-content a {
727
+ color: var(--mdLink);
728
+ text-decoration: underline;
729
+ }
730
+
731
+ .markdown-content code {
732
+ background: rgba(128, 128, 128, 0.2);
733
+ color: var(--mdCode);
734
+ padding: 0 4px;
735
+ border-radius: 3px;
736
+ font-family: inherit;
737
+ }
738
+
739
+ .markdown-content pre {
740
+ background: transparent;
741
+ margin: var(--line-height) 0;
742
+ overflow-x: auto;
743
+ }
744
+
745
+ .markdown-content pre code {
746
+ display: block;
747
+ background: none;
748
+ color: var(--text);
749
+ }
750
+
751
+ .markdown-content blockquote {
752
+ border-left: 3px solid var(--mdQuoteBorder);
753
+ padding-left: var(--line-height);
754
+ margin: var(--line-height) 0;
755
+ color: var(--mdQuote);
756
+ font-style: italic;
757
+ }
758
+
759
+ .markdown-content ul,
760
+ .markdown-content ol {
761
+ margin: var(--line-height) 0;
762
+ padding-left: calc(var(--line-height) * 2);
763
+ }
764
+
765
+ .markdown-content li { margin: 0; }
766
+ .markdown-content li::marker { color: var(--mdListBullet); }
767
+
768
+ .markdown-content hr {
769
+ border: none;
770
+ border-top: 1px solid var(--mdHr);
771
+ margin: var(--line-height) 0;
772
+ }
773
+
774
+ .markdown-content table {
775
+ border-collapse: collapse;
776
+ margin: 0.5em 0;
777
+ width: 100%;
778
+ }
779
+
780
+ .markdown-content th,
781
+ .markdown-content td {
782
+ border: 1px solid var(--mdCodeBlockBorder);
783
+ padding: 6px 10px;
784
+ text-align: left;
785
+ }
786
+
787
+ .markdown-content th {
788
+ background: rgba(128, 128, 128, 0.1);
789
+ font-weight: bold;
790
+ }
791
+
792
+ .markdown-content img {
793
+ max-width: 100%;
794
+ border-radius: 4px;
795
+ }
796
+
797
+ /* Syntax highlighting */
798
+ .hljs { background: transparent; color: var(--text); }
799
+ .hljs-comment, .hljs-quote { color: var(--syntaxComment); }
800
+ .hljs-keyword, .hljs-selector-tag { color: var(--syntaxKeyword); }
801
+ .hljs-number, .hljs-literal { color: var(--syntaxNumber); }
802
+ .hljs-string, .hljs-doctag { color: var(--syntaxString); }
803
+ /* Function names: hljs v11 uses .hljs-title.function_ compound class */
804
+ .hljs-function, .hljs-title, .hljs-title.function_, .hljs-section, .hljs-name { color: var(--syntaxFunction); }
805
+ /* Types: hljs v11 uses .hljs-title.class_ for class names */
806
+ .hljs-type, .hljs-class, .hljs-title.class_, .hljs-built_in { color: var(--syntaxType); }
807
+ .hljs-attr, .hljs-variable, .hljs-variable.language_, .hljs-params, .hljs-property { color: var(--syntaxVariable); }
808
+ .hljs-meta, .hljs-meta .hljs-keyword, .hljs-meta .hljs-string { color: var(--syntaxKeyword); }
809
+ .hljs-operator { color: var(--syntaxOperator); }
810
+ .hljs-punctuation { color: var(--syntaxPunctuation); }
811
+ .hljs-subst { color: var(--text); }
812
+
813
+ /* Footer */
814
+ .footer {
815
+ margin-top: 48px;
816
+ padding: 20px;
817
+ text-align: center;
818
+ color: var(--dim);
819
+ font-size: 10px;
820
+ }
821
+
822
+ /* Mobile */
823
+ #hamburger {
824
+ display: none;
825
+ position: fixed;
826
+ top: 10px;
827
+ left: 10px;
828
+ z-index: 100;
829
+ padding: 3px 8px;
830
+ font-size: 12px;
831
+ font-family: inherit;
832
+ background: transparent;
833
+ color: var(--muted);
834
+ border: 1px solid var(--dim);
835
+ border-radius: 3px;
836
+ cursor: pointer;
837
+ }
838
+
839
+ #hamburger:hover {
840
+ color: var(--text);
841
+ border-color: var(--text);
842
+ }
843
+
844
+
845
+
846
+ #sidebar-overlay {
847
+ display: none;
848
+ position: fixed;
849
+ top: 0;
850
+ left: 0;
851
+ right: 0;
852
+ bottom: 0;
853
+ background: rgba(0, 0, 0, 0.5);
854
+ z-index: 98;
855
+ }
856
+
857
+ @media (max-width: 900px) {
858
+ #sidebar {
859
+ position: fixed;
860
+ left: -400px;
861
+ width: 400px;
862
+ top: 0;
863
+ bottom: 0;
864
+ height: 100vh;
865
+ z-index: 99;
866
+ transition: left 0.3s;
867
+ }
868
+
869
+ #sidebar.open {
870
+ left: 0;
871
+ }
872
+
873
+ #sidebar-overlay.open {
874
+ display: block;
875
+ }
876
+
877
+ #hamburger {
878
+ display: block;
879
+ }
880
+
881
+ .sidebar-close {
882
+ display: block;
883
+ }
884
+
885
+ #content {
886
+ padding: var(--line-height) 16px;
887
+ }
888
+
889
+ #content > * {
890
+ max-width: 100%;
891
+ }
892
+ }
893
+
894
+ @media (max-width: 500px) {
895
+ #sidebar {
896
+ width: 100vw;
897
+ left: -100vw;
898
+ }
899
+ }
900
+
901
+ @media print {
902
+ #sidebar, #sidebar-toggle { display: none !important; }
903
+ body { background: white; color: black; }
904
+ #content { max-width: none; }
905
+ }