name: pattern-schema description: Design schemas.tsx with Input/Output types for patterns user-invocable: false
Use Skill("ct") for ct CLI documentation when running commands.
Schema Design Phase
Goal
Create schemas.tsx with all data types and Input/Output types BEFORE any pattern code.
Read First
-
docs/common/concepts/types-and-schemas/default.md -
docs/common/concepts/types-and-schemas/writable.md -
docs/common/concepts/pattern.md(Input/Output section)
Rules
-
ALWAYS use
pattern<Input, Output>()- Never use single-typepattern<State>(). Single-type patterns cannot be tested via.send(). - Every editable field needs
Writable<>in Input type (for write access) -
Output types never use
Writable<>- they reflect returned data shape - Fields that could be undefined initially: use
Default<T, value> - Actions in Output type:
Stream<T>(enables testing and linking) - Sub-patterns need
[NAME]: stringand[UI]: VNodein Output type
Template
import { Default, NAME, Stream, UI, VNode, Writable } from "commontools";
// ============ DATA TYPES ============
export interface Item {
name: Default<string, "">;
done: Default<boolean, false>;
}
// ============ PATTERN INPUT/OUTPUT ============
export interface ItemInput {
item: Writable<Item>; // Writable in Input = pattern will modify
}
export interface ItemOutput {
[NAME]: string; // Required for sub-patterns
[UI]: VNode; // Required for sub-patterns
item: Item; // No Writable in Output
toggle: Stream<void>; // Actions as Stream<T>
}
Done When
- All data types defined with correct Writable/Default wrapping
- All Input/Output types defined for each sub-pattern
- No TypeScript errors:
deno task ct check schemas.tsx --no-run
chat Comments (0)
Sign in to join the discussion and leave a comment.
Skill Details
GitHub Stars
24
GitHub Forks
10
Created
Jan 2026
Last Updated
4 months ago
tools
tools ide plugins
Related Skills
Build your own?
Join 12,000+ developers contributing to the Claude ecosystem.
No comments yet. Be the first to share your thoughts!