ml-uikit 1.1.0 → 1.1.2

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 (231) hide show
  1. package/dist/components/ui/alert.d.ts +8 -2
  2. package/dist/components/ui/alert.d.ts.map +1 -1
  3. package/dist/components/ui/badge.d.ts +1 -1
  4. package/dist/components/ui/button.d.ts.map +1 -1
  5. package/dist/components/ui/checkbox.d.ts.map +1 -1
  6. package/dist/components/ui/icon-button.d.ts +9 -0
  7. package/dist/components/ui/icon-button.d.ts.map +1 -0
  8. package/dist/components/ui/input-group.d.ts.map +1 -1
  9. package/dist/components/ui/radio-group.d.ts.map +1 -1
  10. package/dist/components/ui/select.d.ts.map +1 -1
  11. package/dist/components/ui/sidebar.d.ts.map +1 -1
  12. package/dist/components/ui/slider.d.ts.map +1 -1
  13. package/dist/components/ui/switch.d.ts.map +1 -1
  14. package/dist/components/ui/tabs.d.ts.map +1 -1
  15. package/dist/index.cjs.js +1 -1
  16. package/dist/index.cjs10.js +1 -1
  17. package/dist/index.cjs10.js.map +1 -1
  18. package/dist/index.cjs11.js +1 -1
  19. package/dist/index.cjs11.js.map +1 -1
  20. package/dist/index.cjs12.js +1 -1
  21. package/dist/index.cjs12.js.map +1 -1
  22. package/dist/index.cjs13.js +1 -1
  23. package/dist/index.cjs13.js.map +1 -1
  24. package/dist/index.cjs14.js +1 -1
  25. package/dist/index.cjs14.js.map +1 -1
  26. package/dist/index.cjs15.js +1 -7
  27. package/dist/index.cjs15.js.map +1 -1
  28. package/dist/index.cjs16.js +7 -1
  29. package/dist/index.cjs16.js.map +1 -1
  30. package/dist/index.cjs17.js +1 -1
  31. package/dist/index.cjs17.js.map +1 -1
  32. package/dist/index.cjs18.js +1 -1
  33. package/dist/index.cjs18.js.map +1 -1
  34. package/dist/index.cjs19.js +1 -1
  35. package/dist/index.cjs19.js.map +1 -1
  36. package/dist/index.cjs2.js +1 -1
  37. package/dist/index.cjs20.js +1 -1
  38. package/dist/index.cjs20.js.map +1 -1
  39. package/dist/index.cjs21.js +1 -1
  40. package/dist/index.cjs21.js.map +1 -1
  41. package/dist/index.cjs22.js +1 -1
  42. package/dist/index.cjs22.js.map +1 -1
  43. package/dist/index.cjs23.js +1 -1
  44. package/dist/index.cjs23.js.map +1 -1
  45. package/dist/index.cjs24.js +1 -1
  46. package/dist/index.cjs24.js.map +1 -1
  47. package/dist/index.cjs25.js +1 -1
  48. package/dist/index.cjs25.js.map +1 -1
  49. package/dist/index.cjs26.js +1 -1
  50. package/dist/index.cjs26.js.map +1 -1
  51. package/dist/index.cjs27.js +1 -1
  52. package/dist/index.cjs27.js.map +1 -1
  53. package/dist/index.cjs28.js +1 -1
  54. package/dist/index.cjs28.js.map +1 -1
  55. package/dist/index.cjs29.js +1 -1
  56. package/dist/index.cjs29.js.map +1 -1
  57. package/dist/index.cjs3.js +1 -1
  58. package/dist/index.cjs30.js +1 -1
  59. package/dist/index.cjs30.js.map +1 -1
  60. package/dist/index.cjs31.js +1 -1
  61. package/dist/index.cjs31.js.map +1 -1
  62. package/dist/index.cjs32.js +1 -1
  63. package/dist/index.cjs32.js.map +1 -1
  64. package/dist/index.cjs33.js +1 -1
  65. package/dist/index.cjs33.js.map +1 -1
  66. package/dist/index.cjs34.js +1 -1
  67. package/dist/index.cjs34.js.map +1 -1
  68. package/dist/index.cjs35.js +1 -1
  69. package/dist/index.cjs35.js.map +1 -1
  70. package/dist/index.cjs36.js +1 -1
  71. package/dist/index.cjs36.js.map +1 -1
  72. package/dist/index.cjs37.js +1 -1
  73. package/dist/index.cjs37.js.map +1 -1
  74. package/dist/index.cjs38.js +1 -1
  75. package/dist/index.cjs38.js.map +1 -1
  76. package/dist/index.cjs39.js +1 -1
  77. package/dist/index.cjs39.js.map +1 -1
  78. package/dist/index.cjs4.js +1 -1
  79. package/dist/index.cjs4.js.map +1 -1
  80. package/dist/index.cjs40.js +1 -1
  81. package/dist/index.cjs40.js.map +1 -1
  82. package/dist/index.cjs41.js +1 -1
  83. package/dist/index.cjs41.js.map +1 -1
  84. package/dist/index.cjs42.js +1 -1
  85. package/dist/index.cjs42.js.map +1 -1
  86. package/dist/index.cjs43.js +1 -1
  87. package/dist/index.cjs43.js.map +1 -1
  88. package/dist/index.cjs44.js +1 -1
  89. package/dist/index.cjs44.js.map +1 -1
  90. package/dist/index.cjs45.js +1 -1
  91. package/dist/index.cjs45.js.map +1 -1
  92. package/dist/index.cjs46.js +1 -1
  93. package/dist/index.cjs46.js.map +1 -1
  94. package/dist/index.cjs47.js +1 -1
  95. package/dist/index.cjs47.js.map +1 -1
  96. package/dist/index.cjs48.js +1 -1
  97. package/dist/index.cjs48.js.map +1 -1
  98. package/dist/index.cjs49.js +1 -1
  99. package/dist/index.cjs49.js.map +1 -1
  100. package/dist/index.cjs5.js +1 -1
  101. package/dist/index.cjs50.js +1 -1
  102. package/dist/index.cjs50.js.map +1 -1
  103. package/dist/index.cjs51.js +1 -1
  104. package/dist/index.cjs51.js.map +1 -1
  105. package/dist/index.cjs52.js +1 -1
  106. package/dist/index.cjs52.js.map +1 -1
  107. package/dist/index.cjs53.js +1 -1
  108. package/dist/index.cjs53.js.map +1 -1
  109. package/dist/index.cjs54.js +1 -1
  110. package/dist/index.cjs54.js.map +1 -1
  111. package/dist/index.cjs55.js +1 -1
  112. package/dist/index.cjs55.js.map +1 -1
  113. package/dist/index.cjs56.js +1 -1
  114. package/dist/index.cjs56.js.map +1 -1
  115. package/dist/index.cjs57.js +1 -1
  116. package/dist/index.cjs57.js.map +1 -1
  117. package/dist/index.cjs7.js +1 -1
  118. package/dist/index.cjs8.js +1 -1
  119. package/dist/index.cjs9.js +1 -1
  120. package/dist/index.d.ts +3 -1
  121. package/dist/index.d.ts.map +1 -1
  122. package/dist/index.es.js +321 -312
  123. package/dist/index.es.js.map +1 -1
  124. package/dist/index.es10.js +27 -27
  125. package/dist/index.es10.js.map +1 -1
  126. package/dist/index.es11.js +19 -72
  127. package/dist/index.es11.js.map +1 -1
  128. package/dist/index.es12.js +62 -157
  129. package/dist/index.es12.js.map +1 -1
  130. package/dist/index.es13.js +169 -58
  131. package/dist/index.es13.js.map +1 -1
  132. package/dist/index.es14.js +55 -157
  133. package/dist/index.es14.js.map +1 -1
  134. package/dist/index.es15.js +150 -181
  135. package/dist/index.es15.js.map +1 -1
  136. package/dist/index.es16.js +188 -21
  137. package/dist/index.es16.js.map +1 -1
  138. package/dist/index.es17.js +31 -5
  139. package/dist/index.es17.js.map +1 -1
  140. package/dist/index.es18.js +5 -103
  141. package/dist/index.es18.js.map +1 -1
  142. package/dist/index.es19.js +70 -103
  143. package/dist/index.es19.js.map +1 -1
  144. package/dist/index.es2.js +1 -1
  145. package/dist/index.es20.js +108 -61
  146. package/dist/index.es20.js.map +1 -1
  147. package/dist/index.es21.js +59 -60
  148. package/dist/index.es21.js.map +1 -1
  149. package/dist/index.es22.js +69 -114
  150. package/dist/index.es22.js.map +1 -1
  151. package/dist/index.es23.js +132 -97
  152. package/dist/index.es23.js.map +1 -1
  153. package/dist/index.es24.js +49 -156
  154. package/dist/index.es24.js.map +1 -1
  155. package/dist/index.es25.js +194 -76
  156. package/dist/index.es25.js.map +1 -1
  157. package/dist/index.es26.js +89 -20
  158. package/dist/index.es26.js.map +1 -1
  159. package/dist/index.es27.js +20 -22
  160. package/dist/index.es27.js.map +1 -1
  161. package/dist/index.es28.js +17 -144
  162. package/dist/index.es28.js.map +1 -1
  163. package/dist/index.es29.js +145 -37
  164. package/dist/index.es29.js.map +1 -1
  165. package/dist/index.es3.js +1 -1
  166. package/dist/index.es30.js +37 -179
  167. package/dist/index.es30.js.map +1 -1
  168. package/dist/index.es31.js +174 -18
  169. package/dist/index.es31.js.map +1 -1
  170. package/dist/index.es32.js +29 -16
  171. package/dist/index.es32.js.map +1 -1
  172. package/dist/index.es33.js +15 -92
  173. package/dist/index.es33.js.map +1 -1
  174. package/dist/index.es34.js +91 -189
  175. package/dist/index.es34.js.map +1 -1
  176. package/dist/index.es35.js +165 -71
  177. package/dist/index.es35.js.map +1 -1
  178. package/dist/index.es36.js +85 -84
  179. package/dist/index.es36.js.map +1 -1
  180. package/dist/index.es37.js +92 -17
  181. package/dist/index.es37.js.map +1 -1
  182. package/dist/index.es38.js +19 -21
  183. package/dist/index.es38.js.map +1 -1
  184. package/dist/index.es39.js +16 -21
  185. package/dist/index.es39.js.map +1 -1
  186. package/dist/index.es4.js +65 -26
  187. package/dist/index.es4.js.map +1 -1
  188. package/dist/index.es40.js +22 -25
  189. package/dist/index.es40.js.map +1 -1
  190. package/dist/index.es41.js +25 -104
  191. package/dist/index.es41.js.map +1 -1
  192. package/dist/index.es42.js +117 -20
  193. package/dist/index.es42.js.map +1 -1
  194. package/dist/index.es43.js +19 -97
  195. package/dist/index.es43.js.map +1 -1
  196. package/dist/index.es44.js +77 -509
  197. package/dist/index.es44.js.map +1 -1
  198. package/dist/index.es45.js +552 -11
  199. package/dist/index.es45.js.map +1 -1
  200. package/dist/index.es46.js +15 -18
  201. package/dist/index.es46.js.map +1 -1
  202. package/dist/index.es47.js +44 -19
  203. package/dist/index.es47.js.map +1 -1
  204. package/dist/index.es48.js +19 -12
  205. package/dist/index.es48.js.map +1 -1
  206. package/dist/index.es49.js +13 -22
  207. package/dist/index.es49.js.map +1 -1
  208. package/dist/index.es5.js +1 -1
  209. package/dist/index.es50.js +23 -197
  210. package/dist/index.es50.js.map +1 -1
  211. package/dist/index.es51.js +191 -28
  212. package/dist/index.es51.js.map +1 -1
  213. package/dist/index.es52.js +45 -14
  214. package/dist/index.es52.js.map +1 -1
  215. package/dist/index.es53.js +12 -28
  216. package/dist/index.es53.js.map +1 -1
  217. package/dist/index.es54.js +30 -34
  218. package/dist/index.es54.js.map +1 -1
  219. package/dist/index.es55.js +37 -19
  220. package/dist/index.es55.js.map +1 -1
  221. package/dist/index.es56.js +20 -6
  222. package/dist/index.es56.js.map +1 -1
  223. package/dist/index.es57.js +5 -11
  224. package/dist/index.es57.js.map +1 -1
  225. package/dist/index.es7.js +1 -1
  226. package/dist/index.es8.js +1 -1
  227. package/dist/index.es9.js +1 -1
  228. package/dist/style.css +436 -172
  229. package/package.json +1 -1
  230. package/dist/hooks/use-mobile.d.ts +0 -2
  231. package/dist/hooks/use-mobile.d.ts.map +0 -1
@@ -1,46 +1,154 @@
1
- import * as e from "react";
2
- import { OTPInput as c, OTPInputContext as d } from "input-otp";
3
- import { Minus as p } from "lucide-react";
4
- import { cn as n } from "./index.es56.js";
5
- const u = e.forwardRef(({ className: t, containerClassName: r, ...a }, o) => /* @__PURE__ */ e.createElement(
6
- c,
1
+ import * as a from "react";
2
+ import { cva as s } from "class-variance-authority";
3
+ import { cn as r } from "./index.es57.js";
4
+ import { Button as u } from "./index.es10.js";
5
+ import { Input as p } from "./index.es28.js";
6
+ import { Textarea as l } from "./index.es53.js";
7
+ function h({ className: e, ...t }) {
8
+ return /* @__PURE__ */ a.createElement(
9
+ "div",
10
+ {
11
+ "data-slot": "input-group",
12
+ role: "group",
13
+ className: r(
14
+ "group/input-group relative flex w-full items-center rounded-[8px] border border-[#e6e6e6] bg-white text-[14px] leading-[20px] text-foreground transition-colors",
15
+ "h-10 has-[>textarea]:h-auto",
16
+ // Variants based on alignment.
17
+ "has-[>[data-align=inline-start]]:[&>input]:pl-2",
18
+ "has-[>[data-align=inline-end]]:[&>input]:pr-2",
19
+ "has-[>[data-align=block-start]]:h-auto has-[>[data-align=block-start]]:flex-col has-[>[data-align=block-start]]:[&>input]:pb-3",
20
+ "has-[>[data-align=block-end]]:h-auto has-[>[data-align=block-end]]:flex-col has-[>[data-align=block-end]]:[&>input]:pt-3",
21
+ // Focus state.
22
+ "focus-within:border-[#1D1C20]",
23
+ // Error state.
24
+ "has-[[data-slot][aria-invalid=true]]:border-[#ff3b30]",
25
+ // Disabled state.
26
+ "data-[disabled=true]:cursor-not-allowed data-[disabled=true]:bg-[#f2f2f2] data-[disabled=true]:text-[#9ca3af]",
27
+ e
28
+ ),
29
+ ...t
30
+ }
31
+ );
32
+ }
33
+ const d = s(
34
+ "flex h-auto cursor-text select-none items-center justify-center gap-2 py-1.5 text-sm font-medium text-[#7f7d83] group-data-[disabled=true]/input-group:text-[#b3b3b3] [&>kbd]:rounded-[calc(var(--radius)-5px)] [&>svg:not([class*='size-'])]:size-4",
7
35
  {
8
- ref: o,
9
- containerClassName: n(
10
- "flex items-center gap-2 has-[:disabled]:opacity-50",
11
- r
12
- ),
13
- className: n("disabled:cursor-not-allowed", t),
14
- ...a
36
+ variants: {
37
+ align: {
38
+ "inline-start": "order-first pl-3 has-[>button]:ml-[-0.45rem] has-[>kbd]:ml-[-0.35rem]",
39
+ "inline-end": "order-last pr-3 has-[>button]:mr-[-0.4rem] has-[>kbd]:mr-[-0.35rem]",
40
+ "block-start": "[.border-b]:pb-3 order-first w-full justify-start px-3 pt-3 group-has-[>input]/input-group:pt-2.5",
41
+ "block-end": "[.border-t]:pt-3 order-last w-full justify-start px-3 pb-3 group-has-[>input]/input-group:pb-2.5"
42
+ }
43
+ },
44
+ defaultVariants: {
45
+ align: "inline-start"
46
+ }
15
47
  }
16
- ));
17
- u.displayName = "InputOTP";
18
- const f = e.forwardRef(({ className: t, ...r }, a) => /* @__PURE__ */ e.createElement("div", { ref: a, className: n("flex items-center", t), ...r }));
19
- f.displayName = "InputOTPGroup";
20
- const O = e.forwardRef(({ index: t, className: r, ...a }, o) => {
21
- const s = e.useContext(d), { char: i, hasFakeCaret: l, isActive: m } = s.slots[t];
22
- return /* @__PURE__ */ e.createElement(
48
+ );
49
+ function v({
50
+ className: e,
51
+ align: t = "inline-start",
52
+ ...o
53
+ }) {
54
+ return /* @__PURE__ */ a.createElement(
23
55
  "div",
24
56
  {
25
- ref: o,
26
- className: n(
27
- "relative flex h-9 w-9 items-center justify-center border-y border-r border-input text-sm shadow-sm transition-all first:rounded-l-md first:border-l last:rounded-r-md",
28
- m && "z-10 ring-1 ring-ring",
29
- r
30
- ),
31
- ...a
57
+ role: "group",
58
+ "data-slot": "input-group-addon",
59
+ "data-align": t,
60
+ className: r(d({ align: t }), e),
61
+ onClick: (n) => {
62
+ n.target.closest("button") || n.currentTarget.parentElement?.querySelector("input")?.focus();
63
+ },
64
+ ...o
65
+ }
66
+ );
67
+ }
68
+ const c = s(
69
+ "flex items-center gap-2 text-sm shadow-none",
70
+ {
71
+ variants: {
72
+ size: {
73
+ xs: "h-6 gap-1 rounded-[calc(var(--radius)-5px)] px-2 has-[>svg]:px-2 [&>svg:not([class*='size-'])]:size-3.5",
74
+ sm: "h-8 gap-1.5 rounded-md px-2.5 has-[>svg]:px-2.5",
75
+ "icon-xs": "size-6 rounded-[calc(var(--radius)-5px)] p-0 has-[>svg]:p-0",
76
+ "icon-sm": "size-8 p-0 has-[>svg]:p-0"
77
+ }
32
78
  },
33
- i,
34
- l && /* @__PURE__ */ e.createElement("div", { className: "pointer-events-none absolute inset-0 flex items-center justify-center" }, /* @__PURE__ */ e.createElement("div", { className: "h-4 w-px animate-caret-blink bg-foreground duration-1000" }))
79
+ defaultVariants: {
80
+ size: "xs"
81
+ }
82
+ }
83
+ );
84
+ function k({
85
+ className: e,
86
+ type: t = "button",
87
+ variant: o = "ghost",
88
+ size: n = "xs",
89
+ ...i
90
+ }) {
91
+ return /* @__PURE__ */ a.createElement(
92
+ u,
93
+ {
94
+ type: t,
95
+ "data-size": n,
96
+ variant: o,
97
+ className: r(c({ size: n }), e),
98
+ ...i
99
+ }
100
+ );
101
+ }
102
+ function z({ className: e, ...t }) {
103
+ return /* @__PURE__ */ a.createElement(
104
+ "span",
105
+ {
106
+ className: r(
107
+ "text-muted-foreground flex items-center gap-2 text-sm [&_svg:not([class*='size-'])]:size-4 [&_svg]:pointer-events-none",
108
+ e
109
+ ),
110
+ ...t
111
+ }
112
+ );
113
+ }
114
+ function w({
115
+ className: e,
116
+ ...t
117
+ }) {
118
+ return /* @__PURE__ */ a.createElement(
119
+ p,
120
+ {
121
+ "data-slot": "input-group-control",
122
+ className: r(
123
+ "flex-1 rounded-none border-0 bg-transparent shadow-none focus-visible:ring-0 dark:bg-transparent",
124
+ e
125
+ ),
126
+ ...t
127
+ }
128
+ );
129
+ }
130
+ function G({
131
+ className: e,
132
+ ...t
133
+ }) {
134
+ return /* @__PURE__ */ a.createElement(
135
+ l,
136
+ {
137
+ "data-slot": "input-group-control",
138
+ className: r(
139
+ "flex-1 resize-none rounded-none border-0 bg-transparent py-3 shadow-none focus-visible:ring-0 dark:bg-transparent",
140
+ e
141
+ ),
142
+ ...t
143
+ }
35
144
  );
36
- });
37
- O.displayName = "InputOTPSlot";
38
- const P = e.forwardRef(({ ...t }, r) => /* @__PURE__ */ e.createElement("div", { ref: r, role: "separator", ...t }, /* @__PURE__ */ e.createElement(p, null)));
39
- P.displayName = "InputOTPSeparator";
145
+ }
40
146
  export {
41
- u as InputOTP,
42
- f as InputOTPGroup,
43
- P as InputOTPSeparator,
44
- O as InputOTPSlot
147
+ h as InputGroup,
148
+ v as InputGroupAddon,
149
+ k as InputGroupButton,
150
+ w as InputGroupInput,
151
+ z as InputGroupText,
152
+ G as InputGroupTextarea
45
153
  };
46
154
  //# sourceMappingURL=index.es29.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.es29.js","sources":["../src/components/ui/input-otp.tsx"],"sourcesContent":["import * as React from \"react\"\nimport { OTPInput, OTPInputContext } from \"input-otp\"\nimport { Minus } from \"lucide-react\"\n\nimport { cn } from \"@/lib/utils\"\n\nconst InputOTP = React.forwardRef<\n React.ElementRef<typeof OTPInput>,\n React.ComponentPropsWithoutRef<typeof OTPInput>\n>(({ className, containerClassName, ...props }, ref) => (\n <OTPInput\n ref={ref}\n containerClassName={cn(\n \"flex items-center gap-2 has-[:disabled]:opacity-50\",\n containerClassName\n )}\n className={cn(\"disabled:cursor-not-allowed\", className)}\n {...props}\n />\n))\nInputOTP.displayName = \"InputOTP\"\n\nconst InputOTPGroup = React.forwardRef<\n React.ElementRef<\"div\">,\n React.ComponentPropsWithoutRef<\"div\">\n>(({ className, ...props }, ref) => (\n <div ref={ref} className={cn(\"flex items-center\", className)} {...props} />\n))\nInputOTPGroup.displayName = \"InputOTPGroup\"\n\nconst InputOTPSlot = React.forwardRef<\n React.ElementRef<\"div\">,\n React.ComponentPropsWithoutRef<\"div\"> & { index: number }\n>(({ index, className, ...props }, ref) => {\n const inputOTPContext = React.useContext(OTPInputContext)\n const { char, hasFakeCaret, isActive } = inputOTPContext.slots[index]\n\n return (\n <div\n ref={ref}\n className={cn(\n \"relative flex h-9 w-9 items-center justify-center border-y border-r border-input text-sm shadow-sm transition-all first:rounded-l-md first:border-l last:rounded-r-md\",\n isActive && \"z-10 ring-1 ring-ring\",\n className\n )}\n {...props}\n >\n {char}\n {hasFakeCaret && (\n <div className=\"pointer-events-none absolute inset-0 flex items-center justify-center\">\n <div className=\"h-4 w-px animate-caret-blink bg-foreground duration-1000\" />\n </div>\n )}\n </div>\n )\n})\nInputOTPSlot.displayName = \"InputOTPSlot\"\n\nconst InputOTPSeparator = React.forwardRef<\n React.ElementRef<\"div\">,\n React.ComponentPropsWithoutRef<\"div\">\n>(({ ...props }, ref) => (\n <div ref={ref} role=\"separator\" {...props}>\n <Minus />\n </div>\n))\nInputOTPSeparator.displayName = \"InputOTPSeparator\"\n\nexport { InputOTP, InputOTPGroup, InputOTPSlot, InputOTPSeparator }\n"],"names":["InputOTP","React","className","containerClassName","props","ref","OTPInput","cn","InputOTPGroup","InputOTPSlot","index","inputOTPContext","OTPInputContext","char","hasFakeCaret","isActive","InputOTPSeparator","Minus"],"mappings":";;;;AAMA,MAAMA,IAAWC,EAAM,WAGrB,CAAC,EAAE,WAAAC,GAAW,oBAAAC,GAAoB,GAAGC,EAAA,GAASC,MAC9C,gBAAAJ,EAAA;AAAA,EAACK;AAAA,EAAA;AAAA,IACC,KAAAD;AAAA,IACA,oBAAoBE;AAAA,MAClB;AAAA,MACAJ;AAAA,IAAA;AAAA,IAEF,WAAWI,EAAG,+BAA+BL,CAAS;AAAA,IACrD,GAAGE;AAAA,EAAA;AACN,CACD;AACDJ,EAAS,cAAc;AAEvB,MAAMQ,IAAgBP,EAAM,WAG1B,CAAC,EAAE,WAAAC,GAAW,GAAGE,KAASC,sCACzB,OAAA,EAAI,KAAAA,GAAU,WAAWE,EAAG,qBAAqBL,CAAS,GAAI,GAAGE,GAAO,CAC1E;AACDI,EAAc,cAAc;AAE5B,MAAMC,IAAeR,EAAM,WAGzB,CAAC,EAAE,OAAAS,GAAO,WAAAR,GAAW,GAAGE,EAAA,GAASC,MAAQ;AACzC,QAAMM,IAAkBV,EAAM,WAAWW,CAAe,GAClD,EAAE,MAAAC,GAAM,cAAAC,GAAc,UAAAC,MAAaJ,EAAgB,MAAMD,CAAK;AAEpE,SACE,gBAAAT,EAAA;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,KAAAI;AAAA,MACA,WAAWE;AAAA,QACT;AAAA,QACAQ,KAAY;AAAA,QACZb;AAAA,MAAA;AAAA,MAED,GAAGE;AAAA,IAAA;AAAA,IAEHS;AAAA,IACAC,qCACE,OAAA,EAAI,WAAU,2EACb,gBAAAb,EAAA,cAAC,OAAA,EAAI,WAAU,2DAAA,CAA2D,CAC5E;AAAA,EAAA;AAIR,CAAC;AACDQ,EAAa,cAAc;AAE3B,MAAMO,IAAoBf,EAAM,WAG9B,CAAC,EAAE,GAAGG,KAASC,sCACd,OAAA,EAAI,KAAAA,GAAU,MAAK,aAAa,GAAGD,KAClC,gBAAAH,EAAA,cAACgB,GAAA,IAAM,CACT,CACD;AACDD,EAAkB,cAAc;"}
1
+ {"version":3,"file":"index.es29.js","sources":["../src/components/ui/input-group.tsx"],"sourcesContent":["import * as React from \"react\"\nimport { cva, type VariantProps } from \"class-variance-authority\"\n\nimport { cn } from \"@/lib/utils\"\nimport { Button } from \"@/components/ui/button\"\nimport { Input } from \"@/components/ui/input\"\nimport { Textarea } from \"@/components/ui/textarea\"\n\nfunction InputGroup({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"input-group\"\n role=\"group\"\n className={cn(\n \"group/input-group relative flex w-full items-center rounded-[8px] border border-[#e6e6e6] bg-white text-[14px] leading-[20px] text-foreground transition-colors\",\n \"h-10 has-[>textarea]:h-auto\",\n\n // Variants based on alignment.\n \"has-[>[data-align=inline-start]]:[&>input]:pl-2\",\n \"has-[>[data-align=inline-end]]:[&>input]:pr-2\",\n \"has-[>[data-align=block-start]]:h-auto has-[>[data-align=block-start]]:flex-col has-[>[data-align=block-start]]:[&>input]:pb-3\",\n \"has-[>[data-align=block-end]]:h-auto has-[>[data-align=block-end]]:flex-col has-[>[data-align=block-end]]:[&>input]:pt-3\",\n\n // Focus state.\n \"focus-within:border-[#1D1C20]\",\n\n // Error state.\n \"has-[[data-slot][aria-invalid=true]]:border-[#ff3b30]\",\n\n // Disabled state.\n \"data-[disabled=true]:cursor-not-allowed data-[disabled=true]:bg-[#f2f2f2] data-[disabled=true]:text-[#9ca3af]\",\n\n className\n )}\n {...props}\n />\n )\n}\n\nconst inputGroupAddonVariants = cva(\n \"flex h-auto cursor-text select-none items-center justify-center gap-2 py-1.5 text-sm font-medium text-[#7f7d83] group-data-[disabled=true]/input-group:text-[#b3b3b3] [&>kbd]:rounded-[calc(var(--radius)-5px)] [&>svg:not([class*='size-'])]:size-4\",\n {\n variants: {\n align: {\n \"inline-start\":\n \"order-first pl-3 has-[>button]:ml-[-0.45rem] has-[>kbd]:ml-[-0.35rem]\",\n \"inline-end\":\n \"order-last pr-3 has-[>button]:mr-[-0.4rem] has-[>kbd]:mr-[-0.35rem]\",\n \"block-start\":\n \"[.border-b]:pb-3 order-first w-full justify-start px-3 pt-3 group-has-[>input]/input-group:pt-2.5\",\n \"block-end\":\n \"[.border-t]:pt-3 order-last w-full justify-start px-3 pb-3 group-has-[>input]/input-group:pb-2.5\",\n },\n },\n defaultVariants: {\n align: \"inline-start\",\n },\n }\n)\n\nfunction InputGroupAddon({\n className,\n align = \"inline-start\",\n ...props\n}: React.ComponentProps<\"div\"> & VariantProps<typeof inputGroupAddonVariants>) {\n return (\n <div\n role=\"group\"\n data-slot=\"input-group-addon\"\n data-align={align}\n className={cn(inputGroupAddonVariants({ align }), className)}\n onClick={(e) => {\n if ((e.target as HTMLElement).closest(\"button\")) {\n return\n }\n e.currentTarget.parentElement?.querySelector(\"input\")?.focus()\n }}\n {...props}\n />\n )\n}\n\nconst inputGroupButtonVariants = cva(\n \"flex items-center gap-2 text-sm shadow-none\",\n {\n variants: {\n size: {\n xs: \"h-6 gap-1 rounded-[calc(var(--radius)-5px)] px-2 has-[>svg]:px-2 [&>svg:not([class*='size-'])]:size-3.5\",\n sm: \"h-8 gap-1.5 rounded-md px-2.5 has-[>svg]:px-2.5\",\n \"icon-xs\":\n \"size-6 rounded-[calc(var(--radius)-5px)] p-0 has-[>svg]:p-0\",\n \"icon-sm\": \"size-8 p-0 has-[>svg]:p-0\",\n },\n },\n defaultVariants: {\n size: \"xs\",\n },\n }\n)\n\nfunction InputGroupButton({\n className,\n type = \"button\",\n variant = \"ghost\",\n size = \"xs\",\n ...props\n}: Omit<React.ComponentProps<typeof Button>, \"size\"> &\n VariantProps<typeof inputGroupButtonVariants>) {\n return (\n <Button\n type={type}\n data-size={size}\n variant={variant}\n className={cn(inputGroupButtonVariants({ size }), className)}\n {...props}\n />\n )\n}\n\nfunction InputGroupText({ className, ...props }: React.ComponentProps<\"span\">) {\n return (\n <span\n className={cn(\n \"text-muted-foreground flex items-center gap-2 text-sm [&_svg:not([class*='size-'])]:size-4 [&_svg]:pointer-events-none\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction InputGroupInput({\n className,\n ...props\n}: React.ComponentProps<\"input\">) {\n return (\n <Input\n data-slot=\"input-group-control\"\n className={cn(\n \"flex-1 rounded-none border-0 bg-transparent shadow-none focus-visible:ring-0 dark:bg-transparent\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction InputGroupTextarea({\n className,\n ...props\n}: React.ComponentProps<\"textarea\">) {\n return (\n <Textarea\n data-slot=\"input-group-control\"\n className={cn(\n \"flex-1 resize-none rounded-none border-0 bg-transparent py-3 shadow-none focus-visible:ring-0 dark:bg-transparent\",\n className\n )}\n {...props}\n />\n )\n}\n\nexport {\n InputGroup,\n InputGroupAddon,\n InputGroupButton,\n InputGroupText,\n InputGroupInput,\n InputGroupTextarea,\n}\n"],"names":["InputGroup","className","props","React","cn","inputGroupAddonVariants","cva","InputGroupAddon","align","e","inputGroupButtonVariants","InputGroupButton","type","variant","size","Button","InputGroupText","InputGroupInput","Input","InputGroupTextarea","Textarea"],"mappings":"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"}
package/dist/index.es3.js CHANGED
@@ -1,7 +1,7 @@
1
1
  import * as e from "react";
2
2
  import * as t from "@radix-ui/react-accordion";
3
3
  import { ChevronDown as i } from "lucide-react";
4
- import { cn as m } from "./index.es56.js";
4
+ import { cn as m } from "./index.es57.js";
5
5
  const p = t.Root, c = e.forwardRef(({ className: a, ...o }, r) => /* @__PURE__ */ e.createElement(
6
6
  t.Item,
7
7
  {
@@ -1,188 +1,46 @@
1
- import * as a from "react";
2
- import { Slot as m } from "@radix-ui/react-slot";
3
- import { cva as i } from "class-variance-authority";
4
- import { cn as r } from "./index.es56.js";
5
- import { Separator as d } from "./index.es42.js";
6
- function x({ className: t, ...e }) {
7
- return /* @__PURE__ */ a.createElement(
8
- "div",
9
- {
10
- role: "list",
11
- "data-slot": "item-group",
12
- className: r("group/item-group flex flex-col", t),
13
- ...e
14
- }
15
- );
16
- }
17
- function b({
18
- className: t,
19
- ...e
20
- }) {
21
- return /* @__PURE__ */ a.createElement(
22
- d,
23
- {
24
- "data-slot": "item-separator",
25
- orientation: "horizontal",
26
- className: r("my-0", t),
27
- ...e
28
- }
29
- );
30
- }
31
- const c = i(
32
- "group/item [a]:hover:bg-accent/50 focus-visible:border-ring focus-visible:ring-ring/50 [a]:transition-colors flex flex-wrap items-center rounded-md border border-transparent text-sm outline-none transition-colors duration-100 focus-visible:ring-[3px]",
1
+ import * as e from "react";
2
+ import { OTPInput as c, OTPInputContext as d } from "input-otp";
3
+ import { Minus as p } from "lucide-react";
4
+ import { cn as n } from "./index.es57.js";
5
+ const u = e.forwardRef(({ className: t, containerClassName: r, ...a }, o) => /* @__PURE__ */ e.createElement(
6
+ c,
33
7
  {
34
- variants: {
35
- variant: {
36
- default: "bg-transparent",
37
- outline: "border-border",
38
- muted: "bg-muted/50"
39
- },
40
- size: {
41
- default: "gap-4 p-4 ",
42
- sm: "gap-2.5 px-4 py-3"
43
- }
44
- },
45
- defaultVariants: {
46
- variant: "default",
47
- size: "default"
48
- }
8
+ ref: o,
9
+ containerClassName: n(
10
+ "flex items-center gap-2 has-[:disabled]:opacity-50",
11
+ r
12
+ ),
13
+ className: n("disabled:cursor-not-allowed", t),
14
+ ...a
49
15
  }
50
- );
51
- function E({
52
- className: t,
53
- variant: e = "default",
54
- size: n = "default",
55
- asChild: o = !1,
56
- ...s
57
- }) {
58
- const l = o ? m : "div";
59
- return /* @__PURE__ */ a.createElement(
60
- l,
61
- {
62
- "data-slot": "item",
63
- "data-variant": e,
64
- "data-size": n,
65
- className: r(c({ variant: e, size: n, className: t })),
66
- ...s
67
- }
68
- );
69
- }
70
- const u = i(
71
- "flex shrink-0 items-center justify-center gap-2 group-has-[[data-slot=item-description]]/item:translate-y-0.5 group-has-[[data-slot=item-description]]/item:self-start [&_svg]:pointer-events-none",
72
- {
73
- variants: {
74
- variant: {
75
- default: "bg-transparent",
76
- icon: "bg-muted size-8 rounded-sm border [&_svg:not([class*='size-'])]:size-4",
77
- image: "size-10 overflow-hidden rounded-sm [&_img]:size-full [&_img]:object-cover"
78
- }
79
- },
80
- defaultVariants: {
81
- variant: "default"
82
- }
83
- }
84
- );
85
- function I({
86
- className: t,
87
- variant: e = "default",
88
- ...n
89
- }) {
90
- return /* @__PURE__ */ a.createElement(
91
- "div",
92
- {
93
- "data-slot": "item-media",
94
- "data-variant": e,
95
- className: r(u({ variant: e, className: t })),
96
- ...n
97
- }
98
- );
99
- }
100
- function N({ className: t, ...e }) {
101
- return /* @__PURE__ */ a.createElement(
16
+ ));
17
+ u.displayName = "InputOTP";
18
+ const f = e.forwardRef(({ className: t, ...r }, a) => /* @__PURE__ */ e.createElement("div", { ref: a, className: n("flex items-center", t), ...r }));
19
+ f.displayName = "InputOTPGroup";
20
+ const O = e.forwardRef(({ index: t, className: r, ...a }, o) => {
21
+ const s = e.useContext(d), { char: i, hasFakeCaret: l, isActive: m } = s.slots[t];
22
+ return /* @__PURE__ */ e.createElement(
102
23
  "div",
103
24
  {
104
- "data-slot": "item-content",
105
- className: r(
106
- "flex flex-1 flex-col gap-1 [&+[data-slot=item-content]]:flex-none",
107
- t
25
+ ref: o,
26
+ className: n(
27
+ "relative flex h-9 w-9 items-center justify-center border-y border-r border-input text-sm shadow-sm transition-all first:rounded-l-md first:border-l last:rounded-r-md",
28
+ m && "z-10 ring-1 ring-ring",
29
+ r
108
30
  ),
109
- ...e
110
- }
111
- );
112
- }
113
- function h({ className: t, ...e }) {
114
- return /* @__PURE__ */ a.createElement(
115
- "div",
116
- {
117
- "data-slot": "item-title",
118
- className: r(
119
- "flex w-fit items-center gap-2 text-sm font-medium leading-snug",
120
- t
121
- ),
122
- ...e
123
- }
124
- );
125
- }
126
- function z({ className: t, ...e }) {
127
- return /* @__PURE__ */ a.createElement(
128
- "p",
129
- {
130
- "data-slot": "item-description",
131
- className: r(
132
- "text-muted-foreground line-clamp-2 text-balance text-sm font-normal leading-normal",
133
- "[&>a:hover]:text-primary [&>a]:underline [&>a]:underline-offset-4",
134
- t
135
- ),
136
- ...e
137
- }
138
- );
139
- }
140
- function y({ className: t, ...e }) {
141
- return /* @__PURE__ */ a.createElement(
142
- "div",
143
- {
144
- "data-slot": "item-actions",
145
- className: r("flex items-center gap-2", t),
146
- ...e
147
- }
148
- );
149
- }
150
- function w({ className: t, ...e }) {
151
- return /* @__PURE__ */ a.createElement(
152
- "div",
153
- {
154
- "data-slot": "item-header",
155
- className: r(
156
- "flex basis-full items-center justify-between gap-2",
157
- t
158
- ),
159
- ...e
160
- }
161
- );
162
- }
163
- function j({ className: t, ...e }) {
164
- return /* @__PURE__ */ a.createElement(
165
- "div",
166
- {
167
- "data-slot": "item-footer",
168
- className: r(
169
- "flex basis-full items-center justify-between gap-2",
170
- t
171
- ),
172
- ...e
173
- }
31
+ ...a
32
+ },
33
+ i,
34
+ l && /* @__PURE__ */ e.createElement("div", { className: "pointer-events-none absolute inset-0 flex items-center justify-center" }, /* @__PURE__ */ e.createElement("div", { className: "h-4 w-px animate-caret-blink bg-foreground duration-1000" }))
174
35
  );
175
- }
36
+ });
37
+ O.displayName = "InputOTPSlot";
38
+ const P = e.forwardRef(({ ...t }, r) => /* @__PURE__ */ e.createElement("div", { ref: r, role: "separator", ...t }, /* @__PURE__ */ e.createElement(p, null)));
39
+ P.displayName = "InputOTPSeparator";
176
40
  export {
177
- E as Item,
178
- y as ItemActions,
179
- N as ItemContent,
180
- z as ItemDescription,
181
- j as ItemFooter,
182
- x as ItemGroup,
183
- w as ItemHeader,
184
- I as ItemMedia,
185
- b as ItemSeparator,
186
- h as ItemTitle
41
+ u as InputOTP,
42
+ f as InputOTPGroup,
43
+ P as InputOTPSeparator,
44
+ O as InputOTPSlot
187
45
  };
188
46
  //# sourceMappingURL=index.es30.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.es30.js","sources":["../src/components/ui/item.tsx"],"sourcesContent":["import * as React from \"react\"\nimport { Slot } from \"@radix-ui/react-slot\"\nimport { cva, type VariantProps } from \"class-variance-authority\"\n\nimport { cn } from \"@/lib/utils\"\nimport { Separator } from \"@/components/ui/separator\"\n\nfunction ItemGroup({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n role=\"list\"\n data-slot=\"item-group\"\n className={cn(\"group/item-group flex flex-col\", className)}\n {...props}\n />\n )\n}\n\nfunction ItemSeparator({\n className,\n ...props\n}: React.ComponentProps<typeof Separator>) {\n return (\n <Separator\n data-slot=\"item-separator\"\n orientation=\"horizontal\"\n className={cn(\"my-0\", className)}\n {...props}\n />\n )\n}\n\nconst itemVariants = cva(\n \"group/item [a]:hover:bg-accent/50 focus-visible:border-ring focus-visible:ring-ring/50 [a]:transition-colors flex flex-wrap items-center rounded-md border border-transparent text-sm outline-none transition-colors duration-100 focus-visible:ring-[3px]\",\n {\n variants: {\n variant: {\n default: \"bg-transparent\",\n outline: \"border-border\",\n muted: \"bg-muted/50\",\n },\n size: {\n default: \"gap-4 p-4 \",\n sm: \"gap-2.5 px-4 py-3\",\n },\n },\n defaultVariants: {\n variant: \"default\",\n size: \"default\",\n },\n }\n)\n\nfunction Item({\n className,\n variant = \"default\",\n size = \"default\",\n asChild = false,\n ...props\n}: React.ComponentProps<\"div\"> &\n VariantProps<typeof itemVariants> & { asChild?: boolean }) {\n const Comp = asChild ? Slot : \"div\"\n return (\n <Comp\n data-slot=\"item\"\n data-variant={variant}\n data-size={size}\n className={cn(itemVariants({ variant, size, className }))}\n {...props}\n />\n )\n}\n\nconst itemMediaVariants = cva(\n \"flex shrink-0 items-center justify-center gap-2 group-has-[[data-slot=item-description]]/item:translate-y-0.5 group-has-[[data-slot=item-description]]/item:self-start [&_svg]:pointer-events-none\",\n {\n variants: {\n variant: {\n default: \"bg-transparent\",\n icon: \"bg-muted size-8 rounded-sm border [&_svg:not([class*='size-'])]:size-4\",\n image:\n \"size-10 overflow-hidden rounded-sm [&_img]:size-full [&_img]:object-cover\",\n },\n },\n defaultVariants: {\n variant: \"default\",\n },\n }\n)\n\nfunction ItemMedia({\n className,\n variant = \"default\",\n ...props\n}: React.ComponentProps<\"div\"> & VariantProps<typeof itemMediaVariants>) {\n return (\n <div\n data-slot=\"item-media\"\n data-variant={variant}\n className={cn(itemMediaVariants({ variant, className }))}\n {...props}\n />\n )\n}\n\nfunction ItemContent({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"item-content\"\n className={cn(\n \"flex flex-1 flex-col gap-1 [&+[data-slot=item-content]]:flex-none\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction ItemTitle({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"item-title\"\n className={cn(\n \"flex w-fit items-center gap-2 text-sm font-medium leading-snug\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction ItemDescription({ className, ...props }: React.ComponentProps<\"p\">) {\n return (\n <p\n data-slot=\"item-description\"\n className={cn(\n \"text-muted-foreground line-clamp-2 text-balance text-sm font-normal leading-normal\",\n \"[&>a:hover]:text-primary [&>a]:underline [&>a]:underline-offset-4\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction ItemActions({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"item-actions\"\n className={cn(\"flex items-center gap-2\", className)}\n {...props}\n />\n )\n}\n\nfunction ItemHeader({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"item-header\"\n className={cn(\n \"flex basis-full items-center justify-between gap-2\",\n className\n )}\n {...props}\n />\n )\n}\n\nfunction ItemFooter({ className, ...props }: React.ComponentProps<\"div\">) {\n return (\n <div\n data-slot=\"item-footer\"\n className={cn(\n \"flex basis-full items-center justify-between gap-2\",\n className\n )}\n {...props}\n />\n )\n}\n\nexport {\n Item,\n ItemMedia,\n ItemContent,\n ItemActions,\n ItemGroup,\n ItemSeparator,\n ItemTitle,\n ItemDescription,\n ItemHeader,\n ItemFooter,\n}\n"],"names":["ItemGroup","className","props","React","cn","ItemSeparator","Separator","itemVariants","cva","Item","variant","size","asChild","Comp","Slot","itemMediaVariants","ItemMedia","ItemContent","ItemTitle","ItemDescription","ItemActions","ItemHeader","ItemFooter"],"mappings":";;;;;AAOA,SAASA,EAAU,EAAE,WAAAC,GAAW,GAAGC,KAAsC;AACvE,SACE,gBAAAC,EAAA;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,MAAK;AAAA,MACL,aAAU;AAAA,MACV,WAAWC,EAAG,kCAAkCH,CAAS;AAAA,MACxD,GAAGC;AAAA,IAAA;AAAA,EAAA;AAGV;AAEA,SAASG,EAAc;AAAA,EACrB,WAAAJ;AAAA,EACA,GAAGC;AACL,GAA2C;AACzC,SACE,gBAAAC,EAAA;AAAA,IAACG;AAAA,IAAA;AAAA,MACC,aAAU;AAAA,MACV,aAAY;AAAA,MACZ,WAAWF,EAAG,QAAQH,CAAS;AAAA,MAC9B,GAAGC;AAAA,IAAA;AAAA,EAAA;AAGV;AAEA,MAAMK,IAAeC;AAAA,EACnB;AAAA,EACA;AAAA,IACE,UAAU;AAAA,MACR,SAAS;AAAA,QACP,SAAS;AAAA,QACT,SAAS;AAAA,QACT,OAAO;AAAA,MAAA;AAAA,MAET,MAAM;AAAA,QACJ,SAAS;AAAA,QACT,IAAI;AAAA,MAAA;AAAA,IACN;AAAA,IAEF,iBAAiB;AAAA,MACf,SAAS;AAAA,MACT,MAAM;AAAA,IAAA;AAAA,EACR;AAEJ;AAEA,SAASC,EAAK;AAAA,EACZ,WAAAR;AAAA,EACA,SAAAS,IAAU;AAAA,EACV,MAAAC,IAAO;AAAA,EACP,SAAAC,IAAU;AAAA,EACV,GAAGV;AACL,GAC6D;AAC3D,QAAMW,IAAOD,IAAUE,IAAO;AAC9B,SACE,gBAAAX,EAAA;AAAA,IAACU;AAAA,IAAA;AAAA,MACC,aAAU;AAAA,MACV,gBAAcH;AAAA,MACd,aAAWC;AAAA,MACX,WAAWP,EAAGG,EAAa,EAAE,SAAAG,GAAS,MAAAC,GAAM,WAAAV,EAAA,CAAW,CAAC;AAAA,MACvD,GAAGC;AAAA,IAAA;AAAA,EAAA;AAGV;AAEA,MAAMa,IAAoBP;AAAA,EACxB;AAAA,EACA;AAAA,IACE,UAAU;AAAA,MACR,SAAS;AAAA,QACP,SAAS;AAAA,QACT,MAAM;AAAA,QACN,OACE;AAAA,MAAA;AAAA,IACJ;AAAA,IAEF,iBAAiB;AAAA,MACf,SAAS;AAAA,IAAA;AAAA,EACX;AAEJ;AAEA,SAASQ,EAAU;AAAA,EACjB,WAAAf;AAAA,EACA,SAAAS,IAAU;AAAA,EACV,GAAGR;AACL,GAAyE;AACvE,SACE,gBAAAC,EAAA;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,aAAU;AAAA,MACV,gBAAcO;AAAA,MACd,WAAWN,EAAGW,EAAkB,EAAE,SAAAL,GAAS,WAAAT,EAAA,CAAW,CAAC;AAAA,MACtD,GAAGC;AAAA,IAAA;AAAA,EAAA;AAGV;AAEA,SAASe,EAAY,EAAE,WAAAhB,GAAW,GAAGC,KAAsC;AACzE,SACE,gBAAAC,EAAA;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,aAAU;AAAA,MACV,WAAWC;AAAA,QACT;AAAA,QACAH;AAAA,MAAA;AAAA,MAED,GAAGC;AAAA,IAAA;AAAA,EAAA;AAGV;AAEA,SAASgB,EAAU,EAAE,WAAAjB,GAAW,GAAGC,KAAsC;AACvE,SACE,gBAAAC,EAAA;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,aAAU;AAAA,MACV,WAAWC;AAAA,QACT;AAAA,QACAH;AAAA,MAAA;AAAA,MAED,GAAGC;AAAA,IAAA;AAAA,EAAA;AAGV;AAEA,SAASiB,EAAgB,EAAE,WAAAlB,GAAW,GAAGC,KAAoC;AAC3E,SACE,gBAAAC,EAAA;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,aAAU;AAAA,MACV,WAAWC;AAAA,QACT;AAAA,QACA;AAAA,QACAH;AAAA,MAAA;AAAA,MAED,GAAGC;AAAA,IAAA;AAAA,EAAA;AAGV;AAEA,SAASkB,EAAY,EAAE,WAAAnB,GAAW,GAAGC,KAAsC;AACzE,SACE,gBAAAC,EAAA;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,aAAU;AAAA,MACV,WAAWC,EAAG,2BAA2BH,CAAS;AAAA,MACjD,GAAGC;AAAA,IAAA;AAAA,EAAA;AAGV;AAEA,SAASmB,EAAW,EAAE,WAAApB,GAAW,GAAGC,KAAsC;AACxE,SACE,gBAAAC,EAAA;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,aAAU;AAAA,MACV,WAAWC;AAAA,QACT;AAAA,QACAH;AAAA,MAAA;AAAA,MAED,GAAGC;AAAA,IAAA;AAAA,EAAA;AAGV;AAEA,SAASoB,EAAW,EAAE,WAAArB,GAAW,GAAGC,KAAsC;AACxE,SACE,gBAAAC,EAAA;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,aAAU;AAAA,MACV,WAAWC;AAAA,QACT;AAAA,QACAH;AAAA,MAAA;AAAA,MAED,GAAGC;AAAA,IAAA;AAAA,EAAA;AAGV;"}
1
+ {"version":3,"file":"index.es30.js","sources":["../src/components/ui/input-otp.tsx"],"sourcesContent":["import * as React from \"react\"\nimport { OTPInput, OTPInputContext } from \"input-otp\"\nimport { Minus } from \"lucide-react\"\n\nimport { cn } from \"@/lib/utils\"\n\nconst InputOTP = React.forwardRef<\n React.ElementRef<typeof OTPInput>,\n React.ComponentPropsWithoutRef<typeof OTPInput>\n>(({ className, containerClassName, ...props }, ref) => (\n <OTPInput\n ref={ref}\n containerClassName={cn(\n \"flex items-center gap-2 has-[:disabled]:opacity-50\",\n containerClassName\n )}\n className={cn(\"disabled:cursor-not-allowed\", className)}\n {...props}\n />\n))\nInputOTP.displayName = \"InputOTP\"\n\nconst InputOTPGroup = React.forwardRef<\n React.ElementRef<\"div\">,\n React.ComponentPropsWithoutRef<\"div\">\n>(({ className, ...props }, ref) => (\n <div ref={ref} className={cn(\"flex items-center\", className)} {...props} />\n))\nInputOTPGroup.displayName = \"InputOTPGroup\"\n\nconst InputOTPSlot = React.forwardRef<\n React.ElementRef<\"div\">,\n React.ComponentPropsWithoutRef<\"div\"> & { index: number }\n>(({ index, className, ...props }, ref) => {\n const inputOTPContext = React.useContext(OTPInputContext)\n const { char, hasFakeCaret, isActive } = inputOTPContext.slots[index]\n\n return (\n <div\n ref={ref}\n className={cn(\n \"relative flex h-9 w-9 items-center justify-center border-y border-r border-input text-sm shadow-sm transition-all first:rounded-l-md first:border-l last:rounded-r-md\",\n isActive && \"z-10 ring-1 ring-ring\",\n className\n )}\n {...props}\n >\n {char}\n {hasFakeCaret && (\n <div className=\"pointer-events-none absolute inset-0 flex items-center justify-center\">\n <div className=\"h-4 w-px animate-caret-blink bg-foreground duration-1000\" />\n </div>\n )}\n </div>\n )\n})\nInputOTPSlot.displayName = \"InputOTPSlot\"\n\nconst InputOTPSeparator = React.forwardRef<\n React.ElementRef<\"div\">,\n React.ComponentPropsWithoutRef<\"div\">\n>(({ ...props }, ref) => (\n <div ref={ref} role=\"separator\" {...props}>\n <Minus />\n </div>\n))\nInputOTPSeparator.displayName = \"InputOTPSeparator\"\n\nexport { InputOTP, InputOTPGroup, InputOTPSlot, InputOTPSeparator }\n"],"names":["InputOTP","React","className","containerClassName","props","ref","OTPInput","cn","InputOTPGroup","InputOTPSlot","index","inputOTPContext","OTPInputContext","char","hasFakeCaret","isActive","InputOTPSeparator","Minus"],"mappings":";;;;AAMA,MAAMA,IAAWC,EAAM,WAGrB,CAAC,EAAE,WAAAC,GAAW,oBAAAC,GAAoB,GAAGC,EAAA,GAASC,MAC9C,gBAAAJ,EAAA;AAAA,EAACK;AAAA,EAAA;AAAA,IACC,KAAAD;AAAA,IACA,oBAAoBE;AAAA,MAClB;AAAA,MACAJ;AAAA,IAAA;AAAA,IAEF,WAAWI,EAAG,+BAA+BL,CAAS;AAAA,IACrD,GAAGE;AAAA,EAAA;AACN,CACD;AACDJ,EAAS,cAAc;AAEvB,MAAMQ,IAAgBP,EAAM,WAG1B,CAAC,EAAE,WAAAC,GAAW,GAAGE,KAASC,sCACzB,OAAA,EAAI,KAAAA,GAAU,WAAWE,EAAG,qBAAqBL,CAAS,GAAI,GAAGE,GAAO,CAC1E;AACDI,EAAc,cAAc;AAE5B,MAAMC,IAAeR,EAAM,WAGzB,CAAC,EAAE,OAAAS,GAAO,WAAAR,GAAW,GAAGE,EAAA,GAASC,MAAQ;AACzC,QAAMM,IAAkBV,EAAM,WAAWW,CAAe,GAClD,EAAE,MAAAC,GAAM,cAAAC,GAAc,UAAAC,MAAaJ,EAAgB,MAAMD,CAAK;AAEpE,SACE,gBAAAT,EAAA;AAAA,IAAC;AAAA,IAAA;AAAA,MACC,KAAAI;AAAA,MACA,WAAWE;AAAA,QACT;AAAA,QACAQ,KAAY;AAAA,QACZb;AAAA,MAAA;AAAA,MAED,GAAGE;AAAA,IAAA;AAAA,IAEHS;AAAA,IACAC,qCACE,OAAA,EAAI,WAAU,2EACb,gBAAAb,EAAA,cAAC,OAAA,EAAI,WAAU,2DAAA,CAA2D,CAC5E;AAAA,EAAA;AAIR,CAAC;AACDQ,EAAa,cAAc;AAE3B,MAAMO,IAAoBf,EAAM,WAG9B,CAAC,EAAE,GAAGG,KAASC,sCACd,OAAA,EAAI,KAAAA,GAAU,MAAK,aAAa,GAAGD,KAClC,gBAAAH,EAAA,cAACgB,GAAA,IAAM,CACT,CACD;AACDD,EAAkB,cAAc;"}