@datum-cloud/datum-ui 0.3.0-alpha.ffa8392 → 0.3.2-dev.5bd364b

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 (162) hide show
  1. package/dist/app-navigation/index.mjs +12 -0
  2. package/dist/app-navigation-CCvjPijd.mjs +416 -0
  3. package/dist/autocomplete/index.mjs +4 -4
  4. package/dist/{autocomplete-e33EmvBu.mjs → autocomplete-DcKO7pj5.mjs} +3 -3
  5. package/dist/avatar-stack/index.mjs +2 -2
  6. package/dist/{avatar-stack-Ci0cnjxv.mjs → avatar-stack-B21McFeb.mjs} +1 -1
  7. package/dist/{calendar-date-picker-BBAg78Lg.mjs → calendar-date-picker-Bw6Mrr-P.mjs} +4 -3
  8. package/dist/checkbox/index.mjs +1 -2
  9. package/dist/checkbox-LG1OKTpG.mjs +34 -0
  10. package/dist/collapsible/index.mjs +1 -1
  11. package/dist/command/index.mjs +2 -2
  12. package/dist/{command-DQlO6uTL.mjs → command-s0Yv3abE.mjs} +1 -1
  13. package/dist/components/base/index.d.ts +1 -0
  14. package/dist/components/base/index.d.ts.map +1 -1
  15. package/dist/components/base/sidebar/index.d.ts +2 -0
  16. package/dist/components/base/sidebar/index.d.ts.map +1 -0
  17. package/dist/components/{features → base}/sidebar/sidebar.d.ts +1 -1
  18. package/dist/components/base/sidebar/sidebar.d.ts.map +1 -0
  19. package/dist/components/base/skeleton/index.d.ts +1 -1
  20. package/dist/components/base/skeleton/index.d.ts.map +1 -1
  21. package/dist/components/base/skeleton/skeleton.d.ts +22 -0
  22. package/dist/components/base/skeleton/skeleton.d.ts.map +1 -0
  23. package/dist/components/base/typography/typography.d.ts +2 -2
  24. package/dist/components/features/app-navigation/app-navigation.d.ts +14 -0
  25. package/dist/components/features/app-navigation/app-navigation.d.ts.map +1 -0
  26. package/dist/components/features/app-navigation/index.d.ts +4 -0
  27. package/dist/components/features/app-navigation/index.d.ts.map +1 -0
  28. package/dist/components/features/{sidebar/nav-main.d.ts → app-navigation/nav-menu.d.ts} +3 -3
  29. package/dist/components/features/app-navigation/nav-menu.d.ts.map +1 -0
  30. package/dist/components/features/calendar-date-picker/calendar-date-picker.d.ts +2 -1
  31. package/dist/components/features/calendar-date-picker/calendar-date-picker.d.ts.map +1 -1
  32. package/dist/components/features/data-table/components/active-filters.d.ts +5 -0
  33. package/dist/components/features/data-table/components/active-filters.d.ts.map +1 -0
  34. package/dist/components/features/data-table/components/column-header.d.ts.map +1 -1
  35. package/dist/components/features/data-table/components/content.d.ts.map +1 -1
  36. package/dist/components/features/data-table/components/loading.d.ts.map +1 -1
  37. package/dist/components/features/data-table/components/pagination.d.ts.map +1 -1
  38. package/dist/components/features/data-table/components/search.d.ts +1 -1
  39. package/dist/components/features/data-table/components/search.d.ts.map +1 -1
  40. package/dist/components/features/data-table/core/client-provider.d.ts +5 -7
  41. package/dist/components/features/data-table/core/client-provider.d.ts.map +1 -1
  42. package/dist/components/features/data-table/core/data-table-context.d.ts +23 -0
  43. package/dist/components/features/data-table/core/data-table-context.d.ts.map +1 -1
  44. package/dist/components/features/data-table/core/filter-engine.d.ts +5 -0
  45. package/dist/components/features/data-table/core/filter-engine.d.ts.map +1 -1
  46. package/dist/components/features/data-table/core/server-provider.d.ts +4 -7
  47. package/dist/components/features/data-table/core/server-provider.d.ts.map +1 -1
  48. package/dist/components/features/data-table/core/store.d.ts.map +1 -1
  49. package/dist/components/features/data-table/data-table.d.ts +1 -0
  50. package/dist/components/features/data-table/data-table.d.ts.map +1 -1
  51. package/dist/components/features/data-table/filters/checkbox-filter.d.ts +1 -1
  52. package/dist/components/features/data-table/filters/checkbox-filter.d.ts.map +1 -1
  53. package/dist/components/features/data-table/filters/date-picker-filter.d.ts +1 -1
  54. package/dist/components/features/data-table/filters/date-picker-filter.d.ts.map +1 -1
  55. package/dist/components/features/data-table/filters/select-filter.d.ts +1 -1
  56. package/dist/components/features/data-table/filters/select-filter.d.ts.map +1 -1
  57. package/dist/components/features/data-table/hooks/index.d.ts +1 -1
  58. package/dist/components/features/data-table/hooks/index.d.ts.map +1 -1
  59. package/dist/components/features/data-table/hooks/use-data-table-client.d.ts +11 -10
  60. package/dist/components/features/data-table/hooks/use-data-table-client.d.ts.map +1 -1
  61. package/dist/components/features/data-table/hooks/use-data-table-server.d.ts +12 -17
  62. package/dist/components/features/data-table/hooks/use-data-table-server.d.ts.map +1 -1
  63. package/dist/components/features/data-table/hooks/use-selectors.d.ts +4 -33
  64. package/dist/components/features/data-table/hooks/use-selectors.d.ts.map +1 -1
  65. package/dist/components/features/data-table/index.d.ts +2 -4
  66. package/dist/components/features/data-table/index.d.ts.map +1 -1
  67. package/dist/components/features/data-table/types.d.ts +45 -31
  68. package/dist/components/features/data-table/types.d.ts.map +1 -1
  69. package/dist/components/features/index.d.ts +1 -1
  70. package/dist/components/features/index.d.ts.map +1 -1
  71. package/dist/data-table/index.mjs +659 -414
  72. package/dist/date-picker/index.mjs +5 -5
  73. package/dist/dialog/index.mjs +2 -2
  74. package/dist/{dialog-B2EZJW-q.mjs → dialog-bnMMf9GD.mjs} +2 -2
  75. package/dist/dropdown/index.mjs +1 -1
  76. package/dist/dropzone/index.mjs +1 -1
  77. package/dist/empty-content/index.mjs +1 -1
  78. package/dist/form/index.mjs +12 -12
  79. package/dist/grid/index.mjs +1 -1
  80. package/dist/hooks/index.mjs +1 -1
  81. package/dist/hover-card/index.mjs +1 -1
  82. package/dist/icons/index.mjs +1 -1
  83. package/dist/index.mjs +49 -49
  84. package/dist/input/index.mjs +2 -2
  85. package/dist/{input-D241oNEm.mjs → input-fzXBheCN.mjs} +1 -1
  86. package/dist/input-group/index.mjs +3 -3
  87. package/dist/{input-group-uobp64zr.mjs → input-group-CPaFSTEV.mjs} +2 -2
  88. package/dist/input-number/index.mjs +2 -2
  89. package/dist/{input-number-CEMgBk8-.mjs → input-number-D1HCcTXO.mjs} +1 -1
  90. package/dist/input-with-addons/index.mjs +1 -1
  91. package/dist/label/index.mjs +1 -2
  92. package/dist/{label-byipFGok.mjs → label-_ste_Re3.mjs} +12 -1
  93. package/dist/loader-overlay/index.mjs +1 -1
  94. package/dist/map/index.mjs +8 -8
  95. package/dist/{map-DupFPkJT.mjs → map-2RG9pYZR.mjs} +4 -4
  96. package/dist/more-actions/index.mjs +2 -2
  97. package/dist/{more-actions-D6OyqZQS.mjs → more-actions-BODYgG1C.mjs} +2 -2
  98. package/dist/page-title/index.mjs +1 -1
  99. package/dist/popover/index.mjs +1 -1
  100. package/dist/radio-group/index.mjs +1 -1
  101. package/dist/select/index.mjs +1 -1
  102. package/dist/{select-BznmyqBr.mjs → select-CwVIFWFO.mjs} +1 -1
  103. package/dist/sheet/index.mjs +2 -2
  104. package/dist/{sheet-Bmayi68h.mjs → sheet-mx5XjyEY.mjs} +2 -2
  105. package/dist/sidebar/index.mjs +6 -7
  106. package/dist/{sidebar-D2zE7rPy.mjs → sidebar-BW76ss_f.mjs} +8 -417
  107. package/dist/skeleton/index.mjs +2 -1
  108. package/dist/skeleton-DZ31pU4B.mjs +28 -0
  109. package/dist/spinner/index.mjs +1 -1
  110. package/dist/stepper/index.mjs +1 -1
  111. package/dist/styles/root.css +3 -0
  112. package/dist/switch/index.mjs +1 -1
  113. package/dist/table/index.mjs +1 -1
  114. package/dist/tabs/index.mjs +1 -1
  115. package/dist/tag-input/index.mjs +2 -2
  116. package/dist/{tag-input-BI8IRBDH.mjs → tag-input-DorFQ9bA.mjs} +1 -1
  117. package/dist/task-queue/index.mjs +4 -4
  118. package/dist/{task-queue-dropdown-D6k067_W.mjs → task-queue-dropdown-DtS0IKci.mjs} +4 -4
  119. package/dist/textarea/index.mjs +2 -2
  120. package/dist/{textarea-BZ85VFsJ.mjs → textarea-KZUKGHlO.mjs} +1 -1
  121. package/dist/{to-api-format-CXQ7knV4.mjs → to-api-format-CzPt5UAX.mjs} +3 -3
  122. package/dist/toast/index.mjs +1 -1
  123. package/dist/tooltip/index.mjs +1 -1
  124. package/dist/{use-copy-to-clipboard-CC2hhyYI.mjs → use-copy-to-clipboard-C9cT2Qb-.mjs} +1 -1
  125. package/dist/{use-stepper-CU75TdjZ.mjs → use-stepper-DJd8o9dV.mjs} +14 -14
  126. package/dist/{use-toast-BLBGnOC3.mjs → use-toast-DBmysDS6.mjs} +1 -1
  127. package/package.json +85 -79
  128. package/dist/checkbox-DB5_3E_l.mjs +0 -22
  129. package/dist/checkbox-DMC1Mhaw.mjs +0 -17
  130. package/dist/components/features/data-table/hooks/use-data-table-context.d.ts +0 -2
  131. package/dist/components/features/data-table/hooks/use-data-table-context.d.ts.map +0 -1
  132. package/dist/components/features/sidebar/app-sidebar.d.ts +0 -14
  133. package/dist/components/features/sidebar/app-sidebar.d.ts.map +0 -1
  134. package/dist/components/features/sidebar/index.d.ts +0 -4
  135. package/dist/components/features/sidebar/index.d.ts.map +0 -1
  136. package/dist/components/features/sidebar/nav-main.d.ts.map +0 -1
  137. package/dist/components/features/sidebar/sidebar.d.ts.map +0 -1
  138. package/dist/label-ClzLBWRT.mjs +0 -16
  139. /package/dist/{close.icon-D2r5q3bj.mjs → close.icon-CMNMoXM_.mjs} +0 -0
  140. /package/dist/{col-Cg_2sTDA.mjs → col-DCneNxQj.mjs} +0 -0
  141. /package/dist/{collapsible-Dw71o2um.mjs → collapsible-Bt9UYfv3.mjs} +0 -0
  142. /package/dist/{dialog-Bm4trnic.mjs → dialog-DXBaT9gA.mjs} +0 -0
  143. /package/dist/{dropdown-DLZXinlT.mjs → dropdown-Dgm_b6Mm.mjs} +0 -0
  144. /package/dist/{dropdown-menu-Xahj42Gr.mjs → dropdown-menu-DAFyO-qD.mjs} +0 -0
  145. /package/dist/{dropzone-CGyjGnER.mjs → dropzone-DR6O9OdU.mjs} +0 -0
  146. /package/dist/{empty-content-ByvwjHUs.mjs → empty-content-Dm7_5jO9.mjs} +0 -0
  147. /package/dist/{hover-card-BNrHtWy6.mjs → hover-card-CUPfFUqE.mjs} +0 -0
  148. /package/dist/{input-C-ZmsHkk.mjs → input-DuyjEKEW.mjs} +0 -0
  149. /package/dist/{input-with-addons-DzuyGa6G.mjs → input-with-addons-DN9LGwUU.mjs} +0 -0
  150. /package/dist/{loader-overlay-CbxcjyHV.mjs → loader-overlay-CpA0zV8D.mjs} +0 -0
  151. /package/dist/{page-title-CrYQ091u.mjs → page-title-D62FV6vD.mjs} +0 -0
  152. /package/dist/{popover-CYzXdp9q.mjs → popover-Ds9624qY.mjs} +0 -0
  153. /package/dist/{radio-group-WZCIDQCH.mjs → radio-group-B9Hm77LQ.mjs} +0 -0
  154. /package/dist/{sheet-b9V9soz8.mjs → sheet-Cemwh78x.mjs} +0 -0
  155. /package/dist/{skeleton-D3qW_KvG.mjs → skeleton-CkE23wsL.mjs} +0 -0
  156. /package/dist/{spinner-CKTGKv5n.mjs → spinner-earfjpJs.mjs} +0 -0
  157. /package/dist/{stepper-B07hPGG7.mjs → stepper-CZeks9Ex.mjs} +0 -0
  158. /package/dist/{switch-CujyyOi6.mjs → switch-Cn9IM2gC.mjs} +0 -0
  159. /package/dist/{table-fZEvpdD-.mjs → table-Dpzh0VPK.mjs} +0 -0
  160. /package/dist/{tabs-B7cW59gB.mjs → tabs-OYVCDOif.mjs} +0 -0
  161. /package/dist/{textarea-BSkDKiej.mjs → textarea-QYRcDEpK.mjs} +0 -0
  162. /package/dist/{tooltip-CbCWKEzu.mjs → tooltip-U3XxlW4l.mjs} +0 -0
@@ -0,0 +1,12 @@
1
+ import "../utils-Bfgoe-Gm.mjs";
2
+ import "../separator-T2ppyD-8.mjs";
3
+ import "../button-AzpnV-WB.mjs";
4
+ import "../collapsible-Bt9UYfv3.mjs";
5
+ import "../input-DuyjEKEW.mjs";
6
+ import "../sheet-Cemwh78x.mjs";
7
+ import { C as SidebarTrigger, S as SidebarSeparator, _ as SidebarMenuSub, a as SidebarGroupAction, b as SidebarProvider, c as SidebarHeader, d as SidebarMenu, f as SidebarMenuAction, g as SidebarMenuSkeleton, h as SidebarMenuItem, i as SidebarGroup, l as SidebarInput, m as SidebarMenuButton, n as SidebarContent, o as SidebarGroupContent, p as SidebarMenuBadge, r as SidebarFooter, s as SidebarGroupLabel, t as Sidebar, u as SidebarInset, v as SidebarMenuSubButton, w as useSidebar, x as SidebarRail, y as SidebarMenuSubItem } from "../sidebar-BW76ss_f.mjs";
8
+ import "../skeleton-CkE23wsL.mjs";
9
+ import "../tooltip-U3XxlW4l.mjs";
10
+ import { n as NavMenu, t as AppNavigation } from "../app-navigation-CCvjPijd.mjs";
11
+
12
+ export { AppNavigation, NavMenu, 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,416 @@
1
+ import { t as cn } from "./cn-DWCc1QRE.mjs";
2
+ import { t as Icon } from "./icon-wrapper-9ticVbRL.mjs";
3
+ import { n as CollapsibleContent, r as CollapsibleTrigger, t as Collapsible } from "./collapsible-Bt9UYfv3.mjs";
4
+ import { C as SidebarTrigger, S as SidebarSeparator, _ as SidebarMenuSub, c as SidebarHeader, d as SidebarMenu, h as SidebarMenuItem, i as SidebarGroup, m as SidebarMenuButton, n as SidebarContent, o as SidebarGroupContent, r as SidebarFooter, s as SidebarGroupLabel, t as Sidebar, w as useSidebar } from "./sidebar-BW76ss_f.mjs";
5
+ import { ChevronRight, ExternalLinkIcon } from "lucide-react";
6
+ import { Fragment, useCallback, useEffect, useRef, useState } from "react";
7
+ import { Fragment as Fragment$1, jsx, jsxs } from "react/jsx-runtime";
8
+ import { motion } from "motion/react";
9
+
10
+ //#region src/components/features/app-navigation/nav-menu.tsx
11
+ const NAV_STYLES = {
12
+ menuButton: "rounded-xl h-8 font-normal text-xs transition-all px-2 py-1 data-[active=true]:bg-sidebar data-[active=true]:text-foreground data-[active=true]:text-sidebar-primary data-[active=true]:[&>svg]:text-primary hover:bg-sidebar hover:text-sidebar-primary hover:[&>svg]:text-sidebar-primary hover:bg-sidebar-accent data-[active=true]:bg-sidebar-accent hover:font-semibold data-[active=true]:hover:[&>svg]:text-sidebar-primary transition-colors duration-300 gap-2.5 text-foreground [&>svg]:text-icon-primary",
13
+ disabled: "pointer-events-none opacity-50",
14
+ icon: "duration-300 transition-all",
15
+ iconSmall: "size-4 duration-300 transition-all"
16
+ };
17
+ function NavIcon({ icon: IconComponent, className, size = "default" }) {
18
+ if (!IconComponent) return null;
19
+ return /* @__PURE__ */ jsx(Icon, {
20
+ icon: IconComponent,
21
+ className: cn(size === "small" ? NAV_STYLES.iconSmall : NAV_STYLES.icon, className)
22
+ });
23
+ }
24
+ NavIcon.displayName = "NavIcon";
25
+ function NavSidebarMenuButton({ ref, item, isActive, disableTooltip, className, children, asChild, ...props }) {
26
+ return /* @__PURE__ */ jsx(SidebarMenuButton, {
27
+ ref,
28
+ tooltip: disableTooltip ? void 0 : item.title,
29
+ isActive,
30
+ disabled: item.disabled,
31
+ asChild,
32
+ className: cn(NAV_STYLES.menuButton, item.disabled && NAV_STYLES.disabled, className),
33
+ ...props,
34
+ children: asChild ? children : /* @__PURE__ */ jsxs(Fragment$1, { children: [/* @__PURE__ */ jsx(NavIcon, { icon: item.icon }), children] })
35
+ });
36
+ }
37
+ NavSidebarMenuButton.displayName = "NavSidebarMenuButton";
38
+ function NavMenu({ ref, className, items, currentPath, linkComponent: LinkComp = "a", overrideState, itemClassName, disableTooltip, closeOnNavigation, ...props }) {
39
+ const pathname = currentPath;
40
+ const { state: sidebarState, isMobile, closeForNavigation, setOpen } = useSidebar();
41
+ const [openItems, setOpenItems] = useState({});
42
+ const isInitialMount = useRef(true);
43
+ const previousOpenItems = useRef({});
44
+ const previousPathname = useRef(pathname);
45
+ const state = overrideState ?? sidebarState;
46
+ const previousState = useRef(state);
47
+ useEffect(() => {
48
+ previousOpenItems.current = openItems;
49
+ if (isInitialMount.current) isInitialMount.current = false;
50
+ }, [openItems]);
51
+ useEffect(() => {
52
+ previousPathname.current = pathname;
53
+ }, [pathname]);
54
+ const activeNavItem = useCallback((item) => {
55
+ const normalize = (p) => {
56
+ let result = p.startsWith("/") ? p : `/${p}`;
57
+ if (result !== "/" && result.endsWith("/")) result = result.slice(0, -1);
58
+ return result;
59
+ };
60
+ const cleanCurrentPath = normalize(pathname);
61
+ if (!item.href) return false;
62
+ const cleanNavPath = normalize(item.href);
63
+ if (cleanNavPath === "/") return cleanCurrentPath === "/";
64
+ const hasActiveDescendant = (navItem) => {
65
+ if (!navItem.children || navItem.children.length === 0) return false;
66
+ return navItem.children.some((child) => {
67
+ if (!child.href) return hasActiveDescendant(child);
68
+ const cleanChildPath = normalize(child.href);
69
+ if (cleanCurrentPath === cleanChildPath || cleanCurrentPath.startsWith(`${cleanChildPath}/`)) return true;
70
+ return hasActiveDescendant(child);
71
+ });
72
+ };
73
+ if ((item.children || []).length > 0) {
74
+ if (hasActiveDescendant(item)) return false;
75
+ return cleanCurrentPath === cleanNavPath;
76
+ }
77
+ const isExcluded = item.excludePaths?.some((excludePath) => {
78
+ const cleanExcludePath = normalize(excludePath);
79
+ return cleanCurrentPath === cleanExcludePath || cleanCurrentPath.startsWith(`${cleanExcludePath}/`);
80
+ }) ?? false;
81
+ const isDirectMatch = cleanCurrentPath === cleanNavPath || !isExcluded && cleanCurrentPath.startsWith(`${cleanNavPath}/`);
82
+ const isTabChildMatch = item.tabChildLinks?.some((childPath) => {
83
+ const cleanChildPath = normalize(childPath);
84
+ return cleanCurrentPath === cleanChildPath || cleanCurrentPath.startsWith(`${cleanChildPath}/`);
85
+ }) ?? false;
86
+ return isDirectMatch || isTabChildMatch;
87
+ }, [pathname]);
88
+ const hasActiveDescendant = useCallback((item) => {
89
+ if (activeNavItem(item)) return true;
90
+ if (item.children) return item.children.some((child) => hasActiveDescendant(child));
91
+ return false;
92
+ }, [activeNavItem]);
93
+ const findItemByHref = useCallback((href, items) => {
94
+ for (const item of items) {
95
+ if (item.href === href) return item;
96
+ if (item.children) {
97
+ const found = findItemByHref(href, item.children);
98
+ if (found) return found;
99
+ }
100
+ }
101
+ return null;
102
+ }, []);
103
+ useEffect(() => {
104
+ if (previousState.current === "expanded" && state === "collapsed") setOpenItems((prev) => {
105
+ const newOpenItems = {};
106
+ Object.keys(prev).forEach((itemHref) => {
107
+ const item = findItemByHref(itemHref, items);
108
+ if (item && hasActiveDescendant(item)) newOpenItems[itemHref] = true;
109
+ });
110
+ return newOpenItems;
111
+ });
112
+ previousState.current = state;
113
+ }, [
114
+ state,
115
+ items,
116
+ hasActiveDescendant,
117
+ findItemByHref
118
+ ]);
119
+ const toggleItem = (itemId) => {
120
+ setOpenItems((prev) => ({
121
+ ...prev,
122
+ [itemId]: !prev[itemId]
123
+ }));
124
+ };
125
+ const handleNavigation = useCallback(() => {
126
+ if (closeOnNavigation && !isMobile) closeForNavigation();
127
+ }, [
128
+ closeOnNavigation,
129
+ isMobile,
130
+ closeForNavigation
131
+ ]);
132
+ const renderNavItem = (item, level = 0) => {
133
+ if ("hidden" in item && item.hidden) return null;
134
+ const itemKey = `${item.title}-${item.href || ""}-${level}`;
135
+ if ("type" in item && item.type === "group") return /* @__PURE__ */ jsxs(Fragment, { children: [/* @__PURE__ */ jsxs(SidebarGroup, {
136
+ className: "mb-2 p-0! px-2",
137
+ children: [item.title && /* @__PURE__ */ jsx(SidebarGroupLabel, {
138
+ className: "lowercase group-data-[state=collapsed]:hidden first-letter:uppercase",
139
+ children: item.title
140
+ }), /* @__PURE__ */ jsx(SidebarGroupContent, {
141
+ className: "flex flex-col gap-1",
142
+ children: (item.children || []).map((child) => renderNavItem(child, level + 1))
143
+ })]
144
+ }), /* @__PURE__ */ jsx(SidebarSeparator, { className: "my-2 hidden group-data-[state=collapsed]:block" })] }, itemKey);
145
+ const isActive = activeNavItem(item);
146
+ const pathnameExistInDropdowns = item.children?.filter((dropdownItem) => pathname.includes(dropdownItem.href)) || [];
147
+ const hasChildren = (item.children || []).length > 0;
148
+ const isOpen = openItems[item.href] !== void 0 ? openItems[item.href] : Boolean(pathnameExistInDropdowns.length);
149
+ const hasActiveChild = pathnameExistInDropdowns.length > 0;
150
+ if (state === "collapsed" && !isMobile && level <= 2 && hasChildren) return /* @__PURE__ */ jsxs(Fragment, { children: [
151
+ item.showSeparatorAbove && /* @__PURE__ */ jsx(SidebarSeparator, { className: "my-1" }),
152
+ /* @__PURE__ */ jsx(SidebarMenu, { children: /* @__PURE__ */ jsxs("div", {
153
+ className: "flex flex-col px-2",
154
+ children: [/* @__PURE__ */ jsx(NavSidebarMenuButton, {
155
+ item,
156
+ isActive,
157
+ disableTooltip,
158
+ className: itemClassName,
159
+ onClick: () => {
160
+ setOpen(true);
161
+ if (item.href) setOpenItems((prev) => ({
162
+ ...prev,
163
+ [item.href]: true
164
+ }));
165
+ }
166
+ }), hasActiveChild && /* @__PURE__ */ jsx(motion.div, {
167
+ variants: {
168
+ hidden: { opacity: 0 },
169
+ visible: {
170
+ opacity: 1,
171
+ transition: {
172
+ staggerChildren: .05,
173
+ delayChildren: .1
174
+ }
175
+ }
176
+ },
177
+ initial: "hidden",
178
+ animate: "visible",
179
+ className: "flex flex-col gap-0.5",
180
+ children: item.children?.map((subItem) => {
181
+ const isSubItemActive = activeNavItem(subItem);
182
+ return /* @__PURE__ */ jsx(motion.div, {
183
+ variants: {
184
+ hidden: { opacity: 0 },
185
+ visible: {
186
+ opacity: 1,
187
+ transition: {
188
+ duration: .2,
189
+ ease: "easeOut"
190
+ }
191
+ }
192
+ },
193
+ children: /* @__PURE__ */ jsx(SidebarMenuButton, {
194
+ tooltip: subItem.title,
195
+ isActive: isSubItemActive,
196
+ className: "h-6 p-0 group-data-[collapsible=icon]:h-6! group-data-[collapsible=icon]:p-0!",
197
+ asChild: true,
198
+ children: /* @__PURE__ */ jsx(LinkComp, {
199
+ className: "flex items-center justify-center",
200
+ ...LinkComp === "a" ? { href: subItem.href || "" } : { to: subItem.href || "" },
201
+ onClick: () => {
202
+ handleNavigation();
203
+ },
204
+ children: /* @__PURE__ */ jsx("span", { className: cn("size-1 rounded-full", isSubItemActive ? "bg-primary" : "bg-sidebar-primary-foreground") })
205
+ })
206
+ })
207
+ }, `collapsed-dot-${subItem.href}-${level}`);
208
+ })
209
+ })]
210
+ }) }),
211
+ item.showSeparatorBelow && /* @__PURE__ */ jsx(SidebarSeparator, { className: "my-2" })
212
+ ] }, itemKey);
213
+ if (hasChildren && level <= 3) return /* @__PURE__ */ jsxs(Fragment, { children: [
214
+ item.showSeparatorAbove && /* @__PURE__ */ jsx(SidebarSeparator, { className: "my-2" }),
215
+ /* @__PURE__ */ jsx(SidebarMenu, {
216
+ className: "px-2",
217
+ children: /* @__PURE__ */ jsx(Collapsible, {
218
+ asChild: true,
219
+ open: isOpen,
220
+ onOpenChange: (open) => {
221
+ if (item.href) setOpenItems((prev) => ({
222
+ ...prev,
223
+ [item.href]: open
224
+ }));
225
+ },
226
+ className: "group/collapsible",
227
+ children: /* @__PURE__ */ jsxs(SidebarMenuItem, { children: [/* @__PURE__ */ jsx(CollapsibleTrigger, {
228
+ asChild: true,
229
+ className: "w-full",
230
+ children: /* @__PURE__ */ jsxs(NavSidebarMenuButton, {
231
+ item,
232
+ isActive,
233
+ disableTooltip,
234
+ className: itemClassName,
235
+ children: [/* @__PURE__ */ jsx("span", { children: item.title }), /* @__PURE__ */ jsx(Icon, {
236
+ icon: ChevronRight,
237
+ className: "ml-auto transition-transform duration-200 group-data-[state=open]/collapsible:rotate-90"
238
+ })]
239
+ })
240
+ }), /* @__PURE__ */ jsx(CollapsibleContent, {
241
+ className: "data-[state=open]:animate-collapsible-down data-[state=closed]:animate-collapsible-up overflow-hidden",
242
+ children: /* @__PURE__ */ jsx("div", {
243
+ style: {
244
+ minHeight: 0,
245
+ overflow: "hidden"
246
+ },
247
+ children: /* @__PURE__ */ jsx(motion.div, {
248
+ variants: {
249
+ hidden: { opacity: 0 },
250
+ visible: {
251
+ opacity: 1,
252
+ transition: {
253
+ staggerChildren: .05,
254
+ delayChildren: .1
255
+ }
256
+ }
257
+ },
258
+ initial: isInitialMount.current || previousOpenItems.current[item.href] === openItems[item.href] && previousState.current === state && previousPathname.current === pathname && !hasActiveChild ? "visible" : "hidden",
259
+ animate: isOpen ? "visible" : "hidden",
260
+ children: /* @__PURE__ */ jsx(SidebarMenuSub, {
261
+ className: cn(level >= 1 ? "mr-0 pr-[.1rem]" : "", level === 2 ? "pl-4" : "", level === 3 ? "pl-6" : "", "mr-0 gap-0.5 pr-0"),
262
+ children: item.children?.map((subItem, index) => /* @__PURE__ */ jsx(motion.div, {
263
+ variants: {
264
+ hidden: { opacity: 0 },
265
+ visible: {
266
+ opacity: 1,
267
+ transition: {
268
+ duration: .2,
269
+ ease: "easeOut"
270
+ }
271
+ }
272
+ },
273
+ children: renderNavItem(subItem, level + 1)
274
+ }, `${subItem.href}-${level}-${index}`))
275
+ })
276
+ }, `collapsible-${item.href}-${isOpen}`)
277
+ })
278
+ })] })
279
+ }, `collapsed-item-drop-down-item-${item.title}-${level}`)
280
+ }),
281
+ item.showSeparatorBelow && /* @__PURE__ */ jsx(SidebarSeparator, { className: "my-2" })
282
+ ] }, itemKey);
283
+ const renderCollapsible = (currentItem, currentLevel) => {
284
+ const currentItemIsActive = activeNavItem(currentItem);
285
+ const currentItemPathnameExistInDropdowns = currentItem.children?.filter((dropdownItem) => pathname.includes(dropdownItem.href)) || [];
286
+ return /* @__PURE__ */ jsx(Collapsible, {
287
+ asChild: true,
288
+ open: openItems[currentItem.href] || Boolean(currentItemPathnameExistInDropdowns.length),
289
+ onOpenChange: (open) => {
290
+ if (currentItem.href) setOpenItems((prev) => ({
291
+ ...prev,
292
+ [currentItem.href]: open
293
+ }));
294
+ },
295
+ className: "group/collapsible",
296
+ children: /* @__PURE__ */ jsxs(SidebarMenuItem, { children: [/* @__PURE__ */ jsx(CollapsibleTrigger, {
297
+ asChild: true,
298
+ className: "w-full",
299
+ children: /* @__PURE__ */ jsxs(NavSidebarMenuButton, {
300
+ item: currentItem,
301
+ isActive: currentItemIsActive,
302
+ disableTooltip,
303
+ className: itemClassName,
304
+ children: [/* @__PURE__ */ jsx("span", { children: currentItem.title }), /* @__PURE__ */ jsx(Icon, {
305
+ icon: ChevronRight,
306
+ className: "ml-auto transition-transform duration-200 group-data-[state=open]/collapsible:rotate-90"
307
+ })]
308
+ })
309
+ }), /* @__PURE__ */ jsx(CollapsibleContent, {
310
+ className: "data-[state=open]:animate-collapsible-down data-[state=closed]:animate-collapsible-up overflow-hidden",
311
+ children: /* @__PURE__ */ jsx("div", {
312
+ style: {
313
+ minHeight: 0,
314
+ overflow: "hidden"
315
+ },
316
+ children: /* @__PURE__ */ jsx(SidebarMenuSub, {
317
+ className: cn(currentLevel >= 1 ? "mr-0 pr-[.1rem]" : "", "gap-0.5"),
318
+ children: currentItem.children?.map((subItem) => renderNavItem(subItem, currentLevel + 1))
319
+ })
320
+ })
321
+ })] }, `collapsible-sidebar-${currentItem.title}-${currentLevel}`)
322
+ }, `collapsed-item-drop-down-item-${currentItem.title}-${currentLevel}`);
323
+ };
324
+ if (level <= 2 && hasChildren) return /* @__PURE__ */ jsxs(Fragment, { children: [
325
+ item.showSeparatorAbove && /* @__PURE__ */ jsx(SidebarSeparator, { className: "my-2" }),
326
+ /* @__PURE__ */ jsx(SidebarMenu, {
327
+ className: "px-2",
328
+ children: renderCollapsible(item, level)
329
+ }),
330
+ item.showSeparatorBelow && /* @__PURE__ */ jsx(SidebarSeparator, { className: "my-2" })
331
+ ] }, itemKey);
332
+ return /* @__PURE__ */ jsxs(Fragment, { children: [
333
+ item.showSeparatorAbove && /* @__PURE__ */ jsx(SidebarSeparator, { className: "my-2" }),
334
+ /* @__PURE__ */ jsx(SidebarMenu, {
335
+ className: cn(`level_${level} px-2`),
336
+ children: /* @__PURE__ */ jsx(SidebarMenuItem, { children: /* @__PURE__ */ jsx(NavSidebarMenuButton, {
337
+ asChild: true,
338
+ item,
339
+ isActive: isActive && !hasActiveChild,
340
+ disableTooltip,
341
+ onClick: () => hasChildren && toggleItem(item.href),
342
+ className: cn(level >= 1 && "h-6", itemClassName),
343
+ children: item.type === "externalLink" ? /* @__PURE__ */ jsxs("a", {
344
+ href: item.href || "",
345
+ target: "_blank",
346
+ rel: "noopener noreferrer",
347
+ className: "flex items-center justify-between",
348
+ children: [/* @__PURE__ */ jsxs("div", {
349
+ className: "flex items-center gap-2",
350
+ children: [item?.icon && /* @__PURE__ */ jsx(Icon, {
351
+ icon: item.icon,
352
+ className: "size-4 transition-all duration-300"
353
+ }), /* @__PURE__ */ jsx("span", { children: item.title })]
354
+ }), /* @__PURE__ */ jsx(Icon, {
355
+ icon: ExternalLinkIcon,
356
+ className: "ml-auto size-4"
357
+ })]
358
+ }) : /* @__PURE__ */ jsxs(LinkComp, {
359
+ ...LinkComp === "a" ? { href: item.href || "" } : { to: item.href || "" },
360
+ onClick: handleNavigation,
361
+ onMouseEnter: () => item.onPrefetch?.(),
362
+ children: [item?.icon && /* @__PURE__ */ jsx(Icon, {
363
+ icon: item.icon,
364
+ className: "text-sidebar-primary transition-all duration-300"
365
+ }), /* @__PURE__ */ jsx("span", { children: item.title })]
366
+ })
367
+ }) })
368
+ }),
369
+ item.showSeparatorBelow && /* @__PURE__ */ jsx(SidebarSeparator, { className: "my-2" })
370
+ ] }, itemKey);
371
+ };
372
+ return /* @__PURE__ */ jsx("ul", {
373
+ ref,
374
+ "data-sidebar": "menu",
375
+ className: cn("flex h-full w-full min-w-0 flex-col gap-0.5 py-2", className),
376
+ ...props,
377
+ children: (items || []).map((item) => renderNavItem(item))
378
+ });
379
+ }
380
+ NavMenu.displayName = "NavMenu";
381
+
382
+ //#endregion
383
+ //#region src/components/features/app-navigation/app-navigation.tsx
384
+ function AppNavigation({ navItems, title, closeOnNavigation, defaultOpen, currentPath, linkComponent, ...props }) {
385
+ const { setOpen } = useSidebar();
386
+ useEffect(() => {
387
+ if (defaultOpen === false) setOpen(false);
388
+ }, [defaultOpen, setOpen]);
389
+ return /* @__PURE__ */ jsx(Sidebar, {
390
+ collapsible: props.collapsible ?? "offcanvas",
391
+ ...props,
392
+ children: /* @__PURE__ */ jsxs(SidebarContent, {
393
+ className: "gap-0",
394
+ children: [
395
+ title && /* @__PURE__ */ jsx(SidebarHeader, {
396
+ className: "px-4 pt-4 pb-0",
397
+ children: title
398
+ }),
399
+ navItems.length > 0 && /* @__PURE__ */ jsx(NavMenu, {
400
+ className: "h-fit py-2",
401
+ items: navItems,
402
+ currentPath,
403
+ linkComponent,
404
+ closeOnNavigation
405
+ }),
406
+ props.collapsible !== "none" && /* @__PURE__ */ jsx(SidebarFooter, {
407
+ className: "mt-auto p-2",
408
+ children: /* @__PURE__ */ jsx(SidebarTrigger, {})
409
+ })
410
+ ]
411
+ })
412
+ });
413
+ }
414
+
415
+ //#endregion
416
+ export { NavMenu as n, AppNavigation as t };
@@ -1,7 +1,7 @@
1
1
  import "../utils-Bfgoe-Gm.mjs";
2
- import "../dialog-Bm4trnic.mjs";
3
- import "../command-DQlO6uTL.mjs";
4
- import "../popover-CYzXdp9q.mjs";
5
- import { t as Autocomplete } from "../autocomplete-e33EmvBu.mjs";
2
+ import "../dialog-DXBaT9gA.mjs";
3
+ import "../command-s0Yv3abE.mjs";
4
+ import "../popover-Ds9624qY.mjs";
5
+ import { t as Autocomplete } from "../autocomplete-DcKO7pj5.mjs";
6
6
 
7
7
  export { Autocomplete };
@@ -1,7 +1,7 @@
1
1
  import { t as cn } from "./cn-DWCc1QRE.mjs";
2
- import { a as CommandInput, i as CommandGroup, o as CommandItem, r as CommandEmpty, s as CommandList, t as Command } from "./command-DQlO6uTL.mjs";
3
- import { i as PopoverTrigger, r as PopoverContent, t as Popover } from "./popover-CYzXdp9q.mjs";
4
- import { t as LoaderOverlay } from "./loader-overlay-CbxcjyHV.mjs";
2
+ import { a as CommandInput, i as CommandGroup, o as CommandItem, r as CommandEmpty, s as CommandList, t as Command } from "./command-s0Yv3abE.mjs";
3
+ import { i as PopoverTrigger, r as PopoverContent, t as Popover } from "./popover-Ds9624qY.mjs";
4
+ import { t as LoaderOverlay } from "./loader-overlay-CpA0zV8D.mjs";
5
5
  import { CheckIcon, ChevronDown } from "lucide-react";
6
6
  import * as React$1 from "react";
7
7
  import { Fragment as Fragment$1, jsx, jsxs } from "react/jsx-runtime";
@@ -1,5 +1,5 @@
1
1
  import "../utils-Bfgoe-Gm.mjs";
2
- import "../tooltip-CbCWKEzu.mjs";
3
- import { n as avatarStackVariants, t as AvatarStack } from "../avatar-stack-Ci0cnjxv.mjs";
2
+ import "../tooltip-U3XxlW4l.mjs";
3
+ import { n as avatarStackVariants, t as AvatarStack } from "../avatar-stack-B21McFeb.mjs";
4
4
 
5
5
  export { AvatarStack, avatarStackVariants };
@@ -1,6 +1,6 @@
1
1
  import { t as cn } from "./cn-DWCc1QRE.mjs";
2
2
  import { t as cn$1 } from "./utils-Bfgoe-Gm.mjs";
3
- import { t as Tooltip } from "./tooltip-CbCWKEzu.mjs";
3
+ import { t as Tooltip } from "./tooltip-U3XxlW4l.mjs";
4
4
  import { cva } from "class-variance-authority";
5
5
  import "react";
6
6
  import { Fragment as Fragment$1, jsx, jsxs } from "react/jsx-runtime";
@@ -1,8 +1,8 @@
1
1
  import { t as cn } from "./cn-DWCc1QRE.mjs";
2
2
  import { t as Button } from "./button-AzpnV-WB.mjs";
3
3
  import { t as Calendar$1 } from "./calendar-DlIHeWb0.mjs";
4
- import { i as PopoverTrigger, r as PopoverContent, t as Popover } from "./popover-CYzXdp9q.mjs";
5
- import { i as SelectItem, l as SelectTrigger, n as SelectContent, t as Select, u as SelectValue } from "./select-BznmyqBr.mjs";
4
+ import { i as PopoverTrigger, r as PopoverContent, t as Popover } from "./popover-Ds9624qY.mjs";
5
+ import { i as SelectItem, l as SelectTrigger, n as SelectContent, t as Select, u as SelectValue } from "./select-CwVIFWFO.mjs";
6
6
  import { cva } from "class-variance-authority";
7
7
  import { CalendarIcon, X } from "lucide-react";
8
8
  import * as React$1 from "react";
@@ -36,7 +36,7 @@ const multiSelectVariants = cva("flex font-normal shadow-none items-center justi
36
36
  } },
37
37
  defaultVariants: { variant: "default" }
38
38
  });
39
- function CalendarDatePicker({ ref, id = "calendar-date-picker", className, triggerClassName, date, closeOnSelect = false, numberOfMonths = 2, yearsRange = 10, onDateSelect, variant, placeholder, excludePresets, customPresets, minDate, maxDate, disableFuture = false, disablePast = false, maxRange, popoverClassName, ...props }) {
39
+ function CalendarDatePicker({ ref, id = "calendar-date-picker", className, triggerClassName, date, closeOnSelect = false, numberOfMonths = 2, yearsRange = 10, onDateSelect, variant, placeholder, excludePresets, customPresets, minDate, maxDate, disableFuture = false, disablePast = false, maxRange, popoverClassName, disabled, ...props }) {
40
40
  const [isPopoverOpen, setIsPopoverOpen] = React$1.useState(false);
41
41
  const [selectedRange, setSelectedRange] = React$1.useState(numberOfMonths === 2 ? "This Year" : "Today");
42
42
  const [monthFrom, setMonthFrom] = React$1.useState(date?.from);
@@ -428,6 +428,7 @@ function CalendarDatePicker({ ref, id = "calendar-date-picker", className, trigg
428
428
  id: "date",
429
429
  ref,
430
430
  ...props,
431
+ disabled,
431
432
  className: cn("w-full", triggerClassName, multiSelectVariants({
432
433
  variant,
433
434
  className
@@ -1,5 +1,4 @@
1
1
  import "../utils-Bfgoe-Gm.mjs";
2
- import "../checkbox-DB5_3E_l.mjs";
3
- import { t as Checkbox } from "../checkbox-DMC1Mhaw.mjs";
2
+ import { t as Checkbox } from "../checkbox-LG1OKTpG.mjs";
4
3
 
5
4
  export { Checkbox };
@@ -0,0 +1,34 @@
1
+ import { t as cn } from "./cn-DWCc1QRE.mjs";
2
+ import { t as cn$1 } from "./utils-Bfgoe-Gm.mjs";
3
+ import { CheckIcon } from "lucide-react";
4
+ import "react";
5
+ import { jsx } from "react/jsx-runtime";
6
+ import * as CheckboxPrimitive from "@radix-ui/react-checkbox";
7
+
8
+ //#region ../shadcn/ui/checkbox.tsx
9
+ function Checkbox$1({ className, ...props }) {
10
+ return /* @__PURE__ */ jsx(CheckboxPrimitive.Root, {
11
+ "data-slot": "checkbox",
12
+ className: cn$1("peer border-input dark:bg-input/30 data-[state=checked]:bg-primary data-[state=checked]:text-primary-foreground dark:data-[state=checked]:bg-primary data-[state=checked]:border-primary focus-visible:border-ring focus-visible:ring-ring/50 aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive size-4 shrink-0 rounded-[4px] border shadow-xs transition-shadow outline-none focus-visible:ring-[3px] disabled:cursor-not-allowed disabled:opacity-50", className),
13
+ ...props,
14
+ children: /* @__PURE__ */ jsx(CheckboxPrimitive.Indicator, {
15
+ "data-slot": "checkbox-indicator",
16
+ className: "flex items-center justify-center text-current transition-none",
17
+ children: /* @__PURE__ */ jsx(CheckIcon, { className: "size-3.5" })
18
+ })
19
+ });
20
+ }
21
+
22
+ //#endregion
23
+ //#region src/components/base/checkbox/checkbox.tsx
24
+ function Checkbox({ ref, className, ...props }) {
25
+ return /* @__PURE__ */ jsx(Checkbox$1, {
26
+ ref,
27
+ className: cn(className),
28
+ ...props
29
+ });
30
+ }
31
+ Checkbox.displayName = "Checkbox";
32
+
33
+ //#endregion
34
+ export { Checkbox as t };
@@ -1,3 +1,3 @@
1
- import { n as CollapsibleContent, r as CollapsibleTrigger, t as Collapsible } from "../collapsible-Dw71o2um.mjs";
1
+ import { n as CollapsibleContent, r as CollapsibleTrigger, t as Collapsible } from "../collapsible-Bt9UYfv3.mjs";
2
2
 
3
3
  export { Collapsible, CollapsibleContent, CollapsibleTrigger };
@@ -1,5 +1,5 @@
1
1
  import "../utils-Bfgoe-Gm.mjs";
2
- import "../dialog-Bm4trnic.mjs";
3
- import { a as CommandInput, c as CommandSeparator, i as CommandGroup, l as CommandShortcut, n as CommandDialog, o as CommandItem, r as CommandEmpty, s as CommandList, t as Command } from "../command-DQlO6uTL.mjs";
2
+ import "../dialog-DXBaT9gA.mjs";
3
+ import { a as CommandInput, c as CommandSeparator, i as CommandGroup, l as CommandShortcut, n as CommandDialog, o as CommandItem, r as CommandEmpty, s as CommandList, t as Command } from "../command-s0Yv3abE.mjs";
4
4
 
5
5
  export { Command, CommandDialog, CommandEmpty, CommandGroup, CommandInput, CommandItem, CommandList, CommandSeparator, CommandShortcut };
@@ -1,5 +1,5 @@
1
1
  import { t as cn } from "./utils-Bfgoe-Gm.mjs";
2
- import { i as DialogDescription, l as DialogTitle, o as DialogHeader, r as DialogContent, t as Dialog } from "./dialog-Bm4trnic.mjs";
2
+ import { i as DialogDescription, l as DialogTitle, o as DialogHeader, r as DialogContent, t as Dialog } from "./dialog-DXBaT9gA.mjs";
3
3
  import { SearchIcon } from "lucide-react";
4
4
  import "react";
5
5
  import { jsx, jsxs } from "react/jsx-runtime";
@@ -26,6 +26,7 @@ export * from './radio-group';
26
26
  export * from './select';
27
27
  export * from './separator';
28
28
  export * from './sheet';
29
+ export * from './sidebar';
29
30
  export * from './skeleton';
30
31
  export * from './spinner';
31
32
  export * from './switch';
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/base/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAGH,cAAc,SAAS,CAAA;AACvB,cAAc,SAAS,CAAA;AAEvB,cAAc,cAAc,CAAA;AAC5B,cAAc,UAAU,CAAA;AACxB,cAAc,gBAAgB,CAAA;AAC9B,cAAc,YAAY,CAAA;AAC1B,cAAc,QAAQ,CAAA;AACtB,cAAc,SAAS,CAAA;AACvB,cAAc,YAAY,CAAA;AAC1B,cAAc,eAAe,CAAA;AAC7B,cAAc,WAAW,CAAA;AACzB,cAAc,UAAU,CAAA;AACxB,cAAc,cAAc,CAAA;AAC5B,cAAc,SAAS,CAAA;AACvB,cAAc,eAAe,CAAA;AAC7B,cAAc,SAAS,CAAA;AAEvB,cAAc,OAAO,CAAA;AACrB,cAAc,sBAAsB,CAAA;AACpC,cAAc,WAAW,CAAA;AACzB,cAAc,eAAe,CAAA;AAC7B,cAAc,UAAU,CAAA;AACxB,cAAc,aAAa,CAAA;AAC3B,cAAc,SAAS,CAAA;AACvB,cAAc,YAAY,CAAA;AAC1B,cAAc,WAAW,CAAA;AACzB,cAAc,UAAU,CAAA;AACxB,cAAc,SAAS,CAAA;AACvB,cAAc,QAAQ,CAAA;AACtB,cAAc,YAAY,CAAA;AAC1B,cAAc,WAAW,CAAA;AACzB,cAAc,cAAc,CAAA;AAC5B,cAAc,kBAAkB,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/base/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAGH,cAAc,SAAS,CAAA;AACvB,cAAc,SAAS,CAAA;AAEvB,cAAc,cAAc,CAAA;AAC5B,cAAc,UAAU,CAAA;AACxB,cAAc,gBAAgB,CAAA;AAC9B,cAAc,YAAY,CAAA;AAC1B,cAAc,QAAQ,CAAA;AACtB,cAAc,SAAS,CAAA;AACvB,cAAc,YAAY,CAAA;AAC1B,cAAc,eAAe,CAAA;AAC7B,cAAc,WAAW,CAAA;AACzB,cAAc,UAAU,CAAA;AACxB,cAAc,cAAc,CAAA;AAC5B,cAAc,SAAS,CAAA;AACvB,cAAc,eAAe,CAAA;AAC7B,cAAc,SAAS,CAAA;AAEvB,cAAc,OAAO,CAAA;AACrB,cAAc,sBAAsB,CAAA;AACpC,cAAc,WAAW,CAAA;AACzB,cAAc,eAAe,CAAA;AAC7B,cAAc,UAAU,CAAA;AACxB,cAAc,aAAa,CAAA;AAC3B,cAAc,SAAS,CAAA;AACvB,cAAc,WAAW,CAAA;AACzB,cAAc,YAAY,CAAA;AAC1B,cAAc,WAAW,CAAA;AACzB,cAAc,UAAU,CAAA;AACxB,cAAc,SAAS,CAAA;AACvB,cAAc,QAAQ,CAAA;AACtB,cAAc,YAAY,CAAA;AAC1B,cAAc,WAAW,CAAA;AACzB,cAAc,cAAc,CAAA;AAC5B,cAAc,kBAAkB,CAAA"}
@@ -0,0 +1,2 @@
1
+ export * from './sidebar';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/base/sidebar/index.ts"],"names":[],"mappings":"AAAA,cAAc,WAAW,CAAA"}
@@ -2,7 +2,7 @@ import type { VariantProps } from 'class-variance-authority';
2
2
  import { Button } from '../../../_shadcn/ui/button';
3
3
  import { Separator } from '../../../_shadcn/ui/separator';
4
4
  import * as React from 'react';
5
- import { Input } from '../../base/input/input';
5
+ import { Input } from '../input/input';
6
6
  interface SidebarContext {
7
7
  state: 'expanded' | 'collapsed';
8
8
  open: boolean;
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sidebar.d.ts","sourceRoot":"","sources":["../../../../src/components/base/sidebar/sidebar.tsx"],"names":[],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- export * from '../../../_shadcn/ui/skeleton';
1
+ export * from './skeleton';
2
2
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/base/skeleton/index.ts"],"names":[],"mappings":"AAAA,cAAc,0BAA0B,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/base/skeleton/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAA"}
@@ -0,0 +1,22 @@
1
+ import { Skeleton as ShadcnSkeleton } from '../../../_shadcn/ui/skeleton';
2
+ import * as React from 'react';
3
+ /**
4
+ * Datum Skeleton component – extends shadcn Skeleton with Datum-specific styling.
5
+ *
6
+ * Wraps the shadcn Skeleton so you can add custom base styles here and pass
7
+ * additional className for overrides. All standard div props are supported.
8
+ *
9
+ * @example
10
+ * ```tsx
11
+ * <Skeleton className="h-4 w-48" />
12
+ * <Skeleton className="h-8 w-full rounded-lg" />
13
+ * ```
14
+ */
15
+ declare function Skeleton({ ref, className, ...props }: React.ComponentProps<typeof ShadcnSkeleton> & {
16
+ ref?: React.RefObject<React.ComponentRef<typeof ShadcnSkeleton> | null>;
17
+ }): import("react/jsx-runtime").JSX.Element;
18
+ declare namespace Skeleton {
19
+ var displayName: string;
20
+ }
21
+ export { Skeleton };
22
+ //# sourceMappingURL=skeleton.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"skeleton.d.ts","sourceRoot":"","sources":["../../../../src/components/base/skeleton/skeleton.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,IAAI,cAAc,EAAE,MAAM,0BAA0B,CAAA;AACrE,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAG9B;;;;;;;;;;;GAWG;AACH,iBAAS,QAAQ,CAAC,EAAE,GAAG,EAAE,SAAS,EAAE,GAAG,KAAK,EAAE,EAAE,KAAK,CAAC,cAAc,CAAC,OAAO,cAAc,CAAC,GAAG;IAAE,GAAG,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC,KAAK,CAAC,YAAY,CAAC,OAAO,cAAc,CAAC,GAAG,IAAI,CAAC,CAAA;CAAE,2CAOxK;kBAPQ,QAAQ;;;AAWjB,OAAO,EAAE,QAAQ,EAAE,CAAA"}