opendevbrowser 0.0.28 → 0.0.29

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 (313) hide show
  1. package/README.md +2 -2
  2. package/dist/accessibility-snapshot-PA6NWNS7.js +39 -0
  3. package/dist/accessibility-snapshot-PA6NWNS7.js.map +1 -0
  4. package/dist/active-window-YNYTIPZN.js +37 -0
  5. package/dist/active-window-YNYTIPZN.js.map +1 -0
  6. package/dist/annotate-STYHXZYJ.js +205 -0
  7. package/dist/annotate-STYHXZYJ.js.map +1 -0
  8. package/dist/artifacts-KJ6RNDO2.js +120 -0
  9. package/dist/artifacts-KJ6RNDO2.js.map +1 -0
  10. package/dist/attr-GHFZZ4SA.js +84 -0
  11. package/dist/attr-GHFZZ4SA.js.map +1 -0
  12. package/dist/browser/ops-client.d.ts +1 -0
  13. package/dist/browser/ops-client.d.ts.map +1 -1
  14. package/dist/canvas-54FBOEGP.js +309 -0
  15. package/dist/canvas-54FBOEGP.js.map +1 -0
  16. package/dist/capture-desktop-SNABC24E.js +38 -0
  17. package/dist/capture-desktop-SNABC24E.js.map +1 -0
  18. package/dist/capture-window-UJSB5AMP.js +40 -0
  19. package/dist/capture-window-UJSB5AMP.js.map +1 -0
  20. package/dist/check-ST5UQ2F5.js +71 -0
  21. package/dist/check-ST5UQ2F5.js.map +1 -0
  22. package/dist/checked-IEMWI5CU.js +71 -0
  23. package/dist/checked-IEMWI5CU.js.map +1 -0
  24. package/dist/chunk-2CG4SW3E.js +64 -0
  25. package/dist/chunk-2CG4SW3E.js.map +1 -0
  26. package/dist/chunk-2SIMIPLY.js +67 -0
  27. package/dist/chunk-2SIMIPLY.js.map +1 -0
  28. package/dist/chunk-37VSRUW4.js +141 -0
  29. package/dist/chunk-37VSRUW4.js.map +1 -0
  30. package/dist/chunk-5SWZDVOW.js +144 -0
  31. package/dist/chunk-5SWZDVOW.js.map +1 -0
  32. package/dist/chunk-6PVZ2ABC.js +429 -0
  33. package/dist/chunk-6PVZ2ABC.js.map +1 -0
  34. package/dist/chunk-7GVOUZMQ.js +64 -0
  35. package/dist/chunk-7GVOUZMQ.js.map +1 -0
  36. package/dist/chunk-7THCPS52.js +84 -0
  37. package/dist/chunk-7THCPS52.js.map +1 -0
  38. package/dist/chunk-ASMHEEKY.js +10 -0
  39. package/dist/chunk-ASMHEEKY.js.map +1 -0
  40. package/dist/chunk-DBF5OKH3.js +111 -0
  41. package/dist/chunk-DBF5OKH3.js.map +1 -0
  42. package/dist/chunk-DW4TX7MU.js +54 -0
  43. package/dist/chunk-DW4TX7MU.js.map +1 -0
  44. package/dist/chunk-IPE7TF2P.js +54 -0
  45. package/dist/chunk-IPE7TF2P.js.map +1 -0
  46. package/dist/chunk-IQTJHXZJ.js +126 -0
  47. package/dist/chunk-IQTJHXZJ.js.map +1 -0
  48. package/dist/chunk-J47N77VG.js +2969 -0
  49. package/dist/chunk-J47N77VG.js.map +1 -0
  50. package/dist/chunk-JZXD6FWR.js +25 -0
  51. package/dist/chunk-JZXD6FWR.js.map +1 -0
  52. package/dist/{chunk-QVWOPIZJ.js → chunk-KDSNXS6N.js} +75 -149
  53. package/dist/chunk-KDSNXS6N.js.map +1 -0
  54. package/dist/chunk-KZ2IXVQT.js +219 -0
  55. package/dist/chunk-KZ2IXVQT.js.map +1 -0
  56. package/dist/chunk-LBPELU7L.js +3649 -0
  57. package/dist/chunk-LBPELU7L.js.map +1 -0
  58. package/dist/chunk-MX3NFLCE.js +940 -0
  59. package/dist/chunk-MX3NFLCE.js.map +1 -0
  60. package/dist/chunk-N44UXKIB.js +26 -0
  61. package/dist/chunk-N44UXKIB.js.map +1 -0
  62. package/dist/chunk-OW5HMYMI.js +19 -0
  63. package/dist/chunk-OW5HMYMI.js.map +1 -0
  64. package/dist/chunk-OYNLAZQU.js +838 -0
  65. package/dist/chunk-OYNLAZQU.js.map +1 -0
  66. package/dist/chunk-PDPJN2OP.js +17 -0
  67. package/dist/chunk-PDPJN2OP.js.map +1 -0
  68. package/dist/chunk-RCZZGGJS.js +226 -0
  69. package/dist/chunk-RCZZGGJS.js.map +1 -0
  70. package/dist/chunk-RJNI3BHT.js +1 -0
  71. package/dist/chunk-RPXWUCQQ.js +112 -0
  72. package/dist/chunk-RPXWUCQQ.js.map +1 -0
  73. package/dist/chunk-S5KZQJJI.js +107 -0
  74. package/dist/chunk-S5KZQJJI.js.map +1 -0
  75. package/dist/{chunk-T3VVHJTK.js → chunk-S6S2UP6U.js} +1074 -1459
  76. package/dist/chunk-S6S2UP6U.js.map +1 -0
  77. package/dist/{chunk-I5ZCOZZV.js → chunk-SXAGSEKZ.js} +1202 -9561
  78. package/dist/chunk-SXAGSEKZ.js.map +1 -0
  79. package/dist/chunk-T4GMCW6Z.js +46 -0
  80. package/dist/chunk-T4GMCW6Z.js.map +1 -0
  81. package/dist/chunk-WHQZBUNY.js +982 -0
  82. package/dist/chunk-WHQZBUNY.js.map +1 -0
  83. package/dist/chunk-WOXBLP7V.js +610 -0
  84. package/dist/chunk-WOXBLP7V.js.map +1 -0
  85. package/dist/cli/commands/inspiredesign.d.ts.map +1 -1
  86. package/dist/cli/commands/macro-resolve.d.ts +4 -1
  87. package/dist/cli/commands/macro-resolve.d.ts.map +1 -1
  88. package/dist/cli/commands/product-video.d.ts.map +1 -1
  89. package/dist/cli/commands/research.d.ts.map +1 -1
  90. package/dist/cli/commands/serve.d.ts.map +1 -1
  91. package/dist/cli/commands/shopping.d.ts.map +1 -1
  92. package/dist/cli/commands/workflow-output.d.ts +2 -0
  93. package/dist/cli/commands/workflow-output.d.ts.map +1 -0
  94. package/dist/cli/daemon-commands.d.ts.map +1 -1
  95. package/dist/cli/daemon.d.ts.map +1 -1
  96. package/dist/cli/index.js +204 -8123
  97. package/dist/cli/index.js.map +1 -1
  98. package/dist/cli/installers/postinstall-skill-sync.js +2 -1
  99. package/dist/cli/installers/postinstall-skill-sync.js.map +1 -1
  100. package/dist/cli/remote-relay.d.ts.map +1 -1
  101. package/dist/click-TENZA3Y6.js +81 -0
  102. package/dist/click-TENZA3Y6.js.map +1 -0
  103. package/dist/clone-component-STH5AR6M.js +82 -0
  104. package/dist/clone-component-STH5AR6M.js.map +1 -0
  105. package/dist/clone-page-BSTWAPAJ.js +69 -0
  106. package/dist/clone-page-BSTWAPAJ.js.map +1 -0
  107. package/dist/close-CEMMAAM7.js +63 -0
  108. package/dist/close-CEMMAAM7.js.map +1 -0
  109. package/dist/close-QCWUNRAI.js +63 -0
  110. package/dist/close-QCWUNRAI.js.map +1 -0
  111. package/dist/connect-J3RVSEZF.js +107 -0
  112. package/dist/connect-J3RVSEZF.js.map +1 -0
  113. package/dist/console-poll-HL7BVIVX.js +76 -0
  114. package/dist/console-poll-HL7BVIVX.js.map +1 -0
  115. package/dist/cookie-import-WMUCIIHN.js +177 -0
  116. package/dist/cookie-import-WMUCIIHN.js.map +1 -0
  117. package/dist/cookie-list-PB2N4RPH.js +117 -0
  118. package/dist/cookie-list-PB2N4RPH.js.map +1 -0
  119. package/dist/daemon-5KSVMGN4.js +194 -0
  120. package/dist/daemon-5KSVMGN4.js.map +1 -0
  121. package/dist/daemon-fingerprint.json +1 -1
  122. package/dist/debug-trace-snapshot-RK7KDXA5.js +136 -0
  123. package/dist/debug-trace-snapshot-RK7KDXA5.js.map +1 -0
  124. package/dist/dialog-P6P4U7XE.js +75 -0
  125. package/dist/dialog-P6P4U7XE.js.map +1 -0
  126. package/dist/disconnect-32F7IDIP.js +58 -0
  127. package/dist/disconnect-32F7IDIP.js.map +1 -0
  128. package/dist/enabled-A6C6ZM2O.js +71 -0
  129. package/dist/enabled-A6C6ZM2O.js.map +1 -0
  130. package/dist/extension-extractor-GKWSFHPN.js +11 -0
  131. package/dist/extension-extractor-GKWSFHPN.js.map +1 -0
  132. package/dist/global-D6WLWBXA.js +56 -0
  133. package/dist/global-D6WLWBXA.js.map +1 -0
  134. package/dist/goto-ULTSABDM.js +98 -0
  135. package/dist/goto-ULTSABDM.js.map +1 -0
  136. package/dist/help-EKKKEDL5.js +491 -0
  137. package/dist/help-EKKKEDL5.js.map +1 -0
  138. package/dist/hover-UF2ZUMTQ.js +71 -0
  139. package/dist/hover-UF2ZUMTQ.js.map +1 -0
  140. package/dist/html-B6TX7GK7.js +84 -0
  141. package/dist/html-B6TX7GK7.js.map +1 -0
  142. package/dist/index.js +68 -34
  143. package/dist/index.js.map +1 -1
  144. package/dist/inspector-6S5FKUZQ.js +62 -0
  145. package/dist/inspector-6S5FKUZQ.js.map +1 -0
  146. package/dist/inspector-audit-ARGEGOS7.js +84 -0
  147. package/dist/inspector-audit-ARGEGOS7.js.map +1 -0
  148. package/dist/inspector-plan-CSG5HZOC.js +69 -0
  149. package/dist/inspector-plan-CSG5HZOC.js.map +1 -0
  150. package/dist/inspiredesign-7VRMMZN4.js +234 -0
  151. package/dist/inspiredesign-7VRMMZN4.js.map +1 -0
  152. package/dist/install-autostart-output-5DOMKCQL.js +41 -0
  153. package/dist/install-autostart-output-5DOMKCQL.js.map +1 -0
  154. package/dist/install-autostart-reconciliation-NHKOFYTD.js +73 -0
  155. package/dist/install-autostart-reconciliation-NHKOFYTD.js.map +1 -0
  156. package/dist/launch-REYCIR3Z.js +225 -0
  157. package/dist/launch-REYCIR3Z.js.map +1 -0
  158. package/dist/list-NPRXRQY2.js +51 -0
  159. package/dist/list-NPRXRQY2.js.map +1 -0
  160. package/dist/list-STYD2ZWA.js +54 -0
  161. package/dist/list-STYD2ZWA.js.map +1 -0
  162. package/dist/local-HXJLUUNT.js +54 -0
  163. package/dist/local-HXJLUUNT.js.map +1 -0
  164. package/dist/macro-resolve-ZIJZ65QI.js +253 -0
  165. package/dist/macro-resolve-ZIJZ65QI.js.map +1 -0
  166. package/dist/macros/execute-runtime.d.ts +3 -1
  167. package/dist/macros/execute-runtime.d.ts.map +1 -1
  168. package/dist/macros/execute.d.ts +2 -0
  169. package/dist/macros/execute.d.ts.map +1 -1
  170. package/dist/native-UPLVQ2SG.js +22 -0
  171. package/dist/native-UPLVQ2SG.js.map +1 -0
  172. package/dist/network-poll-HLDOSC72.js +76 -0
  173. package/dist/network-poll-HLDOSC72.js.map +1 -0
  174. package/dist/new-HXLLN6UT.js +69 -0
  175. package/dist/new-HXLLN6UT.js.map +1 -0
  176. package/dist/onboarding-metadata-7E3KLYSZ.js +27 -0
  177. package/dist/onboarding-metadata-7E3KLYSZ.js.map +1 -0
  178. package/dist/open-KDR25LQZ.js +81 -0
  179. package/dist/open-KDR25LQZ.js.map +1 -0
  180. package/dist/opendevbrowser.js +68 -34
  181. package/dist/opendevbrowser.js.map +1 -1
  182. package/dist/perf-EM6SWFJ6.js +58 -0
  183. package/dist/perf-EM6SWFJ6.js.map +1 -0
  184. package/dist/pointer-down-ZYWRZNCH.js +55 -0
  185. package/dist/pointer-down-ZYWRZNCH.js.map +1 -0
  186. package/dist/pointer-drag-LVEAVJO4.js +54 -0
  187. package/dist/pointer-drag-LVEAVJO4.js.map +1 -0
  188. package/dist/pointer-move-7SRKUS66.js +52 -0
  189. package/dist/pointer-move-7SRKUS66.js.map +1 -0
  190. package/dist/pointer-up-KLDBSK37.js +55 -0
  191. package/dist/pointer-up-KLDBSK37.js.map +1 -0
  192. package/dist/press-UIIXFTD7.js +83 -0
  193. package/dist/press-UIIXFTD7.js.map +1 -0
  194. package/dist/product-video-PYOXJVAI.js +235 -0
  195. package/dist/product-video-PYOXJVAI.js.map +1 -0
  196. package/dist/providers/artifacts.d.ts +0 -2
  197. package/dist/providers/artifacts.d.ts.map +1 -1
  198. package/dist/providers/blocker.d.ts.map +1 -1
  199. package/dist/providers/bounded-map.d.ts +2 -0
  200. package/dist/providers/bounded-map.d.ts.map +1 -0
  201. package/dist/providers/community/index.d.ts.map +1 -1
  202. package/dist/providers/constraint.d.ts.map +1 -1
  203. package/dist/providers/index.d.ts +1 -0
  204. package/dist/providers/index.d.ts.map +1 -1
  205. package/dist/providers/renderer.d.ts.map +1 -1
  206. package/dist/providers/research-compiler.d.ts +1 -1
  207. package/dist/providers/research-compiler.d.ts.map +1 -1
  208. package/dist/providers/research-executor.d.ts.map +1 -1
  209. package/dist/providers/runtime-factory.d.ts.map +1 -1
  210. package/dist/providers/shared/traversal-url.d.ts +3 -0
  211. package/dist/providers/shared/traversal-url.d.ts.map +1 -1
  212. package/dist/providers/shopping/index.d.ts.map +1 -1
  213. package/dist/providers/social/search-quality.d.ts.map +1 -1
  214. package/dist/providers/workflow-handoff.d.ts +4 -0
  215. package/dist/providers/workflow-handoff.d.ts.map +1 -1
  216. package/dist/providers/workflows.d.ts.map +1 -1
  217. package/dist/{providers-QF2RFB4J.js → providers-4YY2BLXG.js} +19 -14
  218. package/dist/providers-4YY2BLXG.js.map +1 -0
  219. package/dist/public-surface/generated-manifest.d.ts +2 -2
  220. package/dist/public-surface/generated-manifest.d.ts.map +1 -1
  221. package/dist/public-surface/source.d.ts +2 -2
  222. package/dist/public-surface/source.d.ts.map +1 -1
  223. package/dist/relay/protocol.d.ts +3 -1
  224. package/dist/relay/protocol.d.ts.map +1 -1
  225. package/dist/relay/relay-server.d.ts +6 -0
  226. package/dist/relay/relay-server.d.ts.map +1 -1
  227. package/dist/research-CKXMJ2DK.js +295 -0
  228. package/dist/research-CKXMJ2DK.js.map +1 -0
  229. package/dist/review-7HWJPZOD.js +48 -0
  230. package/dist/review-7HWJPZOD.js.map +1 -0
  231. package/dist/review-desktop-2IBJHFB5.js +54 -0
  232. package/dist/review-desktop-2IBJHFB5.js.map +1 -0
  233. package/dist/rpc-3HGIEJUO.js +159 -0
  234. package/dist/rpc-3HGIEJUO.js.map +1 -0
  235. package/dist/run-ADRYI3MS.js +180 -0
  236. package/dist/run-ADRYI3MS.js.map +1 -0
  237. package/dist/screencast-start-DTLUHD5H.js +67 -0
  238. package/dist/screencast-start-DTLUHD5H.js.map +1 -0
  239. package/dist/screencast-stop-54C5LRSS.js +59 -0
  240. package/dist/screencast-stop-54C5LRSS.js.map +1 -0
  241. package/dist/screenshot-HOAKR7P7.js +68 -0
  242. package/dist/screenshot-HOAKR7P7.js.map +1 -0
  243. package/dist/scroll-IAOO5COY.js +84 -0
  244. package/dist/scroll-IAOO5COY.js.map +1 -0
  245. package/dist/scroll-into-view-RKWSLAPH.js +71 -0
  246. package/dist/scroll-into-view-RKWSLAPH.js.map +1 -0
  247. package/dist/select-IGD3T6X4.js +86 -0
  248. package/dist/select-IGD3T6X4.js.map +1 -0
  249. package/dist/serve-7X4INUCU.js +498 -0
  250. package/dist/serve-7X4INUCU.js.map +1 -0
  251. package/dist/shopping-FC6DRW76.js +273 -0
  252. package/dist/shopping-FC6DRW76.js.map +1 -0
  253. package/dist/skill-lifecycle-5UAZGKSN.js +89 -0
  254. package/dist/skill-lifecycle-5UAZGKSN.js.map +1 -0
  255. package/dist/skills-NSXDX6YM.js +26 -0
  256. package/dist/skills-NSXDX6YM.js.map +1 -0
  257. package/dist/snapshot-X22GG324.js +113 -0
  258. package/dist/snapshot-X22GG324.js.map +1 -0
  259. package/dist/status-SP55LMNW.js +132 -0
  260. package/dist/status-SP55LMNW.js.map +1 -0
  261. package/dist/status-VH2WXIDG.js +35 -0
  262. package/dist/status-VH2WXIDG.js.map +1 -0
  263. package/dist/status-capabilities-YBERLRRA.js +57 -0
  264. package/dist/status-capabilities-YBERLRRA.js.map +1 -0
  265. package/dist/text-6TB5WNLI.js +84 -0
  266. package/dist/text-6TB5WNLI.js.map +1 -0
  267. package/dist/tools/macro_resolve.d.ts.map +1 -1
  268. package/dist/type-3UI3TQH3.js +94 -0
  269. package/dist/type-3UI3TQH3.js.map +1 -0
  270. package/dist/uncheck-5L3D2D4U.js +71 -0
  271. package/dist/uncheck-5L3D2D4U.js.map +1 -0
  272. package/dist/uninstall-KYKGJAX7.js +91 -0
  273. package/dist/uninstall-KYKGJAX7.js.map +1 -0
  274. package/dist/update-SMXPYGXS.js +305 -0
  275. package/dist/update-SMXPYGXS.js.map +1 -0
  276. package/dist/update-skill-modes-BVX7IVMW.js +38 -0
  277. package/dist/update-skill-modes-BVX7IVMW.js.map +1 -0
  278. package/dist/upload-YG4J2EMI.js +56 -0
  279. package/dist/upload-YG4J2EMI.js.map +1 -0
  280. package/dist/use-V3LGFP3K.js +63 -0
  281. package/dist/use-V3LGFP3K.js.map +1 -0
  282. package/dist/value-3247D57X.js +71 -0
  283. package/dist/value-3247D57X.js.map +1 -0
  284. package/dist/visible-A7HEV36U.js +71 -0
  285. package/dist/visible-A7HEV36U.js.map +1 -0
  286. package/dist/wait-UZPP4Y4R.js +109 -0
  287. package/dist/wait-UZPP4Y4R.js.map +1 -0
  288. package/dist/windows-76TR3AIP.js +37 -0
  289. package/dist/windows-76TR3AIP.js.map +1 -0
  290. package/extension/dist/background.js +99 -22
  291. package/extension/dist/ops/ops-runtime.js +85 -7
  292. package/extension/dist/ops/ops-session-store.js +3 -0
  293. package/extension/dist/ops/target-session-coordinator.js +3 -0
  294. package/extension/dist/services/CDPRouter.js +9 -0
  295. package/extension/manifest.json +1 -1
  296. package/package.json +1 -1
  297. package/skills/opendevbrowser-best-practices/SKILL.md +8 -6
  298. package/skills/opendevbrowser-best-practices/artifacts/skill-runtime-surface-matrix.md +1 -1
  299. package/skills/opendevbrowser-best-practices/scripts/odb-workflow.sh +3 -2
  300. package/skills/opendevbrowser-best-practices/scripts/validator-fixture-cli.sh +39 -2
  301. package/skills/opendevbrowser-research/SKILL.md +64 -12
  302. package/skills/opendevbrowser-research/artifacts/research-workflows.md +56 -19
  303. package/skills/opendevbrowser-research/assets/templates/compact.md +31 -5
  304. package/skills/opendevbrowser-research/assets/templates/context.json +52 -1
  305. package/skills/opendevbrowser-research/assets/templates/report.md +57 -4
  306. package/skills/opendevbrowser-research/examples/sample-input.json +1 -1
  307. package/skills/opendevbrowser-research/examples/sample-output.md +27 -2
  308. package/skills/opendevbrowser-research/scripts/run-research.sh +2 -6
  309. package/skills/opendevbrowser-research/scripts/validate-skill-assets.sh +115 -1
  310. package/dist/chunk-I5ZCOZZV.js.map +0 -1
  311. package/dist/chunk-QVWOPIZJ.js.map +0 -1
  312. package/dist/chunk-T3VVHJTK.js.map +0 -1
  313. /package/dist/{providers-QF2RFB4J.js.map → chunk-RJNI3BHT.js.map} +0 -0
@@ -0,0 +1,58 @@
1
+ import "./chunk-RJNI3BHT.js";
2
+ import {
3
+ parseOptionalStringFlag
4
+ } from "./chunk-RPXWUCQQ.js";
5
+ import {
6
+ callDaemon
7
+ } from "./chunk-OYNLAZQU.js";
8
+ import "./chunk-LBPELU7L.js";
9
+ import "./chunk-SXAGSEKZ.js";
10
+ import "./chunk-MX3NFLCE.js";
11
+ import "./chunk-ASMHEEKY.js";
12
+ import {
13
+ createUsageError
14
+ } from "./chunk-IPE7TF2P.js";
15
+ import "./chunk-STGGGVYT.js";
16
+ import "./chunk-3ILXPKSJ.js";
17
+ import "./chunk-TBUCZX4A.js";
18
+ import "./chunk-Y2KL55OG.js";
19
+ import "./chunk-5SWZDVOW.js";
20
+ import "./chunk-S6S2UP6U.js";
21
+ import "./chunk-S5KZQJJI.js";
22
+ import "./chunk-KZ2IXVQT.js";
23
+ import "./chunk-WHQZBUNY.js";
24
+ import "./chunk-FUSXMW3G.js";
25
+
26
+ // src/cli/commands/devtools/perf.ts
27
+ function parsePerfArgs(rawArgs) {
28
+ const parsed = {};
29
+ for (let i = 0; i < rawArgs.length; i += 1) {
30
+ const arg = rawArgs[i];
31
+ if (arg === "--session-id") {
32
+ const value = rawArgs[i + 1];
33
+ if (!value) throw createUsageError("Missing value for --session-id");
34
+ parsed.sessionId = value;
35
+ i += 1;
36
+ continue;
37
+ }
38
+ if (arg?.startsWith("--session-id=")) {
39
+ parsed.sessionId = arg.split("=", 2)[1];
40
+ continue;
41
+ }
42
+ }
43
+ return parsed;
44
+ }
45
+ async function runPerf(args) {
46
+ const { sessionId } = parsePerfArgs(args.rawArgs);
47
+ const targetId = parseOptionalStringFlag(args.rawArgs, "--target-id");
48
+ if (!sessionId) throw createUsageError("Missing --session-id");
49
+ const result = await callDaemon("devtools.perf", {
50
+ sessionId,
51
+ ...typeof targetId === "string" ? { targetId } : {}
52
+ });
53
+ return { success: true, message: "Performance metrics captured.", data: result };
54
+ }
55
+ export {
56
+ runPerf
57
+ };
58
+ //# sourceMappingURL=perf-EM6SWFJ6.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/cli/commands/devtools/perf.ts"],"sourcesContent":["import type { ParsedArgs } from \"../../args\";\nimport { callDaemon } from \"../../client\";\nimport { createUsageError } from \"../../errors\";\nimport { parseOptionalStringFlag } from \"../../utils/parse\";\n\nfunction parsePerfArgs(rawArgs: string[]): { sessionId?: string } {\n const parsed: { sessionId?: string } = {};\n for (let i = 0; i < rawArgs.length; i += 1) {\n const arg = rawArgs[i];\n if (arg === \"--session-id\") {\n const value = rawArgs[i + 1];\n if (!value) throw createUsageError(\"Missing value for --session-id\");\n parsed.sessionId = value;\n i += 1;\n continue;\n }\n if (arg?.startsWith(\"--session-id=\")) {\n parsed.sessionId = arg.split(\"=\", 2)[1];\n continue;\n }\n }\n return parsed;\n}\n\nexport async function runPerf(args: ParsedArgs) {\n const { sessionId } = parsePerfArgs(args.rawArgs);\n const targetId = parseOptionalStringFlag(args.rawArgs, \"--target-id\");\n if (!sessionId) throw createUsageError(\"Missing --session-id\");\n const result = await callDaemon(\"devtools.perf\", {\n sessionId,\n ...(typeof targetId === \"string\" ? { targetId } : {})\n });\n return { success: true, message: \"Performance metrics captured.\", data: result };\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAKA,SAAS,cAAc,SAA2C;AAChE,QAAM,SAAiC,CAAC;AACxC,WAAS,IAAI,GAAG,IAAI,QAAQ,QAAQ,KAAK,GAAG;AAC1C,UAAM,MAAM,QAAQ,CAAC;AACrB,QAAI,QAAQ,gBAAgB;AAC1B,YAAM,QAAQ,QAAQ,IAAI,CAAC;AAC3B,UAAI,CAAC,MAAO,OAAM,iBAAiB,gCAAgC;AACnE,aAAO,YAAY;AACnB,WAAK;AACL;AAAA,IACF;AACA,QAAI,KAAK,WAAW,eAAe,GAAG;AACpC,aAAO,YAAY,IAAI,MAAM,KAAK,CAAC,EAAE,CAAC;AACtC;AAAA,IACF;AAAA,EACF;AACA,SAAO;AACT;AAEA,eAAsB,QAAQ,MAAkB;AAC9C,QAAM,EAAE,UAAU,IAAI,cAAc,KAAK,OAAO;AAChD,QAAM,WAAW,wBAAwB,KAAK,SAAS,aAAa;AACpE,MAAI,CAAC,UAAW,OAAM,iBAAiB,sBAAsB;AAC7D,QAAM,SAAS,MAAM,WAAW,iBAAiB;AAAA,IAC/C;AAAA,IACA,GAAI,OAAO,aAAa,WAAW,EAAE,SAAS,IAAI,CAAC;AAAA,EACrD,CAAC;AACD,SAAO,EAAE,SAAS,MAAM,SAAS,iCAAiC,MAAM,OAAO;AACjF;","names":[]}
@@ -0,0 +1,55 @@
1
+ import {
2
+ parsePointerButton,
3
+ parsePointerClickCount,
4
+ requirePointerCoordinate
5
+ } from "./chunk-T4GMCW6Z.js";
6
+ import "./chunk-RJNI3BHT.js";
7
+ import {
8
+ parseOptionalStringFlag
9
+ } from "./chunk-RPXWUCQQ.js";
10
+ import {
11
+ callDaemon
12
+ } from "./chunk-OYNLAZQU.js";
13
+ import "./chunk-LBPELU7L.js";
14
+ import "./chunk-SXAGSEKZ.js";
15
+ import "./chunk-MX3NFLCE.js";
16
+ import "./chunk-ASMHEEKY.js";
17
+ import {
18
+ createUsageError
19
+ } from "./chunk-IPE7TF2P.js";
20
+ import "./chunk-STGGGVYT.js";
21
+ import "./chunk-3ILXPKSJ.js";
22
+ import "./chunk-TBUCZX4A.js";
23
+ import "./chunk-Y2KL55OG.js";
24
+ import "./chunk-5SWZDVOW.js";
25
+ import "./chunk-S6S2UP6U.js";
26
+ import "./chunk-S5KZQJJI.js";
27
+ import "./chunk-KZ2IXVQT.js";
28
+ import "./chunk-WHQZBUNY.js";
29
+ import "./chunk-FUSXMW3G.js";
30
+
31
+ // src/cli/commands/interact/pointer-down.ts
32
+ async function runPointerDown(args) {
33
+ const sessionId = parseOptionalStringFlag(args.rawArgs, "--session-id");
34
+ const targetId = parseOptionalStringFlag(args.rawArgs, "--target-id");
35
+ const x = requirePointerCoordinate(args.rawArgs, "--x");
36
+ const y = requirePointerCoordinate(args.rawArgs, "--y");
37
+ const button = parsePointerButton(args.rawArgs);
38
+ const clickCount = parsePointerClickCount(args.rawArgs);
39
+ if (!sessionId) {
40
+ throw createUsageError("Missing --session-id");
41
+ }
42
+ const result = await callDaemon("pointer.down", {
43
+ sessionId,
44
+ x,
45
+ y,
46
+ ...typeof button === "string" ? { button } : {},
47
+ ...typeof clickCount === "number" ? { clickCount } : {},
48
+ ...typeof targetId === "string" ? { targetId } : {}
49
+ });
50
+ return { success: true, message: "Pointer down complete.", data: result };
51
+ }
52
+ export {
53
+ runPointerDown
54
+ };
55
+ //# sourceMappingURL=pointer-down-ZYWRZNCH.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/cli/commands/interact/pointer-down.ts"],"sourcesContent":["import type { ParsedArgs } from \"../../args\";\nimport { callDaemon } from \"../../client\";\nimport { createUsageError } from \"../../errors\";\nimport { parseOptionalStringFlag } from \"../../utils/parse\";\nimport {\n parsePointerButton,\n parsePointerClickCount,\n requirePointerCoordinate\n} from \"./pointer-shared\";\n\nexport async function runPointerDown(args: ParsedArgs) {\n const sessionId = parseOptionalStringFlag(args.rawArgs, \"--session-id\");\n const targetId = parseOptionalStringFlag(args.rawArgs, \"--target-id\");\n const x = requirePointerCoordinate(args.rawArgs, \"--x\");\n const y = requirePointerCoordinate(args.rawArgs, \"--y\");\n const button = parsePointerButton(args.rawArgs);\n const clickCount = parsePointerClickCount(args.rawArgs);\n\n if (!sessionId) {\n throw createUsageError(\"Missing --session-id\");\n }\n\n const result = await callDaemon(\"pointer.down\", {\n sessionId,\n x,\n y,\n ...(typeof button === \"string\" ? { button } : {}),\n ...(typeof clickCount === \"number\" ? { clickCount } : {}),\n ...(typeof targetId === \"string\" ? { targetId } : {})\n });\n return { success: true, message: \"Pointer down complete.\", data: result };\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAUA,eAAsB,eAAe,MAAkB;AACrD,QAAM,YAAY,wBAAwB,KAAK,SAAS,cAAc;AACtE,QAAM,WAAW,wBAAwB,KAAK,SAAS,aAAa;AACpE,QAAM,IAAI,yBAAyB,KAAK,SAAS,KAAK;AACtD,QAAM,IAAI,yBAAyB,KAAK,SAAS,KAAK;AACtD,QAAM,SAAS,mBAAmB,KAAK,OAAO;AAC9C,QAAM,aAAa,uBAAuB,KAAK,OAAO;AAEtD,MAAI,CAAC,WAAW;AACd,UAAM,iBAAiB,sBAAsB;AAAA,EAC/C;AAEA,QAAM,SAAS,MAAM,WAAW,gBAAgB;AAAA,IAC9C;AAAA,IACA;AAAA,IACA;AAAA,IACA,GAAI,OAAO,WAAW,WAAW,EAAE,OAAO,IAAI,CAAC;AAAA,IAC/C,GAAI,OAAO,eAAe,WAAW,EAAE,WAAW,IAAI,CAAC;AAAA,IACvD,GAAI,OAAO,aAAa,WAAW,EAAE,SAAS,IAAI,CAAC;AAAA,EACrD,CAAC;AACD,SAAO,EAAE,SAAS,MAAM,SAAS,0BAA0B,MAAM,OAAO;AAC1E;","names":[]}
@@ -0,0 +1,54 @@
1
+ import {
2
+ parsePointerSteps,
3
+ requirePointerCoordinate
4
+ } from "./chunk-T4GMCW6Z.js";
5
+ import "./chunk-RJNI3BHT.js";
6
+ import {
7
+ parseOptionalStringFlag
8
+ } from "./chunk-RPXWUCQQ.js";
9
+ import {
10
+ callDaemon
11
+ } from "./chunk-OYNLAZQU.js";
12
+ import "./chunk-LBPELU7L.js";
13
+ import "./chunk-SXAGSEKZ.js";
14
+ import "./chunk-MX3NFLCE.js";
15
+ import "./chunk-ASMHEEKY.js";
16
+ import {
17
+ createUsageError
18
+ } from "./chunk-IPE7TF2P.js";
19
+ import "./chunk-STGGGVYT.js";
20
+ import "./chunk-3ILXPKSJ.js";
21
+ import "./chunk-TBUCZX4A.js";
22
+ import "./chunk-Y2KL55OG.js";
23
+ import "./chunk-5SWZDVOW.js";
24
+ import "./chunk-S6S2UP6U.js";
25
+ import "./chunk-S5KZQJJI.js";
26
+ import "./chunk-KZ2IXVQT.js";
27
+ import "./chunk-WHQZBUNY.js";
28
+ import "./chunk-FUSXMW3G.js";
29
+
30
+ // src/cli/commands/interact/pointer-drag.ts
31
+ async function runPointerDrag(args) {
32
+ const sessionId = parseOptionalStringFlag(args.rawArgs, "--session-id");
33
+ const targetId = parseOptionalStringFlag(args.rawArgs, "--target-id");
34
+ const fromX = requirePointerCoordinate(args.rawArgs, "--from-x");
35
+ const fromY = requirePointerCoordinate(args.rawArgs, "--from-y");
36
+ const toX = requirePointerCoordinate(args.rawArgs, "--to-x");
37
+ const toY = requirePointerCoordinate(args.rawArgs, "--to-y");
38
+ const steps = parsePointerSteps(args.rawArgs);
39
+ if (!sessionId) {
40
+ throw createUsageError("Missing --session-id");
41
+ }
42
+ const result = await callDaemon("pointer.drag", {
43
+ sessionId,
44
+ from: { x: fromX, y: fromY },
45
+ to: { x: toX, y: toY },
46
+ ...typeof steps === "number" ? { steps } : {},
47
+ ...typeof targetId === "string" ? { targetId } : {}
48
+ });
49
+ return { success: true, message: "Pointer drag complete.", data: result };
50
+ }
51
+ export {
52
+ runPointerDrag
53
+ };
54
+ //# sourceMappingURL=pointer-drag-LVEAVJO4.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/cli/commands/interact/pointer-drag.ts"],"sourcesContent":["import type { ParsedArgs } from \"../../args\";\nimport { callDaemon } from \"../../client\";\nimport { createUsageError } from \"../../errors\";\nimport { parseOptionalStringFlag } from \"../../utils/parse\";\nimport { parsePointerSteps, requirePointerCoordinate } from \"./pointer-shared\";\n\nexport async function runPointerDrag(args: ParsedArgs) {\n const sessionId = parseOptionalStringFlag(args.rawArgs, \"--session-id\");\n const targetId = parseOptionalStringFlag(args.rawArgs, \"--target-id\");\n const fromX = requirePointerCoordinate(args.rawArgs, \"--from-x\");\n const fromY = requirePointerCoordinate(args.rawArgs, \"--from-y\");\n const toX = requirePointerCoordinate(args.rawArgs, \"--to-x\");\n const toY = requirePointerCoordinate(args.rawArgs, \"--to-y\");\n const steps = parsePointerSteps(args.rawArgs);\n\n if (!sessionId) {\n throw createUsageError(\"Missing --session-id\");\n }\n\n const result = await callDaemon(\"pointer.drag\", {\n sessionId,\n from: { x: fromX, y: fromY },\n to: { x: toX, y: toY },\n ...(typeof steps === \"number\" ? { steps } : {}),\n ...(typeof targetId === \"string\" ? { targetId } : {})\n });\n return { success: true, message: \"Pointer drag complete.\", data: result };\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAMA,eAAsB,eAAe,MAAkB;AACrD,QAAM,YAAY,wBAAwB,KAAK,SAAS,cAAc;AACtE,QAAM,WAAW,wBAAwB,KAAK,SAAS,aAAa;AACpE,QAAM,QAAQ,yBAAyB,KAAK,SAAS,UAAU;AAC/D,QAAM,QAAQ,yBAAyB,KAAK,SAAS,UAAU;AAC/D,QAAM,MAAM,yBAAyB,KAAK,SAAS,QAAQ;AAC3D,QAAM,MAAM,yBAAyB,KAAK,SAAS,QAAQ;AAC3D,QAAM,QAAQ,kBAAkB,KAAK,OAAO;AAE5C,MAAI,CAAC,WAAW;AACd,UAAM,iBAAiB,sBAAsB;AAAA,EAC/C;AAEA,QAAM,SAAS,MAAM,WAAW,gBAAgB;AAAA,IAC9C;AAAA,IACA,MAAM,EAAE,GAAG,OAAO,GAAG,MAAM;AAAA,IAC3B,IAAI,EAAE,GAAG,KAAK,GAAG,IAAI;AAAA,IACrB,GAAI,OAAO,UAAU,WAAW,EAAE,MAAM,IAAI,CAAC;AAAA,IAC7C,GAAI,OAAO,aAAa,WAAW,EAAE,SAAS,IAAI,CAAC;AAAA,EACrD,CAAC;AACD,SAAO,EAAE,SAAS,MAAM,SAAS,0BAA0B,MAAM,OAAO;AAC1E;","names":[]}
@@ -0,0 +1,52 @@
1
+ import {
2
+ parsePointerSteps,
3
+ requirePointerCoordinate
4
+ } from "./chunk-T4GMCW6Z.js";
5
+ import "./chunk-RJNI3BHT.js";
6
+ import {
7
+ parseOptionalStringFlag
8
+ } from "./chunk-RPXWUCQQ.js";
9
+ import {
10
+ callDaemon
11
+ } from "./chunk-OYNLAZQU.js";
12
+ import "./chunk-LBPELU7L.js";
13
+ import "./chunk-SXAGSEKZ.js";
14
+ import "./chunk-MX3NFLCE.js";
15
+ import "./chunk-ASMHEEKY.js";
16
+ import {
17
+ createUsageError
18
+ } from "./chunk-IPE7TF2P.js";
19
+ import "./chunk-STGGGVYT.js";
20
+ import "./chunk-3ILXPKSJ.js";
21
+ import "./chunk-TBUCZX4A.js";
22
+ import "./chunk-Y2KL55OG.js";
23
+ import "./chunk-5SWZDVOW.js";
24
+ import "./chunk-S6S2UP6U.js";
25
+ import "./chunk-S5KZQJJI.js";
26
+ import "./chunk-KZ2IXVQT.js";
27
+ import "./chunk-WHQZBUNY.js";
28
+ import "./chunk-FUSXMW3G.js";
29
+
30
+ // src/cli/commands/interact/pointer-move.ts
31
+ async function runPointerMove(args) {
32
+ const sessionId = parseOptionalStringFlag(args.rawArgs, "--session-id");
33
+ const targetId = parseOptionalStringFlag(args.rawArgs, "--target-id");
34
+ const x = requirePointerCoordinate(args.rawArgs, "--x");
35
+ const y = requirePointerCoordinate(args.rawArgs, "--y");
36
+ const steps = parsePointerSteps(args.rawArgs);
37
+ if (!sessionId) {
38
+ throw createUsageError("Missing --session-id");
39
+ }
40
+ const result = await callDaemon("pointer.move", {
41
+ sessionId,
42
+ x,
43
+ y,
44
+ ...typeof steps === "number" ? { steps } : {},
45
+ ...typeof targetId === "string" ? { targetId } : {}
46
+ });
47
+ return { success: true, message: "Pointer move complete.", data: result };
48
+ }
49
+ export {
50
+ runPointerMove
51
+ };
52
+ //# sourceMappingURL=pointer-move-7SRKUS66.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/cli/commands/interact/pointer-move.ts"],"sourcesContent":["import type { ParsedArgs } from \"../../args\";\nimport { callDaemon } from \"../../client\";\nimport { createUsageError } from \"../../errors\";\nimport { parseOptionalStringFlag } from \"../../utils/parse\";\nimport { parsePointerSteps, requirePointerCoordinate } from \"./pointer-shared\";\n\nexport async function runPointerMove(args: ParsedArgs) {\n const sessionId = parseOptionalStringFlag(args.rawArgs, \"--session-id\");\n const targetId = parseOptionalStringFlag(args.rawArgs, \"--target-id\");\n const x = requirePointerCoordinate(args.rawArgs, \"--x\");\n const y = requirePointerCoordinate(args.rawArgs, \"--y\");\n const steps = parsePointerSteps(args.rawArgs);\n\n if (!sessionId) {\n throw createUsageError(\"Missing --session-id\");\n }\n\n const result = await callDaemon(\"pointer.move\", {\n sessionId,\n x,\n y,\n ...(typeof steps === \"number\" ? { steps } : {}),\n ...(typeof targetId === \"string\" ? { targetId } : {})\n });\n return { success: true, message: \"Pointer move complete.\", data: result };\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAMA,eAAsB,eAAe,MAAkB;AACrD,QAAM,YAAY,wBAAwB,KAAK,SAAS,cAAc;AACtE,QAAM,WAAW,wBAAwB,KAAK,SAAS,aAAa;AACpE,QAAM,IAAI,yBAAyB,KAAK,SAAS,KAAK;AACtD,QAAM,IAAI,yBAAyB,KAAK,SAAS,KAAK;AACtD,QAAM,QAAQ,kBAAkB,KAAK,OAAO;AAE5C,MAAI,CAAC,WAAW;AACd,UAAM,iBAAiB,sBAAsB;AAAA,EAC/C;AAEA,QAAM,SAAS,MAAM,WAAW,gBAAgB;AAAA,IAC9C;AAAA,IACA;AAAA,IACA;AAAA,IACA,GAAI,OAAO,UAAU,WAAW,EAAE,MAAM,IAAI,CAAC;AAAA,IAC7C,GAAI,OAAO,aAAa,WAAW,EAAE,SAAS,IAAI,CAAC;AAAA,EACrD,CAAC;AACD,SAAO,EAAE,SAAS,MAAM,SAAS,0BAA0B,MAAM,OAAO;AAC1E;","names":[]}
@@ -0,0 +1,55 @@
1
+ import {
2
+ parsePointerButton,
3
+ parsePointerClickCount,
4
+ requirePointerCoordinate
5
+ } from "./chunk-T4GMCW6Z.js";
6
+ import "./chunk-RJNI3BHT.js";
7
+ import {
8
+ parseOptionalStringFlag
9
+ } from "./chunk-RPXWUCQQ.js";
10
+ import {
11
+ callDaemon
12
+ } from "./chunk-OYNLAZQU.js";
13
+ import "./chunk-LBPELU7L.js";
14
+ import "./chunk-SXAGSEKZ.js";
15
+ import "./chunk-MX3NFLCE.js";
16
+ import "./chunk-ASMHEEKY.js";
17
+ import {
18
+ createUsageError
19
+ } from "./chunk-IPE7TF2P.js";
20
+ import "./chunk-STGGGVYT.js";
21
+ import "./chunk-3ILXPKSJ.js";
22
+ import "./chunk-TBUCZX4A.js";
23
+ import "./chunk-Y2KL55OG.js";
24
+ import "./chunk-5SWZDVOW.js";
25
+ import "./chunk-S6S2UP6U.js";
26
+ import "./chunk-S5KZQJJI.js";
27
+ import "./chunk-KZ2IXVQT.js";
28
+ import "./chunk-WHQZBUNY.js";
29
+ import "./chunk-FUSXMW3G.js";
30
+
31
+ // src/cli/commands/interact/pointer-up.ts
32
+ async function runPointerUp(args) {
33
+ const sessionId = parseOptionalStringFlag(args.rawArgs, "--session-id");
34
+ const targetId = parseOptionalStringFlag(args.rawArgs, "--target-id");
35
+ const x = requirePointerCoordinate(args.rawArgs, "--x");
36
+ const y = requirePointerCoordinate(args.rawArgs, "--y");
37
+ const button = parsePointerButton(args.rawArgs);
38
+ const clickCount = parsePointerClickCount(args.rawArgs);
39
+ if (!sessionId) {
40
+ throw createUsageError("Missing --session-id");
41
+ }
42
+ const result = await callDaemon("pointer.up", {
43
+ sessionId,
44
+ x,
45
+ y,
46
+ ...typeof button === "string" ? { button } : {},
47
+ ...typeof clickCount === "number" ? { clickCount } : {},
48
+ ...typeof targetId === "string" ? { targetId } : {}
49
+ });
50
+ return { success: true, message: "Pointer up complete.", data: result };
51
+ }
52
+ export {
53
+ runPointerUp
54
+ };
55
+ //# sourceMappingURL=pointer-up-KLDBSK37.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/cli/commands/interact/pointer-up.ts"],"sourcesContent":["import type { ParsedArgs } from \"../../args\";\nimport { callDaemon } from \"../../client\";\nimport { createUsageError } from \"../../errors\";\nimport { parseOptionalStringFlag } from \"../../utils/parse\";\nimport {\n parsePointerButton,\n parsePointerClickCount,\n requirePointerCoordinate\n} from \"./pointer-shared\";\n\nexport async function runPointerUp(args: ParsedArgs) {\n const sessionId = parseOptionalStringFlag(args.rawArgs, \"--session-id\");\n const targetId = parseOptionalStringFlag(args.rawArgs, \"--target-id\");\n const x = requirePointerCoordinate(args.rawArgs, \"--x\");\n const y = requirePointerCoordinate(args.rawArgs, \"--y\");\n const button = parsePointerButton(args.rawArgs);\n const clickCount = parsePointerClickCount(args.rawArgs);\n\n if (!sessionId) {\n throw createUsageError(\"Missing --session-id\");\n }\n\n const result = await callDaemon(\"pointer.up\", {\n sessionId,\n x,\n y,\n ...(typeof button === \"string\" ? { button } : {}),\n ...(typeof clickCount === \"number\" ? { clickCount } : {}),\n ...(typeof targetId === \"string\" ? { targetId } : {})\n });\n return { success: true, message: \"Pointer up complete.\", data: result };\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAUA,eAAsB,aAAa,MAAkB;AACnD,QAAM,YAAY,wBAAwB,KAAK,SAAS,cAAc;AACtE,QAAM,WAAW,wBAAwB,KAAK,SAAS,aAAa;AACpE,QAAM,IAAI,yBAAyB,KAAK,SAAS,KAAK;AACtD,QAAM,IAAI,yBAAyB,KAAK,SAAS,KAAK;AACtD,QAAM,SAAS,mBAAmB,KAAK,OAAO;AAC9C,QAAM,aAAa,uBAAuB,KAAK,OAAO;AAEtD,MAAI,CAAC,WAAW;AACd,UAAM,iBAAiB,sBAAsB;AAAA,EAC/C;AAEA,QAAM,SAAS,MAAM,WAAW,cAAc;AAAA,IAC5C;AAAA,IACA;AAAA,IACA;AAAA,IACA,GAAI,OAAO,WAAW,WAAW,EAAE,OAAO,IAAI,CAAC;AAAA,IAC/C,GAAI,OAAO,eAAe,WAAW,EAAE,WAAW,IAAI,CAAC;AAAA,IACvD,GAAI,OAAO,aAAa,WAAW,EAAE,SAAS,IAAI,CAAC;AAAA,EACrD,CAAC;AACD,SAAO,EAAE,SAAS,MAAM,SAAS,wBAAwB,MAAM,OAAO;AACxE;","names":[]}
@@ -0,0 +1,83 @@
1
+ import "./chunk-RJNI3BHT.js";
2
+ import {
3
+ parseOptionalStringFlag
4
+ } from "./chunk-RPXWUCQQ.js";
5
+ import {
6
+ callDaemon
7
+ } from "./chunk-OYNLAZQU.js";
8
+ import "./chunk-LBPELU7L.js";
9
+ import "./chunk-SXAGSEKZ.js";
10
+ import "./chunk-MX3NFLCE.js";
11
+ import "./chunk-ASMHEEKY.js";
12
+ import {
13
+ createUsageError
14
+ } from "./chunk-IPE7TF2P.js";
15
+ import "./chunk-STGGGVYT.js";
16
+ import "./chunk-3ILXPKSJ.js";
17
+ import "./chunk-TBUCZX4A.js";
18
+ import "./chunk-Y2KL55OG.js";
19
+ import "./chunk-5SWZDVOW.js";
20
+ import "./chunk-S6S2UP6U.js";
21
+ import "./chunk-S5KZQJJI.js";
22
+ import "./chunk-KZ2IXVQT.js";
23
+ import "./chunk-WHQZBUNY.js";
24
+ import "./chunk-FUSXMW3G.js";
25
+
26
+ // src/cli/commands/interact/press.ts
27
+ function parsePressArgs(rawArgs) {
28
+ const parsed = {};
29
+ for (let i = 0; i < rawArgs.length; i += 1) {
30
+ const arg = rawArgs[i];
31
+ if (arg === "--session-id") {
32
+ const value = rawArgs[i + 1];
33
+ if (!value) throw createUsageError("Missing value for --session-id");
34
+ parsed.sessionId = value;
35
+ i += 1;
36
+ continue;
37
+ }
38
+ if (arg?.startsWith("--session-id=")) {
39
+ parsed.sessionId = arg.split("=", 2)[1];
40
+ continue;
41
+ }
42
+ if (arg === "--key") {
43
+ const value = rawArgs[i + 1];
44
+ if (!value) throw createUsageError("Missing value for --key");
45
+ parsed.key = value;
46
+ i += 1;
47
+ continue;
48
+ }
49
+ if (arg?.startsWith("--key=")) {
50
+ parsed.key = arg.split("=", 2)[1];
51
+ continue;
52
+ }
53
+ if (arg === "--ref") {
54
+ const value = rawArgs[i + 1];
55
+ if (!value) throw createUsageError("Missing value for --ref");
56
+ parsed.ref = value;
57
+ i += 1;
58
+ continue;
59
+ }
60
+ if (arg?.startsWith("--ref=")) {
61
+ parsed.ref = arg.split("=", 2)[1];
62
+ continue;
63
+ }
64
+ }
65
+ return parsed;
66
+ }
67
+ async function runPress(args) {
68
+ const { sessionId, key, ref } = parsePressArgs(args.rawArgs);
69
+ const targetId = parseOptionalStringFlag(args.rawArgs, "--target-id");
70
+ if (!sessionId) throw createUsageError("Missing --session-id");
71
+ if (!key) throw createUsageError("Missing --key");
72
+ const result = await callDaemon("interact.press", {
73
+ sessionId,
74
+ key,
75
+ ref,
76
+ ...typeof targetId === "string" ? { targetId } : {}
77
+ });
78
+ return { success: true, message: "Key press complete.", data: result };
79
+ }
80
+ export {
81
+ runPress
82
+ };
83
+ //# sourceMappingURL=press-UIIXFTD7.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/cli/commands/interact/press.ts"],"sourcesContent":["import type { ParsedArgs } from \"../../args\";\nimport { callDaemon } from \"../../client\";\nimport { createUsageError } from \"../../errors\";\nimport { parseOptionalStringFlag } from \"../../utils/parse\";\n\nfunction parsePressArgs(rawArgs: string[]): { sessionId?: string; key?: string; ref?: string } {\n const parsed: { sessionId?: string; key?: string; ref?: string } = {};\n for (let i = 0; i < rawArgs.length; i += 1) {\n const arg = rawArgs[i];\n if (arg === \"--session-id\") {\n const value = rawArgs[i + 1];\n if (!value) throw createUsageError(\"Missing value for --session-id\");\n parsed.sessionId = value;\n i += 1;\n continue;\n }\n if (arg?.startsWith(\"--session-id=\")) {\n parsed.sessionId = arg.split(\"=\", 2)[1];\n continue;\n }\n if (arg === \"--key\") {\n const value = rawArgs[i + 1];\n if (!value) throw createUsageError(\"Missing value for --key\");\n parsed.key = value;\n i += 1;\n continue;\n }\n if (arg?.startsWith(\"--key=\")) {\n parsed.key = arg.split(\"=\", 2)[1];\n continue;\n }\n if (arg === \"--ref\") {\n const value = rawArgs[i + 1];\n if (!value) throw createUsageError(\"Missing value for --ref\");\n parsed.ref = value;\n i += 1;\n continue;\n }\n if (arg?.startsWith(\"--ref=\")) {\n parsed.ref = arg.split(\"=\", 2)[1];\n continue;\n }\n }\n return parsed;\n}\n\nexport async function runPress(args: ParsedArgs) {\n const { sessionId, key, ref } = parsePressArgs(args.rawArgs);\n const targetId = parseOptionalStringFlag(args.rawArgs, \"--target-id\");\n if (!sessionId) throw createUsageError(\"Missing --session-id\");\n if (!key) throw createUsageError(\"Missing --key\");\n const result = await callDaemon(\"interact.press\", {\n sessionId,\n key,\n ref,\n ...(typeof targetId === \"string\" ? { targetId } : {})\n });\n return { success: true, message: \"Key press complete.\", data: result };\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAKA,SAAS,eAAe,SAAuE;AAC7F,QAAM,SAA6D,CAAC;AACpE,WAAS,IAAI,GAAG,IAAI,QAAQ,QAAQ,KAAK,GAAG;AAC1C,UAAM,MAAM,QAAQ,CAAC;AACrB,QAAI,QAAQ,gBAAgB;AAC1B,YAAM,QAAQ,QAAQ,IAAI,CAAC;AAC3B,UAAI,CAAC,MAAO,OAAM,iBAAiB,gCAAgC;AACnE,aAAO,YAAY;AACnB,WAAK;AACL;AAAA,IACF;AACA,QAAI,KAAK,WAAW,eAAe,GAAG;AACpC,aAAO,YAAY,IAAI,MAAM,KAAK,CAAC,EAAE,CAAC;AACtC;AAAA,IACF;AACA,QAAI,QAAQ,SAAS;AACnB,YAAM,QAAQ,QAAQ,IAAI,CAAC;AAC3B,UAAI,CAAC,MAAO,OAAM,iBAAiB,yBAAyB;AAC5D,aAAO,MAAM;AACb,WAAK;AACL;AAAA,IACF;AACA,QAAI,KAAK,WAAW,QAAQ,GAAG;AAC7B,aAAO,MAAM,IAAI,MAAM,KAAK,CAAC,EAAE,CAAC;AAChC;AAAA,IACF;AACA,QAAI,QAAQ,SAAS;AACnB,YAAM,QAAQ,QAAQ,IAAI,CAAC;AAC3B,UAAI,CAAC,MAAO,OAAM,iBAAiB,yBAAyB;AAC5D,aAAO,MAAM;AACb,WAAK;AACL;AAAA,IACF;AACA,QAAI,KAAK,WAAW,QAAQ,GAAG;AAC7B,aAAO,MAAM,IAAI,MAAM,KAAK,CAAC,EAAE,CAAC;AAChC;AAAA,IACF;AAAA,EACF;AACA,SAAO;AACT;AAEA,eAAsB,SAAS,MAAkB;AAC/C,QAAM,EAAE,WAAW,KAAK,IAAI,IAAI,eAAe,KAAK,OAAO;AAC3D,QAAM,WAAW,wBAAwB,KAAK,SAAS,aAAa;AACpE,MAAI,CAAC,UAAW,OAAM,iBAAiB,sBAAsB;AAC7D,MAAI,CAAC,IAAK,OAAM,iBAAiB,eAAe;AAChD,QAAM,SAAS,MAAM,WAAW,kBAAkB;AAAA,IAChD;AAAA,IACA;AAAA,IACA;AAAA,IACA,GAAI,OAAO,aAAa,WAAW,EAAE,SAAS,IAAI,CAAC;AAAA,EACrD,CAAC;AACD,SAAO,EAAE,SAAS,MAAM,SAAS,uBAAuB,MAAM,OAAO;AACvE;","names":[]}
@@ -0,0 +1,235 @@
1
+ import {
2
+ resolveWorkflowOutputDirFlag
3
+ } from "./chunk-PDPJN2OP.js";
4
+ import "./chunk-RJNI3BHT.js";
5
+ import {
6
+ parseNumberFlag
7
+ } from "./chunk-RPXWUCQQ.js";
8
+ import {
9
+ DEFAULT_WORKFLOW_TRANSPORT_TIMEOUT_MS
10
+ } from "./chunk-OW5HMYMI.js";
11
+ import {
12
+ callDaemon
13
+ } from "./chunk-OYNLAZQU.js";
14
+ import "./chunk-LBPELU7L.js";
15
+ import "./chunk-SXAGSEKZ.js";
16
+ import "./chunk-MX3NFLCE.js";
17
+ import "./chunk-ASMHEEKY.js";
18
+ import {
19
+ buildWorkflowCompletionMessage
20
+ } from "./chunk-37VSRUW4.js";
21
+ import {
22
+ createUsageError
23
+ } from "./chunk-IPE7TF2P.js";
24
+ import "./chunk-STGGGVYT.js";
25
+ import "./chunk-3ILXPKSJ.js";
26
+ import "./chunk-TBUCZX4A.js";
27
+ import "./chunk-Y2KL55OG.js";
28
+ import "./chunk-5SWZDVOW.js";
29
+ import {
30
+ isChallengeAutomationMode
31
+ } from "./chunk-S6S2UP6U.js";
32
+ import "./chunk-S5KZQJJI.js";
33
+ import "./chunk-KZ2IXVQT.js";
34
+ import "./chunk-WHQZBUNY.js";
35
+ import "./chunk-FUSXMW3G.js";
36
+
37
+ // src/cli/commands/product-video.ts
38
+ var requireValue = (rawArgs, index, flag) => {
39
+ const value = rawArgs[index + 1];
40
+ if (!value) {
41
+ throw createUsageError(`Missing value for ${flag}`);
42
+ }
43
+ return value;
44
+ };
45
+ var parseBoolean = (value, flag) => {
46
+ if (value === "true") return true;
47
+ if (value === "false") return false;
48
+ throw createUsageError(`Invalid ${flag}: ${value}`);
49
+ };
50
+ var COOKIE_POLICY_VALUES = /* @__PURE__ */ new Set(["off", "auto", "required"]);
51
+ var BROWSER_MODE_VALUES = /* @__PURE__ */ new Set(["auto", "extension", "managed"]);
52
+ var parseProductVideoArgs = (rawArgs) => {
53
+ const parsed = {};
54
+ for (let index = 0; index < rawArgs.length; index += 1) {
55
+ const arg = rawArgs[index];
56
+ if (arg === "--product-url") {
57
+ parsed.productUrl = requireValue(rawArgs, index, "--product-url");
58
+ index += 1;
59
+ continue;
60
+ }
61
+ if (arg?.startsWith("--product-url=")) {
62
+ parsed.productUrl = arg.split("=", 2)[1];
63
+ continue;
64
+ }
65
+ if (arg === "--product-name") {
66
+ parsed.productName = requireValue(rawArgs, index, "--product-name");
67
+ index += 1;
68
+ continue;
69
+ }
70
+ if (arg?.startsWith("--product-name=")) {
71
+ parsed.productName = arg.split("=", 2)[1];
72
+ continue;
73
+ }
74
+ if (arg === "--provider-hint") {
75
+ parsed.providerHint = requireValue(rawArgs, index, "--provider-hint");
76
+ index += 1;
77
+ continue;
78
+ }
79
+ if (arg?.startsWith("--provider-hint=")) {
80
+ parsed.providerHint = arg.split("=", 2)[1];
81
+ continue;
82
+ }
83
+ if (arg === "--include-screenshots") {
84
+ parsed.includeScreenshots = true;
85
+ continue;
86
+ }
87
+ if (arg?.startsWith("--include-screenshots=")) {
88
+ parsed.includeScreenshots = parseBoolean(arg.split("=", 2)[1] ?? "", "--include-screenshots");
89
+ continue;
90
+ }
91
+ if (arg === "--include-all-images") {
92
+ parsed.includeAllImages = true;
93
+ continue;
94
+ }
95
+ if (arg?.startsWith("--include-all-images=")) {
96
+ parsed.includeAllImages = parseBoolean(arg.split("=", 2)[1] ?? "", "--include-all-images");
97
+ continue;
98
+ }
99
+ if (arg === "--include-copy") {
100
+ parsed.includeCopy = true;
101
+ continue;
102
+ }
103
+ if (arg?.startsWith("--include-copy=")) {
104
+ parsed.includeCopy = parseBoolean(arg.split("=", 2)[1] ?? "", "--include-copy");
105
+ continue;
106
+ }
107
+ if (arg === "--output-dir") {
108
+ parsed.outputDir = resolveWorkflowOutputDirFlag(requireValue(rawArgs, index, "--output-dir"));
109
+ index += 1;
110
+ continue;
111
+ }
112
+ if (arg?.startsWith("--output-dir=")) {
113
+ parsed.outputDir = resolveWorkflowOutputDirFlag(arg.split("=", 2)[1]);
114
+ continue;
115
+ }
116
+ if (arg === "--ttl-hours") {
117
+ parsed.ttlHours = parseNumberFlag(requireValue(rawArgs, index, "--ttl-hours"), "--ttl-hours", { min: 1, max: 168 });
118
+ index += 1;
119
+ continue;
120
+ }
121
+ if (arg?.startsWith("--ttl-hours=")) {
122
+ parsed.ttlHours = parseNumberFlag(arg.split("=", 2)[1] ?? "", "--ttl-hours", { min: 1, max: 168 });
123
+ continue;
124
+ }
125
+ if (arg === "--timeout-ms") {
126
+ parsed.timeoutMs = parseNumberFlag(requireValue(rawArgs, index, "--timeout-ms"), "--timeout-ms", { min: 1 });
127
+ index += 1;
128
+ continue;
129
+ }
130
+ if (arg?.startsWith("--timeout-ms=")) {
131
+ parsed.timeoutMs = parseNumberFlag(arg.split("=", 2)[1] ?? "", "--timeout-ms", { min: 1 });
132
+ continue;
133
+ }
134
+ if (arg === "--browser-mode") {
135
+ const value = requireValue(rawArgs, index, "--browser-mode").toLowerCase();
136
+ if (!BROWSER_MODE_VALUES.has(value)) {
137
+ throw createUsageError(`Invalid --browser-mode: ${value}`);
138
+ }
139
+ parsed.browserMode = value;
140
+ index += 1;
141
+ continue;
142
+ }
143
+ if (arg?.startsWith("--browser-mode=")) {
144
+ const value = (arg.split("=", 2)[1] ?? "").toLowerCase();
145
+ if (!BROWSER_MODE_VALUES.has(value)) {
146
+ throw createUsageError(`Invalid --browser-mode: ${value}`);
147
+ }
148
+ parsed.browserMode = value;
149
+ continue;
150
+ }
151
+ if (arg === "--use-cookies") {
152
+ parsed.useCookies = true;
153
+ continue;
154
+ }
155
+ if (arg?.startsWith("--use-cookies=")) {
156
+ parsed.useCookies = parseBoolean(arg.split("=", 2)[1] ?? "", "--use-cookies");
157
+ continue;
158
+ }
159
+ if (arg === "--challenge-automation-mode") {
160
+ const value = requireValue(rawArgs, index, "--challenge-automation-mode");
161
+ if (!isChallengeAutomationMode(value)) {
162
+ throw createUsageError(`Invalid --challenge-automation-mode: ${value}`);
163
+ }
164
+ parsed.challengeAutomationMode = value;
165
+ index += 1;
166
+ continue;
167
+ }
168
+ if (arg?.startsWith("--challenge-automation-mode=")) {
169
+ const value = arg.split("=", 2)[1] ?? "";
170
+ if (!isChallengeAutomationMode(value)) {
171
+ throw createUsageError(`Invalid --challenge-automation-mode: ${value}`);
172
+ }
173
+ parsed.challengeAutomationMode = value;
174
+ continue;
175
+ }
176
+ if (arg === "--cookie-policy-override" || arg === "--cookie-policy") {
177
+ const value = requireValue(rawArgs, index, arg).toLowerCase();
178
+ if (!COOKIE_POLICY_VALUES.has(value)) {
179
+ throw createUsageError(`Invalid ${arg}: ${value}`);
180
+ }
181
+ parsed.cookiePolicyOverride = value;
182
+ index += 1;
183
+ continue;
184
+ }
185
+ if (arg?.startsWith("--cookie-policy-override=") || arg?.startsWith("--cookie-policy=")) {
186
+ const value = (arg.split("=", 2)[1] ?? "").toLowerCase();
187
+ if (!COOKIE_POLICY_VALUES.has(value)) {
188
+ throw createUsageError(`Invalid --cookie-policy-override: ${value}`);
189
+ }
190
+ parsed.cookiePolicyOverride = value;
191
+ continue;
192
+ }
193
+ }
194
+ return parsed;
195
+ };
196
+ async function runProductVideoCommand(args) {
197
+ const [subcommand, ...rest] = args.rawArgs;
198
+ if (subcommand !== "run") {
199
+ throw createUsageError("Usage: opendevbrowser product-video run --product-url <url> | --product-name <name>");
200
+ }
201
+ const parsed = parseProductVideoArgs(rest);
202
+ if (!parsed.productUrl && !parsed.productName) {
203
+ throw createUsageError("Missing --product-url or --product-name");
204
+ }
205
+ const timeoutMs = parsed.timeoutMs ?? DEFAULT_WORKFLOW_TRANSPORT_TIMEOUT_MS;
206
+ const data = await callDaemon("product.video.run", {
207
+ product_url: parsed.productUrl,
208
+ product_name: parsed.productName,
209
+ provider_hint: parsed.providerHint,
210
+ include_screenshots: parsed.includeScreenshots,
211
+ include_all_images: parsed.includeAllImages,
212
+ include_copy: parsed.includeCopy,
213
+ output_dir: resolveWorkflowOutputDirFlag(parsed.outputDir),
214
+ ttl_hours: parsed.ttlHours,
215
+ timeoutMs,
216
+ browserMode: parsed.browserMode,
217
+ useCookies: parsed.useCookies,
218
+ challengeAutomationMode: parsed.challengeAutomationMode,
219
+ cookiePolicyOverride: parsed.cookiePolicyOverride
220
+ });
221
+ return {
222
+ success: true,
223
+ message: buildWorkflowCompletionMessage("Product video asset workflow", data),
224
+ data
225
+ };
226
+ }
227
+ var __test__ = {
228
+ parseProductVideoArgs,
229
+ parseBoolean
230
+ };
231
+ export {
232
+ __test__,
233
+ runProductVideoCommand
234
+ };
235
+ //# sourceMappingURL=product-video-PYOXJVAI.js.map