@docyrus/docyrus 0.0.34 → 0.0.35

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (66) hide show
  1. package/README.md +25 -0
  2. package/agent-loader.js +3 -2
  3. package/agent-loader.js.map +2 -2
  4. package/main.js +82162 -46093
  5. package/main.js.map +4 -4
  6. package/package.json +12 -3
  7. package/resources/chrome-tools/browser-content.js +46 -46
  8. package/resources/chrome-tools/browser-cookies.js +16 -16
  9. package/resources/chrome-tools/browser-eval.js +27 -27
  10. package/resources/chrome-tools/browser-hn-scraper.js +1 -1
  11. package/resources/chrome-tools/browser-nav.js +23 -23
  12. package/resources/chrome-tools/browser-pick.js +127 -127
  13. package/resources/chrome-tools/browser-screenshot.js +10 -10
  14. package/resources/chrome-tools/browser-start.js +38 -38
  15. package/resources/pi-agent/extensions/answer.ts +392 -384
  16. package/resources/pi-agent/extensions/context.ts +415 -415
  17. package/resources/pi-agent/extensions/control.ts +1287 -1287
  18. package/resources/pi-agent/extensions/diff.ts +171 -171
  19. package/resources/pi-agent/extensions/files.ts +155 -155
  20. package/resources/pi-agent/extensions/knowledge.ts +664 -0
  21. package/resources/pi-agent/extensions/loop.ts +375 -375
  22. package/resources/pi-agent/extensions/pi-bash-live-view/index.ts +1 -1
  23. package/resources/pi-agent/extensions/pi-bash-live-view/package.json +22 -22
  24. package/resources/pi-agent/extensions/pi-bash-live-view/pty-execute.ts +2 -2
  25. package/resources/pi-agent/extensions/pi-bash-live-view/pty-session.ts +2 -2
  26. package/resources/pi-agent/extensions/pi-bash-live-view/spawn-helper.ts +2 -2
  27. package/resources/pi-agent/extensions/pi-bash-live-view/terminal-emulator.ts +18 -18
  28. package/resources/pi-agent/extensions/pi-bash-live-view/truncate.ts +1 -1
  29. package/resources/pi-agent/extensions/pi-bash-live-view/widget.ts +4 -4
  30. package/resources/pi-agent/extensions/pi-custom-compaction/package.json +4 -4
  31. package/resources/pi-agent/extensions/pi-mcp-adapter/app-bridge.bundle.js +14 -14
  32. package/resources/pi-agent/extensions/pi-mcp-adapter/commands.ts +6 -6
  33. package/resources/pi-agent/extensions/pi-mcp-adapter/config.ts +9 -9
  34. package/resources/pi-agent/extensions/pi-mcp-adapter/consent-manager.ts +4 -4
  35. package/resources/pi-agent/extensions/pi-mcp-adapter/direct-tools.ts +13 -13
  36. package/resources/pi-agent/extensions/pi-mcp-adapter/glimpse-ui.ts +5 -5
  37. package/resources/pi-agent/extensions/pi-mcp-adapter/host-html-template.ts +13 -13
  38. package/resources/pi-agent/extensions/pi-mcp-adapter/index.ts +14 -14
  39. package/resources/pi-agent/extensions/pi-mcp-adapter/init.ts +17 -17
  40. package/resources/pi-agent/extensions/pi-mcp-adapter/lifecycle.ts +2 -2
  41. package/resources/pi-agent/extensions/pi-mcp-adapter/logger.ts +2 -2
  42. package/resources/pi-agent/extensions/pi-mcp-adapter/mcp-panel.ts +17 -17
  43. package/resources/pi-agent/extensions/pi-mcp-adapter/metadata-cache.ts +9 -9
  44. package/resources/pi-agent/extensions/pi-mcp-adapter/npx-resolver.ts +35 -35
  45. package/resources/pi-agent/extensions/pi-mcp-adapter/oauth-handler.ts +1 -1
  46. package/resources/pi-agent/extensions/pi-mcp-adapter/proxy-modes.ts +12 -12
  47. package/resources/pi-agent/extensions/pi-mcp-adapter/server-manager.ts +6 -6
  48. package/resources/pi-agent/extensions/pi-mcp-adapter/tool-metadata.ts +4 -4
  49. package/resources/pi-agent/extensions/pi-mcp-adapter/types.ts +2 -2
  50. package/resources/pi-agent/extensions/pi-mcp-adapter/ui-resource-handler.ts +6 -6
  51. package/resources/pi-agent/extensions/pi-mcp-adapter/ui-server.ts +17 -17
  52. package/resources/pi-agent/extensions/pi-mcp-adapter/ui-session.ts +22 -22
  53. package/resources/pi-agent/extensions/pi-mcp-adapter/utils.ts +2 -2
  54. package/resources/pi-agent/extensions/prompt-editor.ts +900 -900
  55. package/resources/pi-agent/extensions/prompt-url-widget.ts +122 -122
  56. package/resources/pi-agent/extensions/redraws.ts +14 -14
  57. package/resources/pi-agent/extensions/review.ts +1533 -1533
  58. package/resources/pi-agent/extensions/todos.ts +1735 -1735
  59. package/resources/pi-agent/extensions/tps.ts +40 -40
  60. package/resources/pi-agent/extensions/whimsical.ts +3 -3
  61. package/resources/pi-agent/prompts/agent-system.md +2 -0
  62. package/resources/pi-agent/prompts/coder-system.md +2 -0
  63. package/server-loader.js +82 -1
  64. package/server-loader.js.map +3 -3
  65. package/tui.mjs +2 -0
  66. package/tui.mjs.map +1 -1
@@ -4,159 +4,159 @@ import puppeteer from "puppeteer-core";
4
4
 
5
5
  const message = process.argv.slice(2).join(" ");
6
6
  if (!message) {
7
- console.log("Usage: browser-pick.js 'message'");
8
- console.log("\nExample:");
9
- console.log(' browser-pick.js "Click the submit button"');
10
- process.exit(1);
7
+ console.log("Usage: browser-pick.js 'message'");
8
+ console.log("\nExample:");
9
+ console.log(' browser-pick.js "Click the submit button"');
10
+ process.exit(1);
11
11
  }
12
12
 
13
13
  const b = await Promise.race([
14
- puppeteer.connect({
15
- browserURL: "http://localhost:9222",
16
- defaultViewport: null,
17
- }),
18
- new Promise((_, reject) => setTimeout(() => reject(new Error("timeout")), 5000)),
14
+ puppeteer.connect({
15
+ browserURL: "http://localhost:9222",
16
+ defaultViewport: null,
17
+ }),
18
+ new Promise((_, reject) => setTimeout(() => reject(new Error("timeout")), 5000)),
19
19
  ]).catch((e) => {
20
- console.error("✗ Could not connect to browser:", e.message);
21
- console.error(" Run: browser-start.js");
22
- process.exit(1);
20
+ console.error("✗ Could not connect to browser:", e.message);
21
+ console.error(" Run: browser-start.js");
22
+ process.exit(1);
23
23
  });
24
24
 
25
25
  const p = (await b.pages()).at(-1);
26
26
 
27
27
  if (!p) {
28
- console.error("✗ No active tab found");
29
- process.exit(1);
28
+ console.error("✗ No active tab found");
29
+ process.exit(1);
30
30
  }
31
31
 
32
32
  // Inject pick() helper into current page
33
33
  await p.evaluate(() => {
34
- if (!window.pick) {
35
- window.pick = async (message) => {
36
- if (!message) {
37
- throw new Error("pick() requires a message parameter");
38
- }
39
- return new Promise((resolve) => {
40
- const selections = [];
41
- const selectedElements = new Set();
42
-
43
- const overlay = document.createElement("div");
44
- overlay.style.cssText =
34
+ if (!window.pick) {
35
+ window.pick = async(message) => {
36
+ if (!message) {
37
+ throw new Error("pick() requires a message parameter");
38
+ }
39
+ return new Promise((resolve) => {
40
+ const selections = [];
41
+ const selectedElements = new Set();
42
+
43
+ const overlay = document.createElement("div");
44
+ overlay.style.cssText =
45
45
  "position:fixed;top:0;left:0;width:100%;height:100%;z-index:2147483647;pointer-events:none";
46
46
 
47
- const highlight = document.createElement("div");
48
- highlight.style.cssText =
47
+ const highlight = document.createElement("div");
48
+ highlight.style.cssText =
49
49
  "position:absolute;border:2px solid #3b82f6;background:rgba(59,130,246,0.1);transition:all 0.1s";
50
- overlay.appendChild(highlight);
50
+ overlay.appendChild(highlight);
51
51
 
52
- const banner = document.createElement("div");
53
- banner.style.cssText =
52
+ const banner = document.createElement("div");
53
+ banner.style.cssText =
54
54
  "position:fixed;bottom:20px;left:50%;transform:translateX(-50%);background:#1f2937;color:white;padding:12px 24px;border-radius:8px;font:14px sans-serif;box-shadow:0 4px 12px rgba(0,0,0,0.3);pointer-events:auto;z-index:2147483647";
55
55
 
56
- const updateBanner = () => {
57
- banner.textContent = `${message} (${selections.length} selected, Cmd/Ctrl+click to add, Enter to finish, ESC to cancel)`;
58
- };
59
- updateBanner();
60
-
61
- document.body.append(banner, overlay);
62
-
63
- const cleanup = () => {
64
- document.removeEventListener("mousemove", onMove, true);
65
- document.removeEventListener("click", onClick, true);
66
- document.removeEventListener("keydown", onKey, true);
67
- overlay.remove();
68
- banner.remove();
69
- selectedElements.forEach((el) => {
70
- el.style.outline = "";
71
- });
72
- };
73
-
74
- const onMove = (e) => {
75
- const el = document.elementFromPoint(e.clientX, e.clientY);
76
- if (!el || overlay.contains(el) || banner.contains(el)) return;
77
- const r = el.getBoundingClientRect();
78
- highlight.style.cssText = `position:absolute;border:2px solid #3b82f6;background:rgba(59,130,246,0.1);top:${r.top}px;left:${r.left}px;width:${r.width}px;height:${r.height}px`;
79
- };
80
-
81
- const buildElementInfo = (el) => {
82
- const parents = [];
83
- let current = el.parentElement;
84
- while (current && current !== document.body) {
85
- const parentInfo = current.tagName.toLowerCase();
86
- const id = current.id ? `#${current.id}` : "";
87
- const cls = current.className
88
- ? `.${current.className.trim().split(/\s+/).join(".")}`
89
- : "";
90
- parents.push(parentInfo + id + cls);
91
- current = current.parentElement;
92
- }
93
-
94
- return {
95
- tag: el.tagName.toLowerCase(),
96
- id: el.id || null,
97
- class: el.className || null,
98
- text: el.textContent?.trim().slice(0, 200) || null,
99
- html: el.outerHTML.slice(0, 500),
100
- parents: parents.join(" > "),
101
- };
102
- };
103
-
104
- const onClick = (e) => {
105
- if (banner.contains(e.target)) return;
106
- e.preventDefault();
107
- e.stopPropagation();
108
- const el = document.elementFromPoint(e.clientX, e.clientY);
109
- if (!el || overlay.contains(el) || banner.contains(el)) return;
110
-
111
- if (e.metaKey || e.ctrlKey) {
112
- if (!selectedElements.has(el)) {
113
- selectedElements.add(el);
114
- el.style.outline = "3px solid #10b981";
115
- selections.push(buildElementInfo(el));
116
- updateBanner();
117
- }
118
- } else {
119
- cleanup();
120
- const info = buildElementInfo(el);
121
- resolve(selections.length > 0 ? selections : info);
122
- }
123
- };
124
-
125
- const onKey = (e) => {
126
- if (e.key === "Escape") {
127
- e.preventDefault();
128
- cleanup();
129
- resolve(null);
130
- } else if (e.key === "Enter" && selections.length > 0) {
131
- e.preventDefault();
132
- cleanup();
133
- resolve(selections);
134
- }
135
- };
136
-
137
- document.addEventListener("mousemove", onMove, true);
138
- document.addEventListener("click", onClick, true);
139
- document.addEventListener("keydown", onKey, true);
140
- });
141
- };
142
- }
56
+ const updateBanner = () => {
57
+ banner.textContent = `${message} (${selections.length} selected, Cmd/Ctrl+click to add, Enter to finish, ESC to cancel)`;
58
+ };
59
+ updateBanner();
60
+
61
+ document.body.append(banner, overlay);
62
+
63
+ const cleanup = () => {
64
+ document.removeEventListener("mousemove", onMove, true);
65
+ document.removeEventListener("click", onClick, true);
66
+ document.removeEventListener("keydown", onKey, true);
67
+ overlay.remove();
68
+ banner.remove();
69
+ selectedElements.forEach((el) => {
70
+ el.style.outline = "";
71
+ });
72
+ };
73
+
74
+ const onMove = (e) => {
75
+ const el = document.elementFromPoint(e.clientX, e.clientY);
76
+ if (!el || overlay.contains(el) || banner.contains(el)) {return;}
77
+ const r = el.getBoundingClientRect();
78
+ highlight.style.cssText = `position:absolute;border:2px solid #3b82f6;background:rgba(59,130,246,0.1);top:${r.top}px;left:${r.left}px;width:${r.width}px;height:${r.height}px`;
79
+ };
80
+
81
+ const buildElementInfo = (el) => {
82
+ const parents = [];
83
+ let current = el.parentElement;
84
+ while (current && current !== document.body) {
85
+ const parentInfo = current.tagName.toLowerCase();
86
+ const id = current.id ? `#${current.id}` : "";
87
+ const cls = current.className
88
+ ? `.${current.className.trim().split(/\s+/).join(".")}`
89
+ : "";
90
+ parents.push(parentInfo + id + cls);
91
+ current = current.parentElement;
92
+ }
93
+
94
+ return {
95
+ tag: el.tagName.toLowerCase(),
96
+ id: el.id || null,
97
+ class: el.className || null,
98
+ text: el.textContent?.trim().slice(0, 200) || null,
99
+ html: el.outerHTML.slice(0, 500),
100
+ parents: parents.join(" > "),
101
+ };
102
+ };
103
+
104
+ const onClick = (e) => {
105
+ if (banner.contains(e.target)) {return;}
106
+ e.preventDefault();
107
+ e.stopPropagation();
108
+ const el = document.elementFromPoint(e.clientX, e.clientY);
109
+ if (!el || overlay.contains(el) || banner.contains(el)) {return;}
110
+
111
+ if (e.metaKey || e.ctrlKey) {
112
+ if (!selectedElements.has(el)) {
113
+ selectedElements.add(el);
114
+ el.style.outline = "3px solid #10b981";
115
+ selections.push(buildElementInfo(el));
116
+ updateBanner();
117
+ }
118
+ } else {
119
+ cleanup();
120
+ const info = buildElementInfo(el);
121
+ resolve(selections.length > 0 ? selections : info);
122
+ }
123
+ };
124
+
125
+ const onKey = (e) => {
126
+ if (e.key === "Escape") {
127
+ e.preventDefault();
128
+ cleanup();
129
+ resolve(null);
130
+ } else if (e.key === "Enter" && selections.length > 0) {
131
+ e.preventDefault();
132
+ cleanup();
133
+ resolve(selections);
134
+ }
135
+ };
136
+
137
+ document.addEventListener("mousemove", onMove, true);
138
+ document.addEventListener("click", onClick, true);
139
+ document.addEventListener("keydown", onKey, true);
140
+ });
141
+ };
142
+ }
143
143
  });
144
144
 
145
145
  const result = await p.evaluate((msg) => window.pick(msg), message);
146
146
 
147
147
  if (Array.isArray(result)) {
148
- for (let i = 0; i < result.length; i++) {
149
- if (i > 0) console.log("");
150
- for (const [key, value] of Object.entries(result[i])) {
151
- console.log(`${key}: ${value}`);
152
- }
153
- }
148
+ for (let i = 0; i < result.length; i++) {
149
+ if (i > 0) {console.log("");}
150
+ for (const [key, value] of Object.entries(result[i])) {
151
+ console.log(`${key}: ${value}`);
152
+ }
153
+ }
154
154
  } else if (typeof result === "object" && result !== null) {
155
- for (const [key, value] of Object.entries(result)) {
156
- console.log(`${key}: ${value}`);
157
- }
155
+ for (const [key, value] of Object.entries(result)) {
156
+ console.log(`${key}: ${value}`);
157
+ }
158
158
  } else {
159
- console.log(result);
159
+ console.log(result);
160
160
  }
161
161
 
162
162
  await b.disconnect();
@@ -5,22 +5,22 @@ import { join } from "node:path";
5
5
  import puppeteer from "puppeteer-core";
6
6
 
7
7
  const b = await Promise.race([
8
- puppeteer.connect({
9
- browserURL: "http://localhost:9222",
10
- defaultViewport: null,
11
- }),
12
- new Promise((_, reject) => setTimeout(() => reject(new Error("timeout")), 5000)),
8
+ puppeteer.connect({
9
+ browserURL: "http://localhost:9222",
10
+ defaultViewport: null,
11
+ }),
12
+ new Promise((_, reject) => setTimeout(() => reject(new Error("timeout")), 5000)),
13
13
  ]).catch((e) => {
14
- console.error("✗ Could not connect to browser:", e.message);
15
- console.error(" Run: browser-start.js");
16
- process.exit(1);
14
+ console.error("✗ Could not connect to browser:", e.message);
15
+ console.error(" Run: browser-start.js");
16
+ process.exit(1);
17
17
  });
18
18
 
19
19
  const p = (await b.pages()).at(-1);
20
20
 
21
21
  if (!p) {
22
- console.error("✗ No active tab found");
23
- process.exit(1);
22
+ console.error("✗ No active tab found");
23
+ process.exit(1);
24
24
  }
25
25
 
26
26
  const timestamp = new Date().toISOString().replace(/[:.]/g, "-");
@@ -6,23 +6,23 @@ import puppeteer from "puppeteer-core";
6
6
  const useProfile = process.argv[2] === "--profile";
7
7
 
8
8
  if (process.argv[2] && process.argv[2] !== "--profile") {
9
- console.log("Usage: browser-start.js [--profile]");
10
- console.log("\nOptions:");
11
- console.log(" --profile Copy your default Chrome profile (cookies, logins)");
12
- process.exit(1);
9
+ console.log("Usage: browser-start.js [--profile]");
10
+ console.log("\nOptions:");
11
+ console.log(" --profile Copy your default Chrome profile (cookies, logins)");
12
+ process.exit(1);
13
13
  }
14
14
 
15
15
  const SCRAPING_DIR = `${process.env.HOME}/.cache/browser-tools`;
16
16
 
17
17
  // Check if already running on :9222
18
18
  try {
19
- const browser = await puppeteer.connect({
20
- browserURL: "http://localhost:9222",
21
- defaultViewport: null,
22
- });
23
- await browser.disconnect();
24
- console.log("✓ Chrome already running on :9222");
25
- process.exit(0);
19
+ const browser = await puppeteer.connect({
20
+ browserURL: "http://localhost:9222",
21
+ defaultViewport: null,
22
+ });
23
+ await browser.disconnect();
24
+ console.log("✓ Chrome already running on :9222");
25
+ process.exit(0);
26
26
  } catch {}
27
27
 
28
28
  // Setup profile directory
@@ -30,13 +30,13 @@ execSync(`mkdir -p "${SCRAPING_DIR}"`, { stdio: "ignore" });
30
30
 
31
31
  // Remove SingletonLock to allow new instance
32
32
  try {
33
- execSync(`rm -f "${SCRAPING_DIR}/SingletonLock" "${SCRAPING_DIR}/SingletonSocket" "${SCRAPING_DIR}/SingletonCookie"`, { stdio: "ignore" });
33
+ execSync(`rm -f "${SCRAPING_DIR}/SingletonLock" "${SCRAPING_DIR}/SingletonSocket" "${SCRAPING_DIR}/SingletonCookie"`, { stdio: "ignore" });
34
34
  } catch {}
35
35
 
36
36
  if (useProfile) {
37
- console.log("Syncing profile...");
38
- execSync(
39
- `rsync -a --delete \
37
+ console.log("Syncing profile...");
38
+ execSync(
39
+ `rsync -a --delete \
40
40
  --exclude='SingletonLock' \
41
41
  --exclude='SingletonSocket' \
42
42
  --exclude='SingletonCookie' \
@@ -46,41 +46,41 @@ if (useProfile) {
46
46
  --exclude='*/Last Session' \
47
47
  --exclude='*/Last Tabs' \
48
48
  "${process.env.HOME}/Library/Application Support/Google/Chrome/" "${SCRAPING_DIR}/"`,
49
- { stdio: "pipe" },
50
- );
49
+ { stdio: "pipe" },
50
+ );
51
51
  }
52
52
 
53
53
  // Start Chrome with flags to force new instance
54
54
  spawn(
55
- "/Applications/Google Chrome.app/Contents/MacOS/Google Chrome",
56
- [
57
- "--remote-debugging-port=9222",
58
- `--user-data-dir=${SCRAPING_DIR}`,
59
- "--no-first-run",
60
- "--no-default-browser-check",
61
- ],
62
- { detached: true, stdio: "ignore" },
55
+ "/Applications/Google Chrome.app/Contents/MacOS/Google Chrome",
56
+ [
57
+ "--remote-debugging-port=9222",
58
+ `--user-data-dir=${SCRAPING_DIR}`,
59
+ "--no-first-run",
60
+ "--no-default-browser-check",
61
+ ],
62
+ { detached: true, stdio: "ignore" },
63
63
  ).unref();
64
64
 
65
65
  // Wait for Chrome to be ready
66
66
  let connected = false;
67
67
  for (let i = 0; i < 30; i++) {
68
- try {
69
- const browser = await puppeteer.connect({
70
- browserURL: "http://localhost:9222",
71
- defaultViewport: null,
72
- });
73
- await browser.disconnect();
74
- connected = true;
75
- break;
76
- } catch {
77
- await new Promise((r) => setTimeout(r, 500));
78
- }
68
+ try {
69
+ const browser = await puppeteer.connect({
70
+ browserURL: "http://localhost:9222",
71
+ defaultViewport: null,
72
+ });
73
+ await browser.disconnect();
74
+ connected = true;
75
+ break;
76
+ } catch {
77
+ await new Promise((r) => setTimeout(r, 500));
78
+ }
79
79
  }
80
80
 
81
81
  if (!connected) {
82
- console.error("✗ Failed to connect to Chrome");
83
- process.exit(1);
82
+ console.error("✗ Failed to connect to Chrome");
83
+ process.exit(1);
84
84
  }
85
85
 
86
86
  console.log(`✓ Chrome started on :9222${useProfile ? " with your profile" : ""}`);