@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 } from './chunk-RAS6HUEI.js';
7
7
  import { ChevronUp, Check, ChevronDown, X, Search } from 'lucide-react';
@@ -42,7 +42,7 @@ cva(
42
42
  "absolute z-[var(--z-dropdown)] mt-1 overflow-auto rounded-md border border-border bg-background"
43
43
  );
44
44
  var multiSelectOptionVariants = cva(
45
- "relative cursor-pointer select-none px-3 py-2 text-text-primary",
45
+ "relative cursor-pointer select-none px-3 py-2 text-text-primary rounded-sm",
46
46
  {
47
47
  variants: {
48
48
  selected: {
@@ -90,7 +90,11 @@ var MultiSelect = React.memo(
90
90
  ref,
91
91
  ...props
92
92
  }) => {
93
- const [controlledVal, setCurrentValue] = useControllable({ value, defaultValue: defaultValue ?? [], onChange });
93
+ const [controlledVal, setCurrentValue] = useControllable({
94
+ value,
95
+ defaultValue: defaultValue ?? [],
96
+ onChange
97
+ });
94
98
  const currentValue = controlledVal ?? [];
95
99
  const [visibleChipsCount, setVisibleChipsCount] = React.useState(maxChipsVisible);
96
100
  const handleSelect = React.useCallback(
@@ -146,13 +150,10 @@ var MultiSelect = React.memo(
146
150
  success,
147
151
  helperText
148
152
  });
149
- const selectedOptions = React.useMemo(
150
- () => {
151
- const valueSet = new Set(currentValue);
152
- return options.filter((opt) => valueSet.has(opt.value));
153
- },
154
- [options, currentValue]
155
- );
153
+ const selectedOptions = React.useMemo(() => {
154
+ const valueSet = new Set(currentValue);
155
+ return options.filter((opt) => valueSet.has(opt.value));
156
+ }, [options, currentValue]);
156
157
  const handleRemoveChip = React.useCallback(
157
158
  (optionValue, e) => {
158
159
  e.stopPropagation();
@@ -239,7 +240,7 @@ var MultiSelect = React.memo(
239
240
  "div",
240
241
  {
241
242
  ref: scrollContainerRef,
242
- className: cn("overflow-auto relative", classNames?.dropdown),
243
+ className: cn("overflow-auto relative p-1", classNames?.dropdown),
243
244
  style: { maxHeight: maxDropdownHeight },
244
245
  role: "listbox",
245
246
  id: listboxId,
@@ -261,86 +262,76 @@ var MultiSelect = React.memo(
261
262
  {
262
263
  ref: refCallback,
263
264
  style: {
264
- height: `${Math.min(virtualizer.getTotalSize(), maxDropdownHeight)}px`,
265
- overflow: "auto"
265
+ height: `${virtualizer.getTotalSize()}px`,
266
+ width: "100%",
267
+ position: "relative"
266
268
  },
267
- onScroll: handleScroll,
268
- children: /* @__PURE__ */ jsx(
269
- "div",
270
- {
271
- style: {
272
- height: `${virtualizer.getTotalSize()}px`,
273
- width: "100%",
274
- position: "relative"
275
- },
276
- children: virtualizer.getVirtualItems().map((virtualItem) => {
277
- const item = filteredOptions[virtualItem.index];
278
- if (item?.type === "group") {
279
- return /* @__PURE__ */ jsx(
280
- "div",
281
- {
282
- style: {
283
- position: "absolute",
284
- top: 0,
285
- left: 0,
286
- width: "100%",
287
- height: `${virtualItem.size}px`,
288
- transform: `translateY(${virtualItem.start}px)`
289
- },
290
- className: multiSelectGroupVariants(),
291
- children: item?.data
292
- },
293
- `group-${virtualItem.index}`
294
- );
295
- }
296
- const option = item?.data;
297
- const isSelected = currentValue.includes(option.value);
298
- const selectableIndex = selectableOptions.indexOf(
299
- item
300
- );
301
- const isHighlighted = selectableIndex === highlightedIndex;
302
- return /* @__PURE__ */ jsxs(
303
- "div",
304
- {
305
- "data-value": option.value,
306
- style: {
307
- position: "absolute",
308
- top: 0,
309
- left: 0,
310
- width: "100%",
311
- height: `${virtualItem.size}px`,
312
- transform: `translateY(${virtualItem.start}px)`
313
- },
314
- className: cn(
315
- "multiSelect_option",
316
- multiSelectOptionVariants({
317
- selected: isSelected,
318
- disabled: !!option.disabled
319
- }),
320
- isHighlighted && "bg-surface",
321
- classNames?.option,
322
- isSelected && classNames?.optionSelected
323
- ),
324
- onClick: () => !option.disabled && handleOptionClick(option.value),
325
- role: "option",
326
- "aria-selected": isSelected,
327
- "aria-disabled": option.disabled,
328
- "data-slot": "multiSelect_option",
329
- children: [
330
- option.label,
331
- isSelected && /* @__PURE__ */ jsx("span", { className: "absolute right-3 top-1/2 -translate-y-1/2", children: /* @__PURE__ */ jsx(
332
- Check,
333
- {
334
- className: cn("text-slot", iconSizes[size])
335
- }
336
- ) })
337
- ]
269
+ children: virtualizer.getVirtualItems().map((virtualItem) => {
270
+ const item = filteredOptions[virtualItem.index];
271
+ if (item?.type === "group") {
272
+ return /* @__PURE__ */ jsx(
273
+ "div",
274
+ {
275
+ style: {
276
+ position: "absolute",
277
+ top: 0,
278
+ left: 0,
279
+ width: "100%",
280
+ height: `${virtualItem.size}px`,
281
+ transform: `translateY(${virtualItem.start}px)`
338
282
  },
339
- option.value
340
- );
341
- })
283
+ className: multiSelectGroupVariants(),
284
+ children: item?.data
285
+ },
286
+ `group-${virtualItem.index}`
287
+ );
342
288
  }
343
- )
289
+ const option = item?.data;
290
+ const isSelected = currentValue.includes(option.value);
291
+ const selectableIndex = selectableOptions.indexOf(
292
+ item
293
+ );
294
+ const isHighlighted = selectableIndex === highlightedIndex;
295
+ return /* @__PURE__ */ jsxs(
296
+ "div",
297
+ {
298
+ "data-value": option.value,
299
+ style: {
300
+ position: "absolute",
301
+ top: 0,
302
+ left: 0,
303
+ width: "100%",
304
+ height: `${virtualItem.size}px`,
305
+ transform: `translateY(${virtualItem.start}px)`
306
+ },
307
+ className: cn(
308
+ "multiSelect_option",
309
+ multiSelectOptionVariants({
310
+ selected: isSelected,
311
+ disabled: !!option.disabled
312
+ }),
313
+ isHighlighted && "bg-surface",
314
+ classNames?.option,
315
+ isSelected && classNames?.optionSelected
316
+ ),
317
+ onClick: () => !option.disabled && handleOptionClick(option.value),
318
+ role: "option",
319
+ "aria-selected": isSelected,
320
+ "aria-disabled": option.disabled,
321
+ "data-slot": "multiSelect_option",
322
+ children: [
323
+ option.label,
324
+ isSelected && /* @__PURE__ */ jsx("span", { className: "absolute right-3 top-1/2 -translate-y-1/2", children: /* @__PURE__ */ jsx(
325
+ Check,
326
+ {
327
+ className: cn("text-slot", iconSizes[size])
328
+ }
329
+ ) })
330
+ ]
331
+ },
332
+ option.value
333
+ );
334
+ })
344
335
  }
345
336
  ) : /* @__PURE__ */ jsx("div", { children: filteredOptions.map((item, index) => {
346
337
  if (item.type === "group") {
@@ -363,6 +354,7 @@ var MultiSelect = React.memo(
363
354
  "div",
364
355
  {
365
356
  "data-value": option.value,
357
+ "data-option-index": index,
366
358
  className: cn(
367
359
  "multiSelect_option",
368
360
  multiSelectOptionVariants({
@@ -380,12 +372,7 @@ var MultiSelect = React.memo(
380
372
  "data-slot": "multiSelect_option",
381
373
  children: [
382
374
  option.label,
383
- isSelected && /* @__PURE__ */ jsx("span", { className: "absolute right-3 top-1/2 -translate-y-1/2", children: /* @__PURE__ */ jsx(
384
- Check,
385
- {
386
- className: cn("text-slot", iconSizes[size])
387
- }
388
- ) })
375
+ isSelected && /* @__PURE__ */ jsx("span", { className: "absolute right-3 top-1/2 -translate-y-1/2", children: /* @__PURE__ */ jsx(Check, { className: cn("text-slot", iconSizes[size]) }) })
389
376
  ]
390
377
  },
391
378
  option.value
@@ -455,7 +442,10 @@ var MultiSelect = React.memo(
455
442
  onKeyDown: (e) => {
456
443
  if (e.key === "Enter" || e.key === " ") {
457
444
  e.preventDefault();
458
- handleRemoveChip(option.value, e);
445
+ handleRemoveChip(
446
+ option.value,
447
+ e
448
+ );
459
449
  }
460
450
  },
461
451
  className: cn(
@@ -609,5 +599,5 @@ MultiSelect.displayName = "MultiSelect";
609
599
  var multi_select_default = MultiSelect;
610
600
 
611
601
  export { multi_select_default };
612
- //# sourceMappingURL=chunk-XOEEAMMY.js.map
613
- //# sourceMappingURL=chunk-XOEEAMMY.js.map
602
+ //# sourceMappingURL=chunk-X3VT5SSK.js.map
603
+ //# sourceMappingURL=chunk-X3VT5SSK.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/multi-select/utils.ts","../src/multi-select/index.tsx"],"names":[],"mappings":"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","file":"chunk-X3VT5SSK.js","sourcesContent":["import { cva } from \"class-variance-authority\";\n\nexport const multiSelectTriggerVariants = 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 gap-1\",\n {\n variants: {\n status: {\n default: \"border-border\",\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\",\n sm: \"h-(--select-height-sm) px-(--select-padding-x-sm) text-sm\",\n md: \"h-(--select-height-md) px-(--select-padding-x-md) text-base\",\n lg: \"h-(--select-height-lg) px-(--select-padding-x-lg) text-lg\",\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\nexport const multiSelectDropdownVariants = cva(\n \"absolute z-[var(--z-dropdown)] mt-1 overflow-auto rounded-md border border-border bg-background\",\n);\n\nexport const multiSelectOptionVariants = cva(\n \"relative cursor-pointer select-none px-3 py-2 text-text-primary rounded-sm\",\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\nexport const multiSelectGroupVariants = cva(\n \"px-3 py-2 text-xs font-semibold text-text-secondary uppercase tracking-wider bg-surface\",\n);\n","\"use client\";\n\nimport { Check, ChevronDown, ChevronUp, Search, X } from \"lucide-react\";\nimport React from \"react\";\nimport { useControllable } from \"../hooks/useControllable\";\n\nimport { Popover, PopoverContent, PopoverTrigger } from \"../popover\";\nimport Spinner from \"../spinner\";\nimport { useSelectBase } from \"../shared/useSelectBase\";\nimport type { FlattenedItem } from \"../shared/useSelectBase\";\nimport { cn, iconSizes } from \"../utils\";\nimport { colorVars } from \"../variants\";\nimport type { MultiSelectOption, MultiSelectProps } from \"./types\";\nimport {\n multiSelectGroupVariants,\n multiSelectOptionVariants,\n multiSelectTriggerVariants,\n} from \"./utils\";\n\nconst MultiSelect = React.memo<MultiSelectProps>(\n ({\n size = \"md\",\n label,\n helperText,\n error,\n warning,\n info,\n success,\n options = [],\n placeholder = \"Select options\",\n loading = false,\n fullWidth = true,\n maxChipsVisible = 3,\n value,\n defaultValue,\n onChange,\n disabled,\n required,\n clearable = false,\n virtualizeThreshold = 50,\n maxDropdownHeight = 300,\n className,\n classNames,\n ref,\n ...props\n }) => {\n const [controlledVal, setCurrentValue] = useControllable<string[]>({\n value,\n defaultValue: defaultValue ?? [],\n onChange,\n });\n const currentValue = controlledVal ?? [];\n const [visibleChipsCount, setVisibleChipsCount] =\n React.useState(maxChipsVisible);\n\n const handleSelect = React.useCallback(\n (optionValue: string) => {\n const newValue = (currentValue || []).includes(optionValue)\n ? (currentValue || []).filter((v) => v !== optionValue)\n : [...(currentValue || []), optionValue];\n setCurrentValue(newValue);\n setHighlightedIndex(-1);\n },\n [currentValue, setCurrentValue],\n );\n\n const {\n // State\n isOpen,\n setIsOpen,\n searchQuery,\n setSearchQuery: _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<MultiSelectOption>({\n options,\n onSelectOption: (option) => handleSelect(option.value),\n virtualizeThreshold,\n maxDropdownHeight,\n label,\n idPrefix: \"multiselect\",\n error,\n warning,\n info,\n success,\n helperText,\n });\n\n const selectedOptions = React.useMemo(() => {\n const valueSet = new Set(currentValue);\n return options.filter((opt) => valueSet.has(opt.value));\n }, [options, currentValue]);\n\n const handleRemoveChip = React.useCallback(\n (optionValue: string, e: React.MouseEvent | React.KeyboardEvent) => {\n e.stopPropagation();\n const newValue = (currentValue || []).filter((v) => v !== optionValue);\n setCurrentValue(newValue);\n },\n [currentValue, setCurrentValue],\n );\n\n const handleClear = React.useCallback(\n (e: React.MouseEvent) => {\n e.stopPropagation();\n setCurrentValue([]);\n },\n [setCurrentValue],\n );\n\n const handleInputKeyDown = React.useCallback(\n (e: React.KeyboardEvent<HTMLInputElement>) => {\n if (e.key === \"Backspace\" && !searchQuery && currentValue.length > 0) {\n e.preventDefault();\n const lastValue = currentValue[currentValue.length - 1];\n handleRemoveChip(lastValue!, e);\n } else {\n handleKeyDown(e);\n }\n },\n [searchQuery, currentValue, handleRemoveChip, handleKeyDown],\n );\n\n React.useEffect(() => {\n if (selectedOptions.length === 0 || !triggerRef.current) {\n setVisibleChipsCount(maxChipsVisible);\n return;\n }\n\n const calculateVisibleChips = () => {\n const container = triggerRef.current;\n if (!container) return;\n\n const hiddenChips = container.querySelectorAll(\"[data-hidden-chip]\");\n if (hiddenChips.length === 0) return;\n\n const containerWidth = container.offsetWidth;\n const padding =\n size === \"sm\" ? 12 : size === \"md\" ? 16 : size === \"lg\" ? 20 : 24;\n const chevronWidth = 32;\n const gap = 4;\n const plusIndicatorWidth = 50;\n\n const availableWidth = containerWidth - padding * 2 - chevronWidth;\n let totalWidth = 0;\n let visibleCount = 0;\n\n for (let i = 0; i < hiddenChips.length; i++) {\n const chip = hiddenChips[i];\n if (!chip) continue;\n const chipWidth = chip.getBoundingClientRect().width;\n const requiredSpace =\n totalWidth + chipWidth + (visibleCount > 0 ? gap : 0);\n\n const needsPlusIndicator = i < hiddenChips.length - 1;\n const spaceWithIndicator =\n requiredSpace + (needsPlusIndicator ? gap + plusIndicatorWidth : 0);\n\n if (spaceWithIndicator <= availableWidth) {\n totalWidth = requiredSpace;\n visibleCount++;\n } else {\n break;\n }\n }\n\n setVisibleChipsCount(Math.max(1, visibleCount));\n };\n\n const timeoutId = setTimeout(calculateVisibleChips, 0);\n\n const resizeObserver = new ResizeObserver(() => {\n requestAnimationFrame(calculateVisibleChips);\n });\n\n if (triggerRef.current) {\n resizeObserver.observe(triggerRef.current);\n }\n\n return () => {\n clearTimeout(timeoutId);\n resizeObserver.disconnect();\n };\n }, [currentValue.length, size, maxChipsVisible, triggerRef]);\n\n const handleOptionClick = React.useCallback(\n (optionValue: string) => {\n handleSelect(optionValue);\n },\n [handleSelect],\n );\n\n const renderOptionsList = React.useMemo(\n () => (\n <div className=\"relative\" data-slot=\"multiSelect_dropdown\">\n {/* Top scroll indicator */}\n {showTopArrow && (\n <div className=\"flex items-center justify-center\">\n <ChevronUp className=\"h-4 w-4 text-text-primary\" />\n </div>\n )}\n\n <div\n ref={scrollContainerRef}\n className={cn(\"overflow-auto relative p-1\", classNames?.dropdown)}\n style={{ maxHeight: maxDropdownHeight }}\n role=\"listbox\"\n id={listboxId}\n aria-multiselectable=\"true\"\n aria-labelledby={label ? labelId : undefined}\n onScroll={handleScroll}\n >\n {filteredOptions.length === 0 ? (\n <div\n className={cn(\n \"multiSelect_empty px-3 py-4 text-center text-sm text-text-secondary\",\n classNames?.empty,\n )}\n data-slot=\"multiSelect_empty\"\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?.type === \"group\") {\n return (\n <div\n key={`group-${virtualItem.index}`}\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={multiSelectGroupVariants()}\n >\n {item?.data as string}\n </div>\n );\n }\n\n const option = item?.data as MultiSelectOption;\n const isSelected = currentValue.includes(option.value);\n const selectableIndex = selectableOptions.indexOf(\n item as FlattenedItem<MultiSelectOption>,\n );\n const isHighlighted = selectableIndex === highlightedIndex;\n\n return (\n <div\n key={option.value}\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 \"multiSelect_option\",\n multiSelectOptionVariants({\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 data-slot=\"multiSelect_option\"\n >\n {option.label}\n {isSelected && (\n <span className=\"absolute right-3 top-1/2 -translate-y-1/2\">\n <Check\n className={cn(\"text-slot\", iconSizes[size])}\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 className={multiSelectGroupVariants()}\n >\n {item.data as string}\n </div>\n );\n }\n\n const option = item.data as MultiSelectOption;\n const isSelected = currentValue.includes(option.value);\n const selectableIndex = selectableOptions.indexOf(\n item as FlattenedItem<MultiSelectOption>,\n );\n const isHighlighted = selectableIndex === highlightedIndex;\n\n return (\n <div\n key={option.value}\n data-value={option.value}\n data-option-index={index}\n className={cn(\n \"multiSelect_option\",\n multiSelectOptionVariants({\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 data-slot=\"multiSelect_option\"\n >\n {option.label}\n {isSelected && (\n <span className=\"absolute right-3 top-1/2 -translate-y-1/2\">\n <Check className={cn(\"text-slot\", iconSizes[size])} />\n </span>\n )}\n </div>\n );\n })}\n </div>\n )}\n </div>\n\n {/* Bottom scroll indicator */}\n {showBottomArrow && (\n <div className=\"flex items-center justify-center\">\n <ChevronDown className=\"h-4 w-4 text-text-primary\" />\n </div>\n )}\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 className={cn(\n \"multiSelect_trigger\",\n multiSelectTriggerVariants({ status, size, fullWidth }),\n loading && \"opacity-50\",\n classNames?.trigger,\n className,\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 data-slot=\"multiSelect_trigger\"\n >\n {selectedOptions.length > 0 && (\n <div className=\"flex gap-1 shrink-0\">\n {selectedOptions.slice(0, visibleChipsCount).map((option) => (\n <span\n key={option.value}\n className={cn(\n \"multiSelect_tag inline-flex items-center gap-1 px-2 bg-slot-10 text-slot rounded text-sm whitespace-nowrap\",\n classNames?.tag,\n )}\n data-slot=\"multiSelect_tag\"\n >\n {option.label}\n <span\n role=\"button\"\n tabIndex={disabled ? -1 : 0}\n onClick={(e) => handleRemoveChip(option.value, e)}\n onKeyDown={(e) => {\n if (e.key === \"Enter\" || e.key === \" \") {\n e.preventDefault();\n handleRemoveChip(\n option.value,\n e as unknown as React.MouseEvent,\n );\n }\n }}\n className={cn(\n \"multiSelect_tagRemove hover:text-error cursor-pointer\",\n disabled && \"pointer-events-none\",\n classNames?.tagRemove,\n )}\n aria-disabled={disabled}\n data-slot=\"multiSelect_tagRemove\"\n >\n <X className=\"h-3 w-3\" />\n </span>\n </span>\n ))}\n {selectedOptions.length > visibleChipsCount && (\n <span className=\"inline-flex items-center px-2 py-0.5 bg-surface text-text-secondary rounded text-sm whitespace-nowrap\">\n +{selectedOptions.length - visibleChipsCount}\n </span>\n )}\n </div>\n )}\n <div\n className=\"absolute opacity-0 pointer-events-none whitespace-nowrap\"\n aria-hidden=\"true\"\n >\n {selectedOptions.map((option) => (\n <span\n key={option.value}\n data-hidden-chip\n className=\"inline-flex items-center gap-1 px-2 py-0.5 bg-slot-10 text-slot rounded text-sm whitespace-nowrap\"\n >\n {option.label}\n <X className=\"h-3 w-3\" />\n </span>\n ))}\n </div>\n <input\n ref={inputRef}\n type=\"text\"\n className=\"bg-transparent outline-none cursor-pointer placeholder:text-text-secondary/50 flex-1 min-w-0 pointer-events-none\"\n placeholder={selectedOptions.length > 0 ? \"\" : placeholder}\n value={searchQuery}\n onChange={handleInputChange}\n onClick={handleInputClick}\n onKeyDown={handleInputKeyDown}\n onKeyUp={handleKeyUp}\n disabled={disabled || loading}\n readOnly={!isOpen}\n tabIndex={0}\n />\n <div className=\"flex items-center gap-1 text-text-secondary\">\n {loading ? (\n <Spinner />\n ) : (\n <>\n {clearable && selectedOptions.length > 0 && !disabled && (\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 {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 className={cn(\n \"multiSelect_root relative group\",\n colorVars.primary,\n fullWidth ? \"w-full\" : \"inline-block\",\n classNames?.root,\n )}\n ref={ref}\n data-slot=\"multiSelect_root\"\n {...props}\n >\n <Popover open={isOpen} onOpenChange={setIsOpen}>\n <PopoverTrigger asChild>{triggerButton}</PopoverTrigger>\n\n <PopoverContent\n className=\"p-0 w-(--radix-popover-trigger-width)\"\n align=\"start\"\n sideOffset={4}\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 className={cn(\n \"multiSelect_label block mb-0.5\",\n classNames?.label,\n )}\n data-slot=\"multiSelect_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 className={cn(\n \"multiSelect_helper text-xs\",\n status === \"error\" && \"text-error\",\n status === \"warning\" && \"text-warning\",\n status === \"info\" && \"text-info\",\n status === \"success\" && \"text-success\",\n status === \"default\" && \"text-text-secondary\",\n classNames?.helper,\n )}\n data-slot=\"multiSelect_helper\"\n >\n {helperMessage}\n </p>\n )}\n </div>\n {selectElement}\n </div>\n );\n },\n);\n\nMultiSelect.displayName = \"MultiSelect\";\n\nexport type * from \"./types\";\nexport default MultiSelect;\n"]}
@@ -25,6 +25,9 @@ var Skeleton = React.memo(
25
25
  "div",
26
26
  {
27
27
  "data-slot": "root",
28
+ role: "status",
29
+ "aria-busy": "true",
30
+ "aria-label": "Loading",
28
31
  className: cn(
29
32
  "skeleton_root",
30
33
  skeletonVariants({ size, color }),
@@ -40,5 +43,5 @@ Skeleton.displayName = "Skeleton";
40
43
  var skeleton_default = Skeleton;
41
44
 
42
45
  export { skeleton_default };
43
- //# sourceMappingURL=chunk-SFP77VS3.js.map
44
- //# sourceMappingURL=chunk-SFP77VS3.js.map
46
+ //# sourceMappingURL=chunk-X7JN7WPF.js.map
47
+ //# sourceMappingURL=chunk-X7JN7WPF.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/skeleton/index.tsx"],"names":[],"mappings":";;;;;;AASA,IAAM,gBAAA,GAAmB,IAAI,uBAAA,EAAyB;AAAA,EACpD,QAAA,EAAU;AAAA,IACR,IAAA,EAAM;AAAA,MACJ,EAAA,EAAI,KAAA;AAAA,MACJ,EAAA,EAAI,KAAA;AAAA,MACJ,EAAA,EAAI,KAAA;AAAA,MACJ,EAAA,EAAI;AAAA,KACN;AAAA,IACA,KAAA,EAAO;AAAA,GACT;AAAA,EACA,eAAA,EAAiB;AAAA,IACf,IAAA,EAAM,IAAA;AAAA,IACN,KAAA,EAAO;AAAA;AAEX,CAAC,CAAA;AAED,IAAM,WAAW,KAAA,CAAM,IAAA;AAAA,EACrB,CAAC,EAAE,KAAA,GAAQ,SAAA,EAAW,OAAO,IAAA,EAAM,SAAA,EAAW,MAAA,GAAS,KAAA,EAAM,KAAM;AACjE,IAAA,uBACE,GAAA;AAAA,MAAC,KAAA;AAAA,MAAA;AAAA,QACC,WAAA,EAAU,MAAA;AAAA,QACV,IAAA,EAAK,QAAA;AAAA,QACL,WAAA,EAAU,MAAA;AAAA,QACV,YAAA,EAAW,SAAA;AAAA,QACX,SAAA,EAAW,EAAA;AAAA,UACT,eAAA;AAAA,UACA,gBAAA,CAAiB,EAAE,IAAA,EAAM,KAAA,EAAO,CAAA;AAAA,UAChC,YAAA;AAAA,UACA,MAAA,IAAU,4BAAA;AAAA,UACV;AAAA;AACF;AAAA,KACF;AAAA,EAEJ;AACF,CAAA;AAEA,QAAA,CAAS,WAAA,GAAc,UAAA;AAGvB,IAAO,gBAAA,GAAQ","file":"chunk-X7JN7WPF.js","sourcesContent":["'use client'\n\nimport { cva } from 'class-variance-authority'\nimport React from 'react'\n\nimport { cn } from '../utils'\nimport { colorVars } from '../variants'\nimport type { SkeletonProps } from './types'\n\nconst skeletonVariants = cva('animate-pulse rounded', {\n variants: {\n size: {\n xs: 'h-3',\n sm: 'h-4',\n md: 'h-5',\n lg: 'h-6',\n },\n color: colorVars,\n },\n defaultVariants: {\n size: 'md',\n color: 'default',\n },\n})\n\nconst Skeleton = React.memo<SkeletonProps>(\n ({ color = 'default', size = 'md', className, circle = false }) => {\n return (\n <div\n data-slot=\"root\"\n role=\"status\"\n aria-busy=\"true\"\n aria-label=\"Loading\"\n className={cn(\n 'skeleton_root',\n skeletonVariants({ size, color }),\n 'bg-slot-50',\n circle && 'rounded-full aspect-square',\n className,\n )}\n />\n )\n },\n)\n\nSkeleton.displayName = 'Skeleton'\n\nexport type * from './types'\nexport default Skeleton\n"]}
@@ -0,0 +1,201 @@
1
+ import { colorVars } from './chunk-G6QIIWKU.js';
2
+ import { cn } from './chunk-RAS6HUEI.js';
3
+ import { cva } from 'class-variance-authority';
4
+ import React, { useState, useCallback, useEffect } from 'react';
5
+ import { ArrowUp, X, Plus } from 'lucide-react';
6
+ import { jsxs, jsx } from 'react/jsx-runtime';
7
+
8
+ var buttonVariants = cva(
9
+ "inline-flex items-center justify-center shadow-lg transition-all hover:scale-105 active:scale-95 disabled:opacity-50 disabled:pointer-events-none cursor-pointer",
10
+ {
11
+ variants: {
12
+ size: {
13
+ xs: "w-8 h-8 text-sm",
14
+ sm: "w-10 h-10 text-base",
15
+ md: "w-12 h-12 text-lg",
16
+ lg: "w-14 h-14 text-xl"
17
+ },
18
+ shape: {
19
+ circle: "rounded-full",
20
+ square: "rounded-lg"
21
+ },
22
+ variant: {
23
+ default: "bg-background border border-border text-text-primary hover:bg-surface",
24
+ colored: "bg-slot text-slot-fg hover:bg-slot-90"
25
+ }
26
+ },
27
+ defaultVariants: { size: "md", shape: "circle", variant: "default" }
28
+ }
29
+ );
30
+ var FloatButton = React.memo(
31
+ ({
32
+ icon,
33
+ label,
34
+ tooltip,
35
+ badge,
36
+ onClick,
37
+ href,
38
+ target,
39
+ color = "default",
40
+ size = "md",
41
+ shape = "circle",
42
+ disabled = false,
43
+ className,
44
+ classNames,
45
+ style
46
+ }) => {
47
+ const variant = color === "default" ? "default" : "colored";
48
+ const Component = href ? "a" : "button";
49
+ const content = /* @__PURE__ */ jsxs(
50
+ Component,
51
+ {
52
+ ...href ? { href, target } : { type: "button", onClick, disabled },
53
+ "data-slot": "button",
54
+ title: tooltip,
55
+ className: cn(
56
+ "floatButton_button",
57
+ buttonVariants({ size, shape, variant }),
58
+ color !== "default" && colorVars[color],
59
+ "relative",
60
+ classNames?.button,
61
+ className
62
+ ),
63
+ style,
64
+ children: [
65
+ icon,
66
+ label && !icon && /* @__PURE__ */ jsx("span", { className: "text-xs font-medium", children: label }),
67
+ badge !== void 0 && /* @__PURE__ */ jsx(
68
+ "span",
69
+ {
70
+ "data-slot": "badge",
71
+ className: cn(
72
+ "floatButton_badge",
73
+ "absolute -top-1 -right-1 min-w-[18px] h-[18px] px-1 rounded-full bg-error text-error-foreground text-[10px] font-medium flex items-center justify-center",
74
+ classNames?.badge
75
+ ),
76
+ children: badge
77
+ }
78
+ )
79
+ ]
80
+ }
81
+ );
82
+ return content;
83
+ }
84
+ );
85
+ FloatButton.displayName = "FloatButton";
86
+ var FloatButtonGroup = React.memo(
87
+ ({
88
+ children,
89
+ trigger = "click",
90
+ icon,
91
+ closeIcon,
92
+ open: controlledOpen,
93
+ onOpenChange,
94
+ shape = "circle",
95
+ color = "primary",
96
+ size = "md",
97
+ placement = "top",
98
+ className,
99
+ classNames,
100
+ style
101
+ }) => {
102
+ const [internalOpen, setInternalOpen] = useState(false);
103
+ const isOpen = controlledOpen !== void 0 ? controlledOpen : internalOpen;
104
+ const setOpen = useCallback(
105
+ (v) => {
106
+ if (controlledOpen === void 0) setInternalOpen(v);
107
+ onOpenChange?.(v);
108
+ },
109
+ [controlledOpen, onOpenChange]
110
+ );
111
+ const placementClasses = {
112
+ top: "flex-col-reverse gap-3 bottom-0",
113
+ bottom: "flex-col gap-3 top-0",
114
+ left: "flex-row-reverse gap-3 right-0",
115
+ right: "flex-row gap-3 left-0"
116
+ };
117
+ const openIcon = icon ?? /* @__PURE__ */ jsx(Plus, { className: "w-5 h-5" });
118
+ const closedIcon = closeIcon ?? /* @__PURE__ */ jsx(X, { className: "w-5 h-5" });
119
+ return /* @__PURE__ */ jsxs(
120
+ "div",
121
+ {
122
+ "data-slot": "group",
123
+ className: cn("floatButton_group", "relative inline-flex", classNames?.group, className),
124
+ style,
125
+ onMouseEnter: trigger === "hover" ? () => setOpen(true) : void 0,
126
+ onMouseLeave: trigger === "hover" ? () => setOpen(false) : void 0,
127
+ children: [
128
+ /* @__PURE__ */ jsx(
129
+ FloatButton,
130
+ {
131
+ icon: /* @__PURE__ */ jsx("span", { className: cn("transition-transform duration-200", isOpen && "rotate-45"), children: isOpen ? closedIcon : openIcon }),
132
+ color,
133
+ size,
134
+ shape,
135
+ onClick: trigger === "click" ? () => setOpen(!isOpen) : void 0
136
+ }
137
+ ),
138
+ isOpen && /* @__PURE__ */ jsx("div", { className: cn("absolute flex items-center", placementClasses[placement]), children: React.Children.map(children, (child, idx) => {
139
+ if (!React.isValidElement(child)) return child;
140
+ return /* @__PURE__ */ jsx(
141
+ "div",
142
+ {
143
+ className: "animate-in fade-in zoom-in-75",
144
+ style: { animationDelay: `${idx * 50}ms`, animationFillMode: "both", animationDuration: "150ms" },
145
+ children: React.cloneElement(child, {
146
+ size: child.props.size || size,
147
+ shape: child.props.shape || shape
148
+ })
149
+ },
150
+ idx
151
+ );
152
+ }) })
153
+ ]
154
+ }
155
+ );
156
+ }
157
+ );
158
+ FloatButtonGroup.displayName = "FloatButtonGroup";
159
+ var BackTop = React.memo(
160
+ ({
161
+ visibilityHeight = 400,
162
+ onClick,
163
+ icon,
164
+ size = "md",
165
+ shape = "circle",
166
+ color = "default",
167
+ ...props
168
+ }) => {
169
+ const [visible, setVisible] = useState(false);
170
+ useEffect(() => {
171
+ if (typeof window === "undefined") return;
172
+ const handleScroll = () => setVisible(window.scrollY >= visibilityHeight);
173
+ handleScroll();
174
+ window.addEventListener("scroll", handleScroll, { passive: true });
175
+ return () => window.removeEventListener("scroll", handleScroll);
176
+ }, [visibilityHeight]);
177
+ const handleClick = useCallback(() => {
178
+ window.scrollTo({ top: 0, behavior: "smooth" });
179
+ onClick?.();
180
+ }, [onClick]);
181
+ if (!visible) return null;
182
+ return /* @__PURE__ */ jsx(
183
+ FloatButton,
184
+ {
185
+ icon: icon ?? /* @__PURE__ */ jsx(ArrowUp, { className: "w-5 h-5" }),
186
+ tooltip: "Back to top",
187
+ onClick: handleClick,
188
+ size,
189
+ shape,
190
+ color,
191
+ ...props
192
+ }
193
+ );
194
+ }
195
+ );
196
+ BackTop.displayName = "BackTop";
197
+ var float_button_default = FloatButton;
198
+
199
+ export { BackTop, FloatButton, FloatButtonGroup, float_button_default };
200
+ //# sourceMappingURL=chunk-YRSHBAUQ.js.map
201
+ //# sourceMappingURL=chunk-YRSHBAUQ.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/float-button/index.tsx"],"names":[],"mappings":";;;;;;;AAUA,IAAM,cAAA,GAAiB,GAAA;AAAA,EACrB,kKAAA;AAAA,EACA;AAAA,IACE,QAAA,EAAU;AAAA,MACR,IAAA,EAAM;AAAA,QACJ,EAAA,EAAI,iBAAA;AAAA,QACJ,EAAA,EAAI,qBAAA;AAAA,QACJ,EAAA,EAAI,mBAAA;AAAA,QACJ,EAAA,EAAI;AAAA,OACN;AAAA,MACA,KAAA,EAAO;AAAA,QACL,MAAA,EAAQ,cAAA;AAAA,QACR,MAAA,EAAQ;AAAA,OACV;AAAA,MACA,OAAA,EAAS;AAAA,QACP,OAAA,EAAS,uEAAA;AAAA,QACT,OAAA,EAAS;AAAA;AACX,KACF;AAAA,IACA,iBAAiB,EAAE,IAAA,EAAM,MAAM,KAAA,EAAO,QAAA,EAAU,SAAS,SAAA;AAAU;AAEvE,CAAA;AAEA,IAAM,cAAc,KAAA,CAAM,IAAA;AAAA,EACxB,CAAC;AAAA,IACC,IAAA;AAAA,IACA,KAAA;AAAA,IACA,OAAA;AAAA,IACA,KAAA;AAAA,IACA,OAAA;AAAA,IACA,IAAA;AAAA,IACA,MAAA;AAAA,IACA,KAAA,GAAQ,SAAA;AAAA,IACR,IAAA,GAAO,IAAA;AAAA,IACP,KAAA,GAAQ,QAAA;AAAA,IACR,QAAA,GAAW,KAAA;AAAA,IACX,SAAA;AAAA,IACA,UAAA;AAAA,IACA;AAAA,GACF,KAAM;AACJ,IAAA,MAAM,OAAA,GAAU,KAAA,KAAU,SAAA,GAAY,SAAA,GAAY,SAAA;AAClD,IAAA,MAAM,SAAA,GAAY,OAAO,GAAA,GAAM,QAAA;AAE/B,IAAA,MAAM,OAAA,mBACJ,IAAA;AAAA,MAAC,SAAA;AAAA,MAAA;AAAA,QACE,GAAI,IAAA,GAAO,EAAE,IAAA,EAAM,MAAA,KAAW,EAAE,IAAA,EAAM,QAAA,EAAmB,OAAA,EAAS,QAAA,EAAS;AAAA,QAC5E,WAAA,EAAU,QAAA;AAAA,QACV,KAAA,EAAO,OAAA;AAAA,QACP,SAAA,EAAW,EAAA;AAAA,UACT,oBAAA;AAAA,UACA,cAAA,CAAe,EAAE,IAAA,EAAM,KAAA,EAAO,SAAS,CAAA;AAAA,UACvC,KAAA,KAAU,SAAA,IAAa,SAAA,CAAU,KAAK,CAAA;AAAA,UACtC,UAAA;AAAA,UACA,UAAA,EAAY,MAAA;AAAA,UACZ;AAAA,SACF;AAAA,QACA,KAAA;AAAA,QAEC,QAAA,EAAA;AAAA,UAAA,IAAA;AAAA,UACA,SAAS,CAAC,IAAA,wBAAS,MAAA,EAAA,EAAK,SAAA,EAAU,uBAAuB,QAAA,EAAA,KAAA,EAAM,CAAA;AAAA,UAC/D,UAAU,MAAA,oBACT,GAAA;AAAA,YAAC,MAAA;AAAA,YAAA;AAAA,cACC,WAAA,EAAU,OAAA;AAAA,cACV,SAAA,EAAW,EAAA;AAAA,gBACT,mBAAA;AAAA,gBACA,0JAAA;AAAA,gBACA,UAAA,EAAY;AAAA,eACd;AAAA,cAEC,QAAA,EAAA;AAAA;AAAA;AACH;AAAA;AAAA,KAEJ;AAGF,IAAA,OAAO,OAAA;AAAA,EACT;AACF;AAEA,WAAA,CAAY,WAAA,GAAc,aAAA;AAE1B,IAAM,mBAAmB,KAAA,CAAM,IAAA;AAAA,EAC7B,CAAC;AAAA,IACC,QAAA;AAAA,IACA,OAAA,GAAU,OAAA;AAAA,IACV,IAAA;AAAA,IACA,SAAA;AAAA,IACA,IAAA,EAAM,cAAA;AAAA,IACN,YAAA;AAAA,IACA,KAAA,GAAQ,QAAA;AAAA,IACR,KAAA,GAAQ,SAAA;AAAA,IACR,IAAA,GAAO,IAAA;AAAA,IACP,SAAA,GAAY,KAAA;AAAA,IACZ,SAAA;AAAA,IACA,UAAA;AAAA,IACA;AAAA,GACF,KAAM;AACJ,IAAA,MAAM,CAAC,YAAA,EAAc,eAAe,CAAA,GAAI,SAAS,KAAK,CAAA;AACtD,IAAA,MAAM,MAAA,GAAS,cAAA,KAAmB,MAAA,GAAY,cAAA,GAAiB,YAAA;AAE/D,IAAA,MAAM,OAAA,GAAU,WAAA;AAAA,MACd,CAAC,CAAA,KAAe;AACd,QAAA,IAAI,cAAA,KAAmB,MAAA,EAAW,eAAA,CAAgB,CAAC,CAAA;AACnD,QAAA,YAAA,GAAe,CAAC,CAAA;AAAA,MAClB,CAAA;AAAA,MACA,CAAC,gBAAgB,YAAY;AAAA,KAC/B;AAEA,IAAA,MAAM,gBAAA,GAAmB;AAAA,MACvB,GAAA,EAAK,iCAAA;AAAA,MACL,MAAA,EAAQ,sBAAA;AAAA,MACR,IAAA,EAAM,gCAAA;AAAA,MACN,KAAA,EAAO;AAAA,KACT;AAEA,IAAA,MAAM,QAAA,GAAW,IAAA,oBAAQ,GAAA,CAAC,IAAA,EAAA,EAAK,WAAU,SAAA,EAAU,CAAA;AACnD,IAAA,MAAM,UAAA,GAAa,SAAA,oBAAa,GAAA,CAAC,CAAA,EAAA,EAAE,WAAU,SAAA,EAAU,CAAA;AAEvD,IAAA,uBACE,IAAA;AAAA,MAAC,KAAA;AAAA,MAAA;AAAA,QACC,WAAA,EAAU,OAAA;AAAA,QACV,WAAW,EAAA,CAAG,mBAAA,EAAqB,sBAAA,EAAwB,UAAA,EAAY,OAAO,SAAS,CAAA;AAAA,QACvF,KAAA;AAAA,QACA,cAAc,OAAA,KAAY,OAAA,GAAU,MAAM,OAAA,CAAQ,IAAI,CAAA,GAAI,MAAA;AAAA,QAC1D,cAAc,OAAA,KAAY,OAAA,GAAU,MAAM,OAAA,CAAQ,KAAK,CAAA,GAAI,MAAA;AAAA,QAE3D,QAAA,EAAA;AAAA,0BAAA,GAAA;AAAA,YAAC,WAAA;AAAA,YAAA;AAAA,cACC,IAAA,kBACE,GAAA,CAAC,MAAA,EAAA,EAAK,SAAA,EAAW,EAAA,CAAG,mCAAA,EAAqC,MAAA,IAAU,WAAW,CAAA,EAC3E,QAAA,EAAA,MAAA,GAAS,UAAA,GAAa,QAAA,EACzB,CAAA;AAAA,cAEF,KAAA;AAAA,cACA,IAAA;AAAA,cACA,KAAA;AAAA,cACA,SAAS,OAAA,KAAY,OAAA,GAAU,MAAM,OAAA,CAAQ,CAAC,MAAM,CAAA,GAAI;AAAA;AAAA,WAC1D;AAAA,UAEC,0BACC,GAAA,CAAC,KAAA,EAAA,EAAI,SAAA,EAAW,EAAA,CAAG,8BAA8B,gBAAA,CAAiB,SAAS,CAAC,CAAA,EACzE,gBAAM,QAAA,CAAS,GAAA,CAAI,QAAA,EAAU,CAAC,OAAO,GAAA,KAAQ;AAC5C,YAAA,IAAI,CAAC,KAAA,CAAM,cAAA,CAAe,KAAK,GAAG,OAAO,KAAA;AACzC,YAAA,uBACE,GAAA;AAAA,cAAC,KAAA;AAAA,cAAA;AAAA,gBAEC,SAAA,EAAU,+BAAA;AAAA,gBACV,KAAA,EAAO,EAAE,cAAA,EAAgB,CAAA,EAAG,GAAA,GAAM,EAAE,CAAA,EAAA,CAAA,EAAM,iBAAA,EAAmB,MAAA,EAAQ,iBAAA,EAAmB,OAAA,EAAQ;AAAA,gBAE/F,QAAA,EAAA,KAAA,CAAM,aAAa,KAAA,EAA+C;AAAA,kBACjE,IAAA,EAAO,KAAA,CAA+C,KAAA,CAAM,IAAA,IAAQ,IAAA;AAAA,kBACpE,KAAA,EAAQ,KAAA,CAA+C,KAAA,CAAM,KAAA,IAAS;AAAA,iBACvE;AAAA,eAAA;AAAA,cAPI;AAAA,aAQP;AAAA,UAEJ,CAAC,CAAA,EACH;AAAA;AAAA;AAAA,KAEJ;AAAA,EAEJ;AACF;AAEA,gBAAA,CAAiB,WAAA,GAAc,kBAAA;AAE/B,IAAM,UAAU,KAAA,CAAM,IAAA;AAAA,EACpB,CAAC;AAAA,IACC,gBAAA,GAAmB,GAAA;AAAA,IACnB,OAAA;AAAA,IACA,IAAA;AAAA,IACA,IAAA,GAAO,IAAA;AAAA,IACP,KAAA,GAAQ,QAAA;AAAA,IACR,KAAA,GAAQ,SAAA;AAAA,IACR,GAAG;AAAA,GACL,KAAM;AACJ,IAAA,MAAM,CAAC,OAAA,EAAS,UAAU,CAAA,GAAI,SAAS,KAAK,CAAA;AAE5C,IAAA,SAAA,CAAU,MAAM;AACd,MAAA,IAAI,OAAO,WAAW,WAAA,EAAa;AACnC,MAAA,MAAM,YAAA,GAAe,MAAM,UAAA,CAAW,MAAA,CAAO,WAAW,gBAAgB,CAAA;AACxE,MAAA,YAAA,EAAa;AACb,MAAA,MAAA,CAAO,iBAAiB,QAAA,EAAU,YAAA,EAAc,EAAE,OAAA,EAAS,MAAM,CAAA;AACjE,MAAA,OAAO,MAAM,MAAA,CAAO,mBAAA,CAAoB,QAAA,EAAU,YAAY,CAAA;AAAA,IAChE,CAAA,EAAG,CAAC,gBAAgB,CAAC,CAAA;AAErB,IAAA,MAAM,WAAA,GAAc,YAAY,MAAM;AACpC,MAAA,MAAA,CAAO,SAAS,EAAE,GAAA,EAAK,CAAA,EAAG,QAAA,EAAU,UAAU,CAAA;AAC9C,MAAA,OAAA,IAAU;AAAA,IACZ,CAAA,EAAG,CAAC,OAAO,CAAC,CAAA;AAEZ,IAAA,IAAI,CAAC,SAAS,OAAO,IAAA;AAErB,IAAA,uBACE,GAAA;AAAA,MAAC,WAAA;AAAA,MAAA;AAAA,QACC,IAAA,EAAM,IAAA,oBAAQ,GAAA,CAAC,OAAA,EAAA,EAAQ,WAAU,SAAA,EAAU,CAAA;AAAA,QAC3C,OAAA,EAAQ,aAAA;AAAA,QACR,OAAA,EAAS,WAAA;AAAA,QACT,IAAA;AAAA,QACA,KAAA;AAAA,QACA,KAAA;AAAA,QACC,GAAG;AAAA;AAAA,KACN;AAAA,EAEJ;AACF;AAEA,OAAA,CAAQ,WAAA,GAAc,SAAA;AAItB,IAAO,oBAAA,GAAQ","file":"chunk-YRSHBAUQ.js","sourcesContent":["'use client'\n\nimport { cva } from 'class-variance-authority'\nimport React, { useState, useEffect, useCallback } from 'react'\n\nimport { ArrowUp, X, Plus } from 'lucide-react'\nimport { cn } from '../utils'\nimport { colorVars } from '../variants'\nimport type { FloatButtonProps, FloatButtonGroupProps, BackTopProps } from './types'\n\nconst buttonVariants = cva(\n 'inline-flex items-center justify-center shadow-lg transition-all hover:scale-105 active:scale-95 disabled:opacity-50 disabled:pointer-events-none cursor-pointer',\n {\n variants: {\n size: {\n xs: 'w-8 h-8 text-sm',\n sm: 'w-10 h-10 text-base',\n md: 'w-12 h-12 text-lg',\n lg: 'w-14 h-14 text-xl',\n },\n shape: {\n circle: 'rounded-full',\n square: 'rounded-lg',\n },\n variant: {\n default: 'bg-background border border-border text-text-primary hover:bg-surface',\n colored: 'bg-slot text-slot-fg hover:bg-slot-90',\n },\n },\n defaultVariants: { size: 'md', shape: 'circle', variant: 'default' },\n },\n)\n\nconst FloatButton = React.memo<FloatButtonProps>(\n ({\n icon,\n label,\n tooltip,\n badge,\n onClick,\n href,\n target,\n color = 'default',\n size = 'md',\n shape = 'circle',\n disabled = false,\n className,\n classNames,\n style,\n }) => {\n const variant = color === 'default' ? 'default' : 'colored'\n const Component = href ? 'a' : 'button'\n\n const content = (\n <Component\n {...(href ? { href, target } : { type: 'button' as const, onClick, disabled })}\n data-slot=\"button\"\n title={tooltip}\n className={cn(\n 'floatButton_button',\n buttonVariants({ size, shape, variant }),\n color !== 'default' && colorVars[color],\n 'relative',\n classNames?.button,\n className,\n )}\n style={style}\n >\n {icon}\n {label && !icon && <span className=\"text-xs font-medium\">{label}</span>}\n {badge !== undefined && (\n <span\n data-slot=\"badge\"\n className={cn(\n 'floatButton_badge',\n 'absolute -top-1 -right-1 min-w-[18px] h-[18px] px-1 rounded-full bg-error text-error-foreground text-[10px] font-medium flex items-center justify-center',\n classNames?.badge,\n )}\n >\n {badge}\n </span>\n )}\n </Component>\n )\n\n return content\n },\n)\n\nFloatButton.displayName = 'FloatButton'\n\nconst FloatButtonGroup = React.memo<FloatButtonGroupProps>(\n ({\n children,\n trigger = 'click',\n icon,\n closeIcon,\n open: controlledOpen,\n onOpenChange,\n shape = 'circle',\n color = 'primary',\n size = 'md',\n placement = 'top',\n className,\n classNames,\n style,\n }) => {\n const [internalOpen, setInternalOpen] = useState(false)\n const isOpen = controlledOpen !== undefined ? controlledOpen : internalOpen\n\n const setOpen = useCallback(\n (v: boolean) => {\n if (controlledOpen === undefined) setInternalOpen(v)\n onOpenChange?.(v)\n },\n [controlledOpen, onOpenChange],\n )\n\n const placementClasses = {\n top: 'flex-col-reverse gap-3 bottom-0',\n bottom: 'flex-col gap-3 top-0',\n left: 'flex-row-reverse gap-3 right-0',\n right: 'flex-row gap-3 left-0',\n }\n\n const openIcon = icon ?? <Plus className=\"w-5 h-5\" />\n const closedIcon = closeIcon ?? <X className=\"w-5 h-5\" />\n\n return (\n <div\n data-slot=\"group\"\n className={cn('floatButton_group', 'relative inline-flex', classNames?.group, className)}\n style={style}\n onMouseEnter={trigger === 'hover' ? () => setOpen(true) : undefined}\n onMouseLeave={trigger === 'hover' ? () => setOpen(false) : undefined}\n >\n <FloatButton\n icon={\n <span className={cn('transition-transform duration-200', isOpen && 'rotate-45')}>\n {isOpen ? closedIcon : openIcon}\n </span>\n }\n color={color}\n size={size}\n shape={shape}\n onClick={trigger === 'click' ? () => setOpen(!isOpen) : undefined}\n />\n\n {isOpen && (\n <div className={cn('absolute flex items-center', placementClasses[placement])}>\n {React.Children.map(children, (child, idx) => {\n if (!React.isValidElement(child)) return child\n return (\n <div\n key={idx}\n className=\"animate-in fade-in zoom-in-75\"\n style={{ animationDelay: `${idx * 50}ms`, animationFillMode: 'both', animationDuration: '150ms' }}\n >\n {React.cloneElement(child as React.ReactElement<FloatButtonProps>, {\n size: (child as React.ReactElement<FloatButtonProps>).props.size || size,\n shape: (child as React.ReactElement<FloatButtonProps>).props.shape || shape,\n })}\n </div>\n )\n })}\n </div>\n )}\n </div>\n )\n },\n)\n\nFloatButtonGroup.displayName = 'FloatButtonGroup'\n\nconst BackTop = React.memo<BackTopProps>(\n ({\n visibilityHeight = 400,\n onClick,\n icon,\n size = 'md',\n shape = 'circle',\n color = 'default',\n ...props\n }) => {\n const [visible, setVisible] = useState(false)\n\n useEffect(() => {\n if (typeof window === 'undefined') return\n const handleScroll = () => setVisible(window.scrollY >= visibilityHeight)\n handleScroll()\n window.addEventListener('scroll', handleScroll, { passive: true })\n return () => window.removeEventListener('scroll', handleScroll)\n }, [visibilityHeight])\n\n const handleClick = useCallback(() => {\n window.scrollTo({ top: 0, behavior: 'smooth' })\n onClick?.()\n }, [onClick])\n\n if (!visible) return null\n\n return (\n <FloatButton\n icon={icon ?? <ArrowUp className=\"w-5 h-5\" />}\n tooltip=\"Back to top\"\n onClick={handleClick}\n size={size}\n shape={shape}\n color={color}\n {...props}\n />\n )\n },\n)\n\nBackTop.displayName = 'BackTop'\n\nexport type * from './types'\nexport { FloatButton, FloatButtonGroup, BackTop }\nexport default FloatButton\n"]}