skills/macpilot-ui-inspector/SKILL.md
Inspect and interact with macOS UI elements using MacPilot accessibility APIs. Find buttons, text fields, labels, and other elements by role, label, or position, then click, read, or modify them.
npx skillsauth add adhikjoshi/macpilot-skills macpilot-ui-inspectorInstall this skill globally with one command. Works with Claude Code, Cursor, and Windsurf.
3 of 9 scanners reported clean
Some scanners were skipped, did not run, or reported a non-clean status. Review each row below.
Use MacPilot's accessibility (AX) commands to inspect, find, and interact with UI elements in any macOS application. This skill enables precise programmatic control of app interfaces.
Use this skill when the user asks to:
macpilot ui list --app "Safari" --json # All elements
macpilot ui list --app "Safari" --role AXButton --json # Only buttons
macpilot ui list --app "Safari" --depth 5 --json # Deeper scan
macpilot ui list --app "Safari" --hierarchy --json # With hierarchy
macpilot ui find "Save" --app "TextEdit" --json # Find by label
macpilot ui find "Save" --role AXButton --json # Filter by role
macpilot ui find "Save" --exact --json # Exact match only
macpilot ui find-text "Submit" --app "Safari" --json
# Returns: position {x, y}, size {w, h} - use for clicking
macpilot ui click "Save" --app "TextEdit" --json
macpilot ui click "Cancel" --role AXButton --json
macpilot ui get-value "Search" --app "Safari" --json # Read field value
macpilot ui set-value "Search" "query text" --app "Safari" # Set field value
macpilot ui set-value "Dark Mode" "1" --role AXCheckBox # Toggle checkbox
macpilot ui set-focus "Search" --app "Safari" --json # Focus an element
macpilot ui scroll "content" down 5 --app "Safari" # Scroll element
macpilot ui attributes "Save" --app "TextEdit" --json # All AX attributes
macpilot ui elements-at 500 300 --json # What's at x=500 y=300
macpilot ui elements-at 500 300 --radius 50 --json # Search wider area
macpilot ui tree --app "Finder" --json # Full AX tree
macpilot ui tree --app "Finder" --depth 3 --json # Limit depth
macpilot ui shortcuts --app "Safari" --json # All shortcuts
macpilot ui shortcuts --app "Safari" --menu File --json # Menu-specific
macpilot wait element "Download Complete" --app "Safari" --timeout 30 --json
| Role | Description |
|------|-------------|
| AXButton | Buttons (push, toggle) |
| AXTextField | Text input fields |
| AXTextArea | Multi-line text areas |
| AXStaticText | Labels and display text |
| AXCheckBox | Checkboxes and toggles |
| AXRadioButton | Radio buttons |
| AXPopUpButton | Dropdown menus |
| AXComboBox | Combo boxes |
| AXTable | Tables and lists |
| AXRow | Table/list rows |
| AXMenuItem | Menu items |
| AXToolbar | Toolbars |
| AXScrollArea | Scrollable regions |
| AXWindow | Windows |
| AXSheet | Modal sheets |
| AXImage | Images |
| AXLink | Hyperlinks |
| AXGroup | Generic container |
# Always focus app first
macpilot app focus "Safari"
# Find the element to verify it exists
macpilot ui find "Downloads" --app "Safari" --role AXButton --json
# Click it
macpilot ui click "Downloads" --app "Safari"
macpilot app focus "System Settings"
macpilot ui get-value "Computer Name" --app "System Settings" --json
macpilot app focus "MyApp"
macpilot ui set-value "Name" "John Doe" --app "MyApp"
macpilot ui set-value "Email" "[email protected]" --app "MyApp"
macpilot ui click "Submit" --app "MyApp"
# Start with a broad scan
macpilot ui tree --app "SomeApp" --depth 2 --json
# Narrow down to specific elements
macpilot ui list --app "SomeApp" --role AXButton --json
# Inspect a specific element
macpilot ui attributes "Settings" --app "SomeApp" --json
# When label-based clicking fails, find coordinates first
macpilot ui find-text "Submit" --app "MyApp" --json
# Use returned x,y to click
macpilot click 450 320
macpilot app focus before any UI interaction--json output for reliable parsing of element propertiesui click fails, fall back to ui find-text + macpilot click x yui tree --depth 2 first to understand app structure before deep scans--role filter significantly speeds up element searches in complex appstools
Manage macOS windows with MacPilot. List, move, resize, snap, minimize, fullscreen, and arrange application windows. Supports multi-display and Spaces.
content-media
Capture screenshots and extract text via OCR using MacPilot. Take full-screen, region, or window screenshots, and recognize text in images or screen areas with multi-language support.
tools
Handle macOS file dialogs (Open, Save, Print) with MacPilot. Navigate folders, select files, set filenames, and dismiss dialogs programmatically in any application.
tools
Core macOS automation skill using MacPilot CLI. Enables Claude Code to control apps, type text, click elements, run shell commands, and automate workflows on macOS via the `macpilot` command.