@mdigital_ui/ui 0.4.5 → 0.4.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (128) hide show
  1. package/README.md +258 -662
  2. package/dist/anchor/index.js +4 -0
  3. package/dist/anchor/index.js.map +1 -0
  4. package/dist/autocomplete/index.js +6 -0
  5. package/dist/autocomplete/index.js.map +1 -0
  6. package/dist/breadcrumbs/index.js +3 -3
  7. package/dist/calendar/index.js +4 -0
  8. package/dist/calendar/index.js.map +1 -0
  9. package/dist/chunk-3Z7RLVWD.js +258 -0
  10. package/dist/chunk-3Z7RLVWD.js.map +1 -0
  11. package/dist/chunk-5YEC6FDN.js +263 -0
  12. package/dist/chunk-5YEC6FDN.js.map +1 -0
  13. package/dist/{chunk-OTNKP5CD.js → chunk-6NXZWLSM.js} +3 -3
  14. package/dist/{chunk-OTNKP5CD.js.map → chunk-6NXZWLSM.js.map} +1 -1
  15. package/dist/{chunk-AL2EEKUY.js → chunk-6ROGWFQ2.js} +3 -3
  16. package/dist/{chunk-AL2EEKUY.js.map → chunk-6ROGWFQ2.js.map} +1 -1
  17. package/dist/{chunk-LJOQ2C5W.js → chunk-6RZEJRTC.js} +3 -3
  18. package/dist/{chunk-LJOQ2C5W.js.map → chunk-6RZEJRTC.js.map} +1 -1
  19. package/dist/chunk-74AF6PO2.js +374 -0
  20. package/dist/chunk-74AF6PO2.js.map +1 -0
  21. package/dist/chunk-75N6T3IS.js +77 -0
  22. package/dist/chunk-75N6T3IS.js.map +1 -0
  23. package/dist/{chunk-BKLJDEUX.js → chunk-DBPLQZJ2.js} +38 -14
  24. package/dist/chunk-DBPLQZJ2.js.map +1 -0
  25. package/dist/{chunk-HVHQA34X.js → chunk-DIUOGEL3.js} +95 -100
  26. package/dist/chunk-DIUOGEL3.js.map +1 -0
  27. package/dist/chunk-ED4CQZ72.js +343 -0
  28. package/dist/chunk-ED4CQZ72.js.map +1 -0
  29. package/dist/{chunk-4ZXHLPRS.js → chunk-FY2TZ2NT.js} +4 -4
  30. package/dist/{chunk-4ZXHLPRS.js.map → chunk-FY2TZ2NT.js.map} +1 -1
  31. package/dist/{chunk-I5AD247M.js → chunk-HKQOAEFY.js} +13 -3
  32. package/dist/chunk-HKQOAEFY.js.map +1 -0
  33. package/dist/chunk-JWYBDNC6.js +307 -0
  34. package/dist/chunk-JWYBDNC6.js.map +1 -0
  35. package/dist/{chunk-W5VLFE4U.js → chunk-LHZJ2GJU.js} +32 -6
  36. package/dist/chunk-LHZJ2GJU.js.map +1 -0
  37. package/dist/{chunk-253JZOYG.js → chunk-NB66D6A5.js} +3 -2
  38. package/dist/chunk-NB66D6A5.js.map +1 -0
  39. package/dist/{chunk-BGMYX7L5.js → chunk-NF6JUJBE.js} +9 -7
  40. package/dist/chunk-NF6JUJBE.js.map +1 -0
  41. package/dist/chunk-NPK4ESMA.js +281 -0
  42. package/dist/chunk-NPK4ESMA.js.map +1 -0
  43. package/dist/{chunk-X7MF3TIF.js → chunk-PD3O6ZH4.js} +12 -5
  44. package/dist/chunk-PD3O6ZH4.js.map +1 -0
  45. package/dist/{chunk-HJITFPBT.js → chunk-QDJ5PZPP.js} +14 -9
  46. package/dist/chunk-QDJ5PZPP.js.map +1 -0
  47. package/dist/chunk-QEYNOLRC.js +157 -0
  48. package/dist/chunk-QEYNOLRC.js.map +1 -0
  49. package/dist/chunk-RNG7HR6U.js +174 -0
  50. package/dist/chunk-RNG7HR6U.js.map +1 -0
  51. package/dist/chunk-TDPJYCNI.js +96 -0
  52. package/dist/chunk-TDPJYCNI.js.map +1 -0
  53. package/dist/chunk-UFYG3HKL.js +374 -0
  54. package/dist/chunk-UFYG3HKL.js.map +1 -0
  55. package/dist/chunk-VNH6R5EU.js +211 -0
  56. package/dist/chunk-VNH6R5EU.js.map +1 -0
  57. package/dist/{chunk-XOEEAMMY.js → chunk-X3VT5SSK.js} +88 -98
  58. package/dist/chunk-X3VT5SSK.js.map +1 -0
  59. package/dist/{chunk-SFP77VS3.js → chunk-X7JN7WPF.js} +5 -2
  60. package/dist/chunk-X7JN7WPF.js.map +1 -0
  61. package/dist/chunk-YRSHBAUQ.js +201 -0
  62. package/dist/chunk-YRSHBAUQ.js.map +1 -0
  63. package/dist/chunk-YUACN5GJ.js +303 -0
  64. package/dist/chunk-YUACN5GJ.js.map +1 -0
  65. package/dist/color-picker/index.js +6 -0
  66. package/dist/color-picker/index.js.map +1 -0
  67. package/dist/date-picker/RangePicker.d.ts.map +1 -1
  68. package/dist/date-picker/index.d.ts.map +1 -1
  69. package/dist/date-picker/index.js +1 -1
  70. package/dist/date-picker/shared.d.ts +5 -0
  71. package/dist/date-picker/shared.d.ts.map +1 -1
  72. package/dist/dropdown/index.js +2 -2
  73. package/dist/float-button/index.js +5 -0
  74. package/dist/float-button/index.js.map +1 -0
  75. package/dist/index.js +50 -2995
  76. package/dist/index.js.map +1 -1
  77. package/dist/input/index.d.ts.map +1 -1
  78. package/dist/input/index.js +1 -1
  79. package/dist/input-password/index.js +2 -2
  80. package/dist/mentions/index.js +4 -0
  81. package/dist/mentions/index.js.map +1 -0
  82. package/dist/menubar/index.d.ts +3 -3
  83. package/dist/menubar/index.d.ts.map +1 -1
  84. package/dist/menubar/index.js +2 -2
  85. package/dist/multi-select/index.d.ts.map +1 -1
  86. package/dist/multi-select/index.js +4 -4
  87. package/dist/number-input/index.d.ts.map +1 -1
  88. package/dist/number-input/index.js +1 -1
  89. package/dist/qr-code/index.js +5 -0
  90. package/dist/qr-code/index.js.map +1 -0
  91. package/dist/resizable/index.js +4 -0
  92. package/dist/resizable/index.js.map +1 -0
  93. package/dist/result/index.js +4 -0
  94. package/dist/result/index.js.map +1 -0
  95. package/dist/select/index.d.ts.map +1 -1
  96. package/dist/select/index.js +4 -4
  97. package/dist/shared/useSelectBase.d.ts.map +1 -1
  98. package/dist/skeleton/index.d.ts.map +1 -1
  99. package/dist/skeleton/index.js +1 -1
  100. package/dist/table/index.js +4 -4
  101. package/dist/tabs/index.d.ts.map +1 -1
  102. package/dist/tabs/index.js +1 -1
  103. package/dist/tags-input/index.js +5 -0
  104. package/dist/tags-input/index.js.map +1 -0
  105. package/dist/toast/index.d.ts.map +1 -1
  106. package/dist/toast/index.js +1 -1
  107. package/dist/tooltip/index.d.ts.map +1 -1
  108. package/dist/tooltip/index.js +1 -1
  109. package/dist/tour/index.js +5 -0
  110. package/dist/tour/index.js.map +1 -0
  111. package/dist/typography/index.js +4 -0
  112. package/dist/typography/index.js.map +1 -0
  113. package/dist/watermark/index.js +4 -0
  114. package/dist/watermark/index.js.map +1 -0
  115. package/package.json +59 -11
  116. package/styles/global.css +6 -3
  117. package/dist/chunk-253JZOYG.js.map +0 -1
  118. package/dist/chunk-BGMYX7L5.js.map +0 -1
  119. package/dist/chunk-BKLJDEUX.js.map +0 -1
  120. package/dist/chunk-HJITFPBT.js.map +0 -1
  121. package/dist/chunk-HVHQA34X.js.map +0 -1
  122. package/dist/chunk-I5AD247M.js.map +0 -1
  123. package/dist/chunk-JBNFVXH5.js +0 -322
  124. package/dist/chunk-JBNFVXH5.js.map +0 -1
  125. package/dist/chunk-SFP77VS3.js.map +0 -1
  126. package/dist/chunk-W5VLFE4U.js.map +0 -1
  127. package/dist/chunk-X7MF3TIF.js.map +0 -1
  128. package/dist/chunk-XOEEAMMY.js.map +0 -1
@@ -1,7 +1,7 @@
1
- import { useSelectBase } from './chunk-HJITFPBT.js';
1
+ import { useSelectBase } from './chunk-QDJ5PZPP.js';
2
2
  import { useControllable } from './chunk-PQOIW5CM.js';
3
- import { Popover, PopoverTrigger, PopoverContent } from './chunk-ROQGBDET.js';
4
3
  import { spinner_default } from './chunk-RRPMZYVN.js';
4
+ import { Popover, PopoverTrigger, PopoverContent } from './chunk-ROQGBDET.js';
5
5
  import { colorVars } from './chunk-G6QIIWKU.js';
6
6
  import { cn, iconSizes, statusMessageVariants } from './chunk-RAS6HUEI.js';
7
7
  import { cva } from 'class-variance-authority';
@@ -86,7 +86,11 @@ var Select = React.memo(
86
86
  ref,
87
87
  ...props
88
88
  }) => {
89
- const [currentValue, setCurrentValue] = useControllable({ value, defaultValue: defaultValue ?? "", onChange });
89
+ const [currentValue, setCurrentValue] = useControllable({
90
+ value,
91
+ defaultValue: defaultValue ?? "",
92
+ onChange
93
+ });
90
94
  const {
91
95
  // State
92
96
  isOpen,
@@ -168,7 +172,7 @@ var Select = React.memo(
168
172
  "div",
169
173
  {
170
174
  ref: scrollContainerRef,
171
- className: "overflow-auto relative",
175
+ className: "overflow-auto relative p-1",
172
176
  style: { maxHeight: maxDropdownHeight },
173
177
  role: "listbox",
174
178
  id: listboxId,
@@ -190,105 +194,95 @@ var Select = React.memo(
190
194
  {
191
195
  ref: refCallback,
192
196
  style: {
193
- height: `${Math.min(virtualizer.getTotalSize(), maxDropdownHeight)}px`,
194
- overflow: "auto"
197
+ height: `${virtualizer.getTotalSize()}px`,
198
+ width: "100%",
199
+ position: "relative"
195
200
  },
196
- onScroll: handleScroll,
197
- children: /* @__PURE__ */ jsx(
198
- "div",
199
- {
200
- style: {
201
- height: `${virtualizer.getTotalSize()}px`,
202
- width: "100%",
203
- position: "relative"
204
- },
205
- children: virtualizer.getVirtualItems().map((virtualItem) => {
206
- const item = filteredOptions[virtualItem.index];
207
- if (!item) return null;
208
- if (item.type === "group") {
209
- return /* @__PURE__ */ jsx(
210
- "div",
201
+ children: virtualizer.getVirtualItems().map((virtualItem) => {
202
+ const item = filteredOptions[virtualItem.index];
203
+ if (!item) return null;
204
+ if (item.type === "group") {
205
+ return /* @__PURE__ */ jsx(
206
+ "div",
207
+ {
208
+ "data-slot": "group",
209
+ style: {
210
+ position: "absolute",
211
+ top: 0,
212
+ left: 0,
213
+ width: "100%",
214
+ height: `${virtualItem.size}px`,
215
+ transform: `translateY(${virtualItem.start}px)`
216
+ },
217
+ className: cn(
218
+ "select_group",
219
+ selectGroupVariants(),
220
+ classNames?.group
221
+ ),
222
+ children: /* @__PURE__ */ jsx(
223
+ "span",
211
224
  {
212
- "data-slot": "group",
213
- style: {
214
- position: "absolute",
215
- top: 0,
216
- left: 0,
217
- width: "100%",
218
- height: `${virtualItem.size}px`,
219
- transform: `translateY(${virtualItem.start}px)`
220
- },
225
+ "data-slot": "groupLabel",
221
226
  className: cn(
222
- "select_group",
223
- selectGroupVariants(),
224
- classNames?.group
227
+ "select_groupLabel",
228
+ classNames?.groupLabel
225
229
  ),
226
- children: /* @__PURE__ */ jsx(
227
- "span",
228
- {
229
- "data-slot": "groupLabel",
230
- className: cn(
231
- "select_groupLabel",
232
- classNames?.groupLabel
233
- ),
234
- children: item.data
235
- }
236
- )
237
- },
238
- `group-${virtualItem.index}`
239
- );
240
- }
241
- const option = item.data;
242
- const isSelected = option.value === currentValue;
243
- const selectableIndex = selectableOptions.indexOf(
244
- item
245
- );
246
- const isHighlighted = selectableIndex === highlightedIndex;
247
- return /* @__PURE__ */ jsxs(
248
- "div",
249
- {
250
- "data-slot": "option",
251
- "data-value": option.value,
252
- style: {
253
- position: "absolute",
254
- top: 0,
255
- left: 0,
256
- width: "100%",
257
- height: `${virtualItem.size}px`,
258
- transform: `translateY(${virtualItem.start}px)`
259
- },
260
- className: cn(
261
- "select_option",
262
- selectOptionVariants({
263
- selected: isSelected,
264
- disabled: !!option.disabled
265
- }),
266
- isHighlighted && "bg-surface",
267
- classNames?.option,
268
- isSelected && classNames?.optionSelected
269
- ),
270
- onClick: () => !option.disabled && handleOptionClick(option.value),
271
- role: "option",
272
- "aria-selected": isSelected,
273
- "aria-disabled": option.disabled,
274
- children: [
275
- option.label,
276
- isSelected && /* @__PURE__ */ jsx("span", { className: "absolute right-3 top-1/2 -translate-y-1/2", children: /* @__PURE__ */ jsx(
277
- Check,
278
- {
279
- className: cn(
280
- "text-slot animate-in zoom-in-75 duration-150",
281
- iconSizes[size]
282
- )
283
- }
284
- ) })
285
- ]
286
- },
287
- option.value
288
- );
289
- })
230
+ children: item.data
231
+ }
232
+ )
233
+ },
234
+ `group-${virtualItem.index}`
235
+ );
290
236
  }
291
- )
237
+ const option = item.data;
238
+ const isSelected = option.value === currentValue;
239
+ const selectableIndex = selectableOptions.indexOf(
240
+ item
241
+ );
242
+ const isHighlighted = selectableIndex === highlightedIndex;
243
+ return /* @__PURE__ */ jsxs(
244
+ "div",
245
+ {
246
+ "data-slot": "option",
247
+ "data-value": option.value,
248
+ style: {
249
+ position: "absolute",
250
+ top: 0,
251
+ left: 0,
252
+ width: "100%",
253
+ height: `${virtualItem.size}px`,
254
+ transform: `translateY(${virtualItem.start}px)`
255
+ },
256
+ className: cn(
257
+ "select_option",
258
+ selectOptionVariants({
259
+ selected: isSelected,
260
+ disabled: !!option.disabled
261
+ }),
262
+ isHighlighted && "bg-surface",
263
+ classNames?.option,
264
+ isSelected && classNames?.optionSelected
265
+ ),
266
+ onClick: () => !option.disabled && handleOptionClick(option.value),
267
+ role: "option",
268
+ "aria-selected": isSelected,
269
+ "aria-disabled": option.disabled,
270
+ children: [
271
+ option.label,
272
+ isSelected && /* @__PURE__ */ jsx("span", { className: "absolute right-3 top-1/2 -translate-y-1/2", children: /* @__PURE__ */ jsx(
273
+ Check,
274
+ {
275
+ className: cn(
276
+ "text-slot animate-in zoom-in-75 duration-150",
277
+ iconSizes[size]
278
+ )
279
+ }
280
+ ) })
281
+ ]
282
+ },
283
+ option.value
284
+ );
285
+ })
292
286
  }
293
287
  ) : /* @__PURE__ */ jsx("div", { children: filteredOptions.map((item, index) => {
294
288
  if (item.type === "group") {
@@ -327,6 +321,7 @@ var Select = React.memo(
327
321
  {
328
322
  "data-slot": "option",
329
323
  "data-value": option.value,
324
+ "data-option-index": index,
330
325
  className: cn(
331
326
  "select_option",
332
327
  selectOptionVariants({
@@ -530,5 +525,5 @@ Select.displayName = "Select";
530
525
  var select_default = Select;
531
526
 
532
527
  export { select_default };
533
- //# sourceMappingURL=chunk-HVHQA34X.js.map
534
- //# sourceMappingURL=chunk-HVHQA34X.js.map
528
+ //# sourceMappingURL=chunk-DIUOGEL3.js.map
529
+ //# sourceMappingURL=chunk-DIUOGEL3.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/select/index.tsx"],"names":[],"mappings":"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","file":"chunk-DIUOGEL3.js","sourcesContent":["\"use client\";\n\nimport { cva } from \"class-variance-authority\";\nimport { Check, ChevronDown, ChevronUp, Search, X } from \"lucide-react\";\nimport React from \"react\";\nimport { useControllable } from \"../hooks/useControllable\";\n\nimport Spinner from \"../spinner\";\n\nimport { Popover, PopoverContent, PopoverTrigger } from \"../popover\";\nimport { colorVars } from \"../variants\";\nimport { useSelectBase } from \"../shared/useSelectBase\";\nimport type { FlattenedItem } from \"../shared/useSelectBase\";\nimport { cn, iconSizes, statusMessageVariants } from \"../utils\";\nimport type { SelectOption, SelectProps } from \"./types\";\n\nconst selectTriggerVariants = cva(\n \"w-full flex items-center justify-between rounded-md bg-background text-text-primary border focus:border-primary outline-none disabled:opacity-50 disabled:cursor-not-allowed cursor-pointer transition-colors\",\n {\n variants: {\n status: {\n default: \"border-border hover:border-primary/50\",\n error: \"border-error\",\n warning: \"border-warning\",\n info: \"border-info\",\n success: \"border-success\",\n },\n size: {\n xs: \"h-(--select-height-xs) px-(--select-padding-x-xs) text-xs gap-1.5\",\n sm: \"h-(--select-height-sm) px-(--select-padding-x-sm) text-sm gap-2\",\n md: \"h-(--select-height-md) px-(--select-padding-x-md) text-base gap-2.5\",\n lg: \"h-(--select-height-lg) px-(--select-padding-x-lg) text-lg gap-3\",\n },\n fullWidth: {\n true: \"w-full\",\n false: \"max-w-full\",\n },\n },\n defaultVariants: {\n status: \"default\",\n size: \"md\",\n fullWidth: true,\n },\n },\n);\n\nconst selectOptionVariants = cva(\n \"relative cursor-pointer select-none px-3 py-2 text-text-primary rounded-sm transition-colors\",\n {\n variants: {\n selected: {\n true: \"bg-slot-10 text-slot font-medium\",\n false: \"hover:bg-surface\",\n },\n disabled: {\n true: \"opacity-50 cursor-not-allowed\",\n false: \"\",\n },\n },\n defaultVariants: {\n selected: false,\n disabled: false,\n },\n },\n);\n\nconst selectGroupVariants = cva(\n \"px-3 py-2 text-xs font-semibold text-text-secondary uppercase tracking-wider bg-surface/50\",\n);\n\nconst Select = React.memo<SelectProps>(\n ({\n size = \"md\",\n label,\n helperText,\n error,\n warning,\n info,\n success,\n options = [],\n placeholder = \"Select an option\",\n loading = false,\n fullWidth = true,\n value,\n defaultValue,\n onChange,\n clearable = false,\n disabled,\n required,\n virtualizeThreshold = 50,\n maxDropdownHeight = 300,\n className,\n classNames,\n ref,\n ...props\n }) => {\n const [currentValue, setCurrentValue] = useControllable<string | number>({\n value,\n defaultValue: defaultValue ?? \"\",\n onChange,\n });\n\n const {\n // State\n isOpen,\n setIsOpen,\n searchQuery,\n setSearchQuery,\n setHighlightedIndex,\n highlightedIndex,\n showTopArrow,\n showBottomArrow,\n // Refs\n triggerRef,\n inputRef,\n scrollContainerRef,\n // Computed\n filteredOptions,\n selectableOptions,\n shouldVirtualize,\n virtualizer,\n // IDs & validation\n labelId,\n listboxId,\n helperId,\n status,\n helperMessage,\n // Handlers\n handleInputChange,\n handleInputClick,\n handleScroll,\n handleKeyDown,\n handleKeyUp,\n refCallback,\n } = useSelectBase<SelectOption>({\n options,\n onSelectOption: (option) => handleSelect(option.value),\n virtualizeThreshold,\n maxDropdownHeight,\n label,\n idPrefix: \"select\",\n error,\n warning,\n info,\n success,\n helperText,\n });\n\n const handleSelect = React.useCallback(\n (optionValue: string | number) => {\n setCurrentValue(optionValue);\n setIsOpen(false);\n setSearchQuery(\"\");\n setHighlightedIndex(-1);\n },\n [setCurrentValue, setIsOpen, setSearchQuery, setHighlightedIndex],\n );\n\n const selectedOption = React.useMemo(\n () => options.find((opt) => opt.value === currentValue),\n [options, currentValue],\n );\n const displayValue = isOpen ? searchQuery : selectedOption?.label || \"\";\n\n const handleClear = React.useCallback(\n (e: React.MouseEvent) => {\n e.stopPropagation();\n setCurrentValue(\"\");\n setSearchQuery(\"\");\n setHighlightedIndex(-1);\n },\n [setCurrentValue, setSearchQuery, setHighlightedIndex],\n );\n\n const handleOptionClick = React.useCallback(\n (optionValue: string | number) => {\n handleSelect(optionValue);\n },\n [handleSelect],\n );\n\n const renderOptionsList = React.useMemo(\n () => (\n <div className=\"relative\">\n {/* Top scroll indicator */}\n <div className=\"flex items-center justify-center h-4\">\n {showTopArrow && (\n <ChevronUp className=\"size-4 text-text-primary animate-in fade-in duration-150\" />\n )}\n </div>\n\n <div\n ref={scrollContainerRef}\n className=\"overflow-auto relative p-1\"\n style={{ maxHeight: maxDropdownHeight }}\n role=\"listbox\"\n id={listboxId}\n aria-labelledby={label ? labelId : undefined}\n onScroll={handleScroll}\n >\n {!filteredOptions.length ? (\n <div\n data-slot=\"empty\"\n className={cn(\n \"select_empty\",\n \"px-3 py-4 text-center text-sm text-text-secondary\",\n classNames?.empty,\n )}\n >\n No options found\n </div>\n ) : shouldVirtualize ? (\n <div\n ref={refCallback}\n style={{\n height: `${virtualizer.getTotalSize()}px`,\n width: \"100%\",\n position: \"relative\",\n }}\n >\n {virtualizer.getVirtualItems().map((virtualItem) => {\n const item = filteredOptions[virtualItem.index];\n\n if (!item) return null;\n\n if (item.type === \"group\") {\n return (\n <div\n key={`group-${virtualItem.index}`}\n data-slot=\"group\"\n style={{\n position: \"absolute\",\n top: 0,\n left: 0,\n width: \"100%\",\n height: `${virtualItem.size}px`,\n transform: `translateY(${virtualItem.start}px)`,\n }}\n className={cn(\n \"select_group\",\n selectGroupVariants(),\n classNames?.group,\n )}\n >\n <span\n data-slot=\"groupLabel\"\n className={cn(\n \"select_groupLabel\",\n classNames?.groupLabel,\n )}\n >\n {item.data as string}\n </span>\n </div>\n );\n }\n\n const option = item.data as SelectOption;\n const isSelected = option.value === currentValue;\n const selectableIndex = selectableOptions.indexOf(\n item as FlattenedItem<SelectOption>,\n );\n const isHighlighted = selectableIndex === highlightedIndex;\n\n return (\n <div\n key={option.value}\n data-slot=\"option\"\n data-value={option.value}\n style={{\n position: \"absolute\",\n top: 0,\n left: 0,\n width: \"100%\",\n height: `${virtualItem.size}px`,\n transform: `translateY(${virtualItem.start}px)`,\n }}\n className={cn(\n \"select_option\",\n selectOptionVariants({\n selected: isSelected,\n disabled: !!option.disabled,\n }),\n isHighlighted && \"bg-surface\",\n classNames?.option,\n isSelected && classNames?.optionSelected,\n )}\n onClick={() =>\n !option.disabled && handleOptionClick(option.value)\n }\n role=\"option\"\n aria-selected={isSelected}\n aria-disabled={option.disabled}\n >\n {option.label}\n {isSelected && (\n <span className=\"absolute right-3 top-1/2 -translate-y-1/2\">\n <Check\n className={cn(\n \"text-slot animate-in zoom-in-75 duration-150\",\n iconSizes[size],\n )}\n />\n </span>\n )}\n </div>\n );\n })}\n </div>\n ) : (\n <div>\n {filteredOptions.map((item, index) => {\n if (item.type === \"group\") {\n return (\n <div\n key={`group-${index}`}\n data-slot=\"group\"\n className={cn(\n \"select_group\",\n selectGroupVariants(),\n classNames?.group,\n )}\n >\n <span\n data-slot=\"groupLabel\"\n className={cn(\n \"select_groupLabel\",\n classNames?.groupLabel,\n )}\n >\n {item.data as string}\n </span>\n </div>\n );\n }\n\n const option = item.data as SelectOption;\n const isSelected = option.value === currentValue;\n const selectableIndex = selectableOptions.indexOf(\n item as FlattenedItem<SelectOption>,\n );\n const isHighlighted = selectableIndex === highlightedIndex;\n\n return (\n <div\n key={option.value}\n data-slot=\"option\"\n data-value={option.value}\n data-option-index={index}\n className={cn(\n \"select_option\",\n selectOptionVariants({\n selected: isSelected,\n disabled: !!option.disabled,\n }),\n isHighlighted && \"bg-surface\",\n classNames?.option,\n isSelected && classNames?.optionSelected,\n )}\n onClick={() =>\n !option.disabled && handleOptionClick(option.value)\n }\n role=\"option\"\n aria-selected={isSelected}\n aria-disabled={option.disabled}\n >\n {option.label}\n {isSelected && (\n <span className=\"absolute right-3 top-1/2 -translate-y-1/2\">\n <Check\n className={cn(\n \"text-slot animate-in zoom-in-75 duration-150\",\n iconSizes[size],\n )}\n />\n </span>\n )}\n </div>\n );\n })}\n </div>\n )}\n </div>\n\n {/* Bottom scroll indicator */}\n <div className=\"flex items-center justify-center h-4\">\n {showBottomArrow && (\n <ChevronDown className=\"size-4 text-text-primary animate-in fade-in duration-150\" />\n )}\n </div>\n </div>\n ),\n [\n showTopArrow,\n showBottomArrow,\n filteredOptions,\n shouldVirtualize,\n virtualizer,\n currentValue,\n selectableOptions,\n highlightedIndex,\n handleOptionClick,\n maxDropdownHeight,\n listboxId,\n label,\n labelId,\n handleScroll,\n refCallback,\n classNames,\n size,\n ],\n );\n\n // Trigger button (used in both desktop and mobile)\n const triggerButton = (\n <button\n ref={triggerRef}\n type=\"button\"\n data-slot=\"trigger\"\n className={cn(\n \"select_trigger\",\n selectTriggerVariants({ status, size, fullWidth }),\n loading && \"opacity-50\",\n className,\n classNames?.trigger,\n )}\n disabled={disabled || loading}\n aria-haspopup=\"listbox\"\n aria-expanded={isOpen}\n aria-controls={listboxId}\n aria-labelledby={label ? labelId : undefined}\n aria-describedby={helperMessage ? helperId : undefined}\n >\n <input\n ref={inputRef}\n type=\"text\"\n data-slot=\"search\"\n className={cn(\n \"select_search\",\n \"w-full text-ellipsis flex-1 bg-transparent outline-none cursor-pointer placeholder:text-text-secondary/50\",\n classNames?.search,\n )}\n placeholder={placeholder}\n value={displayValue}\n onChange={handleInputChange}\n onClick={handleInputClick}\n onKeyDown={handleKeyDown}\n onKeyUp={handleKeyUp}\n disabled={disabled || loading}\n readOnly={!isOpen}\n tabIndex={0}\n aria-autocomplete=\"list\"\n aria-controls={isOpen ? listboxId : undefined}\n />\n <div\n data-slot=\"triggerIcon\"\n className={cn(\n \"select_triggerIcon\",\n \"flex items-center gap-1 text-text-secondary\",\n classNames?.triggerIcon,\n )}\n >\n {clearable && currentValue && !disabled && !loading && (\n <span\n role=\"button\"\n tabIndex={-1}\n onClick={handleClear}\n onKeyDown={(e) => {\n if (e.key === \"Enter\" || e.key === \" \") {\n e.preventDefault();\n handleClear(e as unknown as React.MouseEvent);\n }\n }}\n className=\"hover:text-text-primary transition-colors cursor-pointer\"\n aria-label=\"Clear selection\"\n >\n <X className={iconSizes[size]} />\n </span>\n )}\n {loading ? (\n <Spinner />\n ) : (\n <>\n {isOpen ? (\n <Search className={iconSizes[size]} />\n ) : (\n <ChevronDown className={iconSizes[size]} />\n )}\n </>\n )}\n </div>\n </button>\n );\n\n const selectElement = (\n <div\n data-slot=\"root\"\n className={cn(\n \"select_root\",\n \"relative group\",\n colorVars.primary,\n fullWidth ? \"w-full\" : \"inline-block\",\n classNames?.root,\n )}\n ref={ref}\n {...props}\n >\n <Popover open={isOpen} onOpenChange={setIsOpen}>\n <PopoverTrigger asChild>{triggerButton}</PopoverTrigger>\n\n <PopoverContent\n data-slot=\"dropdown\"\n className={cn(\n \"select_dropdown\",\n \"p-0 w-[var(--radix-popover-trigger-width)]\",\n classNames?.dropdown,\n )}\n align=\"start\"\n onOpenAutoFocus={(e: Event) => {\n e.preventDefault();\n inputRef.current?.focus();\n }}\n >\n {renderOptionsList}\n </PopoverContent>\n </Popover>\n </div>\n );\n\n return (\n <div className={cn(\"w-full flex flex-col\", !fullWidth && \"inline-block\")}>\n <div className=\"flex gap-2 items-center\">\n {label && (\n <label\n id={labelId}\n data-slot=\"label\"\n className={cn(\"select_label\", \"block mb-0.5\", classNames?.label)}\n >\n <span className=\"text-sm font-medium text-text-secondary\">\n {label}\n {required && <span className=\"text-error ml-1\">*</span>}\n </span>\n </label>\n )}\n {helperMessage && (\n <p\n id={helperId}\n data-slot=\"helper\"\n className={cn(\n \"select_helper\",\n statusMessageVariants({ status }),\n classNames?.helper,\n )}\n >\n {helperMessage}\n </p>\n )}\n </div>\n {selectElement}\n </div>\n );\n },\n);\n\nSelect.displayName = \"Select\";\n\nexport type * from \"./types\";\nexport default Select;\n"]}
@@ -0,0 +1,343 @@
1
+ import { useMenuNavigation } from './chunk-NZHKNUGE.js';
2
+ import { Popover, PopoverTrigger, PopoverContent } from './chunk-ROQGBDET.js';
3
+ import { cn } from './chunk-RAS6HUEI.js';
4
+ import React, { useState, useMemo, useCallback, useEffect } from 'react';
5
+ import { ChevronRight, Check, Circle } from 'lucide-react';
6
+ import { jsx, Fragment, jsxs } from 'react/jsx-runtime';
7
+
8
+ var ITEM_CLASS = "menubar_item relative flex items-center gap-2 px-3 py-1.5 text-sm cursor-pointer transition-colors last:rounded-b-sm first:rounded-t-sm";
9
+ var MenuItems = React.memo(
10
+ ({ items, classNames, onItemClick, onClose }) => {
11
+ const [activeSubmenu, setActiveSubmenu] = useState(null);
12
+ const hasAnyIcon = useMemo(
13
+ () => items.some(
14
+ (item) => !item.separator && item.type !== "label" && (item.icon || item.type === "checkbox" || item.type === "radio")
15
+ ),
16
+ [items]
17
+ );
18
+ const enabledIndices = useMemo(
19
+ () => items.map(
20
+ (item, i) => !item.separator && item.type !== "label" && !item.disabled ? i : -1
21
+ ).filter((i) => i !== -1),
22
+ [items]
23
+ );
24
+ const onMenuSelect = useCallback(
25
+ (index) => {
26
+ const item = items[index];
27
+ if (!item || item.children && item.children.length > 0) return;
28
+ onItemClick(item);
29
+ },
30
+ [items, onItemClick]
31
+ );
32
+ const { highlightedIndex, handleKeyDown, highlightFirst } = useMenuNavigation({
33
+ enabledIndices,
34
+ isOpen: true,
35
+ onClose,
36
+ onSelect: onMenuSelect
37
+ });
38
+ useEffect(() => {
39
+ highlightFirst();
40
+ }, [highlightFirst]);
41
+ useEffect(() => {
42
+ const listener = (e) => {
43
+ handleKeyDown(e);
44
+ e.stopImmediatePropagation();
45
+ };
46
+ document.addEventListener("keydown", listener);
47
+ return () => document.removeEventListener("keydown", listener);
48
+ }, [handleKeyDown]);
49
+ return /* @__PURE__ */ jsx(Fragment, { children: items.map((item, idx) => {
50
+ if (item.separator) {
51
+ return /* @__PURE__ */ jsx(
52
+ "div",
53
+ {
54
+ "data-slot": "separator",
55
+ className: cn(
56
+ "menubar_separator h-px bg-border my-1 -mx-1",
57
+ classNames?.separator
58
+ ),
59
+ role: "separator"
60
+ },
61
+ item.key || `separator-${idx}`
62
+ );
63
+ }
64
+ if (item.type === "label") {
65
+ return /* @__PURE__ */ jsx(
66
+ "div",
67
+ {
68
+ "data-slot": "label",
69
+ className: cn(
70
+ "menubar_label px-3 py-1.5 text-xs font-semibold text-text-secondary mx-1",
71
+ classNames?.label
72
+ ),
73
+ role: "presentation",
74
+ children: item.label
75
+ },
76
+ item.key
77
+ );
78
+ }
79
+ const isCheckboxOrRadio = item.type === "checkbox" || item.type === "radio";
80
+ const hasChildren = item.children && item.children.length > 0;
81
+ const isFocused = highlightedIndex === idx;
82
+ if (hasChildren) {
83
+ return /* @__PURE__ */ jsxs(
84
+ Popover,
85
+ {
86
+ open: activeSubmenu === item.key,
87
+ onOpenChange: (open) => setActiveSubmenu(open ? item.key : null),
88
+ children: [
89
+ /* @__PURE__ */ jsx(PopoverTrigger, { asChild: true, children: /* @__PURE__ */ jsxs(
90
+ "div",
91
+ {
92
+ "data-slot": "item",
93
+ className: cn(
94
+ ITEM_CLASS,
95
+ item.disabled ? "opacity-50 cursor-not-allowed" : "hover:bg-surface focus-visible:bg-surface focus-visible:outline-none",
96
+ isFocused && !item.disabled && "bg-surface",
97
+ classNames?.item
98
+ ),
99
+ role: "menuitem",
100
+ "aria-disabled": item.disabled,
101
+ "aria-haspopup": "menu",
102
+ tabIndex: item.disabled ? -1 : 0,
103
+ onMouseEnter: () => !item.disabled && setActiveSubmenu(item.key),
104
+ children: [
105
+ item.icon ? /* @__PURE__ */ jsx("span", { className: "w-4 h-4 shrink-0", children: item.icon }) : hasAnyIcon && /* @__PURE__ */ jsx("span", { className: "w-4 h-4 shrink-0" }),
106
+ /* @__PURE__ */ jsx("span", { className: "flex-1", children: item.label }),
107
+ /* @__PURE__ */ jsx(ChevronRight, { className: "w-4 h-4 ml-2 shrink-0" })
108
+ ]
109
+ }
110
+ ) }),
111
+ /* @__PURE__ */ jsx(
112
+ PopoverContent,
113
+ {
114
+ side: "right",
115
+ align: "start",
116
+ "data-slot": "submenu",
117
+ className: cn(
118
+ "menubar_submenu min-w-[200px] w-auto p-1 rounded-md",
119
+ classNames?.submenu
120
+ ),
121
+ onOpenAutoFocus: (e) => e.preventDefault(),
122
+ onCloseAutoFocus: (e) => e.preventDefault(),
123
+ children: /* @__PURE__ */ jsx(
124
+ MenuItems,
125
+ {
126
+ items: item.children,
127
+ classNames,
128
+ onItemClick,
129
+ onClose
130
+ }
131
+ )
132
+ }
133
+ )
134
+ ]
135
+ },
136
+ item.key
137
+ );
138
+ }
139
+ return /* @__PURE__ */ jsxs(
140
+ "div",
141
+ {
142
+ "data-slot": "item",
143
+ className: cn(
144
+ ITEM_CLASS,
145
+ item.disabled ? "opacity-50 cursor-not-allowed" : "hover:bg-surface focus-visible:bg-surface focus-visible:outline-none",
146
+ isFocused && !item.disabled && "bg-surface",
147
+ isCheckboxOrRadio && classNames?.checkboxItem,
148
+ item.type === "radio" && classNames?.radioItem,
149
+ classNames?.item
150
+ ),
151
+ role: item.type === "checkbox" ? "menuitemcheckbox" : item.type === "radio" ? "menuitemradio" : "menuitem",
152
+ "aria-disabled": item.disabled,
153
+ "aria-checked": isCheckboxOrRadio ? item.checked : void 0,
154
+ tabIndex: item.disabled ? -1 : 0,
155
+ onClick: () => !item.disabled && onItemClick(item),
156
+ children: [
157
+ isCheckboxOrRadio && /* @__PURE__ */ jsx("span", { className: "w-4 h-4 shrink-0", children: item.checked && /* @__PURE__ */ jsxs(Fragment, { children: [
158
+ item.type === "checkbox" && /* @__PURE__ */ jsx(Check, { className: "w-4 h-4" }),
159
+ item.type === "radio" && /* @__PURE__ */ jsx(Circle, { className: "w-4 h-4 fill-current" })
160
+ ] }) }),
161
+ !isCheckboxOrRadio && (item.icon ? /* @__PURE__ */ jsx("span", { className: "w-4 h-4 shrink-0", children: item.icon }) : hasAnyIcon && /* @__PURE__ */ jsx("span", { className: "w-4 h-4 shrink-0" })),
162
+ /* @__PURE__ */ jsx("span", { className: "flex-1", children: item.label }),
163
+ item.shortcut && /* @__PURE__ */ jsx(
164
+ "span",
165
+ {
166
+ "data-slot": "shortcut",
167
+ className: cn(
168
+ "menubar_shortcut text-xs text-text-secondary ml-auto",
169
+ classNames?.shortcut
170
+ ),
171
+ children: item.shortcut
172
+ }
173
+ )
174
+ ]
175
+ },
176
+ item.key
177
+ );
178
+ }) });
179
+ }
180
+ );
181
+ MenuItems.displayName = "MenuItems";
182
+ var Menubar = React.memo(
183
+ ({ menus, className, classNames, ref }) => {
184
+ const [activeMenu, setActiveMenu] = useState(null);
185
+ const [hoverMode, setHoverMode] = useState(false);
186
+ const handleMenuClick = useCallback(
187
+ (menuKey, disabled) => {
188
+ if (disabled) return;
189
+ setActiveMenu((prev) => prev === menuKey ? null : menuKey);
190
+ setHoverMode(true);
191
+ },
192
+ []
193
+ );
194
+ const handleMenuHover = useCallback(
195
+ (menuKey, disabled) => {
196
+ if (disabled) return;
197
+ if (hoverMode && activeMenu !== null) {
198
+ setActiveMenu(menuKey);
199
+ }
200
+ },
201
+ [hoverMode, activeMenu]
202
+ );
203
+ const handleClose = useCallback(() => {
204
+ setActiveMenu(null);
205
+ setHoverMode(false);
206
+ }, []);
207
+ const handleItemClick = useCallback(
208
+ (item) => {
209
+ if (item.type === "checkbox") {
210
+ item.onCheckedChange?.(!item.checked);
211
+ } else if (item.type === "radio") {
212
+ item.onCheckedChange?.(true);
213
+ } else {
214
+ item.onClick?.();
215
+ }
216
+ if (item.type !== "checkbox" && item.type !== "radio") {
217
+ handleClose();
218
+ }
219
+ },
220
+ [handleClose]
221
+ );
222
+ useEffect(() => {
223
+ if (!activeMenu) return;
224
+ const handler = (e) => {
225
+ const currentIndex = menus.findIndex((m) => m.key === activeMenu);
226
+ if (e.key === "ArrowRight") {
227
+ e.preventDefault();
228
+ e.stopImmediatePropagation();
229
+ let next = (currentIndex + 1) % menus.length;
230
+ let attempts = 0;
231
+ while (attempts < menus.length && menus[next]?.disabled) {
232
+ next = (next + 1) % menus.length;
233
+ attempts++;
234
+ }
235
+ const nextMenu = menus[next];
236
+ if (attempts < menus.length && nextMenu && !nextMenu.disabled) {
237
+ setActiveMenu(nextMenu.key);
238
+ }
239
+ } else if (e.key === "ArrowLeft") {
240
+ e.preventDefault();
241
+ e.stopImmediatePropagation();
242
+ let prev = currentIndex - 1 < 0 ? menus.length - 1 : currentIndex - 1;
243
+ let attempts = 0;
244
+ while (attempts < menus.length && menus[prev]?.disabled) {
245
+ prev = prev - 1 < 0 ? menus.length - 1 : prev - 1;
246
+ attempts++;
247
+ }
248
+ const prevMenu = menus[prev];
249
+ if (attempts < menus.length && prevMenu && !prevMenu.disabled) {
250
+ setActiveMenu(prevMenu.key);
251
+ }
252
+ }
253
+ };
254
+ document.addEventListener("keydown", handler);
255
+ return () => document.removeEventListener("keydown", handler);
256
+ }, [activeMenu, menus]);
257
+ return /* @__PURE__ */ jsx(
258
+ "div",
259
+ {
260
+ ref,
261
+ "data-slot": "root",
262
+ className: cn(
263
+ "menubar_root flex items-center gap-1 px-2 py-1 bg-background border-b border-border",
264
+ className,
265
+ classNames?.root
266
+ ),
267
+ role: "menubar",
268
+ children: menus.map((menu) => /* @__PURE__ */ jsxs(
269
+ Popover,
270
+ {
271
+ open: activeMenu === menu.key,
272
+ onOpenChange: (open) => {
273
+ if (open) {
274
+ setActiveMenu(menu.key);
275
+ setHoverMode(true);
276
+ } else {
277
+ handleClose();
278
+ }
279
+ },
280
+ children: [
281
+ /* @__PURE__ */ jsx(PopoverTrigger, { asChild: true, children: /* @__PURE__ */ jsx(
282
+ "button",
283
+ {
284
+ "data-slot": "trigger",
285
+ className: cn(
286
+ "menubar_trigger px-3 py-1.5 text-sm rounded-sm transition-colors",
287
+ menu.disabled ? "opacity-50 cursor-not-allowed" : "hover:bg-surface focus-visible:bg-surface focus-visible:outline-none",
288
+ activeMenu === menu.key && "bg-surface",
289
+ classNames?.trigger
290
+ ),
291
+ role: "menuitem",
292
+ "aria-haspopup": "menu",
293
+ "aria-expanded": activeMenu === menu.key,
294
+ "aria-disabled": menu.disabled,
295
+ onClick: () => handleMenuClick(menu.key, menu.disabled),
296
+ onMouseEnter: () => handleMenuHover(menu.key, menu.disabled),
297
+ children: menu.label
298
+ }
299
+ ) }),
300
+ /* @__PURE__ */ jsx(
301
+ PopoverContent,
302
+ {
303
+ side: "bottom",
304
+ align: "start",
305
+ sideOffset: 2,
306
+ "data-slot": "content",
307
+ className: cn(
308
+ "menubar_content min-w-[200px] w-auto p-1 rounded-md",
309
+ classNames?.content
310
+ ),
311
+ onOpenAutoFocus: (e) => e.preventDefault(),
312
+ onCloseAutoFocus: (e) => e.preventDefault(),
313
+ onPointerDownOutside: (e) => {
314
+ const target = e.target;
315
+ if (target.closest('[data-slot="root"]')) {
316
+ e.preventDefault();
317
+ }
318
+ },
319
+ children: /* @__PURE__ */ jsx(
320
+ MenuItems,
321
+ {
322
+ items: menu.items,
323
+ classNames,
324
+ onItemClick: handleItemClick,
325
+ onClose: handleClose
326
+ }
327
+ )
328
+ }
329
+ )
330
+ ]
331
+ },
332
+ menu.key
333
+ ))
334
+ }
335
+ );
336
+ }
337
+ );
338
+ Menubar.displayName = "Menubar";
339
+ var menubar_default = Menubar;
340
+
341
+ export { menubar_default };
342
+ //# sourceMappingURL=chunk-ED4CQZ72.js.map
343
+ //# sourceMappingURL=chunk-ED4CQZ72.js.map