Installable full-stack features for React apps
Framework-agnostic. Database-flexible. No lock-in.
BTST lets you install production-ready app features as npm packages.
Instead of spending weeks building the same things again and again
(routes, APIs, database schemas, SSR, SEO, forms…):
npm install @btst/stackEnable the features you need and keep building your product.
| Plugin | Description |
|---|---|
| Blog | Content management, editor, drafts, publishing, SEO, RSS feeds |
| AI Chat | AI-powered chat with conversation history, streaming, and customizable models |
| CMS | Headless CMS with custom content types, Zod schemas, and auto-generated forms |
| Form Builder | Dynamic form builder with drag-and-drop editor, submissions, and validation |
| UI Builder | Visual drag-and-drop page builder with component registry and public rendering |
| Kanban | Project management with boards, columns, tasks, drag-and-drop, and priority levels |
| Media | Media library with uploads, folders, picker UI, URL registration, and reusable image inputs |
| OpenAPI | Auto-generated API documentation with interactive Scalar UI |
| Route Docs | Auto-generated client route documentation with interactive navigation |
| Better Auth UI | Beautiful shadcn/ui authentication components for better-auth |
| Comments | Commenting system with moderation, likes, and nested replies |
Each plugin ships frontend + backend together: routes, APIs, database models, React components, SSR, and SEO — already wired.
Want a specific plugin? Open an issue and let us know!
- Installable features – real product features, not just UI
- Framework-agnostic – Next.js, React Router, TanStack Router, Remix
- Database-flexible – Prisma, Drizzle, Kysely, MongoDB
- Zero boilerplate – no manual route or API wiring
- Type-safe – end-to-end TypeScript
You keep your codebase, database, and deployment.
import { stack } from "@btst/stack"
import { blogBackendPlugin } from "@btst/stack/plugins/blog/api"
import { createMemoryAdapter } from "@btst/adapter-memory"
export const { handler, dbSchema } = stack({
basePath: "/api/data",
plugins: {
blog: blogBackendPlugin()
},
adapter: (db) => createMemoryAdapter(db)({})
})import { createStackClient } from "@btst/stack/client"
import { blogClientPlugin } from "@btst/stack/plugins/blog/client"
import { QueryClient } from "@tanstack/react-query"
export const getStackClient = (queryClient: QueryClient) =>
createStackClient({
plugins: {
blog: blogClientPlugin({
apiBaseURL: "http://localhost:3000",
apiBasePath: "/api/data",
siteBaseURL: "http://localhost:3000",
siteBasePath: "/pages",
queryClient,
})
}
})Now you have a working blog with API, pages, SSR, and SEO. See the full installation guide for database adapters, auth hooks, and framework-specific setup.
Optional CLI to generate schemas and run migrations from enabled plugins:
npm install -D @btst/cliGenerate drizzle schema:
npx @btst/cli generate --orm drizzle --config lib/stack.ts --output db/schema.tsSupports Prisma, Drizzle, MongoDB and Kysely SQL dialects.
Each plugin's UI layer is available as a shadcn registry block. Use it to eject and fully customize the page components while keeping all data-fetching and API logic from @btst/stack:
# Install a single plugin's UI (for example, Media)
npx shadcn@latest add https://github.com/better-stack-ai/better-stack/blob/main/packages/stack/registry/btst-media.json
# Or install the full collection
npx shadcn@latest add https://github.com/better-stack-ai/better-stack/blob/main/packages/stack/registry/registry.jsonComponents are copied into src/components/btst/{plugin}/client/ — all relative imports remain valid and you can edit them freely.
If you're using an AI coding agent (Cursor, Claude Code, VS Code, OpenAI Codex etc.) you can install the BTST integration skill so your agent understands the plugin system, adapter setup, and wiring patterns out of the box:
npx skills@latest add better-stack-ai/better-stack/.agents/skills/btst-integrationOr manually copy skills/btst-integration/SKILL.md into your project's agent skills directory.
Full documentation, guides, and plugin development: 👉 https://www.better-stack.ai
Bug reports, plugin PRs, and documentation improvements are welcome. See CONTRIBUTING.md for the plugin development guide, testing instructions, and submission checklist.
If this saves you time, a ⭐ helps others find it.
MIT © olliethedev