@thalamiq/ui 0.1.1

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 (333) hide show
  1. package/README.md +29 -0
  2. package/dist/components/accordion.d.mts +10 -0
  3. package/dist/components/accordion.d.ts +10 -0
  4. package/dist/components/accordion.js +148 -0
  5. package/dist/components/accordion.js.map +1 -0
  6. package/dist/components/accordion.mjs +113 -0
  7. package/dist/components/accordion.mjs.map +1 -0
  8. package/dist/components/alert-dialog.d.mts +17 -0
  9. package/dist/components/alert-dialog.d.ts +17 -0
  10. package/dist/components/alert-dialog.js +264 -0
  11. package/dist/components/alert-dialog.js.map +1 -0
  12. package/dist/components/alert-dialog.mjs +222 -0
  13. package/dist/components/alert-dialog.mjs.map +1 -0
  14. package/dist/components/alert.d.mts +13 -0
  15. package/dist/components/alert.d.ts +13 -0
  16. package/dist/components/alert.js +133 -0
  17. package/dist/components/alert.js.map +1 -0
  18. package/dist/components/alert.mjs +109 -0
  19. package/dist/components/alert.mjs.map +1 -0
  20. package/dist/components/aspect-ratio.d.mts +6 -0
  21. package/dist/components/aspect-ratio.d.ts +6 -0
  22. package/dist/components/aspect-ratio.js +74 -0
  23. package/dist/components/aspect-ratio.js.map +1 -0
  24. package/dist/components/aspect-ratio.mjs +42 -0
  25. package/dist/components/aspect-ratio.mjs.map +1 -0
  26. package/dist/components/avatar.d.mts +9 -0
  27. package/dist/components/avatar.d.ts +9 -0
  28. package/dist/components/avatar.js +130 -0
  29. package/dist/components/avatar.js.map +1 -0
  30. package/dist/components/avatar.mjs +96 -0
  31. package/dist/components/avatar.mjs.map +1 -0
  32. package/dist/components/badge.d.mts +13 -0
  33. package/dist/components/badge.d.ts +13 -0
  34. package/dist/components/badge.js +106 -0
  35. package/dist/components/badge.js.map +1 -0
  36. package/dist/components/badge.mjs +83 -0
  37. package/dist/components/badge.mjs.map +1 -0
  38. package/dist/components/breadcrumb.d.mts +14 -0
  39. package/dist/components/breadcrumb.d.ts +14 -0
  40. package/dist/components/breadcrumb.js +182 -0
  41. package/dist/components/breadcrumb.js.map +1 -0
  42. package/dist/components/breadcrumb.mjs +154 -0
  43. package/dist/components/breadcrumb.mjs.map +1 -0
  44. package/dist/components/button-group.d.mts +17 -0
  45. package/dist/components/button-group.d.ts +17 -0
  46. package/dist/components/button-group.js +183 -0
  47. package/dist/components/button-group.js.map +1 -0
  48. package/dist/components/button-group.mjs +148 -0
  49. package/dist/components/button-group.mjs.map +1 -0
  50. package/dist/components/button.d.mts +14 -0
  51. package/dist/components/button.d.ts +14 -0
  52. package/dist/components/button.js +119 -0
  53. package/dist/components/button.js.map +1 -0
  54. package/dist/components/button.mjs +96 -0
  55. package/dist/components/button.mjs.map +1 -0
  56. package/dist/components/calendar.d.mts +13 -0
  57. package/dist/components/calendar.d.ts +13 -0
  58. package/dist/components/calendar.js +324 -0
  59. package/dist/components/calendar.js.map +1 -0
  60. package/dist/components/calendar.mjs +295 -0
  61. package/dist/components/calendar.mjs.map +1 -0
  62. package/dist/components/card.d.mts +12 -0
  63. package/dist/components/card.d.ts +12 -0
  64. package/dist/components/card.js +158 -0
  65. package/dist/components/card.js.map +1 -0
  66. package/dist/components/card.mjs +128 -0
  67. package/dist/components/card.mjs.map +1 -0
  68. package/dist/components/carousel.d.mts +24 -0
  69. package/dist/components/carousel.d.ts +24 -0
  70. package/dist/components/carousel.js +343 -0
  71. package/dist/components/carousel.js.map +1 -0
  72. package/dist/components/carousel.mjs +307 -0
  73. package/dist/components/carousel.mjs.map +1 -0
  74. package/dist/components/chart.d.mts +43 -0
  75. package/dist/components/chart.d.ts +43 -0
  76. package/dist/components/chart.js +330 -0
  77. package/dist/components/chart.js.map +1 -0
  78. package/dist/components/chart.mjs +293 -0
  79. package/dist/components/chart.mjs.map +1 -0
  80. package/dist/components/checkbox.d.mts +7 -0
  81. package/dist/components/checkbox.d.ts +7 -0
  82. package/dist/components/checkbox.js +109 -0
  83. package/dist/components/checkbox.js.map +1 -0
  84. package/dist/components/checkbox.mjs +77 -0
  85. package/dist/components/checkbox.mjs.map +1 -0
  86. package/dist/components/collapsible.d.mts +8 -0
  87. package/dist/components/collapsible.d.ts +8 -0
  88. package/dist/components/collapsible.js +95 -0
  89. package/dist/components/collapsible.js.map +1 -0
  90. package/dist/components/collapsible.mjs +61 -0
  91. package/dist/components/collapsible.mjs.map +1 -0
  92. package/dist/components/command.d.mts +22 -0
  93. package/dist/components/command.d.ts +22 -0
  94. package/dist/components/command.js +370 -0
  95. package/dist/components/command.js.map +1 -0
  96. package/dist/components/command.mjs +330 -0
  97. package/dist/components/command.mjs.map +1 -0
  98. package/dist/components/context-menu.d.mts +28 -0
  99. package/dist/components/context-menu.d.ts +28 -0
  100. package/dist/components/context-menu.js +326 -0
  101. package/dist/components/context-menu.js.map +1 -0
  102. package/dist/components/context-menu.mjs +280 -0
  103. package/dist/components/context-menu.mjs.map +1 -0
  104. package/dist/components/dialog.d.mts +18 -0
  105. package/dist/components/dialog.d.ts +18 -0
  106. package/dist/components/dialog.js +223 -0
  107. package/dist/components/dialog.js.map +1 -0
  108. package/dist/components/dialog.mjs +182 -0
  109. package/dist/components/dialog.mjs.map +1 -0
  110. package/dist/components/drawer.d.mts +16 -0
  111. package/dist/components/drawer.d.ts +16 -0
  112. package/dist/components/drawer.js +205 -0
  113. package/dist/components/drawer.js.map +1 -0
  114. package/dist/components/drawer.mjs +174 -0
  115. package/dist/components/drawer.mjs.map +1 -0
  116. package/dist/components/dropdown-menu.d.mts +28 -0
  117. package/dist/components/dropdown-menu.d.ts +28 -0
  118. package/dist/components/dropdown-menu.js +333 -0
  119. package/dist/components/dropdown-menu.js.map +1 -0
  120. package/dist/components/dropdown-menu.mjs +287 -0
  121. package/dist/components/dropdown-menu.mjs.map +1 -0
  122. package/dist/components/empty.d.mts +15 -0
  123. package/dist/components/empty.d.ts +15 -0
  124. package/dist/components/empty.js +171 -0
  125. package/dist/components/empty.js.map +1 -0
  126. package/dist/components/empty.mjs +144 -0
  127. package/dist/components/empty.mjs.map +1 -0
  128. package/dist/components/field.d.mts +30 -0
  129. package/dist/components/field.d.ts +30 -0
  130. package/dist/components/field.js +372 -0
  131. package/dist/components/field.js.map +1 -0
  132. package/dist/components/field.mjs +331 -0
  133. package/dist/components/field.mjs.map +1 -0
  134. package/dist/components/form.d.mts +28 -0
  135. package/dist/components/form.d.ts +28 -0
  136. package/dist/components/form.js +220 -0
  137. package/dist/components/form.js.map +1 -0
  138. package/dist/components/form.mjs +186 -0
  139. package/dist/components/form.mjs.map +1 -0
  140. package/dist/components/hover-card.d.mts +9 -0
  141. package/dist/components/hover-card.d.ts +9 -0
  142. package/dist/components/hover-card.js +114 -0
  143. package/dist/components/hover-card.js.map +1 -0
  144. package/dist/components/hover-card.mjs +80 -0
  145. package/dist/components/hover-card.mjs.map +1 -0
  146. package/dist/components/input-group.d.mts +20 -0
  147. package/dist/components/input-group.d.ts +20 -0
  148. package/dist/components/input-group.js +316 -0
  149. package/dist/components/input-group.js.map +1 -0
  150. package/dist/components/input-group.mjs +289 -0
  151. package/dist/components/input-group.mjs.map +1 -0
  152. package/dist/components/input-otp.d.mts +14 -0
  153. package/dist/components/input-otp.d.ts +14 -0
  154. package/dist/components/input-otp.js +151 -0
  155. package/dist/components/input-otp.js.map +1 -0
  156. package/dist/components/input-otp.mjs +116 -0
  157. package/dist/components/input-otp.mjs.map +1 -0
  158. package/dist/components/input.d.mts +6 -0
  159. package/dist/components/input.d.ts +6 -0
  160. package/dist/components/input.js +83 -0
  161. package/dist/components/input.js.map +1 -0
  162. package/dist/components/input.mjs +59 -0
  163. package/dist/components/input.mjs.map +1 -0
  164. package/dist/components/item.d.mts +28 -0
  165. package/dist/components/item.d.ts +28 -0
  166. package/dist/components/item.js +301 -0
  167. package/dist/components/item.js.map +1 -0
  168. package/dist/components/item.mjs +260 -0
  169. package/dist/components/item.mjs.map +1 -0
  170. package/dist/components/kbd.d.mts +6 -0
  171. package/dist/components/kbd.d.ts +6 -0
  172. package/dist/components/kbd.js +94 -0
  173. package/dist/components/kbd.js.map +1 -0
  174. package/dist/components/kbd.mjs +69 -0
  175. package/dist/components/kbd.mjs.map +1 -0
  176. package/dist/components/label.d.mts +7 -0
  177. package/dist/components/label.d.ts +7 -0
  178. package/dist/components/label.js +96 -0
  179. package/dist/components/label.js.map +1 -0
  180. package/dist/components/label.mjs +64 -0
  181. package/dist/components/label.mjs.map +1 -0
  182. package/dist/components/menubar.d.mts +29 -0
  183. package/dist/components/menubar.d.ts +29 -0
  184. package/dist/components/menubar.js +361 -0
  185. package/dist/components/menubar.js.map +1 -0
  186. package/dist/components/menubar.mjs +314 -0
  187. package/dist/components/menubar.mjs.map +1 -0
  188. package/dist/components/navigation-menu.d.mts +18 -0
  189. package/dist/components/navigation-menu.d.ts +18 -0
  190. package/dist/components/navigation-menu.js +267 -0
  191. package/dist/components/navigation-menu.js.map +1 -0
  192. package/dist/components/navigation-menu.mjs +227 -0
  193. package/dist/components/navigation-menu.mjs.map +1 -0
  194. package/dist/components/pagination.d.mts +18 -0
  195. package/dist/components/pagination.d.ts +18 -0
  196. package/dist/components/pagination.js +231 -0
  197. package/dist/components/pagination.js.map +1 -0
  198. package/dist/components/pagination.mjs +207 -0
  199. package/dist/components/pagination.mjs.map +1 -0
  200. package/dist/components/popover.d.mts +10 -0
  201. package/dist/components/popover.d.ts +10 -0
  202. package/dist/components/popover.js +120 -0
  203. package/dist/components/popover.js.map +1 -0
  204. package/dist/components/popover.mjs +85 -0
  205. package/dist/components/popover.mjs.map +1 -0
  206. package/dist/components/progress.d.mts +7 -0
  207. package/dist/components/progress.d.ts +7 -0
  208. package/dist/components/progress.js +109 -0
  209. package/dist/components/progress.js.map +1 -0
  210. package/dist/components/progress.mjs +77 -0
  211. package/dist/components/progress.mjs.map +1 -0
  212. package/dist/components/radio-group.d.mts +8 -0
  213. package/dist/components/radio-group.d.ts +8 -0
  214. package/dist/components/radio-group.js +125 -0
  215. package/dist/components/radio-group.js.map +1 -0
  216. package/dist/components/radio-group.mjs +92 -0
  217. package/dist/components/radio-group.mjs.map +1 -0
  218. package/dist/components/resizable.d.mts +11 -0
  219. package/dist/components/resizable.d.ts +11 -0
  220. package/dist/components/resizable.js +128 -0
  221. package/dist/components/resizable.js.map +1 -0
  222. package/dist/components/resizable.mjs +94 -0
  223. package/dist/components/resizable.mjs.map +1 -0
  224. package/dist/components/scroll-area.d.mts +8 -0
  225. package/dist/components/scroll-area.d.ts +8 -0
  226. package/dist/components/scroll-area.js +143 -0
  227. package/dist/components/scroll-area.js.map +1 -0
  228. package/dist/components/scroll-area.mjs +110 -0
  229. package/dist/components/scroll-area.mjs.map +1 -0
  230. package/dist/components/select.d.mts +18 -0
  231. package/dist/components/select.d.ts +18 -0
  232. package/dist/components/select.js +270 -0
  233. package/dist/components/select.js.map +1 -0
  234. package/dist/components/select.mjs +229 -0
  235. package/dist/components/select.mjs.map +1 -0
  236. package/dist/components/separator.d.mts +7 -0
  237. package/dist/components/separator.d.ts +7 -0
  238. package/dist/components/separator.js +102 -0
  239. package/dist/components/separator.js.map +1 -0
  240. package/dist/components/separator.mjs +70 -0
  241. package/dist/components/separator.mjs.map +1 -0
  242. package/dist/components/sheet.d.mts +16 -0
  243. package/dist/components/sheet.d.ts +16 -0
  244. package/dist/components/sheet.js +213 -0
  245. package/dist/components/sheet.js.map +1 -0
  246. package/dist/components/sheet.mjs +174 -0
  247. package/dist/components/sheet.mjs.map +1 -0
  248. package/dist/components/sidebar.d.mts +75 -0
  249. package/dist/components/sidebar.d.ts +75 -0
  250. package/dist/components/sidebar.js +1055 -0
  251. package/dist/components/sidebar.js.map +1 -0
  252. package/dist/components/sidebar.mjs +1000 -0
  253. package/dist/components/sidebar.mjs.map +1 -0
  254. package/dist/components/skeleton.d.mts +5 -0
  255. package/dist/components/skeleton.d.ts +5 -0
  256. package/dist/components/skeleton.js +77 -0
  257. package/dist/components/skeleton.js.map +1 -0
  258. package/dist/components/skeleton.mjs +53 -0
  259. package/dist/components/skeleton.mjs.map +1 -0
  260. package/dist/components/slider.d.mts +7 -0
  261. package/dist/components/slider.d.ts +7 -0
  262. package/dist/components/slider.js +145 -0
  263. package/dist/components/slider.js.map +1 -0
  264. package/dist/components/slider.mjs +113 -0
  265. package/dist/components/slider.mjs.map +1 -0
  266. package/dist/components/sonner.d.mts +6 -0
  267. package/dist/components/sonner.d.ts +6 -0
  268. package/dist/components/sonner.js +85 -0
  269. package/dist/components/sonner.js.map +1 -0
  270. package/dist/components/sonner.mjs +69 -0
  271. package/dist/components/sonner.mjs.map +1 -0
  272. package/dist/components/spinner.d.mts +5 -0
  273. package/dist/components/spinner.d.ts +5 -0
  274. package/dist/components/spinner.js +79 -0
  275. package/dist/components/spinner.js.map +1 -0
  276. package/dist/components/spinner.mjs +57 -0
  277. package/dist/components/spinner.mjs.map +1 -0
  278. package/dist/components/switch.d.mts +7 -0
  279. package/dist/components/switch.d.ts +7 -0
  280. package/dist/components/switch.js +109 -0
  281. package/dist/components/switch.js.map +1 -0
  282. package/dist/components/switch.mjs +77 -0
  283. package/dist/components/switch.mjs.map +1 -0
  284. package/dist/components/table.d.mts +13 -0
  285. package/dist/components/table.d.ts +13 -0
  286. package/dist/components/table.js +184 -0
  287. package/dist/components/table.js.map +1 -0
  288. package/dist/components/table.mjs +153 -0
  289. package/dist/components/table.mjs.map +1 -0
  290. package/dist/components/tabs.d.mts +10 -0
  291. package/dist/components/tabs.d.ts +10 -0
  292. package/dist/components/tabs.js +147 -0
  293. package/dist/components/tabs.js.map +1 -0
  294. package/dist/components/tabs.mjs +112 -0
  295. package/dist/components/tabs.mjs.map +1 -0
  296. package/dist/components/textarea.d.mts +6 -0
  297. package/dist/components/textarea.d.ts +6 -0
  298. package/dist/components/textarea.js +80 -0
  299. package/dist/components/textarea.js.map +1 -0
  300. package/dist/components/textarea.mjs +56 -0
  301. package/dist/components/textarea.mjs.map +1 -0
  302. package/dist/components/toggle-group.d.mts +14 -0
  303. package/dist/components/toggle-group.d.ts +14 -0
  304. package/dist/components/toggle-group.js +179 -0
  305. package/dist/components/toggle-group.js.map +1 -0
  306. package/dist/components/toggle-group.mjs +146 -0
  307. package/dist/components/toggle-group.mjs.map +1 -0
  308. package/dist/components/toggle.d.mts +13 -0
  309. package/dist/components/toggle.d.ts +13 -0
  310. package/dist/components/toggle.js +119 -0
  311. package/dist/components/toggle.js.map +1 -0
  312. package/dist/components/toggle.mjs +86 -0
  313. package/dist/components/toggle.mjs.map +1 -0
  314. package/dist/components/tooltip.d.mts +10 -0
  315. package/dist/components/tooltip.d.ts +10 -0
  316. package/dist/components/tooltip.js +137 -0
  317. package/dist/components/tooltip.js.map +1 -0
  318. package/dist/components/tooltip.mjs +102 -0
  319. package/dist/components/tooltip.mjs.map +1 -0
  320. package/dist/hooks/use-mobile.d.mts +3 -0
  321. package/dist/hooks/use-mobile.d.ts +3 -0
  322. package/dist/hooks/use-mobile.js +56 -0
  323. package/dist/hooks/use-mobile.js.map +1 -0
  324. package/dist/hooks/use-mobile.mjs +22 -0
  325. package/dist/hooks/use-mobile.mjs.map +1 -0
  326. package/dist/styles/globals.css +230 -0
  327. package/dist/utils/utils.d.mts +5 -0
  328. package/dist/utils/utils.d.ts +5 -0
  329. package/dist/utils/utils.js +36 -0
  330. package/dist/utils/utils.js.map +1 -0
  331. package/dist/utils/utils.mjs +12 -0
  332. package/dist/utils/utils.mjs.map +1 -0
  333. package/package.json +393 -0
@@ -0,0 +1,324 @@
1
+ "use client";
2
+ "use strict";
3
+ "use client";
4
+ var __create = Object.create;
5
+ var __defProp = Object.defineProperty;
6
+ var __defProps = Object.defineProperties;
7
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
8
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
9
+ var __getOwnPropNames = Object.getOwnPropertyNames;
10
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
11
+ var __getProtoOf = Object.getPrototypeOf;
12
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
13
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
14
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
15
+ var __spreadValues = (a, b) => {
16
+ for (var prop in b || (b = {}))
17
+ if (__hasOwnProp.call(b, prop))
18
+ __defNormalProp(a, prop, b[prop]);
19
+ if (__getOwnPropSymbols)
20
+ for (var prop of __getOwnPropSymbols(b)) {
21
+ if (__propIsEnum.call(b, prop))
22
+ __defNormalProp(a, prop, b[prop]);
23
+ }
24
+ return a;
25
+ };
26
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
27
+ var __objRest = (source, exclude) => {
28
+ var target = {};
29
+ for (var prop in source)
30
+ if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
31
+ target[prop] = source[prop];
32
+ if (source != null && __getOwnPropSymbols)
33
+ for (var prop of __getOwnPropSymbols(source)) {
34
+ if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
35
+ target[prop] = source[prop];
36
+ }
37
+ return target;
38
+ };
39
+ var __export = (target, all) => {
40
+ for (var name in all)
41
+ __defProp(target, name, { get: all[name], enumerable: true });
42
+ };
43
+ var __copyProps = (to, from, except, desc) => {
44
+ if (from && typeof from === "object" || typeof from === "function") {
45
+ for (let key of __getOwnPropNames(from))
46
+ if (!__hasOwnProp.call(to, key) && key !== except)
47
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
48
+ }
49
+ return to;
50
+ };
51
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
52
+ // If the importer is in node compatibility mode or this is not an ESM
53
+ // file that has been converted to a CommonJS file using a Babel-
54
+ // compatible transform (i.e. "__esModule" has not been set), then set
55
+ // "default" to the CommonJS "module.exports" for node compatibility.
56
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
57
+ mod
58
+ ));
59
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
60
+
61
+ // lib/components/calendar.tsx
62
+ var calendar_exports = {};
63
+ __export(calendar_exports, {
64
+ Calendar: () => Calendar,
65
+ CalendarDayButton: () => CalendarDayButton
66
+ });
67
+ module.exports = __toCommonJS(calendar_exports);
68
+ var React = __toESM(require("react"));
69
+ var import_lucide_react = require("lucide-react");
70
+ var import_react_day_picker = require("react-day-picker");
71
+
72
+ // lib/utils/utils.ts
73
+ var import_clsx = require("clsx");
74
+ var import_tailwind_merge = require("tailwind-merge");
75
+ function cn(...inputs) {
76
+ return (0, import_tailwind_merge.twMerge)((0, import_clsx.clsx)(inputs));
77
+ }
78
+
79
+ // lib/components/button.tsx
80
+ var import_react_slot = require("@radix-ui/react-slot");
81
+ var import_class_variance_authority = require("class-variance-authority");
82
+ var import_jsx_runtime = require("react/jsx-runtime");
83
+ var buttonVariants = (0, import_class_variance_authority.cva)(
84
+ "inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium transition-all disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg:not([class*='size-'])]:size-4 shrink-0 [&_svg]:shrink-0 outline-none focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px] aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive",
85
+ {
86
+ variants: {
87
+ variant: {
88
+ default: "bg-primary text-primary-foreground hover:bg-primary/90",
89
+ destructive: "bg-destructive text-white hover:bg-destructive/90 focus-visible:ring-destructive/20 dark:focus-visible:ring-destructive/40 dark:bg-destructive/60",
90
+ outline: "border bg-background hover:bg-accent hover:text-accent-foreground dark:border-border dark:hover:bg-input/50",
91
+ secondary: "bg-secondary text-secondary-foreground hover:bg-secondary/80",
92
+ ghost: "hover:bg-accent hover:text-accent-foreground dark:hover:bg-accent/50",
93
+ link: "text-primary underline-offset-4 hover:underline"
94
+ },
95
+ size: {
96
+ default: "h-9 px-4 py-2 has-[>svg]:px-3",
97
+ sm: "h-8 rounded-md gap-1.5 px-3 has-[>svg]:px-2.5",
98
+ lg: "h-10 rounded-md px-6 has-[>svg]:px-4",
99
+ icon: "size-9",
100
+ "icon-sm": "size-8",
101
+ "icon-lg": "size-10"
102
+ }
103
+ },
104
+ defaultVariants: {
105
+ variant: "default",
106
+ size: "default"
107
+ }
108
+ }
109
+ );
110
+ function Button(_a) {
111
+ var _b = _a, {
112
+ className,
113
+ variant,
114
+ size,
115
+ asChild = false
116
+ } = _b, props = __objRest(_b, [
117
+ "className",
118
+ "variant",
119
+ "size",
120
+ "asChild"
121
+ ]);
122
+ const Comp = asChild ? import_react_slot.Slot : "button";
123
+ return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
124
+ Comp,
125
+ __spreadValues({
126
+ "data-slot": "button",
127
+ className: cn(buttonVariants({ variant, size, className }))
128
+ }, props)
129
+ );
130
+ }
131
+
132
+ // lib/components/calendar.tsx
133
+ var import_jsx_runtime2 = require("react/jsx-runtime");
134
+ function Calendar(_a) {
135
+ var _b = _a, {
136
+ className,
137
+ classNames,
138
+ showOutsideDays = true,
139
+ captionLayout = "label",
140
+ buttonVariant = "ghost",
141
+ formatters,
142
+ components
143
+ } = _b, props = __objRest(_b, [
144
+ "className",
145
+ "classNames",
146
+ "showOutsideDays",
147
+ "captionLayout",
148
+ "buttonVariant",
149
+ "formatters",
150
+ "components"
151
+ ]);
152
+ const defaultClassNames = (0, import_react_day_picker.getDefaultClassNames)();
153
+ return /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
154
+ import_react_day_picker.DayPicker,
155
+ __spreadValues({
156
+ showOutsideDays,
157
+ className: cn(
158
+ "bg-background group/calendar p-3 [--cell-size:--spacing(8)] [[data-slot=card-content]_&]:bg-transparent [[data-slot=popover-content]_&]:bg-transparent",
159
+ String.raw`rtl:**:[.rdp-button\_next>svg]:rotate-180`,
160
+ String.raw`rtl:**:[.rdp-button\_previous>svg]:rotate-180`,
161
+ className
162
+ ),
163
+ captionLayout,
164
+ formatters: __spreadValues({
165
+ formatMonthDropdown: (date) => date.toLocaleString("default", { month: "short" })
166
+ }, formatters),
167
+ classNames: __spreadValues({
168
+ root: cn("w-fit", defaultClassNames.root),
169
+ months: cn(
170
+ "flex gap-4 flex-col md:flex-row relative",
171
+ defaultClassNames.months
172
+ ),
173
+ month: cn("flex flex-col w-full gap-4", defaultClassNames.month),
174
+ nav: cn(
175
+ "flex items-center gap-1 w-full absolute top-0 inset-x-0 justify-between",
176
+ defaultClassNames.nav
177
+ ),
178
+ button_previous: cn(
179
+ buttonVariants({ variant: buttonVariant }),
180
+ "size-(--cell-size) aria-disabled:opacity-50 p-0 select-none",
181
+ defaultClassNames.button_previous
182
+ ),
183
+ button_next: cn(
184
+ buttonVariants({ variant: buttonVariant }),
185
+ "size-(--cell-size) aria-disabled:opacity-50 p-0 select-none",
186
+ defaultClassNames.button_next
187
+ ),
188
+ month_caption: cn(
189
+ "flex items-center justify-center h-(--cell-size) w-full px-(--cell-size)",
190
+ defaultClassNames.month_caption
191
+ ),
192
+ dropdowns: cn(
193
+ "w-full flex items-center text-sm font-medium justify-center h-(--cell-size) gap-1.5",
194
+ defaultClassNames.dropdowns
195
+ ),
196
+ dropdown_root: cn(
197
+ "relative has-focus:border-ring border border-input shadow-xs has-focus:ring-ring/50 has-focus:ring-[3px] rounded-md",
198
+ defaultClassNames.dropdown_root
199
+ ),
200
+ dropdown: cn(
201
+ "absolute bg-popover inset-0 opacity-0",
202
+ defaultClassNames.dropdown
203
+ ),
204
+ caption_label: cn(
205
+ "select-none font-medium",
206
+ captionLayout === "label" ? "text-sm" : "rounded-md pl-2 pr-1 flex items-center gap-1 text-sm h-8 [&>svg]:text-muted-foreground [&>svg]:size-3.5",
207
+ defaultClassNames.caption_label
208
+ ),
209
+ table: "w-full border-collapse",
210
+ weekdays: cn("flex", defaultClassNames.weekdays),
211
+ weekday: cn(
212
+ "text-muted-foreground rounded-md flex-1 font-normal text-[0.8rem] select-none",
213
+ defaultClassNames.weekday
214
+ ),
215
+ week: cn("flex w-full mt-2", defaultClassNames.week),
216
+ week_number_header: cn(
217
+ "select-none w-(--cell-size)",
218
+ defaultClassNames.week_number_header
219
+ ),
220
+ week_number: cn(
221
+ "text-[0.8rem] select-none text-muted-foreground",
222
+ defaultClassNames.week_number
223
+ ),
224
+ day: cn(
225
+ "relative w-full h-full p-0 text-center [&:first-child[data-selected=true]_button]:rounded-l-md [&:last-child[data-selected=true]_button]:rounded-r-md group/day aspect-square select-none",
226
+ defaultClassNames.day
227
+ ),
228
+ range_start: cn(
229
+ "rounded-l-md bg-accent",
230
+ defaultClassNames.range_start
231
+ ),
232
+ range_middle: cn("rounded-none", defaultClassNames.range_middle),
233
+ range_end: cn("rounded-r-md bg-accent", defaultClassNames.range_end),
234
+ today: cn(
235
+ "bg-accent text-accent-foreground rounded-md data-[selected=true]:rounded-none",
236
+ defaultClassNames.today
237
+ ),
238
+ outside: cn(
239
+ "text-muted-foreground aria-selected:text-muted-foreground",
240
+ defaultClassNames.outside
241
+ ),
242
+ disabled: cn(
243
+ "text-muted-foreground opacity-50",
244
+ defaultClassNames.disabled
245
+ ),
246
+ hidden: cn("invisible", defaultClassNames.hidden)
247
+ }, classNames),
248
+ components: __spreadValues({
249
+ Root: (_a2) => {
250
+ var _b2 = _a2, { className: className2, rootRef } = _b2, props2 = __objRest(_b2, ["className", "rootRef"]);
251
+ return /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
252
+ "div",
253
+ __spreadValues({
254
+ "data-slot": "calendar",
255
+ ref: rootRef,
256
+ className: cn(className2)
257
+ }, props2)
258
+ );
259
+ },
260
+ Chevron: (_c) => {
261
+ var _d = _c, { className: className2, orientation } = _d, props2 = __objRest(_d, ["className", "orientation"]);
262
+ if (orientation === "left") {
263
+ return /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(import_lucide_react.ChevronLeftIcon, __spreadValues({ className: cn("size-4", className2) }, props2));
264
+ }
265
+ if (orientation === "right") {
266
+ return /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
267
+ import_lucide_react.ChevronRightIcon,
268
+ __spreadValues({
269
+ className: cn("size-4", className2)
270
+ }, props2)
271
+ );
272
+ }
273
+ return /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(import_lucide_react.ChevronDownIcon, __spreadValues({ className: cn("size-4", className2) }, props2));
274
+ },
275
+ DayButton: CalendarDayButton,
276
+ WeekNumber: (_e) => {
277
+ var _f = _e, { children } = _f, props2 = __objRest(_f, ["children"]);
278
+ return /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("td", __spreadProps(__spreadValues({}, props2), { children: /* @__PURE__ */ (0, import_jsx_runtime2.jsx)("div", { className: "flex size-(--cell-size) items-center justify-center text-center", children }) }));
279
+ }
280
+ }, components)
281
+ }, props)
282
+ );
283
+ }
284
+ function CalendarDayButton(_a) {
285
+ var _b = _a, {
286
+ className,
287
+ day,
288
+ modifiers
289
+ } = _b, props = __objRest(_b, [
290
+ "className",
291
+ "day",
292
+ "modifiers"
293
+ ]);
294
+ const defaultClassNames = (0, import_react_day_picker.getDefaultClassNames)();
295
+ const ref = React.useRef(null);
296
+ React.useEffect(() => {
297
+ var _a2;
298
+ if (modifiers.focused) (_a2 = ref.current) == null ? void 0 : _a2.focus();
299
+ }, [modifiers.focused]);
300
+ return /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(
301
+ Button,
302
+ __spreadValues({
303
+ ref,
304
+ variant: "ghost",
305
+ size: "icon",
306
+ "data-day": day.date.toLocaleDateString(),
307
+ "data-selected-single": modifiers.selected && !modifiers.range_start && !modifiers.range_end && !modifiers.range_middle,
308
+ "data-range-start": modifiers.range_start,
309
+ "data-range-end": modifiers.range_end,
310
+ "data-range-middle": modifiers.range_middle,
311
+ className: cn(
312
+ "data-[selected-single=true]:bg-primary data-[selected-single=true]:text-primary-foreground data-[range-middle=true]:bg-accent data-[range-middle=true]:text-accent-foreground data-[range-start=true]:bg-primary data-[range-start=true]:text-primary-foreground data-[range-end=true]:bg-primary data-[range-end=true]:text-primary-foreground group-data-[focused=true]/day:border-ring group-data-[focused=true]/day:ring-ring/50 dark:hover:text-accent-foreground flex aspect-square size-auto w-full min-w-(--cell-size) flex-col gap-1 leading-none font-normal group-data-[focused=true]/day:relative group-data-[focused=true]/day:z-10 group-data-[focused=true]/day:ring-[3px] data-[range-end=true]:rounded-md data-[range-end=true]:rounded-r-md data-[range-middle=true]:rounded-none data-[range-start=true]:rounded-md data-[range-start=true]:rounded-l-md [&>span]:text-xs [&>span]:opacity-70",
313
+ defaultClassNames.day,
314
+ className
315
+ )
316
+ }, props)
317
+ );
318
+ }
319
+ // Annotate the CommonJS export names for ESM import in node:
320
+ 0 && (module.exports = {
321
+ Calendar,
322
+ CalendarDayButton
323
+ });
324
+ //# sourceMappingURL=calendar.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../../lib/components/calendar.tsx","../../lib/utils/utils.ts","../../lib/components/button.tsx"],"sourcesContent":["\"use client\"\n\nimport * as React from \"react\"\nimport {\n ChevronDownIcon,\n ChevronLeftIcon,\n ChevronRightIcon,\n} from \"lucide-react\"\nimport { DayButton, DayPicker, getDefaultClassNames } from \"react-day-picker\"\n\nimport { cn } from \"../utils/utils\"\nimport { Button, buttonVariants } from \"./button\"\n\nfunction Calendar({\n className,\n classNames,\n showOutsideDays = true,\n captionLayout = \"label\",\n buttonVariant = \"ghost\",\n formatters,\n components,\n ...props\n}: React.ComponentProps<typeof DayPicker> & {\n buttonVariant?: React.ComponentProps<typeof Button>[\"variant\"]\n}) {\n const defaultClassNames = getDefaultClassNames()\n\n return (\n <DayPicker\n showOutsideDays={showOutsideDays}\n className={cn(\n \"bg-background group/calendar p-3 [--cell-size:--spacing(8)] [[data-slot=card-content]_&]:bg-transparent [[data-slot=popover-content]_&]:bg-transparent\",\n String.raw`rtl:**:[.rdp-button\\_next>svg]:rotate-180`,\n String.raw`rtl:**:[.rdp-button\\_previous>svg]:rotate-180`,\n className\n )}\n captionLayout={captionLayout}\n formatters={{\n formatMonthDropdown: (date) =>\n date.toLocaleString(\"default\", { month: \"short\" }),\n ...formatters,\n }}\n classNames={{\n root: cn(\"w-fit\", defaultClassNames.root),\n months: cn(\n \"flex gap-4 flex-col md:flex-row relative\",\n defaultClassNames.months\n ),\n month: cn(\"flex flex-col w-full gap-4\", defaultClassNames.month),\n nav: cn(\n \"flex items-center gap-1 w-full absolute top-0 inset-x-0 justify-between\",\n defaultClassNames.nav\n ),\n button_previous: cn(\n buttonVariants({ variant: buttonVariant }),\n \"size-(--cell-size) aria-disabled:opacity-50 p-0 select-none\",\n defaultClassNames.button_previous\n ),\n button_next: cn(\n buttonVariants({ variant: buttonVariant }),\n \"size-(--cell-size) aria-disabled:opacity-50 p-0 select-none\",\n defaultClassNames.button_next\n ),\n month_caption: cn(\n \"flex items-center justify-center h-(--cell-size) w-full px-(--cell-size)\",\n defaultClassNames.month_caption\n ),\n dropdowns: cn(\n \"w-full flex items-center text-sm font-medium justify-center h-(--cell-size) gap-1.5\",\n defaultClassNames.dropdowns\n ),\n dropdown_root: cn(\n \"relative has-focus:border-ring border border-input shadow-xs has-focus:ring-ring/50 has-focus:ring-[3px] rounded-md\",\n defaultClassNames.dropdown_root\n ),\n dropdown: cn(\n \"absolute bg-popover inset-0 opacity-0\",\n defaultClassNames.dropdown\n ),\n caption_label: cn(\n \"select-none font-medium\",\n captionLayout === \"label\"\n ? \"text-sm\"\n : \"rounded-md pl-2 pr-1 flex items-center gap-1 text-sm h-8 [&>svg]:text-muted-foreground [&>svg]:size-3.5\",\n defaultClassNames.caption_label\n ),\n table: \"w-full border-collapse\",\n weekdays: cn(\"flex\", defaultClassNames.weekdays),\n weekday: cn(\n \"text-muted-foreground rounded-md flex-1 font-normal text-[0.8rem] select-none\",\n defaultClassNames.weekday\n ),\n week: cn(\"flex w-full mt-2\", defaultClassNames.week),\n week_number_header: cn(\n \"select-none w-(--cell-size)\",\n defaultClassNames.week_number_header\n ),\n week_number: cn(\n \"text-[0.8rem] select-none text-muted-foreground\",\n defaultClassNames.week_number\n ),\n day: cn(\n \"relative w-full h-full p-0 text-center [&:first-child[data-selected=true]_button]:rounded-l-md [&:last-child[data-selected=true]_button]:rounded-r-md group/day aspect-square select-none\",\n defaultClassNames.day\n ),\n range_start: cn(\n \"rounded-l-md bg-accent\",\n defaultClassNames.range_start\n ),\n range_middle: cn(\"rounded-none\", defaultClassNames.range_middle),\n range_end: cn(\"rounded-r-md bg-accent\", defaultClassNames.range_end),\n today: cn(\n \"bg-accent text-accent-foreground rounded-md data-[selected=true]:rounded-none\",\n defaultClassNames.today\n ),\n outside: cn(\n \"text-muted-foreground aria-selected:text-muted-foreground\",\n defaultClassNames.outside\n ),\n disabled: cn(\n \"text-muted-foreground opacity-50\",\n defaultClassNames.disabled\n ),\n hidden: cn(\"invisible\", defaultClassNames.hidden),\n ...classNames,\n }}\n components={{\n Root: ({ className, rootRef, ...props }) => {\n return (\n <div\n data-slot=\"calendar\"\n ref={rootRef}\n className={cn(className)}\n {...props}\n />\n )\n },\n Chevron: ({ className, orientation, ...props }) => {\n if (orientation === \"left\") {\n return (\n <ChevronLeftIcon className={cn(\"size-4\", className)} {...props} />\n )\n }\n\n if (orientation === \"right\") {\n return (\n <ChevronRightIcon\n className={cn(\"size-4\", className)}\n {...props}\n />\n )\n }\n\n return (\n <ChevronDownIcon className={cn(\"size-4\", className)} {...props} />\n )\n },\n DayButton: CalendarDayButton,\n WeekNumber: ({ children, ...props }) => {\n return (\n <td {...props}>\n <div className=\"flex size-(--cell-size) items-center justify-center text-center\">\n {children}\n </div>\n </td>\n )\n },\n ...components,\n }}\n {...props}\n />\n )\n}\n\nfunction CalendarDayButton({\n className,\n day,\n modifiers,\n ...props\n}: React.ComponentProps<typeof DayButton>) {\n const defaultClassNames = getDefaultClassNames()\n\n const ref = React.useRef<HTMLButtonElement>(null)\n React.useEffect(() => {\n if (modifiers.focused) ref.current?.focus()\n }, [modifiers.focused])\n\n return (\n <Button\n ref={ref}\n variant=\"ghost\"\n size=\"icon\"\n data-day={day.date.toLocaleDateString()}\n data-selected-single={\n modifiers.selected &&\n !modifiers.range_start &&\n !modifiers.range_end &&\n !modifiers.range_middle\n }\n data-range-start={modifiers.range_start}\n data-range-end={modifiers.range_end}\n data-range-middle={modifiers.range_middle}\n className={cn(\n \"data-[selected-single=true]:bg-primary data-[selected-single=true]:text-primary-foreground data-[range-middle=true]:bg-accent data-[range-middle=true]:text-accent-foreground data-[range-start=true]:bg-primary data-[range-start=true]:text-primary-foreground data-[range-end=true]:bg-primary data-[range-end=true]:text-primary-foreground group-data-[focused=true]/day:border-ring group-data-[focused=true]/day:ring-ring/50 dark:hover:text-accent-foreground flex aspect-square size-auto w-full min-w-(--cell-size) flex-col gap-1 leading-none font-normal group-data-[focused=true]/day:relative group-data-[focused=true]/day:z-10 group-data-[focused=true]/day:ring-[3px] data-[range-end=true]:rounded-md data-[range-end=true]:rounded-r-md data-[range-middle=true]:rounded-none data-[range-start=true]:rounded-md data-[range-start=true]:rounded-l-md [&>span]:text-xs [&>span]:opacity-70\",\n defaultClassNames.day,\n className\n )}\n {...props}\n />\n )\n}\n\nexport { Calendar, CalendarDayButton }\n","import { clsx, type ClassValue } from \"clsx\"\nimport { twMerge } from \"tailwind-merge\"\n\nexport function cn(...inputs: ClassValue[]) {\n return twMerge(clsx(inputs))\n}","import * as React from \"react\"\nimport { Slot } from \"@radix-ui/react-slot\"\nimport { cva, type VariantProps } from \"class-variance-authority\"\n\nimport { cn } from \"../utils/utils\"\n\nconst buttonVariants = cva(\n \"inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium transition-all disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg:not([class*='size-'])]:size-4 shrink-0 [&_svg]:shrink-0 outline-none focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px] aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive\",\n {\n variants: {\n variant: {\n default: \"bg-primary text-primary-foreground hover:bg-primary/90\",\n destructive:\n \"bg-destructive text-white hover:bg-destructive/90 focus-visible:ring-destructive/20 dark:focus-visible:ring-destructive/40 dark:bg-destructive/60\",\n outline:\n \"border bg-background hover:bg-accent hover:text-accent-foreground dark:border-border dark:hover:bg-input/50\",\n secondary:\n \"bg-secondary text-secondary-foreground hover:bg-secondary/80\",\n ghost:\n \"hover:bg-accent hover:text-accent-foreground dark:hover:bg-accent/50\",\n link: \"text-primary underline-offset-4 hover:underline\",\n },\n size: {\n default: \"h-9 px-4 py-2 has-[>svg]:px-3\",\n sm: \"h-8 rounded-md gap-1.5 px-3 has-[>svg]:px-2.5\",\n lg: \"h-10 rounded-md px-6 has-[>svg]:px-4\",\n icon: \"size-9\",\n \"icon-sm\": \"size-8\",\n \"icon-lg\": \"size-10\",\n },\n },\n defaultVariants: {\n variant: \"default\",\n size: \"default\",\n },\n }\n)\n\nfunction Button({\n className,\n variant,\n size,\n asChild = false,\n ...props\n}: React.ComponentProps<\"button\"> &\n VariantProps<typeof buttonVariants> & {\n asChild?: boolean\n }) {\n const Comp = asChild ? Slot : \"button\"\n\n return (\n <Comp\n data-slot=\"button\"\n className={cn(buttonVariants({ variant, size, className }))}\n {...props}\n />\n )\n}\n\nexport { Button, buttonVariants }\n"],"mappings":"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","names":["import_jsx_runtime","_a","_b","className","props"]}
@@ -0,0 +1,295 @@
1
+ "use client";
2
+ "use client";
3
+ var __defProp = Object.defineProperty;
4
+ var __defProps = Object.defineProperties;
5
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
6
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
7
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
8
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
9
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
10
+ var __spreadValues = (a, b) => {
11
+ for (var prop in b || (b = {}))
12
+ if (__hasOwnProp.call(b, prop))
13
+ __defNormalProp(a, prop, b[prop]);
14
+ if (__getOwnPropSymbols)
15
+ for (var prop of __getOwnPropSymbols(b)) {
16
+ if (__propIsEnum.call(b, prop))
17
+ __defNormalProp(a, prop, b[prop]);
18
+ }
19
+ return a;
20
+ };
21
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
22
+ var __objRest = (source, exclude) => {
23
+ var target = {};
24
+ for (var prop in source)
25
+ if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
26
+ target[prop] = source[prop];
27
+ if (source != null && __getOwnPropSymbols)
28
+ for (var prop of __getOwnPropSymbols(source)) {
29
+ if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
30
+ target[prop] = source[prop];
31
+ }
32
+ return target;
33
+ };
34
+
35
+ // lib/components/calendar.tsx
36
+ import * as React from "react";
37
+ import {
38
+ ChevronDownIcon,
39
+ ChevronLeftIcon,
40
+ ChevronRightIcon
41
+ } from "lucide-react";
42
+ import { DayPicker, getDefaultClassNames } from "react-day-picker";
43
+
44
+ // lib/utils/utils.ts
45
+ import { clsx } from "clsx";
46
+ import { twMerge } from "tailwind-merge";
47
+ function cn(...inputs) {
48
+ return twMerge(clsx(inputs));
49
+ }
50
+
51
+ // lib/components/button.tsx
52
+ import { Slot } from "@radix-ui/react-slot";
53
+ import { cva } from "class-variance-authority";
54
+ import { jsx } from "react/jsx-runtime";
55
+ var buttonVariants = cva(
56
+ "inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium transition-all disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg:not([class*='size-'])]:size-4 shrink-0 [&_svg]:shrink-0 outline-none focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:ring-[3px] aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 aria-invalid:border-destructive",
57
+ {
58
+ variants: {
59
+ variant: {
60
+ default: "bg-primary text-primary-foreground hover:bg-primary/90",
61
+ destructive: "bg-destructive text-white hover:bg-destructive/90 focus-visible:ring-destructive/20 dark:focus-visible:ring-destructive/40 dark:bg-destructive/60",
62
+ outline: "border bg-background hover:bg-accent hover:text-accent-foreground dark:border-border dark:hover:bg-input/50",
63
+ secondary: "bg-secondary text-secondary-foreground hover:bg-secondary/80",
64
+ ghost: "hover:bg-accent hover:text-accent-foreground dark:hover:bg-accent/50",
65
+ link: "text-primary underline-offset-4 hover:underline"
66
+ },
67
+ size: {
68
+ default: "h-9 px-4 py-2 has-[>svg]:px-3",
69
+ sm: "h-8 rounded-md gap-1.5 px-3 has-[>svg]:px-2.5",
70
+ lg: "h-10 rounded-md px-6 has-[>svg]:px-4",
71
+ icon: "size-9",
72
+ "icon-sm": "size-8",
73
+ "icon-lg": "size-10"
74
+ }
75
+ },
76
+ defaultVariants: {
77
+ variant: "default",
78
+ size: "default"
79
+ }
80
+ }
81
+ );
82
+ function Button(_a) {
83
+ var _b = _a, {
84
+ className,
85
+ variant,
86
+ size,
87
+ asChild = false
88
+ } = _b, props = __objRest(_b, [
89
+ "className",
90
+ "variant",
91
+ "size",
92
+ "asChild"
93
+ ]);
94
+ const Comp = asChild ? Slot : "button";
95
+ return /* @__PURE__ */ jsx(
96
+ Comp,
97
+ __spreadValues({
98
+ "data-slot": "button",
99
+ className: cn(buttonVariants({ variant, size, className }))
100
+ }, props)
101
+ );
102
+ }
103
+
104
+ // lib/components/calendar.tsx
105
+ import { jsx as jsx2 } from "react/jsx-runtime";
106
+ function Calendar(_a) {
107
+ var _b = _a, {
108
+ className,
109
+ classNames,
110
+ showOutsideDays = true,
111
+ captionLayout = "label",
112
+ buttonVariant = "ghost",
113
+ formatters,
114
+ components
115
+ } = _b, props = __objRest(_b, [
116
+ "className",
117
+ "classNames",
118
+ "showOutsideDays",
119
+ "captionLayout",
120
+ "buttonVariant",
121
+ "formatters",
122
+ "components"
123
+ ]);
124
+ const defaultClassNames = getDefaultClassNames();
125
+ return /* @__PURE__ */ jsx2(
126
+ DayPicker,
127
+ __spreadValues({
128
+ showOutsideDays,
129
+ className: cn(
130
+ "bg-background group/calendar p-3 [--cell-size:--spacing(8)] [[data-slot=card-content]_&]:bg-transparent [[data-slot=popover-content]_&]:bg-transparent",
131
+ String.raw`rtl:**:[.rdp-button\_next>svg]:rotate-180`,
132
+ String.raw`rtl:**:[.rdp-button\_previous>svg]:rotate-180`,
133
+ className
134
+ ),
135
+ captionLayout,
136
+ formatters: __spreadValues({
137
+ formatMonthDropdown: (date) => date.toLocaleString("default", { month: "short" })
138
+ }, formatters),
139
+ classNames: __spreadValues({
140
+ root: cn("w-fit", defaultClassNames.root),
141
+ months: cn(
142
+ "flex gap-4 flex-col md:flex-row relative",
143
+ defaultClassNames.months
144
+ ),
145
+ month: cn("flex flex-col w-full gap-4", defaultClassNames.month),
146
+ nav: cn(
147
+ "flex items-center gap-1 w-full absolute top-0 inset-x-0 justify-between",
148
+ defaultClassNames.nav
149
+ ),
150
+ button_previous: cn(
151
+ buttonVariants({ variant: buttonVariant }),
152
+ "size-(--cell-size) aria-disabled:opacity-50 p-0 select-none",
153
+ defaultClassNames.button_previous
154
+ ),
155
+ button_next: cn(
156
+ buttonVariants({ variant: buttonVariant }),
157
+ "size-(--cell-size) aria-disabled:opacity-50 p-0 select-none",
158
+ defaultClassNames.button_next
159
+ ),
160
+ month_caption: cn(
161
+ "flex items-center justify-center h-(--cell-size) w-full px-(--cell-size)",
162
+ defaultClassNames.month_caption
163
+ ),
164
+ dropdowns: cn(
165
+ "w-full flex items-center text-sm font-medium justify-center h-(--cell-size) gap-1.5",
166
+ defaultClassNames.dropdowns
167
+ ),
168
+ dropdown_root: cn(
169
+ "relative has-focus:border-ring border border-input shadow-xs has-focus:ring-ring/50 has-focus:ring-[3px] rounded-md",
170
+ defaultClassNames.dropdown_root
171
+ ),
172
+ dropdown: cn(
173
+ "absolute bg-popover inset-0 opacity-0",
174
+ defaultClassNames.dropdown
175
+ ),
176
+ caption_label: cn(
177
+ "select-none font-medium",
178
+ captionLayout === "label" ? "text-sm" : "rounded-md pl-2 pr-1 flex items-center gap-1 text-sm h-8 [&>svg]:text-muted-foreground [&>svg]:size-3.5",
179
+ defaultClassNames.caption_label
180
+ ),
181
+ table: "w-full border-collapse",
182
+ weekdays: cn("flex", defaultClassNames.weekdays),
183
+ weekday: cn(
184
+ "text-muted-foreground rounded-md flex-1 font-normal text-[0.8rem] select-none",
185
+ defaultClassNames.weekday
186
+ ),
187
+ week: cn("flex w-full mt-2", defaultClassNames.week),
188
+ week_number_header: cn(
189
+ "select-none w-(--cell-size)",
190
+ defaultClassNames.week_number_header
191
+ ),
192
+ week_number: cn(
193
+ "text-[0.8rem] select-none text-muted-foreground",
194
+ defaultClassNames.week_number
195
+ ),
196
+ day: cn(
197
+ "relative w-full h-full p-0 text-center [&:first-child[data-selected=true]_button]:rounded-l-md [&:last-child[data-selected=true]_button]:rounded-r-md group/day aspect-square select-none",
198
+ defaultClassNames.day
199
+ ),
200
+ range_start: cn(
201
+ "rounded-l-md bg-accent",
202
+ defaultClassNames.range_start
203
+ ),
204
+ range_middle: cn("rounded-none", defaultClassNames.range_middle),
205
+ range_end: cn("rounded-r-md bg-accent", defaultClassNames.range_end),
206
+ today: cn(
207
+ "bg-accent text-accent-foreground rounded-md data-[selected=true]:rounded-none",
208
+ defaultClassNames.today
209
+ ),
210
+ outside: cn(
211
+ "text-muted-foreground aria-selected:text-muted-foreground",
212
+ defaultClassNames.outside
213
+ ),
214
+ disabled: cn(
215
+ "text-muted-foreground opacity-50",
216
+ defaultClassNames.disabled
217
+ ),
218
+ hidden: cn("invisible", defaultClassNames.hidden)
219
+ }, classNames),
220
+ components: __spreadValues({
221
+ Root: (_a2) => {
222
+ var _b2 = _a2, { className: className2, rootRef } = _b2, props2 = __objRest(_b2, ["className", "rootRef"]);
223
+ return /* @__PURE__ */ jsx2(
224
+ "div",
225
+ __spreadValues({
226
+ "data-slot": "calendar",
227
+ ref: rootRef,
228
+ className: cn(className2)
229
+ }, props2)
230
+ );
231
+ },
232
+ Chevron: (_c) => {
233
+ var _d = _c, { className: className2, orientation } = _d, props2 = __objRest(_d, ["className", "orientation"]);
234
+ if (orientation === "left") {
235
+ return /* @__PURE__ */ jsx2(ChevronLeftIcon, __spreadValues({ className: cn("size-4", className2) }, props2));
236
+ }
237
+ if (orientation === "right") {
238
+ return /* @__PURE__ */ jsx2(
239
+ ChevronRightIcon,
240
+ __spreadValues({
241
+ className: cn("size-4", className2)
242
+ }, props2)
243
+ );
244
+ }
245
+ return /* @__PURE__ */ jsx2(ChevronDownIcon, __spreadValues({ className: cn("size-4", className2) }, props2));
246
+ },
247
+ DayButton: CalendarDayButton,
248
+ WeekNumber: (_e) => {
249
+ var _f = _e, { children } = _f, props2 = __objRest(_f, ["children"]);
250
+ return /* @__PURE__ */ jsx2("td", __spreadProps(__spreadValues({}, props2), { children: /* @__PURE__ */ jsx2("div", { className: "flex size-(--cell-size) items-center justify-center text-center", children }) }));
251
+ }
252
+ }, components)
253
+ }, props)
254
+ );
255
+ }
256
+ function CalendarDayButton(_a) {
257
+ var _b = _a, {
258
+ className,
259
+ day,
260
+ modifiers
261
+ } = _b, props = __objRest(_b, [
262
+ "className",
263
+ "day",
264
+ "modifiers"
265
+ ]);
266
+ const defaultClassNames = getDefaultClassNames();
267
+ const ref = React.useRef(null);
268
+ React.useEffect(() => {
269
+ var _a2;
270
+ if (modifiers.focused) (_a2 = ref.current) == null ? void 0 : _a2.focus();
271
+ }, [modifiers.focused]);
272
+ return /* @__PURE__ */ jsx2(
273
+ Button,
274
+ __spreadValues({
275
+ ref,
276
+ variant: "ghost",
277
+ size: "icon",
278
+ "data-day": day.date.toLocaleDateString(),
279
+ "data-selected-single": modifiers.selected && !modifiers.range_start && !modifiers.range_end && !modifiers.range_middle,
280
+ "data-range-start": modifiers.range_start,
281
+ "data-range-end": modifiers.range_end,
282
+ "data-range-middle": modifiers.range_middle,
283
+ className: cn(
284
+ "data-[selected-single=true]:bg-primary data-[selected-single=true]:text-primary-foreground data-[range-middle=true]:bg-accent data-[range-middle=true]:text-accent-foreground data-[range-start=true]:bg-primary data-[range-start=true]:text-primary-foreground data-[range-end=true]:bg-primary data-[range-end=true]:text-primary-foreground group-data-[focused=true]/day:border-ring group-data-[focused=true]/day:ring-ring/50 dark:hover:text-accent-foreground flex aspect-square size-auto w-full min-w-(--cell-size) flex-col gap-1 leading-none font-normal group-data-[focused=true]/day:relative group-data-[focused=true]/day:z-10 group-data-[focused=true]/day:ring-[3px] data-[range-end=true]:rounded-md data-[range-end=true]:rounded-r-md data-[range-middle=true]:rounded-none data-[range-start=true]:rounded-md data-[range-start=true]:rounded-l-md [&>span]:text-xs [&>span]:opacity-70",
285
+ defaultClassNames.day,
286
+ className
287
+ )
288
+ }, props)
289
+ );
290
+ }
291
+ export {
292
+ Calendar,
293
+ CalendarDayButton
294
+ };
295
+ //# sourceMappingURL=calendar.mjs.map