@aigencydev/cli 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 (104) hide show
  1. package/README.md +83 -0
  2. package/dist/agent/chunker.js +59 -0
  3. package/dist/agent/chunker.js.map +1 -0
  4. package/dist/agent/history.js +35 -0
  5. package/dist/agent/history.js.map +1 -0
  6. package/dist/agent/loop.js +219 -0
  7. package/dist/agent/loop.js.map +1 -0
  8. package/dist/agent/memory.js +177 -0
  9. package/dist/agent/memory.js.map +1 -0
  10. package/dist/api-client/auth.js +43 -0
  11. package/dist/api-client/auth.js.map +1 -0
  12. package/dist/api-client/base.js +154 -0
  13. package/dist/api-client/base.js.map +1 -0
  14. package/dist/api-client/stream.js +123 -0
  15. package/dist/api-client/stream.js.map +1 -0
  16. package/dist/api-client/updates.js +31 -0
  17. package/dist/api-client/updates.js.map +1 -0
  18. package/dist/api-client/usage.js +15 -0
  19. package/dist/api-client/usage.js.map +1 -0
  20. package/dist/auth/oauth.js +178 -0
  21. package/dist/auth/oauth.js.map +1 -0
  22. package/dist/auth/pkce.js +19 -0
  23. package/dist/auth/pkce.js.map +1 -0
  24. package/dist/auth/session.js +48 -0
  25. package/dist/auth/session.js.map +1 -0
  26. package/dist/auth/storage.js +142 -0
  27. package/dist/auth/storage.js.map +1 -0
  28. package/dist/cli.js +161 -0
  29. package/dist/cli.js.map +1 -0
  30. package/dist/commands/chat.js +76 -0
  31. package/dist/commands/chat.js.map +1 -0
  32. package/dist/commands/help.js +61 -0
  33. package/dist/commands/help.js.map +1 -0
  34. package/dist/commands/init.js +43 -0
  35. package/dist/commands/init.js.map +1 -0
  36. package/dist/commands/login.js +153 -0
  37. package/dist/commands/login.js.map +1 -0
  38. package/dist/commands/logout.js +30 -0
  39. package/dist/commands/logout.js.map +1 -0
  40. package/dist/commands/update.js +88 -0
  41. package/dist/commands/update.js.map +1 -0
  42. package/dist/commands/usage.js +64 -0
  43. package/dist/commands/usage.js.map +1 -0
  44. package/dist/config/defaults.js +54 -0
  45. package/dist/config/defaults.js.map +1 -0
  46. package/dist/config/hooks.js +99 -0
  47. package/dist/config/hooks.js.map +1 -0
  48. package/dist/config/paths.js +62 -0
  49. package/dist/config/paths.js.map +1 -0
  50. package/dist/config/settings.js +80 -0
  51. package/dist/config/settings.js.map +1 -0
  52. package/dist/index.js +36 -0
  53. package/dist/index.js.map +1 -0
  54. package/dist/security/command-filter.js +121 -0
  55. package/dist/security/command-filter.js.map +1 -0
  56. package/dist/security/sandbox.js +182 -0
  57. package/dist/security/sandbox.js.map +1 -0
  58. package/dist/security/sanitize.js +59 -0
  59. package/dist/security/sanitize.js.map +1 -0
  60. package/dist/tools/bash.js +206 -0
  61. package/dist/tools/bash.js.map +1 -0
  62. package/dist/tools/diff.js +56 -0
  63. package/dist/tools/diff.js.map +1 -0
  64. package/dist/tools/edit-file.js +165 -0
  65. package/dist/tools/edit-file.js.map +1 -0
  66. package/dist/tools/list-files.js +116 -0
  67. package/dist/tools/list-files.js.map +1 -0
  68. package/dist/tools/read-file.js +107 -0
  69. package/dist/tools/read-file.js.map +1 -0
  70. package/dist/tools/registry.js +54 -0
  71. package/dist/tools/registry.js.map +1 -0
  72. package/dist/tools/search-files.js +159 -0
  73. package/dist/tools/search-files.js.map +1 -0
  74. package/dist/tools/types.js +5 -0
  75. package/dist/tools/types.js.map +1 -0
  76. package/dist/tools/write-file.js +141 -0
  77. package/dist/tools/write-file.js.map +1 -0
  78. package/dist/types/index.js +8 -0
  79. package/dist/types/index.js.map +1 -0
  80. package/dist/ui/App.js +264 -0
  81. package/dist/ui/App.js.map +1 -0
  82. package/dist/ui/InputBar.js +22 -0
  83. package/dist/ui/InputBar.js.map +1 -0
  84. package/dist/ui/MessageList.js +82 -0
  85. package/dist/ui/MessageList.js.map +1 -0
  86. package/dist/ui/ModeIndicator.js +23 -0
  87. package/dist/ui/ModeIndicator.js.map +1 -0
  88. package/dist/ui/PermissionPrompt.js +61 -0
  89. package/dist/ui/PermissionPrompt.js.map +1 -0
  90. package/dist/ui/StatusBar.js +39 -0
  91. package/dist/ui/StatusBar.js.map +1 -0
  92. package/dist/ui/theme.js +42 -0
  93. package/dist/ui/theme.js.map +1 -0
  94. package/dist/utils/abort.js +61 -0
  95. package/dist/utils/abort.js.map +1 -0
  96. package/dist/utils/errors.js +63 -0
  97. package/dist/utils/errors.js.map +1 -0
  98. package/dist/utils/formatting.js +102 -0
  99. package/dist/utils/formatting.js.map +1 -0
  100. package/dist/utils/logger.js +43 -0
  101. package/dist/utils/logger.js.map +1 -0
  102. package/dist/version.js +10 -0
  103. package/dist/version.js.map +1 -0
  104. package/package.json +64 -0
package/dist/ui/App.js ADDED
@@ -0,0 +1,264 @@
1
+ /**
2
+ * App — AIGENCY CLI interactive chat ana bileşeni.
3
+ *
4
+ * Layout (üstten alta):
5
+ * - Header (ASCII logo + versiyon)
6
+ * - MessageList (sohbet geçmişi)
7
+ * - PermissionPrompt (aktifse)
8
+ * - InputBar (meşgulse disabled)
9
+ * - StatusBar (token, mode, proje)
10
+ *
11
+ * State makinesi:
12
+ * idle → user submits → busy → permission? → tool exec → ... → idle
13
+ */
14
+ import React, { useCallback, useEffect, useRef, useState } from "react";
15
+ import { Box, Text, useApp, useInput } from "ink";
16
+ import { MessageList } from "./MessageList.js";
17
+ import { InputBar } from "./InputBar.js";
18
+ import { StatusBar } from "./StatusBar.js";
19
+ import { PermissionPrompt } from "./PermissionPrompt.js";
20
+ import { ChatHistory } from "../agent/history.js";
21
+ import { runAgentLoop, clearSessionApprovalCache } from "../agent/loop.js";
22
+ import { CLI_DISPLAY_NAME, CLI_VERSION } from "../version.js";
23
+ const MODE_CYCLE = ["default", "plan", "accept_edits", "auto"];
24
+ function newId() {
25
+ return `msg-${Date.now()}-${Math.floor(Math.random() * 10000)}`;
26
+ }
27
+ export function App({ session, initialMode, initialModel, cwd, projectRoot, initialPrompt, settings, memorySummary, }) {
28
+ const { exit } = useApp();
29
+ const [messages, setMessages] = useState([]);
30
+ const [busy, setBusy] = useState(false);
31
+ const [mode, setMode] = useState(initialMode);
32
+ const [model] = useState(initialModel);
33
+ const [tokensUsed, setTokensUsed] = useState(0);
34
+ const [tokensLimit, setTokensLimit] = useState(initialModel === "max" ? 5_000_000 : 1_000_000);
35
+ const [pending, setPending] = useState(null);
36
+ const historyRef = useRef(new ChatHistory());
37
+ const abortRef = useRef(null);
38
+ const pushMessage = useCallback((msg) => {
39
+ setMessages((prev) => [...prev, { ...msg, id: newId() }]);
40
+ }, []);
41
+ // Başlangıç mesajı
42
+ useEffect(() => {
43
+ pushMessage({
44
+ kind: "info",
45
+ content: `${CLI_DISPLAY_NAME} v${CLI_VERSION} — ${session.user.name || session.user.email}`,
46
+ });
47
+ pushMessage({
48
+ kind: "info",
49
+ content: "Shift+Tab ile mod değiştirin · /help yardım · Ctrl+C çıkış",
50
+ });
51
+ }, [pushMessage, session.user.name, session.user.email]);
52
+ // Input handler — Shift+Tab mode cycle, Ctrl+C exit/abort
53
+ useInput((input, key) => {
54
+ if (key.shift && key.tab) {
55
+ if (busy)
56
+ return;
57
+ setMode((current) => {
58
+ const idx = MODE_CYCLE.indexOf(current);
59
+ const next = MODE_CYCLE[(idx + 1) % MODE_CYCLE.length] ?? "default";
60
+ pushMessage({
61
+ kind: "info",
62
+ content: `Mod değiştirildi: ${next}`,
63
+ });
64
+ return next;
65
+ });
66
+ return;
67
+ }
68
+ if (key.ctrl && input === "c") {
69
+ if (busy && abortRef.current) {
70
+ abortRef.current.abort();
71
+ pushMessage({ kind: "warning", content: "İşlem iptal edildi" });
72
+ }
73
+ else {
74
+ exit();
75
+ }
76
+ }
77
+ });
78
+ // Permission callback — Promise'i state'e bağlar, PermissionPrompt resolve eder
79
+ const requestPermission = useCallback((req) => {
80
+ return new Promise((resolve) => {
81
+ setPending({ request: req, resolve });
82
+ });
83
+ }, []);
84
+ const handlePermissionResponse = useCallback((resp) => {
85
+ if (pending) {
86
+ pending.resolve(resp);
87
+ setPending(null);
88
+ }
89
+ }, [pending]);
90
+ // Slash komut handler
91
+ const handleSlashCommand = useCallback((raw) => {
92
+ const cmd = raw.slice(1).toLowerCase().trim();
93
+ if (cmd === "clear") {
94
+ setMessages([]);
95
+ historyRef.current.clear();
96
+ clearSessionApprovalCache();
97
+ pushMessage({ kind: "info", content: "Sohbet ve oturum onayları temizlendi" });
98
+ return true;
99
+ }
100
+ if (cmd === "help") {
101
+ pushMessage({ kind: "info", content: "Komutlar: /clear /help /mode /cost /exit" });
102
+ pushMessage({ kind: "info", content: "Kısayollar: Shift+Tab mod · Ctrl+C iptal" });
103
+ return true;
104
+ }
105
+ if (cmd === "exit" || cmd === "quit") {
106
+ exit();
107
+ return true;
108
+ }
109
+ if (cmd === "cost") {
110
+ pushMessage({
111
+ kind: "info",
112
+ content: `Bu oturum: ${tokensUsed} token kullanıldı (limit ${tokensLimit})`,
113
+ });
114
+ return true;
115
+ }
116
+ if (cmd.startsWith("mode")) {
117
+ const parts = cmd.split(/\s+/);
118
+ const target = parts[1];
119
+ if (target && MODE_CYCLE.includes(target)) {
120
+ setMode(target);
121
+ pushMessage({ kind: "info", content: `Mod: ${target}` });
122
+ }
123
+ else {
124
+ pushMessage({
125
+ kind: "info",
126
+ content: `Mevcut mod: ${mode} · Kullanılabilir: ${MODE_CYCLE.join(", ")}`,
127
+ });
128
+ }
129
+ return true;
130
+ }
131
+ pushMessage({ kind: "warning", content: `Bilinmeyen slash komut: /${cmd}` });
132
+ return true;
133
+ }, [exit, mode, pushMessage, tokensLimit, tokensUsed]);
134
+ // Ana prompt submit
135
+ const handleSubmit = useCallback(async (value) => {
136
+ if (value.startsWith("/")) {
137
+ handleSlashCommand(value);
138
+ return;
139
+ }
140
+ pushMessage({ kind: "user", content: value });
141
+ setBusy(true);
142
+ const controller = new AbortController();
143
+ abortRef.current = controller;
144
+ try {
145
+ const onEvent = (event) => {
146
+ switch (event.type) {
147
+ case "agent_think":
148
+ pushMessage({ kind: "think", content: event.content });
149
+ break;
150
+ case "agent_tool_call":
151
+ pushMessage({
152
+ kind: "tool_call",
153
+ content: JSON.stringify(event.params).slice(0, 200),
154
+ toolName: event.toolName,
155
+ toolStatus: "pending",
156
+ });
157
+ break;
158
+ case "agent_tool_result": {
159
+ const status = event.result.success ? "ok" : "error";
160
+ pushMessage({
161
+ kind: "tool_result",
162
+ content: event.result.success
163
+ ? event.result.output.slice(0, 500)
164
+ : event.result.error || "Hata",
165
+ toolStatus: status,
166
+ });
167
+ break;
168
+ }
169
+ case "agent_message":
170
+ if (!event.delta) {
171
+ pushMessage({ kind: "assistant", content: event.content });
172
+ }
173
+ break;
174
+ case "cli_token_usage":
175
+ setTokensUsed(event.cumulative_month);
176
+ if (event.quota_limit > 0)
177
+ setTokensLimit(event.quota_limit);
178
+ break;
179
+ case "cli_quota_warning":
180
+ pushMessage({ kind: "warning", content: event.message });
181
+ break;
182
+ case "agent_error":
183
+ pushMessage({ kind: "error", content: event.error });
184
+ break;
185
+ case "error":
186
+ pushMessage({ kind: "error", content: event.message });
187
+ break;
188
+ case "agent_complete":
189
+ if (event.summary) {
190
+ // summary zaten agent_message ile geliyor olabilir
191
+ }
192
+ break;
193
+ }
194
+ };
195
+ const result = await runAgentLoop({
196
+ accessToken: session.access_token,
197
+ prompt: value,
198
+ history: historyRef.current,
199
+ mode,
200
+ model,
201
+ projectRoot,
202
+ workingDirectory: cwd,
203
+ signal: controller.signal,
204
+ onEvent,
205
+ requestPermission,
206
+ settings,
207
+ priorInsights: memorySummary,
208
+ });
209
+ // History'ye ekle — sadece kullanıcı + final assistant mesajı
210
+ historyRef.current.push({ role: "user", content: value });
211
+ if (result.finalMessage) {
212
+ historyRef.current.push({
213
+ role: "assistant",
214
+ content: result.finalMessage,
215
+ });
216
+ }
217
+ if (result.aborted) {
218
+ pushMessage({ kind: "warning", content: "Yanıt iptal edildi" });
219
+ }
220
+ }
221
+ catch (err) {
222
+ pushMessage({
223
+ kind: "error",
224
+ content: err.message || "Beklenmeyen hata",
225
+ });
226
+ }
227
+ finally {
228
+ setBusy(false);
229
+ abortRef.current = null;
230
+ }
231
+ }, [
232
+ cwd,
233
+ handleSlashCommand,
234
+ memorySummary,
235
+ mode,
236
+ model,
237
+ projectRoot,
238
+ pushMessage,
239
+ requestPermission,
240
+ session.access_token,
241
+ settings,
242
+ ]);
243
+ // Initial prompt varsa otomatik submit
244
+ const didInitialRef = useRef(false);
245
+ useEffect(() => {
246
+ if (didInitialRef.current)
247
+ return;
248
+ if (initialPrompt && !busy) {
249
+ didInitialRef.current = true;
250
+ handleSubmit(initialPrompt);
251
+ }
252
+ }, [busy, handleSubmit, initialPrompt]);
253
+ return (React.createElement(Box, { flexDirection: "column" },
254
+ React.createElement(Box, { paddingX: 1 },
255
+ React.createElement(Text, { color: "cyan", bold: true }, "AIGENCY CLI"),
256
+ React.createElement(Text, { color: "gray" },
257
+ " v",
258
+ CLI_VERSION)),
259
+ React.createElement(MessageList, { messages: messages }),
260
+ pending && (React.createElement(PermissionPrompt, { request: pending.request, onRespond: handlePermissionResponse })),
261
+ !pending && React.createElement(InputBar, { onSubmit: handleSubmit, disabled: busy }),
262
+ React.createElement(StatusBar, { tokensUsed: tokensUsed, tokensLimit: tokensLimit, mode: mode, model: model, cwd: cwd, busy: busy })));
263
+ }
264
+ //# sourceMappingURL=App.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"App.js","sourceRoot":"","sources":["../../src/ui/App.tsx"],"names":[],"mappings":"AAAA;;;;;;;;;;;;GAYG;AAEH,OAAO,KAAK,EAAE,EAAE,WAAW,EAAE,SAAS,EAAW,MAAM,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AACjF,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,KAAK,CAAC;AAClD,OAAO,EAAE,WAAW,EAAkB,MAAM,kBAAkB,CAAC;AAC/D,OAAO,EAAE,QAAQ,EAAE,MAAM,eAAe,CAAC;AACzC,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAE,gBAAgB,EAAE,MAAM,uBAAuB,CAAC;AAQzD,OAAO,EAAE,WAAW,EAAE,MAAM,qBAAqB,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,yBAAyB,EAAE,MAAM,kBAAkB,CAAC;AAC3E,OAAO,EAAE,gBAAgB,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAmB9D,MAAM,UAAU,GAAqB,CAAC,SAAS,EAAE,MAAM,EAAE,cAAc,EAAE,MAAM,CAAC,CAAC;AAEjF,SAAS,KAAK;IACZ,OAAO,OAAO,IAAI,CAAC,GAAG,EAAE,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,KAAK,CAAC,EAAE,CAAC;AAClE,CAAC;AAED,MAAM,UAAU,GAAG,CAAC,EAClB,OAAO,EACP,WAAW,EACX,YAAY,EACZ,GAAG,EACH,WAAW,EACX,aAAa,EACb,QAAQ,EACR,aAAa,GACP;IACN,MAAM,EAAE,IAAI,EAAE,GAAG,MAAM,EAAE,CAAC;IAC1B,MAAM,CAAC,QAAQ,EAAE,WAAW,CAAC,GAAG,QAAQ,CAAc,EAAE,CAAC,CAAC;IAC1D,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IACxC,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,QAAQ,CAAiB,WAAW,CAAC,CAAC;IAC9D,MAAM,CAAC,KAAK,CAAC,GAAG,QAAQ,CAAY,YAAY,CAAC,CAAC;IAClD,MAAM,CAAC,UAAU,EAAE,aAAa,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;IAChD,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,CAC5C,YAAY,KAAK,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAC/C,CAAC;IACF,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,QAAQ,CAA2B,IAAI,CAAC,CAAC;IAEvE,MAAM,UAAU,GAAG,MAAM,CAAC,IAAI,WAAW,EAAE,CAAC,CAAC;IAC7C,MAAM,QAAQ,GAAG,MAAM,CAAyB,IAAI,CAAC,CAAC;IAEtD,MAAM,WAAW,GAAG,WAAW,CAAC,CAAC,GAA0B,EAAE,EAAE;QAC7D,WAAW,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,GAAG,IAAI,EAAE,EAAE,GAAG,GAAG,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC,CAAC;IAC5D,CAAC,EAAE,EAAE,CAAC,CAAC;IAEP,mBAAmB;IACnB,SAAS,CAAC,GAAG,EAAE;QACb,WAAW,CAAC;YACV,IAAI,EAAE,MAAM;YACZ,OAAO,EAAE,GAAG,gBAAgB,KAAK,WAAW,MAAM,OAAO,CAAC,IAAI,CAAC,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC,KAAK,EAAE;SAC5F,CAAC,CAAC;QACH,WAAW,CAAC;YACV,IAAI,EAAE,MAAM;YACZ,OAAO,EAAE,4DAA4D;SACtE,CAAC,CAAC;IACL,CAAC,EAAE,CAAC,WAAW,EAAE,OAAO,CAAC,IAAI,CAAC,IAAI,EAAE,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;IAEzD,0DAA0D;IAC1D,QAAQ,CAAC,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE;QACtB,IAAI,GAAG,CAAC,KAAK,IAAI,GAAG,CAAC,GAAG,EAAE,CAAC;YACzB,IAAI,IAAI;gBAAE,OAAO;YACjB,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;gBAClB,MAAM,GAAG,GAAG,UAAU,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;gBACxC,MAAM,IAAI,GAAG,UAAU,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,UAAU,CAAC,MAAM,CAAC,IAAI,SAAS,CAAC;gBACpE,WAAW,CAAC;oBACV,IAAI,EAAE,MAAM;oBACZ,OAAO,EAAE,qBAAqB,IAAI,EAAE;iBACrC,CAAC,CAAC;gBACH,OAAO,IAAI,CAAC;YACd,CAAC,CAAC,CAAC;YACH,OAAO;QACT,CAAC;QACD,IAAI,GAAG,CAAC,IAAI,IAAI,KAAK,KAAK,GAAG,EAAE,CAAC;YAC9B,IAAI,IAAI,IAAI,QAAQ,CAAC,OAAO,EAAE,CAAC;gBAC7B,QAAQ,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;gBACzB,WAAW,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,OAAO,EAAE,oBAAoB,EAAE,CAAC,CAAC;YAClE,CAAC;iBAAM,CAAC;gBACN,IAAI,EAAE,CAAC;YACT,CAAC;QACH,CAAC;IACH,CAAC,CAAC,CAAC;IAEH,gFAAgF;IAChF,MAAM,iBAAiB,GAAG,WAAW,CACnC,CAAC,GAAsB,EAA+B,EAAE;QACtD,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;YAC7B,UAAU,CAAC,EAAE,OAAO,EAAE,GAAG,EAAE,OAAO,EAAE,CAAC,CAAC;QACxC,CAAC,CAAC,CAAC;IACL,CAAC,EACD,EAAE,CACH,CAAC;IAEF,MAAM,wBAAwB,GAAG,WAAW,CAC1C,CAAC,IAAwB,EAAE,EAAE;QAC3B,IAAI,OAAO,EAAE,CAAC;YACZ,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;YACtB,UAAU,CAAC,IAAI,CAAC,CAAC;QACnB,CAAC;IACH,CAAC,EACD,CAAC,OAAO,CAAC,CACV,CAAC;IAEF,sBAAsB;IACtB,MAAM,kBAAkB,GAAG,WAAW,CACpC,CAAC,GAAW,EAAW,EAAE;QACvB,MAAM,GAAG,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,IAAI,EAAE,CAAC;QAC9C,IAAI,GAAG,KAAK,OAAO,EAAE,CAAC;YACpB,WAAW,CAAC,EAAE,CAAC,CAAC;YAChB,UAAU,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;YAC3B,yBAAyB,EAAE,CAAC;YAC5B,WAAW,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,sCAAsC,EAAE,CAAC,CAAC;YAC/E,OAAO,IAAI,CAAC;QACd,CAAC;QACD,IAAI,GAAG,KAAK,MAAM,EAAE,CAAC;YACnB,WAAW,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,0CAA0C,EAAE,CAAC,CAAC;YACnF,WAAW,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,0CAA0C,EAAE,CAAC,CAAC;YACnF,OAAO,IAAI,CAAC;QACd,CAAC;QACD,IAAI,GAAG,KAAK,MAAM,IAAI,GAAG,KAAK,MAAM,EAAE,CAAC;YACrC,IAAI,EAAE,CAAC;YACP,OAAO,IAAI,CAAC;QACd,CAAC;QACD,IAAI,GAAG,KAAK,MAAM,EAAE,CAAC;YACnB,WAAW,CAAC;gBACV,IAAI,EAAE,MAAM;gBACZ,OAAO,EAAE,cAAc,UAAU,4BAA4B,WAAW,GAAG;aAC5E,CAAC,CAAC;YACH,OAAO,IAAI,CAAC;QACd,CAAC;QACD,IAAI,GAAG,CAAC,UAAU,CAAC,MAAM,CAAC,EAAE,CAAC;YAC3B,MAAM,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;YAC/B,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,CAA+B,CAAC;YACtD,IAAI,MAAM,IAAI,UAAU,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC;gBAC1C,OAAO,CAAC,MAAM,CAAC,CAAC;gBAChB,WAAW,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,QAAQ,MAAM,EAAE,EAAE,CAAC,CAAC;YAC3D,CAAC;iBAAM,CAAC;gBACN,WAAW,CAAC;oBACV,IAAI,EAAE,MAAM;oBACZ,OAAO,EAAE,eAAe,IAAI,sBAAsB,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE;iBAC1E,CAAC,CAAC;YACL,CAAC;YACD,OAAO,IAAI,CAAC;QACd,CAAC;QACD,WAAW,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,OAAO,EAAE,4BAA4B,GAAG,EAAE,EAAE,CAAC,CAAC;QAC7E,OAAO,IAAI,CAAC;IACd,CAAC,EACD,CAAC,IAAI,EAAE,IAAI,EAAE,WAAW,EAAE,WAAW,EAAE,UAAU,CAAC,CACnD,CAAC;IAEF,oBAAoB;IACpB,MAAM,YAAY,GAAG,WAAW,CAC9B,KAAK,EAAE,KAAa,EAAE,EAAE;QACtB,IAAI,KAAK,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC;YAC1B,kBAAkB,CAAC,KAAK,CAAC,CAAC;YAC1B,OAAO;QACT,CAAC;QACD,WAAW,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC;QAC9C,OAAO,CAAC,IAAI,CAAC,CAAC;QAEd,MAAM,UAAU,GAAG,IAAI,eAAe,EAAE,CAAC;QACzC,QAAQ,CAAC,OAAO,GAAG,UAAU,CAAC;QAE9B,IAAI,CAAC;YACH,MAAM,OAAO,GAAG,CAAC,KAAkB,EAAQ,EAAE;gBAC3C,QAAQ,KAAK,CAAC,IAAI,EAAE,CAAC;oBACnB,KAAK,aAAa;wBAChB,WAAW,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC;wBACvD,MAAM;oBACR,KAAK,iBAAiB;wBACpB,WAAW,CAAC;4BACV,IAAI,EAAE,WAAW;4BACjB,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC;4BACnD,QAAQ,EAAE,KAAK,CAAC,QAAQ;4BACxB,UAAU,EAAE,SAAS;yBACtB,CAAC,CAAC;wBACH,MAAM;oBACR,KAAK,mBAAmB,CAAC,CAAC,CAAC;wBACzB,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC;wBACrD,WAAW,CAAC;4BACV,IAAI,EAAE,aAAa;4BACnB,OAAO,EAAE,KAAK,CAAC,MAAM,CAAC,OAAO;gCAC3B,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC;gCACnC,CAAC,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,IAAI,MAAM;4BAChC,UAAU,EAAE,MAAM;yBACnB,CAAC,CAAC;wBACH,MAAM;oBACR,CAAC;oBACD,KAAK,eAAe;wBAClB,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE,CAAC;4BACjB,WAAW,CAAC,EAAE,IAAI,EAAE,WAAW,EAAE,OAAO,EAAE,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC;wBAC7D,CAAC;wBACD,MAAM;oBACR,KAAK,iBAAiB;wBACpB,aAAa,CAAC,KAAK,CAAC,gBAAgB,CAAC,CAAC;wBACtC,IAAI,KAAK,CAAC,WAAW,GAAG,CAAC;4BAAE,cAAc,CAAC,KAAK,CAAC,WAAW,CAAC,CAAC;wBAC7D,MAAM;oBACR,KAAK,mBAAmB;wBACtB,WAAW,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,OAAO,EAAE,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC;wBACzD,MAAM;oBACR,KAAK,aAAa;wBAChB,WAAW,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,CAAC,KAAK,EAAE,CAAC,CAAC;wBACrD,MAAM;oBACR,KAAK,OAAO;wBACV,WAAW,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC;wBACvD,MAAM;oBACR,KAAK,gBAAgB;wBACnB,IAAI,KAAK,CAAC,OAAO,EAAE,CAAC;4BAClB,mDAAmD;wBACrD,CAAC;wBACD,MAAM;gBACV,CAAC;YACH,CAAC,CAAC;YAEF,MAAM,MAAM,GAAG,MAAM,YAAY,CAAC;gBAChC,WAAW,EAAE,OAAO,CAAC,YAAY;gBACjC,MAAM,EAAE,KAAK;gBACb,OAAO,EAAE,UAAU,CAAC,OAAO;gBAC3B,IAAI;gBACJ,KAAK;gBACL,WAAW;gBACX,gBAAgB,EAAE,GAAG;gBACrB,MAAM,EAAE,UAAU,CAAC,MAAM;gBACzB,OAAO;gBACP,iBAAiB;gBACjB,QAAQ;gBACR,aAAa,EAAE,aAAa;aAC7B,CAAC,CAAC;YAEH,8DAA8D;YAC9D,UAAU,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC;YAC1D,IAAI,MAAM,CAAC,YAAY,EAAE,CAAC;gBACxB,UAAU,CAAC,OAAO,CAAC,IAAI,CAAC;oBACtB,IAAI,EAAE,WAAW;oBACjB,OAAO,EAAE,MAAM,CAAC,YAAY;iBAC7B,CAAC,CAAC;YACL,CAAC;YAED,IAAI,MAAM,CAAC,OAAO,EAAE,CAAC;gBACnB,WAAW,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,OAAO,EAAE,oBAAoB,EAAE,CAAC,CAAC;YAClE,CAAC;QACH,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACb,WAAW,CAAC;gBACV,IAAI,EAAE,OAAO;gBACb,OAAO,EAAG,GAAa,CAAC,OAAO,IAAI,kBAAkB;aACtD,CAAC,CAAC;QACL,CAAC;gBAAS,CAAC;YACT,OAAO,CAAC,KAAK,CAAC,CAAC;YACf,QAAQ,CAAC,OAAO,GAAG,IAAI,CAAC;QAC1B,CAAC;IACH,CAAC,EACD;QACE,GAAG;QACH,kBAAkB;QAClB,aAAa;QACb,IAAI;QACJ,KAAK;QACL,WAAW;QACX,WAAW;QACX,iBAAiB;QACjB,OAAO,CAAC,YAAY;QACpB,QAAQ;KACT,CACF,CAAC;IAEF,uCAAuC;IACvC,MAAM,aAAa,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;IACpC,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,aAAa,CAAC,OAAO;YAAE,OAAO;QAClC,IAAI,aAAa,IAAI,CAAC,IAAI,EAAE,CAAC;YAC3B,aAAa,CAAC,OAAO,GAAG,IAAI,CAAC;YAC7B,YAAY,CAAC,aAAa,CAAC,CAAC;QAC9B,CAAC;IACH,CAAC,EAAE,CAAC,IAAI,EAAE,YAAY,EAAE,aAAa,CAAC,CAAC,CAAC;IAExC,OAAO,CACL,oBAAC,GAAG,IAAC,aAAa,EAAC,QAAQ;QACzB,oBAAC,GAAG,IAAC,QAAQ,EAAE,CAAC;YACd,oBAAC,IAAI,IAAC,KAAK,EAAC,MAAM,EAAC,IAAI,wBAEhB;YACP,oBAAC,IAAI,IAAC,KAAK,EAAC,MAAM;;gBAAI,WAAW,CAAQ,CACrC;QACN,oBAAC,WAAW,IAAC,QAAQ,EAAE,QAAQ,GAAI;QAClC,OAAO,IAAI,CACV,oBAAC,gBAAgB,IAAC,OAAO,EAAE,OAAO,CAAC,OAAO,EAAE,SAAS,EAAE,wBAAwB,GAAI,CACpF;QACA,CAAC,OAAO,IAAI,oBAAC,QAAQ,IAAC,QAAQ,EAAE,YAAY,EAAE,QAAQ,EAAE,IAAI,GAAI;QACjE,oBAAC,SAAS,IACR,UAAU,EAAE,UAAU,EACtB,WAAW,EAAE,WAAW,EACxB,IAAI,EAAE,IAAI,EACV,KAAK,EAAE,KAAK,EACZ,GAAG,EAAE,GAAG,EACR,IAAI,EAAE,IAAI,GACV,CACE,CACP,CAAC;AACJ,CAAC"}
@@ -0,0 +1,22 @@
1
+ /**
2
+ * InputBar — kullanıcı prompt girişi.
3
+ *
4
+ * Ink text-input wrapper. / ile başlarsa slash komut hint'i görünür.
5
+ */
6
+ import React, { useState } from "react";
7
+ import { Box, Text } from "ink";
8
+ import TextInput from "ink-text-input";
9
+ export function InputBar({ onSubmit, disabled, placeholder = "Komut yazın veya / ile slash komutu…", }) {
10
+ const [value, setValue] = useState("");
11
+ const handleSubmit = (submitted) => {
12
+ const trimmed = submitted.trim();
13
+ if (!trimmed)
14
+ return;
15
+ setValue("");
16
+ onSubmit(trimmed);
17
+ };
18
+ return (React.createElement(Box, { borderStyle: "round", borderColor: disabled ? "gray" : "cyan", paddingX: 1 },
19
+ React.createElement(Text, { color: disabled ? "gray" : "cyan", bold: true }, "› "),
20
+ disabled ? (React.createElement(Text, { color: "gray" }, "(me\u015Fgul \u2014 l\u00FCtfen bekleyin\u2026)")) : (React.createElement(TextInput, { value: value, onChange: setValue, onSubmit: handleSubmit, placeholder: placeholder }))));
21
+ }
22
+ //# sourceMappingURL=InputBar.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"InputBar.js","sourceRoot":"","sources":["../../src/ui/InputBar.tsx"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,EAAE,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AACxC,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAChC,OAAO,SAAS,MAAM,gBAAgB,CAAC;AAQvC,MAAM,UAAU,QAAQ,CAAC,EACvB,QAAQ,EACR,QAAQ,EACR,WAAW,GAAG,sCAAsC,GAC9C;IACN,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAC,EAAE,CAAC,CAAC;IAEvC,MAAM,YAAY,GAAG,CAAC,SAAiB,EAAQ,EAAE;QAC/C,MAAM,OAAO,GAAG,SAAS,CAAC,IAAI,EAAE,CAAC;QACjC,IAAI,CAAC,OAAO;YAAE,OAAO;QACrB,QAAQ,CAAC,EAAE,CAAC,CAAC;QACb,QAAQ,CAAC,OAAO,CAAC,CAAC;IACpB,CAAC,CAAC;IAEF,OAAO,CACL,oBAAC,GAAG,IAAC,WAAW,EAAC,OAAO,EAAC,WAAW,EAAE,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,EAAE,QAAQ,EAAE,CAAC;QAC3E,oBAAC,IAAI,IAAC,KAAK,EAAE,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,EAAE,IAAI,UAC1C,IAAI,CACA;QACN,QAAQ,CAAC,CAAC,CAAC,CACV,oBAAC,IAAI,IAAC,KAAK,EAAC,MAAM,sDAAmC,CACtD,CAAC,CAAC,CAAC,CACF,oBAAC,SAAS,IACR,KAAK,EAAE,KAAK,EACZ,QAAQ,EAAE,QAAQ,EAClB,QAAQ,EAAE,YAAY,EACtB,WAAW,EAAE,WAAW,GACxB,CACH,CACG,CACP,CAAC;AACJ,CAAC"}
@@ -0,0 +1,82 @@
1
+ /**
2
+ * MessageList — sohbet mesajlarını, tool çağrılarını ve agent düşüncelerini render eder.
3
+ *
4
+ * Her render öncesi content sanitizeForDisplay'den geçer — UI tarafı ek güvenlik ağı.
5
+ */
6
+ import React from "react";
7
+ import { Box, Text } from "ink";
8
+ import { sanitizeForDisplay } from "../security/sanitize.js";
9
+ const kindColor = {
10
+ user: "cyan",
11
+ assistant: "white",
12
+ think: "gray",
13
+ tool_call: "yellow",
14
+ tool_result: "green",
15
+ error: "red",
16
+ info: "blue",
17
+ warning: "yellow",
18
+ };
19
+ const kindPrefix = {
20
+ user: "›",
21
+ assistant: "●",
22
+ think: "…",
23
+ tool_call: "▸",
24
+ tool_result: "▪",
25
+ error: "✗",
26
+ info: "ℹ",
27
+ warning: "⚠",
28
+ };
29
+ function MessageItem({ message }) {
30
+ const color = kindColor[message.kind];
31
+ const prefix = kindPrefix[message.kind];
32
+ const safeContent = sanitizeForDisplay(message.content);
33
+ if (message.kind === "tool_call") {
34
+ return (React.createElement(Box, null,
35
+ React.createElement(Text, { color: color },
36
+ prefix,
37
+ " ",
38
+ message.toolName,
39
+ " "),
40
+ React.createElement(Text, { color: "gray" }, safeContent)));
41
+ }
42
+ if (message.kind === "tool_result") {
43
+ const statusColor = message.toolStatus === "error" ? "red" : "green";
44
+ const lines = safeContent.split("\n");
45
+ return (React.createElement(Box, { flexDirection: "column", marginLeft: 2 },
46
+ React.createElement(Text, { color: statusColor },
47
+ prefix,
48
+ " ",
49
+ lines.slice(0, 6).join("\n")),
50
+ lines.length > 6 && (React.createElement(Text, { color: "gray" },
51
+ " \u2026 (",
52
+ lines.length - 6,
53
+ " sat\u0131r daha)"))));
54
+ }
55
+ if (message.kind === "think") {
56
+ return (React.createElement(Box, { marginLeft: 2 },
57
+ React.createElement(Text, { color: color, italic: true },
58
+ prefix,
59
+ " ",
60
+ safeContent)));
61
+ }
62
+ if (message.kind === "user") {
63
+ // user input sanitize edilmez — kullanıcının kendi yazdığı bozulmamalı
64
+ return (React.createElement(Box, null,
65
+ React.createElement(Text, { color: color, bold: true },
66
+ prefix,
67
+ " ",
68
+ message.content)));
69
+ }
70
+ // assistant / info / error / warning
71
+ return (React.createElement(Box, null,
72
+ React.createElement(Text, { color: color },
73
+ prefix,
74
+ " ",
75
+ safeContent)));
76
+ }
77
+ export function MessageList({ messages, maxVisible = 30 }) {
78
+ const visible = messages.slice(-maxVisible);
79
+ return (React.createElement(Box, { flexDirection: "column", paddingX: 1 }, visible.map((msg) => (React.createElement(Box, { key: msg.id, marginBottom: msg.kind === "assistant" || msg.kind === "user" ? 1 : 0 },
80
+ React.createElement(MessageItem, { message: msg }))))));
81
+ }
82
+ //# sourceMappingURL=MessageList.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MessageList.js","sourceRoot":"","sources":["../../src/ui/MessageList.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,23 @@
1
+ /**
2
+ * ModeIndicator — mevcut izin modunu gösterir.
3
+ * Kullanıcı Shift+Tab ile döngüsel değiştirir.
4
+ */
5
+ import React from "react";
6
+ import { Box, Text } from "ink";
7
+ import { modeLabel } from "./theme.js";
8
+ const modeColorMap = {
9
+ default: "cyan",
10
+ plan: "blue",
11
+ accept_edits: "yellow",
12
+ auto: "magenta",
13
+ };
14
+ export function ModeIndicator({ mode }) {
15
+ const color = modeColorMap[mode];
16
+ const label = modeLabel[mode] || mode;
17
+ return (React.createElement(Box, null,
18
+ React.createElement(Text, { color: color, bold: true },
19
+ "[",
20
+ label,
21
+ "]")));
22
+ }
23
+ //# sourceMappingURL=ModeIndicator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ModeIndicator.js","sourceRoot":"","sources":["../../src/ui/ModeIndicator.tsx"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAEhC,OAAO,EAAE,SAAS,EAAE,MAAM,YAAY,CAAC;AAMvC,MAAM,YAAY,GAAmC;IACnD,OAAO,EAAE,MAAM;IACf,IAAI,EAAE,MAAM;IACZ,YAAY,EAAE,QAAQ;IACtB,IAAI,EAAE,SAAS;CAChB,CAAC;AAEF,MAAM,UAAU,aAAa,CAAC,EAAE,IAAI,EAAS;IAC3C,MAAM,KAAK,GAAG,YAAY,CAAC,IAAI,CAAC,CAAC;IACjC,MAAM,KAAK,GAAG,SAAS,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC;IACtC,OAAO,CACL,oBAAC,GAAG;QACF,oBAAC,IAAI,IAAC,KAAK,EAAE,KAAK,EAAE,IAAI;;YACpB,KAAK;gBACF,CACH,CACP,CAAC;AACJ,CAAC"}
@@ -0,0 +1,61 @@
1
+ /**
2
+ * PermissionPrompt — tool call için onay prompt'u.
3
+ *
4
+ * Klavye:
5
+ * y = kabul
6
+ * n = reddet
7
+ * a = oturum boyunca bu tool'u kabul et (approve_once_session)
8
+ * ESC / Ctrl+C = iptal
9
+ */
10
+ import React, { useState } from "react";
11
+ import { Box, Text, useInput } from "ink";
12
+ const severityColor = {
13
+ low: "green",
14
+ medium: "yellow",
15
+ high: "red",
16
+ };
17
+ export function PermissionPrompt({ request, onRespond, }) {
18
+ const [handled, setHandled] = useState(false);
19
+ useInput((input, key) => {
20
+ if (handled)
21
+ return;
22
+ if (key.escape) {
23
+ setHandled(true);
24
+ onRespond({ decision: "cancel" });
25
+ return;
26
+ }
27
+ const ch = input.toLowerCase();
28
+ if (ch === "y") {
29
+ setHandled(true);
30
+ onRespond({ decision: "approve" });
31
+ }
32
+ else if (ch === "n") {
33
+ setHandled(true);
34
+ onRespond({ decision: "reject" });
35
+ }
36
+ else if (ch === "a") {
37
+ setHandled(true);
38
+ onRespond({ decision: "approve_once_session" });
39
+ }
40
+ }, { isActive: !handled });
41
+ const color = severityColor[request.severity];
42
+ return (React.createElement(Box, { borderStyle: "round", borderColor: color, paddingX: 1, flexDirection: "column", marginY: 1 },
43
+ React.createElement(Text, { color: color, bold: true },
44
+ "⚠ İzin gerekli: ",
45
+ React.createElement(Text, { color: "white" }, request.title)),
46
+ React.createElement(Box, { marginTop: 1 },
47
+ React.createElement(Text, { color: "gray" }, request.description)),
48
+ request.preview && (React.createElement(Box, { marginTop: 1, borderStyle: "single", borderColor: "gray", paddingX: 1, flexDirection: "column" },
49
+ React.createElement(Text, { color: "gray" }, request.preview.split("\n").slice(0, 12).join("\n")),
50
+ request.preview.split("\n").length > 12 && (React.createElement(Text, { color: "gray" }, "\u2026 daha fazla sat\u0131r")))),
51
+ React.createElement(Box, { marginTop: 1 },
52
+ React.createElement(Text, null,
53
+ React.createElement(Text, { color: "green" }, "[y]"),
54
+ React.createElement(Text, { color: "gray" }, " kabul "),
55
+ React.createElement(Text, { color: "red" }, "[n]"),
56
+ React.createElement(Text, { color: "gray" }, " reddet "),
57
+ React.createElement(Text, { color: "yellow" }, "[a]"),
58
+ React.createElement(Text, { color: "gray" }, " oturum boyunca kabul "),
59
+ React.createElement(Text, { color: "gray" }, "[Esc] iptal")))));
60
+ }
61
+ //# sourceMappingURL=PermissionPrompt.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PermissionPrompt.js","sourceRoot":"","sources":["../../src/ui/PermissionPrompt.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,39 @@
1
+ /**
2
+ * StatusBar — ekranın alt barında token sayacı, mode, proje bilgisi.
3
+ */
4
+ import React from "react";
5
+ import { Box, Text } from "ink";
6
+ import path from "node:path";
7
+ import { ModeIndicator } from "./ModeIndicator.js";
8
+ function formatNumber(n) {
9
+ return n.toLocaleString("tr-TR");
10
+ }
11
+ function pct(used, limit) {
12
+ if (limit <= 0)
13
+ return "—";
14
+ return `${Math.min(100, Math.round((used / limit) * 100))}%`;
15
+ }
16
+ export function StatusBar({ tokensUsed, tokensLimit, mode, model, cwd, busy, }) {
17
+ const percentStr = pct(tokensUsed, tokensLimit);
18
+ const projectName = path.basename(cwd) || cwd;
19
+ const modelLabel = model === "max" ? "AIGENCY Max" : "AIGENCY Pro";
20
+ const pctNumber = tokensLimit > 0 ? (tokensUsed / tokensLimit) * 100 : 0;
21
+ const pctColor = pctNumber >= 85 ? "red" : pctNumber >= 60 ? "yellow" : "green";
22
+ return (React.createElement(Box, { borderStyle: "single", borderColor: "gray", paddingX: 1, justifyContent: "space-between" },
23
+ React.createElement(Box, null,
24
+ React.createElement(ModeIndicator, { mode: mode }),
25
+ React.createElement(Text, { color: "gray" }, " \u00B7 "),
26
+ React.createElement(Text, { color: "cyan" }, modelLabel),
27
+ React.createElement(Text, { color: "gray" }, " \u00B7 "),
28
+ React.createElement(Text, { color: "white" }, projectName)),
29
+ React.createElement(Box, null,
30
+ busy && React.createElement(Text, { color: "yellow" }, "\u25CF \u00E7al\u0131\u015F\u0131yor "),
31
+ React.createElement(Text, { color: pctColor },
32
+ formatNumber(tokensUsed),
33
+ "/",
34
+ formatNumber(tokensLimit),
35
+ " (",
36
+ percentStr,
37
+ ")"))));
38
+ }
39
+ //# sourceMappingURL=StatusBar.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StatusBar.js","sourceRoot":"","sources":["../../src/ui/StatusBar.tsx"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,MAAM,KAAK,CAAC;AAChC,OAAO,IAAI,MAAM,WAAW,CAAC;AAE7B,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AAWnD,SAAS,YAAY,CAAC,CAAS;IAC7B,OAAO,CAAC,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC;AACnC,CAAC;AAED,SAAS,GAAG,CAAC,IAAY,EAAE,KAAa;IACtC,IAAI,KAAK,IAAI,CAAC;QAAE,OAAO,GAAG,CAAC;IAC3B,OAAO,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC,IAAI,GAAG,KAAK,CAAC,GAAG,GAAG,CAAC,CAAC,GAAG,CAAC;AAC/D,CAAC;AAED,MAAM,UAAU,SAAS,CAAC,EACxB,UAAU,EACV,WAAW,EACX,IAAI,EACJ,KAAK,EACL,GAAG,EACH,IAAI,GACE;IACN,MAAM,UAAU,GAAG,GAAG,CAAC,UAAU,EAAE,WAAW,CAAC,CAAC;IAChD,MAAM,WAAW,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,IAAI,GAAG,CAAC;IAC9C,MAAM,UAAU,GAAG,KAAK,KAAK,KAAK,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,aAAa,CAAC;IAEnE,MAAM,SAAS,GAAG,WAAW,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,UAAU,GAAG,WAAW,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IACzE,MAAM,QAAQ,GACZ,SAAS,IAAI,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS,IAAI,EAAE,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC;IAEjE,OAAO,CACL,oBAAC,GAAG,IACF,WAAW,EAAC,QAAQ,EACpB,WAAW,EAAC,MAAM,EAClB,QAAQ,EAAE,CAAC,EACX,cAAc,EAAC,eAAe;QAE9B,oBAAC,GAAG;YACF,oBAAC,aAAa,IAAC,IAAI,EAAE,IAAI,GAAI;YAC7B,oBAAC,IAAI,IAAC,KAAK,EAAC,MAAM,eAAW;YAC7B,oBAAC,IAAI,IAAC,KAAK,EAAC,MAAM,IAAE,UAAU,CAAQ;YACtC,oBAAC,IAAI,IAAC,KAAK,EAAC,MAAM,eAAW;YAC7B,oBAAC,IAAI,IAAC,KAAK,EAAC,OAAO,IAAE,WAAW,CAAQ,CACpC;QACN,oBAAC,GAAG;YACD,IAAI,IAAI,oBAAC,IAAI,IAAC,KAAK,EAAC,QAAQ,4CAAoB;YACjD,oBAAC,IAAI,IAAC,KAAK,EAAE,QAAQ;gBAClB,YAAY,CAAC,UAAU,CAAC;;gBAAG,YAAY,CAAC,WAAW,CAAC;;gBAAI,UAAU;oBAC9D,CACH,CACF,CACP,CAAC;AACJ,CAAC"}
@@ -0,0 +1,42 @@
1
+ /**
2
+ * AIGENCY CLI — Ink UI tema renkleri.
3
+ *
4
+ * Ink 5 kendi renk isimleri ile çalışır: "white", "cyan", "yellow", "red" vb.
5
+ * Hex kod da destekler. Burada terminal uyumlu isimler tutuyoruz.
6
+ */
7
+ export const theme = {
8
+ // Markaj
9
+ brand: "cyan",
10
+ brandDim: "cyanBright",
11
+ accent: "magenta",
12
+ // Durum
13
+ success: "green",
14
+ warning: "yellow",
15
+ error: "red",
16
+ info: "blue",
17
+ // Metin
18
+ muted: "gray",
19
+ text: "white",
20
+ // Agent rolleri (sunucu StreamEvent agent_spawn event'i için)
21
+ orchestrator: "white",
22
+ planner: "blue",
23
+ coder: "green",
24
+ researcher: "magenta",
25
+ reviewer: "yellow",
26
+ tester: "red",
27
+ designer: "cyan",
28
+ deployer: "yellow",
29
+ };
30
+ export const modeColor = {
31
+ default: "brand",
32
+ plan: "info",
33
+ accept_edits: "warning",
34
+ auto: "accent",
35
+ };
36
+ export const modeLabel = {
37
+ default: "VARSAYILAN",
38
+ plan: "PLAN",
39
+ accept_edits: "OTO.YAZ",
40
+ auto: "OTOMATİK",
41
+ };
42
+ //# sourceMappingURL=theme.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"theme.js","sourceRoot":"","sources":["../../src/ui/theme.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,MAAM,CAAC,MAAM,KAAK,GAAG;IACnB,SAAS;IACT,KAAK,EAAE,MAAe;IACtB,QAAQ,EAAE,YAAqB;IAC/B,MAAM,EAAE,SAAkB;IAE1B,QAAQ;IACR,OAAO,EAAE,OAAgB;IACzB,OAAO,EAAE,QAAiB;IAC1B,KAAK,EAAE,KAAc;IACrB,IAAI,EAAE,MAAe;IAErB,QAAQ;IACR,KAAK,EAAE,MAAe;IACtB,IAAI,EAAE,OAAgB;IAEtB,8DAA8D;IAC9D,YAAY,EAAE,OAAgB;IAC9B,OAAO,EAAE,MAAe;IACxB,KAAK,EAAE,OAAgB;IACvB,UAAU,EAAE,SAAkB;IAC9B,QAAQ,EAAE,QAAiB;IAC3B,MAAM,EAAE,KAAc;IACtB,QAAQ,EAAE,MAAe;IACzB,QAAQ,EAAE,QAAiB;CAC5B,CAAC;AAEF,MAAM,CAAC,MAAM,SAAS,GAAuC;IAC3D,OAAO,EAAE,OAAO;IAChB,IAAI,EAAE,MAAM;IACZ,YAAY,EAAE,SAAS;IACvB,IAAI,EAAE,QAAQ;CACf,CAAC;AAEF,MAAM,CAAC,MAAM,SAAS,GAA2B;IAC/C,OAAO,EAAE,YAAY;IACrB,IAAI,EAAE,MAAM;IACZ,YAAY,EAAE,SAAS;IACvB,IAAI,EAAE,UAAU;CACjB,CAAC"}
@@ -0,0 +1,61 @@
1
+ /**
2
+ * AIGENCY CLI — abort controller wrapper.
3
+ *
4
+ * Ctrl+C (SIGINT) yakalar ve `AbortController` ile ilerideki operasyonlara
5
+ * iletir. API client timeout'ları ve SSE stream loop'u bu controller'ı kullanır.
6
+ */
7
+ export class AbortManager {
8
+ controller = new AbortController();
9
+ disposed = false;
10
+ listenerAttached = false;
11
+ constructor() {
12
+ this.attachSigint();
13
+ }
14
+ get signal() {
15
+ return this.controller.signal;
16
+ }
17
+ abort(reason) {
18
+ if (this.disposed)
19
+ return;
20
+ try {
21
+ this.controller.abort(reason);
22
+ }
23
+ catch {
24
+ // Zaten abort edilmiş olabilir
25
+ }
26
+ }
27
+ reset() {
28
+ this.controller = new AbortController();
29
+ this.disposed = false;
30
+ }
31
+ dispose() {
32
+ this.disposed = true;
33
+ if (this.listenerAttached && typeof process.off === "function") {
34
+ process.off("SIGINT", this.onSigint);
35
+ this.listenerAttached = false;
36
+ }
37
+ }
38
+ onSigint = () => {
39
+ if (this.controller.signal.aborted) {
40
+ // İkinci Ctrl+C — zorla çık
41
+ process.exit(130);
42
+ }
43
+ this.abort("SIGINT");
44
+ };
45
+ attachSigint() {
46
+ if (this.listenerAttached)
47
+ return;
48
+ process.on("SIGINT", this.onSigint);
49
+ this.listenerAttached = true;
50
+ }
51
+ }
52
+ /**
53
+ * Singleton — CLI boyunca tek bir AbortManager.
54
+ */
55
+ let globalManager = null;
56
+ export function getGlobalAbortManager() {
57
+ if (!globalManager)
58
+ globalManager = new AbortManager();
59
+ return globalManager;
60
+ }
61
+ //# sourceMappingURL=abort.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"abort.js","sourceRoot":"","sources":["../../src/utils/abort.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,MAAM,OAAO,YAAY;IACf,UAAU,GAAG,IAAI,eAAe,EAAE,CAAC;IACnC,QAAQ,GAAG,KAAK,CAAC;IACjB,gBAAgB,GAAG,KAAK,CAAC;IAEjC;QACE,IAAI,CAAC,YAAY,EAAE,CAAC;IACtB,CAAC;IAED,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC;IAChC,CAAC;IAED,KAAK,CAAC,MAAe;QACnB,IAAI,IAAI,CAAC,QAAQ;YAAE,OAAO;QAC1B,IAAI,CAAC;YACH,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QAChC,CAAC;QAAC,MAAM,CAAC;YACP,+BAA+B;QACjC,CAAC;IACH,CAAC;IAED,KAAK;QACH,IAAI,CAAC,UAAU,GAAG,IAAI,eAAe,EAAE,CAAC;QACxC,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;IACxB,CAAC;IAED,OAAO;QACL,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QACrB,IAAI,IAAI,CAAC,gBAAgB,IAAI,OAAO,OAAO,CAAC,GAAG,KAAK,UAAU,EAAE,CAAC;YAC/D,OAAO,CAAC,GAAG,CAAC,QAAQ,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;YACrC,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC;QAChC,CAAC;IACH,CAAC;IAEO,QAAQ,GAAG,GAAG,EAAE;QACtB,IAAI,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;YACnC,4BAA4B;YAC5B,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QACpB,CAAC;QACD,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;IACvB,CAAC,CAAC;IAEM,YAAY;QAClB,IAAI,IAAI,CAAC,gBAAgB;YAAE,OAAO;QAClC,OAAO,CAAC,EAAE,CAAC,QAAQ,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;QACpC,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;IAC/B,CAAC;CACF;AAED;;GAEG;AACH,IAAI,aAAa,GAAwB,IAAI,CAAC;AAE9C,MAAM,UAAU,qBAAqB;IACnC,IAAI,CAAC,aAAa;QAAE,aAAa,GAAG,IAAI,YAAY,EAAE,CAAC;IACvD,OAAO,aAAa,CAAC;AACvB,CAAC"}