@ultraviolet/ui 2.0.0-beta.10 → 2.0.0-beta.11

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.
Files changed (52) hide show
  1. package/dist/components/DateInput/index.cjs +2 -2
  2. package/dist/components/DateInput/index.js +2 -2
  3. package/dist/components/List/HeaderRow.cjs +2 -4
  4. package/dist/components/List/HeaderRow.js +2 -4
  5. package/dist/components/List/Row.cjs +32 -16
  6. package/dist/components/List/Row.js +32 -16
  7. package/dist/components/List/index.cjs +3 -3
  8. package/dist/components/List/index.js +3 -3
  9. package/dist/components/Menu/MenuContent.cjs +9 -8
  10. package/dist/components/Menu/MenuContent.d.ts +3 -1
  11. package/dist/components/Menu/MenuContent.js +10 -9
  12. package/dist/components/Menu/MenuProvider.cjs +9 -8
  13. package/dist/components/Menu/MenuProvider.d.ts +3 -0
  14. package/dist/components/Menu/MenuProvider.js +10 -9
  15. package/dist/components/Menu/components/Item.cjs +19 -7
  16. package/dist/components/Menu/components/Item.js +21 -9
  17. package/dist/components/Menu/helpers.cjs +3 -0
  18. package/dist/components/Menu/helpers.js +3 -0
  19. package/dist/components/Menu/index.d.ts +2 -1
  20. package/dist/components/Menu/types.d.ts +2 -1
  21. package/dist/components/Modal/components/Disclosure.cjs +5 -5
  22. package/dist/components/Modal/components/Disclosure.d.ts +1 -1
  23. package/dist/components/Modal/components/Disclosure.js +6 -6
  24. package/dist/components/Modal/index.cjs +4 -1
  25. package/dist/components/Modal/index.js +5 -2
  26. package/dist/components/Modal/types.d.ts +2 -1
  27. package/dist/components/NumberInput/index.cjs +23 -31
  28. package/dist/components/NumberInput/index.js +23 -31
  29. package/dist/components/Popover/index.cjs +2 -2
  30. package/dist/components/Popover/index.d.ts +4 -2
  31. package/dist/components/Popover/index.js +2 -2
  32. package/dist/components/Popup/helpers.cjs +41 -1
  33. package/dist/components/Popup/helpers.d.ts +1 -1
  34. package/dist/components/Popup/helpers.js +41 -1
  35. package/dist/components/Popup/index.cjs +8 -12
  36. package/dist/components/Popup/index.js +8 -12
  37. package/dist/components/SearchInput/types.d.ts +1 -1
  38. package/dist/components/SelectInput/Dropdown.cjs +9 -9
  39. package/dist/components/SelectInput/Dropdown.js +9 -9
  40. package/dist/components/Slider/styles.d.ts +26 -15
  41. package/dist/components/StepList/index.cjs +3 -3
  42. package/dist/components/StepList/index.js +3 -3
  43. package/dist/components/Table/index.cjs +2 -2
  44. package/dist/components/Table/index.js +2 -2
  45. package/dist/components/TimeInput/index.cjs +3 -3
  46. package/dist/components/TimeInput/index.js +3 -3
  47. package/dist/components/Tooltip/index.cjs +1 -1
  48. package/dist/components/Tooltip/index.d.ts +36 -4
  49. package/dist/components/Tooltip/index.js +1 -1
  50. package/dist/components/UnitInput/index.cjs +19 -38
  51. package/dist/components/UnitInput/index.js +19 -38
  52. package/package.json +5 -5
@@ -1,9 +1,11 @@
1
1
  "use client";
2
- import { jsx } from "@emotion/react/jsx-runtime";
2
+ import { jsx, jsxs } from "@emotion/react/jsx-runtime";
3
3
  import _styled from "@emotion/styled/base";
4
+ import { ArrowRightIcon } from "@ultraviolet/icons";
4
5
  import { forwardRef, useCallback } from "react";
6
+ import { Stack } from "../../Stack/index.js";
5
7
  import { Tooltip } from "../../Tooltip/index.js";
6
- import { useMenu } from "../MenuProvider.js";
8
+ import { useMenu, useDisclosureContext } from "../MenuProvider.js";
7
9
  const ANIMATION_DURATION = 200;
8
10
  const itemCoreStyle = ({
9
11
  theme,
@@ -43,7 +45,7 @@ const itemCoreStyle = ({
43
45
  fill: ${theme.colors[sentiment].textHover};
44
46
  }
45
47
  }`}
46
- `;
48
+ `;
47
49
  const Container = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
48
50
  shouldForwardProp: (prop) => !["borderless"].includes(prop),
49
51
  target: "e50xbs82"
@@ -57,7 +59,7 @@ const Container = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "produ
57
59
  }) => borderless ? "" : `border-bottom: 1px solid ${theme.colors.neutral.border};`, " padding:", ({
58
60
  theme,
59
61
  borderless
60
- }) => `${borderless ? theme.space["0.25"] : theme.space["0.5"]} ${theme.space["0.5"]}`, ";&:last-child{border:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL01lbnUvY29tcG9uZW50cy9JdGVtLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnRTJCIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL01lbnUvY29tcG9uZW50cy9JdGVtLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIid1c2UgY2xpZW50J1xuXG5pbXBvcnQgdHlwZSB7IFRoZW1lIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCdcbmltcG9ydCB0eXBlIHsgTW91c2VFdmVudCwgTW91c2VFdmVudEhhbmRsZXIsIFJlYWN0Tm9kZSwgUmVmIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBmb3J3YXJkUmVmLCB1c2VDYWxsYmFjayB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgVG9vbHRpcCB9IGZyb20gJy4uLy4uL1Rvb2x0aXAnXG5pbXBvcnQgeyB1c2VNZW51IH0gZnJvbSAnLi4vTWVudVByb3ZpZGVyJ1xuXG50eXBlIE1lbnVJdGVtU2VudGltZW50ID0gJ25ldXRyYWwnIHwgJ3ByaW1hcnknIHwgJ2RhbmdlcidcblxuY29uc3QgQU5JTUFUSU9OX0RVUkFUSU9OID0gMjAwIC8vIGluIG1zXG5cbmNvbnN0IGl0ZW1Db3JlU3R5bGUgPSAoe1xuICB0aGVtZSxcbiAgc2VudGltZW50LFxuICBkaXNhYmxlZCxcbn06IHtcbiAgdGhlbWU6IFRoZW1lXG4gIGJvcmRlcmxlc3M6IGJvb2xlYW5cbiAgc2VudGltZW50OiBNZW51SXRlbVNlbnRpbWVudFxuICBkaXNhYmxlZDogYm9vbGVhblxufSkgPT4gYFxuICBkaXNwbGF5OiBmbGV4O1xuICBqdXN0aWZ5LWNvbnRlbnQ6IHN0YXJ0O1xuICB0ZXh0LWFsaWduOiBsZWZ0O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBtaW4taGVpZ2h0OiAke3RoZW1lLnNpemluZ1snNDAwJ119O1xuICBtYXgtaGVpZ2h0OiAke3RoZW1lLnNpemluZ1snNTAwJ119O1xuICBmb250LXNpemU6ICR7dGhlbWUudHlwb2dyYXBoeS5ib2R5U21hbGwuZm9udFNpemV9O1xuICBsaW5lLWhlaWdodDogJHt0aGVtZS50eXBvZ3JhcGh5LmJvZHlTbWFsbC5saW5lSGVpZ2h0fTtcbiAgZm9udC13ZWlnaHQ6IGluaGVyaXQ7XG4gIHBhZGRpbmc6ICR7YCR7dGhlbWUuc3BhY2VbJzAuNSddfSAke3RoZW1lLnNwYWNlWycxJ119YH07XG4gIGJvcmRlcjogbm9uZTtcbiAgY3Vyc29yOiBwb2ludGVyO1xuICBtaW4td2lkdGg6IDYuODc1cmVtO1xuICB3aWR0aDogMTAwJTtcbiAgYm9yZGVyLXJhZGl1czogJHt0aGVtZS5yYWRpaS5kZWZhdWx0fTtcbiAgdHJhbnNpdGlvbjogYmFja2dyb3VuZC1jb2xvciAke0FOSU1BVElPTl9EVVJBVElPTn1tcywgY29sb3IgJHtBTklNQVRJT05fRFVSQVRJT059bXM7XG5cbiAgY29sb3I6ICR7dGhlbWUuY29sb3JzW3NlbnRpbWVudF1bZGlzYWJsZWQgPyAndGV4dERpc2FibGVkJyA6ICd0ZXh0J119O1xuICBzdmcge1xuICAgIGZpbGw6ICR7dGhlbWUuY29sb3JzW3NlbnRpbWVudF1bZGlzYWJsZWQgPyAndGV4dERpc2FibGVkJyA6ICd0ZXh0J119O1xuICB9XG5cbiAgJHtcbiAgICBkaXNhYmxlZFxuICAgICAgPyBgXG4gICAgICAgIGN1cnNvcjogbm90LWFsbG93ZWQ7XG4gICAgICBgXG4gICAgICA6IGBcbiAgICAgICAgICAmOmhvdmVyLFxuICAgICAgICAgICY6Zm9jdXMsICZbZGF0YS1hY3RpdmU9J3RydWUnXSB7XG4gICAgICAgICAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke3RoZW1lLmNvbG9yc1tzZW50aW1lbnRdLmJhY2tncm91bmRIb3Zlcn07XG4gICAgICAgICAgICBjb2xvcjogJHt0aGVtZS5jb2xvcnNbc2VudGltZW50XS50ZXh0SG92ZXJ9O1xuICAgICAgICAgICAgc3ZnIHtcbiAgICAgICAgICAgICAgZmlsbDogJHt0aGVtZS5jb2xvcnNbc2VudGltZW50XS50ZXh0SG92ZXJ9O1xuICAgICAgICAgICAgfVxuICAgICAgICAgIH1gXG4gIH1cbiAgYFxuXG5jb25zdCBDb250YWluZXIgPSBzdHlsZWQoJ2RpdicsIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IHByb3AgPT4gIVsnYm9yZGVybGVzcyddLmluY2x1ZGVzKHByb3ApLFxufSk8eyBib3JkZXJsZXNzOiBib29sZWFuIH0+YFxuICAkeyh7IHRoZW1lLCBib3JkZXJsZXNzIH0pID0+XG4gICAgYm9yZGVybGVzc1xuICAgICAgPyAnJ1xuICAgICAgOiBgYm9yZGVyLWJvdHRvbTogMXB4IHNvbGlkICR7dGhlbWUuY29sb3JzLm5ldXRyYWwuYm9yZGVyfTtgfVxuICBwYWRkaW5nOiAkeyh7IHRoZW1lLCBib3JkZXJsZXNzIH0pID0+XG4gICAgYCR7Ym9yZGVybGVzcyA/IHRoZW1lLnNwYWNlWycwLjI1J10gOiB0aGVtZS5zcGFjZVsnMC41J119ICR7XG4gICAgICB0aGVtZS5zcGFjZVsnMC41J11cbiAgICB9YH07XG4gICY6bGFzdC1jaGlsZCB7XG4gICAgYm9yZGVyOiBub25lO1xuICB9XG5gXG5cbmNvbnN0IFN0eWxlZEl0ZW0gPSBzdHlsZWQoJ2J1dHRvbicsIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IHByb3AgPT4gIVsnYm9yZGVybGVzcycsICdzZW50aW1lbnQnXS5pbmNsdWRlcyhwcm9wKSxcbn0pPHtcbiAgYm9yZGVybGVzczogYm9vbGVhblxuICBkaXNhYmxlZDogYm9vbGVhblxuICBzZW50aW1lbnQ6IE1lbnVJdGVtU2VudGltZW50XG59PmBcbiAgJHsoeyB0aGVtZSwgYm9yZGVybGVzcywgc2VudGltZW50LCBkaXNhYmxlZCB9KSA9PlxuICAgIGl0ZW1Db3JlU3R5bGUoeyB0aGVtZSwgYm9yZGVybGVzcywgc2VudGltZW50LCBkaXNhYmxlZCB9KX1cbiAgYmFja2dyb3VuZDogbm9uZTtcbmBcblxuY29uc3QgU3R5bGVkTGlua0l0ZW0gPSBzdHlsZWQoJ2EnLCB7XG4gIHNob3VsZEZvcndhcmRQcm9wOiBwcm9wID0+ICFbJ2JvcmRlcmxlc3MnLCAnc2VudGltZW50J10uaW5jbHVkZXMocHJvcCksXG59KTx7XG4gIGJvcmRlcmxlc3M6IGJvb2xlYW5cbiAgZGlzYWJsZWQ6IGJvb2xlYW5cbiAgc2VudGltZW50OiBNZW51SXRlbVNlbnRpbWVudFxufT5gXG4gICR7KHsgdGhlbWUsIGJvcmRlcmxlc3MsIHNlbnRpbWVudCwgZGlzYWJsZWQgfSkgPT5cbiAgICBpdGVtQ29yZVN0eWxlKHsgdGhlbWUsIGJvcmRlcmxlc3MsIHNlbnRpbWVudCwgZGlzYWJsZWQgfSl9XG4gIHRleHQtZGVjb3JhdGlvbjogbm9uZTtcblxuICAmOmZvY3VzIHtcbiAgICB0ZXh0LWRlY29yYXRpb246IG5vbmU7XG4gIH1cbmBcblxudHlwZSBJdGVtUHJvcHMgPSB7XG4gIGhyZWY/OiBIVE1MQW5jaG9yRWxlbWVudFsnaHJlZiddXG4gIHRhcmdldD86IEhUTUxBbmNob3JFbGVtZW50Wyd0YXJnZXQnXVxuICByZWw/OiBIVE1MQW5jaG9yRWxlbWVudFsncmVsJ11cbiAgZGlzYWJsZWQ/OiBib29sZWFuIHwgdW5kZWZpbmVkXG4gIHRvb2x0aXA/OiBzdHJpbmcgfCB1bmRlZmluZWRcbiAgY2xhc3NOYW1lPzogc3RyaW5nIHwgdW5kZWZpbmVkXG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgb25DbGljaz86IE1vdXNlRXZlbnRIYW5kbGVyPEhUTUxFbGVtZW50PiB8IHVuZGVmaW5lZFxuICBib3JkZXJsZXNzPzogYm9vbGVhblxuICBzZW50aW1lbnQ/OiBNZW51SXRlbVNlbnRpbWVudFxuICBhY3RpdmU/OiBib29sZWFuXG4gICdkYXRhLXRlc3RpZCc/OiBzdHJpbmdcbiAgLyoqXG4gICAqIElmIHlvdSBjaGlsZHJlbiBpcyBjb21wbGV4IGFuZCB5b3Ugd2FudCB0byBzcGVjaWZ5IHRoZSBzZWFyY2ggdGV4dCB1c2UgdGhpcyBwcm9wLlxuICAgKi9cbiAgc2VhcmNoVGV4dD86IHN0cmluZ1xufVxuXG5jb25zdCBJdGVtID0gZm9yd2FyZFJlZjxIVE1MRWxlbWVudCwgSXRlbVByb3BzPihcbiAgKFxuICAgIHtcbiAgICAgIGJvcmRlcmxlc3MgPSBmYWxzZSxcbiAgICAgIGRpc2FibGVkID0gZmFsc2UsXG4gICAgICBvbkNsaWNrLFxuICAgICAgc2VudGltZW50ID0gJ25ldXRyYWwnLFxuICAgICAgaHJlZixcbiAgICAgIHRhcmdldCxcbiAgICAgIHJlbCxcbiAgICAgIGNoaWxkcmVuLFxuICAgICAgdG9vbHRpcCxcbiAgICAgIGFjdGl2ZSxcbiAgICAgIGNsYXNzTmFtZSxcbiAgICAgIHNlYXJjaFRleHQsXG4gICAgICAnZGF0YS10ZXN0aWQnOiBkYXRhVGVzdElkLFxuICAgIH0sXG4gICAgcmVmLFxuICApID0+IHtcbiAgICBjb25zdCB7IGhpZGVPbkNsaWNrSXRlbSwgc2V0SXNWaXNpYmxlIH0gPSB1c2VNZW51KClcblxuICAgIGNvbnN0IG9uQ2xpY2tIYW5kbGUgPSB1c2VDYWxsYmFjayhcbiAgICAgIChldmVudDogTW91c2VFdmVudDxIVE1MQW5jaG9yRWxlbWVudD4pID0+IHtcbiAgICAgICAgaWYgKGRpc2FibGVkKSByZXR1cm4gdW5kZWZpbmVkXG4gICAgICAgIG9uQ2xpY2s/LihldmVudClcbiAgICAgICAgaWYgKGhpZGVPbkNsaWNrSXRlbSkge1xuICAgICAgICAgIHNldElzVmlzaWJsZShmYWxzZSlcbiAgICAgICAgfVxuXG4gICAgICAgIHJldHVybiB1bmRlZmluZWRcbiAgICAgIH0sXG4gICAgICBbZGlzYWJsZWQsIGhpZGVPbkNsaWNrSXRlbSwgb25DbGljaywgc2V0SXNWaXNpYmxlXSxcbiAgICApXG5cbiAgICBpZiAoaHJlZiAmJiAhZGlzYWJsZWQpIHtcbiAgICAgIHJldHVybiAoXG4gICAgICAgIDxDb250YWluZXIgYm9yZGVybGVzcz17Ym9yZGVybGVzc30gZGF0YS1zZWFyY2gtdGV4dD17c2VhcmNoVGV4dH0+XG4gICAgICAgICAgPFRvb2x0aXAgdGV4dD17dG9vbHRpcH0+XG4gICAgICAgICAgICA8U3R5bGVkTGlua0l0ZW1cbiAgICAgICAgICAgICAgZGF0YS1hY3RpdmU9e2FjdGl2ZX1cbiAgICAgICAgICAgICAgYm9yZGVybGVzc1xuICAgICAgICAgICAgICBocmVmPXtocmVmfVxuICAgICAgICAgICAgICB0YXJnZXQ9e3RhcmdldH1cbiAgICAgICAgICAgICAgcmVsPXtyZWx9XG4gICAgICAgICAgICAgIHJlZj17cmVmIGFzIFJlZjxIVE1MQW5jaG9yRWxlbWVudD59XG4gICAgICAgICAgICAgIG9uQ2xpY2s9e29uQ2xpY2tIYW5kbGV9XG4gICAgICAgICAgICAgIHJvbGU9XCJtZW51aXRlbVwiXG4gICAgICAgICAgICAgIGRpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgICAgICAgICAgc2VudGltZW50PXtzZW50aW1lbnR9XG4gICAgICAgICAgICAgIGNsYXNzTmFtZT17Y2xhc3NOYW1lfVxuICAgICAgICAgICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZH1cbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAge2NoaWxkcmVufVxuICAgICAgICAgICAgPC9TdHlsZWRMaW5rSXRlbT5cbiAgICAgICAgICA8L1Rvb2x0aXA+XG4gICAgICAgIDwvQ29udGFpbmVyPlxuICAgICAgKVxuICAgIH1cblxuICAgIHJldHVybiAoXG4gICAgICA8Q29udGFpbmVyIGJvcmRlcmxlc3M9e2JvcmRlcmxlc3N9IGRhdGEtc2VhcmNoLXRleHQ9e3NlYXJjaFRleHR9PlxuICAgICAgICA8VG9vbHRpcCB0ZXh0PXt0b29sdGlwfT5cbiAgICAgICAgICA8U3R5bGVkSXRlbVxuICAgICAgICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICAgICAgICByZWY9e3JlZiBhcyBSZWY8SFRNTEJ1dHRvbkVsZW1lbnQ+fVxuICAgICAgICAgICAgcm9sZT1cIm1lbnVpdGVtXCJcbiAgICAgICAgICAgIGRpc2FibGVkPXtkaXNhYmxlZH1cbiAgICAgICAgICAgIG9uQ2xpY2s9e2V2ZW50ID0+IHtcbiAgICAgICAgICAgICAgb25DbGljaz8uKGV2ZW50KVxuICAgICAgICAgICAgICBpZiAoaGlkZU9uQ2xpY2tJdGVtKSB7XG4gICAgICAgICAgICAgICAgc2V0SXNWaXNpYmxlKGZhbHNlKVxuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9fVxuICAgICAgICAgICAgYm9yZGVybGVzcz17Ym9yZGVybGVzc31cbiAgICAgICAgICAgIHNlbnRpbWVudD17c2VudGltZW50fVxuICAgICAgICAgICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gICAgICAgICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZH1cbiAgICAgICAgICAgIGRhdGEtYWN0aXZlPXthY3RpdmV9XG4gICAgICAgICAgPlxuICAgICAgICAgICAge2NoaWxkcmVufVxuICAgICAgICAgIDwvU3R5bGVkSXRlbT5cbiAgICAgICAgPC9Ub29sdGlwPlxuICAgICAgPC9Db250YWluZXI+XG4gICAgKVxuICB9LFxuKVxuXG5leHBvcnQgZGVmYXVsdCBJdGVtXG4iXX0= */"));
62
+ }) => `${borderless ? theme.space["0.25"] : theme.space["0.5"]} ${theme.space["0.5"]}`, ";&:last-child{border:none;}width:100%;" + (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/Menu/components/Item.tsx"],"names":[],"mappings":"AAkE2B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Menu/components/Item.tsx","sourcesContent":["'use client'\n\nimport type { Theme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { ArrowRightIcon } from '@ultraviolet/icons'\nimport type { MouseEvent, MouseEventHandler, ReactNode, Ref } from 'react'\nimport { forwardRef, useCallback } from 'react'\nimport { Stack } from '../../Stack'\nimport { Tooltip } from '../../Tooltip'\nimport { useDisclosureContext, useMenu } from '../MenuProvider'\n\ntype MenuItemSentiment = 'neutral' | 'primary' | 'danger'\n\nconst ANIMATION_DURATION = 200 // in ms\n\nconst itemCoreStyle = ({\n  theme,\n  sentiment,\n  disabled,\n}: {\n  theme: Theme\n  borderless: boolean\n  sentiment: MenuItemSentiment\n  disabled: boolean\n}) => `\n  display: flex;\n  justify-content: start;\n  text-align: left;\n  align-items: center;\n  min-height: ${theme.sizing['400']};\n  max-height: ${theme.sizing['500']};\n  font-size: ${theme.typography.bodySmall.fontSize};\n  line-height: ${theme.typography.bodySmall.lineHeight};\n  font-weight: inherit;\n  padding: ${`${theme.space['0.5']} ${theme.space['1']}`};\n  border: none;\n  cursor: pointer;\n  min-width: 6.875rem;\n  width: 100%;\n  border-radius: ${theme.radii.default};\n  transition: background-color ${ANIMATION_DURATION}ms, color ${ANIMATION_DURATION}ms;\n\n  color: ${theme.colors[sentiment][disabled ? 'textDisabled' : 'text']};\n  svg {\n    fill: ${theme.colors[sentiment][disabled ? 'textDisabled' : 'text']};\n  }\n\n  ${\n    disabled\n      ? `\n        cursor: not-allowed;\n      `\n      : `\n          &:hover,\n          &:focus, &[data-active='true'] {\n            background-color: ${theme.colors[sentiment].backgroundHover};\n            color: ${theme.colors[sentiment].textHover};\n            svg {\n              fill: ${theme.colors[sentiment].textHover};\n            }\n          }`\n  }\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['borderless'].includes(prop),\n})<{ borderless: boolean }>`\n  ${({ theme, borderless }) =>\n    borderless\n      ? ''\n      : `border-bottom: 1px solid ${theme.colors.neutral.border};`}\n  padding: ${({ theme, borderless }) =>\n    `${borderless ? theme.space['0.25'] : theme.space['0.5']} ${\n      theme.space['0.5']\n    }`};\n  &:last-child {\n    border: none;\n  }\n  width: 100%;\n`\n\nconst StyledItem = styled('button', {\n  shouldForwardProp: prop => !['borderless', 'sentiment'].includes(prop),\n})<{\n  borderless: boolean\n  disabled: boolean\n  sentiment: MenuItemSentiment\n}>`\n  ${({ theme, borderless, sentiment, disabled }) =>\n    itemCoreStyle({ theme, borderless, sentiment, disabled })}\n  background: none;\n`\n\nconst StyledLinkItem = styled('a', {\n  shouldForwardProp: prop => !['borderless', 'sentiment'].includes(prop),\n})<{\n  borderless: boolean\n  disabled: boolean\n  sentiment: MenuItemSentiment\n}>`\n  ${({ theme, borderless, sentiment, disabled }) =>\n    itemCoreStyle({ theme, borderless, sentiment, disabled })}\n  text-decoration: none;\n\n  &:focus {\n    text-decoration: none;\n  }\n`\n\ntype ItemProps = {\n  href?: HTMLAnchorElement['href']\n  target?: HTMLAnchorElement['target']\n  rel?: HTMLAnchorElement['rel']\n  disabled?: boolean | undefined\n  tooltip?: string | undefined\n  className?: string | undefined\n  children: ReactNode\n  onClick?: MouseEventHandler<HTMLElement> | undefined\n  borderless?: boolean\n  sentiment?: MenuItemSentiment\n  active?: boolean\n  'data-testid'?: string\n  /**\n   * If you children is complex and you want to specify the search text use this prop.\n   */\n  searchText?: string\n}\n\nconst Item = forwardRef<HTMLElement, ItemProps>(\n  (\n    {\n      borderless = false,\n      disabled = false,\n      onClick,\n      sentiment = 'neutral',\n      href,\n      target,\n      rel,\n      children,\n      tooltip,\n      active,\n      className,\n      searchText,\n      'data-testid': dataTestId,\n    },\n    ref,\n  ) => {\n    const { hideOnClickItem, setIsVisible, isVisible } = useMenu()\n    const isDisclosure = useDisclosureContext()\n\n    const onClickHandle = useCallback(\n      (event: MouseEvent<HTMLAnchorElement>) => {\n        if (disabled) return undefined\n        onClick?.(event)\n        if (hideOnClickItem) {\n          setIsVisible(false)\n        }\n\n        return undefined\n      },\n      [disabled, hideOnClickItem, onClick, setIsVisible],\n    )\n\n    if (href && !disabled) {\n      return (\n        <Container borderless={borderless} data-search-text={searchText}>\n          <Tooltip text={tooltip}>\n            <StyledLinkItem\n              data-active={active}\n              borderless\n              href={href}\n              target={target}\n              rel={rel}\n              ref={ref as Ref<HTMLAnchorElement>}\n              onClick={onClickHandle}\n              role=\"menuitem\"\n              disabled={disabled}\n              sentiment={sentiment}\n              className={className}\n              data-testid={dataTestId}\n            >\n              {isDisclosure ? (\n                <Stack\n                  justifyContent=\"space-between\"\n                  direction=\"row\"\n                  width=\"100%\"\n                  alignItems=\"center\"\n                >\n                  {children} <ArrowRightIcon />\n                </Stack>\n              ) : (\n                children\n              )}\n            </StyledLinkItem>\n          </Tooltip>\n        </Container>\n      )\n    }\n\n    return (\n      <Container borderless={borderless} data-search-text={searchText}>\n        <Tooltip text={tooltip}>\n          <StyledItem\n            type=\"button\"\n            ref={ref as Ref<HTMLButtonElement>}\n            role=\"menuitem\"\n            disabled={disabled}\n            onClick={event => {\n              onClick?.(event)\n              if (hideOnClickItem) {\n                setIsVisible(false)\n              }\n            }}\n            borderless={borderless}\n            sentiment={sentiment}\n            className={className}\n            data-testid={dataTestId}\n            data-active={active || (isVisible && isDisclosure)}\n          >\n            {isDisclosure ? (\n              <Stack\n                justifyContent=\"space-between\"\n                direction=\"row\"\n                width=\"100%\"\n                alignItems=\"center\"\n              >\n                {children} <ArrowRightIcon />\n              </Stack>\n            ) : (\n              children\n            )}\n          </StyledItem>\n        </Tooltip>\n      </Container>\n    )\n  },\n)\n\nexport default Item\n"]} */"));
61
63
  const StyledItem = /* @__PURE__ */ _styled("button", process.env.NODE_ENV === "production" ? {
62
64
  shouldForwardProp: (prop) => !["borderless", "sentiment"].includes(prop),
63
65
  target: "e50xbs81"
@@ -74,7 +76,7 @@ const StyledItem = /* @__PURE__ */ _styled("button", process.env.NODE_ENV === "p
74
76
  theme,
75
77
  sentiment,
76
78
  disabled
77
- }), " background:none;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL01lbnUvY29tcG9uZW50cy9JdGVtLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFvRkUiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvTWVudS9jb21wb25lbnRzL0l0ZW0udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCB0eXBlIHsgVGhlbWUgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCdcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHR5cGUgeyBNb3VzZUV2ZW50LCBNb3VzZUV2ZW50SGFuZGxlciwgUmVhY3ROb2RlLCBSZWYgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IGZvcndhcmRSZWYsIHVzZUNhbGxiYWNrIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBUb29sdGlwIH0gZnJvbSAnLi4vLi4vVG9vbHRpcCdcbmltcG9ydCB7IHVzZU1lbnUgfSBmcm9tICcuLi9NZW51UHJvdmlkZXInXG5cbnR5cGUgTWVudUl0ZW1TZW50aW1lbnQgPSAnbmV1dHJhbCcgfCAncHJpbWFyeScgfCAnZGFuZ2VyJ1xuXG5jb25zdCBBTklNQVRJT05fRFVSQVRJT04gPSAyMDAgLy8gaW4gbXNcblxuY29uc3QgaXRlbUNvcmVTdHlsZSA9ICh7XG4gIHRoZW1lLFxuICBzZW50aW1lbnQsXG4gIGRpc2FibGVkLFxufToge1xuICB0aGVtZTogVGhlbWVcbiAgYm9yZGVybGVzczogYm9vbGVhblxuICBzZW50aW1lbnQ6IE1lbnVJdGVtU2VudGltZW50XG4gIGRpc2FibGVkOiBib29sZWFuXG59KSA9PiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGp1c3RpZnktY29udGVudDogc3RhcnQ7XG4gIHRleHQtYWxpZ246IGxlZnQ7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIG1pbi1oZWlnaHQ6ICR7dGhlbWUuc2l6aW5nWyc0MDAnXX07XG4gIG1heC1oZWlnaHQ6ICR7dGhlbWUuc2l6aW5nWyc1MDAnXX07XG4gIGZvbnQtc2l6ZTogJHt0aGVtZS50eXBvZ3JhcGh5LmJvZHlTbWFsbC5mb250U2l6ZX07XG4gIGxpbmUtaGVpZ2h0OiAke3RoZW1lLnR5cG9ncmFwaHkuYm9keVNtYWxsLmxpbmVIZWlnaHR9O1xuICBmb250LXdlaWdodDogaW5oZXJpdDtcbiAgcGFkZGluZzogJHtgJHt0aGVtZS5zcGFjZVsnMC41J119ICR7dGhlbWUuc3BhY2VbJzEnXX1gfTtcbiAgYm9yZGVyOiBub25lO1xuICBjdXJzb3I6IHBvaW50ZXI7XG4gIG1pbi13aWR0aDogNi44NzVyZW07XG4gIHdpZHRoOiAxMDAlO1xuICBib3JkZXItcmFkaXVzOiAke3RoZW1lLnJhZGlpLmRlZmF1bHR9O1xuICB0cmFuc2l0aW9uOiBiYWNrZ3JvdW5kLWNvbG9yICR7QU5JTUFUSU9OX0RVUkFUSU9OfW1zLCBjb2xvciAke0FOSU1BVElPTl9EVVJBVElPTn1tcztcblxuICBjb2xvcjogJHt0aGVtZS5jb2xvcnNbc2VudGltZW50XVtkaXNhYmxlZCA/ICd0ZXh0RGlzYWJsZWQnIDogJ3RleHQnXX07XG4gIHN2ZyB7XG4gICAgZmlsbDogJHt0aGVtZS5jb2xvcnNbc2VudGltZW50XVtkaXNhYmxlZCA/ICd0ZXh0RGlzYWJsZWQnIDogJ3RleHQnXX07XG4gIH1cblxuICAke1xuICAgIGRpc2FibGVkXG4gICAgICA/IGBcbiAgICAgICAgY3Vyc29yOiBub3QtYWxsb3dlZDtcbiAgICAgIGBcbiAgICAgIDogYFxuICAgICAgICAgICY6aG92ZXIsXG4gICAgICAgICAgJjpmb2N1cywgJltkYXRhLWFjdGl2ZT0ndHJ1ZSddIHtcbiAgICAgICAgICAgIGJhY2tncm91bmQtY29sb3I6ICR7dGhlbWUuY29sb3JzW3NlbnRpbWVudF0uYmFja2dyb3VuZEhvdmVyfTtcbiAgICAgICAgICAgIGNvbG9yOiAke3RoZW1lLmNvbG9yc1tzZW50aW1lbnRdLnRleHRIb3Zlcn07XG4gICAgICAgICAgICBzdmcge1xuICAgICAgICAgICAgICBmaWxsOiAke3RoZW1lLmNvbG9yc1tzZW50aW1lbnRdLnRleHRIb3Zlcn07XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfWBcbiAgfVxuICBgXG5cbmNvbnN0IENvbnRhaW5lciA9IHN0eWxlZCgnZGl2Jywge1xuICBzaG91bGRGb3J3YXJkUHJvcDogcHJvcCA9PiAhWydib3JkZXJsZXNzJ10uaW5jbHVkZXMocHJvcCksXG59KTx7IGJvcmRlcmxlc3M6IGJvb2xlYW4gfT5gXG4gICR7KHsgdGhlbWUsIGJvcmRlcmxlc3MgfSkgPT5cbiAgICBib3JkZXJsZXNzXG4gICAgICA/ICcnXG4gICAgICA6IGBib3JkZXItYm90dG9tOiAxcHggc29saWQgJHt0aGVtZS5jb2xvcnMubmV1dHJhbC5ib3JkZXJ9O2B9XG4gIHBhZGRpbmc6ICR7KHsgdGhlbWUsIGJvcmRlcmxlc3MgfSkgPT5cbiAgICBgJHtib3JkZXJsZXNzID8gdGhlbWUuc3BhY2VbJzAuMjUnXSA6IHRoZW1lLnNwYWNlWycwLjUnXX0gJHtcbiAgICAgIHRoZW1lLnNwYWNlWycwLjUnXVxuICAgIH1gfTtcbiAgJjpsYXN0LWNoaWxkIHtcbiAgICBib3JkZXI6IG5vbmU7XG4gIH1cbmBcblxuY29uc3QgU3R5bGVkSXRlbSA9IHN0eWxlZCgnYnV0dG9uJywge1xuICBzaG91bGRGb3J3YXJkUHJvcDogcHJvcCA9PiAhWydib3JkZXJsZXNzJywgJ3NlbnRpbWVudCddLmluY2x1ZGVzKHByb3ApLFxufSk8e1xuICBib3JkZXJsZXNzOiBib29sZWFuXG4gIGRpc2FibGVkOiBib29sZWFuXG4gIHNlbnRpbWVudDogTWVudUl0ZW1TZW50aW1lbnRcbn0+YFxuICAkeyh7IHRoZW1lLCBib3JkZXJsZXNzLCBzZW50aW1lbnQsIGRpc2FibGVkIH0pID0+XG4gICAgaXRlbUNvcmVTdHlsZSh7IHRoZW1lLCBib3JkZXJsZXNzLCBzZW50aW1lbnQsIGRpc2FibGVkIH0pfVxuICBiYWNrZ3JvdW5kOiBub25lO1xuYFxuXG5jb25zdCBTdHlsZWRMaW5rSXRlbSA9IHN0eWxlZCgnYScsIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IHByb3AgPT4gIVsnYm9yZGVybGVzcycsICdzZW50aW1lbnQnXS5pbmNsdWRlcyhwcm9wKSxcbn0pPHtcbiAgYm9yZGVybGVzczogYm9vbGVhblxuICBkaXNhYmxlZDogYm9vbGVhblxuICBzZW50aW1lbnQ6IE1lbnVJdGVtU2VudGltZW50XG59PmBcbiAgJHsoeyB0aGVtZSwgYm9yZGVybGVzcywgc2VudGltZW50LCBkaXNhYmxlZCB9KSA9PlxuICAgIGl0ZW1Db3JlU3R5bGUoeyB0aGVtZSwgYm9yZGVybGVzcywgc2VudGltZW50LCBkaXNhYmxlZCB9KX1cbiAgdGV4dC1kZWNvcmF0aW9uOiBub25lO1xuXG4gICY6Zm9jdXMge1xuICAgIHRleHQtZGVjb3JhdGlvbjogbm9uZTtcbiAgfVxuYFxuXG50eXBlIEl0ZW1Qcm9wcyA9IHtcbiAgaHJlZj86IEhUTUxBbmNob3JFbGVtZW50WydocmVmJ11cbiAgdGFyZ2V0PzogSFRNTEFuY2hvckVsZW1lbnRbJ3RhcmdldCddXG4gIHJlbD86IEhUTUxBbmNob3JFbGVtZW50WydyZWwnXVxuICBkaXNhYmxlZD86IGJvb2xlYW4gfCB1bmRlZmluZWRcbiAgdG9vbHRpcD86IHN0cmluZyB8IHVuZGVmaW5lZFxuICBjbGFzc05hbWU/OiBzdHJpbmcgfCB1bmRlZmluZWRcbiAgY2hpbGRyZW46IFJlYWN0Tm9kZVxuICBvbkNsaWNrPzogTW91c2VFdmVudEhhbmRsZXI8SFRNTEVsZW1lbnQ+IHwgdW5kZWZpbmVkXG4gIGJvcmRlcmxlc3M/OiBib29sZWFuXG4gIHNlbnRpbWVudD86IE1lbnVJdGVtU2VudGltZW50XG4gIGFjdGl2ZT86IGJvb2xlYW5cbiAgJ2RhdGEtdGVzdGlkJz86IHN0cmluZ1xuICAvKipcbiAgICogSWYgeW91IGNoaWxkcmVuIGlzIGNvbXBsZXggYW5kIHlvdSB3YW50IHRvIHNwZWNpZnkgdGhlIHNlYXJjaCB0ZXh0IHVzZSB0aGlzIHByb3AuXG4gICAqL1xuICBzZWFyY2hUZXh0Pzogc3RyaW5nXG59XG5cbmNvbnN0IEl0ZW0gPSBmb3J3YXJkUmVmPEhUTUxFbGVtZW50LCBJdGVtUHJvcHM+KFxuICAoXG4gICAge1xuICAgICAgYm9yZGVybGVzcyA9IGZhbHNlLFxuICAgICAgZGlzYWJsZWQgPSBmYWxzZSxcbiAgICAgIG9uQ2xpY2ssXG4gICAgICBzZW50aW1lbnQgPSAnbmV1dHJhbCcsXG4gICAgICBocmVmLFxuICAgICAgdGFyZ2V0LFxuICAgICAgcmVsLFxuICAgICAgY2hpbGRyZW4sXG4gICAgICB0b29sdGlwLFxuICAgICAgYWN0aXZlLFxuICAgICAgY2xhc3NOYW1lLFxuICAgICAgc2VhcmNoVGV4dCxcbiAgICAgICdkYXRhLXRlc3RpZCc6IGRhdGFUZXN0SWQsXG4gICAgfSxcbiAgICByZWYsXG4gICkgPT4ge1xuICAgIGNvbnN0IHsgaGlkZU9uQ2xpY2tJdGVtLCBzZXRJc1Zpc2libGUgfSA9IHVzZU1lbnUoKVxuXG4gICAgY29uc3Qgb25DbGlja0hhbmRsZSA9IHVzZUNhbGxiYWNrKFxuICAgICAgKGV2ZW50OiBNb3VzZUV2ZW50PEhUTUxBbmNob3JFbGVtZW50PikgPT4ge1xuICAgICAgICBpZiAoZGlzYWJsZWQpIHJldHVybiB1bmRlZmluZWRcbiAgICAgICAgb25DbGljaz8uKGV2ZW50KVxuICAgICAgICBpZiAoaGlkZU9uQ2xpY2tJdGVtKSB7XG4gICAgICAgICAgc2V0SXNWaXNpYmxlKGZhbHNlKVxuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIHVuZGVmaW5lZFxuICAgICAgfSxcbiAgICAgIFtkaXNhYmxlZCwgaGlkZU9uQ2xpY2tJdGVtLCBvbkNsaWNrLCBzZXRJc1Zpc2libGVdLFxuICAgIClcblxuICAgIGlmIChocmVmICYmICFkaXNhYmxlZCkge1xuICAgICAgcmV0dXJuIChcbiAgICAgICAgPENvbnRhaW5lciBib3JkZXJsZXNzPXtib3JkZXJsZXNzfSBkYXRhLXNlYXJjaC10ZXh0PXtzZWFyY2hUZXh0fT5cbiAgICAgICAgICA8VG9vbHRpcCB0ZXh0PXt0b29sdGlwfT5cbiAgICAgICAgICAgIDxTdHlsZWRMaW5rSXRlbVxuICAgICAgICAgICAgICBkYXRhLWFjdGl2ZT17YWN0aXZlfVxuICAgICAgICAgICAgICBib3JkZXJsZXNzXG4gICAgICAgICAgICAgIGhyZWY9e2hyZWZ9XG4gICAgICAgICAgICAgIHRhcmdldD17dGFyZ2V0fVxuICAgICAgICAgICAgICByZWw9e3JlbH1cbiAgICAgICAgICAgICAgcmVmPXtyZWYgYXMgUmVmPEhUTUxBbmNob3JFbGVtZW50Pn1cbiAgICAgICAgICAgICAgb25DbGljaz17b25DbGlja0hhbmRsZX1cbiAgICAgICAgICAgICAgcm9sZT1cIm1lbnVpdGVtXCJcbiAgICAgICAgICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAgICAgICBzZW50aW1lbnQ9e3NlbnRpbWVudH1cbiAgICAgICAgICAgICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gICAgICAgICAgICAgIGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfVxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICB7Y2hpbGRyZW59XG4gICAgICAgICAgICA8L1N0eWxlZExpbmtJdGVtPlxuICAgICAgICAgIDwvVG9vbHRpcD5cbiAgICAgICAgPC9Db250YWluZXI+XG4gICAgICApXG4gICAgfVxuXG4gICAgcmV0dXJuIChcbiAgICAgIDxDb250YWluZXIgYm9yZGVybGVzcz17Ym9yZGVybGVzc30gZGF0YS1zZWFyY2gtdGV4dD17c2VhcmNoVGV4dH0+XG4gICAgICAgIDxUb29sdGlwIHRleHQ9e3Rvb2x0aXB9PlxuICAgICAgICAgIDxTdHlsZWRJdGVtXG4gICAgICAgICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgICAgICAgIHJlZj17cmVmIGFzIFJlZjxIVE1MQnV0dG9uRWxlbWVudD59XG4gICAgICAgICAgICByb2xlPVwibWVudWl0ZW1cIlxuICAgICAgICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAgICAgb25DbGljaz17ZXZlbnQgPT4ge1xuICAgICAgICAgICAgICBvbkNsaWNrPy4oZXZlbnQpXG4gICAgICAgICAgICAgIGlmIChoaWRlT25DbGlja0l0ZW0pIHtcbiAgICAgICAgICAgICAgICBzZXRJc1Zpc2libGUoZmFsc2UpXG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH19XG4gICAgICAgICAgICBib3JkZXJsZXNzPXtib3JkZXJsZXNzfVxuICAgICAgICAgICAgc2VudGltZW50PXtzZW50aW1lbnR9XG4gICAgICAgICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgICAgICAgIGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfVxuICAgICAgICAgICAgZGF0YS1hY3RpdmU9e2FjdGl2ZX1cbiAgICAgICAgICA+XG4gICAgICAgICAgICB7Y2hpbGRyZW59XG4gICAgICAgICAgPC9TdHlsZWRJdGVtPlxuICAgICAgICA8L1Rvb2x0aXA+XG4gICAgICA8L0NvbnRhaW5lcj5cbiAgICApXG4gIH0sXG4pXG5cbmV4cG9ydCBkZWZhdWx0IEl0ZW1cbiJdfQ== */"));
79
+ }), " background:none;" + (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/Menu/components/Item.tsx"],"names":[],"mappings":"AAuFE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Menu/components/Item.tsx","sourcesContent":["'use client'\n\nimport type { Theme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { ArrowRightIcon } from '@ultraviolet/icons'\nimport type { MouseEvent, MouseEventHandler, ReactNode, Ref } from 'react'\nimport { forwardRef, useCallback } from 'react'\nimport { Stack } from '../../Stack'\nimport { Tooltip } from '../../Tooltip'\nimport { useDisclosureContext, useMenu } from '../MenuProvider'\n\ntype MenuItemSentiment = 'neutral' | 'primary' | 'danger'\n\nconst ANIMATION_DURATION = 200 // in ms\n\nconst itemCoreStyle = ({\n  theme,\n  sentiment,\n  disabled,\n}: {\n  theme: Theme\n  borderless: boolean\n  sentiment: MenuItemSentiment\n  disabled: boolean\n}) => `\n  display: flex;\n  justify-content: start;\n  text-align: left;\n  align-items: center;\n  min-height: ${theme.sizing['400']};\n  max-height: ${theme.sizing['500']};\n  font-size: ${theme.typography.bodySmall.fontSize};\n  line-height: ${theme.typography.bodySmall.lineHeight};\n  font-weight: inherit;\n  padding: ${`${theme.space['0.5']} ${theme.space['1']}`};\n  border: none;\n  cursor: pointer;\n  min-width: 6.875rem;\n  width: 100%;\n  border-radius: ${theme.radii.default};\n  transition: background-color ${ANIMATION_DURATION}ms, color ${ANIMATION_DURATION}ms;\n\n  color: ${theme.colors[sentiment][disabled ? 'textDisabled' : 'text']};\n  svg {\n    fill: ${theme.colors[sentiment][disabled ? 'textDisabled' : 'text']};\n  }\n\n  ${\n    disabled\n      ? `\n        cursor: not-allowed;\n      `\n      : `\n          &:hover,\n          &:focus, &[data-active='true'] {\n            background-color: ${theme.colors[sentiment].backgroundHover};\n            color: ${theme.colors[sentiment].textHover};\n            svg {\n              fill: ${theme.colors[sentiment].textHover};\n            }\n          }`\n  }\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['borderless'].includes(prop),\n})<{ borderless: boolean }>`\n  ${({ theme, borderless }) =>\n    borderless\n      ? ''\n      : `border-bottom: 1px solid ${theme.colors.neutral.border};`}\n  padding: ${({ theme, borderless }) =>\n    `${borderless ? theme.space['0.25'] : theme.space['0.5']} ${\n      theme.space['0.5']\n    }`};\n  &:last-child {\n    border: none;\n  }\n  width: 100%;\n`\n\nconst StyledItem = styled('button', {\n  shouldForwardProp: prop => !['borderless', 'sentiment'].includes(prop),\n})<{\n  borderless: boolean\n  disabled: boolean\n  sentiment: MenuItemSentiment\n}>`\n  ${({ theme, borderless, sentiment, disabled }) =>\n    itemCoreStyle({ theme, borderless, sentiment, disabled })}\n  background: none;\n`\n\nconst StyledLinkItem = styled('a', {\n  shouldForwardProp: prop => !['borderless', 'sentiment'].includes(prop),\n})<{\n  borderless: boolean\n  disabled: boolean\n  sentiment: MenuItemSentiment\n}>`\n  ${({ theme, borderless, sentiment, disabled }) =>\n    itemCoreStyle({ theme, borderless, sentiment, disabled })}\n  text-decoration: none;\n\n  &:focus {\n    text-decoration: none;\n  }\n`\n\ntype ItemProps = {\n  href?: HTMLAnchorElement['href']\n  target?: HTMLAnchorElement['target']\n  rel?: HTMLAnchorElement['rel']\n  disabled?: boolean | undefined\n  tooltip?: string | undefined\n  className?: string | undefined\n  children: ReactNode\n  onClick?: MouseEventHandler<HTMLElement> | undefined\n  borderless?: boolean\n  sentiment?: MenuItemSentiment\n  active?: boolean\n  'data-testid'?: string\n  /**\n   * If you children is complex and you want to specify the search text use this prop.\n   */\n  searchText?: string\n}\n\nconst Item = forwardRef<HTMLElement, ItemProps>(\n  (\n    {\n      borderless = false,\n      disabled = false,\n      onClick,\n      sentiment = 'neutral',\n      href,\n      target,\n      rel,\n      children,\n      tooltip,\n      active,\n      className,\n      searchText,\n      'data-testid': dataTestId,\n    },\n    ref,\n  ) => {\n    const { hideOnClickItem, setIsVisible, isVisible } = useMenu()\n    const isDisclosure = useDisclosureContext()\n\n    const onClickHandle = useCallback(\n      (event: MouseEvent<HTMLAnchorElement>) => {\n        if (disabled) return undefined\n        onClick?.(event)\n        if (hideOnClickItem) {\n          setIsVisible(false)\n        }\n\n        return undefined\n      },\n      [disabled, hideOnClickItem, onClick, setIsVisible],\n    )\n\n    if (href && !disabled) {\n      return (\n        <Container borderless={borderless} data-search-text={searchText}>\n          <Tooltip text={tooltip}>\n            <StyledLinkItem\n              data-active={active}\n              borderless\n              href={href}\n              target={target}\n              rel={rel}\n              ref={ref as Ref<HTMLAnchorElement>}\n              onClick={onClickHandle}\n              role=\"menuitem\"\n              disabled={disabled}\n              sentiment={sentiment}\n              className={className}\n              data-testid={dataTestId}\n            >\n              {isDisclosure ? (\n                <Stack\n                  justifyContent=\"space-between\"\n                  direction=\"row\"\n                  width=\"100%\"\n                  alignItems=\"center\"\n                >\n                  {children} <ArrowRightIcon />\n                </Stack>\n              ) : (\n                children\n              )}\n            </StyledLinkItem>\n          </Tooltip>\n        </Container>\n      )\n    }\n\n    return (\n      <Container borderless={borderless} data-search-text={searchText}>\n        <Tooltip text={tooltip}>\n          <StyledItem\n            type=\"button\"\n            ref={ref as Ref<HTMLButtonElement>}\n            role=\"menuitem\"\n            disabled={disabled}\n            onClick={event => {\n              onClick?.(event)\n              if (hideOnClickItem) {\n                setIsVisible(false)\n              }\n            }}\n            borderless={borderless}\n            sentiment={sentiment}\n            className={className}\n            data-testid={dataTestId}\n            data-active={active || (isVisible && isDisclosure)}\n          >\n            {isDisclosure ? (\n              <Stack\n                justifyContent=\"space-between\"\n                direction=\"row\"\n                width=\"100%\"\n                alignItems=\"center\"\n              >\n                {children} <ArrowRightIcon />\n              </Stack>\n            ) : (\n              children\n            )}\n          </StyledItem>\n        </Tooltip>\n      </Container>\n    )\n  },\n)\n\nexport default Item\n"]} */"));
78
80
  const StyledLinkItem = /* @__PURE__ */ _styled("a", process.env.NODE_ENV === "production" ? {
79
81
  shouldForwardProp: (prop) => !["borderless", "sentiment"].includes(prop),
80
82
  target: "e50xbs80"
@@ -91,7 +93,7 @@ const StyledLinkItem = /* @__PURE__ */ _styled("a", process.env.NODE_ENV === "pr
91
93
  theme,
92
94
  sentiment,
93
95
  disabled
94
- }), " text-decoration:none;&:focus{text-decoration:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3VpL3NyYy9jb21wb25lbnRzL01lbnUvY29tcG9uZW50cy9JdGVtLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnR0UiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvdWkvc3JjL2NvbXBvbmVudHMvTWVudS9jb21wb25lbnRzL0l0ZW0udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiJ3VzZSBjbGllbnQnXG5cbmltcG9ydCB0eXBlIHsgVGhlbWUgfSBmcm9tICdAZW1vdGlvbi9yZWFjdCdcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJ1xuaW1wb3J0IHR5cGUgeyBNb3VzZUV2ZW50LCBNb3VzZUV2ZW50SGFuZGxlciwgUmVhY3ROb2RlLCBSZWYgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB7IGZvcndhcmRSZWYsIHVzZUNhbGxiYWNrIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBUb29sdGlwIH0gZnJvbSAnLi4vLi4vVG9vbHRpcCdcbmltcG9ydCB7IHVzZU1lbnUgfSBmcm9tICcuLi9NZW51UHJvdmlkZXInXG5cbnR5cGUgTWVudUl0ZW1TZW50aW1lbnQgPSAnbmV1dHJhbCcgfCAncHJpbWFyeScgfCAnZGFuZ2VyJ1xuXG5jb25zdCBBTklNQVRJT05fRFVSQVRJT04gPSAyMDAgLy8gaW4gbXNcblxuY29uc3QgaXRlbUNvcmVTdHlsZSA9ICh7XG4gIHRoZW1lLFxuICBzZW50aW1lbnQsXG4gIGRpc2FibGVkLFxufToge1xuICB0aGVtZTogVGhlbWVcbiAgYm9yZGVybGVzczogYm9vbGVhblxuICBzZW50aW1lbnQ6IE1lbnVJdGVtU2VudGltZW50XG4gIGRpc2FibGVkOiBib29sZWFuXG59KSA9PiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGp1c3RpZnktY29udGVudDogc3RhcnQ7XG4gIHRleHQtYWxpZ246IGxlZnQ7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIG1pbi1oZWlnaHQ6ICR7dGhlbWUuc2l6aW5nWyc0MDAnXX07XG4gIG1heC1oZWlnaHQ6ICR7dGhlbWUuc2l6aW5nWyc1MDAnXX07XG4gIGZvbnQtc2l6ZTogJHt0aGVtZS50eXBvZ3JhcGh5LmJvZHlTbWFsbC5mb250U2l6ZX07XG4gIGxpbmUtaGVpZ2h0OiAke3RoZW1lLnR5cG9ncmFwaHkuYm9keVNtYWxsLmxpbmVIZWlnaHR9O1xuICBmb250LXdlaWdodDogaW5oZXJpdDtcbiAgcGFkZGluZzogJHtgJHt0aGVtZS5zcGFjZVsnMC41J119ICR7dGhlbWUuc3BhY2VbJzEnXX1gfTtcbiAgYm9yZGVyOiBub25lO1xuICBjdXJzb3I6IHBvaW50ZXI7XG4gIG1pbi13aWR0aDogNi44NzVyZW07XG4gIHdpZHRoOiAxMDAlO1xuICBib3JkZXItcmFkaXVzOiAke3RoZW1lLnJhZGlpLmRlZmF1bHR9O1xuICB0cmFuc2l0aW9uOiBiYWNrZ3JvdW5kLWNvbG9yICR7QU5JTUFUSU9OX0RVUkFUSU9OfW1zLCBjb2xvciAke0FOSU1BVElPTl9EVVJBVElPTn1tcztcblxuICBjb2xvcjogJHt0aGVtZS5jb2xvcnNbc2VudGltZW50XVtkaXNhYmxlZCA/ICd0ZXh0RGlzYWJsZWQnIDogJ3RleHQnXX07XG4gIHN2ZyB7XG4gICAgZmlsbDogJHt0aGVtZS5jb2xvcnNbc2VudGltZW50XVtkaXNhYmxlZCA/ICd0ZXh0RGlzYWJsZWQnIDogJ3RleHQnXX07XG4gIH1cblxuICAke1xuICAgIGRpc2FibGVkXG4gICAgICA/IGBcbiAgICAgICAgY3Vyc29yOiBub3QtYWxsb3dlZDtcbiAgICAgIGBcbiAgICAgIDogYFxuICAgICAgICAgICY6aG92ZXIsXG4gICAgICAgICAgJjpmb2N1cywgJltkYXRhLWFjdGl2ZT0ndHJ1ZSddIHtcbiAgICAgICAgICAgIGJhY2tncm91bmQtY29sb3I6ICR7dGhlbWUuY29sb3JzW3NlbnRpbWVudF0uYmFja2dyb3VuZEhvdmVyfTtcbiAgICAgICAgICAgIGNvbG9yOiAke3RoZW1lLmNvbG9yc1tzZW50aW1lbnRdLnRleHRIb3Zlcn07XG4gICAgICAgICAgICBzdmcge1xuICAgICAgICAgICAgICBmaWxsOiAke3RoZW1lLmNvbG9yc1tzZW50aW1lbnRdLnRleHRIb3Zlcn07XG4gICAgICAgICAgICB9XG4gICAgICAgICAgfWBcbiAgfVxuICBgXG5cbmNvbnN0IENvbnRhaW5lciA9IHN0eWxlZCgnZGl2Jywge1xuICBzaG91bGRGb3J3YXJkUHJvcDogcHJvcCA9PiAhWydib3JkZXJsZXNzJ10uaW5jbHVkZXMocHJvcCksXG59KTx7IGJvcmRlcmxlc3M6IGJvb2xlYW4gfT5gXG4gICR7KHsgdGhlbWUsIGJvcmRlcmxlc3MgfSkgPT5cbiAgICBib3JkZXJsZXNzXG4gICAgICA/ICcnXG4gICAgICA6IGBib3JkZXItYm90dG9tOiAxcHggc29saWQgJHt0aGVtZS5jb2xvcnMubmV1dHJhbC5ib3JkZXJ9O2B9XG4gIHBhZGRpbmc6ICR7KHsgdGhlbWUsIGJvcmRlcmxlc3MgfSkgPT5cbiAgICBgJHtib3JkZXJsZXNzID8gdGhlbWUuc3BhY2VbJzAuMjUnXSA6IHRoZW1lLnNwYWNlWycwLjUnXX0gJHtcbiAgICAgIHRoZW1lLnNwYWNlWycwLjUnXVxuICAgIH1gfTtcbiAgJjpsYXN0LWNoaWxkIHtcbiAgICBib3JkZXI6IG5vbmU7XG4gIH1cbmBcblxuY29uc3QgU3R5bGVkSXRlbSA9IHN0eWxlZCgnYnV0dG9uJywge1xuICBzaG91bGRGb3J3YXJkUHJvcDogcHJvcCA9PiAhWydib3JkZXJsZXNzJywgJ3NlbnRpbWVudCddLmluY2x1ZGVzKHByb3ApLFxufSk8e1xuICBib3JkZXJsZXNzOiBib29sZWFuXG4gIGRpc2FibGVkOiBib29sZWFuXG4gIHNlbnRpbWVudDogTWVudUl0ZW1TZW50aW1lbnRcbn0+YFxuICAkeyh7IHRoZW1lLCBib3JkZXJsZXNzLCBzZW50aW1lbnQsIGRpc2FibGVkIH0pID0+XG4gICAgaXRlbUNvcmVTdHlsZSh7IHRoZW1lLCBib3JkZXJsZXNzLCBzZW50aW1lbnQsIGRpc2FibGVkIH0pfVxuICBiYWNrZ3JvdW5kOiBub25lO1xuYFxuXG5jb25zdCBTdHlsZWRMaW5rSXRlbSA9IHN0eWxlZCgnYScsIHtcbiAgc2hvdWxkRm9yd2FyZFByb3A6IHByb3AgPT4gIVsnYm9yZGVybGVzcycsICdzZW50aW1lbnQnXS5pbmNsdWRlcyhwcm9wKSxcbn0pPHtcbiAgYm9yZGVybGVzczogYm9vbGVhblxuICBkaXNhYmxlZDogYm9vbGVhblxuICBzZW50aW1lbnQ6IE1lbnVJdGVtU2VudGltZW50XG59PmBcbiAgJHsoeyB0aGVtZSwgYm9yZGVybGVzcywgc2VudGltZW50LCBkaXNhYmxlZCB9KSA9PlxuICAgIGl0ZW1Db3JlU3R5bGUoeyB0aGVtZSwgYm9yZGVybGVzcywgc2VudGltZW50LCBkaXNhYmxlZCB9KX1cbiAgdGV4dC1kZWNvcmF0aW9uOiBub25lO1xuXG4gICY6Zm9jdXMge1xuICAgIHRleHQtZGVjb3JhdGlvbjogbm9uZTtcbiAgfVxuYFxuXG50eXBlIEl0ZW1Qcm9wcyA9IHtcbiAgaHJlZj86IEhUTUxBbmNob3JFbGVtZW50WydocmVmJ11cbiAgdGFyZ2V0PzogSFRNTEFuY2hvckVsZW1lbnRbJ3RhcmdldCddXG4gIHJlbD86IEhUTUxBbmNob3JFbGVtZW50WydyZWwnXVxuICBkaXNhYmxlZD86IGJvb2xlYW4gfCB1bmRlZmluZWRcbiAgdG9vbHRpcD86IHN0cmluZyB8IHVuZGVmaW5lZFxuICBjbGFzc05hbWU/OiBzdHJpbmcgfCB1bmRlZmluZWRcbiAgY2hpbGRyZW46IFJlYWN0Tm9kZVxuICBvbkNsaWNrPzogTW91c2VFdmVudEhhbmRsZXI8SFRNTEVsZW1lbnQ+IHwgdW5kZWZpbmVkXG4gIGJvcmRlcmxlc3M/OiBib29sZWFuXG4gIHNlbnRpbWVudD86IE1lbnVJdGVtU2VudGltZW50XG4gIGFjdGl2ZT86IGJvb2xlYW5cbiAgJ2RhdGEtdGVzdGlkJz86IHN0cmluZ1xuICAvKipcbiAgICogSWYgeW91IGNoaWxkcmVuIGlzIGNvbXBsZXggYW5kIHlvdSB3YW50IHRvIHNwZWNpZnkgdGhlIHNlYXJjaCB0ZXh0IHVzZSB0aGlzIHByb3AuXG4gICAqL1xuICBzZWFyY2hUZXh0Pzogc3RyaW5nXG59XG5cbmNvbnN0IEl0ZW0gPSBmb3J3YXJkUmVmPEhUTUxFbGVtZW50LCBJdGVtUHJvcHM+KFxuICAoXG4gICAge1xuICAgICAgYm9yZGVybGVzcyA9IGZhbHNlLFxuICAgICAgZGlzYWJsZWQgPSBmYWxzZSxcbiAgICAgIG9uQ2xpY2ssXG4gICAgICBzZW50aW1lbnQgPSAnbmV1dHJhbCcsXG4gICAgICBocmVmLFxuICAgICAgdGFyZ2V0LFxuICAgICAgcmVsLFxuICAgICAgY2hpbGRyZW4sXG4gICAgICB0b29sdGlwLFxuICAgICAgYWN0aXZlLFxuICAgICAgY2xhc3NOYW1lLFxuICAgICAgc2VhcmNoVGV4dCxcbiAgICAgICdkYXRhLXRlc3RpZCc6IGRhdGFUZXN0SWQsXG4gICAgfSxcbiAgICByZWYsXG4gICkgPT4ge1xuICAgIGNvbnN0IHsgaGlkZU9uQ2xpY2tJdGVtLCBzZXRJc1Zpc2libGUgfSA9IHVzZU1lbnUoKVxuXG4gICAgY29uc3Qgb25DbGlja0hhbmRsZSA9IHVzZUNhbGxiYWNrKFxuICAgICAgKGV2ZW50OiBNb3VzZUV2ZW50PEhUTUxBbmNob3JFbGVtZW50PikgPT4ge1xuICAgICAgICBpZiAoZGlzYWJsZWQpIHJldHVybiB1bmRlZmluZWRcbiAgICAgICAgb25DbGljaz8uKGV2ZW50KVxuICAgICAgICBpZiAoaGlkZU9uQ2xpY2tJdGVtKSB7XG4gICAgICAgICAgc2V0SXNWaXNpYmxlKGZhbHNlKVxuICAgICAgICB9XG5cbiAgICAgICAgcmV0dXJuIHVuZGVmaW5lZFxuICAgICAgfSxcbiAgICAgIFtkaXNhYmxlZCwgaGlkZU9uQ2xpY2tJdGVtLCBvbkNsaWNrLCBzZXRJc1Zpc2libGVdLFxuICAgIClcblxuICAgIGlmIChocmVmICYmICFkaXNhYmxlZCkge1xuICAgICAgcmV0dXJuIChcbiAgICAgICAgPENvbnRhaW5lciBib3JkZXJsZXNzPXtib3JkZXJsZXNzfSBkYXRhLXNlYXJjaC10ZXh0PXtzZWFyY2hUZXh0fT5cbiAgICAgICAgICA8VG9vbHRpcCB0ZXh0PXt0b29sdGlwfT5cbiAgICAgICAgICAgIDxTdHlsZWRMaW5rSXRlbVxuICAgICAgICAgICAgICBkYXRhLWFjdGl2ZT17YWN0aXZlfVxuICAgICAgICAgICAgICBib3JkZXJsZXNzXG4gICAgICAgICAgICAgIGhyZWY9e2hyZWZ9XG4gICAgICAgICAgICAgIHRhcmdldD17dGFyZ2V0fVxuICAgICAgICAgICAgICByZWw9e3JlbH1cbiAgICAgICAgICAgICAgcmVmPXtyZWYgYXMgUmVmPEhUTUxBbmNob3JFbGVtZW50Pn1cbiAgICAgICAgICAgICAgb25DbGljaz17b25DbGlja0hhbmRsZX1cbiAgICAgICAgICAgICAgcm9sZT1cIm1lbnVpdGVtXCJcbiAgICAgICAgICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAgICAgICBzZW50aW1lbnQ9e3NlbnRpbWVudH1cbiAgICAgICAgICAgICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gICAgICAgICAgICAgIGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfVxuICAgICAgICAgICAgPlxuICAgICAgICAgICAgICB7Y2hpbGRyZW59XG4gICAgICAgICAgICA8L1N0eWxlZExpbmtJdGVtPlxuICAgICAgICAgIDwvVG9vbHRpcD5cbiAgICAgICAgPC9Db250YWluZXI+XG4gICAgICApXG4gICAgfVxuXG4gICAgcmV0dXJuIChcbiAgICAgIDxDb250YWluZXIgYm9yZGVybGVzcz17Ym9yZGVybGVzc30gZGF0YS1zZWFyY2gtdGV4dD17c2VhcmNoVGV4dH0+XG4gICAgICAgIDxUb29sdGlwIHRleHQ9e3Rvb2x0aXB9PlxuICAgICAgICAgIDxTdHlsZWRJdGVtXG4gICAgICAgICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgICAgICAgIHJlZj17cmVmIGFzIFJlZjxIVE1MQnV0dG9uRWxlbWVudD59XG4gICAgICAgICAgICByb2xlPVwibWVudWl0ZW1cIlxuICAgICAgICAgICAgZGlzYWJsZWQ9e2Rpc2FibGVkfVxuICAgICAgICAgICAgb25DbGljaz17ZXZlbnQgPT4ge1xuICAgICAgICAgICAgICBvbkNsaWNrPy4oZXZlbnQpXG4gICAgICAgICAgICAgIGlmIChoaWRlT25DbGlja0l0ZW0pIHtcbiAgICAgICAgICAgICAgICBzZXRJc1Zpc2libGUoZmFsc2UpXG4gICAgICAgICAgICAgIH1cbiAgICAgICAgICAgIH19XG4gICAgICAgICAgICBib3JkZXJsZXNzPXtib3JkZXJsZXNzfVxuICAgICAgICAgICAgc2VudGltZW50PXtzZW50aW1lbnR9XG4gICAgICAgICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgICAgICAgIGRhdGEtdGVzdGlkPXtkYXRhVGVzdElkfVxuICAgICAgICAgICAgZGF0YS1hY3RpdmU9e2FjdGl2ZX1cbiAgICAgICAgICA+XG4gICAgICAgICAgICB7Y2hpbGRyZW59XG4gICAgICAgICAgPC9TdHlsZWRJdGVtPlxuICAgICAgICA8L1Rvb2x0aXA+XG4gICAgICA8L0NvbnRhaW5lcj5cbiAgICApXG4gIH0sXG4pXG5cbmV4cG9ydCBkZWZhdWx0IEl0ZW1cbiJdfQ== */"));
96
+ }), " text-decoration:none;&:focus{text-decoration:none;}" + (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/Menu/components/Item.tsx"],"names":[],"mappings":"AAmGE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/ui/src/components/Menu/components/Item.tsx","sourcesContent":["'use client'\n\nimport type { Theme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { ArrowRightIcon } from '@ultraviolet/icons'\nimport type { MouseEvent, MouseEventHandler, ReactNode, Ref } from 'react'\nimport { forwardRef, useCallback } from 'react'\nimport { Stack } from '../../Stack'\nimport { Tooltip } from '../../Tooltip'\nimport { useDisclosureContext, useMenu } from '../MenuProvider'\n\ntype MenuItemSentiment = 'neutral' | 'primary' | 'danger'\n\nconst ANIMATION_DURATION = 200 // in ms\n\nconst itemCoreStyle = ({\n  theme,\n  sentiment,\n  disabled,\n}: {\n  theme: Theme\n  borderless: boolean\n  sentiment: MenuItemSentiment\n  disabled: boolean\n}) => `\n  display: flex;\n  justify-content: start;\n  text-align: left;\n  align-items: center;\n  min-height: ${theme.sizing['400']};\n  max-height: ${theme.sizing['500']};\n  font-size: ${theme.typography.bodySmall.fontSize};\n  line-height: ${theme.typography.bodySmall.lineHeight};\n  font-weight: inherit;\n  padding: ${`${theme.space['0.5']} ${theme.space['1']}`};\n  border: none;\n  cursor: pointer;\n  min-width: 6.875rem;\n  width: 100%;\n  border-radius: ${theme.radii.default};\n  transition: background-color ${ANIMATION_DURATION}ms, color ${ANIMATION_DURATION}ms;\n\n  color: ${theme.colors[sentiment][disabled ? 'textDisabled' : 'text']};\n  svg {\n    fill: ${theme.colors[sentiment][disabled ? 'textDisabled' : 'text']};\n  }\n\n  ${\n    disabled\n      ? `\n        cursor: not-allowed;\n      `\n      : `\n          &:hover,\n          &:focus, &[data-active='true'] {\n            background-color: ${theme.colors[sentiment].backgroundHover};\n            color: ${theme.colors[sentiment].textHover};\n            svg {\n              fill: ${theme.colors[sentiment].textHover};\n            }\n          }`\n  }\n`\n\nconst Container = styled('div', {\n  shouldForwardProp: prop => !['borderless'].includes(prop),\n})<{ borderless: boolean }>`\n  ${({ theme, borderless }) =>\n    borderless\n      ? ''\n      : `border-bottom: 1px solid ${theme.colors.neutral.border};`}\n  padding: ${({ theme, borderless }) =>\n    `${borderless ? theme.space['0.25'] : theme.space['0.5']} ${\n      theme.space['0.5']\n    }`};\n  &:last-child {\n    border: none;\n  }\n  width: 100%;\n`\n\nconst StyledItem = styled('button', {\n  shouldForwardProp: prop => !['borderless', 'sentiment'].includes(prop),\n})<{\n  borderless: boolean\n  disabled: boolean\n  sentiment: MenuItemSentiment\n}>`\n  ${({ theme, borderless, sentiment, disabled }) =>\n    itemCoreStyle({ theme, borderless, sentiment, disabled })}\n  background: none;\n`\n\nconst StyledLinkItem = styled('a', {\n  shouldForwardProp: prop => !['borderless', 'sentiment'].includes(prop),\n})<{\n  borderless: boolean\n  disabled: boolean\n  sentiment: MenuItemSentiment\n}>`\n  ${({ theme, borderless, sentiment, disabled }) =>\n    itemCoreStyle({ theme, borderless, sentiment, disabled })}\n  text-decoration: none;\n\n  &:focus {\n    text-decoration: none;\n  }\n`\n\ntype ItemProps = {\n  href?: HTMLAnchorElement['href']\n  target?: HTMLAnchorElement['target']\n  rel?: HTMLAnchorElement['rel']\n  disabled?: boolean | undefined\n  tooltip?: string | undefined\n  className?: string | undefined\n  children: ReactNode\n  onClick?: MouseEventHandler<HTMLElement> | undefined\n  borderless?: boolean\n  sentiment?: MenuItemSentiment\n  active?: boolean\n  'data-testid'?: string\n  /**\n   * If you children is complex and you want to specify the search text use this prop.\n   */\n  searchText?: string\n}\n\nconst Item = forwardRef<HTMLElement, ItemProps>(\n  (\n    {\n      borderless = false,\n      disabled = false,\n      onClick,\n      sentiment = 'neutral',\n      href,\n      target,\n      rel,\n      children,\n      tooltip,\n      active,\n      className,\n      searchText,\n      'data-testid': dataTestId,\n    },\n    ref,\n  ) => {\n    const { hideOnClickItem, setIsVisible, isVisible } = useMenu()\n    const isDisclosure = useDisclosureContext()\n\n    const onClickHandle = useCallback(\n      (event: MouseEvent<HTMLAnchorElement>) => {\n        if (disabled) return undefined\n        onClick?.(event)\n        if (hideOnClickItem) {\n          setIsVisible(false)\n        }\n\n        return undefined\n      },\n      [disabled, hideOnClickItem, onClick, setIsVisible],\n    )\n\n    if (href && !disabled) {\n      return (\n        <Container borderless={borderless} data-search-text={searchText}>\n          <Tooltip text={tooltip}>\n            <StyledLinkItem\n              data-active={active}\n              borderless\n              href={href}\n              target={target}\n              rel={rel}\n              ref={ref as Ref<HTMLAnchorElement>}\n              onClick={onClickHandle}\n              role=\"menuitem\"\n              disabled={disabled}\n              sentiment={sentiment}\n              className={className}\n              data-testid={dataTestId}\n            >\n              {isDisclosure ? (\n                <Stack\n                  justifyContent=\"space-between\"\n                  direction=\"row\"\n                  width=\"100%\"\n                  alignItems=\"center\"\n                >\n                  {children} <ArrowRightIcon />\n                </Stack>\n              ) : (\n                children\n              )}\n            </StyledLinkItem>\n          </Tooltip>\n        </Container>\n      )\n    }\n\n    return (\n      <Container borderless={borderless} data-search-text={searchText}>\n        <Tooltip text={tooltip}>\n          <StyledItem\n            type=\"button\"\n            ref={ref as Ref<HTMLButtonElement>}\n            role=\"menuitem\"\n            disabled={disabled}\n            onClick={event => {\n              onClick?.(event)\n              if (hideOnClickItem) {\n                setIsVisible(false)\n              }\n            }}\n            borderless={borderless}\n            sentiment={sentiment}\n            className={className}\n            data-testid={dataTestId}\n            data-active={active || (isVisible && isDisclosure)}\n          >\n            {isDisclosure ? (\n              <Stack\n                justifyContent=\"space-between\"\n                direction=\"row\"\n                width=\"100%\"\n                alignItems=\"center\"\n              >\n                {children} <ArrowRightIcon />\n              </Stack>\n            ) : (\n              children\n            )}\n          </StyledItem>\n        </Tooltip>\n      </Container>\n    )\n  },\n)\n\nexport default Item\n"]} */"));
95
97
  const Item = forwardRef(({
96
98
  borderless = false,
97
99
  disabled = false,
@@ -109,8 +111,10 @@ const Item = forwardRef(({
109
111
  }, ref) => {
110
112
  const {
111
113
  hideOnClickItem,
112
- setIsVisible
114
+ setIsVisible,
115
+ isVisible
113
116
  } = useMenu();
117
+ const isDisclosure = useDisclosureContext();
114
118
  const onClickHandle = useCallback((event) => {
115
119
  if (disabled) return void 0;
116
120
  onClick?.(event);
@@ -120,14 +124,22 @@ const Item = forwardRef(({
120
124
  return void 0;
121
125
  }, [disabled, hideOnClickItem, onClick, setIsVisible]);
122
126
  if (href && !disabled) {
123
- return /* @__PURE__ */ jsx(Container, { borderless, "data-search-text": searchText, children: /* @__PURE__ */ jsx(Tooltip, { text: tooltip, children: /* @__PURE__ */ jsx(StyledLinkItem, { "data-active": active, borderless: true, href, target, rel, ref, onClick: onClickHandle, role: "menuitem", disabled, sentiment, className, "data-testid": dataTestId, children }) }) });
127
+ return /* @__PURE__ */ jsx(Container, { borderless, "data-search-text": searchText, children: /* @__PURE__ */ jsx(Tooltip, { text: tooltip, children: /* @__PURE__ */ jsx(StyledLinkItem, { "data-active": active, borderless: true, href, target, rel, ref, onClick: onClickHandle, role: "menuitem", disabled, sentiment, className, "data-testid": dataTestId, children: isDisclosure ? /* @__PURE__ */ jsxs(Stack, { justifyContent: "space-between", direction: "row", width: "100%", alignItems: "center", children: [
128
+ children,
129
+ " ",
130
+ /* @__PURE__ */ jsx(ArrowRightIcon, {})
131
+ ] }) : children }) }) });
124
132
  }
125
133
  return /* @__PURE__ */ jsx(Container, { borderless, "data-search-text": searchText, children: /* @__PURE__ */ jsx(Tooltip, { text: tooltip, children: /* @__PURE__ */ jsx(StyledItem, { type: "button", ref, role: "menuitem", disabled, onClick: (event) => {
126
134
  onClick?.(event);
127
135
  if (hideOnClickItem) {
128
136
  setIsVisible(false);
129
137
  }
130
- }, borderless, sentiment, className, "data-testid": dataTestId, "data-active": active, children }) }) });
138
+ }, borderless, sentiment, className, "data-testid": dataTestId, "data-active": active || isVisible && isDisclosure, children: isDisclosure ? /* @__PURE__ */ jsxs(Stack, { justifyContent: "space-between", direction: "row", width: "100%", alignItems: "center", children: [
139
+ children,
140
+ " ",
141
+ /* @__PURE__ */ jsx(ArrowRightIcon, {})
142
+ ] }) : children }) }) });
131
143
  });
132
144
  export {
133
145
  Item as default
@@ -19,6 +19,9 @@ const searchChildren = (children, searchString) => {
19
19
  children: searchChildren(childProps.children, searchString)
20
20
  });
21
21
  }
22
+ if (childProps.disclosure && typeof childProps.disclosure.props.children === "string" && childProps.disclosure.props.children.match(searchRegex)) {
23
+ return child;
24
+ }
22
25
  const childMatches = searchChildren(childProps.children, searchString);
23
26
  if (childMatches.length > 0) {
24
27
  return child;
@@ -17,6 +17,9 @@ const searchChildren = (children, searchString) => {
17
17
  children: searchChildren(childProps.children, searchString)
18
18
  });
19
19
  }
20
+ if (childProps.disclosure && typeof childProps.disclosure.props.children === "string" && childProps.disclosure.props.children.match(searchRegex)) {
21
+ return child;
22
+ }
20
23
  const childMatches = searchChildren(childProps.children, searchString);
21
24
  if (childMatches.length > 0) {
22
25
  return child;
@@ -20,6 +20,7 @@ export declare const Menu: import("react").ForwardRefExoticComponent<{
20
20
  searchable?: boolean;
21
21
  hideOnClickItem?: boolean;
22
22
  footer?: import("react").ReactNode;
23
+ placement?: Exclude<import("react").ComponentProps<typeof import("..").Popup>["placement"], "nested-menu">;
23
24
  } & Pick<{
24
25
  id?: string;
25
26
  children: import("react").ReactNode | ((renderProps: {
@@ -52,7 +53,7 @@ export declare const Menu: import("react").ForwardRefExoticComponent<{
52
53
  disableAnimation?: boolean;
53
54
  portalTarget?: HTMLElement;
54
55
  dynamicDomRendering?: boolean;
55
- } & import("react").RefAttributes<HTMLDivElement>, "placement" | "align" | "dynamicDomRendering"> & import("react").RefAttributes<HTMLButtonElement>> & {
56
+ } & import("react").RefAttributes<HTMLDivElement>, "align" | "dynamicDomRendering"> & import("react").RefAttributes<HTMLButtonElement>> & {
56
57
  Item: import("react").ForwardRefExoticComponent<{
57
58
  href?: HTMLAnchorElement["href"];
58
59
  target?: HTMLAnchorElement["target"];
@@ -48,5 +48,6 @@ export type MenuProps = {
48
48
  */
49
49
  hideOnClickItem?: boolean;
50
50
  footer?: ReactNode;
51
- } & Pick<ComponentProps<typeof Popup>, 'placement' | 'dynamicDomRendering' | 'align'>;
51
+ placement?: Exclude<ComponentProps<typeof Popup>['placement'], 'nested-menu'>;
52
+ } & Pick<ComponentProps<typeof Popup>, 'dynamicDomRendering' | 'align'>;
52
53
  export {};
@@ -8,16 +8,16 @@ const Disclosure = ({
8
8
  visible,
9
9
  handleClose,
10
10
  toggle,
11
- id
11
+ id,
12
+ ref
12
13
  }) => {
13
- const disclosureRef = react.createRef();
14
14
  react.useEffect(() => {
15
- const element = disclosureRef.current;
15
+ const element = ref.current;
16
16
  element?.addEventListener("click", handleOpen);
17
17
  return () => {
18
18
  element?.removeEventListener("click", handleOpen);
19
19
  };
20
- }, [handleOpen, disclosureRef]);
20
+ }, [handleOpen, ref]);
21
21
  const finalDisclosure = react.useMemo(() => {
22
22
  if (typeof disclosure === "function") {
23
23
  return disclosure({
@@ -37,7 +37,7 @@ const Disclosure = ({
37
37
  return null;
38
38
  }
39
39
  return react.cloneElement(finalDisclosure, {
40
- ref: disclosureRef,
40
+ ref,
41
41
  "aria-controls": id,
42
42
  "aria-haspopup": "dialog"
43
43
  });
@@ -1,2 +1,2 @@
1
1
  import type { DisclosureProps } from '../types';
2
- export declare const Disclosure: ({ disclosure, handleOpen, visible, handleClose, toggle, id, }: DisclosureProps) => import("react").ReactElement<unknown, string | import("react").JSXElementConstructor<any>> | null;
2
+ export declare const Disclosure: ({ disclosure, handleOpen, visible, handleClose, toggle, id, ref, }: DisclosureProps) => import("react").ReactElement<unknown, string | import("react").JSXElementConstructor<any>> | null;
@@ -1,21 +1,21 @@
1
1
  "use client";
2
- import { createRef, useEffect, useMemo, isValidElement, cloneElement } from "react";
2
+ import { useEffect, useMemo, isValidElement, cloneElement } from "react";
3
3
  const Disclosure = ({
4
4
  disclosure,
5
5
  handleOpen,
6
6
  visible,
7
7
  handleClose,
8
8
  toggle,
9
- id
9
+ id,
10
+ ref
10
11
  }) => {
11
- const disclosureRef = createRef();
12
12
  useEffect(() => {
13
- const element = disclosureRef.current;
13
+ const element = ref.current;
14
14
  element?.addEventListener("click", handleOpen);
15
15
  return () => {
16
16
  element?.removeEventListener("click", handleOpen);
17
17
  };
18
- }, [handleOpen, disclosureRef]);
18
+ }, [handleOpen, ref]);
19
19
  const finalDisclosure = useMemo(() => {
20
20
  if (typeof disclosure === "function") {
21
21
  return disclosure({
@@ -35,7 +35,7 @@ const Disclosure = ({
35
35
  return null;
36
36
  }
37
37
  return cloneElement(finalDisclosure, {
38
- ref: disclosureRef,
38
+ ref,
39
39
  "aria-controls": id,
40
40
  "aria-haspopup": "dialog"
41
41
  });
@@ -31,10 +31,12 @@ const Modal = ({
31
31
  }) => {
32
32
  const [visible, setVisible] = react.useState(false);
33
33
  const controlId = react.useId();
34
+ const disclosureRef = react.useRef(null);
34
35
  const handleOpen = react.useCallback(() => {
35
36
  setVisible(true);
36
37
  }, []);
37
38
  const handleClose = react.useCallback(() => {
39
+ disclosureRef.current?.focus();
38
40
  if (onClose) {
39
41
  onClose();
40
42
  } else {
@@ -46,13 +48,14 @@ const Modal = ({
46
48
  }
47
49
  }, [onBeforeClose, onClose]);
48
50
  const handleToggle = react.useCallback(() => {
51
+ disclosureRef.current?.focus();
49
52
  setVisible((current) => !current);
50
53
  }, []);
51
54
  const finalId = id ?? controlId;
52
55
  const finalSize = size ?? width;
53
56
  const context = react.useContext(ModalProvider.ModalContext);
54
57
  return /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
55
- disclosure ? /* @__PURE__ */ jsxRuntime.jsx(Disclosure.Disclosure, { id: finalId, handleOpen, disclosure, handleClose, visible, toggle: handleToggle }) : null,
58
+ disclosure ? /* @__PURE__ */ jsxRuntime.jsx(Disclosure.Disclosure, { id: finalId, handleOpen, disclosure, handleClose, visible, toggle: handleToggle, ref: disclosureRef }) : null,
56
59
  !context ? /* @__PURE__ */ jsxRuntime.jsx(ModalProvider.ModalProvider, { children: /* @__PURE__ */ jsxRuntime.jsx(ModalContent.ModalContent, { open, opened, visible, placement, finalSize, ariaLabel, hideOnClickOutside, hideOnEsc, preventBodyScroll, handleClose, className, backdropClassName, dataTestId, customDialogStyles, customDialogBackdropStyles, isClosable, handleOpen, handleToggle, finalId, image, children }) }) : /* @__PURE__ */ jsxRuntime.jsx(ModalContent.ModalContent, { open, opened, visible, placement, finalSize, ariaLabel, hideOnClickOutside, hideOnEsc, preventBodyScroll, handleClose, className, backdropClassName, dataTestId, customDialogStyles, customDialogBackdropStyles, isClosable, handleOpen, handleToggle, finalId, image, children })
57
60
  ] });
58
61
  };
@@ -1,6 +1,6 @@
1
1
  "use client";
2
2
  import { jsxs, Fragment, jsx } from "@emotion/react/jsx-runtime";
3
- import { useState, useId, useCallback, useContext } from "react";
3
+ import { useState, useId, useRef, useCallback, useContext } from "react";
4
4
  import { ModalContent } from "./ModalContent.js";
5
5
  import { ModalContext, ModalProvider } from "./ModalProvider.js";
6
6
  import { Disclosure } from "./components/Disclosure.js";
@@ -29,10 +29,12 @@ const Modal = ({
29
29
  }) => {
30
30
  const [visible, setVisible] = useState(false);
31
31
  const controlId = useId();
32
+ const disclosureRef = useRef(null);
32
33
  const handleOpen = useCallback(() => {
33
34
  setVisible(true);
34
35
  }, []);
35
36
  const handleClose = useCallback(() => {
37
+ disclosureRef.current?.focus();
36
38
  if (onClose) {
37
39
  onClose();
38
40
  } else {
@@ -44,13 +46,14 @@ const Modal = ({
44
46
  }
45
47
  }, [onBeforeClose, onClose]);
46
48
  const handleToggle = useCallback(() => {
49
+ disclosureRef.current?.focus();
47
50
  setVisible((current) => !current);
48
51
  }, []);
49
52
  const finalId = id ?? controlId;
50
53
  const finalSize = size ?? width;
51
54
  const context = useContext(ModalContext);
52
55
  return /* @__PURE__ */ jsxs(Fragment, { children: [
53
- disclosure ? /* @__PURE__ */ jsx(Disclosure, { id: finalId, handleOpen, disclosure, handleClose, visible, toggle: handleToggle }) : null,
56
+ disclosure ? /* @__PURE__ */ jsx(Disclosure, { id: finalId, handleOpen, disclosure, handleClose, visible, toggle: handleToggle, ref: disclosureRef }) : null,
54
57
  !context ? /* @__PURE__ */ jsx(ModalProvider, { children: /* @__PURE__ */ jsx(ModalContent, { open, opened, visible, placement, finalSize, ariaLabel, hideOnClickOutside, hideOnEsc, preventBodyScroll, handleClose, className, backdropClassName, dataTestId, customDialogStyles, customDialogBackdropStyles, isClosable, handleOpen, handleToggle, finalId, image, children }) }) : /* @__PURE__ */ jsx(ModalContent, { open, opened, visible, placement, finalSize, ariaLabel, hideOnClickOutside, hideOnEsc, preventBodyScroll, handleClose, className, backdropClassName, dataTestId, customDialogStyles, customDialogBackdropStyles, isClosable, handleOpen, handleToggle, finalId, image, children })
55
58
  ] });
56
59
  };
@@ -1,4 +1,4 @@
1
- import type { ReactElement, ReactNode } from 'react';
1
+ import type { ReactElement, ReactNode, RefObject } from 'react';
2
2
  import type React from 'react';
3
3
  export type ModalSize = 'large' | 'medium' | 'small' | 'xsmall' | 'xxsmall';
4
4
  export type ModalPlacement = 'bottom' | 'bottom-left' | 'bottom-right' | 'center' | 'top' | 'top-left' | 'top-right' | 'right' | 'left';
@@ -28,6 +28,7 @@ export type DisclosureProps = {
28
28
  visible: ModalState['visible'];
29
29
  toggle: ModalState['toggle'];
30
30
  id: string;
31
+ ref: RefObject<HTMLDivElement | null>;
31
32
  };
32
33
  export type DialogProps = {
33
34
  ariaLabel?: string;