@srcroot/ui 0.0.54 → 0.0.56
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/README.md +151 -151
- package/dist/index.d.ts +0 -0
- package/dist/index.js +55 -1
- package/package.json +7 -2
- package/src/registry/analytics/google-analytics.tsx +36 -39
- package/src/registry/analytics/google-tag-manager.tsx +62 -65
- package/src/registry/analytics/meta-pixel.tsx +44 -47
- package/src/registry/analytics/microsoft-clarity.tsx +31 -34
- package/src/registry/analytics/tiktok-pixel.tsx +34 -37
- package/src/registry/lib/utils.ts +0 -0
- package/src/registry/themes/v3/blue.css +157 -157
- package/src/registry/themes/v3/glass.css +153 -153
- package/src/registry/themes/v3/gray.css +157 -157
- package/src/registry/themes/v3/green.css +157 -157
- package/src/registry/themes/v3/neutral.css +157 -157
- package/src/registry/themes/v3/orange.css +157 -157
- package/src/registry/themes/v3/rose.css +157 -157
- package/src/registry/themes/v3/slate.css +157 -157
- package/src/registry/themes/v3/stone.css +157 -157
- package/src/registry/themes/v3/violet.css +186 -186
- package/src/registry/themes/v3/zinc.css +157 -157
- package/src/registry/themes/v4/blue.css +184 -184
- package/src/registry/themes/v4/glass.css +180 -180
- package/src/registry/themes/v4/gray.css +184 -184
- package/src/registry/themes/v4/green.css +184 -184
- package/src/registry/themes/v4/neutral.css +184 -184
- package/src/registry/themes/v4/orange.css +184 -184
- package/src/registry/themes/v4/rose.css +184 -184
- package/src/registry/themes/v4/slate.css +184 -184
- package/src/registry/themes/v4/stone.css +184 -184
- package/src/registry/themes/v4/violet.css +184 -184
- package/src/registry/themes/v4/zinc.css +184 -184
- package/src/registry/ui/accordion.tsx +164 -165
- package/src/registry/ui/alert-dialog.tsx +213 -214
- package/src/registry/ui/alert.tsx +73 -76
- package/src/registry/ui/aspect-ratio.tsx +44 -47
- package/src/registry/ui/avatar.tsx +96 -97
- package/src/registry/ui/badge.tsx +52 -55
- package/src/registry/ui/breadcrumb.tsx +147 -150
- package/src/registry/ui/button-group.tsx +64 -67
- package/src/registry/ui/button.tsx +71 -72
- package/src/registry/ui/calendar.tsx +514 -515
- package/src/registry/ui/card.tsx +88 -91
- package/src/registry/ui/carousel.tsx +214 -214
- package/src/registry/ui/chart.tsx +373 -373
- package/src/registry/ui/chatbot.tsx +86 -13
- package/src/registry/ui/checkbox.tsx +93 -94
- package/src/registry/ui/collapsible.tsx +107 -108
- package/src/registry/ui/combobox.tsx +171 -171
- package/src/registry/ui/command.tsx +300 -300
- package/src/registry/ui/container.tsx +44 -47
- package/src/registry/ui/context-menu.tsx +221 -221
- package/src/registry/ui/date-picker.tsx +228 -228
- package/src/registry/ui/dialog.tsx +269 -270
- package/src/registry/ui/drawer.tsx +10 -4
- package/src/registry/ui/dropdown-menu.tsx +529 -530
- package/src/registry/ui/empty-state.tsx +0 -2
- package/src/registry/ui/file-upload.tsx +0 -0
- package/src/registry/ui/floating-dock.tsx +0 -0
- package/src/registry/ui/form-field.tsx +91 -94
- package/src/registry/ui/google-analytics.tsx +38 -0
- package/src/registry/ui/google-tag-manager.tsx +64 -0
- package/src/registry/ui/hover-card.tsx +223 -223
- package/src/registry/ui/image.tsx +144 -147
- package/src/registry/ui/input-group.tsx +82 -85
- package/src/registry/ui/input.tsx +125 -125
- package/src/registry/ui/kbd.tsx +60 -63
- package/src/registry/ui/label.tsx +36 -37
- package/src/registry/ui/loading-spinner.tsx +108 -111
- package/src/registry/ui/map.tsx +0 -0
- package/src/registry/ui/marquee.tsx +2 -0
- package/src/registry/ui/menubar.tsx +246 -246
- package/src/registry/ui/meta-pixel.tsx +46 -0
- package/src/registry/ui/microsoft-clarity.tsx +33 -0
- package/src/registry/ui/native-select.tsx +49 -52
- package/src/registry/ui/otp-input.tsx +152 -155
- package/src/registry/ui/pagination.tsx +149 -152
- package/src/registry/ui/patterns.tsx +28 -0
- package/src/registry/ui/popover.tsx +226 -227
- package/src/registry/ui/progress.tsx +51 -52
- package/src/registry/ui/radio.tsx +99 -102
- package/src/registry/ui/resizable.tsx +314 -314
- package/src/registry/ui/scroll-animation.tsx +45 -0
- package/src/registry/ui/scroll-area.tsx +121 -122
- package/src/registry/ui/scroll-to-top.tsx +0 -0
- package/src/registry/ui/search.tsx +147 -150
- package/src/registry/ui/select.tsx +292 -293
- package/src/registry/ui/separator.tsx +46 -47
- package/src/registry/ui/sheet.tsx +6 -3
- package/src/registry/ui/sidebar.tsx +628 -628
- package/src/registry/ui/skeleton.tsx +26 -29
- package/src/registry/ui/slider.tsx +196 -197
- package/src/registry/ui/slot.tsx +69 -72
- package/src/registry/ui/star-rating.tsx +131 -134
- package/src/registry/ui/switch.tsx +72 -73
- package/src/registry/ui/table-of-contents.tsx +96 -96
- package/src/registry/ui/table.tsx +138 -139
- package/src/registry/ui/tabs.tsx +124 -125
- package/src/registry/ui/text.tsx +61 -64
- package/src/registry/ui/textarea.tsx +41 -42
- package/src/registry/ui/theme-switcher.tsx +66 -66
- package/src/registry/ui/tiktok-pixel.tsx +36 -0
- package/src/registry/ui/toast.tsx +97 -98
- package/src/registry/ui/toggle-group.tsx +129 -129
- package/src/registry/ui/toggle.tsx +72 -72
- package/src/registry/ui/tooltip.tsx +143 -144
- package/src/registry/ui/whatsapp.tsx +0 -0
|
@@ -1,152 +1,149 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
import
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
*
|
|
11
|
-
*
|
|
12
|
-
*
|
|
13
|
-
*
|
|
14
|
-
*
|
|
15
|
-
*
|
|
16
|
-
*
|
|
17
|
-
*
|
|
18
|
-
*
|
|
19
|
-
*
|
|
20
|
-
*
|
|
21
|
-
*
|
|
22
|
-
*
|
|
23
|
-
*
|
|
24
|
-
*
|
|
25
|
-
*
|
|
26
|
-
*
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
{
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
<circle cx="
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
PaginationEllipsis,
|
|
151
|
-
}
|
|
152
|
-
|
|
1
|
+
import * as React from "react"
|
|
2
|
+
import { cn } from "@/lib/utils"
|
|
3
|
+
import { buttonVariants } from "./button"
|
|
4
|
+
|
|
5
|
+
interface PaginationProps extends React.HTMLAttributes<HTMLElement> { }
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* Pagination component
|
|
9
|
+
*
|
|
10
|
+
* @example
|
|
11
|
+
* <Pagination>
|
|
12
|
+
* <PaginationContent>
|
|
13
|
+
* <PaginationItem>
|
|
14
|
+
* <PaginationPrevious href="#" />
|
|
15
|
+
* </PaginationItem>
|
|
16
|
+
* <PaginationItem>
|
|
17
|
+
* <PaginationLink href="#">1</PaginationLink>
|
|
18
|
+
* </PaginationItem>
|
|
19
|
+
* <PaginationItem>
|
|
20
|
+
* <PaginationLink href="#" isActive>2</PaginationLink>
|
|
21
|
+
* </PaginationItem>
|
|
22
|
+
* <PaginationItem>
|
|
23
|
+
* <PaginationNext href="#" />
|
|
24
|
+
* </PaginationItem>
|
|
25
|
+
* </PaginationContent>
|
|
26
|
+
* </Pagination>
|
|
27
|
+
*/
|
|
28
|
+
const Pagination = ({ className, ...props }: PaginationProps) => (
|
|
29
|
+
<nav
|
|
30
|
+
role="navigation"
|
|
31
|
+
aria-label="pagination"
|
|
32
|
+
className={cn("mx-auto flex w-full justify-center", className)}
|
|
33
|
+
{...props}
|
|
34
|
+
/>
|
|
35
|
+
)
|
|
36
|
+
Pagination.displayName = "Pagination"
|
|
37
|
+
|
|
38
|
+
const PaginationContent = React.forwardRef<
|
|
39
|
+
HTMLUListElement,
|
|
40
|
+
React.HTMLAttributes<HTMLUListElement>
|
|
41
|
+
>(({ className, ...props }, ref) => (
|
|
42
|
+
<ul
|
|
43
|
+
ref={ref}
|
|
44
|
+
className={cn("flex flex-row items-center gap-1", className)}
|
|
45
|
+
{...props}
|
|
46
|
+
/>
|
|
47
|
+
))
|
|
48
|
+
PaginationContent.displayName = "PaginationContent"
|
|
49
|
+
|
|
50
|
+
const PaginationItem = React.forwardRef<
|
|
51
|
+
HTMLLIElement,
|
|
52
|
+
React.LiHTMLAttributes<HTMLLIElement>
|
|
53
|
+
>(({ className, ...props }, ref) => (
|
|
54
|
+
<li ref={ref} className={cn("", className)} {...props} />
|
|
55
|
+
))
|
|
56
|
+
PaginationItem.displayName = "PaginationItem"
|
|
57
|
+
|
|
58
|
+
interface PaginationLinkProps extends React.AnchorHTMLAttributes<HTMLAnchorElement> {
|
|
59
|
+
isActive?: boolean
|
|
60
|
+
size?: "default" | "sm" | "lg" | "icon"
|
|
61
|
+
children?: React.ReactNode
|
|
62
|
+
className?: string
|
|
63
|
+
href?: string
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
const PaginationLink = ({
|
|
67
|
+
className,
|
|
68
|
+
isActive,
|
|
69
|
+
size = "icon",
|
|
70
|
+
...props
|
|
71
|
+
}: PaginationLinkProps) => (
|
|
72
|
+
<a
|
|
73
|
+
aria-current={isActive ? "page" : undefined}
|
|
74
|
+
className={cn(
|
|
75
|
+
buttonVariants({
|
|
76
|
+
variant: isActive ? "outline" : "ghost",
|
|
77
|
+
size,
|
|
78
|
+
}),
|
|
79
|
+
className
|
|
80
|
+
)}
|
|
81
|
+
{...props}
|
|
82
|
+
/>
|
|
83
|
+
)
|
|
84
|
+
PaginationLink.displayName = "PaginationLink"
|
|
85
|
+
|
|
86
|
+
const PaginationPrevious = ({
|
|
87
|
+
className,
|
|
88
|
+
...props
|
|
89
|
+
}: React.ComponentProps<typeof PaginationLink>) => (
|
|
90
|
+
<PaginationLink
|
|
91
|
+
aria-label="Go to previous page"
|
|
92
|
+
size="default"
|
|
93
|
+
className={cn("gap-1 pl-2.5", className)}
|
|
94
|
+
{...props}
|
|
95
|
+
>
|
|
96
|
+
<svg className="h-4 w-4" fill="none" viewBox="0 0 24 24" stroke="currentColor" strokeWidth={2}>
|
|
97
|
+
<path strokeLinecap="round" strokeLinejoin="round" d="M15 19l-7-7 7-7" />
|
|
98
|
+
</svg>
|
|
99
|
+
<span>Previous</span>
|
|
100
|
+
</PaginationLink>
|
|
101
|
+
)
|
|
102
|
+
PaginationPrevious.displayName = "PaginationPrevious"
|
|
103
|
+
|
|
104
|
+
const PaginationNext = ({
|
|
105
|
+
className,
|
|
106
|
+
...props
|
|
107
|
+
}: React.ComponentProps<typeof PaginationLink>) => (
|
|
108
|
+
<PaginationLink
|
|
109
|
+
aria-label="Go to next page"
|
|
110
|
+
size="default"
|
|
111
|
+
className={cn("gap-1 pr-2.5", className)}
|
|
112
|
+
{...props}
|
|
113
|
+
>
|
|
114
|
+
<span>Next</span>
|
|
115
|
+
<svg className="h-4 w-4" fill="none" viewBox="0 0 24 24" stroke="currentColor" strokeWidth={2}>
|
|
116
|
+
<path strokeLinecap="round" strokeLinejoin="round" d="M9 5l7 7-7 7" />
|
|
117
|
+
</svg>
|
|
118
|
+
</PaginationLink>
|
|
119
|
+
)
|
|
120
|
+
PaginationNext.displayName = "PaginationNext"
|
|
121
|
+
|
|
122
|
+
const PaginationEllipsis = ({
|
|
123
|
+
className,
|
|
124
|
+
...props
|
|
125
|
+
}: React.HTMLAttributes<HTMLSpanElement>) => (
|
|
126
|
+
<span
|
|
127
|
+
aria-hidden
|
|
128
|
+
className={cn("flex h-9 w-9 items-center justify-center", className)}
|
|
129
|
+
{...props}
|
|
130
|
+
>
|
|
131
|
+
<svg className="h-4 w-4" fill="currentColor" viewBox="0 0 24 24">
|
|
132
|
+
<circle cx="12" cy="12" r="1" />
|
|
133
|
+
<circle cx="19" cy="12" r="1" />
|
|
134
|
+
<circle cx="5" cy="12" r="1" />
|
|
135
|
+
</svg>
|
|
136
|
+
<span className="sr-only">More pages</span>
|
|
137
|
+
</span>
|
|
138
|
+
)
|
|
139
|
+
PaginationEllipsis.displayName = "PaginationEllipsis"
|
|
140
|
+
|
|
141
|
+
export {
|
|
142
|
+
Pagination,
|
|
143
|
+
PaginationContent,
|
|
144
|
+
PaginationLink,
|
|
145
|
+
PaginationItem,
|
|
146
|
+
PaginationPrevious,
|
|
147
|
+
PaginationNext,
|
|
148
|
+
PaginationEllipsis,
|
|
149
|
+
}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
"use client"
|
|
2
|
+
|
|
3
|
+
import { cn } from "@/lib/utils"
|
|
4
|
+
|
|
5
|
+
export const GridPattern = ({ className }: { className?: string }) => {
|
|
6
|
+
return (
|
|
7
|
+
<div className={cn("absolute inset-0 z-0 opacity-[0.05] pointer-events-none", className)}>
|
|
8
|
+
<svg className="w-full h-full" xmlns="http://www.w3.org/2000/svg">
|
|
9
|
+
<defs>
|
|
10
|
+
<pattern id="grid-pattern" width="40" height="40" patternUnits="userSpaceOnUse">
|
|
11
|
+
<path d="M 40 0 L 0 0 0 40" fill="none" stroke="currentColor" strokeWidth="1" />
|
|
12
|
+
</pattern>
|
|
13
|
+
</defs>
|
|
14
|
+
<rect width="100%" height="100%" fill="url(#grid-pattern)" />
|
|
15
|
+
</svg>
|
|
16
|
+
</div>
|
|
17
|
+
)
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
export const WavePattern = ({ className }: { className?: string }) => {
|
|
21
|
+
return (
|
|
22
|
+
<div className={cn("absolute inset-0 z-0 bg-muted/40 opacity-10 pointer-events-none overflow-hidden", className)}>
|
|
23
|
+
<svg className="w-full h-full" viewBox="0 0 1440 320" xmlns="http://www.w3.org/2000/svg" preserveAspectRatio="none">
|
|
24
|
+
<path fill="currentColor" fillOpacity="0.2" d="M0,192L48,197.3C96,203,192,213,288,229.3C384,245,480,267,576,250.7C672,235,768,181,864,181.3C960,181,1056,235,1152,234.7C1248,235,1344,181,1392,154.7L1440,128V320H1392C1344,320,1248,320,1152,320C1056,320,960,320,864,320C768,320,672,320,576,320C480,320,384,320,288,320C192,320,96,320,48,320H0Z"></path>
|
|
25
|
+
</svg>
|
|
26
|
+
</div>
|
|
27
|
+
)
|
|
28
|
+
}
|