liquidcn 0.0.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 (148) hide show
  1. package/LICENSE.md +201 -0
  2. package/README.md +209 -0
  3. package/dist/cjs/client/components/index.js +18 -0
  4. package/dist/cjs/client/components/index.js.map +1 -0
  5. package/dist/cjs/client/components/ui/dialog.js +48 -0
  6. package/dist/cjs/client/components/ui/dialog.js.map +1 -0
  7. package/dist/cjs/client/components/ui/index.js +24 -0
  8. package/dist/cjs/client/components/ui/index.js.map +1 -0
  9. package/dist/cjs/client/components/ui/pretty-date.js +91 -0
  10. package/dist/cjs/client/components/ui/pretty-date.js.map +1 -0
  11. package/dist/cjs/client/components/ui/resizable-navbar.js +126 -0
  12. package/dist/cjs/client/components/ui/resizable-navbar.js.map +1 -0
  13. package/dist/cjs/client/components/ui/select.js +50 -0
  14. package/dist/cjs/client/components/ui/select.js.map +1 -0
  15. package/dist/cjs/client/components/ui/sonner.js +12 -0
  16. package/dist/cjs/client/components/ui/sonner.js.map +1 -0
  17. package/dist/cjs/client/components/ui/switch.js +11 -0
  18. package/dist/cjs/client/components/ui/switch.js.map +1 -0
  19. package/dist/cjs/client/components/ui/tabs.js +53 -0
  20. package/dist/cjs/client/components/ui/tabs.js.map +1 -0
  21. package/dist/cjs/client/hooks/index.js +18 -0
  22. package/dist/cjs/client/hooks/index.js.map +1 -0
  23. package/dist/cjs/client/hooks/use-cookie-with-fallback.js +107 -0
  24. package/dist/cjs/client/hooks/use-cookie-with-fallback.js.map +1 -0
  25. package/dist/cjs/client/index.js +19 -0
  26. package/dist/cjs/client/index.js.map +1 -0
  27. package/dist/cjs/components/index.js +18 -0
  28. package/dist/cjs/components/index.js.map +1 -0
  29. package/dist/cjs/components/ui/alert.js +33 -0
  30. package/dist/cjs/components/ui/alert.js.map +1 -0
  31. package/dist/cjs/components/ui/badge.js +28 -0
  32. package/dist/cjs/components/ui/badge.js.map +1 -0
  33. package/dist/cjs/components/ui/button.js +39 -0
  34. package/dist/cjs/components/ui/button.js.map +1 -0
  35. package/dist/cjs/components/ui/card.js +48 -0
  36. package/dist/cjs/components/ui/card.js.map +1 -0
  37. package/dist/cjs/components/ui/footer.js +9 -0
  38. package/dist/cjs/components/ui/footer.js.map +1 -0
  39. package/dist/cjs/components/ui/index.js +25 -0
  40. package/dist/cjs/components/ui/index.js.map +1 -0
  41. package/dist/cjs/components/ui/input.js +12 -0
  42. package/dist/cjs/components/ui/input.js.map +1 -0
  43. package/dist/cjs/components/ui/pretty-amount.js +167 -0
  44. package/dist/cjs/components/ui/pretty-amount.js.map +1 -0
  45. package/dist/cjs/components/ui/textarea.js +12 -0
  46. package/dist/cjs/components/ui/textarea.js.map +1 -0
  47. package/dist/cjs/index.js +19 -0
  48. package/dist/cjs/index.js.map +1 -0
  49. package/dist/cjs/utils.js +9 -0
  50. package/dist/cjs/utils.js.map +1 -0
  51. package/dist/esm/client/components/index.js +2 -0
  52. package/dist/esm/client/components/index.js.map +1 -0
  53. package/dist/esm/client/components/ui/dialog.js +37 -0
  54. package/dist/esm/client/components/ui/dialog.js.map +1 -0
  55. package/dist/esm/client/components/ui/index.js +8 -0
  56. package/dist/esm/client/components/ui/index.js.map +1 -0
  57. package/dist/esm/client/components/ui/pretty-date.js +88 -0
  58. package/dist/esm/client/components/ui/pretty-date.js.map +1 -0
  59. package/dist/esm/client/components/ui/resizable-navbar.js +113 -0
  60. package/dist/esm/client/components/ui/resizable-navbar.js.map +1 -0
  61. package/dist/esm/client/components/ui/select.js +39 -0
  62. package/dist/esm/client/components/ui/select.js.map +1 -0
  63. package/dist/esm/client/components/ui/sonner.js +9 -0
  64. package/dist/esm/client/components/ui/sonner.js.map +1 -0
  65. package/dist/esm/client/components/ui/switch.js +9 -0
  66. package/dist/esm/client/components/ui/switch.js.map +1 -0
  67. package/dist/esm/client/components/ui/tabs.js +47 -0
  68. package/dist/esm/client/components/ui/tabs.js.map +1 -0
  69. package/dist/esm/client/hooks/index.js +2 -0
  70. package/dist/esm/client/hooks/index.js.map +1 -0
  71. package/dist/esm/client/hooks/use-cookie-with-fallback.js +104 -0
  72. package/dist/esm/client/hooks/use-cookie-with-fallback.js.map +1 -0
  73. package/dist/esm/client/index.js +3 -0
  74. package/dist/esm/client/index.js.map +1 -0
  75. package/dist/esm/components/index.js +2 -0
  76. package/dist/esm/components/index.js.map +1 -0
  77. package/dist/esm/components/ui/alert.js +30 -0
  78. package/dist/esm/components/ui/alert.js.map +1 -0
  79. package/dist/esm/components/ui/badge.js +25 -0
  80. package/dist/esm/components/ui/badge.js.map +1 -0
  81. package/dist/esm/components/ui/button.js +36 -0
  82. package/dist/esm/components/ui/button.js.map +1 -0
  83. package/dist/esm/components/ui/card.js +41 -0
  84. package/dist/esm/components/ui/card.js.map +1 -0
  85. package/dist/esm/components/ui/footer.js +6 -0
  86. package/dist/esm/components/ui/footer.js.map +1 -0
  87. package/dist/esm/components/ui/index.js +9 -0
  88. package/dist/esm/components/ui/index.js.map +1 -0
  89. package/dist/esm/components/ui/input.js +11 -0
  90. package/dist/esm/components/ui/input.js.map +1 -0
  91. package/dist/esm/components/ui/pretty-amount.js +164 -0
  92. package/dist/esm/components/ui/pretty-amount.js.map +1 -0
  93. package/dist/esm/components/ui/textarea.js +11 -0
  94. package/dist/esm/components/ui/textarea.js.map +1 -0
  95. package/dist/esm/index.js +3 -0
  96. package/dist/esm/index.js.map +1 -0
  97. package/dist/esm/utils.js +6 -0
  98. package/dist/esm/utils.js.map +1 -0
  99. package/dist/styles.css +563 -0
  100. package/dist/types/client/components/index.d.ts +2 -0
  101. package/dist/types/client/components/index.d.ts.map +1 -0
  102. package/dist/types/client/components/ui/dialog.d.ts +16 -0
  103. package/dist/types/client/components/ui/dialog.d.ts.map +1 -0
  104. package/dist/types/client/components/ui/index.d.ts +8 -0
  105. package/dist/types/client/components/ui/index.d.ts.map +1 -0
  106. package/dist/types/client/components/ui/pretty-date.d.ts +30 -0
  107. package/dist/types/client/components/ui/pretty-date.d.ts.map +1 -0
  108. package/dist/types/client/components/ui/resizable-navbar.d.ts +84 -0
  109. package/dist/types/client/components/ui/resizable-navbar.d.ts.map +1 -0
  110. package/dist/types/client/components/ui/select.d.ts +16 -0
  111. package/dist/types/client/components/ui/select.d.ts.map +1 -0
  112. package/dist/types/client/components/ui/sonner.d.ts +6 -0
  113. package/dist/types/client/components/ui/sonner.d.ts.map +1 -0
  114. package/dist/types/client/components/ui/switch.d.ts +5 -0
  115. package/dist/types/client/components/ui/switch.d.ts.map +1 -0
  116. package/dist/types/client/components/ui/tabs.d.ts +11 -0
  117. package/dist/types/client/components/ui/tabs.d.ts.map +1 -0
  118. package/dist/types/client/hooks/index.d.ts +2 -0
  119. package/dist/types/client/hooks/index.d.ts.map +1 -0
  120. package/dist/types/client/hooks/use-cookie-with-fallback.d.ts +20 -0
  121. package/dist/types/client/hooks/use-cookie-with-fallback.d.ts.map +1 -0
  122. package/dist/types/client/index.d.ts +3 -0
  123. package/dist/types/client/index.d.ts.map +1 -0
  124. package/dist/types/components/index.d.ts +2 -0
  125. package/dist/types/components/index.d.ts.map +1 -0
  126. package/dist/types/components/ui/alert.d.ts +21 -0
  127. package/dist/types/components/ui/alert.d.ts.map +1 -0
  128. package/dist/types/components/ui/badge.d.ts +10 -0
  129. package/dist/types/components/ui/badge.d.ts.map +1 -0
  130. package/dist/types/components/ui/button.d.ts +16 -0
  131. package/dist/types/components/ui/button.d.ts.map +1 -0
  132. package/dist/types/components/ui/card.d.ts +26 -0
  133. package/dist/types/components/ui/card.d.ts.map +1 -0
  134. package/dist/types/components/ui/footer.d.ts +25 -0
  135. package/dist/types/components/ui/footer.d.ts.map +1 -0
  136. package/dist/types/components/ui/index.d.ts +9 -0
  137. package/dist/types/components/ui/index.d.ts.map +1 -0
  138. package/dist/types/components/ui/input.d.ts +10 -0
  139. package/dist/types/components/ui/input.d.ts.map +1 -0
  140. package/dist/types/components/ui/pretty-amount.d.ts +24 -0
  141. package/dist/types/components/ui/pretty-amount.d.ts.map +1 -0
  142. package/dist/types/components/ui/textarea.d.ts +10 -0
  143. package/dist/types/components/ui/textarea.d.ts.map +1 -0
  144. package/dist/types/index.d.ts +3 -0
  145. package/dist/types/index.d.ts.map +1 -0
  146. package/dist/types/utils.d.ts +3 -0
  147. package/dist/types/utils.d.ts.map +1 -0
  148. package/package.json +102 -0
@@ -0,0 +1,113 @@
1
+ "use client";
2
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
+ import { Slot } from "@radix-ui/react-slot";
4
+ import { Menu, X } from "lucide-react";
5
+ import { AnimatePresence, motion, useMotionValueEvent, useScroll } from "motion/react";
6
+ import React, { useRef, useState } from "react";
7
+ import { Button } from "../../../components/ui/button.js";
8
+ import { cn } from "../../../utils.js";
9
+ function getButtonClasses() {
10
+ return "px-4 py-2 rounded-md text-sm font-bold relative cursor-pointer hover:-translate-y-0.5 transition duration-200 inline-block text-center";
11
+ }
12
+ export const Navbar = ({ children, className, reverse, menuOpen }) => {
13
+ const ref = useRef(null);
14
+ const { scrollY } = useScroll({
15
+ target: ref,
16
+ offset: ["start start", "end start"],
17
+ });
18
+ const [visible, setVisible] = useState(false);
19
+ const [sticky, setSticky] = useState(true);
20
+ const prevScrollY = useRef(0);
21
+ useMotionValueEvent(scrollY, "change", (latest) => {
22
+ if (menuOpen)
23
+ return;
24
+ const previous = prevScrollY.current;
25
+ const isScrollingUp = latest < previous;
26
+ const threshold = !reverse ? 50 : 8;
27
+ if (latest > 20) {
28
+ setVisible(true);
29
+ }
30
+ else {
31
+ setVisible(false);
32
+ }
33
+ if (latest < threshold) {
34
+ setSticky(true);
35
+ }
36
+ else if (isScrollingUp && latest > 80) {
37
+ setSticky(true);
38
+ }
39
+ else if (!isScrollingUp && latest >= threshold) {
40
+ setSticky(false);
41
+ }
42
+ prevScrollY.current = latest;
43
+ });
44
+ const isSticky = menuOpen ? true : sticky;
45
+ return (_jsx(motion.div, { ref: ref, className: cn("sticky inset-x-0 top-4 z-40 w-full", className), animate: {
46
+ opacity: !isSticky ? 0 : 1,
47
+ y: !isSticky ? -100 : 0,
48
+ }, transition: {
49
+ duration: 0.6,
50
+ ease: [0.4, 0, 0.2, 1],
51
+ }, children: React.Children.map(children, (child) => React.isValidElement(child)
52
+ ? React.cloneElement(child, { visible })
53
+ : child) }));
54
+ };
55
+ export const NavBody = ({ children, className, visible }) => {
56
+ return (_jsxs(motion.div, { animate: {
57
+ width: visible ? "40%" : "100%",
58
+ y: visible ? 20 : 0,
59
+ }, transition: {
60
+ default: { duration: 0 },
61
+ width: { type: "spring", stiffness: 150, damping: 30 },
62
+ y: { type: "spring", stiffness: 150, damping: 30 },
63
+ }, style: {
64
+ minWidth: "800px",
65
+ }, className: cn("relative z-[60] mx-auto hidden w-full max-w-7xl flex-row items-center justify-between self-start px-4 py-2 lg:flex", className), children: [_jsx(AnimatePresence, { children: visible && (_jsx(motion.div, { initial: { opacity: 0 }, animate: { opacity: 1 }, exit: { opacity: 0 }, transition: { duration: 0.2 }, className: "absolute inset-0 liquid-glass rounded-full border border-white/20", children: _jsx("span", { className: "liquid-glass-content", "aria-hidden": "true" }) })) }), _jsx("div", { className: "relative z-10 flex w-full flex-row items-center justify-between", children: children })] }));
66
+ };
67
+ export const NavItems = ({ items, className, onItemClick, currentPath, LinkComponent, }) => {
68
+ const [hovered, setHovered] = useState(null);
69
+ const Link = LinkComponent || (({ href, ...props }) => _jsx("a", { href: href, ...props }));
70
+ return (_jsx(motion.div, { role: "menubar", onMouseLeave: () => setHovered(null), className: cn("absolute inset-0 hidden flex-1 flex-row items-center justify-center space-x-2 text-sm font-medium transition duration-200 lg:flex lg:space-x-2 text-white/90 hover:text-white", className), children: items.map((item, idx) => {
71
+ const isActive = currentPath === item.link;
72
+ return (_jsxs(Link, { href: item.link, onMouseEnter: () => setHovered(idx), onFocus: () => setHovered(idx), onBlur: () => setHovered((prev) => (prev === idx ? null : prev)), onClick: onItemClick, className: "group relative inline-flex items-center gap-1 px-4 py-2 text-sm font-medium transition-colors duration-200 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-white/50 focus-visible:ring-offset-transparent text-white/90 hover:text-white", children: [_jsx("span", { className: "relative z-20", children: item.name }), _jsx(AnimatePresence, { children: (hovered === idx || isActive) && (_jsx(motion.span, { layoutId: "nav-underline", className: "pointer-events-none absolute inset-x-3 bottom-1 h-[2px] origin-center rounded-full bg-white/70", initial: { opacity: 0, scaleX: 0 }, animate: {
73
+ opacity: hovered === idx || isActive ? 1 : 0.2,
74
+ scaleX: hovered === idx || isActive ? 1 : 0.8,
75
+ }, exit: { opacity: 0, scaleX: 0 }, transition: { duration: 0.2 } })) })] }, `link-${idx}`));
76
+ }) }));
77
+ };
78
+ export const MobileNav = ({ children, className, visible }) => {
79
+ return (_jsx(motion.div, { animate: {
80
+ y: visible ? 20 : 0,
81
+ }, transition: {
82
+ type: "spring",
83
+ stiffness: 150,
84
+ damping: 30,
85
+ }, className: cn("relative z-50 mx-auto flex w-full max-w-[calc(100vw-2rem)] flex-col items-stretch space-y-3 bg-transparent px-0 py-2 lg:hidden", className), children: React.Children.map(children, (child) => React.isValidElement(child)
86
+ ? React.cloneElement(child, { visible })
87
+ : child) }));
88
+ };
89
+ export const MobileNavHeader = ({ children, className, visible }) => {
90
+ return (_jsxs("div", { className: cn("relative z-[60] w-full", className), children: [_jsx(AnimatePresence, { children: visible && (_jsx(motion.div, { initial: { opacity: 0 }, animate: { opacity: 1 }, exit: { opacity: 0 }, transition: { duration: 0.2 }, className: "absolute inset-0 liquid-glass rounded-[28px] border border-white/20", children: _jsx("span", { className: "liquid-glass-content", "aria-hidden": "true" }) })) }), _jsx("div", { className: "relative z-10 flex w-full flex-row items-center justify-between px-4 py-2", children: children })] }));
91
+ };
92
+ export const MobileNavMenu = ({ children, className, isOpen }) => {
93
+ return (_jsx(AnimatePresence, { children: isOpen && (_jsx(motion.div, { initial: { opacity: 0, y: -8 }, animate: { opacity: 1, y: 0 }, exit: { opacity: 0, y: -8 }, transition: {
94
+ default: { duration: 0 },
95
+ y: { type: "spring", stiffness: 150, damping: 30 },
96
+ opacity: { duration: 0.35 },
97
+ }, className: cn("relative z-[60] w-full liquid-glass rounded-[28px] border border-white/20", className), children: _jsx("div", { className: "liquid-glass-content flex flex-col items-start justify-start gap-4 px-4 py-6", children: children }) })) }));
98
+ };
99
+ export const MobileNavToggle = ({ isOpen, onClick }) => {
100
+ const iconClass = "text-white drop-shadow";
101
+ const toggleBaseClasses = cn("flex h-10 w-10 items-center justify-center rounded-full transition focus:outline-none focus-visible:ring-2 focus-visible:ring-white/60 focus-visible:ring-offset-2");
102
+ return isOpen ? (_jsx(Button, { "aria-label": "Close navigation", className: toggleBaseClasses, onClick: onClick, children: _jsx(X, { className: iconClass }) })) : (_jsx(Button, { "aria-label": "Open navigation", className: toggleBaseClasses, onClick: onClick, children: _jsx(Menu, { className: iconClass }) }));
103
+ };
104
+ export const NavbarLogo = ({ href = "/", imageSrc, imageAlt = "logo", imageWidth = 50, imageHeight = 50, imageClassName = "rounded-full -m-3", label = "Levr", className, LinkComponent, ImageComponent, }) => {
105
+ const Link = LinkComponent || (({ href, ...props }) => _jsx("a", { href: href, ...props }));
106
+ const Image = ImageComponent ||
107
+ (({ src, alt, width, height, className: imgClassName }) => (_jsx("img", { src: src, alt: alt, width: width, height: height, className: imgClassName })));
108
+ return (_jsxs(Link, { href: href, className: cn("relative z-20 mr-4 flex items-center space-x-2 px-2 py-1 text-sm font-normal text-white drop-shadow", className), children: [_jsx(Image, { src: imageSrc, alt: imageAlt, width: imageWidth, height: imageHeight, className: imageClassName }), _jsx("span", { className: "font-medium text-white drop-shadow", children: label })] }));
109
+ };
110
+ export const NavbarButton = ({ href, as: Tag = "a", children, className, asChild = false, ...props }) => {
111
+ const Comp = asChild ? Slot : Tag;
112
+ return (_jsx(Comp, { href: asChild ? undefined : href || undefined, className: cn(getButtonClasses(), className), ...props, children: children }));
113
+ };
@@ -0,0 +1 @@
1
+ {"version":3,"file":"resizable-navbar.js","sourceRoot":"","sources":["../../../../../src/client/components/ui/resizable-navbar.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,39 @@
1
+ "use client";
2
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
+ import * as SelectPrimitive from "@radix-ui/react-select";
4
+ import { CheckIcon, ChevronDownIcon, ChevronUpIcon } from "lucide-react";
5
+ import * as React from "react";
6
+ import { cn } from "../../../utils.js";
7
+ function Select({ ...props }) {
8
+ return _jsx(SelectPrimitive.Root, { "data-slot": "select", ...props });
9
+ }
10
+ function SelectGroup({ ...props }) {
11
+ return _jsx(SelectPrimitive.Group, { "data-slot": "select-group", ...props });
12
+ }
13
+ function SelectValue({ ...props }) {
14
+ return _jsx(SelectPrimitive.Value, { "data-slot": "select-value", ...props });
15
+ }
16
+ function SelectTrigger({ className, size = "default", children, ...props }) {
17
+ return (_jsxs(SelectPrimitive.Trigger, { "data-slot": "select-trigger", "data-size": size, className: cn("relative flex w-fit items-center justify-between gap-2 rounded-lg border px-3 py-2 text-sm whitespace-nowrap transition-all duration-300 outline-none select-none text-white disabled:pointer-events-none disabled:opacity-50 data-[size=default]:h-9 data-[size=sm]:h-8 backdrop-blur-sm bg-white/10 border-white/30 hover:bg-white/15 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-white/60 focus-visible:ring-offset-0 shadow-[inset_0_1px_0px_rgba(255,255,255,0.5),0_0_9px_rgba(0,0,0,0.2),0_3px_8px_rgba(0,0,0,0.15)] data-[placeholder]:text-white/60 before:absolute before:inset-0 before:content-[''] before:rounded-lg before:pointer-events-none before:bg-gradient-to-br before:from-white/30 before:via-transparent before:to-transparent before:opacity-40 after:absolute after:inset-0 after:content-[''] after:rounded-lg after:pointer-events-none after:bg-gradient-to-tl after:from-white/15 after:via-transparent after:to-transparent after:opacity-30 *:data-[slot=select-value]:line-clamp-1 *:data-[slot=select-value]:flex *:data-[slot=select-value]:items-center *:data-[slot=select-value]:gap-2 *:data-[slot=select-value]:relative *:data-[slot=select-value]:z-10 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4 [&_svg]:relative [&_svg]:z-10 aria-invalid:border-destructive/60 aria-invalid:focus-visible:ring-destructive/40", className), ...props, children: [children, _jsx(SelectPrimitive.Icon, { asChild: true, children: _jsx(ChevronDownIcon, { className: "size-4 opacity-70" }) })] }));
18
+ }
19
+ function SelectContent({ className, children, position = "popper", ...props }) {
20
+ return (_jsx(SelectPrimitive.Portal, { children: _jsxs(SelectPrimitive.Content, { "data-slot": "select-content", className: cn("relative z-50 max-h-(--radix-select-content-available-height) min-w-[8rem] origin-(--radix-select-content-transform-origin) overflow-x-hidden overflow-y-auto rounded-lg border text-white backdrop-blur-sm bg-white/10 border-white/30 shadow-[inset_0_1px_0px_rgba(255,255,255,0.5),0_0_9px_rgba(0,0,0,0.2),0_3px_8px_rgba(0,0,0,0.15)] data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 before:absolute before:inset-0 before:content-[\"\"] before:rounded-lg before:pointer-events-none before:bg-gradient-to-br before:from-white/30 before:via-transparent before:to-transparent before:opacity-40 after:absolute after:inset-0 after:content-[\"\"] after:rounded-lg after:pointer-events-none after:bg-gradient-to-tl after:from-white/15 after:via-transparent after:to-transparent after:opacity-30", position === "popper" &&
21
+ "data-[side=bottom]:translate-y-1 data-[side=left]:-translate-x-1 data-[side=right]:translate-x-1 data-[side=top]:-translate-y-1", className), position: position, ...props, children: [_jsx(SelectScrollUpButton, {}), _jsx(SelectPrimitive.Viewport, { className: cn("p-1 relative z-10", position === "popper" &&
22
+ "h-[var(--radix-select-trigger-height)] w-full min-w-[var(--radix-select-trigger-width)] scroll-my-1"), children: children }), _jsx(SelectScrollDownButton, {})] }) }));
23
+ }
24
+ function SelectLabel({ className, ...props }) {
25
+ return (_jsx(SelectPrimitive.Label, { "data-slot": "select-label", className: cn("text-white/70 px-2 py-1.5 text-xs font-medium", className), ...props }));
26
+ }
27
+ function SelectItem({ className, children, ...props }) {
28
+ return (_jsxs(SelectPrimitive.Item, { "data-slot": "select-item", className: cn("relative flex w-full cursor-default items-center gap-2 rounded-md py-1.5 pr-8 pl-2 text-sm outline-hidden select-none transition-colors duration-200 text-white/90 hover:bg-white/15 focus:bg-white/15 data-[disabled]:pointer-events-none data-[disabled]:opacity-50 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4 *:[span]:last:flex *:[span]:last:items-center *:[span]:last:gap-2", className), ...props, children: [_jsx("span", { className: "absolute right-2 flex size-3.5 items-center justify-center", children: _jsx(SelectPrimitive.ItemIndicator, { children: _jsx(CheckIcon, { className: "size-4" }) }) }), _jsx(SelectPrimitive.ItemText, { children: children })] }));
29
+ }
30
+ function SelectSeparator({ className, ...props }) {
31
+ return (_jsx(SelectPrimitive.Separator, { "data-slot": "select-separator", className: cn("bg-white/20 pointer-events-none -mx-1 my-1 h-px", className), ...props }));
32
+ }
33
+ function SelectScrollUpButton({ className, ...props }) {
34
+ return (_jsx(SelectPrimitive.ScrollUpButton, { "data-slot": "select-scroll-up-button", className: cn("flex cursor-default items-center justify-center py-1", className), ...props, children: _jsx(ChevronUpIcon, { className: "size-4" }) }));
35
+ }
36
+ function SelectScrollDownButton({ className, ...props }) {
37
+ return (_jsx(SelectPrimitive.ScrollDownButton, { "data-slot": "select-scroll-down-button", className: cn("flex cursor-default items-center justify-center py-1", className), ...props, children: _jsx(ChevronDownIcon, { className: "size-4" }) }));
38
+ }
39
+ export { Select, SelectContent, SelectGroup, SelectItem, SelectLabel, SelectScrollDownButton, SelectScrollUpButton, SelectSeparator, SelectTrigger, SelectValue, };
@@ -0,0 +1 @@
1
+ {"version":3,"file":"select.js","sourceRoot":"","sources":["../../../../../src/client/components/ui/select.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,9 @@
1
+ 'use client';
2
+ import { jsx as _jsx } from "react/jsx-runtime";
3
+ import { Toaster as Sonner } from 'sonner';
4
+ const Toaster = ({ ...props }) => {
5
+ const { theme = 'system' } = props;
6
+ return (_jsx(Sonner, { theme: theme, className: "toaster group", toastOptions: { className: 'liquid-glass' }, ...props }));
7
+ };
8
+ export { Toaster };
9
+ //# sourceMappingURL=sonner.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sonner.js","sourceRoot":"","sources":["../../../../../src/client/components/ui/sonner.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAA;;AAGZ,OAAO,EAAE,OAAO,IAAI,MAAM,EAAE,MAAM,QAAQ,CAAA;AAE1C,MAAM,OAAO,GAAG,CAAC,EAAE,GAAG,KAAK,EAA0D,EAAE,EAAE;IACvF,MAAM,EAAE,KAAK,GAAG,QAAQ,EAAE,GAAG,KAAK,CAAA;IAElC,OAAO,CACL,KAAC,MAAM,IACL,KAAK,EAAE,KAAK,EACZ,SAAS,EAAC,eAAe,EACzB,YAAY,EAAE,EAAE,SAAS,EAAE,cAAc,EAAE,KACvC,KAAK,GACT,CACH,CAAA;AACH,CAAC,CAAA;AAED,OAAO,EAAE,OAAO,EAAE,CAAA"}
@@ -0,0 +1,9 @@
1
+ "use client";
2
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
+ import * as SwitchPrimitive from "@radix-ui/react-switch";
4
+ import * as React from "react";
5
+ import { cn } from "../../../utils.js";
6
+ function Switch({ className, ...props }) {
7
+ return (_jsxs(SwitchPrimitive.Root, { "data-slot": "switch", className: cn("glass glass-sm peer relative inline-flex h-6 w-11 shrink-0 items-center rounded-full border border-white/30 bg-white/20 shadow-sm transition-all outline-none data-[state=checked]:bg-primary/80 data-[state=checked]:border-primary/50 focus-visible:ring-2 focus-visible:ring-white/50 disabled:cursor-not-allowed disabled:opacity-50", className), ...props, children: [_jsx("span", { className: "glass-layers glass-refraction glass-tint-none", "aria-hidden": "true" }), _jsx(SwitchPrimitive.Thumb, { "data-slot": "switch-thumb", className: cn("pointer-events-none relative z-10 block size-5 rounded-full bg-white/90 border border-white/50 shadow-md ring-0 transition-transform data-[state=checked]:translate-x-5 data-[state=unchecked]:translate-x-0.5 data-[state=checked]:bg-white") })] }));
8
+ }
9
+ export { Switch };
@@ -0,0 +1 @@
1
+ {"version":3,"file":"switch.js","sourceRoot":"","sources":["../../../../../src/client/components/ui/switch.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAA;;AAEZ,OAAO,KAAK,eAAe,MAAM,wBAAwB,CAAA;AACzD,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAE9B,OAAO,EAAE,EAAE,EAAE,MAAM,gBAAgB,CAAA;AAEnC,SAAS,MAAM,CAAC,EAAE,SAAS,EAAE,GAAG,KAAK,EAAqD;IACxF,OAAO,CACL,MAAC,eAAe,CAAC,IAAI,iBACT,QAAQ,EAClB,SAAS,EAAE,EAAE,CACX,0UAA0U,EAC1U,SAAS,CACV,KACG,KAAK,aAET,eAAM,SAAS,EAAC,+CAA+C,iBAAa,MAAM,GAAG,EACrF,KAAC,eAAe,CAAC,KAAK,iBACV,cAAc,EACxB,SAAS,EAAE,EAAE,CACX,8OAA8O,CAC/O,GACD,IACmB,CACxB,CAAA;AACH,CAAC;AAED,OAAO,EAAE,MAAM,EAAE,CAAA"}
@@ -0,0 +1,47 @@
1
+ "use client";
2
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
3
+ import * as TabsPrimitive from "@radix-ui/react-tabs";
4
+ import * as React from "react";
5
+ import { cn } from "../../../utils.js";
6
+ function Tabs({ responsive, className, queryKey, defaultValue, value: controlledValue, onValueChange: controlledOnValueChange, ...props }) {
7
+ const getInitialValue = React.useCallback(() => {
8
+ if (typeof window === "undefined" || !queryKey)
9
+ return defaultValue;
10
+ const params = new URLSearchParams(window.location.search);
11
+ return params.get(queryKey) || defaultValue;
12
+ }, [queryKey, defaultValue]);
13
+ const [internalValue, setInternalValue] = React.useState(getInitialValue);
14
+ React.useEffect(() => {
15
+ if (!queryKey)
16
+ return;
17
+ const handlePopState = () => {
18
+ const params = new URLSearchParams(window.location.search);
19
+ const urlValue = params.get(queryKey) || defaultValue;
20
+ setInternalValue(urlValue);
21
+ };
22
+ window.addEventListener("popstate", handlePopState);
23
+ return () => window.removeEventListener("popstate", handlePopState);
24
+ }, [queryKey, defaultValue]);
25
+ const handleValueChange = React.useCallback((value) => {
26
+ setInternalValue(value);
27
+ if (queryKey && typeof window !== "undefined") {
28
+ const url = new URL(window.location.href);
29
+ url.searchParams.set(queryKey, value);
30
+ window.history.replaceState({}, "", url.toString());
31
+ }
32
+ controlledOnValueChange?.(value);
33
+ }, [queryKey, controlledOnValueChange]);
34
+ const value = controlledValue !== undefined ? controlledValue : internalValue;
35
+ return (_jsx(TabsPrimitive.Root, { "data-slot": "tabs", "data-responsive": responsive ? "" : undefined, className: cn("flex flex-col gap-2", responsive &&
36
+ "[&_[data-slot=tabs-list-wrapper]]:h-max [&_[data-slot=tabs-list-wrapper]]:w-full", responsive && "[&_[role=\"tab\"]]:flex-1", className), value: value, onValueChange: handleValueChange, ...props }));
37
+ }
38
+ function TabsList({ className, children, ...props }) {
39
+ return (_jsxs("div", { "data-slot": "tabs-list-wrapper", className: cn("glass glass-md relative text-muted-foreground h-10 w-fit rounded-lg border border-foreground/30 p-[3px]", className), children: [_jsx("span", { className: "glass-layers glass-refraction glass-texture glass-tint-none", "aria-hidden": "true" }), _jsx(TabsPrimitive.List, { "data-slot": "tabs-list", className: "inline-flex items-center justify-center h-full w-full relative z-10", ...props, children: children })] }));
40
+ }
41
+ function TabsTrigger({ className, ...props }) {
42
+ return (_jsx(TabsPrimitive.Trigger, { "data-slot": "tabs-trigger", className: cn("data-[state=active]:bg-background dark:data-[state=active]:text-foreground focus-visible:border-ring focus-visible:ring-ring/50 focus-visible:outline-ring dark:data-[state=active]:border-input dark:data-[state=active]:bg-input/30 text-foreground dark:text-muted-foreground inline-flex h-[calc(100%-1px)] flex-1 items-center justify-center gap-1.5 rounded-md border border-transparent px-2 py-1 text-sm font-medium whitespace-nowrap transition-[color,box-shadow] focus-visible:ring-[3px] focus-visible:outline-1 disabled:pointer-events-none disabled:opacity-50 data-[state=active]:shadow-sm [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4 relative z-10", className), ...props }));
43
+ }
44
+ function TabsContent({ className, ...props }) {
45
+ return (_jsx(TabsPrimitive.Content, { "data-slot": "tabs-content", className: cn("flex-1 outline-none", className), ...props }));
46
+ }
47
+ export { Tabs, TabsContent, TabsList, TabsTrigger };
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tabs.js","sourceRoot":"","sources":["../../../../../src/client/components/ui/tabs.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export * from "./use-cookie-with-fallback.js";
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/client/hooks/index.ts"],"names":[],"mappings":"AAAA,cAAc,4BAA4B,CAAA"}
@@ -0,0 +1,104 @@
1
+ import { useCallback, useEffect, useState } from 'react';
2
+ function isInIframe() {
3
+ if (typeof window === 'undefined')
4
+ return false;
5
+ try {
6
+ return window.self !== window.top;
7
+ }
8
+ catch {
9
+ return true;
10
+ }
11
+ }
12
+ function isSecureContext() {
13
+ if (typeof window === 'undefined')
14
+ return false;
15
+ return window.location.protocol === 'https:' || window.location.hostname === 'localhost';
16
+ }
17
+ export function useCookieWithFallback(cookieName, localStorageKey) {
18
+ const [value, setValue] = useState(null);
19
+ const getPreference = useCallback(() => {
20
+ if (typeof window === 'undefined')
21
+ return null;
22
+ const inIframe = isInIframe();
23
+ try {
24
+ if (inIframe) {
25
+ const storageValue = localStorage.getItem(localStorageKey);
26
+ if (storageValue !== null)
27
+ return storageValue;
28
+ }
29
+ const nameEQ = cookieName + '=';
30
+ const ca = document.cookie.split(';');
31
+ for (let i = 0; i < ca.length; i++) {
32
+ let c = ca[i];
33
+ while (c.charAt(0) === ' ')
34
+ c = c.substring(1, c.length);
35
+ if (c.indexOf(nameEQ) === 0)
36
+ return c.substring(nameEQ.length, c.length);
37
+ }
38
+ return localStorage.getItem(localStorageKey);
39
+ }
40
+ catch (error) {
41
+ console.warn('Error getting preference:', error);
42
+ return null;
43
+ }
44
+ }, [cookieName, localStorageKey]);
45
+ const setPreference = useCallback((newValue, options) => {
46
+ if (typeof window === 'undefined')
47
+ return;
48
+ const inIframe = isInIframe();
49
+ const secure = isSecureContext();
50
+ try {
51
+ if (inIframe) {
52
+ localStorage.setItem(localStorageKey, newValue);
53
+ }
54
+ const expires = new Date();
55
+ expires.setTime(expires.getTime() + options.days * 24 * 60 * 60 * 1000);
56
+ if (inIframe && secure) {
57
+ document.cookie = `${cookieName}=${newValue};expires=${expires.toUTCString()};path=/;SameSite=None;Secure`;
58
+ }
59
+ else if (inIframe) {
60
+ localStorage.setItem(localStorageKey, newValue);
61
+ }
62
+ else {
63
+ document.cookie = `${cookieName}=${newValue};expires=${expires.toUTCString()};path=/;SameSite=Lax`;
64
+ }
65
+ setValue(newValue);
66
+ }
67
+ catch (error) {
68
+ console.warn('Cookie setting failed, using localStorage:', error);
69
+ try {
70
+ localStorage.setItem(localStorageKey, newValue);
71
+ setValue(newValue);
72
+ }
73
+ catch (storageError) {
74
+ console.error('Both cookie and localStorage failed:', storageError);
75
+ }
76
+ }
77
+ }, [cookieName, localStorageKey]);
78
+ const deletePreference = useCallback(() => {
79
+ if (typeof window === 'undefined')
80
+ return;
81
+ try {
82
+ localStorage.removeItem(localStorageKey);
83
+ document.cookie = `${cookieName}=; expires=Thu, 01 Jan 1970 00:00:00 UTC; path=/;`;
84
+ if (isInIframe() && isSecureContext()) {
85
+ document.cookie = `${cookieName}=; expires=Thu, 01 Jan 1970 00:00:00 UTC; path=/; SameSite=None; Secure`;
86
+ }
87
+ setValue(null);
88
+ }
89
+ catch (error) {
90
+ console.warn('Error deleting preference:', error);
91
+ }
92
+ }, [cookieName, localStorageKey]);
93
+ useEffect(() => {
94
+ const initialValue = getPreference();
95
+ setValue(initialValue);
96
+ }, [getPreference]);
97
+ return {
98
+ value,
99
+ getPreference,
100
+ setPreference,
101
+ deletePreference,
102
+ };
103
+ }
104
+ //# sourceMappingURL=use-cookie-with-fallback.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-cookie-with-fallback.js","sourceRoot":"","sources":["../../../../src/client/hooks/use-cookie-with-fallback.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ export * from "./components/index.js";
2
+ export * from "./hooks/index.js";
3
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/client/index.ts"],"names":[],"mappings":"AAAA,cAAc,cAAc,CAAA;AAC5B,cAAc,SAAS,CAAA"}
@@ -0,0 +1,2 @@
1
+ export * from "./ui/index.js";
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/index.ts"],"names":[],"mappings":"AAAA,cAAc,MAAM,CAAA"}
@@ -0,0 +1,30 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { cva } from "class-variance-authority";
3
+ import * as React from "react";
4
+ import { cn } from "../../utils.js";
5
+ const alertVariants = cva("relative w-full max-w-full rounded-lg border border-foreground/30 px-4 py-3 text-sm [&>svg]:size-4 [&>svg]:translate-y-0.5 [&>svg]:text-current", {
6
+ variants: {
7
+ variant: {
8
+ default: "text-foreground [&>svg]:text-foreground *:data-[slot=alert-description]:text-foreground/90",
9
+ destructive: "text-destructive [&>svg]:text-destructive *:data-[slot=alert-description]:text-destructive/80",
10
+ },
11
+ },
12
+ defaultVariants: {
13
+ variant: "default",
14
+ },
15
+ });
16
+ function Alert({ className, contentClassName, variant, isGlass = false, children, ...props }) {
17
+ const contentClasses = cn("grid has-[>svg]:grid-cols-[calc(var(--spacing)*4)_minmax(0,1fr)] grid-cols-[0_minmax(0,1fr)] has-[>svg]:gap-x-3 gap-y-0.5 items-start relative z-10", contentClassName);
18
+ if (!isGlass) {
19
+ return (_jsx("div", { "data-slot": "alert", role: "alert", className: cn(alertVariants({ variant }), "bg-background", className), ...props, children: _jsx("div", { className: contentClasses, children: children }) }));
20
+ }
21
+ return (_jsxs("div", { "data-slot": "alert", role: "alert", className: cn(alertVariants({ variant }), "glass glass-md", className), ...props, children: [_jsx("span", { className: "glass-layers glass-refraction glass-texture glass-tint-none", "aria-hidden": "true" }), _jsx("div", { className: contentClasses, children: children })] }));
22
+ }
23
+ function AlertTitle({ className, ...props }) {
24
+ return (_jsx("div", { "data-slot": "alert-title", className: cn("break-all relative z-10 col-start-2 line-clamp-1 min-h-4 min-w-0 font-medium tracking-tight", className), ...props }));
25
+ }
26
+ function AlertDescription({ className, ...props }) {
27
+ return (_jsx("div", { "data-slot": "alert-description", className: cn("break-all relative z-10 text-muted-foreground col-start-2 min-w-0 grid justify-items-start gap-1 text-sm [&_p]:leading-relaxed", className), ...props }));
28
+ }
29
+ export { Alert, AlertDescription, AlertTitle };
30
+ //# sourceMappingURL=alert.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"alert.js","sourceRoot":"","sources":["../../../../src/components/ui/alert.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,GAAG,EAAqB,MAAM,0BAA0B,CAAA;AACjE,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAE9B,OAAO,EAAE,EAAE,EAAE,MAAM,aAAa,CAAA;AAEhC,MAAM,aAAa,GAAG,GAAG,CACvB,iJAAiJ,EACjJ;IACE,QAAQ,EAAE;QACR,OAAO,EAAE;YACP,OAAO,EACL,4FAA4F;YAC9F,WAAW,EACT,+FAA+F;SAClG;KACF;IACD,eAAe,EAAE;QACf,OAAO,EAAE,SAAS;KACnB;CACF,CACF,CAAA;AAcD,SAAS,KAAK,CAAC,EACb,SAAS,EACT,gBAAgB,EAChB,OAAO,EACP,OAAO,GAAG,KAAK,EACf,QAAQ,EACR,GAAG,KAAK,EACG;IACX,MAAM,cAAc,GAAG,EAAE,CACvB,qJAAqJ,EACrJ,gBAAgB,CACjB,CAAA;IAED,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,OAAO,CACL,2BACY,OAAO,EACjB,IAAI,EAAC,OAAO,EACZ,SAAS,EAAE,EAAE,CAAC,aAAa,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,eAAe,EAAE,SAAS,CAAC,KACjE,KAAK,YAET,cAAK,SAAS,EAAE,cAAc,YAAG,QAAQ,GAAO,GAC5C,CACP,CAAA;IACH,CAAC;IAED,OAAO,CACL,4BACY,OAAO,EACjB,IAAI,EAAC,OAAO,EACZ,SAAS,EAAE,EAAE,CAAC,aAAa,CAAC,EAAE,OAAO,EAAE,CAAC,EAAE,gBAAgB,EAAE,SAAS,CAAC,KAClE,KAAK,aAET,eACE,SAAS,EAAC,6DAA6D,iBAC3D,MAAM,GAClB,EACF,cAAK,SAAS,EAAE,cAAc,YAAG,QAAQ,GAAO,IAC5C,CACP,CAAA;AACH,CAAC;AAED,SAAS,UAAU,CAAC,EAAE,SAAS,EAAE,GAAG,KAAK,EAA+B;IACtE,OAAO,CACL,2BACY,aAAa,EACvB,SAAS,EAAE,EAAE,CACX,6FAA6F,EAC7F,SAAS,CACV,KACG,KAAK,GACT,CACH,CAAA;AACH,CAAC;AAED,SAAS,gBAAgB,CAAC,EAAE,SAAS,EAAE,GAAG,KAAK,EAA+B;IAC5E,OAAO,CACL,2BACY,mBAAmB,EAC7B,SAAS,EAAE,EAAE,CACX,gIAAgI,EAChI,SAAS,CACV,KACG,KAAK,GACT,CACH,CAAA;AACH,CAAC;AAED,OAAO,EAAE,KAAK,EAAE,gBAAgB,EAAE,UAAU,EAAE,CAAA"}
@@ -0,0 +1,25 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Slot } from "@radix-ui/react-slot";
3
+ import { cva } from "class-variance-authority";
4
+ import * as React from "react";
5
+ import { cn } from "../../utils.js";
6
+ const badgeVariants = cva("rounded-md border px-2 py-0.5 text-xs font-medium w-fit whitespace-nowrap shrink-0 [&>svg]:size-3 gap-1 [&>svg]:pointer-events-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 transition-[color,box-shadow]", {
7
+ variants: {
8
+ variant: {
9
+ default: "border-white/40 bg-white/10 text-white [a&]:hover:bg-white/15",
10
+ primary: "border-primary/40 bg-primary/10 text-primary [a&]:hover:bg-primary/15",
11
+ secondary: "border-white/40 bg-white/8 text-white/90 [a&]:hover:bg-white/12",
12
+ destructive: "border-white/40 bg-white/10 text-destructive [a&]:hover:bg-white/15",
13
+ outline: "border-white/50 bg-black/20 text-white [a&]:hover:bg-black/30",
14
+ },
15
+ },
16
+ defaultVariants: {
17
+ variant: "default",
18
+ },
19
+ });
20
+ function Badge({ className, variant, asChild = false, children, ...props }) {
21
+ const Comp = asChild ? Slot : "span";
22
+ return (_jsxs(Comp, { "data-slot": "badge", className: cn(badgeVariants({ variant }), "glass glass-sm relative inline-flex items-center justify-center gap-1", className), ...props, children: [_jsx("span", { className: "glass-layers glass-refraction glass-texture glass-tint-none", "aria-hidden": "true" }), children] }));
23
+ }
24
+ export { Badge, badgeVariants };
25
+ //# sourceMappingURL=badge.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"badge.js","sourceRoot":"","sources":["../../../../src/components/ui/badge.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,sBAAsB,CAAA;AAC3C,OAAO,EAAE,GAAG,EAAqB,MAAM,0BAA0B,CAAA;AACjE,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAE9B,OAAO,EAAE,EAAE,EAAE,MAAM,aAAa,CAAA;AAEhC,MAAM,aAAa,GAAG,GAAG,CACvB,wVAAwV,EACxV;IACE,QAAQ,EAAE;QACR,OAAO,EAAE;YACP,OAAO,EAAE,+DAA+D;YACxE,OAAO,EAAE,uEAAuE;YAChF,SAAS,EAAE,iEAAiE;YAC5E,WAAW,EAAE,qEAAqE;YAClF,OAAO,EAAE,+DAA+D;SACzE;KACF;IACD,eAAe,EAAE;QACf,OAAO,EAAE,SAAS;KACnB;CACF,CACF,CAAA;AAED,SAAS,KAAK,CAAC,EACb,SAAS,EACT,OAAO,EACP,OAAO,GAAG,KAAK,EACf,QAAQ,EACR,GAAG,KAAK,EACkF;IAC1F,MAAM,IAAI,GAAG,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAA;IAEpC,OAAO,CACL,MAAC,IAAI,iBACO,OAAO,EACjB,SAAS,EAAE,EAAE,CACX,aAAa,CAAC,EAAE,OAAO,EAAE,CAAC,EAC1B,uEAAuE,EACvE,SAAS,CACV,KACG,KAAK,aAET,eACE,SAAS,EAAC,6DAA6D,iBAC3D,MAAM,GAClB,EACD,QAAQ,IACJ,CACR,CAAA;AACH,CAAC;AAED,OAAO,EAAE,KAAK,EAAE,aAAa,EAAE,CAAA"}
@@ -0,0 +1,36 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Slot } from "@radix-ui/react-slot";
3
+ import { cva } from "class-variance-authority";
4
+ import * as React from "react";
5
+ import { cn } from "../../utils.js";
6
+ const buttonVariants = cva("cursor-pointer rounded-lg border text-sm font-semibold transition-all duration-300 align-middle select-none font-sans text-white disabled:pointer-events-none disabled:opacity-50 bg-white/10 border-white/40 hover:bg-white/20 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-white/60 focus-visible:ring-offset-0 [&_svg]:pointer-events-none [&_svg:not([class*=\"size-\"])]:size-4 [&_svg]:shrink-0 aria-invalid:border-destructive/60 aria-invalid:focus-visible:ring-destructive/40", {
7
+ variants: {
8
+ variant: {
9
+ default: "text-primary-foreground bg-primary/20 border-primary/40 hover:bg-primary/30 focus-visible:ring-primary/50",
10
+ destructive: "text-destructive-foreground bg-destructive/25 border-destructive/50 hover:bg-destructive/35 focus-visible:ring-destructive/50",
11
+ outline: "text-white bg-white/10 border-white/50 hover:bg-white/20 focus-visible:ring-white/60",
12
+ secondary: "text-secondary-foreground bg-secondary/20 border-secondary/50 hover:bg-secondary/30 focus-visible:ring-secondary/50",
13
+ ghost: "text-white bg-transparent border-transparent shadow-none hover:bg-white/10 focus-visible:ring-white/60",
14
+ link: "text-primary bg-transparent border-transparent shadow-none underline-offset-4 hover:underline hover:bg-transparent focus-visible:ring-0",
15
+ },
16
+ size: {
17
+ default: "h-9 px-4 py-2 has-[>svg]:px-3",
18
+ sm: "h-8 rounded-md gap-1.5 px-3 has-[>svg]:px-2.5",
19
+ lg: "h-10 rounded-xl px-6 has-[>svg]:px-4",
20
+ icon: "size-9",
21
+ },
22
+ },
23
+ defaultVariants: {
24
+ variant: "default",
25
+ size: "default",
26
+ },
27
+ });
28
+ function Button({ className, variant, size, asChild = false, noGlass = false, children, ...props }) {
29
+ const shouldUseGlass = !noGlass && variant !== "ghost" && variant !== "link";
30
+ if (asChild) {
31
+ return (_jsx(Slot, { "data-slot": "button", className: cn(buttonVariants({ variant, size }), "relative inline-flex items-center justify-center gap-2 whitespace-nowrap overflow-hidden", shouldUseGlass && "glass glass-lg", className), ...props, children: children }));
32
+ }
33
+ return (_jsxs("button", { "data-slot": "button", className: cn(buttonVariants({ variant, size }), "relative inline-flex items-center justify-center gap-2 whitespace-nowrap overflow-hidden", shouldUseGlass && "glass glass-lg", className), ...props, children: [shouldUseGlass && (_jsx("span", { className: "glass-layers glass-refraction glass-texture glass-tint-none", "aria-hidden": "true" })), children] }));
34
+ }
35
+ export { Button, buttonVariants };
36
+ //# sourceMappingURL=button.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"button.js","sourceRoot":"","sources":["../../../../src/components/ui/button.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,sBAAsB,CAAA;AAC3C,OAAO,EAAE,GAAG,EAAqB,MAAM,0BAA0B,CAAA;AACjE,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAE9B,OAAO,EAAE,EAAE,EAAE,MAAM,aAAa,CAAA;AAEhC,MAAM,cAAc,GAAG,GAAG,CACxB,6eAA6e,EAC7e;IACE,QAAQ,EAAE;QACR,OAAO,EAAE;YACP,OAAO,EACL,2GAA2G;YAC7G,WAAW,EACT,+HAA+H;YACjI,OAAO,EACL,sFAAsF;YACxF,SAAS,EACP,qHAAqH;YACvH,KAAK,EACH,wGAAwG;YAC1G,IAAI,EAAE,yIAAyI;SAChJ;QACD,IAAI,EAAE;YACJ,OAAO,EAAE,+BAA+B;YACxC,EAAE,EAAE,+CAA+C;YACnD,EAAE,EAAE,sCAAsC;YAC1C,IAAI,EAAE,QAAQ;SACf;KACF;IACD,eAAe,EAAE;QACf,OAAO,EAAE,SAAS;QAClB,IAAI,EAAE,SAAS;KAChB;CACF,CACF,CAAA;AAWD,SAAS,MAAM,CAAC,EACd,SAAS,EACT,OAAO,EACP,IAAI,EACJ,OAAO,GAAG,KAAK,EACf,OAAO,GAAG,KAAK,EACf,QAAQ,EACR,GAAG,KAAK,EACI;IAEZ,MAAM,cAAc,GAAG,CAAC,OAAO,IAAI,OAAO,KAAK,OAAO,IAAI,OAAO,KAAK,MAAM,CAAA;IAI5E,IAAI,OAAO,EAAE,CAAC;QACZ,OAAO,CACL,KAAC,IAAI,iBACO,QAAQ,EAClB,SAAS,EAAE,EAAE,CACX,cAAc,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,EACjC,0FAA0F,EAC1F,cAAc,IAAI,gBAAgB,EAClC,SAAS,CACV,KACG,KAAK,YAER,QAAQ,GACJ,CACR,CAAA;IACH,CAAC;IAED,OAAO,CACL,+BACY,QAAQ,EAClB,SAAS,EAAE,EAAE,CACX,cAAc,CAAC,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,EACjC,0FAA0F,EAC1F,cAAc,IAAI,gBAAgB,EAClC,SAAS,CACV,KACG,KAAK,aAER,cAAc,IAAI,CACjB,eACE,SAAS,EAAC,6DAA6D,iBAC3D,MAAM,GAClB,CACH,EACA,QAAQ,IACF,CACV,CAAA;AACH,CAAC;AAED,OAAO,EAAE,MAAM,EAAE,cAAc,EAAE,CAAA"}
@@ -0,0 +1,41 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import * as React from "react";
3
+ import { cn } from "../../utils.js";
4
+ const glassSizeClasses = {
5
+ sm: "glass-sm",
6
+ md: "glass-md",
7
+ lg: "glass-lg",
8
+ xl: "glass-xl",
9
+ };
10
+ const glassTintClasses = {
11
+ none: "glass-tint-none",
12
+ light: "glass-tint-light",
13
+ default: "glass-tint-default",
14
+ dark: "glass-tint-dark",
15
+ };
16
+ function Card({ className, size = "md", tint = "none", isGlass = false, children, ...props }) {
17
+ if (!isGlass) {
18
+ return (_jsx("div", { "data-slot": "card", className: cn("bg-background text-card-foreground flex flex-col gap-4 rounded-xl border py-4 border-foreground/30 overflow-hidden relative max-w-full min-w-0", className), ...props, children: children }));
19
+ }
20
+ return (_jsxs("div", { "data-slot": "card", className: cn("glass relative text-card-foreground rounded-xl border py-4 border-foreground/30 max-w-full min-w-0", glassSizeClasses[size], className), ...props, children: [_jsx("span", { className: cn("glass-layers glass-refraction glass-texture", glassTintClasses[tint]), "aria-hidden": "true" }), _jsx("div", { className: "relative z-10 flex flex-col gap-4", children: children })] }));
21
+ }
22
+ function CardHeader({ className, ...props }) {
23
+ return (_jsx("div", { "data-slot": "card-header", className: cn("relative z-10 @container/card-header grid auto-rows-min grid-rows-[auto_auto] items-start gap-1.5 px-4 has-data-[slot=card-action]:grid-cols-[1fr_auto] [.border-b]:pb-4", className), ...props }));
24
+ }
25
+ function CardTitle({ className, ...props }) {
26
+ return (_jsx("div", { "data-slot": "card-title", className: cn("relative z-10 leading-none font-semibold", className), ...props }));
27
+ }
28
+ function CardDescription({ className, ...props }) {
29
+ return (_jsx("div", { "data-slot": "card-description", className: cn("break-all relative z-10 text-muted-foreground text-sm", className), ...props }));
30
+ }
31
+ function CardAction({ className, ...props }) {
32
+ return (_jsx("div", { "data-slot": "card-action", className: cn("relative z-10 col-start-2 row-span-2 row-start-1 self-start justify-self-end", className), ...props }));
33
+ }
34
+ function CardContent({ className, ...props }) {
35
+ return (_jsx("div", { "data-slot": "card-content", className: cn("relative z-10 px-4 min-w-0 overflow-hidden", className), ...props }));
36
+ }
37
+ function CardFooter({ className, ...props }) {
38
+ return (_jsx("div", { "data-slot": "card-footer", className: cn("relative z-10 flex items-center px-4 [.border-t]:pt-4", className), ...props }));
39
+ }
40
+ export { Card, CardAction, CardContent, CardDescription, CardFooter, CardHeader, CardTitle };
41
+ //# sourceMappingURL=card.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"card.js","sourceRoot":"","sources":["../../../../src/components/ui/card.tsx"],"names":[],"mappings":";AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAA;AAE9B,OAAO,EAAE,EAAE,EAAE,MAAM,aAAa,CAAA;AAKhC,MAAM,gBAAgB,GAA8B;IAClD,EAAE,EAAE,UAAU;IACd,EAAE,EAAE,UAAU;IACd,EAAE,EAAE,UAAU;IACd,EAAE,EAAE,UAAU;CACf,CAAA;AAED,MAAM,gBAAgB,GAA8B;IAClD,IAAI,EAAE,iBAAiB;IACvB,KAAK,EAAE,kBAAkB;IACzB,OAAO,EAAE,oBAAoB;IAC7B,IAAI,EAAE,iBAAiB;CACxB,CAAA;AAiBD,SAAS,IAAI,CAAC,EACZ,SAAS,EACT,IAAI,GAAG,IAAI,EACX,IAAI,GAAG,MAAM,EACb,OAAO,GAAG,KAAK,EACf,QAAQ,EACR,GAAG,KAAK,EACE;IACV,IAAI,CAAC,OAAO,EAAE,CAAC;QACb,OAAO,CACL,2BACY,MAAM,EAChB,SAAS,EAAE,EAAE,CACX,gJAAgJ,EAChJ,SAAS,CACV,KACG,KAAK,YAER,QAAQ,GACL,CACP,CAAA;IACH,CAAC;IAED,OAAO,CACL,4BACY,MAAM,EAChB,SAAS,EAAE,EAAE,CACX,oGAAoG,EACpG,gBAAgB,CAAC,IAAI,CAAC,EACtB,SAAS,CACV,KACG,KAAK,aAET,eACE,SAAS,EAAE,EAAE,CAAC,6CAA6C,EAAE,gBAAgB,CAAC,IAAI,CAAC,CAAC,iBACxE,MAAM,GAClB,EACF,cAAK,SAAS,EAAC,mCAAmC,YAAE,QAAQ,GAAO,IAC/D,CACP,CAAA;AACH,CAAC;AAED,SAAS,UAAU,CAAC,EAAE,SAAS,EAAE,GAAG,KAAK,EAA+B;IACtE,OAAO,CACL,2BACY,aAAa,EACvB,SAAS,EAAE,EAAE,CACX,0KAA0K,EAC1K,SAAS,CACV,KACG,KAAK,GACT,CACH,CAAA;AACH,CAAC;AAED,SAAS,SAAS,CAAC,EAAE,SAAS,EAAE,GAAG,KAAK,EAA+B;IACrE,OAAO,CACL,2BACY,YAAY,EACtB,SAAS,EAAE,EAAE,CAAC,0CAA0C,EAAE,SAAS,CAAC,KAChE,KAAK,GACT,CACH,CAAA;AACH,CAAC;AAED,SAAS,eAAe,CAAC,EAAE,SAAS,EAAE,GAAG,KAAK,EAA+B;IAC3E,OAAO,CACL,2BACY,kBAAkB,EAC5B,SAAS,EAAE,EAAE,CAAC,uDAAuD,EAAE,SAAS,CAAC,KAC7E,KAAK,GACT,CACH,CAAA;AACH,CAAC;AAED,SAAS,UAAU,CAAC,EAAE,SAAS,EAAE,GAAG,KAAK,EAA+B;IACtE,OAAO,CACL,2BACY,aAAa,EACvB,SAAS,EAAE,EAAE,CACX,8EAA8E,EAC9E,SAAS,CACV,KACG,KAAK,GACT,CACH,CAAA;AACH,CAAC;AAED,SAAS,WAAW,CAAC,EAAE,SAAS,EAAE,GAAG,KAAK,EAA+B;IACvE,OAAO,CACL,2BACY,cAAc,EACxB,SAAS,EAAE,EAAE,CAAC,4CAA4C,EAAE,SAAS,CAAC,KAClE,KAAK,GACT,CACH,CAAA;AACH,CAAC;AAED,SAAS,UAAU,CAAC,EAAE,SAAS,EAAE,GAAG,KAAK,EAA+B;IACtE,OAAO,CACL,2BACY,aAAa,EACvB,SAAS,EAAE,EAAE,CAAC,uDAAuD,EAAE,SAAS,CAAC,KAC7E,KAAK,GACT,CACH,CAAA;AACH,CAAC;AAED,OAAO,EAAE,IAAI,EAAE,UAAU,EAAE,WAAW,EAAE,eAAe,EAAE,UAAU,EAAE,UAAU,EAAE,SAAS,EAAE,CAAA"}
@@ -0,0 +1,6 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Heart } from 'lucide-react';
3
+ export function Footer({ links, builtByText = 'Built by', builtByBrand = 'Levr', showLogo = true, linkComponent: LinkComponent = ({ href, ...props }) => _jsx("a", { href: href, ...props }), }) {
4
+ return (_jsxs("footer", { className: "relative mt-auto", children: [_jsx("div", { className: "absolute top-0 left-0 right-0 h-px liquid-glass-border" }), _jsx("div", { className: "relative z-10 py-6 px-4", children: _jsxs("div", { className: "flex flex-col sm:flex-row items-center justify-between gap-4", children: [_jsx("nav", { className: "flex items-center gap-6", "aria-label": "Footer navigation", children: links.map((link) => (_jsxs(LinkComponent, { href: link.href, target: "_blank", rel: "noopener noreferrer", className: "group flex items-center gap-2 text-muted-foreground hover:text-foreground transition-colors duration-200", "aria-label": link.name, children: [_jsx(link.icon, { className: "h-5 w-5" }), link.showLabel && _jsx("span", { className: "text-sm font-medium", children: link.name })] }, link.name))) }), showLogo && (_jsxs("p", { className: "flex items-center gap-1.5 text-sm text-muted-foreground", children: [builtByText, " ", _jsx("b", { className: "text-primary", children: builtByBrand }), " team with", ' ', _jsx(Heart, { className: "h-4 w-4 text-red-500 fill-red-500" })] }))] }) })] }));
5
+ }
6
+ //# sourceMappingURL=footer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"footer.js","sourceRoot":"","sources":["../../../../src/components/ui/footer.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,cAAc,CAAA;AAyBpC,MAAM,UAAU,MAAM,CAAC,EACrB,KAAK,EACL,WAAW,GAAG,UAAU,EACxB,YAAY,GAAG,MAAM,EACrB,QAAQ,GAAG,IAAI,EACf,aAAa,EAAE,aAAa,GAAG,CAAC,EAAE,IAAI,EAAE,GAAG,KAAK,EAAO,EAAE,EAAE,CAAC,YAAG,IAAI,EAAE,IAAI,KAAM,KAAK,GAAI,GAC5E;IACZ,OAAO,CACL,kBAAQ,SAAS,EAAC,kBAAkB,aAElC,cAAK,SAAS,EAAC,wDAAwD,GAAG,EAE1E,cAAK,SAAS,EAAC,yBAAyB,YACtC,eAAK,SAAS,EAAC,8DAA8D,aAE3E,cAAK,SAAS,EAAC,yBAAyB,gBAAY,mBAAmB,YACpE,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CACnB,MAAC,aAAa,IAEZ,IAAI,EAAE,IAAI,CAAC,IAAI,EACf,MAAM,EAAC,QAAQ,EACf,GAAG,EAAC,qBAAqB,EACzB,SAAS,EAAC,0GAA0G,gBACxG,IAAI,CAAC,IAAI,aAErB,KAAC,IAAI,CAAC,IAAI,IAAC,SAAS,EAAC,SAAS,GAAG,EAChC,IAAI,CAAC,SAAS,IAAI,eAAM,SAAS,EAAC,qBAAqB,YAAE,IAAI,CAAC,IAAI,GAAQ,KARtE,IAAI,CAAC,IAAI,CASA,CACjB,CAAC,GACE,EAGL,QAAQ,IAAI,CACX,aAAG,SAAS,EAAC,yDAAyD,aACnE,WAAW,OAAE,YAAG,SAAS,EAAC,cAAc,YAAE,YAAY,GAAK,gBAAW,GAAG,EAC1E,KAAC,KAAK,IAAC,SAAS,EAAC,mCAAmC,GAAG,IACrD,CACL,IACG,GACF,IACC,CACV,CAAA;AACH,CAAC"}
@@ -0,0 +1,9 @@
1
+ export * from "./alert.js";
2
+ export * from "./badge.js";
3
+ export * from "./button.js";
4
+ export * from "./card.js";
5
+ export * from "./footer.js";
6
+ export * from "./input.js";
7
+ export * from "./pretty-amount.js";
8
+ export * from "./textarea.js";
9
+ //# sourceMappingURL=index.js.map