tribunal-kit 2.4.6 โ 3.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.agent/ARCHITECTURE.md +99 -99
- package/.agent/GEMINI.md +52 -52
- package/.agent/agents/accessibility-reviewer.md +139 -86
- package/.agent/agents/ai-code-reviewer.md +160 -90
- package/.agent/agents/backend-specialist.md +164 -127
- package/.agent/agents/code-archaeologist.md +115 -73
- package/.agent/agents/database-architect.md +130 -110
- package/.agent/agents/debugger.md +137 -97
- package/.agent/agents/dependency-reviewer.md +78 -30
- package/.agent/agents/devops-engineer.md +161 -118
- package/.agent/agents/documentation-writer.md +151 -87
- package/.agent/agents/explorer-agent.md +117 -99
- package/.agent/agents/frontend-reviewer.md +127 -47
- package/.agent/agents/frontend-specialist.md +169 -109
- package/.agent/agents/game-developer.md +28 -164
- package/.agent/agents/logic-reviewer.md +87 -49
- package/.agent/agents/mobile-developer.md +151 -103
- package/.agent/agents/mobile-reviewer.md +133 -50
- package/.agent/agents/orchestrator.md +121 -110
- package/.agent/agents/penetration-tester.md +103 -77
- package/.agent/agents/performance-optimizer.md +136 -92
- package/.agent/agents/performance-reviewer.md +139 -69
- package/.agent/agents/product-manager.md +104 -70
- package/.agent/agents/product-owner.md +6 -25
- package/.agent/agents/project-planner.md +95 -95
- package/.agent/agents/qa-automation-engineer.md +174 -87
- package/.agent/agents/security-auditor.md +133 -129
- package/.agent/agents/seo-specialist.md +160 -99
- package/.agent/agents/sql-reviewer.md +132 -44
- package/.agent/agents/supervisor-agent.md +137 -109
- package/.agent/agents/swarm-worker-contracts.md +17 -17
- package/.agent/agents/swarm-worker-registry.md +46 -46
- package/.agent/agents/test-coverage-reviewer.md +132 -53
- package/.agent/agents/test-engineer.md +0 -21
- package/.agent/agents/type-safety-reviewer.md +143 -33
- package/.agent/patterns/generator.md +9 -9
- package/.agent/patterns/inversion.md +12 -12
- package/.agent/patterns/pipeline.md +9 -9
- package/.agent/patterns/reviewer.md +13 -13
- package/.agent/patterns/tool-wrapper.md +9 -9
- package/.agent/rules/GEMINI.md +63 -63
- package/.agent/scripts/__pycache__/auto_preview.cpython-311.pyc +0 -0
- package/.agent/scripts/__pycache__/bundle_analyzer.cpython-311.pyc +0 -0
- package/.agent/scripts/__pycache__/checklist.cpython-311.pyc +0 -0
- package/.agent/scripts/__pycache__/dependency_analyzer.cpython-311.pyc +0 -0
- package/.agent/scripts/__pycache__/security_scan.cpython-311.pyc +0 -0
- package/.agent/scripts/__pycache__/session_manager.cpython-311.pyc +0 -0
- package/.agent/scripts/__pycache__/skill_integrator.cpython-311.pyc +0 -0
- package/.agent/scripts/__pycache__/swarm_dispatcher.cpython-311.pyc +0 -0
- package/.agent/scripts/__pycache__/test_runner.cpython-311.pyc +0 -0
- package/.agent/scripts/__pycache__/verify_all.cpython-311.pyc +0 -0
- package/.agent/scripts/compress_skills.py +167 -0
- package/.agent/scripts/consolidate_skills.py +173 -0
- package/.agent/scripts/deep_compress.py +202 -0
- package/.agent/scripts/minify_context.py +80 -0
- package/.agent/scripts/security_scan.py +1 -1
- package/.agent/scripts/strip_tribunal.py +41 -0
- package/.agent/skills/agent-organizer/SKILL.md +60 -100
- package/.agent/skills/agentic-patterns/SKILL.md +0 -70
- package/.agent/skills/ai-prompt-injection-defense/SKILL.md +108 -53
- package/.agent/skills/api-patterns/SKILL.md +197 -257
- package/.agent/skills/api-security-auditor/SKILL.md +125 -57
- package/.agent/skills/app-builder/SKILL.md +326 -50
- package/.agent/skills/app-builder/templates/SKILL.md +13 -15
- package/.agent/skills/app-builder/templates/astro-static/TEMPLATE.md +16 -16
- package/.agent/skills/app-builder/templates/chrome-extension/TEMPLATE.md +22 -22
- package/.agent/skills/app-builder/templates/cli-tool/TEMPLATE.md +18 -18
- package/.agent/skills/app-builder/templates/electron-desktop/TEMPLATE.md +20 -20
- package/.agent/skills/app-builder/templates/express-api/TEMPLATE.md +17 -17
- package/.agent/skills/app-builder/templates/flutter-app/TEMPLATE.md +18 -18
- package/.agent/skills/app-builder/templates/monorepo-turborepo/TEMPLATE.md +21 -21
- package/.agent/skills/app-builder/templates/nextjs-fullstack/TEMPLATE.md +19 -19
- package/.agent/skills/app-builder/templates/nextjs-saas/TEMPLATE.md +26 -26
- package/.agent/skills/app-builder/templates/nextjs-static/TEMPLATE.md +26 -26
- package/.agent/skills/app-builder/templates/nuxt-app/TEMPLATE.md +19 -19
- package/.agent/skills/app-builder/templates/python-fastapi/TEMPLATE.md +18 -18
- package/.agent/skills/app-builder/templates/react-native-app/TEMPLATE.md +20 -20
- package/.agent/skills/appflow-wireframe/SKILL.md +71 -98
- package/.agent/skills/architecture/SKILL.md +161 -200
- package/.agent/skills/authentication-best-practices/SKILL.md +121 -54
- package/.agent/skills/bash-linux/SKILL.md +71 -166
- package/.agent/skills/behavioral-modes/SKILL.md +8 -69
- package/.agent/skills/brainstorming/SKILL.md +345 -127
- package/.agent/skills/building-native-ui/SKILL.md +125 -57
- package/.agent/skills/clean-code/SKILL.md +266 -149
- package/.agent/skills/code-review-checklist/SKILL.md +0 -62
- package/.agent/skills/config-validator/SKILL.md +73 -131
- package/.agent/skills/csharp-developer/SKILL.md +434 -73
- package/.agent/skills/database-design/SKILL.md +190 -275
- package/.agent/skills/deployment-procedures/SKILL.md +81 -158
- package/.agent/skills/devops-engineer/SKILL.md +255 -94
- package/.agent/skills/devops-incident-responder/SKILL.md +50 -69
- package/.agent/skills/doc.md +5 -5
- package/.agent/skills/documentation-templates/SKILL.md +19 -63
- package/.agent/skills/edge-computing/SKILL.md +75 -165
- package/.agent/skills/extract-design-system/SKILL.md +84 -58
- package/.agent/skills/framer-motion-expert/SKILL.md +195 -0
- package/.agent/skills/frontend-design/SKILL.md +151 -499
- package/.agent/skills/game-design-expert/SKILL.md +71 -0
- package/.agent/skills/game-engineering-expert/SKILL.md +88 -0
- package/.agent/skills/geo-fundamentals/SKILL.md +52 -178
- package/.agent/skills/github-operations/SKILL.md +197 -272
- package/.agent/skills/gsap-expert/SKILL.md +194 -0
- package/.agent/skills/i18n-localization/SKILL.md +60 -172
- package/.agent/skills/intelligent-routing/SKILL.md +123 -103
- package/.agent/skills/lint-and-validate/SKILL.md +8 -52
- package/.agent/skills/llm-engineering/SKILL.md +281 -195
- package/.agent/skills/local-first/SKILL.md +76 -159
- package/.agent/skills/mcp-builder/SKILL.md +48 -188
- package/.agent/skills/mobile-design/SKILL.md +213 -219
- package/.agent/skills/motion-engineering/SKILL.md +184 -0
- package/.agent/skills/nextjs-react-expert/SKILL.md +184 -203
- package/.agent/skills/nodejs-best-practices/SKILL.md +403 -185
- package/.agent/skills/observability/SKILL.md +211 -203
- package/.agent/skills/parallel-agents/SKILL.md +53 -146
- package/.agent/skills/performance-profiling/SKILL.md +171 -151
- package/.agent/skills/plan-writing/SKILL.md +49 -153
- package/.agent/skills/platform-engineer/SKILL.md +57 -103
- package/.agent/skills/playwright-best-practices/SKILL.md +110 -63
- package/.agent/skills/powershell-windows/SKILL.md +61 -179
- package/.agent/skills/python-patterns/SKILL.md +7 -35
- package/.agent/skills/python-pro/SKILL.md +273 -114
- package/.agent/skills/react-specialist/SKILL.md +227 -108
- package/.agent/skills/readme-builder/SKILL.md +15 -85
- package/.agent/skills/realtime-patterns/SKILL.md +216 -243
- package/.agent/skills/red-team-tactics/SKILL.md +10 -51
- package/.agent/skills/rust-pro/SKILL.md +525 -142
- package/.agent/skills/seo-fundamentals/SKILL.md +92 -153
- package/.agent/skills/server-management/SKILL.md +110 -166
- package/.agent/skills/shadcn-ui-expert/SKILL.md +154 -55
- package/.agent/skills/skill-creator/SKILL.md +18 -58
- package/.agent/skills/sql-pro/SKILL.md +543 -68
- package/.agent/skills/supabase-postgres-best-practices/SKILL.md +28 -68
- package/.agent/skills/swiftui-expert/SKILL.md +124 -57
- package/.agent/skills/systematic-debugging/SKILL.md +49 -151
- package/.agent/skills/tailwind-patterns/SKILL.md +433 -149
- package/.agent/skills/tdd-workflow/SKILL.md +63 -169
- package/.agent/skills/test-result-analyzer/SKILL.md +33 -73
- package/.agent/skills/testing-patterns/SKILL.md +437 -130
- package/.agent/skills/trend-researcher/SKILL.md +30 -71
- package/.agent/skills/ui-ux-pro-max/SKILL.md +0 -41
- package/.agent/skills/ui-ux-researcher/SKILL.md +51 -91
- package/.agent/skills/vue-expert/SKILL.md +225 -119
- package/.agent/skills/vulnerability-scanner/SKILL.md +264 -226
- package/.agent/skills/web-accessibility-auditor/SKILL.md +141 -58
- package/.agent/skills/web-design-guidelines/SKILL.md +17 -61
- package/.agent/skills/webapp-testing/SKILL.md +71 -196
- package/.agent/skills/whimsy-injector/SKILL.md +58 -132
- package/.agent/skills/workflow-optimizer/SKILL.md +28 -68
- package/.agent/workflows/api-tester.md +96 -224
- package/.agent/workflows/audit.md +81 -122
- package/.agent/workflows/brainstorm.md +69 -105
- package/.agent/workflows/changelog.md +65 -97
- package/.agent/workflows/create.md +73 -88
- package/.agent/workflows/debug.md +80 -111
- package/.agent/workflows/deploy.md +119 -92
- package/.agent/workflows/enhance.md +80 -91
- package/.agent/workflows/fix.md +68 -97
- package/.agent/workflows/generate.md +165 -164
- package/.agent/workflows/migrate.md +106 -109
- package/.agent/workflows/orchestrate.md +103 -86
- package/.agent/workflows/performance-benchmarker.md +77 -268
- package/.agent/workflows/plan.md +120 -98
- package/.agent/workflows/preview.md +39 -96
- package/.agent/workflows/refactor.md +105 -97
- package/.agent/workflows/review-ai.md +63 -102
- package/.agent/workflows/review.md +71 -110
- package/.agent/workflows/session.md +53 -113
- package/.agent/workflows/status.md +42 -88
- package/.agent/workflows/strengthen-skills.md +90 -51
- package/.agent/workflows/swarm.md +114 -129
- package/.agent/workflows/test.md +125 -102
- package/.agent/workflows/tribunal-backend.md +60 -78
- package/.agent/workflows/tribunal-database.md +62 -100
- package/.agent/workflows/tribunal-frontend.md +62 -82
- package/.agent/workflows/tribunal-full.md +56 -100
- package/.agent/workflows/tribunal-mobile.md +65 -94
- package/.agent/workflows/tribunal-performance.md +62 -105
- package/.agent/workflows/ui-ux-pro-max.md +72 -121
- package/README.md +11 -15
- package/package.json +1 -1
- package/.agent/skills/api-patterns/api-style.md +0 -42
- package/.agent/skills/api-patterns/auth.md +0 -24
- package/.agent/skills/api-patterns/documentation.md +0 -26
- package/.agent/skills/api-patterns/graphql.md +0 -41
- package/.agent/skills/api-patterns/rate-limiting.md +0 -31
- package/.agent/skills/api-patterns/response.md +0 -37
- package/.agent/skills/api-patterns/rest.md +0 -40
- package/.agent/skills/api-patterns/security-testing.md +0 -122
- package/.agent/skills/api-patterns/trpc.md +0 -41
- package/.agent/skills/api-patterns/versioning.md +0 -22
- package/.agent/skills/app-builder/agent-coordination.md +0 -71
- package/.agent/skills/app-builder/feature-building.md +0 -53
- package/.agent/skills/app-builder/project-detection.md +0 -34
- package/.agent/skills/app-builder/scaffolding.md +0 -118
- package/.agent/skills/app-builder/tech-stack.md +0 -40
- package/.agent/skills/architecture/context-discovery.md +0 -43
- package/.agent/skills/architecture/examples.md +0 -94
- package/.agent/skills/architecture/pattern-selection.md +0 -68
- package/.agent/skills/architecture/patterns-reference.md +0 -50
- package/.agent/skills/architecture/trade-off-analysis.md +0 -77
- package/.agent/skills/brainstorming/dynamic-questioning.md +0 -360
- package/.agent/skills/database-design/database-selection.md +0 -43
- package/.agent/skills/database-design/indexing.md +0 -39
- package/.agent/skills/database-design/migrations.md +0 -48
- package/.agent/skills/database-design/optimization.md +0 -36
- package/.agent/skills/database-design/orm-selection.md +0 -30
- package/.agent/skills/database-design/schema-design.md +0 -56
- package/.agent/skills/dotnet-core-expert/SKILL.md +0 -103
- package/.agent/skills/framer-motion-animations/SKILL.md +0 -74
- package/.agent/skills/frontend-design/animation-guide.md +0 -331
- package/.agent/skills/frontend-design/color-system.md +0 -329
- package/.agent/skills/frontend-design/decision-trees.md +0 -418
- package/.agent/skills/frontend-design/motion-graphics.md +0 -306
- package/.agent/skills/frontend-design/typography-system.md +0 -363
- package/.agent/skills/frontend-design/ux-psychology.md +0 -1116
- package/.agent/skills/frontend-design/visual-effects.md +0 -383
- package/.agent/skills/game-development/2d-games/SKILL.md +0 -119
- package/.agent/skills/game-development/3d-games/SKILL.md +0 -135
- package/.agent/skills/game-development/SKILL.md +0 -236
- package/.agent/skills/game-development/game-art/SKILL.md +0 -185
- package/.agent/skills/game-development/game-audio/SKILL.md +0 -190
- package/.agent/skills/game-development/game-design/SKILL.md +0 -129
- package/.agent/skills/game-development/mobile-games/SKILL.md +0 -108
- package/.agent/skills/game-development/multiplayer/SKILL.md +0 -132
- package/.agent/skills/game-development/pc-games/SKILL.md +0 -144
- package/.agent/skills/game-development/vr-ar/SKILL.md +0 -123
- package/.agent/skills/game-development/web-games/SKILL.md +0 -150
- package/.agent/skills/intelligent-routing/router-manifest.md +0 -65
- package/.agent/skills/mobile-design/decision-trees.md +0 -516
- package/.agent/skills/mobile-design/mobile-backend.md +0 -491
- package/.agent/skills/mobile-design/mobile-color-system.md +0 -420
- package/.agent/skills/mobile-design/mobile-debugging.md +0 -122
- package/.agent/skills/mobile-design/mobile-design-thinking.md +0 -357
- package/.agent/skills/mobile-design/mobile-navigation.md +0 -458
- package/.agent/skills/mobile-design/mobile-performance.md +0 -767
- package/.agent/skills/mobile-design/mobile-testing.md +0 -356
- package/.agent/skills/mobile-design/mobile-typography.md +0 -433
- package/.agent/skills/mobile-design/platform-android.md +0 -666
- package/.agent/skills/mobile-design/platform-ios.md +0 -561
- package/.agent/skills/mobile-design/touch-psychology.md +0 -537
- package/.agent/skills/nextjs-react-expert/1-async-eliminating-waterfalls.md +0 -312
- package/.agent/skills/nextjs-react-expert/2-bundle-bundle-size-optimization.md +0 -240
- package/.agent/skills/nextjs-react-expert/3-server-server-side-performance.md +0 -490
- package/.agent/skills/nextjs-react-expert/4-client-client-side-data-fetching.md +0 -264
- package/.agent/skills/nextjs-react-expert/5-rerender-re-render-optimization.md +0 -581
- package/.agent/skills/nextjs-react-expert/6-rendering-rendering-performance.md +0 -432
- package/.agent/skills/nextjs-react-expert/7-js-javascript-performance.md +0 -684
- package/.agent/skills/nextjs-react-expert/8-advanced-advanced-patterns.md +0 -150
- package/.agent/skills/vulnerability-scanner/checklists.md +0 -121
|
@@ -1,73 +1,172 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: shadcn-ui-expert
|
|
3
|
-
description:
|
|
4
|
-
allowed-tools: Read, Write, Edit, Glob, Grep
|
|
5
|
-
version:
|
|
6
|
-
last-updated: 2026-
|
|
7
|
-
applies-to-model: claude-3-7-sonnet
|
|
8
|
-
---
|
|
9
|
-
|
|
10
|
-
# Shadcn UI Expert
|
|
11
|
-
|
|
12
|
-
You are a Frontend Architect that specializes in building clean, decoupled component libraries using the Shadcn UI paradigm and Radix UI primitives.
|
|
13
|
-
|
|
14
|
-
## Core Directives
|
|
15
|
-
|
|
16
|
-
1. **Composition Over Configuration:**
|
|
17
|
-
- Shadcn components are not npm packages; they are raw code installed into the repository.
|
|
18
|
-
- Do not attempt to dramatically alter a component's internal logic unless explicitly requested. Instead, compose standard components (`<Button>`, `<Dialog>`, `<Popover>`) to achieve complex layouts.
|
|
19
|
-
|
|
20
|
-
2. **Tailwind Class Merging:**
|
|
21
|
-
- Always use the `cn()` utility (typically `clsx` and `tailwind-merge`) when allowing custom `className` props to override default Shadcn component styles.
|
|
22
|
-
- Guard against styling regressions when composing UI components.
|
|
23
|
-
|
|
24
|
-
3. **Accessibility (a11y) First:**
|
|
25
|
-
- Radix primitives handle complex WAI-ARIA behavior. Do not try to manually reinvent focus trapping, keyboard navigation, or `aria-*` state logic unless building a component entirely from scratch.
|
|
26
|
-
|
|
27
|
-
4. **Design Tokens:**
|
|
28
|
-
- Always adhere to the project's CSS variables (`--primary`, `--muted`, `--ring`). Do not hardcode arbitrary hex values into Tailwind classes (`bg-[#FF5500]`) when Shadcn standardizes colors via tokens (`bg-primary`).
|
|
29
|
-
|
|
30
|
-
## Execution
|
|
31
|
-
Whenever constructing a new UI feature, declare which Shadcn components are required. If a component is missing, request the user to run the appropriate CLI command (`npx shadcn-ui@latest add <component>`) rather than hallucinating your own inferior baseline component.
|
|
1
|
+
---
|
|
2
|
+
name: shadcn-ui-expert
|
|
3
|
+
description: shadcn/ui mastery. Installation, customization via tailwind.config, component extraction, state management with Radix Primitives, theme variables (CSS custom properties), dark mode implementations, and overriding default designs. Use when building or modifying shadcn/ui components in React/Next.js projects.
|
|
4
|
+
allowed-tools: Read, Write, Edit, Glob, Grep
|
|
5
|
+
version: 2.0.0
|
|
6
|
+
last-updated: 2026-04-02
|
|
7
|
+
applies-to-model: gemini-2.5-pro, claude-3-7-sonnet
|
|
8
|
+
---
|
|
32
9
|
|
|
10
|
+
# shadcn/ui Expert โ Component Architecture Mastery
|
|
33
11
|
|
|
34
12
|
---
|
|
35
13
|
|
|
36
|
-
##
|
|
14
|
+
## 1. Core Architecture
|
|
15
|
+
|
|
16
|
+
shadcn/ui leverages two layers:
|
|
17
|
+
1. **Radix UI Primitives**: Headless, fully accessible functionality (Focus management, ARIA, Keyboard nav).
|
|
18
|
+
2. **Tailwind CSS**: The styling layer mapped over the headless components.
|
|
19
|
+
|
|
20
|
+
```typescript
|
|
21
|
+
// โ BAD: Re-inventing the wheel for accessibility
|
|
22
|
+
const Select = ({ options }) => {
|
|
23
|
+
const [open, setOpen] = useState(false)
|
|
24
|
+
return <div onClick={() => setOpen(!open)}>...</div> // Breaks keyboard/screen readers
|
|
25
|
+
}
|
|
37
26
|
|
|
38
|
-
|
|
27
|
+
// โ
GOOD: Using shadcn (Radix under the hood)
|
|
28
|
+
import { Select, SelectContent, SelectItem, SelectTrigger, SelectValue } from "@/components/ui/select"
|
|
39
29
|
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
30
|
+
export function MySelect() {
|
|
31
|
+
return (
|
|
32
|
+
<Select>
|
|
33
|
+
<SelectTrigger className="w-[180px]">
|
|
34
|
+
<SelectValue placeholder="Theme" />
|
|
35
|
+
</SelectTrigger>
|
|
36
|
+
<SelectContent>
|
|
37
|
+
<SelectItem value="light">Light</SelectItem>
|
|
38
|
+
<SelectItem value="dark">Dark</SelectItem>
|
|
39
|
+
</SelectContent>
|
|
40
|
+
</Select>
|
|
41
|
+
)
|
|
42
|
+
}
|
|
43
|
+
```
|
|
45
44
|
|
|
46
45
|
---
|
|
47
46
|
|
|
48
|
-
##
|
|
47
|
+
## 2. Component Modification (You Own The Code)
|
|
48
|
+
|
|
49
|
+
Do not treat `components/ui/*` as an immutable black box. You are *supposed* to modify them.
|
|
49
50
|
|
|
50
|
-
|
|
51
|
-
**Active reviewers: `logic-reviewer` ยท `security-auditor`**
|
|
51
|
+
### Adding Variants via `cva` (Class Variance Authority)
|
|
52
52
|
|
|
53
|
-
|
|
53
|
+
```typescript
|
|
54
|
+
import { cva, type VariantProps } from "class-variance-authority"
|
|
54
55
|
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
56
|
+
// Adding a new "ghost-rounded" variant to the Button component
|
|
57
|
+
const buttonVariants = cva(
|
|
58
|
+
"inline-flex items-center justify-center whitespace-nowrap rounded-md text-sm font-medium transition-colors...",
|
|
59
|
+
{
|
|
60
|
+
variants: {
|
|
61
|
+
variant: {
|
|
62
|
+
default: "bg-primary text-primary-foreground shadow hover:bg-primary/90",
|
|
63
|
+
destructive: "bg-destructive text-destructive-foreground shadow-sm hover:bg-destructive/90",
|
|
64
|
+
outline: "border border-input bg-background shadow-sm hover:bg-accent hover:text-accent-foreground",
|
|
65
|
+
// YOUR CUSTOM VARIANT:
|
|
66
|
+
"ghost-rounded": "bg-transparent hover:bg-accent hover:text-accent-foreground rounded-full px-6",
|
|
67
|
+
},
|
|
68
|
+
size: {
|
|
69
|
+
default: "h-9 px-4 py-2",
|
|
70
|
+
sm: "h-8 rounded-md px-3 text-xs",
|
|
71
|
+
lg: "h-10 rounded-md px-8",
|
|
72
|
+
icon: "h-9 w-9",
|
|
73
|
+
},
|
|
74
|
+
},
|
|
75
|
+
defaultVariants: {
|
|
76
|
+
variant: "default",
|
|
77
|
+
size: "default",
|
|
78
|
+
},
|
|
79
|
+
}
|
|
80
|
+
)
|
|
81
|
+
```
|
|
58
82
|
|
|
59
|
-
|
|
83
|
+
---
|
|
60
84
|
|
|
61
|
-
|
|
85
|
+
## 3. Theming & Dark Mode (CSS Variables)
|
|
86
|
+
|
|
87
|
+
shadcn/ui manages themes explicitly through CSS custom properties (variables), not Tailwind config hardcoding.
|
|
88
|
+
|
|
89
|
+
```css
|
|
90
|
+
/* app/globals.css */
|
|
91
|
+
@layer base {
|
|
92
|
+
:root {
|
|
93
|
+
--background: 0 0% 100%;
|
|
94
|
+
--foreground: 222.2 84% 4.9%;
|
|
95
|
+
--card: 0 0% 100%;
|
|
96
|
+
--card-foreground: 222.2 84% 4.9%;
|
|
97
|
+
--primary: 221.2 83.2% 53.3%;
|
|
98
|
+
--primary-foreground: 210 40% 98%;
|
|
99
|
+
/* ... */
|
|
100
|
+
--radius: 0.5rem;
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
.dark {
|
|
104
|
+
--background: 222.2 84% 4.9%;
|
|
105
|
+
--foreground: 210 40% 98%;
|
|
106
|
+
--card: 222.2 84% 4.9%;
|
|
107
|
+
--primary: 217.2 91.2% 59.8%;
|
|
108
|
+
/* ... */
|
|
109
|
+
}
|
|
110
|
+
}
|
|
62
111
|
```
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
112
|
+
|
|
113
|
+
Implementation with Tailwind v4 CSS-first configuration:
|
|
114
|
+
```css
|
|
115
|
+
/* Note how standard colors map directly to the CSS vars */
|
|
116
|
+
@theme {
|
|
117
|
+
--color-background: hsl(var(--background));
|
|
118
|
+
--color-foreground: hsl(var(--foreground));
|
|
119
|
+
--color-primary: hsl(var(--primary));
|
|
120
|
+
--color-primary-foreground: hsl(var(--primary-foreground));
|
|
121
|
+
--radius-lg: var(--radius);
|
|
122
|
+
--radius-md: calc(var(--radius) - 2px);
|
|
123
|
+
--radius-sm: calc(var(--radius) - 4px);
|
|
124
|
+
}
|
|
67
125
|
```
|
|
68
126
|
|
|
69
|
-
|
|
127
|
+
---
|
|
128
|
+
|
|
129
|
+
## 4. Using the `cn` Utility
|
|
130
|
+
|
|
131
|
+
The `cn` utility combines `clsx` (conditional classes) and `tailwind-merge` (fixing class conflicts).
|
|
70
132
|
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
133
|
+
```typescript
|
|
134
|
+
import { clsx, type ClassValue } from "clsx"
|
|
135
|
+
import { twMerge } from "tailwind-merge"
|
|
136
|
+
|
|
137
|
+
export function cn(...inputs: ClassValue[]) {
|
|
138
|
+
return twMerge(clsx(inputs))
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
// โ BAD: String concatenation breeds conflicts
|
|
142
|
+
// hover:bg-blue-500 will fail if className contains hover:bg-red-500 earlier
|
|
143
|
+
const className = `px-4 py-2 bg-blue-500 hover:bg-blue-600 ${props.className}`
|
|
144
|
+
|
|
145
|
+
// โ
GOOD: cn resolves conflicts correctly
|
|
146
|
+
const className = cn("px-4 py-2 bg-blue-500 hover:bg-blue-600", props.className)
|
|
147
|
+
```
|
|
148
|
+
|
|
149
|
+
---
|
|
150
|
+
|
|
151
|
+
## 5. Next.js App Router Integration
|
|
152
|
+
|
|
153
|
+
### Modals / Dialogs inside Server Components
|
|
154
|
+
Radix primitives (Dialog, Select, etc.) utilize React context and side effects. They must be Client Components.
|
|
155
|
+
|
|
156
|
+
```typescript
|
|
157
|
+
// โ BAD: Server Component trying to use a shadcn Dialog directly with state
|
|
158
|
+
export default function Page() {
|
|
159
|
+
const [open, setOpen] = useState(false); // ERROR
|
|
160
|
+
return <Dialog open={open}>...</Dialog>
|
|
161
|
+
}
|
|
162
|
+
|
|
163
|
+
// โ
GOOD: Extract the interactive part to a Client Component
|
|
164
|
+
import { MyDialogComponent } from "./MyDialogComponent" // "use client" inside
|
|
165
|
+
|
|
166
|
+
export default async function Page() {
|
|
167
|
+
const data = await fetchDb(); // Server Component fetches data
|
|
168
|
+
return <MyDialogComponent data={data} /> // Passes data to interactive client component
|
|
169
|
+
}
|
|
170
|
+
```
|
|
171
|
+
|
|
172
|
+
---
|
|
@@ -1,68 +1,28 @@
|
|
|
1
|
-
---
|
|
2
|
-
name: skill-creator
|
|
3
|
-
description: Meta-agent specialized in expanding the framework's procedural knowledge by creating new, highly-structured SKILL.md files.
|
|
4
|
-
allowed-tools: Read, Write, Edit, Glob, Grep
|
|
5
|
-
version: 1.0.0
|
|
6
|
-
last-updated: 2026-03-30
|
|
7
|
-
applies-to-model: claude-3-7-sonnet, gemini-2.5-pro
|
|
8
|
-
---
|
|
9
|
-
|
|
10
|
-
# Skill Creator
|
|
11
|
-
|
|
12
|
-
You are a Meta-Agent tasked with defining the capabilities of future AI agents by creating rigorous `SKILL.md` files.
|
|
13
|
-
|
|
14
|
-
## Designing a Skill
|
|
15
|
-
|
|
16
|
-
When asked to generate a new skill, strictly follow this layout:
|
|
17
|
-
|
|
18
|
-
1. **Frontmatter**: Must include `name`, `description` (short, punchy), and `allowed-tools`.
|
|
19
|
-
2. **Title & Identity**: A clear markdown `# Title` and an introductory paragraph specifying the agent's persona.
|
|
20
|
-
3. **Core Directives**: 3-5 rigid bullet points explaining the specific techniques, rules, or anti-patterns for the domain.
|
|
21
|
-
4. **Execution Rules**: How the agent must behave (e.g., verifying inputs prior to writing code, mandatory formatting).
|
|
22
|
-
|
|
23
|
-
## Crucial Principle
|
|
24
|
-
Make the skill files actionable. Abstract advice ("be efficient", "write good code") wastes context window. Define what "good" means by providing strict code constraints (e.g., "Max line length is 100", "Never use global state without an ADR").
|
|
25
|
-
|
|
26
|
-
When you render the file, ensure it is written to `.agent/skills/<skill-name>/SKILL.md`.
|
|
27
|
-
|
|
28
|
-
|
|
29
1
|
---
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
2. **Hallucinated Libraries/Methods:** Using non-existent methods or packages. Always `// VERIFY` or check `package.json` / `requirements.txt`.
|
|
37
|
-
3. **Skipping Edge Cases:** Writing the "happy path" and ignoring error handling, timeouts, or data validation.
|
|
38
|
-
4. **Context Amnesia:** Forgetting the user's constraints and offering generic advice instead of tailored solutions.
|
|
39
|
-
5. **Silent Degradation:** Catching and suppressing errors without logging or re-raising.
|
|
40
|
-
|
|
2
|
+
name: skill-creator
|
|
3
|
+
description: Meta-agent specialized in expanding the framework's procedural knowledge by creating new, highly-structured SKILL.md files.
|
|
4
|
+
allowed-tools: Read, Write, Edit, Glob, Grep
|
|
5
|
+
version: 1.0.0
|
|
6
|
+
last-updated: 2026-03-30
|
|
7
|
+
applies-to-model: claude-3-7-sonnet, gemini-2.5-pro
|
|
41
8
|
---
|
|
42
9
|
|
|
43
|
-
|
|
10
|
+
# Skill Creator
|
|
44
11
|
|
|
45
|
-
|
|
46
|
-
**Active reviewers: `logic-reviewer` ยท `security-auditor`**
|
|
12
|
+
You are a Meta-Agent tasked with defining the capabilities of future AI agents by creating rigorous `SKILL.md` files.
|
|
47
13
|
|
|
48
|
-
|
|
14
|
+
## Designing a Skill
|
|
49
15
|
|
|
50
|
-
|
|
51
|
-
2. **Silent Degradation:** Catching and suppressing errors without logging or handling.
|
|
52
|
-
3. **Context Amnesia:** Forgetting the user's constraints and offering generic advice instead of tailored solutions.
|
|
16
|
+
When asked to generate a new skill, strictly follow this layout:
|
|
53
17
|
|
|
54
|
-
|
|
18
|
+
1. **Frontmatter**: Must include `name`, `description` (short, punchy), and `allowed-tools`.
|
|
19
|
+
2. **Title & Identity**: A clear markdown `# Title` and an introductory paragraph specifying the agent's persona.
|
|
20
|
+
3. **Core Directives**: 3-5 rigid bullet points explaining the specific techniques, rules, or anti-patterns for the domain.
|
|
21
|
+
4. **Execution Rules**: How the agent must behave (e.g., verifying inputs prior to writing code, mandatory formatting).
|
|
55
22
|
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
โ
Did I rely ONLY on real, verified tools and methods?
|
|
59
|
-
โ
Is this solution appropriately scoped to the user's constraints?
|
|
60
|
-
โ
Did I handle potential failure modes and edge cases?
|
|
61
|
-
โ
Have I avoided generic boilerplate that doesn't add value?
|
|
62
|
-
```
|
|
23
|
+
## Crucial Principle
|
|
24
|
+
Make the skill files actionable. Abstract advice ("be efficient", "write good code") wastes context window. Define what "good" means by providing strict code constraints (e.g., "Max line length is 100", "Never use global state without an ADR").
|
|
63
25
|
|
|
64
|
-
|
|
26
|
+
When you render the file, ensure it is written to `.agent/skills/<skill-name>/SKILL.md`.
|
|
65
27
|
|
|
66
|
-
|
|
67
|
-
- โ **Forbidden:** Declaring a task complete because the output "looks correct."
|
|
68
|
-
- โ
**Required:** You are explicitly forbidden from finalizing any task without providing **concrete evidence** (terminal output, passing tests, compile success, or equivalent proof) that your output works as intended.
|
|
28
|
+
---
|