@hyunsdev/ui 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +674 -0
- package/README.md +89 -0
- package/SKILL.md +38 -0
- package/dist/WindowContext-DybYtZJa.d.ts +50 -0
- package/dist/_styles-BbTx89aX.d.ts +3 -0
- package/dist/chunk-23KUNTRD.js +49 -0
- package/dist/chunk-23KUNTRD.js.map +1 -0
- package/dist/chunk-3RTSANKB.js +51 -0
- package/dist/chunk-3RTSANKB.js.map +1 -0
- package/dist/chunk-4QIWBOF4.js +129 -0
- package/dist/chunk-4QIWBOF4.js.map +1 -0
- package/dist/chunk-5JCWC7IU.js +293 -0
- package/dist/chunk-5JCWC7IU.js.map +1 -0
- package/dist/chunk-6ANDNGHD.js +33 -0
- package/dist/chunk-6ANDNGHD.js.map +1 -0
- package/dist/chunk-7W7QZHEZ.js +42 -0
- package/dist/chunk-7W7QZHEZ.js.map +1 -0
- package/dist/chunk-BHO4WT2N.js +51 -0
- package/dist/chunk-BHO4WT2N.js.map +1 -0
- package/dist/chunk-BI3KKBIC.js +11 -0
- package/dist/chunk-BI3KKBIC.js.map +1 -0
- package/dist/chunk-D3SP7GL3.js +55 -0
- package/dist/chunk-D3SP7GL3.js.map +1 -0
- package/dist/chunk-D7W4RSQX.js +115 -0
- package/dist/chunk-D7W4RSQX.js.map +1 -0
- package/dist/chunk-DN2AEEA2.js +11 -0
- package/dist/chunk-DN2AEEA2.js.map +1 -0
- package/dist/chunk-ETTKFCO6.js +84 -0
- package/dist/chunk-ETTKFCO6.js.map +1 -0
- package/dist/chunk-GJT7TDBS.js +66 -0
- package/dist/chunk-GJT7TDBS.js.map +1 -0
- package/dist/chunk-HZT6RQYZ.js +109 -0
- package/dist/chunk-HZT6RQYZ.js.map +1 -0
- package/dist/chunk-JB2QZV7K.js +60 -0
- package/dist/chunk-JB2QZV7K.js.map +1 -0
- package/dist/chunk-KJJB2PVC.js +21 -0
- package/dist/chunk-KJJB2PVC.js.map +1 -0
- package/dist/chunk-NE3IVPMO.js +31 -0
- package/dist/chunk-NE3IVPMO.js.map +1 -0
- package/dist/chunk-O2BG2KSY.js +23 -0
- package/dist/chunk-O2BG2KSY.js.map +1 -0
- package/dist/chunk-OUFGNJ3V.js +1726 -0
- package/dist/chunk-OUFGNJ3V.js.map +1 -0
- package/dist/chunk-PLZMCJSL.js +351 -0
- package/dist/chunk-PLZMCJSL.js.map +1 -0
- package/dist/chunk-POG5DZBT.js +104 -0
- package/dist/chunk-POG5DZBT.js.map +1 -0
- package/dist/chunk-SECZM6JE.js +170 -0
- package/dist/chunk-SECZM6JE.js.map +1 -0
- package/dist/chunk-T64WPXSC.js +48 -0
- package/dist/chunk-T64WPXSC.js.map +1 -0
- package/dist/chunk-TU5CYBB4.js +90 -0
- package/dist/chunk-TU5CYBB4.js.map +1 -0
- package/dist/chunk-UVAI2U6X.js +153 -0
- package/dist/chunk-UVAI2U6X.js.map +1 -0
- package/dist/chunk-UXCBLYG6.js +142 -0
- package/dist/chunk-UXCBLYG6.js.map +1 -0
- package/dist/chunk-VUR4MQMH.js +53 -0
- package/dist/chunk-VUR4MQMH.js.map +1 -0
- package/dist/chunk-WIEKNG4S.js +26 -0
- package/dist/chunk-WIEKNG4S.js.map +1 -0
- package/dist/chunk-WIZ4OLOB.js +23 -0
- package/dist/chunk-WIZ4OLOB.js.map +1 -0
- package/dist/chunk-WJRJBMFN.js +21 -0
- package/dist/chunk-WJRJBMFN.js.map +1 -0
- package/dist/chunk-YUPLJP3F.js +33 -0
- package/dist/chunk-YUPLJP3F.js.map +1 -0
- package/dist/chunk-Z7ITPSUF.js +184 -0
- package/dist/chunk-Z7ITPSUF.js.map +1 -0
- package/dist/chunk-ZC76ALSI.js +75 -0
- package/dist/chunk-ZC76ALSI.js.map +1 -0
- package/dist/code-block-core-xkE94Rk5.d.ts +30 -0
- package/dist/components/accordion.d.ts +9 -0
- package/dist/components/accordion.js +98 -0
- package/dist/components/accordion.js.map +1 -0
- package/dist/components/alert-dialog.d.ts +26 -0
- package/dist/components/alert-dialog.js +341 -0
- package/dist/components/alert-dialog.js.map +1 -0
- package/dist/components/alert.d.ts +13 -0
- package/dist/components/alert.js +76 -0
- package/dist/components/alert.js.map +1 -0
- package/dist/components/aspect-ratio.d.ts +6 -0
- package/dist/components/aspect-ratio.js +12 -0
- package/dist/components/aspect-ratio.js.map +1 -0
- package/dist/components/avatar.d.ts +13 -0
- package/dist/components/avatar.js +19 -0
- package/dist/components/avatar.js.map +1 -0
- package/dist/components/badge.d.ts +12 -0
- package/dist/components/badge.js +11 -0
- package/dist/components/badge.js.map +1 -0
- package/dist/components/breadcrumb.d.ts +13 -0
- package/dist/components/breadcrumb.js +102 -0
- package/dist/components/breadcrumb.js.map +1 -0
- package/dist/components/button-group.d.ts +16 -0
- package/dist/components/button-group.js +15 -0
- package/dist/components/button-group.js.map +1 -0
- package/dist/components/button.d.ts +14 -0
- package/dist/components/button.js +11 -0
- package/dist/components/button.js.map +1 -0
- package/dist/components/calendar.d.ts +14 -0
- package/dist/components/calendar.js +13 -0
- package/dist/components/calendar.js.map +1 -0
- package/dist/components/card.d.ts +13 -0
- package/dist/components/card.js +21 -0
- package/dist/components/card.js.map +1 -0
- package/dist/components/carousel.d.ts +32 -0
- package/dist/components/carousel.js +196 -0
- package/dist/components/carousel.js.map +1 -0
- package/dist/components/chart.d.ts +46 -0
- package/dist/components/chart.js +254 -0
- package/dist/components/chart.js.map +1 -0
- package/dist/components/checkbox.d.ts +6 -0
- package/dist/components/checkbox.js +41 -0
- package/dist/components/checkbox.js.map +1 -0
- package/dist/components/code-block-core.d.ts +3 -0
- package/dist/components/code-block-core.js +13 -0
- package/dist/components/code-block-core.js.map +1 -0
- package/dist/components/code-block-custom.d.ts +20 -0
- package/dist/components/code-block-custom.js +16 -0
- package/dist/components/code-block-custom.js.map +1 -0
- package/dist/components/code-block-shiki.d.ts +13 -0
- package/dist/components/code-block-shiki.js +15 -0
- package/dist/components/code-block-shiki.js.map +1 -0
- package/dist/components/code-block.d.ts +5 -0
- package/dist/components/code-block.js +14 -0
- package/dist/components/code-block.js.map +1 -0
- package/dist/components/collapsible.d.ts +8 -0
- package/dist/components/collapsible.js +24 -0
- package/dist/components/collapsible.js.map +1 -0
- package/dist/components/collection.d.ts +63 -0
- package/dist/components/collection.js +598 -0
- package/dist/components/collection.js.map +1 -0
- package/dist/components/color-dot.d.ts +19 -0
- package/dist/components/color-dot.js +41 -0
- package/dist/components/color-dot.js.map +1 -0
- package/dist/components/color-picker.d.ts +12 -0
- package/dist/components/color-picker.js +142 -0
- package/dist/components/color-picker.js.map +1 -0
- package/dist/components/combobox.d.ts +74 -0
- package/dist/components/combobox.js +610 -0
- package/dist/components/combobox.js.map +1 -0
- package/dist/components/command.d.ts +21 -0
- package/dist/components/command.js +31 -0
- package/dist/components/command.js.map +1 -0
- package/dist/components/date-picker.d.ts +43 -0
- package/dist/components/date-picker.js +235 -0
- package/dist/components/date-picker.js.map +1 -0
- package/dist/components/dialog.d.ts +25 -0
- package/dist/components/dialog.js +31 -0
- package/dist/components/dialog.js.map +1 -0
- package/dist/components/drawer.d.ts +15 -0
- package/dist/components/drawer.js +124 -0
- package/dist/components/drawer.js.map +1 -0
- package/dist/components/dropdown-menu.d.ts +34 -0
- package/dist/components/dropdown-menu.js +248 -0
- package/dist/components/dropdown-menu.js.map +1 -0
- package/dist/components/empty.d.ts +15 -0
- package/dist/components/empty.js +104 -0
- package/dist/components/empty.js.map +1 -0
- package/dist/components/field.d.ts +29 -0
- package/dist/components/field.js +214 -0
- package/dist/components/field.js.map +1 -0
- package/dist/components/format-bytes.d.ts +12 -0
- package/dist/components/format-bytes.js +30 -0
- package/dist/components/format-bytes.js.map +1 -0
- package/dist/components/format-number.d.ts +12 -0
- package/dist/components/format-number.js +30 -0
- package/dist/components/format-number.js.map +1 -0
- package/dist/components/gauge.d.ts +11 -0
- package/dist/components/gauge.js +82 -0
- package/dist/components/gauge.js.map +1 -0
- package/dist/components/hover-card.d.ts +8 -0
- package/dist/components/hover-card.js +45 -0
- package/dist/components/hover-card.js.map +1 -0
- package/dist/components/input-group.d.ts +24 -0
- package/dist/components/input-group.js +23 -0
- package/dist/components/input-group.js.map +1 -0
- package/dist/components/input-otp.d.ts +20 -0
- package/dist/components/input-otp.js +95 -0
- package/dist/components/input-otp.js.map +1 -0
- package/dist/components/input.d.ts +9 -0
- package/dist/components/input.js +9 -0
- package/dist/components/input.js.map +1 -0
- package/dist/components/item.d.ts +27 -0
- package/dist/components/item.js +182 -0
- package/dist/components/item.js.map +1 -0
- package/dist/components/kbd.d.ts +6 -0
- package/dist/components/kbd.js +34 -0
- package/dist/components/kbd.js.map +1 -0
- package/dist/components/label.d.ts +6 -0
- package/dist/components/label.js +9 -0
- package/dist/components/label.js.map +1 -0
- package/dist/components/loading-bar.d.ts +8 -0
- package/dist/components/loading-bar.js +127 -0
- package/dist/components/loading-bar.js.map +1 -0
- package/dist/components/loading-dots.d.ts +5 -0
- package/dist/components/loading-dots.js +45 -0
- package/dist/components/loading-dots.js.map +1 -0
- package/dist/components/main-provider.d.ts +7 -0
- package/dist/components/main-provider.js +12 -0
- package/dist/components/main-provider.js.map +1 -0
- package/dist/components/mark.d.ts +11 -0
- package/dist/components/mark.js +44 -0
- package/dist/components/mark.js.map +1 -0
- package/dist/components/pagination.d.ts +21 -0
- package/dist/components/pagination.js +114 -0
- package/dist/components/pagination.js.map +1 -0
- package/dist/components/popover.d.ts +12 -0
- package/dist/components/popover.js +22 -0
- package/dist/components/popover.js.map +1 -0
- package/dist/components/prev-next-navigation.d.ts +15 -0
- package/dist/components/prev-next-navigation.js +85 -0
- package/dist/components/prev-next-navigation.js.map +1 -0
- package/dist/components/progress.d.ts +6 -0
- package/dist/components/progress.js +38 -0
- package/dist/components/progress.js.map +1 -0
- package/dist/components/radio-group.d.ts +7 -0
- package/dist/components/radio-group.js +57 -0
- package/dist/components/radio-group.js.map +1 -0
- package/dist/components/relative-time.d.ts +16 -0
- package/dist/components/relative-time.js +75 -0
- package/dist/components/relative-time.js.map +1 -0
- package/dist/components/resizable.d.ts +10 -0
- package/dist/components/resizable.js +45 -0
- package/dist/components/resizable.js.map +1 -0
- package/dist/components/scroll-area.d.ts +7 -0
- package/dist/components/scroll-area.js +11 -0
- package/dist/components/scroll-area.js.map +1 -0
- package/dist/components/select.d.ts +20 -0
- package/dist/components/select.js +189 -0
- package/dist/components/select.js.map +1 -0
- package/dist/components/separator.d.ts +6 -0
- package/dist/components/separator.js +9 -0
- package/dist/components/separator.js.map +1 -0
- package/dist/components/sheet.d.ts +16 -0
- package/dist/components/sheet.js +25 -0
- package/dist/components/sheet.js.map +1 -0
- package/dist/components/show-more.d.ts +15 -0
- package/dist/components/show-more.js +79 -0
- package/dist/components/show-more.js.map +1 -0
- package/dist/components/skeleton.d.ts +5 -0
- package/dist/components/skeleton.js +8 -0
- package/dist/components/skeleton.js.map +1 -0
- package/dist/components/slider.d.ts +6 -0
- package/dist/components/slider.js +65 -0
- package/dist/components/slider.js.map +1 -0
- package/dist/components/snippet.d.ts +13 -0
- package/dist/components/snippet.js +135 -0
- package/dist/components/snippet.js.map +1 -0
- package/dist/components/sonner.d.ts +6 -0
- package/dist/components/sonner.js +10 -0
- package/dist/components/sonner.js.map +1 -0
- package/dist/components/spinner.d.ts +5 -0
- package/dist/components/spinner.js +8 -0
- package/dist/components/spinner.js.map +1 -0
- package/dist/components/stat.d.ts +17 -0
- package/dist/components/stat.js +71 -0
- package/dist/components/stat.js.map +1 -0
- package/dist/components/steps.d.ts +17 -0
- package/dist/components/steps.js +133 -0
- package/dist/components/steps.js.map +1 -0
- package/dist/components/switch.d.ts +8 -0
- package/dist/components/switch.js +44 -0
- package/dist/components/switch.js.map +1 -0
- package/dist/components/table.d.ts +12 -0
- package/dist/components/table.js +101 -0
- package/dist/components/table.js.map +1 -0
- package/dist/components/tabs.d.ts +14 -0
- package/dist/components/tabs.js +88 -0
- package/dist/components/tabs.js.map +1 -0
- package/dist/components/textarea.d.ts +5 -0
- package/dist/components/textarea.js +9 -0
- package/dist/components/textarea.js.map +1 -0
- package/dist/components/theme-provider.d.ts +10 -0
- package/dist/components/theme-provider.js +14 -0
- package/dist/components/theme-provider.js.map +1 -0
- package/dist/components/time-picker.d.ts +17 -0
- package/dist/components/time-picker.js +219 -0
- package/dist/components/time-picker.js.map +1 -0
- package/dist/components/timeline.d.ts +17 -0
- package/dist/components/timeline.js +138 -0
- package/dist/components/timeline.js.map +1 -0
- package/dist/components/toggle-group.d.ts +14 -0
- package/dist/components/toggle-group.js +82 -0
- package/dist/components/toggle-group.js.map +1 -0
- package/dist/components/toggle.d.ts +12 -0
- package/dist/components/toggle.js +11 -0
- package/dist/components/toggle.js.map +1 -0
- package/dist/components/tooltip.d.ts +9 -0
- package/dist/components/tooltip.js +15 -0
- package/dist/components/tooltip.js.map +1 -0
- package/dist/components/typography.d.ts +17 -0
- package/dist/components/typography.js +91 -0
- package/dist/components/typography.js.map +1 -0
- package/dist/hooks/use-mobile.d.ts +3 -0
- package/dist/hooks/use-mobile.js +7 -0
- package/dist/hooks/use-mobile.js.map +1 -0
- package/dist/hooks/use-theme.d.ts +3 -0
- package/dist/hooks/use-theme.js +8 -0
- package/dist/hooks/use-theme.js.map +1 -0
- package/dist/index.d.ts +7 -0
- package/dist/index.js +27 -0
- package/dist/index.js.map +1 -0
- package/dist/layouts/center/index.d.ts +18 -0
- package/dist/layouts/center/index.js +73 -0
- package/dist/layouts/center/index.js.map +1 -0
- package/dist/layouts/chat/index.d.ts +42 -0
- package/dist/layouts/chat/index.js +191 -0
- package/dist/layouts/chat/index.js.map +1 -0
- package/dist/layouts/command/index.d.ts +2 -0
- package/dist/layouts/command/index.js +1 -0
- package/dist/layouts/command/index.js.map +1 -0
- package/dist/layouts/panel/index.d.ts +55 -0
- package/dist/layouts/panel/index.js +513 -0
- package/dist/layouts/panel/index.js.map +1 -0
- package/dist/layouts/presentation/index.d.ts +14 -0
- package/dist/layouts/presentation/index.js +100 -0
- package/dist/layouts/presentation/index.js.map +1 -0
- package/dist/layouts/site/index.d.ts +17 -0
- package/dist/layouts/site/index.js +82 -0
- package/dist/layouts/site/index.js.map +1 -0
- package/dist/layouts/window/index.d.ts +223 -0
- package/dist/layouts/window/index.js +127 -0
- package/dist/layouts/window/index.js.map +1 -0
- package/dist/layouts/workbench/index.d.ts +281 -0
- package/dist/layouts/workbench/index.js +2457 -0
- package/dist/layouts/workbench/index.js.map +1 -0
- package/dist/lib/format.d.ts +15 -0
- package/dist/lib/format.js +9 -0
- package/dist/lib/format.js.map +1 -0
- package/dist/lib/theme.d.ts +22 -0
- package/dist/lib/theme.js +25 -0
- package/dist/lib/theme.js.map +1 -0
- package/dist/lib/utils.d.ts +5 -0
- package/dist/lib/utils.js +7 -0
- package/dist/lib/utils.js.map +1 -0
- package/dist/styles/fonts.css +1 -0
- package/dist/styles/globals.css +717 -0
- package/dist/styles/tokens.css +693 -0
- package/package.json +137 -0
|
@@ -0,0 +1,610 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import {
|
|
3
|
+
Command,
|
|
4
|
+
CommandGroup,
|
|
5
|
+
CommandItem,
|
|
6
|
+
CommandList
|
|
7
|
+
} from "../chunk-Z7ITPSUF.js";
|
|
8
|
+
import {
|
|
9
|
+
Popover,
|
|
10
|
+
PopoverAnchor,
|
|
11
|
+
PopoverContent
|
|
12
|
+
} from "../chunk-ZC76ALSI.js";
|
|
13
|
+
import "../chunk-PLZMCJSL.js";
|
|
14
|
+
import "../chunk-UVAI2U6X.js";
|
|
15
|
+
import "../chunk-NE3IVPMO.js";
|
|
16
|
+
import "../chunk-YUPLJP3F.js";
|
|
17
|
+
import "../chunk-TU5CYBB4.js";
|
|
18
|
+
import {
|
|
19
|
+
Badge
|
|
20
|
+
} from "../chunk-VUR4MQMH.js";
|
|
21
|
+
import {
|
|
22
|
+
fieldInvalidClass
|
|
23
|
+
} from "../chunk-O2BG2KSY.js";
|
|
24
|
+
import {
|
|
25
|
+
cn
|
|
26
|
+
} from "../chunk-DN2AEEA2.js";
|
|
27
|
+
|
|
28
|
+
// src/components/combobox.tsx
|
|
29
|
+
import * as React from "react";
|
|
30
|
+
import { Command as CommandPrimitive } from "cmdk";
|
|
31
|
+
import { CheckIcon, ChevronDownIcon, LoaderCircleIcon, SearchIcon, XIcon } from "lucide-react";
|
|
32
|
+
import { Fragment, jsx, jsxs } from "react/jsx-runtime";
|
|
33
|
+
var ComboboxContext = React.createContext(null);
|
|
34
|
+
function useControllableState({
|
|
35
|
+
value,
|
|
36
|
+
defaultValue,
|
|
37
|
+
onChange
|
|
38
|
+
}) {
|
|
39
|
+
const [internalValue, setInternalValue] = React.useState(defaultValue);
|
|
40
|
+
const isControlled = value !== void 0;
|
|
41
|
+
const currentValue = isControlled ? value : internalValue;
|
|
42
|
+
const setValue = React.useCallback(
|
|
43
|
+
(nextValue) => {
|
|
44
|
+
if (!isControlled) {
|
|
45
|
+
setInternalValue(nextValue);
|
|
46
|
+
}
|
|
47
|
+
onChange?.(nextValue);
|
|
48
|
+
},
|
|
49
|
+
[isControlled, onChange]
|
|
50
|
+
);
|
|
51
|
+
return [currentValue, setValue];
|
|
52
|
+
}
|
|
53
|
+
function useComboboxContext(componentName) {
|
|
54
|
+
const context = React.useContext(ComboboxContext);
|
|
55
|
+
if (!context) {
|
|
56
|
+
throw new Error(`${componentName} must be used within <Combobox>.`);
|
|
57
|
+
}
|
|
58
|
+
return context;
|
|
59
|
+
}
|
|
60
|
+
function Combobox(props) {
|
|
61
|
+
const {
|
|
62
|
+
options,
|
|
63
|
+
query: queryProp,
|
|
64
|
+
defaultQuery = "",
|
|
65
|
+
onQueryChange,
|
|
66
|
+
open: openProp,
|
|
67
|
+
defaultOpen = false,
|
|
68
|
+
onOpenChange,
|
|
69
|
+
creatable = false,
|
|
70
|
+
loading = false,
|
|
71
|
+
disabled = false,
|
|
72
|
+
invalid = false,
|
|
73
|
+
placeholder = "Search\u2026",
|
|
74
|
+
emptyMessage = "No results found.",
|
|
75
|
+
loadingMessage = "Loading\u2026",
|
|
76
|
+
createLabel = (query2) => `Create "${query2}"`,
|
|
77
|
+
onCreateOption,
|
|
78
|
+
id,
|
|
79
|
+
className,
|
|
80
|
+
children,
|
|
81
|
+
multiple: multipleProp,
|
|
82
|
+
...divProps
|
|
83
|
+
} = props;
|
|
84
|
+
const inputId = React.useId();
|
|
85
|
+
const listId = React.useId();
|
|
86
|
+
const multiple = multipleProp === true;
|
|
87
|
+
const singleValueProp = props.multiple === true ? void 0 : props.value;
|
|
88
|
+
const singleDefaultValue = props.multiple === true ? void 0 : props.defaultValue;
|
|
89
|
+
const singleOnValueChange = props.multiple === true ? void 0 : props.onValueChange;
|
|
90
|
+
const multiValueProp = props.multiple === true ? props.value : void 0;
|
|
91
|
+
const multiDefaultValue = props.multiple === true ? props.defaultValue ?? [] : [];
|
|
92
|
+
const multiOnValueChange = props.multiple === true ? props.onValueChange : void 0;
|
|
93
|
+
const [open = defaultOpen, setOpenState] = useControllableState({
|
|
94
|
+
value: openProp,
|
|
95
|
+
defaultValue: defaultOpen,
|
|
96
|
+
onChange: onOpenChange
|
|
97
|
+
});
|
|
98
|
+
const [query = defaultQuery, setQueryState] = useControllableState({
|
|
99
|
+
value: queryProp,
|
|
100
|
+
defaultValue: defaultQuery,
|
|
101
|
+
onChange: onQueryChange
|
|
102
|
+
});
|
|
103
|
+
const [singleValue = singleDefaultValue, setSingleValue] = useControllableState({
|
|
104
|
+
value: singleValueProp,
|
|
105
|
+
defaultValue: singleDefaultValue,
|
|
106
|
+
onChange: singleOnValueChange
|
|
107
|
+
});
|
|
108
|
+
const [multiValue = multiDefaultValue, setMultiValue] = useControllableState({
|
|
109
|
+
value: multiValueProp,
|
|
110
|
+
defaultValue: multiDefaultValue,
|
|
111
|
+
onChange: multiOnValueChange
|
|
112
|
+
});
|
|
113
|
+
const triggerRef = React.useRef(null);
|
|
114
|
+
const inputRef = React.useRef(null);
|
|
115
|
+
const [contentWidth, setContentWidth] = React.useState();
|
|
116
|
+
const [createdOptions, setCreatedOptions] = React.useState([]);
|
|
117
|
+
React.useEffect(() => {
|
|
118
|
+
const trigger = triggerRef.current;
|
|
119
|
+
if (!trigger) {
|
|
120
|
+
return;
|
|
121
|
+
}
|
|
122
|
+
const update = () => {
|
|
123
|
+
setContentWidth(trigger.offsetWidth);
|
|
124
|
+
};
|
|
125
|
+
update();
|
|
126
|
+
const observer = new ResizeObserver(update);
|
|
127
|
+
observer.observe(trigger);
|
|
128
|
+
return () => observer.disconnect();
|
|
129
|
+
}, []);
|
|
130
|
+
const allOptions = React.useMemo(() => {
|
|
131
|
+
const map = /* @__PURE__ */ new Map();
|
|
132
|
+
createdOptions.forEach((option) => {
|
|
133
|
+
map.set(option.value, option);
|
|
134
|
+
});
|
|
135
|
+
options.forEach((option) => {
|
|
136
|
+
map.set(option.value, option);
|
|
137
|
+
});
|
|
138
|
+
return Array.from(map.values());
|
|
139
|
+
}, [createdOptions, options]);
|
|
140
|
+
const selectedValues = React.useMemo(
|
|
141
|
+
() => multiple ? multiValue : singleValue ? [singleValue] : [],
|
|
142
|
+
[multiple, multiValue, singleValue]
|
|
143
|
+
);
|
|
144
|
+
const normalizedQuery = query.trim().toLowerCase();
|
|
145
|
+
const filteredOptions = React.useMemo(() => {
|
|
146
|
+
if (!normalizedQuery) {
|
|
147
|
+
return allOptions;
|
|
148
|
+
}
|
|
149
|
+
return allOptions.filter((option) => {
|
|
150
|
+
const terms = [option.label, option.value, ...option.keywords ?? []];
|
|
151
|
+
return terms.some((term) => term.toLowerCase().includes(normalizedQuery));
|
|
152
|
+
});
|
|
153
|
+
}, [allOptions, normalizedQuery]);
|
|
154
|
+
const filteredGroups = React.useMemo(() => {
|
|
155
|
+
const groups = /* @__PURE__ */ new Map();
|
|
156
|
+
filteredOptions.forEach((option) => {
|
|
157
|
+
const groupKey = option.group ?? "";
|
|
158
|
+
const existingGroup = groups.get(groupKey);
|
|
159
|
+
if (existingGroup) {
|
|
160
|
+
existingGroup.options.push(option);
|
|
161
|
+
return;
|
|
162
|
+
}
|
|
163
|
+
groups.set(groupKey, {
|
|
164
|
+
group: option.group,
|
|
165
|
+
options: [option]
|
|
166
|
+
});
|
|
167
|
+
});
|
|
168
|
+
return Array.from(groups.values());
|
|
169
|
+
}, [filteredOptions]);
|
|
170
|
+
const selectedOptions = React.useMemo(() => {
|
|
171
|
+
const optionMap = new Map(allOptions.map((option) => [option.value, option]));
|
|
172
|
+
return selectedValues.map((value) => optionMap.get(value) ?? { value, label: value });
|
|
173
|
+
}, [allOptions, selectedValues]);
|
|
174
|
+
const selectedSingleLabel = !multiple ? selectedOptions[0]?.label : void 0;
|
|
175
|
+
const inputValue = multiple ? query : open ? query : query || selectedSingleLabel || "";
|
|
176
|
+
const hasSelection = selectedValues.length > 0;
|
|
177
|
+
const hasQuery = query.trim().length > 0;
|
|
178
|
+
const hasExactOption = React.useMemo(
|
|
179
|
+
() => allOptions.some((option) => {
|
|
180
|
+
const optionValue = option.value.trim().toLowerCase();
|
|
181
|
+
const optionLabel = option.label.trim().toLowerCase();
|
|
182
|
+
return optionValue === normalizedQuery || optionLabel === normalizedQuery;
|
|
183
|
+
}),
|
|
184
|
+
[allOptions, normalizedQuery]
|
|
185
|
+
);
|
|
186
|
+
const showCreateOption = creatable && hasQuery && !hasExactOption && !loading;
|
|
187
|
+
const createOptionLabel = hasQuery ? createLabel(query.trim()) : null;
|
|
188
|
+
const setOpen = React.useCallback(
|
|
189
|
+
(nextOpen) => {
|
|
190
|
+
setOpenState(nextOpen);
|
|
191
|
+
if (!nextOpen) {
|
|
192
|
+
setQueryState("");
|
|
193
|
+
}
|
|
194
|
+
},
|
|
195
|
+
[setOpenState, setQueryState]
|
|
196
|
+
);
|
|
197
|
+
const setQuery = React.useCallback(
|
|
198
|
+
(nextQuery) => {
|
|
199
|
+
if (disabled) {
|
|
200
|
+
return;
|
|
201
|
+
}
|
|
202
|
+
if (!open) {
|
|
203
|
+
setOpenState(true);
|
|
204
|
+
}
|
|
205
|
+
setQueryState(nextQuery);
|
|
206
|
+
},
|
|
207
|
+
[disabled, open, setOpenState, setQueryState]
|
|
208
|
+
);
|
|
209
|
+
const removeValue = React.useCallback(
|
|
210
|
+
(valueToRemove) => {
|
|
211
|
+
if (disabled) {
|
|
212
|
+
return;
|
|
213
|
+
}
|
|
214
|
+
if (multiple) {
|
|
215
|
+
setMultiValue(selectedValues.filter((value) => value !== valueToRemove));
|
|
216
|
+
return;
|
|
217
|
+
}
|
|
218
|
+
if (singleValue === valueToRemove) {
|
|
219
|
+
setSingleValue(void 0);
|
|
220
|
+
}
|
|
221
|
+
},
|
|
222
|
+
[disabled, multiple, selectedValues, setMultiValue, setSingleValue, singleValue]
|
|
223
|
+
);
|
|
224
|
+
const clear = React.useCallback(() => {
|
|
225
|
+
if (disabled) {
|
|
226
|
+
return;
|
|
227
|
+
}
|
|
228
|
+
setQueryState("");
|
|
229
|
+
if (multiple) {
|
|
230
|
+
setMultiValue([]);
|
|
231
|
+
return;
|
|
232
|
+
}
|
|
233
|
+
setSingleValue(void 0);
|
|
234
|
+
}, [disabled, multiple, setMultiValue, setQueryState, setSingleValue]);
|
|
235
|
+
const selectOption = React.useCallback(
|
|
236
|
+
(option) => {
|
|
237
|
+
if (disabled || option.disabled) {
|
|
238
|
+
return;
|
|
239
|
+
}
|
|
240
|
+
if (multiple) {
|
|
241
|
+
const nextValues = selectedValues.includes(option.value) ? selectedValues.filter((value) => value !== option.value) : [...selectedValues, option.value];
|
|
242
|
+
setMultiValue(nextValues);
|
|
243
|
+
setQueryState("");
|
|
244
|
+
setOpenState(true);
|
|
245
|
+
inputRef.current?.focus();
|
|
246
|
+
return;
|
|
247
|
+
}
|
|
248
|
+
setSingleValue(option.value);
|
|
249
|
+
setQueryState("");
|
|
250
|
+
setOpenState(false);
|
|
251
|
+
},
|
|
252
|
+
[
|
|
253
|
+
disabled,
|
|
254
|
+
multiple,
|
|
255
|
+
selectedValues,
|
|
256
|
+
setMultiValue,
|
|
257
|
+
setOpenState,
|
|
258
|
+
setQueryState,
|
|
259
|
+
setSingleValue
|
|
260
|
+
]
|
|
261
|
+
);
|
|
262
|
+
const createOption = React.useCallback(() => {
|
|
263
|
+
const nextValue = query.trim();
|
|
264
|
+
if (!nextValue || disabled) {
|
|
265
|
+
return;
|
|
266
|
+
}
|
|
267
|
+
const createdOption = {
|
|
268
|
+
value: nextValue,
|
|
269
|
+
label: nextValue
|
|
270
|
+
};
|
|
271
|
+
setCreatedOptions((currentOptions) => {
|
|
272
|
+
if (currentOptions.some((option) => option.value === nextValue)) {
|
|
273
|
+
return currentOptions;
|
|
274
|
+
}
|
|
275
|
+
return [...currentOptions, createdOption];
|
|
276
|
+
});
|
|
277
|
+
onCreateOption?.(nextValue);
|
|
278
|
+
selectOption(createdOption);
|
|
279
|
+
}, [disabled, onCreateOption, query, selectOption]);
|
|
280
|
+
const onInputKeyDown = React.useCallback(
|
|
281
|
+
(event) => {
|
|
282
|
+
if (disabled) {
|
|
283
|
+
return;
|
|
284
|
+
}
|
|
285
|
+
if (event.key === "Backspace" && !query && multiple && selectedValues.length > 0) {
|
|
286
|
+
event.preventDefault();
|
|
287
|
+
const lastValue = selectedValues[selectedValues.length - 1];
|
|
288
|
+
if (lastValue) {
|
|
289
|
+
removeValue(lastValue);
|
|
290
|
+
}
|
|
291
|
+
}
|
|
292
|
+
if (event.key === "Escape") {
|
|
293
|
+
event.preventDefault();
|
|
294
|
+
setOpen(false);
|
|
295
|
+
}
|
|
296
|
+
},
|
|
297
|
+
[disabled, multiple, query, removeValue, selectedValues, setOpen]
|
|
298
|
+
);
|
|
299
|
+
const contextValue = {
|
|
300
|
+
inputId: id ?? inputId,
|
|
301
|
+
listId,
|
|
302
|
+
open,
|
|
303
|
+
setOpen,
|
|
304
|
+
query,
|
|
305
|
+
setQuery,
|
|
306
|
+
inputValue,
|
|
307
|
+
multiple,
|
|
308
|
+
creatable,
|
|
309
|
+
disabled,
|
|
310
|
+
invalid,
|
|
311
|
+
loading,
|
|
312
|
+
placeholder,
|
|
313
|
+
emptyMessage,
|
|
314
|
+
loadingMessage,
|
|
315
|
+
createOptionLabel,
|
|
316
|
+
showCreateOption,
|
|
317
|
+
selectedValues,
|
|
318
|
+
selectedOptions,
|
|
319
|
+
filteredGroups,
|
|
320
|
+
hasSelection,
|
|
321
|
+
hasQuery,
|
|
322
|
+
triggerRef,
|
|
323
|
+
inputRef,
|
|
324
|
+
contentWidth,
|
|
325
|
+
clear,
|
|
326
|
+
removeValue,
|
|
327
|
+
selectOption,
|
|
328
|
+
createOption,
|
|
329
|
+
onInputKeyDown
|
|
330
|
+
};
|
|
331
|
+
return /* @__PURE__ */ jsx(ComboboxContext.Provider, { value: contextValue, children: /* @__PURE__ */ jsx(
|
|
332
|
+
Command,
|
|
333
|
+
{
|
|
334
|
+
shouldFilter: false,
|
|
335
|
+
loop: true,
|
|
336
|
+
className: cn("overflow-visible rounded-none bg-transparent p-0", className),
|
|
337
|
+
children: /* @__PURE__ */ jsx(Popover, { open, onOpenChange: setOpen, children: /* @__PURE__ */ jsx("div", { "data-slot": "combobox", ...divProps, children: children ?? /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
338
|
+
/* @__PURE__ */ jsxs(ComboboxTrigger, { children: [
|
|
339
|
+
/* @__PURE__ */ jsx(ComboboxTags, {}),
|
|
340
|
+
/* @__PURE__ */ jsx(ComboboxInput, {}),
|
|
341
|
+
/* @__PURE__ */ jsx(ComboboxClear, {})
|
|
342
|
+
] }),
|
|
343
|
+
/* @__PURE__ */ jsx(ComboboxContent, { children: /* @__PURE__ */ jsx(ComboboxList, {}) })
|
|
344
|
+
] }) }) })
|
|
345
|
+
}
|
|
346
|
+
) });
|
|
347
|
+
}
|
|
348
|
+
function ComboboxTrigger({
|
|
349
|
+
className,
|
|
350
|
+
children,
|
|
351
|
+
leadingIcon = /* @__PURE__ */ jsx(SearchIcon, { className: "text-field-placeholder size-4 shrink-0" }),
|
|
352
|
+
...props
|
|
353
|
+
}) {
|
|
354
|
+
const context = useComboboxContext("ComboboxTrigger");
|
|
355
|
+
return /* @__PURE__ */ jsx(PopoverAnchor, { asChild: true, children: /* @__PURE__ */ jsxs(
|
|
356
|
+
"div",
|
|
357
|
+
{
|
|
358
|
+
ref: context.triggerRef,
|
|
359
|
+
"data-slot": "combobox-trigger",
|
|
360
|
+
"aria-disabled": context.disabled || void 0,
|
|
361
|
+
"aria-invalid": context.invalid || void 0,
|
|
362
|
+
className: cn(
|
|
363
|
+
"border-field-border bg-field-background text-field-text focus-within:border-field-border-focus focus-within:ring-focus-ring aria-disabled:bg-field-background-disabled flex min-h-8 w-full cursor-text items-center gap-1 rounded-lg border px-2 py-1 transition-colors focus-within:ring-3 aria-disabled:cursor-not-allowed aria-disabled:opacity-50",
|
|
364
|
+
fieldInvalidClass,
|
|
365
|
+
className
|
|
366
|
+
),
|
|
367
|
+
onMouseDown: (event) => {
|
|
368
|
+
if (context.disabled) {
|
|
369
|
+
return;
|
|
370
|
+
}
|
|
371
|
+
if (event.target instanceof HTMLElement && event.target.closest("[data-combobox-interactive]")) {
|
|
372
|
+
return;
|
|
373
|
+
}
|
|
374
|
+
event.preventDefault();
|
|
375
|
+
context.setOpen(true);
|
|
376
|
+
context.inputRef.current?.focus();
|
|
377
|
+
},
|
|
378
|
+
...props,
|
|
379
|
+
children: [
|
|
380
|
+
leadingIcon,
|
|
381
|
+
children,
|
|
382
|
+
/* @__PURE__ */ jsx(ChevronDownIcon, { className: "text-field-placeholder ml-auto size-4 shrink-0" })
|
|
383
|
+
]
|
|
384
|
+
}
|
|
385
|
+
) });
|
|
386
|
+
}
|
|
387
|
+
function ComboboxInput({
|
|
388
|
+
className,
|
|
389
|
+
onFocus,
|
|
390
|
+
onKeyDown,
|
|
391
|
+
...props
|
|
392
|
+
}) {
|
|
393
|
+
const context = useComboboxContext("ComboboxInput");
|
|
394
|
+
return /* @__PURE__ */ jsx(
|
|
395
|
+
CommandPrimitive.Input,
|
|
396
|
+
{
|
|
397
|
+
ref: context.inputRef,
|
|
398
|
+
id: context.inputId,
|
|
399
|
+
"data-slot": "combobox-input",
|
|
400
|
+
"aria-controls": context.listId,
|
|
401
|
+
"aria-expanded": context.open,
|
|
402
|
+
"aria-autocomplete": "list",
|
|
403
|
+
"aria-invalid": context.invalid || void 0,
|
|
404
|
+
disabled: context.disabled,
|
|
405
|
+
placeholder: !context.multiple && context.selectedOptions[0] && !context.open ? void 0 : context.placeholder,
|
|
406
|
+
value: context.inputValue,
|
|
407
|
+
onFocus: (event) => {
|
|
408
|
+
context.setOpen(true);
|
|
409
|
+
onFocus?.(event);
|
|
410
|
+
},
|
|
411
|
+
onValueChange: context.setQuery,
|
|
412
|
+
onKeyDown: (event) => {
|
|
413
|
+
context.onInputKeyDown(event);
|
|
414
|
+
onKeyDown?.(event);
|
|
415
|
+
},
|
|
416
|
+
className: cn(
|
|
417
|
+
"placeholder:text-field-placeholder min-w-[4ch] flex-1 bg-transparent text-sm outline-none disabled:cursor-not-allowed",
|
|
418
|
+
className
|
|
419
|
+
),
|
|
420
|
+
...props
|
|
421
|
+
}
|
|
422
|
+
);
|
|
423
|
+
}
|
|
424
|
+
function ComboboxContent({
|
|
425
|
+
className,
|
|
426
|
+
style,
|
|
427
|
+
children,
|
|
428
|
+
onOpenAutoFocus,
|
|
429
|
+
...props
|
|
430
|
+
}) {
|
|
431
|
+
const context = useComboboxContext("ComboboxContent");
|
|
432
|
+
return /* @__PURE__ */ jsx(
|
|
433
|
+
PopoverContent,
|
|
434
|
+
{
|
|
435
|
+
"data-slot": "combobox-content",
|
|
436
|
+
align: "start",
|
|
437
|
+
sideOffset: 4,
|
|
438
|
+
className: cn("gap-0 p-1", className),
|
|
439
|
+
style: {
|
|
440
|
+
width: context.contentWidth ? `${context.contentWidth}px` : void 0,
|
|
441
|
+
...style
|
|
442
|
+
},
|
|
443
|
+
onOpenAutoFocus: (event) => {
|
|
444
|
+
event.preventDefault();
|
|
445
|
+
onOpenAutoFocus?.(event);
|
|
446
|
+
},
|
|
447
|
+
...props,
|
|
448
|
+
children
|
|
449
|
+
}
|
|
450
|
+
);
|
|
451
|
+
}
|
|
452
|
+
function ComboboxList({
|
|
453
|
+
className,
|
|
454
|
+
children,
|
|
455
|
+
...props
|
|
456
|
+
}) {
|
|
457
|
+
const context = useComboboxContext("ComboboxList");
|
|
458
|
+
return /* @__PURE__ */ jsx(CommandList, { id: context.listId, className: cn("max-h-64", className), ...props, children: children ? children : context.loading ? /* @__PURE__ */ jsx(ComboboxLoading, {}) : context.filteredGroups.length > 0 ? /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
459
|
+
context.filteredGroups.map(
|
|
460
|
+
(group) => group.group ? /* @__PURE__ */ jsx(ComboboxGroup, { heading: group.group, children: group.options.map((option) => /* @__PURE__ */ jsx(ComboboxItem, { option }, option.value)) }, group.group) : group.options.map((option) => /* @__PURE__ */ jsx(ComboboxItem, { option }, option.value))
|
|
461
|
+
),
|
|
462
|
+
context.showCreateOption ? /* @__PURE__ */ jsx(
|
|
463
|
+
CommandItem,
|
|
464
|
+
{
|
|
465
|
+
value: `__create__${context.query}`,
|
|
466
|
+
onSelect: context.createOption,
|
|
467
|
+
className: "mt-1",
|
|
468
|
+
children: context.createOptionLabel
|
|
469
|
+
}
|
|
470
|
+
) : null
|
|
471
|
+
] }) : context.showCreateOption ? /* @__PURE__ */ jsx(CommandItem, { value: `__create__${context.query}`, onSelect: context.createOption, children: context.createOptionLabel }) : /* @__PURE__ */ jsx(ComboboxEmpty, {}) });
|
|
472
|
+
}
|
|
473
|
+
function ComboboxGroup({
|
|
474
|
+
className,
|
|
475
|
+
children,
|
|
476
|
+
...props
|
|
477
|
+
}) {
|
|
478
|
+
return /* @__PURE__ */ jsx(CommandGroup, { className: cn("overflow-hidden", className), ...props, children });
|
|
479
|
+
}
|
|
480
|
+
function ComboboxItem({
|
|
481
|
+
option,
|
|
482
|
+
className,
|
|
483
|
+
children,
|
|
484
|
+
...props
|
|
485
|
+
}) {
|
|
486
|
+
const context = useComboboxContext("ComboboxItem");
|
|
487
|
+
const isSelected = context.selectedValues.includes(option.value);
|
|
488
|
+
return /* @__PURE__ */ jsxs(
|
|
489
|
+
CommandItem,
|
|
490
|
+
{
|
|
491
|
+
"data-checked": isSelected || void 0,
|
|
492
|
+
value: option.value,
|
|
493
|
+
...context.disabled || option.disabled ? { disabled: true } : {},
|
|
494
|
+
onSelect: () => context.selectOption(option),
|
|
495
|
+
className,
|
|
496
|
+
...props,
|
|
497
|
+
children: [
|
|
498
|
+
/* @__PURE__ */ jsx("span", { className: "truncate", children: children ?? option.label }),
|
|
499
|
+
!isSelected ? /* @__PURE__ */ jsx(CheckIcon, { className: "ml-auto size-4 opacity-0" }) : null
|
|
500
|
+
]
|
|
501
|
+
}
|
|
502
|
+
);
|
|
503
|
+
}
|
|
504
|
+
function ComboboxEmpty({ className, children, ...props }) {
|
|
505
|
+
const context = useComboboxContext("ComboboxEmpty");
|
|
506
|
+
return /* @__PURE__ */ jsx(
|
|
507
|
+
"div",
|
|
508
|
+
{
|
|
509
|
+
"data-slot": "combobox-empty",
|
|
510
|
+
className: cn("text-text-muted py-6 text-center text-sm", className),
|
|
511
|
+
...props,
|
|
512
|
+
children: children ?? context.emptyMessage
|
|
513
|
+
}
|
|
514
|
+
);
|
|
515
|
+
}
|
|
516
|
+
function ComboboxLoading({ className, children, ...props }) {
|
|
517
|
+
const context = useComboboxContext("ComboboxLoading");
|
|
518
|
+
return /* @__PURE__ */ jsxs(
|
|
519
|
+
"div",
|
|
520
|
+
{
|
|
521
|
+
"data-slot": "combobox-loading",
|
|
522
|
+
className: cn("text-text-muted flex items-center gap-2 px-2 py-3 text-sm", className),
|
|
523
|
+
...props,
|
|
524
|
+
children: [
|
|
525
|
+
/* @__PURE__ */ jsx(LoaderCircleIcon, { className: "size-4 animate-spin" }),
|
|
526
|
+
/* @__PURE__ */ jsx("span", { children: children ?? context.loadingMessage })
|
|
527
|
+
]
|
|
528
|
+
}
|
|
529
|
+
);
|
|
530
|
+
}
|
|
531
|
+
function ComboboxTags({ className, children, ...props }) {
|
|
532
|
+
const context = useComboboxContext("ComboboxTags");
|
|
533
|
+
if (!context.multiple || context.selectedOptions.length === 0) {
|
|
534
|
+
return children ? /* @__PURE__ */ jsx("div", { "data-slot": "combobox-tags", className, ...props, children }) : null;
|
|
535
|
+
}
|
|
536
|
+
return /* @__PURE__ */ jsx(
|
|
537
|
+
"div",
|
|
538
|
+
{
|
|
539
|
+
"data-slot": "combobox-tags",
|
|
540
|
+
className: cn("flex flex-wrap items-center gap-1", className),
|
|
541
|
+
...props,
|
|
542
|
+
children: children ?? context.selectedOptions.map((option) => /* @__PURE__ */ jsx(ComboboxTag, { option }, option.value))
|
|
543
|
+
}
|
|
544
|
+
);
|
|
545
|
+
}
|
|
546
|
+
function ComboboxTag({
|
|
547
|
+
option,
|
|
548
|
+
className,
|
|
549
|
+
children,
|
|
550
|
+
...props
|
|
551
|
+
}) {
|
|
552
|
+
const context = useComboboxContext("ComboboxTag");
|
|
553
|
+
return /* @__PURE__ */ jsxs(Badge, { variant: "normal", className: cn("gap-1 pr-1", className), ...props, children: [
|
|
554
|
+
/* @__PURE__ */ jsx("span", { className: "truncate", children: children ?? option.label }),
|
|
555
|
+
/* @__PURE__ */ jsx(
|
|
556
|
+
"button",
|
|
557
|
+
{
|
|
558
|
+
type: "button",
|
|
559
|
+
"data-combobox-interactive": true,
|
|
560
|
+
className: "hover:bg-background-modifier-hover rounded-full p-0.5 transition-colors",
|
|
561
|
+
onMouseDown: (event) => event.preventDefault(),
|
|
562
|
+
onClick: () => context.removeValue(option.value),
|
|
563
|
+
"aria-label": `Remove ${option.label}`,
|
|
564
|
+
children: /* @__PURE__ */ jsx(XIcon, { className: "size-3" })
|
|
565
|
+
}
|
|
566
|
+
)
|
|
567
|
+
] });
|
|
568
|
+
}
|
|
569
|
+
function ComboboxClear({
|
|
570
|
+
className,
|
|
571
|
+
children,
|
|
572
|
+
...props
|
|
573
|
+
}) {
|
|
574
|
+
const context = useComboboxContext("ComboboxClear");
|
|
575
|
+
if (!context.hasSelection && !context.hasQuery) {
|
|
576
|
+
return null;
|
|
577
|
+
}
|
|
578
|
+
return /* @__PURE__ */ jsx(
|
|
579
|
+
"button",
|
|
580
|
+
{
|
|
581
|
+
type: "button",
|
|
582
|
+
"data-slot": "combobox-clear",
|
|
583
|
+
"data-combobox-interactive": true,
|
|
584
|
+
className: cn(
|
|
585
|
+
"text-field-placeholder hover:bg-background-modifier-hover hover:text-text-normal ml-1 inline-flex size-5 shrink-0 items-center justify-center rounded-full transition-colors",
|
|
586
|
+
className
|
|
587
|
+
),
|
|
588
|
+
onMouseDown: (event) => event.preventDefault(),
|
|
589
|
+
onClick: context.clear,
|
|
590
|
+
"aria-label": "Clear selection",
|
|
591
|
+
...props,
|
|
592
|
+
children: children ?? /* @__PURE__ */ jsx(XIcon, { className: "size-3.5" })
|
|
593
|
+
}
|
|
594
|
+
);
|
|
595
|
+
}
|
|
596
|
+
export {
|
|
597
|
+
Combobox,
|
|
598
|
+
ComboboxClear,
|
|
599
|
+
ComboboxContent,
|
|
600
|
+
ComboboxEmpty,
|
|
601
|
+
ComboboxGroup,
|
|
602
|
+
ComboboxInput,
|
|
603
|
+
ComboboxItem,
|
|
604
|
+
ComboboxList,
|
|
605
|
+
ComboboxLoading,
|
|
606
|
+
ComboboxTag,
|
|
607
|
+
ComboboxTags,
|
|
608
|
+
ComboboxTrigger
|
|
609
|
+
};
|
|
610
|
+
//# sourceMappingURL=combobox.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../src/components/combobox.tsx"],"sourcesContent":["\"use client\"\n\nimport * as React from \"react\"\n\nimport { Command as CommandPrimitive } from \"cmdk\"\nimport { CheckIcon, ChevronDownIcon, LoaderCircleIcon, SearchIcon, XIcon } from \"lucide-react\"\n\nimport { Badge } from \"@hyunsdev/ui/components/badge\"\nimport {\n Command as CommandRoot,\n CommandGroup as CommandGroupPrimitive,\n CommandItem as CommandItemPrimitive,\n CommandList as CommandListPrimitive,\n} from \"@hyunsdev/ui/components/command\"\nimport { Popover, PopoverAnchor, PopoverContent } from \"@hyunsdev/ui/components/popover\"\nimport { cn } from \"@hyunsdev/ui/lib/utils\"\n\nimport { fieldInvalidClass } from \"./_styles\"\n\nexport type ComboboxOption = {\n value: string\n label: string\n keywords?: readonly string[]\n disabled?: boolean\n group?: string | undefined\n}\n\ntype ComboboxSharedProps = {\n options: readonly ComboboxOption[]\n query?: string | undefined\n defaultQuery?: string | undefined\n onQueryChange?: (query: string) => void\n open?: boolean | undefined\n defaultOpen?: boolean | undefined\n onOpenChange?: (open: boolean) => void\n creatable?: boolean\n loading?: boolean\n disabled?: boolean\n invalid?: boolean\n placeholder?: string\n emptyMessage?: React.ReactNode\n loadingMessage?: React.ReactNode\n createLabel?: (query: string) => React.ReactNode\n onCreateOption?: (query: string) => void\n id?: string\n className?: string\n children?: React.ReactNode\n}\n\ntype SingleComboboxProps = ComboboxSharedProps & {\n multiple?: false\n value?: string | undefined\n defaultValue?: string | undefined\n onValueChange?: (value: string | undefined) => void\n}\n\ntype MultiComboboxProps = ComboboxSharedProps & {\n multiple: true\n value?: string[] | undefined\n defaultValue?: string[] | undefined\n onValueChange?: (value: string[]) => void\n}\n\nexport type ComboboxProps = SingleComboboxProps | MultiComboboxProps\n\ntype ComboboxContextValue = {\n inputId: string\n listId: string\n open: boolean\n setOpen: (open: boolean) => void\n query: string\n setQuery: (query: string) => void\n inputValue: string\n multiple: boolean\n creatable: boolean\n disabled: boolean\n invalid: boolean\n loading: boolean\n placeholder?: string\n emptyMessage: React.ReactNode\n loadingMessage: React.ReactNode\n createOptionLabel: React.ReactNode\n showCreateOption: boolean\n selectedValues: string[]\n selectedOptions: ComboboxOption[]\n filteredGroups: Array<{ group?: string | undefined; options: ComboboxOption[] }>\n hasSelection: boolean\n hasQuery: boolean\n triggerRef: React.RefObject<HTMLDivElement | null>\n inputRef: React.RefObject<HTMLInputElement | null>\n contentWidth?: number | undefined\n clear: () => void\n removeValue: (value: string) => void\n selectOption: (option: ComboboxOption) => void\n createOption: () => void\n onInputKeyDown: (event: React.KeyboardEvent<HTMLInputElement>) => void\n}\n\nconst ComboboxContext = React.createContext<ComboboxContextValue | null>(null)\n\nfunction useControllableState<T>({\n value,\n defaultValue,\n onChange,\n}: {\n value: T | undefined\n defaultValue: T\n onChange?: ((value: T) => void) | undefined\n}) {\n const [internalValue, setInternalValue] = React.useState(defaultValue)\n const isControlled = value !== undefined\n const currentValue = isControlled ? value : internalValue\n\n const setValue = React.useCallback(\n (nextValue: T) => {\n if (!isControlled) {\n setInternalValue(nextValue)\n }\n\n onChange?.(nextValue)\n },\n [isControlled, onChange],\n )\n\n return [currentValue, setValue] as const\n}\n\nfunction useComboboxContext(componentName: string) {\n const context = React.useContext(ComboboxContext)\n\n if (!context) {\n throw new Error(`${componentName} must be used within <Combobox>.`)\n }\n\n return context\n}\n\nfunction Combobox(props: ComboboxProps & Omit<React.ComponentProps<\"div\">, keyof ComboboxProps>) {\n const {\n options,\n query: queryProp,\n defaultQuery = \"\",\n onQueryChange,\n open: openProp,\n defaultOpen = false,\n onOpenChange,\n creatable = false,\n loading = false,\n disabled = false,\n invalid = false,\n placeholder = \"Search…\",\n emptyMessage = \"No results found.\",\n loadingMessage = \"Loading…\",\n createLabel = (query) => `Create \"${query}\"`,\n onCreateOption,\n id,\n className,\n children,\n multiple: multipleProp,\n ...divProps\n } = props\n const inputId = React.useId()\n const listId = React.useId()\n const multiple = multipleProp === true\n const singleValueProp = props.multiple === true ? undefined : props.value\n const singleDefaultValue = props.multiple === true ? undefined : props.defaultValue\n const singleOnValueChange = props.multiple === true ? undefined : props.onValueChange\n const multiValueProp = props.multiple === true ? props.value : undefined\n const multiDefaultValue = props.multiple === true ? (props.defaultValue ?? []) : []\n const multiOnValueChange = props.multiple === true ? props.onValueChange : undefined\n const [open = defaultOpen, setOpenState] = useControllableState<boolean>({\n value: openProp,\n defaultValue: defaultOpen,\n onChange: onOpenChange,\n })\n const [query = defaultQuery, setQueryState] = useControllableState<string>({\n value: queryProp,\n defaultValue: defaultQuery,\n onChange: onQueryChange,\n })\n\n const [singleValue = singleDefaultValue, setSingleValue] = useControllableState<\n string | undefined\n >({\n value: singleValueProp,\n defaultValue: singleDefaultValue,\n onChange: singleOnValueChange,\n })\n const [multiValue = multiDefaultValue, setMultiValue] = useControllableState<string[]>({\n value: multiValueProp,\n defaultValue: multiDefaultValue,\n onChange: multiOnValueChange,\n })\n\n const triggerRef = React.useRef<HTMLDivElement>(null)\n const inputRef = React.useRef<HTMLInputElement>(null)\n const [contentWidth, setContentWidth] = React.useState<number>()\n const [createdOptions, setCreatedOptions] = React.useState<ComboboxOption[]>([])\n\n React.useEffect(() => {\n const trigger = triggerRef.current\n\n if (!trigger) {\n return\n }\n\n const update = () => {\n setContentWidth(trigger.offsetWidth)\n }\n\n update()\n\n const observer = new ResizeObserver(update)\n observer.observe(trigger)\n\n return () => observer.disconnect()\n }, [])\n\n const allOptions = React.useMemo(() => {\n const map = new Map<string, ComboboxOption>()\n\n createdOptions.forEach((option) => {\n map.set(option.value, option)\n })\n\n options.forEach((option) => {\n map.set(option.value, option)\n })\n\n return Array.from(map.values())\n }, [createdOptions, options])\n\n const selectedValues = React.useMemo(\n () => (multiple ? multiValue : singleValue ? [singleValue] : []),\n [multiple, multiValue, singleValue],\n )\n const normalizedQuery = query.trim().toLowerCase()\n const filteredOptions = React.useMemo(() => {\n if (!normalizedQuery) {\n return allOptions\n }\n\n return allOptions.filter((option) => {\n const terms = [option.label, option.value, ...(option.keywords ?? [])]\n\n return terms.some((term) => term.toLowerCase().includes(normalizedQuery))\n })\n }, [allOptions, normalizedQuery])\n\n const filteredGroups = React.useMemo(() => {\n const groups = new Map<string, { group?: string | undefined; options: ComboboxOption[] }>()\n\n filteredOptions.forEach((option) => {\n const groupKey = option.group ?? \"\"\n const existingGroup = groups.get(groupKey)\n\n if (existingGroup) {\n existingGroup.options.push(option)\n return\n }\n\n groups.set(groupKey, {\n group: option.group,\n options: [option],\n })\n })\n\n return Array.from(groups.values())\n }, [filteredOptions])\n\n const selectedOptions = React.useMemo(() => {\n const optionMap = new Map(allOptions.map((option) => [option.value, option] as const))\n\n return selectedValues.map((value) => optionMap.get(value) ?? { value, label: value })\n }, [allOptions, selectedValues])\n\n const selectedSingleLabel = !multiple ? selectedOptions[0]?.label : undefined\n const inputValue = multiple ? query : open ? query : query || selectedSingleLabel || \"\"\n const hasSelection = selectedValues.length > 0\n const hasQuery = query.trim().length > 0\n\n const hasExactOption = React.useMemo(\n () =>\n allOptions.some((option) => {\n const optionValue = option.value.trim().toLowerCase()\n const optionLabel = option.label.trim().toLowerCase()\n\n return optionValue === normalizedQuery || optionLabel === normalizedQuery\n }),\n [allOptions, normalizedQuery],\n )\n\n const showCreateOption = creatable && hasQuery && !hasExactOption && !loading\n const createOptionLabel = hasQuery ? createLabel(query.trim()) : null\n\n const setOpen = React.useCallback(\n (nextOpen: boolean) => {\n setOpenState(nextOpen)\n\n if (!nextOpen) {\n setQueryState(\"\")\n }\n },\n [setOpenState, setQueryState],\n )\n\n const setQuery = React.useCallback(\n (nextQuery: string) => {\n if (disabled) {\n return\n }\n\n if (!open) {\n setOpenState(true)\n }\n\n setQueryState(nextQuery)\n },\n [disabled, open, setOpenState, setQueryState],\n )\n\n const removeValue = React.useCallback(\n (valueToRemove: string) => {\n if (disabled) {\n return\n }\n\n if (multiple) {\n setMultiValue(selectedValues.filter((value) => value !== valueToRemove))\n return\n }\n\n if (singleValue === valueToRemove) {\n setSingleValue(undefined)\n }\n },\n [disabled, multiple, selectedValues, setMultiValue, setSingleValue, singleValue],\n )\n\n const clear = React.useCallback(() => {\n if (disabled) {\n return\n }\n\n setQueryState(\"\")\n\n if (multiple) {\n setMultiValue([])\n return\n }\n\n setSingleValue(undefined)\n }, [disabled, multiple, setMultiValue, setQueryState, setSingleValue])\n\n const selectOption = React.useCallback(\n (option: ComboboxOption) => {\n if (disabled || option.disabled) {\n return\n }\n\n if (multiple) {\n const nextValues = selectedValues.includes(option.value)\n ? selectedValues.filter((value) => value !== option.value)\n : [...selectedValues, option.value]\n\n setMultiValue(nextValues)\n setQueryState(\"\")\n setOpenState(true)\n inputRef.current?.focus()\n return\n }\n\n setSingleValue(option.value)\n setQueryState(\"\")\n setOpenState(false)\n },\n [\n disabled,\n multiple,\n selectedValues,\n setMultiValue,\n setOpenState,\n setQueryState,\n setSingleValue,\n ],\n )\n\n const createOption = React.useCallback(() => {\n const nextValue = query.trim()\n\n if (!nextValue || disabled) {\n return\n }\n\n const createdOption: ComboboxOption = {\n value: nextValue,\n label: nextValue,\n }\n\n setCreatedOptions((currentOptions) => {\n if (currentOptions.some((option) => option.value === nextValue)) {\n return currentOptions\n }\n\n return [...currentOptions, createdOption]\n })\n\n onCreateOption?.(nextValue)\n selectOption(createdOption)\n }, [disabled, onCreateOption, query, selectOption])\n\n const onInputKeyDown = React.useCallback(\n (event: React.KeyboardEvent<HTMLInputElement>) => {\n if (disabled) {\n return\n }\n\n if (event.key === \"Backspace\" && !query && multiple && selectedValues.length > 0) {\n event.preventDefault()\n const lastValue = selectedValues[selectedValues.length - 1]\n\n if (lastValue) {\n removeValue(lastValue)\n }\n }\n\n if (event.key === \"Escape\") {\n event.preventDefault()\n setOpen(false)\n }\n },\n [disabled, multiple, query, removeValue, selectedValues, setOpen],\n )\n\n const contextValue: ComboboxContextValue = {\n inputId: id ?? inputId,\n listId,\n open,\n setOpen,\n query,\n setQuery,\n inputValue,\n multiple,\n creatable,\n disabled,\n invalid,\n loading,\n placeholder,\n emptyMessage,\n loadingMessage,\n createOptionLabel,\n showCreateOption,\n selectedValues,\n selectedOptions,\n filteredGroups,\n hasSelection,\n hasQuery,\n triggerRef,\n inputRef,\n contentWidth,\n clear,\n removeValue,\n selectOption,\n createOption,\n onInputKeyDown,\n }\n\n return (\n <ComboboxContext.Provider value={contextValue}>\n <CommandRoot\n shouldFilter={false}\n loop\n className={cn(\"overflow-visible rounded-none bg-transparent p-0\", className)}\n >\n <Popover open={open} onOpenChange={setOpen}>\n <div data-slot=\"combobox\" {...divProps}>\n {children ?? (\n <>\n <ComboboxTrigger>\n <ComboboxTags />\n <ComboboxInput />\n <ComboboxClear />\n </ComboboxTrigger>\n <ComboboxContent>\n <ComboboxList />\n </ComboboxContent>\n </>\n )}\n </div>\n </Popover>\n </CommandRoot>\n </ComboboxContext.Provider>\n )\n}\n\nfunction ComboboxTrigger({\n className,\n children,\n leadingIcon = <SearchIcon className=\"text-field-placeholder size-4 shrink-0\" />,\n ...props\n}: React.ComponentProps<\"div\"> & { leadingIcon?: React.ReactNode }) {\n const context = useComboboxContext(\"ComboboxTrigger\")\n\n return (\n <PopoverAnchor asChild>\n <div\n ref={context.triggerRef}\n data-slot=\"combobox-trigger\"\n aria-disabled={context.disabled || undefined}\n aria-invalid={context.invalid || undefined}\n className={cn(\n \"border-field-border bg-field-background text-field-text focus-within:border-field-border-focus focus-within:ring-focus-ring aria-disabled:bg-field-background-disabled flex min-h-8 w-full cursor-text items-center gap-1 rounded-lg border px-2 py-1 transition-colors focus-within:ring-3 aria-disabled:cursor-not-allowed aria-disabled:opacity-50\",\n fieldInvalidClass,\n className,\n )}\n onMouseDown={(event) => {\n if (context.disabled) {\n return\n }\n\n if (\n event.target instanceof HTMLElement &&\n event.target.closest(\"[data-combobox-interactive]\")\n ) {\n return\n }\n\n event.preventDefault()\n context.setOpen(true)\n context.inputRef.current?.focus()\n }}\n {...props}\n >\n {leadingIcon}\n {children}\n <ChevronDownIcon className=\"text-field-placeholder ml-auto size-4 shrink-0\" />\n </div>\n </PopoverAnchor>\n )\n}\n\nfunction ComboboxInput({\n className,\n onFocus,\n onKeyDown,\n ...props\n}: Omit<\n React.ComponentProps<typeof CommandPrimitive.Input>,\n \"value\" | \"onValueChange\" | \"disabled\" | \"placeholder\"\n>) {\n const context = useComboboxContext(\"ComboboxInput\")\n\n return (\n <CommandPrimitive.Input\n ref={context.inputRef}\n id={context.inputId}\n data-slot=\"combobox-input\"\n aria-controls={context.listId}\n aria-expanded={context.open}\n aria-autocomplete=\"list\"\n aria-invalid={context.invalid || undefined}\n disabled={context.disabled}\n placeholder={\n !context.multiple && context.selectedOptions[0] && !context.open\n ? undefined\n : context.placeholder\n }\n value={context.inputValue}\n onFocus={(event) => {\n context.setOpen(true)\n onFocus?.(event)\n }}\n onValueChange={context.setQuery}\n onKeyDown={(event) => {\n context.onInputKeyDown(event)\n onKeyDown?.(event)\n }}\n className={cn(\n \"placeholder:text-field-placeholder min-w-[4ch] flex-1 bg-transparent text-sm outline-none disabled:cursor-not-allowed\",\n className,\n )}\n {...props}\n />\n )\n}\n\nfunction ComboboxContent({\n className,\n style,\n children,\n onOpenAutoFocus,\n ...props\n}: React.ComponentProps<typeof PopoverContent>) {\n const context = useComboboxContext(\"ComboboxContent\")\n\n return (\n <PopoverContent\n data-slot=\"combobox-content\"\n align=\"start\"\n sideOffset={4}\n className={cn(\"gap-0 p-1\", className)}\n style={{\n width: context.contentWidth ? `${context.contentWidth}px` : undefined,\n ...style,\n }}\n onOpenAutoFocus={(event) => {\n event.preventDefault()\n onOpenAutoFocus?.(event)\n }}\n {...props}\n >\n {children}\n </PopoverContent>\n )\n}\n\nfunction ComboboxList({\n className,\n children,\n ...props\n}: React.ComponentProps<typeof CommandListPrimitive>) {\n const context = useComboboxContext(\"ComboboxList\")\n\n return (\n <CommandListPrimitive id={context.listId} className={cn(\"max-h-64\", className)} {...props}>\n {children ? (\n children\n ) : context.loading ? (\n <ComboboxLoading />\n ) : context.filteredGroups.length > 0 ? (\n <>\n {context.filteredGroups.map((group) =>\n group.group ? (\n <ComboboxGroup key={group.group} heading={group.group}>\n {group.options.map((option) => (\n <ComboboxItem key={option.value} option={option} />\n ))}\n </ComboboxGroup>\n ) : (\n group.options.map((option) => <ComboboxItem key={option.value} option={option} />)\n ),\n )}\n {context.showCreateOption ? (\n <CommandItemPrimitive\n value={`__create__${context.query}`}\n onSelect={context.createOption}\n className=\"mt-1\"\n >\n {context.createOptionLabel}\n </CommandItemPrimitive>\n ) : null}\n </>\n ) : context.showCreateOption ? (\n <CommandItemPrimitive value={`__create__${context.query}`} onSelect={context.createOption}>\n {context.createOptionLabel}\n </CommandItemPrimitive>\n ) : (\n <ComboboxEmpty />\n )}\n </CommandListPrimitive>\n )\n}\n\nfunction ComboboxGroup({\n className,\n children,\n ...props\n}: React.ComponentProps<typeof CommandGroupPrimitive>) {\n return (\n <CommandGroupPrimitive className={cn(\"overflow-hidden\", className)} {...props}>\n {children}\n </CommandGroupPrimitive>\n )\n}\n\nfunction ComboboxItem({\n option,\n className,\n children,\n ...props\n}: Omit<React.ComponentProps<typeof CommandItemPrimitive>, \"value\" | \"onSelect\"> & {\n option: ComboboxOption\n}) {\n const context = useComboboxContext(\"ComboboxItem\")\n const isSelected = context.selectedValues.includes(option.value)\n\n return (\n <CommandItemPrimitive\n data-checked={isSelected || undefined}\n value={option.value}\n {...(context.disabled || option.disabled ? { disabled: true } : {})}\n onSelect={() => context.selectOption(option)}\n className={className}\n {...props}\n >\n <span className=\"truncate\">{children ?? option.label}</span>\n {!isSelected ? <CheckIcon className=\"ml-auto size-4 opacity-0\" /> : null}\n </CommandItemPrimitive>\n )\n}\n\nfunction ComboboxEmpty({ className, children, ...props }: React.ComponentProps<\"div\">) {\n const context = useComboboxContext(\"ComboboxEmpty\")\n\n return (\n <div\n data-slot=\"combobox-empty\"\n className={cn(\"text-text-muted py-6 text-center text-sm\", className)}\n {...props}\n >\n {children ?? context.emptyMessage}\n </div>\n )\n}\n\nfunction ComboboxLoading({ className, children, ...props }: React.ComponentProps<\"div\">) {\n const context = useComboboxContext(\"ComboboxLoading\")\n\n return (\n <div\n data-slot=\"combobox-loading\"\n className={cn(\"text-text-muted flex items-center gap-2 px-2 py-3 text-sm\", className)}\n {...props}\n >\n <LoaderCircleIcon className=\"size-4 animate-spin\" />\n <span>{children ?? context.loadingMessage}</span>\n </div>\n )\n}\n\nfunction ComboboxTags({ className, children, ...props }: React.ComponentProps<\"div\">) {\n const context = useComboboxContext(\"ComboboxTags\")\n\n if (!context.multiple || context.selectedOptions.length === 0) {\n return children ? (\n <div data-slot=\"combobox-tags\" className={className} {...props}>\n {children}\n </div>\n ) : null\n }\n\n return (\n <div\n data-slot=\"combobox-tags\"\n className={cn(\"flex flex-wrap items-center gap-1\", className)}\n {...props}\n >\n {children ??\n context.selectedOptions.map((option) => <ComboboxTag key={option.value} option={option} />)}\n </div>\n )\n}\n\nfunction ComboboxTag({\n option,\n className,\n children,\n ...props\n}: React.ComponentProps<typeof Badge> & {\n option: ComboboxOption\n}) {\n const context = useComboboxContext(\"ComboboxTag\")\n\n return (\n <Badge variant=\"normal\" className={cn(\"gap-1 pr-1\", className)} {...props}>\n <span className=\"truncate\">{children ?? option.label}</span>\n <button\n type=\"button\"\n data-combobox-interactive\n className=\"hover:bg-background-modifier-hover rounded-full p-0.5 transition-colors\"\n onMouseDown={(event) => event.preventDefault()}\n onClick={() => context.removeValue(option.value)}\n aria-label={`Remove ${option.label}`}\n >\n <XIcon className=\"size-3\" />\n </button>\n </Badge>\n )\n}\n\nfunction ComboboxClear({\n className,\n children,\n ...props\n}: Omit<React.ComponentProps<\"button\">, \"children\"> & { children?: React.ReactNode }) {\n const context = useComboboxContext(\"ComboboxClear\")\n\n if (!context.hasSelection && !context.hasQuery) {\n return null\n }\n\n return (\n <button\n type=\"button\"\n data-slot=\"combobox-clear\"\n data-combobox-interactive\n className={cn(\n \"text-field-placeholder hover:bg-background-modifier-hover hover:text-text-normal ml-1 inline-flex size-5 shrink-0 items-center justify-center rounded-full transition-colors\",\n className,\n )}\n onMouseDown={(event) => event.preventDefault()}\n onClick={context.clear}\n aria-label=\"Clear selection\"\n {...props}\n >\n {children ?? <XIcon className=\"size-3.5\" />}\n </button>\n )\n}\n\nexport {\n Combobox,\n ComboboxTrigger,\n ComboboxInput,\n ComboboxContent,\n ComboboxList,\n ComboboxGroup,\n ComboboxItem,\n ComboboxEmpty,\n ComboboxLoading,\n ComboboxTag,\n ComboboxTags,\n ComboboxClear,\n}\n"],"mappings":"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","names":["query"]}
|