@voyantjs/ui 0.6.7

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 (262) hide show
  1. package/README.md +30 -0
  2. package/dist/components/accordion.d.ts +7 -0
  3. package/dist/components/accordion.d.ts.map +1 -0
  4. package/dist/components/accordion.js +17 -0
  5. package/dist/components/alert-dialog.d.ts +19 -0
  6. package/dist/components/alert-dialog.d.ts.map +1 -0
  7. package/dist/components/alert-dialog.js +42 -0
  8. package/dist/components/alert.d.ts +11 -0
  9. package/dist/components/alert.d.ts.map +1 -0
  10. package/dist/components/alert.js +27 -0
  11. package/dist/components/aspect-ratio.d.ts +5 -0
  12. package/dist/components/aspect-ratio.d.ts.map +1 -0
  13. package/dist/components/aspect-ratio.js +8 -0
  14. package/dist/components/avatar.d.ts +12 -0
  15. package/dist/components/avatar.d.ts.map +1 -0
  16. package/dist/components/avatar.js +22 -0
  17. package/dist/components/badge.d.ts +8 -0
  18. package/dist/components/badge.d.ts.map +1 -0
  19. package/dist/components/badge.js +33 -0
  20. package/dist/components/breadcrumb.d.ts +11 -0
  21. package/dist/components/breadcrumb.d.ts.map +1 -0
  22. package/dist/components/breadcrumb.js +36 -0
  23. package/dist/components/button-group.d.ts +11 -0
  24. package/dist/components/button-group.d.ts.map +1 -0
  25. package/dist/components/button-group.js +36 -0
  26. package/dist/components/button.d.ts +9 -0
  27. package/dist/components/button.d.ts.map +1 -0
  28. package/dist/components/button.js +34 -0
  29. package/dist/components/calendar.d.ts +11 -0
  30. package/dist/components/calendar.d.ts.map +1 -0
  31. package/dist/components/calendar.js +76 -0
  32. package/dist/components/card.d.ts +12 -0
  33. package/dist/components/card.d.ts.map +1 -0
  34. package/dist/components/card.js +24 -0
  35. package/dist/components/carousel.d.ts +29 -0
  36. package/dist/components/carousel.d.ts.map +1 -0
  37. package/dist/components/carousel.js +91 -0
  38. package/dist/components/chart.d.ts +45 -0
  39. package/dist/components/chart.d.ts.map +1 -0
  40. package/dist/components/chart.js +121 -0
  41. package/dist/components/checkbox.d.ts +4 -0
  42. package/dist/components/checkbox.d.ts.map +1 -0
  43. package/dist/components/checkbox.js +8 -0
  44. package/dist/components/collapsible.d.ts +6 -0
  45. package/dist/components/collapsible.d.ts.map +1 -0
  46. package/dist/components/collapsible.js +12 -0
  47. package/dist/components/combobox.d.ts +25 -0
  48. package/dist/components/combobox.d.ts.map +1 -0
  49. package/dist/components/combobox.js +57 -0
  50. package/dist/components/command.d.ts +20 -0
  51. package/dist/components/command.d.ts.map +1 -0
  52. package/dist/components/command.js +35 -0
  53. package/dist/components/confirm-action-button.d.ts +14 -0
  54. package/dist/components/confirm-action-button.d.ts.map +1 -0
  55. package/dist/components/confirm-action-button.js +21 -0
  56. package/dist/components/context-menu.d.ts +30 -0
  57. package/dist/components/context-menu.d.ts.map +1 -0
  58. package/dist/components/context-menu.js +50 -0
  59. package/dist/components/contract-template-authoring-help.d.ts +32 -0
  60. package/dist/components/contract-template-authoring-help.d.ts.map +1 -0
  61. package/dist/components/contract-template-authoring-help.js +37 -0
  62. package/dist/components/country-combobox.d.ts +9 -0
  63. package/dist/components/country-combobox.d.ts.map +1 -0
  64. package/dist/components/country-combobox.js +47 -0
  65. package/dist/components/currency-combobox.d.ts +14 -0
  66. package/dist/components/currency-combobox.d.ts.map +1 -0
  67. package/dist/components/currency-combobox.js +53 -0
  68. package/dist/components/dashboard-widgets.d.ts +66 -0
  69. package/dist/components/dashboard-widgets.d.ts.map +1 -0
  70. package/dist/components/dashboard-widgets.js +64 -0
  71. package/dist/components/data-table-column-header.d.ts +9 -0
  72. package/dist/components/data-table-column-header.d.ts.map +1 -0
  73. package/dist/components/data-table-column-header.js +12 -0
  74. package/dist/components/data-table-pagination.d.ts +7 -0
  75. package/dist/components/data-table-pagination.d.ts.map +1 -0
  76. package/dist/components/data-table-pagination.js +11 -0
  77. package/dist/components/data-table.d.ts +22 -0
  78. package/dist/components/data-table.d.ts.map +1 -0
  79. package/dist/components/data-table.js +55 -0
  80. package/dist/components/date-picker.d.ts +38 -0
  81. package/dist/components/date-picker.d.ts.map +1 -0
  82. package/dist/components/date-picker.js +120 -0
  83. package/dist/components/date-time-picker.d.ts +30 -0
  84. package/dist/components/date-time-picker.d.ts.map +1 -0
  85. package/dist/components/date-time-picker.js +75 -0
  86. package/dist/components/dialog.d.ts +18 -0
  87. package/dist/components/dialog.d.ts.map +1 -0
  88. package/dist/components/dialog.js +37 -0
  89. package/dist/components/direction.d.ts +2 -0
  90. package/dist/components/direction.d.ts.map +1 -0
  91. package/dist/components/direction.js +1 -0
  92. package/dist/components/drawer.d.ts +14 -0
  93. package/dist/components/drawer.d.ts.map +1 -0
  94. package/dist/components/drawer.js +34 -0
  95. package/dist/components/dropdown-menu.d.ts +30 -0
  96. package/dist/components/dropdown-menu.d.ts.map +1 -0
  97. package/dist/components/dropdown-menu.js +50 -0
  98. package/dist/components/empty.d.ts +12 -0
  99. package/dist/components/empty.d.ts.map +1 -0
  100. package/dist/components/empty.js +33 -0
  101. package/dist/components/field.d.ts +25 -0
  102. package/dist/components/field.d.ts.map +1 -0
  103. package/dist/components/field.js +65 -0
  104. package/dist/components/hover-card.d.ts +6 -0
  105. package/dist/components/hover-card.d.ts.map +1 -0
  106. package/dist/components/hover-card.js +13 -0
  107. package/dist/components/index.d.ts +86 -0
  108. package/dist/components/index.d.ts.map +1 -0
  109. package/dist/components/index.js +85 -0
  110. package/dist/components/input-group.d.ts +19 -0
  111. package/dist/components/input-group.d.ts.map +1 -0
  112. package/dist/components/input-group.js +73 -0
  113. package/dist/components/input-otp.d.ts +12 -0
  114. package/dist/components/input-otp.d.ts.map +1 -0
  115. package/dist/components/input-otp.js +20 -0
  116. package/dist/components/input.d.ts +4 -0
  117. package/dist/components/input.d.ts.map +1 -0
  118. package/dist/components/input.js +7 -0
  119. package/dist/components/item.d.ts +23 -0
  120. package/dist/components/item.d.ts.map +1 -0
  121. package/dist/components/item.js +78 -0
  122. package/dist/components/kbd.d.ts +4 -0
  123. package/dist/components/kbd.d.ts.map +1 -0
  124. package/dist/components/kbd.js +9 -0
  125. package/dist/components/label.d.ts +4 -0
  126. package/dist/components/label.d.ts.map +1 -0
  127. package/dist/components/label.js +8 -0
  128. package/dist/components/menubar.d.ts +30 -0
  129. package/dist/components/menubar.d.ts.map +1 -0
  130. package/dist/components/menubar.js +56 -0
  131. package/dist/components/native-select.d.ts +9 -0
  132. package/dist/components/native-select.d.ts.map +1 -0
  133. package/dist/components/native-select.js +13 -0
  134. package/dist/components/navigation-menu.d.ts +12 -0
  135. package/dist/components/navigation-menu.d.ts.map +1 -0
  136. package/dist/components/navigation-menu.js +31 -0
  137. package/dist/components/notification-deliveries-page.d.ts +2 -0
  138. package/dist/components/notification-deliveries-page.d.ts.map +1 -0
  139. package/dist/components/notification-deliveries-page.js +22 -0
  140. package/dist/components/notification-delivery-detail-dialog.d.ts +8 -0
  141. package/dist/components/notification-delivery-detail-dialog.d.ts.map +1 -0
  142. package/dist/components/notification-delivery-detail-dialog.js +29 -0
  143. package/dist/components/notification-reminder-rule-dialog.d.ts +10 -0
  144. package/dist/components/notification-reminder-rule-dialog.d.ts.map +1 -0
  145. package/dist/components/notification-reminder-rule-dialog.js +123 -0
  146. package/dist/components/notification-reminder-rules-page.d.ts +2 -0
  147. package/dist/components/notification-reminder-rules-page.d.ts.map +1 -0
  148. package/dist/components/notification-reminder-rules-page.js +35 -0
  149. package/dist/components/notification-reminder-runs-page.d.ts +2 -0
  150. package/dist/components/notification-reminder-runs-page.d.ts.map +1 -0
  151. package/dist/components/notification-reminder-runs-page.js +20 -0
  152. package/dist/components/notification-template-authoring-help.d.ts +11 -0
  153. package/dist/components/notification-template-authoring-help.d.ts.map +1 -0
  154. package/dist/components/notification-template-authoring-help.js +6 -0
  155. package/dist/components/notification-template-detail-page.d.ts +6 -0
  156. package/dist/components/notification-template-detail-page.d.ts.map +1 -0
  157. package/dist/components/notification-template-detail-page.js +145 -0
  158. package/dist/components/notification-template-dialog.d.ts +10 -0
  159. package/dist/components/notification-template-dialog.d.ts.map +1 -0
  160. package/dist/components/notification-template-dialog.js +296 -0
  161. package/dist/components/notification-templates-page.d.ts +2 -0
  162. package/dist/components/notification-templates-page.d.ts.map +1 -0
  163. package/dist/components/notification-templates-page.js +33 -0
  164. package/dist/components/overview-metric.d.ts +12 -0
  165. package/dist/components/overview-metric.d.ts.map +1 -0
  166. package/dist/components/overview-metric.js +6 -0
  167. package/dist/components/pagination.d.ts +18 -0
  168. package/dist/components/pagination.d.ts.map +1 -0
  169. package/dist/components/pagination.js +26 -0
  170. package/dist/components/popover.d.ts +10 -0
  171. package/dist/components/popover.d.ts.map +1 -0
  172. package/dist/components/popover.js +22 -0
  173. package/dist/components/progress.d.ts +8 -0
  174. package/dist/components/progress.d.ts.map +1 -0
  175. package/dist/components/progress.js +19 -0
  176. package/dist/components/radio-group.d.ts +6 -0
  177. package/dist/components/radio-group.d.ts.map +1 -0
  178. package/dist/components/radio-group.js +11 -0
  179. package/dist/components/resizable.d.ts +8 -0
  180. package/dist/components/resizable.d.ts.map +1 -0
  181. package/dist/components/resizable.js +13 -0
  182. package/dist/components/rich-text-editor.d.ts +13 -0
  183. package/dist/components/rich-text-editor.d.ts.map +1 -0
  184. package/dist/components/rich-text-editor.js +71 -0
  185. package/dist/components/rich-text-variable-extension.d.ts +6 -0
  186. package/dist/components/rich-text-variable-extension.d.ts.map +1 -0
  187. package/dist/components/rich-text-variable-extension.js +117 -0
  188. package/dist/components/scroll-area.d.ts +5 -0
  189. package/dist/components/scroll-area.d.ts.map +1 -0
  190. package/dist/components/scroll-area.js +10 -0
  191. package/dist/components/select.d.ts +16 -0
  192. package/dist/components/select.d.ts.map +1 -0
  193. package/dist/components/select.js +33 -0
  194. package/dist/components/selection-action-bar.d.ts +8 -0
  195. package/dist/components/selection-action-bar.d.ts.map +1 -0
  196. package/dist/components/selection-action-bar.js +7 -0
  197. package/dist/components/separator.d.ts +4 -0
  198. package/dist/components/separator.d.ts.map +1 -0
  199. package/dist/components/separator.js +7 -0
  200. package/dist/components/sheet.d.ts +15 -0
  201. package/dist/components/sheet.d.ts.map +1 -0
  202. package/dist/components/sheet.js +37 -0
  203. package/dist/components/sidebar-core.d.ts +34 -0
  204. package/dist/components/sidebar-core.d.ts.map +1 -0
  205. package/dist/components/sidebar-core.js +112 -0
  206. package/dist/components/sidebar-menu.d.ts +33 -0
  207. package/dist/components/sidebar-menu.d.ts.map +1 -0
  208. package/dist/components/sidebar-menu.js +128 -0
  209. package/dist/components/sidebar.d.ts +3 -0
  210. package/dist/components/sidebar.d.ts.map +1 -0
  211. package/dist/components/sidebar.js +2 -0
  212. package/dist/components/skeleton.d.ts +7 -0
  213. package/dist/components/skeleton.d.ts.map +1 -0
  214. package/dist/components/skeleton.js +6 -0
  215. package/dist/components/slider.d.ts +4 -0
  216. package/dist/components/slider.d.ts.map +1 -0
  217. package/dist/components/slider.js +9 -0
  218. package/dist/components/sonner.d.ts +4 -0
  219. package/dist/components/sonner.d.ts.map +1 -0
  220. package/dist/components/sonner.js +24 -0
  221. package/dist/components/spinner.d.ts +3 -0
  222. package/dist/components/spinner.d.ts.map +1 -0
  223. package/dist/components/spinner.js +7 -0
  224. package/dist/components/switch.d.ts +6 -0
  225. package/dist/components/switch.d.ts.map +1 -0
  226. package/dist/components/switch.js +7 -0
  227. package/dist/components/table.d.ts +11 -0
  228. package/dist/components/table.d.ts.map +1 -0
  229. package/dist/components/table.js +27 -0
  230. package/dist/components/tabs.d.ts +11 -0
  231. package/dist/components/tabs.d.ts.map +1 -0
  232. package/dist/components/tabs.js +28 -0
  233. package/dist/components/textarea.d.ts +4 -0
  234. package/dist/components/textarea.d.ts.map +1 -0
  235. package/dist/components/textarea.js +6 -0
  236. package/dist/components/toggle-group.d.ts +11 -0
  237. package/dist/components/toggle-group.d.ts.map +1 -0
  238. package/dist/components/toggle-group.js +24 -0
  239. package/dist/components/toggle.d.ts +9 -0
  240. package/dist/components/toggle.d.ts.map +1 -0
  241. package/dist/components/toggle.js +25 -0
  242. package/dist/components/tooltip.d.ts +7 -0
  243. package/dist/components/tooltip.d.ts.map +1 -0
  244. package/dist/components/tooltip.js +16 -0
  245. package/dist/components/typography.d.ts +18 -0
  246. package/dist/components/typography.d.ts.map +1 -0
  247. package/dist/components/typography.js +48 -0
  248. package/dist/hooks/use-mobile.d.ts +2 -0
  249. package/dist/hooks/use-mobile.d.ts.map +1 -0
  250. package/dist/hooks/use-mobile.js +15 -0
  251. package/dist/lib/crop-image.d.ts +4 -0
  252. package/dist/lib/crop-image.d.ts.map +1 -0
  253. package/dist/lib/crop-image.js +30 -0
  254. package/dist/lib/utils.d.ts +3 -0
  255. package/dist/lib/utils.d.ts.map +1 -0
  256. package/dist/lib/utils.js +5 -0
  257. package/dist/lib/zod-resolver.d.ts +4 -0
  258. package/dist/lib/zod-resolver.d.ts.map +1 -0
  259. package/dist/lib/zod-resolver.js +39 -0
  260. package/package.json +108 -0
  261. package/postcss.config.mjs +6 -0
  262. package/src/styles/globals.css +157 -0
@@ -0,0 +1,112 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { PanelLeftIcon } from "lucide-react";
3
+ import * as React from "react";
4
+ import { useIsMobile } from "../hooks/use-mobile";
5
+ import { cn } from "../lib/utils";
6
+ import { Button } from "./button";
7
+ import { Input } from "./input";
8
+ import { Separator } from "./separator";
9
+ import { Sheet, SheetContent, SheetDescription, SheetHeader, SheetTitle } from "./sheet";
10
+ const SIDEBAR_COOKIE_NAME = "sidebar_state";
11
+ const SIDEBAR_COOKIE_MAX_AGE = 60 * 60 * 24 * 7;
12
+ const SIDEBAR_WIDTH = "16rem";
13
+ const SIDEBAR_WIDTH_MOBILE = "18rem";
14
+ const SIDEBAR_WIDTH_ICON = "3rem";
15
+ const SIDEBAR_KEYBOARD_SHORTCUT = "b";
16
+ const SidebarContext = React.createContext(null);
17
+ function useSidebar() {
18
+ const context = React.useContext(SidebarContext);
19
+ if (!context) {
20
+ throw new Error("useSidebar must be used within a SidebarProvider.");
21
+ }
22
+ return context;
23
+ }
24
+ function SidebarProvider({ defaultOpen = true, open: openProp, onOpenChange: setOpenProp, className, style, children, ...props }) {
25
+ const isMobile = useIsMobile();
26
+ const [openMobile, setOpenMobile] = React.useState(false);
27
+ const [_open, _setOpen] = React.useState(defaultOpen);
28
+ const open = openProp ?? _open;
29
+ const setOpen = React.useCallback((value) => {
30
+ const openState = typeof value === "function" ? value(open) : value;
31
+ if (setOpenProp) {
32
+ setOpenProp(openState);
33
+ }
34
+ else {
35
+ _setOpen(openState);
36
+ }
37
+ // biome-ignore lint/suspicious/noDocumentCookie: Sidebar state cookie needs broad browser support beyond the Cookie Store API.
38
+ document.cookie = `${SIDEBAR_COOKIE_NAME}=${openState}; path=/; max-age=${SIDEBAR_COOKIE_MAX_AGE}`;
39
+ }, [setOpenProp, open]);
40
+ const toggleSidebar = React.useCallback(() => {
41
+ return isMobile ? setOpenMobile((value) => !value) : setOpen((value) => !value);
42
+ }, [isMobile, setOpen]);
43
+ React.useEffect(() => {
44
+ const handleKeyDown = (event) => {
45
+ if (event.key === SIDEBAR_KEYBOARD_SHORTCUT && (event.metaKey || event.ctrlKey)) {
46
+ event.preventDefault();
47
+ toggleSidebar();
48
+ }
49
+ };
50
+ window.addEventListener("keydown", handleKeyDown);
51
+ return () => window.removeEventListener("keydown", handleKeyDown);
52
+ }, [toggleSidebar]);
53
+ const state = open ? "expanded" : "collapsed";
54
+ const contextValue = React.useMemo(() => ({
55
+ state,
56
+ open,
57
+ setOpen,
58
+ isMobile,
59
+ openMobile,
60
+ setOpenMobile,
61
+ toggleSidebar,
62
+ }), [state, open, setOpen, isMobile, openMobile, toggleSidebar]);
63
+ return (_jsx(SidebarContext.Provider, { value: contextValue, children: _jsx("div", { "data-slot": "sidebar-wrapper", style: {
64
+ "--sidebar-width": SIDEBAR_WIDTH,
65
+ "--sidebar-width-icon": SIDEBAR_WIDTH_ICON,
66
+ ...style,
67
+ }, className: cn("group/sidebar-wrapper flex min-h-svh w-full has-data-[variant=inset]:bg-sidebar", className), ...props, children: children }) }));
68
+ }
69
+ function Sidebar({ side = "left", variant = "sidebar", collapsible = "offcanvas", className, children, dir, ...props }) {
70
+ const { isMobile, state, openMobile, setOpenMobile } = useSidebar();
71
+ if (collapsible === "none") {
72
+ return (_jsx("div", { "data-slot": "sidebar", className: cn("flex h-full w-(--sidebar-width) flex-col bg-sidebar text-sidebar-foreground", className), ...props, children: children }));
73
+ }
74
+ if (isMobile) {
75
+ return (_jsx(Sheet, { open: openMobile, onOpenChange: setOpenMobile, ...props, children: _jsxs(SheetContent, { dir: dir, "data-sidebar": "sidebar", "data-slot": "sidebar", "data-mobile": "true", className: "w-(--sidebar-width) bg-sidebar p-0 text-sidebar-foreground [&>button]:hidden", style: { "--sidebar-width": SIDEBAR_WIDTH_MOBILE }, side: side, children: [_jsxs(SheetHeader, { className: "sr-only", children: [_jsx(SheetTitle, { children: "Sidebar" }), _jsx(SheetDescription, { children: "Displays the mobile sidebar." })] }), _jsx("div", { className: "flex h-full w-full flex-col", children: children })] }) }));
76
+ }
77
+ return (_jsxs("div", { className: "group peer hidden text-sidebar-foreground md:block", "data-state": state, "data-collapsible": state === "collapsed" ? collapsible : "", "data-variant": variant, "data-side": side, "data-slot": "sidebar", children: [_jsx("div", { "data-slot": "sidebar-gap", className: cn("relative w-(--sidebar-width) bg-transparent transition-[width] duration-200 ease-linear", "group-data-[collapsible=offcanvas]:w-0", "group-data-[side=right]:rotate-180", variant === "floating" || variant === "inset"
78
+ ? "group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)+(--spacing(4)))]"
79
+ : "group-data-[collapsible=icon]:w-(--sidebar-width-icon)") }), _jsx("div", { "data-slot": "sidebar-container", "data-side": side, className: cn("fixed inset-y-0 z-10 hidden h-svh w-(--sidebar-width) transition-[left,right,width] duration-200 ease-linear data-[side=left]:left-0 data-[side=left]:group-data-[collapsible=offcanvas]:left-[calc(var(--sidebar-width)*-1)] data-[side=right]:right-0 data-[side=right]:group-data-[collapsible=offcanvas]:right-[calc(var(--sidebar-width)*-1)] md:flex", variant === "floating" || variant === "inset"
80
+ ? "p-2 group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)+(--spacing(4))+2px)]"
81
+ : "group-data-[collapsible=icon]:w-(--sidebar-width-icon) group-data-[side=left]:border-r group-data-[side=right]:border-l", className), ...props, children: _jsx("div", { "data-sidebar": "sidebar", "data-slot": "sidebar-inner", className: "flex size-full flex-col bg-sidebar group-data-[variant=floating]:rounded-lg group-data-[variant=floating]:shadow-sm group-data-[variant=floating]:ring-1 group-data-[variant=floating]:ring-sidebar-border", children: children }) })] }));
82
+ }
83
+ function SidebarTrigger({ className, onClick, ...props }) {
84
+ const { toggleSidebar } = useSidebar();
85
+ return (_jsxs(Button, { "data-sidebar": "trigger", "data-slot": "sidebar-trigger", variant: "ghost", size: "icon-sm", className: cn(className), onClick: (event) => {
86
+ onClick?.(event);
87
+ toggleSidebar();
88
+ }, ...props, children: [_jsx(PanelLeftIcon, {}), _jsx("span", { className: "sr-only", children: "Toggle Sidebar" })] }));
89
+ }
90
+ function SidebarRail({ className, ...props }) {
91
+ const { toggleSidebar } = useSidebar();
92
+ return (_jsx("button", { "data-sidebar": "rail", "data-slot": "sidebar-rail", "aria-label": "Toggle Sidebar", tabIndex: -1, onClick: toggleSidebar, title: "Toggle Sidebar", className: cn("absolute inset-y-0 z-20 hidden w-4 transition-all ease-linear group-data-[side=left]:-right-4 group-data-[side=right]:left-0 after:absolute after:inset-y-0 after:start-1/2 after:w-[2px] hover:after:bg-sidebar-border sm:flex ltr:-translate-x-1/2 rtl:-translate-x-1/2", "in-data-[side=left]:cursor-w-resize in-data-[side=right]:cursor-e-resize", "[[data-side=left][data-state=collapsed]_&]:cursor-e-resize [[data-side=right][data-state=collapsed]_&]:cursor-w-resize", "group-data-[collapsible=offcanvas]:translate-x-0 group-data-[collapsible=offcanvas]:after:left-full hover:group-data-[collapsible=offcanvas]:bg-sidebar", "[[data-side=left][data-collapsible=offcanvas]_&]:-right-2", "[[data-side=right][data-collapsible=offcanvas]_&]:-left-2", className), ...props }));
93
+ }
94
+ function SidebarInset({ className, ...props }) {
95
+ return (_jsx("main", { "data-slot": "sidebar-inset", className: cn("relative flex w-full flex-1 flex-col bg-background md:peer-data-[variant=inset]:m-2 md:peer-data-[variant=inset]:ml-0 md:peer-data-[variant=inset]:rounded-xl md:peer-data-[variant=inset]:shadow-sm md:peer-data-[variant=inset]:peer-data-[state=collapsed]:ml-2", className), ...props }));
96
+ }
97
+ function SidebarInput({ className, ...props }) {
98
+ return (_jsx(Input, { "data-slot": "sidebar-input", "data-sidebar": "input", className: cn("h-8 w-full bg-background shadow-none", className), ...props }));
99
+ }
100
+ function SidebarHeader({ className, ...props }) {
101
+ return (_jsx("div", { "data-slot": "sidebar-header", "data-sidebar": "header", className: cn("flex flex-col gap-2 p-2", className), ...props }));
102
+ }
103
+ function SidebarFooter({ className, ...props }) {
104
+ return (_jsx("div", { "data-slot": "sidebar-footer", "data-sidebar": "footer", className: cn("flex flex-col gap-2 p-2", className), ...props }));
105
+ }
106
+ function SidebarSeparator({ className, ...props }) {
107
+ return (_jsx(Separator, { "data-slot": "sidebar-separator", "data-sidebar": "separator", className: cn("mx-2 w-auto bg-sidebar-border", className), ...props }));
108
+ }
109
+ function SidebarContent({ className, ...props }) {
110
+ return (_jsx("div", { "data-slot": "sidebar-content", "data-sidebar": "content", className: cn("no-scrollbar flex min-h-0 flex-1 flex-col gap-2 overflow-auto group-data-[collapsible=icon]:overflow-hidden", className), ...props }));
111
+ }
112
+ export { Sidebar, SidebarContent, SidebarFooter, SidebarHeader, SidebarInput, SidebarInset, SidebarProvider, SidebarRail, SidebarSeparator, SidebarTrigger, useSidebar, };
@@ -0,0 +1,33 @@
1
+ import { useRender } from "@base-ui/react/use-render";
2
+ import { type VariantProps } from "class-variance-authority";
3
+ import * as React from "react";
4
+ import { TooltipContent } from "./tooltip";
5
+ declare function SidebarGroup({ className, ...props }: React.ComponentProps<"div">): import("react/jsx-runtime").JSX.Element;
6
+ declare function SidebarGroupLabel({ className, render, ...props }: useRender.ComponentProps<"div"> & React.ComponentProps<"div">): React.ReactElement<unknown, string | React.JSXElementConstructor<any>>;
7
+ declare function SidebarGroupAction({ className, render, ...props }: useRender.ComponentProps<"button"> & React.ComponentProps<"button">): React.ReactElement<unknown, string | React.JSXElementConstructor<any>>;
8
+ declare function SidebarGroupContent({ className, ...props }: React.ComponentProps<"div">): import("react/jsx-runtime").JSX.Element;
9
+ declare function SidebarMenu({ className, ...props }: React.ComponentProps<"ul">): import("react/jsx-runtime").JSX.Element;
10
+ declare function SidebarMenuItem({ className, ...props }: React.ComponentProps<"li">): import("react/jsx-runtime").JSX.Element;
11
+ declare const sidebarMenuButtonVariants: (props?: ({
12
+ variant?: "default" | "outline" | null | undefined;
13
+ size?: "default" | "sm" | "lg" | null | undefined;
14
+ } & import("class-variance-authority/types").ClassProp) | undefined) => string;
15
+ declare function SidebarMenuButton({ render, isActive, variant, size, tooltip, className, ...props }: useRender.ComponentProps<"button"> & React.ComponentProps<"button"> & {
16
+ isActive?: boolean;
17
+ tooltip?: string | React.ComponentProps<typeof TooltipContent>;
18
+ } & VariantProps<typeof sidebarMenuButtonVariants>): import("react/jsx-runtime").JSX.Element;
19
+ declare function SidebarMenuAction({ className, render, showOnHover, ...props }: useRender.ComponentProps<"button"> & React.ComponentProps<"button"> & {
20
+ showOnHover?: boolean;
21
+ }): React.ReactElement<unknown, string | React.JSXElementConstructor<any>>;
22
+ declare function SidebarMenuBadge({ className, ...props }: React.ComponentProps<"div">): import("react/jsx-runtime").JSX.Element;
23
+ declare function SidebarMenuSkeleton({ className, showIcon, ...props }: React.ComponentProps<"div"> & {
24
+ showIcon?: boolean;
25
+ }): import("react/jsx-runtime").JSX.Element;
26
+ declare function SidebarMenuSub({ className, ...props }: React.ComponentProps<"ul">): import("react/jsx-runtime").JSX.Element;
27
+ declare function SidebarMenuSubItem({ className, ...props }: React.ComponentProps<"li">): import("react/jsx-runtime").JSX.Element;
28
+ declare function SidebarMenuSubButton({ render, size, isActive, className, ...props }: useRender.ComponentProps<"a"> & React.ComponentProps<"a"> & {
29
+ size?: "sm" | "md";
30
+ isActive?: boolean;
31
+ }): React.ReactElement<unknown, string | React.JSXElementConstructor<any>>;
32
+ export { SidebarGroup, SidebarGroupAction, SidebarGroupContent, SidebarGroupLabel, SidebarMenu, SidebarMenuAction, SidebarMenuBadge, SidebarMenuButton, SidebarMenuItem, SidebarMenuSkeleton, SidebarMenuSub, SidebarMenuSubButton, SidebarMenuSubItem, };
33
+ //# sourceMappingURL=sidebar-menu.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sidebar-menu.d.ts","sourceRoot":"","sources":["../../src/components/sidebar-menu.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,2BAA2B,CAAA;AACrD,OAAO,EAAO,KAAK,YAAY,EAAE,MAAM,0BAA0B,CAAA;AACjE,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAI9B,OAAO,EAAW,cAAc,EAAkB,MAAM,WAAW,CAAA;AAEnE,iBAAS,YAAY,CAAC,EAAE,SAAS,EAAE,GAAG,KAAK,EAAE,EAAE,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,2CASzE;AAED,iBAAS,iBAAiB,CAAC,EACzB,SAAS,EACT,MAAM,EACN,GAAG,KAAK,EACT,EAAE,SAAS,CAAC,cAAc,CAAC,KAAK,CAAC,GAAG,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,0EAkB/D;AAED,iBAAS,kBAAkB,CAAC,EAC1B,SAAS,EACT,MAAM,EACN,GAAG,KAAK,EACT,EAAE,SAAS,CAAC,cAAc,CAAC,QAAQ,CAAC,GAAG,KAAK,CAAC,cAAc,CAAC,QAAQ,CAAC,0EAkBrE;AAED,iBAAS,mBAAmB,CAAC,EAAE,SAAS,EAAE,GAAG,KAAK,EAAE,EAAE,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,2CAShF;AAED,iBAAS,WAAW,CAAC,EAAE,SAAS,EAAE,GAAG,KAAK,EAAE,EAAE,KAAK,CAAC,cAAc,CAAC,IAAI,CAAC,2CASvE;AAED,iBAAS,eAAe,CAAC,EAAE,SAAS,EAAE,GAAG,KAAK,EAAE,EAAE,KAAK,CAAC,cAAc,CAAC,IAAI,CAAC,2CAS3E;AAED,QAAA,MAAM,yBAAyB;;;8EAoB9B,CAAA;AAED,iBAAS,iBAAiB,CAAC,EACzB,MAAM,EACN,QAAgB,EAChB,OAAmB,EACnB,IAAgB,EAChB,OAAO,EACP,SAAS,EACT,GAAG,KAAK,EACT,EAAE,SAAS,CAAC,cAAc,CAAC,QAAQ,CAAC,GACnC,KAAK,CAAC,cAAc,CAAC,QAAQ,CAAC,GAAG;IAC/B,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,OAAO,CAAC,EAAE,MAAM,GAAG,KAAK,CAAC,cAAc,CAAC,OAAO,cAAc,CAAC,CAAA;CAC/D,GAAG,YAAY,CAAC,OAAO,yBAAyB,CAAC,2CAoCnD;AAED,iBAAS,iBAAiB,CAAC,EACzB,SAAS,EACT,MAAM,EACN,WAAmB,EACnB,GAAG,KAAK,EACT,EAAE,SAAS,CAAC,cAAc,CAAC,QAAQ,CAAC,GACnC,KAAK,CAAC,cAAc,CAAC,QAAQ,CAAC,GAAG;IAC/B,WAAW,CAAC,EAAE,OAAO,CAAA;CACtB,0EAoBF;AAED,iBAAS,gBAAgB,CAAC,EAAE,SAAS,EAAE,GAAG,KAAK,EAAE,EAAE,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,2CAY7E;AAED,iBAAS,mBAAmB,CAAC,EAC3B,SAAS,EACT,QAAgB,EAChB,GAAG,KAAK,EACT,EAAE,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,GAAG;IAC/B,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB,2CAkBA;AAED,iBAAS,cAAc,CAAC,EAAE,SAAS,EAAE,GAAG,KAAK,EAAE,EAAE,KAAK,CAAC,cAAc,CAAC,IAAI,CAAC,2CAY1E;AAED,iBAAS,kBAAkB,CAAC,EAAE,SAAS,EAAE,GAAG,KAAK,EAAE,EAAE,KAAK,CAAC,cAAc,CAAC,IAAI,CAAC,2CAS9E;AAED,iBAAS,oBAAoB,CAAC,EAC5B,MAAM,EACN,IAAW,EACX,QAAgB,EAChB,SAAS,EACT,GAAG,KAAK,EACT,EAAE,SAAS,CAAC,cAAc,CAAC,GAAG,CAAC,GAC9B,KAAK,CAAC,cAAc,CAAC,GAAG,CAAC,GAAG;IAC1B,IAAI,CAAC,EAAE,IAAI,GAAG,IAAI,CAAA;IAClB,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB,0EAoBF;AAED,OAAO,EACL,YAAY,EACZ,kBAAkB,EAClB,mBAAmB,EACnB,iBAAiB,EACjB,WAAW,EACX,iBAAiB,EACjB,gBAAgB,EAChB,iBAAiB,EACjB,eAAe,EACf,mBAAmB,EACnB,cAAc,EACd,oBAAoB,EACpB,kBAAkB,GACnB,CAAA"}
@@ -0,0 +1,128 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { mergeProps } from "@base-ui/react/merge-props";
3
+ import { useRender } from "@base-ui/react/use-render";
4
+ import { cva } from "class-variance-authority";
5
+ import * as React from "react";
6
+ import { cn } from "../lib/utils";
7
+ import { useSidebar } from "./sidebar-core";
8
+ import { Skeleton } from "./skeleton";
9
+ import { Tooltip, TooltipContent, TooltipTrigger } from "./tooltip";
10
+ function SidebarGroup({ className, ...props }) {
11
+ return (_jsx("div", { "data-slot": "sidebar-group", "data-sidebar": "group", className: cn("relative flex w-full min-w-0 flex-col p-2", className), ...props }));
12
+ }
13
+ function SidebarGroupLabel({ className, render, ...props }) {
14
+ return useRender({
15
+ defaultTagName: "div",
16
+ props: mergeProps({
17
+ className: cn("flex h-8 shrink-0 items-center rounded-md px-2 text-xs font-medium text-sidebar-foreground/70 ring-sidebar-ring outline-hidden transition-[margin,opacity] duration-200 ease-linear group-data-[collapsible=icon]:-mt-8 group-data-[collapsible=icon]:opacity-0 focus-visible:ring-2 [&>svg]:size-4 [&>svg]:shrink-0", className),
18
+ }, props),
19
+ render,
20
+ state: {
21
+ slot: "sidebar-group-label",
22
+ sidebar: "group-label",
23
+ },
24
+ });
25
+ }
26
+ function SidebarGroupAction({ className, render, ...props }) {
27
+ return useRender({
28
+ defaultTagName: "button",
29
+ props: mergeProps({
30
+ className: cn("absolute top-3.5 right-3 flex aspect-square w-5 items-center justify-center rounded-md p-0 text-sidebar-foreground ring-sidebar-ring outline-hidden transition-transform group-data-[collapsible=icon]:hidden after:absolute after:-inset-2 hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 md:after:hidden [&>svg]:size-4 [&>svg]:shrink-0", className),
31
+ }, props),
32
+ render,
33
+ state: {
34
+ slot: "sidebar-group-action",
35
+ sidebar: "group-action",
36
+ },
37
+ });
38
+ }
39
+ function SidebarGroupContent({ className, ...props }) {
40
+ return (_jsx("div", { "data-slot": "sidebar-group-content", "data-sidebar": "group-content", className: cn("w-full text-sm", className), ...props }));
41
+ }
42
+ function SidebarMenu({ className, ...props }) {
43
+ return (_jsx("ul", { "data-slot": "sidebar-menu", "data-sidebar": "menu", className: cn("flex w-full min-w-0 flex-col gap-1", className), ...props }));
44
+ }
45
+ function SidebarMenuItem({ className, ...props }) {
46
+ return (_jsx("li", { "data-slot": "sidebar-menu-item", "data-sidebar": "menu-item", className: cn("group/menu-item relative", className), ...props }));
47
+ }
48
+ const sidebarMenuButtonVariants = cva("peer/menu-button group/menu-button flex w-full items-center gap-2 overflow-hidden rounded-md p-2 text-left text-sm ring-sidebar-ring outline-hidden transition-[width,height,padding] group-has-data-[sidebar=menu-action]/menu-item:pr-8 group-data-[collapsible=icon]:size-8! group-data-[collapsible=icon]:p-2! hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 active:bg-sidebar-accent active:text-sidebar-accent-foreground disabled:pointer-events-none disabled:opacity-50 aria-disabled:pointer-events-none aria-disabled:opacity-50 data-open:hover:bg-sidebar-accent data-open:hover:text-sidebar-accent-foreground data-active:bg-sidebar-accent data-active:font-medium data-active:text-sidebar-accent-foreground [&_svg]:size-4 [&_svg]:shrink-0 [&>span:last-child]:truncate", {
49
+ variants: {
50
+ variant: {
51
+ default: "hover:bg-sidebar-accent hover:text-sidebar-accent-foreground",
52
+ outline: "bg-background shadow-[0_0_0_1px_hsl(var(--sidebar-border))] hover:bg-sidebar-accent hover:text-sidebar-accent-foreground hover:shadow-[0_0_0_1px_hsl(var(--sidebar-accent))]",
53
+ },
54
+ size: {
55
+ default: "h-8 text-sm",
56
+ sm: "h-7 text-xs",
57
+ lg: "h-12 text-sm group-data-[collapsible=icon]:p-0!",
58
+ },
59
+ },
60
+ defaultVariants: {
61
+ variant: "default",
62
+ size: "default",
63
+ },
64
+ });
65
+ function SidebarMenuButton({ render, isActive = false, variant = "default", size = "default", tooltip, className, ...props }) {
66
+ const { isMobile, state } = useSidebar();
67
+ const comp = useRender({
68
+ defaultTagName: "button",
69
+ props: mergeProps({
70
+ className: cn(sidebarMenuButtonVariants({ variant, size }), className),
71
+ }, props),
72
+ render: !tooltip ? render : _jsx(TooltipTrigger, { render: render }),
73
+ state: {
74
+ slot: "sidebar-menu-button",
75
+ sidebar: "menu-button",
76
+ size,
77
+ active: isActive,
78
+ },
79
+ });
80
+ if (!tooltip) {
81
+ return comp;
82
+ }
83
+ const tooltipProps = typeof tooltip === "string" ? { children: tooltip } : tooltip;
84
+ return (_jsxs(Tooltip, { children: [comp, _jsx(TooltipContent, { side: "right", align: "center", hidden: state !== "collapsed" || isMobile, ...tooltipProps })] }));
85
+ }
86
+ function SidebarMenuAction({ className, render, showOnHover = false, ...props }) {
87
+ return useRender({
88
+ defaultTagName: "button",
89
+ props: mergeProps({
90
+ className: cn("absolute top-1.5 right-1 flex aspect-square w-5 items-center justify-center rounded-md p-0 text-sidebar-foreground ring-sidebar-ring outline-hidden transition-transform group-data-[collapsible=icon]:hidden peer-hover/menu-button:text-sidebar-accent-foreground peer-data-[size=default]/menu-button:top-1.5 peer-data-[size=lg]/menu-button:top-2.5 peer-data-[size=sm]/menu-button:top-1 after:absolute after:-inset-2 hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 md:after:hidden [&>svg]:size-4 [&>svg]:shrink-0", showOnHover &&
91
+ "group-focus-within/menu-item:opacity-100 group-hover/menu-item:opacity-100 peer-data-active/menu-button:text-sidebar-accent-foreground aria-expanded:opacity-100 md:opacity-0", className),
92
+ }, props),
93
+ render,
94
+ state: {
95
+ slot: "sidebar-menu-action",
96
+ sidebar: "menu-action",
97
+ },
98
+ });
99
+ }
100
+ function SidebarMenuBadge({ className, ...props }) {
101
+ return (_jsx("div", { "data-slot": "sidebar-menu-badge", "data-sidebar": "menu-badge", className: cn("pointer-events-none absolute right-1 flex h-5 min-w-5 items-center justify-center rounded-md px-1 text-xs font-medium text-sidebar-foreground tabular-nums select-none group-data-[collapsible=icon]:hidden peer-hover/menu-button:text-sidebar-accent-foreground peer-data-[size=default]/menu-button:top-1.5 peer-data-[size=lg]/menu-button:top-2.5 peer-data-[size=sm]/menu-button:top-1 peer-data-active/menu-button:text-sidebar-accent-foreground", className), ...props }));
102
+ }
103
+ function SidebarMenuSkeleton({ className, showIcon = false, ...props }) {
104
+ const [width] = React.useState(() => `${Math.floor(Math.random() * 40) + 50}%`);
105
+ return (_jsxs("div", { "data-slot": "sidebar-menu-skeleton", "data-sidebar": "menu-skeleton", className: cn("flex h-8 items-center gap-2 rounded-md px-2", className), ...props, children: [showIcon && _jsx(Skeleton, { className: "size-4 rounded-md", "data-sidebar": "menu-skeleton-icon" }), _jsx(Skeleton, { className: "h-4 max-w-(--skeleton-width) flex-1", "data-sidebar": "menu-skeleton-text", style: { "--skeleton-width": width } })] }));
106
+ }
107
+ function SidebarMenuSub({ className, ...props }) {
108
+ return (_jsx("ul", { "data-slot": "sidebar-menu-sub", "data-sidebar": "menu-sub", className: cn("mx-3.5 flex min-w-0 translate-x-px flex-col gap-1 border-l border-sidebar-border px-2.5 py-0.5 group-data-[collapsible=icon]:hidden", className), ...props }));
109
+ }
110
+ function SidebarMenuSubItem({ className, ...props }) {
111
+ return (_jsx("li", { "data-slot": "sidebar-menu-sub-item", "data-sidebar": "menu-sub-item", className: cn("group/menu-sub-item relative", className), ...props }));
112
+ }
113
+ function SidebarMenuSubButton({ render, size = "md", isActive = false, className, ...props }) {
114
+ return useRender({
115
+ defaultTagName: "a",
116
+ props: mergeProps({
117
+ className: cn("flex h-7 min-w-0 -translate-x-px items-center gap-2 overflow-hidden rounded-md px-2 text-sidebar-foreground ring-sidebar-ring outline-hidden group-data-[collapsible=icon]:hidden hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 active:bg-sidebar-accent active:text-sidebar-accent-foreground disabled:pointer-events-none disabled:opacity-50 aria-disabled:pointer-events-none aria-disabled:opacity-50 data-[size=md]:text-sm data-[size=sm]:text-xs data-active:bg-sidebar-accent data-active:text-sidebar-accent-foreground [&>span:last-child]:truncate [&>svg]:size-4 [&>svg]:shrink-0 [&>svg]:text-sidebar-accent-foreground", className),
118
+ }, props),
119
+ render,
120
+ state: {
121
+ slot: "sidebar-menu-sub-button",
122
+ sidebar: "menu-sub-button",
123
+ size,
124
+ active: isActive,
125
+ },
126
+ });
127
+ }
128
+ export { SidebarGroup, SidebarGroupAction, SidebarGroupContent, SidebarGroupLabel, SidebarMenu, SidebarMenuAction, SidebarMenuBadge, SidebarMenuButton, SidebarMenuItem, SidebarMenuSkeleton, SidebarMenuSub, SidebarMenuSubButton, SidebarMenuSubItem, };
@@ -0,0 +1,3 @@
1
+ export { Sidebar, SidebarContent, SidebarFooter, SidebarHeader, SidebarInput, SidebarInset, SidebarProvider, SidebarRail, SidebarSeparator, SidebarTrigger, useSidebar, } from "./sidebar-core";
2
+ export { SidebarGroup, SidebarGroupAction, SidebarGroupContent, SidebarGroupLabel, SidebarMenu, SidebarMenuAction, SidebarMenuBadge, SidebarMenuButton, SidebarMenuItem, SidebarMenuSkeleton, SidebarMenuSub, SidebarMenuSubButton, SidebarMenuSubItem, } from "./sidebar-menu";
3
+ //# sourceMappingURL=sidebar.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sidebar.d.ts","sourceRoot":"","sources":["../../src/components/sidebar.tsx"],"names":[],"mappings":"AAAA,OAAO,EACL,OAAO,EACP,cAAc,EACd,aAAa,EACb,aAAa,EACb,YAAY,EACZ,YAAY,EACZ,eAAe,EACf,WAAW,EACX,gBAAgB,EAChB,cAAc,EACd,UAAU,GACX,MAAM,gBAAgB,CAAA;AAEvB,OAAO,EACL,YAAY,EACZ,kBAAkB,EAClB,mBAAmB,EACnB,iBAAiB,EACjB,WAAW,EACX,iBAAiB,EACjB,gBAAgB,EAChB,iBAAiB,EACjB,eAAe,EACf,mBAAmB,EACnB,cAAc,EACd,oBAAoB,EACpB,kBAAkB,GACnB,MAAM,gBAAgB,CAAA"}
@@ -0,0 +1,2 @@
1
+ export { Sidebar, SidebarContent, SidebarFooter, SidebarHeader, SidebarInput, SidebarInset, SidebarProvider, SidebarRail, SidebarSeparator, SidebarTrigger, useSidebar, } from "./sidebar-core";
2
+ export { SidebarGroup, SidebarGroupAction, SidebarGroupContent, SidebarGroupLabel, SidebarMenu, SidebarMenuAction, SidebarMenuBadge, SidebarMenuButton, SidebarMenuItem, SidebarMenuSkeleton, SidebarMenuSub, SidebarMenuSubButton, SidebarMenuSubItem, } from "./sidebar-menu";
@@ -0,0 +1,7 @@
1
+ interface SkeletonProps extends Omit<React.ComponentPropsWithoutRef<"div">, "style"> {
2
+ className?: string;
3
+ style?: Record<string, string | number | undefined>;
4
+ }
5
+ declare function Skeleton({ className, style, ...props }: SkeletonProps): import("react/jsx-runtime").JSX.Element;
6
+ export { Skeleton };
7
+ //# sourceMappingURL=skeleton.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"skeleton.d.ts","sourceRoot":"","sources":["../../src/components/skeleton.tsx"],"names":[],"mappings":"AAEA,UAAU,aAAc,SAAQ,IAAI,CAAC,KAAK,CAAC,wBAAwB,CAAC,KAAK,CAAC,EAAE,OAAO,CAAC;IAClF,SAAS,CAAC,EAAE,MAAM,CAAA;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,CAAC,CAAA;CACpD;AAED,iBAAS,QAAQ,CAAC,EAAE,SAAS,EAAE,KAAK,EAAE,GAAG,KAAK,EAAE,EAAE,aAAa,2CAS9D;AAED,OAAO,EAAE,QAAQ,EAAE,CAAA"}
@@ -0,0 +1,6 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { cn } from "../lib/utils";
3
+ function Skeleton({ className, style, ...props }) {
4
+ return (_jsx("div", { "data-slot": "skeleton", className: cn("animate-pulse rounded-md bg-muted", className), style: style, ...props }));
5
+ }
6
+ export { Skeleton };
@@ -0,0 +1,4 @@
1
+ import { Slider as SliderPrimitive } from "@base-ui/react/slider";
2
+ declare function Slider({ className, defaultValue, value, min, max, ...props }: SliderPrimitive.Root.Props): import("react/jsx-runtime").JSX.Element;
3
+ export { Slider };
4
+ //# sourceMappingURL=slider.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"slider.d.ts","sourceRoot":"","sources":["../../src/components/slider.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,IAAI,eAAe,EAAE,MAAM,uBAAuB,CAAA;AAKjE,iBAAS,MAAM,CAAC,EACd,SAAS,EACT,YAAY,EACZ,KAAK,EACL,GAAO,EACP,GAAS,EACT,GAAG,KAAK,EACT,EAAE,eAAe,CAAC,IAAI,CAAC,KAAK,2CAqC5B;AAED,OAAO,EAAE,MAAM,EAAE,CAAA"}
@@ -0,0 +1,9 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Slider as SliderPrimitive } from "@base-ui/react/slider";
3
+ import * as React from "react";
4
+ import { cn } from "../lib/utils";
5
+ function Slider({ className, defaultValue, value, min = 0, max = 100, ...props }) {
6
+ const _values = React.useMemo(() => (Array.isArray(value) ? value : Array.isArray(defaultValue) ? defaultValue : [min, max]), [value, defaultValue, min, max]);
7
+ return (_jsx(SliderPrimitive.Root, { className: cn("data-horizontal:w-full data-vertical:h-full", className), "data-slot": "slider", defaultValue: defaultValue, value: value, min: min, max: max, thumbAlignment: "edge", ...props, children: _jsxs(SliderPrimitive.Control, { className: "relative flex w-full touch-none items-center select-none data-disabled:opacity-50 data-vertical:h-full data-vertical:min-h-40 data-vertical:w-auto data-vertical:flex-col", children: [_jsx(SliderPrimitive.Track, { "data-slot": "slider-track", className: "relative grow overflow-hidden rounded-full bg-muted select-none data-horizontal:h-1.5 data-horizontal:w-full data-vertical:h-full data-vertical:w-1.5", children: _jsx(SliderPrimitive.Indicator, { "data-slot": "slider-range", className: "bg-primary select-none data-horizontal:h-full data-vertical:w-full" }) }), Array.from({ length: _values.length }, (_, index) => (_jsx(SliderPrimitive.Thumb, { "data-slot": "slider-thumb", className: "block size-4 shrink-0 rounded-full border border-primary bg-white shadow-sm ring-ring/50 transition-[color,box-shadow] select-none hover:ring-4 focus-visible:ring-4 focus-visible:outline-hidden disabled:pointer-events-none disabled:opacity-50" }, String(_values[index] ?? index))))] }) }));
8
+ }
9
+ export { Slider };
@@ -0,0 +1,4 @@
1
+ import { type ToasterProps } from "sonner";
2
+ declare const Toaster: ({ ...props }: ToasterProps) => import("react/jsx-runtime").JSX.Element;
3
+ export { Toaster };
4
+ //# sourceMappingURL=sonner.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sonner.d.ts","sourceRoot":"","sources":["../../src/components/sonner.tsx"],"names":[],"mappings":"AAQA,OAAO,EAAqB,KAAK,YAAY,EAAE,MAAM,QAAQ,CAAA;AAE7D,QAAA,MAAM,OAAO,GAAI,cAAc,YAAY,4CA8B1C,CAAA;AAED,OAAO,EAAE,OAAO,EAAE,CAAA"}
@@ -0,0 +1,24 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { CircleCheckIcon, InfoIcon, Loader2Icon, OctagonXIcon, TriangleAlertIcon, } from "lucide-react";
3
+ import { useTheme } from "next-themes";
4
+ import { Toaster as Sonner } from "sonner";
5
+ const Toaster = ({ ...props }) => {
6
+ const { theme = "system" } = useTheme();
7
+ return (_jsx(Sonner, { theme: theme, className: "toaster group", icons: {
8
+ success: _jsx(CircleCheckIcon, { className: "size-4" }),
9
+ info: _jsx(InfoIcon, { className: "size-4" }),
10
+ warning: _jsx(TriangleAlertIcon, { className: "size-4" }),
11
+ error: _jsx(OctagonXIcon, { className: "size-4" }),
12
+ loading: _jsx(Loader2Icon, { className: "size-4 animate-spin" }),
13
+ }, style: {
14
+ "--normal-bg": "var(--popover)",
15
+ "--normal-text": "var(--popover-foreground)",
16
+ "--normal-border": "var(--border)",
17
+ "--border-radius": "var(--radius)",
18
+ }, toastOptions: {
19
+ classNames: {
20
+ toast: "cn-toast",
21
+ },
22
+ }, ...props }));
23
+ };
24
+ export { Toaster };
@@ -0,0 +1,3 @@
1
+ declare function Spinner({ className, ...props }: React.ComponentProps<"svg">): import("react/jsx-runtime").JSX.Element;
2
+ export { Spinner };
3
+ //# sourceMappingURL=spinner.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"spinner.d.ts","sourceRoot":"","sources":["../../src/components/spinner.tsx"],"names":[],"mappings":"AAGA,iBAAS,OAAO,CAAC,EAAE,SAAS,EAAE,GAAG,KAAK,EAAE,EAAE,KAAK,CAAC,cAAc,CAAC,KAAK,CAAC,2CASpE;AAED,OAAO,EAAE,OAAO,EAAE,CAAA"}
@@ -0,0 +1,7 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { Loader2Icon } from "lucide-react";
3
+ import { cn } from "../lib/utils";
4
+ function Spinner({ className, ...props }) {
5
+ return (_jsx(Loader2Icon, { role: "status", "aria-label": "Loading", className: cn("size-4 animate-spin", className), ...props }));
6
+ }
7
+ export { Spinner };
@@ -0,0 +1,6 @@
1
+ import { Switch as SwitchPrimitive } from "@base-ui/react/switch";
2
+ declare function Switch({ className, size, ...props }: SwitchPrimitive.Root.Props & {
3
+ size?: "sm" | "default";
4
+ }): import("react/jsx-runtime").JSX.Element;
5
+ export { Switch };
6
+ //# sourceMappingURL=switch.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"switch.d.ts","sourceRoot":"","sources":["../../src/components/switch.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,IAAI,eAAe,EAAE,MAAM,uBAAuB,CAAA;AAIjE,iBAAS,MAAM,CAAC,EACd,SAAS,EACT,IAAgB,EAChB,GAAG,KAAK,EACT,EAAE,eAAe,CAAC,IAAI,CAAC,KAAK,GAAG;IAC9B,IAAI,CAAC,EAAE,IAAI,GAAG,SAAS,CAAA;CACxB,2CAiBA;AAED,OAAO,EAAE,MAAM,EAAE,CAAA"}
@@ -0,0 +1,7 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { Switch as SwitchPrimitive } from "@base-ui/react/switch";
3
+ import { cn } from "../lib/utils";
4
+ function Switch({ className, size = "default", ...props }) {
5
+ return (_jsx(SwitchPrimitive.Root, { "data-slot": "switch", "data-size": size, className: cn("peer group/switch relative inline-flex shrink-0 items-center rounded-full border border-transparent shadow-xs transition-all outline-none after:absolute after:-inset-x-3 after:-inset-y-2 focus-visible:border-ring focus-visible:ring-3 focus-visible:ring-ring/50 aria-invalid:border-destructive aria-invalid:ring-3 aria-invalid:ring-destructive/20 data-[size=default]:h-[18.4px] data-[size=default]:w-[32px] data-[size=sm]:h-[14px] data-[size=sm]:w-[24px] dark:aria-invalid:border-destructive/50 dark:aria-invalid:ring-destructive/40 data-checked:bg-primary data-unchecked:bg-input dark:data-unchecked:bg-input/80 data-disabled:cursor-not-allowed data-disabled:opacity-50", className), ...props, children: _jsx(SwitchPrimitive.Thumb, { "data-slot": "switch-thumb", className: "pointer-events-none block rounded-full bg-background ring-0 transition-transform group-data-[size=default]/switch:size-4 group-data-[size=sm]/switch:size-3 group-data-[size=default]/switch:data-checked:translate-x-[calc(100%-2px)] group-data-[size=sm]/switch:data-checked:translate-x-[calc(100%-2px)] dark:data-checked:bg-primary-foreground group-data-[size=default]/switch:data-unchecked:translate-x-0 group-data-[size=sm]/switch:data-unchecked:translate-x-0 dark:data-unchecked:bg-foreground" }) }));
6
+ }
7
+ export { Switch };
@@ -0,0 +1,11 @@
1
+ import type * as React from "react";
2
+ declare function Table({ className, ...props }: React.ComponentProps<"table">): import("react/jsx-runtime").JSX.Element;
3
+ declare function TableHeader({ className, ...props }: React.ComponentProps<"thead">): import("react/jsx-runtime").JSX.Element;
4
+ declare function TableBody({ className, ...props }: React.ComponentProps<"tbody">): import("react/jsx-runtime").JSX.Element;
5
+ declare function TableFooter({ className, ...props }: React.ComponentProps<"tfoot">): import("react/jsx-runtime").JSX.Element;
6
+ declare function TableRow({ className, ...props }: React.ComponentProps<"tr">): import("react/jsx-runtime").JSX.Element;
7
+ declare function TableHead({ className, ...props }: React.ComponentProps<"th">): import("react/jsx-runtime").JSX.Element;
8
+ declare function TableCell({ className, ...props }: React.ComponentProps<"td">): import("react/jsx-runtime").JSX.Element;
9
+ declare function TableCaption({ className, ...props }: React.ComponentProps<"caption">): import("react/jsx-runtime").JSX.Element;
10
+ export { Table, TableBody, TableCaption, TableCell, TableFooter, TableHead, TableHeader, TableRow };
11
+ //# sourceMappingURL=table.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"table.d.ts","sourceRoot":"","sources":["../../src/components/table.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,KAAK,MAAM,OAAO,CAAA;AAInC,iBAAS,KAAK,CAAC,EAAE,SAAS,EAAE,GAAG,KAAK,EAAE,EAAE,KAAK,CAAC,cAAc,CAAC,OAAO,CAAC,2CAUpE;AAED,iBAAS,WAAW,CAAC,EAAE,SAAS,EAAE,GAAG,KAAK,EAAE,EAAE,KAAK,CAAC,cAAc,CAAC,OAAO,CAAC,2CAE1E;AAED,iBAAS,SAAS,CAAC,EAAE,SAAS,EAAE,GAAG,KAAK,EAAE,EAAE,KAAK,CAAC,cAAc,CAAC,OAAO,CAAC,2CAQxE;AAED,iBAAS,WAAW,CAAC,EAAE,SAAS,EAAE,GAAG,KAAK,EAAE,EAAE,KAAK,CAAC,cAAc,CAAC,OAAO,CAAC,2CAQ1E;AAED,iBAAS,QAAQ,CAAC,EAAE,SAAS,EAAE,GAAG,KAAK,EAAE,EAAE,KAAK,CAAC,cAAc,CAAC,IAAI,CAAC,2CAWpE;AAED,iBAAS,SAAS,CAAC,EAAE,SAAS,EAAE,GAAG,KAAK,EAAE,EAAE,KAAK,CAAC,cAAc,CAAC,IAAI,CAAC,2CAWrE;AAED,iBAAS,SAAS,CAAC,EAAE,SAAS,EAAE,GAAG,KAAK,EAAE,EAAE,KAAK,CAAC,cAAc,CAAC,IAAI,CAAC,2CAQrE;AAED,iBAAS,YAAY,CAAC,EAAE,SAAS,EAAE,GAAG,KAAK,EAAE,EAAE,KAAK,CAAC,cAAc,CAAC,SAAS,CAAC,2CAQ7E;AAED,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,YAAY,EAAE,SAAS,EAAE,WAAW,EAAE,SAAS,EAAE,WAAW,EAAE,QAAQ,EAAE,CAAA"}
@@ -0,0 +1,27 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { cn } from "../lib/utils";
3
+ function Table({ className, ...props }) {
4
+ return (_jsx("div", { "data-slot": "table-container", className: "relative w-full overflow-x-auto", children: _jsx("table", { "data-slot": "table", className: cn("w-full caption-bottom text-sm", className), ...props }) }));
5
+ }
6
+ function TableHeader({ className, ...props }) {
7
+ return _jsx("thead", { "data-slot": "table-header", className: cn("[&_tr]:border-b", className), ...props });
8
+ }
9
+ function TableBody({ className, ...props }) {
10
+ return (_jsx("tbody", { "data-slot": "table-body", className: cn("[&_tr:last-child]:border-0", className), ...props }));
11
+ }
12
+ function TableFooter({ className, ...props }) {
13
+ return (_jsx("tfoot", { "data-slot": "table-footer", className: cn("border-t bg-muted/50 font-medium [&>tr]:last:border-b-0", className), ...props }));
14
+ }
15
+ function TableRow({ className, ...props }) {
16
+ return (_jsx("tr", { "data-slot": "table-row", className: cn("border-b transition-colors hover:bg-muted/50 has-aria-expanded:bg-muted/50 data-[state=selected]:bg-muted", className), ...props }));
17
+ }
18
+ function TableHead({ className, ...props }) {
19
+ return (_jsx("th", { "data-slot": "table-head", className: cn("h-10 px-2 text-left align-middle font-medium whitespace-nowrap text-foreground [&:has([role=checkbox])]:pr-0", className), ...props }));
20
+ }
21
+ function TableCell({ className, ...props }) {
22
+ return (_jsx("td", { "data-slot": "table-cell", className: cn("p-2 align-middle whitespace-nowrap [&:has([role=checkbox])]:pr-0", className), ...props }));
23
+ }
24
+ function TableCaption({ className, ...props }) {
25
+ return (_jsx("caption", { "data-slot": "table-caption", className: cn("mt-4 text-sm text-muted-foreground", className), ...props }));
26
+ }
27
+ export { Table, TableBody, TableCaption, TableCell, TableFooter, TableHead, TableHeader, TableRow };
@@ -0,0 +1,11 @@
1
+ import { Tabs as TabsPrimitive } from "@base-ui/react/tabs";
2
+ import { type VariantProps } from "class-variance-authority";
3
+ declare function Tabs({ className, orientation, ...props }: TabsPrimitive.Root.Props): import("react/jsx-runtime").JSX.Element;
4
+ declare const tabsListVariants: (props?: ({
5
+ variant?: "line" | "default" | null | undefined;
6
+ } & import("class-variance-authority/types").ClassProp) | undefined) => string;
7
+ declare function TabsList({ className, variant, ...props }: TabsPrimitive.List.Props & VariantProps<typeof tabsListVariants>): import("react/jsx-runtime").JSX.Element;
8
+ declare function TabsTrigger({ className, ...props }: TabsPrimitive.Tab.Props): import("react/jsx-runtime").JSX.Element;
9
+ declare function TabsContent({ className, ...props }: TabsPrimitive.Panel.Props): import("react/jsx-runtime").JSX.Element;
10
+ export { Tabs, TabsContent, TabsList, TabsTrigger, tabsListVariants };
11
+ //# sourceMappingURL=tabs.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tabs.d.ts","sourceRoot":"","sources":["../../src/components/tabs.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,IAAI,aAAa,EAAE,MAAM,qBAAqB,CAAA;AAC3D,OAAO,EAAO,KAAK,YAAY,EAAE,MAAM,0BAA0B,CAAA;AAIjE,iBAAS,IAAI,CAAC,EAAE,SAAS,EAAE,WAA0B,EAAE,GAAG,KAAK,EAAE,EAAE,aAAa,CAAC,IAAI,CAAC,KAAK,2CAS1F;AAED,QAAA,MAAM,gBAAgB;;8EAarB,CAAA;AAED,iBAAS,QAAQ,CAAC,EAChB,SAAS,EACT,OAAmB,EACnB,GAAG,KAAK,EACT,EAAE,aAAa,CAAC,IAAI,CAAC,KAAK,GAAG,YAAY,CAAC,OAAO,gBAAgB,CAAC,2CASlE;AAED,iBAAS,WAAW,CAAC,EAAE,SAAS,EAAE,GAAG,KAAK,EAAE,EAAE,aAAa,CAAC,GAAG,CAAC,KAAK,2CAcpE;AAED,iBAAS,WAAW,CAAC,EAAE,SAAS,EAAE,GAAG,KAAK,EAAE,EAAE,aAAa,CAAC,KAAK,CAAC,KAAK,2CAQtE;AAED,OAAO,EAAE,IAAI,EAAE,WAAW,EAAE,QAAQ,EAAE,WAAW,EAAE,gBAAgB,EAAE,CAAA"}
@@ -0,0 +1,28 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { Tabs as TabsPrimitive } from "@base-ui/react/tabs";
3
+ import { cva } from "class-variance-authority";
4
+ import { cn } from "../lib/utils";
5
+ function Tabs({ className, orientation = "horizontal", ...props }) {
6
+ return (_jsx(TabsPrimitive.Root, { "data-slot": "tabs", "data-orientation": orientation, className: cn("group/tabs flex gap-2 data-horizontal:flex-col", className), ...props }));
7
+ }
8
+ const tabsListVariants = cva("group/tabs-list inline-flex w-fit items-center justify-center rounded-lg p-[3px] text-muted-foreground group-data-horizontal/tabs:h-9 group-data-vertical/tabs:h-fit group-data-vertical/tabs:flex-col data-[variant=line]:rounded-none", {
9
+ variants: {
10
+ variant: {
11
+ default: "bg-muted",
12
+ line: "gap-1 bg-transparent",
13
+ },
14
+ },
15
+ defaultVariants: {
16
+ variant: "default",
17
+ },
18
+ });
19
+ function TabsList({ className, variant = "default", ...props }) {
20
+ return (_jsx(TabsPrimitive.List, { "data-slot": "tabs-list", "data-variant": variant, className: cn(tabsListVariants({ variant }), className), ...props }));
21
+ }
22
+ function TabsTrigger({ className, ...props }) {
23
+ return (_jsx(TabsPrimitive.Tab, { "data-slot": "tabs-trigger", className: cn("relative inline-flex h-[calc(100%-1px)] flex-1 items-center justify-center gap-1.5 rounded-md border border-transparent px-2 py-1 text-sm font-medium whitespace-nowrap text-foreground/60 transition-all group-data-vertical/tabs:w-full group-data-vertical/tabs:justify-start hover:text-foreground focus-visible:border-ring focus-visible:ring-[3px] focus-visible:ring-ring/50 focus-visible:outline-1 focus-visible:outline-ring disabled:pointer-events-none disabled:opacity-50 has-data-[icon=inline-end]:pr-1.5 has-data-[icon=inline-start]:pl-1.5 aria-disabled:pointer-events-none aria-disabled:opacity-50 dark:text-muted-foreground dark:hover:text-foreground group-data-[variant=default]/tabs-list:data-active:shadow-sm group-data-[variant=line]/tabs-list:data-active:shadow-none [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4", "group-data-[variant=line]/tabs-list:bg-transparent group-data-[variant=line]/tabs-list:data-active:bg-transparent dark:group-data-[variant=line]/tabs-list:data-active:border-transparent dark:group-data-[variant=line]/tabs-list:data-active:bg-transparent", "data-active:bg-background data-active:text-foreground dark:data-active:border-input dark:data-active:bg-input/30 dark:data-active:text-foreground", "after:absolute after:bg-foreground after:opacity-0 after:transition-opacity group-data-horizontal/tabs:after:inset-x-0 group-data-horizontal/tabs:after:bottom-[-5px] group-data-horizontal/tabs:after:h-0.5 group-data-vertical/tabs:after:inset-y-0 group-data-vertical/tabs:after:-right-1 group-data-vertical/tabs:after:w-0.5 group-data-[variant=line]/tabs-list:data-active:after:opacity-100", className), ...props }));
24
+ }
25
+ function TabsContent({ className, ...props }) {
26
+ return (_jsx(TabsPrimitive.Panel, { "data-slot": "tabs-content", className: cn("flex-1 text-sm outline-none", className), ...props }));
27
+ }
28
+ export { Tabs, TabsContent, TabsList, TabsTrigger, tabsListVariants };
@@ -0,0 +1,4 @@
1
+ import type * as React from "react";
2
+ declare function Textarea({ className, ...props }: React.ComponentProps<"textarea">): import("react/jsx-runtime").JSX.Element;
3
+ export { Textarea };
4
+ //# sourceMappingURL=textarea.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"textarea.d.ts","sourceRoot":"","sources":["../../src/components/textarea.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,KAAK,MAAM,OAAO,CAAA;AAInC,iBAAS,QAAQ,CAAC,EAAE,SAAS,EAAE,GAAG,KAAK,EAAE,EAAE,KAAK,CAAC,cAAc,CAAC,UAAU,CAAC,2CAW1E;AAED,OAAO,EAAE,QAAQ,EAAE,CAAA"}
@@ -0,0 +1,6 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { cn } from "../lib/utils";
3
+ function Textarea({ className, ...props }) {
4
+ return (_jsx("textarea", { "data-slot": "textarea", className: cn("flex field-sizing-content min-h-16 w-full rounded-md border border-input bg-transparent px-2.5 py-2 text-base shadow-xs transition-[color,box-shadow] outline-none placeholder:text-muted-foreground focus-visible:border-ring focus-visible:ring-3 focus-visible:ring-ring/50 disabled:cursor-not-allowed disabled:opacity-50 aria-invalid:border-destructive aria-invalid:ring-3 aria-invalid:ring-destructive/20 md:text-sm dark:bg-input/30 dark:aria-invalid:border-destructive/50 dark:aria-invalid:ring-destructive/40", className), ...props }));
5
+ }
6
+ export { Textarea };
@@ -0,0 +1,11 @@
1
+ import { Toggle as TogglePrimitive } from "@base-ui/react/toggle";
2
+ import { ToggleGroup as ToggleGroupPrimitive } from "@base-ui/react/toggle-group";
3
+ import type { VariantProps } from "class-variance-authority";
4
+ import { toggleVariants } from "./toggle";
5
+ declare function ToggleGroup({ className, variant, size, spacing, orientation, children, ...props }: ToggleGroupPrimitive.Props & VariantProps<typeof toggleVariants> & {
6
+ spacing?: number;
7
+ orientation?: "horizontal" | "vertical";
8
+ }): import("react/jsx-runtime").JSX.Element;
9
+ declare function ToggleGroupItem({ className, children, variant, size, ...props }: TogglePrimitive.Props & VariantProps<typeof toggleVariants>): import("react/jsx-runtime").JSX.Element;
10
+ export { ToggleGroup, ToggleGroupItem };
11
+ //# sourceMappingURL=toggle-group.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"toggle-group.d.ts","sourceRoot":"","sources":["../../src/components/toggle-group.tsx"],"names":[],"mappings":"AAEA,OAAO,EAAE,MAAM,IAAI,eAAe,EAAE,MAAM,uBAAuB,CAAA;AACjE,OAAO,EAAE,WAAW,IAAI,oBAAoB,EAAE,MAAM,6BAA6B,CAAA;AACjF,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,0BAA0B,CAAA;AAG5D,OAAO,EAAE,cAAc,EAAE,MAAM,UAAU,CAAA;AAczC,iBAAS,WAAW,CAAC,EACnB,SAAS,EACT,OAAO,EACP,IAAI,EACJ,OAAW,EACX,WAA0B,EAC1B,QAAQ,EACR,GAAG,KAAK,EACT,EAAE,oBAAoB,CAAC,KAAK,GAC3B,YAAY,CAAC,OAAO,cAAc,CAAC,GAAG;IACpC,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,WAAW,CAAC,EAAE,YAAY,GAAG,UAAU,CAAA;CACxC,2CAoBF;AAED,iBAAS,eAAe,CAAC,EACvB,SAAS,EACT,QAAQ,EACR,OAAmB,EACnB,IAAgB,EAChB,GAAG,KAAK,EACT,EAAE,eAAe,CAAC,KAAK,GAAG,YAAY,CAAC,OAAO,cAAc,CAAC,2CAsB7D;AAED,OAAO,EAAE,WAAW,EAAE,eAAe,EAAE,CAAA"}
@@ -0,0 +1,24 @@
1
+ "use client";
2
+ import { jsx as _jsx } from "react/jsx-runtime";
3
+ import { Toggle as TogglePrimitive } from "@base-ui/react/toggle";
4
+ import { ToggleGroup as ToggleGroupPrimitive } from "@base-ui/react/toggle-group";
5
+ import * as React from "react";
6
+ import { cn } from "../lib/utils";
7
+ import { toggleVariants } from "./toggle";
8
+ const ToggleGroupContext = React.createContext({
9
+ size: "default",
10
+ variant: "default",
11
+ spacing: 0,
12
+ orientation: "horizontal",
13
+ });
14
+ function ToggleGroup({ className, variant, size, spacing = 0, orientation = "horizontal", children, ...props }) {
15
+ return (_jsx(ToggleGroupPrimitive, { "data-slot": "toggle-group", "data-variant": variant, "data-size": size, "data-spacing": spacing, "data-orientation": orientation, style: { "--gap": spacing }, className: cn("group/toggle-group flex w-fit flex-row items-center gap-[--spacing(var(--gap))] rounded-md data-[spacing=0]:data-[variant=outline]:shadow-xs data-vertical:flex-col data-vertical:items-stretch", className), ...props, children: _jsx(ToggleGroupContext.Provider, { value: { variant, size, spacing, orientation }, children: children }) }));
16
+ }
17
+ function ToggleGroupItem({ className, children, variant = "default", size = "default", ...props }) {
18
+ const context = React.useContext(ToggleGroupContext);
19
+ return (_jsx(TogglePrimitive, { "data-slot": "toggle-group-item", "data-variant": context.variant || variant, "data-size": context.size || size, "data-spacing": context.spacing, className: cn("shrink-0 group-data-[spacing=0]/toggle-group:rounded-none group-data-[spacing=0]/toggle-group:px-2 group-data-[spacing=0]/toggle-group:shadow-none focus:z-10 focus-visible:z-10 group-data-[spacing=0]/toggle-group:has-data-[icon=inline-end]:pr-1.5 group-data-[spacing=0]/toggle-group:has-data-[icon=inline-start]:pl-1.5 group-data-horizontal/toggle-group:data-[spacing=0]:first:rounded-l-md group-data-vertical/toggle-group:data-[spacing=0]:first:rounded-t-md group-data-horizontal/toggle-group:data-[spacing=0]:last:rounded-r-md group-data-vertical/toggle-group:data-[spacing=0]:last:rounded-b-md data-[state=on]:bg-muted group-data-horizontal/toggle-group:data-[spacing=0]:data-[variant=outline]:border-l-0 group-data-vertical/toggle-group:data-[spacing=0]:data-[variant=outline]:border-t-0 group-data-horizontal/toggle-group:data-[spacing=0]:data-[variant=outline]:first:border-l group-data-vertical/toggle-group:data-[spacing=0]:data-[variant=outline]:first:border-t", toggleVariants({
20
+ variant: context.variant || variant,
21
+ size: context.size || size,
22
+ }), className), ...props, children: children }));
23
+ }
24
+ export { ToggleGroup, ToggleGroupItem };
@@ -0,0 +1,9 @@
1
+ import { Toggle as TogglePrimitive } from "@base-ui/react/toggle";
2
+ import { type VariantProps } from "class-variance-authority";
3
+ declare const toggleVariants: (props?: ({
4
+ variant?: "default" | "outline" | null | undefined;
5
+ size?: "default" | "sm" | "lg" | null | undefined;
6
+ } & import("class-variance-authority/types").ClassProp) | undefined) => string;
7
+ declare function Toggle({ className, variant, size, ...props }: TogglePrimitive.Props & VariantProps<typeof toggleVariants>): import("react/jsx-runtime").JSX.Element;
8
+ export { Toggle, toggleVariants };
9
+ //# sourceMappingURL=toggle.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"toggle.d.ts","sourceRoot":"","sources":["../../src/components/toggle.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,IAAI,eAAe,EAAE,MAAM,uBAAuB,CAAA;AACjE,OAAO,EAAO,KAAK,YAAY,EAAE,MAAM,0BAA0B,CAAA;AAIjE,QAAA,MAAM,cAAc;;;8EAoBnB,CAAA;AAED,iBAAS,MAAM,CAAC,EACd,SAAS,EACT,OAAmB,EACnB,IAAgB,EAChB,GAAG,KAAK,EACT,EAAE,eAAe,CAAC,KAAK,GAAG,YAAY,CAAC,OAAO,cAAc,CAAC,2CAQ7D;AAED,OAAO,EAAE,MAAM,EAAE,cAAc,EAAE,CAAA"}