pattern-implement
1
总安装量
1
周安装量
#44596
全站排名
安装命令
npx skills add https://github.com/commontoolsinc/labs --skill pattern-implement
Agent 安装分布
opencode
1
cursor
1
antigravity
1
gemini-cli
1
Skill 文档
Use Skill("ct") for ct CLI documentation when running commands.
Implement Sub-Pattern
Core Rule
Write ONE sub-pattern with minimal stub UI. No styling, just basic inputs/buttons to verify data flow.
Always use pattern<Input, Output>() – expose actions as Stream<T> for testability.
Order
- Leaf patterns first (no dependencies on other patterns)
- Container patterns (compose leaf patterns)
- main.tsx last (composes everything)
Read First
docs/common/patterns/– especiallymeta/for generalizable idiomsdocs/common/concepts/action.md– action() for local statedocs/common/concepts/handler.md– handler() for reusable logicdocs/common/concepts/reactivity.md– Cell behavior, .get()/.set()docs/common/concepts/identity.md– equals() for object comparison
Key Patterns
action() – Closes over local state in pattern body:
const inputValue = Cell.of("");
const submit = action(() => {
items.push({ text: inputValue.get() });
inputValue.set("");
});
handler() – Reused with different bindings:
const deleteItem = handler<void, { items: Writable<Item[]>; index: number }>(
(_, { items, index }) => items.set(items.get().toSpliced(index, 1))
);
// In JSX: onClick={deleteItem({ items, index })}
Rendering sub-patterns – Use function calls, not JSX:
// â
Correct
{items.map((item) => ItemPattern({ item, allItems: items }))}
// â Wrong - JSX fails with typed Output
{items.map((item) => <ItemPattern item={item} />)}
Done When
- Pattern compiles:
deno task ct check pattern.tsx --no-run - Minimal UI renders inputs/buttons
- Ready for testing