base-ui-react
Scannednpx machina-cli add skill secondsky/claude-skills/base-ui-react --openclawBase UI React
Status: Beta (v1.0.0-beta.4) ⚠️ | Last Verified: 2025-11-18
What Is Base UI?
MUI's unstyled, accessible React component library:
- 27+ accessible components
- Render props pattern
- Full styling control
- Floating UI integration
- Alternative to Radix UI
Beta status: v1.0.0-beta.4 (stable v1.0 expected Q4 2025)
Quick Start
Install
bun add @base-ui-components/react
Basic Dialog
import * as Dialog from '@base-ui-components/react/dialog';
export function MyDialog() {
return (
<Dialog.Root>
<Dialog.Trigger>Open</Dialog.Trigger>
<Dialog.Portal>
<Dialog.Backdrop />
<Dialog.Popup>
<Dialog.Title>Title</Dialog.Title>
<Dialog.Description>Content</Dialog.Description>
<Dialog.Close>Close</Dialog.Close>
</Dialog.Popup>
</Dialog.Portal>
</Dialog.Root>
);
}
Basic Select
import * as Select from '@base-ui-components/react/select';
<Select.Root>
<Select.Trigger>
<Select.Value placeholder="Select" />
</Select.Trigger>
<Select.Portal>
<Select.Positioner>
<Select.Popup>
<Select.Option value="1">Option 1</Select.Option>
<Select.Option value="2">Option 2</Select.Option>
</Select.Popup>
</Select.Positioner>
</Select.Portal>
</Select.Root>
Load references/setup-guide.md for complete examples.
Core Components
Available (27+):
- Dialog
- Select
- Popover
- Tooltip
- Accordion
- NumberField
- Checkbox
- Switch
- Tabs
- Slider
- And more...
Critical Rules
Always Do ✅
- Use Portal for popups (Dialog, Select, Popover)
- Use Positioner for floating elements
- Add Backdrop for modal dialogs
- Style with Tailwind (or any CSS)
- Use render props (not asChild like Radix)
- Test accessibility (ARIA built-in)
- Handle Portal edge cases (SSR, hydration)
- Check beta docs for breaking changes
- Use TypeScript for better DX
- Test on target browsers
Never Do ❌
- Never use asChild (use render function instead)
- Never skip Portal for popups (positioning breaks)
- Never skip Positioner (Floating UI won't work)
- Never assume API stability (beta software)
- Never skip accessibility testing
- Never use with React <19 (requires React 19+)
- Never skip Backdrop for modals
- Never hardcode z-index (use Portal)
- Never skip SSR testing (hydration issues)
- Never assume Radix compatibility (different API)
With Tailwind
<Dialog.Popup className="rounded-lg bg-white p-6 shadow-xl dark:bg-gray-800">
<Dialog.Title className="text-xl font-bold text-gray-900 dark:text-white">
Dialog Title
</Dialog.Title>
<Dialog.Description className="mt-2 text-gray-600 dark:text-gray-300">
Dialog content here
</Dialog.Description>
<Dialog.Close className="mt-4 rounded bg-blue-500 px-4 py-2 text-white hover:bg-blue-600">
Close
</Dialog.Close>
</Dialog.Popup>
Common Use Cases
Use Case 1: Modal Dialog
<Dialog.Root>
<Dialog.Trigger className="btn">Open Modal</Dialog.Trigger>
<Dialog.Portal>
<Dialog.Backdrop className="fixed inset-0 bg-black/50" />
<Dialog.Popup className="fixed left-1/2 top-1/2 -translate-x-1/2 -translate-y-1/2 rounded-lg bg-white p-6">
<Dialog.Title>Confirm Action</Dialog.Title>
<Dialog.Description>Are you sure?</Dialog.Description>
<Dialog.Close>Cancel</Dialog.Close>
</Dialog.Popup>
</Dialog.Portal>
</Dialog.Root>
Use Case 2: Dropdown Select
<Select.Root>
<Select.Trigger className="flex items-center gap-2 rounded border px-4 py-2">
<Select.Value placeholder="Select option" />
</Select.Trigger>
<Select.Portal>
<Select.Positioner className="z-50">
<Select.Popup className="rounded border bg-white shadow-lg">
<Select.Option value="1" className="px-4 py-2 hover:bg-gray-100">
Option 1
</Select.Option>
<Select.Option value="2" className="px-4 py-2 hover:bg-gray-100">
Option 2
</Select.Option>
</Select.Popup>
</Select.Positioner>
</Select.Portal>
</Select.Root>
Use Case 3: Tooltip
import * as Tooltip from '@base-ui-components/react/tooltip';
<Tooltip.Root>
<Tooltip.Trigger>Hover me</Tooltip.Trigger>
<Tooltip.Portal>
<Tooltip.Positioner>
<Tooltip.Popup className="rounded bg-gray-900 px-2 py-1 text-sm text-white">
Tooltip text
</Tooltip.Popup>
</Tooltip.Positioner>
</Tooltip.Portal>
</Tooltip.Root>
Beta Considerations
Stable for production:
- Dialog
- Popover
- Tooltip
- Select
- Accordion
Use with caution:
- NumberField (API may change)
- Complex form components
Migration path:
- v1.0 stable expected Q4 2025
- Breaking changes will be documented
- Codemods likely provided
vs Radix UI
| Feature | Base UI | Radix UI |
|---|---|---|
| Pattern | Render props | asChild |
| Positioning | Floating UI built-in | Manual |
| Beta | Yes | Stable |
| Tree-shaking | Better | Good |
| Bundle size | Smaller | Larger |
When to use Base UI:
- Prefer render props
- Need built-in positioning
- Want smaller bundle
- Okay with beta
When to use Radix:
- Need stability
- Prefer asChild pattern
- Established ecosystem
Resources
References (references/):
example-reference.md- Detailed component examples and patternsmigration-from-radix.md- Complete migration guide from Radix UI (includes render prop pattern explanation)setup-guide.md- Installation and setup walkthrough
Templates (templates/):
Accordion.tsx- Accordion component with render propsDialog.tsx- Modal dialog exampleNumberField.tsx- Number input with validationPopover.tsx- Popover with positioningSelect.tsx- Select dropdownTooltip.tsx- Tooltip componentmigration-example.tsx- Radix to Base UI migration example
Official Documentation
- Base UI: https://base-ui.mui.com/
- Components: https://base-ui.mui.com/components/
- Migration Guide: https://base-ui.mui.com/base-ui/getting-started/migration/
Questions? Issues?
- Check
references/setup-guide.mdfor setup - Review beta status warnings
- See official docs for latest updates
- Consider Radix if need stability
Source
git clone https://github.com/secondsky/claude-skills/blob/main/plugins/base-ui-react/skills/base-ui-react/SKILL.mdView on GitHub Overview
Base UI React is MUI's unstyled yet accessible React component library with Floating UI integration. It offers 27+ components, a render props API, and full styling control, making it a viable Radix UI alternative. The package is in beta (v1.0.0-beta.4) with a stable v1.0 expected in late 2025.
How This Skill Works
Base UI provides unstyled component primitives that rely on Floating UI for precise positioning. Popups and overlays are rendered via portals and positioned with a Positioner, while the render props pattern exposes internal state for customization and accessibility (ARIA) support.
When to Use It
- Build accessible modal dialogs using Dialog (Root, Trigger, Portal, Backdrop, Popup, Title, Description, Close).
- Implement dropdowns, popovers, or tooltips requiring robust positioning.
- Migrate from Radix UI to a compatible, unstyled Base UI solution.
- Need full styling control with CSS/Tailwind while keeping behavior exposed via render props.
- Address positioning or beta-related issues in v1.0 beta and ensure cross-browser compatibility.
Quick Start
- Step 1: Install bun add @base-ui-components/react
- Step 2: Copy the Basic Dialog example and run in a React app
- Step 3: Try a Basic Select example or consult references/setup-guide.md for complete examples
Best Practices
- Use Portal for popups (Dialog, Select, Popover) to avoid clipping and z-index issues.
- Use Positioner for all floating elements to ensure correct placement.
- Always add a Backdrop for modal dialogs to improve focus and accessibility.
- Style with Tailwind (or any CSS) to maintain full styling control over components.
- Prefer render props (not asChild) and test accessibility (ARIA) across target devices and browsers.
Example Use Cases
- Modal Dialog: <Dialog.Root> with Trigger, Portal, Backdrop, Popup, Title, Description, Close.
- Basic Select: <Select.Root> with Trigger, Value, Portal, Positioner, Popup, Options.
- Tailwind-styled Dialog.Popup: applying className like rounded-lg bg-white p-6.
- Radix migration scenario: replace Radix UI usage with Base UI components for a consistent unstyled approach.
- Accessible components: leverage ARIA attributes and render props to build dropdowns, dialogs, and tooltips.