@hobenakicoffee/libraries 1.28.0 → 1.29.0
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/package.json +5 -39
- package/src/nuqs/common.ts +12 -0
- package/src/nuqs/index.ts +2 -0
- package/src/nuqs/transactions.ts +31 -0
- package/src/components/ui/alert-dialog.tsx +0 -196
- package/src/components/ui/alert.tsx +0 -76
- package/src/components/ui/avatar.tsx +0 -110
- package/src/components/ui/badge.tsx +0 -49
- package/src/components/ui/breadcrumb.tsx +0 -122
- package/src/components/ui/button-group.tsx +0 -82
- package/src/components/ui/card.tsx +0 -100
- package/src/components/ui/chart.tsx +0 -364
- package/src/components/ui/checkbox.tsx +0 -30
- package/src/components/ui/dialog.tsx +0 -162
- package/src/components/ui/drawer.tsx +0 -126
- package/src/components/ui/dropdown-menu.tsx +0 -267
- package/src/components/ui/empty-minimal.tsx +0 -20
- package/src/components/ui/empty.tsx +0 -101
- package/src/components/ui/field.tsx +0 -235
- package/src/components/ui/input-group.tsx +0 -170
- package/src/components/ui/input-otp.tsx +0 -84
- package/src/components/ui/input.tsx +0 -37
- package/src/components/ui/item.tsx +0 -196
- package/src/components/ui/label.tsx +0 -19
- package/src/components/ui/popover.tsx +0 -87
- package/src/components/ui/radio-group.tsx +0 -47
- package/src/components/ui/select.tsx +0 -205
- package/src/components/ui/separator.tsx +0 -26
- package/src/components/ui/sheet.tsx +0 -141
- package/src/components/ui/sidebar.tsx +0 -699
- package/src/components/ui/skeleton.tsx +0 -13
- package/src/components/ui/sonner.tsx +0 -74
- package/src/components/ui/table.tsx +0 -114
- package/src/components/ui/tabs.tsx +0 -88
- package/src/components/ui/textarea.tsx +0 -35
- package/src/components/ui/toggle-group.tsx +0 -91
- package/src/components/ui/toggle.tsx +0 -44
- package/src/components/ui/tooltip.tsx +0 -59
package/package.json
CHANGED
|
@@ -1,54 +1,18 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@hobenakicoffee/libraries",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.29.0",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"types": "src/index.ts",
|
|
6
6
|
"exports": {
|
|
7
7
|
".": "./src/index.ts",
|
|
8
8
|
"./components/turnstile-captcha": "./src/components/turnstile-captcha.tsx",
|
|
9
|
-
"./components/ui/alert": "./src/components/ui/alert.tsx",
|
|
10
|
-
"./components/ui/alert-dialog": "./src/components/ui/alert-dialog.tsx",
|
|
11
|
-
"./components/ui/avatar": "./src/components/ui/avatar.tsx",
|
|
12
|
-
"./components/ui/badge": "./src/components/ui/badge.tsx",
|
|
13
|
-
"./components/ui/breadcrumb": "./src/components/ui/breadcrumb.tsx",
|
|
14
|
-
"./components/ui/button": "./src/components/ui/button.tsx",
|
|
15
|
-
"./components/ui/button-group": "./src/components/ui/button-group.tsx",
|
|
16
|
-
"./components/ui/calendar": "./src/components/ui/calendar.tsx",
|
|
17
|
-
"./components/ui/card": "./src/components/ui/card.tsx",
|
|
18
|
-
"./components/ui/chart": "./src/components/ui/chart.tsx",
|
|
19
|
-
"./components/ui/checkbox": "./src/components/ui/checkbox.tsx",
|
|
20
|
-
"./components/ui/dialog": "./src/components/ui/dialog.tsx",
|
|
21
|
-
"./components/ui/drawer": "./src/components/ui/drawer.tsx",
|
|
22
|
-
"./components/ui/dropdown-menu": "./src/components/ui/dropdown-menu.tsx",
|
|
23
|
-
"./components/ui/empty": "./src/components/ui/empty.tsx",
|
|
24
|
-
"./components/ui/empty-minimal": "./src/components/ui/empty-minimal.tsx",
|
|
25
|
-
"./components/ui/field": "./src/components/ui/field.tsx",
|
|
26
|
-
"./components/ui/input": "./src/components/ui/input.tsx",
|
|
27
|
-
"./components/ui/input-group": "./src/components/ui/input-group.tsx",
|
|
28
|
-
"./components/ui/input-otp": "./src/components/ui/input-otp.tsx",
|
|
29
|
-
"./components/ui/item": "./src/components/ui/item.tsx",
|
|
30
|
-
"./components/ui/label": "./src/components/ui/label.tsx",
|
|
31
|
-
"./components/ui/popover": "./src/components/ui/popover.tsx",
|
|
32
|
-
"./components/ui/radio-group": "./src/components/ui/radio-group.tsx",
|
|
33
|
-
"./components/ui/select": "./src/components/ui/select.tsx",
|
|
34
|
-
"./components/ui/separator": "./src/components/ui/separator.tsx",
|
|
35
|
-
"./components/ui/sheet": "./src/components/ui/sheet.tsx",
|
|
36
|
-
"./components/ui/sidebar": "./src/components/ui/sidebar.tsx",
|
|
37
|
-
"./components/ui/skeleton": "./src/components/ui/skeleton.tsx",
|
|
38
|
-
"./components/ui/sonner": "./src/components/ui/sonner.tsx",
|
|
39
|
-
"./components/ui/spinner": "./src/components/ui/spinner.tsx",
|
|
40
|
-
"./components/ui/table": "./src/components/ui/table.tsx",
|
|
41
|
-
"./components/ui/tabs": "./src/components/ui/tabs.tsx",
|
|
42
|
-
"./components/ui/textarea": "./src/components/ui/textarea.tsx",
|
|
43
|
-
"./components/ui/toggle": "./src/components/ui/toggle.tsx",
|
|
44
|
-
"./components/ui/toggle-group": "./src/components/ui/toggle-group.tsx",
|
|
45
|
-
"./components/ui/tooltip": "./src/components/ui/tooltip.tsx",
|
|
46
9
|
"./constants": "./src/constants/index.ts",
|
|
47
10
|
"./lib/utils": "./src/lib/utils.ts",
|
|
48
11
|
"./moderation": "./src/moderation/index.ts",
|
|
49
12
|
"./providers/theme-provider": "./src/providers/theme-provider.tsx",
|
|
50
13
|
"./types": "./src/types/index.ts",
|
|
51
14
|
"./utils": "./src/utils/index.ts",
|
|
15
|
+
"./nuqs": "./src/nuqs/index.ts",
|
|
52
16
|
"./scripts": "./src/scripts/index.ts"
|
|
53
17
|
},
|
|
54
18
|
"files": [
|
|
@@ -103,6 +67,7 @@
|
|
|
103
67
|
"input-otp": "^1.4.2",
|
|
104
68
|
"install": "^0.13.0",
|
|
105
69
|
"next-themes": "^0.4.6",
|
|
70
|
+
"nuqs": "^2.8.9",
|
|
106
71
|
"openai": "^6.22.0",
|
|
107
72
|
"radix-ui": "^1.4.3",
|
|
108
73
|
"react": "^19.2.4",
|
|
@@ -114,6 +79,7 @@
|
|
|
114
79
|
"tailwind-merge": "^3.5.0",
|
|
115
80
|
"tailwindcss": "^4.2.1",
|
|
116
81
|
"tw-animate-css": "^1.4.0",
|
|
117
|
-
"vaul": "^1.1.2"
|
|
82
|
+
"vaul": "^1.1.2",
|
|
83
|
+
"zod": "^4.3.6"
|
|
118
84
|
}
|
|
119
85
|
}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { type inferParserType, parseAsJson, parseAsStringLiteral } from "nuqs";
|
|
2
|
+
import { z } from "zod";
|
|
3
|
+
|
|
4
|
+
export const parseAsSortOrder = parseAsStringLiteral(["asc", "desc"]);
|
|
5
|
+
export type SortOrder = inferParserType<typeof parseAsSortOrder>;
|
|
6
|
+
|
|
7
|
+
export const parseAsDateRange = parseAsJson(
|
|
8
|
+
z.object({
|
|
9
|
+
from: z.date(),
|
|
10
|
+
to: z.date().optional(),
|
|
11
|
+
})
|
|
12
|
+
);
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import {
|
|
2
|
+
type inferParserType,
|
|
3
|
+
parseAsArrayOf,
|
|
4
|
+
parseAsStringLiteral,
|
|
5
|
+
} from "nuqs";
|
|
6
|
+
import {
|
|
7
|
+
PaymentProviders,
|
|
8
|
+
PaymentStatuses,
|
|
9
|
+
PaymentTypes,
|
|
10
|
+
ServiceTypes,
|
|
11
|
+
} from "@/constants";
|
|
12
|
+
import { parseAsDateRange, parseAsSortOrder } from "./common";
|
|
13
|
+
|
|
14
|
+
export const transactionsFilterParsers = {
|
|
15
|
+
statuses: parseAsArrayOf(
|
|
16
|
+
parseAsStringLiteral(Object.values(PaymentStatuses))
|
|
17
|
+
),
|
|
18
|
+
types: parseAsArrayOf(parseAsStringLiteral(Object.values(PaymentTypes))),
|
|
19
|
+
serviceTypes: parseAsArrayOf(
|
|
20
|
+
parseAsStringLiteral(Object.values(ServiceTypes))
|
|
21
|
+
),
|
|
22
|
+
providers: parseAsArrayOf(
|
|
23
|
+
parseAsStringLiteral(Object.values(PaymentProviders))
|
|
24
|
+
),
|
|
25
|
+
dateRange: parseAsDateRange,
|
|
26
|
+
amountSort: parseAsSortOrder,
|
|
27
|
+
};
|
|
28
|
+
|
|
29
|
+
export type TransactionFilters = inferParserType<
|
|
30
|
+
typeof transactionsFilterParsers
|
|
31
|
+
>;
|
|
@@ -1,196 +0,0 @@
|
|
|
1
|
-
import { AlertDialog as AlertDialogPrimitive } from "radix-ui";
|
|
2
|
-
import type * as React from "react";
|
|
3
|
-
import { Button } from "@/components/ui/button";
|
|
4
|
-
import { cn } from "@/lib/utils";
|
|
5
|
-
|
|
6
|
-
function AlertDialog({
|
|
7
|
-
...props
|
|
8
|
-
}: React.ComponentProps<typeof AlertDialogPrimitive.Root>) {
|
|
9
|
-
return <AlertDialogPrimitive.Root data-slot="alert-dialog" {...props} />;
|
|
10
|
-
}
|
|
11
|
-
|
|
12
|
-
function AlertDialogTrigger({
|
|
13
|
-
...props
|
|
14
|
-
}: React.ComponentProps<typeof AlertDialogPrimitive.Trigger>) {
|
|
15
|
-
return (
|
|
16
|
-
<AlertDialogPrimitive.Trigger data-slot="alert-dialog-trigger" {...props} />
|
|
17
|
-
);
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
function AlertDialogPortal({
|
|
21
|
-
...props
|
|
22
|
-
}: React.ComponentProps<typeof AlertDialogPrimitive.Portal>) {
|
|
23
|
-
return (
|
|
24
|
-
<AlertDialogPrimitive.Portal data-slot="alert-dialog-portal" {...props} />
|
|
25
|
-
);
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
function AlertDialogOverlay({
|
|
29
|
-
className,
|
|
30
|
-
...props
|
|
31
|
-
}: React.ComponentProps<typeof AlertDialogPrimitive.Overlay>) {
|
|
32
|
-
return (
|
|
33
|
-
<AlertDialogPrimitive.Overlay
|
|
34
|
-
className={cn(
|
|
35
|
-
"data-closed:fade-out-0 data-open:fade-in-0 fixed inset-0 z-50 bg-black/10 duration-100 data-closed:animate-out data-open:animate-in supports-backdrop-filter:backdrop-blur-xs",
|
|
36
|
-
className
|
|
37
|
-
)}
|
|
38
|
-
data-slot="alert-dialog-overlay"
|
|
39
|
-
{...props}
|
|
40
|
-
/>
|
|
41
|
-
);
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
function AlertDialogContent({
|
|
45
|
-
className,
|
|
46
|
-
size = "default",
|
|
47
|
-
...props
|
|
48
|
-
}: React.ComponentProps<typeof AlertDialogPrimitive.Content> & {
|
|
49
|
-
size?: "default" | "sm";
|
|
50
|
-
}) {
|
|
51
|
-
return (
|
|
52
|
-
<AlertDialogPortal>
|
|
53
|
-
<AlertDialogOverlay />
|
|
54
|
-
<AlertDialogPrimitive.Content
|
|
55
|
-
className={cn(
|
|
56
|
-
"data-closed:fade-out-0 data-open:fade-in-0 data-closed:zoom-out-95 data-open:zoom-in-95 group/alert-dialog-content fixed top-1/2 left-1/2 z-50 grid w-full -translate-x-1/2 -translate-y-1/2 gap-6 rounded-xl bg-background p-6 outline-none ring-1 ring-foreground/10 duration-100 data-[size=default]:max-w-xs data-[size=sm]:max-w-xs data-closed:animate-out data-open:animate-in data-[size=default]:sm:max-w-lg",
|
|
57
|
-
className
|
|
58
|
-
)}
|
|
59
|
-
data-size={size}
|
|
60
|
-
data-slot="alert-dialog-content"
|
|
61
|
-
{...props}
|
|
62
|
-
/>
|
|
63
|
-
</AlertDialogPortal>
|
|
64
|
-
);
|
|
65
|
-
}
|
|
66
|
-
|
|
67
|
-
function AlertDialogHeader({
|
|
68
|
-
className,
|
|
69
|
-
...props
|
|
70
|
-
}: React.ComponentProps<"div">) {
|
|
71
|
-
return (
|
|
72
|
-
<div
|
|
73
|
-
className={cn(
|
|
74
|
-
"grid grid-rows-[auto_1fr] place-items-center gap-1.5 text-center has-data-[slot=alert-dialog-media]:grid-rows-[auto_auto_1fr] has-data-[slot=alert-dialog-media]:gap-x-6 sm:group-data-[size=default]/alert-dialog-content:place-items-start sm:group-data-[size=default]/alert-dialog-content:text-left sm:group-data-[size=default]/alert-dialog-content:has-data-[slot=alert-dialog-media]:grid-rows-[auto_1fr]",
|
|
75
|
-
className
|
|
76
|
-
)}
|
|
77
|
-
data-slot="alert-dialog-header"
|
|
78
|
-
{...props}
|
|
79
|
-
/>
|
|
80
|
-
);
|
|
81
|
-
}
|
|
82
|
-
|
|
83
|
-
function AlertDialogFooter({
|
|
84
|
-
className,
|
|
85
|
-
...props
|
|
86
|
-
}: React.ComponentProps<"div">) {
|
|
87
|
-
return (
|
|
88
|
-
<div
|
|
89
|
-
className={cn(
|
|
90
|
-
"flex flex-col-reverse gap-2 group-data-[size=sm]/alert-dialog-content:grid group-data-[size=sm]/alert-dialog-content:grid-cols-2 sm:flex-row sm:justify-end",
|
|
91
|
-
className
|
|
92
|
-
)}
|
|
93
|
-
data-slot="alert-dialog-footer"
|
|
94
|
-
{...props}
|
|
95
|
-
/>
|
|
96
|
-
);
|
|
97
|
-
}
|
|
98
|
-
|
|
99
|
-
function AlertDialogMedia({
|
|
100
|
-
className,
|
|
101
|
-
...props
|
|
102
|
-
}: React.ComponentProps<"div">) {
|
|
103
|
-
return (
|
|
104
|
-
<div
|
|
105
|
-
className={cn(
|
|
106
|
-
"mb-2 inline-flex size-16 items-center justify-center rounded-md bg-muted sm:group-data-[size=default]/alert-dialog-content:row-span-2 *:[svg:not([class*='size-'])]:size-8",
|
|
107
|
-
className
|
|
108
|
-
)}
|
|
109
|
-
data-slot="alert-dialog-media"
|
|
110
|
-
{...props}
|
|
111
|
-
/>
|
|
112
|
-
);
|
|
113
|
-
}
|
|
114
|
-
|
|
115
|
-
function AlertDialogTitle({
|
|
116
|
-
className,
|
|
117
|
-
...props
|
|
118
|
-
}: React.ComponentProps<typeof AlertDialogPrimitive.Title>) {
|
|
119
|
-
return (
|
|
120
|
-
<AlertDialogPrimitive.Title
|
|
121
|
-
className={cn(
|
|
122
|
-
"font-medium text-lg sm:group-data-[size=default]/alert-dialog-content:group-has-data-[slot=alert-dialog-media]/alert-dialog-content:col-start-2",
|
|
123
|
-
className
|
|
124
|
-
)}
|
|
125
|
-
data-slot="alert-dialog-title"
|
|
126
|
-
{...props}
|
|
127
|
-
/>
|
|
128
|
-
);
|
|
129
|
-
}
|
|
130
|
-
|
|
131
|
-
function AlertDialogDescription({
|
|
132
|
-
className,
|
|
133
|
-
...props
|
|
134
|
-
}: React.ComponentProps<typeof AlertDialogPrimitive.Description>) {
|
|
135
|
-
return (
|
|
136
|
-
<AlertDialogPrimitive.Description
|
|
137
|
-
className={cn(
|
|
138
|
-
"text-balance text-muted-foreground text-sm md:text-pretty *:[a]:underline *:[a]:underline-offset-3 *:[a]:hover:text-foreground",
|
|
139
|
-
className
|
|
140
|
-
)}
|
|
141
|
-
data-slot="alert-dialog-description"
|
|
142
|
-
{...props}
|
|
143
|
-
/>
|
|
144
|
-
);
|
|
145
|
-
}
|
|
146
|
-
|
|
147
|
-
function AlertDialogAction({
|
|
148
|
-
className,
|
|
149
|
-
variant = "default",
|
|
150
|
-
size = "default",
|
|
151
|
-
...props
|
|
152
|
-
}: React.ComponentProps<typeof AlertDialogPrimitive.Action> &
|
|
153
|
-
Pick<React.ComponentProps<typeof Button>, "variant" | "size">) {
|
|
154
|
-
return (
|
|
155
|
-
<Button asChild size={size} variant={variant}>
|
|
156
|
-
<AlertDialogPrimitive.Action
|
|
157
|
-
className={cn(className)}
|
|
158
|
-
data-slot="alert-dialog-action"
|
|
159
|
-
{...props}
|
|
160
|
-
/>
|
|
161
|
-
</Button>
|
|
162
|
-
);
|
|
163
|
-
}
|
|
164
|
-
|
|
165
|
-
function AlertDialogCancel({
|
|
166
|
-
className,
|
|
167
|
-
variant = "outline",
|
|
168
|
-
size = "default",
|
|
169
|
-
...props
|
|
170
|
-
}: React.ComponentProps<typeof AlertDialogPrimitive.Cancel> &
|
|
171
|
-
Pick<React.ComponentProps<typeof Button>, "variant" | "size">) {
|
|
172
|
-
return (
|
|
173
|
-
<Button asChild size={size} variant={variant}>
|
|
174
|
-
<AlertDialogPrimitive.Cancel
|
|
175
|
-
className={cn(className)}
|
|
176
|
-
data-slot="alert-dialog-cancel"
|
|
177
|
-
{...props}
|
|
178
|
-
/>
|
|
179
|
-
</Button>
|
|
180
|
-
);
|
|
181
|
-
}
|
|
182
|
-
|
|
183
|
-
export {
|
|
184
|
-
AlertDialog,
|
|
185
|
-
AlertDialogAction,
|
|
186
|
-
AlertDialogCancel,
|
|
187
|
-
AlertDialogContent,
|
|
188
|
-
AlertDialogDescription,
|
|
189
|
-
AlertDialogFooter,
|
|
190
|
-
AlertDialogHeader,
|
|
191
|
-
AlertDialogMedia,
|
|
192
|
-
AlertDialogOverlay,
|
|
193
|
-
AlertDialogPortal,
|
|
194
|
-
AlertDialogTitle,
|
|
195
|
-
AlertDialogTrigger,
|
|
196
|
-
};
|
|
@@ -1,76 +0,0 @@
|
|
|
1
|
-
import { cva, type VariantProps } from "class-variance-authority";
|
|
2
|
-
import type * as React from "react";
|
|
3
|
-
|
|
4
|
-
import { cn } from "@/lib/utils";
|
|
5
|
-
|
|
6
|
-
const alertVariants = cva(
|
|
7
|
-
"group/alert relative grid w-full gap-0.5 rounded-lg border px-3 py-3 text-left text-xs has-data-[slot=alert-action]:relative has-[>svg]:grid-cols-[auto_1fr] has-[>svg]:gap-x-2.5 has-data-[slot=alert-action]:pr-18 *:[svg:not([class*='size-'])]:size-4 *:[svg]:row-span-2 *:[svg]:translate-y-0.5 *:[svg]:text-current",
|
|
8
|
-
{
|
|
9
|
-
variants: {
|
|
10
|
-
variant: {
|
|
11
|
-
default: "bg-card text-card-foreground",
|
|
12
|
-
destructive:
|
|
13
|
-
"border-destructive/15 bg-destructive/5 text-destructive *:data-[slot=alert-description]:text-destructive/90 *:[svg]:text-current",
|
|
14
|
-
},
|
|
15
|
-
},
|
|
16
|
-
defaultVariants: {
|
|
17
|
-
variant: "default",
|
|
18
|
-
},
|
|
19
|
-
}
|
|
20
|
-
);
|
|
21
|
-
|
|
22
|
-
function Alert({
|
|
23
|
-
className,
|
|
24
|
-
variant,
|
|
25
|
-
...props
|
|
26
|
-
}: React.ComponentProps<"div"> & VariantProps<typeof alertVariants>) {
|
|
27
|
-
return (
|
|
28
|
-
<div
|
|
29
|
-
className={cn(alertVariants({ variant }), className)}
|
|
30
|
-
data-slot="alert"
|
|
31
|
-
role="alert"
|
|
32
|
-
{...props}
|
|
33
|
-
/>
|
|
34
|
-
);
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
function AlertTitle({ className, ...props }: React.ComponentProps<"div">) {
|
|
38
|
-
return (
|
|
39
|
-
<div
|
|
40
|
-
className={cn(
|
|
41
|
-
"font-medium group-has-[>svg]/alert:col-start-2 [&_a]:underline [&_a]:underline-offset-3 [&_a]:hover:text-foreground",
|
|
42
|
-
className
|
|
43
|
-
)}
|
|
44
|
-
data-slot="alert-title"
|
|
45
|
-
{...props}
|
|
46
|
-
/>
|
|
47
|
-
);
|
|
48
|
-
}
|
|
49
|
-
|
|
50
|
-
function AlertDescription({
|
|
51
|
-
className,
|
|
52
|
-
...props
|
|
53
|
-
}: React.ComponentProps<"div">) {
|
|
54
|
-
return (
|
|
55
|
-
<div
|
|
56
|
-
className={cn(
|
|
57
|
-
"text-balance text-muted-foreground text-sm md:text-pretty [&_a]:underline [&_a]:underline-offset-3 [&_a]:hover:text-foreground [&_p:not(:last-child)]:mb-4",
|
|
58
|
-
className
|
|
59
|
-
)}
|
|
60
|
-
data-slot="alert-description"
|
|
61
|
-
{...props}
|
|
62
|
-
/>
|
|
63
|
-
);
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
function AlertAction({ className, ...props }: React.ComponentProps<"div">) {
|
|
67
|
-
return (
|
|
68
|
-
<div
|
|
69
|
-
className={cn("absolute top-2.5 right-3", className)}
|
|
70
|
-
data-slot="alert-action"
|
|
71
|
-
{...props}
|
|
72
|
-
/>
|
|
73
|
-
);
|
|
74
|
-
}
|
|
75
|
-
|
|
76
|
-
export { Alert, AlertTitle, AlertDescription, AlertAction };
|
|
@@ -1,110 +0,0 @@
|
|
|
1
|
-
import { Avatar as AvatarPrimitive } from "radix-ui";
|
|
2
|
-
import type * as React from "react";
|
|
3
|
-
|
|
4
|
-
import { cn } from "@/lib/utils";
|
|
5
|
-
|
|
6
|
-
function Avatar({
|
|
7
|
-
className,
|
|
8
|
-
size = "default",
|
|
9
|
-
...props
|
|
10
|
-
}: React.ComponentProps<typeof AvatarPrimitive.Root> & {
|
|
11
|
-
size?: "default" | "sm" | "lg";
|
|
12
|
-
}) {
|
|
13
|
-
return (
|
|
14
|
-
<AvatarPrimitive.Root
|
|
15
|
-
className={cn(
|
|
16
|
-
"group/avatar relative flex size-8 shrink-0 select-none rounded-full after:absolute after:inset-0 after:rounded-full after:border after:border-border after:mix-blend-darken data-[size=lg]:size-10 data-[size=sm]:size-6 dark:after:mix-blend-lighten",
|
|
17
|
-
className
|
|
18
|
-
)}
|
|
19
|
-
data-size={size}
|
|
20
|
-
data-slot="avatar"
|
|
21
|
-
{...props}
|
|
22
|
-
/>
|
|
23
|
-
);
|
|
24
|
-
}
|
|
25
|
-
|
|
26
|
-
function AvatarImage({
|
|
27
|
-
className,
|
|
28
|
-
...props
|
|
29
|
-
}: React.ComponentProps<typeof AvatarPrimitive.Image>) {
|
|
30
|
-
return (
|
|
31
|
-
<AvatarPrimitive.Image
|
|
32
|
-
className={cn(
|
|
33
|
-
"aspect-square size-full rounded-full object-cover",
|
|
34
|
-
className
|
|
35
|
-
)}
|
|
36
|
-
data-slot="avatar-image"
|
|
37
|
-
{...props}
|
|
38
|
-
/>
|
|
39
|
-
);
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
function AvatarFallback({
|
|
43
|
-
className,
|
|
44
|
-
...props
|
|
45
|
-
}: React.ComponentProps<typeof AvatarPrimitive.Fallback>) {
|
|
46
|
-
return (
|
|
47
|
-
<AvatarPrimitive.Fallback
|
|
48
|
-
className={cn(
|
|
49
|
-
"flex size-full items-center justify-center rounded-full bg-muted text-muted-foreground text-sm group-data-[size=sm]/avatar:text-xs",
|
|
50
|
-
className
|
|
51
|
-
)}
|
|
52
|
-
data-slot="avatar-fallback"
|
|
53
|
-
{...props}
|
|
54
|
-
/>
|
|
55
|
-
);
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
function AvatarBadge({ className, ...props }: React.ComponentProps<"span">) {
|
|
59
|
-
return (
|
|
60
|
-
<span
|
|
61
|
-
className={cn(
|
|
62
|
-
"absolute right-0 bottom-0 z-10 inline-flex select-none items-center justify-center rounded-full bg-primary text-primary-foreground bg-blend-color ring-2 ring-background",
|
|
63
|
-
"group-data-[size=sm]/avatar:size-2 group-data-[size=sm]/avatar:[&>svg]:hidden",
|
|
64
|
-
"group-data-[size=default]/avatar:size-2.5 group-data-[size=default]/avatar:[&>svg]:size-2",
|
|
65
|
-
"group-data-[size=lg]/avatar:size-3 group-data-[size=lg]/avatar:[&>svg]:size-2",
|
|
66
|
-
className
|
|
67
|
-
)}
|
|
68
|
-
data-slot="avatar-badge"
|
|
69
|
-
{...props}
|
|
70
|
-
/>
|
|
71
|
-
);
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
function AvatarGroup({ className, ...props }: React.ComponentProps<"div">) {
|
|
75
|
-
return (
|
|
76
|
-
<div
|
|
77
|
-
className={cn(
|
|
78
|
-
"group/avatar-group flex -gap-x-2 *:data-[slot=avatar]:ring-2 *:data-[slot=avatar]:ring-background",
|
|
79
|
-
className
|
|
80
|
-
)}
|
|
81
|
-
data-slot="avatar-group"
|
|
82
|
-
{...props}
|
|
83
|
-
/>
|
|
84
|
-
);
|
|
85
|
-
}
|
|
86
|
-
|
|
87
|
-
function AvatarGroupCount({
|
|
88
|
-
className,
|
|
89
|
-
...props
|
|
90
|
-
}: React.ComponentProps<"div">) {
|
|
91
|
-
return (
|
|
92
|
-
<div
|
|
93
|
-
className={cn(
|
|
94
|
-
"relative flex size-8 shrink-0 items-center justify-center rounded-full bg-muted text-muted-foreground text-sm ring-2 ring-background group-has-data-[size=lg]/avatar-group:size-10 group-has-data-[size=sm]/avatar-group:size-6 [&>svg]:size-4 group-has-data-[size=lg]/avatar-group:[&>svg]:size-5 group-has-data-[size=sm]/avatar-group:[&>svg]:size-3",
|
|
95
|
-
className
|
|
96
|
-
)}
|
|
97
|
-
data-slot="avatar-group-count"
|
|
98
|
-
{...props}
|
|
99
|
-
/>
|
|
100
|
-
);
|
|
101
|
-
}
|
|
102
|
-
|
|
103
|
-
export {
|
|
104
|
-
Avatar,
|
|
105
|
-
AvatarImage,
|
|
106
|
-
AvatarFallback,
|
|
107
|
-
AvatarGroup,
|
|
108
|
-
AvatarGroupCount,
|
|
109
|
-
AvatarBadge,
|
|
110
|
-
};
|
|
@@ -1,49 +0,0 @@
|
|
|
1
|
-
import { cva, type VariantProps } from "class-variance-authority";
|
|
2
|
-
import { Slot } from "radix-ui";
|
|
3
|
-
import type * as React from "react";
|
|
4
|
-
|
|
5
|
-
import { cn } from "@/lib/utils";
|
|
6
|
-
|
|
7
|
-
const badgeVariants = cva(
|
|
8
|
-
"group/badge inline-flex h-6 w-fit shrink-0 items-center justify-center gap-1 overflow-hidden whitespace-nowrap rounded-4xl px-2 py-1 font-normal text-xs uppercase ring-1 transition-all transition-colors focus-visible:border-ring focus-visible:ring-ring focus-visible:ring-ring has-data-[icon=inline-end]:pr-1.5 has-data-[icon=inline-start]:pl-1.5 aria-invalid:border-destructive aria-invalid:ring-destructive/20 dark:aria-invalid:ring-destructive/40 [&>svg]:pointer-events-none [&>svg]:size-3!",
|
|
9
|
-
{
|
|
10
|
-
variants: {
|
|
11
|
-
variant: {
|
|
12
|
-
default: "bg-primary text-primary-foreground [a]:hover:bg-primary/80",
|
|
13
|
-
secondary:
|
|
14
|
-
"bg-secondary text-secondary-foreground [a]:hover:bg-secondary/80",
|
|
15
|
-
destructive:
|
|
16
|
-
"bg-destructive/10 text-destructive focus-visible:ring-destructive/20 dark:bg-destructive/20 dark:focus-visible:ring-destructive/40 [a]:hover:bg-destructive/20",
|
|
17
|
-
outline:
|
|
18
|
-
"border-border text-foreground [a]:hover:bg-muted [a]:hover:text-muted-foreground",
|
|
19
|
-
ghost:
|
|
20
|
-
"hover:bg-muted hover:text-muted-foreground dark:hover:bg-muted/50",
|
|
21
|
-
link: "text-primary underline-offset-4 hover:underline",
|
|
22
|
-
},
|
|
23
|
-
},
|
|
24
|
-
defaultVariants: {
|
|
25
|
-
variant: "default",
|
|
26
|
-
},
|
|
27
|
-
}
|
|
28
|
-
);
|
|
29
|
-
|
|
30
|
-
function Badge({
|
|
31
|
-
className,
|
|
32
|
-
variant = "default",
|
|
33
|
-
asChild = false,
|
|
34
|
-
...props
|
|
35
|
-
}: React.ComponentProps<"span"> &
|
|
36
|
-
VariantProps<typeof badgeVariants> & { asChild?: boolean }) {
|
|
37
|
-
const Comp = asChild ? Slot.Root : "span";
|
|
38
|
-
|
|
39
|
-
return (
|
|
40
|
-
<Comp
|
|
41
|
-
className={cn(badgeVariants({ variant }), className)}
|
|
42
|
-
data-slot="badge"
|
|
43
|
-
data-variant={variant}
|
|
44
|
-
{...props}
|
|
45
|
-
/>
|
|
46
|
-
);
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
export { Badge, badgeVariants };
|
|
@@ -1,122 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
ArrowRight01Icon,
|
|
3
|
-
MoreHorizontalCircle01Icon,
|
|
4
|
-
} from "@hugeicons/core-free-icons";
|
|
5
|
-
import { HugeiconsIcon } from "@hugeicons/react";
|
|
6
|
-
import { Slot } from "radix-ui";
|
|
7
|
-
import type * as React from "react";
|
|
8
|
-
import { cn } from "@/lib/utils";
|
|
9
|
-
|
|
10
|
-
function Breadcrumb({ className, ...props }: React.ComponentProps<"nav">) {
|
|
11
|
-
return (
|
|
12
|
-
<nav
|
|
13
|
-
aria-label="breadcrumb"
|
|
14
|
-
className={cn(className)}
|
|
15
|
-
data-slot="breadcrumb"
|
|
16
|
-
{...props}
|
|
17
|
-
/>
|
|
18
|
-
);
|
|
19
|
-
}
|
|
20
|
-
|
|
21
|
-
function BreadcrumbList({ className, ...props }: React.ComponentProps<"ol">) {
|
|
22
|
-
return (
|
|
23
|
-
<ol
|
|
24
|
-
className={cn(
|
|
25
|
-
"wrap-break-word flex flex-wrap items-center gap-1.5 text-muted-foreground text-sm sm:gap-2.5",
|
|
26
|
-
className
|
|
27
|
-
)}
|
|
28
|
-
data-slot="breadcrumb-list"
|
|
29
|
-
{...props}
|
|
30
|
-
/>
|
|
31
|
-
);
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
function BreadcrumbItem({ className, ...props }: React.ComponentProps<"li">) {
|
|
35
|
-
return (
|
|
36
|
-
<li
|
|
37
|
-
className={cn("inline-flex items-center gap-1.5", className)}
|
|
38
|
-
data-slot="breadcrumb-item"
|
|
39
|
-
{...props}
|
|
40
|
-
/>
|
|
41
|
-
);
|
|
42
|
-
}
|
|
43
|
-
|
|
44
|
-
function BreadcrumbLink({
|
|
45
|
-
asChild,
|
|
46
|
-
className,
|
|
47
|
-
...props
|
|
48
|
-
}: React.ComponentProps<"a"> & {
|
|
49
|
-
asChild?: boolean;
|
|
50
|
-
}) {
|
|
51
|
-
const Comp = asChild ? Slot.Root : "a";
|
|
52
|
-
|
|
53
|
-
return (
|
|
54
|
-
<Comp
|
|
55
|
-
className={cn("transition-colors hover:text-foreground", className)}
|
|
56
|
-
data-slot="breadcrumb-link"
|
|
57
|
-
{...props}
|
|
58
|
-
/>
|
|
59
|
-
);
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
function BreadcrumbPage({ className, ...props }: React.ComponentProps<"span">) {
|
|
63
|
-
return (
|
|
64
|
-
<span
|
|
65
|
-
aria-current="page"
|
|
66
|
-
aria-disabled="true"
|
|
67
|
-
className={cn("font-normal text-foreground", className)}
|
|
68
|
-
data-slot="breadcrumb-page"
|
|
69
|
-
role="link"
|
|
70
|
-
{...props}
|
|
71
|
-
/>
|
|
72
|
-
);
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
function BreadcrumbSeparator({
|
|
76
|
-
children,
|
|
77
|
-
className,
|
|
78
|
-
...props
|
|
79
|
-
}: React.ComponentProps<"li">) {
|
|
80
|
-
return (
|
|
81
|
-
<li
|
|
82
|
-
aria-hidden="true"
|
|
83
|
-
className={cn("[&>svg]:size-3.5", className)}
|
|
84
|
-
data-slot="breadcrumb-separator"
|
|
85
|
-
role="presentation"
|
|
86
|
-
{...props}
|
|
87
|
-
>
|
|
88
|
-
{children ?? <HugeiconsIcon icon={ArrowRight01Icon} strokeWidth={2} />}
|
|
89
|
-
</li>
|
|
90
|
-
);
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
function BreadcrumbEllipsis({
|
|
94
|
-
className,
|
|
95
|
-
...props
|
|
96
|
-
}: React.ComponentProps<"span">) {
|
|
97
|
-
return (
|
|
98
|
-
<span
|
|
99
|
-
aria-hidden="true"
|
|
100
|
-
className={cn(
|
|
101
|
-
"flex size-5 items-center justify-center [&>svg]:size-4",
|
|
102
|
-
className
|
|
103
|
-
)}
|
|
104
|
-
data-slot="breadcrumb-ellipsis"
|
|
105
|
-
role="presentation"
|
|
106
|
-
{...props}
|
|
107
|
-
>
|
|
108
|
-
<HugeiconsIcon icon={MoreHorizontalCircle01Icon} strokeWidth={2} />
|
|
109
|
-
<span className="sr-only">More</span>
|
|
110
|
-
</span>
|
|
111
|
-
);
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
export {
|
|
115
|
-
Breadcrumb,
|
|
116
|
-
BreadcrumbList,
|
|
117
|
-
BreadcrumbItem,
|
|
118
|
-
BreadcrumbLink,
|
|
119
|
-
BreadcrumbPage,
|
|
120
|
-
BreadcrumbSeparator,
|
|
121
|
-
BreadcrumbEllipsis,
|
|
122
|
-
};
|