@plumbus/ui
v0.2.6
Published
Plumbus UI — client generation and frontend templates
Downloads
1,257
Readme
@plumbus/ui
UI code generation for the Plumbus framework.
Generates typed API clients, React hooks, auth helpers, form metadata, and full Next.js project scaffolds — all derived from your Plumbus capability and entity contracts.
Install
pnpm add @plumbus/uiNote:
@plumbus/coreis a peer dependency and must be installed in your project.
What It Generates
Typed API Clients
Generate fetch-based clients with full type safety from your capability contracts:
import { generateClientCode } from "@plumbus/ui";
const code = generateClientCode([getUserContract, createOrderContract]);
// → typed fetch functions + React hooks for each capabilityAuth Helpers
Generate authentication types, token utilities, and route guards:
import { generateAuthCode } from "@plumbus/ui";
const code = generateAuthCode(authConfig);
// → AuthUser type, useAuth hook, token helpers, withAuth guardForm Metadata
Extract form field metadata from Zod schemas in your entity definitions:
import { generateFormMetadata } from "@plumbus/ui";
const fields = generateFormMetadata(userEntity);
// → field types, labels, validation rules, select optionsNext.js Scaffolding
Generate a complete Next.js project from your contracts:
import { generateNextjsTemplate } from "@plumbus/ui";
const files = generateNextjsTemplate({
capabilities: [getUser, createOrder],
entities: [User, Order],
auth: { provider: "jwt" },
});
// → Full Next.js app with pages, layouts, API routes, and authAI Agent Instructions
This package ships instruction files for AI coding agents:
node_modules/@plumbus/ui/instructions/
├── framework.md # UI package overview and concepts
├── client-generator.md # Typed fetch clients and React hooks
├── auth-generator.md # Auth types, token utils, route guards
├── form-generator.md # Zod schema → form field extraction
├── nextjs-template.md # Full Next.js project scaffold
├── patterns.md # UI conventions and best practices
└── testing.md # UI test setup and patternsDocumentation
Full documentation: github.com/plumbus-framework/plumbus/docs
License
MIT
