Pulled ALL skills from 15 source repositories: - anthropics/skills: 16 (docs, design, MCP, testing) - obra/superpowers: 14 (TDD, debugging, agents, planning) - coreyhaines31/marketingskills: 25 (marketing, CRO, SEO, growth) - better-auth/skills: 5 (auth patterns) - vercel-labs/agent-skills: 5 (React, design, Vercel) - antfu/skills: 16 (Vue, Vite, Vitest, pnpm, Turborepo) - Plus 13 individual skills from various repos Mosaic Stack is not limited to coding — the Orchestrator and subagents serve coding, business, design, marketing, writing, logistics, analysis, and more. Co-Authored-By: Claude Opus 4.6 <noreply@anthropic.com>
40 lines
1.4 KiB
Python
40 lines
1.4 KiB
Python
from playwright.sync_api import sync_playwright
|
|
|
|
# Example: Discovering buttons and other elements on a page
|
|
|
|
with sync_playwright() as p:
|
|
browser = p.chromium.launch(headless=True)
|
|
page = browser.new_page()
|
|
|
|
# Navigate to page and wait for it to fully load
|
|
page.goto('http://localhost:5173')
|
|
page.wait_for_load_state('networkidle')
|
|
|
|
# Discover all buttons on the page
|
|
buttons = page.locator('button').all()
|
|
print(f"Found {len(buttons)} buttons:")
|
|
for i, button in enumerate(buttons):
|
|
text = button.inner_text() if button.is_visible() else "[hidden]"
|
|
print(f" [{i}] {text}")
|
|
|
|
# Discover links
|
|
links = page.locator('a[href]').all()
|
|
print(f"\nFound {len(links)} links:")
|
|
for link in links[:5]: # Show first 5
|
|
text = link.inner_text().strip()
|
|
href = link.get_attribute('href')
|
|
print(f" - {text} -> {href}")
|
|
|
|
# Discover input fields
|
|
inputs = page.locator('input, textarea, select').all()
|
|
print(f"\nFound {len(inputs)} input fields:")
|
|
for input_elem in inputs:
|
|
name = input_elem.get_attribute('name') or input_elem.get_attribute('id') or "[unnamed]"
|
|
input_type = input_elem.get_attribute('type') or 'text'
|
|
print(f" - {name} ({input_type})")
|
|
|
|
# Take screenshot for visual reference
|
|
page.screenshot(path='/tmp/page_discovery.png', full_page=True)
|
|
print("\nScreenshot saved to /tmp/page_discovery.png")
|
|
|
|
browser.close() |