fictoan-react 2.0.0-beta.17 → 2.0.0-beta.18

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (181) hide show
  1. package/dist/components/Accordion/Accordion.d.ts.map +1 -1
  2. package/dist/components/Accordion/Accordion.js +27 -0
  3. package/dist/components/Accordion/Accordion.js.map +1 -0
  4. package/dist/components/Badge/Badge.d.ts.map +1 -1
  5. package/dist/components/Badge/Badge.js +56 -0
  6. package/dist/components/Badge/Badge.js.map +1 -0
  7. package/dist/components/Breadcrumbs/Breadcrumbs.js +65 -0
  8. package/dist/components/Breadcrumbs/Breadcrumbs.js.map +1 -0
  9. package/dist/components/Button/Button.js +28 -0
  10. package/dist/components/Button/Button.js.map +1 -0
  11. package/dist/components/ButtonGroup/ButtonGroup.js +27 -0
  12. package/dist/components/ButtonGroup/ButtonGroup.js.map +1 -0
  13. package/dist/components/Callout/Callout.js +31 -0
  14. package/dist/components/Callout/Callout.js.map +1 -0
  15. package/dist/components/Card/Card.js +27 -0
  16. package/dist/components/Card/Card.js.map +1 -0
  17. package/dist/components/CodeBlock/CodeBlock.js +191 -0
  18. package/dist/components/CodeBlock/CodeBlock.js.map +1 -0
  19. package/dist/components/Divider/Divider.js +29 -0
  20. package/dist/components/Divider/Divider.js.map +1 -0
  21. package/dist/components/Drawer/Drawer.d.ts +3 -0
  22. package/dist/components/Drawer/Drawer.d.ts.map +1 -1
  23. package/dist/components/Drawer/Drawer.js +96 -0
  24. package/dist/components/Drawer/Drawer.js.map +1 -0
  25. package/dist/components/Element/Element.d.ts +6 -2
  26. package/dist/components/Element/Element.d.ts.map +1 -1
  27. package/dist/components/Element/Element.js +152 -0
  28. package/dist/components/Element/Element.js.map +1 -0
  29. package/dist/components/Element/Tags.js +31 -0
  30. package/dist/components/Element/Tags.js.map +1 -0
  31. package/dist/components/Element/constants.js +8 -0
  32. package/dist/components/Element/constants.js.map +1 -0
  33. package/dist/components/Form/Checkbox/Checkbox.d.ts.map +1 -1
  34. package/dist/components/Form/Checkbox/Checkbox.js +78 -0
  35. package/dist/components/Form/Checkbox/Checkbox.js.map +1 -0
  36. package/dist/components/Form/Checkbox/CheckboxAndSwitchGroup.d.ts.map +1 -1
  37. package/dist/components/Form/Checkbox/CheckboxAndSwitchGroup.js +177 -0
  38. package/dist/components/Form/Checkbox/CheckboxAndSwitchGroup.js.map +1 -0
  39. package/dist/components/Form/Checkbox/Switch.d.ts.map +1 -1
  40. package/dist/components/Form/Checkbox/Switch.js +78 -0
  41. package/dist/components/Form/Checkbox/Switch.js.map +1 -0
  42. package/dist/components/Form/FileUpload/FileUpload.d.ts.map +1 -1
  43. package/dist/components/Form/FileUpload/FileUpload.js +142 -0
  44. package/dist/components/Form/FileUpload/FileUpload.js.map +1 -0
  45. package/dist/components/Form/Form/Form.js +37 -0
  46. package/dist/components/Form/Form/Form.js.map +1 -0
  47. package/dist/components/Form/Form/FormGenerator.js +64 -0
  48. package/dist/components/Form/Form/FormGenerator.js.map +1 -0
  49. package/dist/components/Form/FormItem/FormItem.d.ts +16 -0
  50. package/dist/components/Form/FormItem/FormItem.d.ts.map +1 -1
  51. package/dist/components/Form/FormItem/FormItem.js +127 -0
  52. package/dist/components/Form/FormItem/FormItem.js.map +1 -0
  53. package/dist/components/Form/FormItemGroup/FormItemGroup.js +42 -0
  54. package/dist/components/Form/FormItemGroup/FormItemGroup.js.map +1 -0
  55. package/dist/components/Form/InputField/InputField.d.ts.map +1 -1
  56. package/dist/components/Form/InputField/InputField.js +156 -0
  57. package/dist/components/Form/InputField/InputField.js.map +1 -0
  58. package/dist/components/Form/InputLabel/InputLabel.js +30 -0
  59. package/dist/components/Form/InputLabel/InputLabel.js.map +1 -0
  60. package/dist/components/Form/ListBox/ListBox.d.ts.map +1 -1
  61. package/dist/components/Form/ListBox/ListBox.js +284 -0
  62. package/dist/components/Form/ListBox/ListBox.js.map +1 -0
  63. package/dist/components/Form/ListBox/constants.d.ts +1 -1
  64. package/dist/components/Form/ListBox/constants.d.ts.map +1 -1
  65. package/dist/components/Form/ListBox/listBoxUtils.js +49 -0
  66. package/dist/components/Form/ListBox/listBoxUtils.js.map +1 -0
  67. package/dist/components/Form/PinInputField/PinInputField.d.ts +6 -1
  68. package/dist/components/Form/PinInputField/PinInputField.d.ts.map +1 -1
  69. package/dist/components/Form/PinInputField/PinInputField.js +165 -0
  70. package/dist/components/Form/PinInputField/PinInputField.js.map +1 -0
  71. package/dist/components/Form/RadioButton/RadioButton.d.ts.map +1 -1
  72. package/dist/components/Form/RadioButton/RadioButton.js +82 -0
  73. package/dist/components/Form/RadioButton/RadioButton.js.map +1 -0
  74. package/dist/components/Form/RadioButton/RadioGroup.d.ts.map +1 -1
  75. package/dist/components/Form/RadioButton/RadioGroup.js +97 -0
  76. package/dist/components/Form/RadioButton/RadioGroup.js.map +1 -0
  77. package/dist/components/Form/RadioButton/RadioTabGroup.d.ts.map +1 -1
  78. package/dist/components/Form/RadioButton/RadioTabGroup.js +182 -0
  79. package/dist/components/Form/RadioButton/RadioTabGroup.js.map +1 -0
  80. package/dist/components/Form/Range/Range.js +376 -0
  81. package/dist/components/Form/Range/Range.js.map +1 -0
  82. package/dist/components/Form/Select/Select.d.ts.map +1 -1
  83. package/dist/components/Form/Select/Select.js +83 -0
  84. package/dist/components/Form/Select/Select.js.map +1 -0
  85. package/dist/components/Form/TextArea/TextArea.d.ts.map +1 -1
  86. package/dist/components/Form/TextArea/TextArea.js +111 -0
  87. package/dist/components/Form/TextArea/TextArea.js.map +1 -0
  88. package/dist/components/Meter/Meter.js +110 -0
  89. package/dist/components/Meter/Meter.js.map +1 -0
  90. package/dist/components/Modal/Modal.d.ts.map +1 -1
  91. package/dist/components/Modal/Modal.js +75 -0
  92. package/dist/components/Modal/Modal.js.map +1 -0
  93. package/dist/components/Notification/NotificationItem/NotificationItem.d.ts.map +1 -1
  94. package/dist/components/Notification/NotificationItem/NotificationItem.js +70 -0
  95. package/dist/components/Notification/NotificationItem/NotificationItem.js.map +1 -0
  96. package/dist/components/Notification/NotificationsProvider/NotificationsProvider.js +88 -0
  97. package/dist/components/Notification/NotificationsProvider/NotificationsProvider.js.map +1 -0
  98. package/dist/components/Notification/NotificationsWrapper/NotificationsWrapper.d.ts.map +1 -1
  99. package/dist/components/Notification/NotificationsWrapper/NotificationsWrapper.js +35 -0
  100. package/dist/components/Notification/NotificationsWrapper/NotificationsWrapper.js.map +1 -0
  101. package/dist/components/OptionCard/OptionCard.js +150 -0
  102. package/dist/components/OptionCard/OptionCard.js.map +1 -0
  103. package/dist/components/Pagination/Pagination.d.ts.map +1 -1
  104. package/dist/components/Pagination/Pagination.js +206 -0
  105. package/dist/components/Pagination/Pagination.js.map +1 -0
  106. package/dist/components/Pagination/usePagination.js +35 -0
  107. package/dist/components/Pagination/usePagination.js.map +1 -0
  108. package/dist/components/Portion/Portion.js +34 -0
  109. package/dist/components/Portion/Portion.js.map +1 -0
  110. package/dist/components/ProgressBar/ProgressBar.js +63 -0
  111. package/dist/components/ProgressBar/ProgressBar.js.map +1 -0
  112. package/dist/components/Row/Row.js +40 -0
  113. package/dist/components/Row/Row.js.map +1 -0
  114. package/dist/components/Sidebar/ContentWrapper/ContentWrapper.js +23 -0
  115. package/dist/components/Sidebar/ContentWrapper/ContentWrapper.js.map +1 -0
  116. package/dist/components/Sidebar/SidebarFooter/SidebarFooter.js +25 -0
  117. package/dist/components/Sidebar/SidebarFooter/SidebarFooter.js.map +1 -0
  118. package/dist/components/Sidebar/SidebarHeader/SidebarHeader.js +25 -0
  119. package/dist/components/Sidebar/SidebarHeader/SidebarHeader.js.map +1 -0
  120. package/dist/components/Sidebar/SidebarItem/SidebarItem.js +30 -0
  121. package/dist/components/Sidebar/SidebarItem/SidebarItem.js.map +1 -0
  122. package/dist/components/Sidebar/SidebarItemsGroup/SidebarItemsGroup.js +29 -0
  123. package/dist/components/Sidebar/SidebarItemsGroup/SidebarItemsGroup.js.map +1 -0
  124. package/dist/components/Sidebar/SidebarWrapper/SidebarWrapper.d.ts.map +1 -1
  125. package/dist/components/Sidebar/SidebarWrapper/SidebarWrapper.js +35 -0
  126. package/dist/components/Sidebar/SidebarWrapper/SidebarWrapper.js.map +1 -0
  127. package/dist/components/Skeleton/Skeleton.js +84 -0
  128. package/dist/components/Skeleton/Skeleton.js.map +1 -0
  129. package/dist/components/Spinner/Spinner.js +33 -0
  130. package/dist/components/Spinner/Spinner.js.map +1 -0
  131. package/dist/components/Table/Table.js +53 -0
  132. package/dist/components/Table/Table.js.map +1 -0
  133. package/dist/components/Tabs/Tabs.d.ts.map +1 -1
  134. package/dist/components/Tabs/Tabs.js +104 -0
  135. package/dist/components/Tabs/Tabs.js.map +1 -0
  136. package/dist/components/ThemeProvider/ThemeProvider.d.ts +6 -0
  137. package/dist/components/ThemeProvider/ThemeProvider.d.ts.map +1 -1
  138. package/dist/components/ThemeProvider/ThemeProvider.js +52 -0
  139. package/dist/components/ThemeProvider/ThemeProvider.js.map +1 -0
  140. package/dist/components/Toast/ToastItem/ToastItem.js +47 -0
  141. package/dist/components/Toast/ToastItem/ToastItem.js.map +1 -0
  142. package/dist/components/Toast/ToastsProvider/ToastsProvider.js +45 -0
  143. package/dist/components/Toast/ToastsProvider/ToastsProvider.js.map +1 -0
  144. package/dist/components/Toast/ToastsWrapper/ToastsWrapper.d.ts.map +1 -1
  145. package/dist/components/Toast/ToastsWrapper/ToastsWrapper.js +28 -0
  146. package/dist/components/Toast/ToastsWrapper/ToastsWrapper.js.map +1 -0
  147. package/dist/components/Tooltip/Tooltip.d.ts +1 -1
  148. package/dist/components/Tooltip/Tooltip.d.ts.map +1 -1
  149. package/dist/components/Tooltip/Tooltip.js +62 -0
  150. package/dist/components/Tooltip/Tooltip.js.map +1 -0
  151. package/dist/components/Typography/Heading.js +30 -0
  152. package/dist/components/Typography/Heading.js.map +1 -0
  153. package/dist/components/Typography/Text.js +15 -0
  154. package/dist/components/Typography/Text.js.map +1 -0
  155. package/dist/components/index.js +124 -75
  156. package/dist/components/index.js.map +1 -1
  157. package/dist/fictoan-schema.json +2070 -0
  158. package/dist/hooks/UseClickOutside.js +17 -0
  159. package/dist/hooks/UseClickOutside.js.map +1 -0
  160. package/dist/hooks/UseViewTransition.d.ts +2 -0
  161. package/dist/hooks/UseViewTransition.d.ts.map +1 -0
  162. package/dist/hooks/UseViewTransition.js +17 -0
  163. package/dist/hooks/UseViewTransition.js.map +1 -0
  164. package/dist/index.css +6 -10661
  165. package/dist/index.d.ts +1 -0
  166. package/dist/index.d.ts.map +1 -1
  167. package/dist/index.js +142 -151
  168. package/dist/index.js.map +1 -1
  169. package/dist/scripts/generateSchema.d.ts +2 -0
  170. package/dist/scripts/generateSchema.d.ts.map +1 -0
  171. package/dist/scripts/schema-meta.d.ts +12 -0
  172. package/dist/scripts/schema-meta.d.ts.map +1 -0
  173. package/dist/styles/colours.js +55 -0
  174. package/dist/styles/colours.js.map +1 -0
  175. package/dist/utils/classNames.js +6 -0
  176. package/dist/utils/classNames.js.map +1 -0
  177. package/dist/utils/propSeparation.js +77 -0
  178. package/dist/utils/propSeparation.js.map +1 -0
  179. package/package.json +12 -18
  180. package/dist/Accordion-CeGNgNW8.js +0 -4254
  181. package/dist/Accordion-CeGNgNW8.js.map +0 -1
@@ -0,0 +1,284 @@
1
+ "use client";
2
+ import { jsx as a, jsxs as u, Fragment as de } from "react/jsx-runtime";
3
+ import N, { useState as k, useRef as R, useEffect as E } from "react";
4
+ import { Div as f } from "../../Element/Tags.js";
5
+ import { useClickOutside as pe } from "../../../hooks/UseClickOutside.js";
6
+ import { separateWrapperProps as ue } from "../../../utils/propSeparation.js";
7
+ /* empty css */
8
+ import { Badge as me } from "../../Badge/Badge.js";
9
+ import { deriveAriaIds as fe, FormItem as be } from "../FormItem/FormItem.js";
10
+ import { InputField as xe } from "../InputField/InputField.js";
11
+ import { Text as F } from "../../Typography/Text.js";
12
+ import { searchOptions as he } from "./listBoxUtils.js";
13
+ import { Element as W } from "../../Element/Element.js";
14
+ const ve = N.forwardRef(
15
+ ({
16
+ options: H = [],
17
+ label: Y,
18
+ helpText: P,
19
+ errorText: D,
20
+ placeholder: V = "Select an option",
21
+ id: G,
22
+ defaultValue: J,
23
+ onChange: t,
24
+ disabled: h,
25
+ selectionLimit: b,
26
+ allowMultiSelect: v = !1,
27
+ allowCustomEntries: w = !1,
28
+ isLoading: Q,
29
+ value: L,
30
+ isFullWidth: U,
31
+ className: T,
32
+ required: j,
33
+ size: X,
34
+ ...Z
35
+ }, we) => {
36
+ const [i, x] = k(!1), [m, z] = k(""), [c, n] = k(-1), [_, K] = k(!1), I = N.useMemo(() => [...H], [H]), q = N.useCallback(
37
+ (e, s) => e == null || e === "" ? [] : (Array.isArray(e) ? e : [e]).map((o) => s.find((B) => B.value === o)).filter((o) => o !== void 0),
38
+ []
39
+ ), S = L !== void 0, [M, g] = k(
40
+ () => q(J, I)
41
+ ), r = S ? q(L, I) : M, y = N.useCallback((e) => {
42
+ S || g(e);
43
+ }, [S]), O = R(null), A = R(null), C = R(null), ee = N.useId(), d = G || `listbox-${ee.replace(/:/g, "")}`, { describedBy: se } = fe(d, P, D), p = he(I, m), ae = c >= 0 && p[c] ? `${d}-option-${p[c].value}` : void 0, $ = (e) => {
44
+ if (e.disabled) return;
45
+ let s;
46
+ if (v) {
47
+ if (r.some((o) => o.value === e.value))
48
+ s = r.filter((o) => o.value !== e.value);
49
+ else {
50
+ if (b && r.length >= b)
51
+ return;
52
+ s = [...r, e];
53
+ }
54
+ y(s), t == null || t(s.map((o) => o.value));
55
+ } else
56
+ s = [e], y(s), t == null || t(e.value), x(!1);
57
+ z(""), n(-1);
58
+ }, te = (e) => {
59
+ z(e);
60
+ }, re = () => {
61
+ if (!m.trim() || !w) return;
62
+ const e = m.trim(), s = {
63
+ value: e,
64
+ label: e
65
+ };
66
+ I.some((l) => l.value === e) || $(s);
67
+ }, le = (e) => {
68
+ if (v) {
69
+ const s = r.filter((l) => l.value !== e);
70
+ y(s), t == null || t(s.map((l) => l.value));
71
+ } else
72
+ y([]), t == null || t("");
73
+ }, ie = () => {
74
+ y([]), t == null || t(v ? [] : "");
75
+ }, oe = (e) => {
76
+ switch (e.key) {
77
+ case "ArrowDown":
78
+ e.preventDefault(), i ? n(
79
+ (s) => s < p.length - 1 ? s + 1 : s
80
+ ) : (x(!0), n(0));
81
+ break;
82
+ case "ArrowUp":
83
+ e.preventDefault(), n((s) => s > 0 ? s - 1 : s);
84
+ break;
85
+ case "Enter":
86
+ if (e.preventDefault(), w && m.trim()) {
87
+ const s = p.find(
88
+ (l) => l.label.toLowerCase() === m.trim().toLowerCase()
89
+ );
90
+ s ? $(s) : re();
91
+ } else c >= 0 && p[c] && $(p[c]);
92
+ break;
93
+ case "Escape":
94
+ e.preventDefault(), x(!1), n(-1);
95
+ break;
96
+ case " ":
97
+ i || (e.preventDefault(), x(!0), n(0));
98
+ break;
99
+ case "Home":
100
+ i && (e.preventDefault(), n(0));
101
+ break;
102
+ case "End":
103
+ i && (e.preventDefault(), n(p.length - 1));
104
+ break;
105
+ }
106
+ };
107
+ pe(O, () => {
108
+ x(!1), n(-1);
109
+ }), E(() => {
110
+ i && A.current && A.current.focus();
111
+ }, [i]), E(() => {
112
+ if (i && O.current) {
113
+ const e = O.current.getBoundingClientRect(), s = window.innerHeight, l = 300, o = s - e.bottom, B = e.top;
114
+ K(o < l && B > o);
115
+ } else
116
+ K(!1);
117
+ }, [i]), E(() => {
118
+ if (c >= 0) {
119
+ const e = document.querySelector(`[data-index="${c}"]`);
120
+ e == null || e.scrollIntoView({ block: "nearest" });
121
+ }
122
+ }, [c]);
123
+ const { wrapperProps: ce, inputProps: ne } = ue(Z);
124
+ return /* @__PURE__ */ a(
125
+ be,
126
+ {
127
+ label: Y,
128
+ htmlFor: d,
129
+ helpText: P,
130
+ errorText: D,
131
+ required: j,
132
+ isFullWidth: U,
133
+ size: X,
134
+ ...ce,
135
+ children: /* @__PURE__ */ u(
136
+ W,
137
+ {
138
+ as: "div",
139
+ "data-list-box": !0,
140
+ classNames: ["list-box-wrapper", h ? "disabled" : "", T || ""],
141
+ ref: O,
142
+ isFullWidth: U,
143
+ ...ne,
144
+ children: [
145
+ /* @__PURE__ */ u(
146
+ f,
147
+ {
148
+ className: "list-box-input-wrapper",
149
+ id: d,
150
+ onClick: () => !h && x(!i),
151
+ role: "combobox",
152
+ "aria-haspopup": "listbox",
153
+ "aria-expanded": i,
154
+ "aria-controls": `${d}-listbox`,
155
+ "aria-owns": `${d}-listbox`,
156
+ "aria-activedescendant": i ? ae : void 0,
157
+ "aria-invalid": !!D || void 0,
158
+ "aria-required": j,
159
+ "aria-describedby": se,
160
+ "aria-disabled": h || void 0,
161
+ tabIndex: h ? -1 : 0,
162
+ children: [
163
+ v ? /* @__PURE__ */ u(de, { children: [
164
+ r.length > 0 ? /* @__PURE__ */ u(f, { className: "options-wrapper", children: [
165
+ /* @__PURE__ */ a(f, { className: "options-list", children: r.map((e) => /* @__PURE__ */ a(
166
+ me,
167
+ {
168
+ actionIcon: "cross",
169
+ onActionClick: () => le(e.value),
170
+ actionAriaLabel: `Remove ${e.label}`,
171
+ size: "small",
172
+ shape: "rounded",
173
+ children: /* @__PURE__ */ a(F, { children: e.label })
174
+ },
175
+ e.value
176
+ )) }),
177
+ b && r.length >= b && /* @__PURE__ */ u(F, { className: "options-limit-warning", textColour: "red", size: "tiny", children: [
178
+ "You can choose only ",
179
+ b,
180
+ " option",
181
+ b === 1 ? "" : "s"
182
+ ] })
183
+ ] }) : /* @__PURE__ */ a("span", { className: "placeholder", children: V }),
184
+ r.length > 0 && /* @__PURE__ */ a(
185
+ f,
186
+ {
187
+ className: "icon-wrapper clear-all",
188
+ title: "Clear all options",
189
+ onClick: () => ie(),
190
+ children: /* @__PURE__ */ u("svg", { viewBox: "0 0 24 24", children: [
191
+ /* @__PURE__ */ a("line", { x1: "5", y1: "5", x2: "19", y2: "19" }),
192
+ /* @__PURE__ */ a("line", { x1: "5", y1: "19", x2: "19", y2: "5" })
193
+ ] })
194
+ }
195
+ )
196
+ ] }) : r[0] ? /* @__PURE__ */ a(F, { className: "selected-option", children: r[0].label }) : /* @__PURE__ */ a("span", { className: "placeholder", children: V }),
197
+ /* @__PURE__ */ a(f, { className: "icon-wrapper chevrons", children: /* @__PURE__ */ u("svg", { viewBox: "0 0 24 24", "aria-hidden": "true", children: [
198
+ /* @__PURE__ */ a("polyline", { points: "6 9 12 4 18 9" }),
199
+ /* @__PURE__ */ a("polyline", { points: "6 15 12 20 18 15" })
200
+ ] }) })
201
+ ]
202
+ }
203
+ ),
204
+ i && !h && /* @__PURE__ */ u(
205
+ f,
206
+ {
207
+ ref: C,
208
+ className: `list-box-dropdown${_ ? " opens-upward" : ""}`,
209
+ children: [
210
+ /* @__PURE__ */ u(f, { className: "list-box-search-wrapper", children: [
211
+ /* @__PURE__ */ a(
212
+ xe,
213
+ {
214
+ type: "text",
215
+ ref: A,
216
+ className: "list-box-search",
217
+ placeholder: w ? "Type to search or add new" : "Search",
218
+ value: m,
219
+ onChange: te,
220
+ onKeyDown: oe,
221
+ "aria-controls": `${d}-listbox`,
222
+ "aria-label": "Search options",
223
+ isFullWidth: !0
224
+ }
225
+ ),
226
+ w && m.trim() && !r.some((e) => e.label.toLowerCase() === m.trim().toLowerCase()) && /* @__PURE__ */ a(
227
+ "kbd",
228
+ {
229
+ className: "list-box-enter-key",
230
+ "aria-label": "Press Enter to add custom option",
231
+ children: "↵"
232
+ }
233
+ )
234
+ ] }),
235
+ /* @__PURE__ */ a(
236
+ W,
237
+ {
238
+ as: "ul",
239
+ id: `${d}-listbox`,
240
+ className: "list-box-options",
241
+ role: "listbox",
242
+ "aria-multiselectable": v,
243
+ "aria-busy": Q,
244
+ tabIndex: -1,
245
+ children: p.length > 0 ? p.map((e, s) => /* @__PURE__ */ a(
246
+ "li",
247
+ {
248
+ id: `${d}-option-${e.value}`,
249
+ className: `list-box-option ${e.disabled ? "disabled" : ""} ${c === s ? "active" : ""}`,
250
+ role: "option",
251
+ "aria-selected": r.some((l) => l.value === e.value),
252
+ "aria-disabled": e.disabled,
253
+ onClick: () => $(e),
254
+ "data-index": s,
255
+ tabIndex: -1,
256
+ children: e.customLabel || e.label
257
+ },
258
+ e.value
259
+ )) : /* @__PURE__ */ a(
260
+ "li",
261
+ {
262
+ className: "list-box-option disabled",
263
+ role: "alert",
264
+ "aria-live": "polite",
265
+ children: w ? "Type and press Enter to add new option" : "No matches found"
266
+ }
267
+ )
268
+ }
269
+ )
270
+ ]
271
+ }
272
+ )
273
+ ]
274
+ }
275
+ )
276
+ }
277
+ );
278
+ }
279
+ );
280
+ ve.displayName = "ListBox";
281
+ export {
282
+ ve as ListBox
283
+ };
284
+ //# sourceMappingURL=ListBox.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ListBox.js","sources":["../../../../src/components/Form/ListBox/ListBox.tsx"],"sourcesContent":["// REACT CORE ==========================================================================================================\nimport React, { useState, useRef, useEffect, MutableRefObject, KeyboardEvent } from \"react\";\n\n// LOCAL COMPONENTS ====================================================================================================\nimport { Div } from \"$tags\";\nimport { Element } from \"$element\";\n\n// HOOKS ===============================================================================================================\nimport { useClickOutside } from \"$hooks/UseClickOutside\";\n\n// UTILS ===============================================================================================================\nimport { separateWrapperProps } from \"$utils/propSeparation\";\n\n// STYLES ==============================================================================================================\nimport \"./list-box.css\";\n\n// OTHER ===============================================================================================================\nimport { Badge } from \"../../Badge/Badge\";\nimport { FormItem, deriveAriaIds } from \"../FormItem/FormItem\";\nimport { InputField } from \"../InputField/InputField\";\nimport { ListBoxProps, OptionForListBoxProps, ListBoxElementType, ListBoxCustomProps } from \"./constants\";\nimport { Text } from \"../../Typography/Text\";\nimport { searchOptions } from \"./listBoxUtils\";\n\n// COMPONENT ///////////////////////////////////////////////////////////////////////////////////////////////////////////\nexport const ListBox = React.forwardRef<ListBoxElementType, ListBoxProps>(\n (\n {\n options = [],\n label,\n helpText,\n errorText,\n placeholder = \"Select an option\",\n id,\n defaultValue,\n onChange,\n disabled,\n selectionLimit,\n allowMultiSelect = false,\n allowCustomEntries = false,\n isLoading,\n value,\n isFullWidth,\n className,\n required,\n size,\n ...props\n },\n ref\n ) => {\n const [isOpen, setIsOpen] = useState(false);\n const [searchValue, setSearchValue] = useState(\"\");\n const [activeIndex, setActiveIndex] = useState(-1);\n const [openUpward, setOpenUpward] = useState(false);\n\n // Create a memoized version of the combined options\n const allOptions = React.useMemo(() => {\n return [...options];\n }, [options]);\n\n // Map a value or array of values to the matching option objects.\n const resolveSelectedOptions = React.useCallback(\n (val : string | string[] | undefined, opts : OptionForListBoxProps[]) : OptionForListBoxProps[] => {\n if (val == null || val === \"\") return [];\n const values = Array.isArray(val) ? val : [val];\n return values\n .map(v => opts.find(o => o.value === v))\n .filter((o) : o is OptionForListBoxProps => o !== undefined);\n },\n [],\n );\n\n // Internal state for uncontrolled mode. Lazy init from defaultValue so the\n // displayed selection is correct on first paint — no spurious onChange fires.\n const isControlled = value !== undefined;\n const [internalSelectedOptions, setInternalSelectedOptions] = useState<OptionForListBoxProps[]>(\n () => resolveSelectedOptions(defaultValue, allOptions),\n );\n\n // The effective selection: controlled value takes precedence, otherwise internal state.\n const selectedOptions = isControlled\n ? resolveSelectedOptions(value, allOptions)\n : internalSelectedOptions;\n\n const setSelectedOptions = React.useCallback((next : OptionForListBoxProps[]) => {\n if (!isControlled) setInternalSelectedOptions(next);\n }, [ isControlled ]);\n\n // The list-box wrapper renders as a <div>, not a <select> — the prior\n // HTMLSelectElement typing was a pre-existing mistake that only got\n // caught when Element's ref type tightened.\n const dropdownRef = useRef<HTMLDivElement>(null) as MutableRefObject<HTMLDivElement>;\n const searchInputRef = useRef<HTMLInputElement>(null);\n const dropdownMenuRef = useRef<HTMLDivElement>(null);\n\n const reactId = React.useId();\n const listboxId = id || `listbox-${reactId.replace(/:/g, \"\")}`;\n const { describedBy } = deriveAriaIds(listboxId, helpText, errorText);\n const filteredOptions = searchOptions(allOptions, searchValue);\n const activeOptionId = activeIndex >= 0 && filteredOptions[activeIndex]\n ? `${listboxId}-option-${filteredOptions[activeIndex].value}`\n : undefined;\n\n const handleSelectOption = (option: OptionForListBoxProps) => {\n if (option.disabled) return;\n\n let newSelectedOptions: OptionForListBoxProps[];\n if (allowMultiSelect) {\n const isSelected = selectedOptions.some(opt => opt.value === option.value);\n if (isSelected) {\n newSelectedOptions = selectedOptions.filter(opt => opt.value !== option.value);\n } else {\n if (selectionLimit && selectedOptions.length >= selectionLimit) {\n return;\n }\n newSelectedOptions = [...selectedOptions, option];\n }\n setSelectedOptions(newSelectedOptions);\n onChange?.(newSelectedOptions.map(opt => opt.value));\n } else {\n newSelectedOptions = [option];\n setSelectedOptions(newSelectedOptions);\n onChange?.(option.value);\n setIsOpen(false);\n }\n\n setSearchValue(\"\");\n setActiveIndex(-1);\n };\n\n const handleSearchChange = (value: string) => {\n setSearchValue(value);\n };\n\n const handleCustomEntry = () => {\n if (!searchValue.trim() || !allowCustomEntries) return;\n\n const customValue = searchValue.trim();\n const customOption: OptionForListBoxProps = {\n value: customValue,\n label: customValue,\n };\n\n // If this option doesn't exist yet\n if (!allOptions.some(opt => opt.value === customValue)) {\n handleSelectOption(customOption);\n }\n };\n\n const handleDeleteOption = (valueToRemove: string) => {\n if (allowMultiSelect) {\n // Filter out the option to remove\n const newSelectedOptions = selectedOptions.filter(opt => opt.value !== valueToRemove);\n\n // Update local state\n setSelectedOptions(newSelectedOptions);\n\n // Notify parent\n onChange?.(newSelectedOptions.map(opt => opt.value));\n } else {\n // For single-select mode, just clear everything\n setSelectedOptions([]);\n onChange?.(\"\");\n }\n };\n\n const handleClearAll = () => {\n // Reset local state for both single and multi-select\n setSelectedOptions([]);\n\n // Notify parent with empty data\n onChange?.(allowMultiSelect ? [] : \"\");\n };\n\n const handleKeyDown = (event: KeyboardEvent) => {\n switch (event.key) {\n case \"ArrowDown\":\n event.preventDefault();\n if (!isOpen) {\n setIsOpen(true);\n setActiveIndex(0);\n } else {\n setActiveIndex(prev =>\n prev < filteredOptions.length - 1 ? prev + 1 : prev\n );\n }\n break;\n\n case \"ArrowUp\":\n event.preventDefault();\n setActiveIndex(prev => prev > 0 ? prev - 1 : prev);\n break;\n\n case \"Enter\":\n event.preventDefault();\n if (allowCustomEntries && searchValue.trim()) {\n const exactMatch = filteredOptions.find(opt =>\n opt.label.toLowerCase() === searchValue.trim().toLowerCase()\n );\n if (exactMatch) {\n handleSelectOption(exactMatch);\n } else {\n handleCustomEntry();\n }\n } else if (activeIndex >= 0 && filteredOptions[activeIndex]) {\n handleSelectOption(filteredOptions[activeIndex]);\n }\n break;\n\n case \"Escape\":\n event.preventDefault();\n setIsOpen(false);\n setActiveIndex(-1);\n break;\n\n case \" \": // Space key\n if (!isOpen) {\n event.preventDefault();\n setIsOpen(true);\n setActiveIndex(0);\n }\n break;\n\n case \"Home\":\n if (isOpen) {\n event.preventDefault();\n setActiveIndex(0);\n }\n break;\n\n case \"End\":\n if (isOpen) {\n event.preventDefault();\n setActiveIndex(filteredOptions.length - 1);\n }\n break;\n }\n };\n\n useClickOutside(dropdownRef, () => {\n setIsOpen(false);\n setActiveIndex(-1);\n });\n\n useEffect(() => {\n if (isOpen && searchInputRef.current) {\n searchInputRef.current.focus();\n }\n }, [isOpen]);\n\n // Determine if dropdown should open upward based on available viewport space\n useEffect(() => {\n if (isOpen && dropdownRef.current) {\n const wrapperRect = dropdownRef.current.getBoundingClientRect();\n const viewportHeight = window.innerHeight;\n // Estimate dropdown height (max-height is 240px for options + search + padding)\n const estimatedDropdownHeight = 300;\n const spaceBelow = viewportHeight - wrapperRect.bottom;\n const spaceAbove = wrapperRect.top;\n\n // Open upward if not enough space below but enough space above\n setOpenUpward(spaceBelow < estimatedDropdownHeight && spaceAbove > spaceBelow);\n } else {\n setOpenUpward(false);\n }\n }, [isOpen]);\n\n useEffect(() => {\n if (activeIndex >= 0) {\n const activeOption = document.querySelector(`[data-index=\"${activeIndex}\"]`);\n activeOption?.scrollIntoView({ block: \"nearest\" });\n }\n }, [activeIndex]);\n\n // Separate wrapper-level props (margin, padding, etc.) from input-specific props\n const { wrapperProps, inputProps } = separateWrapperProps(props);\n\n return (\n <FormItem\n label={label}\n htmlFor={listboxId}\n helpText={helpText}\n errorText={errorText}\n required={required}\n isFullWidth={isFullWidth}\n size={size}\n {...wrapperProps}\n >\n {/* PARENT */}\n <Element\n as=\"div\"\n data-list-box\n classNames={[\"list-box-wrapper\", disabled ? \"disabled\" : \"\", className || \"\"]}\n ref={dropdownRef}\n isFullWidth={isFullWidth}\n {...inputProps}\n >\n <Div\n className=\"list-box-input-wrapper\"\n id={listboxId}\n onClick={() => !disabled && setIsOpen(!isOpen)}\n role=\"combobox\"\n aria-haspopup=\"listbox\"\n aria-expanded={isOpen}\n aria-controls={`${listboxId}-listbox`}\n aria-owns={`${listboxId}-listbox`}\n aria-activedescendant={isOpen ? activeOptionId : undefined}\n aria-invalid={Boolean(errorText) || undefined}\n aria-required={required}\n aria-describedby={describedBy}\n aria-disabled={disabled || undefined}\n tabIndex={disabled ? -1 : 0}\n >\n {allowMultiSelect ? (\n <>\n {selectedOptions.length > 0 ? (\n <Div className=\"options-wrapper\">\n <Div className=\"options-list\">\n {selectedOptions.map(option => (\n <Badge\n key={option.value}\n actionIcon=\"cross\"\n onActionClick={() => handleDeleteOption(option.value)}\n actionAriaLabel={`Remove ${option.label}`}\n size=\"small\"\n shape=\"rounded\"\n >\n <Text>{option.label}</Text>\n </Badge>\n ))}\n </Div>\n {selectionLimit && selectedOptions.length >= selectionLimit && (\n <Text className=\"options-limit-warning\" textColour=\"red\" size=\"tiny\">\n You can choose only {selectionLimit} option{selectionLimit === 1 ? \"\" : \"s\"}\n </Text>\n )}\n </Div>\n ) : (\n <span className=\"placeholder\">{placeholder}</span>\n )}\n\n {/* Clear button for multi-select */}\n {selectedOptions.length > 0 && (\n <Div\n className=\"icon-wrapper clear-all\"\n title=\"Clear all options\"\n onClick={() => handleClearAll()}\n >\n <svg viewBox=\"0 0 24 24\">\n <line x1=\"5\" y1=\"5\" x2=\"19\" y2=\"19\" />\n <line x1=\"5\" y1=\"19\" x2=\"19\" y2=\"5\" />\n </svg>\n </Div>\n )}\n </>\n ) : (\n selectedOptions[0]\n ? <Text className=\"selected-option\">{selectedOptions[0].label}</Text>\n : <span className=\"placeholder\">{placeholder}</span>\n )}\n\n <Div className=\"icon-wrapper chevrons\">\n <svg viewBox=\"0 0 24 24\" aria-hidden=\"true\">\n <polyline points=\"6 9 12 4 18 9\"></polyline>\n <polyline points=\"6 15 12 20 18 15\"></polyline>\n </svg>\n </Div>\n </Div>\n\n {/* DROPDOWN */}\n {isOpen && !disabled && (\n <Div\n ref={dropdownMenuRef}\n className={`list-box-dropdown${openUpward ? \" opens-upward\" : \"\"}`}\n >\n <Div className=\"list-box-search-wrapper\">\n <InputField\n type=\"text\"\n ref={searchInputRef}\n className=\"list-box-search\"\n placeholder={allowCustomEntries ? \"Type to search or add new\" : \"Search\"}\n value={searchValue}\n onChange={handleSearchChange}\n onKeyDown={handleKeyDown}\n aria-controls={`${listboxId}-listbox`}\n aria-label=\"Search options\"\n isFullWidth\n />\n {allowCustomEntries && searchValue.trim() && !selectedOptions.some(opt =>\n opt.label.toLowerCase() === searchValue.trim().toLowerCase()) && (\n <kbd\n className=\"list-box-enter-key\"\n aria-label=\"Press Enter to add custom option\"\n >\n ↵\n </kbd>\n )}\n </Div>\n\n {/* OPTIONS */}\n <Element\n as=\"ul\"\n id={`${listboxId}-listbox`}\n className=\"list-box-options\"\n role=\"listbox\"\n aria-multiselectable={allowMultiSelect}\n aria-busy={isLoading}\n tabIndex={-1}\n >\n {filteredOptions.length > 0 ? (\n filteredOptions.map((option, index) => (\n <li\n key={option.value}\n id={`${listboxId}-option-${option.value}`}\n className={`list-box-option ${option.disabled ? \"disabled\" : \"\"} ${activeIndex === index ? \"active\" : \"\"}`}\n role=\"option\"\n aria-selected={selectedOptions.some(opt => opt.value === option.value)}\n aria-disabled={option.disabled}\n onClick={() => handleSelectOption(option)}\n data-index={index}\n tabIndex={-1}\n >\n {option.customLabel || option.label}\n </li>\n ))\n ) : (\n <li\n className=\"list-box-option disabled\"\n role=\"alert\"\n aria-live=\"polite\"\n >\n {allowCustomEntries\n ? \"Type and press Enter to add new option\"\n : \"No matches found\"\n }\n </li>\n )}\n </Element>\n </Div>\n )}\n </Element>\n </FormItem>\n );\n }\n);\nListBox.displayName = \"ListBox\";\n"],"names":["ListBox","React","options","label","helpText","errorText","placeholder","id","defaultValue","onChange","disabled","selectionLimit","allowMultiSelect","allowCustomEntries","isLoading","value","isFullWidth","className","required","size","props","ref","isOpen","setIsOpen","useState","searchValue","setSearchValue","activeIndex","setActiveIndex","openUpward","setOpenUpward","allOptions","resolveSelectedOptions","val","opts","v","o","isControlled","internalSelectedOptions","setInternalSelectedOptions","selectedOptions","setSelectedOptions","next","dropdownRef","useRef","searchInputRef","dropdownMenuRef","reactId","listboxId","describedBy","deriveAriaIds","filteredOptions","searchOptions","activeOptionId","handleSelectOption","option","newSelectedOptions","opt","handleSearchChange","handleCustomEntry","customValue","customOption","handleDeleteOption","valueToRemove","handleClearAll","handleKeyDown","event","prev","exactMatch","useClickOutside","useEffect","wrapperRect","viewportHeight","estimatedDropdownHeight","spaceBelow","spaceAbove","activeOption","wrapperProps","inputProps","separateWrapperProps","jsx","FormItem","jsxs","Element","Div","Fragment","Badge","Text","InputField","index"],"mappings":"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"}
@@ -19,7 +19,7 @@ export interface ListBoxCustomProps {
19
19
  disabled?: boolean;
20
20
  placeholder?: string;
21
21
  id?: string;
22
- defaultValue?: string;
22
+ defaultValue?: string | string[];
23
23
  selectionLimit?: NonZeroNumber;
24
24
  allowCustomEntries?: boolean;
25
25
  isLoading?: boolean;
@@ -1 +1 @@
1
- {"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../../../../src/components/Form/ListBox/constants.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,OAAO,EAAE,kBAAkB,EAAE,YAAY,EAAE,MAAM,+BAA+B,CAAC;AAGjF,MAAM,MAAM,kBAAkB,CAAC,CAAC,GAAG,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC,KAAK,IAAI,CAAC;AAChE,MAAM,WAAW,qBAAqB;IAClC,KAAK,EAAW,MAAM,CAAC;IACvB,KAAK,EAAW,MAAM,CAAC;IACvB,WAAY,CAAC,EAAG,KAAK,CAAC,SAAS,CAAC;IAChC,QAAY,CAAC,EAAG,OAAO,CAAC;CAC3B;AAED,MAAM,MAAM,kBAAkB,GAAG,cAAc,CAAC;AAEhD,KAAK,aAAa,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;AAExC,MAAM,WAAW,kBAAkB;IAC/B,OAAmB,CAAC,EAAG,qBAAqB,EAAE,CAAC;IAC/C,KAAmB,CAAC,EAAG,MAAM,CAAC;IAC9B,QAAmB,CAAC,EAAG,MAAM,CAAC;IAC9B,SAAmB,CAAC,EAAG,MAAM,CAAC;IAC9B,gBAAmB,CAAC,EAAG,OAAO,CAAC;IAC/B,QAAmB,CAAC,EAAG,OAAO,CAAC;IAC/B,WAAmB,CAAC,EAAG,MAAM,CAAC;IAC9B,EAAmB,CAAC,EAAG,MAAM,CAAC;IAC9B,YAAmB,CAAC,EAAG,MAAM,CAAC;IAC9B,cAAmB,CAAC,EAAG,aAAa,CAAC;IACrC,kBAAmB,CAAC,EAAG,OAAO,CAAC;IAC/B,SAAmB,CAAC,EAAG,OAAO,CAAC;IAC/B,QAAmB,CAAC,EAAG,kBAAkB,CAAC,MAAM,GAAG,MAAM,EAAE,CAAC,CAAC;IAC7D,KAAmB,CAAC,EAAG,MAAM,GAAG,MAAM,EAAE,CAAC;IACzC,WAAmB,CAAC,EAAG,OAAO,CAAC;IAC/B,IAAmB,CAAC,EAAG,OAAO,CAAC,YAAY,EAAE,MAAM,GAAG,MAAM,CAAC,CAAC;CACjE;AAED,MAAM,MAAM,YAAY,GACpB,IAAI,CAAC,kBAAkB,CAAC,kBAAkB,CAAC,EAAE,MAAM,kBAAkB,GAAG,MAAM,CAAC,GAC7E,kBAAkB,CAAC"}
1
+ {"version":3,"file":"constants.d.ts","sourceRoot":"","sources":["../../../../src/components/Form/ListBox/constants.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,OAAO,EAAE,kBAAkB,EAAE,YAAY,EAAE,MAAM,+BAA+B,CAAC;AAGjF,MAAM,MAAM,kBAAkB,CAAC,CAAC,GAAG,MAAM,IAAI,CAAC,KAAK,EAAE,CAAC,KAAK,IAAI,CAAC;AAChE,MAAM,WAAW,qBAAqB;IAClC,KAAK,EAAW,MAAM,CAAC;IACvB,KAAK,EAAW,MAAM,CAAC;IACvB,WAAY,CAAC,EAAG,KAAK,CAAC,SAAS,CAAC;IAChC,QAAY,CAAC,EAAG,OAAO,CAAC;CAC3B;AAED,MAAM,MAAM,kBAAkB,GAAG,cAAc,CAAC;AAEhD,KAAK,aAAa,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;AAExC,MAAM,WAAW,kBAAkB;IAC/B,OAAmB,CAAC,EAAG,qBAAqB,EAAE,CAAC;IAC/C,KAAmB,CAAC,EAAG,MAAM,CAAC;IAC9B,QAAmB,CAAC,EAAG,MAAM,CAAC;IAC9B,SAAmB,CAAC,EAAG,MAAM,CAAC;IAC9B,gBAAmB,CAAC,EAAG,OAAO,CAAC;IAC/B,QAAmB,CAAC,EAAG,OAAO,CAAC;IAC/B,WAAmB,CAAC,EAAG,MAAM,CAAC;IAC9B,EAAmB,CAAC,EAAG,MAAM,CAAC;IAC9B,YAAmB,CAAC,EAAG,MAAM,GAAG,MAAM,EAAE,CAAC;IACzC,cAAmB,CAAC,EAAG,aAAa,CAAC;IACrC,kBAAmB,CAAC,EAAG,OAAO,CAAC;IAC/B,SAAmB,CAAC,EAAG,OAAO,CAAC;IAC/B,QAAmB,CAAC,EAAG,kBAAkB,CAAC,MAAM,GAAG,MAAM,EAAE,CAAC,CAAC;IAC7D,KAAmB,CAAC,EAAG,MAAM,GAAG,MAAM,EAAE,CAAC;IACzC,WAAmB,CAAC,EAAG,OAAO,CAAC;IAC/B,IAAmB,CAAC,EAAG,OAAO,CAAC,YAAY,EAAE,MAAM,GAAG,MAAM,CAAC,CAAC;CACjE;AAED,MAAM,MAAM,YAAY,GACpB,IAAI,CAAC,kBAAkB,CAAC,kBAAkB,CAAC,EAAE,MAAM,kBAAkB,GAAG,MAAM,CAAC,GAC7E,kBAAkB,CAAC"}
@@ -0,0 +1,49 @@
1
+ "use client";
2
+ const M = (r, i) => {
3
+ const n = [], s = r.length, c = i.length;
4
+ if (s === 0) return c;
5
+ if (c === 0) return s;
6
+ for (let t = 0; t <= c; t++)
7
+ n[t] = [t];
8
+ for (let t = 0; t <= s; t++)
9
+ n[0][t] = t;
10
+ for (let t = 1; t <= c; t++)
11
+ for (let e = 1; e <= s; e++)
12
+ i[t - 1] === r[e - 1] ? n[t][e] = n[t - 1][e - 1] : n[t][e] = Math.min(
13
+ n[t - 1][e] + 1,
14
+ // Deletion
15
+ n[t][e - 1] + 1,
16
+ // Insertion
17
+ n[t - 1][e - 1] + 1
18
+ // Substitution
19
+ );
20
+ return n[c][s];
21
+ }, g = (r, i) => {
22
+ let n = 0, s = 0;
23
+ for (; n < r.length && s < i.length; )
24
+ r[n] === i[s] && n++, s++;
25
+ return n === r.length;
26
+ }, p = (r) => r.split(/[\s\-_]+/).map((i) => i.slice(0, 2)).join("").toLowerCase(), y = (r, i) => {
27
+ if (!i) return r;
28
+ const n = i.toLowerCase().trim(), s = Math.floor(n.length / 2);
29
+ return r.map((t) => {
30
+ const e = t.label.toLowerCase(), o = M(n, e), a = e.split(/[\s\-_]+/), l = n.split(/[\s\-_]+/), h = e.includes(n) || l.every(
31
+ (f) => a.some((d) => d.startsWith(f))
32
+ ), m = p(e), u = g(n, m);
33
+ return {
34
+ option: t,
35
+ distance: o,
36
+ isPartialMatch: h,
37
+ isAcronymMatch: u
38
+ };
39
+ }).filter(
40
+ ({ distance: t, isPartialMatch: e, isAcronymMatch: o }) => e || o || t <= s
41
+ ).sort((t, e) => t.isPartialMatch && !e.isPartialMatch ? -1 : !t.isPartialMatch && e.isPartialMatch ? 1 : t.isAcronymMatch && !e.isAcronymMatch ? -1 : !t.isAcronymMatch && e.isAcronymMatch ? 1 : t.distance - e.distance).map(({ option: t }) => t);
42
+ };
43
+ export {
44
+ p as generateAcronym,
45
+ g as isSubsequence,
46
+ M as levenshteinDistance,
47
+ y as searchOptions
48
+ };
49
+ //# sourceMappingURL=listBoxUtils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"listBoxUtils.js","sources":["../../../../src/components/Form/ListBox/listBoxUtils.ts"],"sourcesContent":["import { OptionForListBoxProps } from \"./constants\";\n\nexport const levenshteinDistance = (a: string, b: string): number => {\n const matrix = [];\n\n const aLength = a.length;\n const bLength = b.length;\n\n // Early exit if one of the strings is empty\n if (aLength === 0) return bLength;\n if (bLength === 0) return aLength;\n\n // Initialize the first row and column of the matrix\n for (let i = 0; i <= bLength; i++) {\n matrix[i] = [ i ];\n }\n for (let j = 0; j <= aLength; j++) {\n matrix[0][j] = j;\n }\n\n // Fill in the rest of the matrix\n for (let i = 1; i <= bLength; i++) {\n for (let j = 1; j <= aLength; j++) {\n if (b[i - 1] === a[j - 1]) {\n matrix[i][j] = matrix[i - 1][j - 1];\n } else {\n matrix[i][j] = Math.min(\n matrix[i - 1][j] + 1, // Deletion\n matrix[i][j - 1] + 1, // Insertion\n matrix[i - 1][j - 1] + 1, // Substitution\n );\n }\n }\n }\n\n return matrix[bLength][aLength];\n};\n\nexport const isSubsequence = (search: string, target: string): boolean => {\n let searchIndex = 0;\n let targetIndex = 0;\n\n while (searchIndex < search.length && targetIndex < target.length) {\n if (search[searchIndex] === target[targetIndex]) {\n searchIndex++;\n }\n targetIndex++;\n }\n\n return searchIndex === search.length;\n};\n\nexport const generateAcronym = (label: string): string => {\n return label\n .split(/[\\s\\-_]+/)\n .map(word => word.slice(0, 2)) // Take first two letters\n .join(\"\")\n .toLowerCase();\n};\n\n// Handle partial matches and common typos =============================================================================\nexport const searchOptions = (options: OptionForListBoxProps[], searchTerm: string) => {\n if (!searchTerm) return options;\n\n const normalizedSearch = searchTerm.toLowerCase().trim();\n\n const maxDistance = Math.floor(normalizedSearch.length / 2);\n\n const matchedOptions = options\n .map(option => {\n const normalizedLabel = option.label.toLowerCase();\n\n const distance = levenshteinDistance(normalizedSearch, normalizedLabel);\n\n const words = normalizedLabel.split(/[\\s\\-_]+/);\n const searchWords = normalizedSearch.split(/[\\s\\-_]+/);\n\n const isPartialMatch =\n normalizedLabel.includes(normalizedSearch) ||\n searchWords.every(searchWord =>\n words.some(word => word.startsWith(searchWord)),\n );\n\n const acronym = generateAcronym(normalizedLabel);\n\n const isAcronymMatch = isSubsequence(normalizedSearch, acronym);\n\n return {\n option,\n distance,\n isPartialMatch,\n isAcronymMatch,\n };\n })\n .filter(({ distance, isPartialMatch, isAcronymMatch }) =>\n isPartialMatch || isAcronymMatch || distance <= maxDistance,\n )\n .sort((a, b) => {\n if (a.isPartialMatch && !b.isPartialMatch) return -1;\n if (!a.isPartialMatch && b.isPartialMatch) return 1;\n\n if (a.isAcronymMatch && !b.isAcronymMatch) return -1;\n if (!a.isAcronymMatch && b.isAcronymMatch) return 1;\n\n return a.distance - b.distance;\n })\n .map(({ option }) => option);\n\n return matchedOptions;\n};\n"],"names":["levenshteinDistance","a","b","matrix","aLength","bLength","i","j","isSubsequence","search","target","searchIndex","targetIndex","generateAcronym","label","word","searchOptions","options","searchTerm","normalizedSearch","maxDistance","option","normalizedLabel","distance","words","searchWords","isPartialMatch","searchWord","acronym","isAcronymMatch"],"mappings":"AAEO,MAAMA,IAAsB,CAACC,GAAWC,MAAsB;AACjE,QAAMC,IAAS,CAAA,GAETC,IAAUH,EAAE,QACZI,IAAUH,EAAE;AAGlB,MAAIE,MAAY,EAAG,QAAOC;AAC1B,MAAIA,MAAY,EAAG,QAAOD;AAG1B,WAASE,IAAI,GAAGA,KAAKD,GAASC;AAC1B,IAAAH,EAAOG,CAAC,IAAI,CAAEA,CAAE;AAEpB,WAASC,IAAI,GAAGA,KAAKH,GAASG;AAC1B,IAAAJ,EAAO,CAAC,EAAEI,CAAC,IAAIA;AAInB,WAASD,IAAI,GAAGA,KAAKD,GAASC;AAC1B,aAASC,IAAI,GAAGA,KAAKH,GAASG;AAC1B,MAAIL,EAAEI,IAAI,CAAC,MAAML,EAAEM,IAAI,CAAC,IACpBJ,EAAOG,CAAC,EAAEC,CAAC,IAAIJ,EAAOG,IAAI,CAAC,EAAEC,IAAI,CAAC,IAElCJ,EAAOG,CAAC,EAAEC,CAAC,IAAI,KAAK;AAAA,QAChBJ,EAAOG,IAAI,CAAC,EAAEC,CAAC,IAAI;AAAA;AAAA,QACnBJ,EAAOG,CAAC,EAAEC,IAAI,CAAC,IAAI;AAAA;AAAA,QACnBJ,EAAOG,IAAI,CAAC,EAAEC,IAAI,CAAC,IAAI;AAAA;AAAA,MAAA;AAMvC,SAAOJ,EAAOE,CAAO,EAAED,CAAO;AAClC,GAEaI,IAAgB,CAACC,GAAgBC,MAA4B;AACtE,MAAIC,IAAc,GACdC,IAAc;AAElB,SAAOD,IAAcF,EAAO,UAAUG,IAAcF,EAAO;AACvD,IAAID,EAAOE,CAAW,MAAMD,EAAOE,CAAW,KAC1CD,KAEJC;AAGJ,SAAOD,MAAgBF,EAAO;AAClC,GAEaI,IAAkB,CAACC,MACrBA,EACF,MAAM,UAAU,EAChB,IAAI,CAAAC,MAAQA,EAAK,MAAM,GAAG,CAAC,CAAC,EAC5B,KAAK,EAAE,EACP,YAAA,GAIIC,IAAgB,CAACC,GAAkCC,MAAuB;AACnF,MAAI,CAACA,EAAY,QAAOD;AAExB,QAAME,IAAmBD,EAAW,YAAA,EAAc,KAAA,GAE5CE,IAAc,KAAK,MAAMD,EAAiB,SAAS,CAAC;AA0C1D,SAxCuBF,EAClB,IAAI,CAAAI,MAAU;AACX,UAAMC,IAAkBD,EAAO,MAAM,YAAA,GAE/BE,IAAWvB,EAAoBmB,GAAkBG,CAAe,GAEhEE,IAAcF,EAAgB,MAAM,UAAU,GAC9CG,IAAcN,EAAiB,MAAM,UAAU,GAE/CO,IACIJ,EAAgB,SAASH,CAAgB,KACzCM,EAAY;AAAA,MAAM,OACdD,EAAM,KAAK,OAAQT,EAAK,WAAWY,CAAU,CAAC;AAAA,IAAA,GAGtDC,IAAUf,EAAgBS,CAAe,GAEzCO,IAAiBrB,EAAcW,GAAkBS,CAAO;AAE9D,WAAO;AAAA,MACH,QAAAP;AAAA,MACA,UAAAE;AAAA,MACA,gBAAAG;AAAA,MACA,gBAAAG;AAAA,IAAA;AAAA,EAER,CAAC,EACA;AAAA,IAAO,CAAC,EAAE,UAAAN,GAAU,gBAAAG,GAAgB,gBAAAG,QACjCH,KAAkBG,KAAkBN,KAAYH;AAAA,EAAA,EAEnD,KAAK,CAACnB,GAAGC,MACFD,EAAE,kBAAkB,CAACC,EAAE,iBAAuB,KAC9C,CAACD,EAAE,kBAAkBC,EAAE,iBAAuB,IAE9CD,EAAE,kBAAkB,CAACC,EAAE,iBAAuB,KAC9C,CAACD,EAAE,kBAAkBC,EAAE,iBAAuB,IAE3CD,EAAE,WAAWC,EAAE,QACzB,EACA,IAAI,CAAC,EAAE,QAAAmB,EAAA,MAAaA,CAAM;AAGnC;"}
@@ -1,5 +1,5 @@
1
1
  import React from "react";
2
- import { CommonAndHTMLProps } from '../../Element/constants';
2
+ import { CommonAndHTMLProps, SpacingTypes } from '../../Element/constants';
3
3
 
4
4
  type PinInputFieldCustomProps = {
5
5
  numberOfFields: number;
@@ -12,6 +12,11 @@ type PinInputFieldCustomProps = {
12
12
  focusFirstInputOnReset?: boolean;
13
13
  isFullWidth?: boolean;
14
14
  ariaLabel?: string;
15
+ label?: string;
16
+ helpText?: string | React.ReactNode;
17
+ errorText?: string;
18
+ required?: boolean;
19
+ size?: Exclude<SpacingTypes, "nano" | "huge">;
15
20
  };
16
21
  export type PinInputFieldElementType = HTMLDivElement & {
17
22
  reset: () => void;
@@ -1 +1 @@
1
- {"version":3,"file":"PinInputField.d.ts","sourceRoot":"","sources":["../../../../src/components/Form/PinInputField/PinInputField.tsx"],"names":[],"mappings":"AACA,OAAO,KAAmF,MAAM,OAAO,CAAC;AAOxG,OAAO,uBAAuB,CAAC;AAG/B,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAO7D,KAAK,wBAAwB,GAAG;IAC5B,cAAc,EAAa,MAAM,CAAC;IAClC,QAAuB,CAAC,EAAG,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACnD,IAAuB,CAAC,EAAG,cAAc,GAAG,QAAQ,CAAC;IACrD,IAAuB,CAAC,EAAG,OAAO,CAAC;IACnC,KAAuB,CAAC,EAAG,OAAO,CAAC;IACnC,SAAuB,CAAC,EAAG,OAAO,CAAC;IACnC,kBAAuB,CAAC,EAAG,SAAS,GAAG,UAAU,CAAC;IAClD,sBAAuB,CAAC,EAAG,OAAO,CAAC;IACnC,WAAuB,CAAC,EAAG,OAAO,CAAC;IACnC,SAAuB,CAAC,EAAG,MAAM,CAAC;CACrC,CAAC;AAEF,MAAM,MAAM,wBAAwB,GAAG,cAAc,GAAG;IAAE,KAAK,EAAE,MAAM,IAAI,CAAA;CAAE,CAAC;AAC9E,MAAM,MAAM,kBAAkB,GAAG,IAAI,CAAC,kBAAkB,CAAC,wBAAwB,CAAC,EAAE,MAAM,wBAAwB,CAAC,GAC/G,wBAAwB,CAAC;AAW7B,eAAO,MAAM,aAAa,gMA6PzB,CAAC"}
1
+ {"version":3,"file":"PinInputField.d.ts","sourceRoot":"","sources":["../../../../src/components/Form/PinInputField/PinInputField.tsx"],"names":[],"mappings":"AACA,OAAO,KAAmF,MAAM,OAAO,CAAC;AAQxG,OAAO,uBAAuB,CAAC;AAG/B,OAAO,EAAE,kBAAkB,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AAO3E,KAAK,wBAAwB,GAAG;IAC5B,cAAc,EAAa,MAAM,CAAC;IAClC,QAAuB,CAAC,EAAG,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACnD,IAAuB,CAAC,EAAG,cAAc,GAAG,QAAQ,CAAC;IACrD,IAAuB,CAAC,EAAG,OAAO,CAAC;IACnC,KAAuB,CAAC,EAAG,OAAO,CAAC;IACnC,SAAuB,CAAC,EAAG,OAAO,CAAC;IACnC,kBAAuB,CAAC,EAAG,SAAS,GAAG,UAAU,CAAC;IAClD,sBAAuB,CAAC,EAAG,OAAO,CAAC;IACnC,WAAuB,CAAC,EAAG,OAAO,CAAC;IACnC,SAAuB,CAAC,EAAG,MAAM,CAAC;IAElC,KAAuB,CAAC,EAAG,MAAM,CAAC;IAClC,QAAuB,CAAC,EAAG,MAAM,GAAG,KAAK,CAAC,SAAS,CAAC;IACpD,SAAuB,CAAC,EAAG,MAAM,CAAC;IAClC,QAAuB,CAAC,EAAG,OAAO,CAAC;IACnC,IAAuB,CAAC,EAAG,OAAO,CAAC,YAAY,EAAE,MAAM,GAAG,MAAM,CAAC,CAAC;CACrE,CAAC;AAEF,MAAM,MAAM,wBAAwB,GAAG,cAAc,GAAG;IAAE,KAAK,EAAE,MAAM,IAAI,CAAA;CAAE,CAAC;AAC9E,MAAM,MAAM,kBAAkB,GAAG,IAAI,CAAC,kBAAkB,CAAC,wBAAwB,CAAC,EAAE,MAAM,wBAAwB,CAAC,GAC/G,wBAAwB,CAAC;AAW7B,eAAO,MAAM,aAAa,gMAiRzB,CAAC"}
@@ -0,0 +1,165 @@
1
+ "use client";
2
+ import { jsx as $ } from "react/jsx-runtime";
3
+ import Z, { useRef as se, useState as E, useCallback as l, useEffect as re, createRef as oe, useImperativeHandle as ce } from "react";
4
+ import { InputField as fe } from "../InputField/InputField.js";
5
+ import { deriveAriaIds as ae, FormItem as le } from "../FormItem/FormItem.js";
6
+ import { Div as ie } from "../../Element/Tags.js";
7
+ /* empty css */
8
+ function q(r, o) {
9
+ return (o === "alphanumeric" ? /^[a-zA-Z0-9]+$/i : /^[0-9]+$/).test(r);
10
+ }
11
+ const ue = Z.forwardRef(
12
+ ({
13
+ numberOfFields: r,
14
+ onChange: o,
15
+ type: m = "number",
16
+ mask: k = !1,
17
+ isOTP: P = !1,
18
+ autoFocus: A = !1,
19
+ pasteFromClipboard: B = "enabled",
20
+ focusFirstInputOnReset: G = !0,
21
+ isFullWidth: J,
22
+ ariaLabel: O,
23
+ // FormItem integration
24
+ label: y,
25
+ helpText: S,
26
+ errorText: b,
27
+ required: _,
28
+ size: Q,
29
+ ...U
30
+ }, W) => {
31
+ const X = se(null), [u, Y] = E([]), [d, w] = E([]), [H, I] = E(!0), [j, D] = E(-1), x = Z.useId(), v = U.id || `pin-input-${x.replace(/:/g, "")}`, F = O || y || "Enter verification code", { describedBy: T } = ae(v, S, b), a = l(
32
+ (s) => {
33
+ var t;
34
+ const e = u[s];
35
+ (t = e == null ? void 0 : e.current) == null || t.focus();
36
+ },
37
+ [u]
38
+ ), L = l(
39
+ (s) => {
40
+ if (!H) return;
41
+ const e = s + 1 < r ? s + 1 : null;
42
+ e && a(e);
43
+ },
44
+ [a, r, H]
45
+ ), K = l(() => {
46
+ w(Array(r).fill("")), o == null || o(""), G && (a(0), D(0));
47
+ }, [r, o, a, G]), p = l(
48
+ (s, e) => {
49
+ const t = [...d];
50
+ t[e] = s, w(t), o == null || o(t.join("")), s !== "" && t.length === r && t.every((i) => i != null && i !== "") && e === r - 1 || (I(!0), L(e));
51
+ },
52
+ [L, r, o, d]
53
+ ), C = l((s, e) => {
54
+ var i;
55
+ const t = typeof s == "string" ? s : s.target.value, f = d[e];
56
+ if (t === "") {
57
+ p("", e);
58
+ return;
59
+ }
60
+ if (t.length > 1 && e < r - 1) {
61
+ if (q(t, m)) {
62
+ let c = [];
63
+ const M = t.split("");
64
+ f === "" ? c = M.filter((N, n) => e + n < r) : ((i = u[e].current) == null ? void 0 : i.selectionEnd) === t.length ? c = M.filter((n, R) => R > 0 && e + R - 1 < r) : c = M.filter((n, R) => R < t.length - 1 && e + R < r);
65
+ const z = d.map(
66
+ (N, n) => n >= e && n < e + c.length ? c[n - e] : N
67
+ );
68
+ w(z), o == null || o(z.join(""));
69
+ const te = Math.min(e + c.length, r - 1);
70
+ a(te);
71
+ }
72
+ } else {
73
+ let c = t;
74
+ (f == null ? void 0 : f.length) > 0 && (c = t.charAt(t.length - 1)), q(c, m) && p(c, e);
75
+ }
76
+ }, [r, o, p, m, d, a, u]), h = l((s, e) => {
77
+ var t;
78
+ if (s.key === "Backspace")
79
+ if (s.target.value === "") {
80
+ if (e > 0) {
81
+ const f = e - 1;
82
+ p("", f), a(f), I(!0);
83
+ }
84
+ } else
85
+ I(!1);
86
+ else s.key === "Escape" ? ((t = u[e].current) == null || t.blur(), V()) : s.key === "ArrowRight" ? e < r - 1 && a(e + 1) : s.key === "ArrowLeft" && e > 0 && a(e - 1);
87
+ }, [a, p, u, r]), g = l((s, e) => {
88
+ D(e);
89
+ }, []), ee = l((s) => {
90
+ const e = s.target;
91
+ setTimeout(() => {
92
+ e.setSelectionRange(e.value.length, e.value.length);
93
+ }, 0);
94
+ }, []), V = l(() => {
95
+ D(-1);
96
+ }, []);
97
+ return re(() => {
98
+ Y((s) => Array(r).fill(0).map((t, f) => {
99
+ var c;
100
+ const i = s[f] || oe();
101
+ return A && f === 0 && ((c = i.current) == null || c.focus()), i;
102
+ }));
103
+ }, [r, A]), ce(
104
+ W,
105
+ () => ({
106
+ ...X.current,
107
+ reset: K
108
+ }),
109
+ [K]
110
+ ), /* @__PURE__ */ $(
111
+ le,
112
+ {
113
+ label: y,
114
+ htmlFor: v,
115
+ helpText: S,
116
+ errorText: b,
117
+ required: _,
118
+ size: Q,
119
+ children: /* @__PURE__ */ $(
120
+ ie,
121
+ {
122
+ "data-pin-input-field": !0,
123
+ ref: X,
124
+ id: v,
125
+ classNames: J ? ["full-width"] : [],
126
+ role: "group",
127
+ "aria-label": y ? void 0 : F,
128
+ "aria-invalid": !!b || void 0,
129
+ "aria-required": _,
130
+ "aria-describedby": T,
131
+ ...U,
132
+ children: Array.from({ length: r }, (s, e) => /* @__PURE__ */ $(
133
+ fe,
134
+ {
135
+ id: `${v}-${e}`,
136
+ ref: u[e],
137
+ type: k ? "password" : m === "number" ? "tel" : "text",
138
+ inputMode: m === "number" ? "numeric" : "text",
139
+ onChange: (t) => C(t, e),
140
+ onKeyDown: (t) => h(t, e),
141
+ onFocus: (t) => g(t, e),
142
+ onSelect: ee,
143
+ onBlur: V,
144
+ placeholder: j !== e ? "⦁" : void 0,
145
+ autoComplete: P ? "one-time-code" : "off",
146
+ value: d[e] || "",
147
+ autoFocus: A && e === 0,
148
+ onCopy: (t) => B === "disabled" && t.preventDefault(),
149
+ onPaste: (t) => B === "disabled" && t.preventDefault(),
150
+ "aria-label": `Digit ${e + 1} of ${r}`,
151
+ "aria-required": _
152
+ },
153
+ e
154
+ ))
155
+ }
156
+ )
157
+ }
158
+ );
159
+ }
160
+ );
161
+ ue.displayName = "PinInputField";
162
+ export {
163
+ ue as PinInputField
164
+ };
165
+ //# sourceMappingURL=PinInputField.js.map