@tutti-os/agent-gui 0.0.57 → 0.0.58
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/agent-conversation/index.js +9 -8
- package/dist/agent-conversation/index.js.map +1 -1
- package/dist/agent-env/index.d.ts +285 -0
- package/dist/agent-env/index.js +360 -0
- package/dist/agent-env/index.js.map +1 -0
- package/dist/agent-message-center/index.js +11 -11
- package/dist/app/renderer/agentactivity.css +8 -33
- package/dist/{chunk-RGVVHF7Q.js → chunk-2WUDORCV.js} +2 -2
- package/dist/{chunk-Z3AAQQFD.js → chunk-5SRRKWE4.js} +2 -2
- package/dist/{chunk-DZ76JPCV.js → chunk-BEFNWUOZ.js} +95 -154
- package/dist/chunk-BEFNWUOZ.js.map +1 -0
- package/dist/{chunk-IMZBRUP3.js → chunk-BT5WEZO5.js} +7 -7
- package/dist/{chunk-HFZOXSSQ.js → chunk-CEMXB7LA.js} +5 -5
- package/dist/{chunk-S6PCOX3S.js → chunk-HVU46DDA.js} +1 -1
- package/dist/chunk-HVU46DDA.js.map +1 -0
- package/dist/{chunk-33LWYV6O.js → chunk-IS6JUDDY.js} +9 -1
- package/dist/chunk-IS6JUDDY.js.map +1 -0
- package/dist/{chunk-VOXUYDQF.js → chunk-N756UO52.js} +11 -7
- package/dist/chunk-N756UO52.js.map +1 -0
- package/dist/{chunk-N37A5CJH.js → chunk-NX6T3DDS.js} +3 -3
- package/dist/{chunk-KOR6UVUJ.js → chunk-OFMORNBO.js} +5 -5
- package/dist/{chunk-QFHR527D.js → chunk-OLI2A3EM.js} +2 -2
- package/dist/chunk-PSLAWU25.js +145 -0
- package/dist/chunk-PSLAWU25.js.map +1 -0
- package/dist/{chunk-2VHP7KQ5.js → chunk-SLT5Q37C.js} +6 -6
- package/dist/{chunk-SZ7JGCS3.js → chunk-UCCUIUGK.js} +4 -4
- package/dist/context-mention-palette/index.js +7 -7
- package/dist/i18n/index.d.ts +8 -0
- package/dist/i18n/index.js +2 -2
- package/dist/index.d.ts +52 -0
- package/dist/index.js +570 -108
- package/dist/index.js.map +1 -1
- package/dist/workbench/contribution.js +2 -2
- package/dist/workbench/index.js +14 -14
- package/dist/workbench/sessionTitle.js +3 -3
- package/dist/workspace-agent-generated-files.js +3 -3
- package/package.json +19 -12
- package/dist/chunk-33LWYV6O.js.map +0 -1
- package/dist/chunk-DZ76JPCV.js.map +0 -1
- package/dist/chunk-S6PCOX3S.js.map +0 -1
- package/dist/chunk-VOXUYDQF.js.map +0 -1
- /package/dist/{chunk-RGVVHF7Q.js.map → chunk-2WUDORCV.js.map} +0 -0
- /package/dist/{chunk-Z3AAQQFD.js.map → chunk-5SRRKWE4.js.map} +0 -0
- /package/dist/{chunk-IMZBRUP3.js.map → chunk-BT5WEZO5.js.map} +0 -0
- /package/dist/{chunk-HFZOXSSQ.js.map → chunk-CEMXB7LA.js.map} +0 -0
- /package/dist/{chunk-N37A5CJH.js.map → chunk-NX6T3DDS.js.map} +0 -0
- /package/dist/{chunk-KOR6UVUJ.js.map → chunk-OFMORNBO.js.map} +0 -0
- /package/dist/{chunk-QFHR527D.js.map → chunk-OLI2A3EM.js.map} +0 -0
- /package/dist/{chunk-2VHP7KQ5.js.map → chunk-SLT5Q37C.js.map} +0 -0
- /package/dist/{chunk-SZ7JGCS3.js.map → chunk-UCCUIUGK.js.map} +0 -0
|
@@ -0,0 +1,360 @@
|
|
|
1
|
+
import {
|
|
2
|
+
classifyFailedAgentMessage,
|
|
3
|
+
closeAgentEnvPanel,
|
|
4
|
+
getAgentEnvPanelStore,
|
|
5
|
+
openAgentEnvPanel,
|
|
6
|
+
resolveAgentErrorPresentation,
|
|
7
|
+
useAgentEnvPanelRequest
|
|
8
|
+
} from "../chunk-PSLAWU25.js";
|
|
9
|
+
|
|
10
|
+
// shared/agentEnv/codexSetupContract.ts
|
|
11
|
+
function asRecord(value) {
|
|
12
|
+
return value && typeof value === "object" && !Array.isArray(value) ? value : null;
|
|
13
|
+
}
|
|
14
|
+
function asString(value) {
|
|
15
|
+
return typeof value === "string" && value.length > 0 ? value : null;
|
|
16
|
+
}
|
|
17
|
+
var STEP_STATUSES = /* @__PURE__ */ new Set([
|
|
18
|
+
"pending",
|
|
19
|
+
"running",
|
|
20
|
+
"ok",
|
|
21
|
+
"error",
|
|
22
|
+
"skipped"
|
|
23
|
+
]);
|
|
24
|
+
var PHASES = /* @__PURE__ */ new Set([
|
|
25
|
+
"detect",
|
|
26
|
+
"install",
|
|
27
|
+
"repair",
|
|
28
|
+
"verify",
|
|
29
|
+
"done",
|
|
30
|
+
"error"
|
|
31
|
+
]);
|
|
32
|
+
function normalizeStep(value, index) {
|
|
33
|
+
const record = asRecord(value);
|
|
34
|
+
if (!record) {
|
|
35
|
+
return null;
|
|
36
|
+
}
|
|
37
|
+
const status = asString(record.status);
|
|
38
|
+
return {
|
|
39
|
+
id: asString(record.id) ?? `step-${index}`,
|
|
40
|
+
label: asString(record.label),
|
|
41
|
+
status: status && STEP_STATUSES.has(status) ? status : "pending",
|
|
42
|
+
detail: asString(record.detail)
|
|
43
|
+
};
|
|
44
|
+
}
|
|
45
|
+
function readCodexSetupActiveAction(status) {
|
|
46
|
+
const statusRecord = asRecord(status);
|
|
47
|
+
if (!statusRecord) {
|
|
48
|
+
return null;
|
|
49
|
+
}
|
|
50
|
+
const raw = asRecord(statusRecord.activeAction);
|
|
51
|
+
if (!raw) {
|
|
52
|
+
return null;
|
|
53
|
+
}
|
|
54
|
+
const phase = asString(raw.phase);
|
|
55
|
+
const steps = Array.isArray(raw.steps) ? raw.steps.map((step, index) => normalizeStep(step, index)).filter((step) => step !== null) : [];
|
|
56
|
+
const log = Array.isArray(raw.log) ? raw.log.filter((entry) => typeof entry === "string") : [];
|
|
57
|
+
const errorRecord = asRecord(raw.error);
|
|
58
|
+
return {
|
|
59
|
+
phase: phase && PHASES.has(phase) ? phase : "detect",
|
|
60
|
+
steps,
|
|
61
|
+
registry: asString(raw.registry),
|
|
62
|
+
log,
|
|
63
|
+
error: errorRecord ? {
|
|
64
|
+
code: asString(errorRecord.code),
|
|
65
|
+
message: asString(errorRecord.message)
|
|
66
|
+
} : null
|
|
67
|
+
};
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
// shared/agentEnv/agentEnvWizardFlow.ts
|
|
71
|
+
function reasonCodeIndicatesCliVersionUnsupported(reasonCode) {
|
|
72
|
+
const lower = (reasonCode ?? "").toLowerCase();
|
|
73
|
+
return lower.includes("version") && !lower.includes("adapter");
|
|
74
|
+
}
|
|
75
|
+
var INSTALLING_PHASES = /* @__PURE__ */ new Set([
|
|
76
|
+
"install",
|
|
77
|
+
"repair",
|
|
78
|
+
"verify"
|
|
79
|
+
]);
|
|
80
|
+
function deriveAgentSetupStages(input) {
|
|
81
|
+
const installing = input.installActionPending || (input.activePhase ? INSTALLING_PHASES.has(input.activePhase) : false);
|
|
82
|
+
const detectStatus = input.detected ? "ok" : "running";
|
|
83
|
+
const networkStatus = !input.detected ? "pending" : input.networkReachable === false ? "error" : "ok";
|
|
84
|
+
const cliOk = input.ready || input.cliInstalled && !input.versionTooOld && !input.platformPackageIncomplete;
|
|
85
|
+
const installStatus = cliOk ? "ok" : installing ? "running" : input.versionTooOld ? "error" : "pending";
|
|
86
|
+
const installProblem = input.platformPackageIncomplete && !cliOk ? "install-platform-incomplete" : void 0;
|
|
87
|
+
const adapterOk = input.ready || input.adapterInstalled && !input.adapterVersionMismatch;
|
|
88
|
+
const adapterStatus = adapterOk ? "ok" : installing ? "running" : input.adapterVersionMismatch ? "error" : "pending";
|
|
89
|
+
const loginStatus = input.authenticated ? "ok" : input.loginPending ? "running" : "pending";
|
|
90
|
+
const readyStatus = input.ready ? "ok" : "pending";
|
|
91
|
+
return [
|
|
92
|
+
{
|
|
93
|
+
id: "detect",
|
|
94
|
+
label: input.labels.detect,
|
|
95
|
+
status: detectStatus,
|
|
96
|
+
detail: null
|
|
97
|
+
},
|
|
98
|
+
{
|
|
99
|
+
id: "network",
|
|
100
|
+
label: input.labels.network,
|
|
101
|
+
status: networkStatus,
|
|
102
|
+
detail: input.networkDetail
|
|
103
|
+
},
|
|
104
|
+
{
|
|
105
|
+
id: "install",
|
|
106
|
+
label: input.labels.install,
|
|
107
|
+
status: installStatus,
|
|
108
|
+
detail: input.cliVersionDetail,
|
|
109
|
+
...installProblem ? { problem: installProblem } : {}
|
|
110
|
+
},
|
|
111
|
+
{
|
|
112
|
+
id: "adapter",
|
|
113
|
+
label: input.labels.adapter,
|
|
114
|
+
status: adapterStatus,
|
|
115
|
+
detail: input.adapterDetail
|
|
116
|
+
},
|
|
117
|
+
{
|
|
118
|
+
id: "login",
|
|
119
|
+
label: input.labels.login,
|
|
120
|
+
status: loginStatus,
|
|
121
|
+
detail: input.accountDetail,
|
|
122
|
+
authMethod: input.authMethod
|
|
123
|
+
},
|
|
124
|
+
{
|
|
125
|
+
id: "ready",
|
|
126
|
+
label: input.labels.ready,
|
|
127
|
+
status: readyStatus,
|
|
128
|
+
detail: null
|
|
129
|
+
}
|
|
130
|
+
];
|
|
131
|
+
}
|
|
132
|
+
function projectRevealedStages(realStages, revealIndex) {
|
|
133
|
+
return realStages.map((stage, index) => {
|
|
134
|
+
if (index < revealIndex) {
|
|
135
|
+
return stage;
|
|
136
|
+
}
|
|
137
|
+
if (index === revealIndex) {
|
|
138
|
+
if (stage.status === "ok" || stage.status === "skipped") {
|
|
139
|
+
return { ...stage, status: "running" };
|
|
140
|
+
}
|
|
141
|
+
return stage;
|
|
142
|
+
}
|
|
143
|
+
return { ...stage, status: "pending" };
|
|
144
|
+
});
|
|
145
|
+
}
|
|
146
|
+
function shouldAdvanceReveal(realStages, revealIndex) {
|
|
147
|
+
const cursor = realStages[revealIndex];
|
|
148
|
+
if (!cursor) {
|
|
149
|
+
return false;
|
|
150
|
+
}
|
|
151
|
+
return cursor.status === "ok" || cursor.status === "skipped";
|
|
152
|
+
}
|
|
153
|
+
function stageRemediation(stage) {
|
|
154
|
+
if (stage.status !== "pending" && stage.status !== "error") {
|
|
155
|
+
return null;
|
|
156
|
+
}
|
|
157
|
+
switch (stage.id) {
|
|
158
|
+
case "network":
|
|
159
|
+
return { actionId: "redetect", problem: "network-unreachable" };
|
|
160
|
+
case "install":
|
|
161
|
+
if (stage.problem) {
|
|
162
|
+
return { actionId: "install", problem: stage.problem };
|
|
163
|
+
}
|
|
164
|
+
return stage.status === "error" ? { actionId: "redetect", problem: "install-outdated" } : { actionId: "install", problem: "install-missing" };
|
|
165
|
+
case "adapter":
|
|
166
|
+
return {
|
|
167
|
+
actionId: "install",
|
|
168
|
+
problem: stage.status === "error" ? "adapter-mismatch" : "adapter-missing"
|
|
169
|
+
};
|
|
170
|
+
case "login":
|
|
171
|
+
return { actionId: "login", problem: "login-missing" };
|
|
172
|
+
default:
|
|
173
|
+
return null;
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
function resolveWizardAutoStartAction(input) {
|
|
177
|
+
const candidate = autoStartCandidate(input.focus);
|
|
178
|
+
if (!candidate) {
|
|
179
|
+
return null;
|
|
180
|
+
}
|
|
181
|
+
if (!input.detected || input.ready) {
|
|
182
|
+
return null;
|
|
183
|
+
}
|
|
184
|
+
if (candidate === "install" && input.installPending) {
|
|
185
|
+
return null;
|
|
186
|
+
}
|
|
187
|
+
if (candidate === "login" && input.loginPending) {
|
|
188
|
+
return null;
|
|
189
|
+
}
|
|
190
|
+
return candidate;
|
|
191
|
+
}
|
|
192
|
+
function autoStartCandidate(focus) {
|
|
193
|
+
switch (focus) {
|
|
194
|
+
case "install":
|
|
195
|
+
case "repair":
|
|
196
|
+
return "install";
|
|
197
|
+
case "upgrade":
|
|
198
|
+
return null;
|
|
199
|
+
case "auth":
|
|
200
|
+
return "login";
|
|
201
|
+
default:
|
|
202
|
+
return null;
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
|
|
206
|
+
// shared/agentEnv/agentEnvViewModel.ts
|
|
207
|
+
var MANUAL_INSTALL_COMMANDS = {
|
|
208
|
+
codex: "npm install -g @openai/codex --include=optional",
|
|
209
|
+
"claude-code": "curl -fsSL https://claude.ai/install.sh | bash"
|
|
210
|
+
};
|
|
211
|
+
function endpointHost(endpoint) {
|
|
212
|
+
if (!endpoint) {
|
|
213
|
+
return null;
|
|
214
|
+
}
|
|
215
|
+
return endpoint.replace(/^https?:\/\//, "").replace(/\/.*$/, "") || null;
|
|
216
|
+
}
|
|
217
|
+
function scrubProxyUrl(url) {
|
|
218
|
+
if (!url) {
|
|
219
|
+
return null;
|
|
220
|
+
}
|
|
221
|
+
try {
|
|
222
|
+
const parsed = new URL(url);
|
|
223
|
+
parsed.username = "";
|
|
224
|
+
parsed.password = "";
|
|
225
|
+
return `${parsed.protocol}//${parsed.host}`;
|
|
226
|
+
} catch {
|
|
227
|
+
return url.replace(/\/\/[^/@]*@/, "//") || null;
|
|
228
|
+
}
|
|
229
|
+
}
|
|
230
|
+
function textToken(text) {
|
|
231
|
+
return text ? { kind: "text", text } : null;
|
|
232
|
+
}
|
|
233
|
+
function joinDetail(parts) {
|
|
234
|
+
const joined = parts.filter((p) => Boolean(p)).join(" \xB7 ");
|
|
235
|
+
return joined || null;
|
|
236
|
+
}
|
|
237
|
+
function deriveHasAnomaly(stages, activeActionError) {
|
|
238
|
+
return stages.some((s) => s.status === "error") || Boolean(activeActionError);
|
|
239
|
+
}
|
|
240
|
+
function buildAgentEnvWizardViewModel(input) {
|
|
241
|
+
const { status, activeAction, provider } = input;
|
|
242
|
+
const ready = status?.availability.status === "ready";
|
|
243
|
+
const installPending = input.installActionPending;
|
|
244
|
+
const loginPending = input.loginPending;
|
|
245
|
+
const busy = installPending || activeAction?.phase === "install" || activeAction?.phase === "repair" || activeAction?.phase === "verify";
|
|
246
|
+
const reasonCode = (status?.availability.reasonCode ?? "").toLowerCase();
|
|
247
|
+
const versionTooOld = reasonCodeIndicatesCliVersionUnsupported(reasonCode);
|
|
248
|
+
const cliBelowFloor = reasonCode.includes("codex_version_too_old");
|
|
249
|
+
const platformPackageIncomplete = reasonCode.includes(
|
|
250
|
+
"codex_platform_pkg_incomplete"
|
|
251
|
+
);
|
|
252
|
+
const adapterVersionMismatch = reasonCode.includes(
|
|
253
|
+
"acp_adapter_version_mismatch"
|
|
254
|
+
);
|
|
255
|
+
const cliDetail = cliBelowFloor && status?.cli.version && status.cli.minVersion ? {
|
|
256
|
+
kind: "version-floor",
|
|
257
|
+
current: status.cli.version,
|
|
258
|
+
required: status.cli.minVersion
|
|
259
|
+
} : status?.cli.installed ? textToken(joinDetail([status?.cli.version, status?.cli.binaryPath])) : textToken(status?.cli.version ?? null);
|
|
260
|
+
const adapterDetail = adapterVersionMismatch && status?.adapter.version && status?.adapter.requiredVersion ? {
|
|
261
|
+
kind: "version-mismatch",
|
|
262
|
+
current: status.adapter.version,
|
|
263
|
+
required: status.adapter.requiredVersion
|
|
264
|
+
} : status?.adapter.installed ? textToken(
|
|
265
|
+
joinDetail([status?.adapter.version, status?.adapter.binaryPath])
|
|
266
|
+
) : textToken(
|
|
267
|
+
status?.adapter.binaryPath ?? (status?.adapter.command?.length ? status.adapter.command.join(" ") : null)
|
|
268
|
+
);
|
|
269
|
+
const networkChecks = status?.network ? [
|
|
270
|
+
{
|
|
271
|
+
kind: "registry",
|
|
272
|
+
reachable: status.network.registry.reachable,
|
|
273
|
+
host: endpointHost(status.network.registry.endpoint)
|
|
274
|
+
},
|
|
275
|
+
...status.network.providerApi ? [
|
|
276
|
+
{
|
|
277
|
+
kind: "api",
|
|
278
|
+
reachable: status.network.providerApi.reachable,
|
|
279
|
+
host: endpointHost(status.network.providerApi.endpoint)
|
|
280
|
+
}
|
|
281
|
+
] : [],
|
|
282
|
+
...status.network.proxy ? [
|
|
283
|
+
{
|
|
284
|
+
kind: "proxy",
|
|
285
|
+
reachable: !status.network.proxy.configured || status.network.proxy.reachable,
|
|
286
|
+
host: scrubProxyUrl(status.network.proxy.url),
|
|
287
|
+
configured: status.network.proxy.configured
|
|
288
|
+
}
|
|
289
|
+
] : []
|
|
290
|
+
] : [];
|
|
291
|
+
const networkReachable = networkChecks.length === 0 ? null : networkChecks.every((c) => c.reachable);
|
|
292
|
+
const accountDetail = status?.auth.accountLabel ? { kind: "text", text: status.auth.accountLabel } : status?.auth.status === "authenticated" ? { kind: "text", text: "__SIGNED_IN__" } : null;
|
|
293
|
+
const authMethod = status?.auth.authMethod ?? null;
|
|
294
|
+
const stages = deriveAgentSetupStages({
|
|
295
|
+
detected: status !== null,
|
|
296
|
+
cliInstalled: status?.cli.installed ?? false,
|
|
297
|
+
versionTooOld,
|
|
298
|
+
platformPackageIncomplete,
|
|
299
|
+
adapterInstalled: status?.adapter.installed ?? false,
|
|
300
|
+
adapterVersionMismatch,
|
|
301
|
+
authenticated: status?.auth.status === "authenticated",
|
|
302
|
+
authRequired: status?.auth.status === "required",
|
|
303
|
+
ready: Boolean(ready),
|
|
304
|
+
activePhase: activeAction?.phase ?? null,
|
|
305
|
+
installActionPending: installPending,
|
|
306
|
+
loginPending,
|
|
307
|
+
networkReachable,
|
|
308
|
+
cliVersionDetail: cliDetail,
|
|
309
|
+
adapterDetail,
|
|
310
|
+
accountDetail,
|
|
311
|
+
authMethod,
|
|
312
|
+
networkDetail: null,
|
|
313
|
+
labels: input.stageLabels
|
|
314
|
+
});
|
|
315
|
+
const registry = activeAction?.registry ?? null;
|
|
316
|
+
const stagesWithDetail = registry ? stages.map(
|
|
317
|
+
(s) => s.id === "ready" ? { ...s, detail: { kind: "text", text: registry } } : s
|
|
318
|
+
) : stages;
|
|
319
|
+
const displayStages = projectRevealedStages(
|
|
320
|
+
stagesWithDetail,
|
|
321
|
+
input.revealIndex
|
|
322
|
+
);
|
|
323
|
+
const blockingIndex = stages.findIndex((s) => s.status !== "ok");
|
|
324
|
+
const blockingStage = blockingIndex >= 0 ? stages[blockingIndex] : void 0;
|
|
325
|
+
const blockingStageId = blockingStage && input.revealIndex >= blockingIndex ? blockingStage.id : null;
|
|
326
|
+
return {
|
|
327
|
+
ready: Boolean(ready),
|
|
328
|
+
busy: Boolean(busy),
|
|
329
|
+
redetecting: input.isLoading,
|
|
330
|
+
displayStages,
|
|
331
|
+
blockingStageId,
|
|
332
|
+
networkChecks,
|
|
333
|
+
hasAnomaly: deriveHasAnomaly(stages, activeAction?.error ?? null),
|
|
334
|
+
activePhase: activeAction?.phase ?? null,
|
|
335
|
+
log: activeAction?.log ?? [],
|
|
336
|
+
registry,
|
|
337
|
+
error: activeAction?.error ?? null,
|
|
338
|
+
manualCommand: MANUAL_INSTALL_COMMANDS[provider] ?? null,
|
|
339
|
+
installPending,
|
|
340
|
+
loginPending
|
|
341
|
+
};
|
|
342
|
+
}
|
|
343
|
+
export {
|
|
344
|
+
buildAgentEnvWizardViewModel,
|
|
345
|
+
classifyFailedAgentMessage,
|
|
346
|
+
closeAgentEnvPanel,
|
|
347
|
+
deriveAgentSetupStages,
|
|
348
|
+
deriveHasAnomaly,
|
|
349
|
+
getAgentEnvPanelStore,
|
|
350
|
+
openAgentEnvPanel,
|
|
351
|
+
projectRevealedStages,
|
|
352
|
+
readCodexSetupActiveAction,
|
|
353
|
+
reasonCodeIndicatesCliVersionUnsupported,
|
|
354
|
+
resolveAgentErrorPresentation,
|
|
355
|
+
resolveWizardAutoStartAction,
|
|
356
|
+
shouldAdvanceReveal,
|
|
357
|
+
stageRemediation,
|
|
358
|
+
useAgentEnvPanelRequest
|
|
359
|
+
};
|
|
360
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../shared/agentEnv/codexSetupContract.ts","../../shared/agentEnv/agentEnvWizardFlow.ts","../../shared/agentEnv/agentEnvViewModel.ts"],"sourcesContent":["/**\n * Frontend contract for the Codex setup progress stream surfaced on the agent\n * provider status snapshot as `activeAction` (片3 progress-flow contract). The\n * backend slice that populates this field has its own source of truth; the\n * generated `AgentProviderStatus` type does not (yet) declare it, so the panel\n * reads it defensively and degrades to detection-only state when it is absent.\n */\n\nexport type CodexSetupStepStatus =\n | \"pending\"\n | \"running\"\n | \"ok\"\n | \"error\"\n | \"skipped\";\n\nexport interface CodexSetupStep {\n id: string;\n label: string | null;\n status: CodexSetupStepStatus;\n detail: string | null;\n}\n\nexport type CodexSetupPhase =\n | \"detect\"\n | \"install\"\n | \"repair\"\n | \"verify\"\n | \"done\"\n | \"error\";\n\nexport interface CodexSetupActiveActionError {\n code: string | null;\n message: string | null;\n}\n\nexport interface CodexSetupActiveAction {\n phase: CodexSetupPhase;\n steps: CodexSetupStep[];\n registry: string | null;\n log: string[];\n error: CodexSetupActiveActionError | null;\n}\n\nfunction asRecord(value: unknown): Record<string, unknown> | null {\n return value && typeof value === \"object\" && !Array.isArray(value)\n ? (value as Record<string, unknown>)\n : null;\n}\n\nfunction asString(value: unknown): string | null {\n return typeof value === \"string\" && value.length > 0 ? value : null;\n}\n\nconst STEP_STATUSES: ReadonlySet<CodexSetupStepStatus> = new Set([\n \"pending\",\n \"running\",\n \"ok\",\n \"error\",\n \"skipped\"\n]);\n\nconst PHASES: ReadonlySet<CodexSetupPhase> = new Set([\n \"detect\",\n \"install\",\n \"repair\",\n \"verify\",\n \"done\",\n \"error\"\n]);\n\nfunction normalizeStep(value: unknown, index: number): CodexSetupStep | null {\n const record = asRecord(value);\n if (!record) {\n return null;\n }\n const status = asString(record.status);\n return {\n id: asString(record.id) ?? `step-${index}`,\n label: asString(record.label),\n status:\n status && STEP_STATUSES.has(status as CodexSetupStepStatus)\n ? (status as CodexSetupStepStatus)\n : \"pending\",\n detail: asString(record.detail)\n };\n}\n\n/**\n * Defensively reads the `activeAction` field off an AgentProviderStatus-like\n * object. Returns null when the field is missing or malformed, which the panel\n * treats as \"no live setup action in progress\".\n */\nexport function readCodexSetupActiveAction(\n status: unknown\n): CodexSetupActiveAction | null {\n const statusRecord = asRecord(status);\n if (!statusRecord) {\n return null;\n }\n const raw = asRecord(statusRecord.activeAction);\n if (!raw) {\n return null;\n }\n const phase = asString(raw.phase);\n const steps = Array.isArray(raw.steps)\n ? raw.steps\n .map((step, index) => normalizeStep(step, index))\n .filter((step): step is CodexSetupStep => step !== null)\n : [];\n const log = Array.isArray(raw.log)\n ? raw.log.filter((entry): entry is string => typeof entry === \"string\")\n : [];\n const errorRecord = asRecord(raw.error);\n return {\n phase:\n phase && PHASES.has(phase as CodexSetupPhase)\n ? (phase as CodexSetupPhase)\n : \"detect\",\n steps,\n registry: asString(raw.registry),\n log,\n error: errorRecord\n ? {\n code: asString(errorRecord.code),\n message: asString(errorRecord.message)\n }\n : null\n };\n}\n","import type { AgentEnvPanelFocus } from \"./agentEnvPanelStore\";\nimport type {\n CodexSetupPhase,\n CodexSetupStepStatus\n} from \"./codexSetupContract\";\n\nexport type AgentSetupStageId =\n | \"detect\"\n | \"network\"\n | \"install\"\n | \"adapter\"\n | \"login\"\n | \"ready\";\n\nexport type StageDetailToken =\n | { kind: \"text\"; text: string }\n | { kind: \"version-floor\"; current: string; required: string }\n | { kind: \"version-mismatch\"; current: string; required: string };\n\n// Whether an availability reason code means the CLI itself is on an unsupported\n// version — as opposed to an ADAPTER version mismatch. The adapter reason code\n// `acp_adapter_version_mismatch` also contains the substring \"version\", so a\n// plain `includes(\"version\")` test wrongly paints the CLI step red (\"版本不受支持\")\n// when only the adapter is mismatched. Require \"version\" but exclude any adapter\n// reason so the CLI and adapter stages stay independent.\nexport function reasonCodeIndicatesCliVersionUnsupported(\n reasonCode: string | null | undefined\n): boolean {\n const lower = (reasonCode ?? \"\").toLowerCase();\n return lower.includes(\"version\") && !lower.includes(\"adapter\");\n}\n\nexport interface AgentSetupStage {\n id: AgentSetupStageId;\n label: string;\n status: CodexSetupStepStatus;\n detail: StageDetailToken | null;\n /**\n * Optional explicit problem token for a blocked stage that can't be inferred\n * from `status` alone. Today only the install stage sets it — when the codex\n * launcher is present but its platform subpackage is missing, the stage is\n * `pending` (the daemon repairs it via the install action) yet needs a distinct\n * \"platform package missing\" problem rather than the generic \"install-missing\".\n */\n problem?: StageProblem;\n authMethod?: string | null;\n}\n\nexport interface AgentSetupStageLabels {\n detect: string;\n network: string;\n install: string;\n adapter: string;\n login: string;\n ready: string;\n}\n\nexport interface DeriveAgentSetupStagesInput {\n detected: boolean;\n cliInstalled: boolean;\n versionTooOld: boolean;\n /**\n * The codex CLI launcher is resolved but its platform-specific optional\n * dependency subpackage (e.g. @openai/codex-darwin-arm64) is missing — the\n * binary spawns ENOENT. The daemon repairs this in place via the install\n * action, so the install stage is `pending` (not `ok`) with a distinct\n * \"platform package missing\" problem token.\n */\n platformPackageIncomplete?: boolean;\n adapterInstalled: boolean;\n adapterVersionMismatch: boolean;\n authenticated: boolean;\n authRequired: boolean;\n ready: boolean;\n activePhase: CodexSetupPhase | null;\n /**\n * Whether the daemon-driven install action is in flight. This is the\n * authoritative \"installing\" signal: the adapter (external-registry) installer\n * emits no activeAction phase, so without this an in-progress adapter install\n * would show no spinner.\n */\n installActionPending: boolean;\n loginPending: boolean;\n /**\n * Active connectivity probe verdict: true (reachable), false (offline), or\n * null when the daemon reported no network info (older daemon / not probed) —\n * null is treated as \"don't block\".\n */\n networkReachable: boolean | null;\n cliVersionDetail: StageDetailToken | null;\n adapterDetail: StageDetailToken | null;\n accountDetail: StageDetailToken | null;\n authMethod: string | null;\n networkDetail: StageDetailToken | null;\n labels: AgentSetupStageLabels;\n}\n\nconst INSTALLING_PHASES: ReadonlySet<CodexSetupPhase> = new Set([\n \"install\",\n \"repair\",\n \"verify\"\n]);\n\n/**\n * Maps primitive provider-status flags onto the fixed 5-stage track the wizard\n * renders. Version verification folds into the install (CLI) stage (an\n * unsupported version means install is `error`, not `ok`). The adapter stage\n * covers the ACP adapter, which for some providers (e.g. claude-code) is a\n * separate, slow npm install distinct from the CLI; for providers where the\n * adapter is the CLI itself it simply tracks the CLI. Login `running` is driven\n * by the caller's pending flag because login runs as a terminal action, not via\n * the activeAction phase stream.\n */\nexport function deriveAgentSetupStages(\n input: DeriveAgentSetupStagesInput\n): AgentSetupStage[] {\n const installing =\n input.installActionPending ||\n (input.activePhase ? INSTALLING_PHASES.has(input.activePhase) : false);\n\n const detectStatus: CodexSetupStepStatus = input.detected ? \"ok\" : \"running\";\n\n // Network is an independent live-connectivity check (registry + provider API),\n // so it is NOT folded into the `ready` short-circuit — a real outage shows even\n // when the CLI is otherwise configured. It can only be judged once detection\n // has run; `false` is the only blocking value (null = no daemon verdict).\n const networkStatus: CodexSetupStepStatus = !input.detected\n ? \"pending\"\n : input.networkReachable === false\n ? \"error\"\n : \"ok\";\n\n // A satisfied CLI stays checked even while an install runs, so the spinner\n // lands on the stage actually being worked on (e.g. the adapter during a\n // repair) rather than flipping every install-related stage back to running.\n // A present launcher with a missing platform subpackage is NOT ok — the\n // daemon repairs it via the install action, so it reads as a pending install.\n const cliOk =\n input.ready ||\n (input.cliInstalled &&\n !input.versionTooOld &&\n !input.platformPackageIncomplete);\n const installStatus: CodexSetupStepStatus = cliOk\n ? \"ok\"\n : installing\n ? \"running\"\n : input.versionTooOld\n ? \"error\"\n : \"pending\";\n const installProblem: StageProblem | undefined =\n input.platformPackageIncomplete && !cliOk\n ? \"install-platform-incomplete\"\n : undefined;\n\n const adapterOk =\n input.ready || (input.adapterInstalled && !input.adapterVersionMismatch);\n const adapterStatus: CodexSetupStepStatus = adapterOk\n ? \"ok\"\n : installing\n ? \"running\"\n : input.adapterVersionMismatch\n ? \"error\"\n : \"pending\";\n\n const loginStatus: CodexSetupStepStatus = input.authenticated\n ? \"ok\"\n : input.loginPending\n ? \"running\"\n : \"pending\";\n\n const readyStatus: CodexSetupStepStatus = input.ready ? \"ok\" : \"pending\";\n\n return [\n {\n id: \"detect\",\n label: input.labels.detect,\n status: detectStatus,\n detail: null\n },\n {\n id: \"network\",\n label: input.labels.network,\n status: networkStatus,\n detail: input.networkDetail\n },\n {\n id: \"install\",\n label: input.labels.install,\n status: installStatus,\n detail: input.cliVersionDetail,\n ...(installProblem ? { problem: installProblem } : {})\n },\n {\n id: \"adapter\",\n label: input.labels.adapter,\n status: adapterStatus,\n detail: input.adapterDetail\n },\n {\n id: \"login\",\n label: input.labels.login,\n status: loginStatus,\n detail: input.accountDetail,\n authMethod: input.authMethod\n },\n {\n id: \"ready\",\n label: input.labels.ready,\n status: readyStatus,\n detail: null\n }\n ];\n}\n\n/**\n * Step-by-step reveal: even when prerequisites are already satisfied, the wizard\n * walks a cursor down the track so each stage visibly \"checks off\" one at a time\n * instead of all flashing complete at once.\n *\n * `revealIndex` is the cursor position. Stages before it show their real status\n * (already revealed). The stage AT the cursor is shown as `running` when its\n * real status is terminal-ok (the brief \"working on it\" moment before it checks\n * off) and otherwise shows its real status (so a genuinely running install, an\n * error, or a blocked prerequisite are honest). Stages after the cursor are\n * dimmed to `pending`.\n */\nexport function projectRevealedStages(\n realStages: AgentSetupStage[],\n revealIndex: number\n): AgentSetupStage[] {\n return realStages.map((stage, index) => {\n if (index < revealIndex) {\n return stage;\n }\n if (index === revealIndex) {\n if (stage.status === \"ok\" || stage.status === \"skipped\") {\n return { ...stage, status: \"running\" };\n }\n return stage;\n }\n return { ...stage, status: \"pending\" };\n });\n}\n\n/**\n * The reveal cursor advances past a stage only once that stage is really done\n * (`ok`/`skipped`). It parks on a stage that is still `running` (a real install\n * in progress), `error`, or `pending` (a blocked prerequisite) — so the\n * animation never races ahead of reality.\n */\nexport function shouldAdvanceReveal(\n realStages: AgentSetupStage[],\n revealIndex: number\n): boolean {\n const cursor = realStages[revealIndex];\n if (!cursor) {\n return false;\n }\n return cursor.status === \"ok\" || cursor.status === \"skipped\";\n}\n\nexport type StageActionId = \"install\" | \"login\" | \"redetect\";\n\n/**\n * The problem token a blocked stage represents. The UI maps this to \"未xxx\"\n * copy; keeping it i18n-agnostic here lets the mapping stay tested without\n * pulling translation strings into the pure flow module.\n */\nexport type StageProblem =\n | \"network-unreachable\"\n | \"install-missing\"\n | \"install-outdated\"\n | \"install-platform-incomplete\"\n | \"adapter-missing\"\n | \"adapter-mismatch\"\n | \"login-missing\";\n\nexport interface StageRemediation {\n actionId: StageActionId;\n problem: StageProblem;\n}\n\n/**\n * For a stage the user must act on (idle `pending`/`error`, never `running` or\n * `ok`), returns what is wrong and which action fixes it. `detect`/`ready` never\n * carry their own remediation — they reflect prerequisites, not user actions.\n *\n * `error` means a version problem on the install/adapter stages (the only stages\n * derive marks `error`); `pending` means the step simply has not run yet.\n */\nexport function stageRemediation(\n stage: AgentSetupStage\n): StageRemediation | null {\n if (stage.status !== \"pending\" && stage.status !== \"error\") {\n return null;\n }\n switch (stage.id) {\n case \"network\":\n // Connectivity isn't fixed by an install/login action — re-running\n // detection (which re-probes the network) is the remediation.\n return { actionId: \"redetect\", problem: \"network-unreachable\" };\n case \"install\":\n // An explicit problem token (today: platform subpackage missing) takes\n // precedence — the daemon repairs it in place via the install action, so\n // route through install rather than the manual-upgrade error path.\n if (stage.problem) {\n return { actionId: \"install\", problem: stage.problem };\n }\n // A genuinely missing CLI is installed for the user; a present-but-\n // outdated CLI is NOT — we don't silently reinstall a binary the user\n // manages. Instead the panel shows the manual upgrade command and\n // re-detection confirms it once they've upgraded.\n return stage.status === \"error\"\n ? { actionId: \"redetect\", problem: \"install-outdated\" }\n : { actionId: \"install\", problem: \"install-missing\" };\n case \"adapter\":\n return {\n actionId: \"install\",\n problem:\n stage.status === \"error\" ? \"adapter-mismatch\" : \"adapter-missing\"\n };\n case \"login\":\n return { actionId: \"login\", problem: \"login-missing\" };\n default:\n return null;\n }\n}\n\nexport interface ResolveWizardAutoStartInput {\n focus: AgentEnvPanelFocus | null;\n detected: boolean;\n ready: boolean;\n installPending: boolean;\n loginPending: boolean;\n}\n\n/**\n * Decides whether opening the wizard with a remediation focus should auto-start\n * an action. Returns the action id to run, or null when nothing should run\n * (non-remediation focus, detection not settled, already ready, or already\n * pending). The caller is responsible for firing this at most once per open.\n */\nexport function resolveWizardAutoStartAction(\n input: ResolveWizardAutoStartInput\n): \"install\" | \"login\" | null {\n const candidate = autoStartCandidate(input.focus);\n if (!candidate) {\n return null;\n }\n if (!input.detected || input.ready) {\n return null;\n }\n if (candidate === \"install\" && input.installPending) {\n return null;\n }\n if (candidate === \"login\" && input.loginPending) {\n return null;\n }\n return candidate;\n}\n\nfunction autoStartCandidate(\n focus: AgentEnvPanelFocus | null\n): \"install\" | \"login\" | null {\n switch (focus) {\n case \"install\":\n case \"repair\":\n return \"install\";\n case \"upgrade\":\n // CLI upgrades are user-driven: opening the panel from a version error\n // shows the manual upgrade command rather than auto-running an install\n // (which can't upgrade an already-present binary anyway).\n return null;\n case \"auth\":\n return \"login\";\n default:\n return null;\n }\n}\n","import type {\n AgentProviderStatus,\n WorkspaceAgentProvider\n} from \"@tutti-os/client-tuttid-ts\";\nimport {\n deriveAgentSetupStages,\n projectRevealedStages,\n reasonCodeIndicatesCliVersionUnsupported,\n type AgentSetupStage,\n type AgentSetupStageId,\n type AgentSetupStageLabels,\n type StageDetailToken\n} from \"./agentEnvWizardFlow.ts\";\nimport type {\n CodexSetupActiveAction,\n CodexSetupActiveActionError,\n CodexSetupPhase\n} from \"./codexSetupContract.ts\";\n\nexport interface NetworkCheck {\n kind: \"registry\" | \"api\" | \"proxy\";\n reachable: boolean;\n host: string | null;\n configured?: boolean;\n}\n\nconst MANUAL_INSTALL_COMMANDS: Partial<Record<WorkspaceAgentProvider, string>> =\n {\n codex: \"npm install -g @openai/codex --include=optional\",\n \"claude-code\": \"curl -fsSL https://claude.ai/install.sh | bash\"\n };\n\nfunction endpointHost(endpoint: string | null | undefined): string | null {\n if (!endpoint) {\n return null;\n }\n return endpoint.replace(/^https?:\\/\\//, \"\").replace(/\\/.*$/, \"\") || null;\n}\n\n// A proxy URL may carry credentials (http://user:pass@host:port). Strip the\n// userinfo before it reaches the renderer/UI so proxy passwords are never\n// surfaced; the scheme + host:port are kept for display.\nfunction scrubProxyUrl(url: string | null | undefined): string | null {\n if (!url) {\n return null;\n }\n try {\n const parsed = new URL(url);\n parsed.username = \"\";\n parsed.password = \"\";\n return `${parsed.protocol}//${parsed.host}`;\n } catch {\n // Not a parseable URL — still strip a leading userinfo segment defensively.\n return url.replace(/\\/\\/[^/@]*@/, \"//\") || null;\n }\n}\n\nfunction textToken(text: string | null): StageDetailToken | null {\n return text ? { kind: \"text\", text } : null;\n}\n\nfunction joinDetail(parts: Array<string | null | undefined>): string | null {\n const joined = parts.filter((p): p is string => Boolean(p)).join(\" · \");\n return joined || null;\n}\n\nexport function deriveHasAnomaly(\n stages: AgentSetupStage[],\n activeActionError: CodexSetupActiveActionError | null\n): boolean {\n return stages.some((s) => s.status === \"error\") || Boolean(activeActionError);\n}\n\nexport interface AgentEnvWizardViewModelInput {\n provider: WorkspaceAgentProvider;\n status: AgentProviderStatus | null;\n isLoading: boolean;\n activeAction: CodexSetupActiveAction | null;\n installActionPending: boolean;\n loginPending: boolean;\n revealIndex: number;\n stageLabels: AgentSetupStageLabels;\n}\n\nexport interface AgentEnvWizardViewModel {\n ready: boolean;\n busy: boolean;\n redetecting: boolean;\n displayStages: AgentSetupStage[];\n blockingStageId: AgentSetupStageId | null;\n networkChecks: NetworkCheck[];\n hasAnomaly: boolean;\n activePhase: CodexSetupPhase | null;\n log: string[];\n registry: string | null;\n error: CodexSetupActiveActionError | null;\n manualCommand: string | null;\n installPending: boolean;\n loginPending: boolean;\n}\n\nexport function buildAgentEnvWizardViewModel(\n input: AgentEnvWizardViewModelInput\n): AgentEnvWizardViewModel {\n const { status, activeAction, provider } = input;\n const ready = status?.availability.status === \"ready\";\n const installPending = input.installActionPending;\n const loginPending = input.loginPending;\n const busy =\n installPending ||\n activeAction?.phase === \"install\" ||\n activeAction?.phase === \"repair\" ||\n activeAction?.phase === \"verify\";\n\n const reasonCode = (status?.availability.reasonCode ?? \"\").toLowerCase();\n const versionTooOld = reasonCodeIndicatesCliVersionUnsupported(reasonCode);\n const cliBelowFloor = reasonCode.includes(\"codex_version_too_old\");\n // The codex launcher is present but its platform subpackage is missing — the\n // CLI spawns ENOENT. The daemon repairs this in place via the install action;\n // the wizard must NOT mark the install stage ok just because the launcher\n // resolved.\n const platformPackageIncomplete = reasonCode.includes(\n \"codex_platform_pkg_incomplete\"\n );\n const adapterVersionMismatch = reasonCode.includes(\n \"acp_adapter_version_mismatch\"\n );\n\n const cliDetail: StageDetailToken | null =\n cliBelowFloor && status?.cli.version && status.cli.minVersion\n ? {\n kind: \"version-floor\",\n current: status.cli.version,\n required: status.cli.minVersion\n }\n : status?.cli.installed\n ? textToken(joinDetail([status?.cli.version, status?.cli.binaryPath]))\n : textToken(status?.cli.version ?? null);\n\n const adapterDetail: StageDetailToken | null =\n adapterVersionMismatch &&\n status?.adapter.version &&\n status?.adapter.requiredVersion\n ? {\n kind: \"version-mismatch\",\n current: status.adapter.version,\n required: status.adapter.requiredVersion\n }\n : status?.adapter.installed\n ? textToken(\n joinDetail([status?.adapter.version, status?.adapter.binaryPath])\n )\n : textToken(\n status?.adapter.binaryPath ??\n (status?.adapter.command?.length\n ? status.adapter.command.join(\" \")\n : null)\n );\n\n const networkChecks: NetworkCheck[] = status?.network\n ? [\n {\n kind: \"registry\",\n reachable: status.network.registry.reachable,\n host: endpointHost(status.network.registry.endpoint)\n },\n ...(status.network.providerApi\n ? [\n {\n kind: \"api\" as const,\n reachable: status.network.providerApi.reachable,\n host: endpointHost(status.network.providerApi.endpoint)\n }\n ]\n : []),\n ...(status.network.proxy\n ? [\n {\n kind: \"proxy\" as const,\n reachable:\n !status.network.proxy.configured ||\n status.network.proxy.reachable,\n host: scrubProxyUrl(status.network.proxy.url),\n configured: status.network.proxy.configured\n }\n ]\n : [])\n ]\n : [];\n const networkReachable =\n networkChecks.length === 0 ? null : networkChecks.every((c) => c.reachable);\n\n const accountDetail: StageDetailToken | null = status?.auth.accountLabel\n ? { kind: \"text\", text: status.auth.accountLabel }\n : status?.auth.status === \"authenticated\"\n ? { kind: \"text\", text: \"__SIGNED_IN__\" }\n : null;\n const authMethod: string | null = status?.auth.authMethod ?? null;\n\n const stages = deriveAgentSetupStages({\n detected: status !== null,\n cliInstalled: status?.cli.installed ?? false,\n versionTooOld,\n platformPackageIncomplete,\n adapterInstalled: status?.adapter.installed ?? false,\n adapterVersionMismatch,\n authenticated: status?.auth.status === \"authenticated\",\n authRequired: status?.auth.status === \"required\",\n ready: Boolean(ready),\n activePhase: activeAction?.phase ?? null,\n installActionPending: installPending,\n loginPending,\n networkReachable,\n cliVersionDetail: cliDetail,\n adapterDetail,\n accountDetail,\n authMethod,\n networkDetail: null,\n labels: input.stageLabels\n });\n\n const registry = activeAction?.registry ?? null;\n const stagesWithDetail = registry\n ? stages.map((s) =>\n s.id === \"ready\"\n ? { ...s, detail: { kind: \"text\" as const, text: registry } }\n : s\n )\n : stages;\n const displayStages = projectRevealedStages(\n stagesWithDetail,\n input.revealIndex\n );\n\n const blockingIndex = stages.findIndex((s) => s.status !== \"ok\");\n const blockingStage = blockingIndex >= 0 ? stages[blockingIndex] : undefined;\n const blockingStageId: AgentSetupStageId | null =\n blockingStage && input.revealIndex >= blockingIndex\n ? blockingStage.id\n : null;\n\n return {\n ready: Boolean(ready),\n busy: Boolean(busy),\n redetecting: input.isLoading,\n displayStages,\n blockingStageId,\n networkChecks,\n hasAnomaly: deriveHasAnomaly(stages, activeAction?.error ?? null),\n activePhase: activeAction?.phase ?? null,\n log: activeAction?.log ?? [],\n registry,\n error: activeAction?.error ?? null,\n manualCommand: MANUAL_INSTALL_COMMANDS[provider] ?? null,\n installPending,\n loginPending\n };\n}\n"],"mappings":"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","names":[]}
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
import {
|
|
2
2
|
formatAgentGuiConversationPlainTitle
|
|
3
|
-
} from "../chunk-
|
|
3
|
+
} from "../chunk-2WUDORCV.js";
|
|
4
4
|
import {
|
|
5
5
|
AgentInteractivePromptSurface,
|
|
6
6
|
approvalOptionDisplayLabel,
|
|
7
7
|
getPromptToolDetails,
|
|
8
8
|
isPromptRequestIdTitle
|
|
9
|
-
} from "../chunk-
|
|
9
|
+
} from "../chunk-OFMORNBO.js";
|
|
10
10
|
import {
|
|
11
11
|
PLAN_IMPLEMENTATION_ACTION_IMPLEMENT,
|
|
12
12
|
PLAN_IMPLEMENTATION_PROMPT,
|
|
@@ -15,7 +15,7 @@ import {
|
|
|
15
15
|
} from "../chunk-MKHDRIGN.js";
|
|
16
16
|
import {
|
|
17
17
|
formatAgentSessionMentionText
|
|
18
|
-
} from "../chunk-
|
|
18
|
+
} from "../chunk-UCCUIUGK.js";
|
|
19
19
|
import {
|
|
20
20
|
AgentMessageMarkdown,
|
|
21
21
|
CustomScrollArea,
|
|
@@ -25,29 +25,29 @@ import {
|
|
|
25
25
|
extractExitPlanModeOptions,
|
|
26
26
|
isExitPlanSwitchModeInput,
|
|
27
27
|
normalizeAskUserQuestions
|
|
28
|
-
} from "../chunk-
|
|
28
|
+
} from "../chunk-SLT5Q37C.js";
|
|
29
29
|
import {
|
|
30
30
|
userAvatarPlaceholderUrl,
|
|
31
31
|
workspaceAgentActivityStatusLabel
|
|
32
|
-
} from "../chunk-
|
|
32
|
+
} from "../chunk-OLI2A3EM.js";
|
|
33
33
|
import {
|
|
34
34
|
resolveWorkspaceAgentSessionSortTimeUnixMs
|
|
35
35
|
} from "../chunk-IBIMGLCD.js";
|
|
36
36
|
import {
|
|
37
37
|
managedAgentRoundedIconUrl
|
|
38
|
-
} from "../chunk-
|
|
38
|
+
} from "../chunk-HVU46DDA.js";
|
|
39
39
|
import {
|
|
40
40
|
workspaceAgentProviderLabel
|
|
41
41
|
} from "../chunk-TYGL25EL.js";
|
|
42
|
-
import "../chunk-PJP5BUU6.js";
|
|
43
|
-
import "../chunk-MTFSQWZ6.js";
|
|
44
|
-
import "../chunk-GCBDIQDX.js";
|
|
45
42
|
import {
|
|
46
43
|
AgentGuiI18nProvider,
|
|
47
44
|
getActiveUiLanguage,
|
|
48
45
|
useTranslation
|
|
49
|
-
} from "../chunk-
|
|
50
|
-
import "../chunk-
|
|
46
|
+
} from "../chunk-5SRRKWE4.js";
|
|
47
|
+
import "../chunk-PJP5BUU6.js";
|
|
48
|
+
import "../chunk-MTFSQWZ6.js";
|
|
49
|
+
import "../chunk-IS6JUDDY.js";
|
|
50
|
+
import "../chunk-GCBDIQDX.js";
|
|
51
51
|
|
|
52
52
|
// agent-message-center/WorkspaceAgentMessageCenterPanel.tsx
|
|
53
53
|
import {
|
|
@@ -5821,6 +5821,7 @@ button.agent-gui-node__conversation-section-toggle:hover
|
|
|
5821
5821
|
--agent-message-locator-dot-size: 6px;
|
|
5822
5822
|
--agent-message-locator-hit-size: 36px;
|
|
5823
5823
|
--agent-message-locator-center-offset: 18px;
|
|
5824
|
+
--agent-message-locator-inline-shift: 4px;
|
|
5824
5825
|
--agent-message-locator-scrollbar-gap: 8px;
|
|
5825
5826
|
--agent-message-locator-visible-height: 100vh;
|
|
5826
5827
|
--agent-message-locator-visible-top-offset: 0px;
|
|
@@ -5856,7 +5857,8 @@ button.agent-gui-node__conversation-section-toggle:hover
|
|
|
5856
5857
|
right: calc(
|
|
5857
5858
|
var(--agent-message-locator-scrollbar-gap) +
|
|
5858
5859
|
var(--agent-message-locator-center-offset) -
|
|
5859
|
-
var(--agent-message-locator-hit-size) / 2
|
|
5860
|
+
var(--agent-message-locator-hit-size) / 2 -
|
|
5861
|
+
var(--agent-message-locator-inline-shift)
|
|
5860
5862
|
);
|
|
5861
5863
|
width: var(--agent-message-locator-hit-size);
|
|
5862
5864
|
height: 100%;
|
|
@@ -7448,7 +7450,11 @@ html[data-theme="light"] [data-message-center-item-id].agent-gui-edge-glow {
|
|
|
7448
7450
|
overflow-y: auto;
|
|
7449
7451
|
overflow-wrap: anywhere;
|
|
7450
7452
|
scrollbar-gutter: stable;
|
|
7451
|
-
scrollbar-
|
|
7453
|
+
/* Keep the scrollbar persistently visible (not hover/focus-only) once the
|
|
7454
|
+
draft overflows the visible viewport: a long pasted/dictated block of
|
|
7455
|
+
text must never look like a single visible line with no affordance that
|
|
7456
|
+
more content exists below (see: Feishu recvo2ITCPrpcA). */
|
|
7457
|
+
scrollbar-width: thin;
|
|
7452
7458
|
white-space: pre-wrap;
|
|
7453
7459
|
}
|
|
7454
7460
|
|
|
@@ -7461,41 +7467,10 @@ html[data-theme="light"] [data-message-center-item-id].agent-gui-edge-glow {
|
|
|
7461
7467
|
max-height: var(--agent-gui-composer-text-viewport-height);
|
|
7462
7468
|
}
|
|
7463
7469
|
|
|
7464
|
-
.agent-gui-node__composer[data-layout="dock"]
|
|
7465
|
-
.agent-gui-node__composer-prompt-input-area:hover
|
|
7466
|
-
textarea,
|
|
7467
|
-
.agent-gui-node__composer[data-layout="dock"]
|
|
7468
|
-
.agent-gui-node__composer-prompt-input-area:hover
|
|
7469
|
-
.agent-gui-node__composer-textarea,
|
|
7470
|
-
.agent-gui-node__composer[data-layout="dock"]
|
|
7471
|
-
.agent-gui-node__composer-prompt-input-area:focus-within
|
|
7472
|
-
textarea,
|
|
7473
|
-
.agent-gui-node__composer[data-layout="dock"]
|
|
7474
|
-
.agent-gui-node__composer-prompt-input-area:focus-within
|
|
7475
|
-
.agent-gui-node__composer-textarea {
|
|
7476
|
-
scrollbar-width: thin;
|
|
7477
|
-
}
|
|
7478
|
-
|
|
7479
7470
|
.agent-gui-node__composer[data-layout="dock"] textarea::-webkit-scrollbar,
|
|
7480
7471
|
.agent-gui-node__composer[data-layout="dock"]
|
|
7481
7472
|
.agent-gui-node__composer-textarea::-webkit-scrollbar {
|
|
7482
7473
|
display: block;
|
|
7483
|
-
width: 0;
|
|
7484
|
-
height: 0;
|
|
7485
|
-
}
|
|
7486
|
-
|
|
7487
|
-
.agent-gui-node__composer[data-layout="dock"]
|
|
7488
|
-
.agent-gui-node__composer-prompt-input-area:hover
|
|
7489
|
-
textarea::-webkit-scrollbar,
|
|
7490
|
-
.agent-gui-node__composer[data-layout="dock"]
|
|
7491
|
-
.agent-gui-node__composer-prompt-input-area:hover
|
|
7492
|
-
.agent-gui-node__composer-textarea::-webkit-scrollbar,
|
|
7493
|
-
.agent-gui-node__composer[data-layout="dock"]
|
|
7494
|
-
.agent-gui-node__composer-prompt-input-area:focus-within
|
|
7495
|
-
textarea::-webkit-scrollbar,
|
|
7496
|
-
.agent-gui-node__composer[data-layout="dock"]
|
|
7497
|
-
.agent-gui-node__composer-prompt-input-area:focus-within
|
|
7498
|
-
.agent-gui-node__composer-textarea::-webkit-scrollbar {
|
|
7499
7474
|
width: 4px;
|
|
7500
7475
|
height: 4px;
|
|
7501
7476
|
}
|
|
@@ -4,7 +4,7 @@ import {
|
|
|
4
4
|
formatAgentSessionMentionText,
|
|
5
5
|
normalizeAgentGUIProviderIdentity,
|
|
6
6
|
resolveAgentGUIExplicitConversationTitle
|
|
7
|
-
} from "./chunk-
|
|
7
|
+
} from "./chunk-UCCUIUGK.js";
|
|
8
8
|
|
|
9
9
|
// workbench/sessionTitle.ts
|
|
10
10
|
function formatAgentGuiSessionPlainTitle(title, options = {}) {
|
|
@@ -96,4 +96,4 @@ export {
|
|
|
96
96
|
formatAgentGuiConversationPlainTitle,
|
|
97
97
|
resolveAgentGuiWorkbenchSessionTitle
|
|
98
98
|
};
|
|
99
|
-
//# sourceMappingURL=chunk-
|
|
99
|
+
//# sourceMappingURL=chunk-2WUDORCV.js.map
|
|
@@ -6,7 +6,7 @@ import {
|
|
|
6
6
|
setCurrentAgentGuiI18nRuntime,
|
|
7
7
|
translate,
|
|
8
8
|
translateInUiLanguage
|
|
9
|
-
} from "./chunk-
|
|
9
|
+
} from "./chunk-IS6JUDDY.js";
|
|
10
10
|
|
|
11
11
|
// i18n/index.ts
|
|
12
12
|
import React, {
|
|
@@ -68,4 +68,4 @@ export {
|
|
|
68
68
|
AgentGuiI18nProvider,
|
|
69
69
|
useTranslation
|
|
70
70
|
};
|
|
71
|
-
//# sourceMappingURL=chunk-
|
|
71
|
+
//# sourceMappingURL=chunk-5SRRKWE4.js.map
|