mimir-ui-kit 1.38.43 → 1.39.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/dist/assets/stories.css +1 -0
- package/dist/assets/styles2.css +1 -0
- package/dist/combobox-Dv6-ANkb.js +508 -0
- package/dist/components/Dropdown/Dropdown.js +176 -176
- package/dist/components/MultiSelectSearch/MultiSelectSearch.js +1 -1
- package/dist/components/SelectSearch/SelectSearch.js +1 -1
- package/dist/components/Table/ColumnOrderSettings.d.ts +18 -0
- package/dist/components/Table/ColumnOrderSettings.js +177 -0
- package/dist/components/Table/Table.d.ts +3 -0
- package/dist/components/Table/Table.js +204 -0
- package/dist/components/Table/TableBody.d.ts +5 -0
- package/dist/components/Table/TableBody.js +109 -0
- package/dist/components/Table/TableCard.d.ts +5 -0
- package/dist/components/Table/TableCard.js +45 -0
- package/dist/components/Table/TableCardsView.d.ts +5 -0
- package/dist/components/Table/TableCardsView.js +84 -0
- package/dist/components/Table/TableFilters.d.ts +12 -0
- package/dist/components/Table/TableFilters.js +165 -0
- package/dist/components/Table/TableHeader.d.ts +3 -0
- package/dist/components/Table/TableHeader.js +70 -0
- package/dist/components/Table/TableRow.d.ts +5 -0
- package/dist/components/Table/TableRow.js +76 -0
- package/dist/components/Table/TableScrollButtons.d.ts +11 -0
- package/dist/components/Table/TableScrollButtons.js +35 -0
- package/dist/components/Table/constants.d.ts +128 -0
- package/dist/components/Table/constants.js +434 -0
- package/dist/components/Table/hooks/index.d.ts +4 -0
- package/dist/components/Table/hooks/index.js +10 -0
- package/dist/components/Table/hooks/useTableInstance.d.ts +3 -0
- package/dist/components/Table/hooks/useTableInstance.js +68 -0
- package/dist/components/Table/hooks/useTableScroll.d.ts +8 -0
- package/dist/components/Table/hooks/useTableScroll.js +54 -0
- package/dist/components/Table/hooks/useTableState.d.ts +13 -0
- package/dist/components/Table/hooks/useTableState.js +56 -0
- package/dist/components/Table/hooks/useTableVirtualization.d.ts +13 -0
- package/dist/components/Table/hooks/useTableVirtualization.js +97 -0
- package/dist/components/Table/index.d.ts +3 -0
- package/dist/components/Table/index.js +10 -0
- package/dist/components/Table/types.d.ts +150 -0
- package/dist/components/Table/utils.d.ts +4 -0
- package/dist/components/Table/utils.js +25 -0
- package/dist/components/index.d.ts +2 -0
- package/dist/components/index.js +72 -64
- package/dist/index-CVk4sixt.js +1862 -0
- package/dist/index-D5H8gPPn.js +546 -0
- package/dist/index.js +106 -98
- package/dist/{portal-D3A00sie.js → portal-C_u5auU1.js} +179 -183
- package/dist/stories.module-fud786VB.js +29 -0
- package/dist/styles.module--QBQYoA9.js +36 -0
- package/package.json +3 -1
- package/dist/combobox-BD-GHvMy.js +0 -980
@@ -0,0 +1 @@
|
|
1
|
+
._tableClassNameContainer_1mzja_3{font-size:var(--mimir-size-text-s);line-height:var(--mimir-line-height-text-m1)}@media (min-width: 1280px){._tableClassNameContainer_1mzja_3{font-size:var(--mimir-size-text-l);line-height:var(--mimir-line-height-text-s1)}}@media (max-width: 1279.1px){._tableClassNameContainer_1mzja_3 ._headerTextClassName_1mzja_14{margin:var(--mimir-space-s) var(--mimir-space-xs)}}@media (max-width: 1279.1px){._tableClassNameContainer_1mzja_3 ._cellClassName_1mzja_19{padding:var(--mimir-space-s) var(--mimir-space-xs)}}._columnOrderDrawer_1mzja_24{min-width:300px}._columnOrderList_1mzja_28{display:flex;flex-direction:column;gap:var(--mimir-space-xs)}._columnOrderItem_1mzja_34{display:flex;gap:var(--mimir-space-xs);align-items:center;padding:var(--mimir-space-xl);background-color:var(--white);border-radius:var(--mimir-control-radius);box-shadow:0 0 #16172705,0 2px 4px #16172705,0 6px 6px #16172705,0 15px 9px #16172703;cursor:grab;transition:background-color .2s}._columnOrderItem_1mzja_34._dragging_1mzja_45{background-color:var(--black-15);opacity:.5}._columnOrderItem_1mzja_34._dragOver_1mzja_49{border-top:3px solid var(--citrine-100)}._columnOrderItem_1mzja_34._disabled_1mzja_52{cursor:not-allowed}._columnOrderItem_1mzja_34._hidden_1mzja_55{opacity:.5}._iconDrag_1mzja_59{cursor:grab}._iconDrag_1mzja_59 path{fill:var(--disabled-color)}._iconDrag_1mzja_59._iconDisabled_1mzja_65{cursor:not-allowed}._iconDrag_1mzja_59._iconDisabled_1mzja_65 path{fill:var(--black-5)}._columnNameAndSwitch_1mzja_72{display:flex;flex:1;align-items:center;justify-content:space-between}._columnName_1mzja_72{font-weight:var(--mimir-font-weight-text-medium)}._columnSwitch_1mzja_83._disabled_1mzja_52{cursor:not-allowed}._columnOrderFooter_1mzja_87{display:flex;justify-content:space-between}._footerButtonGroup_1mzja_92,._controlsRow_1mzja_93{display:flex;gap:var(--mimir-space-xs)}._filterItem_1mzja_98,._filterDateRange_1mzja_99,._filterList_1mzja_100,._tableControlsContainer_1mzja_101{display:flex;flex-direction:column;gap:var(--mimir-space-xl)}._filterLabel_1mzja_107{font-size:var(--mimir-size-text-xl2)}._activeFiltersCount_1mzja_111{color:var(--counter-text)}
|
@@ -0,0 +1 @@
|
|
1
|
+
._tableContainer_12qch_3{position:relative;width:100%;background:var(--black-5);will-change:transform;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}._tableContainer_12qch_3 ._tableScroll_12qch_11{width:100%;height:100%;overflow:auto;white-space:nowrap;-webkit-overflow-scrolling:touch;scroll-behavior:smooth;overscroll-behavior:contain}._tableContainer_12qch_3 ._tableScroll_12qch_11::-webkit-scrollbar{width:4px;height:4px}._tableContainer_12qch_3 ._tableScroll_12qch_11::-webkit-scrollbar-thumb{background-color:var(--black-80);border-radius:var(--mimir-control-radius)}._tableContainer_12qch_3 ._tableScroll_12qch_11::-webkit-scrollbar-track{background-color:var(--white)}._scrollButtons_12qch_32{position:absolute;top:calc(-1 * var(--mimir-space-3xl));right:0;z-index:10;display:flex;align-items:center}._table_12qch_3{width:100%;min-width:100%;table-layout:fixed;border-collapse:collapse;contain:strict}._header_12qch_49{position:-webkit-sticky;position:sticky;top:0;z-index:2;contain:layout}._header-white_12qch_55{background-color:var(--white)}._header-gray_12qch_58{background-color:var(--black-5)}._headerCell_12qch_62{overflow:hidden;font-weight:600;white-space:nowrap;text-align:left;text-overflow:ellipsis;border-bottom:1px solid var(--black-20);contain:content}._headerContent_12qch_72{display:flex;align-items:center;justify-content:space-between}._headerText_12qch_78{flex:1;margin:var(--mimir-space-m);color:var(--black-60)}._sortButton_12qch_84{display:flex;align-items:center;margin:var(--mimir-space-l) var(--mimir-space-l) var(--mimir-space-l) 0;padding:0;background:none;border:none;cursor:pointer;transition:opacity .15s ease;-webkit-tap-highlight-color:transparent}._sortButton_12qch_84:hover{opacity:.8}@media (max-width: 1279.1px){._sortButton_12qch_84{margin:var(--mimir-space-s) var(--mimir-space-s) var(--mimir-space-s) 0}}._sortIcon_12qch_104{display:flex;align-items:center;justify-content:center;width:var(--mimir-space-m);height:var(--mimir-space-m)}._selectHeaderCell_12qch_112{width:var(--mimir-space-5xl);border-bottom:1px solid var(--black-20)}@media (max-width: 1279.1px){._selectHeaderCell_12qch_112{width:var(--mimir-space-xxl)}}._body_12qch_122{background-color:var(--white);contain:content}._virtualBody_12qch_127{position:relative;top:1px;width:100%}._rowWhiteBackground_12qch_133{background-color:var(--white);contain:layout}._rowGrayBackground_12qch_138{background-color:var(--black-5);contain:layout}._row-white-header_12qch_143:nth-child(odd){background-color:var(--white)}._row-white-header_12qch_143:nth-child(2n){background-color:var(--black-5)}._row-gray-header_12qch_149:nth-child(odd){background-color:var(--black-5)}._row-gray-header_12qch_149:nth-child(2n){background-color:var(--white)}._cell_12qch_156{padding:var(--mimir-space-2m) var(--mimir-space-m);overflow:hidden;white-space:normal;text-overflow:ellipsis;vertical-align:top;contain:content}@media (max-width: 768px){._cell_12qch_156{font-size:var(--mimir-size-text-s);line-height:var(--mimir-line-height-text-m1)}}._selectCell_12qch_171{padding:var(--mimir-space-m);vertical-align:top}@media (max-width: 1279.9px){._selectCell_12qch_171{padding:var(--mimir-space-xs)}}._loaderOverlay_12qch_181{position:absolute;top:0;right:0;bottom:0;left:0;z-index:100;display:flex;align-items:center;justify-content:center;background-color:var(--white-transparent);pointer-events:none}._cardsContainer_12qch_192{display:flex;flex-direction:column;gap:var(--mimir-space-xl);width:100%}._cardsVirtualContainer_12qch_199{width:100%}._cardActions_12qch_203{position:absolute;top:var(--mimir-space-m);right:var(--mimir-space-xss);display:flex;align-items:center;justify-content:center;cursor:pointer}._tableCard_12qch_213{position:relative;display:flex;flex-direction:column;gap:var(--mimir-space-m);padding:var(--mimir-space-m) var(--mimir-space-xss) var(--mimir-space-m) var(--mimir-space-m);background-color:var(--white);border-bottom:2px solid var(--citrine-100)}._cardCheckbox_12qch_223{align-self:flex-start;margin-right:var(--mimir-space-m)}._cardContent_12qch_228{display:flex;flex:1;flex-direction:column;gap:var(--mimir-space-m)}._cardValue_12qch_235{color:var(--black-100);font-weight:var(--mimir-font-weight-text-medium);font-size:var(--mimir-size-text-l);line-height:var(--mimir-line-height-text-s1)}._cardArrow_12qch_242{display:flex;align-items:center;justify-content:end;pointer-events:none}._cardHeader_12qch_249{margin-top:var(--mimir-space-2xs);color:var(--black-60);font-size:var(--mimir-size-text-s);line-height:var(--mimir-line-height-text-xss1)}
|
@@ -0,0 +1,508 @@
|
|
1
|
+
import { n as W, u as Ae, d as fe, o as f, M as Re, W as ae, a as te, H as ue, y as pe, p as Ke, $ as Le, b as ke, D as Oe, I as je, s as qe, c as D } from "./keyboard-CUMsrFX1.js";
|
2
|
+
import { u as Ye } from "./index-D5H8gPPn.js";
|
3
|
+
import w, { useRef as H, useEffect as Ne, useState as Se, createContext as he, useReducer as Xe, createRef as Qe, useCallback as ge, useMemo as j, useId as ve, useContext as Ie, Fragment as Ve } from "react";
|
4
|
+
import { flushSync as ee } from "react-dom";
|
5
|
+
import { w as Je } from "./use-active-press-BVQqDQ3V.js";
|
6
|
+
import { u as Ze } from "./use-by-comparator-CVuf9KBq.js";
|
7
|
+
import { K as et, a as tt, b as ot, T as nt, z as it, j as rt, u as lt, I as Te, G as at } from "./label-DOlEWXBl.js";
|
8
|
+
import { c as ut, E as st, R as dt, v as ct, y as pt, n as He, x as vt, a as mt, b as bt, m as ft, f as gt, d as we, t as xt, g as Et } from "./portal-C_u5auU1.js";
|
9
|
+
import { e as Ot } from "./use-resolve-button-type-DhFdPxnv.js";
|
10
|
+
import { c as St, i as ce, u as ht, R as It, H as Tt } from "./open-closed-CkTbpRyi.js";
|
11
|
+
import { f as yt, _ as Ct } from "./focus-management-Dp2_vbQ3.js";
|
12
|
+
import { r as $t } from "./bugs-diTMAGNw.js";
|
13
|
+
let xe = /* @__PURE__ */ new Map(), re = /* @__PURE__ */ new Map();
|
14
|
+
function Pe(e) {
|
15
|
+
var t;
|
16
|
+
let o = (t = re.get(e)) != null ? t : 0;
|
17
|
+
return re.set(e, o + 1), o !== 0 ? () => Me(e) : (xe.set(e, { "aria-hidden": e.getAttribute("aria-hidden"), inert: e.inert }), e.setAttribute("aria-hidden", "true"), e.inert = !0, () => Me(e));
|
18
|
+
}
|
19
|
+
function Me(e) {
|
20
|
+
var t;
|
21
|
+
let o = (t = re.get(e)) != null ? t : 1;
|
22
|
+
if (o === 1 ? re.delete(e) : re.set(e, o - 1), o !== 1) return;
|
23
|
+
let i = xe.get(e);
|
24
|
+
i && (i["aria-hidden"] === null ? e.removeAttribute("aria-hidden") : e.setAttribute("aria-hidden", i["aria-hidden"]), e.inert = i.inert, xe.delete(e));
|
25
|
+
}
|
26
|
+
function Rt(e, { allowed: t, disallowed: o } = {}) {
|
27
|
+
let i = ut(e, "inert-others");
|
28
|
+
W(() => {
|
29
|
+
var a, r;
|
30
|
+
if (!i) return;
|
31
|
+
let l = fe();
|
32
|
+
for (let s of (a = o == null ? void 0 : o()) != null ? a : []) s && l.add(Pe(s));
|
33
|
+
let n = (r = t == null ? void 0 : t()) != null ? r : [];
|
34
|
+
for (let s of n) {
|
35
|
+
if (!s) continue;
|
36
|
+
let c = Ae(s);
|
37
|
+
if (!c) continue;
|
38
|
+
let v = s.parentElement;
|
39
|
+
for (; v && v !== c.body; ) {
|
40
|
+
for (let g of v.children) n.some((E) => g.contains(E)) || l.add(Pe(g));
|
41
|
+
v = v.parentElement;
|
42
|
+
}
|
43
|
+
}
|
44
|
+
return l.dispose;
|
45
|
+
}, [i, t, o]);
|
46
|
+
}
|
47
|
+
function Be(e) {
|
48
|
+
let t = H({ value: "", selectionStart: null, selectionEnd: null });
|
49
|
+
return st(e, "blur", (o) => {
|
50
|
+
let i = o.target;
|
51
|
+
i instanceof HTMLInputElement && (t.current = { value: i.value, selectionStart: i.selectionStart, selectionEnd: i.selectionEnd });
|
52
|
+
}), f(() => {
|
53
|
+
if (document.activeElement !== e && e instanceof HTMLInputElement && e.isConnected) {
|
54
|
+
if (e.focus({ preventScroll: !0 }), e.value !== t.current.value) e.setSelectionRange(e.value.length, e.value.length);
|
55
|
+
else {
|
56
|
+
let { selectionStart: o, selectionEnd: i } = t.current;
|
57
|
+
o !== null && i !== null && e.setSelectionRange(o, i);
|
58
|
+
}
|
59
|
+
t.current = { value: "", selectionStart: null, selectionEnd: null };
|
60
|
+
}
|
61
|
+
});
|
62
|
+
}
|
63
|
+
function Fe(e) {
|
64
|
+
return [e.screenX, e.screenY];
|
65
|
+
}
|
66
|
+
function wt() {
|
67
|
+
let e = H([-1, -1]);
|
68
|
+
return { wasMoved(t) {
|
69
|
+
let o = Fe(t);
|
70
|
+
return e.current[0] === o[0] && e.current[1] === o[1] ? !1 : (e.current = o, !0);
|
71
|
+
}, update(t) {
|
72
|
+
e.current = Fe(t);
|
73
|
+
} };
|
74
|
+
}
|
75
|
+
function Pt(e, { container: t, accept: o, walk: i }) {
|
76
|
+
let a = H(o), r = H(i);
|
77
|
+
Ne(() => {
|
78
|
+
a.current = o, r.current = i;
|
79
|
+
}, [o, i]), W(() => {
|
80
|
+
if (!t || !e) return;
|
81
|
+
let l = Ae(t);
|
82
|
+
if (!l) return;
|
83
|
+
let n = a.current, s = r.current, c = Object.assign((g) => n(g), { acceptNode: n }), v = l.createTreeWalker(t, NodeFilter.SHOW_ELEMENT, c, !1);
|
84
|
+
for (; v.nextNode(); ) s(v.currentNode);
|
85
|
+
}, [t, e, a, r]);
|
86
|
+
}
|
87
|
+
function _e(e, t) {
|
88
|
+
let o = H([]), i = f(e);
|
89
|
+
Ne(() => {
|
90
|
+
let a = [...o.current];
|
91
|
+
for (let [r, l] of t.entries()) if (o.current[r] !== l) {
|
92
|
+
let n = i(t, a);
|
93
|
+
return o.current = t, n;
|
94
|
+
}
|
95
|
+
}, [i, ...t]);
|
96
|
+
}
|
97
|
+
function Mt({ children: e, freeze: t }) {
|
98
|
+
let o = Ee(t, e);
|
99
|
+
return w.createElement(w.Fragment, null, o);
|
100
|
+
}
|
101
|
+
function Ee(e, t) {
|
102
|
+
let [o, i] = Se(t);
|
103
|
+
return !e && o !== t && i(t), e ? o : t;
|
104
|
+
}
|
105
|
+
function Ft(e) {
|
106
|
+
function t() {
|
107
|
+
document.readyState !== "loading" && (e(), document.removeEventListener("DOMContentLoaded", t));
|
108
|
+
}
|
109
|
+
typeof window < "u" && typeof document < "u" && (document.addEventListener("DOMContentLoaded", t), t());
|
110
|
+
}
|
111
|
+
let J = [];
|
112
|
+
Ft(() => {
|
113
|
+
function e(t) {
|
114
|
+
if (!(t.target instanceof HTMLElement) || t.target === document.body || J[0] === t.target) return;
|
115
|
+
let o = t.target;
|
116
|
+
o = o.closest(yt), J.unshift(o ?? t.target), J = J.filter((i) => i != null && i.isConnected), J.splice(10);
|
117
|
+
}
|
118
|
+
window.addEventListener("click", e, { capture: !0 }), window.addEventListener("mousedown", e, { capture: !0 }), window.addEventListener("focus", e, { capture: !0 }), document.body.addEventListener("click", e, { capture: !0 }), document.body.addEventListener("mousedown", e, { capture: !0 }), document.body.addEventListener("focus", e, { capture: !0 });
|
119
|
+
});
|
120
|
+
function _t(e) {
|
121
|
+
throw new Error("Unexpected object: " + e);
|
122
|
+
}
|
123
|
+
var C = ((e) => (e[e.First = 0] = "First", e[e.Previous = 1] = "Previous", e[e.Next = 2] = "Next", e[e.Last = 3] = "Last", e[e.Specific = 4] = "Specific", e[e.Nothing = 5] = "Nothing", e))(C || {});
|
124
|
+
function De(e, t) {
|
125
|
+
let o = t.resolveItems();
|
126
|
+
if (o.length <= 0) return null;
|
127
|
+
let i = t.resolveActiveIndex(), a = i ?? -1;
|
128
|
+
switch (e.focus) {
|
129
|
+
case 0: {
|
130
|
+
for (let r = 0; r < o.length; ++r) if (!t.resolveDisabled(o[r], r, o)) return r;
|
131
|
+
return i;
|
132
|
+
}
|
133
|
+
case 1: {
|
134
|
+
a === -1 && (a = o.length);
|
135
|
+
for (let r = a - 1; r >= 0; --r) if (!t.resolveDisabled(o[r], r, o)) return r;
|
136
|
+
return i;
|
137
|
+
}
|
138
|
+
case 2: {
|
139
|
+
for (let r = a + 1; r < o.length; ++r) if (!t.resolveDisabled(o[r], r, o)) return r;
|
140
|
+
return i;
|
141
|
+
}
|
142
|
+
case 3: {
|
143
|
+
for (let r = o.length - 1; r >= 0; --r) if (!t.resolveDisabled(o[r], r, o)) return r;
|
144
|
+
return i;
|
145
|
+
}
|
146
|
+
case 4: {
|
147
|
+
for (let r = 0; r < o.length; ++r) if (t.resolveId(o[r], r, o) === e.id) return r;
|
148
|
+
return i;
|
149
|
+
}
|
150
|
+
case 5:
|
151
|
+
return null;
|
152
|
+
default:
|
153
|
+
_t(e);
|
154
|
+
}
|
155
|
+
}
|
156
|
+
var ye = ((e) => (e[e.Left = 0] = "Left", e[e.Right = 2] = "Right", e))(ye || {}), Dt = ((e) => (e[e.Open = 0] = "Open", e[e.Closed = 1] = "Closed", e))(Dt || {}), At = ((e) => (e[e.Single = 0] = "Single", e[e.Multi = 1] = "Multi", e))(At || {}), Lt = ((e) => (e[e.Pointer = 0] = "Pointer", e[e.Focus = 1] = "Focus", e[e.Other = 2] = "Other", e))(Lt || {}), kt = ((e) => (e[e.OpenCombobox = 0] = "OpenCombobox", e[e.CloseCombobox = 1] = "CloseCombobox", e[e.GoToOption = 2] = "GoToOption", e[e.SetTyping = 3] = "SetTyping", e[e.RegisterOption = 4] = "RegisterOption", e[e.UnregisterOption = 5] = "UnregisterOption", e[e.SetActivationTrigger = 6] = "SetActivationTrigger", e[e.UpdateVirtualConfiguration = 7] = "UpdateVirtualConfiguration", e[e.SetInputElement = 8] = "SetInputElement", e[e.SetButtonElement = 9] = "SetButtonElement", e[e.SetOptionsElement = 10] = "SetOptionsElement", e))(kt || {});
|
157
|
+
function be(e, t = (o) => o) {
|
158
|
+
let o = e.activeOptionIndex !== null ? e.options[e.activeOptionIndex] : null, i = t(e.options.slice()), a = i.length > 0 && i[0].dataRef.current.order !== null ? i.sort((l, n) => l.dataRef.current.order - n.dataRef.current.order) : Ct(i, (l) => l.dataRef.current.domRef.current), r = o ? a.indexOf(o) : null;
|
159
|
+
return r === -1 && (r = null), { options: a, activeOptionIndex: r };
|
160
|
+
}
|
161
|
+
let Nt = { 1(e) {
|
162
|
+
var t;
|
163
|
+
return (t = e.dataRef.current) != null && t.disabled || e.comboboxState === 1 ? e : { ...e, activeOptionIndex: null, comboboxState: 1, isTyping: !1, activationTrigger: 2, __demoMode: !1 };
|
164
|
+
}, 0(e) {
|
165
|
+
var t, o;
|
166
|
+
if ((t = e.dataRef.current) != null && t.disabled || e.comboboxState === 0) return e;
|
167
|
+
if ((o = e.dataRef.current) != null && o.value) {
|
168
|
+
let i = e.dataRef.current.calculateIndex(e.dataRef.current.value);
|
169
|
+
if (i !== -1) return { ...e, activeOptionIndex: i, comboboxState: 0, __demoMode: !1 };
|
170
|
+
}
|
171
|
+
return { ...e, comboboxState: 0, __demoMode: !1 };
|
172
|
+
}, 3(e, t) {
|
173
|
+
return e.isTyping === t.isTyping ? e : { ...e, isTyping: t.isTyping };
|
174
|
+
}, 2(e, t) {
|
175
|
+
var o, i, a, r;
|
176
|
+
if ((o = e.dataRef.current) != null && o.disabled || e.optionsElement && !((i = e.dataRef.current) != null && i.optionsPropsRef.current.static) && e.comboboxState === 1) return e;
|
177
|
+
if (e.virtual) {
|
178
|
+
let { options: c, disabled: v } = e.virtual, g = t.focus === C.Specific ? t.idx : De(t, { resolveItems: () => c, resolveActiveIndex: () => {
|
179
|
+
var u, T;
|
180
|
+
return (T = (u = e.activeOptionIndex) != null ? u : c.findIndex((O) => !v(O))) != null ? T : null;
|
181
|
+
}, resolveDisabled: v, resolveId() {
|
182
|
+
throw new Error("Function not implemented.");
|
183
|
+
} }), E = (a = t.trigger) != null ? a : 2;
|
184
|
+
return e.activeOptionIndex === g && e.activationTrigger === E ? e : { ...e, activeOptionIndex: g, activationTrigger: E, isTyping: !1, __demoMode: !1 };
|
185
|
+
}
|
186
|
+
let l = be(e);
|
187
|
+
if (l.activeOptionIndex === null) {
|
188
|
+
let c = l.options.findIndex((v) => !v.dataRef.current.disabled);
|
189
|
+
c !== -1 && (l.activeOptionIndex = c);
|
190
|
+
}
|
191
|
+
let n = t.focus === C.Specific ? t.idx : De(t, { resolveItems: () => l.options, resolveActiveIndex: () => l.activeOptionIndex, resolveId: (c) => c.id, resolveDisabled: (c) => c.dataRef.current.disabled }), s = (r = t.trigger) != null ? r : 2;
|
192
|
+
return e.activeOptionIndex === n && e.activationTrigger === s ? e : { ...e, ...l, isTyping: !1, activeOptionIndex: n, activationTrigger: s, __demoMode: !1 };
|
193
|
+
}, 4: (e, t) => {
|
194
|
+
var o, i, a;
|
195
|
+
if ((o = e.dataRef.current) != null && o.virtual) return { ...e, options: [...e.options, t.payload] };
|
196
|
+
let r = t.payload, l = be(e, (s) => (s.push(r), s));
|
197
|
+
e.activeOptionIndex === null && (i = e.dataRef.current) != null && i.isSelected(t.payload.dataRef.current.value) && (l.activeOptionIndex = l.options.indexOf(r));
|
198
|
+
let n = { ...e, ...l, activationTrigger: 2 };
|
199
|
+
return (a = e.dataRef.current) != null && a.__demoMode && e.dataRef.current.value === void 0 && (n.activeOptionIndex = 0), n;
|
200
|
+
}, 5: (e, t) => {
|
201
|
+
var o;
|
202
|
+
if ((o = e.dataRef.current) != null && o.virtual) return { ...e, options: e.options.filter((a) => a.id !== t.id) };
|
203
|
+
let i = be(e, (a) => {
|
204
|
+
let r = a.findIndex((l) => l.id === t.id);
|
205
|
+
return r !== -1 && a.splice(r, 1), a;
|
206
|
+
});
|
207
|
+
return { ...e, ...i, activationTrigger: 2 };
|
208
|
+
}, 6: (e, t) => e.activationTrigger === t.trigger ? e : { ...e, activationTrigger: t.trigger }, 7: (e, t) => {
|
209
|
+
var o, i;
|
210
|
+
if (e.virtual === null) return { ...e, virtual: { options: t.options, disabled: (o = t.disabled) != null ? o : () => !1 } };
|
211
|
+
if (e.virtual.options === t.options && e.virtual.disabled === t.disabled) return e;
|
212
|
+
let a = e.activeOptionIndex;
|
213
|
+
if (e.activeOptionIndex !== null) {
|
214
|
+
let r = t.options.indexOf(e.virtual.options[e.activeOptionIndex]);
|
215
|
+
r !== -1 ? a = r : a = null;
|
216
|
+
}
|
217
|
+
return { ...e, activeOptionIndex: a, virtual: { options: t.options, disabled: (i = t.disabled) != null ? i : () => !1 } };
|
218
|
+
}, 8: (e, t) => e.inputElement === t.element ? e : { ...e, inputElement: t.element }, 9: (e, t) => e.buttonElement === t.element ? e : { ...e, buttonElement: t.element }, 10: (e, t) => e.optionsElement === t.element ? e : { ...e, optionsElement: t.element } }, Ce = he(null);
|
219
|
+
Ce.displayName = "ComboboxActionsContext";
|
220
|
+
function se(e) {
|
221
|
+
let t = Ie(Ce);
|
222
|
+
if (t === null) {
|
223
|
+
let o = new Error(`<${e} /> is missing a parent <Combobox /> component.`);
|
224
|
+
throw Error.captureStackTrace && Error.captureStackTrace(o, se), o;
|
225
|
+
}
|
226
|
+
return t;
|
227
|
+
}
|
228
|
+
let Ue = he(null);
|
229
|
+
function Vt(e) {
|
230
|
+
let t = oe("VirtualProvider"), { options: o } = t.virtual, [i, a] = j(() => {
|
231
|
+
let c = t.optionsElement;
|
232
|
+
if (!c) return [0, 0];
|
233
|
+
let v = window.getComputedStyle(c);
|
234
|
+
return [parseFloat(v.paddingBlockStart || v.paddingTop), parseFloat(v.paddingBlockEnd || v.paddingBottom)];
|
235
|
+
}, [t.optionsElement]), r = Ye({ enabled: o.length !== 0, scrollPaddingStart: i, scrollPaddingEnd: a, count: o.length, estimateSize() {
|
236
|
+
return 40;
|
237
|
+
}, getScrollElement() {
|
238
|
+
return t.optionsElement;
|
239
|
+
}, overscan: 12 }), [l, n] = Se(0);
|
240
|
+
W(() => {
|
241
|
+
n((c) => c + 1);
|
242
|
+
}, [o]);
|
243
|
+
let s = r.getVirtualItems();
|
244
|
+
return s.length === 0 ? null : w.createElement(Ue.Provider, { value: r }, w.createElement("div", { style: { position: "relative", width: "100%", height: `${r.getTotalSize()}px` }, ref: (c) => {
|
245
|
+
if (c) {
|
246
|
+
if (typeof process < "u" && process.env.JEST_WORKER_ID !== void 0 || t.activationTrigger === 0) return;
|
247
|
+
t.activeOptionIndex !== null && o.length > t.activeOptionIndex && r.scrollToIndex(t.activeOptionIndex);
|
248
|
+
}
|
249
|
+
} }, s.map((c) => {
|
250
|
+
var v;
|
251
|
+
return w.createElement(Ve, { key: c.key }, w.cloneElement((v = e.children) == null ? void 0 : v.call(e, { ...e.slot, option: o[c.index] }), { key: `${l}-${c.key}`, "data-index": c.index, "aria-setsize": o.length, "aria-posinset": c.index + 1, style: { position: "absolute", top: 0, left: 0, transform: `translateY(${c.start}px)`, overflowAnchor: "none" } }));
|
252
|
+
})));
|
253
|
+
}
|
254
|
+
let le = he(null);
|
255
|
+
le.displayName = "ComboboxDataContext";
|
256
|
+
function oe(e) {
|
257
|
+
let t = Ie(le);
|
258
|
+
if (t === null) {
|
259
|
+
let o = new Error(`<${e} /> is missing a parent <Combobox /> component.`);
|
260
|
+
throw Error.captureStackTrace && Error.captureStackTrace(o, oe), o;
|
261
|
+
}
|
262
|
+
return t;
|
263
|
+
}
|
264
|
+
function Ht(e, t) {
|
265
|
+
return te(t.type, Nt, e, t);
|
266
|
+
}
|
267
|
+
let Bt = Ve;
|
268
|
+
function Ut(e, t) {
|
269
|
+
var o, i;
|
270
|
+
let a = tt(), { value: r, defaultValue: l, onChange: n, form: s, name: c, by: v, disabled: g = a || !1, onClose: E, __demoMode: u = !1, multiple: T = !1, immediate: O = !1, virtual: b = null, nullable: k, ...A } = e, M = ot(l), [y = T ? [] : void 0, P] = nt(r, n, M), [h, I] = Xe(Ht, { dataRef: Qe(), comboboxState: u ? 0 : 1, isTyping: !1, options: [], virtual: b ? { options: b.options, disabled: (o = b.disabled) != null ? o : () => !1 } : null, activeOptionIndex: null, activationTrigger: 2, inputElement: null, buttonElement: null, optionsElement: null, __demoMode: u }), x = H(!1), G = H({ static: !1, hold: !1 }), L = Ze(v), z = f((m) => b ? v === null ? b.options.indexOf(m) : b.options.findIndex((S) => L(S, m)) : h.options.findIndex((S) => L(S.dataRef.current.value, m))), q = ge((m) => te(d.mode, { 1: () => y.some((S) => L(S, m)), 0: () => L(y, m) }), [y]), K = f((m) => h.activeOptionIndex === z(m)), d = j(() => ({ ...h, immediate: O, optionsPropsRef: G, value: y, defaultValue: M, disabled: g, mode: T ? 1 : 0, virtual: b ? h.virtual : null, get activeOptionIndex() {
|
271
|
+
if (x.current && h.activeOptionIndex === null && (b ? b.options.length > 0 : h.options.length > 0)) {
|
272
|
+
if (b) {
|
273
|
+
let S = b.options.findIndex((U) => {
|
274
|
+
var de, $e;
|
275
|
+
return !(($e = (de = b.disabled) == null ? void 0 : de.call(b, U)) != null && $e);
|
276
|
+
});
|
277
|
+
if (S !== -1) return S;
|
278
|
+
}
|
279
|
+
let m = h.options.findIndex((S) => !S.dataRef.current.disabled);
|
280
|
+
if (m !== -1) return m;
|
281
|
+
}
|
282
|
+
return h.activeOptionIndex;
|
283
|
+
}, calculateIndex: z, compare: L, isSelected: q, isActive: K }), [y, M, g, T, u, h, b]);
|
284
|
+
W(() => {
|
285
|
+
var m;
|
286
|
+
b && I({ type: 7, options: b.options, disabled: (m = b.disabled) != null ? m : null });
|
287
|
+
}, [b, b == null ? void 0 : b.options, b == null ? void 0 : b.disabled]), W(() => {
|
288
|
+
h.dataRef.current = d;
|
289
|
+
}, [d]);
|
290
|
+
let B = d.comboboxState === 0;
|
291
|
+
dt(B, [d.buttonElement, d.inputElement, d.optionsElement], () => _.closeCombobox());
|
292
|
+
let ne = j(() => {
|
293
|
+
var m, S, U;
|
294
|
+
return { open: d.comboboxState === 0, disabled: g, activeIndex: d.activeOptionIndex, activeOption: d.activeOptionIndex === null ? null : d.virtual ? d.virtual.options[(m = d.activeOptionIndex) != null ? m : 0] : (U = (S = d.options[d.activeOptionIndex]) == null ? void 0 : S.dataRef.current.value) != null ? U : null, value: y };
|
295
|
+
}, [d, g, y]), Y = f(() => {
|
296
|
+
if (d.activeOptionIndex !== null) {
|
297
|
+
if (_.setIsTyping(!1), d.virtual) p(d.virtual.options[d.activeOptionIndex]);
|
298
|
+
else {
|
299
|
+
let { dataRef: m } = d.options[d.activeOptionIndex];
|
300
|
+
p(m.current.value);
|
301
|
+
}
|
302
|
+
_.goToOption(C.Specific, d.activeOptionIndex);
|
303
|
+
}
|
304
|
+
}), X = f(() => {
|
305
|
+
I({ type: 0 }), x.current = !0;
|
306
|
+
}), Z = f(() => {
|
307
|
+
I({ type: 1 }), x.current = !1, E == null || E();
|
308
|
+
}), ie = f((m) => {
|
309
|
+
I({ type: 3, isTyping: m });
|
310
|
+
}), F = f((m, S, U) => (x.current = !1, m === C.Specific ? I({ type: 2, focus: C.Specific, idx: S, trigger: U }) : I({ type: 2, focus: m, trigger: U }))), me = f((m, S) => (I({ type: 4, payload: { id: m, dataRef: S } }), () => {
|
311
|
+
d.isActive(S.current.value) && (x.current = !0), I({ type: 5, id: m });
|
312
|
+
})), p = f((m) => te(d.mode, { 0() {
|
313
|
+
return P == null ? void 0 : P(m);
|
314
|
+
}, 1() {
|
315
|
+
let S = d.value.slice(), U = S.findIndex((de) => L(de, m));
|
316
|
+
return U === -1 ? S.push(m) : S.splice(U, 1), P == null ? void 0 : P(S);
|
317
|
+
} })), N = f((m) => {
|
318
|
+
I({ type: 6, trigger: m });
|
319
|
+
}), R = f((m) => {
|
320
|
+
I({ type: 8, element: m });
|
321
|
+
}), V = f((m) => {
|
322
|
+
I({ type: 9, element: m });
|
323
|
+
}), $ = f((m) => {
|
324
|
+
I({ type: 10, element: m });
|
325
|
+
}), _ = j(() => ({ onChange: p, registerOption: me, goToOption: F, setIsTyping: ie, closeCombobox: Z, openCombobox: X, setActivationTrigger: N, selectActiveOption: Y, setInputElement: R, setButtonElement: V, setOptionsElement: $ }), []), [Q, We] = it(), Ge = t === null ? {} : { ref: t }, ze = ge(() => {
|
326
|
+
if (M !== void 0) return P == null ? void 0 : P(M);
|
327
|
+
}, [P, M]);
|
328
|
+
return w.createElement(We, { value: Q, props: { htmlFor: (i = d.inputElement) == null ? void 0 : i.id }, slot: { open: d.comboboxState === 0, disabled: g } }, w.createElement(ct, null, w.createElement(Ce.Provider, { value: _ }, w.createElement(le.Provider, { value: d }, w.createElement(St, { value: te(d.comboboxState, { 0: ce.Open, 1: ce.Closed }) }, c != null && w.createElement(rt, { disabled: g, data: y != null ? { [c]: y } : {}, form: s, onReset: ze }), ue({ ourProps: Ge, theirProps: A, slot: ne, defaultTag: Bt, name: "Combobox" }))))));
|
329
|
+
}
|
330
|
+
let Wt = "input";
|
331
|
+
function Gt(e, t) {
|
332
|
+
var o, i, a, r, l;
|
333
|
+
let n = oe("Combobox.Input"), s = se("Combobox.Input"), c = ve(), v = lt(), { id: g = v || `headlessui-combobox-input-${c}`, onChange: E, displayValue: u, disabled: T = n.disabled || !1, autoFocus: O = !1, type: b = "text", ...k } = e, A = H(null), M = pe(A, t, pt(), s.setInputElement), y = He(n.inputElement), P = Ke(), h = f(() => {
|
334
|
+
s.onChange(null), n.optionsElement && (n.optionsElement.scrollTop = 0), s.goToOption(C.Nothing);
|
335
|
+
}), I = j(() => {
|
336
|
+
var p;
|
337
|
+
return typeof u == "function" && n.value !== void 0 ? (p = u(n.value)) != null ? p : "" : typeof n.value == "string" ? n.value : "";
|
338
|
+
}, [n.value, u]);
|
339
|
+
_e(([p, N], [R, V]) => {
|
340
|
+
if (n.isTyping) return;
|
341
|
+
let $ = A.current;
|
342
|
+
$ && ((V === 0 && N === 1 || p !== R) && ($.value = p), requestAnimationFrame(() => {
|
343
|
+
if (n.isTyping || !$ || (y == null ? void 0 : y.activeElement) !== $) return;
|
344
|
+
let { selectionStart: _, selectionEnd: Q } = $;
|
345
|
+
Math.abs((Q ?? 0) - (_ ?? 0)) === 0 && _ === 0 && $.setSelectionRange($.value.length, $.value.length);
|
346
|
+
}));
|
347
|
+
}, [I, n.comboboxState, y, n.isTyping]), _e(([p], [N]) => {
|
348
|
+
if (p === 0 && N === 1) {
|
349
|
+
if (n.isTyping) return;
|
350
|
+
let R = A.current;
|
351
|
+
if (!R) return;
|
352
|
+
let V = R.value, { selectionStart: $, selectionEnd: _, selectionDirection: Q } = R;
|
353
|
+
R.value = "", R.value = V, Q !== null ? R.setSelectionRange($, _, Q) : R.setSelectionRange($, _);
|
354
|
+
}
|
355
|
+
}, [n.comboboxState]);
|
356
|
+
let x = H(!1), G = f(() => {
|
357
|
+
x.current = !0;
|
358
|
+
}), L = f(() => {
|
359
|
+
P.nextFrame(() => {
|
360
|
+
x.current = !1;
|
361
|
+
});
|
362
|
+
}), z = f((p) => {
|
363
|
+
switch (s.setIsTyping(!0), p.key) {
|
364
|
+
case D.Enter:
|
365
|
+
if (n.comboboxState !== 0 || x.current) return;
|
366
|
+
if (p.preventDefault(), p.stopPropagation(), n.activeOptionIndex === null) {
|
367
|
+
s.closeCombobox();
|
368
|
+
return;
|
369
|
+
}
|
370
|
+
s.selectActiveOption(), n.mode === 0 && s.closeCombobox();
|
371
|
+
break;
|
372
|
+
case D.ArrowDown:
|
373
|
+
return p.preventDefault(), p.stopPropagation(), te(n.comboboxState, { 0: () => s.goToOption(C.Next), 1: () => s.openCombobox() });
|
374
|
+
case D.ArrowUp:
|
375
|
+
return p.preventDefault(), p.stopPropagation(), te(n.comboboxState, { 0: () => s.goToOption(C.Previous), 1: () => {
|
376
|
+
ee(() => s.openCombobox()), n.value || s.goToOption(C.Last);
|
377
|
+
} });
|
378
|
+
case D.Home:
|
379
|
+
if (p.shiftKey) break;
|
380
|
+
return p.preventDefault(), p.stopPropagation(), s.goToOption(C.First);
|
381
|
+
case D.PageUp:
|
382
|
+
return p.preventDefault(), p.stopPropagation(), s.goToOption(C.First);
|
383
|
+
case D.End:
|
384
|
+
if (p.shiftKey) break;
|
385
|
+
return p.preventDefault(), p.stopPropagation(), s.goToOption(C.Last);
|
386
|
+
case D.PageDown:
|
387
|
+
return p.preventDefault(), p.stopPropagation(), s.goToOption(C.Last);
|
388
|
+
case D.Escape:
|
389
|
+
return n.comboboxState !== 0 ? void 0 : (p.preventDefault(), n.optionsElement && !n.optionsPropsRef.current.static && p.stopPropagation(), n.mode === 0 && n.value === null && h(), s.closeCombobox());
|
390
|
+
case D.Tab:
|
391
|
+
if (n.comboboxState !== 0) return;
|
392
|
+
n.mode === 0 && n.activationTrigger !== 1 && s.selectActiveOption(), s.closeCombobox();
|
393
|
+
break;
|
394
|
+
}
|
395
|
+
}), q = f((p) => {
|
396
|
+
E == null || E(p), n.mode === 0 && p.target.value === "" && h(), s.openCombobox();
|
397
|
+
}), K = f((p) => {
|
398
|
+
var N, R, V;
|
399
|
+
let $ = (N = p.relatedTarget) != null ? N : J.find((_) => _ !== p.currentTarget);
|
400
|
+
if (!((R = n.optionsElement) != null && R.contains($)) && !((V = n.buttonElement) != null && V.contains($)) && n.comboboxState === 0) return p.preventDefault(), n.mode === 0 && n.value === null && h(), s.closeCombobox();
|
401
|
+
}), d = f((p) => {
|
402
|
+
var N, R, V;
|
403
|
+
let $ = (N = p.relatedTarget) != null ? N : J.find((_) => _ !== p.currentTarget);
|
404
|
+
(R = n.buttonElement) != null && R.contains($) || (V = n.optionsElement) != null && V.contains($) || n.disabled || n.immediate && n.comboboxState !== 0 && P.microTask(() => {
|
405
|
+
ee(() => s.openCombobox()), s.setActivationTrigger(1);
|
406
|
+
});
|
407
|
+
}), B = Te(), ne = at(), { isFocused: Y, focusProps: X } = Le({ autoFocus: O }), { isHovered: Z, hoverProps: ie } = ke({ isDisabled: T }), F = j(() => ({ open: n.comboboxState === 0, disabled: T, hover: Z, focus: Y, autofocus: O }), [n, Z, Y, O, T]), me = Oe({ ref: M, id: g, role: "combobox", type: b, "aria-controls": (o = n.optionsElement) == null ? void 0 : o.id, "aria-expanded": n.comboboxState === 0, "aria-activedescendant": n.activeOptionIndex === null ? void 0 : n.virtual ? (i = n.options.find((p) => !p.dataRef.current.disabled && n.compare(p.dataRef.current.value, n.virtual.options[n.activeOptionIndex]))) == null ? void 0 : i.id : (a = n.options[n.activeOptionIndex]) == null ? void 0 : a.id, "aria-labelledby": B, "aria-describedby": ne, "aria-autocomplete": "list", defaultValue: (l = (r = e.defaultValue) != null ? r : n.defaultValue !== void 0 ? u == null ? void 0 : u(n.defaultValue) : null) != null ? l : n.defaultValue, disabled: T || void 0, autoFocus: O, onCompositionStart: G, onCompositionEnd: L, onKeyDown: z, onChange: q, onFocus: d, onBlur: K }, X, ie);
|
408
|
+
return ue({ ourProps: me, theirProps: k, slot: F, defaultTag: Wt, name: "Combobox.Input" });
|
409
|
+
}
|
410
|
+
let zt = "button";
|
411
|
+
function Kt(e, t) {
|
412
|
+
var o;
|
413
|
+
let i = oe("Combobox.Button"), a = se("Combobox.Button"), r = pe(t, a.setButtonElement), l = je(), n = ve(), { id: s = `headlessui-combobox-button-${n}`, disabled: c = i.disabled || !1, autoFocus: v = !1, ...g } = e, E = Be(i.inputElement), u = f((x) => {
|
414
|
+
switch (x.key) {
|
415
|
+
case D.Space:
|
416
|
+
case D.Enter:
|
417
|
+
x.preventDefault(), x.stopPropagation(), i.comboboxState === 1 && ee(() => a.openCombobox()), E();
|
418
|
+
return;
|
419
|
+
case D.ArrowDown:
|
420
|
+
x.preventDefault(), x.stopPropagation(), i.comboboxState === 1 && (ee(() => a.openCombobox()), i.value || a.goToOption(C.First)), E();
|
421
|
+
return;
|
422
|
+
case D.ArrowUp:
|
423
|
+
x.preventDefault(), x.stopPropagation(), i.comboboxState === 1 && (ee(() => a.openCombobox()), i.value || a.goToOption(C.Last)), E();
|
424
|
+
return;
|
425
|
+
case D.Escape:
|
426
|
+
if (i.comboboxState !== 0) return;
|
427
|
+
x.preventDefault(), i.optionsElement && !i.optionsPropsRef.current.static && x.stopPropagation(), ee(() => a.closeCombobox()), E();
|
428
|
+
return;
|
429
|
+
default:
|
430
|
+
return;
|
431
|
+
}
|
432
|
+
}), T = f((x) => {
|
433
|
+
x.preventDefault(), !$t(x.currentTarget) && (x.button === ye.Left && (i.comboboxState === 0 ? a.closeCombobox() : a.openCombobox()), E());
|
434
|
+
}), O = Te([s]), { isFocusVisible: b, focusProps: k } = Le({ autoFocus: v }), { isHovered: A, hoverProps: M } = ke({ isDisabled: c }), { pressed: y, pressProps: P } = Je({ disabled: c }), h = j(() => ({ open: i.comboboxState === 0, active: y || i.comboboxState === 0, disabled: c, value: i.value, hover: A, focus: b }), [i, A, b, y, c]), I = Oe({ ref: r, id: s, type: Ot(e, i.buttonElement), tabIndex: -1, "aria-haspopup": "listbox", "aria-controls": (o = i.optionsElement) == null ? void 0 : o.id, "aria-expanded": i.comboboxState === 0, "aria-labelledby": O, disabled: c || void 0, autoFocus: v, onMouseDown: T, onKeyDown: u }, k, M, P);
|
435
|
+
return ue({ mergeRefs: l, ourProps: I, theirProps: g, slot: h, defaultTag: zt, name: "Combobox.Button" });
|
436
|
+
}
|
437
|
+
let jt = "div", qt = Re.RenderStrategy | Re.Static;
|
438
|
+
function Yt(e, t) {
|
439
|
+
var o, i, a;
|
440
|
+
let r = ve(), { id: l = `headlessui-combobox-options-${r}`, hold: n = !1, anchor: s, portal: c = !1, modal: v = !0, transition: g = !1, ...E } = e, u = oe("Combobox.Options"), T = se("Combobox.Options"), O = vt(s);
|
441
|
+
O && (c = !0);
|
442
|
+
let [b, k] = mt(O), [A, M] = Se(null), y = bt(), P = pe(t, O ? b : null, T.setOptionsElement, M), h = He(u.optionsElement), I = ht(), [x, G] = It(g, A, I !== null ? (I & ce.Open) === ce.Open : u.comboboxState === 0);
|
443
|
+
ft(x, u.inputElement, T.closeCombobox);
|
444
|
+
let L = u.__demoMode ? !1 : v && u.comboboxState === 0;
|
445
|
+
gt(L, h);
|
446
|
+
let z = u.__demoMode ? !1 : v && u.comboboxState === 0;
|
447
|
+
Rt(z, { allowed: ge(() => [u.inputElement, u.buttonElement, u.optionsElement], [u.inputElement, u.buttonElement, u.optionsElement]) }), W(() => {
|
448
|
+
var F;
|
449
|
+
u.optionsPropsRef.current.static = (F = e.static) != null ? F : !1;
|
450
|
+
}, [u.optionsPropsRef, e.static]), W(() => {
|
451
|
+
u.optionsPropsRef.current.hold = n;
|
452
|
+
}, [u.optionsPropsRef, n]), Pt(u.comboboxState === 0, { container: u.optionsElement, accept(F) {
|
453
|
+
return F.getAttribute("role") === "option" ? NodeFilter.FILTER_REJECT : F.hasAttribute("role") ? NodeFilter.FILTER_SKIP : NodeFilter.FILTER_ACCEPT;
|
454
|
+
}, walk(F) {
|
455
|
+
F.setAttribute("role", "none");
|
456
|
+
} });
|
457
|
+
let q = Te([(o = u.buttonElement) == null ? void 0 : o.id]), K = j(() => ({ open: u.comboboxState === 0, option: void 0 }), [u.comboboxState]), d = f(() => {
|
458
|
+
T.setActivationTrigger(0);
|
459
|
+
}), B = f((F) => {
|
460
|
+
F.preventDefault(), T.setActivationTrigger(0);
|
461
|
+
}), ne = Oe(O ? y() : {}, { "aria-labelledby": q, role: "listbox", "aria-multiselectable": u.mode === 1 ? !0 : void 0, id: l, ref: P, style: { ...E.style, ...k, "--input-width": we(u.inputElement, !0).width, "--button-width": we(u.buttonElement, !0).width }, onWheel: u.activationTrigger === 0 ? void 0 : d, onMouseDown: B, ...Tt(G) }), Y = x && u.comboboxState === 1, X = Ee(Y, (i = u.virtual) == null ? void 0 : i.options), Z = Ee(Y, u.value), ie = f((F) => u.compare(Z, F));
|
462
|
+
if (u.virtual) {
|
463
|
+
if (X === void 0) throw new Error("Missing `options` in virtual mode");
|
464
|
+
Object.assign(E, { children: w.createElement(le.Provider, { value: X !== u.virtual.options ? { ...u, virtual: { ...u.virtual, options: X } } : u }, w.createElement(Vt, { slot: K }, E.children)) });
|
465
|
+
}
|
466
|
+
return w.createElement(xt, { enabled: c ? e.static || x : !1 }, w.createElement(le.Provider, { value: u.mode === 1 ? u : { ...u, isSelected: ie } }, ue({ ourProps: ne, theirProps: { ...E, children: w.createElement(Mt, { freeze: Y }, typeof E.children == "function" ? (a = E.children) == null ? void 0 : a.call(E, K) : E.children) }, slot: K, defaultTag: jt, features: qt, visible: x, name: "Combobox.Options" })));
|
467
|
+
}
|
468
|
+
let Xt = "div";
|
469
|
+
function Qt(e, t) {
|
470
|
+
var o, i, a, r;
|
471
|
+
let l = oe("Combobox.Option"), n = se("Combobox.Option"), s = ve(), { id: c = `headlessui-combobox-option-${s}`, value: v, disabled: g = (a = (i = (o = l.virtual) == null ? void 0 : o.disabled) == null ? void 0 : i.call(o, v)) != null ? a : !1, order: E = null, ...u } = e, T = Be(l.inputElement), O = l.virtual ? l.activeOptionIndex === l.calculateIndex(v) : l.activeOptionIndex === null ? !1 : ((r = l.options[l.activeOptionIndex]) == null ? void 0 : r.id) === c, b = l.isSelected(v), k = H(null), A = qe({ disabled: g, value: v, domRef: k, order: E }), M = Ie(Ue), y = pe(t, k, M ? M.measureElement : null), P = f(() => {
|
472
|
+
n.setIsTyping(!1), n.onChange(v);
|
473
|
+
});
|
474
|
+
W(() => n.registerOption(c, A), [A, c]);
|
475
|
+
let h = H(!(l.virtual || l.__demoMode));
|
476
|
+
W(() => {
|
477
|
+
if (!l.virtual && !l.__demoMode) return fe().requestAnimationFrame(() => {
|
478
|
+
h.current = !0;
|
479
|
+
});
|
480
|
+
}, [l.virtual, l.__demoMode]), W(() => {
|
481
|
+
if (h.current && l.comboboxState === 0 && O && l.activationTrigger !== 0) return fe().requestAnimationFrame(() => {
|
482
|
+
var d, B;
|
483
|
+
(B = (d = k.current) == null ? void 0 : d.scrollIntoView) == null || B.call(d, { block: "nearest" });
|
484
|
+
});
|
485
|
+
}, [k, O, l.comboboxState, l.activationTrigger, l.activeOptionIndex]);
|
486
|
+
let I = f((d) => {
|
487
|
+
d.preventDefault(), d.button === ye.Left && (g || (P(), Et() || requestAnimationFrame(() => T()), l.mode === 0 && n.closeCombobox()));
|
488
|
+
}), x = f(() => {
|
489
|
+
if (g) return n.goToOption(C.Nothing);
|
490
|
+
let d = l.calculateIndex(v);
|
491
|
+
n.goToOption(C.Specific, d);
|
492
|
+
}), G = wt(), L = f((d) => G.update(d)), z = f((d) => {
|
493
|
+
if (!G.wasMoved(d) || g || O) return;
|
494
|
+
let B = l.calculateIndex(v);
|
495
|
+
n.goToOption(C.Specific, B, 0);
|
496
|
+
}), q = f((d) => {
|
497
|
+
G.wasMoved(d) && (g || O && (l.optionsPropsRef.current.hold || n.goToOption(C.Nothing)));
|
498
|
+
}), K = j(() => ({ active: O, focus: O, selected: b, disabled: g }), [O, b, g]);
|
499
|
+
return ue({ ourProps: { id: c, ref: y, role: "option", tabIndex: g === !0 ? void 0 : -1, "aria-disabled": g === !0 ? !0 : void 0, "aria-selected": b, disabled: void 0, onMouseDown: I, onFocus: x, onPointerEnter: L, onMouseEnter: L, onPointerMove: z, onMouseMove: z, onPointerLeave: q, onMouseLeave: q }, theirProps: u, slot: K, defaultTag: Xt, name: "Combobox.Option" });
|
500
|
+
}
|
501
|
+
let Jt = ae(Ut), Zt = ae(Kt), eo = ae(Gt), to = et, oo = ae(Yt), no = ae(Qt), go = Object.assign(Jt, { Input: eo, Button: Zt, Label: to, Options: oo, Option: no });
|
502
|
+
export {
|
503
|
+
eo as G,
|
504
|
+
go as H,
|
505
|
+
oo as K,
|
506
|
+
Zt as U,
|
507
|
+
no as W
|
508
|
+
};
|