@itilite/lumina-ui 1.1.5 → 1.1.7

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 (164) hide show
  1. package/dist/atom/LoadingSpinner/LoadingSpinner.d.mts +19 -0
  2. package/dist/atom/LoadingSpinner/LoadingSpinner.d.ts +19 -0
  3. package/dist/atom/LoadingSpinner/LoadingSpinner.js +90 -0
  4. package/dist/atom/LoadingSpinner/LoadingSpinner.mjs +9 -0
  5. package/dist/atom/RangePicker/RangePicker.js +266 -136
  6. package/dist/atom/RangePicker/RangePicker.mjs +4 -2
  7. package/dist/atom/Select/Select.d.mts +6 -3
  8. package/dist/atom/Select/Select.d.ts +6 -3
  9. package/dist/atom/Select/Select.js +214 -91
  10. package/dist/atom/Select/Select.mjs +3 -1
  11. package/dist/atom/Slider/Slider.d.mts +34 -0
  12. package/dist/atom/Slider/Slider.d.ts +34 -0
  13. package/dist/atom/Slider/Slider.js +107 -0
  14. package/dist/atom/Slider/Slider.mjs +9 -0
  15. package/dist/chunk-22VF7AVT.mjs +618 -0
  16. package/dist/chunk-2BNAAOBU.mjs +670 -0
  17. package/dist/chunk-2IMRLK6M.mjs +44 -0
  18. package/dist/chunk-2JIINZEK.mjs +618 -0
  19. package/dist/chunk-2LBFKQDZ.mjs +660 -0
  20. package/dist/chunk-2ZJBF5C4.mjs +618 -0
  21. package/dist/chunk-3IMCN4K3.mjs +670 -0
  22. package/dist/chunk-3KBQQCET.mjs +674 -0
  23. package/dist/chunk-3KUHXNFH.mjs +678 -0
  24. package/dist/chunk-3PPNOIXN.mjs +618 -0
  25. package/dist/chunk-3XFY3TXJ.mjs +611 -0
  26. package/dist/chunk-3XW7HS5W.mjs +618 -0
  27. package/dist/chunk-447HZYZ4.mjs +612 -0
  28. package/dist/chunk-46F3B4U6.mjs +618 -0
  29. package/dist/chunk-4K5RZHL4.mjs +618 -0
  30. package/dist/chunk-4QHFP4YD.mjs +666 -0
  31. package/dist/chunk-4TFX4DHY.mjs +702 -0
  32. package/dist/chunk-4TWO6JES.mjs +666 -0
  33. package/dist/chunk-4UQVJ3ZU.mjs +666 -0
  34. package/dist/chunk-5247J65D.mjs +670 -0
  35. package/dist/chunk-66H5WSEJ.mjs +618 -0
  36. package/dist/chunk-6OC6URNL.mjs +73 -0
  37. package/dist/chunk-6OGEXG5U.mjs +618 -0
  38. package/dist/chunk-6ROQXYVN.mjs +672 -0
  39. package/dist/chunk-6WNI6X5Q.mjs +618 -0
  40. package/dist/chunk-72PPCN6D.mjs +675 -0
  41. package/dist/chunk-74EGXFNN.mjs +618 -0
  42. package/dist/chunk-77NCDGJA.mjs +707 -0
  43. package/dist/chunk-7L3WTWF3.mjs +677 -0
  44. package/dist/chunk-7NGBIPZT.mjs +618 -0
  45. package/dist/chunk-7NM4FNMQ.mjs +666 -0
  46. package/dist/chunk-7YBBSVUA.mjs +672 -0
  47. package/dist/chunk-7Z52UP7P.mjs +618 -0
  48. package/dist/chunk-B3LDL3KD.mjs +670 -0
  49. package/dist/chunk-B63IXC6M.mjs +618 -0
  50. package/dist/chunk-B65LGQ47.mjs +666 -0
  51. package/dist/chunk-B6MTRO54.mjs +618 -0
  52. package/dist/chunk-BJBP5XYB.mjs +618 -0
  53. package/dist/chunk-BLLSWPCC.mjs +618 -0
  54. package/dist/chunk-BOYB7REJ.mjs +670 -0
  55. package/dist/chunk-BP2D64XI.mjs +618 -0
  56. package/dist/chunk-BRT5IPGQ.mjs +618 -0
  57. package/dist/chunk-C2J3VBFZ.mjs +670 -0
  58. package/dist/chunk-CDOR7GQP.mjs +618 -0
  59. package/dist/chunk-CI2RMA4V.mjs +612 -0
  60. package/dist/chunk-CNUIZOQJ.mjs +669 -0
  61. package/dist/chunk-CPBXPEST.mjs +672 -0
  62. package/dist/chunk-CVOLXLMU.mjs +618 -0
  63. package/dist/chunk-CWUCNC36.mjs +666 -0
  64. package/dist/chunk-CZBGN6GS.mjs +612 -0
  65. package/dist/chunk-D3APB62N.mjs +618 -0
  66. package/dist/chunk-D3N7VFER.mjs +73 -0
  67. package/dist/chunk-D7TWXVL2.mjs +674 -0
  68. package/dist/chunk-DAZ53AD7.mjs +671 -0
  69. package/dist/chunk-DBY5U6IU.mjs +618 -0
  70. package/dist/chunk-DXTVU4M5.mjs +618 -0
  71. package/dist/chunk-DZBTD6QK.mjs +666 -0
  72. package/dist/chunk-EAK2IMM4.mjs +37 -0
  73. package/dist/chunk-EQT2Q2LW.mjs +610 -0
  74. package/dist/chunk-EWMCELQV.mjs +670 -0
  75. package/dist/chunk-EYKWBEHX.mjs +612 -0
  76. package/dist/chunk-FHLCFUP6.mjs +666 -0
  77. package/dist/chunk-FMPFLQZV.mjs +670 -0
  78. package/dist/chunk-G25YXZ74.mjs +618 -0
  79. package/dist/chunk-GSG6ZC3R.mjs +37 -0
  80. package/dist/chunk-H3MQUFTJ.mjs +618 -0
  81. package/dist/chunk-HKZRLVBX.mjs +618 -0
  82. package/dist/chunk-HQALJGVT.mjs +618 -0
  83. package/dist/chunk-I5GBZ3UX.mjs +676 -0
  84. package/dist/chunk-IQHBVGA4.mjs +677 -0
  85. package/dist/chunk-IV4V55OA.mjs +672 -0
  86. package/dist/chunk-J2RAFKAD.mjs +618 -0
  87. package/dist/chunk-JL34UFI7.mjs +670 -0
  88. package/dist/chunk-JTKSGGQM.mjs +611 -0
  89. package/dist/chunk-JZC2RRDH.mjs +618 -0
  90. package/dist/chunk-K3Y7VKT6.mjs +670 -0
  91. package/dist/chunk-KEVXNUFG.mjs +672 -0
  92. package/dist/chunk-KRYAP7NG.mjs +670 -0
  93. package/dist/chunk-KU655POK.mjs +657 -0
  94. package/dist/chunk-L55SLVNX.mjs +618 -0
  95. package/dist/chunk-LCRYOZEV.mjs +618 -0
  96. package/dist/chunk-LH7PP6V2.mjs +618 -0
  97. package/dist/chunk-LJMMYKE2.mjs +618 -0
  98. package/dist/chunk-LK5TROLL.mjs +666 -0
  99. package/dist/chunk-MDR7DAKM.mjs +618 -0
  100. package/dist/chunk-MJZLCWZ5.mjs +666 -0
  101. package/dist/chunk-MKZTEJLS.mjs +612 -0
  102. package/dist/chunk-MOD7MLCD.mjs +64 -0
  103. package/dist/chunk-MQCOQHHP.mjs +618 -0
  104. package/dist/chunk-MSM4KUBM.mjs +618 -0
  105. package/dist/chunk-MTIUER63.mjs +676 -0
  106. package/dist/chunk-NBLV3UX5.mjs +618 -0
  107. package/dist/chunk-NLADSOJS.mjs +618 -0
  108. package/dist/chunk-NPMTWR3Y.mjs +618 -0
  109. package/dist/chunk-NQ6GKEO7.mjs +670 -0
  110. package/dist/chunk-NZSFYNUK.mjs +618 -0
  111. package/dist/chunk-OANBDTKG.mjs +73 -0
  112. package/dist/chunk-OCNF4O5U.mjs +612 -0
  113. package/dist/chunk-OCW5QSWA.mjs +618 -0
  114. package/dist/chunk-OQF7JZFS.mjs +670 -0
  115. package/dist/chunk-OT675HGC.mjs +670 -0
  116. package/dist/chunk-P47TCYKN.mjs +618 -0
  117. package/dist/chunk-P7TOGXPI.mjs +672 -0
  118. package/dist/chunk-PCAXXEEQ.mjs +618 -0
  119. package/dist/chunk-PDHMG7OZ.mjs +672 -0
  120. package/dist/chunk-PFGVOZGM.mjs +618 -0
  121. package/dist/chunk-PQSSDK3E.mjs +618 -0
  122. package/dist/chunk-PST7W3NG.mjs +618 -0
  123. package/dist/chunk-QGPBZ2YV.mjs +664 -0
  124. package/dist/chunk-QKTMWS4J.mjs +43 -0
  125. package/dist/chunk-QOPCJITC.mjs +618 -0
  126. package/dist/chunk-QSE52CRC.mjs +618 -0
  127. package/dist/chunk-QTP2QMPL.mjs +669 -0
  128. package/dist/chunk-R47XX6IW.mjs +611 -0
  129. package/dist/chunk-RL6AEU6E.mjs +612 -0
  130. package/dist/chunk-T7T4HCHH.mjs +618 -0
  131. package/dist/chunk-TED2WCDG.mjs +618 -0
  132. package/dist/chunk-TJLIMMMB.mjs +612 -0
  133. package/dist/chunk-TNOJDLON.mjs +611 -0
  134. package/dist/chunk-TOR67IHH.mjs +672 -0
  135. package/dist/chunk-TOV7NVKM.mjs +618 -0
  136. package/dist/chunk-TSYMIRRN.mjs +618 -0
  137. package/dist/chunk-TTSRI4V7.mjs +708 -0
  138. package/dist/chunk-UBS3DTE5.mjs +672 -0
  139. package/dist/chunk-UBW6RYVF.mjs +670 -0
  140. package/dist/chunk-UJNUFKR5.mjs +43 -0
  141. package/dist/chunk-VAZZJOSJ.mjs +618 -0
  142. package/dist/chunk-VCWXOX2B.mjs +618 -0
  143. package/dist/chunk-VHCLEOHZ.mjs +618 -0
  144. package/dist/chunk-VTZSCGME.mjs +666 -0
  145. package/dist/chunk-W33KZ2XR.mjs +618 -0
  146. package/dist/chunk-WOVMTYDV.mjs +612 -0
  147. package/dist/chunk-WR3USBWK.mjs +672 -0
  148. package/dist/chunk-WXYQARQ6.mjs +618 -0
  149. package/dist/chunk-XSDANHCE.mjs +618 -0
  150. package/dist/chunk-Y6XKW4NG.mjs +618 -0
  151. package/dist/chunk-YQSNJFZE.mjs +618 -0
  152. package/dist/chunk-Z6VG6AG7.mjs +678 -0
  153. package/dist/chunk-ZAPKQ4C3.mjs +678 -0
  154. package/dist/chunk-ZCWDQNHL.mjs +618 -0
  155. package/dist/chunk-ZF5JBNCI.mjs +618 -0
  156. package/dist/chunk-ZN7BHWOF.mjs +672 -0
  157. package/dist/chunk-ZUQJKA5J.mjs +666 -0
  158. package/dist/chunk-ZWHWIGYQ.mjs +618 -0
  159. package/dist/index.d.mts +3 -0
  160. package/dist/index.d.ts +3 -0
  161. package/dist/index.js +299 -136
  162. package/dist/index.mjs +21 -13
  163. package/dist/styles.css +288 -181
  164. package/package.json +3 -2
@@ -0,0 +1,657 @@
1
+ import {
2
+ Tooltip_default
3
+ } from "./chunk-MLCMZRUC.mjs";
4
+ import {
5
+ __objRest,
6
+ __spreadProps,
7
+ __spreadValues
8
+ } from "./chunk-FWCSY2DS.mjs";
9
+
10
+ // src/atom/Select/Select.tsx
11
+ import { memo as memo3, useCallback, useEffect, useMemo, useRef, useState } from "react";
12
+ import clsx from "clsx";
13
+
14
+ // src/icons/Chevron.tsx
15
+ import * as React from "react";
16
+ import { jsx } from "react/jsx-runtime";
17
+ var Chevron = React.memo(
18
+ (_a) => {
19
+ var _b = _a, { size = 16, color = "#6b7280", className } = _b, rest = __objRest(_b, ["size", "color", "className"]);
20
+ return /* @__PURE__ */ jsx(
21
+ "svg",
22
+ __spreadProps(__spreadValues({
23
+ xmlns: "http://www.w3.org/2000/svg",
24
+ width: size,
25
+ height: size,
26
+ fill: "none",
27
+ viewBox: "0 0 16 16",
28
+ className
29
+ }, rest), {
30
+ children: /* @__PURE__ */ jsx(
31
+ "path",
32
+ {
33
+ fill: color,
34
+ d: "M11.78 6.22a.75.75 0 00-1.06 0L8 8.94 5.28 6.22a.75.75 0 00-1.06 1.06l3.25 3.25a.75.75 0 001.06 0l3.25-3.25a.75.75 0 000-1.06z"
35
+ }
36
+ )
37
+ })
38
+ );
39
+ }
40
+ );
41
+ Chevron.displayName = "Chevron";
42
+
43
+ // src/icons/CrossV2.tsx
44
+ import * as React2 from "react";
45
+ import { jsx as jsx2 } from "react/jsx-runtime";
46
+ var CrossV2 = React2.memo(
47
+ (_a) => {
48
+ var _b = _a, { size = 16, color = "#111827", className } = _b, rest = __objRest(_b, ["size", "color", "className"]);
49
+ return /* @__PURE__ */ jsx2(
50
+ "svg",
51
+ __spreadProps(__spreadValues({
52
+ xmlns: "http://www.w3.org/2000/svg",
53
+ width: size,
54
+ height: size,
55
+ fill: "none",
56
+ viewBox: "0 0 16 16",
57
+ className
58
+ }, rest), {
59
+ children: /* @__PURE__ */ jsx2(
60
+ "path",
61
+ {
62
+ fill: color,
63
+ fillRule: "evenodd",
64
+ d: "M4.293 4.293a1 1 0 011.414 0L8 6.586l2.293-2.293a1 1 0 111.414 1.414L9.414 8l2.293 2.293a1 1 0 01-1.414 1.414L8 9.414l-2.293 2.293a1 1 0 01-1.414-1.414L6.586 8 4.293 5.707a1 1 0 010-1.414z",
65
+ clipRule: "evenodd"
66
+ }
67
+ )
68
+ })
69
+ );
70
+ }
71
+ );
72
+ CrossV2.displayName = "CrossV2";
73
+
74
+ // src/icons/Lock.tsx
75
+ import React3 from "react";
76
+ import { jsx as jsx3 } from "react/jsx-runtime";
77
+ var Lock = React3.memo((_a) => {
78
+ var _b = _a, { size = 16, color = "#000" } = _b, rest = __objRest(_b, ["size", "color"]);
79
+ return /* @__PURE__ */ jsx3(
80
+ "svg",
81
+ __spreadProps(__spreadValues({
82
+ xmlns: "http://www.w3.org/2000/svg",
83
+ width: size,
84
+ height: size,
85
+ fill: "none",
86
+ viewBox: "0 0 16 16"
87
+ }, rest), {
88
+ children: /* @__PURE__ */ jsx3(
89
+ "path",
90
+ {
91
+ fill: color,
92
+ d: "M9 9a1 1 0 11-2 0 1 1 0 012 0zM5 4h-.5A2.5 2.5 0 002 6.5v5A2.5 2.5 0 004.5 14h7a2.5 2.5 0 002.5-2.5v-5A2.5 2.5 0 0011.5 4H11v-.5a3 3 0 00-6 0V4zm1-.5a2 2 0 114 0V4H6v-.5zM11.5 5A1.5 1.5 0 0113 6.5v5a1.5 1.5 0 01-1.5 1.5h-7A1.5 1.5 0 013 11.5v-5A1.5 1.5 0 014.5 5h7z"
93
+ }
94
+ )
95
+ })
96
+ );
97
+ });
98
+
99
+ // src/atom/Select/Select.tsx
100
+ import { jsx as jsx4, jsxs } from "react/jsx-runtime";
101
+ var Select = ({
102
+ label,
103
+ mandatory = false,
104
+ error = false,
105
+ options = [],
106
+ valueSelected = "",
107
+ // Keep for backward compatibility
108
+ value: _valueProp,
109
+ // Rename to avoid potential conflicts with native value attribute
110
+ onChange,
111
+ onSearch,
112
+ isLoading = false,
113
+ disabled = false,
114
+ disabledTooltip = "",
115
+ className = "",
116
+ dropdownClassName = "",
117
+ optionClassName = "",
118
+ style = {},
119
+ showDisplayValue = false,
120
+ // New prop to show displayValue instead of label
121
+ allowClear = true,
122
+ enableSearch = true,
123
+ doubleCharSearch = false,
124
+ id,
125
+ name,
126
+ tabIndex,
127
+ // Add tabIndex prop
128
+ // Additional styling props
129
+ size = "default",
130
+ // 'small', 'default', 'large'
131
+ variant = "default",
132
+ // 'default', 'filled', 'outlined'
133
+ wrapperClassName = "",
134
+ inputClassName = "",
135
+ // Custom class for input element specifically
136
+ labelClassName = "",
137
+ // Custom class for label element specifically
138
+ height = "tw-h-12",
139
+ // Custom height
140
+ experience = "business"
141
+ }) => {
142
+ const normalizeValue = useCallback(
143
+ (val) => {
144
+ if (val === null || val === void 0) return "";
145
+ return String(val);
146
+ },
147
+ []
148
+ );
149
+ const validatedOptions = useMemo(() => {
150
+ if (!Array.isArray(options)) return [];
151
+ return options.filter(
152
+ (opt) => opt && typeof opt === "object" && opt.value !== void 0 && opt.value !== null && opt.label !== void 0
153
+ );
154
+ }, [options]);
155
+ const [isOpen, setIsOpen] = useState(false);
156
+ const [isFocused, setIsFocused] = useState(false);
157
+ const [searchTerm, setSearchTerm] = useState("");
158
+ const [isHovering, setIsHovering] = useState(false);
159
+ const [highlightedIndex, setHighlightedIndex] = useState(-1);
160
+ const [selectedValue, setSelectedValue] = useState(() => {
161
+ const initialValue = valueSelected;
162
+ if (initialValue === null || initialValue === void 0) return "";
163
+ return String(initialValue);
164
+ });
165
+ const inputRef = useRef(null);
166
+ const inputValueRef = useRef("");
167
+ const dropdownRef = useRef(null);
168
+ const optionRefs = useRef([]);
169
+ const optionListRef = useRef(null);
170
+ const blurTimeoutRef = useRef(null);
171
+ const hoverTimeoutRef = useRef(null);
172
+ const isActive = isFocused || Boolean(selectedValue) || Boolean(valueSelected) || Boolean(searchTerm);
173
+ const sizeClasses = useMemo(() => {
174
+ switch (size) {
175
+ case "small":
176
+ return {
177
+ input: "tw-h-8 tw-px-3 tw-typography-body2",
178
+ padding: label ? "tw-pt-4 tw-pb-1" : "tw-py-2",
179
+ labelActive: "tw-top-0 tw-typography-caption4",
180
+ labelInactive: "tw-top-2 tw-typography-caption3"
181
+ };
182
+ case "medium":
183
+ return {
184
+ input: "tw-h-10 tw-px-4 tw-typography-body2",
185
+ padding: label ? "tw-pt-4 tw-pb-1" : "tw-py-2",
186
+ labelActive: "tw-top-1 tw-typography-caption3",
187
+ labelInactive: "tw-top-2.5 tw-typography-body2"
188
+ };
189
+ case "large":
190
+ return {
191
+ input: "tw-h-16 tw-px-5 tw-typography-bodyLarge",
192
+ padding: label ? "tw-pt-8 tw-pb-4" : "tw-py-5",
193
+ labelActive: "tw-top-1 tw-typography-caption2",
194
+ labelInactive: "tw-top-5 tw-typography-body1"
195
+ };
196
+ default:
197
+ return {
198
+ input: height + " tw-px-4 tw-typography-bodyLarge",
199
+ padding: label ? "tw-pt-6 tw-pb-3" : "tw-py-3",
200
+ labelActive: "tw-top-1 tw-typography-caption3",
201
+ labelInactive: "tw-top-3.5 tw-typography-body2"
202
+ };
203
+ }
204
+ }, [size, label, height]);
205
+ const variantClasses = useMemo(() => {
206
+ switch (variant) {
207
+ case "filled":
208
+ return "tw-bg-gray-50 tw-border-transparent";
209
+ case "outlined":
210
+ return "tw-bg-transparent tw-border-2";
211
+ default:
212
+ return " tw-border";
213
+ }
214
+ }, [variant]);
215
+ const handleBlur = useCallback(() => {
216
+ blurTimeoutRef.current = setTimeout(() => {
217
+ setIsOpen(false);
218
+ setSearchTerm("");
219
+ setHighlightedIndex(-1);
220
+ blurTimeoutRef.current = null;
221
+ setIsFocused(false);
222
+ }, 150);
223
+ }, []);
224
+ const handleSearchChange = useCallback(
225
+ (e) => {
226
+ var _a;
227
+ const searchValue = doubleCharSearch ? e.target.value.slice(0, 2) || "" : e.target.value;
228
+ if (doubleCharSearch) {
229
+ setSearchTerm(searchValue);
230
+ } else {
231
+ setSearchTerm(searchValue);
232
+ }
233
+ setIsOpen(true);
234
+ setHighlightedIndex(-1);
235
+ if (onSearch && typeof onSearch === "function") {
236
+ onSearch(searchValue);
237
+ }
238
+ (_a = optionListRef == null ? void 0 : optionListRef.current) == null ? void 0 : _a.scrollTo({
239
+ top: 0,
240
+ behavior: "smooth"
241
+ });
242
+ },
243
+ [doubleCharSearch, onSearch]
244
+ );
245
+ const handleOptionSelect = useCallback(
246
+ (option) => {
247
+ var _a;
248
+ if (blurTimeoutRef.current) {
249
+ clearTimeout(blurTimeoutRef.current);
250
+ blurTimeoutRef.current = null;
251
+ }
252
+ inputValueRef.current = option.label;
253
+ const normalizedValue = normalizeValue(option.value);
254
+ setSelectedValue(normalizedValue);
255
+ setSearchTerm("");
256
+ setIsOpen(false);
257
+ if (enableSearch) {
258
+ setIsFocused(false);
259
+ }
260
+ setIsHovering(false);
261
+ if (onChange) onChange(option.value);
262
+ if (enableSearch) (_a = inputRef.current) == null ? void 0 : _a.blur();
263
+ },
264
+ [normalizeValue, onChange, enableSearch]
265
+ );
266
+ const handleClear = useCallback(
267
+ (e) => {
268
+ var _a;
269
+ inputValueRef.current = "";
270
+ e.stopPropagation();
271
+ e.preventDefault();
272
+ setSelectedValue("");
273
+ setSearchTerm("");
274
+ if (enableSearch) {
275
+ setIsOpen(true);
276
+ setIsFocused(true);
277
+ (_a = inputRef.current) == null ? void 0 : _a.focus();
278
+ } else {
279
+ setIsOpen(false);
280
+ setIsFocused(false);
281
+ }
282
+ if (onChange) onChange(null);
283
+ },
284
+ [onChange, enableSearch]
285
+ );
286
+ useEffect(() => {
287
+ if (!validatedOptions.length) {
288
+ setSelectedValue("");
289
+ setSearchTerm("");
290
+ inputValueRef.current = "";
291
+ }
292
+ }, [validatedOptions.length]);
293
+ useEffect(() => {
294
+ const externalValue = _valueProp !== void 0 ? _valueProp : valueSelected;
295
+ const newValue = normalizeValue(externalValue);
296
+ setSelectedValue((prevValue) => {
297
+ const prevNormalized = normalizeValue(prevValue);
298
+ return prevNormalized !== newValue ? newValue : prevValue;
299
+ });
300
+ }, [valueSelected, _valueProp, normalizeValue]);
301
+ useEffect(() => {
302
+ const handleClickOutside = (event) => {
303
+ if (dropdownRef.current && !dropdownRef.current.contains(event.target)) {
304
+ if (blurTimeoutRef.current) {
305
+ clearTimeout(blurTimeoutRef.current);
306
+ blurTimeoutRef.current = null;
307
+ }
308
+ setIsOpen(false);
309
+ setIsFocused(false);
310
+ setSearchTerm("");
311
+ setHighlightedIndex(-1);
312
+ }
313
+ };
314
+ document.addEventListener("mousedown", handleClickOutside);
315
+ return () => {
316
+ document.removeEventListener("mousedown", handleClickOutside);
317
+ if (blurTimeoutRef.current) {
318
+ clearTimeout(blurTimeoutRef.current);
319
+ }
320
+ if (hoverTimeoutRef.current) {
321
+ clearTimeout(hoverTimeoutRef.current);
322
+ }
323
+ };
324
+ }, []);
325
+ const getDisplayValue = useCallback(() => {
326
+ if (selectedValue && (validatedOptions == null ? void 0 : validatedOptions.length) > 0) {
327
+ const selected = validatedOptions.find(
328
+ (opt) => normalizeValue(opt.value) === normalizeValue(selectedValue)
329
+ );
330
+ if (selected) {
331
+ return showDisplayValue && selected.displayValue ? selected.displayValue : selected.label;
332
+ }
333
+ }
334
+ if (selectedValue && (!validatedOptions || validatedOptions.length === 0)) {
335
+ return selectedValue;
336
+ }
337
+ return "";
338
+ }, [selectedValue, validatedOptions, showDisplayValue, normalizeValue]);
339
+ const filteredOptions = useMemo(() => {
340
+ var _a;
341
+ if (!enableSearch) {
342
+ return validatedOptions;
343
+ }
344
+ (_a = dropdownRef.current) == null ? void 0 : _a.scrollTo(0, 0);
345
+ const updatedFilteredOptions = validatedOptions.filter((option) => {
346
+ var _a2;
347
+ return (_a2 = option == null ? void 0 : option.label) == null ? void 0 : _a2.toLowerCase().includes(searchTerm == null ? void 0 : searchTerm.toLowerCase());
348
+ });
349
+ return updatedFilteredOptions;
350
+ }, [validatedOptions, searchTerm, enableSearch]);
351
+ const getSelectedOptionIndex = useCallback(() => {
352
+ if (!selectedValue || !filteredOptions.length) {
353
+ return 0;
354
+ }
355
+ const index = filteredOptions.findIndex(
356
+ (option) => normalizeValue(option.value) === normalizeValue(selectedValue)
357
+ );
358
+ return index >= 0 ? index : 0;
359
+ }, [selectedValue, filteredOptions, normalizeValue]);
360
+ const handleInputInteraction = useCallback(
361
+ (_e) => {
362
+ var _a;
363
+ if (blurTimeoutRef.current) {
364
+ clearTimeout(blurTimeoutRef.current);
365
+ blurTimeoutRef.current = null;
366
+ }
367
+ if (isOpen) {
368
+ setIsOpen(false);
369
+ setIsFocused(false);
370
+ setSearchTerm("");
371
+ setHighlightedIndex(-1);
372
+ (_a = inputRef.current) == null ? void 0 : _a.blur();
373
+ return;
374
+ }
375
+ setIsFocused(true);
376
+ setIsOpen(true);
377
+ setHighlightedIndex(getSelectedOptionIndex());
378
+ if (inputRef.current) {
379
+ inputRef.current.focus();
380
+ }
381
+ },
382
+ [isOpen, getSelectedOptionIndex]
383
+ );
384
+ const handleKeyDown = useCallback(
385
+ (e) => {
386
+ var _a;
387
+ if (!isOpen) return;
388
+ switch (e.key) {
389
+ case "ArrowDown":
390
+ e.preventDefault();
391
+ setHighlightedIndex((prev) => {
392
+ const nextIndex = prev < filteredOptions.length - 1 ? prev + 1 : prev;
393
+ return nextIndex;
394
+ });
395
+ break;
396
+ case "ArrowUp":
397
+ e.preventDefault();
398
+ setHighlightedIndex((prev) => {
399
+ const nextIndex = prev > 0 ? prev - 1 : prev;
400
+ return nextIndex;
401
+ });
402
+ break;
403
+ case "Enter":
404
+ e.preventDefault();
405
+ if (highlightedIndex >= 0 && filteredOptions[highlightedIndex]) {
406
+ handleOptionSelect(filteredOptions[highlightedIndex]);
407
+ }
408
+ break;
409
+ case "Escape":
410
+ e.preventDefault();
411
+ setIsOpen(false);
412
+ setIsFocused(false);
413
+ setSearchTerm("");
414
+ setHighlightedIndex(-1);
415
+ (_a = inputRef.current) == null ? void 0 : _a.blur();
416
+ break;
417
+ default:
418
+ break;
419
+ }
420
+ },
421
+ [isOpen, highlightedIndex, filteredOptions, handleOptionSelect]
422
+ );
423
+ useEffect(() => {
424
+ if (highlightedIndex >= 0 && optionRefs.current[highlightedIndex]) {
425
+ optionRefs.current[highlightedIndex].scrollIntoView({
426
+ block: "nearest",
427
+ behavior: "smooth"
428
+ });
429
+ }
430
+ }, [highlightedIndex]);
431
+ useEffect(() => {
432
+ optionRefs.current = [];
433
+ }, [filteredOptions]);
434
+ const handleMouseEnter = useCallback(() => {
435
+ if (hoverTimeoutRef.current) {
436
+ clearTimeout(hoverTimeoutRef.current);
437
+ }
438
+ if (!isHovering) {
439
+ setIsHovering(true);
440
+ }
441
+ }, [isHovering]);
442
+ const handleMouseLeave = useCallback(() => {
443
+ hoverTimeoutRef.current = setTimeout(() => {
444
+ setIsHovering(false);
445
+ }, 50);
446
+ }, []);
447
+ const handleChevronClick = useCallback(
448
+ (e) => {
449
+ var _a;
450
+ e.preventDefault();
451
+ if (blurTimeoutRef.current) {
452
+ clearTimeout(blurTimeoutRef.current);
453
+ blurTimeoutRef.current = null;
454
+ }
455
+ if (isOpen) {
456
+ setIsOpen(false);
457
+ setIsFocused(false);
458
+ setSearchTerm("");
459
+ setHighlightedIndex(-1);
460
+ (_a = inputRef.current) == null ? void 0 : _a.blur();
461
+ } else {
462
+ if (inputRef.current) {
463
+ inputRef.current.focus();
464
+ }
465
+ handleInputInteraction();
466
+ }
467
+ },
468
+ [isOpen, handleInputInteraction]
469
+ );
470
+ return /* @__PURE__ */ jsxs(
471
+ "div",
472
+ {
473
+ style,
474
+ className: clsx("tw-relative tw-w-full", wrapperClassName, {
475
+ "tw-cursor-not-allowed": disabled
476
+ }),
477
+ ref: dropdownRef,
478
+ onMouseEnter: handleMouseEnter,
479
+ onMouseLeave: handleMouseLeave,
480
+ children: [
481
+ /* @__PURE__ */ jsxs("div", { className: "tw-relative", children: [
482
+ /* @__PURE__ */ jsx4(
483
+ "input",
484
+ {
485
+ ref: inputRef,
486
+ type: "text",
487
+ id,
488
+ name,
489
+ tabIndex,
490
+ autoComplete: "off",
491
+ autoCorrect: "off",
492
+ autoCapitalize: "off",
493
+ spellCheck: "false",
494
+ value: isFocused && enableSearch ? searchTerm : getDisplayValue(),
495
+ onChange: enableSearch ? handleSearchChange : void 0,
496
+ onClick: handleInputInteraction,
497
+ onKeyDown: handleKeyDown,
498
+ className: clsx(
499
+ "tw-w-full tw-rounded-xl tw-outline-none tw-transition-all tw-duration-200 tw-cursor-pointer tw-border-solid tw-text-color-text-default",
500
+ sizeClasses.input,
501
+ sizeClasses.padding,
502
+ variantClasses,
503
+ {
504
+ "tw-bg-white": valueSelected || getDisplayValue() || isFocused,
505
+ "tw-bg-color-gray-5": !valueSelected || !getDisplayValue(),
506
+ "!tw-bg-[#F8F7F6] tw-cursor-not-allowed tw-pointer-events-none": disabled
507
+ },
508
+ // Conditional padding based on label presence
509
+ !label && "tw-flex tw-items-center",
510
+ {
511
+ "!tw-border-color-primary": isFocused && experience === "business"
512
+ },
513
+ {
514
+ "!tw-border-[#804D7B]": isFocused && experience === "personal"
515
+ },
516
+ error ? "!tw-border-color-text-critical " : "tw-border-[#EBE3DD] hover:tw-border-[#C5B7AC]",
517
+ // Add focus state styling
518
+ "focus:tw-shadow-sm focus:tw-ring-offset-1",
519
+ className,
520
+ inputClassName
521
+ // Put inputClassName last so it can override default classes
522
+ ),
523
+ readOnly: !isFocused || !enableSearch
524
+ }
525
+ ),
526
+ label && /* @__PURE__ */ jsxs(
527
+ "label",
528
+ {
529
+ htmlFor: id,
530
+ className: clsx(
531
+ "tw-absolute tw-left-[18px] tw-pointer-events-none tw-transition-all tw-duration-200 tw-ease-out tw-text-gray-500",
532
+ isActive ? sizeClasses.labelActive : sizeClasses.labelInactive,
533
+ error && "tw-text-color-text-critical",
534
+ labelClassName
535
+ ),
536
+ children: [
537
+ label,
538
+ mandatory && /* @__PURE__ */ jsx4("span", { className: "tw-text-color-text-critical tw-ml-1", children: "*" })
539
+ ]
540
+ }
541
+ ),
542
+ /* @__PURE__ */ jsxs(
543
+ "div",
544
+ {
545
+ className: clsx(
546
+ "tw-absolute tw-right-3 tw-top-1/2 tw--translate-y-1/2 tw-flex tw-items-center",
547
+ {
548
+ "!tw-right-[5px]": doubleCharSearch && !(isHovering && selectedValue && allowClear)
549
+ }
550
+ ),
551
+ children: [
552
+ disabled && /* @__PURE__ */ jsx4("div", { className: "tw-absolute tw-right-0 -tw-top-2", children: /* @__PURE__ */ jsx4(Tooltip_default, { title: disabledTooltip, children: /* @__PURE__ */ jsx4(Lock, { size: 16 }) }) }),
553
+ /* @__PURE__ */ jsx4(
554
+ "div",
555
+ {
556
+ className: clsx(
557
+ "tw-transition-all tw-duration-200 tw-cursor-pointer tw-flex tw-items-center",
558
+ // Only rotate chevron when open and not showing clear icon
559
+ isOpen && !(isHovering && selectedValue && allowClear) && "-tw-rotate-180"
560
+ ),
561
+ onMouseDown: (e) => {
562
+ if (isHovering && selectedValue && allowClear) {
563
+ handleClear(e);
564
+ } else {
565
+ handleChevronClick(e);
566
+ }
567
+ },
568
+ children: isHovering && selectedValue && allowClear ? /* @__PURE__ */ jsx4(CrossV2, { color: "#111827", className: "tw-mr-1" }) : /* @__PURE__ */ jsx4(Chevron, { className: clsx("tw-text-gray-400"), color: "#6B7280" })
569
+ }
570
+ )
571
+ ]
572
+ }
573
+ )
574
+ ] }),
575
+ isOpen && /* @__PURE__ */ jsx4(
576
+ "div",
577
+ {
578
+ className: clsx(
579
+ "tw-absolute tw-z-[100] tw-w-full tw-mt-0 tw-bg-white tw-border tw-border-[#ebe3dd] tw-border-solid tw-rounded-xl tw-shadow-lg tw-overflow-y-auto tw-py-1",
580
+ { "tw-max-h-60": !doubleCharSearch },
581
+ { "tw-max-h-44": doubleCharSearch },
582
+ dropdownClassName
583
+ ),
584
+ ref: optionListRef,
585
+ children: filteredOptions.length > 0 ? filteredOptions.map((option, index) => /* @__PURE__ */ jsx4(
586
+ "div",
587
+ {
588
+ ref: (el) => optionRefs.current[index] = el,
589
+ onClick: () => handleOptionSelect(option),
590
+ onMouseEnter: () => setHighlightedIndex(index),
591
+ className: clsx(
592
+ "tw-transition-all tw-duration-150 tw-typography-body2",
593
+ // Selected option styling
594
+ optionClassName
595
+ ),
596
+ children: /* @__PURE__ */ jsx4(
597
+ "div",
598
+ {
599
+ className: clsx(
600
+ "tw-px-4 tw-cursor-pointer tw-py-2 tw-mx-0.5 tw-rounded-xl",
601
+ normalizeValue(selectedValue) === normalizeValue(option.value) ? experience === "personal" ? "tw-bg-[#f1e8fa]" : "tw-bg-[#fff1e1]" : (
602
+ // Highlighted option styling (keyboard navigation)
603
+ index === highlightedIndex ? "tw-bg-[#f3f4f6] tw-text-gray-900" : (
604
+ // Default option styling
605
+ "tw-text-gray-900 hover:tw-bg-[#1118270a]"
606
+ )
607
+ )
608
+ ),
609
+ children: option.label
610
+ }
611
+ )
612
+ },
613
+ doubleCharSearch ? option.label : option.value
614
+ )) : /* @__PURE__ */ jsx4("div", { className: "tw-px-4 tw-py-3 tw-text-gray-500 tw-text-sm", children: "No options found" })
615
+ }
616
+ )
617
+ ]
618
+ }
619
+ );
620
+ };
621
+ var arePropsEqual = (prevProps, nextProps) => {
622
+ var _a, _b;
623
+ const criticalProps = [
624
+ "value",
625
+ "valueSelected",
626
+ "options",
627
+ "error",
628
+ "disabled",
629
+ "label",
630
+ "mandatory"
631
+ ];
632
+ for (const prop of criticalProps) {
633
+ if (prevProps[prop] !== nextProps[prop]) {
634
+ return false;
635
+ }
636
+ }
637
+ if (((_a = prevProps.options) == null ? void 0 : _a.length) !== ((_b = nextProps.options) == null ? void 0 : _b.length)) {
638
+ return false;
639
+ }
640
+ if (prevProps.options && nextProps.options) {
641
+ for (let i = 0; i < prevProps.options.length; i++) {
642
+ const prevOpt = prevProps.options[i];
643
+ const nextOpt = nextProps.options[i];
644
+ if ((prevOpt == null ? void 0 : prevOpt.value) !== (nextOpt == null ? void 0 : nextOpt.value) || (prevOpt == null ? void 0 : prevOpt.label) !== (nextOpt == null ? void 0 : nextOpt.label)) {
645
+ return false;
646
+ }
647
+ }
648
+ }
649
+ return true;
650
+ };
651
+ Select.displayName = "Select";
652
+ var Select_default = memo3(Select, arePropsEqual);
653
+
654
+ export {
655
+ Select,
656
+ Select_default
657
+ };