build-with-tambo

Detect tech stack and integrate Tambo while preserving existing patterns.

Safety Notice

This listing is imported from skills.sh public index metadata. Review upstream SKILL.md and repository scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "build-with-tambo" with this command: npx skills add tambo-ai/tambo/tambo-ai-tambo-build-with-tambo

Build with Tambo

Detect tech stack and integrate Tambo while preserving existing patterns.

Reference Guides

Use these guides when you need deeper implementation details for a specific area:

  • Components - Create and register Tambo components (generative and interactable).

  • Component Rendering - Handle streaming props, loading states, and persistent component state.

  • Threads and Input - Manage conversations, suggestions, voice input, image attachments, and thread switching.

  • Tools and Context - Add custom tools, MCP servers, context helpers, and resources.

  • CLI Reference - Use tambo init , tambo add , and create-app with non-interactive flags and exit codes.

  • Add Components to Registry - Convert existing React components into Tambo-ready registrations with schemas and descriptions.

These references are duplicated across both skills so each skill works independently.

Workflow

  • Detect tech stack - Analyze package.json and project structure

  • Confirm with user - Present findings, ask about preferences

  • Install dependencies - Add @tambo-ai/react and peer deps

  • Create provider setup - Adapt to existing patterns

  • Register first component - Demonstrate with existing component

Step 1: Detect Tech Stack

Check these files to understand the project:

Key files to read

package.json # Dependencies and scripts tsconfig.json # TypeScript config next.config.* # Next.js vite.config.* # Vite tailwind.config.* # Tailwind CSS postcss.config.* # PostCSS src/index.* or app/ # Entry points

Detection Checklist

Technology Detection

Next.js next in dependencies, next.config.* exists

Vite vite in devDependencies, vite.config.* exists

Create React App react-scripts in dependencies

TypeScript typescript in deps, tsconfig.json exists

Tailwind tailwindcss in deps, config file exists

Plain CSS No Tailwind, CSS files in src/

Zod zod in dependencies

Other validation yup , joi , superstruct in deps

Step 2: Confirm with User

Present findings and ask:

I detected your project uses:

  • Framework: Next.js 14 (App Router)
  • Styling: Tailwind CSS
  • Validation: No Zod (will need to add)
  • TypeScript: Yes

Should I:

  1. Install Tambo with these settings?
  2. Use plain CSS instead of Tailwind for Tambo components?
  3. Something else?

Step 3: Install Dependencies

Core (always required)

npm install @tambo-ai/react

If no Zod installed

npm install zod

Step 4: Create Provider Setup

Next.js App Router

// app/providers.tsx "use client"; import { TamboProvider } from "@tambo-ai/react"; import { components } from "@/lib/tambo";

export function Providers({ children }: { children: React.ReactNode }) { return ( <TamboProvider apiKey={process.env.NEXT_PUBLIC_TAMBO_API_KEY} components={components} > {children} </TamboProvider> ); }

// app/layout.tsx import { Providers } from "./providers";

export default function RootLayout({ children }) { return ( <html> <body> <Providers>{children}</Providers> </body> </html> ); }

Next.js Pages Router

// pages/_app.tsx import { TamboProvider } from "@tambo-ai/react"; import { components } from "@/lib/tambo";

export default function App({ Component, pageProps }) { return ( <TamboProvider apiKey={process.env.NEXT_PUBLIC_TAMBO_API_KEY} components={components} > <Component {...pageProps} /> </TamboProvider> ); }

Vite / CRA

// src/main.tsx import { TamboProvider } from "@tambo-ai/react"; import { components } from "./lib/tambo"; import App from "./App";

ReactDOM.createRoot(document.getElementById("root")!).render( <TamboProvider apiKey={import.meta.env.VITE_TAMBO_API_KEY} components={components}

&#x3C;App />

</TamboProvider>, );

Step 5: Create Component Registry

// lib/tambo.ts (or src/lib/tambo.ts) import { TamboComponent } from "@tambo-ai/react";

export const components: TamboComponent[] = [ // Components will be registered here ];

Adapting to Existing Patterns

No Tailwind? Use Plain CSS

If project uses plain CSS or CSS modules, Tambo components can be styled differently:

// Skip --yes flag to customize styling during add npx tambo add message-thread-full

Select "CSS Modules" or "Plain CSS" when prompted

Existing Validation Library?

If using Yup/Joi instead of Zod, user can either:

  • Add Zod just for Tambo schemas (recommended - small addition)

  • Convert schemas (more work, not recommended)

Monorepo?

Run commands from the package that will use Tambo:

cd packages/web npx tambo init --api-key=sk_...

Environment Variables

npx tambo init --api-key=sk_... automatically creates .env.local with the correct env var for your framework.

If manual setup is needed (monorepo, read-only filesystem), add the appropriate variable:

Framework Variable

Next.js NEXT_PUBLIC_TAMBO_API_KEY

Vite VITE_TAMBO_API_KEY

CRA REACT_APP_TAMBO_API_KEY

Verification

After setup, verify by creating a simple test:

import { useTambo } from "@tambo-ai/react";

function TestComponent() { const { thread, isIdle } = useTambo(); console.log("Tambo connected:", isIdle); return <div>Tambo is set up!</div>; }

Reporting Bugs & Feedback

If you encounter any of these while helping a user, suggest filing a GitHub issue:

  • A bug in @tambo-ai/react , @tambo-ai/client , or the tambo CLI

  • Documentation that contradicts actual behavior

  • Missing or misleading instructions in this skill

Issue Template

Use this template when drafting an issue for tambo-ai/tambo :

Title: [Short description of the problem]

Expected behavior What should happen.

Actual behavior What happens instead, including any error messages or stack traces.

Repro steps

  1. Run npx tambo create-app ... (or whatever command)
  2. Add this code:
// minimal code that reproduces the issue
  1. Observe the error

Environment

  • @tambo-ai/react version:
  • @tambo-ai/client version:
  • Framework (Next.js / Vite / CRA) and version:
  • Node.js version:
  • OS:

Additional context Link to relevant docs or skill file path if applicable.

Security: Redact API keys, tokens, and any customer data before including logs or code snippets in the issue.

Suggesting an Issue to the User

When you hit a problem that looks like a Tambo bug, say something like:

This looks like a bug in @tambo-ai/react . Want me to open a GitHub issue on tambo-ai/tambo with the repro steps and environment details?

Always wait for the user to confirm before filing.

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

General

generative-ui

No summary provided by upstream source.

Repository SourceNeeds Review
General

add-components-to-registry

No summary provided by upstream source.

Repository SourceNeeds Review
General

threads

No summary provided by upstream source.

Repository SourceNeeds Review
General

components

No summary provided by upstream source.

Repository SourceNeeds Review