@neynar/ui 0.2.1 → 0.3.1

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 (547) hide show
  1. package/{llm-docs → .llm}/a.llm.md +2 -16
  2. package/{llm-docs → .llm}/badge.llm.md +16 -21
  3. package/{llm-docs → .llm}/blockquote.llm.md +1 -6
  4. package/.llm/button-group-separator.llm.md +53 -0
  5. package/.llm/button-group-text.llm.md +56 -0
  6. package/.llm/button-group.llm.md +81 -0
  7. package/{llm-docs → .llm}/button.llm.md +1 -1
  8. package/{llm-docs → .llm}/code.llm.md +1 -6
  9. package/.llm/empty-content.llm.md +103 -0
  10. package/.llm/empty-description.llm.md +70 -0
  11. package/.llm/empty-header.llm.md +64 -0
  12. package/.llm/empty-media.llm.md +81 -0
  13. package/.llm/empty-title.llm.md +54 -0
  14. package/.llm/empty.llm.md +158 -0
  15. package/.llm/field-content.llm.md +28 -0
  16. package/.llm/field-description.llm.md +28 -0
  17. package/.llm/field-error.llm.md +41 -0
  18. package/.llm/field-group.llm.md +84 -0
  19. package/.llm/field-label.llm.md +28 -0
  20. package/.llm/field-legend.llm.md +77 -0
  21. package/.llm/field-separator.llm.md +35 -0
  22. package/.llm/field-set.llm.md +80 -0
  23. package/.llm/field-title.llm.md +28 -0
  24. package/.llm/field.llm.md +35 -0
  25. package/{llm-docs → .llm}/h1.llm.md +2 -7
  26. package/{llm-docs → .llm}/h2.llm.md +2 -7
  27. package/{llm-docs → .llm}/h3.llm.md +2 -7
  28. package/{llm-docs → .llm}/h4.llm.md +2 -7
  29. package/{llm-docs → .llm}/h5.llm.md +2 -7
  30. package/{llm-docs → .llm}/h6.llm.md +1 -6
  31. package/.llm/input-group-addon.llm.md +91 -0
  32. package/.llm/input-group-button.llm.md +120 -0
  33. package/.llm/input-group-input.llm.md +145 -0
  34. package/.llm/input-group-text.llm.md +75 -0
  35. package/.llm/input-group-textarea.llm.md +157 -0
  36. package/.llm/input-group.llm.md +108 -0
  37. package/.llm/item-actions.llm.md +77 -0
  38. package/.llm/item-content.llm.md +73 -0
  39. package/.llm/item-description.llm.md +61 -0
  40. package/.llm/item-footer.llm.md +68 -0
  41. package/.llm/item-group.llm.md +73 -0
  42. package/.llm/item-header.llm.md +66 -0
  43. package/.llm/item-media.llm.md +75 -0
  44. package/.llm/item-separator.llm.md +80 -0
  45. package/.llm/item-title.llm.md +59 -0
  46. package/.llm/item.llm.md +115 -0
  47. package/.llm/kbd-group.llm.md +71 -0
  48. package/.llm/kbd.llm.md +71 -0
  49. package/{llm-docs → .llm}/lead.llm.md +1 -6
  50. package/{llm-docs → .llm}/p.llm.md +1 -6
  51. package/{llm-docs → .llm}/sdk-items-registry.json +390 -6
  52. package/{llm-docs → .llm}/small.llm.md +1 -6
  53. package/{llm-docs → .llm}/span.llm.md +2 -16
  54. package/.llm/spinner.llm.md +182 -0
  55. package/{llm-docs → .llm}/strong.llm.md +1 -6
  56. package/{llm-docs → .llm}/typography.llm.md +2 -16
  57. package/dist/components/ui/button-group.d.ts +448 -0
  58. package/dist/components/ui/button-group.d.ts.map +1 -0
  59. package/dist/components/ui/button.d.ts +1 -1
  60. package/dist/components/ui/button.d.ts.map +1 -1
  61. package/dist/components/ui/empty-state.d.ts +1 -0
  62. package/dist/components/ui/empty-state.d.ts.map +1 -1
  63. package/dist/components/ui/empty.d.ts +630 -0
  64. package/dist/components/ui/empty.d.ts.map +1 -0
  65. package/dist/components/ui/field.d.ts +238 -0
  66. package/dist/components/ui/field.d.ts.map +1 -0
  67. package/dist/components/ui/input-group.d.ts +636 -0
  68. package/dist/components/ui/input-group.d.ts.map +1 -0
  69. package/dist/components/ui/item.d.ts +766 -0
  70. package/dist/components/ui/item.d.ts.map +1 -0
  71. package/dist/components/ui/kbd.d.ts +149 -0
  72. package/dist/components/ui/kbd.d.ts.map +1 -0
  73. package/dist/components/ui/scroll-area.d.ts +5 -5
  74. package/dist/components/ui/scroll-area.d.ts.map +1 -1
  75. package/dist/components/ui/spinner.d.ts +194 -0
  76. package/dist/components/ui/spinner.d.ts.map +1 -0
  77. package/dist/components/ui/stack.d.ts.map +1 -1
  78. package/dist/components/ui/stories/accordion.stories.d.ts +0 -1
  79. package/dist/components/ui/stories/accordion.stories.d.ts.map +1 -1
  80. package/dist/components/ui/stories/alert-dialog.stories.d.ts +0 -1
  81. package/dist/components/ui/stories/alert-dialog.stories.d.ts.map +1 -1
  82. package/dist/components/ui/stories/alert.stories.d.ts +0 -1
  83. package/dist/components/ui/stories/alert.stories.d.ts.map +1 -1
  84. package/dist/components/ui/stories/aspect-ratio.stories.d.ts +0 -1
  85. package/dist/components/ui/stories/aspect-ratio.stories.d.ts.map +1 -1
  86. package/dist/components/ui/stories/avatar.stories.d.ts +0 -1
  87. package/dist/components/ui/stories/avatar.stories.d.ts.map +1 -1
  88. package/dist/components/ui/stories/badge.stories.d.ts +0 -1
  89. package/dist/components/ui/stories/badge.stories.d.ts.map +1 -1
  90. package/dist/components/ui/stories/breadcrumb.stories.d.ts +0 -1
  91. package/dist/components/ui/stories/breadcrumb.stories.d.ts.map +1 -1
  92. package/dist/components/ui/stories/button-group.stories.d.ts +48 -0
  93. package/dist/components/ui/stories/button-group.stories.d.ts.map +1 -0
  94. package/dist/components/ui/stories/button.stories.d.ts +0 -1
  95. package/dist/components/ui/stories/button.stories.d.ts.map +1 -1
  96. package/dist/components/ui/stories/calendar.stories.d.ts +0 -1
  97. package/dist/components/ui/stories/calendar.stories.d.ts.map +1 -1
  98. package/dist/components/ui/stories/card.stories.d.ts +0 -1
  99. package/dist/components/ui/stories/card.stories.d.ts.map +1 -1
  100. package/dist/components/ui/stories/carousel.stories.d.ts +0 -1
  101. package/dist/components/ui/stories/carousel.stories.d.ts.map +1 -1
  102. package/dist/components/ui/stories/chart.stories.d.ts +0 -1
  103. package/dist/components/ui/stories/chart.stories.d.ts.map +1 -1
  104. package/dist/components/ui/stories/checkbox.stories.d.ts +0 -1
  105. package/dist/components/ui/stories/checkbox.stories.d.ts.map +1 -1
  106. package/dist/components/ui/stories/cn.stories.d.ts.map +1 -1
  107. package/dist/components/ui/stories/collapsible.stories.d.ts +0 -1
  108. package/dist/components/ui/stories/collapsible.stories.d.ts.map +1 -1
  109. package/dist/components/ui/stories/colors.stories.d.ts +0 -1
  110. package/dist/components/ui/stories/colors.stories.d.ts.map +1 -1
  111. package/dist/components/ui/stories/combobox.stories.d.ts +0 -1
  112. package/dist/components/ui/stories/combobox.stories.d.ts.map +1 -1
  113. package/dist/components/ui/stories/command.stories.d.ts +0 -1
  114. package/dist/components/ui/stories/command.stories.d.ts.map +1 -1
  115. package/dist/components/ui/stories/container.stories.d.ts +0 -1
  116. package/dist/components/ui/stories/container.stories.d.ts.map +1 -1
  117. package/dist/components/ui/stories/context-menu.stories.d.ts +0 -1
  118. package/dist/components/ui/stories/context-menu.stories.d.ts.map +1 -1
  119. package/dist/components/ui/stories/date-picker.stories.d.ts +0 -1
  120. package/dist/components/ui/stories/date-picker.stories.d.ts.map +1 -1
  121. package/dist/components/ui/stories/dialog.stories.d.ts +0 -1
  122. package/dist/components/ui/stories/dialog.stories.d.ts.map +1 -1
  123. package/dist/components/ui/stories/drawer.stories.d.ts +0 -1
  124. package/dist/components/ui/stories/drawer.stories.d.ts.map +1 -1
  125. package/dist/components/ui/stories/dropdown-menu.stories.d.ts +0 -1
  126. package/dist/components/ui/stories/dropdown-menu.stories.d.ts.map +1 -1
  127. package/dist/components/ui/stories/empty-state.stories.d.ts +0 -1
  128. package/dist/components/ui/stories/empty-state.stories.d.ts.map +1 -1
  129. package/dist/components/ui/stories/empty.stories.d.ts +38 -0
  130. package/dist/components/ui/stories/empty.stories.d.ts.map +1 -0
  131. package/dist/components/ui/stories/field.stories.d.ts +48 -0
  132. package/dist/components/ui/stories/field.stories.d.ts.map +1 -0
  133. package/dist/components/ui/stories/hover-card.stories.d.ts +0 -1
  134. package/dist/components/ui/stories/hover-card.stories.d.ts.map +1 -1
  135. package/dist/components/ui/stories/input-group.stories.d.ts +37 -0
  136. package/dist/components/ui/stories/input-group.stories.d.ts.map +1 -0
  137. package/dist/components/ui/stories/input.stories.d.ts +0 -1
  138. package/dist/components/ui/stories/input.stories.d.ts.map +1 -1
  139. package/dist/components/ui/stories/item.stories.d.ts +61 -0
  140. package/dist/components/ui/stories/item.stories.d.ts.map +1 -0
  141. package/dist/components/ui/stories/kbd.stories.d.ts +37 -0
  142. package/dist/components/ui/stories/kbd.stories.d.ts.map +1 -0
  143. package/dist/components/ui/stories/label.stories.d.ts +0 -1
  144. package/dist/components/ui/stories/label.stories.d.ts.map +1 -1
  145. package/dist/components/ui/stories/menubar.stories.d.ts +0 -1
  146. package/dist/components/ui/stories/menubar.stories.d.ts.map +1 -1
  147. package/dist/components/ui/stories/navigation-menu.stories.d.ts +0 -1
  148. package/dist/components/ui/stories/navigation-menu.stories.d.ts.map +1 -1
  149. package/dist/components/ui/stories/pagination.stories.d.ts +0 -1
  150. package/dist/components/ui/stories/pagination.stories.d.ts.map +1 -1
  151. package/dist/components/ui/stories/popover.stories.d.ts +0 -1
  152. package/dist/components/ui/stories/popover.stories.d.ts.map +1 -1
  153. package/dist/components/ui/stories/progress.stories.d.ts +0 -1
  154. package/dist/components/ui/stories/progress.stories.d.ts.map +1 -1
  155. package/dist/components/ui/stories/radio-group.stories.d.ts +0 -1
  156. package/dist/components/ui/stories/radio-group.stories.d.ts.map +1 -1
  157. package/dist/components/ui/stories/resizable.stories.d.ts +0 -1
  158. package/dist/components/ui/stories/resizable.stories.d.ts.map +1 -1
  159. package/dist/components/ui/stories/scroll-area.stories.d.ts +1 -2
  160. package/dist/components/ui/stories/scroll-area.stories.d.ts.map +1 -1
  161. package/dist/components/ui/stories/select.stories.d.ts +0 -1
  162. package/dist/components/ui/stories/select.stories.d.ts.map +1 -1
  163. package/dist/components/ui/stories/separator.stories.d.ts +0 -1
  164. package/dist/components/ui/stories/separator.stories.d.ts.map +1 -1
  165. package/dist/components/ui/stories/sheet.stories.d.ts +0 -1
  166. package/dist/components/ui/stories/sheet.stories.d.ts.map +1 -1
  167. package/dist/components/ui/stories/sidebar.stories.d.ts +0 -1
  168. package/dist/components/ui/stories/sidebar.stories.d.ts.map +1 -1
  169. package/dist/components/ui/stories/skeleton.stories.d.ts +0 -1
  170. package/dist/components/ui/stories/skeleton.stories.d.ts.map +1 -1
  171. package/dist/components/ui/stories/slider.stories.d.ts +0 -1
  172. package/dist/components/ui/stories/slider.stories.d.ts.map +1 -1
  173. package/dist/components/ui/stories/sonner.stories.d.ts.map +1 -1
  174. package/dist/components/ui/stories/spinner.stories.d.ts +37 -0
  175. package/dist/components/ui/stories/spinner.stories.d.ts.map +1 -0
  176. package/dist/components/ui/stories/stack.stories.d.ts +0 -1
  177. package/dist/components/ui/stories/stack.stories.d.ts.map +1 -1
  178. package/dist/components/ui/stories/switch.stories.d.ts +0 -1
  179. package/dist/components/ui/stories/switch.stories.d.ts.map +1 -1
  180. package/dist/components/ui/stories/table.stories.d.ts +0 -1
  181. package/dist/components/ui/stories/table.stories.d.ts.map +1 -1
  182. package/dist/components/ui/stories/tabs.stories.d.ts +0 -1
  183. package/dist/components/ui/stories/tabs.stories.d.ts.map +1 -1
  184. package/dist/components/ui/stories/text-field.stories.d.ts +0 -1
  185. package/dist/components/ui/stories/text-field.stories.d.ts.map +1 -1
  186. package/dist/components/ui/stories/textarea.stories.d.ts +0 -1
  187. package/dist/components/ui/stories/textarea.stories.d.ts.map +1 -1
  188. package/dist/components/ui/stories/theme-toggle.stories.d.ts +0 -1
  189. package/dist/components/ui/stories/theme-toggle.stories.d.ts.map +1 -1
  190. package/dist/components/ui/stories/theme.stories.d.ts +0 -1
  191. package/dist/components/ui/stories/theme.stories.d.ts.map +1 -1
  192. package/dist/components/ui/stories/toggle-group.stories.d.ts +0 -1
  193. package/dist/components/ui/stories/toggle-group.stories.d.ts.map +1 -1
  194. package/dist/components/ui/stories/toggle.stories.d.ts +0 -1
  195. package/dist/components/ui/stories/toggle.stories.d.ts.map +1 -1
  196. package/dist/components/ui/stories/tooltip.stories.d.ts +0 -1
  197. package/dist/components/ui/stories/tooltip.stories.d.ts.map +1 -1
  198. package/dist/components/ui/stories/typography.stories.d.ts +0 -1
  199. package/dist/components/ui/stories/typography.stories.d.ts.map +1 -1
  200. package/dist/components/ui/stories/use-mobile.stories.d.ts.map +1 -1
  201. package/dist/components/ui/stories/use-theme.stories.d.ts.map +1 -1
  202. package/dist/components/ui/theme-toggle.d.ts +0 -3
  203. package/dist/components/ui/theme-toggle.d.ts.map +1 -1
  204. package/dist/components/ui/theme.d.ts.map +1 -1
  205. package/dist/components/ui/typography.d.ts +12 -11
  206. package/dist/components/ui/typography.d.ts.map +1 -1
  207. package/dist/index.d.ts +7 -0
  208. package/dist/index.d.ts.map +1 -1
  209. package/dist/index.js +4973 -2353
  210. package/dist/index.js.map +1 -1
  211. package/dist/tsconfig.tsbuildinfo +1 -1
  212. package/docs/llm/components/display.md +125 -0
  213. package/docs/llm/components/feedback.md +0 -14
  214. package/docs/llm/components/forms.md +94 -0
  215. package/docs/llm/components/layout.md +169 -0
  216. package/llms.txt +18 -12
  217. package/package.json +7 -6
  218. package/src/components/ui/button-group.tsx +525 -0
  219. package/src/components/ui/button.tsx +9 -12
  220. package/src/components/ui/empty-state.tsx +1 -0
  221. package/src/components/ui/empty.tsx +793 -0
  222. package/src/components/ui/field.tsx +494 -0
  223. package/src/components/ui/input-group.tsx +801 -0
  224. package/src/components/ui/item.tsx +955 -0
  225. package/src/components/ui/kbd.tsx +175 -0
  226. package/src/components/ui/skeleton.tsx +1 -1
  227. package/src/components/ui/spinner.tsx +211 -0
  228. package/src/components/ui/stack.tsx +3 -1
  229. package/src/components/ui/stories/accordion.stories.tsx +0 -1
  230. package/src/components/ui/stories/alert-dialog.stories.tsx +0 -1
  231. package/src/components/ui/stories/alert.stories.tsx +0 -1
  232. package/src/components/ui/stories/aspect-ratio.stories.tsx +0 -1
  233. package/src/components/ui/stories/avatar.stories.tsx +0 -1
  234. package/src/components/ui/stories/badge.stories.tsx +0 -1
  235. package/src/components/ui/stories/breadcrumb.stories.tsx +0 -1
  236. package/src/components/ui/stories/button-group.stories.tsx +300 -0
  237. package/src/components/ui/stories/button.stories.tsx +0 -1
  238. package/src/components/ui/stories/calendar.stories.tsx +0 -1
  239. package/src/components/ui/stories/card.stories.tsx +0 -1
  240. package/src/components/ui/stories/carousel.stories.tsx +0 -1
  241. package/src/components/ui/stories/chart.stories.tsx +0 -1
  242. package/src/components/ui/stories/checkbox.stories.tsx +0 -1
  243. package/src/components/ui/stories/cn.stories.tsx +0 -1
  244. package/src/components/ui/stories/collapsible.stories.tsx +0 -1
  245. package/src/components/ui/stories/colors.stories.tsx +0 -1
  246. package/src/components/ui/stories/combobox.stories.tsx +0 -1
  247. package/src/components/ui/stories/command.stories.tsx +0 -1
  248. package/src/components/ui/stories/container.stories.tsx +0 -1
  249. package/src/components/ui/stories/context-menu.stories.tsx +0 -1
  250. package/src/components/ui/stories/date-picker.stories.tsx +0 -1
  251. package/src/components/ui/stories/dialog.stories.tsx +0 -1
  252. package/src/components/ui/stories/drawer.stories.tsx +0 -1
  253. package/src/components/ui/stories/dropdown-menu.stories.tsx +0 -1
  254. package/src/components/ui/stories/empty-state.stories.tsx +0 -1
  255. package/src/components/ui/stories/empty.stories.tsx +293 -0
  256. package/src/components/ui/stories/field.stories.tsx +470 -0
  257. package/src/components/ui/stories/hover-card.stories.tsx +0 -1
  258. package/src/components/ui/stories/input-group.stories.tsx +444 -0
  259. package/src/components/ui/stories/input.stories.tsx +0 -1
  260. package/src/components/ui/stories/item.stories.tsx +601 -0
  261. package/src/components/ui/stories/kbd.stories.tsx +462 -0
  262. package/src/components/ui/stories/label.stories.tsx +0 -1
  263. package/src/components/ui/stories/menubar.stories.tsx +0 -1
  264. package/src/components/ui/stories/navigation-menu.stories.tsx +0 -1
  265. package/src/components/ui/stories/pagination.stories.tsx +0 -1
  266. package/src/components/ui/stories/popover.stories.tsx +0 -1
  267. package/src/components/ui/stories/progress.stories.tsx +0 -1
  268. package/src/components/ui/stories/radio-group.stories.tsx +0 -1
  269. package/src/components/ui/stories/resizable.stories.tsx +0 -1
  270. package/src/components/ui/stories/scroll-area.stories.tsx +0 -1
  271. package/src/components/ui/stories/select.stories.tsx +0 -1
  272. package/src/components/ui/stories/separator.stories.tsx +0 -1
  273. package/src/components/ui/stories/sheet.stories.tsx +0 -1
  274. package/src/components/ui/stories/sidebar.stories.tsx +0 -1
  275. package/src/components/ui/stories/skeleton.stories.tsx +0 -1
  276. package/src/components/ui/stories/slider.stories.tsx +0 -1
  277. package/src/components/ui/stories/sonner.stories.tsx +0 -1
  278. package/src/components/ui/stories/spinner.stories.tsx +356 -0
  279. package/src/components/ui/stories/stack.stories.tsx +0 -1
  280. package/src/components/ui/stories/switch.stories.tsx +0 -1
  281. package/src/components/ui/stories/table.stories.tsx +0 -1
  282. package/src/components/ui/stories/tabs.stories.tsx +0 -1
  283. package/src/components/ui/stories/text-field.stories.tsx +0 -1
  284. package/src/components/ui/stories/textarea.stories.tsx +0 -1
  285. package/src/components/ui/stories/theme-toggle.stories.tsx +0 -1
  286. package/src/components/ui/stories/theme.stories.tsx +0 -1
  287. package/src/components/ui/stories/toggle-group.stories.tsx +0 -1
  288. package/src/components/ui/stories/toggle.stories.tsx +0 -1
  289. package/src/components/ui/stories/tooltip.stories.tsx +0 -1
  290. package/src/components/ui/stories/typography.stories.tsx +5 -2
  291. package/src/components/ui/stories/use-mobile.stories.tsx +0 -1
  292. package/src/components/ui/stories/use-theme.stories.tsx +0 -1
  293. package/src/components/ui/tabs.tsx +1 -1
  294. package/src/components/ui/theme-toggle.tsx +1 -3
  295. package/src/components/ui/theme.tsx +6 -1
  296. package/src/components/ui/typography.tsx +29 -129
  297. package/src/index.ts +7 -0
  298. package/src/styles/globals.css +82 -94
  299. /package/{llm-docs → .llm}/accordion-content.llm.md +0 -0
  300. /package/{llm-docs → .llm}/accordion-item.llm.md +0 -0
  301. /package/{llm-docs → .llm}/accordion-trigger.llm.md +0 -0
  302. /package/{llm-docs → .llm}/accordion.llm.md +0 -0
  303. /package/{llm-docs → .llm}/alert-description.llm.md +0 -0
  304. /package/{llm-docs → .llm}/alert-dialog-action.llm.md +0 -0
  305. /package/{llm-docs → .llm}/alert-dialog-cancel.llm.md +0 -0
  306. /package/{llm-docs → .llm}/alert-dialog-content.llm.md +0 -0
  307. /package/{llm-docs → .llm}/alert-dialog-description.llm.md +0 -0
  308. /package/{llm-docs → .llm}/alert-dialog-footer.llm.md +0 -0
  309. /package/{llm-docs → .llm}/alert-dialog-header.llm.md +0 -0
  310. /package/{llm-docs → .llm}/alert-dialog-overlay.llm.md +0 -0
  311. /package/{llm-docs → .llm}/alert-dialog-portal.llm.md +0 -0
  312. /package/{llm-docs → .llm}/alert-dialog-title.llm.md +0 -0
  313. /package/{llm-docs → .llm}/alert-dialog-trigger.llm.md +0 -0
  314. /package/{llm-docs → .llm}/alert-dialog.llm.md +0 -0
  315. /package/{llm-docs → .llm}/alert-title.llm.md +0 -0
  316. /package/{llm-docs → .llm}/alert.llm.md +0 -0
  317. /package/{llm-docs → .llm}/aspect-ratio.llm.md +0 -0
  318. /package/{llm-docs → .llm}/avatar-fallback.llm.md +0 -0
  319. /package/{llm-docs → .llm}/avatar-image.llm.md +0 -0
  320. /package/{llm-docs → .llm}/avatar.llm.md +0 -0
  321. /package/{llm-docs → .llm}/breadcrumb-ellipsis.llm.md +0 -0
  322. /package/{llm-docs → .llm}/breadcrumb-item.llm.md +0 -0
  323. /package/{llm-docs → .llm}/breadcrumb-link.llm.md +0 -0
  324. /package/{llm-docs → .llm}/breadcrumb-list.llm.md +0 -0
  325. /package/{llm-docs → .llm}/breadcrumb-page.llm.md +0 -0
  326. /package/{llm-docs → .llm}/breadcrumb-separator.llm.md +0 -0
  327. /package/{llm-docs → .llm}/breadcrumb.llm.md +0 -0
  328. /package/{llm-docs → .llm}/calendar-day-button.llm.md +0 -0
  329. /package/{llm-docs → .llm}/calendar.llm.md +0 -0
  330. /package/{llm-docs → .llm}/card-action.llm.md +0 -0
  331. /package/{llm-docs → .llm}/card-content.llm.md +0 -0
  332. /package/{llm-docs → .llm}/card-description.llm.md +0 -0
  333. /package/{llm-docs → .llm}/card-footer.llm.md +0 -0
  334. /package/{llm-docs → .llm}/card-header.llm.md +0 -0
  335. /package/{llm-docs → .llm}/card-title.llm.md +0 -0
  336. /package/{llm-docs → .llm}/card.llm.md +0 -0
  337. /package/{llm-docs → .llm}/carousel-content.llm.md +0 -0
  338. /package/{llm-docs → .llm}/carousel-item.llm.md +0 -0
  339. /package/{llm-docs → .llm}/carousel-next.llm.md +0 -0
  340. /package/{llm-docs → .llm}/carousel-previous.llm.md +0 -0
  341. /package/{llm-docs → .llm}/carousel.llm.md +0 -0
  342. /package/{llm-docs → .llm}/chart-config.llm.md +0 -0
  343. /package/{llm-docs → .llm}/chart-container.llm.md +0 -0
  344. /package/{llm-docs → .llm}/chart-legend-content.llm.md +0 -0
  345. /package/{llm-docs → .llm}/chart-legend.llm.md +0 -0
  346. /package/{llm-docs → .llm}/chart-style.llm.md +0 -0
  347. /package/{llm-docs → .llm}/chart-tooltip-content.llm.md +0 -0
  348. /package/{llm-docs → .llm}/chart-tooltip.llm.md +0 -0
  349. /package/{llm-docs → .llm}/checkbox.llm.md +0 -0
  350. /package/{llm-docs → .llm}/cn.llm.md +0 -0
  351. /package/{llm-docs → .llm}/collapsible-content.llm.md +0 -0
  352. /package/{llm-docs → .llm}/collapsible-trigger.llm.md +0 -0
  353. /package/{llm-docs → .llm}/collapsible.llm.md +0 -0
  354. /package/{llm-docs → .llm}/combobox-option.llm.md +0 -0
  355. /package/{llm-docs → .llm}/combobox.llm.md +0 -0
  356. /package/{llm-docs → .llm}/command-dialog.llm.md +0 -0
  357. /package/{llm-docs → .llm}/command-empty.llm.md +0 -0
  358. /package/{llm-docs → .llm}/command-group.llm.md +0 -0
  359. /package/{llm-docs → .llm}/command-input.llm.md +0 -0
  360. /package/{llm-docs → .llm}/command-item.llm.md +0 -0
  361. /package/{llm-docs → .llm}/command-list.llm.md +0 -0
  362. /package/{llm-docs → .llm}/command-loading.llm.md +0 -0
  363. /package/{llm-docs → .llm}/command-separator.llm.md +0 -0
  364. /package/{llm-docs → .llm}/command-shortcut.llm.md +0 -0
  365. /package/{llm-docs → .llm}/command.llm.md +0 -0
  366. /package/{llm-docs → .llm}/container.llm.md +0 -0
  367. /package/{llm-docs → .llm}/context-menu-checkbox-item.llm.md +0 -0
  368. /package/{llm-docs → .llm}/context-menu-content.llm.md +0 -0
  369. /package/{llm-docs → .llm}/context-menu-group.llm.md +0 -0
  370. /package/{llm-docs → .llm}/context-menu-item.llm.md +0 -0
  371. /package/{llm-docs → .llm}/context-menu-label.llm.md +0 -0
  372. /package/{llm-docs → .llm}/context-menu-portal.llm.md +0 -0
  373. /package/{llm-docs → .llm}/context-menu-radio-group.llm.md +0 -0
  374. /package/{llm-docs → .llm}/context-menu-radio-item.llm.md +0 -0
  375. /package/{llm-docs → .llm}/context-menu-separator.llm.md +0 -0
  376. /package/{llm-docs → .llm}/context-menu-shortcut.llm.md +0 -0
  377. /package/{llm-docs → .llm}/context-menu-sub-content.llm.md +0 -0
  378. /package/{llm-docs → .llm}/context-menu-sub-trigger.llm.md +0 -0
  379. /package/{llm-docs → .llm}/context-menu-sub.llm.md +0 -0
  380. /package/{llm-docs → .llm}/context-menu-trigger.llm.md +0 -0
  381. /package/{llm-docs → .llm}/context-menu.llm.md +0 -0
  382. /package/{llm-docs → .llm}/date-picker.llm.md +0 -0
  383. /package/{llm-docs → .llm}/dialog-close.llm.md +0 -0
  384. /package/{llm-docs → .llm}/dialog-content.llm.md +0 -0
  385. /package/{llm-docs → .llm}/dialog-description.llm.md +0 -0
  386. /package/{llm-docs → .llm}/dialog-footer.llm.md +0 -0
  387. /package/{llm-docs → .llm}/dialog-header.llm.md +0 -0
  388. /package/{llm-docs → .llm}/dialog-overlay.llm.md +0 -0
  389. /package/{llm-docs → .llm}/dialog-portal.llm.md +0 -0
  390. /package/{llm-docs → .llm}/dialog-title.llm.md +0 -0
  391. /package/{llm-docs → .llm}/dialog-trigger.llm.md +0 -0
  392. /package/{llm-docs → .llm}/dialog.llm.md +0 -0
  393. /package/{llm-docs → .llm}/drawer-close.llm.md +0 -0
  394. /package/{llm-docs → .llm}/drawer-content.llm.md +0 -0
  395. /package/{llm-docs → .llm}/drawer-description.llm.md +0 -0
  396. /package/{llm-docs → .llm}/drawer-footer.llm.md +0 -0
  397. /package/{llm-docs → .llm}/drawer-header.llm.md +0 -0
  398. /package/{llm-docs → .llm}/drawer-overlay.llm.md +0 -0
  399. /package/{llm-docs → .llm}/drawer-portal.llm.md +0 -0
  400. /package/{llm-docs → .llm}/drawer-title.llm.md +0 -0
  401. /package/{llm-docs → .llm}/drawer-trigger.llm.md +0 -0
  402. /package/{llm-docs → .llm}/drawer.llm.md +0 -0
  403. /package/{llm-docs → .llm}/dropdown-menu-checkbox-item.llm.md +0 -0
  404. /package/{llm-docs → .llm}/dropdown-menu-content.llm.md +0 -0
  405. /package/{llm-docs → .llm}/dropdown-menu-group.llm.md +0 -0
  406. /package/{llm-docs → .llm}/dropdown-menu-item.llm.md +0 -0
  407. /package/{llm-docs → .llm}/dropdown-menu-label.llm.md +0 -0
  408. /package/{llm-docs → .llm}/dropdown-menu-portal.llm.md +0 -0
  409. /package/{llm-docs → .llm}/dropdown-menu-radio-group.llm.md +0 -0
  410. /package/{llm-docs → .llm}/dropdown-menu-radio-item.llm.md +0 -0
  411. /package/{llm-docs → .llm}/dropdown-menu-separator.llm.md +0 -0
  412. /package/{llm-docs → .llm}/dropdown-menu-shortcut.llm.md +0 -0
  413. /package/{llm-docs → .llm}/dropdown-menu-sub-content.llm.md +0 -0
  414. /package/{llm-docs → .llm}/dropdown-menu-sub-trigger.llm.md +0 -0
  415. /package/{llm-docs → .llm}/dropdown-menu-sub.llm.md +0 -0
  416. /package/{llm-docs → .llm}/dropdown-menu-trigger.llm.md +0 -0
  417. /package/{llm-docs → .llm}/dropdown-menu.llm.md +0 -0
  418. /package/{llm-docs → .llm}/empty-state.llm.md +0 -0
  419. /package/{llm-docs → .llm}/hover-card-content.llm.md +0 -0
  420. /package/{llm-docs → .llm}/hover-card-trigger.llm.md +0 -0
  421. /package/{llm-docs → .llm}/hover-card.llm.md +0 -0
  422. /package/{llm-docs → .llm}/input.llm.md +0 -0
  423. /package/{llm-docs → .llm}/label.llm.md +0 -0
  424. /package/{llm-docs → .llm}/menubar-checkbox-item.llm.md +0 -0
  425. /package/{llm-docs → .llm}/menubar-content.llm.md +0 -0
  426. /package/{llm-docs → .llm}/menubar-group.llm.md +0 -0
  427. /package/{llm-docs → .llm}/menubar-item.llm.md +0 -0
  428. /package/{llm-docs → .llm}/menubar-label.llm.md +0 -0
  429. /package/{llm-docs → .llm}/menubar-menu.llm.md +0 -0
  430. /package/{llm-docs → .llm}/menubar-portal.llm.md +0 -0
  431. /package/{llm-docs → .llm}/menubar-radio-group.llm.md +0 -0
  432. /package/{llm-docs → .llm}/menubar-radio-item.llm.md +0 -0
  433. /package/{llm-docs → .llm}/menubar-separator.llm.md +0 -0
  434. /package/{llm-docs → .llm}/menubar-shortcut.llm.md +0 -0
  435. /package/{llm-docs → .llm}/menubar-sub-content.llm.md +0 -0
  436. /package/{llm-docs → .llm}/menubar-sub-trigger.llm.md +0 -0
  437. /package/{llm-docs → .llm}/menubar-sub.llm.md +0 -0
  438. /package/{llm-docs → .llm}/menubar-trigger.llm.md +0 -0
  439. /package/{llm-docs → .llm}/menubar.llm.md +0 -0
  440. /package/{llm-docs → .llm}/navigation-menu-content.llm.md +0 -0
  441. /package/{llm-docs → .llm}/navigation-menu-indicator.llm.md +0 -0
  442. /package/{llm-docs → .llm}/navigation-menu-item.llm.md +0 -0
  443. /package/{llm-docs → .llm}/navigation-menu-link.llm.md +0 -0
  444. /package/{llm-docs → .llm}/navigation-menu-list.llm.md +0 -0
  445. /package/{llm-docs → .llm}/navigation-menu-trigger-style.llm.md +0 -0
  446. /package/{llm-docs → .llm}/navigation-menu-trigger.llm.md +0 -0
  447. /package/{llm-docs → .llm}/navigation-menu-viewport.llm.md +0 -0
  448. /package/{llm-docs → .llm}/navigation-menu.llm.md +0 -0
  449. /package/{llm-docs → .llm}/pagination-content.llm.md +0 -0
  450. /package/{llm-docs → .llm}/pagination-ellipsis.llm.md +0 -0
  451. /package/{llm-docs → .llm}/pagination-item.llm.md +0 -0
  452. /package/{llm-docs → .llm}/pagination-link.llm.md +0 -0
  453. /package/{llm-docs → .llm}/pagination-next.llm.md +0 -0
  454. /package/{llm-docs → .llm}/pagination-previous.llm.md +0 -0
  455. /package/{llm-docs → .llm}/pagination.llm.md +0 -0
  456. /package/{llm-docs → .llm}/popover-anchor.llm.md +0 -0
  457. /package/{llm-docs → .llm}/popover-content.llm.md +0 -0
  458. /package/{llm-docs → .llm}/popover-trigger.llm.md +0 -0
  459. /package/{llm-docs → .llm}/popover.llm.md +0 -0
  460. /package/{llm-docs → .llm}/progress.llm.md +0 -0
  461. /package/{llm-docs → .llm}/radio-group-indicator.llm.md +0 -0
  462. /package/{llm-docs → .llm}/radio-group-item.llm.md +0 -0
  463. /package/{llm-docs → .llm}/radio-group.llm.md +0 -0
  464. /package/{llm-docs → .llm}/resizable-handle.llm.md +0 -0
  465. /package/{llm-docs → .llm}/resizable-panel-group.llm.md +0 -0
  466. /package/{llm-docs → .llm}/resizable-panel.llm.md +0 -0
  467. /package/{llm-docs → .llm}/scroll-area-corner.llm.md +0 -0
  468. /package/{llm-docs → .llm}/scroll-area-thumb.llm.md +0 -0
  469. /package/{llm-docs → .llm}/scroll-area-viewport.llm.md +0 -0
  470. /package/{llm-docs → .llm}/scroll-area.llm.md +0 -0
  471. /package/{llm-docs → .llm}/scroll-bar.llm.md +0 -0
  472. /package/{llm-docs → .llm}/select-content.llm.md +0 -0
  473. /package/{llm-docs → .llm}/select-group.llm.md +0 -0
  474. /package/{llm-docs → .llm}/select-item.llm.md +0 -0
  475. /package/{llm-docs → .llm}/select-label.llm.md +0 -0
  476. /package/{llm-docs → .llm}/select-scroll-down-button.llm.md +0 -0
  477. /package/{llm-docs → .llm}/select-scroll-up-button.llm.md +0 -0
  478. /package/{llm-docs → .llm}/select-separator.llm.md +0 -0
  479. /package/{llm-docs → .llm}/select-trigger.llm.md +0 -0
  480. /package/{llm-docs → .llm}/select-value.llm.md +0 -0
  481. /package/{llm-docs → .llm}/select.llm.md +0 -0
  482. /package/{llm-docs → .llm}/separator.llm.md +0 -0
  483. /package/{llm-docs → .llm}/sheet-close.llm.md +0 -0
  484. /package/{llm-docs → .llm}/sheet-content.llm.md +0 -0
  485. /package/{llm-docs → .llm}/sheet-description.llm.md +0 -0
  486. /package/{llm-docs → .llm}/sheet-footer.llm.md +0 -0
  487. /package/{llm-docs → .llm}/sheet-header.llm.md +0 -0
  488. /package/{llm-docs → .llm}/sheet-title.llm.md +0 -0
  489. /package/{llm-docs → .llm}/sheet-trigger.llm.md +0 -0
  490. /package/{llm-docs → .llm}/sheet.llm.md +0 -0
  491. /package/{llm-docs → .llm}/sidebar-content.llm.md +0 -0
  492. /package/{llm-docs → .llm}/sidebar-footer.llm.md +0 -0
  493. /package/{llm-docs → .llm}/sidebar-group-action.llm.md +0 -0
  494. /package/{llm-docs → .llm}/sidebar-group-content.llm.md +0 -0
  495. /package/{llm-docs → .llm}/sidebar-group-label.llm.md +0 -0
  496. /package/{llm-docs → .llm}/sidebar-group.llm.md +0 -0
  497. /package/{llm-docs → .llm}/sidebar-header.llm.md +0 -0
  498. /package/{llm-docs → .llm}/sidebar-input.llm.md +0 -0
  499. /package/{llm-docs → .llm}/sidebar-inset.llm.md +0 -0
  500. /package/{llm-docs → .llm}/sidebar-menu-action.llm.md +0 -0
  501. /package/{llm-docs → .llm}/sidebar-menu-badge.llm.md +0 -0
  502. /package/{llm-docs → .llm}/sidebar-menu-button.llm.md +0 -0
  503. /package/{llm-docs → .llm}/sidebar-menu-item.llm.md +0 -0
  504. /package/{llm-docs → .llm}/sidebar-menu-skeleton.llm.md +0 -0
  505. /package/{llm-docs → .llm}/sidebar-menu-sub-button.llm.md +0 -0
  506. /package/{llm-docs → .llm}/sidebar-menu-sub-item.llm.md +0 -0
  507. /package/{llm-docs → .llm}/sidebar-menu-sub.llm.md +0 -0
  508. /package/{llm-docs → .llm}/sidebar-menu.llm.md +0 -0
  509. /package/{llm-docs → .llm}/sidebar-provider.llm.md +0 -0
  510. /package/{llm-docs → .llm}/sidebar-rail.llm.md +0 -0
  511. /package/{llm-docs → .llm}/sidebar-separator.llm.md +0 -0
  512. /package/{llm-docs → .llm}/sidebar-trigger.llm.md +0 -0
  513. /package/{llm-docs → .llm}/sidebar.llm.md +0 -0
  514. /package/{llm-docs → .llm}/skeleton.llm.md +0 -0
  515. /package/{llm-docs → .llm}/slider.llm.md +0 -0
  516. /package/{llm-docs → .llm}/stack.llm.md +0 -0
  517. /package/{llm-docs → .llm}/switch.llm.md +0 -0
  518. /package/{llm-docs → .llm}/table-body.llm.md +0 -0
  519. /package/{llm-docs → .llm}/table-caption.llm.md +0 -0
  520. /package/{llm-docs → .llm}/table-cell.llm.md +0 -0
  521. /package/{llm-docs → .llm}/table-footer.llm.md +0 -0
  522. /package/{llm-docs → .llm}/table-head.llm.md +0 -0
  523. /package/{llm-docs → .llm}/table-header.llm.md +0 -0
  524. /package/{llm-docs → .llm}/table-row.llm.md +0 -0
  525. /package/{llm-docs → .llm}/table.llm.md +0 -0
  526. /package/{llm-docs → .llm}/tabs-content.llm.md +0 -0
  527. /package/{llm-docs → .llm}/tabs-list.llm.md +0 -0
  528. /package/{llm-docs → .llm}/tabs-trigger.llm.md +0 -0
  529. /package/{llm-docs → .llm}/tabs.llm.md +0 -0
  530. /package/{llm-docs → .llm}/text-field.llm.md +0 -0
  531. /package/{llm-docs → .llm}/textarea.llm.md +0 -0
  532. /package/{llm-docs → .llm}/theme-preference.llm.md +0 -0
  533. /package/{llm-docs → .llm}/theme-toggle.llm.md +0 -0
  534. /package/{llm-docs → .llm}/theme.llm.md +0 -0
  535. /package/{llm-docs → .llm}/toast.llm.md +0 -0
  536. /package/{llm-docs → .llm}/toaster.llm.md +0 -0
  537. /package/{llm-docs → .llm}/toggle-group-item.llm.md +0 -0
  538. /package/{llm-docs → .llm}/toggle-group.llm.md +0 -0
  539. /package/{llm-docs → .llm}/toggle.llm.md +0 -0
  540. /package/{llm-docs → .llm}/tooltip-content.llm.md +0 -0
  541. /package/{llm-docs → .llm}/tooltip-provider.llm.md +0 -0
  542. /package/{llm-docs → .llm}/tooltip-trigger.llm.md +0 -0
  543. /package/{llm-docs → .llm}/tooltip.llm.md +0 -0
  544. /package/{llm-docs → .llm}/use-carousel.llm.md +0 -0
  545. /package/{llm-docs → .llm}/use-command-state.llm.md +0 -0
  546. /package/{llm-docs → .llm}/use-is-mobile.llm.md +0 -0
  547. /package/{llm-docs → .llm}/use-sidebar.llm.md +0 -0
@@ -0,0 +1,601 @@
1
+ import type { Meta, StoryObj } from "@storybook/react-vite";
2
+ import {
3
+ CheckCircle2,
4
+ ChevronRight,
5
+ Clock,
6
+ FileText,
7
+ Image as ImageIcon,
8
+ MoreVertical,
9
+ Star,
10
+ User,
11
+ } from "lucide-react";
12
+ import { Badge } from "../badge";
13
+ import { Button } from "../button";
14
+ import {
15
+ Item,
16
+ ItemActions,
17
+ ItemContent,
18
+ ItemDescription,
19
+ ItemFooter,
20
+ ItemGroup,
21
+ ItemHeader,
22
+ ItemMedia,
23
+ ItemSeparator,
24
+ ItemTitle,
25
+ } from "../item";
26
+
27
+ const meta = {
28
+ title: "Layout and Structure/Item",
29
+ component: Item,
30
+ parameters: {
31
+ layout: "centered",
32
+ docs: {
33
+ description: {
34
+ component:
35
+ "A flexible item component for displaying content with media, titles, descriptions, and actions. Perfect for lists, cards, and data displays.",
36
+ },
37
+ },
38
+ },
39
+ argTypes: {
40
+ variant: {
41
+ control: { type: "select" },
42
+ options: ["default", "outline", "muted"],
43
+ description: "The visual variant of the item",
44
+ },
45
+ size: {
46
+ control: { type: "select" },
47
+ options: ["default", "sm"],
48
+ description: "The size of the item",
49
+ },
50
+ asChild: {
51
+ control: { type: "boolean" },
52
+ description: "Render as a child component (e.g., for links)",
53
+ },
54
+ className: {
55
+ control: { type: "text" },
56
+ description: "Additional CSS classes to apply",
57
+ },
58
+ },
59
+ args: {
60
+ variant: "default",
61
+ size: "default",
62
+ },
63
+ } satisfies Meta<typeof Item>;
64
+
65
+ export default meta;
66
+ type Story = StoryObj<typeof meta>;
67
+
68
+ /**
69
+ * Interactive playground with all item properties.
70
+ */
71
+ export const Interactive: Story = {
72
+ render: (args) => (
73
+ <div className="w-96">
74
+ <Item {...args}>
75
+ <ItemMedia variant="icon">
76
+ <FileText className="size-4" />
77
+ </ItemMedia>
78
+ <ItemContent>
79
+ <ItemTitle>Document Title</ItemTitle>
80
+ <ItemDescription>
81
+ A brief description of the document content.
82
+ </ItemDescription>
83
+ </ItemContent>
84
+ <ItemActions>
85
+ <Button variant="ghost" size="icon">
86
+ <MoreVertical className="size-4" />
87
+ </Button>
88
+ </ItemActions>
89
+ </Item>
90
+ </div>
91
+ ),
92
+ };
93
+
94
+ /**
95
+ * Showcase of all available item variants and compositions.
96
+ */
97
+ export const Variants: Story = {
98
+ render: () => (
99
+ <div className="space-y-12 w-full max-w-2xl">
100
+ {/* Basic Items */}
101
+ <div className="space-y-4">
102
+ <h3 className="text-sm font-medium text-muted-foreground">
103
+ Basic Items
104
+ </h3>
105
+ <div className="space-y-2">
106
+ <Item>
107
+ <ItemContent>
108
+ <ItemTitle>Simple Item</ItemTitle>
109
+ <ItemDescription>Just title and description</ItemDescription>
110
+ </ItemContent>
111
+ </Item>
112
+
113
+ <Item variant="outline">
114
+ <ItemContent>
115
+ <ItemTitle>Outlined Item</ItemTitle>
116
+ <ItemDescription>With border styling</ItemDescription>
117
+ </ItemContent>
118
+ </Item>
119
+
120
+ <Item variant="muted">
121
+ <ItemContent>
122
+ <ItemTitle>Muted Item</ItemTitle>
123
+ <ItemDescription>With muted background</ItemDescription>
124
+ </ItemContent>
125
+ </Item>
126
+ </div>
127
+ </div>
128
+
129
+ {/* With Icon Media */}
130
+ <div className="space-y-4">
131
+ <h3 className="text-sm font-medium text-muted-foreground">
132
+ With Icon Media
133
+ </h3>
134
+ <div className="space-y-2">
135
+ <Item>
136
+ <ItemMedia variant="icon">
137
+ <FileText className="size-4" />
138
+ </ItemMedia>
139
+ <ItemContent>
140
+ <ItemTitle>Project Documentation</ItemTitle>
141
+ <ItemDescription>Last updated 2 hours ago</ItemDescription>
142
+ </ItemContent>
143
+ </Item>
144
+
145
+ <Item>
146
+ <ItemMedia variant="icon">
147
+ <User className="size-4" />
148
+ </ItemMedia>
149
+ <ItemContent>
150
+ <ItemTitle>User Profile</ItemTitle>
151
+ <ItemDescription>View and edit profile information</ItemDescription>
152
+ </ItemContent>
153
+ </Item>
154
+ </div>
155
+ </div>
156
+
157
+ {/* With Image Media */}
158
+ <div className="space-y-4">
159
+ <h3 className="text-sm font-medium text-muted-foreground">
160
+ With Image Media
161
+ </h3>
162
+ <div className="space-y-2">
163
+ <Item>
164
+ <ItemMedia variant="image">
165
+ <div className="size-10 bg-gradient-to-br from-purple-400 to-pink-400 rounded-sm" />
166
+ </ItemMedia>
167
+ <ItemContent>
168
+ <ItemTitle>Abstract Artwork</ItemTitle>
169
+ <ItemDescription>Digital illustration by Artist Name</ItemDescription>
170
+ </ItemContent>
171
+ </Item>
172
+
173
+ <Item>
174
+ <ItemMedia variant="image">
175
+ <div className="size-10 bg-gradient-to-br from-blue-400 to-cyan-400 rounded-sm" />
176
+ </ItemMedia>
177
+ <ItemContent>
178
+ <ItemTitle>Ocean Waves</ItemTitle>
179
+ <ItemDescription>Photography collection</ItemDescription>
180
+ </ItemContent>
181
+ </Item>
182
+ </div>
183
+ </div>
184
+
185
+ {/* With Actions */}
186
+ <div className="space-y-4">
187
+ <h3 className="text-sm font-medium text-muted-foreground">
188
+ With Actions
189
+ </h3>
190
+ <div className="space-y-2">
191
+ <Item>
192
+ <ItemMedia variant="icon">
193
+ <FileText className="size-4" />
194
+ </ItemMedia>
195
+ <ItemContent>
196
+ <ItemTitle>Important Document</ItemTitle>
197
+ <ItemDescription>Review required by tomorrow</ItemDescription>
198
+ </ItemContent>
199
+ <ItemActions>
200
+ <Button variant="ghost" size="sm">
201
+ View
202
+ </Button>
203
+ <Button variant="ghost" size="icon">
204
+ <MoreVertical className="size-4" />
205
+ </Button>
206
+ </ItemActions>
207
+ </Item>
208
+
209
+ <Item>
210
+ <ItemContent>
211
+ <ItemTitle>Task Item</ItemTitle>
212
+ <ItemDescription>Complete this task</ItemDescription>
213
+ </ItemContent>
214
+ <ItemActions>
215
+ <Button variant="ghost" size="icon">
216
+ <Star className="size-4" />
217
+ </Button>
218
+ <Button variant="ghost" size="icon">
219
+ <CheckCircle2 className="size-4" />
220
+ </Button>
221
+ </ItemActions>
222
+ </Item>
223
+ </div>
224
+ </div>
225
+
226
+ {/* With Header and Footer */}
227
+ <div className="space-y-4">
228
+ <h3 className="text-sm font-medium text-muted-foreground">
229
+ With Header and Footer
230
+ </h3>
231
+ <div className="space-y-2">
232
+ <Item>
233
+ <ItemMedia variant="icon">
234
+ <Clock className="size-4" />
235
+ </ItemMedia>
236
+ <ItemContent>
237
+ <ItemHeader>
238
+ <ItemTitle>Meeting Notes</ItemTitle>
239
+ <Badge variant="secondary">New</Badge>
240
+ </ItemHeader>
241
+ <ItemDescription>
242
+ Notes from the team sync meeting
243
+ </ItemDescription>
244
+ <ItemFooter>
245
+ <span className="text-xs text-muted-foreground">
246
+ Updated 5 min ago
247
+ </span>
248
+ <span className="text-xs text-muted-foreground">3 comments</span>
249
+ </ItemFooter>
250
+ </ItemContent>
251
+ </Item>
252
+ </div>
253
+ </div>
254
+
255
+ {/* Small Size */}
256
+ <div className="space-y-4">
257
+ <h3 className="text-sm font-medium text-muted-foreground">
258
+ Small Size
259
+ </h3>
260
+ <div className="space-y-2">
261
+ <Item size="sm">
262
+ <ItemMedia variant="icon">
263
+ <FileText className="size-4" />
264
+ </ItemMedia>
265
+ <ItemContent>
266
+ <ItemTitle>Small Item</ItemTitle>
267
+ <ItemDescription>Compact layout</ItemDescription>
268
+ </ItemContent>
269
+ </Item>
270
+
271
+ <Item size="sm">
272
+ <ItemMedia variant="icon">
273
+ <User className="size-4" />
274
+ </ItemMedia>
275
+ <ItemContent>
276
+ <ItemTitle>Another Small Item</ItemTitle>
277
+ </ItemContent>
278
+ <ItemActions>
279
+ <Button variant="ghost" size="icon">
280
+ <ChevronRight className="size-4" />
281
+ </Button>
282
+ </ItemActions>
283
+ </Item>
284
+ </div>
285
+ </div>
286
+
287
+ {/* Item Group */}
288
+ <div className="space-y-4">
289
+ <h3 className="text-sm font-medium text-muted-foreground">
290
+ Item Group with Separators
291
+ </h3>
292
+ <ItemGroup>
293
+ <Item>
294
+ <ItemMedia variant="icon">
295
+ <FileText className="size-4" />
296
+ </ItemMedia>
297
+ <ItemContent>
298
+ <ItemTitle>First Item</ItemTitle>
299
+ <ItemDescription>First item in the group</ItemDescription>
300
+ </ItemContent>
301
+ </Item>
302
+
303
+ <ItemSeparator />
304
+
305
+ <Item>
306
+ <ItemMedia variant="icon">
307
+ <ImageIcon className="size-4" />
308
+ </ItemMedia>
309
+ <ItemContent>
310
+ <ItemTitle>Second Item</ItemTitle>
311
+ <ItemDescription>Second item in the group</ItemDescription>
312
+ </ItemContent>
313
+ </Item>
314
+
315
+ <ItemSeparator />
316
+
317
+ <Item>
318
+ <ItemMedia variant="icon">
319
+ <User className="size-4" />
320
+ </ItemMedia>
321
+ <ItemContent>
322
+ <ItemTitle>Third Item</ItemTitle>
323
+ <ItemDescription>Third item in the group</ItemDescription>
324
+ </ItemContent>
325
+ </Item>
326
+ </ItemGroup>
327
+ </div>
328
+ </div>
329
+ ),
330
+ parameters: {
331
+ layout: "padded",
332
+ docs: {
333
+ description: {
334
+ story:
335
+ "Complete showcase of item variants, sizes, media types, and compositions.",
336
+ },
337
+ },
338
+ },
339
+ };
340
+
341
+ /**
342
+ * Real-world usage examples showing items in practical scenarios.
343
+ */
344
+ export const InContext: Story = {
345
+ render: () => (
346
+ <div className="space-y-8 w-full max-w-2xl">
347
+ {/* File List */}
348
+ <div className="space-y-4 p-6 border rounded-lg">
349
+ <h3 className="text-lg font-semibold">Recent Files</h3>
350
+ <ItemGroup>
351
+ <Item asChild>
352
+ <a href="#">
353
+ <ItemMedia variant="icon">
354
+ <FileText className="size-4" />
355
+ </ItemMedia>
356
+ <ItemContent>
357
+ <ItemHeader>
358
+ <ItemTitle>Q4 Financial Report.pdf</ItemTitle>
359
+ <Badge variant="secondary">PDF</Badge>
360
+ </ItemHeader>
361
+ <ItemDescription>Last modified today at 2:45 PM</ItemDescription>
362
+ <ItemFooter>
363
+ <span className="text-xs text-muted-foreground">2.4 MB</span>
364
+ <span className="text-xs text-muted-foreground">
365
+ Shared with 5 people
366
+ </span>
367
+ </ItemFooter>
368
+ </ItemContent>
369
+ <ItemActions>
370
+ <Button variant="ghost" size="icon">
371
+ <MoreVertical className="size-4" />
372
+ </Button>
373
+ </ItemActions>
374
+ </a>
375
+ </Item>
376
+
377
+ <ItemSeparator />
378
+
379
+ <Item asChild>
380
+ <a href="#">
381
+ <ItemMedia variant="icon">
382
+ <FileText className="size-4" />
383
+ </ItemMedia>
384
+ <ItemContent>
385
+ <ItemTitle>Team Meeting Notes.docx</ItemTitle>
386
+ <ItemDescription>Last modified yesterday</ItemDescription>
387
+ </ItemContent>
388
+ <ItemActions>
389
+ <Button variant="ghost" size="icon">
390
+ <Star className="size-4" />
391
+ </Button>
392
+ <Button variant="ghost" size="icon">
393
+ <MoreVertical className="size-4" />
394
+ </Button>
395
+ </ItemActions>
396
+ </a>
397
+ </Item>
398
+
399
+ <ItemSeparator />
400
+
401
+ <Item asChild>
402
+ <a href="#">
403
+ <ItemMedia variant="icon">
404
+ <ImageIcon className="size-4" />
405
+ </ItemMedia>
406
+ <ItemContent>
407
+ <ItemTitle>Product Mockup.fig</ItemTitle>
408
+ <ItemDescription>Last modified 3 days ago</ItemDescription>
409
+ </ItemContent>
410
+ <ItemActions>
411
+ <Button variant="ghost" size="icon">
412
+ <MoreVertical className="size-4" />
413
+ </Button>
414
+ </ItemActions>
415
+ </a>
416
+ </Item>
417
+ </ItemGroup>
418
+ </div>
419
+
420
+ {/* Notification List */}
421
+ <div className="space-y-4 p-6 border rounded-lg">
422
+ <h3 className="text-lg font-semibold">Notifications</h3>
423
+ <ItemGroup>
424
+ <Item variant="muted">
425
+ <ItemMedia variant="icon">
426
+ <User className="size-4" />
427
+ </ItemMedia>
428
+ <ItemContent>
429
+ <ItemHeader>
430
+ <ItemTitle>New follower</ItemTitle>
431
+ <Badge>New</Badge>
432
+ </ItemHeader>
433
+ <ItemDescription>
434
+ John Doe started following you
435
+ </ItemDescription>
436
+ <ItemFooter>
437
+ <span className="text-xs text-muted-foreground">5 min ago</span>
438
+ </ItemFooter>
439
+ </ItemContent>
440
+ </Item>
441
+
442
+ <ItemSeparator />
443
+
444
+ <Item>
445
+ <ItemMedia variant="icon">
446
+ <CheckCircle2 className="size-4" />
447
+ </ItemMedia>
448
+ <ItemContent>
449
+ <ItemTitle>Task completed</ItemTitle>
450
+ <ItemDescription>
451
+ "Update documentation" was marked as complete
452
+ </ItemDescription>
453
+ <ItemFooter>
454
+ <span className="text-xs text-muted-foreground">2 hours ago</span>
455
+ </ItemFooter>
456
+ </ItemContent>
457
+ </Item>
458
+
459
+ <ItemSeparator />
460
+
461
+ <Item>
462
+ <ItemMedia variant="icon">
463
+ <Clock className="size-4" />
464
+ </ItemMedia>
465
+ <ItemContent>
466
+ <ItemTitle>Meeting reminder</ItemTitle>
467
+ <ItemDescription>
468
+ Team sync meeting in 30 minutes
469
+ </ItemDescription>
470
+ <ItemFooter>
471
+ <span className="text-xs text-muted-foreground">
472
+ Today at 3:30 PM
473
+ </span>
474
+ </ItemFooter>
475
+ </ItemContent>
476
+ </Item>
477
+ </ItemGroup>
478
+ </div>
479
+
480
+ {/* User List */}
481
+ <div className="space-y-4 p-6 border rounded-lg">
482
+ <h3 className="text-lg font-semibold">Team Members</h3>
483
+ <ItemGroup>
484
+ <Item>
485
+ <ItemMedia variant="image">
486
+ <div className="size-10 bg-gradient-to-br from-purple-400 to-pink-400 rounded-full" />
487
+ </ItemMedia>
488
+ <ItemContent>
489
+ <ItemTitle>Alice Johnson</ItemTitle>
490
+ <ItemDescription>Product Manager</ItemDescription>
491
+ </ItemContent>
492
+ <ItemActions>
493
+ <Button variant="outline" size="sm">
494
+ Message
495
+ </Button>
496
+ </ItemActions>
497
+ </Item>
498
+
499
+ <ItemSeparator />
500
+
501
+ <Item>
502
+ <ItemMedia variant="image">
503
+ <div className="size-10 bg-gradient-to-br from-blue-400 to-cyan-400 rounded-full" />
504
+ </ItemMedia>
505
+ <ItemContent>
506
+ <ItemTitle>Bob Smith</ItemTitle>
507
+ <ItemDescription>Lead Developer</ItemDescription>
508
+ </ItemContent>
509
+ <ItemActions>
510
+ <Button variant="outline" size="sm">
511
+ Message
512
+ </Button>
513
+ </ItemActions>
514
+ </Item>
515
+
516
+ <ItemSeparator />
517
+
518
+ <Item>
519
+ <ItemMedia variant="image">
520
+ <div className="size-10 bg-gradient-to-br from-green-400 to-emerald-400 rounded-full" />
521
+ </ItemMedia>
522
+ <ItemContent>
523
+ <ItemTitle>Carol White</ItemTitle>
524
+ <ItemDescription>UX Designer</ItemDescription>
525
+ </ItemContent>
526
+ <ItemActions>
527
+ <Button variant="outline" size="sm">
528
+ Message
529
+ </Button>
530
+ </ItemActions>
531
+ </Item>
532
+ </ItemGroup>
533
+ </div>
534
+
535
+ {/* Settings Menu */}
536
+ <div className="space-y-4 p-6 border rounded-lg">
537
+ <h3 className="text-lg font-semibold">Settings</h3>
538
+ <ItemGroup>
539
+ <Item asChild size="sm">
540
+ <a href="#">
541
+ <ItemContent>
542
+ <ItemTitle>Profile</ItemTitle>
543
+ </ItemContent>
544
+ <ItemActions>
545
+ <ChevronRight className="size-4 text-muted-foreground" />
546
+ </ItemActions>
547
+ </a>
548
+ </Item>
549
+
550
+ <ItemSeparator />
551
+
552
+ <Item asChild size="sm">
553
+ <a href="#">
554
+ <ItemContent>
555
+ <ItemTitle>Notifications</ItemTitle>
556
+ </ItemContent>
557
+ <ItemActions>
558
+ <ChevronRight className="size-4 text-muted-foreground" />
559
+ </ItemActions>
560
+ </a>
561
+ </Item>
562
+
563
+ <ItemSeparator />
564
+
565
+ <Item asChild size="sm">
566
+ <a href="#">
567
+ <ItemContent>
568
+ <ItemTitle>Privacy & Security</ItemTitle>
569
+ </ItemContent>
570
+ <ItemActions>
571
+ <ChevronRight className="size-4 text-muted-foreground" />
572
+ </ItemActions>
573
+ </a>
574
+ </Item>
575
+
576
+ <ItemSeparator />
577
+
578
+ <Item asChild size="sm">
579
+ <a href="#">
580
+ <ItemContent>
581
+ <ItemTitle>Billing</ItemTitle>
582
+ </ItemContent>
583
+ <ItemActions>
584
+ <ChevronRight className="size-4 text-muted-foreground" />
585
+ </ItemActions>
586
+ </a>
587
+ </Item>
588
+ </ItemGroup>
589
+ </div>
590
+ </div>
591
+ ),
592
+ parameters: {
593
+ layout: "padded",
594
+ docs: {
595
+ description: {
596
+ story:
597
+ "Real-world examples showing items in file lists, notifications, user lists, and settings menus.",
598
+ },
599
+ },
600
+ },
601
+ };