Agent Skills: UI Components

UI component library patterns for shadcn/ui and Radix Primitives. Use when building accessible component libraries, customizing shadcn components, using Radix unstyled primitives, or creating design system foundations.

document-asset-creationID: yonatangross/orchestkit/ui-components

Install this agent skill to your local

pnpm dlx add-skill https://github.com/yonatangross/orchestkit/tree/HEAD/src/skills/ui-components

Skill Files

Browse the full folder contents for ui-components.

Download Skill

Loading file tree…

src/skills/ui-components/SKILL.md

Skill Metadata

Name
ui-components
Description
UI component library patterns for shadcn/ui and Radix Primitives. Use when building accessible component libraries, customizing shadcn components, using Radix unstyled primitives, or creating design system foundations.

UI Components

Comprehensive patterns for building accessible UI component libraries with shadcn/ui and Radix Primitives. Covers CVA variants, OKLCH theming, cn() utility, component extension, asChild composition, dialog/menu patterns, and data-attribute styling. Each category has individual rule files in rules/ loaded on-demand.

Quick Reference

| Category | Rules | Impact | When to Use | |----------|-------|--------|-------------| | shadcn/ui | 3 | HIGH | CVA variants, component customization, form patterns, data tables | | Radix Primitives | 3 | HIGH | Dialogs, polymorphic composition, data-attribute styling | | Design System | 5 | HIGH | W3C tokens, OKLCH theming, spacing scales, typography, component states, animation | | Design System Components | 1 | HIGH | Atomic design, CVA variants, accessibility, Storybook | | Forms | 2 | HIGH | React Hook Form v7, Zod validation, Server Actions | | Modern CSS & Tooling | 3 | HIGH | CSS cascade layers, Tailwind v4, Storybook CSF3 | | UX Foundations | 4 | HIGH | Visual hierarchy, typography thresholds, color system, empty states |

Total: 21 rules across 7 categories

Quick Start

// CVA variant system with cn() utility
import { cva, type VariantProps } from 'class-variance-authority'
import { cn } from '@/lib/utils'

const buttonVariants = cva(
  'inline-flex items-center justify-center rounded-md font-medium transition-colors',
  {
    variants: {
      variant: {
        default: 'bg-primary text-primary-foreground hover:bg-primary/90',
        destructive: 'bg-destructive text-destructive-foreground',
        outline: 'border border-input bg-background hover:bg-accent',
        ghost: 'hover:bg-accent hover:text-accent-foreground',
      },
      size: {
        default: 'h-10 px-4 py-2',
        sm: 'h-9 px-3',
        lg: 'h-11 px-8',
      },
    },
    defaultVariants: { variant: 'default', size: 'default' },
  }
)
// Radix Dialog with asChild composition
import { Dialog } from 'radix-ui'

<Dialog.Root>
  <Dialog.Trigger asChild>
    <Button>Open</Button>
  </Dialog.Trigger>
  <Dialog.Portal>
    <Dialog.Overlay className="fixed inset-0 bg-black/50" />
    <Dialog.Content className="data-[state=open]:animate-in">
      <Dialog.Title>Title</Dialog.Title>
      <Dialog.Description>Description</Dialog.Description>
      <Dialog.Close>Close</Dialog.Close>
    </Dialog.Content>
  </Dialog.Portal>
</Dialog.Root>

shadcn/ui

Beautifully designed, accessible components built on CVA variants, cn() utility, and OKLCH theming.

| Rule | File | Key Pattern | |------|------|-------------| | Customization | rules/shadcn-customization.md | CVA variants, cn() utility, OKLCH theming, component extension | | Forms | rules/shadcn-forms.md | Form field wrappers, react-hook-form integration, validation | | Data Table | rules/shadcn-data-table.md | TanStack Table integration, column definitions, sorting/filtering |

Radix Primitives

Unstyled, accessible React primitives for building high-quality design systems.

| Rule | File | Key Pattern | |------|------|-------------| | Dialog | rules/radix-dialog.md | Dialog, AlertDialog, controlled state, animations | | Composition | rules/radix-composition.md | asChild, Slot, nested triggers, polymorphic rendering | | Styling | rules/radix-styling.md | Data attributes, Tailwind arbitrary variants, focus management |

Key Decisions

| Decision | Recommendation | |----------|----------------| | Color format | OKLCH for perceptually uniform theming | | Class merging | Always use cn() for Tailwind conflicts | | Extending components | Wrap, don't modify source files | | Variants | Use CVA for type-safe multi-axis variants | | Styling approach | Data attributes + Tailwind arbitrary variants | | Composition | Use asChild to avoid wrapper divs | | Animation | CSS-only with data-state selectors | | Form components | Combine with react-hook-form |

Anti-Patterns (FORBIDDEN)

  • Modifying shadcn source: Wrap and extend instead of editing generated files
  • Skipping cn(): Direct string concatenation causes Tailwind class conflicts
  • Inline styles over CVA: Use CVA for type-safe, reusable variants
  • Wrapper divs: Use asChild to avoid extra DOM elements
  • Missing Dialog.Title: Every dialog must have an accessible title
  • Positive tabindex: Using tabindex > 0 disrupts natural tab order
  • Color-only states: Use data attributes + multiple indicators
  • Manual focus management: Use Radix built-in focus trapping

Detailed Documentation

| Resource | Description | |----------|-------------| | scripts/ | Templates: CVA component, extended button, dialog, dropdown | | checklists/ | shadcn setup, accessibility audit checklists | | references/ | CVA system, OKLCH theming, cn() utility, focus management |

Design System

Design token architecture, spacing, typography, and interactive component states.

| Rule | File | Key Pattern | |------|------|-------------| | Token Architecture | rules/design-system-tokens.md | W3C tokens, OKLCH colors, Tailwind @theme | | Spacing Scale | rules/design-system-spacing.md | 8px grid, Tailwind space-1 to space-12 | | Typography Scale | rules/design-system-typography.md | Font sizes, weights, line heights | | Component States | rules/design-system-states.md | Hover, focus, active, disabled, loading, animation presets |

Design System Components

Component architecture patterns with atomic design and accessibility.

| Rule | File | Key Pattern | |------|------|-------------| | Component Architecture | rules/design-system-components.md | Atomic design, CVA variants, WCAG 2.1 AA, Storybook |

Forms

React Hook Form v7 with Zod validation and React 19 Server Actions.

| Rule | File | Key Pattern | |------|------|-------------| | React Hook Form | rules/forms-react-hook-form.md | useForm, field arrays, Controller, wizards, file uploads | | Zod & Server Actions | rules/forms-validation-zod.md | Zod schemas, Server Actions, useActionState, async validation |

Modern CSS & Tooling

Modern CSS patterns, Tailwind v4, and component documentation tooling for 2026.

| Rule | File | Key Pattern | |------|------|-------------| | CSS Cascade Layers | rules/css-cascade-layers.md | @layer ordering, specificity-free overrides, third-party isolation | | Tailwind v4 | rules/tailwind-v4-patterns.md | CSS-first @theme, native container queries, @max-* variants | | Storybook Docs | rules/storybook-component-docs.md | CSF3 stories, play() interaction tests, Chromatic visual regression |

UX Foundations

Cognitive-science-grounded UI/UX principles with specific numeric thresholds for production-quality interfaces.

| Rule | File | Key Pattern | |------|------|-------------| | Visual Hierarchy | rules/visual-hierarchy.md | Button tiers, de-emphasis, F/Z scan, Von Restorff, proximity, max-width | | Typography Thresholds | rules/typography-thresholds.md | 65ch line length, 1.4–1.6 line height, rem units, modular type scale | | Color System | rules/color-system.md | OKLCH 9-shade scales, semantic categories, no true black, brand-tinted neutrals | | Empty States | rules/empty-states.md | Skeleton-first, icon + headline + description + CTA, cause-specific tone |

Related Skills

  • ork:accessibility - WCAG compliance and React Aria patterns
  • ork:testing-unit - Component testing patterns