banhaten 0.1.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.
Files changed (201) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +361 -0
  3. package/banhaten.config.example.json +13 -0
  4. package/package.json +59 -0
  5. package/registry/assets/activity-feed-avatar.png +0 -0
  6. package/registry/assets/avatars/avatar-01.jpg +0 -0
  7. package/registry/assets/avatars/avatar-02.jpg +0 -0
  8. package/registry/assets/avatars/avatar-03.jpg +0 -0
  9. package/registry/assets/avatars/avatar-04.jpg +0 -0
  10. package/registry/assets/avatars/avatar-05.jpg +0 -0
  11. package/registry/assets/avatars/avatar-06.jpg +0 -0
  12. package/registry/assets/avatars/avatar-07.jpg +0 -0
  13. package/registry/assets/avatars/avatar-08.jpg +0 -0
  14. package/registry/assets/avatars/avatar-09.jpg +0 -0
  15. package/registry/assets/avatars/avatar-10.jpg +0 -0
  16. package/registry/assets/avatars/avatar-11.jpg +0 -0
  17. package/registry/assets/avatars/avatar-12.jpg +0 -0
  18. package/registry/assets/avatars/avatar-13.jpg +0 -0
  19. package/registry/assets/avatars/avatar-14.jpg +0 -0
  20. package/registry/assets/avatars/avatar-15.jpg +0 -0
  21. package/registry/assets/avatars/avatar-16.jpg +0 -0
  22. package/registry/assets/avatars/avatar-17.jpg +0 -0
  23. package/registry/assets/avatars/avatar-18.jpg +0 -0
  24. package/registry/assets/avatars/avatar-19.jpg +0 -0
  25. package/registry/assets/avatars/avatar-20.jpg +0 -0
  26. package/registry/assets/avatars/avatar-21.jpg +0 -0
  27. package/registry/assets/avatars/avatar-22.jpg +0 -0
  28. package/registry/assets/avatars/avatar-23.jpg +0 -0
  29. package/registry/assets/avatars/avatar-24.jpg +0 -0
  30. package/registry/assets/avatars/avatar-25.jpg +0 -0
  31. package/registry/assets/avatars/avatar-26.jpg +0 -0
  32. package/registry/assets/avatars/avatar-27.jpg +0 -0
  33. package/registry/assets/avatars/avatar-28.jpg +0 -0
  34. package/registry/assets/avatars/avatar-29.jpg +0 -0
  35. package/registry/assets/avatars/avatar-30.jpg +0 -0
  36. package/registry/assets/avatars/avatar-31.jpg +0 -0
  37. package/registry/assets/avatars/avatar-32.jpg +0 -0
  38. package/registry/assets/avatars/avatar-33.jpg +0 -0
  39. package/registry/assets/avatars/avatar-34.jpg +0 -0
  40. package/registry/assets/avatars/avatar-35.jpg +0 -0
  41. package/registry/assets/image-assets.json +744 -0
  42. package/registry/assets/images/art-01.jpg +0 -0
  43. package/registry/assets/images/art-02.jpg +0 -0
  44. package/registry/assets/images/art-03.jpg +0 -0
  45. package/registry/assets/images/art-04.jpg +0 -0
  46. package/registry/assets/images/art-05.jpg +0 -0
  47. package/registry/assets/images/art-06.jpg +0 -0
  48. package/registry/assets/images/art-07.jpg +0 -0
  49. package/registry/assets/images/art-08.jpg +0 -0
  50. package/registry/assets/images/art-09.jpg +0 -0
  51. package/registry/assets/images/art-10.jpg +0 -0
  52. package/registry/assets/images/art-11.jpg +0 -0
  53. package/registry/assets/images/art-12.jpg +0 -0
  54. package/registry/assets/images/art-13.jpg +0 -0
  55. package/registry/assets/images/art-14.jpg +0 -0
  56. package/registry/assets/images/art-15.jpg +0 -0
  57. package/registry/assets/images/art-16.jpg +0 -0
  58. package/registry/assets/images/art-17.jpg +0 -0
  59. package/registry/assets/images/art-18.jpg +0 -0
  60. package/registry/assets/images/art-19.jpg +0 -0
  61. package/registry/assets/images/art-20.jpg +0 -0
  62. package/registry/assets/images/art-21.jpg +0 -0
  63. package/registry/assets/images/art-22.jpg +0 -0
  64. package/registry/assets/images/art-23.jpg +0 -0
  65. package/registry/assets/images/art-24.jpg +0 -0
  66. package/registry/assets/images/art-25.jpg +0 -0
  67. package/registry/assets/images/art-26.jpg +0 -0
  68. package/registry/assets/images/art-27.jpg +0 -0
  69. package/registry/assets/images/nature-01.jpg +0 -0
  70. package/registry/assets/images/nature-02.jpg +0 -0
  71. package/registry/assets/images/nature-03.jpg +0 -0
  72. package/registry/assets/images/nature-04.jpg +0 -0
  73. package/registry/assets/images/nature-05.jpg +0 -0
  74. package/registry/assets/images/nature-06.jpg +0 -0
  75. package/registry/assets/images/nature-07.jpg +0 -0
  76. package/registry/assets/images/nature-08.jpg +0 -0
  77. package/registry/assets/images/nature-09.jpg +0 -0
  78. package/registry/assets/images/nature-10.jpg +0 -0
  79. package/registry/assets/images/nature-11.jpg +0 -0
  80. package/registry/assets/images/nature-12.jpg +0 -0
  81. package/registry/assets/images/nature-13.jpg +0 -0
  82. package/registry/assets/images/nature-14.jpg +0 -0
  83. package/registry/assets/images/nature-15.jpg +0 -0
  84. package/registry/assets/images/nature-16.jpg +0 -0
  85. package/registry/assets/images/nature-17.jpg +0 -0
  86. package/registry/assets/images/nature-18.jpg +0 -0
  87. package/registry/assets/images/nature-19.jpg +0 -0
  88. package/registry/assets/images/nature-20.jpg +0 -0
  89. package/registry/components/accordion.tsx +119 -0
  90. package/registry/components/alert.tsx +282 -0
  91. package/registry/components/attribute.tsx +452 -0
  92. package/registry/components/avatar.tsx +142 -0
  93. package/registry/components/badge.tsx +567 -0
  94. package/registry/components/button-group.tsx +246 -0
  95. package/registry/components/button.tsx +102 -0
  96. package/registry/components/card.tsx +613 -0
  97. package/registry/components/checkbox.tsx +244 -0
  98. package/registry/components/date-picker.tsx +1143 -0
  99. package/registry/components/divider.tsx +82 -0
  100. package/registry/components/expanded/ActivityFeed.tsx +226 -0
  101. package/registry/components/expanded/Banner.tsx +145 -0
  102. package/registry/components/expanded/BannerBoard.tsx +225 -0
  103. package/registry/components/expanded/Breadcrumbs.tsx +156 -0
  104. package/registry/components/expanded/CatalogComponentsShowcase.tsx +211 -0
  105. package/registry/components/expanded/CatalogDivider.tsx +48 -0
  106. package/registry/components/expanded/CatalogTag.tsx +92 -0
  107. package/registry/components/expanded/CommandBar.tsx +406 -0
  108. package/registry/components/expanded/FileUpload.tsx +231 -0
  109. package/registry/components/expanded/IconExplorer.tsx +612 -0
  110. package/registry/components/expanded/OnboardingStepListItem.tsx +67 -0
  111. package/registry/components/expanded/PageHeader.tsx +184 -0
  112. package/registry/components/expanded/Slideout.tsx +514 -0
  113. package/registry/components/expanded/Steps.tsx +266 -0
  114. package/registry/components/expanded/Table.tsx +1014 -0
  115. package/registry/components/expanded/Tabs.tsx +86 -0
  116. package/registry/components/expanded/Timeline.tsx +235 -0
  117. package/registry/components/expanded/TimelineShowcase.tsx +158 -0
  118. package/registry/components/expanded/activityFeed.css +292 -0
  119. package/registry/components/expanded/banner.css +312 -0
  120. package/registry/components/expanded/breadcrumbs.css +140 -0
  121. package/registry/components/expanded/catalogComponentsShowcase.css +87 -0
  122. package/registry/components/expanded/commandBar.css +473 -0
  123. package/registry/components/expanded/divider.css +75 -0
  124. package/registry/components/expanded/fileUpload.css +228 -0
  125. package/registry/components/expanded/iconExplorer.css +764 -0
  126. package/registry/components/expanded/iconPacks.ts +866 -0
  127. package/registry/components/expanded/onboardingStepListItem.css +126 -0
  128. package/registry/components/expanded/pageHeader.css +287 -0
  129. package/registry/components/expanded/slideout.css +955 -0
  130. package/registry/components/expanded/steps.css +329 -0
  131. package/registry/components/expanded/table.css +607 -0
  132. package/registry/components/expanded/tabs.css +197 -0
  133. package/registry/components/expanded/tag.css +148 -0
  134. package/registry/components/expanded/timeline.css +282 -0
  135. package/registry/components/input-content.ts +106 -0
  136. package/registry/components/input.tsx +866 -0
  137. package/registry/components/menu.tsx +758 -0
  138. package/registry/components/modal.tsx +799 -0
  139. package/registry/components/pagination.tsx +543 -0
  140. package/registry/components/progress-slider.tsx +216 -0
  141. package/registry/components/progress.tsx +367 -0
  142. package/registry/components/radio-card.tsx +654 -0
  143. package/registry/components/radio-group.tsx +570 -0
  144. package/registry/components/select-content.tsx +313 -0
  145. package/registry/components/select.tsx +871 -0
  146. package/registry/components/slider.tsx +380 -0
  147. package/registry/components/social-button.tsx +360 -0
  148. package/registry/components/spinner.tsx +31 -0
  149. package/registry/components/tag.tsx +423 -0
  150. package/registry/components/textarea.tsx +625 -0
  151. package/registry/components/toggle.tsx +272 -0
  152. package/registry/components/toolbar.tsx +467 -0
  153. package/registry/components/tooltip.tsx +427 -0
  154. package/registry/examples/accordion-demo.tsx +34 -0
  155. package/registry/examples/alert-demo.tsx +14 -0
  156. package/registry/examples/attribute-demo.tsx +65 -0
  157. package/registry/examples/avatar-demo.tsx +74 -0
  158. package/registry/examples/badge-demo.tsx +53 -0
  159. package/registry/examples/button-demo.tsx +83 -0
  160. package/registry/examples/button-group-demo.tsx +42 -0
  161. package/registry/examples/card-demo.tsx +48 -0
  162. package/registry/examples/checkbox-demo.tsx +67 -0
  163. package/registry/examples/date-picker-demo.tsx +74 -0
  164. package/registry/examples/divider-demo.tsx +17 -0
  165. package/registry/examples/expanded/activity-feed-demo.tsx +22 -0
  166. package/registry/examples/expanded/banner-demo.tsx +23 -0
  167. package/registry/examples/expanded/catalog-components-demo.tsx +5 -0
  168. package/registry/examples/expanded/command-bar-demo.tsx +10 -0
  169. package/registry/examples/expanded/icons-demo.tsx +5 -0
  170. package/registry/examples/expanded/onboarding-step-demo.tsx +11 -0
  171. package/registry/examples/expanded/page-header-demo.tsx +19 -0
  172. package/registry/examples/expanded/slideout-demo.tsx +15 -0
  173. package/registry/examples/expanded/steps-demo.tsx +18 -0
  174. package/registry/examples/expanded/tabs-demo.tsx +13 -0
  175. package/registry/examples/expanded/timeline-demo.tsx +18 -0
  176. package/registry/examples/input-demo.tsx +87 -0
  177. package/registry/examples/menu-demo.tsx +109 -0
  178. package/registry/examples/modal-demo.tsx +16 -0
  179. package/registry/examples/pagination-demo.tsx +17 -0
  180. package/registry/examples/progress-demo.tsx +37 -0
  181. package/registry/examples/progress-slider-demo.tsx +29 -0
  182. package/registry/examples/radio-card-demo.tsx +51 -0
  183. package/registry/examples/radio-group-demo.tsx +62 -0
  184. package/registry/examples/select-demo.tsx +73 -0
  185. package/registry/examples/slider-demo.tsx +31 -0
  186. package/registry/examples/social-button-demo.tsx +51 -0
  187. package/registry/examples/tag-demo.tsx +29 -0
  188. package/registry/examples/textarea-demo.tsx +79 -0
  189. package/registry/examples/toggle-demo.tsx +59 -0
  190. package/registry/examples/toolbar-demo.tsx +80 -0
  191. package/registry/examples/tooltip-demo.tsx +115 -0
  192. package/registry/hooks/use-direction.ts +27 -0
  193. package/registry/index.json +1213 -0
  194. package/registry/styles/globals.css +4600 -0
  195. package/registry/utils/cn.ts +6 -0
  196. package/src/cli/index.js +826 -0
  197. package/tokens/Color mode.zip +0 -0
  198. package/tokens/Numbers.zip +0 -0
  199. package/tokens/Radius.zip +0 -0
  200. package/tokens/Theme.zip +0 -0
  201. package/tokens/banhaten.tokens.json +5525 -0
@@ -0,0 +1,272 @@
1
+ "use client"
2
+
3
+ import * as React from "react"
4
+ import * as SwitchPrimitive from "@radix-ui/react-switch"
5
+ import { cva, type VariantProps } from "class-variance-authority"
6
+
7
+ import { cn } from "@/lib/utils"
8
+
9
+ type ToggleSize = "sm" | "md"
10
+ type ToggleFieldControlPosition = "start" | "end"
11
+
12
+ const toggleVariants = cva(
13
+ [
14
+ "peer group/toggle inline-flex shrink-0 items-center rounded-[var(--bh-radius-full)] bg-[var(--bh-interactive-switch-default)] p-[var(--bh-menu-switch-padding)] outline-none transition-[background-color,box-shadow]",
15
+ "focus-visible:shadow-[var(--shadow-social-button-focus-ring)]",
16
+ "disabled:pointer-events-none data-[disabled]:cursor-not-allowed",
17
+ "data-[state=unchecked]:hover:bg-[var(--bh-interactive-switch-hover)]",
18
+ "data-[state=checked]:bg-[var(--bh-interactive-switch-active)] data-[state=checked]:hover:bg-[var(--bh-interactive-switch-active-hover)]",
19
+ "data-[disabled]:bg-[var(--bh-interactive-switch-disabled)] [&[data-disabled][data-state=checked]]:bg-[var(--bh-interactive-switch-active-disabled)]",
20
+ ],
21
+ {
22
+ variants: {
23
+ size: {
24
+ sm: [
25
+ "h-[var(--bh-menu-switch-height)] w-[var(--bh-menu-switch-width)]",
26
+ "[--bh-toggle-handle-size:var(--bh-menu-switch-handle-size)] [--bh-toggle-offset:var(--bh-space-xl-12)]",
27
+ "[&_[data-slot=toggle-icon]]:size-[var(--bh-toggle-icon-size-sm)]",
28
+ ],
29
+ md: [
30
+ "h-[var(--bh-space-5xl-24)] w-[calc(var(--bh-menu-switch-width)+var(--bh-space-md-8))]",
31
+ "[--bh-toggle-handle-size:calc(var(--bh-space-5xl-24)-var(--bh-space-sm-6))] [--bh-toggle-offset:var(--bh-space-3xl-16)]",
32
+ "[&_[data-slot=toggle-icon]]:size-[var(--bh-toggle-icon-size-md)]",
33
+ ],
34
+ },
35
+ },
36
+ defaultVariants: {
37
+ size: "md",
38
+ },
39
+ }
40
+ )
41
+
42
+ const toggleFieldVariants = cva(
43
+ "group/toggle-field inline-flex min-w-0 max-w-full gap-[var(--bh-space-lg-10)] text-start",
44
+ {
45
+ variants: {
46
+ density: {
47
+ compact: "items-center",
48
+ stacked: "items-start",
49
+ },
50
+ controlPosition: {
51
+ start: "",
52
+ end: "justify-between",
53
+ },
54
+ },
55
+ defaultVariants: {
56
+ controlPosition: "start",
57
+ density: "compact",
58
+ },
59
+ }
60
+ )
61
+
62
+ type ToggleProps = React.ComponentPropsWithoutRef<typeof SwitchPrimitive.Root> &
63
+ VariantProps<typeof toggleVariants> & {
64
+ showIcon?: boolean
65
+ }
66
+
67
+ const Toggle = React.forwardRef<
68
+ React.ElementRef<typeof SwitchPrimitive.Root>,
69
+ ToggleProps
70
+ >(function Toggle({ className, showIcon = false, size, ...props }, ref) {
71
+ return (
72
+ <SwitchPrimitive.Root
73
+ data-slot="toggle"
74
+ ref={ref}
75
+ className={cn(toggleVariants({ size, className }))}
76
+ {...props}
77
+ >
78
+ <SwitchPrimitive.Thumb
79
+ data-slot="toggle-thumb"
80
+ className="pointer-events-none flex size-[var(--bh-toggle-handle-size)] translate-x-0 items-center justify-center rounded-[var(--bh-radius-full)] bg-[var(--bh-interactive-switch-handle)] text-[var(--bh-content-on-light)] shadow-[var(--shadow-component-default)] transition-[background-color,transform] group-data-[disabled]/toggle:bg-[var(--bh-interactive-switch-handle-disabled)] group-data-[state=checked]/toggle:translate-x-[var(--bh-toggle-offset)] rtl:group-data-[state=checked]/toggle:-translate-x-[var(--bh-toggle-offset)]"
81
+ >
82
+ {showIcon ? (
83
+ <span
84
+ aria-hidden="true"
85
+ data-slot="toggle-icon"
86
+ className="grid place-items-center"
87
+ >
88
+ <ToggleCheckIcon className="hidden size-full group-data-[state=checked]/toggle:block" />
89
+ <ToggleCloseIcon className="block size-full group-data-[state=checked]/toggle:hidden" />
90
+ </span>
91
+ ) : null}
92
+ </SwitchPrimitive.Thumb>
93
+ </SwitchPrimitive.Root>
94
+ )
95
+ })
96
+
97
+ type ToggleFieldProps = Omit<
98
+ React.ComponentPropsWithoutRef<"div">,
99
+ "children" | "defaultChecked" | "onChange"
100
+ > &
101
+ Pick<
102
+ ToggleProps,
103
+ | "checked"
104
+ | "defaultChecked"
105
+ | "disabled"
106
+ | "name"
107
+ | "onCheckedChange"
108
+ | "required"
109
+ | "showIcon"
110
+ | "size"
111
+ | "value"
112
+ > & {
113
+ controlPosition?: ToggleFieldControlPosition
114
+ description?: React.ReactNode
115
+ label: React.ReactNode
116
+ toggleClassName?: string
117
+ }
118
+
119
+ const ToggleField = React.forwardRef<HTMLDivElement, ToggleFieldProps>(
120
+ function ToggleField({
121
+ checked,
122
+ className,
123
+ controlPosition = "start",
124
+ defaultChecked,
125
+ description,
126
+ disabled,
127
+ id,
128
+ label,
129
+ name,
130
+ onCheckedChange,
131
+ required,
132
+ showIcon,
133
+ size,
134
+ toggleClassName,
135
+ value,
136
+ ...props
137
+ }, ref) {
138
+ const generatedId = React.useId()
139
+ const toggleId = id ?? generatedId
140
+ const labelId = `${toggleId}-label`
141
+ const descriptionId = description ? `${toggleId}-description` : undefined
142
+ const density = description ? "stacked" : "compact"
143
+ const control = (
144
+ <span
145
+ data-slot="toggle-field-control"
146
+ className={cn(
147
+ "inline-flex shrink-0",
148
+ description ? "pt-[var(--bh-space-xxs-2)]" : undefined
149
+ )}
150
+ >
151
+ <Toggle
152
+ aria-describedby={descriptionId}
153
+ aria-labelledby={labelId}
154
+ checked={checked}
155
+ className={toggleClassName}
156
+ defaultChecked={defaultChecked}
157
+ disabled={disabled}
158
+ id={toggleId}
159
+ name={name}
160
+ onCheckedChange={onCheckedChange}
161
+ required={required}
162
+ showIcon={showIcon}
163
+ size={size}
164
+ value={value}
165
+ />
166
+ </span>
167
+ )
168
+ const content = (
169
+ <span
170
+ data-slot="toggle-field-content"
171
+ className="flex min-w-0 flex-1 flex-col items-start"
172
+ >
173
+ <label
174
+ data-slot="toggle-field-label"
175
+ dir="auto"
176
+ htmlFor={toggleId}
177
+ id={labelId}
178
+ className={cn(
179
+ "w-full min-w-0 cursor-pointer break-words text-[length:var(--bh-text-body-md-regular-font-size)] leading-[var(--bh-text-body-md-regular-line-height)] tracking-[var(--bh-text-body-md-regular-letter-spacing)] text-[var(--bh-content-default)] group-data-[disabled=true]/toggle-field:cursor-not-allowed group-data-[disabled=true]/toggle-field:text-[var(--bh-content-disabled)]",
180
+ description
181
+ ? "font-[var(--bh-text-body-md-medium-font-weight)]"
182
+ : "font-[var(--bh-text-body-md-regular-font-weight)]"
183
+ )}
184
+ >
185
+ {label}
186
+ </label>
187
+ {description ? (
188
+ <span
189
+ data-slot="toggle-field-description"
190
+ dir="auto"
191
+ id={descriptionId}
192
+ className="w-full min-w-0 break-words text-[length:var(--bh-text-body-xs-regular-font-size)] font-[var(--bh-text-body-xs-regular-font-weight)] leading-[var(--bh-text-body-xs-regular-line-height)] tracking-[var(--bh-text-body-xs-regular-letter-spacing)] text-[var(--bh-content-subtle)] group-data-[disabled=true]/toggle-field:text-[var(--bh-content-disabled)]"
193
+ >
194
+ {description}
195
+ </span>
196
+ ) : null}
197
+ </span>
198
+ )
199
+
200
+ return (
201
+ <div
202
+ data-disabled={disabled ? "true" : undefined}
203
+ data-slot="toggle-field"
204
+ ref={ref}
205
+ className={cn(
206
+ toggleFieldVariants({ controlPosition, density }),
207
+ className
208
+ )}
209
+ {...props}
210
+ >
211
+ {controlPosition === "start" ? (
212
+ <>
213
+ {control}
214
+ {content}
215
+ </>
216
+ ) : (
217
+ <>
218
+ {content}
219
+ {control}
220
+ </>
221
+ )}
222
+ </div>
223
+ )
224
+ }
225
+ )
226
+
227
+ function ToggleCheckIcon({ className }: { className?: string }) {
228
+ return (
229
+ <svg
230
+ aria-hidden="true"
231
+ className={className}
232
+ fill="none"
233
+ focusable="false"
234
+ viewBox="0 0 16 16"
235
+ >
236
+ <path
237
+ d="M4 8.2 6.55 10.75 12 5.25"
238
+ stroke="currentColor"
239
+ strokeLinecap="round"
240
+ strokeLinejoin="round"
241
+ strokeWidth="1.75"
242
+ />
243
+ </svg>
244
+ )
245
+ }
246
+
247
+ function ToggleCloseIcon({ className }: { className?: string }) {
248
+ return (
249
+ <svg
250
+ aria-hidden="true"
251
+ className={className}
252
+ fill="none"
253
+ focusable="false"
254
+ viewBox="0 0 16 16"
255
+ >
256
+ <path
257
+ d="m5 5 6 6m0-6-6 6"
258
+ stroke="currentColor"
259
+ strokeLinecap="round"
260
+ strokeWidth="1.75"
261
+ />
262
+ </svg>
263
+ )
264
+ }
265
+
266
+ export { Toggle, ToggleField, toggleFieldVariants, toggleVariants }
267
+ export type {
268
+ ToggleFieldControlPosition,
269
+ ToggleFieldProps,
270
+ ToggleProps,
271
+ ToggleSize,
272
+ }