stitch-sdk-usage
$
npx mdskill add google-labs-code/stitch-sdk/stitch-sdk-usageGenerate and manage UI screens via Stitch SDK
- Creates AI-powered interfaces from text prompts instantly.
- Depends on Google's Stitch API for generation services.
- Analyzes project context to recommend design systems.
- Delivers HTML code, images, or direct download URLs.
SKILL.md
.github/skills/stitch-sdk-usageView on GitHub ↗
---
name: stitch-sdk-usage
description: Use the Stitch SDK to generate, edit, and iterate on UI screens from text prompts, manage projects, and retrieve screen HTML/images. Use when the user wants to consume the SDK in their application.
---
# Using the Stitch SDK
The Stitch SDK provides a TypeScript interface for Google Stitch, an AI-powered UI generation service.
## Installation
```bash
npm install @google/stitch-sdk
```
## Environment Variables
```bash
export STITCH_API_KEY="your-api-key"
```
## Quick Start
```typescript
import { stitch } from "@google/stitch-sdk";
const project = await stitch.createProject("My App");
const screen = await project.generate("A settings page with dark theme");
const html = await screen.getHtml(); // download URL for the HTML
const imageUrl = await screen.getImage(); // download URL for the screenshot
```
The `stitch` singleton reads `STITCH_API_KEY` from the environment and connects on first use — no setup code required.
## Working with Projects
```typescript
import { stitch } from "@google/stitch-sdk";
// List all projects
const projects = await stitch.projects();
// Reference a project by ID (no network call)
const project = stitch.project("4044680601076201931");
// Create a new project
const newProject = await stitch.createProject("My App");
```
## Design Systems
```typescript
// Create a design system for a project
const ds = await project.createDesignSystem({ displayName: "My Theme" });
// List design systems
const systems = await project.listDesignSystems();
// Reference by ID (no network call)
const dsRef = project.designSystem("existing-asset-id");
// Update a design system
const updated = await ds.update({ displayName: "Updated Theme" });
// Apply to screens (requires SelectedScreenInstance objects from project.data.screenInstances)
const screens = await ds.apply([
{ id: "instance-id", sourceScreen: "projects/123/screens/456" },
]);
```
## Uploading Images
Upload an existing image file (PNG, JPG, JPEG, WEBP) to create a screen directly from a mockup or asset.
```typescript
import { stitch } from "@google/stitch-sdk";
const project = stitch.project("your-project-id");
// Upload a local image file
const [screen] = await project.uploadImage("./mockup.png", {
title: "Home Screen",
});
console.log(screen.id);
const html = await screen.getHtml();
const imageUrl = await screen.getImage();
```
The method reads the file from disk and posts it directly to the Stitch REST API — no output token constraints apply (unlike agent-driven MCP calls).
**Supported formats:** `.png`, `.jpg`, `.jpeg`, `.webp`
**Options:**
| Option | Type | Default | Description |
|---|---|---|---|
| `title` | `string` | — | Display title for the created screen |
| `createScreenInstances` | `boolean` | `true` | Whether to add the screen to the canvas |
**Throws** `StitchError` with codes: `NOT_FOUND` (file not found), `UNKNOWN_ERROR` (unsupported format or upload failure), `AUTH_FAILED` (invalid API key).
## Generating and Iterating on Screens
```typescript
// Generate a new screen from a prompt
const screen = await project.generate(
"Login page with email and password fields",
);
// Edit an existing screen
const edited = await screen.edit("Make the background dark and add a subtitle");
// Generate variants of a screen
const variants = await screen.variants("Try different color schemes", {
variantCount: 2,
creativeRange: "EXPLORE",
aspects: ["COLOR_SCHEME", "LAYOUT"],
});
```
## Retrieving Screen Assets
```typescript
// Get screen HTML download URL
const html = await screen.getHtml();
// Get screen screenshot download URL
const imageUrl = await screen.getImage();
```
Both methods use cached data from the generation response when available, falling back to an API call when needed.
## Dynamic Tool Client (for agents)
For agents and orchestration scripts that forward JSON payloads to MCP tools:
```typescript
import { stitch } from "@google/stitch-sdk";
// Find available tools
const { tools } = await stitch.listTools();
for (const tool of tools) {
console.log(`${tool.name}: ${tool.description}`);
}
// Call a tool with a JSON payload
const result = await stitch.callTool("generate_screen_from_text", {
projectId: "123",
prompt: "A login page",
});
await stitch.close();
```
## Error Handling
All SDK methods throw `StitchError` on failure. Use try/catch:
```typescript
import { stitch, StitchError } from "@google/stitch-sdk";
try {
const project = stitch.project("bad-id");
await project.screens();
} catch (e) {
if (e instanceof StitchError) {
console.log(e.code); // "AUTH_FAILED", "NOT_FOUND", etc.
console.log(e.message); // Human-readable description
console.log(e.recoverable); // Whether retrying might succeed
}
}
```
Error codes: `AUTH_FAILED`, `NOT_FOUND`, `PERMISSION_DENIED`, `RATE_LIMITED`, `NETWORK_ERROR`, `VALIDATION_ERROR`, `UNKNOWN_ERROR`
## API Reference
### Stitch Class
| Method | Returns | Description |
| ---------------------- | -------------------- | ------------------------------------------- |
| `createProject(title)` | `Promise<Project>` | Create a new project |
| `projects()` | `Promise<Project[]>` | List all projects |
| `project(id)` | `Project` | Reference a project by ID (no network call) |
### Project Class
| Method | Returns | Description |
| ---------------------------------- | ------------------------- | ------------------------------------------------ |
| `generate(prompt, deviceType?)` | `Promise<Screen>` | Generate a screen from a text prompt |
| `screens()` | `Promise<Screen[]>` | List all screens in the project |
| `getScreen(screenId)` | `Promise<Screen>` | Retrieve a specific screen by ID |
| `uploadImage(filePath, opts?)` | `Promise<Screen[]>` | Upload an image file and create a screen from it |
| `createDesignSystem(designSystem)` | `Promise<DesignSystem>` | Create a design system for this project |
| `listDesignSystems()` | `Promise<DesignSystem[]>` | List all design systems |
| `designSystem(id)` | `DesignSystem` | Reference by ID (no API call) |
`deviceType`: `"MOBILE"` | `"DESKTOP"` | `"TABLET"` | `"AGNOSTIC"`
`uploadImage` supported formats: `.png` `.jpg` `.jpeg` `.webp`
### DesignSystem Class
| Method | Returns | Description |
| -------------------------------- | ----------------------- | ----------------------------------- |
| `update(designSystem)` | `Promise<DesignSystem>` | Update the design system's theme |
| `apply(selectedScreenInstances)` | `Promise<Screen[]>` | Apply this design system to screens |
### Screen Class
| Method | Returns | Description |
| -------------------------------------------------- | ------------------- | ---------------------------------------- |
| `getHtml()` | `Promise<string>` | Get the screen's HTML download URL |
| `getImage()` | `Promise<string>` | Get the screen's screenshot download URL |
| `edit(prompt, deviceType?, modelId?)` | `Promise<Screen>` | Edit the screen using a text prompt |
| `variants(prompt, options, deviceType?, modelId?)` | `Promise<Screen[]>` | Generate variants of the screen |
`modelId`: `"GEMINI_3_PRO"` | `"GEMINI_3_FLASH"`
### StitchToolClient (for agents)
| Method | Returns | Description |
| ---------------------- | ---------------- | -------------------------------------------------- |
| `callTool(name, args)` | `Promise<T>` | Call any MCP tool by name |
| `listTools()` | `Promise<Tools>` | Discover available tools |
| `connect()` | `Promise<void>` | Establish MCP connection (auto-called by callTool) |
| `close()` | `Promise<void>` | Close the connection |
### Explicit Configuration
```typescript
import { Stitch, StitchToolClient } from "@google/stitch-sdk";
const client = new StitchToolClient({
apiKey: "your-api-key",
baseUrl: "https://stitch.googleapis.com/mcp",
timeout: 300_000,
});
const sdk = new Stitch(client);
const projects = await sdk.projects();
```
| Option | Env Variable | Description |
| ------------- | ---------------------- | ------------------------------------------------------------- |
| `apiKey` | `STITCH_API_KEY` | API key for authentication |
| `accessToken` | `STITCH_ACCESS_TOKEN` | OAuth access token |
| `projectId` | `GOOGLE_CLOUD_PROJECT` | GCP project ID (required with OAuth) |
| `baseUrl` | — | MCP server URL (default: `https://stitch.googleapis.com/mcp`) |
| `timeout` | — | Request timeout in ms (default: 300000) |
More from google-labs-code/stitch-sdk
- github-codebase-briefing>-
- stitch-sdk-bug-bashFind bugs in the Stitch SDK using a real API key. Covers standard functional edges and tricky situations.
- stitch-sdk-developmentDevelop the Stitch SDK. Covers the generation pipeline, dual modality (agent vs SDK), error handling, and Traffic Light (Red-Green-Yellow) implementation workflow. Use when adding features, fixing bugs, or understanding the architecture.
- stitch-sdk-domain-designDesign the domain model for the Stitch SDK. Use when mapping MCP tools to domain classes and bindings in domain-map.json. This is Stage 2 of the generation pipeline.
- stitch-sdk-pipelineRun the full Stitch SDK generation pipeline. Use when a new tool is added, or the SDK needs to be regenerated end-to-end.
- stitch-sdk-readmeGenerate or update the README for the Stitch SDK. Use the Bookstore Test structure and source the current API from the codebase. Use when the README needs to be written or updated.