@spear-ai/spectral 1.11.1 → 1.11.2
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/dist/.js +3 -2
- package/dist/ButtonIcon.js +2 -2
- package/dist/Checkbox/CheckboxBase.js +1 -1
- package/dist/Combobox/ComboboxBase.js +1 -1
- package/dist/Combobox.d.ts +5 -2
- package/dist/Combobox.js +97 -69
- package/dist/{ComboboxBase-Dn8Lz9mG.js → ComboboxBase-qX-mQhT6.js} +2 -2
- package/dist/ControlGroup/ControlGroupSelect.d.ts +3 -2
- package/dist/ControlGroup/ControlGroupSelect.js +79 -71
- package/dist/DateTimePicker/DateTimeDisplayInput.js +1 -1
- package/dist/DateTimePicker.js +1 -1
- package/dist/Icons/AnalyzeIcon.d.ts +1 -1
- package/dist/Icons/AnalyzeIcon.js +5 -6
- package/dist/Icons/AnnotationsIcon.d.ts +1 -1
- package/dist/Icons/AnnotationsIcon.js +5 -6
- package/dist/Icons/ApprovedIcon.d.ts +1 -1
- package/dist/Icons/ApprovedIcon.js +5 -6
- package/dist/Icons/ArrowDownIcon.d.ts +1 -1
- package/dist/Icons/ArrowDownIcon.js +5 -6
- package/dist/Icons/ArrowUpIcon.d.ts +1 -1
- package/dist/Icons/ArrowUpIcon.js +5 -6
- package/dist/Icons/BoxToolIcon.d.ts +1 -1
- package/dist/Icons/BoxToolIcon.js +5 -6
- package/dist/Icons/CalendarIcon.d.ts +1 -1
- package/dist/Icons/CalendarIcon.js +5 -6
- package/dist/Icons/CheckCircleIcon.d.ts +1 -1
- package/dist/Icons/CheckCircleIcon.js +5 -6
- package/dist/Icons/CheckSquareIcon.d.ts +1 -1
- package/dist/Icons/CheckSquareIcon.js +5 -6
- package/dist/Icons/CheckmarkIcon.d.ts +1 -1
- package/dist/Icons/CheckmarkIcon.js +6 -7
- package/dist/Icons/ChevronDownIcon.d.ts +1 -1
- package/dist/Icons/ChevronDownIcon.js +5 -6
- package/dist/Icons/ChevronUpIcon.d.ts +1 -1
- package/dist/Icons/ChevronUpIcon.js +5 -6
- package/dist/Icons/ClockIcon.d.ts +1 -1
- package/dist/Icons/ClockIcon.js +5 -6
- package/dist/Icons/CloseCircleIcon.d.ts +1 -1
- package/dist/Icons/CloseCircleIcon.js +5 -6
- package/dist/Icons/CloseIcon.d.ts +1 -1
- package/dist/Icons/CloseIcon.js +5 -6
- package/dist/Icons/Crosshairs2Icon.d.ts +1 -1
- package/dist/Icons/Crosshairs2Icon.js +5 -6
- package/dist/Icons/CrosshairsIcon.d.ts +1 -1
- package/dist/Icons/CrosshairsIcon.js +5 -6
- package/dist/Icons/DashboardIcon.d.ts +1 -1
- package/dist/Icons/DashboardIcon.js +5 -6
- package/dist/Icons/DatabaseIcon.d.ts +1 -1
- package/dist/Icons/DatabaseIcon.js +5 -6
- package/dist/Icons/DeleteIcon.d.ts +1 -1
- package/dist/Icons/DeleteIcon.js +5 -6
- package/dist/Icons/DurationIcon.d.ts +1 -1
- package/dist/Icons/DurationIcon.js +5 -6
- package/dist/Icons/EditIcon.d.ts +1 -1
- package/dist/Icons/EditIcon.js +5 -6
- package/dist/Icons/EmailIcon.d.ts +1 -1
- package/dist/Icons/EmailIcon.js +5 -6
- package/dist/Icons/EraserIcon.d.ts +1 -1
- package/dist/Icons/EraserIcon.js +8 -9
- package/dist/Icons/ErrorIcon.d.ts +1 -1
- package/dist/Icons/ErrorIcon.js +5 -6
- package/dist/Icons/EyeClosedIcon.d.ts +1 -1
- package/dist/Icons/EyeClosedIcon.js +5 -6
- package/dist/Icons/EyeClosedIcon2.d.ts +1 -1
- package/dist/Icons/EyeClosedIcon2.js +5 -6
- package/dist/Icons/EyeOpenIcon.d.ts +1 -1
- package/dist/Icons/EyeOpenIcon.js +5 -6
- package/dist/Icons/FileDownloadIcon.d.ts +1 -1
- package/dist/Icons/FileDownloadIcon.js +5 -6
- package/dist/Icons/GoToFirstIcon.d.ts +1 -1
- package/dist/Icons/GoToFirstIcon.js +5 -6
- package/dist/Icons/GoToLastIcon.d.ts +1 -1
- package/dist/Icons/GoToLastIcon.js +5 -6
- package/dist/Icons/HarmonicCursorsIcon.d.ts +1 -1
- package/dist/Icons/HarmonicCursorsIcon.js +5 -6
- package/dist/Icons/IconBase.d.ts +2 -1
- package/dist/Icons/IconBase.js +26 -26
- package/dist/Icons/InfoIcon.d.ts +1 -1
- package/dist/Icons/InfoIcon.js +5 -6
- package/dist/Icons/KeyboardIcon.d.ts +1 -1
- package/dist/Icons/KeyboardIcon.js +5 -6
- package/dist/Icons/LabelIcon.d.ts +1 -1
- package/dist/Icons/LabelIcon.js +5 -6
- package/dist/Icons/LassoIcon.d.ts +1 -1
- package/dist/Icons/LassoIcon.js +5 -6
- package/dist/Icons/LineToolIcon.d.ts +1 -1
- package/dist/Icons/LineToolIcon.js +5 -6
- package/dist/Icons/LiveViewIcon.d.ts +1 -1
- package/dist/Icons/LiveViewIcon.js +5 -6
- package/dist/Icons/LoaderIcon.d.ts +1 -1
- package/dist/Icons/LoaderIcon.js +10 -11
- package/dist/Icons/LocationIcon.d.ts +1 -1
- package/dist/Icons/LocationIcon.js +5 -6
- package/dist/Icons/LogoutIcon.d.ts +1 -1
- package/dist/Icons/LogoutIcon.js +5 -6
- package/dist/Icons/MaximizeIcon.d.ts +1 -1
- package/dist/Icons/MaximizeIcon.js +5 -6
- package/dist/Icons/MeasureIcon.d.ts +1 -1
- package/dist/Icons/MeasureIcon.js +5 -6
- package/dist/Icons/MessagesIcon.d.ts +1 -1
- package/dist/Icons/MessagesIcon.js +5 -6
- package/dist/Icons/MetadataIcon.d.ts +1 -1
- package/dist/Icons/MetadataIcon.js +5 -6
- package/dist/Icons/MinimizeIcon.d.ts +1 -1
- package/dist/Icons/MinimizeIcon.js +5 -6
- package/dist/Icons/MinusIcon.d.ts +1 -1
- package/dist/Icons/MinusIcon.js +5 -6
- package/dist/Icons/OntologyIcon.d.ts +1 -1
- package/dist/Icons/OntologyIcon.js +5 -6
- package/dist/Icons/PanelIconClose.d.ts +1 -1
- package/dist/Icons/PanelIconClose.js +5 -6
- package/dist/Icons/PanelIconOpen.d.ts +1 -1
- package/dist/Icons/PanelIconOpen.js +5 -6
- package/dist/Icons/PauseIcon.d.ts +1 -1
- package/dist/Icons/PauseIcon.js +5 -6
- package/dist/Icons/PlayIcon.d.ts +1 -1
- package/dist/Icons/PlayIcon.js +5 -6
- package/dist/Icons/PlusIcon.d.ts +1 -1
- package/dist/Icons/PlusIcon.js +5 -6
- package/dist/Icons/PolygonIcon.d.ts +1 -1
- package/dist/Icons/PolygonIcon.js +5 -6
- package/dist/Icons/PrinterIcon.d.ts +1 -1
- package/dist/Icons/PrinterIcon.js +5 -6
- package/dist/Icons/ProgressCheckIcon.d.ts +1 -1
- package/dist/Icons/ProgressCheckIcon.js +5 -6
- package/dist/Icons/ResetIcon.d.ts +1 -1
- package/dist/Icons/ResetIcon.js +5 -6
- package/dist/Icons/ReviewedIcon.d.ts +1 -1
- package/dist/Icons/ReviewedIcon.js +5 -6
- package/dist/Icons/ScissorsIcon.d.ts +1 -1
- package/dist/Icons/ScissorsIcon.js +5 -6
- package/dist/Icons/SearchIcon.d.ts +1 -1
- package/dist/Icons/SearchIcon.js +5 -6
- package/dist/Icons/SettingsIcon.d.ts +1 -1
- package/dist/Icons/SettingsIcon.js +5 -6
- package/dist/Icons/SortAscendingIcon.d.ts +1 -1
- package/dist/Icons/SortAscendingIcon.js +5 -6
- package/dist/Icons/SortAtoZIcon.d.ts +1 -1
- package/dist/Icons/SortAtoZIcon.js +5 -6
- package/dist/Icons/SortDescendingIcon.d.ts +1 -1
- package/dist/Icons/SortDescendingIcon.js +5 -6
- package/dist/Icons/SortZtoAIcon.d.ts +1 -1
- package/dist/Icons/SortZtoAIcon.js +5 -6
- package/dist/Icons/SparklesIcon.d.ts +1 -1
- package/dist/Icons/SparklesIcon.js +5 -6
- package/dist/Icons/StackIcon.d.ts +1 -1
- package/dist/Icons/StackIcon.js +5 -6
- package/dist/Icons/StarIcon.d.ts +1 -1
- package/dist/Icons/StarIcon.js +5 -6
- package/dist/Icons/TrashIcon.d.ts +1 -1
- package/dist/Icons/TrashIcon.js +5 -6
- package/dist/Icons/UndoIcon.d.ts +1 -1
- package/dist/Icons/UndoIcon.js +5 -6
- package/dist/Icons/UploadIcon.d.ts +1 -1
- package/dist/Icons/UploadIcon.js +5 -6
- package/dist/Icons/User2Icon.d.ts +1 -1
- package/dist/Icons/User2Icon.js +5 -6
- package/dist/Icons/UserIcon.d.ts +1 -1
- package/dist/Icons/UserIcon.js +5 -6
- package/dist/Icons/WarningIcon.d.ts +1 -1
- package/dist/Icons/WarningIcon.js +5 -6
- package/dist/Icons/ZoomAllIcon.d.ts +1 -1
- package/dist/Icons/ZoomAllIcon.js +5 -6
- package/dist/Icons/ZoomXIcon.d.ts +1 -1
- package/dist/Icons/ZoomXIcon.js +5 -6
- package/dist/Icons/ZoomYIcon.d.ts +1 -1
- package/dist/Icons/ZoomYIcon.js +5 -6
- package/dist/Input.d.ts +1 -1
- package/dist/Input.js +95 -90
- package/dist/InputNumeric.d.ts +1 -1
- package/dist/InputNumeric.js +70 -65
- package/dist/MultiSelect/MultiSelectBase.d.ts +6 -3
- package/dist/MultiSelect/MultiSelectBase.js +126 -119
- package/dist/MultiSelect.d.ts +3 -2
- package/dist/MultiSelect.js +12 -11
- package/dist/Select.d.ts +2 -1
- package/dist/Select.js +83 -77
- package/dist/Switch/SwitchBase.js +1 -1
- package/dist/Textarea.d.ts +1 -1
- package/dist/Textarea.js +54 -49
- package/dist/Toggle/ToggleBase.js +1 -1
- package/dist/ToggleGroup/ToggleGroupBase.js +5 -2
- package/dist/hooks/useControllableState.d.ts +6 -1
- package/dist/hooks/useControllableState.d.ts.map +1 -1
- package/dist/hooks/useControllableState.js +2 -2
- package/dist/hooks/useUncontrolledState.d.ts +9 -0
- package/dist/hooks/useUncontrolledState.d.ts.map +1 -0
- package/dist/hooks/useUncontrolledState.js +16 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/primitives/select.d.ts +6 -1
- package/dist/primitives/select.d.ts.map +1 -1
- package/dist/primitives/select.js +85 -36
- package/dist/styles/spectral.css +1 -1
- package/dist/utils/formFieldUtils.d.ts +2 -0
- package/dist/utils/formFieldUtils.d.ts.map +1 -1
- package/dist/utils/formFieldUtils.js +18 -15
- package/package.json +1 -1
|
@@ -1,75 +1,124 @@
|
|
|
1
|
+
"use client";
|
|
1
2
|
import { CheckmarkIcon as e } from "../Icons/CheckmarkIcon.js";
|
|
2
3
|
import { ChevronDownIcon as t } from "../Icons/ChevronDownIcon.js";
|
|
3
4
|
import { ChevronUpIcon as n } from "../Icons/ChevronUpIcon.js";
|
|
4
5
|
import { t as r } from "../twUtils-VNWgstKL.js";
|
|
5
|
-
import {
|
|
6
|
-
import "
|
|
7
|
-
import {
|
|
6
|
+
import { getDropdownSurfaceClasses as i } from "../utils/formFieldUtils.js";
|
|
7
|
+
import { a, c as o, d as s, f as c, h as l, i as u, l as d, m as f, n as p, o as m, p as h, r as g, s as _, t as v, u as y } from "../dist-fW81qjVl.js";
|
|
8
|
+
import { useRef as b } from "react";
|
|
9
|
+
import { jsx as x, jsxs as S } from "react/jsx-runtime";
|
|
8
10
|
//#region src/primitives/select.tsx
|
|
9
|
-
var
|
|
11
|
+
var C = 12, w = (e) => {
|
|
12
|
+
let t = document.querySelectorAll("[aria-controls]");
|
|
13
|
+
for (let n of t) if (n.getAttribute("aria-controls") === e) return n;
|
|
14
|
+
return null;
|
|
15
|
+
}, T = (e) => {
|
|
16
|
+
let t = e.id;
|
|
17
|
+
if (!t) return;
|
|
18
|
+
let n = w(t);
|
|
19
|
+
if (!n) return;
|
|
20
|
+
let r = n.closest("[data-slot=\"dialog-content\"]");
|
|
21
|
+
if (!r) return;
|
|
22
|
+
let i = e.getBoundingClientRect(), a = r.getBoundingClientRect(), o = i.bottom - a.bottom + C;
|
|
23
|
+
if (o > 0) {
|
|
24
|
+
r.scrollTo({
|
|
25
|
+
top: r.scrollTop + o,
|
|
26
|
+
behavior: "smooth"
|
|
27
|
+
});
|
|
28
|
+
return;
|
|
29
|
+
}
|
|
30
|
+
let s = a.top - i.top + C;
|
|
31
|
+
s > 0 && r.scrollTo({
|
|
32
|
+
top: Math.max(0, r.scrollTop - s),
|
|
33
|
+
behavior: "smooth"
|
|
34
|
+
});
|
|
35
|
+
}, E = ({ ...e }) => /* @__PURE__ */ x(d, {
|
|
10
36
|
"data-slot": "select",
|
|
11
37
|
...e
|
|
12
|
-
}),
|
|
38
|
+
}), D = ({ ...e }) => /* @__PURE__ */ x(p, {
|
|
13
39
|
"data-slot": "select-group",
|
|
14
40
|
...e
|
|
15
|
-
}),
|
|
41
|
+
}), O = ({ className: e, ...t }) => /* @__PURE__ */ x(f, {
|
|
16
42
|
className: r("min-w-0 block max-w-full flex-1 truncate text-left whitespace-nowrap text-input-text! data-placeholder:text-input-text!", e),
|
|
17
43
|
"data-slot": "select-value",
|
|
18
44
|
...t
|
|
19
|
-
}),
|
|
45
|
+
}), k = ({ asChild: e, children: n, className: i, size: a = "default", ...o }) => /* @__PURE__ */ S(h, {
|
|
20
46
|
asChild: e,
|
|
21
47
|
className: r("[&_svg:not([class*='text-'])]:text-text-placeholder focus-visible:border-ring focus-visible:ring-ring/50 gap-2 rounded-md px-3 py-2 text-sm shadow-xs h-9 *:data-[slot=select-value]:gap-2 [&_svg:not([class*='size-'])]:size-4 min-w-0 *:data-[slot=select-value]:min-w-0 flex w-fit cursor-pointer items-center justify-between border border-input-border bg-transparent text-input-text! transition-[color,box-shadow] outline-none focus-visible:ring-[3px] disabled:cursor-not-allowed disabled:opacity-50 aria-invalid:ring-danger-400 data-placeholder:text-input-text! *:data-[slot=select-value]:line-clamp-1 *:data-[slot=select-value]:flex *:data-[slot=select-value]:items-center data-[state=open]:**:data-[slot=select-chevron]:rotate-180 [&_svg]:pointer-events-none [&_svg]:shrink-0", i),
|
|
22
48
|
"data-size": a,
|
|
23
49
|
"data-slot": "select-trigger",
|
|
24
50
|
...o,
|
|
25
|
-
children: [n, !e && /* @__PURE__ */
|
|
51
|
+
children: [n, !e && /* @__PURE__ */ x(g, {
|
|
26
52
|
asChild: !0,
|
|
27
|
-
children: /* @__PURE__ */
|
|
53
|
+
children: /* @__PURE__ */ x(t, {
|
|
28
54
|
className: "size-4 opacity-50 transition-transform duration-200",
|
|
29
55
|
"data-slot": "select-chevron"
|
|
30
56
|
})
|
|
31
57
|
})]
|
|
32
|
-
}),
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
58
|
+
}), A = ({ align: e = "center", children: t, className: n, dropdownWidth: a = "trigger", onCloseAutoFocus: s, onFocusCapture: c, position: u = "popper", style: d, ...f }) => {
|
|
59
|
+
let p = b(!1), m = a === "trigger" ? "var(--radix-select-trigger-width)" : a === "content" ? "max-content" : a, h = a === "trigger" || a === "content" ? a : "custom", g = (e) => {
|
|
60
|
+
if (c?.(e), p.current) return;
|
|
61
|
+
p.current = !0;
|
|
62
|
+
let t = e.currentTarget;
|
|
63
|
+
requestAnimationFrame(() => {
|
|
64
|
+
T(t);
|
|
65
|
+
});
|
|
66
|
+
}, _ = (e) => {
|
|
67
|
+
p.current = !1, s?.(e);
|
|
68
|
+
};
|
|
69
|
+
return /* @__PURE__ */ x(o, { children: /* @__PURE__ */ S(v, {
|
|
70
|
+
align: e,
|
|
71
|
+
className: r("min-w-32 relative z-50 max-h-[--radix-select-content-available-height] origin-[--radix-select-content-transform-origin] overflow-x-hidden overflow-y-auto text-text-primary motion-safe:data-[side=bottom]:slide-in-from-top-2 motion-safe:data-[side=left]:slide-in-from-right-2 motion-safe:data-[side=right]:slide-in-from-left-2 motion-safe:data-[side=top]:slide-in-from-bottom-2 motion-safe:data-[state=closed]:animate-out motion-safe:data-[state=closed]:fade-out-0 motion-safe:data-[state=closed]:zoom-out-95 motion-safe:data-[state=open]:animate-in motion-safe:data-[state=open]:fade-in-0 motion-safe:data-[state=open]:zoom-in-95", i(), u === "popper" && "data-[side=bottom]:translate-y-1 data-[side=left]:-translate-x-1 data-[side=right]:translate-x-1 data-[side=top]:-translate-y-1", n),
|
|
72
|
+
"data-dropdown-width-mode": h,
|
|
73
|
+
"data-dropdown-width-value": h === "custom" ? a : void 0,
|
|
74
|
+
"data-slot": "select-content",
|
|
75
|
+
onCloseAutoFocus: _,
|
|
76
|
+
onFocusCapture: g,
|
|
77
|
+
position: u,
|
|
78
|
+
style: {
|
|
79
|
+
...d,
|
|
80
|
+
width: m
|
|
81
|
+
},
|
|
82
|
+
...f,
|
|
83
|
+
children: [
|
|
84
|
+
/* @__PURE__ */ x(P, {}),
|
|
85
|
+
/* @__PURE__ */ x(l, {
|
|
86
|
+
className: r("p-1", u === "popper" && "scroll-my-1 h-(--radix-select-trigger-height) w-full min-w-full"),
|
|
87
|
+
"data-slot": "select-viewport",
|
|
88
|
+
children: t
|
|
89
|
+
}),
|
|
90
|
+
/* @__PURE__ */ x(F, {})
|
|
91
|
+
]
|
|
92
|
+
}) });
|
|
93
|
+
}, j = ({ className: e, ...t }) => /* @__PURE__ */ x(_, {
|
|
48
94
|
className: r("px-2 py-1.5 text-xs text-text-primary", e),
|
|
49
95
|
"data-slot": "select-label",
|
|
50
96
|
...t
|
|
51
|
-
}),
|
|
97
|
+
}), M = ({ className: t, children: n, ...i }) => /* @__PURE__ */ S(u, {
|
|
52
98
|
className: r("gap-2 rounded-sm py-1.5 pr-8 pl-2 text-sm [&_svg:not([class*='size-'])]:size-4 *:[span]:last:gap-2 relative flex w-full cursor-default items-center outline-none select-none hover:border-input-border--hover hover:bg-accent hover:text-text-inverted! focus:border-input-border--focus focus:bg-accent focus:text-text-inverted! data-disabled:pointer-events-none data-disabled:opacity-50 data-highlighted:bg-accent data-highlighted:text-text-inverted! [&_svg]:pointer-events-none [&_svg]:shrink-0 hover:[&_svg]:text-text-inverted! focus:[&_svg]:text-text-inverted! data-highlighted:[&_svg]:text-text-inverted! *:[span]:last:flex *:[span]:last:items-center", t),
|
|
53
99
|
"data-slot": "select-item",
|
|
54
|
-
...
|
|
55
|
-
children: [/* @__PURE__ */
|
|
100
|
+
...i,
|
|
101
|
+
children: [/* @__PURE__ */ x("span", {
|
|
56
102
|
className: "right-2 size-3.5 absolute flex items-center justify-center",
|
|
57
|
-
children: /* @__PURE__ */
|
|
58
|
-
}), /* @__PURE__ */
|
|
59
|
-
|
|
103
|
+
children: /* @__PURE__ */ x(a, { children: /* @__PURE__ */ x(e, { className: "size-4" }) })
|
|
104
|
+
}), /* @__PURE__ */ x(m, {
|
|
105
|
+
className: "min-w-0 block max-w-full truncate whitespace-nowrap",
|
|
106
|
+
children: n
|
|
107
|
+
})]
|
|
108
|
+
}), N = ({ className: e, ...t }) => /* @__PURE__ */ x(c, {
|
|
60
109
|
className: r("bg-border -mx-1 my-1 pointer-events-none h-px", e),
|
|
61
110
|
"data-slot": "select-separator",
|
|
62
111
|
...t
|
|
63
|
-
}),
|
|
112
|
+
}), P = ({ className: e, ...t }) => /* @__PURE__ */ x(s, {
|
|
64
113
|
className: r("py-1 flex cursor-default items-center justify-center", e),
|
|
65
114
|
"data-slot": "select-scroll-up-button",
|
|
66
115
|
...t,
|
|
67
|
-
children: /* @__PURE__ */
|
|
68
|
-
}),
|
|
116
|
+
children: /* @__PURE__ */ x(n, { className: "size-4" })
|
|
117
|
+
}), F = ({ className: e, ...n }) => /* @__PURE__ */ x(y, {
|
|
69
118
|
className: r("py-1 flex cursor-default items-center justify-center", e),
|
|
70
119
|
"data-slot": "select-scroll-down-button",
|
|
71
120
|
...n,
|
|
72
|
-
children: /* @__PURE__ */
|
|
121
|
+
children: /* @__PURE__ */ x(t, { className: "size-4" })
|
|
73
122
|
});
|
|
74
123
|
//#endregion
|
|
75
|
-
export {
|
|
124
|
+
export { E as Select, A as SelectContent, D as SelectGroup, M as SelectItem, j as SelectLabel, F as SelectScrollDownButton, P as SelectScrollUpButton, N as SelectSeparator, k as SelectTrigger, O as SelectValue };
|