@bl33dz/fa814698dcde12f86a37ac31dd3aedf9 1.0.0

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 (387) hide show
  1. package/dist/perisai-ui.es.js +6402 -0
  2. package/dist/perisai-ui.umd.js +1 -0
  3. package/dist/ui.css +1 -0
  4. package/fix_imports.sh +38 -0
  5. package/generate_index.cjs +52 -0
  6. package/package.json +46 -0
  7. package/package.json.bak +42 -0
  8. package/src/index.css +7704 -0
  9. package/src/index.ts +179 -0
  10. package/src/lib/utils.ts +6 -0
  11. package/src/shadcn/accordion/Accordion.vue +19 -0
  12. package/src/shadcn/accordion/AccordionContent.vue +23 -0
  13. package/src/shadcn/accordion/AccordionItem.vue +23 -0
  14. package/src/shadcn/accordion/AccordionTrigger.vue +38 -0
  15. package/src/shadcn/accordion/index.ts +4 -0
  16. package/src/shadcn/avatar/Avatar.vue +18 -0
  17. package/src/shadcn/avatar/AvatarFallback.vue +21 -0
  18. package/src/shadcn/avatar/AvatarImage.vue +16 -0
  19. package/src/shadcn/avatar/index.ts +3 -0
  20. package/src/shadcn/breadcrumb/Breadcrumb.vue +8 -0
  21. package/src/shadcn/breadcrumb/BreadcrumbEllipsis.vue +9 -0
  22. package/src/shadcn/breadcrumb/BreadcrumbItem.vue +8 -0
  23. package/src/shadcn/breadcrumb/BreadcrumbLink.vue +8 -0
  24. package/src/shadcn/breadcrumb/BreadcrumbList.vue +8 -0
  25. package/src/shadcn/breadcrumb/BreadcrumbPage.vue +8 -0
  26. package/src/shadcn/breadcrumb/BreadcrumbSeparator.vue +8 -0
  27. package/src/shadcn/breadcrumb/index.ts +7 -0
  28. package/src/shadcn/button/Button.vue +29 -0
  29. package/src/shadcn/button/index.ts +38 -0
  30. package/src/shadcn/calendar/Calendar.vue +64 -0
  31. package/src/shadcn/calendar/CalendarCell.vue +23 -0
  32. package/src/shadcn/calendar/CalendarCellTrigger.vue +39 -0
  33. package/src/shadcn/calendar/CalendarGrid.vue +23 -0
  34. package/src/shadcn/calendar/CalendarGridBody.vue +15 -0
  35. package/src/shadcn/calendar/CalendarGridHead.vue +16 -0
  36. package/src/shadcn/calendar/CalendarGridRow.vue +22 -0
  37. package/src/shadcn/calendar/CalendarHeadCell.vue +23 -0
  38. package/src/shadcn/calendar/CalendarHeader.vue +23 -0
  39. package/src/shadcn/calendar/CalendarHeading.vue +30 -0
  40. package/src/shadcn/calendar/CalendarNextButton.vue +32 -0
  41. package/src/shadcn/calendar/CalendarPrevButton.vue +32 -0
  42. package/src/shadcn/calendar/index.ts +12 -0
  43. package/src/shadcn/card/Card.vue +8 -0
  44. package/src/shadcn/card/CardContent.vue +8 -0
  45. package/src/shadcn/card/CardDescription.vue +8 -0
  46. package/src/shadcn/card/CardHeader.vue +8 -0
  47. package/src/shadcn/card/CardTitle.vue +8 -0
  48. package/src/shadcn/card/index.ts +5 -0
  49. package/src/shadcn/checkbox/Checkbox.vue +38 -0
  50. package/src/shadcn/checkbox/index.ts +1 -0
  51. package/src/shadcn/command/Command.vue +87 -0
  52. package/src/shadcn/command/CommandDialog.vue +31 -0
  53. package/src/shadcn/command/CommandEmpty.vue +27 -0
  54. package/src/shadcn/command/CommandGroup.vue +45 -0
  55. package/src/shadcn/command/CommandInput.vue +39 -0
  56. package/src/shadcn/command/CommandItem.vue +76 -0
  57. package/src/shadcn/command/CommandList.vue +25 -0
  58. package/src/shadcn/command/CommandSeparator.vue +21 -0
  59. package/src/shadcn/command/CommandShortcut.vue +17 -0
  60. package/src/shadcn/command/index.ts +25 -0
  61. package/src/shadcn/context-menu/ContextMenu.vue +18 -0
  62. package/src/shadcn/context-menu/ContextMenuCheckboxItem.vue +38 -0
  63. package/src/shadcn/context-menu/ContextMenuContent.vue +34 -0
  64. package/src/shadcn/context-menu/ContextMenuGroup.vue +15 -0
  65. package/src/shadcn/context-menu/ContextMenuItem.vue +39 -0
  66. package/src/shadcn/context-menu/ContextMenuLabel.vue +22 -0
  67. package/src/shadcn/context-menu/ContextMenuPortal.vue +15 -0
  68. package/src/shadcn/context-menu/ContextMenuRadioGroup.vue +22 -0
  69. package/src/shadcn/context-menu/ContextMenuRadioItem.vue +38 -0
  70. package/src/shadcn/context-menu/ContextMenuSeparator.vue +22 -0
  71. package/src/shadcn/context-menu/ContextMenuShortcut.vue +17 -0
  72. package/src/shadcn/context-menu/ContextMenuSub.vue +22 -0
  73. package/src/shadcn/context-menu/ContextMenuSubContent.vue +33 -0
  74. package/src/shadcn/context-menu/ContextMenuSubTrigger.vue +33 -0
  75. package/src/shadcn/context-menu/ContextMenuTrigger.vue +17 -0
  76. package/src/shadcn/context-menu/index.ts +15 -0
  77. package/src/shadcn/dialog/Dialog.vue +18 -0
  78. package/src/shadcn/dialog/DialogClose.vue +15 -0
  79. package/src/shadcn/dialog/DialogContent.vue +46 -0
  80. package/src/shadcn/dialog/DialogDescription.vue +23 -0
  81. package/src/shadcn/dialog/DialogFooter.vue +15 -0
  82. package/src/shadcn/dialog/DialogHeader.vue +17 -0
  83. package/src/shadcn/dialog/DialogOverlay.vue +21 -0
  84. package/src/shadcn/dialog/DialogScrollContent.vue +56 -0
  85. package/src/shadcn/dialog/DialogTitle.vue +23 -0
  86. package/src/shadcn/dialog/DialogTrigger.vue +15 -0
  87. package/src/shadcn/dialog/index.ts +10 -0
  88. package/src/shadcn/dropdown-menu/DropdownMenu.vue +18 -0
  89. package/src/shadcn/dropdown-menu/DropdownMenuCheckboxItem.vue +38 -0
  90. package/src/shadcn/dropdown-menu/DropdownMenuContent.vue +36 -0
  91. package/src/shadcn/dropdown-menu/DropdownMenuGroup.vue +15 -0
  92. package/src/shadcn/dropdown-menu/DropdownMenuItem.vue +31 -0
  93. package/src/shadcn/dropdown-menu/DropdownMenuLabel.vue +23 -0
  94. package/src/shadcn/dropdown-menu/DropdownMenuRadioGroup.vue +22 -0
  95. package/src/shadcn/dropdown-menu/DropdownMenuRadioItem.vue +39 -0
  96. package/src/shadcn/dropdown-menu/DropdownMenuSeparator.vue +24 -0
  97. package/src/shadcn/dropdown-menu/DropdownMenuShortcut.vue +17 -0
  98. package/src/shadcn/dropdown-menu/DropdownMenuSub.vue +19 -0
  99. package/src/shadcn/dropdown-menu/DropdownMenuSubContent.vue +28 -0
  100. package/src/shadcn/dropdown-menu/DropdownMenuSubTrigger.vue +31 -0
  101. package/src/shadcn/dropdown-menu/DropdownMenuTrigger.vue +17 -0
  102. package/src/shadcn/dropdown-menu/index.ts +16 -0
  103. package/src/shadcn/menubar/Menubar.vue +33 -0
  104. package/src/shadcn/menubar/MenubarCheckboxItem.vue +38 -0
  105. package/src/shadcn/menubar/MenubarContent.vue +42 -0
  106. package/src/shadcn/menubar/MenubarGroup.vue +15 -0
  107. package/src/shadcn/menubar/MenubarItem.vue +37 -0
  108. package/src/shadcn/menubar/MenubarLabel.vue +20 -0
  109. package/src/shadcn/menubar/MenubarMenu.vue +15 -0
  110. package/src/shadcn/menubar/MenubarPortal.vue +5 -0
  111. package/src/shadcn/menubar/MenubarRadioGroup.vue +22 -0
  112. package/src/shadcn/menubar/MenubarRadioItem.vue +38 -0
  113. package/src/shadcn/menubar/MenubarSeparator.vue +21 -0
  114. package/src/shadcn/menubar/MenubarShortcut.vue +17 -0
  115. package/src/shadcn/menubar/MenubarSub.vue +23 -0
  116. package/src/shadcn/menubar/MenubarSubContent.vue +36 -0
  117. package/src/shadcn/menubar/MenubarSubTrigger.vue +28 -0
  118. package/src/shadcn/menubar/MenubarTrigger.vue +28 -0
  119. package/src/shadcn/menubar/index.ts +15 -0
  120. package/src/shadcn/navigation-menu/NavigationMenu.vue +35 -0
  121. package/src/shadcn/navigation-menu/NavigationMenuContent.vue +31 -0
  122. package/src/shadcn/navigation-menu/NavigationMenuIndicator.vue +23 -0
  123. package/src/shadcn/navigation-menu/NavigationMenuItem.vue +21 -0
  124. package/src/shadcn/navigation-menu/NavigationMenuLink.vue +26 -0
  125. package/src/shadcn/navigation-menu/NavigationMenuList.vue +28 -0
  126. package/src/shadcn/navigation-menu/NavigationMenuTrigger.vue +24 -0
  127. package/src/shadcn/navigation-menu/NavigationMenuViewport.vue +31 -0
  128. package/src/shadcn/navigation-menu/index.ts +14 -0
  129. package/src/shadcn/pagination/Pagination.vue +151 -0
  130. package/src/shadcn/pagination/PaginationContent.vue +22 -0
  131. package/src/shadcn/pagination/PaginationEllipsis.vue +25 -0
  132. package/src/shadcn/pagination/PaginationFirst.vue +33 -0
  133. package/src/shadcn/pagination/PaginationItem.vue +31 -0
  134. package/src/shadcn/pagination/PaginationLast.vue +33 -0
  135. package/src/shadcn/pagination/PaginationLink.vue +13 -0
  136. package/src/shadcn/pagination/PaginationNext.vue +22 -0
  137. package/src/shadcn/pagination/PaginationPrevious.vue +33 -0
  138. package/src/shadcn/pagination/index.ts +9 -0
  139. package/src/shadcn/popover/Popover.vue +18 -0
  140. package/src/shadcn/popover/PopoverAnchor.vue +15 -0
  141. package/src/shadcn/popover/PopoverContent.vue +46 -0
  142. package/src/shadcn/popover/PopoverTrigger.vue +15 -0
  143. package/src/shadcn/popover/index.ts +4 -0
  144. package/src/shadcn/radio-group/RadioGroup.vue +24 -0
  145. package/src/shadcn/radio-group/RadioGroupItem.vue +39 -0
  146. package/src/shadcn/radio-group/index.ts +2 -0
  147. package/src/shadcn/range-calendar/RangeCalendar.vue +71 -0
  148. package/src/shadcn/range-calendar/RangeCalendarCell.vue +23 -0
  149. package/src/shadcn/range-calendar/RangeCalendarCellTrigger.vue +41 -0
  150. package/src/shadcn/range-calendar/RangeCalendarGrid.vue +23 -0
  151. package/src/shadcn/range-calendar/RangeCalendarGridBody.vue +15 -0
  152. package/src/shadcn/range-calendar/RangeCalendarGridHead.vue +15 -0
  153. package/src/shadcn/range-calendar/RangeCalendarGridRow.vue +22 -0
  154. package/src/shadcn/range-calendar/RangeCalendarHeadCell.vue +23 -0
  155. package/src/shadcn/range-calendar/RangeCalendarHeader.vue +23 -0
  156. package/src/shadcn/range-calendar/RangeCalendarHeading.vue +30 -0
  157. package/src/shadcn/range-calendar/RangeCalendarNextButton.vue +32 -0
  158. package/src/shadcn/range-calendar/RangeCalendarPrevButton.vue +32 -0
  159. package/src/shadcn/range-calendar/index.ts +12 -0
  160. package/src/shadcn/select/Select.vue +18 -0
  161. package/src/shadcn/select/SelectContent.vue +52 -0
  162. package/src/shadcn/select/SelectGroup.vue +15 -0
  163. package/src/shadcn/select/SelectItem.vue +43 -0
  164. package/src/shadcn/select/SelectItemText.vue +15 -0
  165. package/src/shadcn/select/SelectLabel.vue +17 -0
  166. package/src/shadcn/select/SelectScrollDownButton.vue +26 -0
  167. package/src/shadcn/select/SelectScrollUpButton.vue +26 -0
  168. package/src/shadcn/select/SelectSeparator.vue +19 -0
  169. package/src/shadcn/select/SelectTrigger.vue +33 -0
  170. package/src/shadcn/select/SelectValue.vue +15 -0
  171. package/src/shadcn/select/index.ts +11 -0
  172. package/src/shadcn/separator/Separator.vue +31 -0
  173. package/src/shadcn/separator/index.ts +1 -0
  174. package/src/shadcn/sidebar/MenuGroup.vue +28 -0
  175. package/src/shadcn/sidebar/MenuItemRenderer.vue +23 -0
  176. package/src/shadcn/sidebar/Sidebar.vue +14 -0
  177. package/src/shadcn/sidebar/SidebarDemoContent.vue +26 -0
  178. package/src/shadcn/sidebar/SidebarMenuGroupWithLabel.vue +29 -0
  179. package/src/shadcn/sidebar/SidebarMenuItemWithIcon.vue +103 -0
  180. package/src/shadcn/sidebar/SidebarMenuSub.vue +10 -0
  181. package/src/shadcn/sidebar/SidebarMenuSubItemStyled.vue +38 -0
  182. package/src/shadcn/sidebar/SidebarTrigger.vue +8 -0
  183. package/src/shadcn/sidebar/index.ts +5 -0
  184. package/src/shadcn/slider/Slider.vue +43 -0
  185. package/src/shadcn/slider/index.ts +1 -0
  186. package/src/shadcn/sonner/Sonner.vue +19 -0
  187. package/src/shadcn/sonner/index.ts +1 -0
  188. package/src/shadcn/switch/Switch.vue +38 -0
  189. package/src/shadcn/switch/index.ts +1 -0
  190. package/src/shadcn/tabs/CardTabsContent.vue +16 -0
  191. package/src/shadcn/tabs/CornerCutTabsTrigger.vue +102 -0
  192. package/src/shadcn/tabs/GridTabsList.vue +30 -0
  193. package/src/shadcn/tabs/ScrollableTabsList.vue +8 -0
  194. package/src/shadcn/tabs/Tabs.vue +23 -0
  195. package/src/shadcn/tabs/TabsContent.vue +21 -0
  196. package/src/shadcn/tabs/TabsList.vue +24 -0
  197. package/src/shadcn/tabs/TabsTrigger.vue +30 -0
  198. package/src/shadcn/tabs/VerticalTabsList.vue +28 -0
  199. package/src/shadcn/tabs/VerticalTabsTrigger.vue +16 -0
  200. package/src/shadcn/tabs/index.ts +10 -0
  201. package/src/shadcn/toggle/Toggle.vue +35 -0
  202. package/src/shadcn/toggle/index.ts +28 -0
  203. package/src/shadcn/tooltip/Tooltip.vue +18 -0
  204. package/src/shadcn/tooltip/TooltipContent.vue +34 -0
  205. package/src/shadcn/tooltip/TooltipProvider.vue +14 -0
  206. package/src/shadcn/tooltip/TooltipTrigger.vue +15 -0
  207. package/src/shadcn/tooltip/index.ts +4 -0
  208. package/src/ui/InputOTP.vue +69 -0
  209. package/src/ui/InputOTPContext.ts +10 -0
  210. package/src/ui/InputOTPGroup.vue +7 -0
  211. package/src/ui/InputOTPSeparator.vue +8 -0
  212. package/src/ui/InputOTPSlot.vue +61 -0
  213. package/src/ui/PopoverContent.vue +27 -0
  214. package/src/ui/PopoverTrigger.vue +9 -0
  215. package/src/ui/SelectContent.vue +24 -0
  216. package/src/ui/SelectGroup.vue +22 -0
  217. package/src/ui/SelectItem.vue +25 -0
  218. package/src/ui/SelectLabel.vue +27 -0
  219. package/src/ui/SelectSeparator.vue +23 -0
  220. package/src/ui/SelectTrigger.vue +22 -0
  221. package/src/ui/SelectValue.vue +9 -0
  222. package/src/ui/SheetContent.vue +34 -0
  223. package/src/ui/SheetDescription.vue +9 -0
  224. package/src/ui/SheetHeader.vue +11 -0
  225. package/src/ui/SheetTitle.vue +9 -0
  226. package/src/ui/accordion-content.vue +21 -0
  227. package/src/ui/accordion-item.vue +18 -0
  228. package/src/ui/accordion-trigger.vue +14 -0
  229. package/src/ui/accordion.vue +9 -0
  230. package/src/ui/alert-actions.vue +13 -0
  231. package/src/ui/alert-description.vue +13 -0
  232. package/src/ui/alert-title.vue +13 -0
  233. package/src/ui/alert.vue +63 -0
  234. package/src/ui/avatar-fallback.vue +38 -0
  235. package/src/ui/avatar-group.vue +32 -0
  236. package/src/ui/avatar-image.vue +19 -0
  237. package/src/ui/avatar.vue +32 -0
  238. package/src/ui/badge.vue +90 -0
  239. package/src/ui/breadcrumb-item.vue +11 -0
  240. package/src/ui/breadcrumb-separator.vue +9 -0
  241. package/src/ui/breadcrumb.vue +11 -0
  242. package/src/ui/button.vue +76 -0
  243. package/src/ui/card-content.vue +16 -0
  244. package/src/ui/card-description.vue +16 -0
  245. package/src/ui/card-footer.vue +13 -0
  246. package/src/ui/card-header.vue +19 -0
  247. package/src/ui/card-title.vue +16 -0
  248. package/src/ui/card.vue +73 -0
  249. package/src/ui/category-breakdown-metric.vue +205 -0
  250. package/src/ui/checkbox.vue +84 -0
  251. package/src/ui/cn.ts +6 -0
  252. package/src/ui/dialog-body.vue +13 -0
  253. package/src/ui/dialog-close.vue +9 -0
  254. package/src/ui/dialog-content.vue +36 -0
  255. package/src/ui/dialog-description.vue +13 -0
  256. package/src/ui/dialog-footer.vue +13 -0
  257. package/src/ui/dialog-header.vue +13 -0
  258. package/src/ui/dialog-overlay.vue +14 -0
  259. package/src/ui/dialog-portal.vue +9 -0
  260. package/src/ui/dialog-title.vue +13 -0
  261. package/src/ui/dialog-trigger.vue +9 -0
  262. package/src/ui/dialog.vue +9 -0
  263. package/src/ui/dismissible-badges-demo.vue +94 -0
  264. package/src/ui/drawer-content.vue +53 -0
  265. package/src/ui/drawer-description.vue +23 -0
  266. package/src/ui/drawer-footer.vue +22 -0
  267. package/src/ui/drawer-header.vue +22 -0
  268. package/src/ui/drawer-title.vue +23 -0
  269. package/src/ui/drawer-trigger.vue +23 -0
  270. package/src/ui/drawer.vue +34 -0
  271. package/src/ui/dropdown-menu-checkbox-item.vue +27 -0
  272. package/src/ui/dropdown-menu-content.vue +23 -0
  273. package/src/ui/dropdown-menu-group.vue +7 -0
  274. package/src/ui/dropdown-menu-item.vue +19 -0
  275. package/src/ui/dropdown-menu-label.vue +17 -0
  276. package/src/ui/dropdown-menu-portal.vue +8 -0
  277. package/src/ui/dropdown-menu-radio-group.vue +14 -0
  278. package/src/ui/dropdown-menu-radio-item.vue +30 -0
  279. package/src/ui/dropdown-menu-separator.vue +13 -0
  280. package/src/ui/dropdown-menu-shortcut.vue +15 -0
  281. package/src/ui/dropdown-menu-sub-content.vue +8 -0
  282. package/src/ui/dropdown-menu-sub-trigger.vue +8 -0
  283. package/src/ui/dropdown-menu-sub.vue +8 -0
  284. package/src/ui/dropdown-menu-trigger.vue +8 -0
  285. package/src/ui/dropdown-menu.vue +9 -0
  286. package/src/ui/grouped-avatar.vue +19 -0
  287. package/src/ui/icons/Accessibility.vue +7 -0
  288. package/src/ui/icons/AlignLeft.vue +6 -0
  289. package/src/ui/icons/ArrowDown.vue +7 -0
  290. package/src/ui/icons/ArrowUp.vue +7 -0
  291. package/src/ui/icons/ArrowUpDown.vue +8 -0
  292. package/src/ui/icons/BookOpen.vue +6 -0
  293. package/src/ui/icons/Calendar.vue +9 -0
  294. package/src/ui/icons/Check.vue +6 -0
  295. package/src/ui/icons/ChevronRight.vue +6 -0
  296. package/src/ui/icons/Circle.vue +6 -0
  297. package/src/ui/icons/Copy.vue +7 -0
  298. package/src/ui/icons/Dot.vue +6 -0
  299. package/src/ui/icons/Edit.vue +6 -0
  300. package/src/ui/icons/FileText.vue +9 -0
  301. package/src/ui/icons/Folder.vue +6 -0
  302. package/src/ui/icons/FolderOpen.vue +7 -0
  303. package/src/ui/icons/Hash.vue +6 -0
  304. package/src/ui/icons/Home.vue +6 -0
  305. package/src/ui/icons/Minus.vue +6 -0
  306. package/src/ui/icons/MoreHorizontal.vue +8 -0
  307. package/src/ui/icons/Settings.vue +7 -0
  308. package/src/ui/icons/Slash.vue +6 -0
  309. package/src/ui/icons/Trash2.vue +6 -0
  310. package/src/ui/icons/Type.vue +6 -0
  311. package/src/ui/icons/User.vue +7 -0
  312. package/src/ui/input-otp.vue +52 -0
  313. package/src/ui/input.vue +98 -0
  314. package/src/ui/label.vue +19 -0
  315. package/src/ui/pagination.vue +41 -0
  316. package/src/ui/popover.vue +9 -0
  317. package/src/ui/progress.vue +67 -0
  318. package/src/ui/radio-group-item.vue +53 -0
  319. package/src/ui/radio-group.vue +27 -0
  320. package/src/ui/scrollable-tabs-list.vue +148 -0
  321. package/src/ui/select-multiple.vue +135 -0
  322. package/src/ui/select.vue +77 -0
  323. package/src/ui/separator.vue +60 -0
  324. package/src/ui/sheet.vue +50 -0
  325. package/src/ui/sidebar/BaseSidebar.vue +97 -0
  326. package/src/ui/sidebar/BasicSearch.vue +27 -0
  327. package/src/ui/sidebar/ResponsiveSearch.vue +54 -0
  328. package/src/ui/sidebar/Sidebar.vue +227 -0
  329. package/src/ui/sidebar/SidebarCollapseButton.vue +10 -0
  330. package/src/ui/sidebar/SidebarContent.vue +31 -0
  331. package/src/ui/sidebar/SidebarDescription.vue +10 -0
  332. package/src/ui/sidebar/SidebarExpandButton.vue +10 -0
  333. package/src/ui/sidebar/SidebarFooter.vue +10 -0
  334. package/src/ui/sidebar/SidebarGroup.vue +11 -0
  335. package/src/ui/sidebar/SidebarGroupContent.vue +10 -0
  336. package/src/ui/sidebar/SidebarGroupLabel.vue +7 -0
  337. package/src/ui/sidebar/SidebarHeader.vue +10 -0
  338. package/src/ui/sidebar/SidebarInset.vue +19 -0
  339. package/src/ui/sidebar/SidebarMenu.vue +7 -0
  340. package/src/ui/sidebar/SidebarMenuBadge.vue +7 -0
  341. package/src/ui/sidebar/SidebarMenuButton.vue +17 -0
  342. package/src/ui/sidebar/SidebarMenuItem.vue +10 -0
  343. package/src/ui/sidebar/SidebarMenuSub.vue +18 -0
  344. package/src/ui/sidebar/SidebarMenuSubContent.vue +10 -0
  345. package/src/ui/sidebar/SidebarMenuSubItem.vue +10 -0
  346. package/src/ui/sidebar/SidebarMenuSubTrigger.vue +10 -0
  347. package/src/ui/sidebar/SidebarProvider.vue +108 -0
  348. package/src/ui/sidebar/SidebarScrollArea.vue +10 -0
  349. package/src/ui/sidebar/SidebarSection.vue +10 -0
  350. package/src/ui/sidebar/SidebarSeparator.vue +8 -0
  351. package/src/ui/sidebar/SidebarShortcut.vue +10 -0
  352. package/src/ui/sidebar/SidebarTitle.vue +10 -0
  353. package/src/ui/sidebar/SidebarTrigger.vue +27 -0
  354. package/src/ui/sidebar/Wrapper.vue +12 -0
  355. package/src/ui/sidebar/context.ts +8 -0
  356. package/src/ui/sidebar/index.ts +27 -0
  357. package/src/ui/sidebar/sidebarStore.ts +40 -0
  358. package/src/ui/sidebar/types.ts +30 -0
  359. package/src/ui/sidebar/useAutoCollapse.ts +81 -0
  360. package/src/ui/sidebar.vue +24 -0
  361. package/src/ui/skeleton.vue +15 -0
  362. package/src/ui/slider.vue +32 -0
  363. package/src/ui/sonner.vue +67 -0
  364. package/src/ui/switch.vue +33 -0
  365. package/src/ui/tab-content.vue +28 -0
  366. package/src/ui/tab-list.vue +31 -0
  367. package/src/ui/tab-panel.vue +19 -0
  368. package/src/ui/tab-trigger.vue +34 -0
  369. package/src/ui/tab.vue +30 -0
  370. package/src/ui/table-body.vue +16 -0
  371. package/src/ui/table-caption.vue +20 -0
  372. package/src/ui/table-cell.vue +16 -0
  373. package/src/ui/table-footer.vue +16 -0
  374. package/src/ui/table-header.vue +132 -0
  375. package/src/ui/table-row.vue +16 -0
  376. package/src/ui/table.vue +55 -0
  377. package/src/ui/tabs.vue +33 -0
  378. package/src/ui/textarea.vue +91 -0
  379. package/src/ui/threat-gauge.vue +137 -0
  380. package/src/ui/toggle.vue +69 -0
  381. package/src/ui/tooltip-content.vue +52 -0
  382. package/src/ui/tooltip-provider.vue +13 -0
  383. package/src/ui/tooltip-root.vue +9 -0
  384. package/src/ui/tooltip-trigger.vue +13 -0
  385. package/src/ui/tooltip.vue +22 -0
  386. package/src/ui/utils.ts +6 -0
  387. package/vite.config.ts +39 -0
@@ -0,0 +1,23 @@
1
+ <script lang="ts" setup>
2
+ import type { CalendarGridProps } from "reka-ui"
3
+ import type { HTMLAttributes } from "vue"
4
+ import { reactiveOmit } from "@vueuse/core"
5
+ import { CalendarGrid, useForwardProps } from "reka-ui"
6
+ import { cn } from "@/lib/utils"
7
+
8
+ const props = defineProps<CalendarGridProps & { class?: HTMLAttributes["class"] }>()
9
+
10
+ const delegatedProps = reactiveOmit(props, "class")
11
+
12
+ const forwardedProps = useForwardProps(delegatedProps)
13
+ </script>
14
+
15
+ <template>
16
+ <CalendarGrid
17
+ data-slot="calendar-grid"
18
+ :class="cn('w-full border-collapse space-x-1', props.class)"
19
+ v-bind="forwardedProps"
20
+ >
21
+ <slot />
22
+ </CalendarGrid>
23
+ </template>
@@ -0,0 +1,15 @@
1
+ <script lang="ts" setup>
2
+ import type { CalendarGridBodyProps } from "reka-ui"
3
+ import { CalendarGridBody } from "reka-ui"
4
+
5
+ const props = defineProps<CalendarGridBodyProps>()
6
+ </script>
7
+
8
+ <template>
9
+ <CalendarGridBody
10
+ data-slot="calendar-grid-body"
11
+ v-bind="props"
12
+ >
13
+ <slot />
14
+ </CalendarGridBody>
15
+ </template>
@@ -0,0 +1,16 @@
1
+ <script lang="ts" setup>
2
+ import type { CalendarGridHeadProps } from "reka-ui"
3
+ import type { HTMLAttributes } from "vue"
4
+ import { CalendarGridHead } from "reka-ui"
5
+
6
+ const props = defineProps<CalendarGridHeadProps & { class?: HTMLAttributes["class"] }>()
7
+ </script>
8
+
9
+ <template>
10
+ <CalendarGridHead
11
+ data-slot="calendar-grid-head"
12
+ v-bind="props"
13
+ >
14
+ <slot />
15
+ </CalendarGridHead>
16
+ </template>
@@ -0,0 +1,22 @@
1
+ <script lang="ts" setup>
2
+ import type { CalendarGridRowProps } from "reka-ui"
3
+ import type { HTMLAttributes } from "vue"
4
+ import { reactiveOmit } from "@vueuse/core"
5
+ import { CalendarGridRow, useForwardProps } from "reka-ui"
6
+ import { cn } from "@/lib/utils"
7
+
8
+ const props = defineProps<CalendarGridRowProps & { class?: HTMLAttributes["class"] }>()
9
+
10
+ const delegatedProps = reactiveOmit(props, "class")
11
+
12
+ const forwardedProps = useForwardProps(delegatedProps)
13
+ </script>
14
+
15
+ <template>
16
+ <CalendarGridRow
17
+ data-slot="calendar-grid-row"
18
+ :class="cn('flex', props.class)" v-bind="forwardedProps"
19
+ >
20
+ <slot />
21
+ </CalendarGridRow>
22
+ </template>
@@ -0,0 +1,23 @@
1
+ <script lang="ts" setup>
2
+ import type { CalendarHeadCellProps } from "reka-ui"
3
+ import type { HTMLAttributes } from "vue"
4
+ import { reactiveOmit } from "@vueuse/core"
5
+ import { CalendarHeadCell, useForwardProps } from "reka-ui"
6
+ import { cn } from "@/lib/utils"
7
+
8
+ const props = defineProps<CalendarHeadCellProps & { class?: HTMLAttributes["class"] }>()
9
+
10
+ const delegatedProps = reactiveOmit(props, "class")
11
+
12
+ const forwardedProps = useForwardProps(delegatedProps)
13
+ </script>
14
+
15
+ <template>
16
+ <CalendarHeadCell
17
+ data-slot="calendar-head-cell"
18
+ :class="cn('text-muted-foreground rounded-md w-8 font-normal text-[0.8rem]', props.class)"
19
+ v-bind="forwardedProps"
20
+ >
21
+ <slot />
22
+ </CalendarHeadCell>
23
+ </template>
@@ -0,0 +1,23 @@
1
+ <script lang="ts" setup>
2
+ import type { CalendarHeaderProps } from "reka-ui"
3
+ import type { HTMLAttributes } from "vue"
4
+ import { reactiveOmit } from "@vueuse/core"
5
+ import { CalendarHeader, useForwardProps } from "reka-ui"
6
+ import { cn } from "@/lib/utils"
7
+
8
+ const props = defineProps<CalendarHeaderProps & { class?: HTMLAttributes["class"] }>()
9
+
10
+ const delegatedProps = reactiveOmit(props, "class")
11
+
12
+ const forwardedProps = useForwardProps(delegatedProps)
13
+ </script>
14
+
15
+ <template>
16
+ <CalendarHeader
17
+ data-slot="calendar-header"
18
+ :class="cn('flex justify-center pt-1 relative items-center w-full', props.class)"
19
+ v-bind="forwardedProps"
20
+ >
21
+ <slot />
22
+ </CalendarHeader>
23
+ </template>
@@ -0,0 +1,30 @@
1
+ <script lang="ts" setup>
2
+ import type { CalendarHeadingProps } from "reka-ui"
3
+ import type { HTMLAttributes } from "vue"
4
+ import { reactiveOmit } from "@vueuse/core"
5
+ import { CalendarHeading, useForwardProps } from "reka-ui"
6
+ import { cn } from "@/lib/utils"
7
+
8
+ const props = defineProps<CalendarHeadingProps & { class?: HTMLAttributes["class"] }>()
9
+
10
+ defineSlots<{
11
+ default: (props: { headingValue: string }) => any
12
+ }>()
13
+
14
+ const delegatedProps = reactiveOmit(props, "class")
15
+
16
+ const forwardedProps = useForwardProps(delegatedProps)
17
+ </script>
18
+
19
+ <template>
20
+ <CalendarHeading
21
+ v-slot="{ headingValue }"
22
+ data-slot="calendar-heading"
23
+ :class="cn('text-sm font-medium', props.class)"
24
+ v-bind="forwardedProps"
25
+ >
26
+ <slot :heading-value>
27
+ {{ headingValue }}
28
+ </slot>
29
+ </CalendarHeading>
30
+ </template>
@@ -0,0 +1,32 @@
1
+ <script lang="ts" setup>
2
+ import type { CalendarNextProps } from "reka-ui"
3
+ import type { HTMLAttributes } from "vue"
4
+ import { reactiveOmit } from "@vueuse/core"
5
+ import { ChevronRight } from "lucide-vue-next"
6
+ import { CalendarNext, useForwardProps } from "reka-ui"
7
+ import { cn } from "@/lib/utils"
8
+ import { buttonVariants } from '@/shadcn/button'
9
+
10
+ const props = defineProps<CalendarNextProps & { class?: HTMLAttributes["class"] }>()
11
+
12
+ const delegatedProps = reactiveOmit(props, "class")
13
+
14
+ const forwardedProps = useForwardProps(delegatedProps)
15
+ </script>
16
+
17
+ <template>
18
+ <CalendarNext
19
+ data-slot="calendar-next-button"
20
+ :class="cn(
21
+ buttonVariants({ variant: 'outline' }),
22
+ 'absolute right-1',
23
+ 'size-7 bg-transparent p-0 opacity-50 hover:opacity-100',
24
+ props.class,
25
+ )"
26
+ v-bind="forwardedProps"
27
+ >
28
+ <slot>
29
+ <ChevronRight class="size-4" />
30
+ </slot>
31
+ </CalendarNext>
32
+ </template>
@@ -0,0 +1,32 @@
1
+ <script lang="ts" setup>
2
+ import type { CalendarPrevProps } from "reka-ui"
3
+ import type { HTMLAttributes } from "vue"
4
+ import { reactiveOmit } from "@vueuse/core"
5
+ import { ChevronLeft } from "lucide-vue-next"
6
+ import { CalendarPrev, useForwardProps } from "reka-ui"
7
+ import { cn } from "@/lib/utils"
8
+ import { buttonVariants } from '@/shadcn/button'
9
+
10
+ const props = defineProps<CalendarPrevProps & { class?: HTMLAttributes["class"] }>()
11
+
12
+ const delegatedProps = reactiveOmit(props, "class")
13
+
14
+ const forwardedProps = useForwardProps(delegatedProps)
15
+ </script>
16
+
17
+ <template>
18
+ <CalendarPrev
19
+ data-slot="calendar-prev-button"
20
+ :class="cn(
21
+ buttonVariants({ variant: 'outline' }),
22
+ 'absolute left-1',
23
+ 'size-7 bg-transparent p-0 opacity-50 hover:opacity-100',
24
+ props.class,
25
+ )"
26
+ v-bind="forwardedProps"
27
+ >
28
+ <slot>
29
+ <ChevronLeft class="size-4" />
30
+ </slot>
31
+ </CalendarPrev>
32
+ </template>
@@ -0,0 +1,12 @@
1
+ export { default as Calendar } from "./Calendar.vue"
2
+ export { default as CalendarCell } from "./CalendarCell.vue"
3
+ export { default as CalendarCellTrigger } from "./CalendarCellTrigger.vue"
4
+ export { default as CalendarGrid } from "./CalendarGrid.vue"
5
+ export { default as CalendarGridBody } from "./CalendarGridBody.vue"
6
+ export { default as CalendarGridHead } from "./CalendarGridHead.vue"
7
+ export { default as CalendarGridRow } from "./CalendarGridRow.vue"
8
+ export { default as CalendarHeadCell } from "./CalendarHeadCell.vue"
9
+ export { default as CalendarHeader } from "./CalendarHeader.vue"
10
+ export { default as CalendarHeading } from "./CalendarHeading.vue"
11
+ export { default as CalendarNextButton } from "./CalendarNextButton.vue"
12
+ export { default as CalendarPrevButton } from "./CalendarPrevButton.vue"
@@ -0,0 +1,8 @@
1
+ <template>
2
+ <div class="bg-card border rounded-lg shadow-sm">
3
+ <slot />
4
+ </div>
5
+ </template>
6
+ <script setup lang="ts">
7
+ // No props needed
8
+ </script>
@@ -0,0 +1,8 @@
1
+ <template>
2
+ <div class="p-4">
3
+ <slot />
4
+ </div>
5
+ </template>
6
+ <script setup lang="ts">
7
+ // No props needed
8
+ </script>
@@ -0,0 +1,8 @@
1
+ <template>
2
+ <p class="text-muted-foreground text-sm">
3
+ <slot />
4
+ </p>
5
+ </template>
6
+ <script setup lang="ts">
7
+ // No props needed
8
+ </script>
@@ -0,0 +1,8 @@
1
+ <template>
2
+ <div class="p-4 border-b">
3
+ <slot />
4
+ </div>
5
+ </template>
6
+ <script setup lang="ts">
7
+ // No props needed
8
+ </script>
@@ -0,0 +1,8 @@
1
+ <template>
2
+ <h3 class="text-lg font-semibold">
3
+ <slot />
4
+ </h3>
5
+ </template>
6
+ <script setup lang="ts">
7
+ // No props needed
8
+ </script>
@@ -0,0 +1,5 @@
1
+ export { default as Card } from './Card.vue';
2
+ export { default as CardHeader } from './CardHeader.vue';
3
+ export { default as CardContent } from './CardContent.vue';
4
+ export { default as CardTitle } from './CardTitle.vue';
5
+ export { default as CardDescription } from './CardDescription.vue';
@@ -0,0 +1,38 @@
1
+ <script setup lang="ts">
2
+ import type { CheckboxRootEmits, CheckboxRootProps } from "reka-ui"
3
+ import type { HTMLAttributes } from "vue"
4
+ import { reactiveOmit } from "@vueuse/core"
5
+ import { Check, Minus } from "lucide-vue-next"
6
+ import { CheckboxIndicator, CheckboxRoot, useForwardPropsEmits } from "reka-ui"
7
+ import { cn } from "@/lib/utils"
8
+
9
+ const props = defineProps<CheckboxRootProps & {
10
+ class?: HTMLAttributes["class"],
11
+ validationState?: "success" | "error",
12
+ validationText?: string
13
+ }>()
14
+ const emits = defineEmits<CheckboxRootEmits>()
15
+
16
+ const delegatedProps = reactiveOmit(props, "class")
17
+
18
+ const forwarded = useForwardPropsEmits(delegatedProps, emits)
19
+ </script>
20
+
21
+ <template>
22
+ <CheckboxRoot
23
+ data-slot="checkbox"
24
+ v-bind="forwarded"
25
+ :class="
26
+ cn('peer data-[state=checked]:bg-primary data-[state=checked]:text-primary-foreground data-[state=checked]:border-primary focus-visible:border-ring focus-visible:ring-ring/50 aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive size-4 shrink-0 rounded-[4px] border shadow-xs transition-shadow outline-none focus-visible:ring-[3px] disabled:cursor-not-allowed disabled:opacity-50 bg-input-background',
27
+ props.class)"
28
+ >
29
+ <CheckboxIndicator
30
+ data-slot="checkbox-indicator"
31
+ class="grid place-content-center text-current transition-none"
32
+ >
33
+ <slot>
34
+ <Check class="size-3.5" />
35
+ </slot>
36
+ </CheckboxIndicator>
37
+ </CheckboxRoot>
38
+ </template>
@@ -0,0 +1 @@
1
+ export { default as Checkbox } from "./Checkbox.vue"
@@ -0,0 +1,87 @@
1
+ <script setup lang="ts">
2
+ import type { ListboxRootEmits, ListboxRootProps } from "reka-ui"
3
+ import type { HTMLAttributes } from "vue"
4
+ import { reactiveOmit } from "@vueuse/core"
5
+ import { ListboxRoot, useFilter, useForwardPropsEmits } from "reka-ui"
6
+ import { reactive, ref, watch } from "vue"
7
+ import { cn } from "@/lib/utils"
8
+ import { provideCommandContext } from "."
9
+
10
+ const props = withDefaults(defineProps<ListboxRootProps & { class?: HTMLAttributes["class"] }>(), {
11
+ modelValue: "",
12
+ })
13
+
14
+ const emits = defineEmits<ListboxRootEmits>()
15
+
16
+ const delegatedProps = reactiveOmit(props, "class")
17
+
18
+ const forwarded = useForwardPropsEmits(delegatedProps, emits)
19
+
20
+ const allItems = ref<Map<string, string>>(new Map())
21
+ const allGroups = ref<Map<string, Set<string>>>(new Map())
22
+
23
+ const { contains } = useFilter({ sensitivity: "base" })
24
+ const filterState = reactive({
25
+ search: "",
26
+ filtered: {
27
+ /** The count of all visible items. */
28
+ count: 0,
29
+ /** Map from visible item id to its search score. */
30
+ items: new Map() as Map<string, number>,
31
+ /** Set of groups with at least one visible item. */
32
+ groups: new Set() as Set<string>,
33
+ },
34
+ })
35
+
36
+ function filterItems() {
37
+ if (!filterState.search) {
38
+ filterState.filtered.count = allItems.value.size
39
+ // Do nothing, each item will know to show itself because search is empty
40
+ return
41
+ }
42
+
43
+ // Reset the groups
44
+ filterState.filtered.groups = new Set()
45
+ let itemCount = 0
46
+
47
+ // Check which items should be included
48
+ for (const [id, value] of allItems.value) {
49
+ const score = contains(value, filterState.search)
50
+ filterState.filtered.items.set(id, score ? 1 : 0)
51
+ if (score)
52
+ itemCount++
53
+ }
54
+
55
+ // Check which groups have at least 1 item shown
56
+ for (const [groupId, group] of allGroups.value) {
57
+ for (const itemId of group) {
58
+ if (filterState.filtered.items.get(itemId)! > 0) {
59
+ filterState.filtered.groups.add(groupId)
60
+ break
61
+ }
62
+ }
63
+ }
64
+
65
+ filterState.filtered.count = itemCount
66
+ }
67
+
68
+ watch(() => filterState.search, () => {
69
+ filterItems()
70
+ })
71
+
72
+ provideCommandContext({
73
+ allItems,
74
+ allGroups,
75
+ filterState,
76
+ })
77
+ </script>
78
+
79
+ <template>
80
+ <ListboxRoot
81
+ data-slot="command"
82
+ v-bind="forwarded"
83
+ :class="cn('bg-popover text-popover-foreground flex h-full w-full flex-col overflow-hidden rounded-md', props.class)"
84
+ >
85
+ <slot />
86
+ </ListboxRoot>
87
+ </template>
@@ -0,0 +1,31 @@
1
+ <script setup lang="ts">
2
+ import type { DialogRootEmits, DialogRootProps } from "reka-ui"
3
+ import { useForwardPropsEmits } from "reka-ui"
4
+ import { Dialog, DialogContent, DialogDescription, DialogHeader, DialogTitle } from '@/shadcn/dialog'
5
+ import Command from "./Command.vue"
6
+
7
+ const props = withDefaults(defineProps<DialogRootProps & {
8
+ title?: string
9
+ description?: string
10
+ }>(), {
11
+ title: "Command Palette",
12
+ description: "Search for a command to run...",
13
+ })
14
+ const emits = defineEmits<DialogRootEmits>()
15
+
16
+ const forwarded = useForwardPropsEmits(props, emits)
17
+ </script>
18
+
19
+ <template>
20
+ <Dialog v-bind="forwarded">
21
+ <DialogContent class="overflow-hidden p-0 ">
22
+ <DialogHeader class="sr-only">
23
+ <DialogTitle>{{ title }}</DialogTitle>
24
+ <DialogDescription>{{ description }}</DialogDescription>
25
+ </DialogHeader>
26
+ <Command>
27
+ <slot />
28
+ </Command>
29
+ </DialogContent>
30
+ </Dialog>
31
+ </template>
@@ -0,0 +1,27 @@
1
+ <script setup lang="ts">
2
+ import type { PrimitiveProps } from "reka-ui"
3
+ import type { HTMLAttributes } from "vue"
4
+ import { reactiveOmit } from "@vueuse/core"
5
+ import { Primitive } from "reka-ui"
6
+ import { computed } from "vue"
7
+ import { cn } from "@/lib/utils"
8
+ import { useCommand } from "."
9
+
10
+ const props = defineProps<PrimitiveProps & { class?: HTMLAttributes["class"] }>()
11
+
12
+ const delegatedProps = reactiveOmit(props, "class")
13
+
14
+ const { filterState } = useCommand()
15
+ const isRender = computed(() => !!filterState.search && filterState.filtered.count === 0,
16
+ )
17
+ </script>
18
+
19
+ <template>
20
+ <Primitive
21
+ v-if="isRender"
22
+ data-slot="command-empty"
23
+ v-bind="delegatedProps" :class="cn('py-6 text-center text-sm', props.class)"
24
+ >
25
+ <slot />
26
+ </Primitive>
27
+ </template>
@@ -0,0 +1,45 @@
1
+ <script setup lang="ts">
2
+ import type { ListboxGroupProps } from "reka-ui"
3
+ import type { HTMLAttributes } from "vue"
4
+ import { reactiveOmit } from "@vueuse/core"
5
+ import { ListboxGroup, ListboxGroupLabel, useId } from "reka-ui"
6
+ import { computed, onMounted, onUnmounted } from "vue"
7
+ import { cn } from "@/lib/utils"
8
+ import { provideCommandGroupContext, useCommand } from "."
9
+
10
+ const props = defineProps<ListboxGroupProps & {
11
+ class?: HTMLAttributes["class"]
12
+ heading?: string
13
+ }>()
14
+
15
+ const delegatedProps = reactiveOmit(props, "class")
16
+
17
+ const { allGroups, filterState } = useCommand()
18
+ const id = useId()
19
+
20
+ const isRender = computed(() => !filterState.search ? true : filterState.filtered.groups.has(id))
21
+
22
+ provideCommandGroupContext({ id })
23
+ onMounted(() => {
24
+ if (!allGroups.value.has(id))
25
+ allGroups.value.set(id, new Set())
26
+ })
27
+ onUnmounted(() => {
28
+ allGroups.value.delete(id)
29
+ })
30
+ </script>
31
+
32
+ <template>
33
+ <ListboxGroup
34
+ v-bind="delegatedProps"
35
+ :id="id"
36
+ data-slot="command-group"
37
+ :class="cn('text-foreground overflow-hidden p-1', props.class)"
38
+ :hidden="isRender ? undefined : true"
39
+ >
40
+ <ListboxGroupLabel v-if="heading" class="px-2 py-1.5 text-xs font-medium text-muted-foreground">
41
+ {{ heading }}
42
+ </ListboxGroupLabel>
43
+ <slot />
44
+ </ListboxGroup>
45
+ </template>
@@ -0,0 +1,39 @@
1
+ <script setup lang="ts">
2
+ import type { ListboxFilterProps } from "reka-ui"
3
+ import type { HTMLAttributes } from "vue"
4
+ import { reactiveOmit } from "@vueuse/core"
5
+ import { Search } from "lucide-vue-next"
6
+ import { ListboxFilter, useForwardProps } from "reka-ui"
7
+ import { cn } from "@/lib/utils"
8
+ import { useCommand } from "."
9
+
10
+ defineOptions({
11
+ inheritAttrs: false,
12
+ })
13
+
14
+ const props = defineProps<ListboxFilterProps & {
15
+ class?: HTMLAttributes["class"]
16
+ }>()
17
+
18
+ const delegatedProps = reactiveOmit(props, "class")
19
+
20
+ const forwardedProps = useForwardProps(delegatedProps)
21
+
22
+ const { filterState } = useCommand()
23
+ </script>
24
+
25
+ <template>
26
+ <div
27
+ data-slot="command-input-wrapper"
28
+ class="flex h-9 items-center gap-2 border-b px-3"
29
+ >
30
+ <Search class="size-4 shrink-0 opacity-50" />
31
+ <ListboxFilter
32
+ v-bind="{ ...forwardedProps, ...$attrs }"
33
+ v-model="filterState.search"
34
+ data-slot="command-input"
35
+ auto-focus
36
+ :class="cn('placeholder:text-muted-foreground flex h-10 w-full rounded-md bg-transparent py-3 text-sm outline-hidden disabled:cursor-not-allowed disabled:opacity-50', props.class)"
37
+ />
38
+ </div>
39
+ </template>
@@ -0,0 +1,76 @@
1
+ <script setup lang="ts">
2
+ import type { ListboxItemEmits, ListboxItemProps } from "reka-ui"
3
+ import type { HTMLAttributes } from "vue"
4
+ import { reactiveOmit, useCurrentElement } from "@vueuse/core"
5
+ import { ListboxItem, useForwardPropsEmits, useId } from "reka-ui"
6
+ import { computed, onMounted, onUnmounted, ref } from "vue"
7
+ import { cn } from "@/lib/utils"
8
+ import { useCommand, useCommandGroup } from "."
9
+
10
+ const props = defineProps<ListboxItemProps & { class?: HTMLAttributes["class"] }>()
11
+ const emits = defineEmits<ListboxItemEmits>()
12
+
13
+ const delegatedProps = reactiveOmit(props, "class")
14
+
15
+ const forwarded = useForwardPropsEmits(delegatedProps, emits)
16
+
17
+ const id = useId()
18
+ const { filterState, allItems, allGroups } = useCommand()
19
+ const groupContext = useCommandGroup()
20
+
21
+ const isRender = computed(() => {
22
+ if (!filterState.search) {
23
+ return true
24
+ }
25
+ else {
26
+ const filteredCurrentItem = filterState.filtered.items.get(id)
27
+ // If the filtered items is undefined means not in the all times map yet
28
+ // Do the first render to add into the map
29
+ if (filteredCurrentItem === undefined) {
30
+ return true
31
+ }
32
+
33
+ // Check with filter
34
+ return filteredCurrentItem > 0
35
+ }
36
+ })
37
+
38
+ const itemRef = ref()
39
+ const currentElement = useCurrentElement(itemRef)
40
+ onMounted(() => {
41
+ if (!(currentElement.value instanceof HTMLElement))
42
+ return
43
+
44
+ // textValue to perform filter
45
+ allItems.value.set(id, currentElement.value.textContent ?? (props.value?.toString() ?? ""))
46
+
47
+ const groupId = groupContext?.id
48
+ if (groupId) {
49
+ if (!allGroups.value.has(groupId)) {
50
+ allGroups.value.set(groupId, new Set([id]))
51
+ }
52
+ else {
53
+ allGroups.value.get(groupId)?.add(id)
54
+ }
55
+ }
56
+ })
57
+ onUnmounted(() => {
58
+ allItems.value.delete(id)
59
+ })
60
+ </script>
61
+
62
+ <template>
63
+ <ListboxItem
64
+ v-if="isRender"
65
+ v-bind="forwarded"
66
+ :id="id"
67
+ ref="itemRef"
68
+ data-slot="command-item"
69
+ :class="cn('data-[state=checked]:bg-accent data-[highlighted]:text-accent-foreground [&_svg:not([class*=\'text-\'])]:text-muted-foreground relative flex cursor-default items-center gap-2 rounded-sm px-2 !py-1.5 text-sm outline-hidden select-none data-[disabled]:pointer-events-none data-[disabled]:opacity-50 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*=\'size-\'])]:size-4', props.class)"
70
+ @select="() => {
71
+ filterState.search = ''
72
+ }"
73
+ >
74
+ <slot />
75
+ </ListboxItem>
76
+ </template>