@flodesk/grain 10.5.8 → 10.6.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.
@@ -0,0 +1,318 @@
1
+ import "core-js/modules/es.object.keys.js";
2
+ import "core-js/modules/es.array.index-of.js";
3
+ import "core-js/modules/es.symbol.js";
4
+ import "core-js/modules/es.object.assign.js";
5
+ import "core-js/modules/es.symbol.description.js";
6
+ import "core-js/modules/es.symbol.iterator.js";
7
+ import "core-js/modules/es.array.iterator.js";
8
+ import "core-js/modules/es.string.iterator.js";
9
+ import "core-js/modules/web.dom-collections.iterator.js";
10
+ import "core-js/modules/es.array.slice.js";
11
+ import "core-js/modules/es.array.from.js";
12
+ import "core-js/modules/es.regexp.exec.js";
13
+ import _styled from "@emotion/styled/base";
14
+ var _excluded = ["children", "hasEllipsis", "paddingLeft"],
15
+ _excluded2 = ["options", "value", "onChange", "menuPlacement", "menuWidth", "menuMaxHeight", "menuZIndex", "placeholder", "label", "hint", "menuItemsHaveEllipsis", "hasPortal", "hasError", "errorMessage", "searchField"];
16
+
17
+ function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
18
+
19
+ function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
20
+
21
+ function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
22
+
23
+ function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
24
+
25
+ function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
26
+
27
+ function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
28
+
29
+ function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
30
+
31
+ function _objectWithoutProperties(source, excluded) { if (source == null) return {}; var target = _objectWithoutPropertiesLoose(source, excluded); var key, i; if (Object.getOwnPropertySymbols) { var sourceSymbolKeys = Object.getOwnPropertySymbols(source); for (i = 0; i < sourceSymbolKeys.length; i++) { key = sourceSymbolKeys[i]; if (excluded.indexOf(key) >= 0) continue; if (!Object.prototype.propertyIsEnumerable.call(source, key)) continue; target[key] = source[key]; } } return target; }
32
+
33
+ function _objectWithoutPropertiesLoose(source, excluded) { if (source == null) return {}; var target = {}; var sourceKeys = Object.keys(source); var key, i; for (i = 0; i < sourceKeys.length; i++) { key = sourceKeys[i]; if (excluded.indexOf(key) >= 0) continue; target[key] = source[key]; } return target; }
34
+
35
+ import "core-js/modules/es.array.concat.js";
36
+ import "core-js/modules/es.array.filter.js";
37
+ import "core-js/modules/es.object.to-string.js";
38
+ import "core-js/modules/es.array.includes.js";
39
+ import "core-js/modules/es.string.includes.js";
40
+ import "core-js/modules/es.array.find.js";
41
+ import "core-js/modules/es.array.map.js";
42
+
43
+ function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
44
+
45
+ import PropTypes from 'prop-types';
46
+ import React, { forwardRef, Fragment, useMemo, useState } from 'react';
47
+ import { Icon, Box, Text } from '.';
48
+ import { IconChevronDown } from '../icons';
49
+ import { Combobox } from '@headlessui/react';
50
+ import { defaultProps, types } from '../types';
51
+ import { InputField, MenuCard, MenuCardTransition, MenuGroupTitle, FieldLabel, FieldHint, componentVars, styles } from '../foundational';
52
+ import { useMenuPosition } from '../foundational/menu';
53
+ import { FloatingPortal } from '@floating-ui/react-dom-interactions';
54
+ import { css, Global } from '@emotion/react';
55
+ import { getColor, getIconSize, getRadius, getSpace, getTransition } from '../utilities';
56
+ import { jsx as ___EmotionJSX } from "@emotion/react";
57
+
58
+ var Root = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
59
+ target: "ea1qwwn2"
60
+ } : {
61
+ target: "ea1qwwn2",
62
+ label: "Root"
63
+ })(styles.transitions, ";--borderColor:", getColor('fieldBorder'), ";position:relative;margin-top:", function (_ref) {
64
+ var marginTop = _ref.marginTop;
65
+ return getSpace(marginTop);
66
+ }, ";border-radius:", getRadius('s'), ";box-shadow:inset 0 0 0 ", componentVars.strokeSize, " var(--borderColor);&:focus-within{--borderColor:", getColor('fieldBorderFocus'), ";}&:hover{--borderColor:", getColor('fieldBorderHover'), ";}", function (_ref2) {
67
+ var open = _ref2.open;
68
+ return open && "\n --borderColor: ".concat(getColor('fieldBorderFocus'), ";\n\n &:hover {\n --borderColor: ").concat(getColor(open ? 'fieldBorderFocus' : 'fieldBorderHover'), ";\n }\n ");
69
+ }, " ", function (_ref3) {
70
+ var hasError = _ref3.hasError;
71
+ return hasError && "\n --borderColor: ".concat(getColor('danger'), ";\n ");
72
+ }, " .autocompleteInput{line-height:1.4;border:none;opacity:", function (_ref4) {
73
+ var open = _ref4.open;
74
+ return open ? 1 : 0;
75
+ }, ";pointer-events:", function (_ref5) {
76
+ var open = _ref5.open;
77
+ return open ? 'auto' : 'none';
78
+ }, ";transition:opacity ", getTransition('xxFast'), ";&:focus-visible{opacity:1;pointer-events:auto;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/autocomplete2.jsx"],"names":[],"mappings":"AAsBuB","file":"../../src/components/autocomplete2.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { forwardRef, Fragment, useMemo, useState } from 'react';\nimport { Icon, Box, Text } from '.';\nimport { IconChevronDown } from '../icons';\nimport { Combobox } from '@headlessui/react';\nimport { defaultProps, types } from '../types';\nimport {\n  InputField,\n  MenuCard,\n  MenuCardTransition,\n  MenuGroupTitle,\n  FieldLabel,\n  FieldHint,\n  componentVars,\n  styles,\n} from '../foundational';\nimport { useMenuPosition } from '../foundational/menu';\nimport { FloatingPortal } from '@floating-ui/react-dom-interactions';\nimport { css, Global } from '@emotion/react';\nimport { getColor, getIconSize, getRadius, getSpace, getTransition } from '../utilities';\nimport styled from '@emotion/styled';\n\nconst Root = styled.div`\n  ${styles.transitions};\n  --borderColor: ${getColor('fieldBorder')};\n\n  position: relative;\n  margin-top: ${({ marginTop }) => getSpace(marginTop)};\n  border-radius: ${getRadius('s')};\n  box-shadow: inset 0 0 0 ${componentVars.strokeSize} var(--borderColor);\n\n  &:focus-within {\n    --borderColor: ${getColor('fieldBorderFocus')};\n  }\n\n  &:hover {\n    --borderColor: ${getColor('fieldBorderHover')};\n  }\n\n  ${({ open }) =>\n    open &&\n    `\n    --borderColor: ${getColor('fieldBorderFocus')};\n\n    &:hover {\n      --borderColor: ${getColor(open ? 'fieldBorderFocus' : 'fieldBorderHover')};\n    }\n  `}\n\n  ${({ hasError }) =>\n    hasError &&\n    `\n    --borderColor: ${getColor('danger')};\n  `}\n\n  .autocompleteInput {\n    line-height: 1.4;\n    border: none;\n    opacity: ${({ open }) => (open ? 1 : 0)};\n    pointer-events: ${({ open }) => (open ? 'auto' : 'none')};\n    transition: opacity ${getTransition('xxFast')};\n\n    &:focus-visible {\n      opacity: 1;\n      pointer-events: auto;\n    }\n  }\n`;\n\nconst EmptyState = () => (\n  <Box paddingY=\"s\" paddingX=\"m\">\n    <Text color=\"content2\">No results</Text>\n  </Box>\n);\n\nconst ExpandIcon = () => (\n  <Box\n    right=\"fieldPaddingX\"\n    position=\"absolute\"\n    top=\"0px\"\n    bottom=\"0px\"\n    margin=\"auto\"\n    height=\"fit-content\"\n  >\n    <Icon icon={<IconChevronDown />} />\n  </Box>\n);\n\nconst getFilteredOptions = (query, options, searchField) => {\n  if (query === '') return options;\n\n  return options.filter(option => option[searchField].toLowerCase().includes(query.toLowerCase()));\n};\n\nconst getShowGroupTitle = (index, option, filteredOptions) => {\n  const firstOptionHasTitle = index === 0 && option.groupTitle;\n  const titleChanged = index > 0 && option.groupTitle !== filteredOptions[index - 1].groupTitle;\n\n  return firstOptionHasTitle || titleChanged;\n};\n\nconst menuItemStyles = css`\n  .autocompleteMenuItem {\n    display: flex;\n    align-items: center;\n    list-style: none;\n    min-height: ${componentVars.textBoxHeight};\n    border-radius: ${getRadius('s')};\n    appearance: none;\n    padding-block: 0;\n    padding: 4px 12px;\n\n    --checkUri: url('data:image/svg+xml,%3Csvg viewBox=\"0 0 22 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"%3E%3Cpath fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M21.707 6.207L8.5 19.414.293 11.207l1.414-1.414L8.5 16.586 20.293 4.793l1.414 1.414z\" fill=\"%2337312f73\"%3E%3C/path%3E%3C/svg%3E');\n    --checkUriActive: url('data:image/svg+xml,%3Csvg viewBox=\"0 0 22 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"%3E%3Cpath fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M21.707 6.207L8.5 19.414.293 11.207l1.414-1.414L8.5 16.586 20.293 4.793l1.414 1.414z\" fill=\"%23241a17\"%3E%3C/path%3E%3C/svg%3E');\n\n    &[data-headlessui-state='active'],\n    &[data-headlessui-state='active selected'] {\n      background-color: ${getColor('fade1')};\n    }\n\n    &[data-headlessui-state='selected'],\n    &[data-headlessui-state='active selected'] {\n      background-image: var(--checkUri);\n      background-repeat: no-repeat;\n      background-position: center right 12px;\n      background-size: auto ${getIconSize('m')};\n    }\n\n    &[data-headlessui-state='active selected'] {\n      background-image: var(--checkUriActive);\n    }\n\n    &[data-headlessui-state='disabled'] {\n      color: ${getColor('disabledContent')};\n      cursor: default;\n    }\n\n    ul & {\n      cursor: pointer;\n      padding-right: 40px;\n    }\n  }\n\n  .autocompleteMenuItemText {\n    flex-grow: 1;\n\n    &.hasEllipsis {\n      white-space: nowrap;\n      overflow: hidden;\n      text-overflow: ellipsis;\n    }\n  }\n`;\n\nconst Item = forwardRef(({ children, hasEllipsis, paddingLeft = '12px', ...props }, ref) => {\n  return (\n    <li\n      className=\"autocompleteMenuItem\"\n      ref={ref}\n      style={{ paddingLeft: getSpace(paddingLeft) }}\n      {...props}\n    >\n      <span\n        className={\n          hasEllipsis ? 'autocompleteMenuItemText hasEllipsis' : 'autocompleteMenuItemText'\n        }\n      >\n        {children}\n      </span>\n    </li>\n  );\n});\n\nconst Trigger = styled.button`\n  text-align: left;\n  height: ${componentVars.textBoxHeight};\n  background-color: transparent;\n  cursor: text;\n  appearance: none;\n  display: block;\n  font: inherit;\n  color: inherit;\n  width: 100%;\n  outline: none;\n  border: none;\n  padding: 0;\n  opacity: ${({ open }) => (open ? 0 : 1)};\n  pointer-events: ${({ open }) => (open ? 'none' : 'auto')};\n  position: absolute;\n  top: 0;\n  left: 0;\n  transition: opacity ${getTransition('xxFast')};\n\n  .autocompleteMenuItem {\n    padding-right: 34px;\n  }\n\n  .autocompleteInput:focus-visible + & {\n    opacity: 0;\n    pointer-events: none;\n  }\n`;\n\nconst TriggerText = styled.span`\n  line-height: 1.4;\n  display: block;\n  padding-block: 0;\n  padding-left: 12px;\n  padding-right: 32px;\n  text-overflow: ellipsis;\n  overflow: hidden;\n  white-space: nowrap;\n`;\n\nexport const Autocomplete2 = ({\n  options,\n  value,\n  onChange,\n  menuPlacement = defaultProps.menuPlacement,\n  menuWidth,\n  menuMaxHeight = defaultProps.menuMaxHeight,\n  menuZIndex,\n  placeholder,\n  label,\n  hint,\n  menuItemsHaveEllipsis = true,\n  hasPortal = true,\n  hasError,\n  errorMessage,\n  searchField = 'content',\n  ...props\n}) => {\n  const [query, setQuery] = useState('');\n\n  const handleChange = option => {\n    onChange(option);\n    setQuery('');\n  };\n\n  const filteredOptions = getFilteredOptions(query, options, searchField);\n\n  const noResults = !Boolean(filteredOptions.length);\n\n  const fieldMarginTop = label || hint ? 'betweenFormControlAndLabel' : undefined;\n\n  const selectedOption = useMemo(\n    () => options.find(option => option.value === value),\n    [options, value],\n  );\n\n  const { reference, floating, floatingStyles } = useMenuPosition({ menuWidth, menuPlacement });\n\n  const OptionsRoot = hasPortal ? FloatingPortal : Fragment;\n\n  return (\n    <>\n      <Global styles={menuItemStyles} />\n      <Combobox as=\"div\" value={selectedOption || ''} onChange={handleChange} {...props}>\n        {({ open }) => {\n          const hasItem = selectedOption?.item;\n          return (\n            <>\n              {label && <Combobox.Label as={FieldLabel}>{label}</Combobox.Label>}\n              {hint && <FieldHint>{hint}</FieldHint>}\n\n              <Root marginTop={fieldMarginTop} ref={reference} open={open} hasError={hasError}>\n                <Combobox.Button as={Box} position=\"relative\">\n                  <Combobox.Input\n                    as={InputField}\n                    autoComplete=\"off\"\n                    onChange={event => setQuery(event.target.value)}\n                    placeholder={placeholder}\n                    displayValue={option => option && option.content}\n                    paddingRight=\"32px\"\n                    hasError={hasError}\n                    className=\"autocompleteInput\"\n                  />\n\n                  <Trigger open={open} className=\"autocompleteTrigger\" tabIndex={-1}>\n                    {hasItem &&\n                      selectedOption.item({\n                        isActive: false,\n                        isSelected: false,\n                        isDisabled: false,\n                      })}\n\n                    {!hasItem && selectedOption && (\n                      <TriggerText>{selectedOption?.content}</TriggerText>\n                    )}\n                  </Trigger>\n\n                  <ExpandIcon />\n                </Combobox.Button>\n\n                <OptionsRoot>\n                  <MenuCardTransition>\n                    <Combobox.Options\n                      static\n                      className=\"grn-context\"\n                      ref={floating}\n                      placement={menuPlacement}\n                      maxHeight={menuMaxHeight}\n                      as={MenuCard}\n                      zIndex={menuZIndex}\n                      style={floatingStyles}\n                      isOpen={open}\n                      paddingX=\"s\"\n                    >\n                      {filteredOptions.map((option, index) => {\n                        const showGroupTitle = getShowGroupTitle(index, option, filteredOptions);\n\n                        return (\n                          <Fragment key={index}>\n                            {showGroupTitle && (\n                              <MenuGroupTitle hasDivider={index > 0} paddingX=\"12px\">\n                                {option.groupTitle}\n                              </MenuGroupTitle>\n                            )}\n\n                            <Combobox.Option\n                              value={option}\n                              as={Fragment}\n                              disabled={option.isDisabled}\n                            >\n                              {({ active }) => {\n                                const isDisabled = option.isDisabled;\n                                const isSelected = option.value === value;\n                                const isActive = !option.isDisabled && active;\n                                const hasEllipsis = menuItemsHaveEllipsis;\n                                if (option.item) {\n                                  return option.item({\n                                    isActive,\n                                    isSelected,\n                                    isDisabled,\n                                    hasEllipsis,\n                                  });\n                                }\n                                return <Item hasEllipsis={hasEllipsis}>{option.content}</Item>;\n                              }}\n                            </Combobox.Option>\n                          </Fragment>\n                        );\n                      })}\n                      {noResults && <EmptyState />}\n                    </Combobox.Options>\n                  </MenuCardTransition>\n                </OptionsRoot>\n              </Root>\n              {errorMessage && (\n                <Box marginTop=\"betweenFormControlAndLabel\" color=\"danger\">\n                  {errorMessage}\n                </Box>\n              )}\n            </>\n          );\n        }}\n      </Combobox>\n    </>\n  );\n};\n\nAutocomplete2.Label = FieldLabel;\nAutocomplete2.Hint = FieldHint;\nAutocomplete2.Item = Item;\n\nAutocomplete2.propTypes = {\n  options: PropTypes.array,\n  value: PropTypes.string,\n  onChange: PropTypes.func.isRequired,\n  menuPlacement: types.menuPlacement,\n  menuWidth: types.dimension,\n  menuMaxHeight: types.dimension,\n  menuZIndex: types.zIndex,\n  label: types.label,\n  hint: types.hint,\n  menuItemsHaveEllipsis: PropTypes.bool,\n  hasPortal: PropTypes.bool,\n  hasError: PropTypes.bool,\n  errorMessage: PropTypes.string,\n};\n"]} */"));
79
+
80
+ var EmptyState = function EmptyState() {
81
+ return ___EmotionJSX(Box, {
82
+ paddingY: "s",
83
+ paddingX: "m"
84
+ }, ___EmotionJSX(Text, {
85
+ color: "content2"
86
+ }, "No results"));
87
+ };
88
+
89
+ var ExpandIcon = function ExpandIcon() {
90
+ return ___EmotionJSX(Box, {
91
+ right: "fieldPaddingX",
92
+ position: "absolute",
93
+ top: "0px",
94
+ bottom: "0px",
95
+ margin: "auto",
96
+ height: "fit-content"
97
+ }, ___EmotionJSX(Icon, {
98
+ icon: ___EmotionJSX(IconChevronDown, null)
99
+ }));
100
+ };
101
+
102
+ var getFilteredOptions = function getFilteredOptions(query, options, searchField) {
103
+ if (query === '') return options;
104
+ return options.filter(function (option) {
105
+ return option[searchField].toLowerCase().includes(query.toLowerCase());
106
+ });
107
+ };
108
+
109
+ var getShowGroupTitle = function getShowGroupTitle(index, option, filteredOptions) {
110
+ var firstOptionHasTitle = index === 0 && option.groupTitle;
111
+ var titleChanged = index > 0 && option.groupTitle !== filteredOptions[index - 1].groupTitle;
112
+ return firstOptionHasTitle || titleChanged;
113
+ };
114
+
115
+ var menuItemStyles = /*#__PURE__*/css(".autocompleteMenuItem{display:flex;align-items:center;list-style:none;min-height:", componentVars.textBoxHeight, ";border-radius:", getRadius('s'), ";appearance:none;padding-block:0;padding:4px 12px;--checkUri:url('data:image/svg+xml,%3Csvg viewBox=\"0 0 22 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"%3E%3Cpath fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M21.707 6.207L8.5 19.414.293 11.207l1.414-1.414L8.5 16.586 20.293 4.793l1.414 1.414z\" fill=\"%2337312f73\"%3E%3C/path%3E%3C/svg%3E');--checkUriActive:url('data:image/svg+xml,%3Csvg viewBox=\"0 0 22 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"%3E%3Cpath fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M21.707 6.207L8.5 19.414.293 11.207l1.414-1.414L8.5 16.586 20.293 4.793l1.414 1.414z\" fill=\"%23241a17\"%3E%3C/path%3E%3C/svg%3E');&[data-headlessui-state='active'],&[data-headlessui-state='active selected']{background-color:", getColor('fade1'), ";}&[data-headlessui-state='selected'],&[data-headlessui-state='active selected']{background-image:var(--checkUri);background-repeat:no-repeat;background-position:center right 12px;background-size:auto ", getIconSize('m'), ";}&[data-headlessui-state='active selected']{background-image:var(--checkUriActive);}&[data-headlessui-state='disabled']{color:", getColor('disabledContent'), ";cursor:default;}ul &{cursor:pointer;padding-right:40px;}}.autocompleteMenuItemText{flex-grow:1;&.hasEllipsis{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}}" + (process.env.NODE_ENV === "production" ? "" : ";label:menuItemStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/autocomplete2.jsx"],"names":[],"mappings":"AAqG0B","file":"../../src/components/autocomplete2.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { forwardRef, Fragment, useMemo, useState } from 'react';\nimport { Icon, Box, Text } from '.';\nimport { IconChevronDown } from '../icons';\nimport { Combobox } from '@headlessui/react';\nimport { defaultProps, types } from '../types';\nimport {\n  InputField,\n  MenuCard,\n  MenuCardTransition,\n  MenuGroupTitle,\n  FieldLabel,\n  FieldHint,\n  componentVars,\n  styles,\n} from '../foundational';\nimport { useMenuPosition } from '../foundational/menu';\nimport { FloatingPortal } from '@floating-ui/react-dom-interactions';\nimport { css, Global } from '@emotion/react';\nimport { getColor, getIconSize, getRadius, getSpace, getTransition } from '../utilities';\nimport styled from '@emotion/styled';\n\nconst Root = styled.div`\n  ${styles.transitions};\n  --borderColor: ${getColor('fieldBorder')};\n\n  position: relative;\n  margin-top: ${({ marginTop }) => getSpace(marginTop)};\n  border-radius: ${getRadius('s')};\n  box-shadow: inset 0 0 0 ${componentVars.strokeSize} var(--borderColor);\n\n  &:focus-within {\n    --borderColor: ${getColor('fieldBorderFocus')};\n  }\n\n  &:hover {\n    --borderColor: ${getColor('fieldBorderHover')};\n  }\n\n  ${({ open }) =>\n    open &&\n    `\n    --borderColor: ${getColor('fieldBorderFocus')};\n\n    &:hover {\n      --borderColor: ${getColor(open ? 'fieldBorderFocus' : 'fieldBorderHover')};\n    }\n  `}\n\n  ${({ hasError }) =>\n    hasError &&\n    `\n    --borderColor: ${getColor('danger')};\n  `}\n\n  .autocompleteInput {\n    line-height: 1.4;\n    border: none;\n    opacity: ${({ open }) => (open ? 1 : 0)};\n    pointer-events: ${({ open }) => (open ? 'auto' : 'none')};\n    transition: opacity ${getTransition('xxFast')};\n\n    &:focus-visible {\n      opacity: 1;\n      pointer-events: auto;\n    }\n  }\n`;\n\nconst EmptyState = () => (\n  <Box paddingY=\"s\" paddingX=\"m\">\n    <Text color=\"content2\">No results</Text>\n  </Box>\n);\n\nconst ExpandIcon = () => (\n  <Box\n    right=\"fieldPaddingX\"\n    position=\"absolute\"\n    top=\"0px\"\n    bottom=\"0px\"\n    margin=\"auto\"\n    height=\"fit-content\"\n  >\n    <Icon icon={<IconChevronDown />} />\n  </Box>\n);\n\nconst getFilteredOptions = (query, options, searchField) => {\n  if (query === '') return options;\n\n  return options.filter(option => option[searchField].toLowerCase().includes(query.toLowerCase()));\n};\n\nconst getShowGroupTitle = (index, option, filteredOptions) => {\n  const firstOptionHasTitle = index === 0 && option.groupTitle;\n  const titleChanged = index > 0 && option.groupTitle !== filteredOptions[index - 1].groupTitle;\n\n  return firstOptionHasTitle || titleChanged;\n};\n\nconst menuItemStyles = css`\n  .autocompleteMenuItem {\n    display: flex;\n    align-items: center;\n    list-style: none;\n    min-height: ${componentVars.textBoxHeight};\n    border-radius: ${getRadius('s')};\n    appearance: none;\n    padding-block: 0;\n    padding: 4px 12px;\n\n    --checkUri: url('data:image/svg+xml,%3Csvg viewBox=\"0 0 22 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"%3E%3Cpath fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M21.707 6.207L8.5 19.414.293 11.207l1.414-1.414L8.5 16.586 20.293 4.793l1.414 1.414z\" fill=\"%2337312f73\"%3E%3C/path%3E%3C/svg%3E');\n    --checkUriActive: url('data:image/svg+xml,%3Csvg viewBox=\"0 0 22 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"%3E%3Cpath fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M21.707 6.207L8.5 19.414.293 11.207l1.414-1.414L8.5 16.586 20.293 4.793l1.414 1.414z\" fill=\"%23241a17\"%3E%3C/path%3E%3C/svg%3E');\n\n    &[data-headlessui-state='active'],\n    &[data-headlessui-state='active selected'] {\n      background-color: ${getColor('fade1')};\n    }\n\n    &[data-headlessui-state='selected'],\n    &[data-headlessui-state='active selected'] {\n      background-image: var(--checkUri);\n      background-repeat: no-repeat;\n      background-position: center right 12px;\n      background-size: auto ${getIconSize('m')};\n    }\n\n    &[data-headlessui-state='active selected'] {\n      background-image: var(--checkUriActive);\n    }\n\n    &[data-headlessui-state='disabled'] {\n      color: ${getColor('disabledContent')};\n      cursor: default;\n    }\n\n    ul & {\n      cursor: pointer;\n      padding-right: 40px;\n    }\n  }\n\n  .autocompleteMenuItemText {\n    flex-grow: 1;\n\n    &.hasEllipsis {\n      white-space: nowrap;\n      overflow: hidden;\n      text-overflow: ellipsis;\n    }\n  }\n`;\n\nconst Item = forwardRef(({ children, hasEllipsis, paddingLeft = '12px', ...props }, ref) => {\n  return (\n    <li\n      className=\"autocompleteMenuItem\"\n      ref={ref}\n      style={{ paddingLeft: getSpace(paddingLeft) }}\n      {...props}\n    >\n      <span\n        className={\n          hasEllipsis ? 'autocompleteMenuItemText hasEllipsis' : 'autocompleteMenuItemText'\n        }\n      >\n        {children}\n      </span>\n    </li>\n  );\n});\n\nconst Trigger = styled.button`\n  text-align: left;\n  height: ${componentVars.textBoxHeight};\n  background-color: transparent;\n  cursor: text;\n  appearance: none;\n  display: block;\n  font: inherit;\n  color: inherit;\n  width: 100%;\n  outline: none;\n  border: none;\n  padding: 0;\n  opacity: ${({ open }) => (open ? 0 : 1)};\n  pointer-events: ${({ open }) => (open ? 'none' : 'auto')};\n  position: absolute;\n  top: 0;\n  left: 0;\n  transition: opacity ${getTransition('xxFast')};\n\n  .autocompleteMenuItem {\n    padding-right: 34px;\n  }\n\n  .autocompleteInput:focus-visible + & {\n    opacity: 0;\n    pointer-events: none;\n  }\n`;\n\nconst TriggerText = styled.span`\n  line-height: 1.4;\n  display: block;\n  padding-block: 0;\n  padding-left: 12px;\n  padding-right: 32px;\n  text-overflow: ellipsis;\n  overflow: hidden;\n  white-space: nowrap;\n`;\n\nexport const Autocomplete2 = ({\n  options,\n  value,\n  onChange,\n  menuPlacement = defaultProps.menuPlacement,\n  menuWidth,\n  menuMaxHeight = defaultProps.menuMaxHeight,\n  menuZIndex,\n  placeholder,\n  label,\n  hint,\n  menuItemsHaveEllipsis = true,\n  hasPortal = true,\n  hasError,\n  errorMessage,\n  searchField = 'content',\n  ...props\n}) => {\n  const [query, setQuery] = useState('');\n\n  const handleChange = option => {\n    onChange(option);\n    setQuery('');\n  };\n\n  const filteredOptions = getFilteredOptions(query, options, searchField);\n\n  const noResults = !Boolean(filteredOptions.length);\n\n  const fieldMarginTop = label || hint ? 'betweenFormControlAndLabel' : undefined;\n\n  const selectedOption = useMemo(\n    () => options.find(option => option.value === value),\n    [options, value],\n  );\n\n  const { reference, floating, floatingStyles } = useMenuPosition({ menuWidth, menuPlacement });\n\n  const OptionsRoot = hasPortal ? FloatingPortal : Fragment;\n\n  return (\n    <>\n      <Global styles={menuItemStyles} />\n      <Combobox as=\"div\" value={selectedOption || ''} onChange={handleChange} {...props}>\n        {({ open }) => {\n          const hasItem = selectedOption?.item;\n          return (\n            <>\n              {label && <Combobox.Label as={FieldLabel}>{label}</Combobox.Label>}\n              {hint && <FieldHint>{hint}</FieldHint>}\n\n              <Root marginTop={fieldMarginTop} ref={reference} open={open} hasError={hasError}>\n                <Combobox.Button as={Box} position=\"relative\">\n                  <Combobox.Input\n                    as={InputField}\n                    autoComplete=\"off\"\n                    onChange={event => setQuery(event.target.value)}\n                    placeholder={placeholder}\n                    displayValue={option => option && option.content}\n                    paddingRight=\"32px\"\n                    hasError={hasError}\n                    className=\"autocompleteInput\"\n                  />\n\n                  <Trigger open={open} className=\"autocompleteTrigger\" tabIndex={-1}>\n                    {hasItem &&\n                      selectedOption.item({\n                        isActive: false,\n                        isSelected: false,\n                        isDisabled: false,\n                      })}\n\n                    {!hasItem && selectedOption && (\n                      <TriggerText>{selectedOption?.content}</TriggerText>\n                    )}\n                  </Trigger>\n\n                  <ExpandIcon />\n                </Combobox.Button>\n\n                <OptionsRoot>\n                  <MenuCardTransition>\n                    <Combobox.Options\n                      static\n                      className=\"grn-context\"\n                      ref={floating}\n                      placement={menuPlacement}\n                      maxHeight={menuMaxHeight}\n                      as={MenuCard}\n                      zIndex={menuZIndex}\n                      style={floatingStyles}\n                      isOpen={open}\n                      paddingX=\"s\"\n                    >\n                      {filteredOptions.map((option, index) => {\n                        const showGroupTitle = getShowGroupTitle(index, option, filteredOptions);\n\n                        return (\n                          <Fragment key={index}>\n                            {showGroupTitle && (\n                              <MenuGroupTitle hasDivider={index > 0} paddingX=\"12px\">\n                                {option.groupTitle}\n                              </MenuGroupTitle>\n                            )}\n\n                            <Combobox.Option\n                              value={option}\n                              as={Fragment}\n                              disabled={option.isDisabled}\n                            >\n                              {({ active }) => {\n                                const isDisabled = option.isDisabled;\n                                const isSelected = option.value === value;\n                                const isActive = !option.isDisabled && active;\n                                const hasEllipsis = menuItemsHaveEllipsis;\n                                if (option.item) {\n                                  return option.item({\n                                    isActive,\n                                    isSelected,\n                                    isDisabled,\n                                    hasEllipsis,\n                                  });\n                                }\n                                return <Item hasEllipsis={hasEllipsis}>{option.content}</Item>;\n                              }}\n                            </Combobox.Option>\n                          </Fragment>\n                        );\n                      })}\n                      {noResults && <EmptyState />}\n                    </Combobox.Options>\n                  </MenuCardTransition>\n                </OptionsRoot>\n              </Root>\n              {errorMessage && (\n                <Box marginTop=\"betweenFormControlAndLabel\" color=\"danger\">\n                  {errorMessage}\n                </Box>\n              )}\n            </>\n          );\n        }}\n      </Combobox>\n    </>\n  );\n};\n\nAutocomplete2.Label = FieldLabel;\nAutocomplete2.Hint = FieldHint;\nAutocomplete2.Item = Item;\n\nAutocomplete2.propTypes = {\n  options: PropTypes.array,\n  value: PropTypes.string,\n  onChange: PropTypes.func.isRequired,\n  menuPlacement: types.menuPlacement,\n  menuWidth: types.dimension,\n  menuMaxHeight: types.dimension,\n  menuZIndex: types.zIndex,\n  label: types.label,\n  hint: types.hint,\n  menuItemsHaveEllipsis: PropTypes.bool,\n  hasPortal: PropTypes.bool,\n  hasError: PropTypes.bool,\n  errorMessage: PropTypes.string,\n};\n"]} */");
116
+ var Item = /*#__PURE__*/forwardRef(function (_ref6, ref) {
117
+ var children = _ref6.children,
118
+ hasEllipsis = _ref6.hasEllipsis,
119
+ _ref6$paddingLeft = _ref6.paddingLeft,
120
+ paddingLeft = _ref6$paddingLeft === void 0 ? '12px' : _ref6$paddingLeft,
121
+ props = _objectWithoutProperties(_ref6, _excluded);
122
+
123
+ return ___EmotionJSX("li", _extends({
124
+ className: "autocompleteMenuItem",
125
+ ref: ref,
126
+ style: {
127
+ paddingLeft: getSpace(paddingLeft)
128
+ }
129
+ }, props), ___EmotionJSX("span", {
130
+ className: hasEllipsis ? 'autocompleteMenuItemText hasEllipsis' : 'autocompleteMenuItemText'
131
+ }, children));
132
+ });
133
+
134
+ var Trigger = /*#__PURE__*/_styled("button", process.env.NODE_ENV === "production" ? {
135
+ target: "ea1qwwn1"
136
+ } : {
137
+ target: "ea1qwwn1",
138
+ label: "Trigger"
139
+ })("text-align:left;height:", componentVars.textBoxHeight, ";background-color:transparent;cursor:text;appearance:none;display:block;font:inherit;color:inherit;width:100%;outline:none;border:none;padding:0;opacity:", function (_ref7) {
140
+ var open = _ref7.open;
141
+ return open ? 0 : 1;
142
+ }, ";pointer-events:", function (_ref8) {
143
+ var open = _ref8.open;
144
+ return open ? 'none' : 'auto';
145
+ }, ";position:absolute;top:0;left:0;transition:opacity ", getTransition('xxFast'), ";.autocompleteMenuItem{padding-right:34px;}.autocompleteInput:focus-visible+&{opacity:0;pointer-events:none;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/autocomplete2.jsx"],"names":[],"mappings":"AA6K6B","file":"../../src/components/autocomplete2.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { forwardRef, Fragment, useMemo, useState } from 'react';\nimport { Icon, Box, Text } from '.';\nimport { IconChevronDown } from '../icons';\nimport { Combobox } from '@headlessui/react';\nimport { defaultProps, types } from '../types';\nimport {\n  InputField,\n  MenuCard,\n  MenuCardTransition,\n  MenuGroupTitle,\n  FieldLabel,\n  FieldHint,\n  componentVars,\n  styles,\n} from '../foundational';\nimport { useMenuPosition } from '../foundational/menu';\nimport { FloatingPortal } from '@floating-ui/react-dom-interactions';\nimport { css, Global } from '@emotion/react';\nimport { getColor, getIconSize, getRadius, getSpace, getTransition } from '../utilities';\nimport styled from '@emotion/styled';\n\nconst Root = styled.div`\n  ${styles.transitions};\n  --borderColor: ${getColor('fieldBorder')};\n\n  position: relative;\n  margin-top: ${({ marginTop }) => getSpace(marginTop)};\n  border-radius: ${getRadius('s')};\n  box-shadow: inset 0 0 0 ${componentVars.strokeSize} var(--borderColor);\n\n  &:focus-within {\n    --borderColor: ${getColor('fieldBorderFocus')};\n  }\n\n  &:hover {\n    --borderColor: ${getColor('fieldBorderHover')};\n  }\n\n  ${({ open }) =>\n    open &&\n    `\n    --borderColor: ${getColor('fieldBorderFocus')};\n\n    &:hover {\n      --borderColor: ${getColor(open ? 'fieldBorderFocus' : 'fieldBorderHover')};\n    }\n  `}\n\n  ${({ hasError }) =>\n    hasError &&\n    `\n    --borderColor: ${getColor('danger')};\n  `}\n\n  .autocompleteInput {\n    line-height: 1.4;\n    border: none;\n    opacity: ${({ open }) => (open ? 1 : 0)};\n    pointer-events: ${({ open }) => (open ? 'auto' : 'none')};\n    transition: opacity ${getTransition('xxFast')};\n\n    &:focus-visible {\n      opacity: 1;\n      pointer-events: auto;\n    }\n  }\n`;\n\nconst EmptyState = () => (\n  <Box paddingY=\"s\" paddingX=\"m\">\n    <Text color=\"content2\">No results</Text>\n  </Box>\n);\n\nconst ExpandIcon = () => (\n  <Box\n    right=\"fieldPaddingX\"\n    position=\"absolute\"\n    top=\"0px\"\n    bottom=\"0px\"\n    margin=\"auto\"\n    height=\"fit-content\"\n  >\n    <Icon icon={<IconChevronDown />} />\n  </Box>\n);\n\nconst getFilteredOptions = (query, options, searchField) => {\n  if (query === '') return options;\n\n  return options.filter(option => option[searchField].toLowerCase().includes(query.toLowerCase()));\n};\n\nconst getShowGroupTitle = (index, option, filteredOptions) => {\n  const firstOptionHasTitle = index === 0 && option.groupTitle;\n  const titleChanged = index > 0 && option.groupTitle !== filteredOptions[index - 1].groupTitle;\n\n  return firstOptionHasTitle || titleChanged;\n};\n\nconst menuItemStyles = css`\n  .autocompleteMenuItem {\n    display: flex;\n    align-items: center;\n    list-style: none;\n    min-height: ${componentVars.textBoxHeight};\n    border-radius: ${getRadius('s')};\n    appearance: none;\n    padding-block: 0;\n    padding: 4px 12px;\n\n    --checkUri: url('data:image/svg+xml,%3Csvg viewBox=\"0 0 22 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"%3E%3Cpath fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M21.707 6.207L8.5 19.414.293 11.207l1.414-1.414L8.5 16.586 20.293 4.793l1.414 1.414z\" fill=\"%2337312f73\"%3E%3C/path%3E%3C/svg%3E');\n    --checkUriActive: url('data:image/svg+xml,%3Csvg viewBox=\"0 0 22 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"%3E%3Cpath fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M21.707 6.207L8.5 19.414.293 11.207l1.414-1.414L8.5 16.586 20.293 4.793l1.414 1.414z\" fill=\"%23241a17\"%3E%3C/path%3E%3C/svg%3E');\n\n    &[data-headlessui-state='active'],\n    &[data-headlessui-state='active selected'] {\n      background-color: ${getColor('fade1')};\n    }\n\n    &[data-headlessui-state='selected'],\n    &[data-headlessui-state='active selected'] {\n      background-image: var(--checkUri);\n      background-repeat: no-repeat;\n      background-position: center right 12px;\n      background-size: auto ${getIconSize('m')};\n    }\n\n    &[data-headlessui-state='active selected'] {\n      background-image: var(--checkUriActive);\n    }\n\n    &[data-headlessui-state='disabled'] {\n      color: ${getColor('disabledContent')};\n      cursor: default;\n    }\n\n    ul & {\n      cursor: pointer;\n      padding-right: 40px;\n    }\n  }\n\n  .autocompleteMenuItemText {\n    flex-grow: 1;\n\n    &.hasEllipsis {\n      white-space: nowrap;\n      overflow: hidden;\n      text-overflow: ellipsis;\n    }\n  }\n`;\n\nconst Item = forwardRef(({ children, hasEllipsis, paddingLeft = '12px', ...props }, ref) => {\n  return (\n    <li\n      className=\"autocompleteMenuItem\"\n      ref={ref}\n      style={{ paddingLeft: getSpace(paddingLeft) }}\n      {...props}\n    >\n      <span\n        className={\n          hasEllipsis ? 'autocompleteMenuItemText hasEllipsis' : 'autocompleteMenuItemText'\n        }\n      >\n        {children}\n      </span>\n    </li>\n  );\n});\n\nconst Trigger = styled.button`\n  text-align: left;\n  height: ${componentVars.textBoxHeight};\n  background-color: transparent;\n  cursor: text;\n  appearance: none;\n  display: block;\n  font: inherit;\n  color: inherit;\n  width: 100%;\n  outline: none;\n  border: none;\n  padding: 0;\n  opacity: ${({ open }) => (open ? 0 : 1)};\n  pointer-events: ${({ open }) => (open ? 'none' : 'auto')};\n  position: absolute;\n  top: 0;\n  left: 0;\n  transition: opacity ${getTransition('xxFast')};\n\n  .autocompleteMenuItem {\n    padding-right: 34px;\n  }\n\n  .autocompleteInput:focus-visible + & {\n    opacity: 0;\n    pointer-events: none;\n  }\n`;\n\nconst TriggerText = styled.span`\n  line-height: 1.4;\n  display: block;\n  padding-block: 0;\n  padding-left: 12px;\n  padding-right: 32px;\n  text-overflow: ellipsis;\n  overflow: hidden;\n  white-space: nowrap;\n`;\n\nexport const Autocomplete2 = ({\n  options,\n  value,\n  onChange,\n  menuPlacement = defaultProps.menuPlacement,\n  menuWidth,\n  menuMaxHeight = defaultProps.menuMaxHeight,\n  menuZIndex,\n  placeholder,\n  label,\n  hint,\n  menuItemsHaveEllipsis = true,\n  hasPortal = true,\n  hasError,\n  errorMessage,\n  searchField = 'content',\n  ...props\n}) => {\n  const [query, setQuery] = useState('');\n\n  const handleChange = option => {\n    onChange(option);\n    setQuery('');\n  };\n\n  const filteredOptions = getFilteredOptions(query, options, searchField);\n\n  const noResults = !Boolean(filteredOptions.length);\n\n  const fieldMarginTop = label || hint ? 'betweenFormControlAndLabel' : undefined;\n\n  const selectedOption = useMemo(\n    () => options.find(option => option.value === value),\n    [options, value],\n  );\n\n  const { reference, floating, floatingStyles } = useMenuPosition({ menuWidth, menuPlacement });\n\n  const OptionsRoot = hasPortal ? FloatingPortal : Fragment;\n\n  return (\n    <>\n      <Global styles={menuItemStyles} />\n      <Combobox as=\"div\" value={selectedOption || ''} onChange={handleChange} {...props}>\n        {({ open }) => {\n          const hasItem = selectedOption?.item;\n          return (\n            <>\n              {label && <Combobox.Label as={FieldLabel}>{label}</Combobox.Label>}\n              {hint && <FieldHint>{hint}</FieldHint>}\n\n              <Root marginTop={fieldMarginTop} ref={reference} open={open} hasError={hasError}>\n                <Combobox.Button as={Box} position=\"relative\">\n                  <Combobox.Input\n                    as={InputField}\n                    autoComplete=\"off\"\n                    onChange={event => setQuery(event.target.value)}\n                    placeholder={placeholder}\n                    displayValue={option => option && option.content}\n                    paddingRight=\"32px\"\n                    hasError={hasError}\n                    className=\"autocompleteInput\"\n                  />\n\n                  <Trigger open={open} className=\"autocompleteTrigger\" tabIndex={-1}>\n                    {hasItem &&\n                      selectedOption.item({\n                        isActive: false,\n                        isSelected: false,\n                        isDisabled: false,\n                      })}\n\n                    {!hasItem && selectedOption && (\n                      <TriggerText>{selectedOption?.content}</TriggerText>\n                    )}\n                  </Trigger>\n\n                  <ExpandIcon />\n                </Combobox.Button>\n\n                <OptionsRoot>\n                  <MenuCardTransition>\n                    <Combobox.Options\n                      static\n                      className=\"grn-context\"\n                      ref={floating}\n                      placement={menuPlacement}\n                      maxHeight={menuMaxHeight}\n                      as={MenuCard}\n                      zIndex={menuZIndex}\n                      style={floatingStyles}\n                      isOpen={open}\n                      paddingX=\"s\"\n                    >\n                      {filteredOptions.map((option, index) => {\n                        const showGroupTitle = getShowGroupTitle(index, option, filteredOptions);\n\n                        return (\n                          <Fragment key={index}>\n                            {showGroupTitle && (\n                              <MenuGroupTitle hasDivider={index > 0} paddingX=\"12px\">\n                                {option.groupTitle}\n                              </MenuGroupTitle>\n                            )}\n\n                            <Combobox.Option\n                              value={option}\n                              as={Fragment}\n                              disabled={option.isDisabled}\n                            >\n                              {({ active }) => {\n                                const isDisabled = option.isDisabled;\n                                const isSelected = option.value === value;\n                                const isActive = !option.isDisabled && active;\n                                const hasEllipsis = menuItemsHaveEllipsis;\n                                if (option.item) {\n                                  return option.item({\n                                    isActive,\n                                    isSelected,\n                                    isDisabled,\n                                    hasEllipsis,\n                                  });\n                                }\n                                return <Item hasEllipsis={hasEllipsis}>{option.content}</Item>;\n                              }}\n                            </Combobox.Option>\n                          </Fragment>\n                        );\n                      })}\n                      {noResults && <EmptyState />}\n                    </Combobox.Options>\n                  </MenuCardTransition>\n                </OptionsRoot>\n              </Root>\n              {errorMessage && (\n                <Box marginTop=\"betweenFormControlAndLabel\" color=\"danger\">\n                  {errorMessage}\n                </Box>\n              )}\n            </>\n          );\n        }}\n      </Combobox>\n    </>\n  );\n};\n\nAutocomplete2.Label = FieldLabel;\nAutocomplete2.Hint = FieldHint;\nAutocomplete2.Item = Item;\n\nAutocomplete2.propTypes = {\n  options: PropTypes.array,\n  value: PropTypes.string,\n  onChange: PropTypes.func.isRequired,\n  menuPlacement: types.menuPlacement,\n  menuWidth: types.dimension,\n  menuMaxHeight: types.dimension,\n  menuZIndex: types.zIndex,\n  label: types.label,\n  hint: types.hint,\n  menuItemsHaveEllipsis: PropTypes.bool,\n  hasPortal: PropTypes.bool,\n  hasError: PropTypes.bool,\n  errorMessage: PropTypes.string,\n};\n"]} */"));
146
+
147
+ var TriggerText = /*#__PURE__*/_styled("span", process.env.NODE_ENV === "production" ? {
148
+ target: "ea1qwwn0"
149
+ } : {
150
+ target: "ea1qwwn0",
151
+ label: "TriggerText"
152
+ })(process.env.NODE_ENV === "production" ? {
153
+ name: "nabtlt",
154
+ styles: "line-height:1.4;display:block;padding-block:0;padding-left:12px;padding-right:32px;text-overflow:ellipsis;overflow:hidden;white-space:nowrap"
155
+ } : {
156
+ name: "nabtlt",
157
+ styles: "line-height:1.4;display:block;padding-block:0;padding-left:12px;padding-right:32px;text-overflow:ellipsis;overflow:hidden;white-space:nowrap",
158
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/components/autocomplete2.jsx"],"names":[],"mappings":"AA2M+B","file":"../../src/components/autocomplete2.jsx","sourcesContent":["import PropTypes from 'prop-types';\nimport React, { forwardRef, Fragment, useMemo, useState } from 'react';\nimport { Icon, Box, Text } from '.';\nimport { IconChevronDown } from '../icons';\nimport { Combobox } from '@headlessui/react';\nimport { defaultProps, types } from '../types';\nimport {\n  InputField,\n  MenuCard,\n  MenuCardTransition,\n  MenuGroupTitle,\n  FieldLabel,\n  FieldHint,\n  componentVars,\n  styles,\n} from '../foundational';\nimport { useMenuPosition } from '../foundational/menu';\nimport { FloatingPortal } from '@floating-ui/react-dom-interactions';\nimport { css, Global } from '@emotion/react';\nimport { getColor, getIconSize, getRadius, getSpace, getTransition } from '../utilities';\nimport styled from '@emotion/styled';\n\nconst Root = styled.div`\n  ${styles.transitions};\n  --borderColor: ${getColor('fieldBorder')};\n\n  position: relative;\n  margin-top: ${({ marginTop }) => getSpace(marginTop)};\n  border-radius: ${getRadius('s')};\n  box-shadow: inset 0 0 0 ${componentVars.strokeSize} var(--borderColor);\n\n  &:focus-within {\n    --borderColor: ${getColor('fieldBorderFocus')};\n  }\n\n  &:hover {\n    --borderColor: ${getColor('fieldBorderHover')};\n  }\n\n  ${({ open }) =>\n    open &&\n    `\n    --borderColor: ${getColor('fieldBorderFocus')};\n\n    &:hover {\n      --borderColor: ${getColor(open ? 'fieldBorderFocus' : 'fieldBorderHover')};\n    }\n  `}\n\n  ${({ hasError }) =>\n    hasError &&\n    `\n    --borderColor: ${getColor('danger')};\n  `}\n\n  .autocompleteInput {\n    line-height: 1.4;\n    border: none;\n    opacity: ${({ open }) => (open ? 1 : 0)};\n    pointer-events: ${({ open }) => (open ? 'auto' : 'none')};\n    transition: opacity ${getTransition('xxFast')};\n\n    &:focus-visible {\n      opacity: 1;\n      pointer-events: auto;\n    }\n  }\n`;\n\nconst EmptyState = () => (\n  <Box paddingY=\"s\" paddingX=\"m\">\n    <Text color=\"content2\">No results</Text>\n  </Box>\n);\n\nconst ExpandIcon = () => (\n  <Box\n    right=\"fieldPaddingX\"\n    position=\"absolute\"\n    top=\"0px\"\n    bottom=\"0px\"\n    margin=\"auto\"\n    height=\"fit-content\"\n  >\n    <Icon icon={<IconChevronDown />} />\n  </Box>\n);\n\nconst getFilteredOptions = (query, options, searchField) => {\n  if (query === '') return options;\n\n  return options.filter(option => option[searchField].toLowerCase().includes(query.toLowerCase()));\n};\n\nconst getShowGroupTitle = (index, option, filteredOptions) => {\n  const firstOptionHasTitle = index === 0 && option.groupTitle;\n  const titleChanged = index > 0 && option.groupTitle !== filteredOptions[index - 1].groupTitle;\n\n  return firstOptionHasTitle || titleChanged;\n};\n\nconst menuItemStyles = css`\n  .autocompleteMenuItem {\n    display: flex;\n    align-items: center;\n    list-style: none;\n    min-height: ${componentVars.textBoxHeight};\n    border-radius: ${getRadius('s')};\n    appearance: none;\n    padding-block: 0;\n    padding: 4px 12px;\n\n    --checkUri: url('data:image/svg+xml,%3Csvg viewBox=\"0 0 22 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"%3E%3Cpath fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M21.707 6.207L8.5 19.414.293 11.207l1.414-1.414L8.5 16.586 20.293 4.793l1.414 1.414z\" fill=\"%2337312f73\"%3E%3C/path%3E%3C/svg%3E');\n    --checkUriActive: url('data:image/svg+xml,%3Csvg viewBox=\"0 0 22 24\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\"%3E%3Cpath fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M21.707 6.207L8.5 19.414.293 11.207l1.414-1.414L8.5 16.586 20.293 4.793l1.414 1.414z\" fill=\"%23241a17\"%3E%3C/path%3E%3C/svg%3E');\n\n    &[data-headlessui-state='active'],\n    &[data-headlessui-state='active selected'] {\n      background-color: ${getColor('fade1')};\n    }\n\n    &[data-headlessui-state='selected'],\n    &[data-headlessui-state='active selected'] {\n      background-image: var(--checkUri);\n      background-repeat: no-repeat;\n      background-position: center right 12px;\n      background-size: auto ${getIconSize('m')};\n    }\n\n    &[data-headlessui-state='active selected'] {\n      background-image: var(--checkUriActive);\n    }\n\n    &[data-headlessui-state='disabled'] {\n      color: ${getColor('disabledContent')};\n      cursor: default;\n    }\n\n    ul & {\n      cursor: pointer;\n      padding-right: 40px;\n    }\n  }\n\n  .autocompleteMenuItemText {\n    flex-grow: 1;\n\n    &.hasEllipsis {\n      white-space: nowrap;\n      overflow: hidden;\n      text-overflow: ellipsis;\n    }\n  }\n`;\n\nconst Item = forwardRef(({ children, hasEllipsis, paddingLeft = '12px', ...props }, ref) => {\n  return (\n    <li\n      className=\"autocompleteMenuItem\"\n      ref={ref}\n      style={{ paddingLeft: getSpace(paddingLeft) }}\n      {...props}\n    >\n      <span\n        className={\n          hasEllipsis ? 'autocompleteMenuItemText hasEllipsis' : 'autocompleteMenuItemText'\n        }\n      >\n        {children}\n      </span>\n    </li>\n  );\n});\n\nconst Trigger = styled.button`\n  text-align: left;\n  height: ${componentVars.textBoxHeight};\n  background-color: transparent;\n  cursor: text;\n  appearance: none;\n  display: block;\n  font: inherit;\n  color: inherit;\n  width: 100%;\n  outline: none;\n  border: none;\n  padding: 0;\n  opacity: ${({ open }) => (open ? 0 : 1)};\n  pointer-events: ${({ open }) => (open ? 'none' : 'auto')};\n  position: absolute;\n  top: 0;\n  left: 0;\n  transition: opacity ${getTransition('xxFast')};\n\n  .autocompleteMenuItem {\n    padding-right: 34px;\n  }\n\n  .autocompleteInput:focus-visible + & {\n    opacity: 0;\n    pointer-events: none;\n  }\n`;\n\nconst TriggerText = styled.span`\n  line-height: 1.4;\n  display: block;\n  padding-block: 0;\n  padding-left: 12px;\n  padding-right: 32px;\n  text-overflow: ellipsis;\n  overflow: hidden;\n  white-space: nowrap;\n`;\n\nexport const Autocomplete2 = ({\n  options,\n  value,\n  onChange,\n  menuPlacement = defaultProps.menuPlacement,\n  menuWidth,\n  menuMaxHeight = defaultProps.menuMaxHeight,\n  menuZIndex,\n  placeholder,\n  label,\n  hint,\n  menuItemsHaveEllipsis = true,\n  hasPortal = true,\n  hasError,\n  errorMessage,\n  searchField = 'content',\n  ...props\n}) => {\n  const [query, setQuery] = useState('');\n\n  const handleChange = option => {\n    onChange(option);\n    setQuery('');\n  };\n\n  const filteredOptions = getFilteredOptions(query, options, searchField);\n\n  const noResults = !Boolean(filteredOptions.length);\n\n  const fieldMarginTop = label || hint ? 'betweenFormControlAndLabel' : undefined;\n\n  const selectedOption = useMemo(\n    () => options.find(option => option.value === value),\n    [options, value],\n  );\n\n  const { reference, floating, floatingStyles } = useMenuPosition({ menuWidth, menuPlacement });\n\n  const OptionsRoot = hasPortal ? FloatingPortal : Fragment;\n\n  return (\n    <>\n      <Global styles={menuItemStyles} />\n      <Combobox as=\"div\" value={selectedOption || ''} onChange={handleChange} {...props}>\n        {({ open }) => {\n          const hasItem = selectedOption?.item;\n          return (\n            <>\n              {label && <Combobox.Label as={FieldLabel}>{label}</Combobox.Label>}\n              {hint && <FieldHint>{hint}</FieldHint>}\n\n              <Root marginTop={fieldMarginTop} ref={reference} open={open} hasError={hasError}>\n                <Combobox.Button as={Box} position=\"relative\">\n                  <Combobox.Input\n                    as={InputField}\n                    autoComplete=\"off\"\n                    onChange={event => setQuery(event.target.value)}\n                    placeholder={placeholder}\n                    displayValue={option => option && option.content}\n                    paddingRight=\"32px\"\n                    hasError={hasError}\n                    className=\"autocompleteInput\"\n                  />\n\n                  <Trigger open={open} className=\"autocompleteTrigger\" tabIndex={-1}>\n                    {hasItem &&\n                      selectedOption.item({\n                        isActive: false,\n                        isSelected: false,\n                        isDisabled: false,\n                      })}\n\n                    {!hasItem && selectedOption && (\n                      <TriggerText>{selectedOption?.content}</TriggerText>\n                    )}\n                  </Trigger>\n\n                  <ExpandIcon />\n                </Combobox.Button>\n\n                <OptionsRoot>\n                  <MenuCardTransition>\n                    <Combobox.Options\n                      static\n                      className=\"grn-context\"\n                      ref={floating}\n                      placement={menuPlacement}\n                      maxHeight={menuMaxHeight}\n                      as={MenuCard}\n                      zIndex={menuZIndex}\n                      style={floatingStyles}\n                      isOpen={open}\n                      paddingX=\"s\"\n                    >\n                      {filteredOptions.map((option, index) => {\n                        const showGroupTitle = getShowGroupTitle(index, option, filteredOptions);\n\n                        return (\n                          <Fragment key={index}>\n                            {showGroupTitle && (\n                              <MenuGroupTitle hasDivider={index > 0} paddingX=\"12px\">\n                                {option.groupTitle}\n                              </MenuGroupTitle>\n                            )}\n\n                            <Combobox.Option\n                              value={option}\n                              as={Fragment}\n                              disabled={option.isDisabled}\n                            >\n                              {({ active }) => {\n                                const isDisabled = option.isDisabled;\n                                const isSelected = option.value === value;\n                                const isActive = !option.isDisabled && active;\n                                const hasEllipsis = menuItemsHaveEllipsis;\n                                if (option.item) {\n                                  return option.item({\n                                    isActive,\n                                    isSelected,\n                                    isDisabled,\n                                    hasEllipsis,\n                                  });\n                                }\n                                return <Item hasEllipsis={hasEllipsis}>{option.content}</Item>;\n                              }}\n                            </Combobox.Option>\n                          </Fragment>\n                        );\n                      })}\n                      {noResults && <EmptyState />}\n                    </Combobox.Options>\n                  </MenuCardTransition>\n                </OptionsRoot>\n              </Root>\n              {errorMessage && (\n                <Box marginTop=\"betweenFormControlAndLabel\" color=\"danger\">\n                  {errorMessage}\n                </Box>\n              )}\n            </>\n          );\n        }}\n      </Combobox>\n    </>\n  );\n};\n\nAutocomplete2.Label = FieldLabel;\nAutocomplete2.Hint = FieldHint;\nAutocomplete2.Item = Item;\n\nAutocomplete2.propTypes = {\n  options: PropTypes.array,\n  value: PropTypes.string,\n  onChange: PropTypes.func.isRequired,\n  menuPlacement: types.menuPlacement,\n  menuWidth: types.dimension,\n  menuMaxHeight: types.dimension,\n  menuZIndex: types.zIndex,\n  label: types.label,\n  hint: types.hint,\n  menuItemsHaveEllipsis: PropTypes.bool,\n  hasPortal: PropTypes.bool,\n  hasError: PropTypes.bool,\n  errorMessage: PropTypes.string,\n};\n"]} */",
159
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
160
+ });
161
+
162
+ export var Autocomplete2 = function Autocomplete2(_ref9) {
163
+ var options = _ref9.options,
164
+ value = _ref9.value,
165
+ onChange = _ref9.onChange,
166
+ _ref9$menuPlacement = _ref9.menuPlacement,
167
+ menuPlacement = _ref9$menuPlacement === void 0 ? defaultProps.menuPlacement : _ref9$menuPlacement,
168
+ menuWidth = _ref9.menuWidth,
169
+ _ref9$menuMaxHeight = _ref9.menuMaxHeight,
170
+ menuMaxHeight = _ref9$menuMaxHeight === void 0 ? defaultProps.menuMaxHeight : _ref9$menuMaxHeight,
171
+ menuZIndex = _ref9.menuZIndex,
172
+ placeholder = _ref9.placeholder,
173
+ label = _ref9.label,
174
+ hint = _ref9.hint,
175
+ _ref9$menuItemsHaveEl = _ref9.menuItemsHaveEllipsis,
176
+ menuItemsHaveEllipsis = _ref9$menuItemsHaveEl === void 0 ? true : _ref9$menuItemsHaveEl,
177
+ _ref9$hasPortal = _ref9.hasPortal,
178
+ hasPortal = _ref9$hasPortal === void 0 ? true : _ref9$hasPortal,
179
+ hasError = _ref9.hasError,
180
+ errorMessage = _ref9.errorMessage,
181
+ _ref9$searchField = _ref9.searchField,
182
+ searchField = _ref9$searchField === void 0 ? 'content' : _ref9$searchField,
183
+ props = _objectWithoutProperties(_ref9, _excluded2);
184
+
185
+ var _useState = useState(''),
186
+ _useState2 = _slicedToArray(_useState, 2),
187
+ query = _useState2[0],
188
+ setQuery = _useState2[1];
189
+
190
+ var handleChange = function handleChange(option) {
191
+ onChange(option);
192
+ setQuery('');
193
+ };
194
+
195
+ var filteredOptions = getFilteredOptions(query, options, searchField);
196
+ var noResults = !Boolean(filteredOptions.length);
197
+ var fieldMarginTop = label || hint ? 'betweenFormControlAndLabel' : undefined;
198
+ var selectedOption = useMemo(function () {
199
+ return options.find(function (option) {
200
+ return option.value === value;
201
+ });
202
+ }, [options, value]);
203
+
204
+ var _useMenuPosition = useMenuPosition({
205
+ menuWidth: menuWidth,
206
+ menuPlacement: menuPlacement
207
+ }),
208
+ reference = _useMenuPosition.reference,
209
+ floating = _useMenuPosition.floating,
210
+ floatingStyles = _useMenuPosition.floatingStyles;
211
+
212
+ var OptionsRoot = hasPortal ? FloatingPortal : Fragment;
213
+ return ___EmotionJSX(React.Fragment, null, ___EmotionJSX(Global, {
214
+ styles: menuItemStyles
215
+ }), ___EmotionJSX(Combobox, _extends({
216
+ as: "div",
217
+ value: selectedOption || '',
218
+ onChange: handleChange
219
+ }, props), function (_ref10) {
220
+ var open = _ref10.open;
221
+ var hasItem = selectedOption === null || selectedOption === void 0 ? void 0 : selectedOption.item;
222
+ return ___EmotionJSX(React.Fragment, null, label && ___EmotionJSX(Combobox.Label, {
223
+ as: FieldLabel
224
+ }, label), hint && ___EmotionJSX(FieldHint, null, hint), ___EmotionJSX(Root, {
225
+ marginTop: fieldMarginTop,
226
+ ref: reference,
227
+ open: open,
228
+ hasError: hasError
229
+ }, ___EmotionJSX(Combobox.Button, {
230
+ as: Box,
231
+ position: "relative"
232
+ }, ___EmotionJSX(Combobox.Input, {
233
+ as: InputField,
234
+ autoComplete: "off",
235
+ onChange: function onChange(event) {
236
+ return setQuery(event.target.value);
237
+ },
238
+ placeholder: placeholder,
239
+ displayValue: function displayValue(option) {
240
+ return option && option.content;
241
+ },
242
+ paddingRight: "32px",
243
+ hasError: hasError,
244
+ className: "autocompleteInput"
245
+ }), ___EmotionJSX(Trigger, {
246
+ open: open,
247
+ className: "autocompleteTrigger",
248
+ tabIndex: -1
249
+ }, hasItem && selectedOption.item({
250
+ isActive: false,
251
+ isSelected: false,
252
+ isDisabled: false
253
+ }), !hasItem && selectedOption && ___EmotionJSX(TriggerText, null, selectedOption === null || selectedOption === void 0 ? void 0 : selectedOption.content)), ___EmotionJSX(ExpandIcon, null)), ___EmotionJSX(OptionsRoot, null, ___EmotionJSX(MenuCardTransition, null, ___EmotionJSX(Combobox.Options, {
254
+ static: true,
255
+ className: "grn-context",
256
+ ref: floating,
257
+ placement: menuPlacement,
258
+ maxHeight: menuMaxHeight,
259
+ as: MenuCard,
260
+ zIndex: menuZIndex,
261
+ style: floatingStyles,
262
+ isOpen: open,
263
+ paddingX: "s"
264
+ }, filteredOptions.map(function (option, index) {
265
+ var showGroupTitle = getShowGroupTitle(index, option, filteredOptions);
266
+ return ___EmotionJSX(Fragment, {
267
+ key: index
268
+ }, showGroupTitle && ___EmotionJSX(MenuGroupTitle, {
269
+ hasDivider: index > 0,
270
+ paddingX: "12px"
271
+ }, option.groupTitle), ___EmotionJSX(Combobox.Option, {
272
+ value: option,
273
+ as: Fragment,
274
+ disabled: option.isDisabled
275
+ }, function (_ref11) {
276
+ var active = _ref11.active;
277
+ var isDisabled = option.isDisabled;
278
+ var isSelected = option.value === value;
279
+ var isActive = !option.isDisabled && active;
280
+ var hasEllipsis = menuItemsHaveEllipsis;
281
+
282
+ if (option.item) {
283
+ return option.item({
284
+ isActive: isActive,
285
+ isSelected: isSelected,
286
+ isDisabled: isDisabled,
287
+ hasEllipsis: hasEllipsis
288
+ });
289
+ }
290
+
291
+ return ___EmotionJSX(Item, {
292
+ hasEllipsis: hasEllipsis
293
+ }, option.content);
294
+ }));
295
+ }), noResults && ___EmotionJSX(EmptyState, null))))), errorMessage && ___EmotionJSX(Box, {
296
+ marginTop: "betweenFormControlAndLabel",
297
+ color: "danger"
298
+ }, errorMessage));
299
+ }));
300
+ };
301
+ Autocomplete2.Label = FieldLabel;
302
+ Autocomplete2.Hint = FieldHint;
303
+ Autocomplete2.Item = Item;
304
+ Autocomplete2.propTypes = {
305
+ options: PropTypes.array,
306
+ value: PropTypes.string,
307
+ onChange: PropTypes.func.isRequired,
308
+ menuPlacement: types.menuPlacement,
309
+ menuWidth: types.dimension,
310
+ menuMaxHeight: types.dimension,
311
+ menuZIndex: types.zIndex,
312
+ label: types.label,
313
+ hint: types.hint,
314
+ menuItemsHaveEllipsis: PropTypes.bool,
315
+ hasPortal: PropTypes.bool,
316
+ hasError: PropTypes.bool,
317
+ errorMessage: PropTypes.string
318
+ };
@@ -17,6 +17,7 @@ export { Slider } from './slider';
17
17
  export { Spinner } from './spinner';
18
18
  export { Switch } from './switch';
19
19
  export { Autocomplete } from './autocomplete';
20
+ export { Autocomplete2 } from './autocomplete2';
20
21
  export { Dropdown } from './dropdown';
21
22
  export { Modal } from './modal';
22
23
  export { Link } from './link';
@@ -2,7 +2,7 @@ import "core-js/modules/es.object.keys.js";
2
2
  import "core-js/modules/es.array.index-of.js";
3
3
  import "core-js/modules/es.symbol.js";
4
4
  var _excluded = ["children"],
5
- _excluded2 = ["children", "zIndex", "placement", "maxHeight", "isOpen"],
5
+ _excluded2 = ["children", "zIndex", "placement", "maxHeight", "isOpen", "paddingX"],
6
6
  _excluded3 = ["children", "isDisabled", "hasIcon", "isSelected", "color", "columns"],
7
7
  _excluded4 = ["children", "isSelected", "isActive", "isDisabled", "icon", "variant", "hasEllipsis", "checkVariant"];
8
8
 
@@ -16,7 +16,7 @@ import "core-js/modules/es.object.assign.js";
16
16
  import React, { Fragment, forwardRef } from 'react';
17
17
  import PropTypes from 'prop-types';
18
18
  import { Global, css } from '@emotion/react';
19
- import { getColor, getDimension, getRadius, getShadow, getTransition } from '../utilities';
19
+ import { getColor, getDimension, getRadius, getShadow, getSpace, getTransition } from '../utilities';
20
20
  import { Box, Checkbox, Icon, Text } from '../components';
21
21
  import { IconCheck } from '../icons';
22
22
  import { componentVars } from './styles';
@@ -83,7 +83,7 @@ export var useMenuPosition = function useMenuPosition(_ref) {
83
83
  floatingStyles: floatingStyles
84
84
  };
85
85
  };
86
- var menuCardStyles = /*#__PURE__*/css(".menuCardLeaveTo,.menuCardEnterFrom{opacity:0;}.menuCardEnterTo{transition-duration:", getTransition('xxFast'), ";}.menuCardLeaveTo{transition-duration:", getTransition('xFast'), ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:menuCardStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/foundational/menu.jsx"],"names":[],"mappings":"AA+D0B","file":"../../src/foundational/menu.jsx","sourcesContent":["import React, { Fragment, forwardRef } from 'react';\nimport PropTypes from 'prop-types';\nimport { Global, css } from '@emotion/react';\nimport { getColor, getDimension, getRadius, getShadow, getTransition } from '../utilities';\nimport { Box, Checkbox, Icon, Text } from '../components';\nimport { IconCheck } from '../icons';\nimport { componentVars } from './styles';\nimport { autoUpdate, flip, size, useFloating } from '@floating-ui/react-dom-interactions';\nimport { Transition } from '@headlessui/react';\n\nconst cardPadding = 8;\nconst cardPaddingPx = `${cardPadding}px`;\nconst itemYPadding = 10;\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 = css`\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, ...props }, ref) => (\n  <Transition\n    as={Fragment}\n    enterFrom=\"menuCardEnterFrom\"\n    enterTo=\"menuCardEnterTo\"\n    leaveFrom=\"menuCardLeaveFrom\"\n    leaveTo=\"menuCardLeaveTo\"\n    ref={ref}\n    {...props}\n  >\n    {children}\n  </Transition>\n));\n\nexport const MenuCard = forwardRef(\n  ({ children, zIndex = 1, placement, maxHeight, isOpen, ...props }, ref) => (\n    <>\n      <Global styles={menuCardStyles} />\n      <ul\n        ref={ref}\n        css={css`\n          padding: ${cardPaddingPx} 0;\n          margin: 0;\n          background: ${getColor('floatingBackground')};\n          z-index: ${zIndex};\n          box-shadow: ${getShadow('m')};\n          border-radius: ${getRadius('m')};\n          overflow: auto;\n          max-height: ${maxHeight};\n          /* to prevent a bug: the menu is not always rmoeved from the DOM, in a animated container */\n          ${!isOpen && `pointer-events: none;`}\n\n          &:focus {\n            outline: none;\n          }\n        `}\n        {...props}\n      >\n        {children}\n      </ul>\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: componentVars.dangerIconColor,\n    iconColorActive: getColor('danger'),\n    backgroundColorActive: componentVars.clearButtonDangerBackgroundHover,\n  },\n};\n\nconst MenuItemRoot = forwardRef(\n  ({ children, isDisabled, hasIcon, isSelected, color, columns, ...props }, ref) => (\n    <li\n      ref={ref}\n      css={css`\n        display: grid;\n        grid-auto-flow: column;\n        gap: 8px;\n        ${isDisabled && `color: ${getColor('disabledContent')}`};\n        ${!isDisabled && `cursor: pointer;`};\n        align-items: center;\n        justify-content: start;\n        list-style: none;\n        padding: ${itemYPadding}px ${itemXPadding}px;\n        margin: 0 ${cardPadding}px;\n        min-height: ${componentVars.textBoxHeight};\n        border-radius: ${getRadius('s')};\n        appearance: none;\n        color: ${color};\n      `}\n      {...props}\n    >\n      {children}\n    </li>\n  ),\n);\n\nexport const MenuGroupTitle = ({ children, hasDivider }) => (\n  <Box\n    paddingX={`${cardPadding + itemXPadding}px`}\n    paddingBottom={cardPaddingPx}\n    marginTop={cardPaddingPx}\n    paddingTop={hasDivider ? `${cardPadding * 2}px` : undefined}\n    borderSide={hasDivider ? 'top' : undefined}\n  >\n    <Text variant=\"caps\">{children}</Text>\n  </Box>\n);\n\nexport const MenuItemDivider = () => (\n  <Box height={componentVars.dividerStrokeSize} marginY={1} backgroundColor=\"border\" />\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    const hasCheckbox = checkVariant === 'checkbox';\n\n    const getColumns = () => {\n      if (Boolean(icon) || hasCheckbox) 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        {hasCheckbox && <Checkbox.Box checked={isSelected} disabled={isDisabled} />}\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', 'checkbox', 'none']),\n};\n"]} */");
86
+ var menuCardStyles = /*#__PURE__*/css(".menuCardLeaveTo,.menuCardEnterFrom{opacity:0;}.menuCardEnterTo{transition-duration:", getTransition('xxFast'), ";}.menuCardLeaveTo{transition-duration:", getTransition('xFast'), ";}" + (process.env.NODE_ENV === "production" ? "" : ";label:menuCardStyles;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/foundational/menu.jsx"],"names":[],"mappings":"AAsE0B","file":"../../src/foundational/menu.jsx","sourcesContent":["import React, { Fragment, forwardRef } 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, Checkbox, Icon, Text } from '../components';\nimport { IconCheck } from '../icons';\nimport { componentVars } from './styles';\nimport { autoUpdate, flip, size, useFloating } from '@floating-ui/react-dom-interactions';\nimport { Transition } from '@headlessui/react';\n\nconst cardPadding = 8;\nconst cardPaddingPx = `${cardPadding}px`;\nconst itemYPadding = 10;\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 = css`\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, ...props }, ref) => (\n  <Transition\n    as={Fragment}\n    enterFrom=\"menuCardEnterFrom\"\n    enterTo=\"menuCardEnterTo\"\n    leaveFrom=\"menuCardLeaveFrom\"\n    leaveTo=\"menuCardLeaveTo\"\n    ref={ref}\n    {...props}\n  >\n    {children}\n  </Transition>\n));\n\nexport const MenuCard = forwardRef(\n  ({ children, zIndex = 1, placement, maxHeight, isOpen, paddingX = 0, ...props }, ref) => (\n    <>\n      <Global styles={menuCardStyles} />\n      <ul\n        ref={ref}\n        css={css`\n          padding: ${cardPaddingPx} ${getSpace(paddingX)};\n          margin: 0;\n          background: ${getColor('floatingBackground')};\n          z-index: ${zIndex};\n          box-shadow: ${getShadow('m')};\n          border-radius: ${getRadius('m')};\n          overflow: auto;\n          max-height: ${maxHeight};\n          /* to prevent a bug: the menu is not always rmoeved from the DOM, in a animated container */\n          ${!isOpen && `pointer-events: none;`}\n\n          &:focus {\n            outline: none;\n          }\n        `}\n        {...props}\n      >\n        {children}\n      </ul>\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: componentVars.dangerIconColor,\n    iconColorActive: getColor('danger'),\n    backgroundColorActive: componentVars.clearButtonDangerBackgroundHover,\n  },\n};\n\nconst MenuItemRoot = forwardRef(\n  ({ children, isDisabled, hasIcon, isSelected, color, columns, ...props }, ref) => (\n    <li\n      ref={ref}\n      css={css`\n        display: grid;\n        grid-auto-flow: column;\n        gap: 8px;\n        ${isDisabled && `color: ${getColor('disabledContent')}`};\n        ${!isDisabled && `cursor: pointer;`};\n        align-items: center;\n        justify-content: start;\n        list-style: none;\n        padding: ${itemYPadding}px ${itemXPadding}px;\n        margin: 0 ${cardPadding}px;\n        min-height: ${componentVars.textBoxHeight};\n        border-radius: ${getRadius('s')};\n        appearance: none;\n        color: ${color};\n      `}\n      {...props}\n    >\n      {children}\n    </li>\n  ),\n);\n\nexport const MenuGroupTitle = ({\n  children,\n  hasDivider,\n  paddingX = `${cardPadding + itemXPadding}px`,\n}) => (\n  <Box paddingX={getSpace(paddingX)} paddingBottom={cardPaddingPx}>\n    <Box\n      height=\"3px\"\n      borderSide={hasDivider ? 'top' : undefined}\n      marginX={`calc(-1 * (${getSpace(paddingX)} + 8px))`}\n      marginTop={cardPaddingPx}\n      paddingTop={hasDivider ? `${cardPadding * 2}px` : undefined}\n    />\n    <Text variant=\"caps\">{children}</Text>\n  </Box>\n);\n\nexport const MenuItemDivider = () => (\n  <Box height={componentVars.dividerStrokeSize} marginY={1} backgroundColor=\"border\" />\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    const hasCheckbox = checkVariant === 'checkbox';\n\n    const getColumns = () => {\n      if (Boolean(icon) || hasCheckbox) 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        {hasCheckbox && <Checkbox.Box checked={isSelected} disabled={isDisabled} />}\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', 'checkbox', 'none']),\n};\n"]} */");
87
87
  export var MenuCardTransition = /*#__PURE__*/forwardRef(function (_ref3, ref) {
88
88
  var children = _ref3.children,
89
89
  props = _objectWithoutProperties(_ref3, _excluded);
@@ -104,13 +104,15 @@ export var MenuCard = /*#__PURE__*/forwardRef(function (_ref4, ref) {
104
104
  placement = _ref4.placement,
105
105
  maxHeight = _ref4.maxHeight,
106
106
  isOpen = _ref4.isOpen,
107
+ _ref4$paddingX = _ref4.paddingX,
108
+ paddingX = _ref4$paddingX === void 0 ? 0 : _ref4$paddingX,
107
109
  props = _objectWithoutProperties(_ref4, _excluded2);
108
110
 
109
111
  return ___EmotionJSX(React.Fragment, null, ___EmotionJSX(Global, {
110
112
  styles: menuCardStyles
111
113
  }), ___EmotionJSX("ul", _extends({
112
114
  ref: ref,
113
- css: /*#__PURE__*/css("padding:", cardPaddingPx, " 0;margin:0;background:", getColor('floatingBackground'), ";z-index:", zIndex, ";box-shadow:", getShadow('m'), ";border-radius:", getRadius('m'), ";overflow:auto;max-height:", maxHeight, ";", !isOpen && "pointer-events: none;", " &:focus{outline:none;}" + (process.env.NODE_ENV === "production" ? "" : ";label:MenuCard;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/foundational/menu.jsx"],"names":[],"mappings":"AAgGgB","file":"../../src/foundational/menu.jsx","sourcesContent":["import React, { Fragment, forwardRef } from 'react';\nimport PropTypes from 'prop-types';\nimport { Global, css } from '@emotion/react';\nimport { getColor, getDimension, getRadius, getShadow, getTransition } from '../utilities';\nimport { Box, Checkbox, Icon, Text } from '../components';\nimport { IconCheck } from '../icons';\nimport { componentVars } from './styles';\nimport { autoUpdate, flip, size, useFloating } from '@floating-ui/react-dom-interactions';\nimport { Transition } from '@headlessui/react';\n\nconst cardPadding = 8;\nconst cardPaddingPx = `${cardPadding}px`;\nconst itemYPadding = 10;\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 = css`\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, ...props }, ref) => (\n  <Transition\n    as={Fragment}\n    enterFrom=\"menuCardEnterFrom\"\n    enterTo=\"menuCardEnterTo\"\n    leaveFrom=\"menuCardLeaveFrom\"\n    leaveTo=\"menuCardLeaveTo\"\n    ref={ref}\n    {...props}\n  >\n    {children}\n  </Transition>\n));\n\nexport const MenuCard = forwardRef(\n  ({ children, zIndex = 1, placement, maxHeight, isOpen, ...props }, ref) => (\n    <>\n      <Global styles={menuCardStyles} />\n      <ul\n        ref={ref}\n        css={css`\n          padding: ${cardPaddingPx} 0;\n          margin: 0;\n          background: ${getColor('floatingBackground')};\n          z-index: ${zIndex};\n          box-shadow: ${getShadow('m')};\n          border-radius: ${getRadius('m')};\n          overflow: auto;\n          max-height: ${maxHeight};\n          /* to prevent a bug: the menu is not always rmoeved from the DOM, in a animated container */\n          ${!isOpen && `pointer-events: none;`}\n\n          &:focus {\n            outline: none;\n          }\n        `}\n        {...props}\n      >\n        {children}\n      </ul>\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: componentVars.dangerIconColor,\n    iconColorActive: getColor('danger'),\n    backgroundColorActive: componentVars.clearButtonDangerBackgroundHover,\n  },\n};\n\nconst MenuItemRoot = forwardRef(\n  ({ children, isDisabled, hasIcon, isSelected, color, columns, ...props }, ref) => (\n    <li\n      ref={ref}\n      css={css`\n        display: grid;\n        grid-auto-flow: column;\n        gap: 8px;\n        ${isDisabled && `color: ${getColor('disabledContent')}`};\n        ${!isDisabled && `cursor: pointer;`};\n        align-items: center;\n        justify-content: start;\n        list-style: none;\n        padding: ${itemYPadding}px ${itemXPadding}px;\n        margin: 0 ${cardPadding}px;\n        min-height: ${componentVars.textBoxHeight};\n        border-radius: ${getRadius('s')};\n        appearance: none;\n        color: ${color};\n      `}\n      {...props}\n    >\n      {children}\n    </li>\n  ),\n);\n\nexport const MenuGroupTitle = ({ children, hasDivider }) => (\n  <Box\n    paddingX={`${cardPadding + itemXPadding}px`}\n    paddingBottom={cardPaddingPx}\n    marginTop={cardPaddingPx}\n    paddingTop={hasDivider ? `${cardPadding * 2}px` : undefined}\n    borderSide={hasDivider ? 'top' : undefined}\n  >\n    <Text variant=\"caps\">{children}</Text>\n  </Box>\n);\n\nexport const MenuItemDivider = () => (\n  <Box height={componentVars.dividerStrokeSize} marginY={1} backgroundColor=\"border\" />\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    const hasCheckbox = checkVariant === 'checkbox';\n\n    const getColumns = () => {\n      if (Boolean(icon) || hasCheckbox) 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        {hasCheckbox && <Checkbox.Box checked={isSelected} disabled={isDisabled} />}\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', 'checkbox', 'none']),\n};\n"]} */")
115
+ css: /*#__PURE__*/css("padding:", cardPaddingPx, " ", getSpace(paddingX), ";margin:0;background:", getColor('floatingBackground'), ";z-index:", zIndex, ";box-shadow:", getShadow('m'), ";border-radius:", getRadius('m'), ";overflow:auto;max-height:", maxHeight, ";", !isOpen && "pointer-events: none;", " &:focus{outline:none;}" + (process.env.NODE_ENV === "production" ? "" : ";label:MenuCard;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/foundational/menu.jsx"],"names":[],"mappings":"AAuGgB","file":"../../src/foundational/menu.jsx","sourcesContent":["import React, { Fragment, forwardRef } 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, Checkbox, Icon, Text } from '../components';\nimport { IconCheck } from '../icons';\nimport { componentVars } from './styles';\nimport { autoUpdate, flip, size, useFloating } from '@floating-ui/react-dom-interactions';\nimport { Transition } from '@headlessui/react';\n\nconst cardPadding = 8;\nconst cardPaddingPx = `${cardPadding}px`;\nconst itemYPadding = 10;\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 = css`\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, ...props }, ref) => (\n  <Transition\n    as={Fragment}\n    enterFrom=\"menuCardEnterFrom\"\n    enterTo=\"menuCardEnterTo\"\n    leaveFrom=\"menuCardLeaveFrom\"\n    leaveTo=\"menuCardLeaveTo\"\n    ref={ref}\n    {...props}\n  >\n    {children}\n  </Transition>\n));\n\nexport const MenuCard = forwardRef(\n  ({ children, zIndex = 1, placement, maxHeight, isOpen, paddingX = 0, ...props }, ref) => (\n    <>\n      <Global styles={menuCardStyles} />\n      <ul\n        ref={ref}\n        css={css`\n          padding: ${cardPaddingPx} ${getSpace(paddingX)};\n          margin: 0;\n          background: ${getColor('floatingBackground')};\n          z-index: ${zIndex};\n          box-shadow: ${getShadow('m')};\n          border-radius: ${getRadius('m')};\n          overflow: auto;\n          max-height: ${maxHeight};\n          /* to prevent a bug: the menu is not always rmoeved from the DOM, in a animated container */\n          ${!isOpen && `pointer-events: none;`}\n\n          &:focus {\n            outline: none;\n          }\n        `}\n        {...props}\n      >\n        {children}\n      </ul>\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: componentVars.dangerIconColor,\n    iconColorActive: getColor('danger'),\n    backgroundColorActive: componentVars.clearButtonDangerBackgroundHover,\n  },\n};\n\nconst MenuItemRoot = forwardRef(\n  ({ children, isDisabled, hasIcon, isSelected, color, columns, ...props }, ref) => (\n    <li\n      ref={ref}\n      css={css`\n        display: grid;\n        grid-auto-flow: column;\n        gap: 8px;\n        ${isDisabled && `color: ${getColor('disabledContent')}`};\n        ${!isDisabled && `cursor: pointer;`};\n        align-items: center;\n        justify-content: start;\n        list-style: none;\n        padding: ${itemYPadding}px ${itemXPadding}px;\n        margin: 0 ${cardPadding}px;\n        min-height: ${componentVars.textBoxHeight};\n        border-radius: ${getRadius('s')};\n        appearance: none;\n        color: ${color};\n      `}\n      {...props}\n    >\n      {children}\n    </li>\n  ),\n);\n\nexport const MenuGroupTitle = ({\n  children,\n  hasDivider,\n  paddingX = `${cardPadding + itemXPadding}px`,\n}) => (\n  <Box paddingX={getSpace(paddingX)} paddingBottom={cardPaddingPx}>\n    <Box\n      height=\"3px\"\n      borderSide={hasDivider ? 'top' : undefined}\n      marginX={`calc(-1 * (${getSpace(paddingX)} + 8px))`}\n      marginTop={cardPaddingPx}\n      paddingTop={hasDivider ? `${cardPadding * 2}px` : undefined}\n    />\n    <Text variant=\"caps\">{children}</Text>\n  </Box>\n);\n\nexport const MenuItemDivider = () => (\n  <Box height={componentVars.dividerStrokeSize} marginY={1} backgroundColor=\"border\" />\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    const hasCheckbox = checkVariant === 'checkbox';\n\n    const getColumns = () => {\n      if (Boolean(icon) || hasCheckbox) 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        {hasCheckbox && <Checkbox.Box checked={isSelected} disabled={isDisabled} />}\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', 'checkbox', 'none']),\n};\n"]} */")
114
116
  }, props), children));
115
117
  });
116
118
  var variantStyles = {
@@ -136,19 +138,24 @@ var MenuItemRoot = /*#__PURE__*/forwardRef(function (_ref5, ref) {
136
138
 
137
139
  return ___EmotionJSX("li", _extends({
138
140
  ref: ref,
139
- css: /*#__PURE__*/css("display:grid;grid-auto-flow:column;gap:8px;", isDisabled && "color: ".concat(getColor('disabledContent')), ";", !isDisabled && "cursor: pointer;", ";align-items:center;justify-content:start;list-style:none;padding:", itemYPadding, "px ", itemXPadding, "px;margin:0 ", cardPadding, "px;min-height:", componentVars.textBoxHeight, ";border-radius:", getRadius('s'), ";appearance:none;color:", color, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:MenuItemRoot;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/foundational/menu.jsx"],"names":[],"mappings":"AAyIc","file":"../../src/foundational/menu.jsx","sourcesContent":["import React, { Fragment, forwardRef } from 'react';\nimport PropTypes from 'prop-types';\nimport { Global, css } from '@emotion/react';\nimport { getColor, getDimension, getRadius, getShadow, getTransition } from '../utilities';\nimport { Box, Checkbox, Icon, Text } from '../components';\nimport { IconCheck } from '../icons';\nimport { componentVars } from './styles';\nimport { autoUpdate, flip, size, useFloating } from '@floating-ui/react-dom-interactions';\nimport { Transition } from '@headlessui/react';\n\nconst cardPadding = 8;\nconst cardPaddingPx = `${cardPadding}px`;\nconst itemYPadding = 10;\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 = css`\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, ...props }, ref) => (\n  <Transition\n    as={Fragment}\n    enterFrom=\"menuCardEnterFrom\"\n    enterTo=\"menuCardEnterTo\"\n    leaveFrom=\"menuCardLeaveFrom\"\n    leaveTo=\"menuCardLeaveTo\"\n    ref={ref}\n    {...props}\n  >\n    {children}\n  </Transition>\n));\n\nexport const MenuCard = forwardRef(\n  ({ children, zIndex = 1, placement, maxHeight, isOpen, ...props }, ref) => (\n    <>\n      <Global styles={menuCardStyles} />\n      <ul\n        ref={ref}\n        css={css`\n          padding: ${cardPaddingPx} 0;\n          margin: 0;\n          background: ${getColor('floatingBackground')};\n          z-index: ${zIndex};\n          box-shadow: ${getShadow('m')};\n          border-radius: ${getRadius('m')};\n          overflow: auto;\n          max-height: ${maxHeight};\n          /* to prevent a bug: the menu is not always rmoeved from the DOM, in a animated container */\n          ${!isOpen && `pointer-events: none;`}\n\n          &:focus {\n            outline: none;\n          }\n        `}\n        {...props}\n      >\n        {children}\n      </ul>\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: componentVars.dangerIconColor,\n    iconColorActive: getColor('danger'),\n    backgroundColorActive: componentVars.clearButtonDangerBackgroundHover,\n  },\n};\n\nconst MenuItemRoot = forwardRef(\n  ({ children, isDisabled, hasIcon, isSelected, color, columns, ...props }, ref) => (\n    <li\n      ref={ref}\n      css={css`\n        display: grid;\n        grid-auto-flow: column;\n        gap: 8px;\n        ${isDisabled && `color: ${getColor('disabledContent')}`};\n        ${!isDisabled && `cursor: pointer;`};\n        align-items: center;\n        justify-content: start;\n        list-style: none;\n        padding: ${itemYPadding}px ${itemXPadding}px;\n        margin: 0 ${cardPadding}px;\n        min-height: ${componentVars.textBoxHeight};\n        border-radius: ${getRadius('s')};\n        appearance: none;\n        color: ${color};\n      `}\n      {...props}\n    >\n      {children}\n    </li>\n  ),\n);\n\nexport const MenuGroupTitle = ({ children, hasDivider }) => (\n  <Box\n    paddingX={`${cardPadding + itemXPadding}px`}\n    paddingBottom={cardPaddingPx}\n    marginTop={cardPaddingPx}\n    paddingTop={hasDivider ? `${cardPadding * 2}px` : undefined}\n    borderSide={hasDivider ? 'top' : undefined}\n  >\n    <Text variant=\"caps\">{children}</Text>\n  </Box>\n);\n\nexport const MenuItemDivider = () => (\n  <Box height={componentVars.dividerStrokeSize} marginY={1} backgroundColor=\"border\" />\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    const hasCheckbox = checkVariant === 'checkbox';\n\n    const getColumns = () => {\n      if (Boolean(icon) || hasCheckbox) 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        {hasCheckbox && <Checkbox.Box checked={isSelected} disabled={isDisabled} />}\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', 'checkbox', 'none']),\n};\n"]} */")
141
+ css: /*#__PURE__*/css("display:grid;grid-auto-flow:column;gap:8px;", isDisabled && "color: ".concat(getColor('disabledContent')), ";", !isDisabled && "cursor: pointer;", ";align-items:center;justify-content:start;list-style:none;padding:", itemYPadding, "px ", itemXPadding, "px;margin:0 ", cardPadding, "px;min-height:", componentVars.textBoxHeight, ";border-radius:", getRadius('s'), ";appearance:none;color:", color, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:MenuItemRoot;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/foundational/menu.jsx"],"names":[],"mappings":"AAgJc","file":"../../src/foundational/menu.jsx","sourcesContent":["import React, { Fragment, forwardRef } 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, Checkbox, Icon, Text } from '../components';\nimport { IconCheck } from '../icons';\nimport { componentVars } from './styles';\nimport { autoUpdate, flip, size, useFloating } from '@floating-ui/react-dom-interactions';\nimport { Transition } from '@headlessui/react';\n\nconst cardPadding = 8;\nconst cardPaddingPx = `${cardPadding}px`;\nconst itemYPadding = 10;\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 = css`\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, ...props }, ref) => (\n  <Transition\n    as={Fragment}\n    enterFrom=\"menuCardEnterFrom\"\n    enterTo=\"menuCardEnterTo\"\n    leaveFrom=\"menuCardLeaveFrom\"\n    leaveTo=\"menuCardLeaveTo\"\n    ref={ref}\n    {...props}\n  >\n    {children}\n  </Transition>\n));\n\nexport const MenuCard = forwardRef(\n  ({ children, zIndex = 1, placement, maxHeight, isOpen, paddingX = 0, ...props }, ref) => (\n    <>\n      <Global styles={menuCardStyles} />\n      <ul\n        ref={ref}\n        css={css`\n          padding: ${cardPaddingPx} ${getSpace(paddingX)};\n          margin: 0;\n          background: ${getColor('floatingBackground')};\n          z-index: ${zIndex};\n          box-shadow: ${getShadow('m')};\n          border-radius: ${getRadius('m')};\n          overflow: auto;\n          max-height: ${maxHeight};\n          /* to prevent a bug: the menu is not always rmoeved from the DOM, in a animated container */\n          ${!isOpen && `pointer-events: none;`}\n\n          &:focus {\n            outline: none;\n          }\n        `}\n        {...props}\n      >\n        {children}\n      </ul>\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: componentVars.dangerIconColor,\n    iconColorActive: getColor('danger'),\n    backgroundColorActive: componentVars.clearButtonDangerBackgroundHover,\n  },\n};\n\nconst MenuItemRoot = forwardRef(\n  ({ children, isDisabled, hasIcon, isSelected, color, columns, ...props }, ref) => (\n    <li\n      ref={ref}\n      css={css`\n        display: grid;\n        grid-auto-flow: column;\n        gap: 8px;\n        ${isDisabled && `color: ${getColor('disabledContent')}`};\n        ${!isDisabled && `cursor: pointer;`};\n        align-items: center;\n        justify-content: start;\n        list-style: none;\n        padding: ${itemYPadding}px ${itemXPadding}px;\n        margin: 0 ${cardPadding}px;\n        min-height: ${componentVars.textBoxHeight};\n        border-radius: ${getRadius('s')};\n        appearance: none;\n        color: ${color};\n      `}\n      {...props}\n    >\n      {children}\n    </li>\n  ),\n);\n\nexport const MenuGroupTitle = ({\n  children,\n  hasDivider,\n  paddingX = `${cardPadding + itemXPadding}px`,\n}) => (\n  <Box paddingX={getSpace(paddingX)} paddingBottom={cardPaddingPx}>\n    <Box\n      height=\"3px\"\n      borderSide={hasDivider ? 'top' : undefined}\n      marginX={`calc(-1 * (${getSpace(paddingX)} + 8px))`}\n      marginTop={cardPaddingPx}\n      paddingTop={hasDivider ? `${cardPadding * 2}px` : undefined}\n    />\n    <Text variant=\"caps\">{children}</Text>\n  </Box>\n);\n\nexport const MenuItemDivider = () => (\n  <Box height={componentVars.dividerStrokeSize} marginY={1} backgroundColor=\"border\" />\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    const hasCheckbox = checkVariant === 'checkbox';\n\n    const getColumns = () => {\n      if (Boolean(icon) || hasCheckbox) 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        {hasCheckbox && <Checkbox.Box checked={isSelected} disabled={isDisabled} />}\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', 'checkbox', 'none']),\n};\n"]} */")
140
142
  }, props), children);
141
143
  });
142
144
  export var MenuGroupTitle = function MenuGroupTitle(_ref6) {
143
145
  var children = _ref6.children,
144
- hasDivider = _ref6.hasDivider;
146
+ hasDivider = _ref6.hasDivider,
147
+ _ref6$paddingX = _ref6.paddingX,
148
+ paddingX = _ref6$paddingX === void 0 ? "".concat(cardPadding + itemXPadding, "px") : _ref6$paddingX;
145
149
  return ___EmotionJSX(Box, {
146
- paddingX: "".concat(cardPadding + itemXPadding, "px"),
147
- paddingBottom: cardPaddingPx,
150
+ paddingX: getSpace(paddingX),
151
+ paddingBottom: cardPaddingPx
152
+ }, ___EmotionJSX(Box, {
153
+ height: "3px",
154
+ borderSide: hasDivider ? 'top' : undefined,
155
+ marginX: "calc(-1 * (".concat(getSpace(paddingX), " + 8px))"),
148
156
  marginTop: cardPaddingPx,
149
- paddingTop: hasDivider ? "".concat(cardPadding * 2, "px") : undefined,
150
- borderSide: hasDivider ? 'top' : undefined
151
- }, ___EmotionJSX(Text, {
157
+ paddingTop: hasDivider ? "".concat(cardPadding * 2, "px") : undefined
158
+ }), ___EmotionJSX(Text, {
152
159
  variant: "caps"
153
160
  }, children));
154
161
  };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@flodesk/grain",
3
- "version": "10.5.8",
3
+ "version": "10.6.0",
4
4
  "description": "Flodesk design system",
5
5
  "module": "es/index.js",
6
6
  "author": "Flodesk",