@appcorp/shadcn 1.0.11 → 1.0.13

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.
@@ -0,0 +1,120 @@
1
+ "use client";
2
+ "use strict";
3
+ var __assign = (this && this.__assign) || function () {
4
+ __assign = Object.assign || function(t) {
5
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
6
+ s = arguments[i];
7
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
8
+ t[p] = s[p];
9
+ }
10
+ return t;
11
+ };
12
+ return __assign.apply(this, arguments);
13
+ };
14
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
15
+ if (k2 === undefined) k2 = k;
16
+ var desc = Object.getOwnPropertyDescriptor(m, k);
17
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
18
+ desc = { enumerable: true, get: function() { return m[k]; } };
19
+ }
20
+ Object.defineProperty(o, k2, desc);
21
+ }) : (function(o, m, k, k2) {
22
+ if (k2 === undefined) k2 = k;
23
+ o[k2] = m[k];
24
+ }));
25
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
26
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
27
+ }) : function(o, v) {
28
+ o["default"] = v;
29
+ });
30
+ var __importStar = (this && this.__importStar) || (function () {
31
+ var ownKeys = function(o) {
32
+ ownKeys = Object.getOwnPropertyNames || function (o) {
33
+ var ar = [];
34
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
35
+ return ar;
36
+ };
37
+ return ownKeys(o);
38
+ };
39
+ return function (mod) {
40
+ if (mod && mod.__esModule) return mod;
41
+ var result = {};
42
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
43
+ __setModuleDefault(result, mod);
44
+ return result;
45
+ };
46
+ })();
47
+ var __rest = (this && this.__rest) || function (s, e) {
48
+ var t = {};
49
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
50
+ t[p] = s[p];
51
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
52
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
53
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
54
+ t[p[i]] = s[p[i]];
55
+ }
56
+ return t;
57
+ };
58
+ Object.defineProperty(exports, "__esModule", { value: true });
59
+ exports.Sheet = Sheet;
60
+ exports.SheetTrigger = SheetTrigger;
61
+ exports.SheetClose = SheetClose;
62
+ exports.SheetContent = SheetContent;
63
+ exports.SheetHeader = SheetHeader;
64
+ exports.SheetFooter = SheetFooter;
65
+ exports.SheetTitle = SheetTitle;
66
+ exports.SheetDescription = SheetDescription;
67
+ var React = __importStar(require("react"));
68
+ var SheetPrimitive = __importStar(require("@radix-ui/react-dialog"));
69
+ var lucide_react_1 = require("lucide-react");
70
+ var utils_1 = require("../lib/utils");
71
+ function Sheet(_a) {
72
+ var props = __rest(_a, []);
73
+ return React.createElement(SheetPrimitive.Root, __assign({ "data-slot": "sheet" }, props));
74
+ }
75
+ function SheetTrigger(_a) {
76
+ var props = __rest(_a, []);
77
+ return React.createElement(SheetPrimitive.Trigger, __assign({ "data-slot": "sheet-trigger" }, props));
78
+ }
79
+ function SheetClose(_a) {
80
+ var props = __rest(_a, []);
81
+ return React.createElement(SheetPrimitive.Close, __assign({ "data-slot": "sheet-close" }, props));
82
+ }
83
+ function SheetPortal(_a) {
84
+ var props = __rest(_a, []);
85
+ return React.createElement(SheetPrimitive.Portal, __assign({ "data-slot": "sheet-portal" }, props));
86
+ }
87
+ function SheetOverlay(_a) {
88
+ var className = _a.className, props = __rest(_a, ["className"]);
89
+ return (React.createElement(SheetPrimitive.Overlay, __assign({ "data-slot": "sheet-overlay", className: (0, utils_1.cn)("data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 fixed inset-0 z-50 bg-black/50", className) }, props)));
90
+ }
91
+ function SheetContent(_a) {
92
+ var className = _a.className, children = _a.children, _b = _a.side, side = _b === void 0 ? "right" : _b, props = __rest(_a, ["className", "children", "side"]);
93
+ return (React.createElement(SheetPortal, null,
94
+ React.createElement(SheetOverlay, null),
95
+ React.createElement(SheetPrimitive.Content, __assign({ "data-slot": "sheet-content", className: (0, utils_1.cn)("bg-background data-[state=open]:animate-in data-[state=closed]:animate-out fixed z-50 flex flex-col gap-4 shadow-lg transition ease-in-out data-[state=closed]:duration-300 data-[state=open]:duration-500", side === "right" &&
96
+ "data-[state=closed]:slide-out-to-right data-[state=open]:slide-in-from-right inset-y-0 right-0 h-full w-3/4 border-l sm:max-w-sm", side === "left" &&
97
+ "data-[state=closed]:slide-out-to-left data-[state=open]:slide-in-from-left inset-y-0 left-0 h-full w-3/4 border-r sm:max-w-sm", side === "top" &&
98
+ "data-[state=closed]:slide-out-to-top data-[state=open]:slide-in-from-top inset-x-0 top-0 h-auto border-b", side === "bottom" &&
99
+ "data-[state=closed]:slide-out-to-bottom data-[state=open]:slide-in-from-bottom inset-x-0 bottom-0 h-auto border-t", className) }, props),
100
+ children,
101
+ React.createElement(SheetPrimitive.Close, { className: "ring-offset-background focus:ring-ring data-[state=open]:bg-secondary absolute top-4 right-4 rounded-xs opacity-70 transition-opacity hover:opacity-100 focus:ring-2 focus:ring-offset-2 focus:outline-hidden disabled:pointer-events-none" },
102
+ React.createElement(lucide_react_1.XIcon, { className: "size-4" }),
103
+ React.createElement("span", { className: "sr-only" }, "Close")))));
104
+ }
105
+ function SheetHeader(_a) {
106
+ var className = _a.className, props = __rest(_a, ["className"]);
107
+ return (React.createElement("div", __assign({ "data-slot": "sheet-header", className: (0, utils_1.cn)("flex flex-col gap-1.5 p-4", className) }, props)));
108
+ }
109
+ function SheetFooter(_a) {
110
+ var className = _a.className, props = __rest(_a, ["className"]);
111
+ return (React.createElement("div", __assign({ "data-slot": "sheet-footer", className: (0, utils_1.cn)("mt-auto flex flex-col gap-2 p-4", className) }, props)));
112
+ }
113
+ function SheetTitle(_a) {
114
+ var className = _a.className, props = __rest(_a, ["className"]);
115
+ return (React.createElement(SheetPrimitive.Title, __assign({ "data-slot": "sheet-title", className: (0, utils_1.cn)("text-foreground font-semibold", className) }, props)));
116
+ }
117
+ function SheetDescription(_a) {
118
+ var className = _a.className, props = __rest(_a, ["className"]);
119
+ return (React.createElement(SheetPrimitive.Description, __assign({ "data-slot": "sheet-description", className: (0, utils_1.cn)("text-muted-foreground text-sm", className) }, props)));
120
+ }
@@ -0,0 +1,69 @@
1
+ import * as React from "react";
2
+ import { VariantProps } from "class-variance-authority";
3
+ import { Button } from "./button";
4
+ import { Input } from "./input";
5
+ import { Separator } from "./separator";
6
+ import { TooltipContent } from "./tooltip";
7
+ type SidebarContextProps = {
8
+ state: "expanded" | "collapsed";
9
+ open: boolean;
10
+ setOpen: (open: boolean) => void;
11
+ openMobile: boolean;
12
+ setOpenMobile: (open: boolean) => void;
13
+ isMobile: boolean;
14
+ toggleSidebar: () => void;
15
+ };
16
+ declare function useSidebar(): SidebarContextProps;
17
+ declare function SidebarProvider({ defaultOpen, open: openProp, onOpenChange: setOpenProp, className, style, children, ...props }: React.ComponentProps<"div"> & {
18
+ defaultOpen?: boolean;
19
+ open?: boolean;
20
+ onOpenChange?: (open: boolean) => void;
21
+ }): React.JSX.Element;
22
+ declare function Sidebar({ side, variant, collapsible, className, children, ...props }: React.ComponentProps<"div"> & {
23
+ side?: "left" | "right";
24
+ variant?: "sidebar" | "floating" | "inset";
25
+ collapsible?: "offcanvas" | "icon" | "none";
26
+ }): React.JSX.Element;
27
+ declare function SidebarTrigger({ className, onClick, ...props }: React.ComponentProps<typeof Button>): React.JSX.Element;
28
+ declare function SidebarRail({ className, ...props }: React.ComponentProps<"button">): React.JSX.Element;
29
+ declare function SidebarInset({ className, ...props }: React.ComponentProps<"main">): React.JSX.Element;
30
+ declare function SidebarInput({ className, ...props }: React.ComponentProps<typeof Input>): React.JSX.Element;
31
+ declare function SidebarHeader({ className, ...props }: React.ComponentProps<"div">): React.JSX.Element;
32
+ declare function SidebarFooter({ className, ...props }: React.ComponentProps<"div">): React.JSX.Element;
33
+ declare function SidebarSeparator({ className, ...props }: React.ComponentProps<typeof Separator>): React.JSX.Element;
34
+ declare function SidebarContent({ className, ...props }: React.ComponentProps<"div">): React.JSX.Element;
35
+ declare function SidebarGroup({ className, ...props }: React.ComponentProps<"div">): React.JSX.Element;
36
+ declare function SidebarGroupLabel({ className, asChild, ...props }: React.ComponentProps<"div"> & {
37
+ asChild?: boolean;
38
+ }): React.JSX.Element;
39
+ declare function SidebarGroupAction({ className, asChild, ...props }: React.ComponentProps<"button"> & {
40
+ asChild?: boolean;
41
+ }): React.JSX.Element;
42
+ declare function SidebarGroupContent({ className, ...props }: React.ComponentProps<"div">): React.JSX.Element;
43
+ declare function SidebarMenu({ className, ...props }: React.ComponentProps<"ul">): React.JSX.Element;
44
+ declare function SidebarMenuItem({ className, ...props }: React.ComponentProps<"li">): React.JSX.Element;
45
+ declare const sidebarMenuButtonVariants: (props?: ({
46
+ variant?: "default" | "outline" | null | undefined;
47
+ size?: "default" | "sm" | "lg" | null | undefined;
48
+ } & import("class-variance-authority/dist/types").ClassProp) | undefined) => string;
49
+ declare function SidebarMenuButton({ asChild, isActive, variant, size, tooltip, className, ...props }: React.ComponentProps<"button"> & {
50
+ asChild?: boolean;
51
+ isActive?: boolean;
52
+ tooltip?: string | React.ComponentProps<typeof TooltipContent>;
53
+ } & VariantProps<typeof sidebarMenuButtonVariants>): React.JSX.Element;
54
+ declare function SidebarMenuAction({ className, asChild, showOnHover, ...props }: React.ComponentProps<"button"> & {
55
+ asChild?: boolean;
56
+ showOnHover?: boolean;
57
+ }): React.JSX.Element;
58
+ declare function SidebarMenuBadge({ className, ...props }: React.ComponentProps<"div">): React.JSX.Element;
59
+ declare function SidebarMenuSkeleton({ className, showIcon, ...props }: React.ComponentProps<"div"> & {
60
+ showIcon?: boolean;
61
+ }): React.JSX.Element;
62
+ declare function SidebarMenuSub({ className, ...props }: React.ComponentProps<"ul">): React.JSX.Element;
63
+ declare function SidebarMenuSubItem({ className, ...props }: React.ComponentProps<"li">): React.JSX.Element;
64
+ declare function SidebarMenuSubButton({ asChild, size, isActive, className, ...props }: React.ComponentProps<"a"> & {
65
+ asChild?: boolean;
66
+ size?: "sm" | "md";
67
+ isActive?: boolean;
68
+ }): React.JSX.Element;
69
+ export { Sidebar, SidebarContent, SidebarFooter, SidebarGroup, SidebarGroupAction, SidebarGroupContent, SidebarGroupLabel, SidebarHeader, SidebarInput, SidebarInset, SidebarMenu, SidebarMenuAction, SidebarMenuBadge, SidebarMenuButton, SidebarMenuItem, SidebarMenuSkeleton, SidebarMenuSub, SidebarMenuSubButton, SidebarMenuSubItem, SidebarProvider, SidebarRail, SidebarSeparator, SidebarTrigger, useSidebar, };
@@ -0,0 +1,326 @@
1
+ "use client";
2
+ "use strict";
3
+ var __assign = (this && this.__assign) || function () {
4
+ __assign = Object.assign || function(t) {
5
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
6
+ s = arguments[i];
7
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
8
+ t[p] = s[p];
9
+ }
10
+ return t;
11
+ };
12
+ return __assign.apply(this, arguments);
13
+ };
14
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
15
+ if (k2 === undefined) k2 = k;
16
+ var desc = Object.getOwnPropertyDescriptor(m, k);
17
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
18
+ desc = { enumerable: true, get: function() { return m[k]; } };
19
+ }
20
+ Object.defineProperty(o, k2, desc);
21
+ }) : (function(o, m, k, k2) {
22
+ if (k2 === undefined) k2 = k;
23
+ o[k2] = m[k];
24
+ }));
25
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
26
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
27
+ }) : function(o, v) {
28
+ o["default"] = v;
29
+ });
30
+ var __importStar = (this && this.__importStar) || (function () {
31
+ var ownKeys = function(o) {
32
+ ownKeys = Object.getOwnPropertyNames || function (o) {
33
+ var ar = [];
34
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
35
+ return ar;
36
+ };
37
+ return ownKeys(o);
38
+ };
39
+ return function (mod) {
40
+ if (mod && mod.__esModule) return mod;
41
+ var result = {};
42
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
43
+ __setModuleDefault(result, mod);
44
+ return result;
45
+ };
46
+ })();
47
+ var __rest = (this && this.__rest) || function (s, e) {
48
+ var t = {};
49
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
50
+ t[p] = s[p];
51
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
52
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
53
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
54
+ t[p[i]] = s[p[i]];
55
+ }
56
+ return t;
57
+ };
58
+ Object.defineProperty(exports, "__esModule", { value: true });
59
+ exports.Sidebar = Sidebar;
60
+ exports.SidebarContent = SidebarContent;
61
+ exports.SidebarFooter = SidebarFooter;
62
+ exports.SidebarGroup = SidebarGroup;
63
+ exports.SidebarGroupAction = SidebarGroupAction;
64
+ exports.SidebarGroupContent = SidebarGroupContent;
65
+ exports.SidebarGroupLabel = SidebarGroupLabel;
66
+ exports.SidebarHeader = SidebarHeader;
67
+ exports.SidebarInput = SidebarInput;
68
+ exports.SidebarInset = SidebarInset;
69
+ exports.SidebarMenu = SidebarMenu;
70
+ exports.SidebarMenuAction = SidebarMenuAction;
71
+ exports.SidebarMenuBadge = SidebarMenuBadge;
72
+ exports.SidebarMenuButton = SidebarMenuButton;
73
+ exports.SidebarMenuItem = SidebarMenuItem;
74
+ exports.SidebarMenuSkeleton = SidebarMenuSkeleton;
75
+ exports.SidebarMenuSub = SidebarMenuSub;
76
+ exports.SidebarMenuSubButton = SidebarMenuSubButton;
77
+ exports.SidebarMenuSubItem = SidebarMenuSubItem;
78
+ exports.SidebarProvider = SidebarProvider;
79
+ exports.SidebarRail = SidebarRail;
80
+ exports.SidebarSeparator = SidebarSeparator;
81
+ exports.SidebarTrigger = SidebarTrigger;
82
+ exports.useSidebar = useSidebar;
83
+ var React = __importStar(require("react"));
84
+ var react_slot_1 = require("@radix-ui/react-slot");
85
+ var class_variance_authority_1 = require("class-variance-authority");
86
+ var lucide_react_1 = require("lucide-react");
87
+ var use_mobile_1 = require("../hooks/use-mobile");
88
+ var utils_1 = require("../lib/utils");
89
+ var button_1 = require("./button");
90
+ var input_1 = require("./input");
91
+ var separator_1 = require("./separator");
92
+ var sheet_1 = require("./sheet");
93
+ var skeleton_1 = require("./skeleton");
94
+ var tooltip_1 = require("./tooltip");
95
+ var SIDEBAR_COOKIE_NAME = "sidebar_state";
96
+ var SIDEBAR_COOKIE_MAX_AGE = 60 * 60 * 24 * 7;
97
+ var SIDEBAR_WIDTH = "16rem";
98
+ var SIDEBAR_WIDTH_MOBILE = "18rem";
99
+ var SIDEBAR_WIDTH_ICON = "3rem";
100
+ var SIDEBAR_KEYBOARD_SHORTCUT = "b";
101
+ var SidebarContext = React.createContext(null);
102
+ function useSidebar() {
103
+ var context = React.useContext(SidebarContext);
104
+ if (!context) {
105
+ throw new Error("useSidebar must be used within a SidebarProvider.");
106
+ }
107
+ return context;
108
+ }
109
+ function SidebarProvider(_a) {
110
+ var _b = _a.defaultOpen, defaultOpen = _b === void 0 ? true : _b, openProp = _a.open, setOpenProp = _a.onOpenChange, className = _a.className, style = _a.style, children = _a.children, props = __rest(_a, ["defaultOpen", "open", "onOpenChange", "className", "style", "children"]);
111
+ var isMobile = (0, use_mobile_1.useIsMobile)();
112
+ var _c = React.useState(false), openMobile = _c[0], setOpenMobile = _c[1];
113
+ // This is the internal state of the sidebar.
114
+ // We use openProp and setOpenProp for control from outside the component.
115
+ var _d = React.useState(defaultOpen), _open = _d[0], _setOpen = _d[1];
116
+ var open = openProp !== null && openProp !== void 0 ? openProp : _open;
117
+ var setOpen = React.useCallback(function (value) {
118
+ var openState = typeof value === "function" ? value(open) : value;
119
+ if (setOpenProp) {
120
+ setOpenProp(openState);
121
+ }
122
+ else {
123
+ _setOpen(openState);
124
+ }
125
+ // This sets the cookie to keep the sidebar state.
126
+ document.cookie = "".concat(SIDEBAR_COOKIE_NAME, "=").concat(openState, "; path=/; max-age=").concat(SIDEBAR_COOKIE_MAX_AGE);
127
+ }, [setOpenProp, open]);
128
+ // Helper to toggle the sidebar.
129
+ var toggleSidebar = React.useCallback(function () {
130
+ return isMobile ? setOpenMobile(function (open) { return !open; }) : setOpen(function (open) { return !open; });
131
+ }, [isMobile, setOpen, setOpenMobile]);
132
+ // Adds a keyboard shortcut to toggle the sidebar.
133
+ React.useEffect(function () {
134
+ var handleKeyDown = function (event) {
135
+ if (event.key === SIDEBAR_KEYBOARD_SHORTCUT &&
136
+ (event.metaKey || event.ctrlKey)) {
137
+ event.preventDefault();
138
+ toggleSidebar();
139
+ }
140
+ };
141
+ window.addEventListener("keydown", handleKeyDown);
142
+ return function () { return window.removeEventListener("keydown", handleKeyDown); };
143
+ }, [toggleSidebar]);
144
+ // We add a state so that we can do data-state="expanded" or "collapsed".
145
+ // This makes it easier to style the sidebar with Tailwind classes.
146
+ var state = open ? "expanded" : "collapsed";
147
+ var contextValue = React.useMemo(function () { return ({
148
+ state: state,
149
+ open: open,
150
+ setOpen: setOpen,
151
+ isMobile: isMobile,
152
+ openMobile: openMobile,
153
+ setOpenMobile: setOpenMobile,
154
+ toggleSidebar: toggleSidebar,
155
+ }); }, [state, open, setOpen, isMobile, openMobile, setOpenMobile, toggleSidebar]);
156
+ return (React.createElement(SidebarContext.Provider, { value: contextValue },
157
+ React.createElement(tooltip_1.TooltipProvider, { delayDuration: 0 },
158
+ React.createElement("div", __assign({ "data-slot": "sidebar-wrapper", style: __assign({ "--sidebar-width": SIDEBAR_WIDTH, "--sidebar-width-icon": SIDEBAR_WIDTH_ICON }, style), className: (0, utils_1.cn)("group/sidebar-wrapper has-data-[variant=inset]:bg-sidebar flex min-h-svh w-full", className) }, props), children))));
159
+ }
160
+ function Sidebar(_a) {
161
+ var _b = _a.side, side = _b === void 0 ? "left" : _b, _c = _a.variant, variant = _c === void 0 ? "sidebar" : _c, _d = _a.collapsible, collapsible = _d === void 0 ? "offcanvas" : _d, className = _a.className, children = _a.children, props = __rest(_a, ["side", "variant", "collapsible", "className", "children"]);
162
+ var _e = useSidebar(), isMobile = _e.isMobile, state = _e.state, openMobile = _e.openMobile, setOpenMobile = _e.setOpenMobile;
163
+ if (collapsible === "none") {
164
+ return (React.createElement("div", __assign({ "data-slot": "sidebar", className: (0, utils_1.cn)("bg-sidebar text-sidebar-foreground flex h-full w-(--sidebar-width) flex-col", className) }, props), children));
165
+ }
166
+ if (isMobile) {
167
+ return (React.createElement(sheet_1.Sheet, __assign({ open: openMobile, onOpenChange: setOpenMobile }, props),
168
+ React.createElement(sheet_1.SheetContent, { "data-sidebar": "sidebar", "data-slot": "sidebar", "data-mobile": "true", className: "bg-sidebar text-sidebar-foreground w-(--sidebar-width) p-0 [&>button]:hidden", style: {
169
+ "--sidebar-width": SIDEBAR_WIDTH_MOBILE,
170
+ }, side: side },
171
+ React.createElement(sheet_1.SheetHeader, { className: "sr-only" },
172
+ React.createElement(sheet_1.SheetTitle, null, "Sidebar"),
173
+ React.createElement(sheet_1.SheetDescription, null, "Displays the mobile sidebar.")),
174
+ React.createElement("div", { className: "flex h-full w-full flex-col" }, children))));
175
+ }
176
+ return (React.createElement("div", { className: "group peer text-sidebar-foreground hidden md:block", "data-state": state, "data-collapsible": state === "collapsed" ? collapsible : "", "data-variant": variant, "data-side": side, "data-slot": "sidebar" },
177
+ React.createElement("div", { "data-slot": "sidebar-gap", className: (0, utils_1.cn)("relative w-(--sidebar-width) bg-transparent transition-[width] duration-200 ease-linear", "group-data-[collapsible=offcanvas]:w-0", "group-data-[side=right]:rotate-180", variant === "floating" || variant === "inset"
178
+ ? "group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)+(--spacing(4)))]"
179
+ : "group-data-[collapsible=icon]:w-(--sidebar-width-icon)") }),
180
+ React.createElement("div", __assign({ "data-slot": "sidebar-container", className: (0, utils_1.cn)("fixed inset-y-0 z-10 hidden h-svh w-(--sidebar-width) transition-[left,right,width] duration-200 ease-linear md:flex", side === "left"
181
+ ? "left-0 group-data-[collapsible=offcanvas]:left-[calc(var(--sidebar-width)*-1)]"
182
+ : "right-0 group-data-[collapsible=offcanvas]:right-[calc(var(--sidebar-width)*-1)]",
183
+ // Adjust the padding for floating and inset variants.
184
+ variant === "floating" || variant === "inset"
185
+ ? "p-2 group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)+(--spacing(4))+2px)]"
186
+ : "group-data-[collapsible=icon]:w-(--sidebar-width-icon) group-data-[side=left]:border-r group-data-[side=right]:border-l", className) }, props),
187
+ React.createElement("div", { "data-sidebar": "sidebar", "data-slot": "sidebar-inner", className: "bg-sidebar group-data-[variant=floating]:border-sidebar-border flex h-full w-full flex-col group-data-[variant=floating]:rounded-lg group-data-[variant=floating]:border group-data-[variant=floating]:shadow-sm" }, children))));
188
+ }
189
+ function SidebarTrigger(_a) {
190
+ var className = _a.className, onClick = _a.onClick, props = __rest(_a, ["className", "onClick"]);
191
+ var toggleSidebar = useSidebar().toggleSidebar;
192
+ return (React.createElement(button_1.Button, __assign({ "data-sidebar": "trigger", "data-slot": "sidebar-trigger", variant: "ghost", size: "icon", className: (0, utils_1.cn)("size-7", className), onClick: function (event) {
193
+ onClick === null || onClick === void 0 ? void 0 : onClick(event);
194
+ toggleSidebar();
195
+ } }, props),
196
+ React.createElement(lucide_react_1.PanelLeftIcon, null),
197
+ React.createElement("span", { className: "sr-only" }, "Toggle Sidebar")));
198
+ }
199
+ function SidebarRail(_a) {
200
+ var className = _a.className, props = __rest(_a, ["className"]);
201
+ var toggleSidebar = useSidebar().toggleSidebar;
202
+ return (React.createElement("button", __assign({ "data-sidebar": "rail", "data-slot": "sidebar-rail", "aria-label": "Toggle Sidebar", tabIndex: -1, onClick: toggleSidebar, title: "Toggle Sidebar", className: (0, utils_1.cn)("hover:after:bg-sidebar-border absolute inset-y-0 z-20 hidden w-4 -translate-x-1/2 transition-all ease-linear group-data-[side=left]:-right-4 group-data-[side=right]:left-0 after:absolute after:inset-y-0 after:left-1/2 after:w-[2px] sm:flex", "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", className) }, props)));
203
+ }
204
+ function SidebarInset(_a) {
205
+ var className = _a.className, props = __rest(_a, ["className"]);
206
+ return (React.createElement("main", __assign({ "data-slot": "sidebar-inset", className: (0, utils_1.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", className) }, props)));
207
+ }
208
+ function SidebarInput(_a) {
209
+ var className = _a.className, props = __rest(_a, ["className"]);
210
+ return (React.createElement(input_1.Input, __assign({ "data-slot": "sidebar-input", "data-sidebar": "input", className: (0, utils_1.cn)("bg-background h-8 w-full shadow-none", className) }, props)));
211
+ }
212
+ function SidebarHeader(_a) {
213
+ var className = _a.className, props = __rest(_a, ["className"]);
214
+ return (React.createElement("div", __assign({ "data-slot": "sidebar-header", "data-sidebar": "header", className: (0, utils_1.cn)("flex flex-col gap-2 p-2", className) }, props)));
215
+ }
216
+ function SidebarFooter(_a) {
217
+ var className = _a.className, props = __rest(_a, ["className"]);
218
+ return (React.createElement("div", __assign({ "data-slot": "sidebar-footer", "data-sidebar": "footer", className: (0, utils_1.cn)("flex flex-col gap-2 p-2", className) }, props)));
219
+ }
220
+ function SidebarSeparator(_a) {
221
+ var className = _a.className, props = __rest(_a, ["className"]);
222
+ return (React.createElement(separator_1.Separator, __assign({ "data-slot": "sidebar-separator", "data-sidebar": "separator", className: (0, utils_1.cn)("bg-sidebar-border mx-2 w-auto", className) }, props)));
223
+ }
224
+ function SidebarContent(_a) {
225
+ var className = _a.className, props = __rest(_a, ["className"]);
226
+ return (React.createElement("div", __assign({ "data-slot": "sidebar-content", "data-sidebar": "content", className: (0, utils_1.cn)("flex min-h-0 flex-1 flex-col gap-2 overflow-auto group-data-[collapsible=icon]:overflow-hidden", className) }, props)));
227
+ }
228
+ function SidebarGroup(_a) {
229
+ var className = _a.className, props = __rest(_a, ["className"]);
230
+ return (React.createElement("div", __assign({ "data-slot": "sidebar-group", "data-sidebar": "group", className: (0, utils_1.cn)("relative flex w-full min-w-0 flex-col p-2", className) }, props)));
231
+ }
232
+ function SidebarGroupLabel(_a) {
233
+ var className = _a.className, _b = _a.asChild, asChild = _b === void 0 ? false : _b, props = __rest(_a, ["className", "asChild"]);
234
+ var Comp = asChild ? react_slot_1.Slot : "div";
235
+ return (React.createElement(Comp, __assign({ "data-slot": "sidebar-group-label", "data-sidebar": "group-label", className: (0, utils_1.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", className) }, props)));
236
+ }
237
+ function SidebarGroupAction(_a) {
238
+ var className = _a.className, _b = _a.asChild, asChild = _b === void 0 ? false : _b, props = __rest(_a, ["className", "asChild"]);
239
+ var Comp = asChild ? react_slot_1.Slot : "button";
240
+ return (React.createElement(Comp, __assign({ "data-slot": "sidebar-group-action", "data-sidebar": "group-action", className: (0, utils_1.cn)("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",
241
+ // Increases the hit area of the button on mobile.
242
+ "after:absolute after:-inset-2 md:after:hidden", "group-data-[collapsible=icon]:hidden", className) }, props)));
243
+ }
244
+ function SidebarGroupContent(_a) {
245
+ var className = _a.className, props = __rest(_a, ["className"]);
246
+ return (React.createElement("div", __assign({ "data-slot": "sidebar-group-content", "data-sidebar": "group-content", className: (0, utils_1.cn)("w-full text-sm", className) }, props)));
247
+ }
248
+ function SidebarMenu(_a) {
249
+ var className = _a.className, props = __rest(_a, ["className"]);
250
+ return (React.createElement("ul", __assign({ "data-slot": "sidebar-menu", "data-sidebar": "menu", className: (0, utils_1.cn)("flex w-full min-w-0 flex-col gap-1", className) }, props)));
251
+ }
252
+ function SidebarMenuItem(_a) {
253
+ var className = _a.className, props = __rest(_a, ["className"]);
254
+ return (React.createElement("li", __assign({ "data-slot": "sidebar-menu-item", "data-sidebar": "menu-item", className: (0, utils_1.cn)("group/menu-item relative", className) }, props)));
255
+ }
256
+ var sidebarMenuButtonVariants = (0, class_variance_authority_1.cva)("peer/menu-button 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] hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 active:bg-sidebar-accent active:text-sidebar-accent-foreground disabled:pointer-events-none disabled:opacity-50 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", {
257
+ variants: {
258
+ variant: {
259
+ default: "hover:bg-sidebar-accent hover:text-sidebar-accent-foreground",
260
+ 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))]",
261
+ },
262
+ size: {
263
+ default: "h-8 text-sm",
264
+ sm: "h-7 text-xs",
265
+ lg: "h-12 text-sm group-data-[collapsible=icon]:p-0!",
266
+ },
267
+ },
268
+ defaultVariants: {
269
+ variant: "default",
270
+ size: "default",
271
+ },
272
+ });
273
+ function SidebarMenuButton(_a) {
274
+ var _b = _a.asChild, asChild = _b === void 0 ? false : _b, _c = _a.isActive, isActive = _c === void 0 ? false : _c, _d = _a.variant, variant = _d === void 0 ? "default" : _d, _e = _a.size, size = _e === void 0 ? "default" : _e, tooltip = _a.tooltip, className = _a.className, props = __rest(_a, ["asChild", "isActive", "variant", "size", "tooltip", "className"]);
275
+ var Comp = asChild ? react_slot_1.Slot : "button";
276
+ var _f = useSidebar(), isMobile = _f.isMobile, state = _f.state;
277
+ var button = (React.createElement(Comp, __assign({ "data-slot": "sidebar-menu-button", "data-sidebar": "menu-button", "data-size": size, "data-active": isActive, className: (0, utils_1.cn)(sidebarMenuButtonVariants({ variant: variant, size: size }), className) }, props)));
278
+ if (!tooltip) {
279
+ return button;
280
+ }
281
+ if (typeof tooltip === "string") {
282
+ tooltip = {
283
+ children: tooltip,
284
+ };
285
+ }
286
+ return (React.createElement(tooltip_1.Tooltip, null,
287
+ React.createElement(tooltip_1.TooltipTrigger, { asChild: true }, button),
288
+ React.createElement(tooltip_1.TooltipContent, __assign({ side: "right", align: "center", hidden: state !== "collapsed" || isMobile }, tooltip))));
289
+ }
290
+ function SidebarMenuAction(_a) {
291
+ var className = _a.className, _b = _a.asChild, asChild = _b === void 0 ? false : _b, _c = _a.showOnHover, showOnHover = _c === void 0 ? false : _c, props = __rest(_a, ["className", "asChild", "showOnHover"]);
292
+ var Comp = asChild ? react_slot_1.Slot : "button";
293
+ return (React.createElement(Comp, __assign({ "data-slot": "sidebar-menu-action", "data-sidebar": "menu-action", className: (0, utils_1.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",
294
+ // Increases the hit area of the button on mobile.
295
+ "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", showOnHover &&
296
+ "peer-data-[active=true]/menu-button:text-sidebar-accent-foreground group-focus-within/menu-item:opacity-100 group-hover/menu-item:opacity-100 data-[state=open]:opacity-100 md:opacity-0", className) }, props)));
297
+ }
298
+ function SidebarMenuBadge(_a) {
299
+ var className = _a.className, props = __rest(_a, ["className"]);
300
+ return (React.createElement("div", __assign({ "data-slot": "sidebar-menu-badge", "data-sidebar": "menu-badge", className: (0, utils_1.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", className) }, props)));
301
+ }
302
+ function SidebarMenuSkeleton(_a) {
303
+ var className = _a.className, _b = _a.showIcon, showIcon = _b === void 0 ? false : _b, props = __rest(_a, ["className", "showIcon"]);
304
+ // Random width between 50 to 90%.
305
+ var width = React.useMemo(function () {
306
+ return "".concat(Math.floor(Math.random() * 40) + 50, "%");
307
+ }, []);
308
+ return (React.createElement("div", __assign({ "data-slot": "sidebar-menu-skeleton", "data-sidebar": "menu-skeleton", className: (0, utils_1.cn)("flex h-8 items-center gap-2 rounded-md px-2", className) }, props),
309
+ showIcon && (React.createElement(skeleton_1.Skeleton, { className: "size-4 rounded-md", "data-sidebar": "menu-skeleton-icon" })),
310
+ React.createElement(skeleton_1.Skeleton, { className: "h-4 max-w-(--skeleton-width) flex-1", "data-sidebar": "menu-skeleton-text", style: {
311
+ "--skeleton-width": width,
312
+ } })));
313
+ }
314
+ function SidebarMenuSub(_a) {
315
+ var className = _a.className, props = __rest(_a, ["className"]);
316
+ return (React.createElement("ul", __assign({ "data-slot": "sidebar-menu-sub", "data-sidebar": "menu-sub", className: (0, utils_1.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", className) }, props)));
317
+ }
318
+ function SidebarMenuSubItem(_a) {
319
+ var className = _a.className, props = __rest(_a, ["className"]);
320
+ return (React.createElement("li", __assign({ "data-slot": "sidebar-menu-sub-item", "data-sidebar": "menu-sub-item", className: (0, utils_1.cn)("group/menu-sub-item relative", className) }, props)));
321
+ }
322
+ function SidebarMenuSubButton(_a) {
323
+ var _b = _a.asChild, asChild = _b === void 0 ? false : _b, _c = _a.size, size = _c === void 0 ? "md" : _c, _d = _a.isActive, isActive = _d === void 0 ? false : _d, className = _a.className, props = __rest(_a, ["asChild", "size", "isActive", "className"]);
324
+ var Comp = asChild ? react_slot_1.Slot : "a";
325
+ return (React.createElement(Comp, __assign({ "data-slot": "sidebar-menu-sub-button", "data-sidebar": "menu-sub-button", "data-size": size, "data-active": isActive, className: (0, utils_1.cn)("text-sidebar-foreground ring-sidebar-ring hover:bg-sidebar-accent hover:text-sidebar-accent-foreground active:bg-sidebar-accent active:text-sidebar-accent-foreground [&>svg]:text-sidebar-accent-foreground 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 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", "data-[active=true]:bg-sidebar-accent data-[active=true]:text-sidebar-accent-foreground", size === "sm" && "text-xs", size === "md" && "text-sm", "group-data-[collapsible=icon]:hidden", className) }, props)));
326
+ }
@@ -0,0 +1,3 @@
1
+ import React from "react";
2
+ declare function Skeleton({ className, ...props }: React.ComponentProps<"div">): React.JSX.Element;
3
+ export { Skeleton };
@@ -0,0 +1,34 @@
1
+ "use strict";
2
+ var __assign = (this && this.__assign) || function () {
3
+ __assign = Object.assign || function(t) {
4
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
5
+ s = arguments[i];
6
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
7
+ t[p] = s[p];
8
+ }
9
+ return t;
10
+ };
11
+ return __assign.apply(this, arguments);
12
+ };
13
+ var __rest = (this && this.__rest) || function (s, e) {
14
+ var t = {};
15
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
16
+ t[p] = s[p];
17
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
18
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
19
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
20
+ t[p[i]] = s[p[i]];
21
+ }
22
+ return t;
23
+ };
24
+ var __importDefault = (this && this.__importDefault) || function (mod) {
25
+ return (mod && mod.__esModule) ? mod : { "default": mod };
26
+ };
27
+ Object.defineProperty(exports, "__esModule", { value: true });
28
+ exports.Skeleton = Skeleton;
29
+ var react_1 = __importDefault(require("react"));
30
+ var utils_1 = require("../lib/utils");
31
+ function Skeleton(_a) {
32
+ var className = _a.className, props = __rest(_a, ["className"]);
33
+ return (react_1.default.createElement("div", __assign({ "data-slot": "skeleton", className: (0, utils_1.cn)("bg-accent animate-pulse rounded-md", className) }, props)));
34
+ }
@@ -0,0 +1,7 @@
1
+ import { FC } from "react";
2
+ import { DashboardMemberItem } from "../data/admin-dashboard";
3
+ interface TeamSwitcherProps {
4
+ members: DashboardMemberItem[];
5
+ }
6
+ export declare const TeamSwitcher: FC<TeamSwitcherProps>;
7
+ export {};
@@ -0,0 +1,47 @@
1
+ "use client";
2
+ "use strict";
3
+ var __importDefault = (this && this.__importDefault) || function (mod) {
4
+ return (mod && mod.__esModule) ? mod : { "default": mod };
5
+ };
6
+ Object.defineProperty(exports, "__esModule", { value: true });
7
+ exports.TeamSwitcher = void 0;
8
+ var react_1 = __importDefault(require("react"));
9
+ var lucide_react_1 = require("lucide-react");
10
+ var dropdown_menu_1 = require("./dropdown-menu");
11
+ var sidebar_1 = require("./sidebar");
12
+ var avatar_1 = require("./avatar");
13
+ var TeamSwitcher = function (_a) {
14
+ var members = _a.members;
15
+ var isMobile = (0, sidebar_1.useSidebar)().isMobile;
16
+ var _b = react_1.default.useState(members[0]), activeMember = _b[0], setActiveMember = _b[1];
17
+ if (!activeMember) {
18
+ return null;
19
+ }
20
+ return (react_1.default.createElement(sidebar_1.SidebarMenu, null,
21
+ react_1.default.createElement(sidebar_1.SidebarMenuItem, null,
22
+ react_1.default.createElement(dropdown_menu_1.DropdownMenu, null,
23
+ react_1.default.createElement(dropdown_menu_1.DropdownMenuTrigger, { asChild: true },
24
+ react_1.default.createElement(sidebar_1.SidebarMenuButton, { size: "lg", className: "data-[state=open]:bg-sidebar-accent data-[state=open]:text-sidebar-accent-foreground" },
25
+ react_1.default.createElement("div", { className: "bg-sidebar-primary text-sidebar-primary-foreground flex aspect-square size-8 items-center justify-center rounded-lg" },
26
+ react_1.default.createElement(avatar_1.Avatar, { className: "size-6" },
27
+ react_1.default.createElement(avatar_1.AvatarImage, { src: activeMember.avatar, alt: activeMember.name }),
28
+ react_1.default.createElement(avatar_1.AvatarFallback, null, activeMember.name.charAt(0)))),
29
+ react_1.default.createElement("div", { className: "grid flex-1 text-left text-sm leading-tight" },
30
+ react_1.default.createElement("span", { className: "truncate font-medium" }, activeMember.name),
31
+ react_1.default.createElement("span", { className: "truncate text-xs" }, activeMember.age)),
32
+ react_1.default.createElement(lucide_react_1.ChevronsUpDown, { className: "ml-auto" }))),
33
+ react_1.default.createElement(dropdown_menu_1.DropdownMenuContent, { className: "w-(--radix-dropdown-menu-trigger-width) min-w-56 rounded-lg", align: "start", side: isMobile ? "bottom" : "right", sideOffset: 4 },
34
+ react_1.default.createElement(dropdown_menu_1.DropdownMenuLabel, { className: "text-muted-foreground text-xs" }, "Members"),
35
+ members.map(function (member) { return (react_1.default.createElement(dropdown_menu_1.DropdownMenuItem, { key: member.name, onClick: function () { return setActiveMember(member); }, className: "gap-2 p-2" },
36
+ react_1.default.createElement("div", { className: "flex size-6 items-center justify-center rounded-md border" },
37
+ react_1.default.createElement(avatar_1.Avatar, { className: "size-6" },
38
+ react_1.default.createElement(avatar_1.AvatarImage, { src: member.avatar, alt: member.name }),
39
+ react_1.default.createElement(avatar_1.AvatarFallback, { className: "!focus:text-red-400" }, member.name.charAt(0)))),
40
+ member.name)); }),
41
+ react_1.default.createElement(dropdown_menu_1.DropdownMenuSeparator, null),
42
+ react_1.default.createElement(dropdown_menu_1.DropdownMenuItem, { className: "gap-2 p-2" },
43
+ react_1.default.createElement("div", { className: "flex size-6 items-center justify-center rounded-md border bg-transparent" },
44
+ react_1.default.createElement(lucide_react_1.Plus, { className: "size-4" })),
45
+ react_1.default.createElement("div", { className: "text-muted-foreground font-medium" }, "Add Member")))))));
46
+ };
47
+ exports.TeamSwitcher = TeamSwitcher;
@@ -0,0 +1,9 @@
1
+ import React from "react";
2
+ interface CustomThemeProviderProps {
3
+ children: React.ReactNode;
4
+ defaultTheme?: string;
5
+ storageKey?: string;
6
+ enableSystem?: boolean;
7
+ }
8
+ export declare function ThemeProvider({ children, defaultTheme, storageKey, enableSystem, ...props }: CustomThemeProviderProps): React.JSX.Element;
9
+ export {};