mimir-ui-kit 1.38.41 → 1.38.42
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/Dropdown.css
CHANGED
@@ -1 +1 @@
|
|
1
|
-
.
|
1
|
+
._menu_1o2uo_3{position:relative}._menu_1o2uo_3 ._menu-button_1o2uo_6{all:unset;cursor:pointer}._menu-items_1o2uo_11{position:absolute;z-index:10000;width:220px;margin-top:var(--mimir-space-3xs);padding:var(--mimir-space-l) var(--mimir-space-xl);overflow:hidden!important;background-color:var(--white);box-shadow:0 3px 15px #1f202326}._menu-items-container_1o2uo_22{display:flex;flex-direction:column;gap:var(--mimir-space-m)}._close-button_1o2uo_28{position:absolute;top:var(--mimir-space-xs);right:var(--mimir-space-xs)}._enter_1o2uo_34{transition:opacity .15s ease-out,transform .15s ease-out}._enter-from_1o2uo_38{transform:translateY(calc(var(--mimir-space-xxs) * -1));opacity:0}._enter-to_1o2uo_43{transform:translateY(0);opacity:1}._leave_1o2uo_48{transition:opacity .15s ease-in,transform .2s ease-in}._leave-from_1o2uo_52{transform:translateY(0);opacity:1}._leave-to_1o2uo_57{transform:translateY(calc(var(--mimir-space-xxs) * -1));opacity:0}
|
@@ -41,6 +41,10 @@ type TProps = {
|
|
41
41
|
* Открывать меню при наведении.
|
42
42
|
*/
|
43
43
|
openOnHover?: boolean;
|
44
|
+
/**
|
45
|
+
* Нужна ли кнопка закрытия.
|
46
|
+
*/
|
47
|
+
needCloseButton?: boolean;
|
44
48
|
/**
|
45
49
|
* Флаг открытия.
|
46
50
|
*/
|
@@ -49,5 +53,5 @@ type TProps = {
|
|
49
53
|
/**
|
50
54
|
* Компонент Dropdown, содержит в себе кнопку и панель выпадающего меню
|
51
55
|
*/
|
52
|
-
export declare const Dropdown: import('react').MemoExoticComponent<({ children, position, popoverProps, className, buttonClassName, panelClassName, menuItemsClassName, buttonContent, openOnHover, isOpen }: TProps) => import("react/jsx-runtime").JSX.Element>;
|
56
|
+
export declare const Dropdown: import('react').MemoExoticComponent<({ children, position, popoverProps, className, buttonClassName, panelClassName, menuItemsClassName, buttonContent, needCloseButton, openOnHover, isOpen }: TProps) => import("react/jsx-runtime").JSX.Element>;
|
53
57
|
export {};
|
@@ -1,59 +1,60 @@
|
|
1
|
-
import { jsx as ce, jsxs as
|
1
|
+
import { jsx as ce, jsxs as Le, Fragment as nt } from "react/jsx-runtime";
|
2
2
|
import { c as fe } from "../../index-DIxK0V-G.js";
|
3
|
-
import
|
4
|
-
import {
|
5
|
-
import {
|
6
|
-
import {
|
7
|
-
import { e as _t } from "../../
|
3
|
+
import y, { createContext as ae, useState as W, useContext as ee, useRef as M, useEffect as de, useMemo as K, Fragment as pe, useReducer as rt, createRef as we, useId as me, memo as ot, useCallback as Ae } from "react";
|
4
|
+
import { Button as lt } from "../Button/Button.js";
|
5
|
+
import { o as S, u as De, M as ve, W as V, y as z, O as oe, n as ie, m as at, e as ut, H as ue, s as Ie, p as it, a as Q, T as st, $ as ct, b as dt, D as Ce, I as pt, c as re } from "../../keyboard-CUMsrFX1.js";
|
6
|
+
import { w as vt } from "../../use-active-press-BVQqDQ3V.js";
|
7
|
+
import { n as Pe, s as ft, l as He, e as mt, E as bt, R as ht, v as Pt, y as $t, x as yt, a as Et, b as gt, m as St, f as Tt, d as _t, t as wt } from "../../portal-D3A00sie.js";
|
8
|
+
import { e as It } from "../../use-resolve-button-type-DhFdPxnv.js";
|
8
9
|
import { T as be, s as he } from "../../hidden-Dn4lM6EL.js";
|
9
|
-
import { R as ke, H as Me, i as D, c as
|
10
|
+
import { R as ke, H as Me, i as D, c as Ge, u as $e, s as Ct } from "../../open-closed-CkTbpRyi.js";
|
10
11
|
import { C as Ft } from "../../close-provider-CEutdhG8.js";
|
11
|
-
import { r as
|
12
|
-
import { b as Oe, P as le, F as Y, A as
|
13
|
-
import { f as
|
14
|
-
import '../../assets/Dropdown.css';function
|
15
|
-
let d = Pe(o), f =
|
16
|
-
var
|
12
|
+
import { r as Ke } from "../../bugs-diTMAGNw.js";
|
13
|
+
import { b as Oe, P as le, F as Y, A as Bt, h as kt, T as Fe } from "../../focus-management-Dp2_vbQ3.js";
|
14
|
+
import { f as Mt } from "../../use-is-mounted-D7cq4xsa.js";
|
15
|
+
import '../../assets/Dropdown.css';function Ot({ defaultContainers: e = [], portals: t, mainTreeNode: o } = {}) {
|
16
|
+
let d = Pe(o), f = S(() => {
|
17
|
+
var b, m;
|
17
18
|
let l = [];
|
18
19
|
for (let r of e) r !== null && (r instanceof HTMLElement ? l.push(r) : "current" in r && r.current instanceof HTMLElement && l.push(r.current));
|
19
20
|
if (t != null && t.current) for (let r of t.current) l.push(r);
|
20
|
-
for (let r of (
|
21
|
+
for (let r of (b = d == null ? void 0 : d.querySelectorAll("html > *, body > *")) != null ? b : []) r !== document.body && r !== document.head && r instanceof HTMLElement && r.id !== "headlessui-portal-root" && (o && (r.contains(o) || r.contains((m = o == null ? void 0 : o.getRootNode()) == null ? void 0 : m.host)) || l.some((h) => r.contains(h)) || l.push(r));
|
21
22
|
return l;
|
22
23
|
});
|
23
|
-
return { resolveContainers: f, contains:
|
24
|
+
return { resolveContainers: f, contains: S((b) => f().some((m) => m.contains(b))) };
|
24
25
|
}
|
25
|
-
let
|
26
|
-
function
|
27
|
-
let [o, d] = W(null), f =
|
28
|
-
return
|
26
|
+
let Ue = ae(null);
|
27
|
+
function je({ children: e, node: t }) {
|
28
|
+
let [o, d] = W(null), f = Xe(t ?? o);
|
29
|
+
return y.createElement(Ue.Provider, { value: f }, e, f === null && y.createElement(be, { features: he.Hidden, ref: (b) => {
|
29
30
|
var m, l;
|
30
|
-
if (
|
31
|
-
for (let r of (l = (m =
|
31
|
+
if (b) {
|
32
|
+
for (let r of (l = (m = De(b)) == null ? void 0 : m.querySelectorAll("html > *, body > *")) != null ? l : []) if (r !== document.body && r !== document.head && r instanceof HTMLElement && r != null && r.contains(b)) {
|
32
33
|
d(r);
|
33
34
|
break;
|
34
35
|
}
|
35
36
|
}
|
36
37
|
} }));
|
37
38
|
}
|
38
|
-
function
|
39
|
+
function Xe(e = null) {
|
39
40
|
var t;
|
40
|
-
return (t = ee(
|
41
|
+
return (t = ee(Ue)) != null ? t : e;
|
41
42
|
}
|
42
43
|
var J = ((e) => (e[e.Forwards = 0] = "Forwards", e[e.Backwards = 1] = "Backwards", e))(J || {});
|
43
|
-
function
|
44
|
+
function We() {
|
44
45
|
let e = M(0);
|
45
|
-
return
|
46
|
+
return ft(!0, "keydown", (t) => {
|
46
47
|
t.key === "Tab" && (e.current = t.shiftKey ? 1 : 0);
|
47
48
|
}, !0), e;
|
48
49
|
}
|
49
|
-
function
|
50
|
+
function Ze(e) {
|
50
51
|
var t;
|
51
|
-
return !!(e.enter || e.enterFrom || e.enterTo || e.leave || e.leaveFrom || e.leaveTo) || ((t = e.as) != null ? t :
|
52
|
+
return !!(e.enter || e.enterFrom || e.enterTo || e.leave || e.leaveFrom || e.leaveTo) || ((t = e.as) != null ? t : Je) !== pe || y.Children.count(e.children) === 1;
|
52
53
|
}
|
53
54
|
let ye = ae(null);
|
54
55
|
ye.displayName = "TransitionContext";
|
55
|
-
var
|
56
|
-
function
|
56
|
+
var xt = ((e) => (e.Visible = "visible", e.Hidden = "hidden", e))(xt || {});
|
57
|
+
function Nt() {
|
57
58
|
let e = ee(ye);
|
58
59
|
if (e === null) throw new Error("A <Transition.Child /> is used but it is missing a parent <Transition /> or <Transition.Root />.");
|
59
60
|
return e;
|
@@ -68,102 +69,102 @@ Ee.displayName = "NestingContext";
|
|
68
69
|
function ge(e) {
|
69
70
|
return "children" in e ? ge(e.children) : e.current.filter(({ el: t }) => t.current !== null).filter(({ state: t }) => t === "visible").length > 0;
|
70
71
|
}
|
71
|
-
function
|
72
|
-
let o = Ie(e), d = M([]), f =
|
72
|
+
function qe(e, t) {
|
73
|
+
let o = Ie(e), d = M([]), f = Mt(), b = it(), m = S((c, a = oe.Hidden) => {
|
73
74
|
let s = d.current.findIndex(({ el: u }) => u === c);
|
74
75
|
s !== -1 && (Q(a, { [oe.Unmount]() {
|
75
76
|
d.current.splice(s, 1);
|
76
77
|
}, [oe.Hidden]() {
|
77
78
|
d.current[s].state = "hidden";
|
78
|
-
} }),
|
79
|
+
} }), b.microTask(() => {
|
79
80
|
var u;
|
80
81
|
!ge(d) && f.current && ((u = o.current) == null || u.call(o));
|
81
82
|
}));
|
82
|
-
}), l =
|
83
|
+
}), l = S((c) => {
|
83
84
|
let a = d.current.find(({ el: s }) => s === c);
|
84
85
|
return a ? a.state !== "visible" && (a.state = "visible") : d.current.push({ el: c, state: "visible" }), () => m(c, oe.Unmount);
|
85
|
-
}), r = M([]),
|
86
|
+
}), r = M([]), h = M(Promise.resolve()), n = M({ enter: [], leave: [] }), E = S((c, a, s) => {
|
86
87
|
r.current.splice(0), t && (t.chains.current[a] = t.chains.current[a].filter(([u]) => u !== c)), t == null || t.chains.current[a].push([c, new Promise((u) => {
|
87
88
|
r.current.push(u);
|
88
89
|
})]), t == null || t.chains.current[a].push([c, new Promise((u) => {
|
89
|
-
Promise.all(n.current[a].map(([
|
90
|
-
})]), a === "enter" ?
|
91
|
-
}), P =
|
92
|
-
Promise.all(n.current[a].splice(0).map(([u,
|
90
|
+
Promise.all(n.current[a].map(([$, T]) => T)).then(() => u());
|
91
|
+
})]), a === "enter" ? h.current = h.current.then(() => t == null ? void 0 : t.wait.current).then(() => s(a)) : s(a);
|
92
|
+
}), P = S((c, a, s) => {
|
93
|
+
Promise.all(n.current[a].splice(0).map(([u, $]) => $)).then(() => {
|
93
94
|
var u;
|
94
95
|
(u = r.current.shift()) == null || u();
|
95
96
|
}).then(() => s(a));
|
96
97
|
});
|
97
|
-
return
|
98
|
+
return K(() => ({ children: d, register: l, unregister: m, onStart: E, onStop: P, wait: h, chains: n }), [l, m, d, E, P, n, h]);
|
98
99
|
}
|
99
|
-
let
|
100
|
-
function
|
100
|
+
let Je = pe, Qe = ve.RenderStrategy;
|
101
|
+
function Lt(e, t) {
|
101
102
|
var o, d;
|
102
|
-
let { transition: f = !0, beforeEnter:
|
103
|
-
ie(() =>
|
104
|
-
if (Z === oe.Hidden &&
|
105
|
-
if (
|
103
|
+
let { transition: f = !0, beforeEnter: b, afterEnter: m, beforeLeave: l, afterLeave: r, enter: h, enterFrom: n, enterTo: E, entered: P, leave: c, leaveFrom: a, leaveTo: s, ...u } = e, [$, T] = W(null), g = M(null), C = Ze(e), H = z(...C ? [g, t, T] : t === null ? [] : [t]), Z = (o = u.unmount) == null || o ? oe.Unmount : oe.Hidden, { show: F, appear: B, initial: q } = Nt(), [k, O] = W(F ? "visible" : "hidden"), U = Rt(), { register: N, unregister: R } = U;
|
104
|
+
ie(() => N(g), [N, g]), ie(() => {
|
105
|
+
if (Z === oe.Hidden && g.current) {
|
106
|
+
if (F && k !== "visible") {
|
106
107
|
O("visible");
|
107
108
|
return;
|
108
109
|
}
|
109
|
-
return Q(k, { hidden: () =>
|
110
|
+
return Q(k, { hidden: () => R(g), visible: () => N(g) });
|
110
111
|
}
|
111
|
-
}, [k,
|
112
|
-
let
|
112
|
+
}, [k, g, N, R, F, Z]);
|
113
|
+
let j = He();
|
113
114
|
ie(() => {
|
114
|
-
if (
|
115
|
-
}, [
|
116
|
-
let te = q && !B,
|
117
|
-
v.current || (O("hidden"),
|
118
|
-
},
|
115
|
+
if (C && j && k === "visible" && g.current === null) throw new Error("Did you forget to passthrough the `ref` to the actual DOM node?");
|
116
|
+
}, [g, k, j, C]);
|
117
|
+
let te = q && !B, X = B && F && q, v = M(!1), i = qe(() => {
|
118
|
+
v.current || (O("hidden"), R(g));
|
119
|
+
}, U), p = S((A) => {
|
119
120
|
v.current = !0;
|
120
121
|
let ne = A ? "enter" : "leave";
|
121
|
-
i.onStart(
|
122
|
-
se === "enter" ?
|
122
|
+
i.onStart(g, ne, (se) => {
|
123
|
+
se === "enter" ? b == null || b() : se === "leave" && (l == null || l());
|
123
124
|
});
|
124
|
-
}),
|
125
|
+
}), _ = S((A) => {
|
125
126
|
let ne = A ? "enter" : "leave";
|
126
|
-
v.current = !1, i.onStop(
|
127
|
+
v.current = !1, i.onStop(g, ne, (se) => {
|
127
128
|
se === "enter" ? m == null || m() : se === "leave" && (r == null || r());
|
128
|
-
}), ne === "leave" && !ge(i) && (O("hidden"),
|
129
|
+
}), ne === "leave" && !ge(i) && (O("hidden"), R(g));
|
129
130
|
});
|
130
131
|
de(() => {
|
131
|
-
|
132
|
-
}, [
|
133
|
-
let w = !(!f || !
|
134
|
-
return k === "visible" && (L |= D.Open), k === "hidden" && (L |= D.Closed),
|
132
|
+
C && f || (p(F), _(F));
|
133
|
+
}, [F, C, f]);
|
134
|
+
let w = !(!f || !C || !j || te), [, I] = ke(w, $, F, { start: p, end: _ }), x = at({ ref: H, className: ((d = ut(u.className, X && h, X && n, I.enter && h, I.enter && I.closed && n, I.enter && !I.closed && E, I.leave && c, I.leave && !I.closed && a, I.leave && I.closed && s, !I.transition && F && P)) == null ? void 0 : d.trim()) || void 0, ...Me(I) }), L = 0;
|
135
|
+
return k === "visible" && (L |= D.Open), k === "hidden" && (L |= D.Closed), I.enter && (L |= D.Opening), I.leave && (L |= D.Closing), y.createElement(Ee.Provider, { value: i }, y.createElement(Ge, { value: L }, ue({ ourProps: x, theirProps: u, defaultTag: Je, features: Qe, visible: k === "visible", name: "Transition.Child" })));
|
135
136
|
}
|
136
|
-
function
|
137
|
-
let { show: o, appear: d = !1, unmount: f = !0, ...
|
138
|
-
|
139
|
-
let
|
140
|
-
if (o === void 0 &&
|
141
|
-
let [n, E] = W(o ? "visible" : "hidden"), P =
|
137
|
+
function At(e, t) {
|
138
|
+
let { show: o, appear: d = !1, unmount: f = !0, ...b } = e, m = M(null), l = Ze(e), r = z(...l ? [m, t] : t === null ? [] : [t]);
|
139
|
+
He();
|
140
|
+
let h = $e();
|
141
|
+
if (o === void 0 && h !== null && (o = (h & D.Open) === D.Open), o === void 0) throw new Error("A <Transition /> is used but it is missing a `show={true | false}` prop.");
|
142
|
+
let [n, E] = W(o ? "visible" : "hidden"), P = qe(() => {
|
142
143
|
o || E("hidden");
|
143
144
|
}), [c, a] = W(!0), s = M([o]);
|
144
145
|
ie(() => {
|
145
146
|
c !== !1 && s.current[s.current.length - 1] !== o && (s.current.push(o), a(!1));
|
146
147
|
}, [s, o]);
|
147
|
-
let u =
|
148
|
+
let u = K(() => ({ show: o, appear: d, initial: c }), [o, d, c]);
|
148
149
|
ie(() => {
|
149
150
|
o ? E("visible") : !ge(P) && m.current !== null && E("hidden");
|
150
151
|
}, [o, P]);
|
151
|
-
let
|
152
|
-
var
|
153
|
-
c && a(!1), (
|
154
|
-
}),
|
155
|
-
var
|
156
|
-
c && a(!1), (
|
152
|
+
let $ = { unmount: f }, T = S(() => {
|
153
|
+
var C;
|
154
|
+
c && a(!1), (C = e.beforeEnter) == null || C.call(e);
|
155
|
+
}), g = S(() => {
|
156
|
+
var C;
|
157
|
+
c && a(!1), (C = e.beforeLeave) == null || C.call(e);
|
157
158
|
});
|
158
|
-
return
|
159
|
+
return y.createElement(Ee.Provider, { value: P }, y.createElement(ye.Provider, { value: u }, ue({ ourProps: { ...$, as: pe, children: y.createElement(Ve, { ref: r, ...$, ...b, beforeEnter: T, beforeLeave: g }) }, theirProps: {}, defaultTag: pe, features: Qe, visible: n === "visible", name: "Transition" })));
|
159
160
|
}
|
160
|
-
function
|
161
|
+
function Dt(e, t) {
|
161
162
|
let o = ee(ye) !== null, d = $e() !== null;
|
162
|
-
return
|
163
|
+
return y.createElement(y.Fragment, null, !o && d ? y.createElement(Be, { ref: t, ...e }) : y.createElement(Ve, { ref: t, ...e }));
|
163
164
|
}
|
164
|
-
let Be = V(
|
165
|
-
var
|
166
|
-
let
|
165
|
+
let Be = V(At), Ve = V(Lt), Ht = V(Dt), Gt = Object.assign(Be, { Child: Ht, Root: Be });
|
166
|
+
var Kt = ((e) => (e[e.Open = 0] = "Open", e[e.Closed = 1] = "Closed", e))(Kt || {}), Ut = ((e) => (e[e.TogglePopover = 0] = "TogglePopover", e[e.ClosePopover = 1] = "ClosePopover", e[e.SetButton = 2] = "SetButton", e[e.SetButtonId = 3] = "SetButtonId", e[e.SetPanel = 4] = "SetPanel", e[e.SetPanelId = 5] = "SetPanelId", e))(Ut || {});
|
167
|
+
let jt = { 0: (e) => ({ ...e, popoverState: Q(e.popoverState, { 0: 1, 1: 0 }), __demoMode: !1 }), 1(e) {
|
167
168
|
return e.popoverState === 1 ? e : { ...e, popoverState: 1, __demoMode: !1 };
|
168
169
|
}, 2(e, t) {
|
169
170
|
return e.button === t.button ? e : { ...e, button: t.button };
|
@@ -185,65 +186,65 @@ function Se(e) {
|
|
185
186
|
}
|
186
187
|
let Te = ae(null);
|
187
188
|
Te.displayName = "PopoverAPIContext";
|
188
|
-
function
|
189
|
+
function Ne(e) {
|
189
190
|
let t = ee(Te);
|
190
191
|
if (t === null) {
|
191
192
|
let o = new Error(`<${e} /> is missing a parent <Popover /> component.`);
|
192
|
-
throw Error.captureStackTrace && Error.captureStackTrace(o,
|
193
|
+
throw Error.captureStackTrace && Error.captureStackTrace(o, Ne), o;
|
193
194
|
}
|
194
195
|
return t;
|
195
196
|
}
|
196
|
-
let
|
197
|
-
|
198
|
-
function
|
199
|
-
return ee(
|
197
|
+
let Re = ae(null);
|
198
|
+
Re.displayName = "PopoverGroupContext";
|
199
|
+
function Ye() {
|
200
|
+
return ee(Re);
|
200
201
|
}
|
201
|
-
let
|
202
|
-
|
203
|
-
function
|
204
|
-
return ee(
|
202
|
+
let _e = ae(null);
|
203
|
+
_e.displayName = "PopoverPanelContext";
|
204
|
+
function Xt() {
|
205
|
+
return ee(_e);
|
205
206
|
}
|
206
|
-
function
|
207
|
-
return Q(t.type,
|
207
|
+
function Wt(e, t) {
|
208
|
+
return Q(t.type, jt, e, t);
|
208
209
|
}
|
209
|
-
let
|
210
|
-
function
|
210
|
+
let Zt = "div";
|
211
|
+
function qt(e, t) {
|
211
212
|
var o;
|
212
|
-
let { __demoMode: d = !1, ...f } = e,
|
213
|
-
|
214
|
-
})), l = M([]), r = rt(
|
213
|
+
let { __demoMode: d = !1, ...f } = e, b = M(null), m = z(t, st((v) => {
|
214
|
+
b.current = v;
|
215
|
+
})), l = M([]), r = rt(Wt, { __demoMode: d, popoverState: d ? 0 : 1, buttons: l, button: null, buttonId: null, panel: null, panelId: null, beforePanelSentinel: we(), afterPanelSentinel: we(), afterButtonSentinel: we() }), [{ popoverState: h, button: n, buttonId: E, panel: P, panelId: c, beforePanelSentinel: a, afterPanelSentinel: s, afterButtonSentinel: u }, $] = r, T = Pe((o = b.current) != null ? o : n), g = K(() => {
|
215
216
|
if (!n || !P) return !1;
|
216
217
|
for (let x of document.querySelectorAll("body > *")) if (Number(x == null ? void 0 : x.contains(n)) ^ Number(x == null ? void 0 : x.contains(P))) return !0;
|
217
|
-
let v = Oe(), i = v.indexOf(n), p = (i + v.length - 1) % v.length,
|
218
|
-
return !P.contains(w) && !P.contains(
|
219
|
-
}, [n, P]),
|
218
|
+
let v = Oe(), i = v.indexOf(n), p = (i + v.length - 1) % v.length, _ = (i + 1) % v.length, w = v[p], I = v[_];
|
219
|
+
return !P.contains(w) && !P.contains(I);
|
220
|
+
}, [n, P]), C = Ie(E), H = Ie(c), Z = K(() => ({ buttonId: C, panelId: H, close: () => $({ type: 1 }) }), [C, H, $]), F = Ye(), B = F == null ? void 0 : F.registerPopover, q = S(() => {
|
220
221
|
var v;
|
221
|
-
return (v =
|
222
|
+
return (v = F == null ? void 0 : F.isFocusWithinPopoverGroup()) != null ? v : (T == null ? void 0 : T.activeElement) && ((n == null ? void 0 : n.contains(T.activeElement)) || (P == null ? void 0 : P.contains(T.activeElement)));
|
222
223
|
});
|
223
224
|
de(() => B == null ? void 0 : B(Z), [B, Z]);
|
224
|
-
let [k, O] =
|
225
|
-
|
226
|
-
var i, p,
|
227
|
-
v.target !== window && v.target instanceof HTMLElement &&
|
228
|
-
}, !0),
|
229
|
-
|
225
|
+
let [k, O] = mt(), U = Xe(n), N = Ot({ mainTreeNode: U, portals: k, defaultContainers: [n, P] });
|
226
|
+
bt(T == null ? void 0 : T.defaultView, "focus", (v) => {
|
227
|
+
var i, p, _, w, I, x;
|
228
|
+
v.target !== window && v.target instanceof HTMLElement && h === 0 && (q() || n && P && (N.contains(v.target) || (p = (i = a.current) == null ? void 0 : i.contains) != null && p.call(i, v.target) || (w = (_ = s.current) == null ? void 0 : _.contains) != null && w.call(_, v.target) || (x = (I = u.current) == null ? void 0 : I.contains) != null && x.call(I, v.target) || $({ type: 1 })));
|
229
|
+
}, !0), ht(h === 0, N.resolveContainers, (v, i) => {
|
230
|
+
$({ type: 1 }), Bt(i, kt.Loose) || (v.preventDefault(), n == null || n.focus());
|
230
231
|
});
|
231
|
-
let
|
232
|
-
|
232
|
+
let R = S((v) => {
|
233
|
+
$({ type: 1 });
|
233
234
|
let i = v ? v instanceof HTMLElement ? v : "current" in v && v.current instanceof HTMLElement ? v.current : n : n;
|
234
235
|
i == null || i.focus();
|
235
|
-
}),
|
236
|
-
return
|
236
|
+
}), j = K(() => ({ close: R, isPortalled: g }), [R, g]), te = K(() => ({ open: h === 0, close: R }), [h, R]), X = { ref: m };
|
237
|
+
return y.createElement(je, { node: U }, y.createElement(Pt, null, y.createElement(_e.Provider, { value: null }, y.createElement(xe.Provider, { value: r }, y.createElement(Te.Provider, { value: j }, y.createElement(Ft, { value: R }, y.createElement(Ge, { value: Q(h, { 0: D.Open, 1: D.Closed }) }, y.createElement(O, null, ue({ ourProps: X, theirProps: f, slot: te, defaultTag: Zt, name: "Popover" })))))))));
|
237
238
|
}
|
238
|
-
let
|
239
|
-
function
|
240
|
-
let o = me(), { id: d = `headlessui-popover-button-${o}`, disabled: f = !1, autoFocus:
|
239
|
+
let Jt = "button";
|
240
|
+
function Qt(e, t) {
|
241
|
+
let o = me(), { id: d = `headlessui-popover-button-${o}`, disabled: f = !1, autoFocus: b = !1, ...m } = e, [l, r] = Se("Popover.Button"), { isPortalled: h } = Ne("Popover.Button"), n = M(null), E = `headlessui-focus-sentinel-${me()}`, P = Ye(), c = P == null ? void 0 : P.closeOthers, a = Xt() !== null;
|
241
242
|
de(() => {
|
242
243
|
if (!a) return r({ type: 3, buttonId: d }), () => {
|
243
244
|
r({ type: 3, buttonId: null });
|
244
245
|
};
|
245
246
|
}, [a, d, r]);
|
246
|
-
let [s] = W(() => Symbol()), u = z(n, t,
|
247
|
+
let [s] = W(() => Symbol()), u = z(n, t, $t(), S((i) => {
|
247
248
|
if (!a) {
|
248
249
|
if (i) l.buttons.current.push(s);
|
249
250
|
else {
|
@@ -252,14 +253,14 @@ function Jt(e, t) {
|
|
252
253
|
}
|
253
254
|
l.buttons.current.length > 1 && console.warn("You are already using a <Popover.Button /> but only 1 <Popover.Button /> is supported."), i && r({ type: 2, button: i });
|
254
255
|
}
|
255
|
-
})),
|
256
|
-
var p,
|
256
|
+
})), $ = z(n, t), T = Pe(n), g = S((i) => {
|
257
|
+
var p, _, w;
|
257
258
|
if (a) {
|
258
259
|
if (l.popoverState === 1) return;
|
259
260
|
switch (i.key) {
|
260
261
|
case re.Space:
|
261
262
|
case re.Enter:
|
262
|
-
i.preventDefault(), (
|
263
|
+
i.preventDefault(), (_ = (p = i.target).click) == null || _.call(p), r({ type: 1 }), (w = l.button) == null || w.focus();
|
263
264
|
break;
|
264
265
|
}
|
265
266
|
} else switch (i.key) {
|
@@ -269,55 +270,55 @@ function Jt(e, t) {
|
|
269
270
|
break;
|
270
271
|
case re.Escape:
|
271
272
|
if (l.popoverState !== 0) return c == null ? void 0 : c(l.buttonId);
|
272
|
-
if (!n.current ||
|
273
|
+
if (!n.current || T != null && T.activeElement && !n.current.contains(T.activeElement)) return;
|
273
274
|
i.preventDefault(), i.stopPropagation(), r({ type: 1 });
|
274
275
|
break;
|
275
276
|
}
|
276
|
-
}),
|
277
|
+
}), C = S((i) => {
|
277
278
|
a || i.key === re.Space && i.preventDefault();
|
278
|
-
}), H =
|
279
|
-
var p,
|
280
|
-
|
281
|
-
}), Z =
|
279
|
+
}), H = S((i) => {
|
280
|
+
var p, _;
|
281
|
+
Ke(i.currentTarget) || f || (a ? (r({ type: 1 }), (p = l.button) == null || p.focus()) : (i.preventDefault(), i.stopPropagation(), l.popoverState === 1 && (c == null || c(l.buttonId)), r({ type: 0 }), (_ = l.button) == null || _.focus()));
|
282
|
+
}), Z = S((i) => {
|
282
283
|
i.preventDefault(), i.stopPropagation();
|
283
|
-
}), { isFocusVisible:
|
284
|
+
}), { isFocusVisible: F, focusProps: B } = ct({ autoFocus: b }), { isHovered: q, hoverProps: k } = dt({ isDisabled: f }), { pressed: O, pressProps: U } = vt({ disabled: f }), N = l.popoverState === 0, R = K(() => ({ open: N, active: O || N, disabled: f, hover: q, focus: F, autofocus: b }), [N, q, F, O, f, b]), j = It(e, l.button), te = a ? Ce({ ref: $, type: j, onKeyDown: g, onClick: H, disabled: f || void 0, autoFocus: b }, B, k, U) : Ce({ ref: u, id: l.buttonId, type: j, "aria-expanded": l.popoverState === 0, "aria-controls": l.panel ? l.panelId : void 0, disabled: f || void 0, autoFocus: b, onKeyDown: g, onKeyUp: C, onClick: H, onMouseDown: Z }, B, k, U), X = We(), v = S(() => {
|
284
285
|
let i = l.panel;
|
285
286
|
if (!i) return;
|
286
287
|
function p() {
|
287
|
-
Q(
|
288
|
+
Q(X.current, { [J.Forwards]: () => le(i, Y.First), [J.Backwards]: () => le(i, Y.Last) }) === Fe.Error && le(Oe().filter((_) => _.dataset.headlessuiFocusGuard !== "true"), Q(X.current, { [J.Forwards]: Y.Next, [J.Backwards]: Y.Previous }), { relativeTo: l.button });
|
288
289
|
}
|
289
290
|
p();
|
290
291
|
});
|
291
|
-
return
|
292
|
+
return y.createElement(y.Fragment, null, ue({ ourProps: te, theirProps: m, slot: R, defaultTag: Jt, name: "Popover.Button" }), N && !a && h && y.createElement(be, { id: E, ref: l.afterButtonSentinel, features: he.Focusable, "data-headlessui-focus-guard": !0, as: "button", type: "button", onFocus: v }));
|
292
293
|
}
|
293
|
-
let
|
294
|
-
function
|
295
|
-
let o = me(), { id: d = `headlessui-popover-backdrop-${o}`, transition: f = !1, ...
|
296
|
-
if (
|
294
|
+
let Vt = "div", Yt = ve.RenderStrategy | ve.Static;
|
295
|
+
function ze(e, t) {
|
296
|
+
let o = me(), { id: d = `headlessui-popover-backdrop-${o}`, transition: f = !1, ...b } = e, [{ popoverState: m }, l] = Se("Popover.Backdrop"), [r, h] = W(null), n = z(t, h), E = $e(), [P, c] = ke(f, r, E !== null ? (E & D.Open) === D.Open : m === 0), a = S(($) => {
|
297
|
+
if (Ke($.currentTarget)) return $.preventDefault();
|
297
298
|
l({ type: 1 });
|
298
|
-
}), s =
|
299
|
-
return ue({ ourProps: u, theirProps:
|
299
|
+
}), s = K(() => ({ open: m === 0 }), [m]), u = { ref: n, id: d, "aria-hidden": !0, onClick: a, ...Me(c) };
|
300
|
+
return ue({ ourProps: u, theirProps: b, slot: s, defaultTag: Vt, features: Yt, visible: P, name: "Popover.Backdrop" });
|
300
301
|
}
|
301
|
-
let
|
302
|
-
function
|
303
|
-
let o = me(), { id: d = `headlessui-popover-panel-${o}`, focus: f = !1, anchor:
|
304
|
-
|
305
|
-
let [H, Z] = W(null),
|
302
|
+
let zt = "div", en = ve.RenderStrategy | ve.Static;
|
303
|
+
function tn(e, t) {
|
304
|
+
let o = me(), { id: d = `headlessui-popover-panel-${o}`, focus: f = !1, anchor: b, portal: m = !1, modal: l = !1, transition: r = !1, ...h } = e, [n, E] = Se("Popover.Panel"), { close: P, isPortalled: c } = Ne("Popover.Panel"), a = `headlessui-focus-sentinel-before-${o}`, s = `headlessui-focus-sentinel-after-${o}`, u = M(null), $ = yt(b), [T, g] = Et($), C = gt();
|
305
|
+
$ && (m = !0);
|
306
|
+
let [H, Z] = W(null), F = z(u, t, $ ? T : null, S((p) => E({ type: 4, panel: p })), Z), B = Pe(u), q = pt();
|
306
307
|
ie(() => (E({ type: 5, panelId: d }), () => {
|
307
308
|
E({ type: 5, panelId: null });
|
308
309
|
}), [d, E]);
|
309
|
-
let k = $e(), [O,
|
310
|
-
|
310
|
+
let k = $e(), [O, U] = ke(r, H, k !== null ? (k & D.Open) === D.Open : n.popoverState === 0);
|
311
|
+
St(O, n.button, () => {
|
311
312
|
E({ type: 1 });
|
312
313
|
});
|
313
|
-
let
|
314
|
-
|
315
|
-
let
|
316
|
-
var
|
314
|
+
let N = n.__demoMode ? !1 : l && O;
|
315
|
+
Tt(N, B);
|
316
|
+
let R = S((p) => {
|
317
|
+
var _;
|
317
318
|
switch (p.key) {
|
318
319
|
case re.Escape:
|
319
320
|
if (n.popoverState !== 0 || !u.current || B != null && B.activeElement && !u.current.contains(B.activeElement)) return;
|
320
|
-
p.preventDefault(), p.stopPropagation(), E({ type: 1 }), (
|
321
|
+
p.preventDefault(), p.stopPropagation(), E({ type: 1 }), (_ = n.button) == null || _.focus();
|
321
322
|
break;
|
322
323
|
}
|
323
324
|
});
|
@@ -329,30 +330,30 @@ function en(e, t) {
|
|
329
330
|
let p = B == null ? void 0 : B.activeElement;
|
330
331
|
u.current.contains(p) || le(u.current, Y.First);
|
331
332
|
}, [n.__demoMode, f, u.current, n.popoverState]);
|
332
|
-
let
|
333
|
-
var
|
333
|
+
let j = K(() => ({ open: n.popoverState === 0, close: P }), [n.popoverState, P]), te = Ce($ ? C() : {}, { ref: F, id: d, onKeyDown: R, onBlur: f && n.popoverState === 0 ? (p) => {
|
334
|
+
var _, w, I, x, L;
|
334
335
|
let A = p.relatedTarget;
|
335
|
-
A && u.current && ((
|
336
|
-
} : void 0, tabIndex: -1, style: { ...
|
336
|
+
A && u.current && ((_ = u.current) != null && _.contains(A) || (E({ type: 1 }), ((I = (w = n.beforePanelSentinel.current) == null ? void 0 : w.contains) != null && I.call(w, A) || (L = (x = n.afterPanelSentinel.current) == null ? void 0 : x.contains) != null && L.call(x, A)) && A.focus({ preventScroll: !0 })));
|
337
|
+
} : void 0, tabIndex: -1, style: { ...h.style, ...g, "--button-width": _t(n.button, !0).width }, ...Me(U) }), X = We(), v = S(() => {
|
337
338
|
let p = u.current;
|
338
339
|
if (!p) return;
|
339
|
-
function
|
340
|
-
Q(
|
340
|
+
function _() {
|
341
|
+
Q(X.current, { [J.Forwards]: () => {
|
341
342
|
var w;
|
342
|
-
le(p, Y.First) ===
|
343
|
+
le(p, Y.First) === Fe.Error && ((w = n.afterPanelSentinel.current) == null || w.focus());
|
343
344
|
}, [J.Backwards]: () => {
|
344
345
|
var w;
|
345
346
|
(w = n.button) == null || w.focus({ preventScroll: !0 });
|
346
347
|
} });
|
347
348
|
}
|
348
|
-
|
349
|
-
}), i =
|
349
|
+
_();
|
350
|
+
}), i = S(() => {
|
350
351
|
let p = u.current;
|
351
352
|
if (!p) return;
|
352
|
-
function
|
353
|
-
Q(
|
353
|
+
function _() {
|
354
|
+
Q(X.current, { [J.Forwards]: () => {
|
354
355
|
if (!n.button) return;
|
355
|
-
let w = Oe(),
|
356
|
+
let w = Oe(), I = w.indexOf(n.button), x = w.slice(0, I + 1), L = [...w.slice(I + 1), ...x];
|
356
357
|
for (let A of L.slice()) if (A.dataset.headlessuiFocusGuard === "true" || H != null && H.contains(A)) {
|
357
358
|
let ne = L.indexOf(A);
|
358
359
|
ne !== -1 && L.splice(ne, 1);
|
@@ -360,130 +361,149 @@ function en(e, t) {
|
|
360
361
|
le(L, Y.First, { sorted: !1 });
|
361
362
|
}, [J.Backwards]: () => {
|
362
363
|
var w;
|
363
|
-
le(p, Y.Previous) ===
|
364
|
+
le(p, Y.Previous) === Fe.Error && ((w = n.button) == null || w.focus());
|
364
365
|
} });
|
365
366
|
}
|
366
|
-
|
367
|
+
_();
|
367
368
|
});
|
368
|
-
return
|
369
|
+
return y.createElement(Ct, null, y.createElement(_e.Provider, { value: d }, y.createElement(Te.Provider, { value: { close: P, isPortalled: c } }, y.createElement(wt, { enabled: m ? e.static || O : !1 }, O && c && y.createElement(be, { id: a, ref: n.beforePanelSentinel, features: he.Focusable, "data-headlessui-focus-guard": !0, as: "button", type: "button", onFocus: v }), ue({ mergeRefs: q, ourProps: te, theirProps: h, slot: j, defaultTag: zt, features: en, visible: O, name: "Popover.Panel" }), O && c && y.createElement(be, { id: s, ref: n.afterPanelSentinel, features: he.Focusable, "data-headlessui-focus-guard": !0, as: "button", type: "button", onFocus: i })))));
|
369
370
|
}
|
370
|
-
let
|
371
|
-
function
|
372
|
-
let o = M(null), d = z(o, t), [f,
|
373
|
-
|
371
|
+
let nn = "div";
|
372
|
+
function rn(e, t) {
|
373
|
+
let o = M(null), d = z(o, t), [f, b] = W([]), m = S((a) => {
|
374
|
+
b((s) => {
|
374
375
|
let u = s.indexOf(a);
|
375
376
|
if (u !== -1) {
|
376
|
-
let
|
377
|
-
return
|
377
|
+
let $ = s.slice();
|
378
|
+
return $.splice(u, 1), $;
|
378
379
|
}
|
379
380
|
return s;
|
380
381
|
});
|
381
|
-
}), l =
|
382
|
+
}), l = S((a) => (b((s) => [...s, a]), () => m(a))), r = S(() => {
|
382
383
|
var a;
|
383
|
-
let s =
|
384
|
+
let s = De(o);
|
384
385
|
if (!s) return !1;
|
385
386
|
let u = s.activeElement;
|
386
|
-
return (a = o.current) != null && a.contains(u) ? !0 : f.some((
|
387
|
-
var
|
388
|
-
return ((
|
387
|
+
return (a = o.current) != null && a.contains(u) ? !0 : f.some(($) => {
|
388
|
+
var T, g;
|
389
|
+
return ((T = s.getElementById($.buttonId.current)) == null ? void 0 : T.contains(u)) || ((g = s.getElementById($.panelId.current)) == null ? void 0 : g.contains(u));
|
389
390
|
});
|
390
|
-
}),
|
391
|
+
}), h = S((a) => {
|
391
392
|
for (let s of f) s.buttonId.current !== a && s.close();
|
392
|
-
}), n =
|
393
|
-
return
|
393
|
+
}), n = K(() => ({ registerPopover: l, unregisterPopover: m, isFocusWithinPopoverGroup: r, closeOthers: h }), [l, m, r, h]), E = K(() => ({}), []), P = e, c = { ref: d };
|
394
|
+
return y.createElement(je, null, y.createElement(Re.Provider, { value: n }, ue({ ourProps: c, theirProps: P, slot: E, defaultTag: nn, name: "Popover.Group" })));
|
394
395
|
}
|
395
|
-
let
|
396
|
-
const
|
397
|
-
menu:
|
398
|
-
"menu-button": "_menu-
|
399
|
-
"menu-items": "_menu-
|
400
|
-
"menu-items-container": "_menu-items-
|
401
|
-
|
402
|
-
|
403
|
-
"enter-
|
404
|
-
|
405
|
-
|
406
|
-
"leave-
|
407
|
-
|
396
|
+
let on = V(qt), et = V(Qt), ln = V(ze), an = V(ze), tt = V(tn), un = V(rn), sn = Object.assign(on, { Button: et, Backdrop: an, Overlay: ln, Panel: tt, Group: un });
|
397
|
+
const cn = "_menu_1o2uo_3", dn = "_enter_1o2uo_34", pn = "_leave_1o2uo_48", G = {
|
398
|
+
menu: cn,
|
399
|
+
"menu-button": "_menu-button_1o2uo_6",
|
400
|
+
"menu-items": "_menu-items_1o2uo_11",
|
401
|
+
"menu-items-container": "_menu-items-container_1o2uo_22",
|
402
|
+
"close-button": "_close-button_1o2uo_28",
|
403
|
+
enter: dn,
|
404
|
+
"enter-from": "_enter-from_1o2uo_38",
|
405
|
+
"enter-to": "_enter-to_1o2uo_43",
|
406
|
+
leave: pn,
|
407
|
+
"leave-from": "_leave-from_1o2uo_52",
|
408
|
+
"leave-to": "_leave-to_1o2uo_57"
|
409
|
+
}, In = 300, Cn = ot(
|
408
410
|
({
|
409
411
|
children: e,
|
410
412
|
position: t = "bottom end",
|
411
413
|
popoverProps: o,
|
412
414
|
className: d,
|
413
415
|
buttonClassName: f,
|
414
|
-
panelClassName:
|
416
|
+
panelClassName: b,
|
415
417
|
menuItemsClassName: m,
|
416
418
|
buttonContent: l,
|
417
|
-
|
418
|
-
|
419
|
+
needCloseButton: r,
|
420
|
+
openOnHover: h = !1,
|
421
|
+
isOpen: n = !1
|
419
422
|
}) => {
|
420
|
-
const [
|
421
|
-
|
422
|
-
}, [
|
423
|
-
(
|
424
|
-
if (
|
425
|
-
const
|
426
|
-
|
423
|
+
const [E, P] = W(n), c = M(null), a = M(null), s = Ae(() => {
|
424
|
+
h && P(!0);
|
425
|
+
}, [h]), u = Ae(
|
426
|
+
($) => {
|
427
|
+
if (h) {
|
428
|
+
const T = $.relatedTarget;
|
429
|
+
c.current && !c.current.contains(T) && a.current && !a.current.contains(T) && P(!1);
|
427
430
|
}
|
428
431
|
},
|
429
|
-
[
|
432
|
+
[h]
|
430
433
|
);
|
431
434
|
return /* @__PURE__ */ ce(
|
432
|
-
|
435
|
+
sn,
|
433
436
|
{
|
434
437
|
as: "div",
|
435
|
-
className: fe(
|
438
|
+
className: fe(G.menu, d),
|
436
439
|
...o,
|
437
|
-
children: ({ open:
|
438
|
-
|
439
|
-
|
440
|
-
|
441
|
-
|
442
|
-
|
443
|
-
|
444
|
-
|
445
|
-
|
446
|
-
|
447
|
-
|
448
|
-
|
449
|
-
|
450
|
-
|
451
|
-
|
452
|
-
|
453
|
-
|
454
|
-
|
455
|
-
|
456
|
-
|
457
|
-
|
458
|
-
|
459
|
-
|
460
|
-
|
461
|
-
|
462
|
-
|
463
|
-
|
464
|
-
|
465
|
-
|
466
|
-
|
467
|
-
|
468
|
-
|
469
|
-
|
470
|
-
|
471
|
-
|
472
|
-
|
440
|
+
children: ({ open: $, close: T }) => {
|
441
|
+
const g = () => {
|
442
|
+
T(), P(!1);
|
443
|
+
};
|
444
|
+
return /* @__PURE__ */ Le(nt, { children: [
|
445
|
+
/* @__PURE__ */ ce(
|
446
|
+
et,
|
447
|
+
{
|
448
|
+
ref: c,
|
449
|
+
onMouseEnter: s,
|
450
|
+
onMouseLeave: u,
|
451
|
+
className: fe(G["menu-button"], f),
|
452
|
+
children: l
|
453
|
+
}
|
454
|
+
),
|
455
|
+
/* @__PURE__ */ ce(
|
456
|
+
Gt,
|
457
|
+
{
|
458
|
+
show: E || $,
|
459
|
+
as: pe,
|
460
|
+
enter: G.enter,
|
461
|
+
enterFrom: G["enter-from"],
|
462
|
+
enterTo: G["enter-to"],
|
463
|
+
leave: G.leave,
|
464
|
+
leaveFrom: G["leave-from"],
|
465
|
+
leaveTo: G["leave-to"],
|
466
|
+
children: /* @__PURE__ */ Le(
|
467
|
+
tt,
|
468
|
+
{
|
469
|
+
ref: a,
|
470
|
+
anchor: t,
|
471
|
+
onMouseEnter: s,
|
472
|
+
onMouseLeave: u,
|
473
|
+
className: fe(G["menu-items"], b),
|
474
|
+
children: [
|
475
|
+
r && /* @__PURE__ */ ce(
|
476
|
+
lt,
|
477
|
+
{
|
478
|
+
isIconButton: !0,
|
479
|
+
iconName: "Close16px",
|
480
|
+
onClick: g,
|
481
|
+
clear: !0,
|
482
|
+
className: G["close-button"]
|
483
|
+
}
|
473
484
|
),
|
474
|
-
|
475
|
-
|
476
|
-
|
477
|
-
|
478
|
-
|
479
|
-
|
480
|
-
|
481
|
-
|
485
|
+
/* @__PURE__ */ ce(
|
486
|
+
"div",
|
487
|
+
{
|
488
|
+
className: fe(
|
489
|
+
G["menu-items-container"],
|
490
|
+
m
|
491
|
+
),
|
492
|
+
children: typeof e == "function" ? e({ close: g }) : e
|
493
|
+
}
|
494
|
+
)
|
495
|
+
]
|
496
|
+
}
|
497
|
+
)
|
498
|
+
}
|
499
|
+
)
|
500
|
+
] });
|
501
|
+
}
|
482
502
|
}
|
483
503
|
);
|
484
504
|
}
|
485
505
|
);
|
486
506
|
export {
|
487
|
-
|
488
|
-
|
507
|
+
In as ANIMATION_DELAY,
|
508
|
+
Cn as Dropdown
|
489
509
|
};
|