@flodesk/grain 11.50.0 → 11.51.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -19,14 +19,14 @@ const Wrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production
19
19
  } : {
20
20
  target: "e1fb3cwm1",
21
21
  label: "Wrapper"
22
- })("--padding:2px;display:flex;border-radius:", getRadius('s'), ";padding:var(--padding);background:hsl(var(--shade-h) var(--fade-s) var(--fade-l) / 7%);", p => !p.hasFullWidth && "width: fit-content", ";", p => p.hasFullWidth && "\n .TextToggle {\n flex: 1 0 0;\n }\n ", ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL3RleHQtdG9nZ2xlLmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFNMEIiLCJmaWxlIjoiLi4vLi4vc3JjL2NvbXBvbmVudHMvdGV4dC10b2dnbGUuanN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZ2V0Q29sb3IsIGdldFJhZGl1cyB9IGZyb20gJy4uL3V0aWxpdGllcyc7XG5pbXBvcnQgUmVhY3QsIHsgZm9yd2FyZFJlZiB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgeyBzdHlsZXMgfSBmcm9tICcuLi9mb3VuZGF0aW9uYWwnO1xuXG5jb25zdCBXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgLS1wYWRkaW5nOiAycHg7XG5cbiAgZGlzcGxheTogZmxleDtcbiAgYm9yZGVyLXJhZGl1czogJHtnZXRSYWRpdXMoJ3MnKX07XG4gIHBhZGRpbmc6IHZhcigtLXBhZGRpbmcpO1xuICBiYWNrZ3JvdW5kOiBoc2wodmFyKC0tc2hhZGUtaCkgdmFyKC0tZmFkZS1zKSB2YXIoLS1mYWRlLWwpIC8gNyUpO1xuXG4gICR7cCA9PiAhcC5oYXNGdWxsV2lkdGggJiYgYHdpZHRoOiBmaXQtY29udGVudGB9O1xuICAke3AgPT5cbiAgICBwLmhhc0Z1bGxXaWR0aCAmJlxuICAgIGBcbiAgICAuVGV4dFRvZ2dsZSB7XG4gICAgICBmbGV4OiAxIDAgMDtcbiAgICB9XG4gIGB9XG5gO1xuXG5jb25zdCBJdGVtV3JhcHBlciA9IHN0eWxlZC5idXR0b25gXG4gICR7c3R5bGVzLmJ1dHRvblJlc2V0fTtcbiAgLS1ib3JkZXJDb2xvcjogdHJhbnNwYXJlbnQ7XG4gIC0taGVpZ2h0OiBjYWxjKHZhcigtLWdybi10ZXh0Ym94LWhlaWdodC1tKSAtIHZhcigtLXBhZGRpbmcpICogMik7XG5cbiAgYm9yZGVyOiBub25lO1xuICBwYWRkaW5nOiAwIHZhcigtLWdybi1zcGFjZS1zMik7XG4gIGhlaWdodDogdmFyKC0taGVpZ2h0KTtcbiAgYmFja2dyb3VuZC1jb2xvcjogdHJhbnNwYXJlbnQ7XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgY29sb3I6IHZhcigtLWdybi1jb2xvci1jb250ZW50Mik7XG4gIGJvcmRlci1yYWRpdXM6IGNhbGMoJHtnZXRSYWRpdXMoJ3MnKX0gLSB2YXIoLS1wYWRkaW5nKSk7XG4gIHdoaXRlLXNwYWNlOiBub3dyYXA7XG4gIHRyYW5zaXRpb246IHZhcigtLWdybi10cmFuc2l0aW9uLWxlYXZlKTtcblxuICAmOmhvdmVyIHtcbiAgICBjb2xvcjogdmFyKC0tZ3JuLWNvbG9yLWNvbnRlbnQpO1xuICAgIHRyYW5zaXRpb246IHZhcigtLWdybi10cmFuc2l0aW9uLWhvdmVyKTtcbiAgfVxuXG4gICR7cCA9PlxuICAgIHAuaXNBY3RpdmUgJiZcbiAgICBgXG4gICAgLS1ib3JkZXJDb2xvcjogJHtnZXRDb2xvcignc2hhZGU5Jyl9O1xuICAgIGNvbG9yOiB2YXIoLS1ncm4tY29sb3ItY29udGVudCk7XG4gICAgdHJhbnNpdGlvbjogdmFyKC0tZ3JuLXRyYW5zaXRpb24tYWN0aXZlKTtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2dldENvbG9yKCdzaGFkZTEnKX07XG5cbiAgICAmOmhvdmVyIHtcbiAgICAgIHRyYW5zaXRpb246IHZhcigtLWdybi10cmFuc2l0aW9uLWFjdGl2ZSk7XG4gICAgfVxuICBgfVxuYDtcblxuZXhwb3J0IGNvbnN0IFRleHRUb2dnbGUgPSBmb3J3YXJkUmVmKCh7IGNoaWxkcmVuLCBpc0FjdGl2ZSwgb25DbGljaywgLi4ucHJvcHMgfSwgcmVmKSA9PiB7XG4gIHJldHVybiAoXG4gICAgPEl0ZW1XcmFwcGVyXG4gICAgICByZWY9e3JlZn1cbiAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgaXNBY3RpdmU9e2lzQWN0aXZlfVxuICAgICAgb25DbGljaz17b25DbGlja31cbiAgICAgIGNsYXNzTmFtZT1cIlRleHRUb2dnbGVcIlxuICAgICAgey4uLnByb3BzfVxuICAgID5cbiAgICAgIHtjaGlsZHJlbn1cbiAgICA8L0l0ZW1XcmFwcGVyPlxuICApO1xufSk7XG5cbmV4cG9ydCBjb25zdCBUZXh0VG9nZ2xlR3JvdXAgPSBmb3J3YXJkUmVmKCh7IGNoaWxkcmVuLCBoYXNGdWxsV2lkdGgsIC4uLnByb3BzIH0sIHJlZikgPT4gKFxuICA8V3JhcHBlciByZWY9e3JlZn0gaGFzRnVsbFdpZHRoPXtoYXNGdWxsV2lkdGh9IHsuLi5wcm9wc30+XG4gICAge2NoaWxkcmVufVxuICA8L1dyYXBwZXI+XG4pKTtcblxuVGV4dFRvZ2dsZUdyb3VwLnByb3BUeXBlcyA9IHtcbiAgY2hpbGRyZW46IFByb3BUeXBlcy5ub2RlLFxuICBoYXNGdWxsV2lkdGg6IFByb3BUeXBlcy5ib29sLFxufTtcblxuVGV4dFRvZ2dsZS5wcm9wVHlwZXMgPSB7XG4gIGNoaWxkcmVuOiBQcm9wVHlwZXMubm9kZSxcbiAgaXNBY3RpdmU6IFByb3BUeXBlcy5ib29sLFxuICBvbkNsaWNrOiBQcm9wVHlwZXMuZnVuYyxcbn07XG4iXX0= */"));
22
+ })("--padding:2px;display:flex;border-radius:", getRadius('s'), ";padding:var(--padding);background:var(--grn-color-overlay);", p => !p.hasFullWidth && "width: fit-content", ";", p => p.hasFullWidth && "\n .TextToggle {\n flex: 1 0 0;\n }\n ", ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL3RleHQtdG9nZ2xlLmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFNMEIiLCJmaWxlIjoiLi4vLi4vc3JjL2NvbXBvbmVudHMvdGV4dC10b2dnbGUuanN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZ2V0Q29sb3IsIGdldFJhZGl1cyB9IGZyb20gJy4uL3V0aWxpdGllcyc7XG5pbXBvcnQgUmVhY3QsIHsgZm9yd2FyZFJlZiB9IGZyb20gJ3JlYWN0JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkJztcbmltcG9ydCBQcm9wVHlwZXMgZnJvbSAncHJvcC10eXBlcyc7XG5pbXBvcnQgeyBzdHlsZXMgfSBmcm9tICcuLi9mb3VuZGF0aW9uYWwnO1xuXG5jb25zdCBXcmFwcGVyID0gc3R5bGVkLmRpdmBcbiAgLS1wYWRkaW5nOiAycHg7XG5cbiAgZGlzcGxheTogZmxleDtcbiAgYm9yZGVyLXJhZGl1czogJHtnZXRSYWRpdXMoJ3MnKX07XG4gIHBhZGRpbmc6IHZhcigtLXBhZGRpbmcpO1xuICBiYWNrZ3JvdW5kOiB2YXIoLS1ncm4tY29sb3Itb3ZlcmxheSk7XG5cbiAgJHtwID0+ICFwLmhhc0Z1bGxXaWR0aCAmJiBgd2lkdGg6IGZpdC1jb250ZW50YH07XG4gICR7cCA9PlxuICAgIHAuaGFzRnVsbFdpZHRoICYmXG4gICAgYFxuICAgIC5UZXh0VG9nZ2xlIHtcbiAgICAgIGZsZXg6IDEgMCAwO1xuICAgIH1cbiAgYH1cbmA7XG5cbmNvbnN0IEl0ZW1XcmFwcGVyID0gc3R5bGVkLmJ1dHRvbmBcbiAgJHtzdHlsZXMuYnV0dG9uUmVzZXR9O1xuICAtLWJvcmRlckNvbG9yOiB0cmFuc3BhcmVudDtcbiAgLS1oZWlnaHQ6IGNhbGModmFyKC0tZ3JuLXRleHRib3gtaGVpZ2h0LW0pIC0gdmFyKC0tcGFkZGluZykgKiAyKTtcblxuICBib3JkZXI6IG5vbmU7XG4gIHBhZGRpbmc6IDAgdmFyKC0tZ3JuLXNwYWNlLXMyKTtcbiAgaGVpZ2h0OiB2YXIoLS1oZWlnaHQpO1xuICBiYWNrZ3JvdW5kLWNvbG9yOiB0cmFuc3BhcmVudDtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICBjb2xvcjogdmFyKC0tZ3JuLWNvbG9yLWNvbnRlbnQyKTtcbiAgYm9yZGVyLXJhZGl1czogY2FsYygke2dldFJhZGl1cygncycpfSAtIHZhcigtLXBhZGRpbmcpKTtcbiAgd2hpdGUtc3BhY2U6IG5vd3JhcDtcbiAgdHJhbnNpdGlvbjogdmFyKC0tZ3JuLXRyYW5zaXRpb24tbGVhdmUpO1xuXG4gICY6aG92ZXIge1xuICAgIGNvbG9yOiB2YXIoLS1ncm4tY29sb3ItY29udGVudCk7XG4gICAgdHJhbnNpdGlvbjogdmFyKC0tZ3JuLXRyYW5zaXRpb24taG92ZXIpO1xuICB9XG5cbiAgJHtwID0+XG4gICAgcC5pc0FjdGl2ZSAmJlxuICAgIGBcbiAgICAtLWJvcmRlckNvbG9yOiAke2dldENvbG9yKCdzaGFkZTknKX07XG4gICAgY29sb3I6IHZhcigtLWdybi1jb2xvci1jb250ZW50KTtcbiAgICB0cmFuc2l0aW9uOiB2YXIoLS1ncm4tdHJhbnNpdGlvbi1hY3RpdmUpO1xuICAgIGJhY2tncm91bmQtY29sb3I6ICR7Z2V0Q29sb3IoJ3NoYWRlMScpfTtcblxuICAgICY6aG92ZXIge1xuICAgICAgdHJhbnNpdGlvbjogdmFyKC0tZ3JuLXRyYW5zaXRpb24tYWN0aXZlKTtcbiAgICB9XG4gIGB9XG5gO1xuXG5leHBvcnQgY29uc3QgVGV4dFRvZ2dsZSA9IGZvcndhcmRSZWYoKHsgY2hpbGRyZW4sIGlzQWN0aXZlLCBvbkNsaWNrLCAuLi5wcm9wcyB9LCByZWYpID0+IHtcbiAgcmV0dXJuIChcbiAgICA8SXRlbVdyYXBwZXJcbiAgICAgIHJlZj17cmVmfVxuICAgICAgdHlwZT1cImJ1dHRvblwiXG4gICAgICBpc0FjdGl2ZT17aXNBY3RpdmV9XG4gICAgICBvbkNsaWNrPXtvbkNsaWNrfVxuICAgICAgY2xhc3NOYW1lPVwiVGV4dFRvZ2dsZVwiXG4gICAgICB7Li4ucHJvcHN9XG4gICAgPlxuICAgICAge2NoaWxkcmVufVxuICAgIDwvSXRlbVdyYXBwZXI+XG4gICk7XG59KTtcblxuZXhwb3J0IGNvbnN0IFRleHRUb2dnbGVHcm91cCA9IGZvcndhcmRSZWYoKHsgY2hpbGRyZW4sIGhhc0Z1bGxXaWR0aCwgLi4ucHJvcHMgfSwgcmVmKSA9PiAoXG4gIDxXcmFwcGVyIHJlZj17cmVmfSBoYXNGdWxsV2lkdGg9e2hhc0Z1bGxXaWR0aH0gey4uLnByb3BzfT5cbiAgICB7Y2hpbGRyZW59XG4gIDwvV3JhcHBlcj5cbikpO1xuXG5UZXh0VG9nZ2xlR3JvdXAucHJvcFR5cGVzID0ge1xuICBjaGlsZHJlbjogUHJvcFR5cGVzLm5vZGUsXG4gIGhhc0Z1bGxXaWR0aDogUHJvcFR5cGVzLmJvb2wsXG59O1xuXG5UZXh0VG9nZ2xlLnByb3BUeXBlcyA9IHtcbiAgY2hpbGRyZW46IFByb3BUeXBlcy5ub2RlLFxuICBpc0FjdGl2ZTogUHJvcFR5cGVzLmJvb2wsXG4gIG9uQ2xpY2s6IFByb3BUeXBlcy5mdW5jLFxufTtcbiJdfQ== */"));
23
23
 
24
24
  const ItemWrapper = /*#__PURE__*/_styled("button", process.env.NODE_ENV === "production" ? {
25
25
  target: "e1fb3cwm0"
26
26
  } : {
27
27
  target: "e1fb3cwm0",
28
28
  label: "ItemWrapper"
29
- })(styles.buttonReset, ";--borderColor:transparent;--height:calc(var(--grn-textbox-height-m) - var(--padding) * 2);border:none;padding:0 var(--grn-space-s2);height:var(--height);background-color:transparent;position:relative;color:var(--grn-color-content2);border-radius:calc(", getRadius('s'), " - var(--padding));white-space:nowrap;transition:var(--grn-transition-leave);&:hover{color:var(--grn-color-content);transition:var(--grn-transition-hover);}", p => p.isActive && "\n --borderColor: ".concat(getColor('shade9'), ";\n color: var(--grn-color-content);\n transition: var(--grn-transition-active);\n background-color: ").concat(getColor('shade1'), ";\n\n &:hover {\n transition: var(--grn-transition-active);\n }\n "), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL3RleHQtdG9nZ2xlLmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3QmlDIiwiZmlsZSI6Ii4uLy4uL3NyYy9jb21wb25lbnRzL3RleHQtdG9nZ2xlLmpzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGdldENvbG9yLCBnZXRSYWRpdXMgfSBmcm9tICcuLi91dGlsaXRpZXMnO1xuaW1wb3J0IFJlYWN0LCB7IGZvcndhcmRSZWYgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IHsgc3R5bGVzIH0gZnJvbSAnLi4vZm91bmRhdGlvbmFsJztcblxuY29uc3QgV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIC0tcGFkZGluZzogMnB4O1xuXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGJvcmRlci1yYWRpdXM6ICR7Z2V0UmFkaXVzKCdzJyl9O1xuICBwYWRkaW5nOiB2YXIoLS1wYWRkaW5nKTtcbiAgYmFja2dyb3VuZDogaHNsKHZhcigtLXNoYWRlLWgpIHZhcigtLWZhZGUtcykgdmFyKC0tZmFkZS1sKSAvIDclKTtcblxuICAke3AgPT4gIXAuaGFzRnVsbFdpZHRoICYmIGB3aWR0aDogZml0LWNvbnRlbnRgfTtcbiAgJHtwID0+XG4gICAgcC5oYXNGdWxsV2lkdGggJiZcbiAgICBgXG4gICAgLlRleHRUb2dnbGUge1xuICAgICAgZmxleDogMSAwIDA7XG4gICAgfVxuICBgfVxuYDtcblxuY29uc3QgSXRlbVdyYXBwZXIgPSBzdHlsZWQuYnV0dG9uYFxuICAke3N0eWxlcy5idXR0b25SZXNldH07XG4gIC0tYm9yZGVyQ29sb3I6IHRyYW5zcGFyZW50O1xuICAtLWhlaWdodDogY2FsYyh2YXIoLS1ncm4tdGV4dGJveC1oZWlnaHQtbSkgLSB2YXIoLS1wYWRkaW5nKSAqIDIpO1xuXG4gIGJvcmRlcjogbm9uZTtcbiAgcGFkZGluZzogMCB2YXIoLS1ncm4tc3BhY2UtczIpO1xuICBoZWlnaHQ6IHZhcigtLWhlaWdodCk7XG4gIGJhY2tncm91bmQtY29sb3I6IHRyYW5zcGFyZW50O1xuICBwb3NpdGlvbjogcmVsYXRpdmU7XG4gIGNvbG9yOiB2YXIoLS1ncm4tY29sb3ItY29udGVudDIpO1xuICBib3JkZXItcmFkaXVzOiBjYWxjKCR7Z2V0UmFkaXVzKCdzJyl9IC0gdmFyKC0tcGFkZGluZykpO1xuICB3aGl0ZS1zcGFjZTogbm93cmFwO1xuICB0cmFuc2l0aW9uOiB2YXIoLS1ncm4tdHJhbnNpdGlvbi1sZWF2ZSk7XG5cbiAgJjpob3ZlciB7XG4gICAgY29sb3I6IHZhcigtLWdybi1jb2xvci1jb250ZW50KTtcbiAgICB0cmFuc2l0aW9uOiB2YXIoLS1ncm4tdHJhbnNpdGlvbi1ob3Zlcik7XG4gIH1cblxuICAke3AgPT5cbiAgICBwLmlzQWN0aXZlICYmXG4gICAgYFxuICAgIC0tYm9yZGVyQ29sb3I6ICR7Z2V0Q29sb3IoJ3NoYWRlOScpfTtcbiAgICBjb2xvcjogdmFyKC0tZ3JuLWNvbG9yLWNvbnRlbnQpO1xuICAgIHRyYW5zaXRpb246IHZhcigtLWdybi10cmFuc2l0aW9uLWFjdGl2ZSk7XG4gICAgYmFja2dyb3VuZC1jb2xvcjogJHtnZXRDb2xvcignc2hhZGUxJyl9O1xuXG4gICAgJjpob3ZlciB7XG4gICAgICB0cmFuc2l0aW9uOiB2YXIoLS1ncm4tdHJhbnNpdGlvbi1hY3RpdmUpO1xuICAgIH1cbiAgYH1cbmA7XG5cbmV4cG9ydCBjb25zdCBUZXh0VG9nZ2xlID0gZm9yd2FyZFJlZigoeyBjaGlsZHJlbiwgaXNBY3RpdmUsIG9uQ2xpY2ssIC4uLnByb3BzIH0sIHJlZikgPT4ge1xuICByZXR1cm4gKFxuICAgIDxJdGVtV3JhcHBlclxuICAgICAgcmVmPXtyZWZ9XG4gICAgICB0eXBlPVwiYnV0dG9uXCJcbiAgICAgIGlzQWN0aXZlPXtpc0FjdGl2ZX1cbiAgICAgIG9uQ2xpY2s9e29uQ2xpY2t9XG4gICAgICBjbGFzc05hbWU9XCJUZXh0VG9nZ2xlXCJcbiAgICAgIHsuLi5wcm9wc31cbiAgICA+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgPC9JdGVtV3JhcHBlcj5cbiAgKTtcbn0pO1xuXG5leHBvcnQgY29uc3QgVGV4dFRvZ2dsZUdyb3VwID0gZm9yd2FyZFJlZigoeyBjaGlsZHJlbiwgaGFzRnVsbFdpZHRoLCAuLi5wcm9wcyB9LCByZWYpID0+IChcbiAgPFdyYXBwZXIgcmVmPXtyZWZ9IGhhc0Z1bGxXaWR0aD17aGFzRnVsbFdpZHRofSB7Li4ucHJvcHN9PlxuICAgIHtjaGlsZHJlbn1cbiAgPC9XcmFwcGVyPlxuKSk7XG5cblRleHRUb2dnbGVHcm91cC5wcm9wVHlwZXMgPSB7XG4gIGNoaWxkcmVuOiBQcm9wVHlwZXMubm9kZSxcbiAgaGFzRnVsbFdpZHRoOiBQcm9wVHlwZXMuYm9vbCxcbn07XG5cblRleHRUb2dnbGUucHJvcFR5cGVzID0ge1xuICBjaGlsZHJlbjogUHJvcFR5cGVzLm5vZGUsXG4gIGlzQWN0aXZlOiBQcm9wVHlwZXMuYm9vbCxcbiAgb25DbGljazogUHJvcFR5cGVzLmZ1bmMsXG59O1xuIl19 */"));
29
+ })(styles.buttonReset, ";--borderColor:transparent;--height:calc(var(--grn-textbox-height-m) - var(--padding) * 2);border:none;padding:0 var(--grn-space-s2);height:var(--height);background-color:transparent;position:relative;color:var(--grn-color-content2);border-radius:calc(", getRadius('s'), " - var(--padding));white-space:nowrap;transition:var(--grn-transition-leave);&:hover{color:var(--grn-color-content);transition:var(--grn-transition-hover);}", p => p.isActive && "\n --borderColor: ".concat(getColor('shade9'), ";\n color: var(--grn-color-content);\n transition: var(--grn-transition-active);\n background-color: ").concat(getColor('shade1'), ";\n\n &:hover {\n transition: var(--grn-transition-active);\n }\n "), ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9jb21wb25lbnRzL3RleHQtdG9nZ2xlLmpzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3QmlDIiwiZmlsZSI6Ii4uLy4uL3NyYy9jb21wb25lbnRzL3RleHQtdG9nZ2xlLmpzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGdldENvbG9yLCBnZXRSYWRpdXMgfSBmcm9tICcuLi91dGlsaXRpZXMnO1xuaW1wb3J0IFJlYWN0LCB7IGZvcndhcmRSZWYgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgUHJvcFR5cGVzIGZyb20gJ3Byb3AtdHlwZXMnO1xuaW1wb3J0IHsgc3R5bGVzIH0gZnJvbSAnLi4vZm91bmRhdGlvbmFsJztcblxuY29uc3QgV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIC0tcGFkZGluZzogMnB4O1xuXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGJvcmRlci1yYWRpdXM6ICR7Z2V0UmFkaXVzKCdzJyl9O1xuICBwYWRkaW5nOiB2YXIoLS1wYWRkaW5nKTtcbiAgYmFja2dyb3VuZDogdmFyKC0tZ3JuLWNvbG9yLW92ZXJsYXkpO1xuXG4gICR7cCA9PiAhcC5oYXNGdWxsV2lkdGggJiYgYHdpZHRoOiBmaXQtY29udGVudGB9O1xuICAke3AgPT5cbiAgICBwLmhhc0Z1bGxXaWR0aCAmJlxuICAgIGBcbiAgICAuVGV4dFRvZ2dsZSB7XG4gICAgICBmbGV4OiAxIDAgMDtcbiAgICB9XG4gIGB9XG5gO1xuXG5jb25zdCBJdGVtV3JhcHBlciA9IHN0eWxlZC5idXR0b25gXG4gICR7c3R5bGVzLmJ1dHRvblJlc2V0fTtcbiAgLS1ib3JkZXJDb2xvcjogdHJhbnNwYXJlbnQ7XG4gIC0taGVpZ2h0OiBjYWxjKHZhcigtLWdybi10ZXh0Ym94LWhlaWdodC1tKSAtIHZhcigtLXBhZGRpbmcpICogMik7XG5cbiAgYm9yZGVyOiBub25lO1xuICBwYWRkaW5nOiAwIHZhcigtLWdybi1zcGFjZS1zMik7XG4gIGhlaWdodDogdmFyKC0taGVpZ2h0KTtcbiAgYmFja2dyb3VuZC1jb2xvcjogdHJhbnNwYXJlbnQ7XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgY29sb3I6IHZhcigtLWdybi1jb2xvci1jb250ZW50Mik7XG4gIGJvcmRlci1yYWRpdXM6IGNhbGMoJHtnZXRSYWRpdXMoJ3MnKX0gLSB2YXIoLS1wYWRkaW5nKSk7XG4gIHdoaXRlLXNwYWNlOiBub3dyYXA7XG4gIHRyYW5zaXRpb246IHZhcigtLWdybi10cmFuc2l0aW9uLWxlYXZlKTtcblxuICAmOmhvdmVyIHtcbiAgICBjb2xvcjogdmFyKC0tZ3JuLWNvbG9yLWNvbnRlbnQpO1xuICAgIHRyYW5zaXRpb246IHZhcigtLWdybi10cmFuc2l0aW9uLWhvdmVyKTtcbiAgfVxuXG4gICR7cCA9PlxuICAgIHAuaXNBY3RpdmUgJiZcbiAgICBgXG4gICAgLS1ib3JkZXJDb2xvcjogJHtnZXRDb2xvcignc2hhZGU5Jyl9O1xuICAgIGNvbG9yOiB2YXIoLS1ncm4tY29sb3ItY29udGVudCk7XG4gICAgdHJhbnNpdGlvbjogdmFyKC0tZ3JuLXRyYW5zaXRpb24tYWN0aXZlKTtcbiAgICBiYWNrZ3JvdW5kLWNvbG9yOiAke2dldENvbG9yKCdzaGFkZTEnKX07XG5cbiAgICAmOmhvdmVyIHtcbiAgICAgIHRyYW5zaXRpb246IHZhcigtLWdybi10cmFuc2l0aW9uLWFjdGl2ZSk7XG4gICAgfVxuICBgfVxuYDtcblxuZXhwb3J0IGNvbnN0IFRleHRUb2dnbGUgPSBmb3J3YXJkUmVmKCh7IGNoaWxkcmVuLCBpc0FjdGl2ZSwgb25DbGljaywgLi4ucHJvcHMgfSwgcmVmKSA9PiB7XG4gIHJldHVybiAoXG4gICAgPEl0ZW1XcmFwcGVyXG4gICAgICByZWY9e3JlZn1cbiAgICAgIHR5cGU9XCJidXR0b25cIlxuICAgICAgaXNBY3RpdmU9e2lzQWN0aXZlfVxuICAgICAgb25DbGljaz17b25DbGlja31cbiAgICAgIGNsYXNzTmFtZT1cIlRleHRUb2dnbGVcIlxuICAgICAgey4uLnByb3BzfVxuICAgID5cbiAgICAgIHtjaGlsZHJlbn1cbiAgICA8L0l0ZW1XcmFwcGVyPlxuICApO1xufSk7XG5cbmV4cG9ydCBjb25zdCBUZXh0VG9nZ2xlR3JvdXAgPSBmb3J3YXJkUmVmKCh7IGNoaWxkcmVuLCBoYXNGdWxsV2lkdGgsIC4uLnByb3BzIH0sIHJlZikgPT4gKFxuICA8V3JhcHBlciByZWY9e3JlZn0gaGFzRnVsbFdpZHRoPXtoYXNGdWxsV2lkdGh9IHsuLi5wcm9wc30+XG4gICAge2NoaWxkcmVufVxuICA8L1dyYXBwZXI+XG4pKTtcblxuVGV4dFRvZ2dsZUdyb3VwLnByb3BUeXBlcyA9IHtcbiAgY2hpbGRyZW46IFByb3BUeXBlcy5ub2RlLFxuICBoYXNGdWxsV2lkdGg6IFByb3BUeXBlcy5ib29sLFxufTtcblxuVGV4dFRvZ2dsZS5wcm9wVHlwZXMgPSB7XG4gIGNoaWxkcmVuOiBQcm9wVHlwZXMubm9kZSxcbiAgaXNBY3RpdmU6IFByb3BUeXBlcy5ib29sLFxuICBvbkNsaWNrOiBQcm9wVHlwZXMuZnVuYyxcbn07XG4iXX0= */"));
30
30
 
31
31
  export const TextToggle = /*#__PURE__*/forwardRef((_ref, ref) => {
32
32
  let {
@@ -126,7 +126,7 @@ const MenuCardUl = /*#__PURE__*/_styled("ul", process.env.NODE_ENV === "producti
126
126
  isDisabled
127
127
  } = _ref7;
128
128
  return isDisabled && "pointer-events: none;";
129
- }, " &:focus{outline:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/foundational/menu.jsx"],"names":[],"mappings":"AAyG4B","file":"../../src/foundational/menu.jsx","sourcesContent":["import React, {\n  Fragment,\n  forwardRef,\n  useCallback,\n  useEffect,\n  useImperativeHandle,\n  useRef,\n} from 'react';\nimport PropTypes from 'prop-types';\nimport { Global, css } from '@emotion/react';\nimport {\n  getColor,\n  getDimension,\n  getRadius,\n  getShadow,\n  getSpace,\n  getTransition,\n} from '../utilities';\nimport { Box, Icon, Text } from '../components';\nimport { IconCheck } from '../icons';\nimport { autoUpdate, flip, size, useFloating } from '@floating-ui/react-dom-interactions';\nimport { Transition } from '@headlessui/react';\nimport { types } from '../types';\nimport styled from '@emotion/styled';\n\nconst cardPadding = 8;\nconst cardPaddingPx = `${cardPadding}px`;\nconst itemXPadding = 12;\n\nexport const placementsMap = {\n  top: 'top',\n  topStart: 'top-start',\n  topEnd: 'top-end',\n  bottom: 'bottom',\n  bottomStart: 'bottom-start',\n  bottomEnd: 'bottom-end',\n  right: 'right',\n  rightStart: 'right-start',\n  rightEnd: 'right-end',\n  left: 'left',\n  leftStart: 'left-start',\n  leftEnd: 'left-end',\n};\n\nexport const useMenuPosition = ({ menuWidth, menuPlacement }) => {\n  const { x, y, reference, floating, strategy, refs } = useFloating({\n    placement: placementsMap[menuPlacement],\n    whileElementsMounted: autoUpdate,\n    middleware: [\n      flip({ padding: 24, flipAlignment: false }),\n      size({\n        apply({ rects, elements }) {\n          const width = getDimension(menuWidth) || `${rects.reference.width}px`;\n          Object.assign(elements.floating.style, {\n            width: width,\n          });\n        },\n        padding: 24,\n      }),\n    ],\n  });\n\n  const floatingStyles = {\n    position: strategy,\n    top: y ?? 0,\n    left: x ?? 0,\n    zIndex: 1100,\n  };\n\n  return {\n    refs,\n    reference,\n    floating,\n    floatingStyles,\n  };\n};\n\nconst menuCardStyles = `\n  .menuCardLeaveTo,\n  .menuCardEnterFrom {\n    opacity: 0;\n  }\n  .menuCardEnterTo {\n    transition-duration: ${getTransition('xxFast')};\n  }\n  .menuCardLeaveTo {\n    transition-duration: ${getTransition('xFast')};\n  }\n`;\n\nexport const MenuCardTransition = forwardRef(({ children, show, ...props }, ref) => (\n  <Transition\n    as={Fragment}\n    enterFrom=\"menuCardEnterFrom\"\n    enterTo=\"menuCardEnterTo\"\n    leaveFrom=\"menuCardLeaveFrom\"\n    leaveTo=\"menuCardLeaveTo\"\n    ref={ref}\n    show={show}\n    {...props}\n  >\n    {children}\n  </Transition>\n));\n\nconst MenuCardUl = styled.ul`\n  padding: ${cardPaddingPx};\n  margin: 0;\n  background: ${getColor('floatingBackground')};\n  z-index: ${({ zIndex }) => zIndex};\n  box-shadow: ${getShadow('m')};\n  border-radius: ${getRadius('m')};\n  overflow: auto;\n  ${({ maxHeight }) => maxHeight && `max-height: ${getSpace(maxHeight)}`};\n  ${({ maxWidth }) => maxWidth && `max-width: ${getSpace(maxWidth)}`};\n  /* to prevent a bug: the menu is not always rmoeved from the DOM, in a animated container */\n  ${({ isDisabled }) => isDisabled && `pointer-events: none;`}\n\n  &:focus {\n    outline: none;\n  }\n`;\n\nexport const MenuCard = forwardRef(\n  ({ children, zIndex = 1, maxHeight, maxWidth, isDisabled, ...props }, ref) => {\n    const menuCardRef = useRef(ref);\n    useImperativeHandle(ref, () => menuCardRef.current, []);\n\n    const scrollToActive = useCallback(() => {\n      // Note: this function is rely on data-headlessui-state attribute\n      const menuCard = menuCardRef.current;\n      const activeItem = menuCard?.querySelector('[data-headlessui-state=\"selected\"]');\n      if (!menuCard || !activeItem) return;\n      const menuCardRect = menuCard.getBoundingClientRect();\n      const activeItemRect = activeItem.getBoundingClientRect();\n      menuCard.scrollTop =\n        activeItem.offsetTop - menuCardRect.height / 2 + activeItemRect.height / 2;\n    }, []);\n\n    useEffect(() => {\n      scrollToActive();\n    }, [scrollToActive]);\n\n    return (\n      <>\n        <Global styles={menuCardStyles} />\n        <MenuCardUl\n          ref={menuCardRef}\n          zIndex={zIndex}\n          maxHeight={maxHeight}\n          maxWidth={maxWidth}\n          isDisabled={isDisabled}\n          className=\"MenuCard grn-context\"\n          {...props}\n        >\n          {children}\n        </MenuCardUl>\n      </>\n    );\n  },\n);\n\nconst variantStyles = {\n  neutral: {\n    backgroundColorActive: getColor('fade1'),\n    iconColorActive: getColor('content'),\n  },\n  danger: {\n    color: getColor('danger'),\n    iconColor: 'var(--grn-icon-danger-color)',\n    iconColorActive: getColor('danger'),\n    backgroundColorActive: 'var(--grn-clearbutton-danger-background-hover)',\n  },\n};\n\nconst MenuItemRoot = styled.li`\n  display: grid;\n  grid-auto-flow: column;\n  gap: 8px;\n  ${({ isDisabled }) => isDisabled && `color: ${getColor('disabledContent')}`};\n  ${({ isDisabled }) => !isDisabled && `cursor: pointer;`};\n  align-items: center;\n  justify-content: start;\n  list-style: none;\n  padding-block: 10px;\n  padding-inline: ${itemXPadding}px;\n  margin: 0;\n  min-height: var(--grn-textbox-height-m);\n  border-radius: ${getRadius('s')};\n  appearance: none;\n  color: ${({ color }) => color};\n\n  [data-experiment-compact-textbox] & {\n    padding-block: ${getSpace('s')};\n  }\n`;\n\nexport const MenuGroupTitle = ({ children }) => (\n  <Box\n    css={css`\n      &:first-of-type {\n        --marginTop: calc(-1 * var(--grn-space-s));\n        --borderColor: transparent;\n      }\n      &:not(:first-of-type) {\n        --marginTop: ${cardPaddingPx};\n        --borderColor: var(--grn-color-border);\n      }\n    `}\n    paddingX={`${cardPadding + itemXPadding}px`}\n    paddingTop=\"m\"\n    paddingBottom={cardPaddingPx}\n    marginTop=\"var(--marginTop)\"\n    borderSide=\"top\"\n    borderColor=\"var(--borderColor)\"\n    marginX={`-${cardPaddingPx}`}\n    position=\"relative\"\n  >\n    <Text variant=\"caps\">{children}</Text>\n  </Box>\n);\n\nexport const MenuItemDivider = () => (\n  <Box height=\"1px\" marginY={1} backgroundColor=\"border\" marginX={`-${cardPaddingPx}`} />\n);\n\nexport const MenuItem = forwardRef(\n  (\n    {\n      children,\n      isSelected,\n      isActive,\n      isDisabled,\n      icon,\n      variant = 'neutral',\n      hasEllipsis,\n      checkVariant = 'check',\n      ...props\n    },\n    ref,\n  ) => {\n    const hasCheck = checkVariant === 'check';\n\n    const getColumns = () => {\n      if (Boolean(icon)) return 'auto 1fr';\n      if (hasCheck) return '1fr auto';\n    };\n\n    return (\n      <MenuItemRoot\n        ref={ref}\n        isSelected={isSelected}\n        isDisabled={isDisabled}\n        color={variantStyles[variant].color}\n        hasIcon={Boolean(icon)}\n        style={{\n          background: isActive && variantStyles[variant].backgroundColorActive,\n          gridTemplateColumns: getColumns(),\n        }}\n        {...props}\n      >\n        {icon && (\n          <Icon\n            icon={icon}\n            hasEvenBoundary\n            color={\n              isActive ? variantStyles[variant].iconColorActive : variantStyles[variant].iconColor\n            }\n          />\n        )}\n        <Box width=\"100%\" minWidth=\"0px\" tag=\"span\">\n          <Text hasEllipsis={hasEllipsis}>{children}</Text>\n        </Box>\n        {hasCheck && (\n          <Box opacity={isSelected ? '1' : '0'}>\n            <Icon icon={<IconCheck />} color={isActive ? 'content' : 'icon'} />\n          </Box>\n        )}\n      </MenuItemRoot>\n    );\n  },\n);\n\nMenuItem.propTypes = {\n  isSelected: PropTypes.bool,\n  isActive: PropTypes.bool,\n  isDisabled: PropTypes.bool,\n  icon: PropTypes.node,\n  variant: PropTypes.oneOf(['neutral', 'danger']),\n  hasEllipsis: PropTypes.bool,\n  checkVariant: PropTypes.oneOf(['check', 'none']),\n};\n\nMenuCard.propTypes = {\n  children: PropTypes.node,\n  zIndex: types.zIndex,\n  maxHeight: types.dimension,\n  maxWidth: types.dimension,\n  isDisabled: PropTypes.bool,\n};\n\nMenuCardTransition.propTypes = {\n  children: PropTypes.node,\n  show: PropTypes.bool,\n};\n"]} */"));
129
+ }, " &:focus{outline:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/foundational/menu.jsx"],"names":[],"mappings":"AAyG4B","file":"../../src/foundational/menu.jsx","sourcesContent":["import React, {\n  Fragment,\n  forwardRef,\n  useCallback,\n  useEffect,\n  useImperativeHandle,\n  useRef,\n} from 'react';\nimport PropTypes from 'prop-types';\nimport { Global, css } from '@emotion/react';\nimport {\n  getColor,\n  getDimension,\n  getRadius,\n  getShadow,\n  getSpace,\n  getTransition,\n} from '../utilities';\nimport { Box, Icon, Text } from '../components';\nimport { IconCheck } from '../icons';\nimport { autoUpdate, flip, size, useFloating } from '@floating-ui/react-dom-interactions';\nimport { Transition } from '@headlessui/react';\nimport { types } from '../types';\nimport styled from '@emotion/styled';\n\nconst cardPadding = 8;\nconst cardPaddingPx = `${cardPadding}px`;\nconst itemXPadding = 12;\n\nexport const placementsMap = {\n  top: 'top',\n  topStart: 'top-start',\n  topEnd: 'top-end',\n  bottom: 'bottom',\n  bottomStart: 'bottom-start',\n  bottomEnd: 'bottom-end',\n  right: 'right',\n  rightStart: 'right-start',\n  rightEnd: 'right-end',\n  left: 'left',\n  leftStart: 'left-start',\n  leftEnd: 'left-end',\n};\n\nexport const useMenuPosition = ({ menuWidth, menuPlacement }) => {\n  const { x, y, reference, floating, strategy, refs } = useFloating({\n    placement: placementsMap[menuPlacement],\n    whileElementsMounted: autoUpdate,\n    middleware: [\n      flip({ padding: 24, flipAlignment: false }),\n      size({\n        apply({ rects, elements }) {\n          const width = getDimension(menuWidth) || `${rects.reference.width}px`;\n          Object.assign(elements.floating.style, {\n            width: width,\n          });\n        },\n        padding: 24,\n      }),\n    ],\n  });\n\n  const floatingStyles = {\n    position: strategy,\n    top: y ?? 0,\n    left: x ?? 0,\n    zIndex: 1100,\n  };\n\n  return {\n    refs,\n    reference,\n    floating,\n    floatingStyles,\n  };\n};\n\nconst menuCardStyles = `\n  .menuCardLeaveTo,\n  .menuCardEnterFrom {\n    opacity: 0;\n  }\n  .menuCardEnterTo {\n    transition-duration: ${getTransition('xxFast')};\n  }\n  .menuCardLeaveTo {\n    transition-duration: ${getTransition('xFast')};\n  }\n`;\n\nexport const MenuCardTransition = forwardRef(({ children, show, ...props }, ref) => (\n  <Transition\n    as={Fragment}\n    enterFrom=\"menuCardEnterFrom\"\n    enterTo=\"menuCardEnterTo\"\n    leaveFrom=\"menuCardLeaveFrom\"\n    leaveTo=\"menuCardLeaveTo\"\n    ref={ref}\n    show={show}\n    {...props}\n  >\n    {children}\n  </Transition>\n));\n\nconst MenuCardUl = styled.ul`\n  padding: ${cardPaddingPx};\n  margin: 0;\n  background: ${getColor('floatingBackground')};\n  z-index: ${({ zIndex }) => zIndex};\n  box-shadow: ${getShadow('m')};\n  border-radius: ${getRadius('m')};\n  overflow: auto;\n  ${({ maxHeight }) => maxHeight && `max-height: ${getSpace(maxHeight)}`};\n  ${({ maxWidth }) => maxWidth && `max-width: ${getSpace(maxWidth)}`};\n  /* to prevent a bug: the menu is not always rmoeved from the DOM, in a animated container */\n  ${({ isDisabled }) => isDisabled && `pointer-events: none;`}\n\n  &:focus {\n    outline: none;\n  }\n`;\n\nexport const MenuCard = forwardRef(\n  ({ children, zIndex = 1, maxHeight, maxWidth, isDisabled, ...props }, ref) => {\n    const menuCardRef = useRef(ref);\n    useImperativeHandle(ref, () => menuCardRef.current, []);\n\n    const scrollToActive = useCallback(() => {\n      // Note: this function is rely on data-headlessui-state attribute\n      const menuCard = menuCardRef.current;\n      const activeItem = menuCard?.querySelector('[data-headlessui-state=\"selected\"]');\n      if (!menuCard || !activeItem) return;\n      const menuCardRect = menuCard.getBoundingClientRect();\n      const activeItemRect = activeItem.getBoundingClientRect();\n      menuCard.scrollTop =\n        activeItem.offsetTop - menuCardRect.height / 2 + activeItemRect.height / 2;\n    }, []);\n\n    useEffect(() => {\n      scrollToActive();\n    }, [scrollToActive]);\n\n    return (\n      <>\n        <Global styles={menuCardStyles} />\n        <MenuCardUl\n          ref={menuCardRef}\n          zIndex={zIndex}\n          maxHeight={maxHeight}\n          maxWidth={maxWidth}\n          isDisabled={isDisabled}\n          className=\"MenuCard grn-context\"\n          {...props}\n        >\n          {children}\n        </MenuCardUl>\n      </>\n    );\n  },\n);\n\nconst variantStyles = {\n  neutral: {\n    backgroundColorActive: getColor('overlay'),\n    iconColorActive: getColor('content'),\n  },\n  danger: {\n    color: getColor('danger'),\n    iconColor: 'var(--grn-icon-danger-color)',\n    iconColorActive: getColor('danger'),\n    backgroundColorActive: 'var(--grn-clearbutton-danger-background-hover)',\n  },\n};\n\nconst MenuItemRoot = styled.li`\n  display: grid;\n  grid-auto-flow: column;\n  gap: 8px;\n  ${({ isDisabled }) => isDisabled && `color: ${getColor('disabledContent')}`};\n  ${({ isDisabled }) => !isDisabled && `cursor: pointer;`};\n  align-items: center;\n  justify-content: start;\n  list-style: none;\n  padding-block: 10px;\n  padding-inline: ${itemXPadding}px;\n  margin: 0;\n  min-height: var(--grn-textbox-height-m);\n  border-radius: ${getRadius('s')};\n  appearance: none;\n  color: ${({ color }) => color};\n\n  [data-experiment-compact-textbox] & {\n    padding-block: ${getSpace('s')};\n  }\n`;\n\nexport const MenuGroupTitle = ({ children }) => (\n  <Box\n    css={css`\n      &:first-of-type {\n        --marginTop: calc(-1 * var(--grn-space-s));\n        --borderColor: transparent;\n      }\n      &:not(:first-of-type) {\n        --marginTop: ${cardPaddingPx};\n        --borderColor: var(--grn-color-border);\n      }\n    `}\n    paddingX={`${cardPadding + itemXPadding}px`}\n    paddingTop=\"m\"\n    paddingBottom={cardPaddingPx}\n    marginTop=\"var(--marginTop)\"\n    borderSide=\"top\"\n    borderColor=\"var(--borderColor)\"\n    marginX={`-${cardPaddingPx}`}\n    position=\"relative\"\n  >\n    <Text variant=\"caps\">{children}</Text>\n  </Box>\n);\n\nexport const MenuItemDivider = () => (\n  <Box height=\"1px\" marginY={1} backgroundColor=\"border\" marginX={`-${cardPaddingPx}`} />\n);\n\nexport const MenuItem = forwardRef(\n  (\n    {\n      children,\n      isSelected,\n      isActive,\n      isDisabled,\n      icon,\n      variant = 'neutral',\n      hasEllipsis,\n      checkVariant = 'check',\n      ...props\n    },\n    ref,\n  ) => {\n    const hasCheck = checkVariant === 'check';\n\n    const getColumns = () => {\n      if (Boolean(icon)) return 'auto 1fr';\n      if (hasCheck) return '1fr auto';\n    };\n\n    return (\n      <MenuItemRoot\n        ref={ref}\n        isSelected={isSelected}\n        isDisabled={isDisabled}\n        color={variantStyles[variant].color}\n        hasIcon={Boolean(icon)}\n        style={{\n          background: isActive && variantStyles[variant].backgroundColorActive,\n          gridTemplateColumns: getColumns(),\n        }}\n        {...props}\n      >\n        {icon && (\n          <Icon\n            icon={icon}\n            hasEvenBoundary\n            color={\n              isActive ? variantStyles[variant].iconColorActive : variantStyles[variant].iconColor\n            }\n          />\n        )}\n        <Box width=\"100%\" minWidth=\"0px\" tag=\"span\">\n          <Text hasEllipsis={hasEllipsis}>{children}</Text>\n        </Box>\n        {hasCheck && (\n          <Box opacity={isSelected ? '1' : '0'}>\n            <Icon icon={<IconCheck />} color={isActive ? 'content' : 'icon'} />\n          </Box>\n        )}\n      </MenuItemRoot>\n    );\n  },\n);\n\nMenuItem.propTypes = {\n  isSelected: PropTypes.bool,\n  isActive: PropTypes.bool,\n  isDisabled: PropTypes.bool,\n  icon: PropTypes.node,\n  variant: PropTypes.oneOf(['neutral', 'danger']),\n  hasEllipsis: PropTypes.bool,\n  checkVariant: PropTypes.oneOf(['check', 'none']),\n};\n\nMenuCard.propTypes = {\n  children: PropTypes.node,\n  zIndex: types.zIndex,\n  maxHeight: types.dimension,\n  maxWidth: types.dimension,\n  isDisabled: PropTypes.bool,\n};\n\nMenuCardTransition.propTypes = {\n  children: PropTypes.node,\n  show: PropTypes.bool,\n};\n"]} */"));
130
130
 
131
131
  export const MenuCard = /*#__PURE__*/forwardRef((_ref8, ref) => {
132
132
  let {
@@ -165,7 +165,7 @@ export const MenuCard = /*#__PURE__*/forwardRef((_ref8, ref) => {
165
165
  });
166
166
  const variantStyles = {
167
167
  neutral: {
168
- backgroundColorActive: getColor('fade1'),
168
+ backgroundColorActive: getColor('overlay'),
169
169
  iconColorActive: getColor('content')
170
170
  },
171
171
  danger: {
@@ -196,14 +196,14 @@ const MenuItemRoot = /*#__PURE__*/_styled("li", process.env.NODE_ENV === "produc
196
196
  color
197
197
  } = _ref11;
198
198
  return color;
199
- }, ";[data-experiment-compact-textbox] &{padding-block:", getSpace('s'), ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/foundational/menu.jsx"],"names":[],"mappings":"AA+K8B","file":"../../src/foundational/menu.jsx","sourcesContent":["import React, {\n  Fragment,\n  forwardRef,\n  useCallback,\n  useEffect,\n  useImperativeHandle,\n  useRef,\n} from 'react';\nimport PropTypes from 'prop-types';\nimport { Global, css } from '@emotion/react';\nimport {\n  getColor,\n  getDimension,\n  getRadius,\n  getShadow,\n  getSpace,\n  getTransition,\n} from '../utilities';\nimport { Box, Icon, Text } from '../components';\nimport { IconCheck } from '../icons';\nimport { autoUpdate, flip, size, useFloating } from '@floating-ui/react-dom-interactions';\nimport { Transition } from '@headlessui/react';\nimport { types } from '../types';\nimport styled from '@emotion/styled';\n\nconst cardPadding = 8;\nconst cardPaddingPx = `${cardPadding}px`;\nconst itemXPadding = 12;\n\nexport const placementsMap = {\n  top: 'top',\n  topStart: 'top-start',\n  topEnd: 'top-end',\n  bottom: 'bottom',\n  bottomStart: 'bottom-start',\n  bottomEnd: 'bottom-end',\n  right: 'right',\n  rightStart: 'right-start',\n  rightEnd: 'right-end',\n  left: 'left',\n  leftStart: 'left-start',\n  leftEnd: 'left-end',\n};\n\nexport const useMenuPosition = ({ menuWidth, menuPlacement }) => {\n  const { x, y, reference, floating, strategy, refs } = useFloating({\n    placement: placementsMap[menuPlacement],\n    whileElementsMounted: autoUpdate,\n    middleware: [\n      flip({ padding: 24, flipAlignment: false }),\n      size({\n        apply({ rects, elements }) {\n          const width = getDimension(menuWidth) || `${rects.reference.width}px`;\n          Object.assign(elements.floating.style, {\n            width: width,\n          });\n        },\n        padding: 24,\n      }),\n    ],\n  });\n\n  const floatingStyles = {\n    position: strategy,\n    top: y ?? 0,\n    left: x ?? 0,\n    zIndex: 1100,\n  };\n\n  return {\n    refs,\n    reference,\n    floating,\n    floatingStyles,\n  };\n};\n\nconst menuCardStyles = `\n  .menuCardLeaveTo,\n  .menuCardEnterFrom {\n    opacity: 0;\n  }\n  .menuCardEnterTo {\n    transition-duration: ${getTransition('xxFast')};\n  }\n  .menuCardLeaveTo {\n    transition-duration: ${getTransition('xFast')};\n  }\n`;\n\nexport const MenuCardTransition = forwardRef(({ children, show, ...props }, ref) => (\n  <Transition\n    as={Fragment}\n    enterFrom=\"menuCardEnterFrom\"\n    enterTo=\"menuCardEnterTo\"\n    leaveFrom=\"menuCardLeaveFrom\"\n    leaveTo=\"menuCardLeaveTo\"\n    ref={ref}\n    show={show}\n    {...props}\n  >\n    {children}\n  </Transition>\n));\n\nconst MenuCardUl = styled.ul`\n  padding: ${cardPaddingPx};\n  margin: 0;\n  background: ${getColor('floatingBackground')};\n  z-index: ${({ zIndex }) => zIndex};\n  box-shadow: ${getShadow('m')};\n  border-radius: ${getRadius('m')};\n  overflow: auto;\n  ${({ maxHeight }) => maxHeight && `max-height: ${getSpace(maxHeight)}`};\n  ${({ maxWidth }) => maxWidth && `max-width: ${getSpace(maxWidth)}`};\n  /* to prevent a bug: the menu is not always rmoeved from the DOM, in a animated container */\n  ${({ isDisabled }) => isDisabled && `pointer-events: none;`}\n\n  &:focus {\n    outline: none;\n  }\n`;\n\nexport const MenuCard = forwardRef(\n  ({ children, zIndex = 1, maxHeight, maxWidth, isDisabled, ...props }, ref) => {\n    const menuCardRef = useRef(ref);\n    useImperativeHandle(ref, () => menuCardRef.current, []);\n\n    const scrollToActive = useCallback(() => {\n      // Note: this function is rely on data-headlessui-state attribute\n      const menuCard = menuCardRef.current;\n      const activeItem = menuCard?.querySelector('[data-headlessui-state=\"selected\"]');\n      if (!menuCard || !activeItem) return;\n      const menuCardRect = menuCard.getBoundingClientRect();\n      const activeItemRect = activeItem.getBoundingClientRect();\n      menuCard.scrollTop =\n        activeItem.offsetTop - menuCardRect.height / 2 + activeItemRect.height / 2;\n    }, []);\n\n    useEffect(() => {\n      scrollToActive();\n    }, [scrollToActive]);\n\n    return (\n      <>\n        <Global styles={menuCardStyles} />\n        <MenuCardUl\n          ref={menuCardRef}\n          zIndex={zIndex}\n          maxHeight={maxHeight}\n          maxWidth={maxWidth}\n          isDisabled={isDisabled}\n          className=\"MenuCard grn-context\"\n          {...props}\n        >\n          {children}\n        </MenuCardUl>\n      </>\n    );\n  },\n);\n\nconst variantStyles = {\n  neutral: {\n    backgroundColorActive: getColor('fade1'),\n    iconColorActive: getColor('content'),\n  },\n  danger: {\n    color: getColor('danger'),\n    iconColor: 'var(--grn-icon-danger-color)',\n    iconColorActive: getColor('danger'),\n    backgroundColorActive: 'var(--grn-clearbutton-danger-background-hover)',\n  },\n};\n\nconst MenuItemRoot = styled.li`\n  display: grid;\n  grid-auto-flow: column;\n  gap: 8px;\n  ${({ isDisabled }) => isDisabled && `color: ${getColor('disabledContent')}`};\n  ${({ isDisabled }) => !isDisabled && `cursor: pointer;`};\n  align-items: center;\n  justify-content: start;\n  list-style: none;\n  padding-block: 10px;\n  padding-inline: ${itemXPadding}px;\n  margin: 0;\n  min-height: var(--grn-textbox-height-m);\n  border-radius: ${getRadius('s')};\n  appearance: none;\n  color: ${({ color }) => color};\n\n  [data-experiment-compact-textbox] & {\n    padding-block: ${getSpace('s')};\n  }\n`;\n\nexport const MenuGroupTitle = ({ children }) => (\n  <Box\n    css={css`\n      &:first-of-type {\n        --marginTop: calc(-1 * var(--grn-space-s));\n        --borderColor: transparent;\n      }\n      &:not(:first-of-type) {\n        --marginTop: ${cardPaddingPx};\n        --borderColor: var(--grn-color-border);\n      }\n    `}\n    paddingX={`${cardPadding + itemXPadding}px`}\n    paddingTop=\"m\"\n    paddingBottom={cardPaddingPx}\n    marginTop=\"var(--marginTop)\"\n    borderSide=\"top\"\n    borderColor=\"var(--borderColor)\"\n    marginX={`-${cardPaddingPx}`}\n    position=\"relative\"\n  >\n    <Text variant=\"caps\">{children}</Text>\n  </Box>\n);\n\nexport const MenuItemDivider = () => (\n  <Box height=\"1px\" marginY={1} backgroundColor=\"border\" marginX={`-${cardPaddingPx}`} />\n);\n\nexport const MenuItem = forwardRef(\n  (\n    {\n      children,\n      isSelected,\n      isActive,\n      isDisabled,\n      icon,\n      variant = 'neutral',\n      hasEllipsis,\n      checkVariant = 'check',\n      ...props\n    },\n    ref,\n  ) => {\n    const hasCheck = checkVariant === 'check';\n\n    const getColumns = () => {\n      if (Boolean(icon)) return 'auto 1fr';\n      if (hasCheck) return '1fr auto';\n    };\n\n    return (\n      <MenuItemRoot\n        ref={ref}\n        isSelected={isSelected}\n        isDisabled={isDisabled}\n        color={variantStyles[variant].color}\n        hasIcon={Boolean(icon)}\n        style={{\n          background: isActive && variantStyles[variant].backgroundColorActive,\n          gridTemplateColumns: getColumns(),\n        }}\n        {...props}\n      >\n        {icon && (\n          <Icon\n            icon={icon}\n            hasEvenBoundary\n            color={\n              isActive ? variantStyles[variant].iconColorActive : variantStyles[variant].iconColor\n            }\n          />\n        )}\n        <Box width=\"100%\" minWidth=\"0px\" tag=\"span\">\n          <Text hasEllipsis={hasEllipsis}>{children}</Text>\n        </Box>\n        {hasCheck && (\n          <Box opacity={isSelected ? '1' : '0'}>\n            <Icon icon={<IconCheck />} color={isActive ? 'content' : 'icon'} />\n          </Box>\n        )}\n      </MenuItemRoot>\n    );\n  },\n);\n\nMenuItem.propTypes = {\n  isSelected: PropTypes.bool,\n  isActive: PropTypes.bool,\n  isDisabled: PropTypes.bool,\n  icon: PropTypes.node,\n  variant: PropTypes.oneOf(['neutral', 'danger']),\n  hasEllipsis: PropTypes.bool,\n  checkVariant: PropTypes.oneOf(['check', 'none']),\n};\n\nMenuCard.propTypes = {\n  children: PropTypes.node,\n  zIndex: types.zIndex,\n  maxHeight: types.dimension,\n  maxWidth: types.dimension,\n  isDisabled: PropTypes.bool,\n};\n\nMenuCardTransition.propTypes = {\n  children: PropTypes.node,\n  show: PropTypes.bool,\n};\n"]} */"));
199
+ }, ";[data-experiment-compact-textbox] &{padding-block:", getSpace('s'), ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/foundational/menu.jsx"],"names":[],"mappings":"AA+K8B","file":"../../src/foundational/menu.jsx","sourcesContent":["import React, {\n  Fragment,\n  forwardRef,\n  useCallback,\n  useEffect,\n  useImperativeHandle,\n  useRef,\n} from 'react';\nimport PropTypes from 'prop-types';\nimport { Global, css } from '@emotion/react';\nimport {\n  getColor,\n  getDimension,\n  getRadius,\n  getShadow,\n  getSpace,\n  getTransition,\n} from '../utilities';\nimport { Box, Icon, Text } from '../components';\nimport { IconCheck } from '../icons';\nimport { autoUpdate, flip, size, useFloating } from '@floating-ui/react-dom-interactions';\nimport { Transition } from '@headlessui/react';\nimport { types } from '../types';\nimport styled from '@emotion/styled';\n\nconst cardPadding = 8;\nconst cardPaddingPx = `${cardPadding}px`;\nconst itemXPadding = 12;\n\nexport const placementsMap = {\n  top: 'top',\n  topStart: 'top-start',\n  topEnd: 'top-end',\n  bottom: 'bottom',\n  bottomStart: 'bottom-start',\n  bottomEnd: 'bottom-end',\n  right: 'right',\n  rightStart: 'right-start',\n  rightEnd: 'right-end',\n  left: 'left',\n  leftStart: 'left-start',\n  leftEnd: 'left-end',\n};\n\nexport const useMenuPosition = ({ menuWidth, menuPlacement }) => {\n  const { x, y, reference, floating, strategy, refs } = useFloating({\n    placement: placementsMap[menuPlacement],\n    whileElementsMounted: autoUpdate,\n    middleware: [\n      flip({ padding: 24, flipAlignment: false }),\n      size({\n        apply({ rects, elements }) {\n          const width = getDimension(menuWidth) || `${rects.reference.width}px`;\n          Object.assign(elements.floating.style, {\n            width: width,\n          });\n        },\n        padding: 24,\n      }),\n    ],\n  });\n\n  const floatingStyles = {\n    position: strategy,\n    top: y ?? 0,\n    left: x ?? 0,\n    zIndex: 1100,\n  };\n\n  return {\n    refs,\n    reference,\n    floating,\n    floatingStyles,\n  };\n};\n\nconst menuCardStyles = `\n  .menuCardLeaveTo,\n  .menuCardEnterFrom {\n    opacity: 0;\n  }\n  .menuCardEnterTo {\n    transition-duration: ${getTransition('xxFast')};\n  }\n  .menuCardLeaveTo {\n    transition-duration: ${getTransition('xFast')};\n  }\n`;\n\nexport const MenuCardTransition = forwardRef(({ children, show, ...props }, ref) => (\n  <Transition\n    as={Fragment}\n    enterFrom=\"menuCardEnterFrom\"\n    enterTo=\"menuCardEnterTo\"\n    leaveFrom=\"menuCardLeaveFrom\"\n    leaveTo=\"menuCardLeaveTo\"\n    ref={ref}\n    show={show}\n    {...props}\n  >\n    {children}\n  </Transition>\n));\n\nconst MenuCardUl = styled.ul`\n  padding: ${cardPaddingPx};\n  margin: 0;\n  background: ${getColor('floatingBackground')};\n  z-index: ${({ zIndex }) => zIndex};\n  box-shadow: ${getShadow('m')};\n  border-radius: ${getRadius('m')};\n  overflow: auto;\n  ${({ maxHeight }) => maxHeight && `max-height: ${getSpace(maxHeight)}`};\n  ${({ maxWidth }) => maxWidth && `max-width: ${getSpace(maxWidth)}`};\n  /* to prevent a bug: the menu is not always rmoeved from the DOM, in a animated container */\n  ${({ isDisabled }) => isDisabled && `pointer-events: none;`}\n\n  &:focus {\n    outline: none;\n  }\n`;\n\nexport const MenuCard = forwardRef(\n  ({ children, zIndex = 1, maxHeight, maxWidth, isDisabled, ...props }, ref) => {\n    const menuCardRef = useRef(ref);\n    useImperativeHandle(ref, () => menuCardRef.current, []);\n\n    const scrollToActive = useCallback(() => {\n      // Note: this function is rely on data-headlessui-state attribute\n      const menuCard = menuCardRef.current;\n      const activeItem = menuCard?.querySelector('[data-headlessui-state=\"selected\"]');\n      if (!menuCard || !activeItem) return;\n      const menuCardRect = menuCard.getBoundingClientRect();\n      const activeItemRect = activeItem.getBoundingClientRect();\n      menuCard.scrollTop =\n        activeItem.offsetTop - menuCardRect.height / 2 + activeItemRect.height / 2;\n    }, []);\n\n    useEffect(() => {\n      scrollToActive();\n    }, [scrollToActive]);\n\n    return (\n      <>\n        <Global styles={menuCardStyles} />\n        <MenuCardUl\n          ref={menuCardRef}\n          zIndex={zIndex}\n          maxHeight={maxHeight}\n          maxWidth={maxWidth}\n          isDisabled={isDisabled}\n          className=\"MenuCard grn-context\"\n          {...props}\n        >\n          {children}\n        </MenuCardUl>\n      </>\n    );\n  },\n);\n\nconst variantStyles = {\n  neutral: {\n    backgroundColorActive: getColor('overlay'),\n    iconColorActive: getColor('content'),\n  },\n  danger: {\n    color: getColor('danger'),\n    iconColor: 'var(--grn-icon-danger-color)',\n    iconColorActive: getColor('danger'),\n    backgroundColorActive: 'var(--grn-clearbutton-danger-background-hover)',\n  },\n};\n\nconst MenuItemRoot = styled.li`\n  display: grid;\n  grid-auto-flow: column;\n  gap: 8px;\n  ${({ isDisabled }) => isDisabled && `color: ${getColor('disabledContent')}`};\n  ${({ isDisabled }) => !isDisabled && `cursor: pointer;`};\n  align-items: center;\n  justify-content: start;\n  list-style: none;\n  padding-block: 10px;\n  padding-inline: ${itemXPadding}px;\n  margin: 0;\n  min-height: var(--grn-textbox-height-m);\n  border-radius: ${getRadius('s')};\n  appearance: none;\n  color: ${({ color }) => color};\n\n  [data-experiment-compact-textbox] & {\n    padding-block: ${getSpace('s')};\n  }\n`;\n\nexport const MenuGroupTitle = ({ children }) => (\n  <Box\n    css={css`\n      &:first-of-type {\n        --marginTop: calc(-1 * var(--grn-space-s));\n        --borderColor: transparent;\n      }\n      &:not(:first-of-type) {\n        --marginTop: ${cardPaddingPx};\n        --borderColor: var(--grn-color-border);\n      }\n    `}\n    paddingX={`${cardPadding + itemXPadding}px`}\n    paddingTop=\"m\"\n    paddingBottom={cardPaddingPx}\n    marginTop=\"var(--marginTop)\"\n    borderSide=\"top\"\n    borderColor=\"var(--borderColor)\"\n    marginX={`-${cardPaddingPx}`}\n    position=\"relative\"\n  >\n    <Text variant=\"caps\">{children}</Text>\n  </Box>\n);\n\nexport const MenuItemDivider = () => (\n  <Box height=\"1px\" marginY={1} backgroundColor=\"border\" marginX={`-${cardPaddingPx}`} />\n);\n\nexport const MenuItem = forwardRef(\n  (\n    {\n      children,\n      isSelected,\n      isActive,\n      isDisabled,\n      icon,\n      variant = 'neutral',\n      hasEllipsis,\n      checkVariant = 'check',\n      ...props\n    },\n    ref,\n  ) => {\n    const hasCheck = checkVariant === 'check';\n\n    const getColumns = () => {\n      if (Boolean(icon)) return 'auto 1fr';\n      if (hasCheck) return '1fr auto';\n    };\n\n    return (\n      <MenuItemRoot\n        ref={ref}\n        isSelected={isSelected}\n        isDisabled={isDisabled}\n        color={variantStyles[variant].color}\n        hasIcon={Boolean(icon)}\n        style={{\n          background: isActive && variantStyles[variant].backgroundColorActive,\n          gridTemplateColumns: getColumns(),\n        }}\n        {...props}\n      >\n        {icon && (\n          <Icon\n            icon={icon}\n            hasEvenBoundary\n            color={\n              isActive ? variantStyles[variant].iconColorActive : variantStyles[variant].iconColor\n            }\n          />\n        )}\n        <Box width=\"100%\" minWidth=\"0px\" tag=\"span\">\n          <Text hasEllipsis={hasEllipsis}>{children}</Text>\n        </Box>\n        {hasCheck && (\n          <Box opacity={isSelected ? '1' : '0'}>\n            <Icon icon={<IconCheck />} color={isActive ? 'content' : 'icon'} />\n          </Box>\n        )}\n      </MenuItemRoot>\n    );\n  },\n);\n\nMenuItem.propTypes = {\n  isSelected: PropTypes.bool,\n  isActive: PropTypes.bool,\n  isDisabled: PropTypes.bool,\n  icon: PropTypes.node,\n  variant: PropTypes.oneOf(['neutral', 'danger']),\n  hasEllipsis: PropTypes.bool,\n  checkVariant: PropTypes.oneOf(['check', 'none']),\n};\n\nMenuCard.propTypes = {\n  children: PropTypes.node,\n  zIndex: types.zIndex,\n  maxHeight: types.dimension,\n  maxWidth: types.dimension,\n  isDisabled: PropTypes.bool,\n};\n\nMenuCardTransition.propTypes = {\n  children: PropTypes.node,\n  show: PropTypes.bool,\n};\n"]} */"));
200
200
 
201
201
  export const MenuGroupTitle = _ref12 => {
202
202
  let {
203
203
  children
204
204
  } = _ref12;
205
205
  return ___EmotionJSX(Box, {
206
- css: /*#__PURE__*/css("&:first-of-type{--marginTop:calc(-1 * var(--grn-space-s));--borderColor:transparent;}&:not(:first-of-type){--marginTop:", cardPaddingPx, ";--borderColor:var(--grn-color-border);}" + (process.env.NODE_ENV === "production" ? "" : ";label:MenuGroupTitle;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/foundational/menu.jsx"],"names":[],"mappings":"AAuMY","file":"../../src/foundational/menu.jsx","sourcesContent":["import React, {\n  Fragment,\n  forwardRef,\n  useCallback,\n  useEffect,\n  useImperativeHandle,\n  useRef,\n} from 'react';\nimport PropTypes from 'prop-types';\nimport { Global, css } from '@emotion/react';\nimport {\n  getColor,\n  getDimension,\n  getRadius,\n  getShadow,\n  getSpace,\n  getTransition,\n} from '../utilities';\nimport { Box, Icon, Text } from '../components';\nimport { IconCheck } from '../icons';\nimport { autoUpdate, flip, size, useFloating } from '@floating-ui/react-dom-interactions';\nimport { Transition } from '@headlessui/react';\nimport { types } from '../types';\nimport styled from '@emotion/styled';\n\nconst cardPadding = 8;\nconst cardPaddingPx = `${cardPadding}px`;\nconst itemXPadding = 12;\n\nexport const placementsMap = {\n  top: 'top',\n  topStart: 'top-start',\n  topEnd: 'top-end',\n  bottom: 'bottom',\n  bottomStart: 'bottom-start',\n  bottomEnd: 'bottom-end',\n  right: 'right',\n  rightStart: 'right-start',\n  rightEnd: 'right-end',\n  left: 'left',\n  leftStart: 'left-start',\n  leftEnd: 'left-end',\n};\n\nexport const useMenuPosition = ({ menuWidth, menuPlacement }) => {\n  const { x, y, reference, floating, strategy, refs } = useFloating({\n    placement: placementsMap[menuPlacement],\n    whileElementsMounted: autoUpdate,\n    middleware: [\n      flip({ padding: 24, flipAlignment: false }),\n      size({\n        apply({ rects, elements }) {\n          const width = getDimension(menuWidth) || `${rects.reference.width}px`;\n          Object.assign(elements.floating.style, {\n            width: width,\n          });\n        },\n        padding: 24,\n      }),\n    ],\n  });\n\n  const floatingStyles = {\n    position: strategy,\n    top: y ?? 0,\n    left: x ?? 0,\n    zIndex: 1100,\n  };\n\n  return {\n    refs,\n    reference,\n    floating,\n    floatingStyles,\n  };\n};\n\nconst menuCardStyles = `\n  .menuCardLeaveTo,\n  .menuCardEnterFrom {\n    opacity: 0;\n  }\n  .menuCardEnterTo {\n    transition-duration: ${getTransition('xxFast')};\n  }\n  .menuCardLeaveTo {\n    transition-duration: ${getTransition('xFast')};\n  }\n`;\n\nexport const MenuCardTransition = forwardRef(({ children, show, ...props }, ref) => (\n  <Transition\n    as={Fragment}\n    enterFrom=\"menuCardEnterFrom\"\n    enterTo=\"menuCardEnterTo\"\n    leaveFrom=\"menuCardLeaveFrom\"\n    leaveTo=\"menuCardLeaveTo\"\n    ref={ref}\n    show={show}\n    {...props}\n  >\n    {children}\n  </Transition>\n));\n\nconst MenuCardUl = styled.ul`\n  padding: ${cardPaddingPx};\n  margin: 0;\n  background: ${getColor('floatingBackground')};\n  z-index: ${({ zIndex }) => zIndex};\n  box-shadow: ${getShadow('m')};\n  border-radius: ${getRadius('m')};\n  overflow: auto;\n  ${({ maxHeight }) => maxHeight && `max-height: ${getSpace(maxHeight)}`};\n  ${({ maxWidth }) => maxWidth && `max-width: ${getSpace(maxWidth)}`};\n  /* to prevent a bug: the menu is not always rmoeved from the DOM, in a animated container */\n  ${({ isDisabled }) => isDisabled && `pointer-events: none;`}\n\n  &:focus {\n    outline: none;\n  }\n`;\n\nexport const MenuCard = forwardRef(\n  ({ children, zIndex = 1, maxHeight, maxWidth, isDisabled, ...props }, ref) => {\n    const menuCardRef = useRef(ref);\n    useImperativeHandle(ref, () => menuCardRef.current, []);\n\n    const scrollToActive = useCallback(() => {\n      // Note: this function is rely on data-headlessui-state attribute\n      const menuCard = menuCardRef.current;\n      const activeItem = menuCard?.querySelector('[data-headlessui-state=\"selected\"]');\n      if (!menuCard || !activeItem) return;\n      const menuCardRect = menuCard.getBoundingClientRect();\n      const activeItemRect = activeItem.getBoundingClientRect();\n      menuCard.scrollTop =\n        activeItem.offsetTop - menuCardRect.height / 2 + activeItemRect.height / 2;\n    }, []);\n\n    useEffect(() => {\n      scrollToActive();\n    }, [scrollToActive]);\n\n    return (\n      <>\n        <Global styles={menuCardStyles} />\n        <MenuCardUl\n          ref={menuCardRef}\n          zIndex={zIndex}\n          maxHeight={maxHeight}\n          maxWidth={maxWidth}\n          isDisabled={isDisabled}\n          className=\"MenuCard grn-context\"\n          {...props}\n        >\n          {children}\n        </MenuCardUl>\n      </>\n    );\n  },\n);\n\nconst variantStyles = {\n  neutral: {\n    backgroundColorActive: getColor('fade1'),\n    iconColorActive: getColor('content'),\n  },\n  danger: {\n    color: getColor('danger'),\n    iconColor: 'var(--grn-icon-danger-color)',\n    iconColorActive: getColor('danger'),\n    backgroundColorActive: 'var(--grn-clearbutton-danger-background-hover)',\n  },\n};\n\nconst MenuItemRoot = styled.li`\n  display: grid;\n  grid-auto-flow: column;\n  gap: 8px;\n  ${({ isDisabled }) => isDisabled && `color: ${getColor('disabledContent')}`};\n  ${({ isDisabled }) => !isDisabled && `cursor: pointer;`};\n  align-items: center;\n  justify-content: start;\n  list-style: none;\n  padding-block: 10px;\n  padding-inline: ${itemXPadding}px;\n  margin: 0;\n  min-height: var(--grn-textbox-height-m);\n  border-radius: ${getRadius('s')};\n  appearance: none;\n  color: ${({ color }) => color};\n\n  [data-experiment-compact-textbox] & {\n    padding-block: ${getSpace('s')};\n  }\n`;\n\nexport const MenuGroupTitle = ({ children }) => (\n  <Box\n    css={css`\n      &:first-of-type {\n        --marginTop: calc(-1 * var(--grn-space-s));\n        --borderColor: transparent;\n      }\n      &:not(:first-of-type) {\n        --marginTop: ${cardPaddingPx};\n        --borderColor: var(--grn-color-border);\n      }\n    `}\n    paddingX={`${cardPadding + itemXPadding}px`}\n    paddingTop=\"m\"\n    paddingBottom={cardPaddingPx}\n    marginTop=\"var(--marginTop)\"\n    borderSide=\"top\"\n    borderColor=\"var(--borderColor)\"\n    marginX={`-${cardPaddingPx}`}\n    position=\"relative\"\n  >\n    <Text variant=\"caps\">{children}</Text>\n  </Box>\n);\n\nexport const MenuItemDivider = () => (\n  <Box height=\"1px\" marginY={1} backgroundColor=\"border\" marginX={`-${cardPaddingPx}`} />\n);\n\nexport const MenuItem = forwardRef(\n  (\n    {\n      children,\n      isSelected,\n      isActive,\n      isDisabled,\n      icon,\n      variant = 'neutral',\n      hasEllipsis,\n      checkVariant = 'check',\n      ...props\n    },\n    ref,\n  ) => {\n    const hasCheck = checkVariant === 'check';\n\n    const getColumns = () => {\n      if (Boolean(icon)) return 'auto 1fr';\n      if (hasCheck) return '1fr auto';\n    };\n\n    return (\n      <MenuItemRoot\n        ref={ref}\n        isSelected={isSelected}\n        isDisabled={isDisabled}\n        color={variantStyles[variant].color}\n        hasIcon={Boolean(icon)}\n        style={{\n          background: isActive && variantStyles[variant].backgroundColorActive,\n          gridTemplateColumns: getColumns(),\n        }}\n        {...props}\n      >\n        {icon && (\n          <Icon\n            icon={icon}\n            hasEvenBoundary\n            color={\n              isActive ? variantStyles[variant].iconColorActive : variantStyles[variant].iconColor\n            }\n          />\n        )}\n        <Box width=\"100%\" minWidth=\"0px\" tag=\"span\">\n          <Text hasEllipsis={hasEllipsis}>{children}</Text>\n        </Box>\n        {hasCheck && (\n          <Box opacity={isSelected ? '1' : '0'}>\n            <Icon icon={<IconCheck />} color={isActive ? 'content' : 'icon'} />\n          </Box>\n        )}\n      </MenuItemRoot>\n    );\n  },\n);\n\nMenuItem.propTypes = {\n  isSelected: PropTypes.bool,\n  isActive: PropTypes.bool,\n  isDisabled: PropTypes.bool,\n  icon: PropTypes.node,\n  variant: PropTypes.oneOf(['neutral', 'danger']),\n  hasEllipsis: PropTypes.bool,\n  checkVariant: PropTypes.oneOf(['check', 'none']),\n};\n\nMenuCard.propTypes = {\n  children: PropTypes.node,\n  zIndex: types.zIndex,\n  maxHeight: types.dimension,\n  maxWidth: types.dimension,\n  isDisabled: PropTypes.bool,\n};\n\nMenuCardTransition.propTypes = {\n  children: PropTypes.node,\n  show: PropTypes.bool,\n};\n"]} */"),
206
+ css: /*#__PURE__*/css("&:first-of-type{--marginTop:calc(-1 * var(--grn-space-s));--borderColor:transparent;}&:not(:first-of-type){--marginTop:", cardPaddingPx, ";--borderColor:var(--grn-color-border);}" + (process.env.NODE_ENV === "production" ? "" : ";label:MenuGroupTitle;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/foundational/menu.jsx"],"names":[],"mappings":"AAuMY","file":"../../src/foundational/menu.jsx","sourcesContent":["import React, {\n  Fragment,\n  forwardRef,\n  useCallback,\n  useEffect,\n  useImperativeHandle,\n  useRef,\n} from 'react';\nimport PropTypes from 'prop-types';\nimport { Global, css } from '@emotion/react';\nimport {\n  getColor,\n  getDimension,\n  getRadius,\n  getShadow,\n  getSpace,\n  getTransition,\n} from '../utilities';\nimport { Box, Icon, Text } from '../components';\nimport { IconCheck } from '../icons';\nimport { autoUpdate, flip, size, useFloating } from '@floating-ui/react-dom-interactions';\nimport { Transition } from '@headlessui/react';\nimport { types } from '../types';\nimport styled from '@emotion/styled';\n\nconst cardPadding = 8;\nconst cardPaddingPx = `${cardPadding}px`;\nconst itemXPadding = 12;\n\nexport const placementsMap = {\n  top: 'top',\n  topStart: 'top-start',\n  topEnd: 'top-end',\n  bottom: 'bottom',\n  bottomStart: 'bottom-start',\n  bottomEnd: 'bottom-end',\n  right: 'right',\n  rightStart: 'right-start',\n  rightEnd: 'right-end',\n  left: 'left',\n  leftStart: 'left-start',\n  leftEnd: 'left-end',\n};\n\nexport const useMenuPosition = ({ menuWidth, menuPlacement }) => {\n  const { x, y, reference, floating, strategy, refs } = useFloating({\n    placement: placementsMap[menuPlacement],\n    whileElementsMounted: autoUpdate,\n    middleware: [\n      flip({ padding: 24, flipAlignment: false }),\n      size({\n        apply({ rects, elements }) {\n          const width = getDimension(menuWidth) || `${rects.reference.width}px`;\n          Object.assign(elements.floating.style, {\n            width: width,\n          });\n        },\n        padding: 24,\n      }),\n    ],\n  });\n\n  const floatingStyles = {\n    position: strategy,\n    top: y ?? 0,\n    left: x ?? 0,\n    zIndex: 1100,\n  };\n\n  return {\n    refs,\n    reference,\n    floating,\n    floatingStyles,\n  };\n};\n\nconst menuCardStyles = `\n  .menuCardLeaveTo,\n  .menuCardEnterFrom {\n    opacity: 0;\n  }\n  .menuCardEnterTo {\n    transition-duration: ${getTransition('xxFast')};\n  }\n  .menuCardLeaveTo {\n    transition-duration: ${getTransition('xFast')};\n  }\n`;\n\nexport const MenuCardTransition = forwardRef(({ children, show, ...props }, ref) => (\n  <Transition\n    as={Fragment}\n    enterFrom=\"menuCardEnterFrom\"\n    enterTo=\"menuCardEnterTo\"\n    leaveFrom=\"menuCardLeaveFrom\"\n    leaveTo=\"menuCardLeaveTo\"\n    ref={ref}\n    show={show}\n    {...props}\n  >\n    {children}\n  </Transition>\n));\n\nconst MenuCardUl = styled.ul`\n  padding: ${cardPaddingPx};\n  margin: 0;\n  background: ${getColor('floatingBackground')};\n  z-index: ${({ zIndex }) => zIndex};\n  box-shadow: ${getShadow('m')};\n  border-radius: ${getRadius('m')};\n  overflow: auto;\n  ${({ maxHeight }) => maxHeight && `max-height: ${getSpace(maxHeight)}`};\n  ${({ maxWidth }) => maxWidth && `max-width: ${getSpace(maxWidth)}`};\n  /* to prevent a bug: the menu is not always rmoeved from the DOM, in a animated container */\n  ${({ isDisabled }) => isDisabled && `pointer-events: none;`}\n\n  &:focus {\n    outline: none;\n  }\n`;\n\nexport const MenuCard = forwardRef(\n  ({ children, zIndex = 1, maxHeight, maxWidth, isDisabled, ...props }, ref) => {\n    const menuCardRef = useRef(ref);\n    useImperativeHandle(ref, () => menuCardRef.current, []);\n\n    const scrollToActive = useCallback(() => {\n      // Note: this function is rely on data-headlessui-state attribute\n      const menuCard = menuCardRef.current;\n      const activeItem = menuCard?.querySelector('[data-headlessui-state=\"selected\"]');\n      if (!menuCard || !activeItem) return;\n      const menuCardRect = menuCard.getBoundingClientRect();\n      const activeItemRect = activeItem.getBoundingClientRect();\n      menuCard.scrollTop =\n        activeItem.offsetTop - menuCardRect.height / 2 + activeItemRect.height / 2;\n    }, []);\n\n    useEffect(() => {\n      scrollToActive();\n    }, [scrollToActive]);\n\n    return (\n      <>\n        <Global styles={menuCardStyles} />\n        <MenuCardUl\n          ref={menuCardRef}\n          zIndex={zIndex}\n          maxHeight={maxHeight}\n          maxWidth={maxWidth}\n          isDisabled={isDisabled}\n          className=\"MenuCard grn-context\"\n          {...props}\n        >\n          {children}\n        </MenuCardUl>\n      </>\n    );\n  },\n);\n\nconst variantStyles = {\n  neutral: {\n    backgroundColorActive: getColor('overlay'),\n    iconColorActive: getColor('content'),\n  },\n  danger: {\n    color: getColor('danger'),\n    iconColor: 'var(--grn-icon-danger-color)',\n    iconColorActive: getColor('danger'),\n    backgroundColorActive: 'var(--grn-clearbutton-danger-background-hover)',\n  },\n};\n\nconst MenuItemRoot = styled.li`\n  display: grid;\n  grid-auto-flow: column;\n  gap: 8px;\n  ${({ isDisabled }) => isDisabled && `color: ${getColor('disabledContent')}`};\n  ${({ isDisabled }) => !isDisabled && `cursor: pointer;`};\n  align-items: center;\n  justify-content: start;\n  list-style: none;\n  padding-block: 10px;\n  padding-inline: ${itemXPadding}px;\n  margin: 0;\n  min-height: var(--grn-textbox-height-m);\n  border-radius: ${getRadius('s')};\n  appearance: none;\n  color: ${({ color }) => color};\n\n  [data-experiment-compact-textbox] & {\n    padding-block: ${getSpace('s')};\n  }\n`;\n\nexport const MenuGroupTitle = ({ children }) => (\n  <Box\n    css={css`\n      &:first-of-type {\n        --marginTop: calc(-1 * var(--grn-space-s));\n        --borderColor: transparent;\n      }\n      &:not(:first-of-type) {\n        --marginTop: ${cardPaddingPx};\n        --borderColor: var(--grn-color-border);\n      }\n    `}\n    paddingX={`${cardPadding + itemXPadding}px`}\n    paddingTop=\"m\"\n    paddingBottom={cardPaddingPx}\n    marginTop=\"var(--marginTop)\"\n    borderSide=\"top\"\n    borderColor=\"var(--borderColor)\"\n    marginX={`-${cardPaddingPx}`}\n    position=\"relative\"\n  >\n    <Text variant=\"caps\">{children}</Text>\n  </Box>\n);\n\nexport const MenuItemDivider = () => (\n  <Box height=\"1px\" marginY={1} backgroundColor=\"border\" marginX={`-${cardPaddingPx}`} />\n);\n\nexport const MenuItem = forwardRef(\n  (\n    {\n      children,\n      isSelected,\n      isActive,\n      isDisabled,\n      icon,\n      variant = 'neutral',\n      hasEllipsis,\n      checkVariant = 'check',\n      ...props\n    },\n    ref,\n  ) => {\n    const hasCheck = checkVariant === 'check';\n\n    const getColumns = () => {\n      if (Boolean(icon)) return 'auto 1fr';\n      if (hasCheck) return '1fr auto';\n    };\n\n    return (\n      <MenuItemRoot\n        ref={ref}\n        isSelected={isSelected}\n        isDisabled={isDisabled}\n        color={variantStyles[variant].color}\n        hasIcon={Boolean(icon)}\n        style={{\n          background: isActive && variantStyles[variant].backgroundColorActive,\n          gridTemplateColumns: getColumns(),\n        }}\n        {...props}\n      >\n        {icon && (\n          <Icon\n            icon={icon}\n            hasEvenBoundary\n            color={\n              isActive ? variantStyles[variant].iconColorActive : variantStyles[variant].iconColor\n            }\n          />\n        )}\n        <Box width=\"100%\" minWidth=\"0px\" tag=\"span\">\n          <Text hasEllipsis={hasEllipsis}>{children}</Text>\n        </Box>\n        {hasCheck && (\n          <Box opacity={isSelected ? '1' : '0'}>\n            <Icon icon={<IconCheck />} color={isActive ? 'content' : 'icon'} />\n          </Box>\n        )}\n      </MenuItemRoot>\n    );\n  },\n);\n\nMenuItem.propTypes = {\n  isSelected: PropTypes.bool,\n  isActive: PropTypes.bool,\n  isDisabled: PropTypes.bool,\n  icon: PropTypes.node,\n  variant: PropTypes.oneOf(['neutral', 'danger']),\n  hasEllipsis: PropTypes.bool,\n  checkVariant: PropTypes.oneOf(['check', 'none']),\n};\n\nMenuCard.propTypes = {\n  children: PropTypes.node,\n  zIndex: types.zIndex,\n  maxHeight: types.dimension,\n  maxWidth: types.dimension,\n  isDisabled: PropTypes.bool,\n};\n\nMenuCardTransition.propTypes = {\n  children: PropTypes.node,\n  show: PropTypes.bool,\n};\n"]} */"),
207
207
  paddingX: "".concat(cardPadding + itemXPadding, "px"),
208
208
  paddingTop: "m",
209
209
  paddingBottom: cardPaddingPx,
@@ -12,7 +12,7 @@ const variantStyles = {
12
12
  color: getColor('content'),
13
13
  iconColor: getColor('icon'),
14
14
  hover: {
15
- backgroundColor: getColor('fade1'),
15
+ backgroundColor: getColor('overlay'),
16
16
  iconColor: getColor('content')
17
17
  },
18
18
  active: {
@@ -1,2 +1,2 @@
1
- const theme = "\n /* light */\n\n :root,\n [data-theme='light'],\n [data-theme='dark'] [data-theme='invert'] {\n --grn-color-fade10: var(--grn-color-darkFade10);\n --grn-color-fade9: var(--grn-color-darkFade9);\n --grn-color-fade8: var(--grn-color-darkFade8);\n --grn-color-fade7: var(--grn-color-darkFade7);\n --grn-color-fade6: var(--grn-color-darkFade6);\n --grn-color-fade5: var(--grn-color-darkFade5);\n --grn-color-fade4: var(--grn-color-darkFade4);\n --grn-color-fade3: var(--grn-color-darkFade3);\n --grn-color-fade2: var(--grn-color-darkFade2);\n --grn-color-fade1: var(--grn-color-darkFade1);\n\n --grn-color-shade1: var(--grn-color-shadeTone1);\n --grn-color-shade2: var(--grn-color-shadeTone2);\n --grn-color-shade3: var(--grn-color-shadeTone3);\n --grn-color-shade4: var(--grn-color-shadeTone4);\n --grn-color-shade5: var(--grn-color-shadeTone5);\n --grn-color-shade6: var(--grn-color-shadeTone6);\n --grn-color-shade7: var(--grn-color-shadeTone7);\n --grn-color-shade8: var(--grn-color-shadeTone8);\n --grn-color-shade9: var(--grn-color-shadeTone9);\n --grn-color-shade10: var(--grn-color-shadeTone10);\n --grn-color-shade11: var(--grn-color-shadeTone11);\n --grn-color-shade12: var(--grn-color-shadeTone12);\n --grn-color-shade13: var(--grn-color-shadeTone13);\n }\n\n /* dark */\n\n [data-theme='dark'],\n [data-theme='light'] [data-theme='invert'] {\n --grn-color-fade10: var(--grn-color-lightFade10);\n --grn-color-fade9: var(--grn-color-lightFade9);\n --grn-color-fade8: var(--grn-color-lightFade8);\n --grn-color-fade7: var(--grn-color-lightFade7);\n --grn-color-fade6: var(--grn-color-lightFade6);\n --grn-color-fade5: var(--grn-color-lightFade5);\n --grn-color-fade4: var(--grn-color-lightFade4);\n --grn-color-fade3: var(--grn-color-lightFade3);\n --grn-color-fade2: var(--grn-color-lightFade2);\n --grn-color-fade1: var(--grn-color-lightFade1);\n\n --grn-color-shade1: var(--grn-color-shadeTone13);\n --grn-color-shade2: var(--grn-color-shadeTone12);\n --grn-color-shade3: var(--grn-color-shadeTone11);\n --grn-color-shade4: var(--grn-color-shadeTone10);\n --grn-color-shade5: var(--grn-color-shadeTone9);\n --grn-color-shade6: var(--grn-color-shadeTone8);\n --grn-color-shade7: var(--grn-color-shadeTone7);\n --grn-color-shade8: var(--grn-color-shadeTone6);\n --grn-color-shade9: var(--grn-color-shadeTone5);\n --grn-color-shade10: var(--grn-color-shadeTone4);\n --grn-color-shade11: var(--grn-color-shadeTone3);\n --grn-color-shade12: var(--grn-color-shadeTone2);\n --grn-color-shade13: var(--grn-color-shadeTone1);\n }\n\n /* light */\n\n :root,\n [data-theme='light'],\n [data-theme='dark'] [data-theme='invert'] {\n --content-l: 20%;\n --background-l: 80%;\n --fade-l: var(--bf-s);\n --grn-color-floatingBackground: var(--grn-color-shade1);\n --grn-color-floatingBackground: var(--grn-color-shade1);\n }\n\n /* dark */\n\n [data-theme='dark'],\n [data-theme='light'] [data-theme='invert'] {\n --content-l: 80%;\n --background-l: 20%;\n --fade-l: var(--wf-s);\n --grn-color-floatingBackground: var(--grn-color-shade2);\n --grn-color-floatingBackground: var(--grn-color-shade2);\n }\n\n /* light + dark */\n\n :root,\n [data-theme] {\n --grn-color-content: var(--grn-color-shade12);\n --grn-color-content2: var(--grn-color-fade7);\n --grn-color-content3: var(--grn-color-fade5);\n --grn-color-disabledContent: var(--grn-color-shade7);\n --grn-color-icon: var(--grn-color-fade7);\n --grn-color-disabledIcon: var(--grn-color-fade4);\n\n --grn-color-background: var(--grn-color-shade1);\n --grn-color-background2: var(--grn-color-shade2);\n --grn-color-background3: var(--grn-color-shade3);\n --grn-color-disabledBackground: var(--grn-color-shade4);\n\n --grn-color-border: hsl(var(--shade-hs) var(--content-l) / 12%);\n --grn-color-border2: hsl(var(--shade-hs) var(--content-l) / 20%);\n }\n";
1
+ const theme = "\n /* light */\n\n :root,\n [data-theme='light'],\n [data-theme='dark'] [data-theme='invert'] {\n --grn-color-fade10: var(--grn-color-darkFade10);\n --grn-color-fade9: var(--grn-color-darkFade9);\n --grn-color-fade8: var(--grn-color-darkFade8);\n --grn-color-fade7: var(--grn-color-darkFade7);\n --grn-color-fade6: var(--grn-color-darkFade6);\n --grn-color-fade5: var(--grn-color-darkFade5);\n --grn-color-fade4: var(--grn-color-darkFade4);\n --grn-color-fade3: var(--grn-color-darkFade3);\n --grn-color-fade2: var(--grn-color-darkFade2);\n --grn-color-fade1: var(--grn-color-darkFade1);\n\n --grn-color-shade1: var(--grn-color-shadeTone1);\n --grn-color-shade2: var(--grn-color-shadeTone2);\n --grn-color-shade3: var(--grn-color-shadeTone3);\n --grn-color-shade4: var(--grn-color-shadeTone4);\n --grn-color-shade5: var(--grn-color-shadeTone5);\n --grn-color-shade6: var(--grn-color-shadeTone6);\n --grn-color-shade7: var(--grn-color-shadeTone7);\n --grn-color-shade8: var(--grn-color-shadeTone8);\n --grn-color-shade9: var(--grn-color-shadeTone9);\n --grn-color-shade10: var(--grn-color-shadeTone10);\n --grn-color-shade11: var(--grn-color-shadeTone11);\n --grn-color-shade12: var(--grn-color-shadeTone12);\n --grn-color-shade13: var(--grn-color-shadeTone13);\n }\n\n /* dark */\n\n [data-theme='dark'],\n [data-theme='light'] [data-theme='invert'] {\n --grn-color-fade10: var(--grn-color-lightFade10);\n --grn-color-fade9: var(--grn-color-lightFade9);\n --grn-color-fade8: var(--grn-color-lightFade8);\n --grn-color-fade7: var(--grn-color-lightFade7);\n --grn-color-fade6: var(--grn-color-lightFade6);\n --grn-color-fade5: var(--grn-color-lightFade5);\n --grn-color-fade4: var(--grn-color-lightFade4);\n --grn-color-fade3: var(--grn-color-lightFade3);\n --grn-color-fade2: var(--grn-color-lightFade2);\n --grn-color-fade1: var(--grn-color-lightFade1);\n\n --grn-color-shade1: var(--grn-color-shadeTone13);\n --grn-color-shade2: var(--grn-color-shadeTone12);\n --grn-color-shade3: var(--grn-color-shadeTone11);\n --grn-color-shade4: var(--grn-color-shadeTone10);\n --grn-color-shade5: var(--grn-color-shadeTone9);\n --grn-color-shade6: var(--grn-color-shadeTone8);\n --grn-color-shade7: var(--grn-color-shadeTone7);\n --grn-color-shade8: var(--grn-color-shadeTone6);\n --grn-color-shade9: var(--grn-color-shadeTone5);\n --grn-color-shade10: var(--grn-color-shadeTone4);\n --grn-color-shade11: var(--grn-color-shadeTone3);\n --grn-color-shade12: var(--grn-color-shadeTone2);\n --grn-color-shade13: var(--grn-color-shadeTone1);\n }\n\n /* light */\n\n :root,\n [data-theme='light'],\n [data-theme='dark'] [data-theme='invert'] {\n --content-l: 20%;\n --background-l: 80%;\n --fade-l: var(--bf-s);\n --grn-color-floatingBackground: var(--grn-color-shade1);\n }\n\n /* dark */\n\n [data-theme='dark'],\n [data-theme='light'] [data-theme='invert'] {\n --content-l: 80%;\n --background-l: 20%;\n --fade-l: var(--wf-s);\n --grn-color-floatingBackground: var(--grn-color-shade2);\n }\n\n /* light + dark */\n\n :root,\n [data-theme] {\n --grn-color-content: var(--grn-color-shade12);\n --grn-color-content2: var(--grn-color-fade7);\n --grn-color-content3: var(--grn-color-fade5);\n --grn-color-disabledContent: var(--grn-color-shade7);\n --grn-color-icon: var(--grn-color-fade7);\n --grn-color-disabledIcon: var(--grn-color-fade4);\n\n --grn-color-background: var(--grn-color-shade1);\n --grn-color-background2: var(--grn-color-shade2);\n --grn-color-background3: var(--grn-color-shade3);\n --grn-color-disabledBackground: var(--grn-color-shade4);\n\n --grn-color-border: hsl(var(--shade-hs) var(--content-l) / 12%);\n --grn-color-border2: hsl(var(--shade-hs) var(--content-l) / 20%);\n\n --grn-color-overlay: hsl(var(--shade-h) var(--fade-s) var(--fade-l) / 8%);\n }\n";
2
2
  export default theme;
@@ -91,7 +91,8 @@ export const colors = {
91
91
  background3: 'background3',
92
92
  disabledBackground: 'disabledBackground',
93
93
  floatingBackground: 'floatingBackground',
94
- backdrop: 'backdrop'
94
+ backdrop: 'backdrop',
95
+ overlay: 'overlay'
95
96
  },
96
97
  borders: {
97
98
  border: 'border',
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@flodesk/grain",
3
- "version": "11.50.0",
3
+ "version": "11.51.0",
4
4
  "description": "Flodesk design system",
5
5
  "module": "es/index.js",
6
6
  "types": "es/types/index.d.ts",