@kushagradhawan/kookie-ui 0.1.28 → 0.1.30

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (538) hide show
  1. package/components.css +4742 -2680
  2. package/dist/cjs/components/_internal/base-button.d.ts +36 -0
  3. package/dist/cjs/components/_internal/base-button.d.ts.map +1 -1
  4. package/dist/cjs/components/_internal/base-button.js +1 -1
  5. package/dist/cjs/components/_internal/base-button.js.map +3 -3
  6. package/dist/cjs/components/_internal/base-button.props.d.ts +61 -0
  7. package/dist/cjs/components/_internal/base-button.props.d.ts.map +1 -1
  8. package/dist/cjs/components/_internal/base-button.props.js +1 -1
  9. package/dist/cjs/components/_internal/base-button.props.js.map +3 -3
  10. package/dist/cjs/components/_internal/base-checkbox.props.d.ts +6 -1
  11. package/dist/cjs/components/_internal/base-checkbox.props.d.ts.map +1 -1
  12. package/dist/cjs/components/_internal/base-checkbox.props.js +1 -1
  13. package/dist/cjs/components/_internal/base-checkbox.props.js.map +3 -3
  14. package/dist/cjs/components/_internal/base-menu.props.d.ts +8 -0
  15. package/dist/cjs/components/_internal/base-menu.props.d.ts.map +1 -1
  16. package/dist/cjs/components/_internal/base-menu.props.js +1 -1
  17. package/dist/cjs/components/_internal/base-menu.props.js.map +3 -3
  18. package/dist/cjs/components/_internal/base-radio.props.d.ts +6 -1
  19. package/dist/cjs/components/_internal/base-radio.props.d.ts.map +1 -1
  20. package/dist/cjs/components/_internal/base-radio.props.js +1 -1
  21. package/dist/cjs/components/_internal/base-radio.props.js.map +3 -3
  22. package/dist/cjs/components/accordion.d.ts +22 -0
  23. package/dist/cjs/components/accordion.d.ts.map +1 -0
  24. package/dist/cjs/components/accordion.js +2 -0
  25. package/dist/cjs/components/accordion.js.map +7 -0
  26. package/dist/cjs/components/accordion.props.d.ts +97 -0
  27. package/dist/cjs/components/accordion.props.d.ts.map +1 -0
  28. package/dist/cjs/components/accordion.props.js +2 -0
  29. package/dist/cjs/components/accordion.props.js.map +7 -0
  30. package/dist/cjs/components/alert-dialog.d.ts.map +1 -1
  31. package/dist/cjs/components/alert-dialog.js +1 -1
  32. package/dist/cjs/components/alert-dialog.js.map +3 -3
  33. package/dist/cjs/components/alert-dialog.props.d.ts +69 -2
  34. package/dist/cjs/components/alert-dialog.props.d.ts.map +1 -1
  35. package/dist/cjs/components/alert-dialog.props.js +1 -1
  36. package/dist/cjs/components/alert-dialog.props.js.map +3 -3
  37. package/dist/cjs/components/avatar.d.ts.map +1 -1
  38. package/dist/cjs/components/avatar.js +1 -1
  39. package/dist/cjs/components/avatar.js.map +3 -3
  40. package/dist/cjs/components/avatar.props.d.ts +9 -1
  41. package/dist/cjs/components/avatar.props.d.ts.map +1 -1
  42. package/dist/cjs/components/avatar.props.js +1 -1
  43. package/dist/cjs/components/avatar.props.js.map +3 -3
  44. package/dist/cjs/components/badge.d.ts +8 -1
  45. package/dist/cjs/components/badge.d.ts.map +1 -1
  46. package/dist/cjs/components/badge.js +1 -1
  47. package/dist/cjs/components/badge.js.map +3 -3
  48. package/dist/cjs/components/badge.props.d.ts +14 -6
  49. package/dist/cjs/components/badge.props.d.ts.map +1 -1
  50. package/dist/cjs/components/badge.props.js +1 -1
  51. package/dist/cjs/components/badge.props.js.map +3 -3
  52. package/dist/cjs/components/blockquote.props.d.ts +1 -1
  53. package/dist/cjs/components/button.d.ts +53 -1
  54. package/dist/cjs/components/button.d.ts.map +1 -1
  55. package/dist/cjs/components/button.js +1 -1
  56. package/dist/cjs/components/button.js.map +3 -3
  57. package/dist/cjs/components/button.props.d.ts +17 -0
  58. package/dist/cjs/components/button.props.d.ts.map +1 -1
  59. package/dist/cjs/components/button.props.js.map +2 -2
  60. package/dist/cjs/components/callout.d.ts +4 -0
  61. package/dist/cjs/components/callout.d.ts.map +1 -1
  62. package/dist/cjs/components/callout.js +1 -1
  63. package/dist/cjs/components/callout.js.map +3 -3
  64. package/dist/cjs/components/callout.props.d.ts +9 -1
  65. package/dist/cjs/components/callout.props.d.ts.map +1 -1
  66. package/dist/cjs/components/callout.props.js +1 -1
  67. package/dist/cjs/components/callout.props.js.map +3 -3
  68. package/dist/cjs/components/card.d.ts.map +1 -1
  69. package/dist/cjs/components/card.js +1 -1
  70. package/dist/cjs/components/card.js.map +3 -3
  71. package/dist/cjs/components/card.props.d.ts +5 -0
  72. package/dist/cjs/components/card.props.d.ts.map +1 -1
  73. package/dist/cjs/components/card.props.js +1 -1
  74. package/dist/cjs/components/card.props.js.map +3 -3
  75. package/dist/cjs/components/checkbox-cards.d.ts.map +1 -1
  76. package/dist/cjs/components/checkbox-cards.js +1 -1
  77. package/dist/cjs/components/checkbox-cards.js.map +3 -3
  78. package/dist/cjs/components/checkbox-cards.props.d.ts +2 -2
  79. package/dist/cjs/components/checkbox-cards.props.js +1 -1
  80. package/dist/cjs/components/checkbox-cards.props.js.map +2 -2
  81. package/dist/cjs/components/checkbox-group.props.d.ts +6 -1
  82. package/dist/cjs/components/checkbox-group.props.d.ts.map +1 -1
  83. package/dist/cjs/components/checkbox.d.ts.map +1 -1
  84. package/dist/cjs/components/checkbox.js +1 -1
  85. package/dist/cjs/components/checkbox.js.map +3 -3
  86. package/dist/cjs/components/code.js.map +1 -1
  87. package/dist/cjs/components/code.props.d.ts +1 -1
  88. package/dist/cjs/components/context-menu.d.ts +1 -1
  89. package/dist/cjs/components/context-menu.d.ts.map +1 -1
  90. package/dist/cjs/components/context-menu.js +1 -1
  91. package/dist/cjs/components/context-menu.js.map +3 -3
  92. package/dist/cjs/components/dialog.d.ts.map +1 -1
  93. package/dist/cjs/components/dialog.js +1 -1
  94. package/dist/cjs/components/dialog.js.map +3 -3
  95. package/dist/cjs/components/dialog.props.d.ts +6 -1
  96. package/dist/cjs/components/dialog.props.d.ts.map +1 -1
  97. package/dist/cjs/components/dialog.props.js +1 -1
  98. package/dist/cjs/components/dialog.props.js.map +3 -3
  99. package/dist/cjs/components/dropdown-menu.d.ts +1 -1
  100. package/dist/cjs/components/dropdown-menu.d.ts.map +1 -1
  101. package/dist/cjs/components/dropdown-menu.js +1 -1
  102. package/dist/cjs/components/dropdown-menu.js.map +3 -3
  103. package/dist/cjs/components/heading.props.d.ts +1 -1
  104. package/dist/cjs/components/icon-button.d.ts +79 -1
  105. package/dist/cjs/components/icon-button.d.ts.map +1 -1
  106. package/dist/cjs/components/icon-button.js +4 -1
  107. package/dist/cjs/components/icon-button.js.map +3 -3
  108. package/dist/cjs/components/image.d.ts +131 -12
  109. package/dist/cjs/components/image.d.ts.map +1 -1
  110. package/dist/cjs/components/image.js +1 -1
  111. package/dist/cjs/components/image.js.map +3 -3
  112. package/dist/cjs/components/image.props.d.ts +136 -21
  113. package/dist/cjs/components/image.props.d.ts.map +1 -1
  114. package/dist/cjs/components/image.props.js +1 -1
  115. package/dist/cjs/components/image.props.js.map +3 -3
  116. package/dist/cjs/components/index.d.ts +1 -0
  117. package/dist/cjs/components/index.d.ts.map +1 -1
  118. package/dist/cjs/components/index.js +1 -1
  119. package/dist/cjs/components/index.js.map +3 -3
  120. package/dist/cjs/components/link.props.d.ts +1 -1
  121. package/dist/cjs/components/progress.props.d.ts +2 -2
  122. package/dist/cjs/components/progress.props.js +1 -1
  123. package/dist/cjs/components/progress.props.js.map +2 -2
  124. package/dist/cjs/components/radio-cards.d.ts.map +1 -1
  125. package/dist/cjs/components/radio-cards.js +1 -1
  126. package/dist/cjs/components/radio-cards.js.map +3 -3
  127. package/dist/cjs/components/radio-cards.props.d.ts +2 -2
  128. package/dist/cjs/components/radio-cards.props.js +1 -1
  129. package/dist/cjs/components/radio-cards.props.js.map +2 -2
  130. package/dist/cjs/components/radio.d.ts.map +1 -1
  131. package/dist/cjs/components/radio.js +1 -1
  132. package/dist/cjs/components/radio.js.map +3 -3
  133. package/dist/cjs/components/segmented-control.props.d.ts +3 -3
  134. package/dist/cjs/components/segmented-control.props.js +1 -1
  135. package/dist/cjs/components/segmented-control.props.js.map +2 -2
  136. package/dist/cjs/components/select.d.ts.map +1 -1
  137. package/dist/cjs/components/select.js +1 -1
  138. package/dist/cjs/components/select.js.map +3 -3
  139. package/dist/cjs/components/select.props.d.ts +12 -0
  140. package/dist/cjs/components/select.props.d.ts.map +1 -1
  141. package/dist/cjs/components/select.props.js +1 -1
  142. package/dist/cjs/components/select.props.js.map +2 -2
  143. package/dist/cjs/components/sidebar.d.ts +5 -0
  144. package/dist/cjs/components/sidebar.d.ts.map +1 -1
  145. package/dist/cjs/components/sidebar.js +1 -1
  146. package/dist/cjs/components/sidebar.js.map +3 -3
  147. package/dist/cjs/components/slider.d.ts +5 -0
  148. package/dist/cjs/components/slider.d.ts.map +1 -1
  149. package/dist/cjs/components/slider.js +1 -1
  150. package/dist/cjs/components/slider.js.map +3 -3
  151. package/dist/cjs/components/slider.props.d.ts +10 -2
  152. package/dist/cjs/components/slider.props.d.ts.map +1 -1
  153. package/dist/cjs/components/slider.props.js +1 -1
  154. package/dist/cjs/components/slider.props.js.map +2 -2
  155. package/dist/cjs/components/switch.d.ts.map +1 -1
  156. package/dist/cjs/components/switch.js +1 -1
  157. package/dist/cjs/components/switch.js.map +3 -3
  158. package/dist/cjs/components/switch.props.d.ts +17 -4
  159. package/dist/cjs/components/switch.props.d.ts.map +1 -1
  160. package/dist/cjs/components/switch.props.js +1 -1
  161. package/dist/cjs/components/switch.props.js.map +3 -3
  162. package/dist/cjs/components/tab-nav.d.ts.map +1 -1
  163. package/dist/cjs/components/tab-nav.js +1 -1
  164. package/dist/cjs/components/tab-nav.js.map +3 -3
  165. package/dist/cjs/components/tabs.d.ts.map +1 -1
  166. package/dist/cjs/components/tabs.js +1 -1
  167. package/dist/cjs/components/tabs.js.map +2 -2
  168. package/dist/cjs/components/text-area.d.ts.map +1 -1
  169. package/dist/cjs/components/text-area.js +1 -1
  170. package/dist/cjs/components/text-area.js.map +3 -3
  171. package/dist/cjs/components/text-area.props.d.ts +29 -0
  172. package/dist/cjs/components/text-area.props.d.ts.map +1 -1
  173. package/dist/cjs/components/text-area.props.js +1 -1
  174. package/dist/cjs/components/text-area.props.js.map +3 -3
  175. package/dist/cjs/components/text-field.d.ts.map +1 -1
  176. package/dist/cjs/components/text-field.js +4 -4
  177. package/dist/cjs/components/text-field.js.map +3 -3
  178. package/dist/cjs/components/text-field.props.d.ts +29 -0
  179. package/dist/cjs/components/text-field.props.d.ts.map +1 -1
  180. package/dist/cjs/components/text-field.props.js +1 -1
  181. package/dist/cjs/components/text-field.props.js.map +3 -3
  182. package/dist/cjs/components/text.props.d.ts +1 -1
  183. package/dist/cjs/components/theme.d.ts +3 -0
  184. package/dist/cjs/components/theme.d.ts.map +1 -1
  185. package/dist/cjs/components/theme.js +1 -1
  186. package/dist/cjs/components/theme.js.map +3 -3
  187. package/dist/cjs/components/theme.props.d.ts +14 -0
  188. package/dist/cjs/components/theme.props.d.ts.map +1 -1
  189. package/dist/cjs/components/theme.props.js +1 -1
  190. package/dist/cjs/components/theme.props.js.map +3 -3
  191. package/dist/cjs/components/toggle-button.d.ts +52 -0
  192. package/dist/cjs/components/toggle-button.d.ts.map +1 -1
  193. package/dist/cjs/components/toggle-button.js +1 -1
  194. package/dist/cjs/components/toggle-button.js.map +3 -3
  195. package/dist/cjs/components/toggle-icon-button.d.ts +84 -2
  196. package/dist/cjs/components/toggle-icon-button.d.ts.map +1 -1
  197. package/dist/cjs/components/toggle-icon-button.js +1 -1
  198. package/dist/cjs/components/toggle-icon-button.js.map +3 -3
  199. package/dist/cjs/helpers/extract-margin-props.d.ts +7 -7
  200. package/dist/cjs/hooks/index.d.ts +2 -0
  201. package/dist/cjs/hooks/index.d.ts.map +1 -0
  202. package/dist/cjs/hooks/index.js +2 -0
  203. package/dist/cjs/hooks/index.js.map +7 -0
  204. package/dist/cjs/hooks/use-live-announcer.d.ts +6 -0
  205. package/dist/cjs/hooks/use-live-announcer.d.ts.map +1 -0
  206. package/dist/cjs/hooks/use-live-announcer.js +10 -0
  207. package/dist/cjs/hooks/use-live-announcer.js.map +7 -0
  208. package/dist/cjs/index.d.ts +1 -0
  209. package/dist/cjs/index.d.ts.map +1 -1
  210. package/dist/cjs/index.js +1 -1
  211. package/dist/cjs/index.js.map +2 -2
  212. package/dist/cjs/props/weight.prop.d.ts +1 -1
  213. package/dist/cjs/props/weight.prop.js +1 -1
  214. package/dist/cjs/props/weight.prop.js.map +2 -2
  215. package/dist/esm/components/_internal/base-button.d.ts +36 -0
  216. package/dist/esm/components/_internal/base-button.d.ts.map +1 -1
  217. package/dist/esm/components/_internal/base-button.js +1 -1
  218. package/dist/esm/components/_internal/base-button.js.map +3 -3
  219. package/dist/esm/components/_internal/base-button.props.d.ts +61 -0
  220. package/dist/esm/components/_internal/base-button.props.d.ts.map +1 -1
  221. package/dist/esm/components/_internal/base-button.props.js +1 -1
  222. package/dist/esm/components/_internal/base-button.props.js.map +3 -3
  223. package/dist/esm/components/_internal/base-checkbox.props.d.ts +6 -1
  224. package/dist/esm/components/_internal/base-checkbox.props.d.ts.map +1 -1
  225. package/dist/esm/components/_internal/base-checkbox.props.js +1 -1
  226. package/dist/esm/components/_internal/base-checkbox.props.js.map +3 -3
  227. package/dist/esm/components/_internal/base-menu.props.d.ts +8 -0
  228. package/dist/esm/components/_internal/base-menu.props.d.ts.map +1 -1
  229. package/dist/esm/components/_internal/base-menu.props.js +1 -1
  230. package/dist/esm/components/_internal/base-menu.props.js.map +3 -3
  231. package/dist/esm/components/_internal/base-radio.props.d.ts +6 -1
  232. package/dist/esm/components/_internal/base-radio.props.d.ts.map +1 -1
  233. package/dist/esm/components/_internal/base-radio.props.js +1 -1
  234. package/dist/esm/components/_internal/base-radio.props.js.map +3 -3
  235. package/dist/esm/components/accordion.d.ts +22 -0
  236. package/dist/esm/components/accordion.d.ts.map +1 -0
  237. package/dist/esm/components/accordion.js +2 -0
  238. package/dist/esm/components/accordion.js.map +7 -0
  239. package/dist/esm/components/accordion.props.d.ts +97 -0
  240. package/dist/esm/components/accordion.props.d.ts.map +1 -0
  241. package/dist/esm/components/accordion.props.js +2 -0
  242. package/dist/esm/components/accordion.props.js.map +7 -0
  243. package/dist/esm/components/alert-dialog.d.ts.map +1 -1
  244. package/dist/esm/components/alert-dialog.js +1 -1
  245. package/dist/esm/components/alert-dialog.js.map +3 -3
  246. package/dist/esm/components/alert-dialog.props.d.ts +69 -2
  247. package/dist/esm/components/alert-dialog.props.d.ts.map +1 -1
  248. package/dist/esm/components/alert-dialog.props.js +1 -1
  249. package/dist/esm/components/alert-dialog.props.js.map +3 -3
  250. package/dist/esm/components/avatar.d.ts.map +1 -1
  251. package/dist/esm/components/avatar.js +1 -1
  252. package/dist/esm/components/avatar.js.map +3 -3
  253. package/dist/esm/components/avatar.props.d.ts +9 -1
  254. package/dist/esm/components/avatar.props.d.ts.map +1 -1
  255. package/dist/esm/components/avatar.props.js +1 -1
  256. package/dist/esm/components/avatar.props.js.map +3 -3
  257. package/dist/esm/components/badge.d.ts +8 -1
  258. package/dist/esm/components/badge.d.ts.map +1 -1
  259. package/dist/esm/components/badge.js +1 -1
  260. package/dist/esm/components/badge.js.map +3 -3
  261. package/dist/esm/components/badge.props.d.ts +14 -6
  262. package/dist/esm/components/badge.props.d.ts.map +1 -1
  263. package/dist/esm/components/badge.props.js +1 -1
  264. package/dist/esm/components/badge.props.js.map +3 -3
  265. package/dist/esm/components/blockquote.props.d.ts +1 -1
  266. package/dist/esm/components/button.d.ts +53 -1
  267. package/dist/esm/components/button.d.ts.map +1 -1
  268. package/dist/esm/components/button.js +1 -1
  269. package/dist/esm/components/button.js.map +3 -3
  270. package/dist/esm/components/button.props.d.ts +17 -0
  271. package/dist/esm/components/button.props.d.ts.map +1 -1
  272. package/dist/esm/components/button.props.js.map +2 -2
  273. package/dist/esm/components/callout.d.ts +4 -0
  274. package/dist/esm/components/callout.d.ts.map +1 -1
  275. package/dist/esm/components/callout.js +1 -1
  276. package/dist/esm/components/callout.js.map +3 -3
  277. package/dist/esm/components/callout.props.d.ts +9 -1
  278. package/dist/esm/components/callout.props.d.ts.map +1 -1
  279. package/dist/esm/components/callout.props.js +1 -1
  280. package/dist/esm/components/callout.props.js.map +3 -3
  281. package/dist/esm/components/card.d.ts.map +1 -1
  282. package/dist/esm/components/card.js +1 -1
  283. package/dist/esm/components/card.js.map +3 -3
  284. package/dist/esm/components/card.props.d.ts +5 -0
  285. package/dist/esm/components/card.props.d.ts.map +1 -1
  286. package/dist/esm/components/card.props.js +1 -1
  287. package/dist/esm/components/card.props.js.map +3 -3
  288. package/dist/esm/components/checkbox-cards.d.ts.map +1 -1
  289. package/dist/esm/components/checkbox-cards.js +1 -1
  290. package/dist/esm/components/checkbox-cards.js.map +3 -3
  291. package/dist/esm/components/checkbox-cards.props.d.ts +2 -2
  292. package/dist/esm/components/checkbox-cards.props.js +1 -1
  293. package/dist/esm/components/checkbox-cards.props.js.map +2 -2
  294. package/dist/esm/components/checkbox-group.props.d.ts +6 -1
  295. package/dist/esm/components/checkbox-group.props.d.ts.map +1 -1
  296. package/dist/esm/components/checkbox.d.ts.map +1 -1
  297. package/dist/esm/components/checkbox.js +1 -1
  298. package/dist/esm/components/checkbox.js.map +3 -3
  299. package/dist/esm/components/code.js.map +1 -1
  300. package/dist/esm/components/code.props.d.ts +1 -1
  301. package/dist/esm/components/context-menu.d.ts +1 -1
  302. package/dist/esm/components/context-menu.d.ts.map +1 -1
  303. package/dist/esm/components/context-menu.js +1 -1
  304. package/dist/esm/components/context-menu.js.map +3 -3
  305. package/dist/esm/components/dialog.d.ts.map +1 -1
  306. package/dist/esm/components/dialog.js +1 -1
  307. package/dist/esm/components/dialog.js.map +3 -3
  308. package/dist/esm/components/dialog.props.d.ts +6 -1
  309. package/dist/esm/components/dialog.props.d.ts.map +1 -1
  310. package/dist/esm/components/dialog.props.js +1 -1
  311. package/dist/esm/components/dialog.props.js.map +3 -3
  312. package/dist/esm/components/dropdown-menu.d.ts +1 -1
  313. package/dist/esm/components/dropdown-menu.d.ts.map +1 -1
  314. package/dist/esm/components/dropdown-menu.js +1 -1
  315. package/dist/esm/components/dropdown-menu.js.map +3 -3
  316. package/dist/esm/components/heading.props.d.ts +1 -1
  317. package/dist/esm/components/icon-button.d.ts +79 -1
  318. package/dist/esm/components/icon-button.d.ts.map +1 -1
  319. package/dist/esm/components/icon-button.js +4 -1
  320. package/dist/esm/components/icon-button.js.map +3 -3
  321. package/dist/esm/components/image.d.ts +131 -12
  322. package/dist/esm/components/image.d.ts.map +1 -1
  323. package/dist/esm/components/image.js +1 -1
  324. package/dist/esm/components/image.js.map +3 -3
  325. package/dist/esm/components/image.props.d.ts +136 -21
  326. package/dist/esm/components/image.props.d.ts.map +1 -1
  327. package/dist/esm/components/image.props.js +1 -1
  328. package/dist/esm/components/image.props.js.map +3 -3
  329. package/dist/esm/components/index.d.ts +1 -0
  330. package/dist/esm/components/index.d.ts.map +1 -1
  331. package/dist/esm/components/index.js +1 -1
  332. package/dist/esm/components/index.js.map +3 -3
  333. package/dist/esm/components/link.props.d.ts +1 -1
  334. package/dist/esm/components/progress.props.d.ts +2 -2
  335. package/dist/esm/components/progress.props.js +1 -1
  336. package/dist/esm/components/progress.props.js.map +2 -2
  337. package/dist/esm/components/radio-cards.d.ts.map +1 -1
  338. package/dist/esm/components/radio-cards.js +1 -1
  339. package/dist/esm/components/radio-cards.js.map +3 -3
  340. package/dist/esm/components/radio-cards.props.d.ts +2 -2
  341. package/dist/esm/components/radio-cards.props.js +1 -1
  342. package/dist/esm/components/radio-cards.props.js.map +2 -2
  343. package/dist/esm/components/radio.d.ts.map +1 -1
  344. package/dist/esm/components/radio.js +1 -1
  345. package/dist/esm/components/radio.js.map +3 -3
  346. package/dist/esm/components/segmented-control.props.d.ts +3 -3
  347. package/dist/esm/components/segmented-control.props.js +1 -1
  348. package/dist/esm/components/segmented-control.props.js.map +2 -2
  349. package/dist/esm/components/select.d.ts.map +1 -1
  350. package/dist/esm/components/select.js +1 -1
  351. package/dist/esm/components/select.js.map +3 -3
  352. package/dist/esm/components/select.props.d.ts +12 -0
  353. package/dist/esm/components/select.props.d.ts.map +1 -1
  354. package/dist/esm/components/select.props.js +1 -1
  355. package/dist/esm/components/select.props.js.map +2 -2
  356. package/dist/esm/components/sidebar.d.ts +5 -0
  357. package/dist/esm/components/sidebar.d.ts.map +1 -1
  358. package/dist/esm/components/sidebar.js +1 -1
  359. package/dist/esm/components/sidebar.js.map +3 -3
  360. package/dist/esm/components/slider.d.ts +5 -0
  361. package/dist/esm/components/slider.d.ts.map +1 -1
  362. package/dist/esm/components/slider.js +1 -1
  363. package/dist/esm/components/slider.js.map +3 -3
  364. package/dist/esm/components/slider.props.d.ts +10 -2
  365. package/dist/esm/components/slider.props.d.ts.map +1 -1
  366. package/dist/esm/components/slider.props.js +1 -1
  367. package/dist/esm/components/slider.props.js.map +2 -2
  368. package/dist/esm/components/switch.d.ts.map +1 -1
  369. package/dist/esm/components/switch.js +1 -1
  370. package/dist/esm/components/switch.js.map +3 -3
  371. package/dist/esm/components/switch.props.d.ts +17 -4
  372. package/dist/esm/components/switch.props.d.ts.map +1 -1
  373. package/dist/esm/components/switch.props.js +1 -1
  374. package/dist/esm/components/switch.props.js.map +3 -3
  375. package/dist/esm/components/tab-nav.d.ts.map +1 -1
  376. package/dist/esm/components/tab-nav.js +1 -1
  377. package/dist/esm/components/tab-nav.js.map +3 -3
  378. package/dist/esm/components/tabs.d.ts.map +1 -1
  379. package/dist/esm/components/tabs.js +1 -1
  380. package/dist/esm/components/tabs.js.map +2 -2
  381. package/dist/esm/components/text-area.d.ts.map +1 -1
  382. package/dist/esm/components/text-area.js +1 -1
  383. package/dist/esm/components/text-area.js.map +3 -3
  384. package/dist/esm/components/text-area.props.d.ts +29 -0
  385. package/dist/esm/components/text-area.props.d.ts.map +1 -1
  386. package/dist/esm/components/text-area.props.js +1 -1
  387. package/dist/esm/components/text-area.props.js.map +3 -3
  388. package/dist/esm/components/text-field.d.ts.map +1 -1
  389. package/dist/esm/components/text-field.js +4 -4
  390. package/dist/esm/components/text-field.js.map +3 -3
  391. package/dist/esm/components/text-field.props.d.ts +29 -0
  392. package/dist/esm/components/text-field.props.d.ts.map +1 -1
  393. package/dist/esm/components/text-field.props.js +1 -1
  394. package/dist/esm/components/text-field.props.js.map +3 -3
  395. package/dist/esm/components/text.props.d.ts +1 -1
  396. package/dist/esm/components/theme.d.ts +3 -0
  397. package/dist/esm/components/theme.d.ts.map +1 -1
  398. package/dist/esm/components/theme.js +1 -1
  399. package/dist/esm/components/theme.js.map +3 -3
  400. package/dist/esm/components/theme.props.d.ts +14 -0
  401. package/dist/esm/components/theme.props.d.ts.map +1 -1
  402. package/dist/esm/components/theme.props.js +1 -1
  403. package/dist/esm/components/theme.props.js.map +3 -3
  404. package/dist/esm/components/toggle-button.d.ts +52 -0
  405. package/dist/esm/components/toggle-button.d.ts.map +1 -1
  406. package/dist/esm/components/toggle-button.js +1 -1
  407. package/dist/esm/components/toggle-button.js.map +3 -3
  408. package/dist/esm/components/toggle-icon-button.d.ts +84 -2
  409. package/dist/esm/components/toggle-icon-button.d.ts.map +1 -1
  410. package/dist/esm/components/toggle-icon-button.js +1 -1
  411. package/dist/esm/components/toggle-icon-button.js.map +3 -3
  412. package/dist/esm/helpers/extract-margin-props.d.ts +7 -7
  413. package/dist/esm/hooks/index.d.ts +2 -0
  414. package/dist/esm/hooks/index.d.ts.map +1 -0
  415. package/dist/esm/hooks/index.js +2 -0
  416. package/dist/esm/hooks/index.js.map +7 -0
  417. package/dist/esm/hooks/use-live-announcer.d.ts +6 -0
  418. package/dist/esm/hooks/use-live-announcer.d.ts.map +1 -0
  419. package/dist/esm/hooks/use-live-announcer.js +10 -0
  420. package/dist/esm/hooks/use-live-announcer.js.map +7 -0
  421. package/dist/esm/index.d.ts +1 -0
  422. package/dist/esm/index.d.ts.map +1 -1
  423. package/dist/esm/index.js +1 -1
  424. package/dist/esm/index.js.map +2 -2
  425. package/dist/esm/props/weight.prop.d.ts +1 -1
  426. package/dist/esm/props/weight.prop.js +1 -1
  427. package/dist/esm/props/weight.prop.js.map +2 -2
  428. package/layout/components.css +1 -0
  429. package/layout.css +1 -0
  430. package/package.json +2 -1
  431. package/src/components/_internal/base-button.css +483 -284
  432. package/src/components/_internal/base-button.props.ts +87 -0
  433. package/src/components/_internal/base-button.tsx +127 -10
  434. package/src/components/_internal/base-card.css +866 -83
  435. package/src/components/_internal/base-checkbox.css +252 -52
  436. package/src/components/_internal/base-checkbox.props.ts +4 -1
  437. package/src/components/_internal/base-dialog.css +39 -8
  438. package/src/components/_internal/base-menu.css +55 -32
  439. package/src/components/_internal/base-menu.props.ts +10 -0
  440. package/src/components/_internal/base-radio.css +222 -52
  441. package/src/components/_internal/base-radio.props.ts +4 -1
  442. package/src/components/_internal/base-sidebar-menu.css +223 -0
  443. package/src/components/_internal/base-sidebar.css +141 -0
  444. package/src/components/_internal/base-tab-list.css +16 -0
  445. package/src/components/accordion.css +657 -0
  446. package/src/components/accordion.props.tsx +90 -0
  447. package/src/components/accordion.tsx +209 -0
  448. package/src/components/alert-dialog.props.tsx +22 -2
  449. package/src/components/alert-dialog.tsx +94 -3
  450. package/src/components/avatar.css +294 -152
  451. package/src/components/avatar.props.tsx +7 -1
  452. package/src/components/avatar.tsx +12 -2
  453. package/src/components/badge.css +160 -138
  454. package/src/components/badge.props.tsx +10 -3
  455. package/src/components/badge.tsx +71 -9
  456. package/src/components/button.css +88 -0
  457. package/src/components/button.props.tsx +17 -0
  458. package/src/components/button.tsx +107 -5
  459. package/src/components/callout.css +122 -35
  460. package/src/components/callout.props.tsx +7 -1
  461. package/src/components/callout.tsx +32 -9
  462. package/src/components/card.css +0 -597
  463. package/src/components/card.props.tsx +3 -0
  464. package/src/components/card.tsx +4 -2
  465. package/src/components/checkbox-cards.css +27 -104
  466. package/src/components/checkbox-cards.props.tsx +2 -2
  467. package/src/components/checkbox-cards.tsx +21 -3
  468. package/src/components/checkbox.tsx +2 -0
  469. package/src/components/code.css +1 -1
  470. package/src/components/code.tsx +1 -1
  471. package/src/components/container.css +1 -0
  472. package/src/components/context-menu.tsx +54 -12
  473. package/src/components/dialog.props.tsx +3 -0
  474. package/src/components/dialog.tsx +93 -3
  475. package/src/components/dropdown-menu.tsx +49 -12
  476. package/src/components/icon-button.css +73 -4
  477. package/src/components/icon-button.tsx +125 -19
  478. package/src/components/image.css +160 -91
  479. package/src/components/image.props.ts +152 -15
  480. package/src/components/image.tsx +290 -247
  481. package/src/components/index.css +1 -0
  482. package/src/components/index.tsx +1 -0
  483. package/src/components/kbd.css +23 -44
  484. package/src/components/progress.css +130 -149
  485. package/src/components/progress.props.tsx +2 -2
  486. package/src/components/radio-cards.css +23 -113
  487. package/src/components/radio-cards.props.tsx +2 -2
  488. package/src/components/radio-cards.tsx +45 -18
  489. package/src/components/radio.tsx +4 -3
  490. package/src/components/scroll-area.css +1 -1
  491. package/src/components/segmented-control.css +83 -64
  492. package/src/components/segmented-control.props.tsx +3 -3
  493. package/src/components/select.css +502 -224
  494. package/src/components/select.props.tsx +8 -0
  495. package/src/components/select.tsx +45 -2
  496. package/src/components/sidebar.css +186 -630
  497. package/src/components/sidebar.tsx +61 -5
  498. package/src/components/slider.css +228 -88
  499. package/src/components/slider.props.tsx +6 -2
  500. package/src/components/slider.tsx +201 -24
  501. package/src/components/spinner.css +12 -0
  502. package/src/components/switch.css +135 -216
  503. package/src/components/switch.props.tsx +16 -4
  504. package/src/components/switch.tsx +5 -3
  505. package/src/components/tab-nav.tsx +6 -3
  506. package/src/components/tabs.tsx +2 -0
  507. package/src/components/text-area.css +222 -140
  508. package/src/components/text-area.props.tsx +18 -1
  509. package/src/components/text-area.tsx +58 -7
  510. package/src/components/text-field.css +214 -131
  511. package/src/components/text-field.props.tsx +17 -0
  512. package/src/components/text-field.tsx +79 -28
  513. package/src/components/theme.props.tsx +12 -0
  514. package/src/components/theme.tsx +31 -1
  515. package/src/components/toggle-button.tsx +102 -3
  516. package/src/components/toggle-icon-button.tsx +150 -7
  517. package/src/components/tooltip.css +3 -3
  518. package/src/hooks/index.ts +1 -0
  519. package/src/hooks/use-live-announcer.ts +52 -0
  520. package/src/index.ts +1 -0
  521. package/src/props/weight.prop.ts +1 -1
  522. package/src/styles/fonts.css +27 -13
  523. package/src/styles/index.css +1 -1
  524. package/src/styles/tokens/base.css +2 -0
  525. package/src/styles/tokens/blur.css +32 -0
  526. package/src/styles/tokens/color.css +9 -9
  527. package/src/styles/tokens/constants.css +88 -140
  528. package/src/styles/tokens/index.css +2 -0
  529. package/src/styles/tokens/opacity.css +32 -0
  530. package/src/styles/tokens/radius.css +6 -10
  531. package/src/styles/tokens/shadow.css +25 -25
  532. package/src/styles/tokens/transition.css +49 -13
  533. package/src/styles/tokens/typography.css +7 -3
  534. package/src/styles/utilities/font-weight.css +16 -0
  535. package/styles.css +11129 -8945
  536. package/tokens/base.css +127 -49
  537. package/tokens.css +158 -114
  538. package/utilities.css +72 -0
@@ -8,6 +8,26 @@
8
8
  height: var(--avatar-size);
9
9
  flex-shrink: 0;
10
10
  position: relative;
11
+
12
+ /* Theme-level translucent override */
13
+ :where([data-panel-background='translucent'], [data-material='translucent']) & {
14
+ backdrop-filter: var(--backdrop-filter-components);
15
+ --backdrop-filter-components: blur(var(--backdrop-blur-components));
16
+ }
17
+
18
+ /* Prevent backdrop-filter stacking with parents */
19
+ isolation: isolate;
20
+
21
+ /* Component-level overrides */
22
+ &:where([data-panel-background='solid'], [data-material='solid']) {
23
+ backdrop-filter: none;
24
+ --backdrop-filter-components: none;
25
+ }
26
+
27
+ &:where([data-panel-background='translucent'], [data-material='translucent']) {
28
+ backdrop-filter: var(--backdrop-filter-components);
29
+ --backdrop-filter-components: blur(var(--backdrop-blur-components));
30
+ }
11
31
  }
12
32
 
13
33
  /* Interactive states for avatars used as buttons/links */
@@ -56,27 +76,21 @@
56
76
  &:where(.rt-variant-classic) {
57
77
  @media (hover: hover) {
58
78
  &:where(:hover:not(:disabled, [data-disabled])) {
59
- background-color: var(--accent-3);
60
- /* prettier-ignore */
61
- box-shadow:
62
- inset 0 calc(-1 * var(--classic-border-width)) var(--classic-shadow-blur-large) var(--accent-a2),
63
- inset 0 var(--classic-border-width) var(--white-a12),
64
- inset 0 var(--classic-shadow-blur-medium) var(--classic-shadow-blur-large) var(--accent-a2),
65
- inset 0 calc(-1 * var(--classic-border-width)) var(--accent-a6),
66
- 0 0 0 var(--classic-border-width) var(--accent-a5),
67
- 0 var(--classic-shadow-offset-y) var(--classic-shadow-blur-small) var(--accent-a7);
68
-
69
- :where(.dark, .dark-theme) &,
70
- :where(.dark, .dark-theme) :where(.radix-themes:not(.light, .light-theme)) & {
71
- /* prettier-ignore */
72
- box-shadow:
73
- inset 0 calc(-1 * var(--classic-border-width)) var(--classic-shadow-blur-large) var(--accent-a3),
74
- inset 0 var(--classic-border-width) var(--accent-a11),
75
- inset 0 var(--classic-shadow-blur-medium) var(--classic-shadow-blur-large) var(--accent-a2),
76
- inset 0 var(--classic-shadow-offset-negative) var(--black-a11),
77
- 0 0 0 var(--classic-border-width-thick) var(--accent-a7),
78
- 0 var(--classic-shadow-offset-y) var(--classic-shadow-blur-small) var(--black-a12),
79
- 0 0 0 var(--classic-border-width) var(--accent-a5);
79
+ background-color: var(--gray-2);
80
+ box-shadow: var(--shadow-2);
81
+
82
+ /* Theme-level translucent override for hover */
83
+ :where([data-panel-background='translucent'], [data-material='translucent']) & {
84
+ background-color: color-mix(in srgb, var(--gray-a2), var(--gray-2) 60%);
85
+ }
86
+
87
+ /* Component-level overrides for hover */
88
+ &:where([data-panel-background='solid'], [data-material='solid']) {
89
+ background-color: var(--gray-2);
90
+ }
91
+
92
+ &:where([data-panel-background='translucent'], [data-material='translucent']) {
93
+ background-color: color-mix(in srgb, var(--gray-a2), var(--gray-2) 60%);
80
94
  }
81
95
 
82
96
  & :where(.rt-AvatarFallback) {
@@ -89,9 +103,22 @@
89
103
  &:where(:active:not(:disabled, [data-disabled])) {
90
104
  padding-top: var(--classic-active-padding-offset-2);
91
105
  padding-bottom: 0;
92
- background-color: var(--accent-3);
93
- box-shadow: inset 0 var(--classic-border-width) var(--black-a3), 0 0 0 var(--classic-border-width) var(--accent-a7);
94
- /* keep root top unchanged; internal illusion achieved by padding */
106
+ background-color: var(--gray-3);
107
+ box-shadow: var(--shadow-1);
108
+
109
+ /* Theme-level translucent override for active */
110
+ :where([data-panel-background='translucent'], [data-material='translucent']) & {
111
+ background-color: color-mix(in srgb, var(--gray-a3), var(--gray-3) 60%);
112
+ }
113
+
114
+ /* Component-level overrides for active */
115
+ &:where([data-panel-background='solid'], [data-material='solid']) {
116
+ background-color: var(--gray-3);
117
+ }
118
+
119
+ &:where([data-panel-background='translucent'], [data-material='translucent']) {
120
+ background-color: color-mix(in srgb, var(--gray-a3), var(--gray-3) 60%);
121
+ }
95
122
 
96
123
  & :where(.rt-AvatarFallback) {
97
124
  padding-top: inherit;
@@ -107,17 +134,45 @@
107
134
  @media (hover: hover) {
108
135
  &:where(:hover:not(:disabled, [data-disabled])) {
109
136
  background-color: var(--accent-10);
137
+
138
+ /* Theme-level translucent override for hover */
139
+ :where([data-panel-background='translucent'], [data-material='translucent']) & {
140
+ background-color: color-mix(in srgb, var(--accent-a10), var(--accent-10) 10%);
141
+ }
142
+
143
+ /* Component-level overrides for hover */
144
+ &:where([data-panel-background='solid'], [data-material='solid']) {
145
+ background-color: var(--accent-10);
146
+ }
147
+
148
+ &:where([data-panel-background='translucent'], [data-material='translucent']) {
149
+ background-color: color-mix(in srgb, var(--accent-a10), var(--accent-10) 10%);
150
+ }
151
+
110
152
  & :where(.rt-AvatarFallback) {
111
153
  background-color: inherit;
112
154
  }
113
155
  }
114
156
  }
115
157
  &:where(:active:not(:disabled, [data-disabled])) {
116
- background-color: var(--accent-10);
117
- filter: var(--base-button-solid-active-filter);
158
+ background-color: var(--accent-11);
159
+
160
+ /* Theme-level translucent override for active */
161
+ :where([data-panel-background='translucent'], [data-material='translucent']) & {
162
+ background-color: color-mix(in srgb, var(--accent-a11), var(--accent-11) 10%);
163
+ }
164
+
165
+ /* Component-level overrides for active */
166
+ &:where([data-panel-background='solid'], [data-material='solid']) {
167
+ background-color: var(--accent-11);
168
+ }
169
+
170
+ &:where([data-panel-background='translucent'], [data-material='translucent']) {
171
+ background-color: color-mix(in srgb, var(--accent-a11), var(--accent-11) 10%);
172
+ }
173
+
118
174
  & :where(.rt-AvatarFallback) {
119
175
  background-color: inherit;
120
- filter: inherit;
121
176
  }
122
177
  }
123
178
 
@@ -125,19 +180,45 @@
125
180
  @media (hover: hover) {
126
181
  &:where(:hover:not(:disabled, [data-disabled])) {
127
182
  background-color: var(--accent-12);
128
- filter: var(--base-button-solid-high-contrast-hover-filter);
183
+
184
+ /* Theme-level translucent override for hover */
185
+ :where([data-panel-background='translucent'], [data-material='translucent']) & {
186
+ background-color: color-mix(in srgb, var(--accent-a12), var(--accent-12) 10%);
187
+ }
188
+
189
+ /* Component-level overrides for hover */
190
+ &:where([data-panel-background='solid'], [data-material='solid']) {
191
+ background-color: var(--accent-12);
192
+ }
193
+
194
+ &:where([data-panel-background='translucent'], [data-material='translucent']) {
195
+ background-color: color-mix(in srgb, var(--accent-a12), var(--accent-12) 10%);
196
+ }
197
+
129
198
  & :where(.rt-AvatarFallback) {
130
199
  background-color: inherit;
131
- filter: inherit;
132
200
  }
133
201
  }
134
202
  }
135
203
  &:where(:active:not(:disabled, [data-disabled])) {
136
204
  background-color: var(--accent-12);
137
- filter: var(--base-button-solid-high-contrast-active-filter);
205
+
206
+ /* Theme-level translucent override for active */
207
+ :where([data-panel-background='translucent'], [data-material='translucent']) & {
208
+ background-color: color-mix(in srgb, var(--accent-a12), var(--accent-12) 10%);
209
+ }
210
+
211
+ /* Component-level overrides for active */
212
+ &:where([data-panel-background='solid'], [data-material='solid']) {
213
+ background-color: var(--accent-12);
214
+ }
215
+
216
+ &:where([data-panel-background='translucent'], [data-material='translucent']) {
217
+ background-color: color-mix(in srgb, var(--accent-a12), var(--accent-12) 10%);
218
+ }
219
+
138
220
  & :where(.rt-AvatarFallback) {
139
221
  background-color: inherit;
140
- filter: inherit;
141
222
  }
142
223
  }
143
224
  }
@@ -148,9 +229,19 @@
148
229
  @media (hover: hover) {
149
230
  &:where(:hover:not(:disabled, [data-disabled])) {
150
231
  background-color: var(--accent-4);
232
+
233
+ /* Theme-level translucent override for hover */
234
+ :where([data-panel-background='translucent'], [data-material='translucent']) & {
235
+ background-color: color-mix(in srgb, var(--accent-a4), var(--accent-4) 60%);
236
+ }
237
+
238
+ /* Component-level overrides for hover */
239
+ &:where([data-panel-background='solid'], [data-material='solid']) {
240
+ background-color: var(--accent-4);
241
+ }
151
242
 
152
- :where([data-panel-background='translucent']) & {
153
- background-color: var(--accent-a4);
243
+ &:where([data-panel-background='translucent'], [data-material='translucent']) {
244
+ background-color: color-mix(in srgb, var(--accent-a4), var(--accent-4) 60%);
154
245
  }
155
246
 
156
247
  & :where(.rt-AvatarFallback) {
@@ -160,9 +251,19 @@
160
251
  }
161
252
  &:where(:active:not(:disabled, [data-disabled])) {
162
253
  background-color: var(--accent-5);
254
+
255
+ /* Theme-level translucent override for active */
256
+ :where([data-panel-background='translucent'], [data-material='translucent']) & {
257
+ background-color: color-mix(in srgb, var(--accent-a5), var(--accent-5) 60%);
258
+ }
163
259
 
164
- :where([data-panel-background='translucent']) & {
165
- background-color: var(--accent-a5);
260
+ /* Component-level overrides for active */
261
+ &:where([data-panel-background='solid'], [data-material='solid']) {
262
+ background-color: var(--accent-5);
263
+ }
264
+
265
+ &:where([data-panel-background='translucent'], [data-material='translucent']) {
266
+ background-color: color-mix(in srgb, var(--accent-a5), var(--accent-5) 60%);
166
267
  }
167
268
 
168
269
  & :where(.rt-AvatarFallback) {
@@ -175,22 +276,53 @@
175
276
  &:where(.rt-variant-surface) {
176
277
  @media (hover: hover) {
177
278
  &:where(:hover:not(:disabled, [data-disabled])) {
178
- box-shadow: inset 0 0 0 1px var(--accent-8);
179
- :where([data-panel-background='translucent']) & {
180
- box-shadow: inset 0 0 0 1px var(--accent-a8);
279
+ background-color: var(--accent-3);
280
+ box-shadow: inset 0 0 0 1px var(--accent-7);
281
+
282
+ /* Theme-level translucent override for hover */
283
+ :where([data-panel-background='translucent'], [data-material='translucent']) & {
284
+ background-color: color-mix(in srgb, var(--accent-a3), var(--accent-3) 60%);
285
+ box-shadow: inset 0 0 0 1px var(--accent-a7);
286
+ }
287
+
288
+ /* Component-level overrides for hover */
289
+ &:where([data-panel-background='solid'], [data-material='solid']) {
290
+ background-color: var(--accent-3);
291
+ box-shadow: inset 0 0 0 1px var(--accent-7);
292
+ }
293
+
294
+ &:where([data-panel-background='translucent'], [data-material='translucent']) {
295
+ background-color: color-mix(in srgb, var(--accent-a3), var(--accent-3) 60%);
296
+ box-shadow: inset 0 0 0 1px var(--accent-a7);
181
297
  }
298
+
182
299
  & :where(.rt-AvatarFallback) {
300
+ background-color: inherit;
183
301
  box-shadow: inherit;
184
302
  }
185
303
  }
186
304
  }
187
305
  &:where(:active:not(:disabled, [data-disabled])) {
188
- background-color: var(--accent-3);
306
+ background-color: var(--accent-4);
189
307
  box-shadow: inset 0 0 0 1px var(--accent-8);
190
- :where([data-panel-background='translucent']) & {
191
- background-color: var(--accent-a3);
308
+
309
+ /* Theme-level translucent override for active */
310
+ :where([data-panel-background='translucent'], [data-material='translucent']) & {
311
+ background-color: color-mix(in srgb, var(--accent-a4), var(--accent-4) 60%);
312
+ box-shadow: inset 0 0 0 1px var(--accent-a8);
313
+ }
314
+
315
+ /* Component-level overrides for active */
316
+ &:where([data-panel-background='solid'], [data-material='solid']) {
317
+ background-color: var(--accent-4);
318
+ box-shadow: inset 0 0 0 1px var(--accent-8);
319
+ }
320
+
321
+ &:where([data-panel-background='translucent'], [data-material='translucent']) {
322
+ background-color: color-mix(in srgb, var(--accent-a4), var(--accent-4) 60%);
192
323
  box-shadow: inset 0 0 0 1px var(--accent-a8);
193
324
  }
325
+
194
326
  & :where(.rt-AvatarFallback) {
195
327
  background-color: inherit;
196
328
  box-shadow: inherit;
@@ -203,35 +335,55 @@
203
335
  @media (hover: hover) {
204
336
  &:where(:hover:not(:disabled, [data-disabled])) {
205
337
  background-color: var(--accent-2);
206
- :where([data-panel-background='translucent']) & {
207
- background-color: var(--accent-a2);
208
- backdrop-filter: var(--backdrop-filter-components);
338
+ box-shadow: inset 0 0 0 1px var(--accent-7);
339
+
340
+ /* Theme-level translucent override for hover */
341
+ :where([data-panel-background='translucent'], [data-material='translucent']) & {
342
+ background-color: color-mix(in srgb, var(--accent-a2), var(--accent-2) 60%);
343
+ box-shadow: inset 0 0 0 1px var(--accent-a7);
209
344
  }
210
- & :where(.rt-AvatarFallback) {
211
- background-color: inherit;
212
- backdrop-filter: inherit;
345
+
346
+ /* Component-level overrides for hover */
347
+ &:where([data-panel-background='solid'], [data-material='solid']) {
348
+ background-color: var(--accent-2);
349
+ box-shadow: inset 0 0 0 1px var(--accent-7);
350
+ }
351
+
352
+ &:where([data-panel-background='translucent'], [data-material='translucent']) {
353
+ background-color: color-mix(in srgb, var(--accent-a2), var(--accent-2) 60%);
354
+ box-shadow: inset 0 0 0 1px var(--accent-a7);
213
355
  }
214
356
 
215
- /* Disable backdrop-filter when inside elements that already have backdrop-filter */
216
- :where(.rt-PopoverContent, .rt-BaseDialogContent, .rt-BaseMenuContent, .rt-DropdownMenuContent, .rt-ContextMenuContent, .rt-AlertDialogContent, .rt-HoverCardContent, .rt-TooltipContent, .rt-Card) & {
217
- backdrop-filter: none !important;
357
+ & :where(.rt-AvatarFallback) {
358
+ background-color: inherit;
359
+ box-shadow: inherit;
218
360
  }
219
361
  }
220
362
  }
221
363
  &:where(:active:not(:disabled, [data-disabled])) {
222
364
  background-color: var(--accent-3);
223
- :where([data-panel-background='translucent']) & {
224
- background-color: var(--accent-a3);
225
- backdrop-filter: var(--backdrop-filter-components);
365
+ box-shadow: inset 0 0 0 1px var(--accent-8);
366
+
367
+ /* Theme-level translucent override for active */
368
+ :where([data-panel-background='translucent'], [data-material='translucent']) & {
369
+ background-color: color-mix(in srgb, var(--accent-a3), var(--accent-3) 60%);
370
+ box-shadow: inset 0 0 0 1px var(--accent-a8);
226
371
  }
227
- & :where(.rt-AvatarFallback) {
228
- background-color: inherit;
229
- backdrop-filter: inherit;
372
+
373
+ /* Component-level overrides for active */
374
+ &:where([data-panel-background='solid'], [data-material='solid']) {
375
+ background-color: var(--accent-3);
376
+ box-shadow: inset 0 0 0 1px var(--accent-8);
230
377
  }
231
378
 
232
- /* Disable backdrop-filter when inside elements that already have backdrop-filter */
233
- :where(.rt-PopoverContent, .rt-BaseDialogContent, .rt-BaseMenuContent, .rt-DropdownMenuContent, .rt-ContextMenuContent, .rt-AlertDialogContent, .rt-HoverCardContent, .rt-TooltipContent, .rt-Card) & {
234
- backdrop-filter: none !important;
379
+ &:where([data-panel-background='translucent'], [data-material='translucent']) {
380
+ background-color: color-mix(in srgb, var(--accent-a3), var(--accent-3) 60%);
381
+ box-shadow: inset 0 0 0 1px var(--accent-a8);
382
+ }
383
+
384
+ & :where(.rt-AvatarFallback) {
385
+ background-color: inherit;
386
+ box-shadow: inherit;
235
387
  }
236
388
  }
237
389
  }
@@ -355,12 +507,41 @@
355
507
 
356
508
  .rt-AvatarRoot:where(.rt-variant-solid) {
357
509
  & :where(.rt-AvatarFallback) {
510
+ /* Base state: solid color for solid panels */
358
511
  background-color: var(--accent-9);
359
512
  color: var(--accent-contrast);
513
+
514
+ /* Theme-level translucent override */
515
+ :where([data-panel-background='translucent'], [data-material='translucent']) & {
516
+ background-color: color-mix(in srgb, var(--accent-a9), var(--accent-9) 10%);
517
+ }
518
+
519
+ /* Component-level overrides (higher specificity) */
520
+ :where(.rt-AvatarRoot[data-panel-background='solid'], .rt-AvatarRoot[data-material='solid']) & {
521
+ background-color: var(--accent-9);
522
+ }
523
+
524
+ :where(.rt-AvatarRoot[data-panel-background='translucent'], .rt-AvatarRoot[data-material='translucent']) & {
525
+ background-color: color-mix(in srgb, var(--accent-a9), var(--accent-9) 10%);
526
+ }
360
527
  }
361
528
  &:where(.rt-high-contrast) :where(.rt-AvatarFallback) {
362
529
  background-color: var(--accent-12);
363
- color: var(--accent-1);
530
+ color: var(--gray-1);
531
+
532
+ /* Theme-level translucent override for high contrast */
533
+ :where([data-panel-background='translucent'], [data-material='translucent']) & {
534
+ background-color: color-mix(in srgb, var(--accent-a12), var(--accent-12) 10%);
535
+ }
536
+
537
+ /* Component-level overrides for high contrast */
538
+ :where(.rt-AvatarRoot[data-panel-background='solid'], .rt-AvatarRoot[data-material='solid']) & {
539
+ background-color: var(--accent-12);
540
+ }
541
+
542
+ :where(.rt-AvatarRoot[data-panel-background='translucent'], .rt-AvatarRoot[data-material='translucent']) & {
543
+ background-color: color-mix(in srgb, var(--accent-a12), var(--accent-12) 10%);
544
+ }
364
545
  }
365
546
  &:where([data-disabled]) :where(.rt-AvatarFallback) {
366
547
  color: var(--gray-a8);
@@ -378,40 +559,26 @@
378
559
  color: var(--accent-11);
379
560
 
380
561
  /* Theme-level translucent override */
381
- :where([data-panel-background='translucent']) & {
382
- background-color: var(--accent-a3);
383
- color: var(--accent-a11);
384
- backdrop-filter: var(--backdrop-filter-components);
562
+ :where([data-panel-background='translucent'], [data-material='translucent']) & {
563
+ background-color: color-mix(in srgb, var(--accent-a3), var(--accent-3) 60%);
385
564
  }
386
565
 
387
566
  /* Component-level overrides (higher specificity) */
388
- :where(.rt-AvatarRoot[data-panel-background='solid']) & {
567
+ :where(.rt-AvatarRoot[data-panel-background='solid'], .rt-AvatarRoot[data-material='solid']) & {
389
568
  background-color: var(--accent-3);
390
- color: var(--accent-11);
391
- backdrop-filter: none;
392
- --backdrop-filter-components: none;
393
569
  }
394
570
 
395
- :where(.rt-AvatarRoot[data-panel-background='translucent']) & {
396
- background-color: var(--accent-a3);
397
- color: var(--accent-a11);
398
- backdrop-filter: var(--backdrop-filter-components);
399
- --backdrop-filter-components: blur(var(--backdrop-blur-components));
571
+ :where(.rt-AvatarRoot[data-panel-background='translucent'], .rt-AvatarRoot[data-material='translucent']) & {
572
+ background-color: color-mix(in srgb, var(--accent-a3), var(--accent-3) 60%);
400
573
  }
401
574
  }
402
575
  &:where(.rt-high-contrast) :where(.rt-AvatarFallback) {
403
576
  background-color: var(--accent-3);
404
577
  color: var(--accent-12);
405
-
406
- :where([data-panel-background='translucent']) & {
407
- background-color: var(--accent-a3);
408
- color: var(--accent-a12);
409
- }
410
578
  }
411
579
  &:where([data-disabled]) :where(.rt-AvatarFallback) {
412
580
  color: var(--gray-a8);
413
581
  background-color: var(--gray-a3);
414
- backdrop-filter: none;
415
582
  }
416
583
  }
417
584
 
@@ -419,31 +586,26 @@
419
586
 
420
587
  .rt-AvatarRoot:where(.rt-variant-surface) {
421
588
  & :where(.rt-AvatarFallback) {
422
- /* Base state: solid colors for solid panels */
589
+ /* Base state: solid accent for solid panels */
423
590
  background-color: var(--accent-2);
424
- box-shadow: inset 0 0 0 1px var(--accent-7);
591
+ box-shadow: inset 0 0 0 1px var(--accent-6);
425
592
  color: var(--accent-a11);
426
593
 
427
594
  /* Theme-level translucent override */
428
- :where([data-panel-background='translucent']) & {
429
- background-color: var(--accent-a2);
430
- box-shadow: inset 0 0 0 1px var(--accent-a7);
431
- backdrop-filter: var(--backdrop-filter-components);
595
+ :where([data-panel-background='translucent'], [data-material='translucent']) & {
596
+ background-color: color-mix(in srgb, var(--accent-a2), var(--accent-2) 60%);
597
+ box-shadow: inset 0 0 0 1px var(--accent-a6);
432
598
  }
433
599
 
434
600
  /* Component-level overrides (higher specificity) */
435
- :where(.rt-AvatarRoot[data-panel-background='solid']) & {
601
+ :where(.rt-AvatarRoot[data-panel-background='solid'], .rt-AvatarRoot[data-material='solid']) & {
436
602
  background-color: var(--accent-2);
437
- box-shadow: inset 0 0 0 1px var(--accent-7);
438
- backdrop-filter: none;
439
- --backdrop-filter-components: none;
603
+ box-shadow: inset 0 0 0 1px var(--accent-6);
440
604
  }
441
605
 
442
- :where(.rt-AvatarRoot[data-panel-background='translucent']) & {
443
- background-color: var(--accent-a2);
444
- box-shadow: inset 0 0 0 1px var(--accent-a7);
445
- backdrop-filter: var(--backdrop-filter-components);
446
- --backdrop-filter-components: blur(var(--backdrop-blur-components));
606
+ :where(.rt-AvatarRoot[data-panel-background='translucent'], .rt-AvatarRoot[data-material='translucent']) & {
607
+ background-color: color-mix(in srgb, var(--accent-a2), var(--accent-2) 60%);
608
+ box-shadow: inset 0 0 0 1px var(--accent-a6);
447
609
  }
448
610
  }
449
611
  &:where(.rt-high-contrast) :where(.rt-AvatarFallback) {
@@ -453,7 +615,6 @@
453
615
  color: var(--gray-a8);
454
616
  background-color: var(--gray-a2);
455
617
  box-shadow: inset 0 0 0 1px var(--gray-a6);
456
- backdrop-filter: none;
457
618
  }
458
619
  }
459
620
 
@@ -462,98 +623,79 @@
462
623
  .rt-AvatarRoot:where(.rt-variant-outline) {
463
624
  & :where(.rt-AvatarFallback) {
464
625
  /* Base state: solid colors for solid panels */
465
- background-color: transparent;
466
- box-shadow: inset 0 0 0 1px var(--accent-8);
626
+ box-shadow: inset 0 0 0 1px var(--accent-6);
467
627
  color: var(--accent-11);
468
628
 
469
629
  /* Theme-level translucent override */
470
- :where([data-panel-background='translucent']) & {
471
- box-shadow: inset 0 0 0 1px var(--accent-a8);
630
+ :where([data-panel-background='translucent'], [data-material='translucent']) & {
631
+ box-shadow: inset 0 0 0 1px var(--accent-a6);
472
632
  color: var(--accent-a11);
473
633
  }
474
634
 
475
635
  /* Component-level overrides (higher specificity) */
476
- :where(.rt-AvatarRoot[data-panel-background='solid']) & {
477
- box-shadow: inset 0 0 0 1px var(--accent-8);
636
+ :where(.rt-AvatarRoot[data-panel-background='solid'], .rt-AvatarRoot[data-material='solid']) & {
637
+ box-shadow: inset 0 0 0 1px var(--accent-6);
478
638
  color: var(--accent-11);
479
- backdrop-filter: none;
480
- --backdrop-filter-components: none;
481
639
  }
482
640
 
483
- :where(.rt-AvatarRoot[data-panel-background='translucent']) & {
484
- box-shadow: inset 0 0 0 1px var(--accent-a8);
641
+ :where(.rt-AvatarRoot[data-panel-background='translucent'], .rt-AvatarRoot[data-material='translucent']) & {
642
+ box-shadow: inset 0 0 0 1px var(--accent-a6);
485
643
  color: var(--accent-a11);
486
644
  }
487
645
  }
488
646
  &:where(.rt-high-contrast) :where(.rt-AvatarFallback) {
489
- box-shadow:
490
- inset 0 0 0 1px var(--accent-7),
491
- inset 0 0 0 1px var(--gray-11);
492
647
  color: var(--accent-12);
493
-
494
- /* Theme-level translucent override for high contrast */
495
- :where([data-panel-background='translucent']) & {
496
- box-shadow:
497
- inset 0 0 0 1px var(--accent-a7),
498
- inset 0 0 0 1px var(--gray-a11);
499
- }
500
-
501
- /* Component-level overrides for high contrast */
502
- :where(.rt-AvatarRoot[data-panel-background='solid']) & {
503
- box-shadow:
504
- inset 0 0 0 1px var(--accent-7),
505
- inset 0 0 0 1px var(--gray-11);
506
- }
507
-
508
- :where(.rt-AvatarRoot[data-panel-background='translucent']) & {
509
- box-shadow:
510
- inset 0 0 0 1px var(--accent-a7),
511
- inset 0 0 0 1px var(--gray-a11);
512
- }
513
648
  }
514
649
  &:where([data-disabled]) :where(.rt-AvatarFallback) {
515
650
  color: var(--gray-a8);
516
651
  background-color: transparent;
517
652
  box-shadow: inset 0 0 0 1px var(--gray-a7);
518
- backdrop-filter: none;
519
653
  }
520
654
  }
521
655
 
522
656
  /* classic */
523
657
 
524
658
  .rt-AvatarRoot:where(.rt-variant-classic) {
525
- /* Match button's slight elevation */
526
659
  position: relative;
527
660
  top: var(--classic-elevation-offset);
528
661
  & :where(.rt-AvatarFallback) {
529
662
  position: relative;
530
663
  top: 0; /* reset – elevation handled by root now */
531
664
  color: var(--accent-a11);
532
- background-color: var(--accent-2);
533
- /* prettier-ignore */
534
- box-shadow:
535
- inset 0 calc(-1 * var(--classic-border-width)) var(--classic-shadow-blur-large) var(--accent-a2),
536
- inset 0 var(--classic-border-width) var(--white-a12),
537
- inset 0 var(--classic-shadow-blur-medium) var(--classic-shadow-blur-large) var(--accent-a2),
538
- inset 0 calc(-1 * var(--classic-border-width)) var(--accent-a6),
539
- 0 0 0 var(--classic-border-width) var(--accent-a5),
540
- 0 var(--classic-shadow-offset-y) var(--classic-shadow-blur-small) var(--accent-a7);
541
-
542
- :where(.dark, .dark-theme) &,
543
- :where(.dark, .dark-theme) :where(.radix-themes:not(.light, .light-theme)) & {
544
- /* prettier-ignore */
545
- box-shadow:
546
- inset 0 calc(-1 * var(--classic-border-width)) var(--classic-shadow-blur-large) var(--accent-a3),
547
- inset 0 var(--classic-border-width) var(--accent-a11),
548
- inset 0 var(--classic-shadow-blur-medium) var(--classic-shadow-blur-large) var(--accent-a2),
549
- inset 0 calc(-2 * var(--classic-border-width)) var(--black-a11),
550
- 0 0 0 var(--classic-border-width-thick) var(--accent-a7),
551
- 0 var(--classic-shadow-offset-y) var(--classic-shadow-blur-small) var(--black-a12);
665
+ background-color: var(--color-surface-solid);
666
+ box-shadow: var(--shadow-2);
667
+
668
+ /* Theme-level translucent override */
669
+ :where([data-panel-background='translucent'], [data-material='translucent']) & {
670
+ background-color: var(--color-surface-translucent);
671
+ }
672
+
673
+ /* Component-level overrides (higher specificity) */
674
+ :where(.rt-AvatarRoot[data-panel-background='solid'], .rt-AvatarRoot[data-material='solid']) & {
675
+ background-color: var(--color-surface-solid);
676
+ }
677
+
678
+ :where(.rt-AvatarRoot[data-panel-background='translucent'], .rt-AvatarRoot[data-material='translucent']) & {
679
+ background-color: var(--color-surface-translucent);
552
680
  }
553
681
  }
554
682
  &:where(.rt-high-contrast) :where(.rt-AvatarFallback) {
555
- color: var(--accent-12);
556
- background-color: var(--accent-2);
683
+ color: var(--gray-12);
684
+ background-color: var(--color-surface-solid);
685
+
686
+ /* Theme-level translucent override for high contrast */
687
+ :where([data-panel-background='translucent'], [data-material='translucent']) & {
688
+ background-color: var(--color-surface-translucent);
689
+ }
690
+
691
+ /* Component-level overrides for high contrast */
692
+ :where(.rt-AvatarRoot[data-panel-background='solid'], .rt-AvatarRoot[data-material='solid']) & {
693
+ background-color: var(--color-surface-solid);
694
+ }
695
+
696
+ :where(.rt-AvatarRoot[data-panel-background='translucent'], .rt-AvatarRoot[data-material='translucent']) & {
697
+ background-color: var(--color-surface-translucent);
698
+ }
557
699
  }
558
700
  &:where([data-disabled]) :where(.rt-AvatarFallback) {
559
701
  color: var(--gray-a8);
@@ -6,8 +6,9 @@ import { radiusPropDef } from '../props/radius.prop.js';
6
6
  import type { PropDef } from '../props/prop-def.js';
7
7
 
8
8
  const sizes = ['1', '2', '3', '4', '5', '6', '7', '8', '9'] as const;
9
- const variants = ['solid', 'soft', 'surface', 'outline'] as const;
9
+ const variants = ['classic', 'solid', 'soft', 'surface', 'outline'] as const;
10
10
  const panelBackgrounds = ['solid', 'translucent'] as const;
11
+ const materials = ['solid', 'translucent'] as const;
11
12
 
12
13
  const avatarPropDefs = {
13
14
  ...asChildPropDef,
@@ -17,11 +18,16 @@ const avatarPropDefs = {
17
18
  ...highContrastPropDef,
18
19
  ...radiusPropDef,
19
20
  fallback: { type: 'ReactNode', required: true },
21
+ material: { type: 'enum', values: materials, default: undefined },
22
+ /**
23
+ * @deprecated Use `material` prop instead. This prop will be removed in a future version.
24
+ */
20
25
  panelBackground: { type: 'enum', values: panelBackgrounds, default: undefined },
21
26
  } satisfies {
22
27
  size: PropDef<(typeof sizes)[number]>;
23
28
  variant: PropDef<(typeof variants)[number]>;
24
29
  fallback: PropDef<React.ReactNode>;
30
+ material: PropDef<(typeof materials)[number] | undefined>;
25
31
  panelBackground: PropDef<(typeof panelBackgrounds)[number] | undefined>;
26
32
  };
27
33