@mieweb/ui 0.1.0 → 0.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (88) hide show
  1. package/LICENSE +39 -15
  2. package/README.md +9 -1
  3. package/dist/brands/index.cjs +7 -7
  4. package/dist/brands/index.js +2 -2
  5. package/dist/{chunk-CLNOI5J7.js → chunk-4SMSH4OY.js} +4 -4
  6. package/dist/chunk-4SMSH4OY.js.map +1 -0
  7. package/dist/chunk-4T2ZNPTC.js +220 -0
  8. package/dist/chunk-4T2ZNPTC.js.map +1 -0
  9. package/dist/chunk-5T3AWNHG.cjs +471 -0
  10. package/dist/chunk-5T3AWNHG.cjs.map +1 -0
  11. package/dist/{chunk-LEE3NMNP.cjs → chunk-5UUL5EEO.cjs} +131 -81
  12. package/dist/chunk-5UUL5EEO.cjs.map +1 -0
  13. package/dist/chunk-74K3RRU7.cjs +4 -0
  14. package/dist/{chunk-ZO46CFVN.cjs.map → chunk-74K3RRU7.cjs.map} +1 -1
  15. package/dist/{chunk-VWXGUNBR.cjs → chunk-AKTUXJPI.cjs} +107 -18
  16. package/dist/chunk-AKTUXJPI.cjs.map +1 -0
  17. package/dist/chunk-BV75DAKO.cjs +245 -0
  18. package/dist/chunk-BV75DAKO.cjs.map +1 -0
  19. package/dist/{chunk-6DP6RKUA.cjs → chunk-CLJZHS7Y.cjs} +2 -2
  20. package/dist/{chunk-6DP6RKUA.cjs.map → chunk-CLJZHS7Y.cjs.map} +1 -1
  21. package/dist/{chunk-NH2JVQ6V.cjs → chunk-I7L6CQXR.cjs} +21 -9
  22. package/dist/chunk-I7L6CQXR.cjs.map +1 -0
  23. package/dist/{chunk-BR2XGATJ.cjs → chunk-NNEFAUHV.cjs} +4 -4
  24. package/dist/chunk-NNEFAUHV.cjs.map +1 -0
  25. package/dist/{chunk-KJOFWJHV.js → chunk-QSMMFATL.js} +131 -81
  26. package/dist/chunk-QSMMFATL.js.map +1 -0
  27. package/dist/{chunk-FIUNOH6W.js → chunk-S4DK5WN6.js} +2 -2
  28. package/dist/{chunk-FIUNOH6W.js.map → chunk-S4DK5WN6.js.map} +1 -1
  29. package/dist/chunk-SCV7C55E.cjs +11 -0
  30. package/dist/chunk-SCV7C55E.cjs.map +1 -0
  31. package/dist/{chunk-D5IBXXF2.js → chunk-SD44QJIP.js} +20 -8
  32. package/dist/chunk-SD44QJIP.js.map +1 -0
  33. package/dist/{chunk-QBWVTJKF.js → chunk-UBRDKNLQ.js} +107 -18
  34. package/dist/chunk-UBRDKNLQ.js.map +1 -0
  35. package/dist/chunk-V2DF2GUE.js +3 -0
  36. package/dist/{chunk-ZQ4XMJH7.js.map → chunk-V2DF2GUE.js.map} +1 -1
  37. package/dist/chunk-VSQF22GL.js +9 -0
  38. package/dist/chunk-VSQF22GL.js.map +1 -0
  39. package/dist/chunk-XVZ4SLQB.js +447 -0
  40. package/dist/chunk-XVZ4SLQB.js.map +1 -0
  41. package/dist/components/AudioPlayer/index.cjs +6 -6
  42. package/dist/components/AudioPlayer/index.d.cts +5 -1
  43. package/dist/components/AudioPlayer/index.d.ts +5 -1
  44. package/dist/components/AudioPlayer/index.js +1 -1
  45. package/dist/components/Modal/index.cjs +11 -10
  46. package/dist/components/Modal/index.js +3 -2
  47. package/dist/components/RecordButton/index.cjs +4 -8
  48. package/dist/components/RecordButton/index.d.cts +57 -44
  49. package/dist/components/RecordButton/index.d.ts +57 -44
  50. package/dist/components/RecordButton/index.js +1 -1
  51. package/dist/components/Select/index.cjs +3 -4
  52. package/dist/components/Select/index.js +1 -2
  53. package/dist/components/Slider/index.cjs +25 -0
  54. package/dist/components/Slider/index.cjs.map +1 -0
  55. package/dist/components/Slider/index.d.cts +82 -0
  56. package/dist/components/Slider/index.d.ts +82 -0
  57. package/dist/components/Slider/index.js +4 -0
  58. package/dist/components/Slider/index.js.map +1 -0
  59. package/dist/components/Spinner/index.d.cts +1 -1
  60. package/dist/components/Spinner/index.d.ts +1 -1
  61. package/dist/hooks/index.cjs +3 -2
  62. package/dist/hooks/index.js +2 -1
  63. package/dist/index.cjs +1899 -1238
  64. package/dist/index.cjs.map +1 -1
  65. package/dist/index.d.cts +68 -25
  66. package/dist/index.d.ts +68 -25
  67. package/dist/index.js +1793 -1148
  68. package/dist/index.js.map +1 -1
  69. package/dist/styles.css +1 -1
  70. package/dist/utils/index.cjs +6 -1
  71. package/dist/utils/index.d.cts +14 -1
  72. package/dist/utils/index.d.ts +14 -1
  73. package/dist/utils/index.js +2 -1
  74. package/package.json +7 -7
  75. package/dist/chunk-BR2XGATJ.cjs.map +0 -1
  76. package/dist/chunk-CLNOI5J7.js.map +0 -1
  77. package/dist/chunk-D5IBXXF2.js.map +0 -1
  78. package/dist/chunk-FQ5G7J24.js +0 -297
  79. package/dist/chunk-FQ5G7J24.js.map +0 -1
  80. package/dist/chunk-HLW3XD5R.cjs +0 -322
  81. package/dist/chunk-HLW3XD5R.cjs.map +0 -1
  82. package/dist/chunk-KJOFWJHV.js.map +0 -1
  83. package/dist/chunk-LEE3NMNP.cjs.map +0 -1
  84. package/dist/chunk-NH2JVQ6V.cjs.map +0 -1
  85. package/dist/chunk-QBWVTJKF.js.map +0 -1
  86. package/dist/chunk-VWXGUNBR.cjs.map +0 -1
  87. package/dist/chunk-ZO46CFVN.cjs +0 -4
  88. package/dist/chunk-ZQ4XMJH7.js +0 -3
@@ -1,9 +1,9 @@
1
1
  'use strict';
2
2
 
3
- var chunkSWMRCGL4_cjs = require('./chunk-SWMRCGL4.cjs');
4
3
  var chunkFHY3K6PL_cjs = require('./chunk-FHY3K6PL.cjs');
5
4
  var chunkOR5DRJCW_cjs = require('./chunk-OR5DRJCW.cjs');
6
5
  var React = require('react');
6
+ var reactDom = require('react-dom');
7
7
  var classVarianceAuthority = require('class-variance-authority');
8
8
  var jsxRuntime = require('react/jsx-runtime');
9
9
 
@@ -83,6 +83,7 @@ function Select({
83
83
  const triggerRef = React__namespace.useRef(null);
84
84
  const searchInputRef = React__namespace.useRef(null);
85
85
  const listRef = React__namespace.useRef(null);
86
+ const dropdownRef = React__namespace.useRef(null);
86
87
  const generatedId = React__namespace.useId();
87
88
  const selectId = id || generatedId;
88
89
  const listboxId = `${selectId}-listbox`;
@@ -133,13 +134,58 @@ function Select({
133
134
  return result;
134
135
  }, [filteredOptions]);
135
136
  const selectedOption = flatOptions.find((opt) => opt.value === value);
136
- chunkSWMRCGL4_cjs.useClickOutside(containerRef, () => setIsOpen(false));
137
+ React__namespace.useEffect(() => {
138
+ if (!isOpen) return;
139
+ const handleClickOutside = (e) => {
140
+ const target = e.target;
141
+ if (containerRef.current && !containerRef.current.contains(target) && dropdownRef.current && !dropdownRef.current.contains(target)) {
142
+ setIsOpen(false);
143
+ }
144
+ };
145
+ document.addEventListener("mousedown", handleClickOutside);
146
+ return () => document.removeEventListener("mousedown", handleClickOutside);
147
+ }, [isOpen]);
137
148
  chunkFHY3K6PL_cjs.useEscapeKey(() => {
138
149
  if (isOpen) {
139
150
  setIsOpen(false);
140
151
  triggerRef.current?.focus();
141
152
  }
142
153
  }, isOpen);
154
+ const [dropdownStyle, setDropdownStyle] = React__namespace.useState(
155
+ {}
156
+ );
157
+ const updateDropdownPosition = React__namespace.useCallback(() => {
158
+ if (!triggerRef.current) return;
159
+ const rect = triggerRef.current.getBoundingClientRect();
160
+ const spaceBelow = window.innerHeight - rect.bottom;
161
+ const spaceAbove = rect.top;
162
+ const estimatedDropdownHeight = Math.min(flatOptions.length * 40 + 16, 300);
163
+ const openAbove = spaceBelow < estimatedDropdownHeight && spaceAbove > spaceBelow;
164
+ setDropdownStyle({
165
+ position: "fixed",
166
+ ...openAbove ? { bottom: window.innerHeight - rect.top + 4 } : { top: rect.bottom + 4 },
167
+ left: rect.left,
168
+ width: rect.width,
169
+ maxHeight: Math.max(
170
+ Math.min(openAbove ? spaceAbove - 8 : spaceBelow - 8, 300),
171
+ 0
172
+ ),
173
+ display: "flex",
174
+ flexDirection: "column",
175
+ overflow: "hidden",
176
+ zIndex: 9999
177
+ });
178
+ }, [flatOptions.length]);
179
+ React__namespace.useEffect(() => {
180
+ if (!isOpen) return;
181
+ updateDropdownPosition();
182
+ window.addEventListener("scroll", updateDropdownPosition, true);
183
+ window.addEventListener("resize", updateDropdownPosition);
184
+ return () => {
185
+ window.removeEventListener("scroll", updateDropdownPosition, true);
186
+ window.removeEventListener("resize", updateDropdownPosition);
187
+ };
188
+ }, [isOpen, updateDropdownPosition]);
143
189
  const handleValueChange = React__namespace.useCallback(
144
190
  (newValue) => {
145
191
  if (!isControlled) {
@@ -259,83 +305,87 @@ function Select({
259
305
  ]
260
306
  }
261
307
  ),
262
- isOpen && /* @__PURE__ */ jsxRuntime.jsxs(
263
- "div",
264
- {
265
- className: chunkOR5DRJCW_cjs.cn(
266
- "absolute z-50 mt-1 w-full",
267
- "border-border bg-card rounded-lg border shadow-lg",
268
- "animate-in fade-in zoom-in-95 duration-100"
269
- ),
270
- children: [
271
- searchable && /* @__PURE__ */ jsxRuntime.jsx("div", { className: "border-border border-b p-2", children: /* @__PURE__ */ jsxRuntime.jsx(
272
- "input",
273
- {
274
- ref: searchInputRef,
275
- type: "text",
276
- value: searchQuery,
277
- onChange: (e) => setSearchQuery(e.target.value),
278
- onKeyDown: handleKeyDown,
279
- placeholder: searchPlaceholder,
280
- className: chunkOR5DRJCW_cjs.cn(
281
- "border-input bg-background w-full rounded-md border px-3 py-2 text-sm",
282
- "placeholder:text-muted-foreground",
283
- "focus:ring-ring focus:ring-2 focus:outline-none"
284
- ),
285
- "aria-label": "Search options"
286
- }
287
- ) }),
288
- /* @__PURE__ */ jsxRuntime.jsx(
289
- "ul",
290
- {
291
- ref: listRef,
292
- id: listboxId,
293
- role: "listbox",
294
- "aria-label": label || "Options",
295
- className: "max-h-60 overflow-auto p-1",
296
- children: filteredFlatOptions.length === 0 ? /* @__PURE__ */ jsxRuntime.jsx("li", { className: "text-muted-foreground px-3 py-2 text-center text-sm", children: noResultsText }) : filteredOptions.map((item) => {
297
- if ("options" in item) {
298
- return /* @__PURE__ */ jsxRuntime.jsxs("li", { role: "presentation", children: [
299
- /* @__PURE__ */ jsxRuntime.jsx("div", { className: "text-muted-foreground px-3 py-1.5 text-xs font-semibold tracking-wider uppercase", children: item.label }),
300
- /* @__PURE__ */ jsxRuntime.jsx("ul", { role: "group", "aria-label": item.label, children: item.options.map((option) => /* @__PURE__ */ jsxRuntime.jsx(
301
- SelectOptionItem,
302
- {
303
- option,
304
- isSelected: option.value === value,
305
- isHighlighted: filteredFlatOptions[highlightedIndex]?.value === option.value,
306
- onSelect: () => handleValueChange(option.value),
307
- onMouseEnter: () => {
308
- const idx = filteredFlatOptions.findIndex(
309
- (o) => o.value === option.value
310
- );
311
- setHighlightedIndex(idx);
312
- }
313
- },
314
- option.value
315
- )) })
316
- ] }, `group-${item.label}`);
317
- }
318
- return /* @__PURE__ */ jsxRuntime.jsx(
319
- SelectOptionItem,
320
- {
321
- option: item,
322
- isSelected: item.value === value,
323
- isHighlighted: filteredFlatOptions[highlightedIndex]?.value === item.value,
324
- onSelect: () => handleValueChange(item.value),
325
- onMouseEnter: () => {
326
- const idx = filteredFlatOptions.findIndex(
327
- (o) => o.value === item.value
328
- );
329
- setHighlightedIndex(idx);
330
- }
331
- },
332
- item.value
333
- );
334
- })
335
- }
336
- )
337
- ]
338
- }
308
+ isOpen && reactDom.createPortal(
309
+ /* @__PURE__ */ jsxRuntime.jsxs(
310
+ "div",
311
+ {
312
+ ref: dropdownRef,
313
+ style: dropdownStyle,
314
+ className: chunkOR5DRJCW_cjs.cn(
315
+ "border-border bg-card rounded-lg border shadow-lg",
316
+ "animate-in fade-in zoom-in-95 duration-100"
317
+ ),
318
+ children: [
319
+ searchable && /* @__PURE__ */ jsxRuntime.jsx("div", { className: "border-border border-b p-2", children: /* @__PURE__ */ jsxRuntime.jsx(
320
+ "input",
321
+ {
322
+ ref: searchInputRef,
323
+ type: "text",
324
+ value: searchQuery,
325
+ onChange: (e) => setSearchQuery(e.target.value),
326
+ onKeyDown: handleKeyDown,
327
+ placeholder: searchPlaceholder,
328
+ className: chunkOR5DRJCW_cjs.cn(
329
+ "border-input bg-background w-full rounded-md border px-3 py-2 text-sm",
330
+ "placeholder:text-muted-foreground",
331
+ "focus:ring-ring focus:ring-2 focus:outline-none"
332
+ ),
333
+ "aria-label": "Search options"
334
+ }
335
+ ) }),
336
+ /* @__PURE__ */ jsxRuntime.jsx(
337
+ "ul",
338
+ {
339
+ ref: listRef,
340
+ id: listboxId,
341
+ role: "listbox",
342
+ "aria-label": label || "Options",
343
+ className: "flex-1 overflow-auto p-1",
344
+ children: filteredFlatOptions.length === 0 ? /* @__PURE__ */ jsxRuntime.jsx("li", { className: "text-muted-foreground px-3 py-2 text-center text-sm", children: noResultsText }) : filteredOptions.map((item) => {
345
+ if ("options" in item) {
346
+ return /* @__PURE__ */ jsxRuntime.jsxs("li", { role: "presentation", children: [
347
+ /* @__PURE__ */ jsxRuntime.jsx("div", { className: "text-muted-foreground px-3 py-1.5 text-xs font-semibold tracking-wider uppercase", children: item.label }),
348
+ /* @__PURE__ */ jsxRuntime.jsx("ul", { role: "group", "aria-label": item.label, children: item.options.map((option) => /* @__PURE__ */ jsxRuntime.jsx(
349
+ SelectOptionItem,
350
+ {
351
+ option,
352
+ isSelected: option.value === value,
353
+ isHighlighted: filteredFlatOptions[highlightedIndex]?.value === option.value,
354
+ onSelect: () => handleValueChange(option.value),
355
+ onMouseEnter: () => {
356
+ const idx = filteredFlatOptions.findIndex(
357
+ (o) => o.value === option.value
358
+ );
359
+ setHighlightedIndex(idx);
360
+ }
361
+ },
362
+ option.value
363
+ )) })
364
+ ] }, `group-${item.label}`);
365
+ }
366
+ return /* @__PURE__ */ jsxRuntime.jsx(
367
+ SelectOptionItem,
368
+ {
369
+ option: item,
370
+ isSelected: item.value === value,
371
+ isHighlighted: filteredFlatOptions[highlightedIndex]?.value === item.value,
372
+ onSelect: () => handleValueChange(item.value),
373
+ onMouseEnter: () => {
374
+ const idx = filteredFlatOptions.findIndex(
375
+ (o) => o.value === item.value
376
+ );
377
+ setHighlightedIndex(idx);
378
+ }
379
+ },
380
+ item.value
381
+ );
382
+ })
383
+ }
384
+ )
385
+ ]
386
+ }
387
+ ),
388
+ document.body
339
389
  )
340
390
  ] }),
341
391
  error && /* @__PURE__ */ jsxRuntime.jsx("p", { id: errorId, className: "text-destructive text-sm", role: "alert", children: error }),
@@ -425,5 +475,5 @@ function CheckIcon({ className }) {
425
475
 
426
476
  exports.Select = Select;
427
477
  exports.selectTriggerVariants = selectTriggerVariants;
428
- //# sourceMappingURL=chunk-LEE3NMNP.cjs.map
429
- //# sourceMappingURL=chunk-LEE3NMNP.cjs.map
478
+ //# sourceMappingURL=chunk-5UUL5EEO.cjs.map
479
+ //# sourceMappingURL=chunk-5UUL5EEO.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/components/Select/Select.tsx"],"names":["cva","React","useEscapeKey","cn","jsx","jsxs","createPortal"],"mappings":"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","file":"chunk-5UUL5EEO.cjs","sourcesContent":["import * as React from 'react';\nimport { createPortal } from 'react-dom';\nimport { cva, type VariantProps } from 'class-variance-authority';\nimport { cn } from '../../utils/cn';\nimport { useEscapeKey } from '../../hooks/useEscapeKey';\n\n// ============================================================================\n// Types\n// ============================================================================\n\nexport interface SelectOption {\n /** Unique value for the option */\n value: string;\n /** Display label for the option */\n label: string;\n /** Whether the option is disabled */\n disabled?: boolean;\n /** Optional group this option belongs to */\n group?: string;\n}\n\nexport interface SelectGroup {\n /** Group label */\n label: string;\n /** Options in this group */\n options: SelectOption[];\n}\n\n// ============================================================================\n// Variants\n// ============================================================================\n\nconst selectTriggerVariants = cva(\n [\n 'flex w-full items-center justify-between gap-2',\n 'border border-input rounded-lg',\n 'bg-background text-foreground',\n 'transition-colors duration-200',\n 'focus:outline-none focus:ring-2 focus:ring-ring focus:border-transparent',\n 'disabled:cursor-not-allowed disabled:opacity-50',\n ],\n {\n variants: {\n size: {\n sm: 'h-8 px-3 text-sm',\n md: 'h-10 px-3 text-base',\n lg: 'h-12 px-4 text-lg',\n },\n hasError: {\n true: 'border-destructive focus:ring-destructive',\n false: '',\n },\n },\n defaultVariants: {\n size: 'md',\n hasError: false,\n },\n }\n);\n\n// ============================================================================\n// Select Component\n// ============================================================================\n\nexport interface SelectProps extends VariantProps<\n typeof selectTriggerVariants\n> {\n /** Array of options or groups */\n options: (SelectOption | SelectGroup)[];\n /** Controlled value */\n value?: string;\n /** Default value (uncontrolled) */\n defaultValue?: string;\n /** Callback when value changes */\n onValueChange?: (value: string) => void;\n /** Placeholder text */\n placeholder?: string;\n /** Whether the select is disabled */\n disabled?: boolean;\n /** Label for the select */\n label?: string;\n /** Hide the label visually */\n hideLabel?: boolean;\n /** Error message */\n error?: string;\n /** Helper text */\n helperText?: string;\n /** Enable search/filter */\n searchable?: boolean;\n /** Search placeholder */\n searchPlaceholder?: string;\n /** No results text */\n noResultsText?: string;\n /** Additional class name */\n className?: string;\n /** ID for the select */\n id?: string;\n}\n\n/**\n * An accessible select/dropdown component with search support.\n *\n * @example\n * ```tsx\n * <Select\n * label=\"Country\"\n * placeholder=\"Select a country\"\n * options={[\n * { value: 'us', label: 'United States' },\n * { value: 'ca', label: 'Canada' },\n * { value: 'uk', label: 'United Kingdom' },\n * ]}\n * onValueChange={(value) => console.log(value)}\n * />\n * ```\n */\nfunction Select({\n options,\n value: controlledValue,\n defaultValue,\n onValueChange,\n placeholder = 'Select an option',\n disabled = false,\n label,\n hideLabel = false,\n error,\n helperText,\n size,\n hasError,\n searchable = false,\n searchPlaceholder = 'Search...',\n noResultsText = 'No results found',\n className,\n id,\n}: SelectProps) {\n const [isOpen, setIsOpen] = React.useState(false);\n const [uncontrolledValue, setUncontrolledValue] = React.useState(\n defaultValue || ''\n );\n const [searchQuery, setSearchQuery] = React.useState('');\n const [highlightedIndex, setHighlightedIndex] = React.useState(-1);\n\n const containerRef = React.useRef<HTMLDivElement>(null);\n const triggerRef = React.useRef<HTMLButtonElement>(null);\n const searchInputRef = React.useRef<HTMLInputElement>(null);\n const listRef = React.useRef<HTMLUListElement>(null);\n const dropdownRef = React.useRef<HTMLDivElement>(null);\n\n const generatedId = React.useId();\n const selectId = id || generatedId;\n const listboxId = `${selectId}-listbox`;\n const errorId = `${selectId}-error`;\n const helperId = `${selectId}-helper`;\n\n const isControlled = controlledValue !== undefined;\n const value = isControlled ? controlledValue : uncontrolledValue;\n\n // Flatten options for easy access\n const flatOptions = React.useMemo(() => {\n const result: SelectOption[] = [];\n for (const item of options) {\n if ('options' in item) {\n result.push(...item.options);\n } else {\n result.push(item);\n }\n }\n return result;\n }, [options]);\n\n // Filter options based on search query\n const filteredOptions = React.useMemo(() => {\n if (!searchQuery) return options;\n\n const query = searchQuery.toLowerCase();\n const result: (SelectOption | SelectGroup)[] = [];\n\n for (const item of options) {\n if ('options' in item) {\n const filteredGroupOptions = item.options.filter((opt) =>\n opt.label.toLowerCase().includes(query)\n );\n if (filteredGroupOptions.length > 0) {\n result.push({ ...item, options: filteredGroupOptions });\n }\n } else {\n if (item.label.toLowerCase().includes(query)) {\n result.push(item);\n }\n }\n }\n\n return result;\n }, [options, searchQuery]);\n\n // Get filtered flat options for keyboard navigation\n const filteredFlatOptions = React.useMemo(() => {\n const result: SelectOption[] = [];\n for (const item of filteredOptions) {\n if ('options' in item) {\n result.push(...item.options.filter((opt) => !opt.disabled));\n } else if (!item.disabled) {\n result.push(item);\n }\n }\n return result;\n }, [filteredOptions]);\n\n // Get selected option\n const selectedOption = flatOptions.find((opt) => opt.value === value);\n\n // Close dropdown on click outside (handles both container and portaled dropdown)\n React.useEffect(() => {\n if (!isOpen) return;\n const handleClickOutside = (e: MouseEvent) => {\n const target = e.target as Node;\n if (\n containerRef.current &&\n !containerRef.current.contains(target) &&\n dropdownRef.current &&\n !dropdownRef.current.contains(target)\n ) {\n setIsOpen(false);\n }\n };\n document.addEventListener('mousedown', handleClickOutside);\n return () => document.removeEventListener('mousedown', handleClickOutside);\n }, [isOpen]);\n\n useEscapeKey(() => {\n if (isOpen) {\n setIsOpen(false);\n triggerRef.current?.focus();\n }\n }, isOpen);\n\n // Track trigger position for portal dropdown\n const [dropdownStyle, setDropdownStyle] = React.useState<React.CSSProperties>(\n {}\n );\n\n const updateDropdownPosition = React.useCallback(() => {\n if (!triggerRef.current) return;\n const rect = triggerRef.current.getBoundingClientRect();\n const spaceBelow = window.innerHeight - rect.bottom;\n const spaceAbove = rect.top;\n const estimatedDropdownHeight = Math.min(flatOptions.length * 40 + 16, 300);\n const openAbove =\n spaceBelow < estimatedDropdownHeight && spaceAbove > spaceBelow;\n\n setDropdownStyle({\n position: 'fixed',\n ...(openAbove\n ? { bottom: window.innerHeight - rect.top + 4 }\n : { top: rect.bottom + 4 }),\n left: rect.left,\n width: rect.width,\n maxHeight: Math.max(\n Math.min(openAbove ? spaceAbove - 8 : spaceBelow - 8, 300),\n 0\n ),\n display: 'flex',\n flexDirection: 'column' as const,\n overflow: 'hidden',\n zIndex: 9999,\n });\n }, [flatOptions.length]);\n\n React.useEffect(() => {\n if (!isOpen) return;\n updateDropdownPosition();\n\n window.addEventListener('scroll', updateDropdownPosition, true);\n window.addEventListener('resize', updateDropdownPosition);\n return () => {\n window.removeEventListener('scroll', updateDropdownPosition, true);\n window.removeEventListener('resize', updateDropdownPosition);\n };\n }, [isOpen, updateDropdownPosition]);\n\n // Handle value change\n const handleValueChange = React.useCallback(\n (newValue: string) => {\n if (!isControlled) {\n setUncontrolledValue(newValue);\n }\n onValueChange?.(newValue);\n setIsOpen(false);\n setSearchQuery('');\n triggerRef.current?.focus();\n },\n [isControlled, onValueChange]\n );\n\n // Handle keyboard navigation\n const handleKeyDown = React.useCallback(\n (e: React.KeyboardEvent) => {\n switch (e.key) {\n case 'ArrowDown':\n e.preventDefault();\n if (!isOpen) {\n setIsOpen(true);\n } else {\n setHighlightedIndex((prev) =>\n prev < filteredFlatOptions.length - 1 ? prev + 1 : 0\n );\n }\n break;\n case 'ArrowUp':\n e.preventDefault();\n if (!isOpen) {\n setIsOpen(true);\n } else {\n setHighlightedIndex((prev) =>\n prev > 0 ? prev - 1 : filteredFlatOptions.length - 1\n );\n }\n break;\n case 'Enter':\n case ' ':\n e.preventDefault();\n if (isOpen && highlightedIndex >= 0) {\n handleValueChange(filteredFlatOptions[highlightedIndex].value);\n } else if (!isOpen) {\n setIsOpen(true);\n }\n break;\n case 'Home':\n e.preventDefault();\n setHighlightedIndex(0);\n break;\n case 'End':\n e.preventDefault();\n setHighlightedIndex(filteredFlatOptions.length - 1);\n break;\n }\n },\n [isOpen, highlightedIndex, filteredFlatOptions, handleValueChange]\n );\n\n // Focus search input when dropdown opens\n React.useEffect(() => {\n if (isOpen && searchable && searchInputRef.current) {\n searchInputRef.current.focus();\n }\n }, [isOpen, searchable]);\n\n // Reset highlighted index when search changes\n React.useEffect(() => {\n setHighlightedIndex(filteredFlatOptions.length > 0 ? 0 : -1);\n }, [searchQuery, filteredFlatOptions.length]);\n\n // Build aria-describedby\n const describedByIds = [error ? errorId : null, helperText ? helperId : null]\n .filter(Boolean)\n .join(' ');\n\n return (\n <div className={cn('flex flex-col gap-1.5', className)}>\n {label && (\n <label\n htmlFor={selectId}\n className={cn(\n 'text-foreground text-sm font-medium',\n hideLabel && 'sr-only'\n )}\n >\n {label}\n </label>\n )}\n\n <div ref={containerRef} className=\"relative\">\n {/* Trigger Button */}\n <button\n ref={triggerRef}\n id={selectId}\n type=\"button\"\n role=\"combobox\"\n aria-haspopup=\"listbox\"\n aria-expanded={isOpen}\n aria-controls={listboxId}\n aria-invalid={hasError || !!error}\n aria-describedby={describedByIds || undefined}\n disabled={disabled}\n onClick={() => setIsOpen(!isOpen)}\n onKeyDown={handleKeyDown}\n className={cn(\n selectTriggerVariants({ size, hasError: hasError || !!error })\n )}\n >\n <span\n className={cn(\n 'truncate',\n !selectedOption && 'text-muted-foreground'\n )}\n >\n {selectedOption?.label || placeholder}\n </span>\n <ChevronDownIcon\n className={cn(\n 'text-muted-foreground h-4 w-4 shrink-0 transition-transform',\n isOpen && 'rotate-180'\n )}\n />\n </button>\n\n {/* Dropdown (portaled to body to avoid overflow clipping) */}\n {isOpen &&\n createPortal(\n <div\n ref={dropdownRef}\n style={dropdownStyle}\n className={cn(\n 'border-border bg-card rounded-lg border shadow-lg',\n 'animate-in fade-in zoom-in-95 duration-100'\n )}\n >\n {/* Search Input */}\n {searchable && (\n <div className=\"border-border border-b p-2\">\n <input\n ref={searchInputRef}\n type=\"text\"\n value={searchQuery}\n onChange={(e) => setSearchQuery(e.target.value)}\n onKeyDown={handleKeyDown}\n placeholder={searchPlaceholder}\n className={cn(\n 'border-input bg-background w-full rounded-md border px-3 py-2 text-sm',\n 'placeholder:text-muted-foreground',\n 'focus:ring-ring focus:ring-2 focus:outline-none'\n )}\n aria-label=\"Search options\"\n />\n </div>\n )}\n\n {/* Options List */}\n <ul\n ref={listRef}\n id={listboxId}\n role=\"listbox\"\n aria-label={label || 'Options'}\n className=\"flex-1 overflow-auto p-1\"\n >\n {filteredFlatOptions.length === 0 ? (\n <li className=\"text-muted-foreground px-3 py-2 text-center text-sm\">\n {noResultsText}\n </li>\n ) : (\n filteredOptions.map((item) => {\n if ('options' in item) {\n // Render group\n return (\n <li key={`group-${item.label}`} role=\"presentation\">\n <div className=\"text-muted-foreground px-3 py-1.5 text-xs font-semibold tracking-wider uppercase\">\n {item.label}\n </div>\n <ul role=\"group\" aria-label={item.label}>\n {item.options.map((option) => (\n <SelectOptionItem\n key={option.value}\n option={option}\n isSelected={option.value === value}\n isHighlighted={\n filteredFlatOptions[highlightedIndex]\n ?.value === option.value\n }\n onSelect={() => handleValueChange(option.value)}\n onMouseEnter={() => {\n const idx = filteredFlatOptions.findIndex(\n (o) => o.value === option.value\n );\n setHighlightedIndex(idx);\n }}\n />\n ))}\n </ul>\n </li>\n );\n }\n\n // Render single option\n return (\n <SelectOptionItem\n key={item.value}\n option={item}\n isSelected={item.value === value}\n isHighlighted={\n filteredFlatOptions[highlightedIndex]?.value ===\n item.value\n }\n onSelect={() => handleValueChange(item.value)}\n onMouseEnter={() => {\n const idx = filteredFlatOptions.findIndex(\n (o) => o.value === item.value\n );\n setHighlightedIndex(idx);\n }}\n />\n );\n })\n )}\n </ul>\n </div>,\n document.body\n )}\n </div>\n\n {/* Error Message */}\n {error && (\n <p id={errorId} className=\"text-destructive text-sm\" role=\"alert\">\n {error}\n </p>\n )}\n\n {/* Helper Text */}\n {helperText && !error && (\n <p id={helperId} className=\"text-muted-foreground text-sm\">\n {helperText}\n </p>\n )}\n </div>\n );\n}\n\nSelect.displayName = 'Select';\n\n// ============================================================================\n// Select Option Item (Internal)\n// ============================================================================\n\ninterface SelectOptionItemProps {\n option: SelectOption;\n isSelected: boolean;\n isHighlighted: boolean;\n onSelect: () => void;\n onMouseEnter: () => void;\n}\n\nfunction SelectOptionItem({\n option,\n isSelected,\n isHighlighted,\n onSelect,\n onMouseEnter,\n}: SelectOptionItemProps) {\n const handleKeyDown = (e: React.KeyboardEvent) => {\n if (e.key === 'Enter' || e.key === ' ') {\n e.preventDefault();\n if (!option.disabled) {\n onSelect();\n }\n }\n };\n\n return (\n <li\n role=\"option\"\n aria-selected={isSelected}\n aria-disabled={option.disabled}\n data-highlighted={isHighlighted}\n data-disabled={option.disabled}\n tabIndex={isHighlighted ? 0 : -1}\n onClick={option.disabled ? undefined : onSelect}\n onKeyDown={handleKeyDown}\n onMouseEnter={option.disabled ? undefined : onMouseEnter}\n className={cn(\n 'flex cursor-pointer items-center gap-2 rounded-md px-3 py-2 text-sm',\n 'transition-colors outline-none',\n isHighlighted && 'bg-muted',\n isSelected &&\n 'bg-primary-50 text-primary-900 dark:bg-primary-950 dark:text-primary-100',\n option.disabled && 'cursor-not-allowed opacity-50'\n )}\n >\n <span className=\"flex-1 truncate\">{option.label}</span>\n {isSelected && (\n <CheckIcon className=\"text-primary-500 h-4 w-4 shrink-0\" />\n )}\n </li>\n );\n}\n\n// ============================================================================\n// Icons\n// ============================================================================\n\nfunction ChevronDownIcon({ className }: { className?: string }) {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"24\"\n height=\"24\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n className={className}\n aria-hidden=\"true\"\n >\n <path d=\"m6 9 6 6 6-6\" />\n </svg>\n );\n}\n\nfunction CheckIcon({ className }: { className?: string }) {\n return (\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n width=\"24\"\n height=\"24\"\n viewBox=\"0 0 24 24\"\n fill=\"none\"\n stroke=\"currentColor\"\n strokeWidth=\"2\"\n strokeLinecap=\"round\"\n strokeLinejoin=\"round\"\n className={className}\n aria-hidden=\"true\"\n >\n <path d=\"M20 6 9 17l-5-5\" />\n </svg>\n );\n}\n\nexport { Select, selectTriggerVariants };\n"]}
@@ -0,0 +1,4 @@
1
+ 'use strict';
2
+
3
+ //# sourceMappingURL=chunk-74K3RRU7.cjs.map
4
+ //# sourceMappingURL=chunk-74K3RRU7.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":[],"names":[],"mappings":"","file":"chunk-ZO46CFVN.cjs"}
1
+ {"version":3,"sources":[],"names":[],"mappings":"","file":"chunk-74K3RRU7.cjs"}
@@ -226,11 +226,16 @@ function Waveform({
226
226
  onSeek,
227
227
  waveColor,
228
228
  progressColor,
229
- height = 64
229
+ height = 64,
230
+ showHoverCursor = false,
231
+ onHoverTimeChange,
232
+ cursorColor = "var(--color-red-500, rgb(239, 68, 68))"
230
233
  }) {
231
234
  const containerRef = React__namespace.useRef(null);
232
235
  const wavesurferRef = React__namespace.useRef(null);
233
236
  const [isLoaded, setIsLoaded] = React__namespace.useState(false);
237
+ const [isHovering, setIsHovering] = React__namespace.useState(false);
238
+ const [hoverPosition, setHoverPosition] = React__namespace.useState(0);
234
239
  React__namespace.useEffect(() => {
235
240
  if (!containerRef.current) return;
236
241
  const initWaveSurfer = async () => {
@@ -249,7 +254,7 @@ function Waveform({
249
254
  barRadius: 2,
250
255
  height,
251
256
  normalize: true,
252
- interact: true
257
+ interact: !showHoverCursor
253
258
  });
254
259
  wavesurferRef.current.on("ready", () => {
255
260
  setIsLoaded(true);
@@ -261,9 +266,11 @@ function Waveform({
261
266
  wavesurferRef.current.on("seeking", () => {
262
267
  onTimeUpdate(wavesurferRef.current.getCurrentTime());
263
268
  });
264
- wavesurferRef.current.on("interaction", () => {
265
- onSeek(wavesurferRef.current.getCurrentTime());
266
- });
269
+ if (!showHoverCursor) {
270
+ wavesurferRef.current.on("interaction", () => {
271
+ onSeek(wavesurferRef.current.getCurrentTime());
272
+ });
273
+ }
267
274
  wavesurferRef.current.on("finish", () => {
268
275
  onFinish();
269
276
  });
@@ -279,7 +286,7 @@ function Waveform({
279
286
  wavesurferRef.current = null;
280
287
  }
281
288
  };
282
- }, [src]);
289
+ }, [src, showHoverCursor]);
283
290
  React__namespace.useEffect(() => {
284
291
  if (!wavesurferRef.current || !isLoaded) return;
285
292
  if (isPlaying) {
@@ -292,15 +299,77 @@ function Waveform({
292
299
  if (!wavesurferRef.current || !isLoaded) return;
293
300
  wavesurferRef.current.setPlaybackRate(playbackRate);
294
301
  }, [playbackRate, isLoaded]);
302
+ const handleMouseMove = showHoverCursor ? (e) => {
303
+ if (!containerRef.current || !wavesurferRef.current || !isLoaded)
304
+ return;
305
+ const rect = containerRef.current.getBoundingClientRect();
306
+ const x = Math.max(0, Math.min(e.clientX - rect.left, rect.width));
307
+ const percentage = x / rect.width;
308
+ const duration = wavesurferRef.current.getDuration();
309
+ setHoverPosition(percentage * 100);
310
+ onHoverTimeChange?.(percentage * duration);
311
+ } : void 0;
312
+ const handleMouseEnter = showHoverCursor ? () => setIsHovering(true) : void 0;
313
+ const handleMouseLeave = showHoverCursor ? () => {
314
+ setIsHovering(false);
315
+ setHoverPosition(0);
316
+ onHoverTimeChange?.(null);
317
+ } : void 0;
318
+ const handleClick = showHoverCursor ? (e) => {
319
+ if (!containerRef.current || !wavesurferRef.current || !isLoaded)
320
+ return;
321
+ const rect = containerRef.current.getBoundingClientRect();
322
+ const x = Math.max(0, Math.min(e.clientX - rect.left, rect.width));
323
+ const percentage = x / rect.width;
324
+ wavesurferRef.current.seekTo(percentage);
325
+ onSeek(wavesurferRef.current.getDuration() * percentage);
326
+ onHoverTimeChange?.(null);
327
+ } : void 0;
328
+ const handleKeyDown = showHoverCursor ? (e) => {
329
+ if (!wavesurferRef.current || !isLoaded) return;
330
+ const duration = wavesurferRef.current.getDuration();
331
+ const currentTime = wavesurferRef.current.getCurrentTime();
332
+ const step = duration * 0.05;
333
+ if (e.key === "ArrowRight") {
334
+ e.preventDefault();
335
+ const newTime = Math.min(currentTime + step, duration);
336
+ wavesurferRef.current.seekTo(newTime / duration);
337
+ onSeek(newTime);
338
+ } else if (e.key === "ArrowLeft") {
339
+ e.preventDefault();
340
+ const newTime = Math.max(currentTime - step, 0);
341
+ wavesurferRef.current.seekTo(newTime / duration);
342
+ onSeek(newTime);
343
+ }
344
+ } : void 0;
295
345
  return /* @__PURE__ */ jsxRuntime.jsx(
296
346
  "div",
297
347
  {
298
348
  ref: containerRef,
349
+ role: showHoverCursor ? "slider" : void 0,
350
+ "aria-label": showHoverCursor ? "Audio progress" : void 0,
351
+ "aria-valuemin": showHoverCursor ? 0 : void 0,
352
+ "aria-valuemax": showHoverCursor && wavesurferRef.current ? wavesurferRef.current.getDuration() : void 0,
353
+ "aria-valuenow": showHoverCursor && wavesurferRef.current ? wavesurferRef.current.getCurrentTime() : void 0,
354
+ tabIndex: showHoverCursor ? 0 : void 0,
299
355
  className: chunkOR5DRJCW_cjs.cn(
300
- "w-full rounded-lg bg-neutral-100 dark:bg-neutral-800",
356
+ "relative w-full rounded-lg bg-neutral-100 dark:bg-neutral-800",
357
+ showHoverCursor && "cursor-pointer",
301
358
  !isLoaded && "animate-pulse"
302
359
  ),
303
- style: { height }
360
+ style: { height },
361
+ onMouseMove: handleMouseMove,
362
+ onMouseEnter: handleMouseEnter,
363
+ onMouseLeave: handleMouseLeave,
364
+ onClick: handleClick,
365
+ onKeyDown: handleKeyDown,
366
+ children: showHoverCursor && isHovering && isLoaded && /* @__PURE__ */ jsxRuntime.jsx(
367
+ "div",
368
+ {
369
+ className: "pointer-events-none absolute top-0 bottom-0 z-10 w-0.5",
370
+ style: { left: `${hoverPosition}%`, backgroundColor: cursorColor }
371
+ }
372
+ )
304
373
  }
305
374
  );
306
375
  }
@@ -318,6 +387,8 @@ function AudioPlayer({
318
387
  waveColor,
319
388
  progressColor,
320
389
  waveformHeight = 64,
390
+ showWaveformHoverCursor = true,
391
+ waveformCursorColor,
321
392
  disabled = false,
322
393
  className,
323
394
  "aria-label": ariaLabel,
@@ -333,6 +404,7 @@ function AudioPlayer({
333
404
  const [duration, setDuration] = React__namespace.useState(0);
334
405
  const [playbackRate, setPlaybackRate] = React__namespace.useState(1);
335
406
  const [audioInitialized, setAudioInitialized] = React__namespace.useState(false);
407
+ const [hoverTime, setHoverTime] = React__namespace.useState(null);
336
408
  const audioRef = React__namespace.useRef(null);
337
409
  const isPlaying = state === "playing";
338
410
  const isLoading = state === "loading";
@@ -471,6 +543,9 @@ function AudioPlayer({
471
543
  const handleWaveformSeek = React__namespace.useCallback((time) => {
472
544
  setCurrentTime(time);
473
545
  }, []);
546
+ const handleHoverTimeChange = React__namespace.useCallback((time) => {
547
+ setHoverTime(time);
548
+ }, []);
474
549
  const iconSize = size === "sm" ? "h-3.5 w-3.5" : size === "lg" ? "h-5 w-5" : "h-4 w-4";
475
550
  const getAriaLabel = () => {
476
551
  if (ariaLabel) return ariaLabel;
@@ -489,13 +564,24 @@ function AudioPlayer({
489
564
  children: isLoading ? /* @__PURE__ */ jsxRuntime.jsx(SpinnerIcon, { className: iconSize }) : isPlaying ? /* @__PURE__ */ jsxRuntime.jsx(PauseIcon, { className: iconSize }) : /* @__PURE__ */ jsxRuntime.jsx(PlayIcon, { className: iconSize })
490
565
  }
491
566
  );
492
- const renderTime = () => {
567
+ const renderTime = (useHoverTime = false) => {
493
568
  if (!showTime) return null;
494
- return /* @__PURE__ */ jsxRuntime.jsxs("span", { className: "font-mono text-xs text-neutral-500 tabular-nums dark:text-neutral-400", children: [
495
- formatTime(currentTime),
496
- " / ",
497
- formatTime(duration)
498
- ] });
569
+ const displayTime = useHoverTime && hoverTime !== null ? hoverTime : currentTime;
570
+ const isShowingHoverTime = useHoverTime && hoverTime !== null;
571
+ return /* @__PURE__ */ jsxRuntime.jsxs(
572
+ "span",
573
+ {
574
+ className: chunkOR5DRJCW_cjs.cn(
575
+ "font-mono text-xs tabular-nums",
576
+ isShowingHoverTime ? "text-primary-600 dark:text-primary-400" : "text-neutral-500 dark:text-neutral-400"
577
+ ),
578
+ children: [
579
+ formatTime(displayTime),
580
+ " / ",
581
+ formatTime(duration)
582
+ ]
583
+ }
584
+ );
499
585
  };
500
586
  const renderPlaybackRateControl = () => {
501
587
  if (!showPlaybackRate) return null;
@@ -551,13 +637,16 @@ function AudioPlayer({
551
637
  onSeek: handleWaveformSeek,
552
638
  waveColor,
553
639
  progressColor,
554
- height: waveformHeight
640
+ height: waveformHeight,
641
+ showHoverCursor: showWaveformHoverCursor,
642
+ onHoverTimeChange: handleHoverTimeChange,
643
+ cursorColor: waveformCursorColor
555
644
  }
556
645
  ),
557
646
  /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "flex items-center gap-3", children: [
558
647
  renderPlayButton(),
559
648
  /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "flex flex-1 items-center justify-between", children: [
560
- renderTime(),
649
+ renderTime(true),
561
650
  renderPlaybackRateControl()
562
651
  ] })
563
652
  ] })
@@ -570,5 +659,5 @@ exports.ProgressBar = ProgressBar;
570
659
  exports.audioPlayerVariants = audioPlayerVariants;
571
660
  exports.formatTime = formatTime;
572
661
  exports.playButtonVariants = playButtonVariants;
573
- //# sourceMappingURL=chunk-VWXGUNBR.cjs.map
574
- //# sourceMappingURL=chunk-VWXGUNBR.cjs.map
662
+ //# sourceMappingURL=chunk-AKTUXJPI.cjs.map
663
+ //# sourceMappingURL=chunk-AKTUXJPI.cjs.map