@purpur/library 9.0.10 → 9.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.json +33 -0
- package/CHANGELOG.md +15 -1
- package/dist/LICENSE.txt +45 -24
- package/dist/{autocomplete-Dy8YL7Mo.js → autocomplete-B421J7CS.js} +2 -2
- package/dist/{autocomplete-Dy8YL7Mo.js.map → autocomplete-B421J7CS.js.map} +1 -1
- package/dist/{autocomplete-Dn503hFM.mjs → autocomplete-B8L-dTmF.mjs} +3 -3
- package/dist/{autocomplete-Dn503hFM.mjs.map → autocomplete-B8L-dTmF.mjs.map} +1 -1
- package/dist/autocomplete.cjs.js +1 -1
- package/dist/autocomplete.es.js +1 -1
- package/dist/chat-field-CxOqk0-9.js +2 -0
- package/dist/chat-field-CxOqk0-9.js.map +1 -0
- package/dist/chat-field-yK-TwW0D.mjs +149 -0
- package/dist/chat-field-yK-TwW0D.mjs.map +1 -0
- package/dist/chat-field.cjs.js +2 -0
- package/dist/chat-field.cjs.js.map +1 -0
- package/dist/chat-field.es.js +5 -0
- package/dist/chat-field.es.js.map +1 -0
- package/dist/components/autocomplete/src/autocomplete.d.ts.map +1 -1
- package/dist/components/chat-field/src/chat-field.d.ts +71 -0
- package/dist/components/chat-field/src/chat-field.d.ts.map +1 -0
- package/dist/components/dismissable-chip-group/src/dismissable-chip-group-item.d.ts.map +1 -1
- package/dist/components/dismissable-chip-group/src/dismissable-chip-group.d.ts +6 -1
- package/dist/components/dismissable-chip-group/src/dismissable-chip-group.d.ts.map +1 -1
- package/dist/components/dropdown/src/dropdown-combobox.d.ts +34 -0
- package/dist/components/dropdown/src/dropdown-combobox.d.ts.map +1 -0
- package/dist/components/dropdown/src/dropdown-select.d.ts +34 -0
- package/dist/components/dropdown/src/dropdown-select.d.ts.map +1 -0
- package/dist/components/dropdown/src/dropdown-shared.d.ts +51 -0
- package/dist/components/dropdown/src/dropdown-shared.d.ts.map +1 -0
- package/dist/components/dropdown/src/dropdown.d.ts +6 -0
- package/dist/components/dropdown/src/dropdown.d.ts.map +1 -0
- package/dist/components/dropdown/src/dropdown.types.d.ts +94 -0
- package/dist/components/dropdown/src/dropdown.types.d.ts.map +1 -0
- package/dist/components/dropdown/src/useDropdown.d.ts +38 -0
- package/dist/components/dropdown/src/useDropdown.d.ts.map +1 -0
- package/dist/components/dropdown/src/useDropdownFilter.d.ts +9 -0
- package/dist/components/dropdown/src/useDropdownFilter.d.ts.map +1 -0
- package/dist/components/dropdown/src/useDropdownHighlight.d.ts +19 -0
- package/dist/components/dropdown/src/useDropdownHighlight.d.ts.map +1 -0
- package/dist/components/dropdown/src/useDropdownInput.d.ts +12 -0
- package/dist/components/dropdown/src/useDropdownInput.d.ts.map +1 -0
- package/dist/components/dropdown/src/useOnClickOutside.d.ts +2 -0
- package/dist/components/dropdown/src/useOnClickOutside.d.ts.map +1 -0
- package/dist/components/listbox/src/listbox-item.d.ts +2 -0
- package/dist/components/listbox/src/listbox-item.d.ts.map +1 -1
- package/dist/components/search-field/src/search-field-autocomplete.d.ts +73 -0
- package/dist/components/search-field/src/search-field-autocomplete.d.ts.map +1 -0
- package/dist/components/search-field/src/search-field-base.d.ts +97 -0
- package/dist/components/search-field/src/search-field-base.d.ts.map +1 -0
- package/dist/components/search-field/src/search-field.d.ts +123 -41
- package/dist/components/search-field/src/search-field.d.ts.map +1 -1
- package/dist/components/text-field/src/text-field-ai.d.ts +669 -0
- package/dist/components/text-field/src/text-field-ai.d.ts.map +1 -0
- package/dist/components/text-field/src/text-field-base.d.ts +671 -0
- package/dist/components/text-field/src/text-field-base.d.ts.map +1 -0
- package/dist/components/text-field/src/text-field.d.ts +42 -4
- package/dist/components/text-field/src/text-field.d.ts.map +1 -1
- package/dist/components-metadata.js +29 -1
- package/dist/{date-field-DACXrowI.mjs → date-field-4tYMPw89.mjs} +2 -2
- package/dist/{date-field-DACXrowI.mjs.map → date-field-4tYMPw89.mjs.map} +1 -1
- package/dist/{date-field-Z3LKO4b7.js → date-field-B7ipm5sH.js} +2 -2
- package/dist/{date-field-Z3LKO4b7.js.map → date-field-B7ipm5sH.js.map} +1 -1
- package/dist/date-field.cjs.js +1 -1
- package/dist/date-field.es.js +1 -1
- package/dist/{date-picker-5Gr_cEqA.js → date-picker-B8L1Hm8r.js} +2 -2
- package/dist/{date-picker-5Gr_cEqA.js.map → date-picker-B8L1Hm8r.js.map} +1 -1
- package/dist/{date-picker-CdVUA8NC.mjs → date-picker-Bp_XpoOF.mjs} +2 -2
- package/dist/{date-picker-CdVUA8NC.mjs.map → date-picker-Bp_XpoOF.mjs.map} +1 -1
- package/dist/date-picker.cjs.js +1 -1
- package/dist/date-picker.es.js +1 -1
- package/dist/dismissable-chip-group-Cd23yjBa.js +2 -0
- package/dist/dismissable-chip-group-Cd23yjBa.js.map +1 -0
- package/dist/dismissable-chip-group-D-gD93ON.mjs +89 -0
- package/dist/dismissable-chip-group-D-gD93ON.mjs.map +1 -0
- package/dist/dismissable-chip-group.cjs.js +1 -1
- package/dist/dismissable-chip-group.es.js +5 -2
- package/dist/dropdown-BC6evqyq.js +2 -0
- package/dist/dropdown-BC6evqyq.js.map +1 -0
- package/dist/dropdown-C-Ze4gvG.mjs +771 -0
- package/dist/dropdown-C-Ze4gvG.mjs.map +1 -0
- package/dist/dropdown.cjs.js +2 -0
- package/dist/dropdown.cjs.js.map +1 -0
- package/dist/dropdown.es.js +6 -0
- package/dist/dropdown.es.js.map +1 -0
- package/dist/libraries/library/src/chat-field.d.ts +6 -0
- package/dist/libraries/library/src/chat-field.d.ts.map +1 -0
- package/dist/libraries/library/src/dropdown.d.ts +6 -0
- package/dist/libraries/library/src/dropdown.d.ts.map +1 -0
- package/dist/libraries/library/src/library.d.ts +2 -0
- package/dist/libraries/library/src/library.d.ts.map +1 -1
- package/dist/library.cjs.js +1 -1
- package/dist/library.es.js +601 -591
- package/dist/library.es.js.map +1 -1
- package/dist/listbox-COBHLRtB.js +2 -0
- package/dist/listbox-COBHLRtB.js.map +1 -0
- package/dist/listbox-DG4KmQP_.mjs +66 -0
- package/dist/listbox-DG4KmQP_.mjs.map +1 -0
- package/dist/listbox.cjs.js +1 -1
- package/dist/listbox.es.js +1 -1
- package/dist/purpur.css +1 -1
- package/dist/{quantity-selector-w10wKMmT.mjs → quantity-selector-CsR6KTG3.mjs} +2 -2
- package/dist/{quantity-selector-w10wKMmT.mjs.map → quantity-selector-CsR6KTG3.mjs.map} +1 -1
- package/dist/{quantity-selector-D28He6R8.js → quantity-selector-DWDg4aFO.js} +2 -2
- package/dist/{quantity-selector-D28He6R8.js.map → quantity-selector-DWDg4aFO.js.map} +1 -1
- package/dist/quantity-selector.cjs.js +1 -1
- package/dist/quantity-selector.es.js +1 -1
- package/dist/search-field-Caj2dKLn.mjs +151 -0
- package/dist/search-field-Caj2dKLn.mjs.map +1 -0
- package/dist/search-field-DAktzYb0.js +2 -0
- package/dist/search-field-DAktzYb0.js.map +1 -0
- package/dist/search-field.cjs.js +1 -1
- package/dist/search-field.es.js +3 -2
- package/dist/{table-YR-bpfU0.mjs → table-DXYHrKI7.mjs} +2 -2
- package/dist/{table-YR-bpfU0.mjs.map → table-DXYHrKI7.mjs.map} +1 -1
- package/dist/{table-CJijBJsy.js → table-x3SDCR-z.js} +2 -2
- package/dist/{table-CJijBJsy.js.map → table-x3SDCR-z.js.map} +1 -1
- package/dist/table.cjs.js +1 -1
- package/dist/table.es.js +1 -1
- package/dist/text-field-BQYzwIrG.mjs +322 -0
- package/dist/text-field-BQYzwIrG.mjs.map +1 -0
- package/dist/text-field-BwxGMWds.js +2 -0
- package/dist/text-field-BwxGMWds.js.map +1 -0
- package/dist/text-field.cjs.js +1 -1
- package/dist/text-field.es.js +4 -3
- package/dist/use-autocomplete.es-BHDgQLae.js +2 -0
- package/dist/use-autocomplete.es-BHDgQLae.js.map +1 -0
- package/dist/use-autocomplete.es-CVv3z8t6.mjs +142 -0
- package/dist/use-autocomplete.es-CVv3z8t6.mjs.map +1 -0
- package/package.json +25 -23
- package/src/aliases.ts +8 -0
- package/src/chat-field.ts +6 -0
- package/src/dropdown.ts +6 -0
- package/src/entries.js +2 -0
- package/src/library.ts +4 -0
- package/dist/dismissable-chip-group-CnziecOt.js +0 -2
- package/dist/dismissable-chip-group-CnziecOt.js.map +0 -1
- package/dist/dismissable-chip-group-ZCYOt1sB.mjs +0 -79
- package/dist/dismissable-chip-group-ZCYOt1sB.mjs.map +0 -1
- package/dist/listbox-BmjBtIv8.js +0 -2
- package/dist/listbox-BmjBtIv8.js.map +0 -1
- package/dist/listbox-oDeP8FvH.mjs +0 -65
- package/dist/listbox-oDeP8FvH.mjs.map +0 -1
- package/dist/search-field-CNpJp3Tg.js +0 -2
- package/dist/search-field-CNpJp3Tg.js.map +0 -1
- package/dist/search-field-CWqLnqdo.mjs +0 -91
- package/dist/search-field-CWqLnqdo.mjs.map +0 -1
- package/dist/text-field-BMDf8j-K.mjs +0 -185
- package/dist/text-field-BMDf8j-K.mjs.map +0 -1
- package/dist/text-field-CiLEj0Fq.js +0 -2
- package/dist/text-field-CiLEj0Fq.js.map +0 -1
|
@@ -0,0 +1,142 @@
|
|
|
1
|
+
import { useId as X, useRef as b, useState as R, useCallback as $, useEffect as Z } from "react";
|
|
2
|
+
const ee = ({
|
|
3
|
+
id: f,
|
|
4
|
+
options: v,
|
|
5
|
+
listboxLabel: A,
|
|
6
|
+
selectedOption: a,
|
|
7
|
+
disabled: m = !1,
|
|
8
|
+
readOnly: g = !1,
|
|
9
|
+
openOnFocus: S = !1,
|
|
10
|
+
listboxMaxHeight: d,
|
|
11
|
+
highlightFirstOption: y = !1,
|
|
12
|
+
onSelect: T,
|
|
13
|
+
closeOnSelect: M = !0,
|
|
14
|
+
noOptionsText: K,
|
|
15
|
+
["data-testid"]: k
|
|
16
|
+
}) => {
|
|
17
|
+
const F = X(), l = b(null), x = b(null), u = b(null), h = b({}), [E, C] = R(!1), [o, c] = R(
|
|
18
|
+
y ? v[0] : void 0
|
|
19
|
+
), w = `${f}-listbox`, P = `${f}-input`, B = (e) => `${f}-listbox-item-${e.id}`, D = `--purpur-autocomplete-${F.replace(/:/g, "")}`, Y = { anchorName: D }, O = (e) => k ? `${k}-${e}` : void 0, n = $(() => {
|
|
20
|
+
C(!1), c(void 0);
|
|
21
|
+
}, []);
|
|
22
|
+
Z(() => {
|
|
23
|
+
const e = (t) => {
|
|
24
|
+
l.current && !l.current.contains(t.target) && !u.current?.contains(t.target) && n();
|
|
25
|
+
};
|
|
26
|
+
return document.addEventListener("mousedown", e), () => document.removeEventListener("mousedown", e);
|
|
27
|
+
}, [n]);
|
|
28
|
+
const p = ({ eventType: e }) => {
|
|
29
|
+
C(!0), a && requestAnimationFrame(() => {
|
|
30
|
+
c({ ...a, isSetByClickEvent: e === "CLICK" }), I(h.current[a.id]);
|
|
31
|
+
});
|
|
32
|
+
}, I = (e) => {
|
|
33
|
+
if (!e) return;
|
|
34
|
+
const t = e.getBoundingClientRect(), i = u.current?.getBoundingClientRect() ?? { top: 0, bottom: 0 };
|
|
35
|
+
(t.top < i.top || t.bottom > i.bottom) && e.scrollIntoView({ block: "nearest" });
|
|
36
|
+
}, r = E && (v.length > 0 || !!K), U = (e) => {
|
|
37
|
+
const t = v.filter((s) => !s.disabled);
|
|
38
|
+
if (!t.length) return;
|
|
39
|
+
const i = o ? t.findIndex((s) => s.id === o.id) : -1;
|
|
40
|
+
return e === "ArrowDown" ? t[(i + 1) % t.length] : t[(i - 1 + t.length) % t.length];
|
|
41
|
+
}, q = (e) => {
|
|
42
|
+
r || p({ eventType: "KEYBOARD" });
|
|
43
|
+
const t = U(e);
|
|
44
|
+
c(t ? { ...t } : void 0), t && I(h.current[t.id]);
|
|
45
|
+
}, L = (e) => {
|
|
46
|
+
e.disabled || (T?.(e), x.current?.focus(), M && n());
|
|
47
|
+
}, H = () => {
|
|
48
|
+
p({ eventType: "KEYBOARD" });
|
|
49
|
+
}, N = (e) => {
|
|
50
|
+
if (!(m || g))
|
|
51
|
+
switch (e.key) {
|
|
52
|
+
case "ArrowUp":
|
|
53
|
+
case "ArrowDown":
|
|
54
|
+
e.preventDefault(), q(e.key);
|
|
55
|
+
break;
|
|
56
|
+
case "Enter":
|
|
57
|
+
r && o && (e.preventDefault(), L(o));
|
|
58
|
+
break;
|
|
59
|
+
case "Escape":
|
|
60
|
+
e.preventDefault(), n();
|
|
61
|
+
break;
|
|
62
|
+
case "Tab":
|
|
63
|
+
n();
|
|
64
|
+
break;
|
|
65
|
+
}
|
|
66
|
+
}, V = () => {
|
|
67
|
+
!E && S && !m && !g && p({ eventType: "KEYBOARD" });
|
|
68
|
+
}, j = () => {
|
|
69
|
+
setTimeout(() => {
|
|
70
|
+
const e = document.activeElement;
|
|
71
|
+
e !== document.body && !x.current?.contains(e) && !u.current?.contains(e) && !l.current?.contains(e) && n();
|
|
72
|
+
});
|
|
73
|
+
}, z = () => {
|
|
74
|
+
m || g || (r ? n() : p({ eventType: "CLICK" }));
|
|
75
|
+
}, G = $((e) => {
|
|
76
|
+
if (u.current = e, e && typeof e.showPopover == "function")
|
|
77
|
+
try {
|
|
78
|
+
e.showPopover();
|
|
79
|
+
} catch {
|
|
80
|
+
}
|
|
81
|
+
}, []), J = {
|
|
82
|
+
"aria-label": A,
|
|
83
|
+
"aria-expanded": r,
|
|
84
|
+
"data-testid": O("listbox"),
|
|
85
|
+
id: w,
|
|
86
|
+
ref: G,
|
|
87
|
+
onMouseLeave: () => c(void 0),
|
|
88
|
+
popover: "manual",
|
|
89
|
+
style: {
|
|
90
|
+
...d ? {
|
|
91
|
+
maxHeight: typeof d == "number" ? `${d}px` : d
|
|
92
|
+
} : {},
|
|
93
|
+
positionAnchor: D
|
|
94
|
+
}
|
|
95
|
+
}, Q = (e, t) => {
|
|
96
|
+
const i = (e.id === o?.id || y && !o && t === 0) && !o?.isSetByClickEvent;
|
|
97
|
+
return {
|
|
98
|
+
"data-testid": O(`listbox-item-${e.id}`),
|
|
99
|
+
id: B(e),
|
|
100
|
+
key: e.id,
|
|
101
|
+
onMouseMove: () => {
|
|
102
|
+
e.id !== o?.id && c({ ...e, isSetByClickEvent: !0 });
|
|
103
|
+
},
|
|
104
|
+
onMouseUp: () => L(e),
|
|
105
|
+
ref: (s) => {
|
|
106
|
+
s && (h.current[e.id] = s);
|
|
107
|
+
},
|
|
108
|
+
tabIndex: -1,
|
|
109
|
+
selected: e.id === a?.id,
|
|
110
|
+
disabled: e.disabled,
|
|
111
|
+
highlighted: i,
|
|
112
|
+
hovered: e.id === o?.id && !!o?.isSetByClickEvent,
|
|
113
|
+
"aria-selected": e.id === a?.id
|
|
114
|
+
};
|
|
115
|
+
}, W = {
|
|
116
|
+
role: "combobox",
|
|
117
|
+
"aria-autocomplete": "list",
|
|
118
|
+
"aria-expanded": r,
|
|
119
|
+
"aria-controls": w,
|
|
120
|
+
"aria-activedescendant": o ? B(o) : void 0,
|
|
121
|
+
autoComplete: "off",
|
|
122
|
+
onKeyDown: N,
|
|
123
|
+
onFocus: V,
|
|
124
|
+
onBlur: j,
|
|
125
|
+
onMouseDown: z
|
|
126
|
+
};
|
|
127
|
+
return {
|
|
128
|
+
rootRef: l,
|
|
129
|
+
inputRef: x,
|
|
130
|
+
inputId: P,
|
|
131
|
+
inputProps: W,
|
|
132
|
+
listboxProps: J,
|
|
133
|
+
getListboxItemProps: Q,
|
|
134
|
+
isOpen: r,
|
|
135
|
+
openListbox: H,
|
|
136
|
+
anchorStyle: Y
|
|
137
|
+
};
|
|
138
|
+
};
|
|
139
|
+
export {
|
|
140
|
+
ee as e
|
|
141
|
+
};
|
|
142
|
+
//# sourceMappingURL=use-autocomplete.es-CVv3z8t6.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use-autocomplete.es-CVv3z8t6.mjs","sources":["../../../hooks/autocomplete/dist/use-autocomplete.es.js"],"sourcesContent":["import { useId as Z, useRef as b, useState as A, useCallback as $, useEffect as _ } from \"react\";\nconst ee = ({\n id: p,\n options: m,\n listboxLabel: O,\n selectedOption: r,\n disabled: v = !1,\n readOnly: h = !1,\n openOnFocus: K = !1,\n listboxMaxHeight: u,\n highlightFirstOption: y = !1,\n onSelect: S,\n closeOnSelect: T = !0,\n noOptionsText: P,\n [\"data-testid\"]: w\n}) => {\n const M = Z(), l = b(null), x = b(null), d = b(null), g = b({}), [k, I] = A(!1), [n, a] = A(\n y ? m[0] : void 0\n ), C = `${p}-listbox`, N = `${p}-input`, E = (e) => `${p}-listbox-item-${e.id}`, R = `--purpur-autocomplete-${M.replace(/:/g, \"\")}`, Y = { anchorName: R }, B = (e) => w ? `${w}-${e}` : void 0, o = $(() => {\n I(!1), a(void 0);\n }, []);\n _(() => {\n const e = (t) => {\n l.current && !l.current.contains(t.target) && !d.current?.contains(t.target) && o();\n };\n return document.addEventListener(\"mousedown\", e), () => document.removeEventListener(\"mousedown\", e);\n }, [o]);\n const f = ({ eventType: e }) => {\n I(!0), r && requestAnimationFrame(() => {\n a({ ...r, isSetByClickEvent: e === \"CLICK\" }), D(g.current[r.id]);\n });\n }, D = (e) => {\n if (!e) return;\n const t = e.getBoundingClientRect(), s = d.current?.getBoundingClientRect() ?? { top: 0, bottom: 0 };\n (t.top < s.top || t.bottom > s.bottom) && e.scrollIntoView({ block: \"nearest\" });\n }, c = k && (m.length > 0 || !!P), q = (e) => {\n const t = m.filter((i) => !i.disabled);\n if (!t.length) return;\n const s = n ? t.findIndex((i) => i.id === n.id) : -1;\n return e === \"ArrowDown\" ? t[(s + 1) % t.length] : t[(s - 1 + t.length) % t.length];\n }, F = (e) => {\n c || f({ eventType: \"KEYBOARD\" });\n const t = q(e);\n a(t ? { ...t } : void 0), t && D(g.current[t.id]);\n }, L = (e) => {\n e.disabled || (S?.(e), x.current?.focus(), T && o());\n }, U = () => {\n f({ eventType: \"KEYBOARD\" });\n }, V = (e) => {\n if (!(v || h))\n switch (e.key) {\n case \"ArrowUp\":\n case \"ArrowDown\":\n e.preventDefault(), F(e.key);\n break;\n case \"Enter\":\n c && n && (e.preventDefault(), L(n));\n break;\n case \"Escape\":\n e.preventDefault(), o();\n break;\n case \"Tab\":\n o();\n break;\n }\n }, j = () => {\n !k && K && !v && !h && f({ eventType: \"KEYBOARD\" });\n }, z = () => {\n setTimeout(() => {\n const e = document.activeElement;\n e !== document.body && !x.current?.contains(e) && !d.current?.contains(e) && !l.current?.contains(e) && o();\n });\n }, G = () => {\n v || h || (c ? o() : f({ eventType: \"CLICK\" }));\n }, J = $((e) => {\n if (d.current = e, e && typeof e.showPopover == \"function\")\n try {\n e.showPopover();\n } catch {\n }\n }, []), Q = {\n \"aria-label\": O,\n \"aria-expanded\": c,\n \"data-testid\": B(\"listbox\"),\n id: C,\n ref: J,\n onMouseLeave: () => a(void 0),\n popover: \"manual\",\n style: {\n ...u ? {\n maxHeight: typeof u == \"number\" ? `${u}px` : u\n } : {},\n positionAnchor: R\n }\n }, W = (e, t) => {\n const s = (e.id === n?.id || y && !n && t === 0) && !n?.isSetByClickEvent;\n return {\n \"data-testid\": B(`listbox-item-${e.id}`),\n id: E(e),\n key: e.id,\n onMouseMove: () => {\n e.id !== n?.id && a({ ...e, isSetByClickEvent: !0 });\n },\n onMouseUp: () => L(e),\n ref: (i) => {\n i && (g.current[e.id] = i);\n },\n tabIndex: -1,\n selected: e.id === r?.id,\n disabled: e.disabled,\n highlighted: s,\n hovered: e.id === n?.id && !!n?.isSetByClickEvent,\n \"aria-selected\": e.id === r?.id\n };\n }, X = {\n role: \"combobox\",\n \"aria-autocomplete\": \"list\",\n \"aria-expanded\": c,\n \"aria-controls\": C,\n \"aria-activedescendant\": n ? E(n) : void 0,\n autoComplete: \"off\",\n onKeyDown: V,\n onFocus: j,\n onBlur: z,\n onMouseDown: G\n };\n return {\n rootRef: l,\n inputRef: x,\n inputId: N,\n inputProps: X,\n listboxProps: Q,\n getListboxItemProps: W,\n isOpen: c,\n openListbox: U,\n anchorStyle: Y\n };\n};\nexport {\n ee as useAutocomplete\n};\n//# sourceMappingURL=use-autocomplete.es.js.map\n"],"names":["p","m","O","r","v","h","K","u","S","T","P","w","M","Z","b","d","g","k","I","A","n","a","C","N","E","R","B","o","$","_","f","D","s","c","q","i","F","U","V","j","z","G","J","Q","W","X"],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@purpur/library",
|
|
3
|
-
"version": "9.0
|
|
3
|
+
"version": "9.1.0",
|
|
4
4
|
"license": "AGPL-3.0-only",
|
|
5
5
|
"sideEffects": [
|
|
6
6
|
"*.css",
|
|
@@ -107,70 +107,72 @@
|
|
|
107
107
|
"vite": "^7.2.2",
|
|
108
108
|
"shx": "~0.4.0",
|
|
109
109
|
"@purpur/accordion": "8.21.0",
|
|
110
|
+
"@purpur/action": "8.21.0",
|
|
110
111
|
"@purpur/alert-badge": "8.21.0",
|
|
111
112
|
"@purpur/autocomplete": "8.21.0",
|
|
112
113
|
"@purpur/badge": "8.21.0",
|
|
113
|
-
"@purpur/action": "8.21.0",
|
|
114
114
|
"@purpur/breadcrumbs": "8.21.0",
|
|
115
115
|
"@purpur/button": "8.21.0",
|
|
116
116
|
"@purpur/calendar": "8.21.0",
|
|
117
|
-
"@purpur/card": "8.21.0",
|
|
118
117
|
"@purpur/checkbox": "8.21.0",
|
|
119
118
|
"@purpur/chip-group": "8.21.0",
|
|
120
|
-
"@purpur/
|
|
121
|
-
"@purpur/component-rig": "1.0.0",
|
|
119
|
+
"@purpur/card": "8.21.0",
|
|
122
120
|
"@purpur/color-dot": "8.21.0",
|
|
121
|
+
"@purpur/common-types": "8.21.0",
|
|
123
122
|
"@purpur/container": "8.21.0",
|
|
123
|
+
"@purpur/component-rig": "1.0.0",
|
|
124
124
|
"@purpur/content-block": "8.21.0",
|
|
125
|
-
"@purpur/countdown": "8.21.0",
|
|
126
125
|
"@purpur/counter-badge": "8.21.0",
|
|
127
|
-
"@purpur/
|
|
126
|
+
"@purpur/countdown": "8.21.0",
|
|
128
127
|
"@purpur/date-field": "8.21.0",
|
|
129
|
-
"@purpur/
|
|
128
|
+
"@purpur/cta-link": "8.21.0",
|
|
130
129
|
"@purpur/date-picker": "8.21.0",
|
|
131
|
-
"@purpur/
|
|
132
|
-
"@purpur/drawer": "8.21.0",
|
|
130
|
+
"@purpur/dismissable-chip-group": "8.21.0",
|
|
133
131
|
"@purpur/field-error-text": "8.21.0",
|
|
134
|
-
"@purpur/grid": "8.21.0",
|
|
135
132
|
"@purpur/footer": "8.21.0",
|
|
136
|
-
"@purpur/
|
|
133
|
+
"@purpur/drawer": "8.21.0",
|
|
134
|
+
"@purpur/grid": "8.21.0",
|
|
137
135
|
"@purpur/heading": "8.21.0",
|
|
136
|
+
"@purpur/hero-banner": "8.21.0",
|
|
137
|
+
"@purpur/field-helper-text": "8.21.0",
|
|
138
138
|
"@purpur/illustrative-icon": "8.21.0",
|
|
139
|
-
"@purpur/icon": "8.21.0",
|
|
140
139
|
"@purpur/label": "8.21.0",
|
|
141
|
-
"@purpur/listbox": "8.21.0",
|
|
142
140
|
"@purpur/link": "8.21.0",
|
|
141
|
+
"@purpur/icon": "8.21.0",
|
|
142
|
+
"@purpur/listbox": "8.21.0",
|
|
143
143
|
"@purpur/logo": "8.21.0",
|
|
144
144
|
"@purpur/modal": "8.21.0",
|
|
145
|
-
"@purpur/notification": "8.21.0",
|
|
146
145
|
"@purpur/notification-banner": "8.21.0",
|
|
147
|
-
"@purpur/
|
|
146
|
+
"@purpur/notification": "8.21.0",
|
|
148
147
|
"@purpur/pagination": "8.21.0",
|
|
148
|
+
"@purpur/paragraph": "8.21.0",
|
|
149
149
|
"@purpur/password-field": "8.21.0",
|
|
150
|
+
"@purpur/promotion-card": "8.21.0",
|
|
150
151
|
"@purpur/popover": "8.21.0",
|
|
151
152
|
"@purpur/product-card": "8.21.0",
|
|
152
|
-
"@purpur/quantity-selector": "8.21.0",
|
|
153
153
|
"@purpur/radio-button-group": "8.21.0",
|
|
154
|
-
"@purpur/
|
|
154
|
+
"@purpur/quantity-selector": "8.21.0",
|
|
155
155
|
"@purpur/radio-card-group": "8.21.0",
|
|
156
156
|
"@purpur/rich-text": "8.21.0",
|
|
157
|
-
"@purpur/search-field": "8.21.0",
|
|
158
|
-
"@purpur/select": "8.21.0",
|
|
159
157
|
"@purpur/skeleton": "8.21.0",
|
|
160
|
-
"@purpur/
|
|
158
|
+
"@purpur/select": "8.21.0",
|
|
159
|
+
"@purpur/search-field": "8.21.0",
|
|
161
160
|
"@purpur/spacer": "8.21.0",
|
|
161
|
+
"@purpur/slider": "8.21.0",
|
|
162
162
|
"@purpur/spinner": "8.21.0",
|
|
163
163
|
"@purpur/stepper": "8.21.0",
|
|
164
|
-
"@purpur/tabs": "8.21.0",
|
|
165
164
|
"@purpur/table": "8.21.0",
|
|
166
165
|
"@purpur/text-area": "8.21.0",
|
|
167
166
|
"@purpur/text-field": "8.21.0",
|
|
168
167
|
"@purpur/text-spacing": "8.21.0",
|
|
168
|
+
"@purpur/tabs": "8.21.0",
|
|
169
169
|
"@purpur/theme": "8.21.0",
|
|
170
170
|
"@purpur/toggle": "8.21.0",
|
|
171
171
|
"@purpur/tooltip": "8.21.0",
|
|
172
172
|
"@purpur/tokens": "8.21.0",
|
|
173
|
-
"@purpur/
|
|
173
|
+
"@purpur/chat-field": "9.1.0",
|
|
174
|
+
"@purpur/visually-hidden": "8.21.0",
|
|
175
|
+
"@purpur/dropdown": "0.1.0"
|
|
174
176
|
},
|
|
175
177
|
"peerDependencies": {
|
|
176
178
|
"@types/react": "^18 || ^19",
|
package/src/aliases.ts
CHANGED
|
@@ -41,6 +41,10 @@ export const aliases = [
|
|
|
41
41
|
find: /^@purpur\/card$/,
|
|
42
42
|
replacement: resolve(__dirname, "../../../components/card/src/card.tsx"),
|
|
43
43
|
},
|
|
44
|
+
{
|
|
45
|
+
find: /^@purpur\/chat-field$/,
|
|
46
|
+
replacement: resolve(__dirname, "../../../components/chat-field/src/chat-field.tsx"),
|
|
47
|
+
},
|
|
44
48
|
{
|
|
45
49
|
find: /^@purpur\/checkbox$/,
|
|
46
50
|
replacement: resolve(__dirname, "../../../components/checkbox/src/checkbox.tsx"),
|
|
@@ -92,6 +96,10 @@ export const aliases = [
|
|
|
92
96
|
find: /^@purpur\/drawer$/,
|
|
93
97
|
replacement: resolve(__dirname, "../../../components/drawer/src/drawer.tsx"),
|
|
94
98
|
},
|
|
99
|
+
{
|
|
100
|
+
find: /^@purpur\/dropdown$/,
|
|
101
|
+
replacement: resolve(__dirname, "../../../components/dropdown/src/dropdown.tsx"),
|
|
102
|
+
},
|
|
95
103
|
{
|
|
96
104
|
find: /^@purpur\/field-error-text$/,
|
|
97
105
|
replacement: resolve(
|
package/src/dropdown.ts
ADDED
package/src/entries.js
CHANGED
|
@@ -12,6 +12,7 @@ export const entries = [
|
|
|
12
12
|
"button",
|
|
13
13
|
"calendar",
|
|
14
14
|
"card",
|
|
15
|
+
"chat-field",
|
|
15
16
|
"checkbox",
|
|
16
17
|
"chip-group",
|
|
17
18
|
"color-dot",
|
|
@@ -24,6 +25,7 @@ export const entries = [
|
|
|
24
25
|
"date-picker",
|
|
25
26
|
"dismissable-chip-group",
|
|
26
27
|
"drawer",
|
|
28
|
+
"dropdown",
|
|
27
29
|
"field-error-text",
|
|
28
30
|
"field-helper-text",
|
|
29
31
|
"footer",
|
package/src/library.ts
CHANGED
|
@@ -29,6 +29,8 @@ export * from "@purpur/calendar";
|
|
|
29
29
|
|
|
30
30
|
export * from "@purpur/card";
|
|
31
31
|
|
|
32
|
+
export * from "@purpur/chat-field";
|
|
33
|
+
|
|
32
34
|
export * from "@purpur/checkbox";
|
|
33
35
|
|
|
34
36
|
export * from "@purpur/chip-group";
|
|
@@ -53,6 +55,8 @@ export * from "@purpur/dismissable-chip-group";
|
|
|
53
55
|
|
|
54
56
|
export * from "@purpur/drawer";
|
|
55
57
|
|
|
58
|
+
export * from "@purpur/dropdown";
|
|
59
|
+
|
|
56
60
|
export * from "@purpur/field-error-text";
|
|
57
61
|
|
|
58
62
|
export * from "@purpur/field-helper-text";
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
"use strict";const e=require("react/jsx-runtime"),d=require("react"),j=require("./heading-drD5ugCC.js"),_=require("./bind-DeUYJ6m9.js"),k=require("./close.es-VL3lKi1O.js"),b={"purpur-dismissable-chip-group":"_purpur-dismissable-chip-group_17jk4_1","purpur-dismissable-chip-group__container":"_purpur-dismissable-chip-group__container_17jk4_7","purpur-dismissable-chip-group__container--full-width":"_purpur-dismissable-chip-group__container--full-width_17jk4_14","purpur-dismissable-chip-group-item-wrapper":"_purpur-dismissable-chip-group-item-wrapper_17jk4_17","purpur-dismissable-chip-group-item":"_purpur-dismissable-chip-group-item_17jk4_17","purpur-dismissable-chip-group-item--disabled":"_purpur-dismissable-chip-group-item--disabled_17jk4_43"},n=_.c.bind(b),c="purpur-dismissable-chip-group-item",h=({children:r,id:i,onDismiss:p,disabled:s,...a})=>{const u=l=>{s?l.preventDefault():p?.(i)};return e.jsx("li",{className:n(`${c}-wrapper`),children:d.createElement("button",{...a,className:n(`${c}`,{[`${c}--disabled`]:s}),key:i,disabled:s,"aria-disabled":s,onClick:u},r,e.jsx(k.r,{size:"sm"}))},i)};h.displayName="DismissableChipGroupItem";const m=_.c.bind(b),o="purpur-dismissable-chip-group",t=({children:r,className:i,fullWidth:p=!1,title:s,titleTag:a,...u})=>{const l=d.useId(),g=m([o,i]);return e.jsxs("div",{...u,"aria-labelledby":s?`${l}-label`:void 0,className:g,role:"group",children:[s&&e.jsx(j.Heading,{tag:a??"h2",variant:"subsection-100",children:s}),e.jsx("ul",{"data-testid":"dismissable-chip-group-container",className:m(`${o}__container`,{[`${o}__container--full-width`]:p}),"aria-live":"polite","aria-relevant":"additions removals",children:r})]})};t.Item=h;t.displayName="DismissableChipGroup";exports.DismissableChipGroup=t;
|
|
2
|
-
//# sourceMappingURL=dismissable-chip-group-CnziecOt.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"dismissable-chip-group-CnziecOt.js","sources":["../../../components/dismissable-chip-group/src/dismissable-chip-group-item.tsx","../../../components/dismissable-chip-group/src/dismissable-chip-group.tsx"],"sourcesContent":["import React, { type MouseEvent, type ReactNode } from \"react\";\nimport type { BaseProps } from \"@purpur/common-types\";\nimport { IconClose } from \"@purpur/icon/close\";\nimport c from \"classnames/bind\";\n\nimport styles from \"./dismissable-chip-group.module.scss\";\n\nconst cx = c.bind(styles);\n\nexport type DismissableChipGroupItemProps = Omit<BaseProps<\"button\">, \"aria-label\" | \"children\"> & {\n [\"aria-label\"]: string;\n children: ReactNode;\n onDismiss?: (id?: string) => void;\n};\n\nconst rootClassName = \"purpur-dismissable-chip-group-item\";\n\nexport const DismissableChipGroupItem = ({\n children,\n id,\n onDismiss,\n disabled,\n ...props\n}: DismissableChipGroupItemProps) => {\n const handleClick = (e: MouseEvent<HTMLButtonElement>) => {\n if (disabled) {\n e.preventDefault();\n } else {\n onDismiss?.(id);\n }\n };\n\n return (\n <li key={id} className={cx(`${rootClassName}-wrapper`)}>\n <button\n {...props}\n className={cx(`${rootClassName}`, {\n [`${rootClassName}--disabled`]: disabled,\n })}\n key={id}\n disabled={disabled}\n aria-disabled={disabled}\n onClick={handleClick}\n >\n {children}\n <IconClose size=\"sm\" />\n </button>\n </li>\n );\n};\n\nDismissableChipGroupItem.displayName = \"DismissableChipGroupItem\";\n","import React, { type ReactNode, useId } from \"react\";\nimport type { BaseProps } from \"@purpur/common-types\";\nimport { Heading, type HeadingTagType } from \"@purpur/heading\";\nimport c from \"classnames/bind\";\n\nimport styles from \"./dismissable-chip-group.module.scss\";\nimport { DismissableChipGroupItem } from \"./dismissable-chip-group-item\";\n\nconst cx = c.bind(styles);\n\nexport type DismissableChipGroupProps = Omit<BaseProps, \"children\"> & {\n children: ReactNode;\n fullWidth?: boolean;\n title?: string;\n titleTag?: HeadingTagType;\n};\n\nconst rootClassName = \"purpur-dismissable-chip-group\";\n\nexport const DismissableChipGroup = ({\n children,\n className,\n fullWidth = false,\n title,\n titleTag,\n ...props\n}: DismissableChipGroupProps) => {\n const id = useId();\n const classes = cx([rootClassName, className]);\n\n return (\n <div\n {...props}\n aria-labelledby={title ? `${id}-label` : undefined}\n className={classes}\n role=\"group\"\n >\n {title && (\n <Heading tag={titleTag ?? \"h2\"} variant=\"subsection-100\">\n {title}\n </Heading>\n )}\n <ul\n data-testid=\"dismissable-chip-group-container\"\n className={cx(`${rootClassName}__container`, {\n [`${rootClassName}__container--full-width`]: fullWidth,\n })}\n aria-live=\"polite\"\n aria-relevant=\"additions removals\"\n >\n {children}\n </ul>\n </div>\n );\n};\n\nDismissableChipGroup.Item = DismissableChipGroupItem;\n\nDismissableChipGroup.displayName = \"DismissableChipGroup\";\n"],"names":["cx","c","styles","rootClassName","DismissableChipGroupItem","children","id","onDismiss","disabled","props","handleClick","e","createElement","jsx","IconClose","DismissableChipGroup","className","fullWidth","title","titleTag","useId","classes","jsxs","Heading"],"mappings":"gvBAOMA,EAAKC,EAAAA,EAAE,KAAKC,CAAM,EAQlBC,EAAgB,qCAETC,EAA2B,CAAC,CACvC,SAAAC,EACA,GAAAC,EACA,UAAAC,EACA,SAAAC,EACA,GAAGC,CACL,IAAqC,CACnC,MAAMC,EAAeC,GAAqC,CACpDH,EACFG,EAAE,eAAA,EAEFJ,IAAYD,CAAE,CAElB,EAEA,aACG,KAAA,CAAY,UAAWN,EAAG,GAAGG,CAAa,UAAU,EACnD,SAAAS,EAAAA,cAAC,SAAA,CACE,GAAGH,EACJ,UAAWT,EAAG,GAAGG,CAAa,GAAI,CAChC,CAAC,GAAGA,CAAa,YAAY,EAAGK,CAAA,CACjC,EACD,IAAKF,EACL,SAAAE,EACA,gBAAeA,EACf,QAASE,CAAA,EAERL,EACDQ,EAAAA,IAACC,EAAAA,EAAA,CAAU,KAAK,IAAA,CAAK,CAAA,GAZhBR,CAcT,CAEJ,EAEAF,EAAyB,YAAc,2BC3CvC,MAAMJ,EAAKC,EAAAA,EAAE,KAAKC,CAAM,EASlBC,EAAgB,gCAETY,EAAuB,CAAC,CACnC,SAAAV,EACA,UAAAW,EACA,UAAAC,EAAY,GACZ,MAAAC,EACA,SAAAC,EACA,GAAGV,CACL,IAAiC,CAC/B,MAAMH,EAAKc,EAAAA,MAAA,EACLC,EAAUrB,EAAG,CAACG,EAAea,CAAS,CAAC,EAE7C,OACEM,EAAAA,KAAC,MAAA,CACE,GAAGb,EACJ,kBAAiBS,EAAQ,GAAGZ,CAAE,SAAW,OACzC,UAAWe,EACX,KAAK,QAEJ,SAAA,CAAAH,SACEK,UAAA,CAAQ,IAAKJ,GAAY,KAAM,QAAQ,iBACrC,SAAAD,CAAA,CACH,EAEFL,EAAAA,IAAC,KAAA,CACC,cAAY,mCACZ,UAAWb,EAAG,GAAGG,CAAa,cAAe,CAC3C,CAAC,GAAGA,CAAa,yBAAyB,EAAGc,CAAA,CAC9C,EACD,YAAU,SACV,gBAAc,qBAEb,SAAAZ,CAAA,CAAA,CACH,CAAA,CAAA,CAGN,EAEAU,EAAqB,KAAOX,EAE5BW,EAAqB,YAAc"}
|
|
@@ -1,79 +0,0 @@
|
|
|
1
|
-
import { jsx as r, jsxs as g } from "react/jsx-runtime";
|
|
2
|
-
import { createElement as f, useId as k } from "react";
|
|
3
|
-
import { H as j } from "./heading-xwBuT_-9.mjs";
|
|
4
|
-
import { c as n } from "./bind-CU-R61T-.mjs";
|
|
5
|
-
import { r as C } from "./close.es-BPmk2wkU.mjs";
|
|
6
|
-
const d = {
|
|
7
|
-
"purpur-dismissable-chip-group": "_purpur-dismissable-chip-group_17jk4_1",
|
|
8
|
-
"purpur-dismissable-chip-group__container": "_purpur-dismissable-chip-group__container_17jk4_7",
|
|
9
|
-
"purpur-dismissable-chip-group__container--full-width": "_purpur-dismissable-chip-group__container--full-width_17jk4_14",
|
|
10
|
-
"purpur-dismissable-chip-group-item-wrapper": "_purpur-dismissable-chip-group-item-wrapper_17jk4_17",
|
|
11
|
-
"purpur-dismissable-chip-group-item": "_purpur-dismissable-chip-group-item_17jk4_17",
|
|
12
|
-
"purpur-dismissable-chip-group-item--disabled": "_purpur-dismissable-chip-group-item--disabled_17jk4_43"
|
|
13
|
-
}, m = n.bind(d), l = "purpur-dismissable-chip-group-item", _ = ({
|
|
14
|
-
children: p,
|
|
15
|
-
id: s,
|
|
16
|
-
onDismiss: e,
|
|
17
|
-
disabled: i,
|
|
18
|
-
...a
|
|
19
|
-
}) => {
|
|
20
|
-
const o = (u) => {
|
|
21
|
-
i ? u.preventDefault() : e?.(s);
|
|
22
|
-
};
|
|
23
|
-
return /* @__PURE__ */ r("li", { className: m(`${l}-wrapper`), children: /* @__PURE__ */ f(
|
|
24
|
-
"button",
|
|
25
|
-
{
|
|
26
|
-
...a,
|
|
27
|
-
className: m(`${l}`, {
|
|
28
|
-
[`${l}--disabled`]: i
|
|
29
|
-
}),
|
|
30
|
-
key: s,
|
|
31
|
-
disabled: i,
|
|
32
|
-
"aria-disabled": i,
|
|
33
|
-
onClick: o
|
|
34
|
-
},
|
|
35
|
-
p,
|
|
36
|
-
/* @__PURE__ */ r(C, { size: "sm" })
|
|
37
|
-
) }, s);
|
|
38
|
-
};
|
|
39
|
-
_.displayName = "DismissableChipGroupItem";
|
|
40
|
-
const c = n.bind(d), t = "purpur-dismissable-chip-group", b = ({
|
|
41
|
-
children: p,
|
|
42
|
-
className: s,
|
|
43
|
-
fullWidth: e = !1,
|
|
44
|
-
title: i,
|
|
45
|
-
titleTag: a,
|
|
46
|
-
...o
|
|
47
|
-
}) => {
|
|
48
|
-
const u = k(), h = c([t, s]);
|
|
49
|
-
return /* @__PURE__ */ g(
|
|
50
|
-
"div",
|
|
51
|
-
{
|
|
52
|
-
...o,
|
|
53
|
-
"aria-labelledby": i ? `${u}-label` : void 0,
|
|
54
|
-
className: h,
|
|
55
|
-
role: "group",
|
|
56
|
-
children: [
|
|
57
|
-
i && /* @__PURE__ */ r(j, { tag: a ?? "h2", variant: "subsection-100", children: i }),
|
|
58
|
-
/* @__PURE__ */ r(
|
|
59
|
-
"ul",
|
|
60
|
-
{
|
|
61
|
-
"data-testid": "dismissable-chip-group-container",
|
|
62
|
-
className: c(`${t}__container`, {
|
|
63
|
-
[`${t}__container--full-width`]: e
|
|
64
|
-
}),
|
|
65
|
-
"aria-live": "polite",
|
|
66
|
-
"aria-relevant": "additions removals",
|
|
67
|
-
children: p
|
|
68
|
-
}
|
|
69
|
-
)
|
|
70
|
-
]
|
|
71
|
-
}
|
|
72
|
-
);
|
|
73
|
-
};
|
|
74
|
-
b.Item = _;
|
|
75
|
-
b.displayName = "DismissableChipGroup";
|
|
76
|
-
export {
|
|
77
|
-
b as D
|
|
78
|
-
};
|
|
79
|
-
//# sourceMappingURL=dismissable-chip-group-ZCYOt1sB.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"dismissable-chip-group-ZCYOt1sB.mjs","sources":["../../../components/dismissable-chip-group/src/dismissable-chip-group-item.tsx","../../../components/dismissable-chip-group/src/dismissable-chip-group.tsx"],"sourcesContent":["import React, { type MouseEvent, type ReactNode } from \"react\";\nimport type { BaseProps } from \"@purpur/common-types\";\nimport { IconClose } from \"@purpur/icon/close\";\nimport c from \"classnames/bind\";\n\nimport styles from \"./dismissable-chip-group.module.scss\";\n\nconst cx = c.bind(styles);\n\nexport type DismissableChipGroupItemProps = Omit<BaseProps<\"button\">, \"aria-label\" | \"children\"> & {\n [\"aria-label\"]: string;\n children: ReactNode;\n onDismiss?: (id?: string) => void;\n};\n\nconst rootClassName = \"purpur-dismissable-chip-group-item\";\n\nexport const DismissableChipGroupItem = ({\n children,\n id,\n onDismiss,\n disabled,\n ...props\n}: DismissableChipGroupItemProps) => {\n const handleClick = (e: MouseEvent<HTMLButtonElement>) => {\n if (disabled) {\n e.preventDefault();\n } else {\n onDismiss?.(id);\n }\n };\n\n return (\n <li key={id} className={cx(`${rootClassName}-wrapper`)}>\n <button\n {...props}\n className={cx(`${rootClassName}`, {\n [`${rootClassName}--disabled`]: disabled,\n })}\n key={id}\n disabled={disabled}\n aria-disabled={disabled}\n onClick={handleClick}\n >\n {children}\n <IconClose size=\"sm\" />\n </button>\n </li>\n );\n};\n\nDismissableChipGroupItem.displayName = \"DismissableChipGroupItem\";\n","import React, { type ReactNode, useId } from \"react\";\nimport type { BaseProps } from \"@purpur/common-types\";\nimport { Heading, type HeadingTagType } from \"@purpur/heading\";\nimport c from \"classnames/bind\";\n\nimport styles from \"./dismissable-chip-group.module.scss\";\nimport { DismissableChipGroupItem } from \"./dismissable-chip-group-item\";\n\nconst cx = c.bind(styles);\n\nexport type DismissableChipGroupProps = Omit<BaseProps, \"children\"> & {\n children: ReactNode;\n fullWidth?: boolean;\n title?: string;\n titleTag?: HeadingTagType;\n};\n\nconst rootClassName = \"purpur-dismissable-chip-group\";\n\nexport const DismissableChipGroup = ({\n children,\n className,\n fullWidth = false,\n title,\n titleTag,\n ...props\n}: DismissableChipGroupProps) => {\n const id = useId();\n const classes = cx([rootClassName, className]);\n\n return (\n <div\n {...props}\n aria-labelledby={title ? `${id}-label` : undefined}\n className={classes}\n role=\"group\"\n >\n {title && (\n <Heading tag={titleTag ?? \"h2\"} variant=\"subsection-100\">\n {title}\n </Heading>\n )}\n <ul\n data-testid=\"dismissable-chip-group-container\"\n className={cx(`${rootClassName}__container`, {\n [`${rootClassName}__container--full-width`]: fullWidth,\n })}\n aria-live=\"polite\"\n aria-relevant=\"additions removals\"\n >\n {children}\n </ul>\n </div>\n );\n};\n\nDismissableChipGroup.Item = DismissableChipGroupItem;\n\nDismissableChipGroup.displayName = \"DismissableChipGroup\";\n"],"names":["cx","c","styles","rootClassName","DismissableChipGroupItem","children","id","onDismiss","disabled","props","handleClick","e","createElement","jsx","IconClose","DismissableChipGroup","className","fullWidth","title","titleTag","useId","classes","jsxs","Heading"],"mappings":";;;;;;;;;;;;GAOMA,IAAKC,EAAE,KAAKC,CAAM,GAQlBC,IAAgB,sCAETC,IAA2B,CAAC;AAAA,EACvC,UAAAC;AAAA,EACA,IAAAC;AAAA,EACA,WAAAC;AAAA,EACA,UAAAC;AAAA,EACA,GAAGC;AACL,MAAqC;AACnC,QAAMC,IAAc,CAACC,MAAqC;AACxD,IAAIH,IACFG,EAAE,eAAA,IAEFJ,IAAYD,CAAE;AAAA,EAElB;AAEA,2BACG,MAAA,EAAY,WAAWN,EAAG,GAAGG,CAAa,UAAU,GACnD,UAAA,gBAAAS;AAAA,IAAC;AAAA,IAAA;AAAA,MACE,GAAGH;AAAA,MACJ,WAAWT,EAAG,GAAGG,CAAa,IAAI;AAAA,QAChC,CAAC,GAAGA,CAAa,YAAY,GAAGK;AAAA,MAAA,CACjC;AAAA,MACD,KAAKF;AAAA,MACL,UAAAE;AAAA,MACA,iBAAeA;AAAA,MACf,SAASE;AAAA,IAAA;AAAA,IAERL;AAAA,IACD,gBAAAQ,EAACC,GAAA,EAAU,MAAK,KAAA,CAAK;AAAA,EAAA,KAZhBR,CAcT;AAEJ;AAEAF,EAAyB,cAAc;AC3CvC,MAAMJ,IAAKC,EAAE,KAAKC,CAAM,GASlBC,IAAgB,iCAETY,IAAuB,CAAC;AAAA,EACnC,UAAAV;AAAA,EACA,WAAAW;AAAA,EACA,WAAAC,IAAY;AAAA,EACZ,OAAAC;AAAA,EACA,UAAAC;AAAA,EACA,GAAGV;AACL,MAAiC;AAC/B,QAAMH,IAAKc,EAAA,GACLC,IAAUrB,EAAG,CAACG,GAAea,CAAS,CAAC;AAE7C,SACE,gBAAAM;AAAA,IAAC;AAAA,IAAA;AAAA,MACE,GAAGb;AAAA,MACJ,mBAAiBS,IAAQ,GAAGZ,CAAE,WAAW;AAAA,MACzC,WAAWe;AAAA,MACX,MAAK;AAAA,MAEJ,UAAA;AAAA,QAAAH,uBACEK,GAAA,EAAQ,KAAKJ,KAAY,MAAM,SAAQ,kBACrC,UAAAD,EAAA,CACH;AAAA,QAEF,gBAAAL;AAAA,UAAC;AAAA,UAAA;AAAA,YACC,eAAY;AAAA,YACZ,WAAWb,EAAG,GAAGG,CAAa,eAAe;AAAA,cAC3C,CAAC,GAAGA,CAAa,yBAAyB,GAAGc;AAAA,YAAA,CAC9C;AAAA,YACD,aAAU;AAAA,YACV,iBAAc;AAAA,YAEb,UAAAZ;AAAA,UAAA;AAAA,QAAA;AAAA,MACH;AAAA,IAAA;AAAA,EAAA;AAGN;AAEAU,EAAqB,OAAOX;AAE5BW,EAAqB,cAAc;"}
|
package/dist/listbox-BmjBtIv8.js
DELETED
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
"use strict";const r=require("react/jsx-runtime"),o=require("react"),p=require("./bind-DeUYJ6m9.js"),g=require("./checkmark.es-lYntWFA3.js"),N=require("./paragraph-BsI53OR0.js"),m={"purpur-listbox":"_purpur-listbox_6c8yl_1","purpur-listbox-item":"_purpur-listbox-item_6c8yl_15","purpur-listbox-item--hovered":"_purpur-listbox-item--hovered_6c8yl_29","purpur-listbox-item--highlighted":"_purpur-listbox-item--highlighted_6c8yl_37","purpur-listbox-item--noninteractive":"_purpur-listbox-item--noninteractive_6c8yl_41","purpur-listbox-item--disabled":"_purpur-listbox-item--disabled_6c8yl_44","purpur-listbox-item__icon":"_purpur-listbox-item__icon_6c8yl_51"},u=p.c.bind(m),e="purpur-listbox",a=o.forwardRef((i,t)=>{const{disabled:s,highlighted:d,hovered:x,selected:l,children:c,className:b,noninteractive:_,...h}=i,y=u(`${e}-item`,b,{[`${e}-item--highlighted`]:d,[`${e}-item--selected`]:l,[`${e}-item--hovered`]:x,[`${e}-item--disabled`]:s,[`${e}-item--noninteractive`]:_});return r.jsxs("li",{...h,ref:t,className:y,"aria-selected":!!l,role:"option","aria-disabled":!!s,children:[typeof c=="string"?r.jsx(N.Paragraph,{children:c}):c,l&&r.jsx(g.a,{size:"xs",className:u(`${e}-item__icon`)})]})}),$=i=>o.isValidElement(i)&&i?.type===a;a.displayName="ListBoxItem";const v=p.c.bind(m),f="purpur-listbox",n=o.forwardRef(({children:i,...t},s)=>r.jsx("ul",{...t,ref:s,className:v(f,t.className),role:"listbox",children:o.Children.toArray(i).filter($)}));n.Item=a;n.displayName="ListBox";exports.Listbox=n;
|
|
2
|
-
//# sourceMappingURL=listbox-BmjBtIv8.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"listbox-BmjBtIv8.js","sources":["../../../components/listbox/src/listbox-item.tsx","../../../components/listbox/src/listbox.tsx"],"sourcesContent":["import React, { forwardRef, isValidElement, type ReactElement, type ReactNode } from \"react\";\nimport type { BaseProps } from \"@purpur/common-types\";\nimport { IconCheckmark } from \"@purpur/icon/checkmark\";\nimport { Paragraph } from \"@purpur/paragraph\";\nimport c from \"classnames/bind\";\n\nimport styles from \"./listbox.module.scss\";\n\nconst cx = c.bind(styles);\n\nconst rootClassName = \"purpur-listbox\";\n\nexport type ListboxItemProps = Omit<BaseProps<\"li\">, \"role\"> & {\n highlighted?: boolean;\n hovered?: boolean;\n key?: string;\n selected?: boolean;\n disabled?: boolean;\n noninteractive?: boolean;\n};\n\nexport const ListboxItem = forwardRef<HTMLLIElement, ListboxItemProps>((props, ref) => {\n const {\n disabled,\n highlighted,\n hovered,\n selected,\n children,\n className,\n noninteractive,\n ...liProps\n } = props;\n\n const classes = cx(`${rootClassName}-item`, className, {\n [`${rootClassName}-item--highlighted`]: highlighted,\n [`${rootClassName}-item--selected`]: selected,\n [`${rootClassName}-item--hovered`]: hovered,\n [`${rootClassName}-item--disabled`]: disabled,\n [`${rootClassName}-item--noninteractive`]: noninteractive,\n });\n\n return (\n <li\n {...liProps}\n ref={ref}\n className={classes}\n aria-selected={!!selected}\n role=\"option\"\n aria-disabled={!!disabled}\n >\n {typeof children === \"string\" ? <Paragraph>{children}</Paragraph> : children}\n {selected && <IconCheckmark size=\"xs\" className={cx(`${rootClassName}-item__icon`)} />}\n </li>\n );\n});\n\nexport const isListboxItem = (child?: ReactNode): child is ReactElement<ListboxItemProps> =>\n isValidElement<ListboxItemProps>(child) && child?.type === ListboxItem;\n\nListboxItem.displayName = \"ListBoxItem\";\n","import React, {\n Children,\n forwardRef,\n type ForwardRefExoticComponent,\n type PropsWithoutRef,\n} from \"react\";\nimport type { BaseProps } from \"@purpur/common-types\";\nimport c from \"classnames/bind\";\n\nimport styles from \"./listbox.module.scss\";\nimport { isListboxItem, ListboxItem } from \"./listbox-item\";\n\nconst cx = c.bind(styles);\n\nconst rootClassName = \"purpur-listbox\";\n\nexport type ListboxProps = Omit<BaseProps<\"ul\">, \"role\"> & {\n \"aria-label\": NonNullable<BaseProps<\"ul\">[\"aria-label\"]>;\n \"aria-expanded\": NonNullable<BaseProps<\"ul\">[\"aria-expanded\"]>;\n};\n\ntype ListboxStatic = {\n Item: typeof ListboxItem;\n};\n\ntype ListboxComponent = ForwardRefExoticComponent<PropsWithoutRef<ListboxProps>> & ListboxStatic;\n\nexport const Listbox = forwardRef<HTMLUListElement, ListboxProps>(\n ({ children, ...listboxProps }, ref) => (\n <ul\n {...listboxProps}\n ref={ref}\n className={cx(rootClassName, listboxProps.className)}\n role=\"listbox\"\n >\n {Children.toArray(children).filter(isListboxItem)}\n </ul>\n )\n) as ListboxComponent;\n\nexport type { ListboxItemProps } from \"./listbox-item\";\nListbox.Item = ListboxItem;\nListbox.displayName = \"ListBox\";\n"],"names":["cx","c","styles","rootClassName","ListboxItem","forwardRef","props","ref","disabled","highlighted","hovered","selected","children","className","noninteractive","liProps","classes","jsxs","jsx","Paragraph","IconCheckmark","isListboxItem","child","isValidElement","Listbox","listboxProps","Children"],"mappings":"ipBAQMA,EAAKC,EAAAA,EAAE,KAAKC,CAAM,EAElBC,EAAgB,iBAWTC,EAAcC,EAAAA,WAA4C,CAACC,EAAOC,IAAQ,CACrF,KAAM,CACJ,SAAAC,EACA,YAAAC,EACA,QAAAC,EACA,SAAAC,EACA,SAAAC,EACA,UAAAC,EACA,eAAAC,EACA,GAAGC,CAAA,EACDT,EAEEU,EAAUhB,EAAG,GAAGG,CAAa,QAASU,EAAW,CACrD,CAAC,GAAGV,CAAa,oBAAoB,EAAGM,EACxC,CAAC,GAAGN,CAAa,iBAAiB,EAAGQ,EACrC,CAAC,GAAGR,CAAa,gBAAgB,EAAGO,EACpC,CAAC,GAAGP,CAAa,iBAAiB,EAAGK,EACrC,CAAC,GAAGL,CAAa,uBAAuB,EAAGW,CAAA,CAC5C,EAED,OACEG,EAAAA,KAAC,KAAA,CACE,GAAGF,EACJ,IAAAR,EACA,UAAWS,EACX,gBAAe,CAAC,CAACL,EACjB,KAAK,SACL,gBAAe,CAAC,CAACH,EAEhB,SAAA,CAAA,OAAOI,GAAa,SAAWM,EAAAA,IAACC,EAAAA,UAAA,CAAW,SAAAP,EAAS,EAAeA,EACnED,GAAYO,EAAAA,IAACE,IAAA,CAAc,KAAK,KAAK,UAAWpB,EAAG,GAAGG,CAAa,aAAa,CAAA,CAAG,CAAA,CAAA,CAAA,CAG1F,CAAC,EAEYkB,EAAiBC,GAC5BC,EAAAA,eAAiCD,CAAK,GAAKA,GAAO,OAASlB,EAE7DA,EAAY,YAAc,cC/C1B,MAAMJ,EAAKC,EAAAA,EAAE,KAAKC,CAAM,EAElBC,EAAgB,iBAaTqB,EAAUnB,EAAAA,WACrB,CAAC,CAAE,SAAAO,EAAU,GAAGa,CAAA,EAAgBlB,IAC9BW,EAAAA,IAAC,KAAA,CACE,GAAGO,EACJ,IAAAlB,EACA,UAAWP,EAAGG,EAAesB,EAAa,SAAS,EACnD,KAAK,UAEJ,SAAAC,EAAAA,SAAS,QAAQd,CAAQ,EAAE,OAAOS,CAAa,CAAA,CAAA,CAGtD,EAGAG,EAAQ,KAAOpB,EACfoB,EAAQ,YAAc"}
|
|
@@ -1,65 +0,0 @@
|
|
|
1
|
-
import { jsxs as g, jsx as l } from "react/jsx-runtime";
|
|
2
|
-
import { forwardRef as a, isValidElement as f, Children as N } from "react";
|
|
3
|
-
import { c } from "./bind-CU-R61T-.mjs";
|
|
4
|
-
import { a as $ } from "./checkmark.es-DdgIZN2R.mjs";
|
|
5
|
-
import { P as v } from "./paragraph-Ci50OF1u.mjs";
|
|
6
|
-
const n = {
|
|
7
|
-
"purpur-listbox": "_purpur-listbox_6c8yl_1",
|
|
8
|
-
"purpur-listbox-item": "_purpur-listbox-item_6c8yl_15",
|
|
9
|
-
"purpur-listbox-item--hovered": "_purpur-listbox-item--hovered_6c8yl_29",
|
|
10
|
-
"purpur-listbox-item--highlighted": "_purpur-listbox-item--highlighted_6c8yl_37",
|
|
11
|
-
"purpur-listbox-item--noninteractive": "_purpur-listbox-item--noninteractive_6c8yl_41",
|
|
12
|
-
"purpur-listbox-item--disabled": "_purpur-listbox-item--disabled_6c8yl_44",
|
|
13
|
-
"purpur-listbox-item__icon": "_purpur-listbox-item__icon_6c8yl_51"
|
|
14
|
-
}, m = c.bind(n), i = "purpur-listbox", p = a((t, e) => {
|
|
15
|
-
const {
|
|
16
|
-
disabled: r,
|
|
17
|
-
highlighted: d,
|
|
18
|
-
hovered: x,
|
|
19
|
-
selected: s,
|
|
20
|
-
children: o,
|
|
21
|
-
className: _,
|
|
22
|
-
noninteractive: b,
|
|
23
|
-
...h
|
|
24
|
-
} = t, y = m(`${i}-item`, _, {
|
|
25
|
-
[`${i}-item--highlighted`]: d,
|
|
26
|
-
[`${i}-item--selected`]: s,
|
|
27
|
-
[`${i}-item--hovered`]: x,
|
|
28
|
-
[`${i}-item--disabled`]: r,
|
|
29
|
-
[`${i}-item--noninteractive`]: b
|
|
30
|
-
});
|
|
31
|
-
return /* @__PURE__ */ g(
|
|
32
|
-
"li",
|
|
33
|
-
{
|
|
34
|
-
...h,
|
|
35
|
-
ref: e,
|
|
36
|
-
className: y,
|
|
37
|
-
"aria-selected": !!s,
|
|
38
|
-
role: "option",
|
|
39
|
-
"aria-disabled": !!r,
|
|
40
|
-
children: [
|
|
41
|
-
typeof o == "string" ? /* @__PURE__ */ l(v, { children: o }) : o,
|
|
42
|
-
s && /* @__PURE__ */ l($, { size: "xs", className: m(`${i}-item__icon`) })
|
|
43
|
-
]
|
|
44
|
-
}
|
|
45
|
-
);
|
|
46
|
-
}), L = (t) => f(t) && t?.type === p;
|
|
47
|
-
p.displayName = "ListBoxItem";
|
|
48
|
-
const I = c.bind(n), C = "purpur-listbox", u = a(
|
|
49
|
-
({ children: t, ...e }, r) => /* @__PURE__ */ l(
|
|
50
|
-
"ul",
|
|
51
|
-
{
|
|
52
|
-
...e,
|
|
53
|
-
ref: r,
|
|
54
|
-
className: I(C, e.className),
|
|
55
|
-
role: "listbox",
|
|
56
|
-
children: N.toArray(t).filter(L)
|
|
57
|
-
}
|
|
58
|
-
)
|
|
59
|
-
);
|
|
60
|
-
u.Item = p;
|
|
61
|
-
u.displayName = "ListBox";
|
|
62
|
-
export {
|
|
63
|
-
u as L
|
|
64
|
-
};
|
|
65
|
-
//# sourceMappingURL=listbox-oDeP8FvH.mjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"listbox-oDeP8FvH.mjs","sources":["../../../components/listbox/src/listbox-item.tsx","../../../components/listbox/src/listbox.tsx"],"sourcesContent":["import React, { forwardRef, isValidElement, type ReactElement, type ReactNode } from \"react\";\nimport type { BaseProps } from \"@purpur/common-types\";\nimport { IconCheckmark } from \"@purpur/icon/checkmark\";\nimport { Paragraph } from \"@purpur/paragraph\";\nimport c from \"classnames/bind\";\n\nimport styles from \"./listbox.module.scss\";\n\nconst cx = c.bind(styles);\n\nconst rootClassName = \"purpur-listbox\";\n\nexport type ListboxItemProps = Omit<BaseProps<\"li\">, \"role\"> & {\n highlighted?: boolean;\n hovered?: boolean;\n key?: string;\n selected?: boolean;\n disabled?: boolean;\n noninteractive?: boolean;\n};\n\nexport const ListboxItem = forwardRef<HTMLLIElement, ListboxItemProps>((props, ref) => {\n const {\n disabled,\n highlighted,\n hovered,\n selected,\n children,\n className,\n noninteractive,\n ...liProps\n } = props;\n\n const classes = cx(`${rootClassName}-item`, className, {\n [`${rootClassName}-item--highlighted`]: highlighted,\n [`${rootClassName}-item--selected`]: selected,\n [`${rootClassName}-item--hovered`]: hovered,\n [`${rootClassName}-item--disabled`]: disabled,\n [`${rootClassName}-item--noninteractive`]: noninteractive,\n });\n\n return (\n <li\n {...liProps}\n ref={ref}\n className={classes}\n aria-selected={!!selected}\n role=\"option\"\n aria-disabled={!!disabled}\n >\n {typeof children === \"string\" ? <Paragraph>{children}</Paragraph> : children}\n {selected && <IconCheckmark size=\"xs\" className={cx(`${rootClassName}-item__icon`)} />}\n </li>\n );\n});\n\nexport const isListboxItem = (child?: ReactNode): child is ReactElement<ListboxItemProps> =>\n isValidElement<ListboxItemProps>(child) && child?.type === ListboxItem;\n\nListboxItem.displayName = \"ListBoxItem\";\n","import React, {\n Children,\n forwardRef,\n type ForwardRefExoticComponent,\n type PropsWithoutRef,\n} from \"react\";\nimport type { BaseProps } from \"@purpur/common-types\";\nimport c from \"classnames/bind\";\n\nimport styles from \"./listbox.module.scss\";\nimport { isListboxItem, ListboxItem } from \"./listbox-item\";\n\nconst cx = c.bind(styles);\n\nconst rootClassName = \"purpur-listbox\";\n\nexport type ListboxProps = Omit<BaseProps<\"ul\">, \"role\"> & {\n \"aria-label\": NonNullable<BaseProps<\"ul\">[\"aria-label\"]>;\n \"aria-expanded\": NonNullable<BaseProps<\"ul\">[\"aria-expanded\"]>;\n};\n\ntype ListboxStatic = {\n Item: typeof ListboxItem;\n};\n\ntype ListboxComponent = ForwardRefExoticComponent<PropsWithoutRef<ListboxProps>> & ListboxStatic;\n\nexport const Listbox = forwardRef<HTMLUListElement, ListboxProps>(\n ({ children, ...listboxProps }, ref) => (\n <ul\n {...listboxProps}\n ref={ref}\n className={cx(rootClassName, listboxProps.className)}\n role=\"listbox\"\n >\n {Children.toArray(children).filter(isListboxItem)}\n </ul>\n )\n) as ListboxComponent;\n\nexport type { ListboxItemProps } from \"./listbox-item\";\nListbox.Item = ListboxItem;\nListbox.displayName = \"ListBox\";\n"],"names":["cx","styles","rootClassName","ListboxItem","forwardRef","props","ref","disabled","highlighted","hovered","selected","children","className","noninteractive","liProps","classes","jsxs","jsx","Paragraph","IconCheckmark","isListboxItem","child","isValidElement","Listbox","listboxProps","Children"],"mappings":";;;;;;;;;;;;;GAQMA,IAAK,EAAE,KAAKC,CAAM,GAElBC,IAAgB,kBAWTC,IAAcC,EAA4C,CAACC,GAAOC,MAAQ;AACrF,QAAM;AAAA,IACJ,UAAAC;AAAA,IACA,aAAAC;AAAA,IACA,SAAAC;AAAA,IACA,UAAAC;AAAA,IACA,UAAAC;AAAA,IACA,WAAAC;AAAA,IACA,gBAAAC;AAAA,IACA,GAAGC;AAAA,EAAA,IACDT,GAEEU,IAAUf,EAAG,GAAGE,CAAa,SAASU,GAAW;AAAA,IACrD,CAAC,GAAGV,CAAa,oBAAoB,GAAGM;AAAA,IACxC,CAAC,GAAGN,CAAa,iBAAiB,GAAGQ;AAAA,IACrC,CAAC,GAAGR,CAAa,gBAAgB,GAAGO;AAAA,IACpC,CAAC,GAAGP,CAAa,iBAAiB,GAAGK;AAAA,IACrC,CAAC,GAAGL,CAAa,uBAAuB,GAAGW;AAAA,EAAA,CAC5C;AAED,SACE,gBAAAG;AAAA,IAAC;AAAA,IAAA;AAAA,MACE,GAAGF;AAAA,MACJ,KAAAR;AAAA,MACA,WAAWS;AAAA,MACX,iBAAe,CAAC,CAACL;AAAA,MACjB,MAAK;AAAA,MACL,iBAAe,CAAC,CAACH;AAAA,MAEhB,UAAA;AAAA,QAAA,OAAOI,KAAa,WAAW,gBAAAM,EAACC,GAAA,EAAW,UAAAP,GAAS,IAAeA;AAAA,QACnED,KAAY,gBAAAO,EAACE,GAAA,EAAc,MAAK,MAAK,WAAWnB,EAAG,GAAGE,CAAa,aAAa,EAAA,CAAG;AAAA,MAAA;AAAA,IAAA;AAAA,EAAA;AAG1F,CAAC,GAEYkB,IAAgB,CAACC,MAC5BC,EAAiCD,CAAK,KAAKA,GAAO,SAASlB;AAE7DA,EAAY,cAAc;AC/C1B,MAAMH,IAAK,EAAE,KAAKC,CAAM,GAElBC,IAAgB,kBAaTqB,IAAUnB;AAAA,EACrB,CAAC,EAAE,UAAAO,GAAU,GAAGa,EAAA,GAAgBlB,MAC9B,gBAAAW;AAAA,IAAC;AAAA,IAAA;AAAA,MACE,GAAGO;AAAA,MACJ,KAAAlB;AAAA,MACA,WAAWN,EAAGE,GAAesB,EAAa,SAAS;AAAA,MACnD,MAAK;AAAA,MAEJ,UAAAC,EAAS,QAAQd,CAAQ,EAAE,OAAOS,CAAa;AAAA,IAAA;AAAA,EAAA;AAGtD;AAGAG,EAAQ,OAAOpB;AACfoB,EAAQ,cAAc;"}
|
|
@@ -1,2 +0,0 @@
|
|
|
1
|
-
"use strict";const e=require("react/jsx-runtime"),j=require("react"),_=require("./search.es-Cg2amJSR.js"),k=require("./text-field-CiLEj0Fq.js"),f=require("./bind-DeUYJ6m9.js"),d=require("./button-Dqxdc3nC.js"),v={"purpur-search-field":"_purpur-search-field_uhpkq_1","purpur-search-field--has-clear-button":"_purpur-search-field--has-clear-button_uhpkq_4","purpur-search-field--no-gap":"_purpur-search-field--no-gap_uhpkq_13","purpur-search-field__wrapper":"_purpur-search-field__wrapper_uhpkq_17","purpur-search-field__wrapper--gap":"_purpur-search-field__wrapper--gap_uhpkq_20","purpur-search-field__search-icon":"_purpur-search-field__search-icon_uhpkq_24","purpur-search-field__close-icon":"_purpur-search-field__close-icon_uhpkq_24"},N={"purpur-search-field-button":"_purpur-search-field-button_c16yo_1","purpur-search-field-button--icon-only":"_purpur-search-field-button--icon-only_c16yo_1"},w=f.c.bind(N),h="purpur-search-field-button",z=({["data-testid"]:s,disabled:i,iconOnly:c,label:r})=>{const a={className:w(h,{[`${h}--icon-only`]:c}),disabled:i,"data-testid":s};return c?e.jsx(d.Button,{...a,"aria-label":r,iconOnly:!0,size:"sm",type:"submit",variant:"primary",children:e.jsx(_.s,{size:"xs"})}):e.jsx(d.Button,{...a,size:"sm",type:"submit",variant:"primary",children:r})},S=["button-attached","no-button"],l=f.c.bind(v),u="purpur-search-field",b=j.forwardRef(({["data-testid"]:s,className:i,clearButtonAriaLabel:c,disabled:r,iconOnlySearchButton:a,onClear:m,onSearch:x,searchButtonLabel:y,variant:o,formRef:q,...t},$)=>{const p=n=>s?`${s}-${n}`:void 0,F=(typeof t.value=="number"?t.value!==void 0:t.value?.length)&&!r&&!t.readOnly&&!t.loading,g=l(i,u,{[`${u}--no-gap`]:o==="button-attached",[`${u}--has-clear-button`]:F});return e.jsx("form",{ref:q,className:l(`${u}__wrapper`),"data-testid":s,onSubmit:n=>{n.preventDefault(),x?.(n)},children:e.jsx(k.TextField,{ref:$,className:g,clearButtonAriaLabel:c,disabled:r,onClear:m,startAdornment:a?null:e.jsx(_.s,{size:"xs",className:l(`${u}__search-icon`)},"1"),afterField:o!=="no-button"?e.jsx(z,{disabled:r,iconOnly:a,label:y,"data-testid":p("button")}):null,"data-testid":p("text-field"),type:"search",...t})})});b.displayName="SearchField";exports.SearchField=b;exports.searchFieldVariants=S;
|
|
2
|
-
//# sourceMappingURL=search-field-CNpJp3Tg.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"search-field-CNpJp3Tg.js","sources":["../../../components/search-field/src/search-field-button.tsx","../../../components/search-field/src/search-field.tsx"],"sourcesContent":["import React from \"react\";\nimport { Button } from \"@purpur/button\";\nimport { IconSearch } from \"@purpur/icon/search\";\nimport c from \"classnames/bind\";\n\nimport styles from \"./search-field-button.module.scss\";\n\ntype Props = {\n [\"data-testid\"]?: string;\n disabled?: boolean;\n iconOnly?: boolean;\n label: string;\n};\n\nconst cx = c.bind(styles);\nconst rootClassName = \"purpur-search-field-button\";\n\nexport const SearchFieldButton = ({\n [\"data-testid\"]: dataTestid,\n disabled,\n iconOnly,\n label,\n}: Props) => {\n const props = {\n className: cx(rootClassName, {\n [`${rootClassName}--icon-only`]: iconOnly,\n }),\n disabled,\n [\"data-testid\"]: dataTestid,\n };\n\n if (iconOnly) {\n return (\n <Button {...props} aria-label={label} iconOnly size=\"sm\" type=\"submit\" variant=\"primary\">\n <IconSearch size=\"xs\" />\n </Button>\n );\n }\n\n return (\n <Button {...props} size=\"sm\" type=\"submit\" variant=\"primary\">\n {label}\n </Button>\n );\n};\n","import React, { type ChangeEvent, type FormEvent, forwardRef, type RefObject } from \"react\";\nimport { IconSearch } from \"@purpur/icon/search\";\nimport { TextField, type TextFieldProps } from \"@purpur/text-field\";\nimport c from \"classnames/bind\";\n\nimport styles from \"./search-field.module.scss\";\nimport { SearchFieldButton } from \"./search-field-button\";\n\nexport const searchFieldVariants = [\"button-attached\", \"no-button\"] as const;\n\ntype Variant = (typeof searchFieldVariants)[number];\n\ntype DefaultProps = {\n [\"data-testid\"]?: string;\n /**\n * An accessible label for the clear button.\n * */\n clearButtonAriaLabel: string;\n /**\n * Disables both the input field and submit button if `true`.\n * */\n disabled?: boolean;\n /**\n * Will display only a search icon in the search button if `true`.\n * */\n iconOnlySearchButton?: boolean;\n /**\n * Event handler called when the value of the search field changes.\n * */\n onChange?: (e: ChangeEvent<HTMLInputElement>) => void;\n /**\n * Event handler called when the clear button is clicked.\n * */\n onClear: () => void;\n /**\n * Event handler called when the search form is submitted.\n * */\n onSearch?: (e: FormEvent<HTMLFormElement>) => void;\n /**\n * The label text (or `aria-label` if `iconOnlySearchButton` is `true`) of the search button.\n * */\n searchButtonLabel?: string;\n variant: Variant;\n formRef?: RefObject<HTMLFormElement>;\n};\n\ntype TextSearchButton = {\n iconOnlySearchButton?: false;\n searchButtonLabel: string;\n variant: \"button-attached\";\n};\n\ntype IconOnlySearchButton = {\n iconOnlySearchButton: true;\n searchButtonLabel: string;\n variant: \"button-attached\";\n};\n\ntype NoButton = {\n searchButtonLabel?: never;\n variant: \"no-button\";\n};\n\nexport type SearchFieldProps = DefaultProps &\n (TextSearchButton | IconOnlySearchButton | NoButton) &\n Omit<TextFieldProps, \"startAdornment\" | \"endAdornment\" | \"afterField\" | \"onChange\">;\n\nconst cx = c.bind(styles);\nconst rootClassName = \"purpur-search-field\";\n\nexport const SearchField = forwardRef<HTMLInputElement, SearchFieldProps>(\n (\n {\n [\"data-testid\"]: dataTestId,\n className,\n clearButtonAriaLabel,\n disabled,\n iconOnlySearchButton,\n onClear,\n onSearch,\n searchButtonLabel,\n variant,\n formRef,\n ...props\n },\n ref\n ) => {\n const getTestId = (name: string) => (dataTestId ? `${dataTestId}-${name}` : undefined);\n const hasValue =\n typeof props.value === \"number\" ? props.value !== undefined : props.value?.length;\n const hasClearButton = hasValue && !disabled && !props.readOnly && !props.loading;\n\n const classes = cx(className, rootClassName, {\n [`${rootClassName}--no-gap`]: variant === \"button-attached\",\n [`${rootClassName}--has-clear-button`]: hasClearButton,\n });\n\n return (\n <form\n ref={formRef}\n className={cx(`${rootClassName}__wrapper`)}\n data-testid={dataTestId}\n onSubmit={(e: FormEvent<HTMLFormElement>) => {\n e.preventDefault();\n onSearch?.(e);\n }}\n >\n <TextField\n ref={ref}\n className={classes}\n clearButtonAriaLabel={clearButtonAriaLabel}\n disabled={disabled}\n onClear={onClear}\n startAdornment={\n !iconOnlySearchButton ? (\n <IconSearch size=\"xs\" className={cx(`${rootClassName}__search-icon`)} key=\"1\" />\n ) : null\n }\n afterField={\n variant !== \"no-button\" ? (\n <SearchFieldButton\n disabled={disabled}\n iconOnly={iconOnlySearchButton}\n label={searchButtonLabel}\n data-testid={getTestId(\"button\")}\n />\n ) : null\n }\n data-testid={getTestId(\"text-field\")}\n type=\"search\"\n {...props}\n />\n </form>\n );\n }\n);\n\nSearchField.displayName = \"SearchField\";\n"],"names":["cx","c","styles","rootClassName","SearchFieldButton","dataTestid","disabled","iconOnly","label","props","Button","IconSearch","jsx","searchFieldVariants","SearchField","forwardRef","dataTestId","className","clearButtonAriaLabel","iconOnlySearchButton","onClear","onSearch","searchButtonLabel","variant","formRef","ref","getTestId","name","hasClearButton","classes","e","TextField"],"mappings":"k4BAcMA,EAAKC,EAAAA,EAAE,KAAKC,CAAM,EAClBC,EAAgB,6BAETC,EAAoB,CAAC,CAChC,CAAC,eAAgBC,EACjB,SAAAC,EACA,SAAAC,EACA,MAAAC,CACF,IAAa,CACX,MAAMC,EAAQ,CACZ,UAAWT,EAAGG,EAAe,CAC3B,CAAC,GAAGA,CAAa,aAAa,EAAGI,CAAA,CAClC,EACD,SAAAD,EACC,cAAgBD,CAAA,EAGnB,OAAIE,QAECG,SAAA,CAAQ,GAAGD,EAAO,aAAYD,EAAO,SAAQ,GAAC,KAAK,KAAK,KAAK,SAAS,QAAQ,UAC7E,eAACG,EAAAA,EAAA,CAAW,KAAK,KAAK,EACxB,EAKFC,EAAAA,IAACF,EAAAA,OAAA,CAAQ,GAAGD,EAAO,KAAK,KAAK,KAAK,SAAS,QAAQ,UAChD,SAAAD,CAAA,CACH,CAEJ,ECpCaK,EAAsB,CAAC,kBAAmB,WAAW,EA2D5Db,EAAKC,EAAAA,EAAE,KAAKC,CAAM,EAClBC,EAAgB,sBAETW,EAAcC,EAAAA,WACzB,CACE,CACE,CAAC,eAAgBC,EACjB,UAAAC,EACA,qBAAAC,EACA,SAAAZ,EACA,qBAAAa,EACA,QAAAC,EACA,SAAAC,EACA,kBAAAC,EACA,QAAAC,EACA,QAAAC,EACA,GAAGf,CAAA,EAELgB,IACG,CACH,MAAMC,EAAaC,GAAkBX,EAAa,GAAGA,CAAU,IAAIW,CAAI,GAAK,OAGtEC,GADJ,OAAOnB,EAAM,OAAU,SAAWA,EAAM,QAAU,OAAYA,EAAM,OAAO,SAC1C,CAACH,GAAY,CAACG,EAAM,UAAY,CAACA,EAAM,QAEpEoB,EAAU7B,EAAGiB,EAAWd,EAAe,CAC3C,CAAC,GAAGA,CAAa,UAAU,EAAGoB,IAAY,kBAC1C,CAAC,GAAGpB,CAAa,oBAAoB,EAAGyB,CAAA,CACzC,EAED,OACEhB,EAAAA,IAAC,OAAA,CACC,IAAKY,EACL,UAAWxB,EAAG,GAAGG,CAAa,WAAW,EACzC,cAAaa,EACb,SAAWc,GAAkC,CAC3CA,EAAE,eAAA,EACFT,IAAWS,CAAC,CACd,EAEA,SAAAlB,EAAAA,IAACmB,EAAAA,UAAA,CACC,IAAAN,EACA,UAAWI,EACX,qBAAAX,EACA,SAAAZ,EACA,QAAAc,EACA,eACGD,EAEG,KADFP,EAAAA,IAACD,EAAAA,GAAW,KAAK,KAAK,UAAWX,EAAG,GAAGG,CAAa,eAAe,CAAA,EAAO,GAAI,EAGlF,WACEoB,IAAY,YACVX,EAAAA,IAACR,EAAA,CACC,SAAAE,EACA,SAAUa,EACV,MAAOG,EACP,cAAaI,EAAU,QAAQ,CAAA,CAAA,EAE/B,KAEN,cAAaA,EAAU,YAAY,EACnC,KAAK,SACJ,GAAGjB,CAAA,CAAA,CACN,CAAA,CAGN,CACF,EAEAK,EAAY,YAAc"}
|