Computer Use x Playwright SDK
npm install @onkernel/cu-playwrightA TypeScript SDK that combines Anthropic's Computer Use capabilities with Playwright for browser automation tasks. This SDK provides a clean, type-safe interface for automating browser interactions using Claude's computer use abilities.
- š¤ Simple API: Single ComputerUseAgent class for all computer use tasks
- š Dual Response Types: Support for both text and structured (JSON) responses
- š”ļø Type Safety: Full TypeScript support with Zod schema validation
- ā” Optimized: Clean error handling and robust JSON parsing
- šÆ Focused: Clean API surface with sensible defaults
``bash`
npm install @onkernel/cu-playwrightor
yarn add @onkernel/cu-playwrightor
bun add @onkernel/cu-playwright
`typescript
import { chromium } from 'playwright';
import { ComputerUseAgent } from '@onkernel/cu-playwright';
const browser = await chromium.launch({ headless: false });
const page = await browser.newPage();
// Navigate to Hacker News manually first
await page.goto("https://news.ycombinator.com/");
const agent = new ComputerUseAgent({
apiKey: process.env.ANTHROPIC_API_KEY!,
page,
});
// Simple text response
const answer = await agent.execute('Tell me the title of the top story');
console.log(answer);
await browser.close();
`
The main class for computer use automation.
#### Constructor
`typescript`
new ComputerUseAgent(options: {
apiKey: string;
page: Page;
model?: string;
})
Parameters:
- apiKey (string): Your Anthropic API key. Get one from Anthropic Consolepage
- (Page): Playwright page instance to controlmodel
- (string, optional): Anthropic model to use. Defaults to 'claude-sonnet-4-20250514'
Supported Models:
See Anthropic's Computer Use documentation for the latest model compatibility.
#### execute() Method
`typescript`
async execute
query: string,
schema?: z.ZodSchema
options?: {
systemPromptSuffix?: string;
thinkingBudget?: number;
}
): Promise
Parameters:
- query (string): The task description for Claude to execute
- schema (ZodSchema, optional): Zod schema for structured responses. When provided, the response will be validated against this schema
- options (object, optional):
- systemPromptSuffix (string): Additional instructions appended to the system prompt
- thinkingBudget (number): Token budget for Claude's internal reasoning process. Default: 1024. See Extended Thinking documentation for details
Returns:
- Promise: When schema is provided, returns validated data of type TPromise
- : When no schema is provided, returns the text response
`typescript
import { ComputerUseAgent } from '@onkernel/cu-playwright-ts';
// Navigate to the target page first
await page.goto("https://news.ycombinator.com/");
const agent = new ComputerUseAgent({
apiKey: process.env.ANTHROPIC_API_KEY!,
page,
});
const result = await agent.execute(
'Tell me the title of the top story on this page'
);
console.log(result); // "Title of the top story"
`
`typescript
import { z } from 'zod';
import { ComputerUseAgent } from '@onkernel/cu-playwright-ts';
const agent = new ComputerUseAgent({
apiKey: process.env.ANTHROPIC_API_KEY!,
page,
});
const HackerNewsStory = z.object({
title: z.string(),
points: z.number(),
author: z.string(),
comments: z.number(),
url: z.string().optional(),
});
const stories = await agent.execute(
'Get the top 5 Hacker News stories with their details',
z.array(HackerNewsStory).max(5)
);
console.log(stories);
// [
// {
// title: "Example Story",
// points: 150,
// author: "user123",
// comments: 42,
// url: "https://example.com"
// },
// ...
// ]
`
`typescript`
const result = await agent.execute(
'Complex task requiring more thinking',
undefined, // No schema for text response
{
systemPromptSuffix: 'Be extra careful with form submissions.',
thinkingBudget: 4096, // More thinking tokens for complex tasks
}
);
1. Anthropic API Key: Set your API key as an environment variable:
`bash`
export ANTHROPIC_API_KEY=your_api_key_here
2. Playwright: Install Playwright and browser dependencies:
`bash`
npx playwright install
This SDK leverages Anthropic's Computer Use API with the following key parameters:
parameter controls Claude's internal reasoning process:
- 1024 tokens (default): Suitable for simple tasks
- 4096+ tokens: Better for complex reasoning tasks
- 16k+ tokens: Recommended for highly complex multi-step operationsSee Anthropic's Extended Thinking guide for optimization tips.
Error Handling
The SDK includes built-in error handling:
`typescript
try {
const result = await agent.execute('Your task here');
console.log(result);
} catch (error) {
if (error.message.includes('No response received')) {
console.log('Agent did not receive a response from Claude');
} else {
console.log('Other error:', error.message);
}
}
``1. Use specific, clear instructions: "Click the red 'Submit' button" vs "click submit"
2. For complex tasks, break them down: Use step-by-step instructions in your query
3. Optimize thinking budget: Start with default (1024) and increase for complex tasks
4. Handle errors gracefully: Implement proper error handling for production use
5. Use structured responses: When you need specific data format, use Zod schemas
6. Test in headless: false: During development, run with visible browser to debug
ā ļø Important: Computer use can interact with any visible application. Always:
- Run in isolated environments (containers/VMs) for production
- Avoid providing access to sensitive accounts or data
- Review Claude's actions in logs before production deployment
- Use allowlisted domains when possible
See Anthropic's Computer Use Security Guide for detailed security recommendations.
- Node.js 18+
- TypeScript 5+
- Playwright 1.52+
- Anthropic API key
- Anthropic Computer Use Documentation
- Extended Thinking Guide
- Playwright Documentation
- Zod Documentation
See License