admin9 / blade-daisyui
Blade components for DaisyUI 5 — pure UI, no business logic
Requires
- php: ^8.2
- illuminate/contracts: ^11.0|^12.0
- illuminate/support: ^11.0|^12.0
- spatie/laravel-package-tools: ^1.16
Requires (Dev)
- orchestra/testbench: ^9.0|^10.0
- phpunit/phpunit: ^11.0
README
Blade components for DaisyUI 5 — pure UI, zero business logic.
Provides 65 components as anonymous Blade views with a <x-dui::*> prefix, ready to drop into any Laravel 11/12 project that uses Tailwind CSS + DaisyUI 5.
Requirements
- PHP 8.2+
- Laravel 11 or 12
- Tailwind CSS 4 + DaisyUI 5 (installed in your project)
Installation
composer require admin9/blade-daisyui
The package auto-discovers its service provider. No manual registration needed.
Usage
All components use the dui namespace:
{{-- Button --}} <x-dui::button color="primary">Click me</x-dui::button> {{-- Card --}} <x-dui::card> <x-dui::card.body> <x-dui::card.title>Hello</x-dui::card.title> <p>Card content here.</p> <x-dui::card.actions> <x-dui::button color="primary">Buy Now</x-dui::button> </x-dui::card.actions> </x-dui::card.body> </x-dui::card> {{-- Badge --}} <x-dui::badge color="secondary">New</x-dui::badge> {{-- Alert --}} <x-dui::alert color="info">Heads up!</x-dui::alert> {{-- Modal --}} <x-dui::modal id="my-modal"> <x-dui::modal.box>Modal content</x-dui::modal.box> </x-dui::modal>
Components (65)
Actions
accordion, alert, button, dropdown, fab, loading, modal, progress, radial-progress, skeleton, swap, toast, tooltip
Data Display
avatar, badge, card, carousel, chat, countdown, diff, kbd, list, stat, status, table, timeline
Data Input
calendar, checkbox, fieldset, file-input, filter, input, label, radio, range, rating, select, textarea, toggle, validator
Layout
collapse, divider, dock, drawer, footer, hero, indicator, join, mask, navbar, stack
Navigation
breadcrumbs, link, menu, pagination, steps, tab
Mockup
mockup-browser, mockup-code, mockup-phone, mockup-window
Effects
hover-3d, hover-gallery, text-rotate, theme-controller
Props Convention
Components accept DaisyUI modifier props directly:
| Prop | Type | Description |
|---|---|---|
color |
string | DaisyUI color: primary, secondary, accent, info, success, warning, error |
size |
string | Size modifier: xs, sm, md, lg, xl |
variant |
string | Style variant: outline, soft, dash, ghost, link (component-specific) |
All extra HTML attributes are forwarded to the root element via $attributes->merge().
Customizing Classes
Every component merges your classes with its defaults:
{{-- Adds "mt-4" alongside the built-in "btn btn-primary" --}} <x-dui::button color="primary" class="mt-4">Go</x-dui::button>
Testing
composer test
License
MIT. See LICENSE.md.