ml-uikit 1.1.7 → 1.1.8

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 (285) hide show
  1. package/dist/components/ui/password-input.d.ts +9 -0
  2. package/dist/components/ui/password-input.d.ts.map +1 -0
  3. package/dist/components/ui/searchable-dropdown.d.ts +22 -0
  4. package/dist/components/ui/searchable-dropdown.d.ts.map +1 -0
  5. package/dist/components/ui/table.d.ts +5 -1
  6. package/dist/components/ui/table.d.ts.map +1 -1
  7. package/dist/index.cjs.js +1 -1
  8. package/dist/index.cjs10.js +1 -1
  9. package/dist/index.cjs10.js.map +1 -1
  10. package/dist/index.cjs11.js +1 -1
  11. package/dist/index.cjs11.js.map +1 -1
  12. package/dist/index.cjs12.js +1 -1
  13. package/dist/index.cjs12.js.map +1 -1
  14. package/dist/index.cjs13.js +1 -1
  15. package/dist/index.cjs13.js.map +1 -1
  16. package/dist/index.cjs14.js +1 -1
  17. package/dist/index.cjs14.js.map +1 -1
  18. package/dist/index.cjs15.js +1 -1
  19. package/dist/index.cjs15.js.map +1 -1
  20. package/dist/index.cjs16.js +4 -4
  21. package/dist/index.cjs16.js.map +1 -1
  22. package/dist/index.cjs17.js +1 -1
  23. package/dist/index.cjs17.js.map +1 -1
  24. package/dist/index.cjs19.js +1 -1
  25. package/dist/index.cjs19.js.map +1 -1
  26. package/dist/index.cjs2.js +1 -1
  27. package/dist/index.cjs2.js.map +1 -1
  28. package/dist/index.cjs20.js +1 -1
  29. package/dist/index.cjs20.js.map +1 -1
  30. package/dist/index.cjs21.js +1 -1
  31. package/dist/index.cjs21.js.map +1 -1
  32. package/dist/index.cjs22.js +1 -1
  33. package/dist/index.cjs22.js.map +1 -1
  34. package/dist/index.cjs23.js +1 -1
  35. package/dist/index.cjs23.js.map +1 -1
  36. package/dist/index.cjs24.js +1 -1
  37. package/dist/index.cjs24.js.map +1 -1
  38. package/dist/index.cjs25.js +1 -1
  39. package/dist/index.cjs25.js.map +1 -1
  40. package/dist/index.cjs26.js +1 -1
  41. package/dist/index.cjs26.js.map +1 -1
  42. package/dist/index.cjs27.js +1 -1
  43. package/dist/index.cjs27.js.map +1 -1
  44. package/dist/index.cjs28.js +1 -1
  45. package/dist/index.cjs28.js.map +1 -1
  46. package/dist/index.cjs29.js +1 -1
  47. package/dist/index.cjs29.js.map +1 -1
  48. package/dist/index.cjs3.js +1 -1
  49. package/dist/index.cjs3.js.map +1 -1
  50. package/dist/index.cjs30.js +1 -1
  51. package/dist/index.cjs30.js.map +1 -1
  52. package/dist/index.cjs31.js +1 -1
  53. package/dist/index.cjs31.js.map +1 -1
  54. package/dist/index.cjs32.js +1 -1
  55. package/dist/index.cjs32.js.map +1 -1
  56. package/dist/index.cjs33.js +1 -1
  57. package/dist/index.cjs33.js.map +1 -1
  58. package/dist/index.cjs34.js +1 -1
  59. package/dist/index.cjs34.js.map +1 -1
  60. package/dist/index.cjs35.js +1 -1
  61. package/dist/index.cjs35.js.map +1 -1
  62. package/dist/index.cjs36.js +1 -1
  63. package/dist/index.cjs36.js.map +1 -1
  64. package/dist/index.cjs37.js +1 -1
  65. package/dist/index.cjs37.js.map +1 -1
  66. package/dist/index.cjs38.js +1 -1
  67. package/dist/index.cjs38.js.map +1 -1
  68. package/dist/index.cjs39.js +1 -1
  69. package/dist/index.cjs39.js.map +1 -1
  70. package/dist/index.cjs4.js +1 -1
  71. package/dist/index.cjs4.js.map +1 -1
  72. package/dist/index.cjs40.js +1 -1
  73. package/dist/index.cjs40.js.map +1 -1
  74. package/dist/index.cjs41.js +1 -1
  75. package/dist/index.cjs41.js.map +1 -1
  76. package/dist/index.cjs42.js +1 -1
  77. package/dist/index.cjs42.js.map +1 -1
  78. package/dist/index.cjs43.js +1 -1
  79. package/dist/index.cjs43.js.map +1 -1
  80. package/dist/index.cjs44.js +1 -1
  81. package/dist/index.cjs44.js.map +1 -1
  82. package/dist/index.cjs45.js +1 -1
  83. package/dist/index.cjs45.js.map +1 -1
  84. package/dist/index.cjs46.js +1 -1
  85. package/dist/index.cjs46.js.map +1 -1
  86. package/dist/index.cjs47.js +1 -1
  87. package/dist/index.cjs47.js.map +1 -1
  88. package/dist/index.cjs48.js +1 -1
  89. package/dist/index.cjs48.js.map +1 -1
  90. package/dist/index.cjs49.js +1 -1
  91. package/dist/index.cjs49.js.map +1 -1
  92. package/dist/index.cjs5.js +1 -1
  93. package/dist/index.cjs5.js.map +1 -1
  94. package/dist/index.cjs50.js +1 -1
  95. package/dist/index.cjs50.js.map +1 -1
  96. package/dist/index.cjs51.js +1 -1
  97. package/dist/index.cjs51.js.map +1 -1
  98. package/dist/index.cjs52.js +1 -1
  99. package/dist/index.cjs52.js.map +1 -1
  100. package/dist/index.cjs53.js +1 -1
  101. package/dist/index.cjs53.js.map +1 -1
  102. package/dist/index.cjs54.js +1 -1
  103. package/dist/index.cjs54.js.map +1 -1
  104. package/dist/index.cjs55.js +1 -1
  105. package/dist/index.cjs55.js.map +1 -1
  106. package/dist/index.cjs56.js +1 -1
  107. package/dist/index.cjs56.js.map +1 -1
  108. package/dist/index.cjs57.js +1 -1
  109. package/dist/index.cjs57.js.map +1 -1
  110. package/dist/index.cjs58.js +1 -1
  111. package/dist/index.cjs58.js.map +1 -1
  112. package/dist/index.cjs59.js +1 -1
  113. package/dist/index.cjs59.js.map +1 -1
  114. package/dist/index.cjs60.js +1 -1
  115. package/dist/index.cjs60.js.map +1 -1
  116. package/dist/index.cjs61.js +1 -1
  117. package/dist/index.cjs61.js.map +1 -1
  118. package/dist/index.cjs62.js +1 -1
  119. package/dist/index.cjs62.js.map +1 -1
  120. package/dist/index.cjs63.js +2 -0
  121. package/dist/index.cjs63.js.map +1 -0
  122. package/dist/index.cjs64.js +2 -0
  123. package/dist/index.cjs64.js.map +1 -0
  124. package/dist/index.cjs65.js +2 -0
  125. package/dist/index.cjs65.js.map +1 -0
  126. package/dist/index.cjs66.js +2 -0
  127. package/dist/index.cjs66.js.map +1 -0
  128. package/dist/index.cjs67.js +2 -0
  129. package/dist/index.cjs67.js.map +1 -0
  130. package/dist/index.cjs68.js +7 -0
  131. package/dist/index.cjs68.js.map +1 -0
  132. package/dist/index.cjs69.js +2 -0
  133. package/dist/index.cjs69.js.map +1 -0
  134. package/dist/index.cjs7.js +1 -1
  135. package/dist/index.cjs7.js.map +1 -1
  136. package/dist/index.cjs70.js +2 -0
  137. package/dist/index.cjs70.js.map +1 -0
  138. package/dist/index.cjs71.js +2 -0
  139. package/dist/index.cjs71.js.map +1 -0
  140. package/dist/index.cjs8.js +1 -1
  141. package/dist/index.cjs8.js.map +1 -1
  142. package/dist/index.cjs9.js +1 -1
  143. package/dist/index.cjs9.js.map +1 -1
  144. package/dist/index.d.ts +3 -1
  145. package/dist/index.d.ts.map +1 -1
  146. package/dist/index.es.js +271 -258
  147. package/dist/index.es.js.map +1 -1
  148. package/dist/index.es10.js +22 -21
  149. package/dist/index.es10.js.map +1 -1
  150. package/dist/index.es11.js +14 -13
  151. package/dist/index.es11.js.map +1 -1
  152. package/dist/index.es12.js +31 -31
  153. package/dist/index.es12.js.map +1 -1
  154. package/dist/index.es13.js +39 -38
  155. package/dist/index.es13.js.map +1 -1
  156. package/dist/index.es14.js +34 -33
  157. package/dist/index.es14.js.map +1 -1
  158. package/dist/index.es15.js +107 -102
  159. package/dist/index.es15.js.map +1 -1
  160. package/dist/index.es16.js +155 -140
  161. package/dist/index.es16.js.map +1 -1
  162. package/dist/index.es17.js +21 -18
  163. package/dist/index.es17.js.map +1 -1
  164. package/dist/index.es19.js +63 -59
  165. package/dist/index.es19.js.map +1 -1
  166. package/dist/index.es2.js +10 -6
  167. package/dist/index.es2.js.map +1 -1
  168. package/dist/index.es20.js +85 -78
  169. package/dist/index.es20.js.map +1 -1
  170. package/dist/index.es21.js +68 -59
  171. package/dist/index.es21.js.map +1 -1
  172. package/dist/index.es22.js +68 -62
  173. package/dist/index.es22.js.map +1 -1
  174. package/dist/index.es23.js +83 -76
  175. package/dist/index.es23.js.map +1 -1
  176. package/dist/index.es24.js +178 -94
  177. package/dist/index.es24.js.map +1 -1
  178. package/dist/index.es25.js +57 -164
  179. package/dist/index.es25.js.map +1 -1
  180. package/dist/index.es26.js +198 -77
  181. package/dist/index.es26.js.map +1 -1
  182. package/dist/index.es27.js +90 -20
  183. package/dist/index.es27.js.map +1 -1
  184. package/dist/index.es28.js +21 -22
  185. package/dist/index.es28.js.map +1 -1
  186. package/dist/index.es29.js +19 -343
  187. package/dist/index.es29.js.map +1 -1
  188. package/dist/index.es3.js +35 -32
  189. package/dist/index.es3.js.map +1 -1
  190. package/dist/index.es30.js +38 -148
  191. package/dist/index.es30.js.map +1 -1
  192. package/dist/index.es31.js +377 -42
  193. package/dist/index.es31.js.map +1 -1
  194. package/dist/index.es32.js +146 -172
  195. package/dist/index.es32.js.map +1 -1
  196. package/dist/index.es33.js +46 -253
  197. package/dist/index.es33.js.map +1 -1
  198. package/dist/index.es34.js +195 -180
  199. package/dist/index.es34.js.map +1 -1
  200. package/dist/index.es35.js +253 -29
  201. package/dist/index.es35.js.map +1 -1
  202. package/dist/index.es36.js +183 -14
  203. package/dist/index.es36.js.map +1 -1
  204. package/dist/index.es37.js +29 -93
  205. package/dist/index.es37.js.map +1 -1
  206. package/dist/index.es38.js +13 -187
  207. package/dist/index.es38.js.map +1 -1
  208. package/dist/index.es39.js +93 -96
  209. package/dist/index.es39.js.map +1 -1
  210. package/dist/index.es4.js +38 -32
  211. package/dist/index.es4.js.map +1 -1
  212. package/dist/index.es40.js +182 -80
  213. package/dist/index.es40.js.map +1 -1
  214. package/dist/index.es41.js +98 -17
  215. package/dist/index.es41.js.map +1 -1
  216. package/dist/index.es42.js +101 -21
  217. package/dist/index.es42.js.map +1 -1
  218. package/dist/index.es43.js +20 -28
  219. package/dist/index.es43.js.map +1 -1
  220. package/dist/index.es44.js +19 -28
  221. package/dist/index.es44.js.map +1 -1
  222. package/dist/index.es45.js +25 -176
  223. package/dist/index.es45.js.map +1 -1
  224. package/dist/index.es46.js +36 -21
  225. package/dist/index.es46.js.map +1 -1
  226. package/dist/index.es47.js +171 -78
  227. package/dist/index.es47.js.map +1 -1
  228. package/dist/index.es48.js +17 -551
  229. package/dist/index.es48.js.map +1 -1
  230. package/dist/index.es49.js +106 -13
  231. package/dist/index.es49.js.map +1 -1
  232. package/dist/index.es5.js +71 -67
  233. package/dist/index.es5.js.map +1 -1
  234. package/dist/index.es50.js +559 -35
  235. package/dist/index.es50.js.map +1 -1
  236. package/dist/index.es51.js +12 -19
  237. package/dist/index.es51.js.map +1 -1
  238. package/dist/index.es52.js +47 -12
  239. package/dist/index.es52.js.map +1 -1
  240. package/dist/index.es53.js +21 -25
  241. package/dist/index.es53.js.map +1 -1
  242. package/dist/index.es54.js +14 -217
  243. package/dist/index.es54.js.map +1 -1
  244. package/dist/index.es55.js +23 -44
  245. package/dist/index.es55.js.map +1 -1
  246. package/dist/index.es56.js +237 -13
  247. package/dist/index.es56.js.map +1 -1
  248. package/dist/index.es57.js +44 -28
  249. package/dist/index.es57.js.map +1 -1
  250. package/dist/index.es58.js +17 -36
  251. package/dist/index.es58.js.map +1 -1
  252. package/dist/index.es59.js +33 -18
  253. package/dist/index.es59.js.map +1 -1
  254. package/dist/index.es60.js +39 -6
  255. package/dist/index.es60.js.map +1 -1
  256. package/dist/index.es61.js +21 -267
  257. package/dist/index.es61.js.map +1 -1
  258. package/dist/index.es62.js +3 -6268
  259. package/dist/index.es62.js.map +1 -1
  260. package/dist/index.es63.js +9 -0
  261. package/dist/index.es63.js.map +1 -0
  262. package/dist/index.es64.js +270 -0
  263. package/dist/index.es64.js.map +1 -0
  264. package/dist/index.es65.js +11 -0
  265. package/dist/index.es65.js.map +1 -0
  266. package/dist/index.es66.js +5 -0
  267. package/dist/index.es66.js.map +1 -0
  268. package/dist/index.es67.js +27 -0
  269. package/dist/index.es67.js.map +1 -0
  270. package/dist/index.es68.js +237 -0
  271. package/dist/index.es68.js.map +1 -0
  272. package/dist/index.es69.js +5 -0
  273. package/dist/index.es69.js.map +1 -0
  274. package/dist/index.es7.js +25 -24
  275. package/dist/index.es7.js.map +1 -1
  276. package/dist/index.es70.js +5 -0
  277. package/dist/index.es70.js.map +1 -0
  278. package/dist/index.es71.js +6271 -0
  279. package/dist/index.es71.js.map +1 -0
  280. package/dist/index.es8.js +43 -41
  281. package/dist/index.es8.js.map +1 -1
  282. package/dist/index.es9.js +51 -48
  283. package/dist/index.es9.js.map +1 -1
  284. package/dist/style.css +59 -0
  285. package/package.json +1 -1
@@ -1,188 +1,203 @@
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.es60.js";
5
- import { Separator as d } from "./index.es46.js";
6
- function x({ className: t, ...e }) {
7
- return /* @__PURE__ */ a.createElement(
8
- "div",
1
+ import { j as e } from "./index.es62.js";
2
+ import * as o from "react";
3
+ import { Globe as R, ChevronDown as U, Check as G } from "lucide-react";
4
+ import * as L from "./index.es64.js";
5
+ import { cn as r } from "./index.es63.js";
6
+ import { Command as M, CommandInput as Y, CommandList as $, CommandEmpty as B, CommandGroup as D, CommandItem as H } from "./index.es19.js";
7
+ import { Popover as V, PopoverTrigger as q, PopoverContent as z } from "./index.es43.js";
8
+ import { PHONE_COUNTRY_OPTIONS as J } from "./index.es35.js";
9
+ const K = J, Q = L, W = (s) => {
10
+ const c = Array.from(s);
11
+ if (c.length !== 2)
12
+ return null;
13
+ const n = c.map((a) => {
14
+ const l = a.codePointAt(0);
15
+ return !l || l < 127462 || l > 127487 ? null : String.fromCharCode(l - 127462 + 65);
16
+ });
17
+ return n.some((a) => a === null) ? null : n.join("");
18
+ }, N = ({
19
+ flag: s,
20
+ className: c
21
+ }) => {
22
+ const n = o.useMemo(
23
+ () => W(s),
24
+ [s]
25
+ ), a = n ? Q[n] : void 0;
26
+ return a ? /* @__PURE__ */ e.jsx(
27
+ a,
9
28
  {
10
- role: "list",
11
- "data-slot": "item-group",
12
- className: r("group/item-group flex flex-col", t),
13
- ...e
29
+ "aria-hidden": "true",
30
+ className: r("h-3.5 w-5 shrink-0 rounded-[2px] object-cover", c)
14
31
  }
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]",
33
- {
34
- variants: {
35
- variant: {
36
- default: "bg-transparent",
37
- outline: "border-border",
38
- muted: "bg-muted/50"
32
+ ) : /* @__PURE__ */ e.jsx("span", { "aria-hidden": "true", className: c, children: s });
33
+ }, X = o.forwardRef(
34
+ ({
35
+ className: s,
36
+ inputClassName: c,
37
+ label: n = "Phone number",
38
+ helperText: a,
39
+ error: l,
40
+ country: i,
41
+ defaultCountry: k,
42
+ countryOptions: x = K,
43
+ onCountryChange: f,
44
+ disabled: d,
45
+ type: C = "tel",
46
+ onFocus: v,
47
+ onBlur: y,
48
+ placeholder: S = "Enter phone number",
49
+ ...m
50
+ }, P) => {
51
+ const [h, b] = o.useState(!1), [I, g] = o.useState(!1), [O, F] = o.useState(
52
+ k
53
+ ), u = i ?? O, p = o.useMemo(
54
+ () => x.find((t) => t.value === u),
55
+ [x, u]
56
+ ), E = o.useCallback(
57
+ (t) => {
58
+ i === void 0 && F(t.value), f?.(t), b(!1);
39
59
  },
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
- }
49
- }
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
- }
60
+ [i, f]
61
+ ), T = m["aria-invalid"] === !0 || m["aria-invalid"] === "true", A = !!l || T, w = h || I;
62
+ return /* @__PURE__ */ e.jsxs("div", { className: r("flex w-full flex-col items-start gap-1", s), children: [
63
+ n ? /* @__PURE__ */ e.jsx("p", { className: "w-full text-[14px] font-medium leading-[20px] text-black", children: n }) : null,
64
+ /* @__PURE__ */ e.jsxs(
65
+ "div",
66
+ {
67
+ className: r(
68
+ "flex h-10 w-full items-stretch overflow-hidden rounded-[8px] border bg-white transition-colors",
69
+ d ? "border-[#e6e6e6] bg-[#f2f2f2]" : A ? "border-[#ff3b30]" : w ? "border-[#1d1c20]" : "border-[#e6e6e6]"
70
+ ),
71
+ children: [
72
+ /* @__PURE__ */ e.jsxs(
73
+ V,
74
+ {
75
+ open: h,
76
+ onOpenChange: (t) => {
77
+ d || b(t);
78
+ },
79
+ children: [
80
+ /* @__PURE__ */ e.jsx(q, { asChild: !0, children: /* @__PURE__ */ e.jsxs(
81
+ "button",
82
+ {
83
+ type: "button",
84
+ disabled: d,
85
+ "aria-label": "Select country",
86
+ className: r(
87
+ "flex h-full shrink-0 items-center gap-1 px-2 text-[14px] leading-[20px] outline-none transition-colors",
88
+ p ? w ? "bg-white" : "bg-[#fafafa]" : "bg-white",
89
+ d && "bg-[#f2f2f2] text-[#b3b3b3]"
90
+ ),
91
+ children: [
92
+ p ? /* @__PURE__ */ e.jsxs(e.Fragment, { children: [
93
+ /* @__PURE__ */ e.jsx(N, { flag: p.flag }),
94
+ /* @__PURE__ */ e.jsx("span", { className: "font-normal text-black", children: p.label })
95
+ ] }) : /* @__PURE__ */ e.jsx(R, { className: "h-4 w-4 text-[#adacb0]" }),
96
+ /* @__PURE__ */ e.jsx(U, { className: "h-4 w-4 text-[#adacb0]" })
97
+ ]
98
+ }
99
+ ) }),
100
+ /* @__PURE__ */ e.jsx(
101
+ z,
102
+ {
103
+ align: "start",
104
+ sideOffset: 8,
105
+ className: "w-[240px] rounded-[8px] border border-[#e6e6e6] bg-white p-0 shadow-[0px_2px_4px_0px_rgba(19,25,39,0.12),0px_4px_4px_0px_rgba(19,25,39,0.08)]",
106
+ children: /* @__PURE__ */ e.jsxs(
107
+ M,
108
+ {
109
+ className: r(
110
+ "rounded-[8px] bg-white",
111
+ "[&_[cmdk-input-wrapper]]:mx-2 [&_[cmdk-input-wrapper]]:mb-1 [&_[cmdk-input-wrapper]]:mt-2 [&_[cmdk-input-wrapper]]:h-8 [&_[cmdk-input-wrapper]]:rounded-[4px] [&_[cmdk-input-wrapper]]:border [&_[cmdk-input-wrapper]]:border-[#e6e6e6] [&_[cmdk-input-wrapper]]:px-3",
112
+ "[&_[cmdk-input-wrapper]_svg]:mr-2 [&_[cmdk-input-wrapper]_svg]:h-4 [&_[cmdk-input-wrapper]_svg]:w-4 [&_[cmdk-input-wrapper]_svg]:text-[#adacb0]",
113
+ "[&_[cmdk-input]]:h-full [&_[cmdk-input]]:py-0 [&_[cmdk-input]]:text-[14px] [&_[cmdk-input]]:leading-[20px] [&_[cmdk-input]]:text-black [&_[cmdk-input]]:placeholder:text-[#adacb0]"
114
+ ),
115
+ children: [
116
+ /* @__PURE__ */ e.jsx(Y, { placeholder: "Search country" }),
117
+ /* @__PURE__ */ e.jsxs($, { className: "max-h-56 px-1 pb-1", children: [
118
+ /* @__PURE__ */ e.jsx(B, { className: "px-3 py-2 text-left text-[12px] leading-[16px] text-[#7f7d83]", children: "No country found" }),
119
+ /* @__PURE__ */ e.jsx(D, { className: "p-0", children: x.map((t) => {
120
+ const _ = t.value === u, j = t.name || t.label;
121
+ return /* @__PURE__ */ e.jsxs(
122
+ H,
123
+ {
124
+ value: `${t.label} ${j} ${t.dialCode}`,
125
+ onSelect: () => E(t),
126
+ className: r(
127
+ "flex w-full cursor-pointer items-center gap-2 rounded-[4px] px-3 py-2 text-[14px] leading-[20px] text-black",
128
+ "data-[selected=true]:bg-[#fafafa] data-[selected=true]:text-black",
129
+ _ && "bg-[#fafafa]"
130
+ ),
131
+ children: [
132
+ /* @__PURE__ */ e.jsx(N, { flag: t.flag }),
133
+ /* @__PURE__ */ e.jsx("span", { className: "min-w-0 flex-1 truncate", children: j }),
134
+ t.dialCode ? /* @__PURE__ */ e.jsx("span", { className: "text-[#7f7d83]", children: t.dialCode }) : null,
135
+ /* @__PURE__ */ e.jsx(
136
+ G,
137
+ {
138
+ className: r(
139
+ "h-4 w-4 text-[#1d1c20]",
140
+ _ ? "opacity-100" : "opacity-0"
141
+ )
142
+ }
143
+ )
144
+ ]
145
+ },
146
+ t.value
147
+ );
148
+ }) })
149
+ ] })
150
+ ]
151
+ }
152
+ )
153
+ }
154
+ )
155
+ ]
156
+ }
157
+ ),
158
+ /* @__PURE__ */ e.jsxs(
159
+ "div",
160
+ {
161
+ className: r(
162
+ "flex min-w-0 flex-1 items-center gap-2 border-l border-[#e6e6e6] bg-white px-3 py-2",
163
+ d && "bg-[#f2f2f2]"
164
+ ),
165
+ children: [
166
+ p?.dialCode ? /* @__PURE__ */ e.jsx("span", { className: "shrink-0 text-[14px] leading-[20px] text-[#7f7d83]", children: p.dialCode }) : null,
167
+ /* @__PURE__ */ e.jsx(
168
+ "input",
169
+ {
170
+ ref: P,
171
+ disabled: d,
172
+ placeholder: S,
173
+ onFocus: (t) => {
174
+ g(!0), v?.(t);
175
+ },
176
+ onBlur: (t) => {
177
+ g(!1), y?.(t);
178
+ },
179
+ className: r(
180
+ "h-full w-full min-w-0 border-0 bg-transparent p-0 text-[14px] leading-[20px] text-black outline-none placeholder:text-[#adacb0]",
181
+ d && "cursor-not-allowed text-[#9ca3af] placeholder:text-[#b3b3b3]",
182
+ c
183
+ ),
184
+ type: C,
185
+ ...m
186
+ }
187
+ )
188
+ ]
189
+ }
190
+ )
191
+ ]
192
+ }
193
+ ),
194
+ l ? /* @__PURE__ */ e.jsx("p", { className: "w-full text-[12px] leading-[16px] text-[#ff3b30]", children: l }) : a ? /* @__PURE__ */ e.jsx("p", { className: "w-full text-[12px] leading-[16px] text-[#7f7d83]", children: a }) : null
195
+ ] });
83
196
  }
84
197
  );
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(
102
- "div",
103
- {
104
- "data-slot": "item-content",
105
- className: r(
106
- "flex flex-1 flex-col gap-1 [&+[data-slot=item-content]]:flex-none",
107
- t
108
- ),
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
- }
174
- );
175
- }
198
+ X.displayName = "PhoneInput";
176
199
  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
200
+ K as DEFAULT_COUNTRY_OPTIONS,
201
+ X as PhoneInput
187
202
  };
188
203
  //# sourceMappingURL=index.es34.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.es34.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.es34.js","sources":["../src/components/ui/phone-input.tsx"],"sourcesContent":["import * as React from \"react\"\nimport { Check, ChevronDown, Globe } from \"lucide-react\"\nimport * as CountryFlags from \"country-flag-icons/react/3x2\"\n\nimport { cn } from \"@/lib/utils\"\nimport {\n Command,\n CommandEmpty,\n CommandGroup,\n CommandInput,\n CommandItem,\n CommandList,\n} from \"@/components/ui/command\"\nimport {\n Popover,\n PopoverContent,\n PopoverTrigger,\n} from \"@/components/ui/popover\"\n\nimport {\n PHONE_COUNTRY_OPTIONS,\n type PhoneCountryOption,\n} from \"./phone-countries\"\n\nconst DEFAULT_COUNTRY_OPTIONS = PHONE_COUNTRY_OPTIONS\ntype FlagComponent = React.ComponentType<React.SVGProps<SVGSVGElement>>\n\nconst COUNTRY_FLAG_COMPONENTS = CountryFlags as Record<string, FlagComponent>\n\nexport interface PhoneInputProps\n extends Omit<React.ComponentProps<\"input\">, \"className\"> {\n className?: string\n inputClassName?: string\n label?: string\n helperText?: string\n error?: string\n country?: string\n defaultCountry?: string\n countryOptions?: PhoneCountryOption[]\n onCountryChange?: (country: PhoneCountryOption) => void\n}\n\nconst getCountryCodeFromFlagEmoji = (flag: string): string | null => {\n const symbols = Array.from(flag)\n if (symbols.length !== 2) {\n return null\n }\n\n const letters = symbols.map((symbol) => {\n const codePoint = symbol.codePointAt(0)\n if (!codePoint || codePoint < 0x1f1e6 || codePoint > 0x1f1ff) {\n return null\n }\n return String.fromCharCode(codePoint - 0x1f1e6 + 65)\n })\n\n if (letters.some((letter) => letter === null)) {\n return null\n }\n\n return letters.join(\"\")\n}\n\nconst FlagIcon = ({\n flag,\n className,\n}: {\n flag: string\n className?: string\n}) => {\n const countryCode = React.useMemo(\n () => getCountryCodeFromFlagEmoji(flag),\n [flag]\n )\n const SvgFlag = countryCode ? COUNTRY_FLAG_COMPONENTS[countryCode] : undefined\n\n if (SvgFlag) {\n return (\n <SvgFlag\n aria-hidden=\"true\"\n className={cn(\"h-3.5 w-5 shrink-0 rounded-[2px] object-cover\", className)}\n />\n )\n }\n\n return (\n <span aria-hidden=\"true\" className={className}>\n {flag}\n </span>\n )\n}\n\nconst PhoneInput = React.forwardRef<HTMLInputElement, PhoneInputProps>(\n (\n {\n className,\n inputClassName,\n label = \"Phone number\",\n helperText,\n error,\n country,\n defaultCountry,\n countryOptions = DEFAULT_COUNTRY_OPTIONS,\n onCountryChange,\n disabled,\n type = \"tel\",\n onFocus,\n onBlur,\n placeholder = \"Enter phone number\",\n ...props\n },\n ref\n ) => {\n const [open, setOpen] = React.useState(false)\n const [isInputFocused, setIsInputFocused] = React.useState(false)\n const [uncontrolledCountry, setUncontrolledCountry] = React.useState(\n defaultCountry\n )\n\n const selectedCountryValue = country ?? uncontrolledCountry\n\n const selectedCountry = React.useMemo(\n () =>\n countryOptions.find((option) => option.value === selectedCountryValue),\n [countryOptions, selectedCountryValue]\n )\n\n const handleCountrySelect = React.useCallback(\n (option: PhoneCountryOption) => {\n if (country === undefined) {\n setUncontrolledCountry(option.value)\n }\n onCountryChange?.(option)\n setOpen(false)\n },\n [country, onCountryChange]\n )\n\n const isAriaInvalid =\n props[\"aria-invalid\"] === true || props[\"aria-invalid\"] === \"true\"\n const hasError = Boolean(error) || isAriaInvalid\n const isActive = open || isInputFocused\n\n return (\n <div className={cn(\"flex w-full flex-col items-start gap-1\", className)}>\n {label ? (\n <p className=\"w-full text-[14px] font-medium leading-[20px] text-black\">\n {label}\n </p>\n ) : null}\n\n <div\n className={cn(\n \"flex h-10 w-full items-stretch overflow-hidden rounded-[8px] border bg-white transition-colors\",\n disabled\n ? \"border-[#e6e6e6] bg-[#f2f2f2]\"\n : hasError\n ? \"border-[#ff3b30]\"\n : isActive\n ? \"border-[#1d1c20]\"\n : \"border-[#e6e6e6]\"\n )}\n >\n <Popover\n open={open}\n onOpenChange={(nextOpen) => {\n if (disabled) {\n return\n }\n setOpen(nextOpen)\n }}\n >\n <PopoverTrigger asChild>\n <button\n type=\"button\"\n disabled={disabled}\n aria-label=\"Select country\"\n className={cn(\n \"flex h-full shrink-0 items-center gap-1 px-2 text-[14px] leading-[20px] outline-none transition-colors\",\n selectedCountry\n ? isActive\n ? \"bg-white\"\n : \"bg-[#fafafa]\"\n : \"bg-white\",\n disabled && \"bg-[#f2f2f2] text-[#b3b3b3]\"\n )}\n >\n {selectedCountry ? (\n <>\n <FlagIcon flag={selectedCountry.flag} />\n <span className=\"font-normal text-black\">\n {selectedCountry.label}\n </span>\n </>\n ) : (\n <Globe className=\"h-4 w-4 text-[#adacb0]\" />\n )}\n <ChevronDown className=\"h-4 w-4 text-[#adacb0]\" />\n </button>\n </PopoverTrigger>\n\n <PopoverContent\n align=\"start\"\n sideOffset={8}\n className=\"w-[240px] rounded-[8px] border border-[#e6e6e6] bg-white p-0 shadow-[0px_2px_4px_0px_rgba(19,25,39,0.12),0px_4px_4px_0px_rgba(19,25,39,0.08)]\"\n >\n <Command\n className={cn(\n \"rounded-[8px] bg-white\",\n \"[&_[cmdk-input-wrapper]]:mx-2 [&_[cmdk-input-wrapper]]:mb-1 [&_[cmdk-input-wrapper]]:mt-2 [&_[cmdk-input-wrapper]]:h-8 [&_[cmdk-input-wrapper]]:rounded-[4px] [&_[cmdk-input-wrapper]]:border [&_[cmdk-input-wrapper]]:border-[#e6e6e6] [&_[cmdk-input-wrapper]]:px-3\",\n \"[&_[cmdk-input-wrapper]_svg]:mr-2 [&_[cmdk-input-wrapper]_svg]:h-4 [&_[cmdk-input-wrapper]_svg]:w-4 [&_[cmdk-input-wrapper]_svg]:text-[#adacb0]\",\n \"[&_[cmdk-input]]:h-full [&_[cmdk-input]]:py-0 [&_[cmdk-input]]:text-[14px] [&_[cmdk-input]]:leading-[20px] [&_[cmdk-input]]:text-black [&_[cmdk-input]]:placeholder:text-[#adacb0]\"\n )}\n >\n <CommandInput placeholder=\"Search country\" />\n <CommandList className=\"max-h-56 px-1 pb-1\">\n <CommandEmpty className=\"px-3 py-2 text-left text-[12px] leading-[16px] text-[#7f7d83]\">\n No country found\n </CommandEmpty>\n <CommandGroup className=\"p-0\">\n {countryOptions.map((option) => {\n const isSelected = option.value === selectedCountryValue\n const optionName = option.name || option.label\n\n return (\n <CommandItem\n key={option.value}\n value={`${option.label} ${optionName} ${option.dialCode}`}\n onSelect={() => handleCountrySelect(option)}\n className={cn(\n \"flex w-full cursor-pointer items-center gap-2 rounded-[4px] px-3 py-2 text-[14px] leading-[20px] text-black\",\n \"data-[selected=true]:bg-[#fafafa] data-[selected=true]:text-black\",\n isSelected && \"bg-[#fafafa]\"\n )}\n >\n <FlagIcon flag={option.flag} />\n <span className=\"min-w-0 flex-1 truncate\">{optionName}</span>\n {option.dialCode ? (\n <span className=\"text-[#7f7d83]\">{option.dialCode}</span>\n ) : null}\n <Check\n className={cn(\n \"h-4 w-4 text-[#1d1c20]\",\n isSelected ? \"opacity-100\" : \"opacity-0\"\n )}\n />\n </CommandItem>\n )\n })}\n </CommandGroup>\n </CommandList>\n </Command>\n </PopoverContent>\n </Popover>\n\n <div\n className={cn(\n \"flex min-w-0 flex-1 items-center gap-2 border-l border-[#e6e6e6] bg-white px-3 py-2\",\n disabled && \"bg-[#f2f2f2]\"\n )}\n >\n {selectedCountry?.dialCode ? (\n <span className=\"shrink-0 text-[14px] leading-[20px] text-[#7f7d83]\">\n {selectedCountry.dialCode}\n </span>\n ) : null}\n <input\n ref={ref}\n disabled={disabled}\n placeholder={placeholder}\n onFocus={(event) => {\n setIsInputFocused(true)\n onFocus?.(event)\n }}\n onBlur={(event) => {\n setIsInputFocused(false)\n onBlur?.(event)\n }}\n className={cn(\n \"h-full w-full min-w-0 border-0 bg-transparent p-0 text-[14px] leading-[20px] text-black outline-none placeholder:text-[#adacb0]\",\n disabled &&\n \"cursor-not-allowed text-[#9ca3af] placeholder:text-[#b3b3b3]\",\n inputClassName\n )}\n type={type}\n {...props}\n />\n </div>\n </div>\n\n {error ? (\n <p className=\"w-full text-[12px] leading-[16px] text-[#ff3b30]\">{error}</p>\n ) : helperText ? (\n <p className=\"w-full text-[12px] leading-[16px] text-[#7f7d83]\">\n {helperText}\n </p>\n ) : null}\n </div>\n )\n }\n)\n\nPhoneInput.displayName = \"PhoneInput\"\n\nexport { PhoneInput, DEFAULT_COUNTRY_OPTIONS }\nexport type { PhoneCountryOption }\n"],"names":["DEFAULT_COUNTRY_OPTIONS","PHONE_COUNTRY_OPTIONS","COUNTRY_FLAG_COMPONENTS","CountryFlags","getCountryCodeFromFlagEmoji","flag","symbols","letters","symbol","codePoint","letter","FlagIcon","className","countryCode","React","SvgFlag","jsx","cn","PhoneInput","inputClassName","label","helperText","error","country","defaultCountry","countryOptions","onCountryChange","disabled","type","onFocus","onBlur","placeholder","props","ref","open","setOpen","isInputFocused","setIsInputFocused","uncontrolledCountry","setUncontrolledCountry","selectedCountryValue","selectedCountry","option","handleCountrySelect","isAriaInvalid","hasError","isActive","jsxs","Popover","nextOpen","PopoverTrigger","Fragment","Globe","ChevronDown","PopoverContent","Command","CommandInput","CommandList","CommandEmpty","CommandGroup","isSelected","optionName","CommandItem","Check","event"],"mappings":"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"}