@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,21 @@
1
+ <script setup lang="ts">
2
+ import type { DialogOverlayProps } from "reka-ui"
3
+ import type { HTMLAttributes } from "vue"
4
+ import { reactiveOmit } from "@vueuse/core"
5
+ import { DialogOverlay } from "reka-ui"
6
+ import { cn } from "@/lib/utils"
7
+
8
+ const props = defineProps<DialogOverlayProps & { class?: HTMLAttributes["class"] }>()
9
+
10
+ const delegatedProps = reactiveOmit(props, "class")
11
+ </script>
12
+
13
+ <template>
14
+ <DialogOverlay
15
+ data-slot="dialog-overlay"
16
+ v-bind="delegatedProps"
17
+ :class="cn('data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 fixed inset-0 z-50 bg-black/80', props.class)"
18
+ >
19
+ <slot />
20
+ </DialogOverlay>
21
+ </template>
@@ -0,0 +1,56 @@
1
+ <script setup lang="ts">
2
+ import type { DialogContentEmits, DialogContentProps } from "reka-ui"
3
+ import type { HTMLAttributes } from "vue"
4
+ import { reactiveOmit } from "@vueuse/core"
5
+ import { X } from "lucide-vue-next"
6
+ import {
7
+ DialogClose,
8
+ DialogContent,
9
+
10
+ DialogOverlay,
11
+ DialogPortal,
12
+ useForwardPropsEmits,
13
+ } from "reka-ui"
14
+ import { cn } from "@/lib/utils"
15
+
16
+ const props = defineProps<DialogContentProps & { class?: HTMLAttributes["class"] }>()
17
+ const emits = defineEmits<DialogContentEmits>()
18
+
19
+ const delegatedProps = reactiveOmit(props, "class")
20
+
21
+ const forwarded = useForwardPropsEmits(delegatedProps, emits)
22
+ </script>
23
+
24
+ <template>
25
+ <DialogPortal>
26
+ <DialogOverlay
27
+ class="fixed inset-0 z-50 grid place-items-center overflow-y-auto bg-black/80 data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0"
28
+ >
29
+ <DialogContent
30
+ :class="
31
+ cn(
32
+ 'relative z-50 grid w-full max-w-lg my-8 gap-4 border border-border bg-background p-6 shadow-lg duration-200 sm:rounded-lg md:w-full',
33
+ props.class,
34
+ )
35
+ "
36
+ v-bind="forwarded"
37
+ @pointer-down-outside="(event) => {
38
+ const originalEvent = event.detail.originalEvent;
39
+ const target = originalEvent.target as HTMLElement;
40
+ if (originalEvent.offsetX > target.clientWidth || originalEvent.offsetY > target.clientHeight) {
41
+ event.preventDefault();
42
+ }
43
+ }"
44
+ >
45
+ <slot />
46
+
47
+ <DialogClose
48
+ class="absolute top-4 right-4 p-0.5 transition-colors rounded-md hover:bg-secondary"
49
+ >
50
+ <X class="w-4 h-4" />
51
+ <span class="sr-only">Close</span>
52
+ </DialogClose>
53
+ </DialogContent>
54
+ </DialogOverlay>
55
+ </DialogPortal>
56
+ </template>
@@ -0,0 +1,23 @@
1
+ <script setup lang="ts">
2
+ import type { DialogTitleProps } from "reka-ui"
3
+ import type { HTMLAttributes } from "vue"
4
+ import { reactiveOmit } from "@vueuse/core"
5
+ import { DialogTitle, useForwardProps } from "reka-ui"
6
+ import { cn } from "@/lib/utils"
7
+
8
+ const props = defineProps<DialogTitleProps & { class?: HTMLAttributes["class"] }>()
9
+
10
+ const delegatedProps = reactiveOmit(props, "class")
11
+
12
+ const forwardedProps = useForwardProps(delegatedProps)
13
+ </script>
14
+
15
+ <template>
16
+ <DialogTitle
17
+ data-slot="dialog-title"
18
+ v-bind="forwardedProps"
19
+ :class="cn('text-lg leading-none font-semibold', props.class)"
20
+ >
21
+ <slot />
22
+ </DialogTitle>
23
+ </template>
@@ -0,0 +1,15 @@
1
+ <script setup lang="ts">
2
+ import type { DialogTriggerProps } from "reka-ui"
3
+ import { DialogTrigger } from "reka-ui"
4
+
5
+ const props = defineProps<DialogTriggerProps>()
6
+ </script>
7
+
8
+ <template>
9
+ <DialogTrigger
10
+ data-slot="dialog-trigger"
11
+ v-bind="props"
12
+ >
13
+ <slot />
14
+ </DialogTrigger>
15
+ </template>
@@ -0,0 +1,10 @@
1
+ export { default as Dialog } from "./Dialog.vue"
2
+ export { default as DialogClose } from "./DialogClose.vue"
3
+ export { default as DialogContent } from "./DialogContent.vue"
4
+ export { default as DialogDescription } from "./DialogDescription.vue"
5
+ export { default as DialogFooter } from "./DialogFooter.vue"
6
+ export { default as DialogHeader } from "./DialogHeader.vue"
7
+ export { default as DialogOverlay } from "./DialogOverlay.vue"
8
+ export { default as DialogScrollContent } from "./DialogScrollContent.vue"
9
+ export { default as DialogTitle } from "./DialogTitle.vue"
10
+ export { default as DialogTrigger } from "./DialogTrigger.vue"
@@ -0,0 +1,18 @@
1
+ <script setup lang="ts">
2
+ import type { DropdownMenuRootEmits, DropdownMenuRootProps } from "reka-ui"
3
+ import { DropdownMenuRoot, useForwardPropsEmits } from "reka-ui"
4
+
5
+ const props = defineProps<DropdownMenuRootProps>()
6
+ const emits = defineEmits<DropdownMenuRootEmits>()
7
+
8
+ const forwarded = useForwardPropsEmits(props, emits)
9
+ </script>
10
+
11
+ <template>
12
+ <DropdownMenuRoot
13
+ data-slot="dropdown-menu"
14
+ v-bind="forwarded"
15
+ >
16
+ <slot />
17
+ </DropdownMenuRoot>
18
+ </template>
@@ -0,0 +1,38 @@
1
+ <script setup lang="ts">
2
+ import type { DropdownMenuCheckboxItemEmits, DropdownMenuCheckboxItemProps } from "reka-ui"
3
+ import type { HTMLAttributes } from "vue"
4
+ import { reactiveOmit } from "@vueuse/core"
5
+ import { Check } from "lucide-vue-next"
6
+ import {
7
+ DropdownMenuCheckboxItem,
8
+
9
+ DropdownMenuItemIndicator,
10
+ useForwardPropsEmits,
11
+ } from "reka-ui"
12
+ import { cn } from "@/lib/utils"
13
+
14
+ const props = defineProps<DropdownMenuCheckboxItemProps & { class?: HTMLAttributes["class"] }>()
15
+ const emits = defineEmits<DropdownMenuCheckboxItemEmits>()
16
+
17
+ const delegatedProps = reactiveOmit(props, "class")
18
+
19
+ const forwarded = useForwardPropsEmits(delegatedProps, emits)
20
+ </script>
21
+
22
+ <template>
23
+ <DropdownMenuCheckboxItem
24
+ data-slot="dropdown-menu-checkbox-item"
25
+ v-bind="forwarded"
26
+ :class=" cn(
27
+ 'focus:bg-accent focus:text-accent-foreground relative flex cursor-default items-center gap-2 rounded-sm py-1.5 pr-2 pl-8 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',
28
+ props.class,
29
+ )"
30
+ >
31
+ <span class="pointer-events-none absolute left-2 flex size-3.5 items-center justify-center">
32
+ <DropdownMenuItemIndicator>
33
+ <Check class="size-4" />
34
+ </DropdownMenuItemIndicator>
35
+ </span>
36
+ <slot />
37
+ </DropdownMenuCheckboxItem>
38
+ </template>
@@ -0,0 +1,36 @@
1
+ <script setup lang="ts">
2
+ import type { DropdownMenuContentEmits, DropdownMenuContentProps } from "reka-ui"
3
+ import type { HTMLAttributes } from "vue"
4
+ import { reactiveOmit } from "@vueuse/core"
5
+ import {
6
+ DropdownMenuContent,
7
+
8
+ DropdownMenuPortal,
9
+ useForwardPropsEmits,
10
+ } from "reka-ui"
11
+ import { cn } from "@/lib/utils"
12
+
13
+ const props = withDefaults(
14
+ defineProps<DropdownMenuContentProps & { class?: HTMLAttributes["class"] }>(),
15
+ {
16
+ sideOffset: 4,
17
+ },
18
+ )
19
+ const emits = defineEmits<DropdownMenuContentEmits>()
20
+
21
+ const delegatedProps = reactiveOmit(props, "class")
22
+
23
+ const forwarded = useForwardPropsEmits(delegatedProps, emits)
24
+ </script>
25
+
26
+ <template>
27
+ <DropdownMenuPortal>
28
+ <DropdownMenuContent
29
+ data-slot="dropdown-menu-content"
30
+ v-bind="forwarded"
31
+ :class="cn('bg-popover text-popover-foreground data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 z-50 max-h-(--reka-dropdown-menu-content-available-height) min-w-[8rem] origin-(--reka-dropdown-menu-content-transform-origin) overflow-x-hidden overflow-y-auto rounded-md border p-1 shadow-md', props.class)"
32
+ >
33
+ <slot />
34
+ </DropdownMenuContent>
35
+ </DropdownMenuPortal>
36
+ </template>
@@ -0,0 +1,15 @@
1
+ <script setup lang="ts">
2
+ import type { DropdownMenuGroupProps } from "reka-ui"
3
+ import { DropdownMenuGroup } from "reka-ui"
4
+
5
+ const props = defineProps<DropdownMenuGroupProps>()
6
+ </script>
7
+
8
+ <template>
9
+ <DropdownMenuGroup
10
+ data-slot="dropdown-menu-group"
11
+ v-bind="props"
12
+ >
13
+ <slot />
14
+ </DropdownMenuGroup>
15
+ </template>
@@ -0,0 +1,31 @@
1
+ <script setup lang="ts">
2
+ import type { DropdownMenuItemProps } from "reka-ui"
3
+ import type { HTMLAttributes } from "vue"
4
+ import { reactiveOmit } from "@vueuse/core"
5
+ import { DropdownMenuItem, useForwardProps } from "reka-ui"
6
+ import { cn } from "@/lib/utils"
7
+
8
+ const props = withDefaults(defineProps<DropdownMenuItemProps & {
9
+ class?: HTMLAttributes["class"]
10
+ inset?: boolean
11
+ variant?: "default" | "destructive"
12
+ }>(), {
13
+ variant: "default",
14
+ })
15
+
16
+ const delegatedProps = reactiveOmit(props, "inset", "variant", "class")
17
+
18
+ const forwardedProps = useForwardProps(delegatedProps)
19
+ </script>
20
+
21
+ <template>
22
+ <DropdownMenuItem
23
+ data-slot="dropdown-menu-item"
24
+ :data-inset="inset ? '' : undefined"
25
+ :data-variant="variant"
26
+ v-bind="forwardedProps"
27
+ :class="cn('focus:bg-accent focus:text-accent-foreground data-[variant=destructive]:text-destructive-foreground data-[variant=destructive]:focus:bg-destructive/10 dark:data-[variant=destructive]:focus:bg-destructive/40 data-[variant=destructive]:focus:text-destructive-foreground data-[variant=destructive]:*:[svg]:!text-destructive-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 data-[inset]:pl-8 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*=\'size-\'])]:size-4', props.class)"
28
+ >
29
+ <slot />
30
+ </DropdownMenuItem>
31
+ </template>
@@ -0,0 +1,23 @@
1
+ <script setup lang="ts">
2
+ import type { DropdownMenuLabelProps } from "reka-ui"
3
+ import type { HTMLAttributes } from "vue"
4
+ import { reactiveOmit } from "@vueuse/core"
5
+ import { DropdownMenuLabel, useForwardProps } from "reka-ui"
6
+ import { cn } from "@/lib/utils"
7
+
8
+ const props = defineProps<DropdownMenuLabelProps & { class?: HTMLAttributes["class"], inset?: boolean }>()
9
+
10
+ const delegatedProps = reactiveOmit(props, "class", "inset")
11
+ const forwardedProps = useForwardProps(delegatedProps)
12
+ </script>
13
+
14
+ <template>
15
+ <DropdownMenuLabel
16
+ data-slot="dropdown-menu-label"
17
+ :data-inset="inset ? '' : undefined"
18
+ v-bind="forwardedProps"
19
+ :class="cn('px-2 py-1.5 text-sm font-medium data-[inset]:pl-8', props.class)"
20
+ >
21
+ <slot />
22
+ </DropdownMenuLabel>
23
+ </template>
@@ -0,0 +1,22 @@
1
+ <script setup lang="ts">
2
+ import type { DropdownMenuRadioGroupEmits, DropdownMenuRadioGroupProps } from "reka-ui"
3
+ import {
4
+ DropdownMenuRadioGroup,
5
+
6
+ useForwardPropsEmits,
7
+ } from "reka-ui"
8
+
9
+ const props = defineProps<DropdownMenuRadioGroupProps>()
10
+ const emits = defineEmits<DropdownMenuRadioGroupEmits>()
11
+
12
+ const forwarded = useForwardPropsEmits(props, emits)
13
+ </script>
14
+
15
+ <template>
16
+ <DropdownMenuRadioGroup
17
+ data-slot="dropdown-menu-radio-group"
18
+ v-bind="forwarded"
19
+ >
20
+ <slot />
21
+ </DropdownMenuRadioGroup>
22
+ </template>
@@ -0,0 +1,39 @@
1
+ <script setup lang="ts">
2
+ import type { DropdownMenuRadioItemEmits, DropdownMenuRadioItemProps } from "reka-ui"
3
+ import type { HTMLAttributes } from "vue"
4
+ import { reactiveOmit } from "@vueuse/core"
5
+ import { Circle } from "lucide-vue-next"
6
+ import {
7
+ DropdownMenuItemIndicator,
8
+ DropdownMenuRadioItem,
9
+
10
+ useForwardPropsEmits,
11
+ } from "reka-ui"
12
+ import { cn } from "@/lib/utils"
13
+
14
+ const props = defineProps<DropdownMenuRadioItemProps & { class?: HTMLAttributes["class"] }>()
15
+
16
+ const emits = defineEmits<DropdownMenuRadioItemEmits>()
17
+
18
+ const delegatedProps = reactiveOmit(props, "class")
19
+
20
+ const forwarded = useForwardPropsEmits(delegatedProps, emits)
21
+ </script>
22
+
23
+ <template>
24
+ <DropdownMenuRadioItem
25
+ data-slot="dropdown-menu-radio-item"
26
+ v-bind="forwarded"
27
+ :class="cn(
28
+ 'focus:bg-accent focus:text-accent-foreground relative flex cursor-default items-center gap-2 rounded-sm py-1.5 pr-2 pl-8 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',
29
+ props.class,
30
+ )"
31
+ >
32
+ <span class="pointer-events-none absolute left-2 flex size-3.5 items-center justify-center">
33
+ <DropdownMenuItemIndicator>
34
+ <Circle class="size-2 fill-current" />
35
+ </DropdownMenuItemIndicator>
36
+ </span>
37
+ <slot />
38
+ </DropdownMenuRadioItem>
39
+ </template>
@@ -0,0 +1,24 @@
1
+ <script setup lang="ts">
2
+ import type { DropdownMenuSeparatorProps } from "reka-ui"
3
+ import type { HTMLAttributes } from "vue"
4
+ import { reactiveOmit } from "@vueuse/core"
5
+ import {
6
+ DropdownMenuSeparator,
7
+
8
+ } from "reka-ui"
9
+ import { cn } from "@/lib/utils"
10
+
11
+ const props = defineProps<DropdownMenuSeparatorProps & {
12
+ class?: HTMLAttributes["class"]
13
+ }>()
14
+
15
+ const delegatedProps = reactiveOmit(props, "class")
16
+ </script>
17
+
18
+ <template>
19
+ <DropdownMenuSeparator
20
+ data-slot="dropdown-menu-separator"
21
+ v-bind="delegatedProps"
22
+ :class="cn('bg-border -mx-1 my-1 h-px', props.class)"
23
+ />
24
+ </template>
@@ -0,0 +1,17 @@
1
+ <script setup lang="ts">
2
+ import type { HTMLAttributes } from "vue"
3
+ import { cn } from "@/lib/utils"
4
+
5
+ const props = defineProps<{
6
+ class?: HTMLAttributes["class"]
7
+ }>()
8
+ </script>
9
+
10
+ <template>
11
+ <span
12
+ data-slot="dropdown-menu-shortcut"
13
+ :class="cn('text-muted-foreground ml-auto text-xs tracking-widest', props.class)"
14
+ >
15
+ <slot />
16
+ </span>
17
+ </template>
@@ -0,0 +1,19 @@
1
+ <script setup lang="ts">
2
+ import type { DropdownMenuSubEmits, DropdownMenuSubProps } from "reka-ui"
3
+ import {
4
+ DropdownMenuSub,
5
+
6
+ useForwardPropsEmits,
7
+ } from "reka-ui"
8
+
9
+ const props = defineProps<DropdownMenuSubProps>()
10
+ const emits = defineEmits<DropdownMenuSubEmits>()
11
+
12
+ const forwarded = useForwardPropsEmits(props, emits)
13
+ </script>
14
+
15
+ <template>
16
+ <DropdownMenuSub data-slot="dropdown-menu-sub" v-bind="forwarded">
17
+ <slot />
18
+ </DropdownMenuSub>
19
+ </template>
@@ -0,0 +1,28 @@
1
+ <script setup lang="ts">
2
+ import type { DropdownMenuSubContentEmits, DropdownMenuSubContentProps } from "reka-ui"
3
+ import type { HTMLAttributes } from "vue"
4
+ import { reactiveOmit } from "@vueuse/core"
5
+ import {
6
+ DropdownMenuSubContent,
7
+
8
+ useForwardPropsEmits,
9
+ } from "reka-ui"
10
+ import { cn } from "@/lib/utils"
11
+
12
+ const props = defineProps<DropdownMenuSubContentProps & { class?: HTMLAttributes["class"] }>()
13
+ const emits = defineEmits<DropdownMenuSubContentEmits>()
14
+
15
+ const delegatedProps = reactiveOmit(props, "class")
16
+
17
+ const forwarded = useForwardPropsEmits(delegatedProps, emits)
18
+ </script>
19
+
20
+ <template>
21
+ <DropdownMenuSubContent
22
+ data-slot="dropdown-menu-sub-content"
23
+ v-bind="forwarded"
24
+ :class="cn('bg-popover text-popover-foreground data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 z-50 min-w-[8rem] origin-(--reka-dropdown-menu-content-transform-origin) overflow-hidden rounded-md border p-1 shadow-lg', props.class)"
25
+ >
26
+ <slot />
27
+ </DropdownMenuSubContent>
28
+ </template>
@@ -0,0 +1,31 @@
1
+ <script setup lang="ts">
2
+ import type { DropdownMenuSubTriggerProps } from "reka-ui"
3
+ import type { HTMLAttributes } from "vue"
4
+ import { reactiveOmit } from "@vueuse/core"
5
+ import { ChevronRight } from "lucide-vue-next"
6
+ import {
7
+ DropdownMenuSubTrigger,
8
+
9
+ useForwardProps,
10
+ } from "reka-ui"
11
+ import { cn } from "@/lib/utils"
12
+
13
+ const props = defineProps<DropdownMenuSubTriggerProps & { class?: HTMLAttributes["class"], inset?: boolean }>()
14
+
15
+ const delegatedProps = reactiveOmit(props, "class", "inset")
16
+ const forwardedProps = useForwardProps(delegatedProps)
17
+ </script>
18
+
19
+ <template>
20
+ <DropdownMenuSubTrigger
21
+ data-slot="dropdown-menu-sub-trigger"
22
+ v-bind="forwardedProps"
23
+ :class="cn(
24
+ 'focus:bg-accent focus:text-accent-foreground data-[state=open]:bg-accent data-[state=open]:text-accent-foreground flex cursor-default items-center rounded-sm px-2 py-1.5 text-sm outline-hidden select-none data-[inset]:pl-8',
25
+ props.class,
26
+ )"
27
+ >
28
+ <slot />
29
+ <ChevronRight class="ml-auto size-4" />
30
+ </DropdownMenuSubTrigger>
31
+ </template>
@@ -0,0 +1,17 @@
1
+ <script setup lang="ts">
2
+ import type { DropdownMenuTriggerProps } from "reka-ui"
3
+ import { DropdownMenuTrigger, useForwardProps } from "reka-ui"
4
+
5
+ const props = defineProps<DropdownMenuTriggerProps>()
6
+
7
+ const forwardedProps = useForwardProps(props)
8
+ </script>
9
+
10
+ <template>
11
+ <DropdownMenuTrigger
12
+ data-slot="dropdown-menu-trigger"
13
+ v-bind="forwardedProps"
14
+ >
15
+ <slot />
16
+ </DropdownMenuTrigger>
17
+ </template>
@@ -0,0 +1,16 @@
1
+ export { default as DropdownMenu } from "./DropdownMenu.vue"
2
+
3
+ export { default as DropdownMenuCheckboxItem } from "./DropdownMenuCheckboxItem.vue"
4
+ export { default as DropdownMenuContent } from "./DropdownMenuContent.vue"
5
+ export { default as DropdownMenuGroup } from "./DropdownMenuGroup.vue"
6
+ export { default as DropdownMenuItem } from "./DropdownMenuItem.vue"
7
+ export { default as DropdownMenuLabel } from "./DropdownMenuLabel.vue"
8
+ export { default as DropdownMenuRadioGroup } from "./DropdownMenuRadioGroup.vue"
9
+ export { default as DropdownMenuRadioItem } from "./DropdownMenuRadioItem.vue"
10
+ export { default as DropdownMenuSeparator } from "./DropdownMenuSeparator.vue"
11
+ export { default as DropdownMenuShortcut } from "./DropdownMenuShortcut.vue"
12
+ export { default as DropdownMenuSub } from "./DropdownMenuSub.vue"
13
+ export { default as DropdownMenuSubContent } from "./DropdownMenuSubContent.vue"
14
+ export { default as DropdownMenuSubTrigger } from "./DropdownMenuSubTrigger.vue"
15
+ export { default as DropdownMenuTrigger } from "./DropdownMenuTrigger.vue"
16
+ export { DropdownMenuPortal } from "reka-ui"
@@ -0,0 +1,33 @@
1
+ <script setup lang="ts">
2
+ import type { MenubarRootEmits, MenubarRootProps } from "reka-ui"
3
+ import type { HTMLAttributes } from "vue"
4
+ import { reactiveOmit } from "@vueuse/core"
5
+ import {
6
+ MenubarRoot,
7
+
8
+ useForwardPropsEmits,
9
+ } from "reka-ui"
10
+ import { cn } from "@/lib/utils"
11
+
12
+ const props = defineProps<MenubarRootProps & { class?: HTMLAttributes["class"] }>()
13
+ const emits = defineEmits<MenubarRootEmits>()
14
+
15
+ const delegatedProps = reactiveOmit(props, "class")
16
+
17
+ const forwarded = useForwardPropsEmits(delegatedProps, emits)
18
+ </script>
19
+
20
+ <template>
21
+ <MenubarRoot
22
+ data-slot="menubar"
23
+ v-bind="forwarded"
24
+ :class="
25
+ cn(
26
+ 'bg-background flex h-9 items-center gap-1 rounded-md border p-1 shadow-xs',
27
+ props.class,
28
+ )
29
+ "
30
+ >
31
+ <slot />
32
+ </MenubarRoot>
33
+ </template>
@@ -0,0 +1,38 @@
1
+ <script setup lang="ts">
2
+ import type { MenubarCheckboxItemEmits, MenubarCheckboxItemProps } from "reka-ui"
3
+ import type { HTMLAttributes } from "vue"
4
+ import { reactiveOmit } from "@vueuse/core"
5
+ import { Check } from "lucide-vue-next"
6
+ import {
7
+ MenubarCheckboxItem,
8
+
9
+ MenubarItemIndicator,
10
+ useForwardPropsEmits,
11
+ } from "reka-ui"
12
+ import { cn } from "@/lib/utils"
13
+
14
+ const props = defineProps<MenubarCheckboxItemProps & { class?: HTMLAttributes["class"] }>()
15
+ const emits = defineEmits<MenubarCheckboxItemEmits>()
16
+
17
+ const delegatedProps = reactiveOmit(props, "class")
18
+
19
+ const forwarded = useForwardPropsEmits(delegatedProps, emits)
20
+ </script>
21
+
22
+ <template>
23
+ <MenubarCheckboxItem
24
+ data-slot="menubar-checkbox-item"
25
+ v-bind="forwarded"
26
+ :class="cn(
27
+ 'focus:bg-accent focus:text-accent-foreground relative flex cursor-default items-center gap-2 rounded-xs py-1.5 pr-2 pl-8 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',
28
+ props.class,
29
+ )"
30
+ >
31
+ <span class="pointer-events-none absolute left-2 flex size-3.5 items-center justify-center">
32
+ <MenubarItemIndicator>
33
+ <Check class="size-4" />
34
+ </MenubarItemIndicator>
35
+ </span>
36
+ <slot />
37
+ </MenubarCheckboxItem>
38
+ </template>
@@ -0,0 +1,42 @@
1
+ <script setup lang="ts">
2
+ import type { MenubarContentProps } from "reka-ui"
3
+ import type { HTMLAttributes } from "vue"
4
+ import { reactiveOmit } from "@vueuse/core"
5
+ import {
6
+ MenubarContent,
7
+
8
+ MenubarPortal,
9
+ useForwardProps,
10
+ } from "reka-ui"
11
+ import { cn } from "@/lib/utils"
12
+
13
+ const props = withDefaults(
14
+ defineProps<MenubarContentProps & { class?: HTMLAttributes["class"] }>(),
15
+ {
16
+ align: "start",
17
+ alignOffset: -4,
18
+ sideOffset: 8,
19
+ },
20
+ )
21
+
22
+ const delegatedProps = reactiveOmit(props, "class")
23
+
24
+ const forwardedProps = useForwardProps(delegatedProps)
25
+ </script>
26
+
27
+ <template>
28
+ <MenubarPortal>
29
+ <MenubarContent
30
+ data-slot="menubar-content"
31
+ v-bind="forwardedProps"
32
+ :class="
33
+ cn(
34
+ 'bg-popover text-popover-foreground data-[state=open]:animate-in data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 z-50 min-w-[12rem] origin-(--reka-menubar-content-transform-origin) overflow-hidden rounded-md border p-1 shadow-md',
35
+ props.class,
36
+ )
37
+ "
38
+ >
39
+ <slot />
40
+ </MenubarContent>
41
+ </MenubarPortal>
42
+ </template>
@@ -0,0 +1,15 @@
1
+ <script setup lang="ts">
2
+ import type { MenubarGroupProps } from "reka-ui"
3
+ import { MenubarGroup } from "reka-ui"
4
+
5
+ const props = defineProps<MenubarGroupProps>()
6
+ </script>
7
+
8
+ <template>
9
+ <MenubarGroup
10
+ data-slot="menubar-group"
11
+ v-bind="props"
12
+ >
13
+ <slot />
14
+ </MenubarGroup>
15
+ </template>