@react-grab/amp 0.0.82 → 0.0.84
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 +6596 -58
- package/dist/cli.js +6589 -57
- package/dist/client.cjs +39 -6
- package/dist/client.global.js +4 -3
- package/dist/client.js +39 -6
- package/dist/server.cjs +17 -5
- package/dist/server.js +17 -5
- package/package.json +5 -5
package/dist/client.cjs
CHANGED
|
@@ -1,11 +1,7 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
-
//
|
|
4
|
-
var DEFAULT_PORT = 9567;
|
|
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
6
|
var parseSSEEvent = (eventBlock) => {
|
|
11
7
|
let eventType = "";
|
|
@@ -56,7 +52,14 @@ async function* streamSSE(stream, signal) {
|
|
|
56
52
|
}
|
|
57
53
|
}
|
|
58
54
|
}
|
|
55
|
+
|
|
56
|
+
// src/constants.ts
|
|
57
|
+
var DEFAULT_PORT = 9567;
|
|
58
|
+
|
|
59
|
+
// src/client.ts
|
|
60
|
+
var DEFAULT_SERVER_URL = `http://localhost:${DEFAULT_PORT}`;
|
|
59
61
|
async function* streamFromServer(serverUrl, context, signal) {
|
|
62
|
+
const startTime = Date.now();
|
|
60
63
|
const sessionId = context.sessionId;
|
|
61
64
|
const handleAbort = () => {
|
|
62
65
|
if (sessionId) {
|
|
@@ -80,7 +83,37 @@ async function* streamFromServer(serverUrl, context, signal) {
|
|
|
80
83
|
if (!response.body) {
|
|
81
84
|
throw new Error("No response body");
|
|
82
85
|
}
|
|
83
|
-
|
|
86
|
+
const iterator = streamSSE(response.body, signal)[Symbol.asyncIterator]();
|
|
87
|
+
let done = false;
|
|
88
|
+
let pendingNext = iterator.next();
|
|
89
|
+
while (!done) {
|
|
90
|
+
const result = await Promise.race([
|
|
91
|
+
pendingNext.then((iteratorResult) => ({
|
|
92
|
+
type: "status",
|
|
93
|
+
iteratorResult
|
|
94
|
+
})),
|
|
95
|
+
new Promise(
|
|
96
|
+
(resolve) => setTimeout(() => resolve({ type: "timeout" }), 100)
|
|
97
|
+
)
|
|
98
|
+
]);
|
|
99
|
+
if (result.type === "timeout") {
|
|
100
|
+
const elapsedSeconds = (Date.now() - startTime) / 1e3;
|
|
101
|
+
yield `Working\u2026 ${elapsedSeconds.toFixed(1)}s`;
|
|
102
|
+
} else {
|
|
103
|
+
const iteratorResult = result.iteratorResult;
|
|
104
|
+
done = iteratorResult.done ?? false;
|
|
105
|
+
if (!done && iteratorResult.value) {
|
|
106
|
+
const status = iteratorResult.value;
|
|
107
|
+
if (status === "Completed successfully") {
|
|
108
|
+
const totalSeconds = ((Date.now() - startTime) / 1e3).toFixed(1);
|
|
109
|
+
yield `Completed in ${totalSeconds}s`;
|
|
110
|
+
} else {
|
|
111
|
+
yield status;
|
|
112
|
+
}
|
|
113
|
+
pendingNext = iterator.next();
|
|
114
|
+
}
|
|
115
|
+
}
|
|
116
|
+
}
|
|
84
117
|
} finally {
|
|
85
118
|
signal.removeEventListener("abort", handleAbort);
|
|
86
119
|
}
|
package/dist/client.global.js
CHANGED
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
var ReactGrabAmp=(function(exports){'use strict';var u
|
|
2
|
-
`))
|
|
1
|
+
var ReactGrabAmp=(function(exports){'use strict';var A=5e3,u="react-grab:agent-sessions",y=c=>{let e="",n="";for(let o of c.split(`
|
|
2
|
+
`))o.startsWith("event:")?e=o.slice(6).trim():o.startsWith("data:")&&(n=o.slice(5).trim());return {eventType:e,data:n}};async function*f(c,e){let n=c.getReader(),o=new TextDecoder,r="",t=false,i=()=>{t=true,n.cancel().catch(()=>{});};e.addEventListener("abort",i);try{if(e.aborted)throw new DOMException("Aborted","AbortError");for(;;){let a=await n.read();if(t||e.aborted)throw new DOMException("Aborted","AbortError");let{done:p,value:m}=a;m&&(r+=o.decode(m,{stream:!0}));let d;for(;(d=r.indexOf(`
|
|
3
3
|
|
|
4
|
-
`))!==-1;){let{eventType:
|
|
4
|
+
`))!==-1;){let{eventType:s,data:l}=y(r.slice(0,d));if(r=r.slice(d+2),s==="done")return;if(s==="error")throw new Error(l||"Agent error");l&&(yield l);}if(p)break}}finally{e.removeEventListener("abort",i);try{n.releaseLock();}catch{}}}var E=`http://localhost:${9567}`;async function*g(c,e,n){let o=Date.now(),r=e.sessionId,t=()=>{r&&fetch(`${c}/abort/${r}`,{method:"POST"}).catch(()=>{});};n.addEventListener("abort",t);try{let i=await fetch(`${c}/agent`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(e),signal:n});if(!i.ok)throw new Error(`Server error: ${i.status}`);if(!i.body)throw new Error("No response body");let a=f(i.body,n)[Symbol.asyncIterator](),p=!1,m=a.next();for(;!p;){let d=await Promise.race([m.then(s=>({type:"status",iteratorResult:s})),new Promise(s=>setTimeout(()=>s({type:"timeout"}),100))]);if(d.type==="timeout")yield `Working\u2026 ${((Date.now()-o)/1e3).toFixed(1)}s`;else {let s=d.iteratorResult;if(p=s.done??!1,!p&&s.value){let l=s.value;l==="Completed successfully"?yield `Completed in ${((Date.now()-o)/1e3).toFixed(1)}s`:yield l,m=a.next();}}}}finally{n.removeEventListener("abort",t);}}var b=(c={})=>{let{serverUrl:e=E,getOptions:n}=c,o=null,r=t=>({...n?.()??{},...t??{}});return {send:async function*(t,i){let a={...t,options:r(t.options)};yield*g(e,a,i);},resume:async function*(t,i,a){let p=a.getItem(u);if(!p)throw new Error("No sessions to resume");let d=JSON.parse(p)[t];if(!d)throw new Error(`Session ${t} not found`);let s=d.context,l={...s,options:r(s.options)};yield "Resuming...",yield*g(e,l,i);},supportsResume:true,supportsFollowUp:true,checkConnection:async()=>{let t=Date.now();if(o&&t-o.timestamp<A)return o.result;try{let a=(await fetch(`${e}/health`,{method:"GET"})).ok;return o={result:a,timestamp:t},a}catch{return o={result:false,timestamp:t},false}},abort:async t=>{try{await fetch(`${e}/abort/${t}`,{method:"POST"});}catch{}}}},h=async()=>{if(typeof window>"u")return;let c=b(),e=r=>{r.setAgent({provider:c,storage:sessionStorage});},n=window.__REACT_GRAB__;if(n){e(n);return}window.addEventListener("react-grab:init",r=>{e(r.detail);},{once:true});let o=window.__REACT_GRAB__;o&&e(o);};h();
|
|
5
|
+
exports.attachAgent=h;exports.createAmpAgentProvider=b;return exports;})({});
|
package/dist/client.js
CHANGED
|
@@ -1,9 +1,5 @@
|
|
|
1
|
-
//
|
|
2
|
-
var DEFAULT_PORT = 9567;
|
|
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
4
|
var parseSSEEvent = (eventBlock) => {
|
|
9
5
|
let eventType = "";
|
|
@@ -54,7 +50,14 @@ async function* streamSSE(stream, signal) {
|
|
|
54
50
|
}
|
|
55
51
|
}
|
|
56
52
|
}
|
|
53
|
+
|
|
54
|
+
// src/constants.ts
|
|
55
|
+
var DEFAULT_PORT = 9567;
|
|
56
|
+
|
|
57
|
+
// src/client.ts
|
|
58
|
+
var DEFAULT_SERVER_URL = `http://localhost:${DEFAULT_PORT}`;
|
|
57
59
|
async function* streamFromServer(serverUrl, context, signal) {
|
|
60
|
+
const startTime = Date.now();
|
|
58
61
|
const sessionId = context.sessionId;
|
|
59
62
|
const handleAbort = () => {
|
|
60
63
|
if (sessionId) {
|
|
@@ -78,7 +81,37 @@ async function* streamFromServer(serverUrl, context, signal) {
|
|
|
78
81
|
if (!response.body) {
|
|
79
82
|
throw new Error("No response body");
|
|
80
83
|
}
|
|
81
|
-
|
|
84
|
+
const iterator = streamSSE(response.body, signal)[Symbol.asyncIterator]();
|
|
85
|
+
let done = false;
|
|
86
|
+
let pendingNext = iterator.next();
|
|
87
|
+
while (!done) {
|
|
88
|
+
const result = await Promise.race([
|
|
89
|
+
pendingNext.then((iteratorResult) => ({
|
|
90
|
+
type: "status",
|
|
91
|
+
iteratorResult
|
|
92
|
+
})),
|
|
93
|
+
new Promise(
|
|
94
|
+
(resolve) => setTimeout(() => resolve({ type: "timeout" }), 100)
|
|
95
|
+
)
|
|
96
|
+
]);
|
|
97
|
+
if (result.type === "timeout") {
|
|
98
|
+
const elapsedSeconds = (Date.now() - startTime) / 1e3;
|
|
99
|
+
yield `Working\u2026 ${elapsedSeconds.toFixed(1)}s`;
|
|
100
|
+
} else {
|
|
101
|
+
const iteratorResult = result.iteratorResult;
|
|
102
|
+
done = iteratorResult.done ?? false;
|
|
103
|
+
if (!done && iteratorResult.value) {
|
|
104
|
+
const status = iteratorResult.value;
|
|
105
|
+
if (status === "Completed successfully") {
|
|
106
|
+
const totalSeconds = ((Date.now() - startTime) / 1e3).toFixed(1);
|
|
107
|
+
yield `Completed in ${totalSeconds}s`;
|
|
108
|
+
} else {
|
|
109
|
+
yield status;
|
|
110
|
+
}
|
|
111
|
+
pendingNext = iterator.next();
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
}
|
|
82
115
|
} finally {
|
|
83
116
|
signal.removeEventListener("abort", handleAbort);
|
|
84
117
|
}
|
package/dist/server.cjs
CHANGED
|
@@ -19,8 +19,10 @@ var pc__default = /*#__PURE__*/_interopDefault(pc);
|
|
|
19
19
|
|
|
20
20
|
// src/constants.ts
|
|
21
21
|
var DEFAULT_PORT = 9567;
|
|
22
|
-
|
|
22
|
+
|
|
23
|
+
// ../utils/dist/server.js
|
|
23
24
|
var sleep = (ms) => new Promise((resolve) => setTimeout(resolve, ms));
|
|
25
|
+
var VERSION = "0.0.84";
|
|
24
26
|
var threadMap = /* @__PURE__ */ new Map();
|
|
25
27
|
var abortControllers = /* @__PURE__ */ new Map();
|
|
26
28
|
var extractTextFromContent = (content) => {
|
|
@@ -70,13 +72,18 @@ ${content}`;
|
|
|
70
72
|
if (systemMessage.thread_id) {
|
|
71
73
|
capturedThreadId = systemMessage.thread_id;
|
|
72
74
|
}
|
|
73
|
-
await stream.writeSSE({
|
|
75
|
+
await stream.writeSSE({
|
|
76
|
+
data: "Session started...",
|
|
77
|
+
event: "status"
|
|
78
|
+
});
|
|
74
79
|
}
|
|
75
80
|
break;
|
|
76
81
|
case "assistant": {
|
|
77
82
|
const messageContent = message.message?.content;
|
|
78
83
|
if (messageContent && Array.isArray(messageContent)) {
|
|
79
|
-
const toolUse = messageContent.find(
|
|
84
|
+
const toolUse = messageContent.find(
|
|
85
|
+
(item) => item.type === "tool_use"
|
|
86
|
+
);
|
|
80
87
|
if (toolUse && "name" in toolUse) {
|
|
81
88
|
await stream.writeSSE({
|
|
82
89
|
data: `Using ${toolUse.name}...`,
|
|
@@ -85,7 +92,10 @@ ${content}`;
|
|
|
85
92
|
} else {
|
|
86
93
|
const textContent = extractTextFromContent(messageContent);
|
|
87
94
|
if (textContent && !isAborted()) {
|
|
88
|
-
await stream.writeSSE({
|
|
95
|
+
await stream.writeSSE({
|
|
96
|
+
data: textContent,
|
|
97
|
+
event: "status"
|
|
98
|
+
});
|
|
89
99
|
}
|
|
90
100
|
}
|
|
91
101
|
}
|
|
@@ -148,7 +158,9 @@ var startServer = async (port = DEFAULT_PORT) => {
|
|
|
148
158
|
await sleep(100);
|
|
149
159
|
const honoApplication = createServer();
|
|
150
160
|
nodeServer.serve({ fetch: honoApplication.fetch, port });
|
|
151
|
-
console.log(
|
|
161
|
+
console.log(
|
|
162
|
+
`${pc__default.default.magenta("\u269B")} ${pc__default.default.bold("React Grab")} ${pc__default.default.gray(VERSION)} ${pc__default.default.dim("(Amp)")}`
|
|
163
|
+
);
|
|
152
164
|
console.log(`- Local: ${pc__default.default.cyan(`http://localhost:${port}`)}`);
|
|
153
165
|
};
|
|
154
166
|
if ((typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('server.cjs', document.baseURI).href)) === url.pathToFileURL(process.argv[1]).href) {
|
package/dist/server.js
CHANGED
|
@@ -11,8 +11,10 @@ import { pathToFileURL } from 'url';
|
|
|
11
11
|
|
|
12
12
|
// src/constants.ts
|
|
13
13
|
var DEFAULT_PORT = 9567;
|
|
14
|
-
|
|
14
|
+
|
|
15
|
+
// ../utils/dist/server.js
|
|
15
16
|
var sleep = (ms) => new Promise((resolve) => setTimeout(resolve, ms));
|
|
17
|
+
var VERSION = "0.0.84";
|
|
16
18
|
var threadMap = /* @__PURE__ */ new Map();
|
|
17
19
|
var abortControllers = /* @__PURE__ */ new Map();
|
|
18
20
|
var extractTextFromContent = (content) => {
|
|
@@ -62,13 +64,18 @@ ${content}`;
|
|
|
62
64
|
if (systemMessage.thread_id) {
|
|
63
65
|
capturedThreadId = systemMessage.thread_id;
|
|
64
66
|
}
|
|
65
|
-
await stream.writeSSE({
|
|
67
|
+
await stream.writeSSE({
|
|
68
|
+
data: "Session started...",
|
|
69
|
+
event: "status"
|
|
70
|
+
});
|
|
66
71
|
}
|
|
67
72
|
break;
|
|
68
73
|
case "assistant": {
|
|
69
74
|
const messageContent = message.message?.content;
|
|
70
75
|
if (messageContent && Array.isArray(messageContent)) {
|
|
71
|
-
const toolUse = messageContent.find(
|
|
76
|
+
const toolUse = messageContent.find(
|
|
77
|
+
(item) => item.type === "tool_use"
|
|
78
|
+
);
|
|
72
79
|
if (toolUse && "name" in toolUse) {
|
|
73
80
|
await stream.writeSSE({
|
|
74
81
|
data: `Using ${toolUse.name}...`,
|
|
@@ -77,7 +84,10 @@ ${content}`;
|
|
|
77
84
|
} else {
|
|
78
85
|
const textContent = extractTextFromContent(messageContent);
|
|
79
86
|
if (textContent && !isAborted()) {
|
|
80
|
-
await stream.writeSSE({
|
|
87
|
+
await stream.writeSSE({
|
|
88
|
+
data: textContent,
|
|
89
|
+
event: "status"
|
|
90
|
+
});
|
|
81
91
|
}
|
|
82
92
|
}
|
|
83
93
|
}
|
|
@@ -140,7 +150,9 @@ var startServer = async (port = DEFAULT_PORT) => {
|
|
|
140
150
|
await sleep(100);
|
|
141
151
|
const honoApplication = createServer();
|
|
142
152
|
serve({ fetch: honoApplication.fetch, port });
|
|
143
|
-
console.log(
|
|
153
|
+
console.log(
|
|
154
|
+
`${pc.magenta("\u269B")} ${pc.bold("React Grab")} ${pc.gray(VERSION)} ${pc.dim("(Amp)")}`
|
|
155
|
+
);
|
|
144
156
|
console.log(`- Local: ${pc.cyan(`http://localhost:${port}`)}`);
|
|
145
157
|
};
|
|
146
158
|
if (import.meta.url === pathToFileURL(process.argv[1]).href) {
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@react-grab/amp",
|
|
3
|
-
"version": "0.0.
|
|
3
|
+
"version": "0.0.84",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"bin": {
|
|
6
6
|
"react-grab-amp": "./dist/cli.cjs"
|
|
@@ -24,17 +24,17 @@
|
|
|
24
24
|
"dist"
|
|
25
25
|
],
|
|
26
26
|
"devDependencies": {
|
|
27
|
-
"
|
|
28
|
-
"
|
|
27
|
+
"tsup": "^8.4.0",
|
|
28
|
+
"@react-grab/utils": "0.0.84"
|
|
29
29
|
},
|
|
30
30
|
"dependencies": {
|
|
31
31
|
"@hono/node-server": "^1.19.6",
|
|
32
|
-
"
|
|
32
|
+
"execa": "^9.6.0",
|
|
33
33
|
"@sourcegraph/amp-sdk": "0.1.0-20251210081226-g90e3892",
|
|
34
34
|
"fkill": "^9.0.0",
|
|
35
35
|
"hono": "^4.0.0",
|
|
36
36
|
"picocolors": "^1.1.1",
|
|
37
|
-
"react-grab": "0.0.
|
|
37
|
+
"react-grab": "0.0.84"
|
|
38
38
|
},
|
|
39
39
|
"scripts": {
|
|
40
40
|
"dev": "tsup --watch",
|