@ultraviolet/ui 1.95.4 → 1.95.6
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/components/ActionBar/index.cjs +13 -4
- package/dist/components/ActionBar/index.js +13 -4
- package/dist/components/MenuV2/MenuContent.cjs +48 -14
- package/dist/components/MenuV2/MenuContent.d.ts +1 -0
- package/dist/components/MenuV2/MenuContent.js +44 -10
- package/dist/components/MenuV2/index.d.ts +1 -0
- package/dist/components/MenuV2/types.d.ts +1 -0
- package/dist/components/Modal/components/Dialog.cjs +5 -5
- package/dist/components/Modal/components/Dialog.js +5 -5
- package/dist/components/PieChart/types.d.ts +4 -0
- package/package.json +7 -7
|
@@ -4,13 +4,14 @@ Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
|
4
4
|
const jsxRuntime = require("@emotion/react/jsx-runtime");
|
|
5
5
|
const _styled = require("@emotion/styled/base");
|
|
6
6
|
const reactDom = require("react-dom");
|
|
7
|
+
const index = require("../Stack/index.cjs");
|
|
7
8
|
const animations = require("../../utils/animations.cjs");
|
|
8
9
|
const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
|
|
9
10
|
const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
|
|
10
11
|
const StyledDiv = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
|
|
11
|
-
target: "
|
|
12
|
+
target: "enye6lh1"
|
|
12
13
|
} : {
|
|
13
|
-
target: "
|
|
14
|
+
target: "enye6lh1",
|
|
14
15
|
label: "StyledDiv"
|
|
15
16
|
})("background:", ({
|
|
16
17
|
theme
|
|
@@ -23,12 +24,20 @@ const StyledDiv = /* @__PURE__ */ _styled__default.default("div", process.env.NO
|
|
|
23
24
|
theme
|
|
24
25
|
}) => `${theme.shadows.fixed[0]}, ${theme.shadows.fixed[1]}`, ";height:", ({
|
|
25
26
|
theme
|
|
26
|
-
}) => theme.sizing["700"], ";left:50%;position:fixed;transform:translate(-50%, 0);width:37.5rem;animation:", animations.fadeIn, " 0.2s ease-in-out;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
27
|
+
}) => theme.sizing["700"], ";left:50%;position:fixed;transform:translate(-50%, 0);width:37.5rem;animation:", animations.fadeIn, " 0.2s ease-in-out;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0FjdGlvbkJhci9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBUThDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0FjdGlvbkJhci9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgY3JlYXRlUG9ydGFsIH0gZnJvbSAncmVhY3QtZG9tJ1xuaW1wb3J0IHsgZmFkZUluIH0gZnJvbSAnLi4vLi4vdXRpbHMnXG5pbXBvcnQgeyBTdGFjayB9IGZyb20gJy4uL1N0YWNrJ1xuXG5jb25zdCBTdHlsZWREaXYgPSBzdHlsZWQuZGl2PHsgcmFuazogbnVtYmVyIH0+YFxuICBiYWNrZ3JvdW5kOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5vdGhlci5lbGV2YXRpb24uYmFja2dyb3VuZC5maXhlZH07XG4gIGJvcmRlci1yYWRpdXM6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUucmFkaWkuZGVmYXVsdH07XG4gIGJvdHRvbTogJHsoeyByYW5rLCB0aGVtZSB9KSA9PiBgY2FsYygke3RoZW1lLnNpemluZ1snNzAwJ119ICogJHtyYW5rfSArICR7dGhlbWUuc3BhY2VbJzInXX0pYH07XG4gIGJveC1zaGFkb3c6ICR7KHsgdGhlbWUgfSkgPT4gYCR7dGhlbWUuc2hhZG93cy5maXhlZFswXX0sICR7dGhlbWUuc2hhZG93cy5maXhlZFsxXX1gfTtcbiAgaGVpZ2h0OiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1snNzAwJ119O1xuICBsZWZ0OiA1MCU7XG4gIHBvc2l0aW9uOiBmaXhlZDtcbiAgdHJhbnNmb3JtOiB0cmFuc2xhdGUoLTUwJSwgMCk7XG4gIHdpZHRoOiAzNy41cmVtO1xuICBhbmltYXRpb246ICR7ZmFkZUlufSAwLjJzIGVhc2UtaW4tb3V0O1xuYFxuXG5jb25zdCBDb250YWluZXIgPSBzdHlsZWQoU3RhY2spYFxuICBoZWlnaHQ6IDEwMCU7XG4gIHBhZGRpbmc6IDAgJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMiddfTtcbmBcblxudHlwZSBBY3Rpb25CYXJQcm9wcyA9IHtcbiAgY2hpbGRyZW46IFJlYWN0Tm9kZVxuICAvKipcbiAgICogVGhlIHBvc2l0aW9uIG9mIHRoZSBiYXIgKHN0YXJ0IGF0IDApXG4gICAqL1xuICByYW5rPzogbnVtYmVyXG4gIHJvbGU/OiBzdHJpbmdcbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gICdkYXRhLXRlc3RpZCc/OiBzdHJpbmdcbn1cblxuLyoqXG4gKiBUaGUgQWN0aW9uQmFyIGlzIGEgZmxvYXRpbmcgYmFyIHRoYXQgYXBwZWFycyBhdCB0aGUgYm90dG9tIG9mIGEgcGFnZS5cbiAqIEl0IGNhbiBiZSB1c2VkIHRvIGRpc3BsYXkgaW1wb3J0YW50IGFjdGlvbnMgb3IgaW5mb3JtYXRpb24gdG8gdGhlIHVzZXIsIGFuZCBjYW4gYmUgY29uZmlndXJlZCB0byBkaXNwbGF5IGEgdmFyaWV0eSBvZiBkaWZmZXJlbnQgY29udGVudCB0eXBlcy5cbiAqXG4gKiAqKk5vdGU6KiogQWN0aW9uQmFyIGlzIGFkZGVkIGludG8gYSBwb3J0YWwgYXQgdGhlIGVuZCBvZiB0aGUgYm9keSBlbGVtZW50LiBUaGlzIG1lYW5zIHRoYXQgaXQgd2lsbCBhbHdheXMgYmUgb24gdG9wIG9mIG90aGVyIGVsZW1lbnRzIHdpdGhvdXQgYHotaW5kZXhgLFxuICogYW5kIHdpbGwgbm90IGJlIGFmZmVjdGVkIGJ5IHRoZSBsYXlvdXQgb2YgdGhlIHBhZ2UgaXQgaXMgb24uXG4gKi9cbmV4cG9ydCBjb25zdCBBY3Rpb25CYXIgPSAoe1xuICBjaGlsZHJlbixcbiAgcm9sZSA9ICdkaWFsb2cnLFxuICByYW5rID0gMCxcbiAgY2xhc3NOYW1lLFxuICAnZGF0YS10ZXN0aWQnOiBkYXRhVGVzdElkLFxufTogQWN0aW9uQmFyUHJvcHMpID0+XG4gIGNyZWF0ZVBvcnRhbChcbiAgICA8U3R5bGVkRGl2XG4gICAgICByYW5rPXtyYW5rfVxuICAgICAgcm9sZT17cm9sZX1cbiAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgZGF0YS10ZXN0aWQ9e2RhdGFUZXN0SWR9XG4gICAgPlxuICAgICAgPENvbnRhaW5lciBhbGlnbkl0ZW1zPVwiY2VudGVyXCI+e2NoaWxkcmVufTwvQ29udGFpbmVyPlxuICAgIDwvU3R5bGVkRGl2PixcbiAgICBkb2N1bWVudC5ib2R5LFxuICApXG4iXX0= */"));
|
|
28
|
+
const Container = /* @__PURE__ */ _styled__default.default(index.Stack, process.env.NODE_ENV === "production" ? {
|
|
29
|
+
target: "enye6lh0"
|
|
30
|
+
} : {
|
|
31
|
+
target: "enye6lh0",
|
|
32
|
+
label: "Container"
|
|
33
|
+
})("height:100%;padding:0 ", ({
|
|
34
|
+
theme
|
|
35
|
+
}) => theme.space["2"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0FjdGlvbkJhci9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBcUIrQiIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9BY3Rpb25CYXIvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHR5cGUgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IGNyZWF0ZVBvcnRhbCB9IGZyb20gJ3JlYWN0LWRvbSdcbmltcG9ydCB7IGZhZGVJbiB9IGZyb20gJy4uLy4uL3V0aWxzJ1xuaW1wb3J0IHsgU3RhY2sgfSBmcm9tICcuLi9TdGFjaydcblxuY29uc3QgU3R5bGVkRGl2ID0gc3R5bGVkLmRpdjx7IHJhbms6IG51bWJlciB9PmBcbiAgYmFja2dyb3VuZDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMub3RoZXIuZWxldmF0aW9uLmJhY2tncm91bmQuZml4ZWR9O1xuICBib3JkZXItcmFkaXVzOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmRlZmF1bHR9O1xuICBib3R0b206ICR7KHsgcmFuaywgdGhlbWUgfSkgPT4gYGNhbGMoJHt0aGVtZS5zaXppbmdbJzcwMCddfSAqICR7cmFua30gKyAke3RoZW1lLnNwYWNlWycyJ119KWB9O1xuICBib3gtc2hhZG93OiAkeyh7IHRoZW1lIH0pID0+IGAke3RoZW1lLnNoYWRvd3MuZml4ZWRbMF19LCAke3RoZW1lLnNoYWRvd3MuZml4ZWRbMV19YH07XG4gIGhlaWdodDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zaXppbmdbJzcwMCddfTtcbiAgbGVmdDogNTAlO1xuICBwb3NpdGlvbjogZml4ZWQ7XG4gIHRyYW5zZm9ybTogdHJhbnNsYXRlKC01MCUsIDApO1xuICB3aWR0aDogMzcuNXJlbTtcbiAgYW5pbWF0aW9uOiAke2ZhZGVJbn0gMC4ycyBlYXNlLWluLW91dDtcbmBcblxuY29uc3QgQ29udGFpbmVyID0gc3R5bGVkKFN0YWNrKWBcbiAgaGVpZ2h0OiAxMDAlO1xuICBwYWRkaW5nOiAwICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzInXX07XG5gXG5cbnR5cGUgQWN0aW9uQmFyUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgLyoqXG4gICAqIFRoZSBwb3NpdGlvbiBvZiB0aGUgYmFyIChzdGFydCBhdCAwKVxuICAgKi9cbiAgcmFuaz86IG51bWJlclxuICByb2xlPzogc3RyaW5nXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICAnZGF0YS10ZXN0aWQnPzogc3RyaW5nXG59XG5cbi8qKlxuICogVGhlIEFjdGlvbkJhciBpcyBhIGZsb2F0aW5nIGJhciB0aGF0IGFwcGVhcnMgYXQgdGhlIGJvdHRvbSBvZiBhIHBhZ2UuXG4gKiBJdCBjYW4gYmUgdXNlZCB0byBkaXNwbGF5IGltcG9ydGFudCBhY3Rpb25zIG9yIGluZm9ybWF0aW9uIHRvIHRoZSB1c2VyLCBhbmQgY2FuIGJlIGNvbmZpZ3VyZWQgdG8gZGlzcGxheSBhIHZhcmlldHkgb2YgZGlmZmVyZW50IGNvbnRlbnQgdHlwZXMuXG4gKlxuICogKipOb3RlOioqIEFjdGlvbkJhciBpcyBhZGRlZCBpbnRvIGEgcG9ydGFsIGF0IHRoZSBlbmQgb2YgdGhlIGJvZHkgZWxlbWVudC4gVGhpcyBtZWFucyB0aGF0IGl0IHdpbGwgYWx3YXlzIGJlIG9uIHRvcCBvZiBvdGhlciBlbGVtZW50cyB3aXRob3V0IGB6LWluZGV4YCxcbiAqIGFuZCB3aWxsIG5vdCBiZSBhZmZlY3RlZCBieSB0aGUgbGF5b3V0IG9mIHRoZSBwYWdlIGl0IGlzIG9uLlxuICovXG5leHBvcnQgY29uc3QgQWN0aW9uQmFyID0gKHtcbiAgY2hpbGRyZW4sXG4gIHJvbGUgPSAnZGlhbG9nJyxcbiAgcmFuayA9IDAsXG4gIGNsYXNzTmFtZSxcbiAgJ2RhdGEtdGVzdGlkJzogZGF0YVRlc3RJZCxcbn06IEFjdGlvbkJhclByb3BzKSA9PlxuICBjcmVhdGVQb3J0YWwoXG4gICAgPFN0eWxlZERpdlxuICAgICAgcmFuaz17cmFua31cbiAgICAgIHJvbGU9e3JvbGV9XG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfVxuICAgID5cbiAgICAgIDxDb250YWluZXIgYWxpZ25JdGVtcz1cImNlbnRlclwiPntjaGlsZHJlbn08L0NvbnRhaW5lcj5cbiAgICA8L1N0eWxlZERpdj4sXG4gICAgZG9jdW1lbnQuYm9keSxcbiAgKVxuIl19 */"));
|
|
27
36
|
const ActionBar = ({
|
|
28
37
|
children,
|
|
29
38
|
role = "dialog",
|
|
30
39
|
rank = 0,
|
|
31
40
|
className,
|
|
32
41
|
"data-testid": dataTestId
|
|
33
|
-
}) => reactDom.createPortal(/* @__PURE__ */ jsxRuntime.jsx(StyledDiv, { rank, role, className, "data-testid": dataTestId, children }), document.body);
|
|
42
|
+
}) => reactDom.createPortal(/* @__PURE__ */ jsxRuntime.jsx(StyledDiv, { rank, role, className, "data-testid": dataTestId, children: /* @__PURE__ */ jsxRuntime.jsx(Container, { alignItems: "center", children }) }), document.body);
|
|
34
43
|
exports.ActionBar = ActionBar;
|
|
@@ -2,11 +2,12 @@
|
|
|
2
2
|
import { jsx } from "@emotion/react/jsx-runtime";
|
|
3
3
|
import _styled from "@emotion/styled/base";
|
|
4
4
|
import { createPortal } from "react-dom";
|
|
5
|
+
import { Stack } from "../Stack/index.js";
|
|
5
6
|
import { fadeIn } from "../../utils/animations.js";
|
|
6
7
|
const StyledDiv = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
|
|
7
|
-
target: "
|
|
8
|
+
target: "enye6lh1"
|
|
8
9
|
} : {
|
|
9
|
-
target: "
|
|
10
|
+
target: "enye6lh1",
|
|
10
11
|
label: "StyledDiv"
|
|
11
12
|
})("background:", ({
|
|
12
13
|
theme
|
|
@@ -19,14 +20,22 @@ const StyledDiv = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "produ
|
|
|
19
20
|
theme
|
|
20
21
|
}) => `${theme.shadows.fixed[0]}, ${theme.shadows.fixed[1]}`, ";height:", ({
|
|
21
22
|
theme
|
|
22
|
-
}) => theme.sizing["700"], ";left:50%;position:fixed;transform:translate(-50%, 0);width:37.5rem;animation:", fadeIn, " 0.2s ease-in-out;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
23
|
+
}) => theme.sizing["700"], ";left:50%;position:fixed;transform:translate(-50%, 0);width:37.5rem;animation:", fadeIn, " 0.2s ease-in-out;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0FjdGlvbkJhci9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBUThDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0FjdGlvbkJhci9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgY3JlYXRlUG9ydGFsIH0gZnJvbSAncmVhY3QtZG9tJ1xuaW1wb3J0IHsgZmFkZUluIH0gZnJvbSAnLi4vLi4vdXRpbHMnXG5pbXBvcnQgeyBTdGFjayB9IGZyb20gJy4uL1N0YWNrJ1xuXG5jb25zdCBTdHlsZWREaXYgPSBzdHlsZWQuZGl2PHsgcmFuazogbnVtYmVyIH0+YFxuICBiYWNrZ3JvdW5kOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5vdGhlci5lbGV2YXRpb24uYmFja2dyb3VuZC5maXhlZH07XG4gIGJvcmRlci1yYWRpdXM6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUucmFkaWkuZGVmYXVsdH07XG4gIGJvdHRvbTogJHsoeyByYW5rLCB0aGVtZSB9KSA9PiBgY2FsYygke3RoZW1lLnNpemluZ1snNzAwJ119ICogJHtyYW5rfSArICR7dGhlbWUuc3BhY2VbJzInXX0pYH07XG4gIGJveC1zaGFkb3c6ICR7KHsgdGhlbWUgfSkgPT4gYCR7dGhlbWUuc2hhZG93cy5maXhlZFswXX0sICR7dGhlbWUuc2hhZG93cy5maXhlZFsxXX1gfTtcbiAgaGVpZ2h0OiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1snNzAwJ119O1xuICBsZWZ0OiA1MCU7XG4gIHBvc2l0aW9uOiBmaXhlZDtcbiAgdHJhbnNmb3JtOiB0cmFuc2xhdGUoLTUwJSwgMCk7XG4gIHdpZHRoOiAzNy41cmVtO1xuICBhbmltYXRpb246ICR7ZmFkZUlufSAwLjJzIGVhc2UtaW4tb3V0O1xuYFxuXG5jb25zdCBDb250YWluZXIgPSBzdHlsZWQoU3RhY2spYFxuICBoZWlnaHQ6IDEwMCU7XG4gIHBhZGRpbmc6IDAgJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVsnMiddfTtcbmBcblxudHlwZSBBY3Rpb25CYXJQcm9wcyA9IHtcbiAgY2hpbGRyZW46IFJlYWN0Tm9kZVxuICAvKipcbiAgICogVGhlIHBvc2l0aW9uIG9mIHRoZSBiYXIgKHN0YXJ0IGF0IDApXG4gICAqL1xuICByYW5rPzogbnVtYmVyXG4gIHJvbGU/OiBzdHJpbmdcbiAgY2xhc3NOYW1lPzogc3RyaW5nXG4gICdkYXRhLXRlc3RpZCc/OiBzdHJpbmdcbn1cblxuLyoqXG4gKiBUaGUgQWN0aW9uQmFyIGlzIGEgZmxvYXRpbmcgYmFyIHRoYXQgYXBwZWFycyBhdCB0aGUgYm90dG9tIG9mIGEgcGFnZS5cbiAqIEl0IGNhbiBiZSB1c2VkIHRvIGRpc3BsYXkgaW1wb3J0YW50IGFjdGlvbnMgb3IgaW5mb3JtYXRpb24gdG8gdGhlIHVzZXIsIGFuZCBjYW4gYmUgY29uZmlndXJlZCB0byBkaXNwbGF5IGEgdmFyaWV0eSBvZiBkaWZmZXJlbnQgY29udGVudCB0eXBlcy5cbiAqXG4gKiAqKk5vdGU6KiogQWN0aW9uQmFyIGlzIGFkZGVkIGludG8gYSBwb3J0YWwgYXQgdGhlIGVuZCBvZiB0aGUgYm9keSBlbGVtZW50LiBUaGlzIG1lYW5zIHRoYXQgaXQgd2lsbCBhbHdheXMgYmUgb24gdG9wIG9mIG90aGVyIGVsZW1lbnRzIHdpdGhvdXQgYHotaW5kZXhgLFxuICogYW5kIHdpbGwgbm90IGJlIGFmZmVjdGVkIGJ5IHRoZSBsYXlvdXQgb2YgdGhlIHBhZ2UgaXQgaXMgb24uXG4gKi9cbmV4cG9ydCBjb25zdCBBY3Rpb25CYXIgPSAoe1xuICBjaGlsZHJlbixcbiAgcm9sZSA9ICdkaWFsb2cnLFxuICByYW5rID0gMCxcbiAgY2xhc3NOYW1lLFxuICAnZGF0YS10ZXN0aWQnOiBkYXRhVGVzdElkLFxufTogQWN0aW9uQmFyUHJvcHMpID0+XG4gIGNyZWF0ZVBvcnRhbChcbiAgICA8U3R5bGVkRGl2XG4gICAgICByYW5rPXtyYW5rfVxuICAgICAgcm9sZT17cm9sZX1cbiAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgZGF0YS10ZXN0aWQ9e2RhdGFUZXN0SWR9XG4gICAgPlxuICAgICAgPENvbnRhaW5lciBhbGlnbkl0ZW1zPVwiY2VudGVyXCI+e2NoaWxkcmVufTwvQ29udGFpbmVyPlxuICAgIDwvU3R5bGVkRGl2PixcbiAgICBkb2N1bWVudC5ib2R5LFxuICApXG4iXX0= */"));
|
|
24
|
+
const Container = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
|
|
25
|
+
target: "enye6lh0"
|
|
26
|
+
} : {
|
|
27
|
+
target: "enye6lh0",
|
|
28
|
+
label: "Container"
|
|
29
|
+
})("height:100%;padding:0 ", ({
|
|
30
|
+
theme
|
|
31
|
+
}) => theme.space["2"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0FjdGlvbkJhci9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBcUIrQiIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9BY3Rpb25CYXIvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHR5cGUgeyBSZWFjdE5vZGUgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IGNyZWF0ZVBvcnRhbCB9IGZyb20gJ3JlYWN0LWRvbSdcbmltcG9ydCB7IGZhZGVJbiB9IGZyb20gJy4uLy4uL3V0aWxzJ1xuaW1wb3J0IHsgU3RhY2sgfSBmcm9tICcuLi9TdGFjaydcblxuY29uc3QgU3R5bGVkRGl2ID0gc3R5bGVkLmRpdjx7IHJhbms6IG51bWJlciB9PmBcbiAgYmFja2dyb3VuZDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMub3RoZXIuZWxldmF0aW9uLmJhY2tncm91bmQuZml4ZWR9O1xuICBib3JkZXItcmFkaXVzOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnJhZGlpLmRlZmF1bHR9O1xuICBib3R0b206ICR7KHsgcmFuaywgdGhlbWUgfSkgPT4gYGNhbGMoJHt0aGVtZS5zaXppbmdbJzcwMCddfSAqICR7cmFua30gKyAke3RoZW1lLnNwYWNlWycyJ119KWB9O1xuICBib3gtc2hhZG93OiAkeyh7IHRoZW1lIH0pID0+IGAke3RoZW1lLnNoYWRvd3MuZml4ZWRbMF19LCAke3RoZW1lLnNoYWRvd3MuZml4ZWRbMV19YH07XG4gIGhlaWdodDogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zaXppbmdbJzcwMCddfTtcbiAgbGVmdDogNTAlO1xuICBwb3NpdGlvbjogZml4ZWQ7XG4gIHRyYW5zZm9ybTogdHJhbnNsYXRlKC01MCUsIDApO1xuICB3aWR0aDogMzcuNXJlbTtcbiAgYW5pbWF0aW9uOiAke2ZhZGVJbn0gMC4ycyBlYXNlLWluLW91dDtcbmBcblxuY29uc3QgQ29udGFpbmVyID0gc3R5bGVkKFN0YWNrKWBcbiAgaGVpZ2h0OiAxMDAlO1xuICBwYWRkaW5nOiAwICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3BhY2VbJzInXX07XG5gXG5cbnR5cGUgQWN0aW9uQmFyUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgLyoqXG4gICAqIFRoZSBwb3NpdGlvbiBvZiB0aGUgYmFyIChzdGFydCBhdCAwKVxuICAgKi9cbiAgcmFuaz86IG51bWJlclxuICByb2xlPzogc3RyaW5nXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICAnZGF0YS10ZXN0aWQnPzogc3RyaW5nXG59XG5cbi8qKlxuICogVGhlIEFjdGlvbkJhciBpcyBhIGZsb2F0aW5nIGJhciB0aGF0IGFwcGVhcnMgYXQgdGhlIGJvdHRvbSBvZiBhIHBhZ2UuXG4gKiBJdCBjYW4gYmUgdXNlZCB0byBkaXNwbGF5IGltcG9ydGFudCBhY3Rpb25zIG9yIGluZm9ybWF0aW9uIHRvIHRoZSB1c2VyLCBhbmQgY2FuIGJlIGNvbmZpZ3VyZWQgdG8gZGlzcGxheSBhIHZhcmlldHkgb2YgZGlmZmVyZW50IGNvbnRlbnQgdHlwZXMuXG4gKlxuICogKipOb3RlOioqIEFjdGlvbkJhciBpcyBhZGRlZCBpbnRvIGEgcG9ydGFsIGF0IHRoZSBlbmQgb2YgdGhlIGJvZHkgZWxlbWVudC4gVGhpcyBtZWFucyB0aGF0IGl0IHdpbGwgYWx3YXlzIGJlIG9uIHRvcCBvZiBvdGhlciBlbGVtZW50cyB3aXRob3V0IGB6LWluZGV4YCxcbiAqIGFuZCB3aWxsIG5vdCBiZSBhZmZlY3RlZCBieSB0aGUgbGF5b3V0IG9mIHRoZSBwYWdlIGl0IGlzIG9uLlxuICovXG5leHBvcnQgY29uc3QgQWN0aW9uQmFyID0gKHtcbiAgY2hpbGRyZW4sXG4gIHJvbGUgPSAnZGlhbG9nJyxcbiAgcmFuayA9IDAsXG4gIGNsYXNzTmFtZSxcbiAgJ2RhdGEtdGVzdGlkJzogZGF0YVRlc3RJZCxcbn06IEFjdGlvbkJhclByb3BzKSA9PlxuICBjcmVhdGVQb3J0YWwoXG4gICAgPFN0eWxlZERpdlxuICAgICAgcmFuaz17cmFua31cbiAgICAgIHJvbGU9e3JvbGV9XG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfVxuICAgID5cbiAgICAgIDxDb250YWluZXIgYWxpZ25JdGVtcz1cImNlbnRlclwiPntjaGlsZHJlbn08L0NvbnRhaW5lcj5cbiAgICA8L1N0eWxlZERpdj4sXG4gICAgZG9jdW1lbnQuYm9keSxcbiAgKVxuIl19 */"));
|
|
23
32
|
const ActionBar = ({
|
|
24
33
|
children,
|
|
25
34
|
role = "dialog",
|
|
26
35
|
rank = 0,
|
|
27
36
|
className,
|
|
28
37
|
"data-testid": dataTestId
|
|
29
|
-
}) => createPortal(/* @__PURE__ */ jsx(StyledDiv, { rank, role, className, "data-testid": dataTestId, children }), document.body);
|
|
38
|
+
}) => createPortal(/* @__PURE__ */ jsx(StyledDiv, { rank, role, className, "data-testid": dataTestId, children: /* @__PURE__ */ jsx(Container, { alignItems: "center", children }) }), document.body);
|
|
30
39
|
export {
|
|
31
40
|
ActionBar
|
|
32
41
|
};
|
|
@@ -5,19 +5,22 @@ const jsxRuntime = require("@emotion/react/jsx-runtime");
|
|
|
5
5
|
const _styled = require("@emotion/styled/base");
|
|
6
6
|
const React = require("react");
|
|
7
7
|
const index = require("../Popup/index.cjs");
|
|
8
|
-
const index$
|
|
9
|
-
const index$
|
|
8
|
+
const index$2 = require("../SearchInput/index.cjs");
|
|
9
|
+
const index$1 = require("../Stack/index.cjs");
|
|
10
10
|
const MenuProvider = require("./MenuProvider.cjs");
|
|
11
11
|
const constants = require("./constants.cjs");
|
|
12
12
|
const helpers = require("./helpers.cjs");
|
|
13
13
|
const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
|
|
14
14
|
const _styled__default = /* @__PURE__ */ _interopDefaultCompat(_styled);
|
|
15
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__() {
|
|
16
|
+
return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop).";
|
|
17
|
+
}
|
|
15
18
|
const StyledPopup = /* @__PURE__ */ _styled__default.default(index.Popup, process.env.NODE_ENV === "production" ? {
|
|
16
19
|
shouldForwardProp: (prop) => !["size", "searchable"].includes(prop),
|
|
17
|
-
target: "
|
|
20
|
+
target: "e1rdim8w4"
|
|
18
21
|
} : {
|
|
19
22
|
shouldForwardProp: (prop) => !["size", "searchable"].includes(prop),
|
|
20
|
-
target: "
|
|
23
|
+
target: "e1rdim8w4",
|
|
21
24
|
label: "StyledPopup"
|
|
22
25
|
})("background-color:", ({
|
|
23
26
|
theme
|
|
@@ -31,27 +34,54 @@ const StyledPopup = /* @__PURE__ */ _styled__default.default(index.Popup, proces
|
|
|
31
34
|
searchable
|
|
32
35
|
}) => searchable ? `min-width: 20rem` : null, ";padding:", ({
|
|
33
36
|
theme
|
|
34
|
-
}) => `${theme.space["0.25"]} 0`, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL01lbnVWMi9NZW51Q29udGVudC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBMEJzRCIsImZpbGUiOiIvaG9tZS9ydW5uZXIvd29yay91bHRyYXZpb2xldC91bHRyYXZpb2xldC9wYWNrYWdlcy91aS9zcmMvY29tcG9uZW50cy9NZW51VjIvTWVudUNvbnRlbnQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHR5cGUgeyBCdXR0b25IVE1MQXR0cmlidXRlcywgTW91c2VFdmVudCwgUmVhY3ROb2RlLCBSZWYgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7XG4gIGNsb25lRWxlbWVudCxcbiAgZm9yd2FyZFJlZixcbiAgaXNWYWxpZEVsZW1lbnQsXG4gIHVzZUNhbGxiYWNrLFxuICB1c2VFZmZlY3QsXG4gIHVzZUlkLFxuICB1c2VJbXBlcmF0aXZlSGFuZGxlLFxuICB1c2VNZW1vLFxuICB1c2VSZWYsXG4gIHVzZVN0YXRlLFxufSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IFBvcHVwIH0gZnJvbSAnLi4vUG9wdXAnXG5pbXBvcnQgeyBTZWFyY2hJbnB1dCB9IGZyb20gJy4uL1NlYXJjaElucHV0J1xuaW1wb3J0IHsgU3RhY2sgfSBmcm9tICcuLi9TdGFjaydcbmltcG9ydCB7IHVzZU1lbnUgfSBmcm9tICcuL01lbnVQcm92aWRlcidcbmltcG9ydCB7IFNJWkVTIH0gZnJvbSAnLi9jb25zdGFudHMnXG5pbXBvcnQgeyBzZWFyY2hDaGlsZHJlbiB9IGZyb20gJy4vaGVscGVycydcbmltcG9ydCB0eXBlIHsgTWVudVByb3BzIH0gZnJvbSAnLi90eXBlcydcblxuY29uc3QgU3R5bGVkUG9wdXAgPSBzdHlsZWQoUG9wdXAsIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IHByb3AgPT4gIVsnc2l6ZScsICdzZWFyY2hhYmxlJ10uaW5jbHVkZXMocHJvcCksXG59KTx7IHNpemU/OiBrZXlvZiB0eXBlb2YgU0laRVM7IHNlYXJjaGFibGU6IGJvb2xlYW4gfT5gXG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm90aGVyLmVsZXZhdGlvbi5iYWNrZ3JvdW5kLnJhaXNlZH07XG4gIGJveC1zaGFkb3c6ICR7KHsgdGhlbWUgfSkgPT4gYCR7dGhlbWUuc2hhZG93cy5yYWlzZWRbMF19LCAke3RoZW1lLnNoYWRvd3MucmFpc2VkWzFdfWB9O1xuICBwYWRkaW5nOiAwO1xuXG4gICZbZGF0YS1oYXMtYXJyb3c9J3RydWUnXSB7XG4gICAgJjo6YWZ0ZXIge1xuICAgICAgYm9yZGVyLWNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLmNvbG9ycy5vdGhlci5lbGV2YXRpb24uYmFja2dyb3VuZC5yYWlzZWR9XG4gICAgICAgIHRyYW5zcGFyZW50IHRyYW5zcGFyZW50IHRyYW5zcGFyZW50O1xuICAgIH1cbiAgfVxuXG4gIG1pbi13aWR0aDogJHtTSVpFUy5zbWFsbH07XG4gIG1heC13aWR0aDogJHtTSVpFUy5sYXJnZX07XG4gICR7KHsgc2l6ZSB9KSA9PiAoc2l6ZSA/
|
|
35
|
-
const
|
|
37
|
+
}) => `${theme.space["0.25"]} 0`, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/MenuV2/MenuContent.tsx"],"names":[],"mappings":"AA0BsD","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/MenuV2/MenuContent.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport type { ButtonHTMLAttributes, MouseEvent, ReactNode, Ref } from 'react'\nimport {\n  cloneElement,\n  forwardRef,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useId,\n  useImperativeHandle,\n  useMemo,\n  useRef,\n  useState,\n} from 'react'\nimport { Popup } from '../Popup'\nimport { SearchInput } from '../SearchInput'\nimport { Stack } from '../Stack'\nimport { useMenu } from './MenuProvider'\nimport { SIZES } from './constants'\nimport { searchChildren } from './helpers'\nimport type { MenuProps } from './types'\n\nconst StyledPopup = styled(Popup, {\n  shouldForwardProp: prop => !['size', 'searchable'].includes(prop),\n})<{ size?: keyof typeof SIZES; searchable: boolean }>`\n  background-color: ${({ theme }) => theme.colors.other.elevation.background.raised};\n  box-shadow: ${({ theme }) => `${theme.shadows.raised[0]}, ${theme.shadows.raised[1]}`};\n  padding: 0;\n\n  &[data-has-arrow='true'] {\n    &::after {\n      border-color: ${({ theme }) => theme.colors.other.elevation.background.raised}\n        transparent transparent transparent;\n    }\n  }\n\n  min-width: ${SIZES.small};\n  max-width: ${SIZES.large};\n  ${({ size }) => (size ? `width: ${SIZES[size]};` : null)}\n  ${({ searchable }) => (searchable ? `min-width: 20rem` : null)};\n  padding: ${({ theme }) => `${theme.space['0.25']} 0`};\n`\n\nconst Content = styled(Stack)`\noverflow: auto;\n`\n\nconst Footer = styled(Stack)`\n  padding: ${({ theme }) => theme.space['1']};\n`\n\nconst MenuList = styled(Stack, {\n  shouldForwardProp: prop => !['height'].includes(prop),\n})<{ height: string }>`\n  overflow-y: auto;\n  overflow-x: hidden;\n  max-height: calc(${({ height }) => height} - ${({ theme }) => theme.space['0.5']});\n  &:after,\n  &:before {\n    border: solid transparent;\n    border-width: 9px;\n    content: ' ';\n    height: 0;\n    width: 0;\n    position: absolute;\n    pointer-events: none;\n  }\n\n  &:after {\n    border-color: transparent;\n  }\n  &:before {\n    border-color: transparent;\n  }\n  background-color: ${({ theme }) =>\n    theme.colors.other.elevation.background.raised};\n  color: ${({ theme }) => theme.colors.neutral.text};\n  border-radius: ${({ theme }) => theme.radii.default};\n  position: relative;\n`\n\nconst StyledSearchInput = styled(SearchInput)`\n  padding: ${({ theme }) => theme.space['1']};\n`\n\nexport const Menu = forwardRef(\n  (\n    {\n      id,\n      ariaLabel = 'Menu',\n      children,\n      disclosure,\n      hasArrow = false,\n      placement = 'bottom',\n      className,\n      'data-testid': dataTestId,\n      maxHeight,\n      maxWidth,\n      portalTarget = document.body,\n      size,\n      triggerMethod = 'click',\n      dynamicDomRendering,\n      align,\n      searchable = false,\n      footer,\n    }: MenuProps,\n    ref: Ref<HTMLButtonElement | null>,\n  ) => {\n    const { isVisible, setIsVisible } = useMenu()\n    const searchInputRef = useRef<HTMLInputElement>(null)\n    const [localChild, setLocalChild] = useState<ReactNode[] | null>(null)\n    const popupRef = useRef<HTMLDivElement>(null)\n    const disclosureRef = useRef<HTMLButtonElement>(null)\n    const tempId = useId()\n    const finalId = `menu-${id ?? tempId}`\n\n    // if you need dialog inside your component, use function, otherwise component is fine\n    const target = isValidElement<ButtonHTMLAttributes<HTMLButtonElement>>(\n      disclosure,\n    )\n      ? disclosure\n      : disclosure({ visible: isVisible })\n    const innerRef = useRef(target as unknown as HTMLButtonElement)\n    useImperativeHandle(ref, () => innerRef.current)\n\n    const finalDisclosure = cloneElement(target, {\n      onClick: (event: MouseEvent<HTMLButtonElement>) => {\n        target.props.onClick?.(event)\n        setIsVisible(!isVisible)\n      },\n      'aria-haspopup': 'dialog',\n      'aria-expanded': isVisible,\n      // @ts-expect-error not sure how to fix this\n      ref: disclosureRef,\n    })\n\n    const onSearch = useCallback(\n      (value: string) => {\n        if (typeof children === 'object') {\n          setLocalChild(searchChildren(children, value))\n        }\n      },\n      [children],\n    )\n\n    useEffect(() => {\n      if (isVisible && searchable) {\n        setTimeout(() => {\n          searchInputRef.current?.focus()\n        }, 50)\n      }\n    }, [isVisible, searchable])\n\n    const finalChild = useMemo(() => {\n      if (typeof children === 'function') {\n        return children({ toggle: () => setIsVisible(!isVisible) })\n      }\n\n      if (searchable && localChild) {\n        return localChild\n      }\n\n      return children\n    }, [children, isVisible, localChild, searchable, setIsVisible])\n\n    return (\n      <StyledPopup\n        debounceDelay={triggerMethod === 'hover' ? 250 : 0}\n        hideOnClickOutside\n        aria-label={ariaLabel}\n        className={className}\n        visible={triggerMethod === 'click' ? isVisible : undefined}\n        placement={placement}\n        hasArrow={hasArrow}\n        data-has-arrow={hasArrow}\n        role=\"dialog\"\n        id={finalId}\n        ref={popupRef}\n        onClose={() => {\n          setIsVisible(false)\n          setLocalChild(null)\n        }}\n        tabIndex={-1}\n        maxHeight={maxHeight ?? '30rem'}\n        maxWidth={maxWidth}\n        searchable={searchable}\n        size={size}\n        text={\n          <MenuList\n            data-testid={dataTestId}\n            className={className}\n            role=\"menu\"\n            height={maxHeight ?? '30rem'}\n          >\n            <Content>\n              {searchable && typeof children !== 'function' ? (\n                <StyledSearchInput\n                  size=\"small\"\n                  onSearch={onSearch}\n                  ref={searchInputRef}\n                />\n              ) : null}\n              {finalChild}\n            </Content>\n            {footer ? <Footer>{footer}</Footer> : null}\n          </MenuList>\n        }\n        portalTarget={portalTarget}\n        dynamicDomRendering={dynamicDomRendering}\n        align={align}\n      >\n        {finalDisclosure}\n      </StyledPopup>\n    )\n  },\n)\n"]} */"));
|
|
38
|
+
const Content = /* @__PURE__ */ _styled__default.default(index$1.Stack, process.env.NODE_ENV === "production" ? {
|
|
39
|
+
target: "e1rdim8w3"
|
|
40
|
+
} : {
|
|
41
|
+
target: "e1rdim8w3",
|
|
42
|
+
label: "Content"
|
|
43
|
+
})(process.env.NODE_ENV === "production" ? {
|
|
44
|
+
name: "1qmr6ab",
|
|
45
|
+
styles: "overflow:auto"
|
|
46
|
+
} : {
|
|
47
|
+
name: "1qmr6ab",
|
|
48
|
+
styles: "overflow:auto/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/MenuV2/MenuContent.tsx"],"names":[],"mappings":"AA6C6B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/MenuV2/MenuContent.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport type { ButtonHTMLAttributes, MouseEvent, ReactNode, Ref } from 'react'\nimport {\n  cloneElement,\n  forwardRef,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useId,\n  useImperativeHandle,\n  useMemo,\n  useRef,\n  useState,\n} from 'react'\nimport { Popup } from '../Popup'\nimport { SearchInput } from '../SearchInput'\nimport { Stack } from '../Stack'\nimport { useMenu } from './MenuProvider'\nimport { SIZES } from './constants'\nimport { searchChildren } from './helpers'\nimport type { MenuProps } from './types'\n\nconst StyledPopup = styled(Popup, {\n  shouldForwardProp: prop => !['size', 'searchable'].includes(prop),\n})<{ size?: keyof typeof SIZES; searchable: boolean }>`\n  background-color: ${({ theme }) => theme.colors.other.elevation.background.raised};\n  box-shadow: ${({ theme }) => `${theme.shadows.raised[0]}, ${theme.shadows.raised[1]}`};\n  padding: 0;\n\n  &[data-has-arrow='true'] {\n    &::after {\n      border-color: ${({ theme }) => theme.colors.other.elevation.background.raised}\n        transparent transparent transparent;\n    }\n  }\n\n  min-width: ${SIZES.small};\n  max-width: ${SIZES.large};\n  ${({ size }) => (size ? `width: ${SIZES[size]};` : null)}\n  ${({ searchable }) => (searchable ? `min-width: 20rem` : null)};\n  padding: ${({ theme }) => `${theme.space['0.25']} 0`};\n`\n\nconst Content = styled(Stack)`\noverflow: auto;\n`\n\nconst Footer = styled(Stack)`\n  padding: ${({ theme }) => theme.space['1']};\n`\n\nconst MenuList = styled(Stack, {\n  shouldForwardProp: prop => !['height'].includes(prop),\n})<{ height: string }>`\n  overflow-y: auto;\n  overflow-x: hidden;\n  max-height: calc(${({ height }) => height} - ${({ theme }) => theme.space['0.5']});\n  &:after,\n  &:before {\n    border: solid transparent;\n    border-width: 9px;\n    content: ' ';\n    height: 0;\n    width: 0;\n    position: absolute;\n    pointer-events: none;\n  }\n\n  &:after {\n    border-color: transparent;\n  }\n  &:before {\n    border-color: transparent;\n  }\n  background-color: ${({ theme }) =>\n    theme.colors.other.elevation.background.raised};\n  color: ${({ theme }) => theme.colors.neutral.text};\n  border-radius: ${({ theme }) => theme.radii.default};\n  position: relative;\n`\n\nconst StyledSearchInput = styled(SearchInput)`\n  padding: ${({ theme }) => theme.space['1']};\n`\n\nexport const Menu = forwardRef(\n  (\n    {\n      id,\n      ariaLabel = 'Menu',\n      children,\n      disclosure,\n      hasArrow = false,\n      placement = 'bottom',\n      className,\n      'data-testid': dataTestId,\n      maxHeight,\n      maxWidth,\n      portalTarget = document.body,\n      size,\n      triggerMethod = 'click',\n      dynamicDomRendering,\n      align,\n      searchable = false,\n      footer,\n    }: MenuProps,\n    ref: Ref<HTMLButtonElement | null>,\n  ) => {\n    const { isVisible, setIsVisible } = useMenu()\n    const searchInputRef = useRef<HTMLInputElement>(null)\n    const [localChild, setLocalChild] = useState<ReactNode[] | null>(null)\n    const popupRef = useRef<HTMLDivElement>(null)\n    const disclosureRef = useRef<HTMLButtonElement>(null)\n    const tempId = useId()\n    const finalId = `menu-${id ?? tempId}`\n\n    // if you need dialog inside your component, use function, otherwise component is fine\n    const target = isValidElement<ButtonHTMLAttributes<HTMLButtonElement>>(\n      disclosure,\n    )\n      ? disclosure\n      : disclosure({ visible: isVisible })\n    const innerRef = useRef(target as unknown as HTMLButtonElement)\n    useImperativeHandle(ref, () => innerRef.current)\n\n    const finalDisclosure = cloneElement(target, {\n      onClick: (event: MouseEvent<HTMLButtonElement>) => {\n        target.props.onClick?.(event)\n        setIsVisible(!isVisible)\n      },\n      'aria-haspopup': 'dialog',\n      'aria-expanded': isVisible,\n      // @ts-expect-error not sure how to fix this\n      ref: disclosureRef,\n    })\n\n    const onSearch = useCallback(\n      (value: string) => {\n        if (typeof children === 'object') {\n          setLocalChild(searchChildren(children, value))\n        }\n      },\n      [children],\n    )\n\n    useEffect(() => {\n      if (isVisible && searchable) {\n        setTimeout(() => {\n          searchInputRef.current?.focus()\n        }, 50)\n      }\n    }, [isVisible, searchable])\n\n    const finalChild = useMemo(() => {\n      if (typeof children === 'function') {\n        return children({ toggle: () => setIsVisible(!isVisible) })\n      }\n\n      if (searchable && localChild) {\n        return localChild\n      }\n\n      return children\n    }, [children, isVisible, localChild, searchable, setIsVisible])\n\n    return (\n      <StyledPopup\n        debounceDelay={triggerMethod === 'hover' ? 250 : 0}\n        hideOnClickOutside\n        aria-label={ariaLabel}\n        className={className}\n        visible={triggerMethod === 'click' ? isVisible : undefined}\n        placement={placement}\n        hasArrow={hasArrow}\n        data-has-arrow={hasArrow}\n        role=\"dialog\"\n        id={finalId}\n        ref={popupRef}\n        onClose={() => {\n          setIsVisible(false)\n          setLocalChild(null)\n        }}\n        tabIndex={-1}\n        maxHeight={maxHeight ?? '30rem'}\n        maxWidth={maxWidth}\n        searchable={searchable}\n        size={size}\n        text={\n          <MenuList\n            data-testid={dataTestId}\n            className={className}\n            role=\"menu\"\n            height={maxHeight ?? '30rem'}\n          >\n            <Content>\n              {searchable && typeof children !== 'function' ? (\n                <StyledSearchInput\n                  size=\"small\"\n                  onSearch={onSearch}\n                  ref={searchInputRef}\n                />\n              ) : null}\n              {finalChild}\n            </Content>\n            {footer ? <Footer>{footer}</Footer> : null}\n          </MenuList>\n        }\n        portalTarget={portalTarget}\n        dynamicDomRendering={dynamicDomRendering}\n        align={align}\n      >\n        {finalDisclosure}\n      </StyledPopup>\n    )\n  },\n)\n"]} */",
|
|
49
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
50
|
+
});
|
|
51
|
+
const Footer = /* @__PURE__ */ _styled__default.default(index$1.Stack, process.env.NODE_ENV === "production" ? {
|
|
52
|
+
target: "e1rdim8w2"
|
|
53
|
+
} : {
|
|
54
|
+
target: "e1rdim8w2",
|
|
55
|
+
label: "Footer"
|
|
56
|
+
})("padding:", ({
|
|
57
|
+
theme
|
|
58
|
+
}) => theme.space["1"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/MenuV2/MenuContent.tsx"],"names":[],"mappings":"AAiD4B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/MenuV2/MenuContent.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport type { ButtonHTMLAttributes, MouseEvent, ReactNode, Ref } from 'react'\nimport {\n  cloneElement,\n  forwardRef,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useId,\n  useImperativeHandle,\n  useMemo,\n  useRef,\n  useState,\n} from 'react'\nimport { Popup } from '../Popup'\nimport { SearchInput } from '../SearchInput'\nimport { Stack } from '../Stack'\nimport { useMenu } from './MenuProvider'\nimport { SIZES } from './constants'\nimport { searchChildren } from './helpers'\nimport type { MenuProps } from './types'\n\nconst StyledPopup = styled(Popup, {\n  shouldForwardProp: prop => !['size', 'searchable'].includes(prop),\n})<{ size?: keyof typeof SIZES; searchable: boolean }>`\n  background-color: ${({ theme }) => theme.colors.other.elevation.background.raised};\n  box-shadow: ${({ theme }) => `${theme.shadows.raised[0]}, ${theme.shadows.raised[1]}`};\n  padding: 0;\n\n  &[data-has-arrow='true'] {\n    &::after {\n      border-color: ${({ theme }) => theme.colors.other.elevation.background.raised}\n        transparent transparent transparent;\n    }\n  }\n\n  min-width: ${SIZES.small};\n  max-width: ${SIZES.large};\n  ${({ size }) => (size ? `width: ${SIZES[size]};` : null)}\n  ${({ searchable }) => (searchable ? `min-width: 20rem` : null)};\n  padding: ${({ theme }) => `${theme.space['0.25']} 0`};\n`\n\nconst Content = styled(Stack)`\noverflow: auto;\n`\n\nconst Footer = styled(Stack)`\n  padding: ${({ theme }) => theme.space['1']};\n`\n\nconst MenuList = styled(Stack, {\n  shouldForwardProp: prop => !['height'].includes(prop),\n})<{ height: string }>`\n  overflow-y: auto;\n  overflow-x: hidden;\n  max-height: calc(${({ height }) => height} - ${({ theme }) => theme.space['0.5']});\n  &:after,\n  &:before {\n    border: solid transparent;\n    border-width: 9px;\n    content: ' ';\n    height: 0;\n    width: 0;\n    position: absolute;\n    pointer-events: none;\n  }\n\n  &:after {\n    border-color: transparent;\n  }\n  &:before {\n    border-color: transparent;\n  }\n  background-color: ${({ theme }) =>\n    theme.colors.other.elevation.background.raised};\n  color: ${({ theme }) => theme.colors.neutral.text};\n  border-radius: ${({ theme }) => theme.radii.default};\n  position: relative;\n`\n\nconst StyledSearchInput = styled(SearchInput)`\n  padding: ${({ theme }) => theme.space['1']};\n`\n\nexport const Menu = forwardRef(\n  (\n    {\n      id,\n      ariaLabel = 'Menu',\n      children,\n      disclosure,\n      hasArrow = false,\n      placement = 'bottom',\n      className,\n      'data-testid': dataTestId,\n      maxHeight,\n      maxWidth,\n      portalTarget = document.body,\n      size,\n      triggerMethod = 'click',\n      dynamicDomRendering,\n      align,\n      searchable = false,\n      footer,\n    }: MenuProps,\n    ref: Ref<HTMLButtonElement | null>,\n  ) => {\n    const { isVisible, setIsVisible } = useMenu()\n    const searchInputRef = useRef<HTMLInputElement>(null)\n    const [localChild, setLocalChild] = useState<ReactNode[] | null>(null)\n    const popupRef = useRef<HTMLDivElement>(null)\n    const disclosureRef = useRef<HTMLButtonElement>(null)\n    const tempId = useId()\n    const finalId = `menu-${id ?? tempId}`\n\n    // if you need dialog inside your component, use function, otherwise component is fine\n    const target = isValidElement<ButtonHTMLAttributes<HTMLButtonElement>>(\n      disclosure,\n    )\n      ? disclosure\n      : disclosure({ visible: isVisible })\n    const innerRef = useRef(target as unknown as HTMLButtonElement)\n    useImperativeHandle(ref, () => innerRef.current)\n\n    const finalDisclosure = cloneElement(target, {\n      onClick: (event: MouseEvent<HTMLButtonElement>) => {\n        target.props.onClick?.(event)\n        setIsVisible(!isVisible)\n      },\n      'aria-haspopup': 'dialog',\n      'aria-expanded': isVisible,\n      // @ts-expect-error not sure how to fix this\n      ref: disclosureRef,\n    })\n\n    const onSearch = useCallback(\n      (value: string) => {\n        if (typeof children === 'object') {\n          setLocalChild(searchChildren(children, value))\n        }\n      },\n      [children],\n    )\n\n    useEffect(() => {\n      if (isVisible && searchable) {\n        setTimeout(() => {\n          searchInputRef.current?.focus()\n        }, 50)\n      }\n    }, [isVisible, searchable])\n\n    const finalChild = useMemo(() => {\n      if (typeof children === 'function') {\n        return children({ toggle: () => setIsVisible(!isVisible) })\n      }\n\n      if (searchable && localChild) {\n        return localChild\n      }\n\n      return children\n    }, [children, isVisible, localChild, searchable, setIsVisible])\n\n    return (\n      <StyledPopup\n        debounceDelay={triggerMethod === 'hover' ? 250 : 0}\n        hideOnClickOutside\n        aria-label={ariaLabel}\n        className={className}\n        visible={triggerMethod === 'click' ? isVisible : undefined}\n        placement={placement}\n        hasArrow={hasArrow}\n        data-has-arrow={hasArrow}\n        role=\"dialog\"\n        id={finalId}\n        ref={popupRef}\n        onClose={() => {\n          setIsVisible(false)\n          setLocalChild(null)\n        }}\n        tabIndex={-1}\n        maxHeight={maxHeight ?? '30rem'}\n        maxWidth={maxWidth}\n        searchable={searchable}\n        size={size}\n        text={\n          <MenuList\n            data-testid={dataTestId}\n            className={className}\n            role=\"menu\"\n            height={maxHeight ?? '30rem'}\n          >\n            <Content>\n              {searchable && typeof children !== 'function' ? (\n                <StyledSearchInput\n                  size=\"small\"\n                  onSearch={onSearch}\n                  ref={searchInputRef}\n                />\n              ) : null}\n              {finalChild}\n            </Content>\n            {footer ? <Footer>{footer}</Footer> : null}\n          </MenuList>\n        }\n        portalTarget={portalTarget}\n        dynamicDomRendering={dynamicDomRendering}\n        align={align}\n      >\n        {finalDisclosure}\n      </StyledPopup>\n    )\n  },\n)\n"]} */"));
|
|
59
|
+
const MenuList = /* @__PURE__ */ _styled__default.default(index$1.Stack, process.env.NODE_ENV === "production" ? {
|
|
60
|
+
shouldForwardProp: (prop) => !["height"].includes(prop),
|
|
36
61
|
target: "e1rdim8w1"
|
|
37
62
|
} : {
|
|
63
|
+
shouldForwardProp: (prop) => !["height"].includes(prop),
|
|
38
64
|
target: "e1rdim8w1",
|
|
39
65
|
label: "MenuList"
|
|
40
|
-
})("overflow-y:auto;overflow-x:hidden
|
|
66
|
+
})("overflow-y:auto;overflow-x:hidden;max-height:calc(", ({
|
|
67
|
+
height
|
|
68
|
+
}) => height, " - ", ({
|
|
69
|
+
theme
|
|
70
|
+
}) => theme.space["0.5"], ");&:after,&:before{border:solid transparent;border-width:9px;content:' ';height:0;width:0;position:absolute;pointer-events:none;}&:after{border-color:transparent;}&:before{border-color:transparent;}background-color:", ({
|
|
41
71
|
theme
|
|
42
72
|
}) => theme.colors.other.elevation.background.raised, ";color:", ({
|
|
43
73
|
theme
|
|
44
74
|
}) => theme.colors.neutral.text, ";border-radius:", ({
|
|
45
75
|
theme
|
|
46
|
-
}) => theme.radii.default, ";position:relative;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
47
|
-
const StyledSearchInput = /* @__PURE__ */ _styled__default.default(index$
|
|
76
|
+
}) => theme.radii.default, ";position:relative;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/MenuV2/MenuContent.tsx"],"names":[],"mappings":"AAuDsB","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/MenuV2/MenuContent.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport type { ButtonHTMLAttributes, MouseEvent, ReactNode, Ref } from 'react'\nimport {\n  cloneElement,\n  forwardRef,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useId,\n  useImperativeHandle,\n  useMemo,\n  useRef,\n  useState,\n} from 'react'\nimport { Popup } from '../Popup'\nimport { SearchInput } from '../SearchInput'\nimport { Stack } from '../Stack'\nimport { useMenu } from './MenuProvider'\nimport { SIZES } from './constants'\nimport { searchChildren } from './helpers'\nimport type { MenuProps } from './types'\n\nconst StyledPopup = styled(Popup, {\n  shouldForwardProp: prop => !['size', 'searchable'].includes(prop),\n})<{ size?: keyof typeof SIZES; searchable: boolean }>`\n  background-color: ${({ theme }) => theme.colors.other.elevation.background.raised};\n  box-shadow: ${({ theme }) => `${theme.shadows.raised[0]}, ${theme.shadows.raised[1]}`};\n  padding: 0;\n\n  &[data-has-arrow='true'] {\n    &::after {\n      border-color: ${({ theme }) => theme.colors.other.elevation.background.raised}\n        transparent transparent transparent;\n    }\n  }\n\n  min-width: ${SIZES.small};\n  max-width: ${SIZES.large};\n  ${({ size }) => (size ? `width: ${SIZES[size]};` : null)}\n  ${({ searchable }) => (searchable ? `min-width: 20rem` : null)};\n  padding: ${({ theme }) => `${theme.space['0.25']} 0`};\n`\n\nconst Content = styled(Stack)`\noverflow: auto;\n`\n\nconst Footer = styled(Stack)`\n  padding: ${({ theme }) => theme.space['1']};\n`\n\nconst MenuList = styled(Stack, {\n  shouldForwardProp: prop => !['height'].includes(prop),\n})<{ height: string }>`\n  overflow-y: auto;\n  overflow-x: hidden;\n  max-height: calc(${({ height }) => height} - ${({ theme }) => theme.space['0.5']});\n  &:after,\n  &:before {\n    border: solid transparent;\n    border-width: 9px;\n    content: ' ';\n    height: 0;\n    width: 0;\n    position: absolute;\n    pointer-events: none;\n  }\n\n  &:after {\n    border-color: transparent;\n  }\n  &:before {\n    border-color: transparent;\n  }\n  background-color: ${({ theme }) =>\n    theme.colors.other.elevation.background.raised};\n  color: ${({ theme }) => theme.colors.neutral.text};\n  border-radius: ${({ theme }) => theme.radii.default};\n  position: relative;\n`\n\nconst StyledSearchInput = styled(SearchInput)`\n  padding: ${({ theme }) => theme.space['1']};\n`\n\nexport const Menu = forwardRef(\n  (\n    {\n      id,\n      ariaLabel = 'Menu',\n      children,\n      disclosure,\n      hasArrow = false,\n      placement = 'bottom',\n      className,\n      'data-testid': dataTestId,\n      maxHeight,\n      maxWidth,\n      portalTarget = document.body,\n      size,\n      triggerMethod = 'click',\n      dynamicDomRendering,\n      align,\n      searchable = false,\n      footer,\n    }: MenuProps,\n    ref: Ref<HTMLButtonElement | null>,\n  ) => {\n    const { isVisible, setIsVisible } = useMenu()\n    const searchInputRef = useRef<HTMLInputElement>(null)\n    const [localChild, setLocalChild] = useState<ReactNode[] | null>(null)\n    const popupRef = useRef<HTMLDivElement>(null)\n    const disclosureRef = useRef<HTMLButtonElement>(null)\n    const tempId = useId()\n    const finalId = `menu-${id ?? tempId}`\n\n    // if you need dialog inside your component, use function, otherwise component is fine\n    const target = isValidElement<ButtonHTMLAttributes<HTMLButtonElement>>(\n      disclosure,\n    )\n      ? disclosure\n      : disclosure({ visible: isVisible })\n    const innerRef = useRef(target as unknown as HTMLButtonElement)\n    useImperativeHandle(ref, () => innerRef.current)\n\n    const finalDisclosure = cloneElement(target, {\n      onClick: (event: MouseEvent<HTMLButtonElement>) => {\n        target.props.onClick?.(event)\n        setIsVisible(!isVisible)\n      },\n      'aria-haspopup': 'dialog',\n      'aria-expanded': isVisible,\n      // @ts-expect-error not sure how to fix this\n      ref: disclosureRef,\n    })\n\n    const onSearch = useCallback(\n      (value: string) => {\n        if (typeof children === 'object') {\n          setLocalChild(searchChildren(children, value))\n        }\n      },\n      [children],\n    )\n\n    useEffect(() => {\n      if (isVisible && searchable) {\n        setTimeout(() => {\n          searchInputRef.current?.focus()\n        }, 50)\n      }\n    }, [isVisible, searchable])\n\n    const finalChild = useMemo(() => {\n      if (typeof children === 'function') {\n        return children({ toggle: () => setIsVisible(!isVisible) })\n      }\n\n      if (searchable && localChild) {\n        return localChild\n      }\n\n      return children\n    }, [children, isVisible, localChild, searchable, setIsVisible])\n\n    return (\n      <StyledPopup\n        debounceDelay={triggerMethod === 'hover' ? 250 : 0}\n        hideOnClickOutside\n        aria-label={ariaLabel}\n        className={className}\n        visible={triggerMethod === 'click' ? isVisible : undefined}\n        placement={placement}\n        hasArrow={hasArrow}\n        data-has-arrow={hasArrow}\n        role=\"dialog\"\n        id={finalId}\n        ref={popupRef}\n        onClose={() => {\n          setIsVisible(false)\n          setLocalChild(null)\n        }}\n        tabIndex={-1}\n        maxHeight={maxHeight ?? '30rem'}\n        maxWidth={maxWidth}\n        searchable={searchable}\n        size={size}\n        text={\n          <MenuList\n            data-testid={dataTestId}\n            className={className}\n            role=\"menu\"\n            height={maxHeight ?? '30rem'}\n          >\n            <Content>\n              {searchable && typeof children !== 'function' ? (\n                <StyledSearchInput\n                  size=\"small\"\n                  onSearch={onSearch}\n                  ref={searchInputRef}\n                />\n              ) : null}\n              {finalChild}\n            </Content>\n            {footer ? <Footer>{footer}</Footer> : null}\n          </MenuList>\n        }\n        portalTarget={portalTarget}\n        dynamicDomRendering={dynamicDomRendering}\n        align={align}\n      >\n        {finalDisclosure}\n      </StyledPopup>\n    )\n  },\n)\n"]} */"));
|
|
77
|
+
const StyledSearchInput = /* @__PURE__ */ _styled__default.default(index$2.SearchInput, process.env.NODE_ENV === "production" ? {
|
|
48
78
|
target: "e1rdim8w0"
|
|
49
79
|
} : {
|
|
50
80
|
target: "e1rdim8w0",
|
|
51
81
|
label: "StyledSearchInput"
|
|
52
82
|
})("padding:", ({
|
|
53
83
|
theme
|
|
54
|
-
}) => theme.space["1"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
84
|
+
}) => theme.space["1"], ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/MenuV2/MenuContent.tsx"],"names":[],"mappings":"AAmF6C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/MenuV2/MenuContent.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport type { ButtonHTMLAttributes, MouseEvent, ReactNode, Ref } from 'react'\nimport {\n  cloneElement,\n  forwardRef,\n  isValidElement,\n  useCallback,\n  useEffect,\n  useId,\n  useImperativeHandle,\n  useMemo,\n  useRef,\n  useState,\n} from 'react'\nimport { Popup } from '../Popup'\nimport { SearchInput } from '../SearchInput'\nimport { Stack } from '../Stack'\nimport { useMenu } from './MenuProvider'\nimport { SIZES } from './constants'\nimport { searchChildren } from './helpers'\nimport type { MenuProps } from './types'\n\nconst StyledPopup = styled(Popup, {\n  shouldForwardProp: prop => !['size', 'searchable'].includes(prop),\n})<{ size?: keyof typeof SIZES; searchable: boolean }>`\n  background-color: ${({ theme }) => theme.colors.other.elevation.background.raised};\n  box-shadow: ${({ theme }) => `${theme.shadows.raised[0]}, ${theme.shadows.raised[1]}`};\n  padding: 0;\n\n  &[data-has-arrow='true'] {\n    &::after {\n      border-color: ${({ theme }) => theme.colors.other.elevation.background.raised}\n        transparent transparent transparent;\n    }\n  }\n\n  min-width: ${SIZES.small};\n  max-width: ${SIZES.large};\n  ${({ size }) => (size ? `width: ${SIZES[size]};` : null)}\n  ${({ searchable }) => (searchable ? `min-width: 20rem` : null)};\n  padding: ${({ theme }) => `${theme.space['0.25']} 0`};\n`\n\nconst Content = styled(Stack)`\noverflow: auto;\n`\n\nconst Footer = styled(Stack)`\n  padding: ${({ theme }) => theme.space['1']};\n`\n\nconst MenuList = styled(Stack, {\n  shouldForwardProp: prop => !['height'].includes(prop),\n})<{ height: string }>`\n  overflow-y: auto;\n  overflow-x: hidden;\n  max-height: calc(${({ height }) => height} - ${({ theme }) => theme.space['0.5']});\n  &:after,\n  &:before {\n    border: solid transparent;\n    border-width: 9px;\n    content: ' ';\n    height: 0;\n    width: 0;\n    position: absolute;\n    pointer-events: none;\n  }\n\n  &:after {\n    border-color: transparent;\n  }\n  &:before {\n    border-color: transparent;\n  }\n  background-color: ${({ theme }) =>\n    theme.colors.other.elevation.background.raised};\n  color: ${({ theme }) => theme.colors.neutral.text};\n  border-radius: ${({ theme }) => theme.radii.default};\n  position: relative;\n`\n\nconst StyledSearchInput = styled(SearchInput)`\n  padding: ${({ theme }) => theme.space['1']};\n`\n\nexport const Menu = forwardRef(\n  (\n    {\n      id,\n      ariaLabel = 'Menu',\n      children,\n      disclosure,\n      hasArrow = false,\n      placement = 'bottom',\n      className,\n      'data-testid': dataTestId,\n      maxHeight,\n      maxWidth,\n      portalTarget = document.body,\n      size,\n      triggerMethod = 'click',\n      dynamicDomRendering,\n      align,\n      searchable = false,\n      footer,\n    }: MenuProps,\n    ref: Ref<HTMLButtonElement | null>,\n  ) => {\n    const { isVisible, setIsVisible } = useMenu()\n    const searchInputRef = useRef<HTMLInputElement>(null)\n    const [localChild, setLocalChild] = useState<ReactNode[] | null>(null)\n    const popupRef = useRef<HTMLDivElement>(null)\n    const disclosureRef = useRef<HTMLButtonElement>(null)\n    const tempId = useId()\n    const finalId = `menu-${id ?? tempId}`\n\n    // if you need dialog inside your component, use function, otherwise component is fine\n    const target = isValidElement<ButtonHTMLAttributes<HTMLButtonElement>>(\n      disclosure,\n    )\n      ? disclosure\n      : disclosure({ visible: isVisible })\n    const innerRef = useRef(target as unknown as HTMLButtonElement)\n    useImperativeHandle(ref, () => innerRef.current)\n\n    const finalDisclosure = cloneElement(target, {\n      onClick: (event: MouseEvent<HTMLButtonElement>) => {\n        target.props.onClick?.(event)\n        setIsVisible(!isVisible)\n      },\n      'aria-haspopup': 'dialog',\n      'aria-expanded': isVisible,\n      // @ts-expect-error not sure how to fix this\n      ref: disclosureRef,\n    })\n\n    const onSearch = useCallback(\n      (value: string) => {\n        if (typeof children === 'object') {\n          setLocalChild(searchChildren(children, value))\n        }\n      },\n      [children],\n    )\n\n    useEffect(() => {\n      if (isVisible && searchable) {\n        setTimeout(() => {\n          searchInputRef.current?.focus()\n        }, 50)\n      }\n    }, [isVisible, searchable])\n\n    const finalChild = useMemo(() => {\n      if (typeof children === 'function') {\n        return children({ toggle: () => setIsVisible(!isVisible) })\n      }\n\n      if (searchable && localChild) {\n        return localChild\n      }\n\n      return children\n    }, [children, isVisible, localChild, searchable, setIsVisible])\n\n    return (\n      <StyledPopup\n        debounceDelay={triggerMethod === 'hover' ? 250 : 0}\n        hideOnClickOutside\n        aria-label={ariaLabel}\n        className={className}\n        visible={triggerMethod === 'click' ? isVisible : undefined}\n        placement={placement}\n        hasArrow={hasArrow}\n        data-has-arrow={hasArrow}\n        role=\"dialog\"\n        id={finalId}\n        ref={popupRef}\n        onClose={() => {\n          setIsVisible(false)\n          setLocalChild(null)\n        }}\n        tabIndex={-1}\n        maxHeight={maxHeight ?? '30rem'}\n        maxWidth={maxWidth}\n        searchable={searchable}\n        size={size}\n        text={\n          <MenuList\n            data-testid={dataTestId}\n            className={className}\n            role=\"menu\"\n            height={maxHeight ?? '30rem'}\n          >\n            <Content>\n              {searchable && typeof children !== 'function' ? (\n                <StyledSearchInput\n                  size=\"small\"\n                  onSearch={onSearch}\n                  ref={searchInputRef}\n                />\n              ) : null}\n              {finalChild}\n            </Content>\n            {footer ? <Footer>{footer}</Footer> : null}\n          </MenuList>\n        }\n        portalTarget={portalTarget}\n        dynamicDomRendering={dynamicDomRendering}\n        align={align}\n      >\n        {finalDisclosure}\n      </StyledPopup>\n    )\n  },\n)\n"]} */"));
|
|
55
85
|
const Menu = React.forwardRef(({
|
|
56
86
|
id,
|
|
57
87
|
ariaLabel = "Menu",
|
|
@@ -68,7 +98,8 @@ const Menu = React.forwardRef(({
|
|
|
68
98
|
triggerMethod = "click",
|
|
69
99
|
dynamicDomRendering,
|
|
70
100
|
align,
|
|
71
|
-
searchable = false
|
|
101
|
+
searchable = false,
|
|
102
|
+
footer
|
|
72
103
|
}, ref) => {
|
|
73
104
|
const {
|
|
74
105
|
isVisible,
|
|
@@ -121,9 +152,12 @@ const Menu = React.forwardRef(({
|
|
|
121
152
|
return /* @__PURE__ */ jsxRuntime.jsx(StyledPopup, { debounceDelay: triggerMethod === "hover" ? 250 : 0, hideOnClickOutside: true, "aria-label": ariaLabel, className, visible: triggerMethod === "click" ? isVisible : void 0, placement, hasArrow, "data-has-arrow": hasArrow, role: "dialog", id: finalId, ref: popupRef, onClose: () => {
|
|
122
153
|
setIsVisible(false);
|
|
123
154
|
setLocalChild(null);
|
|
124
|
-
}, tabIndex: -1, maxHeight: maxHeight ?? "30rem", maxWidth, searchable, size, text: /* @__PURE__ */ jsxRuntime.jsxs("
|
|
125
|
-
|
|
126
|
-
|
|
155
|
+
}, tabIndex: -1, maxHeight: maxHeight ?? "30rem", maxWidth, searchable, size, text: /* @__PURE__ */ jsxRuntime.jsxs(MenuList, { "data-testid": dataTestId, className, role: "menu", height: maxHeight ?? "30rem", children: [
|
|
156
|
+
/* @__PURE__ */ jsxRuntime.jsxs(Content, { children: [
|
|
157
|
+
searchable && typeof children !== "function" ? /* @__PURE__ */ jsxRuntime.jsx(StyledSearchInput, { size: "small", onSearch, ref: searchInputRef }) : null,
|
|
158
|
+
finalChild
|
|
159
|
+
] }),
|
|
160
|
+
footer ? /* @__PURE__ */ jsxRuntime.jsx(Footer, { children: footer }) : null
|
|
127
161
|
] }), portalTarget, dynamicDomRendering, align, children: finalDisclosure });
|
|
128
162
|
});
|
|
129
163
|
exports.Menu = Menu;
|