@dyyz1993/agent-browser 0.9.2

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 (187) hide show
  1. package/LICENSE +202 -0
  2. package/README.md +907 -0
  3. package/bin/agent-browser-darwin-arm64 +0 -0
  4. package/bin/agent-browser.js +120 -0
  5. package/dist/__tests__/e2e/utils/test-helpers.d.ts +5 -0
  6. package/dist/__tests__/e2e/utils/test-helpers.d.ts.map +1 -0
  7. package/dist/__tests__/e2e/utils/test-helpers.js +22 -0
  8. package/dist/__tests__/e2e/utils/test-helpers.js.map +1 -0
  9. package/dist/__tests__/test-iframe.d.ts +2 -0
  10. package/dist/__tests__/test-iframe.d.ts.map +1 -0
  11. package/dist/__tests__/test-iframe.js +52 -0
  12. package/dist/__tests__/test-iframe.js.map +1 -0
  13. package/dist/__tests__/utils/parseCli.d.ts +20 -0
  14. package/dist/__tests__/utils/parseCli.d.ts.map +1 -0
  15. package/dist/__tests__/utils/parseCli.js +1086 -0
  16. package/dist/__tests__/utils/parseCli.js.map +1 -0
  17. package/dist/actions.d.ts +50 -0
  18. package/dist/actions.d.ts.map +1 -0
  19. package/dist/actions.js +2164 -0
  20. package/dist/actions.js.map +1 -0
  21. package/dist/browser.d.ts +556 -0
  22. package/dist/browser.d.ts.map +1 -0
  23. package/dist/browser.js +2599 -0
  24. package/dist/browser.js.map +1 -0
  25. package/dist/cli/commands.d.ts +8 -0
  26. package/dist/cli/commands.d.ts.map +1 -0
  27. package/dist/cli/commands.js +1038 -0
  28. package/dist/cli/commands.js.map +1 -0
  29. package/dist/cli/connection.d.ts +50 -0
  30. package/dist/cli/connection.d.ts.map +1 -0
  31. package/dist/cli/connection.js +595 -0
  32. package/dist/cli/connection.js.map +1 -0
  33. package/dist/cli/flags.d.ts +36 -0
  34. package/dist/cli/flags.d.ts.map +1 -0
  35. package/dist/cli/flags.js +206 -0
  36. package/dist/cli/flags.js.map +1 -0
  37. package/dist/cli/help.d.ts +4 -0
  38. package/dist/cli/help.d.ts.map +1 -0
  39. package/dist/cli/help.js +1024 -0
  40. package/dist/cli/help.js.map +1 -0
  41. package/dist/cli/output.d.ts +14 -0
  42. package/dist/cli/output.d.ts.map +1 -0
  43. package/dist/cli/output.js +456 -0
  44. package/dist/cli/output.js.map +1 -0
  45. package/dist/cli-new.d.ts +3 -0
  46. package/dist/cli-new.d.ts.map +1 -0
  47. package/dist/cli-new.js +308 -0
  48. package/dist/cli-new.js.map +1 -0
  49. package/dist/cli-old.d.ts +3 -0
  50. package/dist/cli-old.d.ts.map +1 -0
  51. package/dist/cli-old.js +1101 -0
  52. package/dist/cli-old.js.map +1 -0
  53. package/dist/cli.d.ts +3 -0
  54. package/dist/cli.d.ts.map +1 -0
  55. package/dist/cli.js +403 -0
  56. package/dist/cli.js.map +1 -0
  57. package/dist/content-detection.d.ts +18 -0
  58. package/dist/content-detection.d.ts.map +1 -0
  59. package/dist/content-detection.js +68 -0
  60. package/dist/content-detection.js.map +1 -0
  61. package/dist/daemon.d.ts +55 -0
  62. package/dist/daemon.d.ts.map +1 -0
  63. package/dist/daemon.js +426 -0
  64. package/dist/daemon.js.map +1 -0
  65. package/dist/diff.d.ts +42 -0
  66. package/dist/diff.d.ts.map +1 -0
  67. package/dist/diff.js +166 -0
  68. package/dist/diff.js.map +1 -0
  69. package/dist/human-mouse.d.ts +31 -0
  70. package/dist/human-mouse.d.ts.map +1 -0
  71. package/dist/human-mouse.js +184 -0
  72. package/dist/human-mouse.js.map +1 -0
  73. package/dist/ios-actions.d.ts +11 -0
  74. package/dist/ios-actions.d.ts.map +1 -0
  75. package/dist/ios-actions.js +228 -0
  76. package/dist/ios-actions.js.map +1 -0
  77. package/dist/ios-manager.d.ts +266 -0
  78. package/dist/ios-manager.d.ts.map +1 -0
  79. package/dist/ios-manager.js +1076 -0
  80. package/dist/ios-manager.js.map +1 -0
  81. package/dist/message-bridge.d.ts +10 -0
  82. package/dist/message-bridge.d.ts.map +1 -0
  83. package/dist/message-bridge.js +60 -0
  84. package/dist/message-bridge.js.map +1 -0
  85. package/dist/protocol.d.ts +26 -0
  86. package/dist/protocol.d.ts.map +1 -0
  87. package/dist/protocol.js +912 -0
  88. package/dist/protocol.js.map +1 -0
  89. package/dist/recorder/binding.d.ts +24 -0
  90. package/dist/recorder/binding.d.ts.map +1 -0
  91. package/dist/recorder/binding.js +215 -0
  92. package/dist/recorder/binding.js.map +1 -0
  93. package/dist/recorder/index.d.ts +4 -0
  94. package/dist/recorder/index.d.ts.map +1 -0
  95. package/dist/recorder/index.js +4 -0
  96. package/dist/recorder/index.js.map +1 -0
  97. package/dist/recorder/inject.js +1913 -0
  98. package/dist/recorder/recorder.d.ts +19 -0
  99. package/dist/recorder/recorder.d.ts.map +1 -0
  100. package/dist/recorder/recorder.js +101 -0
  101. package/dist/recorder/recorder.js.map +1 -0
  102. package/dist/recorder/store.d.ts +22 -0
  103. package/dist/recorder/store.d.ts.map +1 -0
  104. package/dist/recorder/store.js +150 -0
  105. package/dist/recorder/store.js.map +1 -0
  106. package/dist/recorder/types.d.ts +73 -0
  107. package/dist/recorder/types.d.ts.map +1 -0
  108. package/dist/recorder/types.js +5 -0
  109. package/dist/recorder/types.js.map +1 -0
  110. package/dist/snapshot.d.ts +81 -0
  111. package/dist/snapshot.d.ts.map +1 -0
  112. package/dist/snapshot.js +1348 -0
  113. package/dist/snapshot.js.map +1 -0
  114. package/dist/stream-server-standalone.d.ts +38 -0
  115. package/dist/stream-server-standalone.d.ts.map +1 -0
  116. package/dist/stream-server-standalone.js +494 -0
  117. package/dist/stream-server-standalone.js.map +1 -0
  118. package/dist/stream-server.d.ts +214 -0
  119. package/dist/stream-server.d.ts.map +1 -0
  120. package/dist/stream-server.js +811 -0
  121. package/dist/stream-server.js.map +1 -0
  122. package/dist/types.d.ts +914 -0
  123. package/dist/types.d.ts.map +1 -0
  124. package/dist/types.js +4 -0
  125. package/dist/types.js.map +1 -0
  126. package/dist/viewer-html.d.ts +2 -0
  127. package/dist/viewer-html.d.ts.map +1 -0
  128. package/dist/viewer-html.js +185 -0
  129. package/dist/viewer-html.js.map +1 -0
  130. package/dist/viewer-script.d.ts +47 -0
  131. package/dist/viewer-script.d.ts.map +1 -0
  132. package/dist/viewer-script.js +586 -0
  133. package/dist/viewer-script.js.map +1 -0
  134. package/package.json +86 -0
  135. package/scripts/build-all-platforms.sh +68 -0
  136. package/scripts/check-version-sync.js +39 -0
  137. package/scripts/check_goods_container.js +35 -0
  138. package/scripts/check_page_content.js +36 -0
  139. package/scripts/click_applause_rate.js +30 -0
  140. package/scripts/copy-native.js +36 -0
  141. package/scripts/copy-recorder.js +21 -0
  142. package/scripts/e2e-test-recorder.ts +584 -0
  143. package/scripts/explore_jd_page.js +31 -0
  144. package/scripts/extract_all_jd_data.js +80 -0
  145. package/scripts/extract_jd_product_detail.js +62 -0
  146. package/scripts/extract_jd_products_correct_links.js +78 -0
  147. package/scripts/extract_jd_products_final.js +80 -0
  148. package/scripts/extract_jd_reviews.js +48 -0
  149. package/scripts/extract_jd_seafood_final.js +78 -0
  150. package/scripts/extract_multiple_products.js +77 -0
  151. package/scripts/extract_products_no_scroll.js +68 -0
  152. package/scripts/extract_products_simple.js +68 -0
  153. package/scripts/find_applause_rate.js +26 -0
  154. package/scripts/find_jd_links.js +28 -0
  155. package/scripts/find_main_content.js +20 -0
  156. package/scripts/find_product_cards.js +38 -0
  157. package/scripts/find_root_content.js +26 -0
  158. package/scripts/find_unique_products.js +55 -0
  159. package/scripts/get_jd_product_detail.js +16 -0
  160. package/scripts/get_jd_products.js +23 -0
  161. package/scripts/get_jd_seafood_products.js +44 -0
  162. package/scripts/get_product_details_from_images.js +54 -0
  163. package/scripts/postinstall.js +235 -0
  164. package/scripts/scroll_and_get_products.js +47 -0
  165. package/scripts/scroll_deep_and_find.js +45 -0
  166. package/scripts/sync-version.js +69 -0
  167. package/scripts/verify-baidu-enter.ts +116 -0
  168. package/skills/agent-browser/SKILL.md +310 -0
  169. package/skills/agent-browser/references/authentication.md +198 -0
  170. package/skills/agent-browser/references/commands.md +471 -0
  171. package/skills/agent-browser/references/data-extraction.md +377 -0
  172. package/skills/agent-browser/references/proxy-support.md +188 -0
  173. package/skills/agent-browser/references/session-management.md +197 -0
  174. package/skills/agent-browser/references/snapshot-refs.md +379 -0
  175. package/skills/agent-browser/references/video-recording.md +173 -0
  176. package/skills/agent-browser/templates/api-interception.sh +53 -0
  177. package/skills/agent-browser/templates/authenticated-session.sh +97 -0
  178. package/skills/agent-browser/templates/capture-workflow.sh +69 -0
  179. package/skills/agent-browser/templates/data-extraction.sh +210 -0
  180. package/skills/agent-browser/templates/form-automation.sh +62 -0
  181. package/skills/skill-creator/LICENSE.txt +202 -0
  182. package/skills/skill-creator/SKILL.md +356 -0
  183. package/skills/skill-creator/references/output-patterns.md +82 -0
  184. package/skills/skill-creator/references/workflows.md +28 -0
  185. package/skills/skill-creator/scripts/init_skill.py +303 -0
  186. package/skills/skill-creator/scripts/package_skill.py +113 -0
  187. package/skills/skill-creator/scripts/quick_validate.py +95 -0
@@ -0,0 +1,19 @@
1
+ import type { Page } from 'playwright-core';
2
+ import type { RecorderConfig } from './types.js';
3
+ import { SessionStore } from './store.js';
4
+ export declare class Recorder {
5
+ private page;
6
+ private cdp;
7
+ private store;
8
+ private config;
9
+ private isRecording;
10
+ constructor(page: Page, store: SessionStore, config?: RecorderConfig);
11
+ start(): Promise<void>;
12
+ stop(): Promise<void>;
13
+ closePanel(): Promise<void>;
14
+ private handleSync;
15
+ restoreState(): Promise<void>;
16
+ isRunning(): boolean;
17
+ getStore(): SessionStore;
18
+ }
19
+ //# sourceMappingURL=recorder.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"recorder.d.ts","sourceRoot":"","sources":["../../src/recorder/recorder.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,IAAI,EAAc,MAAM,iBAAiB,CAAC;AACxD,OAAO,KAAK,EAAgB,cAAc,EAAE,MAAM,YAAY,CAAC;AAC/D,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAe1C,qBAAa,QAAQ;IACnB,OAAO,CAAC,IAAI,CAAO;IACnB,OAAO,CAAC,GAAG,CAA2B;IACtC,OAAO,CAAC,KAAK,CAAe;IAC5B,OAAO,CAAC,MAAM,CAAuE;IACrF,OAAO,CAAC,WAAW,CAAS;gBAEhB,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,YAAY,EAAE,MAAM,CAAC,EAAE,cAAc;IAS9D,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IA0BtB,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IAmBrB,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAajC,OAAO,CAAC,UAAU;IAUZ,YAAY,IAAI,OAAO,CAAC,IAAI,CAAC;IAUnC,SAAS,IAAI,OAAO;IAIpB,QAAQ,IAAI,YAAY;CAGzB"}
@@ -0,0 +1,101 @@
1
+ import fs from 'node:fs';
2
+ import path from 'node:path';
3
+ import { DEFAULT_CONFIG } from './types.js';
4
+ let injectScriptCache = null;
5
+ function getInjectScriptContent() {
6
+ if (injectScriptCache) {
7
+ return injectScriptCache;
8
+ }
9
+ const scriptPath = path.join(__dirname, 'inject.js');
10
+ injectScriptCache = fs.readFileSync(scriptPath, 'utf-8');
11
+ return injectScriptCache;
12
+ }
13
+ export class Recorder {
14
+ page;
15
+ cdp = null;
16
+ store;
17
+ config;
18
+ isRecording = false;
19
+ constructor(page, store, config) {
20
+ this.page = page;
21
+ this.store = store;
22
+ this.config = {
23
+ trajectoryInterval: config?.trajectoryInterval ?? DEFAULT_CONFIG.trajectoryInterval,
24
+ maxTrajectoryPoints: config?.maxTrajectoryPoints ?? DEFAULT_CONFIG.maxTrajectoryPoints
25
+ };
26
+ }
27
+ async start() {
28
+ if (this.isRecording)
29
+ return;
30
+ this.cdp = await this.page.context().newCDPSession(this.page);
31
+ await this.cdp.send('Runtime.addBinding', {
32
+ name: '__recorderSync'
33
+ });
34
+ this.cdp.on('Runtime.bindingCalled', (params) => {
35
+ if (params.name === '__recorderSync') {
36
+ this.handleSync(params.payload);
37
+ }
38
+ });
39
+ const scriptContent = getInjectScriptContent()
40
+ .replace('TRAJECTORY_INTERVAL = 50', `TRAJECTORY_INTERVAL = ${this.config.trajectoryInterval}`)
41
+ .replace('MAX_TRAJECTORY_POINTS = 10', `MAX_TRAJECTORY_POINTS = ${this.config.maxTrajectoryPoints}`);
42
+ await this.page.addInitScript(scriptContent);
43
+ await this.page.evaluate(scriptContent);
44
+ this.isRecording = true;
45
+ console.log('[Recorder] Started with CDP binding');
46
+ }
47
+ async stop() {
48
+ if (!this.isRecording)
49
+ return;
50
+ await this.closePanel();
51
+ this.store.endSession();
52
+ if (this.cdp) {
53
+ await this.cdp.send('Runtime.removeBinding', {
54
+ name: '__recorderSync'
55
+ }).catch(() => { });
56
+ await this.cdp.detach().catch(() => { });
57
+ this.cdp = null;
58
+ }
59
+ this.isRecording = false;
60
+ console.log('[Recorder] Stopped');
61
+ }
62
+ async closePanel() {
63
+ try {
64
+ await this.page.evaluate(() => {
65
+ const win = window;
66
+ if (typeof win.__recorderClosePanel === 'function') {
67
+ win.__recorderClosePanel();
68
+ }
69
+ });
70
+ }
71
+ catch (e) {
72
+ // Ignore errors if page is already closed or navigated away
73
+ }
74
+ }
75
+ handleSync(payload) {
76
+ try {
77
+ const step = JSON.parse(payload);
78
+ this.store.addStep(step);
79
+ console.log(`[Recorder] Step recorded: ${step.action} on ${step.selector}`);
80
+ }
81
+ catch (e) {
82
+ console.error('[Recorder] Failed to parse step:', e);
83
+ }
84
+ }
85
+ async restoreState() {
86
+ const steps = this.store.getSteps();
87
+ await this.page.evaluate((steps) => {
88
+ window.__recorderSteps = steps;
89
+ window.dispatchEvent(new CustomEvent('recorder:restored', {
90
+ detail: { steps: steps }
91
+ }));
92
+ }, steps);
93
+ }
94
+ isRunning() {
95
+ return this.isRecording;
96
+ }
97
+ getStore() {
98
+ return this.store;
99
+ }
100
+ }
101
+ //# sourceMappingURL=recorder.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"recorder.js","sourceRoot":"","sources":["../../src/recorder/recorder.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,22 @@
1
+ import type { RecordingSession, RecordedStep, PageInfo } from './types.js';
2
+ export declare class SessionStore {
3
+ private session;
4
+ private filePath;
5
+ private saveTimeout;
6
+ constructor(sessionId: string, persistPath?: string);
7
+ private load;
8
+ addStep(step: RecordedStep): void;
9
+ updatePageTitle(url: string, title: string): void;
10
+ private normalizeUrl;
11
+ private scheduleSave;
12
+ save(): void;
13
+ getSession(): RecordingSession;
14
+ getSteps(): RecordedStep[];
15
+ getPages(): PageInfo[];
16
+ endSession(): void;
17
+ clear(): void;
18
+ export(): string;
19
+ exportToScript(): string;
20
+ static loadFromPath(filePath: string): SessionStore | null;
21
+ }
22
+ //# sourceMappingURL=store.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"store.d.ts","sourceRoot":"","sources":["../../src/recorder/store.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,gBAAgB,EAAE,YAAY,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AAE3E,qBAAa,YAAY;IACvB,OAAO,CAAC,OAAO,CAAmB;IAClC,OAAO,CAAC,QAAQ,CAAS;IACzB,OAAO,CAAC,WAAW,CAA8C;gBAErD,SAAS,EAAE,MAAM,EAAE,WAAW,CAAC,EAAE,MAAM;IAWnD,OAAO,CAAC,IAAI;IAmBZ,OAAO,CAAC,IAAI,EAAE,YAAY,GAAG,IAAI;IAejC,eAAe,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI;IAQjD,OAAO,CAAC,YAAY;IASpB,OAAO,CAAC,YAAY;IASpB,IAAI,IAAI,IAAI;IAQZ,UAAU,IAAI,gBAAgB;IAI9B,QAAQ,IAAI,YAAY,EAAE;IAI1B,QAAQ,IAAI,QAAQ,EAAE;IAItB,UAAU,IAAI,IAAI;IAKlB,KAAK,IAAI,IAAI;IAQb,MAAM,IAAI,MAAM;IAIhB,cAAc,IAAI,MAAM;IA6CxB,MAAM,CAAC,YAAY,CAAC,QAAQ,EAAE,MAAM,GAAG,YAAY,GAAG,IAAI;CAU3D"}
@@ -0,0 +1,150 @@
1
+ import fs from 'node:fs';
2
+ import path from 'node:path';
3
+ import os from 'node:os';
4
+ export class SessionStore {
5
+ session;
6
+ filePath;
7
+ saveTimeout = null;
8
+ constructor(sessionId, persistPath) {
9
+ const dir = persistPath || path.join(os.tmpdir(), 'agent-browser-recorder');
10
+ if (!fs.existsSync(dir)) {
11
+ fs.mkdirSync(dir, { recursive: true });
12
+ }
13
+ this.filePath = path.join(dir, `session-${sessionId}.json`);
14
+ this.session = this.load();
15
+ }
16
+ load() {
17
+ if (fs.existsSync(this.filePath)) {
18
+ try {
19
+ const content = fs.readFileSync(this.filePath, 'utf-8');
20
+ return JSON.parse(content);
21
+ }
22
+ catch (e) {
23
+ console.warn('[SessionStore] Failed to load session:', e);
24
+ }
25
+ }
26
+ return {
27
+ id: path.basename(this.filePath, '.json').replace('session-', ''),
28
+ name: `Recording Session`,
29
+ startTime: Date.now(),
30
+ pages: [],
31
+ steps: []
32
+ };
33
+ }
34
+ addStep(step) {
35
+ this.session.steps.push(step);
36
+ const pageUrl = step.url ? this.normalizeUrl(step.url) : undefined;
37
+ if (pageUrl && !this.session.pages.find(p => p.url === pageUrl)) {
38
+ this.session.pages.push({
39
+ url: pageUrl,
40
+ title: '',
41
+ firstVisitTime: step.timestamp
42
+ });
43
+ }
44
+ this.scheduleSave();
45
+ }
46
+ updatePageTitle(url, title) {
47
+ const page = this.session.pages.find(p => p.url === this.normalizeUrl(url));
48
+ if (page) {
49
+ page.title = title;
50
+ this.scheduleSave();
51
+ }
52
+ }
53
+ normalizeUrl(url) {
54
+ try {
55
+ const parsed = new URL(url);
56
+ return parsed.origin + parsed.pathname;
57
+ }
58
+ catch {
59
+ return url;
60
+ }
61
+ }
62
+ scheduleSave() {
63
+ if (this.saveTimeout) {
64
+ clearTimeout(this.saveTimeout);
65
+ }
66
+ this.saveTimeout = setTimeout(() => {
67
+ this.save();
68
+ }, 100);
69
+ }
70
+ save() {
71
+ try {
72
+ fs.writeFileSync(this.filePath, JSON.stringify(this.session, null, 2));
73
+ }
74
+ catch (e) {
75
+ console.error('[SessionStore] Failed to save session:', e);
76
+ }
77
+ }
78
+ getSession() {
79
+ return this.session;
80
+ }
81
+ getSteps() {
82
+ return this.session.steps;
83
+ }
84
+ getPages() {
85
+ return this.session.pages;
86
+ }
87
+ endSession() {
88
+ this.session.endTime = Date.now();
89
+ this.save();
90
+ }
91
+ clear() {
92
+ this.session.steps = [];
93
+ this.session.pages = [];
94
+ this.session.startTime = Date.now();
95
+ this.session.endTime = undefined;
96
+ this.save();
97
+ }
98
+ export() {
99
+ return JSON.stringify(this.session, null, 2);
100
+ }
101
+ exportToScript() {
102
+ const lines = [
103
+ `#!/bin/bash`,
104
+ `# Recording: ${this.session.name}`,
105
+ `# Pages: ${this.session.pages.length}`,
106
+ `# Steps: ${this.session.steps.length}`,
107
+ `# Generated: ${new Date().toISOString()}`,
108
+ ''
109
+ ];
110
+ let currentUrl = '';
111
+ for (const step of this.session.steps) {
112
+ if (step.url && step.url !== currentUrl && step.action !== 'navigate') {
113
+ currentUrl = step.url || '';
114
+ lines.push(`# Page: ${step.url}`);
115
+ }
116
+ const comment = step.annotation
117
+ ? ` # ${step.annotation.label}`
118
+ : '';
119
+ switch (step.action) {
120
+ case 'navigate':
121
+ lines.push(`agent-browser open "${step.value}"${comment}`);
122
+ currentUrl = step.value || '';
123
+ break;
124
+ case 'click':
125
+ lines.push(`agent-browser click "${step.selector}"${comment}`);
126
+ break;
127
+ case 'fill':
128
+ lines.push(`agent-browser fill "${step.selector}" "${step.value}"${comment}`);
129
+ break;
130
+ case 'select':
131
+ lines.push(`agent-browser select "${step.selector}" "${step.value}"${comment}`);
132
+ break;
133
+ case 'annotate':
134
+ lines.push(`# Annotate: ${step.selector} -> ${step.annotation?.label}`);
135
+ break;
136
+ }
137
+ }
138
+ return lines.join('\n');
139
+ }
140
+ static loadFromPath(filePath) {
141
+ if (!fs.existsSync(filePath)) {
142
+ return null;
143
+ }
144
+ const content = fs.readFileSync(filePath, 'utf-8');
145
+ const session = JSON.parse(content);
146
+ const store = new SessionStore(session.id, path.dirname(filePath));
147
+ return store;
148
+ }
149
+ }
150
+ //# sourceMappingURL=store.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"store.js","sourceRoot":"","sources":["../../src/recorder/store.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,73 @@
1
+ export interface TrajectoryPoint {
2
+ x: number;
3
+ y: number;
4
+ t: number;
5
+ }
6
+ export interface ViewportInfo {
7
+ width: number;
8
+ height: number;
9
+ }
10
+ export interface ElementInfo {
11
+ tagName: string;
12
+ id?: string;
13
+ className?: string;
14
+ xpath?: string;
15
+ css?: string;
16
+ text?: string;
17
+ attributes?: Record<string, string>;
18
+ }
19
+ export interface Annotation {
20
+ type: 'login' | 'data' | 'pagination' | 'custom';
21
+ label: string;
22
+ description?: string;
23
+ }
24
+ export type RecordedAction = 'click' | 'fill' | 'navigate' | 'annotate' | 'scroll' | 'select' | 'tab_new' | 'tab_switch' | 'tab_close' | 'back' | 'forward' | 'reload' | 'keyboard' | 'link_click' | 'trajectory' | 'resize';
25
+ export interface RecordedStep {
26
+ id: string;
27
+ timestamp: number;
28
+ url?: string;
29
+ action: RecordedAction;
30
+ selector?: string;
31
+ xpath?: string;
32
+ ref?: string;
33
+ value?: string;
34
+ elementInfo?: ElementInfo;
35
+ annotation?: Annotation;
36
+ trajectory?: TrajectoryPoint[];
37
+ viewport?: ViewportInfo;
38
+ index?: number;
39
+ key?: string;
40
+ code?: string;
41
+ ctrlKey?: boolean;
42
+ metaKey?: boolean;
43
+ altKey?: boolean;
44
+ shiftKey?: boolean;
45
+ points?: TrajectoryPoint[];
46
+ x?: number;
47
+ y?: number;
48
+ from?: ViewportInfo;
49
+ to?: ViewportInfo;
50
+ iframe?: boolean;
51
+ }
52
+ export interface PageInfo {
53
+ url: string;
54
+ title: string;
55
+ firstVisitTime: number;
56
+ }
57
+ export interface RecordingSession {
58
+ id: string;
59
+ name: string;
60
+ startTime: number;
61
+ endTime?: number;
62
+ pages: PageInfo[];
63
+ steps: RecordedStep[];
64
+ }
65
+ export interface RecorderConfig {
66
+ sessionId?: string;
67
+ name?: string;
68
+ persistPath?: string;
69
+ trajectoryInterval?: number;
70
+ maxTrajectoryPoints?: number;
71
+ }
72
+ export declare const DEFAULT_CONFIG: Required<Omit<RecorderConfig, 'sessionId' | 'name' | 'persistPath'>>;
73
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/recorder/types.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ export const DEFAULT_CONFIG = {
2
+ trajectoryInterval: 50,
3
+ maxTrajectoryPoints: 10
4
+ };
5
+ //# sourceMappingURL=types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.js","sourceRoot":"","sources":["../../src/recorder/types.ts"],"names":[],"mappings":"AAoFA,MAAM,CAAC,MAAM,cAAc,GAAyE;IAClG,kBAAkB,EAAE,EAAE;IACtB,mBAAmB,EAAE,EAAE;CACxB,CAAC"}
@@ -0,0 +1,81 @@
1
+ /**
2
+ * Enhanced snapshot with element refs for deterministic element selection.
3
+ *
4
+ * This module generates accessibility snapshots with embedded refs that can be
5
+ * used to click/fill/interact with elements without re-querying the DOM.
6
+ *
7
+ * Example output:
8
+ * - heading "Example Domain" [ref=e1] [level=1]
9
+ * - paragraph: Some text content
10
+ * - button "Submit" [ref=e2]
11
+ * - textbox "Email" [ref=e3]
12
+ *
13
+ * Usage:
14
+ * agent-browser snapshot # Full snapshot
15
+ * agent-browser snapshot -i # Interactive elements only
16
+ * agent-browser snapshot --depth 3 # Limit depth
17
+ * agent-browser click @e2 # Click element by ref
18
+ */
19
+ import type { Page, Frame, FrameLocator } from 'playwright-core';
20
+ export interface RefMap {
21
+ [ref: string]: {
22
+ selector: string;
23
+ role: string;
24
+ name?: string;
25
+ /** Index for disambiguation when multiple elements have same role+name */
26
+ nth?: number;
27
+ /** XPath path (only when path=true) */
28
+ xpath?: string;
29
+ /** CSS selector path (only when path=true) */
30
+ cssPath?: string;
31
+ /** Element attributes (only when attrs=true) */
32
+ attributes?: Record<string, string>;
33
+ };
34
+ }
35
+ export interface EnhancedSnapshot {
36
+ tree: string;
37
+ refs: RefMap;
38
+ }
39
+ export interface SnapshotOptions {
40
+ /** Only include interactive elements (buttons, links, inputs, etc.) */
41
+ interactive?: boolean;
42
+ /** Include cursor-interactive elements (cursor:pointer, onclick, tabindex) */
43
+ cursor?: boolean;
44
+ /** Maximum depth of tree to include (0 = root only) */
45
+ maxDepth?: number;
46
+ /** Remove structural elements without meaningful content */
47
+ compact?: boolean;
48
+ /** CSS selector to scope the snapshot */
49
+ selector?: string;
50
+ /** Include xpath and cssPath in refs (requires selector) */
51
+ path?: boolean;
52
+ /** Include element attributes in refs (requires selector) */
53
+ attrs?: boolean;
54
+ }
55
+ /**
56
+ * Reset ref counter (call at start of each snapshot)
57
+ */
58
+ export declare function resetRefs(): void;
59
+ /**
60
+ * Get enhanced snapshot with refs and optional filtering
61
+ */
62
+ export declare function getEnhancedSnapshot(page: Page | Frame | FrameLocator, options?: SnapshotOptions): Promise<EnhancedSnapshot>;
63
+ /**
64
+ * Parse a ref from command argument (e.g., "@e1" -> "e1")
65
+ */
66
+ export declare function parseRef(arg: string): string | null;
67
+ /**
68
+ * Get snapshot statistics
69
+ */
70
+ export declare function getSnapshotStats(tree: string, refs: RefMap): {
71
+ lines: number;
72
+ chars: number;
73
+ tokens: number;
74
+ refs: number;
75
+ interactive: number;
76
+ };
77
+ export declare function getSemanticClass(element: Element): string | null;
78
+ export declare function generateXPath(element: Element, maxDepth?: number): string;
79
+ export declare function generateCSSPath(element: Element, maxDepth?: number): string;
80
+ export declare function collectAttributes(element: Element): Record<string, string>;
81
+ //# sourceMappingURL=snapshot.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"snapshot.d.ts","sourceRoot":"","sources":["../src/snapshot.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;GAiBG;AAEH,OAAO,KAAK,EAAE,IAAI,EAAE,KAAK,EAAW,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAE1E,MAAM,WAAW,MAAM;IACrB,CAAC,GAAG,EAAE,MAAM,GAAG;QACb,QAAQ,EAAE,MAAM,CAAC;QACjB,IAAI,EAAE,MAAM,CAAC;QACb,IAAI,CAAC,EAAE,MAAM,CAAC;QACd,0EAA0E;QAC1E,GAAG,CAAC,EAAE,MAAM,CAAC;QACb,uCAAuC;QACvC,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,8CAA8C;QAC9C,OAAO,CAAC,EAAE,MAAM,CAAC;QACjB,gDAAgD;QAChD,UAAU,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;KACrC,CAAC;CACH;AAED,MAAM,WAAW,gBAAgB;IAC/B,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;CACd;AAED,MAAM,WAAW,eAAe;IAC9B,uEAAuE;IACvE,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,8EAA8E;IAC9E,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,uDAAuD;IACvD,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,4DAA4D;IAC5D,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,yCAAyC;IACzC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,4DAA4D;IAC5D,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,6DAA6D;IAC7D,KAAK,CAAC,EAAE,OAAO,CAAC;CACjB;AAKD;;GAEG;AACH,wBAAgB,SAAS,IAAI,IAAI,CAEhC;AAwTD;;GAEG;AACH,wBAAsB,mBAAmB,CACvC,IAAI,EAAE,IAAI,GAAG,KAAK,GAAG,YAAY,EACjC,OAAO,GAAE,eAAoB,GAC5B,OAAO,CAAC,gBAAgB,CAAC,CA+E3B;AAu0BD;;GAEG;AACH,wBAAgB,QAAQ,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,CAcnD;AAED;;GAEG;AACH,wBAAgB,gBAAgB,CAC9B,IAAI,EAAE,MAAM,EACZ,IAAI,EAAE,MAAM,GACX;IACD,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;CACrB,CAUA;AA6BD,wBAAgB,gBAAgB,CAAC,OAAO,EAAE,OAAO,GAAG,MAAM,GAAG,IAAI,CAYhE;AAED,wBAAgB,aAAa,CAAC,OAAO,EAAE,OAAO,EAAE,QAAQ,GAAE,MAAU,GAAG,MAAM,CAqB5E;AAkDD,wBAAgB,eAAe,CAAC,OAAO,EAAE,OAAO,EAAE,QAAQ,GAAE,MAAU,GAAG,MAAM,CAyC9E;AAyBD,wBAAgB,iBAAiB,CAAC,OAAO,EAAE,OAAO,GAAG,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAS1E"}