@react-grab/cursor 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 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 = 5567;
606
604
 
607
605
  // src/cli.ts
608
- var VERSION = "0.0.81";
609
- var __filename$1 = url.fileURLToPath((typeof document === 'undefined' ? require('u' + 'rl').pathToFileURL(__filename).href : (_documentCurrentScript && _documentCurrentScript.tagName.toUpperCase() === 'SCRIPT' && _documentCurrentScript.src || new URL('cli.cjs', document.baseURI).href)));
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 { fileURLToPath } from 'url';
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 = 5567;
603
602
 
604
603
  // src/cli.ts
605
- var VERSION = "0.0.81";
606
- var __filename = fileURLToPath(import.meta.url);
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,11 +1,7 @@
1
1
  'use strict';
2
2
 
3
- // src/constants.ts
4
- var DEFAULT_PORT = 5567;
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 = 5567;
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
- yield* streamSSE(response.body, signal);
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
  }
@@ -1,4 +1,5 @@
1
- var ReactGrabCursor=(function(exports){'use strict';var m=`http://localhost:${5567}`,E="react-grab:agent-sessions",b=s=>{let e="",n="";for(let r of s.split(`
2
- `))r.startsWith("event:")?e=r.slice(6).trim():r.startsWith("data:")&&(n=r.slice(5).trim());return {eventType:e,data:n}};async function*C(s,e){let n=s.getReader(),r=new TextDecoder,o="",t=false,a=()=>{t=true,n.cancel().catch(()=>{});};e.addEventListener("abort",a);try{if(e.aborted)throw new DOMException("Aborted","AbortError");for(;;){let i=await n.read();if(t||e.aborted)throw new DOMException("Aborted","AbortError");let{done:l,value:u}=i;u&&(o+=r.decode(u,{stream:!0}));let c;for(;(c=o.indexOf(`
1
+ var ReactGrabCursor=(function(exports){'use strict';var f=5e3,m="react-grab:agent-sessions",y=c=>{let t="",r="";for(let o of c.split(`
2
+ `))o.startsWith("event:")?t=o.slice(6).trim():o.startsWith("data:")&&(r=o.slice(5).trim());return {eventType:t,data:r}};async function*g(c,t){let r=c.getReader(),o=new TextDecoder,n="",e=false,i=()=>{e=true,r.cancel().catch(()=>{});};t.addEventListener("abort",i);try{if(t.aborted)throw new DOMException("Aborted","AbortError");for(;;){let a=await r.read();if(e||t.aborted)throw new DOMException("Aborted","AbortError");let{done:l,value:p}=a;p&&(n+=o.decode(p,{stream:!0}));let d;for(;(d=n.indexOf(`
3
3
 
4
- `))!==-1;){let{eventType:d,data:p}=b(o.slice(0,c));if(o=o.slice(c+2),d==="done")return;if(d==="error")throw new Error(p||"Agent error");p&&(yield p);}if(l)break}}finally{e.removeEventListener("abort",a);try{n.releaseLock();}catch{}}}async function*g(s,e,n){let r=e.sessionId,o=()=>{r&&fetch(`${s}/abort/${r}`,{method:"POST"}).catch(()=>{});};n.addEventListener("abort",o);try{let t=await fetch(`${s}/agent`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(e),signal:n});if(!t.ok)throw new Error(`Server error: ${t.status}`);if(!t.body)throw new Error("No response body");yield*C(t.body,n);}finally{n.removeEventListener("abort",o);}}var y=(s={})=>{let{serverUrl:e=m,getOptions:n}=s,r=null,o=t=>({...n?.()??{},...t??{}});return {send:async function*(t,a){let i={...t,options:o(t.options)};yield*g(e,i,a);},resume:async function*(t,a,i){let l=i.getItem(E);if(!l)throw new Error("No sessions to resume");let c=JSON.parse(l)[t];if(!c)throw new Error(`Session ${t} not found`);let d=c.context,p={...d,options:o(d.options)};yield "Resuming...",yield*g(e,p,a);},supportsResume:true,supportsFollowUp:true,checkConnection:async()=>{let t=Date.now();if(r&&t-r.timestamp<5e3)return r.result;try{let i=(await fetch(`${e}/health`,{method:"GET"})).ok;return r={result:i,timestamp:t},i}catch{return r={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 s=y(),e=o=>{o.setAgent({provider:s,storage:sessionStorage});},n=window.__REACT_GRAB__;if(n){e(n);return}window.addEventListener("react-grab:init",o=>{e(o.detail);},{once:true});let r=window.__REACT_GRAB__;r&&e(r);};h();exports.attachAgent=h;exports.createCursorAgentProvider=y;return exports;})({});
4
+ `))!==-1;){let{eventType:s,data:u}=y(n.slice(0,d));if(n=n.slice(d+2),s==="done")return;if(s==="error")throw new Error(u||"Agent error");u&&(yield u);}if(l)break}}finally{t.removeEventListener("abort",i);try{r.releaseLock();}catch{}}}var C=`http://localhost:${5567}`;async function*A(c,t,r){let o=Date.now(),n=t.sessionId,e=()=>{n&&fetch(`${c}/abort/${n}`,{method:"POST"}).catch(()=>{});};r.addEventListener("abort",e);try{let i=await fetch(`${c}/agent`,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(t),signal:r});if(!i.ok)throw new Error(`Server error: ${i.status}`);if(!i.body)throw new Error("No response body");let a=g(i.body,r)[Symbol.asyncIterator](),l=!1,p=a.next();for(;!l;){let d=await Promise.race([p.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(l=s.done??!1,!l&&s.value){let u=s.value;u==="Completed successfully"?yield `Completed in ${((Date.now()-o)/1e3).toFixed(1)}s`:yield u,p=a.next();}}}}finally{r.removeEventListener("abort",e);}}var E=(c={})=>{let{serverUrl:t=C,getOptions:r}=c,o=null,n=e=>({...r?.()??{},...e??{}});return {send:async function*(e,i){let a={...e,options:n(e.options)};yield*A(t,a,i);},resume:async function*(e,i,a){let l=a.getItem(m);if(!l)throw new Error("No sessions to resume");let d=JSON.parse(l)[e];if(!d)throw new Error(`Session ${e} not found`);let s=d.context,u={...s,options:n(s.options)};yield "Resuming...",yield*A(t,u,i);},supportsResume:true,supportsFollowUp:true,checkConnection:async()=>{let e=Date.now();if(o&&e-o.timestamp<f)return o.result;try{let a=(await fetch(`${t}/health`,{method:"GET"})).ok;return o={result:a,timestamp:e},a}catch{return o={result:false,timestamp:e},false}},abort:async e=>{try{await fetch(`${t}/abort/${e}`,{method:"POST"});}catch{}}}},b=async()=>{if(typeof window>"u")return;let c=E(),t=n=>{n.setAgent({provider:c,storage:sessionStorage});},r=window.__REACT_GRAB__;if(r){t(r);return}window.addEventListener("react-grab:init",n=>{t(n.detail);},{once:true});let o=window.__REACT_GRAB__;o&&t(o);};b();
5
+ exports.attachAgent=b;exports.createCursorAgentProvider=E;return exports;})({});
package/dist/client.js CHANGED
@@ -1,9 +1,5 @@
1
- // src/constants.ts
2
- var DEFAULT_PORT = 5567;
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 = 5567;
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
- yield* streamSSE(response.body, signal);
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
@@ -5830,8 +5830,11 @@ var import_picocolors = __toESM(require_picocolors());
5830
5830
  // src/constants.ts
5831
5831
  var DEFAULT_PORT = 5567;
5832
5832
 
5833
+ // ../utils/dist/server.js
5834
+ var sleep = (ms) => new Promise((resolve) => setTimeout(resolve, ms));
5835
+
5833
5836
  // src/server.ts
5834
- var VERSION = "0.0.81";
5837
+ var VERSION = "0.0.83";
5835
5838
  var cursorSessionMap = /* @__PURE__ */ new Map();
5836
5839
  var activeProcesses = /* @__PURE__ */ new Map();
5837
5840
  var parseStreamLine = (line) => {
@@ -6002,6 +6005,7 @@ ${stderrContent}` : errorMessage;
6002
6005
  var startServer = async (port = DEFAULT_PORT) => {
6003
6006
  await fkill(`:${port}`, { force: true, silent: true }).catch(() => {
6004
6007
  });
6008
+ await sleep(100);
6005
6009
  const app = createServer();
6006
6010
  serve({ fetch: app.fetch, port });
6007
6011
  console.log(`${import_picocolors.default.magenta("\u269B")} ${import_picocolors.default.bold("React Grab")} ${import_picocolors.default.gray(VERSION)} ${import_picocolors.default.dim("(Cursor)")}`);
package/dist/server.js CHANGED
@@ -5819,8 +5819,11 @@ var import_picocolors = __toESM(require_picocolors());
5819
5819
  // src/constants.ts
5820
5820
  var DEFAULT_PORT = 5567;
5821
5821
 
5822
+ // ../utils/dist/server.js
5823
+ var sleep = (ms) => new Promise((resolve) => setTimeout(resolve, ms));
5824
+
5822
5825
  // src/server.ts
5823
- var VERSION = "0.0.81";
5826
+ var VERSION = "0.0.83";
5824
5827
  var cursorSessionMap = /* @__PURE__ */ new Map();
5825
5828
  var activeProcesses = /* @__PURE__ */ new Map();
5826
5829
  var parseStreamLine = (line) => {
@@ -5991,6 +5994,7 @@ ${stderrContent}` : errorMessage;
5991
5994
  var startServer = async (port = DEFAULT_PORT) => {
5992
5995
  await fkill(`:${port}`, { force: true, silent: true }).catch(() => {
5993
5996
  });
5997
+ await sleep(100);
5994
5998
  const app = createServer();
5995
5999
  serve({ fetch: app.fetch, port });
5996
6000
  console.log(`${import_picocolors.default.magenta("\u269B")} ${import_picocolors.default.bold("React Grab")} ${import_picocolors.default.gray(VERSION)} ${import_picocolors.default.dim("(Cursor)")}`);
package/package.json CHANGED
@@ -1,9 +1,9 @@
1
1
  {
2
2
  "name": "@react-grab/cursor",
3
- "version": "0.0.81",
3
+ "version": "0.0.83",
4
4
  "type": "module",
5
5
  "bin": {
6
- "react-grab-cursor": "./dist/cli.js"
6
+ "react-grab-cursor": "./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
  "@hono/node-server": "^1.19.6",
@@ -33,7 +34,7 @@
33
34
  "fkill": "^9.0.0",
34
35
  "hono": "^4.0.0",
35
36
  "picocolors": "^1.1.1",
36
- "react-grab": "0.0.81"
37
+ "react-grab": "0.0.83"
37
38
  },
38
39
  "scripts": {
39
40
  "dev": "tsup --watch",