@nuvia/components 1.3.0 → 1.4.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (81) hide show
  1. package/dist/index.cjs +167 -150
  2. package/dist/index.cjs.map +1 -1
  3. package/dist/index.js +167 -150
  4. package/dist/index.js.map +1 -1
  5. package/dist/ui/alert-dialog.cjs +3 -3
  6. package/dist/ui/alert-dialog.cjs.map +1 -1
  7. package/dist/ui/alert-dialog.js +3 -3
  8. package/dist/ui/alert-dialog.js.map +1 -1
  9. package/dist/ui/alert.d.cts +1 -1
  10. package/dist/ui/alert.d.ts +1 -1
  11. package/dist/ui/badge.cjs +3 -3
  12. package/dist/ui/badge.cjs.map +1 -1
  13. package/dist/ui/badge.js +3 -3
  14. package/dist/ui/badge.js.map +1 -1
  15. package/dist/ui/button.cjs +3 -3
  16. package/dist/ui/button.cjs.map +1 -1
  17. package/dist/ui/button.js +3 -3
  18. package/dist/ui/button.js.map +1 -1
  19. package/dist/ui/calendar.cjs +3 -3
  20. package/dist/ui/calendar.cjs.map +1 -1
  21. package/dist/ui/calendar.js +3 -3
  22. package/dist/ui/calendar.js.map +1 -1
  23. package/dist/ui/carousel.cjs +3 -3
  24. package/dist/ui/carousel.cjs.map +1 -1
  25. package/dist/ui/carousel.js +3 -3
  26. package/dist/ui/carousel.js.map +1 -1
  27. package/dist/ui/chip.cjs +2 -2
  28. package/dist/ui/chip.cjs.map +1 -1
  29. package/dist/ui/chip.js +2 -2
  30. package/dist/ui/chip.js.map +1 -1
  31. package/dist/ui/combobox.cjs +4 -4
  32. package/dist/ui/combobox.cjs.map +1 -1
  33. package/dist/ui/combobox.js +4 -4
  34. package/dist/ui/combobox.js.map +1 -1
  35. package/dist/ui/command.cjs +1 -1
  36. package/dist/ui/command.cjs.map +1 -1
  37. package/dist/ui/command.d.cts +7 -7
  38. package/dist/ui/command.d.ts +7 -7
  39. package/dist/ui/command.js +1 -1
  40. package/dist/ui/command.js.map +1 -1
  41. package/dist/ui/context-menu.cjs +1 -1
  42. package/dist/ui/context-menu.cjs.map +1 -1
  43. package/dist/ui/context-menu.js +1 -1
  44. package/dist/ui/context-menu.js.map +1 -1
  45. package/dist/ui/input-otp.d.cts +2 -2
  46. package/dist/ui/input-otp.d.ts +2 -2
  47. package/dist/ui/multi-combobox.cjs +152 -138
  48. package/dist/ui/multi-combobox.cjs.map +1 -1
  49. package/dist/ui/multi-combobox.js +152 -138
  50. package/dist/ui/multi-combobox.js.map +1 -1
  51. package/dist/ui/navigation-menu.cjs +1 -1
  52. package/dist/ui/navigation-menu.cjs.map +1 -1
  53. package/dist/ui/navigation-menu.js +1 -1
  54. package/dist/ui/navigation-menu.js.map +1 -1
  55. package/dist/ui/pagination.cjs +3 -3
  56. package/dist/ui/pagination.cjs.map +1 -1
  57. package/dist/ui/pagination.js +3 -3
  58. package/dist/ui/pagination.js.map +1 -1
  59. package/dist/ui/resizable.cjs +2 -2
  60. package/dist/ui/resizable.cjs.map +1 -1
  61. package/dist/ui/resizable.d.cts +1 -1
  62. package/dist/ui/resizable.d.ts +1 -1
  63. package/dist/ui/resizable.js +2 -2
  64. package/dist/ui/resizable.js.map +1 -1
  65. package/dist/ui/scroll-area.cjs +1 -1
  66. package/dist/ui/scroll-area.cjs.map +1 -1
  67. package/dist/ui/scroll-area.js +1 -1
  68. package/dist/ui/scroll-area.js.map +1 -1
  69. package/dist/ui/separator.cjs +1 -1
  70. package/dist/ui/separator.cjs.map +1 -1
  71. package/dist/ui/separator.js +1 -1
  72. package/dist/ui/separator.js.map +1 -1
  73. package/dist/ui/sidebar.cjs +8 -5
  74. package/dist/ui/sidebar.cjs.map +1 -1
  75. package/dist/ui/sidebar.js +8 -5
  76. package/dist/ui/sidebar.js.map +1 -1
  77. package/dist/ui/skeleton.cjs +4 -1
  78. package/dist/ui/skeleton.cjs.map +1 -1
  79. package/dist/ui/skeleton.js +4 -1
  80. package/dist/ui/skeleton.js.map +1 -1
  81. package/package.json +2 -2
@@ -34,12 +34,12 @@ var React4__namespace = /*#__PURE__*/_interopNamespace(React4);
34
34
 
35
35
  var cn = (...inputs) => tailwindMerge.twMerge(clsx.clsx(inputs));
36
36
  var buttonVariants = classVarianceAuthority.cva(
37
- "inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-xl text-sm font-medium focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-[#5A6FC0] disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0",
37
+ "inline-flex cursor-pointer items-center justify-center gap-2 whitespace-nowrap rounded-xl text-sm font-medium focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-[#5A6FC0] disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0",
38
38
  {
39
39
  variants: {
40
40
  variant: {
41
- default: "bg-foreground-primary-medium text-white shadow hover:bg-primary/90",
42
- destructive: "bg-destructive text-destructive-foreground hover:bg-destructive/90",
41
+ default: "bg-foreground-primary-medium text-white shadow hover:bg-primary-hover",
42
+ destructive: "bg-destructive text-destructive-foreground hover:bg-destructive-hover",
43
43
  outline: "border border-input bg-background hover:bg-secondary hover:text-accent-foreground text-foreground-secondary-heavy",
44
44
  secondary: "bg-background-secondary-light hover:background-secondary-light/40 text-foreground-secondary-heavy",
45
45
  ghost: "text-foreground-secondary-heavy hover:bg-background-secondary-light",
@@ -138,7 +138,7 @@ var CommandSeparator = React4__namespace.forwardRef(({ className, ...props }, re
138
138
  cmdk.Command.Separator,
139
139
  {
140
140
  ref,
141
- className: cn("-mx-1 h-px bg-border", className),
141
+ className: cn("-mx-1 h-px bg-card", className),
142
142
  ...props
143
143
  }
144
144
  ));
@@ -169,149 +169,163 @@ var PopoverContent = React4__namespace.forwardRef(({ className, align = "center"
169
169
  }
170
170
  ) }));
171
171
  PopoverContent.displayName = PopoverPrimitive__namespace.Content.displayName;
172
- var MultiCombobox = React4__namespace.forwardRef(({
173
- options,
174
- placeholder = "Select options...",
175
- searchPlaceholder = "Search...",
176
- emptyMessage = "No options found.",
177
- className,
178
- contentClassName,
179
- value: controlledValue,
180
- onValueChange,
181
- onSelect,
182
- onCreate,
183
- maxDisplayedItems = 3,
184
- asChild,
185
- children
186
- }, ref) => {
187
- const [open, setOpen] = React4__namespace.useState(false);
188
- const [value, setValue] = React4__namespace.useState(controlledValue || []);
189
- const [search, setSearch] = React4__namespace.useState("");
190
- React4__namespace.useEffect(() => {
191
- if (controlledValue !== void 0) {
192
- setValue(controlledValue);
193
- }
194
- }, [controlledValue]);
195
- const handleSelect = React4__namespace.useCallback((currentValue) => {
196
- const newValue = value.includes(currentValue) ? value.filter((v) => v !== currentValue) : [...value, currentValue];
197
- setValue(newValue);
198
- onValueChange?.(newValue);
199
- onSelect?.(newValue);
200
- }, [value, onValueChange, onSelect]);
201
- const handleRemove = React4__namespace.useCallback((valueToRemove) => {
202
- const newValue = value.filter((v) => v !== valueToRemove);
203
- setValue(newValue);
204
- onValueChange?.(newValue);
205
- onSelect?.(newValue);
206
- }, [value, onValueChange, onSelect]);
207
- const selectedLabels = React4__namespace.useMemo(() => {
208
- return value.map((v) => options.find((opt) => opt.value === v)?.label).filter(Boolean);
209
- }, [value, options]);
210
- return /* @__PURE__ */ jsxRuntime.jsxs(PopoverPrimitive.Popover, { open, onOpenChange: setOpen, children: [
211
- /* @__PURE__ */ jsxRuntime.jsx(PopoverPrimitive.PopoverTrigger, { asChild: true, children: asChild ? children : /* @__PURE__ */ jsxRuntime.jsxs(
212
- Button,
213
- {
214
- variant: "outline",
215
- role: "combobox",
216
- "aria-expanded": open,
217
- className: cn("w-full justify-between", className),
218
- children: [
219
- /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "flex flex-wrap gap-1 items-center", children: [
220
- value.length > 0 && /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "flex flex-wrap gap-1", children: [
221
- selectedLabels.slice(0, maxDisplayedItems).map((label, index) => /* @__PURE__ */ jsxRuntime.jsxs(
222
- "div",
172
+ var MultiCombobox = React4__namespace.forwardRef(
173
+ ({
174
+ options,
175
+ placeholder = "Select options...",
176
+ searchPlaceholder = "Search...",
177
+ emptyMessage = "No options found.",
178
+ className,
179
+ contentClassName,
180
+ value: controlledValue,
181
+ onValueChange,
182
+ onSelect,
183
+ onCreate,
184
+ maxDisplayedItems = 3,
185
+ asChild,
186
+ children
187
+ }, ref) => {
188
+ const [open, setOpen] = React4__namespace.useState(false);
189
+ const [value, setValue] = React4__namespace.useState(controlledValue || []);
190
+ const [search, setSearch] = React4__namespace.useState("");
191
+ React4__namespace.useEffect(() => {
192
+ if (controlledValue !== void 0) {
193
+ setValue(controlledValue);
194
+ }
195
+ }, [controlledValue]);
196
+ const handleSelect = React4__namespace.useCallback(
197
+ (currentValue) => {
198
+ const newValue = value.includes(currentValue) ? value.filter((v) => v !== currentValue) : [...value, currentValue];
199
+ setValue(newValue);
200
+ onValueChange?.(newValue);
201
+ onSelect?.(newValue);
202
+ },
203
+ [value, onValueChange, onSelect]
204
+ );
205
+ const handleRemove = React4__namespace.useCallback(
206
+ (valueToRemove) => {
207
+ const newValue = value.filter((v) => v !== valueToRemove);
208
+ setValue(newValue);
209
+ onValueChange?.(newValue);
210
+ onSelect?.(newValue);
211
+ },
212
+ [value, onValueChange, onSelect]
213
+ );
214
+ const selectedLabels = React4__namespace.useMemo(() => {
215
+ return value.map((v) => options.find((opt) => opt.value === v)?.label).filter(Boolean);
216
+ }, [value, options]);
217
+ return /* @__PURE__ */ jsxRuntime.jsxs(PopoverPrimitive.Popover, { open, onOpenChange: setOpen, children: [
218
+ /* @__PURE__ */ jsxRuntime.jsx(PopoverPrimitive.PopoverTrigger, { asChild: true, children: asChild ? children : /* @__PURE__ */ jsxRuntime.jsxs(
219
+ Button,
220
+ {
221
+ variant: "outline",
222
+ role: "combobox",
223
+ "aria-expanded": open,
224
+ className: cn("w-full justify-between", className),
225
+ children: [
226
+ /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "flex flex-wrap gap-1 items-center", children: [
227
+ value.length > 0 && /* @__PURE__ */ jsxRuntime.jsxs("div", { className: "flex flex-wrap gap-1", children: [
228
+ selectedLabels.slice(0, maxDisplayedItems).map((label, index) => /* @__PURE__ */ jsxRuntime.jsxs(
229
+ "div",
230
+ {
231
+ className: "flex items-center gap-1 bg-secondary px-2 py-0.5 rounded-md text-sm",
232
+ children: [
233
+ /* @__PURE__ */ jsxRuntime.jsx("span", { children: label }),
234
+ /* @__PURE__ */ jsxRuntime.jsx(
235
+ "div",
236
+ {
237
+ onClick: (e) => {
238
+ e.stopPropagation();
239
+ handleRemove(value[index]);
240
+ },
241
+ className: "hover:bg-secondary-foreground/20 rounded-sm",
242
+ children: /* @__PURE__ */ jsxRuntime.jsx(reactIcons.Cross2Icon, { className: "h-3 w-3" })
243
+ }
244
+ )
245
+ ]
246
+ },
247
+ index
248
+ )),
249
+ selectedLabels.length > maxDisplayedItems && /* @__PURE__ */ jsxRuntime.jsxs("span", { className: "text-sm text-muted-foreground", children: [
250
+ "+",
251
+ selectedLabels.length - maxDisplayedItems,
252
+ " more"
253
+ ] })
254
+ ] }),
255
+ value.length === 0 && /* @__PURE__ */ jsxRuntime.jsx("span", { className: "text-sm text-muted-foreground font-normal", children: placeholder })
256
+ ] }),
257
+ /* @__PURE__ */ jsxRuntime.jsx(reactIcons.ChevronDownIcon, { className: "opacity-50" })
258
+ ]
259
+ }
260
+ ) }),
261
+ /* @__PURE__ */ jsxRuntime.jsx(
262
+ PopoverContent,
263
+ {
264
+ className: cn("w-full p-0 !rounded-xl border-none", contentClassName),
265
+ children: /* @__PURE__ */ jsxRuntime.jsxs(Command, { className: "rounded-xl border", children: [
266
+ /* @__PURE__ */ jsxRuntime.jsx(
267
+ CommandInput,
268
+ {
269
+ placeholder: searchPlaceholder,
270
+ className: "h-9 w-full",
271
+ value: search,
272
+ onValueChange: setSearch
273
+ }
274
+ ),
275
+ /* @__PURE__ */ jsxRuntime.jsxs(CommandList, { children: [
276
+ /* @__PURE__ */ jsxRuntime.jsxs(CommandEmpty, { className: "flex flex-col gap-3 px-4 py-5", children: [
277
+ !!onCreate && search && /* @__PURE__ */ jsxRuntime.jsxs(
278
+ Button,
279
+ {
280
+ variant: "outline",
281
+ size: "sm",
282
+ onClick: () => {
283
+ setOpen(false);
284
+ onCreate(search);
285
+ },
286
+ children: [
287
+ /* @__PURE__ */ jsxRuntime.jsx(reactIcons.PlusIcon, { className: "h-4 w-4" }),
288
+ /* @__PURE__ */ jsxRuntime.jsxs("span", { className: "truncate", children: [
289
+ 'Create "',
290
+ search,
291
+ '"'
292
+ ] })
293
+ ]
294
+ }
295
+ ),
296
+ /* @__PURE__ */ jsxRuntime.jsx("span", { className: "text-center text-muted-foreground text-xs", children: "No results found" })
297
+ ] }),
298
+ /* @__PURE__ */ jsxRuntime.jsx(CommandGroup, { children: options.map((option) => /* @__PURE__ */ jsxRuntime.jsxs(
299
+ CommandItem,
223
300
  {
224
- className: "flex items-center gap-1 bg-secondary px-2 py-0.5 rounded-md text-sm",
301
+ className: "rounded-xl",
302
+ keywords: [option.label],
303
+ value: option.value,
304
+ onSelect: () => handleSelect(option.value),
305
+ onKeyUp: (e) => e.key === "Enter" && handleSelect(option.value),
306
+ onKeyDown: (e) => e.key === "Enter" && handleSelect(option.value),
225
307
  children: [
226
- /* @__PURE__ */ jsxRuntime.jsx("span", { children: label }),
308
+ option.label,
227
309
  /* @__PURE__ */ jsxRuntime.jsx(
228
- "div",
310
+ reactIcons.CheckIcon,
229
311
  {
230
- onClick: (e) => {
231
- e.stopPropagation();
232
- handleRemove(value[index]);
233
- },
234
- className: "hover:bg-secondary-foreground/20 rounded-sm",
235
- children: /* @__PURE__ */ jsxRuntime.jsx(reactIcons.Cross2Icon, { className: "h-3 w-3" })
312
+ className: cn(
313
+ "ml-auto",
314
+ value.includes(option.value) ? "opacity-100" : "opacity-0"
315
+ )
236
316
  }
237
317
  )
238
318
  ]
239
319
  },
240
- index
241
- )),
242
- selectedLabels.length > maxDisplayedItems && /* @__PURE__ */ jsxRuntime.jsxs("span", { className: "text-sm text-muted-foreground", children: [
243
- "+",
244
- selectedLabels.length - maxDisplayedItems,
245
- " more"
246
- ] })
247
- ] }),
248
- value.length === 0 && /* @__PURE__ */ jsxRuntime.jsx("span", { className: "text-sm text-muted-foreground font-normal", children: placeholder })
249
- ] }),
250
- /* @__PURE__ */ jsxRuntime.jsx(reactIcons.ChevronDownIcon, { className: "opacity-50" })
251
- ]
252
- }
253
- ) }),
254
- /* @__PURE__ */ jsxRuntime.jsx(PopoverContent, { className: cn("w-full p-0 !rounded-xl border-none", contentClassName), children: /* @__PURE__ */ jsxRuntime.jsxs(Command, { className: "rounded-xl border", children: [
255
- /* @__PURE__ */ jsxRuntime.jsx(
256
- CommandInput,
257
- {
258
- placeholder: searchPlaceholder,
259
- className: "h-9 w-full",
260
- value: search,
261
- onValueChange: setSearch
320
+ `${option.value}-${option.label}`
321
+ )) })
322
+ ] })
323
+ ] })
262
324
  }
263
- ),
264
- /* @__PURE__ */ jsxRuntime.jsxs(CommandList, { children: [
265
- /* @__PURE__ */ jsxRuntime.jsxs(CommandEmpty, { className: "flex flex-col gap-3 px-4 py-5", children: [
266
- !!onCreate && search && /* @__PURE__ */ jsxRuntime.jsxs(
267
- Button,
268
- {
269
- variant: "outline",
270
- size: "sm",
271
- onClick: () => {
272
- setOpen(false);
273
- onCreate(search);
274
- },
275
- children: [
276
- /* @__PURE__ */ jsxRuntime.jsx(reactIcons.PlusIcon, { className: "h-4 w-4" }),
277
- /* @__PURE__ */ jsxRuntime.jsxs("span", { className: "truncate", children: [
278
- 'Create "',
279
- search,
280
- '"'
281
- ] })
282
- ]
283
- }
284
- ),
285
- /* @__PURE__ */ jsxRuntime.jsx("span", { className: "text-center text-muted-foreground text-xs", children: "No results found" })
286
- ] }),
287
- /* @__PURE__ */ jsxRuntime.jsx(CommandGroup, { children: options.map((option) => /* @__PURE__ */ jsxRuntime.jsxs(
288
- CommandItem,
289
- {
290
- className: "rounded-lg",
291
- keywords: [option.label],
292
- value: option.value,
293
- onSelect: () => handleSelect(option.value),
294
- onKeyUp: (e) => e.key === "Enter" && handleSelect(option.value),
295
- onKeyDown: (e) => e.key === "Enter" && handleSelect(option.value),
296
- children: [
297
- option.label,
298
- /* @__PURE__ */ jsxRuntime.jsx(
299
- reactIcons.CheckIcon,
300
- {
301
- className: cn(
302
- "ml-auto",
303
- value.includes(option.value) ? "opacity-100" : "opacity-0"
304
- )
305
- }
306
- )
307
- ]
308
- },
309
- option.value
310
- )) })
311
- ] })
312
- ] }) })
313
- ] });
314
- });
325
+ )
326
+ ] });
327
+ }
328
+ );
315
329
  MultiCombobox.displayName = "MultiCombobox";
316
330
 
317
331
  exports.MultiCombobox = MultiCombobox;
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/lib/utils.ts","../../src/ui/button.tsx","../../src/ui/command.tsx","../../src/ui/popover.tsx","../../src/ui/multi-combobox.tsx"],"names":["twMerge","clsx","cva","React","Slot","jsx","React2","CommandPrimitive","jsxs","MagnifyingGlassIcon","React3","PopoverPrimitive","React4","Popover","PopoverTrigger","Cross2Icon","ChevronDownIcon","PlusIcon","CheckIcon"],"mappings":"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","file":"multi-combobox.cjs","sourcesContent":["import { clsx } from \"clsx\";\nimport type { ClassValue } from \"clsx\";\nimport { toast } from \"sonner\";\nimport { twMerge } from \"tailwind-merge\";\n\nexport const cn = (...inputs: ClassValue[]): string => twMerge(clsx(inputs));\n\nexport const capitalize = (str: string) =>\n str?.charAt(0)?.toUpperCase() + str?.slice(1);\n\nexport const handleError = (error: { message: string }): void => {\n toast.error(error.message);\n};\n","\"use client\";\n\nimport * as React from \"react\";\nimport { Slot } from \"@radix-ui/react-slot\";\nimport { cva, type VariantProps } from \"class-variance-authority\";\nimport { cn } from \"../lib/utils\";\n\nconst buttonVariants = cva(\n \"inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-xl text-sm font-medium focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-[#5A6FC0] disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0\",\n {\n variants: {\n variant: {\n default:\n \"bg-foreground-primary-medium text-white shadow hover:bg-primary/90\",\n destructive:\n \"bg-destructive text-destructive-foreground hover:bg-destructive/90\",\n outline:\n \"border border-input bg-background hover:bg-secondary hover:text-accent-foreground text-foreground-secondary-heavy\",\n secondary:\n \"bg-background-secondary-light hover:background-secondary-light/40 text-foreground-secondary-heavy\",\n ghost:\n \"text-foreground-secondary-heavy hover:bg-background-secondary-light\",\n link: \"text-text-links hover:bg-background-secondary-light\",\n accent: \"bg-accent nuvia-gradient-1 text-white\",\n },\n size: {\n default: \"h-10 px-4 py-2\",\n xs: \"h-[30px] px-3 rounded-xl text-xs\",\n sm: \"h-9 rounded-xl px-3 text-xs\",\n lg: \"h-12 rounded-xl px-8\",\n icon: \"h-10 w-10 min-w-10\",\n \"icon-xs\": \"h-[30px] w-[30px] min-w-[30px]\",\n \"icon-sm\": \"h-9 w-9 min-w-9\",\n bullet: \"h-8 w-8 min-w-8\",\n },\n },\n defaultVariants: {\n variant: \"default\",\n size: \"default\",\n },\n },\n);\n\nexport interface ButtonProps\n extends React.ButtonHTMLAttributes<HTMLButtonElement>,\n VariantProps<typeof buttonVariants> {\n asChild?: boolean;\n}\n\nconst Button = React.forwardRef<HTMLButtonElement, ButtonProps>(\n ({ className, variant, size, asChild = false, ...props }, ref) => {\n const Comp = asChild ? Slot : \"button\";\n return (\n <Comp\n className={cn(buttonVariants({ variant, size, className }))}\n ref={ref}\n {...props}\n />\n );\n },\n);\nButton.displayName = \"Button\";\n\nexport { Button, buttonVariants };\n","\"use client\";\n\nimport * as React from \"react\";\nimport type { DialogProps } from \"@radix-ui/react-dialog\";\nimport { Command as CommandPrimitive } from \"cmdk\";\nimport { MagnifyingGlassIcon } from \"@radix-ui/react-icons\";\nimport { cn } from \"../lib/utils\";\nimport { Dialog, DialogContent } from \"./dialog\";\n\nconst Command = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive>\n>(({ className, ...props }, ref) => (\n <CommandPrimitive\n ref={ref}\n className={cn(\n \"flex h-full w-full flex-col overflow-hidden rounded-md bg-popover text-popover-foreground\",\n className,\n )}\n {...props}\n />\n));\nCommand.displayName = CommandPrimitive.displayName;\n\nconst CommandDialog = ({ children, ...props }: DialogProps) => {\n return (\n <Dialog {...props}>\n <DialogContent className=\"overflow-hidden p-0\">\n <Command className=\"[&_[cmdk-group-heading]]:px-2 [&_[cmdk-group-heading]]:font-medium [&_[cmdk-group-heading]]:text-muted-foreground [&_[cmdk-group]:not([hidden])_~[cmdk-group]]:pt-0 [&_[cmdk-group]]:px-2 [&_[cmdk-input-wrapper]_svg]:h-5 [&_[cmdk-input-wrapper]_svg]:w-5 [&_[cmdk-input]]:h-12 [&_[cmdk-item]]:px-2 [&_[cmdk-item]]:py-3 [&_[cmdk-item]_svg]:h-5 [&_[cmdk-item]_svg]:w-5\">\n {children}\n </Command>\n </DialogContent>\n </Dialog>\n );\n};\n\nconst CommandInput = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive.Input>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive.Input>\n>(({ className, ...props }, ref) => (\n <div className=\"flex items-center border-b px-3\" cmdk-input-wrapper=\"\">\n <MagnifyingGlassIcon className=\"mr-2 h-4 w-4 shrink-0 opacity-50\" />\n <CommandPrimitive.Input\n ref={ref}\n className={cn(\n \"flex h-10 w-full rounded-md bg-transparent py-3 text-sm outline-none placeholder:text-muted-foreground disabled:cursor-not-allowed disabled:opacity-50\",\n className,\n )}\n {...props}\n />\n </div>\n));\n\nCommandInput.displayName = CommandPrimitive.Input.displayName;\n\nconst CommandList = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive.List>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive.List>\n>(({ className, ...props }, ref) => (\n <CommandPrimitive.List\n ref={ref}\n className={cn(\"max-h-[300px] overflow-y-auto overflow-x-hidden\", className)}\n {...props}\n />\n));\n\nCommandList.displayName = CommandPrimitive.List.displayName;\n\nconst CommandEmpty = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive.Empty>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive.Empty>\n>((props, ref) => (\n <CommandPrimitive.Empty\n ref={ref}\n className=\"py-6 text-center text-sm\"\n {...props}\n />\n));\n\nCommandEmpty.displayName = CommandPrimitive.Empty.displayName;\n\nconst CommandGroup = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive.Group>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive.Group>\n>(({ className, ...props }, ref) => (\n <CommandPrimitive.Group\n ref={ref}\n className={cn(\n \"overflow-hidden p-1 text-foreground [&_[cmdk-group-heading]]:px-2 [&_[cmdk-group-heading]]:py-1.5 [&_[cmdk-group-heading]]:text-xs [&_[cmdk-group-heading]]:font-medium [&_[cmdk-group-heading]]:text-muted-foreground\",\n className,\n )}\n {...props}\n />\n));\n\nCommandGroup.displayName = CommandPrimitive.Group.displayName;\n\nconst CommandSeparator = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive.Separator>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive.Separator>\n>(({ className, ...props }, ref) => (\n <CommandPrimitive.Separator\n ref={ref}\n className={cn(\"-mx-1 h-px bg-border\", className)}\n {...props}\n />\n));\nCommandSeparator.displayName = CommandPrimitive.Separator.displayName;\n\nconst CommandItem = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive.Item>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive.Item>\n>(({ className, ...props }, ref) => (\n <CommandPrimitive.Item\n ref={ref}\n className={cn(\n \"relative flex cursor-default gap-2 select-none items-center rounded-md px-2 py-1.5 text-sm outline-none data-[disabled=true]:pointer-events-none data-[selected=true]:bg-primary/25 data-[selected=true]:bg-secondary/50 data-[selected=true]:text-accent-foreground data-[disabled=true]:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0\",\n className,\n )}\n {...props}\n />\n));\n\nCommandItem.displayName = CommandPrimitive.Item.displayName;\n\nconst CommandShortcut = ({\n className,\n ...props\n}: React.HTMLAttributes<HTMLSpanElement>) => {\n return (\n <span\n className={cn(\n \"ml-auto text-xs tracking-widest text-muted-foreground\",\n className,\n )}\n {...props}\n />\n );\n};\nCommandShortcut.displayName = \"CommandShortcut\";\n\nexport {\n Command,\n CommandDialog,\n CommandInput,\n CommandList,\n CommandEmpty,\n CommandGroup,\n CommandItem,\n CommandShortcut,\n CommandSeparator,\n};\n","\"use client\"\n\nimport * as React from \"react\"\nimport * as PopoverPrimitive from \"@radix-ui/react-popover\"\n\nimport { cn } from \"../lib/utils\"\n\nconst Popover = PopoverPrimitive.Root\n\nconst PopoverTrigger = PopoverPrimitive.Trigger\n\nconst PopoverAnchor = PopoverPrimitive.Anchor\n\nconst PopoverContent = React.forwardRef<\n React.ElementRef<typeof PopoverPrimitive.Content>,\n React.ComponentPropsWithoutRef<typeof PopoverPrimitive.Content>\n>(({ className, align = \"center\", sideOffset = 4, ...props }, ref) => (\n <PopoverPrimitive.Portal>\n <PopoverPrimitive.Content\n ref={ref}\n align={align}\n sideOffset={sideOffset}\n className={cn(\n \"z-50 w-72 rounded-xl border bg-popover p-4 text-popover-foreground shadow-md outline-none data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2\",\n className\n )}\n {...props}\n />\n </PopoverPrimitive.Portal>\n))\nPopoverContent.displayName = PopoverPrimitive.Content.displayName\n\nexport { Popover, PopoverTrigger, PopoverContent, PopoverAnchor }\n","\"use client\"\n\nimport { Popover, PopoverTrigger } from \"@radix-ui/react-popover\"\nimport * as React from \"react\"\nimport { Button } from \"./button\"\nimport { cn } from \"../lib/utils\"\nimport { Command, CommandEmpty, CommandGroup, CommandInput, CommandItem, CommandList } from \"./command\"\nimport { PopoverContent } from \"./popover\"\nimport { CheckIcon, ChevronDownIcon, Cross2Icon, PlusIcon } from \"@radix-ui/react-icons\"\n\ninterface MultiComboboxOption {\n value: string\n label: string\n}\n\ninterface MultiComboboxProps {\n children?: React.ReactNode\n options: MultiComboboxOption[]\n placeholder?: string\n searchPlaceholder?: string\n emptyMessage?: string\n className?: string\n value?: string[]\n onValueChange?: (value: string[]) => void\n onCreate?: (value: string) => void;\n onSelect?: (value: string[]) => void\n maxDisplayedItems?: number\n contentClassName?: string\n asChild?: boolean\n}\n\nconst MultiCombobox = React.forwardRef<HTMLDivElement, MultiComboboxProps>(({\n options,\n placeholder = \"Select options...\",\n searchPlaceholder = \"Search...\",\n emptyMessage = \"No options found.\",\n className,\n contentClassName,\n value: controlledValue,\n onValueChange,\n onSelect,\n onCreate,\n maxDisplayedItems = 3,\n asChild,\n children,\n}, ref) => {\n const [open, setOpen] = React.useState(false)\n const [value, setValue] = React.useState<string[]>(controlledValue || [])\n const [search, setSearch] = React.useState(\"\")\n\n React.useEffect(() => {\n if (controlledValue !== undefined) {\n setValue(controlledValue)\n }\n }, [controlledValue])\n\n const handleSelect = React.useCallback((currentValue: string) => {\n const newValue = value.includes(currentValue)\n ? value.filter(v => v !== currentValue)\n : [...value, currentValue]\n \n setValue(newValue)\n onValueChange?.(newValue)\n onSelect?.(newValue)\n }, [value, onValueChange, onSelect])\n\n const handleRemove = React.useCallback((valueToRemove: string) => {\n const newValue = value.filter(v => v !== valueToRemove)\n setValue(newValue)\n onValueChange?.(newValue)\n onSelect?.(newValue)\n }, [value, onValueChange, onSelect])\n\n const selectedLabels = React.useMemo(() => {\n return value.map(v => options.find(opt => opt.value === v)?.label).filter(Boolean)\n }, [value, options])\n \n return (\n <Popover open={open} onOpenChange={setOpen}>\n <PopoverTrigger asChild>\n {asChild ? children : (\n <Button\n variant=\"outline\"\n role=\"combobox\"\n aria-expanded={open}\n className={cn(\"w-full justify-between\", className)}\n >\n <div className=\"flex flex-wrap gap-1 items-center\">\n {value.length > 0 && (\n <div className=\"flex flex-wrap gap-1\">\n {selectedLabels.slice(0, maxDisplayedItems).map((label, index) => (\n <div\n key={index}\n className=\"flex items-center gap-1 bg-secondary px-2 py-0.5 rounded-md text-sm\"\n >\n <span>{label}</span>\n <div\n onClick={(e) => {\n e.stopPropagation()\n handleRemove(value[index])\n }}\n className=\"hover:bg-secondary-foreground/20 rounded-sm\"\n >\n <Cross2Icon className=\"h-3 w-3\" />\n </div>\n </div>\n ))}\n {selectedLabels.length > maxDisplayedItems && (\n <span className=\"text-sm text-muted-foreground\">\n +{selectedLabels.length - maxDisplayedItems} more\n </span>\n )}\n </div>\n )}\n {value.length === 0 && (\n <span className=\"text-sm text-muted-foreground font-normal\">\n {placeholder}\n </span>\n )}\n </div>\n <ChevronDownIcon className=\"opacity-50\" />\n </Button>\n )}\n </PopoverTrigger>\n <PopoverContent className={cn(\"w-full p-0 !rounded-xl border-none\", contentClassName)}>\n <Command className=\"rounded-xl border\">\n <CommandInput \n placeholder={searchPlaceholder} \n className=\"h-9 w-full\"\n value={search}\n onValueChange={setSearch}\n />\n <CommandList>\n <CommandEmpty className=\"flex flex-col gap-3 px-4 py-5\">\n {!!onCreate && search && (\n <Button\n variant=\"outline\"\n size=\"sm\"\n onClick={() => {\n setOpen(false);\n onCreate(search);\n }}\n >\n <PlusIcon className=\"h-4 w-4\" />\n <span className=\"truncate\">Create \"{search}\"</span>\n </Button>\n )}\n <span className=\"text-center text-muted-foreground text-xs\">\n No results found\n </span>\n </CommandEmpty>\n <CommandGroup>\n {options.map((option) => (\n <CommandItem\n className=\"rounded-lg\"\n keywords={[option.label]}\n key={option.value}\n value={option.value}\n onSelect={() => handleSelect(option.value)}\n onKeyUp={(e) => e.key === 'Enter' && handleSelect(option.value)}\n onKeyDown={(e) => e.key === 'Enter' && handleSelect(option.value)}\n >\n {option.label}\n <CheckIcon\n className={cn(\n \"ml-auto\",\n value.includes(option.value) ? \"opacity-100\" : \"opacity-0\"\n )}\n />\n </CommandItem>\n ))}\n </CommandGroup>\n </CommandList>\n </Command>\n </PopoverContent>\n </Popover>\n )\n})\n\nMultiCombobox.displayName = \"MultiCombobox\"\n\nexport { MultiCombobox }"]}
1
+ {"version":3,"sources":["../../src/lib/utils.ts","../../src/ui/button.tsx","../../src/ui/command.tsx","../../src/ui/popover.tsx","../../src/ui/multi-combobox.tsx"],"names":["twMerge","clsx","cva","React","Slot","jsx","React2","CommandPrimitive","jsxs","MagnifyingGlassIcon","React3","PopoverPrimitive","React4","Popover","PopoverTrigger","Cross2Icon","ChevronDownIcon","PlusIcon","CheckIcon"],"mappings":"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","file":"multi-combobox.cjs","sourcesContent":["import { clsx } from \"clsx\";\nimport type { ClassValue } from \"clsx\";\nimport { toast } from \"sonner\";\nimport { twMerge } from \"tailwind-merge\";\n\nexport const cn = (...inputs: ClassValue[]): string => twMerge(clsx(inputs));\n\nexport const capitalize = (str: string) =>\n str?.charAt(0)?.toUpperCase() + str?.slice(1);\n\nexport const handleError = (error: { message: string }): void => {\n toast.error(error.message);\n};\n","\"use client\";\n\nimport * as React from \"react\";\nimport { Slot } from \"@radix-ui/react-slot\";\nimport { cva, type VariantProps } from \"class-variance-authority\";\nimport { cn } from \"../lib/utils\";\n\nconst buttonVariants = cva(\n \"inline-flex cursor-pointer items-center justify-center gap-2 whitespace-nowrap rounded-xl text-sm font-medium focus-visible:outline-none focus-visible:ring-1 focus-visible:ring-[#5A6FC0] disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0\",\n {\n variants: {\n variant: {\n default:\n \"bg-foreground-primary-medium text-white shadow hover:bg-primary-hover\",\n destructive:\n \"bg-destructive text-destructive-foreground hover:bg-destructive-hover\",\n outline:\n \"border border-input bg-background hover:bg-secondary hover:text-accent-foreground text-foreground-secondary-heavy\",\n secondary:\n \"bg-background-secondary-light hover:background-secondary-light/40 text-foreground-secondary-heavy\",\n ghost:\n \"text-foreground-secondary-heavy hover:bg-background-secondary-light\",\n link: \"text-text-links hover:bg-background-secondary-light\",\n accent: \"bg-accent nuvia-gradient-1 text-white\",\n },\n size: {\n default: \"h-10 px-4 py-2\",\n xs: \"h-[30px] px-3 rounded-xl text-xs\",\n sm: \"h-9 rounded-xl px-3 text-xs\",\n lg: \"h-12 rounded-xl px-8\",\n icon: \"h-10 w-10 min-w-10\",\n \"icon-xs\": \"h-[30px] w-[30px] min-w-[30px]\",\n \"icon-sm\": \"h-9 w-9 min-w-9\",\n bullet: \"h-8 w-8 min-w-8\",\n },\n },\n defaultVariants: {\n variant: \"default\",\n size: \"default\",\n },\n },\n);\n\nexport interface ButtonProps\n extends React.ButtonHTMLAttributes<HTMLButtonElement>,\n VariantProps<typeof buttonVariants> {\n asChild?: boolean;\n}\n\nconst Button = React.forwardRef<HTMLButtonElement, ButtonProps>(\n ({ className, variant, size, asChild = false, ...props }, ref) => {\n const Comp = asChild ? Slot : \"button\";\n return (\n <Comp\n className={cn(buttonVariants({ variant, size, className }))}\n ref={ref}\n {...props}\n />\n );\n },\n);\nButton.displayName = \"Button\";\n\nexport { Button, buttonVariants };\n","\"use client\";\n\nimport * as React from \"react\";\nimport type { DialogProps } from \"@radix-ui/react-dialog\";\nimport { Command as CommandPrimitive } from \"cmdk\";\nimport { MagnifyingGlassIcon } from \"@radix-ui/react-icons\";\nimport { cn } from \"../lib/utils\";\nimport { Dialog, DialogContent } from \"./dialog\";\n\nconst Command = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive>\n>(({ className, ...props }, ref) => (\n <CommandPrimitive\n ref={ref}\n className={cn(\n \"flex h-full w-full flex-col overflow-hidden rounded-md bg-popover text-popover-foreground\",\n className,\n )}\n {...props}\n />\n));\nCommand.displayName = CommandPrimitive.displayName;\n\nconst CommandDialog = ({ children, ...props }: DialogProps) => {\n return (\n <Dialog {...props}>\n <DialogContent className=\"overflow-hidden p-0\">\n <Command className=\"[&_[cmdk-group-heading]]:px-2 [&_[cmdk-group-heading]]:font-medium [&_[cmdk-group-heading]]:text-muted-foreground [&_[cmdk-group]:not([hidden])_~[cmdk-group]]:pt-0 [&_[cmdk-group]]:px-2 [&_[cmdk-input-wrapper]_svg]:h-5 [&_[cmdk-input-wrapper]_svg]:w-5 [&_[cmdk-input]]:h-12 [&_[cmdk-item]]:px-2 [&_[cmdk-item]]:py-3 [&_[cmdk-item]_svg]:h-5 [&_[cmdk-item]_svg]:w-5\">\n {children}\n </Command>\n </DialogContent>\n </Dialog>\n );\n};\n\nconst CommandInput = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive.Input>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive.Input>\n>(({ className, ...props }, ref) => (\n <div className=\"flex items-center border-b px-3\" cmdk-input-wrapper=\"\">\n <MagnifyingGlassIcon className=\"mr-2 h-4 w-4 shrink-0 opacity-50\" />\n <CommandPrimitive.Input\n ref={ref}\n className={cn(\n \"flex h-10 w-full rounded-md bg-transparent py-3 text-sm outline-none placeholder:text-muted-foreground disabled:cursor-not-allowed disabled:opacity-50\",\n className,\n )}\n {...props}\n />\n </div>\n));\n\nCommandInput.displayName = CommandPrimitive.Input.displayName;\n\nconst CommandList = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive.List>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive.List>\n>(({ className, ...props }, ref) => (\n <CommandPrimitive.List\n ref={ref}\n className={cn(\"max-h-[300px] overflow-y-auto overflow-x-hidden\", className)}\n {...props}\n />\n));\n\nCommandList.displayName = CommandPrimitive.List.displayName;\n\nconst CommandEmpty = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive.Empty>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive.Empty>\n>((props, ref) => (\n <CommandPrimitive.Empty\n ref={ref}\n className=\"py-6 text-center text-sm\"\n {...props}\n />\n));\n\nCommandEmpty.displayName = CommandPrimitive.Empty.displayName;\n\nconst CommandGroup = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive.Group>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive.Group>\n>(({ className, ...props }, ref) => (\n <CommandPrimitive.Group\n ref={ref}\n className={cn(\n \"overflow-hidden p-1 text-foreground [&_[cmdk-group-heading]]:px-2 [&_[cmdk-group-heading]]:py-1.5 [&_[cmdk-group-heading]]:text-xs [&_[cmdk-group-heading]]:font-medium [&_[cmdk-group-heading]]:text-muted-foreground\",\n className,\n )}\n {...props}\n />\n));\n\nCommandGroup.displayName = CommandPrimitive.Group.displayName;\n\nconst CommandSeparator = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive.Separator>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive.Separator>\n>(({ className, ...props }, ref) => (\n <CommandPrimitive.Separator\n ref={ref}\n className={cn(\"-mx-1 h-px bg-card\", className)}\n {...props}\n />\n));\nCommandSeparator.displayName = CommandPrimitive.Separator.displayName;\n\nconst CommandItem = React.forwardRef<\n React.ElementRef<typeof CommandPrimitive.Item>,\n React.ComponentPropsWithoutRef<typeof CommandPrimitive.Item>\n>(({ className, ...props }, ref) => (\n <CommandPrimitive.Item\n ref={ref}\n className={cn(\n \"relative flex cursor-default gap-2 select-none items-center rounded-md px-2 py-1.5 text-sm outline-none data-[disabled=true]:pointer-events-none data-[selected=true]:bg-primary/25 data-[selected=true]:bg-secondary/50 data-[selected=true]:text-accent-foreground data-[disabled=true]:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0\",\n className,\n )}\n {...props}\n />\n));\n\nCommandItem.displayName = CommandPrimitive.Item.displayName;\n\nconst CommandShortcut = ({\n className,\n ...props\n}: React.HTMLAttributes<HTMLSpanElement>) => {\n return (\n <span\n className={cn(\n \"ml-auto text-xs tracking-widest text-muted-foreground\",\n className,\n )}\n {...props}\n />\n );\n};\nCommandShortcut.displayName = \"CommandShortcut\";\n\nexport {\n Command,\n CommandDialog,\n CommandInput,\n CommandList,\n CommandEmpty,\n CommandGroup,\n CommandItem,\n CommandShortcut,\n CommandSeparator,\n};\n","\"use client\"\n\nimport * as React from \"react\"\nimport * as PopoverPrimitive from \"@radix-ui/react-popover\"\n\nimport { cn } from \"../lib/utils\"\n\nconst Popover = PopoverPrimitive.Root\n\nconst PopoverTrigger = PopoverPrimitive.Trigger\n\nconst PopoverAnchor = PopoverPrimitive.Anchor\n\nconst PopoverContent = React.forwardRef<\n React.ElementRef<typeof PopoverPrimitive.Content>,\n React.ComponentPropsWithoutRef<typeof PopoverPrimitive.Content>\n>(({ className, align = \"center\", sideOffset = 4, ...props }, ref) => (\n <PopoverPrimitive.Portal>\n <PopoverPrimitive.Content\n ref={ref}\n align={align}\n sideOffset={sideOffset}\n className={cn(\n \"z-50 w-72 rounded-xl border bg-popover p-4 text-popover-foreground shadow-md outline-none data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2\",\n className\n )}\n {...props}\n />\n </PopoverPrimitive.Portal>\n))\nPopoverContent.displayName = PopoverPrimitive.Content.displayName\n\nexport { Popover, PopoverTrigger, PopoverContent, PopoverAnchor }\n","\"use client\";\n\nimport { Popover, PopoverTrigger } from \"@radix-ui/react-popover\";\nimport * as React from \"react\";\nimport { Button } from \"./button\";\nimport { cn } from \"../lib/utils\";\nimport {\n Command,\n CommandEmpty,\n CommandGroup,\n CommandInput,\n CommandItem,\n CommandList,\n} from \"./command\";\nimport { PopoverContent } from \"./popover\";\nimport {\n CheckIcon,\n ChevronDownIcon,\n Cross2Icon,\n PlusIcon,\n} from \"@radix-ui/react-icons\";\n\ninterface MultiComboboxOption {\n value: string;\n label: string;\n}\n\ninterface MultiComboboxProps {\n children?: React.ReactNode;\n options: MultiComboboxOption[];\n placeholder?: string;\n searchPlaceholder?: string;\n emptyMessage?: string;\n className?: string;\n value?: string[];\n onValueChange?: (value: string[]) => void;\n onCreate?: (value: string) => void;\n onSelect?: (value: string[]) => void;\n maxDisplayedItems?: number;\n contentClassName?: string;\n asChild?: boolean;\n}\n\nconst MultiCombobox = React.forwardRef<HTMLDivElement, MultiComboboxProps>(\n (\n {\n options,\n placeholder = \"Select options...\",\n searchPlaceholder = \"Search...\",\n emptyMessage = \"No options found.\",\n className,\n contentClassName,\n value: controlledValue,\n onValueChange,\n onSelect,\n onCreate,\n maxDisplayedItems = 3,\n asChild,\n children,\n },\n ref,\n ) => {\n const [open, setOpen] = React.useState(false);\n const [value, setValue] = React.useState<string[]>(controlledValue || []);\n const [search, setSearch] = React.useState(\"\");\n\n React.useEffect(() => {\n if (controlledValue !== undefined) {\n setValue(controlledValue);\n }\n }, [controlledValue]);\n\n const handleSelect = React.useCallback(\n (currentValue: string) => {\n const newValue = value.includes(currentValue)\n ? value.filter((v) => v !== currentValue)\n : [...value, currentValue];\n\n setValue(newValue);\n onValueChange?.(newValue);\n onSelect?.(newValue);\n },\n [value, onValueChange, onSelect],\n );\n\n const handleRemove = React.useCallback(\n (valueToRemove: string) => {\n const newValue = value.filter((v) => v !== valueToRemove);\n setValue(newValue);\n onValueChange?.(newValue);\n onSelect?.(newValue);\n },\n [value, onValueChange, onSelect],\n );\n\n const selectedLabels = React.useMemo(() => {\n return value\n .map((v) => options.find((opt) => opt.value === v)?.label)\n .filter(Boolean);\n }, [value, options]);\n\n return (\n <Popover open={open} onOpenChange={setOpen}>\n <PopoverTrigger asChild>\n {asChild ? (\n children\n ) : (\n <Button\n variant=\"outline\"\n role=\"combobox\"\n aria-expanded={open}\n className={cn(\"w-full justify-between\", className)}\n >\n <div className=\"flex flex-wrap gap-1 items-center\">\n {value.length > 0 && (\n <div className=\"flex flex-wrap gap-1\">\n {selectedLabels\n .slice(0, maxDisplayedItems)\n .map((label, index) => (\n <div\n key={index}\n className=\"flex items-center gap-1 bg-secondary px-2 py-0.5 rounded-md text-sm\"\n >\n <span>{label}</span>\n <div\n onClick={(e) => {\n e.stopPropagation();\n handleRemove(value[index]);\n }}\n className=\"hover:bg-secondary-foreground/20 rounded-sm\"\n >\n <Cross2Icon className=\"h-3 w-3\" />\n </div>\n </div>\n ))}\n {selectedLabels.length > maxDisplayedItems && (\n <span className=\"text-sm text-muted-foreground\">\n +{selectedLabels.length - maxDisplayedItems} more\n </span>\n )}\n </div>\n )}\n {value.length === 0 && (\n <span className=\"text-sm text-muted-foreground font-normal\">\n {placeholder}\n </span>\n )}\n </div>\n <ChevronDownIcon className=\"opacity-50\" />\n </Button>\n )}\n </PopoverTrigger>\n <PopoverContent\n className={cn(\"w-full p-0 !rounded-xl border-none\", contentClassName)}\n >\n <Command className=\"rounded-xl border\">\n <CommandInput\n placeholder={searchPlaceholder}\n className=\"h-9 w-full\"\n value={search}\n onValueChange={setSearch}\n />\n <CommandList>\n <CommandEmpty className=\"flex flex-col gap-3 px-4 py-5\">\n {!!onCreate && search && (\n <Button\n variant=\"outline\"\n size=\"sm\"\n onClick={() => {\n setOpen(false);\n onCreate(search);\n }}\n >\n <PlusIcon className=\"h-4 w-4\" />\n <span className=\"truncate\">Create \"{search}\"</span>\n </Button>\n )}\n <span className=\"text-center text-muted-foreground text-xs\">\n No results found\n </span>\n </CommandEmpty>\n <CommandGroup>\n {options.map((option) => (\n <CommandItem\n className=\"rounded-xl\"\n keywords={[option.label]}\n key={`${option.value}-${option.label}`}\n value={option.value}\n onSelect={() => handleSelect(option.value)}\n onKeyUp={(e) =>\n e.key === \"Enter\" && handleSelect(option.value)\n }\n onKeyDown={(e) =>\n e.key === \"Enter\" && handleSelect(option.value)\n }\n >\n {option.label}\n <CheckIcon\n className={cn(\n \"ml-auto\",\n value.includes(option.value)\n ? \"opacity-100\"\n : \"opacity-0\",\n )}\n />\n </CommandItem>\n ))}\n </CommandGroup>\n </CommandList>\n </Command>\n </PopoverContent>\n </Popover>\n );\n },\n);\n\nMultiCombobox.displayName = \"MultiCombobox\";\n\nexport { MultiCombobox };\n"]}