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.
- package/LICENSE.md +201 -0
- package/README.md +209 -0
- package/dist/cjs/client/components/index.js +18 -0
- package/dist/cjs/client/components/index.js.map +1 -0
- package/dist/cjs/client/components/ui/dialog.js +48 -0
- package/dist/cjs/client/components/ui/dialog.js.map +1 -0
- package/dist/cjs/client/components/ui/index.js +24 -0
- package/dist/cjs/client/components/ui/index.js.map +1 -0
- package/dist/cjs/client/components/ui/pretty-date.js +91 -0
- package/dist/cjs/client/components/ui/pretty-date.js.map +1 -0
- package/dist/cjs/client/components/ui/resizable-navbar.js +126 -0
- package/dist/cjs/client/components/ui/resizable-navbar.js.map +1 -0
- package/dist/cjs/client/components/ui/select.js +50 -0
- package/dist/cjs/client/components/ui/select.js.map +1 -0
- package/dist/cjs/client/components/ui/sonner.js +12 -0
- package/dist/cjs/client/components/ui/sonner.js.map +1 -0
- package/dist/cjs/client/components/ui/switch.js +11 -0
- package/dist/cjs/client/components/ui/switch.js.map +1 -0
- package/dist/cjs/client/components/ui/tabs.js +53 -0
- package/dist/cjs/client/components/ui/tabs.js.map +1 -0
- package/dist/cjs/client/hooks/index.js +18 -0
- package/dist/cjs/client/hooks/index.js.map +1 -0
- package/dist/cjs/client/hooks/use-cookie-with-fallback.js +107 -0
- package/dist/cjs/client/hooks/use-cookie-with-fallback.js.map +1 -0
- package/dist/cjs/client/index.js +19 -0
- package/dist/cjs/client/index.js.map +1 -0
- package/dist/cjs/components/index.js +18 -0
- package/dist/cjs/components/index.js.map +1 -0
- package/dist/cjs/components/ui/alert.js +33 -0
- package/dist/cjs/components/ui/alert.js.map +1 -0
- package/dist/cjs/components/ui/badge.js +28 -0
- package/dist/cjs/components/ui/badge.js.map +1 -0
- package/dist/cjs/components/ui/button.js +39 -0
- package/dist/cjs/components/ui/button.js.map +1 -0
- package/dist/cjs/components/ui/card.js +48 -0
- package/dist/cjs/components/ui/card.js.map +1 -0
- package/dist/cjs/components/ui/footer.js +9 -0
- package/dist/cjs/components/ui/footer.js.map +1 -0
- package/dist/cjs/components/ui/index.js +25 -0
- package/dist/cjs/components/ui/index.js.map +1 -0
- package/dist/cjs/components/ui/input.js +12 -0
- package/dist/cjs/components/ui/input.js.map +1 -0
- package/dist/cjs/components/ui/pretty-amount.js +167 -0
- package/dist/cjs/components/ui/pretty-amount.js.map +1 -0
- package/dist/cjs/components/ui/textarea.js +12 -0
- package/dist/cjs/components/ui/textarea.js.map +1 -0
- package/dist/cjs/index.js +19 -0
- package/dist/cjs/index.js.map +1 -0
- package/dist/cjs/utils.js +9 -0
- package/dist/cjs/utils.js.map +1 -0
- package/dist/esm/client/components/index.js +2 -0
- package/dist/esm/client/components/index.js.map +1 -0
- package/dist/esm/client/components/ui/dialog.js +37 -0
- package/dist/esm/client/components/ui/dialog.js.map +1 -0
- package/dist/esm/client/components/ui/index.js +8 -0
- package/dist/esm/client/components/ui/index.js.map +1 -0
- package/dist/esm/client/components/ui/pretty-date.js +88 -0
- package/dist/esm/client/components/ui/pretty-date.js.map +1 -0
- package/dist/esm/client/components/ui/resizable-navbar.js +113 -0
- package/dist/esm/client/components/ui/resizable-navbar.js.map +1 -0
- package/dist/esm/client/components/ui/select.js +39 -0
- package/dist/esm/client/components/ui/select.js.map +1 -0
- package/dist/esm/client/components/ui/sonner.js +9 -0
- package/dist/esm/client/components/ui/sonner.js.map +1 -0
- package/dist/esm/client/components/ui/switch.js +9 -0
- package/dist/esm/client/components/ui/switch.js.map +1 -0
- package/dist/esm/client/components/ui/tabs.js +47 -0
- package/dist/esm/client/components/ui/tabs.js.map +1 -0
- package/dist/esm/client/hooks/index.js +2 -0
- package/dist/esm/client/hooks/index.js.map +1 -0
- package/dist/esm/client/hooks/use-cookie-with-fallback.js +104 -0
- package/dist/esm/client/hooks/use-cookie-with-fallback.js.map +1 -0
- package/dist/esm/client/index.js +3 -0
- package/dist/esm/client/index.js.map +1 -0
- package/dist/esm/components/index.js +2 -0
- package/dist/esm/components/index.js.map +1 -0
- package/dist/esm/components/ui/alert.js +30 -0
- package/dist/esm/components/ui/alert.js.map +1 -0
- package/dist/esm/components/ui/badge.js +25 -0
- package/dist/esm/components/ui/badge.js.map +1 -0
- package/dist/esm/components/ui/button.js +36 -0
- package/dist/esm/components/ui/button.js.map +1 -0
- package/dist/esm/components/ui/card.js +41 -0
- package/dist/esm/components/ui/card.js.map +1 -0
- package/dist/esm/components/ui/footer.js +6 -0
- package/dist/esm/components/ui/footer.js.map +1 -0
- package/dist/esm/components/ui/index.js +9 -0
- package/dist/esm/components/ui/index.js.map +1 -0
- package/dist/esm/components/ui/input.js +11 -0
- package/dist/esm/components/ui/input.js.map +1 -0
- package/dist/esm/components/ui/pretty-amount.js +164 -0
- package/dist/esm/components/ui/pretty-amount.js.map +1 -0
- package/dist/esm/components/ui/textarea.js +11 -0
- package/dist/esm/components/ui/textarea.js.map +1 -0
- package/dist/esm/index.js +3 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/utils.js +6 -0
- package/dist/esm/utils.js.map +1 -0
- package/dist/styles.css +563 -0
- package/dist/types/client/components/index.d.ts +2 -0
- package/dist/types/client/components/index.d.ts.map +1 -0
- package/dist/types/client/components/ui/dialog.d.ts +16 -0
- package/dist/types/client/components/ui/dialog.d.ts.map +1 -0
- package/dist/types/client/components/ui/index.d.ts +8 -0
- package/dist/types/client/components/ui/index.d.ts.map +1 -0
- package/dist/types/client/components/ui/pretty-date.d.ts +30 -0
- package/dist/types/client/components/ui/pretty-date.d.ts.map +1 -0
- package/dist/types/client/components/ui/resizable-navbar.d.ts +84 -0
- package/dist/types/client/components/ui/resizable-navbar.d.ts.map +1 -0
- package/dist/types/client/components/ui/select.d.ts +16 -0
- package/dist/types/client/components/ui/select.d.ts.map +1 -0
- package/dist/types/client/components/ui/sonner.d.ts +6 -0
- package/dist/types/client/components/ui/sonner.d.ts.map +1 -0
- package/dist/types/client/components/ui/switch.d.ts +5 -0
- package/dist/types/client/components/ui/switch.d.ts.map +1 -0
- package/dist/types/client/components/ui/tabs.d.ts +11 -0
- package/dist/types/client/components/ui/tabs.d.ts.map +1 -0
- package/dist/types/client/hooks/index.d.ts +2 -0
- package/dist/types/client/hooks/index.d.ts.map +1 -0
- package/dist/types/client/hooks/use-cookie-with-fallback.d.ts +20 -0
- package/dist/types/client/hooks/use-cookie-with-fallback.d.ts.map +1 -0
- package/dist/types/client/index.d.ts +3 -0
- package/dist/types/client/index.d.ts.map +1 -0
- package/dist/types/components/index.d.ts +2 -0
- package/dist/types/components/index.d.ts.map +1 -0
- package/dist/types/components/ui/alert.d.ts +21 -0
- package/dist/types/components/ui/alert.d.ts.map +1 -0
- package/dist/types/components/ui/badge.d.ts +10 -0
- package/dist/types/components/ui/badge.d.ts.map +1 -0
- package/dist/types/components/ui/button.d.ts +16 -0
- package/dist/types/components/ui/button.d.ts.map +1 -0
- package/dist/types/components/ui/card.d.ts +26 -0
- package/dist/types/components/ui/card.d.ts.map +1 -0
- package/dist/types/components/ui/footer.d.ts +25 -0
- package/dist/types/components/ui/footer.d.ts.map +1 -0
- package/dist/types/components/ui/index.d.ts +9 -0
- package/dist/types/components/ui/index.d.ts.map +1 -0
- package/dist/types/components/ui/input.d.ts +10 -0
- package/dist/types/components/ui/input.d.ts.map +1 -0
- package/dist/types/components/ui/pretty-amount.d.ts +24 -0
- package/dist/types/components/ui/pretty-amount.d.ts.map +1 -0
- package/dist/types/components/ui/textarea.d.ts +10 -0
- package/dist/types/components/ui/textarea.d.ts.map +1 -0
- package/dist/types/index.d.ts +3 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/utils.d.ts +3 -0
- package/dist/types/utils.d.ts.map +1 -0
- 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 @@
|
|
|
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 @@
|
|
|
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 @@
|
|
|
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
|