@react-grab/claude-code 0.0.81 → 0.0.83
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/cli.cjs +2 -6
- package/dist/cli.js +3 -6
- package/dist/client.cjs +51 -24
- package/dist/client.d.cts +0 -1
- package/dist/client.d.ts +0 -1
- package/dist/client.global.js +5 -5
- package/dist/client.js +51 -24
- package/dist/server.cjs +5 -29
- package/dist/server.js +5 -29
- package/package.json +5 -4
package/dist/cli.cjs
CHANGED
|
@@ -1,10 +1,8 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
2
|
'use strict';
|
|
3
3
|
|
|
4
|
-
var url = require('url');
|
|
5
4
|
var path = require('path');
|
|
6
5
|
|
|
7
|
-
var _documentCurrentScript = typeof document !== 'undefined' ? document.currentScript : null;
|
|
8
6
|
var __create = Object.create;
|
|
9
7
|
var __defProp = Object.defineProperty;
|
|
10
8
|
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
@@ -605,10 +603,8 @@ var import_picocolors = __toESM(require_picocolors());
|
|
|
605
603
|
var DEFAULT_PORT = 4567;
|
|
606
604
|
|
|
607
605
|
// src/cli.ts
|
|
608
|
-
var VERSION = "0.0.
|
|
609
|
-
var
|
|
610
|
-
var __dirname$1 = path.dirname(__filename$1);
|
|
611
|
-
var serverPath = path.join(__dirname$1, "server.js");
|
|
606
|
+
var VERSION = "0.0.83";
|
|
607
|
+
var serverPath = path.join(__dirname, "server.cjs");
|
|
612
608
|
(0, import_cross_spawn.default)(process.execPath, [serverPath], {
|
|
613
609
|
detached: true,
|
|
614
610
|
stdio: "ignore"
|
package/dist/cli.js
CHANGED
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
import {
|
|
3
|
-
import { dirname, join } from 'path';
|
|
2
|
+
import { join } from 'path';
|
|
4
3
|
|
|
5
4
|
var __create = Object.create;
|
|
6
5
|
var __defProp = Object.defineProperty;
|
|
@@ -602,10 +601,8 @@ var import_picocolors = __toESM(require_picocolors());
|
|
|
602
601
|
var DEFAULT_PORT = 4567;
|
|
603
602
|
|
|
604
603
|
// src/cli.ts
|
|
605
|
-
var VERSION = "0.0.
|
|
606
|
-
var
|
|
607
|
-
var __dirname = dirname(__filename);
|
|
608
|
-
var serverPath = join(__dirname, "server.js");
|
|
604
|
+
var VERSION = "0.0.83";
|
|
605
|
+
var serverPath = join(__dirname, "server.cjs");
|
|
609
606
|
(0, import_cross_spawn.default)(process.execPath, [serverPath], {
|
|
610
607
|
detached: true,
|
|
611
608
|
stdio: "ignore"
|
package/dist/client.cjs
CHANGED
|
@@ -1,24 +1,8 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
//
|
|
4
|
-
var DEFAULT_PORT = 4567;
|
|
3
|
+
// ../utils/dist/client.js
|
|
5
4
|
var CONNECTION_CHECK_TTL_MS = 5e3;
|
|
6
|
-
|
|
7
|
-
// src/client.ts
|
|
8
|
-
var DEFAULT_SERVER_URL = `http://localhost:${DEFAULT_PORT}`;
|
|
9
5
|
var STORAGE_KEY = "react-grab:agent-sessions";
|
|
10
|
-
var DEFAULT_OPTIONS = {
|
|
11
|
-
systemPrompt: {
|
|
12
|
-
type: "preset",
|
|
13
|
-
preset: "claude_code",
|
|
14
|
-
append: `You are helping a user make changes to a React component based on a selected element.
|
|
15
|
-
The user has selected an element from their UI and wants you to help modify it.
|
|
16
|
-
Provide clear, concise status updates as you work.`
|
|
17
|
-
},
|
|
18
|
-
model: "haiku",
|
|
19
|
-
permissionMode: "bypassPermissions",
|
|
20
|
-
maxTurns: 10
|
|
21
|
-
};
|
|
22
6
|
var parseSSEEvent = (eventBlock) => {
|
|
23
7
|
let eventType = "";
|
|
24
8
|
let data = "";
|
|
@@ -68,7 +52,26 @@ async function* streamSSE(stream, signal) {
|
|
|
68
52
|
}
|
|
69
53
|
}
|
|
70
54
|
}
|
|
55
|
+
|
|
56
|
+
// src/constants.ts
|
|
57
|
+
var DEFAULT_PORT = 4567;
|
|
58
|
+
|
|
59
|
+
// src/client.ts
|
|
60
|
+
var DEFAULT_SERVER_URL = `http://localhost:${DEFAULT_PORT}`;
|
|
61
|
+
var DEFAULT_OPTIONS = {
|
|
62
|
+
systemPrompt: {
|
|
63
|
+
type: "preset",
|
|
64
|
+
preset: "claude_code",
|
|
65
|
+
append: `You are helping a user make changes to a React component based on a selected element.
|
|
66
|
+
The user has selected an element from their UI and wants you to help modify it.
|
|
67
|
+
Provide clear, concise status updates as you work.`
|
|
68
|
+
},
|
|
69
|
+
model: "haiku",
|
|
70
|
+
permissionMode: "bypassPermissions",
|
|
71
|
+
maxTurns: 10
|
|
72
|
+
};
|
|
71
73
|
async function* streamFromServer(serverUrl, context, signal) {
|
|
74
|
+
const startTime = Date.now();
|
|
72
75
|
const sessionId = context.sessionId;
|
|
73
76
|
const handleAbort = () => {
|
|
74
77
|
if (sessionId) {
|
|
@@ -92,7 +95,37 @@ async function* streamFromServer(serverUrl, context, signal) {
|
|
|
92
95
|
if (!response.body) {
|
|
93
96
|
throw new Error("No response body");
|
|
94
97
|
}
|
|
95
|
-
|
|
98
|
+
const iterator = streamSSE(response.body, signal)[Symbol.asyncIterator]();
|
|
99
|
+
let done = false;
|
|
100
|
+
let pendingNext = iterator.next();
|
|
101
|
+
while (!done) {
|
|
102
|
+
const result = await Promise.race([
|
|
103
|
+
pendingNext.then((iteratorResult) => ({
|
|
104
|
+
type: "status",
|
|
105
|
+
iteratorResult
|
|
106
|
+
})),
|
|
107
|
+
new Promise(
|
|
108
|
+
(resolve) => setTimeout(() => resolve({ type: "timeout" }), 100)
|
|
109
|
+
)
|
|
110
|
+
]);
|
|
111
|
+
if (result.type === "timeout") {
|
|
112
|
+
const elapsedSeconds = (Date.now() - startTime) / 1e3;
|
|
113
|
+
yield `Working\u2026 ${elapsedSeconds.toFixed(1)}s`;
|
|
114
|
+
} else {
|
|
115
|
+
const iteratorResult = result.iteratorResult;
|
|
116
|
+
done = iteratorResult.done ?? false;
|
|
117
|
+
if (!done && iteratorResult.value) {
|
|
118
|
+
const status = iteratorResult.value;
|
|
119
|
+
if (status === "Completed successfully") {
|
|
120
|
+
const totalSeconds = ((Date.now() - startTime) / 1e3).toFixed(1);
|
|
121
|
+
yield `Completed in ${totalSeconds}s`;
|
|
122
|
+
} else {
|
|
123
|
+
yield status;
|
|
124
|
+
}
|
|
125
|
+
pendingNext = iterator.next();
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
}
|
|
96
129
|
} finally {
|
|
97
130
|
signal.removeEventListener("abort", handleAbort);
|
|
98
131
|
}
|
|
@@ -147,12 +180,6 @@ var createClaudeAgentProvider = (providerOptions = {}) => {
|
|
|
147
180
|
connectionCache = { result: false, timestamp: now };
|
|
148
181
|
return false;
|
|
149
182
|
}
|
|
150
|
-
},
|
|
151
|
-
undo: async () => {
|
|
152
|
-
try {
|
|
153
|
-
await fetch(`${serverUrl}/undo`, { method: "POST" });
|
|
154
|
-
} catch {
|
|
155
|
-
}
|
|
156
183
|
}
|
|
157
184
|
};
|
|
158
185
|
};
|
package/dist/client.d.cts
CHANGED
package/dist/client.d.ts
CHANGED
package/dist/client.global.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
var ReactGrabClaudeCode=(function(exports){'use strict';var
|
|
2
|
-
|
|
3
|
-
Provide clear, concise status updates as you work.`},model:"haiku",permissionMode:"bypassPermissions",maxTurns:10},E=s=>{let t="",o="";for(let n of s.split(`
|
|
4
|
-
`))n.startsWith("event:")?t=n.slice(6).trim():n.startsWith("data:")&&(o=n.slice(5).trim());return {eventType:t,data:o}};async function*b(s,t){let o=s.getReader(),n=new TextDecoder,r="",e=false,i=()=>{e=true,o.cancel().catch(()=>{});};t.addEventListener("abort",i);try{if(t.aborted)throw new DOMException("Aborted","AbortError");for(;;){let a=await o.read();if(e||t.aborted)throw new DOMException("Aborted","AbortError");let{done:p,value:u}=a;u&&(r+=n.decode(u,{stream:!0}));let c;for(;(c=r.indexOf(`
|
|
1
|
+
var ReactGrabClaudeCode=(function(exports){'use strict';var m=5e3,f="react-grab:agent-sessions",A=c=>{let e="",n="";for(let t of c.split(`
|
|
2
|
+
`))t.startsWith("event:")?e=t.slice(6).trim():t.startsWith("data:")&&(n=t.slice(5).trim());return {eventType:e,data:n}};async function*y(c,e){let n=c.getReader(),t=new TextDecoder,s="",o=false,a=()=>{o=true,n.cancel().catch(()=>{});};e.addEventListener("abort",a);try{if(e.aborted)throw new DOMException("Aborted","AbortError");for(;;){let i=await n.read();if(o||e.aborted)throw new DOMException("Aborted","AbortError");let{done:l,value:u}=i;u&&(s+=t.decode(u,{stream:!0}));let d;for(;(d=s.indexOf(`
|
|
5
3
|
|
|
6
|
-
`))!==-1;){let{eventType:
|
|
4
|
+
`))!==-1;){let{eventType:r,data:p}=A(s.slice(0,d));if(s=s.slice(d+2),r==="done")return;if(r==="error")throw new Error(p||"Agent error");p&&(yield p);}if(l)break}}finally{e.removeEventListener("abort",a);try{n.releaseLock();}catch{}}}var w=`http://localhost:${4567}`,C={systemPrompt:{type:"preset",preset:"claude_code",append:`You are helping a user make changes to a React component based on a selected element.
|
|
5
|
+
The user has selected an element from their UI and wants you to help modify it.
|
|
6
|
+
Provide clear, concise status updates as you work.`},model:"haiku",permissionMode:"bypassPermissions",maxTurns:10};async function*g(c,e,n){let t=Date.now(),s=e.sessionId,o=()=>{s&&fetch(`${c}/abort/${s}`,{method:"POST"}).catch(()=>{});};n.addEventListener("abort",o);try{let a=await fetch(`${c}/agent`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(e),signal:n});if(!a.ok)throw new Error(`Server error: ${a.status}`);if(!a.body)throw new Error("No response body");let i=y(a.body,n)[Symbol.asyncIterator](),l=!1,u=i.next();for(;!l;){let d=await Promise.race([u.then(r=>({type:"status",iteratorResult:r})),new Promise(r=>setTimeout(()=>r({type:"timeout"}),100))]);if(d.type==="timeout")yield `Working\u2026 ${((Date.now()-t)/1e3).toFixed(1)}s`;else {let r=d.iteratorResult;if(l=r.done??!1,!l&&r.value){let p=r.value;p==="Completed successfully"?yield `Completed in ${((Date.now()-t)/1e3).toFixed(1)}s`:yield p,u=i.next();}}}}finally{n.removeEventListener("abort",o);}}var E=(c={})=>{let{serverUrl:e=w,getOptions:n}=c,t=null,s=o=>({...C,...n?.()??{},...o??{}});return {send:async function*(o,a){let i={...o,options:s(o.options)};yield*g(e,i,a);},resume:async function*(o,a,i){let l=i.getItem(f);if(!l)throw new Error("No sessions to resume");let d=JSON.parse(l)[o];if(!d)throw new Error(`Session ${o} not found`);let r=d.context,p={...r,options:s(r.options)};yield "Resuming...",yield*g(e,p,a);},supportsResume:true,supportsFollowUp:true,checkConnection:async()=>{let o=Date.now();if(t&&o-t.timestamp<m)return t.result;try{let i=(await fetch(`${e}/health`,{method:"GET"})).ok;return t={result:i,timestamp:o},i}catch{return t={result:false,timestamp:o},false}}}},b=async()=>{if(typeof window>"u")return;let c=E(),e=s=>{s.setAgent({provider:c,storage:sessionStorage});},n=window.__REACT_GRAB__;if(n){e(n);return}window.addEventListener("react-grab:init",s=>{e(s.detail);},{once:true});let t=window.__REACT_GRAB__;t&&e(t);};b();exports.attachAgent=b;exports.createClaudeAgentProvider=E;return exports;})({});
|
package/dist/client.js
CHANGED
|
@@ -1,22 +1,6 @@
|
|
|
1
|
-
//
|
|
2
|
-
var DEFAULT_PORT = 4567;
|
|
1
|
+
// ../utils/dist/client.js
|
|
3
2
|
var CONNECTION_CHECK_TTL_MS = 5e3;
|
|
4
|
-
|
|
5
|
-
// src/client.ts
|
|
6
|
-
var DEFAULT_SERVER_URL = `http://localhost:${DEFAULT_PORT}`;
|
|
7
3
|
var STORAGE_KEY = "react-grab:agent-sessions";
|
|
8
|
-
var DEFAULT_OPTIONS = {
|
|
9
|
-
systemPrompt: {
|
|
10
|
-
type: "preset",
|
|
11
|
-
preset: "claude_code",
|
|
12
|
-
append: `You are helping a user make changes to a React component based on a selected element.
|
|
13
|
-
The user has selected an element from their UI and wants you to help modify it.
|
|
14
|
-
Provide clear, concise status updates as you work.`
|
|
15
|
-
},
|
|
16
|
-
model: "haiku",
|
|
17
|
-
permissionMode: "bypassPermissions",
|
|
18
|
-
maxTurns: 10
|
|
19
|
-
};
|
|
20
4
|
var parseSSEEvent = (eventBlock) => {
|
|
21
5
|
let eventType = "";
|
|
22
6
|
let data = "";
|
|
@@ -66,7 +50,26 @@ async function* streamSSE(stream, signal) {
|
|
|
66
50
|
}
|
|
67
51
|
}
|
|
68
52
|
}
|
|
53
|
+
|
|
54
|
+
// src/constants.ts
|
|
55
|
+
var DEFAULT_PORT = 4567;
|
|
56
|
+
|
|
57
|
+
// src/client.ts
|
|
58
|
+
var DEFAULT_SERVER_URL = `http://localhost:${DEFAULT_PORT}`;
|
|
59
|
+
var DEFAULT_OPTIONS = {
|
|
60
|
+
systemPrompt: {
|
|
61
|
+
type: "preset",
|
|
62
|
+
preset: "claude_code",
|
|
63
|
+
append: `You are helping a user make changes to a React component based on a selected element.
|
|
64
|
+
The user has selected an element from their UI and wants you to help modify it.
|
|
65
|
+
Provide clear, concise status updates as you work.`
|
|
66
|
+
},
|
|
67
|
+
model: "haiku",
|
|
68
|
+
permissionMode: "bypassPermissions",
|
|
69
|
+
maxTurns: 10
|
|
70
|
+
};
|
|
69
71
|
async function* streamFromServer(serverUrl, context, signal) {
|
|
72
|
+
const startTime = Date.now();
|
|
70
73
|
const sessionId = context.sessionId;
|
|
71
74
|
const handleAbort = () => {
|
|
72
75
|
if (sessionId) {
|
|
@@ -90,7 +93,37 @@ async function* streamFromServer(serverUrl, context, signal) {
|
|
|
90
93
|
if (!response.body) {
|
|
91
94
|
throw new Error("No response body");
|
|
92
95
|
}
|
|
93
|
-
|
|
96
|
+
const iterator = streamSSE(response.body, signal)[Symbol.asyncIterator]();
|
|
97
|
+
let done = false;
|
|
98
|
+
let pendingNext = iterator.next();
|
|
99
|
+
while (!done) {
|
|
100
|
+
const result = await Promise.race([
|
|
101
|
+
pendingNext.then((iteratorResult) => ({
|
|
102
|
+
type: "status",
|
|
103
|
+
iteratorResult
|
|
104
|
+
})),
|
|
105
|
+
new Promise(
|
|
106
|
+
(resolve) => setTimeout(() => resolve({ type: "timeout" }), 100)
|
|
107
|
+
)
|
|
108
|
+
]);
|
|
109
|
+
if (result.type === "timeout") {
|
|
110
|
+
const elapsedSeconds = (Date.now() - startTime) / 1e3;
|
|
111
|
+
yield `Working\u2026 ${elapsedSeconds.toFixed(1)}s`;
|
|
112
|
+
} else {
|
|
113
|
+
const iteratorResult = result.iteratorResult;
|
|
114
|
+
done = iteratorResult.done ?? false;
|
|
115
|
+
if (!done && iteratorResult.value) {
|
|
116
|
+
const status = iteratorResult.value;
|
|
117
|
+
if (status === "Completed successfully") {
|
|
118
|
+
const totalSeconds = ((Date.now() - startTime) / 1e3).toFixed(1);
|
|
119
|
+
yield `Completed in ${totalSeconds}s`;
|
|
120
|
+
} else {
|
|
121
|
+
yield status;
|
|
122
|
+
}
|
|
123
|
+
pendingNext = iterator.next();
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
}
|
|
94
127
|
} finally {
|
|
95
128
|
signal.removeEventListener("abort", handleAbort);
|
|
96
129
|
}
|
|
@@ -145,12 +178,6 @@ var createClaudeAgentProvider = (providerOptions = {}) => {
|
|
|
145
178
|
connectionCache = { result: false, timestamp: now };
|
|
146
179
|
return false;
|
|
147
180
|
}
|
|
148
|
-
},
|
|
149
|
-
undo: async () => {
|
|
150
|
-
try {
|
|
151
|
-
await fetch(`${serverUrl}/undo`, { method: "POST" });
|
|
152
|
-
} catch {
|
|
153
|
-
}
|
|
154
181
|
}
|
|
155
182
|
};
|
|
156
183
|
};
|
package/dist/server.cjs
CHANGED
|
@@ -18157,8 +18157,11 @@ function query({
|
|
|
18157
18157
|
// src/constants.ts
|
|
18158
18158
|
var DEFAULT_PORT = 4567;
|
|
18159
18159
|
|
|
18160
|
+
// ../utils/dist/server.js
|
|
18161
|
+
var sleep = (ms) => new Promise((resolve) => setTimeout(resolve, ms));
|
|
18162
|
+
|
|
18160
18163
|
// src/server.ts
|
|
18161
|
-
var VERSION = "0.0.
|
|
18164
|
+
var VERSION = "0.0.83";
|
|
18162
18165
|
var resolveClaudePath = () => {
|
|
18163
18166
|
const command = process.platform === "win32" ? "where claude" : "which claude";
|
|
18164
18167
|
try {
|
|
@@ -18170,7 +18173,6 @@ var resolveClaudePath = () => {
|
|
|
18170
18173
|
};
|
|
18171
18174
|
var claudeSessionMap = /* @__PURE__ */ new Map();
|
|
18172
18175
|
var abortedSessions = /* @__PURE__ */ new Set();
|
|
18173
|
-
var lastClaudeSessionId;
|
|
18174
18176
|
var isTextBlock = (block) => block.type === "text";
|
|
18175
18177
|
var createServer = () => {
|
|
18176
18178
|
const app = new Hono2();
|
|
@@ -18221,7 +18223,6 @@ ${content}`;
|
|
|
18221
18223
|
}
|
|
18222
18224
|
}
|
|
18223
18225
|
if (!isAborted2() && capturedClaudeSessionId) {
|
|
18224
|
-
lastClaudeSessionId = capturedClaudeSessionId;
|
|
18225
18226
|
if (sessionId) {
|
|
18226
18227
|
claudeSessionMap.set(sessionId, capturedClaudeSessionId);
|
|
18227
18228
|
}
|
|
@@ -18254,32 +18255,6 @@ ${stderr.trim()}` : errorMessage;
|
|
|
18254
18255
|
abortedSessions.add(sessionId);
|
|
18255
18256
|
return context.json({ status: "ok" });
|
|
18256
18257
|
});
|
|
18257
|
-
app.post("/undo", async (context) => {
|
|
18258
|
-
if (!lastClaudeSessionId) {
|
|
18259
|
-
return context.json({ status: "error", message: "No session to undo" });
|
|
18260
|
-
}
|
|
18261
|
-
try {
|
|
18262
|
-
const env = { ...process.env };
|
|
18263
|
-
delete env.NODE_OPTIONS;
|
|
18264
|
-
delete env.VSCODE_INSPECTOR_OPTIONS;
|
|
18265
|
-
const queryResult = query({
|
|
18266
|
-
prompt: "/rewind",
|
|
18267
|
-
options: {
|
|
18268
|
-
pathToClaudeCodeExecutable: resolveClaudePath(),
|
|
18269
|
-
cwd: process.cwd(),
|
|
18270
|
-
env,
|
|
18271
|
-
resume: lastClaudeSessionId
|
|
18272
|
-
}
|
|
18273
|
-
});
|
|
18274
|
-
for await (const message of queryResult) {
|
|
18275
|
-
if (message.type === "result") break;
|
|
18276
|
-
}
|
|
18277
|
-
return context.json({ status: "ok" });
|
|
18278
|
-
} catch (error) {
|
|
18279
|
-
const errorMessage = error instanceof Error ? error.message : "Unknown error";
|
|
18280
|
-
return context.json({ status: "error", message: errorMessage });
|
|
18281
|
-
}
|
|
18282
|
-
});
|
|
18283
18258
|
app.get("/health", (context) => {
|
|
18284
18259
|
return context.json({ status: "ok", provider: "claude" });
|
|
18285
18260
|
});
|
|
@@ -18288,6 +18263,7 @@ ${stderr.trim()}` : errorMessage;
|
|
|
18288
18263
|
var startServer = async (port = DEFAULT_PORT) => {
|
|
18289
18264
|
await fkill(`:${port}`, { force: true, silent: true }).catch(() => {
|
|
18290
18265
|
});
|
|
18266
|
+
await sleep(100);
|
|
18291
18267
|
const app = createServer();
|
|
18292
18268
|
serve({ fetch: app.fetch, port });
|
|
18293
18269
|
console.log(
|
package/dist/server.js
CHANGED
|
@@ -18128,8 +18128,11 @@ function query({
|
|
|
18128
18128
|
// src/constants.ts
|
|
18129
18129
|
var DEFAULT_PORT = 4567;
|
|
18130
18130
|
|
|
18131
|
+
// ../utils/dist/server.js
|
|
18132
|
+
var sleep = (ms) => new Promise((resolve) => setTimeout(resolve, ms));
|
|
18133
|
+
|
|
18131
18134
|
// src/server.ts
|
|
18132
|
-
var VERSION = "0.0.
|
|
18135
|
+
var VERSION = "0.0.83";
|
|
18133
18136
|
var resolveClaudePath = () => {
|
|
18134
18137
|
const command = process.platform === "win32" ? "where claude" : "which claude";
|
|
18135
18138
|
try {
|
|
@@ -18141,7 +18144,6 @@ var resolveClaudePath = () => {
|
|
|
18141
18144
|
};
|
|
18142
18145
|
var claudeSessionMap = /* @__PURE__ */ new Map();
|
|
18143
18146
|
var abortedSessions = /* @__PURE__ */ new Set();
|
|
18144
|
-
var lastClaudeSessionId;
|
|
18145
18147
|
var isTextBlock = (block) => block.type === "text";
|
|
18146
18148
|
var createServer = () => {
|
|
18147
18149
|
const app = new Hono2();
|
|
@@ -18192,7 +18194,6 @@ ${content}`;
|
|
|
18192
18194
|
}
|
|
18193
18195
|
}
|
|
18194
18196
|
if (!isAborted2() && capturedClaudeSessionId) {
|
|
18195
|
-
lastClaudeSessionId = capturedClaudeSessionId;
|
|
18196
18197
|
if (sessionId) {
|
|
18197
18198
|
claudeSessionMap.set(sessionId, capturedClaudeSessionId);
|
|
18198
18199
|
}
|
|
@@ -18225,32 +18226,6 @@ ${stderr.trim()}` : errorMessage;
|
|
|
18225
18226
|
abortedSessions.add(sessionId);
|
|
18226
18227
|
return context.json({ status: "ok" });
|
|
18227
18228
|
});
|
|
18228
|
-
app.post("/undo", async (context) => {
|
|
18229
|
-
if (!lastClaudeSessionId) {
|
|
18230
|
-
return context.json({ status: "error", message: "No session to undo" });
|
|
18231
|
-
}
|
|
18232
|
-
try {
|
|
18233
|
-
const env = { ...process.env };
|
|
18234
|
-
delete env.NODE_OPTIONS;
|
|
18235
|
-
delete env.VSCODE_INSPECTOR_OPTIONS;
|
|
18236
|
-
const queryResult = query({
|
|
18237
|
-
prompt: "/rewind",
|
|
18238
|
-
options: {
|
|
18239
|
-
pathToClaudeCodeExecutable: resolveClaudePath(),
|
|
18240
|
-
cwd: process.cwd(),
|
|
18241
|
-
env,
|
|
18242
|
-
resume: lastClaudeSessionId
|
|
18243
|
-
}
|
|
18244
|
-
});
|
|
18245
|
-
for await (const message of queryResult) {
|
|
18246
|
-
if (message.type === "result") break;
|
|
18247
|
-
}
|
|
18248
|
-
return context.json({ status: "ok" });
|
|
18249
|
-
} catch (error) {
|
|
18250
|
-
const errorMessage = error instanceof Error ? error.message : "Unknown error";
|
|
18251
|
-
return context.json({ status: "error", message: errorMessage });
|
|
18252
|
-
}
|
|
18253
|
-
});
|
|
18254
18229
|
app.get("/health", (context) => {
|
|
18255
18230
|
return context.json({ status: "ok", provider: "claude" });
|
|
18256
18231
|
});
|
|
@@ -18259,6 +18234,7 @@ ${stderr.trim()}` : errorMessage;
|
|
|
18259
18234
|
var startServer = async (port = DEFAULT_PORT) => {
|
|
18260
18235
|
await fkill(`:${port}`, { force: true, silent: true }).catch(() => {
|
|
18261
18236
|
});
|
|
18237
|
+
await sleep(100);
|
|
18262
18238
|
const app = createServer();
|
|
18263
18239
|
serve({ fetch: app.fetch, port });
|
|
18264
18240
|
console.log(
|
package/package.json
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@react-grab/claude-code",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.83",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"bin": {
|
|
6
|
-
"react-grab-claude-code": "./dist/cli.
|
|
6
|
+
"react-grab-claude-code": "./dist/cli.cjs"
|
|
7
7
|
},
|
|
8
8
|
"exports": {
|
|
9
9
|
"./client": {
|
|
@@ -25,7 +25,8 @@
|
|
|
25
25
|
],
|
|
26
26
|
"devDependencies": {
|
|
27
27
|
"@types/cross-spawn": "^6.0.6",
|
|
28
|
-
"tsup": "^8.4.0"
|
|
28
|
+
"tsup": "^8.4.0",
|
|
29
|
+
"@react-grab/utils": "0.0.83"
|
|
29
30
|
},
|
|
30
31
|
"dependencies": {
|
|
31
32
|
"@anthropic-ai/claude-agent-sdk": "^0.1.0",
|
|
@@ -34,7 +35,7 @@
|
|
|
34
35
|
"fkill": "^9.0.0",
|
|
35
36
|
"hono": "^4.0.0",
|
|
36
37
|
"picocolors": "^1.1.1",
|
|
37
|
-
"react-grab": "0.0.
|
|
38
|
+
"react-grab": "0.0.83"
|
|
38
39
|
},
|
|
39
40
|
"scripts": {
|
|
40
41
|
"dev": "tsup --watch",
|