@ultraviolet/ui 1.95.5 → 1.95.7

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.
@@ -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: "enye6lh0"
12
+ target: "enye6lh1"
12
13
  } : {
13
- target: "enye6lh0",
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0FjdGlvbkJhci9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBTzhDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0FjdGlvbkJhci9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgY3JlYXRlUG9ydGFsIH0gZnJvbSAncmVhY3QtZG9tJ1xuaW1wb3J0IHsgZmFkZUluIH0gZnJvbSAnLi4vLi4vdXRpbHMnXG5cbmNvbnN0IFN0eWxlZERpdiA9IHN0eWxlZC5kaXY8eyByYW5rOiBudW1iZXIgfT5gXG4gIGJhY2tncm91bmQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm90aGVyLmVsZXZhdGlvbi5iYWNrZ3JvdW5kLmZpeGVkfTtcbiAgYm9yZGVyLXJhZGl1czogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5yYWRpaS5kZWZhdWx0fTtcbiAgYm90dG9tOiAkeyh7IHJhbmssIHRoZW1lIH0pID0+IGBjYWxjKCR7dGhlbWUuc2l6aW5nWyc3MDAnXX0gKiAke3Jhbmt9ICsgJHt0aGVtZS5zcGFjZVsnMiddfSlgfTtcbiAgYm94LXNoYWRvdzogJHsoeyB0aGVtZSB9KSA9PiBgJHt0aGVtZS5zaGFkb3dzLmZpeGVkWzBdfSwgJHt0aGVtZS5zaGFkb3dzLmZpeGVkWzFdfWB9O1xuICBoZWlnaHQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc2l6aW5nWyc3MDAnXX07XG4gIGxlZnQ6IDUwJTtcbiAgcG9zaXRpb246IGZpeGVkO1xuICB0cmFuc2Zvcm06IHRyYW5zbGF0ZSgtNTAlLCAwKTtcbiAgd2lkdGg6IDM3LjVyZW07XG4gIGFuaW1hdGlvbjogJHtmYWRlSW59IDAuMnMgZWFzZS1pbi1vdXQ7XG5gXG5cbnR5cGUgQWN0aW9uQmFyUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgLyoqXG4gICAqIFRoZSBwb3NpdGlvbiBvZiB0aGUgYmFyIChzdGFydCBhdCAwKVxuICAgKi9cbiAgcmFuaz86IG51bWJlclxuICByb2xlPzogc3RyaW5nXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICAnZGF0YS10ZXN0aWQnPzogc3RyaW5nXG59XG5cbi8qKlxuICogVGhlIEFjdGlvbkJhciBpcyBhIGZsb2F0aW5nIGJhciB0aGF0IGFwcGVhcnMgYXQgdGhlIGJvdHRvbSBvZiBhIHBhZ2UuXG4gKiBJdCBjYW4gYmUgdXNlZCB0byBkaXNwbGF5IGltcG9ydGFudCBhY3Rpb25zIG9yIGluZm9ybWF0aW9uIHRvIHRoZSB1c2VyLCBhbmQgY2FuIGJlIGNvbmZpZ3VyZWQgdG8gZGlzcGxheSBhIHZhcmlldHkgb2YgZGlmZmVyZW50IGNvbnRlbnQgdHlwZXMuXG4gKlxuICogKipOb3RlOioqIEFjdGlvbkJhciBpcyBhZGRlZCBpbnRvIGEgcG9ydGFsIGF0IHRoZSBlbmQgb2YgdGhlIGJvZHkgZWxlbWVudC4gVGhpcyBtZWFucyB0aGF0IGl0IHdpbGwgYWx3YXlzIGJlIG9uIHRvcCBvZiBvdGhlciBlbGVtZW50cyB3aXRob3V0IGB6LWluZGV4YCxcbiAqIGFuZCB3aWxsIG5vdCBiZSBhZmZlY3RlZCBieSB0aGUgbGF5b3V0IG9mIHRoZSBwYWdlIGl0IGlzIG9uLlxuICovXG5leHBvcnQgY29uc3QgQWN0aW9uQmFyID0gKHtcbiAgY2hpbGRyZW4sXG4gIHJvbGUgPSAnZGlhbG9nJyxcbiAgcmFuayA9IDAsXG4gIGNsYXNzTmFtZSxcbiAgJ2RhdGEtdGVzdGlkJzogZGF0YVRlc3RJZCxcbn06IEFjdGlvbkJhclByb3BzKSA9PlxuICBjcmVhdGVQb3J0YWwoXG4gICAgPFN0eWxlZERpdlxuICAgICAgcmFuaz17cmFua31cbiAgICAgIHJvbGU9e3JvbGV9XG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfVxuICAgID5cbiAgICAgIHtjaGlsZHJlbn1cbiAgICA8L1N0eWxlZERpdj4sXG4gICAgZG9jdW1lbnQuYm9keSxcbiAgKVxuIl19 */"));
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: "enye6lh0"
8
+ target: "enye6lh1"
8
9
  } : {
9
- target: "enye6lh0",
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0FjdGlvbkJhci9pbmRleC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBTzhDIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL0FjdGlvbkJhci9pbmRleC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgdHlwZSB7IFJlYWN0Tm9kZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgY3JlYXRlUG9ydGFsIH0gZnJvbSAncmVhY3QtZG9tJ1xuaW1wb3J0IHsgZmFkZUluIH0gZnJvbSAnLi4vLi4vdXRpbHMnXG5cbmNvbnN0IFN0eWxlZERpdiA9IHN0eWxlZC5kaXY8eyByYW5rOiBudW1iZXIgfT5gXG4gIGJhY2tncm91bmQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuY29sb3JzLm90aGVyLmVsZXZhdGlvbi5iYWNrZ3JvdW5kLmZpeGVkfTtcbiAgYm9yZGVyLXJhZGl1czogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5yYWRpaS5kZWZhdWx0fTtcbiAgYm90dG9tOiAkeyh7IHJhbmssIHRoZW1lIH0pID0+IGBjYWxjKCR7dGhlbWUuc2l6aW5nWyc3MDAnXX0gKiAke3Jhbmt9ICsgJHt0aGVtZS5zcGFjZVsnMiddfSlgfTtcbiAgYm94LXNoYWRvdzogJHsoeyB0aGVtZSB9KSA9PiBgJHt0aGVtZS5zaGFkb3dzLmZpeGVkWzBdfSwgJHt0aGVtZS5zaGFkb3dzLmZpeGVkWzFdfWB9O1xuICBoZWlnaHQ6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc2l6aW5nWyc3MDAnXX07XG4gIGxlZnQ6IDUwJTtcbiAgcG9zaXRpb246IGZpeGVkO1xuICB0cmFuc2Zvcm06IHRyYW5zbGF0ZSgtNTAlLCAwKTtcbiAgd2lkdGg6IDM3LjVyZW07XG4gIGFuaW1hdGlvbjogJHtmYWRlSW59IDAuMnMgZWFzZS1pbi1vdXQ7XG5gXG5cbnR5cGUgQWN0aW9uQmFyUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgLyoqXG4gICAqIFRoZSBwb3NpdGlvbiBvZiB0aGUgYmFyIChzdGFydCBhdCAwKVxuICAgKi9cbiAgcmFuaz86IG51bWJlclxuICByb2xlPzogc3RyaW5nXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xuICAnZGF0YS10ZXN0aWQnPzogc3RyaW5nXG59XG5cbi8qKlxuICogVGhlIEFjdGlvbkJhciBpcyBhIGZsb2F0aW5nIGJhciB0aGF0IGFwcGVhcnMgYXQgdGhlIGJvdHRvbSBvZiBhIHBhZ2UuXG4gKiBJdCBjYW4gYmUgdXNlZCB0byBkaXNwbGF5IGltcG9ydGFudCBhY3Rpb25zIG9yIGluZm9ybWF0aW9uIHRvIHRoZSB1c2VyLCBhbmQgY2FuIGJlIGNvbmZpZ3VyZWQgdG8gZGlzcGxheSBhIHZhcmlldHkgb2YgZGlmZmVyZW50IGNvbnRlbnQgdHlwZXMuXG4gKlxuICogKipOb3RlOioqIEFjdGlvbkJhciBpcyBhZGRlZCBpbnRvIGEgcG9ydGFsIGF0IHRoZSBlbmQgb2YgdGhlIGJvZHkgZWxlbWVudC4gVGhpcyBtZWFucyB0aGF0IGl0IHdpbGwgYWx3YXlzIGJlIG9uIHRvcCBvZiBvdGhlciBlbGVtZW50cyB3aXRob3V0IGB6LWluZGV4YCxcbiAqIGFuZCB3aWxsIG5vdCBiZSBhZmZlY3RlZCBieSB0aGUgbGF5b3V0IG9mIHRoZSBwYWdlIGl0IGlzIG9uLlxuICovXG5leHBvcnQgY29uc3QgQWN0aW9uQmFyID0gKHtcbiAgY2hpbGRyZW4sXG4gIHJvbGUgPSAnZGlhbG9nJyxcbiAgcmFuayA9IDAsXG4gIGNsYXNzTmFtZSxcbiAgJ2RhdGEtdGVzdGlkJzogZGF0YVRlc3RJZCxcbn06IEFjdGlvbkJhclByb3BzKSA9PlxuICBjcmVhdGVQb3J0YWwoXG4gICAgPFN0eWxlZERpdlxuICAgICAgcmFuaz17cmFua31cbiAgICAgIHJvbGU9e3JvbGV9XG4gICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgIGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfVxuICAgID5cbiAgICAgIHtjaGlsZHJlbn1cbiAgICA8L1N0eWxlZERpdj4sXG4gICAgZG9jdW1lbnQuYm9keSxcbiAgKVxuIl19 */"));
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$1 = require("../SearchInput/index.cjs");
9
- const index$2 = require("../Stack/index.cjs");
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: "e1rdim8w2"
20
+ target: "e1rdim8w4"
18
21
  } : {
19
22
  shouldForwardProp: (prop) => !["size", "searchable"].includes(prop),
20
- target: "e1rdim8w2",
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,{"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 MenuList = styled(Stack)`\n  overflow-y: auto;\n  overflow-x: hidden;\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    }: 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          <div>\n            {searchable && typeof children !== 'function' ? (\n              <StyledSearchInput\n                size=\"small\"\n                onSearch={onSearch}\n                ref={searchInputRef}\n              />\n            ) : null}\n            <MenuList\n              data-testid={dataTestId}\n              className={className}\n              role=\"menu\"\n            >\n              {finalChild}\n            </MenuList>\n          </div>\n        }\n        portalTarget={portalTarget}\n        dynamicDomRendering={dynamicDomRendering}\n        align={align}\n      >\n        {finalDisclosure}\n      </StyledPopup>\n    )\n  },\n)\n"]} */"));
35
- const MenuList = /* @__PURE__ */ _styled__default.default(index$2.Stack, process.env.NODE_ENV === "production" ? {
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;&: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:", ({
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,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/MenuV2/MenuContent.tsx"],"names":[],"mappings":"AA6C8B","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 MenuList = styled(Stack)`\n  overflow-y: auto;\n  overflow-x: hidden;\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    }: 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          <div>\n            {searchable && typeof children !== 'function' ? (\n              <StyledSearchInput\n                size=\"small\"\n                onSearch={onSearch}\n                ref={searchInputRef}\n              />\n            ) : null}\n            <MenuList\n              data-testid={dataTestId}\n              className={className}\n              role=\"menu\"\n            >\n              {finalChild}\n            </MenuList>\n          </div>\n        }\n        portalTarget={portalTarget}\n        dynamicDomRendering={dynamicDomRendering}\n        align={align}\n      >\n        {finalDisclosure}\n      </StyledPopup>\n    )\n  },\n)\n"]} */"));
47
- const StyledSearchInput = /* @__PURE__ */ _styled__default.default(index$1.SearchInput, process.env.NODE_ENV === "production" ? {
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,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/MenuV2/MenuContent.tsx"],"names":[],"mappings":"AAwE6C","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 MenuList = styled(Stack)`\n  overflow-y: auto;\n  overflow-x: hidden;\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    }: 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          <div>\n            {searchable && typeof children !== 'function' ? (\n              <StyledSearchInput\n                size=\"small\"\n                onSearch={onSearch}\n                ref={searchInputRef}\n              />\n            ) : null}\n            <MenuList\n              data-testid={dataTestId}\n              className={className}\n              role=\"menu\"\n            >\n              {finalChild}\n            </MenuList>\n          </div>\n        }\n        portalTarget={portalTarget}\n        dynamicDomRendering={dynamicDomRendering}\n        align={align}\n      >\n        {finalDisclosure}\n      </StyledPopup>\n    )\n  },\n)\n"]} */"));
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("div", { children: [
125
- searchable && typeof children !== "function" ? /* @__PURE__ */ jsxRuntime.jsx(StyledSearchInput, { size: "small", onSearch, ref: searchInputRef }) : null,
126
- /* @__PURE__ */ jsxRuntime.jsx(MenuList, { "data-testid": dataTestId, className, role: "menu", children: finalChild })
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;
@@ -20,6 +20,7 @@ export declare const Menu: import("react").ForwardRefExoticComponent<{
20
20
  triggerMethod?: "click" | "hover";
21
21
  searchable?: boolean;
22
22
  hideOnClickItem?: boolean;
23
+ footer?: ReactNode;
23
24
  } & Pick<{
24
25
  id?: string;
25
26
  children: ReactNode | ((renderProps: {