vibe-check
Browser automation for AI agents. Use when the user needs to navigate websites, read page content, fill forms, click elements, take screenshots, or manage browser tabs.
Install
mkdir -p .claude/skills/vibe-check && curl -L -o skill.zip "https://mcp.directory/api/skills/download/5292" && unzip -o skill.zip -d .claude/skills/vibe-check && rm skill.zipInstalls to .claude/skills/vibe-check
About this skill
Vibium Browser Automation — CLI Reference
The vibium CLI automates Chrome via the command line. The browser auto-launches on first use (daemon mode keeps it running between commands).
vibium go <url> && vibium map && vibium click @e1 && vibium map
Core Workflow
Every browser automation follows this pattern:
- Navigate:
vibium go <url> - Map:
vibium map(get element refs like@e1,@e2) - Interact: Use refs to click, fill, select — e.g.
vibium click @e1 - Re-map: After navigation or DOM changes, get fresh refs with
vibium map
Binary Resolution
Before running any commands, resolve the vibium binary path once:
- Try
vibiumdirectly (works if globally installed vianpm install -g vibium) - Fall back to
./clicker/bin/vibium(dev environment, in project root) - Fall back to
./node_modules/.bin/vibium(local npm install)
Run vibium --help (or the resolved path) to confirm. Use the resolved path for all subsequent commands.
Windows note: Use forward slashes in paths (e.g. ./clicker/bin/vibium.exe) and quote paths containing spaces.
Command Chaining
Chain commands with && to run them sequentially. The chain stops on first error:
vibium go https://example.com && vibium map && vibium click @e3 && vibium diff map
When to chain: Use && for sequences that should happen back-to-back (navigate → interact → verify). Run commands separately when you need to inspect output between steps.
When NOT to chain: Don't chain commands that depend on parsing the previous output (e.g. reading map output to decide what to click). Run those separately so you can analyze the result first.
Commands
Discovery
vibium map— map interactive elements with @refs (recommended before interacting)vibium map --selector "nav"— scope map to elements within a CSS subtreevibium diff map— compare current vs last map (see what changed)
Navigation
vibium go <url>— go to a pagevibium back— go back in historyvibium forward— go forward in historyvibium reload— reload the current pagevibium url— print current URLvibium title— print page title
Reading Content
vibium text— get all page textvibium text "<selector>"— get text of a specific elementvibium html— get page HTML (use--outerfor outerHTML)vibium find "<selector>"— find element, return@e1ref (clickable withvibium click @e1)vibium find "<selector>" --all— find all matching elements →@e1,@e2, ... (--limit N)vibium find text "Sign In"— find element by text content →@e1vibium find label "Email"— find input by label →@e1vibium find placeholder "Search"— find by placeholder →@e1vibium find testid "submit-btn"— find by data-testid →@e1vibium find xpath "//div[@class]"— find by XPath →@e1vibium find alt "Logo"— find by alt attribute →@e1vibium find title "Settings"— find by title attribute →@e1vibium find role <role>— find element by ARIA role →@e1(--namefor accessible name filter)vibium eval "<js>"— run JavaScript and print result (--stdinto read from stdin)vibium count "<selector>"— count matching elementsvibium screenshot -o file.png— capture screenshot (--full-page,--annotate)vibium a11y-tree— accessibility tree (--everythingfor all nodes)
Interaction
vibium click "<selector>"— click an element (also accepts@reffrom map)vibium dblclick "<selector>"— double-click an elementvibium type "<selector>" "<text>"— type into an input (appends to existing value)vibium fill "<selector>" "<text>"— clear field and type new text (replaces value)vibium press <key> [selector]— press a key on element or focused elementvibium focus "<selector>"— focus an elementvibium hover "<selector>"— hover over an elementvibium scroll [direction]— scroll page (--amount N,--selector)vibium scroll into-view "<selector>"— scroll element into view (centered)vibium keys "<combo>"— press keys (Enter, Control+a, Shift+Tab)vibium select "<selector>" "<value>"— pick a dropdown optionvibium check "<selector>"— check a checkbox/radio (idempotent)vibium uncheck "<selector>"— uncheck a checkbox (idempotent)
Mouse Primitives
vibium mouse click [x] [y]— click at coordinates or current position (--button 0|1|2)vibium mouse move <x> <y>— move mouse to coordinatesvibium mouse down— press mouse button (--button 0|1|2)vibium mouse up— release mouse button (--button 0|1|2)vibium drag "<source>" "<target>"— drag from one element to another
Element State
vibium value "<selector>"— get input/textarea/select valuevibium attr "<selector>" "<attribute>"— get HTML attribute valuevibium is visible "<selector>"— check if element is visible (true/false)vibium is enabled "<selector>"— check if element is enabled (true/false)vibium is checked "<selector>"— check if checkbox/radio is checked (true/false)vibium is actionable "<selector>"— check if element is actionable (true/false)
Waiting
vibium wait "<selector>"— wait for element (--state visible|hidden|attached,--timeout ms)vibium wait url "<pattern>"— wait until URL contains substring (--timeout ms)vibium wait load— wait until page is fully loaded (--timeout ms)vibium wait text "<text>"— wait until text appears on page (--timeout ms)vibium wait fn "<expression>"— wait until JS expression returns truthy (--timeout ms)vibium sleep <ms>— pause execution (max 30000ms)
Capture
vibium screenshot -o file.png— capture screenshot (--full-page,--annotate)vibium pdf -o file.pdf— save page as PDF
Dialogs
vibium dialog accept [text]— accept dialog (optionally with prompt text)vibium dialog dismiss— dismiss dialog
Emulation
vibium viewport— get current viewport dimensionsvibium viewport <width> <height>— set viewport size (--dprfor device pixel ratio)vibium window— get OS browser window dimensions and statevibium window <width> <height> [x] [y]— set window size and position (--state)vibium media— override CSS media features (--color-scheme,--reduced-motion,--forced-colors,--contrast,--media)vibium geolocation <lat> <lng>— override geolocation (--accuracy)vibium content "<html>"— replace page HTML (--stdinto read from stdin)
Frames
vibium frames— list all iframes on the pagevibium frame "<nameOrUrl>"— find a frame by name or URL substring
File Upload
vibium upload "<selector>" <files...>— set files on input[type=file]
Recording
vibium record start— start recording (--screenshots,--snapshots,--name)vibium record stop— stop recording and save ZIP (-o path)
Cookies
vibium cookies— list all cookiesvibium cookies <name> <value>— set a cookievibium cookies clear— clear all cookies
Storage State
vibium storage— export cookies + localStorage + sessionStorage (-o state.json)vibium storage restore <path>— restore state from JSON file
Downloads
vibium download dir <path>— set download directory
Pages
vibium pages— list open pagesvibium page new [url]— open new pagevibium page switch <index|url>— switch pagevibium page close [index]— close page
Debug
vibium highlight "<selector>"— highlight element visually (3 seconds)
Session
vibium start— start a local browser sessionvibium start <url>— start connected to a remote browservibium stop— stop the browser sessionvibium daemon start— start background browservibium daemon status— check if runningvibium daemon stop— stop daemon
Common Patterns
Ref-based workflow (recommended for AI)
vibium go https://example.com
vibium map
vibium click @e1
vibium map # re-map after interaction
Verify action worked
vibium map
vibium click @e3
vibium diff map # see what changed
Read a page
vibium go https://example.com && vibium text
Fill a form (end-to-end)
vibium go https://example.com/login
vibium map
# Look at map output to identify form fields
vibium fill @e1 "user@example.com"
vibium fill @e2 "secret"
vibium click @e3
vibium wait url "/dashboard"
vibium screenshot -o after-login.png
Scoped map (large pages)
vibium map --selector "nav" # Only map elements in <nav>
vibium map --selector "#sidebar" # Only map elements in #sidebar
vibium map --selector "form" # Only map form controls
Semantic find (no CSS selectors needed)
vibium find text "Sign In" # → @e1 [button] "Sign In"
vibium find label "Email" # → @e1 [input] placeholder="Email"
vibium click @e1 # Click the found element
vibium find placeholder "Search..." # → @e1 [input] placeholder="Search..."
vibium find testid "submit-btn" # → @e1 [button] "Submit"
vibium find alt "Company logo" # → @e1 [img] alt="Company logo"
vibium find title "Close" # → @e1 [button] title="Close"
vibium find xpath "//a[@href='/about']" # → @e1 [a] "About"
Authentication with state persistence
# Log in once and save state
vibium go https://app.example.com/login
vibium fill "input[name=email]" "user@example.com"
vibium fill "input[name=password]" "secret"
vibium click "button[type=submit]"
vibium wait url "/dashboard"
vibium storage -o auth.json
# Restore in a later session (skips login)
vibium storage restore auth.json
vibium go https://app.example.com/dashboard
Extract structured data
vibium go https://example.com
vibium eval "JSON.stringify([...document.querySelectorAll('a')].map(a => ({text: a.textContent.trim(), href: a.href})))"
C
Content truncated.
You might also like
flutter-development
aj-geddes
Build beautiful cross-platform mobile apps with Flutter and Dart. Covers widgets, state management with Provider/BLoC, navigation, API integration, and material design.
drawio-diagrams-enhanced
jgtolentino
Create professional draw.io (diagrams.net) diagrams in XML format (.drawio files) with integrated PMP/PMBOK methodologies, extensive visual asset libraries, and industry-standard professional templates. Use this skill when users ask to create flowcharts, swimlane diagrams, cross-functional flowcharts, org charts, network diagrams, UML diagrams, BPMN, project management diagrams (WBS, Gantt, PERT, RACI), risk matrices, stakeholder maps, or any other visual diagram in draw.io format. This skill includes access to custom shape libraries for icons, clipart, and professional symbols.
godot
bfollington
This skill should be used when working on Godot Engine projects. It provides specialized knowledge of Godot's file formats (.gd, .tscn, .tres), architecture patterns (component-based, signal-driven, resource-based), common pitfalls, validation tools, code templates, and CLI workflows. The `godot` command is available for running the game, validating scripts, importing resources, and exporting builds. Use this skill for tasks involving Godot game development, debugging scene/resource files, implementing game systems, or creating new Godot components.
ui-ux-pro-max
nextlevelbuilder
"UI/UX design intelligence. 50 styles, 21 palettes, 50 font pairings, 20 charts, 8 stacks (React, Next.js, Vue, Svelte, SwiftUI, React Native, Flutter, Tailwind). Actions: plan, build, create, design, implement, review, fix, improve, optimize, enhance, refactor, check UI/UX code. Projects: website, landing page, dashboard, admin panel, e-commerce, SaaS, portfolio, blog, mobile app, .html, .tsx, .vue, .svelte. Elements: button, modal, navbar, sidebar, card, table, form, chart. Styles: glassmorphism, claymorphism, minimalism, brutalism, neumorphism, bento grid, dark mode, responsive, skeuomorphism, flat design. Topics: color palette, accessibility, animation, layout, typography, font pairing, spacing, hover, shadow, gradient."
nano-banana-pro
garg-aayush
Generate and edit images using Google's Nano Banana Pro (Gemini 3 Pro Image) API. Use when the user asks to generate, create, edit, modify, change, alter, or update images. Also use when user references an existing image file and asks to modify it in any way (e.g., "modify this image", "change the background", "replace X with Y"). Supports both text-to-image generation and image-to-image editing with configurable resolution (1K default, 2K, or 4K for high resolution). DO NOT read the image file first - use this skill directly with the --input-image parameter.
fastapi-templates
wshobson
Create production-ready FastAPI projects with async patterns, dependency injection, and comprehensive error handling. Use when building new FastAPI applications or setting up backend API projects.
Related MCP Servers
Browse all serversEnhance software testing with Playwright MCP: Fast, reliable browser automation, an innovative alternative to Selenium s
Browser Use lets LLMs and agents access and scrape any website in real time, making web scraping and web page scraping e
Supercharge browser tasks with Browser MCP—AI-driven, local browser automation for powerful, private testing. Inspired b
Supercharge your NextJS projects with AI-powered tools for diagnostics, upgrades, and docs. Accelerate development and b
Empower AI agents for efficient API automation in Postman for API testing. Streamline workflows and boost productivity w
DebuggAI enables zero-config end to end testing for web applications, offering secure tunnels, easy setup, and detailed
Stay ahead of the MCP ecosystem
Get weekly updates on new skills and servers.