a03675113a
- .claude/agents/fn-orquestador/SKILL.md - .claude/commands/fn_claude.md - .claude/rules/INDEX.md - .claude/rules/cpp_apps.md - .claude/rules/ids_naming.md - CHANGELOG.md - apps/dag_engine/README.md - apps/dag_engine/api.go - apps/dag_engine/dags_migrated/example.yaml - apps/dag_engine/dags_migrated/example_lineage_tracking.yaml - ... Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2.2 KiB
2.2 KiB
name, kind, lang, domain, version, purity, signature, description, tags, uses_functions, uses_types, returns, returns_optional, error_type, file_path, params, output, example
| name | kind | lang | domain | version | purity | signature | description | tags | uses_functions | uses_types | returns | returns_optional | error_type | file_path | params | output | example | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| cdp_pick_element_js | function | js | browser | 1.0.0 | pure | (self-executing IIFE injected via CDP Runtime.evaluate) | Snippet JS inyectable que activa modo click-to-pick en una pagina Chrome remota: hover muestra overlay rojo, click captura CSS selector + XPath + tag + texto + bbox y los emite por console.log con prefijo '__fn_picked__'. El caller (navegator_dashboard) lee via CDP Runtime.consoleAPICalled. |
|
false | functions/browser/cdp_pick_element_js.js |
|
Mensaje en console.log con prefijo `__fn_picked__` seguido de JSON {selector,xpath,tag,text,attrs,rect}. Si user pulsa Escape: {cancelled: true}. | # En navegator_dashboard, al pulsar boton "Pick": # 1. Lee el archivo cdp_pick_element_js.js (string). # 2. Envia via WebSocket CDP al tab activo: # {"id": N, "method": "Runtime.evaluate", "params": {"expression": "<contenido del .js>"}} # 3. Escucha eventos "Runtime.consoleAPICalled" filtrando args[0].value == "__fn_picked__". # 4. Parsea args[1].value como JSON -> dict con selector/xpath/tag/text/attrs/rect. |
Cuando usarla
Cuando un user pulsa "Pick element" en un tab de Chrome remoto para capturar un selector robusto sin abrir DevTools. Salida usable en recipes YAML o tests.
Gotchas
- Idempotente: re-inyectar limpia overlay anterior.
- Path CSS truncado a 6 niveles para evitar selectores fragiles cross-rerender.
- Filtra clases dinamicas comunes (
active,hover,selected...) que rotan. - No funciona sobre iframes anidados — solo top frame.
- Escape cancela y emite
{cancelled: true}. - El listener captura events en fase capture para preceder a handlers de la pagina.
Notas
Reutilizable en otras apps C++/Python que hablen CDP. La salida via console.log es preferible a Runtime.evaluate con returnByValue=true porque el pick es asincrono (espera click del user) y no encaja en una sola RPC.