Kushi

Components playground

button

Paste into the :require section of your :ns form:
[kushi.ui.button.core :refer [button]]]
Use the data-kui-surface attributes :solid, :outline, and :minimal to control the surface variant of the button.
[button "Button"]
[button {:-surface :solid} "Button"]
[button {:-surface :outline} "Button"]
[button {:-surface :minimal} "Button"]

button

Paste into the :require section of your :ns form:
[kushi.ui.button.core :refer [button]]]
Use the data-kui-colorway attributes :neutral, :accent, :positive, :warning, and :negative to control the semantic color variant. The default is :neutral.
[button "Button"]
[button {:-colorway :neutral} "Button"]
[button {:-colorway :accent} "Button"]
[button {:-colorway :positive} "Button"]
[button {:-colorway :warning} "Button"]
[button {:-colorway :negative} "Button"]

button

Paste into the :require section of your :ns form:
[kushi.ui.button.core :refer [button]]]
Use the data-kui-shape attributes :pill, :rounded, and :sharp to control the surface variant of the button. The default is :rounded.
[button "Button"]
[button {:-shape :rounded} "Button"]
[button {:-shape :pill} "Button"]
[button {:-shape :sharp} "Button"]

button

Paste into the :require section of your :ns form:
[kushi.ui.button.core :refer [button]]
[kushi.ui.icon.core :refer [icon icon-button]]
[kushi.ui.label.core :refer [label]]]
Check out the icon component for detailed info on icon usage Various buttons with icons:
[button "Button" [icon :play-arrow]]
[button
 [icon :auto-awesome]
 "Wow"
 [icon :auto-awesome]]

button

Paste into the :require section of your :ns form:
[kushi.ui.button.core :refer [button]]]
[:div
 [button "Play"]
 [button (sx :.xxxsmall) "Play"]
 [button (sx :.xxsmall) "Play"]
 [button (sx :.xsmall) "Play"]
 [button (sx :.small) "Play"]
 [button (sx :.medium) "Play"]
 [button (sx :.large) "Play"]
 [button (sx :.xlarge) "Play"]
 [button (sx :.xxlarge) "Play"]
 [button (sx :.xxxlarge) "Play"]]

button

Paste into the :require section of your :ns form:
[kushi.ui.button.core :refer [button]]]
Use the font-weight utility classes :.thin ~ :.heavy to control the weight. Scale of weights:
[:div
 [button "Wow"]
 [button (sx :.thin) "Wow"]
 [button (sx :.extra-light) "Wow"]
 [button (sx :.light) "Wow"]
 [button (sx :.normal) "Wow"]
 [button (sx :.wee-bold) "Wow"]
 [button (sx :.semi-bold) "Wow"]
 [button (sx :.bold) "Wow"]
 [button (sx :.extra-bold) "Wow"]
 [button (sx :.heavy) "Wow"]]

button

Paste into the :require section of your :ns form:
[kushi.ui.button.core :refer [button]]
[kushi.ui.icon.core :refer [icon]]
[kushi.ui.spinner.core
  :refer
  [spinner donut propeller thinking]]]
Examples:
[button
 {:-loading? true}
 [spinner [icon :play-arrow] [propeller]]
 "Play"]
[button {:disabled true} "Play"]

icon

Paste into the :require section of your :ns form:
[kushi.ui.icon.core :refer [icon]]]
[icon (sx :.small :.extra-bold) :star]
[icon (sx :.xxxlarge :.light) :star]
[icon (sx :.medium :.normal) :star]
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star

icon

Paste into the :require section of your :ns form:
[kushi.ui.icon.core :refer [icon]]]
[icon (sx :fs--48px :.extra-bold) :star]
[icon (sx :fs--48px :.light) :star]
[icon (sx :fs--48px :.normal) :star]
star
star
star
star
star
star
star
star
star
star
star
star

icon

Paste into the :require section of your :ns form:
[kushi.ui.icon.core :refer [icon]]]
[:div
 [icon (sx :c--$gray-500) :star]
 [icon (sx :c--$blue-500) :star]
 [icon (sx :c--$green-500) :star]
 [icon (sx :c--$yellow-500) :star]
 [icon (sx :c--$red-500) :star]
 [icon (sx :c--$purple-500) :star]
 [icon (sx :c--$lime-500) :star]
 [icon (sx :c--$brown-500) :star]
 [icon (sx :c--$orange-500) :star]
 [icon (sx :c--$magenta-500) :star]]
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star

icon

Paste into the :require section of your :ns form:
[kushi.ui.icon.core :refer [icon]]]
[icon {:-icon-filled? true} :star]
auto_awesome
auto_awesome
help
help
info
info
favorite
favorite
settings
settings
filter_alt
filter_alt
cloud_upload
cloud_upload
download
download
delete
delete
cancel
cancel
auto_awesome_motion
auto_awesome_motion
archive
archive
sell
sell
visibility
visibility
visibility_off
visibility_off
report_problem
report_problem
check_circle
check_circle
error
error
edit
edit
folder
folder
smartphone
smartphone
star
star
add_circle
add_circle
expand_circle_down
expand_circle_down
auto_awesome
auto_awesome
help
help
info
info
favorite
favorite
settings
settings
filter_alt
filter_alt
cloud_upload
cloud_upload
download
download
delete
delete
cancel
cancel
auto_awesome_motion
auto_awesome_motion
archive
archive
sell
sell
visibility
visibility
visibility_off
visibility_off
report_problem
report_problem
check_circle
check_circle
error
error
edit
edit
folder
folder
smartphone
smartphone
star
star
add_circle
add_circle
expand_circle_down
expand_circle_down

icon

Paste into the :require section of your :ns form:
[kushi.ui.icon.core :refer [icon]]]
[:div
 [icon :search]
 [icon :playlist-add]
 [icon :expand]
 [icon :compress]
 [icon :arrow-back]
 [icon :arrow-forward]
 [icon :sort]
 [icon :clear]
 [icon :keyboard-return]
 [icon :check]
 [icon :find-replace]
 [icon :open-in-new]
 [icon :fingerprint]
 [icon :refresh]
 [icon :download]
 [icon :menu]]
search
playlist_add
expand
compress
arrow_back
arrow_forward
sort
clear
keyboard_return
check
find_replace
open_in_new
fingerprint
refresh
download
menu
search
playlist_add
expand
compress
arrow_back
arrow_forward
sort
clear
keyboard_return
check
find_replace
open_in_new
fingerprint
refresh
download
menu

spinner

Paste into the :require section of your :ns form:
[kushi.ui.spinner.core
  :refer
  [spinner donut propeller thinking]]]
[propeller (sx :.small)]
[propeller (sx :.large)]
[propeller (sx :.xxxlarge)]

spinner

Paste into the :require section of your :ns form:
[kushi.ui.spinner.core
  :refer
  [spinner donut propeller thinking]]]
[:div
 [propeller (sx :c--$gray-500)]
 [propeller (sx :c--$blue-500)]
 [propeller (sx :c--$green-500)]
 [propeller (sx :c--$yellow-500)]
 [propeller (sx :c--$red-500)]
 [propeller (sx :c--$purple-500)]
 [propeller (sx :c--$lime-500)]
 [propeller (sx :c--$brown-500)]
 [propeller (sx :c--$orange-500)]
 [propeller (sx :c--$magenta-500)]]
[:div
 [propeller (sx :.foreground-gray)]
 [propeller (sx :.foreground-blue)]
 [propeller (sx :.foreground-green)]
 [propeller (sx :.foreground-yellow)]
 [propeller (sx :.foreground-red)]
 [propeller (sx :.foreground-purple)]
 [propeller (sx :.foreground-lime)]
 [propeller (sx :.foreground-brown)]
 [propeller (sx :.foreground-orange)]
 [propeller (sx :.foreground-magenta)]]

spinner

Paste into the :require section of your :ns form:
[kushi.ui.spinner.core
  :refer
  [spinner donut propeller thinking]]]
[donut (sx :.small)]
[donut (sx :.large)]
[donut (sx :.xxxlarge)]

spinner

Paste into the :require section of your :ns form:
[kushi.ui.spinner.core
  :refer
  [spinner donut propeller thinking]]]
[:div
 [donut (sx :c--$gray-500)]
 [donut (sx :c--$blue-500)]
 [donut (sx :c--$green-500)]
 [donut (sx :c--$yellow-500)]
 [donut (sx :c--$red-500)]
 [donut (sx :c--$purple-500)]
 [donut (sx :c--$lime-500)]
 [donut (sx :c--$brown-500)]
 [donut (sx :c--$orange-500)]
 [donut (sx :c--$magenta-500)]]
[:div
 [donut (sx :.foreground-gray)]
 [donut (sx :.foreground-blue)]
 [donut (sx :.foreground-green)]
 [donut (sx :.foreground-yellow)]
 [donut (sx :.foreground-red)]
 [donut (sx :.foreground-purple)]
 [donut (sx :.foreground-lime)]
 [donut (sx :.foreground-brown)]
 [donut (sx :.foreground-orange)]
 [donut (sx :.foreground-magenta)]]

spinner

Paste into the :require section of your :ns form:
[kushi.ui.spinner.core
  :refer
  [spinner donut propeller thinking]]]
[thinking (sx :.small)]
[thinking (sx :.large)]
[thinking (sx :.xxxlarge)]

spinner

Paste into the :require section of your :ns form:
[kushi.ui.spinner.core
  :refer
  [spinner donut propeller thinking]]]
[:div
 [thinking (sx :c--$gray-500)]
 [thinking (sx :c--$blue-500)]
 [thinking (sx :c--$green-500)]
 [thinking (sx :c--$yellow-500)]
 [thinking (sx :c--$red-500)]
 [thinking (sx :c--$purple-500)]
 [thinking (sx :c--$lime-500)]
 [thinking (sx :c--$brown-500)]
 [thinking (sx :c--$orange-500)]
 [thinking (sx :c--$magenta-500)]]
[:div
 [thinking (sx :.foreground-gray)]
 [thinking (sx :.foreground-blue)]
 [thinking (sx :.foreground-green)]
 [thinking (sx :.foreground-yellow)]
 [thinking (sx :.foreground-red)]
 [thinking (sx :.foreground-purple)]
 [thinking (sx :.foreground-lime)]
 [thinking (sx :.foreground-brown)]
 [thinking (sx :.foreground-orange)]
 [thinking (sx :.foreground-magenta)]]

radio

Paste into the :require section of your :ns form:
[kushi.ui.radio.core :refer [radio]]]
[:div
 [radio
  (merge-attrs
   (sx :.xxxlarge)
   {:-input-attrs
    {:name :xxxlarge-sample,
     :defaultChecked true}})]
 [radio
  (merge-attrs
   (sx :.xxxlarge)
   {:-input-attrs {:name :xxxlarge-sample}})]]

radio

Paste into the :require section of your :ns form:
[kushi.ui.radio.core :refer [radio]]]
[:section
 (sx :.flex-row-fs)
 [radio {:-input-attrs {:name :demo}} "Yes"]
 [radio {:-input-attrs {:name :demo}} "No"]
 [radio {:-input-attrs {:name :demo}} "Maybe"]]

radio

Paste into the :require section of your :ns form:
[kushi.ui.radio.core :refer [radio]]]
[:section
 (sx
  :.flex-row-fs
  :c--$purple-600
  :dark:c--$purple-300)
 [radio {:-input-attrs {:name :demo}} "Yes"]
 [radio {:-input-attrs {:name :demo}} "No"]
 [radio {:-input-attrs {:name :demo}} "Maybe"]]

radio

Paste into the :require section of your :ns form:
[kushi.ui.radio.core :refer [radio]]]
[:section
 (sx
  :d--grid
  :xsm:gtc--1fr
  :xsm:gtc--1fr:1fr
  :row-gap--1em
  :column-gap--2em
  [:_.emoji
   {:fs :28px,
    :mi :0.33em,
    :filter "grayscale(1)",
    :transition-property :transform,
    :transition-duration :500ms}]
  [:_.kushi-radio-input:checked+.kushi-label>.emoji
   {:filter :none,
    :transform "scale(1.5)",
    :animation :jiggle2:0.5s}])
 [radio
  (merge-attrs
   (sx :.normal)
   {:-input-attrs
    {:name :demo-custom, :defaultChecked true}})
  [label [:span.emoji "🦑"] "Squid"]]
 [radio
  (merge-attrs
   (sx :.normal)
   {:-input-attrs {:name :demo-custom}})
  [label [:span.emoji "🐋"] "Whale"]]
 [radio
  (merge-attrs
   (sx :.normal)
   {:-input-attrs {:name :demo-custom}})
  [label [:span.emoji "🦈 "] "Shark"]]
 [radio
  (merge-attrs
   (sx :.normal)
   {:-input-attrs {:name :demo-custom}})
  [label [:span.emoji "🐊"] "Croc"]]]

switch

Paste into the :require section of your :ns form:
[kushi.ui.switch.core :refer [switch]]]
[:div
 [switch]
 [switch {:-colorway :neutral}]
 [switch {:-colorway :accent}]
 [switch {:-colorway :positive}]
 [switch {:-colorway :warning}]
 [switch {:-colorway :negative}]]

switch

Paste into the :require section of your :ns form:
[kushi.ui.switch.core :refer [switch]]]
[:div
 [switch]
 [switch (sx :.xxxsmall)]
 [switch (sx :.xxsmall)]
 [switch (sx :.xsmall)]
 [switch (sx :.small)]
 [switch (sx :.medium)]
 [switch (sx :.large)]
 [switch (sx :.xlarge)]
 [switch (sx :.xxlarge)]
 [switch (sx :.xxxlarge)]]

switch

Paste into the :require section of your :ns form:
[kushi.ui.switch.core :refer [switch]]]
[switch
 {:-thumb-attrs
  (sx :bgi--$convex :dark:bgi--$convex-3)}]

switch

Paste into the :require section of your :ns form:
[kushi.ui.switch.core :refer [switch]]]
[switch
 (merge-attrs
  (sx
   [:--switch-border-width :0px]
   [:--switch-thumb-scale-factor :1.25])
  {:-thumb-attrs
   (sx :border--1px:solid:currentColor)})]

switch

Paste into the :require section of your :ns form:
[kushi.ui.switch.core :refer [switch]]]
[switch
 (merge-attrs
  (sx [:--switch-width-ratio :2.25])
  {:-track-content-on "ON",
   :-track-content-off "OFF"})]

switch

Paste into the :require section of your :ns form:
[kushi.ui.switch.core :refer [switch]]]
[switch
 {:-thumb-content-on
  [:span (sx :.semi-bold :fs--0.3em) "ON"],
  :-thumb-content-off
  [:span (sx :.semi-bold :fs--0.3em) "OFF"]}]

switch

Paste into the :require section of your :ns form:
[kushi.ui.switch.core :refer [switch]]
[kushi.ui.icon.core :refer [icon]]]
[switch
 {:-track-content-on
  [icon
   (merge-attrs
    (sx :fs--0.55em)
    {:-icon-filled? true})
   :visibility],
  :-track-content-off
  [icon
   (merge-attrs
    (sx :fs--0.55em)
    {:-icon-filled? true})
   :visibility-off]}]

switch

Paste into the :require section of your :ns form:
[kushi.ui.switch.core :refer [switch]]
[kushi.ui.icon.core :refer [icon]]]
[switch
 {:-thumb-content-on
  [icon
   (merge-attrs
    (sx :fs--0.55em)
    {:-icon-filled? true})
   :visibility],
  :-thumb-content-off
  [icon
   (merge-attrs
    (sx :fs--0.55em)
    {:-icon-filled? true})
   :visibility-off]}]

switch

Paste into the :require section of your :ns form:
[kushi.ui.switch.core :refer [switch]]]
[switch {:disabled true}]

checkbox

Paste into the :require section of your :ns form:
[kushi.ui.radio.core :refer [radio]]]
[checkbox
 (merge-attrs
  (sx :fs--$xxxlarge)
  {:-input-attrs
   {:name :xxxlarge-sample,
    :defaultChecked true}})]

checkbox

Paste into the :require section of your :ns form:
[kushi.ui.radio.core :refer [radio]]]
[[label "Sign me up"]]

slider

Paste into the :require section of your :ns form:
[kushi.ui.slider.core :refer [slider]]]
[slider {:min 0, :max 100, :step 1}]
0

slider

Paste into the :require section of your :ns form:
[kushi.ui.slider.core :refer [slider]]]
[slider
 {:min 0,
  :max 100,
  :step 1,
  :-current-value-label-position :thumb-bottom}]
0

slider

Paste into the :require section of your :ns form:
[kushi.ui.slider.core :refer [slider]]]
[slider
 {:min 0,
  :max 100,
  :step 1,
  :-current-value-label-position
  :track-inline-start}]
0

slider

Paste into the :require section of your :ns form:
[kushi.ui.slider.core :refer [slider]]]
[slider
 {:min 0,
  :max 100,
  :step 1,
  :-current-value-label-position
  :track-inline-end}]
0

slider

Paste into the :require section of your :ns form:
[kushi.ui.slider.core :refer [slider]]]
[slider
 {:min 0,
  :max 7,
  :-step-marker :label,
  :-current-value-label-position :track-left}]
01234567

slider

Paste into the :require section of your :ns form:
[kushi.ui.slider.core :refer [slider]]]
[slider {:min 0, :max 7, :-step-marker :dot}]
01234567

slider

Paste into the :require section of your :ns form:
[kushi.ui.slider.core :refer [slider]]]
[slider {:min 0, :max 7, :-step-marker :bar}]
01234567

slider

Paste into the :require section of your :ns form:
[kushi.ui.slider.core :refer [slider]]]
[slider
 {:min 0,
  :max 7,
  :-step-marker :bar,
  :-display-current-value? false}]
01234567

slider

Paste into the :require section of your :ns form:
[kushi.ui.slider.core :refer [slider]]]
[slider
 {:min 0,
  :max 100,
  :step 1,
  :-current-value-label-display-fn
  (fn*
   [p1__28867#]
   (.toFixed (/ p1__28867# 100) 2))}]
0

slider

Paste into the :require section of your :ns form:
[kushi.ui.slider.core :refer [slider]]]
[slider
 {:-steps ["xsmall" "medium" "large" "xlarge"],
  :-step-marker :label,
  :-label-size-class :medium}]
xsmallmediumlargexlarge

slider

Paste into the :require section of your :ns form:
[kushi.ui.slider.core :refer [slider]]]
[slider
 {:-steps
  ["First label is long"
   "Second label"
   "Third label"
   "Last label is long"],
  :-step-marker :dot,
  :-label-size-class :small,
  :-labels-attrs
  (sx
   [:_.kushi-slider-step-label:first-child>span:translate
    :-25%:-50%]
   [:_.kushi-slider-step-label:last-child>span:translate
    :-75%:-50%])}]
First label is longSecond labelThird labelLast label is long

text field

Paste into the :require section of your :ns form:
[kushi.ui.text-field.core :refer [text-field]]]
[text-field
 {:placeholder "Your text here",
  :-label "Input label",
  :-helper "My helper text"}]
My helper text

text field

Paste into the :require section of your :ns form:
[kushi.ui.text-field.core :refer [text-field]]]
[text-field
 {:placeholder "Your text here",
  :required true,
  :-label "Input label",
  :-helper "My helper text"}]
My helper text

text field

Paste into the :require section of your :ns form:
[kushi.ui.text-field.core :refer [text-field]]]
[text-field
 {:placeholder "Your text here",
  :disabled true,
  :-label "Input label",
  :-helper "My helper text"}]
My helper text

text field

Paste into the :require section of your :ns form:
[kushi.ui.text-field.core :refer [text-field]]]
[text-field
 {:placeholder "Your text here",
  :-label "Input label",
  :-helper "Your helper text here"}]
Your helper text here

text field

Paste into the :require section of your :ns form:
[kushi.ui.text-field.core :refer [text-field]]]
[text-field
 {:placeholder "Your text here",
  :-start-enhancer "$",
  :-label "Input label"}]
$

text field

Paste into the :require section of your :ns form:
[kushi.ui.text-field.core :refer [text-field]]]
[text-field
 {:placeholder "Your text here",
  :-end-enhancer [icon :star],
  :-label "Input label"}]
star

text field

Paste into the :require section of your :ns form:
[kushi.ui.text-field.core :refer [text-field]]]
[text-field
 {:placeholder "Your text here",
  :-textarea? true,
  :-label "Input label",
  :-helper "My helper text"}]
My helper text

text field

Paste into the :require section of your :ns form:
[kushi.ui.text-field.core :refer [text-field]]]
[text-field
 {:-colorway :accent,
  :-label-attrs
  (sx :bgc--$yellow-50 :dark:bgc--$yellow-900),
  :placeholder "Your text here",
  :disabled false,
  :-end-enhancer "🦄",
  :-helper "Your helper text here",
  :-start-enhancer "$",
  :-wrapper-attrs
  (sx
   :box-shadow--4px:4px:7px:#f2baf9ab
   :dark:box-shadow--4px:4px:7px:#b000c66e
   {:class :my-input-wrapper-name}),
  :-outer-wrapper-attrs
  (sx
   :b--1px:solid:yellow
   :dark:b--1px:solid:#c419b5
   :box-shadow--8px:8px:17px:#b000c66e
   :dark:box-shadow--8px:8px:17px:#b000c66e
   :p--1em),
  :required false,
  :-label "Input label"}]
$
🦄
Your helper text here

tooltip

Paste into the :require section of your :ns form:
[kushi.ui.tooltip.core :refer [tooltip-attrs]]
[kushi.ui.button.core :refer [button]]]
[button
 (tooltip-attrs {:-text "This is a tooltip"})
 "Hover me"]

tooltip

Paste into the :require section of your :ns form:
[kushi.ui.tooltip.core :refer [tooltip-attrs]]
[kushi.ui.button.core :refer [button]]]
[button
 (tooltip-attrs
  {:-text "This is a tooltip",
   :-tooltip-class
   (css
    {:--tooltip-font-size :34px,
     :--tooltip-background-color :$red-800,
     :--tooltip-background-color-dark-mode
     :$red-300})})
 "Hover me"]
:brc:br:b:bl:blc:rt:lt:r:l:rb:lb:trc:tr:t:tl:tlc

popover

Paste into the :require section of your :ns form:
[kushi.ui.popover.core
  :refer
  [popover-attrs dismiss-popover!]]
[kushi.ui.button.core :refer [button]]
 [reagent.dom :refer [render]]]
(popover-attrs
 {:-f
  (fn
   [popover-el]
   (rdom/render
    (fn
     []
     [:div
      (sx
       :.flex-row-c
       :fs--$xxxlarge
       :padding--0.25em)
      "💃🏽"])
    popover-el))})

popover

Paste into the :require section of your :ns form:
[kushi.ui.popover.core
  :refer
  [popover-attrs dismiss-popover!]]
[kushi.ui.button.core :refer [button]]
 [reagent.dom :refer [render]]]
(popover-attrs
 {:-popover-class
  (css
   {:--popover-background-color :$purple-100,
    :--popover-background-color-dark-mode
    :$purple-900}),
  :-f
  (fn
   [popover-el]
   (rdom/render
    (fn
     []
     [:div
      (sx
       :.flex-row-c
       :fs--$xxxlarge
       :padding--0.25em)
      "💃🏽"])
    popover-el))})

modal

Paste into the :require section of your :ns form:
[kushi.ui.modal.core
  :refer
  [modal
   modal-close-button
   open-kushi-modal
   close-kushi-modal]]
[kushi.ui.button.core :refer [button]]]
(let
 [id "my-modal-basic"]
 [:div
  [button
   {:on-click (fn* [] (open-kushi-modal id))}
   "Click to open modal"]
  [modal
   (merge-attrs
    (sx
     :min-width--300px
     :_.kushi-modal-description:fs--$small)
    {:id id})
   [:div (sx :.xxxlarge :.flex-row-c) "💃🏽"]]])
💃🏽

Example modal

Example modal description goes here.

Example modal

Example modal description goes here.

Example modal

Example modal description goes here.

Example modal

Example modal description goes here.

toast

Paste into the :require section of your :ns form:
[kushi.ui.toast.core
  :refer
  [toast-attrs dismiss-toast!]]
[kushi.ui.button.core :refer [button]]]
[button
 (toast-attrs
  {:-auto-dismiss? false,
   :-f
   (fn
    [toast-el]
    (rdom/render toast-content toast-el))})
 "Save for later"]

card

Paste into the :require section of your :ns form:
[kushi.ui.card.core :refer [card]]]
[card (sx :fs--xxlarge) "My content"]
🐻‍❄

Polar Bear

polar.bear@example.com

🐻‍❄

Polar Bear

polar.bear@example.com

🐻‍❄

Polar Bear

polar.bear@example.com

🐻‍❄

Polar Bear

polar.bear@example.com

🐻‍❄

Polar Bear

polar.bear@example.com

🐻‍❄

Polar Bear

polar.bear@example.com

🐻‍❄

Polar Bear

polar.bear@example.com

🐻‍❄

Polar Bear

polar.bear@example.com

🐻‍❄

Polar Bear

polar.bear@example.com

🐻‍❄

Polar Bear

polar.bear@example.com

alien

tag

Paste into the :require section of your :ns form:
[kushi.ui.tag.core :refer [tag]]]
[:div
 [tag "Done"]
 [tag (sx :.xxxsmall) "Done"]
 [tag (sx :.xxsmall) "Done"]
 [tag (sx :.xsmall) "Done"]
 [tag (sx :.small) "Done"]
 [tag (sx :.medium) "Done"]
 [tag (sx :.large) "Done"]
 [tag (sx :.xlarge) "Done"]
 [tag (sx :.xxlarge) "Done"]
 [tag (sx :.xxxlarge) "Done"]]
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done

callout

Paste into the :require section of your :ns form:
[kushi.ui.callout.core :refer [callout]]]
[callout
 (merge-attrs
  (sx :.large)
  {:-header-text
   [:span
    "Please check out the "
    [link
     (merge-attrs (sx :ws--n) {:href "#"})
     "new features"]],
   :-colorway :accent,
   :-icon [icon :info]})]
info
Please check out the new features
info
Please check out the new features
info
Please check out the new features
info
Please check out the new features
info
Please check out the new features
check_circle
Your transaction was successful.
info
Please check out the new features
info
Please check out the new features
info
Please check out the new features
info
Please check out the new features
info
Please check out the new features
info
Please check out the new features
info
Your transaction was successful
info
Your transaction was successful
info
Your transaction was successful
info
Time to update. Take action.
info
Time to update. Take action.
info
Time to update. Take action.
info
Something went wrong. Learn more.
info
Something went wrong. Learn more.
info
Something went wrong. Learn more.

collapse

Paste into the :require section of your :ns form:
[kushi.ui.collapse.core :refer [collapse]]]
[collapse
 {:-label "Collapsable section label"}
 [:p "Child 1"]
 [:p "Child 2"]]

collapse

Paste into the :require section of your :ns form:
[kushi.ui.collapse.core :refer [collapse]]]
[collapse
 {:-label "Click to expand",
  :-label-expanded "Click to collapse"}
 [:p "Child 1"]
 [:p "Child 2"]]

collapse

Paste into the :require section of your :ns form:
[kushi.ui.collapse.core :refer [collapse]]]
[collapse
 {:-label "Collapsable section label ",
  :-icon-position :end}
 [:p "Child 1"]
 [:p "Child 2"]]

collapse

Paste into the :require section of your :ns form:
[kushi.ui.collapse.core :refer [collapse]]]
[collapse
 (merge-attrs
  (sx
   :bbe--1px:solid:$neutral-800
   :dark:bbe--1px:solid:$neutral-400)
  {:-label "Collapsable section label ",
   :-header-attrs
   (sx
    :bbs--1px:solid:$neutral-800
    :dark:bbs--1px:solid:$neutral-400)})
 [:p "Child 1"]
 [:p "Child 2"]]

collapse

Paste into the :require section of your :ns form:
[kushi.ui.collapse.core :refer [collapse]]]
[collapse
 {:-label "Collapsable section label ",
  :-header-attrs (sx :fw--$bold)}
 [:p "Child 1"]
 [:p "Child 2"]]

collapse

Paste into the :require section of your :ns form:
[kushi.ui.collapse.core :refer [collapse]]]
[collapse
 {:-label "Collapsable section label ",
  :-body-attrs
  (sx
   :bgc--$purple-100
   :dark:bgc--$purple-900
   :pis--1rem),
  :-speed 1000}
 [:section
  (sx :pb--0.5rem)
  [:p "Child 1"]
  [:p "Child 2"]
  [:p "Child 3"]
  [:p "Child 4"]
  [:p "Child 5"]]]

collapse

Paste into the :require section of your :ns form:
[kushi.ui.collapse.core :refer [collapse]]]
[collapse
 {:class
  (css
   :border-block--3px:solid:$purple-100
   :dark:border-block--3px:solid:$purple-850),
  :-label "Collapsable section label ",
  :-body-attrs (sx :pis--0.5rem),
  :-header-attrs
  (sx
   :fw--$semi-bold
   :p--10px
   :bgc--$purple-100
   :dark:bgc--$purple-850)}
 [:p "Child 1"]
 [:p "Child 2"]]

collapse

Paste into the :require section of your :ns form:
[kushi.ui.collapse.core :refer [collapse]]]
[collapse
 {:-label "Collapsable section label",
  :-on-click (fn* [] (js/alert "clicked"))}
 [:p "Child 1"]
 [:p "Child 2"]]

grid

Paste into the :require section of your :ns form:
[kushi.ui.grid.core :refer [grid]]]
[grid
 (sx
  :>div:bgc--$neutral-150
  :dark:>div:bgc--$neutral-800)
 (for
  [x (range 6)]
  [:div
   [:div
    (sx :.absolute-fill :.flex-col-c :ai--c)
    (inc x)]])]
1
2
3
4
5
6

grid

Paste into the :require section of your :ns form:
[kushi.ui.grid.core :refer [grid]]]
[grid
 (merge-attrs
  (sx
   :>div:bgc--$neutral-150
   :dark:>div:bgc--$neutral-800)
  {:-column-min-width :80px,
   :-gap :15px,
   :-aspect-ratio :2:3})
 (for
  [x (range 25)]
  [:div
   [:div
    (sx :.absolute-fill :.flex-col-c :ai--c)
    (inc x)]])]
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25

Colors

Kushi includes a foundation of global and alias color tokens.

Semantic alias tokens map to global tokens like so:

--positive200--green200--negative400--red400--warning300--yellow300--accent600--blue600--neutral50--neutral50

gray

All --gray* values on the scale have a corresponding --neutral* alias token

50$gray-50
TextTextTextText
100$gray-100
TextTextTextText
150$gray-150
TextTextTextText
200$gray-200
TextTextTextText
250$gray-250
TextTextTextText
300$gray-300
TextTextTextText
350$gray-350
TextTextTextText
400$gray-400
TextTextTextText
450$gray-450
TextTextTextText
500$gray-500
TextTextTextText
550$gray-550
TextTextTextText
600$gray-600
TextTextTextText
650$gray-650
TextTextTextText
700$gray-700
TextTextTextText
750$gray-750
TextTextTextText
800$gray-800
TextTextTextText
850$gray-850
TextTextTextText
900$gray-900
TextTextTextText
950$gray-950
TextTextTextText
1000$gray-1000
TextTextTextText

red

All --red* values on the scale have a corresponding --negative* alias token

50$red-50
TextTextTextText
100$red-100
TextTextTextText
150$red-150
TextTextTextText
200$red-200
TextTextTextText
250$red-250
TextTextTextText
300$red-300
TextTextTextText
350$red-350
TextTextTextText
400$red-400
TextTextTextText
450$red-450
TextTextTextText
500$red-500
TextTextTextText
550$red-550
TextTextTextText
600$red-600
TextTextTextText
650$red-650
TextTextTextText
700$red-700
TextTextTextText
750$red-750
TextTextTextText
800$red-800
TextTextTextText
850$red-850
TextTextTextText
900$red-900
TextTextTextText
950$red-950
TextTextTextText
1000$red-1000
TextTextTextText

orange

50$orange-50
TextTextTextText
100$orange-100
TextTextTextText
150$orange-150
TextTextTextText
200$orange-200
TextTextTextText
250$orange-250
TextTextTextText
300$orange-300
TextTextTextText
350$orange-350
TextTextTextText
400$orange-400
TextTextTextText
450$orange-450
TextTextTextText
500$orange-500
TextTextTextText
550$orange-550
TextTextTextText
600$orange-600
TextTextTextText
650$orange-650
TextTextTextText
700$orange-700
TextTextTextText
750$orange-750
TextTextTextText
800$orange-800
TextTextTextText
850$orange-850
TextTextTextText
900$orange-900
TextTextTextText
950$orange-950
TextTextTextText
1000$orange-1000
TextTextTextText

gold

All --gold* values on the scale have a corresponding --warning* alias token

50$gold-50
TextTextTextText
100$gold-100
TextTextTextText
150$gold-150
TextTextTextText
200$gold-200
TextTextTextText
250$gold-250
TextTextTextText
300$gold-300
TextTextTextText
350$gold-350
TextTextTextText
400$gold-400
TextTextTextText
450$gold-450
TextTextTextText
500$gold-500
TextTextTextText
550$gold-550
TextTextTextText
600$gold-600
TextTextTextText
650$gold-650
TextTextTextText
700$gold-700
TextTextTextText
750$gold-750
TextTextTextText
800$gold-800
TextTextTextText
850$gold-850
TextTextTextText
900$gold-900
TextTextTextText
950$gold-950
TextTextTextText
1000$gold-1000
TextTextTextText

yellow

50$yellow-50
TextTextTextText
100$yellow-100
TextTextTextText
150$yellow-150
TextTextTextText
200$yellow-200
TextTextTextText
250$yellow-250
TextTextTextText
300$yellow-300
TextTextTextText
350$yellow-350
TextTextTextText
400$yellow-400
TextTextTextText
450$yellow-450
TextTextTextText
500$yellow-500
TextTextTextText
550$yellow-550
TextTextTextText
600$yellow-600
TextTextTextText
650$yellow-650
TextTextTextText
700$yellow-700
TextTextTextText
750$yellow-750
TextTextTextText
800$yellow-800
TextTextTextText
850$yellow-850
TextTextTextText
900$yellow-900
TextTextTextText
950$yellow-950
TextTextTextText
1000$yellow-1000
TextTextTextText

green

All --green* values on the scale have a corresponding --positive* alias token

50$green-50
TextTextTextText
100$green-100
TextTextTextText
150$green-150
TextTextTextText
200$green-200
TextTextTextText
250$green-250
TextTextTextText
300$green-300
TextTextTextText
350$green-350
TextTextTextText
400$green-400
TextTextTextText
450$green-450
TextTextTextText
500$green-500
TextTextTextText
550$green-550
TextTextTextText
600$green-600
TextTextTextText
650$green-650
TextTextTextText
700$green-700
TextTextTextText
750$green-750
TextTextTextText
800$green-800
TextTextTextText
850$green-850
TextTextTextText
900$green-900
TextTextTextText
950$green-950
TextTextTextText
1000$green-1000
TextTextTextText

blue

All --blue* values on the scale have a corresponding --accent* alias token

50$blue-50
TextTextTextText
100$blue-100
TextTextTextText
150$blue-150
TextTextTextText
200$blue-200
TextTextTextText
250$blue-250
TextTextTextText
300$blue-300
TextTextTextText
350$blue-350
TextTextTextText
400$blue-400
TextTextTextText
450$blue-450
TextTextTextText
500$blue-500
TextTextTextText
550$blue-550
TextTextTextText
600$blue-600
TextTextTextText
650$blue-650
TextTextTextText
700$blue-700
TextTextTextText
750$blue-750
TextTextTextText
800$blue-800
TextTextTextText
850$blue-850
TextTextTextText
900$blue-900
TextTextTextText
950$blue-950
TextTextTextText
1000$blue-1000
TextTextTextText

purple

50$purple-50
TextTextTextText
100$purple-100
TextTextTextText
150$purple-150
TextTextTextText
200$purple-200
TextTextTextText
250$purple-250
TextTextTextText
300$purple-300
TextTextTextText
350$purple-350
TextTextTextText
400$purple-400
TextTextTextText
450$purple-450
TextTextTextText
500$purple-500
TextTextTextText
550$purple-550
TextTextTextText
600$purple-600
TextTextTextText
650$purple-650
TextTextTextText
700$purple-700
TextTextTextText
750$purple-750
TextTextTextText
800$purple-800
TextTextTextText
850$purple-850
TextTextTextText
900$purple-900
TextTextTextText
950$purple-950
TextTextTextText
1000$purple-1000
TextTextTextText

magenta

50$magenta-50
TextTextTextText
100$magenta-100
TextTextTextText
150$magenta-150
TextTextTextText
200$magenta-200
TextTextTextText
250$magenta-250
TextTextTextText
300$magenta-300
TextTextTextText
350$magenta-350
TextTextTextText
400$magenta-400
TextTextTextText
450$magenta-450
TextTextTextText
500$magenta-500
TextTextTextText
550$magenta-550
TextTextTextText
600$magenta-600
TextTextTextText
650$magenta-650
TextTextTextText
700$magenta-700
TextTextTextText
750$magenta-750
TextTextTextText
800$magenta-800
TextTextTextText
850$magenta-850
TextTextTextText
900$magenta-900
TextTextTextText
950$magenta-950
TextTextTextText
1000$magenta-1000
TextTextTextText

brown

50$brown-50
TextTextTextText
100$brown-100
TextTextTextText
150$brown-150
TextTextTextText
200$brown-200
TextTextTextText
250$brown-250
TextTextTextText
300$brown-300
TextTextTextText
350$brown-350
TextTextTextText
400$brown-400
TextTextTextText
450$brown-450
TextTextTextText
500$brown-500
TextTextTextText
550$brown-550
TextTextTextText
600$brown-600
TextTextTextText
650$brown-650
TextTextTextText
700$brown-700
TextTextTextText
750$brown-750
TextTextTextText
800$brown-800
TextTextTextText
850$brown-850
TextTextTextText
900$brown-900
TextTextTextText
950$brown-950
TextTextTextText
1000$brown-1000
TextTextTextText

Typography

Kushi includes a foundation of global tokens and utility class scales for type size, weight, letter-spacing, sizing, and capitalization.

[:span
 (sx
  :.xxlarge
  :.bold
  :.xloose
  :.uppercase
  :.italic)
 "My text"]
[:span
 (sx
  :fs--$xxlarge
  :fw--$bold
  :letter-spacing--$xloose)
 "My text "]

The following utility classes are available for font-style and capitalization::.sans:.serif:.italic:.oblique:.uppercase:.lowercase:.capitalize

Kushi employes the typefaces Inter and Fira Code by default.
These can be changed via the following tokens in the [:theme :design-tokens] entry in your theming config map (in kushi.edn file):
:.--sans-serif-font-stack:.--serif-font-stack:.--code-font-stack

Type size scale

Kushi offers a typographic sizing scale with t-shirt sizing fromxxxsmallup toxxxxlarge.

The quick brown fox.
The quick brown fox.
The quick brown fox.
The quick brown fox.
The quick brown fox.
The quick brown fox.
The quick brown fox.
The quick brown fox.
The quick brown fox.
The quick brown fox.

Type weight scale

Kushi offers a typographic weight scale with t-shirt sizing fromthinup toheavy.

The quick brown fox.
The quick brown fox.
The quick brown fox.
The quick brown fox.
The quick brown fox.
The quick brown fox.
The quick brown fox.
The quick brown fox.
The quick brown fox.

Type tracking scale

Kushi offers a typographic tracking scale with t-shirt sizing fromxxxtightup toxxxxloose.

The quick brown fox.
The quick brown fox.
The quick brown fox.
The quick brown fox.
The quick brown fox.
The quick brown fox.
The quick brown fox.
The quick brown fox.

A Readymade Foundation for UI

Kushi is a base for building web UI with ClojureScript.

grid

Paste into the :require section of your :ns form:
[kushi.ui.grid.core :refer [grid]]]
[grid
 (sx
  :>div:bgc--$neutral-150
  :dark:>div:bgc--$neutral-800)
 (for
  [x (range 6)]
  [:div
   [:div
    (sx :.absolute-fill :.flex-col-c :ai--c)
    (inc x)]])]
1
2
3
4
5
6

grid

Paste into the :require section of your :ns form:
[kushi.ui.grid.core :refer [grid]]]
[grid
 (merge-attrs
  (sx
   :>div:bgc--$neutral-150
   :dark:>div:bgc--$neutral-800)
  {:-column-min-width :80px,
   :-gap :15px,
   :-aspect-ratio :2:3})
 (for
  [x (range 25)]
  [:div
   [:div
    (sx :.absolute-fill :.flex-col-c :ai--c)
    (inc x)]])]
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25

slider

Paste into the :require section of your :ns form:
[kushi.ui.slider.core :refer [slider]]]
[slider
 {:min 0,
  :max 100,
  :step 1,
  :-current-value-label-position
  :track-inline-end}]
0

slider

Paste into the :require section of your :ns form:
[kushi.ui.slider.core :refer [slider]]]
[slider
 {:min 0,
  :max 7,
  :-step-marker :label,
  :-current-value-label-position :track-left}]
01234567

slider

Paste into the :require section of your :ns form:
[kushi.ui.slider.core :refer [slider]]]
[slider
 {:min 0,
  :max 7,
  :-step-marker :bar,
  :-display-current-value? false}]
01234567

slider

Paste into the :require section of your :ns form:
[kushi.ui.slider.core :refer [slider]]]
[slider
 {:-steps ["xsmall" "medium" "large" "xlarge"],
  :-step-marker :label,
  :-label-size-class :medium}]
xsmallmediumlargexlarge

slider

Paste into the :require section of your :ns form:
[kushi.ui.slider.core :refer [slider]]]
[slider
 {:-steps
  ["First label is long"
   "Second label"
   "Third label"
   "Last label is long"],
  :-step-marker :dot,
  :-label-size-class :small,
  :-labels-attrs
  (sx
   [:_.kushi-slider-step-label:first-child>span:translate
    :-25%:-50%]
   [:_.kushi-slider-step-label:last-child>span:translate
    :-75%:-50%])}]
First label is longSecond labelThird labelLast label is long
:brc:br:b:bl:blc:rt:lt:r:l:rb:lb:trc:tr:t:tl:tlc

tag

Paste into the :require section of your :ns form:
[kushi.ui.tag.core :refer [tag]]]
[:div
 [tag "Done"]
 [tag (sx :.xxxsmall) "Done"]
 [tag (sx :.xxsmall) "Done"]
 [tag (sx :.xsmall) "Done"]
 [tag (sx :.small) "Done"]
 [tag (sx :.medium) "Done"]
 [tag (sx :.large) "Done"]
 [tag (sx :.xlarge) "Done"]
 [tag (sx :.xxlarge) "Done"]
 [tag (sx :.xxxlarge) "Done"]]
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done
Done

spinner

Paste into the :require section of your :ns form:
[kushi.ui.spinner.core
  :refer
  [spinner donut propeller thinking]]]
[propeller (sx :.small)]
[propeller (sx :.large)]
[propeller (sx :.xxxlarge)]

spinner

Paste into the :require section of your :ns form:
[kushi.ui.spinner.core
  :refer
  [spinner donut propeller thinking]]]
[:div
 [propeller (sx :c--$gray-500)]
 [propeller (sx :c--$blue-500)]
 [propeller (sx :c--$green-500)]
 [propeller (sx :c--$yellow-500)]
 [propeller (sx :c--$red-500)]
 [propeller (sx :c--$purple-500)]
 [propeller (sx :c--$lime-500)]
 [propeller (sx :c--$brown-500)]
 [propeller (sx :c--$orange-500)]
 [propeller (sx :c--$magenta-500)]]
[:div
 [propeller (sx :.foreground-gray)]
 [propeller (sx :.foreground-blue)]
 [propeller (sx :.foreground-green)]
 [propeller (sx :.foreground-yellow)]
 [propeller (sx :.foreground-red)]
 [propeller (sx :.foreground-purple)]
 [propeller (sx :.foreground-lime)]
 [propeller (sx :.foreground-brown)]
 [propeller (sx :.foreground-orange)]
 [propeller (sx :.foreground-magenta)]]

spinner

Paste into the :require section of your :ns form:
[kushi.ui.spinner.core
  :refer
  [spinner donut propeller thinking]]]
[donut (sx :.small)]
[donut (sx :.large)]
[donut (sx :.xxxlarge)]

spinner

Paste into the :require section of your :ns form:
[kushi.ui.spinner.core
  :refer
  [spinner donut propeller thinking]]]
[:div
 [donut (sx :c--$gray-500)]
 [donut (sx :c--$blue-500)]
 [donut (sx :c--$green-500)]
 [donut (sx :c--$yellow-500)]
 [donut (sx :c--$red-500)]
 [donut (sx :c--$purple-500)]
 [donut (sx :c--$lime-500)]
 [donut (sx :c--$brown-500)]
 [donut (sx :c--$orange-500)]
 [donut (sx :c--$magenta-500)]]
[:div
 [donut (sx :.foreground-gray)]
 [donut (sx :.foreground-blue)]
 [donut (sx :.foreground-green)]
 [donut (sx :.foreground-yellow)]
 [donut (sx :.foreground-red)]
 [donut (sx :.foreground-purple)]
 [donut (sx :.foreground-lime)]
 [donut (sx :.foreground-brown)]
 [donut (sx :.foreground-orange)]
 [donut (sx :.foreground-magenta)]]

spinner

Paste into the :require section of your :ns form:
[kushi.ui.spinner.core
  :refer
  [spinner donut propeller thinking]]]
[thinking (sx :.small)]
[thinking (sx :.large)]
[thinking (sx :.xxxlarge)]

spinner

Paste into the :require section of your :ns form:
[kushi.ui.spinner.core
  :refer
  [spinner donut propeller thinking]]]
[:div
 [thinking (sx :c--$gray-500)]
 [thinking (sx :c--$blue-500)]
 [thinking (sx :c--$green-500)]
 [thinking (sx :c--$yellow-500)]
 [thinking (sx :c--$red-500)]
 [thinking (sx :c--$purple-500)]
 [thinking (sx :c--$lime-500)]
 [thinking (sx :c--$brown-500)]
 [thinking (sx :c--$orange-500)]
 [thinking (sx :c--$magenta-500)]]
[:div
 [thinking (sx :.foreground-gray)]
 [thinking (sx :.foreground-blue)]
 [thinking (sx :.foreground-green)]
 [thinking (sx :.foreground-yellow)]
 [thinking (sx :.foreground-red)]
 [thinking (sx :.foreground-purple)]
 [thinking (sx :.foreground-lime)]
 [thinking (sx :.foreground-brown)]
 [thinking (sx :.foreground-orange)]
 [thinking (sx :.foreground-magenta)]]

icon

Paste into the :require section of your :ns form:
[kushi.ui.icon.core :refer [icon]]]
[icon (sx :.small :.extra-bold) :star]
[icon (sx :.xxxlarge :.light) :star]
[icon (sx :.medium :.normal) :star]
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star

icon

Paste into the :require section of your :ns form:
[kushi.ui.icon.core :refer [icon]]]
[icon (sx :fs--48px :.extra-bold) :star]
[icon (sx :fs--48px :.light) :star]
[icon (sx :fs--48px :.normal) :star]
star
star
star
star
star
star
star
star
star
star
star
star

icon

Paste into the :require section of your :ns form:
[kushi.ui.icon.core :refer [icon]]]
[:div
 [icon (sx :c--$gray-500) :star]
 [icon (sx :c--$blue-500) :star]
 [icon (sx :c--$green-500) :star]
 [icon (sx :c--$yellow-500) :star]
 [icon (sx :c--$red-500) :star]
 [icon (sx :c--$purple-500) :star]
 [icon (sx :c--$lime-500) :star]
 [icon (sx :c--$brown-500) :star]
 [icon (sx :c--$orange-500) :star]
 [icon (sx :c--$magenta-500) :star]]
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star
star

icon

Paste into the :require section of your :ns form:
[kushi.ui.icon.core :refer [icon]]]
[icon {:-icon-filled? true} :star]
auto_awesome
auto_awesome
help
help
info
info
favorite
favorite
settings
settings
filter_alt
filter_alt
cloud_upload
cloud_upload
download
download
delete
delete
cancel
cancel
auto_awesome_motion
auto_awesome_motion
archive
archive
sell
sell
visibility
visibility
visibility_off
visibility_off
report_problem
report_problem
check_circle
check_circle
error
error
edit
edit
folder
folder
smartphone
smartphone
star
star
add_circle
add_circle
expand_circle_down
expand_circle_down
auto_awesome
auto_awesome
help
help
info
info
favorite
favorite
settings
settings
filter_alt
filter_alt
cloud_upload
cloud_upload
download
download
delete
delete
cancel
cancel
auto_awesome_motion
auto_awesome_motion
archive
archive
sell
sell
visibility
visibility
visibility_off
visibility_off
report_problem
report_problem
check_circle
check_circle
error
error
edit
edit
folder
folder
smartphone
smartphone
star
star
add_circle
add_circle
expand_circle_down
expand_circle_down

icon

Paste into the :require section of your :ns form:
[kushi.ui.icon.core :refer [icon]]]
[:div
 [icon :search]
 [icon :playlist-add]
 [icon :expand]
 [icon :compress]
 [icon :arrow-back]
 [icon :arrow-forward]
 [icon :sort]
 [icon :clear]
 [icon :keyboard-return]
 [icon :check]
 [icon :find-replace]
 [icon :open-in-new]
 [icon :fingerprint]
 [icon :refresh]
 [icon :download]
 [icon :menu]]
search
playlist_add
expand
compress
arrow_back
arrow_forward
sort
clear
keyboard_return
check
find_replace
open_in_new
fingerprint
refresh
download
menu
search
playlist_add
expand
compress
arrow_back
arrow_forward
sort
clear
keyboard_return
check
find_replace
open_in_new
fingerprint
refresh
download
menu

card

Paste into the :require section of your :ns form:
[kushi.ui.card.core :refer [card]]]
[card (sx :fs--xxlarge) "My content"]
🐻‍❄

Polar Bear

polar.bear@example.com

🐻‍❄

Polar Bear

polar.bear@example.com

🐻‍❄

Polar Bear

polar.bear@example.com

🐻‍❄

Polar Bear

polar.bear@example.com

🐻‍❄

Polar Bear

polar.bear@example.com

🐻‍❄

Polar Bear

polar.bear@example.com

🐻‍❄

Polar Bear

polar.bear@example.com

🐻‍❄

Polar Bear

polar.bear@example.com

🐻‍❄

Polar Bear

polar.bear@example.com

🐻‍❄

Polar Bear

polar.bear@example.com

callout

Paste into the :require section of your :ns form:
[kushi.ui.callout.core :refer [callout]]]
[callout
 (merge-attrs
  (sx :.large)
  {:-header-text
   [:span
    "Please check out the "
    [link
     (merge-attrs (sx :ws--n) {:href "#"})
     "new features"]],
   :-colorway :accent,
   :-icon [icon :info]})]
info
Please check out the new features
info
Please check out the new features
info
Please check out the new features
info
Please check out the new features
info
Please check out the new features
check_circle
Your transaction was successful.
info
Please check out the new features
info
Please check out the new features
info
Please check out the new features
info
Please check out the new features
info
Please check out the new features
info
Please check out the new features
info
Your transaction was successful
info
Your transaction was successful
info
Your transaction was successful
info
Time to update. Take action.
info
Time to update. Take action.
info
Time to update. Take action.
info
Something went wrong. Learn more.
info
Something went wrong. Learn more.
info
Something went wrong. Learn more.

button

Paste into the :require section of your :ns form:
[kushi.ui.button.core :refer [button]]]
Use the data-kui-surface attributes :solid, :outline, and :minimal to control the surface variant of the button.
[button "Button"]
[button {:-surface :solid} "Button"]
[button {:-surface :outline} "Button"]
[button {:-surface :minimal} "Button"]

button

Paste into the :require section of your :ns form:
[kushi.ui.button.core :refer [button]]]
Use the data-kui-colorway attributes :neutral, :accent, :positive, :warning, and :negative to control the semantic color variant. The default is :neutral.
[button "Button"]
[button {:-colorway :neutral} "Button"]
[button {:-colorway :accent} "Button"]
[button {:-colorway :positive} "Button"]
[button {:-colorway :warning} "Button"]
[button {:-colorway :negative} "Button"]

button

Paste into the :require section of your :ns form:
[kushi.ui.button.core :refer [button]]]
Use the data-kui-shape attributes :pill, :rounded, and :sharp to control the surface variant of the button. The default is :rounded.
[button "Button"]
[button {:-shape :rounded} "Button"]
[button {:-shape :pill} "Button"]
[button {:-shape :sharp} "Button"]

button

Paste into the :require section of your :ns form:
[kushi.ui.button.core :refer [button]]
[kushi.ui.icon.core :refer [icon icon-button]]
[kushi.ui.label.core :refer [label]]]
Check out the icon component for detailed info on icon usage Various buttons with icons:
[button "Button" [icon :play-arrow]]
[button
 [icon :auto-awesome]
 "Wow"
 [icon :auto-awesome]]

button

Paste into the :require section of your :ns form:
[kushi.ui.button.core :refer [button]]]
[:div
 [button "Play"]
 [button (sx :.xxxsmall) "Play"]
 [button (sx :.xxsmall) "Play"]
 [button (sx :.xsmall) "Play"]
 [button (sx :.small) "Play"]
 [button (sx :.medium) "Play"]
 [button (sx :.large) "Play"]
 [button (sx :.xlarge) "Play"]
 [button (sx :.xxlarge) "Play"]
 [button (sx :.xxxlarge) "Play"]]

button

Paste into the :require section of your :ns form:
[kushi.ui.button.core :refer [button]]]
Use the font-weight utility classes :.thin ~ :.heavy to control the weight. Scale of weights:
[:div
 [button "Wow"]
 [button (sx :.thin) "Wow"]
 [button (sx :.extra-light) "Wow"]
 [button (sx :.light) "Wow"]
 [button (sx :.normal) "Wow"]
 [button (sx :.wee-bold) "Wow"]
 [button (sx :.semi-bold) "Wow"]
 [button (sx :.bold) "Wow"]
 [button (sx :.extra-bold) "Wow"]
 [button (sx :.heavy) "Wow"]]

button

Paste into the :require section of your :ns form:
[kushi.ui.button.core :refer [button]]
[kushi.ui.icon.core :refer [icon]]
[kushi.ui.spinner.core
  :refer
  [spinner donut propeller thinking]]]
Examples:
[button
 {:-loading? true}
 [spinner [icon :play-arrow] [propeller]]
 "Play"]
[button {:disabled true} "Play"]

collapse

Paste into the :require section of your :ns form:
[kushi.ui.collapse.core :refer [collapse]]]
[collapse
 {:-label "Collapsable section label"}
 [:p "Child 1"]
 [:p "Child 2"]]

collapse

Paste into the :require section of your :ns form:
[kushi.ui.collapse.core :refer [collapse]]]
[collapse
 {:-label "Click to expand",
  :-label-expanded "Click to collapse"}
 [:p "Child 1"]
 [:p "Child 2"]]

collapse

Paste into the :require section of your :ns form:
[kushi.ui.collapse.core :refer [collapse]]]
[collapse
 {:-label "Collapsable section label ",
  :-icon-position :end}
 [:p "Child 1"]
 [:p "Child 2"]]

collapse

Paste into the :require section of your :ns form:
[kushi.ui.collapse.core :refer [collapse]]]
[collapse
 (merge-attrs
  (sx
   :bbe--1px:solid:$neutral-800
   :dark:bbe--1px:solid:$neutral-400)
  {:-label "Collapsable section label ",
   :-header-attrs
   (sx
    :bbs--1px:solid:$neutral-800
    :dark:bbs--1px:solid:$neutral-400)})
 [:p "Child 1"]
 [:p "Child 2"]]

collapse

Paste into the :require section of your :ns form:
[kushi.ui.collapse.core :refer [collapse]]]
[collapse
 {:-label "Collapsable section label ",
  :-header-attrs (sx :fw--$bold)}
 [:p "Child 1"]
 [:p "Child 2"]]

collapse

Paste into the :require section of your :ns form:
[kushi.ui.collapse.core :refer [collapse]]]
[collapse
 {:-label "Collapsable section label ",
  :-body-attrs
  (sx
   :bgc--$purple-100
   :dark:bgc--$purple-900
   :pis--1rem),
  :-speed 1000}
 [:section
  (sx :pb--0.5rem)
  [:p "Child 1"]
  [:p "Child 2"]
  [:p "Child 3"]
  [:p "Child 4"]
  [:p "Child 5"]]]

collapse

Paste into the :require section of your :ns form:
[kushi.ui.collapse.core :refer [collapse]]]
[collapse
 {:class
  (css
   :border-block--3px:solid:$purple-100
   :dark:border-block--3px:solid:$purple-850),
  :-label "Collapsable section label ",
  :-body-attrs (sx :pis--0.5rem),
  :-header-attrs
  (sx
   :fw--$semi-bold
   :p--10px
   :bgc--$purple-100
   :dark:bgc--$purple-850)}
 [:p "Child 1"]
 [:p "Child 2"]]

collapse

Paste into the :require section of your :ns form:
[kushi.ui.collapse.core :refer [collapse]]]
[collapse
 {:-label "Collapsable section label",
  :-on-click (fn* [] (js/alert "clicked"))}
 [:p "Child 1"]
 [:p "Child 2"]]

radio

Paste into the :require section of your :ns form:
[kushi.ui.radio.core :refer [radio]]]
[:section
 (sx :.flex-row-fs)
 [radio {:-input-attrs {:name :demo}} "Yes"]
 [radio {:-input-attrs {:name :demo}} "No"]
 [radio {:-input-attrs {:name :demo}} "Maybe"]]

radio

Paste into the :require section of your :ns form:
[kushi.ui.radio.core :refer [radio]]]
[:section
 (sx
  :.flex-row-fs
  :c--$purple-600
  :dark:c--$purple-300)
 [radio {:-input-attrs {:name :demo}} "Yes"]
 [radio {:-input-attrs {:name :demo}} "No"]
 [radio {:-input-attrs {:name :demo}} "Maybe"]]

radio

Paste into the :require section of your :ns form:
[kushi.ui.radio.core :refer [radio]]]
[:section
 (sx
  :d--grid
  :xsm:gtc--1fr
  :xsm:gtc--1fr:1fr
  :row-gap--1em
  :column-gap--2em
  [:_.emoji
   {:fs :28px,
    :mi :0.33em,
    :filter "grayscale(1)",
    :transition-property :transform,
    :transition-duration :500ms}]
  [:_.kushi-radio-input:checked+.kushi-label>.emoji
   {:filter :none,
    :transform "scale(1.5)",
    :animation :jiggle2:0.5s}])
 [radio
  (merge-attrs
   (sx :.normal)
   {:-input-attrs
    {:name :demo-custom, :defaultChecked true}})
  [label [:span.emoji "🦑"] "Squid"]]
 [radio
  (merge-attrs
   (sx :.normal)
   {:-input-attrs {:name :demo-custom}})
  [label [:span.emoji "🐋"] "Whale"]]
 [radio
  (merge-attrs
   (sx :.normal)
   {:-input-attrs {:name :demo-custom}})
  [label [:span.emoji "🦈 "] "Shark"]]
 [radio
  (merge-attrs
   (sx :.normal)
   {:-input-attrs {:name :demo-custom}})
  [label [:span.emoji "🐊"] "Croc"]]]

switch

Paste into the :require section of your :ns form:
[kushi.ui.switch.core :refer [switch]]]
[:div
 [switch]
 [switch {:-colorway :neutral}]
 [switch {:-colorway :accent}]
 [switch {:-colorway :positive}]
 [switch {:-colorway :warning}]
 [switch {:-colorway :negative}]]

switch

Paste into the :require section of your :ns form:
[kushi.ui.switch.core :refer [switch]]]
[:div
 [switch]
 [switch (sx :.xxxsmall)]
 [switch (sx :.xxsmall)]
 [switch (sx :.xsmall)]
 [switch (sx :.small)]
 [switch (sx :.medium)]
 [switch (sx :.large)]
 [switch (sx :.xlarge)]
 [switch (sx :.xxlarge)]
 [switch (sx :.xxxlarge)]]

switch

Paste into the :require section of your :ns form:
[kushi.ui.switch.core :refer [switch]]]
[switch
 {:-thumb-attrs
  (sx :bgi--$convex :dark:bgi--$convex-3)}]

switch

Paste into the :require section of your :ns form:
[kushi.ui.switch.core :refer [switch]]]
[switch
 (merge-attrs
  (sx
   [:--switch-border-width :0px]
   [:--switch-thumb-scale-factor :1.25])
  {:-thumb-attrs
   (sx :border--1px:solid:currentColor)})]

switch

Paste into the :require section of your :ns form:
[kushi.ui.switch.core :refer [switch]]]
[switch
 (merge-attrs
  (sx [:--switch-width-ratio :2.25])
  {:-track-content-on "ON",
   :-track-content-off "OFF"})]

switch

Paste into the :require section of your :ns form:
[kushi.ui.switch.core :refer [switch]]]
[switch
 {:-thumb-content-on
  [:span (sx :.semi-bold :fs--0.3em) "ON"],
  :-thumb-content-off
  [:span (sx :.semi-bold :fs--0.3em) "OFF"]}]

switch

Paste into the :require section of your :ns form:
[kushi.ui.switch.core :refer [switch]]
[kushi.ui.icon.core :refer [icon]]]
[switch
 {:-track-content-on
  [icon
   (merge-attrs
    (sx :fs--0.55em)
    {:-icon-filled? true})
   :visibility],
  :-track-content-off
  [icon
   (merge-attrs
    (sx :fs--0.55em)
    {:-icon-filled? true})
   :visibility-off]}]

switch

Paste into the :require section of your :ns form:
[kushi.ui.switch.core :refer [switch]]
[kushi.ui.icon.core :refer [icon]]]
[switch
 {:-thumb-content-on
  [icon
   (merge-attrs
    (sx :fs--0.55em)
    {:-icon-filled? true})
   :visibility],
  :-thumb-content-off
  [icon
   (merge-attrs
    (sx :fs--0.55em)
    {:-icon-filled? true})
   :visibility-off]}]

switch

Paste into the :require section of your :ns form:
[kushi.ui.switch.core :refer [switch]]]
[switch {:disabled true}]

checkbox

Paste into the :require section of your :ns form:
[kushi.ui.radio.core :refer [radio]]]
[checkbox
 (merge-attrs
  (sx :fs--$xxxlarge)
  {:-input-attrs
   {:name :xxxlarge-sample,
    :defaultChecked true}})]

checkbox

Paste into the :require section of your :ns form:
[kushi.ui.radio.core :refer [radio]]]
[[label "Sign me up"]]