Agent skill
react-component-create
Create new React components following project patterns and best practices. Includes proper typing, testing, and documentation.
Install this agent skill to your Project
npx add-skill https://github.com/cpa03/blueprintify/tree/main/.opencode/skill/react-component-create
SKILL.md
React Component Create Skill
Create production-ready React components.
Component Template
Functional Component
import { memo, useCallback, type FC } from "react";
interface ComponentNameProps {
/** Description of prop */
propName: string;
/** Optional prop with default */
optionalProp?: boolean;
/** Callback handler */
onAction?: (value: string) => void;
}
/**
* ComponentName - Brief description
*
* @example
* <ComponentName propName="value" onAction={handleAction} />
*/
export const ComponentName: FC<ComponentNameProps> = memo(
({ propName, optionalProp = false, onAction }) => {
const handleClick = useCallback(() => {
onAction?.(propName);
}, [propName, onAction]);
return <div className="component-name">{/* Component content */}</div>;
}
);
ComponentName.displayName = "ComponentName";
Test Template
import { render, screen, fireEvent } from "@testing-library/react";
import { describe, it, expect, vi } from "vitest";
import { ComponentName } from "./ComponentName";
describe("ComponentName", () => {
it("renders correctly", () => {
render(<ComponentName propName="test" />);
expect(screen.getByText("test")).toBeInTheDocument();
});
it("calls onAction when clicked", () => {
const onAction = vi.fn();
render(<ComponentName propName="test" onAction={onAction} />);
fireEvent.click(screen.getByRole("button"));
expect(onAction).toHaveBeenCalledWith("test");
});
});
Directory Structure
components/
ComponentName/
index.ts # Export barrel
ComponentName.tsx # Component implementation
ComponentName.test.tsx # Tests
ComponentName.css # Styles (if needed)
Checklist
- Props interface defined with JSDoc
- Component wrapped with memo if pure
- Callbacks wrapped with useCallback
- DisplayName set for debugging
- Tests cover main scenarios
- Accessibility attributes added
- Types exported if needed elsewhere
Recommended Agent Skills
Expand your agent's capabilities with these related and highly-rated skills.
ci-pipeline-update
Updates CI/CD pipelines for DevOps Engineer
obra-superpowers-test-driven-development
Use when implementing any feature or bugfix, before writing implementation code
typescript-refactor
Safely refactor TypeScript code while maintaining type safety and test coverage. Includes verification steps.
obra-superpowers-using-git-worktrees
Use when starting feature work that needs isolation from current workspace or before executing implementation plans - creates isolated git worktrees with smart directory selection and safety verification
madappgang-claude-code-debugging-strategies
Universal debugging strategies and techniques applicable across all technology stacks. Use when approaching unknown bugs or need language-agnostic debugging methodology.
resilience-check
Checklist for reliability engineering
Didn't find tool you were looking for?