daisyUI 5 is a CSS library for Tailwind CSS daisyUI 5 provides class names for common UI components
tailwind.config.js
file is deprecated in Tailwind CSS v4. do not use tailwind.config.js
. Tailwind CSS v4 only needs @import "tailwindcss";
in the CSS file if it's a node dependency.npm i -D daisyui@latest
and then adding @plugin "daisyui";
to the CSS file<link href="https://cdn.jsdelivr.net/npm/daisyui@5" rel="stylesheet" type="text/css" />
<script src="https://cdn.jsdelivr.net/npm/@tailwindcss/browser@4"></script>
@import "tailwindcss";
@plugin "daisyui";
btn px-10
sets a custom horizontal padding to a btn
!
at the end of the Tailwind CSS utility class to override the existing styles. For example btn bg-red-500!
sets a custom background color to a btn
forcefully. This is a last resort solution and should be used sparinglyflex
and grid
for layout, it should be responsive using Tailwind CSS responsive utility prefixes.bg-base-100 text-base-content
to body unless it's necessarydaisyUI 5 class names are one of the following categories. these type names are only for reference and are not used in the actual code
component
: the required component classpart
: a child part of a componentstyle
: sets a specific style to component or partbehavior
: changes the behavior of component or partcolor
: sets a specific color to component or partsize
: sets a specific size to component or partplacement
: sets a specific placement to component or partdirection
: sets a specific direction to component or partmodifier
: modifies the component or part in a specific waydaisyUI 5 config docs: https://daisyui.com/docs/config/ daisyUI without config:
@plugin "daisyui";
daisyUI config with light
theme only:
@plugin "daisyui" {
themes: light --default;
}
daisyUI with all the default configs:
@plugin "daisyui" {
themes: light --default, dark --prefersdark;
root: ":root";
include: ;
exclude: ;
prefix: ;
logs: true;
}
An example config:
In below config, all the built-in themes are enabled while bumblebee is the default theme and synthwave is the prefersdark theme (default dark mode)
All the other themes are enabled and can be used by adding data-theme="THEME_NAME"
to the <html>
element
root scrollbar gutter is excluded. daisy-
prefix is used for all daisyUI classes and console.log is disabled
@plugin "daisyui" {
themes: light, dark, cupcake, bumblebee --default, emerald, corporate, synthwave --prefersdark, retro, cyberpunk, valentine, halloween, garden, forest, aqua, lofi, pastel, fantasy, wireframe, black, luxury, dracula, cmyk, autumn, business, acid, lemonade, night, coffee, winter, dim, nord, sunset, caramellatte, abyss, silk;
root: ":root";
include: ;
exclude: rootscrollgutter, checkbox;
prefix: daisy-;
logs: false;
}
primary
: Primary brand color, The main color of your brandprimary-content
: Foreground content color to use on primary colorsecondary
: Secondary brand color, The optional, secondary color of your brandsecondary-content
: Foreground content color to use on secondary coloraccent
: Accent brand color, The optional, accent color of your brandaccent-content
: Foreground content color to use on accent colorneutral
: Neutral dark color, For not-saturated parts of UIneutral-content
: Foreground content color to use on neutral colorbase-100
:-100 Base surface color of page, used for blank backgroundsbase-200
:-200 Base color, darker shade, to create elevationsbase-300
:-300 Base color, even more darker shade, to create elevationsbase-content
: Foreground content color to use on base colorinfo
: Info color, For informative/helpful messagesinfo-content
: Foreground content color to use on info colorsuccess
: Success color, For success/safe messagessuccess-content
: Foreground content color to use on success colorwarning
: Warning color, For warning/caution messageswarning-content
: Foreground content color to use on warning colorerror
: Error color, For error/danger/destructive messageserror-content
: Foreground content color to use on error colorbg-primary
will use the primary color for the backgrounddark:
for daisyUI color namesred-500
) is used, it will be same red color on all themesprimary
) is used, it will change color based on the themetext-gray-800
on bg-base-100
would be unreadable on a dark theme - because on dark theme, bg-base-100
is a dark color*-content
colors should have a good contrast compared to their associated colorsbase-*
colors for majority of the page. use primary
color for important elementsA CSS file with Tailwind CSS, daisyUI and a custom daisyUI theme looks like this:
@import "tailwindcss";
@plugin "daisyui";
@plugin "daisyui/theme" {
name: "mytheme";
default: true; /* set as default */
prefersdark: false; /* set as default dark mode (prefers-color-scheme:dark) */
color-scheme: light; /* color of browser-provided UI */
--color-base-100: oklch(98% 0.02 240);
--color-base-200: oklch(95% 0.03 240);
--color-base-300: oklch(92% 0.04 240);
--color-base-content: oklch(20% 0.05 240);
--color-primary: oklch(55% 0.3 240);
--color-primary-content: oklch(98% 0.01 240);
--color-secondary: oklch(70% 0.25 200);
--color-secondary-content: oklch(98% 0.01 200);
--color-accent: oklch(65% 0.25 160);
--color-accent-content: oklch(98% 0.01 160);
--color-neutral: oklch(50% 0.05 240);
--color-neutral-content: oklch(98% 0.01 240);
--color-info: oklch(70% 0.2 220);
--color-info-content: oklch(98% 0.01 220);
--color-success: oklch(65% 0.25 140);
--color-success-content: oklch(98% 0.01 140);
--color-warning: oklch(80% 0.25 80);
--color-warning-content: oklch(20% 0.05 80);
--color-error: oklch(65% 0.3 30);
--color-error-content: oklch(98% 0.01 30);
--radius-selector: 1rem; /* border radius of selectors (checkbox, toggle, badge) */
--radius-field: 0.25rem; /* border radius of fields (button, input, select, tab) */
--radius-box: 0.5rem; /* border radius of boxes (card, modal, alert) */
--size-selector: 0.25rem; /* base size of selectors (checkbox, toggle, badge) */
--size-field: 0.25rem; /* base size of fields (button, input, select, tab) */
--border: 1px; /* border size */
--depth: 1; /* Adds a shadow and subtle 3D effect to components */
--noise: 0; /* Adds a subtle noise effect to components */
}
You can use https://daisyui.com/theme-generator/ to create your own theme
Accordion is used for showing and hiding content but only one item can stay open at a time
collapse
collapse-title
, collapse-content
collapse-arrow
, collapse-plus
, collapse-open
, collapse-close
<div class="collapse {MODIFIER}">{CONTENT}</div>
where content is:
<input type="radio" name="{name}" checked="{checked}" />
<div class="collapse-title">{title}</div>
<div class="collapse-content">{CONTENT}</div>
{checked}
with checked="checked"
if you want the accordion to be open by defaultAlert informs users about important events
alert
alert-outline
, alert-dash
, alert-soft
alert-info
, alert-success
, alert-warning
, alert-error
alert-vertical
, alert-horizontal
<div role="alert" class="alert {MODIFIER}">{CONTENT}</div>
sm:alert-horizontal
for responsive layoutsAvatars are used to show a thumbnail
avatar
, avatar-group
avatar-online
, avatar-offline
, avatar-placeholder
<div class="avatar {MODIFIER}">
<div>
<img src="{image-url}" />
</div>
</div>
avatar-group
for containing multiple avatarsw-*
and h-*
mask-squircle
, mask-hexagon
, mask-triangle
Badges are used to inform the user of the status of specific data
badge
badge-outline
, badge-dash
, badge-soft
, badge-ghost
badge-neutral
, badge-primary
, badge-secondary
, badge-accent
, badge-info
, badge-success
, badge-warning
, badge-error
badge-xs
, badge-sm
, badge-md
, badge-lg
, badge-xl
<span class="badge {MODIFIER}">Badge</span>
Breadcrumbs helps users to navigate
breadcrumbs
<div class="breadcrumbs">
<ul><li><a>Link</a></li></ul>
</div>
max-width
or the list gets larger than the container it will scrollButtons allow the user to take actions
btn
btn-neutral
, btn-primary
, btn-secondary
, btn-accent
, btn-info
, btn-success
, btn-warning
, btn-error
btn-outline
, btn-dash
, btn-soft
, btn-ghost
, btn-link
btn-active
, btn-disabled
btn-xs
, btn-sm
, btn-md
, btn-lg
, btn-xl
btn-wide
, btn-block
, btn-square
, btn-circle
<button class="btn {MODIFIER}">Button</button>
<button>
, <a>
, <input>
tabindex="-1" role="button" aria-disabled="true"
if you want to disable the button using a class nameCalendar includes styles for different calendar libraries
cally (for Cally web component)
pika-single (for the input field that opens Pikaday calendar)
react-day-picker (for the DayPicker component)
For Cally:
<calendar-date class="cally">{CONTENT}</calendar-date>
For Pikaday:
<input type="text" class="input pika-single">
For React Day Picker:
<DayPicker className="react-day-picker">
Cards are used to group and display content
card
card-title
, card-body
, card-actions
card-border
, card-dash
card-side
, image-full
card-xs
, card-sm
, card-md
, card-lg
, card-xl
<div class="card {MODIFIER}">
<figure><img src="{image-url}" alt="{alt-text}" /></figure>
<div class="card-body">
<h2 class="card-title">{title}</h2>
<p>{CONTENT}</p>
<div class="card-actions">{actions}</div>
</div>
</div>
<figure>
and <div class="card-body">
are optionalsm:card-horizontal
for responsive layoutscard-body
, the image will be placed at the bottomCarousel show images or content in a scrollable area
carousel
carousel-item
carousel-start
, carousel-center
, carousel-end
carousel-horizontal
, carousel-vertical
<div class="carousel {MODIFIER}">{CONTENT}</div>
carousel-item
divs: <div class="carousel-item"></div>
w-full
to each carousel itemChat bubbles are used to show one line of conversation and all its data, including the author image, author name, time, etc
chat
chat-image
, chat-header
, chat-footer
, chat-bubble
chat-start
, chat-end
chat-bubble-neutral
, chat-bubble-primary
, chat-bubble-secondary
, chat-bubble-accent
, chat-bubble-info
, chat-bubble-success
, chat-bubble-warning
, chat-bubble-error
<div class="chat {PLACEMENT}">
<div class="chat-image"></div>
<div class="chat-header"></div>
<div class="chat-bubble {COLOR}">Message text</div>
<div class="chat-footer"></div>
</div>
chat-start
or chat-end
<div class="chat-image avatar">
and nest the avatar content insideCheckboxes are used to select or deselect a value
checkbox
checkbox-primary
, checkbox-secondary
, checkbox-accent
, checkbox-neutral
, checkbox-success
, checkbox-warning
, checkbox-info
, checkbox-error
checkbox-xs
, checkbox-sm
, checkbox-md
, checkbox-lg
, checkbox-xl
<input type="checkbox" class="checkbox {MODIFIER}" />
Collapse is used for showing and hiding content
collapse
collapse-title
, collapse-content
collapse-arrow
, collapse-plus
, collapse-open
, collapse-close
<div tabindex="0" class="collapse {MODIFIER}">
<div class="collapse-title">{title}</div>
<div class="collapse-content">{CONTENT}</div>
</div>
tabindex="0"
, you can use <input type="checkbox">
as a first childCountdown gives you a transition effect when you change a number between 0 to 99
countdown
<span class="countdown">
<span style="--value:{number};">number</span>
</span>
--value
CSS variable and text must be a number between 0 and 99--value
CSS variable using JSaria-live="polite"
and aria-label="{number}"
so screen readers can properly read changesDiff component shows a side-by-side comparison of two items
diff
diff-item-1
, diff-item-2
, diff-resizer
<figure class="diff">
<div class="diff-item-1">{item1}</div>
<div class="diff-item-2">{item2}</div>
<div class="diff-resizer"></div>
</figure>
aspect-16/9
or other aspect ratio classes to <figure class="diff">
elementDivider will be used to separate content vertically or horizontally
divider
divider-neutral
, divider-primary
, divider-secondary
, divider-accent
, divider-success
, divider-warning
, divider-info
, divider-error
divider-vertical
, divider-horizontal
divider-start
, divider-end
<div class="divider {MODIFIER}">{text}</div>
Dock (also know as Bottom navigation or Bottom bar) is a UI element that provides navigation options to the user. Dock sticks to the bottom of the screen
dock
dock-label
dock-active
dock-xs
, dock-sm
, dock-md
, dock-lg
, dock-xl
<div class="dock {MODIFIER}">{CONTENT}</div>
where content is a list of buttons:
<button>
<svg>{icon}</svg>
<span class="dock-label">Text</span>
</button>
dock-active
class to the button<meta name="viewport" content="viewport-fit=cover">
is required for responsivness of the dock in iOSDrawer is a grid layout that can show/hide a sidebar on the left or right side of the page
drawer
drawer-toggle
, drawer-content
, drawer-side
, drawer-overlay
drawer-end
drawer-open
<div class="drawer {MODIFIER}">
<input id="my-drawer" type="checkbox" class="drawer-toggle" />
<div class="drawer-content">{CONTENT}</div>
<div class="drawer-side">{SIDEBAR}</div>
</div>
where {CONTENT} can be navbar, site content, footer, etc and {SIDEBAR} can be a menu like:
<ul class="menu p-4 w-80 min-h-full bg-base-100 text-base-content">
<li><a>Item 1</a></li>
<li><a>Item 2</a></li>
</ul>
id
is required for the drawer-toggle
input. change my-drawer
to a unique id according to your needslg:drawer-open
can be used to make sidebar visible on larger screensdrawer-toggle
is a hidden checkbox. Use label with "for" attribute to toggle state<label for="my-drawer" class="btn drawer-button">Open drawer</label>
where my-drawer
is the id of the drawer-toggle
inputdrawer-content
element. for example navbar, footer, etc should not be outside of drawer
Dropdown can open a menu or any other element when the button is clicked
dropdown
dropdown-content
dropdown-start
, dropdown-center
, dropdown-end
, dropdown-top
, dropdown-bottom
, dropdown-left
, dropdown-right
dropdown-hover
, dropdown-open
Using details and summary
<details class="dropdown">
<summary>Button</summary>
<ul class="dropdown-content">{CONTENT}</ul>
</details>
Using popover API
<button popovertarget="{id}" style="anchor-name:--{anchor}">{button}</button>
<ul class="dropdown-content" popover id="{id}" style="position-anchor:--{anchor}">{CONTENT}</ul>
Using CSS focus
<div class="dropdown">
<div tabindex="0" role="button">Button</div>
<ul tabindex="0" class="dropdown-content">{CONTENT}</ul>
</div>
{id}
and {anchor}
with a unique nametabindex="0"
and role="button"
on the button<ul>
)Fieldset is a container for grouping related form elements. It includes fieldset-legend as a title and fieldset-label as a description
fieldset
fieldset-legend
, fieldset-label
<fieldset class="fieldset">
<legend class="fieldset-legend">{title}</legend>
{CONTENT}
<p class="fieldset-label">{description}</p>
</fieldset>
File Input is a an input field for uploading files
file-input
file-input-ghost
file-input-neutral
, file-input-primary
, file-input-secondary
, file-input-accent
, file-input-info
, file-input-success
, file-input-warning
, file-input-error
file-input-xs
, file-input-sm
, file-input-md
, file-input-lg
, file-input-xl
<input type="file" class="file-input {MODIFIER}" />
Filter is a group of radio buttons. Choosing one of the options will hide the others and shows a reset button next to the chosen option
filter
filter-reset
Using HTML form
<form class="filter">
<input class="btn btn-square" type="reset" value="×"/>
<input class="btn" type="radio" name="{name}" aria-label="{label}"/>
</form>
Without HTML form
<div class="filter">
<input class="btn filter-reset" type="radio" name="{name}" aria-label="{label}"/>
<input class="btn" type="radio" name="{name}" aria-label="{label}"/>
</div>
{name}
and {label}
with proper values for each radio inputname
attributes to avoid conflicts<form>
tag when possible and only use <div>
if you can't use a HTML form for some reasonfilter-reset
class for the reset buttonFooter can contain logo, copyright notice, and links to other pages
footer
footer-title
footer-center
footer-horizontal
, footer-vertical
<footer class="footer {MODIFIER}">{CONTENT}</footer>
where content can contain several <nav>
tags with footer-title
and links inside
sm:footer-horizontal
to make footer responsivebase-200
for background colorHero is a component for displaying a large box or image with a title and description
hero
hero-content
, hero-overlay
<div class="hero {MODIFIER}">{CONTENT}</div>
hero-content
for the text contenthero-overlay
inside the hero to overlay the background image with a colorIndicators are used to place an element on the corner of another element
indicator
indicator-item
indicator-start
, indicator-center
, indicator-end
, indicator-top
, indicator-middle
, indicator-bottom
<div class="indicator">
<span class="indicator-item">{indicator content}</span>
<div>{main content}</div>
</div>
indicator-item
class) before the main contentindicator-end indicator-top
Text Input is a simple input field
input
input-ghost
input-neutral
, input-primary
, input-secondary
, input-accent
, input-info
, input-success
, input-warning
, input-error
input-xs
, input-sm
, input-md
, input-lg
, input-xl
<input type="{type}" placeholder="Type here" class="input {MODIFIER}" />
input
class for the parent when you have more than one element inside inputJoin is a container for grouping multiple items, it can be used to group buttons, inputs, etc. Join applies border radius to the first and last item. Join can be used to create a horizontal or vertical list of items
join
, join-item
join-vertical
, join-horizontal
<div class="join {MODIFIER}">{CONTENT}</div>
join-item
will be affectedlg:join-horizontal
for responsive layoutsKbd is used to display keyboard shortcuts
kbd
kbd-xs
, kbd-sm
, kbd-md
, kbd-lg
, kbd-xl
<kbd class="kbd {MODIFIER}">K</kbd>
Label is used to provide a name or title for an input field. Label can be placed before or after the field
label
, floating-label
For regular label:
<label class="input">
<span class="label">{label text}</span>
<input type="text" placeholder="Type here" />
</label>
For floating label:
<label class="floating-label">
<input type="text" placeholder="Type here" class="input" />
<span>{label text}</span>
</label>
input
class is for styling the parent element which contains the input field and label, so the label does not have the 'input' classfloating-label
for the parent of an input field and a span that floats above the input field when the field is focusedLink adds the missing underline style to links
link
link-hover
link-neutral
, link-primary
, link-secondary
, link-accent
, link-success
, link-info
, link-warning
, link-error
<a class="link {MODIFIER}">Click me</a>
List is a vertical layout to display information in rows
list
, list-row
list-col-wrap
, list-col-grow
<ul class="list">
<li class="list-row">{CONTENT}</li>
</ul>
list-row
for each item inside the listlist-row
will fill the remaining space. You can use list-col-grow
on another child to make it fill the remaining space insteadlist-col-wrap
to force an item to wrap to the next lineLoading shows an animation to indicate that something is loading
loading
loading-spinner
, loading-dots
, loading-ring
, loading-ball
, loading-bars
, loading-infinity
loading-xs
, loading-sm
, loading-md
, loading-lg
, loading-xl
<span class="loading {MODIFIER}"></span>
Mask crops the content of the element to common shapes
mask
mask-squircle
, mask-heart
, mask-hexagon
, mask-hexagon-2
, mask-decagon
, mask-pentagon
, mask-diamond
, mask-square
, mask-circle
, mask-star
, mask-star-2
, mask-triangle
, mask-triangle-2
, mask-triangle-3
, mask-triangle-4
mask-half-1
, mask-half-2
<img class="mask {MODIFIER}" src="{image-url}" />
mask
class namesw-*
and h-*
Menu is used to display a list of links vertically or horizontally
menu
menu-title
, menu-dropdown
, menu-dropdown-toggle
menu-disabled
, menu-active
, menu-focus
, menu-dropdown-show
menu-xs
, menu-sm
, menu-md
, menu-lg
, menu-xl
menu-vertical
, menu-horizontal
Vertical menu:
<ul class="menu">
<li><button>Item</button></li>
</ul>
Horizontal menu:
<ul class="menu menu-horizontal">
<li><button>Item</button></li>
</ul>
lg:menu-horizontal
for responsive layoutsmenu-title
for list item title<details>
tag to make submenus collapsiblemenu-dropdown
and menu-dropdown-toggle
to toggle the dropdown using JSBrowser mockup shows a box that looks like a browser window
mockup-browser
mockup-browser-toolbar
<div class="mockup-browser">
<div class="mockup-browser-toolbar">
{toolbar content}
</div>
<div>{CONTENT}</div>
</div>
mockup-browser
class nameinput
classCode mockup is used to show a block of code in a box that looks like a code editor
mockup-code
<div class="mockup-code">
<pre data-prefix="$"><code>npm i daisyui</code></pre>
</div>
<pre data-prefix="{prefix}">
to show a prefix before each line<code>
tag to add code syntax highlighting (requires additional library)Phone mockup shows a mockup of an iPhone
mockup-phone
mockup-phone-camera
, mockup-phone-display
<div class="mockup-phone">
<div class="mockup-phone-camera"></div>
<div class="mockup-phone-display">{CONTENT}</div>
</div>
mockup-phone-display
you can add anythingWindow mockup shows a box that looks like an operating system window
mockup-window
<div class="mockup-window">
<div>{CONTENT}</div>
</div>
Modal is used to show a dialog or a box when you click a button
modal
modal-box
, modal-action
, modal-backdrop
, modal-toggle
modal-open
modal-top
, modal-middle
, modal-bottom
, modal-start
, modal-end
Using HTML dialog element
<button onclick="my_modal.showModal()">Open modal</button>
<dialog id="my_modal" class="modal">
<div class="modal-box">{CONTENT}</div>
<form method="dialog" class="modal-backdrop"><button>close</button></form>
</dialog>
Using checkbox (legacy)
<label for="my-modal" class="btn">Open modal</label>
<input type="checkbox" id="my-modal" class="modal-toggle" />
<div class="modal">
<div class="modal-box">{CONTENT}</div>
<label class="modal-backdrop" for="my-modal">Close</label>
</div>
Using anchor links (legacy)
<a href="#my-modal" class="btn">Open modal</a>
<div class="modal" id="my-modal">
<div class="modal-box">{CONTENT}</div>
</div>
tabindex="0"
to make modal focusable<form method="dialog">
for closing the modal with submitNavbar is used to show a navigation bar on the top of the page
navbar
navbar-start
, navbar-center
, navbar-end
<div class="navbar">{CONTENT}</div>
navbar-start
, navbar-center
, navbar-end
to position content horizontallybase-200
for background colorPagination is a group of buttons
join
join-item
join-vertical
, join-horizontal
<div class="join">{CONTENT}</div>
join-item
for each button or link inside the paginationbtn
class for styling pagination itemsProgress bar can be used to show the progress of a task or to show the passing of time
progress
progress-neutral
, progress-primary
, progress-secondary
, progress-accent
, progress-info
, progress-success
, progress-warning
, progress-error
<progress class="progress {MODIFIER}" value="50" max="100"></progress>
Radial progress can be used to show the progress of a task or to show the passing of time
radial-progress
<div class="radial-progress" style="--value:70;" aria-valuenow="70" role="progressbar">70%</div>
--value
CSS variable and text must be a number between 0 and 100aria-valuenow="{value}"
, aria-valuenow={value}
so screen readers can properly read value and also show that its a progress element to themdiv
instead of progress because browsers can't show text inside progress tag--size
for setting size (default 5rem) and --thickness
to set how thick the indicator isRadio buttons allow the user to select one option
radio
radio-neutral
, radio-primary
, radio-secondary
, radio-accent
, radio-success
, radio-warning
, radio-info
, radio-error
radio-xs
, radio-sm
, radio-md
, radio-lg
, radio-xl
<input type="radio" name="{name}" class="radio {MODIFIER}" />
name
attributes to avoid conflicts with other sets of radio inputs on the same pageRange slider is used to select a value by sliding a handle
range
range-neutral
, range-primary
, range-secondary
, range-accent
, range-success
, range-warning
, range-info
, range-error
range-xs
, range-sm
, range-md
, range-lg
, range-xl
<input type="range" min="0" max="100" value="40" class="range {MODIFIER}" />
min
and max
attributesRating is a set of radio buttons that allow the user to rate something
rating
rating-half
, rating-hidden
rating-xs
, rating-sm
, rating-md
, rating-lg
, rating-xl
<div class="rating {MODIFIER}">
<input type="radio" name="rating-1" class="mask mask-star" />
</div>
name
attributes to avoid conflicts with other ratings on the same pagerating-hidden
for the first radio to make it hidden so user can clear the ratingSelect is used to pick a value from a list of options
select
select-ghost
select-neutral
, select-primary
, select-secondary
, select-accent
, select-info
, select-success
, select-warning
, select-error
select-xs
, select-sm
, select-md
, select-lg
, select-xl
<select class="select {MODIFIER}">
<option>Option</option>
</select>
Skeleton is a component that can be used to show a loading state
skeleton
<div class="skeleton"></div>
h-*
and w-*
utility classes to set height and widthStack visually puts elements on top of each other
stack
stack-top
, stack-bottom
, stack-start
, stack-end
<div class="stack {MODIFIER}">{CONTENT}</div>
w-*
and h-*
classes to set the width and height of the stack, making all items the same sizeStat is used to show numbers and data in a block
stats
stat
, stat-title
, stat-value
, stat-desc
, stat-figure
, stat-actions
stats-horizontal
, stats-vertical
<div class="stats {MODIFIER}">
<div class="stat">{CONTENT}</div>
</div>
stats-vertical
classstat-title
, stat-value
, stat-desc
inside a stat
Status is a really small icon to visually show the current status of an element, like online, offline, error, etc
status
status-neutral
, status-primary
, status-secondary
, status-accent
, status-info
, status-success
, status-warning
, status-error
status-xs
, status-sm
, status-md
, status-lg
, status-xl
<span class="status {MODIFIER}"></span>
Steps can be used to show a list of steps in a process
steps
step
, step-icon
step-neutral
, step-primary
, step-secondary
, step-accent
, step-info
, step-success
, step-warning
, step-error
steps-vertical
, steps-horizontal
<ul class="steps {MODIFIER}">
<li class="step">{step content}</li>
</ul>
step-primary
classstep-icon
classdata-content
,use data-content="{value}"
at the <li>
Swap allows you to toggle the visibility of two elements using a checkbox or a class name
swap
swap-on
, swap-off
, swap-indeterminate
swap-active
swap-rotate
, swap-flip
Using checkbox
<label class="swap {MODIFIER}">
<input type="checkbox" />
<div class="swap-on">{content when active}</div>
<div class="swap-off">{content when inactive}</div>
</label>
Using class name
<div class="swap {MODIFIER}">
<div class="swap-on">{content when active}</div>
<div class="swap-off">{content when inactive}</div>
</div>
swap-active
class using JS to control stateswap-indeterminate
classTabs can be used to show a list of links in a tabbed format
tabs
tab
, tab-content
tabs-box
, tabs-border
, tabs-lift
tab-active
, tab-disabled
tabs-top
, tabs-bottom
Using buttons:
<div role="tablist" class="tabs {MODIFIER}">
<button role="tab" class="tab">Tab</button>
</div>
Using radio inputs:
<div role="tablist" class="tabs tabs-box">
<input type="radio" name="my_tabs" class="tab" aria-label="Tab" />
</div>
Table can be used to show a list of data in a table format
table
table-zebra
, table-pin-rows
, table-pin-cols
table-xs
, table-sm
, table-md
, table-lg
, table-xl
<div class="overflow-x-auto">
<table class="table {MODIFIER}">
<thead>
<tr>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<th></th>
</tr>
</tbody>
</table>
</div>
overflow-x-auto
class is added to the wrapper div to make the table horizontally scrollable on smaller screensTextarea allows users to enter text in multiple lines
textarea
textarea-ghost
textarea-neutral
, textarea-primary
, textarea-secondary
, textarea-accent
, textarea-info
, textarea-success
, textarea-warning
, textarea-error
textarea-xs
, textarea-sm
, textarea-md
, textarea-lg
, textarea-xl
<textarea class="textarea {MODIFIER}" placeholder="Bio"></textarea>
If a checked checkbox input or a checked radio input with theme-controller class exists in the page, The page will have the same theme as that input's value
theme-controller
<input type="checkbox" value="{theme-name}" class="theme-controller" />
Timeline component shows a list of events in chronological order
timeline
timeline-start
, timeline-middle
, timeline-end
timeline-snap-icon
, timeline-box
, timeline-compact
timeline-vertical
, timeline-horizontal
<ul class="timeline {MODIFIER}">
<li>
<div class="timeline-start">{start}</div>
<div class="timeline-middle">{icon}</div>
<div class="timeline-end">{end}</div>
</li>
</ul>
timeline-vertical
class to the ul
element or just do nothing (because its the default style.)timeline-snap-icon
to snap the icon to the start instead of middletimeline-compact
class to force all items on one sideToast is a wrapper to stack elements, positioned on the corner of page
toast
toast-start
, toast-center
, toast-end
, toast-top
, toast-middle
, toast-bottom
<div class="toast {MODIFIER}">{CONTENT}</div>
Toggle is a checkbox that is styled to look like a switch button
toggle
toggle-primary
, toggle-secondary
, toggle-accent
, toggle-neutral
, toggle-success
, toggle-warning
, toggle-info
, toggle-error
toggle-xs
, toggle-sm
, toggle-md
, toggle-lg
, toggle-xl
<input type="checkbox" class="toggle {MODIFIER}" />
Validator class changes the color of form elements to error or success based on input's validation rules
validator
validator-hint
<input type="{type}" class="input validator" required />
<p class="validator-hint">Error message</p>
input
, select
, textarea