@sunggang/ui-lib 0.3.66 → 0.4.1

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 (93) hide show
  1. package/BaseCkeditor.cjs.js +66855 -0
  2. package/BaseCkeditor.esm.js +15 -18
  3. package/BigCalender.cjs.d.ts +1 -0
  4. package/BigCalender.cjs.default.js +1 -0
  5. package/BigCalender.cjs.js +20404 -0
  6. package/BigCalender.cjs.mjs +2 -0
  7. package/BigCalender.esm.d.ts +1 -0
  8. package/BigCalender.esm.js +20393 -0
  9. package/CkEditor.cjs.d.ts +1 -0
  10. package/CkEditor.cjs.default.js +1 -0
  11. package/CkEditor.cjs.js +31 -0
  12. package/CkEditor.cjs.mjs +2 -0
  13. package/CkEditor.esm.d.ts +1 -0
  14. package/CkEditor.esm.js +23 -0
  15. package/DataTable.cjs.d.ts +1 -0
  16. package/DataTable.cjs.default.js +1 -0
  17. package/DataTable.cjs.js +968 -0
  18. package/DataTable.cjs.mjs +2 -0
  19. package/DataTable.esm.d.ts +1 -0
  20. package/DataTable.esm.js +943 -0
  21. package/DropImage.cjs.d.ts +1 -0
  22. package/DropImage.cjs.default.js +1 -0
  23. package/DropImage.cjs.js +16845 -0
  24. package/DropImage.cjs.mjs +2 -0
  25. package/DropImage.esm.d.ts +1 -0
  26. package/DropImage.esm.js +16834 -0
  27. package/Form.cjs.d.ts +1 -0
  28. package/Form.cjs.default.js +1 -0
  29. package/Form.cjs.js +402 -0
  30. package/Form.cjs.mjs +2 -0
  31. package/Form.esm.d.ts +1 -0
  32. package/Form.esm.js +390 -0
  33. package/FormProvider.cjs.d.ts +1 -0
  34. package/FormProvider.cjs.default.js +1 -0
  35. package/FormProvider.cjs.js +81 -0
  36. package/FormProvider.cjs.mjs +2 -0
  37. package/FormProvider.esm.d.ts +1 -0
  38. package/FormProvider.esm.js +71 -0
  39. package/LiffProvider.cjs.d.ts +1 -0
  40. package/LiffProvider.cjs.default.js +1 -0
  41. package/LiffProvider.cjs.js +1120 -0
  42. package/LiffProvider.cjs.mjs +2 -0
  43. package/LiffProvider.esm.d.ts +1 -0
  44. package/LiffProvider.esm.js +1114 -0
  45. package/Modal.cjs.js +168 -0
  46. package/Modal.esm.js +164 -0
  47. package/Tabs.cjs.d.ts +1 -0
  48. package/Tabs.cjs.default.js +1 -0
  49. package/Tabs.cjs.js +62 -0
  50. package/Tabs.cjs.mjs +2 -0
  51. package/Tabs.esm.d.ts +1 -0
  52. package/Tabs.esm.js +58 -0
  53. package/_commonjsHelpers.cjs.js +30 -0
  54. package/_commonjsHelpers.esm.js +25 -0
  55. package/_tslib.cjs.js +232 -0
  56. package/_tslib.esm.js +224 -0
  57. package/baseSwitch.cjs.js +25830 -0
  58. package/baseSwitch.esm.js +25785 -0
  59. package/index.cjs.css +4832 -0
  60. package/index.cjs.d.ts +1 -0
  61. package/index.cjs.default.js +1 -0
  62. package/index.cjs.js +2097 -0
  63. package/index.cjs.mjs +2 -0
  64. package/index.cjs2.js +1064 -0
  65. package/index.cjs3.js +6424 -0
  66. package/index.esm.cjs.js +3406 -0
  67. package/index.esm.css +3624 -3632
  68. package/index.esm.esm.js +3375 -0
  69. package/index.esm.js +2032 -22
  70. package/index.esm2.js +131 -81165
  71. package/index.esm3.js +2 -25
  72. package/inheritsLoose.cjs.js +9 -0
  73. package/inheritsLoose.esm.js +7 -0
  74. package/input.cjs.js +244 -0
  75. package/input.esm.js +220 -0
  76. package/memoize-one.esm.cjs.js +204 -0
  77. package/memoize-one.esm.esm.js +189 -0
  78. package/package.json +59 -5
  79. package/setPrototypeOf.cjs.js +91 -0
  80. package/setPrototypeOf.esm.js +83 -0
  81. package/src/BigCalender.d.ts +2 -0
  82. package/src/CkEditor.d.ts +1 -0
  83. package/src/DataTable.d.ts +2 -0
  84. package/src/DropImage.d.ts +2 -0
  85. package/src/Form.d.ts +3 -0
  86. package/src/FormProvider.d.ts +1 -0
  87. package/src/LiffProvider.d.ts +1 -0
  88. package/src/Tabs.d.ts +1 -0
  89. package/src/index.d.ts +9 -21
  90. package/styled-components.esm.cjs.js +1621 -0
  91. package/styled-components.esm.esm.js +1615 -0
  92. package/utils.cjs.js +13 -0
  93. package/utils.esm.js +11 -0
package/index.cjs.js ADDED
@@ -0,0 +1,2097 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var input = require('./input.cjs.js');
6
+ var jsxRuntime = require('react/jsx-runtime');
7
+ var React = require('react');
8
+ var SwitchPrimitives = require('@radix-ui/react-switch');
9
+ var utils = require('./utils.cjs.js');
10
+ var index_esm = require('./index.esm.cjs.js');
11
+ var baseSwitch = require('./baseSwitch.cjs.js');
12
+ var format = require('date-fns/format');
13
+ var lucideReact = require('lucide-react');
14
+ var react = require('@iconify/react');
15
+ var reactDayPicker = require('react-day-picker');
16
+ var zhTW = require('date-fns/locale/zh-TW');
17
+ var PopoverPrimitive = require('@radix-ui/react-popover');
18
+ var reactDateRange = require('react-date-range');
19
+ var locales = require('react-date-range/dist/locale/index.js');
20
+ var addDays = require('date-fns/addDays');
21
+ var CheckboxPrimitive = require('@radix-ui/react-checkbox');
22
+ var reactIcons = require('@radix-ui/react-icons');
23
+ var inputOtp = require('input-otp');
24
+ require('@radix-ui/react-slot');
25
+ require('class-variance-authority');
26
+ require('clsx');
27
+ require('tailwind-merge');
28
+ require('next/dynamic');
29
+ require('./setPrototypeOf.cjs.js');
30
+ require('./memoize-one.esm.cjs.js');
31
+ require('@emotion/react');
32
+ require('react-dom');
33
+ require('@mui/material');
34
+ require('./styled-components.esm.cjs.js');
35
+ require('./_tslib.cjs.js');
36
+ require('./_commonjsHelpers.cjs.js');
37
+ require('./Modal.cjs.js');
38
+ require('@radix-ui/react-select');
39
+
40
+ function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
41
+
42
+ function _interopNamespace(e) {
43
+ if (e && e.__esModule) return e;
44
+ var n = Object.create(null);
45
+ if (e) {
46
+ Object.keys(e).forEach(function (k) {
47
+ if (k !== 'default') {
48
+ var d = Object.getOwnPropertyDescriptor(e, k);
49
+ Object.defineProperty(n, k, d.get ? d : {
50
+ enumerable: true,
51
+ get: function () { return e[k]; }
52
+ });
53
+ }
54
+ });
55
+ }
56
+ n["default"] = e;
57
+ return Object.freeze(n);
58
+ }
59
+
60
+ var React__namespace = /*#__PURE__*/_interopNamespace(React);
61
+ var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
62
+ var SwitchPrimitives__namespace = /*#__PURE__*/_interopNamespace(SwitchPrimitives);
63
+ var format__default = /*#__PURE__*/_interopDefaultLegacy(format);
64
+ var zhTW__default = /*#__PURE__*/_interopDefaultLegacy(zhTW);
65
+ var PopoverPrimitive__namespace = /*#__PURE__*/_interopNamespace(PopoverPrimitive);
66
+ var locales__namespace = /*#__PURE__*/_interopNamespace(locales);
67
+ var addDays__default = /*#__PURE__*/_interopDefaultLegacy(addDays);
68
+ var CheckboxPrimitive__namespace = /*#__PURE__*/_interopNamespace(CheckboxPrimitive);
69
+
70
+ function _define_property$6(obj, key, value) {
71
+ if (key in obj) {
72
+ Object.defineProperty(obj, key, {
73
+ value: value,
74
+ enumerable: true,
75
+ configurable: true,
76
+ writable: true
77
+ });
78
+ } else {
79
+ obj[key] = value;
80
+ }
81
+ return obj;
82
+ }
83
+ function _object_spread$6(target) {
84
+ for(var i = 1; i < arguments.length; i++){
85
+ var source = arguments[i] != null ? arguments[i] : {};
86
+ var ownKeys = Object.keys(source);
87
+ if (typeof Object.getOwnPropertySymbols === "function") {
88
+ ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {
89
+ return Object.getOwnPropertyDescriptor(source, sym).enumerable;
90
+ }));
91
+ }
92
+ ownKeys.forEach(function(key) {
93
+ _define_property$6(target, key, source[key]);
94
+ });
95
+ }
96
+ return target;
97
+ }
98
+ function ownKeys$5(object, enumerableOnly) {
99
+ var keys = Object.keys(object);
100
+ if (Object.getOwnPropertySymbols) {
101
+ var symbols = Object.getOwnPropertySymbols(object);
102
+ if (enumerableOnly) {
103
+ symbols = symbols.filter(function(sym) {
104
+ return Object.getOwnPropertyDescriptor(object, sym).enumerable;
105
+ });
106
+ }
107
+ keys.push.apply(keys, symbols);
108
+ }
109
+ return keys;
110
+ }
111
+ function _object_spread_props$5(target, source) {
112
+ source = source != null ? source : {};
113
+ if (Object.getOwnPropertyDescriptors) {
114
+ Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
115
+ } else {
116
+ ownKeys$5(Object(source)).forEach(function(key) {
117
+ Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
118
+ });
119
+ }
120
+ return target;
121
+ }
122
+ function _object_without_properties$4(source, excluded) {
123
+ if (source == null) return {};
124
+ var target = _object_without_properties_loose$4(source, excluded);
125
+ var key, i;
126
+ if (Object.getOwnPropertySymbols) {
127
+ var sourceSymbolKeys = Object.getOwnPropertySymbols(source);
128
+ for(i = 0; i < sourceSymbolKeys.length; i++){
129
+ key = sourceSymbolKeys[i];
130
+ if (excluded.indexOf(key) >= 0) continue;
131
+ if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;
132
+ target[key] = source[key];
133
+ }
134
+ }
135
+ return target;
136
+ }
137
+ function _object_without_properties_loose$4(source, excluded) {
138
+ if (source == null) return {};
139
+ var target = {};
140
+ var sourceKeys = Object.keys(source);
141
+ var key, i;
142
+ for(i = 0; i < sourceKeys.length; i++){
143
+ key = sourceKeys[i];
144
+ if (excluded.indexOf(key) >= 0) continue;
145
+ target[key] = source[key];
146
+ }
147
+ return target;
148
+ }
149
+ var Switch = /*#__PURE__*/ React__namespace.forwardRef(function(_param, ref) {
150
+ var _param_size = _param.size, size = _param_size === void 0 ? "large" : _param_size, color = _param.color, props = _object_without_properties$4(_param, [
151
+ "size",
152
+ "color"
153
+ ]);
154
+ var control = index_esm.useForm().control;
155
+ var name = props.name, className = props.className;
156
+ var bgColor = color === "blue" ? "data-[state=checked]:bg-blue-500" : color === "red" ? "data-[state=checked]:bg-red-500" : color === "green" ? "data-[state=checked]:bg-green-500" : color === "yellow" ? "data-[state=checked]:bg-yellow-500" : "data-[state=checked]:bg-blue-500";
157
+ var sizeClass = {
158
+ small: {
159
+ root: "h-4 w-7",
160
+ thumb: "h-3 w-3 data-[state=checked]:translate-x-3"
161
+ },
162
+ medium: {
163
+ root: "h-5 w-9",
164
+ thumb: "h-4 w-4 data-[state=checked]:translate-x-4"
165
+ },
166
+ large: {
167
+ root: "h-6 w-11",
168
+ thumb: "h-5 w-5 data-[state=checked]:translate-x-5"
169
+ }
170
+ };
171
+ return /*#__PURE__*/ jsxRuntime.jsx("div", {
172
+ className: [
173
+ "h-24 w-full",
174
+ className
175
+ ].join(" "),
176
+ children: /*#__PURE__*/ jsxRuntime.jsx(index_esm.Controller, {
177
+ name: name || "",
178
+ control: control,
179
+ render: function(param) {
180
+ param.field;
181
+ return /*#__PURE__*/ jsxRuntime.jsx(SwitchPrimitives__namespace.Root, _object_spread_props$5(_object_spread$6({
182
+ className: utils.cn("peer inline-flex h-5 w-9 shrink-0 cursor-pointer items-center rounded-full border-2 border-transparent shadow-sm transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 focus-visible:ring-offset-background disabled:cursor-not-allowed disabled:opacity-50", bgColor, sizeClass[size].root, "data-[state=unchecked]:bg-input")
183
+ }, props), {
184
+ ref: ref,
185
+ children: /*#__PURE__*/ jsxRuntime.jsx(SwitchPrimitives__namespace.Thumb, {
186
+ className: utils.cn("pointer-events-none block h-4 w-4 rounded-full bg-background shadow-lg ring-0 transition-transform data-[state=checked]:translate-x-4 data-[state=unchecked]:translate-x-0", sizeClass[size].thumb)
187
+ })
188
+ }));
189
+ }
190
+ })
191
+ });
192
+ });
193
+
194
+ var phone = /^09\d{8}$/;
195
+ var email = /^\w+([.-]?\w+)*@\w+([.-]?\w+)*(\.\w{2,3})+$/i;
196
+ var birthday = /^(19|20)\d\d[-](0[1-9]|1[012])[-](0[1-9]|[12][0-9]|3[01])$/;
197
+ var carrier = /^\/[0-9A-Z.+-]{7}$/;
198
+ var Regex = {
199
+ phone: phone,
200
+ email: email,
201
+ birthday: birthday,
202
+ carrier: carrier
203
+ };
204
+
205
+ var verifyTaiwanIdIntermediateString = function(input) {
206
+ var idArray = input.split("");
207
+ var intRadix = 10;
208
+ var TAIWAN_ID_LOCALE_CODE_LIST = [
209
+ 1,
210
+ 10,
211
+ 19,
212
+ 28,
213
+ 37,
214
+ 46,
215
+ 55,
216
+ 64,
217
+ 39,
218
+ 73,
219
+ 82,
220
+ 2,
221
+ 11,
222
+ 20,
223
+ 48,
224
+ 29,
225
+ 38,
226
+ 47,
227
+ 56,
228
+ 65,
229
+ 74,
230
+ 83,
231
+ 21,
232
+ 3,
233
+ 12,
234
+ 30
235
+ ];
236
+ var RESIDENT_CERTIFICATE_NUMBER_LIST = [
237
+ "0",
238
+ "1",
239
+ "2",
240
+ "3",
241
+ "4",
242
+ "5",
243
+ "6",
244
+ "7",
245
+ "4",
246
+ "8",
247
+ "9",
248
+ "0",
249
+ "1",
250
+ "2",
251
+ "5",
252
+ "3",
253
+ "4",
254
+ "5",
255
+ "6",
256
+ "7",
257
+ "8",
258
+ "9",
259
+ "2",
260
+ "0",
261
+ "1",
262
+ "3"
263
+ ];
264
+ // if is not a number (居留證編號)
265
+ // eslint-disable-next-line no-restricted-globals
266
+ if (isNaN(parseInt(idArray[1], intRadix))) {
267
+ idArray[1] = RESIDENT_CERTIFICATE_NUMBER_LIST[input.charCodeAt(1) - "A".charCodeAt(0)];
268
+ }
269
+ var result = idArray.reduce(function(sum, n, index) {
270
+ if (index === 0) {
271
+ return sum + TAIWAN_ID_LOCALE_CODE_LIST[idArray[0].charCodeAt(0) - "A".charCodeAt(0)];
272
+ }
273
+ if (index === 9) {
274
+ return sum + parseInt(idArray[9], intRadix);
275
+ }
276
+ return sum + parseInt(idArray[index], intRadix) * (9 - index);
277
+ }, 0);
278
+ if (result % 10 === 0) {
279
+ return true;
280
+ }
281
+ return false;
282
+ };
283
+ var verifyId = function(input) {
284
+ var regex = /^[A-Z][1,2,8,9]\d{8}$/;
285
+ if (!regex.test(input)) {
286
+ return false;
287
+ }
288
+ return verifyTaiwanIdIntermediateString(input);
289
+ };
290
+ var verifyTaxId = function(idStr) {
291
+ var regex = /^\d{8}$/;
292
+ if (!regex.test(idStr)) {
293
+ console.log("Fail, 長度錯誤");
294
+ return false;
295
+ }
296
+ var len = 8;
297
+ var idArray = new Array(len);
298
+ var weight = [
299
+ 1,
300
+ 2,
301
+ 1,
302
+ 2,
303
+ 1,
304
+ 2,
305
+ 4,
306
+ 1
307
+ ];
308
+ var sum = 0;
309
+ // eslint-disable-next-line no-plusplus
310
+ for(var i = 0; i < len; i++){
311
+ idArray[i] = parseInt(idStr[i], 10);
312
+ var p = idArray[i] * weight[i];
313
+ var s = Math.floor(p / 10) + p % 10;
314
+ sum += s;
315
+ }
316
+ var checkNumber = 5;
317
+ var isLegal = sum % checkNumber === 0 || (sum + 1) % checkNumber === 0 && idArray[6] === 7;
318
+ if (!isLegal) {
319
+ console.log("Fail, 不合法的統一編號驗證");
320
+ }
321
+ return isLegal;
322
+ };
323
+
324
+ function _define_property$5(obj, key, value) {
325
+ if (key in obj) {
326
+ Object.defineProperty(obj, key, {
327
+ value: value,
328
+ enumerable: true,
329
+ configurable: true,
330
+ writable: true
331
+ });
332
+ } else {
333
+ obj[key] = value;
334
+ }
335
+ return obj;
336
+ }
337
+ function _extends$1() {
338
+ _extends$1 = Object.assign || function(target) {
339
+ for(var i = 1; i < arguments.length; i++){
340
+ var source = arguments[i];
341
+ for(var key in source){
342
+ if (Object.prototype.hasOwnProperty.call(source, key)) {
343
+ target[key] = source[key];
344
+ }
345
+ }
346
+ }
347
+ return target;
348
+ };
349
+ return _extends$1.apply(this, arguments);
350
+ }
351
+ function _object_destructuring_empty$1(o) {
352
+ if (o === null || o === void 0) throw new TypeError("Cannot destructure " + o);
353
+ return o;
354
+ }
355
+ function _object_spread$5(target) {
356
+ for(var i = 1; i < arguments.length; i++){
357
+ var source = arguments[i] != null ? arguments[i] : {};
358
+ var ownKeys = Object.keys(source);
359
+ if (typeof Object.getOwnPropertySymbols === "function") {
360
+ ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {
361
+ return Object.getOwnPropertyDescriptor(source, sym).enumerable;
362
+ }));
363
+ }
364
+ ownKeys.forEach(function(key) {
365
+ _define_property$5(target, key, source[key]);
366
+ });
367
+ }
368
+ return target;
369
+ }
370
+ function ownKeys$4(object, enumerableOnly) {
371
+ var keys = Object.keys(object);
372
+ if (Object.getOwnPropertySymbols) {
373
+ var symbols = Object.getOwnPropertySymbols(object);
374
+ if (enumerableOnly) {
375
+ symbols = symbols.filter(function(sym) {
376
+ return Object.getOwnPropertyDescriptor(object, sym).enumerable;
377
+ });
378
+ }
379
+ keys.push.apply(keys, symbols);
380
+ }
381
+ return keys;
382
+ }
383
+ function _object_spread_props$4(target, source) {
384
+ source = source != null ? source : {};
385
+ if (Object.getOwnPropertyDescriptors) {
386
+ Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
387
+ } else {
388
+ ownKeys$4(Object(source)).forEach(function(key) {
389
+ Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
390
+ });
391
+ }
392
+ return target;
393
+ }
394
+ function _object_without_properties$3(source, excluded) {
395
+ if (source == null) return {};
396
+ var target = _object_without_properties_loose$3(source, excluded);
397
+ var key, i;
398
+ if (Object.getOwnPropertySymbols) {
399
+ var sourceSymbolKeys = Object.getOwnPropertySymbols(source);
400
+ for(i = 0; i < sourceSymbolKeys.length; i++){
401
+ key = sourceSymbolKeys[i];
402
+ if (excluded.indexOf(key) >= 0) continue;
403
+ if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;
404
+ target[key] = source[key];
405
+ }
406
+ }
407
+ return target;
408
+ }
409
+ function _object_without_properties_loose$3(source, excluded) {
410
+ if (source == null) return {};
411
+ var target = {};
412
+ var sourceKeys = Object.keys(source);
413
+ var key, i;
414
+ for(i = 0; i < sourceKeys.length; i++){
415
+ key = sourceKeys[i];
416
+ if (excluded.indexOf(key) >= 0) continue;
417
+ target[key] = source[key];
418
+ }
419
+ return target;
420
+ }
421
+ function Calendar(_param) {
422
+ var className = _param.className, classNames = _param.classNames, _param_showOutsideDays = _param.showOutsideDays, showOutsideDays = _param_showOutsideDays === void 0 ? true : _param_showOutsideDays, props = _object_without_properties$3(_param, [
423
+ "className",
424
+ "classNames",
425
+ "showOutsideDays"
426
+ ]);
427
+ return /*#__PURE__*/ jsxRuntime.jsx(reactDayPicker.DayPicker, _object_spread_props$4(_object_spread$5({
428
+ showOutsideDays: showOutsideDays,
429
+ className: utils.cn("p-3", className),
430
+ classNames: _object_spread$5({
431
+ months: "flex flex-col sm:flex-row space-y-4 sm:space-x-4 sm:space-y-0",
432
+ month: "space-y-4",
433
+ caption: "flex justify-center pt-1 relative items-center",
434
+ caption_label: "text-sm font-medium",
435
+ nav: "space-x-1 flex items-center",
436
+ nav_button: utils.cn(input.buttonVariants({
437
+ variant: "outline"
438
+ }), "h-7 w-7 bg-transparent p-0 opacity-50 hover:opacity-100"),
439
+ nav_button_previous: "absolute left-1",
440
+ nav_button_next: "absolute right-1",
441
+ table: "w-full border-collapse space-y-1",
442
+ head_row: "flex",
443
+ head_cell: "text-muted-foreground rounded-md w-8 font-normal text-[0.8rem]",
444
+ row: "flex w-full mt-2",
445
+ cell: utils.cn("relative p-0 text-center text-sm focus-within:relative focus-within:z-20 [&:has([aria-selected])]:bg-accent [&:has([aria-selected].day-outside)]:bg-accent/50 [&:has([aria-selected].day-range-end)]:rounded-r-md", props.mode === "range" ? "[&:has(>.day-range-end)]:rounded-r-md [&:has(>.day-range-start)]:rounded-l-md first:[&:has([aria-selected])]:rounded-l-md last:[&:has([aria-selected])]:rounded-r-md" : "[&:has([aria-selected])]:rounded-md"),
446
+ day: utils.cn(input.buttonVariants({
447
+ variant: "ghost"
448
+ }), "h-8 w-8 p-0 font-normal aria-selected:opacity-100"),
449
+ day_range_start: "day-range-start",
450
+ day_range_end: "day-range-end",
451
+ day_selected: "bg-[#000] text-[#fff] hover:bg-[#000] hover:text-[#fff] focus:bg-[#000] focus:text-[#fff]",
452
+ day_today: "bg-accent text-accent-foreground",
453
+ day_outside: "day-outside text-muted-foreground opacity-50 aria-selected:bg-accent/50 aria-selected:text-muted-foreground aria-selected:opacity-30",
454
+ day_disabled: "text-muted-foreground opacity-50",
455
+ day_range_middle: "aria-selected:bg-accent aria-selected:text-accent-foreground",
456
+ day_hidden: "invisible"
457
+ }, classNames),
458
+ components: {
459
+ IconLeft: function(_param) {
460
+ _extends$1({}, _object_destructuring_empty$1(_param));
461
+ return /*#__PURE__*/ jsxRuntime.jsx(react.Icon, {
462
+ icon: "heroicons-solid:arrow-left",
463
+ width: "1rem",
464
+ height: "1rem"
465
+ });
466
+ },
467
+ IconRight: function(_param) {
468
+ _extends$1({}, _object_destructuring_empty$1(_param));
469
+ return /*#__PURE__*/ jsxRuntime.jsx(react.Icon, {
470
+ icon: "heroicons-solid:arrow-right",
471
+ width: "1rem",
472
+ height: "1rem"
473
+ });
474
+ }
475
+ }
476
+ }, props), {
477
+ locale: zhTW__default["default"]
478
+ }));
479
+ }
480
+ Calendar.displayName = "Calendar";
481
+
482
+ function _define_property$4(obj, key, value) {
483
+ if (key in obj) {
484
+ Object.defineProperty(obj, key, {
485
+ value: value,
486
+ enumerable: true,
487
+ configurable: true,
488
+ writable: true
489
+ });
490
+ } else {
491
+ obj[key] = value;
492
+ }
493
+ return obj;
494
+ }
495
+ function _object_spread$4(target) {
496
+ for(var i = 1; i < arguments.length; i++){
497
+ var source = arguments[i] != null ? arguments[i] : {};
498
+ var ownKeys = Object.keys(source);
499
+ if (typeof Object.getOwnPropertySymbols === "function") {
500
+ ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {
501
+ return Object.getOwnPropertyDescriptor(source, sym).enumerable;
502
+ }));
503
+ }
504
+ ownKeys.forEach(function(key) {
505
+ _define_property$4(target, key, source[key]);
506
+ });
507
+ }
508
+ return target;
509
+ }
510
+ function _object_without_properties$2(source, excluded) {
511
+ if (source == null) return {};
512
+ var target = _object_without_properties_loose$2(source, excluded);
513
+ var key, i;
514
+ if (Object.getOwnPropertySymbols) {
515
+ var sourceSymbolKeys = Object.getOwnPropertySymbols(source);
516
+ for(i = 0; i < sourceSymbolKeys.length; i++){
517
+ key = sourceSymbolKeys[i];
518
+ if (excluded.indexOf(key) >= 0) continue;
519
+ if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;
520
+ target[key] = source[key];
521
+ }
522
+ }
523
+ return target;
524
+ }
525
+ function _object_without_properties_loose$2(source, excluded) {
526
+ if (source == null) return {};
527
+ var target = {};
528
+ var sourceKeys = Object.keys(source);
529
+ var key, i;
530
+ for(i = 0; i < sourceKeys.length; i++){
531
+ key = sourceKeys[i];
532
+ if (excluded.indexOf(key) >= 0) continue;
533
+ target[key] = source[key];
534
+ }
535
+ return target;
536
+ }
537
+ var Popover = PopoverPrimitive__namespace.Root;
538
+ var PopoverTrigger = PopoverPrimitive__namespace.Trigger;
539
+ var PopoverContent = /*#__PURE__*/ React__namespace.forwardRef(function(_param, ref) {
540
+ var className = _param.className, _param_align = _param.align, align = _param_align === void 0 ? "center" : _param_align, _param_sideOffset = _param.sideOffset, sideOffset = _param_sideOffset === void 0 ? 4 : _param_sideOffset, props = _object_without_properties$2(_param, [
541
+ "className",
542
+ "align",
543
+ "sideOffset"
544
+ ]);
545
+ return /*#__PURE__*/ jsxRuntime.jsx(PopoverPrimitive__namespace.Portal, {
546
+ children: /*#__PURE__*/ jsxRuntime.jsx(PopoverPrimitive__namespace.Content, _object_spread$4({
547
+ ref: ref,
548
+ align: align,
549
+ sideOffset: sideOffset,
550
+ className: utils.cn("z-50 w-72 rounded-md border bg-popover p-4 text-popover-foreground shadow-md outline-none data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2", className)
551
+ }, props))
552
+ });
553
+ });
554
+ PopoverContent.displayName = PopoverPrimitive__namespace.Content.displayName;
555
+
556
+ function DateRangePicker(param) {
557
+ var className = param.className, inputClassName = param.inputClassName, disable = param.disable, _param_isShowCleanBtn = param.isShowCleanBtn, isShowCleanBtn = _param_isShowCleanBtn === void 0 ? true : _param_isShowCleanBtn, onChange = param.onChange, dates = param.dates, setDates = param.setDates;
558
+ var handleDateChange = function(newDate) {
559
+ if (newDate) {
560
+ setDates(newDate);
561
+ if (onChange) onChange(newDate);
562
+ }
563
+ };
564
+ return /*#__PURE__*/ jsxRuntime.jsxs("div", {
565
+ className: "flex gap-2 items-center",
566
+ children: [
567
+ /*#__PURE__*/ jsxRuntime.jsx("div", {
568
+ className: utils.cn("grid gap-2", className, disable ? "pointer-events-none opacity-55" : "pointer-events-auto opacity-100"),
569
+ children: /*#__PURE__*/ jsxRuntime.jsxs(Popover, {
570
+ children: [
571
+ /*#__PURE__*/ jsxRuntime.jsx(PopoverTrigger, {
572
+ asChild: true,
573
+ children: /*#__PURE__*/ jsxRuntime.jsxs(input.Button, {
574
+ id: "date",
575
+ variant: "outline",
576
+ className: utils.cn("w-[300px] justify-start text-left font-normal", !dates && "text-muted-foreground", inputClassName),
577
+ children: [
578
+ /*#__PURE__*/ jsxRuntime.jsx(lucideReact.Calendar, {
579
+ className: "mr-2 h-4 w-4"
580
+ }),
581
+ (dates === null || dates === void 0 ? void 0 : dates.from) ? dates.to ? /*#__PURE__*/ jsxRuntime.jsxs(jsxRuntime.Fragment, {
582
+ children: [
583
+ format__default["default"](dates.from, "yyyy-MM-dd"),
584
+ " -",
585
+ " ",
586
+ format__default["default"](dates.to, "yyyy-MM-dd")
587
+ ]
588
+ }) : format__default["default"](dates.from, "yyyy-MM-dd") : /*#__PURE__*/ jsxRuntime.jsx("span", {
589
+ children: "請選擇日期"
590
+ })
591
+ ]
592
+ })
593
+ }),
594
+ /*#__PURE__*/ jsxRuntime.jsx(PopoverContent, {
595
+ className: "w-auto p-0",
596
+ align: "start",
597
+ children: /*#__PURE__*/ jsxRuntime.jsx(Calendar, {
598
+ initialFocus: true,
599
+ mode: "range",
600
+ defaultMonth: dates === null || dates === void 0 ? void 0 : dates.from,
601
+ selected: dates,
602
+ onSelect: handleDateChange,
603
+ numberOfMonths: 2
604
+ })
605
+ })
606
+ ]
607
+ })
608
+ }),
609
+ isShowCleanBtn && /*#__PURE__*/ jsxRuntime.jsx(input.Button, {
610
+ variant: "ghost",
611
+ className: utils.cn("justify-start text-left font-normal"),
612
+ onClick: function() {
613
+ return setDates(undefined);
614
+ },
615
+ children: "清除日期"
616
+ })
617
+ ]
618
+ });
619
+ }
620
+
621
+ function _array_like_to_array$2(arr, len) {
622
+ if (len == null || len > arr.length) len = arr.length;
623
+ for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];
624
+ return arr2;
625
+ }
626
+ function _array_with_holes$2(arr) {
627
+ if (Array.isArray(arr)) return arr;
628
+ }
629
+ function _iterable_to_array_limit$2(arr, i) {
630
+ var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];
631
+ if (_i == null) return;
632
+ var _arr = [];
633
+ var _n = true;
634
+ var _d = false;
635
+ var _s, _e;
636
+ try {
637
+ for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){
638
+ _arr.push(_s.value);
639
+ if (i && _arr.length === i) break;
640
+ }
641
+ } catch (err) {
642
+ _d = true;
643
+ _e = err;
644
+ } finally{
645
+ try {
646
+ if (!_n && _i["return"] != null) _i["return"]();
647
+ } finally{
648
+ if (_d) throw _e;
649
+ }
650
+ }
651
+ return _arr;
652
+ }
653
+ function _non_iterable_rest$2() {
654
+ throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
655
+ }
656
+ function _sliced_to_array$2(arr, i) {
657
+ return _array_with_holes$2(arr) || _iterable_to_array_limit$2(arr, i) || _unsupported_iterable_to_array$2(arr, i) || _non_iterable_rest$2();
658
+ }
659
+ function _unsupported_iterable_to_array$2(o, minLen) {
660
+ if (!o) return;
661
+ if (typeof o === "string") return _array_like_to_array$2(o, minLen);
662
+ var n = Object.prototype.toString.call(o).slice(8, -1);
663
+ if (n === "Object" && o.constructor) n = o.constructor.name;
664
+ if (n === "Map" || n === "Set") return Array.from(n);
665
+ if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array$2(o, minLen);
666
+ }
667
+ var SingleDatePicker = function(param) {
668
+ var disable = param.disable, onChange = param.onChange;
669
+ var _useState = _sliced_to_array$2(React.useState(), 2), date = _useState[0], setDate = _useState[1];
670
+ var handleDate = function(newDate) {
671
+ if (newDate) {
672
+ setDate(newDate);
673
+ if (onChange) onChange(newDate);
674
+ }
675
+ };
676
+ return /*#__PURE__*/ jsxRuntime.jsx("div", {
677
+ className: utils.cn(disable ? "pointer-events-none opacity-55" : "pointer-events-auto opacity-100"),
678
+ children: /*#__PURE__*/ jsxRuntime.jsxs(Popover, {
679
+ children: [
680
+ /*#__PURE__*/ jsxRuntime.jsx(PopoverTrigger, {
681
+ asChild: true,
682
+ children: /*#__PURE__*/ jsxRuntime.jsxs(input.Button, {
683
+ variant: "outline",
684
+ className: utils.cn("w-[280px] justify-start text-left font-normal", !date && "text-muted-foreground"),
685
+ children: [
686
+ /*#__PURE__*/ jsxRuntime.jsx(lucideReact.Calendar, {
687
+ className: "mr-2 h-4 w-4"
688
+ }),
689
+ date ? format__default["default"](date, "yyyy-MM-dd") : /*#__PURE__*/ jsxRuntime.jsx("span", {
690
+ children: "請選擇日期"
691
+ })
692
+ ]
693
+ })
694
+ }),
695
+ /*#__PURE__*/ jsxRuntime.jsx(PopoverContent, {
696
+ className: "w-auto p-0",
697
+ children: /*#__PURE__*/ jsxRuntime.jsx(Calendar, {
698
+ mode: "single",
699
+ selected: date,
700
+ onSelect: handleDate,
701
+ initialFocus: true
702
+ })
703
+ })
704
+ ]
705
+ })
706
+ });
707
+ };
708
+
709
+ function _array_like_to_array$1(arr, len) {
710
+ if (len == null || len > arr.length) len = arr.length;
711
+ for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];
712
+ return arr2;
713
+ }
714
+ function _array_with_holes$1(arr) {
715
+ if (Array.isArray(arr)) return arr;
716
+ }
717
+ function _iterable_to_array_limit$1(arr, i) {
718
+ var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];
719
+ if (_i == null) return;
720
+ var _arr = [];
721
+ var _n = true;
722
+ var _d = false;
723
+ var _s, _e;
724
+ try {
725
+ for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){
726
+ _arr.push(_s.value);
727
+ if (i && _arr.length === i) break;
728
+ }
729
+ } catch (err) {
730
+ _d = true;
731
+ _e = err;
732
+ } finally{
733
+ try {
734
+ if (!_n && _i["return"] != null) _i["return"]();
735
+ } finally{
736
+ if (_d) throw _e;
737
+ }
738
+ }
739
+ return _arr;
740
+ }
741
+ function _non_iterable_rest$1() {
742
+ throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
743
+ }
744
+ function _sliced_to_array$1(arr, i) {
745
+ return _array_with_holes$1(arr) || _iterable_to_array_limit$1(arr, i) || _unsupported_iterable_to_array$1(arr, i) || _non_iterable_rest$1();
746
+ }
747
+ function _unsupported_iterable_to_array$1(o, minLen) {
748
+ if (!o) return;
749
+ if (typeof o === "string") return _array_like_to_array$1(o, minLen);
750
+ var n = Object.prototype.toString.call(o).slice(8, -1);
751
+ if (n === "Object" && o.constructor) n = o.constructor.name;
752
+ if (n === "Map" || n === "Set") return Array.from(n);
753
+ if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array$1(o, minLen);
754
+ }
755
+ var ReactDateRange = function(param) {
756
+ var className = param.className, item = param.item, onChange = param.onChange, dates = param.dates, date = param.date;
757
+ var _useState = _sliced_to_array$1(React.useState("zhTW"), 1), locale = _useState[0];
758
+ var _useState1 = _sliced_to_array$1(React.useState(""), 2), calendarData = _useState1[0], setCalendarData = _useState1[1];
759
+ var _useState2 = _sliced_to_array$1(React.useState({
760
+ startDate: new Date(),
761
+ endDate: addDays__default["default"](new Date(), 7),
762
+ key: "selection"
763
+ }), 2), range = _useState2[0], setRange = _useState2[1];
764
+ var _useState3 = _sliced_to_array$1(React.useState(false), 2), open = _useState3[0], setOpen = _useState3[1];
765
+ var refOne = React.useRef(null);
766
+ var hideOnEscape = function(e) {
767
+ if (e.key === "Escape") {
768
+ setOpen(false);
769
+ }
770
+ };
771
+ var hideOnClickOutside = function(e) {
772
+ if (refOne.current && !refOne.current.contains(e.target)) {
773
+ setOpen(false);
774
+ }
775
+ };
776
+ React.useEffect(function() {
777
+ setCalendarData(date);
778
+ }, [
779
+ date
780
+ ]);
781
+ React.useEffect(function() {
782
+ if (!dates) return;
783
+ setRange(dates);
784
+ }, [
785
+ dates
786
+ ]);
787
+ React.useEffect(function() {
788
+ document.addEventListener("keydown", hideOnEscape, true);
789
+ document.addEventListener("click", hideOnClickOutside, true);
790
+ return function() {
791
+ document.removeEventListener("keydown", hideOnEscape, true);
792
+ document.removeEventListener("click", hideOnClickOutside, true);
793
+ };
794
+ }, []);
795
+ var formatDates = function() {
796
+ if (!range) return;
797
+ var startDate = range.startDate, endDate = range.endDate;
798
+ return "".concat(format__default["default"](startDate, "yyyy-MM-dd"), " ~ ").concat(format__default["default"](endDate, "yyyy-MM-dd"));
799
+ };
800
+ var formatDate = calendarData ? format__default["default"](calendarData, (item === null || item === void 0 ? void 0 : item.dateDisplayFormat) || "yyyy-MM-dd") : "";
801
+ return /*#__PURE__*/ jsxRuntime.jsxs("div", {
802
+ className: [
803
+ className,
804
+ "relative"
805
+ ].join(" "),
806
+ children: [
807
+ (item === null || item === void 0 ? void 0 : item.label) && /*#__PURE__*/ jsxRuntime.jsx("div", {
808
+ className: "text-gray-700 font-medium mb-2 h-6",
809
+ children: item === null || item === void 0 ? void 0 : item.label
810
+ }),
811
+ /*#__PURE__*/ jsxRuntime.jsx("input", {
812
+ className: "border-solid border rounded p-2 h-10 w-full timePicker border-gray-300",
813
+ name: item === null || item === void 0 ? void 0 : item.name,
814
+ onClick: function() {
815
+ return setOpen(function(openState) {
816
+ return !openState;
817
+ });
818
+ },
819
+ placeholder: item === null || item === void 0 ? void 0 : item.placeholder,
820
+ value: (item === null || item === void 0 ? void 0 : item.type) === "date" ? formatDate : formatDates(),
821
+ autoComplete: "off"
822
+ }),
823
+ open && /*#__PURE__*/ jsxRuntime.jsxs("div", {
824
+ className: "absolute top-[72px] left-0 z-50 shadow-md",
825
+ ref: refOne,
826
+ children: [
827
+ open && (item === null || item === void 0 ? void 0 : item.type) === "date" && /*#__PURE__*/ jsxRuntime.jsx(reactDateRange.Calendar, {
828
+ data: calendarData,
829
+ locale: locales__namespace[locale],
830
+ dateDisplayFormat: item === null || item === void 0 ? void 0 : item.dateDisplayFormat,
831
+ onChange: function(value) {
832
+ setCalendarData(value);
833
+ if (onChange) onChange(value);
834
+ setOpen(false);
835
+ }
836
+ }),
837
+ open && (item === null || item === void 0 ? void 0 : item.type) === "dateRange" && /*#__PURE__*/ jsxRuntime.jsx(reactDateRange.DateRange, {
838
+ editableDateInputs: true,
839
+ onChange: function(value) {
840
+ setRange(value.selection);
841
+ if (onChange) onChange(value.selection);
842
+ },
843
+ ranges: [
844
+ range
845
+ ],
846
+ locale: locales__namespace[locale],
847
+ dateDisplayFormat: "yyyy.MM.dd"
848
+ })
849
+ ]
850
+ })
851
+ ]
852
+ });
853
+ };
854
+
855
+ function _define_property$3(obj, key, value) {
856
+ if (key in obj) {
857
+ Object.defineProperty(obj, key, {
858
+ value: value,
859
+ enumerable: true,
860
+ configurable: true,
861
+ writable: true
862
+ });
863
+ } else {
864
+ obj[key] = value;
865
+ }
866
+ return obj;
867
+ }
868
+ function _object_spread$3(target) {
869
+ for(var i = 1; i < arguments.length; i++){
870
+ var source = arguments[i] != null ? arguments[i] : {};
871
+ var ownKeys = Object.keys(source);
872
+ if (typeof Object.getOwnPropertySymbols === "function") {
873
+ ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {
874
+ return Object.getOwnPropertyDescriptor(source, sym).enumerable;
875
+ }));
876
+ }
877
+ ownKeys.forEach(function(key) {
878
+ _define_property$3(target, key, source[key]);
879
+ });
880
+ }
881
+ return target;
882
+ }
883
+ function ownKeys$3(object, enumerableOnly) {
884
+ var keys = Object.keys(object);
885
+ if (Object.getOwnPropertySymbols) {
886
+ var symbols = Object.getOwnPropertySymbols(object);
887
+ if (enumerableOnly) {
888
+ symbols = symbols.filter(function(sym) {
889
+ return Object.getOwnPropertyDescriptor(object, sym).enumerable;
890
+ });
891
+ }
892
+ keys.push.apply(keys, symbols);
893
+ }
894
+ return keys;
895
+ }
896
+ function _object_spread_props$3(target, source) {
897
+ source = source != null ? source : {};
898
+ if (Object.getOwnPropertyDescriptors) {
899
+ Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
900
+ } else {
901
+ ownKeys$3(Object(source)).forEach(function(key) {
902
+ Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
903
+ });
904
+ }
905
+ return target;
906
+ }
907
+ function _object_without_properties$1(source, excluded) {
908
+ if (source == null) return {};
909
+ var target = _object_without_properties_loose$1(source, excluded);
910
+ var key, i;
911
+ if (Object.getOwnPropertySymbols) {
912
+ var sourceSymbolKeys = Object.getOwnPropertySymbols(source);
913
+ for(i = 0; i < sourceSymbolKeys.length; i++){
914
+ key = sourceSymbolKeys[i];
915
+ if (excluded.indexOf(key) >= 0) continue;
916
+ if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;
917
+ target[key] = source[key];
918
+ }
919
+ }
920
+ return target;
921
+ }
922
+ function _object_without_properties_loose$1(source, excluded) {
923
+ if (source == null) return {};
924
+ var target = {};
925
+ var sourceKeys = Object.keys(source);
926
+ var key, i;
927
+ for(i = 0; i < sourceKeys.length; i++){
928
+ key = sourceKeys[i];
929
+ if (excluded.indexOf(key) >= 0) continue;
930
+ target[key] = source[key];
931
+ }
932
+ return target;
933
+ }
934
+ var Checkbox = /*#__PURE__*/ React__namespace.forwardRef(function(_param, ref) {
935
+ var className = _param.className, props = _object_without_properties$1(_param, [
936
+ "className"
937
+ ]);
938
+ return /*#__PURE__*/ jsxRuntime.jsx(CheckboxPrimitive__namespace.Root, _object_spread_props$3(_object_spread$3({
939
+ ref: ref,
940
+ className: utils.cn("peer h-4 w-4 shrink-0 rounded-sm border border-primary shadow focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-ring disabled:cursor-not-allowed disabled:opacity-50 data-[state=checked]:bg-primary data-[state=checked]:text-primary-foreground", className)
941
+ }, props), {
942
+ children: /*#__PURE__*/ jsxRuntime.jsx(CheckboxPrimitive__namespace.Indicator, {
943
+ className: utils.cn("flex items-center justify-center text-current"),
944
+ children: /*#__PURE__*/ jsxRuntime.jsx(reactIcons.CheckIcon, {
945
+ className: "h-4 w-4"
946
+ })
947
+ })
948
+ }));
949
+ });
950
+ Checkbox.displayName = CheckboxPrimitive__namespace.Root.displayName;
951
+
952
+ function _define_property$2(obj, key, value) {
953
+ if (key in obj) {
954
+ Object.defineProperty(obj, key, {
955
+ value: value,
956
+ enumerable: true,
957
+ configurable: true,
958
+ writable: true
959
+ });
960
+ } else {
961
+ obj[key] = value;
962
+ }
963
+ return obj;
964
+ }
965
+ function _extends() {
966
+ _extends = Object.assign || function(target) {
967
+ for(var i = 1; i < arguments.length; i++){
968
+ var source = arguments[i];
969
+ for(var key in source){
970
+ if (Object.prototype.hasOwnProperty.call(source, key)) {
971
+ target[key] = source[key];
972
+ }
973
+ }
974
+ }
975
+ return target;
976
+ };
977
+ return _extends.apply(this, arguments);
978
+ }
979
+ function _object_destructuring_empty(o) {
980
+ if (o === null || o === void 0) throw new TypeError("Cannot destructure " + o);
981
+ return o;
982
+ }
983
+ function _object_spread$2(target) {
984
+ for(var i = 1; i < arguments.length; i++){
985
+ var source = arguments[i] != null ? arguments[i] : {};
986
+ var ownKeys = Object.keys(source);
987
+ if (typeof Object.getOwnPropertySymbols === "function") {
988
+ ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {
989
+ return Object.getOwnPropertyDescriptor(source, sym).enumerable;
990
+ }));
991
+ }
992
+ ownKeys.forEach(function(key) {
993
+ _define_property$2(target, key, source[key]);
994
+ });
995
+ }
996
+ return target;
997
+ }
998
+ function ownKeys$2(object, enumerableOnly) {
999
+ var keys = Object.keys(object);
1000
+ if (Object.getOwnPropertySymbols) {
1001
+ var symbols = Object.getOwnPropertySymbols(object);
1002
+ if (enumerableOnly) {
1003
+ symbols = symbols.filter(function(sym) {
1004
+ return Object.getOwnPropertyDescriptor(object, sym).enumerable;
1005
+ });
1006
+ }
1007
+ keys.push.apply(keys, symbols);
1008
+ }
1009
+ return keys;
1010
+ }
1011
+ function _object_spread_props$2(target, source) {
1012
+ source = source != null ? source : {};
1013
+ if (Object.getOwnPropertyDescriptors) {
1014
+ Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
1015
+ } else {
1016
+ ownKeys$2(Object(source)).forEach(function(key) {
1017
+ Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
1018
+ });
1019
+ }
1020
+ return target;
1021
+ }
1022
+ function _object_without_properties(source, excluded) {
1023
+ if (source == null) return {};
1024
+ var target = _object_without_properties_loose(source, excluded);
1025
+ var key, i;
1026
+ if (Object.getOwnPropertySymbols) {
1027
+ var sourceSymbolKeys = Object.getOwnPropertySymbols(source);
1028
+ for(i = 0; i < sourceSymbolKeys.length; i++){
1029
+ key = sourceSymbolKeys[i];
1030
+ if (excluded.indexOf(key) >= 0) continue;
1031
+ if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue;
1032
+ target[key] = source[key];
1033
+ }
1034
+ }
1035
+ return target;
1036
+ }
1037
+ function _object_without_properties_loose(source, excluded) {
1038
+ if (source == null) return {};
1039
+ var target = {};
1040
+ var sourceKeys = Object.keys(source);
1041
+ var key, i;
1042
+ for(i = 0; i < sourceKeys.length; i++){
1043
+ key = sourceKeys[i];
1044
+ if (excluded.indexOf(key) >= 0) continue;
1045
+ target[key] = source[key];
1046
+ }
1047
+ return target;
1048
+ }
1049
+ var InputOTP = /*#__PURE__*/ React__namespace.forwardRef(function(_param, ref) {
1050
+ var className = _param.className, containerClassName = _param.containerClassName, props = _object_without_properties(_param, [
1051
+ "className",
1052
+ "containerClassName"
1053
+ ]);
1054
+ return /*#__PURE__*/ jsxRuntime.jsx(inputOtp.OTPInput, _object_spread$2({
1055
+ ref: ref,
1056
+ containerClassName: utils.cn("flex items-center gap-2 has-[:disabled]:opacity-50", containerClassName),
1057
+ className: utils.cn("disabled:cursor-not-allowed", className)
1058
+ }, props));
1059
+ });
1060
+ var InputOTPGroup = /*#__PURE__*/ React__namespace.forwardRef(function(_param, ref) {
1061
+ var className = _param.className, props = _object_without_properties(_param, [
1062
+ "className"
1063
+ ]);
1064
+ return /*#__PURE__*/ jsxRuntime.jsx("div", _object_spread$2({
1065
+ ref: ref,
1066
+ className: utils.cn("flex items-center", className)
1067
+ }, props));
1068
+ });
1069
+ var InputOTPSlot = /*#__PURE__*/ React__namespace.forwardRef(function(_param, ref) {
1070
+ var index = _param.index, className = _param.className, ringClassName = _param.ringClassName, props = _object_without_properties(_param, [
1071
+ "index",
1072
+ "className",
1073
+ "ringClassName"
1074
+ ]);
1075
+ var inputOTPContext = React__namespace.useContext(inputOtp.OTPInputContext);
1076
+ var _inputOTPContext_slots_index = inputOTPContext.slots[index], char = _inputOTPContext_slots_index.char, hasFakeCaret = _inputOTPContext_slots_index.hasFakeCaret, isActive = _inputOTPContext_slots_index.isActive;
1077
+ return /*#__PURE__*/ jsxRuntime.jsxs("div", _object_spread_props$2(_object_spread$2({
1078
+ ref: ref,
1079
+ className: utils.cn("relative flex h-9 w-9 items-center justify-center border-y border-r border-input text-sm shadow-sm transition-all first:rounded-l-md first:border-l last:rounded-r-md", isActive && "z-10 ring-1 ".concat(ringClassName), className)
1080
+ }, props), {
1081
+ children: [
1082
+ char,
1083
+ hasFakeCaret && /*#__PURE__*/ jsxRuntime.jsx("div", {
1084
+ className: "pointer-events-none absolute inset-0 flex items-center justify-center",
1085
+ children: /*#__PURE__*/ jsxRuntime.jsx("div", {
1086
+ className: "h-4 w-px animate-caret-blink bg-foreground duration-1000"
1087
+ })
1088
+ })
1089
+ ]
1090
+ }));
1091
+ });
1092
+ var InputOTPSeparator = /*#__PURE__*/ React__namespace.forwardRef(function(_param, ref) {
1093
+ var props = _extends({}, _object_destructuring_empty(_param));
1094
+ return /*#__PURE__*/ jsxRuntime.jsx("div", _object_spread_props$2(_object_spread$2({
1095
+ ref: ref,
1096
+ role: "separator"
1097
+ }, props), {
1098
+ children: /*#__PURE__*/ jsxRuntime.jsx(react.Icon, {
1099
+ icon: "octicon:dash-16"
1100
+ })
1101
+ }));
1102
+ });
1103
+
1104
+ function Spin(props) {
1105
+ var show = props.show, _props_overlayBackground = props.overlayBackground, overlayBackground = _props_overlayBackground === void 0 ? "bg-[#00000055]" : _props_overlayBackground;
1106
+ return show ? /*#__PURE__*/ jsxRuntime.jsx("div", {
1107
+ className: [
1108
+ "fixed flex justify-center items-center w-full h-full left-0 top-0 z-[9999] overflow-hidden",
1109
+ overlayBackground
1110
+ ].join(" "),
1111
+ children: /*#__PURE__*/ jsxRuntime.jsx("div", {
1112
+ className: "top-2/4 left-2/4",
1113
+ children: /*#__PURE__*/ jsxRuntime.jsx("div", {
1114
+ className: "w-10 h-10 rounded-full border-4 border-solid border-[#ffffff33] border-t-[#dbdbdb] animate-spin"
1115
+ })
1116
+ })
1117
+ }) : null;
1118
+ }
1119
+
1120
+ var COLORS = [
1121
+ "blue",
1122
+ "orange",
1123
+ "yellow",
1124
+ "red",
1125
+ "purple",
1126
+ "amber",
1127
+ "lime",
1128
+ "green",
1129
+ "emerald",
1130
+ "teal",
1131
+ "cyan",
1132
+ "sky",
1133
+ "violet",
1134
+ "indigo",
1135
+ "purple",
1136
+ "fuchsia",
1137
+ "pink",
1138
+ "rose"
1139
+ ];
1140
+ var DEFAULT_THEME = "blue";
1141
+ var THEME_DATA = {
1142
+ bg: {
1143
+ blue: "bg-blue-500",
1144
+ orange: "bg-orange-500",
1145
+ yellow: "bg-yellow-500",
1146
+ red: "bg-red-500",
1147
+ purple: "bg-purple-500",
1148
+ amber: "bg-amber-500",
1149
+ lime: "bg-lime-500",
1150
+ green: "bg-green-500",
1151
+ emerald: "bg-emerald-500",
1152
+ teal: "bg-teal-500",
1153
+ cyan: "bg-cyan-500",
1154
+ sky: "bg-sky-500",
1155
+ indigo: "bg-indigo-500",
1156
+ violet: "bg-violet-500",
1157
+ fuchsia: "bg-fuchsia-500",
1158
+ pink: "bg-pink-500",
1159
+ rose: "bg-rose-500"
1160
+ },
1161
+ bgHover: {
1162
+ blue: "hover:bg-blue-100",
1163
+ orange: "hover:bg-orange-100",
1164
+ yellow: "hover:bg-yellow-100",
1165
+ red: "hover:bg-red-100",
1166
+ purple: "hover:bg-purple-100",
1167
+ amber: "hover:bg-amber-100",
1168
+ lime: "hover:bg-lime-100",
1169
+ green: "hover:bg-green-100",
1170
+ emerald: "hover:bg-emerald-100",
1171
+ teal: "hover:bg-teal-100",
1172
+ cyan: "hover:bg-cyan-100",
1173
+ sky: "hover:bg-sky-100",
1174
+ indigo: "hover:bg-indigo-100",
1175
+ violet: "hover:bg-violet-100",
1176
+ fuchsia: "hover:bg-fuchsia-100",
1177
+ pink: "hover:bg-pink-100",
1178
+ rose: "hover:bg-rose-100"
1179
+ },
1180
+ ring: {
1181
+ blue: "focus:ring-blue-500/20",
1182
+ orange: "focus:ring-orange-500/20",
1183
+ yellow: "focus:ring-yellow-500/20",
1184
+ red: "focus:ring-red-500/20",
1185
+ purple: "focus:ring-purple-500/20",
1186
+ amber: "focus:ring-amber-500/20",
1187
+ lime: "focus:ring-lime-500/20",
1188
+ green: "focus:ring-green-500/20",
1189
+ emerald: "focus:ring-emerald-500/20",
1190
+ teal: "focus:ring-teal-500/20",
1191
+ cyan: "focus:ring-cyan-500/20",
1192
+ sky: "focus:ring-sky-500/20",
1193
+ indigo: "focus:ring-indigo-500/20",
1194
+ violet: "focus:ring-violet-500/20",
1195
+ fuchsia: "focus:ring-fuchsia-500/20",
1196
+ pink: "focus:ring-pink-500/20",
1197
+ rose: "focus:ring-rose-500/20"
1198
+ },
1199
+ borderFocus: {
1200
+ blue: "focus:border-blue-500",
1201
+ orange: "focus:border-orange-500",
1202
+ yellow: "focus:border-yellow-500",
1203
+ red: "focus:border-red-500",
1204
+ purple: "focus:border-purple-500",
1205
+ amber: "focus:border-amber-500",
1206
+ lime: "focus:border-lime-500",
1207
+ green: "focus:border-green-500",
1208
+ emerald: "focus:border-emerald-500",
1209
+ teal: "focus:border-teal-500",
1210
+ cyan: "focus:border-cyan-500",
1211
+ sky: "focus:border-sky-500",
1212
+ indigo: "focus:border-indigo-500",
1213
+ violet: "focus:border-violet-500",
1214
+ fuchsia: "focus:border-fuchsia-500",
1215
+ pink: "focus:border-pink-500",
1216
+ rose: "focus:border-rose-500"
1217
+ },
1218
+ text: {
1219
+ blue: "text-blue-500",
1220
+ orange: "text-orange-500",
1221
+ yellow: "text-yellow-500",
1222
+ red: "text-red-500",
1223
+ purple: "text-purple-500",
1224
+ amber: "text-amber-500",
1225
+ lime: "text-lime-500",
1226
+ green: "text-green-500",
1227
+ emerald: "text-emerald-500",
1228
+ teal: "text-teal-500",
1229
+ cyan: "text-cyan-500",
1230
+ sky: "text-sky-500",
1231
+ indigo: "text-indigo-500",
1232
+ violet: "text-violet-500",
1233
+ fuchsia: "text-fuchsia-500",
1234
+ pink: "text-pink-500",
1235
+ rose: "text-rose-500"
1236
+ },
1237
+ textHover: {
1238
+ blue: "hover:text-blue-500",
1239
+ orange: "hover:text-orange-500",
1240
+ yellow: "hover:text-yellow-500",
1241
+ red: "hover:text-red-500",
1242
+ purple: "hover:text-purple-500",
1243
+ amber: "hover:text-amber-500",
1244
+ lime: "hover:text-lime-500",
1245
+ green: "hover:text-green-500",
1246
+ emerald: "hover:text-emerald-500",
1247
+ teal: "hover:text-teal-500",
1248
+ cyan: "hover:text-cyan-500",
1249
+ sky: "hover:text-sky-500",
1250
+ indigo: "hover:text-indigo-500",
1251
+ violet: "hover:text-violet-500",
1252
+ fuchsia: "hover:text-fuchsia-500",
1253
+ pink: "hover:text-pink-500",
1254
+ rose: "hover:text-rose-500"
1255
+ }
1256
+ };
1257
+
1258
+ function useOnClickOutside(ref, handler) {
1259
+ React.useEffect(function() {
1260
+ var listener = function(event) {
1261
+ if (!ref.current || ref.current.contains(event.target)) {
1262
+ return;
1263
+ }
1264
+ handler(event);
1265
+ };
1266
+ document.addEventListener("mousedown", listener);
1267
+ document.addEventListener("touchstart", listener);
1268
+ return function() {
1269
+ document.removeEventListener("mousedown", listener);
1270
+ document.removeEventListener("touchstart", listener);
1271
+ };
1272
+ }, [
1273
+ ref,
1274
+ handler
1275
+ ]);
1276
+ }
1277
+
1278
+ var CloseIcon = function(param) {
1279
+ var _param_className = param.className, className = _param_className === void 0 ? "" : _param_className;
1280
+ return /*#__PURE__*/ jsxRuntime.jsx("svg", {
1281
+ className: className,
1282
+ fill: "currentColor",
1283
+ viewBox: "0 0 20 20",
1284
+ xmlns: "http://www.w3.org/2000/svg",
1285
+ children: /*#__PURE__*/ jsxRuntime.jsx("path", {
1286
+ fillRule: "evenodd",
1287
+ d: "M4.293 4.293a1 1 0 011.414 0L10 8.586l4.293-4.293a1 1 0 111.414 1.414L11.414 10l4.293 4.293a1 1 0 01-1.414 1.414L10 11.414l-4.293 4.293a1 1 0 01-1.414-1.414L8.586 10 4.293 5.707a1 1 0 010-1.414z",
1288
+ clipRule: "evenodd"
1289
+ })
1290
+ });
1291
+ };
1292
+ var ChevronIcon = function(param) {
1293
+ var _param_className = param.className, className = _param_className === void 0 ? "" : _param_className;
1294
+ return /*#__PURE__*/ jsxRuntime.jsx("svg", {
1295
+ className: className,
1296
+ fill: "currentColor",
1297
+ viewBox: "0 0 20 20",
1298
+ xmlns: "http://www.w3.org/2000/svg",
1299
+ children: /*#__PURE__*/ jsxRuntime.jsx("path", {
1300
+ fillRule: "evenodd",
1301
+ d: "M7.293 14.707a1 1 0 010-1.414L10.586 10 7.293 6.707a1 1 0 011.414-1.414l4 4a1 1 0 010 1.414l-4 4a1 1 0 01-1.414 0z",
1302
+ clipRule: "evenodd"
1303
+ })
1304
+ });
1305
+ };
1306
+ var SearchIcon = function(param) {
1307
+ var _param_className = param.className, className = _param_className === void 0 ? "" : _param_className;
1308
+ return /*#__PURE__*/ jsxRuntime.jsx("svg", {
1309
+ className: className,
1310
+ fill: "none",
1311
+ stroke: "currentColor",
1312
+ viewBox: "0 0 24 24",
1313
+ xmlns: "http://www.w3.org/2000/svg",
1314
+ children: /*#__PURE__*/ jsxRuntime.jsx("path", {
1315
+ strokeLinecap: "round",
1316
+ strokeLinejoin: "round",
1317
+ strokeWidth: 2,
1318
+ d: "M21 21l-6-6m2-5a7 7 0 11-14 0 7 7 0 0114 0z"
1319
+ })
1320
+ });
1321
+ };
1322
+
1323
+ var SelectContext = /*#__PURE__*/ React.createContext({
1324
+ value: null,
1325
+ handleValueChange: function(selected) {
1326
+ console.log("selected:", selected);
1327
+ },
1328
+ formatGroupLabel: null,
1329
+ formatOptionLabel: null,
1330
+ classNames: undefined
1331
+ });
1332
+ var useSelectContext = function() {
1333
+ return React.useContext(SelectContext);
1334
+ };
1335
+ var SelectProvider = function(param) {
1336
+ var value = param.value, handleValueChange = param.handleValueChange, otherData = param.otherData, children = param.children;
1337
+ var store = React.useMemo(function() {
1338
+ return {
1339
+ value: value,
1340
+ handleValueChange: handleValueChange,
1341
+ formatGroupLabel: otherData && typeof otherData.formatGroupLabel === "function" ? otherData.formatGroupLabel : null,
1342
+ formatOptionLabel: otherData && typeof otherData.formatOptionLabel === "function" ? otherData.formatOptionLabel : null,
1343
+ classNames: (otherData === null || otherData === void 0 ? void 0 : otherData.classNames) || undefined
1344
+ };
1345
+ }, [
1346
+ handleValueChange,
1347
+ otherData,
1348
+ value
1349
+ ]);
1350
+ return /*#__PURE__*/ jsxRuntime.jsx(SelectContext.Provider, {
1351
+ value: store,
1352
+ children: children
1353
+ });
1354
+ };
1355
+
1356
+ var DisabledItem = function(param) {
1357
+ var children = param.children;
1358
+ var classNames = React.useContext(SelectContext).classNames;
1359
+ return /*#__PURE__*/ jsxRuntime.jsx("div", {
1360
+ className: classNames && classNames.listDisabledItem ? classNames.listDisabledItem : "px-2 py-2 cursor-not-allowed truncate text-gray-400 select-none",
1361
+ children: children
1362
+ });
1363
+ };
1364
+
1365
+ function _define_property$1(obj, key, value) {
1366
+ if (key in obj) {
1367
+ Object.defineProperty(obj, key, {
1368
+ value: value,
1369
+ enumerable: true,
1370
+ configurable: true,
1371
+ writable: true
1372
+ });
1373
+ } else {
1374
+ obj[key] = value;
1375
+ }
1376
+ return obj;
1377
+ }
1378
+ function _object_spread$1(target) {
1379
+ for(var i = 1; i < arguments.length; i++){
1380
+ var source = arguments[i] != null ? arguments[i] : {};
1381
+ var ownKeys = Object.keys(source);
1382
+ if (typeof Object.getOwnPropertySymbols === "function") {
1383
+ ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {
1384
+ return Object.getOwnPropertyDescriptor(source, sym).enumerable;
1385
+ }));
1386
+ }
1387
+ ownKeys.forEach(function(key) {
1388
+ _define_property$1(target, key, source[key]);
1389
+ });
1390
+ }
1391
+ return target;
1392
+ }
1393
+ function ownKeys$1(object, enumerableOnly) {
1394
+ var keys = Object.keys(object);
1395
+ if (Object.getOwnPropertySymbols) {
1396
+ var symbols = Object.getOwnPropertySymbols(object);
1397
+ if (enumerableOnly) {
1398
+ symbols = symbols.filter(function(sym) {
1399
+ return Object.getOwnPropertyDescriptor(object, sym).enumerable;
1400
+ });
1401
+ }
1402
+ keys.push.apply(keys, symbols);
1403
+ }
1404
+ return keys;
1405
+ }
1406
+ function _object_spread_props$1(target, source) {
1407
+ source = source != null ? source : {};
1408
+ if (Object.getOwnPropertyDescriptors) {
1409
+ Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
1410
+ } else {
1411
+ ownKeys$1(Object(source)).forEach(function(key) {
1412
+ Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
1413
+ });
1414
+ }
1415
+ return target;
1416
+ }
1417
+ var Item = function(param) {
1418
+ var item = param.item, primaryColor = param.primaryColor;
1419
+ var _useSelectContext = useSelectContext(), classNames = _useSelectContext.classNames, value = _useSelectContext.value, handleValueChange = _useSelectContext.handleValueChange, formatOptionLabel = _useSelectContext.formatOptionLabel;
1420
+ var isSelected = React.useMemo(function() {
1421
+ return value !== null && !Array.isArray(value) && value.value === item.value;
1422
+ }, [
1423
+ item.value,
1424
+ value
1425
+ ]);
1426
+ var textHoverColor = React.useMemo(function() {
1427
+ if (COLORS.includes(primaryColor)) {
1428
+ return THEME_DATA.textHover[primaryColor];
1429
+ }
1430
+ return THEME_DATA.textHover[DEFAULT_THEME];
1431
+ }, [
1432
+ primaryColor
1433
+ ]);
1434
+ var bgColor = React.useMemo(function() {
1435
+ if (COLORS.includes(primaryColor)) {
1436
+ return THEME_DATA.bg[primaryColor];
1437
+ }
1438
+ return THEME_DATA.bg[DEFAULT_THEME];
1439
+ }, [
1440
+ primaryColor
1441
+ ]);
1442
+ var bgHoverColor = React.useMemo(function() {
1443
+ if (COLORS.includes(primaryColor)) {
1444
+ return THEME_DATA.bgHover[primaryColor];
1445
+ }
1446
+ return THEME_DATA.bgHover[DEFAULT_THEME];
1447
+ }, [
1448
+ primaryColor
1449
+ ]);
1450
+ var getItemClass = React.useCallback(function() {
1451
+ var baseClass = "block transition duration-200 px-2 py-2 cursor-pointer select-none truncate rounded";
1452
+ var selectedClass = isSelected ? "text-white ".concat(bgColor) : "text-gray-500 ".concat(bgHoverColor, " ").concat(textHoverColor);
1453
+ return classNames && classNames.listItem ? classNames.listItem({
1454
+ isSelected: isSelected
1455
+ }) : "".concat(baseClass, " ").concat(selectedClass);
1456
+ }, [
1457
+ bgColor,
1458
+ bgHoverColor,
1459
+ classNames,
1460
+ isSelected,
1461
+ textHoverColor
1462
+ ]);
1463
+ return /*#__PURE__*/ jsxRuntime.jsx(jsxRuntime.Fragment, {
1464
+ children: formatOptionLabel ? /*#__PURE__*/ jsxRuntime.jsx("div", {
1465
+ onClick: function() {
1466
+ return handleValueChange(item);
1467
+ },
1468
+ children: formatOptionLabel(_object_spread_props$1(_object_spread$1({}, item), {
1469
+ isSelected: isSelected
1470
+ }))
1471
+ }) : /*#__PURE__*/ jsxRuntime.jsx(jsxRuntime.Fragment, {
1472
+ children: item.disabled ? /*#__PURE__*/ jsxRuntime.jsx(DisabledItem, {
1473
+ children: item.label
1474
+ }) : /*#__PURE__*/ jsxRuntime.jsx("li", {
1475
+ tabIndex: 0,
1476
+ onKeyDown: function(e) {
1477
+ if (e.key === " " || e.key === "Enter") {
1478
+ handleValueChange(item);
1479
+ }
1480
+ },
1481
+ "aria-selected": isSelected,
1482
+ role: "option",
1483
+ onClick: function() {
1484
+ return handleValueChange(item);
1485
+ },
1486
+ className: getItemClass(),
1487
+ children: item.label
1488
+ })
1489
+ })
1490
+ });
1491
+ };
1492
+
1493
+ var GroupItem = function(param) {
1494
+ var item = param.item, primaryColor = param.primaryColor;
1495
+ var _useSelectContext = useSelectContext(), classNames = _useSelectContext.classNames, formatGroupLabel = _useSelectContext.formatGroupLabel;
1496
+ return /*#__PURE__*/ jsxRuntime.jsx(jsxRuntime.Fragment, {
1497
+ children: item.options.length > 0 && /*#__PURE__*/ jsxRuntime.jsxs(jsxRuntime.Fragment, {
1498
+ children: [
1499
+ formatGroupLabel ? /*#__PURE__*/ jsxRuntime.jsx(jsxRuntime.Fragment, {
1500
+ children: formatGroupLabel(item)
1501
+ }) : /*#__PURE__*/ jsxRuntime.jsx("div", {
1502
+ className: (classNames === null || classNames === void 0 ? void 0 : classNames.listGroupLabel) ? classNames.listGroupLabel : "pr-2 py-2 cursor-default select-none truncate font-bold text-gray-700",
1503
+ children: item.label
1504
+ }),
1505
+ item.options.map(function(item, index) {
1506
+ return /*#__PURE__*/ jsxRuntime.jsx(Item, {
1507
+ primaryColor: primaryColor,
1508
+ item: item
1509
+ }, index);
1510
+ })
1511
+ ]
1512
+ })
1513
+ });
1514
+ };
1515
+
1516
+ var Options = function(param) {
1517
+ var list = param.list, noOptionsMessage = param.noOptionsMessage, text = param.text, isMultiple = param.isMultiple, value = param.value, _param_primaryColor = param.primaryColor, primaryColor = _param_primaryColor === void 0 ? DEFAULT_THEME : _param_primaryColor;
1518
+ var classNames = React.useContext(SelectContext).classNames;
1519
+ var filterByText = React.useCallback(function() {
1520
+ var filterItem = function(item) {
1521
+ return item.label.toLowerCase().indexOf(text.toLowerCase()) > -1;
1522
+ };
1523
+ var result = list.map(function(item) {
1524
+ if ("options" in item) {
1525
+ return {
1526
+ label: item.label,
1527
+ options: item.options.filter(filterItem)
1528
+ };
1529
+ }
1530
+ return item;
1531
+ });
1532
+ result = result.filter(function(item) {
1533
+ if ("options" in item) {
1534
+ return item.options.length > 0;
1535
+ }
1536
+ return filterItem(item);
1537
+ });
1538
+ return result;
1539
+ }, [
1540
+ text,
1541
+ list
1542
+ ]);
1543
+ var removeValues = React.useCallback(function(array) {
1544
+ if (!isMultiple) {
1545
+ return array;
1546
+ }
1547
+ if (Array.isArray(value)) {
1548
+ var valueId = value.map(function(item) {
1549
+ return item.value;
1550
+ });
1551
+ var filterItem = function(item) {
1552
+ return !valueId.includes(item.value);
1553
+ };
1554
+ var newArray = array.map(function(item) {
1555
+ if ("options" in item) {
1556
+ return {
1557
+ label: item.label,
1558
+ options: item.options.filter(filterItem)
1559
+ };
1560
+ }
1561
+ return item;
1562
+ });
1563
+ newArray = newArray.filter(function(item) {
1564
+ if ("options" in item) {
1565
+ return item.options.length > 0;
1566
+ } else {
1567
+ return filterItem(item);
1568
+ }
1569
+ });
1570
+ return newArray;
1571
+ }
1572
+ return array;
1573
+ }, [
1574
+ isMultiple,
1575
+ value
1576
+ ]);
1577
+ var filterResult = React.useMemo(function() {
1578
+ return removeValues(filterByText());
1579
+ }, [
1580
+ filterByText,
1581
+ removeValues
1582
+ ]);
1583
+ return /*#__PURE__*/ jsxRuntime.jsxs("div", {
1584
+ role: "options",
1585
+ className: classNames && classNames.list ? classNames.list : "max-h-72 overflow-y-auto",
1586
+ children: [
1587
+ filterResult.map(function(item, index) {
1588
+ return /*#__PURE__*/ jsxRuntime.jsx(React__default["default"].Fragment, {
1589
+ children: "options" in item ? /*#__PURE__*/ jsxRuntime.jsxs(jsxRuntime.Fragment, {
1590
+ children: [
1591
+ /*#__PURE__*/ jsxRuntime.jsx("div", {
1592
+ className: "px-2.5",
1593
+ children: /*#__PURE__*/ jsxRuntime.jsx(GroupItem, {
1594
+ primaryColor: primaryColor || DEFAULT_THEME,
1595
+ item: item
1596
+ })
1597
+ }),
1598
+ index + 1 < filterResult.length && /*#__PURE__*/ jsxRuntime.jsx("hr", {
1599
+ className: "my-1"
1600
+ })
1601
+ ]
1602
+ }) : /*#__PURE__*/ jsxRuntime.jsx("div", {
1603
+ className: "px-2.5",
1604
+ children: /*#__PURE__*/ jsxRuntime.jsx(Item, {
1605
+ primaryColor: primaryColor || DEFAULT_THEME,
1606
+ item: item
1607
+ })
1608
+ })
1609
+ }, index);
1610
+ }),
1611
+ filterResult.length === 0 && /*#__PURE__*/ jsxRuntime.jsx(DisabledItem, {
1612
+ children: noOptionsMessage
1613
+ })
1614
+ ]
1615
+ });
1616
+ };
1617
+
1618
+ var SearchInput = /*#__PURE__*/ React.forwardRef(function SearchInput(param, ref) {
1619
+ var _param_placeholder = param.placeholder, placeholder = _param_placeholder === void 0 ? "" : _param_placeholder, _param_value = param.value, value = _param_value === void 0 ? "" : _param_value, onChange = param.onChange, _param_name = param.name, name = _param_name === void 0 ? "" : _param_name;
1620
+ var classNames = React.useContext(SelectContext).classNames;
1621
+ return /*#__PURE__*/ jsxRuntime.jsxs("div", {
1622
+ className: classNames && classNames.searchContainer ? classNames.searchContainer : "relative py-1 px-2.5",
1623
+ children: [
1624
+ /*#__PURE__*/ jsxRuntime.jsx(SearchIcon, {
1625
+ className: classNames && classNames.searchIcon ? classNames.searchIcon : "absolute w-5 h-5 mt-2.5 pb-0.5 ml-2 text-gray-500"
1626
+ }),
1627
+ /*#__PURE__*/ jsxRuntime.jsx("input", {
1628
+ ref: ref,
1629
+ className: classNames && classNames.searchBox ? classNames.searchBox : "w-full py-2 pl-8 text-sm text-gray-500 bg-gray-100 border border-gray-200 rounded focus:border-gray-200 focus:ring-0 focus:outline-none",
1630
+ type: "text",
1631
+ placeholder: placeholder,
1632
+ value: value,
1633
+ onChange: onChange,
1634
+ name: name
1635
+ })
1636
+ ]
1637
+ });
1638
+ });
1639
+
1640
+ var Spinner = function(param) {
1641
+ var _param_primaryColor = param.primaryColor, primaryColor = _param_primaryColor === void 0 ? DEFAULT_THEME : _param_primaryColor;
1642
+ var spinnerColor = React.useMemo(function() {
1643
+ if (COLORS.includes(primaryColor)) {
1644
+ return THEME_DATA.text[primaryColor];
1645
+ }
1646
+ return THEME_DATA.text[DEFAULT_THEME];
1647
+ }, [
1648
+ primaryColor
1649
+ ]);
1650
+ return /*#__PURE__*/ jsxRuntime.jsxs("svg", {
1651
+ className: "animate-spin mr-0.5 h-5 w-5 ".concat(spinnerColor),
1652
+ xmlns: "http://www.w3.org/2000/svg",
1653
+ fill: "none",
1654
+ viewBox: "0 0 24 24",
1655
+ children: [
1656
+ /*#__PURE__*/ jsxRuntime.jsx("circle", {
1657
+ className: "opacity-25",
1658
+ cx: "12",
1659
+ cy: "12",
1660
+ r: "10",
1661
+ stroke: "currentColor",
1662
+ strokeWidth: "4"
1663
+ }),
1664
+ /*#__PURE__*/ jsxRuntime.jsx("path", {
1665
+ className: "opacity-75",
1666
+ fill: "currentColor",
1667
+ d: "M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 014 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z"
1668
+ })
1669
+ ]
1670
+ });
1671
+ };
1672
+
1673
+ function _array_like_to_array(arr, len) {
1674
+ if (len == null || len > arr.length) len = arr.length;
1675
+ for(var i = 0, arr2 = new Array(len); i < len; i++)arr2[i] = arr[i];
1676
+ return arr2;
1677
+ }
1678
+ function _array_with_holes(arr) {
1679
+ if (Array.isArray(arr)) return arr;
1680
+ }
1681
+ function _array_without_holes(arr) {
1682
+ if (Array.isArray(arr)) return _array_like_to_array(arr);
1683
+ }
1684
+ function _define_property(obj, key, value) {
1685
+ if (key in obj) {
1686
+ Object.defineProperty(obj, key, {
1687
+ value: value,
1688
+ enumerable: true,
1689
+ configurable: true,
1690
+ writable: true
1691
+ });
1692
+ } else {
1693
+ obj[key] = value;
1694
+ }
1695
+ return obj;
1696
+ }
1697
+ function _iterable_to_array(iter) {
1698
+ if (typeof Symbol !== "undefined" && iter[Symbol.iterator] != null || iter["@@iterator"] != null) return Array.from(iter);
1699
+ }
1700
+ function _iterable_to_array_limit(arr, i) {
1701
+ var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"];
1702
+ if (_i == null) return;
1703
+ var _arr = [];
1704
+ var _n = true;
1705
+ var _d = false;
1706
+ var _s, _e;
1707
+ try {
1708
+ for(_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true){
1709
+ _arr.push(_s.value);
1710
+ if (i && _arr.length === i) break;
1711
+ }
1712
+ } catch (err) {
1713
+ _d = true;
1714
+ _e = err;
1715
+ } finally{
1716
+ try {
1717
+ if (!_n && _i["return"] != null) _i["return"]();
1718
+ } finally{
1719
+ if (_d) throw _e;
1720
+ }
1721
+ }
1722
+ return _arr;
1723
+ }
1724
+ function _non_iterable_rest() {
1725
+ throw new TypeError("Invalid attempt to destructure non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
1726
+ }
1727
+ function _non_iterable_spread() {
1728
+ throw new TypeError("Invalid attempt to spread non-iterable instance.\\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
1729
+ }
1730
+ function _object_spread(target) {
1731
+ for(var i = 1; i < arguments.length; i++){
1732
+ var source = arguments[i] != null ? arguments[i] : {};
1733
+ var ownKeys = Object.keys(source);
1734
+ if (typeof Object.getOwnPropertySymbols === "function") {
1735
+ ownKeys = ownKeys.concat(Object.getOwnPropertySymbols(source).filter(function(sym) {
1736
+ return Object.getOwnPropertyDescriptor(source, sym).enumerable;
1737
+ }));
1738
+ }
1739
+ ownKeys.forEach(function(key) {
1740
+ _define_property(target, key, source[key]);
1741
+ });
1742
+ }
1743
+ return target;
1744
+ }
1745
+ function ownKeys(object, enumerableOnly) {
1746
+ var keys = Object.keys(object);
1747
+ if (Object.getOwnPropertySymbols) {
1748
+ var symbols = Object.getOwnPropertySymbols(object);
1749
+ if (enumerableOnly) {
1750
+ symbols = symbols.filter(function(sym) {
1751
+ return Object.getOwnPropertyDescriptor(object, sym).enumerable;
1752
+ });
1753
+ }
1754
+ keys.push.apply(keys, symbols);
1755
+ }
1756
+ return keys;
1757
+ }
1758
+ function _object_spread_props(target, source) {
1759
+ source = source != null ? source : {};
1760
+ if (Object.getOwnPropertyDescriptors) {
1761
+ Object.defineProperties(target, Object.getOwnPropertyDescriptors(source));
1762
+ } else {
1763
+ ownKeys(Object(source)).forEach(function(key) {
1764
+ Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key));
1765
+ });
1766
+ }
1767
+ return target;
1768
+ }
1769
+ function _sliced_to_array(arr, i) {
1770
+ return _array_with_holes(arr) || _iterable_to_array_limit(arr, i) || _unsupported_iterable_to_array(arr, i) || _non_iterable_rest();
1771
+ }
1772
+ function _to_consumable_array(arr) {
1773
+ return _array_without_holes(arr) || _iterable_to_array(arr) || _unsupported_iterable_to_array(arr) || _non_iterable_spread();
1774
+ }
1775
+ function _unsupported_iterable_to_array(o, minLen) {
1776
+ if (!o) return;
1777
+ if (typeof o === "string") return _array_like_to_array(o, minLen);
1778
+ var n = Object.prototype.toString.call(o).slice(8, -1);
1779
+ if (n === "Object" && o.constructor) n = o.constructor.name;
1780
+ if (n === "Map" || n === "Set") return Array.from(n);
1781
+ if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _array_like_to_array(o, minLen);
1782
+ }
1783
+ var DropDown = function(param) {
1784
+ var _param_options = param.options, options = _param_options === void 0 ? [] : _param_options, _param_value = param.value, value = _param_value === void 0 ? null : _param_value, onChange = param.onChange, onSearchInputChange = param.onSearchInputChange, _param_placeholder = param.placeholder, placeholder = _param_placeholder === void 0 ? "Select..." : _param_placeholder, _param_searchInputPlaceholder = param.searchInputPlaceholder, searchInputPlaceholder = _param_searchInputPlaceholder === void 0 ? "Search..." : _param_searchInputPlaceholder, _param_isMultiple = param.isMultiple, isMultiple = _param_isMultiple === void 0 ? false : _param_isMultiple, _param_isClearable = param.isClearable, isClearable = _param_isClearable === void 0 ? false : _param_isClearable, _param_isSearchable = param.isSearchable, isSearchable = _param_isSearchable === void 0 ? false : _param_isSearchable, _param_isDisabled = param.isDisabled, isDisabled = _param_isDisabled === void 0 ? false : _param_isDisabled, _param_loading = param.loading, loading = _param_loading === void 0 ? false : _param_loading, _param_menuIsOpen = param.menuIsOpen, menuIsOpen = _param_menuIsOpen === void 0 ? false : _param_menuIsOpen, _param_noOptionsMessage = param.noOptionsMessage, noOptionsMessage = _param_noOptionsMessage === void 0 ? "No options found" : _param_noOptionsMessage, _param_primaryColor = param.primaryColor, primaryColor = _param_primaryColor === void 0 ? DEFAULT_THEME : _param_primaryColor, _param_formatGroupLabel = param.formatGroupLabel, formatGroupLabel = _param_formatGroupLabel === void 0 ? null : _param_formatGroupLabel, _param_formatOptionLabel = param.formatOptionLabel, formatOptionLabel = _param_formatOptionLabel === void 0 ? null : _param_formatOptionLabel, classNames = param.classNames;
1785
+ var _useState = _sliced_to_array(React.useState(menuIsOpen), 2), open = _useState[0], setOpen = _useState[1];
1786
+ var _useState1 = _sliced_to_array(React.useState(options), 2), list = _useState1[0], setList = _useState1[1];
1787
+ var _useState2 = _sliced_to_array(React.useState(""), 2), inputValue = _useState2[0], setInputValue = _useState2[1];
1788
+ var ref = React.useRef(null);
1789
+ var searchBoxRef = React.useRef(null);
1790
+ React.useEffect(function() {
1791
+ var formatItem = function(item) {
1792
+ if ("disabled" in item) return item;
1793
+ return _object_spread_props(_object_spread({}, item), {
1794
+ disabled: false
1795
+ });
1796
+ };
1797
+ setList(options.map(function(item) {
1798
+ if ("options" in item) {
1799
+ return {
1800
+ label: item.label,
1801
+ options: item.options.map(formatItem)
1802
+ };
1803
+ } else {
1804
+ return formatItem(item);
1805
+ }
1806
+ }));
1807
+ }, [
1808
+ options
1809
+ ]);
1810
+ React.useEffect(function() {
1811
+ if (isSearchable) {
1812
+ if (open) {
1813
+ var _searchBoxRef_current;
1814
+ (_searchBoxRef_current = searchBoxRef.current) === null || _searchBoxRef_current === void 0 ? void 0 : _searchBoxRef_current.select();
1815
+ } else {
1816
+ setInputValue("");
1817
+ }
1818
+ }
1819
+ }, [
1820
+ open,
1821
+ isSearchable
1822
+ ]);
1823
+ var toggle = React.useCallback(function() {
1824
+ if (!isDisabled) {
1825
+ setOpen(!open);
1826
+ }
1827
+ }, [
1828
+ isDisabled,
1829
+ open
1830
+ ]);
1831
+ var closeDropDown = React.useCallback(function() {
1832
+ if (open) setOpen(false);
1833
+ }, [
1834
+ open
1835
+ ]);
1836
+ useOnClickOutside(ref, function() {
1837
+ closeDropDown();
1838
+ });
1839
+ var onPressEnterOrSpace = React.useCallback(function(e) {
1840
+ e.preventDefault();
1841
+ if ((e.code === "Enter" || e.code === "Space") && !isDisabled) {
1842
+ toggle();
1843
+ }
1844
+ }, [
1845
+ isDisabled,
1846
+ toggle
1847
+ ]);
1848
+ var handleValueChange = React.useCallback(function(selected) {
1849
+ var update = function update() {
1850
+ if (!isMultiple && !Array.isArray(value)) {
1851
+ closeDropDown();
1852
+ onChange(selected);
1853
+ }
1854
+ if (isMultiple && (Array.isArray(value) || value === null)) {
1855
+ onChange(value === null ? [
1856
+ selected
1857
+ ] : _to_consumable_array(value).concat([
1858
+ selected
1859
+ ]));
1860
+ }
1861
+ };
1862
+ if (selected !== value) {
1863
+ update();
1864
+ }
1865
+ }, [
1866
+ closeDropDown,
1867
+ isMultiple,
1868
+ onChange,
1869
+ value
1870
+ ]);
1871
+ var clearValue = React.useCallback(function(e) {
1872
+ e.stopPropagation();
1873
+ onChange(null);
1874
+ }, [
1875
+ onChange
1876
+ ]);
1877
+ var removeItem = React.useCallback(function(e, item) {
1878
+ if (isMultiple && Array.isArray(value) && value.length) {
1879
+ e.stopPropagation();
1880
+ var result = value.filter(function(current) {
1881
+ return item.value !== current.value;
1882
+ });
1883
+ onChange(result.length ? result : null);
1884
+ }
1885
+ }, [
1886
+ isMultiple,
1887
+ onChange,
1888
+ value
1889
+ ]);
1890
+ var getSelectClass = React.useCallback(function() {
1891
+ var ringColor = THEME_DATA.ring[DEFAULT_THEME];
1892
+ if (COLORS.includes(primaryColor)) {
1893
+ ringColor = THEME_DATA.ring[primaryColor];
1894
+ }
1895
+ var borderFocus = THEME_DATA.borderFocus[DEFAULT_THEME];
1896
+ if (COLORS.includes(primaryColor)) {
1897
+ borderFocus = THEME_DATA.borderFocus[primaryColor];
1898
+ }
1899
+ var baseClass = "flex text-sm text-gray-500 border border-gray-300 rounded shadow-sm transition-all duration-300 focus:outline-none";
1900
+ var defaultClass = "".concat(baseClass, " ").concat(isDisabled ? "bg-gray-200" : "bg-white hover:border-gray-400 ".concat(borderFocus, " focus:ring ").concat(ringColor));
1901
+ return classNames && classNames.menuButton ? classNames.menuButton({
1902
+ isDisabled: isDisabled
1903
+ }) : defaultClass;
1904
+ }, [
1905
+ classNames,
1906
+ isDisabled,
1907
+ primaryColor
1908
+ ]);
1909
+ var getTagItemClass = React.useCallback(function(item) {
1910
+ var baseClasse = "bg-gray-200 border rounded-sm flex space-x-1";
1911
+ var disabledClass = isDisabled ? "border-gray-500 px-1" : "pl-1";
1912
+ return (classNames === null || classNames === void 0 ? void 0 : classNames.tagItem) ? classNames.tagItem({
1913
+ item: item,
1914
+ isDisabled: isDisabled
1915
+ }) : "".concat(baseClasse, " ").concat(disabledClass);
1916
+ }, [
1917
+ classNames,
1918
+ isDisabled
1919
+ ]);
1920
+ return /*#__PURE__*/ jsxRuntime.jsx(SelectProvider, {
1921
+ otherData: {
1922
+ formatGroupLabel: formatGroupLabel,
1923
+ formatOptionLabel: formatOptionLabel,
1924
+ classNames: classNames
1925
+ },
1926
+ value: value,
1927
+ handleValueChange: handleValueChange,
1928
+ children: /*#__PURE__*/ jsxRuntime.jsxs("div", {
1929
+ className: "relative w-full",
1930
+ ref: ref,
1931
+ children: [
1932
+ /*#__PURE__*/ jsxRuntime.jsxs("div", {
1933
+ "aria-expanded": open,
1934
+ onKeyDown: onPressEnterOrSpace,
1935
+ onClick: toggle,
1936
+ className: getSelectClass(),
1937
+ children: [
1938
+ /*#__PURE__*/ jsxRuntime.jsx("div", {
1939
+ className: "grow pl-2.5 py-2 pr-2 flex flex-wrap gap-1",
1940
+ children: !isMultiple ? /*#__PURE__*/ jsxRuntime.jsx("p", {
1941
+ className: "truncate cursor-default select-none",
1942
+ children: value && !Array.isArray(value) ? value.label : placeholder
1943
+ }) : /*#__PURE__*/ jsxRuntime.jsxs(jsxRuntime.Fragment, {
1944
+ children: [
1945
+ value === null && placeholder,
1946
+ Array.isArray(value) && value.map(function(item, index) {
1947
+ return /*#__PURE__*/ jsxRuntime.jsxs("div", {
1948
+ className: getTagItemClass(item),
1949
+ children: [
1950
+ /*#__PURE__*/ jsxRuntime.jsx("p", {
1951
+ className: (classNames === null || classNames === void 0 ? void 0 : classNames.tagItemText) ? classNames.tagItemText : "text-gray-600 truncate cursor-default select-none",
1952
+ children: item.label
1953
+ }),
1954
+ !isDisabled && /*#__PURE__*/ jsxRuntime.jsx("div", {
1955
+ role: "button",
1956
+ tabIndex: 0,
1957
+ onClick: function(e) {
1958
+ return removeItem(e, item);
1959
+ },
1960
+ className: (classNames === null || classNames === void 0 ? void 0 : classNames.tagItemIconContainer) ? classNames.tagItemIconContainer : "flex items-center px-1 cursor-pointer rounded-r-sm hover:bg-red-200 hover:text-red-600",
1961
+ children: /*#__PURE__*/ jsxRuntime.jsx(CloseIcon, {
1962
+ className: (classNames === null || classNames === void 0 ? void 0 : classNames.tagItemIcon) ? classNames.tagItemIcon : "w-3 h-3 mt-0.5"
1963
+ })
1964
+ })
1965
+ ]
1966
+ }, index);
1967
+ })
1968
+ ]
1969
+ })
1970
+ }),
1971
+ /*#__PURE__*/ jsxRuntime.jsxs("div", {
1972
+ className: "flex flex-none items-center py-1.5",
1973
+ children: [
1974
+ loading && /*#__PURE__*/ jsxRuntime.jsx("div", {
1975
+ className: "px-1.5",
1976
+ children: /*#__PURE__*/ jsxRuntime.jsx(Spinner, {
1977
+ primaryColor: primaryColor
1978
+ })
1979
+ }),
1980
+ isClearable && !isDisabled && value !== null && /*#__PURE__*/ jsxRuntime.jsx("div", {
1981
+ className: "px-1.5 cursor-pointer",
1982
+ onClick: clearValue,
1983
+ children: /*#__PURE__*/ jsxRuntime.jsx(CloseIcon, {
1984
+ className: (classNames === null || classNames === void 0 ? void 0 : classNames.closeIcon) ? classNames.closeIcon : "w-5 h-5 p-0.5"
1985
+ })
1986
+ }),
1987
+ /*#__PURE__*/ jsxRuntime.jsx("div", {
1988
+ className: "h-full",
1989
+ children: /*#__PURE__*/ jsxRuntime.jsx("span", {
1990
+ className: "w-px h-full inline-block text-white bg-gray-300 text-opacity-0"
1991
+ })
1992
+ }),
1993
+ /*#__PURE__*/ jsxRuntime.jsx("div", {
1994
+ className: "px-1.5",
1995
+ children: /*#__PURE__*/ jsxRuntime.jsx(ChevronIcon, {
1996
+ className: "transition duration-300 w-6 h-6 p-0.5".concat(open ? " transform rotate-90 text-gray-500" : " text-gray-300")
1997
+ })
1998
+ })
1999
+ ]
2000
+ })
2001
+ ]
2002
+ }),
2003
+ open && !isDisabled && /*#__PURE__*/ jsxRuntime.jsxs("div", {
2004
+ className: (classNames === null || classNames === void 0 ? void 0 : classNames.menu) ? classNames.menu : "absolute z-10 w-full bg-white shadow-lg border rounded py-1 mt-1.5 text-sm text-gray-700",
2005
+ children: [
2006
+ isSearchable && /*#__PURE__*/ jsxRuntime.jsx(SearchInput, {
2007
+ ref: searchBoxRef,
2008
+ value: inputValue,
2009
+ placeholder: searchInputPlaceholder,
2010
+ onChange: function(e) {
2011
+ if (onSearchInputChange && typeof onSearchInputChange === "function") onSearchInputChange(e);
2012
+ setInputValue(e.target.value);
2013
+ }
2014
+ }),
2015
+ /*#__PURE__*/ jsxRuntime.jsx(Options, {
2016
+ list: list,
2017
+ noOptionsMessage: noOptionsMessage,
2018
+ text: inputValue,
2019
+ isMultiple: isMultiple,
2020
+ value: value,
2021
+ primaryColor: primaryColor || DEFAULT_THEME
2022
+ })
2023
+ ]
2024
+ })
2025
+ ]
2026
+ })
2027
+ });
2028
+ };
2029
+
2030
+ var InputOTPs = function(param) {
2031
+ var noticeText = param.noticeText, _param_length = param.length, length = _param_length === void 0 ? 6 : _param_length, _param_textClassName = param.textClassName, textClassName = _param_textClassName === void 0 ? "text-sm" : _param_textClassName, _param_ringClassName = param.ringClassName, ringClassName = _param_ringClassName === void 0 ? "" : _param_ringClassName, value = param.value, setValue = param.setValue;
2032
+ var inputs = Array.from({
2033
+ length: length
2034
+ }, function(_, index) {
2035
+ return index + 1;
2036
+ });
2037
+ return /*#__PURE__*/ jsxRuntime.jsxs("div", {
2038
+ children: [
2039
+ /*#__PURE__*/ jsxRuntime.jsx(InputOTP, {
2040
+ maxLength: length,
2041
+ value: value,
2042
+ onChange: function(value) {
2043
+ return setValue(value);
2044
+ },
2045
+ children: /*#__PURE__*/ jsxRuntime.jsx(InputOTPGroup, {
2046
+ children: inputs.map(function(num, index) {
2047
+ return /*#__PURE__*/ jsxRuntime.jsx(InputOTPSlot, {
2048
+ index: index,
2049
+ ringClassName: ringClassName
2050
+ });
2051
+ })
2052
+ })
2053
+ }),
2054
+ /*#__PURE__*/ jsxRuntime.jsx("div", {
2055
+ className: [
2056
+ textClassName,
2057
+ "mt-2"
2058
+ ].join(" "),
2059
+ children: value === "" ? /*#__PURE__*/ jsxRuntime.jsx(jsxRuntime.Fragment, {
2060
+ children: noticeText
2061
+ }) : null
2062
+ })
2063
+ ]
2064
+ });
2065
+ };
2066
+
2067
+ exports.Button = input.Button;
2068
+ exports.Input = input.Input;
2069
+ exports.buttonVariants = input.buttonVariants;
2070
+ exports.BaseSwitch = baseSwitch.BaseSwitch;
2071
+ exports.Select = baseSwitch.Select;
2072
+ exports.SelectContent = baseSwitch.SelectContent;
2073
+ exports.SelectGroup = baseSwitch.SelectGroup;
2074
+ exports.SelectItem = baseSwitch.SelectItem;
2075
+ exports.SelectLabel = baseSwitch.SelectLabel;
2076
+ exports.SelectScrollDownButton = baseSwitch.SelectScrollDownButton;
2077
+ exports.SelectScrollUpButton = baseSwitch.SelectScrollUpButton;
2078
+ exports.SelectSeparator = baseSwitch.SelectSeparator;
2079
+ exports.SelectTrigger = baseSwitch.SelectTrigger;
2080
+ exports.SelectValue = baseSwitch.SelectValue;
2081
+ exports.validateMsg = baseSwitch.validateMsg;
2082
+ exports.Checkbox = Checkbox;
2083
+ exports.DateRangePicker = DateRangePicker;
2084
+ exports.DropDown = DropDown;
2085
+ exports.InputOTP = InputOTP;
2086
+ exports.InputOTPGroup = InputOTPGroup;
2087
+ exports.InputOTPSeparator = InputOTPSeparator;
2088
+ exports.InputOTPSlot = InputOTPSlot;
2089
+ exports.InputOTPs = InputOTPs;
2090
+ exports.ReactDateRange = ReactDateRange;
2091
+ exports.Regex = Regex;
2092
+ exports.SingleDatePicker = SingleDatePicker;
2093
+ exports.Spin = Spin;
2094
+ exports.Switch = Switch;
2095
+ exports.verifyId = verifyId;
2096
+ exports.verifyTaiwanIdIntermediateString = verifyTaiwanIdIntermediateString;
2097
+ exports.verifyTaxId = verifyTaxId;