@customafk/lunas-ui 0.0.38 → 0.0.39

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 (174) hide show
  1. package/dist/{button-CuD6ftFd.d.cts → button-DiLUZ6nN.d.cts} +3 -3
  2. package/dist/{button-DG4Wt4hh.d.ts → button-y_YnE05_.d.ts} +3 -3
  3. package/dist/calendar-4R0xSc0m.js +2 -0
  4. package/dist/calendar-4R0xSc0m.js.map +1 -0
  5. package/dist/calendar-DB7j4ZPb.cjs +2 -0
  6. package/dist/calendar-DB7j4ZPb.cjs.map +1 -0
  7. package/dist/{command-DT-Vyt0F.d.cts → command-BFjO9Ikd.d.ts} +12 -12
  8. package/dist/{command-D-A3HhTp.d.ts → command-CUExI_pN.d.cts} +12 -12
  9. package/dist/data-display/empty.d.cts +2 -2
  10. package/dist/data-display/empty.d.ts +2 -2
  11. package/dist/data-display/statistic.d.cts +2 -2
  12. package/dist/data-display/statistic.d.ts +2 -2
  13. package/dist/{dialog-bbVmbjTG.d.cts → dialog-DsaPxVX2.d.ts} +12 -12
  14. package/dist/{dialog-q2qolwKy.d.ts → dialog-loB0RecL.d.cts} +12 -12
  15. package/dist/dialogs/detail-dialog/component/sidebar.cjs +1 -1
  16. package/dist/dialogs/detail-dialog/component/sidebar.d.cts +49 -48
  17. package/dist/dialogs/detail-dialog/component/sidebar.d.ts +49 -48
  18. package/dist/dialogs/detail-dialog/component/sidebar.js +1 -1
  19. package/dist/dialogs/detail-dialog/index.cjs +1 -1
  20. package/dist/dialogs/detail-dialog/index.cjs.map +1 -1
  21. package/dist/dialogs/detail-dialog/index.js +1 -1
  22. package/dist/dialogs/detail-dialog/index.js.map +1 -1
  23. package/dist/dialogs/form-dialog.d.cts +2 -2
  24. package/dist/dialogs/form-dialog.d.ts +2 -2
  25. package/dist/forms/combobox-field.d.cts +2 -2
  26. package/dist/forms/combobox-field.d.ts +2 -2
  27. package/dist/forms/date-field.cjs +1 -1
  28. package/dist/forms/date-field.d.cts +2 -2
  29. package/dist/forms/date-field.d.ts +2 -2
  30. package/dist/forms/date-field.js +1 -1
  31. package/dist/forms/form-wrapper.d.cts +2 -2
  32. package/dist/forms/form-wrapper.d.ts +2 -2
  33. package/dist/forms/multi-select-field.d.cts +2 -2
  34. package/dist/forms/multi-select-field.d.ts +2 -2
  35. package/dist/forms/number-field.d.cts +2 -2
  36. package/dist/forms/number-field.d.ts +2 -2
  37. package/dist/forms/password-field.d.cts +2 -2
  38. package/dist/forms/password-field.d.ts +2 -2
  39. package/dist/forms/select-field.d.cts +2 -2
  40. package/dist/forms/select-field.d.ts +2 -2
  41. package/dist/forms/switch-field.d.cts +2 -2
  42. package/dist/forms/switch-field.d.ts +2 -2
  43. package/dist/forms/text-field.d.cts +2 -2
  44. package/dist/forms/text-field.d.ts +2 -2
  45. package/dist/forms/textarea-field.d.cts +2 -2
  46. package/dist/forms/textarea-field.d.ts +2 -2
  47. package/dist/{input-xXKZJ_56.d.ts → input-BHn3mzNR.d.cts} +3 -3
  48. package/dist/{input-Cl99LGyN.d.cts → input-DqL21WVw.d.ts} +3 -3
  49. package/dist/layouts/app-layout/index.cjs +1 -1
  50. package/dist/layouts/app-layout/index.cjs.map +1 -1
  51. package/dist/layouts/app-layout/index.d.cts +47 -47
  52. package/dist/layouts/app-layout/index.d.ts +47 -47
  53. package/dist/layouts/app-layout/index.js +1 -1
  54. package/dist/layouts/app-layout/index.js.map +1 -1
  55. package/dist/layouts/flex.d.cts +7 -7
  56. package/dist/layouts/flex.d.ts +5 -5
  57. package/dist/layouts/main/index.d.ts +4 -4
  58. package/dist/{separator-DUrj7nek.d.ts → separator-Dbp_UwEF.d.cts} +3 -3
  59. package/dist/{separator-DnlF2DdF.d.cts → separator-G_CtQEqW.d.ts} +3 -3
  60. package/dist/sidebar-3ZtESIIQ.cjs +2 -0
  61. package/dist/sidebar-3ZtESIIQ.cjs.map +1 -0
  62. package/dist/sidebar-3aHCC_OD.js +2 -0
  63. package/dist/sidebar-3aHCC_OD.js.map +1 -0
  64. package/dist/table/index.d.cts +2 -2
  65. package/dist/table/index.d.ts +2 -2
  66. package/dist/{toggle-DBzjbA4J.d.ts → toggle-DkZBD4Qc.d.cts} +5 -5
  67. package/dist/{toggle-CtovzZAs.d.cts → toggle-UTf5bV7k.d.ts} +4 -4
  68. package/dist/{tooltip-0nIbScX6.d.ts → tooltip-DFsHixOs.d.ts} +6 -6
  69. package/dist/{tooltip-Dmw3-czf.d.cts → tooltip-qUdoNuzQ.d.cts} +6 -6
  70. package/dist/typography/paragraph.d.cts +2 -2
  71. package/dist/typography/paragraph.d.ts +2 -2
  72. package/dist/typography/title.d.cts +2 -2
  73. package/dist/typography/title.d.ts +2 -2
  74. package/dist/ui/alert-dialog.d.cts +12 -12
  75. package/dist/ui/alert.d.cts +6 -6
  76. package/dist/ui/alert.d.ts +4 -4
  77. package/dist/ui/aspect-ratio.d.cts +2 -2
  78. package/dist/ui/aspect-ratio.d.ts +2 -2
  79. package/dist/ui/avatar.d.cts +4 -4
  80. package/dist/ui/avatar.d.ts +4 -4
  81. package/dist/ui/badge.d.cts +3 -3
  82. package/dist/ui/badge.d.ts +3 -3
  83. package/dist/ui/breadcrumb.d.cts +8 -8
  84. package/dist/ui/breadcrumb.d.ts +8 -8
  85. package/dist/ui/button.d.cts +1 -1
  86. package/dist/ui/button.d.ts +1 -1
  87. package/dist/ui/calendar.cjs +1 -1
  88. package/dist/ui/calendar.d.cts +4 -4
  89. package/dist/ui/calendar.d.ts +4 -4
  90. package/dist/ui/calendar.js +1 -1
  91. package/dist/ui/card.d.cts +8 -8
  92. package/dist/ui/card.d.ts +8 -8
  93. package/dist/ui/carousel.d.cts +7 -7
  94. package/dist/ui/carousel.d.ts +7 -7
  95. package/dist/ui/collapsible.d.cts +4 -4
  96. package/dist/ui/collapsible.d.ts +4 -4
  97. package/dist/ui/command.d.cts +2 -2
  98. package/dist/ui/command.d.ts +2 -2
  99. package/dist/ui/context-menu.d.cts +16 -16
  100. package/dist/ui/context-menu.d.ts +16 -16
  101. package/dist/ui/dialog.d.cts +1 -1
  102. package/dist/ui/dialog.d.ts +1 -1
  103. package/dist/ui/dropdown-menu.d.cts +16 -16
  104. package/dist/ui/dropdown-menu.d.ts +16 -16
  105. package/dist/ui/file-uploader.d.cts +2 -2
  106. package/dist/ui/file-uploader.d.ts +2 -2
  107. package/dist/ui/form.d.cts +7 -7
  108. package/dist/ui/form.d.ts +7 -7
  109. package/dist/ui/hover-card.d.cts +4 -4
  110. package/dist/ui/hover-card.d.ts +4 -4
  111. package/dist/ui/input-otp.d.cts +5 -5
  112. package/dist/ui/input-otp.d.ts +5 -5
  113. package/dist/ui/input.d.cts +1 -1
  114. package/dist/ui/input.d.ts +1 -1
  115. package/dist/ui/inputs/search-input.d.cts +3 -3
  116. package/dist/ui/inputs/search-input.d.ts +3 -3
  117. package/dist/ui/label.d.cts +2 -2
  118. package/dist/ui/label.d.ts +2 -2
  119. package/dist/ui/menubar.d.cts +17 -17
  120. package/dist/ui/menubar.d.ts +17 -17
  121. package/dist/ui/multi-select.d.cts +2 -2
  122. package/dist/ui/multi-select.d.ts +2 -2
  123. package/dist/ui/navigation-menu.d.cts +11 -11
  124. package/dist/ui/navigation-menu.d.ts +11 -11
  125. package/dist/ui/pagination.d.cts +9 -9
  126. package/dist/ui/pagination.d.ts +9 -9
  127. package/dist/ui/popover.d.cts +5 -5
  128. package/dist/ui/popover.d.ts +5 -5
  129. package/dist/ui/progress.d.cts +2 -2
  130. package/dist/ui/progress.d.ts +2 -2
  131. package/dist/ui/radio-group.d.cts +3 -3
  132. package/dist/ui/radio-group.d.ts +3 -3
  133. package/dist/ui/resizable.d.cts +4 -4
  134. package/dist/ui/resizable.d.ts +4 -4
  135. package/dist/ui/scroll-area.d.cts +3 -3
  136. package/dist/ui/scroll-area.d.ts +3 -3
  137. package/dist/ui/select.d.cts +11 -11
  138. package/dist/ui/select.d.ts +11 -11
  139. package/dist/ui/separator.d.cts +1 -1
  140. package/dist/ui/separator.d.ts +1 -1
  141. package/dist/ui/sheet.d.cts +9 -9
  142. package/dist/ui/sheet.d.ts +9 -9
  143. package/dist/ui/sidebar.d.cts +30 -30
  144. package/dist/ui/sidebar.d.ts +30 -30
  145. package/dist/ui/skeleton.d.cts +2 -2
  146. package/dist/ui/skeleton.d.ts +2 -2
  147. package/dist/ui/slider.d.cts +2 -2
  148. package/dist/ui/slider.d.ts +2 -2
  149. package/dist/ui/sonner.d.cts +2 -2
  150. package/dist/ui/sonner.d.ts +2 -2
  151. package/dist/ui/switch.d.cts +2 -2
  152. package/dist/ui/switch.d.ts +2 -2
  153. package/dist/ui/table.d.cts +9 -9
  154. package/dist/ui/table.d.ts +9 -9
  155. package/dist/ui/tabs.d.cts +5 -5
  156. package/dist/ui/tabs.d.ts +5 -5
  157. package/dist/ui/textarea.d.cts +2 -2
  158. package/dist/ui/textarea.d.ts +2 -2
  159. package/dist/ui/toggle-group.d.cts +4 -4
  160. package/dist/ui/toggle-group.d.ts +4 -4
  161. package/dist/ui/toggle.d.cts +1 -1
  162. package/dist/ui/toggle.d.ts +1 -1
  163. package/dist/ui/tooltip.d.cts +1 -1
  164. package/dist/ui/tooltip.d.ts +1 -1
  165. package/package.json +1 -5
  166. package/styles/theme.css +7 -3
  167. package/dist/calendar-CdqoCacy.js +0 -2
  168. package/dist/calendar-CdqoCacy.js.map +0 -1
  169. package/dist/calendar-Di2ItTy8.cjs +0 -2
  170. package/dist/calendar-Di2ItTy8.cjs.map +0 -1
  171. package/dist/sidebar-DQ2i5dVQ.cjs +0 -2
  172. package/dist/sidebar-DQ2i5dVQ.cjs.map +0 -1
  173. package/dist/sidebar-PJA75H5x.js +0 -2
  174. package/dist/sidebar-PJA75H5x.js.map +0 -1
@@ -1,8 +1,8 @@
1
- import { Button } from "../../button-DG4Wt4hh.js";
2
- import { Separator } from "../../separator-DUrj7nek.js";
3
- import { TooltipContent } from "../../tooltip-0nIbScX6.js";
1
+ import { Button } from "../../button-y_YnE05_.js";
2
+ import { Separator } from "../../separator-G_CtQEqW.js";
3
+ import { TooltipContent } from "../../tooltip-DFsHixOs.js";
4
4
  import React$1 from "react";
5
- import * as react_jsx_runtime261 from "react/jsx-runtime";
5
+ import * as react_jsx_runtime259 from "react/jsx-runtime";
6
6
  import { VariantProps } from "class-variance-authority";
7
7
  import * as class_variance_authority_types7 from "class-variance-authority/types";
8
8
 
@@ -29,7 +29,7 @@ declare function SidebarProvider({
29
29
  defaultOpen?: boolean;
30
30
  open?: boolean;
31
31
  onOpenChange?: (open: boolean) => void;
32
- }): react_jsx_runtime261.JSX.Element;
32
+ }): react_jsx_runtime259.JSX.Element;
33
33
  declare function Sidebar({
34
34
  side,
35
35
  variant,
@@ -41,72 +41,72 @@ declare function Sidebar({
41
41
  side?: 'left' | 'right';
42
42
  variant?: 'sidebar' | 'floating' | 'inset';
43
43
  collapsible?: 'offcanvas' | 'icon' | 'none';
44
- }): react_jsx_runtime261.JSX.Element;
45
- declare function SidebarTrigger({
44
+ }): react_jsx_runtime259.JSX.Element;
45
+ declare function AppLayoutSidebarTrigger({
46
46
  className,
47
47
  onClick,
48
48
  ...props
49
- }: React$1.ComponentProps<typeof Button>): react_jsx_runtime261.JSX.Element;
50
- declare function SidebarRail({
49
+ }: React$1.ComponentProps<typeof Button>): react_jsx_runtime259.JSX.Element;
50
+ declare function AppLayoutSidebarRail({
51
51
  className,
52
52
  ...props
53
- }: React$1.ComponentProps<'button'>): react_jsx_runtime261.JSX.Element;
54
- declare function SidebarInset({
53
+ }: React$1.ComponentProps<'button'>): react_jsx_runtime259.JSX.Element;
54
+ declare function AppLayoutSidebarInset({
55
55
  className,
56
56
  children,
57
57
  ...props
58
- }: React$1.ComponentProps<'main'>): react_jsx_runtime261.JSX.Element;
59
- declare function SidebarHeader({
58
+ }: React$1.ComponentProps<'main'>): react_jsx_runtime259.JSX.Element;
59
+ declare function AppLayoutSidebarHeader({
60
60
  className,
61
61
  ...props
62
- }: React$1.ComponentProps<'div'>): react_jsx_runtime261.JSX.Element;
63
- declare function SidebarFooter({
62
+ }: React$1.ComponentProps<'div'>): react_jsx_runtime259.JSX.Element;
63
+ declare function AppLayoutSidebarFooter({
64
64
  className,
65
65
  ...props
66
- }: React$1.ComponentProps<'div'>): react_jsx_runtime261.JSX.Element;
67
- declare function SidebarSeparator({
66
+ }: React$1.ComponentProps<'div'>): react_jsx_runtime259.JSX.Element;
67
+ declare function AppLayoutSidebarSeparator({
68
68
  className,
69
69
  ...props
70
- }: React$1.ComponentProps<typeof Separator>): react_jsx_runtime261.JSX.Element;
71
- declare function SidebarContent({
70
+ }: React$1.ComponentProps<typeof Separator>): react_jsx_runtime259.JSX.Element;
71
+ declare function AppLayoutSidebarContent({
72
72
  className,
73
73
  ...props
74
- }: React$1.ComponentProps<'div'>): react_jsx_runtime261.JSX.Element;
75
- declare function SidebarGroup({
74
+ }: React$1.ComponentProps<'div'>): react_jsx_runtime259.JSX.Element;
75
+ declare function AppLayoutSidebarGroup({
76
76
  className,
77
77
  ...props
78
- }: React$1.ComponentProps<'div'>): react_jsx_runtime261.JSX.Element;
79
- declare function SidebarGroupLabel({
78
+ }: React$1.ComponentProps<'div'>): react_jsx_runtime259.JSX.Element;
79
+ declare function AppLayoutSidebarGroupLabel({
80
80
  className,
81
81
  asChild,
82
82
  ...props
83
83
  }: React$1.ComponentProps<'div'> & {
84
84
  asChild?: boolean;
85
- }): react_jsx_runtime261.JSX.Element;
86
- declare function SidebarGroupAction({
85
+ }): react_jsx_runtime259.JSX.Element;
86
+ declare function AppLayoutSidebarGroupAction({
87
87
  className,
88
88
  asChild,
89
89
  ...props
90
90
  }: React$1.ComponentProps<'button'> & {
91
91
  asChild?: boolean;
92
- }): react_jsx_runtime261.JSX.Element;
93
- declare function SidebarGroupContent({
92
+ }): react_jsx_runtime259.JSX.Element;
93
+ declare function AppLayoutSidebarGroupContent({
94
94
  className,
95
95
  ...props
96
- }: React$1.ComponentProps<'div'>): react_jsx_runtime261.JSX.Element;
97
- declare function SidebarMenu({
96
+ }: React$1.ComponentProps<'div'>): react_jsx_runtime259.JSX.Element;
97
+ declare function AppLayoutSidebarMenu({
98
98
  className,
99
99
  ...props
100
- }: React$1.ComponentProps<'ul'>): react_jsx_runtime261.JSX.Element;
101
- declare function SidebarMenuItem({
100
+ }: React$1.ComponentProps<'ul'>): react_jsx_runtime259.JSX.Element;
101
+ declare function AppLayoutSidebarMenuItem({
102
102
  className,
103
103
  ...props
104
- }: React$1.ComponentProps<'li'>): react_jsx_runtime261.JSX.Element;
104
+ }: React$1.ComponentProps<'li'>): react_jsx_runtime259.JSX.Element;
105
105
  declare const sidebarMenuButtonVariants: (props?: ({
106
106
  variant?: "default" | "outline" | null | undefined;
107
107
  size?: "sm" | "lg" | "default" | null | undefined;
108
108
  } & class_variance_authority_types7.ClassProp) | undefined) => string;
109
- declare function SidebarMenuButton({
109
+ declare function AppLayoutSidebarMenuButton({
110
110
  asChild,
111
111
  isActive,
112
112
  variant,
@@ -118,8 +118,8 @@ declare function SidebarMenuButton({
118
118
  asChild?: boolean;
119
119
  isActive?: boolean;
120
120
  tooltip?: string | React$1.ComponentProps<typeof TooltipContent>;
121
- } & VariantProps<typeof sidebarMenuButtonVariants>): react_jsx_runtime261.JSX.Element;
122
- declare function SidebarMenuAction({
121
+ } & VariantProps<typeof sidebarMenuButtonVariants>): react_jsx_runtime259.JSX.Element;
122
+ declare function AppLayoutSidebarMenuAction({
123
123
  className,
124
124
  asChild,
125
125
  showOnHover,
@@ -127,27 +127,27 @@ declare function SidebarMenuAction({
127
127
  }: React$1.ComponentProps<'button'> & {
128
128
  asChild?: boolean;
129
129
  showOnHover?: boolean;
130
- }): react_jsx_runtime261.JSX.Element;
131
- declare function SidebarMenuBadge({
130
+ }): react_jsx_runtime259.JSX.Element;
131
+ declare function AppLayoutSidebarMenuBadge({
132
132
  className,
133
133
  ...props
134
- }: React$1.ComponentProps<'div'>): react_jsx_runtime261.JSX.Element;
135
- declare function SidebarMenuSkeleton({
134
+ }: React$1.ComponentProps<'div'>): react_jsx_runtime259.JSX.Element;
135
+ declare function AppLayoutSidebarMenuSkeleton({
136
136
  className,
137
137
  showIcon,
138
138
  ...props
139
139
  }: React$1.ComponentProps<'div'> & {
140
140
  showIcon?: boolean;
141
- }): react_jsx_runtime261.JSX.Element;
142
- declare function SidebarMenuSub({
141
+ }): react_jsx_runtime259.JSX.Element;
142
+ declare function AppLayoutSidebarMenuSub({
143
143
  className,
144
144
  ...props
145
- }: React$1.ComponentProps<'ul'>): react_jsx_runtime261.JSX.Element;
146
- declare function SidebarMenuSubItem({
145
+ }: React$1.ComponentProps<'ul'>): react_jsx_runtime259.JSX.Element;
146
+ declare function AppLayoutSidebarMenuSubItem({
147
147
  className,
148
148
  ...props
149
- }: React$1.ComponentProps<'li'>): react_jsx_runtime261.JSX.Element;
150
- declare function SidebarMenuSubButton({
149
+ }: React$1.ComponentProps<'li'>): react_jsx_runtime259.JSX.Element;
150
+ declare function AppLayoutSidebarMenuSubButton({
151
151
  asChild,
152
152
  size,
153
153
  isActive,
@@ -157,7 +157,7 @@ declare function SidebarMenuSubButton({
157
157
  asChild?: boolean;
158
158
  size?: 'sm' | 'md';
159
159
  isActive?: boolean;
160
- }): react_jsx_runtime261.JSX.Element;
160
+ }): react_jsx_runtime259.JSX.Element;
161
161
  //#endregion
162
162
  //#region packages/components/layouts/app-layout/index.d.ts
163
163
  declare const AppLayoutWrapper: React.FC<React.PropsWithChildren>;
@@ -169,5 +169,5 @@ declare const AppLayoutMainGroup: React.FC<React.PropsWithChildren<{
169
169
  }>>;
170
170
  declare const AppLayoutMainGroupContent: React.FC<React.PropsWithChildren>;
171
171
  //#endregion
172
- export { AppLayoutHeader, AppLayoutMain, AppLayoutMainGroup, AppLayoutMainGroupContent, AppLayoutSidebar, AppLayoutWrapper, Sidebar, SidebarContent, SidebarFooter, SidebarGroup, SidebarGroupAction, SidebarGroupContent, SidebarGroupLabel, SidebarHeader, SidebarInset, SidebarMenu, SidebarMenuAction, SidebarMenuBadge, SidebarMenuButton, SidebarMenuItem, SidebarMenuSkeleton, SidebarMenuSub, SidebarMenuSubButton, SidebarMenuSubItem, SidebarProvider, SidebarRail, SidebarSeparator, SidebarTrigger, useSidebar };
172
+ export { AppLayoutHeader, AppLayoutMain, AppLayoutMainGroup, AppLayoutMainGroupContent, AppLayoutSidebar, AppLayoutSidebarContent, AppLayoutSidebarFooter, AppLayoutSidebarGroup, AppLayoutSidebarGroupAction, AppLayoutSidebarGroupContent, AppLayoutSidebarGroupLabel, AppLayoutSidebarHeader, AppLayoutSidebarInset, AppLayoutSidebarMenu, AppLayoutSidebarMenuAction, AppLayoutSidebarMenuBadge, AppLayoutSidebarMenuButton, AppLayoutSidebarMenuItem, AppLayoutSidebarMenuSkeleton, AppLayoutSidebarMenuSub, AppLayoutSidebarMenuSubButton, AppLayoutSidebarMenuSubItem, AppLayoutSidebarRail, AppLayoutSidebarSeparator, AppLayoutSidebarTrigger, AppLayoutWrapper, Sidebar, SidebarProvider, useSidebar };
173
173
  //# sourceMappingURL=index.d.ts.map
@@ -1,2 +1,2 @@
1
- "use client";import{cn as e}from"../../utils-D9AH0PUV.js";import{Tooltip as t,TooltipContent as n,TooltipProvider as r,TooltipTrigger as i}from"../../tooltip-CaqA5ydI.js";import{Button as a}from"../../button-tXV0dTFU.js";import{Separator as o}from"../../separator-aLdI4FQe.js";import{Sheet as s,SheetContent as c,SheetDescription as l,SheetHeader as u,SheetTitle as d}from"../../sheet-DqPtcv9H.js";import{Skeleton as f}from"../../skeleton-BSi1n1L2.js";import{useIsMobile as p}from"../../use-mobile-CNVZwItd.js";import m from"react";import{jsx as h,jsxs as g}from"react/jsx-runtime";import{cva as _}from"class-variance-authority";import{Slot as v}from"radix-ui";import{MenuIcon as y,ShoppingCartIcon as b}from"lucide-react";const x=m.createContext(null);function S(){let e=m.useContext(x);if(!e)throw Error(`useSidebar must be used within a SidebarProvider.`);return e}function C({defaultOpen:t=!0,open:n,onOpenChange:i,className:a,style:o,children:s,...c}){let l=p(),[u,d]=m.useState(!1),[f,g]=m.useState(t),_=n??f,v=m.useCallback(e=>{let t=typeof e==`function`?e(_):e;i?i(t):g(t),document.cookie=`sidebar_state=${t}; path=/; max-age=604800`},[i,_]),y=m.useCallback(()=>l?d(e=>!e):v(e=>!e),[l,v,d]);m.useEffect(()=>{let e=e=>{e.key===`b`&&(e.metaKey||e.ctrlKey)&&(e.preventDefault(),y())};return window.addEventListener(`keydown`,e),()=>window.removeEventListener(`keydown`,e)},[y]);let b=_?`expanded`:`collapsed`,S=m.useMemo(()=>({state:b,isMobile:l,toggleSidebar:y,open:_,setOpen:v,openMobile:u,setOpenMobile:d}),[b,_,v,l,u,d,y]);return h(x.Provider,{value:S,children:h(r,{delayDuration:0,children:h(`div`,{"data-slot":`sidebar-wrapper`,style:{"--sidebar-width":`16rem`,"--sidebar-width-icon":`3rem`,...o},className:e(`group/sidebar-wrapper`,`has-data-[variant=inset]:bg-sidebar`,`flex h-svh w-full`,a),...c,children:s})})})}function w({side:t=`left`,variant:n=`sidebar`,collapsible:r=`offcanvas`,className:i,children:a,...o}){let{isMobile:f,state:p,openMobile:m,setOpenMobile:_}=S();return r===`none`?h(`aside`,{"data-slot":`sidebar`,className:e(`bg-sidebar`,`text-sidebar-foreground`,`flex h-full w-(--sidebar-width) flex-col`,i),...o,children:a}):f?h(s,{open:m,onOpenChange:_,...o,children:g(c,{"data-sidebar":`sidebar`,"data-slot":`sidebar`,"data-mobile":`true`,className:`bg-sidebar text-sidebar-foreground w-(--sidebar-width) p-0 [&>button]:hidden`,style:{"--sidebar-width":`18rem`},side:t,children:[g(u,{className:`sr-only`,children:[h(d,{children:`Sidebar`}),h(l,{children:`Displays the mobile sidebar.`})]}),h(`div`,{className:`flex h-full w-full flex-col`,children:a})]})}):g(`aside`,{className:`group peer text-sidebar-foreground bg-card hidden md:block`,"data-state":p,"data-collapsible":p===`collapsed`?r:``,"data-variant":n,"data-side":t,"data-slot":`sidebar`,children:[h(`div`,{"data-slot":`sidebar-gap`,className:e(`relative`,`bg-transparent`,`transition-[width] duration-200 ease-linear`,`h-14 w-(--sidebar-width)`,`group-data-[collapsible=offcanvas]:w-0`,`group-data-[side=right]:rotate-180`,n===`floating`||n===`inset`?`group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)+(--spacing(4)))]`:`group-data-[collapsible=icon]:w-(--sidebar-width-icon)`)}),h(`div`,{"data-slot":`sidebar-container`,className:e(`hidden md:flex`,`shadow-nav fixed inset-y-0 top-14 z-10`,`h-[calc(100svh-3.5rem)] w-(--sidebar-width)`,`transition-[left,right,width] duration-200 ease-linear`,t===`left`&&`left-0 group-data-[collapsible=offcanvas]:left-[calc(var(--sidebar-width)*-1)]`,t===`right`&&`right-0 group-data-[collapsible=offcanvas]:right-[calc(var(--sidebar-width)*-1)]`,n===`floating`||n===`inset`?`p-2 group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)+(--spacing(4)))]`:`group-data-[collapsible=icon]:w-(--sidebar-width-icon) group-data-[side=left]:border-r group-data-[side=right]:border-l`,i),...o,children:h(`div`,{"data-sidebar":`sidebar`,"data-slot":`sidebar-inner`,className:e(`flex size-full flex-col`,`group-data-[variant=floating]:rounded-lg`,`group-data-[variant=floating]:border`,`group-data-[variant=floating]:border-sidebar-border`,`group-data-[variant=floating]:shadow-sm`),children:a})})]})}function T({className:t,onClick:n,...r}){let{toggleSidebar:i}=S();return g(a,{"data-sidebar":`trigger`,"data-slot":`sidebar-trigger`,variant:`ghost`,color:`muted`,size:`icon`,className:e(`size-10 rounded-full`,t),onClick:e=>{n?.(e),i()},...r,children:[h(y,{className:`!size-6`}),h(`span`,{className:`sr-only`,children:`Toggle Sidebar`})]})}function E({className:t,...n}){let{toggleSidebar:r}=S();return h(`button`,{"data-sidebar":`rail`,"data-slot":`sidebar-rail`,"aria-label":`Toggle Sidebar`,tabIndex:-1,onClick:r,title:`Toggle Sidebar`,className:e(`absolute inset-y-0 z-20 hidden w-4 -translate-x-1/2 transition-all ease-linear sm:flex`,`after:absolute after:inset-y-0 after:left-1/2 after:w-[2px]`,`group-data-[side=left]:-right-4`,`group-data-[side=right]:left-0`,`in-data-[side=left]:cursor-w-resize`,`in-data-[side=right]:cursor-e-resize`,`hover:after:bg-sidebar-border`,`hover:group-data-[collapsible=offcanvas]:bg-sidebar`,`group-data-[collapsible=offcanvas]:translate-x-0`,`group-data-[collapsible=offcanvas]:after:left-full`,`[[data-side=left][data-state=collapsed]_&]:cursor-e-resize`,`[[data-side=right][data-state=collapsed]_&]:cursor-w-resize`,`[[data-side=left][data-collapsible=offcanvas]_&]:-right-2`,`[[data-side=right][data-collapsible=offcanvas]_&]:-left-2`,t),...n})}function D({className:t,children:n,...r}){return g(`main`,{"data-slot":`sidebar-inset`,className:e(`relative flex w-full flex-1 flex-col`,t),...r,children:[h(`div`,{className:`h-14 w-full`}),h(`div`,{className:e(`flex-1 inset-shadow-sm`),children:n})]})}function O({className:t,...n}){return h(`div`,{"data-slot":`sidebar-header`,"data-sidebar":`header`,className:e(`flex flex-col gap-2 p-2`,t),...n})}function k({className:t,...n}){return h(`div`,{"data-slot":`sidebar-footer`,"data-sidebar":`footer`,className:e(`flex flex-col gap-2 p-2`,t),...n})}function A({className:t,...n}){return h(o,{"data-slot":`sidebar-separator`,"data-sidebar":`separator`,className:e(`bg-sidebar-border mx-2 w-auto`,t),...n})}function j({className:t,...n}){return h(`div`,{"data-slot":`sidebar-content`,"data-sidebar":`content`,className:e(`flex min-h-0 flex-1 flex-col gap-2 overflow-auto group-data-[collapsible=icon]:overflow-hidden`,t),...n})}function M({className:t,...n}){return h(`div`,{"data-slot":`sidebar-group`,"data-sidebar":`group`,className:e(`relative flex w-full min-w-0 flex-col p-2`,t),...n})}function N({className:t,asChild:n=!1,...r}){let i=n?v.Slot:`div`;return h(i,{"data-slot":`sidebar-group-label`,"data-sidebar":`group-label`,className:e(`flex h-8 shrink-0 items-center rounded-md px-2 text-xs font-medium outline-hidden transition-[margin,opacity] duration-200 ease-linear focus-visible:ring-2`,`text-sidebar-foreground/70`,`ring-sidebar-ring`,`[&>svg]:size-4`,`[&>svg]:shrink-0`,`group-data-[collapsible=icon]:-mt-8`,`group-data-[collapsible=icon]:opacity-0`,t),...r})}function P({className:t,asChild:n=!1,...r}){let i=n?v.Slot:`button`;return h(i,{"data-slot":`sidebar-group-action`,"data-sidebar":`group-action`,className:e(`text-sidebar-foreground ring-sidebar-ring hover:bg-sidebar-accent hover:text-sidebar-accent-foreground absolute top-3.5 right-3 flex aspect-square w-5 items-center justify-center rounded-md p-0 outline-hidden transition-transform`,`focus-visible:ring-2`,`[&>svg]:size-4`,`[&>svg]:shrink-0`,`after:absolute after:-inset-2 md:after:hidden`,`group-data-[collapsible=icon]:hidden`,t),...r})}function F({className:t,...n}){return h(`div`,{"data-slot":`sidebar-group-content`,"data-sidebar":`group-content`,className:e(`w-full text-sm`,t),...n})}function I({className:t,...n}){return h(`ul`,{"data-slot":`sidebar-menu`,"data-sidebar":`menu`,className:e(`flex w-full min-w-0 flex-col gap-1`,t),...n})}function L({className:t,...n}){return h(`li`,{"data-slot":`sidebar-menu-item`,"data-sidebar":`menu-item`,className:e(`group/menu-item relative`,t),...n})}const R=_([`peer/menu-button`,`cursor-pointer`,`flex w-full items-center gap-2`,`overflow-hidden rounded-md p-2 text-left text-sm outline-hidden`,`ring-sidebar-ring transition-[width,height,padding]`,`focus-visible:ring-2`,`hover:bg-sidebar-accent`,`hover:text-sidebar-accent-foreground`,`active:bg-sidebar-accent`,`active:text-sidebar-accent-foreground`,`disabled:pointer-events-none`,`disabled:opacity-50`,`group-has-data-[sidebar=menu-action]/menu-item:pr-8`,`aria-disabled:pointer-events-none`,`aria-disabled:opacity-50`,`data-[active=true]:bg-sidebar-accent`,`data-[active=true]:font-medium`,`data-[active=true]:text-sidebar-accent-foreground`,`data-[state=open]:hover:bg-sidebar-accent`,`data-[state=open]:hover:text-sidebar-accent-foreground`,`group-data-[collapsible=icon]:size-8!`,`group-data-[collapsible=icon]:p-2!`,`[&>span:last-child]:truncate`,`[&>svg]:size-4`,`[&>svg]:shrink-0`],{variants:{variant:{default:`hover:bg-sidebar-accent hover:text-sidebar-accent-foreground`,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))]`},size:{default:`h-8 text-sm`,sm:`h-7 text-xs`,lg:`h-12 text-sm group-data-[collapsible=icon]:p-0!`}},defaultVariants:{variant:`default`,size:`default`}});function z({asChild:r=!1,isActive:a=!1,variant:o=`default`,size:s=`default`,tooltip:c,className:l,...u}){let d=r?v.Slot:`button`,{isMobile:f,state:p}=S(),m=h(d,{"data-slot":`sidebar-menu-button`,"data-sidebar":`menu-button`,"data-size":s,"data-active":a,className:e(R({variant:o,size:s}),l),...u});return c?(typeof c==`string`&&(c={children:c}),g(t,{children:[h(i,{asChild:!0,children:m}),h(n,{side:`right`,align:`center`,hidden:p!==`collapsed`||f,...c})]})):m}function B({className:t,asChild:n=!1,showOnHover:r=!1,...i}){let a=n?v.Slot:`button`;return h(a,{"data-slot":`sidebar-menu-action`,"data-sidebar":`menu-action`,className:e(`text-sidebar-foreground ring-sidebar-ring hover:bg-sidebar-accent hover:text-sidebar-accent-foreground peer-hover/menu-button:text-sidebar-accent-foreground absolute top-1.5 right-1 flex aspect-square w-5 items-center justify-center rounded-md p-0 outline-hidden transition-transform`,`focus-visible:ring-2`,`[&>svg]:size-4`,`[&>svg]:shrink-0`,`after:absolute after:-inset-2 md:after:hidden`,`peer-data-[size=sm]/menu-button:top-1`,`peer-data-[size=default]/menu-button:top-1.5`,`peer-data-[size=lg]/menu-button:top-2.5`,`group-data-[collapsible=icon]:hidden`,r&&`peer-data-[active=true]/menu-button:text-sidebar-accent-foreground`,r&&`group-focus-within/menu-item:opacity-100`,r&&`group-hover/menu-item:opacity-100`,r&&`data-[state=open]:opacity-100 md:opacity-0`,t),...i})}function V({className:t,...n}){return h(`div`,{"data-slot":`sidebar-menu-badge`,"data-sidebar":`menu-badge`,className:e(`text-sidebar-foreground pointer-events-none absolute right-1 flex h-5 min-w-5 items-center justify-center rounded-md px-1 text-xs font-medium tabular-nums select-none`,`peer-hover/menu-button:text-sidebar-accent-foreground`,`peer-data-[active=true]/menu-button:text-sidebar-accent-foreground`,`peer-data-[size=sm]/menu-button:top-1`,`peer-data-[size=default]/menu-button:top-1.5`,`peer-data-[size=lg]/menu-button:top-2.5`,`group-data-[collapsible=icon]:hidden`,t),...n})}function H({className:t,showIcon:n=!1,...r}){let i=m.useMemo(()=>`${Math.floor(Math.random()*40)+50}%`,[]);return g(`div`,{"data-slot":`sidebar-menu-skeleton`,"data-sidebar":`menu-skeleton`,className:e(`flex h-8 items-center gap-2 rounded-md px-2`,t),...r,children:[n&&h(f,{className:`size-4 rounded-md`,"data-sidebar":`menu-skeleton-icon`}),h(f,{className:`h-4 max-w-(--skeleton-width) flex-1`,"data-sidebar":`menu-skeleton-text`,style:{"--skeleton-width":i}})]})}function U({className:t,...n}){return h(`ul`,{"data-slot":`sidebar-menu-sub`,"data-sidebar":`menu-sub`,className:e(`border-sidebar-border mx-3.5 flex min-w-0 translate-x-px flex-col gap-1 border-l px-2.5 py-0.5`,`group-data-[collapsible=icon]:hidden`,t),...n})}function W({className:t,...n}){return h(`li`,{"data-slot":`sidebar-menu-sub-item`,"data-sidebar":`menu-sub-item`,className:e(`group/menu-sub-item relative`,t),...n})}function G({asChild:t=!1,size:n=`md`,isActive:r=!1,className:i,...a}){let o=t?v.Slot:`a`;return h(o,{"data-slot":`sidebar-menu-sub-button`,"data-sidebar":`menu-sub-button`,"data-size":n,"data-active":r,className:e(`text-sidebar-foreground`,`ring-sidebar-ring`,`flex h-7 min-w-0 -translate-x-px items-center gap-2 overflow-hidden rounded-md px-2 outline-hidden`,`focus-visible:ring-2`,`hover:bg-sidebar-accent`,`hover:text-sidebar-accent-foreground`,`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`,`[&>svg]:size-4`,`[&>svg]:shrink-0`,`[&>svg]:text-sidebar-accent-foreground`,`[&>span:last-child]:truncate`,`data-[active=true]:bg-sidebar-accent`,`data-[active=true]:text-sidebar-accent-foreground`,n===`sm`&&`text-xs`,n===`md`&&`text-sm`,`group-data-[collapsible=icon]:hidden`,i),...a})}const K=({children:e})=>h(C,{children:e}),q=({children:t})=>g(`header`,{className:e(`bg-card`,`h-(--header-height)`,`absolute inset-x-0 top-0 z-20 gap-2 px-4`,`shadow-nav flex items-center`,`transition-[width,height] ease-linear`,`group-has-data-[collapsible=icon]/sidebar-wrapper:h-(--header-height)`),children:[h(T,{}),g(`div`,{className:`ml-2.5 flex gap-x-2`,children:[h(`div`,{className:`bg-sidebar-primary text-sidebar-primary-foreground flex aspect-square size-8 items-center justify-center rounded-lg`,children:h(b,{size:20})}),g(`div`,{className:`grid flex-1 text-left text-sm leading-tight`,children:[h(`span`,{className:`truncate font-medium`,children:`Lunas Store`}),h(`span`,{className:`truncate text-xs`,children:`Established 2023`})]})]}),h(`div`,{className:`flex flex-1 items-center justify-end`,children:t})]}),J=({children:e,...t})=>h(w,{variant:`inset`,collapsible:`icon`,...t,children:e}),Y=({children:e})=>h(D,{children:h(`section`,{className:`relative size-full`,children:h(`div`,{className:`absolute inset-0`,children:e})})}),X=({children:t,className:n})=>h(`div`,{"data-slot":`main-group`,className:e(`flex size-full flex-col gap-4 overflow-y-auto p-4`,n),children:t}),Z=({children:e})=>h(`div`,{"data-slot":`main-group-content`,className:`bg-card shadow-card size-full rounded-md p-4`,children:e});export{q as AppLayoutHeader,Y as AppLayoutMain,X as AppLayoutMainGroup,Z as AppLayoutMainGroupContent,J as AppLayoutSidebar,K as AppLayoutWrapper,w as Sidebar,j as SidebarContent,k as SidebarFooter,M as SidebarGroup,P as SidebarGroupAction,F as SidebarGroupContent,N as SidebarGroupLabel,O as SidebarHeader,D as SidebarInset,I as SidebarMenu,B as SidebarMenuAction,V as SidebarMenuBadge,z as SidebarMenuButton,L as SidebarMenuItem,H as SidebarMenuSkeleton,U as SidebarMenuSub,G as SidebarMenuSubButton,W as SidebarMenuSubItem,C as SidebarProvider,E as SidebarRail,A as SidebarSeparator,T as SidebarTrigger,S as useSidebar};
1
+ "use client";import{cn as e}from"../../utils-D9AH0PUV.js";import{Tooltip as t,TooltipContent as n,TooltipProvider as r,TooltipTrigger as i}from"../../tooltip-CaqA5ydI.js";import{Button as a}from"../../button-tXV0dTFU.js";import{Separator as o}from"../../separator-aLdI4FQe.js";import{Sheet as s,SheetContent as c,SheetDescription as l,SheetHeader as u,SheetTitle as d}from"../../sheet-DqPtcv9H.js";import{Skeleton as f}from"../../skeleton-BSi1n1L2.js";import{useIsMobile as p}from"../../use-mobile-CNVZwItd.js";import m from"react";import{jsx as h,jsxs as g}from"react/jsx-runtime";import{cva as _}from"class-variance-authority";import{Slot as v}from"radix-ui";import{MenuIcon as y,ShoppingCartIcon as b}from"lucide-react";const x=m.createContext(null);function S(){let e=m.useContext(x);if(!e)throw Error(`useSidebar must be used within a SidebarProvider.`);return e}function C({defaultOpen:t=!0,open:n,onOpenChange:i,className:a,style:o,children:s,...c}){let l=p(),[u,d]=m.useState(!1),[f,g]=m.useState(t),_=n??f,v=m.useCallback(e=>{let t=typeof e==`function`?e(_):e;i?i(t):g(t),document.cookie=`sidebar_state=${t}; path=/; max-age=604800`},[i,_]),y=m.useCallback(()=>l?d(e=>!e):v(e=>!e),[l,v,d]);m.useEffect(()=>{let e=e=>{e.key===`b`&&(e.metaKey||e.ctrlKey)&&(e.preventDefault(),y())};return window.addEventListener(`keydown`,e),()=>window.removeEventListener(`keydown`,e)},[y]);let b=_?`expanded`:`collapsed`,S=m.useMemo(()=>({state:b,isMobile:l,toggleSidebar:y,open:_,setOpen:v,openMobile:u,setOpenMobile:d}),[b,_,v,l,u,d,y]);return h(x.Provider,{value:S,children:h(r,{delayDuration:0,children:h(`div`,{"data-slot":`sidebar-wrapper`,style:{"--sidebar-width":`16rem`,"--sidebar-width-icon":`3rem`,...o},className:e(`group/sidebar-wrapper`,`has-data-[variant=inset]:bg-sidebar`,`flex h-svh w-full`,a),...c,children:s})})})}function w({side:t=`left`,variant:n=`sidebar`,collapsible:r=`offcanvas`,className:i,children:a,...o}){let{isMobile:f,state:p,openMobile:m,setOpenMobile:_}=S();return r===`none`?h(`aside`,{"data-slot":`sidebar`,className:e(`bg-sidebar`,`text-sidebar-foreground`,`flex h-full w-(--sidebar-width) flex-col`,i),...o,children:a}):f?h(s,{open:m,onOpenChange:_,...o,children:g(c,{"data-sidebar":`sidebar`,"data-slot":`sidebar`,"data-mobile":`true`,className:`bg-sidebar text-sidebar-foreground w-(--sidebar-width) p-0 [&>button]:hidden`,style:{"--sidebar-width":`18rem`},side:t,children:[g(u,{className:`sr-only`,children:[h(d,{children:`Sidebar`}),h(l,{children:`Displays the mobile sidebar.`})]}),h(`div`,{className:`flex h-full w-full flex-col`,children:a})]})}):g(`aside`,{className:`group peer text-sidebar-foreground bg-card hidden md:block`,"data-state":p,"data-collapsible":p===`collapsed`?r:``,"data-variant":n,"data-side":t,"data-slot":`sidebar`,children:[h(`div`,{"data-slot":`sidebar-gap`,className:e(`relative`,`bg-transparent`,`transition-[width] duration-200 ease-linear`,`h-14 w-(--sidebar-width)`,`group-data-[collapsible=offcanvas]:w-0`,`group-data-[side=right]:rotate-180`,n===`floating`||n===`inset`?`group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)+(--spacing(4)))]`:`group-data-[collapsible=icon]:w-(--sidebar-width-icon)`)}),h(`div`,{"data-slot":`sidebar-container`,className:e(`hidden md:flex`,`shadow-nav fixed inset-y-0 top-14 z-10`,`h-[calc(100svh-3.5rem)] w-(--sidebar-width)`,`transition-[left,right,width] duration-200 ease-linear`,t===`left`&&`left-0 group-data-[collapsible=offcanvas]:left-[calc(var(--sidebar-width)*-1)]`,t===`right`&&`right-0 group-data-[collapsible=offcanvas]:right-[calc(var(--sidebar-width)*-1)]`,n===`floating`||n===`inset`?`p-2 group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)+(--spacing(4)))]`:`group-data-[collapsible=icon]:w-(--sidebar-width-icon) group-data-[side=left]:border-r group-data-[side=right]:border-l`,i),...o,children:h(`div`,{"data-sidebar":`sidebar`,"data-slot":`sidebar-inner`,className:e(`flex size-full flex-col`,`group-data-[variant=floating]:rounded-lg`,`group-data-[variant=floating]:border`,`group-data-[variant=floating]:border-sidebar-border`,`group-data-[variant=floating]:shadow-sm`),children:a})})]})}function T({className:t,onClick:n,...r}){let{toggleSidebar:i}=S();return g(a,{"data-sidebar":`trigger`,"data-slot":`sidebar-trigger`,variant:`ghost`,color:`muted`,size:`icon`,className:e(`size-10 rounded-full`,t),onClick:e=>{n?.(e),i()},...r,children:[h(y,{className:`!size-6`}),h(`span`,{className:`sr-only`,children:`Toggle Sidebar`})]})}function E({className:t,...n}){let{toggleSidebar:r}=S();return h(`button`,{"data-sidebar":`rail`,"data-slot":`sidebar-rail`,"aria-label":`Toggle Sidebar`,tabIndex:-1,onClick:r,title:`Toggle Sidebar`,className:e(`absolute inset-y-0 z-20 hidden w-4 -translate-x-1/2 transition-all ease-linear sm:flex`,`after:absolute after:inset-y-0 after:left-1/2 after:w-[2px]`,`group-data-[side=left]:-right-4`,`group-data-[side=right]:left-0`,`in-data-[side=left]:cursor-w-resize`,`in-data-[side=right]:cursor-e-resize`,`hover:after:bg-sidebar-border`,`hover:group-data-[collapsible=offcanvas]:bg-sidebar`,`group-data-[collapsible=offcanvas]:translate-x-0`,`group-data-[collapsible=offcanvas]:after:left-full`,`[[data-side=left][data-state=collapsed]_&]:cursor-e-resize`,`[[data-side=right][data-state=collapsed]_&]:cursor-w-resize`,`[[data-side=left][data-collapsible=offcanvas]_&]:-right-2`,`[[data-side=right][data-collapsible=offcanvas]_&]:-left-2`,t),...n})}function D({className:t,children:n,...r}){return g(`main`,{"data-slot":`sidebar-inset`,className:e(`relative flex w-full flex-1 flex-col`,t),...r,children:[h(`div`,{className:`h-14 w-full`}),h(`div`,{className:e(`flex-1 inset-shadow-sm`),children:n})]})}function O({className:t,...n}){return h(`div`,{"data-slot":`sidebar-header`,"data-sidebar":`header`,className:e(`flex flex-col gap-2 p-2`,t),...n})}function k({className:t,...n}){return h(`div`,{"data-slot":`sidebar-footer`,"data-sidebar":`footer`,className:e(`flex flex-col gap-2 p-2`,t),...n})}function A({className:t,...n}){return h(o,{"data-slot":`sidebar-separator`,"data-sidebar":`separator`,className:e(`bg-sidebar-border mx-2 w-auto`,t),...n})}function j({className:t,...n}){return h(`div`,{"data-slot":`sidebar-content`,"data-sidebar":`content`,className:e(`flex min-h-0 flex-1 flex-col gap-2 overflow-auto group-data-[collapsible=icon]:overflow-hidden`,t),...n})}function M({className:t,...n}){return h(`div`,{"data-slot":`sidebar-group`,"data-sidebar":`group`,className:e(`relative flex w-full min-w-0 flex-col p-2`,t),...n})}function N({className:t,asChild:n=!1,...r}){let i=n?v.Slot:`div`;return h(i,{"data-slot":`sidebar-group-label`,"data-sidebar":`group-label`,className:e(`flex h-8 shrink-0 items-center rounded-md px-2 text-xs font-medium outline-hidden transition-[margin,opacity] duration-200 ease-linear focus-visible:ring-2`,`text-sidebar-foreground/70`,`ring-sidebar-ring`,`[&>svg]:size-4`,`[&>svg]:shrink-0`,`group-data-[collapsible=icon]:-mt-8`,`group-data-[collapsible=icon]:opacity-0`,t),...r})}function P({className:t,asChild:n=!1,...r}){let i=n?v.Slot:`button`;return h(i,{"data-slot":`sidebar-group-action`,"data-sidebar":`group-action`,className:e(`text-sidebar-foreground ring-sidebar-ring hover:bg-sidebar-accent hover:text-sidebar-accent-foreground absolute top-3.5 right-3 flex aspect-square w-5 items-center justify-center rounded-md p-0 outline-hidden transition-transform`,`focus-visible:ring-2`,`[&>svg]:size-4`,`[&>svg]:shrink-0`,`after:absolute after:-inset-2 md:after:hidden`,`group-data-[collapsible=icon]:hidden`,t),...r})}function F({className:t,...n}){return h(`div`,{"data-slot":`sidebar-group-content`,"data-sidebar":`group-content`,className:e(`w-full text-sm`,t),...n})}function I({className:t,...n}){return h(`ul`,{"data-slot":`sidebar-menu`,"data-sidebar":`menu`,className:e(`flex w-full min-w-0 flex-col gap-1`,t),...n})}function L({className:t,...n}){return h(`li`,{"data-slot":`sidebar-menu-item`,"data-sidebar":`menu-item`,className:e(`group/menu-item relative`,t),...n})}const R=_([`peer/menu-button`,`cursor-pointer`,`flex w-full items-center gap-2`,`overflow-hidden rounded-md p-2 outline-hidden`,`text-left truncate`,`transition-[color,width,height,padding]`,`hover:bg-sidebar-accent`,`hover:text-sidebar-accent-foreground`,`active:bg-sidebar-accent`,`active:text-sidebar-accent-foreground`,`disabled:pointer-events-none`,`disabled:opacity-50`,`group-has-data-[sidebar=menu-action]/menu-item:pr-8`,`aria-disabled:pointer-events-none`,`aria-disabled:opacity-50`,`data-[active=true]:bg-sidebar-primary-muted`,`data-[active=true]:font-medium`,`data-[active=true]:text-sidebar-primary`,`data-[state=open]:hover:bg-sidebar-accent`,`data-[state=open]:hover:text-sidebar-accent-foreground`,`group-data-[collapsible=icon]:size-8!`,`group-data-[collapsible=icon]:p-2!`,`[&>svg]:size-4`,`[&>svg]:shrink-0`,`[&>span:last-child]:truncate`],{variants:{variant:{default:`hover:bg-sidebar-accent/60 hover:text-sidebar-accent-foreground/80`,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))]`},size:{default:`h-8 text-sm`,sm:`h-7 text-xs`,lg:`h-12 text-sm group-data-[collapsible=icon]:p-0!`}},defaultVariants:{variant:`default`,size:`default`}});function z({asChild:r=!1,isActive:a=!1,variant:o=`default`,size:s=`default`,tooltip:c,className:l,...u}){let d=r?v.Slot:`button`,{isMobile:f,state:p}=S(),m=h(d,{"data-slot":`sidebar-menu-button`,"data-sidebar":`menu-button`,"data-size":s,"data-active":a,className:e(R({variant:o,size:s}),l),...u});return c?(typeof c==`string`&&(c={children:c}),g(t,{children:[h(i,{asChild:!0,children:m}),h(n,{side:`right`,align:`center`,hidden:p!==`collapsed`||f,...c})]})):m}function B({className:t,asChild:n=!1,showOnHover:r=!1,...i}){let a=n?v.Slot:`button`;return h(a,{"data-slot":`sidebar-menu-action`,"data-sidebar":`menu-action`,className:e(`text-sidebar-foreground ring-sidebar-ring hover:bg-sidebar-accent hover:text-sidebar-accent-foreground peer-hover/menu-button:text-sidebar-accent-foreground absolute top-1.5 right-1 flex aspect-square w-5 items-center justify-center rounded-md p-0 outline-hidden transition-transform`,`focus-visible:ring-2`,`[&>svg]:size-4`,`[&>svg]:shrink-0`,`after:absolute after:-inset-2 md:after:hidden`,`peer-data-[size=sm]/menu-button:top-1`,`peer-data-[size=default]/menu-button:top-1.5`,`peer-data-[size=lg]/menu-button:top-2.5`,`group-data-[collapsible=icon]:hidden`,r&&`peer-data-[active=true]/menu-button:text-sidebar-accent-foreground`,r&&`group-focus-within/menu-item:opacity-100`,r&&`group-hover/menu-item:opacity-100`,r&&`data-[state=open]:opacity-100 md:opacity-0`,t),...i})}function V({className:t,...n}){return h(`div`,{"data-slot":`sidebar-menu-badge`,"data-sidebar":`menu-badge`,className:e(`text-sidebar-foreground pointer-events-none absolute right-1 flex h-5 min-w-5 items-center justify-center rounded-md px-1 text-xs font-medium tabular-nums select-none`,`peer-hover/menu-button:text-sidebar-accent-foreground`,`peer-data-[active=true]/menu-button:text-sidebar-accent-foreground`,`peer-data-[size=sm]/menu-button:top-1`,`peer-data-[size=default]/menu-button:top-1.5`,`peer-data-[size=lg]/menu-button:top-2.5`,`group-data-[collapsible=icon]:hidden`,t),...n})}function H({className:t,showIcon:n=!1,...r}){let i=m.useMemo(()=>`${Math.floor(Math.random()*40)+50}%`,[]);return g(`div`,{"data-slot":`sidebar-menu-skeleton`,"data-sidebar":`menu-skeleton`,className:e(`flex h-8 items-center gap-2 rounded-md px-2`,t),...r,children:[n&&h(f,{className:`size-4 rounded-md`,"data-sidebar":`menu-skeleton-icon`}),h(f,{className:`h-4 max-w-(--skeleton-width) flex-1`,"data-sidebar":`menu-skeleton-text`,style:{"--skeleton-width":i}})]})}function U({className:t,...n}){return h(`ul`,{"data-slot":`sidebar-menu-sub`,"data-sidebar":`menu-sub`,className:e(`border-sidebar-border mx-3.5 flex min-w-0 translate-x-px flex-col gap-1 border-l px-2.5 py-0.5`,`group-data-[collapsible=icon]:hidden`,t),...n})}function W({className:t,...n}){return h(`li`,{"data-slot":`sidebar-menu-sub-item`,"data-sidebar":`menu-sub-item`,className:e(`group/menu-sub-item relative`,t),...n})}function G({asChild:t=!1,size:n=`md`,isActive:r=!1,className:i,...a}){let o=t?v.Slot:`a`;return h(o,{"data-slot":`sidebar-menu-sub-button`,"data-sidebar":`menu-sub-button`,"data-size":n,"data-active":r,className:e(`text-sidebar-foreground`,`ring-sidebar-ring`,`flex h-7 min-w-0 -translate-x-px items-center gap-2 overflow-hidden rounded-md px-2 outline-hidden`,`focus-visible:ring-2`,`hover:bg-sidebar-accent`,`hover:text-sidebar-accent-foreground`,`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`,`[&>svg]:size-4`,`[&>svg]:shrink-0`,`[&>svg]:text-sidebar-accent-foreground`,`[&>span:last-child]:truncate`,`data-[active=true]:bg-sidebar-accent`,`data-[active=true]:text-sidebar-accent-foreground`,n===`sm`&&`text-xs`,n===`md`&&`text-sm`,`group-data-[collapsible=icon]:hidden`,i),...a})}const K=({children:e})=>h(C,{children:e}),q=({children:t})=>g(`header`,{className:e(`bg-card`,`h-(--header-height)`,`absolute inset-x-0 top-0 z-20 gap-2 px-4`,`shadow-nav flex items-center`,`transition-[width,height] ease-linear`,`group-has-data-[collapsible=icon]/sidebar-wrapper:h-(--header-height)`),children:[h(T,{}),g(`div`,{className:`ml-2.5 flex gap-x-2`,children:[h(`div`,{className:`bg-sidebar-primary text-sidebar-primary-foreground flex aspect-square size-8 items-center justify-center rounded-lg`,children:h(b,{size:20})}),g(`div`,{className:`grid flex-1 text-left text-sm leading-tight`,children:[h(`span`,{className:`truncate font-medium`,children:`Lunas Store`}),h(`span`,{className:`truncate text-xs`,children:`Established 2023`})]})]}),h(`div`,{className:`flex flex-1 items-center justify-end`,children:t})]}),J=({children:e,...t})=>h(w,{variant:`inset`,collapsible:`icon`,...t,children:e}),Y=({children:e})=>h(D,{children:h(`section`,{className:`relative size-full`,children:h(`div`,{className:`absolute inset-0`,children:e})})}),X=({children:t,className:n})=>h(`div`,{"data-slot":`main-group`,className:e(`flex size-full flex-col gap-4 overflow-y-auto p-4`,n),children:t}),Z=({children:e})=>h(`div`,{"data-slot":`main-group-content`,className:`bg-card shadow-card size-full rounded-md p-4`,children:e});export{q as AppLayoutHeader,Y as AppLayoutMain,X as AppLayoutMainGroup,Z as AppLayoutMainGroupContent,J as AppLayoutSidebar,j as AppLayoutSidebarContent,k as AppLayoutSidebarFooter,M as AppLayoutSidebarGroup,P as AppLayoutSidebarGroupAction,F as AppLayoutSidebarGroupContent,N as AppLayoutSidebarGroupLabel,O as AppLayoutSidebarHeader,D as AppLayoutSidebarInset,I as AppLayoutSidebarMenu,B as AppLayoutSidebarMenuAction,V as AppLayoutSidebarMenuBadge,z as AppLayoutSidebarMenuButton,L as AppLayoutSidebarMenuItem,H as AppLayoutSidebarMenuSkeleton,U as AppLayoutSidebarMenuSub,G as AppLayoutSidebarMenuSubButton,W as AppLayoutSidebarMenuSubItem,E as AppLayoutSidebarRail,A as AppLayoutSidebarSeparator,T as AppLayoutSidebarTrigger,K as AppLayoutWrapper,w as Sidebar,C as SidebarProvider,S as useSidebar};
2
2
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","names":["open","Separator","SlotPrimitive","Tooltip","AppLayoutWrapper: React.FC<React.PropsWithChildren>","AppLayoutHeader: React.FC<React.PropsWithChildren>","AppLayoutSidebar: React.FC<React.PropsWithChildren & React.ComponentProps<typeof Sidebar>>","AppLayoutMain: React.FC<React.PropsWithChildren>","AppLayoutMainGroup: React.FC<React.PropsWithChildren<{ className?: string }>>","AppLayoutMainGroupContent: React.FC<React.PropsWithChildren>"],"sources":["../../../packages/components/layouts/app-layout/sidebar.tsx","../../../packages/components/layouts/app-layout/index.tsx"],"sourcesContent":["import React from 'react'\nimport { Slot as SlotPrimitive } from 'radix-ui'\nimport { cva, type VariantProps } from 'class-variance-authority'\nimport { MenuIcon } from 'lucide-react'\n\nimport { Button } from '@/components/ui/button'\nimport { Separator } from '@/components/ui/separator'\nimport { Sheet, SheetContent, SheetDescription, SheetHeader, SheetTitle } from '@/components/ui/sheet'\nimport { Skeleton } from '@/components/ui/skeleton'\nimport { TooltipProvider } from '@/components/ui/tooltip'\nimport { Tooltip, TooltipContent, TooltipTrigger } from '@/components/ui/tooltip'\n\nimport { useIsMobile } from '@/hooks/use-mobile'\nimport { cn } from '@/lib/utils'\n\nconst SIDEBAR_COOKIE_NAME = 'sidebar_state'\nconst SIDEBAR_COOKIE_MAX_AGE = 60 * 60 * 24 * 7\nconst SIDEBAR_WIDTH = '16rem'\nconst SIDEBAR_WIDTH_MOBILE = '18rem'\nconst SIDEBAR_WIDTH_ICON = '3rem'\nconst SIDEBAR_KEYBOARD_SHORTCUT = 'b'\n\ntype SidebarContextProps = {\n state: 'expanded' | 'collapsed'\n open: boolean\n setOpen: (open: boolean) => void\n openMobile: boolean\n setOpenMobile: (open: boolean) => void\n isMobile: boolean\n toggleSidebar: () => void\n}\n\nconst SidebarContext = React.createContext<SidebarContextProps | null>(null)\n\nfunction useSidebar() {\n const context = React.useContext(SidebarContext)\n if (!context) {\n throw new Error('useSidebar must be used within a SidebarProvider.')\n }\n\n return context\n}\n\nfunction SidebarProvider({\n defaultOpen = true,\n open: openProp,\n onOpenChange: setOpenProp,\n className,\n style,\n children,\n ...props\n}: React.ComponentProps<'div'> & {\n defaultOpen?: boolean\n open?: boolean\n onOpenChange?: (open: boolean) => void\n}) {\n const isMobile = useIsMobile()\n const [openMobile, setOpenMobile] = React.useState(false)\n\n // This is the internal state of the sidebar.\n // We use openProp and setOpenProp for control from outside the component.\n const [_open, _setOpen] = React.useState(defaultOpen)\n const open = openProp ?? _open\n const setOpen = React.useCallback(\n (value: boolean | ((value: boolean) => boolean)) => {\n const openState = typeof value === 'function' ? value(open) : value\n if (setOpenProp) {\n setOpenProp(openState)\n } else {\n _setOpen(openState)\n }\n\n // This sets the cookie to keep the sidebar state.\n document.cookie = `${SIDEBAR_COOKIE_NAME}=${openState}; path=/; max-age=${SIDEBAR_COOKIE_MAX_AGE}`\n },\n [setOpenProp, open],\n )\n\n // Helper to toggle the sidebar.\n const toggleSidebar = React.useCallback(() => {\n return isMobile ? setOpenMobile((open) => !open) : setOpen((open) => !open)\n }, [isMobile, setOpen, setOpenMobile])\n\n // Adds a keyboard shortcut to toggle the sidebar.\n React.useEffect(() => {\n const handleKeyDown = (event: KeyboardEvent) => {\n if (event.key === SIDEBAR_KEYBOARD_SHORTCUT && (event.metaKey || event.ctrlKey)) {\n event.preventDefault()\n toggleSidebar()\n }\n }\n\n window.addEventListener('keydown', handleKeyDown)\n return () => window.removeEventListener('keydown', handleKeyDown)\n }, [toggleSidebar])\n\n // We add a state so that we can do data-state=\"expanded\" or \"collapsed\".\n // This makes it easier to style the sidebar with Tailwind classes.\n const state = open ? 'expanded' : 'collapsed'\n\n const contextValue = React.useMemo<SidebarContextProps>(\n () => ({\n state,\n isMobile,\n\n toggleSidebar,\n\n open,\n setOpen,\n\n openMobile,\n setOpenMobile,\n }),\n [state, open, setOpen, isMobile, openMobile, setOpenMobile, toggleSidebar],\n )\n\n return (\n <SidebarContext.Provider value={contextValue}>\n <TooltipProvider delayDuration={0}>\n <div\n data-slot=\"sidebar-wrapper\"\n style={\n {\n '--sidebar-width': SIDEBAR_WIDTH,\n '--sidebar-width-icon': SIDEBAR_WIDTH_ICON,\n ...style,\n } as React.CSSProperties\n }\n className={cn('group/sidebar-wrapper', 'has-data-[variant=inset]:bg-sidebar', 'flex h-svh w-full', className)}\n {...props}\n >\n {children}\n </div>\n </TooltipProvider>\n </SidebarContext.Provider>\n )\n}\n\nfunction Sidebar({\n side = 'left',\n variant = 'sidebar',\n collapsible = 'offcanvas',\n className,\n children,\n ...props\n}: React.ComponentProps<'div'> & {\n side?: 'left' | 'right'\n variant?: 'sidebar' | 'floating' | 'inset'\n collapsible?: 'offcanvas' | 'icon' | 'none'\n}) {\n const { isMobile, state, openMobile, setOpenMobile } = useSidebar()\n\n if (collapsible === 'none') {\n return (\n <aside data-slot=\"sidebar\" className={cn('bg-sidebar', 'text-sidebar-foreground', 'flex h-full w-(--sidebar-width) flex-col', className)} {...props}>\n {children}\n </aside>\n )\n }\n\n if (isMobile) {\n return (\n <Sheet open={openMobile} onOpenChange={setOpenMobile} {...props}>\n <SheetContent\n data-sidebar=\"sidebar\"\n data-slot=\"sidebar\"\n data-mobile=\"true\"\n className=\"bg-sidebar text-sidebar-foreground w-(--sidebar-width) p-0 [&>button]:hidden\"\n style={\n {\n '--sidebar-width': SIDEBAR_WIDTH_MOBILE,\n } as React.CSSProperties\n }\n side={side}\n >\n <SheetHeader className=\"sr-only\">\n <SheetTitle>Sidebar</SheetTitle>\n <SheetDescription>Displays the mobile sidebar.</SheetDescription>\n </SheetHeader>\n <div className=\"flex h-full w-full flex-col\">{children}</div>\n </SheetContent>\n </Sheet>\n )\n }\n\n return (\n <aside\n className=\"group peer text-sidebar-foreground bg-card hidden md:block\"\n data-state={state}\n data-collapsible={state === 'collapsed' ? collapsible : ''}\n data-variant={variant}\n data-side={side}\n data-slot=\"sidebar\"\n >\n {/* This is what handles the sidebar gap on desktop */}\n <div\n data-slot=\"sidebar-gap\"\n className={cn(\n 'relative',\n 'bg-transparent',\n 'transition-[width] duration-200 ease-linear',\n 'h-14 w-(--sidebar-width)',\n 'group-data-[collapsible=offcanvas]:w-0',\n 'group-data-[side=right]:rotate-180',\n variant === 'floating' || variant === 'inset'\n ? 'group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)+(--spacing(4)))]'\n : 'group-data-[collapsible=icon]:w-(--sidebar-width-icon)',\n )}\n />\n <div\n data-slot=\"sidebar-container\"\n className={cn(\n 'hidden md:flex',\n 'shadow-nav fixed inset-y-0 top-14 z-10',\n 'h-[calc(100svh-3.5rem)] w-(--sidebar-width)',\n 'transition-[left,right,width] duration-200 ease-linear',\n side === 'left' && 'left-0 group-data-[collapsible=offcanvas]:left-[calc(var(--sidebar-width)*-1)]',\n side === 'right' && 'right-0 group-data-[collapsible=offcanvas]:right-[calc(var(--sidebar-width)*-1)]',\n // Adjust the padding for floating and inset variants.\n variant === 'floating' || variant === 'inset'\n ? 'p-2 group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)+(--spacing(4)))]'\n : 'group-data-[collapsible=icon]:w-(--sidebar-width-icon) group-data-[side=left]:border-r group-data-[side=right]:border-l',\n className,\n )}\n {...props}\n >\n <div\n data-sidebar=\"sidebar\"\n data-slot=\"sidebar-inner\"\n className={cn(\n 'flex size-full flex-col',\n 'group-data-[variant=floating]:rounded-lg',\n 'group-data-[variant=floating]:border',\n 'group-data-[variant=floating]:border-sidebar-border',\n 'group-data-[variant=floating]:shadow-sm',\n )}\n >\n {children}\n </div>\n </div>\n </aside>\n )\n}\n\nfunction SidebarTrigger({ className, onClick, ...props }: React.ComponentProps<typeof Button>) {\n const { toggleSidebar } = useSidebar()\n\n return (\n <Button\n data-sidebar=\"trigger\"\n data-slot=\"sidebar-trigger\"\n variant=\"ghost\"\n color=\"muted\"\n size=\"icon\"\n className={cn('size-10 rounded-full', className)}\n onClick={(event) => {\n onClick?.(event)\n toggleSidebar()\n }}\n {...props}\n >\n <MenuIcon className=\"!size-6\" />\n <span className=\"sr-only\">Toggle Sidebar</span>\n </Button>\n )\n}\n\nfunction SidebarRail({ className, ...props }: React.ComponentProps<'button'>) {\n const { toggleSidebar } = useSidebar()\n\n return (\n <button\n data-sidebar=\"rail\"\n data-slot=\"sidebar-rail\"\n aria-label=\"Toggle Sidebar\"\n tabIndex={-1}\n onClick={toggleSidebar}\n title=\"Toggle Sidebar\"\n className={cn(\n 'absolute inset-y-0 z-20 hidden w-4 -translate-x-1/2 transition-all ease-linear sm:flex',\n 'after:absolute after:inset-y-0 after:left-1/2 after:w-[2px]',\n 'group-data-[side=left]:-right-4',\n 'group-data-[side=right]:left-0',\n 'in-data-[side=left]:cursor-w-resize',\n 'in-data-[side=right]:cursor-e-resize',\n 'hover:after:bg-sidebar-border',\n 'hover:group-data-[collapsible=offcanvas]:bg-sidebar',\n 'group-data-[collapsible=offcanvas]:translate-x-0',\n 'group-data-[collapsible=offcanvas]:after:left-full',\n '[[data-side=left][data-state=collapsed]_&]:cursor-e-resize',\n '[[data-side=right][data-state=collapsed]_&]:cursor-w-resize',\n '[[data-side=left][data-collapsible=offcanvas]_&]:-right-2',\n '[[data-side=right][data-collapsible=offcanvas]_&]:-left-2',\n className,\n )}\n {...props}\n />\n )\n}\n\nfunction SidebarInset({ className, children, ...props }: React.ComponentProps<'main'>) {\n return (\n <main data-slot=\"sidebar-inset\" className={cn('relative flex w-full flex-1 flex-col', className)} {...props}>\n <div className=\"h-14 w-full\" />\n <div className={cn('flex-1 inset-shadow-sm')}>{children}</div>\n </main>\n )\n}\n\nfunction SidebarHeader({ className, ...props }: React.ComponentProps<'div'>) {\n return <div data-slot=\"sidebar-header\" data-sidebar=\"header\" className={cn('flex flex-col gap-2 p-2', className)} {...props} />\n}\n\nfunction SidebarFooter({ className, ...props }: React.ComponentProps<'div'>) {\n return <div data-slot=\"sidebar-footer\" data-sidebar=\"footer\" className={cn('flex flex-col gap-2 p-2', className)} {...props} />\n}\n\nfunction SidebarSeparator({ className, ...props }: React.ComponentProps<typeof Separator>) {\n return <Separator data-slot=\"sidebar-separator\" data-sidebar=\"separator\" className={cn('bg-sidebar-border mx-2 w-auto', className)} {...props} />\n}\n\nfunction SidebarContent({ className, ...props }: React.ComponentProps<'div'>) {\n return (\n <div\n data-slot=\"sidebar-content\"\n data-sidebar=\"content\"\n className={cn('flex min-h-0 flex-1 flex-col gap-2 overflow-auto group-data-[collapsible=icon]:overflow-hidden', className)}\n {...props}\n />\n )\n}\n\nfunction SidebarGroup({ className, ...props }: React.ComponentProps<'div'>) {\n return <div data-slot=\"sidebar-group\" data-sidebar=\"group\" className={cn('relative flex w-full min-w-0 flex-col p-2', className)} {...props} />\n}\n\nfunction SidebarGroupLabel({ className, asChild = false, ...props }: React.ComponentProps<'div'> & { asChild?: boolean }) {\n const Comp = asChild ? SlotPrimitive.Slot : 'div'\n\n return (\n <Comp\n data-slot=\"sidebar-group-label\"\n data-sidebar=\"group-label\"\n className={cn(\n 'flex h-8 shrink-0 items-center rounded-md px-2 text-xs font-medium outline-hidden transition-[margin,opacity] duration-200 ease-linear focus-visible:ring-2',\n 'text-sidebar-foreground/70',\n 'ring-sidebar-ring',\n '[&>svg]:size-4',\n '[&>svg]:shrink-0',\n 'group-data-[collapsible=icon]:-mt-8',\n 'group-data-[collapsible=icon]:opacity-0',\n className,\n )}\n {...props}\n />\n )\n}\n\nfunction SidebarGroupAction({ className, asChild = false, ...props }: React.ComponentProps<'button'> & { asChild?: boolean }) {\n const Comp = asChild ? SlotPrimitive.Slot : 'button'\n\n return (\n <Comp\n data-slot=\"sidebar-group-action\"\n data-sidebar=\"group-action\"\n className={cn(\n 'text-sidebar-foreground ring-sidebar-ring hover:bg-sidebar-accent hover:text-sidebar-accent-foreground absolute top-3.5 right-3 flex aspect-square w-5 items-center justify-center rounded-md p-0 outline-hidden transition-transform',\n 'focus-visible:ring-2',\n '[&>svg]:size-4',\n '[&>svg]:shrink-0',\n // Increases the hit area of the button on mobile.\n 'after:absolute after:-inset-2 md:after:hidden',\n 'group-data-[collapsible=icon]:hidden',\n className,\n )}\n {...props}\n />\n )\n}\n\nfunction SidebarGroupContent({ className, ...props }: React.ComponentProps<'div'>) {\n return <div data-slot=\"sidebar-group-content\" data-sidebar=\"group-content\" className={cn('w-full text-sm', className)} {...props} />\n}\n\nfunction SidebarMenu({ className, ...props }: React.ComponentProps<'ul'>) {\n return <ul data-slot=\"sidebar-menu\" data-sidebar=\"menu\" className={cn('flex w-full min-w-0 flex-col gap-1', className)} {...props} />\n}\n\nfunction SidebarMenuItem({ className, ...props }: React.ComponentProps<'li'>) {\n return <li data-slot=\"sidebar-menu-item\" data-sidebar=\"menu-item\" className={cn('group/menu-item relative', className)} {...props} />\n}\n\nconst sidebarMenuButtonVariants = cva(\n [\n 'peer/menu-button',\n 'cursor-pointer',\n 'flex w-full items-center gap-2',\n 'overflow-hidden rounded-md p-2 text-left text-sm outline-hidden',\n 'ring-sidebar-ring transition-[width,height,padding]',\n 'focus-visible:ring-2',\n 'hover:bg-sidebar-accent',\n 'hover:text-sidebar-accent-foreground',\n 'active:bg-sidebar-accent',\n 'active:text-sidebar-accent-foreground',\n 'disabled:pointer-events-none',\n 'disabled:opacity-50',\n 'group-has-data-[sidebar=menu-action]/menu-item:pr-8',\n 'aria-disabled:pointer-events-none',\n 'aria-disabled:opacity-50',\n 'data-[active=true]:bg-sidebar-accent',\n 'data-[active=true]:font-medium',\n 'data-[active=true]:text-sidebar-accent-foreground',\n 'data-[state=open]:hover:bg-sidebar-accent',\n 'data-[state=open]:hover:text-sidebar-accent-foreground',\n 'group-data-[collapsible=icon]:size-8!',\n 'group-data-[collapsible=icon]:p-2!',\n '[&>span:last-child]:truncate',\n '[&>svg]:size-4',\n '[&>svg]:shrink-0',\n ],\n {\n variants: {\n variant: {\n default: 'hover:bg-sidebar-accent hover:text-sidebar-accent-foreground',\n outline:\n '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))]',\n },\n size: {\n default: 'h-8 text-sm',\n sm: 'h-7 text-xs',\n lg: 'h-12 text-sm group-data-[collapsible=icon]:p-0!',\n },\n },\n defaultVariants: {\n variant: 'default',\n size: 'default',\n },\n },\n)\n\nfunction SidebarMenuButton({\n asChild = false,\n isActive = false,\n variant = 'default',\n size = 'default',\n tooltip,\n className,\n ...props\n}: React.ComponentProps<'button'> & {\n asChild?: boolean\n isActive?: boolean\n tooltip?: string | React.ComponentProps<typeof TooltipContent>\n} & VariantProps<typeof sidebarMenuButtonVariants>) {\n const Comp = asChild ? SlotPrimitive.Slot : 'button'\n const { isMobile, state } = useSidebar()\n\n const button = (\n <Comp\n data-slot=\"sidebar-menu-button\"\n data-sidebar=\"menu-button\"\n data-size={size}\n data-active={isActive}\n className={cn(sidebarMenuButtonVariants({ variant, size }), className)}\n {...props}\n />\n )\n\n if (!tooltip) {\n return button\n }\n\n if (typeof tooltip === 'string') {\n tooltip = {\n children: tooltip,\n }\n }\n\n return (\n <Tooltip>\n <TooltipTrigger asChild>{button}</TooltipTrigger>\n <TooltipContent side=\"right\" align=\"center\" hidden={state !== 'collapsed' || isMobile} {...tooltip} />\n </Tooltip>\n )\n}\n\nfunction SidebarMenuAction({\n className,\n asChild = false,\n showOnHover = false,\n ...props\n}: React.ComponentProps<'button'> & {\n asChild?: boolean\n showOnHover?: boolean\n}) {\n const Comp = asChild ? SlotPrimitive.Slot : 'button'\n\n return (\n <Comp\n data-slot=\"sidebar-menu-action\"\n data-sidebar=\"menu-action\"\n className={cn(\n 'text-sidebar-foreground ring-sidebar-ring hover:bg-sidebar-accent hover:text-sidebar-accent-foreground peer-hover/menu-button:text-sidebar-accent-foreground absolute top-1.5 right-1 flex aspect-square w-5 items-center justify-center rounded-md p-0 outline-hidden transition-transform',\n 'focus-visible:ring-2',\n '[&>svg]:size-4',\n '[&>svg]:shrink-0',\n // Increases the hit area of the button on mobile.\n 'after:absolute after:-inset-2 md:after:hidden',\n 'peer-data-[size=sm]/menu-button:top-1',\n 'peer-data-[size=default]/menu-button:top-1.5',\n 'peer-data-[size=lg]/menu-button:top-2.5',\n 'group-data-[collapsible=icon]:hidden',\n showOnHover && 'peer-data-[active=true]/menu-button:text-sidebar-accent-foreground',\n showOnHover && 'group-focus-within/menu-item:opacity-100',\n showOnHover && 'group-hover/menu-item:opacity-100',\n showOnHover && 'data-[state=open]:opacity-100 md:opacity-0',\n className,\n )}\n {...props}\n />\n )\n}\n\nfunction SidebarMenuBadge({ className, ...props }: React.ComponentProps<'div'>) {\n return (\n <div\n data-slot=\"sidebar-menu-badge\"\n data-sidebar=\"menu-badge\"\n className={cn(\n 'text-sidebar-foreground pointer-events-none absolute right-1 flex h-5 min-w-5 items-center justify-center rounded-md px-1 text-xs font-medium tabular-nums select-none',\n 'peer-hover/menu-button:text-sidebar-accent-foreground',\n 'peer-data-[active=true]/menu-button:text-sidebar-accent-foreground',\n 'peer-data-[size=sm]/menu-button:top-1',\n 'peer-data-[size=default]/menu-button:top-1.5',\n 'peer-data-[size=lg]/menu-button:top-2.5',\n 'group-data-[collapsible=icon]:hidden',\n className,\n )}\n {...props}\n />\n )\n}\n\nfunction SidebarMenuSkeleton({\n className,\n showIcon = false,\n ...props\n}: React.ComponentProps<'div'> & {\n showIcon?: boolean\n}) {\n // Random width between 50 to 90%.\n const width = React.useMemo(() => {\n return `${Math.floor(Math.random() * 40) + 50}%`\n }, [])\n\n return (\n <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}>\n {showIcon && <Skeleton className=\"size-4 rounded-md\" data-sidebar=\"menu-skeleton-icon\" />}\n <Skeleton\n className=\"h-4 max-w-(--skeleton-width) flex-1\"\n data-sidebar=\"menu-skeleton-text\"\n style={\n {\n '--skeleton-width': width,\n } as React.CSSProperties\n }\n />\n </div>\n )\n}\n\nfunction SidebarMenuSub({ className, ...props }: React.ComponentProps<'ul'>) {\n return (\n <ul\n data-slot=\"sidebar-menu-sub\"\n data-sidebar=\"menu-sub\"\n className={cn(\n 'border-sidebar-border mx-3.5 flex min-w-0 translate-x-px flex-col gap-1 border-l px-2.5 py-0.5',\n 'group-data-[collapsible=icon]:hidden',\n className,\n )}\n {...props}\n />\n )\n}\n\nfunction SidebarMenuSubItem({ className, ...props }: React.ComponentProps<'li'>) {\n return <li data-slot=\"sidebar-menu-sub-item\" data-sidebar=\"menu-sub-item\" className={cn('group/menu-sub-item relative', className)} {...props} />\n}\n\nfunction SidebarMenuSubButton({\n asChild = false,\n size = 'md',\n isActive = false,\n className,\n ...props\n}: React.ComponentProps<'a'> & {\n asChild?: boolean\n size?: 'sm' | 'md'\n isActive?: boolean\n}) {\n const Comp = asChild ? SlotPrimitive.Slot : 'a'\n\n return (\n <Comp\n data-slot=\"sidebar-menu-sub-button\"\n data-sidebar=\"menu-sub-button\"\n data-size={size}\n data-active={isActive}\n className={cn(\n 'text-sidebar-foreground',\n 'ring-sidebar-ring',\n 'flex h-7 min-w-0 -translate-x-px items-center gap-2 overflow-hidden rounded-md px-2 outline-hidden',\n 'focus-visible:ring-2',\n 'hover:bg-sidebar-accent',\n 'hover:text-sidebar-accent-foreground',\n 'active:bg-sidebar-accent',\n 'active:text-sidebar-accent-foreground',\n 'disabled:pointer-events-none',\n 'disabled:opacity-50',\n 'aria-disabled:pointer-events-none',\n 'aria-disabled:opacity-50',\n '[&>svg]:size-4',\n '[&>svg]:shrink-0',\n '[&>svg]:text-sidebar-accent-foreground',\n '[&>span:last-child]:truncate',\n 'data-[active=true]:bg-sidebar-accent',\n 'data-[active=true]:text-sidebar-accent-foreground',\n size === 'sm' && 'text-xs',\n size === 'md' && 'text-sm',\n 'group-data-[collapsible=icon]:hidden',\n className,\n )}\n {...props}\n />\n )\n}\n\nexport {\n Sidebar,\n SidebarContent,\n SidebarFooter,\n SidebarGroup,\n SidebarGroupAction,\n SidebarGroupContent,\n SidebarGroupLabel,\n SidebarHeader,\n SidebarInset,\n SidebarMenu,\n SidebarMenuAction,\n SidebarMenuBadge,\n SidebarMenuButton,\n SidebarMenuItem,\n SidebarMenuSkeleton,\n SidebarMenuSub,\n SidebarMenuSubButton,\n SidebarMenuSubItem,\n SidebarProvider,\n SidebarRail,\n SidebarSeparator,\n SidebarTrigger,\n // eslint-disable-next-line react-refresh/only-export-components\n useSidebar,\n}\n","'use client'\nimport { ShoppingCartIcon } from 'lucide-react'\n\nimport { cn } from '@/lib/utils'\n\nimport { Sidebar, SidebarInset, SidebarProvider, SidebarTrigger } from './sidebar'\n\nexport * from './sidebar'\n\nexport const AppLayoutWrapper: React.FC<React.PropsWithChildren> = ({ children }) => {\n return <SidebarProvider>{children}</SidebarProvider>\n}\n\nexport const AppLayoutHeader: React.FC<React.PropsWithChildren> = ({ children }) => {\n return (\n <header\n className={cn(\n 'bg-card',\n 'h-(--header-height)',\n 'absolute inset-x-0 top-0 z-20 gap-2 px-4',\n 'shadow-nav flex items-center',\n 'transition-[width,height] ease-linear',\n 'group-has-data-[collapsible=icon]/sidebar-wrapper:h-(--header-height)',\n )}\n >\n <SidebarTrigger />\n\n <div className=\"ml-2.5 flex gap-x-2\">\n <div className=\"bg-sidebar-primary text-sidebar-primary-foreground flex aspect-square size-8 items-center justify-center rounded-lg\">\n <ShoppingCartIcon size={20} />\n </div>\n <div className=\"grid flex-1 text-left text-sm leading-tight\">\n <span className=\"truncate font-medium\">Lunas Store</span>\n <span className=\"truncate text-xs\">Established 2023</span>\n </div>\n </div>\n\n <div className=\"flex flex-1 items-center justify-end\">{children}</div>\n </header>\n )\n}\n\nexport const AppLayoutSidebar: React.FC<React.PropsWithChildren & React.ComponentProps<typeof Sidebar>> = ({ children, ...props }) => {\n return (\n <Sidebar variant=\"inset\" collapsible=\"icon\" {...props}>\n {children}\n </Sidebar>\n )\n}\n\nexport const AppLayoutMain: React.FC<React.PropsWithChildren> = ({ children }) => {\n return (\n <SidebarInset>\n <section className=\"relative size-full\">\n <div className=\"absolute inset-0\">{children}</div>\n </section>\n </SidebarInset>\n )\n}\n\nexport const AppLayoutMainGroup: React.FC<React.PropsWithChildren<{ className?: string }>> = ({ children, className }) => {\n return (\n <div data-slot=\"main-group\" className={cn('flex size-full flex-col gap-4 overflow-y-auto p-4', className)}>\n {children}\n </div>\n )\n}\n\nexport const AppLayoutMainGroupContent: React.FC<React.PropsWithChildren> = ({ children }) => {\n return (\n <div data-slot=\"main-group-content\" className=\"bg-card shadow-card size-full rounded-md p-4\">\n {children}\n </div>\n )\n}\n"],"mappings":"mtBAeA,MAiBM,EAAiB,EAAM,cAA0C,MAEvE,SAAS,GAAa,CACpB,IAAM,EAAU,EAAM,WAAW,GACjC,GAAI,CAAC,EACH,MAAU,MAAM,qDAGlB,OAAO,EAGT,SAAS,EAAgB,CACvB,cAAc,GACd,KAAM,EACN,aAAc,EACd,YACA,QACA,WACA,GAAG,GAKF,CACD,IAAM,EAAW,IACX,CAAC,EAAY,GAAiB,EAAM,SAAS,IAI7C,CAAC,EAAO,GAAY,EAAM,SAAS,GACnC,EAAO,GAAY,EACnB,EAAU,EAAM,YACnB,GAAmD,CAClD,IAAM,EAAY,OAAO,GAAU,WAAa,EAAM,GAAQ,EAC1D,EACF,EAAY,GAEZ,EAAS,GAIX,SAAS,OAAS,iBAA0B,EAAU,2BAExD,CAAC,EAAa,IAIV,EAAgB,EAAM,gBACnB,EAAW,EAAe,GAAS,CAACA,GAAQ,EAAS,GAAS,CAACA,GACrE,CAAC,EAAU,EAAS,IAGvB,EAAM,cAAgB,CACpB,IAAM,EAAiB,GAAyB,CAC1C,EAAM,MAAQ,MAA8B,EAAM,SAAW,EAAM,WACrE,EAAM,iBACN,MAKJ,OADA,OAAO,iBAAiB,UAAW,OACtB,OAAO,oBAAoB,UAAW,IAClD,CAAC,IAIJ,IAAM,EAAQ,EAAO,WAAa,YAE5B,EAAe,EAAM,aAClB,CACL,QACA,WAEA,gBAEA,OACA,UAEA,aACA,kBAEF,CAAC,EAAO,EAAM,EAAS,EAAU,EAAY,EAAe,IAG9D,OACE,EAAC,EAAe,SAAA,CAAS,MAAO,WAC9B,EAAC,EAAA,CAAgB,cAAe,WAC9B,EAAC,MAAA,CACC,YAAU,kBACV,MACE,CACE,kBAAmB,QACnB,uBAAwB,OACxB,GAAG,GAGP,UAAW,EAAG,wBAAyB,sCAAuC,oBAAqB,GACnG,GAAI,EAEH,iBAOX,SAAS,EAAQ,CACf,OAAO,OACP,UAAU,UACV,cAAc,YACd,YACA,WACA,GAAG,GAKF,CACD,GAAM,CAAE,WAAU,QAAO,aAAY,iBAAkB,IAmCvD,OAjCI,IAAgB,OAEhB,EAAC,QAAA,CAAM,YAAU,UAAU,UAAW,EAAG,aAAc,0BAA2B,2CAA4C,GAAY,GAAI,EAC3I,aAKH,EAEA,EAAC,EAAA,CAAM,KAAM,EAAY,aAAc,EAAe,GAAI,WACxD,EAAC,EAAA,CACC,eAAa,UACb,YAAU,UACV,cAAY,OACZ,UAAU,+EACV,MACE,CACE,kBAAmB,SAGjB,iBAEN,EAAC,EAAA,CAAY,UAAU,oBACrB,EAAC,EAAA,CAAA,SAAW,YACZ,EAAC,EAAA,CAAA,SAAiB,oCAEpB,EAAC,MAAA,CAAI,UAAU,8BAA+B,kBAOpD,EAAC,QAAA,CACC,UAAU,6DACV,aAAY,EACZ,mBAAkB,IAAU,YAAc,EAAc,GACxD,eAAc,EACd,YAAW,EACX,YAAU,oBAGV,EAAC,MAAA,CACC,YAAU,cACV,UAAW,EACT,WACA,iBACA,8CACA,2BACA,yCACA,qCACA,IAAY,YAAc,IAAY,QAClC,mFACA,4DAGR,EAAC,MAAA,CACC,YAAU,oBACV,UAAW,EACT,iBACA,yCACA,8CACA,yDACA,IAAS,QAAU,iFACnB,IAAS,SAAW,mFAEpB,IAAY,YAAc,IAAY,QAClC,uFACA,0HACJ,GAEF,GAAI,WAEJ,EAAC,MAAA,CACC,eAAa,UACb,YAAU,gBACV,UAAW,EACT,0BACA,2CACA,uCACA,sDACA,2CAGD,kBAOX,SAAS,EAAe,CAAE,YAAW,UAAS,GAAG,GAA8C,CAC7F,GAAM,CAAE,iBAAkB,IAE1B,OACE,EAAC,EAAA,CACC,eAAa,UACb,YAAU,kBACV,QAAQ,QACR,MAAM,QACN,KAAK,OACL,UAAW,EAAG,uBAAwB,GACtC,QAAU,GAAU,CAClB,IAAU,GACV,KAEF,GAAI,YAEJ,EAAC,EAAA,CAAS,UAAU,YACpB,EAAC,OAAA,CAAK,UAAU,mBAAU,sBAKhC,SAAS,EAAY,CAAE,YAAW,GAAG,GAAyC,CAC5E,GAAM,CAAE,iBAAkB,IAE1B,OACE,EAAC,SAAA,CACC,eAAa,OACb,YAAU,eACV,aAAW,iBACX,SAAU,GACV,QAAS,EACT,MAAM,iBACN,UAAW,EACT,yFACA,8DACA,kCACA,iCACA,sCACA,uCACA,gCACA,sDACA,mDACA,qDACA,6DACA,8DACA,4DACA,4DACA,GAEF,GAAI,IAKV,SAAS,EAAa,CAAE,YAAW,WAAU,GAAG,GAAuC,CACrF,OACE,EAAC,OAAA,CAAK,YAAU,gBAAgB,UAAW,EAAG,uCAAwC,GAAY,GAAI,YACpG,EAAC,MAAA,CAAI,UAAU,gBACf,EAAC,MAAA,CAAI,UAAW,EAAG,0BAA4B,gBAKrD,SAAS,EAAc,CAAE,YAAW,GAAG,GAAsC,CAC3E,OAAO,EAAC,MAAA,CAAI,YAAU,iBAAiB,eAAa,SAAS,UAAW,EAAG,0BAA2B,GAAY,GAAI,IAGxH,SAAS,EAAc,CAAE,YAAW,GAAG,GAAsC,CAC3E,OAAO,EAAC,MAAA,CAAI,YAAU,iBAAiB,eAAa,SAAS,UAAW,EAAG,0BAA2B,GAAY,GAAI,IAGxH,SAAS,EAAiB,CAAE,YAAW,GAAG,GAAiD,CACzF,OAAO,EAACC,EAAAA,CAAU,YAAU,oBAAoB,eAAa,YAAY,UAAW,EAAG,gCAAiC,GAAY,GAAI,IAG1I,SAAS,EAAe,CAAE,YAAW,GAAG,GAAsC,CAC5E,OACE,EAAC,MAAA,CACC,YAAU,kBACV,eAAa,UACb,UAAW,EAAG,iGAAkG,GAChH,GAAI,IAKV,SAAS,EAAa,CAAE,YAAW,GAAG,GAAsC,CAC1E,OAAO,EAAC,MAAA,CAAI,YAAU,gBAAgB,eAAa,QAAQ,UAAW,EAAG,4CAA6C,GAAY,GAAI,IAGxI,SAAS,EAAkB,CAAE,YAAW,UAAU,GAAO,GAAG,GAA8D,CACxH,IAAM,EAAO,EAAUC,EAAc,KAAO,MAE5C,OACE,EAAC,EAAA,CACC,YAAU,sBACV,eAAa,cACb,UAAW,EACT,8JACA,6BACA,oBACA,iBACA,mBACA,sCACA,0CACA,GAEF,GAAI,IAKV,SAAS,EAAmB,CAAE,YAAW,UAAU,GAAO,GAAG,GAAiE,CAC5H,IAAM,EAAO,EAAUA,EAAc,KAAO,SAE5C,OACE,EAAC,EAAA,CACC,YAAU,uBACV,eAAa,eACb,UAAW,EACT,wOACA,uBACA,iBACA,mBAEA,gDACA,uCACA,GAEF,GAAI,IAKV,SAAS,EAAoB,CAAE,YAAW,GAAG,GAAsC,CACjF,OAAO,EAAC,MAAA,CAAI,YAAU,wBAAwB,eAAa,gBAAgB,UAAW,EAAG,iBAAkB,GAAY,GAAI,IAG7H,SAAS,EAAY,CAAE,YAAW,GAAG,GAAqC,CACxE,OAAO,EAAC,KAAA,CAAG,YAAU,eAAe,eAAa,OAAO,UAAW,EAAG,qCAAsC,GAAY,GAAI,IAG9H,SAAS,EAAgB,CAAE,YAAW,GAAG,GAAqC,CAC5E,OAAO,EAAC,KAAA,CAAG,YAAU,oBAAoB,eAAa,YAAY,UAAW,EAAG,2BAA4B,GAAY,GAAI,IAG9H,MAAM,EAA4B,EAChC,CACE,mBACA,iBACA,iCACA,kEACA,sDACA,uBACA,0BACA,uCACA,2BACA,wCACA,+BACA,sBACA,sDACA,oCACA,2BACA,uCACA,iCACA,oDACA,4CACA,yDACA,wCACA,qCACA,+BACA,iBACA,oBAEF,CACE,SAAU,CACR,QAAS,CACP,QAAS,+DACT,QACE,gLAEJ,KAAM,CACJ,QAAS,cACT,GAAI,cACJ,GAAI,oDAGR,gBAAiB,CACf,QAAS,UACT,KAAM,aAKZ,SAAS,EAAkB,CACzB,UAAU,GACV,WAAW,GACX,UAAU,UACV,OAAO,UACP,UACA,YACA,GAAG,GAK+C,CAClD,IAAM,EAAO,EAAUA,EAAc,KAAO,SACtC,CAAE,WAAU,SAAU,IAEtB,EACJ,EAAC,EAAA,CACC,YAAU,sBACV,eAAa,cACb,YAAW,EACX,cAAa,EACb,UAAW,EAAG,EAA0B,CAAE,UAAS,SAAS,GAC5D,GAAI,IAcR,OAVK,GAID,OAAO,GAAY,WACrB,EAAU,CACR,SAAU,IAKZ,EAACC,EAAAA,CAAAA,SAAAA,CACC,EAAC,EAAA,CAAe,QAAA,YAAS,IACzB,EAAC,EAAA,CAAe,KAAK,QAAQ,MAAM,SAAS,OAAQ,IAAU,aAAe,EAAU,GAAI,QAZtF,EAiBX,SAAS,EAAkB,CACzB,YACA,UAAU,GACV,cAAc,GACd,GAAG,GAIF,CACD,IAAM,EAAO,EAAUD,EAAc,KAAO,SAE5C,OACE,EAAC,EAAA,CACC,YAAU,sBACV,eAAa,cACb,UAAW,EACT,8RACA,uBACA,iBACA,mBAEA,gDACA,wCACA,+CACA,0CACA,uCACA,GAAe,qEACf,GAAe,2CACf,GAAe,oCACf,GAAe,6CACf,GAEF,GAAI,IAKV,SAAS,EAAiB,CAAE,YAAW,GAAG,GAAsC,CAC9E,OACE,EAAC,MAAA,CACC,YAAU,qBACV,eAAa,aACb,UAAW,EACT,yKACA,wDACA,qEACA,wCACA,+CACA,0CACA,uCACA,GAEF,GAAI,IAKV,SAAS,EAAoB,CAC3B,YACA,WAAW,GACX,GAAG,GAGF,CAED,IAAM,EAAQ,EAAM,YACX,GAAG,KAAK,MAAM,KAAK,SAAW,IAAM,GAAG,GAC7C,IAEH,OACE,EAAC,MAAA,CAAI,YAAU,wBAAwB,eAAa,gBAAgB,UAAW,EAAG,8CAA+C,GAAY,GAAI,YAC9I,GAAY,EAAC,EAAA,CAAS,UAAU,oBAAoB,eAAa,uBAClE,EAAC,EAAA,CACC,UAAU,sCACV,eAAa,qBACb,MACE,CACE,mBAAoB,QAQhC,SAAS,EAAe,CAAE,YAAW,GAAG,GAAqC,CAC3E,OACE,EAAC,KAAA,CACC,YAAU,mBACV,eAAa,WACb,UAAW,EACT,iGACA,uCACA,GAEF,GAAI,IAKV,SAAS,EAAmB,CAAE,YAAW,GAAG,GAAqC,CAC/E,OAAO,EAAC,KAAA,CAAG,YAAU,wBAAwB,eAAa,gBAAgB,UAAW,EAAG,+BAAgC,GAAY,GAAI,IAG1I,SAAS,EAAqB,CAC5B,UAAU,GACV,OAAO,KACP,WAAW,GACX,YACA,GAAG,GAKF,CACD,IAAM,EAAO,EAAUA,EAAc,KAAO,IAE5C,OACE,EAAC,EAAA,CACC,YAAU,0BACV,eAAa,kBACb,YAAW,EACX,cAAa,EACb,UAAW,EACT,0BACA,oBACA,qGACA,uBACA,0BACA,uCACA,2BACA,wCACA,+BACA,sBACA,oCACA,2BACA,iBACA,mBACA,yCACA,+BACA,uCACA,oDACA,IAAS,MAAQ,UACjB,IAAS,MAAQ,UACjB,uCACA,GAEF,GAAI,IC/mBV,MAAaE,GAAuD,CAAE,cAC7D,EAAC,EAAA,CAAiB,aAGdC,GAAsD,CAAE,cAEjE,EAAC,SAAA,CACC,UAAW,EACT,UACA,sBACA,2CACA,+BACA,wCACA,mFAGF,EAAC,EAAA,IAED,EAAC,MAAA,CAAI,UAAU,gCACb,EAAC,MAAA,CAAI,UAAU,+HACb,EAAC,EAAA,CAAiB,KAAM,OAE1B,EAAC,MAAA,CAAI,UAAU,wDACb,EAAC,OAAA,CAAK,UAAU,gCAAuB,gBACvC,EAAC,OAAA,CAAK,UAAU,4BAAmB,2BAIvC,EAAC,MAAA,CAAI,UAAU,uCAAwC,gBAKhDC,GAA8F,CAAE,WAAU,GAAG,KAEtH,EAAC,EAAA,CAAQ,QAAQ,QAAQ,YAAY,OAAO,GAAI,EAC7C,aAKMC,GAAoD,CAAE,cAE/D,EAAC,EAAA,CAAA,SACC,EAAC,UAAA,CAAQ,UAAU,8BACjB,EAAC,MAAA,CAAI,UAAU,mBAAoB,iBAM9BC,GAAiF,CAAE,WAAU,eAEtG,EAAC,MAAA,CAAI,YAAU,aAAa,UAAW,EAAG,oDAAqD,GAC5F,aAKMC,GAAgE,CAAE,cAE3E,EAAC,MAAA,CAAI,YAAU,qBAAqB,UAAU,+CAC3C"}
1
+ {"version":3,"file":"index.js","names":["open","Separator","SlotPrimitive","Tooltip","AppLayoutWrapper: React.FC<React.PropsWithChildren>","AppLayoutHeader: React.FC<React.PropsWithChildren>","AppLayoutSidebar: React.FC<React.PropsWithChildren & React.ComponentProps<typeof Sidebar>>","AppLayoutMain: React.FC<React.PropsWithChildren>","AppLayoutMainGroup: React.FC<React.PropsWithChildren<{ className?: string }>>","AppLayoutMainGroupContent: React.FC<React.PropsWithChildren>"],"sources":["../../../packages/components/layouts/app-layout/sidebar.tsx","../../../packages/components/layouts/app-layout/index.tsx"],"sourcesContent":["import React from 'react'\nimport { Slot as SlotPrimitive } from 'radix-ui'\nimport { cva, type VariantProps } from 'class-variance-authority'\nimport { MenuIcon } from 'lucide-react'\n\nimport { Button } from '@/components/ui/button'\nimport { Separator } from '@/components/ui/separator'\nimport { Sheet, SheetContent, SheetDescription, SheetHeader, SheetTitle } from '@/components/ui/sheet'\nimport { Skeleton } from '@/components/ui/skeleton'\nimport { TooltipProvider } from '@/components/ui/tooltip'\nimport { Tooltip, TooltipContent, TooltipTrigger } from '@/components/ui/tooltip'\n\nimport { useIsMobile } from '@/hooks/use-mobile'\nimport { cn } from '@/lib/utils'\n\nconst SIDEBAR_COOKIE_NAME = 'sidebar_state'\nconst SIDEBAR_COOKIE_MAX_AGE = 60 * 60 * 24 * 7\nconst SIDEBAR_WIDTH = '16rem'\nconst SIDEBAR_WIDTH_MOBILE = '18rem'\nconst SIDEBAR_WIDTH_ICON = '3rem'\nconst SIDEBAR_KEYBOARD_SHORTCUT = 'b'\n\ntype SidebarContextProps = {\n state: 'expanded' | 'collapsed'\n open: boolean\n setOpen: (open: boolean) => void\n openMobile: boolean\n setOpenMobile: (open: boolean) => void\n isMobile: boolean\n toggleSidebar: () => void\n}\n\nconst SidebarContext = React.createContext<SidebarContextProps | null>(null)\n\nfunction useSidebar() {\n const context = React.useContext(SidebarContext)\n if (!context) {\n throw new Error('useSidebar must be used within a SidebarProvider.')\n }\n\n return context\n}\n\nfunction SidebarProvider({\n defaultOpen = true,\n open: openProp,\n onOpenChange: setOpenProp,\n className,\n style,\n children,\n ...props\n}: React.ComponentProps<'div'> & {\n defaultOpen?: boolean\n open?: boolean\n onOpenChange?: (open: boolean) => void\n}) {\n const isMobile = useIsMobile()\n const [openMobile, setOpenMobile] = React.useState(false)\n\n // This is the internal state of the sidebar.\n // We use openProp and setOpenProp for control from outside the component.\n const [_open, _setOpen] = React.useState(defaultOpen)\n const open = openProp ?? _open\n const setOpen = React.useCallback(\n (value: boolean | ((value: boolean) => boolean)) => {\n const openState = typeof value === 'function' ? value(open) : value\n if (setOpenProp) {\n setOpenProp(openState)\n } else {\n _setOpen(openState)\n }\n\n // This sets the cookie to keep the sidebar state.\n document.cookie = `${SIDEBAR_COOKIE_NAME}=${openState}; path=/; max-age=${SIDEBAR_COOKIE_MAX_AGE}`\n },\n [setOpenProp, open],\n )\n\n // Helper to toggle the sidebar.\n const toggleSidebar = React.useCallback(() => {\n return isMobile ? setOpenMobile((open) => !open) : setOpen((open) => !open)\n }, [isMobile, setOpen, setOpenMobile])\n\n // Adds a keyboard shortcut to toggle the sidebar.\n React.useEffect(() => {\n const handleKeyDown = (event: KeyboardEvent) => {\n if (event.key === SIDEBAR_KEYBOARD_SHORTCUT && (event.metaKey || event.ctrlKey)) {\n event.preventDefault()\n toggleSidebar()\n }\n }\n\n window.addEventListener('keydown', handleKeyDown)\n return () => window.removeEventListener('keydown', handleKeyDown)\n }, [toggleSidebar])\n\n // We add a state so that we can do data-state=\"expanded\" or \"collapsed\".\n // This makes it easier to style the sidebar with Tailwind classes.\n const state = open ? 'expanded' : 'collapsed'\n\n const contextValue = React.useMemo<SidebarContextProps>(\n () => ({\n state,\n isMobile,\n\n toggleSidebar,\n\n open,\n setOpen,\n\n openMobile,\n setOpenMobile,\n }),\n [state, open, setOpen, isMobile, openMobile, setOpenMobile, toggleSidebar],\n )\n\n return (\n <SidebarContext.Provider value={contextValue}>\n <TooltipProvider delayDuration={0}>\n <div\n data-slot=\"sidebar-wrapper\"\n style={\n {\n '--sidebar-width': SIDEBAR_WIDTH,\n '--sidebar-width-icon': SIDEBAR_WIDTH_ICON,\n ...style,\n } as React.CSSProperties\n }\n className={cn('group/sidebar-wrapper', 'has-data-[variant=inset]:bg-sidebar', 'flex h-svh w-full', className)}\n {...props}\n >\n {children}\n </div>\n </TooltipProvider>\n </SidebarContext.Provider>\n )\n}\n\nfunction Sidebar({\n side = 'left',\n variant = 'sidebar',\n collapsible = 'offcanvas',\n className,\n children,\n ...props\n}: React.ComponentProps<'div'> & {\n side?: 'left' | 'right'\n variant?: 'sidebar' | 'floating' | 'inset'\n collapsible?: 'offcanvas' | 'icon' | 'none'\n}) {\n const { isMobile, state, openMobile, setOpenMobile } = useSidebar()\n\n if (collapsible === 'none') {\n return (\n <aside data-slot=\"sidebar\" className={cn('bg-sidebar', 'text-sidebar-foreground', 'flex h-full w-(--sidebar-width) flex-col', className)} {...props}>\n {children}\n </aside>\n )\n }\n\n if (isMobile) {\n return (\n <Sheet open={openMobile} onOpenChange={setOpenMobile} {...props}>\n <SheetContent\n data-sidebar=\"sidebar\"\n data-slot=\"sidebar\"\n data-mobile=\"true\"\n className=\"bg-sidebar text-sidebar-foreground w-(--sidebar-width) p-0 [&>button]:hidden\"\n style={\n {\n '--sidebar-width': SIDEBAR_WIDTH_MOBILE,\n } as React.CSSProperties\n }\n side={side}\n >\n <SheetHeader className=\"sr-only\">\n <SheetTitle>Sidebar</SheetTitle>\n <SheetDescription>Displays the mobile sidebar.</SheetDescription>\n </SheetHeader>\n <div className=\"flex h-full w-full flex-col\">{children}</div>\n </SheetContent>\n </Sheet>\n )\n }\n\n return (\n <aside\n className=\"group peer text-sidebar-foreground bg-card hidden md:block\"\n data-state={state}\n data-collapsible={state === 'collapsed' ? collapsible : ''}\n data-variant={variant}\n data-side={side}\n data-slot=\"sidebar\"\n >\n {/* This is what handles the sidebar gap on desktop */}\n <div\n data-slot=\"sidebar-gap\"\n className={cn(\n 'relative',\n 'bg-transparent',\n 'transition-[width] duration-200 ease-linear',\n 'h-14 w-(--sidebar-width)',\n 'group-data-[collapsible=offcanvas]:w-0',\n 'group-data-[side=right]:rotate-180',\n variant === 'floating' || variant === 'inset'\n ? 'group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)+(--spacing(4)))]'\n : 'group-data-[collapsible=icon]:w-(--sidebar-width-icon)',\n )}\n />\n <div\n data-slot=\"sidebar-container\"\n className={cn(\n 'hidden md:flex',\n 'shadow-nav fixed inset-y-0 top-14 z-10',\n 'h-[calc(100svh-3.5rem)] w-(--sidebar-width)',\n 'transition-[left,right,width] duration-200 ease-linear',\n side === 'left' && 'left-0 group-data-[collapsible=offcanvas]:left-[calc(var(--sidebar-width)*-1)]',\n side === 'right' && 'right-0 group-data-[collapsible=offcanvas]:right-[calc(var(--sidebar-width)*-1)]',\n // Adjust the padding for floating and inset variants.\n variant === 'floating' || variant === 'inset'\n ? 'p-2 group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)+(--spacing(4)))]'\n : 'group-data-[collapsible=icon]:w-(--sidebar-width-icon) group-data-[side=left]:border-r group-data-[side=right]:border-l',\n className,\n )}\n {...props}\n >\n <div\n data-sidebar=\"sidebar\"\n data-slot=\"sidebar-inner\"\n className={cn(\n 'flex size-full flex-col',\n 'group-data-[variant=floating]:rounded-lg',\n 'group-data-[variant=floating]:border',\n 'group-data-[variant=floating]:border-sidebar-border',\n 'group-data-[variant=floating]:shadow-sm',\n )}\n >\n {children}\n </div>\n </div>\n </aside>\n )\n}\n\nfunction AppLayoutSidebarTrigger({ className, onClick, ...props }: React.ComponentProps<typeof Button>) {\n const { toggleSidebar } = useSidebar()\n\n return (\n <Button\n data-sidebar=\"trigger\"\n data-slot=\"sidebar-trigger\"\n variant=\"ghost\"\n color=\"muted\"\n size=\"icon\"\n className={cn('size-10 rounded-full', className)}\n onClick={(event) => {\n onClick?.(event)\n toggleSidebar()\n }}\n {...props}\n >\n <MenuIcon className=\"!size-6\" />\n <span className=\"sr-only\">Toggle Sidebar</span>\n </Button>\n )\n}\n\nfunction AppLayoutSidebarRail({ className, ...props }: React.ComponentProps<'button'>) {\n const { toggleSidebar } = useSidebar()\n\n return (\n <button\n data-sidebar=\"rail\"\n data-slot=\"sidebar-rail\"\n aria-label=\"Toggle Sidebar\"\n tabIndex={-1}\n onClick={toggleSidebar}\n title=\"Toggle Sidebar\"\n className={cn(\n 'absolute inset-y-0 z-20 hidden w-4 -translate-x-1/2 transition-all ease-linear sm:flex',\n 'after:absolute after:inset-y-0 after:left-1/2 after:w-[2px]',\n 'group-data-[side=left]:-right-4',\n 'group-data-[side=right]:left-0',\n 'in-data-[side=left]:cursor-w-resize',\n 'in-data-[side=right]:cursor-e-resize',\n 'hover:after:bg-sidebar-border',\n 'hover:group-data-[collapsible=offcanvas]:bg-sidebar',\n 'group-data-[collapsible=offcanvas]:translate-x-0',\n 'group-data-[collapsible=offcanvas]:after:left-full',\n '[[data-side=left][data-state=collapsed]_&]:cursor-e-resize',\n '[[data-side=right][data-state=collapsed]_&]:cursor-w-resize',\n '[[data-side=left][data-collapsible=offcanvas]_&]:-right-2',\n '[[data-side=right][data-collapsible=offcanvas]_&]:-left-2',\n className,\n )}\n {...props}\n />\n )\n}\n\nfunction AppLayoutSidebarInset({ className, children, ...props }: React.ComponentProps<'main'>) {\n return (\n <main data-slot=\"sidebar-inset\" className={cn('relative flex w-full flex-1 flex-col', className)} {...props}>\n <div className=\"h-14 w-full\" />\n <div className={cn('flex-1 inset-shadow-sm')}>{children}</div>\n </main>\n )\n}\n\nfunction AppLayoutSidebarHeader({ className, ...props }: React.ComponentProps<'div'>) {\n return <div data-slot=\"sidebar-header\" data-sidebar=\"header\" className={cn('flex flex-col gap-2 p-2', className)} {...props} />\n}\n\nfunction AppLayoutSidebarFooter({ className, ...props }: React.ComponentProps<'div'>) {\n return <div data-slot=\"sidebar-footer\" data-sidebar=\"footer\" className={cn('flex flex-col gap-2 p-2', className)} {...props} />\n}\n\nfunction AppLayoutSidebarSeparator({ className, ...props }: React.ComponentProps<typeof Separator>) {\n return <Separator data-slot=\"sidebar-separator\" data-sidebar=\"separator\" className={cn('bg-sidebar-border mx-2 w-auto', className)} {...props} />\n}\n\nfunction AppLayoutSidebarContent({ className, ...props }: React.ComponentProps<'div'>) {\n return (\n <div\n data-slot=\"sidebar-content\"\n data-sidebar=\"content\"\n className={cn('flex min-h-0 flex-1 flex-col gap-2 overflow-auto group-data-[collapsible=icon]:overflow-hidden', className)}\n {...props}\n />\n )\n}\n\nfunction AppLayoutSidebarGroup({ className, ...props }: React.ComponentProps<'div'>) {\n return <div data-slot=\"sidebar-group\" data-sidebar=\"group\" className={cn('relative flex w-full min-w-0 flex-col p-2', className)} {...props} />\n}\n\nfunction AppLayoutSidebarGroupLabel({ className, asChild = false, ...props }: React.ComponentProps<'div'> & { asChild?: boolean }) {\n const Comp = asChild ? SlotPrimitive.Slot : 'div'\n\n return (\n <Comp\n data-slot=\"sidebar-group-label\"\n data-sidebar=\"group-label\"\n className={cn(\n 'flex h-8 shrink-0 items-center rounded-md px-2 text-xs font-medium outline-hidden transition-[margin,opacity] duration-200 ease-linear focus-visible:ring-2',\n 'text-sidebar-foreground/70',\n 'ring-sidebar-ring',\n '[&>svg]:size-4',\n '[&>svg]:shrink-0',\n 'group-data-[collapsible=icon]:-mt-8',\n 'group-data-[collapsible=icon]:opacity-0',\n className,\n )}\n {...props}\n />\n )\n}\n\nfunction AppLayoutSidebarGroupAction({ className, asChild = false, ...props }: React.ComponentProps<'button'> & { asChild?: boolean }) {\n const Comp = asChild ? SlotPrimitive.Slot : 'button'\n\n return (\n <Comp\n data-slot=\"sidebar-group-action\"\n data-sidebar=\"group-action\"\n className={cn(\n 'text-sidebar-foreground ring-sidebar-ring hover:bg-sidebar-accent hover:text-sidebar-accent-foreground absolute top-3.5 right-3 flex aspect-square w-5 items-center justify-center rounded-md p-0 outline-hidden transition-transform',\n 'focus-visible:ring-2',\n '[&>svg]:size-4',\n '[&>svg]:shrink-0',\n // Increases the hit area of the button on mobile.\n 'after:absolute after:-inset-2 md:after:hidden',\n 'group-data-[collapsible=icon]:hidden',\n className,\n )}\n {...props}\n />\n )\n}\n\nfunction AppLayoutSidebarGroupContent({ className, ...props }: React.ComponentProps<'div'>) {\n return <div data-slot=\"sidebar-group-content\" data-sidebar=\"group-content\" className={cn('w-full text-sm', className)} {...props} />\n}\n\nfunction AppLayoutSidebarMenu({ className, ...props }: React.ComponentProps<'ul'>) {\n return <ul data-slot=\"sidebar-menu\" data-sidebar=\"menu\" className={cn('flex w-full min-w-0 flex-col gap-1', className)} {...props} />\n}\n\nfunction AppLayoutSidebarMenuItem({ className, ...props }: React.ComponentProps<'li'>) {\n return <li data-slot=\"sidebar-menu-item\" data-sidebar=\"menu-item\" className={cn('group/menu-item relative', className)} {...props} />\n}\n\nconst sidebarMenuButtonVariants = cva(\n [\n 'peer/menu-button',\n 'cursor-pointer',\n 'flex w-full items-center gap-2',\n 'overflow-hidden rounded-md p-2 outline-hidden',\n 'text-left truncate',\n 'transition-[color,width,height,padding]',\n 'hover:bg-sidebar-accent',\n 'hover:text-sidebar-accent-foreground',\n 'active:bg-sidebar-accent',\n 'active:text-sidebar-accent-foreground',\n 'disabled:pointer-events-none',\n 'disabled:opacity-50',\n 'group-has-data-[sidebar=menu-action]/menu-item:pr-8',\n 'aria-disabled:pointer-events-none',\n 'aria-disabled:opacity-50',\n 'data-[active=true]:bg-sidebar-primary-muted',\n 'data-[active=true]:font-medium',\n 'data-[active=true]:text-sidebar-primary',\n 'data-[state=open]:hover:bg-sidebar-accent',\n 'data-[state=open]:hover:text-sidebar-accent-foreground',\n 'group-data-[collapsible=icon]:size-8!',\n 'group-data-[collapsible=icon]:p-2!',\n '[&>svg]:size-4',\n '[&>svg]:shrink-0',\n '[&>span:last-child]:truncate',\n ],\n {\n variants: {\n variant: {\n default: 'hover:bg-sidebar-accent/60 hover:text-sidebar-accent-foreground/80',\n outline:\n '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))]',\n },\n size: {\n default: 'h-8 text-sm',\n sm: 'h-7 text-xs',\n lg: 'h-12 text-sm group-data-[collapsible=icon]:p-0!',\n },\n },\n defaultVariants: {\n variant: 'default',\n size: 'default',\n },\n },\n)\n\nfunction AppLayoutSidebarMenuButton({\n asChild = false,\n isActive = false,\n variant = 'default',\n size = 'default',\n tooltip,\n className,\n ...props\n}: React.ComponentProps<'button'> & {\n asChild?: boolean\n isActive?: boolean\n tooltip?: string | React.ComponentProps<typeof TooltipContent>\n} & VariantProps<typeof sidebarMenuButtonVariants>) {\n const Comp = asChild ? SlotPrimitive.Slot : 'button'\n const { isMobile, state } = useSidebar()\n\n const button = (\n <Comp\n data-slot=\"sidebar-menu-button\"\n data-sidebar=\"menu-button\"\n data-size={size}\n data-active={isActive}\n className={cn(sidebarMenuButtonVariants({ variant, size }), className)}\n {...props}\n />\n )\n\n if (!tooltip) {\n return button\n }\n\n if (typeof tooltip === 'string') {\n tooltip = {\n children: tooltip,\n }\n }\n\n return (\n <Tooltip>\n <TooltipTrigger asChild>{button}</TooltipTrigger>\n <TooltipContent side=\"right\" align=\"center\" hidden={state !== 'collapsed' || isMobile} {...tooltip} />\n </Tooltip>\n )\n}\n\nfunction AppLayoutSidebarMenuAction({\n className,\n asChild = false,\n showOnHover = false,\n ...props\n}: React.ComponentProps<'button'> & {\n asChild?: boolean\n showOnHover?: boolean\n}) {\n const Comp = asChild ? SlotPrimitive.Slot : 'button'\n\n return (\n <Comp\n data-slot=\"sidebar-menu-action\"\n data-sidebar=\"menu-action\"\n className={cn(\n 'text-sidebar-foreground ring-sidebar-ring hover:bg-sidebar-accent hover:text-sidebar-accent-foreground peer-hover/menu-button:text-sidebar-accent-foreground absolute top-1.5 right-1 flex aspect-square w-5 items-center justify-center rounded-md p-0 outline-hidden transition-transform',\n 'focus-visible:ring-2',\n '[&>svg]:size-4',\n '[&>svg]:shrink-0',\n // Increases the hit area of the button on mobile.\n 'after:absolute after:-inset-2 md:after:hidden',\n 'peer-data-[size=sm]/menu-button:top-1',\n 'peer-data-[size=default]/menu-button:top-1.5',\n 'peer-data-[size=lg]/menu-button:top-2.5',\n 'group-data-[collapsible=icon]:hidden',\n showOnHover && 'peer-data-[active=true]/menu-button:text-sidebar-accent-foreground',\n showOnHover && 'group-focus-within/menu-item:opacity-100',\n showOnHover && 'group-hover/menu-item:opacity-100',\n showOnHover && 'data-[state=open]:opacity-100 md:opacity-0',\n className,\n )}\n {...props}\n />\n )\n}\n\nfunction AppLayoutSidebarMenuBadge({ className, ...props }: React.ComponentProps<'div'>) {\n return (\n <div\n data-slot=\"sidebar-menu-badge\"\n data-sidebar=\"menu-badge\"\n className={cn(\n 'text-sidebar-foreground pointer-events-none absolute right-1 flex h-5 min-w-5 items-center justify-center rounded-md px-1 text-xs font-medium tabular-nums select-none',\n 'peer-hover/menu-button:text-sidebar-accent-foreground',\n 'peer-data-[active=true]/menu-button:text-sidebar-accent-foreground',\n 'peer-data-[size=sm]/menu-button:top-1',\n 'peer-data-[size=default]/menu-button:top-1.5',\n 'peer-data-[size=lg]/menu-button:top-2.5',\n 'group-data-[collapsible=icon]:hidden',\n className,\n )}\n {...props}\n />\n )\n}\n\nfunction AppLayoutSidebarMenuSkeleton({\n className,\n showIcon = false,\n ...props\n}: React.ComponentProps<'div'> & {\n showIcon?: boolean\n}) {\n // Random width between 50 to 90%.\n const width = React.useMemo(() => {\n return `${Math.floor(Math.random() * 40) + 50}%`\n }, [])\n\n return (\n <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}>\n {showIcon && <Skeleton className=\"size-4 rounded-md\" data-sidebar=\"menu-skeleton-icon\" />}\n <Skeleton\n className=\"h-4 max-w-(--skeleton-width) flex-1\"\n data-sidebar=\"menu-skeleton-text\"\n style={\n {\n '--skeleton-width': width,\n } as React.CSSProperties\n }\n />\n </div>\n )\n}\n\nfunction AppLayoutSidebarMenuSub({ className, ...props }: React.ComponentProps<'ul'>) {\n return (\n <ul\n data-slot=\"sidebar-menu-sub\"\n data-sidebar=\"menu-sub\"\n className={cn(\n 'border-sidebar-border mx-3.5 flex min-w-0 translate-x-px flex-col gap-1 border-l px-2.5 py-0.5',\n 'group-data-[collapsible=icon]:hidden',\n className,\n )}\n {...props}\n />\n )\n}\n\nfunction AppLayoutSidebarMenuSubItem({ className, ...props }: React.ComponentProps<'li'>) {\n return <li data-slot=\"sidebar-menu-sub-item\" data-sidebar=\"menu-sub-item\" className={cn('group/menu-sub-item relative', className)} {...props} />\n}\n\nfunction AppLayoutSidebarMenuSubButton({\n asChild = false,\n size = 'md',\n isActive = false,\n className,\n ...props\n}: React.ComponentProps<'a'> & {\n asChild?: boolean\n size?: 'sm' | 'md'\n isActive?: boolean\n}) {\n const Comp = asChild ? SlotPrimitive.Slot : 'a'\n\n return (\n <Comp\n data-slot=\"sidebar-menu-sub-button\"\n data-sidebar=\"menu-sub-button\"\n data-size={size}\n data-active={isActive}\n className={cn(\n 'text-sidebar-foreground',\n 'ring-sidebar-ring',\n 'flex h-7 min-w-0 -translate-x-px items-center gap-2 overflow-hidden rounded-md px-2 outline-hidden',\n 'focus-visible:ring-2',\n 'hover:bg-sidebar-accent',\n 'hover:text-sidebar-accent-foreground',\n 'active:bg-sidebar-accent',\n 'active:text-sidebar-accent-foreground',\n 'disabled:pointer-events-none',\n 'disabled:opacity-50',\n 'aria-disabled:pointer-events-none',\n 'aria-disabled:opacity-50',\n '[&>svg]:size-4',\n '[&>svg]:shrink-0',\n '[&>svg]:text-sidebar-accent-foreground',\n '[&>span:last-child]:truncate',\n 'data-[active=true]:bg-sidebar-accent',\n 'data-[active=true]:text-sidebar-accent-foreground',\n size === 'sm' && 'text-xs',\n size === 'md' && 'text-sm',\n 'group-data-[collapsible=icon]:hidden',\n className,\n )}\n {...props}\n />\n )\n}\n\nexport {\n Sidebar,\n SidebarProvider,\n AppLayoutSidebarContent,\n AppLayoutSidebarFooter,\n AppLayoutSidebarGroup,\n AppLayoutSidebarGroupAction,\n AppLayoutSidebarGroupContent,\n AppLayoutSidebarGroupLabel,\n AppLayoutSidebarHeader,\n AppLayoutSidebarInset,\n AppLayoutSidebarMenu,\n AppLayoutSidebarMenuAction,\n AppLayoutSidebarMenuBadge,\n AppLayoutSidebarMenuButton,\n AppLayoutSidebarMenuItem,\n AppLayoutSidebarMenuSkeleton,\n AppLayoutSidebarMenuSub,\n AppLayoutSidebarMenuSubButton,\n AppLayoutSidebarMenuSubItem,\n AppLayoutSidebarRail,\n AppLayoutSidebarSeparator,\n AppLayoutSidebarTrigger,\n // eslint-disable-next-line react-refresh/only-export-components\n useSidebar,\n}\n","'use client'\nimport { ShoppingCartIcon } from 'lucide-react'\n\nimport { cn } from '@/lib/utils'\n\nimport { Sidebar, AppLayoutSidebarInset, SidebarProvider, AppLayoutSidebarTrigger } from './sidebar'\n\nexport * from './sidebar'\n\nexport const AppLayoutWrapper: React.FC<React.PropsWithChildren> = ({ children }) => {\n return <SidebarProvider>{children}</SidebarProvider>\n}\n\nexport const AppLayoutHeader: React.FC<React.PropsWithChildren> = ({ children }) => {\n return (\n <header\n className={cn(\n 'bg-card',\n 'h-(--header-height)',\n 'absolute inset-x-0 top-0 z-20 gap-2 px-4',\n 'shadow-nav flex items-center',\n 'transition-[width,height] ease-linear',\n 'group-has-data-[collapsible=icon]/sidebar-wrapper:h-(--header-height)',\n )}\n >\n <AppLayoutSidebarTrigger />\n\n <div className=\"ml-2.5 flex gap-x-2\">\n <div className=\"bg-sidebar-primary text-sidebar-primary-foreground flex aspect-square size-8 items-center justify-center rounded-lg\">\n <ShoppingCartIcon size={20} />\n </div>\n <div className=\"grid flex-1 text-left text-sm leading-tight\">\n <span className=\"truncate font-medium\">Lunas Store</span>\n <span className=\"truncate text-xs\">Established 2023</span>\n </div>\n </div>\n\n <div className=\"flex flex-1 items-center justify-end\">{children}</div>\n </header>\n )\n}\n\nexport const AppLayoutSidebar: React.FC<React.PropsWithChildren & React.ComponentProps<typeof Sidebar>> = ({ children, ...props }) => {\n return (\n <Sidebar variant=\"inset\" collapsible=\"icon\" {...props}>\n {children}\n </Sidebar>\n )\n}\n\nexport const AppLayoutMain: React.FC<React.PropsWithChildren> = ({ children }) => {\n return (\n <AppLayoutSidebarInset>\n <section className=\"relative size-full\">\n <div className=\"absolute inset-0\">{children}</div>\n </section>\n </AppLayoutSidebarInset>\n )\n}\n\nexport const AppLayoutMainGroup: React.FC<React.PropsWithChildren<{ className?: string }>> = ({ children, className }) => {\n return (\n <div data-slot=\"main-group\" className={cn('flex size-full flex-col gap-4 overflow-y-auto p-4', className)}>\n {children}\n </div>\n )\n}\n\nexport const AppLayoutMainGroupContent: React.FC<React.PropsWithChildren> = ({ children }) => {\n return (\n <div data-slot=\"main-group-content\" className=\"bg-card shadow-card size-full rounded-md p-4\">\n {children}\n </div>\n )\n}\n"],"mappings":"mtBAeA,MAiBM,EAAiB,EAAM,cAA0C,MAEvE,SAAS,GAAa,CACpB,IAAM,EAAU,EAAM,WAAW,GACjC,GAAI,CAAC,EACH,MAAU,MAAM,qDAGlB,OAAO,EAGT,SAAS,EAAgB,CACvB,cAAc,GACd,KAAM,EACN,aAAc,EACd,YACA,QACA,WACA,GAAG,GAKF,CACD,IAAM,EAAW,IACX,CAAC,EAAY,GAAiB,EAAM,SAAS,IAI7C,CAAC,EAAO,GAAY,EAAM,SAAS,GACnC,EAAO,GAAY,EACnB,EAAU,EAAM,YACnB,GAAmD,CAClD,IAAM,EAAY,OAAO,GAAU,WAAa,EAAM,GAAQ,EAC1D,EACF,EAAY,GAEZ,EAAS,GAIX,SAAS,OAAS,iBAA0B,EAAU,2BAExD,CAAC,EAAa,IAIV,EAAgB,EAAM,gBACnB,EAAW,EAAe,GAAS,CAACA,GAAQ,EAAS,GAAS,CAACA,GACrE,CAAC,EAAU,EAAS,IAGvB,EAAM,cAAgB,CACpB,IAAM,EAAiB,GAAyB,CAC1C,EAAM,MAAQ,MAA8B,EAAM,SAAW,EAAM,WACrE,EAAM,iBACN,MAKJ,OADA,OAAO,iBAAiB,UAAW,OACtB,OAAO,oBAAoB,UAAW,IAClD,CAAC,IAIJ,IAAM,EAAQ,EAAO,WAAa,YAE5B,EAAe,EAAM,aAClB,CACL,QACA,WAEA,gBAEA,OACA,UAEA,aACA,kBAEF,CAAC,EAAO,EAAM,EAAS,EAAU,EAAY,EAAe,IAG9D,OACE,EAAC,EAAe,SAAA,CAAS,MAAO,WAC9B,EAAC,EAAA,CAAgB,cAAe,WAC9B,EAAC,MAAA,CACC,YAAU,kBACV,MACE,CACE,kBAAmB,QACnB,uBAAwB,OACxB,GAAG,GAGP,UAAW,EAAG,wBAAyB,sCAAuC,oBAAqB,GACnG,GAAI,EAEH,iBAOX,SAAS,EAAQ,CACf,OAAO,OACP,UAAU,UACV,cAAc,YACd,YACA,WACA,GAAG,GAKF,CACD,GAAM,CAAE,WAAU,QAAO,aAAY,iBAAkB,IAmCvD,OAjCI,IAAgB,OAEhB,EAAC,QAAA,CAAM,YAAU,UAAU,UAAW,EAAG,aAAc,0BAA2B,2CAA4C,GAAY,GAAI,EAC3I,aAKH,EAEA,EAAC,EAAA,CAAM,KAAM,EAAY,aAAc,EAAe,GAAI,WACxD,EAAC,EAAA,CACC,eAAa,UACb,YAAU,UACV,cAAY,OACZ,UAAU,+EACV,MACE,CACE,kBAAmB,SAGjB,iBAEN,EAAC,EAAA,CAAY,UAAU,oBACrB,EAAC,EAAA,CAAA,SAAW,YACZ,EAAC,EAAA,CAAA,SAAiB,oCAEpB,EAAC,MAAA,CAAI,UAAU,8BAA+B,kBAOpD,EAAC,QAAA,CACC,UAAU,6DACV,aAAY,EACZ,mBAAkB,IAAU,YAAc,EAAc,GACxD,eAAc,EACd,YAAW,EACX,YAAU,oBAGV,EAAC,MAAA,CACC,YAAU,cACV,UAAW,EACT,WACA,iBACA,8CACA,2BACA,yCACA,qCACA,IAAY,YAAc,IAAY,QAClC,mFACA,4DAGR,EAAC,MAAA,CACC,YAAU,oBACV,UAAW,EACT,iBACA,yCACA,8CACA,yDACA,IAAS,QAAU,iFACnB,IAAS,SAAW,mFAEpB,IAAY,YAAc,IAAY,QAClC,uFACA,0HACJ,GAEF,GAAI,WAEJ,EAAC,MAAA,CACC,eAAa,UACb,YAAU,gBACV,UAAW,EACT,0BACA,2CACA,uCACA,sDACA,2CAGD,kBAOX,SAAS,EAAwB,CAAE,YAAW,UAAS,GAAG,GAA8C,CACtG,GAAM,CAAE,iBAAkB,IAE1B,OACE,EAAC,EAAA,CACC,eAAa,UACb,YAAU,kBACV,QAAQ,QACR,MAAM,QACN,KAAK,OACL,UAAW,EAAG,uBAAwB,GACtC,QAAU,GAAU,CAClB,IAAU,GACV,KAEF,GAAI,YAEJ,EAAC,EAAA,CAAS,UAAU,YACpB,EAAC,OAAA,CAAK,UAAU,mBAAU,sBAKhC,SAAS,EAAqB,CAAE,YAAW,GAAG,GAAyC,CACrF,GAAM,CAAE,iBAAkB,IAE1B,OACE,EAAC,SAAA,CACC,eAAa,OACb,YAAU,eACV,aAAW,iBACX,SAAU,GACV,QAAS,EACT,MAAM,iBACN,UAAW,EACT,yFACA,8DACA,kCACA,iCACA,sCACA,uCACA,gCACA,sDACA,mDACA,qDACA,6DACA,8DACA,4DACA,4DACA,GAEF,GAAI,IAKV,SAAS,EAAsB,CAAE,YAAW,WAAU,GAAG,GAAuC,CAC9F,OACE,EAAC,OAAA,CAAK,YAAU,gBAAgB,UAAW,EAAG,uCAAwC,GAAY,GAAI,YACpG,EAAC,MAAA,CAAI,UAAU,gBACf,EAAC,MAAA,CAAI,UAAW,EAAG,0BAA4B,gBAKrD,SAAS,EAAuB,CAAE,YAAW,GAAG,GAAsC,CACpF,OAAO,EAAC,MAAA,CAAI,YAAU,iBAAiB,eAAa,SAAS,UAAW,EAAG,0BAA2B,GAAY,GAAI,IAGxH,SAAS,EAAuB,CAAE,YAAW,GAAG,GAAsC,CACpF,OAAO,EAAC,MAAA,CAAI,YAAU,iBAAiB,eAAa,SAAS,UAAW,EAAG,0BAA2B,GAAY,GAAI,IAGxH,SAAS,EAA0B,CAAE,YAAW,GAAG,GAAiD,CAClG,OAAO,EAACC,EAAAA,CAAU,YAAU,oBAAoB,eAAa,YAAY,UAAW,EAAG,gCAAiC,GAAY,GAAI,IAG1I,SAAS,EAAwB,CAAE,YAAW,GAAG,GAAsC,CACrF,OACE,EAAC,MAAA,CACC,YAAU,kBACV,eAAa,UACb,UAAW,EAAG,iGAAkG,GAChH,GAAI,IAKV,SAAS,EAAsB,CAAE,YAAW,GAAG,GAAsC,CACnF,OAAO,EAAC,MAAA,CAAI,YAAU,gBAAgB,eAAa,QAAQ,UAAW,EAAG,4CAA6C,GAAY,GAAI,IAGxI,SAAS,EAA2B,CAAE,YAAW,UAAU,GAAO,GAAG,GAA8D,CACjI,IAAM,EAAO,EAAUC,EAAc,KAAO,MAE5C,OACE,EAAC,EAAA,CACC,YAAU,sBACV,eAAa,cACb,UAAW,EACT,8JACA,6BACA,oBACA,iBACA,mBACA,sCACA,0CACA,GAEF,GAAI,IAKV,SAAS,EAA4B,CAAE,YAAW,UAAU,GAAO,GAAG,GAAiE,CACrI,IAAM,EAAO,EAAUA,EAAc,KAAO,SAE5C,OACE,EAAC,EAAA,CACC,YAAU,uBACV,eAAa,eACb,UAAW,EACT,wOACA,uBACA,iBACA,mBAEA,gDACA,uCACA,GAEF,GAAI,IAKV,SAAS,EAA6B,CAAE,YAAW,GAAG,GAAsC,CAC1F,OAAO,EAAC,MAAA,CAAI,YAAU,wBAAwB,eAAa,gBAAgB,UAAW,EAAG,iBAAkB,GAAY,GAAI,IAG7H,SAAS,EAAqB,CAAE,YAAW,GAAG,GAAqC,CACjF,OAAO,EAAC,KAAA,CAAG,YAAU,eAAe,eAAa,OAAO,UAAW,EAAG,qCAAsC,GAAY,GAAI,IAG9H,SAAS,EAAyB,CAAE,YAAW,GAAG,GAAqC,CACrF,OAAO,EAAC,KAAA,CAAG,YAAU,oBAAoB,eAAa,YAAY,UAAW,EAAG,2BAA4B,GAAY,GAAI,IAG9H,MAAM,EAA4B,EAChC,CACE,mBACA,iBACA,iCACA,gDACA,qBACA,0CACA,0BACA,uCACA,2BACA,wCACA,+BACA,sBACA,sDACA,oCACA,2BACA,8CACA,iCACA,0CACA,4CACA,yDACA,wCACA,qCACA,iBACA,mBACA,gCAEF,CACE,SAAU,CACR,QAAS,CACP,QAAS,qEACT,QACE,gLAEJ,KAAM,CACJ,QAAS,cACT,GAAI,cACJ,GAAI,oDAGR,gBAAiB,CACf,QAAS,UACT,KAAM,aAKZ,SAAS,EAA2B,CAClC,UAAU,GACV,WAAW,GACX,UAAU,UACV,OAAO,UACP,UACA,YACA,GAAG,GAK+C,CAClD,IAAM,EAAO,EAAUA,EAAc,KAAO,SACtC,CAAE,WAAU,SAAU,IAEtB,EACJ,EAAC,EAAA,CACC,YAAU,sBACV,eAAa,cACb,YAAW,EACX,cAAa,EACb,UAAW,EAAG,EAA0B,CAAE,UAAS,SAAS,GAC5D,GAAI,IAcR,OAVK,GAID,OAAO,GAAY,WACrB,EAAU,CACR,SAAU,IAKZ,EAACC,EAAAA,CAAAA,SAAAA,CACC,EAAC,EAAA,CAAe,QAAA,YAAS,IACzB,EAAC,EAAA,CAAe,KAAK,QAAQ,MAAM,SAAS,OAAQ,IAAU,aAAe,EAAU,GAAI,QAZtF,EAiBX,SAAS,EAA2B,CAClC,YACA,UAAU,GACV,cAAc,GACd,GAAG,GAIF,CACD,IAAM,EAAO,EAAUD,EAAc,KAAO,SAE5C,OACE,EAAC,EAAA,CACC,YAAU,sBACV,eAAa,cACb,UAAW,EACT,8RACA,uBACA,iBACA,mBAEA,gDACA,wCACA,+CACA,0CACA,uCACA,GAAe,qEACf,GAAe,2CACf,GAAe,oCACf,GAAe,6CACf,GAEF,GAAI,IAKV,SAAS,EAA0B,CAAE,YAAW,GAAG,GAAsC,CACvF,OACE,EAAC,MAAA,CACC,YAAU,qBACV,eAAa,aACb,UAAW,EACT,yKACA,wDACA,qEACA,wCACA,+CACA,0CACA,uCACA,GAEF,GAAI,IAKV,SAAS,EAA6B,CACpC,YACA,WAAW,GACX,GAAG,GAGF,CAED,IAAM,EAAQ,EAAM,YACX,GAAG,KAAK,MAAM,KAAK,SAAW,IAAM,GAAG,GAC7C,IAEH,OACE,EAAC,MAAA,CAAI,YAAU,wBAAwB,eAAa,gBAAgB,UAAW,EAAG,8CAA+C,GAAY,GAAI,YAC9I,GAAY,EAAC,EAAA,CAAS,UAAU,oBAAoB,eAAa,uBAClE,EAAC,EAAA,CACC,UAAU,sCACV,eAAa,qBACb,MACE,CACE,mBAAoB,QAQhC,SAAS,EAAwB,CAAE,YAAW,GAAG,GAAqC,CACpF,OACE,EAAC,KAAA,CACC,YAAU,mBACV,eAAa,WACb,UAAW,EACT,iGACA,uCACA,GAEF,GAAI,IAKV,SAAS,EAA4B,CAAE,YAAW,GAAG,GAAqC,CACxF,OAAO,EAAC,KAAA,CAAG,YAAU,wBAAwB,eAAa,gBAAgB,UAAW,EAAG,+BAAgC,GAAY,GAAI,IAG1I,SAAS,EAA8B,CACrC,UAAU,GACV,OAAO,KACP,WAAW,GACX,YACA,GAAG,GAKF,CACD,IAAM,EAAO,EAAUA,EAAc,KAAO,IAE5C,OACE,EAAC,EAAA,CACC,YAAU,0BACV,eAAa,kBACb,YAAW,EACX,cAAa,EACb,UAAW,EACT,0BACA,oBACA,qGACA,uBACA,0BACA,uCACA,2BACA,wCACA,+BACA,sBACA,oCACA,2BACA,iBACA,mBACA,yCACA,+BACA,uCACA,oDACA,IAAS,MAAQ,UACjB,IAAS,MAAQ,UACjB,uCACA,GAEF,GAAI,IC/mBV,MAAaE,GAAuD,CAAE,cAC7D,EAAC,EAAA,CAAiB,aAGdC,GAAsD,CAAE,cAEjE,EAAC,SAAA,CACC,UAAW,EACT,UACA,sBACA,2CACA,+BACA,wCACA,mFAGF,EAAC,EAAA,IAED,EAAC,MAAA,CAAI,UAAU,gCACb,EAAC,MAAA,CAAI,UAAU,+HACb,EAAC,EAAA,CAAiB,KAAM,OAE1B,EAAC,MAAA,CAAI,UAAU,wDACb,EAAC,OAAA,CAAK,UAAU,gCAAuB,gBACvC,EAAC,OAAA,CAAK,UAAU,4BAAmB,2BAIvC,EAAC,MAAA,CAAI,UAAU,uCAAwC,gBAKhDC,GAA8F,CAAE,WAAU,GAAG,KAEtH,EAAC,EAAA,CAAQ,QAAQ,QAAQ,YAAY,OAAO,GAAI,EAC7C,aAKMC,GAAoD,CAAE,cAE/D,EAAC,EAAA,CAAA,SACC,EAAC,UAAA,CAAQ,UAAU,8BACjB,EAAC,MAAA,CAAI,UAAU,mBAAoB,iBAM9BC,GAAiF,CAAE,WAAU,eAEtG,EAAC,MAAA,CAAI,YAAU,aAAa,UAAW,EAAG,oDAAqD,GAC5F,aAKMC,GAAgE,CAAE,cAE3E,EAAC,MAAA,CAAI,YAAU,qBAAqB,UAAU,+CAC3C"}
@@ -1,6 +1,6 @@
1
- import * as react_jsx_runtime72 from "react/jsx-runtime";
1
+ import * as react_jsx_runtime12 from "react/jsx-runtime";
2
2
  import React from "react";
3
- import * as class_variance_authority_types1 from "class-variance-authority/types";
3
+ import * as class_variance_authority_types0 from "class-variance-authority/types";
4
4
  import { VariantProps } from "class-variance-authority";
5
5
 
6
6
  //#region packages/components/layouts/flex.d.ts
@@ -8,12 +8,12 @@ declare const flexVariants: (props?: ({
8
8
  vertical?: boolean | null | undefined;
9
9
  width?: "full" | "auto" | "fit" | "screen" | "min" | "max" | null | undefined;
10
10
  wrap?: boolean | null | undefined;
11
- margin?: "sm" | "lg" | "md" | "xl" | "none" | null | undefined;
12
- padding?: "sm" | "lg" | "md" | "xl" | "none" | null | undefined;
13
- gap?: "sm" | "lg" | "xs" | "md" | "xl" | "none" | null | undefined;
11
+ margin?: "sm" | "md" | "lg" | "xl" | "none" | null | undefined;
12
+ padding?: "sm" | "md" | "lg" | "xl" | "none" | null | undefined;
13
+ gap?: "xs" | "sm" | "md" | "lg" | "xl" | "none" | null | undefined;
14
14
  justify?: "start" | "center" | "end" | "between" | "around" | "evenly" | "stretch" | null | undefined;
15
15
  align?: "start" | "center" | "end" | "stretch" | "baseline" | null | undefined;
16
- } & class_variance_authority_types1.ClassProp) | undefined) => string;
16
+ } & class_variance_authority_types0.ClassProp) | undefined) => string;
17
17
  type Props = {
18
18
  className?: string;
19
19
  } & VariantProps<typeof flexVariants>;
@@ -28,7 +28,7 @@ declare const Flex: ({
28
28
  align,
29
29
  className,
30
30
  children
31
- }: React.PropsWithChildren<Props>) => react_jsx_runtime72.JSX.Element;
31
+ }: React.PropsWithChildren<Props>) => react_jsx_runtime12.JSX.Element;
32
32
  //#endregion
33
33
  export { Flex };
34
34
  //# sourceMappingURL=flex.d.cts.map
@@ -1,5 +1,5 @@
1
1
  import React from "react";
2
- import * as react_jsx_runtime14 from "react/jsx-runtime";
2
+ import * as react_jsx_runtime12 from "react/jsx-runtime";
3
3
  import { VariantProps } from "class-variance-authority";
4
4
  import * as class_variance_authority_types0 from "class-variance-authority/types";
5
5
 
@@ -8,9 +8,9 @@ declare const flexVariants: (props?: ({
8
8
  vertical?: boolean | null | undefined;
9
9
  width?: "full" | "auto" | "fit" | "screen" | "min" | "max" | null | undefined;
10
10
  wrap?: boolean | null | undefined;
11
- margin?: "sm" | "lg" | "md" | "xl" | "none" | null | undefined;
12
- padding?: "sm" | "lg" | "md" | "xl" | "none" | null | undefined;
13
- gap?: "sm" | "lg" | "xs" | "md" | "xl" | "none" | null | undefined;
11
+ margin?: "sm" | "md" | "lg" | "xl" | "none" | null | undefined;
12
+ padding?: "sm" | "md" | "lg" | "xl" | "none" | null | undefined;
13
+ gap?: "xs" | "sm" | "md" | "lg" | "xl" | "none" | null | undefined;
14
14
  justify?: "start" | "center" | "end" | "between" | "around" | "evenly" | "stretch" | null | undefined;
15
15
  align?: "start" | "center" | "end" | "stretch" | "baseline" | null | undefined;
16
16
  } & class_variance_authority_types0.ClassProp) | undefined) => string;
@@ -28,7 +28,7 @@ declare const Flex: ({
28
28
  align,
29
29
  className,
30
30
  children
31
- }: React.PropsWithChildren<Props>) => react_jsx_runtime14.JSX.Element;
31
+ }: React.PropsWithChildren<Props>) => react_jsx_runtime12.JSX.Element;
32
32
  //#endregion
33
33
  export { Flex };
34
34
  //# sourceMappingURL=flex.d.ts.map
@@ -1,17 +1,17 @@
1
- import * as react_jsx_runtime260 from "react/jsx-runtime";
1
+ import * as react_jsx_runtime282 from "react/jsx-runtime";
2
2
 
3
3
  //#region packages/components/layouts/main/wrapper.d.ts
4
4
  declare const MainLayoutWrapper: ({
5
5
  children
6
- }: React.PropsWithChildren) => react_jsx_runtime260.JSX.Element;
6
+ }: React.PropsWithChildren) => react_jsx_runtime282.JSX.Element;
7
7
  //#endregion
8
8
  //#region packages/components/layouts/main/content.d.ts
9
9
  declare const MainLayoutContent: ({
10
10
  children
11
- }: React.PropsWithChildren) => react_jsx_runtime260.JSX.Element;
11
+ }: React.PropsWithChildren) => react_jsx_runtime282.JSX.Element;
12
12
  //#endregion
13
13
  //#region packages/components/layouts/main/header.d.ts
14
- declare const MainLayoutHeader: () => react_jsx_runtime260.JSX.Element;
14
+ declare const MainLayoutHeader: () => react_jsx_runtime282.JSX.Element;
15
15
  //#endregion
16
16
  export { MainLayoutContent, MainLayoutHeader, MainLayoutWrapper };
17
17
  //# sourceMappingURL=index.d.ts.map
@@ -1,4 +1,4 @@
1
- import * as react_jsx_runtime85 from "react/jsx-runtime";
1
+ import * as react_jsx_runtime78 from "react/jsx-runtime";
2
2
  import { Separator } from "radix-ui";
3
3
 
4
4
  //#region packages/components/ui/separator.d.ts
@@ -7,7 +7,7 @@ declare function Separator$1({
7
7
  orientation,
8
8
  decorative,
9
9
  ...props
10
- }: React.ComponentProps<typeof Separator.Root>): react_jsx_runtime85.JSX.Element;
10
+ }: React.ComponentProps<typeof Separator.Root>): react_jsx_runtime78.JSX.Element;
11
11
  //#endregion
12
12
  export { Separator$1 as Separator };
13
- //# sourceMappingURL=separator-DUrj7nek.d.ts.map
13
+ //# sourceMappingURL=separator-Dbp_UwEF.d.cts.map
@@ -1,4 +1,4 @@
1
- import * as react_jsx_runtime254 from "react/jsx-runtime";
1
+ import * as react_jsx_runtime179 from "react/jsx-runtime";
2
2
  import { Separator } from "radix-ui";
3
3
 
4
4
  //#region packages/components/ui/separator.d.ts
@@ -7,7 +7,7 @@ declare function Separator$1({
7
7
  orientation,
8
8
  decorative,
9
9
  ...props
10
- }: React.ComponentProps<typeof Separator.Root>): react_jsx_runtime254.JSX.Element;
10
+ }: React.ComponentProps<typeof Separator.Root>): react_jsx_runtime179.JSX.Element;
11
11
  //#endregion
12
12
  export { Separator$1 as Separator };
13
- //# sourceMappingURL=separator-DnlF2DdF.d.cts.map
13
+ //# sourceMappingURL=separator-G_CtQEqW.d.ts.map
@@ -0,0 +1,2 @@
1
+ const e=require(`./chunk-CUT6urMc.cjs`),t=require(`./utils-BsjVK5EW.cjs`),n=require(`./tooltip-D7xs4Hao.cjs`),r=require(`./button-Cg9ZsZ68.cjs`),i=require(`./input-C2xQcVZP.cjs`),a=require(`./separator-Cigaqna1.cjs`),o=require(`./sheet-CX3PajAc.cjs`),s=require(`./skeleton-tNlCAW9R.cjs`),c=require(`./use-mobile-DD7ESbjU.cjs`),l=e.__toESM(require(`react`)),u=e.__toESM(require(`react/jsx-runtime`)),d=e.__toESM(require(`class-variance-authority`)),f=e.__toESM(require(`radix-ui`)),p=e.__toESM(require(`lucide-react`)),m=`detai_dialog_sidebar_state`,h=3600*24*7,g=`16rem`,_=`18rem`,v=`3rem`,y=`p`,b=l.default.createContext(null);function x(){let e=l.default.useContext(b);if(!e)throw Error(`useSidebar must be used within a SidebarProvider.`);return e}function S({defaultOpen:e=!0,open:r,onOpenChange:i,className:a,style:o,children:s,...d}){let f=c.useIsMobile(),[p,m]=l.default.useState(!1),[h,g]=l.default.useState(e),_=r??h,v=l.default.useCallback(e=>{let t=typeof e==`function`?e(_):e;i?i(t):g(t),document.cookie=`detai_dialog_sidebar_state=${t}; path=/; max-age=604800`},[i,_]),y=l.default.useCallback(()=>f?m(e=>!e):v(e=>!e),[v]);l.default.useEffect(()=>{let e=e=>{e.key===`p`&&(e.metaKey||e.ctrlKey)&&(e.preventDefault(),y())};return window.addEventListener(`keydown`,e),()=>window.removeEventListener(`keydown`,e)},[y]);let x=_?`expanded`:`collapsed`,S=l.default.useMemo(()=>({state:x,isMobile:f,toggleSidebar:y,open:_,setOpen:v,openMobile:p,setOpenMobile:m}),[x,_,v,p,m,y]);return(0,u.jsx)(b.Provider,{value:S,children:(0,u.jsx)(n.TooltipProvider,{delayDuration:0,children:(0,u.jsx)(`div`,{"data-slot":`sidebar-wrapper`,style:{"--sidebar-width":`16rem`,"--sidebar-width-icon":`3rem`,...o},className:t.cn(`group/sidebar-wrapper`,`has-data-[variant=inset]:bg-sidebar`,`flex min-h-svh w-full`,a),...d,children:s})})})}function C({side:e=`left`,variant:n=`sidebar`,collapsible:r=`offcanvas`,className:i,children:a,...s}){let{state:c,isMobile:l,openMobile:d,setOpenMobile:f}=x();return r===`none`?(0,u.jsx)(`div`,{"data-slot":`sidebar`,className:t.cn(`bg-sidebar text-sidebar-foreground flex h-full w-(--sidebar-width) flex-col`,i),...s,children:a}):l?(0,u.jsx)(o.Sheet,{open:d,onOpenChange:f,...s,children:(0,u.jsxs)(o.SheetContent,{"data-sidebar":`sidebar`,"data-slot":`sidebar`,"data-mobile":`true`,className:`bg-sidebar text-sidebar-foreground w-(--sidebar-width) p-0 [&>button]:hidden`,style:{"--sidebar-width":`18rem`},side:e,children:[(0,u.jsxs)(o.SheetHeader,{className:`sr-only`,children:[(0,u.jsx)(o.SheetTitle,{children:`Sidebar`}),(0,u.jsx)(o.SheetDescription,{children:`Displays the mobile sidebar.`})]}),(0,u.jsx)(`div`,{className:`flex h-full w-full flex-col`,children:a})]})}):(0,u.jsxs)(`div`,{className:`group peer text-sidebar-foreground hidden md:block`,"data-state":c,"data-collapsible":c===`collapsed`?r:``,"data-variant":n,"data-side":e,"data-slot":`sidebar`,children:[(0,u.jsx)(`div`,{"data-slot":`sidebar-gap`,className:t.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`,n===`floating`||n===`inset`?`group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)+(--spacing(4)))]`:`group-data-[collapsible=icon]:w-(--sidebar-width-icon)`)}),(0,u.jsx)(`div`,{"data-slot":`sidebar-container`,className:t.cn(`absolute inset-y-0 z-10 hidden w-(--sidebar-width) transition-[left,right,width] duration-200 ease-linear md:flex`,e===`left`?`left-0 group-data-[collapsible=offcanvas]:left-[calc(var(--sidebar-width)*-1)]`:`right-0 group-data-[collapsible=offcanvas]:right-[calc(var(--sidebar-width)*-1)]`,n===`floating`||n===`inset`?`p-2 group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)+(--spacing(4))+2px)]`:`group-data-[collapsible=icon]:w-(--sidebar-width-icon)`,i),...s,children:(0,u.jsx)(`div`,{"data-sidebar":`sidebar`,"data-slot":`sidebar-inner`,className:t.cn(`flex h-full w-full flex-col`,`group-data-[variant=floating]:border-sidebar-border`,`group-data-[variant=floating]:rounded-lg`,`group-data-[variant=floating]:border`,`group-data-[variant=floating]:shadow-sm`),children:a})})]})}function w({className:e,onClick:n,...i}){let{toggleSidebar:a}=x();return(0,u.jsxs)(r.Button,{"data-sidebar":`trigger`,"data-slot":`sidebar-trigger`,variant:`ghost`,color:`secondary`,size:`icon`,className:t.cn(`size-10 rounded-full [&_svg]:!size-6`,e),onClick:e=>{n?.(e),a()},...i,children:[(0,u.jsx)(p.MenuIcon,{}),(0,u.jsx)(`span`,{className:`sr-only`,children:`Toggle Sidebar`})]})}function T({className:e,...n}){let{toggleSidebar:r}=x();return(0,u.jsx)(`button`,{"data-sidebar":`rail`,"data-slot":`sidebar-rail`,"aria-label":`Toggle Sidebar`,tabIndex:-1,onClick:r,title:`Toggle Sidebar`,className:t.cn(`absolute inset-y-0 z-20 hidden w-4 -translate-x-1/2 transition-all ease-linear sm:flex`,`after:absolute`,`after:inset-y-0`,`after:left-1/2 after:w-0.5`,`hover:after:bg-sidebar-border`,`group-data-[side=left]:-right-4`,`group-data-[side=right]:left-0`,`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`,`hover:group-data-[collapsible=offcanvas]:bg-sidebar`,`group-data-[collapsible=offcanvas]:translate-x-0`,`group-data-[collapsible=offcanvas]:after:left-full`,`[[data-side=left][data-collapsible=offcanvas]_&]:-right-2`,`[[data-side=right][data-collapsible=offcanvas]_&]:-left-2`,e),...n})}function E({className:e,...n}){return(0,u.jsx)(`main`,{"data-slot":`sidebar-inset`,className:t.cn(`bg-background relative flex w-full flex-1 flex-col`,`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`,e),...n})}function D({className:e,...n}){return(0,u.jsx)(i.Input,{"data-slot":`sidebar-input`,"data-sidebar":`input`,className:t.cn(`bg-background h-8 w-full shadow-none`,e),...n})}function O({className:e,...n}){return(0,u.jsx)(`div`,{"data-slot":`sidebar-header`,"data-sidebar":`header`,className:t.cn(`flex flex-col gap-2 p-2`,e),...n})}function k({className:e,...n}){return(0,u.jsx)(`div`,{"data-slot":`sidebar-footer`,"data-sidebar":`footer`,className:t.cn(`flex flex-col gap-2 p-2`,e),...n})}function A({className:e,...n}){return(0,u.jsx)(a.Separator,{"data-slot":`sidebar-separator`,"data-sidebar":`separator`,className:t.cn(`bg-sidebar-border mx-2 w-auto`,e),...n})}function j({className:e,...n}){return(0,u.jsx)(`div`,{"data-slot":`sidebar-content`,"data-sidebar":`content`,className:t.cn(`flex min-h-0 flex-1 flex-col gap-2 overflow-auto`,`group-data-[collapsible=icon]:overflow-hidden`,e),...n})}function M({className:e,...n}){return(0,u.jsx)(`div`,{"data-slot":`sidebar-group`,"data-sidebar":`group`,className:t.cn(`relative flex w-full min-w-0 flex-col p-2`,e),...n})}function N({className:e,asChild:n=!1,...r}){let i=n?f.Slot.Slot:`div`;return(0,u.jsx)(i,{"data-slot":`sidebar-group-label`,"data-sidebar":`group-label`,className:t.cn(`text-sidebar-foreground/70 ring-sidebar-ring flex h-8 shrink-0 items-center rounded-md px-2 text-xs font-medium outline-hidden transition-[margin,opacity] duration-200 ease-linear`,`focus-visible:ring-2`,`[&>svg]:size-4`,`[&>svg]:shrink-0`,`group-data-[collapsible=icon]:-mt-8`,`group-data-[collapsible=icon]:opacity-0`,e),...r})}function P({className:e,asChild:n=!1,...r}){let i=n?f.Slot.Slot:`button`;return(0,u.jsx)(i,{"data-slot":`sidebar-group-action`,"data-sidebar":`group-action`,className:t.cn(`text-sidebar-foreground ring-sidebar-ring absolute top-3.5 right-3 flex aspect-square w-5 items-center justify-center rounded-md p-0 outline-hidden transition-transform`,`hover:bg-sidebar-accent hover:text-sidebar-accent-foreground`,`focus-visible:ring-2`,`[&>svg]:size-4`,`[&>svg]:shrink-0`,`after:absolute`,`after:-inset-2`,`md:after:hidden`,`group-data-[collapsible=icon]:hidden`,e),...r})}function F({className:e,...n}){return(0,u.jsx)(`div`,{"data-slot":`sidebar-group-content`,"data-sidebar":`group-content`,className:t.cn(`w-full text-sm`,e),...n})}function I({className:e,...n}){return(0,u.jsx)(`ul`,{"data-slot":`sidebar-menu`,"data-sidebar":`menu`,className:t.cn(`flex w-full min-w-0 flex-col gap-1`,e),...n})}function L({className:e,...n}){return(0,u.jsx)(`li`,{"data-slot":`sidebar-menu-item`,"data-sidebar":`menu-item`,className:t.cn(`group/menu-item relative`,e),...n})}const R=(0,d.cva)([`peer/menu-button`,`cursor-pointer`,`flex w-full items-center gap-2`,`overflow-hidden rounded-md p-2 outline-hidden`,`text-left truncate`,`transition-[color,width,height,padding]`,`hover:bg-sidebar-accent`,`hover:text-sidebar-accent-foreground`,`active:bg-sidebar-accent`,`active:text-sidebar-accent-foreground`,`disabled:pointer-events-none`,`disabled:opacity-50`,`group-has-data-[sidebar=menu-action]/menu-item:pr-8`,`aria-disabled:pointer-events-none`,`aria-disabled:opacity-50`,`data-[active=true]:bg-sidebar-primary-muted`,`data-[active=true]:font-medium`,`data-[active=true]:text-sidebar-primary`,`data-[state=open]:hover:bg-sidebar-accent`,`data-[state=open]:hover:text-sidebar-accent-foreground`,`group-data-[collapsible=icon]:size-8!`,`group-data-[collapsible=icon]:p-2!`,`[&>svg]:size-4`,`[&>svg]:shrink-0`,`[&>span:last-child]:truncate`],{variants:{variant:{default:`hover:bg-sidebar-accent/60 hover:text-sidebar-accent-foreground/80`,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))]`},size:{default:`h-8 text-sm`,sm:`h-7 text-xs`,lg:`h-12 text-sm group-data-[collapsible=icon]:p-0!`}},defaultVariants:{variant:`default`,size:`default`}});function z({asChild:e=!1,isActive:r=!1,variant:i=`default`,size:a=`default`,tooltip:o,className:s,...c}){let l=e?f.Slot.Slot:`button`,{state:d}=x(),p=(0,u.jsx)(l,{"data-slot":`sidebar-menu-button`,"data-sidebar":`menu-button`,"data-size":a,"data-active":r,className:t.cn(R({variant:i,size:a}),s),...c});return o?(typeof o==`string`&&(o={children:o}),(0,u.jsxs)(n.Tooltip,{children:[(0,u.jsx)(n.TooltipTrigger,{asChild:!0,children:p}),(0,u.jsx)(n.TooltipContent,{side:`right`,align:`center`,hidden:d!==`collapsed`,...o})]})):p}function B({className:e,asChild:n=!1,showOnHover:r=!1,...i}){let a=n?f.Slot.Slot:`button`;return(0,u.jsx)(a,{"data-slot":`sidebar-menu-action`,"data-sidebar":`menu-action`,className:t.cn(`text-sidebar-foreground ring-sidebar-ring`,`hover:bg-sidebar-accent`,`hover:text-sidebar-accent-foreground`,`peer-hover/menu-button:text-sidebar-accent-foreground absolute top-1.5 right-1 flex aspect-square w-5 items-center justify-center rounded-md p-0 outline-hidden transition-transform`,`focus-visible:ring-2`,`[&>svg]:size-4`,`[&>svg]:shrink-0`,`after:absolute after:-inset-2 md:after:hidden`,`peer-data-[size=sm]/menu-button:top-1`,`peer-data-[size=default]/menu-button:top-1.5`,`peer-data-[size=lg]/menu-button:top-2.5`,`group-data-[collapsible=icon]:hidden`,r&&`peer-data-[active=true]/menu-button:text-sidebar-accent-foreground`,r&&`$group-focus-within/menu-item:opacity-100`,r&&`group-hover/menu-item:opacity-100`,r&&`data-[state=open]:opacity-100 md:opacity-0`,e),...i})}function V({className:e,...n}){return(0,u.jsx)(`div`,{"data-slot":`sidebar-menu-badge`,"data-sidebar":`menu-badge`,className:t.cn(`text-sidebar-foreground pointer-events-none absolute right-1 flex h-5 min-w-5 items-center justify-center rounded-md px-1 text-xs font-medium tabular-nums select-none`,`peer-hover/menu-button:text-sidebar-accent-foreground`,`peer-data-[active=true]/menu-button:text-sidebar-accent-foreground`,`peer-data-[size=sm]/menu-button:top-1`,`peer-data-[size=default]/menu-button:top-1.5`,`peer-data-[size=lg]/menu-button:top-2.5`,`group-data-[collapsible=icon]:hidden`,e),...n})}function H({className:e,showIcon:n=!1,...r}){let i=l.default.useMemo(()=>`${Math.floor(Math.random()*40)+50}%`,[]);return(0,u.jsxs)(`div`,{"data-slot":`sidebar-menu-skeleton`,"data-sidebar":`menu-skeleton`,className:t.cn(`flex h-8 items-center gap-2 rounded-md px-2`,e),...r,children:[n&&(0,u.jsx)(s.Skeleton,{className:`size-4 rounded-md`,"data-sidebar":`menu-skeleton-icon`}),(0,u.jsx)(s.Skeleton,{className:`h-4 max-w-(--skeleton-width) flex-1`,"data-sidebar":`menu-skeleton-text`,style:{"--skeleton-width":i}})]})}function U({className:e,...n}){return(0,u.jsx)(`ul`,{"data-slot":`sidebar-menu-sub`,"data-sidebar":`menu-sub`,className:t.cn(`border-sidebar-border mx-3.5 flex min-w-0 translate-x-px flex-col gap-1 border-l px-2.5 py-0.5`,`group-data-[collapsible=icon]:hidden`,e),...n})}function W({className:e,...n}){return(0,u.jsx)(`li`,{"data-slot":`sidebar-menu-sub-item`,"data-sidebar":`menu-sub-item`,className:t.cn(`group/menu-sub-item relative`,e),...n})}function G({asChild:e=!1,size:n=`md`,isActive:r=!1,className:i,...a}){let o=e?f.Slot.Slot:`a`;return(0,u.jsx)(o,{"data-slot":`sidebar-menu-sub-button`,"data-sidebar":`menu-sub-button`,"data-size":n,"data-active":r,className:t.cn(`text-sidebar-foreground ring-sidebar-ring`,`flex h-7 min-w-0 -translate-x-px items-center gap-2 overflow-hidden rounded-md px-2 outline-hidden`,`hover:bg-sidebar-accent`,`hover:text-sidebar-accent-foreground`,`active:bg-sidebar-accent`,`active:text-sidebar-accent-foreground`,`focus-visible:ring-2`,`disabled:pointer-events-none`,`disabled:opacity-50`,`aria-disabled:pointer-events-none`,`aria-disabled:opacity-50`,`[&>span:last-child]:truncate`,`[&>svg]:size-4`,`[&>svg]:shrink-0`,`[&>svg]:text-sidebar-accent-foreground`,`data-[active=true]:bg-sidebar-accent`,`data-[active=true]:text-sidebar-accent-foreground`,`group-data-[collapsible=icon]:hidden`,n===`sm`&&`text-xs`,n===`md`&&`text-sm`,i),...a})}Object.defineProperty(exports,`DetailDialogSidebarContent`,{enumerable:!0,get:function(){return j}}),Object.defineProperty(exports,`DetailDialogSidebarFooter`,{enumerable:!0,get:function(){return k}}),Object.defineProperty(exports,`DetailDialogSidebarGroup`,{enumerable:!0,get:function(){return M}}),Object.defineProperty(exports,`DetailDialogSidebarGroupAction`,{enumerable:!0,get:function(){return P}}),Object.defineProperty(exports,`DetailDialogSidebarGroupContent`,{enumerable:!0,get:function(){return F}}),Object.defineProperty(exports,`DetailDialogSidebarGroupLabel`,{enumerable:!0,get:function(){return N}}),Object.defineProperty(exports,`DetailDialogSidebarHeader`,{enumerable:!0,get:function(){return O}}),Object.defineProperty(exports,`DetailDialogSidebarMenu`,{enumerable:!0,get:function(){return I}}),Object.defineProperty(exports,`DetailDialogSidebarMenuAction`,{enumerable:!0,get:function(){return B}}),Object.defineProperty(exports,`DetailDialogSidebarMenuBadge`,{enumerable:!0,get:function(){return V}}),Object.defineProperty(exports,`DetailDialogSidebarMenuButton`,{enumerable:!0,get:function(){return z}}),Object.defineProperty(exports,`DetailDialogSidebarMenuItem`,{enumerable:!0,get:function(){return L}}),Object.defineProperty(exports,`DetailDialogSidebarMenuSkeleton`,{enumerable:!0,get:function(){return H}}),Object.defineProperty(exports,`DetailDialogSidebarMenuSub`,{enumerable:!0,get:function(){return U}}),Object.defineProperty(exports,`DetailDialogSidebarMenuSubButton`,{enumerable:!0,get:function(){return G}}),Object.defineProperty(exports,`DetailDialogSidebarMenuSubItem`,{enumerable:!0,get:function(){return W}}),Object.defineProperty(exports,`DetailDialogSidebarRail`,{enumerable:!0,get:function(){return T}}),Object.defineProperty(exports,`DetailDialogSidebarSeparator`,{enumerable:!0,get:function(){return A}}),Object.defineProperty(exports,`DetailDialogSidebarTrigger`,{enumerable:!0,get:function(){return w}}),Object.defineProperty(exports,`Sidebar`,{enumerable:!0,get:function(){return C}}),Object.defineProperty(exports,`SidebarInput`,{enumerable:!0,get:function(){return D}}),Object.defineProperty(exports,`SidebarInset`,{enumerable:!0,get:function(){return E}}),Object.defineProperty(exports,`SidebarProvider`,{enumerable:!0,get:function(){return S}}),Object.defineProperty(exports,`useSidebar`,{enumerable:!0,get:function(){return x}});
2
+ //# sourceMappingURL=sidebar-3ZtESIIQ.cjs.map