ml-uikit 1.1.6 → 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.
- package/dist/components/ui/date-range-picker.d.ts +3 -0
- package/dist/components/ui/date-range-picker.d.ts.map +1 -1
- package/dist/components/ui/password-input.d.ts +9 -0
- package/dist/components/ui/password-input.d.ts.map +1 -0
- package/dist/components/ui/searchable-dropdown.d.ts +22 -0
- package/dist/components/ui/searchable-dropdown.d.ts.map +1 -0
- package/dist/components/ui/table.d.ts +5 -1
- package/dist/components/ui/table.d.ts.map +1 -1
- package/dist/index.cjs.js +1 -1
- package/dist/index.cjs10.js +1 -1
- package/dist/index.cjs10.js.map +1 -1
- package/dist/index.cjs11.js +1 -1
- package/dist/index.cjs11.js.map +1 -1
- package/dist/index.cjs12.js +1 -1
- package/dist/index.cjs12.js.map +1 -1
- package/dist/index.cjs13.js +1 -1
- package/dist/index.cjs13.js.map +1 -1
- package/dist/index.cjs14.js +1 -1
- package/dist/index.cjs14.js.map +1 -1
- package/dist/index.cjs15.js +1 -1
- package/dist/index.cjs15.js.map +1 -1
- package/dist/index.cjs16.js +4 -4
- package/dist/index.cjs16.js.map +1 -1
- package/dist/index.cjs17.js +1 -1
- package/dist/index.cjs17.js.map +1 -1
- package/dist/index.cjs19.js +1 -1
- package/dist/index.cjs19.js.map +1 -1
- package/dist/index.cjs2.js +1 -1
- package/dist/index.cjs2.js.map +1 -1
- package/dist/index.cjs20.js +1 -1
- package/dist/index.cjs20.js.map +1 -1
- package/dist/index.cjs21.js +1 -1
- package/dist/index.cjs21.js.map +1 -1
- package/dist/index.cjs22.js +1 -1
- package/dist/index.cjs22.js.map +1 -1
- package/dist/index.cjs23.js +1 -1
- package/dist/index.cjs23.js.map +1 -1
- package/dist/index.cjs24.js +1 -1
- package/dist/index.cjs24.js.map +1 -1
- package/dist/index.cjs25.js +1 -1
- package/dist/index.cjs25.js.map +1 -1
- package/dist/index.cjs26.js +1 -1
- package/dist/index.cjs26.js.map +1 -1
- package/dist/index.cjs27.js +1 -1
- package/dist/index.cjs27.js.map +1 -1
- package/dist/index.cjs28.js +1 -1
- package/dist/index.cjs28.js.map +1 -1
- package/dist/index.cjs29.js +1 -1
- package/dist/index.cjs29.js.map +1 -1
- package/dist/index.cjs3.js +1 -1
- package/dist/index.cjs3.js.map +1 -1
- package/dist/index.cjs30.js +1 -1
- package/dist/index.cjs30.js.map +1 -1
- package/dist/index.cjs31.js +1 -1
- package/dist/index.cjs31.js.map +1 -1
- package/dist/index.cjs32.js +1 -1
- package/dist/index.cjs32.js.map +1 -1
- package/dist/index.cjs33.js +1 -1
- package/dist/index.cjs33.js.map +1 -1
- package/dist/index.cjs34.js +1 -1
- package/dist/index.cjs34.js.map +1 -1
- package/dist/index.cjs35.js +1 -1
- package/dist/index.cjs35.js.map +1 -1
- package/dist/index.cjs36.js +1 -1
- package/dist/index.cjs36.js.map +1 -1
- package/dist/index.cjs37.js +1 -1
- package/dist/index.cjs37.js.map +1 -1
- package/dist/index.cjs38.js +1 -1
- package/dist/index.cjs38.js.map +1 -1
- package/dist/index.cjs39.js +1 -1
- package/dist/index.cjs39.js.map +1 -1
- package/dist/index.cjs4.js +1 -1
- package/dist/index.cjs4.js.map +1 -1
- package/dist/index.cjs40.js +1 -1
- package/dist/index.cjs40.js.map +1 -1
- package/dist/index.cjs41.js +1 -1
- package/dist/index.cjs41.js.map +1 -1
- package/dist/index.cjs42.js +1 -1
- package/dist/index.cjs42.js.map +1 -1
- package/dist/index.cjs43.js +1 -1
- package/dist/index.cjs43.js.map +1 -1
- package/dist/index.cjs44.js +1 -1
- package/dist/index.cjs44.js.map +1 -1
- package/dist/index.cjs45.js +1 -1
- package/dist/index.cjs45.js.map +1 -1
- package/dist/index.cjs46.js +1 -1
- package/dist/index.cjs46.js.map +1 -1
- package/dist/index.cjs47.js +1 -1
- package/dist/index.cjs47.js.map +1 -1
- package/dist/index.cjs48.js +1 -1
- package/dist/index.cjs48.js.map +1 -1
- package/dist/index.cjs49.js +1 -1
- package/dist/index.cjs49.js.map +1 -1
- package/dist/index.cjs5.js +1 -1
- package/dist/index.cjs5.js.map +1 -1
- package/dist/index.cjs50.js +1 -1
- package/dist/index.cjs50.js.map +1 -1
- package/dist/index.cjs51.js +1 -1
- package/dist/index.cjs51.js.map +1 -1
- package/dist/index.cjs52.js +1 -1
- package/dist/index.cjs52.js.map +1 -1
- package/dist/index.cjs53.js +1 -1
- package/dist/index.cjs53.js.map +1 -1
- package/dist/index.cjs54.js +1 -1
- package/dist/index.cjs54.js.map +1 -1
- package/dist/index.cjs55.js +1 -1
- package/dist/index.cjs55.js.map +1 -1
- package/dist/index.cjs56.js +1 -1
- package/dist/index.cjs56.js.map +1 -1
- package/dist/index.cjs57.js +1 -1
- package/dist/index.cjs57.js.map +1 -1
- package/dist/index.cjs58.js +1 -1
- package/dist/index.cjs58.js.map +1 -1
- package/dist/index.cjs59.js +1 -1
- package/dist/index.cjs59.js.map +1 -1
- package/dist/index.cjs60.js +1 -1
- package/dist/index.cjs60.js.map +1 -1
- package/dist/index.cjs61.js +1 -1
- package/dist/index.cjs61.js.map +1 -1
- package/dist/index.cjs62.js +1 -1
- package/dist/index.cjs62.js.map +1 -1
- package/dist/index.cjs63.js +2 -0
- package/dist/index.cjs63.js.map +1 -0
- package/dist/index.cjs64.js +2 -0
- package/dist/index.cjs64.js.map +1 -0
- package/dist/index.cjs65.js +2 -0
- package/dist/index.cjs65.js.map +1 -0
- package/dist/index.cjs66.js +2 -0
- package/dist/index.cjs66.js.map +1 -0
- package/dist/index.cjs67.js +2 -0
- package/dist/index.cjs67.js.map +1 -0
- package/dist/index.cjs68.js +7 -0
- package/dist/index.cjs68.js.map +1 -0
- package/dist/index.cjs69.js +2 -0
- package/dist/index.cjs69.js.map +1 -0
- package/dist/index.cjs7.js +1 -1
- package/dist/index.cjs7.js.map +1 -1
- package/dist/index.cjs70.js +2 -0
- package/dist/index.cjs70.js.map +1 -0
- package/dist/index.cjs71.js +2 -0
- package/dist/index.cjs71.js.map +1 -0
- package/dist/index.cjs8.js +1 -1
- package/dist/index.cjs8.js.map +1 -1
- package/dist/index.cjs9.js +1 -1
- package/dist/index.cjs9.js.map +1 -1
- package/dist/index.d.ts +3 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.es.js +271 -258
- package/dist/index.es.js.map +1 -1
- package/dist/index.es10.js +22 -21
- package/dist/index.es10.js.map +1 -1
- package/dist/index.es11.js +14 -13
- package/dist/index.es11.js.map +1 -1
- package/dist/index.es12.js +31 -31
- package/dist/index.es12.js.map +1 -1
- package/dist/index.es13.js +39 -38
- package/dist/index.es13.js.map +1 -1
- package/dist/index.es14.js +34 -33
- package/dist/index.es14.js.map +1 -1
- package/dist/index.es15.js +107 -102
- package/dist/index.es15.js.map +1 -1
- package/dist/index.es16.js +155 -140
- package/dist/index.es16.js.map +1 -1
- package/dist/index.es17.js +21 -18
- package/dist/index.es17.js.map +1 -1
- package/dist/index.es19.js +63 -59
- package/dist/index.es19.js.map +1 -1
- package/dist/index.es2.js +10 -6
- package/dist/index.es2.js.map +1 -1
- package/dist/index.es20.js +85 -78
- package/dist/index.es20.js.map +1 -1
- package/dist/index.es21.js +68 -59
- package/dist/index.es21.js.map +1 -1
- package/dist/index.es22.js +68 -62
- package/dist/index.es22.js.map +1 -1
- package/dist/index.es23.js +83 -76
- package/dist/index.es23.js.map +1 -1
- package/dist/index.es24.js +178 -94
- package/dist/index.es24.js.map +1 -1
- package/dist/index.es25.js +57 -164
- package/dist/index.es25.js.map +1 -1
- package/dist/index.es26.js +198 -77
- package/dist/index.es26.js.map +1 -1
- package/dist/index.es27.js +90 -20
- package/dist/index.es27.js.map +1 -1
- package/dist/index.es28.js +21 -22
- package/dist/index.es28.js.map +1 -1
- package/dist/index.es29.js +19 -339
- package/dist/index.es29.js.map +1 -1
- package/dist/index.es3.js +35 -32
- package/dist/index.es3.js.map +1 -1
- package/dist/index.es30.js +38 -148
- package/dist/index.es30.js.map +1 -1
- package/dist/index.es31.js +377 -42
- package/dist/index.es31.js.map +1 -1
- package/dist/index.es32.js +146 -172
- package/dist/index.es32.js.map +1 -1
- package/dist/index.es33.js +46 -253
- package/dist/index.es33.js.map +1 -1
- package/dist/index.es34.js +195 -180
- package/dist/index.es34.js.map +1 -1
- package/dist/index.es35.js +253 -29
- package/dist/index.es35.js.map +1 -1
- package/dist/index.es36.js +183 -14
- package/dist/index.es36.js.map +1 -1
- package/dist/index.es37.js +29 -93
- package/dist/index.es37.js.map +1 -1
- package/dist/index.es38.js +13 -187
- package/dist/index.es38.js.map +1 -1
- package/dist/index.es39.js +93 -96
- package/dist/index.es39.js.map +1 -1
- package/dist/index.es4.js +38 -32
- package/dist/index.es4.js.map +1 -1
- package/dist/index.es40.js +182 -80
- package/dist/index.es40.js.map +1 -1
- package/dist/index.es41.js +98 -17
- package/dist/index.es41.js.map +1 -1
- package/dist/index.es42.js +101 -21
- package/dist/index.es42.js.map +1 -1
- package/dist/index.es43.js +20 -28
- package/dist/index.es43.js.map +1 -1
- package/dist/index.es44.js +19 -28
- package/dist/index.es44.js.map +1 -1
- package/dist/index.es45.js +25 -176
- package/dist/index.es45.js.map +1 -1
- package/dist/index.es46.js +36 -21
- package/dist/index.es46.js.map +1 -1
- package/dist/index.es47.js +171 -78
- package/dist/index.es47.js.map +1 -1
- package/dist/index.es48.js +17 -551
- package/dist/index.es48.js.map +1 -1
- package/dist/index.es49.js +106 -13
- package/dist/index.es49.js.map +1 -1
- package/dist/index.es5.js +71 -67
- package/dist/index.es5.js.map +1 -1
- package/dist/index.es50.js +559 -35
- package/dist/index.es50.js.map +1 -1
- package/dist/index.es51.js +12 -19
- package/dist/index.es51.js.map +1 -1
- package/dist/index.es52.js +47 -12
- package/dist/index.es52.js.map +1 -1
- package/dist/index.es53.js +21 -25
- package/dist/index.es53.js.map +1 -1
- package/dist/index.es54.js +14 -217
- package/dist/index.es54.js.map +1 -1
- package/dist/index.es55.js +23 -44
- package/dist/index.es55.js.map +1 -1
- package/dist/index.es56.js +237 -13
- package/dist/index.es56.js.map +1 -1
- package/dist/index.es57.js +44 -28
- package/dist/index.es57.js.map +1 -1
- package/dist/index.es58.js +17 -36
- package/dist/index.es58.js.map +1 -1
- package/dist/index.es59.js +33 -18
- package/dist/index.es59.js.map +1 -1
- package/dist/index.es60.js +39 -6
- package/dist/index.es60.js.map +1 -1
- package/dist/index.es61.js +21 -267
- package/dist/index.es61.js.map +1 -1
- package/dist/index.es62.js +3 -6268
- package/dist/index.es62.js.map +1 -1
- package/dist/index.es63.js +9 -0
- package/dist/index.es63.js.map +1 -0
- package/dist/index.es64.js +270 -0
- package/dist/index.es64.js.map +1 -0
- package/dist/index.es65.js +11 -0
- package/dist/index.es65.js.map +1 -0
- package/dist/index.es66.js +5 -0
- package/dist/index.es66.js.map +1 -0
- package/dist/index.es67.js +27 -0
- package/dist/index.es67.js.map +1 -0
- package/dist/index.es68.js +237 -0
- package/dist/index.es68.js.map +1 -0
- package/dist/index.es69.js +5 -0
- package/dist/index.es69.js.map +1 -0
- package/dist/index.es7.js +25 -24
- package/dist/index.es7.js.map +1 -1
- package/dist/index.es70.js +5 -0
- package/dist/index.es70.js.map +1 -0
- package/dist/index.es71.js +6271 -0
- package/dist/index.es71.js.map +1 -0
- package/dist/index.es8.js +43 -41
- package/dist/index.es8.js.map +1 -1
- package/dist/index.es9.js +51 -48
- package/dist/index.es9.js.map +1 -1
- package/dist/style.css +199 -49
- package/package.json +1 -1
package/dist/index.es34.js
CHANGED
|
@@ -1,188 +1,203 @@
|
|
|
1
|
-
import
|
|
2
|
-
import
|
|
3
|
-
import {
|
|
4
|
-
import
|
|
5
|
-
import {
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
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
|
-
|
|
11
|
-
|
|
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
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
{
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
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
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
)
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
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
|
-
|
|
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
|
-
|
|
178
|
-
|
|
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
|
package/dist/index.es34.js.map
CHANGED
|
@@ -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":"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"}
|
|
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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"}
|